.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);text-align:center;color:var(--fg-primary, var(--text-primary));font-family:var(--font-sans);padding:var(--space-xl)}.error-boundary--fullscreen{min-height:100dvh;background:var(--bg-app, var(--bg-canvas, var(--bg-card)))}.error-boundary--scoped{flex:1 1 auto;min-height:240px;background:transparent}.error-boundary__title{font-family:var(--font-display);font-size:var(--font-lg);font-weight:var(--fw-semibold);margin:0;color:var(--fg-primary, var(--text-primary))}.error-boundary__body{color:var(--fg-muted, var(--text-secondary));max-width:42ch;margin:0;line-height:var(--leading-normal)}.error-boundary__detail{font-family:var(--font-mono);font-size:var(--font-xs);color:var(--fg-muted, var(--text-muted));background:var(--bg-subtle, transparent);border:1px solid var(--border-subtle, transparent);padding:var(--space-sm) var(--space-md);border-radius:var(--r-sm, var(--radius-md));max-width:60ch;word-break:break-word}.error-boundary__actions{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.error-boundary__btn{padding:var(--space-sm) var(--space-lg);background:transparent;color:var(--fg-primary, var(--text-primary));border:1px solid var(--border-default, var(--border-color));border-radius:var(--r-sm, var(--radius-md));font-family:inherit;font-size:var(--font-sm);font-weight:var(--fw-medium);cursor:pointer;transition:background .16s ease,border-color .16s ease}.error-boundary__btn:hover{background:var(--bg-hover)}.error-boundary__btn--primary{background:var(--brand, var(--primary));color:var(--fg-on-brand, var(--bg-surface));border-color:var(--brand, var(--primary))}.error-boundary__btn--primary:hover{background:var(--brand-hover, var(--primary-light))}.skeleton{background:linear-gradient(90deg,var(--skeleton-base) 25%,var(--skeleton-highlight) 50%,var(--skeleton-base) 75%);background-size:200% 100%;animation:ui-skeleton-shimmer var(--skeleton-shimmer-duration) ease-in-out infinite;border-radius:var(--radius-sm)}.page-skeleton{display:flex;flex-direction:column;width:100%;min-height:100%;box-sizing:border-box}.page-skeleton__header{display:flex;align-items:center;gap:var(--space-md);height:var(--header-height, 64px);min-height:var(--header-height, 64px);padding:0 var(--space-lg);background:var(--bg-canvas, var(--bg-card));border-bottom:1px solid var(--border-default, var(--border-color));box-sizing:border-box;flex-shrink:0}.page-skeleton__header-avatar{width:32px;height:32px;border-radius:var(--radius-sm);flex-shrink:0}.page-skeleton__header-title{height:18px;width:180px;border-radius:var(--radius-sm)}.page-skeleton__body{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl);flex:1 1 auto;min-height:0}@media(max-width:480px){.page-skeleton__body{padding:var(--space-lg)}}@media(prefers-reduced-motion:reduce){.skeleton{animation:none;background:var(--skeleton-base)}}.skeleton-card{padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-md)}.skeleton-card-header{display:flex;align-items:center;gap:var(--space-md)}.skeleton-card-info{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.skeleton-message{display:flex;margin-bottom:var(--space-lg)}.skeleton-message.left{justify-content:flex-start}.skeleton-message.right{justify-content:flex-end}.skeleton-field{display:flex;flex-direction:column;gap:var(--space-sm)}.profile-skeleton{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.skeleton-text{display:flex;flex-direction:column;gap:var(--space-sm);width:100%}.skeleton-list{display:flex;flex-direction:column;width:100%}.skeleton-list--gap-sm{gap:var(--space-sm)}.skeleton-list--gap-md{gap:var(--space-md)}.skeleton-list--gap-lg{gap:var(--space-lg)}.skeleton-list__row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md);min-height:64px}.skeleton-list__row-text{flex:1;display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}.skeleton-table{display:flex;flex-direction:column;width:100%;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.skeleton-table__row{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);min-height:48px;align-items:center}.skeleton-table__row:last-child{border-bottom:0}.skeleton-table__row--head{background:var(--bg-section);min-height:40px}.skeleton-form{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.skeleton-form__field{display:flex;flex-direction:column;gap:var(--space-sm)}.skeleton-form__actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm);justify-content:flex-end}@media(max-width:820px){.skeleton-form__actions{flex-direction:column-reverse;align-items:stretch}}.skeleton-dashboard{display:flex;flex-direction:column;gap:var(--space-xl);width:100%}.skeleton-dashboard__header{display:flex;flex-direction:column;gap:var(--space-sm)}.skeleton-dashboard__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md)}.skeleton-dashboard__metric{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);min-height:112px}.skeleton-dashboard__chart,.skeleton-dashboard__feed{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg)}@media(max-width:820px){.skeleton-dashboard{gap:var(--space-lg)}.skeleton-dashboard__metrics{grid-template-columns:1fr 1fr}}@media(max-width:480px){.skeleton-dashboard__metrics{grid-template-columns:1fr}}.skeleton-chat{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-lg);width:100%}.skeleton-overlay{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-md)}.tinted-loader{position:relative;pointer-events:none;background:radial-gradient(circle at 50% 50%,var(--skeleton-tint-glow) 0%,var(--skeleton-tint-bg) 45%,transparent 75%);animation:ui-tint-pulse var(--skeleton-pulse-duration) ease-in-out infinite;border-radius:var(--radius-lg)}.tinted-loader--overlay{position:absolute;inset:0;z-index:2}.tinted-loader--pane{position:relative;width:100%;min-height:160px}.tinted-loader--inline{position:relative;width:100%;height:40px;border-radius:var(--radius-pill)}@media(prefers-reduced-motion:reduce){.tinted-loader{animation:none}}.ui-breadcrumb{padding:0;min-width:0;overflow:hidden}.ui-breadcrumb__list{display:flex;align-items:baseline;gap:var(--space-xs);list-style:none;margin:0;padding:0;flex-wrap:nowrap;overflow:hidden}.ui-breadcrumb__item{display:flex;align-items:baseline;gap:var(--space-xs);flex-shrink:1;min-width:0;overflow:hidden}.ui-breadcrumb__item:not(:last-child){flex-shrink:0}.ui-breadcrumb__item:last-child{flex-shrink:2;overflow:hidden}.ui-breadcrumb__link{font-family:var(--font-mono, inherit);font-size:var(--text-xs, var(--font-sm));font-weight:var(--fw-medium);letter-spacing:var(--tracking-wide);color:var(--fg-muted, var(--text-muted));background:none;border:none;cursor:pointer;padding:2px var(--space-xs);border-radius:var(--r-sm, var(--radius-sm));white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .14s ease,color .14s ease}.ui-breadcrumb__link:hover{background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.ui-breadcrumb__link:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px}.ui-breadcrumb__current{font-family:var(--font-mono, inherit);font-size:var(--text-xs, var(--font-sm));font-weight:var(--fw-medium);letter-spacing:var(--tracking-wide);color:var(--fg-primary, var(--text-primary));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ui-breadcrumb__sep{color:var(--fg-muted, var(--text-muted));flex-shrink:0;width:12px;height:12px}.ui-breadcrumb__list--title-first .ui-breadcrumb__item:first-child .ui-breadcrumb__link{font-family:var(--font-display, var(--font-brand));font-size:var(--text-lg, 18px);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-snug);color:var(--fg-primary, var(--text-primary));padding:0;text-transform:none}.ui-breadcrumb__list--current-title .ui-breadcrumb__item:last-child .ui-breadcrumb__current{font-family:var(--font-display, var(--font-brand));font-size:var(--text-lg, 18px);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-snug);color:var(--fg-primary, var(--text-primary));text-transform:none}.ui-breadcrumb__list--header-title .ui-breadcrumb__item:first-child .ui-breadcrumb__link{font-family:var(--font-display, var(--font-brand));font-size:var(--text-lg, 18px);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-snug);color:var(--fg-primary, var(--text-primary));padding:0;text-transform:none}.toast-container{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg, var(--radius-lg));font-size:var(--text-md);font-weight:var(--fw-medium);line-height:var(--leading-normal);pointer-events:auto;min-width:280px;max-width:420px;box-shadow:var(--shadow-md);border:1px solid transparent}.toast-success{background:color-mix(in oklch,var(--success) 18%,var(--bg-elevated));color:var(--fg-success);border-color:color-mix(in oklch,var(--success) 30%,transparent)}.toast-error{background:color-mix(in oklch,var(--danger) 18%,var(--bg-elevated));color:var(--fg-danger);border-color:color-mix(in oklch,var(--danger) 30%,transparent)}.toast-warning{background:color-mix(in oklch,var(--warning) 18%,var(--bg-elevated));color:var(--fg-warning);border-color:color-mix(in oklch,var(--warning) 30%,transparent)}.toast-info{background:color-mix(in oklch,var(--info) 18%,var(--bg-elevated));color:var(--fg-link);border-color:color-mix(in oklch,var(--info) 30%,transparent)}[data-theme=light] .toast-success,[data-theme=light] .toast-error,[data-theme=light] .toast-warning,[data-theme=light] .toast-info{background:color-mix(in oklch,currentColor 10%,var(--bg-canvas))}[data-theme=light] .toast{box-shadow:var(--shadow-sm)}.toast-icon{display:flex;flex-shrink:0}.toast-message{flex:1}.toast-close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;margin:-10px -10px -10px 0;border-radius:var(--radius-sm);background:none;border:none;color:inherit;opacity:.6;cursor:pointer;flex-shrink:0}.toast-close:hover{opacity:1;background:var(--bg-hover)}.toast-close:focus-visible{outline:none;box-shadow:var(--focus-ring)}.toast-enter{animation:toastSlideIn .3s ease}.toast-exit{animation:toastSlideOut .3s ease forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-16px)}}@media(prefers-reduced-motion:reduce){.toast-enter,.toast-exit{animation:none}}.notifications-bell{position:relative}.notifications-bell__btn{position:relative;width:36px;height:36px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast)}.notifications-bell__btn:hover{background:var(--bg-hover);color:var(--text-primary)}.notifications-bell__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 var(--space-xs);background:var(--danger);color:var(--text-primary);border-radius:var(--radius-pill);font-size:var(--font-xs);font-weight:var(--fw-semibold);line-height:18px;text-align:center}.notifications-bell__panel{position:absolute;top:calc(100% + var(--space-xs));right:0;width:min(360px,calc(100vw - var(--space-md) * 2));max-height:480px;overflow-y:auto;background:var(--bg-canvas, var(--bg-elevated));border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);z-index:50}.notifications-bell__panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-canvas, var(--bg-elevated));z-index:1}.notifications-bell__panel-header h4{margin:0;font-size:var(--font-md)}.notifications-bell__mark-all{background:none;border:none;color:var(--primary-light);cursor:pointer;font-size:var(--font-sm);padding:var(--space-xs) var(--space-sm)}.notifications-bell__mark-all:hover{text-decoration:underline}.notifications-bell__tabs{display:flex;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--border-color);background:var(--bg-canvas, var(--bg-elevated))}.notifications-bell__tab{flex:1 1 auto;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);min-height:32px;padding:0 var(--space-sm);background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-muted);font-family:inherit;font-size:var(--font-sm);font-weight:var(--fw-medium);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.notifications-bell__tab:hover{background:var(--bg-hover);color:var(--text-primary)}.notifications-bell__tab:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-25)}.notifications-bell__tab.is-active{background:var(--primary-10);color:var(--primary-light);border-color:var(--primary-25)}.notifications-bell__tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--space-xs);border-radius:var(--radius-pill);background:var(--bg-hover);color:var(--text-muted);font-size:var(--font-xs);font-weight:var(--fw-semibold);line-height:var(--leading-none)}.notifications-bell__tab.is-active .notifications-bell__tab-count{background:var(--primary-25);color:var(--primary-light)}.notifications-bell__empty{padding:var(--space-md);color:var(--text-muted);margin:0;text-align:center}.notifications-bell__list{list-style:none;margin:0;padding:0}.notifications-bell__list li{border-bottom:1px solid var(--border-color)}.notifications-bell__list li:last-child{border-bottom:none}.notifications-bell__item{display:flex;flex-direction:row;align-items:center;gap:var(--space-sm);width:100%;min-height:56px;padding:var(--space-sm) var(--space-md);background:transparent;border:none;color:var(--text-primary);text-align:left;cursor:pointer;font-family:inherit}.notifications-bell__item:hover{background:var(--bg-hover)}.notifications-bell__item-icon{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--primary-10);color:var(--primary-light)}.notifications-bell__item-body{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;min-width:0}.notifications-bell__item-text{line-height:var(--leading-normal);word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:var(--font-sm)}.notifications-bell__item-text--expanded{-webkit-line-clamp:unset;line-clamp:unset;display:block}.notifications-bell__item--expanded{background:var(--bg-hover)}.notifications-bell__item small{color:var(--text-muted);font-size:var(--font-xs)}.notifications-bell__list li.is-unread .notifications-bell__item{background:var(--primary-10)}.notifications-bell__list li[data-category=social] .notifications-bell__item-icon{background:var(--primary-10);color:var(--primary-light)}.notifications-bell__list li[data-category=message] .notifications-bell__item-icon{background:#10b98126;color:var(--success)}.notifications-bell__list li[data-category=review] .notifications-bell__item-icon{background:var(--primary-15);color:var(--primary-light)}.notifications-bell__list li[data-category=system] .notifications-bell__item-icon{background:#f59e0b26;color:var(--warning)}.network-indicator{display:inline-flex;align-items:center;gap:var(--space-xs);padding:0 var(--space-sm);color:var(--fg-muted, var(--text-muted));font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wide);pointer-events:none}.network-indicator__dot{width:6px;height:6px;border-radius:var(--r-pill, var(--radius-pill));background:var(--brand, var(--primary));animation:network-indicator-pulse 1.2s ease-in-out infinite}.network-indicator__label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes network-indicator-pulse{0%,to{opacity:.35;transform:scale(.85)}50%{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.network-indicator__dot{animation:none;opacity:.9}}.role-gate{display:flex;flex-direction:column;width:100%;flex:1;min-height:0;background:var(--bg-app);color:var(--fg-primary);overflow:hidden}.role-gate__body{flex:1;overflow-y:auto;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.role-gate__forbidden{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);text-align:center;padding:var(--space-2xl) var(--space-xl);max-width:480px;background:var(--bg-surface);border:1px solid var(--border-subtle, var(--border-color));border-radius:var(--r-lg, var(--radius-xl));box-shadow:var(--shadow-sm)}.role-gate__forbidden-icon{display:grid;place-items:center;width:64px;height:64px;border-radius:var(--r-pill, var(--radius-pill));background:var(--brand-soft);color:var(--fg-brand);border:1px solid color-mix(in oklch,var(--brand) 20%,transparent)}.role-gate__forbidden-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:var(--fw-semibold);color:var(--fg-primary);margin:0;letter-spacing:var(--tracking-snug);line-height:var(--leading-snug)}.role-gate__forbidden-body{font-size:var(--text-md);color:var(--fg-secondary);line-height:var(--leading-relaxed);margin:0}.role-gate__forbidden-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);min-height:40px;background:var(--brand);color:var(--fg-on-brand);border:1px solid var(--brand);border-radius:var(--r-sm, var(--radius-md));font-family:inherit;font-size:var(--text-sm);font-weight:var(--fw-medium);cursor:pointer;margin-top:var(--space-sm);transition:background .16s ease,box-shadow .16s ease}.role-gate__forbidden-btn:hover{background:var(--brand-hover, var(--primary-light));box-shadow:var(--shadow-sm)}.role-gate__forbidden-btn:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px}@media(max-width:820px){.role-gate__body{padding:var(--space-lg)}.role-gate__forbidden{padding:var(--space-xl) var(--space-lg);width:100%}}@media(prefers-reduced-motion:reduce){.role-gate__forbidden-btn{transition:none}}.ui-modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);-webkit-backdrop-filter:var(--overlay-blur);backdrop-filter:var(--overlay-blur);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg);overflow:hidden;animation:ui-modal-fade-in .2s ease}@keyframes ui-modal-fade-in{0%{opacity:0}to{opacity:1}}.ui-modal{width:100%;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 24px 60px #00000059,0 2px 8px #0003;display:flex;flex-direction:column;height:calc(100dvh - var(--space-lg) * 2);max-height:calc(100dvh - var(--space-lg) * 2);overflow:hidden;animation:ui-modal-slide-in .2s ease both}@keyframes ui-modal-slide-in{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.ui-modal--xs{max-width:var(--modal-w-xs);height:auto}.ui-modal--sm{max-width:var(--modal-w-sm);height:auto}.ui-modal--md{max-width:var(--modal-w-md)}.ui-modal--lg{max-width:var(--modal-w-lg)}.ui-modal--xl{max-width:var(--modal-w-xl)}.ui-modal--fullscreen{max-width:none;width:100%;height:100dvh;max-height:100dvh;border-radius:0;border:none}.ui-modal--xs,.ui-modal--sm{max-height:calc(100dvh - var(--space-lg) * 2)}.ui-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color);flex-shrink:0}.ui-modal__title-group{display:flex;flex-direction:column;gap:var(--space-xs);flex:1 1 auto;min-width:0}.ui-modal__title{font-size:var(--font-lg);font-weight:var(--fw-semibold);color:var(--text-primary);margin:0;line-height:var(--leading-snug)}.ui-modal__subtitle{font-size:var(--font-sm);color:var(--text-muted);margin:0;line-height:var(--leading-normal)}.ui-modal__close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-secondary);background:transparent;border:1px solid transparent;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);flex-shrink:0}.ui-modal__close:hover{background:var(--bg-hover);color:var(--text-primary)}.ui-modal__close:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px}.ui-modal__body{flex:1 1 auto;overflow-y:auto;overflow-x:hidden;padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-lg);scroll-behavior:smooth;color:var(--text-primary)}.ui-modal--xs .ui-modal__body,.ui-modal--sm .ui-modal__body{padding:var(--space-lg);gap:var(--space-md)}.ui-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border-color);flex-shrink:0;background:var(--bg-elevated)}.ui-modal--xs .ui-modal__footer,.ui-modal--sm .ui-modal__footer{padding:var(--space-md) var(--space-lg)}.ui-modal--tone-danger .ui-modal__header{border-bottom-color:var(--danger)}.ui-modal--tone-danger .ui-modal__title{color:var(--danger)}@media(max-width:820px){.ui-modal-overlay{padding:var(--space-lg)}.ui-modal{height:calc(100dvh - var(--space-lg) * 2);max-height:calc(100dvh - var(--space-lg) * 2);border-radius:var(--radius-lg)}.ui-modal--fullscreen{height:100dvh;max-height:100dvh;border-radius:0}.ui-modal__header,.ui-modal__footer{padding-left:max(var(--space-lg),env(safe-area-inset-left));padding-right:max(var(--space-lg),env(safe-area-inset-right))}.ui-modal__body{padding-top:var(--space-lg);padding-bottom:var(--space-lg);padding-left:max(var(--space-lg),env(safe-area-inset-left));padding-right:max(var(--space-lg),env(safe-area-inset-right))}.ui-modal__footer{flex-direction:column-reverse}.ui-modal__footer>*{width:100%}}@media(min-width:821px){.ui-modal-overlay--right{justify-content:flex-end;align-items:stretch;padding:0}.ui-modal--right{height:100dvh;max-height:100dvh;border-radius:var(--radius-xl) 0 0 var(--radius-xl);animation:ui-modal-slide-in-right .25s ease}}@keyframes ui-modal-slide-in-right{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);font-family:inherit;font-weight:var(--fw-medium);line-height:var(--leading-none);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast),opacity var(--transition-fast);white-space:nowrap;-webkit-tap-highlight-color:transparent}.ui-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none!important}.ui-btn:focus-visible{outline:none;box-shadow:var(--focus-ring)}.ui-btn__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.ui-btn__label{display:inline-flex;align-items:center}.ui-btn--sm{min-height:36px;padding:var(--space-xs) var(--space-md);font-size:var(--font-sm)}.ui-btn--md{min-height:44px;padding:10px var(--space-lg);font-size:var(--font-md)}.ui-btn--lg{min-height:52px;padding:var(--space-md) var(--space-xl);font-size:var(--font-base);font-weight:var(--fw-semibold)}.ui-btn--full{width:100%}.ui-btn--icon-only{padding:0;aspect-ratio:1}.ui-btn--icon-only.ui-btn--sm,.ui-btn--icon-only.ui-btn--md{width:44px}.ui-btn--icon-only.ui-btn--lg{width:52px}.ui-btn--primary{color:var(--bg-surface);background:var(--primary);border-color:transparent}.ui-btn--primary:hover:not(:disabled){background:var(--primary-light);box-shadow:0 4px 16px var(--primary-25)}.ui-btn--secondary{color:var(--text-primary);background:var(--bg-active);border-color:var(--border-color)}.ui-btn--secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-hover)}.ui-btn--ghost{color:var(--text-secondary);background:transparent;border-color:var(--border-color)}.ui-btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-hover)}.ui-btn--danger{color:var(--danger);background:transparent;border-color:var(--border-color)}.ui-btn--danger:hover:not(:disabled){background:var(--danger-bg);border-color:var(--danger)}.ui-btn:active:not(:disabled){transform:scale(.97);transition:transform .05s}@media(hover:none)and (pointer:coarse){.ui-btn:hover{background:inherit;border-color:inherit;box-shadow:none}.ui-btn--primary{background:var(--primary)}.ui-btn--secondary{background:var(--bg-active)}}.ui-form-field{display:flex;flex-direction:column;gap:var(--space-xs)}.ui-form-field+.ui-form-field{margin-top:var(--space-md)}.ui-form-field__label{font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--text-secondary);display:inline-flex;align-items:center;gap:var(--space-xs)}.ui-form-field__required{color:var(--danger);font-weight:var(--fw-semibold)}.ui-form-field__label--sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.ui-form-field__control{display:flex;flex-direction:column;gap:var(--space-xs)}.ui-form-field__control>input,.ui-form-field__control>textarea,.ui-form-field__control>select{width:100%}.ui-form-field__help{font-size:var(--font-xs);color:var(--text-muted);margin:0;line-height:var(--leading-normal)}.ui-form-field__error{font-size:var(--font-xs);color:var(--danger);margin:0;line-height:var(--leading-normal)}.ui-form-field--invalid .ui-form-field__control>input,.ui-form-field--invalid .ui-form-field__control>textarea,.ui-form-field--invalid .ui-form-field__control>select{border-color:var(--danger)}.ui-form-field__radio-group{display:flex;flex-direction:column;gap:var(--space-xs)}.ui-form-field__radio{display:inline-flex;align-items:center;gap:var(--space-sm);font-size:var(--font-md);color:var(--text-primary);cursor:pointer;min-height:44px;padding:var(--space-xs) 0;-webkit-user-select:none;user-select:none}.ui-form-field__radio input[type=radio]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.ui-form-field__chips{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.ui-button-spinner{animation:ui-button-spinner-rotate .8s linear infinite;flex-shrink:0;vertical-align:middle}@keyframes ui-button-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.ui-button-spinner{animation-duration:2.4s}}.form-hidden-file{display:none}.file-list{display:flex;flex-direction:column;gap:var(--space-xs)}.file-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--primary-8);border-radius:var(--radius-md);font-size:var(--font-sm)}.file-item--new{border:1px dashed var(--primary-20)}.file-icon{display:flex;color:var(--primary-light);flex-shrink:0}.file-name{flex:1;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-delete{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.file-delete:hover:not(:disabled){background:#ef444426;color:var(--danger)}.upload-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:10px;font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--primary-light);background:var(--primary-5);border:1px dashed var(--primary-20);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.upload-btn:hover{background:var(--primary-10);border-color:var(--primary-30)}.user-menu{position:fixed;left:var(--user-menu-left, 0);bottom:var(--user-menu-bottom, 0);z-index:1000;min-width:240px;max-width:280px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-xs);animation:user-menu-in .16s var(--transition-default) both}@media(max-width:820px){.user-menu{right:var(--user-menu-right, 12px);max-width:none;padding:var(--space-sm);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom,0px));border-radius:var(--radius-xl)}.user-menu__item{min-height:44px;font-size:var(--font-lg)}}@media(prefers-reduced-motion:reduce){.user-menu{animation:none}}@keyframes user-menu-in{0%{opacity:0;transform:translateY(4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu__header{padding:var(--space-sm) var(--space-md)}.user-menu__name{margin:0;font-weight:var(--fw-semibold);color:var(--text-primary);font-size:var(--font-md);line-height:var(--leading-snug)}.user-menu__email,.user-menu__meta{margin:2px 0 0;color:var(--text-muted);font-size:var(--font-xs);line-height:var(--leading-snug);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu__meta{color:var(--text-secondary)}.user-menu__divider{height:1px;margin:var(--space-xs) calc(var(--space-xs) * -1);background:var(--border-color)}.user-menu__item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:var(--font-md);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);min-height:36px}.user-menu__item:hover,.user-menu__item:focus-visible{background:var(--bg-hover);outline:none}.user-menu__item:focus-visible{box-shadow:0 0 0 2px var(--primary-25)}.user-menu__item:disabled{opacity:.6;cursor:not-allowed}.user-menu__item svg{flex-shrink:0;color:var(--text-secondary)}.user-menu__item:hover svg{color:var(--text-primary)}.user-menu__item--danger{color:var(--danger)}.user-menu__item--danger svg{color:var(--danger)}.user-menu__item--danger:hover{background:var(--danger-bg);color:var(--danger)}.user-menu__item--danger:hover svg{color:var(--danger)}.user-menu__theme .user-menu__item-label{flex:1 1 auto}.user-menu__theme .user-menu__item-value{font-size:var(--font-xs);color:var(--text-muted);text-transform:capitalize}.user-menu__theme-options{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-xs);margin:2px var(--space-xs) var(--space-xs);padding:var(--space-xs);background:var(--bg-elevated);border-radius:var(--radius-md)}.user-menu__theme-option{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);min-height:32px;padding:0 var(--space-xs);border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-family:inherit;font-size:var(--font-xs);font-weight:var(--fw-medium);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.user-menu__theme-option:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu__theme-option:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-25)}.user-menu__theme-option.is-active{background:var(--primary-15);color:var(--primary-light);border-color:var(--primary-25)}.ui-tooltip{position:fixed;z-index:10000;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-primary);font-size:var(--font-xs);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-wide);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md);animation:ui-tooltip-in .12s ease-out both}.ui-tooltip--right{transform:translateY(-50%)}.ui-tooltip--left{transform:translate(-100%,-50%)}.ui-tooltip--top{transform:translate(-50%,-100%)}.ui-tooltip--bottom{transform:translate(-50%)}@keyframes ui-tooltip-in{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.ui-tooltip{animation:none}}@media(hover:none){.ui-tooltip{display:none}}.ui-confirm-dialog__body{gap:var(--space-sm)}.ui-confirm-dialog__head{display:flex;align-items:center;gap:var(--space-sm)}.ui-confirm-dialog__icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-pill);background:var(--danger-bg, rgba(239, 68, 68, .15));color:var(--danger);flex-shrink:0}.ui-confirm-dialog__title{font-family:var(--font-display, var(--font-brand));font-size:var(--font-lg);font-weight:var(--fw-semibold);line-height:var(--leading-snug);margin:0;color:var(--text-primary)}.ui-confirm-dialog__desc{font-size:var(--font-sm);color:var(--text-secondary);line-height:var(--leading-normal);margin:0}.ui-confirm-dialog__extra{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-xs)}.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100dvh;border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:1000;transition:width var(--transition-normal);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width);overflow:visible}.sidebar-edge-zone{position:fixed;top:0;left:calc(var(--sidebar-width) - 4px);width:16px;height:100dvh;z-index:1001;cursor:pointer;transition:left var(--transition-normal)}.sidebar-edge-zone--collapsed{left:calc(var(--sidebar-collapsed-width) - 4px)}.sidebar-icon-tooltip{position:fixed;transform:translateY(-50%);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--text-secondary);font-size:var(--text-xs);font-weight:var(--fw-semibold);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md);z-index:10000}@media(max-width:820px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1000;width:280px!important;height:100vh;height:100dvh;overflow:auto!important;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.sidebar.collapsed,.sidebar-toggle{display:none}.sidebar-toggle-overlay{display:none!important}.sidebar-edge-zone,.sidebar-icon-tooltip{display:none}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;box-sizing:border-box;gap:var(--space-sm);flex-shrink:0}.sidebar.collapsed .sidebar-header{gap:var(--space-xs)}.sidebar.collapsed .brand{gap:0}.sidebar-toggle-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sidebar);background:#8b5cf626;border:none;color:var(--primary-light);cursor:pointer;opacity:0;transition:opacity var(--transition-fast);z-index:2}.sidebar.collapsed .brand-logo:hover .logo-image{opacity:.15;filter:blur(1.5px)}.sidebar.collapsed .brand-logo:hover .sidebar-toggle-overlay{opacity:1}.sidebar-toggle{position:relative}.sidebar-toggle:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:0 4px 20px #8b5cf64d}.sidebar-header-actions{display:flex;align-items:center;gap:var(--space-sm)}.sidebar-new-chat-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sidebar);color:var(--text-secondary);background:var(--bg-hover);border:none;cursor:pointer;transition:all var(--transition-fast)}.sidebar-new-chat-icon:hover{background:var(--primary);color:var(--fg-on-brand);box-shadow:0 4px 20px #8b5cf64d}.brand{display:flex;align-items:center;min-width:0;overflow:hidden}.brand-logo{display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;transition:all var(--transition-fast)}.logo-image{width:100%;height:100%;object-fit:contain;transition:opacity var(--transition-fast),filter var(--transition-fast)}.brand-text{display:flex;align-items:center}.logo-text-image{object-fit:contain}@media(max-width:820px){.logo-text-image{display:none}}.sidebar-nav{flex:1;overflow-y:auto}.sidebar-nav--with-chat-panel{overflow-y:auto}.sidebar.collapsed .sidebar-nav{overflow:visible}.nav-section-title{display:block;padding-left:var(--space-md)}.nav-item{display:flex;align-items:center;width:100%;position:relative;text-align:left;border:none;cursor:pointer;font-family:inherit}.nav-item:focus{outline:none}.nav-item:focus-visible{outline:2px solid var(--primary, var(--primary));outline-offset:-2px}.nav-icon{display:flex;align-items:center;justify-content:center;transition:all var(--transition-default)}.nav-content{flex:1;min-width:0;display:flex;align-items:center;gap:var(--space-xs)}.nav-label{display:block}.nav-lock-icon{color:var(--text-muted);opacity:.6;flex-shrink:0}.nav-description{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.active-indicator{width:4px;height:24px;background:linear-gradient(180deg,var(--primary),var(--accent));border-radius:2px;position:absolute;right:0}.sidebar.collapsed .nav-item{border-radius:var(--radius-sidebar)}.sidebar.collapsed .active-indicator{right:-4px}.expand-icon{display:flex;align-items:center;justify-content:center;margin-left:var(--space-sm);color:var(--text-muted);transition:transform var(--transition-fast)}.expand-icon.expanded{transform:rotate(180deg)}.nav-item-with-submenu{margin-bottom:var(--space-xs)}.nav-item.expanded{margin-bottom:var(--space-sm)}.submenu{display:flex;flex-direction:column;gap:2px;padding-left:0;margin-top:var(--space-xs);margin-bottom:var(--space-sm);animation:submenuSlideDown .2s ease}@keyframes submenuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes itemFadeIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.submenu-item{display:flex;align-items:center;width:100%;background:none;animation:itemFadeIn .25s ease;border:none;font-weight:var(--fw-medium);cursor:pointer;text-align:left;overflow:hidden}.submenu-item span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.submenu-item svg{flex-shrink:0}.submenu-item svg{flex-shrink:0;opacity:.7}.submenu-item--indent{padding-left:28px;font-size:var(--text-xs)}.submenu-chevron{margin-left:auto;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0;opacity:.5}.submenu-chevron.expanded{transform:rotate(180deg)}.submenu-nested{display:flex;flex-direction:column;gap:1px;padding-left:0;animation:submenuSlideDown .2s ease}.chat-project-tag{margin-left:auto;font-size:var(--text-2xs);color:var(--text-muted);background:var(--primary-8);padding:1px 6px;border-radius:var(--radius-pill);flex-shrink:0;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.submenu-item--deep{padding-left:50px;font-size:var(--font-xs)}.submenu-item--muted{color:var(--text-muted);opacity:.7}.submenu-item--muted:hover{opacity:1}.submenu-section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xs) var(--space-sm);margin-bottom:2px}.submenu-section-toggle{display:flex;align-items:center;gap:var(--space-sidebar-hairline);background:none;border:none;color:var(--text-muted);font-size:var(--font-xs);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-wide);text-transform:uppercase;cursor:pointer;padding:2px 0;transition:color var(--transition-fast)}.submenu-section-toggle:hover{color:var(--text-secondary)}.submenu-section-count{font-size:var(--text-2xs);color:var(--text-muted);opacity:.6}.submenu-section-add{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.submenu-section-add:hover{background:#8b5cf626;color:var(--primary-light)}.submenu-item-wrap{position:relative;display:flex;align-items:center;width:100%}.submenu-item-wrap .submenu-chevron{margin-left:0}.submenu-item-wrap .submenu-item{flex:1;min-width:0;padding-right:28px}.submenu-more-btn{display:none;align-items:center;justify-content:center;position:absolute;right:4px;background:none;border:none;color:var(--text-muted);pointer-events:auto;cursor:pointer;padding:2px;border-radius:4px;z-index:2;transition:color var(--transition-fast),background var(--transition-fast)}@media(hover:hover){.submenu-item-wrap:hover .submenu-more-btn{display:flex}.submenu-more-btn:hover{color:var(--text-primary);background:var(--bg-active)}}@media(hover:none){.submenu-more-btn{display:flex;opacity:.5}}.submenu-item:has(.submenu-rename-input){background:#8b5cf614;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-md)}.submenu-rename-input{flex:1;min-width:0;font-size:inherit;font-weight:inherit;color:var(--text-primary);background:transparent;border:none;outline:none;padding:0;font-family:inherit;line-height:inherit}.sidebar-footer{flex-shrink:0}.sidebar.collapsed .sidebar-footer{padding:var(--space-md) var(--space-sm) var(--space-xl) var(--space-sm)}.user-section-wrapper{display:flex;align-items:center;gap:var(--space-sidebar-hairline);width:100%}.sidebar.collapsed .user-section-wrapper{justify-content:center}.user-section{display:flex;align-items:center;flex:1;min-width:0;text-align:left;transition:all var(--transition-fast);cursor:pointer;border:none}.user-menu-trigger{width:32px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius-md);background:transparent;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.user-menu-trigger:hover,.user-menu-trigger[aria-expanded=true]{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-color)}.user-menu-trigger:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-25)}.sidebar.collapsed .user-section{justify-content:center;padding:11px}.user-section.active{background:#8b5cf626;border:1px solid rgba(139,92,246,.3)}.user-avatar{display:flex;align-items:center;justify-content:center;color:var(--fg-on-brand);flex-shrink:0}.user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-name{display:block;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.settings-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;cursor:pointer}.settings-icon:hover{color:var(--primary-light)}.upgrade-btn{display:flex;align-items:center;gap:var(--space-xs);font-weight:var(--fw-semibold);color:var(--fg-on-brand);background:var(--primary);flex-shrink:0;transition:all var(--transition-fast);cursor:pointer}.upgrade-btn:hover{background:var(--primary-light);box-shadow:0 2px 8px var(--primary-25)}.typewriter{display:inline}.typewriter-cursor{display:inline;font-weight:100;color:var(--primary);animation:blink-cursor .6s step-end infinite;font-size:.85em;margin-left:1px;opacity:.8}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.search-modal-backdrop{position:fixed;inset:0;z-index:9999;background:var(--overlay-bg);-webkit-backdrop-filter:var(--overlay-blur);backdrop-filter:var(--overlay-blur);display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;animation:fadeIn .15s ease}.search-modal{width:90%;max-width:560px;max-height:60vh;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:0 16px 48px #00000080;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .2s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.search-modal-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-color)}.search-modal-icon{color:var(--text-muted);flex-shrink:0}.search-modal-input{flex:1;font-size:var(--font-lg);font-family:inherit;color:var(--text-primary);background:none;border:none;outline:none;padding:0}.search-modal-input::placeholder{color:var(--text-muted)}.search-modal-esc{font-size:var(--font-xs);color:var(--text-muted);background:var(--bg-active);border:none;border-radius:var(--radius-sm);padding:2px 6px;cursor:pointer;flex-shrink:0}.search-results{flex:1;overflow-y:auto;padding:var(--space-sm)}.search-result-section{margin-bottom:var(--space-xs)}.search-result-label{display:block;font-size:var(--font-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:var(--space-sm) var(--space-md) var(--space-xs)}.search-result-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:10px var(--space-md);font-size:var(--font-md);color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.search-result-item:hover{background:var(--primary-8);color:var(--text-primary)}.search-result-item svg{color:var(--text-muted);flex-shrink:0}.search-result-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-no-results{padding:var(--space-2xl) var(--space-lg);text-align:center;font-size:var(--font-md);color:var(--text-muted)}.search-load-more{display:block;width:100%;padding:var(--space-sidebar-pad);margin-top:var(--space-xs);font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--primary-light);background:none;border:1px dashed var(--primary-20);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center}.search-load-more:hover{background:var(--primary-8);border-color:var(--primary-30)}.search-loading{padding:var(--space-md) var(--space-lg);text-align:center;font-size:var(--font-sm);color:var(--text-muted);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.search-hint{padding:var(--space-xl) var(--space-lg);text-align:center;font-size:var(--font-sm);color:var(--text-muted)}@media(max-width:820px){.search-modal-backdrop{padding-top:10vh}.search-modal{width:92%;max-height:70vh}.search-modal-input{font-size:var(--font-lg)}.search-modal-esc{display:none}.search-result-item{min-height:44px}}.sidebar-chat-panel{display:flex;flex-direction:column;margin-top:var(--space-xs);margin-bottom:var(--space-sm);padding-top:0;min-height:0;flex:1;overflow:hidden}.sp-new-section{padding:var(--space-sidebar-hairline) 0;display:flex;flex-direction:column;gap:var(--space-xs);flex-shrink:0}.sp-new-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sidebar-hairline);width:100%;padding:7px 10px;font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--text-primary);background:#8b5cf61a;border:1px dashed rgba(139,92,246,.3);border-radius:var(--radius-pill);transition:all var(--transition-default);cursor:pointer}.sp-new-btn:hover{background:#8b5cf626;border-color:var(--primary);color:var(--primary-light)}.sp-new-btn.sp-secondary{background:var(--primary-5);border:1px dashed var(--border-color);color:var(--text-secondary)}.sp-new-btn.sp-secondary:hover{background:#8b5cf614;border-color:#8b5cf64d;color:var(--primary-light)}.sp-create-form{display:flex;flex-direction:column;gap:var(--space-sidebar-hairline)}.sp-create-form input{padding:var(--space-sm) var(--space-sm);font-size:var(--font-sm);color:var(--text-primary);background:var(--primary-5);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.sp-create-form input:focus{border-color:var(--primary);box-shadow:var(--shadow-glow);outline:none}.sp-create-actions{display:flex;gap:var(--space-sidebar-hairline)}.sp-stats{display:flex;align-items:center;gap:var(--space-sidebar-hairline);padding:var(--space-xs) var(--space-xs) var(--space-xs);font-size:var(--font-xs);color:var(--text-muted);flex-shrink:0}.sp-stat-divider{opacity:.5}.sp-projects-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;min-height:0}.sp-section-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);width:100%;border-radius:var(--radius-md);background:transparent;border:none;color:var(--text-muted);font-weight:var(--fw-bold);text-transform:uppercase;cursor:pointer;transition:all var(--transition-fast)}.sp-section-header:hover{color:var(--text-primary);background:var(--primary-5)}.sp-count-badge{margin-left:auto;border:none;font-weight:var(--fw-semibold)}.sp-project-item{border-radius:var(--radius-md);background:transparent;overflow:visible;transition:all var(--transition-fast)}.sp-project-item:hover{background:var(--primary-5)}.sp-project-item.expanded{background:#8b5cf60a}.sp-project-header{display:flex;align-items:center;width:100%;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative;overflow:hidden}.sp-project-header-btn{display:flex;align-items:center;gap:var(--space-sm);flex:1;min-width:0;padding:6px var(--space-sm);text-align:left;background:none;border:none;cursor:pointer}.sp-project-header:hover,.sp-project-header.expanded{background:#8b5cf60f}.sp-project-header:after{content:"";position:absolute;right:0;top:0;bottom:0;width:50px;border-radius:0 var(--radius-md) var(--radius-md) 0;background:linear-gradient(to right,transparent,var(--bg-elevated));opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.sp-project-header:hover:after{opacity:1}.sp-project-header.expanded:after{background:linear-gradient(to right,transparent,rgba(18,14,28,.95))}.sp-project-header:hover .expand-icon{opacity:0}.sp-project-more-btn{display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:3px;border-radius:5px;flex-shrink:0;position:absolute;right:6px;z-index:2;transition:color var(--transition-fast),background var(--transition-fast)}.sp-project-more-btn:hover{color:var(--text-primary);background:var(--bg-active)}.sp-project-header:hover .sp-project-more-btn{display:flex}.sp-project-header:has(.sp-project-rename-input):after{display:none}.sp-project-header:has(.sp-project-rename-input){border:1px solid var(--primary)!important;background:#8b5cf60d!important}.sp-project-rename-input{width:100%;font-size:var(--text-xs);font-weight:var(--fw-semibold);color:var(--text-primary);background:transparent;border:none;outline:none;padding:0;font-family:inherit}.sp-project-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.sp-project-info{flex:1;min-width:0}.sp-project-name{display:block;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-project-count{display:block;font-size:var(--text-2xs);color:var(--text-muted)}.sp-chats-list{padding:2px 2px 2px var(--space-md)}.sp-chat-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:6px var(--space-sm);text-align:left;border-radius:var(--radius-sm);margin-bottom:1px;transition:all var(--transition-fast);background:none;border:none;cursor:pointer;font-size:var(--text-xs);position:relative}.sp-chat-item:hover{background:var(--primary-5)}.sp-chat-item:after{content:"";position:absolute;right:0;top:0;bottom:0;width:50px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;background:linear-gradient(to right,transparent,var(--bg-elevated));opacity:0;pointer-events:none;transition:opacity var(--transition-fast)}.sp-chat-item:hover:after{opacity:1}.sp-chat-item:hover .chat-more-btn{display:flex}.sp-chat-item.selected:after{background:linear-gradient(to right,transparent,rgba(20,15,30,.95))}.sp-chat-item.selected{background:#8b5cf61a;border:1px solid rgba(139,92,246,.2)}.sp-chat-item:has(.sp-chat-rename-input){border:1px solid var(--primary)!important;background:#8b5cf60d!important;box-shadow:none!important}.sp-chat-item:has(.sp-chat-rename-input):after{display:none}.sp-chat-icon{display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.sp-chat-item.selected .sp-chat-icon{color:var(--primary-light)}.sp-chat-info{flex:1;min-width:0}.sp-chat-name{display:block;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-chat-rename-input{width:100%;font-size:var(--text-xs);font-weight:var(--fw-medium);color:var(--text-primary);background:transparent;border:none;border-radius:0;padding:1px 0;outline:none}.sp-chat-rename-input:focus{outline:none;border:none}.sp-new-chat-btn{display:flex;align-items:center;gap:5px;width:100%;padding:6px 10px;font-size:var(--font-xs);font-weight:var(--fw-medium);color:var(--text-muted);background:transparent;border:none;border-radius:5px;transition:all var(--transition-fast);cursor:pointer}.sp-new-chat-btn:hover{color:var(--primary-light);background:#8b5cf60d}.sp-direct-chats-section{padding:var(--space-xs) 0 var(--space-xs)}.sp-direct-chats-label{font-weight:var(--fw-bold);text-transform:uppercase}.sp-direct-chats-list{overflow:visible;padding:0 var(--space-xs) var(--space-xs)}.sp-loading-hint{padding:var(--space-sm) var(--space-sm);color:var(--text-muted);font-size:var(--font-xs)}.chat-more-btn{display:none;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px;flex-shrink:0;right:4px;position:relative;z-index:2;transition:color var(--transition-fast),background var(--transition-fast)}.chat-more-btn:hover{color:var(--text-primary);background:var(--bg-active)}.context-menu{position:fixed;z-index:9998;min-width:140px;padding:var(--space-xs);border-radius:var(--radius-sidebar);background:var(--bg-elevated);border:1px solid var(--border-color);box-shadow:var(--shadow-md)}.context-menu-item{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-sm);border-radius:var(--radius-md);border:none;background:transparent;font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.context-menu-item:hover{background:var(--bg-hover)}.context-menu-item.danger{color:#ef4444f2}.context-menu-item.danger:hover{background:#ef444414}.rp-modal-overlay{position:fixed;inset:0;z-index:9999;background:var(--overlay-bg);-webkit-backdrop-filter:var(--overlay-blur);backdrop-filter:var(--overlay-blur);display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.rp-modal{width:min(520px,100%);border-radius:var(--radius-xl);border:1px solid rgba(139,92,246,.18);background:var(--bg-elevated);box-shadow:var(--shadow-md);padding:var(--space-lg)}.rp-modal-title{font-size:var(--font-lg);font-weight:var(--fw-bold);color:var(--text-primary);margin-bottom:var(--space-sm)}.rp-modal-message{font-size:var(--font-sm);line-height:var(--leading-normal);color:var(--text-secondary);margin-bottom:14px}.rp-modal-actions{display:flex;gap:10px}.danger-btn{flex:1;padding:.75rem 1.5rem;font-size:var(--font-sm);font-weight:var(--fw-bold);color:var(--fg-on-brand);background:linear-gradient(135deg,#ef4444f2,#dc2626f2);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-default)}.danger-btn:hover{box-shadow:0 0 0 3px #ef44441f}.danger-btn:disabled,.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.cancel-btn{flex:1;padding:.5rem 1rem;font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--text-secondary);background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-pill);transition:all var(--transition-default);cursor:pointer}.cancel-btn:hover{background:var(--bg-active)}.submit-btn{flex:1;padding:.5rem 1rem;font-size:var(--font-sm);font-weight:var(--fw-semibold);color:var(--fg-on-brand);background:linear-gradient(to right,var(--primary),var(--primary-light));border:none;border-radius:var(--radius-pill);transition:all var(--transition-default);cursor:pointer}.submit-btn:hover{box-shadow:0 4px 20px #8b5cf64d;transform:scale(1.02)}.sidebar{background:var(--bg-canvas, var(--bg-elevated));padding:0;font-size:var(--text-sm);line-height:var(--leading-normal)}.sidebar-header{padding:14px 14px var(--space-sm);height:auto;border-bottom:1px solid var(--border-subtle, var(--border-color));background:transparent}.sidebar.collapsed .sidebar-header{padding:14px var(--space-sm) var(--space-sm)}.brand{gap:9px}.brand-logo{width:22px;height:22px;border-radius:var(--radius-sm)}.sidebar.collapsed .brand-logo{width:28px;height:28px}.logo-text-image{height:22px}.sidebar-nav{padding:var(--space-sm);gap:var(--space-xs)}.sidebar.collapsed .sidebar-nav{padding:var(--space-sm) var(--space-xs)}.nav-section{margin-bottom:var(--space-sm)}.nav-section-title{font-family:var(--font-mono);font-size:var(--text-3xs);font-weight:var(--fw-medium);letter-spacing:var(--tracking-wider);color:var(--fg-muted, var(--text-muted));padding:var(--space-xs) var(--space-sm);margin-bottom:var(--space-xs);text-transform:uppercase}.nav-item{gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--r-sm, var(--radius-md));font-size:var(--text-sm);color:var(--fg-secondary, var(--text-secondary));margin-bottom:0;background:transparent;transition:background .14s ease,color .14s ease;border-left:2px solid transparent;padding-left:var(--space-sm)}.nav-item:hover{background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.nav-item:hover .nav-icon{color:var(--fg-primary, var(--text-primary))}.nav-item.active{background:var(--brand-soft, rgba(124, 58, 237, .15));color:var(--brand-soft-fg, var(--primary-light));font-weight:var(--fw-semibold);border-left-color:var(--brand, var(--primary))}.nav-item.active:hover{background:color-mix(in oklch,var(--brand) 20%,transparent)}.nav-item:focus-visible,.submenu-item:focus-visible,.sp-chat-item:focus-visible,.sp-project-header-btn:focus-visible,.user-section:focus-visible{outline:2px solid var(--brand, var(--primary));outline-offset:-2px;box-shadow:0 0 0 3px var(--primary-25, rgba(124, 58, 237, .25))}.sidebar.collapsed .nav-item{padding:var(--space-sm);padding-left:6px;justify-content:center;border-left-width:0;position:relative}.sidebar.collapsed .nav-item.active:after{content:"";position:absolute;right:0;top:6px;bottom:6px;width:2px;background:var(--brand, var(--primary));border-radius:2px}.nav-icon{width:16px;height:16px;background:transparent!important;color:var(--fg-muted, var(--text-muted));border-radius:0;box-shadow:none!important;flex-shrink:0}.nav-item:hover .nav-icon,.nav-item.active .nav-icon{background:transparent!important;color:var(--brand, var(--primary));box-shadow:none!important}.sidebar.collapsed .nav-icon{width:16px;height:16px}.nav-label{font-size:var(--text-sm);font-weight:var(--fw-medium)}.nav-description{display:none}.submenu-item{padding:var(--space-xs) var(--space-sm) var(--space-xs) var(--space-2xl);font-size:var(--text-xs);color:var(--fg-muted, var(--text-muted));border-radius:var(--r-xs, var(--radius-sm));gap:var(--space-sm);transition:background .14s ease,color .14s ease}.submenu-item:hover{background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.submenu-item.active{background:var(--brand-soft, rgba(124, 58, 237, .15));color:var(--brand-soft-fg, var(--primary-light));font-weight:var(--fw-medium)}.submenu-item.active svg{color:var(--brand, var(--primary));opacity:1}.active-indicator{display:none}.sp-project-header-btn,.sp-chat-item{font-size:var(--text-xs);padding:5px var(--space-sm);border-radius:var(--r-xs, var(--radius-sm));gap:var(--space-sm)}.sp-project-name{font-size:12px;font-weight:500}.sp-chat-name{font-size:12px;font-weight:400}.sp-project-icon{width:18px;height:18px;background:transparent;color:var(--fg-muted, var(--text-muted));border-radius:4px}.sp-project-header.expanded .sp-project-icon{background:transparent;color:var(--brand, var(--primary))}.sp-section-header{font-family:var(--font-mono);font-size:var(--text-3xs);letter-spacing:var(--tracking-wider);padding:10px var(--space-sm) var(--space-xs);margin-top:6px;border-top:1px solid var(--border-subtle, var(--border-color))}.sidebar-chat-panel .sp-section-header:first-child,.submenu .sp-section-header:first-child{border-top:0;margin-top:0}.sp-direct-chats-section{border-top:1px solid var(--border-subtle, var(--border-color));margin-top:6px;padding-top:6px}.sp-direct-chats-label{font-family:var(--font-mono);font-size:var(--text-3xs);letter-spacing:var(--tracking-wider);padding:var(--space-xs) var(--space-sm) var(--space-xs);color:var(--fg-muted, var(--text-muted))}.sp-count-badge{font-family:var(--font-mono);font-size:var(--text-3xs);background:var(--bg-subtle);color:var(--fg-muted);padding:1px 6px;border-radius:var(--r-pill, var(--radius-pill))}.sidebar-footer{padding:10px var(--space-md) 14px;border-top:1px solid var(--border-subtle, var(--border-color))}.user-section{padding:6px var(--space-sm);border-radius:var(--r-sm, var(--radius-md));background:transparent;gap:10px}.user-section:hover{background:var(--bg-hover)}.user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--violet-400, var(--violet-400)),var(--violet-700, var(--primary-dark)));font-size:var(--text-2xs);font-weight:var(--fw-semibold)}.user-name{font-size:12.5px;font-weight:500}.user-role{font-size:var(--text-2xs);font-family:var(--font-mono);color:var(--fg-muted, var(--text-muted))}.upgrade-btn{font-size:var(--text-2xs);padding:3px 9px;border-radius:var(--r-pill, var(--radius-pill));font-family:var(--font-mono);letter-spacing:var(--tracking-wide);text-transform:uppercase}@media(prefers-reduced-motion:reduce){.sidebar,.nav-item,.submenu-item{transition:none}}.sidebar.collapsed .nav-item,.sidebar.collapsed .submenu-item,.sidebar.collapsed .sp-chat-item,.sidebar.collapsed .sp-project-header-btn,.sidebar.collapsed .user-section,.sidebar.collapsed .sidebar-new-chat-icon,.sidebar.collapsed .sidebar-toggle,.sidebar.collapsed .user-menu-trigger{padding:6px!important;width:40px!important;height:40px!important;margin-inline:auto!important;display:grid!important;place-items:center!important;border-left:0!important;border-radius:var(--r-sm, var(--radius-md))!important;position:relative}.sidebar.collapsed .nav-item.active{border-left:0!important}.sidebar.collapsed .nav-icon,.sidebar.collapsed .submenu-item svg,.sidebar.collapsed .sp-project-icon,.sidebar.collapsed .sp-chat-icon{width:16px!important;height:16px!important;color:var(--fg-secondary, var(--text-secondary))}.sidebar.collapsed .nav-item.active .nav-icon,.sidebar.collapsed .submenu-item.active svg{color:var(--brand, var(--primary))}.sidebar.collapsed .nav-content,.sidebar.collapsed .submenu-item span,.sidebar.collapsed .sp-project-info,.sidebar.collapsed .sp-chat-name,.sidebar.collapsed .sp-section-header,.sidebar.collapsed .user-info,.sidebar.collapsed .expand-icon,.sidebar.collapsed .nav-section-title{display:none!important}.sidebar.collapsed .user-avatar{width:28px!important;height:28px!important}.sidebar.collapsed .sidebar-header{padding:10px var(--space-sm)!important;justify-content:center!important}.sidebar.collapsed .sidebar-nav,.sidebar.collapsed .sidebar-footer{padding-left:var(--space-sm)!important;padding-right:var(--space-sm)!important}.sidebar.collapsed .nav-section{margin-bottom:2px}.sidebar.collapsed .nav-section+.nav-section{padding-top:6px;margin-top:0;border-top:1px solid var(--border-subtle, var(--border-color))}.sidebar-header,.sidebar.collapsed .sidebar-header{height:var(--header-height, 64px)!important;min-height:var(--header-height, 64px)!important;padding-top:0!important;padding-bottom:0!important;align-items:center!important;box-sizing:border-box}.mentality-overlay__fab{position:fixed;right:20px;bottom:calc(92px + env(safe-area-inset-bottom,0px));z-index:900;display:inline-flex;align-items:center;justify-content:center;gap:6px;width:44px;height:44px;padding:0;font-family:var(--font-display);font-size:var(--font-sm);font-weight:var(--fw-semibold);letter-spacing:-.005em;color:var(--fg-on-brand, var(--bg-surface));background:var(--brand, var(--primary));border:1px solid color-mix(in oklch,var(--brand, var(--primary)) 60%,transparent);border-radius:var(--radius-pill);box-shadow:var(--shadow-lg, 0 10px 24px rgba(0, 0, 0, .2));cursor:pointer;white-space:nowrap;overflow:hidden;transition:width .18s ease,padding .18s ease,transform .14s ease,box-shadow .14s ease}.mentality-overlay__fab-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.mentality-overlay__fab--draggable{left:var(--fab-left);top:var(--fab-top);right:auto;bottom:auto;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.mentality-overlay__fab--draggable.is-dragging{cursor:grabbing;box-shadow:0 18px 40px #00000047;transform:scale(1.04);transition:none}.mentality-overlay__fab:hover{transform:translateY(-1px);box-shadow:0 12px 28px #00000038}.mentality-overlay__fab:focus-visible{outline:2px solid var(--primary-25);outline-offset:3px}.mentality-overlay{position:fixed;right:20px;bottom:20px;z-index:900;width:380px;max-width:calc(100vw - 24px);max-height:calc(100vh - 40px);display:flex;flex-direction:column;background:var(--bg-surface, var(--bg-card));border:1px solid var(--border-subtle, var(--border-color));border-radius:var(--r-md, 14px);box-shadow:var(--shadow-lg, 0 10px 32px rgba(0, 0, 0, .24));animation:mentality-in .16s ease-out both}@keyframes mentality-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.mentality-overlay__head{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 14px var(--space-sm);gap:10px}.mentality-overlay__title-group{display:flex;flex-direction:column;gap:2px}.mentality-overlay__eyebrow{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--brand-soft-fg, var(--primary-light))}.mentality-overlay__title{font-family:var(--font-display);font-size:var(--font-base);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-snug);color:var(--fg-primary, var(--text-primary));margin:0}.mentality-overlay__close{display:grid;place-items:center;width:28px;height:28px;border-radius:var(--r-sm, var(--radius-md));background:transparent;border:1px solid transparent;color:var(--fg-muted, var(--text-muted));cursor:pointer;transition:background .12s ease,color .12s ease}.mentality-overlay__close:hover{background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.mentality-overlay__module{display:flex;align-items:center;gap:var(--space-sm);padding:0 var(--space-lg) var(--space-sm)}.mentality-overlay__module-label{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted, var(--text-muted));flex-shrink:0}.mentality-overlay__module-select{position:relative;flex:1;min-width:0}.mentality-overlay__module-select select{width:100%;padding:7px 28px 7px var(--space-md);font-family:var(--font-display);font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--fg-primary, var(--text-primary));background:var(--bg-subtle);border:1px solid var(--border-subtle, var(--border-color));border-radius:var(--r-sm, var(--radius-md));-webkit-appearance:none;appearance:none;cursor:pointer}.mentality-overlay__module-select select:focus{outline:none;border-color:var(--brand, var(--primary));box-shadow:0 0 0 2px var(--primary-25)}.mentality-overlay__module-select svg{position:absolute;right:9px;top:50%;transform:translateY(-50%);color:var(--fg-muted, var(--text-muted));pointer-events:none}.mentality-overlay__body{flex:1;min-height:0;overflow-y:auto;padding:var(--space-xs) var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.mentality-overlay__skel{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-xs) var(--space-lg) var(--space-md)}.mentality-overlay__error{display:flex;align-items:center;gap:var(--space-sm);margin:var(--space-xs) var(--space-lg) var(--space-md);padding:10px var(--space-md);border-radius:var(--r-sm, 10px);background:color-mix(in oklch,var(--danger, var(--danger)) 8%,transparent);color:var(--danger, var(--danger));font-size:var(--text-sm);flex-wrap:wrap}.mentality-overlay__empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-sm);padding:20px 14px;color:var(--fg-muted, var(--text-muted))}.mentality-overlay__empty p{margin:0;font-size:12.5px;line-height:1.5}.mentality-overlay__section-label{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted, var(--text-muted));margin-bottom:6px}.mentality-overlay__cards{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.mentality-card{padding:10px var(--space-md);border-radius:var(--r-sm, 10px);background:var(--bg-subtle);border:1px solid var(--border-subtle, var(--border-color));border-left:3px solid var(--border-subtle, var(--border-color))}.mentality-card--risk{border-left-color:var(--danger, var(--danger))}.mentality-card--insight{border-left-color:var(--brand, var(--primary))}.mentality-card--profile{border-left-color:var(--warning, var(--warning))}.mentality-card__head{display:flex;align-items:center;gap:6px;margin-bottom:var(--space-xs)}.mentality-card__head svg{color:var(--fg-muted, var(--text-muted))}.mentality-card__kind{font-family:var(--font-mono);font-size:var(--text-3xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted, var(--text-muted));font-weight:var(--fw-semibold)}.mentality-card__meta{margin-left:auto;font-family:var(--font-mono);font-size:var(--text-3xs);letter-spacing:.06em;text-transform:uppercase;color:var(--fg-muted, var(--text-muted));background:var(--bg-surface, var(--bg-card));padding:1px 6px;border-radius:var(--radius-pill);border:1px solid var(--border-subtle, var(--border-color))}.mentality-card__body{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--fg-primary, var(--text-primary));display:inline}.mentality-card__if,.mentality-card__then{display:inline-block;padding:0 var(--space-xs);margin-right:var(--space-xs);border-radius:3px;font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:.06em;text-transform:uppercase;font-weight:var(--fw-semibold)}.mentality-card__if{background:color-mix(in oklch,var(--brand, var(--primary)) 14%,transparent);color:var(--brand, var(--primary));margin-right:6px}.mentality-card__then{background:color-mix(in oklch,var(--success, var(--success)) 14%,transparent);color:var(--success, var(--success));margin-left:6px;margin-right:6px}.mentality-overlay__chat{display:flex;flex-direction:column;gap:10px;padding-top:6px;border-top:1px dashed var(--border-subtle, var(--border-color))}.mentality-bubble{padding:10px var(--space-md);border-radius:var(--r-sm, 10px);font-size:var(--font-sm);line-height:var(--leading-normal)}.mentality-bubble--user{align-self:flex-end;background:var(--brand-soft, var(--primary-15));color:var(--brand-soft-fg, var(--primary-light));max-width:80%}.mentality-bubble--bot{background:var(--bg-subtle);color:var(--fg-primary, var(--text-primary))}.mentality-bubble p{margin:0 0 var(--space-xs)}.mentality-bubble p:last-child{margin-bottom:0}.mentality-overlay__foot{position:relative;padding:0 var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.mentality-overlay__foot:before{content:"";position:absolute;top:-28px;left:0;right:0;height:28px;background:linear-gradient(to bottom,transparent,var(--bg-surface, var(--bg-card)));pointer-events:none}.mentality-overlay__composer{display:flex;flex-direction:column;gap:var(--space-xs);padding:10px var(--space-md) 6px;background:var(--bg-canvas, var(--bg-card));border:1px solid var(--border-subtle, var(--border-color));border-radius:var(--r-md, 14px);transition:border-color .14s ease,box-shadow .14s ease}.mentality-overlay__composer:focus-within{border-color:var(--brand, var(--primary));box-shadow:0 0 0 2px var(--primary-25)}.mentality-overlay__textarea{width:100%;min-height:24px;max-height:140px;padding:0;font:inherit;line-height:var(--leading-normal);color:var(--fg-primary, var(--text-primary));background:transparent;border:0;outline:none;resize:none;overflow-y:auto;-webkit-appearance:none;appearance:none}.mentality-overlay__textarea:disabled{opacity:.55;cursor:not-allowed}.mentality-overlay__textarea::placeholder{color:var(--fg-muted, var(--text-muted))}.mentality-overlay__actions{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs);padding-top:2px}.mentality-overlay__actions-left{display:flex;align-items:center;gap:2px}.mentality-overlay__action{display:grid;place-items:center;width:30px;height:30px;padding:0;border:0;background:transparent;border-radius:var(--r-sm, var(--radius-md));color:var(--fg-muted, var(--text-muted));cursor:pointer;transition:background .12s ease,color .12s ease}.mentality-overlay__action:hover:not(:disabled){background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.mentality-overlay__action:disabled{opacity:.55;cursor:not-allowed}.mentality-overlay__action.is-active{color:var(--brand, var(--primary));background:var(--brand-soft, var(--primary-15))}.mentality-overlay__send{display:grid;place-items:center;width:32px;height:32px;padding:0;border:0;border-radius:var(--radius-md);background:var(--fg-primary);color:var(--fg-inverse);cursor:pointer;transition:opacity .12s ease,background .12s ease;flex-shrink:0}.mentality-overlay__send:hover:not(:disabled){opacity:.8}.mentality-overlay__send:disabled{background:var(--text-muted, var(--fg-muted));opacity:.3;cursor:not-allowed}.mentality-overlay__send-spin{animation:mentality-overlay__spin .9s linear infinite}@keyframes mentality-overlay__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mentality-overlay__file-input{display:none}.mentality-overlay__chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.mentality-overlay__chip{display:inline-flex;align-items:center;gap:6px;padding:var(--space-xs) var(--space-sm) var(--space-xs) var(--space-sm);max-width:100%;font-size:var(--text-xs);font-weight:var(--fw-medium);background:var(--bg-subtle);color:var(--fg-primary, var(--text-primary));border:1px solid var(--border-subtle, var(--border-color));border-radius:var(--radius-pill)}.mentality-overlay__chip.is-loading{color:var(--fg-muted, var(--text-muted))}.mentality-overlay__chip.is-error{background:color-mix(in oklch,var(--danger, var(--danger)) 10%,transparent);border-color:color-mix(in oklch,var(--danger, var(--danger)) 30%,transparent);color:var(--danger, var(--danger))}.mentality-overlay__chip-name{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mentality-overlay__chip-meta{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:.05em;text-transform:uppercase;color:var(--fg-muted, var(--text-muted))}.mentality-overlay__chip-remove{display:grid;place-items:center;width:18px;height:18px;padding:0;margin-left:2px;border:0;background:transparent;border-radius:var(--radius-pill);color:inherit;opacity:.75;cursor:pointer;transition:opacity .12s ease,background .12s ease}.mentality-overlay__chip-remove:hover{opacity:1;background:var(--bg-hover)}.mentality-overlay__attach{display:grid;place-items:center;width:32px;height:32px;flex-shrink:0;border-radius:var(--r-sm, var(--radius-md));border:1px solid var(--border-subtle, var(--border-color));background:var(--bg-subtle);color:var(--fg-muted, var(--text-muted));cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.mentality-overlay__attach:hover:not(:disabled){background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.mentality-overlay__attach:disabled{opacity:.55;cursor:not-allowed}.mentality-overlay__attach.is-active{background:var(--brand-soft, var(--primary-15));color:var(--brand-soft-fg, var(--primary-light));border-color:color-mix(in oklch,var(--brand, var(--primary)) 30%,transparent)}.mentality-overlay__foot-note{font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wide);color:var(--fg-muted, var(--text-muted));margin:0}@media(max-width:820px){.mentality-overlay{right:10px;left:10px;bottom:10px;width:auto}.mentality-overlay__fab{right:12px}}@media(prefers-reduced-motion:reduce){.mentality-overlay{animation:none}.mentality-overlay__fab{transition:none}.mentality-overlay__fab:hover{transform:none}}.layout{display:flex;width:100%;overflow:hidden;overscroll-behavior:none;position:fixed;inset:0;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);background:transparent}.safari-tint-top{position:fixed;top:0;left:0;right:0;height:calc(env(safe-area-inset-top,0px) + 8px);background-color:var(--bg-app);-webkit-mask-image:linear-gradient(to bottom,black calc(100% - 8px),transparent);mask-image:linear-gradient(to bottom,black calc(100% - 8px),transparent);z-index:9998;pointer-events:none}.safari-tint-bottom{position:fixed;bottom:0;left:0;right:0;height:calc(env(safe-area-inset-bottom,0px) + 8px);background-color:var(--bg-app);-webkit-mask-image:linear-gradient(to top,black calc(100% - 8px),transparent);mask-image:linear-gradient(to top,black calc(100% - 8px),transparent);z-index:9998;pointer-events:none}.layout-main{flex:1;display:flex;flex-direction:column;min-width:0;position:relative;margin-left:var(--sidebar-width);transition:margin-left var(--transition-normal)}.layout-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.sidebar-overlay{display:none}@media(max-width:820px){.layout-main,.layout-main.sidebar-collapsed{margin-left:0;width:100%;height:100%;overflow:hidden}.sidebar-overlay{display:block;position:fixed;inset:0;background:var(--overlay-bg);-webkit-backdrop-filter:var(--overlay-blur);backdrop-filter:var(--overlay-blur);z-index:999;animation:overlayFadeIn .2s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}}.streaming-cursor{display:inline-block;width:8px;height:1em;margin-left:2px;vertical-align:text-bottom;background:var(--primary-light, currentColor);border-radius:2px;animation:streaming-cursor-blink 1.1s steps(2,start) infinite}@keyframes streaming-cursor-blink{0%,49%{opacity:1}50%,to{opacity:0}}.streaming-pulse{display:inline-block;width:36px;height:14px;border-radius:var(--radius-pill, var(--radius-pill));background:var(--bg-hover, rgba(255, 255, 255, .08));animation:streaming-pulse-fade 1.2s ease-in-out infinite}@keyframes streaming-pulse-fade{0%,to{opacity:.35;transform:scale(.96)}50%{opacity:1;transform:scale(1)}}@media(prefers-reduced-motion:reduce){.streaming-cursor,.streaming-pulse{animation:none}.streaming-cursor{opacity:.8}}.message-bubble{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.user-bubble{display:flex;justify-content:flex-end}.user-bubble .message-content{max-width:70%;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--fg-on-brand);border-radius:18px 18px 4px;font-size:var(--font-base);line-height:var(--leading-normal);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-md)}.message-files{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-top:var(--space-xs)}.message-file-item{text-decoration:none;color:inherit;transition:transform .2s ease}.message-file-item:hover{transform:scale(1.02)}.file-thumbnail{width:120px;height:120px;border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.2);background:#0000001a}.file-thumbnail img{width:100%;height:100%;object-fit:cover}.image-loading{width:100%;height:100%;background:#ffffff0d;position:relative;overflow:hidden}.image-loading:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{to{left:100%}}.image-error{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#ffffff0d;color:var(--text-muted)}.file-stub{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);max-width:200px}.file-stub svg{flex-shrink:0;opacity:.9}.file-name{font-size:var(--font-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:var(--fw-medium)}.assistant-bubble{display:flex;align-items:flex-start;gap:var(--space-md)}.avatar{width:40px;height:40px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.assistant-avatar{background:transparent!important;border-radius:0!important;box-shadow:none!important;padding:0;border:none}.assistant-avatar-image{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 8px rgba(139,92,246,.4)) drop-shadow(0 4px 12px rgba(168,85,247,.3)) drop-shadow(0 1px 3px rgba(0,0,0,.2))}.message-wrapper{max-width:70%}.sender-name{display:block;font-size:var(--font-sm);font-weight:var(--fw-semibold);color:var(--primary-light);margin-bottom:6px}.assistant-bubble .message-content{padding:14px 18px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:4px 18px 18px;font-size:var(--font-base);line-height:var(--leading-relaxed);color:var(--text-primary)}.assistant-bubble .message-content.typing-only{padding:10px var(--space-md);width:fit-content;max-width:240px;background:linear-gradient(135deg,#8b5cf62e,#ea580c1f);border:1px solid rgba(139,92,246,.22);box-shadow:0 10px 24px #00000038,0 0 22px #8b5cf61f}.assistant-bubble .message-content strong{color:var(--primary-light);font-weight:var(--fw-semibold)}.assistant-bubble .message-content code{background:#8b5cf626;color:var(--accent);padding:2px 6px;border-radius:4px;font-size:.9em;font-family:Monaco,Menlo,monospace}.assistant-bubble .message-content p{margin:var(--space-sm) 0}.assistant-bubble .message-content p:first-child{margin-top:0}.assistant-bubble .message-content p:last-child{margin-bottom:0}.assistant-bubble .message-content h1,.assistant-bubble .message-content h2,.assistant-bubble .message-content h3,.assistant-bubble .message-content h4,.assistant-bubble .message-content h5,.assistant-bubble .message-content h6{margin:var(--space-lg) 0 var(--space-sm) 0;font-weight:var(--fw-semibold);color:var(--text-primary);line-height:var(--leading-snug)}.assistant-bubble .message-content h1:first-child,.assistant-bubble .message-content h2:first-child,.assistant-bubble .message-content h3:first-child,.assistant-bubble .message-content h4:first-child,.assistant-bubble .message-content h5:first-child,.assistant-bubble .message-content h6:first-child{margin-top:0}.assistant-bubble .message-content h1{font-size:1.5em}.assistant-bubble .message-content h2{font-size:1.3em}.assistant-bubble .message-content h3{font-size:1.15em}.assistant-bubble .message-content h4,.assistant-bubble .message-content h5,.assistant-bubble .message-content h6{font-size:1em}.assistant-bubble .message-content ul,.assistant-bubble .message-content ol{margin:var(--space-md) 0;padding-left:var(--space-xl)}.assistant-bubble .message-content li{margin:6px 0;color:var(--text-secondary)}.assistant-bubble .message-content ul{list-style-type:disc}.assistant-bubble .message-content ol{list-style-type:decimal}.assistant-bubble .message-content ul ul,.assistant-bubble .message-content ol ol,.assistant-bubble .message-content ul ol,.assistant-bubble .message-content ol ul{margin-top:var(--space-xs);margin-bottom:var(--space-xs)}.assistant-bubble .message-content blockquote{margin:var(--space-md) 0;padding:var(--space-sm) var(--space-lg);border-left:3px solid var(--primary);background:#8b5cf614;border-radius:4px;color:var(--text-secondary)}.assistant-bubble .message-content a{color:var(--primary-light);text-decoration:underline}.assistant-bubble .message-content a:hover{color:var(--primary)}.assistant-bubble .message-content pre{margin:var(--space-md) 0;padding:var(--space-md);background:var(--bg-code);border-radius:var(--radius-sm);overflow-x:auto}.assistant-bubble .message-content pre code{background:transparent;padding:0;color:var(--text-secondary);font-size:.9em}.message-actions{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);opacity:1}.copy-btn,.message-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.copy-btn:hover,.message-action-btn:hover{background:var(--primary-15);color:var(--text-primary)}.typing-ellipsis{display:inline-block;vertical-align:middle}.typing-ellipsis .dot{display:none}.typing-ellipsis:after{content:"▍";display:inline-block;color:var(--primary-light);animation:cursorPulse 1s ease-in-out infinite;font-size:1em;line-height:var(--leading-none)}@keyframes cursorPulse{0%,to{opacity:1}50%{opacity:.2}}.tool-call-bubble{padding:2px 0}.tool-call-container{display:flex;flex-direction:column;gap:var(--space-xs)}.tool-call-card{display:flex;flex-direction:column;border-left:2px solid var(--primary-20);padding-left:var(--space-md);margin-left:var(--space-xs)}.tool-call-header{display:flex;align-items:center;gap:6px;font-size:var(--font-sm);color:var(--text-muted);background:none;border:none;padding:var(--space-xs) 0;cursor:pointer;text-align:left;transition:color var(--transition-fast)}.tool-call-header:hover{color:var(--text-secondary)}.tool-icon{display:flex;align-items:center;color:var(--primary-light)}.tool-icon svg{width:14px;height:14px}.tool-label{display:none}.tool-name{font-weight:var(--fw-medium);color:var(--text-secondary);font-size:var(--font-sm)}.tool-call-header .toggle-arrow{display:flex;align-items:center;margin-left:var(--space-xs);color:var(--text-muted);transition:transform var(--transition-fast)}.tool-call-header .toggle-arrow.expanded{transform:rotate(180deg)}.tool-args{padding:0;margin-top:var(--space-xs);animation:fadeIn .15s ease}.tool-args pre{margin:0;font-size:var(--font-xs);color:var(--text-muted);font-family:Monaco,Menlo,monospace;background:var(--bg-code);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);white-space:pre-wrap;word-break:break-word;overflow-x:auto;max-height:200px;overflow-y:auto}.tool-result-bubble{padding:2px 0}.tool-result-container{border-left:2px solid rgba(34,197,94,.3);padding-left:var(--space-md);margin-left:var(--space-xs)}.tool-result-toggle{display:flex;align-items:center;gap:6px;padding:var(--space-xs) 0;font-size:var(--text-xs);color:var(--text-muted);background:none;border:none;cursor:pointer;transition:color var(--transition-fast)}.tool-result-toggle:hover{color:var(--text-secondary)}.tool-result-icon{display:flex;align-items:center;color:var(--success-22)}.tool-result-label{display:flex;align-items:center;gap:var(--space-xs);font-weight:var(--fw-medium);font-size:var(--font-sm);color:var(--text-secondary)}.toggle-arrow{display:flex;align-items:center;transition:transform var(--transition-fast)}.toggle-arrow.expanded{transform:rotate(180deg)}.tool-result-content{margin-top:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow-x:auto;max-height:400px;overflow-y:auto}.tool-result-content pre{margin:0;font-size:var(--font-xs);color:var(--text-muted);font-family:Monaco,Menlo,monospace;white-space:pre-wrap;word-break:break-word}.tool-result-markdown{font-size:var(--font-md);line-height:var(--leading-relaxed);color:var(--text-primary)}.tool-result-markdown p{margin:var(--space-sm) 0}.tool-result-markdown p:first-child{margin-top:0}.tool-result-markdown h2{font-size:var(--font-lg);margin:var(--space-lg) 0 var(--space-sm);color:var(--primary-light)}.tool-result-markdown code{background:var(--bg-code);padding:2px 6px;border-radius:4px;font-size:var(--text-xs)}.tool-result-section{display:flex;flex-direction:column;gap:6px}.tool-result-section-label{font-size:var(--font-xs);font-weight:var(--fw-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.tool-result-content pre{margin:0;font-size:var(--text-xs);font-family:Monaco,Menlo,monospace;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto;background:var(--bg-code);padding:var(--space-sm);border-radius:4px}.tool-result-inputs{color:#8b5cf6e6}@media(max-width:820px){.user-bubble .message-content,.message-wrapper{max-width:85%}.tool-call-card{max-width:90%}.tool-args code{max-width:200px}}@media(max-width:480px){.user-bubble .message-content,.message-wrapper{max-width:90%}.avatar{width:32px;height:32px}.assistant-bubble .message-content,.user-bubble .message-content{padding:10px 14px;font-size:var(--font-md)}}.assistant-meta-chip{display:inline-flex;flex-wrap:wrap;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);padding:2px var(--space-sm);background:var(--bg-subtle);border:1px solid var(--border-color);border-radius:var(--radius-pill);font-size:var(--font-xs);color:var(--text-muted);font-variant-numeric:tabular-nums;line-height:var(--leading-snug);width:fit-content;max-width:100%}@media(max-width:480px){.assistant-meta-chip{display:none}}.typing-dots{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-lg)}.typing-dot{width:8px;height:8px;border-radius:50%;background:var(--fg-muted);animation:typing-bounce 1.4s ease-in-out infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}@media(prefers-reduced-motion:reduce){.typing-dot{animation:none;opacity:.6}}.chat-quota-banner{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:var(--bg-subtle);border-top:1px solid var(--warning);border-bottom:1px solid var(--border-subtle, var(--border-color));color:var(--fg-primary, var(--text-primary));font-size:var(--font-sm, var(--font-sm))}.chat-quota-banner--exhausted{background:color-mix(in oklch,var(--danger) 14%,var(--bg-surface));border-top-color:var(--danger);color:var(--danger)}.chat-quota-banner__text{flex:1;min-width:0}.chat-quota-banner__actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.chat-quota-banner__dismiss{background:transparent;border:none;color:inherit;font-size:inherit;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--r-sm, var(--radius-sm));opacity:.7}.chat-quota-banner__dismiss:hover{opacity:1;background:var(--bg-elevated, rgba(0,0,0,.04))}.chat-quota-banner__dismiss:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px;opacity:1}.chatroom{display:flex;flex-direction:column;height:100%;background:var(--bg-card);overflow:hidden;position:relative}.chatroom-header-title{display:flex;align-items:center;gap:var(--space-md);min-width:0}.chatroom-header-title__name{font-size:inherit;font-weight:inherit;color:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-project-label{display:flex;align-items:center;gap:var(--space-xs);margin-left:var(--space-md);padding:var(--space-xs) 10px;font-size:var(--text-xs);font-weight:var(--fw-medium);color:var(--primary-light);background:var(--primary-8);border-radius:var(--radius-pill)}.dm-avatar{width:32px;height:32px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:var(--font-md);font-weight:var(--fw-semibold);color:var(--fg-on-brand);position:relative;flex-shrink:0}.dm-avatar.online{box-shadow:var(--shadow-glow)}.dm-avatar .status-indicator{position:absolute;bottom:-2px;right:-2px;width:10px;height:10px;background:var(--success-22);border:2px solid var(--bg-elevated);border-radius:50%}.group-avatar-header{width:32px;height:32px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:var(--fg-on-brand);flex-shrink:0}.action-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:var(--text-secondary);background:var(--bg-hover);border:none;transition:all var(--transition-fast);cursor:pointer}.action-btn:hover{background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--fg-on-brand);box-shadow:var(--shadow-glow)}.action-btn.panel-toggle.active{background:#8b5cf633;border-color:var(--primary);color:var(--primary-light)}.panel-toggle-tooltip{position:fixed;transform:translate(-100%,-50%);padding:6px var(--space-md);border-radius:var(--radius-md);background:var(--bg-elevated);border:1px solid var(--border-color);color:var(--fg-secondary);font-size:var(--text-xs);font-weight:var(--fw-semibold);white-space:nowrap;pointer-events:none;z-index:1002}.action-btn.profile-btn{display:none}@media(max-width:820px){.action-btn.profile-btn{display:flex}.header-actions>.action-btn:not(.panel-toggle,.profile-btn){display:none}}.messages-area{flex:1;overflow-y:auto;padding:var(--space-xl);padding-bottom:var(--space-2xl);display:flex;flex-direction:column;position:relative}.messages-list{display:flex;flex-direction:column;gap:var(--space-lg)}.chatroom--empty{align-items:center;overflow:hidden}.chatroom--empty .surface-header{align-self:stretch}.chatroom--empty .messages-area{display:none}.chatroom--empty .empty-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 var(--space-xl) var(--space-lg);width:100%;max-width:768px;margin-top:auto}.chatroom--empty .input-area{width:100%;max-width:768px;margin-bottom:auto}.empty-welcome .chiefy-mascot{width:80px;height:80px;margin-bottom:var(--space-lg)}.welcome-title{font-size:var(--font-2xl);font-weight:var(--fw-bold);background:linear-gradient(135deg,var(--primary-light),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 var(--space-sm)}.welcome-subtitle{font-size:var(--font-md);color:var(--text-muted);margin:0}.welcome-starters{display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:center;margin-top:var(--space-xl);max-width:640px}.welcome-starter{padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-primary);font-family:inherit;font-size:var(--font-sm);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.welcome-starter:hover{background:var(--primary-15);border-color:var(--primary-25)}.welcome-starter:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px}.chatroom .empty-state{padding:var(--space-3xl)}.chiefy-mascot{width:200px;height:200px;object-fit:contain;margin-bottom:var(--space-xl)}@media(max-width:820px){.chiefy-mascot{width:120px;height:120px;margin-bottom:var(--space-lg)}}.empty-icon{font-size:var(--text-5xl);margin-bottom:var(--space-xl);opacity:.5}.chatroom .empty-state h2{font-size:var(--font-2xl);font-weight:var(--fw-bold);background:linear-gradient(135deg,var(--primary-light),#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.empty-state p{font-size:var(--font-md);color:var(--text-secondary)}@media(max-width:820px){.empty-state{padding:var(--space-xl)}.empty-state h2{font-size:var(--text-lg);margin-bottom:6px}.empty-state p{font-size:var(--font-sm)}.empty-icon{font-size:var(--text-4xl);margin-bottom:var(--space-lg)}}.scroll-to-bottom-btn{position:absolute;bottom:168px;inset-inline:0;margin-inline:auto;width:32px;height:32px;border-radius:50%;background:var(--bg-elevated);border:none;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background var(--transition-fast),color var(--transition-fast);transition:all var(--transition-fast);animation:fadeIn .2s ease}.scroll-to-bottom-btn:hover{background:var(--primary);color:var(--fg-on-brand);border-color:var(--primary)}.chat-turn-controls{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-lg);min-height:36px}.chat-turn-controls--subtle{min-height:28px;padding:2px var(--space-lg)}.chat-turn-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);font-family:inherit;font-size:var(--font-sm);font-weight:var(--fw-medium);color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-pill);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.chat-turn-btn:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--primary-25, var(--border-color))}.chat-turn-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--primary-25)}.chat-turn-btn--stop{color:var(--text-primary);border-color:var(--primary-25);background:var(--primary-15, var(--bg-elevated))}.chat-turn-btn--ghost{background:transparent;border-color:transparent;color:var(--text-muted);padding:2px var(--space-sm)}.chat-turn-btn--ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}.chat-footer{display:flex;align-items:center;justify-content:center;padding:6px var(--space-xl) var(--space-md);padding-bottom:max(var(--space-md),env(safe-area-inset-bottom,0px))}.ai-disclosure{margin:0;font-size:var(--text-xs);color:var(--fg-muted);text-align:center;line-height:var(--leading-none)}@media(max-width:480px){.chat-footer{padding:var(--space-xs) var(--space-lg) var(--space-sm);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom,0px))}.ai-disclosure{font-size:var(--text-xs)}}.input-area{position:relative;padding:var(--space-sm) var(--space-lg) 0}.input-area:before{content:"";position:absolute;top:-32px;left:0;right:0;height:32px;background:linear-gradient(to bottom,transparent,var(--bg-app));pointer-events:none}.input-container{display:flex;flex-direction:column;gap:0;max-width:768px;margin:0 auto;padding:10px var(--space-lg) 6px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:20px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input-container:focus-within{border-color:var(--primary-25, rgba(124, 58, 237, .25));box-shadow:0 0 0 3px #7c3aed14}.chat-input{width:100%;min-height:24px;max-height:160px;padding:0;font-size:var(--font-lg);line-height:var(--leading-normal);color:var(--text-primary);font-family:inherit;background:transparent;outline:none!important;border:none!important;box-shadow:none!important;resize:none;overflow-y:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none}.chat-input:focus,.chat-input:focus-visible,.chat-input:active{outline:none!important;border:none!important;box-shadow:none!important}.chat-input::placeholder{color:var(--text-muted)}.input-bottom-row{display:flex;align-items:center;justify-content:space-between;padding-top:var(--space-xs)}.input-actions-left{display:flex;align-items:center;gap:var(--space-xs)}.input-action{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;background:none;border:none;cursor:pointer}.input-action:hover{background:var(--bg-hover);color:var(--text-secondary)}.input-chip{display:inline-flex;align-items:center;gap:var(--space-sm);padding:6px 6px 6px var(--space-md);font-size:var(--font-sm);font-weight:var(--fw-medium);border-radius:var(--radius-pill);max-width:280px;animation:fadeIn .15s ease}@media(max-width:480px){.input-chip{max-width:200px}}.input-chip svg:first-child{flex-shrink:0;opacity:.7}.input-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.input-chip-remove{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:none;border:none;color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.input-chip-remove:hover{background:var(--primary-20);color:var(--text-primary)}.input-chip--project{color:var(--primary-light);background:var(--primary-8);border:1px solid var(--primary-15)}.input-chip--file{color:var(--text-primary);background:var(--primary-10);border:1px solid var(--primary-20)}.input-action.attach-toggle.active{background:var(--primary-12);color:var(--primary-light);transform:rotate(45deg)}.attach-menu-container{position:relative}.attach-menu{position:absolute;bottom:calc(100% + 8px);left:0;min-width:220px;background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-xs);animation:attachMenuIn .15s ease;overscroll-behavior:contain;touch-action:none;z-index:100}@keyframes attachMenuIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.attach-menu-item{display:flex;align-items:center;gap:var(--space-md);width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-md);font-weight:var(--fw-medium);color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.attach-menu-item:hover{background:var(--primary-8);color:var(--text-primary)}.attach-menu-item svg{color:var(--text-muted);flex-shrink:0}.attach-menu-item:hover svg{color:var(--primary-light)}.attach-menu-chevron{margin-left:auto;color:var(--text-muted)}.attach-menu-divider{height:1px;background:var(--border-color);margin:var(--space-xs) 0}.attach-submenu{animation:fadeIn .15s ease}.attach-menu-back{color:var(--text-muted)!important;font-size:var(--font-sm)!important}.attach-menu-item.active{background:var(--primary-10);color:var(--primary-light)}.attach-menu-create{color:var(--primary-light)!important}@media(max-width:820px){.attach-menu-container{position:static}.attach-menu{position:fixed;bottom:0;left:0;right:0;min-width:unset;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-md);padding-bottom:max(var(--space-md),env(safe-area-inset-bottom,var(--space-md)));animation:attachMenuSlideUp .2s ease;z-index:1001}.attach-menu-container:has(.attach-menu):before{content:"";position:fixed;inset:0;background:#0006;z-index:1000;animation:overlayFadeIn .2s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.attach-menu:before{content:"";display:block;width:36px;height:4px;background:var(--text-muted);border-radius:2px;margin:0 auto var(--space-sm)}@keyframes attachMenuSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.attach-menu-item{padding:14px var(--space-lg);font-size:var(--font-lg)}}.send-btn{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--fg-primary);color:var(--fg-inverse);transition:all var(--transition-fast);flex-shrink:0;border:none;cursor:pointer}.send-btn:hover:not(:disabled){opacity:.8}.send-btn:disabled{background:var(--text-muted);opacity:.3;cursor:not-allowed}.input-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-sm)}@media(max-width:820px){.messages-area{padding:var(--space-lg)}.input-area{padding:var(--space-sm) var(--space-md);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom,var(--space-sm)))}.input-container{margin:0}.input-action:last-of-type{display:flex}}@media(max-width:480px){.input-area{padding:var(--space-sm) var(--space-md);padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom,var(--space-sm)))}.input-container{margin:0 var(--space-xs)}.chat-input{font-size:var(--font-lg)}}.checkout-success{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-md);padding:var(--space-lg) 0}.checkout-success__icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--primary-15),rgba(124,58,237,.05));color:var(--primary)}.checkout-success__title{font-size:var(--text-xl);font-weight:var(--fw-bold);color:var(--text-primary);margin:0}.checkout-success__desc{font-size:var(--font-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);margin:0;max-width:280px}.networking-dm-frame{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;padding:var(--space-md)}.networking-dm-frame>.conv-detail{flex:1 1 auto;min-height:0}:focus,:focus-visible{outline:none}input:focus,textarea:focus,select:focus{outline:none;box-shadow:none}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit;border:none;outline:none;background:none}.suspense-loader{flex:1;display:flex;align-items:center;justify-content:center;color:var(--fg-muted)}.session-warning{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.6rem 1rem;background:var(--primary, var(--primary));color:var(--fg-on-brand);font-size:var(--text-sm);font-weight:var(--fw-medium);text-align:center;z-index:9999;flex-shrink:0}.session-warning button{padding:.25rem .75rem;background:#fff3;color:var(--fg-on-brand);border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-sm, var(--radius-sm));font-size:var(--text-xs);font-weight:var(--fw-semibold);cursor:pointer}.session-warning button:hover{background:#ffffff59}.offline-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;background:var(--badge-warning, var(--warning));color:var(--fg-primary);font-size:var(--text-sm);font-weight:var(--fw-semibold);text-align:center;z-index:9999;flex-shrink:0}.auth-gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:2rem;z-index:9999;background:var(--bg-dark);overflow:hidden}.auth-gate:before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.15),transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.auth-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--space-lg);padding:40px var(--space-2xl);border-radius:var(--radius-xl);position:relative;background:var(--bg-elevated);border:1px solid var(--border-color);box-shadow:var(--shadow-md);max-width:480px;width:100%}.auth-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:var(--primary-10);flex-shrink:0}.auth-icon svg{width:32px;height:32px}.auth-card.checking .auth-icon{color:var(--violet-400)}.auth-card.forbidden .auth-icon{color:var(--warning);background:#f59e0b1a}.auth-card.error .auth-icon{color:var(--danger);background:#ef44441a}.auth-title{font-weight:var(--fw-bold);font-size:var(--text-2xl);color:var(--text-primary);margin:0}.auth-subtitle{font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--text-secondary);margin:0}.auth-actions{display:flex;gap:var(--space-md);margin-top:var(--space-sm)}.auth-btn-primary{display:inline-flex;align-items:center;padding:.75rem 1.75rem;background:linear-gradient(to right,var(--primary),var(--primary-light));border:1px solid var(--primary-30);border-radius:var(--radius-pill);color:var(--bg-surface);font-size:var(--text-md);font-weight:var(--fw-semibold);text-decoration:none;cursor:pointer;transition:all .2s ease}.auth-btn-primary:hover{opacity:.9;box-shadow:var(--shadow-primary);transform:scale(1.02)}.auth-btn-secondary{display:inline-flex;align-items:center;padding:.75rem 1.75rem;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-pill);color:var(--text-secondary);font-size:var(--text-md);font-weight:var(--fw-medium);text-decoration:none;cursor:pointer;transition:all .2s ease}.auth-btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-active);color:var(--text-primary);transform:scale(1.02)}.spin{animation:auth-rotate 1.2s linear infinite}@keyframes auth-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--primary: #7c3aed;--primary-light: #9333ea;--primary-dark: #6d28d9;--accent: #9333ea;--primary-5: rgba(139, 92, 246, .05);--primary-8: rgba(139, 92, 246, .08);--primary-10: rgba(139, 92, 246, .1);--primary-12: rgba(139, 92, 246, .12);--primary-15: rgba(139, 92, 246, .15);--primary-20: rgba(139, 92, 246, .2);--primary-25: rgba(139, 92, 246, .25);--primary-30: rgba(139, 92, 246, .3);--primary-35: rgba(139, 92, 246, .35);--success: #10b981;--success-22: #22c55e;--warning: #eab308;--danger: #ef4444;--info: var(--primary-light);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Space Grotesk", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--text-3xs: 9px;--text-2xs: 10px;--text-xs: 11px;--text-sm: 13px;--text-md: 14px;--text-base: 15px;--text-lg: 16px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 40px;--text-5xl: 56px;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--leading-none: 1;--leading-tight: 1.2;--leading-snug: 1.3;--leading-normal: 1.45;--leading-relaxed: 1.55;--leading-loose: 1.65;--tracking-tight: -.02em;--tracking-snug: -.01em;--tracking-normal: 0;--tracking-wide: .02em;--tracking-wider: .08em;--tracking-widest: .12em;--r-xs: 6px;--r-sm: 8px;--r-md: 12px;--r-lg: 16px;--r-xl: 20px;--r-2xl: 24px;--r-pill: 9999px;--violet-400: #a78bfa;--violet-500: var(--primary);--violet-700: var(--primary-dark)}:root,[data-theme=dark]{color-scheme:dark;--bg-app: #0a0415;--bg-canvas: #120825;--bg-surface: #1d0b39;--bg-elevated: #1e0a3a;--bg-subtle: #1a0f2e;--bg-sunken: #0a0415;--bg-hover: rgba(255, 255, 255, .05);--bg-active: rgba(255, 255, 255, .08);--bg-inverse: #fdf8ef;--fg-primary: #ffffff;--fg-secondary: rgba(255, 255, 255, .7);--fg-muted: rgba(255, 255, 255, .45);--fg-subtle: rgba(255, 255, 255, .3);--fg-disabled: rgba(255, 255, 255, .35);--fg-placeholder: var(--fg-muted);--fg-inverse: #1a1028;--fg-brand: var(--primary-light);--fg-on-brand: #ffffff;--fg-danger: var(--danger);--fg-success: var(--success);--fg-warning: var(--warning);--fg-link: var(--primary-light);--fg-link-hover: var(--primary);--border-subtle: rgba(255, 255, 255, .08);--border-default: var(--primary-15);--border-strong: var(--primary-35);--border-brand: var(--primary-35);--brand: var(--primary);--brand-hover: var(--primary-light);--brand-soft: var(--primary-15);--brand-soft-fg: #d9c7ff;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .48);--shadow-glow: 0 0 20px var(--primary-25);--grid-line: rgba(255, 255, 255, .05);--text-primary: var(--fg-primary);--text-secondary: var(--fg-secondary);--text-muted: var(--fg-muted)}[data-theme=light]{color-scheme:light;--bg-app: #f7f0e5;--bg-canvas: #ece3d3;--bg-surface: #fdf8ef;--bg-elevated: #ffffff;--bg-subtle: #ece3d3;--bg-sunken: #e5d9c2;--bg-hover: rgba(124, 58, 237, .06);--bg-active: rgba(124, 58, 237, .1);--bg-inverse: #1a1028;--fg-primary: #1a1028;--fg-secondary: rgba(26, 16, 40, .65);--fg-muted: rgba(26, 16, 40, .4);--fg-subtle: rgba(26, 16, 40, .28);--fg-disabled: rgba(26, 16, 40, .32);--fg-placeholder: var(--fg-muted);--fg-inverse: #f7f0e5;--fg-brand: var(--primary-dark);--fg-on-brand: #ffffff;--fg-danger: var(--danger);--fg-success: var(--success);--fg-warning: var(--warning);--fg-link: var(--primary-dark);--fg-link-hover: var(--primary);--border-subtle: rgba(26, 16, 40, .08);--border-default: rgba(124, 58, 237, .18);--border-strong: rgba(124, 58, 237, .4);--border-brand: rgba(124, 58, 237, .4);--brand: var(--primary);--brand-hover: var(--primary-dark);--brand-soft: rgba(124, 58, 237, .1);--brand-soft-fg: #5b21b6;--shadow-xs: 0 1px 2px rgba(26, 16, 40, .04);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(124, 58, 237, .15);--grid-line: rgba(26, 16, 40, .05);--text-primary: var(--fg-primary);--text-secondary: var(--fg-secondary);--text-muted: var(--fg-muted)}html,body{margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.55;color:var(--fg-primary);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"cv11","ss01","ss03"}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;margin:0;color:var(--fg-primary);text-wrap:balance}p{margin:0;text-wrap:pretty}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:none;border:0;padding:0}a{color:var(--brand);text-decoration:none}code,pre,.mono{font-family:var(--font-mono);font-size:.92em}svg{display:block}.hairline-x{background:var(--border-subtle);height:1px;width:100%}.hairline-y{background:var(--border-subtle);width:1px}.mono{font-family:var(--font-mono);letter-spacing:-.01em}.display{font-family:var(--font-display)}.muted{color:var(--fg-muted)}.sub{color:var(--fg-secondary)}.eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-muted)}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;color:var(--fg-secondary);background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--r-xs)}.tag--brand{color:var(--brand-soft-fg);background:var(--brand-soft);border-color:var(--border-brand)}.tag--success{color:var(--success);background:color-mix(in oklch,var(--success) 14%,transparent);border-color:transparent}.tag--warning{color:var(--warning);background:color-mix(in oklch,var(--warning) 14%,transparent);border-color:transparent}.tag--danger{color:var(--danger);background:color-mix(in oklch,var(--danger) 14%,transparent);border-color:transparent}.tag--info{color:var(--info);background:color-mix(in oklch,var(--info) 14%,transparent);border-color:transparent}.ui{--ui-side: 232px;--ui-top: 52px;background:var(--bg-app);color:var(--fg-primary);font-family:var(--font-sans);font-size:var(--text-sm);line-height:var(--leading-normal);display:grid;grid-template-columns:var(--ui-side) 1fr;min-height:620px;position:relative}.ui--compact{font-size:11.5px;--ui-side: 200px}.ui--collapsed{--ui-side: 56px}.ui-side{background:var(--bg-canvas);border-right:1px solid var(--border-subtle);padding:14px 10px;display:flex;flex-direction:column;gap:14px;overflow:hidden}.ui-brand{display:flex;align-items:center;gap:9px;padding:2px 6px 6px}.ui-brand__mark{width:22px;height:22px;border-radius:6px;background:linear-gradient(135deg,var(--violet-500),var(--violet-700));display:grid;place-items:center;color:var(--fg-on-brand);font-family:var(--font-display);font-weight:var(--fw-bold);font-size:var(--text-xs);box-shadow:inset 0 1px #ffffff4d}.ui-brand__text{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em}.ui-brand__text small{display:block;color:var(--fg-muted);font-size:10px;font-weight:400;font-family:var(--font-mono)}.ui-side__section{display:flex;flex-direction:column;gap:1px}.ui-side__label{font-family:var(--font-mono);font-size:var(--text-3xs);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--fg-muted);padding:2px 8px 4px}.ui-nav{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:var(--r-sm);color:var(--fg-secondary);font-size:var(--text-sm)}.ui-nav__icon{width:16px;height:16px;flex-shrink:0;color:var(--fg-muted)}.ui-nav:hover{background:var(--bg-hover);color:var(--fg-primary)}.ui-nav.is-active{background:var(--brand-soft);color:var(--brand-soft-fg);font-weight:var(--fw-medium)}.ui-nav.is-active .ui-nav__icon{color:var(--brand)}.ui-nav__count{margin-left:auto;font-family:var(--font-mono);font-size:var(--text-2xs);color:var(--fg-muted);padding:1px 6px;background:var(--bg-subtle);border-radius:var(--r-pill)}.ui-nav.is-active .ui-nav__count{color:var(--brand);background:color-mix(in oklch,var(--brand) 15%,transparent)}.ui-nav--sub{padding-left:30px;font-size:var(--text-xs);color:var(--fg-muted)}.ui-side__foot{margin-top:auto;padding-top:10px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:9px}.ui-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--violet-400),var(--violet-700));color:var(--fg-on-brand);display:grid;place-items:center;font-size:10.5px;font-weight:600;flex-shrink:0}.ui-avatar--xs{width:20px;height:20px;font-size:9px}.ui-avatar--sm{width:22px;height:22px;font-size:9.5px}.ui-avatar--md{width:32px;height:32px;font-size:12px}.ui-avatar--lg{width:44px;height:44px;font-size:16px}.ui-main{display:flex;flex-direction:column;min-width:0}.ui-top{height:var(--ui-top);padding:0 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:12px;background:var(--bg-canvas)}.ui-top__crumbs{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-muted);display:flex;align-items:center;gap:6px}.ui-top__crumbs b{color:var(--fg-primary);font-weight:500}.ui-top__search{margin-left:auto;display:flex;align-items:center;gap:8px;padding:5px 10px;border:1px solid var(--border-default);border-radius:var(--r-sm);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--fg-muted);background:var(--bg-subtle);min-width:220px}.ui-top__search kbd{font-family:var(--font-mono);font-size:var(--text-2xs);padding:1px 5px;border-radius:4px;border:1px solid var(--border-default);background:var(--bg-surface);color:var(--fg-secondary);margin-left:auto}.ui-top__icon{width:28px;height:28px;display:grid;place-items:center;border-radius:var(--r-sm);color:var(--fg-muted)}.ui-top__icon:hover{background:var(--bg-hover);color:var(--fg-primary)}.ui-subnav{display:flex;gap:2px;padding:0 16px;border-bottom:1px solid var(--border-subtle);background:var(--bg-canvas)}.ui-subnav__item{padding:10px 12px;font-size:var(--text-sm);color:var(--fg-muted);border-bottom:2px solid transparent;margin-bottom:-1px}.ui-subnav__item.is-active{color:var(--fg-primary);border-bottom-color:var(--brand);font-weight:var(--fw-medium)}.ui-canvas{padding:20px 24px;flex:1;overflow:auto;display:flex;flex-direction:column;gap:16px}.ui-canvas--split{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;padding:20px 24px}.ui-ph{display:flex;align-items:end;gap:12px;justify-content:space-between}.ui-ph__title{font-family:var(--font-display);font-size:22px;font-weight:600;letter-spacing:-.02em}.ui-ph__sub{color:var(--fg-muted);font-size:12.5px;margin-top:2px}.ui-card{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--r-md);padding:14px}.ui-card--empty{border-style:dashed;border-color:var(--border-subtle);background:transparent}.ui-card__label{font-family:var(--font-mono);font-size:var(--text-2xs);text-transform:uppercase;letter-spacing:var(--tracking-widest);color:var(--fg-muted)}.ui-card__value{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-tight);margin-top:2px}.ui-card__trend{font-size:11px;font-family:var(--font-mono);color:var(--success)}.ui-card__trend.is-down{color:var(--danger)}.ui-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;font-size:var(--text-sm);font-weight:var(--fw-medium);border-radius:var(--r-sm);border:1px solid var(--border-default);background:var(--bg-surface);color:var(--fg-primary)}.ui-btn--primary{background:var(--brand);color:var(--fg-on-brand);border-color:transparent;box-shadow:var(--shadow-xs)}.ui-btn--ghost{background:transparent;border-color:transparent;color:var(--fg-secondary)}.ui-btn--sm{padding:4px 9px;font-size:11.5px}.ph{background:repeating-linear-gradient(135deg,var(--bg-subtle) 0 10px,var(--bg-sunken) 10px 11px);border:1px solid var(--border-subtle);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:var(--text-2xs);color:var(--fg-muted);letter-spacing:var(--tracking-wider);text-transform:uppercase}.ph--sq{aspect-ratio:1}.ph--wide{aspect-ratio:16/9}.pbar{height:6px;border-radius:999px;background:var(--bg-subtle);overflow:hidden}.pbar__fill{height:100%;background:linear-gradient(90deg,var(--violet-500),var(--violet-400));border-radius:inherit}.chip{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;font-size:var(--text-xs);font-family:var(--font-mono);color:var(--fg-secondary);background:var(--bg-subtle);border-radius:var(--r-pill);border:1px solid var(--border-subtle)}.chip--brand{color:var(--brand-soft-fg);background:var(--brand-soft);border-color:var(--border-brand)}.chip--success{color:var(--success);background:color-mix(in oklch,var(--success) 14%,transparent);border-color:transparent}.chip--warn{color:var(--warning);background:color-mix(in oklch,var(--warning) 14%,transparent);border-color:transparent}.chip--danger{color:var(--danger);background:color-mix(in oklch,var(--danger) 14%,transparent);border-color:transparent}.chip__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-sm)}.row:hover{background:var(--bg-hover)}.row__name{font-weight:500}.row__meta{color:var(--fg-muted);font-size:11px}.tbl{width:100%;border-collapse:collapse;font-size:12px}.tbl th{text-align:left;font-family:var(--font-mono);font-size:var(--text-2xs);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted);font-weight:var(--fw-medium);padding:6px 10px;border-bottom:1px solid var(--border-subtle)}.tbl td{padding:9px 10px;border-bottom:1px solid var(--border-subtle)}.tbl tr:last-child td{border-bottom:0}.tbl tr:hover td{background:var(--bg-hover)}.ui-input,.ui-textarea,.ui-select{width:100%;padding:var(--space-md) var(--space-lg);font-size:var(--font-md);font-family:inherit;color:var(--text-primary);background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-md);outline:none;min-height:44px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-sizing:border-box}.ui-input:hover,.ui-textarea:hover,.ui-select:hover{border-color:var(--border-strong, var(--border-color))}.ui-input:focus-visible,.ui-textarea:focus-visible,.ui-select:focus-visible{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-15)}.ui-input::placeholder,.ui-textarea::placeholder{color:var(--text-muted)}.ui-textarea{min-height:96px;resize:vertical;line-height:var(--leading-normal)}.ui-select{appearance:none;padding-right:var(--space-xl);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='none' stroke='%239ca3af' stroke-width='1.5' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;background-size:12px auto}.ui-input:disabled,.ui-textarea:disabled,.ui-select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-subtle)}.ui-status-chip{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--fw-semibold);letter-spacing:var(--tracking-wide);text-transform:uppercase;border-radius:var(--r-pill, 9999px);flex-shrink:0;line-height:var(--leading-tight);white-space:nowrap}.ui-status-chip--neutral{background:var(--bg-subtle);color:var(--fg-secondary, var(--text-secondary))}.ui-status-chip--brand{background:var(--brand-soft, var(--primary-15));color:var(--brand-soft-fg, var(--primary-light))}.ui-status-chip--success{background:color-mix(in oklch,var(--success) 14%,transparent);color:var(--success)}.ui-status-chip--warning{background:color-mix(in oklch,var(--warning) 16%,transparent);color:var(--warning)}.ui-status-chip--danger{background:color-mix(in oklch,var(--danger) 12%,transparent);color:var(--danger)}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffe6;background-color:#0a0415;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary: #7c3aed;--primary-light: #9333ea;--primary-dark: #6d28d9;--accent: #9333ea;--primary-5: rgba(139, 92, 246, .05);--primary-8: rgba(139, 92, 246, .08);--primary-10: rgba(139, 92, 246, .1);--primary-12: rgba(139, 92, 246, .12);--primary-15: rgba(139, 92, 246, .15);--primary-20: rgba(139, 92, 246, .2);--primary-25: rgba(139, 92, 246, .25);--primary-30: rgba(139, 92, 246, .3);--primary-35: rgba(139, 92, 246, .35);--bg-dark: #0a0415;--bg-mid: #1e0a3a;--bg-card: #120825;--bg-elevated: #1d0b39;--bg-section: #120825;--bg-hover: rgba(255, 255, 255, .05);--bg-active: rgba(255, 255, 255, .08);--bg-scrollbar: #1a0f2e;--bg-scrollbar-hover: #2a1a4e;--bg-code: rgba(0, 0, 0, .28);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .45);--border-color: var(--primary-15);--border-hover: var(--primary-35);--font-xs: 11px;--font-sm: 13px;--font-md: 14px;--font-base: 15px;--font-lg: 16px;--font-xl: 20px;--font-2xl: 24px;--font-brand: "Space Grotesk", system-ui, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--space-3xl: 40px;--space-4xl: 48px;--space-5xl: 64px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--space-sidebar-hairline: 6px;--space-sidebar-pad: 10px;--radius-sidebar: 10px;--radius-xl: 16px;--radius-2xl: 24px;--radius-pill: 9999px;--modal-w-xs: 360px;--modal-w-sm: 440px;--modal-w-md: 560px;--modal-w-lg: 720px;--modal-w-xl: 960px;--overlay-bg: rgba(0, 0, 0, .6);--overlay-blur: blur(4px);--sidebar-width: 280px;--sidebar-collapsed-width: 72px;--header-height: 64px;--bp-sm: 480px;--bp-md: 820px;--bp-mobile: 480px;--bp-tablet: 768px;--bp-desktop: 1024px;--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--success: #10b981;--level-low: #7a95b8;--level-low-bg: rgba(122, 149, 184, .18);--level-mid: #9d7cd8;--level-mid-bg: rgba(157, 124, 216, .18);--level-senior: #d4a84b;--level-senior-bg: rgba(212, 168, 75, .18);--transition-fast: .15s ease;--transition-default: .2s ease;--transition-normal: .25s ease;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .48);--shadow-glow: 0 0 20px var(--primary-25);--shadow-lift: 0 8px 24px rgba(0, 0, 0, .35), 0 0 0 1px var(--primary-20);--shadow-primary: 0 8px 24px var(--primary-25);--gradient-hero-bg: radial-gradient(at 0% 0%, var(--primary-15) 0%, transparent 48%), radial-gradient(at 100% 0%, rgba(147, 51, 234, .15) 0%, transparent 52%), radial-gradient(at 50% 100%, rgba(124, 58, 237, .08) 0%, transparent 55%);--gradient-celebration: radial-gradient(at 50% 0%, var(--primary-25) 0%, transparent 55%), linear-gradient(180deg, var(--bg-elevated), var(--bg-card));--pattern-dots: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, .04) 1px, transparent 0);--badge-success: #22c55e;--badge-success-bg: rgba(34, 197, 94, .15);--badge-warning: #eab308;--badge-warning-bg: rgba(234, 179, 8, .15);--badge-danger: #ef4444;--badge-danger-bg: rgba(239, 68, 68, .15);--badge-info: var(--primary);--badge-info-bg: var(--primary-15);--focus-ring: 0 0 0 3px var(--primary-35);scrollbar-color:var(--bg-scrollbar) var(--bg-dark);--skeleton-base: rgba(139, 92, 246, .12);--skeleton-highlight: rgba(139, 92, 246, .28);--skeleton-edge: rgba(139, 92, 246, .06);--skeleton-tint-bg: rgba(139, 92, 246, .12);--skeleton-tint-glow: rgba(139, 92, 246, .24);--skeleton-shimmer-duration: 1.5s;--skeleton-pulse-duration: 2.2s}[data-theme=light]{color-scheme:light;color:#1a1028;background-color:#f7f0e5;--bg-dark: #f7f0e5;--bg-mid: #faf3e7;--bg-card: #fdf8ef;--bg-elevated: #ffffff;--bg-section: #fdf8ef;--bg-hover: rgba(124, 58, 237, .06);--bg-active: rgba(124, 58, 237, .1);--bg-scrollbar: #c4b8e8;--bg-scrollbar-hover: #a890d8;--bg-code: rgba(0, 0, 0, .07);--text-primary: #1a1028;--text-secondary: rgba(26, 16, 40, .65);--text-muted: rgba(26, 16, 40, .4);--border-color: rgba(124, 58, 237, .18);--border-hover: rgba(124, 58, 237, .4);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .12);--shadow-glow: 0 0 20px rgba(124, 58, 237, .15);--shadow-lift: 0 8px 24px rgba(0, 0, 0, .1), 0 0 0 1px rgba(124, 58, 237, .15);--shadow-primary: 0 8px 24px rgba(124, 58, 237, .2);--gradient-hero-bg: radial-gradient(at 0% 0%, rgba(124, 58, 237, .08) 0%, transparent 48%), radial-gradient(at 100% 0%, rgba(147, 51, 234, .08) 0%, transparent 52%), radial-gradient(at 50% 100%, rgba(124, 58, 237, .04) 0%, transparent 55%);--gradient-celebration: radial-gradient(at 50% 0%, rgba(124, 58, 237, .15) 0%, transparent 55%), linear-gradient(180deg, var(--bg-elevated), var(--bg-card));--pattern-dots: radial-gradient(circle at 1px 1px, rgba(0, 0, 0, .05) 1px, transparent 0);--focus-ring: 0 0 0 3px rgba(124, 58, 237, .3);scrollbar-color:var(--bg-scrollbar) var(--bg-dark);--skeleton-base: rgba(124, 58, 237, .14);--skeleton-highlight: rgba(124, 58, 237, .32);--skeleton-edge: rgba(124, 58, 237, .08);--skeleton-tint-bg: rgba(124, 58, 237, .14);--skeleton-tint-glow: rgba(124, 58, 237, .28)}html,body,#root{height:100%;width:100%;overflow-x:hidden;overscroll-behavior:none;touch-action:manipulation}html{background-color:var(--bg-elevated)}*{-webkit-tap-highlight-color:transparent}*,*:before,*:after{box-sizing:border-box}@media(hover:none)and (pointer:coarse){*{-webkit-tap-highlight-color:transparent!important}*:hover{transition-delay:0s!important;transition-duration:0s!important}button,a,[role=button]{cursor:default!important}}a{font-weight:500;color:var(--primary-light);text-decoration:inherit}a:hover{color:var(--primary)}.menu-btn{display:none!important}@media(max-width:820px){.menu-btn{display:flex!important}.send-btn,.input-action,.copy-btn,.remove-file-btn,.project-badge-remove,.scroll-to-bottom-btn{min-width:44px;min-height:44px}.attach-menu-item{min-height:48px}}body{margin:0;min-width:320px;min-height:100dvh;width:100%;background-color:var(--bg-app);background-image:none!important}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none;width:0;height:0}h1,h2,h3,h4,h5,h6{font-family:var(--font-brand)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;top:var(--space-sm);left:var(--space-sm);z-index:10000;padding:var(--space-sm) var(--space-md);background:var(--primary);color:var(--text-primary);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;text-decoration:none;transform:translateY(-200%);transition:transform var(--transition-fast)}.skip-link:focus,.skip-link:focus-visible{transform:translateY(0);outline:2px solid var(--primary-25);outline-offset:2px}@keyframes ui-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes ui-tint-pulse{0%,to{opacity:.82}50%{opacity:1}}h1{font-size:3.2em;line-height:1.1}.theme-transitioning,.theme-transitioning *,.theme-transitioning *:before,.theme-transitioning *:after{transition:background-color .25s ease,color .2s ease,border-color .2s ease,box-shadow .2s ease!important;transition-delay:0s!important}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 24px;position:absolute;inset:0;pointer-events:none}.empty-state>*{pointer-events:auto}.empty-state .empty-icon{color:var(--text-muted);margin-bottom:16px;opacity:.5}.empty-state h2{font-size:var(--font-xl);font-weight:600;color:var(--text-primary);margin:0 0 8px}.empty-state p{font-size:var(--font-md);color:var(--text-muted);margin:0 0 20px;max-width:320px}.empty-action-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:var(--font-sm);font-weight:500;color:var(--fg-on-brand);background:var(--primary);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:background var(--transition-fast)}.empty-action-btn:hover{background:var(--primary-light)}.empty-state .empty-icon svg{width:48px;height:48px}.empty-state.empty-error .empty-icon{color:#ef4444;opacity:.7}.icon-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);flex-shrink:0}.icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.icon-btn:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.icon-btn--sm{width:32px;height:32px}@supports (-webkit-touch-callout: none){@media(max-width:768px){input[type=text],input[type=email],input[type=password],input[type=search],input[type=tel],input[type=url],input[type=number],input[type=date],input[type=datetime-local],input[type=time],input:not([type]),textarea,select{font-size:var(--font-lg)!important}}}.ui-modal{height:calc(100dvh - var(--space-lg) * 2);max-height:calc(100dvh - var(--space-lg) * 2)}.ui-modal--sm{max-height:calc(100dvh - var(--space-lg) * 2)}@media(min-width:1024px){.ui-modal--right{height:100dvh;max-height:100dvh}}@supports not (height: 100dvh){.ui-modal,.ui-modal--sm{height:calc(100vh - var(--space-lg) * 2);max-height:calc(100vh - var(--space-lg) * 2)}@media(min-width:1024px){.ui-modal--right{height:100vh;max-height:100vh}}}.sidebar{height:100dvh}@supports not (height: 100dvh){.sidebar{height:100vh}}body{min-height:100dvh}@supports not (min-height: 100dvh){body{min-height:100vh}}.messages-area,.ui-modal__body,.sidebar-nav,.sidebar-content,.sidebar-projects,.sidebar-chats,.conversation-detail-messages,.course-layout-content,.networking-list,.mentorship-list,.profile-scroll,.education-scroll,.notifications-list{overscroll-behavior:contain}@media(max-width:768px){.chatroom{padding-bottom:var(--kb-offset, 0px);transition:padding-bottom .15s ease}.input-area{padding-bottom:max(var(--space-sm),env(safe-area-inset-bottom,var(--space-sm)))}}.chat-input{font-size:var(--font-lg)}@media(min-width:769px){.chat-input{font-size:15px}}@media(min-width:769px){.conversations-view__messages,.mentorship-scroll,.mentorship-content{max-height:calc(100dvh - var(--header-height) - 200px)}}@media(orientation:landscape)and (max-width:926px){.layout-main{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right))}}.toast-container,.toast,.toast-list{bottom:max(16px,env(safe-area-inset-bottom,16px))!important}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.ui-modal-overlay{overscroll-behavior:contain;-webkit-overflow-scrolling:auto}button,[role=button],.icon-btn,.action-btn{-webkit-touch-callout:none}.message-bubble,.message-content{-webkit-touch-callout:default;-webkit-user-select:text;user-select:text}:root{--page-padding-block: 20px;--page-padding-inline: 24px;--page-max-width: 1240px}@media(max-width:768px){:root{--page-padding-block: 16px;--page-padding-inline: 12px}}.education-content,.networking-content,.profile-content,.settings-view__main,.ui-canvas{padding:var(--page-padding-block) var(--page-padding-inline)!important}.education-content:after,.networking-content:after,.profile-content:after,.settings-view__main:after,.ui-canvas:after,.conversations-view__list:after{content:"";display:block;height:32px;flex-shrink:0}@media(max-width:768px){.education-content:after,.networking-content:after,.profile-content:after,.settings-view__main:after,.ui-canvas:after,.conversations-view__list:after{height:20px}}.chatroom-header,.profile-header,.education-header,.networking-header,.admin-dashboard__pane-header,.admin-dashboard__header,.conv-detail__header,.page-header,.home-view__chrome,.surface-header{display:flex!important;align-items:center!important;gap:var(--space-md)!important;height:var(--header-height, 64px)!important;min-height:var(--header-height, 64px)!important;padding-top:0!important;padding-bottom:0!important;padding-left:var(--space-lg)!important;padding-right:var(--space-lg)!important;border-bottom:1px solid var(--border-default, var(--border-color))!important;background:var(--bg-canvas, var(--bg-card))!important;box-sizing:border-box;flex-shrink:0;position:sticky!important;top:0!important;z-index:20!important}.surface-header{z-index:30!important;padding-top:env(safe-area-inset-top,0px)}.chatroom-header h1,.chatroom-header h2,.chatroom-header .header-title,.chatroom-header .chat-title,.profile-header h1,.profile-header h2,.profile-header .header-title,.education-header h1,.education-header h2,.education-header .header-title,.education-header .education-title,.networking-header h1,.networking-header h2,.networking-header .header-title,.networking-header .networking-title,.admin-dashboard__header h1,.admin-dashboard__header h2,.admin-dashboard__header .header-title,.admin-dashboard__pane-header h1,.admin-dashboard__pane-header h2,.conv-detail__header h1,.conv-detail__header h2,.conv-detail__header h3,.page-header__title,.home-view__chrome-title,.surface-header__title,.conversations-view__title{font-family:var(--font-display)!important;font-size:var(--text-lg, 18px)!important;font-weight:var(--fw-semibold)!important;letter-spacing:var(--tracking-snug)!important;color:var(--fg-primary, var(--text-primary))!important;line-height:var(--leading-tight)!important;margin:0!important;background:none!important;background-image:none!important;-webkit-background-clip:border-box!important;background-clip:border-box!important;-webkit-text-fill-color:currentColor!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.chatroom-header .header-icon,.profile-header .header-icon,.education-header .header-icon,.networking-header .header-icon,.admin-dashboard__header .header-icon,.admin-dashboard__pane-header .header-icon,.page-header .page-header__icon,.surface-header>svg:first-child:not(.surface-header__menu svg){display:none!important}.chatroom-header .header-subtitle,.chatroom-header p,.profile-header p,.education-header p,.networking-header p,.page-header__subtitle,.page-header__eyebrow{font-size:var(--text-xs)!important;color:var(--fg-muted, var(--text-muted))!important;margin:0!important}.chatroom-header .menu-btn,.chatroom-header .icon-btn,.profile-header .menu-btn,.profile-header .icon-btn,.education-header .menu-btn,.education-header .icon-btn,.networking-header .menu-btn,.networking-header .icon-btn,.surface-header__menu{width:36px!important;height:36px!important;border-radius:var(--r-sm, var(--radius-md))!important}.surface-header__menu,.surface-header__back{display:grid;place-items:center;width:44px;height:44px;border-radius:var(--r-sm, var(--radius-md));background:transparent;border:0;color:var(--fg-secondary, var(--text-secondary));cursor:pointer;transition:background .14s ease,color .14s ease;flex-shrink:0}.surface-header__menu:hover,.surface-header__back:hover{background:var(--bg-hover);color:var(--fg-primary, var(--text-primary))}.surface-header__menu:focus-visible,.surface-header__back:focus-visible{outline:2px solid var(--primary-25);outline-offset:2px}.surface-header__menu{display:none}@media(max-width:820px){.surface-header__menu{display:grid}}.surface-header__title-group{display:flex;flex-direction:column;gap:var(--space-xs);min-width:0;flex:1 1 auto}.surface-header__title-row{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.surface-header__icon{display:inline-flex;align-items:center;justify-content:center;color:var(--fg-secondary, var(--text-secondary));flex-shrink:0}.surface-header__eyebrow{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--fw-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wider);color:var(--fg-muted, var(--text-muted));line-height:var(--leading-tight)}.surface-header__subtitle{font-size:var(--font-sm);color:var(--fg-muted, var(--text-muted));line-height:var(--leading-snug);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.surface-header__count{font-family:var(--font-mono);font-size:var(--font-xs);color:var(--fg-muted, var(--text-muted));padding:var(--space-xs) var(--space-sm);background:var(--bg-subtle);border-radius:var(--r-pill, var(--radius-pill));flex-shrink:0}.surface-header__actions{margin-left:auto;display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}@media(max-width:820px){.surface-header{padding:0 var(--space-md)}.surface-header__subtitle{display:none}}@media(prefers-reduced-motion:reduce){.surface-header__menu,.surface-header__back{transition:none}}:root{--font-xs: var(--text-xs);--font-sm: var(--text-sm);--font-md: var(--text-md);--font-lg: var(--text-lg);--font-xl: var(--text-xl);--font-2xl: var(--text-2xl);--font-brand: var(--font-display)}body{font-family:var(--font-sans);font-size:var(--text-md);font-weight:var(--fw-regular);line-height:var(--leading-relaxed);color:var(--fg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}h1,h2,h3,h4,h5,h6,.h1,.h2,.h3,.h4,.h5,.h6{font-family:var(--font-display);font-weight:var(--fw-semibold);color:var(--fg-primary);text-wrap:balance;margin:0}h1,.h1{font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}h2,.h2{font-size:var(--text-2xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}h3,.h3{font-size:var(--text-xl);line-height:var(--leading-snug);letter-spacing:var(--tracking-snug)}h4,.h4{font-size:var(--text-lg);line-height:var(--leading-snug);letter-spacing:var(--tracking-snug)}h5,.h5{font-family:var(--font-sans);font-size:var(--text-md);line-height:var(--leading-snug);letter-spacing:var(--tracking-normal)}h6,.h6{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--fw-medium);line-height:var(--leading-normal);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted)}p{margin:0;text-wrap:pretty;line-height:var(--leading-relaxed)}b,strong{font-weight:var(--fw-semibold)}small,.caption,.meta{font-size:var(--text-xs);line-height:var(--leading-normal);color:var(--fg-muted)}label,.label{font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--fw-medium);line-height:var(--leading-normal);color:var(--fg-secondary)}.help-text,.form-help{font-size:var(--text-xs);line-height:var(--leading-normal);color:var(--fg-muted)}a{color:var(--fg-link);text-decoration:none}a:hover{color:var(--fg-link-hover)}code,pre,.mono,kbd{font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-snug)}button,.ui-btn{font-family:var(--font-sans);font-size:var(--text-md);font-weight:var(--fw-medium);line-height:var(--leading-none);letter-spacing:var(--tracking-normal)}.ui-btn--sm{font-size:var(--text-sm)}.ui-btn--lg{font-size:var(--text-lg)}input,textarea,select{font-family:var(--font-sans);font-size:var(--text-md);color:var(--fg-primary)}textarea{line-height:var(--leading-normal)}::placeholder{color:var(--fg-placeholder)}table th{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--fw-medium);letter-spacing:var(--tracking-wider);text-transform:uppercase;color:var(--fg-muted)}table td{font-size:var(--text-sm);color:var(--fg-primary)}.chip,.tag,.eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--fw-medium);letter-spacing:var(--tracking-wide);line-height:var(--leading-none)}.eyebrow{letter-spacing:var(--tracking-widest);text-transform:uppercase}.ui-nav,.ui-nav--sub{font-size:var(--text-sm)}.ui-side__label,.ui-nav__count,.ui-top__crumbs,.ui-top__search,.ui-subnav__item,.ui-card__label,.ui-btn--ghost,.row__meta{font-size:var(--text-xs)}.ui-card__value{font-size:var(--text-2xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}.ui-ph__title{font-size:var(--text-xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}.ui-ph__sub{font-size:var(--text-sm);color:var(--fg-muted)}.row__name{font-size:var(--text-sm);font-weight:var(--fw-medium)}.tbl{font-size:var(--text-sm)}.tbl th{font-size:var(--text-xs);font-family:var(--font-mono);letter-spacing:var(--tracking-wider);text-transform:uppercase}.home-dash__title{font-size:var(--text-3xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-dash__subtitle{font-size:var(--text-md);color:var(--fg-secondary)}.home-dash__eyebrow{font-size:var(--text-xs);font-family:var(--font-mono)}.home-dash__card-title{font-size:var(--text-md);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-dash__stat-label{font-size:var(--text-xs);font-family:var(--font-mono)}.home-dash__stat-value{font-size:var(--text-2xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-dash__stat-meta{font-size:var(--text-xs)}.home-dash__stat-sub{font-size:var(--text-xs);font-family:var(--font-mono)}.home-dash__queue-title{font-size:var(--text-xl);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-dash__queue-sub{font-size:var(--text-sm)}.home-dash__resume-title{font-size:var(--text-lg);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-dash__resume-meta{font-size:var(--text-sm)}.home-dash__mentor-name{font-size:var(--text-md)}.home-dash__mentor-meta{font-size:var(--text-xs)}.home-dash__next-text{font-size:var(--text-sm)}.home-dash__next-meta{font-size:var(--text-xs)}.home-view__card-title{font-size:var(--text-md);font-family:var(--font-display);font-weight:var(--fw-semibold)}.home-view__card-desc{font-size:var(--text-sm)}.home-view__card-eyebrow{font-size:var(--text-xs);font-family:var(--font-mono)}.sidebar .nav-label{font-size:var(--text-sm);font-weight:var(--fw-medium)}.sidebar .nav-section-title,.sidebar .submenu-section-toggle,.sidebar .sp-direct-chats-label{font-size:var(--text-2xs);font-family:var(--font-mono);letter-spacing:var(--tracking-widest);text-transform:uppercase}.sidebar .user-name{font-size:var(--text-sm);font-weight:var(--fw-medium)}.sidebar .user-role{font-size:var(--text-2xs);font-family:var(--font-mono)}.conversations-view__title,.conv-detail__header h3,.conv-detail__header h2{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--fw-semibold)}.conv-row__name{font-size:var(--text-sm);font-weight:var(--fw-medium)}.conv-row__time{font-size:var(--text-xs);font-family:var(--font-mono)}.conv-row__snippet{font-size:var(--text-sm);color:var(--fg-secondary)}.conv-msg__bubble{font-size:var(--text-md);line-height:var(--leading-relaxed)}.conv-msg__meta{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--fg-muted)}.chat-msg__body,.message-bubble__content,.chatroom__message-body{font-size:var(--text-base);line-height:var(--leading-loose)}.notifications-bell__panel-header h4{font-size:var(--text-md);font-family:var(--font-display);font-weight:var(--fw-semibold)}.notifications-bell__mark-all{font-size:var(--text-sm)}.page-header__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--fw-semibold)}.page-header__eyebrow{font-family:var(--font-mono);font-size:var(--text-xs)}.page-header__subtitle{font-size:var(--text-sm)}.surface-header__title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--fw-semibold)}.surface-header__count{font-family:var(--font-mono);font-size:var(--text-xs)}.section-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:var(--fw-semibold);line-height:var(--leading-snug);color:var(--fg-primary)}@media(max-width:820px){h1,.h1{font-size:var(--text-2xl)}h2,.h2{font-size:var(--text-xl)}h3,.h3{font-size:var(--text-lg)}.home-dash__title{font-size:var(--text-2xl)}.home-dash__stat-value,.ui-card__value{font-size:var(--text-xl)}}@media(max-width:480px){.surface-header__title,.page-header__title{font-size:var(--text-md)}}.ui-title{font-family:var(--font-display);font-weight:var(--fw-semibold);color:var(--fg-primary);margin:0;text-wrap:balance}.ui-title--page{font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.ui-title--section{font-size:var(--text-2xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.ui-title--card{font-size:var(--text-lg);line-height:var(--leading-snug);letter-spacing:var(--tracking-snug)}.ui-title--eyebrow{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--fw-medium);line-height:var(--leading-normal);letter-spacing:var(--tracking-widest);text-transform:uppercase;color:var(--fg-muted)}@media(max-width:820px){.ui-title--page{font-size:var(--text-2xl)}.ui-title--section{font-size:var(--text-xl)}}.ui-text{font-family:var(--font-sans);font-weight:var(--fw-regular);color:var(--fg-primary);margin:0}.ui-text--body{font-size:var(--text-md);line-height:var(--leading-relaxed)}.ui-text--body-lg{font-size:var(--text-base);line-height:var(--leading-loose)}.ui-text--body-sm{font-size:var(--text-sm);line-height:var(--leading-normal)}.ui-text--caption{font-size:var(--text-xs);line-height:var(--leading-normal);color:var(--fg-muted)}.ui-text--meta{font-family:var(--font-mono);font-size:var(--text-xs);line-height:var(--leading-normal);color:var(--fg-muted)}.ui-text--label{font-size:var(--text-sm);font-weight:var(--fw-medium);line-height:var(--leading-normal);color:var(--fg-secondary)}.ui-text--code{font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--leading-normal);letter-spacing:var(--tracking-snug)}.ui-text--kbd{font-family:var(--font-mono);font-size:var(--text-xs);padding:2px var(--space-xs);border:1px solid var(--border-subtle);border-radius:var(--r-xs);background:var(--bg-subtle)}.ui-text--tone-secondary{color:var(--fg-secondary)}.ui-text--tone-muted{color:var(--fg-muted)}.ui-text--tone-danger{color:var(--fg-danger)}.ui-text--tone-success{color:var(--fg-success)}.ui-text--tone-warning{color:var(--fg-warning)}.ui-text--tone-brand{color:var(--fg-brand)}.ui-text--tone-inverse{color:var(--fg-inverse)}.ui-text--weight-regular{font-weight:var(--fw-regular)}.ui-text--weight-medium{font-weight:var(--fw-medium)}.ui-text--weight-semibold{font-weight:var(--fw-semibold)}.ui-text--weight-bold{font-weight:var(--fw-bold)}.ui-text--truncate{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0}.ui-text--numeric{font-variant-numeric:tabular-nums}.ui-link{display:inline;font:inherit;color:var(--fg-link);background:none;border:0;padding:0;cursor:pointer;text-decoration:none;transition:color .14s ease}.ui-link:hover{color:var(--fg-link-hover)}.ui-link--muted{color:var(--fg-muted)}.ui-link--muted:hover{color:var(--fg-secondary)}.ui-link--brand{color:var(--fg-brand);font-weight:var(--fw-medium)}.ui-link--brand:hover{color:var(--fg-link-hover)}.ui-link--underline-always,.ui-link--underline-hover:hover{text-decoration:underline;text-underline-offset:2px}.ui-link--disabled{color:var(--fg-disabled);cursor:not-allowed;pointer-events:none}.ui-link:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--r-xs)}@media(prefers-reduced-motion:reduce){.ui-link{transition:none}}.chatroom,.conversations-view,.networking-view,.education-view,.mentorship-view,.admin-dashboard,.profile-view,.settings-view,.home-view,.networking-dm-frame{background:var(--bg-app, var(--bg-dark))!important;color:var(--fg-primary, var(--text-primary))!important}.chatroom,.conversations-view,.networking-view,.education-view,.mentorship-view,.admin-dashboard,.profile-view,.settings-view,.home-view{min-height:100%}
