:root,[data-theme=dark]{--color-bg:#0e0c0c;--color-surface:#141111;--color-surface-2:#1a1717;--color-surface-offset:#201c1c;--color-surface-dynamic:#2a2525;--color-divider:#2e2828;--color-border:#3a3333;--color-text:#e8e0dc;--color-text-muted:#8a7f7c;--color-text-faint:#4a4240;--color-text-inverse:#0e0c0c;--color-primary:#c0392b;--color-primary-hover:#e74c3c;--color-primary-active:#922b21;--color-primary-highlight:#2c1512;--color-secondary:#7b2d2d;--color-secondary-hover:#922b21;--color-success:#4a7c59;--color-success-highlight:#1a2e20;--color-error:#e74c3c;--color-error-highlight:#2c1512;--color-warning:#c07c2b;--color-warning-highlight:#2c1e0f;--shadow-sm:0 1px 3px oklch(0% 0 0/.4);--shadow-md:0 4px 16px oklch(0% 0 0/.5);--shadow-lg:0 8px 24px oklch(0% 0 0/.5);--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-full:9999px;--transition-interactive:.16s cubic-bezier(.16, 1, .3, 1);--font-display:"Cinzel", "Georgia", serif;--font-body:"Inter", "system-ui", sans-serif;--sidebar-width:260px;--text-xs:.7rem;--text-sm:.8rem;--text-base:.875rem;--bg-primary:var(--color-bg);--bg-card:var(--color-surface);--bg-card-hover:var(--color-surface-offset);--accent:var(--color-primary);--accent-hover:var(--color-primary-hover);--accent-muted:var(--color-primary-highlight);--text-primary:var(--color-text);--text-muted:var(--color-text-muted);--text-dim:var(--color-text-faint);--border-subtle:var(--color-border);--shadow:var(--shadow-md);--radius:var(--radius-md);--font-heading:var(--font-display);--transition:var(--transition-interactive)}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}#root{height:100%;display:flex}button,input,select,textarea{font-family:inherit;font-size:inherit}button{cursor:pointer;background:0 0;border:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.app{width:100%;height:100vh;display:flex;overflow:hidden}.editor-wrapper{flex:1;min-width:0;display:flex;overflow:hidden}.library-sidebar{background:var(--color-bg);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;transition:width .2s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden}.library-sidebar.open{width:280px}.library-sidebar.collapsed{width:48px}.library-header{background:var(--color-bg);z-index:2;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 12px;display:flex;position:sticky;top:0}.library-title{font-family:var(--font-display);font-size:var(--text-sm);letter-spacing:.08em;color:var(--color-text);font-weight:600}.library-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.library-card-entry{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border-left:2px solid #0000;align-items:center;gap:10px;padding:8px 10px;display:flex;position:relative}.library-card-entry:hover{background:var(--color-surface-offset)}.library-card-entry.active{background:var(--color-surface-offset);border-left-color:var(--color-primary)}.library-card-avatar{border-radius:var(--radius-sm);flex-shrink:0;width:32px;height:32px;overflow:hidden}.library-card-avatar img{object-fit:cover;width:100%;height:100%}.library-avatar-placeholder{background:var(--color-surface-offset);width:100%;height:100%;color:var(--color-text-faint);justify-content:center;align-items:center;font-size:.8rem;font-weight:600;display:flex}.library-card-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.library-card-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.library-card-time{color:var(--color-text-faint);font-size:.7rem}.library-card-delete{opacity:0;color:var(--color-text-faint);border-radius:var(--radius-sm);transition:all var(--transition);cursor:pointer;background:0 0;padding:4px;font-size:.8rem;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.library-card-entry:hover .library-card-delete{opacity:1}.library-card-delete:hover{color:var(--color-error);background:var(--color-error-highlight)}.library-empty{text-align:center;color:var(--color-text-faint);padding:24px 8px;font-size:.8rem;font-style:italic}.library-toggle{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm) 0 0 var(--radius-sm);width:24px;height:48px;color:var(--color-text-muted);cursor:pointer;z-index:3;transition:all var(--transition);border-right:none;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.library-sidebar.collapsed .library-toggle{border-radius:var(--radius-sm);border-right:1px solid var(--color-border);width:32px;height:48px;left:50%;transform:translate(-50%,-50%)}.library-toggle:hover{color:var(--color-text);background:var(--color-surface-offset)}.save-btn{position:relative}.unsaved-dot{background:#8b0000;border-radius:50%;width:6px;height:6px;display:inline-block;position:absolute;top:3px;right:3px}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:10;flex-direction:column;gap:20px;padding:20px;display:flex;position:relative;overflow-y:auto}.sidebar-header{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding-bottom:12px;display:flex}.header-actions{align-items:center;gap:4px;display:flex}.app-title-wrapper{align-items:center;gap:10px;display:flex}.app-title{color:var(--color-primary);letter-spacing:.05em;margin:0;font-family:Cinzel Decorative,Cinzel,Georgia,serif;font-size:1.1rem;font-weight:600}.app-title-tome{opacity:.75;pointer-events:none;width:96px;height:auto;transition:opacity;transform:translate(3px,3px)}.app-title-tome:hover{opacity:.55}.settings-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--color-text-muted);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.settings-btn:hover{background:var(--color-surface-offset);color:var(--color-text)}.settings-btn-top{width:44px;color:var(--color-text-muted);border:none;border-left:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.settings-btn-top:hover{background:var(--color-surface-offset);color:var(--color-text)}.patreon-btn-top{color:#ff5900;border:none;border-left:1px solid var(--color-border);cursor:pointer;width:44px;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.patreon-btn-top:hover{background:var(--color-surface-offset);color:#ff7a33}.patreon-btn-top svg{flex-shrink:0;display:block}.btn-ghost{color:var(--color-text-muted);border-radius:var(--radius-sm);border:1px solid var(--color-border);transition:all var(--transition);background:0 0;padding:6px 12px;font-size:.85rem}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-ghost.active{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-highlight)}.import-dropdown{position:relative}.import-dropdown-menu{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:100;min-width:160px;margin-top:4px;position:absolute;top:100%;left:0;overflow:hidden}.import-dropdown-option{width:100%;color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition);background:0 0;border:none;align-items:center;gap:8px;padding:10px 14px;font-size:.85rem;display:flex}.import-dropdown-option:hover{background:var(--color-surface-offset)}.toast-container{z-index:2000;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:12px 20px;font-size:.9rem;font-weight:500;animation:.3s toastSlideIn}@keyframes toastSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-success{background:var(--color-success);color:#e8e0dc}.toast-error{background:var(--color-error);color:#fff}.toast-warning{color:#d4924a;background:#2a2214;border:1px solid #c0852b55}.toast-info{color:#9a9896;background:#1c1b19;border:1px solid #3a3836}.import-bar{background:var(--color-surface-offset);border-radius:var(--radius-md);border:1px solid var(--color-border);flex-direction:column;gap:10px;padding:12px;animation:.2s slideDown;display:flex}.import-bar-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:500}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.import-input-row{align-items:center;gap:10px;display:flex}.import-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);min-width:0;color:var(--color-text);transition:border-color var(--transition), box-shadow var(--transition);text-overflow:ellipsis;white-space:nowrap;flex:1;padding:10px 14px;font-size:.9rem;overflow:hidden}.import-input::placeholder{color:var(--color-text-faint)}.import-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-highlight);outline:none}.detection-label{white-space:nowrap;border-radius:var(--radius-sm);padding:4px 8px;font-size:.75rem;font-weight:500}.detection-label.detected{color:var(--color-primary);background:var(--color-primary-highlight)}.detection-label.unknown{color:var(--color-text-faint);background:var(--color-surface-offset)}.import-error{color:var(--color-error);background:var(--color-error-highlight);border-radius:var(--radius-sm);border-left:3px solid var(--color-error);padding:8px 12px;font-size:.85rem}.import-actions{align-items:center;gap:10px;display:flex}.import-dismiss{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition);background:0 0;padding:4px 8px;font-size:1rem}.import-dismiss:hover{color:var(--color-text)}.avatar-section{justify-content:center;display:flex}.avatar-upload{border-radius:var(--radius-md);cursor:pointer;width:150px;height:150px;transition:all var(--transition);overflow:hidden}.avatar-upload:not(.has-image){border:1px solid var(--color-border);background:var(--color-surface-offset);justify-content:center;align-items:center;display:flex}.avatar-upload:not(.has-image):hover{border-color:var(--color-primary)}.avatar-upload.has-image{box-shadow:var(--shadow-sm);overflow:visible}.avatar-upload img{object-fit:cover;width:100%;height:100%}.avatar-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.plus-icon{color:var(--color-text-faint);transition:color var(--transition);font-size:2.5rem;font-weight:300}.avatar-upload:hover .plus-icon{color:var(--color-primary)}.avatar-magnifier-wrapper{cursor:crosshair;flex-shrink:0;position:relative}.avatar-main-img{object-fit:cover;border:1px solid #2a2826;border-radius:6px;width:100%;height:100%;display:block}.avatar-preview-panel{pointer-events:none;z-index:100;background-repeat:no-repeat;border:1px solid #3a3836;border-radius:8px;width:220px;height:220px;position:fixed;box-shadow:0 8px 32px #0009,0 0 0 1px #c0392b26;-webkit-mask-image:radial-gradient(#000 60%,#0000 100%);mask-image:radial-gradient(#000 60%,#0000 100%)}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.75rem;font-weight:500}.name-input{border:none;border-bottom:1px solid var(--color-border);color:var(--color-text);transition:border-color var(--transition);background:0 0;padding:8px 0;font-size:1.1rem}.name-input::placeholder{color:var(--color-text-faint)}.name-input:focus{border-bottom-color:var(--color-primary);outline:none}.text-input{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);transition:border-color var(--transition), box-shadow var(--transition);padding:10px 14px;font-size:.9rem}.text-input::placeholder{color:var(--color-text-faint)}.text-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-highlight);outline:none}.select-input{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a7f7c' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding:10px 32px 10px 14px;font-size:.9rem}.select-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-highlight);outline:none}.select-input option{background:var(--color-surface-2);color:var(--color-text)}.sidebar-actions{flex-direction:column;gap:10px;margin-top:auto;display:flex}.btn{border-radius:var(--radius-md);transition:all var(--transition);justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-size:.9rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border:1px solid #0000}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-primary:active:not(:disabled){background:var(--color-primary-active)}.btn-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);background:0 0}.btn-secondary:hover:not(:disabled){color:var(--color-primary);border-color:var(--color-primary)}.main-content{background:var(--color-bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.main-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);align-items:stretch;display:flex}.tab-bar{background:var(--color-surface);flex-wrap:wrap;flex:1;gap:0;min-width:0;padding:0 20px;display:flex}.tab{color:var(--color-text-muted);transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 16px;font-size:.85rem;font-weight:500;position:relative}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-text);border-bottom-color:var(--color-primary);background:0 0}.tab.active:after{display:none}.editor-area{flex:1;padding:20px;overflow:hidden}.field-textarea{border-radius:var(--radius-md);width:100%;height:100%;color:var(--color-text);resize:none;transition:border-color var(--transition), box-shadow var(--transition);border:none;padding:20px;font-size:.95rem;line-height:1.7;background:0 0!important}.field-textarea::placeholder{color:var(--color-text-faint)}.field-textarea:focus{box-shadow:none;outline:none}.rune-field{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);height:100%;position:relative;overflow:hidden}.rune-field:before{content:"";pointer-events:none;z-index:0;opacity:.25;background-image:url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='420' height='320' viewBox='0 0 420 320'><g fill='none' stroke='%23c0392b' stroke-linecap='round' stroke-linejoin='round'><g transform='translate(32,178)'><line x1='0' y1='0' x2='0' y2='46' stroke-width='1.8'/><line x1='0' y1='12' x2='19' y2='5' stroke-width='1.4'/><line x1='0' y1='25' x2='19' y2='18' stroke-width='1.4'/></g><g transform='translate(122,218)'><line x1='0' y1='0' x2='0' y2='44' stroke-width='1.8'/><line x1='0' y1='0' x2='-15' y2='17' stroke-width='1.4'/><line x1='0' y1='0' x2='15' y2='17' stroke-width='1.4'/></g><g transform='translate(210,152)'><line x1='0' y1='24' x2='0' y2='54' stroke-width='1.8'/><line x1='0' y1='24' x2='-17' y2='0' stroke-width='1.4'/><line x1='0' y1='24' x2='17' y2='0' stroke-width='1.4'/><line x1='0' y1='24' x2='0' y2='8' stroke-width='1.4'/></g><g transform='translate(62,60)'><line x1='0' y1='0' x2='0' y2='38' stroke-width='1.8'/><path d='M0,0 Q17,-10 17,18' stroke-width='1.4'/><line x1='17' y1='18' x2='17' y2='38' stroke-width='1.4'/></g><g transform='translate(258,65)'><line x1='0' y1='0' x2='0' y2='42' stroke-width='1.8'/><line x1='19' y1='0' x2='19' y2='42' stroke-width='1.8'/><line x1='0' y1='9' x2='19' y2='33' stroke-width='1.4'/></g><g transform='translate(168,22)'><line x1='0' y1='0' x2='0' y2='34' stroke-width='1.8'/><line x1='-11' y1='9' x2='11' y2='23' stroke-width='1.4'/></g><g transform='translate(325,215)'><polygon points='0,-21 15,0 0,21 -15,0' stroke-width='1.4'/><line x1='-15' y1='0' x2='-23' y2='13' stroke-width='1.4'/><line x1='15' y1='0' x2='23' y2='13' stroke-width='1.4'/></g><g transform='translate(375,242)'><line x1='0' y1='-22' x2='0' y2='24' stroke-width='1.8'/><path d='M0,-22 Q21,-22 21,-2 Q21,14 0,10' stroke-width='1.4'/><line x1='0' y1='10' x2='19' y2='24' stroke-width='1.4'/></g><g transform='translate(72,258)'><line x1='0' y1='-18' x2='0' y2='18' stroke-width='1.8'/><path d='M0,-18 Q19,-18 19,-4 Q19,9 0,9' stroke-width='1.4'/></g><g transform='translate(378,82)'><line x1='0' y1='0' x2='0' y2='40' stroke-width='1.8'/><line x1='-6' y1='0' x2='6' y2='0' stroke-width='1.2'/><line x1='-6' y1='40' x2='6' y2='40' stroke-width='1.2'/></g><g transform='translate(166,238)'><line x1='0' y1='-16' x2='0' y2='16' stroke-width='1.8'/><path d='M0,-16 Q17,-8 0,0' stroke-width='1.4'/><path d='M0,0 Q19,9 0,16' stroke-width='1.4'/></g><g transform='translate(310,75)'><line x1='0' y1='-20' x2='0' y2='20' stroke-width='1.8'/><line x1='0' y1='-20' x2='-12' y2='-8' stroke-width='1.4'/><line x1='0' y1='20' x2='12' y2='8' stroke-width='1.4'/></g><g transform='translate(140,90)'><line x1='-16' y1='-16' x2='16' y2='16' stroke-width='1.4'/><line x1='-16' y1='16' x2='16' y2='-16' stroke-width='1.4'/><line x1='-16' y1='-16' x2='-16' y2='16' stroke-width='1.4'/><line x1='16' y1='-16' x2='16' y2='16' stroke-width='1.4'/></g><g transform='translate(240,135)'><circle cx='0' cy='0' r='21' stroke-width='1.2'/><line x1='-21' y1='0' x2='21' y2='0' stroke-width='1'/><line x1='0' y1='-21' x2='0' y2='21' stroke-width='1'/></g><g transform='translate(302,152)'><polygon points='0,-23 21,13 -21,13' stroke-width='1.2'/><line x1='0' y1='-23' x2='0' y2='13' stroke-width='0.8'/></g><g transform='translate(155,190)'><line x1='-13' y1='0' x2='13' y2='0' stroke-width='1.2'/><line x1='0' y1='-13' x2='0' y2='13' stroke-width='1.2'/><line x1='-9' y1='-9' x2='9' y2='9' stroke-width='1'/><line x1='9' y1='-9' x2='-9' y2='9' stroke-width='1'/></g><g transform='translate(88,160)'><circle cx='0' cy='0' r='10' stroke-width='1'/><circle cx='0' cy='0' r='5' stroke-width='0.8'/></g><circle cx='192' cy='275' r='2.2' fill='%23c0392b' stroke='none'/><circle cx='142' cy='295' r='1.6' fill='%23c0392b' stroke='none'/><circle cx='96' cy='200' r='2' fill='%23c0392b' stroke='none'/><circle cx='345' cy='108' r='1.8' fill='%23c0392b' stroke='none'/><circle cx='280' cy='295' r='2' fill='%23c0392b' stroke='none'/></g></svg>");background-repeat:repeat;background-size:420px 320px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0000 28%,#0000002e 45%,#0000008c 75%,#000000e6 100%);mask-image:linear-gradient(#0000 28%,#0000002e 45%,#0000008c 75%,#000000e6 100%)}.rune-field textarea{z-index:1;background:0 0;position:relative}.undo-redo-overlay{z-index:2;gap:2px;display:flex;position:absolute;bottom:10px;right:10px}.undo-redo-btn{width:30px;height:30px;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;display:flex}.undo-redo-btn:hover:not(:disabled){color:var(--color-text);background:#ffffff14}.undo-redo-btn:active:not(:disabled){color:var(--color-primary);background:#ffffff1f}.undo-redo-btn:disabled{opacity:.25;cursor:not-allowed}.undo-redo-btn svg{flex-shrink:0;display:block}.editor-footer{background:var(--color-surface);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.word-count{font-size:var(--text-xs);color:var(--color-text-faint);font-variant-numeric:tabular-nums}.editor-meta-left{align-items:center;gap:12px;display:flex}.editor-actions{align-items:center;gap:10px;display:flex}.token-count{font-size:var(--text-xs);font-variant-numeric:tabular-nums;transition:color var(--transition)}.total-token-count{font-size:var(--text-xs);font-variant-numeric:tabular-nums;letter-spacing:.02em;transition:color var(--transition);font-weight:500}.action-bar{background:var(--color-surface);border-top:1px solid var(--color-border);align-items:center;gap:16px;padding:12px 20px;display:flex}.action-spacer{flex:1}.export-actions{gap:12px;display:flex}.export-json-wrapper{align-items:stretch;display:flex}.export-format-dropdown{align-items:stretch;display:flex;position:relative}.export-format-trigger{color:var(--color-text-muted);border:none;border-left:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);border-radius:0 var(--radius-md) var(--radius-md) 0;background:0 0;margin-left:-1px;padding:0 8px;font-size:.7rem}.export-format-trigger:hover{color:var(--color-text);background:var(--color-surface-offset)}.export-format-menu{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:100;min-width:180px;margin-bottom:4px;position:absolute;bottom:100%;right:0;overflow:hidden}.export-format-option{width:100%;color:var(--color-text);text-align:left;cursor:pointer;transition:background var(--transition);background:0 0;border:none;padding:10px 14px;font-size:.85rem;display:block}.export-format-option:hover{background:var(--color-surface-offset)}.export-format-option.selected{color:var(--color-primary);background:var(--color-primary-highlight)}.modal-overlay{z-index:1000;background:#0e0c0cb3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.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:400px;animation:.15s slideIn;overflow:visible}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h2{font-family:var(--font-display);color:var(--color-text);letter-spacing:.03em;margin:0;font-size:1.1rem;font-weight:600}.modal-close{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;font-size:1.5rem;line-height:1;display:flex}.modal-close:hover{background:var(--color-surface-offset);color:var(--color-text)}.modal-content{padding:20px;overflow:visible}.modal-content .input-label{margin-bottom:8px}.modal-content .text-input{width:100%}.input-hint{color:var(--color-text-faint);margin:10px 0 0;font-size:.8rem}.input-hint a{color:var(--color-primary);text-decoration:none}.input-hint a:hover{text-decoration:underline}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:10px;padding:16px 20px;display:flex}.score-card-trigger{border-bottom:1px solid var(--color-border);justify-content:center;padding-bottom:10px;display:flex}.score-card-btn{border:1px solid var(--color-primary);width:100%;color:var(--color-primary);background:0 0}.score-card-btn:hover:not(:disabled){background:var(--color-primary-highlight)}.spinner{border:2px solid var(--color-surface-dynamic);border-top-color:var(--color-primary);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin;display:inline-block}.spinner.large{border-width:3px;width:32px;height:32px}@keyframes spin{to{transform:rotate(360deg)}}.score-card-panel{flex-direction:column;flex:1;gap:16px;display:flex;overflow-y:auto}.score-loading{text-align:center;color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.score-loading p{margin-top:16px;font-size:.9rem}.score-error{flex-direction:column;gap:12px;padding:16px;display:flex}.error-title{color:var(--color-text);margin:0;font-size:1rem;font-weight:600}.error-content{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-sm);max-height:300px;padding:12px;overflow-y:auto}.error-content pre{color:var(--color-text-muted);white-space:pre-wrap;word-break:break-word;margin:0;font-size:.8rem}.score-overall{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}.score-overall-header{justify-content:space-between;align-items:baseline;margin-bottom:10px;display:flex}.score-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.85rem;font-weight:500}.score-value{color:var(--color-text);font-size:1.75rem;font-weight:700}.progress-bar{background:var(--color-surface-dynamic);border-radius:var(--radius-sm);height:8px;overflow:hidden}.progress-bar.large{height:12px}.progress-bar.mini{height:4px}.progress-fill{border-radius:var(--radius-sm);height:100%;transition:width .5s}.score-fields{flex-direction:column;gap:12px;display:flex}.score-field-row{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px}.score-field-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.field-name{color:var(--color-text);font-size:.85rem;font-weight:500}.field-score{color:var(--color-text-muted);font-variant-numeric:tabular-nums;font-size:.85rem;font-weight:600}.field-note{flex-direction:column;gap:8px;margin-top:8px;display:flex}.note-text{color:var(--color-text-muted);font-size:.8rem;line-height:1.4}.fix-btn{color:var(--color-primary);background:var(--color-primary-highlight);border-radius:var(--radius-sm);transition:all var(--transition);border:1px solid #0000;align-self:flex-start;padding:4px 10px;font-size:.75rem;font-weight:500}.fix-btn:hover:not(:disabled){border-color:var(--color-primary)}.fix-btn:disabled{opacity:.4;cursor:not-allowed}.score-section{flex-direction:column;gap:8px;display:flex}.section-title{margin:0;font-size:.85rem;font-weight:600}.strengths-title{color:var(--color-success)}.improvements-title{color:var(--color-warning)}.score-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.score-list li{color:var(--color-text-muted);padding-left:16px;font-size:.8rem;line-height:1.4;position:relative}.score-list.strengths li:before{content:"✓";color:var(--color-success);position:absolute;left:0}.score-list.improvements li:before{content:"📍";font-size:.7rem;position:absolute;left:0}.close-score-link{color:var(--color-text-muted);text-align:center;transition:color var(--transition);background:0 0;margin-top:auto;padding:8px 0;font-size:.85rem}.close-score-link:hover{color:var(--color-text)}.help-btn-top{width:44px;height:100%;color:var(--color-text-muted);border:none;border-left:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-family:Cinzel Decorative,Cinzel,Georgia,serif;font-size:1rem;font-weight:600;display:flex}.help-btn-top:hover{background:var(--color-surface-offset);color:var(--color-primary);text-shadow:0 0 8px #c0392b4d}.changelog-modal{max-width:420px}.changelog-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;padding:20px 20px 16px;display:flex}.changelog-title{color:var(--color-primary);letter-spacing:.05em;margin:0;font-family:Cinzel Decorative,Cinzel,Georgia,serif;font-size:1.2rem;font-weight:600}.changelog-subtitle{color:var(--color-text-muted);margin:4px 0 0;font-size:.8rem;font-style:italic}.changelog-body{max-height:400px;padding:20px;overflow-y:auto}.changelog-version{margin-bottom:4px}.changelog-version-label{color:var(--color-text);letter-spacing:.03em;margin:0 0 10px;font-family:Cinzel Decorative,Cinzel,Georgia,serif;font-size:.9rem;font-weight:600}.changelog-notes{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.changelog-notes li{color:var(--color-text-muted);padding-left:18px;font-size:.82rem;line-height:1.5;position:relative}.changelog-notes li:before{content:"—";color:var(--color-primary);opacity:.5;position:absolute;left:0}.changelog-divider{background:var(--color-border);opacity:.5;height:1px;margin:16px 0}.changelog-footer{border-top:1px solid var(--color-border);text-align:center;padding:14px 20px}.changelog-link{color:var(--color-primary);letter-spacing:.02em;transition:all var(--transition);font-size:.85rem;font-weight:500;text-decoration:none}.changelog-link:hover{text-shadow:0 0 8px #c0392b40;text-decoration:underline}.settings-modal{max-width:480px}.model-selection{margin-top:20px}.model-loading{background:var(--color-surface-offset);border-radius:var(--radius-sm);color:var(--color-text-muted);align-items:center;gap:10px;padding:12px;font-size:.9rem;display:flex}.model-error{flex-direction:column;gap:8px;display:flex}.model-error span{color:var(--color-text-muted);font-size:.85rem}.model-type-toggle{gap:8px;margin-bottom:10px;display:flex}.toggle-btn{border-radius:var(--radius-sm);background:var(--color-surface-offset);color:var(--color-text-muted);border:1px solid var(--color-border);transition:all var(--transition);flex:1;padding:10px 16px;font-size:.85rem;font-weight:500}.toggle-btn:hover{color:var(--color-text);border-color:var(--color-surface-dynamic)}.toggle-btn.active{background:var(--color-primary-highlight);color:var(--color-primary);border-color:var(--color-primary)}.model-select{max-height:250px}.model-pricing-hint{color:var(--color-text-faint);margin-top:8px;font-size:.8rem}.model-pricing-hint a{color:var(--color-primary)}.model-dropdown{position:relative}.model-dropdown-trigger{background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);justify-content:space-between;align-items:center;padding:10px 14px;font-size:.9rem;display:flex}.model-dropdown-trigger:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-highlight);outline:none}.model-dropdown-arrow{color:var(--color-text-muted);transition:transform var(--transition);margin-left:8px;font-size:.7rem}.model-dropdown.open .model-dropdown-arrow{transform:rotate(180deg)}.model-dropdown-list{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);z-index:100;max-height:200px;box-shadow:var(--shadow-md);margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.model-dropdown-item{color:var(--color-text);cursor:pointer;transition:background var(--transition);padding:10px 14px;font-size:.85rem}.model-dropdown-item:hover{background:var(--color-surface-offset)}.model-dropdown-item.selected{color:var(--color-primary);background:var(--color-primary-highlight)}.alt-greetings-list{flex-direction:column;gap:8px;padding:16px;display:flex}.greeting-card{background:#1c1b19;border:1px solid #2a2826;border-radius:6px;transition:border-color .2s;overflow:hidden}.greeting-card:focus-within{border-color:#c0392b44}.greeting-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 14px;display:flex}.greeting-drag-handle{color:#3e3c3a;cursor:grab;padding:0 4px;font-size:16px}.greeting-drag-handle:active{cursor:grabbing}.greeting-default-badge{color:#c0392b;width:16px;font-size:12px;font-weight:700}.greeting-label{color:#9a9896;letter-spacing:.04em;flex:1;font-size:13px}.greeting-token-count{color:#5a5856;font-size:11px}.greeting-chevron{color:#5a5856;font-size:12px;transition:transform .2s}.greeting-card-body{flex-direction:column;gap:8px;padding:0 14px 14px;display:flex}.greeting-delete-row{justify-content:flex-end;display:flex}.greeting-delete-btn{color:#5a5856;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:12px;transition:color .2s}.greeting-delete-btn:hover:not(:disabled){color:#c0392b}.greeting-delete-btn:disabled{opacity:.3;cursor:not-allowed}.add-greeting-btn{color:#5a5856;cursor:pointer;background:0 0;border:1px dashed #2a2826;border-radius:6px;width:calc(100% - 32px);margin:16px 16px 0;padding:8px 16px;font-size:13px;transition:border-color .2s,color .2s}.add-greeting-btn:hover{color:#c0392b;border-color:#c0392b66}.examples-list{flex-direction:column;gap:8px;padding:16px;display:flex}.example-card{background:#1c1b19;border:1px solid #2a2826;border-radius:6px;transition:border-color .2s;overflow:hidden}.example-card:focus-within{border-color:#c0392b44}.example-card-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 14px;display:flex}.example-drag-handle{color:#3e3c3a;cursor:grab;padding:0 4px;font-size:16px}.example-drag-handle:active{cursor:grabbing}.example-label{color:#9a9896;letter-spacing:.04em;flex:1;font-size:13px}.example-meta{color:#5a5856;gap:10px;font-size:11px;display:flex}.example-chevron{color:#5a5856;font-size:12px;transition:transform .2s}.example-card-body{flex-direction:column;gap:10px;padding:0 14px 14px;display:flex}.example-turn{background:#141212;border:1px solid #2a2826;border-radius:6px;flex-direction:column;gap:8px;padding:10px;display:flex}.example-turn-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.example-speaker-select{color:#9a9896;cursor:pointer;background:#1c1b19;border:1px solid #2a2826;border-radius:4px;padding:4px 8px;font-size:12px}.example-speaker-select:focus{border-color:#c0392b66;outline:none}.example-turn-delete{color:#5a5856;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 6px;font-size:12px}.example-turn-delete:hover{color:#c0392b}.example-turn-textarea{resize:vertical;min-height:80px!important}.example-actions{justify-content:space-between;align-items:center;gap:10px;display:flex}.add-example-btn,.add-turn-btn{color:#5a5856;cursor:pointer;background:0 0;border:1px dashed #2a2826;border-radius:6px;padding:8px 16px;font-size:13px;transition:border-color .2s,color .2s}.add-example-btn:hover,.add-turn-btn:hover{color:#c0392b;border-color:#c0392b66}.delete-example-btn{color:#5a5856;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:12px;transition:color .2s}.delete-example-btn:hover{color:#c0392b}.examples-empty{color:#6a6866;text-align:center;flex-direction:column;align-items:center;gap:16px;padding:24px 16px;font-size:13px;display:flex}.examples-empty p{margin:0}.crop-backdrop{z-index:200;background:#000000d1;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.crop-panel{background:#1c1b19;border:1px solid #2a2826;border-radius:10px;flex-direction:column;width:480px;max-width:95vw;display:flex;overflow:hidden;box-shadow:0 24px 64px #000000b3}.crop-panel-header{letter-spacing:.08em;text-transform:uppercase;color:#9a9896;border-bottom:1px solid #2a2826;justify-content:space-between;align-items:center;padding:14px 18px;font-size:13px;display:flex}.crop-panel-header button{color:#5a5856;cursor:pointer;background:0 0;border:none;font-size:18px;line-height:1;transition:color .2s}.crop-panel-header button:hover{color:#c0392b}.crop-canvas-area{background:#141212;width:100%;height:360px;position:relative}.crop-panel-footer{border-top:1px solid #2a2826;justify-content:space-between;align-items:center;gap:10px;padding:12px 18px;display:flex}.crop-format-toggle{color:#6a6866;align-items:center;gap:6px;font-size:12px;display:flex}.crop-format-btn{color:#6a6866;cursor:pointer;background:0 0;border:1px solid #2a2826;border-radius:4px;padding:3px 10px;font-size:12px;transition:all .18s}.crop-format-btn.active{color:#c0392b;background:#c0392b11;border-color:#c0392b66}.crop-actions{gap:8px;display:flex}.crop-btn-cancel{color:#6a6866;cursor:pointer;background:0 0;border:1px solid #2a2826;border-radius:5px;padding:6px 16px;font-size:13px;transition:border-color .2s,color .2s}.crop-btn-cancel:hover{color:#9a9896;border-color:#4a4846}.crop-btn-save{color:#fff;cursor:pointer;background:#c0392b;border:none;border-radius:5px;padding:6px 20px;font-size:13px;transition:background .2s}.crop-btn-save:hover{background:#a93226}.avatar-edit-link{color:#5a5856;cursor:pointer;text-align:center;letter-spacing:.04em;background:0 0;border:none;width:100%;margin-top:5px;padding:0;font-size:11px;transition:color .2s;display:block}.avatar-edit-link:hover{color:#c0392b}.item-ai-actions{align-items:center;gap:8px;display:flex}.item-ai-btn{color:#7a7876;cursor:pointer;background:0 0;border:1px solid #2a2826;border-radius:5px;align-items:center;gap:4px;padding:5px 10px;font-size:12px;transition:border-color .2s,color .2s,background .2s;display:inline-flex}.item-ai-btn:hover:not(:disabled){color:#c0392b;background:#c0392b11;border-color:#c0392b66}.item-ai-btn:disabled{opacity:.45;cursor:not-allowed}.lorebook-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;min-height:300px;padding:2rem;display:flex}.lorebook-empty-icon{opacity:.7;margin-bottom:.5rem;font-size:3rem}.lorebook-empty-title{color:#c0392b;margin:0 0 .75rem;font-family:Cinzel,Georgia,serif;font-size:1.3rem}.lorebook-empty-desc{color:#6a6866;max-width:500px;margin:0 0 1.25rem;font-size:.9rem;line-height:1.6}.lorebook-empty-state .btn{padding:.6rem 1.5rem;font-size:.95rem}.lorebook-meta-panel{background:#1c1b19;border:1px solid #2a2826;border-radius:8px;flex-direction:column;gap:.75rem;padding:1rem;display:flex}.lorebook-meta-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.lorebook-meta-title{color:#9a9896;letter-spacing:.05em;margin:0;font-family:Cinzel,Georgia,serif;font-size:.9rem;font-weight:600}.lorebook-meta-stats{color:#5a5856;align-items:center;gap:.5rem;font-size:.75rem;display:flex}.lorebook-meta-stats span{display:inline}.lorebook-meta-fields{flex-direction:column;gap:.75rem;display:flex}.lorebook-meta-row{flex-wrap:wrap;align-items:flex-end;gap:.75rem;display:flex}.lorebook-meta-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.lorebook-field-row{flex-direction:column;gap:.4rem;display:flex}.lorebook-field-label{text-transform:uppercase;letter-spacing:.04em;color:#6a6866;font-size:.72rem;font-weight:600}.lorebook-field-row-inline{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.lorebook-field-inline-group{flex-direction:column;gap:.4rem;display:flex}.lorebook-field-input,.lorebook-field-textarea,.lorebook-field-select{color:#9a9896;background:#141212;border:1px solid #2a2826;border-radius:4px;width:100%;padding:.45rem .55rem;font-family:inherit;font-size:.85rem;transition:border-color .15s}.lorebook-field-input::placeholder,.lorebook-field-textarea::placeholder{color:#3e3c3a}.lorebook-field-input:focus,.lorebook-field-textarea:focus,.lorebook-field-select:focus{border-color:#c0392b66;outline:none}.lorebook-field-textarea{resize:vertical;min-height:40px;line-height:1.5}.lorebook-content-input{min-height:120px}.lorebook-field-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a7f7c' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.lorebook-field-select option{color:#9a9896;background:#1c1b19}.lorebook-field-number{width:80px}.lorebook-field-input:disabled,.lorebook-field-textarea:disabled{opacity:.4;cursor:not-allowed}.lorebook-entry-card{background:#1c1b19;border:1px solid #2a2826;border-radius:6px;transition:border-color .15s;overflow:hidden}.lorebook-entry-card.has-warnings{border-color:#c07c2b}.lorebook-entry-card.is-disabled{opacity:.55}.lorebook-entry-header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.5rem;min-height:44px;padding:.6rem .75rem;display:flex}.lorebook-entry-header:hover{background:#ffffff05}.lorebook-drag-handle{cursor:grab;color:#3e3c3a;opacity:.5;padding:0 .15rem;font-size:1rem;line-height:1;transition:opacity .15s}.lorebook-drag-handle:hover{opacity:1}.lorebook-drag-handle.dragging{cursor:grabbing}.lorebook-entry-label{color:#9a9896;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.9rem;font-weight:600;overflow:hidden}.lorebook-chevron{color:#3e3c3a;flex-shrink:0;font-size:.7rem;transition:transform .2s}.lorebook-badge{text-transform:uppercase;letter-spacing:.03em;border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:700;line-height:1.4}.lorebook-badge-enabled{color:#6abf7b;background:#4a7c5940}.lorebook-badge-constant{color:#e0a84d;background:#c07c2b40}.lorebook-badge-regex{color:#8eaadb;background:#6a82bf40}.lorebook-badge-warning{color:#e07c5a;background:#c05c3a40}.lorebook-badge-disabled{color:#888;background:#78787833}.lorebook-entry-token-count{color:#5a5856;flex-shrink:0;font-size:.72rem}.lorebook-entry-body{border-top:1px solid #2a2826;flex-direction:column;gap:.75rem;padding:.85rem .85rem .75rem;display:flex}.lorebook-toggles-row{flex-wrap:wrap;align-items:center;gap:.85rem;display:flex}.lorebook-toggle{color:#9a9896;cursor:pointer;align-items:center;gap:.35rem;font-size:.82rem;display:flex}.lorebook-toggle input[type=checkbox]{cursor:pointer;accent-color:#c0392b;margin:0}.lorebook-entry-warnings{background:#c05c3a14;border:1px solid #c05c3a26;border-radius:4px;flex-direction:column;gap:.2rem;padding:.5rem .65rem;display:flex}.lorebook-warning-text{color:#c07c2b;font-size:.78rem;line-height:1.4}.lorebook-entry-actions{justify-content:flex-end;gap:.5rem;padding-top:.25rem;display:flex}.lorebook-action-btn{color:#6a6866;cursor:pointer;background:0 0;border:1px solid #2a2826;border-radius:4px;padding:.3rem .7rem;font-family:inherit;font-size:.8rem;transition:all .15s}.lorebook-action-btn:hover{color:#c0392b;background:#c0392b11;border-color:#c0392b66}.lorebook-delete-btn:hover{color:#c0392b;border-color:#c0392b}.lorebook-filter-bar{align-items:center;gap:.65rem;display:flex}.lorebook-filter-input{color:#9a9896;background:#141212;border:1px solid #2a2826;border-radius:6px;flex:1;padding:.45rem .65rem;font-family:inherit;font-size:.85rem;transition:border-color .15s}.lorebook-filter-input::placeholder{color:#3e3c3a}.lorebook-filter-input:focus{border-color:#c0392b66;outline:none}.lorebook-filter-count{color:#5a5856;white-space:nowrap;font-size:.75rem}.lorebook-no-results{text-align:center;color:#5a5856;padding:2rem 1rem;font-size:.85rem;font-style:italic}.lorebook-entries-list{flex-direction:column;flex:1;gap:.5rem;display:flex;overflow-y:auto}.lorebook-remove-btn{color:#5a5856;cursor:pointer;background:0 0;border:1px solid #2a2826;border-radius:4px;margin-left:auto;padding:.35rem .65rem;font-family:inherit;font-size:.82rem;transition:all .15s}.lorebook-remove-btn:hover{color:#c0392b;border-color:#c0392b}
