:root{--color-primary: #5b7cfa;--color-primary-hover: #4a6bf0;--color-primary-light: #eef2ff;--color-primary-ghost: rgba(91, 124, 250, .12);--color-success: #22c55e;--color-success-light: #dcfce7;--color-error: #ef4444;--color-error-light: #fef2f2;--color-warning: #f59e0b;--color-warning-light: #fffbeb;--bg: #f6f7f9;--surface: #ffffff;--surface-raised: #ffffff;--surface-overlay: rgba(0, 0, 0, .25);--surface-hover: rgba(0, 0, 0, .03);--text: #1a1d23;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-on-primary: #ffffff;--text-success: #16a34a;--text-error: #dc2626;--border: #e5e7eb;--border-strong: #d1d5db;--border-focus: rgba(91, 124, 250, .5);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 28px rgba(15, 23, 42, .08);--shadow-xl: 0 20px 50px rgba(15, 23, 42, .12);--shadow-glow: 0 0 24px rgba(91, 124, 250, .12);--shadow-card-hover: 0 8px 30px rgba(91, 124, 250, .08), 0 2px 8px rgba(0, 0, 0, .04);--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .875rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.75rem;--leading-tight: 1.3;--leading-normal: 1.5;--leading-relaxed: 1.65;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-extrabold: 800;--weight-black: 900;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 999px;--transition-fast: .12s ease;--transition-base: .18s ease;--transition-slow: .3s ease;--gradient-brand: linear-gradient(135deg, #5b7cfa, #7c3aed);--gradient-primary: linear-gradient(135deg, #5b7cfa 0%, #6d5bfa 50%, #7c3aed 100%);--gradient-primary-hover: linear-gradient(135deg, #4a6bf0 0%, #5c4be0 50%, #6d28d9 100%);--gradient-accent-line: linear-gradient(90deg, #5b7cfa, #7c3aed, #ec4899);--z-dropdown: 100;--z-modal: 2000;--z-toast: 3000;--card-header-bg: linear-gradient(180deg, #141928, #1a1f30);--card-header-border: #2d3348;--card-header-text: #f3f4f6;--stat-bar-bg: #e5e7eb;--stat-bar-fill: linear-gradient(90deg, #22c55e, #5b7cfa);--badge-bg: rgba(96, 165, 250, .12);--badge-border: rgba(96, 165, 250, .35);--badge-text: #93c5fd}[data-theme=dark]{--bg: #0c0e14;--surface: #151821;--surface-raised: #1c2030;--surface-overlay: rgba(0, 0, 0, .5);--surface-hover: rgba(255, 255, 255, .05);--text: #f0f1f3;--text-secondary: #9ca3af;--text-tertiary: #6b7280;--text-on-primary: #ffffff;--text-success: #34d399;--text-error: #f87171;--border: #2d3348;--border-strong: #3d445c;--border-focus: rgba(107, 138, 255, .5);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 10px 28px rgba(0, 0, 0, .35);--shadow-xl: 0 20px 50px rgba(0, 0, 0, .45);--shadow-glow: 0 0 24px rgba(107, 138, 255, .15);--shadow-card-hover: 0 8px 30px rgba(107, 138, 255, .12), 0 2px 8px rgba(0, 0, 0, .2);--color-primary: #6b8aff;--color-primary-hover: #5a7af5;--color-primary-light: rgba(107, 138, 255, .15);--color-primary-ghost: rgba(107, 138, 255, .08);--color-success-light: rgba(34, 197, 94, .15);--color-error-light: rgba(239, 68, 68, .15);--color-warning-light: rgba(245, 158, 11, .15);--card-header-bg: linear-gradient(180deg, rgba(15, 23, 42, .92), rgba(15, 23, 42, .6));--card-header-border: rgba(36, 48, 70, .85);--stat-bar-bg: rgba(36, 48, 70, .55);--stat-bar-fill: linear-gradient(90deg, rgba(34, 197, 94, .85), rgba(96, 165, 250, .85));--badge-bg: rgba(96, 165, 250, .12);--badge-border: rgba(96, 165, 250, .35);--badge-text: #cfe6ff}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;-webkit-text-size-adjust:100%}body{height:100%;font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-slow),color var(--transition-slow)}#root{min-height:100%}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}ul,ol{list-style:none}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary);background-clip:padding-box}::selection{background:var(--color-primary);color:#fff}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn var(--transition-base) ease both}.animate-fade-in-up{animation:fadeInUp .35s ease both}.animate-slide-up{animation:slideUp .4s cubic-bezier(.16,1,.3,1) both}.cn-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-sans);font-weight:var(--weight-semibold);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1px solid transparent;white-space:nowrap;line-height:1}.cn-btn:hover{transform:translateY(-1px)}.cn-btn:active{transform:translateY(0)}.cn-btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.cn-btn--sm{padding:6px 12px;font-size:var(--text-xs);border-radius:var(--radius-sm)}.cn-btn--md{padding:10px 18px;font-size:var(--text-base)}.cn-btn--lg{padding:14px 28px;font-size:var(--text-md);border-radius:var(--radius-lg)}.cn-btn--primary{background:var(--gradient-primary);color:var(--text-on-primary);border-color:transparent;box-shadow:var(--shadow-sm),0 2px 8px #5b7cfa33}.cn-btn--primary:hover{background:var(--gradient-primary-hover);box-shadow:0 8px 24px #5b7cfa4d,0 2px 4px #0000000f}.cn-btn--secondary{background:var(--surface);color:var(--text);border-color:var(--border-strong)}.cn-btn--secondary:hover{background:var(--bg);border-color:var(--color-primary);color:var(--color-primary)}.cn-btn--ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.cn-btn--ghost:hover{background:var(--color-primary-ghost);color:var(--color-primary)}.cn-btn--danger{background:var(--surface);color:var(--text-error);border-color:var(--border-strong)}.cn-btn--danger:hover{border-color:var(--color-error);background:var(--color-error-light)}.cn-btn--loading{opacity:.75;cursor:wait}.cn-btn__spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.cn-card{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden;transition:box-shadow var(--transition-slow),transform var(--transition-slow)}.cn-card__header{padding:16px 20px 14px;background:var(--card-header-bg);border-bottom:1px solid var(--card-header-border);display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative}.cn-card__header:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent-line);border-radius:2px 2px 0 0}.cn-card__title{margin:0;font-size:var(--text-base);font-weight:var(--weight-extrabold);color:var(--card-header-text);letter-spacing:.3px;text-transform:uppercase}.cn-card__header-right{display:flex;align-items:center;gap:8px}.cn-card__content{padding:20px}.cn-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:var(--radius-full);border:1px solid var(--badge-border);background:var(--badge-bg);color:var(--badge-text);font-size:var(--text-xs);font-weight:var(--weight-bold);letter-spacing:.2px;white-space:nowrap}.cn-badge--success{border-color:#22c55e66;background:#22c55e1f;color:var(--text-success)}.cn-badge--error{border-color:#ef444466;background:#ef44441f;color:var(--text-error)}.cn-pill{display:inline-flex;gap:6px;align-items:center;padding:8px 12px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-raised);font-size:var(--text-xs);color:var(--text-secondary);font-weight:var(--weight-medium)}.cn-pill b{color:var(--text);font-weight:var(--weight-bold)}.cn-progress{width:100%;height:10px;border-radius:var(--radius-full);background:var(--stat-bar-bg);overflow:hidden;border:1px solid var(--border)}.cn-progress__fill{height:100%;background:var(--stat-bar-fill);transition:width .5s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-full);box-shadow:0 0 8px #5b7cfa4d}.cn-stat{padding:12px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface-raised)}.cn-stat__label{display:flex;justify-content:space-between;gap:10px;font-size:var(--text-xs);font-weight:var(--weight-extrabold);color:var(--text);margin-bottom:8px}.cn-stat__value{color:var(--color-primary);font-weight:var(--weight-black);letter-spacing:.2px}.cn-stat__track{height:8px;border-radius:var(--radius-full);background:var(--stat-bar-bg);border:1px solid var(--border);overflow:hidden}.cn-stat__fill{display:block;height:100%;background:var(--stat-bar-fill);transition:width .5s cubic-bezier(.4,0,.2,1);border-radius:var(--radius-full);box-shadow:0 0 6px #5b7cfa40}.cn-stat__help{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;margin-left:6px;padding:0;border:1px solid var(--border-strong);border-radius:var(--radius-full);background:var(--color-primary-ghost);color:var(--color-primary);font-size:10px;font-weight:var(--weight-bold);line-height:1;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);vertical-align:middle;position:relative;top:-1px}.cn-stat__help:hover{background:var(--color-primary-light);border-color:var(--color-primary);transform:scale(1.15)}.cn-stat__help:focus-visible{outline:2px solid var(--border-focus);outline-offset:1px}.cn-stat-help-modal{display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding:var(--space-4) 0;text-align:center}.cn-stat-help-modal__icon{display:flex;align-items:baseline;gap:4px}.cn-stat-help-modal__score{font-size:var(--text-3xl);font-weight:var(--weight-black);background:var(--stat-bar-fill);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cn-stat-help-modal__max{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:var(--weight-medium)}.cn-stat-help-modal__desc{font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--text-secondary);max-width:360px;margin:0}.cn-field{display:flex;flex-direction:column;gap:6px}.cn-field__label{font-weight:var(--weight-extrabold);font-size:var(--text-sm);color:var(--text);letter-spacing:.15px}.cn-field__hint{color:var(--text-tertiary);font-size:var(--text-xs);line-height:var(--leading-tight);margin:0}.cn-field__error{color:var(--text-error);font-size:var(--text-xs);margin:0}.cn-textarea{width:100%;min-height:90px;resize:vertical;background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-md);padding:12px;font-size:var(--text-base);font-family:var(--font-sans);color:var(--text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cn-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #5b7cfa26}.cn-textarea--error{border-color:var(--color-error)}.cn-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--surface-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:18px}.cn-modal{width:min(920px,96vw);max-height:min(82vh,780px);overflow:hidden;border-radius:var(--radius-2xl);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-xl);display:flex;flex-direction:column}.cn-modal__header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.cn-modal__title{font-weight:var(--weight-black);font-size:var(--text-md);letter-spacing:.2px;margin:0}.cn-modal__close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary);border-radius:var(--radius-full);padding:0;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.cn-modal__close:hover{color:var(--text);border-color:var(--border-strong);background:var(--bg)}.cn-modal__body{padding:20px;overflow:auto;flex:1}.cn-modal__footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.cn-toast{position:fixed;left:50%;bottom:24px;transform:translate(-50%) translateY(8px);padding:12px 20px 12px 24px;border-radius:var(--radius-lg);border:1px solid var(--border);border-left:3px solid var(--color-primary);background:var(--surface-raised);box-shadow:var(--shadow-xl);color:var(--text);font-size:var(--text-sm);font-weight:var(--weight-medium);max-width:92vw;text-align:center;z-index:var(--z-toast);opacity:0;pointer-events:none;transition:opacity var(--transition-base),transform var(--transition-base)}.cn-toast--visible{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.cn-skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--border) 25%,var(--surface-raised) 50%,var(--border) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite}.cn-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:20px 0;border:none}.cn-delta{display:inline-flex;font-size:var(--text-xs);padding:3px 8px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary);white-space:nowrap;font-weight:var(--weight-semibold)}.cn-delta--good{border-color:#22c55e66;color:var(--text-success);background:var(--color-success-light)}.cn-delta--bad{border-color:#ef444466;color:var(--text-error);background:var(--color-error-light)}.cn-question{padding:20px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-raised);margin-bottom:16px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.cn-question:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #5b7cfa14}.cn-option{display:block;width:100%;text-align:left;padding:14px 16px;margin-bottom:10px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-sans);font-size:var(--text-base);color:var(--text)}.cn-option:hover{background:var(--bg);border-color:var(--border-strong);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.cn-option--selected{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 1px var(--color-primary),var(--shadow-sm)}.cn-option--selected:hover{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 1px var(--color-primary),var(--shadow-md)}.cn-option__key{font-weight:var(--weight-extrabold);color:var(--color-primary);margin-right:8px}.cn-option__note{display:block;color:var(--text-secondary);font-size:var(--text-xs);margin-top:6px;line-height:var(--leading-tight)}.cn-log-entry{border:1px solid var(--border);background:var(--surface-raised);border-radius:var(--radius-lg);padding:14px;margin-bottom:10px;animation:fadeIn var(--transition-base) ease both;transition:border-color var(--transition-fast)}.cn-log-entry:hover{border-color:var(--border-strong)}.cn-log-entry__top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.cn-log-entry__tag{font-size:11px;padding:3px 8px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary)}.cn-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:520px){.cn-stats-grid{grid-template-columns:1fr}}.cn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.dtree h3{margin:0 0 10px;font-size:var(--text-lg);font-weight:var(--weight-black);color:var(--text)}.dtree h4{margin:16px 0 6px;font-size:var(--text-md);font-weight:var(--weight-bold);color:var(--text)}.dtree p{color:var(--text-secondary);line-height:var(--leading-relaxed);margin:8px 0}.dtree ul{margin:10px 0 0 18px;list-style:disc}.dtree li{margin:6px 0;color:var(--text);line-height:var(--leading-relaxed)}.dtree hr{border:none;height:1px;background:var(--border);margin:16px 0}.dtree pre{margin:12px 0;padding:12px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-raised);color:var(--text);overflow:auto;font-size:var(--text-xs);font-family:var(--font-mono)}.cn-offline-banner{position:fixed;top:0;left:0;right:0;background:var(--color-warning);color:#1a1d23;padding:6px 16px;text-align:center;font-size:var(--text-xs);font-weight:var(--weight-semibold);z-index:var(--z-toast);transition:transform var(--transition-base)}.cn-install-prompt{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-lg);border:1px solid var(--color-primary);background:var(--color-primary-light);margin-bottom:16px;animation:fadeIn var(--transition-base) ease both}.cn-install-prompt__text{flex:1;font-size:var(--text-sm);color:var(--text)}.cn-header-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:var(--surface-raised);color:var(--text-secondary);border-radius:var(--radius-md);padding:0;cursor:pointer;transition:all var(--transition-fast);line-height:1;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px}.cn-header-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-ghost);transform:translateY(-1px)}.cn-app-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:12px 0 24px;flex-wrap:wrap}.cn-app-header__brand{display:flex;align-items:center;gap:12px}.cn-app-header__logo{width:36px;height:36px;background:var(--gradient-brand);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px;letter-spacing:-.5px;flex-shrink:0;box-shadow:0 2px 8px #5b7cfa40}.cn-app-header__title{font-size:var(--text-xl);font-weight:var(--weight-black);margin:0;background:var(--gradient-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px;line-height:1.2}.cn-app-header__tagline{margin:2px 0 0;color:var(--text-tertiary);font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:.2px}.cn-app-header__actions{display:flex;gap:6px;align-items:center}@media(max-width:980px){.cn-layout-grid{grid-template-columns:1fr!important}.cn-sidebar-desktop{display:none!important}}.cn-sidebar-toggle{display:none}@media(max-width:980px){.cn-sidebar-toggle{display:inline-flex}}.cn-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s ease}.cn-sidebar-overlay--visible{opacity:1;pointer-events:auto}.cn-sidebar-drawer{position:fixed;top:0;left:0;bottom:0;height:100vh;height:100dvh;z-index:100;width:min(340px,85vw);background:var(--surface);border-right:1px solid var(--border);box-shadow:var(--shadow-lg, 4px 0 24px rgba(0, 0, 0, .18));transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.cn-sidebar-drawer--open{transform:translate(0)}.cn-sidebar-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 10px;border-bottom:1px solid var(--border)}.cn-sidebar-drawer__title{margin:0;font-size:var(--text-lg);font-weight:700;color:var(--text)}.cn-sidebar-drawer__close{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.cn-sidebar-drawer__close:hover{background:var(--surface-hover);color:var(--text)}.cn-sidebar-drawer__body{padding:18px;flex:1;overflow-y:auto;min-height:0}@media(min-width:981px){.cn-sidebar-drawer,.cn-sidebar-overlay{display:none!important}}.cn-log-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;background:#00000073;opacity:0;pointer-events:none;transition:opacity .25s ease}.cn-log-overlay--visible{opacity:1;pointer-events:auto}.cn-log-drawer{position:fixed;top:0;right:0;bottom:0;height:100vh;height:100dvh;z-index:100;width:min(380px,90vw);background:var(--surface);border-left:1px solid var(--border);box-shadow:var(--shadow-lg, -4px 0 24px rgba(0, 0, 0, .18));transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow:hidden}.cn-log-drawer--open{transform:translate(0)}.cn-history-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);padding:var(--space-10) var(--space-4);text-align:center}.cn-history-empty__icon{font-size:2.5rem;opacity:.6}.cn-history-empty__text{color:var(--text-tertiary);font-size:var(--text-sm);line-height:var(--leading-relaxed);max-width:280px;margin:0}.cn-history-list{display:flex;flex-direction:column;gap:var(--space-3)}.cn-history-card{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;text-align:left;padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-raised);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);display:flex;flex-direction:column;gap:8px}.cn-history-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-1px)}.cn-history-card__top{display:flex;justify-content:space-between;align-items:center}.cn-history-card__number{font-size:var(--text-xs);font-weight:var(--weight-bold);color:var(--color-primary)}.cn-history-card__date{font-size:var(--text-xs);color:var(--text-tertiary)}.cn-history-card__scenario{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text);line-height:var(--leading-tight);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cn-history-card__bottom{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);color:var(--text-secondary)}.cn-history-card__quality{margin-left:auto;color:var(--text-success);font-weight:var(--weight-semibold)}.cn-history-back{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;padding:0;color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--weight-semibold);cursor:pointer;margin-bottom:var(--space-4);transition:opacity var(--transition-fast)}.cn-history-back:hover{opacity:.75}.cn-history-detail__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-4)}.cn-history-detail__scenario{font-size:var(--text-md);font-weight:var(--weight-bold);color:var(--text);margin:0 0 6px;line-height:var(--leading-tight)}.cn-history-detail__meta{display:flex;gap:var(--space-2);font-size:var(--text-xs);color:var(--text-tertiary);flex-wrap:wrap}.cn-history-quality-badge{display:flex;flex-direction:column;align-items:center;padding:var(--space-3);border-radius:var(--radius-lg);background:var(--color-primary-ghost);border:1px solid var(--border);min-width:64px;flex-shrink:0}.cn-history-quality-badge__value{font-size:var(--text-2xl);font-weight:var(--weight-black);background:var(--stat-bar-fill);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.cn-history-quality-badge__label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:var(--weight-medium);margin-top:2px}.cn-history-section-title{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--text);margin:0 0 var(--space-3) 0}.cn-history-stats-table{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--space-4)}.cn-history-stats-row{display:grid;grid-template-columns:1.5fr .6fr .6fr .6fr;gap:var(--space-2);padding:8px 10px;border-radius:var(--radius-sm);font-size:var(--text-xs);align-items:center}.cn-history-stats-row:nth-child(2n){background:var(--color-primary-ghost)}.cn-history-stats-row--header{font-weight:var(--weight-bold);color:var(--text-tertiary);font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding-bottom:6px;border-bottom:1px solid var(--border)}.cn-history-stats-name{font-weight:var(--weight-semibold);color:var(--text)}.cn-history-stats-val{text-align:center;color:var(--text-secondary);font-weight:var(--weight-medium)}.cn-history-delta{text-align:center;font-weight:var(--weight-bold)}.cn-history-delta--up{color:var(--text-success)}.cn-history-delta--down{color:var(--text-error)}.cn-history-delta--neutral{color:var(--text-tertiary)}.cn-history-analysis{padding:var(--space-4);border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface-raised);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary);max-height:400px;overflow-y:auto}.cn-history-delete-confirm{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--text-secondary)}@keyframes splashFadeInUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes splashOrb{0%,to{transform:translate(0) scale(1)}33%{transform:translate(12px,-18px) scale(1.05)}66%{transform:translate(-8px,10px) scale(.97)}}.cn-splash{position:relative;display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;overflow:hidden;padding:var(--space-8) var(--space-4)}.cn-splash__orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:0;pointer-events:none;transition:opacity 1.2s ease}.cn-splash--ready .cn-splash__orb{opacity:1}.cn-splash__orb--1{width:420px;height:420px;background:radial-gradient(circle,rgba(91,124,250,.25),transparent 70%);top:-80px;right:-60px;animation:splashOrb 14s ease-in-out infinite}.cn-splash__orb--2{width:340px;height:340px;background:radial-gradient(circle,rgba(34,197,94,.18),transparent 70%);bottom:-40px;left:-40px;animation:splashOrb 18s ease-in-out infinite reverse}.cn-splash__inner{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;max-width:640px;width:100%;z-index:1}.cn-splash__animation{width:260px;height:260px;margin-bottom:var(--space-2);opacity:0;transition:opacity .6s ease .1s}.cn-splash--ready .cn-splash__animation{opacity:1}.cn-splash__title{font-size:clamp(1.6rem,4vw,var(--text-3xl));font-weight:var(--weight-extrabold);line-height:var(--leading-tight);color:var(--text);margin-bottom:var(--space-4);opacity:0}.cn-splash--ready .cn-splash__title{animation:splashFadeInUp .7s ease .2s both}.cn-splash__title-accent{background:linear-gradient(135deg,var(--color-primary),var(--color-success));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cn-splash__subtitle{font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--text-secondary);max-width:520px;margin-bottom:var(--space-8);opacity:0}.cn-splash--ready .cn-splash__subtitle{animation:splashFadeInUp .7s ease .32s both}.cn-splash__features{display:flex;flex-direction:column;gap:var(--space-3);width:100%;margin-bottom:var(--space-8)}.cn-splash__feature{display:flex;align-items:flex-start;gap:var(--space-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);text-align:left;opacity:0;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.cn-splash--ready .cn-splash__feature{animation:splashFadeInUp .55s ease both}.cn-splash__feature:hover{transform:translateY(-3px);box-shadow:var(--shadow-md),var(--shadow-glow);border-color:var(--border-strong)}.cn-splash__feature-icon{flex-shrink:0;width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-primary-ghost);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.cn-splash__feature-title{display:block;font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:2px}.cn-splash__feature-desc{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text-secondary)}.cn-splash__cta{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);opacity:0}.cn-splash--ready .cn-splash__cta{animation:splashFadeInUp .6s ease .55s both}.cn-splash__cta .cn-btn{min-width:200px;font-size:var(--text-md);padding:var(--space-4) var(--space-8)}.cn-splash__note{font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.02em}@media(max-width:480px){.cn-splash__animation{width:200px;height:200px}.cn-splash__feature{padding:var(--space-3) var(--space-4)}}.cn-splash__install-link{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-xs);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:color var(--transition-base),background var(--transition-base);letter-spacing:.02em}.cn-splash__install-link:hover{color:var(--accent);background:var(--surface-raised)}.cn-install-banner{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(12px);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface-raised);box-shadow:var(--shadow-xl);color:var(--text);font-size:var(--text-sm);max-width:min(480px,92vw);width:max-content;z-index:var(--z-toast);opacity:0;pointer-events:none;animation:installBannerIn .45s ease forwards}.cn-install-banner--visible{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.cn-install-banner__content{display:flex;align-items:center;gap:var(--space-2);min-width:0}.cn-install-banner__icon{font-size:var(--text-lg);flex-shrink:0}.cn-install-banner__text{line-height:var(--leading-tight)}.cn-install-banner__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.cn-install-banner__dismiss{background:none;border:none;color:var(--text-tertiary);font-size:var(--text-md);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);line-height:1;transition:color var(--transition-base),background var(--transition-base)}.cn-install-banner__dismiss:hover{color:var(--text);background:var(--surface)}@keyframes installBannerIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:600px){.cn-app-container{padding:12px 10px 48px!important}.cn-app-header{margin:4px 0 14px;gap:10px}.cn-app-header__brand{gap:8px}.cn-app-header__logo{width:30px;height:30px;font-size:15px;border-radius:8px}.cn-app-header__title{font-size:var(--text-md)}.cn-app-header__tagline{display:none}.cn-app-header__actions{gap:4px}.cn-header-btn{width:32px;height:32px}.cn-header-btn svg{width:16px;height:16px}.cn-card{border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border-left:none;border-right:none;margin-left:-10px;margin-right:-10px;border-radius:var(--radius-sm)}.cn-card__header{padding:10px 14px 9px;gap:8px}.cn-card__header:before{height:2px}.cn-card__title{font-size:var(--text-xs);letter-spacing:.4px}.cn-card__content{padding:14px}.cn-layout-grid{gap:12px!important}.cn-question{padding:14px;margin-bottom:10px;border-radius:var(--radius-md)}.cn-option{padding:12px 14px;margin-bottom:8px;border-radius:var(--radius-md)}.cn-stat{padding:10px;border-radius:var(--radius-md)}.cn-stats-grid{gap:8px}.cn-log-entry{padding:10px 12px;margin-bottom:8px;border-radius:var(--radius-md)}.cn-pill{padding:6px 10px;font-size:11px;gap:4px}.cn-progress{height:8px}.cn-delta{padding:2px 6px;font-size:11px}.cn-divider{margin:12px 0}.cn-btn--sm{padding:5px 10px;font-size:11px}.cn-btn--md{padding:8px 14px;font-size:var(--text-sm)}.cn-btn--lg{padding:12px 22px;font-size:var(--text-base)}.cn-row{gap:8px}.cn-textarea{min-height:72px;padding:10px;font-size:var(--text-sm)}.cn-field__label{font-size:var(--text-xs)}.cn-field__hint{font-size:11px}.cn-badge{padding:3px 8px;font-size:11px}.cn-modal-overlay{padding:0;align-items:flex-end}.cn-modal{width:100vw;max-height:92vh;max-height:92dvh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;border-bottom:none;animation:mobileSheetUp .3s cubic-bezier(.16,1,.3,1) both}.cn-modal__header{padding:14px 16px;gap:8px}.cn-modal__title{font-size:var(--text-base)}.cn-modal__body{padding:14px 16px}.cn-modal__footer{padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));gap:8px}.cn-toast{left:10px;right:10px;bottom:16px;bottom:max(16px,env(safe-area-inset-bottom));transform:translateY(8px);max-width:none;border-radius:var(--radius-md);padding:10px 14px 10px 16px;font-size:var(--text-xs)}.cn-toast--visible{transform:translateY(0)}.cn-offline-banner{padding:4px 12px;font-size:11px}.cn-install-banner{left:8px;right:8px;bottom:12px;bottom:max(12px,env(safe-area-inset-bottom));transform:translateY(12px);max-width:none;width:auto;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--text-xs);gap:var(--space-2)}.cn-install-banner--visible{transform:translateY(0)}.cn-sidebar-drawer{width:100vw}.cn-sidebar-drawer__header{padding:14px 14px 10px}.cn-sidebar-drawer__body{padding:14px}.cn-log-drawer{width:min(100vw,420px)}.cn-splash{padding:var(--space-6) var(--space-3)}.cn-splash__animation{width:180px;height:180px}.cn-splash__title{font-size:1.35rem}.cn-splash__subtitle{font-size:var(--text-sm);margin-bottom:var(--space-6)}.cn-splash__features{gap:var(--space-2);margin-bottom:var(--space-6)}.cn-splash__feature{padding:var(--space-3);gap:var(--space-3)}.cn-splash__feature-icon{width:36px;height:36px}.cn-splash__feature-title{font-size:var(--text-sm)}.cn-splash__feature-desc{font-size:var(--text-xs)}.cn-history-card{padding:var(--space-3);gap:6px}.cn-history-stats-row{padding:6px 8px;font-size:11px}.cn-history-detail__scenario{font-size:var(--text-base)}}@keyframes mobileSheetUp{0%{opacity:0;transform:translateY(40%)}to{opacity:1;transform:translateY(0)}}
