.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: #167A73;--brand-deep: #256D85;--brand-light: rgba(22,122,115,.1);--brand-glow: rgba(22,122,115,.18);--brand-50: rgba(22,122,115,.05);--brand-100: rgba(22,122,115,.1);--brand-200: rgba(22,122,115,.2);--brand-300: rgba(22,122,115,.34);--brand-400: #1A8F86;--brand-500: #167A73;--brand-600: #0F5F59;--brand-700: #0B4F4A;--gray-50: #F8FBFA;--gray-100: #F2F6F5;--gray-200: #EDF3F1;--gray-300: #DDE7E3;--gray-400: #B8C6C1;--gray-500: #8C9D97;--gray-600: #66756F;--gray-700: #3F4F4A;--gray-800: #24302D;--gray-900: #17211F;--success: #12966F;--success-bg: #EAF7F2;--success-500: #12966F;--warning: #B7791F;--warning-bg: #FFF8E8;--warning-500: #B7791F;--danger: #D14343;--danger-bg: #FFF1F0;--danger-500: #D14343;--error: #D14343;--error-500: #D14343;--info: #256D85;--info-bg: #EAF4F7;--info-500: #256D85;--bg-base: #F2F6F5;--bg-surface: #F4F7F6;--bg-card: #FFFFFF;--bg-subtle: #EEF4F2;--bg-glass: rgba(255,255,255,.92);--bg-glass-strong: rgba(255,255,255,.97);--overlay-scrim: rgba(0,0,0,.45);--bg-primary: #FFFFFF;--bg-secondary: #F4F7F6;--bg-tertiary: #EEF4F2;--text-primary: #17211F;--text: #24302D;--text-secondary: #66756F;--text-tertiary: #9AA7A2;--text-inverse: #FFFFFF;--text-brand: #167A73;--border: #DDE7E3;--border-subtle: #EDF3F1;--border-card: rgba(23,33,31,.08);--border-brand: rgba(22,122,115,.25);--border-default: #DDE7E3;--border-strong: #B8C6C1;--border-focus: #167A73;--bubble-ai-bg: #FFFFFF;--bubble-ai-text: #24302D;--bubble-user-bg: var(--brand);--bubble-user-text: #FFFFFF;--shadow-xs: 0 1px 2px rgba(23,33,31,.04);--shadow-sm: 0 1px 4px rgba(23,33,31,.07);--shadow-card: 0 1px 4px rgba(23,33,31,.06);--shadow-md: 0 8px 24px rgba(23,33,31,.1);--shadow-popup: 0 10px 28px rgba(23,33,31,.12);--shadow-brand: 0 6px 16px rgba(22,122,115,.24);--shadow-modal: 0 16px 48px rgba(23,33,31,.16);--shadow-focus: 0 0 0 3px rgba(22,122,115,.2);--shadow-bubble: 0 1px 3px rgba(23,33,31,.1);--shadow-dropdown: 0 8px 24px rgba(23,33,31,.14), 0 4px 8px rgba(23,33,31,.06);--radius-none: 0px;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--radius-chip: 14px;--radius-full: 9999px;--duration-instant: 80ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .35s;--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-in-out: cubic-bezier(.4,0,.2,1);--ease-spring: cubic-bezier(.34,1.56,.64,1);--transition: var(--duration-normal) var(--ease-out)}@media(prefers-color-scheme:dark){:root{--brand: #4DB6A8;--brand-deep: #6BB6D3;--brand-light: rgba(77,182,168,.14);--brand-glow: rgba(77,182,168,.2);--brand-50: rgba(77,182,168,.08);--brand-100: rgba(77,182,168,.14);--brand-200: rgba(77,182,168,.22);--brand-300: rgba(77,182,168,.34);--brand-400: #66C8BA;--brand-500: #4DB6A8;--brand-600: #36A094;--brand-700: #26887E;--success: #5DD6A8;--success-bg: rgba(93,214,168,.12);--warning: #F2B84B;--warning-bg: rgba(242,184,75,.12);--danger: #FF8A80;--danger-bg: rgba(255,138,128,.12);--error: #FF8A80;--error-500: #FF8A80;--info: #77C6DA;--info-bg: rgba(119,198,218,.12);--text-primary: #F0F6F4;--text: #DDE8E5;--text-secondary: #A7B8B3;--text-tertiary: #71827D;--text-inverse: #FFFFFF;--text-brand: #4DB6A8;--border: #2C3B38;--border-subtle: #22302E;--border-card: rgba(255,255,255,.05);--border-brand: rgba(77,182,168,.32);--border-default: #2C3B38;--border-strong: #4B5F5A;--border-focus: #4DB6A8;--bg-base: #101817;--bg-surface: #101817;--bg-card: #182422;--bg-subtle: #22302E;--bg-glass: rgba(24,36,34,.88);--bg-glass-strong: rgba(24,36,34,.96);--overlay-scrim: rgba(0,0,0,.56);--bg-primary: #182422;--bg-secondary: #101817;--bg-tertiary: #22302E;--bubble-ai-bg: #182422;--bubble-ai-text: #DDE8E5;--bubble-user-bg: var(--brand);--shadow-brand: 0 4px 12px rgba(77,182,168,.24), 0 2px 4px rgba(77,182,168,.14);--shadow-focus: 0 0 0 3px rgba(77,182,168,.28)}}[data-theme=dark]{--brand: #4DB6A8;--brand-deep: #6BB6D3;--brand-light: rgba(77,182,168,.14);--brand-glow: rgba(77,182,168,.2);--brand-50: rgba(77,182,168,.08);--brand-100: rgba(77,182,168,.14);--brand-200: rgba(77,182,168,.22);--brand-300: rgba(77,182,168,.34);--brand-400: #66C8BA;--brand-500: #4DB6A8;--brand-600: #36A094;--brand-700: #26887E;--success: #5DD6A8;--success-bg: rgba(93,214,168,.12);--warning: #F2B84B;--warning-bg: rgba(242,184,75,.12);--danger: #FF8A80;--danger-bg: rgba(255,138,128,.12);--error: #FF8A80;--error-500: #FF8A80;--info: #77C6DA;--info-bg: rgba(119,198,218,.12);--text-primary: #F0F6F4;--text: #DDE8E5;--text-secondary: #A7B8B3;--text-tertiary: #71827D;--text-inverse: #FFFFFF;--text-brand: #4DB6A8;--border: #2C3B38;--border-subtle: #22302E;--border-card: rgba(255,255,255,.05);--border-brand: rgba(77,182,168,.32);--border-default: #2C3B38;--border-strong: #4B5F5A;--border-focus: #4DB6A8;--bg-base: #101817;--bg-surface: #101817;--bg-card: #182422;--bg-subtle: #22302E;--bg-glass: rgba(24,36,34,.88);--bg-glass-strong: rgba(24,36,34,.96);--overlay-scrim: rgba(0,0,0,.56);--bg-primary: #182422;--bg-secondary: #101817;--bg-tertiary: #22302E;--bubble-ai-bg: #182422;--bubble-ai-text: #DDE8E5;--bubble-user-bg: var(--brand);--shadow-brand: 0 4px 12px rgba(77,182,168,.24), 0 2px 4px rgba(77,182,168,.14);--shadow-focus: 0 0 0 3px rgba(77,182,168,.28)}: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: #167A73;--brand-500: #167A73;--brand-deep: #256D85;--brand-light: rgba(22,122,115,.1);--brand-glow: rgba(22,122,115,.18);--success: #12966F;--success-bg: #EAF7F2;--warning: #B7791F;--warning-bg: #FFF8E8;--danger: #D14343;--danger-bg: #FFF1F0;--info: #256D85;--info-bg: #EAF4F7;--text-primary: #17211F;--text: #24302D;--text-secondary: #66756F;--text-tertiary: #9AA7A2;--text-inverse: #FFFFFF;--text-brand: #167A73;--border: #DDE7E3;--border-subtle: #EDF3F1;--border-card: rgba(23,33,31,.08);--border-brand: rgba(22,122,115,.25);--bg-base: #F2F6F5;--bg-surface: #F4F7F6;--bg-card: #ffffff;--bg-subtle: #EEF4F2;--bg-glass: rgba(255,255,255,.92);--bg-glass-strong: rgba(255,255,255,.97);--overlay-scrim: rgba(0,0,0,.45);--shadow-xs: 0 1px 2px rgba(23,33,31,.04);--shadow-sm: 0 1px 4px rgba(23,33,31,.07);--shadow-md: 0 8px 24px rgba(23,33,31,.1);--shadow-card: 0 1px 4px rgba(23,33,31,.06);--shadow-popup: 0 10px 28px rgba(23,33,31,.12);--shadow-brand: 0 6px 16px rgba(22,122,115,.24);--shadow-modal: 0 16px 48px rgba(23,33,31,.16);--radius-xs: 4px;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--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: 77px}@media(prefers-color-scheme:dark){:root{--brand: #4DB6A8;--brand-deep: #6BB6D3;--brand-light: rgba(77,182,168,.14);--brand-glow: rgba(77,182,168,.2);--success: #5DD6A8;--success-bg: rgba(93,214,168,.12);--warning: #F2B84B;--warning-bg: rgba(242,184,75,.12);--danger: #FF8A80;--danger-bg: rgba(255,138,128,.12);--info: #77C6DA;--info-bg: rgba(119,198,218,.12);--text-primary: #F0F6F4;--text: #DDE8E5;--text-secondary: #A7B8B3;--text-tertiary: #71827D;--text-inverse: #FFFFFF;--text-brand: #4DB6A8;--border: #2C3B38;--border-subtle: #22302E;--border-card: rgba(255,255,255,.05);--border-brand: rgba(77,182,168,.32);--bg-base: #101817;--bg-surface: #101817;--bg-card: #182422;--bg-subtle: #22302E;--bg-glass: rgba(24,36,34,.88);--bg-glass-strong: rgba(24,36,34,.96);--overlay-scrim: rgba(0,0,0,.56);--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(77,182,168,.24), 0 2px 4px rgba(77,182,168,.14);--shadow-modal: 0 12px 40px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.25)}}[data-theme=dark]{--brand: #4DB6A8;--brand-deep: #6BB6D3;--brand-light: rgba(77,182,168,.14);--brand-glow: rgba(77,182,168,.2);--success: #5DD6A8;--success-bg: rgba(93,214,168,.12);--warning: #F2B84B;--warning-bg: rgba(242,184,75,.12);--danger: #FF8A80;--danger-bg: rgba(255,138,128,.12);--info: #77C6DA;--info-bg: rgba(119,198,218,.12);--text-primary: #F0F6F4;--text: #DDE8E5;--text-secondary: #A7B8B3;--text-tertiary: #71827D;--text-inverse: #FFFFFF;--text-brand: #4DB6A8;--border: #2C3B38;--border-subtle: #22302E;--border-card: rgba(255,255,255,.05);--border-brand: rgba(77,182,168,.32);--bg-base: #101817;--bg-surface: #101817;--bg-card: #182422;--bg-subtle: #22302E;--bg-glass: rgba(24,36,34,.88);--bg-glass-strong: rgba(24,36,34,.96);--overlay-scrim: rgba(0,0,0,.56);--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(77,182,168,.24), 0 2px 4px rgba(77,182,168,.14);--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);color:var(--text);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:linear-gradient(180deg,color-mix(in srgb,var(--bg-surface) 92%,var(--brand) 8%) 0%,var(--bg-surface) 38%,var(--bg-base) 100%)}.mobile-frame{width:100%;max-width:430px;min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,var(--bg-glass) 0%,transparent 190px),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:var(--bg-glass-strong);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border);box-shadow:0 1px color-mix(in srgb,var(--bg-card) 70%,transparent);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-primary);letter-spacing:0;display:inline-flex;align-items:center;gap:6px}.topbar-brand:before{content:"";width:8px;height:8px;border-radius:3px;background:var(--brand);box-shadow:0 0 0 4px var(--brand-light)}.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;border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-subtle)}.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-glass);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:color-mix(in srgb,var(--danger) 20%,transparent);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;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--brand) 25%,transparent) transparent}.tabbar{position:fixed;bottom:0;left:0;right:0;margin:0 auto;width:100%;max-width:430px;display:flex;flex-direction:column;background:var(--bg-glass-strong);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--border);box-shadow:0 -8px 26px color-mix(in srgb,var(--text) 8%,transparent);padding-bottom:env(safe-area-inset-bottom,0px);z-index:100;overflow:hidden}.tabbar-items{width:100%;display:flex}.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-icp{width:100%;padding:0 8px 5px;color:var(--text-tertiary);font-size:10px;line-height:1.2;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tabbar-icp:active{color:var(--brand)}.app-icp-fallback{position:fixed;left:0;right:0;bottom:calc(4px + env(safe-area-inset-bottom,0px));z-index:90;width:100%;max-width:430px;margin:0 auto;padding:4px 10px;color:var(--text-tertiary);font-size:10px;line-height:1.2;text-align:center;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:auto}.app-icp-fallback:active,.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);box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--brand) 14%,transparent)}.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:14px 14px 18px;display:flex;flex-direction:column;gap:14px}.card-block{background:var(--bg-card);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-card);box-shadow:var(--shadow-card)}.card-block+.card-block{margin-top:0}.hero-card{background:var(--bg-card);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border-card);box-shadow:var(--shadow-card);position:relative;overflow:hidden}.hero-card:before{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--brand)}.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:var(--radius-md);padding:16px;border:1px solid var(--border-card);box-shadow:var(--shadow-card)}.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 var(--border-card);box-shadow:var(--shadow-card);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:var(--success)}.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-subtle);border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border-subtle)}.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:var(--text-inverse);font-size:14px;font-weight:500;min-height:40px;padding:0 18px;white-space:nowrap;box-shadow:none;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 var(--border-brand)}.soft-button.secondary:not(:disabled):active{background:color-mix(in srgb,var(--brand) 16%,transparent)}.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:var(--text-inverse);box-shadow:none}.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-glass);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:var(--text-inverse);border-color:var(--brand);box-shadow:none}.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,var(--brand) 0%,var(--brand-deep) 100%);color:var(--text-inverse);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;box-shadow:var(--shadow-brand)}.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:var(--text-inverse);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:var(--info-bg)}.ticket-result.done{background:var(--success-bg)}.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:var(--success)}.chat-kpi-trend.down{color:var(--danger)}.chat-kpi-trend.flat{color:var(--text-secondary)}.chat-kpi-trend.warn{color:var(--warning)}.chat-broadcast-block{background:var(--bg-surface);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:var(--brand);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:var(--bg-glass-strong);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--border-card);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:var(--brand-light)}.input-side-btn.mic-active{color:var(--danger);background:var(--danger-bg);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:var(--danger);padding:4px 8px;text-align:center;background:var(--danger-bg);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:var(--text-inverse);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:var(--text-inverse);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 var(--border-card),0 20px 60px color-mix(in srgb,var(--text) 10%,transparent)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
