:root{--fo-bg-base: #F8F9FA;--fo-bg-surface: #FFFFFF;--fo-bg-elevated: #FFFFFF;--fo-bg-hover: #F1F3F5;--fo-bg-active: #E9ECEF;--fo-bg-muted: #F8F9FA;--fo-text-primary: #212529;--fo-text-secondary: #495057;--fo-text-tertiary: #6C757D;--fo-text-disabled: #ADB5BD;--fo-text-inverse: #FFFFFF;--fo-accent-primary: #2563EB;--fo-accent-hover: #1D4ED8;--fo-accent-active: #1E40AF;--fo-accent-soft: #EFF6FF;--fo-accent-border: #BFDBFE;--fo-success: #059669;--fo-success-soft: #ECFDF5;--fo-warning: #D97706;--fo-warning-soft: #FFFBEB;--fo-error: #DC2626;--fo-error-soft: #FEF2F2;--fo-info: #2563EB;--fo-info-soft: #EFF6FF;--fo-border-subtle: #F1F3F5;--fo-border-default: #DEE2E6;--fo-border-strong: #CED4DA;--fo-border-focus: #2563EB;--fo-shadow-xs: 0 1px 2px rgba(0, 0, 0, .04);--fo-shadow-sm: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--fo-shadow-md: 0 4px 6px rgba(0, 0, 0, .05), 0 2px 4px rgba(0, 0, 0, .03);--fo-shadow-lg: 0 10px 15px rgba(0, 0, 0, .05), 0 4px 6px rgba(0, 0, 0, .03);--fo-shadow-xl: 0 20px 25px rgba(0, 0, 0, .08), 0 10px 10px rgba(0, 0, 0, .04);--fo-doc-paper: #FFFFFF;--fo-doc-shadow: 0 1px 3px rgba(0,0,0,.08), 0 8px 24px rgba(0,0,0,.06);--fo-doc-canvas: #F8F9FA}body.dark-theme,:root.dark{--fo-bg-base: #0F0F0F;--fo-bg-surface: #171717;--fo-bg-elevated: #1F1F1F;--fo-bg-hover: #262626;--fo-bg-active: #2E2E2E;--fo-bg-muted: #141414;--fo-text-primary: #FAFAFA;--fo-text-secondary: #A1A1A1;--fo-text-tertiary: #737373;--fo-text-disabled: #525252;--fo-text-inverse: #171717;--fo-accent-primary: #3B82F6;--fo-accent-hover: #60A5FA;--fo-accent-active: #2563EB;--fo-accent-soft: rgba(59, 130, 246, .15);--fo-accent-border: rgba(59, 130, 246, .3);--fo-success: #22C55E;--fo-success-soft: rgba(34, 197, 94, .15);--fo-warning: #F59E0B;--fo-warning-soft: rgba(245, 158, 11, .15);--fo-error: #EF4444;--fo-error-soft: rgba(239, 68, 68, .15);--fo-border-subtle: #262626;--fo-border-default: #333333;--fo-border-strong: #404040;--fo-border-focus: #3B82F6;--fo-shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--fo-shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--fo-shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--fo-shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--fo-shadow-xl: 0 20px 25px rgba(0, 0, 0, .6);--fo-doc-paper: #1F1F1F;--fo-doc-shadow: 0 1px 3px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.5);--fo-doc-canvas: #0F0F0F}@media(prefers-contrast:high){:root{--fo-bg-base: #FFFFFF;--fo-bg-surface: #FFFFFF;--fo-text-primary: #000000;--fo-text-secondary: #000000;--fo-border-default: #000000;--fo-accent-primary: #0000EE}body.dark-theme,:root.dark{--fo-bg-base: #000000;--fo-bg-surface: #000000;--fo-text-primary: #FFFFFF;--fo-text-secondary: #FFFFFF;--fo-border-default: #FFFFFF;--fo-accent-primary: #00BFFF}}:root{--fo-font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Helvetica Neue", sans-serif;--fo-font-mono: "SF Mono", "Cascadia Code", "Consolas", "Liberation Mono", "Menlo", monospace;--fo-text-xs: .75rem;--fo-text-sm: .875rem;--fo-text-base: 1rem;--fo-text-lg: 1.125rem;--fo-text-xl: 1.25rem;--fo-text-2xl: 1.5rem;--fo-text-3xl: 1.875rem;--fo-text-4xl: 2.25rem;--fo-leading-tight: 1.25;--fo-leading-snug: 1.375;--fo-leading-normal: 1.5;--fo-leading-relaxed: 1.625;--fo-leading-loose: 2;--fo-font-normal: 400;--fo-font-medium: 500;--fo-font-semibold: 600;--fo-font-bold: 700}:root{--fo-space-0: 0;--fo-space-px: 1px;--fo-space-0-5: .125rem;--fo-space-1: .25rem;--fo-space-1-5: .375rem;--fo-space-2: .5rem;--fo-space-2-5: .625rem;--fo-space-3: .75rem;--fo-space-3-5: .875rem;--fo-space-4: 1rem;--fo-space-5: 1.25rem;--fo-space-6: 1.5rem;--fo-space-8: 2rem;--fo-space-10: 2.5rem;--fo-space-12: 3rem;--fo-space-16: 4rem;--fo-space-20: 5rem;--fo-space-24: 6rem}:root{--fo-radius-none: 0;--fo-radius-sm: .25rem;--fo-radius-md: .375rem;--fo-radius-lg: .5rem;--fo-radius-xl: .75rem;--fo-radius-2xl: 1rem;--fo-radius-3xl: 1.5rem;--fo-radius-full: 9999px}:root{--fo-ease-linear: linear;--fo-ease-in: cubic-bezier(.4, 0, 1, 1);--fo-ease-out: cubic-bezier(.16, 1, .3, 1);--fo-ease-in-out: cubic-bezier(.65, 0, .35, 1);--fo-ease-snap: cubic-bezier(.2, 0, 0, 1);--fo-duration-instant: 50ms;--fo-duration-fast: .1s;--fo-duration-normal: .15s;--fo-duration-slow: .25s;--fo-duration-slower: .35s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--fo-z-dropdown: 100;--fo-z-sticky: 200;--fo-z-fixed: 300;--fo-z-modal-bg: 400;--fo-z-modal: 500;--fo-z-popover: 600;--fo-z-tooltip: 700;--fo-z-toast: 800}.fo-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--fo-space-2);padding:var(--fo-space-2) var(--fo-space-4);border-radius:var(--fo-radius-md);font-family:var(--fo-font-sans);font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);line-height:1;text-decoration:none;cursor:pointer;transition:background-color var(--fo-duration-fast) var(--fo-ease-snap),border-color var(--fo-duration-fast) var(--fo-ease-snap),color var(--fo-duration-fast) var(--fo-ease-snap),box-shadow var(--fo-duration-fast) var(--fo-ease-snap),transform var(--fo-duration-fast) var(--fo-ease-snap);-webkit-user-select:none;user-select:none;white-space:nowrap}.fo-btn:focus-visible{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.fo-btn:disabled{cursor:not-allowed;opacity:.5}.fo-btn-primary{background:var(--fo-accent-primary);color:var(--fo-text-inverse);border:1px solid transparent}.fo-btn-primary:hover:not(:disabled){background:var(--fo-accent-hover);transform:translateY(-1px)}.fo-btn-primary:active:not(:disabled){background:var(--fo-accent-active);transform:translateY(0)}.fo-btn-secondary{background:var(--fo-bg-surface);color:var(--fo-text-primary);border:1px solid var(--fo-border-default)}.fo-btn-secondary:hover:not(:disabled){background:var(--fo-bg-hover);border-color:var(--fo-border-strong)}.fo-btn-secondary:active:not(:disabled){background:var(--fo-bg-active)}.fo-btn-ghost{background:transparent;color:var(--fo-text-secondary);border:1px solid transparent;padding:var(--fo-space-1-5) var(--fo-space-2)}.fo-btn-ghost:hover:not(:disabled){background:var(--fo-bg-hover);color:var(--fo-text-primary)}.fo-btn-ghost:active:not(:disabled){background:var(--fo-bg-active)}.fo-btn-ghost.active{background:var(--fo-accent-soft);color:var(--fo-accent-primary)}.fo-btn-danger{background:var(--fo-error);color:var(--fo-text-inverse);border:1px solid transparent}.fo-btn-danger:hover:not(:disabled){background:#b91c1c}.fo-btn-xs{padding:var(--fo-space-1) var(--fo-space-2);font-size:var(--fo-text-xs)}.fo-btn-sm{padding:var(--fo-space-1-5) var(--fo-space-3);font-size:var(--fo-text-sm)}.fo-btn-lg{padding:var(--fo-space-3) var(--fo-space-6);font-size:var(--fo-text-base)}.fo-btn-icon{padding:var(--fo-space-2);width:36px;height:36px}.fo-btn-icon.fo-btn-xs{padding:var(--fo-space-1);width:24px;height:24px}.fo-btn-icon.fo-btn-sm{padding:var(--fo-space-1-5);width:32px;height:32px}.fo-input{display:block;width:100%;padding:var(--fo-space-2) var(--fo-space-3);background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-md);font-family:var(--fo-font-sans);font-size:var(--fo-text-base);color:var(--fo-text-primary);transition:border-color var(--fo-duration-fast) var(--fo-ease-snap),box-shadow var(--fo-duration-fast) var(--fo-ease-snap)}.fo-input::placeholder{color:var(--fo-text-tertiary)}.fo-input:hover:not(:disabled){border-color:var(--fo-border-strong)}.fo-input:focus{outline:none;border-color:var(--fo-accent-primary);box-shadow:0 0 0 3px var(--fo-accent-soft)}.fo-input:disabled{background:var(--fo-bg-muted);color:var(--fo-text-disabled);cursor:not-allowed}.fo-input.fo-input-error{border-color:var(--fo-error)}.fo-input.fo-input-error:focus{box-shadow:0 0 0 3px var(--fo-error-soft)}.fo-input-group{display:flex;flex-direction:column;gap:var(--fo-space-1)}.fo-input-label{font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);color:var(--fo-text-primary)}.fo-input-hint{font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.fo-input-error-text{font-size:var(--fo-text-xs);color:var(--fo-error)}.fo-select{appearance:none;display:block;width:100%;padding:var(--fo-space-2) var(--fo-space-8) var(--fo-space-2) var(--fo-space-3);background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-md);font-family:var(--fo-font-sans);font-size:var(--fo-text-sm);color:var(--fo-text-primary);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236C757D' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--fo-space-2) center;transition:border-color var(--fo-duration-fast) var(--fo-ease-snap),box-shadow var(--fo-duration-fast) var(--fo-ease-snap)}.fo-select:hover:not(:disabled){border-color:var(--fo-border-strong)}.fo-select:focus{outline:none;border-color:var(--fo-accent-primary);box-shadow:0 0 0 3px var(--fo-accent-soft)}.fo-checkbox,.fo-radio{display:inline-flex;align-items:center;gap:var(--fo-space-2);cursor:pointer}.fo-checkbox input,.fo-radio input{width:16px;height:16px;accent-color:var(--fo-accent-primary);cursor:pointer}.fo-checkbox input:focus-visible,.fo-radio input:focus-visible{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.fo-card{background:var(--fo-bg-surface);border:1px solid var(--fo-border-subtle);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-sm)}.fo-card-header{padding:var(--fo-space-4);border-bottom:1px solid var(--fo-border-subtle)}.fo-card-body{padding:var(--fo-space-4)}.fo-card-footer{padding:var(--fo-space-4);border-top:1px solid var(--fo-border-subtle)}.fo-card-interactive{cursor:pointer;transition:border-color var(--fo-duration-fast) var(--fo-ease-snap),box-shadow var(--fo-duration-fast) var(--fo-ease-snap),transform var(--fo-duration-fast) var(--fo-ease-snap)}.fo-card-interactive:hover{border-color:var(--fo-border-default);box-shadow:var(--fo-shadow-md);transform:translateY(-2px)}.fo-badge{display:inline-flex;align-items:center;gap:var(--fo-space-1);padding:var(--fo-space-0-5) var(--fo-space-2);border-radius:var(--fo-radius-full);font-size:var(--fo-text-xs);font-weight:var(--fo-font-medium);line-height:1.4}.fo-badge-default{background:var(--fo-bg-hover);color:var(--fo-text-secondary)}.fo-badge-primary{background:var(--fo-accent-soft);color:var(--fo-accent-primary)}.fo-badge-success{background:var(--fo-success-soft);color:var(--fo-success)}.fo-badge-warning{background:var(--fo-warning-soft);color:var(--fo-warning)}.fo-badge-error{background:var(--fo-error-soft);color:var(--fo-error)}.fo-tooltip{position:absolute;z-index:var(--fo-z-tooltip);max-width:250px;padding:var(--fo-space-2) var(--fo-space-3);background:var(--fo-bg-elevated);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-md);font-size:var(--fo-text-sm);color:var(--fo-text-primary);box-shadow:var(--fo-shadow-lg);animation:fo-tooltip-fade-in var(--fo-duration-fast) var(--fo-ease-out)}@keyframes fo-tooltip-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fo-tooltip-shortcut{display:inline-flex;gap:var(--fo-space-1);margin-left:var(--fo-space-2)}.fo-tooltip-shortcut kbd{padding:var(--fo-space-0-5) var(--fo-space-1);background:var(--fo-bg-active);border-radius:var(--fo-radius-sm);font-family:var(--fo-font-mono);font-size:var(--fo-text-xs)}.fo-modal-backdrop{position:fixed;inset:0;z-index:var(--fo-z-modal-bg);background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fo-fade-in var(--fo-duration-normal) var(--fo-ease-out)}.fo-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:var(--fo-z-modal);width:100%;max-width:500px;max-height:90vh;overflow:auto;background:var(--fo-bg-elevated);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-xl);box-shadow:var(--fo-shadow-xl);animation:fo-modal-in var(--fo-duration-slow) var(--fo-ease-out)}@keyframes fo-fade-in{0%{opacity:0}to{opacity:1}}@keyframes fo-modal-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.fo-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-4);border-bottom:1px solid var(--fo-border-subtle)}.fo-modal-title{font-size:var(--fo-text-lg);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary)}.fo-modal-body{padding:var(--fo-space-4)}.fo-modal-footer{display:flex;justify-content:flex-end;gap:var(--fo-space-2);padding:var(--fo-space-4);border-top:1px solid var(--fo-border-subtle)}.fo-toast{display:flex;align-items:flex-start;gap:var(--fo-space-3);padding:var(--fo-space-3) var(--fo-space-4);background:var(--fo-bg-elevated);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-lg);animation:fo-slide-in-right var(--fo-duration-normal) var(--fo-ease-out)}@keyframes fo-slide-in-right{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.fo-toast-success{border-left:3px solid var(--fo-success)}.fo-toast-warning{border-left:3px solid var(--fo-warning)}.fo-toast-error{border-left:3px solid var(--fo-error)}.fo-toast-info{border-left:3px solid var(--fo-info)}.fo-divider{width:100%;height:1px;background:var(--fo-border-default);margin:var(--fo-space-4) 0}.fo-divider-vertical{width:1px;height:100%;background:var(--fo-border-default);margin:0 var(--fo-space-2)}.fo-skeleton{background:linear-gradient(90deg,var(--fo-bg-hover) 25%,var(--fo-bg-active) 50%,var(--fo-bg-hover) 75%);background-size:200% 100%;animation:fo-shimmer 1.5s infinite;border-radius:var(--fo-radius-sm)}@keyframes fo-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.fo-skeleton-text{height:1em;margin-bottom:var(--fo-space-2)}.fo-skeleton-avatar{width:40px;height:40px;border-radius:var(--fo-radius-full)}.fo-skeleton-button{width:100px;height:36px}.fo-avatar{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--fo-radius-full);background:var(--fo-accent-primary);color:var(--fo-text-inverse);font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);overflow:hidden}.fo-avatar img{width:100%;height:100%;object-fit:cover}.fo-avatar-xs{width:24px;height:24px;font-size:var(--fo-text-xs)}.fo-avatar-sm{width:32px;height:32px;font-size:var(--fo-text-xs)}.fo-avatar-lg{width:48px;height:48px;font-size:var(--fo-text-base)}.fo-avatar-xl{width:64px;height:64px;font-size:var(--fo-text-lg)}.fo-skip-link{position:absolute;top:-100%;left:var(--fo-space-4);padding:var(--fo-space-2) var(--fo-space-4);background:var(--fo-accent-primary);color:var(--fo-text-inverse);border-radius:var(--fo-radius-md);z-index:9999;text-decoration:none}.fo-skip-link:focus{top:var(--fo-space-4)}*:focus-visible{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.fo-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}.fo-writer{display:flex;height:100%;width:100%;overflow:hidden;background:var(--fo-bg-base)}.fo-writer-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;background:var(--fo-bg-surface);border-right:1px solid var(--fo-border-default);transition:width var(--fo-duration-normal) var(--fo-ease-out)}.fo-writer-sidebar.collapsed{width:48px}.fo-writer-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.fo-writer-panel{width:280px;flex-shrink:0;display:flex;flex-direction:column;background:var(--fo-bg-surface);border-left:1px solid var(--fo-border-default);animation:fo-slide-in-from-right var(--fo-duration-normal) var(--fo-ease-out)}@keyframes fo-slide-in-from-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.fo-writer-toolbar{display:flex;align-items:center;gap:var(--fo-space-0-5);padding:var(--fo-space-1-5) var(--fo-space-3);background:var(--fo-bg-surface);border-bottom:1px solid var(--fo-border-default);overflow-x:auto;flex-shrink:0}.fo-writer-toolbar::-webkit-scrollbar{height:4px}.fo-writer-toolbar::-webkit-scrollbar-thumb{background:var(--fo-border-default);border-radius:var(--fo-radius-full)}.fo-toolbar-group{display:flex;align-items:center;gap:var(--fo-space-0-5)}.fo-toolbar-divider{width:1px;height:24px;background:var(--fo-border-default);margin:0 var(--fo-space-1)}.fo-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--fo-space-1);padding:var(--fo-space-1-5) var(--fo-space-2);background:transparent;border:none;border-radius:var(--fo-radius-sm);color:var(--fo-text-secondary);font-size:var(--fo-text-sm);cursor:pointer;transition:background-color var(--fo-duration-fast) var(--fo-ease-snap),color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-toolbar-btn:hover{background:var(--fo-bg-hover);color:var(--fo-text-primary)}.fo-toolbar-btn:active{background:var(--fo-bg-active)}.fo-toolbar-btn.active{background:var(--fo-accent-soft);color:var(--fo-accent-primary)}.fo-toolbar-btn svg{width:16px;height:16px}.fo-toolbar-dropdown{position:relative}.fo-toolbar-dropdown-menu{position:absolute;top:100%;left:0;z-index:var(--fo-z-dropdown);min-width:180px;margin-top:var(--fo-space-1);padding:var(--fo-space-1);background:var(--fo-bg-elevated);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-lg);animation:fo-dropdown-in var(--fo-duration-fast) var(--fo-ease-out)}@keyframes fo-dropdown-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.fo-writer-canvas{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--fo-space-8) var(--fo-space-6);background:var(--fo-doc-canvas)}.fo-writer-canvas::-webkit-scrollbar{width:8px}.fo-writer-canvas::-webkit-scrollbar-track{background:transparent}.fo-writer-canvas::-webkit-scrollbar-thumb{background:var(--fo-border-default);border-radius:var(--fo-radius-full)}.fo-writer-canvas::-webkit-scrollbar-thumb:hover{background:var(--fo-border-strong)}.fo-writer-page{max-width:816px;min-height:1056px;margin:0 auto;padding:96px 72px;background:var(--fo-doc-paper);border-radius:var(--fo-radius-sm);box-shadow:var(--fo-doc-shadow)}.fo-writer-page.a4{width:210mm;min-height:297mm;max-width:100%}.fo-writer-page+.fo-writer-page{margin-top:var(--fo-space-8)}.fo-writer-editor{height:100%;font-family:var(--fo-font-sans);font-size:16px;line-height:1.7;color:var(--fo-text-primary)}.fo-writer-editor:focus{outline:none}.fo-writer-editor h1{font-size:var(--fo-text-3xl);font-weight:var(--fo-font-bold);line-height:var(--fo-leading-tight);margin:0 0 var(--fo-space-4) 0;color:var(--fo-text-primary)}.fo-writer-editor h2{font-size:var(--fo-text-2xl);font-weight:var(--fo-font-semibold);line-height:var(--fo-leading-tight);margin:var(--fo-space-8) 0 var(--fo-space-3) 0;color:var(--fo-text-primary)}.fo-writer-editor h3{font-size:var(--fo-text-xl);font-weight:var(--fo-font-semibold);line-height:var(--fo-leading-snug);margin:var(--fo-space-6) 0 var(--fo-space-2) 0;color:var(--fo-text-primary)}.fo-writer-editor h4{font-size:var(--fo-text-lg);font-weight:var(--fo-font-medium);margin:var(--fo-space-4) 0 var(--fo-space-2) 0;color:var(--fo-text-primary)}.fo-writer-editor p{margin:0 0 var(--fo-space-4) 0}.fo-writer-editor p:last-child{margin-bottom:0}.fo-writer-editor strong{font-weight:var(--fo-font-semibold)}.fo-writer-editor em{font-style:italic}.fo-writer-editor u{text-decoration:underline;text-underline-offset:2px}.fo-writer-editor s{text-decoration:line-through}.fo-writer-editor mark{background:#fef08a;padding:0 2px;border-radius:2px}.fo-writer-editor a{color:var(--fo-accent-primary);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.fo-writer-editor a:hover{color:var(--fo-accent-hover)}.fo-writer-editor ul,.fo-writer-editor ol{margin:0 0 var(--fo-space-4) 0;padding-left:var(--fo-space-6)}.fo-writer-editor li{margin-bottom:var(--fo-space-1)}.fo-writer-editor li>p{margin:0}.fo-writer-editor blockquote{margin:var(--fo-space-4) 0;padding:var(--fo-space-3) var(--fo-space-4);border-left:3px solid var(--fo-accent-primary);background:var(--fo-accent-soft);border-radius:0 var(--fo-radius-sm) var(--fo-radius-sm) 0;font-style:italic;color:var(--fo-text-secondary)}.fo-writer-editor blockquote p{margin:0}.fo-writer-editor code{padding:2px 6px;background:var(--fo-bg-hover);border-radius:var(--fo-radius-sm);font-family:var(--fo-font-mono);font-size:.9em;color:var(--fo-text-primary)}.fo-writer-editor pre{margin:var(--fo-space-4) 0;padding:var(--fo-space-4);background:var(--fo-bg-base);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-lg);overflow-x:auto}.fo-writer-editor pre code{padding:0;background:transparent;border-radius:0}.fo-writer-editor hr{border:none;height:1px;background:var(--fo-border-default);margin:var(--fo-space-8) 0}.fo-writer-editor img{max-width:100%;height:auto;border-radius:var(--fo-radius-md);margin:var(--fo-space-4) 0}.fo-writer-editor img.ProseMirror-selectednode{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.fo-writer-editor table{width:100%;border-collapse:collapse;margin:var(--fo-space-4) 0}.fo-writer-editor th,.fo-writer-editor td{border:1px solid var(--fo-border-default);padding:var(--fo-space-2) var(--fo-space-3);text-align:left}.fo-writer-editor th{background:var(--fo-bg-base);font-weight:var(--fo-font-semibold)}.fo-writer-editor tr:hover td{background:var(--fo-bg-hover)}.fo-writer-editor ul[data-type=taskList]{list-style:none;padding-left:0}.fo-writer-editor ul[data-type=taskList] li{display:flex;align-items:flex-start;gap:var(--fo-space-2)}.fo-writer-editor ul[data-type=taskList] li input[type=checkbox]{margin-top:4px;accent-color:var(--fo-accent-primary)}.fo-writer-editor .ProseMirror-selectednode{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.fo-writer-editor ::selection{background:var(--fo-accent-soft)}.fo-writer-editor .is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--fo-text-tertiary);pointer-events:none;height:0}.fo-bubble-menu{display:flex;align-items:center;gap:var(--fo-space-0-5);padding:var(--fo-space-1);background:var(--fo-bg-elevated);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-lg);animation:fo-bubble-in var(--fo-duration-fast) var(--fo-ease-out)}@keyframes fo-bubble-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fo-bubble-menu .fo-toolbar-btn{padding:var(--fo-space-1-5)}.fo-bubble-menu .fo-toolbar-divider{height:20px;margin:0 var(--fo-space-0-5)}.fo-comments-panel{display:flex;flex-direction:column;height:100%}.fo-comments-header{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-4);border-bottom:1px solid var(--fo-border-subtle)}.fo-comments-header-title{font-size:var(--fo-text-base);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary)}.fo-comments-list{flex:1;overflow-y:auto;padding:var(--fo-space-4)}.fo-comment{padding:var(--fo-space-3);background:var(--fo-bg-base);border-radius:var(--fo-radius-lg);margin-bottom:var(--fo-space-3)}.fo-comment:last-child{margin-bottom:0}.fo-comment-header{display:flex;align-items:center;gap:var(--fo-space-2);margin-bottom:var(--fo-space-2)}.fo-comment-author{font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);color:var(--fo-text-primary)}.fo-comment-time{font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.fo-comment-text{font-size:var(--fo-text-sm);color:var(--fo-text-secondary);line-height:var(--fo-leading-relaxed)}.fo-comment-resolved{opacity:.6}.fo-comment-resolved .fo-comment-text{text-decoration:line-through}.fo-comments-input{padding:var(--fo-space-4);border-top:1px solid var(--fo-border-subtle)}.fo-writer-statusbar{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-1-5) var(--fo-space-4);background:var(--fo-bg-surface);border-top:1px solid var(--fo-border-default);font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.fo-statusbar-left,.fo-statusbar-right{display:flex;align-items:center;gap:var(--fo-space-4)}.fo-statusbar-item{display:flex;align-items:center;gap:var(--fo-space-1)}.fo-statusbar-item svg{width:12px;height:12px}.fo-statusbar-btn{display:flex;align-items:center;gap:var(--fo-space-1);padding:var(--fo-space-1) var(--fo-space-2);background:transparent;border:none;border-radius:var(--fo-radius-sm);color:var(--fo-text-tertiary);font-size:var(--fo-text-xs);cursor:pointer;transition:color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-statusbar-btn:hover{color:var(--fo-text-secondary);text-decoration:underline}@media print{.fo-writer-sidebar,.fo-writer-toolbar,.fo-writer-panel,.fo-writer-statusbar,.fo-bubble-menu{display:none!important}.fo-writer-canvas{padding:0!important;background:#fff!important;overflow:visible!important}.fo-writer-page{box-shadow:none!important;border-radius:0!important;max-width:none!important;padding:2cm!important;margin:0!important}.fo-writer-editor{font-size:12pt!important;line-height:1.5!important;color:#000!important}}.fo-calc{display:flex;height:100%;width:100%;overflow:hidden;background:var(--fo-bg-base)}.fo-calc-sidebar{width:200px;flex-shrink:0;display:flex;flex-direction:column;background:var(--fo-bg-surface);border-right:1px solid var(--fo-border-default)}.fo-calc-sidebar.collapsed{width:48px}.fo-calc-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.fo-formula-bar{display:flex;align-items:center;gap:var(--fo-space-2);padding:var(--fo-space-2) var(--fo-space-3);background:var(--fo-bg-elevated);border-bottom:1px solid var(--fo-border-default)}.fo-formula-cell-ref{display:flex;align-items:center;gap:var(--fo-space-1);padding:var(--fo-space-1-5) var(--fo-space-2);min-width:80px;background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-sm);font-family:var(--fo-font-mono);font-size:var(--fo-text-sm);color:var(--fo-text-primary)}.fo-formula-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--fo-accent-primary);font-style:italic;font-weight:var(--fo-font-semibold)}.fo-formula-input{flex:1;padding:var(--fo-space-1-5) var(--fo-space-2);background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-sm);font-family:var(--fo-font-mono);font-size:var(--fo-text-sm);color:var(--fo-text-primary);transition:border-color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-formula-input:focus{outline:none;border-color:var(--fo-accent-primary);box-shadow:0 0 0 2px var(--fo-accent-soft)}.fo-formula-input::placeholder{color:var(--fo-text-tertiary);font-family:var(--fo-font-sans);font-style:italic}.fo-calc-grid-container{flex:1;overflow:auto;position:relative}.fo-calc-grid{display:grid;border-collapse:collapse;font-size:var(--fo-text-sm);font-variant-numeric:tabular-nums}.fo-cell{padding:var(--fo-space-1) var(--fo-space-2);background:var(--fo-bg-surface);border-right:1px solid var(--fo-border-subtle);border-bottom:1px solid var(--fo-border-subtle);min-height:24px;min-width:80px;position:relative;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;transition:background-color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-cell-header{background:var(--fo-bg-base);color:var(--fo-text-secondary);font-weight:var(--fo-font-medium);text-align:center;-webkit-user-select:none;user-select:none;position:sticky;z-index:10}.fo-cell-header-row{top:0}.fo-cell-header-col{left:0}.fo-cell-header-corner{top:0;left:0;z-index:20}.fo-row:hover .fo-cell,.fo-row:hover .fo-cell-header-col{background:var(--fo-bg-hover)}.fo-cell.selected{outline:2px solid var(--fo-accent-primary);outline-offset:-1px;background:var(--fo-accent-soft);z-index:5}.fo-cell.in-selection{background:var(--fo-accent-soft)}.fo-cell.editing{padding:0}.fo-cell.editing input{width:100%;height:100%;padding:var(--fo-space-1) var(--fo-space-2);border:none;outline:none;font-size:inherit;font-family:inherit;background:var(--fo-bg-surface)}.fo-cell.has-formula:after{content:"";position:absolute;top:2px;right:2px;width:0;height:0;border-top:6px solid var(--fo-accent-primary);border-left:6px solid transparent}.fo-cell.error{color:var(--fo-error);background:var(--fo-error-soft)}.fo-cell-text{text-align:left}.fo-cell-number{text-align:right;font-variant-numeric:tabular-nums}.fo-cell-currency{text-align:right}.fo-cell-currency.negative{color:var(--fo-error)}.fo-cell-percent{text-align:right;position:relative}.fo-cell-percent:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);height:4px;width:var(--percent-width, 0%);max-width:calc(100% - 50px);background:var(--fo-accent-primary);border-radius:var(--fo-radius-full);opacity:.3}.fo-cell-date{text-align:left;color:var(--fo-text-secondary)}.fo-cell-status{display:flex;align-items:center}.fo-cell-status-tag{display:inline-flex;align-items:center;gap:var(--fo-space-1);padding:var(--fo-space-0-5) var(--fo-space-2);border-radius:var(--fo-radius-full);font-size:var(--fo-text-xs);font-weight:var(--fo-font-medium)}.fo-cell-status-tag.success{background:var(--fo-success-soft);color:var(--fo-success)}.fo-cell-status-tag.warning{background:var(--fo-warning-soft);color:var(--fo-warning)}.fo-cell-status-tag.error{background:var(--fo-error-soft);color:var(--fo-error)}.fo-cell-status-tag.info{background:var(--fo-info-soft);color:var(--fo-info)}.fo-cell-checkbox{display:flex;align-items:center;justify-content:center}.fo-cell-checkbox input{width:16px;height:16px;accent-color:var(--fo-accent-primary);cursor:pointer}.fo-cell-user{display:flex;align-items:center;gap:var(--fo-space-2)}.fo-cell-user-avatar{width:20px;height:20px;border-radius:var(--fo-radius-full);background:var(--fo-accent-primary);color:var(--fo-text-inverse);font-size:var(--fo-text-xs);font-weight:var(--fo-font-medium);display:flex;align-items:center;justify-content:center;flex-shrink:0}.fo-cell-progress{display:flex;align-items:center;gap:var(--fo-space-2)}.fo-cell-progress-bar{flex:1;height:6px;background:var(--fo-bg-hover);border-radius:var(--fo-radius-full);overflow:hidden}.fo-cell-progress-fill{height:100%;background:var(--fo-accent-primary);border-radius:var(--fo-radius-full);transition:width var(--fo-duration-normal) var(--fo-ease-out)}.fo-cell-progress-value{font-size:var(--fo-text-xs);color:var(--fo-text-tertiary);min-width:35px;text-align:right}.fo-cell-rating{display:flex;gap:2px}.fo-cell-rating-star{color:var(--fo-warning);font-size:14px}.fo-cell-rating-star.empty{color:var(--fo-border-default)}.fo-cell-link{color:var(--fo-accent-primary);text-decoration:underline;cursor:pointer}.fo-cell-link:hover{color:var(--fo-accent-hover)}.fo-sheets-list{flex:1;overflow-y:auto;padding:var(--fo-space-2)}.fo-sheets-header{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-3);border-bottom:1px solid var(--fo-border-subtle)}.fo-sheets-title{font-size:var(--fo-text-xs);font-weight:var(--fo-font-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--fo-text-tertiary)}.fo-sheet-item{display:flex;align-items:center;gap:var(--fo-space-2);padding:var(--fo-space-2) var(--fo-space-3);border-radius:var(--fo-radius-md);cursor:pointer;transition:background-color var(--fo-duration-fast) var(--fo-ease-snap),color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-sheet-item:hover{background:var(--fo-bg-hover)}.fo-sheet-item.active{background:var(--fo-accent-soft);color:var(--fo-accent-primary)}.fo-sheet-item-icon{width:16px;height:16px;color:var(--fo-text-tertiary)}.fo-sheet-item.active .fo-sheet-item-icon{color:var(--fo-accent-primary)}.fo-sheet-item-name{flex:1;font-size:var(--fo-text-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fo-sheet-add{margin:var(--fo-space-2);padding:var(--fo-space-2);border:1px dashed var(--fo-border-default);border-radius:var(--fo-radius-md);color:var(--fo-text-tertiary);font-size:var(--fo-text-sm);text-align:center;cursor:pointer;transition:border-color var(--fo-duration-fast) var(--fo-ease-snap),color var(--fo-duration-fast) var(--fo-ease-snap)}.fo-sheet-add:hover{border-color:var(--fo-accent-primary);color:var(--fo-accent-primary)}.fo-calc-summary{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-1-5) var(--fo-space-4);background:var(--fo-bg-surface);border-top:1px solid var(--fo-border-default);font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.fo-summary-left,.fo-summary-right{display:flex;align-items:center;gap:var(--fo-space-4)}.fo-summary-stat{display:flex;align-items:center;gap:var(--fo-space-1)}.fo-summary-label{font-weight:var(--fo-font-medium);color:var(--fo-text-tertiary)}.fo-summary-value{font-family:var(--fo-font-mono);color:var(--fo-text-secondary)}.fo-summary-value.highlight{color:var(--fo-accent-primary);font-weight:var(--fo-font-semibold)}.fo-chart-container{padding:var(--fo-space-4);background:var(--fo-bg-surface);border:1px solid var(--fo-border-subtle);border-radius:var(--fo-radius-lg)}.fo-chart-title{font-size:var(--fo-text-base);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary);margin-bottom:var(--fo-space-3)}.univer-sheet-container{--univer-primary-color: var(--fo-accent-primary);--univer-selection-color: var(--fo-accent-soft)}@media print{.fo-calc-sidebar,.fo-formula-bar,.fo-calc-summary{display:none!important}.fo-calc-grid-container{overflow:visible!important}.fo-cell{background:#fff!important;color:#000!important;border-color:#ccc!important}.fo-cell-header{background:#f5f5f5!important}}.editor-container{display:flex;flex-direction:column;height:100vh;background-color:var(--fo-bg-base);overflow:hidden}.editor-toolbar{display:flex;align-items:center;gap:var(--fo-space-2);padding:var(--fo-space-2) var(--fo-space-4);background-color:var(--fo-bg-surface);border-bottom:1px solid var(--fo-border-default);flex-wrap:wrap;flex-shrink:0;z-index:10}.editor-toolbar.loading{justify-content:center;color:var(--fo-text-tertiary)}.editor-toolbar button{display:inline-flex;align-items:center;justify-content:center;gap:var(--fo-space-1);padding:var(--fo-space-1-5);background:transparent;border:none;border-radius:var(--fo-radius-sm);color:var(--fo-text-secondary);cursor:pointer;transition:background-color var(--fo-duration-fast) var(--fo-ease-snap),color var(--fo-duration-fast) var(--fo-ease-snap)}.editor-toolbar button:hover{background-color:var(--fo-bg-hover);color:var(--fo-text-primary)}.editor-toolbar button.is-active{background-color:var(--fo-accent-soft);color:var(--fo-accent-primary)}.editor-toolbar button:focus-visible{outline:2px solid var(--fo-accent-primary);outline-offset:2px}.btn-toggle-mode{background:var(--fo-accent-soft)!important;border:1px solid var(--fo-accent-border)!important;color:var(--fo-accent-primary)!important}.btn-toggle-mode:hover{background:var(--fo-accent-primary)!important;color:var(--fo-text-inverse)!important}.btn-save{background:var(--fo-accent-primary)!important;color:var(--fo-text-inverse)!important;padding:var(--fo-space-1-5) var(--fo-space-3)!important;font-weight:var(--fo-font-medium)}.btn-save:hover{background:var(--fo-accent-hover)!important}.btn-workflow{color:var(--fo-success)!important;background:var(--fo-success-soft)!important;border:1px solid var(--fo-success)!important;padding:var(--fo-space-1-5) var(--fo-space-3)!important;gap:var(--fo-space-2);font-weight:var(--fo-font-medium)}.btn-workflow:hover{background:var(--fo-success)!important;color:var(--fo-text-inverse)!important}.divider{width:1px;height:24px;background:var(--fo-border-default);margin:0 var(--fo-space-1)}.toolbar-select{height:32px;padding:0 var(--fo-space-2);background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-sm);font-size:var(--fo-text-sm);color:var(--fo-text-primary);cursor:pointer;transition:border-color var(--fo-duration-fast) var(--fo-ease-snap)}.toolbar-select:hover{border-color:var(--fo-border-strong)}.toolbar-select:focus{outline:none;border-color:var(--fo-accent-primary)}.toolbar-select-size{width:60px}.status-bar{margin-left:auto;display:flex;align-items:center;gap:var(--fo-space-4);font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.stats{background:var(--fo-bg-hover);padding:var(--fo-space-0-5) var(--fo-space-2);border-radius:var(--fo-radius-sm);font-family:var(--fo-font-mono)}.view-mode-group{background:var(--fo-bg-hover);border-radius:var(--fo-radius-md);padding:2px;display:flex;gap:2px}.view-mode-group button{padding:var(--fo-space-1-5) var(--fo-space-2);border-radius:var(--fo-radius-sm);transition:all var(--fo-duration-fast) var(--fo-ease-snap)}.view-mode-group button.is-active{background:var(--fo-accent-primary);color:var(--fo-text-inverse);box-shadow:var(--fo-shadow-sm)}.view-mode-group button:hover:not(.is-active){background:var(--fo-bg-active)}.editor-scroll-area{flex:1;overflow-y:auto;padding:var(--fo-space-8);display:flex;justify-content:center;position:relative;padding-bottom:20rem;z-index:1;background:var(--fo-doc-canvas)}.editor-scroll-area::-webkit-scrollbar{width:8px}.editor-scroll-area::-webkit-scrollbar-track{background:transparent}.editor-scroll-area::-webkit-scrollbar-thumb{background:var(--fo-border-default);border-radius:var(--fo-radius-full)}.editor-scroll-area::-webkit-scrollbar-thumb:hover{background:var(--fo-border-strong)}.editor-content{width:100%;max-width:800px;min-height:1123px;background:var(--fo-doc-paper)!important;color:var(--fo-text-primary)!important;box-shadow:var(--fo-doc-shadow);border-radius:var(--fo-radius-sm);position:relative;--page-content-height: 934px;--page-gap: 40px}.editor-content,.editor-content .ProseMirror,.editor-content p,.editor-content h1,.editor-content h2,.editor-content h3,.editor-content h4,.editor-content h5,.editor-content h6,.editor-content span,.editor-content div,.editor-content li,.editor-content td,.editor-content th{color:var(--fo-text-primary)!important;background-color:transparent}.editor-content{background-color:var(--fo-doc-paper)!important}.editor-content.view-normal{max-width:800px;box-shadow:var(--fo-doc-shadow)}.editor-content.view-weblayout{max-width:100%;min-height:auto;box-shadow:none;border-left:3px solid var(--fo-accent-primary);border-radius:0}.editor-content.view-weblayout:before,.editor-content.view-weblayout:after{display:none}.editor-content.view-pagelayout{max-width:794px;min-height:1123px;box-shadow:var(--fo-shadow-xl);border:1px solid var(--fo-border-default);margin:var(--fo-space-5) auto}.editor-content.view-pagelayout:before,.editor-content.view-pagelayout:after{display:none!important}.editor-scroll-area:has(.view-pagelayout){background:var(--fo-bg-base);background-image:none}.ProseMirror{outline:none;min-height:500px;line-height:var(--fo-leading-relaxed)}.ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--fo-text-tertiary);pointer-events:none;height:0}.ProseMirror strong,.ProseMirror b{font-weight:var(--fo-font-bold)!important}.ProseMirror em,.ProseMirror i{font-style:italic!important}.ProseMirror u{text-decoration:underline!important;text-underline-offset:2px}.ProseMirror s,.ProseMirror strike{text-decoration:line-through!important}.ProseMirror sub{vertical-align:sub;font-size:smaller}.ProseMirror sup{vertical-align:super;font-size:smaller}.ProseMirror a{color:var(--fo-accent-primary);text-decoration:underline;text-underline-offset:2px;cursor:pointer}.ProseMirror a:hover{color:var(--fo-accent-hover)}.bubble-menu{display:flex;background-color:var(--fo-bg-elevated);padding:var(--fo-space-1);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-lg);border:1px solid var(--fo-border-default);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.bubble-menu button{border:none;background:none;color:var(--fo-text-primary);padding:var(--fo-space-1-5) var(--fo-space-3);font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);cursor:pointer;border-radius:var(--fo-radius-sm);transition:all var(--fo-duration-fast) var(--fo-ease-snap)}.bubble-menu button:hover,.bubble-menu button.is-active{background-color:var(--fo-accent-primary);color:var(--fo-text-inverse)}.floating-menu{display:flex;flex-direction:column;background-color:var(--fo-bg-elevated);padding:var(--fo-space-1);border-radius:var(--fo-radius-lg);box-shadow:var(--fo-shadow-lg);border:1px solid var(--fo-border-default);min-width:150px}.floating-btn{display:flex;align-items:center;gap:var(--fo-space-2);border:none;background:none;color:var(--fo-text-primary);padding:var(--fo-space-2) var(--fo-space-3);font-size:var(--fo-text-sm);text-align:left;cursor:pointer;border-radius:var(--fo-radius-sm);transition:background var(--fo-duration-fast) var(--fo-ease-snap)}.floating-btn:hover{background-color:var(--fo-bg-hover)}.ProseMirror table{border-collapse:collapse;table-layout:fixed;width:100%;margin:0;overflow:hidden}.ProseMirror td,.ProseMirror th{min-width:1em;border:1px solid var(--fo-border-default);padding:var(--fo-space-2) var(--fo-space-3);vertical-align:top;box-sizing:border-box;position:relative}.ProseMirror th{font-weight:var(--fo-font-semibold);text-align:left;background-color:var(--fo-bg-base)}.ProseMirror tr:hover td{background-color:var(--fo-bg-hover)}.ProseMirror .selectedCell:after{z-index:2;position:absolute;content:"";inset:0;background:var(--fo-accent-soft);pointer-events:none}.ProseMirror .column-resize-handle{position:absolute;right:-2px;top:0;bottom:-2px;width:4px;background-color:var(--fo-accent-primary);pointer-events:none}.ProseMirror img{max-width:100%;height:auto;border-radius:var(--fo-radius-md);display:block;margin:var(--fo-space-4) 0}.ProseMirror img.ProseMirror-selectednode{outline:3px solid var(--fo-accent-primary)}.comment-mark{background-color:var(--fo-warning-soft);border-bottom:2px solid var(--fo-warning);cursor:pointer}.comment-mark.active{background-color:#fbc02d80}.comments-panel{width:300px;background-color:var(--fo-bg-surface);border-left:1px solid var(--fo-border-default);display:flex;flex-direction:column;height:100vh;flex-shrink:0}.comments-header{padding:var(--fo-space-4);border-bottom:1px solid var(--fo-border-subtle);display:flex;justify-content:space-between;align-items:center}.comments-header h3{margin:0;font-size:var(--fo-text-base);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary)}.comments-list{flex:1;overflow-y:auto;padding:var(--fo-space-4);display:flex;flex-direction:column;gap:var(--fo-space-4)}.comments-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--fo-text-tertiary);gap:var(--fo-space-2)}.comment-thread{background-color:var(--fo-bg-base);border:1px solid var(--fo-border-subtle);border-radius:var(--fo-radius-lg);padding:var(--fo-space-3);transition:all var(--fo-duration-fast) var(--fo-ease-snap);box-shadow:var(--fo-shadow-xs)}.comment-thread.active{border-color:var(--fo-accent-primary);box-shadow:0 0 0 2px var(--fo-accent-soft)}.comment-thread.resolved{opacity:.6;background-color:var(--fo-bg-muted)}.comment-meta{display:flex;justify-content:space-between;margin-bottom:var(--fo-space-1);font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.comment-author{font-weight:var(--fo-font-semibold);color:var(--fo-text-primary);display:flex;align-items:center;gap:var(--fo-space-1)}.comment-content{font-size:var(--fo-text-sm);margin-bottom:var(--fo-space-2);white-space:pre-wrap;color:var(--fo-text-secondary)}.suggestion-insertion,.track-changes-insertion{background-color:var(--fo-success-soft);border-bottom:2px solid var(--fo-success);color:var(--fo-success);text-decoration:none}.suggestion-deletion,.track-changes-deletion{background-color:var(--fo-error-soft);text-decoration:line-through;color:var(--fo-error)}.lt-error-spelling{text-decoration:underline wavy var(--fo-error);text-decoration-skip-ink:none;cursor:pointer;background-color:var(--fo-error-soft);border-radius:2px;padding:0 1px;margin:0 -1px}.lt-error-grammar{text-decoration:underline wavy var(--fo-accent-primary);text-decoration-skip-ink:none;cursor:pointer;background-color:var(--fo-accent-soft);border-radius:2px;padding:0 1px;margin:0 -1px}.lt-error-typo{text-decoration:underline dashed var(--fo-success);text-decoration-skip-ink:none;cursor:pointer;background-color:var(--fo-success-soft);border-radius:2px;padding:0 1px;margin:0 -1px}.lt-error-style{text-decoration:underline dotted var(--fo-warning);text-decoration-skip-ink:none;cursor:pointer;background-color:var(--fo-warning-soft);border-radius:2px;padding:0 1px;margin:0 -1px}.proofreading-badge{display:inline-flex;align-items:center;gap:var(--fo-space-1);padding:var(--fo-space-0-5) var(--fo-space-2);border-radius:var(--fo-radius-full);font-size:var(--fo-text-xs);font-weight:var(--fo-font-medium)}.proofreading-badge.has-errors{background:var(--fo-error-soft);color:var(--fo-error)}.proofreading-badge.checking{background:var(--fo-accent-soft);color:var(--fo-accent-primary)}.proofreading-badge.clean{background:var(--fo-success-soft);color:var(--fo-success)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:var(--fo-z-modal-bg)}.modal-content{background:var(--fo-bg-elevated);border-radius:var(--fo-radius-xl);padding:var(--fo-space-6);min-width:320px;max-width:480px;box-shadow:var(--fo-shadow-xl);border:1px solid var(--fo-border-default)}.modal-content h3{margin:0 0 var(--fo-space-4) 0;font-size:var(--fo-text-lg);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary)}.modal-content input[type=text],.modal-content input[type=url],.modal-content textarea{width:100%;padding:var(--fo-space-2) var(--fo-space-3);background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-md);font-size:var(--fo-text-sm);color:var(--fo-text-primary);box-sizing:border-box}.modal-content input:focus,.modal-content textarea:focus{outline:none;border-color:var(--fo-accent-primary);box-shadow:0 0 0 3px var(--fo-accent-soft)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--fo-space-2);margin-top:var(--fo-space-4)}.modal-actions button{padding:var(--fo-space-2) var(--fo-space-4);border-radius:var(--fo-radius-md);cursor:pointer;font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);border:1px solid var(--fo-border-default);background:var(--fo-bg-surface);color:var(--fo-text-primary);transition:all var(--fo-duration-fast) var(--fo-ease-snap)}.modal-actions button:hover{background:var(--fo-bg-hover)}.modal-actions button.primary{background:var(--fo-accent-primary);color:var(--fo-text-inverse);border-color:transparent}.modal-actions button.primary:hover{background:var(--fo-accent-hover)}.editor-page-container{display:flex;flex-direction:column;align-items:center;gap:var(--fo-space-6);padding:var(--fo-space-10) var(--fo-space-5);min-height:100%;background:var(--fo-doc-canvas)}.editor-page{background:var(--fo-doc-paper);box-shadow:var(--fo-doc-shadow);position:relative;overflow:visible;box-sizing:border-box;transition:box-shadow var(--fo-duration-fast) var(--fo-ease-snap)}.editor-page:hover{box-shadow:var(--fo-shadow-xl)}.editor-page.size-a4.portrait{width:794px;min-height:1123px}.editor-page.size-a4.landscape{width:1123px;min-height:794px}.editor-page.size-letter.portrait{width:816px;min-height:1056px}.editor-page.size-letter.landscape{width:1056px;min-height:816px}.editor-page-header,.editor-page-footer{position:absolute;left:0;right:0;padding:var(--fo-space-2) var(--fo-space-5);font-size:var(--fo-text-xs);color:var(--fo-text-tertiary);background:var(--fo-bg-base);z-index:10}.editor-page-header{top:0;border-bottom:1px dashed var(--fo-border-subtle)}.editor-page-footer{bottom:0;border-top:1px dashed var(--fo-border-subtle)}.editor-normal-view{max-width:800px;margin:0 auto;padding:var(--fo-space-10);background:var(--fo-doc-paper);min-height:calc(100vh - 120px);box-shadow:var(--fo-shadow-md)}.editor-toolbar button.track-changes-active{color:var(--fo-warning)!important;background:var(--fo-warning-soft)!important}.editor-toolbar .toc-label{font-size:var(--fo-text-xs);font-weight:var(--fo-font-bold)}.editor-toolbar .language-select{background:var(--fo-bg-surface);border:1px solid var(--fo-border-default);border-radius:var(--fo-radius-sm);color:var(--fo-text-secondary);font-size:var(--fo-text-xs);padding:var(--fo-space-1) var(--fo-space-2);cursor:pointer}.editor-toolbar .language-select:hover{border-color:var(--fo-border-strong)}.editor-toolbar .language-select:focus{outline:none;border-color:var(--fo-accent-primary)}.editor-toolbar .proofreading-error-badge{position:absolute;top:-4px;right:-4px;background:var(--fo-error);color:var(--fo-text-inverse);font-size:var(--fo-text-xs);font-weight:var(--fo-font-bold);border-radius:var(--fo-radius-full);width:16px;height:16px;display:flex;align-items:center;justify-content:center}.editor-toolbar .proofreading-checking{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--fo-accent-primary);border-radius:var(--fo-radius-full);animation:pulse 1s infinite}.editor-toolbar .lifecycle-badge-btn{background:none;border:none;padding:0;cursor:pointer;margin-right:var(--fo-space-3)}@media print{@page{margin:15mm;size:A4}body,html,#root,.app-container,.main-content,.editor-container{background:#fff!important;height:auto!important;width:100%!important;overflow:visible!important;position:static!important;display:block!important;margin:0!important;padding:0!important}.editor-toolbar,.sidebar,.comments-panel,.bubble-menu,.floating-menu,.modal-overlay,nav,aside{display:none!important;visibility:hidden!important}.editor-scroll-area{padding:0!important;overflow:visible!important;background:#fff!important}.editor-content{box-shadow:none!important;padding:20mm!important;margin:0!important;width:100%!important;max-width:none!important;border:none!important;color:#000!important;background:#fff!important}.ProseMirror{color:#000!important;background:#fff!important}.ProseMirror *{color:#000!important}.ProseMirror a{color:#000!important;text-decoration:underline!important}.ProseMirror th,.ProseMirror td{border:1px solid #333!important}.ProseMirror img{max-width:100%!important;page-break-inside:avoid}.ProseMirror h1,.ProseMirror h2,.ProseMirror h3{page-break-after:avoid}}:root{font-family:var(--fo-font-sans, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: var(--fo-bg-base);--bg-secondary: var(--fo-bg-surface);--bg-tertiary: var(--fo-bg-elevated);--bg-card: var(--fo-bg-surface);--bg-glass: var(--fo-bg-surface);--bg-hover: var(--fo-bg-hover);--text-primary: var(--fo-text-primary);--text-secondary: var(--fo-text-secondary);--text-tertiary: var(--fo-text-tertiary);--text-muted: var(--fo-text-disabled);--border-color: var(--fo-border-default);--border-glass: var(--fo-border-subtle);--accent-color: var(--fo-accent-primary);--accent-hover: var(--fo-accent-hover);--accent-light: var(--fo-accent-soft);--brand-primary: var(--fo-accent-primary);--brand-primary-dark: var(--fo-accent-hover);--brand-gradient: linear-gradient(135deg, var(--fo-accent-primary) 0%, #3b82f6 100%);--error-color: var(--fo-error);--success-color: var(--fo-success);--warning-color: var(--fo-warning);--shadow-sm: var(--fo-shadow-sm);--shadow-md: var(--fo-shadow-md);--shadow-lg: var(--fo-shadow-lg);--shadow-glass: var(--fo-shadow-xl);--radius-sm: var(--fo-radius-lg);--radius-md: var(--fo-radius-xl);--radius-lg: var(--fo-radius-2xl);--radius-xl: var(--fo-radius-3xl);--space-xs: var(--fo-space-1);--space-sm: var(--fo-space-2);--space-md: var(--fo-space-4);--space-lg: var(--fo-space-6);--space-xl: var(--fo-space-8);--space-2xl: var(--fo-space-12);--font-xs: var(--fo-text-xs);--font-sm: var(--fo-text-sm);--font-md: var(--fo-text-base);--font-lg: var(--fo-text-lg);--font-xl: var(--fo-text-xl);--font-2xl: var(--fo-text-2xl);--font-3xl: var(--fo-text-3xl);--transition-fast: var(--fo-duration-fast) var(--fo-ease-snap);--transition-normal: var(--fo-duration-normal) var(--fo-ease-out);--transition-slow: var(--fo-duration-slow) var(--fo-ease-out);--z-dropdown: var(--fo-z-dropdown);--z-modal: var(--fo-z-modal);--z-toast: var(--fo-z-toast);--z-tooltip: var(--fo-z-tooltip)}body.dark-theme{color-scheme:dark;--bg-primary: var(--fo-bg-base);--bg-secondary: var(--fo-bg-surface);--bg-tertiary: var(--fo-bg-elevated);--bg-card: var(--fo-bg-surface);--bg-glass: var(--fo-bg-surface);--bg-hover: var(--fo-bg-hover);--text-primary: var(--fo-text-primary);--text-secondary: var(--fo-text-secondary);--text-tertiary: var(--fo-text-tertiary);--text-muted: var(--fo-text-disabled);--border-color: var(--fo-border-default);--border-glass: var(--fo-border-subtle);--accent-color: var(--fo-accent-primary);--accent-hover: var(--fo-accent-hover);--accent-light: var(--fo-accent-soft);--brand-primary: var(--fo-accent-primary);--brand-primary-dark: var(--fo-accent-hover);--brand-gradient: linear-gradient(135deg, var(--fo-accent-primary) 0%, #60a5fa 100%);--shadow-sm: var(--fo-shadow-sm);--shadow-md: var(--fo-shadow-md);--shadow-lg: var(--fo-shadow-lg);--shadow-glass: var(--fo-shadow-xl)}:root{color:var(--text-primary);background-color:var(--bg-primary)}*{box-sizing:border-box}a{font-weight:500;color:var(--accent-color);text-decoration:none;transition:color .2s}a:hover{color:var(--accent-hover)}body{margin:0;width:100vw;height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin:0}button{border-radius:var(--radius-md);border:1px solid var(--border-color);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s}button:hover{background-color:var(--bg-hover);transform:translateY(-1px)}button:focus,button:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;position:relative}.main-content-glass{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px 16px 16px 0}.topbar-glass{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--glass-bg, rgba(255, 255, 255, .75));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);margin-bottom:8px;box-shadow:var(--shadow-glass)}.topbar-left{flex:1}.topbar-right{display:flex;align-items:center;gap:12px}.page-content{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--glass-bg, rgba(255, 255, 255, .75));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);box-shadow:var(--shadow-glass)}.page-content::-webkit-scrollbar{width:8px}.page-content::-webkit-scrollbar-track{background:transparent}.page-content::-webkit-scrollbar-thumb{background:#0000001a;border-radius:4px}.page-content::-webkit-scrollbar-thumb:hover{background:#0003}.loading-spinner-container{display:flex;align-items:center;justify-content:center;height:100%;min-height:200px}.loading-spinner-glass{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 48px;background:var(--glass-bg, rgba(255, 255, 255, .75));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid rgba(255,255,255,.5);box-shadow:var(--shadow-glass)}.loading-spinner-glass .spinner{width:32px;height:32px;border:3px solid rgba(6,182,212,.2);border-top-color:#06b6d4;border-radius:50%;animation:spin .8s linear infinite}.loading-spinner-glass span{color:var(--text-secondary);font-size:.9rem}.fullpage-loader{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e3a5f,#0f172a,#312e81)}.loader-content{text-align:center}.loader-logo{font-size:64px;margin-bottom:24px;animation:pulse 2s ease-in-out infinite}.loader-text{color:#fff;font-size:1.25rem;margin-bottom:24px;opacity:.9}.loader-bar{width:200px;height:4px;background:#fff3;border-radius:2px;overflow:hidden}.loader-progress{height:100%;width:30%;background:linear-gradient(90deg,#06b6d4,#3b82f6);border-radius:2px;animation:loading 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes loading{0%{transform:translate(-100%)}50%{transform:translate(200%)}to{transform:translate(-100%)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.bg-blue-500{background-color:#3b82f6}.bg-emerald-500{background-color:#10b981}.bg-purple-500{background-color:#a855f7}.bg-amber-500{background-color:#f59e0b}.bg-rose-500{background-color:#f43f5e}.bg-cyan-500{background-color:#06b6d4}.text-blue-500{color:#3b82f6}.text-emerald-500{color:#10b981}.text-purple-500{color:#a855f7}.text-amber-500{color:#f59e0b}.text-rose-500{color:#f43f5e}.text-cyan-500{color:#06b6d4}.from-blue-500{--tw-gradient-from: #3b82f6}.from-emerald-500{--tw-gradient-from: #10b981}.from-purple-500{--tw-gradient-from: #a855f7}.from-amber-500{--tw-gradient-from: #f59e0b}.from-rose-500{--tw-gradient-from: #f43f5e}.from-cyan-500{--tw-gradient-from: #06b6d4}.to-cyan-500{--tw-gradient-to: #06b6d4}.to-teal-500{--tw-gradient-to: #14b8a6}.to-pink-500{--tw-gradient-to: #ec4899}.to-orange-500{--tw-gradient-to: #f97316}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-from),var(--tw-gradient-to))}@media(max-width:1024px){.main-content-glass{padding:12px}}@media(max-width:768px){.app-container{flex-direction:column}.main-content-glass{margin-top:56px;padding:12px}.topbar-glass{padding:10px 16px;border-radius:12px}.page-content{border-radius:12px}.mobile-header{display:flex}.sidebar-overlay.visible{display:block}}@media(max-width:480px){.main-content-glass{padding:8px}.topbar-glass{padding:8px 12px;margin-bottom:8px}.page-content{border-radius:8px}}@media print{.sidebar,.mobile-header,.mobile-title,.brand,.sidebar-overlay,.albert-fab,.toast-container,.notification-container,nav.sidebar,.app-sidebar,.deployment-banner,.tab-bar-container{display:none!important;visibility:hidden!important}.main-content,.main-content-glass,.page-content{margin:0!important;padding:0!important;width:100%!important;max-width:none!important}.app-container,.app,#root{display:block!important;width:100%!important;height:auto!important;overflow:visible!important}body{background:#fff!important}}.albert-panel-overlay{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;box-shadow:0 10px 30px #0003;border-radius:12px;background:var(--bg-card, #1e1e1e);border:1px solid var(--border-color, #333);width:400px;height:600px;transition:all .3s ease}.albert-panel-overlay.expanded{width:900px;height:85vh;bottom:40px;right:40px}.albert-panel-container{display:flex;flex-direction:column;height:100%}.albert-panel-header{padding:8px 16px;border-bottom:1px solid var(--border-color, #333);display:flex;justify-content:space-between;align-items:center;background:#0003;border-radius:12px 12px 0 0}.albert-panel-title{display:flex;align-items:center;gap:10px}.albert-panel-title h3{margin:0;font-size:1rem;color:#e0e0e0}.albert-panel-tabs{display:flex;gap:8px;background:#0003;padding:4px;border-radius:8px}.albert-tab-btn{background:transparent;border:none;color:#888;cursor:pointer;padding:4px 8px;border-radius:4px;display:flex;align-items:center;gap:6px;font-size:.85rem}.albert-tab-btn:hover{color:#fff}.albert-tab-btn.active{background:#ffffff1a;color:#fff}.albert-panel-actions{display:flex;gap:8px}.albert-context-badge{display:flex;align-items:center;gap:6px;padding:6px 16px;font-size:.8rem;color:#888;background:#646cff14;border-bottom:1px solid var(--border-color, #333)}.albert-context-badge svg{color:#646cff}.badge-doc{color:#aaa;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.badge-calc{color:#666;font-size:.75rem}.albert-panel-body{display:flex;flex:1;overflow:hidden}.albert-chat-view{display:flex;flex-direction:column;flex:1}.albert-panel-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.message{display:flex;width:100%}.message.user{justify-content:flex-end}.message.ai{justify-content:flex-start}.message.system{justify-content:center}.message-bubble{max-width:85%;padding:10px 14px;border-radius:12px;font-size:.95rem;line-height:1.5;white-space:pre-wrap;position:relative}.message.user .message-bubble{background:#646cff;color:#fff;border-bottom-right-radius:4px}.message.ai .message-bubble{background:#2a2a2a;color:#e0e0e0;border-bottom-left-radius:4px}.message.system .message-bubble{background:#646cff1a;color:#888;font-size:.85rem;border-radius:8px;max-width:95%}.system-msg{font-style:italic}.message-bubble.loading{display:flex;align-items:center;gap:8px;color:#888}.message.ai .message-bubble .copy-btn{position:absolute;top:.4rem;right:.4rem;background:#0000004d;border:none;border-radius:4px;padding:.3rem;cursor:pointer;color:#888;opacity:0;transition:opacity .2s,background .2s,color .2s;display:flex;align-items:center;justify-content:center}.message.ai .message-bubble:hover .copy-btn{opacity:1}.message.ai .message-bubble .copy-btn:hover{background:#646cff4d;color:#646cff}.message.ai .message-bubble .copy-btn svg{width:14px;height:14px}.message.ai .message-bubble p{margin:0 0 .5rem}.message.ai .message-bubble p:last-child{margin-bottom:0}.message.ai .message-bubble code{background-color:#1a1a1a;padding:.15rem .3rem;border-radius:3px;font-family:Fira Code,Consolas,monospace;font-size:.85em}.message.ai .message-bubble pre{background-color:#1a1a1a;padding:.75rem;border-radius:6px;overflow-x:auto;margin:.5rem 0}.message.ai .message-bubble pre code{background:none;padding:0}.message.ai .message-bubble ul,.message.ai .message-bubble ol{margin:.5rem 0;padding-left:1.5rem}.message.ai .message-bubble li{margin:.25rem 0}.message.ai .message-bubble h1,.message.ai .message-bubble h2,.message.ai .message-bubble h3{margin:.75rem 0 .5rem;font-size:1em;font-weight:600}.message.ai .message-bubble blockquote{border-left:3px solid #646cff;margin:.5rem 0;padding-left:.75rem;color:#aaa}.message.ai .message-bubble a{color:#646cff;text-decoration:none}.message.ai .message-bubble a:hover{text-decoration:underline}.message.ai .message-bubble table{border-collapse:collapse;margin:.5rem 0;width:100%}.message.ai .message-bubble th,.message.ai .message-bubble td{border:1px solid #444;padding:.4rem .6rem;text-align:left}.message.ai .message-bubble th{background-color:#2a2a2a}.albert-suggestions{background:linear-gradient(135deg,#646cff1a,#646cff0d);border:1px solid rgba(100,108,255,.3);border-radius:12px;padding:12px;margin:8px 0}.suggestions-header{display:flex;align-items:center;gap:6px;color:#646cff;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.suggestions-list{display:flex;flex-wrap:wrap;gap:8px}.suggestion-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;color:#e0e0e0;font-size:.8rem;cursor:pointer;transition:all .2s ease}.suggestion-chip:hover{background:#646cff33;border-color:#646cff;color:#fff;transform:translateY(-1px)}.suggestion-chip svg{color:#646cff}.albert-panel-input-area{padding:12px;border-top:1px solid var(--border-color, #333);background:#0000001a;border-radius:0 0 12px 12px}.albert-input-row{display:flex;gap:8px}.albert-input-row input{flex:1;padding:10px 14px;border-radius:8px;border:1px solid #444;background:#1a1a1a;color:#fff;font-family:inherit;font-size:.95rem}.albert-input-row input:focus{outline:none;border-color:#646cff}.albert-input-row button{background:#646cff;color:#fff;border:none;width:40px;border-radius:8px;display:flex;justify-content:center;align-items:center;cursor:pointer}.albert-input-row button:disabled{opacity:.5;cursor:not-allowed}.albert-calc-action{padding:12px;margin:0 16px 8px;background:#646cff1a;border:1px solid rgba(100,108,255,.3);border-radius:8px}.calc-action-header{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:500;color:#e0e0e0;margin-bottom:8px}.calc-action-formula{display:block;padding:8px;background:#1a1a1a;border-radius:4px;font-family:monospace;font-size:.85rem;color:#4ade80;margin-bottom:8px}.calc-action-apply{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;background:#646cff;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem}.calc-action-apply:hover{background:#5558dd}.albert-panel-header .btn-icon{background:transparent;border:none;color:#888;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.albert-panel-header .btn-icon:hover{color:#fff}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.albert-fab{position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:28px;background:linear-gradient(135deg,#646cff,#9089fc);color:#fff;border:none;box-shadow:0 4px 15px #646cff66;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:9998;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;padding:0}.albert-fab:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 6px 20px #646cff80}.albert-fab:active{transform:scale(.95)}.albert-fab:focus{outline:none;box-shadow:0 0 0 3px #646cff4d,0 4px 15px #646cff66}@media(prefers-color-scheme:dark){.albert-fab{box-shadow:0 4px 20px #646cff4d}.albert-fab:hover{box-shadow:0 6px 25px #646cff66}}[cmdk-dialog]{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;max-width:640px;z-index:9999}[cmdk-overlay]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9998;animation:fadeIn .1s ease-out}.command-menu{background:var(--bg-surface, #ffffff);border-radius:12px;box-shadow:0 16px 70px #0003;border:1px solid var(--border-color, #e2e8f0);overflow:hidden;display:flex;flex-direction:column;animation:slideUp .1s ease-out}.command-input-wrapper{display:flex;align-items:center;padding:16px;border-bottom:1px solid var(--border-color, #e2e8f0)}.command-icon{color:var(--text-secondary, #94a3b8);margin-right:12px}.command-input{flex:1;border:none;outline:none;font-size:16px;background:transparent;color:var(--text-primary, #1e293b)}.command-input::placeholder{color:var(--text-secondary, #94a3b8)}.command-loader{width:16px;height:16px;border:2px solid var(--bg-secondary, #f1f5f9);border-top-color:var(--primary-color, #3b82f6);border-radius:50%;animation:spin .6s linear infinite;margin-right:8px}[cmdk-list]{max-height:400px;overflow-y:auto;padding:8px;scroll-behavior:smooth}[cmdk-empty]{padding:32px;text-align:center;color:var(--text-secondary);font-size:14px}[cmdk-group-heading]{padding:8px 12px 4px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}[cmdk-item]{content-visibility:auto;cursor:pointer;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:12px;padding:12px;color:var(--text-primary);-webkit-user-select:none;user-select:none;transition:all .1s ease}[cmdk-item][data-selected=true]{background:var(--bg-highlight, #f8fafc);color:var(--primary-color, #2563eb)}[cmdk-item][data-disabled=true]{color:var(--text-disabled);cursor:not-allowed}.command-item{width:100%;display:flex;align-items:center}.command-item-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--bg-secondary, #f1f5f9);border-radius:6px;flex-shrink:0}.command-item-content{flex:1;min-width:0;margin-left:12px;margin-right:12px}.command-item-title{display:flex;align-items:center;gap:8px;font-weight:500}.command-item-snippet{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.command-item-snippet b{color:var(--primary-color);font-weight:600}.command-item-meta{font-size:11px;color:var(--text-light, #cbd5e1);display:flex;align-items:center;gap:4px}.command-tag{font-size:10px;padding:2px 6px;border-radius:99px;background:var(--bg-secondary);color:var(--text-secondary)}.command-tag.status{background:#dbeafe;color:#1e40af}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-48%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.command-kbd{font-family:inherit;font-size:11px;padding:3px 6px;background:var(--bg-secondary, #f1f5f9);border:1px solid var(--border-color, #e2e8f0);border-radius:4px;color:var(--text-secondary, #64748b);margin-left:auto;flex-shrink:0;font-weight:500}[cmdk-item][data-selected=true] .command-kbd{background:var(--bg-tertiary, #e2e8f0);border-color:var(--border-color-dark, #cbd5e1)}.dark-theme .command-kbd{background:var(--bg-tertiary, #374151);border-color:var(--border-color, #4b5563);color:var(--text-secondary, #9ca3af)}.dark-theme [cmdk-item][data-selected=true] .command-kbd{background:var(--bg-quaternary, #4b5563)}.fuzzy-highlight{color:var(--primary-color, #3b82f6);font-weight:600;background:#3b82f61a;border-radius:2px;padding:0 1px}[cmdk-item][data-selected=true] .fuzzy-highlight{background:#3b82f633}.dark-theme .fuzzy-highlight{background:#60a5fa26}.dark-theme [cmdk-item][data-selected=true] .fuzzy-highlight{background:#60a5fa40}.shortcut-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.shortcut-modal{background:var(--bg-card, #1e1e1e);border:1px solid var(--border-color, #333);border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000080;animation:slideIn .2s ease}.shortcut-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #333)}.shortcut-modal-header h2{margin:0;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.5rem;color:var(--text-primary, #fff)}.shortcut-modal-header .close-btn{background:transparent;border:none;color:var(--text-secondary, #888);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s}.shortcut-modal-header .close-btn:hover{background:var(--hover-bg, #333);color:var(--text-primary, #fff)}.shortcut-modal-body{flex:1;overflow-y:auto;padding:1rem 1.25rem;display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media(max-width:600px){.shortcut-modal-body{grid-template-columns:1fr}}.shortcut-group h3{margin:0 0 .75rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #888)}.shortcut-list{display:flex;flex-direction:column;gap:.5rem}.shortcut-item{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0}.shortcut-desc{font-size:.875rem;color:var(--text-primary, #e0e0e0)}.shortcut-keys{display:flex;align-items:center;gap:.25rem}.shortcut-keys kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;height:1.5rem;padding:0 .4rem;font-size:.75rem;font-family:inherit;font-weight:500;background:linear-gradient(180deg,#3a3a3a,#2a2a2a);border:1px solid #444;border-radius:4px;color:#e0e0e0;box-shadow:0 2px #1a1a1a}.key-separator{color:var(--text-secondary, #666);font-size:.75rem;margin:0 .1rem}.shortcut-modal-footer{padding:.75rem 1.25rem;border-top:1px solid var(--border-color, #333);display:flex;justify-content:center}.shortcut-modal-footer .hint{font-size:.75rem;color:var(--text-secondary, #666);display:flex;align-items:center;gap:.5rem}.shortcut-modal-footer kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .3rem;font-size:.7rem;background:#2a2a2a;border:1px solid #444;border-radius:3px;color:#aaa}.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}.tab-bar-container{display:flex;align-items:center;background:var(--glass-bg, rgba(255, 255, 255, .75));backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);padding:4px 6px;margin-bottom:8px;box-shadow:var(--shadow-glass);min-height:40px;gap:4px}.tab-bar-scroll{display:flex;align-items:center;gap:2px;overflow-x:auto;overflow-y:hidden;flex:1;scrollbar-width:none}.tab-bar-scroll::-webkit-scrollbar{display:none}.tab-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border:none;border-radius:var(--radius-md, 8px);background:transparent;color:var(--text-on-glass-secondary, #4b5563);font-size:.8rem;font-weight:500;cursor:pointer;white-space:nowrap;max-width:200px;min-width:0;transition:background .15s ease,color .15s ease;flex-shrink:0;position:relative}.tab-item:hover{background:#0000000d;color:var(--text-on-glass, #1a1e21)}.tab-item.tab-active{background:#06b6d41f;color:#0e7490;font-weight:600}.tab-item:focus-visible{outline:2px solid var(--accent-color, #06b6d4);outline-offset:-2px}.tab-icon{flex-shrink:0}.tab-title{overflow:hidden;text-overflow:ellipsis;min-width:0}.tab-close-btn{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;border-radius:4px;background:transparent;color:inherit;padding:0;flex-shrink:0;opacity:.25;transition:opacity .1s,background .1s;margin-left:2px;cursor:pointer}.tab-item:hover .tab-close-btn,.tab-item:focus-within .tab-close-btn{opacity:.5}.tab-close-btn:hover{opacity:1!important;background:#0000001a}.tab-active .tab-close-btn:hover{background:#06b6d433}.tab-bar-fullscreen-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius-md, 8px);background:transparent;color:var(--text-on-glass-secondary, #4b5563);cursor:pointer;flex-shrink:0;padding:0;transition:background .15s,color .15s}.tab-bar-fullscreen-btn:hover{background:#0000000d;color:var(--text-on-glass, #1a1e21)}.tab-bar-fullscreen-btn:focus-visible{outline:2px solid var(--accent-color, #06b6d4);outline-offset:-2px}.app-container.app-fullscreen .sidebar-glass,.app-container.app-fullscreen .mobile-header,.app-container.app-fullscreen .sidebar-overlay,.app-container.app-fullscreen .topbar-glass,.app-container.app-fullscreen .albert-fab{display:none!important}.app-container.app-fullscreen .main-content-glass{padding:4px}.app-container.app-fullscreen .tab-bar-container{border-radius:8px;margin-bottom:4px}.app-container.app-fullscreen .page-content{border-radius:8px}body.dark-theme .tab-bar-container{border-color:#ffffff1a}body.dark-theme .tab-item:hover{background:#ffffff14}body.dark-theme .tab-item.tab-active{background:#06b6d426;color:#22d3ee}body.dark-theme .tab-close-btn:hover{background:#ffffff26}body.dark-theme .tab-active .tab-close-btn:hover{background:#06b6d44d}body.dark-theme .tab-bar-fullscreen-btn:hover{background:#ffffff14}@media(prefers-reduced-motion:reduce){.tab-item,.tab-close-btn,.tab-bar-fullscreen-btn{transition:none}}@media(forced-colors:active){.tab-item.tab-active{border:2px solid Highlight}.tab-item:focus-visible{outline:2px solid Highlight}.tab-close-btn:hover{background:Highlight;color:HighlightText}}@media(max-width:768px){.tab-bar-container{display:none}}@media print{.tab-bar-container{display:none!important}}.upgrade-modal{max-width:480px;text-align:center}.upgrade-icon{display:flex;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,#646cff26,#8b5cf626);border-radius:50%;color:var(--primary-color)}.upgrade-modal h3{margin:0 0 1rem;font-size:1.5rem;color:var(--text-primary)}.upgrade-message{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1rem}.upgrade-message strong{color:var(--primary-color)}.upgrade-message em{font-style:normal;color:var(--text-primary)}.upgrade-cta{color:var(--text-primary);font-size:.95rem;margin-bottom:1rem}.upgrade-features{text-align:left;margin:0 0 1.5rem;padding:1rem 1.5rem;background:#646cff0d;border-radius:8px;list-style:none}.upgrade-features li{position:relative;padding-left:1.5rem;margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}.upgrade-features li:last-child{margin-bottom:0}.upgrade-features li:before{content:"✓";position:absolute;left:0;color:#28a745;font-weight:700}.feature-locked-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:#6c757d26;color:#6c757d;border-radius:4px;font-size:.75rem;font-weight:500}.feature-locked-badge svg{width:12px;height:12px}.feature-gate{position:relative}.feature-gate.locked{pointer-events:none;opacity:.6;filter:grayscale(30%)}.feature-gate.locked:after{content:"";position:absolute;inset:0;background:#0000000d;cursor:not-allowed;pointer-events:auto}.trial-banner{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(90deg,#ffc10726,#fd7e1426);border:1px solid rgba(255,193,7,.3);border-radius:8px;margin-bottom:1rem}.trial-banner-text{display:flex;align-items:center;gap:.5rem;color:#d39e00;font-size:.9rem}.trial-banner-text strong{color:#fd7e14}.trial-banner-action{background:#fd7e14;color:#fff;border:none;padding:.4rem .75rem;border-radius:4px;font-size:.85rem;font-weight:500;cursor:pointer;transition:background .2s}.trial-banner-action:hover{background:#e96d0c}.tier-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tier-badge.tier-free{background:#6c757d26;color:#6c757d}.tier-badge.tier-professional{background:#007bff26;color:#007bff}.tier-badge.tier-enterprise{background:linear-gradient(135deg,#646cff33,#8b5cf633);color:#646cff}.tier-badge.tier-government{background:#28a74526;color:#28a745}@media(prefers-color-scheme:dark){.upgrade-features{background:#646cff1a}.feature-gate.locked:after{background:#0003}}body.dark-theme .upgrade-features{background:#646cff1a}body.dark-theme .feature-gate.locked:after{background:#0003}:root{--bg-forest: url(https://images.unsplash.com/photo-1448375240586-882707db888b?w=1920&q=80);--bg-lake: url(https://images.unsplash.com/photo-1439066615861-d1af74d74000?w=1920&q=80);--bg-mountains: url(https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1920&q=80);--bg-city: url(https://images.unsplash.com/photo-1480714378408-67cf0d13bc1b?w=1920&q=80);--bg-market: url(https://images.unsplash.com/photo-1488459716781-31db52582fe9?w=1920&q=80);--bg-aurora: linear-gradient(135deg, #667eea 0%, #764ba2 50%, #f093fb 100%);--app-background: var(--bg-lake);--app-background-overlay: rgba(255, 255, 255, .15)}body[data-bg-theme=forest]{--app-background: var(--bg-forest)}body[data-bg-theme=lake]{--app-background: var(--bg-lake)}body[data-bg-theme=mountains]{--app-background: var(--bg-mountains)}body[data-bg-theme=city]{--app-background: var(--bg-city)}body[data-bg-theme=market]{--app-background: var(--bg-market)}body[data-bg-theme=aurora]{--app-background: var(--bg-aurora)}:root{--glass-bg: rgba(255, 255, 255, .75);--glass-bg-hover: rgba(255, 255, 255, .85);--glass-bg-active: rgba(255, 255, 255, .9);--glass-border: rgba(255, 255, 255, .4);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .1);--glass-blur: blur(20px);--card-bg: rgba(255, 255, 255, .8);--card-border: 1px solid rgba(255, 255, 255, .5);--card-radius: 20px;--card-shadow: 0 4px 24px rgba(0, 0, 0, .08);--sidebar-bg: rgba(255, 255, 255, .85);--sidebar-border: 1px solid rgba(255, 255, 255, .5);--text-on-glass: #1a1e21;--text-on-glass-secondary: #4b5563;--text-on-glass-muted: #9ca3af;--accent-cyan: #06b6d4;--accent-cyan-light: rgba(6, 182, 212, .1);--accent-purple: #a855f7;--accent-purple-light: rgba(168, 85, 247, .1);--accent-emerald: #10b981;--accent-rose: #f43f5e;--accent-amber: #f59e0b;--gradient-primary: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);--gradient-ai: linear-gradient(135deg, #a855f7 0%, #ec4899 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}body.dark-theme{--glass-bg: rgba(15, 23, 42, .8);--glass-bg-hover: rgba(30, 41, 59, .85);--glass-bg-active: rgba(30, 41, 59, .95);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3);--card-bg: rgba(30, 41, 59, .8);--card-border: 1px solid rgba(255, 255, 255, .1);--sidebar-bg: rgba(15, 23, 42, .9);--sidebar-border: 1px solid rgba(255, 255, 255, .1);--text-on-glass: #f8fafc;--text-on-glass-secondary: #94a3b8;--text-on-glass-muted: #64748b;--app-background-overlay: rgba(0, 0, 0, .3)}.app-container{position:relative;min-height:100vh;background-image:var(--app-background);background-size:cover;background-position:center;background-attachment:fixed}.app-container:before{content:"";position:fixed;inset:0;background:var(--app-background-overlay);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none;z-index:0}.app-container>*{position:relative;z-index:1}.glass-card{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);transition:all var(--transition-normal)}.glass-card:hover{background:var(--glass-bg-hover);box-shadow:0 8px 32px #0000001f;transform:translateY(-2px)}.glass-card-static{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow)}.btn-glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:12px;padding:10px 20px;color:var(--text-on-glass);font-weight:500;cursor:pointer;transition:all var(--transition-normal)}.btn-glass:hover{background:var(--glass-bg-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.btn-primary{background:var(--gradient-primary);border:none;color:#fff;border-radius:12px;padding:10px 20px;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #06b6d44d}.btn-ai{background:var(--gradient-ai);border:none;color:#fff;border-radius:12px;padding:10px 20px;font-weight:600;cursor:pointer;transition:all var(--transition-normal)}.btn-ai:hover{transform:translateY(-2px);box-shadow:0 8px 20px #a855f74d}.quick-action-card{padding:20px;border-radius:16px;color:#fff;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden}.quick-action-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);pointer-events:none}.quick-action-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #0003}.quick-action-blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.quick-action-emerald{background:linear-gradient(135deg,#10b981,#059669)}.quick-action-purple{background:linear-gradient(135deg,#a855f7,#7c3aed)}.quick-action-rose{background:linear-gradient(135deg,#f43f5e,#e11d48)}.quick-action-amber{background:linear-gradient(135deg,#f59e0b,#d97706)}.quick-action-cyan{background:linear-gradient(135deg,#06b6d4,#0891b2)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:500}.status-badge-success{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}.status-badge-info{background:#06b6d41a;color:#0891b2;border:1px solid rgba(6,182,212,.2)}.status-badge-ai{background:#a855f71a;color:#7c3aed;border:1px solid rgba(168,85,247,.2)}.input-glass{width:100%;padding:12px 16px;background:#ffffff80;border:1px solid rgba(255,255,255,.3);border-radius:12px;color:var(--text-on-glass);font-size:.95rem;transition:all var(--transition-normal)}.input-glass:focus{outline:none;background:#ffffffb3;border-color:var(--accent-cyan);box-shadow:0 0 0 3px #06b6d41a}.input-glass::placeholder{color:var(--text-on-glass-muted)}.search-bar-glass{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#0000000d;border:1px solid rgba(0,0,0,.08);border-radius:12px;transition:all var(--transition-normal)}.search-bar-glass:hover{background:#00000014}.search-bar-glass:focus-within{background:#fff;border-color:var(--accent-cyan);box-shadow:0 0 0 3px #06b6d41a}.search-bar-glass input{flex:1;background:transparent;border:none;outline:none;font-size:.95rem;color:var(--text-on-glass)}.search-bar-glass kbd{padding:4px 8px;background:#0000000f;border-radius:6px;font-size:.75rem;color:var(--text-on-glass-muted)}.nav-item-glass{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:12px;color:var(--text-on-glass-secondary);text-decoration:none;transition:all var(--transition-fast);cursor:pointer}.nav-item-glass:hover{background:#0000000d;color:var(--text-on-glass)}.nav-item-glass.active{background:var(--accent-cyan-light);color:var(--accent-cyan);font-weight:500}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;transition:all var(--transition-fast);cursor:pointer}.activity-item:hover{background:#00000008}.activity-icon{width:40px;height:40px;border-radius:12px;background:#0000000d;display:flex;align-items:center;justify-content:center;color:var(--text-on-glass-secondary)}.activity-content{flex:1;min-width:0}.activity-title{font-weight:500;color:var(--text-on-glass);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-subtitle{font-size:.85rem;color:var(--text-on-glass-muted)}.activity-time{font-size:.8rem;color:var(--text-on-glass-muted)}.stat-card{padding:20px}.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:16px}.stat-label{font-size:.9rem;color:var(--text-on-glass-secondary);margin-bottom:4px}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-on-glass);margin-bottom:4px}.stat-change{font-size:.85rem;color:var(--accent-emerald)}.chart-bars{display:flex;align-items:flex-end;gap:4px;height:80px;margin-bottom:8px}.chart-bar{flex:1;background:var(--gradient-primary);border-radius:4px 4px 0 0;transition:all var(--transition-normal);min-height:8px}.chart-bar:hover{opacity:.8;transform:scaleY(1.05);transform-origin:bottom}.progress-bar{height:8px;background:#00000014;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--gradient-success);border-radius:4px;transition:width var(--transition-slow)}.tab-bar{display:flex;align-items:center;gap:4px;margin-bottom:16px}.tab-item{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#ffffff80;border-radius:12px 12px 0 0;color:var(--text-on-glass-secondary);cursor:pointer;transition:all var(--transition-fast)}.tab-item.active{background:#ffffffe6;color:var(--text-on-glass);border-bottom:2px solid var(--accent-cyan)}.tab-close{padding:2px;border-radius:4px;opacity:.5;transition:all var(--transition-fast)}.tab-close:hover{opacity:1;background:#0000001a}.ai-panel{position:fixed;right:16px;bottom:16px;width:320px;z-index:1000}.ai-panel-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid rgba(0,0,0,.08)}.ai-panel-icon{width:36px;height:36px;border-radius:10px;background:var(--gradient-ai);display:flex;align-items:center;justify-content:center;color:#fff}.ai-suggestion-chips{display:flex;flex-wrap:wrap;gap:8px;padding:16px}.ai-chip{padding:6px 12px;background:#0000000d;border-radius:20px;font-size:.8rem;color:var(--text-on-glass-secondary);cursor:pointer;transition:all var(--transition-fast)}.ai-chip:hover{background:#0000001a;color:var(--text-on-glass)}.user-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.user-avatar-gradient{background:linear-gradient(135deg,#f59e0b,#ea580c)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in-up{animation:fadeInUp .5s ease forwards}.animate-scale-in{animation:scaleIn .3s ease forwards}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}@media(max-width:1024px){.glass-card{border-radius:16px}}@media(max-width:768px){:root{--card-radius: 16px}.btn-glass,.btn-primary,.btn-ai{padding:14px 24px;min-height:48px;font-size:1rem}.nav-item-glass{padding:14px 16px;min-height:48px}.activity-item{padding:14px;min-height:60px}.activity-icon{width:44px;height:44px}.ai-chip{padding:10px 16px;font-size:.85rem;min-height:40px}.input-glass{padding:14px 18px;font-size:1rem;min-height:48px}.search-bar-glass{padding:12px 16px;min-height:48px}.search-bar-glass input{font-size:1rem}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.quick-action-card{padding:16px;min-height:80px}.tab-item{padding:12px 18px;min-height:44px}.tab-close{padding:6px;min-width:32px;min-height:32px}.ai-panel{width:calc(100vw - 32px);max-width:400px;right:16px;left:16px;margin:0 auto}}@media(max-width:480px){:root{--card-radius: 12px}.glass-card,.glass-card-static{border-radius:12px}.btn-glass,.btn-primary,.btn-ai{padding:12px 20px;border-radius:10px}.nav-item-glass{padding:12px 14px;border-radius:10px}.ai-panel{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;border-radius:20px 20px 0 0;margin:0}.stat-card{padding:14px}.stat-icon{width:36px;height:36px;margin-bottom:12px}.stat-value{font-size:1.25rem}.stat-label{font-size:.8rem}.glass-card:hover,.quick-action-card:hover{transform:none}}@media(max-width:768px){.app-container{background-attachment:scroll}}@media(max-width:480px){:root{--glass-blur: blur(12px)}.glass-card,.glass-card-static{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}@media(hover:none)and (pointer:coarse){.btn-glass,.btn-primary,.btn-ai,.nav-item-glass,.activity-item,.ai-chip,.tab-item,.quick-action-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.btn-glass:active{background:var(--glass-bg-active);transform:scale(.98)}.btn-primary:active,.btn-ai:active{transform:scale(.98);opacity:.9}.quick-action-card:active{transform:scale(.98);opacity:.95}.glass-card:hover{transform:none}.glass-card:active{transform:scale(.99);opacity:.95}.nav-item-glass:active{background:#00000014}.ai-chip:active{background:#0000001f}}@supports (padding: max(0px)){@media(max-width:768px){.ai-panel{padding-bottom:max(16px,env(safe-area-inset-bottom))}}}@media(prefers-reduced-motion:reduce){.animate-fade-in-up,.animate-scale-in{animation:none;opacity:1;transform:none}.glass-card,.btn-glass,.btn-primary,.btn-ai,.quick-action-card,.nav-item-glass,.activity-item{transition:none}}.code-editor-overlay{position:fixed;inset:0;z-index:10000;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:40px;animation:codeEditorFadeIn .3s ease}@keyframes codeEditorFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.code-editor-overlay>*{width:100%;height:100%;max-width:1400px;max-height:900px;box-shadow:0 25px 80px #0009;border-radius:12px;overflow:hidden}.code-editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:#1e1e1e;color:#ccc;gap:16px;border-radius:12px}.code-editor-loading .loading-spinner{width:48px;height:48px;border:3px solid #3c3c3c;border-top-color:#e94560;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}body.dark-theme .setting-group h3,body.dark-theme .setting-group h4{color:var(--text-on-glass)!important}body.dark-theme .setting-group p,body.dark-theme .setting-group label{color:var(--text-on-glass-secondary)!important}body.dark-theme .setting-group small{color:var(--text-on-glass-muted)!important}body.dark-theme .setting-group .setting-info p{color:var(--text-on-glass-secondary)!important}body.dark-theme .setting-group .setting-info h4{color:var(--text-on-glass)!important}body.dark-theme .setting-input,body.dark-theme .setting-group select,body.dark-theme .setting-group input[type=text],body.dark-theme .setting-group input[type=email],body.dark-theme .setting-group input[type=url],body.dark-theme .setting-group input[type=password],body.dark-theme .setting-group input[type=number],body.dark-theme .setting-group textarea{background:var(--glass-bg)!important;color:var(--text-on-glass)!important;border-color:var(--glass-border)!important}body.dark-theme .setting-group select option{background:#1e293b;color:#f8fafc}body.dark-theme .modal-content,body.dark-theme .upgrade-modal{background:var(--card-bg)!important;color:var(--text-on-glass)!important;border-color:var(--glass-border)!important}body.dark-theme .modal-content h3,body.dark-theme .modal-content h4{color:var(--text-on-glass)!important}body.dark-theme .modal-content p,body.dark-theme .modal-content li{color:var(--text-on-glass-secondary)!important}body.dark-theme .modal-content small{color:var(--text-on-glass-muted)!important}body.dark-theme .legal-page,body.dark-theme .legal-page h1,body.dark-theme .legal-page h2,body.dark-theme .legal-page h3{color:var(--text-on-glass)!important}body.dark-theme .legal-page p,body.dark-theme .legal-page li,body.dark-theme .legal-page .contact-info p{color:var(--text-on-glass-secondary)!important}body.dark-theme .legal-page .last-updated{color:var(--text-on-glass-muted)!important}body.dark-theme .legal-page a{color:var(--accent-cyan)!important}body.dark-theme .sap-connection-card,body.dark-theme .sap-connection-item{background:var(--glass-bg)!important;border-color:var(--glass-border)!important}body.dark-theme [style*="background: #fff"],body.dark-theme [style*="background: white"],body.dark-theme [style*="background-color: #fff"],body.dark-theme [style*="background-color: white"],body.dark-theme [style*="background: rgb(255"],body.dark-theme [style*="backgroundColor: rgb(255"],body.dark-theme [style*="background: '#fff'"],body.dark-theme [style*="background: '#f1f5f9'"],body.dark-theme [style*="background: '#f3f4f6'"],body.dark-theme [style*="background: '#f8fafc'"],body.dark-theme [style*="background: '#f9fafb'"],body.dark-theme [style*="background: '#e2e8f0'"]{background:var(--glass-bg)!important}body.dark-theme [style*="color: '#333'"],body.dark-theme [style*="color: '#1a1e21'"],body.dark-theme [style*="color: '#111'"],body.dark-theme [style*="color: '#000'"],body.dark-theme [style*="color: 'black'"],body.dark-theme [style*="color: '#0a0a0a'"]{color:var(--text-on-glass)!important}body.dark-theme [style*="color: '#666'"],body.dark-theme [style*="color: '#4b5563'"],body.dark-theme [style*="color: '#374151'"],body.dark-theme [style*="color: '#64748b'"],body.dark-theme [style*="color: '#6b7280'"]{color:var(--text-on-glass-secondary)!important}body.dark-theme [style*="color: '#888'"],body.dark-theme [style*="color: '#999'"],body.dark-theme [style*="color: '#9ca3af'"],body.dark-theme [style*="color: '#aaa'"]{color:var(--text-on-glass-muted)!important}body.dark-theme [style*="border-color: '#e2e8f0'"],body.dark-theme [style*="border-color: '#eee'"],body.dark-theme [style*="border: 1px solid #e2e8f0"],body.dark-theme [style*="border: '1px solid #e2e8f0'"],body.dark-theme [style*="borderBottom: '1px solid #eee'"],body.dark-theme [style*="border: '2px solid var(--border-color)'"]{border-color:var(--glass-border)!important}body.dark-theme .page-content,body.dark-theme .page-content h1,body.dark-theme .page-content h2,body.dark-theme .page-content h3,body.dark-theme .page-content h4{color:var(--text-on-glass)}body.dark-theme .setting-group [style*="background: '#fff'"]{background:var(--glass-bg-active)!important}body.dark-theme .setting-group [style*="borderBottom: '1px solid #eee'"]{border-bottom-color:var(--glass-border)!important}body.dark-theme .setting-group [style*="color: '#333'"]{color:var(--text-on-glass)!important}body.dark-theme .topbar-glass{background:var(--glass-bg);border-bottom-color:var(--glass-border)}body.dark-theme .tab-bar{background:var(--glass-bg)!important;border-bottom-color:var(--glass-border)!important}body.dark-theme .tab-item{color:var(--text-on-glass-secondary)!important}body.dark-theme .tab-item.active{color:var(--text-on-glass)!important;background:var(--glass-bg-active)!important}body.dark-theme .tab-item:hover:not(.active){background:var(--glass-bg-hover)!important}body.dark-theme .dashboard-card,body.dark-theme .stat-card,body.dark-theme .activity-item{background:var(--glass-bg)!important;border-color:var(--glass-border)!important;color:var(--text-on-glass)!important}body.dark-theme .file-list-item,body.dark-theme .file-grid-item{color:var(--text-on-glass)!important}body.dark-theme .file-list-item:hover,body.dark-theme .file-grid-item:hover{background:var(--glass-bg-hover)!important}body.dark-theme .context-menu,body.dark-theme [role=menu]{background:var(--card-bg)!important;border-color:var(--glass-border)!important;box-shadow:0 8px 32px #0006!important}body.dark-theme .context-menu-item,body.dark-theme [role=menuitem]{color:var(--text-on-glass)!important}body.dark-theme .context-menu-item:hover,body.dark-theme [role=menuitem]:hover{background:var(--glass-bg-hover)!important}body.dark-theme select{background:var(--glass-bg)!important;color:var(--text-on-glass)!important;border-color:var(--glass-border)!important}body.dark-theme [role=tooltip],body.dark-theme .tooltip{background:#1e293b!important;color:#f8fafc!important;border-color:#ffffff1a!important}body.dark-theme .search-input,body.dark-theme input[type=search]{background:var(--glass-bg)!important;color:var(--text-on-glass)!important;border-color:var(--glass-border)!important}body.dark-theme .search-input::placeholder,body.dark-theme input::placeholder{color:var(--text-on-glass-muted)!important}body.dark-theme .alert,body.dark-theme .info-box,body.dark-theme .notice{background:var(--glass-bg)!important;border-color:var(--glass-border)!important;color:var(--text-on-glass-secondary)!important}body.dark-theme .upgrade-modal .upgrade-message,body.dark-theme .upgrade-modal .upgrade-cta,body.dark-theme .upgrade-modal .upgrade-features li{color:var(--text-on-glass-secondary)!important}body.dark-theme .upgrade-modal .upgrade-icon,body.dark-theme .empty-state,body.dark-theme .no-results{color:var(--text-on-glass-muted)!important}body.dark-theme .command-menu-overlay .command-menu{background:var(--card-bg)!important;border-color:var(--glass-border)!important}body.dark-theme .command-menu-item{color:var(--text-on-glass)!important}body.dark-theme .command-menu-item:hover,body.dark-theme .command-menu-item.selected{background:var(--glass-bg-hover)!important}body.dark-theme .process-browser,body.dark-theme .mapping-manager{background:var(--card-bg)!important;color:var(--text-on-glass)!important}body.dark-theme .page-content strong,body.dark-theme .setting-group strong{color:var(--text-on-glass)!important}body.dark-theme .page-content a:not([style*=color]),body.dark-theme .setting-group a:not([style*=color]){color:var(--accent-cyan)!important}.skeleton{background:linear-gradient(90deg,#2a2a2a 25%,#3a3a3a,#2a2a2a 75%);background-size:200% 100%}.skeleton-text{border-radius:4px;height:1em}.skeleton-circular{border-radius:50%}.skeleton-rectangular{border-radius:0}.skeleton-rounded{border-radius:8px}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-wave{animation:skeleton-wave 1.6s linear infinite}.skeleton-none{animation:none}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--bg-card, #1e1e1e);border-radius:12px;overflow:hidden;border:1px solid var(--border-color, #333)}.skeleton-card-content{padding:1rem;display:flex;flex-direction:column;gap:.5rem}.skeleton-card-footer{display:flex;align-items:center;gap:.5rem;margin-top:.5rem}.skeleton-list-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #333)}.skeleton-list-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.skeleton-table{display:flex;flex-direction:column;gap:0}.skeleton-table-header{display:flex;gap:1rem;padding:.75rem 1rem;background:var(--bg-header, #252525);border-bottom:1px solid var(--border-color, #333)}.skeleton-table-row{display:flex;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #2a2a2a);align-items:center}.skeleton-kanban{display:flex;gap:1rem;padding:1rem;overflow-x:auto}.skeleton-kanban-column{min-width:280px;background:var(--bg-card, #1e1e1e);border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:1rem}.skeleton-kanban-cards{display:flex;flex-direction:column;gap:.75rem}.skeleton-kanban-card{background:var(--bg-elevated, #252525);border-radius:6px;padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.skeleton-kanban-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem}.skeleton-document{padding:2rem;max-width:800px;margin:0 auto}.skeleton-document-meta{display:flex;align-items:center;gap:.75rem;margin:1rem 0 2rem}.skeleton-document-content{display:flex;flex-direction:column;gap:.5rem}.skeleton-email-list{display:flex;flex-direction:column}.skeleton-email-item{display:flex;gap:1rem;padding:1rem;border-bottom:1px solid var(--border-color, #2a2a2a)}.skeleton-email-content{flex:1;display:flex;flex-direction:column;gap:.35rem}.skeleton-email-header{display:flex;justify-content:space-between;align-items:center}body:not(.dark-theme) .skeleton{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%}
