.topbar-back{display:flex;align-items:center;gap:2px;background:none;border:none;padding:6px 4px;cursor:pointer;color:var(--brand);font-size:15px;font-weight:500;min-height:40px;transition:opacity var(--transition)}.topbar-back:active{opacity:.6}.topbar-back-label{color:var(--brand);font-weight:500}.topbar-user{color:var(--text-secondary);font-size:12px;text-decoration:none;background:var(--bg-surface);min-height:44px;display:inline-flex;align-items:center;padding:0 10px;border-radius:999px;border:1px solid var(--border);transition:background var(--transition);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar-user:active{background:var(--border)}.topbar-role{opacity:.7}@media(max-width:360px){.topbar-role{display:none}}.page-shell.page-shell--task-flow{padding-bottom:env(safe-area-inset-bottom,0px)}:root{--text-xs:11px;--text-sm:13px;--text-base:15px;--text-md:15px;--text-lg:16px;--text-xl:18px;--text-2xl:20px;--text-3xl:24px;--text-kpi:28px;--space-0:0px;--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;--brand:#4F7EFF;--brand-deep:#7B5EFF;--brand-light:rgba(79,126,255,.1);--brand-glow:rgba(79,126,255,.25);--brand-50:rgba(79,126,255,.05);--brand-100:rgba(79,126,255,.1);--brand-200:rgba(79,126,255,.2);--brand-300:rgba(79,126,255,.4);--brand-400:#4F7EFF;--brand-500:#4F7EFF;--brand-600:#7B5EFF;--brand-700:#6B5ACD;--gray-50:#F9FAFB;--gray-100:#F2F4F7;--gray-200:#EAECF0;--gray-300:#D0D5DD;--gray-400:#98A2B3;--gray-500:#667085;--gray-600:#475467;--gray-700:#344054;--gray-800:#1D2939;--gray-900:#101828;--success:#00C48C;--success-bg:#E8FBF4;--success-500:#00C48C;--warning:#FF9500;--warning-bg:#FFF7E6;--warning-500:#FF9500;--danger:#FF4757;--danger-bg:#FFF0F0;--danger-500:#FF4757;--error:#FF4757;--error-500:#FF4757;--info:#4F7EFF;--info-bg:#EEF3FF;--info-500:#4F7EFF;--bg-base:#EEF1F8;--bg-surface:#EEF1F8;--bg-card:#ffffff;--bg-subtle:#F5F7FF;--bg-glass:rgba(255,255,255,.85);--bg-primary:#ffffff;--bg-secondary:#EEF1F8;--bg-tertiary:#F5F7FF;--text-primary:#0F1729;--text:#1A1D2E;--text-secondary:#5A6379;--text-tertiary:#9EA8BD;--text-inverse:#FFFFFF;--text-brand:#4F7EFF;--border:#E4E8F4;--border-subtle:#EEF1F8;--border-card:rgba(0,0,0,.05);--border-brand:rgba(79,126,255,.25);--border-default:#E4E8F4;--border-strong:#D0D5DD;--border-focus:#4F7EFF;--bubble-ai-bg:#ffffff;--bubble-ai-text:#1A1D2E;--bubble-user-bg:linear-gradient(135deg,#4F7EFF 0%,#7B5EFF 100%);--bubble-user-text:#FFFFFF;--shadow-xs:0 1px 2px rgba(15,23,41,.05);--shadow-sm:0 1px 3px rgba(15,23,41,.08),0 1px 2px rgba(15,23,41,.04);--shadow-card:0 1px 3px rgba(15,23,41,.06),0 1px 2px rgba(15,23,41,.04);--shadow-md:0 4px 16px rgba(15,23,41,.1),0 2px 4px rgba(15,23,41,.06);--shadow-popup:0 4px 16px rgba(15,23,41,.1),0 2px 4px rgba(15,23,41,.06);--shadow-brand:0 4px 12px rgba(79,126,255,.3),0 2px 4px rgba(79,126,255,.15);--shadow-modal:0 12px 40px rgba(15,23,41,.15),0 4px 12px rgba(15,23,41,.08);--shadow-focus:0 0 0 3px rgba(79,126,255,.2);--shadow-bubble:0 1px 3px rgba(15,23,41,.1);--shadow-dropdown:0 8px 24px rgba(15,23,41,.14),0 4px 8px rgba(15,23,41,.06);--radius-none:0px;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-chip:14px;--radius-full:9999px;--duration-instant:50ms;--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--ease-default:cubic-bezier(.4,0,.2,1);--ease-out:cubic-bezier(.16,1,.3,1);--ease-in:cubic-bezier(.4,0,1,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);--transition:var(--duration-normal)var(--ease-out)}@media(prefers-color-scheme:dark){:root{--brand:#6B8AFF;--brand-deep:#A78BFA;--brand-light:rgba(107,138,255,.12);--brand-glow:rgba(107,138,255,.2);--brand-400:#6B8AFF;--brand-500:#6B8AFF;--brand-600:#A78BFA;--success:#34D399;--success-bg:rgba(52,211,153,.1);--warning:#FBBF24;--warning-bg:rgba(251,191,36,.1);--danger:#F87171;--danger-bg:rgba(248,113,113,.1);--info:#6B8AFF;--info-bg:rgba(107,138,255,.1);--text-primary:#F0F2F8;--text:#E5E7EF;--text-secondary:#9EA8BD;--text-tertiary:#6B7280;--text-inverse:#FFFFFF;--text-brand:#6B8AFF;--border:#2E2E3A;--border-subtle:#252530;--border-card:rgba(255,255,255,.05);--border-brand:rgba(107,138,255,.3);--bg-base:#111118;--bg-surface:#111118;--bg-card:#1C1C24;--bg-subtle:#252530;--bg-glass:rgba(28,28,36,.85);--bg-primary:#1C1C24;--bg-secondary:#111118;--bg-tertiary:#252530;--bubble-ai-bg:#1C1C24;--bubble-ai-text:#E5E7EF;--shadow-xs:0 1px 2px rgba(0,0,0,.25);--shadow-sm:0 1px 3px rgba(0,0,0,.3),0 1px 2px rgba(0,0,0,.2);--shadow-card:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15);--shadow-md:0 4px 16px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-popup:0 4px 16px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-brand:0 4px 12px rgba(107,138,255,.25),0 2px 4px rgba(107,138,255,.15);--shadow-modal:0 12px 40px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.25);--shadow-focus:0 0 0 3px rgba(107,138,255,.3)}}[data-theme=dark]{--brand:#6B8AFF;--brand-deep:#A78BFA;--brand-light:rgba(107,138,255,.12);--brand-glow:rgba(107,138,255,.2);--brand-400:#6B8AFF;--brand-500:#6B8AFF;--brand-600:#A78BFA;--success:#34D399;--success-bg:rgba(52,211,153,.1);--warning:#FBBF24;--warning-bg:rgba(251,191,36,.1);--danger:#F87171;--danger-bg:rgba(248,113,113,.1);--info:#6B8AFF;--info-bg:rgba(107,138,255,.1);--text-primary:#F0F2F8;--text:#E5E7EF;--text-secondary:#9EA8BD;--text-tertiary:#6B7280;--text-inverse:#FFFFFF;--text-brand:#6B8AFF;--border:#2E2E3A;--border-subtle:#252530;--border-card:rgba(255,255,255,.05);--border-brand:rgba(107,138,255,.3);--bg-base:#111118;--bg-surface:#111118;--bg-card:#1C1C24;--bg-subtle:#252530;--bg-glass:rgba(28,28,36,.85);--bg-primary:#1C1C24;--bg-secondary:#111118;--bg-tertiary:#252530;--bubble-ai-bg:#1C1C24;--bubble-ai-text:#E5E7EF;--shadow-xs:0 1px 2px rgba(0,0,0,.25);--shadow-sm:0 1px 3px rgba(0,0,0,.3),0 1px 2px rgba(0,0,0,.2);--shadow-card:0 1px 3px rgba(0,0,0,.2),0 1px 2px rgba(0,0,0,.15);--shadow-md:0 4px 16px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-popup:0 4px 16px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);--shadow-brand:0 4px 12px rgba(107,138,255,.25),0 2px 4px rgba(107,138,255,.15);--shadow-modal:0 12px 40px rgba(0,0,0,.4),0 4px 12px rgba(0,0,0,.25);--shadow-focus:0 0 0 3px rgba(107,138,255,.3)}:root{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,SF Pro Text,Helvetica Neue,Microsoft YaHei,sans-serif;font-size:15px;line-height:1.55;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--text-xs: 11px;--text-sm: 13px;--text-md: 15px;--text-lg: 16px;--text-xl: 18px;--text-2xl: 20px;--text-3xl: 24px;--text-kpi: 28px;--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;--brand: #4F7EFF;--brand-500: #4F7EFF;--brand-deep: #7B5EFF;--brand-light: rgba(79,126,255,.1);--brand-glow: rgba(79,126,255,.25);--success: #00C48C;--success-bg: #E8FBF4;--warning: #FF9500;--warning-bg: #FFF7E6;--danger: #FF4757;--danger-bg: #FFF0F0;--info: #4F7EFF;--info-bg: #EEF3FF;--text-primary: #0F1729;--text: #1A1D2E;--text-secondary: #5A6379;--text-tertiary: #9EA8BD;--text-inverse: #FFFFFF;--text-brand: #4F7EFF;--border: #E4E8F4;--border-subtle: #EEF1F8;--border-card: rgba(0,0,0,.05);--border-brand: rgba(79,126,255,.25);--bg-base: #EEF1F8;--bg-surface: #EEF1F8;--bg-card: #ffffff;--bg-subtle: #F5F7FF;--bg-glass: rgba(255,255,255,.85);--shadow-xs: 0 1px 2px rgba(15,23,41,.05);--shadow-sm: 0 1px 3px rgba(15,23,41,.08), 0 1px 2px rgba(15,23,41,.04);--shadow-md: 0 4px 16px rgba(15,23,41,.1), 0 2px 4px rgba(15,23,41,.06);--shadow-card: 0 1px 3px rgba(15,23,41,.06), 0 1px 2px rgba(15,23,41,.04);--shadow-popup: 0 4px 16px rgba(15,23,41,.1), 0 2px 4px rgba(15,23,41,.06);--shadow-brand: 0 4px 12px rgba(79,126,255,.3), 0 2px 4px rgba(79,126,255,.15);--shadow-modal: 0 12px 40px rgba(15,23,41,.15), 0 4px 12px rgba(15,23,41,.08);--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-chip: 14px;--radius-full: 9999px;--duration-instant: 80ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--transition: var(--duration-normal) var(--ease-out);--app-topbar-height: 58px;--app-tabbar-height: 61px}@media(prefers-color-scheme:dark){:root{--brand: #6B8AFF;--brand-deep: #A78BFA;--brand-light: rgba(107,138,255,.12);--brand-glow: rgba(107,138,255,.2);--success: #34D399;--success-bg: rgba(52,211,153,.1);--warning: #FBBF24;--warning-bg: rgba(251,191,36,.1);--danger: #F87171;--danger-bg: rgba(248,113,113,.1);--info: #6B8AFF;--info-bg: rgba(107,138,255,.1);--text-primary: #F0F2F8;--text: #E5E7EF;--text-secondary: #9EA8BD;--text-tertiary: #6B7280;--text-inverse: #FFFFFF;--text-brand: #6B8AFF;--border: #2E2E3A;--border-subtle: #252530;--border-card: rgba(255,255,255,.05);--border-brand: rgba(107,138,255,.3);--bg-base: #111118;--bg-surface: #111118;--bg-card: #1C1C24;--bg-subtle: #252530;--bg-glass: rgba(28,28,36,.85);--shadow-xs: 0 1px 2px rgba(0,0,0,.25);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 16px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-card: 0 1px 3px rgba(0,0,0,.2), 0 1px 2px rgba(0,0,0,.15);--shadow-popup: 0 4px 16px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-brand: 0 4px 12px rgba(107,138,255,.25), 0 2px 4px rgba(107,138,255,.15);--shadow-modal: 0 12px 40px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.25)}}[data-theme=dark]{--brand: #6B8AFF;--brand-deep: #A78BFA;--brand-light: rgba(107,138,255,.12);--brand-glow: rgba(107,138,255,.2);--success: #34D399;--success-bg: rgba(52,211,153,.1);--warning: #FBBF24;--warning-bg: rgba(251,191,36,.1);--danger: #F87171;--danger-bg: rgba(248,113,113,.1);--info: #6B8AFF;--info-bg: rgba(107,138,255,.1);--text-primary: #F0F2F8;--text: #E5E7EF;--text-secondary: #9EA8BD;--text-tertiary: #6B7280;--text-inverse: #FFFFFF;--text-brand: #6B8AFF;--border: #2E2E3A;--border-subtle: #252530;--border-card: rgba(255,255,255,.05);--border-brand: rgba(107,138,255,.3);--bg-base: #111118;--bg-surface: #111118;--bg-card: #1C1C24;--bg-subtle: #252530;--bg-glass: rgba(28,28,36,.85);--shadow-xs: 0 1px 2px rgba(0,0,0,.25);--shadow-sm: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 16px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-card: 0 1px 3px rgba(0,0,0,.2), 0 1px 2px rgba(0,0,0,.15);--shadow-popup: 0 4px 16px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2);--shadow-brand: 0 4px 12px rgba(107,138,255,.25), 0 2px 4px rgba(107,138,255,.15);--shadow-modal: 0 12px 40px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.25)}*{box-sizing:border-box}html{height:100%;background:var(--bg-surface)}body{margin:0;height:100%;background:var(--bg-surface);overflow-x:hidden;-webkit-overflow-scrolling:touch}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button,select{cursor:pointer}input,textarea{cursor:text}button:disabled{opacity:.45;cursor:not-allowed}button,a,[role=button]{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.app-shell{display:flex;justify-content:center;min-height:100vh;min-height:100dvh;background:var(--bg-surface)}.mobile-frame{width:100%;max-width:430px;min-height:100vh;min-height:100dvh;background:var(--bg-surface);position:relative;display:flex;flex-direction:column;overflow-x:hidden}.topbar{display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;right:0;margin:0 auto;width:100%;max-width:430px;padding:calc(env(safe-area-inset-top,0px) + 6px) 16px 8px;background:#fffffff5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);z-index:100;flex-shrink:0}.topbar>*{margin-bottom:0}.topbar-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0;overflow:hidden}.topbar-brand{font-size:16px;font-weight:800;color:var(--text);letter-spacing:-.5px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.topbar-user{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%;flex-shrink:1;min-height:44px;display:inline-flex;align-items:center;padding:0 10px}.topbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-left:8px}.topbar-badge{display:inline-flex;align-items:center;justify-content:center;gap:4px;font-size:12px;color:var(--text-secondary);background:var(--bg-surface);min-height:44px;min-width:48px;padding:0 11px;border-radius:999px;font-weight:500;border:1px solid var(--border);transition:background var(--transition)}.topbar-badge.has-unread{background:var(--danger-bg);color:var(--danger);border-color:#ff475733;font-weight:600}.page-shell{flex:1;padding-top:calc(var(--app-topbar-height) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--app-tabbar-height) + env(safe-area-inset-bottom,0px));overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}.tabbar{position:fixed;bottom:0;left:0;right:0;margin:0 auto;width:100%;max-width:430px;display:flex;background:#fffffff7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(0,0,0,.06);padding-bottom:env(safe-area-inset-bottom,0px);z-index:100;overflow:hidden}.tabbar-item{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 2px 6px;color:var(--text-tertiary);font-size:10px;font-weight:500;transition:color var(--transition);position:relative;min-height:44px}.tabbar-item.router-link-active{color:var(--brand)}.tabbar-icon-wrap{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:9px;transition:background var(--transition),transform var(--transition);flex-shrink:0}.tabbar-item.router-link-active .tabbar-icon-wrap{background:var(--brand-light);transform:scale(1.05)}.tabbar-item:active .tabbar-icon-wrap{transform:scale(.92)}.tabbar-label{font-size:10px;font-weight:500;letter-spacing:.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.screen-page{padding:12px 14px 16px;display:flex;flex-direction:column;gap:12px}.card-block{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow-xs)}.card-block+.card-block{margin-top:0}.hero-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:16px;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow-sm)}.hero-title{margin:0;font-size:20px;font-weight:700;color:var(--text);line-height:1.3}.hero-subtitle{margin:6px 0 0;font-size:13px;color:var(--text-secondary);line-height:1.5}.content-card{background:var(--bg-card);border-radius:16px;padding:16px;border:1px solid var(--border)}.section-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.section-title{margin:0;font-size:15px;font-weight:600;color:var(--text)}.section-subtitle{margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.work-card{background:var(--bg-card);border-radius:var(--radius-md);padding:14px;border:1px solid rgba(0,0,0,.05);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition),transform var(--transition)}.work-card:active{transform:scale(.99);box-shadow:none}.work-card-title{margin:0;font-size:15px;font-weight:600;color:var(--text);line-height:1.4}.work-card-meta{margin:4px 0 0;font-size:12px;color:var(--text-secondary)}.work-card-body{margin-top:10px;font-size:13px;color:var(--text-secondary);line-height:1.6}.stack-list{display:flex;flex-direction:column;gap:10px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0;letter-spacing:.2px}.status-badge:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;flex-shrink:0}.status-badge.pending{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.status-badge.pending:before{background:var(--text-tertiary)}.status-badge.active{background:var(--brand-light);color:var(--brand)}.status-badge.active:before{background:var(--brand);animation:pulse-dot 1.5s ease-in-out infinite}.status-badge.done{background:var(--success-bg);color:#389e0d}.status-badge.done:before{background:var(--success)}.status-badge.warn{background:var(--warning-bg);color:var(--warning)}.status-badge.warn:before{background:var(--warning)}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.info-grid{display:flex;flex-direction:column;gap:11px}.info-row{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;font-size:13px}.info-label{color:var(--text-secondary);flex-shrink:0;word-break:normal;overflow-wrap:break-word;min-width:56px}.info-value{color:var(--text);font-weight:500;text-align:right;word-break:normal;max-width:65%;overflow-wrap:break-word;min-width:0}.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.metric-tile{background:var(--bg-surface);border-radius:12px;padding:12px}.metric-label{font-size:11px;color:var(--text-secondary)}.metric-value{margin-top:6px;font-size:22px;font-weight:700;color:var(--text);line-height:1.2}.metric-note{margin-top:4px;font-size:12px;color:var(--text-secondary);line-height:1.4;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden}.soft-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:var(--radius-sm);background:var(--brand);color:#fff;font-size:14px;font-weight:500;min-height:40px;padding:0 18px;white-space:nowrap;box-shadow:var(--shadow-brand);transition:background var(--transition),box-shadow var(--transition),transform var(--transition);-webkit-user-select:none;user-select:none}.soft-button:not(:disabled):active{transform:scale(.97);box-shadow:none;background:var(--brand-deep)}.soft-button.secondary{background:var(--brand-light);color:var(--brand);box-shadow:none;border:1px solid rgba(22,119,255,.2)}.soft-button.secondary:not(:disabled):active{background:#bae0ff}.soft-button.ghost{background:var(--bg-card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-xs)}.soft-button.ghost:not(:disabled):active{background:var(--bg-surface)}.soft-button.warn{background:var(--danger);color:#fff;box-shadow:0 4px 12px #ff4d4f40}.soft-button.sm{min-height:32px;font-size:12px;padding:0 12px;border-radius:var(--radius-sm);box-shadow:none}.action-row{display:flex;flex-wrap:wrap;gap:8px}.chip-group{display:flex;gap:8px;flex-wrap:wrap}.chip-btn{border:1px solid var(--border);border-radius:999px;background:var(--bg-card);color:var(--text-secondary);font-size:13px;padding:5px 14px;min-height:32px;font-weight:500;transition:all var(--transition);box-shadow:var(--shadow-xs)}.chip-btn:active{transform:scale(.96)}.chip-btn.active{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:var(--shadow-brand)}.timeline-list{display:flex;flex-direction:column;gap:0}.timeline-item{padding:0 0 16px 18px;border-left:2px solid var(--border);position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand);position:absolute;left:-5px;top:3px}.timeline-time{font-size:11px;color:var(--text-tertiary)}.timeline-text{margin-top:4px;font-size:13px;color:var(--text);line-height:1.5}.empty-tip{padding:20px 16px;text-align:center;color:var(--text-tertiary);font-size:13px;line-height:1.6}.muted{color:var(--text-secondary);font-size:13px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;color:var(--text-secondary);font-weight:500;letter-spacing:.1px}.field input,.field textarea,.field select{border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;background:var(--bg-subtle);font-size:15px;outline:none;resize:vertical;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition);color:var(--text)}.field input::placeholder,.field textarea::placeholder{color:var(--text-tertiary)}.field input:focus,.field textarea:focus{border-color:var(--brand);background:var(--bg-card);outline:2px solid var(--brand);outline-offset:2px}.login-screen{min-height:calc(100vh - 52px);padding:0 16px 24px;display:flex;flex-direction:column;gap:16px}.login-hero{display:flex;flex-direction:column;align-items:center;padding:40px 0 12px;gap:10px;text-align:center}.login-logo{width:60px;height:60px;border-radius:18px;background:linear-gradient(145deg,#4f9ef8,#1a6bef);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;box-shadow:0 8px 24px #1a6bef40}.login-title{margin:0;font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.5px}.login-subtitle{margin:0;font-size:13px;color:var(--text-secondary)}.chat-screen{display:flex;flex-direction:column;min-height:calc(100vh - 120px);padding:0}.chat-welcome{flex:1;display:flex;flex-direction:column;align-items:flex-start;padding:32px 20px 16px}.chat-welcome-title{font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.3px;white-space:nowrap;margin:0 0 8px}.chat-welcome-sub{font-size:14px;color:var(--text-secondary);margin:0 0 24px}.suggest-list{width:100%;display:flex;flex-direction:column;gap:8px}.suggest-item{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:13px 16px;text-align:left;font-size:14px;color:var(--text);font-weight:400;line-height:1.45;display:block;width:100%;transition:background .12s}.suggest-item:active{background:var(--bg-surface)}.chat-flow{flex:1;padding:12px 14px 0;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.message{display:flex;flex-direction:column;max-width:90%}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.msg-bubble{padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.6;word-break:normal;overflow-wrap:break-word}.message.user .msg-bubble{background:var(--brand);color:#fff;border-bottom-right-radius:4px}.message.assistant .msg-bubble{background:var(--bg-card);color:var(--text);border:1px solid var(--border);border-bottom-left-radius:4px}.msg-sender{font-size:11px;color:var(--text-tertiary);margin-bottom:5px;padding:0 2px}.message.user .msg-sender{text-align:right}.msg-card{margin-top:8px;border-radius:14px;border:1px solid var(--border);background:var(--bg-card);overflow:hidden}.msg-card-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px 8px;border-bottom:1px solid var(--border-subtle)}.msg-card-label{font-size:11px;font-weight:600;color:var(--brand);background:var(--brand-light);padding:2px 8px;border-radius:999px}.msg-card-tag{font-size:11px;color:var(--text-tertiary)}.trace-section{padding:0 14px;background:var(--bg-surface)}.trace-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:9px 0;border:none;background:none;font-size:12px;color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border-subtle);cursor:pointer}.trace-toggle-icon{font-size:10px;color:var(--text-tertiary);transition:transform .15s}.trace-toggle-icon.open{transform:rotate(90deg)}.trace-steps{padding:8px 0;display:flex;flex-direction:column;gap:8px}.trace-step-row{display:flex;gap:8px;align-items:flex-start;font-size:12px}.trace-agent-tag{flex-shrink:0;font-size:11px;font-weight:600;color:var(--brand);background:var(--brand-light);padding:1px 7px;border-radius:4px}.trace-step-text{color:var(--text-secondary);line-height:1.5;flex:1;word-break:normal;overflow-wrap:break-word}.result-section{padding:12px 14px}.ticket-result{border-radius:10px;padding:12px 14px}.ticket-result.pending{background:var(--bg-surface)}.ticket-result.active{background:linear-gradient(135deg,#dbeafe,#eff6ff)}.ticket-result.done{background:linear-gradient(135deg,#dcfce7,#f0fdf4)}.ticket-result-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 8px;line-height:1.4}.ticket-result-row{font-size:12px;color:var(--text-secondary);line-height:1.6}.report-result{background:var(--bg-surface);border-radius:10px;padding:12px 14px}.report-result-title{font-size:13px;font-weight:600;color:var(--text);margin:0 0 8px}.chat-report-card{display:flex;flex-direction:column;gap:8px;width:100%}.chat-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.chat-kpi-tile{background:var(--bg-card);border:1px solid var(--border);border-top-width:2px;border-radius:10px;padding:8px 8px 7px}.chat-kpi-label{font-size:9px;color:var(--text-secondary);font-weight:500;margin-bottom:2px}.chat-kpi-value{font-size:16px;font-weight:800;color:var(--text);line-height:1.2;letter-spacing:-.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-kpi-unit{font-size:9px;font-weight:500;color:var(--text-secondary);margin-left:1px;flex-shrink:0}.chat-kpi-trend{font-size:10px;font-weight:600;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-kpi-trend.up{color:#16a34a}.chat-kpi-trend.down{color:#dc2626}.chat-kpi-trend.flat{color:var(--text-secondary)}.chat-kpi-trend.warn{color:#d97706}.chat-broadcast-block{background:linear-gradient(135deg,var(--bg-surface) 0%,rgba(123,94,255,.04) 100%);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.chat-broadcast-header{display:flex;align-items:center;gap:5px;margin-bottom:5px}.chat-broadcast-tag{font-size:9px;font-weight:700;color:#6366f1;text-transform:uppercase;letter-spacing:.5px}.chat-broadcast-body{display:flex;flex-direction:column;gap:0}.chat-broadcast-line{display:block;font-size:12px;color:var(--text);line-height:1.75;padding:5px 0 5px 10px;border-left:2px solid var(--border);margin-bottom:6px;overflow-wrap:break-word;word-break:normal}.chat-broadcast-line--first{font-weight:600;color:var(--brand);border-left-color:var(--brand)}.chat-broadcast-line:last-child{margin-bottom:0}.chat-broadcast-para{display:block;margin:0 0 8px;line-height:1.75}.chat-report-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.chat-report-section.notices .chat-report-line{background:var(--warning-bg);border-left-color:var(--warning)}.chat-report-sec-title{font-size:11px;font-weight:600;color:var(--text);padding:7px 10px 6px;background:var(--bg-surface);border-bottom:1px solid var(--border)}.chat-report-line{font-size:11px;color:var(--text-secondary);line-height:1.55;padding:5px 10px 5px 12px;border-left:2px solid var(--border)}.chat-report-line.first{color:var(--text);font-weight:500;border-left-color:var(--brand)}.chat-report-line.notice{border-left-color:var(--warning)}.report-result-list{margin:0;padding:0 0 0 16px;display:flex;flex-direction:column;gap:5px}.report-result-list li{font-size:12px;color:var(--text-secondary);line-height:1.5}.query-result-title{font-size:13px;font-weight:600;color:var(--text);margin:0 0 8px}.msg-actions{display:flex;gap:14px;margin-top:6px;padding:0 2px}.msg-action-btn{border:none;background:none;font-size:12px;color:var(--text-tertiary);padding:0;min-height:auto}.msg-action-btn.active{color:var(--brand);font-weight:600}.composer{position:sticky;bottom:0;background:#fffffff7;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(0,0,0,.06);padding:10px 14px;z-index:50}.feature-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px;scrollbar-width:none}.feature-chips::-webkit-scrollbar{display:none}.feature-chip{flex-shrink:0;border:1px solid var(--border);border-radius:999px;background:var(--bg-surface);color:var(--text-secondary);font-size:12px;font-weight:500;padding:5px 12px;min-height:30px;white-space:nowrap}.feature-chip.active{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.feature-chip.muted{border-color:var(--border);color:var(--text-tertiary);background:var(--bg-subtle)}.input-row{display:flex;align-items:center;gap:8px;background:var(--bg-surface);border-radius:16px;padding:10px 12px;border:1px solid var(--border);min-height:48px}.input-row:focus-within{border-color:var(--brand)}.input-side-btn{flex-shrink:0;width:36px;height:36px;border:none;border-radius:10px;background:var(--bg-subtle);color:var(--text-secondary);font-size:18px;display:flex;align-items:center;justify-content:center;padding:0;min-height:auto;transition:background .2s,color .2s;align-self:flex-end}.input-side-btn.mic-requesting{color:var(--brand);background:#6366f114}.input-side-btn.mic-active{color:#dc2626;background:#dc262614;border-radius:50%}@keyframes mic-blink{0%,to{opacity:1}50%{opacity:.3}}.mic-live{animation:mic-blink 1s ease-in-out infinite;display:inline-block}.voice-error-tip{font-size:12px;color:#dc2626;padding:4px 8px;text-align:center;background:#dc26260f;border-radius:8px;margin-top:4px}.chat-textarea{flex:1;border:none;background:transparent;resize:none;font-size:15px;line-height:1.5;color:var(--text);padding:4px 0;max-height:100px;min-height:26px;outline:none;vertical-align:middle}.chat-textarea::placeholder{color:var(--text-tertiary)}.send-btn{flex-shrink:0;width:36px;height:36px;border:none;border-radius:10px;background:var(--brand);color:#fff;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;padding:0;min-height:auto;transition:background .15s,transform .1s;align-self:flex-end}.send-btn:active:not(:disabled){transform:scale(.95)}.send-btn:disabled{background:var(--bg-surface);color:var(--text-tertiary);opacity:1}.voice-bar{width:100%;height:52px;border-radius:14px;border:none;background:var(--brand);color:#fff;font-size:16px;font-weight:600;letter-spacing:.3px}.nav-badge{font-size:12px;color:var(--brand);background:var(--brand-light);padding:4px 10px;border-radius:999px;font-weight:500}.report-list{margin:0;padding:0 0 0 16px;display:flex;flex-direction:column;gap:6px}.report-list li{font-size:13px;color:var(--text-secondary);line-height:1.55}.hero-eyebrow{font-size:11px;font-weight:600;color:var(--brand);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}@media(min-width:431px){.mobile-frame{min-height:900px;box-shadow:0 0 0 1px #0000000f,0 20px 60px #0000001a}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
