*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--color-surface-subtle);color:var(--color-text-primary)}.container{max-width:1200px;margin:0 auto;padding:2rem}header{margin-bottom:3rem}.header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.header-content>div:first-child{text-align:left}.header-actions{display:flex;align-items:center;gap:1rem}.user-info{color:var(--color-text-secondary);font-size:.95rem}.logout-button{padding:.5rem 1rem;background-color:var(--color-error);color:var(--color-text-primary);border:none;border-radius:var(--radius-base);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.logout-button:hover{background-color:var(--color-error);transform:translateY(-1px);box-shadow:0 2px 4px var(--color-error)}.logout-button:active{transform:translateY(0)}.gallery-button{padding:.5rem 1rem;background-color:var(--color-brand-primary);color:var(--color-text-primary);border:none;border-radius:var(--radius-base);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.gallery-button:hover{background-color:var(--color-info);transform:translateY(-1px);box-shadow:0 2px 4px var(--color-info)}.gallery-button:active{transform:translateY(0)}h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--color-text-primary)}.subtitle{font-size:1.1rem;color:var(--color-text-secondary)}section{margin-bottom:3rem}h2{font-size:1.5rem;margin-bottom:1rem;color:var(--color-text-secondary)}.tools-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.tool-card{background:var(--color-surface-default);border-radius:var(--radius-md);padding:1.5rem;box-shadow:0 2px 4px var(--color-bg-overlay);transition:transform .2s,box-shadow .2s}.tool-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px var(--color-bg-overlay)}.tool-card.clickable{cursor:pointer}.tool-card.clickable:hover{border:2px solid var(--color-brand-primary);transform:translateY(-2px);box-shadow:0 4px 8px var(--color-info-bg)}.tool-card h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--color-text-primary);font-family:Monaco,Courier New,monospace}.description{color:var(--color-text-secondary);line-height:1.5;margin-bottom:1rem;font-size:.95rem}.meta{display:flex;gap:1rem;font-size:.9rem}.cost{color:var(--color-success);font-weight:600}.time{color:var(--color-text-secondary)}.error{color:var(--color-error);padding:1rem;background:var(--color-error-bg);border-radius:var(--radius-sm)}p{line-height:1.6}.composer-back-button{position:fixed;top:1rem;right:1rem;padding:.75rem 1.5rem;background:var(--color-surface-default);color:var(--color-brand-primary);border:2px solid var(--color-brand-primary);border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;z-index:1000;box-shadow:0 2px 8px var(--color-bg-overlay)}.composer-back-button:hover{background:var(--color-brand-primary);color:var(--color-text-primary);transform:translateY(-1px);box-shadow:0 4px 12px var(--color-info)}.tool-card.featured{background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);color:var(--color-text-primary);position:relative;overflow:hidden}.tool-card.featured h3,.tool-card.featured .description{color:var(--color-text-primary)}.tool-card.featured:hover{transform:translateY(-4px);box-shadow:0 8px 16px var(--color-brand-primary-bg)}.new-badge{position:absolute;top:1rem;right:1rem;background:var(--color-success);color:var(--color-text-primary);font-size:.7rem;font-weight:700;padding:.25rem .75rem;border-radius:var(--radius-lg);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px var(--color-border-strong)}@media (max-width: 768px){button,.button,a.button{min-height:44px;min-width:44px}.container{padding:1rem}.logout-button,.gallery-button{padding:.75rem 1.25rem;min-height:44px;font-size:1rem}.composer-back-button{min-height:44px;padding:1rem 1.5rem;font-size:1rem;bottom:1rem;right:1rem}.tool-card.clickable{min-height:120px}h1{font-size:2rem}h2{font-size:1.25rem}.tools-list{grid-template-columns:1fr;gap:1rem}}.ui-toast{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-surface-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:320px;max-width:420px;animation:ui-toast-slide-in .3s ease-out;position:relative}@keyframes ui-toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.ui-toast--success{border-left:4px solid var(--color-success)}.ui-toast--error{border-left:4px solid var(--color-error)}.ui-toast--warning{border-left:4px solid var(--color-warning)}.ui-toast--info{border-left:4px solid var(--color-info)}.ui-toast__icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:var(--font-bold);border-radius:var(--radius-full)}.ui-toast--success .ui-toast__icon{background:var(--color-success-bg);color:var(--color-success)}.ui-toast--error .ui-toast__icon{background:var(--color-error-bg);color:var(--color-error)}.ui-toast--warning .ui-toast__icon{background:var(--color-warning-bg);color:var(--color-warning)}.ui-toast--info .ui-toast__icon{background:var(--color-info-bg);color:var(--color-info)}.ui-toast__content{flex:1;min-width:0}.ui-toast__message{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-primary);margin:0;line-height:var(--leading-tight)}.ui-toast__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1);line-height:var(--leading-normal)}.ui-toast__close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-tertiary);font-size:var(--text-xl);line-height:1;cursor:pointer;transition:all var(--transition-base)}.ui-toast__close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.ui-toast__close:focus{outline:2px solid var(--color-brand-primary);outline-offset:2px}@media (max-width: 768px){.ui-toast{min-width:280px;max-width:calc(100vw - var(--spacing-8))}}.ui-toast-container{position:fixed;top:var(--spacing-6);right:var(--spacing-6);z-index:9999;display:flex;flex-direction:column;gap:var(--spacing-3);pointer-events:none}.ui-toast-container>*{pointer-events:auto}@media (max-width: 768px){.ui-toast-container{top:var(--spacing-4);right:var(--spacing-4);left:var(--spacing-4)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);padding:1rem}.login-card{background:var(--color-surface-default);border-radius:var(--radius-lg);box-shadow:0 10px 40px var(--color-bg-overlay);padding:2.5rem;width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2.5rem;margin:0 0 .5rem;color:var(--color-text-primary)}.login-subtitle{color:var(--color-text-secondary);font-size:1rem;margin:0}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-card .form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.login-card .form-group label{font-weight:600;color:var(--color-text-primary)!important;font-size:.875rem;display:block}.login-card .form-group input{padding:.75rem;border:2px solid var(--color-border-default)!important;border-radius:var(--radius-md);font-size:1rem;transition:all .2s;background-color:var(--color-bg-primary)!important;color:var(--color-text-primary)!important;-webkit-text-fill-color:var(--color-text-primary)!important;display:block!important;width:100%!important;box-sizing:border-box!important}.login-card .form-group input::placeholder{color:var(--color-text-tertiary)!important;opacity:1!important}.login-card .form-group input:focus{outline:none;border-color:var(--color-brand-primary);box-shadow:0 0 0 3px var(--color-brand-primary-bg)}.login-card .form-group input:disabled{background-color:var(--color-surface-subtle)!important;cursor:not-allowed}.login-card .form-group input:-webkit-autofill,.login-card .form-group input:-webkit-autofill:hover,.login-card .form-group input:-webkit-autofill:focus,.login-card .form-group input:-webkit-autofill:active{-webkit-text-fill-color:var(--color-text-primary)!important;-webkit-box-shadow:0 0 0 30px var(--color-bg-primary) inset!important;box-shadow:0 0 0 30px var(--color-bg-primary) inset!important;background-color:var(--color-bg-primary)!important}.login-card .form-group input[type=password]{color:var(--color-text-primary)!important;-webkit-text-fill-color:var(--color-text-primary)!important;background-color:var(--color-bg-primary)!important;display:block!important;width:100%!important;visibility:visible!important;opacity:1!important;border:2px solid var(--color-border-default)!important}input#password{color:var(--color-text-primary)!important;-webkit-text-fill-color:var(--color-text-primary)!important;background-color:var(--color-bg-primary)!important}.error-message{background-color:var(--color-error-bg);border:1px solid var(--color-error-bg);color:var(--color-error);padding:.75rem;border-radius:var(--radius-md);font-size:.875rem}.login-button{background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);color:var(--color-text-primary);padding:.875rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px var(--color-brand-primary-bg)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}.login-footer{margin-top:1.5rem;text-align:center}.login-hint{color:var(--color-text-secondary);font-size:.875rem;margin:0}.theme-toggle{position:relative;display:inline-block}.theme-toggle-button{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface-default, rgba(255, 255, 255, .1));border:1px solid var(--color-border-default, var(--color-border-strong));border-radius:var(--radius-md, 8px);color:var(--color-text-primary, white);font-size:.875rem;cursor:pointer;transition:all var(--transition-base, .2s);min-height:44px}.theme-toggle-button:hover{background:var(--color-surface-hover, rgba(255, 255, 255, .15));border-color:var(--color-border-strong, rgba(255, 255, 255, .3))}.theme-toggle-button:active{background:var(--color-surface-active, var(--color-border-strong))}.theme-icon{font-size:1.125rem;line-height:1}.theme-label{font-weight:500}.theme-chevron{font-size:.625rem;transition:transform var(--transition-fast, .15s)}.theme-chevron.open{transform:rotate(180deg)}.theme-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:160px;background:var(--color-bg-elevated, var(--color-bg-elevated));border:1px solid var(--color-border-default, var(--color-border-strong));border-radius:var(--radius-md, 8px);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));overflow:hidden;z-index:var(--z-dropdown, 100);animation:slideDown .15s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.theme-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--color-text-primary, white);font-size:.875rem;text-align:left;cursor:pointer;transition:background var(--transition-fast, .15s);min-height:44px}.theme-option:hover{background:var(--color-surface-hover, var(--color-border-subtle))}.theme-option.active{background:var(--color-surface-active, rgba(102, 126, 234, .15));color:var(--color-brand-primary, var(--color-brand-primary))}.theme-option-icon{font-size:1.125rem;line-height:1}.theme-option-label{flex:1;font-weight:500}.theme-checkmark{font-size:.875rem;font-weight:600;color:var(--color-brand-primary, var(--color-brand-primary))}@media (max-width: 768px){.theme-toggle-button{padding:.625rem .875rem}.theme-dropdown{min-width:140px}.theme-option{padding:.875rem 1rem}}@media (max-width: 480px){.theme-label{display:none}.theme-toggle-button{padding:.625rem}}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;background:var(--color-bg-secondary);color:var(--color-text-primary);overflow-x:hidden;overflow-y:auto;transition:transform .3s ease;z-index:1000;box-shadow:2px 0 10px #0000004d}.sidebar-header{padding:.75rem 1rem;border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:space-between}.sidebar-header h2{margin:0;font-size:1.25rem;font-weight:600;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.version-number{font-size:.625rem;font-weight:600;opacity:.7}.sidebar-close{display:none;background:none;border:none;color:var(--color-text-primary);font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;line-height:1;transition:transform .2s}.sidebar-close:hover{transform:rotate(90deg)}.sidebar-nav{padding:.5rem 0}.nav-section{margin-bottom:.25rem}.nav-section-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem .5rem .75rem;background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:.8rem;font-weight:500;transition:all .15s;border-radius:var(--radius-base);margin:0 .5rem}.nav-section-header:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.nav-section-title{display:flex;align-items:center;gap:.5rem}.nav-section-icon{font-size:1rem}.nav-section-toggle{font-size:.7rem;transition:transform .2s}.nav-section-toggle.collapsed{transform:rotate(-90deg)}.nav-section-content{margin-top:.25rem}.nav-link{display:flex;align-items:center;gap:.625rem;padding:.5rem 1rem .5rem .75rem;margin:0 .5rem;color:var(--color-text-secondary);text-decoration:none;transition:all .15s;position:relative;border-radius:var(--radius-base);font-size:.875rem}.nav-link:hover{background:var(--color-border-subtle);color:var(--color-text-primary)}.nav-link.active{background:var(--color-brand-primary);color:var(--color-text-primary)}.nav-icon{font-size:1.1rem;width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-label{flex:1;font-size:.875rem}.nav-badge{font-size:.7rem;padding:.2rem .5rem;border-radius:10px;background:var(--color-brand-primary-bg);color:var(--color-brand-primary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.nav-badge.new{background:var(--color-success-bg);color:var(--color-success)}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px}.sidebar.open{transform:translate(0)}.sidebar-close{display:block;min-width:44px;min-height:44px}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg-overlay);z-index:999}.nav-section-header{min-height:44px;padding:.75rem 1rem .75rem .75rem;font-size:.85rem}.nav-subsection-header{min-height:44px;padding:.75rem 1rem .75rem 1.5rem}.nav-link{min-height:44px;padding:.75rem 1rem .75rem .75rem;font-size:.9rem}.nav-link-nested{min-height:44px;padding-left:2.5rem}.nav-link-sibling{min-height:44px;padding-left:1.5rem}.nav-icon{font-size:1.25rem;width:24px}.nav-section-icon{font-size:1.1rem}}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:var(--color-surface-subtle);margin:4px 0}.sidebar::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm);border:2px solid transparent;background-clip:content-box}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--color-border-default);background-clip:content-box}.nav-subsection{margin:.25rem 0}.nav-subsection-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.375rem 1rem .375rem 1.5rem;background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:.75rem;font-weight:500;transition:all .15s;border-radius:var(--radius-base);margin:0 .5rem;text-align:left}.nav-subsection-header:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.nav-subsection-title{display:flex;align-items:center;gap:.5rem;flex:1}.nav-subsection-label{flex:1}.nav-subsection-toggle{font-size:.6rem;transition:transform .2s;margin-left:.5rem}.nav-subsection-toggle.collapsed{transform:rotate(-90deg)}.nav-subsection-content{margin-top:.25rem;padding-left:0}.nav-link-sub{padding-left:2.25rem;font-size:.875rem}.nav-link-sub .nav-icon{font-size:1rem;width:18px}.nav-link-nested{padding-left:2.75rem;font-size:.85rem}.nav-link-nested .nav-icon{font-size:1rem;width:18px}.nav-link-sibling{padding-left:1.5rem}.nav-divider{height:1px;background:var(--color-border-subtle);margin:.75rem 1rem}.nav-group-label{padding:.5rem 1.25rem .25rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-tertiary)}.sidebar-system-controls{margin-top:var(--spacing-4);padding:0 .5rem;display:flex;flex-direction:column;gap:var(--spacing-3)}.sidebar-divider{height:1px;background:var(--color-border-subtle);margin:var(--spacing-2) 0}.sidebar-user-info{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-surface-hover);border-radius:var(--radius-md)}.sidebar-user-icon{font-size:var(--text-lg)}.sidebar-user-name{color:var(--color-text-primary);font-size:var(--text-sm);font-weight:var(--font-medium)}.sidebar-logout-button{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast);width:100%}.sidebar-logout-button:hover{background:var(--color-error);color:var(--color-text-primary);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.sidebar-logout-icon{font-size:var(--text-base)}.sidebar-logout-label{flex:1;text-align:left}.nav-link-primary{margin:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);border-radius:var(--radius-md);color:#fff!important;font-weight:600;font-size:1rem;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.nav-link-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003;filter:brightness(1.1)}.nav-link-primary.active{background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%)}.nav-link-primary .nav-icon{font-size:1.25rem}@media (max-width: 768px){.sidebar-system-controls{gap:var(--spacing-2)}.sidebar-logout-button{min-height:44px}.nav-link-primary{min-height:50px}}.task-manager-button{position:fixed;bottom:2rem;right:2rem;width:60px;height:60px;border-radius:var(--radius-full);border:none;cursor:pointer;font-size:1.5rem;box-shadow:0 4px 12px #00000026;transition:all .3s ease;z-index:1000;display:flex;align-items:center;justify-content:center}.task-manager-button.idle{background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);color:var(--color-surface-default)}.task-manager-button.running{background:linear-gradient(135deg,#4facfe,#00f2fe);color:var(--color-surface-default);animation:pulse 2s infinite}.task-manager-button.failed{background:linear-gradient(135deg,#f093fb,#f5576c);color:var(--color-surface-default)}.task-manager-button.awaiting-brief{background:linear-gradient(135deg,orange,tomato);color:var(--color-surface-default);animation:pulse-brief 1.5s infinite}@keyframes pulse-brief{0%,to{box-shadow:0 4px 12px #00000026}50%{box-shadow:0 4px 24px #ffa50099}}.task-manager-button:hover{transform:scale(1.1);box-shadow:0 6px 20px #00000040}@keyframes pulse{0%,to{box-shadow:0 4px 12px #00000026}50%{box-shadow:0 4px 24px #4facfe99}}.task-badge{position:absolute;top:-4px;right:-4px;background:#f44;color:var(--color-surface-default);border-radius:var(--radius-full);width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;border:2px solid white}.task-panel{position:fixed;bottom:6rem;right:2rem;width:400px;max-height:600px;background:var(--color-surface-default);border-radius:var(--radius-lg);box-shadow:0 8px 32px var(--color-border-strong);display:flex;flex-direction:column;z-index:999;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.task-panel-header{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-default);display:flex;justify-content:space-between;align-items:center}.task-panel-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.close-panel-button{background:none;border:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-base);transition:all .2s}.close-panel-button:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.task-filters{display:flex;padding:.5rem 1rem;border-bottom:1px solid var(--color-border-default);gap:.5rem}.filter-tab{padding:.5rem 1rem;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;border-radius:var(--radius-base);transition:all .2s}.filter-tab:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.filter-tab.active{background:#e0e7ff;color:#4338ca}.task-list{flex:1;overflow-y:auto;padding:.5rem}.no-tasks{padding:3rem 1rem;text-align:center;color:var(--color-text-tertiary);font-size:.875rem}.task-item{background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-md);margin-bottom:.5rem;overflow:hidden;transition:all .2s}.task-item:hover{border-color:var(--color-border-default);box-shadow:0 2px 8px var(--color-border-subtle)}.task-item.running{border-left:3px solid var(--color-brand-primary)}.task-item.completed{border-left:3px solid var(--color-success);opacity:.7}.task-item.failed,.task-item.cancelled{border-left:3px solid var(--color-error)}.task-item.awaiting_user_input{border-left:3px solid #ffa500;background:linear-gradient(to right,rgba(255,165,0,.05),transparent)}.task-item-header{padding:.75rem;display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.task-status-icon{font-size:1.25rem;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.task-item.running .task-status-icon{animation:spin 1s linear infinite}.task-info{flex:1;min-width:0}.task-title{font-weight:500;color:var(--color-text-primary);font-size:.875rem;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-description{font-size:.8125rem;color:var(--color-text-secondary);margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-meta{font-size:.75rem;color:var(--color-text-secondary)}.task-progress-msg{display:block;font-style:italic}.task-time{display:block}.task-actions{display:flex;gap:.5rem;flex-shrink:0}.task-action-btn{padding:.25rem .75rem;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s;font-weight:500}.task-action-btn.cancel{background:var(--color-error-bg);color:var(--color-error)}.task-action-btn.cancel:hover{background:var(--color-error-bg)}.task-action-btn.dismiss{background:var(--color-surface-subtle);color:var(--color-text-secondary);width:24px;height:24px;padding:0;font-size:1rem;line-height:1}.task-action-btn.dismiss:hover{background:var(--color-border-default);color:var(--color-text-primary)}.task-progress-container{padding:0 .75rem .75rem;position:relative}.task-progress-bar{height:4px;background:linear-gradient(90deg,var(--color-brand-primary) 0%,var(--color-info) 100%);border-radius:2px;transition:width .3s ease;position:relative}.task-progress-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.task-progress-text{font-size:.75rem;color:var(--color-text-secondary);margin-top:.25rem}.task-details{padding:.75rem;background:var(--color-surface-subtle);border-top:1px solid var(--color-border-default);font-size:.8125rem}.task-detail-item{margin-bottom:.5rem}.task-detail-item:last-child{margin-bottom:0}.task-detail-item strong{display:block;color:var(--color-text-secondary);margin-bottom:.25rem}.task-detail-item.error{color:var(--color-error);background:var(--color-error-bg);padding:.5rem;border-radius:var(--radius-sm)}.task-detail-item code{font-family:monospace;font-size:.75rem;color:var(--color-text-secondary);background:var(--color-surface-default);padding:.125rem .25rem;border-radius:3px;border:1px solid var(--color-border-default)}.task-detail-item ul{margin:.25rem 0 0;padding-left:1.5rem;color:var(--color-text-secondary)}.task-detail-item li{margin:.25rem 0}@media (max-width: 768px){.task-panel{right:1rem;left:1rem;width:auto;bottom:5rem;max-height:calc(100vh - 10rem)}.task-manager-button{right:1rem;bottom:1.5rem}.filter-tab{min-height:44px;padding:.75rem 1rem;font-size:.9rem}.task-action-btn{min-height:36px;min-width:36px;padding:.5rem 1rem}.task-action-btn.dismiss{min-width:36px;min-height:36px}.close-panel-button{min-width:44px;min-height:44px}.task-item-header{padding:1rem;min-height:60px}}@media (max-width: 480px){.task-panel{bottom:4.5rem;max-height:calc(100vh - 8rem)}.task-manager-button{width:56px;height:56px;right:1rem;bottom:1rem}.task-badge{width:20px;height:20px;font-size:.7rem}}.task-brief-container{margin:.75rem 0;padding:0}.task-child-jobs-container{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.task-item[style*=margin-left]{opacity:.95}.task-item[style*=margin-left]:hover{opacity:1}.generic-brief{padding:var(--spacing-4);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border-default)}.brief-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.brief-header h4{margin:0;color:var(--color-text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold)}.brief-type-badge{font-size:var(--text-sm);padding:var(--spacing-1) var(--spacing-2);background:var(--color-surface-subtle);border-radius:var(--radius-base);color:var(--color-text-secondary)}.brief-message{margin-bottom:var(--spacing-4)}.brief-message p{margin:0 0 var(--spacing-2) 0;color:var(--color-text-secondary);line-height:1.5}.brief-data{margin:var(--spacing-4) 0}.brief-data h5{margin:0 0 var(--spacing-2) 0;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium)}.brief-data pre{padding:var(--spacing-4);background:var(--color-bg-tertiary);border-radius:var(--radius-base);border:1px solid var(--color-border-default);color:var(--color-success);font-size:var(--text-sm);overflow-x:auto;max-height:300px;overflow-y:auto}.brief-actions{display:flex;gap:var(--spacing-3);margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-default)}.brief-actions button{flex:1;padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);border:none;cursor:pointer;font-weight:var(--font-semibold);font-size:var(--text-base);transition:all var(--transition-base)}.brief-actions button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-success);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-surface-subtle);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-hover)}.btn-danger{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover:not(:disabled){background:var(--color-error);color:var(--color-text-inverse)}.clothing-items-review-brief{padding:var(--spacing-4);background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border-default);max-height:80vh;overflow-y:auto}.source-image-preview{margin:var(--spacing-4) 0;padding:var(--spacing-4);background:var(--color-bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--color-border-default)}.source-image-preview h5{margin:0 0 var(--spacing-3) 0;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.05em}.source-image{width:100%;max-width:600px;height:auto;border-radius:var(--radius-md);border:1px solid var(--color-border-default);display:block;margin:0 auto}.clothing-items-review-brief .brief-header{padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-default)}.clothing-items-review-brief .brief-header h4{color:var(--color-text-primary)}.item-count{font-size:var(--text-sm);padding:var(--spacing-1) var(--spacing-3);background:var(--color-success-bg);border-radius:var(--radius-full);color:var(--color-success);font-weight:var(--font-medium)}.outfit-name{font-style:italic;color:var(--color-text-tertiary)}.selection-controls{display:flex;gap:var(--spacing-2);align-items:center;margin:var(--spacing-4) 0;padding:var(--spacing-3);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.btn-select{padding:var(--spacing-2) var(--spacing-3);background:var(--color-surface-subtle);border:1px solid var(--color-border-default);border-radius:var(--radius-base);color:var(--color-text-primary);cursor:pointer;font-size:var(--text-sm);transition:all var(--transition-base)}.btn-select:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-strong)}.btn-select:disabled{opacity:.5;cursor:not-allowed}.selection-count{margin-left:auto;font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--font-medium)}.items-list{display:flex;flex-direction:column;gap:var(--spacing-3);margin:var(--spacing-4) 0;max-height:500px;overflow-y:auto;padding-right:var(--spacing-2)}.item-card{padding:var(--spacing-4);background:var(--color-bg-tertiary);border:2px solid var(--color-border-default);border-radius:var(--radius-lg);transition:all var(--transition-base)}.item-card:hover{border-color:var(--color-border-strong)}.item-card.selected{border-color:var(--color-success);background:var(--color-success-bg)}.item-header{display:flex;gap:var(--spacing-3);align-items:flex-start;margin-bottom:var(--spacing-3)}.item-header input[type=checkbox]{margin-top:var(--spacing-1);width:18px;height:18px;cursor:pointer;flex-shrink:0}.item-title{flex:1;display:flex;gap:var(--spacing-2);align-items:center;flex-wrap:wrap}.item-title strong{color:var(--color-text-primary);font-size:var(--text-base);font-weight:var(--font-semibold)}.category-badge{font-size:var(--text-xs);padding:var(--spacing-1) var(--spacing-2);background:var(--color-brand-primary);border-radius:var(--radius-base);color:var(--color-text-inverse);font-weight:var(--font-medium);text-transform:capitalize}.item-details{display:flex;flex-direction:column;gap:var(--spacing-2);padding-left:calc(18px + var(--spacing-3))}.detail-row{display:flex;gap:var(--spacing-2)}.detail-row.full-width{flex-direction:column}.detail-label{font-weight:var(--font-medium);color:var(--color-text-tertiary);min-width:60px;font-size:var(--text-sm)}.detail-value{color:var(--color-text-secondary);flex:1;font-size:var(--text-sm)}.detail-value p{margin:0;line-height:1.5}.brief-error{padding:var(--spacing-4);background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-lg);color:var(--color-error)}.brief-error p{margin:0 0 var(--spacing-2) 0}.brief-error pre{margin:var(--spacing-2) 0 0 0;padding:var(--spacing-2);background:var(--color-bg-tertiary);border-radius:var(--radius-base);font-size:var(--text-sm);overflow-x:auto;color:var(--color-text-secondary)}.job-hierarchy-toggle{cursor:pointer;color:var(--color-text-secondary);font-size:.75rem;padding:.25rem .4rem;border-radius:var(--radius-sm);transition:all .2s;-webkit-user-select:none;user-select:none;flex-shrink:0;margin-right:.25rem;display:inline-flex;align-items:center;justify-content:center}.job-hierarchy-toggle:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.job-hierarchy-toggle.loading{animation:spin 1s linear infinite;cursor:wait}.job-child-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .4rem;margin-left:.4rem;background:var(--color-brand-primary-bg);color:var(--color-brand-primary);border-radius:8px;font-size:.7rem;font-weight:600}.layout{display:flex;min-height:100vh;background:var(--color-bg-primary)}.layout-main{flex:1;margin-left:260px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .3s ease;position:relative}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:90;background:var(--color-brand-primary);border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.5rem;border-radius:var(--radius-md);line-height:1;transition:all .2s;box-shadow:var(--shadow-lg)}.mobile-menu-toggle:hover{transform:scale(1.1);background:var(--color-brand-hover)}.layout-content{flex:1;padding:2rem;padding-top:calc(60px + 2rem);overflow-x:hidden}@media (max-width: 768px){.layout-main{margin-left:0}.mobile-menu-toggle{display:block;min-width:44px;min-height:44px;font-size:1.75rem}.layout-content{padding:1rem;padding-top:calc(80px + 4rem)}}@media (max-width: 480px){.layout-content{padding:.75rem}.user-info span{display:none}}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);font-family:var(--font-sans);font-weight:var(--font-medium);text-align:center;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all var(--transition-base);border:none;text-decoration:none;-webkit-tap-highlight-color:transparent}.ui-button:focus{outline:none;box-shadow:0 0 0 3px var(--color-info-bg)}.ui-button:disabled{cursor:not-allowed;opacity:.6}.ui-button--sm{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm);border-radius:var(--radius-sm);min-height:32px}.ui-button--md{padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-base);border-radius:var(--radius-base);min-height:40px}.ui-button--lg{padding:var(--spacing-4) var(--spacing-8);font-size:var(--text-lg);border-radius:var(--radius-md);min-height:48px}.ui-button--full-width{width:100%}.ui-button--primary{background:var(--color-brand-primary);color:var(--color-text-inverse)}.ui-button--primary:hover:not(:disabled){background:var(--color-brand-hover)}.ui-button--primary:active:not(:disabled){background:var(--color-brand-active)}.ui-button--secondary{background:var(--color-surface-default);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.ui-button--secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-strong)}.ui-button--secondary:active:not(:disabled){background:var(--color-surface-active)}.ui-button--danger{background:var(--color-surface-default);color:var(--color-error);border:1px solid var(--color-error)}.ui-button--danger:hover:not(:disabled){background:var(--color-error);color:var(--color-text-inverse)}.ui-button--danger:active:not(:disabled){background:var(--color-error);opacity:.9}.ui-button--success{background:var(--color-success);color:var(--color-text-inverse)}.ui-button--success:hover:not(:disabled){background:var(--color-success);opacity:.9}.ui-button--success:active:not(:disabled){background:var(--color-success);opacity:.8}.ui-button--ghost{background:transparent;color:var(--color-brand-primary)}.ui-button--ghost:hover:not(:disabled){background:var(--color-surface-hover)}.ui-button--ghost:active:not(:disabled){background:var(--color-surface-active)}.ui-button--loading{position:relative;cursor:wait}.ui-button__content--loading{visibility:hidden}.ui-button__spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:var(--radius-full);animation:ui-button-spin .6s linear infinite}@keyframes ui-button-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.ui-button--sm.ui-button--icon{padding:var(--spacing-2);min-width:32px}.ui-button--md.ui-button--icon{padding:var(--spacing-3);min-width:40px}.ui-button--lg.ui-button--icon{padding:var(--spacing-4);min-width:48px}.ui-form-input{display:block;width:100%;font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-primary);line-height:1.5;padding:var(--spacing-3);background:var(--color-surface-default);border:2px solid var(--color-border-default);border-radius:var(--radius-base);transition:all var(--transition-base)}.ui-form-input::placeholder{color:var(--color-text-tertiary)}.ui-form-input:hover:not(:disabled){border-color:var(--color-border-strong)}.ui-form-input:focus{outline:none;border-color:var(--color-brand-primary);box-shadow:0 0 0 3px var(--color-info-bg)}.ui-form-input:disabled{background:var(--color-surface-subtle);color:var(--color-text-disabled);cursor:not-allowed;opacity:.7}.ui-form-input--error{border-color:var(--color-error)}.ui-form-input--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-bg)}.ui-form-input--full-width{width:100%}.ui-text-input{min-height:44px}.ui-textarea{font-family:var(--font-sans);min-height:100px}.ui-textarea--resize-none{resize:none}.ui-textarea--resize-vertical{resize:vertical}.ui-textarea--resize-horizontal{resize:horizontal}.ui-textarea--resize-both{resize:both}.ui-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;min-height:44px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--spacing-3) center;padding-right:var(--spacing-10)}.ui-select:disabled{cursor:not-allowed}[data-theme=light] .ui-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234b5563' d='M6 9L1 4h10z'/%3E%3C/svg%3E")}.ui-form-field{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-6)}.ui-form-field__label{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-primary);display:block}.ui-form-field__required{color:var(--color-error);margin-left:var(--spacing-1)}.ui-form-field__help-text{font-size:var(--text-sm);color:var(--color-text-secondary);margin:0;line-height:1.4}.ui-form-field__error{font-size:var(--text-sm);color:var(--color-error);margin:0;display:flex;align-items:flex-start;gap:var(--spacing-2);line-height:1.4}.ui-form-field__error:before{content:"⚠";flex-shrink:0}.ui-form,.ui-form__fields{display:flex;flex-direction:column;gap:var(--spacing-4)}.ui-form__actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;margin-top:var(--spacing-2);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-default)}.ui-form--compact .ui-form__fields{gap:var(--spacing-3)}.ui-form--compact .ui-form__actions{margin-top:var(--spacing-1);padding-top:var(--spacing-3)}.ui-form--inline{flex-direction:row;align-items:flex-end;flex-wrap:wrap}.ui-form--inline .ui-form__fields{flex-direction:row;flex:1;min-width:0;gap:var(--spacing-3)}.ui-form--inline .ui-form__actions{margin-top:0;padding-top:0;border-top:none}.ui-file-upload{display:flex;flex-direction:column;gap:var(--spacing-2)}.ui-file-upload__label{display:block;font-size:.875rem;font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.ui-file-upload__help-text{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-2) 0}.ui-file-upload__dropzone{border:2px dashed var(--color-border-default);border-radius:var(--radius-md);padding:var(--spacing-6);text-align:center;cursor:pointer;transition:all .2s ease;background:var(--color-bg-secondary);position:relative;min-height:200px;display:flex;align-items:center;justify-content:center}.ui-file-upload__dropzone:hover:not(.ui-file-upload__dropzone--disabled){border-color:var(--color-brand-primary);background:var(--color-bg-tertiary)}.ui-file-upload__dropzone--dragging{border-color:var(--color-brand-primary);background:rgba(var(--color-brand-primary-rgb),.05);border-style:solid}.ui-file-upload__dropzone--disabled{cursor:not-allowed;opacity:.5}.ui-file-upload__dropzone--error{border-color:var(--color-error)}.ui-file-upload__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.ui-file-upload__empty{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3)}.ui-file-upload__icon{font-size:3rem;opacity:.5}.ui-file-upload__text{font-size:.95rem;color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-2)}.ui-file-upload__accepted,.ui-file-upload__max-size{font-size:.8125rem;color:var(--color-text-tertiary)}.ui-file-upload__preview{display:flex;flex-direction:column;gap:var(--spacing-3);width:100%}.ui-file-upload__preview-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-primary);border:1px solid var(--color-border-default);border-radius:var(--radius-sm);transition:background .15s ease}.ui-file-upload__preview-item:hover{background:var(--color-bg-tertiary)}.ui-file-upload__preview-image{width:60px;height:60px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center}.ui-file-upload__preview-image img{width:100%;height:100%;object-fit:cover}.ui-file-upload__preview-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:2rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);flex-shrink:0}.ui-file-upload__preview-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--spacing-1)}.ui-file-upload__preview-name{font-size:.875rem;font-weight:500;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ui-file-upload__preview-size{font-size:.8125rem;color:var(--color-text-tertiary)}.ui-file-upload__preview-remove{width:28px;height:28px;border:none;background:transparent;color:var(--color-text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.ui-file-upload__preview-remove:hover{background:var(--color-error);color:#fff}.ui-file-upload__error{font-size:.875rem;color:var(--color-error);margin:var(--spacing-1) 0 0 0}.ui-file-upload__add-more{margin-top:var(--spacing-2);align-self:flex-start}.ui-card{background:var(--color-surface-subtle);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base);height:100%;display:flex;flex-direction:column}.ui-card--clickable{cursor:pointer}.ui-card--clickable:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:var(--color-brand-primary)}.ui-card--clickable:focus{outline:2px solid var(--color-brand-primary);outline-offset:2px}.ui-card--selected{outline:3px solid var(--color-brand-primary);outline-offset:2px;border-color:var(--color-brand-primary)}.ui-card__image{width:100%;overflow:hidden;background:var(--color-surface-default);position:relative;display:flex;align-items:center;justify-content:center}.ui-card__image-img{width:100%;height:100%;object-fit:cover;display:block}.ui-card__image--preserve-aspect .ui-card__image-img{height:auto!important;object-fit:contain!important}.ui-card__image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-surface-default)}.ui-card__image-placeholder-icon{font-size:5rem;opacity:.3}.ui-card__image-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2);background:var(--color-bg-overlay);color:var(--color-text-primary);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium)}.ui-card__content{padding:var(--spacing-6);flex:1;display:flex;flex-direction:column;gap:var(--spacing-3)}.ui-card__title{font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0;line-height:var(--leading-tight)}.ui-card__description{color:var(--color-text-secondary);line-height:var(--leading-normal);margin:0;font-size:var(--text-base);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;flex:1}.ui-card__badges{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin:var(--spacing-2) 0}.ui-card__badge{padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap}.ui-card__badge--default{background:var(--color-surface-subtle);border:1px solid var(--color-border-default);color:var(--color-text-secondary)}.ui-card__badge--success{background:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.ui-card__badge--warning{background:var(--color-warning-bg);border:1px solid var(--color-warning);color:var(--color-warning)}.ui-card__badge--info{background:var(--color-info-bg);border:1px solid var(--color-info);color:var(--color-info)}.ui-card__badge--purple{background:color-mix(in srgb,var(--color-brand-secondary) 15%,transparent);border:1px solid color-mix(in srgb,var(--color-brand-secondary) 40%,transparent);color:var(--color-brand-secondary)}.ui-card__meta{display:flex;gap:var(--spacing-4);flex-wrap:wrap;font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:auto;padding-top:var(--spacing-2)}.ui-card__meta-item{display:flex;align-items:center;gap:var(--spacing-1)}.ui-card__meta-icon{opacity:.7}.ui-card__date{font-size:var(--text-sm);color:var(--color-text-tertiary);margin-top:var(--spacing-2)}@media (max-width: 768px){.ui-card__content{padding:var(--spacing-4)}.ui-card__title{font-size:var(--text-lg)}.ui-card__description{font-size:var(--text-sm)}}.ui-modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-bg-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-8);animation:ui-modal-fade-in .2s ease-out}@keyframes ui-modal-fade-in{0%{opacity:0}to{opacity:1}}.ui-modal__container{background:var(--color-surface-elevated);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);max-height:90vh;overflow-y:auto;position:relative;animation:ui-modal-slide-in .3s ease-out;display:flex;flex-direction:column}@keyframes ui-modal-slide-in{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.ui-modal__container--sm{width:100%;max-width:400px}.ui-modal__container--md{width:100%;max-width:600px}.ui-modal__container--lg{width:100%;max-width:900px}.ui-modal__container--xl{width:100%;max-width:1200px}.ui-modal__container--full{width:calc(100% - var(--spacing-16));max-width:none;height:calc(100% - var(--spacing-16));max-height:none}.ui-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-6);border-bottom:1px solid var(--color-border-default);gap:var(--spacing-4);flex-shrink:0}.ui-modal__title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0;line-height:var(--leading-tight)}.ui-modal__close{background:var(--color-surface-subtle);border:1px solid var(--color-border-default);color:var(--color-text-primary);font-size:2rem;line-height:1;width:40px;height:40px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-base);flex-shrink:0}.ui-modal__close:hover{background:var(--color-surface-default);border-color:var(--color-border-strong);transform:rotate(90deg)}.ui-modal__close:focus{outline:2px solid var(--color-brand-primary);outline-offset:2px}.ui-modal__content{padding:var(--spacing-6);overflow-y:auto;flex:1}.ui-modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-6);border-top:1px solid var(--color-border-default);flex-shrink:0}@media (max-width: 768px){.ui-modal__overlay{padding:var(--spacing-4)}.ui-modal__container{max-height:95vh}.ui-modal__container--sm,.ui-modal__container--md,.ui-modal__container--lg,.ui-modal__container--xl{width:100%;max-width:none}.ui-modal__container--full{width:100%;height:100%}.ui-modal__header{padding:var(--spacing-4)}.ui-modal__title{font-size:var(--text-xl)}.ui-modal__content{padding:var(--spacing-4)}.ui-modal__footer{padding:var(--spacing-4);flex-wrap:wrap}}.ui-spinner{display:inline-flex;align-items:center;justify-content:center}.ui-spinner__circle{border-radius:var(--radius-full);border-style:solid;animation:ui-spinner-rotate .8s linear infinite}.ui-spinner--sm .ui-spinner__circle{width:16px;height:16px;border-width:2px}.ui-spinner--md .ui-spinner__circle{width:24px;height:24px;border-width:3px}.ui-spinner--lg .ui-spinner__circle{width:40px;height:40px;border-width:4px}.ui-spinner--xl .ui-spinner__circle{width:64px;height:64px;border-width:5px}.ui-spinner--default .ui-spinner__circle{border-color:var(--color-border-strong);border-top-color:var(--color-text-primary)}.ui-spinner--primary .ui-spinner__circle{border-color:color-mix(in srgb,var(--color-brand-primary) 20%,transparent);border-top-color:var(--color-brand-primary)}.ui-spinner--white .ui-spinner__circle{border-color:color-mix(in srgb,var(--color-text-inverse) 20%,transparent);border-top-color:var(--color-text-inverse)}@keyframes ui-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ui-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-16) var(--spacing-8);color:var(--color-text-secondary)}.ui-empty-state__icon{font-size:4rem;margin-bottom:var(--spacing-6);opacity:.6}.ui-empty-state__title{font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-3) 0}.ui-empty-state__description{font-size:var(--text-base);color:var(--color-text-secondary);max-width:400px;margin:0 0 var(--spacing-6) 0;line-height:var(--leading-normal)}.ui-empty-state__action{margin-top:var(--spacing-2)}@media (max-width: 768px){.ui-empty-state{padding:var(--spacing-12) var(--spacing-4)}.ui-empty-state__icon{font-size:3rem}.ui-empty-state__title{font-size:var(--text-xl)}.ui-empty-state__description{font-size:var(--text-sm)}}.ui-async-content{width:100%}.ui-async-content__state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-16) var(--spacing-8);text-align:center}.ui-async-content--loading{min-height:200px;display:flex;align-items:center;justify-content:center}.ui-async-content__text{margin-top:var(--spacing-4);color:var(--color-text-secondary);font-size:var(--text-base)}.ui-async-content--error{min-height:200px;display:flex;align-items:center;justify-content:center}.ui-async-content__error{max-width:500px}.ui-async-content__error-icon{font-size:3rem;margin-bottom:var(--spacing-4)}.ui-async-content__error-title{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-error);margin:0 0 var(--spacing-3) 0}.ui-async-content__error-message{font-size:var(--text-base);color:var(--color-text-secondary);margin:0;line-height:var(--leading-normal)}.ui-async-content--empty{min-height:200px}@media (max-width: 768px){.ui-async-content__state{padding:var(--spacing-12) var(--spacing-4)}.ui-async-content__error-icon{font-size:2.5rem}.ui-async-content__error-title{font-size:var(--text-xl)}.ui-async-content__error-message{font-size:var(--text-sm)}}.page-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-6);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-subtle);min-height:60px;position:fixed;top:0;left:260px;right:0;z-index:50}.breadcrumbs{flex:1}.breadcrumb-list{display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-2);list-style:none;margin:0;padding:0}.breadcrumb-item{display:flex;align-items:center;gap:var(--spacing-2)}.breadcrumb-link{color:var(--color-text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:var(--font-medium);transition:color var(--transition-fast);white-space:nowrap}.breadcrumb-link:hover{color:var(--color-brand-primary);text-decoration:underline}.breadcrumb-current{color:var(--color-text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap}.breadcrumb-separator{color:var(--color-text-tertiary);font-size:var(--text-base);-webkit-user-select:none;user-select:none}.page-header-actions{display:flex;align-items:center;gap:var(--spacing-3);margin-left:var(--spacing-4)}@media (max-width: 768px){.page-header{left:0;flex-direction:column;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);padding-top:4rem}.breadcrumb-list{gap:var(--spacing-1)}.breadcrumb-link,.breadcrumb-current{font-size:var(--text-xs)}.page-header-actions{width:100%;margin-left:0;justify-content:flex-end}}@media (max-width: 480px){.breadcrumb-link,.breadcrumb-current{max-width:120px;overflow:hidden;text-overflow:ellipsis}}.tab-view{display:flex;flex-direction:column;width:100%}.tab-list{display:flex;gap:var(--spacing-1);border-bottom:1px solid var(--color-border-subtle);overflow-x:auto;overflow-y:hidden;scrollbar-width:thin}.tab-list::-webkit-scrollbar{height:4px}.tab-list::-webkit-scrollbar-track{background:var(--color-bg-secondary)}.tab-list::-webkit-scrollbar-thumb{background:var(--color-border-default);border-radius:var(--radius-sm)}.tab-list--align-left{justify-content:flex-start}.tab-list--align-center{justify-content:center}.tab-list--align-right{justify-content:flex-end}.tab{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;position:relative;border-bottom:2px solid transparent}.tab:hover:not(.tab--disabled){color:var(--color-text-primary);background:var(--color-surface-hover)}.tab:focus-visible{outline:2px solid var(--color-brand-primary);outline-offset:-2px}.tab--active{color:var(--color-text-primary);font-weight:var(--font-semibold)}.tab--disabled{color:var(--color-text-tertiary);cursor:not-allowed;opacity:.5}.tab-icon{font-size:var(--text-base);display:flex;align-items:center}.tab-label{flex:1}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 var(--spacing-1);background:var(--color-brand-primary);color:var(--color-text-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full)}.tab-view--underline .tab--active{border-bottom-color:var(--color-brand-primary)}.tab-view--pills .tab-list{border-bottom:none;gap:var(--spacing-2)}.tab-view--pills .tab{border-radius:var(--radius-md);border:1px solid transparent}.tab-view--pills .tab--active{background:var(--color-brand-primary-bg);border-color:var(--color-brand-primary);color:var(--color-brand-primary)}.tab-view--boxed .tab-list{border-bottom:1px solid var(--color-border-default);gap:0}.tab-view--boxed .tab{border:1px solid transparent;border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0;margin-bottom:-1px}.tab-view--boxed .tab--active{background:var(--color-bg-primary);border-color:var(--color-border-default);border-bottom-color:var(--color-bg-primary)}.tab-panels{position:relative;flex:1}.tab-panel{display:none;animation:fadeIn var(--transition-normal)}.tab-panel--active{display:block}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.tab{padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-xs)}.tab-icon{font-size:var(--text-sm)}.tab-badge{min-width:18px;height:18px;font-size:10px}}.tab-panel>*:first-child{margin-top:var(--spacing-4)}.grid-layout{display:grid;gap:var(--grid-gap, var(--spacing-4));align-items:var(--grid-align-items, stretch);justify-items:var(--grid-justify-items, stretch);width:100%}.grid-layout:not(.grid-layout--responsive):not(.grid-layout--auto-fit){grid-template-columns:repeat(var(--grid-columns, 3),1fr)}.grid-layout--auto-fit{grid-template-columns:repeat(auto-fit,minmax(var(--grid-min-column-width, 250px),1fr))}.grid-layout--responsive{grid-template-columns:repeat(var(--grid-columns-xs, 1),1fr)}@media (min-width: 576px){.grid-layout--responsive{grid-template-columns:repeat(var(--grid-columns-sm, 2),1fr)}}@media (min-width: 768px){.grid-layout--responsive{grid-template-columns:repeat(var(--grid-columns-md, 3),1fr)}}@media (min-width: 992px){.grid-layout--responsive{grid-template-columns:repeat(var(--grid-columns-lg, 4),1fr)}}@media (min-width: 1200px){.grid-layout--responsive{grid-template-columns:repeat(var(--grid-columns-xl, 4),1fr)}}.grid-layout[style*=--grid-row-gap]{row-gap:var(--grid-row-gap)}.grid-layout[style*=--grid-column-gap]{column-gap:var(--grid-column-gap)}.grid-layout[style*=--grid-row-gap][style*=--grid-column-gap]{gap:var(--grid-row-gap) var(--grid-column-gap)}.grid-layout>*{min-width:0;min-height:0}.badge{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-semibold);border-radius:var(--radius-full);white-space:nowrap;transition:all var(--transition-fast)}.badge--sm{font-size:var(--text-xs);padding:.125rem var(--spacing-2);min-height:18px}.badge--md{font-size:var(--text-xs);padding:.25rem var(--spacing-2);min-height:20px}.badge--lg{font-size:var(--text-sm);padding:.375rem var(--spacing-3);min-height:24px}.badge--dot{width:8px;height:8px;padding:0;min-width:8px;min-height:8px;border-radius:var(--radius-full)}.badge--dot.badge--sm{width:6px;height:6px;min-width:6px;min-height:6px}.badge--dot.badge--lg{width:10px;height:10px;min-width:10px;min-height:10px}.badge--default{background:var(--color-surface-hover);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.badge--success{background:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success)}.badge--error{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning)}.badge--info{background:var(--color-info-bg);color:var(--color-info);border:1px solid var(--color-info)}.badge--brand{background:var(--color-brand-primary-bg);color:var(--color-brand-primary);border:1px solid var(--color-brand-primary)}.badge--dot.badge--default{background:var(--color-text-tertiary);border:none}.badge--dot.badge--success{background:var(--color-success);border:none}.badge--dot.badge--error{background:var(--color-error);border:none}.badge--dot.badge--warning{background:var(--color-warning);border:none}.badge--dot.badge--info{background:var(--color-info);border:none}.badge--dot.badge--brand{background:var(--color-brand-primary);border:none}.tooltip-trigger{display:inline-flex;align-items:center}.tooltip{position:fixed;z-index:var(--z-tooltip, 9999);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-tertiary);color:var(--color-text-primary);font-size:var(--text-xs);line-height:1.4;border-radius:var(--radius-md);border:1px solid var(--color-border-default);box-shadow:var(--shadow-lg);pointer-events:none;max-width:300px;word-wrap:break-word;animation:tooltipFadeIn var(--transition-fast)}@keyframes tooltipFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.tooltip-arrow{position:absolute;width:0;height:0;border-style:solid}.tooltip--top .tooltip-arrow{bottom:-6px;left:50%;transform:translate(-50%);border-width:6px 6px 0 6px;border-color:var(--color-bg-tertiary) transparent transparent transparent}.tooltip--top .tooltip-arrow:before{content:"";position:absolute;bottom:1px;left:-6px;border-width:6px 6px 0 6px;border-style:solid;border-color:var(--color-border-default) transparent transparent transparent}.tooltip--bottom .tooltip-arrow{top:-6px;left:50%;transform:translate(-50%);border-width:0 6px 6px 6px;border-color:transparent transparent var(--color-bg-tertiary) transparent}.tooltip--bottom .tooltip-arrow:before{content:"";position:absolute;top:1px;left:-6px;border-width:0 6px 6px 6px;border-style:solid;border-color:transparent transparent var(--color-border-default) transparent}.tooltip--left .tooltip-arrow{right:-6px;top:50%;transform:translateY(-50%);border-width:6px 0 6px 6px;border-color:transparent transparent transparent var(--color-bg-tertiary)}.tooltip--left .tooltip-arrow:before{content:"";position:absolute;right:1px;top:-6px;border-width:6px 0 6px 6px;border-style:solid;border-color:transparent transparent transparent var(--color-border-default)}.tooltip--right .tooltip-arrow{left:-6px;top:50%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:transparent var(--color-bg-tertiary) transparent transparent}.tooltip--right .tooltip-arrow:before{content:"";position:absolute;left:1px;top:-6px;border-width:6px 6px 6px 0;border-style:solid;border-color:transparent var(--color-border-default) transparent transparent}.icon-button{display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-family:inherit;line-height:1;position:relative}.icon-button:focus-visible{outline:2px solid var(--color-brand-primary);outline-offset:2px}.icon-button:disabled{cursor:not-allowed;opacity:.5}.icon-button--loading{cursor:wait}.icon-button--sm{width:28px;height:28px;font-size:var(--text-sm)}.icon-button--md{width:36px;height:36px;font-size:var(--text-base)}.icon-button--lg{width:44px;height:44px;font-size:var(--text-lg)}.icon-button-icon{display:flex;align-items:center;justify-content:center}.icon-button-spinner{width:1em;height:1em;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:iconButtonSpin .6s linear infinite}@keyframes iconButtonSpin{to{transform:rotate(360deg)}}.icon-button--default{background:var(--color-surface-hover);color:var(--color-text-primary);border:1px solid var(--color-border-default)}.icon-button--default:hover:not(:disabled){background:var(--color-surface-active);border-color:var(--color-border-strong);transform:translateY(-1px)}.icon-button--default:active:not(:disabled){transform:translateY(0)}.icon-button--primary{background:var(--color-brand-primary);color:var(--color-text-primary)}.icon-button--primary:hover:not(:disabled){background:var(--color-brand-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.icon-button--primary:active:not(:disabled){background:var(--color-brand-active);transform:translateY(0)}.icon-button--secondary{background:var(--color-surface-subtle);color:var(--color-text-secondary);border:1px solid var(--color-border-subtle)}.icon-button--secondary:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text-primary);border-color:var(--color-border-default)}.icon-button--danger{background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error)}.icon-button--danger:hover:not(:disabled){background:var(--color-error);color:var(--color-text-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.icon-button--danger:active:not(:disabled){transform:translateY(0)}.icon-button--ghost{background:transparent;color:var(--color-text-secondary)}.icon-button--ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text-primary)}.icon-button--ghost:active:not(:disabled){background:var(--color-surface-active)}.divider{border:none;background:var(--color-border-subtle)}.divider--horizontal{width:100%;height:1px}.divider--vertical{width:1px;height:100%;display:inline-block}.divider--horizontal.divider--spacing-sm{margin:var(--spacing-2) 0}.divider--horizontal.divider--spacing-md{margin:var(--spacing-4) 0}.divider--horizontal.divider--spacing-lg{margin:var(--spacing-6) 0}.divider--horizontal.divider--spacing-none{margin:0}.divider--vertical.divider--spacing-sm{margin:0 var(--spacing-2)}.divider--vertical.divider--spacing-md{margin:0 var(--spacing-4)}.divider--vertical.divider--spacing-lg{margin:0 var(--spacing-6)}.divider--vertical.divider--spacing-none{margin:0}.divider--with-label{display:flex;align-items:center;background:transparent;height:auto;gap:var(--spacing-3)}.divider-line{flex:1;height:1px;background:var(--color-border-subtle)}.divider-label{color:var(--color-text-tertiary);font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap}.selectable-entity-item{display:inline-flex;flex-direction:column;border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:var(--color-surface-default);cursor:pointer;transition:all .2s ease;overflow:hidden;max-width:300px;width:fit-content}.selectable-entity-item:hover:not(.disabled){background:var(--color-surface-hover);border-color:var(--color-border-default);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.selectable-entity-item.checked{background:var(--color-brand-primary-bg);border:3px solid var(--color-brand-primary);box-shadow:0 0 0 1px var(--color-brand-primary),0 4px 16px #6366f14d;transform:scale(1.02)}.selectable-entity-item.disabled{opacity:.5;cursor:not-allowed}.selectable-entity-image{width:100%;background:var(--color-surface-subtle);border-bottom:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:center}.selectable-entity-image img{max-width:100%;max-height:250px;width:auto;height:auto;object-fit:contain}.selectable-entity-footer{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem}.selectable-entity-name{flex:1;color:var(--color-text-primary);font-size:.95rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selectable-entity-checkbox{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--color-brand-primary);margin:0}.selectable-entity-item.disabled .selectable-entity-checkbox{cursor:not-allowed}@media (max-width: 640px){.selectable-entity-item{max-width:100%}.selectable-entity-footer{padding:.5rem}.selectable-entity-name{font-size:.875rem}}.dashboard{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 4rem);padding:2rem}.dashboard-welcome{max-width:900px;text-align:center}.dashboard-welcome h1{font-size:3rem;margin-bottom:.5rem;color:#fff;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.welcome-subtitle{font-size:1.25rem;color:var(--color-text-tertiary);margin-bottom:3rem}.welcome-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:3rem}.welcome-card{background:var(--color-surface-subtle);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:2rem;transition:var(--transition-slow)}.welcome-card:hover{background:var(--color-surface-hover);border-color:var(--color-brand-primary);transform:translateY(-4px);box-shadow:var(--shadow-xl)}.welcome-icon{font-size:3rem;margin-bottom:1rem}.welcome-card h2{font-size:1.5rem;color:#fff;margin-bottom:.75rem}.welcome-card p{font-size:.95rem;color:var(--color-text-secondary);line-height:1.6;margin:0}.welcome-cta{padding:1.5rem;background:var(--color-info-bg);border:1px solid var(--color-info);border-radius:var(--radius-md)}.welcome-cta p{margin:0;color:var(--color-text-primary);font-size:1rem}@media (max-width: 768px){.dashboard-welcome h1{font-size:2rem}.welcome-subtitle{font-size:1rem}.welcome-content{grid-template-columns:1fr;gap:1.5rem}}.jobs-page{max-width:1200px;margin:0 auto;padding:2rem;min-height:calc(100vh - 4rem)}.jobs-header{margin-bottom:2rem}.jobs-header h2{margin:0 0 .5rem;font-size:2rem;color:var(--color-text-primary)}.jobs-subtitle{margin:0;color:var(--color-text-tertiary);font-size:.875rem}.jobs-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-button{padding:.5rem 1rem;background:var(--color-surface-subtle);color:var(--color-text-secondary);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:all .2s}.filter-button:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.filter-button.active{background:var(--color-brand-primary-bg);color:var(--color-brand-primary);border-color:var(--color-brand-primary)}.jobs-list{display:flex;flex-direction:column;gap:.75rem}.jobs-loading,.jobs-empty{text-align:center;padding:3rem;color:var(--color-text-tertiary);font-size:.875rem}.job-item{background:var(--color-surface-subtle);border:1px solid var(--color-surface-subtle);border-radius:var(--radius-md);overflow:hidden;transition:all .2s}.job-item:hover{background:var(--color-border-subtle);border-color:var(--color-border-strong)}.job-item.completed{border-left:3px solid var(--color-success)}.job-item.running,.job-item.queued{border-left:3px solid var(--color-brand-primary)}.job-item.failed,.job-item.cancelled{border-left:3px solid var(--color-error)}.job-item.stuck{border-left:3px solid var(--color-warning);background:var(--color-warning-bg)}.job-item.stuck:hover{background:var(--color-surface-hover)}.job-item-header{display:flex;align-items:center;gap:1rem;padding:1rem;cursor:pointer;-webkit-user-select:none;user-select:none}.job-status-icon{font-size:1.25rem;flex-shrink:0}.job-item.running .job-status-icon{animation:spin 1s linear infinite}.job-info{flex:1;min-width:0}.job-title{font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.job-meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--color-text-tertiary)}.job-id{font-family:monospace}.job-progress-msg{color:var(--color-text-secondary)}.job-time{color:var(--color-text-tertiary)}.job-actions{display:flex;gap:.5rem}.job-action-btn{padding:.25rem .75rem;border:none;border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s}.job-action-btn.cancel{background:var(--color-error-bg);color:var(--color-error)}.job-action-btn.cancel:hover{background:var(--color-error)}.job-action-btn.retry{background:var(--color-brand-primary-bg);color:var(--color-brand-primary)}.job-action-btn.retry:hover{background:var(--color-brand-primary);color:var(--color-surface-base)}.job-action-btn.dismiss{background:var(--color-surface-subtle);color:var(--color-text-secondary);font-size:1.25rem;line-height:1;padding:.25rem .5rem}.job-action-btn.dismiss:hover{background:var(--color-border-strong);color:var(--color-text-primary)}.job-progress-container{position:relative;height:4px;background:var(--color-surface-subtle);margin:0 1rem .5rem}.job-progress-bar{height:100%;background:linear-gradient(90deg,var(--color-brand-primary),var(--color-brand-secondary));transition:width .3s}.job-progress-text{position:absolute;right:0;top:-1.25rem;font-size:.625rem;color:var(--color-text-tertiary)}.job-details{padding:1rem;background:var(--color-border-strong);border-top:1px solid var(--color-surface-subtle)}.job-detail-item{margin-bottom:.75rem;font-size:.875rem;color:var(--color-text-secondary)}.job-detail-item:last-child{margin-bottom:0}.job-detail-item strong{color:var(--color-text-primary);margin-right:.5rem}.job-detail-item code{background:var(--color-surface-subtle);padding:.125rem .375rem;border-radius:3px;font-family:monospace;font-size:.75rem}.job-detail-item.error{color:var(--color-error)}.job-detail-item ul{margin:.5rem 0 0 1.5rem;padding:0}.job-detail-item li{margin-bottom:.25rem}.job-prompt{margin-top:.5rem;padding:1rem;background:var(--color-surface-strong);border:1px solid var(--color-surface-subtle);border-radius:var(--radius-sm);font-family:Courier New,Courier,monospace;font-size:.75rem;color:var(--color-text-primary);white-space:pre-wrap;overflow-x:auto;overflow-y:auto;max-height:400px;line-height:1.5}.jobs-search-bar{position:relative;margin-bottom:1rem}.jobs-search-input{width:100%;padding:.75rem 2.5rem .75rem 1rem;background:var(--color-surface-subtle);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.875rem;transition:all .2s}.jobs-search-input:focus{outline:none;background:var(--color-border-subtle);border-color:var(--color-brand-primary)}.jobs-search-input::placeholder{color:var(--color-text-tertiary)}.jobs-search-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:var(--color-surface-subtle);border:none;color:var(--color-text-tertiary);font-size:1.5rem;line-height:1;padding:.25rem .5rem;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s}.jobs-search-clear:hover{background:var(--color-border-strong);color:var(--color-text-primary)}.jobs-advanced-filters{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.filter-select{padding:.5rem 2rem .5rem .75rem;background:var(--color-surface-subtle);color:var(--color-text-primary);border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12"><path fill="white" d="M6 9L1 4h10z"/></svg>');background-repeat:no-repeat;background-position:right .5rem center;background-size:12px}.filter-select:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-default)}.filter-select:focus{outline:none;border-color:var(--color-brand-primary)}.filter-select option{background:var(--color-bg-secondary);color:var(--color-text-primary)}.filter-clear-btn{padding:.5rem 1rem;background:var(--color-error-bg);color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s;margin-left:auto}.filter-clear-btn:hover{background:var(--color-error);border-color:var(--color-error)}.job-metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem;padding:1rem;background:var(--color-surface-subtle);border-radius:var(--radius-base);border:1px solid var(--color-border-subtle)}.job-metadata-item{font-size:.875rem;color:var(--color-text-secondary)}.job-metadata-item strong{display:block;color:var(--color-text-tertiary);font-size:.75rem;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.job-metadata-item code{background:var(--color-surface-subtle);padding:.25rem .5rem;border-radius:3px;font-family:monospace;font-size:.875rem;color:var(--color-brand-primary)}.job-prompt-response-controls{display:flex;gap:.5rem;margin-bottom:1rem}.view-toggle-btn{padding:.5rem 1rem;background:var(--color-surface-subtle);color:var(--color-text-tertiary);border:1px solid var(--color-surface-subtle);border-radius:var(--radius-sm);font-size:.875rem;cursor:pointer;transition:all .2s}.view-toggle-btn:hover{background:var(--color-surface-subtle);color:var(--color-text-primary)}.view-toggle-btn.active{background:var(--color-brand-primary-bg);color:var(--color-brand-primary);border-color:var(--color-brand-primary)}.job-prompt-response-container{display:flex;gap:1rem;margin-bottom:1rem}.job-prompt-response-container.stacked{flex-direction:column}.job-prompt-response-container.side-by-side{flex-direction:row}.job-prompt-section,.job-response-section{flex:1;min-width:0}.job-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-surface-subtle)}.job-section-header strong{color:var(--color-text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.copy-btn{padding:.375rem .75rem;background:var(--color-brand-primary-bg);color:var(--color-brand-primary);border:1px solid var(--color-brand-primary-bg);border-radius:var(--radius-sm);font-size:.75rem;cursor:pointer;transition:all .2s;white-space:nowrap}.copy-btn:hover{background:var(--color-brand-primary-bg);border-color:var(--color-brand-primary)}.job-code-block{margin:0;padding:1rem;background:var(--color-surface-strong);border:1px solid var(--color-surface-subtle);border-radius:var(--radius-base);font-family:SF Mono,Monaco,Inconsolata,Fira Mono,Droid Sans Mono,Source Code Pro,monospace;font-size:.8125rem;color:var(--color-text-primary);white-space:pre-wrap;overflow-x:auto;overflow-y:auto;max-height:500px;line-height:1.6}.job-code-block::-webkit-scrollbar{width:8px;height:8px}.job-code-block::-webkit-scrollbar-track{background:var(--color-border-strong);border-radius:var(--radius-sm)}.job-code-block::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:var(--radius-sm)}.job-code-block::-webkit-scrollbar-thumb:hover{background:var(--color-border-default)}.job-detail-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-surface-subtle);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}@media (max-width: 768px){.job-prompt-response-container.side-by-side{flex-direction:column}.jobs-advanced-filters,.filter-group{flex-direction:column;align-items:stretch}.filter-select{width:100%}.filter-clear-btn{margin-left:0}.job-metadata-grid{grid-template-columns:1fr}}.stuck-badge{display:inline-block;margin-left:.5rem;padding:.125rem .5rem;background:var(--color-warning);color:var(--color-text-on-brand);font-size:.625rem;font-weight:700;border-radius:3px;text-transform:uppercase;letter-spacing:.5px;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.6}}.stuck-reason{color:var(--color-warning);font-weight:500;font-size:.75rem}.child-jobs-container{display:flex;flex-direction:column;gap:.75rem;margin-top:.75rem}.job-item[style*=margin-left]{opacity:.95}.job-item[style*=margin-left]:hover{opacity:1}.entity-browser{padding:2rem;max-width:1400px;margin:0 auto}.entity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.entity-header-left h2{font-size:2rem;margin:0 0 .5rem;color:var(--color-text-primary)}.entity-count{color:#fff9;margin:0;font-size:.95rem}.entity-header-right{display:flex;gap:1rem;flex-wrap:wrap}.refresh-button,.secondary-action-button,.primary-action-button{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:.95rem;cursor:pointer;transition:all .2s;white-space:nowrap}.refresh-button,.secondary-action-button{background:#ffffff1a;color:var(--color-text-primary);border:1px solid var(--color-border-strong)}.refresh-button:hover:not(:disabled),.secondary-action-button:hover{background:#ffffff26}.refresh-button:disabled{opacity:.5;cursor:not-allowed}.primary-action-button{background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);color:var(--color-text-inverse);font-weight:500}.primary-action-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.entity-controls{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;min-width:250px}.search-box input{width:100%;padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.95rem}.search-box input::placeholder{color:#fff6}.search-box input:focus{outline:none;border-color:#667eea80;box-shadow:0 0 0 3px #667eea1a}.sort-box{display:flex;align-items:center;gap:.5rem}.sort-box label{color:#ffffffb3;font-size:.9rem}.sort-box select{padding:.75rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:.95rem;cursor:pointer}.sort-box select:focus{outline:none;border-color:#667eea80}.entity-loading,.entity-error,.entity-empty{text-align:center;padding:4rem 2rem;color:#fff9}.entity-error{color:#ff6b6b}.entity-empty p{font-size:1.25rem;margin-bottom:2rem}.entity-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .3s;width:100%;max-width:200px;height:100%;display:flex;flex-direction:column}.entity-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000004d;border-color:#667eea80}.entity-card-image{width:100%;height:200px;overflow:hidden;background:var(--color-border-strong);position:relative}.entity-card-image img{width:100%;height:100%;object-fit:cover}.entity-card-image-preserve-aspect{height:auto!important}.entity-card-image-preserve-aspect img{height:auto!important;object-fit:contain!important}.entity-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;opacity:.3}.entity-card-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.entity-card-title{font-size:1.25rem;margin:0 0 .75rem;color:var(--color-text-primary);font-weight:600}.entity-card-title--clamped{display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4em;max-height:7em;min-height:2.8em;word-wrap:break-word}.entity-card-description{color:#ffffffb3;line-height:1.6;margin:0 0 1rem;font-size:.9rem;flex:1}.entity-card-meta{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:#ffffff80;margin-top:auto}.entity-card-meta-item{display:flex;align-items:center;gap:.25rem}.entity-card-date{font-size:.85rem;color:#fff6;margin-top:.5rem}.entity-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.entity-detail-container{background:#1a1a1a;border-radius:var(--radius-lg);max-width:900px;width:100%;max-height:90vh;overflow-y:auto;position:relative}.entity-detail-close{position:sticky;top:1rem;right:1rem;float:right;background:#ffffff1a;border:none;color:var(--color-text-primary);font-size:2rem;width:40px;height:40px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.entity-detail-close:hover{background:var(--color-border-strong)}.entity-detail-view{padding-top:1rem}.entity-breadcrumb{margin-bottom:1.5rem}.back-button{padding:.75rem 1.5rem;background:#ffffff1a;color:var(--color-text-primary);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);cursor:pointer;font-size:.95rem;transition:all .2s}.back-button:hover{background:#ffffff26}.entity-detail-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.5rem}.entity-tab{display:inline-block;padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-secondary);font-size:.95rem;cursor:pointer;transition:all .2s;border-radius:var(--radius-md) 8px 0 0;text-decoration:none}.entity-tab:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.entity-tab.active{color:var(--color-text-primary);background:var(--color-brand-primary-bg);border-bottom-color:var(--color-brand-primary);font-weight:500}.entity-detail-full-width{width:100%}.entity-detail-columns{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.entity-detail-preview{position:sticky;top:2rem}.entity-detail-preview img{width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:0 4px 16px #0000004d}.entity-detail-content{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:2rem}.entity-detail-actions{display:flex;justify-content:space-between;align-items:center;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1);gap:1rem}.edit-button,.save-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);border:none;border-radius:var(--radius-md);color:var(--color-text-inverse);font-weight:500;cursor:pointer;transition:all .2s}.edit-button:hover,.save-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cancel-button{padding:.75rem 1.5rem;background:#ffffff1a;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all .2s}.cancel-button:hover{background:#ffffff26}.delete-button{padding:.75rem 1.5rem;background:#ff646433;border:1px solid rgba(255,100,100,.3);border-radius:var(--radius-md);color:#ff6b6b;cursor:pointer;transition:all .2s}.delete-button:hover{background:#ff64644d}.save-button:disabled,.cancel-button:disabled,.delete-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 1024px){.entity-detail-columns{grid-template-columns:1fr}.entity-detail-preview{position:relative;top:0}}@media (max-width: 768px){.entity-browser{padding:1rem}.entity-header{flex-direction:column;align-items:flex-start;gap:1rem}.entity-header-right{width:100%}.entity-header-right button{flex:1}.entity-controls{flex-direction:column}.search-box,.sort-box{width:100%}.entity-detail-content{padding:1.5rem}.entity-detail-actions{flex-direction:column}.entity-detail-actions>div{width:100%;margin-left:0!important}}.entity-gallery{width:100%}.entity-gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.entity-gallery-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#fffffff2}.gallery-count{margin:0;font-size:.9rem;color:#fff9}.entity-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}.gallery-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s ease}.gallery-card:hover{transform:translateY(-4px);background:#ffffff0d;border-color:#667eea80;box-shadow:0 8px 24px #0000004d}.gallery-card-image{height:280px;overflow:hidden;background:#0000004d;position:relative}.gallery-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-card:hover .gallery-card-image img{transform:scale(1.05)}.gallery-card-content{padding:1rem}.gallery-card-title{font-size:1rem;margin:0 0 .5rem;color:#ffffffe6;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-card-badges{display:flex;gap:.25rem;flex-wrap:wrap;margin-bottom:.5rem}.entity-badge{padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;border:1px solid}.entity-badge-character{background:#6366f133;border-color:#6366f14d;color:#6366f1}.entity-badge-clothing{background:#a855f733;border-color:#a855f74d;color:#a855f7}.entity-badge-style{background:#f59e0b33;border-color:#f59e0b4d;color:#f59e0b}.gallery-card-date{margin:.5rem 0 0;font-size:.85rem;color:#ffffff80}.gallery-back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;margin-bottom:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#6366f1;font-size:.95rem;cursor:pointer;transition:all .2s}.gallery-back-button:hover{background:#ffffff1a;border-color:#667eea80;transform:translate(-4px)}.gallery-detail-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.gallery-detail-left{position:sticky;top:2rem}.gallery-detail-image{width:100%;height:auto;border-radius:var(--radius-lg);box-shadow:0 4px 16px #0000004d}.gallery-detail-right{padding:2rem}.gallery-detail-title{color:var(--color-surface-default);margin:0 0 1.5rem;font-size:1.5rem;font-weight:600}.gallery-detail-section{margin-bottom:1.5rem}.gallery-detail-section h3{color:#fffc;font-size:1rem;margin:0 0 .75rem;font-weight:600}.gallery-detail-section p{color:#ffffffb3;margin:0;line-height:1.6}.gallery-detail-entity-type{margin-bottom:1rem}.gallery-detail-entity-type:last-child{margin-bottom:0}.gallery-detail-entity-type h4{color:#fff9;font-size:.85rem;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.gallery-detail-entity-list{display:flex;gap:.5rem;flex-wrap:wrap}.gallery-detail-entity-badge{padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-base);font-size:.85rem;color:#ffffffe6;text-decoration:none;transition:all .2s;display:inline-block}.gallery-detail-entity-badge:hover{background:#ffffff26;border-color:#667eea80;transform:translateY(-2px)}.entity-role{color:#ffffff80;margin-left:.5rem;font-size:.8rem}.gallery-detail-download{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);color:var(--color-surface-default);text-decoration:none;border-radius:var(--radius-md);font-weight:500;transition:transform .2s,box-shadow .2s}.gallery-detail-download:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea80}.entity-gallery-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.entity-gallery-loading .spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.1);border-top-color:#6366f1;border-radius:var(--radius-full);animation:spin 1s linear infinite}.entity-gallery-loading p{color:#fff9;margin:0}.entity-gallery-error{padding:2rem;text-align:center;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:var(--radius-md);color:#ff6b6b}.entity-gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;padding:2rem}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.entity-gallery-empty h3{margin:0 0 .5rem;color:#fffc}.entity-gallery-empty p{margin:0;color:#ffffff80;max-width:400px}@media (max-width: 768px){.gallery-detail-container{grid-template-columns:1fr;gap:1.5rem}.gallery-detail-left{position:static}.gallery-detail-right{padding:0}.entity-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.gallery-card-image{height:200px}}.reference-images-tab{padding:1rem;position:relative;min-height:200px}.reference-images-tab.dragging{background:#2196f30d}.reference-images-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.reference-images-header .header-left{display:flex;align-items:center;gap:.75rem}.reference-images-header h3{margin:0;font-size:1rem;color:#fffffff2}.reference-images-header .image-count{font-size:.85rem;color:#fff9;background:#ffffff1a;padding:.2rem .5rem;border-radius:4px}.reference-images-header .upload-button{background:#2196f333;color:#42a5f5;border:1px solid rgba(33,150,243,.3);padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s,border-color .2s}.reference-images-header .upload-button:hover:not(:disabled){background:#2196f34d;border-color:#2196f380}.reference-images-header .upload-button:disabled{opacity:.6;cursor:not-allowed}.reference-images-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff9}.reference-images-loading .spinner{width:2rem;height:2rem;border:3px solid rgba(255,255,255,.2);border-top-color:#42a5f5;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.reference-images-error{background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:6px;padding:.75rem 1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}.reference-images-error p{margin:0;color:#ef5350;font-size:.85rem}.reference-images-error button{background:transparent;border:1px solid rgba(244,67,54,.3);color:#ef5350;padding:.25rem .5rem;border-radius:4px;cursor:pointer;font-size:.75rem}.upload-progress{margin-bottom:1rem}.upload-progress .progress-bar{width:100%;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.upload-progress .progress-fill{height:100%;background:linear-gradient(90deg,#42a5f5,#66bb6a);transition:width .3s}.drag-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#2196f31a;border:2px dashed rgba(33,150,243,.5);border-radius:8px;display:flex;align-items:center;justify-content:center;z-index:10}.drag-overlay .drag-content{text-align:center;color:#42a5f5}.drag-overlay .drag-icon{font-size:2.5rem;display:block;margin-bottom:.5rem}.drag-overlay p{margin:0;font-size:1rem;font-weight:500}.reference-images-empty{text-align:center;padding:3rem 2rem;color:#fff9}.reference-images-empty .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.reference-images-empty h4{margin:0 0 .5rem;color:#ffffffe6;font-size:1.1rem}.reference-images-empty p{margin:0 0 .25rem;font-size:.9rem}.reference-images-empty .hint{font-size:.8rem;opacity:.7}.reference-images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.reference-image-card{position:relative;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s,transform .2s}.reference-image-card:hover{border-color:#2196f380;transform:translateY(-2px)}.reference-image-card .image-wrapper{aspect-ratio:1;overflow:hidden}.reference-image-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.reference-image-card:hover img{transform:scale(1.05)}.reference-image-card .image-actions{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem;background:linear-gradient(to bottom,rgba(0,0,0,.6),transparent)}.reference-image-card .image-role{background:#2196f34d;color:#42a5f5;padding:.15rem .4rem;border-radius:3px;font-size:.7rem;font-weight:500}.reference-image-card .delete-button{width:24px;height:24px;background:#f44336b3;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,background .2s}.reference-image-card:hover .delete-button{opacity:1}.reference-image-card .delete-button:hover{background:#f44336}.image-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.image-preview-modal .modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.image-preview-modal .modal-content img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px}.image-preview-modal .modal-info{margin-top:1rem;text-align:center;color:#fffc}.image-preview-modal .modal-info .role{color:#42a5f5;font-size:.9rem;margin:0 0 .5rem}.image-preview-modal .modal-info .description{font-size:.85rem;margin:0}.image-preview-modal .close-button{position:absolute;top:-1rem;right:-1rem;width:2rem;height:2rem;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:background .2s}.image-preview-modal .close-button:hover{background:#fff3}.toast{position:fixed;bottom:2rem;right:2rem;background:#667eeaf2;color:#fff;padding:.875rem 1.5rem;border-radius:24px;display:flex;align-items:center;gap:.75rem;box-shadow:0 4px 16px #0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;animation:toastSlideIn .3s ease-out;min-width:200px;max-width:400px}.toast-loading{background:#667eeaf2}.toast-success{background:#4caf50f2}.toast-error{background:#f44336f2}.toast-info{background:#2196f3f2}.toast-icon{display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700}.toast-message{font-size:.9rem;font-weight:500;flex:1}.toast-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:toastSpin .8s linear infinite}@keyframes toastSlideIn{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes toastSpin{to{transform:rotate(360deg)}}@media (max-width: 768px){.toast{bottom:5rem;right:1rem;left:1rem;max-width:none;padding:.75rem 1.25rem}}.tag-manager{margin-bottom:1.5rem}.tag-manager-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.tag-manager-label{display:block;color:#ffffffe6;font-weight:500;font-size:.95rem}.tag-count{display:inline-block;padding:.125rem .5rem;background:#ffffff1a;border-radius:12px;color:#ffffffb3;font-size:.75rem;font-weight:500}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding:.75rem;background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:8px;min-height:3rem}.tag-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:16px;color:#fff;font-size:.85rem;font-weight:500;box-shadow:0 2px 4px #0003;transition:transform .1s,box-shadow .1s}.tag-badge:hover{transform:translateY(-1px);box-shadow:0 3px 6px #0000004d}.tag-name{-webkit-user-select:none;user-select:none}.tag-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;background:#fff3;border:none;border-radius:50%;color:#fff;font-size:1.125rem;line-height:1;cursor:pointer;transition:background .15s}.tag-remove:hover{background:#ffffff4d}.tag-remove:active{background:#fff6}.tag-remove:disabled{opacity:.5;cursor:not-allowed}.tag-input-container{position:relative;flex:1;min-width:140px}.tag-input{width:100%;padding:.5rem .75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:16px;color:#fff;font-size:.85rem;outline:none;transition:border-color .2s,background .2s}.tag-input::placeholder{color:#fff6}.tag-input:focus{background:#ffffff14;border-color:#ffffff4d}.tag-input:disabled{opacity:.5;cursor:not-allowed}.tag-suggestions{position:absolute;top:calc(100% + .375rem);left:0;right:0;max-height:240px;overflow-y:auto;background:#1e1e1efa;border:1px solid rgba(255,255,255,.15);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tag-suggestion{display:flex;align-items:center;gap:.625rem;padding:.625rem .75rem;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.05)}.tag-suggestion:last-child{border-bottom:none}.tag-suggestion:hover,.tag-suggestion.selected{background:#ffffff14}.tag-suggestion-color{width:12px;height:12px;border-radius:50%;flex-shrink:0}.tag-suggestion-name{flex:1;color:#fffffff2;font-size:.9rem;font-weight:500}.tag-suggestion-category{padding:.125rem .5rem;background:#ffffff1a;border-radius:10px;color:#fff9;font-size:.75rem;text-transform:uppercase;letter-spacing:.03em}.tag-suggestion-count{padding:.125rem .375rem;background:#ffffff0d;border-radius:10px;color:#ffffff80;font-size:.75rem;font-weight:500}.tag-empty-message{color:#fff6;font-size:.9rem;font-style:italic;margin:0}.tag-suggestions::-webkit-scrollbar{width:8px}.tag-suggestions::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.tag-suggestions::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.tag-suggestions::-webkit-scrollbar-thumb:hover{background:#ffffff40}.clothing-item-outfits{padding:var(--spacing-4)}.clothing-item-outfits-loading,.clothing-item-outfits-error,.clothing-item-outfits-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);text-align:center;min-height:300px}.clothing-item-outfits-empty .empty-icon{font-size:48px;margin-bottom:var(--spacing-4)}.clothing-item-outfits-empty h3{margin:0 0 var(--spacing-2) 0;color:var(--color-text-primary)}.clothing-item-outfits-empty p{margin:var(--spacing-2) 0;color:var(--color-text-secondary)}.clothing-item-outfits-empty .create-outfit-link{display:inline-block;margin-top:var(--spacing-4);padding:var(--spacing-3) var(--spacing-5);background:var(--color-primary);color:#fff;text-decoration:none;border-radius:var(--radius-md);font-weight:500;transition:background-color .2s}.clothing-item-outfits-empty .create-outfit-link:hover{background:var(--color-primary-hover)}.clothing-item-outfits-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.clothing-item-outfits-header h3{margin:0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.outfits-count{color:var(--color-text-tertiary);font-size:14px}.clothing-item-outfits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-4)}.outfit-card{display:flex;flex-direction:column;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;transition:all .2s;cursor:pointer}.outfit-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.outfit-card-image{width:100%;height:180px;background:var(--color-background-tertiary);overflow:hidden;display:flex;align-items:center;justify-content:center}.outfit-card-image img{width:100%;height:100%;object-fit:cover}.outfit-card-content{padding:var(--spacing-3);flex:1;display:flex;flex-direction:column;gap:var(--spacing-2)}.outfit-card-title{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.outfit-card-items{margin:0;font-size:14px;color:var(--color-text-secondary)}.outfit-card-notes{margin:0;font-size:14px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.outfit-card-date{margin:auto 0 0;font-size:12px;color:var(--color-text-tertiary)}.clothing-item-similar{padding:var(--spacing-4)}.clothing-item-similar-loading,.clothing-item-similar-error,.clothing-item-similar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);text-align:center;min-height:300px}.clothing-item-similar-empty .empty-icon{font-size:48px;margin-bottom:var(--spacing-4)}.clothing-item-similar-empty h3{margin:0 0 var(--spacing-2) 0;color:var(--color-text-primary)}.clothing-item-similar-empty p{margin:var(--spacing-2) 0;color:var(--color-text-secondary)}.clothing-item-similar-empty .hint{font-size:14px;color:var(--color-text-tertiary);font-style:italic}.clothing-item-similar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border)}.clothing-item-similar-header h3{margin:0;font-size:20px;font-weight:600;color:var(--color-text-primary)}.similar-count{color:var(--color-text-tertiary);font-size:14px}.clothing-item-similar-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-4)}.similar-item-card{display:flex;flex-direction:column;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;text-decoration:none;transition:all .2s;cursor:pointer;position:relative}.similar-item-card:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.similar-item-card-image{width:100%;height:180px;background:var(--color-background-tertiary);overflow:hidden;display:flex;align-items:center;justify-content:center}.similar-item-card-image img{width:100%;height:100%;object-fit:cover}.similar-item-card-content{padding:var(--spacing-3);flex:1;display:flex;flex-direction:column;gap:var(--spacing-2)}.similarity-badge{position:absolute;top:8px;right:8px;background:#4caf50f2;color:#fff;padding:4px 12px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 2px 8px #0003}.similar-item-card-title{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.similar-item-card-category,.similar-item-card-color,.similar-item-card-fabric{margin:0;font-size:14px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.model-selector{display:flex;flex-direction:column;gap:.375rem}.model-selector-select{width:100%;padding:.5rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;font-size:.875rem;background-color:#0000004d;color:#fff;cursor:pointer;transition:border-color .2s}.model-selector-select:hover:not(:disabled){border-color:#fff6}.model-selector-select:focus{outline:none;border-color:#3b82f699;box-shadow:0 0 0 2px #3b82f61a}.model-selector-select:disabled{background-color:#0003;cursor:not-allowed;opacity:.6}.model-selector-hint{font-size:.75rem;color:#fff9;display:block;margin-top:.25rem}.model-selector-error .model-selector-error-text{color:#ef4444;display:block;margin-top:.25rem}.model-selector-empty,.model-selector-error{opacity:.8}.two-column-tool-layout{width:100%;max-width:1400px;margin:0 auto;padding:1rem}.tool-header{margin:1.5rem 0 2rem}.tool-title{font-size:2rem;font-weight:600;margin:0 0 .5rem;color:#fff}.tool-description{font-size:1rem;color:#ffffffb3;margin:0}.tool-error-message{background-color:#ff44441a;border:1px solid #ff4444;border-radius:4px;padding:1rem;margin-bottom:1.5rem;color:#f44}.tool-error-message strong{font-weight:600}.tool-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}.tool-column{background-color:#ffffff0d;border-radius:8px;padding:1.5rem;min-height:400px}.tool-column-title{font-size:1.25rem;font-weight:600;margin:0 0 1.5rem;color:#fff;border-bottom:2px solid rgba(255,255,255,.1);padding-bottom:.75rem}@media (max-width: 768px){.tool-content{grid-template-columns:1fr}}.entity-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:999;padding:2rem}.entity-selector-modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);max-width:600px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0006}.entity-selector-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1)}.entity-selector-header h2{color:#fff;margin:0;font-size:1.25rem}.entity-selector-close{background:none;border:none;color:#fff9;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.entity-selector-close:hover{color:#fff}.entity-selector-body{padding:1.5rem 2rem;flex:1;overflow:hidden;display:flex;flex-direction:column}.entity-selector-search{margin-bottom:1rem}.entity-selector-search input{width:100%;padding:.75rem 1rem;background:#0000004d;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:#fff;font-size:.95rem}.entity-selector-search input:focus{outline:none;border-color:#8b5cf680;box-shadow:0 0 0 2px #8b5cf61a}.entity-selector-list{flex:1;overflow-y:auto;margin:0 -.5rem;padding:0 .5rem}.entity-selector-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#ffffff0d;border-radius:var(--radius-md);margin-bottom:.5rem;cursor:pointer;transition:all .2s}.entity-selector-item:hover{background:#8b5cf633;transform:translate(4px)}.entity-selector-item-name{color:#fff;font-weight:500;flex:1}.entity-selector-item-id{font-family:Courier New,monospace;font-size:.75rem;color:#ffffff80;margin-left:1rem}.entity-selector-empty{text-align:center;color:#fff9;padding:2rem;font-style:italic}@media (max-width: 768px){.entity-selector-overlay{padding:1rem}.entity-selector-modal{max-height:85vh}.entity-selector-header,.entity-selector-body{padding:1rem 1.5rem}.entity-selector-item{padding:.75rem}.entity-selector-item-name{font-size:.9rem}}.merge-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.merge-modal{background:var(--color-bg-secondary);border-radius:var(--radius-lg);max-width:1200px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0006}.merge-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.1);position:sticky;top:0;background:var(--color-bg-secondary);z-index:10}.merge-modal-header h2{color:var(--color-surface-default);margin:0;font-size:1.5rem}.merge-close-btn{background:none;border:none;color:#fff9;font-size:2rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.merge-close-btn:hover{color:var(--color-surface-default)}.merge-modal-body{padding:2rem}.merge-error{background:#ff52521a;border:1px solid rgba(255,82,82,.3);color:#ff5252;padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem}.merge-step h3{color:var(--color-surface-default);margin:0 0 1.5rem;font-size:1.25rem}.merge-entities-side-by-side{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:2rem}.merge-entity-column{background:#ffffff0d;border-radius:var(--radius-md);padding:1.5rem}.merge-column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.1)}.merge-label{color:#ffffffe6;font-weight:600;font-size:.95rem}.merge-entity-id{font-family:Courier New,monospace;font-size:.75rem;color:#ffffff80}.merge-entity-details{display:flex;flex-direction:column;gap:.75rem}.merge-detail-row{display:flex;gap:.5rem}.merge-detail-label{color:#fff9;font-size:.85rem;font-weight:500;min-width:120px;flex-shrink:0}.merge-detail-value{color:#ffffffe6;font-size:.85rem;flex:1;overflow:hidden;text-overflow:ellipsis}.merge-references{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:2rem}.merge-references h4{color:var(--color-surface-default);margin:0 0 1rem;font-size:1rem}.merge-no-references{color:#fff9;margin:0;font-style:italic}.merge-reference-list{display:flex;flex-direction:column;gap:1rem}.merge-reference-group{color:#fffc}.merge-reference-group strong{display:block;margin-bottom:.5rem;color:var(--color-surface-default)}.merge-reference-group ul{margin:0;padding-left:1.5rem;color:#ffffffb3}.merge-reference-count{display:inline-block;background:#ffffff1a;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.85rem}.merge-summary{background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem}.merge-summary p{color:#ffffffe6;margin:0}.merge-summary strong{color:var(--color-info);padding:0 .25rem}.merge-preview{background:#ffffff0d;border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem}.merge-preview h4{color:var(--color-surface-default);margin:0 0 1rem;font-size:1rem}.merge-fields{display:flex;flex-direction:column;gap:1rem}.merge-field{display:flex;flex-direction:column;gap:.5rem}.merge-field label{color:#ffffffb3;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.merge-field input,.merge-field textarea{width:100%;padding:.75rem;background:#0000004d;border:1px solid var(--color-border-strong);border-radius:var(--radius-base);color:var(--color-surface-default);font-family:inherit;font-size:.9rem;resize:vertical}.merge-field input:focus,.merge-field textarea:focus{outline:none;border-color:#8b5cf680;box-shadow:0 0 0 2px #8b5cf61a}.merge-array-field{display:flex;flex-wrap:wrap;gap:.5rem}.merge-array-item{background:#8b5cf633;color:var(--color-surface-default);padding:.25rem .75rem;border-radius:var(--radius-lg);font-size:.85rem}.merge-warning{background:#ff98001a;border:1px solid rgba(255,152,0,.3);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem}.merge-warning strong{color:#ffa726;display:block;margin-bottom:.75rem}.merge-warning ul{color:#fffc;margin:.75rem 0;padding-left:1.5rem}.merge-warning p{color:#fff9;margin:.75rem 0 0;font-size:.9rem;font-style:italic}.merge-actions{display:flex;justify-content:flex-end;gap:1rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.1)}.merge-btn{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.merge-btn:disabled{opacity:.5;cursor:not-allowed}.merge-btn-secondary{background:#ffffff1a;color:var(--color-surface-default)}.merge-btn-secondary:hover:not(:disabled){background:#ffffff26}.merge-btn-primary{background:linear-gradient(135deg,#8b5cf6,var(--color-brand-primary));color:var(--color-surface-default)}.merge-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.merge-btn-danger{background:linear-gradient(135deg,var(--color-error),var(--color-error));color:var(--color-surface-default)}.merge-btn-danger:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #ef444466}@media (max-width: 768px){.merge-modal-overlay{padding:1rem}.merge-entities-side-by-side{grid-template-columns:1fr;gap:1rem}.merge-modal-header{padding:1rem 1.5rem}.merge-modal-body{padding:1.5rem}.merge-actions{flex-direction:column-reverse}.merge-btn{width:100%}}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.contract-dependency-graph{position:relative;width:100%;height:calc(100vh - 250px);min-height:600px;display:flex;flex-direction:column}.graph-container{flex:1;width:100%;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;overflow:hidden}.graph-legend{position:absolute;top:16px;right:16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px;box-shadow:0 2px 8px #0000001a;z-index:10;max-width:200px}.legend-title{font-weight:600;font-size:13px;margin-bottom:8px;color:#1e293b}.legend-items{display:flex;flex-direction:column;gap:6px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#475569}.legend-color{width:16px;height:16px;border-radius:4px;border:1px solid rgba(255,255,255,.3)}.legend-symbols{display:flex;flex-direction:column;gap:4px}.legend-symbol{font-size:11px;color:#64748b;display:flex;align-items:center;gap:4px}.legend-symbol span:first-child{width:16px;text-align:center}.contract-node{display:flex;flex-direction:column;gap:6px}.contract-node-title{font-weight:600;font-size:13px;text-align:center;word-break:break-word}.contract-node-stats{display:flex;justify-content:center;gap:8px;font-size:11px;opacity:.9}.producer-count,.consumer-count{display:flex;align-items:center;gap:2px}.graph-instructions{margin-top:12px;padding:12px;background:#f1f5f9;border-radius:6px;text-align:center}.graph-instructions p{margin:0;font-size:13px;color:#475569}.graph-instructions strong{color:#1e293b}.contract-graph-loading,.contract-graph-error,.contract-graph-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;color:#64748b}.contract-graph-loading .spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.contract-graph-error p{color:#ef4444;font-size:14px}.contract-graph-empty p{font-size:14px}.contract-dependency-graph .react-flow__node{cursor:pointer}.contract-dependency-graph .react-flow__node:hover{filter:brightness(1.1);transform:scale(1.02);transition:all .2s ease}.contract-dependency-graph .react-flow__edge-path{stroke-width:2}.contract-dependency-graph .react-flow__edge:hover .react-flow__edge-path{stroke-width:3}.contract-dependency-graph .react-flow__controls{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #0000001a}.contract-dependency-graph .react-flow__controls-button{background:#fff;border-bottom:1px solid #e2e8f0}.contract-dependency-graph .react-flow__controls-button:hover{background:#f8fafc}.contract-dependency-graph .react-flow__background{background-color:#f8fafc}.contracts-page{padding:2rem;max-width:1400px;margin:0 auto}.contracts-header{margin-bottom:2rem}.contracts-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--color-text-primary)}.contracts-header .subtitle{margin:0;color:var(--color-text-secondary);font-size:1.1rem}.view-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--color-border-default)}.view-tabs .tab{padding:.75rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:var(--color-text-secondary);transition:all var(--transition-base)}.view-tabs .tab:hover{color:var(--color-text-primary);background:var(--color-surface-hover)}.view-tabs .tab.active{color:var(--color-brand-primary);border-bottom-color:var(--color-brand-primary);background:var(--color-surface-subtle)}.search-bar{margin-bottom:1.5rem}.search-bar input{width:100%;padding:.75rem 1rem;font-size:1rem;background:var(--color-surface-default);color:var(--color-text-primary);border:2px solid var(--color-border-default);border-radius:var(--radius-lg);transition:border-color var(--transition-base)}.search-bar input:focus{outline:none;border-color:var(--color-brand-primary)}.search-bar input::placeholder{color:var(--color-text-tertiary)}.error-message{padding:1rem;background:#ef44441a;border:1px solid rgb(239,68,68);border-radius:var(--radius-lg);color:#fca5a5;margin-bottom:1.5rem}.contracts-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.loading,.empty-message{text-align:center;padding:3rem;color:var(--color-text-secondary);font-size:1.1rem}.contract-card{padding:1.5rem;background:var(--color-surface-default);border:2px solid var(--color-border-default);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-base)}.contract-card:hover{border-color:var(--color-brand-primary);transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000004d,0 4px 6px -2px #0003}.contract-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.contract-card-header h3{margin:0;font-size:1.25rem;color:var(--color-text-primary);flex:1}.version-badge{padding:.25rem .75rem;background:var(--color-brand-primary);color:var(--color-text-inverse);border-radius:var(--radius-full);font-size:.85rem;font-weight:600}.contract-description{margin:0 0 1rem;color:var(--color-text-secondary);line-height:1.5;font-size:.95rem}.contract-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border-default)}.meta-item{font-size:.85rem;color:var(--color-text-secondary)}.contract-detail{max-width:900px;margin:0 auto}.back-button{padding:.5rem 1rem;background:var(--color-surface-default);border:2px solid var(--color-border-default);border-radius:var(--radius-lg);cursor:pointer;font-size:.95rem;color:var(--color-text-primary);margin-bottom:1.5rem;transition:all var(--transition-base)}.back-button:hover{border-color:var(--color-brand-primary);color:var(--color-brand-primary)}.detail-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:2px solid var(--color-border-default)}.detail-header h2{margin:0 0 .5rem;font-size:2rem;color:var(--color-text-primary)}.detail-description{margin:.5rem 0 0;color:var(--color-text-secondary);line-height:1.6;font-size:1.1rem}.contract-relationships{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.relationship-section h3{margin:0 0 1rem;font-size:1.1rem;color:var(--color-text-primary)}.relationship-list{display:flex;flex-wrap:wrap;gap:.5rem}.relationship-tag{padding:.5rem 1rem;background:var(--color-surface-subtle);border-radius:var(--radius-md);font-size:.9rem;color:var(--color-text-primary);font-family:var(--font-mono)}.empty-text{color:var(--color-text-tertiary);font-style:italic;font-size:.9rem}.schema-section,.guidance-section,.example-section,.io-section{margin-bottom:2rem}.schema-section h3,.guidance-section h3,.example-section h3,.io-section h3{margin:0 0 1rem;font-size:1.25rem;color:var(--color-text-primary)}.schema-display{background:var(--color-surface-subtle);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);padding:1.5rem;overflow-x:auto;font-family:var(--font-mono);font-size:.9rem;line-height:1.5;color:var(--color-text-primary);margin:0;max-height:600px;overflow-y:auto}.guidance-items{display:flex;flex-direction:column;gap:1rem}.guidance-item{padding:1rem;background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-lg);line-height:1.6;color:var(--color-text-primary)}.guidance-item strong{color:var(--color-brand-primary);font-family:var(--font-mono);display:block;margin-bottom:.5rem}.tool-metadata{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;background:var(--color-surface-subtle);border-radius:var(--radius-lg);margin-bottom:2rem}.metadata-item{font-size:.95rem;color:var(--color-text-primary)}.metadata-item strong{color:var(--color-text-secondary);margin-right:.5rem}.domain-contracts-list{margin-bottom:1rem;padding:1rem;background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-lg)}.domain-contracts-list strong{display:block;margin-bottom:.75rem;color:var(--color-text-secondary)}@media (max-width: 768px){.contracts-page{padding:1rem}.contracts-list,.contract-relationships{grid-template-columns:1fr}.view-tabs .tab{padding:.5rem 1rem;font-size:.9rem;min-height:44px}.detail-header h2{font-size:1.5rem}.schema-display{font-size:.75rem;padding:1rem}.back-button{min-height:44px}.contract-card{min-height:120px}}.contract-card:focus-visible,.back-button:focus-visible,.view-tabs .tab:focus-visible{outline:2px solid var(--color-brand-primary);outline-offset:2px}.contract-health-dashboard{padding:2rem;max-width:1400px;margin:0 auto}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.dashboard-header h1{margin:0;font-size:2rem;color:var(--color-text-primary)}.dashboard-header .subtitle{margin:.25rem 0 0;color:var(--color-text-secondary);font-size:.95rem;flex-basis:100%}.refresh-button,.retry-button{padding:.6rem 1.2rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;transition:all .2s}.refresh-button:hover,.retry-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.overall-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.metric-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;text-align:center;transition:all .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.metric-card.primary{border:2px solid var(--color-primary);background:linear-gradient(135deg,var(--color-surface) 0%,var(--color-bg-secondary) 100%)}.metric-card.success{border-color:var(--color-success)}.metric-card.error{border-color:var(--color-error)}.metric-label{font-size:.9rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.metric-value{font-size:2rem;font-weight:700;color:var(--color-text-primary);margin:.5rem 0}.metric-value.large{font-size:3rem}.metric-sublabel{font-size:.85rem;color:var(--color-text-secondary);font-weight:600;margin-top:.25rem}.tools-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.tools-section h2{margin:0 0 1rem;font-size:1.5rem;color:var(--color-text-primary)}.tools-table{overflow-x:auto}.tools-table table{width:100%;border-collapse:collapse}.tools-table th{text-align:left;padding:.75rem 1rem;background:var(--color-bg-secondary);color:var(--color-text-secondary);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--color-border)}.tools-table td{padding:1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-primary)}.tools-table tr:hover{background:var(--color-bg-secondary)}.tools-table tr.selected{background:var(--color-primary-light)}.tool-id{font-family:monospace;font-weight:600;color:var(--color-primary)}.success-count{color:var(--color-success);font-weight:600}.error-count{color:var(--color-error);font-weight:600}.compliance-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;color:#fff;font-weight:600;font-size:.9rem}.status-badge{font-weight:600;font-size:.9rem}.view-details-button{padding:.5rem 1rem;background:var(--color-info);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.view-details-button:hover{background:var(--color-info-dark);transform:translateY(-1px)}.tool-details-panel{background:var(--color-surface);border:2px solid var(--color-primary);border-radius:12px;padding:1.5rem;margin-bottom:2rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.panel-header h3{margin:0;color:var(--color-text-primary);font-size:1.25rem}.close-button{background:transparent;border:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:.25rem .5rem;transition:all .2s}.close-button:hover{color:var(--color-error);transform:scale(1.1)}.no-issues-message{text-align:center;padding:2rem;color:var(--color-success);font-size:1.1rem;font-weight:600}.issues-list{display:flex;flex-direction:column;gap:1rem}.issue-card{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.issue-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;cursor:pointer;transition:background .2s;gap:1rem}.issue-header:hover{background:var(--color-surface)}.issue-timestamp{font-size:.85rem;color:var(--color-text-secondary);font-family:monospace;flex-shrink:0}.issue-summary{color:var(--color-error);font-weight:600;font-size:.9rem;flex:1}.expand-icon{color:var(--color-text-secondary);font-size:.9rem;flex-shrink:0}.issue-details{padding:0 1rem 1rem;border-top:1px solid var(--color-border)}.issue-section{margin-top:1rem}.issue-section h4{margin:0 0 .5rem;color:var(--color-error);font-size:.95rem}.issue-section.warning h4{color:var(--color-warning)}.issue-section ul{list-style:none;padding:0;margin:0}.issue-section li{padding:.5rem;margin:.25rem 0;background:var(--color-surface);border-left:3px solid var(--color-error);border-radius:4px;font-size:.9rem}.issue-section.warning li{border-left-color:var(--color-warning)}.issue-section strong{color:var(--color-primary);font-family:monospace}.issue-section code{background:var(--color-bg-tertiary);padding:.2rem .4rem;border-radius:4px;font-family:monospace;font-size:.85rem}.type-mismatch{margin-top:.5rem;padding:.5rem;background:var(--color-bg-tertiary);border-radius:4px;font-size:.85rem}.loading,.error-message,.empty-message{text-align:center;padding:3rem;color:var(--color-text-secondary);font-size:1.1rem}.error-message{color:var(--color-error);background:var(--color-surface);border:2px solid var(--color-error);border-radius:12px;margin:2rem 0}@media (max-width: 768px){.contract-health-dashboard{padding:1rem}.overall-metrics{grid-template-columns:1fr}.dashboard-header{flex-direction:column;align-items:flex-start}.tools-table{font-size:.85rem}.tools-table th,.tools-table td{padding:.5rem}.issue-header{flex-direction:column;align-items:flex-start}}.component-showcase{max-width:1200px;margin:0 auto;padding:var(--spacing-8)}.showcase-header{margin-bottom:var(--spacing-12)}.showcase-header h1{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-3) 0}.showcase-header p{font-size:var(--text-lg);color:var(--color-text-secondary);margin:0}.showcase-section{margin-bottom:var(--spacing-16);padding:var(--spacing-8);background:var(--color-surface-default);border:1px solid var(--color-border-default);border-radius:var(--radius-lg)}.showcase-section h2{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-8) 0;padding-bottom:var(--spacing-4);border-bottom:2px solid var(--color-border-default)}.showcase-group{margin-bottom:var(--spacing-8)}.showcase-group:last-child{margin-bottom:0}.showcase-group h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-4) 0}.showcase-row{display:flex;gap:var(--spacing-4);flex-wrap:wrap;align-items:center}.showcase-actions{display:flex;gap:var(--spacing-4);margin-top:var(--spacing-6)}@media (max-width: 768px){.component-showcase,.showcase-section{padding:var(--spacing-4)}.showcase-row{flex-direction:column;align-items:stretch}.showcase-actions{flex-direction:column}}.story-workflow-page{padding:2rem;max-width:1400px;margin:0 auto}.story-header{margin-bottom:2rem}.story-header h2{margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.story-subtitle{color:var(--color-text-secondary);font-size:1rem;margin:0}.story-info{margin-bottom:2rem}.story-info .info-box{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.story-info .info-box h3{margin:0 0 1rem;font-size:1.1rem;font-weight:600}.story-info .info-box ol{margin:0 0 1rem;padding-left:1.5rem}.story-info .info-box li{margin-bottom:.5rem;line-height:1.5}.story-info .info-note{color:var(--color-text-secondary);font-size:.9rem;margin:0}.story-form{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:2rem}.story-form-header{margin-bottom:2rem}.story-form-eyebrow{color:var(--color-primary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.story-form-header h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.story-form-subtitle{color:var(--color-text-secondary);font-size:.95rem;margin:0}.form-section{margin-bottom:2rem}.form-section h3{font-size:1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;font-size:.95rem}.form-group select,.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:6px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.form-group select:disabled,.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group small{display:block;margin-top:.5rem;color:var(--color-text-tertiary);font-size:.85rem}.error-message{background:#f443361a;border:1px solid rgba(244,67,54,.3);color:#f44336;padding:1rem;border-radius:6px;margin-bottom:1rem}.success-message{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50;padding:1rem;border-radius:6px;margin-bottom:1rem}.story-form-cta{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.generate-button{background:linear-gradient(135deg,var(--color-primary) 0%,#7c3aed 100%);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.generate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.generate-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.tab-content{padding:1.5rem 0}.workflow-info{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;padding:2rem}.workflow-config-section{margin-bottom:2rem}.workflow-config-section:last-child{margin-bottom:0}.config-section-header{margin-bottom:1.5rem}.config-eyebrow{color:var(--color-primary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.config-section-header h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.config-subtitle{color:var(--color-text-secondary);font-size:.95rem;margin:0}.tool-contract-card{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem}.tool-contract-header{margin-bottom:1rem}.tool-contract-header h4{margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.tool-contract-header p{color:var(--color-text-secondary);font-size:.9rem;margin:0}.tool-contract-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.tool-contract-meta>div{display:flex;flex-direction:column;gap:.25rem}.tool-contract-meta .label{font-size:.8rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.tool-contract-meta code{background:var(--color-bg-primary);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-family:SF Mono,Monaco,Inconsolata,monospace}.workflow-steps{margin:0;padding-left:1.5rem}.workflow-steps li{margin-bottom:1rem;line-height:1.5}.workflow-steps li:last-child{margin-bottom:0}.workflow-steps strong{color:var(--color-text-primary)}.workflow-steps p{margin:.25rem 0 0;color:var(--color-text-secondary);font-size:.9rem}@media (max-width: 768px){.story-workflow-page{padding:1rem}.story-form,.workflow-info{padding:1.5rem}.tool-contract-meta{grid-template-columns:1fr 1fr}}.direct-upload-provider{display:flex;flex-direction:column;gap:1.5rem}@media (max-width: 768px){.upload-actions{flex-direction:column-reverse}.upload-actions button{width:100%}}.image-upload-provider{display:flex;flex-direction:column;gap:1.5rem}.upload-header{text-align:center}.upload-header h3{font-size:1.3rem;color:var(--color-text-primary);margin-bottom:.5rem}.upload-header p{color:var(--color-text-secondary);font-size:1rem}.upload-area{position:relative}.file-input{display:none}.file-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem 2rem;background:var(--color-surface-subtle);border:2px dashed var(--color-border-strong);border-radius:var(--radius-lg);cursor:pointer;transition:all .3s;min-height:200px}.file-label:hover{background:var(--color-surface-hover);border-color:var(--color-brand-primary)}.upload-icon{font-size:3rem;opacity:.7}.upload-text{text-align:center}.file-prompt{font-size:1.1rem;color:var(--color-text-primary);font-weight:500}.file-hint{font-size:.9rem;color:var(--color-text-tertiary);margin-top:.5rem}.image-preview-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.image-preview{max-width:100%;max-height:300px;border-radius:var(--radius-md);object-fit:contain;box-shadow:0 4px 6px #0000004d}.file-info-overlay{text-align:center}.file-name{font-size:1.1rem;color:var(--color-text-primary);font-weight:500;margin-bottom:.5rem;word-break:break-word}.file-size{font-size:.9rem;color:var(--color-text-secondary)}.error-message{padding:1rem;background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);text-align:center}.upload-progress{display:flex;flex-direction:column;gap:.5rem}.progress-bar{width:100%;height:8px;background:var(--color-surface-subtle);border-radius:var(--radius-sm);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);transition:width .3s ease}.progress-text{text-align:center;font-size:.9rem;color:var(--color-text-secondary)}.upload-actions{display:flex;gap:1rem;justify-content:flex-end}.upload-actions .btn-primary{padding:.75rem 2rem;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);border:none;border-radius:var(--radius-md);color:var(--color-surface-default);font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.upload-actions .btn-primary:hover:not(:disabled){transform:translateY(-2px);opacity:.9}.upload-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.upload-actions .btn-secondary{padding:.75rem 1.5rem;background:var(--color-surface-hover);border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.upload-actions .btn-secondary:hover:not(:disabled){background:var(--color-surface-active)}.upload-actions .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.upload-info{padding:1rem;background:var(--color-surface-subtle);border-left:3px solid var(--color-brand-primary);border-radius:var(--radius-sm);font-size:.9rem;color:var(--color-text-secondary)}.upload-info strong{color:var(--color-text-primary)}@media (max-width: 768px){.upload-actions{flex-direction:column-reverse}.upload-actions button{width:100%}.image-preview{max-height:200px}}.media-provider-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.media-provider-modal{background:var(--color-bg-primary);border:1px solid var(--color-border-strong);border-radius:var(--radius-lg);width:90%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl)}.media-provider-modal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 2rem;border-bottom:1px solid var(--color-border-subtle)}.media-provider-modal .modal-header h2{font-size:1.5rem;color:var(--color-text-primary);margin:0}.media-provider-modal .close-button{background:none;border:none;font-size:1.5rem;color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-sm);transition:background .2s,color .2s}.media-provider-modal .close-button:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.media-provider-modal .modal-tabs{display:flex;gap:.5rem;padding:0 2rem;border-bottom:1px solid var(--color-border-subtle);background:var(--color-surface-subtle)}.media-provider-modal .tab{background:none;border:none;padding:1rem 1.5rem;font-size:1rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:color .2s,border-color .2s;white-space:nowrap}.media-provider-modal .tab:hover{color:var(--color-text-primary)}.media-provider-modal .tab.active{color:var(--color-brand-primary);border-bottom-color:var(--color-brand-primary)}.media-provider-modal .modal-body{flex:1;overflow-y:auto;padding:2rem}@media (max-width: 768px){.media-provider-modal{width:95%;max-height:95vh}.media-provider-modal .modal-header{padding:1rem}.media-provider-modal .modal-tabs{padding:0 1rem}.media-provider-modal .tab{padding:.75rem 1rem;font-size:.9rem}.media-provider-modal .modal-body{padding:1rem}}.workflow-panel{margin-top:2rem;border:1px solid var(--color-border-default);border-radius:var(--radius-lg, .75rem);background:var(--color-surface-default);box-shadow:var(--shadow-sm);overflow:hidden}.workflow-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border-subtle)}.workflow-panel-header h3{margin:0;font-size:1.1rem}.workflow-panel-subtitle{margin:.25rem 0 0;color:var(--color-text-secondary);font-size:.9rem}.workflow-refresh{padding:.4rem 1rem;border:1px solid var(--color-border-default);border-radius:6px;background:transparent;cursor:pointer}.workflow-refresh:disabled{opacity:.5;cursor:not-allowed}.workflow-panel-empty,.workflow-panel-error{padding:1rem 1.25rem;font-size:.95rem;color:var(--color-text-secondary)}.workflow-panel-error{color:var(--color-error)}.workflow-table-wrapper{overflow-x:auto}.workflow-table{width:100%;border-collapse:collapse;font-size:.95rem}.workflow-table th,.workflow-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border-subtle);text-align:left}.workflow-status-wrapper{display:flex;align-items:center;gap:.5rem}.workflow-step-count{font-size:.85rem;color:var(--color-text-secondary)}.workflow-status{display:inline-flex;align-items:center;padding:.15rem .6rem;border-radius:999px;font-size:.8rem;font-weight:600;text-transform:capitalize}.workflow-status-running{background:var(--color-info-bg);color:var(--color-info)}.workflow-status-completed{background:var(--color-success-bg);color:var(--color-success)}.workflow-status-failed,.workflow-status-cancelled{background:var(--color-error-bg);color:var(--color-error)}.workflow-status-unknown{background:var(--color-border-subtle);color:var(--color-text-secondary)}.workflow-job-id{font-family:var(--font-mono, "JetBrains Mono", "Fira Mono", monospace);font-size:.85rem}.workflow-error-cell{max-width:280px;color:var(--color-text-secondary)}.workflow-actions{display:flex;gap:.5rem}.workflow-action-button{padding:.35rem .8rem;border:1px solid var(--color-border-default);border-radius:var(--radius-md, .5rem);background:var(--color-bg-primary);cursor:pointer;font-size:.85rem}.workflow-action-button.secondary{border-color:var(--color-border-subtle);color:var(--color-text-secondary)}.workflow-action-button:disabled{opacity:.5;cursor:not-allowed}.workflow-step-timings{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.workflow-step-timings-empty{color:var(--color-text-secondary)}.workflow-step-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.15rem .5rem;border-radius:999px;background:var(--color-surface-muted, rgba(0,0,0,.04));font-size:.75rem;border:1px solid var(--color-border-subtle)}.workflow-step-chip .chip-label{font-weight:600;text-transform:capitalize}.workflow-step-chip .chip-value{font-family:var(--font-mono, "JetBrains Mono", monospace);color:var(--color-text-secondary)}.workflow-step-chip.status-failed{border-color:var(--color-error-bg);background:var(--color-error-bg);color:var(--color-error)}.workflow-step-chip.status-completed{border-color:var(--color-success-bg);background:var(--color-success-bg);color:var(--color-success)}.workflow-data-flow-container{display:flex;flex-direction:column;gap:1.5rem;height:100%;min-height:600px}.workflow-data-flow-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;padding:1rem;background:var(--color-surface-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.workflow-data-flow-header h3{margin:0;font-size:1.25rem;color:var(--color-text-primary)}.workflow-description{margin:.5rem 0 0;font-size:.9rem;color:var(--color-text-secondary)}.workflow-meta{display:flex;flex-direction:column;gap:.5rem;align-items:flex-end}.workflow-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.workflow-meta-item .label{color:var(--color-text-tertiary);font-weight:600}.workflow-meta-item code{background:var(--color-surface);padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.8rem;color:var(--color-accent)}.workflow-legend{display:flex;gap:2rem;padding:.75rem 1rem;background:var(--color-surface-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border-subtle)}.legend-item{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:var(--color-text-secondary)}.legend-line{width:40px;height:2px}.legend-line.solid{background:var(--color-info)}.legend-line.dashed{background:linear-gradient(to right,var(--color-warning) 50%,transparent 50%);background-size:8px 2px;background-repeat:repeat-x}.workflow-data-flow-graph{flex:1;min-height:600px!important;height:600px!important;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-subtle);overflow:hidden}.workflow-data-flow-graph .react-flow{height:100%!important;width:100%!important}.workflow-data-flow-loading,.workflow-data-flow-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem;text-align:center;color:var(--color-text-secondary)}.workflow-data-flow-error{color:var(--color-error)}.error-detail{margin-top:.5rem;font-size:.9rem;color:var(--color-text-tertiary)}.workflow-node-content{display:flex;flex-direction:column;gap:.5rem}.workflow-node-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.25rem}.workflow-node-icon{font-size:1.25rem;line-height:1}.workflow-node-title{font-weight:600;font-size:1rem;color:var(--color-text-primary)}.workflow-node-label{font-weight:600;font-size:.95rem}.workflow-node-description{font-size:.85rem;color:var(--color-text-secondary);line-height:1.4;margin-bottom:.25rem}.workflow-node-tool{font-size:.8rem;color:var(--color-text-tertiary);padding-top:.5rem;border-top:1px solid var(--color-border-subtle)}.workflow-node-tool-label{font-weight:600;color:var(--color-text-secondary)}.workflow-node-io{font-size:.75rem;color:var(--color-text-tertiary);background:var(--color-surface-subtle);padding:.4rem .6rem;border-radius:var(--radius-sm);margin-top:.25rem}.workflow-node-io-label{font-weight:600;color:var(--color-accent)}.workflow-data-flow-graph .react-flow__node{cursor:grab}.workflow-data-flow-graph .react-flow__node:active{cursor:grabbing}.workflow-data-flow-graph .react-flow__edge-path{stroke-width:2}.workflow-data-flow-graph .react-flow__edge-text{font-size:11px;font-weight:600}.workflow-data-flow-graph .react-flow__controls{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.workflow-data-flow-graph .react-flow__controls-button{background:var(--color-surface);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-primary)}.workflow-data-flow-graph .react-flow__controls-button:hover{background:var(--color-surface-hover)}.workflow-data-flow-graph .react-flow__controls-button svg{fill:var(--color-text-primary)}.outfit-from-images{padding:2rem;max-width:1200px;margin:0 auto}.page-header h1{margin:0 0 .5rem;font-size:2rem;color:var(--color-text-primary)}.page-header p{margin:0;color:var(--color-text-secondary);font-size:1.1rem}.upload-form-container{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media (max-width: 968px){.upload-form-container{grid-template-columns:1fr}}.upload-form{background:var(--color-surface-subtle);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:2rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--color-text-primary)}.file-input,.text-input{width:100%;padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:1rem}.file-input:disabled,.text-input:disabled{opacity:.5;cursor:not-allowed}.help-text{margin:.5rem 0 0;font-size:.9rem;color:var(--color-text-tertiary)}.image-preview{margin-bottom:1.5rem}.preview-label{margin:0 0 .5rem;font-weight:600;color:var(--color-text-primary)}.preview-image{max-width:100%;max-height:300px;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.2);display:block}.submit-button{width:100%;padding:1rem;font-size:1.1rem;font-weight:600;margin-top:1rem}.info-section{background:var(--color-surface-subtle);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:2rem}.info-section h3{margin:0 0 1rem;color:var(--color-text-primary)}.info-section h3:not(:first-child){margin-top:2rem}.info-section ol,.info-section ul{margin:0;padding-left:1.5rem;color:var(--color-text-secondary);line-height:1.6}.alert{padding:1rem;border-radius:var(--radius-md);margin-bottom:1rem}.alert-error{background:#dc26261a;border:1px solid rgba(220,38,38,.3);color:#fca5a5}.alert-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac}.media-select-button{width:100%;padding:1rem;background:linear-gradient(135deg,var(--color-brand-primary) 0%,var(--color-brand-secondary) 100%);border:none;border-radius:var(--radius-md);color:var(--color-surface-default);font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.media-select-button:hover:not(:disabled){transform:translateY(-2px);opacity:.9}.media-select-button:disabled{opacity:.5;cursor:not-allowed}.help-text.selected-file{color:var(--color-brand-primary);font-weight:500}.outfit-from-video-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.page-header p{color:var(--text-secondary);font-size:1rem}.outfit-from-video-execute{max-width:800px;margin:0 auto}.workflow-description{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.workflow-description h3{font-size:1.3rem;color:var(--text-primary);margin-bottom:1rem}.workflow-description p{color:var(--text-secondary);margin-bottom:1rem;line-height:1.6}.workflow-description ol{margin-left:1.5rem;color:var(--text-secondary);line-height:1.8}.workflow-description ol li{margin-bottom:.5rem}.workflow-description ol li strong{color:var(--text-primary)}.workflow-form{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:2rem}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.form-group label .file-name{font-weight:400;color:var(--text-secondary);font-size:.9rem}.form-group input[type=file],.form-group input[type=text],.form-group input[type=number]{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem}.form-group input[type=file]{padding:.5rem}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-hint{display:block;margin-top:.5rem;color:var(--text-secondary);font-size:.875rem;line-height:1.4}.checkbox-group label{display:flex;align-items:center;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto;margin-right:.75rem;cursor:pointer}.checkbox-group label span{font-weight:400}.error-message{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error);padding:1rem;border-radius:4px;margin-bottom:1.5rem}.error-message strong{font-weight:600}.btn-primary{width:100%;padding:1rem;background:var(--color-brand-primary);color:var(--color-text-on-brand);border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-primary:hover:not(:disabled){background:var(--color-brand-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (prefers-color-scheme: dark){.workflow-description{background:var(--color-surface-elevated)}.workflow-form{background:var(--color-surface-default)}.form-group input[type=file],.form-group input[type=text],.form-group input[type=number]{background:var(--color-surface-elevated)}}@media (max-width: 768px){.outfit-from-video-page{padding:1rem}.page-header h1{font-size:1.5rem}.workflow-description,.workflow-form{padding:1rem}}.cei-page{padding:2rem;max-width:900px;margin:0 auto}.cei-page h1{margin-bottom:.25rem}.cei-description{color:var(--text-muted, #6b7280);margin-bottom:1.5rem}.cei-card{background:var(--card-bg, #111827);border:1px solid var(--card-border, #1f2937);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.cei-field{margin-bottom:1.25rem}.cei-field label{display:block;font-weight:600;margin-bottom:.5rem}.cei-file-input{width:100%;padding:1rem;border:1px dashed var(--card-border, #1f2937);border-radius:8px;background:var(--input-bg, #0f172a);color:inherit}.cei-category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.cei-category-chip{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;border:1px solid var(--card-border, #1f2937);background:var(--chip-bg, #111827);cursor:pointer;transition:border-color .15s ease,background .15s ease}.cei-category-chip.cei-selected{border-color:#a855f7;background:#a855f71a}.cei-actions{display:flex;gap:1rem;align-items:center}.cei-actions button{border:none;border-radius:8px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer}.cei-actions button.primary{background:linear-gradient(135deg,#a855f7,#6366f1);color:#fff}.cei-actions button.secondary{background:transparent;color:var(--text-muted, #9ca3af)}.cei-error{color:#f87171;margin-top:.75rem}.cei-results{margin-top:2rem}.cei-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}.cei-stub-card{border:1px solid var(--card-border, #1f2937);border-radius:12px;padding:1rem;background:var(--card-bg, #111827)}.cei-stub-card h3{margin:0 0 .5rem;font-size:1.1rem}.cei-stub-meta{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-muted, #9ca3af);margin-bottom:.5rem}.cei-evidence-list{margin-top:.75rem;font-size:.85rem;color:var(--text-muted, #9ca3af)}.tool-page{padding:2rem;max-width:1400px;margin:0 auto}.tool-header{margin-bottom:2rem}.tool-header h1{font-size:2rem;font-weight:600;margin:0 0 .5rem;color:var(--color-text)}.tool-header .subtitle{color:var(--color-text-muted);margin:0}.tool-section{background:var(--color-bg-secondary);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.info-box{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;padding:1rem;margin-bottom:1.5rem}.info-box p{margin:0;color:var(--color-text)}.tool-admin-table-container{overflow-x:auto}.tool-admin-table{width:100%;border-collapse:collapse;background:var(--color-bg-primary);border-radius:6px;overflow:hidden}.tool-admin-table thead{background:var(--color-bg-tertiary)}.tool-admin-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-text);border-bottom:2px solid var(--color-border)}.tool-admin-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.tool-admin-table tbody tr:hover{background:var(--color-bg-secondary)}.tool-admin-table tbody tr:last-child td{border-bottom:none}.tool-id-label{font-size:.85rem;color:var(--color-text-muted);font-family:monospace;margin-top:.25rem}.description-cell{max-width:300px;font-size:.9rem;color:var(--color-text-muted)}.model-cell{min-width:250px}.model-selector{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-bg-primary);color:var(--color-text);font-size:.9rem;font-family:monospace}.model-selector:focus{outline:none;border-color:var(--color-primary)}.model-selector:disabled{opacity:.5;cursor:not-allowed}.saving-indicator{display:inline-block;margin-left:.5rem;font-size:.85rem;color:var(--color-text-muted);font-style:italic}.temperature-cell{font-family:monospace;color:var(--color-text-muted)}.actions-cell{text-align:right}.no-config-label{font-size:.85rem;color:var(--color-text-muted);font-style:italic}.btn{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-bg-secondary)}.btn-sm{padding:.375rem .75rem;font-size:.85rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--color-text-muted)}.empty-state p{margin:0}.error-message{background:#fee;border:1px solid #fcc;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem}.embedding-tester-page{padding:2rem;max-width:1400px;margin:0 auto}.page-header{margin-bottom:3rem}.page-header h1{font-size:2.5rem;margin-bottom:.5rem}.page-subtitle{font-size:1.1rem;color:var(--color-text-secondary)}.error-banner{background:#ff3b301a;border:1px solid rgba(255,59,48,.3);color:#ff3b30;padding:1rem;border-radius:8px;margin-bottom:2rem}.test-section{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:2rem;margin-bottom:2rem}.test-section h2{font-size:1.8rem;margin-bottom:.5rem}.section-description{color:var(--color-text-secondary);margin-bottom:1.5rem}.models-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:1.5rem}.model-card{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:1.5rem;transition:all .2s}.model-card.encoded{border-color:#34c75980;background:#34c7590d}.model-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.model-header h3{font-size:1.2rem;margin:0}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.badge.success{background:#34c75933;color:#34c759}.model-info{margin-bottom:1rem}.model-description{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:.5rem}.model-dimensions{font-size:.9rem;color:var(--color-text-tertiary)}.encode-results{background:#0000004d;border-radius:6px;padding:1rem;margin-bottom:1rem}.result-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.result-row:last-child{border-bottom:none}.result-row span{color:var(--color-text-secondary)}.result-row strong{color:var(--color-text-primary)}.model-actions{display:flex;gap:.5rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;flex:1}.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)}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover:not(:disabled){background:#ffffff26}.btn-danger{background:#ff3b3033;color:#ff3b30;border:1px solid rgba(255,59,48,.3)}.btn-danger:hover:not(:disabled){background:#ff3b304d}.clear-all{display:block;margin:0 auto;max-width:200px}.search-form{display:flex;gap:1rem;margin-bottom:2rem}.search-input{flex:1;padding:1rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem}.search-input:focus{outline:none;border-color:var(--color-primary)}.search-results h3{font-size:1.4rem;margin-bottom:1.5rem}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.results-column{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;overflow:hidden}.results-header{background:#ffffff0d;padding:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.results-header h4{margin:0 0 .5rem;font-size:1.1rem}.timing-info{display:flex;gap:1rem;font-size:.85rem;color:var(--color-text-secondary)}.results-list{padding:1rem}.result-item{display:flex;gap:1rem;padding:1rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:6px;margin-bottom:.75rem;transition:all .2s}.result-item:hover{background:#ffffff0d;border-color:#fff3}.result-rank{font-size:1.2rem;font-weight:700;color:var(--color-text-tertiary);min-width:30px}.result-content{flex:1}.result-similarity{font-size:1.3rem;font-weight:700;color:var(--color-primary);margin-bottom:.5rem}.result-details strong{display:block;margin-bottom:.25rem}.result-meta{color:var(--color-text-secondary);font-size:.9rem;margin-bottom:.5rem}.result-description{color:var(--color-text-tertiary);font-size:.85rem;line-height:1.4}.instructions{background:#ff9f0a0d;border-color:#ff9f0a33}.instructions h2{color:#ff9f0a}.instructions ol{margin-left:1.5rem;line-height:1.8}.instructions ul{margin-left:1.5rem;line-height:1.6}.instructions li{margin-bottom:.5rem}.tips{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,159,10,.2)}.tips h3{font-size:1.2rem;margin-bottom:1rem}.tips ul{list-style:none;margin-left:0}.tips li{padding-left:0}.base-tool-config-page{min-height:100vh;background:linear-gradient(135deg,#000000e6,#141428f2);color:var(--color-surface-default);padding:2rem}.tool-config-header{margin-bottom:2rem}.tool-config-title{font-size:2rem;font-weight:700;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}.tool-icon{font-size:2.5rem}.tabs{display:flex;gap:.5rem;border-bottom:2px solid rgba(255,255,255,.1)}.tab{padding:.75rem 1.5rem;background:none;border:none;color:#fff9;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.tab:hover{color:#ffffffe6;background:#ffffff0d}.tab.active{color:var(--color-surface-default);border-bottom-color:var(--color-brand-primary);background:#3b82f61a}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:var(--color-brand-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:var(--color-error);margin:1rem 0;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md)}.error-banner{background:#ef444426;border:1px solid rgba(239,68,68,.4);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;color:#fca5a5}.btn-close-error{background:none;border:none;color:#fca5a5;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;opacity:.7;transition:opacity .2s}.btn-close-error:hover{opacity:1}.tool-config-content{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:2rem;min-height:400px}.config-tab,.test-tab{max-width:800px}.config-form{margin-bottom:2rem}.test-form{margin-bottom:1.5rem}.config-form label,.test-form label{display:block;color:#ffffffe6;margin-bottom:.5rem;font-weight:500}.config-form input,.config-form select,.config-form textarea,.test-form input,.test-form select,.test-form textarea{width:100%;padding:.75rem;background:#0000004d;border:1px solid var(--color-border-strong);border-radius:var(--radius-md);color:var(--color-surface-default);font-size:1rem;font-family:inherit;transition:border-color .2s}.config-form input:focus,.config-form select:focus,.config-form textarea:focus,.test-form input:focus,.test-form select:focus,.test-form textarea:focus{outline:none;border-color:var(--color-brand-primary);background:#0006}.config-form input[type=checkbox],.test-form input[type=checkbox]{width:auto;margin-right:.5rem}.config-actions{display:flex;gap:1rem;margin-top:2rem}.btn-primary,.btn-secondary,.btn-retry{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,var(--color-brand-primary),var(--color-info));color:var(--color-surface-default)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-info),#1d4ed8);transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#ffffff1a;color:#ffffffe6;border:1px solid var(--color-border-strong)}.btn-secondary:hover{background:#ffffff26}.btn-retry{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.4)}.btn-retry:hover{background:#ef44444d}.btn-save{min-width:180px}.btn-reload{min-width:120px}.testing-indicator{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#3b82f61a;border:1px solid rgba(59,130,246,.3);border-radius:var(--radius-md);margin-top:1.5rem}.testing-indicator .loading-spinner{width:32px;height:32px}.last-job-info{padding:1.5rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);margin-top:1.5rem}.last-job-info strong{color:#86efac}.last-job-info .hint{color:#fff9;font-size:.9rem;margin-top:.5rem}@media (max-width: 768px){.base-tool-config-page{padding:1rem}.tool-config-title{font-size:1.5rem}.tabs{flex-direction:column}.tab{text-align:left;border-bottom:none;border-left:3px solid transparent;padding-left:1rem}.tab.active{border-left-color:var(--color-brand-primary);border-bottom-color:transparent}.config-actions{flex-direction:column}.btn-save,.btn-reload{width:100%}}.tool-page{max-width:1200px;margin:0 auto;padding:2rem}.tool-header{margin-bottom:2rem;text-align:center}.tool-header h1{color:#fff;margin:0 0 .5rem;font-size:2rem}.tool-header p{color:#ffffffb3;font-size:1.1rem}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:1rem;margin-bottom:2rem;color:#fca5a5e6}.processing-status,.loading{text-align:center;padding:3rem;background:#ffffff0d;border-radius:12px;margin-bottom:2rem}.spinner{border:3px solid rgba(255,255,255,.1);border-top:3px solid rgba(139,92,246,.9);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.document-section{margin-bottom:2rem}.document-section h3{color:#fff;margin:0 0 1.5rem;font-size:1.3rem}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.document-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1.5rem;transition:all .2s}.document-card:hover{background:#ffffff14;border-color:#8b5cf64d}.document-card.selectable{cursor:pointer}.document-card.selected{border-color:#22c55e99;background:#22c55e1a}.document-card.processed{border-color:#22c55e4d}.document-info h4{color:#fff;margin:0 0 .5rem;font-size:1.1rem}.doc-meta{color:#fff9;font-size:.9rem;margin:.25rem 0}.process-button{width:100%;margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,#3b82f6e6,#2563ebe6);border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:all .2s}.process-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}.process-button:disabled{opacity:.5;cursor:not-allowed}.processed-badge,.selected-badge{margin-top:1rem;padding:.5rem;background:#22c55e33;border-radius:8px;color:#22c55ee6;text-align:center;font-weight:600;font-size:.9rem}.result-success{background:#ffffff0d;border-radius:12px;padding:3rem;text-align:center}.success-icon{width:80px;height:80px;background:#22c55e33;border:3px solid rgba(34,197,94,.5);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#22c55ee6;margin:0 auto 1.5rem}.result-success h2{color:#22c55ee6;margin:0 0 1rem;font-size:2rem}.result-success h3{color:#fff;margin:0 0 2rem;font-size:1.5rem}.result-details{text-align:left;max-width:600px;margin:2rem auto;background:#0000004d;padding:1.5rem;border-radius:12px}.result-details p{color:#fffc;margin:.75rem 0;line-height:1.6}.result-details code{background:#0000004d;padding:.25rem .5rem;border-radius:4px;font-family:monospace;color:#8b5cf6e6}.next-steps{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}.next-steps p{color:#3b82f6e6;font-weight:500}.action-button,.action-buttons button{padding:1rem 2rem;background:linear-gradient(135deg,#8b5cf6e6,#3b82f6e6);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin:.5rem}.action-button:hover,.action-buttons button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.empty-state{text-align:center;padding:4rem 2rem;max-width:600px;margin:0 auto}.empty-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.5}.empty-state h3{color:#fff;margin:0 0 1rem;font-size:1.5rem}.empty-state p{color:#ffffffb3;line-height:1.8}.question-form{max-width:800px;margin:2rem auto}.question-form textarea{width:100%;padding:1rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem;font-family:inherit;resize:vertical;margin-bottom:1rem}.question-form textarea:focus{outline:none;border-color:#8b5cf680}.question-form button{width:100%;padding:1rem;background:linear-gradient(135deg,#8b5cf6e6,#3b82f6e6);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.question-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.question-form button:disabled{opacity:.5;cursor:not-allowed}.answer-result{max-width:900px;margin:0 auto}.answer-header,.answer-body{background:#ffffff0d;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem}.answer-header h3,.answer-body h3{color:#fff;margin:0 0 1rem;font-size:1.2rem}.answer-header p,.answer-body p{color:#ffffffe6;line-height:1.8;font-size:1.05rem;margin:0}.citations{background:#ffffff0d;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem}.citations h3{color:#fff;margin:0 0 1rem;font-size:1.2rem}.citation-card{background:#0000004d;padding:1rem;border-radius:8px;border-left:3px solid rgba(59,130,246,.5);margin-bottom:1rem}.citation-card:last-child{margin-bottom:0}.citation-header{color:#ffffffe6;margin-bottom:.5rem;font-size:.95rem}.citation-text{color:#ffffffb3;font-style:italic;font-size:.9rem;line-height:1.6;margin:0}.confidence{text-align:center;padding:1rem;background:#ffffff0d;border-radius:8px;margin-bottom:1.5rem}.confidence strong{color:#fff;margin-right:.5rem}.action-buttons{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.document-selection{margin-bottom:2rem}.document-selection h3{color:#fff;margin:0 0 1.5rem;font-size:1.3rem}@media (max-width: 768px){.tool-page{padding:1rem}.documents-grid{grid-template-columns:1fr}}.items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin:1rem 0}.item-card{border:2px solid rgba(255,255,255,.2);border-radius:8px;padding:.5rem;cursor:pointer;transition:all .2s ease;position:relative;background:#ffffff0d}.item-card:hover{border-color:#8b5cf6e6;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.item-card.selected{border-color:#22c55ee6;background:#22c55e1a}.item-card img{width:100%;height:120px;object-fit:cover;border-radius:4px;margin-bottom:.5rem}.item-info{text-align:center}.item-name{font-size:.875rem;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#fff}.item-check{position:absolute;top:.5rem;right:.5rem;background:#22c55ee6;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.tool-content{display:grid;grid-template-columns:300px 1fr;gap:2rem;margin-top:2rem}.info-section{background:#ffffff0d;padding:1.5rem;border-radius:12px;height:fit-content}.info-section h3{color:#fff;margin:1.5rem 0 .75rem;font-size:1.1rem}.info-section h3:first-child{margin-top:0}.info-section ol,.info-section ul{color:#fffc;line-height:1.8;padding-left:1.5rem}.info-section li{margin-bottom:.5rem}.tool-form{background:#ffffff0d;padding:2rem;border-radius:12px}.tool-form h3{color:#fff;margin:2rem 0 1rem;font-size:1.2rem}.tool-form h3:first-child{margin-top:0}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:#fff;margin-bottom:.5rem;font-weight:500}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#8b5cf680}.form-group textarea{resize:vertical;min-height:80px}.field-help{color:#fff9;font-size:.875rem;margin-top:.5rem}.tool-subtitle{color:#ffffffb3;font-size:1.1rem}.success-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:8px;padding:1rem;margin-bottom:1rem;color:#22c55ee6}.image-select-wrapper{margin-bottom:1rem}.media-select-button{width:100%;padding:1rem;background:#3b82f61a;border:2px dashed rgba(59,130,246,.3);border-radius:8px;color:#3b82f6e6;font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.media-select-button:hover{background:#3b82f626;border-color:#3b82f680}.media-select-button.has-selection{border-style:solid;border-color:#22c55e80;background:#22c55e1a;color:#22c55ee6}.media-select-button .checkmark{font-size:1.2rem}.media-select-button .change-text{margin-left:auto;font-size:.875rem;opacity:.7}.selected-image-preview{margin-top:1rem;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.1)}.selected-image-preview img{width:100%;max-height:300px;object-fit:contain;background:#0000004d}@media (max-width: 968px){.tool-content{grid-template-columns:1fr}}.entity-merger-execute{display:flex;flex-direction:column;gap:24px}.entity-merger-execute .info-box{background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:8px;padding:20px}.entity-merger-execute .info-box h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--color-text-primary)}.entity-merger-execute .info-box h3:not(:first-child){margin-top:20px}.entity-merger-execute .info-box ol,.entity-merger-execute .info-box ul{margin:0;padding-left:24px}.entity-merger-execute .info-box li{margin-bottom:8px;color:var(--color-text-secondary);line-height:1.5}.entity-merger-execute .info-box strong{color:var(--color-text-primary)}.entity-merger-execute .entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-top:12px}.entity-merger-execute .required{color:var(--color-danger)}.entity-merger-execute button[disabled]{opacity:.5;cursor:not-allowed}.prompt-editor{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem;margin-top:1rem}.prompt-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.prompt-editor-header h3{margin:0;font-size:1.1rem;color:var(--color-text)}.prompt-editor-modified{background:#ff98001a;color:#ff9800;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.prompt-editor-info{margin-bottom:1rem;padding:.75rem;background:var(--color-surface-hover);border-radius:4px;border-left:3px solid var(--color-primary)}.prompt-editor-info p{margin:0;font-size:.9rem;color:var(--color-text-muted);line-height:1.5}.prompt-editor-textarea{width:100%;min-height:400px;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,Courier New,monospace;font-size:.9rem;line-height:1.6;background:var(--color-background);border:1px solid var(--color-border);border-radius:4px;color:var(--color-text);resize:vertical;transition:border-color .2s}.prompt-editor-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #2196f31a}.prompt-editor-textarea[readonly]{background:var(--color-surface-hover);cursor:default}.prompt-editor-stats{display:flex;gap:1.5rem;margin-top:.5rem;padding:.5rem 0;font-size:.85rem;color:var(--color-text-muted)}.prompt-editor-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.prompt-editor-button{padding:.625rem 1.25rem;border:none;border-radius:4px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.prompt-editor-button.primary{background:var(--color-primary);color:#fff}.prompt-editor-button.primary:hover:not(:disabled){background:#1976d2;box-shadow:0 2px 8px #2196f34d}.prompt-editor-button.secondary{background:var(--color-surface-hover);color:var(--color-text);border:1px solid var(--color-border)}.prompt-editor-button.secondary:hover:not(:disabled){background:var(--color-border)}.prompt-editor-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.prompt-editor{padding:1rem}.prompt-editor-textarea{min-height:300px;font-size:.85rem}.prompt-editor-actions{flex-direction:column}.prompt-editor-button{width:100%}}.execution-detail-page{padding:2rem;max-width:1400px;margin:0 auto}.execution-loading,.execution-error{text-align:center;padding:3rem;color:var(--color-text-muted)}.execution-error{color:var(--color-error)}.execution-error button{margin-top:1rem;padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:4px;cursor:pointer}.execution-header{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem;margin-bottom:2rem}.execution-title-row{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.back-button{padding:.5rem 1rem;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.back-button:hover{background:var(--color-border)}.view-prompt-button{padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.view-prompt-button:hover{background:#1976d2;box-shadow:0 2px 8px #2196f34d}.execution-title-row h2{margin:0;flex:1}.execution-status{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase}.execution-status-completed{background:#4caf501a;color:#4caf50}.execution-status-failed{background:#f443361a;color:#f44336}.execution-status-running{background:#2196f31a;color:#2196f3}.execution-status-pending{background:#9e9e9e1a;color:#9e9e9e}.execution-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.meta-item{display:flex;flex-direction:column;gap:.25rem}.meta-label{font-size:.85rem;color:var(--color-text-muted);font-weight:500}.meta-value{font-size:.95rem;color:var(--color-text)}.meta-value code{background:var(--color-surface-hover);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-family:Courier New,monospace}.execution-error-banner{margin-top:1rem;padding:1rem;background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:4px;color:#f44336}.execution-steps{margin-top:2rem}.execution-steps h3{margin-bottom:1rem}.steps-list{display:flex;flex-direction:column;gap:1rem}.step-detail{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;transition:all .2s}.step-detail.status-failed{border-color:#f443364d}.step-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;cursor:pointer;transition:background .2s}.step-header:hover{background:var(--color-surface-hover)}.step-main-info{display:flex;align-items:center;gap:.75rem;flex:1}.step-number{font-weight:700;color:var(--color-text-muted);font-size:.9rem}.step-name{font-weight:600;font-size:1rem}.step-tool{background:var(--color-surface-hover);padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-family:Courier New,monospace}.step-meta{display:flex;align-items:center;gap:1rem}.step-duration{font-size:.9rem;color:var(--color-text-muted);font-family:Courier New,monospace}.step-toggle{color:var(--color-text-muted);font-size:.9rem}.step-content{padding:0 1.5rem 1.5rem;border-top:1px solid var(--color-border)}.step-section{margin-top:1.5rem}.step-section:first-child{margin-top:1rem}.step-section h4{margin:0 0 .75rem;font-size:.95rem;color:var(--color-text-muted);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.step-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.step-info-grid div{font-size:.9rem}.step-data{background:var(--color-background);padding:1rem;border-radius:4px;border:1px solid var(--color-border);overflow-x:auto;font-size:.85rem;font-family:Courier New,monospace;line-height:1.5}.step-error{background:#f443360d;padding:1rem;border-radius:4px;border:1px solid rgba(244,67,54,.3)}.error-text{color:#f44336;margin:0;font-family:Courier New,monospace;font-size:.85rem;white-space:pre-wrap}.agent-iterations{margin-top:1rem}.agent-iterations h4{margin:0 0 1rem;font-size:1rem;color:var(--color-text)}.agent-iterations-empty{padding:1rem;text-align:center;color:var(--color-text-muted);font-style:italic}.agent-iteration{background:var(--color-background);border:1px solid var(--color-border);border-radius:6px;margin-bottom:.75rem;overflow:hidden}.iteration-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-surface-hover);transition:background .2s}.iteration-header:hover{background:var(--color-border)}.iteration-number{font-weight:700;font-size:.9rem;color:var(--color-primary)}.iteration-summary{flex:1;margin-left:1rem;font-size:.9rem;color:var(--color-text-muted)}.iteration-tokens,.iteration-toggle{color:var(--color-text-muted);font-size:.85rem}.iteration-details{padding:1rem}.iteration-content{margin-bottom:1rem}.iteration-content h5{margin:0 0 .5rem;font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;font-weight:600}.iteration-content pre{background:var(--color-surface);padding:.75rem;border-radius:4px;border:1px solid var(--color-border);overflow-x:auto;font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-word;margin:0}.iteration-tool-calls{margin-bottom:1rem}.iteration-tool-calls h5{margin:0 0 .5rem;font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;font-weight:600}.tool-call{background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:.75rem;margin-bottom:.5rem}.tool-call:last-child{margin-bottom:0}.tool-call-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.tool-name{background:#2196f31a;color:#2196f3;padding:.25rem .5rem;border-radius:4px;font-size:.85rem;font-weight:600;font-family:Courier New,monospace}.tool-id{font-size:.75rem;color:var(--color-text-muted);font-family:Courier New,monospace}.tool-call-args{margin-top:.5rem}.tool-call-args pre{background:var(--color-background);padding:.75rem;border-radius:4px;border:1px solid var(--color-border);overflow-x:auto;font-size:.8rem;line-height:1.4;margin:0}.iteration-usage{display:flex;flex-wrap:wrap;gap:1rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;font-size:.85rem}.iteration-usage span{color:var(--color-text-muted)}.cached-tokens{color:#4caf50!important;font-weight:600}.prompt-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.prompt-modal-content{background:var(--color-background);border-radius:8px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}@media (max-width: 768px){.execution-detail-page{padding:1rem}.execution-meta,.step-info-grid{grid-template-columns:1fr}.step-main-info{flex-wrap:wrap}.iteration-usage{flex-direction:column;gap:.5rem}}.chat-page{display:flex;flex-direction:column;height:calc(100vh - 60px);max-height:calc(100vh - 60px);background:var(--bg-primary)}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.chat-header-title{display:flex;align-items:center;gap:.5rem}.chat-header-title h1{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.chat-icon{font-size:1.5rem}.chat-header-actions{display:flex;align-items:center;gap:1rem}.chat-session-id{font-size:.75rem;color:var(--text-tertiary);font-family:monospace}.chat-new-session-btn{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:all .15s ease}.chat-new-session-btn:hover{background:var(--bg-hover);border-color:var(--accent-color);color:var(--accent-color)}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.chat-message{display:flex;gap:.75rem;max-width:85%;animation:messageSlideIn .2s ease-out}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message-user{align-self:flex-end;flex-direction:row-reverse}.chat-message-assistant{align-self:flex-start}.chat-message-avatar{width:36px;height:36px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.chat-message-content{display:flex;flex-direction:column;gap:.5rem}.chat-message-text{padding:.75rem 1rem;border-radius:12px;line-height:1.5}.chat-message-text p{margin:0}.chat-message-text p+p{margin-top:.5rem}.chat-message-user .chat-message-text{background:var(--accent-color);color:#fff;border-bottom-right-radius:4px}.chat-message-assistant .chat-message-text{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:4px}.chat-message-loading{padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px 12px 12px 4px;display:flex;gap:.25rem}.loading-dot{font-size:1.5rem;line-height:1;animation:loadingBounce 1.4s infinite ease-in-out both;color:var(--text-tertiary)}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}@keyframes loadingBounce{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.chat-message-api-action{padding:0 .25rem}.api-action-badge{display:inline-block;padding:.25rem .5rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;font-size:.7rem;font-family:monospace;color:var(--text-tertiary)}.chat-message-suggestions{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:.25rem}.chat-suggestion-btn{padding:.375rem .75rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;font-size:.8rem;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.chat-suggestion-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-color);color:var(--accent-color)}.chat-suggestion-btn:disabled{opacity:.5;cursor:not-allowed}.chat-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin:0 1.5rem;background:var(--error-bg, #fee2e2);border:1px solid var(--error-border, #fecaca);border-radius:8px;color:var(--error-text, #dc2626);font-size:.875rem}.error-icon{font-size:1rem}.error-dismiss{margin-left:auto;background:none;border:none;font-size:1.25rem;cursor:pointer;color:inherit;opacity:.7;padding:0;line-height:1}.error-dismiss:hover{opacity:1}.chat-input-form{display:flex;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.chat-input{flex:1;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:.9375rem;outline:none;transition:border-color .15s ease}.chat-input:focus{border-color:var(--accent-color)}.chat-input::placeholder{color:var(--text-tertiary)}.chat-input:disabled{opacity:.7;cursor:not-allowed}.chat-send-btn{padding:.75rem 1.5rem;background:var(--accent-color);border:none;border-radius:8px;color:#fff;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .15s ease;min-width:80px}.chat-send-btn:hover:not(:disabled){background:var(--accent-color-hover, var(--accent-color));filter:brightness(1.1)}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}:root[data-theme=dark] .chat-error{--error-bg: #451a1a;--error-border: #7f1d1d;--error-text: #fca5a5}@media (max-width: 768px){.chat-header{padding:.75rem 1rem}.chat-messages{padding:1rem}.chat-message{max-width:95%}.chat-input-form{padding:.75rem 1rem}.chat-session-id{display:none}}:root{--color-bg-primary: #0f0f1e;--color-bg-secondary: #1a1a2e;--color-bg-tertiary: #16213e;--color-bg-elevated: #1f1f2e;--color-bg-overlay: rgba(0, 0, 0, .7);--color-surface-default: #1a1a2e;--color-surface-subtle: #16213e;--color-surface-elevated: #1f1f2e;--color-surface-hover: rgba(255, 255, 255, .08);--color-surface-active: rgba(255, 255, 255, .12);--color-text-primary: #ffffff;--color-text-secondary: rgba(255, 255, 255, .7);--color-text-tertiary: rgba(255, 255, 255, .5);--color-text-disabled: rgba(255, 255, 255, .3);--color-text-inverse: #1d1d1f;--color-border-default: rgba(255, 255, 255, .12);--color-border-subtle: rgba(255, 255, 255, .08);--color-border-strong: rgba(255, 255, 255, .2);--color-brand-primary: #667eea;--color-brand-secondary: #764ba2;--color-brand-hover: #7b8ef0;--color-brand-active: #8f9df4;--color-success: #34d399;--color-success-bg: rgba(16, 185, 129, .15);--color-warning: #fbbf24;--color-warning-bg: rgba(245, 158, 11, .15);--color-error: #f87171;--color-error-bg: rgba(239, 68, 68, .15);--color-info: #60a5fa;--color-info-bg: rgba(59, 130, 246, .15);--color-status-running: #60a5fa;--color-status-completed: #34d399;--color-status-failed: #f87171;--color-status-archived: #fbbf24;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--spacing-24: 6rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono: "Monaco", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--shadow-none: none;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-base: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .06);--radius-none: 0;--radius-sm: .25rem;--radius-base: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-slower: .5s cubic-bezier(.4, 0, .2, 1);--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-overlay: 400;--z-modal: 500;--z-popover: 600;--z-toast: 700;--z-tooltip: 800}[data-theme=light]{--color-bg-primary: #ffffff;--color-bg-secondary: #f5f5f7;--color-bg-tertiary: #e8e8ed;--color-bg-elevated: #ffffff;--color-bg-overlay: rgba(0, 0, 0, .5);--color-surface-default: #ffffff;--color-surface-subtle: #f5f5f7;--color-surface-elevated: #ffffff;--color-surface-hover: #f0f0f5;--color-surface-active: #e8e8ed;--color-text-primary: #1d1d1f;--color-text-secondary: #6e6e73;--color-text-tertiary: #86868b;--color-text-disabled: #c7c7cc;--color-text-inverse: #ffffff;--color-border-default: rgba(0, 0, 0, .12);--color-border-subtle: rgba(0, 0, 0, .08);--color-border-strong: rgba(0, 0, 0, .2);--color-brand-primary: #667eea;--color-brand-secondary: #764ba2;--color-brand-hover: #5568d3;--color-brand-active: #4556c2;--color-success: #10b981;--color-success-bg: #d1fae5;--color-warning: #f59e0b;--color-warning-bg: #fef3c7;--color-error: #ef4444;--color-error-bg: #fee2e2;--color-info: #3b82f6;--color-info-bg: #dbeafe;--color-status-running: #3b82f6;--color-status-completed: #10b981;--color-status-failed: #ef4444;--color-status-archived: #f59e0b}body{background:var(--color-bg-primary);color:var(--color-text-primary);font-family:var(--font-sans);transition:background-color var(--transition-base),color var(--transition-base)}*{transition-property:background-color,border-color,color,fill,stroke;transition-duration:var(--transition-fast);transition-timing-function:ease-in-out}.preload *{transition:none!important}
