@import"https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background-color:var(--color-primary-dark);color:var(--color-text-on-dark);display:flex;flex-direction:column;transition:width .2s ease;position:fixed;top:0;left:0;bottom:0;z-index:100}[data-sidebar-collapsed=true] .sidebar{width:64px}.app-main{flex:1;margin-left:240px;transition:margin-left .2s ease;display:flex;flex-direction:column}[data-sidebar-collapsed=true] .app-main{margin-left:64px}.sidebar-logo{padding:var(--spacing-lg);font-family:var(--font-title);font-size:1.5rem;font-weight:700;letter-spacing:2px;border-bottom:1px solid rgba(255,255,255,.1);white-space:nowrap;overflow:hidden}.sidebar-nav{flex:1;padding:var(--spacing-sm) 0}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);color:#ffffffb3;text-decoration:none;transition:all .15s ease;font-size:.9rem;border-left:3px solid transparent;white-space:nowrap;overflow:hidden}.sidebar-nav-item:hover{color:#fff;background-color:#ffffff0d;text-decoration:none}.sidebar-nav-item.active{color:#fff;background-color:#ffffff1a;border-left-color:var(--color-accent-rose)}.sidebar-nav-icon{width:24px;min-width:24px;text-align:center;font-size:1.1rem;flex-shrink:0}.sidebar-nav-label{overflow:hidden;transition:opacity .15s ease,width .2s ease;opacity:1}[data-sidebar-collapsed=true] .sidebar-nav-label{opacity:0;width:0}.sidebar-toggle{padding:var(--spacing-md);text-align:center;cursor:pointer;color:#ffffff80;border-top:1px solid rgba(255,255,255,.1);background:none;border-left:none;border-right:none;border-bottom:none;width:100%;font-size:1rem}.sidebar-toggle:hover{color:#fff}.app-header{height:56px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-lg);position:sticky;top:0;z-index:50}.app-header-breadcrumb{font-size:.9rem;color:var(--color-text-secondary);display:flex;align-items:center}.app-header-breadcrumb__link{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.app-header-breadcrumb__link:hover{color:var(--color-accent-rose);text-decoration:none}.app-header-breadcrumb__sep{color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.app-header-breadcrumb__current{color:var(--color-text-primary);font-weight:600}.app-header-user-container{position:relative}.app-header-user{display:flex;align-items:center;gap:var(--spacing-xs);cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid var(--color-border);background:none;font-size:.9rem;color:var(--color-text-primary)}.app-header-user:hover{background-color:var(--color-background)}.app-header-user-arrow{font-size:.7rem;color:var(--color-text-secondary)}.app-header-user-menu{position:absolute;top:100%;right:0;margin-top:var(--spacing-xs);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:160px;z-index:200;padding:var(--spacing-xs) 0}.app-header-user-menu-item{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:.875rem;color:var(--color-text-primary);background:none;border:none;cursor:pointer}.app-header-user-menu-item:hover{background-color:var(--color-background)}.app-content{flex:1;padding:var(--spacing-lg);background-color:var(--color-background)}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-xl);text-align:center;gap:var(--spacing-md)}.error-boundary h2{color:var(--color-danger)}.error-boundary p{color:var(--color-text-secondary);font-family:monospace;background-color:var(--color-background);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-sm);max-width:600px}.error-boundary button{padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-accent-rose);color:var(--color-text-on-accent);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem}.error-boundary button:hover{opacity:.9}.loading-spinner-wrapper{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.loading-spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent-rose);border-radius:50%;animation:spin .7s linear infinite}.loading-spinner--sm{width:20px;height:20px;border-width:2px}.loading-spinner--lg{width:52px;height:52px;border-width:4px}@keyframes spin{to{transform:rotate(360deg)}}.app-header-left{display:flex;align-items:center;gap:var(--spacing-sm)}.hamburger-btn{display:none;background:none;border:none;font-size:1.25rem;cursor:pointer;padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text-primary);border-radius:var(--radius-sm);line-height:1}.hamburger-btn:hover{background-color:var(--color-background)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:99}@media(max-width:768px){.hamburger-btn{display:flex;align-items:center}.sidebar{transform:translate(-100%);width:240px!important}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.app-main{margin-left:0!important}.sidebar-toggle{display:none}}.toast-container{position:fixed;top:var(--spacing-md);right:var(--spacing-md);z-index:1100;display:flex;flex-direction:column;gap:var(--spacing-sm);pointer-events:none;width:360px;max-width:calc(100vw - 2 * var(--spacing-md))}.toast{display:flex;flex-direction:column;background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);overflow:hidden;pointer-events:all;border-left:4px solid transparent;animation:toast-in .25s ease forwards}.toast--exiting{animation:toast-out .25s ease forwards}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes toast-out{0%{opacity:1;transform:translate(0);max-height:200px;margin-bottom:0}to{opacity:0;transform:translate(20px);max-height:0;margin-bottom:calc(-1 * var(--spacing-sm))}}.toast--success{border-left-color:var(--color-success)}.toast--error{border-left-color:var(--color-danger)}.toast--warning{border-left-color:var(--color-warning)}.toast--info{border-left-color:var(--color-info)}.toast__content{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.toast__icon{font-size:1rem;line-height:1.5;flex-shrink:0}.toast--success .toast__icon{color:var(--color-success)}.toast--error .toast__icon{color:var(--color-danger)}.toast--warning .toast__icon{color:var(--color-warning)}.toast--info .toast__icon{color:var(--color-info)}.toast__message{flex:1;font-size:.9375rem;line-height:1.5;color:var(--color-text-primary);word-break:break-word;padding-top:2px}.toast__dismiss{background:none;border:none;cursor:pointer;padding:2px 4px;color:var(--color-text-secondary);font-size:.875rem;line-height:1;border-radius:var(--radius-sm);flex-shrink:0;transition:color .15s ease;margin-left:auto}.toast__dismiss:hover{color:var(--color-text-primary)}.toast__dismiss:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.toast__progress{height:3px;background-color:#00000014;overflow:hidden}.toast__progress-bar{height:100%;transform-origin:left;transition:transform linear}.toast--success .toast__progress-bar{background-color:var(--color-success)}.toast--error .toast__progress-bar{background-color:var(--color-danger)}.toast--warning .toast__progress-bar{background-color:var(--color-warning)}.toast--info .toast__progress-bar{background-color:var(--color-info)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary-dark);padding:var(--spacing-md)}.auth-card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 20px 60px #0006,0 4px 12px #0003;padding:var(--spacing-xxl) var(--spacing-xl);width:100%;max-width:420px}.auth-logo{text-align:center;margin-bottom:var(--spacing-xl)}.auth-logo-mark{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-md);background-color:var(--color-primary-dark);margin-bottom:var(--spacing-sm)}.auth-logo-mark svg{width:32px;height:32px;fill:var(--color-accent-rose)}.auth-brand-name{font-family:var(--font-title);font-size:1.5rem;font-weight:700;color:var(--color-primary-dark);letter-spacing:.1em;display:block}.auth-heading{font-family:var(--font-title);font-size:1.25rem;color:var(--color-text-primary);text-align:center;margin-bottom:var(--spacing-xs)}.auth-subheading{font-size:.875rem;color:var(--color-text-secondary);text-align:center;margin-bottom:var(--spacing-xl)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.auth-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.auth-label{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.auth-input{padding:10px var(--spacing-md);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:.9375rem;color:var(--color-text-primary);background-color:var(--color-surface);transition:border-color .15s ease,box-shadow .15s ease;width:100%}.auth-input:focus{outline:none;border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c1f}.auth-input--error{border-color:var(--color-danger)}.auth-input--error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef44441f}.auth-input-group{position:relative}.auth-input-group .auth-input{padding-right:44px}.auth-password-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;font-size:1.125rem;line-height:1;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.auth-password-toggle:hover{color:var(--color-text-primary)}.auth-password-toggle:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.auth-field-error{font-size:.8125rem;color:var(--color-danger);margin-top:2px}.auth-error-banner{display:flex;align-items:flex-start;gap:var(--spacing-sm);background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:#b91c1c;font-size:.875rem;line-height:1.4}.auth-success-banner{display:flex;align-items:flex-start;gap:var(--spacing-sm);background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:#15803d;font-size:.875rem;line-height:1.4}.auth-info-banner{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:#1d4ed8;font-size:.8125rem;line-height:1.5;word-break:break-all}.auth-info-banner strong{display:block;margin-bottom:var(--spacing-xs)}.auth-submit-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:11px var(--spacing-md);background-color:var(--color-accent-rose);color:var(--color-text-on-accent);border:none;border-radius:var(--radius-md);font-family:var(--font-title);font-size:.9375rem;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:background-color .15s ease,opacity .15s ease;margin-top:var(--spacing-xs)}.auth-submit-btn:hover:not(:disabled){background-color:#e0004f}.auth-submit-btn:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.auth-submit-btn:disabled{opacity:.65;cursor:not-allowed}.auth-btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:auth-spin .7s linear infinite;flex-shrink:0}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-footer{margin-top:var(--spacing-lg);text-align:center;font-size:.875rem;color:var(--color-text-secondary)}.auth-footer a{color:var(--color-accent-rose);font-weight:500}.auth-footer a:hover{text-decoration:underline}.auth-footer-divider{display:inline-block;margin:0 var(--spacing-sm);color:var(--color-border)}@media(max-width:480px){.auth-card{padding:var(--spacing-xl) var(--spacing-lg);border-radius:var(--radius-md)}}.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-weight:600;line-height:1;white-space:nowrap;flex-shrink:0}.badge--sm{font-size:.6875rem;padding:2px var(--spacing-xs);min-height:18px}.badge--md{font-size:.8125rem;padding:3px var(--spacing-sm);min-height:22px}.badge--success{background-color:#10b9811f;color:#065f46}.badge--warning{background-color:#f59e0b1f;color:#92400e}.badge--danger{background-color:#ef44441f;color:#991b1b}.badge--info{background-color:#3b82f61f;color:#1e40af}.badge--neutral{background-color:#6b72801f;color:#374151}.bulk-action-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-primary-dark);color:var(--color-text-on-dark);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.bulk-action-bar__count{font-size:.875rem;font-weight:600;white-space:nowrap}.bulk-action-bar__actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);border:2px solid transparent;border-radius:var(--radius-md);font-family:var(--font-body);font-weight:600;line-height:1;cursor:pointer;text-decoration:none;transition:background-color .15s ease,border-color .15s ease,color .15s ease,opacity .15s ease,transform .1s ease;white-space:nowrap;-webkit-user-select:none;user-select:none;position:relative}.btn:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.btn:active:not(:disabled){transform:translateY(1px)}.btn--sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.8125rem;min-height:32px}.btn--md{padding:var(--spacing-sm) var(--spacing-md);font-size:.9375rem;min-height:40px}.btn--lg{padding:var(--spacing-sm) var(--spacing-lg);font-size:1.0625rem;min-height:48px}.btn--primary{background-color:var(--color-accent-rose);border-color:var(--color-accent-rose);color:var(--color-text-on-accent)}.btn--primary:hover:not(:disabled){background-color:#d4004d;border-color:#d4004d}.btn--primary:active:not(:disabled){background-color:#b3003f;border-color:#b3003f}.btn--secondary{background-color:transparent;border-color:var(--color-primary-dark);color:var(--color-primary-dark)}.btn--secondary:hover:not(:disabled){background-color:var(--color-primary-dark);color:var(--color-text-on-dark)}.btn--secondary:active:not(:disabled){background-color:#062a66;border-color:#062a66;color:var(--color-text-on-dark)}.btn--danger{background-color:var(--color-danger);border-color:var(--color-danger);color:#fff}.btn--danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}.btn--danger:active:not(:disabled){background-color:#b91c1c;border-color:#b91c1c}.btn--ghost{background-color:transparent;border-color:transparent;color:var(--color-text-primary)}.btn--ghost:hover:not(:disabled){background-color:#041d4512}.btn--ghost:active:not(:disabled){background-color:#041d451f}.btn--full-width{width:100%}.btn:disabled,.btn--loading{opacity:.6;cursor:not-allowed;transform:none;pointer-events:none}.btn__spinner{display:inline-block;width:1em;height:1em;border:2px solid currentColor;border-top-color:transparent;border-radius:var(--radius-full);animation:btn-spin .65s linear infinite;flex-shrink:0}@keyframes btn-spin{to{transform:rotate(360deg)}}.filter-bar{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap;padding:var(--spacing-sm) 0}.filter-bar__search{flex:1;min-width:160px;max-width:280px;padding:6px var(--spacing-md);border:1px solid var(--color-border);border-radius:20px;background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.filter-bar__search::placeholder{color:var(--color-text-secondary)}.filter-bar__search:hover{border-color:var(--color-primary-dark)}.filter-bar__search:focus{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c26}.filter-chip{position:relative;display:inline-flex;flex-shrink:0}.filter-chip__btn{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:6px 14px;border:1px solid var(--color-border);border-radius:20px;background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);outline:none}.filter-chip__btn:hover{border-color:var(--color-primary-dark);background-color:var(--color-background)}.filter-chip__btn:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.filter-chip__btn--active{background-color:#041d4514;border-color:var(--color-primary-dark);color:var(--color-primary-dark);font-weight:var(--font-weight-medium)}.filter-chip__btn--active:hover{background-color:#041d4524}.filter-chip__btn--open{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c1f}.filter-chip__label{flex:1}.filter-chip__count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;background-color:var(--color-primary-dark);color:var(--color-text-on-dark);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1}.filter-chip__chevron{font-size:.7rem;line-height:1;transition:transform var(--transition-fast);flex-shrink:0}.filter-chip__chevron--open{transform:rotate(180deg)}.filter-chip__popover{position:absolute;top:calc(100% + 6px);left:0;z-index:100;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001f;padding:var(--spacing-md);min-width:220px;max-width:320px}.filter-chip__options{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);max-height:280px;overflow-y:auto}.filter-chip__option{display:inline-flex;align-items:center;padding:4px 12px;border:1px solid var(--color-border);border-radius:var(--radius-full);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);outline:none}.filter-chip__option:hover{border-color:var(--color-primary-dark);background-color:var(--color-background)}.filter-chip__option:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.filter-chip__option--selected{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-text-on-dark);font-weight:var(--font-weight-medium)}.filter-chip__option--selected:hover{background-color:#062a66;border-color:#062a66}.filter-chip__group-header{width:100%;display:flex;flex-direction:column}.filter-chip__group-separator{width:100%;border:none;border-top:1px solid var(--color-border);margin:var(--spacing-xs) 0}.filter-chip__group-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;color:var(--color-text-secondary);padding:var(--spacing-xs) 0 2px;letter-spacing:.03em}.filter-chip__range{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.filter-chip__range-input{flex:1;min-width:0;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.filter-chip__range-input::placeholder{color:var(--color-text-secondary)}.filter-chip__range-input:hover{border-color:var(--color-primary-dark)}.filter-chip__range-input:focus{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c26}.filter-chip__range-sep{color:var(--color-text-secondary);font-size:var(--font-size-sm);flex-shrink:0}.filter-chip__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);border-top:1px solid var(--color-border);padding-top:var(--spacing-sm);margin-top:0}.filter-chip__apply-btn{display:inline-flex;align-items:center;justify-content:center;padding:5px var(--spacing-md);border:none;border-radius:var(--radius-sm);background-color:var(--color-primary-dark);color:var(--color-text-on-dark);font-family:var(--font-body);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background-color var(--transition-fast);outline:none}.filter-chip__apply-btn:hover{background-color:#062a66}.filter-chip__apply-btn:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.filter-chip__clear-btn{background:none;border:none;padding:0;color:var(--color-text-secondary);font-family:var(--font-body);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color var(--transition-fast);outline:none}.filter-chip__clear-btn:hover{color:var(--color-accent-rose)}.filter-chip__clear-btn:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px;border-radius:var(--radius-sm)}.card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.card__body--padding-sm{padding:var(--spacing-sm)}.card__body--padding-md{padding:var(--spacing-md)}.card__body--padding-lg{padding:var(--spacing-lg)}.card__header{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card__header--padding-sm{padding:var(--spacing-sm)}.card__header--padding-lg{padding:var(--spacing-lg)}.card__title{font-family:var(--font-title);font-size:1.125rem;font-weight:700;color:var(--color-primary-dark);line-height:1.3;margin:0}.card__subtitle{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-xs);line-height:1.4}.card__body{flex:1;padding:var(--spacing-md)}.card__actions{padding:var(--spacing-md);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);flex-wrap:wrap}.card__actions--padding-sm{padding:var(--spacing-sm)}.card__actions--padding-lg{padding:var(--spacing-lg)}.datatable-wrapper{position:relative;width:100%;font-family:var(--font-body);font-size:var(--font-size-sm);color:var(--color-text-primary)}.datatable-toolbar{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.datatable-search{flex:1;max-width:320px;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.datatable-search::placeholder{color:var(--color-text-secondary)}.datatable-search:hover{border-color:var(--color-primary-dark)}.datatable-search:focus{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c26}.datatable-scroll{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.datatable{width:100%;border-collapse:collapse;min-width:400px}.datatable__thead{background-color:var(--color-primary-dark)}.datatable__th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);color:var(--color-text-on-dark);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-bottom:2px solid rgba(255,255,255,.1);-webkit-user-select:none;user-select:none}.datatable__th--sortable{cursor:pointer;transition:background-color var(--transition-fast)}.datatable__th--sortable:hover{background-color:#ffffff14}.datatable__th--sortable:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:-2px}.datatable__th-content{display:flex;align-items:center;gap:var(--spacing-xs)}.datatable__th--checkbox,.datatable__td--checkbox{width:40px;padding-left:var(--spacing-md);padding-right:var(--spacing-sm)}.datatable__th--actions{text-align:right;padding-right:var(--spacing-md)}.datatable__sort-icon{display:inline-flex;flex-direction:column;gap:1px;opacity:.35;flex-shrink:0}.datatable__sort-icon--asc,.datatable__sort-icon--desc{opacity:1;color:var(--color-accent-rose)}.datatable__tbody{background-color:var(--color-surface)}.datatable__tr{border-bottom:1px solid var(--color-border);transition:background-color var(--transition-fast)}.datatable__tr:last-child{border-bottom:none}.datatable__tr:nth-child(2n){background-color:#041d4506}.datatable__tr:hover{background-color:#041d450d}.datatable__tr--selected{background-color:#ff005c0f!important}.datatable__tr--clickable{cursor:pointer}.datatable__tr--clickable:hover{background-color:#041d4512}.datatable__td{padding:var(--spacing-sm) var(--spacing-md);vertical-align:middle;color:var(--color-text-primary)}.datatable__td--actions{text-align:right;padding-right:var(--spacing-md);white-space:nowrap}.datatable__checkbox{width:16px;height:16px;cursor:pointer;accent-color:var(--color-accent-rose)}.datatable__empty{padding:var(--spacing-xxl) var(--spacing-md);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-md)}.datatable__tr--skeleton .datatable__td{padding-top:var(--spacing-md);padding-bottom:var(--spacing-md)}.datatable__skeleton-cell{height:14px;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--color-border) 25%,rgba(229,231,235,.5) 50%,var(--color-border) 75%);background-size:200% 100%;animation:datatable-pulse 1.4s ease-in-out infinite}@keyframes datatable-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.datatable__tr--skeleton:nth-child(1) .datatable__skeleton-cell{width:80%}.datatable__tr--skeleton:nth-child(2) .datatable__skeleton-cell{width:65%}.datatable__tr--skeleton:nth-child(3) .datatable__skeleton-cell{width:90%}.datatable__tr--skeleton:nth-child(4) .datatable__skeleton-cell{width:70%}.datatable__tr--skeleton:nth-child(5) .datatable__skeleton-cell{width:85%}.datatable-pagination{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.datatable-pagination__info{flex-shrink:0}.datatable-pagination__controls{display:flex;align-items:center;gap:var(--spacing-sm)}.datatable-pagination__pages{display:flex;align-items:center;gap:2px}.datatable-pagination__page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 var(--spacing-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast);-webkit-user-select:none;user-select:none}.datatable-pagination__page-btn:hover:not(:disabled){background-color:var(--color-background);border-color:var(--color-primary-dark)}.datatable-pagination__page-btn:disabled{opacity:.4;cursor:not-allowed}.datatable-pagination__page-btn--active{background-color:var(--color-primary-dark);color:var(--color-text-on-dark);border-color:var(--color-primary-dark);font-weight:var(--font-weight-semibold)}.datatable-pagination__page-btn--active:hover:not(:disabled){background-color:var(--color-primary-dark)}.datatable-pagination__ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.datatable-pagination__size-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-sm);cursor:pointer;outline:none;transition:border-color var(--transition-fast)}.datatable-pagination__size-select:hover{border-color:var(--color-primary-dark)}.datatable-pagination__size-select:focus{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c26}.datatable-scroll--loading{opacity:.6;pointer-events:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-xxl) var(--spacing-xl);gap:var(--spacing-sm)}.empty-state__icon{font-size:3rem;line-height:1;margin-bottom:var(--spacing-sm)}.empty-state__title{font-family:var(--font-title);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.empty-state__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:360px;margin:0}.empty-state__action{margin-top:var(--spacing-md)}.file-dropzone{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl) var(--spacing-lg);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-background);cursor:pointer;text-align:center;transition:border-color .2s ease,background-color .2s ease,box-shadow .2s ease;min-height:160px;-webkit-user-select:none;user-select:none}.file-dropzone:hover:not(.file-dropzone--disabled){border-color:var(--color-accent-rose);background-color:#ff005c0a}.file-dropzone:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.file-dropzone--drag-active{border-color:var(--color-accent-rose);background-color:#ff005c0f;box-shadow:0 0 0 4px #ff005c1f}.file-dropzone--error{border-color:var(--color-danger);background-color:#ef44440a}.file-dropzone--disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.file-dropzone__input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;width:100%;height:100%;cursor:pointer}.file-dropzone__icon{font-size:2.5rem;line-height:1;color:var(--color-text-secondary);pointer-events:none}.file-dropzone--drag-active .file-dropzone__icon{color:var(--color-accent-rose)}.file-dropzone__label{font-size:.9375rem;font-weight:600;color:var(--color-text-primary);pointer-events:none}.file-dropzone__sublabel{font-size:.8125rem;color:var(--color-text-secondary);pointer-events:none}.file-dropzone__hint{font-size:.75rem;color:var(--color-text-secondary);margin-top:var(--spacing-xs);pointer-events:none}.file-dropzone__error{font-size:.8125rem;color:var(--color-danger);font-weight:500;pointer-events:none;display:flex;align-items:center;gap:var(--spacing-xs)}.input-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-field__label{font-size:.875rem;font-weight:600;color:var(--color-text-primary);line-height:1.4}.input-field__required{color:var(--color-accent-rose);margin-left:2px;aria-hidden:true}.input-field__control{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text-primary);font-family:var(--font-body);font-size:.9375rem;line-height:1.5;transition:border-color .15s ease,box-shadow .15s ease;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input-field__control::placeholder{color:var(--color-text-secondary)}.input-field__control:hover:not(:disabled){border-color:var(--color-primary-dark)}.input-field__control:focus{border-color:var(--color-accent-rose);box-shadow:0 0 0 3px #ff005c26}.input-field__control:disabled{background-color:var(--color-background);color:var(--color-text-secondary);cursor:not-allowed;opacity:.7}.input-field__control--error{border-color:var(--color-danger)}.input-field__control--error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef444426}.input-field__control--textarea{resize:vertical;min-height:96px}.input-field__error{font-size:.8125rem;color:var(--color-danger);line-height:1.4;display:flex;align-items:center;gap:var(--spacing-xs)}.input-field__hint{font-size:.8125rem;color:var(--color-text-secondary);line-height:1.4}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#041d4599;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:modal-overlay-in .2s ease forwards}.modal-overlay--closing{animation:modal-overlay-out .2s ease forwards}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-overlay-out{0%{opacity:1}to{opacity:0}}.modal{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:calc(100vh - 2 * var(--spacing-md));width:100%;position:relative;animation:modal-in .2s ease forwards}.modal-overlay--closing .modal{animation:modal-out .2s ease forwards}@keyframes modal-in{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes modal-out{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(-8px)}}.modal--sm{max-width:400px}.modal--md{max-width:560px}.modal--lg{max-width:800px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal__title{font-family:var(--font-title);font-size:1.125rem;font-weight:700;color:var(--color-primary-dark);margin:0;line-height:1.3}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;padding:0;flex-shrink:0;font-size:1.25rem;line-height:1;transition:background-color .15s ease,color .15s ease}.modal__close:hover{background-color:var(--color-background);color:var(--color-text-primary)}.modal__close:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.modal__body{padding:var(--spacing-lg);overflow-y:auto;flex:1}.modal__footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);flex-shrink:0;flex-wrap:wrap}.modal-open{overflow:hidden}.thumbnail{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md, .375rem);border:1px solid var(--color-border, #e5e7eb);background:var(--color-surface-raised, #f9fafb);overflow:hidden;flex-shrink:0;position:relative}.thumbnail--clickable{cursor:pointer}.thumbnail--clickable:hover{border-color:var(--color-primary, #2563eb);box-shadow:0 0 0 2px var(--color-primary-100, #dbeafe)}.thumbnail--clickable:focus-visible{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.thumbnail__img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.thumbnail__placeholder,.thumbnail__fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--color-surface-raised, #f3f4f6);color:var(--color-text-muted, #9ca3af);font-size:1.25rem;line-height:1}.dashboard{display:flex;flex-direction:column;gap:var(--spacing-xl)}.dashboard__welcome{display:flex;flex-direction:column;gap:var(--spacing-xs)}.dashboard__heading{font-family:var(--font-title);font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.dashboard__subheading{font-size:var(--font-size-md);color:var(--color-text-secondary);margin:0}.dashboard__stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.stat-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);background-color:var(--color-surface);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-card__icon{font-size:1.75rem;line-height:1;width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.stat-card--documents .stat-card__icon{background-color:#eff6ff}.stat-card--inventory .stat-card__icon{background-color:#f0fdf4}.stat-card--proposals .stat-card__icon{background-color:#fff7ed}.stat-card--users .stat-card__icon{background-color:#fdf4ff}.stat-card__body{display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:0}.stat-card__count{font-size:1.75rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);line-height:1}.stat-card__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.dashboard__activity{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-lg)}@media(max-width:700px){.dashboard__activity{grid-template-columns:1fr}}.activity-panel{display:flex;flex-direction:column;gap:var(--spacing-sm);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.activity-panel__heading{font-family:var(--font-title);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-xs);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.activity-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.activity-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-sm);border-radius:var(--radius-md);transition:background-color var(--transition-fast);text-decoration:none;color:inherit;min-width:0}.activity-item:hover{background-color:var(--color-background);text-decoration:none}.activity-item__icon{font-size:1.1rem;flex-shrink:0;width:28px;text-align:center}.activity-item__body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.activity-item__name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-item__meta{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.dashboard__error{background-color:#fef2f2;border:1px solid #fecaca;color:var(--color-danger);border-radius:var(--radius-md);padding:var(--spacing-md);font-size:var(--font-size-sm)}.dashboard__loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xxl)}.document-modal__footer{display:flex;justify-content:flex-end;gap:var(--spacing-sm);flex-wrap:wrap}.document-modal__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.document-modal__file-preview{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md)}.document-modal__file-icon{font-size:2rem;line-height:1;flex-shrink:0}.document-modal__file-info{flex:1;min-width:0}.document-modal__file-name{font-weight:600;font-size:.9375rem;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.document-modal__file-meta{font-size:.8125rem;color:var(--color-text-secondary);margin-top:2px}.document-modal__file-remove{flex-shrink:0;background:none;border:none;padding:4px;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-md);line-height:1;font-size:1rem;transition:color .15s ease,background-color .15s ease}.document-modal__file-remove:hover{color:var(--color-danger);background-color:#ef444414}.document-modal__file-remove:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px}.document-modal__progress{height:6px;background-color:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.document-modal__progress-bar{height:100%;background-color:var(--color-accent-rose);border-radius:var(--radius-full);transition:width .3s ease}.document-modal__error{font-size:.875rem;color:var(--color-danger);background-color:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);display:flex;align-items:flex-start;gap:var(--spacing-xs)}.document-view__meta-grid{display:grid;grid-template-columns:max-content 1fr;column-gap:var(--spacing-lg);row-gap:var(--spacing-sm);align-items:baseline;margin-bottom:var(--spacing-md)}.document-view__meta-label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.document-view__meta-value{font-size:.9375rem;color:var(--color-text-primary);word-break:break-word}.document-view__notes{padding:var(--spacing-md);background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9375rem;color:var(--color-text-primary);white-space:pre-wrap;word-break:break-word;margin-top:var(--spacing-sm)}.document-view__notes-heading{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;margin-bottom:var(--spacing-xs)}.document-view__preview{margin-top:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;background-color:var(--color-background)}.document-view__preview-img{display:block;max-width:100%;max-height:400px;object-fit:contain;margin:0 auto}.document-view__preview-embed{display:block;width:100%;height:400px;border:none}.document-view__divider{border:none;border-top:1px solid var(--color-border);margin:var(--spacing-md) 0}.document-view__preview--unsupported{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl);text-align:center}.document-view__preview-message{color:var(--color-text-secondary);font-size:.875rem}.document-view__preview--loading{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--color-text-secondary);font-size:.875rem}.document-view__preview--error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xl);color:var(--color-danger);font-size:.875rem;text-align:center}.document-view__preview-text{padding:var(--spacing-md);font-family:monospace;font-size:.8125rem;line-height:1.6;white-space:pre-wrap;word-break:break-word;max-height:400px;overflow-y:auto;color:var(--color-text-primary);background-color:var(--color-background);margin:0}.documents-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem)}.documents-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.documents-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.documents-page__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.documents-page__filters{display:flex;align-items:center;gap:var(--space-2, .5rem)}.documents-page__filter-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #555);white-space:nowrap}.documents-page__filter-select{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);background:var(--color-surface, #fff);color:var(--color-text-primary, #111);font-size:.875rem;cursor:pointer}.documents-page__filter-select:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.documents-page__name{font-weight:500;color:var(--color-text-primary, #111)}.documents-page__title-link{background:none;border:none;padding:0;margin:0;font-family:inherit;font-size:inherit;font-weight:600;color:var(--color-primary-dark, #041d45);cursor:pointer;text-align:left;text-decoration:underline;text-underline-offset:2px;text-decoration-color:transparent;transition:color .15s ease,text-decoration-color .15s ease}.documents-page__title-link:hover{color:var(--color-accent-rose, #ff005c);text-decoration-color:var(--color-accent-rose, #ff005c)}.documents-page__title-link:focus-visible{outline:2px solid var(--color-accent-rose, #ff005c);outline-offset:2px;border-radius:2px}.documents-page__filename{max-width:14rem;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.documents-page__type-icon{font-size:1.1rem;line-height:1}.documents-page__file-size{white-space:nowrap;font-variant-numeric:tabular-nums}.documents-page__notes{max-width:12rem;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;color:var(--color-text-secondary, #555)}.documents-page__date{white-space:nowrap}.documents-page__expiry-header{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.documents-page__expiry-toggle{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:.75rem;line-height:1;border-radius:var(--radius-sm, 4px);opacity:.6;transition:opacity var(--transition-fast, .15s ease),background var(--transition-fast, .15s ease)}.documents-page__expiry-toggle:hover{opacity:1;background:#00000014}.documents-page__empty-cell{color:var(--color-text-muted, #9ca3af)}.documents-page__actions{display:flex;align-items:center;gap:var(--space-1, .25rem)}.documents-page__action-delete{color:var(--color-danger-600, #dc2626)}.documents-page__modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.documents-page__modal-warning{margin-top:var(--space-2, .5rem);font-size:.8125rem;color:var(--color-text-muted, #9ca3af)}.import-modal__steps{display:flex;align-items:center;gap:0;margin-bottom:var(--spacing-lg)}.import-modal__step{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:600;color:var(--color-text-secondary);white-space:nowrap}.import-modal__step--active{color:var(--color-accent-rose)}.import-modal__step--done{color:var(--color-success, #16a34a)}.import-modal__step-num{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;font-size:.75rem;font-weight:700;background-color:var(--color-border);color:var(--color-text-secondary);flex-shrink:0}.import-modal__step--active .import-modal__step-num{background-color:var(--color-accent-rose);color:#fff}.import-modal__step--done .import-modal__step-num{background-color:var(--color-success, #16a34a);color:#fff}.import-modal__step-sep{flex:1;height:2px;background-color:var(--color-border);margin:0 var(--spacing-xs);min-width:var(--spacing-md)}.import-modal__step-sep--done{background-color:var(--color-success, #16a34a)}.import-modal__loading{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl) 0;color:var(--color-text-secondary)}.import-modal__spinner{width:36px;height:36px;border:3px solid var(--color-border);border-top-color:var(--color-accent-rose);border-radius:50%;animation:import-spin .7s linear infinite}@keyframes import-spin{to{transform:rotate(360deg)}}.import-modal__error{background-color:#fef2f2;border:1px solid #fca5a5;border-radius:var(--radius-md);color:var(--color-danger, #dc2626);padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-md);font-size:.875rem}.import-modal__summary{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.import-modal__stat{display:flex;align-items:center;gap:var(--spacing-xs);font-size:.875rem;font-weight:600}.import-modal__stat-count{font-size:1.25rem;font-weight:700}.import-modal__stat--total .import-modal__stat-count{color:var(--color-text-primary)}.import-modal__stat--valid .import-modal__stat-count{color:var(--color-success, #16a34a)}.import-modal__stat--invalid .import-modal__stat-count{color:var(--color-danger, #dc2626)}.import-modal__table-wrap{overflow-x:auto;overflow-y:auto;max-height:340px;border:1px solid var(--color-border);border-radius:var(--radius-md)}.import-modal__table{width:100%;border-collapse:collapse;font-size:.8125rem}.import-modal__table th{position:sticky;top:0;background-color:var(--color-surface);padding:var(--spacing-xs) var(--spacing-sm);text-align:left;font-weight:700;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);white-space:nowrap}.import-modal__table td{padding:var(--spacing-xs) var(--spacing-sm);border-bottom:1px solid var(--color-border);vertical-align:top;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.import-modal__table tr.import-modal__row--valid:hover td{background-color:var(--color-background)}.import-modal__table tr.import-modal__row--invalid td{background-color:#fef2f2}.import-modal__row-index{color:var(--color-text-secondary);font-variant-numeric:tabular-nums}.import-modal__row-status{text-align:center;font-size:1rem;width:32px}.import-modal__error-cell{position:relative;cursor:help}.import-modal__error-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;background-color:var(--color-danger, #dc2626);color:#fff;border-radius:50%;font-size:.6875rem;font-weight:700;cursor:help}.import-modal__error-list{position:absolute;top:100%;left:0;z-index:10;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:var(--spacing-sm);min-width:220px;max-width:320px;list-style:none;margin:0;white-space:normal}.import-modal__error-list li{font-size:.8125rem;color:var(--color-danger, #dc2626);padding:2px 0;display:flex;align-items:flex-start;gap:4px}.import-modal__error-list li:before{content:"•";flex-shrink:0}.import-modal__footer{display:flex;align-items:center;gap:var(--spacing-sm);justify-content:flex-end;flex-wrap:wrap}.import-modal__confirm-summary{text-align:center;padding:var(--spacing-lg) 0}.import-modal__confirm-count{font-size:2.5rem;font-weight:800;color:var(--color-accent-rose);display:block;line-height:1;margin-bottom:var(--spacing-xs)}.import-modal__confirm-label{font-size:1rem;color:var(--color-text-secondary)}.import-modal__confirm-skipped{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-sm)}.import-modal__success{text-align:center;padding:var(--spacing-xl) 0}.import-modal__success-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-md)}.import-modal__success-title{font-family:var(--font-title);font-size:1.25rem;font-weight:700;color:var(--color-success, #16a34a);margin-bottom:var(--spacing-xs)}.import-modal__success-body{color:var(--color-text-secondary);font-size:.9375rem}.inventory-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem)}.inventory-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.inventory-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.inventory-page__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.inventory-page__filters{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3, .75rem)}.inventory-page__filter-group{display:flex;align-items:center;gap:var(--space-2, .5rem)}.inventory-page__filter-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #555);white-space:nowrap}.inventory-page__filter-select{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);background:var(--color-surface, #fff);color:var(--color-text-primary, #111);font-size:.875rem;cursor:pointer}.inventory-page__filter-select:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.inventory-page__filter-price-inputs{display:flex;align-items:center;gap:var(--space-1, .25rem)}.inventory-page__filter-price-input{width:6rem;padding:.375rem .5rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);background:var(--color-surface, #fff);color:var(--color-text-primary, #111);font-size:.875rem}.inventory-page__filter-price-input:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.inventory-page__filter-price-sep{color:var(--color-text-muted, #9ca3af);font-size:.875rem}.inventory-page__name{font-weight:500;color:var(--color-text-primary, #111)}.inventory-page__location{color:var(--color-text-secondary, #555);max-width:12rem;display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.inventory-page__dimensions{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--color-text-secondary, #555)}.inventory-page__price{white-space:nowrap;font-variant-numeric:tabular-nums;font-weight:500}.inventory-page__image-count{white-space:nowrap;color:var(--color-text-secondary, #555);font-variant-numeric:tabular-nums}.inventory-page__empty-cell{color:var(--color-text-muted, #9ca3af)}.inventory-page__actions{display:flex;align-items:center;gap:var(--space-1, .25rem)}.inventory-page__action-delete{color:var(--color-danger-600, #dc2626)}.inventory-page__modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.inventory-page__modal-warning{margin-top:var(--space-2, .5rem);font-size:.8125rem;color:var(--color-text-muted, #9ca3af)}.image-manager{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.image-manager__header{display:flex;align-items:center;justify-content:space-between}.image-manager__title{font-size:var(--font-size-base, 1rem);font-weight:600;color:var(--color-text-primary, #111827);margin:0}.image-manager__count{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #6b7280)}.image-manager__limit-note{font-size:var(--font-size-sm, .875rem);color:var(--color-text-secondary, #6b7280);text-align:center;padding:var(--space-3, .75rem);border:1px dashed var(--color-border, #e5e7eb);border-radius:var(--radius-md, .5rem)}.image-manager__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-3, .75rem)}.image-manager__card{position:relative;border:2px solid var(--color-border, #e5e7eb);border-radius:var(--radius-md, .5rem);overflow:hidden;background:var(--color-surface, #ffffff);cursor:grab;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column;align-items:center;padding:var(--space-2, .5rem);gap:var(--space-1, .25rem);-webkit-user-select:none;user-select:none}.image-manager__card:hover{border-color:var(--color-border-hover, #9ca3af);box-shadow:0 2px 6px #00000014}.image-manager__card:active{cursor:grabbing}.image-manager__card--new{border-color:var(--color-primary-200, #bfdbfe);background:var(--color-primary-50, #eff6ff)}.image-manager__card--drag-over{border-color:var(--color-primary-500, #3b82f6);border-style:dashed;box-shadow:0 0 0 3px var(--color-primary-100, #dbeafe)}.image-manager__thumb-wrap{width:120px;height:120px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, .25rem);overflow:hidden;background:var(--color-neutral-100, #f3f4f6);flex-shrink:0}.image-manager__thumb{width:100%;height:100%;object-fit:cover}.image-manager__thumb-placeholder{font-size:2.5rem;opacity:.5}.image-manager__new-badge{position:absolute;top:var(--space-1, .25rem);left:var(--space-1, .25rem);background:var(--color-primary-600, #2563eb);color:#fff;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 5px;border-radius:3px;line-height:1.4}.image-manager__label{width:100%;font-size:.7rem;color:var(--color-text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;margin:0}.image-manager__delete-btn{position:absolute;top:var(--space-1, .25rem);right:var(--space-1, .25rem);width:22px;height:22px;border-radius:50%;border:none;background:var(--color-danger-600, #dc2626);color:#fff;font-size:.7rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s,transform .1s;opacity:0}.image-manager__card:hover .image-manager__delete-btn,.image-manager__card:focus-within .image-manager__delete-btn{opacity:1}.image-manager__delete-btn:hover{background:var(--color-danger-700, #b91c1c);transform:scale(1.1)}.image-manager__delete-btn:focus-visible{outline:2px solid var(--color-focus-ring, #3b82f6);outline-offset:2px;opacity:1}.inventory-form-page{max-width:900px;margin:0 auto;padding:var(--space-6, 1.5rem) var(--space-4, 1rem);display:flex;flex-direction:column;gap:var(--space-6, 1.5rem)}.inventory-form-page__back{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.inventory-form-page__back:hover{color:var(--color-accent-rose);text-decoration:none}.inventory-form-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.inventory-form-page__title{font-size:var(--font-size-2xl, 1.5rem);font-weight:700;color:var(--color-text-primary, #111827);margin:0}.inventory-form-page__loading{color:var(--color-text-secondary, #6b7280);font-size:var(--font-size-sm, .875rem);padding:var(--space-8, 2rem);text-align:center}.inventory-form-page__error{background:var(--color-danger-50, #fef2f2);color:var(--color-danger-700, #b91c1c);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .5rem);padding:var(--space-3, .75rem) var(--space-4, 1rem);font-size:var(--font-size-sm, .875rem)}.inventory-form-page__form{display:flex;flex-direction:column;gap:var(--space-5, 1.25rem)}.inventory-form-page__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4, 1rem)}@media(max-width:640px){.inventory-form-page__grid{grid-template-columns:1fr}}.inventory-form-page__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3, .75rem);padding-top:var(--space-4, 1rem);border-top:1px solid var(--color-border, #e5e7eb)}.image-gallery{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.image-gallery--empty{align-items:center;justify-content:center;min-height:80px}.image-gallery__empty-text{font-size:var(--font-size-sm, .875rem);color:var(--color-text-muted, #9ca3af)}.image-gallery__strip{display:flex;flex-wrap:wrap;gap:var(--space-2, .5rem)}.image-gallery__thumb-btn{padding:0;border:2px solid transparent;border-radius:var(--radius-md, .5rem);background:none;cursor:pointer;overflow:hidden;transition:border-color .15s,box-shadow .15s;flex-shrink:0}.image-gallery__thumb-btn:hover{border-color:var(--color-primary-400, #60a5fa)}.image-gallery__thumb-btn--active{border-color:var(--color-primary-600, #2563eb);box-shadow:0 0 0 2px var(--color-primary-200, #bfdbfe)}.image-gallery__thumb-btn:focus-visible{outline:2px solid var(--color-focus-ring, #3b82f6);outline-offset:2px}.image-gallery__thumb{width:80px;height:80px;object-fit:cover;display:block}.image-gallery__lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000e0;display:flex;align-items:center;justify-content:center}.image-gallery__lb-close{position:absolute;top:var(--space-4, 1rem);right:var(--space-4, 1rem);width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:#ffffff1a;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .15s}.image-gallery__lb-close:hover{background:#ffffff40}.image-gallery__lb-close:focus-visible{outline:2px solid #fff;outline-offset:2px}.image-gallery__lb-counter{position:absolute;top:var(--space-4, 1rem);left:50%;transform:translate(-50%);color:#ffffffbf;font-size:var(--font-size-sm, .875rem);font-weight:500;z-index:10;-webkit-user-select:none;user-select:none}.image-gallery__lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:#ffffff1a;color:#fff;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .15s;line-height:1}.image-gallery__lb-nav--prev{left:var(--space-4, 1rem)}.image-gallery__lb-nav--next{right:var(--space-4, 1rem)}.image-gallery__lb-nav:hover{background:#ffffff40}.image-gallery__lb-nav:focus-visible{outline:2px solid #fff;outline-offset:2px}.image-gallery__lb-img-wrap{max-width:calc(100vw - 160px);max-height:calc(100vh - 100px);display:flex;align-items:center;justify-content:center}.image-gallery__lb-img{max-width:100%;max-height:calc(100vh - 100px);object-fit:contain;border-radius:var(--radius-md, .5rem);box-shadow:0 8px 32px #00000080}.inventory-detail-page{max-width:900px;margin:0 auto;padding:var(--space-6, 1.5rem) var(--space-4, 1rem);display:flex;flex-direction:column;gap:var(--space-6, 1.5rem)}.inventory-detail-page__back{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.inventory-detail-page__back:hover{color:var(--color-accent-rose);text-decoration:none}.inventory-detail-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.inventory-detail-page__loading{color:var(--color-text-secondary, #6b7280);font-size:var(--font-size-sm, .875rem);padding:var(--space-8, 2rem);text-align:center}.inventory-detail-page__error{background:var(--color-danger-50, #fef2f2);color:var(--color-danger-700, #b91c1c);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .5rem);padding:var(--space-3, .75rem) var(--space-4, 1rem);font-size:var(--font-size-sm, .875rem)}.inventory-detail-page__title{font-size:var(--font-size-2xl, 1.5rem);font-weight:700;color:var(--color-text-primary, #111827);margin:0}.inventory-detail__card{background:var(--color-surface, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:var(--radius-lg, .75rem);padding:var(--space-5, 1.25rem) var(--space-6, 1.5rem)}.inventory-detail__meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4, 1rem) var(--space-6, 1.5rem);margin:0}.inventory-detail__meta-row{display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.inventory-detail__meta-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary, #6b7280);margin:0}.inventory-detail__meta-value{font-size:var(--font-size-base, 1rem);color:var(--color-text-primary, #111827);margin:0}.inventory-detail__empty{color:var(--color-text-muted, #9ca3af)}.inventory-detail__notes{margin:0;white-space:pre-wrap;color:var(--color-text-primary, #111827);font-size:var(--font-size-sm, .875rem);line-height:1.6}.inventory-detail__gallery-section{display:flex;flex-direction:column;gap:var(--space-3, .75rem)}.inventory-detail__gallery-heading{font-size:var(--font-size-lg, 1.125rem);font-weight:600;color:var(--color-text-primary, #111827);margin:0}.user-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.user-detail__grid{display:grid;grid-template-columns:max-content 1fr;gap:var(--space-2, .5rem) var(--space-4, 1rem);margin:0}.user-detail__label{font-weight:500;color:var(--color-text-secondary, #555);font-size:.875rem;white-space:nowrap}.user-detail__value{color:var(--color-text-primary, #111);font-size:.875rem;word-break:break-word}.user-form-modal__form{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.user-form-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.user-form-modal__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.user-form-modal__checkbox-row{display:flex;align-items:center;gap:var(--space-2, .5rem)}.user-form-modal__checkbox{width:1rem;height:1rem;cursor:pointer}.user-form-modal__checkbox-label{font-size:.875rem;font-weight:500;color:var(--color-text-primary, #111);cursor:pointer}.users-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem)}.users-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.users-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.users-page__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.users-page__filters{display:flex;align-items:center;gap:var(--space-2, .5rem);flex-wrap:wrap}.users-page__filter-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #555);white-space:nowrap}.users-page__filter-select{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);background:var(--color-surface, #fff);color:var(--color-text-primary, #111);font-size:.875rem;cursor:pointer}.users-page__filter-select:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.users-page__name{font-weight:500;color:var(--color-text-primary, #111)}.users-page__email{color:var(--color-text-secondary, #555);font-size:.875rem}.users-page__date{white-space:nowrap;font-size:.875rem;color:var(--color-text-secondary, #555)}.users-page__empty-cell{color:var(--color-text-muted, #9ca3af)}.users-page__actions{display:flex;align-items:center;gap:var(--space-1, .25rem)}.users-page__action-deactivate{color:var(--color-danger-600, #dc2626)}.users-page__modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.permission-matrix{overflow-x:auto;-webkit-overflow-scrolling:touch}.permission-matrix__table{width:100%;border-collapse:collapse;font-size:.8125rem;table-layout:auto}.permission-matrix__module-header,.permission-matrix__action-header{padding:.5rem .5rem .375rem;text-align:center;font-weight:600;font-size:.75rem;color:var(--color-text-secondary, #555);border-bottom:2px solid var(--color-border, #d1d5db);white-space:nowrap}.permission-matrix__module-header{text-align:left;min-width:120px}.permission-matrix__row{transition:background-color .1s ease}.permission-matrix__row--even{background:var(--color-surface, #ffffff)}.permission-matrix__row--odd{background:var(--color-surface-alt, #f9fafb)}.permission-matrix__row--user-mgmt{background:var(--color-surface-alt, #f9fafb);border-top:1px dashed var(--color-border, #d1d5db)}.permission-matrix__row:hover{background:var(--color-primary-50, #eff6ff)}.permission-matrix__module-label{padding:.5rem .75rem .5rem .5rem;font-weight:500;color:var(--color-text-primary, #111);white-space:nowrap;border-right:1px solid var(--color-border, #d1d5db);vertical-align:middle}.permission-matrix__module-label--sub{font-weight:400;font-size:.75rem;color:var(--color-text-secondary, #555);padding-left:1.25rem}.permission-matrix__cell{text-align:center;vertical-align:middle;padding:.375rem .25rem;border-bottom:1px solid var(--color-border-light, #f3f4f6)}.permission-matrix__cell--empty{background:var(--color-surface-muted, #f8fafc)}.permission-matrix__checkbox{width:1rem;height:1rem;cursor:pointer;accent-color:var(--color-primary, #2563eb)}.permission-matrix__checkbox:disabled{cursor:not-allowed;opacity:.5}.permission-matrix__checkbox:focus-visible{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px;border-radius:2px}.roles-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem)}.roles-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.roles-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.roles-page__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.roles-page__empty{color:var(--color-text-secondary, #555);font-size:.875rem}.roles-page__cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4, 1rem)}.role-card{background:var(--color-surface, #fff);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-lg, .5rem);padding:var(--space-4, 1rem);display:flex;flex-direction:column;gap:var(--space-2, .5rem);transition:box-shadow .15s ease,border-color .15s ease;position:relative}.role-card[role=button]{cursor:pointer}.role-card[role=button]:hover{box-shadow:0 2px 8px #0000001a;border-color:var(--color-primary-200, #bfdbfe)}.role-card[role=button]:focus-visible{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.role-card--system{border-color:var(--color-border, #d1d5db);background:var(--color-surface-alt, #f9fafb)}.role-card--skeleton{pointer-events:none;opacity:.6}.role-card__skeleton-name,.role-card__skeleton-desc,.role-card__skeleton-stats{border-radius:var(--radius-sm, .25rem);background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6,#e5e7eb 75%);background-size:200% 100%;animation:skeleton-shimmer 1.4s infinite}.role-card__skeleton-name{height:1.25rem;width:60%}.role-card__skeleton-desc{height:.875rem;width:85%;margin-top:.25rem}.role-card__skeleton-stats{height:.75rem;width:50%;margin-top:.5rem}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.role-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-2, .5rem)}.role-card__name-row{display:flex;align-items:center;gap:var(--space-2, .5rem);flex-wrap:wrap}.role-card__name{font-weight:600;font-size:1rem;color:var(--color-text-primary, #111);text-transform:capitalize}.role-card__system-badge{flex-shrink:0}.role-card__actions{display:flex;align-items:center;gap:var(--space-1, .25rem);flex-shrink:0}.role-card__delete-btn{color:var(--color-danger-600, #dc2626)}.role-card__delete-btn:disabled{color:var(--color-text-muted, #9ca3af)!important}.role-card__description{margin:0;font-size:.875rem;color:var(--color-text-secondary, #555);line-height:1.4}.role-card__stats{display:flex;align-items:center;gap:var(--space-2, .5rem);font-size:.75rem;color:var(--color-text-muted, #9ca3af);margin-top:var(--space-1, .25rem)}.role-card__stat-value{font-weight:600;color:var(--color-text-secondary, #555)}.role-card__stat-divider{color:var(--color-border, #d1d5db)}.roles-page__modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.roles-page__delete-warning{font-size:.875rem;color:var(--color-text-secondary, #555);margin-top:var(--space-2, .5rem)}.role-form-modal__form{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.role-form-modal__readonly-notice{padding:var(--space-2, .5rem) var(--space-3, .75rem);background:var(--color-warning-50, #fffbeb);border:1px solid var(--color-warning-200, #fde68a);border-radius:var(--radius-md, .375rem);color:var(--color-warning-700, #b45309);font-size:.875rem}.role-form-modal__textarea{resize:vertical;min-height:3.5rem}.role-form-modal__matrix-section{display:flex;flex-direction:column;gap:var(--space-2, .5rem)}.role-form-modal__matrix-title{margin:0;font-size:.875rem;font-weight:600;color:var(--color-text-primary, #111)}.role-form-modal__footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.role-form-modal__error{padding:var(--space-2, .5rem) var(--space-3, .75rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.slide{width:100%;height:100%;position:relative;background-color:var(--color-primary-dark);color:var(--color-text-on-dark);font-family:var(--font-body);overflow:hidden;display:flex;flex-direction:column}[data-placeholder]:empty:before{content:attr(data-placeholder);color:#ffffff4d;pointer-events:none}.slide [contenteditable=true]:focus{outline:2px solid var(--color-accent-rose);border-radius:2px}.slide__image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#ffffff12;color:#ffffff59;font-size:1em;font-family:var(--font-title);letter-spacing:.1em;text-transform:uppercase}.slide--title{align-items:center;justify-content:center;text-align:center;padding:6% 10%}.slide__title-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5em}.slide__title-heading{font-family:var(--font-title);font-size:3em;font-weight:700;color:var(--color-light);line-height:1.1;letter-spacing:-.01em}.slide__title-subtitle{font-size:1.25em;color:#ffffffb3;font-weight:400}.slide__logo-placeholder{position:absolute;bottom:5%;left:50%;transform:translate(-50%);font-family:var(--font-title);font-size:.85em;font-weight:700;letter-spacing:.3em;color:var(--color-accent-rose);opacity:.9}.slide--image-right,.slide--image-left{flex-direction:row}.slide__text-half{flex:1;display:flex;flex-direction:column;justify-content:center;padding:6% 7%;gap:.6em;background-color:var(--color-primary-dark)}.slide__image-half{flex:1;position:relative;overflow:hidden}.slide__image{width:100%;height:100%;object-fit:cover;display:block}.slide__split-title{font-family:var(--font-title);font-size:1.75em;font-weight:700;color:var(--color-light);line-height:1.2}.slide__split-description{font-size:.9em;color:#ffffffbf;line-height:1.6}.slide--full-image{background-size:cover;background-position:center;background-repeat:no-repeat;align-items:center;justify-content:center;text-align:center}.slide__full-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#041d4599}.slide__full-content{position:relative;z-index:1;padding:6% 10%;display:flex;flex-direction:column;align-items:center;gap:.5em}.slide__full-title{font-family:var(--font-title);font-size:2.5em;font-weight:700;color:var(--color-light);line-height:1.1}.slide__full-description{font-size:1em;color:#fffc;line-height:1.6;max-width:70%}.slide--comparison{padding:4% 5%;gap:3%}.slide__comparison-title{font-family:var(--font-title);font-size:1.4em;font-weight:700;color:var(--color-light);text-align:center}.slide__comparison-body{flex:1;display:flex;flex-direction:row;align-items:stretch;gap:0}.slide__comparison-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4em;padding:2% 3%;background:#ffffff0a;border-radius:var(--radius-md)}.slide__comparison-item--empty{justify-content:center}.slide__comparison-vs{display:flex;align-items:center;justify-content:center;padding:0 2%;font-family:var(--font-title);font-size:1.2em;font-weight:700;color:var(--color-accent-rose)}.slide__comparison-img{width:100%;max-height:45%;object-fit:cover;border-radius:var(--radius-sm)}.slide__comparison-name{font-family:var(--font-title);font-size:.85em;font-weight:600;color:var(--color-light);text-align:center}.slide__comparison-price{font-size:1em;font-weight:700;color:var(--color-accent-rose)}.slide__comparison-spec{font-size:.7em;color:#fff9;text-align:center}.slide--summary{padding:4% 5%;gap:3%}.slide__summary-title{font-family:var(--font-title);font-size:1.6em;font-weight:700;color:var(--color-light);text-align:center}.slide__summary-table-wrap{flex:1;overflow:hidden}.slide__summary-table{width:100%;border-collapse:collapse;font-size:.8em}.slide__summary-th{padding:.5em .75em;text-align:left;color:#ffffff80;font-weight:600;font-size:.85em;text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid rgba(255,255,255,.1)}.slide__summary-th--price{text-align:right}.slide__summary-tr{border-bottom:1px solid rgba(255,255,255,.07)}.slide__summary-tr--total{border-top:2px solid rgba(255,255,255,.2);border-bottom:none}.slide__summary-td{padding:.45em .75em;color:#ffffffd9;vertical-align:middle}.slide__summary-td--price{text-align:right}.slide__summary-td--total-label{font-weight:700;color:var(--color-light)}.slide__summary-td--total{font-weight:700;color:var(--color-accent-rose);font-size:1.05em}.slide__summary-cta{font-size:.75em;color:#ffffff80;text-align:center;padding:1% 0}.slide-canvas{width:100%;aspect-ratio:16 / 9;position:relative;background:#000;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-lg)}.slide-canvas__stage{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.slide-canvas__stage--empty{display:flex;align-items:center;justify-content:center;background:var(--color-primary-dark)}.slide-canvas__empty-msg{color:#fff6;font-size:1rem;font-family:var(--font-body)}.proposals-page{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-6, 1.5rem)}.proposals-page__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4, 1rem)}.proposals-page__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.proposals-page__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.proposals-page__filters{display:flex;align-items:center;gap:var(--space-2, .5rem)}.proposals-page__filter-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #555);white-space:nowrap}.proposals-page__filter-select{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);background:var(--color-surface, #fff);color:var(--color-text-primary, #111);font-size:.875rem;cursor:pointer}.proposals-page__filter-select:focus{outline:2px solid var(--color-primary, #2563eb);outline-offset:2px}.proposals-page__name{font-weight:500;color:var(--color-text-primary, #111)}.proposals-page__title-link{background:none;border:none;padding:0;margin:0;font-family:inherit;font-size:inherit;font-weight:600;color:var(--color-primary-dark, #041d45);cursor:pointer;text-align:left;text-decoration:underline;text-underline-offset:2px;text-decoration-color:transparent;transition:color .15s ease,text-decoration-color .15s ease}.proposals-page__title-link:hover{color:var(--color-accent-rose, #ff005c);text-decoration-color:var(--color-accent-rose, #ff005c)}.proposals-page__title-link:focus-visible{outline:2px solid var(--color-accent-rose, #ff005c);outline-offset:2px;border-radius:2px}.proposals-page__currency{font-variant-numeric:tabular-nums;white-space:nowrap}.proposals-page__price{white-space:nowrap;font-variant-numeric:tabular-nums}.proposals-page__date{white-space:nowrap}.proposals-page__empty-cell{color:var(--color-text-muted, #9ca3af)}.proposals-page__actions{display:flex;align-items:center;gap:var(--space-1, .25rem)}.proposals-page__action-delete{color:var(--color-danger-600, #dc2626)}.proposals-page__modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3, .75rem)}.proposals-page__modal-warning{margin-top:var(--space-2, .5rem);font-size:.8125rem;color:var(--color-text-muted, #9ca3af)}.proposal-wizard{display:flex;flex-direction:column;gap:var(--space-6, 1.5rem);padding:var(--space-6, 1.5rem);max-width:900px}.proposal-wizard__header{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2, .5rem)}.proposal-wizard__back-btn{background:none;border:none;padding:0;font-family:inherit;font-size:.875rem;color:var(--color-text-secondary, #555);cursor:pointer;display:flex;align-items:center;gap:var(--space-1, .25rem);transition:color .15s ease}.proposal-wizard__back-btn:hover{color:var(--color-primary, #2563eb)}.proposal-wizard__title{margin:0;font-size:1.5rem;font-weight:600;color:var(--color-text-primary, #111)}.proposal-wizard__steps{display:flex;align-items:center;gap:0}.proposal-wizard__step{display:flex;align-items:center;gap:var(--space-2, .5rem);padding:var(--space-2, .5rem) var(--space-4, 1rem);font-size:.875rem;font-weight:500;color:var(--color-text-muted, #9ca3af);border-bottom:2px solid transparent;transition:color .15s ease,border-color .15s ease}.proposal-wizard__step--active{color:var(--color-primary, #2563eb);border-bottom-color:var(--color-primary, #2563eb)}.proposal-wizard__step--done{color:var(--color-success-600, #16a34a)}.proposal-wizard__step-number{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--color-neutral-100, #f3f4f6);font-size:.75rem;font-weight:700;color:inherit;transition:background .15s ease}.proposal-wizard__step--active .proposal-wizard__step-number{background:var(--color-primary, #2563eb);color:#fff}.proposal-wizard__step--done .proposal-wizard__step-number{background:var(--color-success-600, #16a34a);color:#fff}.proposal-wizard__error{padding:var(--space-3, .75rem) var(--space-4, 1rem);background:var(--color-danger-50, #fef2f2);border:1px solid var(--color-danger-200, #fecaca);border-radius:var(--radius-md, .375rem);color:var(--color-danger-700, #b91c1c);font-size:.875rem}.proposal-wizard__rfp-section{display:flex;flex-direction:column;gap:var(--space-4, 1rem)}.proposal-wizard__rfp-textarea{width:100%;min-height:180px;padding:var(--space-3, .75rem);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);font-family:inherit;font-size:.9375rem;line-height:1.6;color:var(--color-text-primary, #111);background:var(--color-surface, #fff);resize:vertical;box-sizing:border-box;transition:border-color .15s ease,box-shadow .15s ease}.proposal-wizard__rfp-textarea:focus{outline:none;border-color:var(--color-primary, #2563eb);box-shadow:0 0 0 3px #2563eb26}.proposal-wizard__rfp-textarea::placeholder{color:var(--color-text-muted, #9ca3af)}.proposal-wizard__rfp-actions{display:flex;align-items:center;gap:var(--space-3, .75rem)}.proposal-wizard__results{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-4, 1rem);background:var(--color-neutral-50, #f9fafb);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem)}.proposal-wizard__results-title{margin:0;font-size:1rem;font-weight:600;color:var(--color-text-primary, #111)}.proposal-wizard__field{display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.proposal-wizard__field-header{display:flex;align-items:center;gap:var(--space-2, .5rem)}.proposal-wizard__field-label{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary, #555);text-transform:uppercase;letter-spacing:.04em}.proposal-wizard__confidence{display:inline-block;width:.625rem;height:.625rem;border-radius:50%;flex-shrink:0}.proposal-wizard__confidence--high{background:var(--color-success-500, #22c55e)}.proposal-wizard__confidence--medium{background:var(--color-warning-500, #f59e0b)}.proposal-wizard__confidence--low{background:var(--color-danger-500, #ef4444)}.proposal-wizard__chip-list{display:flex;flex-wrap:wrap;gap:var(--space-2, .5rem);align-items:center}.proposal-wizard__chip{display:inline-flex;align-items:center;gap:var(--space-1, .25rem);padding:.25rem .5rem;background:var(--color-surface, #fff);border:1px solid var(--color-border, #d1d5db);border-radius:9999px;font-size:.8125rem;color:var(--color-text-primary, #111)}.proposal-wizard__chip-remove{background:none;border:none;padding:0;margin:0;font-size:.75rem;color:var(--color-text-muted, #9ca3af);cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;width:1rem;height:1rem;border-radius:50%;transition:background .1s ease,color .1s ease}.proposal-wizard__chip-remove:hover{background:var(--color-danger-100, #fee2e2);color:var(--color-danger-600, #dc2626)}.proposal-wizard__chip-add{display:inline-flex;align-items:center;gap:var(--space-1, .25rem);padding:.25rem .5rem;background:none;border:1px dashed var(--color-border, #d1d5db);border-radius:9999px;font-size:.8125rem;color:var(--color-text-secondary, #555);cursor:pointer;transition:border-color .15s ease,color .15s ease}.proposal-wizard__chip-add:hover{border-color:var(--color-primary, #2563eb);color:var(--color-primary, #2563eb)}.proposal-wizard__chip-input{padding:.2rem .375rem;border:1px solid var(--color-primary, #2563eb);border-radius:9999px;font-family:inherit;font-size:.8125rem;outline:none;min-width:8rem}.proposal-wizard__input-row{display:flex;gap:var(--space-2, .5rem);align-items:center}.proposal-wizard__input{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);font-family:inherit;font-size:.875rem;color:var(--color-text-primary, #111);background:var(--color-surface, #fff);transition:border-color .15s ease}.proposal-wizard__input:focus{outline:none;border-color:var(--color-primary, #2563eb)}.proposal-wizard__input--amount{width:9rem}.proposal-wizard__input--wide{width:100%;max-width:24rem}.proposal-wizard__select{padding:.375rem .625rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);font-family:inherit;font-size:.875rem;color:var(--color-text-primary, #111);background:var(--color-surface, #fff);cursor:pointer;transition:border-color .15s ease}.proposal-wizard__select:focus{outline:none;border-color:var(--color-primary, #2563eb)}.proposal-wizard__step1-footer{display:flex;align-items:center;gap:var(--space-4, 1rem);flex-wrap:wrap}.proposal-wizard__currency-row{display:flex;align-items:center;gap:var(--space-2, .5rem)}.proposal-wizard__currency-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary, #555);white-space:nowrap}.proposal-wizard__match-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3, .75rem)}.proposal-wizard__match-meta{font-size:.875rem;color:var(--color-text-secondary, #555)}.proposal-wizard__match-meta strong{color:var(--color-text-primary, #111)}.proposal-wizard__match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--space-4, 1rem)}.proposal-wizard__match-card{display:flex;flex-direction:column;gap:var(--space-3, .75rem);padding:var(--space-4, 1rem);background:var(--color-surface, #fff);border:2px solid var(--color-border, #d1d5db);border-radius:var(--radius-lg, .5rem);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease;position:relative}.proposal-wizard__match-card:hover{border-color:var(--color-primary-light, #93c5fd);box-shadow:0 2px 8px #0000000f}.proposal-wizard__match-card--selected{border-color:var(--color-primary, #2563eb);background:var(--color-primary-50, #eff6ff)}.proposal-wizard__match-card-top{display:flex;align-items:flex-start;gap:var(--space-3, .75rem)}.proposal-wizard__match-card-info{flex:1;min-width:0}.proposal-wizard__match-card-name{margin:0 0 var(--space-1, .25rem);font-size:.9375rem;font-weight:600;color:var(--color-text-primary, #111);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proposal-wizard__match-card-location{margin:0 0 var(--space-2, .5rem);font-size:.8125rem;color:var(--color-text-secondary, #555);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proposal-wizard__match-card-badges{display:flex;flex-wrap:wrap;gap:var(--space-1, .25rem)}.proposal-wizard__match-card-price{margin-top:var(--space-1, .25rem);font-size:.875rem;font-weight:600;color:var(--color-text-primary, #111)}.proposal-wizard__score{display:inline-flex;align-items:center;justify-content:center;min-width:2.75rem;height:2.75rem;border-radius:50%;font-size:.875rem;font-weight:700;flex-shrink:0}.proposal-wizard__score--high{background:var(--color-success-100, #dcfce7);color:var(--color-success-700, #15803d)}.proposal-wizard__score--medium{background:var(--color-warning-100, #fef9c3);color:var(--color-warning-700, #a16207)}.proposal-wizard__score--low{background:var(--color-neutral-100, #f3f4f6);color:var(--color-text-secondary, #555)}.proposal-wizard__reasons{border-top:1px solid var(--color-border, #d1d5db);padding-top:var(--space-2, .5rem)}.proposal-wizard__reasons-toggle{background:none;border:none;padding:0;font-family:inherit;font-size:.8125rem;color:var(--color-primary, #2563eb);cursor:pointer;display:flex;align-items:center;gap:var(--space-1, .25rem);margin-bottom:var(--space-1, .25rem)}.proposal-wizard__reasons-list{margin:0;padding:0 0 0 var(--space-4, 1rem);font-size:.8125rem;color:var(--color-text-secondary, #555)}.proposal-wizard__reasons-list li{margin-bottom:.125rem}.proposal-wizard__match-card-checkbox{position:absolute;top:var(--space-3, .75rem);right:var(--space-3, .75rem);width:1.125rem;height:1.125rem;cursor:pointer;accent-color:var(--color-primary, #2563eb)}.proposal-wizard__step2-footer{display:flex;flex-direction:column;gap:var(--space-4, 1rem);padding:var(--space-4, 1rem);background:var(--color-neutral-50, #f9fafb);border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem)}.proposal-wizard__title-row{display:flex;flex-direction:column;gap:var(--space-1, .25rem)}.proposal-wizard__title-label{font-size:.875rem;font-weight:600;color:var(--color-text-secondary, #555)}.proposal-wizard__title-input{padding:.5rem .75rem;border:1px solid var(--color-border, #d1d5db);border-radius:var(--radius-md, .375rem);font-family:inherit;font-size:.9375rem;color:var(--color-text-primary, #111);background:var(--color-surface, #fff);max-width:32rem;transition:border-color .15s ease}.proposal-wizard__title-input:focus{outline:none;border-color:var(--color-primary, #2563eb)}.proposal-wizard__footer-actions{display:flex;align-items:center;gap:var(--space-3, .75rem);flex-wrap:wrap}.proposal-wizard__selected-count{font-size:.875rem;color:var(--color-text-secondary, #555)}.proposal-wizard__selected-count strong{color:var(--color-primary, #2563eb)}.proposal-wizard__no-matches{text-align:center;padding:var(--space-8, 2rem);color:var(--color-text-muted, #9ca3af);font-size:.9375rem}.proposal-detail{display:flex;flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-xl);max-width:960px;margin:0 auto}.proposal-detail__loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xxl)}.proposal-detail__error{padding:var(--spacing-md);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--color-danger);font-size:var(--font-size-sm)}.proposal-detail__back{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.proposal-detail__back:hover{color:var(--color-accent-rose);text-decoration:none}.proposal-detail__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.proposal-detail__title-group{display:flex;flex-direction:column;gap:var(--spacing-sm);min-width:0}.proposal-detail__title{font-family:var(--font-title);font-size:1.75rem;font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0;line-height:1.2}.proposal-detail__status-row{display:flex;align-items:center;gap:var(--spacing-sm)}.proposal-detail__edit-btn{flex-shrink:0}.proposal-detail__header-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.proposal-detail__meta{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.proposal-detail__meta-heading{font-family:var(--font-title);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.proposal-detail__meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.proposal-detail__meta-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.proposal-detail__meta-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.proposal-detail__meta-value{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.proposal-detail__meta-value--empty{color:var(--color-text-secondary);font-weight:var(--font-weight-normal)}.proposal-detail__notes{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.proposal-detail__notes-heading{font-family:var(--font-title);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-sm)}.proposal-detail__notes-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin:0;white-space:pre-wrap}.proposal-detail__inventory{display:flex;flex-direction:column;gap:var(--spacing-md)}.proposal-detail__inventory-heading{font-family:var(--font-title);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.proposal-detail__inventory-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.proposal-detail__inventory-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base)}.proposal-detail__inventory-card:hover{box-shadow:var(--shadow-md)}.proposal-detail__inventory-thumb{width:100%;aspect-ratio:16 / 9;background:var(--color-background);overflow:hidden;display:flex;align-items:center;justify-content:center}.proposal-detail__inventory-thumb img{width:100%;height:100%;object-fit:cover}.proposal-detail__inventory-thumb-placeholder{font-size:2rem;color:var(--color-text-secondary);opacity:.4}.proposal-detail__inventory-info{padding:var(--spacing-sm) var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-xs)}.proposal-detail__inventory-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proposal-detail__inventory-location{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proposal-detail__inventory-empty{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center}@media(max-width:640px){.proposal-detail{padding:var(--spacing-md)}.proposal-detail__title{font-size:1.25rem}.proposal-detail__header{flex-direction:column;align-items:flex-start}}.slide-preview{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal);background:#000000f2;display:flex;align-items:center;justify-content:center;padding:4vh 6vw}.slide-preview__canvas-wrap{width:100%;max-width:1280px;max-height:80vh;aspect-ratio:16 / 9;opacity:0;transition:opacity var(--transition-slow)}.slide-preview__canvas-wrap--visible{opacity:1}.slide-preview__close{position:absolute;top:20px;right:24px;background:#ffffff1a;border:none;color:#fff;font-size:1.5rem;width:40px;height:40px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background var(--transition-fast)}.slide-preview__close:hover{background:#fff3}.slide-preview__counter{position:absolute;top:24px;left:50%;transform:translate(-50%);color:#ffffff80;font-size:.875rem;font-family:var(--font-body);letter-spacing:.05em}.slide-preview__nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:3rem;line-height:1;width:56px;height:80px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);-webkit-user-select:none;user-select:none}.slide-preview__nav:hover:not(:disabled){background:#fff3}.slide-preview__nav:disabled{opacity:.25;cursor:default}.slide-preview__nav--prev{left:16px}.slide-preview__nav--next{right:16px}.slide-editor{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--color-background)}.slide-editor__breadcrumb{display:flex;flex-direction:row;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:var(--color-primary-dark);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.slide-editor__toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary-dark);color:var(--color-text-on-dark);flex-shrink:0;gap:var(--spacing-md);box-shadow:var(--shadow-sm)}.slide-editor__title{font-family:var(--font-title);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.slide-editor__back{display:inline-flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:#fff9;text-decoration:none;transition:color var(--transition-fast);white-space:nowrap}.slide-editor__back:hover{color:#fff;text-decoration:none}.slide-editor__toolbar-left{display:flex;align-items:center;gap:var(--spacing-sm);min-width:0}.slide-editor__toolbar-actions{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.slide-editor__btn{padding:6px 14px;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:var(--color-light);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:var(--font-body);cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.slide-editor__btn:hover:not(:disabled){background:#ffffff26}.slide-editor__btn:disabled{opacity:.4;cursor:default}.slide-editor__btn--primary{background:var(--color-accent-rose);border-color:var(--color-accent-rose)}.slide-editor__btn--primary:hover:not(:disabled){background:#e0004f}.slide-editor__btn--danger{background:var(--color-danger);border-color:var(--color-danger)}.slide-editor__btn--danger:hover:not(:disabled){background:#dc2626}.slide-editor__save-status{font-size:var(--font-size-sm);margin-left:var(--spacing-xs);white-space:nowrap}.slide-editor__save-status--saved{color:var(--color-success)}.slide-editor__save-status--saving{color:#fff9}.slide-editor__save-status--unsaved{color:var(--color-warning)}.slide-editor__workspace{display:flex;flex:1;overflow:hidden;min-height:0}.slide-editor__left{width:200px;flex-shrink:0;background:#0a2452;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;overflow:hidden}.slide-list{flex:1;overflow-y:auto;padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.slide-list__item{position:relative;border-radius:var(--radius-sm);cursor:pointer;padding:6px;background:#ffffff0a;border:2px solid transparent;transition:border-color var(--transition-fast),background var(--transition-fast);-webkit-user-select:none;user-select:none}.slide-list__item:hover{background:#ffffff14}.slide-list__item--active{border-color:var(--color-accent-rose);background:#ff005c14}.slide-list__index{font-size:10px;color:#fff6;margin-bottom:4px;font-family:var(--font-body)}.slide-list__thumb{width:100%;aspect-ratio:16 / 9;overflow:hidden;border-radius:var(--radius-sm);background:var(--color-primary-dark);position:relative}.slide-list__thumb-inner{position:absolute;top:0;right:0;bottom:0;left:0}.slide-list__label{font-size:10px;color:#ffffff80;margin-top:4px;text-align:center;font-family:var(--font-body);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.slide-list__delete{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:var(--radius-full);border:none;background:var(--color-danger);color:#fff;font-size:10px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;padding:0}.slide-list__add-btn{margin:var(--spacing-sm);padding:8px;background:#ffffff0f;border:1px dashed rgba(255,255,255,.2);color:#fff9;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:var(--font-body);cursor:pointer;width:calc(100% - var(--spacing-md));transition:background var(--transition-fast),color var(--transition-fast)}.slide-list__add-btn:hover{background:#ffffff1f;color:#fff}.slide-editor__center{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg);background:#1a1a2e;overflow:hidden}.slide-editor__canvas-wrap{width:100%;max-width:960px}.slide-editor__right{width:250px;flex-shrink:0;background:var(--color-surface);border-left:1px solid var(--color-border);overflow-y:auto}.slide-editor__properties{padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.slide-editor__panel-heading{font-family:var(--font-title);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border-bottom:1px solid var(--color-border);padding-bottom:var(--spacing-sm)}.slide-editor__field{display:flex;flex-direction:column;gap:4px}.slide-editor__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.slide-editor__select,.slide-editor__input{width:100%;padding:7px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:var(--font-body);background:var(--color-surface);color:var(--color-text-primary);transition:border-color var(--transition-fast)}.slide-editor__select:focus,.slide-editor__input:focus{outline:none;border-color:var(--color-accent-rose)}.slide-editor__textarea{width:100%;padding:7px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-family:var(--font-body);background:var(--color-surface);color:var(--color-text-primary);resize:vertical;transition:border-color var(--transition-fast)}.slide-editor__textarea:focus{outline:none;border-color:var(--color-accent-rose)}.slide-editor__no-slide{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.slide-editor__loading{display:flex;align-items:center;justify-content:center;height:100vh}.slide-editor__error{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--color-danger);font-size:var(--font-size-md);padding:var(--spacing-lg);text-align:center}.slide-editor__confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) + 10);background:#0009;display:flex;align-items:center;justify-content:center}.slide-editor__confirm-dialog{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:var(--spacing-md);max-width:360px;width:90%}.slide-editor__confirm-msg{font-size:var(--font-size-md);color:var(--color-text-primary)}.slide-editor__confirm-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm)}:root{--color-primary-dark: #041d45;--color-accent-rose: #ff005c;--color-light: #ffffff;--color-background: #f5f7fa;--color-surface: #ffffff;--color-text-primary: #1a1a2e;--color-text-secondary: #6b7280;--color-text-on-dark: #ffffff;--color-text-on-accent: #ffffff;--color-border: #e5e7eb;--color-success: #10b981;--color-warning: #f59e0b;--color-danger: #ef4444;--color-info: #3b82f6;--color-surface-raised: #ffffff;--color-overlay: rgba(4, 29, 69, .6);--font-body: "Barlow", sans-serif;--font-title: "Futura", "Century Gothic", "AppleGothic", sans-serif;--font-size-xs: .6875rem;--font-size-sm: .8125rem;--font-size-md: .9375rem;--font-size-lg: 1.0625rem;--font-size-xl: 1.125rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-xxl: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--z-modal: 1000;--z-toast: 1100;--z-tooltip: 1200;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background-color:var(--color-background);color:var(--color-text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-title);line-height:1.2;color:var(--color-text-primary)}a{color:var(--color-accent-rose);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--color-accent-rose);outline-offset:2px;border-radius:var(--radius-sm)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-primary-dark);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#062a66}*{scrollbar-width:thin;scrollbar-color:var(--color-primary-dark) var(--color-background)}img,svg{display:block;max-width:100%}button,input,select,textarea{font-family:inherit;font-size:inherit}html,body{overflow-x:hidden}
