*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root,[data-theme=light]{--color-bg: #f8f9fb;--color-surface: #ffffff;--color-surface-alt: #f3f4f7;--color-surface-hover: #eef0f4;--color-border: #e2e5ea;--color-border-strong: #cdd1d8;--color-text: #1a1d23;--color-text-secondary: #5a6069;--color-text-tertiary: #8a8f98;--color-text-inverse: #ffffff;--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff4ff;--color-primary-text: #ffffff;--color-accent: #0f766e;--color-accent-light: #ecfdf5;--color-info: #2563eb;--color-info-bg: #eff6ff;--color-info-border: #bfdbfe;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-success-border: #bbf7d0;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-warning-border: #fde68a;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-ai: #7c3aed;--color-ai-bg: #f5f3ff;--color-ai-border: #ddd6fe;--color-slate: #64748b;--color-slate-bg: #f1f5f9;--color-slate-border: #cbd5e1;--color-header-bg: #1e293b;--color-header-text: #f1f5f9;--color-header-text-secondary: #94a3b8;--color-header-border: #334155;--color-sidebar-bg: #ffffff;--color-sidebar-border: #e2e5ea;--color-sidebar-hover: #f3f4f7;--color-sidebar-active: #eff4ff;--color-sidebar-active-border: #2563eb;--color-footer-bg: #f3f4f7;--color-footer-text: #64748b;--color-table-header-bg: #f8f9fb;--color-table-row-hover: #f3f4f7;--color-table-row-selected: #eff4ff;--color-table-border: #e2e5ea;--color-input-bg: #ffffff;--color-input-border: #d1d5db;--color-input-focus: #2563eb;--color-card-shadow: rgba(0, 0, 0, .06);--color-overlay: rgba(0, 0, 0, .4);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--sidebar-width: 260px;--header-height: 56px;--footer-height: 40px}[data-theme=dark]{--color-bg: #0f1117;--color-surface: #1a1d27;--color-surface-alt: #22252f;--color-surface-hover: #2a2d38;--color-border: #2e3140;--color-border-strong: #3d4050;--color-text: #e8eaef;--color-text-secondary: #9ba1ad;--color-text-tertiary: #6b7280;--color-text-inverse: #0f1117;--color-primary: #3b82f6;--color-primary-hover: #60a5fa;--color-primary-light: #1e2a4a;--color-primary-text: #ffffff;--color-accent: #2dd4bf;--color-accent-light: #132e2a;--color-info: #3b82f6;--color-info-bg: #1e2a4a;--color-info-border: #1e40af;--color-success: #22c55e;--color-success-bg: #132e1a;--color-success-border: #166534;--color-warning: #f59e0b;--color-warning-bg: #2e2510;--color-warning-border: #92400e;--color-error: #ef4444;--color-error-bg: #2e1313;--color-error-border: #991b1b;--color-ai: #a78bfa;--color-ai-bg: #1e1533;--color-ai-border: #5b21b6;--color-slate: #94a3b8;--color-slate-bg: #1e2330;--color-slate-border: #334155;--color-header-bg: #111318;--color-header-text: #e8eaef;--color-header-text-secondary: #6b7280;--color-header-border: #2e3140;--color-sidebar-bg: #151720;--color-sidebar-border: #2e3140;--color-sidebar-hover: #22252f;--color-sidebar-active: #1e2a4a;--color-sidebar-active-border: #3b82f6;--color-footer-bg: #111318;--color-footer-text: #6b7280;--color-table-header-bg: #1a1d27;--color-table-row-hover: #22252f;--color-table-row-selected: #1e2a4a;--color-table-border: #2e3140;--color-input-bg: #22252f;--color-input-border: #3d4050;--color-input-focus: #3b82f6;--color-card-shadow: rgba(0, 0, 0, .3);--color-overlay: rgba(0, 0, 0, .6);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4)}html,body,#root{height:100%;width:100%;overflow:hidden}body{background:var(--color-bg);color:var(--color-text)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.global-header{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);padding:0 var(--spacing-lg);background:var(--color-header-bg);color:var(--color-header-text);border-bottom:1px solid var(--color-header-border);flex-shrink:0;z-index:100}.header-left{display:flex;align-items:center;gap:var(--spacing-md)}.brand-block{display:flex;align-items:center;gap:var(--spacing-sm)}.brand-mark{width:32px;height:32px;border-radius:var(--radius-md);background:var(--color-primary);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;letter-spacing:-.5px;flex-shrink:0}.brand-name{font-size:15px;font-weight:600;letter-spacing:-.3px;color:var(--color-header-text)}.brand-separator{width:1px;height:24px;background:var(--color-header-border);margin:0 var(--spacing-sm)}.workspace-label{font-size:12px;color:var(--color-header-text-secondary);font-weight:500}.header-right{display:flex;align-items:center;gap:2px}.header-action{display:flex;align-items:center;gap:var(--spacing-xs);padding:6px 10px;background:none;border:none;color:var(--color-header-text-secondary);font-size:12px;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s,color .15s;white-space:nowrap;font-family:inherit}.header-action:hover{background:#ffffff14;color:var(--color-header-text)}.header-action-icon{font-size:15px;line-height:1}.language-selector{display:flex;align-items:center;gap:var(--spacing-xs);padding:4px 6px 4px 10px;border-radius:var(--radius-sm);transition:background .15s}.language-selector:hover{background:#ffffff14}.language-selector-icon{font-size:15px;line-height:1}.language-selector-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;border:1px solid var(--color-header-border);color:var(--color-header-text-secondary);font-size:12px;font-family:inherit;padding:3px 22px 3px 8px;border-radius:var(--radius-sm);cursor:pointer;outline:none;transition:border-color .15s,color .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239ca3af' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:10px 6px}.language-selector-select:hover,.language-selector-select:focus-visible{border-color:var(--color-header-text-secondary);color:var(--color-header-text)}.language-selector-select:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.language-selector-select option{background:var(--color-surface);color:var(--color-text)}.header-divider{width:1px;height:20px;background:var(--color-header-border);margin:0 6px}.user-menu-wrapper{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:var(--spacing-sm);padding:4px 10px;background:none;border:1px solid transparent;color:var(--color-header-text);cursor:pointer;border-radius:var(--radius-md);font-family:inherit;font-size:12px;transition:background .15s}.user-menu-trigger:hover{background:#ffffff14}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}.user-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:200;padding:var(--spacing-xs) 0}.user-menu-header{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-xs)}.user-menu-header-name{font-size:13px;font-weight:600;color:var(--color-text)}.user-menu-header-hint{font-size:11px;color:var(--color-text-tertiary);margin-top:2px}.user-menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:8px var(--spacing-md);background:none;border:none;color:var(--color-text-secondary);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s,color .1s}.user-menu-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.user-menu-item-icon{font-size:14px}.user-menu-separator{height:1px;background:var(--color-border);margin:var(--spacing-xs) 0}.shell-content{display:flex;flex:1;overflow:hidden}.left-sidebar{width:var(--sidebar-width);background:var(--color-sidebar-bg);border-right:1px solid var(--color-sidebar-border);overflow-y:auto;flex-shrink:0;padding:var(--spacing-md) 0}.nav-group{margin-bottom:var(--spacing-md)}.nav-group-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);padding:0 var(--spacing-md);margin-bottom:var(--spacing-xs)}.nav-group ul{list-style:none}.nav-item{position:relative}.nav-item-button{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:8px var(--spacing-md);background:none;border:none;color:var(--color-text-secondary);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s,color .1s;border-left:2px solid transparent}.nav-item-button:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.nav-item-current .nav-item-button{background:var(--color-sidebar-active);color:var(--color-primary);border-left-color:var(--color-sidebar-active-border);font-weight:600}.nav-item-planned .nav-item-button{opacity:.55;cursor:default}.nav-item-icon{font-size:15px;flex-shrink:0}.nav-item-label{flex:1}.nav-item-badge{font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 5px;border-radius:3px;background:var(--color-surface-alt);color:var(--color-text-tertiary);flex-shrink:0}.nav-item-current .nav-item-badge{background:var(--color-primary-light);color:var(--color-primary)}.page-surface{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-header{padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.page-header h2{font-size:18px;font-weight:700;color:var(--color-text);margin-bottom:2px}.page-header-subtitle{font-size:12px;color:var(--color-text-secondary)}.page-body{flex:1;overflow-y:auto;padding:var(--spacing-lg) var(--spacing-xl)}.app-footer{display:flex;align-items:center;justify-content:space-between;height:var(--footer-height);padding:0 var(--spacing-lg);background:var(--color-footer-bg);border-top:1px solid var(--color-border);font-size:11px;color:var(--color-footer-text);flex-shrink:0}.inline-command{display:inline-block;margin-top:var(--spacing-xs);padding:6px 8px;background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;word-break:break-all}.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}:root{--font-family-sans: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;--font-family-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-base: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 22px;--font-size-3xl: 28px;--font-size-4xl: 36px;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-base: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.025em;--letter-spacing-normal: 0;--letter-spacing-wide: .025em;--letter-spacing-wider: .05em;--letter-spacing-widest: .1em;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--radius-none: 0;--radius-xs: 2px;--radius-2xl: 16px;--radius-full: 9999px;--z-base: 0;--z-raised: 10;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-popover: 500;--z-toast: 600;--z-tooltip: 700;--z-max: 9999;--duration-instant: 0ms;--duration-fast: .1s;--duration-normal: .15s;--duration-slow: .25s;--duration-slower: .4s;--easing-default: cubic-bezier(.16, 1, .3, 1);--easing-in: cubic-bezier(.4, 0, 1, 1);--easing-out: cubic-bezier(0, 0, .2, 1);--easing-inout: cubic-bezier(.4, 0, .2, 1);--easing-spring: cubic-bezier(.34, 1.56, .64, 1);--easing-bounce: cubic-bezier(.68, -.55, .27, 1.55);--focus-ring-color: var(--color-primary);--focus-ring-offset: 2px;--focus-ring-width: 2px;--iconbar-width: 48px;--right-sidebar-width: 280px;--breadcrumb-height: 36px;--tabbar-height: 40px;--commandpalette-width: 560px;--commandpalette-maxheight: 400px;--scrollbar-width: 6px;--scrollbar-radius: 3px;--color-focus-ring: var(--color-primary);--color-selection-bg: var(--color-primary-light);--color-selection-text: var(--color-primary);--color-destructive: var(--color-error);--color-destructive-bg: var(--color-error-bg);--color-destructive-hover: #b91c1c;--color-kbd-bg: var(--color-surface-alt);--color-kbd-border: var(--color-border-strong);--color-code-bg: var(--color-surface-alt);--color-separator: var(--color-border);--color-icon-bar-bg: var(--color-header-bg);--color-icon-bar-border: var(--color-header-border);--color-icon-bar-icon: var(--color-header-text-secondary);--color-icon-bar-active: var(--color-header-text);--color-icon-bar-activebg: rgba(255,255,255,.12);--color-icon-bar-hover: rgba(255,255,255,.08);--color-right-sidebar-bg: var(--color-sidebar-bg);--color-right-sidebar-border: var(--color-sidebar-border);--color-skeleton-base: var(--color-surface-alt);--color-skeleton-shine: var(--color-surface-hover);--color-progress-track: var(--color-surface-alt);--color-progress-fill: var(--color-primary);--color-avatar-bg: var(--color-primary);--color-avatar-text: var(--color-primary-text);--color-tag-bg: var(--color-surface-alt);--color-tag-border: var(--color-border);--color-tag-text: var(--color-text-secondary);--color-tag-remove: var(--color-text-tertiary)}[data-theme=high-contrast]{--color-bg: #000000;--color-surface: #0a0a0a;--color-surface-alt: #141414;--color-surface-hover: #1f1f1f;--color-border: #ffffff;--color-border-strong: #ffffff;--color-text: #ffffff;--color-text-secondary: #e0e0e0;--color-text-tertiary: #b0b0b0;--color-text-inverse: #000000;--color-primary: #60a5fa;--color-primary-hover: #93c5fd;--color-primary-light: #1e2a4a;--color-primary-text: #000000;--color-accent: #34d399;--color-accent-light: #064e3b;--color-info: #60a5fa;--color-info-bg: #0f1d3a;--color-info-border: #60a5fa;--color-success: #4ade80;--color-success-bg: #052e16;--color-success-border: #4ade80;--color-warning: #fbbf24;--color-warning-bg: #1c1300;--color-warning-border: #fbbf24;--color-error: #f87171;--color-error-bg: #2d0000;--color-error-border: #f87171;--color-ai: #c4b5fd;--color-ai-bg: #1e0a3c;--color-ai-border: #c4b5fd;--color-slate: #e2e8f0;--color-slate-bg: #1a1f2e;--color-slate-border: #e2e8f0;--color-header-bg: #000000;--color-header-text: #ffffff;--color-header-text-secondary: #c0c0c0;--color-header-border: #ffffff;--color-sidebar-bg: #000000;--color-sidebar-border: #ffffff;--color-sidebar-hover: #1a1a1a;--color-sidebar-active: #1e2a4a;--color-sidebar-active-border: #60a5fa;--color-footer-bg: #000000;--color-footer-text: #c0c0c0;--color-table-header-bg: #0a0a0a;--color-table-row-hover: #1a1a1a;--color-table-row-selected: #1e2a4a;--color-table-border: #ffffff;--color-input-bg: #0a0a0a;--color-input-border: #ffffff;--color-input-focus: #60a5fa;--color-card-shadow: rgba(255, 255, 255, .1);--color-overlay: rgba(0, 0, 0, .85);--shadow-sm: 0 0 0 1px #ffffff;--shadow-md: 0 0 0 1px #ffffff, 0 2px 8px rgba(0,0,0,.8);--shadow-lg: 0 0 0 1px #ffffff, 0 4px 16px rgba(0,0,0,.9);--color-icon-bar-bg: #000000;--color-icon-bar-border: #ffffff;--color-icon-bar-icon: #c0c0c0;--color-icon-bar-active: #ffffff;--color-icon-bar-activebg: rgba(255,255,255,.2);--color-icon-bar-hover: rgba(255,255,255,.15);--color-skeleton-base: #1a1a1a;--color-skeleton-shine: #2a2a2a;--color-progress-track: #1a1a1a;--color-progress-fill: #60a5fa}[data-theme=custom]{--color-bg: var(--custom-bg-primary, #f0f4ff);--color-surface: #ffffff;--color-surface-alt: color-mix(in srgb, var(--custom-accent, #7c3aed) 6%, #ffffff);--color-surface-hover: color-mix(in srgb, var(--custom-accent, #7c3aed) 10%, #ffffff);--color-border: color-mix(in srgb, var(--custom-accent, #7c3aed) 15%, #e2e5ea);--color-border-strong: color-mix(in srgb, var(--custom-accent, #7c3aed) 25%, #cdd1d8);--color-text: #1a1d23;--color-text-secondary: #5a6069;--color-text-tertiary: #8a8f98;--color-text-inverse: #ffffff;--color-primary: var(--custom-accent, #7c3aed);--color-primary-hover: color-mix(in srgb, var(--custom-accent, #7c3aed) 80%, #000000);--color-primary-light: color-mix(in srgb, var(--custom-accent, #7c3aed) 10%, #ffffff);--color-primary-text: #ffffff;--color-accent: var(--custom-accent, #7c3aed);--color-accent-light: color-mix(in srgb, var(--custom-accent, #7c3aed) 10%, #ffffff);--color-header-bg: color-mix(in srgb, var(--custom-accent, #7c3aed) 90%, #000000);--color-header-text: #f1f5f9;--color-header-text-secondary: rgba(241,245,249,.7);--color-header-border: color-mix(in srgb, var(--custom-accent, #7c3aed) 70%, #000000);--color-sidebar-active: color-mix(in srgb, var(--custom-accent, #7c3aed) 12%, #ffffff);--color-sidebar-active-border: var(--custom-accent, #7c3aed);--color-input-focus: var(--custom-accent, #7c3aed);--color-icon-bar-bg: color-mix(in srgb, var(--custom-accent, #7c3aed) 90%, #000000);--color-icon-bar-border: color-mix(in srgb, var(--custom-accent, #7c3aed) 70%, #000000);--color-info: #2563eb;--color-info-bg: #eff6ff;--color-info-border: #bfdbfe;--color-success: #16a34a;--color-success-bg: #f0fdf4;--color-success-border: #bbf7d0;--color-warning: #d97706;--color-warning-bg: #fffbeb;--color-warning-border: #fde68a;--color-error: #dc2626;--color-error-bg: #fef2f2;--color-error-border: #fecaca;--color-footer-bg: #f3f4f7;--color-footer-text: #64748b;--color-overlay: rgba(0, 0, 0, .4);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .1)}[data-theme=dark]{--color-icon-bar-bg: #111318;--color-icon-bar-border: #2e3140;--color-icon-bar-icon: #6b7280;--color-icon-bar-active: #e8eaef;--color-icon-bar-activebg: rgba(255,255,255,.1);--color-icon-bar-hover: rgba(255,255,255,.06);--color-right-sidebar-bg: #151720;--color-right-sidebar-border: #2e3140;--color-skeleton-base: #22252f;--color-skeleton-shine: #2a2d38;--color-progress-track: #22252f;--color-progress-fill: #3b82f6;--color-kbd-bg: #22252f;--color-kbd-border: #3d4050;--color-code-bg: #22252f;--color-destructive: #ef4444;--color-destructive-bg: #2e1313;--color-destructive-hover: #ef4444;--color-tag-bg: #22252f;--color-tag-border: #3d4050;--color-tag-text: #9ba1ad;--color-tag-remove: #6b7280;--color-focus-ring: #3b82f6}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}::-webkit-scrollbar{width:var(--scrollbar-width);height:var(--scrollbar-width)}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--scrollbar-radius)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.skip-to-main{position:absolute;top:-100px;left:var(--space-4);z-index:var(--z-max);background:var(--color-primary);color:var(--color-primary-text);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-decoration:none;transition:top var(--duration-normal)}.skip-to-main:focus{top:var(--space-4)}[dir=rtl] .app-shell-body{flex-direction:row-reverse}[dir=rtl] .icon-bar{order:3;border-right:none;border-left:1px solid var(--color-icon-bar-border)}[dir=rtl] .left-sidebar{border-right:none;border-left:1px solid var(--color-sidebar-border);order:2}[dir=rtl] .right-sidebar{border-left:none;border-right:1px solid var(--color-right-sidebar-border);order:0}[dir=rtl] .nav-item-button{border-left:none;border-right:2px solid transparent;text-align:right}[dir=rtl] .nav-item-current .nav-item-button{border-right-color:var(--color-sidebar-active-border)}[dir=rtl] .header-left,[dir=rtl] .header-right{flex-direction:row-reverse}[dir=rtl] .user-menu-dropdown,[dir=rtl] .ds-dropdown{right:auto;left:0}[dir=rtl] .ds-context-menu{direction:rtl}[dir=rtl] .ds-toast-container{right:auto;left:var(--space-6)}[dir=rtl] .ds-breadcrumb-sep{transform:scaleX(-1)}.icon-bar{width:var(--iconbar-width);background:var(--color-icon-bar-bg);border-right:1px solid var(--color-icon-bar-border);display:flex;flex-direction:column;align-items:center;flex-shrink:0;overflow:hidden;z-index:var(--z-sticky)}.icon-bar-section{display:flex;flex-direction:column;align-items:center;width:100%}.icon-bar-section--top{padding-top:var(--space-2);flex:1}.icon-bar-section--bottom{padding-bottom:var(--space-2)}.icon-bar-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:var(--iconbar-width);height:var(--iconbar-width);background:none;border:none;color:var(--color-icon-bar-icon);cursor:pointer;position:relative;transition:background var(--duration-normal),color var(--duration-normal);font-size:18px}.icon-bar-btn:hover{background:var(--color-icon-bar-hover);color:var(--color-icon-bar-active)}.icon-bar-btn[aria-pressed=true],.icon-bar-btn.active{background:var(--color-icon-bar-activebg);color:var(--color-icon-bar-active)}.icon-bar-btn[aria-pressed=true]:before,.icon-bar-btn.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:2px;height:24px;background:var(--color-primary);border-radius:0 var(--radius-xs) var(--radius-xs) 0}[dir=rtl] .icon-bar-btn[aria-pressed=true]:before,[dir=rtl] .icon-bar-btn.active:before{left:auto;right:0;border-radius:var(--radius-xs) 0 0 var(--radius-xs)}.icon-bar-btn-label{font-size:9px;font-weight:var(--font-weight-medium);margin-top:2px;text-align:center;letter-spacing:.03em;line-height:1;opacity:.8}.icon-bar-separator{width:28px;height:1px;background:var(--color-icon-bar-border);margin:var(--space-1) 0;flex-shrink:0}.ds-toolbar{display:flex;gap:var(--space-2);padding:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.ds-toolbar--wrap{flex-wrap:wrap}.ds-toolbar--vertical{flex-direction:column;align-items:stretch}.ds-toolbar-group{display:flex;flex-direction:column;gap:var(--space-2);min-width:0;padding:var(--space-2);background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:var(--radius-md)}.ds-toolbar-group-items{display:flex;align-items:stretch;gap:var(--space-1);flex-wrap:wrap}.ds-toolbar--vertical .ds-toolbar-group-items{flex-direction:column;align-items:stretch}.ds-toolbar-group-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider)}.ds-toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:34px;min-width:34px;padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid transparent;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-size:var(--font-size-sm);font-family:inherit;transition:background var(--duration-fast),border-color var(--duration-fast),color var(--duration-fast),box-shadow var(--duration-fast)}.ds-toolbar-btn:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border)}.ds-toolbar-btn:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.ds-toolbar-btn:disabled{opacity:.45;cursor:not-allowed}.ds-toolbar-btn--active{background:var(--color-primary-light);border-color:color-mix(in srgb,var(--color-primary) 50%,var(--color-border));color:var(--color-primary)}.ds-toolbar-btn--icon-only{padding-inline:var(--space-2)}.ds-toolbar-btn--stacked{min-width:76px;flex-direction:column;gap:var(--space-1);align-items:center}.ds-toolbar-btn-icon{display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1}.ds-toolbar-btn-label{line-height:1.2;white-space:nowrap}.ds-toolbar-btn-caret{font-size:10px;color:var(--color-text-tertiary)}.ds-toolbar-item-separator{width:1px;min-height:28px;background:var(--color-border);margin:0 var(--space-1)}.ds-toolbar--vertical .ds-toolbar-item-separator{width:auto;height:1px;min-height:1px}.app-shell-body{display:flex;flex:1;overflow:hidden;min-height:0}.right-sidebar{width:var(--right-sidebar-width);background:var(--color-right-sidebar-bg);border-left:1px solid var(--color-right-sidebar-border);overflow-y:auto;flex-shrink:0;transition:width var(--duration-slow) var(--easing-out)}.right-sidebar--collapsed{width:0;overflow:hidden}.right-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);flex-shrink:0}.ds-splitter{width:4px;cursor:col-resize;background:transparent;flex-shrink:0;transition:background var(--duration-fast);position:relative}.ds-splitter:hover,.ds-splitter.dragging{background:var(--color-primary)}.ds-splitter:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;margin:0 -4px}.ds-breadcrumbs{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary);min-height:var(--breadcrumb-height);padding:0 var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;flex-wrap:wrap}.ds-breadcrumb-item{display:flex;align-items:center;gap:var(--space-1)}.ds-breadcrumb-link{color:var(--color-text-secondary);text-decoration:none;cursor:pointer;background:none;border:none;font-size:inherit;font-family:inherit;padding:0;transition:color var(--duration-fast)}.ds-breadcrumb-link:hover{color:var(--color-primary);text-decoration:underline}.ds-breadcrumb-current{color:var(--color-text);font-weight:var(--font-weight-medium)}.ds-breadcrumb-sep{color:var(--color-text-tertiary);font-size:var(--font-size-xs);-webkit-user-select:none;user-select:none}.ds-tabs{display:flex;flex-direction:column}.ds-tablist{display:flex;border-bottom:1px solid var(--color-border);gap:0;overflow-x:auto;flex-shrink:0;scrollbar-width:none}.ds-tablist::-webkit-scrollbar{display:none}.ds-tab{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);background:none;border:none;border-bottom:2px solid transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:inherit;cursor:pointer;white-space:nowrap;transition:color var(--duration-normal),border-color var(--duration-normal);margin-bottom:-1px}.ds-tab:hover{color:var(--color-text)}.ds-tab[aria-selected=true]{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.ds-tab:disabled{opacity:.5;cursor:not-allowed}.ds-tab-panel{padding:var(--space-4) 0}.ds-tab-panel[hidden]{display:none}.ds-dropdown-wrapper{position:relative;display:inline-flex}.ds-dropdown{position:fixed;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-1) 0;margin:0;list-style:none;animation:ds-dropdown-in var(--duration-normal) var(--easing-default)}.ds-dropdown--right{left:auto;right:0}.ds-dropdown--up{top:auto;bottom:calc(100% + var(--space-1))}@keyframes ds-dropdown-in{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.ds-menu-item{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:none;border:none;color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;text-align:start;transition:background var(--duration-fast),color var(--duration-fast);border-radius:0;-webkit-user-select:none;user-select:none}.ds-menu-item:hover{background:var(--color-surface-hover)}.ds-menu-item:focus-visible{outline:none;background:var(--color-surface-hover)}.ds-menu-item[aria-disabled=true],.ds-menu-item:disabled{opacity:.45;cursor:not-allowed}.ds-menu-item[role=menuitemcheckbox][aria-checked=true],.ds-menu-item[role=menuitemradio][aria-checked=true]{background:var(--color-primary-light)}.ds-menu-item--destructive{color:var(--color-destructive)}.ds-menu-item--destructive:hover{background:var(--color-destructive-bg);color:var(--color-destructive)}.ds-menu-item-icon{width:16px;flex-shrink:0;text-align:center;font-size:14px}.ds-menu-item-label{flex:1}.ds-menu-item-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap}.ds-menu-item-kbd{font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-kbd-bg);border:1px solid var(--color-kbd-border);border-radius:var(--radius-xs);padding:0 4px}.ds-menu-item-check{width:16px;flex-shrink:0;color:var(--color-primary);font-size:12px}.ds-menu-separator{height:1px;background:var(--color-border);margin:var(--space-1) 0}.ds-menu-section-header{padding:var(--space-1) var(--space-3) var(--space-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-widest);-webkit-user-select:none;user-select:none}.ds-submenu-wrapper{position:relative}.ds-submenu{position:absolute;top:-4px;left:100%;min-width:160px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-1) 0;animation:ds-dropdown-in var(--duration-normal) var(--easing-default)}[dir=rtl] .ds-submenu{left:auto;right:100%}.ds-context-menu{position:fixed;min-width:180px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-popover);padding:var(--space-1) 0;margin:0;list-style:none;animation:ds-dropdown-in var(--duration-fast) var(--easing-default)}.ds-command-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);z-index:var(--z-modal);display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;animation:ds-fade-in var(--duration-normal)}@keyframes ds-fade-in{0%{opacity:0}to{opacity:1}}.ds-command-panel{width:var(--commandpalette-width);max-width:calc(100vw - var(--space-8));background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;animation:ds-slide-in var(--duration-slow) var(--easing-default)}@keyframes ds-slide-in{0%{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.ds-command-input-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.ds-command-input-icon{color:var(--color-text-tertiary);font-size:16px;flex-shrink:0}.ds-command-input{flex:1;background:none;border:none;outline:none;font-size:var(--font-size-md);font-family:inherit;color:var(--color-text)}.ds-command-input::placeholder{color:var(--color-text-tertiary)}.ds-command-results{max-height:var(--commandpalette-maxheight);overflow-y:auto;padding:var(--space-1) 0}.ds-command-result-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);cursor:pointer;transition:background var(--duration-fast)}.ds-command-result-item:hover,.ds-command-result-item[aria-selected=true]{background:var(--color-surface-hover)}.ds-command-result-icon{font-size:16px;color:var(--color-text-secondary);flex-shrink:0}.ds-command-result-label{flex:1;font-size:var(--font-size-base);color:var(--color-text)}.ds-command-result-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.ds-command-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-4);padding:var(--space-2) var(--space-4);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.ds-command-kbd{display:inline-flex;align-items:center;gap:var(--space-1);background:var(--color-kbd-bg);border:1px solid var(--color-kbd-border);border-radius:var(--radius-xs);padding:1px 5px;font-size:var(--font-size-xs);font-family:var(--font-family-mono);color:var(--color-text-secondary)}.ds-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);z-index:var(--z-overlay);animation:ds-fade-in var(--duration-normal)}.ds-dialog{position:fixed;top:50%;left:50%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:calc(100vh - var(--space-8));display:flex;flex-direction:column;transform:translate(-50%,-50%);z-index:var(--z-modal);animation:ds-dialog-in var(--duration-slow) var(--easing-default);overflow:hidden}.ds-dialog--sm{max-width:360px}.ds-dialog--md{max-width:540px}.ds-dialog--lg{max-width:720px}.ds-dialog--xl{max-width:960px}.ds-dialog--full{max-width:calc(100vw - var(--space-8));max-height:calc(100vh - var(--space-8))}@keyframes ds-dialog-in{0%{opacity:0;transform:translate(-50%,calc(-50% + 8px)) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.ds-dialog-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0;gap:var(--space-4)}.ds-dialog-header-text{flex:1;min-width:0}.ds-dialog-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.ds-dialog-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.ds-dialog-close{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);font-size:18px;line-height:1;flex-shrink:0;transition:color var(--duration-fast),background var(--duration-fast)}.ds-dialog-close:hover{color:var(--color-text);background:var(--color-surface-hover)}.ds-dialog-body{flex:1;overflow-y:auto;padding:var(--space-6)}.ds-dialog-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);flex-shrink:0}.ds-dialog-footer--between{justify-content:space-between}.ds-dialog--destructive .ds-dialog-title{color:var(--color-destructive)}.ds-dialog--nonmodal{position:fixed;bottom:var(--space-6);right:var(--space-6);max-width:360px;z-index:var(--z-popover);box-shadow:var(--shadow-lg)}[dir=rtl] .ds-dialog--nonmodal{right:auto;left:var(--space-6)}.ds-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-overlay);z-index:var(--z-overlay);animation:ds-fade-in var(--duration-normal)}.ds-drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:90vw;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:var(--shadow-lg);z-index:var(--z-modal);display:flex;flex-direction:column;animation:ds-drawer-in var(--duration-slow) var(--easing-default)}.ds-drawer--left{right:auto;left:0;border-left:none;border-right:1px solid var(--color-border);animation:ds-drawer-in-left var(--duration-slow) var(--easing-default)}@keyframes ds-drawer-in{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes ds-drawer-in-left{0%{transform:translate(-100%)}to{transform:translate(0)}}[dir=rtl] .ds-drawer{right:auto;left:0;border-left:none;border-right:1px solid var(--color-border);animation-name:ds-drawer-in-left}[dir=rtl] .ds-drawer--left{left:auto;right:0;border-right:none;border-left:1px solid var(--color-border);animation-name:ds-drawer-in}.ds-tooltip-wrapper{position:relative;display:inline-flex}.ds-tooltip{position:absolute;bottom:calc(100% + var(--space-2));left:50%;transform:translate(-50%);background:var(--color-text);color:var(--color-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);white-space:nowrap;pointer-events:none;z-index:var(--z-tooltip);animation:ds-fade-in var(--duration-fast);max-width:240px;text-align:center;font-weight:var(--font-weight-medium)}.ds-tooltip--below{bottom:auto;top:calc(100% + var(--space-2))}.ds-tooltip--end{left:auto;right:0;transform:none}.ds-tooltip--start{left:0;transform:none}.ds-popover-wrapper{position:relative;display:inline-flex}.ds-popover{position:absolute;top:calc(100% + var(--space-2));left:0;min-width:240px;max-width:320px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:var(--z-popover);padding:var(--space-3) var(--space-4);animation:ds-dropdown-in var(--duration-normal) var(--easing-default)}.ds-popover--end{left:auto;right:0}.ds-popover--up{top:auto;bottom:calc(100% + var(--space-2))}.ds-popover-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:var(--space-2);color:var(--color-text)}.ds-popover-body{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-base)}.ds-hint-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:var(--radius-full);background:var(--color-surface-alt);border:1px solid var(--color-border);color:var(--color-text-tertiary);font-size:10px;font-weight:var(--font-weight-bold);cursor:pointer;line-height:1;flex-shrink:0;transition:background var(--duration-fast),color var(--duration-fast)}.ds-hint-icon:hover{background:var(--color-primary-light);color:var(--color-primary)}.ds-alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid;font-size:var(--font-size-sm)}.ds-alert--info{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info)}.ds-alert--success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.ds-alert--warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning)}.ds-alert--error{background:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error)}.ds-alert-icon{font-size:16px;flex-shrink:0;margin-top:1px}.ds-alert-content{flex:1;min-width:0}.ds-alert-body{display:block;color:var(--color-text-secondary);line-height:var(--line-height-base)}.ds-alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.ds-alert-text{color:var(--color-text-secondary);line-height:var(--line-height-base)}.ds-alert-dismiss{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-top:-2px;background:color-mix(in srgb,currentColor 8%,transparent);border:1px solid color-mix(in srgb,currentColor 22%,transparent);border-radius:var(--radius-sm);cursor:pointer;color:inherit;font-size:14px;flex-shrink:0;transition:background var(--duration-fast),border-color var(--duration-fast),color var(--duration-fast),opacity var(--duration-fast)}.ds-alert-dismiss:hover:not(:disabled){background:color-mix(in srgb,currentColor 16%,transparent)}.ds-alert-dismiss:active:not(:disabled){background:color-mix(in srgb,currentColor 22%,transparent)}.ds-alert-dismiss:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.ds-alert-dismiss:disabled{opacity:.4;cursor:not-allowed}.ds-alert-actions{margin-top:var(--space-2);display:flex;gap:var(--space-2)}.ds-announcement-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-2) var(--space-6);background:var(--color-warning-bg);border-bottom:1px solid var(--color-warning-border);font-size:var(--font-size-sm);color:var(--color-warning);flex-shrink:0}.ds-toast-container{position:fixed;bottom:calc(var(--footer-height) + var(--space-4));right:var(--space-6);display:flex;flex-direction:column-reverse;gap:var(--space-2);z-index:var(--z-toast);pointer-events:none;max-width:380px}.ds-toast{display:flex;align-items:flex-start;gap:var(--space-2);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);border:1px solid;font-size:var(--font-size-sm);box-shadow:var(--shadow-lg);pointer-events:all;animation:ds-toast-in var(--duration-slow) var(--easing-spring)}@keyframes ds-toast-in{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}.ds-toast--success{background:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.ds-toast--error{background:var(--color-error-bg);border-color:var(--color-error-border);color:var(--color-error)}.ds-toast--warning{background:var(--color-warning-bg);border-color:var(--color-warning-border);color:var(--color-warning)}.ds-toast--info{background:var(--color-info-bg);border-color:var(--color-info-border);color:var(--color-info)}.ds-toast-icon{font-size:16px;flex-shrink:0}.ds-toast-body{flex:1;min-width:0}.ds-toast-title{font-weight:var(--font-weight-semibold);line-height:1.3}.ds-toast-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.ds-toast-close{background:none;border:none;cursor:pointer;color:inherit;font-size:14px;padding:0;opacity:.6;flex-shrink:0;margin-top:1px}.ds-toast-close:hover{opacity:1}.ds-toast-action{margin-top:var(--space-2)}.ds-field{display:flex;flex-direction:column;gap:var(--space-1)}.ds-field-label-row{display:flex;align-items:center;gap:var(--space-1)}.ds-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);line-height:var(--line-height-tight)}.ds-label-required{color:var(--color-error);font-size:var(--font-size-sm);margin-left:2px}.ds-label-required:before{content:"*"}.ds-input,.ds-textarea,.ds-select{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);font-size:var(--font-size-base);font-family:var(--font-family-sans);color:var(--color-text);width:100%;transition:border-color var(--duration-normal),box-shadow var(--duration-normal);line-height:var(--line-height-base)}.ds-input:focus,.ds-textarea:focus,.ds-select:focus{outline:none;border-color:var(--color-input-focus);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-input-focus) 15%,transparent)}.ds-input--error,.ds-textarea--error,.ds-select--error{border-color:var(--color-error)}.ds-input--error:focus,.ds-textarea--error:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-error) 15%,transparent)}.ds-input--success,.ds-textarea--success{border-color:var(--color-success)}.ds-input:disabled,.ds-textarea:disabled,.ds-select:disabled{opacity:.55;cursor:not-allowed;background:var(--color-surface-alt)}.ds-input[readonly],.ds-textarea[readonly]{background:var(--color-surface-alt);cursor:default}.ds-textarea{min-height:80px;resize:vertical}.ds-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:12px 8px;padding-right:32px;cursor:pointer}.ds-helper{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:var(--line-height-base)}.ds-error-text{font-size:var(--font-size-xs);color:var(--color-error);display:flex;align-items:center;gap:var(--space-1)}.ds-error-icon{font-size:12px;flex-shrink:0}.ds-input-wrapper{position:relative;display:flex;align-items:center}.ds-input-wrapper .ds-input{padding-left:var(--space-8)}.ds-input-wrapper .ds-input--trail{padding-right:var(--space-8)}.ds-input-lead{position:absolute;left:var(--space-3);color:var(--color-text-tertiary);font-size:14px;pointer-events:none}.ds-input-trail{position:absolute;right:var(--space-3);color:var(--color-text-tertiary);font-size:14px}.ds-check-label,.ds-radio-label{display:flex;align-items:flex-start;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text);line-height:var(--line-height-base)}.ds-check-label input[type=checkbox],.ds-radio-label input[type=radio]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--color-primary);cursor:pointer}.ds-check-label:has(input:disabled),.ds-radio-label:has(input:disabled){opacity:.55;cursor:not-allowed}.ds-radio-group{display:flex;flex-direction:column;gap:var(--space-2)}.ds-toggle-label{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;-webkit-user-select:none;user-select:none}.ds-toggle-track{position:relative;width:36px;height:20px;background:var(--color-border-strong);border-radius:var(--radius-full);transition:background var(--duration-normal);flex-shrink:0}.ds-toggle-input{position:absolute;opacity:0;width:0;height:0}.ds-toggle-input:checked~.ds-toggle-track{background:var(--color-primary)}.ds-toggle-input:disabled~.ds-toggle-track{opacity:.55;cursor:not-allowed}.ds-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:var(--radius-full);transition:transform var(--duration-normal) var(--easing-spring);box-shadow:0 1px 3px #0003;pointer-events:none}.ds-toggle-input:checked~.ds-toggle-track .ds-toggle-thumb{transform:translate(16px)}.ds-toggle-text{font-size:var(--font-size-sm);color:var(--color-text);line-height:var(--line-height-base)}.ds-file-zone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);padding:var(--space-8) var(--space-6);text-align:center;cursor:pointer;transition:border-color var(--duration-normal),background var(--duration-normal);background:var(--color-surface-alt)}.ds-file-zone:hover,.ds-file-zone--dragover{border-color:var(--color-primary);background:var(--color-primary-light)}.ds-file-zone-icon{font-size:28px;color:var(--color-text-tertiary);margin-bottom:var(--space-2)}.ds-file-zone-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.ds-file-zone-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.ds-tag-input{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-1);min-height:38px;background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2);cursor:text;transition:border-color var(--duration-normal),box-shadow var(--duration-normal)}.ds-tag-input:focus-within{border-color:var(--color-input-focus);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-input-focus) 15%,transparent)}.ds-tag-input-inner{flex:1;min-width:80px;background:none;border:none;outline:none;font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text);padding:2px 0}.ds-date-input{cursor:pointer}.ds-table-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden}.ds-table-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.ds-table-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.ds-table-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text)}.ds-table-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.ds-table-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;flex-wrap:wrap}.ds-table-search{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:160px}.ds-table-search-input{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-md);padding:var(--space-1) var(--space-2) var(--space-1) var(--space-6);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text);width:220px;max-width:100%;transition:border-color var(--duration-normal)}.ds-table-search-input:focus{outline:none;border-color:var(--color-input-focus)}.ds-table-search-wrapper{position:relative}.ds-table-search-icon{position:absolute;left:var(--space-2);top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);font-size:13px;pointer-events:none}.ds-table-toolbar-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.ds-table-scroll-wrap{flex:1;overflow:auto;position:relative}.ds-table--static-head .ds-table thead th{position:static}.ds-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm);table-layout:auto}.ds-table thead th{position:sticky;top:0;z-index:var(--z-raised);background:var(--color-table-header-bg);border-bottom:1px solid var(--color-table-border);padding:var(--space-2) var(--space-4);text-align:start;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;letter-spacing:var(--letter-spacing-wide);text-transform:uppercase;-webkit-user-select:none;user-select:none}.ds-table th[data-align=end]{text-align:end}.ds-table th[data-align=center]{text-align:center}.ds-table-th-inner{display:flex;align-items:center;gap:var(--space-1)}.ds-table-sort-btn{display:inline-flex;align-items:center;gap:var(--space-1);background:none;border:none;font:inherit;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);cursor:pointer;padding:0;transition:color var(--duration-fast)}.ds-table-sort-btn:hover{color:var(--color-text)}.ds-table-sort-btn--asc,.ds-table-sort-btn--desc{color:var(--color-primary)}.ds-table-sort-icon{font-size:11px}.ds-table-col-hint{margin-left:var(--space-1)}.ds-table tbody td{padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-table-border);color:var(--color-text);vertical-align:middle}.ds-table td[data-align=end]{text-align:end}.ds-table td[data-align=center]{text-align:center}.ds-table tbody tr{cursor:pointer}.ds-table tbody tr:hover td{background:var(--color-table-row-hover)}.ds-table tbody tr.row--selected td{background:var(--color-table-row-selected)}.ds-table tbody tr:last-child td{border-bottom:none}.ds-table th.col-select,.ds-table td.col-select{width:40px;padding-right:var(--space-2)}.ds-table tbody tr.row--expandable{cursor:pointer}.ds-table .row-expand-cell{background:var(--color-surface-alt);border-bottom:1px solid var(--color-table-border)}.ds-table .row-expand-inner{padding:var(--space-4) var(--space-6);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.ds-table-state{padding:var(--space-10) var(--space-6);text-align:center;color:var(--color-text-secondary)}.ds-table-state-icon{font-size:36px;margin-bottom:var(--space-3)}.ds-table-state-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.ds-table-state-text{font-size:var(--font-size-sm)}.ds-table-pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-2) var(--space-4);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-shrink:0;flex-wrap:wrap}.ds-table-pagination--sticky{position:sticky;bottom:0;background:var(--color-surface);z-index:var(--z-raised)}.ds-table-pagination-info{white-space:nowrap}.ds-table-pagination-status{flex:1 1 240px;min-width:220px;color:var(--color-text-tertiary)}.ds-table-pagination-controls{display:flex;align-items:center;gap:var(--space-1)}.ds-table-pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 var(--space-2);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-secondary);cursor:pointer;transition:background var(--duration-fast),border-color var(--duration-fast),color var(--duration-fast)}.ds-table-pagination-btn:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.ds-table-pagination-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.ds-table-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ds-table-rows-per-page{display:flex;align-items:center;gap:var(--space-2);white-space:nowrap}.ds-table-rows-select{background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-sm);padding:3px var(--space-2);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text);cursor:pointer}.ds-table-page-input{width:72px;height:28px;padding:0 var(--space-2);background:var(--color-input-bg);border:1px solid var(--color-input-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:var(--font-size-sm);font-family:inherit}.ds-table-page-input:focus{outline:none;border-color:var(--color-input-focus)}.ds-table-row-actions{display:flex;align-items:center;gap:var(--space-1)}.ds-table-row-action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);cursor:pointer;transition:background var(--duration-fast),color var(--duration-fast);font-size:14px}.ds-table-row-action-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.ds-table-row-action-btn--destructive{color:var(--color-destructive)}.ds-table-row-action-btn--destructive:hover{background:var(--color-destructive-bg);color:var(--color-destructive)}.ds-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 7px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1.4;white-space:nowrap}.ds-badge--info{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info-border)}.ds-badge--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.ds-badge--warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.ds-badge--error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error-border)}.ds-badge--ai{background:var(--color-ai-bg);color:var(--color-ai);border:1px solid var(--color-ai-border)}.ds-badge--slate{background:var(--color-slate-bg);color:var(--color-slate);border:1px solid var(--color-slate-border)}.ds-badge--neutral{background:var(--color-surface-alt);color:var(--color-text-secondary);border:1px solid var(--color-border)}.ds-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px 6px 3px 8px;border-radius:var(--radius-full);background:var(--color-tag-bg);border:1px solid var(--color-tag-border);color:var(--color-tag-text);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.ds-chip-remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;background:none;border:none;color:var(--color-tag-remove);cursor:pointer;border-radius:var(--radius-full);font-size:12px;padding:0;transition:color var(--duration-fast),background var(--duration-fast)}.ds-chip-remove:hover{color:var(--color-text);background:var(--color-surface-hover)}.ds-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-avatar-bg);color:var(--color-avatar-text);font-weight:var(--font-weight-semibold);flex-shrink:0;line-height:1}.ds-avatar--xs{width:20px;height:20px;font-size:9px}.ds-avatar--sm{width:28px;height:28px;font-size:11px}.ds-avatar--md{width:36px;height:36px;font-size:13px}.ds-avatar--lg{width:48px;height:48px;font-size:18px}.ds-avatar--xl{width:64px;height:64px;font-size:22px}.ds-avatar--square{border-radius:var(--radius-md)}.ds-avatar-group{display:flex}.ds-avatar-group .ds-avatar{margin-inline-start:-8px;border:2px solid var(--color-surface)}.ds-avatar-group .ds-avatar:first-child{margin-inline-start:0}.ds-tag{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-tag-bg);border:1px solid var(--color-tag-border);color:var(--color-tag-text);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.ds-progress{width:100%;height:8px;background:var(--color-progress-track);border-radius:var(--radius-full);overflow:hidden}.ds-progress-bar{height:100%;background:var(--color-progress-fill);border-radius:var(--radius-full);transition:width var(--duration-slow) var(--easing-out)}.ds-progress--sm{height:4px}.ds-progress--lg{height:12px}.ds-progress--success .ds-progress-bar{background:var(--color-success)}.ds-progress--warning .ds-progress-bar{background:var(--color-warning)}.ds-progress--error .ds-progress-bar{background:var(--color-error)}.ds-progress--indeterminate .ds-progress-bar{width:40%!important;animation:ds-progress-indeterminate 1.5s ease-in-out infinite}@keyframes ds-progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}.ds-spinner{display:inline-block;border-radius:var(--radius-full);border:2px solid var(--color-border);border-top-color:var(--color-primary);animation:ds-spin .7s linear infinite;flex-shrink:0}.ds-spinner--xs{width:12px;height:12px;border-width:1.5px}.ds-spinner--sm{width:16px;height:16px}.ds-spinner--md{width:24px;height:24px;border-width:3px}.ds-spinner--lg{width:36px;height:36px;border-width:3px}.ds-spinner--xl{width:48px;height:48px;border-width:4px}@keyframes ds-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.ds-spinner{animation:none}}.ds-skeleton{background:var(--color-skeleton-base);border-radius:var(--radius-sm);position:relative;overflow:hidden;display:block}.ds-skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,var(--color-skeleton-shine) 40%,var(--color-skeleton-shine) 60%,transparent 100%);animation:ds-shimmer 1.5s ease-in-out infinite}@keyframes ds-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ds-skeleton--text{height:14px;width:100%;border-radius:var(--radius-sm);margin-bottom:var(--space-2)}.ds-skeleton--title{height:20px;width:60%;border-radius:var(--radius-sm);margin-bottom:var(--space-3)}.ds-skeleton--circle{border-radius:var(--radius-full)}.ds-skeleton--btn{height:32px;width:80px;border-radius:var(--radius-md)}.ds-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-12) var(--space-6);gap:var(--space-3)}.ds-empty-icon{font-size:48px;color:var(--color-text-tertiary);line-height:1}.ds-empty-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.ds-empty-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:360px;line-height:var(--line-height-relaxed)}.ds-empty-action{margin-top:var(--space-2)}.ds-desc-list{display:grid;grid-template-columns:max-content 1fr;gap:var(--space-2) var(--space-6);font-size:var(--font-size-sm)}.ds-desc-list dt{color:var(--color-text-secondary);font-weight:var(--font-weight-medium);white-space:nowrap;align-self:start;padding-top:1px}.ds-desc-list dd{color:var(--color-text);word-break:break-word}.ds-kpi{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-1)}.ds-kpi-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-widest);color:var(--color-text-tertiary)}.ds-kpi-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-extrabold);color:var(--color-text);line-height:var(--line-height-tight)}.ds-kpi-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.ds-kpi-trend{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.ds-kpi-trend--up{color:var(--color-success)}.ds-kpi-trend--down{color:var(--color-error)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-4);height:36px;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);font-family:var(--font-family-sans);cursor:pointer;border:1px solid transparent;transition:background var(--duration-normal),border-color var(--duration-normal),color var(--duration-normal),box-shadow var(--duration-normal);white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;position:relative;flex-shrink:0;overflow:hidden}.ds-btn-content{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2)}.ds-btn-content--stacked{flex-direction:column;gap:var(--space-1);line-height:1.1}.ds-btn-icon{display:inline-flex;align-items:center;justify-content:center;line-height:1}.ds-btn:focus-visible{outline:var(--focus-ring-width) solid var(--focus-ring-color);outline-offset:var(--focus-ring-offset)}.ds-btn:disabled,.ds-btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.ds-btn--sm{height:28px;padding:0 var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.ds-btn--lg{height:44px;padding:0 var(--space-6);font-size:var(--font-size-md);border-radius:var(--radius-lg)}.ds-btn--icon{width:36px;padding:0}.ds-btn--icon.ds-btn--sm{width:28px}.ds-btn--icon.ds-btn--lg{width:44px}.ds-btn--stacked{height:auto;min-height:52px;padding-top:var(--space-2);padding-bottom:var(--space-2)}.ds-btn--primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.ds-btn--primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.ds-btn--primary:active:not(:disabled){filter:brightness(.9)}.ds-btn--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border-strong)}.ds-btn--secondary:hover:not(:disabled){background:var(--color-surface-hover)}.ds-btn--secondary:active:not(:disabled){background:color-mix(in srgb,var(--color-surface-hover) 82%,var(--color-text) 18%)}.ds-btn--ghost{background:none;color:var(--color-primary);border-color:transparent}.ds-btn--ghost:hover:not(:disabled){background:var(--color-primary-light)}.ds-btn--ghost:active:not(:disabled){background:color-mix(in srgb,var(--color-primary-light) 75%,var(--color-primary) 25%)}.ds-btn--destructive{background:var(--color-destructive);color:#fff;border-color:var(--color-destructive)}.ds-btn--destructive:hover:not(:disabled){background:var(--color-destructive-hover);border-color:var(--color-destructive-hover)}.ds-btn--outline{background:none;color:var(--color-primary);border-color:var(--color-primary)}.ds-btn--outline:hover:not(:disabled){background:var(--color-primary-light)}.ds-btn--outline:active:not(:disabled){background:color-mix(in srgb,var(--color-primary-light) 70%,var(--color-primary) 30%)}.ds-btn--subtle{background:var(--color-surface-alt);color:var(--color-text-secondary);border-color:transparent}.ds-btn--subtle:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.ds-btn--subtle:active:not(:disabled){background:color-mix(in srgb,var(--color-surface-hover) 80%,var(--color-text) 20%)}.ds-btn--link{background:none;border-color:transparent;color:var(--color-primary);height:auto;padding:0;border-radius:0}.ds-btn--link:hover:not(:disabled){color:var(--color-primary-hover);text-decoration:underline}.ds-btn--link:active:not(:disabled){color:var(--color-primary)}.ds-btn--loading{pointer-events:none}.ds-btn--loading .ds-btn-content{opacity:0}.ds-btn--loading .ds-btn-spinner-shell{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;justify-content:center}.ds-btn-group{display:inline-flex}.ds-btn-group .ds-btn{border-radius:0;border-inline-end-width:0}.ds-btn-group .ds-btn:first-child{border-start-start-radius:var(--radius-md);border-end-start-radius:var(--radius-md)}.ds-btn-group .ds-btn:last-child{border-start-end-radius:var(--radius-md);border-end-end-radius:var(--radius-md);border-inline-end-width:1px}.ds-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.ds-panel+.ds-panel{margin-top:var(--space-2)}.ds-panel--accordion{margin-top:0!important}.ds-panel--accordion+.ds-panel--accordion{border-top:none;border-radius:0}.ds-panel--accordion:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.ds-panel--accordion:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:1px solid var(--color-border)}.ds-panel-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);cursor:pointer;text-align:start;transition:background var(--duration-fast)}.ds-panel-trigger:hover{background:var(--color-surface-hover)}.ds-panel-trigger-left{display:flex;align-items:center;gap:var(--space-2)}.ds-panel-icon{font-size:14px;color:var(--color-text-secondary)}.ds-panel-chevron{font-size:12px;color:var(--color-text-tertiary);transition:transform var(--duration-normal)}.ds-panel-trigger[aria-expanded=true] .ds-panel-chevron{transform:rotate(180deg)}.ds-panel-body{padding:var(--space-4);border-top:1px solid var(--color-border);overflow:hidden}.ds-callout{display:flex;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border-inline-start:4px solid;background:var(--color-surface-alt)}.ds-callout--info{border-color:var(--color-info);background:var(--color-info-bg)}.ds-callout--success{border-color:var(--color-success);background:var(--color-success-bg)}.ds-callout--warning{border-color:var(--color-warning);background:var(--color-warning-bg)}.ds-callout--error{border-color:var(--color-error);background:var(--color-error-bg)}.ds-callout-icon{font-size:18px;flex-shrink:0;margin-top:1px;margin-right:5px}.ds-callout--info .ds-callout-icon{color:var(--color-info)}.ds-callout--success .ds-callout-icon{color:var(--color-success)}.ds-callout--warning .ds-callout-icon{color:var(--color-warning)}.ds-callout--error .ds-callout-icon{color:var(--color-error)}.ds-callout-body{flex:1;min-width:0}.ds-callout-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-1)}.ds-callout-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-base)}.ds-pagination{display:flex;align-items:center;gap:var(--space-1);flex-wrap:wrap}.ds-pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--space-2);background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:inherit;color:var(--color-text-secondary);cursor:pointer;transition:background var(--duration-fast),border-color var(--duration-fast),color var(--duration-fast)}.ds-pagination-btn:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-border-strong)}.ds-pagination-btn--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.ds-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.ds-pagination-ellipsis{color:var(--color-text-tertiary);padding:0 var(--space-1)}.ds-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}.ds-card-header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.ds-card-header-text{flex:1;min-width:0}.ds-card-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text)}.ds-card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.ds-card-body{padding:var(--space-6);flex:1}.ds-card-footer{padding:var(--space-3) var(--space-6);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-2)}.ds-inspector{display:flex;flex-direction:column;font-size:var(--font-size-sm)}.ds-inspector-section{border-bottom:1px solid var(--color-border)}.ds-inspector-section-title{padding:var(--space-2) var(--space-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-widest);color:var(--color-text-tertiary);background:var(--color-surface-alt);-webkit-user-select:none;user-select:none}.ds-inspector-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--color-table-border)}.ds-inspector-row:last-child{border-bottom:none}.ds-inspector-key{color:var(--color-text-secondary);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ds-inspector-value{color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--font-family-mono);font-size:var(--font-size-xs)}.ds-token-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-2)}.ds-token-swatch{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.ds-token-color{height:40px;width:100%}.ds-token-info{padding:var(--space-2) var(--space-2);font-size:var(--font-size-xs);background:var(--color-surface-alt)}.ds-token-name{font-weight:var(--font-weight-semibold);color:var(--color-text);font-family:var(--font-family-mono);margin-bottom:2px;word-break:break-all}.ds-token-value{color:var(--color-text-tertiary);font-family:var(--font-family-mono)}.ds-type-scale-row{display:flex;align-items:baseline;gap:var(--space-6);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.ds-type-scale-row:last-child{border-bottom:none}.ds-type-scale-meta{width:120px;flex-shrink:0;font-size:var(--font-size-xs);font-family:var(--font-family-mono);color:var(--color-text-tertiary)}.ds-type-scale-sample{color:var(--color-text)}.ds-status-dot{display:inline-block;width:8px;height:8px;border-radius:var(--radius-full);flex-shrink:0}.ds-status-dot--online{background:var(--color-success)}.ds-status-dot--offline{background:var(--color-error)}.ds-status-dot--idle{background:var(--color-warning)}.ds-status-dot--unknown{background:var(--color-text-tertiary)}.ds-status-dot--pulsing{background:var(--color-success);animation:ds-pulse 2s ease-in-out infinite}@keyframes ds-pulse{0%,to{opacity:1}50%{opacity:.4}}.ds-scroll-area{overflow:auto;scrollbar-width:thin;scrollbar-color:var(--color-border-strong) transparent}.ds-divider{height:1px;background:var(--color-border);border:none;margin:var(--space-4) 0}.ds-divider--vertical{width:1px;height:auto;align-self:stretch;margin:0 var(--space-2)}.demo-layout{display:grid;grid-template-columns:220px 1fr;min-height:100%;background:var(--color-bg)}.demo-nav{position:sticky;top:0;height:100vh;overflow-y:auto;background:var(--color-sidebar-bg);border-inline-end:1px solid var(--color-sidebar-border);padding:var(--space-4) 0;flex-shrink:0}.demo-nav-section{padding:var(--space-3) var(--space-4) var(--space-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-widest);color:var(--color-text-tertiary)}.demo-nav-link{display:block;padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;cursor:pointer;background:none;border:none;width:100%;text-align:start;font-family:inherit;border-inline-start:2px solid transparent;transition:background var(--duration-fast),color var(--duration-fast)}.demo-nav-link:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.demo-nav-link.active{background:var(--color-sidebar-active);color:var(--color-primary);border-inline-start-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.demo-content{padding:var(--space-8);overflow-y:auto;min-height:100vh}.demo-section{margin-bottom:var(--space-12);scroll-margin-top:var(--space-6)}.demo-section-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin-bottom:var(--space-1);padding-bottom:var(--space-3);border-bottom:2px solid var(--color-border)}.demo-section-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);margin-top:var(--space-2)}.demo-subsection{margin-bottom:var(--space-8)}.demo-subsection-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--space-4)}.demo-row{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}.demo-col{display:flex;flex-direction:column;gap:var(--space-3)}.demo-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.demo-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.demo-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.demo-context-zone{padding:var(--space-8);border:2px dashed var(--color-border);border-radius:var(--radius-lg);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-tertiary);cursor:context-menu;-webkit-user-select:none;user-select:none}.tf-surface-stack{display:flex;flex-direction:column;gap:var(--space-4)}.tf-kpi-grid,.tf-card-grid,.tf-grid-two,.tf-grid-estimate,.tf-grid-split,.tf-form-grid{display:grid;gap:var(--space-4)}.tf-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.tf-card-grid,.tf-grid-two,.tf-grid-estimate{grid-template-columns:repeat(2,minmax(0,1fr))}.tf-grid-split{grid-template-columns:minmax(0,1fr) 360px;align-items:start}.tf-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.tf-form-grid .tf-field-wide{grid-column:1 / -1}.tf-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-4)}.tf-panel--hero{padding:var(--space-6)}.tf-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-4)}.tf-panel-heading{display:flex;flex-direction:column;gap:var(--space-1)}.tf-panel-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.tf-panel-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.tf-panel-actions,.tf-action-row,.tf-toolbar-actions,.tf-badge-row{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.tf-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.tf-toolbar-search{width:min(320px,100%)}.tf-inline-note,.tf-muted-text{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.tf-body-text{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.tf-hero{display:flex;flex-direction:column;gap:var(--space-2);padding-bottom:var(--space-4);margin-bottom:var(--space-4);border-bottom:1px solid var(--color-border)}.tf-hero-label,.tf-section-kicker{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-tertiary)}.tf-hero-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-extrabold);line-height:var(--line-height-tight);color:var(--color-text)}.tf-hero-value--success{color:var(--color-success)}.tf-hero-value--warning{color:var(--color-warning);font-size:var(--font-size-2xl)}.tf-hero-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.tf-section{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-4)}.tf-section-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.tf-list{padding-left:var(--space-4);display:flex;flex-direction:column;gap:var(--space-2);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.tf-list--ordered{list-style:decimal}.tf-recent-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-2)}.tf-recent-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-block:var(--space-3);border-bottom:1px solid var(--color-border)}.tf-recent-item:last-child{border-bottom:none;padding-bottom:0}.tf-recent-item:first-child{padding-top:0}.tf-recent-label{font-size:var(--font-size-sm);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tf-recent-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);flex-shrink:0}.tf-table-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;padding-top:var(--space-3)}.tf-login-shell{overflow:auto}.tf-login-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);padding:var(--space-8) var(--space-4)}.tf-login-card{width:min(100%,460px)}.tf-login-card-header{text-align:center;align-items:center}.tf-login-submit{width:100%}.tf-login-disclaimer{width:min(100%,560px)}@media (max-width: 1280px){.right-sidebar:not(.right-sidebar--pinned){position:fixed;right:0;top:var(--header-height);bottom:var(--footer-height);z-index:var(--z-overlay);box-shadow:var(--shadow-lg)}.demo-grid-4{grid-template-columns:repeat(2,1fr)}.tf-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){:root{--iconbar-width: 0px}.icon-bar{display:none}.left-sidebar{position:fixed;left:-100%;top:var(--header-height);bottom:var(--footer-height);z-index:var(--z-overlay);box-shadow:var(--shadow-lg);transition:left var(--duration-slow) var(--easing-out);width:var(--sidebar-width)}.left-sidebar.open{left:0}.demo-layout{grid-template-columns:1fr}.demo-nav{display:none}.demo-grid-2,.demo-grid-3{grid-template-columns:1fr}.ds-commandpalette-width{--commandpalette-width: calc(100vw - 32px) }.tf-card-grid,.tf-grid-two,.tf-grid-estimate,.tf-grid-split,.tf-form-grid,.tf-kpi-grid{grid-template-columns:1fr}.tf-toolbar,.tf-table-footer{align-items:stretch}.tf-login-main{justify-content:flex-start}}@media (max-width: 480px){:root{--header-height: 48px}.ds-dialog{margin:var(--space-2);max-width:calc(100vw - var(--space-4))}.ds-table-pagination{flex-direction:column;align-items:flex-start}.demo-content{padding:var(--space-4)}}
