:root{--seq-blue: #1e73be;--seq-blue-light: #3b8fd4;--seq-blue-dark: #1a5a9a;--seq-navy: #00102e;--seq-orange: var(--seq-blue);--seq-orange-light: var(--seq-blue-light);--seq-orange-dark: var(--seq-blue-dark);--color-primary: var(--seq-blue);--color-primary-hover: var(--seq-blue-light);--color-primary-active: var(--seq-blue-dark);--bg-primary: #f0f7ff;--bg-secondary: #ffffff;--bg-tertiary: #e8f1fc;--bg-card: #ffffff;--bg-glass: rgba(30, 115, 190, .05);--bg-hover: #ebf4ff;--text-primary: #1e293b;--text-secondary: #475569;--text-muted: #94a3b8;--text-inverse: #ffffff;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--rag-red: #ef4444;--rag-amber: #f59e0b;--rag-green: #10b981;--border-color: #e2e8f0;--border-color-light: #f1f5f9;--border-radius-sm: 6px;--border-radius-md: 10px;--border-radius-lg: 16px;--border-radius-xl: 24px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(30, 115, 190, .15);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--sidebar-width: 260px;--sidebar-collapsed-width: 72px;--header-height: 64px;--max-content-width: 1400px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--border-radius-md)}.skeleton-circle{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:50%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading, var(--font-family));font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-sm)}p{color:var(--text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.app-layout{display:flex;min-height:100vh}.app-main{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-width);transition:margin-left .28s cubic-bezier(.4,0,.2,1);background:var(--bg-primary);overflow-x:hidden}.app-main.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.app-content{flex:1;padding:var(--spacing-xl);max-width:var(--max-content-width);margin:0 auto;width:100%;overflow-x:hidden}.suspended-banner{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:2px solid #f59e0b;color:#92400e;font-size:var(--font-size-sm);font-weight:500;line-height:1.4;animation:bannerSlideDown .3s ease-out}.suspended-banner svg{flex-shrink:0;color:#d97706}@keyframes bannerSlideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}:root{--sidebar-bg: var(--brand-primary, #1e293b);--sidebar-text: rgba(255, 255, 255, .85);--sidebar-text-muted: rgba(255, 255, 255, .5);--sidebar-hover-bg: rgba(255, 255, 255, .08);--sidebar-active-bg: rgba(255, 255, 255, .14);--sidebar-active-text: #ffffff;--sidebar-border: rgba(255, 255, 255, .1);--sidebar-toggle-bg: rgba(255, 255, 255, .06)}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;transition:width .28s cubic-bezier(.4,0,.2,1);z-index:100;overflow:hidden;box-shadow:2px 0 12px #00000026}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{padding:var(--spacing-md) var(--spacing-md);display:flex;flex-direction:row;justify-content:space-between;align-items:flex-start;gap:var(--spacing-sm);border-bottom:1px solid var(--sidebar-border);min-height:64px}.sidebar-brand{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0;cursor:pointer;padding:6px;border-radius:var(--border-radius-sm);transition:background var(--transition-fast);text-align:center}.sidebar-brand:hover{background:var(--sidebar-hover-bg)}.sidebar-logo-wrapper{background:#fff;border-radius:var(--border-radius-md);padding:6px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;width:100%}.sidebar-logo-mini{width:32px;height:32px;object-fit:contain;flex-shrink:0}.sidebar-logo-full{max-width:100%;max-height:48px;object-fit:contain;flex-shrink:0}.sidebar-brand-text{display:flex;flex-direction:column;min-width:0;overflow:hidden;width:100%}.sidebar-brand-name{font-size:var(--font-size-sm);font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-brand-company{font-size:.68rem;color:var(--sidebar-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--border-radius-sm);border:none;background:var(--sidebar-toggle-bg);color:var(--sidebar-text);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;margin-top:4px}.sidebar-toggle:hover{background:var(--sidebar-hover-bg);color:#fff;opacity:1}.sidebar.collapsed .sidebar-header{flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-md) var(--spacing-sm)}.sidebar.collapsed .sidebar-brand{padding:4px}.sidebar.collapsed .sidebar-logo-wrapper{width:auto}.sidebar.collapsed .sidebar-toggle{margin-top:var(--spacing-xs);width:100%}.sidebar-nav{padding:var(--spacing-sm) var(--spacing-sm);overflow-y:auto}.sidebar-nav-main{flex:1;min-height:0}.sidebar-nav-bottom{flex:0 0 auto}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:10px 12px;border-radius:var(--border-radius-md);color:var(--sidebar-text);cursor:pointer;transition:all .15s ease;margin-bottom:2px;text-decoration:none;font-size:var(--font-size-sm);font-weight:500;border:none;background:none;width:100%;text-align:left}.sidebar-nav-item:hover{background:var(--sidebar-hover-bg);color:#fff}.sidebar-nav-item.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:600}.sidebar-nav-icon{flex-shrink:0;width:20px;height:20px}.sidebar-nav-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .sidebar-nav-item{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-nav-label{display:none}.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;flex:0 0 auto}.sidebar-divider{height:1px;background:var(--sidebar-border);margin:var(--spacing-xs) var(--spacing-md)}.sidebar-user-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);margin:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius-md);background:var(--sidebar-hover-bg)}.sidebar-user-avatar{width:32px;height:32px;border-radius:50%;background:#fff3;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm);flex-shrink:0}.sidebar-user-details{min-width:0;overflow:hidden}.sidebar-user-name{font-size:var(--font-size-xs);font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.sidebar-user-role{font-size:.65rem;color:var(--sidebar-text-muted);margin:0;line-height:1.3}.sidebar-signout{margin:var(--spacing-xs) var(--spacing-sm) var(--spacing-md);color:var(--sidebar-text-muted)!important}.sidebar-signout:hover{color:#fff!important;background:#ef444426!important}.sidebar-safe-mode{margin:2px var(--spacing-sm);position:relative;transition:all .2s ease}.sidebar-safe-mode:hover{background:#f59e0b1f!important}.sidebar-safe-mode.active{background:#f59e0b2e!important;color:#fbbf24!important;border-left:3px solid #f59e0b;padding-left:9px}.safe-mode-icon-active{color:#fbbf24!important;filter:drop-shadow(0 0 6px rgba(245,158,11,.6));animation:safeModeGlow 2s ease-in-out infinite}@keyframes safeModeGlow{0%,to{filter:drop-shadow(0 0 4px rgba(245,158,11,.4))}50%{filter:drop-shadow(0 0 8px rgba(245,158,11,.8))}}.safe-mode-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:#f59e0b40;color:#fbbf24;padding:1px 6px;border-radius:999px;margin-left:8px;line-height:1.4}.sidebar-mobile-trigger{display:none;position:fixed;top:14px;left:14px;z-index:101;width:40px;height:40px;border-radius:var(--border-radius-md);border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-md);cursor:pointer;color:var(--text-primary);align-items:center;justify-content:center}.sidebar-mobile-overlay{position:fixed;inset:0;background:#00000080;z-index:99;animation:fadeIn .2s ease}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width);transition:transform .28s cubic-bezier(.4,0,.2,1)}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .sidebar-nav-label,.sidebar.mobile-open .sidebar-brand,.sidebar.mobile-open .sidebar-brand-text,.sidebar.mobile-open .sidebar-user-info,.sidebar-mobile-trigger{display:flex}.app-main{margin-left:0!important}}.sidebar-skeleton{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:100;padding:0}.sidebar-skeleton .skeleton{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1f,#ffffff0f 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.sidebar-skeleton-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-skeleton-nav{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-sm)}.sidebar-skeleton-item{display:flex;align-items:center;gap:var(--spacing-md);padding:10px 12px}.breadcrumbs{padding:0 0 var(--spacing-md) 0}.breadcrumb-list{display:flex;align-items:center;gap:2px;list-style:none;margin:0;padding:0;flex-wrap:wrap}.breadcrumb-segment{display:flex;align-items:center;gap:2px}.breadcrumb-item{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-sm);color:var(--text-muted);padding:2px 6px;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.breadcrumb-link{color:var(--text-secondary);text-decoration:none;cursor:pointer}.breadcrumb-link:hover{color:var(--color-primary);background:var(--bg-hover)}.breadcrumb-current{color:var(--text-primary);font-weight:600}.breadcrumb-root{font-weight:600}.breadcrumb-separator{display:flex;align-items:center;color:var(--text-muted);opacity:.5;padding:0 2px}.app-page-content{animation:pageEnter .3s ease-out}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.nav-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--border-radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-xs)}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:#1e73be1a;color:var(--color-primary)}.nav-item svg{flex-shrink:0;width:20px;height:20px}.nav-item span{white-space:nowrap;overflow:hidden}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.card-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.metric-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.metric-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--color-primary)}.metric-card.success:before{background:var(--color-success)}.metric-card.warning:before{background:var(--color-warning)}.metric-card.error:before{background:var(--color-error)}.metric-label{font-size:var(--font-size-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm)}.metric-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--text-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--border-radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-glow)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-sm);letter-spacing:.01em}.form-input{width:100%;padding:var(--spacing-md);background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-md);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.form-input:hover{border-color:var(--seq-blue-light);background-color:#f5faff}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be26;background-color:#fff}.form-input::placeholder{color:var(--text-muted)}.form-input.error{border-color:var(--color-error)}.form-error{font-size:var(--font-size-sm);color:var(--color-error);margin-top:var(--spacing-xs)}select.form-input,.form-input[data-select],select:not([class]){appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:36px;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='%231e73be' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;background-size:16px 16px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-md);font-family:inherit;line-height:1.5;min-height:40px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}select.form-input:hover,select:not([class]):hover{border-color:var(--seq-blue-light);background-color:#f5faff;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='%233b8fd4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}select.form-input:focus,select:not([class]):focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be26;background-color:#fff;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='%231e73be' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}select.form-input:disabled,select:not([class]):disabled{opacity:.5;cursor:not-allowed;background-color:var(--bg-tertiary)}select.form-input::-ms-expand,select:not([class])::-ms-expand{display:none}select.form-input option,select:not([class]) option{padding:8px 12px;background:#fff;color:var(--text-primary);font-size:var(--font-size-md)}select.form-input optgroup,select:not([class]) optgroup{font-weight:600;color:var(--text-secondary);background:var(--bg-secondary)}select.form-input-sm,.pnl-range-bar select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding:6px 30px 6px 10px;background-color:var(--bg-secondary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231e73be' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;background-size:14px 14px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-primary);font-size:var(--font-size-sm);font-family:inherit;font-weight:500;line-height:1.4;min-height:32px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}select.form-input-sm:hover,.pnl-range-bar select:hover{border-color:var(--seq-blue-light);background-color:var(--bg-hover)}select.form-input-sm:focus,.pnl-range-bar select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #1e73be1f;background-color:#fff}select.select-auto{width:auto;max-width:100%;transition:width .2s cubic-bezier(.4,0,.2,1),border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}textarea.form-input{resize:vertical;min-height:80px;line-height:1.6}textarea.form-input:focus{min-height:100px}.notes-rich-editor:empty:before{content:attr(data-placeholder);color:var(--text-muted);pointer-events:none;font-style:normal}.notes-rich-editor:focus{background-color:#fff}.notes-rich-editor .mention-chip{display:inline-flex;align-items:center;gap:3px;padding:1px 8px 1px 6px;border-radius:12px;font-size:.78rem;font-weight:600;white-space:nowrap;vertical-align:baseline;line-height:1.6;cursor:default;-webkit-user-select:all;user-select:all}.notes-avatar-tooltip{position:relative}.notes-avatar-tooltip:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);right:0;transform:scale(.92);padding:4px 10px;border-radius:6px;background:#0f172aeb;color:#fff;font-size:.68rem;font-weight:500;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease,transform .15s ease;z-index:9999;box-shadow:0 2px 8px #0000002e}.notes-avatar-tooltip:hover:after{opacity:1;transform:scale(1)}.notes-avatar-tooltip:hover{z-index:999!important}input[type=number].form-input::-webkit-inner-spin-button,input[type=number].form-input::-webkit-outer-spin-button{height:28px;opacity:0;transition:opacity var(--transition-fast)}input[type=number].form-input:hover::-webkit-inner-spin-button,input[type=number].form-input:hover::-webkit-outer-spin-button,input[type=number].form-input:focus::-webkit-inner-spin-button,input[type=number].form-input:focus::-webkit-outer-spin-button{opacity:1}input[type=number].form-input,input[type=number]{font-variant-numeric:tabular-nums}input[type=number]:not(.form-input)::-webkit-inner-spin-button,input[type=number]:not(.form-input)::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]:not(.form-input){-moz-appearance:textfield}input[type=checkbox],input[type=radio]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid #cbd5e1;background:#fff;cursor:pointer;transition:all .15s ease;position:relative;display:inline-grid;place-content:center;flex-shrink:0;vertical-align:middle;margin:0}input[type=checkbox]{border-radius:5px}input[type=radio]{border-radius:50%}input[type=checkbox]:hover,input[type=radio]:hover{border-color:var(--seq-blue-light);background:#f0f7ff}input[type=checkbox]:focus-visible,input[type=radio]:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be26}input[type=checkbox]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=checkbox]:checked:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}input[type=radio]:checked{background:var(--color-primary);border-color:var(--color-primary)}input[type=radio]:checked:after{content:"";width:6px;height:6px;border-radius:50%;background:#fff}input[type=checkbox]:disabled,input[type=radio]:disabled{opacity:.45;cursor:not-allowed;background:#f1f5f9}.form-input:disabled{opacity:.55;cursor:not-allowed;background:var(--bg-primary);border-color:var(--border-color-light)}input[type=search].form-input::-webkit-search-cancel-button{-webkit-appearance:none;appearance:none;height:16px;width:16px;background: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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") no-repeat center;cursor:pointer}input[type=date].form-input,input[type=datetime-local].form-input{cursor:pointer}input[type=date].form-input::-webkit-calendar-picker-indicator,input[type=datetime-local].form-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}input[type=date].form-input:hover::-webkit-calendar-picker-indicator,input[type=datetime-local].form-input:hover::-webkit-calendar-picker-indicator{opacity:1}.table-container{overflow-x:auto;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);background:var(--bg-card)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}.table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}.table tr:hover td{background:var(--bg-hover)}.table tr:last-child td{border-bottom:none}.rag-indicator{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);border-radius:9999px;font-size:var(--font-size-sm);font-weight:500}.rag-indicator.red{background:#ef44441a;color:var(--rag-red)}.rag-indicator.amber{background:#f59e0b1a;color:var(--rag-amber)}.rag-indicator.green{background:#10b9811a;color:var(--rag-green)}.rag-indicator.blue{background:#3b82f61a;color:#3b82f6}.rag-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.modal-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.modal-body{padding:var(--spacing-lg)}.modal-footer{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--border-color)}.spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinning,.animate-spin{animation:spin 1s linear infinite}@keyframes fadeInThink{0%{opacity:0;transform:translateY(-50%) translate(4px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@keyframes pulseGlow{0%,to{opacity:1;box-shadow:0 0 #8b5cf633}50%{opacity:.7;box-shadow:0 0 8px 2px #8b5cf626}}.markdown-analysis{font-family:inherit;line-height:1.6;color:var(--text-secondary)}.markdown-analysis>:first-child{margin-top:0}.markdown-analysis>:last-child{margin-bottom:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes notifPulse{0%{transform:scale(1);box-shadow:0 0 #ef444480}50%{transform:scale(1.08);box-shadow:0 0 0 6px #ef444400}to{transform:scale(1);box-shadow:0 0 #ef444400}}@keyframes viewSwitchIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.view-switch-animate{animation:viewSwitchIn .28s cubic-bezier(.23,1,.32,1) both}@keyframes rowSlideIn{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.variation-row-invalid td{background:#ef444406!important;position:relative}.variation-row-invalid td:first-child{box-shadow:inset 3px 0 #ef444480}.variation-row-invalid:hover td{background:#ef44440f!important}.variation-row-invalid .var-amount-cell{opacity:.5;text-decoration:line-through;text-decoration-color:#ef444466}.variation-row-pending td{background:#f59e0b06!important;position:relative}.variation-row-pending td:first-child{box-shadow:inset 3px 0 #f59e0b80}.variation-row-pending:hover td{background:#f59e0b0f!important}.variation-row-valid td{background:#22c55e04!important}.variation-row-valid td:first-child{box-shadow:inset 3px 0 #22c55e59}.variation-row-valid:hover td{background:#22c55e0d!important}.var-status-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:var(--spacing-lg)}.var-status-card{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.var-status-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px}.var-status-card:hover{border-color:var(--border-color-dark, #c4c9d2);box-shadow:0 2px 8px #0000000f;transform:translateY(-1px)}.var-status-card--active{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 2px 8px #1e73be1a}.var-status-card--valid:before{background:#22c55e}.var-status-card--invalid:before{background:#ef4444}.var-status-card--pending:before{background:#f59e0b}.var-status-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.var-status-card--valid .var-status-card-icon{background:#22c55e1a;color:#16a34a}.var-status-card--invalid .var-status-card-icon{background:#ef44441a;color:#dc2626}.var-status-card--pending .var-status-card-icon{background:#f59e0b1a;color:#d97706}.var-status-card-content{display:flex;flex-direction:column;gap:2px;min-width:0}.var-status-card-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.var-status-card-value{font-size:1.15rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.var-status-card-amount{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.var-subtab-toggle{display:flex;gap:0;align-items:center;padding:4px;background:var(--bg-tertiary);border-radius:12px;border:1px solid var(--border-color);margin-bottom:var(--spacing-md)}.var-subtab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;font-size:.88rem;font-weight:500;border-radius:9px;border:none;cursor:pointer;background:transparent;color:var(--text-muted);transition:all .2s cubic-bezier(.23,1,.32,1);position:relative;white-space:nowrap}.var-subtab-btn:hover:not(.var-subtab-btn--active){color:var(--text-secondary);background:#00000008}.var-subtab-btn--active{background:var(--bg-card);color:var(--text-primary);font-weight:600;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a}.var-subtab-btn--active .var-subtab-icon{color:var(--color-primary)}.var-subtab-icon{display:flex;align-items:center;transition:color .2s ease}.var-filter-chips{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.var-filter-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;font-size:.8rem;font-weight:500;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.var-filter-chip:hover{border-color:var(--text-muted);background:var(--bg-tertiary)}.var-filter-chip--active{border-color:var(--color-primary);background:#1e73be14;color:var(--color-primary);font-weight:600}.var-filter-chip-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.var-filter-chip-dot--valid{background:#22c55e}.var-filter-chip-dot--invalid{background:#ef4444}.var-filter-chip-dot--pending{background:#f59e0b}.var-filter-chip-dot--all{background:var(--color-primary)}@keyframes pendingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}.var-pending-dot{animation:pendingPulse 2s ease-in-out infinite}.recon-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding:4px 28px 4px 8px;font-size:.75rem;font-weight:600;font-family:inherit;line-height:1.4;border-radius:var(--border-radius-sm);border:1px solid var(--border-color);background-color:var(--bg-tertiary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231e73be' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;background-size:12px 12px;color:var(--text-secondary);min-width:110px;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.recon-select:hover{border-color:var(--seq-blue-light);background-color:#f5faff}.recon-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #1e73be1f;background-color:#fff}.recon-select option{padding:6px 10px;background:#fff;color:var(--text-primary);font-size:.8rem}.recon-select--null{color:var(--text-secondary);background-color:var(--bg-tertiary);border-color:var(--border-color)}.recon-select--reconciled{color:#059669;background-color:#10b98114;border-color:#10b9814d}.recon-select--held{color:#b45309;background-color:#f59e0b14;border-color:#f59e0b4d}.recon-select--paid{color:#1a5a9a;background-color:#1e73be14;border-color:#1e73be4d}.recon-bulk-bar{display:flex;align-items:center;gap:10px;padding:8px 16px!important;margin-bottom:var(--spacing-md)!important;background:var(--bg-tertiary)!important;border:1px solid var(--border-color)!important;border-radius:var(--border-radius-md)!important;animation:rowSlideIn .2s ease-out}.recon-bulk-count{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);white-space:nowrap}.recon-bulk-label{font-size:var(--font-size-xs);color:var(--text-muted);white-space:nowrap}.recon-bulk-divider{width:1px;height:20px;background:var(--border-color);flex-shrink:0}.recon-bulk-btn{padding:4px 12px;font-size:.72rem;font-weight:600;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.recon-bulk-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.recon-bulk-btn--null{border-color:var(--border-color);color:var(--text-secondary)}.recon-bulk-btn--null:hover{background:var(--bg-tertiary)}.recon-bulk-btn--reconciled{border-color:#10b9814d;color:#059669}.recon-bulk-btn--reconciled:hover{background:#10b98114}.recon-bulk-btn--held{border-color:#f59e0b4d;color:#b45309}.recon-bulk-btn--held:hover{background:#f59e0b14}.recon-bulk-btn--paid{border-color:#1e73be4d;color:#1a5a9a}.recon-bulk-btn--paid:hover{background:#1e73be14}.var-filter-chip-dot--not-recon{background:#94a3b8}.var-filter-chip-dot--recon{background:#10b981}.var-filter-chip-dot--held{background:#f59e0b}.var-filter-chip-dot--paid-status{background:#1e73be}.recon-filter-label{font-size:.72rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;white-space:nowrap}.recon-filter-divider{width:1px;height:18px;background:var(--border-color);flex-shrink:0;margin:0 4px}.recon-checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.var-status-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:10px;font-size:.85rem;font-weight:500}.var-status-banner--invalid{background:#ef444414;border:1px solid rgba(239,68,68,.2);color:#991b1b}.var-status-banner--pending{background:#f59e0b14;border:1px solid rgba(245,158,11,.2);color:#92400e}.var-status-banner-icon{display:flex;flex-shrink:0}@media(prefers-reduced-motion:reduce){.view-switch-animate,.var-pending-dot{animation:none}}.loading-overlay{position:fixed;inset:0;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);z-index:9999}@media(max-width:768px){.metric-grid{grid-template-columns:1fr}.app-content{padding:var(--spacing-md)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}.modal-overlay{padding:var(--spacing-md)}.modal{max-width:100%}}@media(max-width:480px){.app-content{padding:var(--spacing-sm)}h1{font-size:var(--font-size-xl)}h2{font-size:var(--font-size-lg)}h3{font-size:var(--font-size-md)}.metric-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.btn{padding:var(--spacing-xs) var(--spacing-md);font-size:var(--font-size-xs)}.card{padding:var(--spacing-md)}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%}}.var-detail-modal{max-width:1000px;width:95%;display:flex;flex-direction:column;max-height:92vh;overflow:hidden}.var-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-card);position:sticky;top:0;z-index:10;gap:16px;flex-wrap:wrap;flex-shrink:0}.var-detail-header-left{flex:1;min-width:180px}.var-detail-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.var-detail-title{margin:0;font-size:1.3rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;word-break:break-word}.var-detail-date{color:var(--text-muted);font-size:.85rem;margin-top:4px}.var-detail-actions{display:flex;gap:8px;align-items:center;flex-shrink:0;flex-wrap:wrap}.var-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border:1px solid transparent}.var-badge--debit{background:#eaeff5;color:#263c54;border-color:#c9daeb}.var-badge--credit{background:#d7eaff;background:oklch(.93 .04 250);color:#004981;color:oklch(.4 .12 250);border-color:#b1d2f4}.var-badge--valid{background:#d7f4e0;color:#004725;color:oklch(.35 .1 155);border-color:#9bd4ae}.var-badge--invalid{background:#ffe3df;background:oklch(.94 .04 25);color:#7c2524;border-color:#f3bfba}.var-badge--pending{background:#ffebd2;color:#733e00;color:oklch(.42 .1 60);border-color:#efd3ac}.var-badge--discount{background:#ddedff;background:oklch(.94 .04 250);color:#004981;color:oklch(.4 .12 250);border-color:#b1d2f4;gap:4px;font-size:.8rem}.var-detail-body{padding:20px 24px;background:var(--bg-primary);overflow-y:auto;flex:1;min-height:0}.var-detail-body>*+*{margin-top:20px}.var-finance-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm)}.var-finance-cell{display:flex;flex-direction:column;gap:4px}.var-finance-cell--actions{grid-column:1 / -1;display:flex;align-items:center;gap:12px;padding-top:12px;border-top:1px solid var(--border-color);flex-wrap:wrap}.var-finance-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.var-finance-value{font-size:1.6rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.var-finance-value--success{color:var(--color-success)}.var-finance-value--warning{color:var(--color-warning)}.var-finance-input-group{display:flex;gap:8px;align-items:center;flex:1;max-width:400px}.var-finance-input-wrap{position:relative;flex:1}.var-finance-input-wrap .currency-prefix{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:1rem;pointer-events:none}.var-finance-input-wrap input{padding-left:28px;height:42px;font-weight:600;font-size:1.05rem;width:100%}.var-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.var-section--blue{border-left:3px solid oklch(.55 .15 255)}.var-section--amber{border-left:3px solid oklch(.7 .15 80)}.var-section--teal{border-left:3px solid oklch(.55 .12 195)}.var-section--indigo{border-left:3px solid oklch(.55 .12 290)}.var-section--rose{border-left:3px solid oklch(.6 .16 15)}.var-section-header{padding:14px 20px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:.9rem;display:flex;align-items:center;gap:8px;background:#f4f7fa;color:var(--text-primary)}.var-section-header--blue{background:#e4f0ff;background:oklch(.95 .03 255);color:#003974;color:oklch(.35 .12 255)}.var-section-header--amber{background:#fef0d4;color:#613700;color:oklch(.38 .1 65)}.var-section-header--teal{background:#d1f7f7;color:#004647;color:oklch(.35 .1 195)}.var-section-header--indigo{background:#eeecff;background:oklch(.95 .04 290);color:#43337c}.var-section-header--rose{background:#ffe7e8;background:oklch(.95 .04 15);color:#751e2d}.var-section-header--dark{background:#0f171f;color:#eceff2}.var-section-empty{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.9rem}.var-table{width:100%;border-collapse:collapse}.var-table thead{border-bottom:1px solid var(--border-color)}.var-table th{text-align:left;padding:10px 20px;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.var-table th.text-right{text-align:right}.var-table thead--blue th{color:#1d487c}.var-table thead--amber th{color:#6f4000;color:oklch(.42 .1 65)}.var-table thead--teal th{color:#004e4f;color:oklch(.38 .1 195)}.var-table thead--indigo th{color:#4d427f}.var-table td{padding:12px 20px;font-size:.9rem;color:var(--text-primary);vertical-align:top}.var-table td.text-right{text-align:right}.var-table td.font-medium{font-weight:500}.var-table td.font-semibold{font-weight:600}.var-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .12s ease}.var-table tbody tr:last-child{border-bottom:none}.var-table tbody tr:hover{background:#f6f9fc}.var-table .rate-hint{font-size:.72rem;color:var(--text-muted);margin-top:2px}.var-table .remarks-cell{word-break:break-word;font-size:.85rem;color:var(--text-secondary);max-width:200px}.var-table-total{border-top:2px solid var(--border-color)!important;border-bottom:none!important;background:#f3f5f8}.var-table-total td{font-weight:700;padding:12px 20px}.var-table-total--blue{background:#dbe9fc!important;border-top-color:#2971c6!important}.var-table-total--blue td{color:#003974;color:oklch(.35 .12 255)}.var-table-total--amber{background:#f8eace!important;border-top-color:#cd9200!important;border-top-color:oklch(.7 .15 80)!important}.var-table-total--amber td{color:#613700;color:oklch(.38 .1 65)}.var-table-total--teal{background:#caf1f0!important;border-top-color:#008484!important;border-top-color:oklch(.55 .12 195)!important}.var-table-total--teal td{color:#004647;color:oklch(.35 .1 195)}.var-table-total--indigo{background:#e7e4ff!important;background:oklch(.93 .04 290)!important;border-top-color:#7163b2!important}.var-table-total--indigo td{color:#43337c}.var-table-total--rose{background:#ffdee0!important;background:oklch(.93 .04 15)!important;border-top-color:#cd4f61!important}.var-table-total--rose td{color:#751e2d}.var-table .thead--rose th{color:#7a323b}.var-grand-total{padding:20px 24px;background:#0f171f;border-radius:var(--border-radius-lg);color:#fff;display:flex;justify-content:space-between;align-items:center;gap:24px}.var-grand-total-label{font-weight:600;font-size:1rem;opacity:.85}.var-grand-total-value{font-weight:700;font-size:1.5rem;letter-spacing:-.02em}.var-content-section{padding:20px 24px;background:var(--bg-card);border-top:1px solid var(--border-color)}.var-content-label{font-size:.75rem;font-weight:600;color:var(--text-muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px}.var-content-block{font-size:.9rem;white-space:pre-wrap;color:var(--text-secondary);line-height:1.6;padding:14px 16px;background:var(--bg-primary);border-radius:var(--border-radius-md);border-left:3px solid var(--color-primary)}.var-signatures{display:flex;gap:12px;flex-wrap:wrap}.var-sig-chip{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--border-radius-md);font-size:.85rem;font-weight:500;border:1px solid transparent}.var-sig-chip--signed{background:#e3f8e9;border-color:#b9e4c6;color:#00572f;color:oklch(.4 .1 155)}.var-sig-chip--unsigned{background:#f3f5f8;border-color:var(--border-color);color:var(--text-muted)}.var-photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.var-photo-thumb{aspect-ratio:1;border:1px solid var(--border-color);border-radius:var(--border-radius-md);overflow:hidden;cursor:pointer;position:relative}.var-photo-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .2s ease}.var-photo-thumb:hover img{transform:scale(1.06)}@media(max-width:768px){.var-detail-modal{width:100%;max-height:100vh;border-radius:0}.var-detail-header,.var-detail-body{padding:16px}.var-detail-body>*+*{margin-top:16px}.var-finance-strip{grid-template-columns:1fr;gap:12px;padding:16px}.var-finance-value{font-size:1.3rem}.var-detail-actions{width:100%;justify-content:flex-end}.var-table th,.var-table td{padding:10px 14px}.var-grand-total{flex-direction:column;text-align:center;gap:8px;padding:16px}}@media(max-width:480px){.var-detail-header{padding:14px;gap:12px}.var-detail-title{font-size:1.1rem}.var-detail-body{padding:12px}.var-detail-body>*+*{margin-top:12px}.var-detail-actions .btn{padding:6px 10px;font-size:.75rem}.var-detail-actions .btn span.btn-label{display:none}.var-section-header{padding:12px 14px;font-size:.85rem}.var-table th,.var-table td{padding:8px 12px;font-size:.8rem}.var-table .rate-hint{font-size:.65rem}.var-table .remarks-cell{max-width:120px;font-size:.75rem}.var-finance-input-group{flex-direction:column;align-items:stretch;max-width:100%}.var-finance-cell--actions{flex-direction:column;align-items:stretch}.var-finance-cell--actions .btn{width:100%;justify-content:center}.var-photo-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.var-content-section{padding:16px}}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.w-full{width:100%}.glass-card{background:#ffffffe6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,1);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border-radius:var(--border-radius-lg);transition:all var(--transition-normal);position:relative;overflow:hidden}.glass-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,#fff0,#fffc,#fff0);opacity:.6}.glass-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;background:#fffffffa}.card-lift{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}.card-lift:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.input-modern{background:#fff;border:1px solid #e2e8f0;border-radius:var(--border-radius-md);transition:all .2s ease;font-size:.95rem;line-height:1.5;color:#1e293b}.input-modern:hover{border-color:#cbd5e1}.input-modern:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be1a;outline:none}.section-header-gradient{background:linear-gradient(to right,#f8fafc,#fff);border-bottom:1px solid #f1f5f9;padding:1rem 1.5rem}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-animated{animation:modalSlideIn .2s cubic-bezier(.16,1,.3,1)}.upload-zone{border:2px dashed #cbd5e1;border-radius:var(--border-radius-lg);transition:all .2s ease;cursor:pointer;background:#f8fafc}.upload-zone:hover{border-color:var(--color-primary);background:#f0f9ff}.checkbox-modern{width:20px;height:20px;border-radius:6px}.file-pill{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;transition:all .2s ease;box-shadow:0 1px 2px #0000000d}.file-pill:hover{border-color:var(--color-primary);box-shadow:0 2px 4px #0000000d}.settings-container{max-width:1000px;margin:0 auto}.variations-list::-webkit-scrollbar{width:6px}.variations-list::-webkit-scrollbar-track{background:transparent}.variations-list::-webkit-scrollbar-thumb{background-color:#cbd5e1;border-radius:20px}.claims-chat-widget{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:16px}.claims-chat-fab{width:56px;height:56px;border-radius:50%;border:none;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #1e73be59;transition:all var(--transition-normal)}.claims-chat-fab:hover{background:var(--color-primary-hover);box-shadow:0 6px 24px #1e73be73}.claims-chat-fab--open{background:var(--color-error);box-shadow:0 4px 16px #ef444459;transform:rotate(90deg)}.claims-chat-fab--open:hover{background:#dc2626}.chat-window{position:fixed;bottom:96px;right:24px;width:min(380px,calc(100vw - 48px));height:min(600px,calc(100vh - 140px));background:var(--bg-secondary);border-radius:var(--border-radius-xl);box-shadow:0 12px 40px #00000026,0 0 0 1px var(--border-color);display:flex;flex-direction:column;overflow:hidden;z-index:200}.chat-window-header{padding:16px 20px;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.chat-window-header-left{display:flex;align-items:center;gap:12px}.chat-window-header-avatar{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.2);overflow:hidden;background:#fff;display:flex;align-items:center;justify-content:center}.chat-window-header-avatar-img{width:28px;height:28px;object-fit:contain}.chat-window-title{font-size:1.05rem;font-weight:700;line-height:1.2;color:#fff}.chat-window-status{font-size:.7rem;color:#fffc;display:flex;align-items:center;gap:5px;margin-top:2px}.chat-window-status-dot{width:7px;height:7px;border-radius:50%;background:#4ade80;animation:pulse 2s ease-in-out infinite}.chat-window-close{background:transparent;border:none;color:#fffc;cursor:pointer;padding:6px;border-radius:8px;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center}.chat-window-close:hover{color:#fff;background:#ffffff26}.chat-window-messages{flex:1;overflow-y:auto;padding:16px;background:var(--bg-primary)}.chat-window-messages::-webkit-scrollbar{width:5px}.chat-window-messages::-webkit-scrollbar-track{background:transparent}.chat-window-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:10px}.chat-window-messages-inner{display:flex;flex-direction:column;gap:4px}.chat-window-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 16px;text-align:center;color:var(--text-muted);margin-top:40px}.chat-window-empty-icon{width:56px;height:56px;border-radius:50%;background:#1e73be14;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.chat-window-empty-img{width:32px;height:32px;object-fit:contain;opacity:.7}.chat-window-empty-text{font-size:.82rem;color:var(--text-muted);line-height:1.5;max-width:260px}.chat-window-input-area{padding:14px 16px;background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0}.chat-window-form{display:flex;gap:8px}.chat-window-input{flex:1;padding:10px 16px;border:1px solid var(--border-color);border-radius:24px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.chat-window-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be1a}.chat-window-input:disabled{opacity:.5}.chat-window-input::placeholder{color:var(--text-muted)}.chat-window-send{width:40px;height:40px;border-radius:50%;padding:0;flex-shrink:0;display:flex;align-items:center;justify-content:center}.chat-window-footer{text-align:center;margin-top:8px}.chat-window-powered{font-size:.62rem;color:var(--text-muted);letter-spacing:.02em}.chat-message{display:flex;width:100%;margin-bottom:12px}.chat-message--user{justify-content:flex-end}.chat-message--bot{justify-content:flex-start}.chat-message-inner{display:flex;max-width:85%;gap:8px}.chat-message-inner--user{flex-direction:row-reverse}.chat-message-inner--bot{flex-direction:row}.chat-avatar-wrap{flex-shrink:0;margin-top:2px}.chat-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center}.chat-avatar--user{background:#1e73be1a;color:var(--color-primary)}.chat-avatar--bot{background:#fff;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.chat-avatar-img{width:20px;height:20px;object-fit:contain}.chat-bubble{padding:10px 14px;border-radius:16px;font-size:.82rem;line-height:1.55;box-shadow:var(--shadow-sm);word-break:break-word}.chat-bubble--user{background:var(--color-primary);color:#fff;border-top-right-radius:4px}.chat-bubble--bot{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-top-left-radius:4px}.chat-bubble--typing{display:flex;align-items:center;gap:8px}.chat-typing-text{font-size:.8rem;color:var(--text-muted)}.chat-typing-spinner{width:14px;height:14px;color:var(--color-primary)}.chat-md-content{font-size:.82rem;line-height:1.6}.chat-md-content>:first-child{margin-top:0}.chat-md-content>:last-child{margin-bottom:0}.chat-md-h1{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:12px 0 6px;padding-bottom:4px;border-bottom:1px solid var(--border-color)}.chat-md-h2{font-size:.88rem;font-weight:700;color:var(--text-primary);margin:10px 0 5px;padding-bottom:3px;border-bottom:1px solid var(--border-color-light, var(--border-color))}.chat-md-h3{font-size:.84rem;font-weight:700;color:var(--text-primary);margin:8px 0 4px}.chat-md-p{font-size:.82rem;line-height:1.6;color:var(--text-secondary);margin-bottom:8px}.chat-md-strong{color:var(--text-primary);font-weight:700}.chat-md-ul,.chat-md-ol{padding-left:18px;margin-bottom:8px;font-size:.82rem;line-height:1.6;color:var(--text-secondary)}.chat-md-li{margin-bottom:3px}.chat-md-blockquote{border-left:3px solid var(--color-primary);padding:6px 10px;margin:8px 0;background:#1e73be0a;border-radius:0 6px 6px 0;color:var(--text-secondary);font-style:italic;font-size:.8rem}.chat-md-table-wrap{overflow-x:auto;margin:8px 0;border-radius:6px;border:1px solid var(--border-color)}.chat-md-table{width:100%;border-collapse:collapse;font-size:.72rem;line-height:1.4}.chat-md-thead{background:var(--bg-tertiary)}.chat-md-th{padding:6px 10px;text-align:left;font-weight:700;font-size:.68rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);border-bottom:2px solid var(--border-color);white-space:nowrap}.chat-md-td{padding:5px 10px;border-top:1px solid var(--border-color-light, var(--border-color));color:var(--text-primary)}.chat-md-code-inline{background:var(--bg-tertiary);padding:1px 5px;border-radius:4px;font-size:.76rem;font-family:SF Mono,Fira Code,monospace;color:var(--color-primary)}.chat-md-pre{background:var(--seq-navy);color:#e2e8f0;padding:10px;border-radius:8px;overflow-x:auto;margin:8px 0;font-size:.72rem;line-height:1.5}.chat-md-code-block{font-family:SF Mono,Fira Code,monospace;font-size:.72rem}.chat-md-hr{border:none;border-top:1px solid var(--border-color);margin:10px 0}.chat-action-link{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;margin:4px 4px 4px 0;border:1px solid var(--primary-color);border-radius:20px;background:linear-gradient(135deg,#3b82f614,#3b82f60a);color:var(--primary-color);font-size:.78rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all .2s ease;line-height:1.4;white-space:nowrap;text-decoration:none}.chat-action-link:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.chat-action-link:active{transform:translateY(0);box-shadow:none}.chat-action-link svg{flex-shrink:0}.chat-md-link{color:var(--primary-color);text-decoration:underline;text-underline-offset:2px;font-weight:500;transition:color .15s}.chat-md-link:hover{color:var(--primary-hover)}@media(max-width:640px){.claims-chat-widget{bottom:16px;right:16px}.chat-window{bottom:80px;right:12px;width:calc(100vw - 24px);height:calc(100vh - 120px);border-radius:var(--border-radius-lg)}.claims-chat-fab{width:50px;height:50px}}.pnl-guide{display:flex;align-items:flex-start;gap:16px;background:linear-gradient(135deg,#f0f7ff,#e8f1fc);border:1px solid rgba(30,115,190,.15);border-radius:var(--border-radius-lg);padding:16px 20px;margin-bottom:16px;position:relative;animation:fadeInUp .3s ease}.pnl-guide-icon{flex-shrink:0;width:36px;height:36px;border-radius:10px;background:var(--color-primary);color:var(--text-inverse);display:flex;align-items:center;justify-content:center}.pnl-guide-tips{flex:1;display:flex;flex-wrap:wrap;gap:8px 24px}.pnl-guide-tip{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--text-secondary);line-height:1.4}.pnl-guide-tip strong{color:var(--text-primary);font-weight:600}.pnl-guide-close{position:absolute;top:10px;right:10px;background:none;border:none;cursor:pointer;padding:4px;color:var(--text-muted);border-radius:6px;transition:background var(--transition-fast),color var(--transition-fast)}.pnl-guide-close:hover{background:#0000000f;color:var(--text-secondary)}.pnl-table-wrap{overflow:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-lg);background:var(--bg-secondary);max-height:calc(100vh - 340px);box-shadow:var(--shadow-sm)}.pnl-table-wrap table{border-collapse:collapse;white-space:nowrap;width:100%}.pnl-table-wrap thead tr{position:sticky;top:0;z-index:30;background:var(--bg-secondary)}.pnl-table-wrap thead th{padding:10px 12px;text-align:right;font-weight:600;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;background:var(--bg-secondary);border-bottom:2px solid var(--border-color);white-space:nowrap}.pnl-table-wrap thead th:first-child,.pnl-table-wrap thead th:nth-child(2){background:#e8f0f8;color:var(--seq-blue-dark);border-bottom-color:#1e73be40}.pnl-table-wrap thead th:first-child{text-align:left}.pnl-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast)}.pnl-section-header:hover{filter:brightness(.97)}.pnl-section-header td{padding:0!important;border-bottom:1px solid var(--border-color)!important}.pnl-section-header-inner{display:flex;align-items:center;gap:8px;padding:10px 12px;font-size:12.5px;font-weight:700;letter-spacing:.3px}.pnl-section-badge{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pnl-section-chevron{margin-left:auto;transition:transform var(--transition-fast);opacity:.5}.pnl-section-header:hover .pnl-section-chevron{opacity:.8}.pnl-cat-row td{border-bottom:1px solid var(--border-color-light);transition:background var(--transition-fast)}.pnl-cat-row:last-child td{border-bottom:1px solid var(--border-color)}.pnl-cat-label{text-align:left!important;font-size:12.5px;font-weight:500;color:var(--text-secondary);padding-left:44px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pnl-edit-cell{cursor:pointer;position:relative}.pnl-edit-cell:hover{background:var(--bg-hover)!important}.pnl-edit-cell .pnl-edit-icon{opacity:0;transition:opacity var(--transition-fast)}.pnl-edit-cell:hover .pnl-edit-icon{opacity:.6}.pnl-data-row td{border-bottom:1px solid var(--border-color-light)}.pnl-summary-divider td{height:3px;background:var(--border-color);border:none;padding:0}.pnl-summary-row td{border-bottom:1px solid var(--border-color-light)}.pnl-profit-row td{font-size:13px!important;font-weight:700!important;border-bottom:2px solid var(--border-color)!important}.pnl-pct-row td{font-size:12px}.pnl-range-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:12px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md)}.pnl-range-bar .pnl-year-tabs{display:flex;gap:2px;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:2px}.pnl-range-bar .pnl-year-tab{padding:5px 14px;border-radius:4px;border:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--text-secondary);background:transparent;transition:all var(--transition-fast)}.pnl-range-bar .pnl-year-tab:hover{color:var(--text-primary);background:#0000000a}.pnl-range-bar .pnl-year-tab.active{background:var(--color-primary);color:var(--text-inverse);box-shadow:0 1px 3px #1e73be4d}.pnl-range-bar .pnl-divider{width:1px;height:24px;background:var(--border-color)}.pnl-range-bar select{padding:5px 28px 5px 8px;font-size:12.5px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background-color:var(--bg-secondary);color:var(--text-primary);min-height:unset}.pnl-scroll-controls{display:flex;align-items:center;gap:6px;margin-left:auto}.pnl-scroll-controls button{padding:4px 8px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-secondary);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.pnl-scroll-controls button:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--color-primary)}.pnl-scroll-badge{font-size:11px;color:var(--text-muted);min-width:60px;text-align:center}.pnl-sticky-label{position:sticky;left:0;z-index:12;background:#f0f5fc;border-right:1px solid rgba(30,115,190,.08)}.pnl-sticky-total{position:sticky;z-index:12;background:#f0f5fc;border-right:2px solid rgba(30,115,190,.12)}.pnl-profit-row .pnl-sticky-label,.pnl-profit-row .pnl-sticky-total{background:inherit}.pnl-summary-row .pnl-sticky-label,.pnl-summary-row .pnl-sticky-total{background:#f0f5fc}.pnl-cat-row:hover .pnl-sticky-label,.pnl-cat-row:hover .pnl-sticky-total,.pnl-data-row:hover .pnl-sticky-label,.pnl-data-row:hover .pnl-sticky-total{background:#e8f0f8}.pnl-section-header-sticky{position:sticky;left:0;z-index:11;background:inherit}.pnl-section-header-fill{background:inherit}.pnl-section-revenue{background:#ecfdf5}.pnl-section-revenue .pnl-section-badge{background:#10b98126;color:#059669}.pnl-section-revenue .pnl-section-header-inner{color:#065f46}.pnl-section-materials-budget{background:#f5f3ff}.pnl-section-materials-budget .pnl-section-badge{background:#6d28d91f;color:#7c3aed}.pnl-section-materials-budget .pnl-section-header-inner{color:#5b21b6}.pnl-section-expenses-materials{background:#f5f3ff}.pnl-section-expenses-materials .pnl-section-badge{background:#6d28d91f;color:#7c3aed}.pnl-section-expenses-materials .pnl-section-header-inner{color:#5b21b6}.pnl-section-expenses-other{background:#fef2f2}.pnl-section-expenses-other .pnl-section-badge{background:#ef44441f;color:#dc2626}.pnl-section-expenses-other .pnl-section-header-inner{color:#991b1b}.pnl-section-expenses-wages{background:#fffbeb}.pnl-section-expenses-wages .pnl-section-badge{background:#f59e0b26;color:#d97706}.pnl-section-expenses-wages .pnl-section-header-inner{color:#92400e}.pnl-section-summary{background:#f0f7ff}.pnl-section-summary .pnl-section-badge{background:#1e73be1f;color:var(--color-primary)}.pnl-section-summary .pnl-section-header-inner{color:var(--seq-blue-dark)}.pnl-claims-link{cursor:pointer;position:relative;transition:background var(--transition-fast)}.pnl-claims-link:hover{background:#ecfdf5!important}.pnl-claims-link .pnl-link-icon{opacity:0;transition:opacity var(--transition-fast)}.pnl-claims-link:hover .pnl-link-icon{opacity:.7}.project-summary-grid{display:grid;grid-template-columns:300px 1fr;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media(max-width:768px){.project-summary-grid{grid-template-columns:1fr}}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.table td,.table th{word-break:break-word;overflow-wrap:break-word}.detail-grid-cell{min-width:0;overflow-wrap:anywhere;word-break:break-word}@media(max-width:640px){.modal{width:100%!important;max-width:100%!important;margin:0;border-radius:0;max-height:100dvh}.modal-overlay{align-items:flex-end}}@media(max-width:480px){.card h1,.card h2,.card h3{word-break:break-word;overflow-wrap:break-word}}.hidden{display:none}@media(min-width:640px){.sm\:inline{display:inline!important}}.vault-container{position:relative;min-height:500px}.vault-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.vault-toolbar-left{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:200px}.vault-toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.vault-search{position:relative;flex:1;max-width:320px}.vault-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.vault-search-input{width:100%;padding:8px 32px 8px 34px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-primary);font-size:.85rem;color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.vault-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be1f}.vault-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.vault-sort{display:flex;align-items:center;gap:4px}.vault-sort-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-primary);font-size:.82rem;color:var(--text-secondary);cursor:pointer}.vault-sort-dir{display:flex;align-items:center;gap:2px;padding:7px 8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);cursor:pointer;color:var(--text-secondary);transition:background .2s}.vault-sort-dir:hover{background:var(--bg-hover)}.vault-sort-dir-label{font-size:.85rem;font-weight:600}.vault-stats{display:flex;align-items:center;gap:var(--spacing-md)}.vault-stat{display:flex;align-items:center;gap:4px;font-size:.78rem;color:var(--text-muted);white-space:nowrap}.vault-select-btn.active{background:#1e73be1a;color:var(--color-primary)}.vault-upload-btn{display:inline-flex;align-items:center;gap:6px;font-size:.85rem}.vault-new-folder-dialog{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);margin-bottom:var(--spacing-md);color:var(--text-secondary)}.vault-new-folder-dialog .vault-inline-input{flex:1}.vault-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--spacing-md);min-height:480px}.vault-layout.with-details{grid-template-columns:220px 1fr 300px}.vault-sidebar{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);overflow-y:auto;overflow-x:hidden;max-height:600px}.vault-folder-tree{padding:var(--spacing-xs) 0}.vault-folder-item{display:flex;align-items:center;gap:6px;padding:7px 12px;cursor:pointer;color:var(--text-secondary);font-size:.82rem;transition:background .15s,color .15s,transform .2s ease,box-shadow .2s ease;border-left:3px solid transparent;-webkit-user-select:none;user-select:none;min-width:0;overflow:hidden}.vault-folder-item:hover{background:var(--bg-hover)}.vault-folder-item.active{background:#1e73be14;color:var(--color-primary);border-left-color:var(--color-primary);font-weight:600}.vault-folder-item.drop-target{background:#1e73be1f;border-left:3px solid var(--color-primary);box-shadow:inset 0 0 0 1px #1e73be33,0 0 12px #1e73be1a;animation:vault-drop-pulse-tree 1.2s ease-in-out infinite;transform:translate(3px);transition:transform .2s ease,background .2s ease,box-shadow .2s ease}@keyframes vault-drop-pulse-tree{0%,to{box-shadow:inset 0 0 0 1px #1e73be33,0 0 8px #1e73be14}50%{box-shadow:inset 0 0 0 1px #1e73be4d,0 0 16px #1e73be26}}.vault-folder-item.drop-target .vault-folder-icon{transform:scale(1.2);filter:drop-shadow(0 0 5px rgba(30,115,190,.5));transition:transform .2s ease,filter .2s ease}.vault-folder-item.drop-target .vault-folder-name{color:var(--color-primary);font-weight:600;transition:color .15s,font-weight .15s}.vault-folder-item.root{padding-left:12px;border-bottom:1px solid var(--border-color-light);margin-bottom:2px}.vault-folder-expand{background:none;border:none;padding:0;cursor:pointer;color:inherit;display:flex;align-items:center;flex-shrink:0}.vault-folder-icon{flex-shrink:0;color:var(--text-muted)}.vault-folder-icon.active{color:var(--color-primary)}.vault-folder-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.vault-new-folder-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;margin:4px 8px;background:none;border:1px dashed var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-muted);font-size:.78rem;cursor:pointer;width:calc(100% - 16px);transition:all .2s}.vault-inline-input{border:1px solid var(--color-primary);border-radius:4px;padding:3px 8px;font-size:.82rem;color:var(--text-primary);background:var(--bg-secondary);outline:none;box-shadow:0 0 0 2px #1e73be26;flex:1;min-width:0}.vault-main{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:var(--spacing-md);overflow-y:auto;max-height:600px;position:relative}.vault-breadcrumbs{display:flex;align-items:center;gap:4px;padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--border-color-light);flex-wrap:wrap}.vault-breadcrumb-item{display:flex;align-items:center;gap:4px}.vault-breadcrumb-sep{color:var(--text-muted)}.vault-breadcrumb-btn{background:none;border:none;padding:4px 8px;border-radius:4px;color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:all .2s}.vault-breadcrumb-btn:hover{background:var(--bg-hover);color:var(--color-primary)}.vault-breadcrumb-btn.current{color:var(--text-primary);font-weight:600}.vault-section{margin-bottom:var(--spacing-lg)}.vault-section-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--spacing-sm)}.vault-grid{display:grid;gap:var(--spacing-sm)}.vault-grid.folders{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.vault-grid.files{grid-template-columns:1fr}.vault-folder-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color-light);border-radius:var(--border-radius-sm);cursor:pointer;transition:all .2s}.vault-folder-card:hover{border-color:var(--color-primary);background:#1e73be0f;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.vault-folder-card-icon{color:var(--color-primary);flex-shrink:0}.vault-folder-card-name{font-size:.82rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vault-file-card{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-color-light);border-radius:var(--border-radius-sm);cursor:pointer;transition:all .2s;position:relative}.vault-file-card:hover{background:var(--bg-hover);border-color:var(--border-color)}.vault-file-card.selected{background:#1e73be14;border-color:var(--color-primary);box-shadow:0 0 0 1px #1e73be33}.vault-file-card.multi-selected{background:#1e73be0f;border-color:var(--color-primary)}.vault-file-card.dragging{opacity:.35;border-style:dashed;transform:scale(.97)}.vault-file-card[draggable=true]{cursor:grab;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.vault-file-card[draggable=true]:active{cursor:grabbing}@keyframes vault-drop-pulse{0%,to{box-shadow:0 0 0 3px #1e73be26,0 0 12px #1e73be14}50%{box-shadow:0 0 0 5px #1e73be38,0 0 20px #1e73be24}}.vault-folder-card.drop-target{border:2px dashed var(--color-primary);background:#1e73be1a;transform:scale(1.04);animation:vault-drop-pulse 1.2s ease-in-out infinite;z-index:2}.vault-folder-card.drop-target .vault-folder-card-icon{transform:scale(1.2);filter:drop-shadow(0 0 6px rgba(30,115,190,.5));transition:transform .2s ease,filter .2s ease}.vault-folder-card.drop-target .vault-folder-card-name{color:var(--color-primary);font-weight:600;transition:color .2s}.vault-folder-card.dragging{opacity:.35;border-style:dashed;transform:scale(.97)}.vault-folder-card[draggable=true]{cursor:grab;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.vault-folder-card[draggable=true]:active{cursor:grabbing}.vault-search-indicator{display:flex;align-items:center;gap:8px;padding:8px 14px;margin-bottom:12px;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:var(--border-radius-sm);font-size:.8rem;color:var(--color-primary)}.vault-search-indicator svg{flex-shrink:0;opacity:.7}.vault-file-checkbox{flex-shrink:0;color:var(--text-muted)}.vault-file-checkbox .checked{color:var(--color-primary)}.vault-file-card-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--border-radius-sm);background:#00000008}.vault-file-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.vault-file-card-name{font-size:.85rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vault-file-card-name.clickable{cursor:pointer;border-radius:3px;padding:1px 4px;margin:-1px -4px;transition:color .15s,background .15s}.vault-file-card-name.clickable:hover{color:var(--color-primary);background:#1e73be0f;text-decoration:underline;text-underline-offset:2px}.vault-file-card-meta{font-size:.72rem;color:var(--text-muted)}.vault-file-card-menu{background:none;border:none;padding:4px;border-radius:4px;color:var(--text-muted);cursor:pointer;opacity:0;transition:opacity .2s}.vault-file-card:hover .vault-file-card-menu{opacity:1}.vault-file-card-menu:hover{background:var(--bg-tertiary);color:var(--text-primary)}.vault-details-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);padding:var(--spacing-md);overflow-y:auto;max-height:600px;animation:vaultSlideIn .25s ease-out}@keyframes vaultSlideIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.vault-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.vault-details-header h3{font-size:.9rem;font-weight:700;color:var(--text-primary)}.vault-details-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px}.vault-details-close:hover{color:var(--text-primary);background:var(--bg-hover)}.vault-details-preview{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--border-radius-sm);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);min-height:120px}.vault-details-image{max-width:100%;max-height:200px;object-fit:contain;border-radius:var(--border-radius-sm)}.vault-details-icon-preview{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);color:var(--text-muted)}.vault-details-ext{font-size:.72rem;font-weight:600;text-transform:uppercase;color:var(--text-muted)}.vault-details-name-section{margin-bottom:var(--spacing-md)}.vault-details-filename{font-size:.88rem;font-weight:600;color:var(--text-primary);word-break:break-all}.vault-details-name-edit{display:flex;gap:6px}.vault-details-meta{display:flex;flex-direction:column;gap:8px;padding:var(--spacing-sm) 0;border-top:1px solid var(--border-color-light);border-bottom:1px solid var(--border-color-light);margin-bottom:var(--spacing-md)}.vault-details-meta-row{display:flex;justify-content:space-between;align-items:center}.vault-details-meta-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.vault-details-meta-value{font-size:.82rem;color:var(--text-primary);font-weight:500;text-align:right}.vault-details-actions{display:flex;flex-direction:column;gap:6px}.vault-action-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background:none;border:1px solid var(--border-color-light);border-radius:var(--border-radius-sm);color:var(--text-secondary);font-size:.82rem;cursor:pointer;transition:all .2s}.vault-action-btn:hover{background:var(--bg-hover);border-color:var(--border-color)}.vault-action-btn.primary{background:var(--color-primary);color:var(--text-inverse);border-color:var(--color-primary)}.vault-action-btn.primary:hover{background:var(--color-primary-hover)}.vault-action-btn.danger{color:var(--color-error)}.vault-action-btn.danger:hover{background:#ef44440f;border-color:var(--color-error)}.vault-context-menu{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);box-shadow:var(--shadow-lg);padding:4px;min-width:160px;animation:vaultFadeIn .15s ease-out}@keyframes vaultFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.vault-context-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;color:var(--text-secondary);font-size:.82rem;cursor:pointer;border-radius:4px;text-align:left;transition:background .15s}.vault-context-menu button:hover{background:var(--bg-hover);color:var(--text-primary)}.vault-context-menu button.danger{color:var(--color-error)}.vault-context-menu button.danger:hover{background:#ef44440f}.vault-context-divider{height:1px;background:var(--border-color);margin:4px 6px}.vault-preview-overlay{position:fixed;inset:0;z-index:10000;background:#000000d1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:vaultPreviewFadeIn .2s ease-out}@keyframes vaultPreviewFadeIn{0%{opacity:0}to{opacity:1}}.vault-preview-container{display:flex;flex-direction:column;width:90vw;max-width:1100px;height:85vh;max-height:85vh;background:var(--bg-primary);border-radius:12px;overflow:hidden;box-shadow:0 24px 64px #00000080;animation:vaultPreviewSlideUp .25s ease-out}.vault-preview-container.fullscreen{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}@keyframes vaultPreviewSlideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.vault-preview-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.vault-preview-title{display:flex;align-items:center;gap:10px;min-width:0}.vault-preview-title>svg{flex-shrink:0;color:var(--color-primary);opacity:.7;width:28px;height:28px}.vault-preview-title-info{display:flex;flex-direction:column;min-width:0}.vault-preview-filename{font-weight:600;font-size:.9rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vault-preview-meta{font-size:.75rem;color:var(--text-tertiary)}.vault-preview-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.vault-preview-action-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;background:none;color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .15s}.vault-preview-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.vault-preview-action-btn.close{color:var(--text-tertiary)}.vault-preview-action-btn.close:hover{background:#ef444414;color:var(--color-error)}.vault-preview-body{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:16px;background:var(--bg-primary)}.vault-preview-image-wrap{display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:auto}.vault-preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px;box-shadow:0 4px 24px #0000001f}.vault-preview-iframe{width:100%;height:100%;border:none;border-radius:6px;background:#fff}.vault-preview-video-wrap{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.vault-preview-video{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 24px #0000001f;background:#000}.vault-preview-audio-wrap{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:480px;padding:40px 24px}.vault-preview-audio-icon{display:flex;align-items:center;justify-content:center;width:96px;height:96px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#8b5cf6);color:#fff;box-shadow:0 8px 32px #3b82f640}.vault-preview-audio-icon svg{width:40px;height:40px}.vault-preview-audio-name{font-size:.95rem;font-weight:600;color:var(--text-primary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.vault-preview-audio{width:100%;border-radius:8px}.vault-preview-loading,.vault-preview-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-secondary);text-align:center}.vault-preview-loading .spin{animation:spin .8s linear infinite}.vault-preview-error svg{opacity:.4;color:var(--text-tertiary)}.vault-preview-error p{font-size:.9rem;color:var(--text-tertiary)}@media(max-width:768px){.vault-preview-container{width:100vw;height:100vh;max-width:100vw;max-height:100vh;border-radius:0}.vault-preview-body{padding:8px}}.vault-drop-zone{position:relative;flex:1;display:flex;flex-direction:column}.vault-drag-overlay{position:absolute;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#1e73be14;border:3px dashed var(--color-primary);border-radius:var(--border-radius-md);animation:vaultPulse 1.5s infinite}.vault-drag-overlay-content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);color:var(--color-primary)}.vault-drag-overlay-content h3{font-size:1.1rem;font-weight:700}.vault-drag-overlay-content p{font-size:.85rem;color:var(--text-secondary)}@keyframes vaultPulse{0%,to{background:#1e73be0f}50%{background:#1e73be1f}}.vault-upload-progress-panel{position:fixed;bottom:20px;right:20px;width:360px;max-height:300px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);z-index:1000;overflow:hidden;animation:vaultSlideUp .3s ease-out}@keyframes vaultSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.vault-upload-progress-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color-light)}.vault-upload-progress-title{display:flex;align-items:center;gap:6px;font-size:.82rem;font-weight:600;color:var(--text-primary)}.vault-upload-cancel{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-error);font-size:.75rem;cursor:pointer}.vault-upload-progress-list{padding:8px;max-height:200px;overflow-y:auto}.vault-upload-progress-item{padding:6px 8px;margin-bottom:6px}.vault-upload-progress-info{display:flex;align-items:center;gap:6px;margin-bottom:4px}.vault-upload-icon{flex-shrink:0}.vault-upload-icon.success{color:var(--color-success)}.vault-upload-icon.error{color:var(--color-error)}.vault-upload-icon.uploading{animation:spin 1s linear infinite}.vault-upload-icon.pending{color:var(--text-muted)}.vault-upload-progress-name{flex:1;font-size:.78rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vault-upload-progress-size{font-size:.72rem;color:var(--text-muted);flex-shrink:0}.vault-upload-progress-bar-track{height:4px;background:var(--bg-tertiary);border-radius:2px;overflow:hidden}.vault-upload-progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--seq-blue-light));border-radius:2px;transition:width .3s ease}.vault-upload-progress-item.complete .vault-upload-progress-bar-fill{background:var(--color-success)}.vault-upload-progress-item.error .vault-upload-progress-bar-fill{background:var(--color-error)}.vault-upload-progress-error{font-size:.72rem;color:var(--color-error);margin-top:2px}.vault-modal-overlay{position:fixed;inset:0;z-index:9000;background:#00000080;display:flex;align-items:center;justify-content:center;animation:vaultFadeIn .2s ease-out}.vault-modal{background:var(--bg-secondary);border-radius:var(--border-radius-md);box-shadow:var(--shadow-lg);width:90%;max-width:420px;max-height:80vh;display:flex;flex-direction:column;animation:vaultSlideUp .25s ease-out}.vault-modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.vault-modal-header h3{font-size:.95rem;font-weight:700;color:var(--text-primary)}.vault-modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px}.vault-modal-body{overflow-y:auto;padding:var(--spacing-sm) 0}.vault-modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-md);border-top:1px solid var(--border-color)}.vault-modal-empty{padding:var(--spacing-lg);text-align:center;color:var(--text-muted);font-size:.85rem}.vault-move-folder-item{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;color:var(--text-secondary);font-size:.82rem;transition:background .15s}.vault-move-folder-item:hover{background:var(--bg-hover)}.vault-move-folder-item.selected{background:#1e73be14;color:var(--color-primary);font-weight:600}.vault-move-folder-item.current{opacity:.5;cursor:not-allowed}.vault-move-current-badge{font-size:.65rem;padding:2px 6px;background:var(--bg-tertiary);border-radius:4px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-left:auto}.vault-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;min-height:300px}.vault-empty-icon{display:flex;align-items:center;justify-content:center;width:88px;height:88px;border-radius:50%;background:linear-gradient(135deg,#1e73be14,#1e73be05);color:var(--color-primary);margin-bottom:var(--spacing-lg)}.vault-empty h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.vault-empty p{font-size:.88rem;color:var(--text-secondary)}.vault-empty-hint{font-size:.78rem!important;color:var(--text-muted)!important;margin-top:var(--spacing-xs)}.vault-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);gap:var(--spacing-sm);color:var(--text-muted);min-height:200px}.vault-loading p{font-size:.85rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.vault-color-picker{display:flex;gap:8px;flex-wrap:wrap}.vault-color-swatch{border-radius:50%;border:2px solid transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,border-color .2s,box-shadow .2s;padding:0}.vault-color-swatch:hover{transform:scale(1.15);box-shadow:0 2px 8px #0003}.vault-color-swatch.active{border-color:#ffffffb3;box-shadow:0 0 0 2px #3b82f680;transform:scale(1.1)}.vault-create-folder-modal,.vault-share-modal{background:var(--bg-secondary);border-radius:var(--border-radius-lg, 12px);box-shadow:var(--shadow-lg);width:90%;max-width:480px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;animation:vaultSlideUp .25s ease-out}.vault-modal-title{display:flex;align-items:center;gap:8px}.vault-modal-title h3{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0}.vault-modal-subtitle{padding:0 var(--spacing-md);font-size:.82rem;color:var(--text-secondary);font-weight:500}.vault-modal-location{padding:6px var(--spacing-md) 0;font-size:.78rem;color:var(--text-muted)}.vault-modal-location strong{color:var(--text-secondary)}.vault-modal-section{padding:var(--spacing-sm) var(--spacing-md)}.vault-modal-label{display:block;font-size:.78rem;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.vault-modal-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm, 6px);background:var(--bg-primary);color:var(--text-primary);font-size:.88rem;outline:none;transition:border-color .2s}.vault-modal-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #1e73be1f}.vault-input-hint{display:block;text-align:right;font-size:.72rem;color:var(--text-muted);margin-top:4px;opacity:.7}.vault-visibility-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.vault-visibility-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:1.5px solid var(--border-color);border-radius:var(--border-radius-sm, 6px);background:var(--bg-primary);cursor:pointer;color:var(--text-muted);transition:all .2s}.vault-visibility-card:hover{border-color:var(--color-primary);color:var(--text-primary)}.vault-visibility-card.active{border-color:var(--color-primary);background:#1e73be0f;color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.vault-visibility-label{font-size:.78rem;font-weight:600}.vault-visibility-desc{font-size:.68rem;color:var(--text-muted);text-align:center;line-height:1.3}.vault-visibility-grid.compact{gap:6px}.vault-visibility-card.compact{flex-direction:row;padding:8px 12px;gap:6px}.vault-visibility-card.compact .vault-visibility-desc{display:none}.vault-user-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.vault-user-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px 3px 10px;background:#1e73be1a;color:var(--color-primary);border-radius:100px;font-size:.75rem;font-weight:500}.vault-chip-remove{display:inline-flex;align-items:center;background:none;border:none;padding:2px;cursor:pointer;color:var(--color-primary);opacity:.6;transition:opacity .15s}.vault-chip-remove:hover{opacity:1}.vault-user-search-wrap{position:relative;margin-bottom:8px}.vault-user-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.vault-user-search-input{width:100%;padding:7px 10px 7px 30px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm, 6px);background:var(--bg-primary);color:var(--text-primary);font-size:.82rem;outline:none}.vault-user-search-input:focus{border-color:var(--color-primary)}.vault-user-list{max-height:200px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--border-radius-sm, 6px);background:var(--bg-primary)}.vault-user-list.compact{max-height:160px}.vault-user-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:transparent;cursor:pointer;text-align:left;transition:background .15s}.vault-user-item:hover{background:var(--bg-hover)}.vault-user-item.selected{background:#1e73be0f}.vault-user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0}.vault-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.vault-user-name{font-size:.82rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vault-user-email{font-size:.72rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vault-user-check{color:var(--color-primary);flex-shrink:0}.vault-user-empty{padding:16px;text-align:center;font-size:.82rem;color:var(--text-muted)}.vault-modal-btn{padding:8px 16px;border:none;border-radius:var(--border-radius-sm, 6px);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s}.vault-modal-btn.primary{background:var(--color-primary);color:#fff}.vault-modal-btn.primary:hover:not(:disabled){filter:brightness(1.1)}.vault-modal-btn.primary:disabled{opacity:.5;cursor:not-allowed}.vault-modal-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.vault-modal-btn.secondary:hover{background:var(--bg-hover)}.vault-current-shares{margin-bottom:10px;border:1px solid var(--border-color);border-radius:var(--border-radius-sm, 6px);overflow:hidden}.vault-share-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border-color)}.vault-share-row:last-child{border-bottom:none}.vault-share-remove{background:none;border:none;padding:4px;color:var(--text-muted);cursor:pointer;transition:color .15s}.vault-share-remove:hover{color:var(--color-error)}.vault-share-info{padding:var(--spacing-md);font-size:.82rem;color:var(--text-muted);text-align:center;background:var(--bg-tertiary);border-radius:var(--border-radius-sm, 6px)}.vault-visibility-badge{flex-shrink:0;margin-left:4px}.vault-visibility-badge.private{color:#f59e0b}.vault-visibility-badge.shared{color:#8b5cf6}.vault-folder-badge{flex-shrink:0;margin-left:4px}.vault-folder-badge.private{color:#f59e0b}.vault-folder-badge.shared{color:#8b5cf6}.vault-context-color-picker{padding:8px 12px;border-top:1px solid var(--border-color)}.vault-new-folder-btn{display:flex;align-items:center;gap:6px;width:100%;padding:8px 12px;margin-top:4px;border:1px dashed var(--border-color);border-radius:var(--border-radius-sm, 6px);background:transparent;color:var(--text-muted);font-size:.78rem;cursor:pointer;transition:all .15s}.vault-new-folder-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:#1e73be0a}.vault-folder-card{position:relative}.vault-folder-card .vault-folder-badge{position:absolute;top:6px;right:6px}@media(max-width:768px){.vault-layout,.vault-layout.with-details{grid-template-columns:1fr}.vault-sidebar{display:none}.vault-details-panel{position:fixed;right:0;top:0;bottom:0;width:100%;max-width:360px;max-height:100vh;z-index:1000;border-radius:0;box-shadow:var(--shadow-lg)}.vault-toolbar{flex-direction:column;align-items:stretch}.vault-toolbar-left,.vault-toolbar-right{justify-content:space-between}.vault-search{max-width:100%}.vault-upload-progress-panel{width:calc(100% - 32px);left:16px;right:16px}.vault-grid.folders{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media(max-width:480px){.vault-stats,.vault-sort{display:none}}.vault-confirm-modal{max-width:440px!important;overflow:hidden;border-radius:16px!important}.vault-delete-breakdown{display:flex;flex-direction:column;gap:6px;padding:10px 14px;border-radius:10px;background:#fef2f2;border:1px solid #fecaca}.vault-delete-breakdown-label{font-size:.78rem;font-weight:600;color:#991b1b}.vault-delete-breakdown-chips{display:flex;flex-wrap:wrap;gap:6px}.vault-delete-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600}.vault-delete-chip.folders{background:#fef3c7;color:#92400e;border:1px solid #fde68a}.vault-delete-chip.files{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}.vault-cfm-strip{height:4px;width:100%;flex-shrink:0}.vault-cfm-strip.danger{background:linear-gradient(90deg,#ef4444,#f87171)}.vault-cfm-strip.warning{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.vault-cfm-strip.info{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.vault-cfm-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px;transition:all .15s;z-index:1}.vault-cfm-close:hover{background:var(--bg-hover);color:var(--text-primary)}.vault-cfm-body{display:flex;flex-direction:column;align-items:center;padding:28px 24px 20px;text-align:center}.vault-cfm-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.vault-cfm-icon.danger{color:#ef4444;background:#ef44441a;box-shadow:0 0 0 8px #ef44440d}.vault-cfm-icon.warning{color:#f59e0b;background:#f59e0b1a;box-shadow:0 0 0 8px #f59e0b0d}.vault-cfm-icon.info{color:#3b82f6;background:#3b82f61a;box-shadow:0 0 0 8px #3b82f60d}.vault-cfm-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 8px}.vault-cfm-message{font-size:.85rem;line-height:1.55;color:var(--text-secondary);margin:0;max-width:300px}.vault-cfm-actions{display:flex;gap:10px;padding:16px 24px 20px;justify-content:center}.vault-cfm-cancel{padding:9px 20px;border-radius:10px;font-size:.82rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.vault-cfm-cancel:hover{background:var(--bg-hover);border-color:var(--text-muted)}.vault-cfm-confirm{display:inline-flex;align-items:center;gap:6px;padding:9px 22px;border-radius:10px;font-size:.82rem;font-weight:600;border:none;color:#fff;cursor:pointer;transition:all .2s ease}.vault-cfm-confirm.danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d}.vault-cfm-confirm.danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 14px #ef444466;transform:translateY(-1px)}.vault-cfm-confirm.warning{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #f59e0b4d}.vault-cfm-confirm.warning:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 14px #f59e0b66;transform:translateY(-1px)}.vault-cfm-confirm.info{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d}.vault-cfm-confirm.info:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 14px #3b82f666;transform:translateY(-1px)}.vault-cfm-confirm:active{transform:translateY(0)}.vault-cfm-strip.success{background:linear-gradient(90deg,#16a34a,#22c55e)}.vault-cfm-icon.success{color:#16a34a;background:#16a34a1a;box-shadow:0 0 0 8px #16a34a0d}.vault-cfm-confirm.success{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 2px 8px #16a34a4d}.vault-cfm-confirm.success:hover:not(:disabled){background:linear-gradient(135deg,#15803d,#166534);box-shadow:0 4px 14px #16a34a66;transform:translateY(-1px)}.vault-cfm-confirm:disabled{opacity:.55;cursor:not-allowed;box-shadow:none}.reconcile-field{width:100%;max-width:320px;margin-top:18px;text-align:left}.reconcile-field-label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:7px}.reconcile-date-row{display:flex;gap:8px;align-items:stretch}.reconcile-date-input-wrap{position:relative;flex:1;display:flex;align-items:center}.reconcile-date-icon{position:absolute;left:11px;color:var(--text-muted);pointer-events:none}.reconcile-date-input{width:100%;padding:10px 12px 10px 34px;font-size:.85rem;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;outline:none;transition:border-color .15s,box-shadow .15s}.reconcile-date-input:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a24}.reconcile-today-chip{flex-shrink:0;padding:0 14px;font-size:.78rem;font-weight:600;color:#15803d;background:#16a34a14;border:1px solid rgba(22,163,74,.22);border-radius:10px;cursor:pointer;transition:background .15s,border-color .15s}.reconcile-today-chip:hover{background:#16a34a24;border-color:#16a34a66}.reconcile-by{margin:10px 0 0;font-size:.78rem;color:var(--text-secondary)}.reconcile-by strong{color:var(--text-primary);font-weight:600}.vault-duplicate-modal{max-width:560px!important;overflow:hidden;border-radius:16px!important}.vault-dup-header{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 16px;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a;position:relative}.vault-dup-header-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #f59e0b4d}.vault-dup-header-text{flex:1;min-width:0}.vault-dup-header-text h3{font-size:.95rem;font-weight:700;color:#92400e;margin:0 0 3px}.vault-dup-header-text p{font-size:.78rem;color:#a16207;margin:0;line-height:1.4}.vault-duplicate-modal .vault-modal-close{position:absolute;right:12px;top:12px}.vault-dup-bulk{display:flex;align-items:center;gap:8px;padding:10px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.vault-dup-bulk-label{font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.vault-dup-bulk-group{display:flex;gap:6px}.vault-dup-bulk-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .18s ease}.vault-dup-bulk-btn:hover{border-color:var(--accent);color:var(--accent);background:#3b82f60f}.vault-dup-bulk-btn.active.replace{background:#fef2f2;color:#dc2626;border-color:#fca5a5}.vault-dup-bulk-btn.active.keep{background:#eff6ff;color:#2563eb;border-color:#93c5fd}.vault-dup-bulk-btn.active.skip{background:#f9fafb;color:#6b7280;border-color:#d1d5db}.vault-dup-list{overflow-y:auto;max-height:300px;flex-shrink:1}.vault-dup-row{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-color-light, rgba(0,0,0,.05));transition:background .15s ease}.vault-dup-row:hover{background:var(--bg-hover)}.vault-dup-row:last-child{border-bottom:none}.vault-dup-file-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);color:#64748b;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vault-dup-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.vault-dup-file-name{font-size:.82rem;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vault-dup-file-meta{font-size:.72rem;color:var(--text-muted)}.vault-dup-file-actions{display:flex;gap:4px;flex-shrink:0}.vault-dup-action{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:8px;font-size:.72rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-muted);cursor:pointer;transition:all .18s ease;white-space:nowrap}.vault-dup-action:hover{border-color:var(--accent);color:var(--accent);background:#3b82f60a}.vault-dup-action.active.replace{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#dc2626;border-color:#fca5a5;box-shadow:0 1px 3px #dc26261f}.vault-dup-action.active.keep{background:linear-gradient(135deg,#eff6ff,#dbeafe);color:#2563eb;border-color:#93c5fd;box-shadow:0 1px 3px #2563eb1f}.vault-dup-action.active.skip{background:linear-gradient(135deg,#f9fafb,#f3f4f6);color:#6b7280;border-color:#d1d5db}.vault-dup-summary{display:flex;flex-wrap:wrap;gap:6px;padding:10px 20px;border-top:1px solid var(--border-color);background:var(--bg-primary)}.vault-dup-summary-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.02em}.vault-dup-summary-tag.replace{background:#fef2f2;color:#dc2626}.vault-dup-summary-tag.keep{background:#eff6ff;color:#2563eb}.vault-dup-summary-tag.skip{background:#f3f4f6;color:#6b7280}.vault-dup-summary-tag.new{background:#f0fdf4;color:#16a34a}.vault-dup-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-secondary);min-height:56px;align-items:center}.vault-dup-cancel{padding:9px 20px;border-radius:10px;font-size:.82rem;font-weight:600;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .25s ease}.vault-dup-cancel:hover{background:var(--bg-hover);border-color:var(--text-muted)}.vault-dup-cancel.solo{margin-left:auto}.vault-dup-confirm{display:inline-flex;align-items:center;gap:6px;padding:9px 22px;border-radius:10px;font-size:.82rem;font-weight:600;border:none;color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f659;cursor:pointer;transition:all .2s ease}.vault-dup-confirm.show{animation:dupConfirmSlideIn .3s ease-out}.vault-dup-confirm:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 14px #3b82f673;transform:translateY(-1px)}.vault-dup-confirm:active{transform:translateY(0)}@keyframes dupConfirmSlideIn{0%{opacity:0;transform:translate(12px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@media(max-width:640px){.vault-duplicate-modal{max-width:95vw!important}.vault-dup-row{flex-direction:column;align-items:flex-start;gap:10px}.vault-dup-file-actions{width:100%}.vault-dup-action{flex:1;justify-content:center}.vault-dup-bulk-group{flex-wrap:wrap}}.idle-timeout-backdrop{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;background:#0000008c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.idle-timeout-modal{position:relative;background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--border-radius-xl, 24px);box-shadow:0 25px 60px #0003,0 0 0 1px #f59e0b14;padding:40px 36px 32px;max-width:380px;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center}.idle-timeout-timer{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.idle-timeout-ring{position:absolute;inset:0;width:100%;height:100%}.idle-timeout-timer-content{display:flex;flex-direction:column;align-items:center;gap:2px;z-index:1}.idle-timeout-shield{display:flex;align-items:center;justify-content:center;margin-bottom:2px}.idle-timeout-seconds{font-size:2rem;font-weight:700;line-height:1;letter-spacing:-.02em;transition:color .5s ease;font-variant-numeric:tabular-nums}.idle-timeout-seconds-label{font-size:.65rem;font-weight:500;color:var(--text-muted, #94a3b8);text-transform:uppercase;letter-spacing:.08em}.idle-timeout-text{display:flex;flex-direction:column;gap:8px}.idle-timeout-title{font-size:1.25rem;font-weight:700;color:var(--text-primary, #1e293b);margin:0;line-height:1.3}.idle-timeout-description{font-size:.875rem;color:var(--text-secondary, #475569);line-height:1.5;margin:0;max-width:65ch}.idle-timeout-actions{display:flex;flex-direction:column;gap:10px;width:100%}.idle-timeout-btn-stay{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 20px;border:none;border-radius:var(--border-radius-md, 10px);background:var(--color-primary, #1e73be);color:#fff;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .15s ease;letter-spacing:-.01em}.idle-timeout-btn-stay:hover{background:var(--color-primary-hover, #3b8fd4);transform:translateY(-1px);box-shadow:0 4px 12px #1e73be4d}.idle-timeout-btn-stay:active{transform:scale(.97);box-shadow:none}.idle-timeout-btn-stay:focus-visible{outline:2px solid var(--color-primary, #1e73be);outline-offset:2px}.idle-timeout-btn-signout{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 20px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--border-radius-md, 10px);background:transparent;color:var(--text-secondary, #475569);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.idle-timeout-btn-signout:hover{border-color:var(--color-error, #ef4444);color:var(--color-error, #ef4444);background:#ef44440a}.idle-timeout-btn-signout:active{transform:scale(.97)}.idle-timeout-btn-signout:focus-visible{outline:2px solid var(--color-error, #ef4444);outline-offset:2px}@media(max-width:480px){.idle-timeout-modal{padding:32px 24px 24px;max-width:calc(100vw - 32px);gap:20px;border-radius:var(--border-radius-lg, 16px)}.idle-timeout-timer{width:100px;height:100px}.idle-timeout-seconds{font-size:1.5rem}.idle-timeout-title{font-size:1.125rem}}@media(prefers-reduced-motion:reduce){.idle-timeout-backdrop,.idle-timeout-modal{animation:none!important;transition:none!important}.idle-timeout-ring circle{transition:none!important}.idle-timeout-shield{animation:none!important}}.paid-builder-cell{display:flex;flex-direction:column;gap:4px;align-items:flex-end;cursor:pointer;min-width:136px;padding:6px 8px;border-radius:8px;border:1px solid transparent;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.paid-builder-cell--has-value{background:#f8fafc;border-color:#e2e8f0}.paid-builder-cell--empty{background:transparent}.paid-builder-cell:hover{background:#eff6ff;border-color:#2563eb47;box-shadow:0 6px 16px #2563eb1f}.paid-builder-cell:focus-visible{outline:2px solid rgba(37,99,235,.55);outline-offset:2px}.variation-payment-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border-color-light, rgba(0, 0, 0, .05));transition:background .12s ease}.variation-payment-row:hover{background:var(--bg-hover, rgba(0, 0, 0, .02))}.variation-payment-row:last-child{border-bottom:none}.variation-mini-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;outline:none;cursor:pointer}.variation-mini-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #8b5cf6;box-shadow:0 1px 4px #00000026;cursor:grab;transition:all .15s ease}.variation-mini-slider::-webkit-slider-thumb:hover{transform:scale(1.15)}.variation-mini-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid #8b5cf6;box-shadow:0 1px 4px #00000026;cursor:grab}.var-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.var-badge.credit{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.var-badge.debit{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}@keyframes popoverIn{0%{opacity:0;transform:translateY(-4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.login-container{--login-primary: var(--brand-primary, #1e40af);--login-secondary: var(--brand-secondary, #3b82f6);--login-accent: var(--brand-accent, #06b6d4);--login-ink: #0f172a;--login-muted: #64748b;--login-border: #e2e8f0;--login-field-bg: #f8fafc;min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(1200px 600px at 12% -10%,#eef4ff,#eef4ff00 55%),radial-gradient(1000px 600px at 110% 110%,#f3f0ff,#f3f0ff00 50%),#f5f7fb;font-family:var(--font-body, "Inter", system-ui, sans-serif)}.login-shell{display:grid;grid-template-columns:1fr;width:100%;max-width:420px;background:#fff;border:1px solid var(--login-border);border-radius:22px;overflow:hidden;box-shadow:0 1px 2px #0f172a0a,0 24px 60px -28px #0f172a47}.login-brand-panel{display:none;position:relative;overflow:hidden;padding:44px 40px;color:#fff;background:linear-gradient(155deg,var(--login-primary) 0%,var(--login-secondary) 78%,var(--login-accent) 140%);isolation:isolate}.login-brand-panel-inner{position:relative;z-index:1;display:flex;flex-direction:column;height:100%}.login-brand-glow{position:absolute;inset:0;z-index:0;background:radial-gradient(420px 280px at 85% 8%,rgba(255,255,255,.22),transparent 60%),radial-gradient(360px 300px at 0% 100%,rgba(255,255,255,.14),transparent 55%);pointer-events:none;animation:login-breathe 7s ease-in-out infinite}@keyframes login-breathe{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.login-intro{position:fixed;inset:0;z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;cursor:pointer;isolation:isolate;background:linear-gradient(155deg,var(--login-primary) 0%,var(--login-secondary) 78%,var(--login-accent) 150%)}.login-intro-glow{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(600px 400px at 50% 32%,rgba(255,255,255,.22),transparent 60%),radial-gradient(500px 420px at 85% 100%,rgba(255,255,255,.12),transparent 55%);animation:login-breathe 6s ease-in-out infinite}.login-intro-badge{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;width:100px;height:100px;border-radius:28px;background:#fffffff7;box-shadow:0 30px 70px -22px #0000008c}.login-intro-badge img{width:62px;height:62px;object-fit:contain}.login-intro-name{position:relative;z-index:1;display:flex;font-family:var(--font-heading, "Inter", sans-serif);font-size:30px;font-weight:700;letter-spacing:-.02em;color:#fff}.login-intro-name span{white-space:pre}@media(prefers-reduced-motion:reduce){.login-brand-glow,.login-intro-glow{animation:none}}.login-brand-badge{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:18px;background:#fffffff5;box-shadow:0 10px 24px -12px #00000073;margin-bottom:22px}.login-brand-badge-logo{width:40px;height:40px;object-fit:contain}.login-brand-name{font-family:var(--font-heading, "Inter", sans-serif);font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0 0 8px;color:#fff}.login-brand-tagline{font-size:14px;line-height:1.5;color:#ffffffdb;margin:0 0 28px;max-width:30ch}.login-feature-list{list-style:none;margin:auto 0 0;padding:0;display:flex;flex-direction:column;gap:14px}.login-feature-item{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:#fffffff2}.login-feature-tick{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px;border-radius:8px;background:#ffffff29;color:#fff}.login-feature-tick svg{width:15px;height:15px}.login-main{display:flex;align-items:center;justify-content:center;padding:36px 28px}.login-card{width:100%;max-width:340px;display:flex;flex-direction:column}.login-logo-mobile{height:52px;width:auto;max-width:150px;object-fit:contain;align-self:center;margin-bottom:20px}.login-header{margin-bottom:22px}.login-title{font-family:var(--font-heading, "Inter", sans-serif);font-size:24px;font-weight:700;letter-spacing:-.02em;color:var(--login-ink);margin:0 0 6px}.login-subtitle{font-size:14px;color:var(--login-muted);margin:0;word-break:break-word}.login-welcome{display:flex;align-items:center;gap:14px;margin-bottom:22px}.login-welcome-avatar{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;background:color-mix(in srgb,var(--login-primary) 12%,#ffffff);border:1px solid color-mix(in srgb,var(--login-primary) 22%,transparent);color:var(--login-primary);font-family:var(--font-heading, "Inter", sans-serif);font-size:19px;font-weight:700;letter-spacing:.01em;flex-shrink:0}.login-welcome-avatar img{width:32px;height:32px;object-fit:contain}.login-welcome-text{min-width:0}.login-welcome-text .login-title{font-size:20px;margin-bottom:2px}.login-form{display:flex;flex-direction:column}.login-form-group{margin-bottom:16px}.login-label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:6px}.login-input{width:100%;padding:12px 14px;border:1px solid var(--login-border);border-radius:11px;font-size:15px;color:var(--login-ink);background:var(--login-field-bg);outline:none;transition:border-color .15s,box-shadow .15s,background .15s}.login-input:focus{border-color:var(--login-primary);background:#fff;box-shadow:0 0 0 4px color-mix(in srgb,var(--login-primary) 14%,transparent)}.login-input::placeholder{color:#94a3b8}.login-password-wrapper{position:relative}.login-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--login-muted);cursor:pointer;padding:4px;display:flex;border-radius:6px;transition:color .15s,background .15s}.login-password-toggle:hover{color:var(--login-ink);background:#eef2f7}.login-error{padding:11px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:14px}.login-error p{color:#dc2626;font-size:13px;margin:0}.login-button{width:100%;padding:13px 18px;background:var(--login-primary);color:#fff;border:none;border-radius:11px;font-size:15px;font-weight:600;cursor:pointer;transition:filter .15s,transform .08s,box-shadow .15s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 22px -12px color-mix(in srgb,var(--login-primary) 70%,transparent)}.login-button:hover:not(:disabled){filter:brightness(1.06)}.login-button:active:not(:disabled){transform:scale(.985)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-sso-button{width:100%;padding:12px 18px;background:#fff;color:#1f2937;border:1px solid var(--login-border);border-radius:11px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .08s,box-shadow .15s;display:flex;align-items:center;justify-content:center;gap:10px}.login-sso-button:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.login-sso-button:active:not(:disabled){transform:scale(.985)}.login-sso-button:disabled{opacity:.7;cursor:not-allowed}.login-sso-button--primary{border-color:#cbd5e1;box-shadow:0 10px 22px -16px #0f172a66}.login-sso-icon{width:20px;height:20px;flex-shrink:0}.login-sso-spinner{width:18px;height:18px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:sso-spin .6s linear infinite;flex-shrink:0}@keyframes sso-spin{to{transform:rotate(360deg)}}.login-divider{display:flex;align-items:center;margin:18px 0;gap:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--login-border)}.login-divider span{font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.login-text-link{background:none;border:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--login-primary);padding:10px 8px;margin-top:14px;text-align:center;border-radius:8px;transition:background .15s}.login-text-link:hover:not(:disabled){background:color-mix(in srgb,var(--login-primary) 8%,transparent)}.login-text-link--muted{color:var(--login-muted);font-weight:500;margin-top:4px}.login-text-link--muted:hover:not(:disabled){background:#f1f5f9}.login-text-link:disabled{opacity:.6;cursor:not-allowed}.login-back-link{align-self:flex-start;display:inline-flex;align-items:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--login-muted);font-size:13px;font-weight:600;padding:6px 8px 6px 4px;margin:0 0 10px -4px;border-radius:8px;transition:color .15s,background .15s}.login-back-link:hover:not(:disabled){color:var(--login-ink);background:#f1f5f9}.login-footer{margin-top:22px;padding-top:16px;border-top:1px solid #f1f5f9;text-align:center;font-size:12px;color:#94a3b8;line-height:1.5}@media(min-width:860px){.login-shell{grid-template-columns:1.05fr 1fr;max-width:880px}.login-brand-panel{display:block}.login-logo-mobile{display:none}.login-main{padding:48px 40px}}.setup-container{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:12px;background:linear-gradient(135deg,#ebf4ff,#f0f9ff,#f5f3ff)}.setup-card{width:100%;max-width:360px;background:#fff;border:1px solid #e0e7ff;border-radius:12px;padding:24px 20px;box-shadow:0 4px 20px #0000000f}.setup-header{text-align:center;margin-bottom:20px}.setup-logo{width:auto;height:60px;max-width:160px;margin-bottom:12px;object-fit:contain}.setup-title{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 4px}.setup-subtitle{font-size:13px;color:#6b7280;margin:0}.setup-form-group{margin-bottom:14px}.setup-label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:5px}.setup-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:16px;color:#1f2937;background:#f9fafb;outline:none;transition:border-color .2s,box-shadow .2s}.setup-input:focus{border-color:#1e73be;box-shadow:0 0 0 2px #1e73be1a}.setup-input::placeholder{color:#9ca3af}.setup-password-wrapper{position:relative}.setup-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#6b7280;cursor:pointer;padding:0;display:flex}.setup-requirements{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:12px;margin-bottom:14px}.setup-requirement{display:flex;align-items:center;gap:8px;font-size:12px;color:#94a3b8;margin-bottom:4px}.setup-requirement:last-child{margin-bottom:0}.setup-requirement.met{color:#10b981}.setup-requirement svg{opacity:.3}.setup-requirement.met svg{opacity:1}.setup-error{padding:10px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:14px}.setup-error p{color:#dc2626;font-size:13px;margin:0}.setup-button{width:100%;padding:11px 18px;background:#1e73be;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .2s,transform .1s}.setup-button:hover:not(:disabled){background:#1a5a9a}.setup-button:active:not(:disabled){transform:scale(.98)}.setup-button:disabled{opacity:.6;cursor:not-allowed}@media(min-width:480px){.setup-card{max-width:380px;padding:28px 24px}.setup-logo{height:70px;max-width:180px}.setup-title{font-size:22px}}.pnl-grid-row{display:grid;gap:20px;margin-bottom:24px}.pnl-grid-metrics{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.pnl-grid-2col{grid-template-columns:repeat(2,1fr);align-items:stretch}.pnl-chart-card{display:flex;flex-direction:column;min-height:0}.pnl-chart-card>div:nth-child(2){flex:1;min-height:200px}@media(max-width:1024px){.pnl-grid-2col{grid-template-columns:repeat(2,1fr);gap:16px}.pnl-grid-metrics{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.pnl-grid-2col{grid-template-columns:1fr}.pnl-grid-metrics{grid-template-columns:repeat(2,1fr)}.pnl-chart-card{padding:1rem!important}}@media(max-width:480px){.pnl-grid-metrics{grid-template-columns:1fr}.pnl-grid-row{gap:12px;margin-bottom:16px}.pnl-chart-card{border-radius:12px!important;padding:.875rem!important}}@media(max-width:768px){.pnl-pareto-switcher{flex-direction:column!important;align-items:stretch!important}.pnl-pareto-switcher button{text-align:center}}.dfb-trigger{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border:1.5px solid oklch(.85 .02 270);border-radius:12px;background:#f9fafe;font-size:.82rem;font-weight:550;color:#343a4b;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.dfb-trigger:before{content:"";position:absolute;inset:0;background:#445def0f;opacity:0;transition:opacity .2s ease}.dfb-trigger:hover:before{opacity:1}.dfb-trigger:hover{border-color:#6684fb;transform:translateY(-1px);box-shadow:0 4px 16px #4761e41a}.dfb-trigger:active{transform:translateY(0)}.dfb-trigger.has-filters{border-color:#445def;background:#e8eeff;background:oklch(.95 .04 270);color:#1f2d87}.dfb-trigger-icon{display:flex;color:#4761e4;transition:transform .3s cubic-bezier(.16,1,.3,1)}.dfb-trigger:hover .dfb-trigger-icon{transform:rotate(15deg)}.dfb-trigger-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:.65rem;font-weight:700;color:#fff;background:#445def;animation:dfb-count-pop .35s cubic-bezier(.34,1.56,.64,1)}@keyframes dfb-count-pop{0%{transform:scale(0) rotate(-20deg)}60%{transform:scale(1.15) rotate(3deg)}to{transform:scale(1) rotate(0)}}.dfb-active-pills{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-left:8px}.dfb-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.72rem;font-weight:500;background:#e4ebff;background:oklch(.94 .04 270);color:#2a3c97;border:1px solid oklch(.88 .06 270);animation:dfb-pill-enter .3s cubic-bezier(.16,1,.3,1) backwards;transition:all .2s ease}.dfb-pill:nth-child(1){animation-delay:0s}.dfb-pill:nth-child(2){animation-delay:.04s}.dfb-pill:nth-child(3){animation-delay:.08s}.dfb-pill:nth-child(4){animation-delay:.12s}@keyframes dfb-pill-enter{0%{opacity:0;transform:translate(-6px) scale(.92)}to{opacity:1;transform:translate(0) scale(1)}}.dfb-pill-x{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:#4761e41f;cursor:pointer;transition:all .15s ease;border:none;padding:0;color:#2f40c2}.dfb-pill-x:hover{background:#4761e440;transform:scale(1.1)}.dfb-overlay{position:fixed;inset:0;z-index:900;background:#080b1473;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding:48px 24px 24px;animation:dfb-overlay-in .3s cubic-bezier(.16,1,.3,1)}.dfb-overlay.closing{animation:dfb-overlay-out .25s cubic-bezier(.4,0,1,1) forwards}@keyframes dfb-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes dfb-overlay-out{0%{opacity:1}to{opacity:0}}.dfb-modal{width:100%;max-width:720px;max-height:calc(100vh - 96px);border-radius:20px;background:#fbfcfe;border:1px solid oklch(.9 .01 270);box-shadow:0 24px 80px -12px #0d142c2e,0 8px 24px #0d142c0f;display:flex;flex-direction:column;overflow:hidden;animation:dfb-modal-in .4s cubic-bezier(.16,1,.3,1)}.dfb-overlay.closing .dfb-modal{animation:dfb-modal-out .2s cubic-bezier(.4,0,1,1) forwards}@keyframes dfb-modal-in{0%{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes dfb-modal-out{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(8px) scale(.98)}}.dfb-modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 16px;border-bottom:1px solid oklch(.92 .01 270)}.dfb-modal-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:#445def;color:#fff;flex-shrink:0}.dfb-modal-title{flex:1}.dfb-modal-title h2{font-size:1.05rem;font-weight:650;color:#12161f;margin:0;line-height:1.3}.dfb-modal-title p{font-size:.78rem;color:#6d717e;margin:2px 0 0}.dfb-modal-close{width:36px;height:36px;border-radius:10px;border:1px solid oklch(.9 .01 270);background:#f4f5f9;color:#5f636f;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.dfb-modal-close:hover{background:#eaebef;border-color:#c8cddb;color:#2a2d38;transform:rotate(90deg)}.dfb-modal-body{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:24px}.dfb-section{animation:dfb-section-enter .45s cubic-bezier(.16,1,.3,1) backwards}.dfb-section:nth-child(1){animation-delay:.06s}.dfb-section:nth-child(2){animation-delay:.12s}.dfb-section:nth-child(3){animation-delay:.18s}.dfb-section:nth-child(4){animation-delay:.24s}@keyframes dfb-section-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.dfb-section-label{font-size:.7rem;font-weight:650;color:#5f636f;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:flex;align-items:center;gap:8px}.dfb-section-label-icon{display:flex;color:#4b65d9}.dfb-list-wrapper{border:1px solid oklch(.9 .01 270);border-radius:14px;background:#f7f8fa;overflow:hidden;transition:border-color .2s ease}.dfb-list-wrapper:focus-within{border-color:#6684fb;box-shadow:0 0 0 3px #4761e414}.dfb-list-search{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid oklch(.93 .008 270)}.dfb-list-search-icon{color:#7b808d;flex-shrink:0}.dfb-list-search input{width:100%;border:none;background:transparent;font-size:.82rem;color:#12161f;outline:none}.dfb-list-search input::placeholder{color:#8b8f99}.dfb-list-items{max-height:200px;overflow-y:auto;padding:6px 0;scrollbar-width:thin;scrollbar-color:oklch(.82 .01 270) transparent}.dfb-list-item{display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:.82rem;color:#2a2d38;cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.dfb-list-item:hover{background:#eef2fc}.dfb-list-item.selected{background:#e8eeff;background:oklch(.95 .03 270);color:#182469;font-weight:500}.dfb-list-checkbox{width:18px;height:18px;border-radius:5px;border:1.5px solid oklch(.78 .02 270);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s cubic-bezier(.16,1,.3,1)}.dfb-list-checkbox.checked{background:#445def;border-color:#445def;animation:dfb-check-bounce .35s cubic-bezier(.34,1.56,.64,1)}@keyframes dfb-check-bounce{0%{transform:scale(.6)}50%{transform:scale(1.15)}to{transform:scale(1)}}.dfb-list-empty{padding:24px;text-align:center;color:#7d808a;font-size:.8rem}.dfb-select-all{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 8px;border-bottom:1px solid oklch(.94 .006 270)}.dfb-select-all-btn{border:none;background:none;font-size:.72rem;font-weight:550;color:#3e55c8;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s ease}.dfb-select-all-btn:hover{background:#e8eeff;background:oklch(.95 .04 270)}.dfb-select-count-label{font-size:.7rem;color:#7d808a}.dfb-presets-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.dfb-preset-chip{padding:9px 6px;border-radius:10px;border:1.5px solid oklch(.9 .01 270);background:#f7f8fa;font-size:.78rem;font-weight:500;color:#515561;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);text-align:center;position:relative;overflow:hidden}.dfb-preset-chip:after{content:"";position:absolute;inset:0;background:#445def0f;opacity:0;transition:opacity .2s ease}.dfb-preset-chip:hover:after{opacity:1}.dfb-preset-chip:hover{border-color:#819ae9;transform:translateY(-1px)}.dfb-preset-chip.active{border-color:#445def;background:#445def;color:#fff;font-weight:600;transform:translateY(-1px);box-shadow:0 4px 12px #445def40}.dfb-preset-chip.active:after{display:none}.dfb-date-range{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;margin-top:12px;padding:14px;border-radius:12px;background:#f4f5f9;border:1px solid oklch(.92 .01 270);animation:dfb-section-enter .3s cubic-bezier(.16,1,.3,1)}.dfb-date-pair{display:flex;gap:6px}.dfb-date-select{flex:1;padding:8px 28px 8px 10px;border-radius:8px;border:1px solid oklch(.88 .01 270);font-size:.78rem;color:#1e212b;background:#fff;cursor:pointer;outline:none;transition:all .2s ease;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%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 10px center}.dfb-date-select:focus{border-color:#445def;box-shadow:0 0 0 3px #4761e414}.dfb-date-separator{font-size:.75rem;font-weight:500;color:#7b808d;text-align:center}.dfb-status-control{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-radius:12px;background:#f0f2f5;border:1px solid oklch(.9 .01 270);padding:4px;position:relative}.dfb-status-btn{padding:10px 8px;border:none;border-radius:9px;background:transparent;font-size:.8rem;font-weight:500;color:#5f636f;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);z-index:1;text-align:center}.dfb-status-btn:hover:not(.active){color:#363a45;background:#f7f8fc}.dfb-status-btn.active{background:#445def;color:#fff;font-weight:600;box-shadow:0 2px 8px #445def33}.dfb-modal-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid oklch(.92 .01 270);background:#f7f8fa}.dfb-footer-info{font-size:.78rem;color:#5f636f}.dfb-footer-info strong{font-weight:650;color:#1f2d87}.dfb-footer-actions{display:flex;gap:10px}.dfb-btn-clear{padding:9px 18px;border-radius:10px;border:1px solid oklch(.9 .01 270);background:#f7f8fa;font-size:.82rem;font-weight:550;color:#515561;cursor:pointer;transition:all .2s ease}.dfb-btn-clear:hover{border-color:#ed7477;color:#bb061e;background:#fff1f0;background:oklch(.97 .02 25)}.dfb-btn-apply{padding:9px 22px;border-radius:10px;border:none;background:#445def;font-size:.82rem;font-weight:600;color:#fff;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #445def33}.dfb-btn-apply:hover{background:#3646e8;transform:translateY(-1px);box-shadow:0 4px 16px #445def4d}.dfb-btn-apply:active{transform:translateY(0)}.dfb-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media(max-width:640px){.dfb-overlay{padding:0;align-items:flex-end}.dfb-modal{max-width:100%;max-height:88vh;border-radius:24px 24px 0 0;animation:dfb-modal-slide-up .4s cubic-bezier(.16,1,.3,1)}@keyframes dfb-modal-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.dfb-overlay.closing .dfb-modal{animation:dfb-modal-slide-down .25s cubic-bezier(.4,0,1,1) forwards}@keyframes dfb-modal-slide-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}.dfb-modal-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;border-radius:2px;background:#c1c4cb}.dfb-modal-header{padding-top:24px;position:relative}.dfb-row-2col{grid-template-columns:1fr}.dfb-presets-grid{grid-template-columns:repeat(3,1fr)}.dfb-active-pills{display:none}}[data-theme=dark] .dfb-trigger{background:#181a22;border-color:#2f333d;color:#b8bdcb}[data-theme=dark] .dfb-trigger.has-filters{background:#1a2135;border-color:#364ba7}[data-theme=dark] .dfb-overlay{background:#02030999}[data-theme=dark] .dfb-modal{background:#0f1118;border-color:#252933;box-shadow:0 24px 80px #00000280}[data-theme=dark] .dfb-modal-header{border-color:#1f2129}[data-theme=dark] .dfb-modal-title h2{color:#e3e4e8}[data-theme=dark] .dfb-modal-title p{color:#7d808a}[data-theme=dark] .dfb-modal-close{background:#1a1d24;border-color:#2b2e36;color:#8b8f99}[data-theme=dark] .dfb-list-wrapper{background:#14161c;border-color:#2b2e36}[data-theme=dark] .dfb-list-search input{color:#dddee1}[data-theme=dark] .dfb-list-item{color:#c1c4cb}[data-theme=dark] .dfb-list-item:hover{background:#1b1f29}[data-theme=dark] .dfb-list-item.selected{background:#1a2135}[data-theme=dark] .dfb-preset-chip{background:#181a22;border-color:#2f333d;color:#aaaeb8}[data-theme=dark] .dfb-preset-chip:hover{border-color:#40518d}[data-theme=dark] .dfb-status-control{background:#14161c;border-color:#262930}[data-theme=dark] .dfb-status-btn{color:#8b8f99}[data-theme=dark] .dfb-modal-footer{background:#0d0f15;border-color:#1f2129}[data-theme=dark] .dfb-date-range{background:#14161c;border-color:#262930}[data-theme=dark] .dfb-date-select{background:#181a22;border-color:#2f333d;color:#cbced3}[data-theme=dark] .dfb-pill{background:#1a2135;border-color:#303955;color:#a4bbff}[data-theme=dark] .dfb-btn-clear{background:#181a22;border-color:#2f333d;color:#9b9ea8}[data-theme=dark] .dfb-section-label{color:#7d808a}[data-theme=dark] .dfb-list-checkbox{border-color:#434753}.tour-engine{position:fixed;inset:0;z-index:10000;pointer-events:none;font-family:var(--font-family, "Inter", system-ui, -apple-system, sans-serif);-webkit-font-smoothing:antialiased}.tour-welcome-backdrop{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;background:#0f172a73;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:auto}.tour-welcome-modal{position:relative;width:440px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);overflow-y:auto;padding:0;border-radius:var(--border-radius-xl, 24px);background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e2e8f0);box-shadow:0 24px 64px #0000001f,0 8px 24px #00000014,0 0 0 1px #0000000a}.tour-welcome-body{padding:1.75rem 1.75rem 1.5rem}.tour-welcome-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .75rem;border-radius:20px;background:#1e73be14;font-size:.72rem;font-weight:600;color:var(--brand-primary, var(--color-primary, #1e73be));letter-spacing:.03em;text-transform:uppercase;margin-bottom:1rem}.tour-welcome-title{font-size:1.35rem;font-weight:700;color:var(--text-primary, #1e293b);line-height:1.3;margin:0 0 .375rem;letter-spacing:-.02em;font-family:var(--font-heading, var(--font-family))}.tour-welcome-subtitle{font-size:.85rem;color:var(--text-secondary, #475569);line-height:1.6;margin:0 0 1.25rem}.tour-welcome-features{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.tour-welcome-feature{display:flex;align-items:center;gap:.75rem;padding:.625rem .75rem;border-radius:var(--border-radius-md, 10px);background:var(--bg-primary, #f0f7ff);border:1px solid transparent;transition:border-color .2s ease,background .2s ease}.tour-welcome-feature:hover{border-color:var(--border-color, #e2e8f0);background:var(--bg-hover, #ebf4ff)}.tour-welcome-feature-icon{font-size:1.2rem;flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm, 6px);background:var(--bg-card, #ffffff);box-shadow:var(--shadow-sm, 0 1px 2px rgba(0, 0, 0, .05))}.tour-welcome-feature-text{display:flex;flex-direction:column;gap:.0625rem}.tour-welcome-feature-label{font-size:.82rem;font-weight:600;color:var(--text-primary, #1e293b)}.tour-welcome-feature-desc{font-size:.72rem;color:var(--text-muted, #94a3b8);line-height:1.4}.tour-welcome-actions{display:flex;flex-direction:column;align-items:stretch;gap:.375rem}.tour-welcome-actions .tour-btn-primary{width:100%;padding:.75rem;font-size:.875rem}.tour-welcome-actions .tour-btn-skip{text-align:center;padding:.5rem}.tour-completion{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;background:#0f172a73;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:auto}.tour-completion-content{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:420px;padding:2.5rem 2rem;border-radius:var(--border-radius-xl, 24px);background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e2e8f0);box-shadow:0 24px 64px #0000001f,0 8px 24px #00000014}.tour-completion-icon{font-size:3rem;margin-bottom:1rem}.tour-completion-title{font-size:1.5rem;font-weight:700;color:var(--text-primary, #1e293b);margin:0 0 .5rem;letter-spacing:-.02em;font-family:var(--font-heading, var(--font-family))}.tour-completion-description{font-size:.875rem;color:var(--text-secondary, #475569);line-height:1.6;margin:0 0 1.5rem}.tour-tooltip{width:360px;max-width:calc(100vw - 32px);padding:1.125rem;border-radius:var(--border-radius-lg, 16px);background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e2e8f0);box-shadow:0 20px 50px #0000001f,0 8px 20px #0000000f,0 0 0 1px #0000000a;z-index:10001}.tour-tooltip-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.375rem}.tour-tooltip-icon{font-size:1.35rem;flex-shrink:0}.tour-tooltip-title{font-size:.95rem;font-weight:650;color:var(--text-primary, #1e293b);margin:0;letter-spacing:-.01em;font-family:var(--font-heading, var(--font-family))}.tour-tooltip-description{font-size:.82rem;color:var(--text-secondary, #475569);line-height:1.6;margin:0 0 .875rem}.tour-tooltip-actions{display:flex;align-items:center;justify-content:space-between}.tour-tooltip-nav{display:flex;align-items:center;gap:.5rem}.tour-interactive-hint{display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;color:var(--brand-primary, var(--color-primary, #1e73be));padding:.4rem .875rem;border-radius:var(--border-radius-md, 10px);background:#1e73be0f;border:1px solid rgba(30,115,190,.15)}.tour-interactive-dot{width:7px;height:7px;border-radius:50%;background:var(--brand-primary, var(--color-primary, #1e73be));animation:tour-pulse-dot 1.5s ease-in-out infinite}@keyframes tour-pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}.tour-progress{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.tour-progress-bar{flex:1;height:3px;border-radius:3px;background:var(--bg-tertiary, #e8f1fc);overflow:hidden}.tour-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--brand-primary, var(--color-primary, #1e73be)),var(--brand-secondary, #3b82f6))}.tour-progress-text{font-size:.65rem;font-weight:600;color:var(--text-muted, #94a3b8);white-space:nowrap;letter-spacing:.04em;text-transform:uppercase}.tour-btn-primary{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1.25rem;font-size:.82rem;font-weight:600;color:#fff;background:var(--brand-primary, var(--color-primary, #1e73be));border:none;border-radius:var(--border-radius-md, 10px);cursor:pointer;transition:all .2s ease;letter-spacing:.01em;font-family:inherit}.tour-btn-primary:hover{background:var(--brand-primary, var(--color-primary-hover, #3b8fd4));filter:brightness(1.08);box-shadow:0 4px 12px #1e73be40;transform:translateY(-1px)}.tour-btn-primary:active{transform:translateY(0);filter:brightness(.95)}.tour-btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.4rem .75rem;font-size:.78rem;font-weight:500;color:var(--text-secondary, #475569);background:var(--bg-primary, #f0f7ff);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--border-radius-sm, 6px);cursor:pointer;transition:all .2s ease;font-family:inherit}.tour-btn-secondary:hover{color:var(--text-primary, #1e293b);background:var(--bg-hover, #ebf4ff);border-color:var(--border-color, #e2e8f0)}.tour-btn-skip{background:none;border:none;color:var(--text-muted, #94a3b8);font-size:.78rem;font-weight:500;cursor:pointer;padding:.35rem .5rem;transition:color .2s ease;font-family:inherit}.tour-btn-skip:hover{color:var(--text-secondary, #475569)}.tour-btn-pulse{animation:tour-btn-pulse 2.5s ease-in-out infinite}@keyframes tour-btn-pulse{0%,to{box-shadow:0 0 #1e73be4d}50%{box-shadow:0 0 0 10px #1e73be00}}.tour-btn-glow{animation:tour-btn-glow 3s ease-in-out infinite}@keyframes tour-btn-glow{0%,to{box-shadow:0 2px 12px #10b98126}50%{box-shadow:0 4px 24px #10b9814d}}.tour-confetti-particle{animation:tour-confetti-fall linear forwards}@keyframes tour-confetti-fall{0%{transform:translateY(0) rotate(0) scale(1);opacity:1}25%{opacity:1}to{transform:translateY(100vh) rotate(720deg) scale(.3);opacity:0}}.tour-spotlight-overlay{pointer-events:auto}@media(max-width:1023px){.tour-tooltip{position:fixed!important;inset:auto 16px 24px!important;width:auto;max-width:none;transform:none!important}.tour-welcome-modal{width:400px}}@media(max-width:768px){.tour-tooltip{bottom:0!important;left:0!important;right:0!important;border-radius:var(--border-radius-lg, 16px) var(--border-radius-lg, 16px) 0 0;padding:1.25rem 1rem calc(env(safe-area-inset-bottom,0px) + 1rem)}.tour-welcome-modal{width:100%;max-width:100%;border-radius:var(--border-radius-xl, 24px) var(--border-radius-xl, 24px) 0 0;margin-top:auto;max-height:85vh}.tour-welcome-backdrop{align-items:flex-end}.tour-welcome-title{font-size:1.15rem}.tour-completion-content{border-radius:var(--border-radius-xl, 24px) var(--border-radius-xl, 24px) 0 0;margin-top:auto;max-width:100%;width:100%}.tour-completion{align-items:flex-end}.tour-completion-title{font-size:1.25rem}}@media(prefers-reduced-motion:reduce){.tour-btn-pulse,.tour-btn-glow,.tour-interactive-dot,.tour-confetti-particle{animation:none!important}.tour-welcome-backdrop,.tour-welcome-modal,.tour-completion,.tour-completion-content,.tour-tooltip,.tour-spotlight-overlay,.tour-spotlight-hole{transition:none!important}}.web-editor{border:1px solid var(--border-color);border-radius:var(--border-radius-md);background-color:var(--bg-tertiary);overflow:hidden;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.web-editor:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e73be26;background-color:#fff}.web-editor__toolbar{display:flex;flex-wrap:wrap;gap:4px;padding:6px;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.web-editor__btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid transparent;border-radius:var(--border-radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background-color .12s,color .12s,border-color .12s}.web-editor__btn:hover{background-color:var(--bg-hover);color:var(--color-primary)}.web-editor__btn:active{transform:scale(.94)}.web-editor__btn.is-active{background-color:var(--bg-glass);border-color:var(--color-primary);color:var(--color-primary)}.web-editor .ProseMirror{min-height:150px;padding:var(--spacing-md);outline:none;color:var(--text-primary);font-size:var(--font-size-md);line-height:1.6}.web-editor .ProseMirror:focus{outline:none}.web-editor .ProseMirror>*+*{margin-top:.65em}.web-editor .ProseMirror h2{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.web-editor .ProseMirror h3{font-size:1.05rem;font-weight:700;color:var(--text-primary)}.web-editor .ProseMirror ul{list-style:disc;padding-left:1.25rem}.web-editor .ProseMirror ol{list-style:decimal;padding-left:1.25rem}.web-editor .ProseMirror blockquote{border-left:3px solid var(--color-primary);padding-left:.9rem;color:var(--text-secondary)}.web-editor .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-muted);float:left;height:0;pointer-events:none}.web-editor__hint{font-size:.72rem;color:var(--text-muted);margin-top:6px}
