@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&family=Noto+Sans+TC:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0b0f19;--bg-secondary:#111827;--bg-tertiary:#1a2332;--bg-surface:#1e293b;--bg-hover:#263348;--bg-active:#2d3d56;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--accent-primary:#3b82f6;--accent-primary-hover:#2563eb;--accent-secondary:#8b5cf6;--accent-success:#10b981;--accent-warning:#f59e0b;--accent-danger:#ef4444;--accent-info:#06b6d4;--impact-high:#ef4444;--impact-medium:#f59e0b;--impact-low:#10b981;--cat-credit-card:#3b82f6;--cat-personal-loan:#8b5cf6;--cat-mortgage:#a855f7;--cat-digital-account:#06b6d4;--cat-wealth-mgmt:#f59e0b;--cat-payment:#10b981;--cat-insurance:#ec4899;--cat-fund:#f97316;--cat-membership:#14b8a6;--border-color:#1e293b;--border-subtle:#334155;--border-hover:#475569;--glass-bg:#111827d9;--glass-border:#ffffff0f;--glass-shadow:0 8px 32px #0000004d;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 24px #0006;--shadow-glow:0 0 20px #3b82f626;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-full:9999px;--sidebar-width:260px;--sidebar-collapsed-width:68px;--header-height:56px;--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.4s ease;--font-ui:"Inter", "Noto Sans TC", -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--font-cn:"Noto Sans TC", "PingFang TC", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-size:16px}body{font-family:var(--font-ui);color:var(--text-primary);background-color:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;min-height:100dvh;font-weight:400;line-height:1.6;overflow-x:hidden}#root{min-height:100dvh}img,svg,video{max-width:100%;display:block}a{color:var(--accent-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-primary-hover)}button{cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}h1,h2,h3,h4,h5,h6{font-family:var(--font-ui);color:var(--text-primary);letter-spacing:-.01em;font-weight:600;line-height:1.3}h1{letter-spacing:-.025em;font-size:1.875rem;font-weight:700}h2{letter-spacing:-.02em;font-size:1.5rem;font-weight:600}h3{font-size:1.25rem;font-weight:600}h4{font-size:1.125rem;font-weight:600}h5{font-size:1rem;font-weight:600}h6{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.875rem;font-weight:600}p{color:var(--text-secondary);line-height:1.7}small{color:var(--text-muted);font-size:.8125rem}code{font-family:var(--font-mono);background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--accent-primary);padding:2px 6px;font-size:.875em}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent-primary)}.text-success{color:var(--accent-success)}.text-warning{color:var(--accent-warning)}.text-danger{color:var(--accent-danger)}.text-info{color:var(--accent-info)}.font-mono{font-family:var(--font-mono)}.font-cn{font-family:var(--font-cn)}.font-bold{font-weight:600}.font-light{font-weight:300}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-center{text-align:center}.text-right{text-align:right}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);padding:var(--space-lg);transition:border-color var(--transition-normal), box-shadow var(--transition-normal)}.card:hover{border-color:#ffffff1a}.card-header{padding-bottom:var(--space-md);margin-bottom:var(--space-md);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.card-header h3,.card-header h4{margin:0}.card-body{flex:1}.card-footer{justify-content:flex-end;align-items:center;gap:var(--space-sm);padding-top:var(--space-md);margin-top:var(--space-md);border-top:1px solid var(--border-color);display:flex}.card-clickable{cursor:pointer;transition:border-color var(--transition-normal), box-shadow var(--transition-normal), transform var(--transition-normal)}.card-clickable:hover{box-shadow:var(--shadow-glow);border-color:#3b82f633;transform:translateY(-1px)}.card-clickable:active{transform:translateY(0)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;padding:8px 18px;font-size:.875rem;font-weight:500;line-height:1.4;display:inline-flex;position:relative;overflow:hidden}.btn:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.btn-primary:hover{background:var(--accent-primary-hover);border-color:var(--accent-primary-hover);box-shadow:0 0 16px #3b82f64d}.btn-primary:active{background:#1d4ed8}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border-subtle)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-secondary:active{background:var(--bg-active)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-ghost:active{background:var(--bg-active)}.btn-danger{color:var(--accent-danger);background:#ef44441f;border-color:#ef444433}.btn-danger:hover{background:#ef444433;border-color:#ef444459}.btn-danger:active{background:#ef444447}.btn-sm{padding:4px 12px;font-size:.8125rem}.btn-lg{border-radius:var(--radius-md);padding:12px 28px;font-size:1rem}.btn-icon{min-width:36px;min-height:36px;padding:8px}.btn-icon.btn-sm{min-width:28px;min-height:28px;padding:4px}.input,.textarea,.select{width:100%;color:var(--text-primary);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:10px 14px;font-size:.875rem;line-height:1.5;display:block}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.input:hover,.textarea:hover,.select:hover{border-color:var(--border-subtle)}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f626}.textarea{resize:vertical;min-height:100px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.input-sm{padding:6px 10px;font-size:.8125rem}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text-secondary);font-size:.8125rem;font-weight:500}.input-hint{color:var(--text-muted);font-size:.75rem}.input-error{border-color:var(--accent-danger)}.input-error:focus{box-shadow:0 0 0 3px #ef444426}.input-error-msg{color:var(--accent-danger);font-size:.75rem}.badge{border-radius:var(--radius-full);white-space:nowrap;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color);align-items:center;gap:4px;padding:2px 10px;font-size:.75rem;font-weight:500;line-height:1.6;display:inline-flex}.badge-primary{color:var(--accent-primary);background:#3b82f61f;border-color:#3b82f633}.badge-success{color:var(--accent-success);background:#10b9811f;border-color:#10b98133}.badge-warning{color:var(--accent-warning);background:#f59e0b1f;border-color:#f59e0b33}.badge-danger{color:var(--accent-danger);background:#ef44441f;border-color:#ef444433}.badge-info{color:var(--accent-info);background:#06b6d41f;border-color:#06b6d433}.badge-purple{color:var(--accent-secondary);background:#8b5cf61f;border-color:#8b5cf633}.tag{border-radius:var(--radius-full);background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-color);transition:all var(--transition-fast);align-items:center;gap:6px;padding:4px 12px;font-size:.8125rem;font-weight:500;display:inline-flex}.tag:hover{border-color:var(--border-subtle);background:var(--bg-hover)}.tag-remove{width:16px;height:16px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.75rem;line-height:1;display:inline-flex}.tag-remove:hover{color:var(--accent-danger);background:#ef444433}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table thead{z-index:1;position:sticky;top:0}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);white-space:nowrap;padding:10px 16px;font-size:.75rem;font-weight:600}.table td{color:var(--text-secondary);border-bottom:1px solid var(--border-color);vertical-align:middle;padding:12px 16px}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td{border-bottom:none}.table-sortable th{cursor:pointer;-webkit-user-select:none;user-select:none}.table-sortable th:hover{color:var(--text-secondary)}.empty-state{padding:var(--space-2xl) var(--space-lg);text-align:center;justify-content:center;align-items:center;gap:var(--space-md);flex-direction:column;min-height:240px;display:flex}.empty-state-icon{opacity:.4;margin-bottom:var(--space-sm);font-size:3rem}.empty-state-title{color:var(--text-primary);font-size:1.125rem;font-weight:600}.empty-state-desc{color:var(--text-muted);max-width:360px;font-size:.875rem;line-height:1.6}.stat-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);gap:var(--space-xs);transition:border-color var(--transition-normal);flex-direction:column;display:flex}.stat-card:hover{border-color:#ffffff1a}.stat-card-label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.stat-card-value{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.02em;font-size:1.75rem;font-weight:600;line-height:1.2}.stat-card-change{font-family:var(--font-mono);font-size:.8125rem;font-weight:500}.stat-card-change.positive{color:var(--accent-success)}.stat-card-change.negative{color:var(--accent-danger)}.stat-card-change.neutral{color:var(--text-muted)}.impact-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.impact-dot.high{background:var(--impact-high);box-shadow:0 0 6px #ef444466}.impact-dot.medium{background:var(--impact-medium);box-shadow:0 0 6px #f59e0b66}.impact-dot.low{background:var(--impact-low);box-shadow:0 0 6px #10b98166}.product-type-badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:6px;padding:3px 12px;font-size:.75rem;font-weight:500;display:inline-flex}.product-type-badge.credit-card{color:var(--cat-credit-card);background:#3b82f61f;border:1px solid #3b82f633}.product-type-badge.personal-loan{color:var(--cat-personal-loan);background:#8b5cf61f;border:1px solid #8b5cf633}.product-type-badge.mortgage{color:var(--cat-mortgage);background:#a855f71f;border:1px solid #a855f733}.product-type-badge.digital-account{color:var(--cat-digital-account);background:#06b6d41f;border:1px solid #06b6d433}.product-type-badge.wealth-mgmt{color:var(--cat-wealth-mgmt);background:#f59e0b1f;border:1px solid #f59e0b33}.product-type-badge.payment{color:var(--cat-payment);background:#10b9811f;border:1px solid #10b98133}.product-type-badge.insurance{color:var(--cat-insurance);background:#ec48991f;border:1px solid #ec489933}.product-type-badge.fund{color:var(--cat-fund);background:#f973161f;border:1px solid #f9731633}.product-type-badge.membership{color:var(--cat-membership);background:#14b8a61f;border:1px solid #14b8a633}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.grid-2{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-md);grid-template-columns:repeat(4,1fr);display:grid}.w-full{width:100%}.h-full{height:100%}.mt-xs{margin-top:var(--space-xs)}.mt-sm{margin-top:var(--space-sm)}.mt-md{margin-top:var(--space-md)}.mt-lg{margin-top:var(--space-lg)}.mt-xl{margin-top:var(--space-xl)}.mb-xs{margin-bottom:var(--space-xs)}.mb-sm{margin-bottom:var(--space-sm)}.mb-md{margin-bottom:var(--space-md)}.mb-lg{margin-bottom:var(--space-lg)}.mb-xl{margin-bottom:var(--space-xl)}.p-sm{padding:var(--space-sm)}.p-md{padding:var(--space-md)}.p-lg{padding:var(--space-lg)}.p-xl{padding:var(--space-xl)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.relative{position:relative}.divider{background:var(--border-color);height:1px;margin:var(--space-md) 0;border:none}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);white-space:nowrap;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:1000;padding:4px 10px;font-size:.75rem;font-weight:500;position:absolute;top:50%;left:calc(100% + 10px);transform:translateY(-50%)}[data-tooltip]:hover:after{opacity:1}.skeleton{background:linear-gradient(90deg, var(--bg-tertiary) 25%, var(--bg-hover) 50%, var(--bg-tertiary) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.skeleton-text{width:100%;height:14px;margin-bottom:8px}.skeleton-text:last-child{width:60%}.skeleton-title{width:40%;height:20px;margin-bottom:16px}.skeleton-circle{border-radius:50%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-16px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn var(--transition-normal) ease forwards}.animate-slide-up{animation:slideUp var(--transition-slow) ease forwards}.animate-slide-left{animation:slideInLeft var(--transition-slow) ease forwards}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.animate-scale-in{animation:scaleIn var(--transition-normal) ease forwards}.stagger-children>*{opacity:0;animation:slideUp var(--transition-slow) ease forwards}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}*{scrollbar-width:thin;scrollbar-color:var(--border-subtle) transparent}::selection{color:var(--text-primary);background:#3b82f64d}::selection{color:var(--text-primary);background:#3b82f64d}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.page{animation:fadeIn var(--transition-normal) ease;padding:var(--space-lg)}.page-header{margin-bottom:var(--space-xl)}.page-title{color:var(--text-primary);margin-bottom:var(--space-xs);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-muted);font-size:.875rem}@media (width<=1200px){.grid-4{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-color);height:100%;transition:width var(--transition-normal);flex-direction:column;display:flex;overflow:hidden}.sidebar-logo{align-items:center;gap:var(--space-sm);padding:0 var(--space-md);height:var(--header-height);border-bottom:1px solid var(--border-color);flex-shrink:0;display:flex;overflow:hidden}.sidebar-logo-icon{flex-shrink:0;justify-content:center;align-items:center;width:36px;font-size:1.5rem;display:flex}.sidebar-logo-text{color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap;opacity:1;transition:opacity var(--transition-fast);font-size:1.125rem;font-weight:700}.sidebar-logo-text span{color:var(--accent-primary)}.sidebar.collapsed .sidebar-logo-text{opacity:0;width:0;overflow:hidden}.sidebar-regions{padding:var(--space-sm) var(--space-sm);border-bottom:1px solid var(--border-color);flex-shrink:0;gap:2px;display:flex}.sidebar-region-btn{color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:1px solid #0000;flex:1;justify-content:center;align-items:center;gap:6px;padding:6px 8px;font-size:.8125rem;font-weight:500;text-decoration:none;display:flex;overflow:hidden}.sidebar-region-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-region-btn.active{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--border-subtle)}.sidebar-region-icon{flex-shrink:0;font-size:1rem}.sidebar-region-label{transition:opacity var(--transition-fast), width var(--transition-fast)}.sidebar.collapsed .sidebar-region-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-regions{padding:var(--space-xs);flex-direction:column}.sidebar.collapsed .sidebar-region-btn{justify-content:center;padding:8px}.sidebar-nav{padding:var(--space-sm) var(--space-sm);flex:1;overflow:hidden auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:var(--space-md) var(--space-sm) var(--space-xs);white-space:nowrap;transition:opacity var(--transition-fast);font-size:.6875rem;font-weight:600;overflow:hidden}.sidebar.collapsed .sidebar-section-label{opacity:0;height:0;margin:0;padding:0;overflow:hidden}.sidebar-nav-item{align-items:center;gap:var(--space-sm);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border-left:3px solid #0000;margin-bottom:2px;padding:8px 12px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.sidebar-nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-nav-item.active{color:var(--accent-primary);border-left-color:var(--accent-primary);background:#3b82f614}.sidebar-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;font-size:1.125rem;display:flex}.sidebar-nav-label{opacity:1;transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar-nav-label{opacity:0;width:0;overflow:hidden}.sidebar.collapsed .sidebar-nav-item{border-radius:var(--radius-sm);border-left-width:0;justify-content:center;padding:10px 0}.sidebar.collapsed .sidebar-nav-item.active{background:#3b82f61f}.sidebar-footer{padding:var(--space-sm);border-top:1px solid var(--border-color);flex-shrink:0}.sidebar-collapse-btn{width:100%;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;gap:var(--space-sm);background:0 0;border:1px solid #0000;padding:8px;font-size:.8125rem;font-weight:500;display:flex}.sidebar-collapse-btn:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-collapse-icon{transition:transform var(--transition-normal);flex-shrink:0;font-size:1rem}.sidebar.collapsed .sidebar-collapse-icon{transform:rotate(180deg)}.sidebar-collapse-label{transition:opacity var(--transition-fast)}.sidebar.collapsed .sidebar-collapse-label{opacity:0;width:0;overflow:hidden}.research-mode-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.research-mode-card{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left}.research-mode-card:hover{border-color:var(--accent-primary);background:var(--bg-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0003}.research-mode-card.selected{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary);background:#3b82f614}.research-mode-icon{margin-bottom:var(--space-sm);font-size:2rem}.research-mode-label{color:var(--text-primary);margin-bottom:4px;font-size:1rem;font-weight:600}.research-mode-desc{color:var(--text-muted);font-size:.8rem;line-height:1.4}.research-input-area{gap:var(--space-md);align-items:flex-end;display:flex}.research-input-area .input-group{flex:1}.research-topic-input{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);background:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary);width:100%;transition:all var(--transition-fast);font-size:1.05rem}.research-topic-input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 3px #3b82f626}.research-topic-input::placeholder{color:var(--text-muted)}.btn-research{padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);color:#fff;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:var(--space-sm);background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;font-size:1rem;font-weight:600;display:flex}.btn-research:hover{transform:translateY(-1px);box-shadow:0 4px 16px #3b82f666}.btn-research:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.research-history-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast);color:inherit;text-decoration:none;display:flex}.research-history-item:hover{background:var(--bg-hover);border-color:var(--border-subtle);color:inherit}.research-history-mode{flex-shrink:0;font-size:1.5rem}.research-history-info{flex:1;min-width:0}.research-history-topic{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:600;overflow:hidden}.research-history-meta{color:var(--text-muted);margin-top:2px;font-size:.75rem}.streaming-indicator{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);color:var(--accent-primary);background:#3b82f61a;font-size:.85rem;font-weight:500;display:flex}.streaming-dot{background:var(--accent-primary);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite streamPulse}.streaming-dot:nth-child(2){animation-delay:.2s}.streaming-dot:nth-child(3){animation-delay:.4s}@keyframes streamPulse{0%,to{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}.report-layout{gap:var(--space-lg);grid-template-columns:220px 1fr;align-items:start;display:grid}@media (width<=900px){.report-layout{grid-template-columns:1fr}.report-toc{display:none}}.report-toc{top:var(--space-lg);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-md);max-height:80vh;position:sticky;overflow-y:auto}.report-toc-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--border-color);font-size:.75rem;font-weight:600}.report-toc-link{color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast);margin-bottom:2px;padding:4px 8px;font-size:.8rem;line-height:1.4;text-decoration:none;display:block}.report-toc-link:hover{color:var(--text-primary);background:var(--bg-hover)}.report-toc-link.h3{padding-left:20px;font-size:.75rem}.report-main{min-width:0}.report-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-2xl);color:var(--text-primary);font-size:.95rem;line-height:1.8}.report-content h2{border-bottom:2px solid var(--border-color);color:var(--text-primary);margin:2rem 0 1rem;padding-bottom:.5rem;font-size:1.35rem;font-weight:700}.report-content h2:first-child{margin-top:0}.report-content h3{color:var(--text-primary);margin:1.5rem 0 .75rem;font-size:1.1rem;font-weight:600}.report-content h4{margin:1.2rem 0 .5rem;font-size:1rem;font-weight:600}.report-content p{margin:.75rem 0}.report-content ul,.report-content ol{margin:.5rem 0;padding-left:1.5rem}.report-content li{margin:.3rem 0}.report-content strong{color:var(--accent-primary);font-weight:600}.report-content table{border-collapse:collapse;width:100%;margin:1rem 0;font-size:.85rem}.report-content th{background:var(--bg-tertiary);color:var(--text-primary);text-align:left;border:1px solid var(--border-color);padding:10px 14px;font-weight:600}.report-content td{border:1px solid var(--border-color);color:var(--text-secondary);padding:8px 14px}.report-content tr:hover td{background:var(--bg-hover)}.report-content blockquote{border-left:3px solid var(--accent-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary);background:#3b82f60d;margin:1rem 0;padding:.5rem 1rem}.report-content code{background:var(--bg-tertiary);border-radius:var(--radius-xs);padding:2px 6px;font-size:.85em}.report-content mark,.search-highlight{color:inherit;background:#facc154d;border-radius:2px;padding:1px 2px}.report-actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.followup-section{margin-top:var(--space-lg);border-top:2px solid var(--border-color);padding-top:var(--space-lg)}.followup-messages{gap:var(--space-md);margin-bottom:var(--space-md);flex-direction:column;display:flex}.followup-msg{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);max-width:85%;font-size:.9rem;line-height:1.6}.followup-msg.user{color:#fff;border-bottom-right-radius:var(--radius-xs);background:linear-gradient(135deg,#3b82f6,#2563eb);align-self:flex-end}.followup-msg.assistant{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:var(--radius-xs);align-self:flex-start}.followup-input-row{gap:var(--space-sm);display:flex}.followup-input{padding:var(--space-md);border-radius:var(--radius-lg);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);flex:1;font-size:.9rem}.followup-input:focus{border-color:var(--accent-primary);outline:none}.settings-grid{gap:var(--space-lg);max-width:640px;display:grid}.api-key-input-wrap{position:relative}.api-key-input-wrap input{padding-right:50px}.api-key-toggle{cursor:pointer;color:var(--text-muted);background:0 0;border:none;font-size:1rem;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.global-search-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:flex-start;padding-top:15vh;display:flex;position:fixed;inset:0}.global-search-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:640px;animation:.2s slideUp;overflow:hidden;box-shadow:0 24px 64px #0006}.global-search-input-wrap{align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);display:flex}.global-search-input-wrap span{font-size:1.2rem}.global-search-input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:1rem}.global-search-results{max-height:400px;padding:var(--space-sm);overflow-y:auto}.global-search-result{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);cursor:pointer;color:inherit;transition:background var(--transition-fast);text-decoration:none;display:flex}.global-search-result:hover{background:var(--bg-hover);color:inherit}.global-search-result-icon{flex-shrink:0;font-size:1.2rem}.global-search-result-info{flex:1;min-width:0}.global-search-result-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:500;overflow:hidden}.global-search-result-sub{color:var(--text-muted);font-size:.75rem}.global-search-empty{padding:var(--space-xl);text-align:center;color:var(--text-muted);font-size:.9rem}.global-search-hint{padding:var(--space-sm) var(--space-md);text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);font-size:.75rem}@media print{.sidebar,.header,.report-toc,.report-actions,.followup-section,.btn,button{display:none!important}.report-layout{grid-template-columns:1fr!important}.report-content{box-shadow:none!important;border:none!important;padding:0!important}}.header{height:var(--header-height);padding:0 var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;display:flex}.header-breadcrumb{align-items:center;gap:var(--space-xs);color:var(--text-muted);min-width:0;font-size:.8125rem;display:flex}.header-breadcrumb-item{color:var(--text-muted);transition:color var(--transition-fast);white-space:nowrap;text-decoration:none}.header-breadcrumb-item:hover{color:var(--text-secondary)}.header-breadcrumb-item.current{color:var(--text-primary);font-weight:500}.header-breadcrumb-sep{color:var(--border-hover);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:.75rem}.header-actions{align-items:center;gap:var(--space-sm);flex-shrink:0;display:flex}.header-icon-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:1rem;display:flex}.header-icon-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.header-lang-toggle{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);align-items:center;gap:2px;padding:2px;display:flex}.header-lang-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:4px;padding:4px 10px;font-size:.75rem;font-weight:500}.header-lang-btn:hover{color:var(--text-secondary)}.header-lang-btn.active{color:var(--text-primary);background:var(--bg-surface);box-shadow:var(--shadow-sm)}.header-avatar{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;cursor:pointer;width:32px;height:32px;transition:box-shadow var(--transition-fast);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.header-avatar:hover{box-shadow:0 0 0 2px var(--bg-secondary), 0 0 0 4px var(--accent-primary)}.layout{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--header-height) 1fr;min-height:100dvh;transition:grid-template-columns var(--transition-normal);grid-template-areas:"sidebar header""sidebar content";display:grid}.layout.sidebar-collapsed{grid-template-columns:var(--sidebar-collapsed-width) 1fr}.layout-header{z-index:20;grid-area:header;position:sticky;top:0}.layout-sidebar{z-index:30;grid-area:sidebar;height:100dvh;position:sticky;top:0}.layout-content{background:var(--bg-primary);grid-area:content;min-height:0;overflow:hidden auto}.dashboard-stats{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.dashboard-stats .stat-card{animation:slideUp var(--transition-slow) ease both}@media (width<=1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dashboard-stats{grid-template-columns:1fr}}.dashboard-grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=900px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-project-list,.dashboard-trend-list,.dashboard-campaign-list{flex-direction:column;gap:2px;display:flex}.dashboard-project-item,.dashboard-trend-item,.dashboard-campaign-item{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background var(--transition-fast);color:inherit;justify-content:space-between;align-items:center;text-decoration:none;display:flex}.dashboard-project-item:hover,.dashboard-trend-item:hover,.dashboard-campaign-item:hover{background:var(--bg-hover);color:inherit}.dashboard-project-info{align-items:center;gap:var(--space-md);display:flex}.dashboard-project-region{font-size:1.25rem}.dashboard-project-title,.dashboard-trend-title,.dashboard-campaign-title{color:var(--text-primary);font-size:.875rem;font-weight:500}.dashboard-trend-item,.dashboard-campaign-item{justify-content:flex-start;gap:var(--space-md)}.dashboard-campaign-icon{font-size:1.125rem}.dashboard-quick-links{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.dashboard-quick-link{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);transition:all var(--transition-fast);font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.dashboard-quick-link:hover{background:var(--bg-hover);border-color:var(--border-subtle);color:var(--text-primary);transform:translateY(-1px)}.dashboard-quick-link span:first-child{font-size:1.25rem}.compare-tabs{gap:var(--space-sm);padding-bottom:var(--space-xs);display:flex;overflow-x:auto}.compare-tab{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);white-space:nowrap;cursor:pointer;transition:all var(--transition-fast);font-size:.875rem;font-weight:500;display:flex}.compare-tab:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.compare-tab.active{background:var(--bg-surface);border-color:var(--accent-primary);color:var(--text-primary);box-shadow:0 0 12px #3b82f626}.compare-table-card{padding:0;overflow:hidden}.compare-table-container{overflow-x:auto}.compare-table{min-width:100%}.compare-th-label{z-index:2;min-width:160px;position:sticky;left:0;background:var(--bg-tertiary)!important}.compare-th-product{min-width:200px}.compare-product-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);display:flex}.compare-product-competitor{color:var(--text-muted);text-transform:none;letter-spacing:0;font-size:.75rem;font-weight:400}.compare-product-name{color:var(--text-primary);text-transform:none;letter-spacing:0;font-size:.8125rem;font-weight:600}.compare-td-label{color:var(--text-secondary);background:var(--bg-secondary);z-index:1;font-weight:500;position:sticky;left:0}.compare-td-label .ml-1{margin-left:4px}.compare-td-value{position:relative}.compare-td-value.best-value{background:#10b98114}.compare-cell-input{border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:.875rem;font-family:var(--font-mono);transition:all var(--transition-fast);background:0 0;border:1px solid #0000;outline:none;padding:4px 8px}.compare-cell-input:hover{border-color:var(--border-color)}.compare-cell-input:focus{border-color:var(--accent-primary);background:var(--bg-tertiary);box-shadow:0 0 0 2px #3b82f626}.best-marker{color:var(--accent-success);font-size:.75rem;position:absolute;top:4px;right:4px}.compare-rating{letter-spacing:1px;font-size:.875rem}
