:root{--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--accent-jade: #73daca;--accent-jade-hover: #5fc4b4;--accent-jade-deep: #41a6b5;--accent-jade-bright: #a4f3e2;--accent-coral: #f7768e;--accent-coral-hover: #e15c75;--accent-sun: #e0af68;--accent-sun-hover: #cf9a51;--accent-lagoon: #7aa2f7;--accent-lagoon-hover: #5e88e8;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-pill: 999px;--transition-fast: .15s ease;--transition-normal: .22s cubic-bezier(.4, 0, .2, 1);--color-primary: var(--accent-jade);--color-primary-hover: var(--accent-jade-hover);--color-success: var(--accent-jade);--color-success-hover: var(--accent-jade-hover);--color-danger: var(--accent-coral);--color-danger-hover: var(--accent-coral-hover);--color-warning: var(--accent-sun);--color-warning-hover: var(--accent-sun-hover);--color-ghost-border: var(--accent-jade);--color-ghost-border-hover: var(--accent-jade-hover);--tag-chip-bg: var(--accent-jade-soft);--tag-chip-border: var(--accent-jade-overlay);--tag-chip-fg: var(--accent-jade)}:root[data-theme=dark]{color-scheme:dark;--sidebar-bg: #16161e;--sidebar-bg-hover: #1f2335;--sidebar-bg-active: #292e42;--sidebar-border: #1f2335;--sidebar-border-light: #292e42;--sidebar-text: #9aa5ce;--sidebar-text-muted: #565f89;--sidebar-text-hover: #c0caf5;--sidebar-accent: #7aa2f7;--bg-main: #1a1b26;--surface-card: #24283b;--surface-elevated: #292e42;--surface-muted: #1f2335;--border-card: #3b4261;--border-soft: #292e42;--shadow-card: 0 1px 2px rgba(0, 0, 0, .32), 0 6px 18px rgba(0, 0, 0, .4);--shadow-card-hover: 0 2px 4px rgba(0, 0, 0, .4), 0 14px 32px rgba(0, 0, 0, .5);--shadow-elevated: 0 24px 60px rgba(0, 0, 0, .6);--text-primary: #c0caf5;--text-muted: #9aa5ce;--text-on-accent: #16161e;--accent-jade-soft: rgba(115, 218, 202, .16);--accent-jade-overlay: rgba(115, 218, 202, .28);--accent-jade-text: var(--accent-jade);--accent-coral-soft: rgba(247, 118, 142, .16);--color-primary-text: var(--text-on-accent);--color-secondary: var(--surface-muted);--color-secondary-hover: var(--border-card);--color-secondary-text: var(--text-primary);--color-danger-text: var(--text-on-accent);--color-ghost-bg-hover: var(--accent-jade-soft);--ring-focus: 0 0 0 3px var(--accent-jade-soft);--ring-focus-strong: 0 0 0 3px var(--accent-jade-overlay);--gradient-tropical: linear-gradient(180deg, var(--accent-jade) 0%, var(--accent-jade-hover) 100%);--gradient-tropical-overlay: linear-gradient(135deg, rgba(115, 218, 202, .22) 0%, rgba(122, 162, 247, .22) 100%);--shadow-tropical: 0 1px 0 rgba(255, 255, 255, .18) inset, 0 8px 22px rgba(0, 0, 0, .45);--text-on-tropical: var(--text-on-accent)}:root[data-theme=light]{color-scheme:light;--sidebar-bg: #eef0f4;--sidebar-bg-hover: #e1e6ef;--sidebar-bg-active: #d4dbe8;--sidebar-border: #d4dbe8;--sidebar-border-light: #e1e6ef;--sidebar-text: #4c5174;--sidebar-text-muted: #7a82a2;--sidebar-text-hover: #1a1b26;--sidebar-accent: #3d59a1;--bg-main: #f7f6f1;--surface-card: #ffffff;--surface-elevated: #fdfcf8;--surface-muted: #ecebe6;--border-card: #d8d6cd;--border-soft: #e5e3dc;--shadow-card: 0 1px 2px rgba(20, 26, 42, .06), 0 4px 12px rgba(20, 26, 42, .05);--shadow-card-hover: 0 2px 4px rgba(20, 26, 42, .1), 0 10px 24px rgba(20, 26, 42, .08);--shadow-elevated: 0 18px 44px rgba(20, 26, 42, .14);--text-primary: #1a1b26;--text-muted: #565f89;--text-on-accent: #16161e;--accent-jade-soft: rgba(65, 166, 181, .14);--accent-jade-overlay: rgba(65, 166, 181, .24);--accent-jade-text: var(--accent-jade-deep);--accent-coral-soft: rgba(247, 118, 142, .14);--tag-chip-bg: var(--accent-jade-overlay);--tag-chip-border: var(--accent-jade-deep);--tag-chip-fg: var(--accent-jade-deep);--color-primary-text: var(--text-on-accent);--color-secondary: var(--surface-muted);--color-secondary-hover: var(--border-soft);--color-secondary-text: var(--text-primary);--color-danger-text: #ffffff;--color-ghost-bg-hover: var(--accent-jade-soft);--ring-focus: 0 0 0 3px var(--accent-jade-soft);--ring-focus-strong: 0 0 0 3px var(--accent-jade-overlay);--gradient-tropical: linear-gradient(180deg, var(--accent-jade) 0%, var(--accent-jade-hover) 100%);--gradient-tropical-overlay: linear-gradient(135deg, rgba(115, 218, 202, .28) 0%, rgba(122, 162, 247, .28) 100%);--shadow-tropical: 0 1px 0 rgba(255, 255, 255, .55) inset, 0 6px 16px rgba(20, 26, 42, .12);--text-on-tropical: var(--text-on-accent)}:root:not([data-theme]){color-scheme:dark;--sidebar-bg: #16161e;--sidebar-bg-hover: #1f2335;--sidebar-bg-active: #292e42;--sidebar-border: #1f2335;--sidebar-border-light: #292e42;--sidebar-text: #9aa5ce;--sidebar-text-muted: #565f89;--sidebar-text-hover: #c0caf5;--sidebar-accent: #7aa2f7;--bg-main: #1a1b26;--surface-card: #24283b;--surface-elevated: #292e42;--surface-muted: #1f2335;--border-card: #3b4261;--border-soft: #292e42;--shadow-card: 0 1px 2px rgba(0, 0, 0, .32), 0 6px 18px rgba(0, 0, 0, .4);--shadow-card-hover: 0 2px 4px rgba(0, 0, 0, .4), 0 14px 32px rgba(0, 0, 0, .5);--shadow-elevated: 0 24px 60px rgba(0, 0, 0, .6);--text-primary: #c0caf5;--text-muted: #9aa5ce;--text-on-accent: #16161e;--accent-jade-soft: rgba(115, 218, 202, .16);--accent-jade-overlay: rgba(115, 218, 202, .28);--accent-jade-text: var(--accent-jade);--accent-coral-soft: rgba(247, 118, 142, .16);--color-primary-text: var(--text-on-accent);--color-secondary: var(--surface-muted);--color-secondary-hover: var(--border-card);--color-secondary-text: var(--text-primary);--color-danger-text: var(--text-on-accent);--color-ghost-bg-hover: var(--accent-jade-soft);--ring-focus: 0 0 0 3px var(--accent-jade-soft);--ring-focus-strong: 0 0 0 3px var(--accent-jade-overlay);--gradient-tropical: linear-gradient(180deg, var(--accent-jade) 0%, var(--accent-jade-hover) 100%);--gradient-tropical-overlay: linear-gradient(135deg, rgba(115, 218, 202, .22) 0%, rgba(122, 162, 247, .22) 100%);--shadow-tropical: 0 1px 0 rgba(255, 255, 255, .18) inset, 0 8px 22px rgba(0, 0, 0, .45);--text-on-tropical: var(--text-on-accent)}.panel{background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--spacing-lg)}.panel-flush{background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.panel-elevated{background:var(--surface-elevated);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);padding:var(--spacing-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.625rem 1.1rem;font:inherit;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);user-select:none;white-space:nowrap}.btn:disabled,.btn[aria-disabled=true]{opacity:.55;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--ring-focus-strong)}.btn svg{width:1em;height:1em;flex-shrink:0}.btn-sm{padding:.35rem .75rem;font-size:var(--font-size-sm)}.btn-md{padding:.625rem 1.1rem;font-size:var(--font-size-base)}.btn-lg{padding:.875rem 1.6rem;font-size:var(--font-size-lg)}.btn-primary{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-secondary-text)}.btn-secondary:hover:not(:disabled){background:var(--color-secondary-hover);border-color:var(--color-secondary-hover)}.btn-success{background:var(--color-success);border-color:var(--color-success);color:var(--color-primary-text)}.btn-success:hover:not(:disabled){background:var(--color-success-hover);border-color:var(--color-success-hover)}.btn-ghost{background:transparent;border-color:var(--color-ghost-border);color:var(--color-ghost-border)}.btn-ghost:hover:not(:disabled){background:var(--color-ghost-bg-hover);border-color:var(--color-ghost-border-hover);color:var(--color-ghost-border-hover)}.btn-danger{background:var(--color-danger);border-color:var(--color-danger);color:var(--color-danger-text)}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn-pill{border-radius:var(--radius-pill)}.btn-icon{padding:.5rem;border-radius:50%}.chip{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:.18rem .55rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-pill);background:var(--accent-jade-soft);color:var(--accent-jade);border:1px solid transparent;line-height:1.4}.chip-outline{background:transparent;border-color:var(--accent-jade);color:var(--accent-jade)}.chip-warning{background:#e0af682e;color:var(--accent-sun)}.chip-danger{background:var(--accent-coral-soft);color:var(--accent-coral)}.hint{background:var(--accent-jade-soft);border:1px solid transparent;color:var(--accent-jade);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.input{width:100%;padding:.6rem .85rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.input::placeholder{color:var(--text-muted);opacity:.7}.input:focus,.input:focus-visible{outline:none;border-color:var(--accent-jade);background:var(--surface-card);box-shadow:var(--ring-focus)}.focus-ring:focus-visible{outline:none;box-shadow:var(--ring-focus)}.badge{display:inline-block;font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-sm)}.badge-sm{padding:.3rem .6rem;font-size:.7rem}.badge-md{padding:.35rem .75rem;font-size:var(--font-size-sm)}.badge-default{background:var(--border-card);color:var(--text-muted)}.badge-language,.badge-status{background:var(--accent-jade-soft);color:var(--accent-jade)}.card{position:relative;background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:1.25rem;box-shadow:var(--shadow-card);transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal)}.card-interactive{cursor:pointer}.card-interactive:hover{border-color:var(--accent-jade);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}a.card-feature{text-decoration:none;color:inherit;display:block;padding:var(--spacing-lg)}.card-feature:hover{transform:translateY(-4px);border-color:var(--accent-jade);box-shadow:var(--shadow-card-hover)}.card-icon{width:48px;height:48px;background:var(--accent-jade-soft);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);color:var(--accent-jade-hover)}.card-icon svg{width:24px;height:24px}.card-title{font-weight:var(--font-weight-bold);font-size:1.05rem;color:var(--text-primary);margin-bottom:var(--spacing-sm);line-height:1.3}.card-description{color:var(--text-muted);font-size:var(--font-size-sm)}.card-preview{color:var(--text-muted);font-size:var(--font-size-sm);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;margin-top:var(--spacing-sm)}.card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-md);padding-top:.75rem;border-top:1px solid var(--border-soft);font-size:var(--font-size-xs);color:var(--text-muted)}.card-header{padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--accent-jade);margin-bottom:var(--spacing-sm)}.chat-history{max-height:200px;overflow:hidden;margin:var(--spacing-xs) .75rem 0 2.25rem;padding-left:var(--spacing-sm);border-left:1px solid var(--sidebar-border-light)}.chat-history-list{overflow-y:auto;max-height:200px}.chat-history-item{display:flex;align-items:center;height:32px;padding:0 var(--spacing-xs);margin:var(--spacing-xs) 0;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;transition:background var(--transition-fast)}.chat-history-item:hover{background:#ffffff0d}.chat-history-item.active{background:#ffffff14}.chat-history-title{flex:1;min-width:0;font-size:var(--font-size-base);color:var(--sidebar-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:32px;transition:color var(--transition-fast)}.chat-history-item:hover .chat-history-title,.chat-history-item.active .chat-history-title{color:var(--sidebar-text)}.chat-history-title-input{flex:1;min-width:0;font-size:var(--font-size-base);background:transparent;border:none;border-bottom:1px solid var(--sidebar-accent);color:var(--sidebar-text);padding:0;margin:0;outline:none;font-family:inherit;line-height:30px}.chat-history-btn{flex-shrink:0;width:22px;text-align:center;background:transparent;border:none;color:#555;font-size:var(--font-size-sm);cursor:pointer;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast);line-height:1}.chat-history-item:hover .chat-history-btn{opacity:1}.chat-history-btn:hover{color:var(--sidebar-text)}.chat-history-btn.delete:hover{color:#e66}.empty-state{color:var(--text-muted);text-align:center;padding:var(--spacing-xl)}.empty-state-default{background:var(--surface-card);border-radius:var(--radius-lg)}.empty-state-dashed{background:var(--surface-card);border-radius:var(--radius-lg);border:2px dashed var(--border-card);padding:3rem var(--spacing-xl)}.empty-state-inline{padding:var(--spacing-md);font-size:.9rem}.empty-state-message{margin:0;font-style:italic}.empty-state svg{width:48px;height:48px;opacity:.3;margin-bottom:var(--spacing-md)}.loading-state{color:var(--text-muted);text-align:center;padding:var(--spacing-xl)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-muted)}.form-row{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.form-row .form-group{flex:1}.form-input,.form-group input,.form-group select,.form-group textarea{padding:.75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);width:100%}.form-input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-jade);background:var(--surface-card);box-shadow:var(--ring-focus)}.form-group textarea{resize:vertical;min-height:100px;line-height:var(--line-height-relaxed)}.header-panel{display:flex;flex-direction:column;gap:.75rem;background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);margin-bottom:var(--spacing-md);box-shadow:var(--shadow-card)}.header-panel-row{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.header-panel-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;min-width:64px;flex-shrink:0}.header-panel-spacer{flex:1}.tag-pick-row{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);flex:1;min-width:0}.tag-pick-empty{color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}.tag-pick{display:inline-flex;align-items:center;padding:.3rem .75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-pill);font:inherit;font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.tag-pick:hover{border-color:var(--accent-jade);color:var(--accent-jade)}.tag-pick.selected{background:var(--accent-jade-soft);border-color:var(--accent-jade);color:var(--accent-jade)}.source-picker{position:relative;flex:1;min-width:0;max-width:360px}.source-picker-input-wrap{position:relative;display:flex;align-items:center}.source-picker-input{width:100%;padding:.4rem 2rem .4rem .75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;font-size:var(--font-size-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.source-picker-input::placeholder{color:var(--text-muted);opacity:.7}.source-picker-input:focus,.source-picker-input:focus-visible{outline:none;border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.source-picker-clear{position:absolute;right:.4rem;top:50%;transform:translateY(-50%);width:1.3rem;height:1.3rem;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-pill);cursor:pointer;font-size:1.1rem;line-height:1;padding:0}.source-picker-clear:hover{background:var(--surface-elevated);color:var(--text-primary)}.source-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:20;max-height:260px;overflow-y:auto;background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-md);box-shadow:var(--shadow-card-hover);padding:.25rem}.source-picker-option{display:block;width:100%;text-align:left;padding:.4rem .6rem;background:transparent;color:var(--text-primary);border:none;border-radius:var(--radius-sm);cursor:pointer;font:inherit;font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.source-picker-option:hover,.source-picker-option:focus-visible{background:var(--accent-jade-soft);color:var(--text-primary);outline:none}.source-picker-option.synthetic{color:var(--text-muted);font-style:italic}.source-picker-empty{padding:.5rem .6rem;color:var(--text-muted);font-size:var(--font-size-sm);font-style:italic}.icon{flex-shrink:0}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;background:transparent;border:1px solid var(--border-card);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);text-decoration:none;flex-shrink:0}.icon-btn svg{width:24px;height:24px}.icon-btn:hover:not(:disabled){color:var(--accent-jade);border-color:var(--accent-jade);background:var(--accent-jade-soft)}.icon-btn:active:not(:disabled){transform:translateY(1px)}.icon-btn:focus-visible{outline:none;box-shadow:var(--ring-focus)}.icon-btn:disabled,.icon-btn[aria-disabled=true]{cursor:not-allowed}.icon-btn.active{background:var(--accent-jade);border-color:var(--accent-jade);color:var(--text-on-accent)}.icon-btn.active:hover:not(:disabled){background:var(--accent-jade-hover);border-color:var(--accent-jade-hover);color:var(--text-on-accent)}.icon-btn.engaged{border-color:var(--accent-jade);background:var(--accent-jade-soft);color:var(--accent-jade)}.icon-btn.engaged:hover:not(:disabled){background:var(--accent-jade-overlay);border-color:var(--accent-jade);color:var(--accent-jade)}.icon-btn-primary{background:var(--accent-jade);border-color:var(--accent-jade);color:var(--text-on-accent)}.icon-btn-primary:hover:not(:disabled){background:var(--accent-jade-hover);border-color:var(--accent-jade-hover);color:var(--text-on-accent)}.icon-btn-ghost{border-color:var(--accent-jade);color:var(--accent-jade)}.deck-author{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .65rem;background:var(--accent-jade-soft);color:var(--accent-jade);border-radius:var(--radius-pill);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.deck-author-avatar{font-size:1.05rem;line-height:1}.deck-author-name{overflow:hidden;text-overflow:ellipsis}.import-deck-modal .modal-body{padding-bottom:.25rem}.import-deck-list{display:flex;flex-direction:column;gap:.25rem}.import-deck-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:.4rem .6rem;background:var(--surface-muted);border:1px solid var(--border-card);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast);min-width:0}.import-deck-row:hover{border-color:var(--accent-jade)}.import-deck-row.is-imported{opacity:.6;cursor:default}.import-deck-row input[type=checkbox]{accent-color:var(--accent-jade);flex-shrink:0;margin:0}.import-deck-title{font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-sm);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:12rem}.import-deck-count{background:var(--surface-card);color:var(--text-muted);border-radius:var(--radius-pill);padding:.05rem .5rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);flex-shrink:0}.import-deck-preview{flex:1;min-width:0;font-size:var(--font-size-sm);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.import-deck-row .deck-author{flex-shrink:0}.import-empty{margin:0;font-size:var(--font-size-sm);color:var(--text-muted);text-align:center;padding:var(--spacing-lg)}.modal-footer-spacer{flex:1}.modal-header-left{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.shared-texts-modal .import-deck-list{gap:var(--spacing-sm)}.shared-texts-modal .import-deck-row{display:grid;grid-template-columns:auto 1fr;column-gap:var(--spacing-sm);row-gap:.45rem;align-items:start;padding:.85rem .9rem;background:var(--surface-elevated);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.shared-texts-modal .import-deck-row:hover:not(.is-imported){border-color:var(--accent-jade);box-shadow:var(--shadow-card-hover)}.shared-texts-modal .import-deck-row input[type=checkbox]{grid-column:1;grid-row:1;margin-top:.2rem}.shared-texts-modal .import-deck-title{grid-column:2;grid-row:1;max-width:none;white-space:normal;overflow:visible;text-overflow:clip;font-size:var(--font-size-base);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.shared-texts-modal .import-deck-preview{grid-column:2;grid-row:2;flex:none;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:var(--font-size-sm);line-height:var(--line-height-normal);color:var(--text-muted)}.shared-texts-modal .import-deck-footer{grid-column:2;grid-row:3;display:flex;flex-wrap:wrap;align-items:center;gap:.3rem}.import-deck-tags{display:inline-flex;flex-wrap:wrap;gap:.3rem}.shared-friend-filter{font:inherit;font-size:var(--font-size-sm);color:var(--text-primary);background:var(--surface-muted);border:1px solid var(--border-card);border-radius:var(--radius-md);padding:.3rem .5rem;cursor:pointer;max-width:12rem}.shared-friend-filter:focus{outline:none;border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.shared-empty-placeholder{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-md)}.shared-empty-icon{font-size:2.75rem;line-height:1;margin-bottom:var(--spacing-xs)}.shared-empty-title{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.01em}.shared-empty-body{margin:0;max-width:28rem;font-size:var(--font-size-sm);color:var(--text-muted);line-height:var(--line-height-relaxed)}.shared-empty-cta{margin-top:var(--spacing-sm);display:inline-flex;align-items:center;text-decoration:none}.shared-empty-cta:hover{text-decoration:none}.modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-card{background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-elevated);max-width:540px;width:100%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) 1.25rem;border-bottom:1px solid var(--border-soft)}.modal-header h2{margin:0;font-size:1.05rem;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-muted);transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--spacing-md) 1.25rem;overflow-y:auto;min-height:5rem;color:var(--text-primary)}.modal-footer{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding:.75rem 1.25rem;border-top:1px solid var(--border-soft);background:var(--surface-muted)}.modal-footer .btn{font-size:var(--font-size-sm)}.error-text{color:var(--color-danger);font-size:.9rem;margin:0}.confirm-overlay{z-index:1100}.confirm-modal{max-width:26rem}.confirm-modal .modal-body{min-height:auto}.confirm-message{margin:0;line-height:1.5;color:var(--text-primary)}.note-dialog-subject{display:flex;flex-direction:column;gap:.15rem;margin-bottom:var(--spacing-sm);padding:.5rem .65rem;background:var(--surface-muted);border:1px solid var(--border-card);border-radius:var(--radius-md)}.note-dialog-subject-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.note-dialog-subject-text{font-weight:var(--font-weight-semibold);color:var(--text-primary);overflow-wrap:anywhere}.note-dialog-subject-secondary{font-size:var(--font-size-sm);color:var(--text-muted);overflow-wrap:anywhere}.note-dialog-input{width:100%;box-sizing:border-box;padding:.55rem .65rem;background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;font-size:var(--font-size-base);line-height:var(--line-height-normal);resize:vertical}.note-dialog-input:focus{outline:none;border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.note-dialog-hint{margin:.5rem 0 0;font-size:var(--font-size-sm);color:var(--text-muted);line-height:var(--line-height-normal)}.notifications-stack{position:fixed;top:calc(var(--topbar-height, 0px) + var(--spacing-md));right:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm);z-index:1100;max-width:360px;width:calc(100% - var(--spacing-xl));pointer-events:none}@media(min-width:769px){.notifications-stack{top:var(--spacing-lg)}}.notification-toast{pointer-events:auto;display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:.75rem var(--spacing-md);background:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border-card);border-left:3px solid var(--accent-jade);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);animation:notification-slide-in .25s ease-out}.notification-toast.leaving{animation:notification-fade-out .2s ease-in forwards}@keyframes notification-slide-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes notification-fade-out{to{opacity:0;transform:translate(20px)}}.notification-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-jade-soft);display:inline-flex;align-items:center;justify-content:center;font-size:18px;line-height:1;flex-shrink:0}.notification-body{flex:1;min-width:0}.notification-message{margin:0 0 .2rem;font-size:var(--font-size-sm);color:var(--text-primary);line-height:1.4}.notification-link{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--accent-jade);text-decoration:none}.notification-link:hover{text-decoration:underline}.notification-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem;line-height:1;padding:.15rem .3rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.notification-close:hover{color:var(--text-primary);background:var(--surface-muted)}.flash-error-stack{top:auto;bottom:var(--spacing-md)}@media(min-width:769px){.flash-error-stack{top:auto;bottom:var(--spacing-lg)}}.flash-toast{border-left-width:3px;border-left-style:solid}.flash-toast-icon{font-weight:var(--font-weight-bold, 700)}.flash-toast-error{border-left-color:var(--color-danger, #ef4444)}.flash-toast-icon-error{background:color-mix(in srgb,var(--color-danger, #ef4444) 18%,transparent);color:var(--color-danger, #ef4444)}.flash-toast-success{border-left-color:var(--accent-jade, #10b981)}.flash-toast-icon-success{background:color-mix(in srgb,var(--accent-jade, #10b981) 18%,transparent);color:var(--accent-jade, #10b981)}.flash-toast-info{border-left-color:var(--accent-azure, var(--text-muted))}.flash-toast-icon-info{background:color-mix(in srgb,var(--text-muted) 18%,transparent);color:var(--text-muted)}.page-heading{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.page-heading-title{margin:0;flex:1 1 220px;min-width:0}.page-heading-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);flex:0 1 auto;min-width:0;margin-left:auto}.page-heading-separator{display:inline-block;width:1px;height:24px;background:var(--border-card);margin:0 var(--spacing-xs)}@media(max-width:480px){.page-heading-separator{display:none}.page-heading-actions{margin-left:0}}.profile-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid var(--sidebar-border-light);border-radius:50%;color:var(--sidebar-text-hover);cursor:pointer;flex-shrink:0;transition:background var(--transition-normal),border-color var(--transition-normal)}.profile-icon:hover{background:var(--sidebar-bg-hover);border-color:var(--sidebar-accent)}.profile-icon svg{width:20px;height:20px}#profile-avatar.has-emoji{font-size:20px;line-height:1}.section{margin-bottom:var(--spacing-xl)}.section-card{background:var(--surface-card);border:1px solid var(--border-card);padding:var(--spacing-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-card)}.section-plain{padding:var(--spacing-sm) 0}.section-title{font-size:var(--font-size-xl);color:var(--text-primary);margin-bottom:var(--spacing-md);font-weight:var(--font-weight-semibold)}.speech-modal{width:min(360px,calc(100vw - 32px))}.speech-body{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-md)}.speech-mic{width:96px;height:96px;border-radius:50%;border:none;background:var(--accent-jade);color:var(--text-on-accent);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #0006,0 1px #ffffff2e inset;transition:background var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.speech-mic:hover:not(:disabled){background:var(--accent-jade-hover);transform:scale(1.04)}.speech-mic.is-recording{background:var(--accent-coral);animation:speech-mic-pulse 1.4s ease-in-out infinite}.speech-mic.is-recording:hover{background:var(--accent-coral-hover)}.speech-mic.is-busy{background:var(--surface-muted);color:var(--text-muted);cursor:progress;animation:speech-mic-spin 1.2s linear infinite}.speech-mic:disabled{cursor:progress}.speech-status{margin:0;font-size:var(--font-size-sm);color:var(--text-muted);text-align:center;min-height:1.2em}@keyframes speech-mic-pulse{0%,to{box-shadow:0 8px 24px #0006,0 0 0 0 var(--accent-coral-soft)}50%{box-shadow:0 8px 24px #0006,0 0 0 14px transparent}}@keyframes speech-mic-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border-card);border-top-color:var(--accent-jade);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:12px;height:12px}.spinner-md{width:20px;height:20px}.spinner-lg{width:32px;height:32px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.loading-inline{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:var(--spacing-md);color:var(--text-muted)}.typing-indicator{display:flex;gap:4px;padding:.25rem 0}.typing-indicator span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.table-container{background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);overflow-x:auto}.vocab-table{width:100%;border-collapse:collapse}.vocab-table thead th{text-align:left;font-weight:var(--font-weight-semibold);color:var(--text-muted);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;padding:.75rem var(--spacing-md);background:var(--surface-muted);border-bottom:1px solid var(--border-card)}.vocab-table tbody td{padding:.75rem var(--spacing-md);border-bottom:1px solid var(--border-soft);vertical-align:top;color:var(--text-primary)}.vocab-table tbody tr:hover{background:var(--surface-elevated)}.vocab-table tbody tr.vrow-spacer,.vocab-table tbody tr.vrow-spacer:hover{background:none}.vocab-table tbody tr.vrow-spacer>td{padding:0;border:0}.word-col{width:20%}.translation-col{width:30%}.phrase-col{width:35%}.source-col{width:15%}.vocab-table-word .word-col{width:30%}.vocab-table-word .translation-col{width:35%}.vocab-table-word .tags-col{width:20%}.vocab-table-phrase .phrase-col{width:32%}.vocab-table-phrase .translation-col{width:28%}.vocab-table-phrase .tags-col{width:25%}.cell-view{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.cell-text{flex:1;word-break:break-word}.word-text{font-weight:var(--font-weight-semibold);color:var(--text-primary)}.source-link{color:var(--accent-jade);text-decoration:none;font-size:.85rem}.source-link:hover{text-decoration:underline}.source-link-kind{display:none}.date-text{color:var(--text-muted);font-size:var(--font-size-xs)}.row-action-btn{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;flex-shrink:0;padding:0;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;opacity:0;color:var(--text-muted);transition:opacity var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.row-action-btn svg{width:1.05rem;height:1.05rem}.row-action-btn:hover{color:var(--text-primary);background:var(--surface-muted)}.cell-view:hover .row-action-btn,.translation-item:hover .row-action-btn{opacity:1}.row-action-btn.delete-btn:hover{color:var(--accent-coral)}.row-action-btn.add-btn:hover{color:var(--accent-jade)}.row-action-btn.speak-btn:hover{color:var(--accent-lagoon)}.row-action-btn.regenerate-btn:hover{color:var(--accent-jade)}.row-action-btn.regenerate-btn.is-spinning{opacity:1;color:var(--accent-jade);animation:spin .8s linear infinite}.row-action-btn.speak-btn.is-busy{color:var(--accent-lagoon);opacity:1;animation:speak-pulse 1s ease-in-out infinite}@keyframes speak-pulse{0%,to{opacity:1}50%{opacity:.5}}.row-action-btn.ignore-btn:hover{color:var(--text-primary)}.vocab-table .vocab-row.is-ignored .cell-text,.vocab-table .vocab-row.is-ignored .translation-text,.vocab-table .vocab-row.is-ignored .no-translation{color:var(--text-muted)}.vocab-table .vocab-row.is-ignored .source-link,.vocab-table .vocab-row.is-ignored .date-text,.vocab-table .vocab-row.is-ignored .tag-chip{opacity:.6}.vocab-table .vocab-row.is-ignored .ignore-btn{opacity:.7}.vocab-table .vocab-row.is-ignored .ignore-btn:hover{opacity:1;color:var(--accent-jade)}.edit-input{width:100%;padding:.4rem .5rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--accent-jade);border-radius:var(--radius-sm);font:inherit;font-size:.9rem;box-sizing:border-box}.edit-input:focus{outline:none;box-shadow:var(--ring-focus)}.translation-view{display:flex;flex-direction:column;gap:.25rem}.translation-list{display:flex;flex-direction:column}.translation-item{display:flex;align-items:center;gap:.4rem;padding:.25rem 0}.translation-item+.translation-item{border-top:1px solid var(--border-soft)}.translation-item .translation-text{flex:1;color:var(--text-primary);font-size:.95rem}.empty-translation{display:flex;align-items:center;gap:.4rem}.no-translation{color:var(--text-muted);font-style:italic;font-size:.85rem;opacity:.7}.add-first-btn{opacity:0;transition:opacity var(--transition-fast)}.translation-view:hover .add-first-btn{opacity:1}.translation-merged-group{display:flex;flex-direction:column}.translation-merged-group+.translation-item,.translation-item+.translation-merged-group,.translation-merged-group+.translation-merged-group{border-top:1px solid var(--border-soft)}.translation-item.translation-merged .merged-text{flex:1;color:var(--text-primary);font-size:.95rem}.merged-marker{color:var(--accent-jade);font-style:italic;opacity:.85}.row-action-btn.merged-toggle-btn{opacity:.55}.row-action-btn.merged-toggle-btn:hover{opacity:1;color:var(--accent-jade)}.row-action-btn.merged-toggle-btn.is-expanded svg{transform:rotate(180deg)}.row-action-btn.merged-toggle-btn svg{transition:transform var(--transition-fast)}.translation-merged-group.is-expanded{border-left:2px solid var(--accent-jade-overlay);padding-left:.5rem;margin:.15rem 0}.merged-expanded-head{display:flex;align-items:center;justify-content:flex-end;gap:.4rem}@media(max-width:768px){.vocab-table .tags-col,.vocab-table .row-action-btn{display:none}.vocab-table thead th,.vocab-table tbody td{padding:.6rem .65rem}.source-link-full{display:none}.source-link-kind{display:inline-block}}.tabs{display:flex;gap:var(--spacing-sm)}.tab{padding:.5rem var(--spacing-md);border:1px solid var(--border-card);background:var(--surface-card);color:var(--text-primary);border-radius:var(--radius-md);cursor:pointer;font:inherit;font-size:.9rem;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.tab:hover{border-color:var(--accent-jade)}.tab.active{background:var(--accent-jade);color:var(--text-on-accent);border-color:var(--accent-jade)}.tag-editor{display:flex;flex-wrap:wrap;gap:.25rem;align-items:center;font-size:.8rem}.tag-chip{display:inline-flex;align-items:center;gap:.2rem;padding:.15rem .45rem;background:var(--tag-chip-bg);color:var(--tag-chip-fg);border:1px solid var(--tag-chip-border);border-radius:var(--radius-pill);font-size:.75rem;line-height:1.3;white-space:nowrap}.tag-chip-name{word-break:break-word}.tag-chip-remove{background:none;border:none;color:var(--tag-chip-fg);cursor:pointer;font-size:.95rem;line-height:1;padding:0;opacity:.7;transition:opacity var(--transition-fast),color var(--transition-fast)}.tag-chip-remove:hover{opacity:1;color:var(--accent-coral)}.tag-add-btn{background:transparent;border:1px dashed var(--tag-chip-fg);color:var(--tag-chip-fg);border-radius:var(--radius-pill);padding:.05rem .45rem;font-size:.85rem;line-height:1.2;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.tag-add-btn:hover{background:var(--accent-jade-soft);border-color:var(--tag-chip-fg)}.tag-add-input{background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--accent-jade-soft);border-radius:var(--radius-pill);padding:.1rem .5rem;font:inherit;font-size:.75rem;outline:none;width:7rem}.tag-add-input::placeholder{color:var(--text-muted);opacity:.7}.tag-add-input:focus{border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.tag-add-wrapper{position:relative;display:inline-block}.tag-suggestions{position:absolute;top:calc(100% + 4px);left:0;z-index:50;margin:0;padding:.2rem 0;list-style:none;min-width:9rem;max-width:18rem;background:var(--surface-elevated);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);box-shadow:var(--shadow-elevated);font-size:.8rem;max-height:12rem;overflow-y:auto}.tag-suggestion{padding:.3rem .7rem;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tag-suggestion.is-highlighted,.tag-suggestion:hover{background:var(--accent-jade-soft);color:var(--accent-jade)}.tag-editor.compact{font-size:.7rem;gap:.2rem}.tag-editor.compact .tag-chip{padding:.05rem .35rem;font-size:.65rem}.tag-editor.compact .tag-add-btn{padding:0 .35rem;font-size:.75rem}.inline-save-panel{background:var(--surface-elevated);border:2px solid var(--accent-jade);border-radius:var(--radius-md);padding:.75rem var(--spacing-md);margin:.75rem 0;box-shadow:var(--shadow-card-hover);white-space:normal}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.panel-title{font-weight:var(--font-weight-semibold);color:var(--accent-jade);font-size:.8rem}.panel-note-btn{margin-left:auto;margin-right:.15rem;display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem .3rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.panel-note-btn:hover{color:var(--accent-jade);background:var(--surface-muted)}.panel-note-btn svg{display:block}.panel-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem;line-height:1;padding:.15rem}.panel-close:hover{color:var(--text-primary)}.selected-phrase{padding:0;margin-bottom:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.phrase-text{font-style:italic;color:var(--text-primary);flex:1;word-break:break-word;font-size:.9rem}.phrase-edit-label{display:flex;flex-direction:column;gap:.25rem}.phrase-edit-caption{font-size:.7rem;font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.phrase-edit-input{width:100%;padding:.4rem .6rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-sm);font:inherit;font-size:.9rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.phrase-edit-input:focus,.phrase-edit-input:focus-visible{outline:none;border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.phrase-edit-input::placeholder{color:var(--text-muted);opacity:.6}.phrase-translation-display{font-style:italic;font-size:.9rem;color:var(--text-primary);padding:0 .2rem;word-break:break-word}.phrase-translation-display.is-loading{color:var(--text-muted);opacity:.8}.selected-phrase .save-phrase-btn{align-self:flex-end}.save-phrase-btn,.save-selected-btn{background:var(--accent-jade);color:var(--text-on-accent);border:none;padding:.35rem .6rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast)}.save-selected-btn{padding:.4rem .75rem;font-size:.8rem}.save-phrase-btn:hover,.save-selected-btn:hover{background:var(--accent-jade-hover)}.save-phrase-btn:disabled,.save-selected-btn:disabled{background:var(--surface-muted);color:var(--text-muted);cursor:not-allowed}.analysis-status{color:var(--text-muted);font-size:.75rem;margin-bottom:.4rem;display:flex;align-items:center;gap:.4rem}.extractor-spinner{width:12px;height:12px;border:2px solid var(--border-card);border-top-color:var(--accent-jade);border-radius:50%;animation:extractor-spin .8s linear infinite}@keyframes extractor-spin{to{transform:rotate(360deg)}}.extracted-section{margin-top:var(--spacing-sm)}.section-label{font-size:.65rem;font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.35rem}.items-grid{display:flex;flex-wrap:wrap;gap:.35rem}.save-item{background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-sm);padding:.3rem .5rem;font:inherit;font-size:.8rem;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);display:flex;align-items:center;gap:.3rem}.save-item:hover{border-color:var(--accent-jade);background:var(--accent-jade-soft)}.save-item.selected{background:var(--accent-jade-soft);border-color:var(--accent-jade)}.save-item.saved{background:var(--accent-jade-soft);border-color:var(--accent-jade);color:var(--accent-jade)}.item-check{width:12px;height:12px;border:1.5px solid var(--border-card);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--text-on-accent);transition:background var(--transition-fast),border-color var(--transition-fast);flex-shrink:0}.save-item.selected .item-check,.save-item.saved .item-check{background:var(--accent-jade);border-color:var(--accent-jade)}.item-translation,.item-base-form{color:var(--text-muted);font-size:.75rem;margin-left:.25rem}.panel-actions{margin-top:.6rem;display:flex;gap:var(--spacing-sm)}.text-extractable::selection{background:var(--accent-jade-soft)}.texts-list-sidebar{max-height:200px;overflow:hidden;margin:var(--spacing-xs) .75rem 0 2.25rem;padding-left:var(--spacing-sm);border-left:1px solid var(--sidebar-border-light)}.texts-list-items{overflow-y:auto;max-height:200px}.texts-list-item{display:flex;align-items:center;height:32px;padding:0 var(--spacing-xs);margin:var(--spacing-xs) 0;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;transition:background var(--transition-fast)}.texts-list-item:hover{background:#ffffff0d}.texts-list-item.active{background:#ffffff14}.texts-list-title{flex:1;min-width:0;font-size:var(--font-size-base);color:var(--sidebar-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:32px;transition:color var(--transition-fast)}.texts-list-item:hover .texts-list-title,.texts-list-item.active .texts-list-title{color:var(--sidebar-text)}.texts-list-title-input{flex:1;min-width:0;font-size:var(--font-size-base);background:transparent;border:none;border-bottom:1px solid var(--sidebar-accent);color:var(--sidebar-text);padding:0;margin:0;outline:none;font-family:inherit;line-height:30px}.texts-list-btn{flex-shrink:0;width:22px;text-align:center;background:transparent;border:none;color:#555;font-size:var(--font-size-sm);cursor:pointer;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast);line-height:1}.texts-list-item:hover .texts-list-btn{opacity:1}.texts-list-btn:hover{color:var(--sidebar-text)}.texts-list-btn.delete:hover{color:#e66}.saved-texts-modal .texts-list-sidebar{max-height:none;margin:0;padding-left:0;border-left:none;overflow:visible}.saved-texts-modal .texts-list-items{max-height:60vh;overflow-y:auto}.saved-texts-modal .texts-list-item{height:auto;padding:.55rem .75rem}.saved-texts-modal .texts-list-title{color:var(--text-primary);line-height:1.4}.saved-texts-modal .texts-list-item:hover{background:var(--surface-elevated)}.saved-texts-modal .texts-list-item.active{background:var(--accent-jade-soft)}.saved-texts-modal .texts-list-btn{color:var(--text-muted);opacity:1}.saved-texts-modal .texts-list-btn:hover{color:var(--text-primary)}.saved-texts-modal .texts-list-btn.delete:hover{color:var(--accent-coral)}.toggle{display:inline-flex;align-items:stretch;background:var(--surface-card);border:1px solid var(--border-card);border-radius:var(--radius-pill);padding:2px;gap:0}.toggle-option{appearance:none;font:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);background:transparent;border:none;color:var(--text-muted);padding:.4rem .95rem;border-radius:var(--radius-pill);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast)}.toggle-option:hover:not(.active){color:var(--text-primary);background:var(--accent-jade-soft)}.toggle-option:focus-visible{outline:none;box-shadow:var(--ring-focus)}.toggle-option.active{background:var(--accent-jade);color:var(--text-on-accent)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}html{font-size:16px}body{font-family:system-ui,-apple-system,sans-serif;font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background:var(--bg-main);min-height:100vh;overflow-x:clip}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:var(--font-weight-bold);letter-spacing:-.015em}h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-lg);position:relative;padding-bottom:.6rem}h1:after{content:"";position:absolute;left:0;bottom:0;width:60px;height:8px;background-repeat:no-repeat;background-position:left center;background-size:60px 8px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 8' fill='none'><path d='M2 4 Q 6 0.5, 10 4 T 18 4 T 26 4 T 34 4 T 42 4 T 50 4 T 58 4' stroke='%2373daca' stroke-width='2.4' stroke-linecap='round' fill='none'/></svg>")}h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}h3{font-size:var(--font-size-xl);margin-bottom:var(--spacing-sm)}a{color:var(--accent-lagoon);text-decoration:none}a:hover{text-decoration:underline;text-decoration-color:var(--accent-lagoon);text-decoration-thickness:2px;text-underline-offset:3px}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-box-shadow:0 0 0 100px var(--surface-muted) inset!important;-webkit-text-fill-color:var(--text-primary)!important;caret-color:var(--text-primary);transition:background-color 600000s 0s,color 600000s 0s}.error-message{color:var(--color-danger);padding:var(--spacing-md);text-align:center}.inline-error{display:flex;align-items:center;gap:var(--spacing-sm);color:var(--color-danger);padding:var(--spacing-md)}.inline-error .error-icon{font-size:var(--font-size-lg)}.loading-content{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-lg);color:var(--text-muted)}.placeholder-text{color:var(--text-muted);padding:var(--spacing-md)}
