@layer tokens,base,components,utilities,theme;@layer tokens{: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;--fo-albert-accent: #646cff;--fo-albert-accent-hover: #5a62e6;--fo-albert-accent-soft: rgba(100, 108, 255, .08);--fo-accent-cyan: #06b6d4;--fo-accent-cyan-soft: rgba(6, 182, 212, .1);--fo-accent-purple: #a855f7;--fo-accent-purple-soft: rgba(168, 85, 247, .1);--fo-accent-emerald: #10b981;--fo-accent-rose: #f43f5e;--fo-accent-amber: #f59e0b;--fo-gradient-primary: linear-gradient(135deg, #06b6d4 0%, #3b82f6 100%);--fo-gradient-ai: linear-gradient(135deg, #a855f7 0%, #ec4899 100%);--fo-gradient-success: linear-gradient(135deg, #10b981 0%, #06b6d4 100%)}@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}}: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;--fo-blur-sm: blur(4px);--fo-blur-md: blur(12px);--fo-blur-lg: blur(20px);--fo-blur-xl: blur(40px)}@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}}:root *:focus-visible{outline:2px solid var(--fo-accent-primary, #2563eb)!important;outline-offset:2px!important}:root input:focus-visible,:root textarea:focus-visible,:root select:focus-visible,:root [contenteditable=true]:focus-visible{outline:2px solid var(--fo-accent-primary, #2563eb)!important;outline-offset:0!important}@media(pointer:coarse){button,[role=button],a,select,summary,input[type=checkbox],input[type=radio]{min-height:44px;min-width:44px}}.dashboard-grid{container-name:dashboard;container-type:inline-size}.file-browser{container-name:file-browser;container-type:inline-size}.kanban-board{container-name:kanban;container-type:inline-size}@container dashboard (max-width: 640px){.dashboard-grid{grid-template-columns:1fr}}@container file-browser (max-width: 500px){.file-grid{grid-template-columns:1fr}.file-browser-header{flex-direction:column;gap:8px}}@container kanban (max-width: 600px){.kanban-board{flex-direction:column}.kanban-column{min-width:100%}}@media(pointer:coarse){.sidebar button,.sidebar a,.tab-bar button,.tab-bar a,.bottom-navigation button,.bottom-navigation a,.kanban-card .card-action,.calendar-event,.file-browser-item,.mail-list-item,[role=button],[role=tab],[role=menuitem]{min-height:44px;min-width:44px}}@layer tokens{:root{--fo-space-1: 4px;--fo-space-2: 8px;--fo-space-3: 12px;--fo-space-4: 16px;--fo-space-6: 24px;--fo-space-8: 32px;--fo-space-12: 48px;--fo-space-16: 64px;--fo-radius-sm: 4px;--fo-radius-md: 6px;--fo-radius-lg: 8px;--fo-radius-xl: 12px;--fo-radius-full: 9999px;--fo-font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--fo-font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", monospace;--fo-font-size-xs: .6875rem;--fo-font-size-sm: .75rem;--fo-font-size-md: .875rem;--fo-font-size-lg: 1rem;--fo-font-size-xl: 1.125rem;--fo-font-size-2xl: 1.5rem;--fo-transition-fast: .1s ease;--fo-transition-normal: .2s ease;--fo-transition-slow: .3s ease;--fo-z-dropdown: 100;--fo-z-sticky: 200;--fo-z-modal-backdrop: 300;--fo-z-modal: 400;--fo-z-popover: 500;--fo-z-tooltip: 600;--fo-z-toast: 700;--fo-dense-row-height: 32px;--fo-dense-button-height: 28px;--fo-dense-icon-size: 16px;--fo-max-reading-width: 72ch}:root,[data-theme=light]{--fo-color-bg-default: #ffffff;--fo-color-bg-subtle: #f8f9fa;--fo-color-bg-muted: #f1f3f5;--fo-color-bg-emphasis: #e9ecef;--fo-color-bg-canvas: #ffffff;--fo-color-bg-overlay: rgba(0, 0, 0, .5);--fo-color-text-default: #212529;--fo-color-text-muted: #868e96;--fo-color-text-subtle: #adb5bd;--fo-color-text-inverse: #ffffff;--fo-color-text-link: #1971c2;--fo-color-text-link-hover: #1864ab;--fo-color-border-default: #dee2e6;--fo-color-border-muted: #e9ecef;--fo-color-border-emphasis: #adb5bd;--fo-color-border-focus: #4dabf7;--fo-color-primary: #1971c2;--fo-color-primary-hover: #1864ab;--fo-color-primary-subtle: #d0ebff;--fo-color-primary-text: #ffffff;--fo-color-success: #2f9e44;--fo-color-success-subtle: #d3f9d8;--fo-color-warning: #e67700;--fo-color-warning-subtle: #fff3bf;--fo-color-error: #e03131;--fo-color-error-subtle: #ffe3e3;--fo-color-info: #1971c2;--fo-color-info-subtle: #d0ebff;--fo-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--fo-shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--fo-shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--fo-shadow-xl: 0 20px 25px rgba(0, 0, 0, .15);--fo-focus-ring: 0 0 0 2px var(--fo-color-border-focus), 0 0 0 4px rgba(77, 171, 247, .3)}[data-theme=high-contrast]{--fo-color-bg-default: #000000;--fo-color-bg-subtle: #1a1a1a;--fo-color-bg-muted: #2a2a2a;--fo-color-bg-emphasis: #3a3a3a;--fo-color-bg-canvas: #000000;--fo-color-bg-overlay: rgba(0, 0, 0, .8);--fo-color-text-default: #ffffff;--fo-color-text-muted: #ffff00;--fo-color-text-subtle: #00ffff;--fo-color-text-inverse: #000000;--fo-color-text-link: #ffff00;--fo-color-text-link-hover: #ffffff;--fo-color-border-default: #ffffff;--fo-color-border-muted: #808080;--fo-color-border-emphasis: #ffffff;--fo-color-border-focus: #ffff00;--fo-color-primary: #ffff00;--fo-color-primary-hover: #ffffff;--fo-color-primary-subtle: #333300;--fo-color-primary-text: #000000;--fo-color-success: #00ff00;--fo-color-success-subtle: #003300;--fo-color-warning: #ffff00;--fo-color-warning-subtle: #333300;--fo-color-error: #ff0000;--fo-color-error-subtle: #330000;--fo-color-info: #00ffff;--fo-color-info-subtle: #003333;--fo-shadow-sm: none;--fo-shadow-md: none;--fo-shadow-lg: none;--fo-shadow-xl: none;--fo-focus-ring: 0 0 0 3px #ffff00}@media(forced-colors:active){:root{--fo-color-bg-default: Canvas;--fo-color-text-default: CanvasText;--fo-color-primary: Highlight;--fo-color-primary-text: HighlightText;--fo-color-border-default: CanvasText;--fo-color-border-focus: Highlight;--fo-color-text-link: LinkText}}@media(prefers-reduced-motion:reduce){:root{--fo-transition-fast: 0ms;--fo-transition-normal: 0ms;--fo-transition-slow: 0ms}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root,[data-theme=light]{--fo-writer-canvas-bg: #ffffff;--fo-writer-canvas-shadow: var(--fo-shadow-md);--fo-writer-canvas-border: var(--fo-color-border-muted);--fo-writer-toolbar-bg: var(--fo-color-bg-subtle);--fo-writer-toolbar-border: var(--fo-color-border-default);--fo-writer-toolbar-button-hover: var(--fo-color-bg-muted);--fo-writer-toolbar-button-active: var(--fo-color-primary-subtle);--fo-writer-statusbar-bg: var(--fo-color-bg-subtle);--fo-writer-statusbar-text: var(--fo-color-text-muted);--fo-writer-ruler-bg: var(--fo-color-bg-muted);--fo-writer-ruler-text: var(--fo-color-text-subtle);--fo-writer-sidebar-bg: var(--fo-color-bg-default);--fo-writer-sidebar-border: var(--fo-color-border-default);--fo-writer-selection-bg: rgba(25, 113, 194, .2);--fo-writer-cursor-color: var(--fo-color-text-default);--fo-writer-comment-bg: #fff9db;--fo-writer-track-insert: #2f9e44;--fo-writer-track-delete: #e03131;--fo-writer-page-surround: var(--fo-color-bg-muted);--fo-writer-loading-overlay: rgba(255, 255, 255, .9);--fo-writer-context-menu-bg: var(--fo-color-bg-default);--fo-writer-context-menu-shadow: 0 4px 16px rgba(0, 0, 0, .15);--fo-writer-context-menu-hover: var(--fo-color-bg-muted)}}@layer components{.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;touch-action:manipulation}button,[role=button],a,input,select,textarea,[tabindex]{touch-action:manipulation}.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-visible{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-visible{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-visible{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:var(--fo-z-popover);text-decoration:none}.fo-skip-link:focus-visible{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-error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;padding:var(--fo-space-8);text-align:center;background:var(--fo-bg-base)}.fo-error-boundary-icon{margin-bottom:var(--fo-space-4);color:var(--fo-error)}.fo-error-boundary-title{font-size:var(--fo-text-xl);font-weight:var(--fo-font-semibold);color:var(--fo-text-primary);margin:0 0 var(--fo-space-2) 0}.fo-error-boundary-message{color:var(--fo-text-secondary);margin:0 0 var(--fo-space-8) 0;max-width:500px;line-height:1.6}.fo-error-boundary-actions{display:flex;gap:var(--fo-space-4)}.fo-error-boundary-details{margin-top:var(--fo-space-8);max-width:600px;text-align:left}.fo-error-boundary-details summary{cursor:pointer;color:var(--fo-text-tertiary);margin-bottom:var(--fo-space-2);font-size:var(--fo-text-sm)}.fo-error-boundary-details pre{background:var(--fo-bg-elevated);padding:var(--fo-space-4);border-radius:var(--fo-radius-lg);overflow:auto;font-size:var(--fo-text-sm);font-family:var(--fo-font-mono);color:var(--fo-error);border:1px solid var(--fo-border-subtle)}.fo-form-field{display:flex;flex-direction:column;gap:var(--fo-space-1)}.fo-form-field-label{font-size:var(--fo-text-sm);font-weight:var(--fo-font-medium);color:var(--fo-text-primary)}.fo-form-field-label .fo-form-field-required{color:var(--fo-error);margin-left:var(--fo-space-1)}.fo-form-field-help{font-size:var(--fo-text-xs);color:var(--fo-text-tertiary)}.fo-form-field-error{font-size:var(--fo-text-xs);color:var(--fo-error);display:flex;align-items:center;gap:var(--fo-space-1)}.fo-form-field-success .fo-input{border-color:var(--fo-success)}.fo-form-field-success .fo-input:focus-visible{box-shadow:0 0 0 3px var(--fo-success-soft)}.fo-form-field-warning .fo-input{border-color:var(--fo-warning)}.fo-form-field-warning .fo-input:focus-visible{box-shadow:0 0 0 3px var(--fo-warning-soft)}.fo-form-field-error-state .fo-input{border-color:var(--fo-error)}.fo-form-field-error-state .fo-input:focus-visible{box-shadow:0 0 0 3px var(--fo-error-soft)}.fo-notification-banner{display:flex;align-items:center;gap:var(--fo-space-3);padding:var(--fo-space-3) var(--fo-space-4);border-radius:var(--fo-radius-md);font-size:var(--fo-text-sm)}.fo-notification-banner-warning{background:var(--fo-warning-soft);color:var(--fo-warning);border:1px solid var(--fo-warning)}.fo-notification-banner-error{background:var(--fo-error-soft);color:var(--fo-error);border:1px solid var(--fo-error)}.fo-notification-banner-info{background:var(--fo-accent-soft);color:var(--fo-accent-primary);border:1px solid var(--fo-accent-primary)}.fo-notification-banner-icon{flex-shrink:0}.fo-notification-banner-content{flex:1}.fo-notification-banner-dismiss{flex-shrink:0;cursor:pointer;background:none;border:none;color:inherit;opacity:.7;padding:var(--fo-space-1);border-radius:var(--fo-radius-sm)}.fo-notification-banner-dismiss:hover{opacity:1;background:#0000001a}.fo-icon-mr{margin-right:8px}.fo-icon-mr-sm{margin-right:4px;vertical-align:middle}.fo-sap-loading{display:flex;align-items:center;gap:8px;padding:2rem}.fo-sap-description{color:var(--fo-text-secondary, #64748b);margin-bottom:1rem}.fo-sap-error{background:var(--fo-bg-tertiary, #fef2f2);border:1px solid var(--fo-border-color, #fecaca);color:var(--fo-error);padding:.75rem 1rem;border-radius:var(--fo-radius-md);margin-bottom:1rem;display:flex;align-items:center;gap:8px}.fo-sap-conn-list{margin-bottom:1.5rem}.fo-sap-conn-card{background:var(--fo-bg-secondary, #f8fafc);border:1px solid var(--fo-border-color, #e2e8f0);border-radius:var(--fo-radius-lg);padding:1rem;margin-bottom:.75rem}.fo-sap-conn-header{display:flex;justify-content:space-between;align-items:flex-start}.fo-sap-conn-meta{display:flex;align-items:center;gap:8px}.fo-sap-badge{font-size:.75rem;background:var(--fo-bg-tertiary, #e2e8f0);padding:2px 6px;border-radius:var(--fo-radius-sm)}.fo-sap-badge-basic{background:#3b82f626}.fo-sap-badge-apikey{background:#eab30826}.fo-sap-badge-cookie{background:#ec489926}.fo-sap-badge-oauth2{background:#22c55e26}.fo-sap-badge-x509{background:#f59e0b26}.fo-sap-badge-none{background:var(--fo-bg-tertiary, #f3f4f6)}.fo-sap-conn-url{font-size:.875rem;color:var(--fo-text-secondary, #64748b);margin-top:4px}.fo-sap-conn-desc{font-size:.875rem;color:var(--fo-text-muted, #94a3b8);margin-top:2px}.fo-sap-conn-error{font-size:.75rem;color:var(--fo-error);margin-top:4px;display:flex;align-items:center;gap:4px}.fo-sap-conn-success{font-size:.75rem;color:#16a34a;margin-top:4px;display:flex;align-items:center;gap:4px}.fo-sap-conn-actions{display:flex;gap:8px}.fo-sap-test-result{margin-top:.75rem;padding:.75rem;border-radius:var(--fo-radius-md);font-size:.875rem}.fo-sap-test-success{background:#22c55e26}.fo-sap-test-failure{background:#ef444426}.fo-sap-test-header{display:flex;align-items:center;gap:6px}.fo-sap-test-detail{margin-top:4px}.fo-sap-test-latency{margin-top:4px;color:var(--fo-text-secondary, #64748b)}.fo-sap-empty{background:var(--fo-bg-tertiary, #f1f5f9);padding:2rem;border-radius:var(--fo-radius-lg);text-align:center;margin-bottom:1rem}.fo-sap-empty-icon{margin-bottom:8px;color:var(--fo-text-secondary, #64748b)}.fo-sap-empty-text{margin:0;color:var(--fo-text-secondary, #64748b)}.fo-sap-form{background:var(--fo-bg-secondary, #f8fafc);border:1px solid var(--fo-border-color, #e2e8f0);border-radius:var(--fo-radius-lg);padding:1.5rem}.fo-sap-form-title{margin-top:0;margin-bottom:1rem}.fo-sap-form-grid{display:grid;gap:1rem;margin-bottom:1rem}.fo-sap-form-grid-2col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.fo-sap-form-span{grid-column:1 / -1}.fo-sap-form-hint{font-size:.8rem;color:var(--fo-text-secondary, #64748b);margin:0}.fo-sap-form-actions{display:flex;gap:.75rem;justify-content:flex-end}.fo-sap-label{display:block;margin-bottom:4px;font-weight:500}.fo-sap-password-wrapper{position:relative}.fo-sap-password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px}.fo-sap-password-input{padding-right:40px}.fo-sap-pem-textarea{font-family:monospace;font-size:.75rem}.fo-sap-compact-btn{padding:6px 12px}.fo-sap-delete-btn{padding:6px 12px;color:var(--fo-error)}.fo-sap-doc-link{margin-top:1.5rem;font-size:.875rem;color:var(--fo-text-secondary, #64748b)}.fo-sap-doc-link a{color:inherit}.fo-sap-add-btn{display:flex;align-items:center;gap:6px}.fo-contact-container{display:flex;height:100%;background:var(--fo-bg-primary, #fff)}.fo-contact-sidebar{width:260px;border-right:1px solid var(--fo-border-color, #e5e7eb);padding:16px;overflow-y:auto}.fo-contact-sidebar-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.fo-contact-sidebar-title{font-weight:600;font-size:15px}.fo-contact-icon-btn{margin-left:auto;background:none;border:none;cursor:pointer;padding:4px;border-radius:var(--fo-radius-sm);opacity:.7}.fo-contact-alert-banner{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:var(--fo-radius-md);background:#fef3c7;color:#92400e;font-size:12px;margin-bottom:12px}.fo-contact-loading{opacity:.5;padding:8px}.fo-contact-empty{opacity:.5;padding:8px;font-size:13px}.fo-contact-item{padding:8px 10px;border-radius:var(--fo-radius-md);cursor:pointer;margin-bottom:2px}.fo-contact-item.active{background:var(--fo-accent-bg, #e8f0fe)}.fo-contact-item.archived{opacity:.5}.fo-contact-item-name{font-weight:500;font-size:13px}.fo-contact-item-org{font-size:11px;opacity:.6}.fo-contact-status-badge{font-size:10px;padding:1px 6px;border-radius:var(--fo-radius-sm);background:var(--fo-border-color, #e5e7eb)}.fo-contact-main{flex:1;padding:24px;overflow-y:auto}.fo-contact-placeholder{padding:40px;opacity:.4;text-align:center}.fo-contact-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.fo-contact-field{margin-bottom:10px}.fo-contact-field-label{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;opacity:.6;margin-bottom:4px}.fo-contact-field-input{width:100%;padding:8px 10px;border-radius:var(--fo-radius-md);border:1px solid var(--fo-border-color, #d1d5db);background:var(--fo-bg-secondary, #f9fafb);font-size:var(--fo-text-sm)}.fo-contact-notes{width:100%;min-height:200px;padding:10px;border-radius:var(--fo-radius-md);border:1px solid var(--fo-border-color, #d1d5db);background:var(--fo-bg-secondary, #f9fafb);font-size:var(--fo-text-sm);font-family:inherit;resize:vertical}.fo-contact-facts{padding:12px;border-radius:var(--fo-radius-lg);background:var(--fo-bg-secondary, #f0f4f8);margin-top:12px}.fo-contact-facts-title{margin:0 0 8px;font-size:13px;opacity:.7}.fo-contact-fact-row{display:flex;justify-content:space-between;font-size:13px;padding:2px 0}.fo-contact-fact-key{opacity:.6}.fo-contact-fact-value{font-weight:500}.fo-contact-actions{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap}.fo-contact-btn-primary{display:flex;align-items:center;gap:4px;padding:8px 14px;border-radius:var(--fo-radius-md);border:none;background:var(--fo-accent, #2563eb);color:var(--fo-text-inverse);cursor:pointer;font-size:var(--fo-text-sm);font-weight:500}.fo-contact-btn-secondary{display:flex;align-items:center;gap:4px;padding:8px 12px;border-radius:var(--fo-radius-md);border:1px solid var(--fo-border-color, #d1d5db);background:transparent;cursor:pointer;font-size:var(--fo-text-sm)}.fo-contact-btn-danger{display:flex;align-items:center;gap:4px;padding:8px 10px;border-radius:var(--fo-radius-md);border:1px solid #ef4444;background:transparent;color:var(--fo-error);cursor:pointer;font-size:var(--fo-text-sm)}.fo-contact-aggregate-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--fo-radius-md);border:1px dashed var(--fo-accent, #2563eb);background:transparent;color:var(--fo-accent, #2563eb);cursor:pointer;font-size:var(--fo-text-sm);margin-top:12px}.fo-contact-snooze-panel{margin-top:12px;padding:12px;border-radius:var(--fo-radius-lg);border:1px solid var(--fo-border-color, #e5e7eb)}.fo-contact-archived-banner{display:flex;align-items:center;gap:6px;padding:10px 12px;border-radius:var(--fo-radius-lg);background:var(--fo-bg-hover);margin-top:12px;font-size:var(--fo-text-sm);opacity:.7}.fo-contact-last-interaction{margin-top:12px;font-size:12px;opacity:.5}.fo-contact-section-title{margin:0 0 8px;font-size:13px;opacity:.7}.fo-contact-heading{margin:0 0 12px;font-size:16px}}@layer components{.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-visible{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)}body.calc-status-bar-hidden .fo-writer-statusbar{display:none}.fo-writer-statusbar{display:flex;align-items:center;justify-content:space-between;padding:var(--fo-space-1-5, 6px) var(--fo-space-4, 16px);background:var(--fo-bg-surface, #f8fafc);border-top:1px solid var(--fo-border-default, #e2e8f0);font-size:var(--fo-text-xs, 12px);color:var(--fo-text-tertiary, #64748b);flex-shrink:0;min-height:28px;z-index:10}.fo-statusbar-left,.fo-statusbar-right{display:flex;align-items:center;gap:var(--fo-space-4, 16px)}.fo-statusbar-item{display:flex;align-items:center;gap:var(--fo-space-1, 4px)}.fo-statusbar-item svg{width:12px;height:12px}.fo-statusbar-btn{display:flex;align-items:center;gap:var(--fo-space-1, 4px);padding:var(--fo-space-1, 4px) var(--fo-space-2, 8px);background:transparent;border:none;border-radius:var(--fo-radius-sm, 4px);color:var(--fo-text-tertiary, #64748b);font-size:var(--fo-text-xs, 12px);cursor:pointer;transition:color .15s ease}.fo-statusbar-btn:hover{color:var(--fo-text-secondary, #334155)}.fo-statusbar-btn:disabled{opacity:.35;cursor:default}.fo-statusbar-zoom-slider{width:100px;height:4px;cursor:pointer;accent-color:var(--fo-accent-primary, #4a90d9)}.fo-statusbar-zoom-value{min-width:36px;text-align:right;font-variant-numeric:tabular-nums}.fo-statusbar-status{color:var(--fo-text-tertiary)}.fo-statusbar-compat-select{font-size:11px;padding:1px 4px;border:1px solid var(--fo-border-subtle, #e2e8f0);border-radius:3px;background:transparent;color:var(--fo-text-secondary, #64748b);cursor:pointer;outline:none;margin-left:2px}.fo-statusbar-compat-select:hover{border-color:var(--fo-border-hover, #94a3b8);color:var(--fo-text-primary, #334155)}.fo-statusbar-compat-select:focus{border-color:var(--fo-accent, #3b82f6)}.fo-search-panel{position:absolute;top:8px;right:16px;z-index:50;display:flex;align-items:flex-start;gap:4px;background:var(--fo-bg-surface, #ffffff);border:1px solid var(--fo-border-default, #d1d5db);border-radius:var(--fo-radius-md);box-shadow:0 2px 8px #0000001f;padding:6px 8px;font-size:var(--fo-text-sm)}.fo-search-panel-toggle{display:flex;align-items:center;justify-content:center;width:20px;height:26px;background:none;border:none;cursor:pointer;color:var(--fo-text-secondary, #6b7280);border-radius:3px;flex-shrink:0;margin-top:1px}.fo-search-panel-toggle:hover{background:var(--fo-bg-hover, #f3f4f6)}.fo-search-panel-fields{display:flex;flex-direction:column;gap:4px}.fo-search-panel-row{display:flex;align-items:center;gap:4px}.fo-search-panel-input{width:180px;height:26px;padding:0 8px;border:1px solid var(--fo-border-default, #d1d5db);border-radius:var(--fo-radius-sm);font-size:var(--fo-text-sm);background:var(--fo-bg-base, #ffffff);color:var(--fo-text-primary, #111827);outline:none}.fo-search-panel-input:focus-visible{border-color:var(--fo-primary, #3b82f6);box-shadow:0 0 0 2px #3b82f626}.fo-search-panel-count{min-width:40px;text-align:center;font-size:12px;color:var(--fo-text-tertiary, #9ca3af);font-variant-numeric:tabular-nums}.fo-search-panel-option{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:1px solid transparent;border-radius:3px;cursor:pointer;color:var(--fo-text-secondary, #6b7280)}.fo-search-panel-option:hover{background:var(--fo-bg-hover, #f3f4f6)}.fo-search-panel-option.active{background:var(--fo-primary-light, #dbeafe);border-color:var(--fo-primary, #3b82f6);color:var(--fo-primary, #3b82f6)}.fo-search-panel-btn{display:flex;align-items:center;justify-content:center;height:24px;padding:0 6px;background:none;border:1px solid var(--fo-border-default, #d1d5db);border-radius:3px;cursor:pointer;color:var(--fo-text-secondary, #6b7280);font-size:12px;white-space:nowrap}.fo-search-panel-btn:hover:not(:disabled){background:var(--fo-bg-hover, #f3f4f6)}.fo-search-panel-btn:disabled{opacity:.4;cursor:default}.fo-search-panel-close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;border-radius:3px;cursor:pointer;color:var(--fo-text-secondary, #6b7280)}.fo-search-panel-close:hover{background:var(--fo-bg-hover, #f3f4f6);color:var(--fo-text-primary, #111827)}@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-proof-panel{display:none!important}}.fo-proof-panel{width:320px;flex-shrink:0;display:flex;flex-direction:column;background:var(--fo-bg-surface, #ffffff);border-left:1px solid var(--fo-border-default, #e2e8f0);height:100%;overflow:hidden;animation:fo-slide-in-from-right var(--fo-duration-normal, .2s) var(--fo-ease-out, ease-out)}.fo-proof-header{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--fo-border-default, #e2e8f0);flex-shrink:0}.fo-proof-title{flex:1;font-size:var(--fo-text-sm);font-weight:600;color:var(--fo-text-primary, #1e293b)}.fo-proof-close,.fo-proof-recheck{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:none;border:none;border-radius:var(--fo-radius-sm);cursor:pointer;color:var(--fo-text-secondary, #64748b)}.fo-proof-close:hover,.fo-proof-recheck:hover{background:var(--fo-bg-hover, #f1f5f9);color:var(--fo-text-primary, #1e293b)}.fo-proof-recheck:disabled{opacity:.4;cursor:default}.fo-proof-spin{animation:fo-proof-rotate .8s linear infinite}@keyframes fo-proof-rotate{to{transform:rotate(360deg)}}.fo-proof-summary{padding:6px 12px;font-size:12px;color:var(--fo-text-tertiary, #94a3b8);border-bottom:1px solid var(--fo-border-subtle, #f1f5f9);flex-shrink:0}.fo-proof-content{flex:1;overflow-y:auto;padding:8px 0}.fo-proof-content::-webkit-scrollbar{width:6px}.fo-proof-content::-webkit-scrollbar-thumb{background:var(--fo-border-default, #e2e8f0);border-radius:3px}.fo-proof-error{display:flex;align-items:flex-start;gap:8px;padding:12px;margin:8px 12px;background:var(--fo-error-soft);border-radius:var(--fo-radius-md);font-size:12px;color:#b91c1c;line-height:1.4}.fo-proof-error svg{flex-shrink:0;margin-top:1px}.fo-proof-checking{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 16px;color:var(--fo-text-tertiary, #94a3b8);font-size:var(--fo-text-sm)}.fo-proof-spinner{width:24px;height:24px;border:2.5px solid var(--fo-border-default, #e2e8f0);border-top-color:var(--fo-accent-primary, #3b82f6);border-radius:50%;animation:fo-proof-rotate .7s linear infinite}.fo-proof-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;color:var(--fo-text-tertiary, #94a3b8);font-size:var(--fo-text-sm)}.fo-proof-group{margin-bottom:4px}.fo-proof-group-header{display:flex;align-items:center;gap:6px;width:100%;padding:6px 12px;background:none;border:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--fo-text-secondary, #475569);text-align:left}.fo-proof-group-header:hover{background:var(--fo-bg-hover, #f8fafc)}.fo-proof-group-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.fo-proof-group-label{flex:1}.fo-proof-group-count{font-weight:400;color:var(--fo-text-tertiary, #94a3b8)}.fo-proof-chevron{transition:transform .15s ease;transform:rotate(-90deg);color:var(--fo-text-tertiary, #94a3b8)}.fo-proof-chevron-open{transform:rotate(0)}.fo-proof-item{padding:8px 12px 8px 16px;cursor:pointer;transition:background .1s ease}.fo-proof-item:hover{background:var(--fo-bg-hover, #f8fafc)}.fo-proof-item-active{background:var(--fo-accent-soft, #eff6ff)}.fo-proof-item-word{display:flex;flex-wrap:wrap;align-items:baseline;gap:2px;padding-left:8px;border-left:3px solid var(--fo-border-default);font-size:var(--fo-text-sm);line-height:1.5}.fo-proof-item-error{font-weight:600;color:var(--fo-text-primary, #1e293b);text-decoration:line-through;text-decoration-color:currentColor;opacity:.7}.fo-proof-item-arrow{color:var(--fo-text-tertiary, #94a3b8);font-size:12px}.fo-proof-suggestion{display:inline;background:none;border:none;padding:1px 4px;border-radius:3px;font-size:var(--fo-text-sm);font-weight:500;color:var(--fo-accent-primary, #2563eb);cursor:pointer}.fo-proof-suggestion:hover{background:var(--fo-accent-soft, #dbeafe);text-decoration:underline}.fo-proof-item-context{margin-top:4px;padding-left:12px;font-size:var(--fo-text-xs);color:var(--fo-text-tertiary, #94a3b8);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fo-proof-item-message{margin-top:4px;padding-left:12px;font-size:var(--fo-text-xs);color:var(--fo-text-secondary, #64748b);line-height:1.3}}@layer components{.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-visible{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:var(--fo-border-strong)!important}.fo-cell-header{background:#f5f5f5!important}}}@layer components{.editor-container{display:flex;flex-direction:column;height:100%;flex:1;min-height:0;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);border:1px solid var(--fo-accent-border);color:var(--fo-accent-primary)}.btn-toggle-mode:hover{background:var(--fo-accent-primary);color:var(--fo-text-inverse)}.btn-save{background:var(--fo-accent-primary);color:var(--fo-text-inverse);padding:var(--fo-space-1-5) var(--fo-space-3);font-weight:var(--fo-font-medium)}.btn-save:hover{background:var(--fo-accent-hover)}.btn-workflow{color:var(--fo-success);background:var(--fo-success-soft);border:1px solid var(--fo-success);padding:var(--fo-space-1-5) var(--fo-space-3);gap:var(--fo-space-2);font-weight:var(--fo-font-medium)}.btn-workflow:hover{background:var(--fo-success);color:var(--fo-text-inverse)}.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-visible{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:hidden;display:flex;position:relative;z-index:1;min-height:0;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);color:var(--fo-text-primary);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);background-color:transparent}.editor-content{background-color:var(--fo-doc-paper)}.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}.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)}.ProseMirror em,.ProseMirror i{font-style:italic}.ProseMirror u{text-decoration:underline;text-underline-offset:2px}.ProseMirror s,.ProseMirror strike{text-decoration:line-through}.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-visible,.modal-content textarea:focus-visible{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);background:var(--fo-warning-soft)}.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-visible{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}}}.fo-app-shell{display:grid;grid-template-rows:auto 1fr auto;grid-template-columns:1fr;height:100dvh;overflow:hidden}.fo-writer-layout{display:grid;grid-template-columns:1fr;overflow:hidden;min-height:0}.fo-sidebar{display:none;overflow-y:auto;border-left:1px solid var(--fo-color-border-default, #dee2e6);background:var(--fo-writer-sidebar-bg, var(--fo-color-bg-default, #fff));transition:width var(--fo-transition-normal, .2s ease)}.fo-sidebar--left{border-left:none;border-right:1px solid var(--fo-color-border-default, #dee2e6)}.fo-sidebar--collapsed{width:48px;min-width:48px}@media(max-width:639px){.fo-sidebar{display:none!important}.fo-writer-toolbar{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.fo-writer-toolbar::-webkit-scrollbar{display:none}.ownwriter-canvas-container{padding:0!important}.fo-writer-toolbar button,.fo-writer-toolbar [role=button]{min-width:44px;min-height:44px;padding:var(--fo-space-2, 8px)}.fo-ribbon-tab-content:not(.active){display:none}.fo-writer-statusbar{font-size:var(--fo-font-size-xs, 11px);padding:var(--fo-space-1, 4px) var(--fo-space-2, 8px)}.ownwriter-context-menu{position:fixed!important;inset:auto 0 0!important;width:100%!important;max-height:60vh;border-radius:var(--fo-radius-lg, 8px) var(--fo-radius-lg, 8px) 0 0;overflow-y:auto;-webkit-overflow-scrolling:touch}.fo-toolbar-desktop-only{display:none!important}.fo-floating-toolbar{position:fixed;bottom:max(env(keyboard-inset-height,0px),env(safe-area-inset-bottom,0px));left:0;right:0;z-index:var(--fo-z-sticky, 200);display:flex;justify-content:center;gap:var(--fo-space-1, 4px);padding:var(--fo-space-2, 8px);background:var(--fo-writer-toolbar-bg, var(--fo-color-bg-subtle, #f8f9fa));border-top:1px solid var(--fo-color-border-default, #dee2e6);box-shadow:var(--fo-shadow-lg, 0 -4px 12px rgba(0,0,0,.1));transition:bottom .15s ease-out;overscroll-behavior:none;touch-action:none}}@media(min-width:640px)and (max-width:1023px){.fo-writer-layout{grid-template-columns:1fr}.fo-sidebar{position:fixed;right:0;top:0;bottom:0;width:320px;z-index:var(--fo-z-modal, 400);box-shadow:var(--fo-shadow-xl, 0 20px 25px rgba(0,0,0,.15))}.fo-sidebar--open{display:block}.fo-sidebar-backdrop{position:fixed;inset:0;background:var(--fo-color-bg-overlay, rgba(0,0,0,.5));z-index:calc(var(--fo-z-modal, 400) - 1)}.fo-writer-toolbar button{min-width:40px;min-height:40px}}@media(min-width:1024px)and (max-width:1439px){.fo-writer-layout{grid-template-columns:1fr auto}.fo-sidebar:not(.fo-sidebar--left){display:block;width:280px;min-width:200px;max-width:400px;resize:horizontal}.fo-sidebar--left{display:block;width:48px;min-width:48px}}@media(min-width:1440px){.fo-writer-layout{grid-template-columns:auto 1fr auto}.fo-sidebar{display:block}.fo-sidebar:not(.fo-sidebar--left){width:320px;min-width:240px;max-width:480px;resize:horizontal}.fo-sidebar--left{width:240px;min-width:200px;max-width:360px;resize:horizontal}}.dense-mode{--fo-dense-row-height: 32px;--fo-dense-button-height: 28px;--fo-dense-icon-size: 16px;--fo-dense-font-size: var(--fo-font-size-sm, 12px);--fo-dense-padding-x: 8px;--fo-dense-padding-y: 4px;--fo-dense-gap: 4px}.dense-mode .fo-writer-toolbar{min-height:var(--fo-dense-row-height);padding:var(--fo-dense-padding-y) var(--fo-dense-padding-x);gap:var(--fo-dense-gap)}.dense-mode .fo-writer-toolbar button,.dense-mode .fo-writer-toolbar [role=button]{height:var(--fo-dense-button-height);min-height:var(--fo-dense-button-height);padding:var(--fo-dense-padding-y) var(--fo-dense-padding-x);font-size:var(--fo-dense-font-size)}.dense-mode .fo-writer-toolbar svg,.dense-mode .fo-writer-toolbar .icon{width:var(--fo-dense-icon-size);height:var(--fo-dense-icon-size)}.dense-mode .editor-toolbar{min-height:var(--fo-dense-row-height);padding:var(--fo-dense-padding-y) 12px;gap:var(--fo-dense-gap)}.dense-mode .editor-toolbar button,.dense-mode .editor-toolbar [role=button]{height:var(--fo-dense-button-height);min-height:var(--fo-dense-button-height);padding:var(--fo-dense-padding-y) var(--fo-dense-padding-x);font-size:var(--fo-dense-font-size)}.dense-mode .editor-toolbar svg{width:var(--fo-dense-icon-size);height:var(--fo-dense-icon-size)}.dense-mode .ownwriter-toolbar{padding:var(--fo-dense-padding-y) 8px;gap:var(--fo-dense-gap)}.dense-mode .ownwriter-toolbar button{padding:var(--fo-dense-padding-y) 8px;font-size:var(--fo-dense-font-size)}.dense-mode .fo-toolbar-group{gap:2px}.dense-mode .fo-toolbar-btn{padding:var(--fo-dense-padding-y) 6px;font-size:var(--fo-dense-font-size)}.dense-mode .fo-toolbar-btn svg{width:14px;height:14px}.dense-mode .fo-toolbar-divider{height:20px;margin:0 4px}.dense-mode .fo-writer-statusbar{min-height:24px;padding:2px 12px;font-size:var(--fo-font-size-xs, 11px)}.dense-mode .fo-sidebar,.dense-mode .fo-writer-sidebar{font-size:var(--fo-dense-font-size)}.dense-mode .fo-btn{padding:var(--fo-dense-padding-y) 12px;font-size:var(--fo-dense-font-size)}.dense-mode .fo-btn-icon{width:var(--fo-dense-button-height);height:var(--fo-dense-button-height);padding:var(--fo-dense-padding-y)}.dense-mode .fo-bubble-menu{padding:2px;gap:2px}.dense-mode .fo-bubble-menu .fo-toolbar-btn{padding:4px}.dense-mode .context-menu-item,.dense-mode .ownwriter-context-menu .ctx-item{padding:4px 8px;font-size:var(--fo-dense-font-size)}.dense-mode .tab-bar{min-height:var(--fo-dense-row-height)}.dense-mode .tab-item{padding:var(--fo-dense-padding-y) var(--fo-dense-padding-x);font-size:var(--fo-dense-font-size)}.dense-mode .fo-proof-header{padding:6px 8px}.dense-mode .fo-proof-item{padding:4px 8px 4px 12px}.dense-mode .fo-proof-group-header{padding:4px 8px;font-size:11px}.dense-mode .fo-search-panel{padding:4px 6px}.dense-mode .fo-search-panel-input{height:24px;font-size:var(--fo-dense-font-size)}.fo-dense .fo-writer-toolbar button{height:var(--fo-dense-button-height, 28px);min-height:var(--fo-dense-button-height, 28px);padding:var(--fo-space-1, 4px) var(--fo-space-2, 8px);font-size:var(--fo-font-size-sm, 12px)}.fo-dense .fo-writer-toolbar{height:var(--fo-dense-row-height, 32px)}.fo-dense .fo-writer-toolbar svg,.fo-dense .fo-writer-toolbar .icon{width:var(--fo-dense-icon-size, 16px);height:var(--fo-dense-icon-size, 16px)}.fo-sidebar[data-width]{width:attr(data-width)}.ownwriter-editor-root{container-name:editor-container;container-type:inline-size}.editor-container{container-name:editor-shell;container-type:inline-size}.fo-writer-main{container-name:writer-main;container-type:inline-size}.fo-writer-panel{container-name:writer-panel;container-type:inline-size}@container editor-container (max-width: 600px){.ownwriter-canvas{max-width:100%}.ownwriter-canvas-container{padding:8px 4px 16px}}@container editor-container (max-width: 480px){.ownwriter-canvas-container{padding:0}}@container editor-shell (max-width: 700px){.editor-toolbar{flex-wrap:wrap;gap:var(--fo-space-1, 4px)}.fo-toolbar-desktop-only{display:none}}@container editor-shell (max-width: 500px){.editor-toolbar{padding:var(--fo-space-1, 4px) var(--fo-space-2, 8px)}.fo-toolbar-divider{display:none}}@container writer-main (max-width: 640px){.fo-writer-toolbar{overflow-x:auto;scrollbar-width:none}.fo-writer-toolbar::-webkit-scrollbar{display:none}}@container writer-panel (max-width: 240px){.fo-comments-header{flex-direction:column;align-items:flex-start;gap:var(--fo-space-1, 4px)}.fo-proof-header{flex-wrap:wrap}}@media print{.fo-writer-toolbar,.fo-sidebar,.fo-writer-statusbar,.fo-floating-toolbar{display:none!important}.fo-writer-layout{grid-template-columns:1fr!important}}@media(pointer:coarse){.fo-writer-toolbar button,.fo-writer-toolbar [role=button]{min-width:44px;min-height:44px}.fo-writer-toolbar{gap:4px}.fo-sidebar{border-left-width:4px}}@media(forced-colors:active){.fo-writer-toolbar button,.fo-writer-toolbar [role=button],.editor-toolbar button,.ownwriter-toolbar button,.fo-toolbar-btn,.fo-btn,.fo-statusbar-btn{border:1px solid ButtonText;color:ButtonText;background:ButtonFace;forced-color-adjust:none}.fo-writer-toolbar button:hover,.editor-toolbar button:hover,.fo-toolbar-btn:hover,.fo-btn:hover{border-color:Highlight;color:Highlight}.fo-writer-toolbar button.active,.editor-toolbar button.active,.fo-toolbar-btn.active{border-color:Highlight;color:HighlightText;background:Highlight}.fo-btn-primary{background:Highlight;color:HighlightText;border-color:Highlight}.fo-btn-primary:hover:not(:disabled){background:HighlightText;color:Highlight;border-color:Highlight}*:focus-visible{outline:2px solid Highlight;outline-offset:2px}.fo-toolbar-divider,.fo-divider,.fo-divider-vertical{background:CanvasText}.fo-writer-toolbar,.editor-toolbar,.fo-writer-statusbar,.fo-sidebar,.fo-writer-panel{border-color:CanvasText}.context-menu,.ownwriter-context-menu{border:2px solid CanvasText;background:Canvas;forced-color-adjust:none}.context-menu-item,.ownwriter-context-menu .ctx-item{color:CanvasText;border:1px solid transparent}.context-menu-item:hover,.ownwriter-context-menu .ctx-item:hover{border-color:Highlight;background:Highlight;color:HighlightText}.context-menu-item.danger{color:LinkText}.fo-text-primary,.fo-text-secondary,.fo-text-tertiary,.fo-writer-editor,.ownwriter-status{color:CanvasText}.fo-input,.fo-select,.fo-search-panel-input{border:1px solid CanvasText;background:Canvas;color:CanvasText}.fo-input:focus-visible,.fo-select:focus-visible,.fo-search-panel-input:focus-visible{border-color:Highlight;outline:2px solid Highlight}a,.fo-writer-editor a{color:LinkText}.fo-modal,.shortcut-modal,.shortcut-overview-modal{border:2px solid CanvasText;background:Canvas;forced-color-adjust:none}.fo-badge{border:1px solid CanvasText;background:Canvas;color:CanvasText}.fo-card{border:1px solid CanvasText}::-webkit-scrollbar-thumb{background:CanvasText}button:disabled,.fo-btn:disabled{border-color:GrayText;color:GrayText}.ctx-shortcut,.context-menu-shortcut{color:GrayText}kbd{border:1px solid CanvasText;color:CanvasText;background:Canvas}}@layer base{: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)}}@layer base{: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:background-color .2s,color .2s,border-color .2s,box-shadow .2s,opacity .2s}button:hover{background-color:var(--bg-hover);transform:translateY(-1px)}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;display:flex;flex-direction:column;min-height:0;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:has(>.editor-container){overflow:hidden}.page-content:has(.editor-container){overflow:hidden}.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 spin{to{transform:rotate(360deg)}}@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%)}}}@layer utilities{.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))}}@layer base{@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}}}@layer base{[dir=rtl]{text-align:right}[dir=rtl] .sidebar-glass{border-right:none;border-left:1px solid rgba(255,255,255,.5)}[dir=rtl] .main-content-glass{padding:16px 0 16px 16px}@media(max-width:768px){[dir=rtl] .sidebar-glass{left:auto;right:0;transform:translate(100%)}[dir=rtl] .sidebar-glass.mobile-open{transform:translate(0)}[dir=rtl] .main-content-glass{padding:12px}}[dir=rtl] .loader-progress{animation-direction:reverse}}.sr-only{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important}:focus-visible{outline:2px solid #2563eb!important;outline-offset:2px!important;border-radius:2px}input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #2563eb!important;outline-offset:0!important}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.media-consent-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--fo-z-modal);animation:mediaConsentFadeIn .15s ease}@keyframes mediaConsentFadeIn{0%{opacity:0}to{opacity:1}}.media-consent-dialog{background:var(--bg-primary, white);border-radius:var(--fo-radius-xl);width:100%;max-width:540px;box-shadow:0 20px 60px #0000004d;animation:mediaConsentSlideUp .2s ease}@keyframes mediaConsentSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.media-consent-header{display:flex;align-items:center;gap:12px;padding:20px 24px 0}.media-consent-header-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#dbeafe;color:#2563eb;flex-shrink:0}.media-consent-header h3{flex:1;margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary, var(--fo-text-primary))}.media-consent-close{background:none;border:none;color:var(--text-secondary, var(--fo-text-tertiary));cursor:pointer;padding:4px;border-radius:var(--fo-radius-sm)}.media-consent-close:hover{background:var(--bg-secondary, #f5f5f5)}.media-consent-body{padding:16px 24px}.media-consent-files{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.media-consent-file-tag{display:inline-block;padding:3px 10px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, var(--fo-border-default));border-radius:var(--fo-radius-sm);font-size:var(--fo-text-xs, .75rem);color:var(--text-secondary, var(--fo-text-tertiary));max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-consent-intro{margin:0 0 12px;color:var(--text-primary, var(--fo-text-primary));font-size:var(--fo-text-base);font-weight:500}.media-consent-points{list-style:none;padding:0;margin:0 0 16px}.media-consent-points li{position:relative;padding:8px 0 8px 12px;color:var(--text-secondary, var(--fo-text-tertiary));font-size:var(--fo-text-sm);line-height:1.5}.media-consent-points li:before{content:"•";position:absolute;left:0;color:var(--text-secondary, var(--fo-text-tertiary))}.media-consent-points li strong{color:var(--text-primary, var(--fo-text-primary));font-weight:600}.media-consent-points li+li{border-top:1px solid var(--border-color, var(--fo-border-default))}.media-consent-checkbox-row{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, var(--fo-border-default));border-radius:var(--fo-radius-lg);cursor:pointer;-webkit-user-select:none;user-select:none}.media-consent-checkbox-row:hover{background:var(--bg-tertiary, #eee)}.media-consent-checkbox-row input[type=checkbox]{margin-top:2px;flex-shrink:0;width:16px;height:16px;accent-color:var(--accent-color, var(--fo-accent-primary));cursor:pointer}.media-consent-checkbox-label{font-size:var(--fo-text-sm);line-height:1.4;color:var(--text-primary, var(--fo-text-primary))}.media-consent-actions{display:flex;gap:12px;padding:16px 24px 20px;justify-content:flex-end}.media-consent-cancel{padding:10px 20px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, var(--fo-border-default));border-radius:var(--fo-radius-lg);cursor:pointer;font-size:var(--fo-text-sm);font-weight:500;color:var(--text-primary, var(--fo-text-primary));transition:background-color .15s ease}.media-consent-cancel:hover{background:var(--bg-tertiary, #eee)}.media-consent-confirm{padding:10px 20px;border:none;border-radius:var(--fo-radius-lg);cursor:pointer;font-size:var(--fo-text-sm);font-weight:500;color:var(--fo-text-inverse, white);background:var(--accent-color, var(--fo-accent-primary));transition:background-color .15s ease,opacity .15s ease}.media-consent-confirm:hover:not(:disabled){background:var(--fo-accent-hover)}.media-consent-confirm:disabled{opacity:.5;cursor:not-allowed}.albert-fab{position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:28px;background:linear-gradient(135deg,var(--fo-albert-accent) 0%,var(--fo-albert-accent-hover) 100%);color:var(--fo-text-inverse);border:none;box-shadow:0 4px 15px #646cff66;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:var(--fo-z-fixed);overflow:visible;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-visible{outline:none;box-shadow:0 0 0 3px #646cff4d,0 4px 15px #646cff66}body.albert-thinking .albert-fab{animation:albert-think-pulse 2s cubic-bezier(.4,0,.6,1) infinite;box-shadow:0 0 20px #646cff99,0 0 40px #9089fc4d}body.albert-thinking .albert-fab:before{content:"";position:absolute;inset:-4px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0%,rgba(100,108,255,.4) 25%,transparent 50%,rgba(144,137,252,.3) 75%,transparent 100%);animation:albert-think-rotate 3s linear infinite;z-index:-1;mask:radial-gradient(circle,transparent 60%,black 62%);-webkit-mask:radial-gradient(circle,transparent 60%,black 62%)}@keyframes albert-think-pulse{0%,to{box-shadow:0 0 15px #646cff80,0 0 30px #9089fc33;transform:scale(1)}50%{box-shadow:0 0 25px #646cffb3,0 0 50px #9089fc59;transform:scale(1.05)}}@keyframes albert-think-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){body.albert-thinking .albert-fab{animation:none;box-shadow:0 0 20px #646cff99}body.albert-thinking .albert-fab:before{animation:none;opacity:.5}}.fo-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--fo-bg-surface, #ffffff);border-top:1px solid var(--fo-border-default, #e5e7eb);padding:4px 0 calc(4px + env(safe-area-inset-bottom,0px));justify-content:space-around;align-items:center}@media(max-width:639px){.fo-bottom-nav{display:flex}}.fo-bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:44px;min-height:44px;padding:4px 8px;border:none;background:transparent;color:var(--fo-text-secondary, #6b7280);cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;border-radius:8px;transition:color .15s ease,background .15s ease}.fo-bottom-nav-item:active{background:var(--fo-bg-accent-subtle, rgba(59, 130, 246, .08))}.fo-bottom-nav-item.active{color:var(--fo-bg-accent, #3b82f6)}.fo-bottom-nav-label{font-size:10px;font-weight:500;line-height:1;white-space:nowrap}[data-theme=dark] .fo-bottom-nav,.dark .fo-bottom-nav{background:var(--fo-bg-surface, #1e1e1e);border-top-color:var(--fo-border-default, #333)}[data-theme=dark] .fo-bottom-nav-item,.dark .fo-bottom-nav-item{color:var(--fo-text-secondary, #9ca3af)}[data-theme=dark] .fo-bottom-nav-item.active,.dark .fo-bottom-nav-item.active{color:var(--fo-bg-accent, #60a5fa)}@media(max-width:639px){.app-content{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}}.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, var(--fo-text-secondary));font-size:var(--fo-text-sm);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:var(--fo-radius-sm);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;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, var(--fo-text-secondary));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}.app-container.app-fullscreen .main-content-glass{padding:4px}.app-container.app-fullscreen .tab-bar-container{border-radius:var(--fo-radius-lg);margin-bottom:4px}.app-container.app-fullscreen .page-content{border-radius:var(--fo-radius-lg)}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}}@layer base{: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: var(--fo-text-primary);--text-on-glass-secondary: var(--fo-text-secondary);--text-on-glass-muted: var(--fo-text-tertiary);--accent-cyan: var(--fo-accent-cyan);--accent-cyan-light: var(--fo-accent-cyan-soft);--accent-purple: var(--fo-accent-purple);--accent-purple-light: var(--fo-accent-purple-soft);--accent-emerald: var(--fo-accent-emerald);--accent-rose: var(--fo-accent-rose);--accent-amber: var(--fo-accent-amber);--gradient-primary: var(--fo-gradient-primary);--gradient-ai: var(--fo-gradient-ai);--gradient-success: var(--fo-gradient-success);--transition-fast: var(--fo-duration-fast);--transition-normal: var(--fo-duration-normal);--transition-slow: var(--fo-duration-slow)}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);--app-background-overlay: rgba(0, 0, 0, .3)}@supports not (backdrop-filter: blur(1px)){:root{--glass-bg: rgba(255, 255, 255, .92);--glass-bg-hover: rgba(255, 255, 255, .96);--glass-bg-active: rgba(255, 255, 255, .98);--card-bg: rgba(255, 255, 255, .95);--sidebar-bg: rgba(255, 255, 255, .95)}body.dark-theme{--glass-bg: rgba(15, 23, 42, .95);--glass-bg-hover: rgba(30, 41, 59, .97);--card-bg: rgba(30, 41, 59, .95);--sidebar-bg: rgba(15, 23, 42, .97)}}.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:var(--fo-radius-xl);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:var(--fo-text-inverse);border-radius:var(--fo-radius-xl);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:var(--fo-text-inverse);border-radius:var(--fo-radius-xl);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:var(--fo-radius-2xl);color:var(--fo-text-inverse);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,var(--fo-accent-primary) 0%,#1d4ed8 100%)}.quick-action-emerald{background:linear-gradient(135deg,var(--fo-success) 0%,#059669 100%)}.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:var(--fo-radius-3xl);font-size:var(--fo-text-sm);font-weight:500}.status-badge-success{background:#10b9811a;color:var(--fo-success);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:var(--fo-radius-xl);color:var(--text-on-glass);font-size:var(--fo-text-base);transition:all var(--transition-normal)}.input-glass:focus-visible{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:var(--fo-radius-xl);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:var(--fo-text-base);color:var(--text-on-glass)}.search-bar-glass kbd{padding:4px 8px;background:#0000000f;border-radius:var(--fo-radius-md);font-size:.75rem;color:var(--text-on-glass-muted)}.nav-item-glass{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:var(--fo-radius-xl);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:var(--fo-radius-xl);transition:all var(--transition-fast);cursor:pointer}.activity-item:hover{background:#00000008}.activity-icon{width:40px;height:40px;border-radius:var(--fo-radius-xl);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,.activity-time{font-size:var(--fo-text-sm);color:var(--text-on-glass-muted)}.stat-card{padding:20px}.stat-icon{width:44px;height:44px;border-radius:var(--fo-radius-xl);display:flex;align-items:center;justify-content:center;color:var(--fo-text-inverse);margin-bottom:16px}.stat-label{font-size:var(--fo-text-sm);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:var(--fo-text-sm);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:var(--fo-radius-sm) var(--fo-radius-sm) 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:var(--fo-radius-sm);overflow:hidden}.progress-fill{height:100%;background:var(--gradient-success);border-radius:var(--fo-radius-sm);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:var(--fo-radius-xl) var(--fo-radius-xl) 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:var(--fo-radius-sm);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:var(--fo-z-modal)}.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:var(--fo-radius-lg);background:var(--gradient-ai);display:flex;align-items:center;justify-content:center;color:var(--fo-text-inverse)}.ai-suggestion-chips{display:flex;flex-wrap:wrap;gap:8px;padding:16px}.ai-chip{padding:6px 12px;background:#0000000d;border-radius:var(--fo-radius-3xl);font-size:var(--fo-text-sm);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:var(--fo-text-inverse)}.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:var(--fo-radius-2xl)}}@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:var(--fo-text-sm);min-height:40px}.input-glass{padding:14px 16px;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 16px;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:var(--fo-radius-xl)}.btn-glass,.btn-primary,.btn-ai{padding:12px 20px;border-radius:var(--fo-radius-lg)}.nav-item-glass{padding:12px 14px;border-radius:var(--fo-radius-lg)}.ai-panel{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;border-radius:var(--fo-radius-3xl) var(--fo-radius-3xl) 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:var(--fo-text-sm)}.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){button,[role=button],a:not(.inline-link),input[type=checkbox],input[type=radio],select,.btn-glass,.btn-primary,.btn-ai,.nav-item-glass,.activity-item,.ai-chip,.tab-item,.quick-action-card{min-height:44px;min-width:44px;-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:var(--fo-z-modal);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:var(--fo-radius-xl);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:var(--fo-radius-xl)}.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)}}}[data-glass=false] .glass-card,[data-glass=false] .glass-card-static{background:var(--fo-color-bg-default, #ffffff);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--fo-color-border-default, #dee2e6);box-shadow:var(--fo-shadow-sm)}[data-glass=false] .btn-glass{background:var(--fo-color-bg-subtle, #f8f9fa);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--fo-color-border-default, #dee2e6)}[data-glass=false] .input-glass,[data-glass=false] .search-bar-glass{background:var(--fo-color-bg-default, #ffffff);backdrop-filter:none;-webkit-backdrop-filter:none;border:1px solid var(--fo-color-border-default, #dee2e6)}[data-glass=false] .app-container{background:var(--fo-color-bg-default, #ffffff);backdrop-filter:none;-webkit-backdrop-filter:none}.skeleton{background:linear-gradient(90deg,var(--fo-bg-elevated) 25%,#3a3a3a 50%,var(--fo-bg-elevated) 75%);background-size:200% 100%}.skeleton-text{border-radius:var(--fo-radius-sm);height:1em}.skeleton-circular{border-radius:50%}.skeleton-rectangular{border-radius:0}.skeleton-rounded{border-radius:var(--fo-radius-lg)}.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:var(--fo-radius-xl);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, var(--fo-bg-elevated));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:var(--fo-radius-lg);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, var(--fo-bg-elevated));border-radius:var(--fo-radius-md);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}.skeleton-writer-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--fo-bg-surface, #1e1e1e);border-bottom:1px solid var(--fo-border-default, #333);flex-shrink:0}.skeleton-toolbar-divider{width:1px;height:24px;background:var(--fo-border-default, #333);margin:0 4px;flex-shrink:0}.skeleton-writer-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--fo-bg-surface, #1e1e1e);border-right:1px solid var(--fo-border-default, #333)}.skeleton-sidebar-header{display:flex;align-items:center;justify-content:space-between}.skeleton-sidebar-items{display:flex;flex-direction:column;gap:8px}.skeleton-sidebar-item{display:flex;align-items:center;gap:8px;padding:4px 0}.skeleton-sidebar-item-indent{padding-left:20px}.skeleton-writer-layout{display:flex;flex-direction:column;width:100%;height:100%;overflow:hidden}.skeleton-writer-body{display:flex;flex:1;min-height:0;overflow:hidden}.skeleton-writer-canvas-area{flex:1;display:flex;justify-content:center;padding:24px 40px 40px;background:var(--fo-doc-canvas, #2a2a2a);overflow:auto}.skeleton-writer-canvas-area .skeleton-document{background:var(--fo-doc-paper, #1e1e1e);box-shadow:0 1px 4px #00000014,0 4px 16px #0000001f;border-radius:0;max-width:800px;width:100%}body:not(.dark-theme) .skeleton{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%}body:not(.dark-theme) .skeleton-writer-toolbar{background:var(--fo-bg-surface, #f5f5f5);border-bottom-color:var(--fo-border-default, #e0e0e0)}body:not(.dark-theme) .skeleton-toolbar-divider{background:var(--fo-border-default, #e0e0e0)}body:not(.dark-theme) .skeleton-writer-sidebar{background:var(--fo-bg-surface, #f8f8f8);border-right-color:var(--fo-border-default, #e0e0e0)}body:not(.dark-theme) .skeleton-writer-canvas-area{background:var(--fo-doc-canvas, #f0f1f3)}body:not(.dark-theme) .skeleton-writer-canvas-area .skeleton-document{background:var(--fo-doc-paper, white)}
