@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary: #3B82F6;--color-primary-hover: #2563EB;--color-primary-light: #EFF6FF;--color-primary-bg: #DBEAFE;--bg-body: #F8FAFC;--bg-sidebar: #FFFFFF;--bg-card: #FFFFFF;--bg-card-hover: #F1F5F9;--bg-input: #F1F5F9;--border-default: #E2E8F0;--border-light: #F1F5F9;--text-primary: #0F172A;--text-secondary: #64748B;--text-tertiary: #94A3B8;--text-on-primary: #FFFFFF;--color-success: #22C55E;--color-success-light: #F0FDF4;--color-warning: #F59E0B;--color-warning-light: #FFFBEB;--color-danger: #EF4444;--color-danger-light: #FEF2F2;--chart-1: #3B82F6;--chart-2: #60A5FA;--chart-3: #93C5FD;--chart-4: #BFDBFE;--chart-5: #DBEAFE;--chart-fill: rgba(59, 130, 246, .08);--shadow-card: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--shadow-card-hover: 0 4px 12px rgba(0, 0, 0, .08);--shadow-dropdown: 0 10px 30px rgba(0, 0, 0, .1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--bg-body: #0F172A;--bg-sidebar: #1E293B;--bg-card: #1E293B;--bg-card-hover: #334155;--bg-input: #334155;--border-default: #334155;--border-light: #1E293B;--text-primary: #F8FAFC;--text-secondary: #94A3B8;--text-tertiary: #64748B;--shadow-card: 0 1px 3px rgba(0, 0, 0, .2);--shadow-card-hover: 0 4px 12px rgba(0, 0, 0, .3);--chart-fill: rgba(59, 130, 246, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100vh;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-slow),color var(--transition-slow)}a{color:inherit;text-decoration:none}.text-display{font-size:32px;font-weight:700;line-height:1.2;letter-spacing:-.02em}.text-heading-1{font-size:22px;font-weight:600;line-height:1.3}.text-heading-2{font-size:18px;font-weight:600;line-height:1.4}.text-heading-3{font-size:15px;font-weight:600;line-height:1.4}.text-body{font-size:14px;font-weight:400;line-height:1.5}.text-caption{font-size:12px;font-weight:500;line-height:1.4}.text-small{font-size:11px;font-weight:400;line-height:1.3}.data-value{font-variant-numeric:tabular-nums}.w-full{width:100%}.fullscreen-center{min-height:100vh;display:grid;place-items:center}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.app-layout{display:flex;min-height:100vh}.app-sidebar{width:var(--sidebar-width);min-height:100vh;position:fixed;top:0;left:0;z-index:30;background:var(--bg-sidebar);border-right:1px solid var(--border-default);display:flex;flex-direction:column;padding:20px 14px;gap:6px;overflow-y:auto;transition:width var(--transition-base),background var(--transition-slow)}.app-sidebar.collapsed{width:var(--sidebar-collapsed-width)}.app-sidebar.collapsed .sidebar-label,.app-sidebar.collapsed .sidebar-section-title,.app-sidebar.collapsed .sidebar-brand-text,.app-sidebar.collapsed .sidebar-chevron,.app-sidebar.collapsed .sidebar-badge,.app-sidebar.collapsed .sidebar-children,.app-sidebar.collapsed .theme-toggle{display:none}.app-sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:10px}.app-sidebar.collapsed .sidebar-brand{justify-content:center;padding:14px 0}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;transition:margin-left var(--transition-base)}.app-sidebar.collapsed~.app-main,.collapsed-layout .app-main{margin-left:var(--sidebar-collapsed-width)}.app-topbar{height:72px;padding:0 var(--space-xl);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);background:var(--bg-card);border-bottom:1px solid var(--border-default);position:sticky;top:0;z-index:20;transition:background var(--transition-slow)}.app-content{flex:1;padding:var(--space-lg) var(--space-xl) var(--space-2xl)}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:8px 12px 18px}.sidebar-brand-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary),#1D4ED8);display:grid;place-items:center;color:#fff;font-size:18px;flex-shrink:0}.sidebar-brand-text{overflow:hidden}.sidebar-brand-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap}.sidebar-brand-caption{font-size:11px;color:var(--text-tertiary);white-space:nowrap}.sidebar-section-title{font-size:11px;font-weight:500;color:var(--text-tertiary);letter-spacing:.05em;text-transform:uppercase;padding:16px 12px 6px;white-space:nowrap}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);font-size:14px;font-weight:400;transition:background var(--transition-fast),color var(--transition-fast);-webkit-user-select:none;user-select:none;text-decoration:none;position:relative;white-space:nowrap}.sidebar-nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--color-primary-light);color:var(--color-primary);font-weight:500}[data-theme=dark] .sidebar-nav-item.active{background:#3b82f626}.sidebar-nav-icon{width:20px;height:20px;flex-shrink:0;stroke-width:1.5}.sidebar-label{flex:1;overflow:hidden;text-overflow:ellipsis}.sidebar-chevron{width:16px;height:16px;color:var(--text-tertiary);transition:transform var(--transition-fast);flex-shrink:0}.sidebar-chevron.open{transform:rotate(180deg)}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:var(--radius-full);background:var(--color-danger);color:#fff;font-size:11px;font-weight:600}.sidebar-children{padding-left:42px;display:flex;flex-direction:column;gap:2px}.sidebar-children .sidebar-nav-item{font-size:13px;padding:7px 12px}.sidebar-nav-item.disabled{opacity:.45;cursor:not-allowed;pointer-events:auto}.sidebar-nav-item.disabled:hover{background:transparent;color:var(--text-secondary)}.sidebar-coming-soon{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);background:var(--bg-input);padding:2px 6px;border-radius:var(--radius-full);white-space:nowrap;margin-left:auto}.sidebar-bottom{margin-top:auto;padding-top:var(--space-md);border-top:1px solid var(--border-default)}.theme-toggle{display:flex;align-items:center;gap:4px;padding:4px;background:var(--bg-input);border-radius:var(--radius-full);margin:8px 8px 4px}.theme-toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;border:none;border-radius:var(--radius-full);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);font-family:inherit}.theme-toggle-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #00000014}.topbar-title{font-size:20px;font-weight:600;color:var(--text-primary)}.topbar-right{display:flex;align-items:center;gap:var(--space-md)}.search-input{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-input);border-radius:var(--radius-full);border:1px solid transparent;min-width:220px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61a}.search-input input{border:none;outline:none;background:transparent;font-size:14px;color:var(--text-primary);width:100%;font-family:inherit}.search-input input::placeholder{color:var(--text-tertiary)}.search-input-icon{color:var(--text-tertiary);flex-shrink:0}.topbar-icon-btn{width:40px;height:40px;border-radius:var(--radius-full);border:none;background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--text-secondary);transition:background var(--transition-fast);position:relative;font-family:inherit}.topbar-icon-btn:hover{background:var(--bg-card-hover)}.topbar-notif-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:var(--color-danger);border:2px solid var(--bg-card)}.topbar-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px;cursor:pointer}.topbar-user-chip{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition-fast)}.topbar-user-chip:hover{background:var(--bg-card-hover)}.topbar-user-name{font-size:13px;font-weight:500;color:var(--text-primary)}.topbar-user-role{font-size:11px;color:var(--text-secondary)}.kpi-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);transition:box-shadow var(--transition-fast),transform var(--transition-fast),background var(--transition-slow);display:flex;flex-direction:column;gap:4px;height:100%}.kpi-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.kpi-card__icon{width:42px;height:42px;border-radius:var(--radius-md);display:grid;place-items:center;margin-bottom:8px;flex-shrink:0}.kpi-card__icon svg{width:22px;height:22px;stroke-width:1.5}.kpi-card__icon--blue{background:var(--color-primary-light);color:var(--color-primary)}.kpi-card__icon--green{background:var(--color-success-light);color:var(--color-success)}.kpi-card__icon--amber{background:var(--color-warning-light);color:var(--color-warning)}.kpi-card__icon--red{background:var(--color-danger-light);color:var(--color-danger)}.kpi-card__label{font-size:13px;color:var(--text-secondary);font-weight:400}.kpi-card__value{font-size:28px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:-.02em;line-height:1.2;margin:2px 0}.kpi-card__trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;margin-top:2px}.kpi-card__trend--up{color:var(--color-success)}.kpi-card__trend--down{color:var(--color-danger)}.kpi-card__trend--flat{color:var(--text-tertiary)}.kpi-card__trend-label{color:var(--text-tertiary);font-weight:400}.chart-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-lg);height:100%;display:flex;flex-direction:column;transition:background var(--transition-slow)}.chart-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.chart-card__title{font-size:16px;font-weight:600;color:var(--text-primary)}.chart-card__more{width:28px;height:28px;border-radius:var(--radius-full);border:none;background:transparent;cursor:pointer;color:var(--text-tertiary);display:grid;place-items:center;transition:background var(--transition-fast);font-family:inherit}.chart-card__more:hover{background:var(--bg-card-hover)}.chart-card__body{flex:1;min-height:0}.chart-card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-light)}.view-report-link{font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:4px;transition:color var(--transition-fast)}.view-report-link:hover{color:var(--color-primary)}.period-toggle{display:flex;gap:2px;padding:3px;background:var(--bg-input);border-radius:var(--radius-sm)}.period-toggle__btn{padding:5px 14px;border:none;border-radius:var(--radius-sm);background:transparent;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:background var(--transition-fast),color var(--transition-fast)}.period-toggle__btn.active{background:var(--color-primary);color:#fff}.period-toggle__btn:hover:not(.active){color:var(--text-primary)}.heatmap-grid{display:flex;flex-direction:column;gap:3px}.heatmap-row{display:flex;align-items:center;gap:3px}.heatmap-label{width:32px;font-size:11px;color:var(--text-tertiary);text-align:right;flex-shrink:0;padding-right:4px}.heatmap-cell{flex:1;aspect-ratio:1.6;min-height:14px;border-radius:3px;transition:opacity var(--transition-fast)}.heatmap-cell:hover{opacity:.8;outline:1px solid var(--color-primary)}.heatmap-x-labels{display:flex;gap:3px;padding-left:36px;margin-top:4px}.heatmap-x-labels span{flex:1;font-size:10px;color:var(--text-tertiary);text-align:center}.heatmap-legend{display:flex;align-items:center;gap:4px;margin-top:12px;justify-content:flex-end}.heatmap-legend span{font-size:10px;color:var(--text-tertiary)}.heatmap-legend-cell{width:14px;height:14px;border-radius:2px}.donut-chart-wrapper{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.donut-center-label{text-align:center}.donut-center-value{font-size:24px;font-weight:700;color:var(--text-primary)}.donut-center-text{font-size:12px;color:var(--text-secondary)}.donut-legend{display:flex;flex-direction:column;gap:8px;width:100%}.donut-legend-item{display:flex;align-items:center;gap:8px}.donut-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.donut-legend-label{flex:1;font-size:13px;color:var(--text-secondary)}.donut-legend-value{font-size:13px;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.dash-grid{display:grid;gap:var(--space-md)}.dash-grid--kpi-row{grid-template-columns:minmax(560px,840px) 1fr}.dash-grid--chart-row{grid-template-columns:1.8fr 1fr}.dash-grid--2col{grid-template-columns:1fr 1fr}.dash-grid--full{grid-template-columns:1fr}.kpi-pair{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.page-shell{display:flex;flex-direction:column;gap:var(--space-lg)}.alert-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-lg);transition:background var(--transition-slow)}.alert-list{display:flex;flex-direction:column;gap:10px}.alert-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius-md);font-size:13px;transition:background var(--transition-fast)}.alert-item:hover{background:var(--bg-card-hover)}.alert-item--critical{border-left:3px solid var(--color-danger)}.alert-item--warning{border-left:3px solid var(--color-warning)}.alert-item--info{border-left:3px solid var(--color-primary)}.alert-item__content{flex:1}.alert-item__title{font-weight:500;color:var(--text-primary);margin-bottom:2px}.alert-item__desc{color:var(--text-secondary);font-size:12px}.alert-item__meta{font-size:11px;color:var(--text-tertiary);display:flex;gap:8px;margin-top:4px}.commentary-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-lg);transition:background var(--transition-slow)}.commentary-item{margin-bottom:12px}.commentary-item:last-child{margin-bottom:0}.commentary-item__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);margin-bottom:4px}.commentary-item__text{font-size:13px;color:var(--text-primary);line-height:1.5}.mix-list{display:flex;flex-direction:column;gap:14px}.mix-item__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.mix-item__label{font-size:13px;color:var(--text-primary);font-weight:500}.mix-item__value{font-size:13px;color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.mix-item__bar{height:8px;border-radius:var(--radius-full);background:var(--bg-input);overflow:hidden}.mix-item__bar>div{height:100%;border-radius:inherit;background:var(--color-primary);transition:width .6s ease}.mix-item__delta{font-size:12px;color:var(--color-success);margin-top:4px}.filter-bar{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:12px var(--space-md);display:flex;align-items:center;gap:12px;flex-wrap:wrap;transition:background var(--transition-slow)}.filter-bar .ant-select{min-width:140px}.page-header__title{font-size:22px;font-weight:600;color:var(--text-primary)!important;margin:0 0 4px!important}.page-header__description{color:var(--text-secondary);font-size:14px}.comparison-list{display:flex;flex-direction:column;gap:14px}.comparison-item__header{display:flex;justify-content:space-between;margin-bottom:6px}.comparison-item__track{height:10px;background:var(--bg-input);border-radius:var(--radius-full);position:relative;overflow:hidden}.comparison-item__bar{position:absolute;inset:0 auto 0 0;border-radius:inherit}.comparison-item__bar--actual{background:var(--color-primary)}.comparison-item__bar--target{background:#3b82f640;clip-path:inset(2px 0 2px 0 round 999px)}.flow-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.flow-grid__item{padding:14px;border:1px solid var(--border-default);border-radius:var(--radius-lg);background:var(--bg-card)}.flow-grid__top{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px}.flow-bars{display:grid;grid-template-columns:54px 1fr;gap:8px;align-items:center}.flow-bars__label{font-size:12px;color:var(--text-secondary)}.flow-bars__track{height:8px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.flow-bars__fill{height:100%;border-radius:inherit}.flow-bars__fill--inflow{background:var(--color-success)}.flow-bars__fill--outflow{background:var(--color-danger)}.aging-list{display:flex;flex-direction:column;gap:12px}.aging-item__header{display:flex;justify-content:space-between;margin-bottom:6px}.aging-item__track{height:8px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.aging-item__fill{height:100%;border-radius:inherit}.aging-item__fill--positive{background:var(--color-success)}.aging-item__fill--warning{background:var(--color-warning)}.aging-item__fill--negative{background:var(--color-danger)}.aging-item__fill--neutral{background:var(--color-primary)}.risk-store-list{display:flex;flex-direction:column;gap:12px}.risk-store-item__header{display:flex;justify-content:space-between;margin-bottom:6px}.risk-store-item__track{height:8px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.risk-store-item__track>div{height:100%;border-radius:inherit;background:var(--color-primary)}.hero-stat{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-lg);text-align:center;transition:background var(--transition-slow)}.hero-stat__label{font-size:13px;color:var(--text-secondary);margin-bottom:4px}.hero-stat__value{font-size:32px;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums}.table-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:12px;transition:background var(--transition-slow)}.login-page{min-height:100vh;display:grid;place-items:center;background:var(--bg-body);padding:var(--space-xl)}.login-card{width:100%;max-width:420px;background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-dropdown);padding:var(--space-2xl) var(--space-xl)}.login-brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:var(--space-xl)}.login-brand-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--color-primary),#1D4ED8);display:grid;place-items:center;color:#fff;font-size:26px}.login-brand-title{font-size:20px;font-weight:700;color:var(--text-primary);text-align:center}.login-brand-subtitle{font-size:13px;color:var(--text-secondary);text-align:center}.login-form{display:flex;flex-direction:column;gap:4px}.login-demo-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:var(--space-lg)}.login-demo-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-md);border:1px solid var(--border-default);background:var(--bg-card);cursor:pointer;text-align:left;width:100%;transition:border-color var(--transition-fast),background var(--transition-fast);font-family:inherit;color:inherit}.login-demo-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.login-demo-name{font-size:13px;font-weight:500;color:var(--text-primary)}.login-demo-email{font-size:11px;color:var(--text-tertiary)}.login-demo-avatar{width:32px;height:32px;border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary);display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.login-divider{display:flex;align-items:center;gap:12px;margin:var(--space-md) 0;color:var(--text-tertiary);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-default)}.sparkline{width:100%;height:180px;margin-top:12px}.sparkline-labels{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:12px}.sparkline-labels strong{font-variant-numeric:tabular-nums}.ant-table-wrapper .ant-table{background:transparent!important}.ant-table-wrapper .ant-table-thead>tr>th,.ant-table-wrapper .ant-table-tbody>tr>td{border-bottom-color:var(--border-default)!important}.ant-alert{border-radius:var(--radius-md)!important}@media(max-width:1439px){.dash-grid--kpi-row,.dash-grid--chart-row{grid-template-columns:1fr 1fr}}@media(max-width:1199px){.app-sidebar{width:var(--sidebar-collapsed-width)}.app-sidebar .sidebar-label,.app-sidebar .sidebar-section-title,.app-sidebar .sidebar-brand-text,.app-sidebar .sidebar-chevron,.app-sidebar .sidebar-badge,.app-sidebar .sidebar-children,.app-sidebar .theme-toggle{display:none}.app-sidebar .sidebar-nav-item{justify-content:center;padding:10px}.app-sidebar .sidebar-brand{justify-content:center;padding:14px 0}.app-main{margin-left:var(--sidebar-collapsed-width)}.dash-grid--kpi-row,.dash-grid--chart-row{grid-template-columns:1fr}}@media(max-width:992px){.flow-grid,.kpi-pair{grid-template-columns:1fr}}@media(max-width:768px){.app-sidebar{display:none}.app-main{margin-left:0}.app-topbar{padding:0 var(--space-md)}.app-content{padding:var(--space-md)}.search-input{min-width:160px}.dash-grid--2col{grid-template-columns:1fr}.sparkline-labels{grid-template-columns:repeat(2,1fr)}}.chatbot-fab{position:fixed;bottom:28px;right:28px;width:56px;height:56px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),#1D4ED8);color:#fff;border:none;display:grid;place-items:center;box-shadow:0 4px 14px #3b82f666;cursor:pointer;z-index:40;transition:transform .2s cubic-bezier(.34,1.56,.64,1),background var(--transition-base)}.chatbot-fab:hover{transform:scale(1.05)}.chatbot-fab:active{transform:scale(.95)}.chatbot-fab:after{content:"";position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:var(--radius-full);border:2px solid var(--color-primary);opacity:0;animation:pulse-ring 2s cubic-bezier(.215,.61,.355,1) infinite}.chatbot-fab.open{background:var(--bg-card);color:var(--text-secondary);box-shadow:var(--shadow-card)}.chatbot-fab.open:after{display:none}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.5}80%,to{transform:scale(1.3);opacity:0}}.chatbot-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:45;opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.chatbot-backdrop.open{opacity:1;pointer-events:auto}.chatbot-panel{position:fixed;top:0;right:0;width:100%;max-width:520px;height:100vh;background:var(--bg-card);z-index:50;display:flex;flex-direction:column;box-shadow:-10px 0 40px #0000001a;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1)}.chatbot-panel.open{transform:translate(0)}.chatbot-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-default);background:var(--bg-body)}.chatbot-header-info{display:flex;align-items:center;gap:12px}.chatbot-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary),#1D4ED8);color:#fff;display:grid;place-items:center}.chatbot-name{font-size:16px;font-weight:600;color:var(--text-primary)}.chatbot-status{font-size:12px;color:var(--color-success);display:flex;align-items:center;gap:6px}.chatbot-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--color-success)}.chatbot-close-btn{width:32px;height:32px;border-radius:var(--radius-full);border:none;background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--text-tertiary);transition:background var(--transition-fast),color var(--transition-fast)}.chatbot-close-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.chatbot-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:24px;scroll-behavior:smooth}.chatbot-msg{display:flex;align-items:flex-start;gap:12px;max-width:90%}.chatbot-msg.user{align-self:flex-end;flex-direction:row-reverse}.chatbot-msg-avatar{width:32px;height:32px;border-radius:var(--radius-full);display:grid;place-items:center;flex-shrink:0}.chatbot-msg.bot .chatbot-msg-avatar{background:var(--color-primary-light);color:var(--color-primary)}[data-theme=dark] .chatbot-msg.bot .chatbot-msg-avatar{background:#3b82f626}.chatbot-msg.user .chatbot-msg-avatar{background:var(--bg-input);color:var(--text-secondary)}.chatbot-msg-content{display:flex;flex-direction:column;gap:4px}.chatbot-msg.user .chatbot-msg-content{align-items:flex-end}.chatbot-msg-bubble{padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.5;white-space:pre-wrap}.chatbot-msg.bot .chatbot-msg-bubble{background:var(--bg-input);color:var(--text-primary);border-bottom-left-radius:4px}.chatbot-msg.user .chatbot-msg-bubble{background:var(--color-primary);color:#fff;border-bottom-right-radius:4px}.chatbot-msg-time{font-size:11px;color:var(--text-tertiary);margin-top:2px}.chatbot-footer{padding:20px 24px;border-top:1px solid var(--border-default);background:var(--bg-body)}.chatbot-input-wrapper{display:flex;align-items:center;gap:12px;background:var(--bg-input);padding:8px 16px;border-radius:var(--radius-full);opacity:.6}.chatbot-input{flex:1;border:none;background:transparent;outline:none;font-family:inherit;font-size:14px;color:var(--text-primary)}.chatbot-send-btn{width:32px;height:32px;border-radius:var(--radius-full);background:transparent;border:none;color:var(--text-tertiary);display:grid;place-items:center}.chatbot-demo-text{text-align:center;font-size:11px;color:var(--text-tertiary);margin-top:12px}
