:root{--primitive-neutral-0: #ffffff;--primitive-neutral-50: #f8f9fa;--primitive-neutral-100: #f1f3f5;--primitive-neutral-200: #e9ecef;--primitive-neutral-300: #dee2e6;--primitive-neutral-400: #ced4da;--primitive-neutral-500: #adb5bd;--primitive-neutral-600: #6c757d;--primitive-neutral-700: #495057;--primitive-neutral-800: #343a40;--primitive-neutral-850: #212529;--primitive-neutral-900: #16191d;--primitive-neutral-950: #0d0f12;--primitive-neutral-1000: #000000;--primitive-brand-50: #eef2ff;--primitive-brand-100: #e0e7ff;--primitive-brand-200: #c7d2fe;--primitive-brand-300: #a5b4fc;--primitive-brand-400: #818cf8;--primitive-brand-500: #6366f1;--primitive-brand-600: #4f46e5;--primitive-brand-700: #4338ca;--primitive-brand-800: #3730a3;--primitive-brand-900: #312e81;--primitive-brand-950: #1e1b4b;--primitive-accent-400: #a78bfa;--primitive-accent-500: #8b5cf6;--primitive-accent-600: #7c3aed;--primitive-success-100: #d1fae5;--primitive-success-400: #34d399;--primitive-success-500: #10b981;--primitive-success-600: #059669;--primitive-success-900: #064e3b;--primitive-warning-100: #fef3c7;--primitive-warning-400: #fbbf24;--primitive-warning-500: #f59e0b;--primitive-warning-600: #d97706;--primitive-warning-900: #78350f;--primitive-danger-100: #fee2e2;--primitive-danger-400: #f87171;--primitive-danger-500: #ef4444;--primitive-danger-600: #dc2626;--primitive-danger-900: #7f1d1d;--primitive-info-100: #dbeafe;--primitive-info-400: #60a5fa;--primitive-info-500: #3b82f6;--primitive-info-600: #2563eb;--primitive-info-900: #1e3a8a}:root,[data-theme=light]{--color-bg-base: var(--primitive-neutral-0);--color-bg-primary: var(--primitive-neutral-50);--color-bg-secondary: var(--primitive-neutral-100);--color-bg-tertiary: var(--primitive-neutral-200);--color-bg-elevated: var(--primitive-neutral-0);--color-bg-overlay: rgba(0, 0, 0, .4);--color-text-primary: var(--primitive-neutral-850);--color-text-secondary: var(--primitive-neutral-600);--color-text-tertiary: var(--primitive-neutral-500);--color-text-disabled: var(--primitive-neutral-400);--color-border-subtle: var(--primitive-neutral-200);--color-border-default: var(--primitive-neutral-300);--color-border-strong: var(--primitive-neutral-400);--color-brand: var(--primitive-brand-600);--color-brand-default: var(--color-brand);--color-brand-hover: var(--primitive-brand-700);--color-brand-active: var(--primitive-brand-800);--color-brand-subtle: var(--primitive-brand-50);--color-brand-text: var(--primitive-neutral-0);--color-accent-default: var(--primitive-accent-500);--color-accent-hover: var(--primitive-accent-600);--color-accent-subtle: #ede9fe;--color-success-bg: var(--primitive-success-100);--color-success-fg: var(--primitive-success-600);--color-success-border: var(--primitive-success-400);--color-warning-bg: var(--primitive-warning-100);--color-warning-fg: var(--primitive-warning-600);--color-warning-border: var(--primitive-warning-400);--color-danger-bg: var(--primitive-danger-100);--color-danger-fg: var(--primitive-danger-600);--color-danger-border: var(--primitive-danger-400);--color-info-bg: var(--primitive-info-100);--color-info-fg: var(--primitive-info-600);--color-info-border: var(--primitive-info-400);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .07);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .15);--color-scrollbar-track: var(--primitive-neutral-100);--color-scrollbar-thumb: var(--primitive-neutral-400);--transition-speed-fast: .15s;--transition-speed-normal: .25s;--transition-speed-slow: .4s;--transition-ease: cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-bg-base: var(--primitive-neutral-950);--color-bg-primary: var(--primitive-neutral-900);--color-bg-secondary: var(--primitive-neutral-850);--color-bg-tertiary: var(--primitive-neutral-800);--color-bg-elevated: var(--primitive-neutral-800);--color-bg-overlay: rgba(0, 0, 0, .65);--color-text-primary: var(--primitive-neutral-50);--color-text-secondary: var(--primitive-neutral-400);--color-text-tertiary: var(--primitive-neutral-500);--color-text-disabled: var(--primitive-neutral-700);--color-border-subtle: var(--primitive-neutral-800);--color-border-default: var(--primitive-neutral-700);--color-border-strong: var(--primitive-neutral-600);--color-brand: var(--primitive-brand-500);--color-brand-default: var(--color-brand);--color-brand-hover: var(--primitive-brand-400);--color-brand-active: var(--primitive-brand-300);--color-brand-subtle: var(--primitive-brand-950);--color-brand-text: var(--primitive-neutral-0);--color-accent-default: var(--primitive-accent-400);--color-accent-hover: var(--primitive-accent-500);--color-accent-subtle: rgba(139, 92, 246, .15);--color-success-bg: var(--primitive-success-900);--color-success-fg: var(--primitive-success-400);--color-success-border: var(--primitive-success-500);--color-warning-bg: var(--primitive-warning-900);--color-warning-fg: var(--primitive-warning-400);--color-warning-border: var(--primitive-warning-500);--color-danger-bg: var(--primitive-danger-900);--color-danger-fg: var(--primitive-danger-400);--color-danger-border: var(--primitive-danger-500);--color-info-bg: var(--primitive-info-900);--color-info-fg: var(--primitive-info-400);--color-info-border: var(--primitive-info-500);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .55);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .6);--color-scrollbar-track: var(--primitive-neutral-900);--color-scrollbar-thumb: var(--primitive-neutral-700)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg-base: var(--primitive-neutral-950);--color-bg-primary: var(--primitive-neutral-900);--color-bg-secondary: var(--primitive-neutral-850);--color-bg-tertiary: var(--primitive-neutral-800);--color-bg-elevated: var(--primitive-neutral-800);--color-bg-overlay: rgba(0, 0, 0, .65);--color-text-primary: var(--primitive-neutral-50);--color-text-secondary: var(--primitive-neutral-400);--color-text-tertiary: var(--primitive-neutral-500);--color-text-disabled: var(--primitive-neutral-700);--color-border-subtle: var(--primitive-neutral-800);--color-border-default: var(--primitive-neutral-700);--color-border-strong: var(--primitive-neutral-600);--color-brand: var(--primitive-brand-500);--color-brand-default: var(--color-brand);--color-brand-hover: var(--primitive-brand-400);--color-brand-active: var(--primitive-brand-300);--color-brand-subtle: var(--primitive-brand-950);--color-brand-text: var(--primitive-neutral-0);--color-accent-default: var(--primitive-accent-400);--color-accent-hover: var(--primitive-accent-500);--color-accent-subtle: rgba(139, 92, 246, .15);--color-success-bg: var(--primitive-success-900);--color-success-fg: var(--primitive-success-400);--color-success-border: var(--primitive-success-500);--color-warning-bg: var(--primitive-warning-900);--color-warning-fg: var(--primitive-warning-400);--color-warning-border: var(--primitive-warning-500);--color-danger-bg: var(--primitive-danger-900);--color-danger-fg: var(--primitive-danger-400);--color-danger-border: var(--primitive-danger-500);--color-info-bg: var(--primitive-info-900);--color-info-fg: var(--primitive-info-400);--color-info-border: var(--primitive-info-500);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .55);--shadow-xl: 0 16px 40px rgba(0, 0, 0, .6);--color-scrollbar-track: var(--primitive-neutral-900);--color-scrollbar-thumb: var(--primitive-neutral-700)}}:root{--text-xs: clamp(.688rem, .6rem + .2vw, .813rem);--text-sm: clamp(.75rem, .68rem + .25vw, .938rem);--text-base: clamp(.875rem, .78rem + .3vw, 1.063rem);--text-lg: clamp(1rem, .9rem + .35vw, 1.25rem);--text-xl: clamp(1.125rem, .98rem + .5vw, 1.5rem);--text-2xl: clamp(1.375rem, 1.15rem + .7vw, 1.875rem);--text-3xl: clamp(1.75rem, 1.4rem + 1.2vw, 2.5rem);--space-1: clamp(4px, .3vw, 6px);--space-2: clamp(6px, .5vw, 10px);--space-3: clamp(8px, .7vw, 14px);--space-4: clamp(12px, .9vw, 20px);--space-6: clamp(16px, 1.3vw, 28px);--space-8: clamp(20px, 1.8vw, 40px);--radius-sm: clamp(4px, .3vw, 6px);--radius: clamp(6px, .5vw, 10px);--radius-lg: clamp(10px, .8vw, 16px);--radius-xl: clamp(14px, 1.1vw, 24px);--activity-bar-width: clamp(44px, 3.5vw, 64px);--top-bar-height: clamp(38px, 3vw, 56px);--sidebar-min-width: clamp(160px, 13vw, 220px);--sidebar-default: clamp(240px, 18vw, 340px)}.app-shell{display:flex;height:100vh;overflow:hidden;background-color:var(--color-bg-base)}.activity-bar{width:var(--activity-bar-width);flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:var(--space-2) 0;gap:2px;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border-subtle);z-index:10;-webkit-app-region:drag}.activity-bar__top{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.activity-bar__bottom{display:flex;flex-direction:column;align-items:center;gap:2px}.activity-bar__btn{-webkit-app-region:no-drag;position:relative;width:calc(var(--activity-bar-width) - 8px);height:calc(var(--activity-bar-width) - 8px);display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius);background:transparent;color:var(--color-text-tertiary);cursor:pointer;transition:background-color var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease);outline:none}.activity-bar__btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.activity-bar__btn.active{color:var(--color-brand-default)}.activity-bar__btn.active:before{content:"";position:absolute;left:-2px;top:50%;transform:translateY(-50%);width:2px;height:clamp(18px,1.4vw,26px);background-color:var(--color-brand-default);border-radius:0 2px 2px 0}.activity-bar__btn[data-tooltip]:after{content:attr(data-tooltip);position:absolute;left:calc(100% + 10px);top:50%;transform:translateY(-50%);background-color:var(--color-bg-elevated);color:var(--color-text-primary);font-size:var(--text-xs);font-weight:500;white-space:nowrap;padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--color-border-default);box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity var(--transition-speed-fast) var(--transition-ease);z-index:100}.activity-bar__btn[data-tooltip]:hover:after{opacity:1}.sidebar{position:relative;flex-shrink:0;display:flex;flex-direction:row;background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border-default);overflow:hidden;transition:width var(--transition-speed-normal) var(--transition-ease)}.sidebar.resizing{transition:none}.sidebar.collapsed{width:0!important}.sidebar__inner{flex:1;min-width:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.sidebar__header{padding:var(--space-3) var(--space-4) var(--space-2);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.sidebar__title{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.sidebar__content{flex:1;overflow-y:auto;padding:var(--space-2) 0}.sidebar__resizer{flex-shrink:0;width:4px;cursor:col-resize;background:transparent;transition:background-color var(--transition-speed-fast) var(--transition-ease);position:relative;z-index:5}.sidebar__resizer:before{content:"";position:absolute;inset:0 -3px}.sidebar__resizer:hover,.sidebar__resizer.active{background-color:var(--color-brand-default)}.main-content{flex:1;overflow:hidden;display:flex;flex-direction:column;background-color:var(--color-bg-base)}.page-scroll{flex:1;overflow-y:auto}.right-panel{position:relative;flex-shrink:0;display:flex;flex-direction:row;background-color:var(--color-bg-secondary);border-left:1px solid var(--color-border-default);overflow:hidden;transition:width var(--transition-speed-normal) var(--transition-ease)}.right-panel.resizing{transition:none}.right-panel.collapsed{width:0!important;border-left:none}.right-panel__resizer{flex-shrink:0;width:4px;cursor:col-resize;background:transparent;transition:background-color var(--transition-speed-fast) var(--transition-ease);position:relative;z-index:5;order:-1}.right-panel__resizer:before{content:"";position:absolute;inset:0 -3px}.right-panel__resizer:hover,.right-panel__resizer.active{background-color:var(--color-brand-default)}.right-panel__inner{flex:1;min-width:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.right-panel__header{padding:var(--space-3) var(--space-4) var(--space-2);border-bottom:1px solid var(--color-border-subtle);flex-shrink:0}.right-panel__title{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-secondary)}.right-panel__content{flex:1;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.top-bar{flex-shrink:0;height:var(--top-bar-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4) 0 var(--space-4);background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-subtle);-webkit-app-region:drag;-webkit-user-select:none;-moz-user-select:none;user-select:none}.top-bar__left{display:flex;align-items:center;gap:var(--space-2);min-width:0}.top-bar__breadcrumb{-webkit-app-region:no-drag;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:20px;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);transition:background-color var(--transition-speed-fast) var(--transition-ease),border-color var(--transition-speed-fast) var(--transition-ease)}.top-bar__breadcrumb:hover{background-color:var(--color-bg-elevated);border-color:var(--color-border-default)}.top-bar__breadcrumb-icon{color:var(--color-brand-default);flex-shrink:0}.top-bar__breadcrumb-label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-bar__breadcrumb--empty .top-bar__breadcrumb-label{color:var(--color-text-secondary);font-weight:500}.top-bar__right{-webkit-app-region:no-drag;display:flex;align-items:center;gap:var(--space-1)}.top-bar__icon-btn{width:clamp(28px,2.2vw,38px);height:clamp(28px,2.2vw,38px);display:flex;align-items:center;justify-content:center;border:none;border-radius:50%;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease),transform var(--transition-speed-fast) var(--transition-ease);outline:none}.top-bar__icon-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);transform:rotate(15deg)}.top-bar__icon-btn:active{transform:scale(.9)}.top-bar__sidebar-toggle:hover{transform:none;background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.top-bar__sidebar-toggle:active{transform:scale(.9)}.top-bar__sidebar-toggle.is-open{color:var(--color-brand-default, #6366f1);background-color:var(--color-brand-subtle, rgba(99,102,241,.12))}.top-bar__sidebar-toggle.is-open:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.top-bar__divider{width:1px;height:clamp(16px,1.2vw,22px);background-color:var(--color-border-subtle);margin:0 var(--space-1);border-radius:1px}.top-bar__avatar{width:clamp(28px,2.2vw,38px);height:clamp(28px,2.2vw,38px);display:flex;align-items:center;justify-content:center;border:1.5px solid var(--color-border-default);border-radius:50%;background:linear-gradient(135deg,var(--color-brand-subtle),var(--color-bg-tertiary));color:var(--color-brand-default);cursor:pointer;overflow:hidden;transition:border-color var(--transition-speed-fast) var(--transition-ease),box-shadow var(--transition-speed-fast) var(--transition-ease),transform var(--transition-speed-fast) var(--transition-ease);outline:none}.top-bar__avatar:hover{border-color:var(--color-brand-default);box-shadow:0 0 0 3px var(--color-brand-subtle);transform:scale(1.08)}.top-bar__avatar:active{transform:scale(.95)}.ae-page-container{padding:24px;max-width:900px;margin:0 auto}.ae-page-header{margin-bottom:24px;border-bottom:1px solid var(--color-border-default);padding-bottom:16px}.ae-page-header h1{font-size:20px;font-weight:600;color:var(--color-text-primary)}.ae-page-error{padding:24px;text-align:center;color:var(--color-notification)}.ae-paragraph-list{display:flex;flex-direction:column;gap:12px}.ae-paragraph-loading,.ae-paragraph-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--color-text-secondary);gap:12px}.ae-segment{position:relative;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:var(--radius-lg, 12px);overflow:hidden;cursor:pointer;transition:all var(--transition-speed-normal, .3s) var(--transition-ease, ease)}.ae-segment:hover{border-color:var(--color-border-hover, var(--color-brand));transform:translateY(-1px);box-shadow:0 4px 12px #0000000d}.ae-segment--active{border-color:var(--color-brand-default, var(--color-brand));background:var(--color-bg-primary, #fff);box-shadow:0 4px 12px #00000014}.ae-segment__color-bar{position:absolute;left:0;top:0;bottom:0;width:4px}.ae-segment__body{padding:var(--space-4, 16px) var(--space-5, 20px);padding-left:calc(var(--space-5, 20px) + 4px)}.ae-segment__index{font-size:var(--text-xs, 12px);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.ae-segment__play-btn{display:flex;align-items:center;gap:var(--space-2, 8px);padding:4px 10px;background:var(--color-bg-tertiary, var(--color-bg-secondary));border:1px solid var(--color-border-default);border-radius:var(--radius-full, 9999px);font-size:var(--text-xs, 12px);font-weight:500;color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-speed-fast, .2s) var(--transition-ease, ease)}.ae-segment__play-btn:hover:not(:disabled){background:var(--color-bg-hover, var(--color-bg-secondary));border-color:var(--color-border-hover, var(--color-border-default))}.ae-segment__play-btn:disabled{opacity:.5;cursor:not-allowed}.ae-segment__play-btn--playing{background:var(--color-brand-subtle, rgba(var(--color-brand-rgb), .1));border-color:var(--color-brand-subtle, rgba(var(--color-brand-rgb), .2));color:var(--color-brand-default, var(--color-brand))}.ae-segment__text{margin-top:var(--space-3, 12px);font-size:var(--text-base, 16px);line-height:1.6;color:var(--color-text-primary)}.ae-segment__audio-tag{display:inline-flex;align-items:center;gap:var(--space-2, 8px);margin-top:var(--space-3, 12px);padding:4px 10px;background:var(--color-brand-subtle, rgba(var(--color-brand-rgb), .1));border-radius:var(--radius-full, 9999px);font-size:var(--text-xs, 12px);font-weight:500;color:var(--color-brand-default, var(--color-brand))}.ae-segment__audio-dot{width:6px;height:6px;border-radius:50%}.ae-segment__controls{margin-top:var(--space-4, 16px);padding-top:var(--space-3, 12px);border-top:1px solid var(--color-border-default);display:flex;flex-direction:column;gap:var(--space-3, 12px)}.ae-segment__control-row{display:flex;align-items:center;gap:var(--space-3, 12px)}.ae-segment__control-label{width:70px;font-size:var(--text-sm, 14px);color:var(--color-text-secondary)}.ae-segment__slider{flex:1;cursor:pointer}.ae-segment__control-value{width:40px;text-align:right;font-size:var(--text-xs, 12px);font-weight:500;font-family:Inter,monospace;color:var(--color-text-secondary)}.ae-toolbar{display:flex;flex-direction:column;gap:16px;height:100%;padding:20px}.ae-toolbar__hint{display:flex;align-items:center;gap:8px;padding:12px;background:var(--color-bg-secondary);border-radius:8px;font-size:13px;color:var(--color-text-secondary);border:1px solid var(--color-border-default)}.ae-toolbar__hint--active{background:rgba(var(--color-brand-rgb),.1);color:var(--color-brand);border-color:var(--color-brand);font-weight:500}.ae-toolbar__dict-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border-default);border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.ae-toolbar__dict-btn:hover{background:var(--color-bg-tertiary)}.ae-toolbar__section-title{font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:8px;padding-bottom:8px;border-bottom:1px solid var(--color-border-default)}.ae-audio-selector{display:flex;flex-direction:column;gap:16px}.ae-audio-selector__dropdown-wrap{position:relative}.ae-audio-selector__trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--color-brand);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.ae-rotate-180{transform:rotate(180deg)}.ae-audio-selector__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;max-height:300px;display:flex;flex-direction:column}.ae-audio-selector__create-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:transparent;border:none;border-bottom:1px solid var(--color-border-default);color:var(--color-brand);font-weight:600;cursor:pointer}.ae-audio-selector__create-btn:hover{background:var(--color-bg-secondary)}.ae-audio-selector__options{overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.ae-audio-selector__option{border-radius:8px}.ae-audio-selector__option:hover{background:var(--color-bg-secondary)}.ae-audio-selector__empty{padding:16px;text-align:center;color:var(--color-text-secondary);font-size:13px}.ae-audio-card{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:8px;border:1px solid var(--color-border-default)}.ae-audio-card__avatar{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:1px solid rgba(0,0,0,.1);background:#fff}.ae-audio-card__name{flex:1;font-weight:500;font-size:14px;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ae-audio-selected{display:flex;flex-direction:column;gap:8px}.ae-audio-selected--empty{align-items:center;justify-content:center;padding:24px;border:1px dashed var(--color-border-default);border-radius:8px}.ae-audio-selected__empty-hint{color:var(--color-text-secondary);font-size:13px;text-align:center}.ae-modal-overlay{position:fixed;inset:0;background:#0009;z-index:9999;display:flex;align-items:center;justify-content:center;padding:24px}.ae-modal{background:var(--color-bg-base);border-radius:12px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 25px #0003;overflow:hidden}.ae-modal--sm{max-width:500px}.ae-modal__header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--color-border-default);background:var(--color-bg-secondary)}.ae-modal__title-wrap{display:flex;align-items:center;gap:12px;color:var(--color-text-primary)}.ae-modal__title{font-size:18px;font-weight:600;margin:0;color:var(--color-text-primary)}.ae-modal__actions{display:flex;gap:12px;margin-right:16px}.ae-modal__close-icon{background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;padding:4px;display:flex}.ae-modal__close-icon:hover{color:var(--color-text-primary)}.ae-modal__cancel-btn,.ae-modal__submit-btn{padding:8px 16px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer}.ae-modal__cancel-btn{background:transparent;border:1px solid var(--color-border-default);color:var(--color-text-primary)}.ae-modal__submit-btn{background:var(--color-brand);border:none;color:#fff}.ae-modal__submit-btn:disabled{opacity:.7;cursor:not-allowed}.ae-modal__body{display:flex;flex:1;overflow:hidden}.ae-modal__left{flex:3;padding:24px;overflow-y:auto;border-right:1px solid var(--color-border-default);display:flex;flex-direction:column;gap:24px}.ae-modal__right{flex:2;padding:24px;background:var(--color-bg-secondary);display:flex;flex-direction:column;align-items:center}.ae-modal__section{display:flex;flex-direction:column;gap:12px}.ae-modal__section-title{font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;margin:0}.ae-modal__input{width:100%;padding:10px 12px;border-radius:8px;border:1px solid var(--color-border-default);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:14px}.ae-file-selector{border:2px dashed var(--color-border-default);border-radius:8px;padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;position:relative;transition:all .2s}.ae-file-selector:hover{background:var(--color-bg-secondary)}.ae-file-selector--has-file{border-style:solid;cursor:default;background:var(--color-bg-secondary);padding:16px}.ae-file-selector__icon{color:var(--color-text-secondary)}.ae-file-selector__hint{color:var(--color-text-secondary);font-size:14px;margin:0}.ae-file-selector__remove{position:absolute;top:-8px;right:-8px;background:var(--color-notification);color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2}.ae-file-selector__audio{width:100%;height:40px}.ae-color-picker{display:flex;flex-wrap:wrap;gap:8px;padding:16px;background:var(--color-bg-secondary);border-radius:8px;border:1px solid var(--color-border-default)}.ae-color-picker__swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.ae-color-picker__swatch:hover{transform:scale(1.1)}.ae-color-picker__swatch--active{border-color:var(--color-text-primary);transform:scale(1.1)}.ae-color-picker__custom{width:32px;height:32px;padding:0;border:none;border-radius:50%;overflow:hidden;cursor:pointer}.ae-color-picker__preview{margin-top:12px;padding:12px;border-radius:8px;text-align:center;font-weight:600;color:#000000b3}.ae-modal__image-drop{width:200px;height:200px;border:2px dashed var(--color-border-default);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;background:var(--color-bg-base);margin-top:24px}.ae-modal__image-preview{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ae-modal__image-remove{position:absolute;top:16px;right:16px;background:var(--color-notification);color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer}.ae-modal__image-placeholder{display:flex;flex-direction:column;align-items:center;color:var(--color-text-secondary)}.ae-modal__image-icon{font-size:32px;margin-bottom:8px}.ae-modal__dict-body{padding:20px 24px;overflow-y:auto;max-height:60vh}.ae-modal__dict-hint{color:var(--color-text-secondary);font-size:13px;margin-bottom:16px}.ae-dict-editor{display:flex;flex-direction:column;gap:12px}.ae-dict-editor__empty{text-align:center;color:var(--color-text-secondary);font-size:14px;padding:24px;background:var(--color-bg-secondary);border-radius:8px}.ae-dict-editor__add-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:var(--color-brand-default);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;transition:opacity .2s}.ae-dict-editor__add-btn:hover{opacity:.9}.ae-dict-entry{display:flex;flex-direction:column;background:var(--color-bg-base);border:1px solid var(--color-border-default);border-radius:8px;padding:2px;position:relative;box-shadow:0 1px 4px #0000000d}.ae-dict-entry__delete{position:absolute;top:6px;right:6px;background:transparent;border:none;color:var(--color-notification);cursor:pointer;padding:2px 6px;font-size:14px;line-height:1;transition:color .2s}.ae-dict-entry__fields{display:flex;align-items:center;gap:5px}.ae-dict-entry__input{flex:1;padding:8px 12px;border-radius:6px;border:1px solid var(--color-border-default);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:14px;min-width:0}.ae-dict-entry__sep{color:var(--color-text-primary);margin:0 6px}.sa-manager__modal{max-width:560px;position:relative}.sa-manager__body{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:20px 24px;gap:16px}.sa-manager__back-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:20px;line-height:1;cursor:pointer;padding:0 4px;transition:color .15s}.sa-manager__back-btn:hover{color:var(--color-text-primary)}.sa-manager__header-icon{color:var(--color-brand-default);flex-shrink:0}.sa-manager__create-btn{display:inline-flex;align-items:center;gap:6px;font-size:13px}.sa-manager__header-create-btn{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--color-brand-default);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.sa-manager__header-create-btn:hover{opacity:.9}.sa-manager__search-wrap{position:relative;display:flex;align-items:center}.sa-manager__search-icon{position:absolute;left:10px;color:var(--color-text-secondary);pointer-events:none}.sa-manager__search-input{width:100%;padding:9px 12px 9px 32px;border:1px solid var(--color-border-default);border-radius:8px;background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:13px;outline:none;transition:border-color .15s}.sa-manager__search-input:focus{border-color:var(--color-brand-default)}.sa-manager__list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:400px;padding-right:2px;scrollbar-width:none;-ms-overflow-style:none}.sa-manager__list::-webkit-scrollbar{display:none}.sa-manager__row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:10px;transition:border-color .15s,box-shadow .15s}.sa-manager__row:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.sa-manager__row--enabled{border-color:var(--color-brand-default);background:var(--color-brand-subtle, rgba(59,130,246,.06))}.sa-manager__row-checkbox{width:20px;height:20px;border-radius:5px;border:2px solid var(--color-border-strong);background:var(--color-bg-base);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;color:#fff;padding:0}.sa-manager__row-checkbox:hover{border-color:var(--color-brand-default);background:var(--color-brand-subtle, rgba(59,130,246,.1))}.sa-manager__row-checkbox--checked{background:var(--color-brand-default);border-color:var(--color-brand-default)}.sa-manager__row-checkbox--checked:hover{background:var(--color-brand-hover, #2563eb);border-color:var(--color-brand-hover, #2563eb)}.sa-manager__row-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px;background:var(--color-brand-default);color:#fff;letter-spacing:.3px;flex-shrink:0;text-transform:uppercase}.sa-manager__row-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.sa-manager__row-avatar{width:38px;height:38px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid rgba(0,0,0,.08);background:var(--color-bg-tertiary);flex-shrink:0}.sa-manager__row-name{flex:1;font-size:14px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-manager__row-actions{display:flex;gap:6px;flex-shrink:0}.sa-manager__icon-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:6px;border:1px solid var(--color-border-default);background:var(--color-bg-base);cursor:pointer;transition:all .15s}.sa-manager__icon-btn--edit{color:var(--color-brand-default)}.sa-manager__icon-btn--edit:hover{background:var(--color-brand-subtle);border-color:var(--color-brand-default)}.sa-manager__icon-btn--delete{color:var(--color-danger-fg)}.sa-manager__icon-btn--delete:hover{background:var(--color-danger-bg);border-color:var(--color-danger-border)}.sa-manager__empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:var(--color-text-secondary);font-size:14px}.sa-manager__empty-icon{color:var(--color-text-tertiary);opacity:.5}.sa-manager__empty{text-align:center;color:var(--color-text-secondary);font-size:13px;padding:24px}.sa-manager__footer-count{font-size:12px;color:var(--color-text-tertiary);text-align:right;margin:0}.sa-manager__form{display:flex;flex-direction:column;gap:20px;overflow-y:auto;max-height:70vh;padding-right:2px;scrollbar-width:none;-ms-overflow-style:none}.sa-manager__form::-webkit-scrollbar{display:none}.sa-manager__form-field{display:flex;flex-direction:column;gap:8px}.sa-manager__form-field--center{align-items:center}.sa-manager__form-label{font-size:13px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.4px}.sa-manager__label-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.sa-manager__label-clear-btn{display:inline-flex;align-items:center;gap:4px;background:transparent;border:none;color:var(--color-danger-fg);font-size:12px;font-weight:600;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .15s}.sa-manager__label-clear-btn:hover{background:var(--color-danger-bg)}.sa-manager__form-optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--color-text-tertiary)}.sa-manager__form-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:8px;border-top:1px solid var(--color-border-default);margin-top:4px}.sa-manager__form-actions .ae-modal__submit-btn{display:flex;align-items:center;gap:6px}.sa-manager__color-submit-row{display:flex;align-items:flex-end;gap:16px}.sa-manager__color-picker-wrap{flex:1}.sa-manager__form-submit{height:42px;padding:0 24px;display:flex;align-items:center;justify-content:center;gap:8px}.sa-manager__color-picker{display:flex;flex-wrap:wrap;gap:8px;padding:14px;background:var(--color-bg-secondary);border-radius:8px;border:1px solid var(--color-border-default)}.sa-manager__color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .1s}.sa-manager__color-swatch:hover{transform:scale(1.15)}.sa-manager__color-swatch--active{border-color:var(--color-text-primary);transform:scale(1.15)}.sa-manager__color-custom{width:28px;height:28px;padding:0;border:none;border-radius:50%;overflow:hidden;cursor:pointer}.sa-manager__color-preview{padding:10px;border-radius:8px;text-align:center;font-size:13px;font-weight:600;color:#000000a6}.sa-manager__image-drop{width:120px;height:120px;border:2px dashed var(--color-border-default);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden;background:var(--color-bg-secondary);transition:border-color .15s}.sa-manager__image-drop--large{width:140px;height:140px;border-width:3px}.sa-manager__image-drop:hover{border-color:var(--color-brand-default)}.sa-manager__image-preview{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.sa-manager__delete-overlay{position:absolute;inset:0;background:var(--color-bg-overlay);border-radius:12px;display:flex;align-items:center;justify-content:center;z-index:10;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sa-manager__delete-box{background:var(--color-bg-base);border-radius:12px;padding:32px 28px;max-width:360px;width:100%;margin:16px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:var(--shadow-xl)}.sa-manager__delete-icon-wrap{width:56px;height:56px;border-radius:50%;background:var(--color-danger-bg);display:flex;align-items:center;justify-content:center}.sa-manager__delete-icon{color:var(--color-danger-fg)}.sa-manager__delete-title{font-size:17px;font-weight:700;color:var(--color-text-primary);margin:0}.sa-manager__delete-desc{font-size:14px;color:var(--color-text-secondary);text-align:center;line-height:1.6;margin:0}.sa-manager__delete-actions{display:flex;gap:10px;margin-top:8px}.sa-manager__delete-confirm-btn{padding:8px 20px;border-radius:6px;font-weight:600;font-size:14px;cursor:pointer;background:var(--color-danger-fg);border:none;color:#fff;transition:opacity .15s}.sa-manager__delete-confirm-btn:disabled{opacity:.7;cursor:not-allowed}.sa-manager__delete-confirm-btn:hover:not(:disabled){opacity:.88}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .2s ease-out}.sidebar-panel-text{padding:var(--space-2) var(--space-4);color:var(--color-text-secondary);font-size:var(--text-sm)}.sidebar-panel-search{padding:var(--space-2) var(--space-4)}.sidebar-panel-search input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);border-radius:var(--radius);border:1px solid var(--color-border-default);background:var(--color-bg-tertiary);color:var(--color-text-primary);outline:none;transition:border-color var(--transition-speed-fast) var(--transition-ease)}.sidebar-panel-search input:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 2px var(--color-brand-subtle)}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;padding:var(--space-8);background-color:var(--color-bg-primary);color:var(--color-text-primary)}.auth-card{width:100%;max-width:clamp(340px,28vw,520px);background-color:var(--color-bg-secondary);border-radius:var(--radius-xl);padding:var(--space-8) var(--space-6);box-shadow:var(--shadow-lg);border:1px solid var(--color-border-default);animation:fade-in .25s ease-out}.auth-card__header{display:flex;align-items:center;margin-bottom:var(--space-6)}.auth-card__back-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;padding:var(--space-2);border-radius:var(--radius);transition:background-color var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.auth-card__back-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.auth-card__title-wrap{flex:1;text-align:center;margin-right:clamp(28px,2.5vw,40px)}.auth-card__title{font-size:var(--text-2xl);font-weight:700;margin:0}.auth-card__subtitle{color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-6);font-size:var(--text-sm)}.auth-card__footer{margin-top:var(--space-6);text-align:center}.auth-card__footer-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.auth-card__footer-link{background:transparent;border:none;cursor:pointer;font-size:var(--text-sm);font-weight:600;color:var(--color-brand-default);text-decoration:underline;padding:0;transition:color var(--transition-speed-fast) var(--transition-ease)}.auth-card__footer-link:hover{color:var(--color-brand-hover)}.alert{padding:var(--space-3) var(--space-4);border-radius:var(--radius);font-size:var(--text-sm);margin-bottom:var(--space-4);animation:fade-in .2s ease-out}.alert--error{background-color:var(--color-danger-bg);color:var(--color-danger-fg);border:1px solid var(--color-danger-border)}.alert--success{background-color:var(--color-success-bg);color:var(--color-success-fg);border:1px solid var(--color-success-border)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.input-group{display:flex;flex-direction:column;gap:var(--space-1)}.input-label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary)}.input-wrapper{position:relative}.input-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--color-text-secondary);display:flex;align-items:center;pointer-events:none}.input-field{width:100%;padding:var(--space-3) var(--space-3) var(--space-3) calc(var(--space-3) * 3 + 2px);border-radius:var(--radius);border:1px solid var(--color-border-default);background-color:var(--color-bg-tertiary);color:var(--color-text-primary);font-size:var(--text-base);outline:none;transition:border-color var(--transition-speed-fast) var(--transition-ease),box-shadow var(--transition-speed-fast) var(--transition-ease)}.input-field:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 2px var(--color-brand-subtle)}.input-field:disabled{background-color:var(--color-bg-primary);opacity:.65;cursor:not-allowed}.otp-group{display:flex;flex-direction:column;gap:var(--space-2)}.otp-row{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-2)}.otp-cell{width:clamp(42px,3.5vw,60px);height:clamp(46px,3.8vw,66px);text-align:center;font-size:var(--text-xl);font-weight:700;border-radius:var(--radius);border:1px solid var(--color-border-default);background-color:var(--color-bg-tertiary);color:var(--color-text-primary);outline:none;transition:border-color var(--transition-speed-fast) var(--transition-ease),box-shadow var(--transition-speed-fast) var(--transition-ease)}.otp-cell:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 2px var(--color-brand-subtle)}.btn-primary{margin-top:var(--space-3);display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:var(--space-3) var(--space-4);background-color:var(--color-text-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:opacity var(--transition-speed-fast) var(--transition-ease),transform var(--transition-speed-fast) var(--transition-ease)}.btn-primary:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{cursor:not-allowed;opacity:.65}.terms-row{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;margin-top:var(--space-1)}.terms-icon{transition:color var(--transition-speed-fast) var(--transition-ease);color:var(--color-text-secondary);flex-shrink:0}.terms-icon.checked{color:var(--color-brand-default)}.terms-text{font-size:var(--text-xs);color:var(--color-text-secondary);-webkit-user-select:none;-moz-user-select:none;user-select:none}.page{padding:var(--space-8);color:var(--color-text-primary)}.page__title{font-size:var(--text-2xl);font-weight:700;margin-bottom:var(--space-6)}.page__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6)}.settings-section{margin-bottom:var(--space-8);padding:var(--space-6);background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border-default)}.settings-section__title{font-size:var(--text-base);font-weight:600;margin-bottom:var(--space-4)}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.user-info{display:flex;align-items:center;gap:var(--space-4)}.user-avatar{width:clamp(40px,3.2vw,56px);height:clamp(40px,3.2vw,56px);border-radius:50%;background-color:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.user-name{font-weight:600;font-size:var(--text-base);margin:0}.user-status{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0}.btn-danger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background-color:var(--color-danger-bg);color:var(--color-danger-fg);border:1px solid var(--color-danger-border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:opacity var(--transition-speed-fast) var(--transition-ease);white-space:nowrap}.btn-danger:hover:not(:disabled){opacity:.85}.btn-danger:disabled{cursor:not-allowed;opacity:.65}.btn-ghost-primary{padding:var(--space-2) var(--space-4);background-color:var(--color-text-primary);color:var(--color-bg-primary);border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;cursor:pointer;transition:opacity var(--transition-speed-fast) var(--transition-ease)}.btn-ghost-primary:hover{opacity:.85}.search-input{width:100%;max-width:clamp(320px,36vw,600px);padding:var(--space-2) var(--space-4);font-size:var(--text-base);border-radius:var(--radius);border:1px solid var(--color-border-default);background:var(--color-bg-tertiary);color:var(--color-text-primary);outline:none;transition:border-color var(--transition-speed-fast) var(--transition-ease),box-shadow var(--transition-speed-fast) var(--transition-ease)}.search-input:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 2px var(--color-brand-subtle)}.search-result{margin-top:var(--space-4);color:var(--color-text-secondary);font-size:var(--text-sm)}.devtest-page{padding:var(--space-6);max-width:clamp(540px,50vw,860px)}.devtest-section{margin-bottom:var(--space-6);padding:var(--space-4);border-radius:var(--radius-lg);background:var(--color-bg-secondary);border:1px solid var(--color-border-default)}.devtest-section__title{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:var(--space-3)}.devtest-btn-row{display:flex;flex-wrap:wrap;gap:var(--space-2)}.devtest-btn{padding:var(--space-2) var(--space-4);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:opacity .15s;color:#fff}.devtest-btn:hover{opacity:.85}.devtest-output{margin-top:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);background:var(--color-bg-tertiary);font-size:var(--text-xs);font-family:monospace;color:var(--color-text-primary);word-break:break-all}.devtest-output__log{margin-top:var(--space-2);color:#4f46e5}.devtest-output--ok{color:#16a34a}.avatar-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.rich-editor-wrap{width:100%;height:100%;overflow:hidden;position:relative}.rich-editor{width:100%;height:100%;background:var(--color-bg-base);color:var(--color-text-primary);font-size:14px;line-height:1.8;outline:none;padding:24px;overflow-y:auto;text-align:justify;transition:background var(--transition-speed-fast) var(--transition-ease),border-color var(--transition-speed-fast) var(--transition-ease)}.rich-editor p,.rich-editor>div{margin-bottom:1.5em}.rich-editor p:last-child,.rich-editor>div:last-child{margin-bottom:0}.rich-editor:empty:before{content:attr(data-placeholder);color:var(--color-text-tertiary);pointer-events:none;display:block;font-style:italic}.rich-editor--dragging{border:2px dashed var(--color-brand-default);background:var(--color-bg-secondary)}.rich-editor__word-count{position:absolute;bottom:12px;right:16px;font-size:12px;font-family:var(--font-mono, monospace);color:var(--color-text-tertiary);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:color var(--transition-speed-fast) var(--transition-ease)}.rich-editor__word-count--warn{color:#facc15}.rich-editor__word-count--danger{color:#f87171}.rich-editor__drag-overlay{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--color-bg-base) 55%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.rich-editor__drag-overlay-label{color:var(--color-brand-default);font-weight:700;font-size:15px;background:var(--color-bg-base);padding:12px 28px;border-radius:var(--radius-lg);border:1px solid color-mix(in srgb,var(--color-brand-default) 30%,transparent);box-shadow:var(--shadow-md)}.chap-toolbar{display:flex;flex-direction:column;gap:20px;padding:20px;color:var(--color-text-primary)}.chap-toolbar__section-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:8px}.chap-toolbar__name-input{width:100%;padding:8px 10px;border-radius:var(--radius);border:1px solid var(--color-border-default);background:var(--color-bg-base);color:var(--color-text-primary);font-size:13px;outline:none;transition:border-color var(--transition-speed-fast) var(--transition-ease),box-shadow var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__name-input:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 2px var(--color-brand-subtle)}.chap-toolbar__status-select{width:100%;padding:7px 10px;border-radius:var(--radius);border:1px solid var(--color-border-default);background:var(--color-bg-base);color:var(--color-text-primary);font-size:13px;outline:none;cursor:pointer;transition:border-color var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__status-select:focus{border-color:var(--color-brand-default)}.chap-toolbar__format-row{display:flex;flex-wrap:wrap;gap:6px}.chap-toolbar__fmt-btn{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;border-radius:var(--radius-sm);border:1px solid var(--color-border-default);background:var(--color-bg-secondary);color:var(--color-text-primary);font-size:14px;font-weight:700;cursor:pointer;transition:background var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease),border-color var(--transition-speed-fast) var(--transition-ease);-webkit-user-select:none;-moz-user-select:none;user-select:none}.chap-toolbar__fmt-btn:hover{background:var(--color-bg-tertiary);border-color:var(--color-brand-default);color:var(--color-brand-default)}.chap-toolbar__fmt-btn--active{background:var(--color-brand-default);border-color:var(--color-brand-default);color:var(--color-bg-primary)}.chap-toolbar__divider{height:1px;background:var(--color-border-subtle);margin:0}.chap-toolbar__image-list{display:flex;flex-direction:column;gap:6px}.chap-toolbar__image-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);font-size:12px;color:var(--color-text-secondary)}.chap-toolbar__image-thumb{width:32px;height:32px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;border:1px solid var(--color-border-subtle)}.chap-toolbar__image-name{flex:1;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.chap-toolbar__image-insert-btn{flex-shrink:0;background:none;border:none;padding:2px 4px;cursor:pointer;color:var(--color-brand-default);border-radius:var(--radius-sm);font-size:11px;font-weight:600;transition:opacity var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__image-insert-btn:hover{opacity:.7}.chap-toolbar__image-remove-btn{flex-shrink:0;background:none;border:none;padding:2px 4px;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-sm);transition:color var(--transition-speed-fast) var(--transition-ease);display:flex;align-items:center}.chap-toolbar__image-remove-btn:hover{color:var(--color-error-fg, #f87171)}.chap-toolbar__drop-zone{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 8px;border:1px dashed var(--color-border-default);border-radius:var(--radius);font-size:12px;color:var(--color-text-tertiary);cursor:pointer;transition:border-color var(--transition-speed-fast) var(--transition-ease),background var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__drop-zone:hover{border-color:var(--color-brand-default);background:color-mix(in srgb,var(--color-brand-default) 6%,transparent);color:var(--color-brand-default)}.chap-toolbar__notes-list{display:flex;flex-direction:column;gap:6px}.chap-toolbar__note-item{display:flex;align-items:flex-start;gap:6px}.chap-toolbar__note-input{flex:1;padding:5px 8px;border-radius:var(--radius-sm);border:1px solid var(--color-border-default);background:var(--color-bg-base);color:var(--color-text-primary);font-size:12px;outline:none;resize:none;transition:border-color var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__note-input:focus{border-color:var(--color-brand-default)}.chap-toolbar__note-remove-btn{flex-shrink:0;background:none;border:none;padding:3px;cursor:pointer;color:var(--color-text-tertiary);border-radius:var(--radius-sm);display:flex;align-items:center;margin-top:3px;transition:color var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__note-remove-btn:hover{color:var(--color-error-fg, #f87171)}.chap-toolbar__note-insert-btn{flex-shrink:0;background:none;border:none;padding:3px;cursor:pointer;color:var(--color-brand-default);border-radius:var(--radius-sm);display:flex;align-items:center;margin-top:3px;font-size:11px;font-weight:600;transition:opacity var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__note-insert-btn:hover{opacity:.7}.chap-toolbar__add-note-btn{display:flex;align-items:center;gap:6px;background:none;border:1px dashed var(--color-border-default);border-radius:var(--radius-sm);padding:5px 10px;font-size:12px;color:var(--color-text-tertiary);cursor:pointer;width:100%;justify-content:center;transition:border-color var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__add-note-btn:hover{border-color:var(--color-brand-default);color:var(--color-brand-default)}.chap-toolbar__save-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;background:var(--color-brand-default);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:opacity var(--transition-speed-fast) var(--transition-ease),transform var(--transition-speed-fast) var(--transition-ease)}.chap-toolbar__save-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.chap-toolbar__save-btn:active:not(:disabled){transform:translateY(0)}.chap-toolbar__save-btn:disabled{opacity:.55;cursor:not-allowed}.ts-sidebar{display:flex;flex-direction:column;height:100%;overflow:hidden;padding-top:4px}.ts-sidebar__nav{flex-shrink:0}.ts-nav-link{display:flex;align-items:center;gap:8px;padding:4px 20px;text-decoration:none;font-size:13px;color:var(--color-text-secondary);background:transparent;outline:none;transition:background var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease);-webkit-user-select:none;-moz-user-select:none;user-select:none}.ts-nav-link:hover,.ts-nav-link--active{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.ts-sidebar__divider{flex-shrink:0;height:1px;margin:8px 12px;background:var(--color-border-subtle)}.ts-tree-book{flex-shrink:0;display:flex;align-items:center;gap:6px;padding:2px 20px 6px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);overflow:hidden}.ts-tree-book__icon{flex-shrink:0}.ts-tree-book__name{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1}.ts-tree-book__add-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:1px;margin-left:auto;color:var(--color-text-tertiary);cursor:pointer;border-radius:3px;opacity:0;transition:opacity var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease),background var(--transition-speed-fast) var(--transition-ease)}.ts-tree-book:hover .ts-tree-book__add-btn{opacity:1}.ts-tree-book__add-btn:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.ts-sidebar__tree{flex:1;overflow-y:auto;overflow-x:hidden;padding-bottom:16px}.ts-sidebar__tree::-webkit-scrollbar{width:4px}.ts-sidebar__tree::-webkit-scrollbar-track{background:transparent}.ts-sidebar__tree::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:2px}.ts-tree-state{display:flex;align-items:center;gap:6px;padding:6px 20px;font-size:12px;color:var(--color-text-tertiary);font-style:italic}.ts-tree-state__spin{animation:ts-spin 1s linear infinite}@keyframes ts-spin{to{transform:rotate(360deg)}}.ts-tree-volume{position:relative;transition:opacity .15s ease}.ts-tree-volume--dragging{opacity:.35}.ts-tree-volume--over>.ts-tree-volume__header{border-top:2px solid var(--color-brand-default)}.ts-tree-volume__header{display:flex;align-items:center;gap:4px;width:100%;padding:3px 8px;background:none;border:none;cursor:pointer;color:var(--color-text-primary);font-size:13px;text-align:left;outline:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background var(--transition-speed-fast) var(--transition-ease)}.ts-tree-volume__header:hover{background:var(--color-bg-tertiary)}.ts-tree-drag-handle{flex-shrink:0;color:var(--color-text-tertiary);opacity:0;cursor:grab;transition:opacity var(--transition-speed-fast) var(--transition-ease)}.ts-tree-volume__header:hover .ts-tree-drag-handle{opacity:1}.ts-tree-drag-handle:active{cursor:grabbing}.ts-tree-chevron{flex-shrink:0;color:var(--color-text-tertiary);transition:transform .15s ease}.ts-tree-chevron--open{transform:rotate(90deg)}.ts-tree-volume__icon{flex-shrink:0;color:var(--color-brand-default)}.ts-tree-volume__name{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;flex:1}.ts-tree-volume__delete-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:1px 2px;color:var(--color-text-tertiary);cursor:pointer;border-radius:3px;opacity:0;transition:opacity var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.ts-tree-volume__header:hover .ts-tree-volume__delete-btn{opacity:1}.ts-tree-volume__delete-btn:hover{color:var(--color-error-fg, #f87171)}.ts-tree-volume__add-chapter-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:1px 2px;color:var(--color-text-tertiary);cursor:pointer;border-radius:3px;opacity:0;transition:opacity var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.ts-tree-volume__header:hover .ts-tree-volume__add-chapter-btn{opacity:1}.ts-tree-volume__add-chapter-btn:hover{color:var(--color-brand-default)}.ts-tree-chapters{display:flex;flex-direction:column}.ts-tree-chapter{display:flex;align-items:center;gap:4px;padding:2px 8px 2px 20px;font-size:12px;color:var(--color-text-secondary);cursor:default;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.ts-tree-chapter:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.ts-tree-chapter__guide{flex-shrink:0;display:inline-block;width:1px;align-self:stretch;background:var(--color-border-subtle);margin-right:8px;border-radius:1px}.ts-tree-chapter__icon{flex-shrink:0;color:var(--color-text-tertiary)}.ts-tree-chapter__name{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.ts-tree-chapter--empty{font-style:italic;opacity:.6}.ts-tree-chapter__edit-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:1px 2px;margin-left:auto;color:var(--color-text-tertiary);cursor:pointer;border-radius:3px;opacity:0;transition:opacity var(--transition-speed-fast) var(--transition-ease),color var(--transition-speed-fast) var(--transition-ease)}.ts-tree-chapter:hover .ts-tree-chapter__edit-btn{opacity:1}.ts-tree-chapter__edit-btn:hover{color:var(--color-brand-default)}.ts-tree-chapter--dragging{opacity:.35}.ts-tree-chapter--over{border-top:2px solid var(--color-brand-default)}.ts-tree-drag-handle--chap{opacity:0;cursor:grab;transition:opacity var(--transition-speed-fast) var(--transition-ease)}.ts-tree-chapter:hover .ts-tree-drag-handle--chap{opacity:1}.ts-tree-drag-handle--chap:active{cursor:grabbing}.ts-tree-volume-new{display:flex;align-items:center;padding:2px 8px}.ts-tree-volume-new__input{flex:1;background:var(--color-bg-secondary);border:1px solid var(--color-brand-default);border-radius:3px;color:var(--color-text-primary);font-size:13px;padding:2px 6px;outline:none}.ts-tree-volume__rename-input{flex:1;min-width:0;background:var(--color-bg-secondary);border:1px solid var(--color-brand-default);border-radius:3px;color:var(--color-text-primary);font-size:13px;padding:0 4px;outline:none}.ts-tree-trash{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;margin:8px 12px 12px;border:1px dashed var(--color-border-default);border-radius:6px;color:var(--color-text-tertiary);font-size:13px;transition:all var(--transition-speed-fast) var(--transition-ease)}.ts-tree-trash--over{border-color:var(--color-error-fg, #f87171);color:var(--color-error-fg, #f87171);background:color-mix(in srgb,var(--color-error-fg, #f87171) 10%,transparent)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}@media(min-width:1920px){.container{max-width:1920px}}@media(min-width:2560px){.container{max-width:2560px}}.\!visible{visibility:visible!important}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-0{bottom:0}.top-0{top:0}.z-10{z-index:10}.m-0{margin:0}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.hidden{display:none}.aspect-\[2\/3\]{aspect-ratio:2/3}.h-12{height:3rem}.h-14{height:3.5rem}.h-28{height:7rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[350px\]{height:350px}.h-full{height:100%}.min-h-\[120px\]{min-height:120px}.min-h-\[60px\]{min-height:60px}.w-10{width:2.5rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-20{width:5rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[120px\]{width:120px}.w-\[140px\]{width:140px}.w-\[180px\]{width:180px}.w-\[80px\]{width:80px}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[120px\]{min-width:120px}.min-w-\[200px\]{min-width:200px}.max-w-4xl{max-width:56rem}.max-w-\[140px\]{max-width:140px}.max-w-\[720px\]{max-width:720px}.max-w-none{max-width:none}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}0%{transform:rotate(0)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-none{resize:none}.resize-y{resize:vertical}.resize{resize:both}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-border-default>:not([hidden])~:not([hidden]){border-color:var(--color-border-default)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-\[14px\]{border-radius:14px}.rounded-\[20px\]{border-radius:20px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-sm{border-radius:.125rem}.rounded-r-md{border-top-right-radius:.375rem;border-bottom-right-radius:.375rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-2{border-left-width:2px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-blue-500\/25{border-color:#3b82f640}.border-border-default{border-color:var(--color-border-default)}.border-border-subtle{border-color:var(--color-border-subtle)}.border-brand{border-color:var(--color-brand-default)}.border-danger-border{border-color:var(--color-danger-border)}.border-green-500\/25{border-color:#22c55e40}.border-orange-200{--tw-border-opacity: 1;border-color:rgb(254 215 170 / var(--tw-border-opacity, 1))}.border-red-500\/25{border-color:#ef444440}.border-success-border{border-color:var(--color-success-border)}.border-transparent{border-color:transparent}.border-yellow-500\/25{border-color:#eab30840}.border-t-transparent{border-top-color:transparent}.bg-bg-base{background-color:var(--color-bg-base)}.bg-bg-secondary{background-color:var(--color-bg-secondary)}.bg-bg-tertiary{background-color:var(--color-bg-tertiary)}.bg-black\/50{background-color:#00000080}.bg-blue-500\/10{background-color:#3b82f61a}.bg-blue-500\/15{background-color:#3b82f626}.bg-border-default{background-color:var(--color-border-default)}.bg-brand{background-color:var(--color-brand-default)}.bg-danger-bg{background-color:var(--color-danger-bg)}.bg-gray-500\/10{background-color:#6b72801a}.bg-green-500\/10{background-color:#22c55e1a}.bg-green-500\/15{background-color:#22c55e26}.bg-orange-50{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity, 1))}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/15{background-color:#ef444426}.bg-success-bg{background-color:var(--color-success-bg)}.bg-transparent{background-color:transparent}.bg-yellow-500\/10{background-color:#eab3081a}.bg-yellow-500\/15{background-color:#eab30826}.object-cover{-o-object-fit:cover;object-fit:cover}.\!p-6{padding:1.5rem!important}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.\!py-6{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-4{padding-bottom:1rem}.pl-3{padding-left:.75rem}.pl-5{padding-left:1.25rem}.pr-1{padding-right:.25rem}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[12px\]{font-size:12px}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[15px\]{font-size:15px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wider{letter-spacing:.05em}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.text-brand{color:var(--color-brand-default)}.text-brand-text{color:var(--color-brand-text)}.text-danger-fg{color:var(--color-danger-fg)}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-green-500{--tw-text-opacity: 1;color:rgb(34 197 94 / var(--tw-text-opacity, 1))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-success-fg{color:var(--color-success-fg)}.text-text-disabled{color:var(--color-text-disabled)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.text-text-tertiary{color:var(--color-text-tertiary)}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}.opacity-0{opacity:0}.opacity-40{opacity:.4}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow-\[0_4px_12px_rgba\(0\,0\,0\,0\.05\)\]{--tw-shadow: 0 4px 12px rgba(0,0,0,.05);--tw-shadow-colored: 0 4px 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.\[appearance\:textfield\]{-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;background-color:var(--color-bg-base);color:var(--color-text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-speed-normal) var(--transition-ease),color var(--transition-speed-normal) var(--transition-ease)}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);line-height:1.25;font-weight:600}p{color:var(--color-text-secondary)}a{color:var(--color-brand-default);text-decoration:none;transition:color var(--transition-speed-fast) var(--transition-ease)}a:hover{color:var(--color-brand-hover)}hr{border:none;border-top:1px solid var(--color-border-subtle)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-scrollbar-track)}::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}:focus-visible{outline:2px solid var(--color-brand-default);outline-offset:2px;border-radius:3px}::-moz-selection{background-color:var(--color-brand-subtle);color:var(--color-brand-default)}::selection{background-color:var(--color-brand-subtle);color:var(--color-brand-default)}img,video{max-width:100%;display:block}.hover\:border-transparent:hover{border-color:transparent}.hover\:bg-bg-secondary:hover{background-color:var(--color-bg-secondary)}.hover\:bg-bg-tertiary:hover{background-color:var(--color-bg-tertiary)}.hover\:bg-brand-hover:hover{background-color:var(--color-brand-hover)}.hover\:bg-danger-border:hover{background-color:var(--color-danger-border)}.hover\:bg-red-400\/10:hover{background-color:#f871711a}.hover\:bg-red-500\/10:hover{background-color:#ef44441a}.hover\:bg-success-border:hover{background-color:var(--color-success-border)}.hover\:text-brand:hover{color:var(--color-brand-default)}.hover\:text-red-400:hover{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.hover\:text-red-500:hover{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.hover\:text-text-primary:hover{color:var(--color-text-primary)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.focus\:border-brand:focus{border-color:var(--color-brand-default)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}@media(prefers-color-scheme:dark){.dark\:border-orange-900{--tw-border-opacity: 1;border-color:rgb(124 45 18 / var(--tw-border-opacity, 1))}.dark\:bg-orange-950\/30{background-color:#4314074d}.dark\:text-orange-300{--tw-text-opacity: 1;color:rgb(253 186 116 / var(--tw-text-opacity, 1))}}.\[\&\:\:-webkit-inner-spin-button\]\:appearance-none::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none}.\[\&\:\:-webkit-outer-spin-button\]\:appearance-none::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none}.\[\&\>td\:first-child\]\:border-l-\[3px\]>td:first-child{border-left-width:3px}.\[\&\>td\:first-child\]\:border-l-brand>td:first-child{border-left-color:var(--color-brand-default)}.\[\&\>td\:first-child\]\:border-l-transparent>td:first-child{border-left-color:transparent}.dash-page{color:var(--color-text-primary);padding:28px 32px 48px;min-height:100%;display:flex;flex-direction:column;gap:32px;max-width:1400px;margin:0 auto}.dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.dash-header__title{font-size:1.65rem;font-weight:700;color:var(--color-text-primary);letter-spacing:-.02em;margin:0;background:linear-gradient(135deg,var(--color-brand-default) 0%,var(--color-accent-default) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.dash-header__subtitle{font-size:.8rem;color:var(--color-text-secondary);margin:6px 0 0;font-weight:400;font-family:monospace;letter-spacing:.02em}.dash-header__right{display:flex;align-items:center;gap:12px;flex-shrink:0}.dash-last-updated{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--color-text-tertiary);font-family:monospace;white-space:nowrap}.dash-refresh-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;background:var(--color-info-bg);border:1px solid var(--color-info-border);border-radius:8px;color:var(--color-info-fg);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.dash-refresh-btn:hover:not(:disabled){background:var(--color-info-bg);border-color:var(--color-info-fg);color:var(--color-info-fg);box-shadow:0 0 12px var(--color-info-bg)}.dash-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.dash-refresh-btn--spinning svg{animation:dash-spin .8s linear infinite}@keyframes dash-spin{to{transform:rotate(360deg)}}.dash-error-banner{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:10px;color:var(--color-danger-fg);font-size:.88rem;animation:dash-fadeIn .3s ease}.dash-error-retry{margin-left:auto;padding:4px 12px;background:var(--color-danger-bg);border:1px solid var(--color-danger-border);border-radius:6px;color:var(--color-danger-fg);font-size:.78rem;cursor:pointer;transition:all .2s}.dash-error-retry:hover{background:var(--color-danger-border)}.dash-section{display:flex;flex-direction:column;gap:14px;animation:dash-fadeUp .45s ease both}.dash-section__label{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.dash-section__dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.dash-section__dot--blue{background:var(--color-info-fg);box-shadow:0 0 6px var(--color-info-fg)}.dash-section__dot--amber{background:var(--color-warning-fg);box-shadow:0 0 6px var(--color-warning-fg)}.dash-section__dot--red{background:var(--color-danger-fg);box-shadow:0 0 6px var(--color-danger-fg)}.dash-grid{display:grid;gap:14px}.dash-grid--3{grid-template-columns:repeat(3,1fr)}.dash-stat-card{position:relative;display:flex;align-items:center;gap:16px;padding:20px;border-radius:14px;border:1px solid var(--color-border-subtle);background:var(--color-bg-tertiary);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:default;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;animation:dash-fadeUp .45s ease both;overflow:hidden}.dash-stat-card:before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .22s;border-radius:inherit;pointer-events:none}.dash-stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px #00000040}.dash-stat-card--blue:hover{border-color:var(--color-info-border);box-shadow:var(--shadow-sm)}.dash-stat-card--indigo:hover{border-color:var(--color-brand-default);box-shadow:var(--shadow-sm)}.dash-stat-card--violet:hover{border-color:var(--color-accent-default);box-shadow:var(--shadow-sm)}.dash-stat-card--cyan:hover{border-color:var(--color-success-border);box-shadow:var(--shadow-sm)}.dash-stat-card__icon-wrap{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;flex-shrink:0;transition:transform .22s ease}.dash-stat-card:hover .dash-stat-card__icon-wrap{transform:scale(1.08)}.dash-stat-card--blue .dash-stat-card__icon-wrap{background:var(--color-info-bg);color:var(--color-info-fg)}.dash-stat-card--indigo .dash-stat-card__icon-wrap{background:var(--color-brand-subtle);color:var(--color-brand-default)}.dash-stat-card--violet .dash-stat-card__icon-wrap{background:var(--color-accent-subtle);color:var(--color-accent-default)}.dash-stat-card--cyan .dash-stat-card__icon-wrap{background:var(--color-success-bg);color:var(--color-success-fg)}.dash-stat-card__body{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.dash-stat-card__label{font-size:.76rem;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-stat-card__value{font-size:1.55rem;font-weight:700;font-family:monospace;letter-spacing:-.02em;line-height:1.1;color:var(--color-text-primary)}.dash-stat-card--blue .dash-stat-card__value{color:var(--color-info-fg)}.dash-stat-card--indigo .dash-stat-card__value{color:var(--color-brand-default)}.dash-stat-card--violet .dash-stat-card__value{color:var(--color-accent-default)}.dash-stat-card--cyan .dash-stat-card__value{color:var(--color-success-fg)}.dash-stat-card__trend{position:absolute;top:14px;right:14px;opacity:.5}.dash-stat-card__trend--up{color:var(--color-success-fg)}.dash-stat-card__trend--down{color:var(--color-danger-fg);transform:rotate(180deg)}.dash-views-row{display:grid;grid-template-columns:1fr 1.5fr;gap:14px}.dash-views-card{display:flex;align-items:center;gap:20px;padding:24px;background:var(--color-bg-tertiary);border:1px solid var(--color-warning-border);border-radius:14px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .22s,box-shadow .22s}.dash-views-card:hover{border-color:var(--color-warning-fg);box-shadow:var(--shadow-md)}.dash-views-card__ring{flex-shrink:0}.dash-views-card__title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);margin:0 0 6px}.dash-views-card__num{font-size:2rem;font-weight:700;font-family:monospace;color:var(--color-warning-fg);margin:0 0 8px;letter-spacing:-.02em;line-height:1}.dash-views-card__sub{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--color-text-secondary);margin:0}.dash-views-card__sub strong{color:var(--color-text-primary)}.dash-today-grid{display:flex;flex-direction:column;gap:10px}.dash-today-grid__heading{display:flex;align-items:center;gap:6px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin:0 0 2px}.dash-highlight-card{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:default;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease;animation:dash-fadeUp .4s ease both}.dash-highlight-card:hover{transform:translate(4px);border-color:color-mix(in srgb,var(--hl-color) 30%,transparent);box-shadow:0 4px 20px color-mix(in srgb,var(--hl-color) 10%,transparent)}.dash-highlight-card__icon-ring{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:color-mix(in srgb,var(--hl-color) 12%,transparent);color:var(--hl-color);flex-shrink:0;transition:transform .2s}.dash-highlight-card:hover .dash-highlight-card__icon-ring{transform:scale(1.1)}.dash-highlight-card__label{font-size:.75rem;color:var(--color-text-secondary);font-weight:500;margin:0 0 3px}.dash-highlight-card__value{font-size:1.3rem;font-weight:700;font-family:monospace;color:var(--hl-color);margin:0;letter-spacing:-.01em}.dash-alert-row{display:flex;flex-direction:column;gap:10px}.dash-alert-card{display:flex;align-items:center;gap:14px;padding:16px 20px;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .25s ease;position:relative}.dash-alert-card--active{background:var(--color-danger-bg);border-color:var(--color-danger-border);animation:dash-pulse-border 2.5s ease-in-out infinite}@keyframes dash-pulse-border{0%,to{border-color:var(--color-danger-border)}50%{border-color:var(--color-danger-fg)}}.dash-alert-card__icon{color:var(--color-text-disabled);flex-shrink:0}.dash-alert-card--active .dash-alert-card__icon{color:var(--color-danger-fg)}.dash-alert-card__title{font-size:.88rem;font-weight:600;color:var(--color-text-primary);margin:0 0 3px}.dash-alert-card__desc{font-size:.8rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.dash-alert-card--active .dash-alert-card__desc{color:var(--color-text-primary)}.dash-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 7px;border-radius:99px;font-size:.72rem;font-weight:700;font-family:monospace;margin-left:auto;flex-shrink:0}.dash-badge--red{background:var(--color-danger-bg);color:var(--color-danger-fg);border:1px solid var(--color-danger-border)}.dash-ring{display:block;flex-shrink:0}.dash-skeleton{display:inline-block;width:80px;height:1.4em;border-radius:6px;background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1a,#ffffff0f 75%);background-size:200% 100%;animation:dash-shimmer 1.4s infinite;vertical-align:middle}.dash-skeleton--sm{width:50px;height:1.1em}.dash-skeleton--lg{width:100px;height:1.6em}@keyframes dash-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes dash-fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes dash-fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1100px){.dash-grid--3{grid-template-columns:repeat(2,1fr)}.dash-views-row{grid-template-columns:1fr}}@media(max-width:768px){.dash-page{padding:16px 16px 36px}.dash-grid--3{grid-template-columns:1fr}.dash-header{flex-direction:column}.dash-views-card{flex-direction:column;text-align:center}}@media(max-width:480px){.dash-header__title{font-size:1.3rem}.dash-stat-card__value{font-size:1.25rem}}@media(prefers-reduced-motion:reduce){.dash-stat-card,.dash-highlight-card,.dash-section{animation:none}.dash-skeleton{animation:none;background:#ffffff12}.dash-refresh-btn--spinning svg{animation:none}}.user-table__row{cursor:pointer;transition:background-color .15s ease}.user-table__row:hover{background-color:var(--color-bg-secondary)}.user-table__row--selected{background-color:color-mix(in srgb,var(--color-brand-default) 10%,transparent)!important;border-left:3px solid var(--color-brand-default)!important}.user-table__row--selected td:first-child{padding-left:calc(.75rem - 3px)}.book-table__checkbox{width:15px;height:15px;accent-color:var(--color-brand-default);cursor:pointer}.book-table__row{cursor:pointer;transition:background-color .15s ease}.book-table__row:hover{background-color:var(--color-bg-secondary)}.book-table__row--selected{background-color:color-mix(in srgb,var(--color-brand-default) 10%,transparent)!important;border-left:3px solid var(--color-brand-default)!important}.book-table__row--selected td:first-child{padding-left:calc(.75rem - 3px)}.book-table__cover{width:36px;height:50px;-o-object-fit:cover;object-fit:cover;border-radius:4px;border:1px solid var(--color-border-subtle);display:block}.book-table__cover-fallback{width:36px;height:50px;border-radius:4px;border:1px solid var(--color-border-subtle);background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.book-batch-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 18px;background:color-mix(in srgb,var(--color-brand-default) 8%,var(--color-bg-tertiary));border:1px solid color-mix(in srgb,var(--color-brand-default) 30%,transparent);border-radius:10px;animation:dash-fadeIn .2s ease;flex-wrap:wrap}.book-batch-bar__info{display:flex;align-items:center;gap:8px;font-size:.83rem;color:var(--color-text-secondary)}.book-batch-bar__info strong{color:var(--color-brand-default);font-family:monospace}.book-batch-bar__actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.book-batch-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:7px;font-size:.78rem;font-weight:600;border:1px solid transparent;cursor:pointer;transition:all .18s ease;white-space:nowrap}.book-batch-btn--success{background:var(--color-success-bg);color:var(--color-success-fg);border-color:var(--color-success-border)}.book-batch-btn--success:hover{background:var(--color-success-border);color:var(--color-success-fg)}.book-batch-btn--warning{background:var(--color-warning-bg);color:var(--color-warning-fg);border-color:var(--color-warning-border)}.book-batch-btn--warning:hover{background:var(--color-warning-border)}.book-batch-btn--info{background:var(--color-info-bg);color:var(--color-info-fg);border-color:var(--color-info-border)}.book-batch-btn--info:hover{background:var(--color-info-border)}.book-batch-btn--brand{background:var(--color-brand-subtle);color:var(--color-brand-default);border-color:color-mix(in srgb,var(--color-brand-default) 40%,transparent)}.book-batch-btn--brand:hover{background:color-mix(in srgb,var(--color-brand-default) 20%,transparent)}.book-batch-btn--ghost{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border-default)}.book-batch-btn--ghost:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.user-detail{display:flex;flex-direction:column;align-items:center;gap:0;padding:8px 4px;animation:dash-fadeIn .25s ease;overflow-y:auto;flex:1}.user-detail__loading,.user-detail__error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 16px;color:var(--color-text-secondary);font-size:.82rem;text-align:center}.user-detail__avatar-wrap{margin-bottom:14px}.user-detail__avatar-img{width:72px;height:72px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid var(--color-border-default)}.user-detail__avatar-fallback{width:72px;height:72px;border-radius:50%;background:var(--color-bg-secondary);border:2px solid var(--color-border-default);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.user-detail__identity{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:18px;text-align:center}.user-detail__name{font-size:1rem;font-weight:700;color:var(--color-text-primary);margin:0;line-height:1.3}.user-detail__status-badge{font-size:.72rem;font-weight:600;padding:2px 10px;border-radius:99px;text-transform:capitalize;letter-spacing:.04em}.user-detail__info-block{width:100%;display:flex;flex-direction:column;gap:6px;margin-bottom:4px}.user-detail__info-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--color-bg-secondary);border-radius:8px;font-size:.8rem;overflow:hidden}.user-detail__info-icon{color:var(--color-text-tertiary);flex-shrink:0}.user-detail__info-label{color:var(--color-text-secondary);font-weight:500;flex-shrink:0;min-width:36px}.user-detail__info-value{color:var(--color-text-primary);margin-left:auto;font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;text-align:right}.user-detail__divider{width:100%;height:1px;background:var(--color-border-subtle);margin:14px 0 10px}.user-detail__stats-heading{width:100%;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin:0 0 8px}.user-detail__stats-list{width:100%;display:flex;flex-direction:column;gap:6px}.user-detail__stat-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--color-bg-secondary);border-radius:8px;border-left:3px solid var(--stat-color, var(--color-border-default));font-size:.8rem;transition:background-color .15s}.user-detail__stat-row:hover{background:color-mix(in srgb,var(--stat-color, transparent) 8%,var(--color-bg-secondary))}.user-detail__stat-icon{color:var(--stat-color);flex-shrink:0}.user-detail__stat-label{color:var(--color-text-secondary);flex:1}.user-detail__stat-value{font-weight:700;font-family:monospace;color:var(--stat-color);font-size:.88rem}.notif-layout{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}@media(max-width:1024px){.notif-layout{grid-template-columns:1fr}}.notif-form-col,.notif-preview-col{display:flex;flex-direction:column;gap:16px}.notif-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:10px;animation:dash-fadeUp .35s ease both}.notif-card--preview{background:color-mix(in srgb,var(--color-brand-default) 4%,var(--color-bg-tertiary));border-color:color-mix(in srgb,var(--color-brand-default) 20%,transparent)}.notif-card__label{display:flex;align-items:center;gap:6px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin-bottom:2px}.notif-field-label{font-size:.78rem;font-weight:600;color:var(--color-text-secondary)}.notif-required{color:var(--color-danger-fg)}.notif-tabs{display:flex;gap:6px;flex-wrap:wrap}.notif-tab{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:8px;font-size:.76rem;font-weight:600;border:1px solid var(--color-border-default);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .18s ease}.notif-tab:hover{background:var(--color-bg-secondary);color:var(--color-text-primary)}.notif-tab--active{background:var(--color-brand-subtle);border-color:color-mix(in srgb,var(--color-brand-default) 50%,transparent);color:var(--color-brand-default)}.notif-input{width:100%;padding:9px 13px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:9px;color:var(--color-text-primary);font-size:.84rem;outline:none;transition:border-color .18s;box-sizing:border-box}.notif-input:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-brand-default) 15%,transparent)}.notif-input--id{width:140px;flex-shrink:0}.notif-textarea{width:100%;padding:10px 13px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:9px;color:var(--color-text-primary);font-size:.84rem;outline:none;resize:vertical;transition:border-color .18s;box-sizing:border-box;font-family:inherit;line-height:1.55}.notif-textarea:focus{border-color:var(--color-brand-default);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-brand-default) 15%,transparent)}.notif-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.notif-select-wrap{position:relative;flex:1;min-width:140px}.notif-select{width:100%;padding:9px 32px 9px 13px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:9px;color:var(--color-text-primary);font-size:.84rem;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;transition:border-color .18s}.notif-select:focus{border-color:var(--color-brand-default)}.notif-select-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.notif-img-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:24px;border:2px dashed var(--color-border-default);border-radius:12px;background:var(--color-bg-secondary);color:var(--color-text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s ease;text-align:center}.notif-img-dropzone:hover{border-color:var(--color-brand-default);background:color-mix(in srgb,var(--color-brand-default) 5%,var(--color-bg-secondary));color:var(--color-text-primary)}.notif-img-dropzone__icon{color:var(--color-text-tertiary)}.notif-img-dropzone__hint{font-size:.72rem;color:var(--color-text-tertiary)}.notif-img-preview{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--color-border-subtle)}.notif-img-preview__img{width:100%;max-height:200px;-o-object-fit:cover;object-fit:cover;display:block}.notif-img-preview__remove{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;background:#000000a6;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}.notif-img-preview__remove:hover{background:#000000d9}.notif-bubble{background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:14px;overflow:hidden;animation:dash-fadeIn .3s ease}.notif-bubble__header{display:flex;align-items:center;gap:6px;padding:10px 14px 8px;border-bottom:1px solid var(--color-border-subtle)}.notif-bubble__bell{color:var(--color-brand-default);flex-shrink:0}.notif-bubble__app{font-size:.72rem;font-weight:700;color:var(--color-text-primary);flex:1}.notif-bubble__time{font-size:.68rem;color:var(--color-text-tertiary)}.notif-bubble__banner{width:100%;max-height:140px;-o-object-fit:cover;object-fit:cover;display:block}.notif-bubble__body{padding:10px 14px 14px}.notif-bubble__title{font-size:.84rem;font-weight:700;color:var(--color-text-primary);margin-bottom:3px}.notif-bubble__subtitle{font-size:.76rem;color:var(--color-text-secondary);margin-bottom:4px}.notif-bubble__text{font-size:.78rem;color:var(--color-text-secondary);line-height:1.5}.notif-bubble__placeholder{opacity:.45;font-style:italic}.notif-send-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 24px;border-radius:12px;background:linear-gradient(135deg,var(--color-brand-default) 0%,var(--color-accent-default) 100%);color:#fff;font-size:.9rem;font-weight:700;border:none;cursor:pointer;transition:opacity .2s,transform .2s,box-shadow .2s;letter-spacing:.01em;box-shadow:0 4px 20px color-mix(in srgb,var(--color-brand-default) 35%,transparent)}.notif-send-btn:hover:not(:disabled){opacity:.92;transform:translateY(-2px);box-shadow:0 8px 28px color-mix(in srgb,var(--color-brand-default) 45%,transparent)}.notif-send-btn:active:not(:disabled){transform:translateY(0)}.notif-send-btn:disabled{opacity:.55;cursor:not-allowed}.notif-spin{animation:dash-spin .8s linear infinite}.notif-tag-input{display:flex;flex-wrap:wrap;gap:6px;align-items:center;min-height:42px;padding:6px 10px;background:var(--color-bg-secondary);border:1px solid var(--color-border-default);border-radius:9px;cursor:text;transition:border-color .18s}.notif-tag-input:focus-within{border-color:var(--color-brand-default);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-brand-default) 15%,transparent)}.notif-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px 2px 9px;border-radius:6px;background:var(--color-brand-subtle);border:1px solid color-mix(in srgb,var(--color-brand-default) 35%,transparent);color:var(--color-brand-default);font-size:.76rem;font-weight:600;white-space:nowrap;max-width:200px}.notif-tag__text{overflow:hidden;text-overflow:ellipsis}.notif-tag__remove{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:3px;background:transparent;border:none;color:var(--color-brand-default);cursor:pointer;padding:0;opacity:.7;flex-shrink:0;transition:opacity .15s,background .15s}.notif-tag__remove:hover{opacity:1;background:color-mix(in srgb,var(--color-brand-default) 20%,transparent)}.notif-tag-input__field{flex:1;min-width:120px;border:none;outline:none;background:transparent;color:var(--color-text-primary);font-size:.84rem;padding:2px;font-family:inherit}.notif-tag-input__field::-moz-placeholder{color:var(--color-text-tertiary)}.notif-tag-input__field::placeholder{color:var(--color-text-tertiary)}
