:root{--border-radius-sm:4px;--border-radius-md:8px;--border-radius-lg:12px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:48px;--z-header:100;--z-footer:100;--z-sticky-tabs:10;--z-modals:1000;--z-tooltips:1100;--color-primary:#1f75d1;--color-primary-light:#e3f2fc;--color-secondary:#6c757d;--color-success:#43a047;--color-danger:#d32f2f;--color-warning:#f57c00;--color-info:#0288d1;--color-text-strong:#222;--color-text-default:#333;--color-text-muted:#666;--color-text-subtle:#888;--surface-disabled:#eceff2;--color-info-bg:#f0f8ff;--color-info-border:#bee5eb;--color-info-text:#0b4f6b;--color-danger-bg:#ffebee;--color-danger-border:#ffcdd2;--table-row-base:#fff;--table-row-alt:#f8f9fa;--table-row-hover:#f2f6fa;--color-danger-text:#b71c1c;--color-success-bg:#e8f5e8;--color-success-border:#c8e6c9;--color-success-text:#1b5e20;--color-warning-bg:#fffbe6;--color-warning-border:#ffe58f;--color-warning-text:#856404;--font-family-sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;--font-size-3xl:2.25rem;--font-size-2xl:1.875rem;--font-size-xl:1.5rem;--font-size-lg:1.125rem;--font-size-md:1rem;--font-size-sm:0.9375rem;--font-size-xs:0.8125rem;--line-height-tight:1.2;--line-height-snug:1.35;--line-height-normal:1.5;--letter-spacing-tight:-0.015em;--letter-spacing-normal:0;--color-border-default:#d0d7de;--color-border-subtle:#e4e7eb;--color-border-strong:#b4bcc2;--focus-ring:0 0 0 3px #1f75d159;--breakpoint-mobile:768px;--breakpoint-desktop:1200px;--container-max-width:1200px;--container-padding:24px;--diff-add-bg:#e6fbf0;--diff-add-border:#b6e8ce;--diff-add-text:#116b3d;--diff-remove-bg:#fff5f5;--diff-remove-border:#fed7d7;--diff-remove-text:#b02323;--diff-change-bg:#fef9e6;--diff-change-border:#f7e7a3;--diff-change-text:#7a5a00;--surface-input:#fff;--surface-hover:#0000000d;--diff-gradient-success-start:#28a745;--diff-gradient-success-end:#20c997;--surface-button:#f5f7f9;--surface-button-hover:#eceff1;--surface-button-active:#e0e3e6;--surface-button-text:var(--color-text-default);--surface-button-secondary:#eceff3;--surface-button-secondary-hover:#e2e7ec;--surface-button-secondary-active:#d7dde2;--surface-button-secondary-border:var(--color-border-default);--surface-button-secondary-text:#1f3547;--surface-button-ghost-bg:#0000;--surface-button-ghost-hover:#0000000d;--surface-button-ghost-active:#00000017;--surface-button-ghost-text:var(--color-text-default);--surface-button-outline-bg:#0000;--surface-button-outline-border:var(--color-border-default);--surface-button-outline-hover-bg:#0000000a;--surface-button-outline-active-bg:#00000014;--surface-button-outline-text:var(--color-text-default);--surface-input-alt:#f8f9fa;--button-border-transparent:#0000;--button-border-neutral:var(--color-border-subtle);--button-border-strong:var(--color-border-default);--button-border-primary:var(--color-primary);--surface-button-primary:var(--color-primary);--surface-button-primary-hover:#1669bd;--surface-button-primary-active:#135da8;--surface-button-primary-text:var(--color-text-on-primary);--datepicker-day-bg:#0000;--datepicker-day-hover-bg:var(--surface-hover);--datepicker-day-selected-bg:var(--color-primary);--datepicker-day-selected-text:var(--color-text-on-primary);--datepicker-day-today-ring:var(--color-primary);--datepicker-day-text:var(--color-text-default);--datepicker-day-disabled-text:var(--color-text-muted);--button-padding-sm-y:4px;--button-padding-sm-x:10px;--button-padding-md-y:8px;--button-padding-md-x:14px;--button-padding-lg-y:12px;--button-padding-lg-x:20px;--button-radius:var(--border-radius-sm);--button-spinner-color:currentColor;--color-text-on-primary:#fff;--color-text-on-success:#fff;--color-text-on-danger:#fff;--color-text-on-warning:#fff;--color-text-on-info:#fff;--surface-elevated-deep:#fdfdfd;--surface-user-panel:var(--surface-elevated);--surface-user-panel-alt:var(--surface-elevated-alt)}.border-radius-sm{border-radius:4px;border-radius:var(--border-radius-sm)}.border-radius-md{border-radius:8px;border-radius:var(--border-radius-md)}.border-radius-lg{border-radius:12px;border-radius:var(--border-radius-lg)}.spacing-xs{margin:4px;margin:var(--spacing-xs)}.spacing-md{margin:16px;margin:var(--spacing-md)}.spacing-lg{margin:24px;margin:var(--spacing-lg)}.spacing-xl{margin:32px;margin:var(--spacing-xl)}.padding-sm{padding:8px;padding:var(--spacing-sm)}.padding-md{padding:16px;padding:var(--spacing-md)}.padding-lg{padding:24px;padding:var(--spacing-lg)}.padding-xl{padding:32px;padding:var(--spacing-xl)}.padding-xxl{padding:48px;padding:var(--spacing-xxl)}.page-title{color:#222;color:var(--color-text-strong);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-family:var(--font-family-sans);font-size:1.875rem;font-size:var(--font-size-2xl);font-weight:700;letter-spacing:-.015em;letter-spacing:var(--letter-spacing-tight);line-height:1.2;line-height:var(--line-height-tight);margin:0 0 12px}.page-description{color:#666;color:var(--color-text-muted);font-size:1rem;font-size:var(--font-size-md);line-height:1.5;line-height:var(--line-height-normal);margin:0 0 32px;max-width:800px}.section-title{color:#222;color:var(--color-text-strong);font-size:1.5rem;font-size:var(--font-size-xl);line-height:1.35;line-height:var(--line-height-snug);margin:0 0 20px}.section-title,.subheading{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-family:var(--font-family-sans)}.subheading{color:#333;color:var(--color-text-default);font-size:1.125rem;font-size:var(--font-size-lg);font-weight:600;margin:0 0 16px}.eyebrow{font-size:.8125rem;font-size:var(--font-size-xs);font-weight:700;letter-spacing:.1em;margin:0 0 8px;text-transform:uppercase}.eyebrow,.text-muted{color:#666;color:var(--color-text-muted)}.text-subtle{color:#888;color:var(--color-text-subtle)}.text-small{font-size:.9375rem;font-size:var(--font-size-sm)}.text-xs{font-size:.8125rem;font-size:var(--font-size-xs)}.text-primary{color:#1f75d1;color:var(--color-primary)}.text-success{color:#43a047;color:var(--color-success)}.text-danger{color:#d32f2f;color:var(--color-danger)}.text-warning{color:#f57c00;color:var(--color-warning)}.text-info{color:#0288d1;color:var(--color-info)}.page-container{max-width:100%;padding:32px 40px;width:100%}.page-header{margin-bottom:32px;text-align:left}.page-header .page-title{margin-bottom:8px}.page-header .page-description{margin-bottom:0}.page-content{display:flex;flex-direction:column;gap:24px}.page-section{background:var(--surface-elevated);border:1px solid #e4e7eb;border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:24px}.page-section-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.page-section-header .section-title{margin-bottom:0}.form-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px}.form-row:last-child{margin-bottom:0}.form-group{display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:200px}.form-group-auto{flex:0 0 auto}.form-label{color:#333;color:var(--color-text-default);font-size:.9375rem;font-size:var(--font-size-sm);font-weight:600}.form-actions{gap:12px}.results-section{margin-top:24px}.results-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.results-count{color:#666;color:var(--color-text-muted);font-size:.9375rem;font-size:var(--font-size-sm);font-weight:500}.icon{align-items:center;display:inline-flex;justify-content:center;line-height:1}.icon-sm{font-size:14px;height:16px;width:16px}.icon-md{font-size:16px;height:20px;width:20px}.icon-lg{font-size:20px;height:28px;width:28px}.icon-primary{color:#1f75d1;color:var(--color-primary)}.icon-success{color:#43a047;color:var(--color-success)}.icon-danger{color:#d32f2f;color:var(--color-danger)}.icon-warning{color:#f57c00;color:var(--color-warning)}.icon-info{color:#0288d1;color:var(--color-info)}.icon-muted{color:#666;color:var(--color-text-muted)}h1.page-title,h1.section-title,h1.subheading,h2.page-title,h2.section-title,h2.subheading,h3.page-title,h3.section-title,h3.subheading{margin-top:0}@media (max-width:820px){.page-title{font-size:1.55rem}.section-title{font-size:1.3rem}.subheading{font-size:1.05rem}}.btn{background:#f5f7f9;background:var(--surface-button);border-radius:4px;border-radius:var(--button-radius);box-shadow:0 1px 2px #0000000d;color:#333;color:var(--surface-button-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-family:var(--font-family-sans);font-size:.9375rem;font-size:var(--font-size-sm);font-weight:600;gap:8px;padding:8px 14px;padding:var(--button-padding-md-y) var(--button-padding-md-x);transition:all .2s ease}.btn:hover{background:#eceff1;background:var(--surface-button-hover);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.btn:active{background:#e0e3e6;background:var(--surface-button-active);box-shadow:0 1px 2px #0000000d;transform:translateY(0)}.btn:focus-visible{box-shadow:0 0 0 3px #1f75d159;box-shadow:var(--focus-ring);outline:none}.btn:disabled,.btn[disabled]{box-shadow:none;cursor:not-allowed;opacity:.55;transform:none}.btn-primary{background:linear-gradient(135deg,#1f75d1,#1a5a9e);background:linear-gradient(135deg,var(--surface-button-primary) 0,#1a5a9e 100%);box-shadow:0 2px 8px #1f75d140;color:#fff;color:var(--surface-button-primary-text)}.btn-primary:hover{background:linear-gradient(135deg,#2485e0,#1f75d1);box-shadow:0 4px 12px #1f75d159}.btn-primary:active{background:#135da8;background:var(--surface-button-primary-active)}.btn-secondary{background:#eceff3;background:var(--surface-button-secondary);border:1px solid #e4e7eb;border:1px solid var(--color-border-subtle);color:#1f3547;color:var(--surface-button-secondary-text)}.btn-secondary:hover{background:#e2e7ec;background:var(--surface-button-secondary-hover)}.btn-secondary:active{background:#d7dde2;background:var(--surface-button-secondary-active)}.btn-success{background:linear-gradient(135deg,#43a047,#2e7d32);background:linear-gradient(135deg,var(--color-success) 0,#2e7d32 100%);box-shadow:0 2px 8px #43a04740;color:#fff}.btn-success:hover{background:linear-gradient(135deg,#4caf50,#43a047);box-shadow:0 4px 12px #43a04759}.btn-success:active{background:#2f7436}.btn-danger{background:linear-gradient(135deg,#d32f2f,#b71c1c);background:linear-gradient(135deg,var(--color-danger) 0,#b71c1c 100%);box-shadow:0 2px 8px #d32f2f40;color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#ef5350,#d32f2f);box-shadow:0 4px 12px #d32f2f59}.btn-danger:active{background:#b71c1c}.btn-ghost{background:#0000;border:none;box-shadow:none;color:#333;color:var(--surface-button-ghost-text)}.btn-ghost:hover{background:#0000000d;box-shadow:none}.btn-ghost:active{background:#00000014}.btn-outline{background:#0000;border:1.5px solid #1f75d1;border:1.5px solid var(--color-primary);box-shadow:none;color:#1f75d1;color:var(--color-primary)}.btn-outline:hover{background:#1f75d114;box-shadow:none}.btn-outline:active{background:#1f75d126}.btn-outline:focus-visible{box-shadow:0 0 0 3px #1f75d159;box-shadow:var(--focus-ring);outline:none}.hover-overlay,.hoverable:hover{background:#0000000d;background:var(--surface-hover)}.btn-icon{height:32px;justify-content:center;padding:6px;width:32px}.btn-sm{font-size:.8125rem;font-size:var(--font-size-xs);padding:4px 10px;padding:var(--button-padding-sm-y) var(--button-padding-sm-x)}.btn-lg{font-size:1rem;font-size:var(--font-size-md);padding:12px 20px;padding:var(--button-padding-lg-y) var(--button-padding-lg-x)}.btn.is-loading{color:#0000!important;pointer-events:none;position:relative}.btn.is-loading:after{animation:btnspin .6s linear infinite;border:2px solid;border:2px solid var(--button-spinner-color);border-radius:50%;border-right:2px solid #0000;content:"";height:14px;position:absolute;width:14px}@keyframes btnspin{to{transform:rotate(1turn)}}.form-control,select,textarea{background:#fff;background:var(--surface-input);border:1px solid #e4e7eb;border:1px solid var(--color-border-subtle);border-radius:8px;border-radius:var(--border-radius-md);box-sizing:border-box;color:#333;color:var(--color-text-default);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-family:var(--font-family-sans);font-size:.9375rem;font-size:var(--font-size-sm);line-height:1.4;padding:10px 14px;transition:all .2s ease;width:100%}.form-control:hover,select:hover,textarea:hover{border-color:#d0d7de;border-color:var(--color-border-default)}.form-control:focus,select:focus,textarea:focus{background:#fff;box-shadow:0 0 0 3px #1f75d126}.form-control[disabled],select[disabled],textarea[disabled]{background:#eceff2;background:var(--surface-disabled);color:#666;color:var(--color-text-muted);cursor:not-allowed}label{color:#333;color:var(--color-text-default);display:block;font-size:.9375rem;font-size:var(--font-size-sm);font-weight:600;margin-bottom:6px}:root[data-theme=dark] input[type=date],:root[data-theme=dark] input[type=time],input[type=date],input[type=time]{background:#fff;background:var(--surface-input);color:#333;color:var(--color-text-default)}:root[data-theme=dark] input[type=date],:root[data-theme=dark] input[type=time]{color-scheme:dark}:root{--picker-icon-filter-light:invert(0.2)}:root[data-theme=dark]{--picker-icon-filter-dark:invert(0.92) brightness(1.25) saturate(1.2)}input[type=time]::-webkit-calendar-picker-indicator{filter:var(--picker-icon-filter-light)}:root[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{filter:var(--picker-icon-filter-dark);opacity:.95}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.2);filter:var(--picker-icon-filter-light)}:root[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator{filter:var(--picker-icon-filter-dark);opacity:.95}input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.2)}:root[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{filter:invert(.85);opacity:.9}input[type=time]::-webkit-clear-button,input[type=time]::-webkit-inner-spin-button{display:none}:root[data-theme=dark] input[type=time]::-webkit-datetime-edit-fields-wrapper{background:#0000}:root[data-theme=dark] input[type=time]::-webkit-datetime-edit-hour-field,:root[data-theme=dark] input[type=time]::-webkit-datetime-edit-minute-field,:root[data-theme=dark] input[type=time]::-webkit-datetime-edit-text{color:#333;color:var(--color-text-default)}.form-hint{color:#666;color:var(--color-text-muted)}.form-error,.form-hint{font-size:.8125rem;font-size:var(--font-size-xs);margin-top:4px}.form-error{color:#d32f2f;color:var(--color-danger)}.table{font-size:.9375rem;font-size:var(--font-size-sm)}.table th{background:var(--surface-elevated-alt);border-bottom:2px solid #e4e7eb;border-bottom:2px solid var(--color-border-subtle);color:#666;color:var(--color-text-muted);font-size:.8125rem;font-size:var(--font-size-xs);letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #e4e7eb;border-bottom:1px solid var(--color-border-subtle);padding:12px 16px;vertical-align:middle}.table tbody tr{transition:background .15s ease}.table tbody tr:hover{background:#f2f6fa;background:var(--table-row-hover)}.table-zebra tbody tr:nth-child(odd){background:#f8f9fa;background:var(--table-row-alt)}.table-compact td,.table-compact th{padding:8px 12px}.react-datepicker,.react-datepicker__header{background:var(--surface-elevated-alt);border:1px solid #e4e7eb;border:1px solid var(--color-border-subtle)}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#333;color:var(--color-text-default);font-weight:600}.react-datepicker__day{background:#0000;background:var(--datepicker-day-bg);border-radius:6px;color:#333;color:var(--datepicker-day-text);transition:background .15s,color .15s,box-shadow .18s}.react-datepicker__day:hover{background:#0000000d;background:var(--datepicker-day-hover-bg)}.react-datepicker__day--outside-month{opacity:.45}.react-datepicker__day--disabled{color:#666;color:var(--datepicker-day-disabled-text);opacity:.4}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected{background:#1f75d1;background:var(--datepicker-day-selected-bg);box-shadow:none;color:#fff;color:var(--datepicker-day-selected-text)}.react-datepicker__day--today{position:relative}.react-datepicker__day--today:after{border:1px solid #1f75d1;border:1px solid var(--datepicker-day-today-ring);border-radius:6px;content:"";inset:0;pointer-events:none;position:absolute}.stack-sm>*+*{margin-top:8px;margin-top:var(--spacing-sm)}.stack-md>*+*{margin-top:16px;margin-top:var(--spacing-md)}.stack-lg>*+*{margin-top:24px;margin-top:var(--spacing-lg)}.card{background:var(--surface-elevated);border:none;border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 1px 3px #0000000a;padding:24px;padding:var(--spacing-lg);position:relative;transition:box-shadow .2s ease}.card-muted{background:var(--surface-elevated-alt)}.card-accent{background:linear-gradient(135deg,#1f75d108,#0000);border-left:3px solid #1f75d1;border-left:3px solid var(--color-primary)}.card-danger{background:linear-gradient(135deg,#d32f2f08,#0000);border-left:3px solid #d32f2f;border-left:3px solid var(--color-danger)}.card-success{background:linear-gradient(135deg,#43a04708,#0000);border-left:3px solid #43a047;border-left:3px solid var(--color-success)}.card-hoverable{transition:all .2s ease}.card-hoverable:hover{box-shadow:0 4px 20px #00000014;transform:translateY(-1px)}.card>:first-child{margin-top:0!important}.card>:last-child{margin-bottom:0!important}.card-sections{display:flex;flex-direction:column;gap:16px;gap:var(--spacing-md)}.badge{background:#eef2f6;border-radius:10px;color:#445;display:inline-block;font-size:.8125rem;font-size:var(--font-size-xs);font-weight:500;letter-spacing:.5px;padding:2px 6px}.card-section+.card-section{margin-top:24px;margin-top:var(--spacing-lg)}.card-section-spaced{padding:16px 0;padding:var(--spacing-md) 0}.card-divider{background:linear-gradient(90deg,#00000014,#0000000a 40%,#00000014);border:none;height:1px;margin:16px 0;margin:var(--spacing-md) 0;width:100%}.card-section-heading{color:#666;color:var(--color-text-muted);font-size:.9375rem;font-size:var(--font-size-sm);font-weight:600;letter-spacing:.06em;margin:0 0 8px;margin:0 0 var(--spacing-sm);text-transform:uppercase}.modal-overlay{align-items:center;background:#00000052;display:flex;inset:0;justify-content:center;padding:24px;padding:var(--spacing-lg);position:fixed;z-index:1000;z-index:var(--z-modals)}.modal{animation:modal-in .24s ease;background:#fff;border-radius:12px;border-radius:var(--border-radius-lg);box-shadow:0 6px 32px -4px #00000040,0 2px 8px #0000001f;padding:32px;padding:var(--spacing-xl);position:relative;width:100%}.modal-header{align-items:flex-start;display:flex;gap:16px;gap:var(--spacing-md);justify-content:space-between;margin:0 0 16px;margin:0 0 var(--spacing-md)}.modal-title{font-size:1.5rem;font-size:var(--font-size-xl);font-weight:600;line-height:1.35;line-height:var(--line-height-snug);margin:0}.modal-body{font-size:.9375rem;font-size:var(--font-size-sm);max-height:70vh;overflow-y:auto}.modal-footer{display:flex;flex-wrap:wrap;gap:8px;gap:var(--spacing-sm);justify-content:flex-end;margin-top:24px;margin-top:var(--spacing-lg)}.modal-sm{max-width:400px}.modal-lg{max-width:820px}.modal-closer{background:#0000;border:none;border-radius:4px;border-radius:var(--border-radius-sm);cursor:pointer;padding:6px;position:absolute;right:12px;top:12px}.modal-closer:hover{background:#0000000d}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.spinner{animation:spin .8s linear infinite;border:2px solid #d0d7de;border-top-color:#1f75d1;border:2px solid var(--color-border-default);display:inline-block;height:1em;vertical-align:middle;width:1em}:root[data-theme=dark]{--color-text-strong:#f5f7fa;--color-text-default:#d5dde3;--color-text-muted:#93a2af;--color-text-subtle:#7e8c98;--color-primary-light:#163d63;--color-info-bg:#163d63;--color-info-border:#215988;--color-info-text:#c2e2ff;--color-danger-bg:#3d1f24;--color-danger-border:#7d3a45;--color-danger-text:#ffb8c0;--color-success-bg:#1a3d24;--color-success-border:#2d6339;--color-success-text:#a8e6b8;--color-warning-bg:#3d3419;--color-warning-border:#7d6c2d;--color-warning-text:#ffe4a0;--surface-base:#0f1419;--surface-elevated:#181f26;--surface-elevated-alt:#222c34;--surface-muted:#1d2731;--surface-accent:#163d63;--color-border-default:#32414d;--color-border-subtle:#25313a;--color-border-strong:#465865;--focus-ring:0 0 0 3px #1f75d173;--surface-disabled:#2a343e;--diff-add-bg:#1a3d24;--diff-add-border:#2d6339;--diff-add-text:#a8e6b8;--diff-remove-bg:#3d1f24;--diff-remove-border:#7d3a45;--diff-remove-text:#ffb8c0;--diff-change-bg:#3c3318;--diff-change-border:#7d6c2d;--diff-change-text:#ffe4a0;--diff-gradient-success-start:#1f6d3a;--diff-gradient-success-end:#178f6a;--color-text-on-primary:#fff;--color-text-on-success:#fff;--color-text-on-danger:#fff;--color-text-on-warning:#fffaf0;--color-text-on-info:#e6f6ff;--table-row-base:#141b21;--table-row-alt:#1a242d;--table-row-hover:#1f3a55;--surface-button:#1f75d1;--surface-button-hover:#1669bd;--surface-button-active:#135da8;--surface-button-text:#fff;--surface-button-secondary:#2a3944;--surface-button-secondary-hover:#324550;--surface-button-secondary-active:#35505d;--surface-button-secondary-border:#32414d;--surface-button-secondary-text:#d5dde3;--surface-input:#1d2731;--surface-input-alt:#22303a;--surface-hover:#1f75d12e;--surface-button-primary:var(--color-primary);--surface-button-primary-hover:#1669bd;--surface-button-primary-active:#135da8;--surface-button-primary-text:#fff;--button-spinner-color:currentColor;--surface-button-ghost-bg:#0000;--surface-button-ghost-hover:#ffffff0f;--surface-button-ghost-active:#ffffff1f;--surface-button-ghost-text:var(--color-text-default);--surface-button-outline-bg:#0000;--surface-button-outline-border:#32414d;--surface-button-outline-hover-bg:#ffffff0f;--surface-button-outline-active-bg:#ffffff1f;--surface-button-outline-text:var(--color-text-default);--button-border-neutral:#2d3a45;--button-border-strong:#32414d;--datepicker-day-bg:#0000;--datepicker-day-hover-bg:#ffffff12;--datepicker-day-selected-bg:var(--color-primary);--datepicker-day-selected-text:var(--color-text-on-primary);--datepicker-day-today-ring:#2f6da5;--datepicker-day-text:var(--color-text-default);--datepicker-day-disabled-text:var(--color-text-muted);--surface-elevated-deep:#12181d;--surface-user-panel:#161d23;--surface-user-panel-alt:#1b242c}.alert-info{background:linear-gradient(135deg,#0288d114,#0288d10a);border-left:3px solid #0288d1;border-left:3px solid var(--color-info);color:#0b4f6b;color:var(--color-info-text)}.alert-danger,.alert-info{border-radius:8px;border-radius:var(--border-radius-md);padding:12px 16px}.alert-danger{background:linear-gradient(135deg,#d32f2f14,#d32f2f0a);border-left:3px solid #d32f2f;border-left:3px solid var(--color-danger);color:#b71c1c;color:var(--color-danger-text)}.alert-success{background:linear-gradient(135deg,#43a04714,#43a0470a);border-left:3px solid #43a047;border-left:3px solid var(--color-success);color:#1b5e20;color:var(--color-success-text)}.alert-success,.alert-warning{border-radius:8px;border-radius:var(--border-radius-md);padding:12px 16px}.alert-warning{background:linear-gradient(135deg,#f57c0014,#f57c000a);border-left:3px solid #f57c00;border-left:3px solid var(--color-warning);color:#856404;color:var(--color-warning-text)}.form-control:focus,select:focus,textarea:focus{border-color:#1f75d1;border-color:var(--color-primary);box-shadow:0 0 0 3px #1f75d159;box-shadow:var(--focus-ring);outline:none}:root:not([data-theme=dark]){--surface-base:#f5f6fa;--surface-elevated:#fff;--surface-elevated-alt:#f8f9fa;--surface-muted:#eef2f5;--surface-accent:var(--color-primary-light)}:root[data-theme=dark] body,body{background:var(--surface-base)}:root[data-theme=dark] body{color:#333;color:var(--color-text-default)}:root[data-theme=dark] .bom-tab-root{background:#0000;border:none;box-shadow:none}:root[data-theme=dark] .bom-table th{background:var(--surface-elevated-alt)}:root[data-theme=dark] .bom-table td{background:#0000}:root[data-theme=dark] .bom-cart{background:var(--surface-elevated-alt)}:root[data-theme=dark] .bom-subtab-btn{color:#666;color:var(--color-text-muted)}:root[data-theme=dark] .bom-subtab-btn:hover{color:#fff}:root[data-theme=dark] .bom-subtab-btn.active{border-bottom-color:#1f75d1;border-bottom-color:var(--color-primary);color:#1f75d1;color:var(--color-primary)}:root[data-theme=dark] .bom-modal{background:var(--surface-elevated);border:1px solid #2d3a45;box-shadow:0 4px 40px #000000b3}:root[data-theme=dark] .bom-modal-table tr td:first-child{color:#1f75d1;color:var(--color-primary)}:root[data-theme=dark] .create-project-select{background:var(--surface-elevated-alt);border-color:#32414d;color:#333;color:var(--color-text-default)}:root[data-theme=dark] .create-project-select:focus,:root[data-theme=dark] .lmc-tool-status-card{background:var(--surface-elevated-alt)}:root[data-theme=dark] .lmc-tool-info-box{background:#163d63;border-color:#215988}:root[data-theme=dark] .lmc-tool-error{background:#3b1e23;border-color:#6d2e38;color:#f5b5be}:root[data-theme=dark] .lmc-tool-success{background:#1f3a26;border-color:#285230;color:#9dd7a9}:root[data-theme=dark] .card .table th{background:var(--surface-elevated-alt)}html[data-theme] .card,html[data-theme] .header,html[data-theme] .lmc-tabs,html[data-theme] .modal,html[data-theme] .table td,html[data-theme] .table th,html[data-theme] body{transition:background-color .35s ease,color .35s ease,border-color .35s ease,box-shadow .35s ease}:root[data-theme=dark] .header{box-shadow:0 2px 6px #0009}:root[data-theme=dark] .lmc-tabs{background:#15202b;border-color:#24323d}:root[data-theme=dark] .lmc-tabs button{color:#666;color:var(--color-text-muted)}:root[data-theme=dark] .lmc-tabs button:focus,:root[data-theme=dark] .lmc-tabs button:hover{background:#ffffff0d;color:#333;color:var(--color-text-default)}:root[data-theme=dark] .lmc-tabs button.active,:root[data-theme=dark] .lmc-tabs button[aria-current=true]{background:#163d63;border-bottom-color:#1f75d1;border-bottom-color:var(--color-primary);box-shadow:0 2px 8px #00000073;color:#fff}:root[data-theme=dark] .card{background:var(--surface-elevated);border-color:#2d3a45;box-shadow:0 1px 3px #0009,0 4px 14px -2px #0000008c}:root[data-theme=dark] .card-muted{background:#24303b}:root[data-theme=dark] .table th{background:#24303b;border-bottom:1px solid #2d3a45;color:#666;color:var(--color-text-muted)}:root[data-theme=dark] .table td{border-bottom:1px solid #2d3a45;color:#333;color:var(--color-text-default)}:root[data-theme=dark] .table tbody tr:hover{background:#f2f6fa;background:var(--table-row-hover)}:root[data-theme=dark] .table-zebra tbody tr:nth-child(odd){background:#1a242d;background:#f8f9fa;background:var(--table-row-alt)}:root[data-theme=dark] .users-table tbody tr:hover{background:#f2f6fa;background:var(--table-row-hover)}:root[data-theme=dark] .form-control,:root[data-theme=dark] select,:root[data-theme=dark] textarea{background:#1d2731;border-color:#32414d;color:#333;color:var(--color-text-default)}:root[data-theme=dark] .form-control:focus,:root[data-theme=dark] select:focus,:root[data-theme=dark] textarea:focus{border-color:#1f75d1;border-color:var(--color-primary);box-shadow:0 0 0 3px #1f75d159}:root[data-theme=dark] .btn{background:#1f75d1;background:var(--color-primary);border-color:#1f75d1;border-color:var(--color-primary);color:#fff}:root[data-theme=dark] .btn:hover{background:#1669bd}:root[data-theme=dark] .btn:active{background:#135da8}:root[data-theme=dark] .btn-secondary{background:#2a3944;border-color:#32414d;color:#d5dde3}:root[data-theme=dark] .btn-secondary:hover{background:#324550}:root[data-theme=dark] .btn-secondary:active{background:#35505d}:root[data-theme=dark] .btn-ghost{color:#333;color:var(--color-text-default)}:root[data-theme=dark] .btn-ghost:hover{background:#ffffff0f}:root[data-theme=dark] .btn-ghost:active{background:#ffffff1f}:root[data-theme=dark] .hover-overlay,:root[data-theme=dark] .hoverable:hover{background:#0000000d;background:var(--surface-hover)}:root[data-theme=dark] .modal{background:#1c252d;border:1px solid #e4e7eb;border:1px solid var(--color-border-subtle);box-shadow:0 6px 32px -4px #000000b3,0 2px 8px #0009}:root[data-theme=dark] .modal-closer:hover{background:#ffffff0f}:root[data-theme=dark] .modal-overlay{background:#0000008c}:root[data-theme=dark] .status-active{background:#1e3a29;color:#7ddc9c}:root[data-theme=dark] .status-inactive{background:#3c1f26;color:#f9a3b0}:root[data-theme=dark] .role-admin{background:#4a3c14;color:#f4d27a}:root[data-theme=dark] .role-user{background:#123b63;color:#8fc8ff}:root[data-theme=dark] .lmc-footer{background:#15202b;color:#888;color:var(--color-text-subtle)}:root[data-theme=dark] .lmc-footer a{color:#fff}:root[data-theme=dark] ::-webkit-scrollbar{width:10px}:root[data-theme=dark] ::-webkit-scrollbar-track{background:#12181d}:root[data-theme=dark] ::-webkit-scrollbar-thumb{background:#20303a;border-radius:6px}:root[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#2a3d48}input:-webkit-autofill,select:-webkit-autofill,textarea:-webkit-autofill{-webkit-text-fill-color:#333;-webkit-text-fill-color:var(--color-text-default);box-shadow:inset 0 0 0 1000px #fff;box-shadow:0 0 0 1000px var(--surface-input) inset;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s}:root[data-theme=dark] input:-webkit-autofill,:root[data-theme=dark] select:-webkit-autofill,:root[data-theme=dark] textarea:-webkit-autofill{-webkit-text-fill-color:#333;-webkit-text-fill-color:var(--color-text-default);box-shadow:inset 0 0 0 1000px #fff;box-shadow:0 0 0 1000px var(--surface-input) inset;caret-color:#333;caret-color:var(--color-text-default)}:root[data-theme=dark] input:-webkit-autofill:focus,:root[data-theme=dark] select:-webkit-autofill:focus,:root[data-theme=dark] textarea:-webkit-autofill:focus{box-shadow:inset 0 0 0 1000px #fff,0 0 0 3px #1f75d159;box-shadow:0 0 0 1000px var(--surface-input) inset,0 0 0 3px #1f75d159}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{background-color:var(--surface-base)!important}body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{max-width:1200px;padding:0 20px}.form-group{margin-bottom:20px}.form-group label{color:var(--color-text-muted);display:block;font-weight:500;margin-bottom:5px}.form-group input{background:#fff;background:var(--surface-input,#fff);border:2px solid #ddd;border:2px solid var(--color-border-subtle,#ddd);border-radius:8px;box-sizing:border-box;color:var(--color-text-default);font-size:16px;min-height:44px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input:focus{border-color:var(--color-primary);outline:none}.form-group select{background-color:#fff;background-color:var(--surface-input,#fff);border:2px solid #ddd;border:2px solid var(--color-border-subtle,#ddd);border-radius:8px;box-sizing:border-box;color:var(--color-text-default);cursor:pointer;font-size:16px;min-height:44px;padding:12px;transition:border-color .3s ease;width:100%}.form-group select:focus{border-color:var(--color-primary);outline:none}.btn{align-items:center;border:none;border-radius:var(--border-radius-md);box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:16px;font-weight:500;height:44px;justify-content:center;line-height:1.2;padding:12px 24px;text-align:center;text-decoration:none;transition:all .3s ease;vertical-align:middle;white-space:nowrap}.btn:disabled,button.btn:disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.btn-link{background:#0000;height:auto;padding:8px 12px}.btn-link,.btn-link:hover{color:var(--color-primary)}.btn-link:hover{background:var(--color-primary-light)}.alert{border:1px solid #0000;border-radius:8px;margin-bottom:20px;padding:15px}.alert-success{background-color:#d4edda;background-color:var(--color-success-bg,#d4edda);border-color:#c3e6cb;border-color:var(--color-success-border,#c3e6cb);color:#155724;color:var(--color-success-text,#155724)}.alert-danger{background-color:#f8d7da;background-color:var(--color-danger-bg,#f8d7da);border-color:#f5c6cb;border-color:var(--color-danger-border,#f5c6cb);color:#721c24;color:var(--color-danger-text,#721c24)}.alert-info{background-color:#d1ecf1;background-color:var(--color-info-bg,#d1ecf1);border-color:#bee5eb;border-color:var(--color-info-border,#bee5eb);color:#0c5460;color:var(--color-info-text,#0c5460)}.loading{align-items:center;display:flex;height:100px;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-top:4px solid var(--color-border-subtle,#f3f3f3);border:4px solid var(--color-border-subtle,#f3f3f3);border-radius:50%;border-top-color:var(--color-primary);height:40px;width:40px}.skeleton-line{animation:pulse 1.4s ease-in-out infinite;background:#eee;background:var(--color-border-subtle,#eee);border-radius:6px;height:14px;margin-bottom:12px}.skeleton-card{background:#fff;background:var(--surface-elevated,#fff);border-radius:var(--border-radius-md);box-shadow:0 2px 6px #0000000f;padding:var(--spacing-md)}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.table{border-collapse:collapse;margin-top:20px;width:100%}.table td,.table th{border-bottom:1px solid #ddd;border-bottom:1px solid var(--color-border-subtle,#ddd);padding:12px;text-align:left}.table th{background-color:#f8f9fa;background-color:var(--surface-elevated,#f8f9fa);color:#495057;color:var(--color-text-strong,#495057);font-weight:600}.table tr:hover{background-color:#f8f9fa;background-color:var(--table-row-hover,#f8f9fa)}@media (max-width:768px){.container{padding:0 15px}.table{font-size:14px}.btn{margin-bottom:10px;width:100%}}.form-actions{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:20px}.form-actions .btn{margin:0}.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{max-width:400px}.container,.login-card{margin:0 auto;width:100%}.container{max-width:var(--container-max-width);padding:0 var(--container-padding)}.form-control{background-color:#fff;background-color:var(--surface-input,#fff);border:1px solid #ddd;border:1px solid var(--color-border-subtle,#ddd);border-radius:var(--border-radius-sm);box-sizing:border-box;color:var(--color-text-default);font-size:16px;min-height:44px;padding:12px 16px;transition:border-color .2s;width:100%}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);outline:none}.form-select{-webkit-appearance:none;appearance:none;background-color:#fff;background-color:var(--surface-input,#fff);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;border:1px solid #ddd;border:1px solid var(--color-border-subtle,#ddd);border-radius:var(--border-radius-sm);box-sizing:border-box;color:var(--color-text-default);cursor:pointer;font-size:16px;min-height:44px;padding:12px 40px 12px 16px;transition:border-color .2s;width:100%}.form-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);outline:none}.error-boundary-container{padding:32px;text-align:center}body{-webkit-font-smoothing:antialiased;background:#f5f6fa;color:var(--color-text-default);font-family:var(--font-family-sans);margin:0;padding:0}html[data-theme=dark] body{background:#0f1419}.app,.dashboard,.main-content{background:#0000}html[data-theme=dark] .app,html[data-theme=dark] .dashboard,html[data-theme=dark] .main-content{background:#0f1419}.app{display:flex;flex-direction:column;min-height:100vh}.header{background-color:var(--color-primary);box-shadow:0 2px 4px #0000001a;color:#fff;height:72px;left:0;min-height:72px;padding:0;position:fixed;top:0;width:100vw;z-index:var(--z-header)}.header,.header-content{align-items:center;display:flex}.header-content{height:100%;justify-content:space-between;margin:0 auto;max-width:var(--container-max-width);padding:0 var(--container-padding);width:100%}.header h1{font-size:1.5rem;margin:0}.header-right{gap:15px}.user-info{gap:10px}.user-avatar{background-color:#fff3;font-weight:700;height:32px;width:32px}.logout-btn{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;padding:8px 16px;transition:all .3s ease}.logout-btn:hover{background:#ffffff4d}.main-content{flex:1 1;margin-top:80px;padding:0 0 2rem}.login-page{background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{margin:0 auto;max-width:400px;padding:0 20px}.login-card{background:#fff;box-shadow:0 20px 40px #0000001a;padding:40px;text-align:center}.login-title{color:#333;font-size:2rem;font-weight:600;margin-bottom:10px}.login-subtitle{color:#666;margin-bottom:30px}.login-form{text-align:left}.login-form .form-group{margin-bottom:20px}.login-form .btn{font-size:16px;font-weight:600;margin-top:10px;padding:14px}.dashboard{padding:0}.dashboard-header{margin-bottom:30px}.dashboard-title{color:#333;font-size:2rem;font-weight:600;margin-bottom:10px}.dashboard-subtitle{color:#666;font-size:1.1rem}.dashboard-content{display:flex;flex-direction:column;gap:var(--spacing-lg)}.users-section{background:#0000;margin-top:var(--spacing-md);padding:0;width:100%}.empty-state{color:var(--color-text-muted);padding:40px 20px;text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:15px;opacity:.5}.modal{max-width:560px}.modal.modal-sm{max-width:400px}.modal.modal-lg{max-width:820px}@media (max-width:768px){.header-content{flex-direction:column;gap:10px}.header-right{justify-content:space-between;width:100%}.login-card{padding:30px 20px}}.login-page{align-items:center;background:var(--surface-base);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:32px 16px}.login-container{max-width:440px;width:100%}.login-card{background:var(--surface-elevated);border-radius:16px;box-shadow:0 6px 32px -4px #00000040,0 2px 8px #0000001f;padding:48px 40px 40px}:root[data-theme=dark] .login-card{background:var(--surface-elevated);box-shadow:0 6px 32px -4px #000000a6,0 2px 10px #0009}.login-title{margin-bottom:8px;margin-top:0}:root[data-theme=dark] .login-title{color:var(--color-text-strong)}.login-subtitle{color:var(--color-text-default);font-size:.95rem;margin:0 0 28px}.login-form{margin:0}.login-form .btn{justify-content:center;margin-top:4px;width:100%}.login-form .btn .spinner{font-size:1em}.login-fieldset{border:0;margin:0;padding:0}.login-error{margin-bottom:16px}.login-spinner{margin-right:8px}.login-form .form-group{margin-bottom:1.2em}.login-form input[disabled]{background:var(--surface-disabled)}.login-form .btn.btn-primary[disabled]{cursor:not-allowed;opacity:.7}.cookie-consent-overlay{align-items:center;background:#0006;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.cookie-consent-modal{background:var(--surface-elevated);border-radius:12px;box-shadow:0 6px 24px #00000026;max-width:520px;padding:24px;width:calc(100% - 32px)}.cookie-consent-modal h3{margin:0 0 12px}.cookie-consent-modal p{color:var(--color-text-default);line-height:1.5;margin:0 0 10px}.cookie-actions{display:flex;justify-content:flex-end;margin-top:12px}:root[data-theme=dark] .login-page{background:var(--surface-base)}:root[data-theme=dark] .cookie-consent-modal p,:root[data-theme=dark] .login-subtitle{color:var(--color-text-default)}:root[data-theme=dark] .cookie-consent-modal{background:var(--surface-elevated);box-shadow:0 6px 28px -4px #000000b3,0 2px 8px #0009}@media (max-width:520px){.login-card{border-radius:14px;padding:36px 28px 32px}.login-subtitle{margin-bottom:24px}}.dashboard-layout{background:var(--surface-base);display:grid;grid-template-areas:"sidebar header" "sidebar main" "sidebar footer";grid-template-columns:240px 1fr;grid-template-rows:100px 1fr auto;min-height:100vh}.dashboard-header{background:var(--surface-elevated);border-bottom:1px solid var(--color-border-subtle);color:var(--color-text-default);grid-area:header;justify-content:space-between;padding:0 40px;position:-webkit-sticky;position:sticky;top:0;z-index:200}.dashboard-header,.header-left{align-items:center;display:flex}.header-left{gap:16px}.header-logo{cursor:pointer;filter:drop-shadow(0 0 3px rgba(31,117,209,.3)) drop-shadow(0 0 6px rgba(31,117,209,.15));height:48px;transition:transform .3s ease,filter .3s ease;width:auto}.header-logo:hover{filter:drop-shadow(0 0 6px rgba(31,117,209,.7)) drop-shadow(0 0 12px rgba(226,0,116,.5)) drop-shadow(0 0 20px rgba(226,0,116,.3));transform:scale(1.05)}.header-logo.spinning,html[data-theme=dark] .header-logo.spinning{animation:logo-spin .6s ease-in-out forwards}@keyframes logo-spin{0%{filter:drop-shadow(0 0 8px rgba(31,117,209,.8));transform:rotate(0deg) scale(1)}25%{filter:drop-shadow(0 0 12px rgba(147,51,234,.9))}50%{filter:drop-shadow(0 0 16px rgba(226,0,116,1));transform:rotate(180deg) scale(1.1)}75%{filter:drop-shadow(0 0 12px rgba(147,51,234,.9))}to{filter:drop-shadow(0 0 4px rgba(100,180,255,.6)) drop-shadow(0 0 8px rgba(100,180,255,.3));transform:rotate(1turn) scale(1)}}html:not([data-theme=dark]) .header-logo:not(.spinning){filter:brightness(.2) saturate(100%) drop-shadow(0 0 4px rgba(31,117,209,.5)) drop-shadow(0 0 8px rgba(31,117,209,.3))}html:not([data-theme=dark]) .header-logo:not(.spinning):hover{filter:brightness(.2) saturate(100%) drop-shadow(0 0 8px rgba(31,117,209,.8)) drop-shadow(0 0 14px rgba(226,0,116,.6)) drop-shadow(0 0 22px rgba(226,0,116,.4))}html:not([data-theme=dark]) .header-logo.spinning{animation:logo-spin-light .6s ease-in-out forwards}@keyframes logo-spin-light{0%{filter:brightness(.2) drop-shadow(0 0 8px rgba(31,117,209,.8));transform:rotate(0deg) scale(1)}25%{filter:brightness(.2) drop-shadow(0 0 12px rgba(147,51,234,.9))}50%{filter:brightness(.2) drop-shadow(0 0 16px rgba(226,0,116,1));transform:rotate(180deg) scale(1.1)}75%{filter:brightness(.2) drop-shadow(0 0 12px rgba(147,51,234,.9))}to{filter:brightness(.2) saturate(100%) drop-shadow(0 0 4px rgba(31,117,209,.5)) drop-shadow(0 0 8px rgba(31,117,209,.3));transform:rotate(1turn) scale(1)}}html[data-theme=dark] .header-logo:not(.spinning){filter:drop-shadow(0 0 4px rgba(100,180,255,.6)) drop-shadow(0 0 8px rgba(100,180,255,.3))}html[data-theme=dark] .header-logo:not(.spinning):hover{filter:drop-shadow(0 0 8px rgba(100,180,255,.8)) drop-shadow(0 0 16px rgba(226,0,116,.6)) drop-shadow(0 0 24px rgba(147,51,234,.4))}.header-right{gap:20px}.header-right,.user-info{align-items:center;display:flex}.user-info{background:var(--surface-elevated-alt);border-radius:var(--border-radius-lg);gap:12px;padding:8px 16px}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,#1a5a9e 100%);border-radius:50%;color:#fff;display:flex;font-size:16px;font-weight:600;height:40px;justify-content:center;width:40px}.user-name{color:var(--color-text-strong);font-size:14px;font-weight:600}.header-actions{gap:12px}.header-actions,.header-btn{align-items:center;display:flex}.header-btn{background:var(--surface-elevated-alt);border:none;border-radius:var(--border-radius-md);color:var(--color-text-default);cursor:pointer;height:44px;justify-content:center;transition:all .2s ease;width:44px}.header-btn:hover{background:var(--color-primary);color:#fff}.header-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.logout-btn{background:#0000;border:1.5px solid var(--color-danger);border-radius:var(--border-radius-md);color:var(--color-danger);cursor:pointer;font-size:14px;font-weight:600;min-height:44px;padding:10px 20px;transition:all .2s ease}.logout-btn:hover{background:var(--color-danger);color:#fff}.logout-btn:focus-visible{outline:2px solid var(--color-danger);outline-offset:2px}.dashboard-main{background:var(--surface-base);grid-area:main;min-height:calc(100vh - 156px);overflow-x:hidden;overflow-y:auto;padding:32px 40px}.dashboard-content{background:var(--surface-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--border-radius-lg);box-shadow:none;max-width:100%;min-height:400px;padding:var(--spacing-xl);width:100%}.content-loading{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:64px 24px}.content-loading .spinner{animation:spin .8s linear infinite;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.content-placeholder{font-size:16px;min-height:300px}.content-placeholder,.dashboard-footer{align-items:center;color:var(--color-text-muted);display:flex;justify-content:center}.dashboard-footer{background:var(--surface-elevated);border-top:1px solid var(--color-border-subtle);font-size:13px;grid-area:footer;padding:16px 40px;text-align:center}.dashboard-footer a{color:var(--color-primary);font-weight:600;text-decoration:none}.dashboard-footer a:hover{text-decoration:underline}@media (min-width:768px) and (max-width:1024px){.dashboard-layout{grid-template-columns:200px 1fr}.dashboard-main{padding:20px 24px}.dashboard-content{padding:20px}.user-name{display:none}}@media (max-width:768px){.dashboard-layout{grid-template-areas:"header" "main" "footer";grid-template-columns:1fr;grid-template-rows:100px 1fr auto}.dashboard-header{padding:0 16px}.header-logo{height:36px}.user-name{display:none}.user-avatar{font-size:12px;height:32px;width:32px}.logout-btn{font-size:13px;min-height:36px;padding:6px 12px}.header-btn{height:36px;width:36px}.dashboard-main{min-height:calc(100vh - 112px);padding:16px}.dashboard-content{border-radius:var(--border-radius-md);padding:16px}.dashboard-footer{font-size:12px;padding:10px 16px}}@media (max-width:480px){.dashboard-header{padding:0 12px}.header-left,.header-right{gap:8px}.header-actions{gap:4px}.dashboard-content,.dashboard-main{padding:12px}.logout-btn span{display:none}}.page-title{font-size:24px;margin:0 0 24px}.page-title,.section-title{color:var(--color-text-primary);font-weight:600}.section-title{font-size:18px;margin:0 0 16px}.tab-loading{align-items:center;color:var(--color-text-secondary);display:flex;flex-direction:column;font-size:14px;gap:16px;justify-content:center;padding:48px 24px}.tab-loading .spinner{animation:spin .8s linear infinite;border:3px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:32px;width:32px}[data-theme=dark] .dashboard-layout,[data-theme=dark] .dashboard-main{background:var(--surface-base)}[data-theme=dark] .dashboard-content{background:var(--surface-elevated);border:1px solid var(--color-border-subtle);box-shadow:none}.sidebar{background:linear-gradient(180deg,#1a2332,#141c28);border-right:none;display:flex;flex-direction:column;grid-area:sidebar;height:100vh;left:0;overflow-x:hidden;overflow-y:auto;position:-webkit-sticky;position:sticky;top:0;transition:transform .3s ease;width:240px;z-index:100}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff40}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 0}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:16px}.sidebar-settings-btn{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-md);color:#fff9;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;transition:all .2s ease;width:100%}.sidebar-settings-btn:hover{background:#ffffff14;color:#fff}.sidebar-settings-btn:active{background:#1f75d14d;color:#fff}.sidebar-mobile-close{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);color:#fff9;cursor:pointer;display:none;height:40px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s ease,color .2s ease;width:40px}.sidebar-mobile-close:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar-item{margin:2px 12px}.sidebar-item-btn{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-md);color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.sidebar-item-btn:hover{background:#ffffff14;color:#fff}.sidebar-item-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar-item.active>.sidebar-item-btn{background:#1f75d126;color:#fff}.sidebar-item-btn.current{background:linear-gradient(135deg,var(--color-primary) 0,#1a5a9e 100%);box-shadow:0 2px 8px #1f75d14d;color:#fff}.sidebar-item-btn.current:hover{background:linear-gradient(135deg,#2485e0,#1f75d1);color:#fff}.sidebar-item-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;width:20px}.sidebar-item-label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item-chevron{align-items:center;display:flex;justify-content:center;opacity:.6;transition:transform .2s ease}.sidebar-subitems{border-left:2px solid #ffffff1a;margin-bottom:8px;margin-left:20px;margin-top:4px;padding-left:12px}.sidebar-subitem-btn{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);color:#fff9;cursor:pointer;display:flex;font-size:13px;font-weight:400;gap:10px;padding:10px 12px;text-align:left;transition:all .2s ease;width:100%}.sidebar-subitem-btn:hover{background:#ffffff0f;color:#fff}.sidebar-subitem-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.sidebar-subitem-btn.current{background:linear-gradient(135deg,var(--color-primary) 0,#1a5a9e 100%);box-shadow:0 2px 8px #1f75d14d;color:#fff;font-weight:500}.sidebar-subitem-btn.current:hover{background:linear-gradient(135deg,#2485e0,#1f75d1)}.sidebar-subitem-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;opacity:.8;width:18px}.sidebar-subitem-btn.current .sidebar-subitem-icon{opacity:1}.sidebar-subitem-label{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;inset:0;position:fixed;z-index:999}.mobile-menu-btn{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-on-primary);cursor:pointer;display:none;height:44px;justify-content:center;padding:0;transition:background .2s ease;width:44px}.mobile-menu-btn:hover{background:#ffffff1a}.mobile-menu-btn:focus-visible{outline:2px solid #fff;outline-offset:2px}@media (max-width:768px){.sidebar{box-shadow:4px 0 24px #00000026;height:100vh;left:0;padding-top:56px;position:fixed;top:0;transform:translateX(-100%);width:280px;z-index:1000}.sidebar.mobile-open{transform:translateX(0)}.sidebar-mobile-close{display:flex}.sidebar-overlay{display:block}.mobile-menu-btn{display:flex}.sidebar-item-btn{min-height:48px;padding:14px 16px}.sidebar-subitem-btn{min-height:44px;padding:12px}}@media (min-width:768px) and (max-width:1024px){.sidebar{width:200px}.sidebar-item-btn{padding:10px 12px}.sidebar-subitem-btn{padding:8px 10px}}.breadcrumbs{margin-bottom:16px;padding:12px 0}.breadcrumbs-list{flex-wrap:wrap;font-size:13px;list-style:none;margin:0;padding:0}.breadcrumbs-item,.breadcrumbs-list{align-items:center;display:flex;gap:4px}.breadcrumbs-separator{align-items:center;color:var(--color-text-muted);display:flex;margin:0 2px}.breadcrumbs-link{align-items:center;background:#0000;border:none;border-radius:var(--border-radius-sm);color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;padding:4px 8px;text-decoration:none;transition:all .2s ease}.breadcrumbs-link:hover{background:var(--color-surface-hover);color:var(--color-primary)}.breadcrumbs-link:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.breadcrumbs-icon{align-items:center;display:flex;opacity:.8}.breadcrumbs-current{align-items:center;color:var(--color-text-muted);display:inline-flex;font-size:13px;font-weight:400;gap:4px;padding:4px 8px}.breadcrumbs-current.is-last{background:var(--color-primary-subtle);border-radius:var(--border-radius-sm);color:var(--color-text-primary);font-weight:600}@media (max-width:768px){.breadcrumbs{margin-bottom:12px;padding:8px 0}.breadcrumbs-list{font-size:12px}.breadcrumbs-current,.breadcrumbs-link{font-size:12px;padding:6px 8px}@media (max-width:480px){.breadcrumbs-item:first-child .breadcrumbs-link span:not(.breadcrumbs-icon){display:none}}}[data-theme=dark] .breadcrumbs-current.is-last{background:var(--color-primary-subtle)}.bom-page-header{margin-bottom:var(--spacing-lg)}.bom-tab-root{background:#0000;border:none;border-radius:0;box-shadow:none;padding:0;width:100%}.bom-page-header .page-title{margin:0 0 8px}.bom-page-header .page-description{margin:0}.bom-subtabs{border-bottom:1px solid var(--color-border-subtle);display:flex;gap:8px;margin-bottom:32px;padding-bottom:0}.bom-subtab-btn{background:#0000;border:none;border-bottom:3px solid #0000;color:var(--color-text-muted);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;margin-bottom:-1px;padding:14px 20px;transition:all .2s ease;white-space:nowrap}.bom-subtab-btn:hover{color:var(--color-text-strong)}.bom-subtab-btn.active{border-bottom-color:var(--color-primary);color:var(--color-primary);font-weight:600}.bom-subtab-btn:disabled{cursor:not-allowed;opacity:.5}.bom-upload{align-items:center}.bom-filter-row,.bom-upload{display:flex;flex-wrap:wrap;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.bom-filter-row .form-control,.bom-filter-row .form-select{flex:1 1;min-width:200px}.bom-results-info{color:var(--color-text-muted);font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--spacing-md)}.bom-list{margin-bottom:var(--spacing-xl)}.bom-table{border-collapse:collapse;font-size:var(--font-size-md);width:100%}.bom-table td,.bom-table th{border-bottom:1px solid var(--color-border-subtle);padding:12px 14px;text-align:left}.bom-table th{color:var(--color-text-strong);font-weight:600}.bom-cart,.bom-table th{background:var(--surface-elevated)}.bom-cart{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);margin-top:var(--spacing-xl);padding:var(--spacing-lg)}.bom-cart-actions{display:flex;gap:var(--spacing-md);justify-content:flex-start;margin-top:var(--spacing-md)}.loading{color:var(--color-primary);font-weight:500}.alert{margin-left:var(--spacing-md)}.bom-lupe-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:20px;padding:0 4px}.bom-modal-overlay{align-items:center;background:#00000040;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.bom-modal{background:var(--surface-elevated);border-radius:var(--radius-lg);box-shadow:0 4px 32px #0000002e;box-sizing:border-box;max-height:calc(100vh - 32px);max-width:var(--container-max-width);min-width:280px;overflow-y:auto;padding:24px 20px;width:100%}.bom-modal-table{border-collapse:collapse;margin-bottom:12px;width:100%}.bom-modal-table td{border-bottom:1px solid var(--color-border-subtle);font-size:var(--font-size-md);overflow-wrap:anywhere;padding:8px 12px;white-space:normal;word-break:break-word}.bom-modal-table tr td:first-child{color:var(--color-primary);font-weight:600;min-width:180px;overflow-wrap:normal;white-space:nowrap;width:auto;word-break:normal}.bom-modal-footer{align-items:center;display:flex;justify-content:space-between;margin-top:16px}.bom-modal-quantity{align-items:center;display:flex;gap:8px}.bom-modal-quantity label{font-weight:600}.bom-modal-quantity input{width:60px}.bom-modal-actions{display:flex;gap:8px}.bom-modal-success{font-weight:600;margin:16px 0;text-align:center}.description-line{display:block;white-space:pre-line}.bom-cart-hinweis{margin-bottom:16px}.bom-validity{font-weight:600;margin-left:8px}.bom-skeleton{padding:16px}.bom-skeleton .skeleton-line-header{height:20px;width:35%}.bom-skeleton .skeleton-line-row{height:12px;width:100%}.bom-file-input-hidden{display:none}.bom-cart-count{font-weight:600;margin-bottom:8px}.bom-cart-quantity-input{width:60px}.bom-cart-total-row{background:var(--surface-elevated-alt);font-weight:700}@media (max-width:768px){.bom-tab-root{padding:var(--spacing-md)}.bom-filter-row{flex-direction:column;gap:var(--spacing-sm)}.bom-table td,.bom-table th{font-size:13px;padding:8px 6px}.bom-cart{padding:var(--spacing-md)}}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:400px;padding:16px;pointer-events:none;position:fixed;width:100%;z-index:9999}.toast-top-right{right:0;top:0}.toast-top-left{left:0;top:0}.toast-bottom-right{bottom:0;right:0}.toast-bottom-left{bottom:0;left:0}.toast-top-center{left:50%;top:0;transform:translateX(-50%)}.toast-bottom-center{bottom:0;left:50%;transform:translateX(-50%)}.toast-item{background:#fff;background:var(--surface-elevated,#fff);border-left:4px solid;border-radius:8px;border-radius:var(--radius-md,8px);box-shadow:0 4px 12px #00000026,0 2px 4px #0000001a;overflow:hidden;pointer-events:auto}.toast-success{border-color:#10b981;border-color:var(--color-success,#10b981)}.toast-success .toast-icon{background:#d1fae5;background:var(--color-success-bg,#d1fae5);color:#10b981;color:var(--color-success,#10b981)}.toast-error{border-color:#ef4444;border-color:var(--color-danger,#ef4444)}.toast-error .toast-icon{background:#fee2e2;background:var(--color-danger-bg,#fee2e2);color:#ef4444;color:var(--color-danger,#ef4444)}.toast-warning{border-color:#f59e0b;border-color:var(--color-warning,#f59e0b)}.toast-warning .toast-icon{background:#fef3c7;background:var(--color-warning-bg,#fef3c7);color:#f59e0b;color:var(--color-warning,#f59e0b)}.toast-info{border-color:#3b82f6;border-color:var(--color-info,#3b82f6)}.toast-info .toast-icon{background:#dbeafe;background:var(--color-info-bg,#dbeafe);color:#3b82f6;color:var(--color-info,#3b82f6)}.toast-content{gap:12px;padding:14px 16px}.toast-content,.toast-icon{align-items:center;display:flex}.toast-icon{border-radius:50%;flex-shrink:0;font-size:14px;font-weight:600;height:28px;justify-content:center;width:28px}.toast-message{color:#374151;color:var(--color-text-default,#374151);flex:1 1;font-size:14px;font-size:var(--font-size-sm,14px);line-height:1.4;word-break:break-word}.toast-close{background:none;border:none;color:#9ca3af;color:var(--color-text-muted,#9ca3af);cursor:pointer;flex-shrink:0;font-size:20px;line-height:1;padding:0;transition:color .2s ease}.toast-close:hover{color:#374151;color:var(--color-text-default,#374151)}.toast-progress{background:#0000000d;height:3px}.toast-progress-bar{height:100%;transition:width 50ms linear}.toast-success .toast-progress-bar{background:#10b981;background:var(--color-success,#10b981)}.toast-error .toast-progress-bar{background:#ef4444;background:var(--color-danger,#ef4444)}.toast-warning .toast-progress-bar{background:#f59e0b;background:var(--color-warning,#f59e0b)}.toast-info .toast-progress-bar{background:#3b82f6;background:var(--color-info,#3b82f6)}.toast-enter{animation:toastSlideIn .3s ease forwards}.toast-exit{animation:toastSlideOut .3s ease forwards}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toastSlideOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast-bottom-left .toast-enter,.toast-top-left .toast-enter{animation:toastSlideInLeft .3s ease forwards}.toast-bottom-left .toast-exit,.toast-top-left .toast-exit{animation:toastSlideOutLeft .3s ease forwards}@keyframes toastSlideInLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}@keyframes toastSlideOutLeft{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(-100%)}}.toast-bottom-center .toast-enter,.toast-top-center .toast-enter{animation:toastSlideInCenter .3s ease forwards}.toast-bottom-center .toast-exit,.toast-top-center .toast-exit{animation:toastSlideOutCenter .3s ease forwards}@keyframes toastSlideInCenter{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes toastSlideOutCenter{0%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(-20px)}}@media (prefers-color-scheme:dark){.toast-item{background:#1f2937;background:var(--surface-elevated,#1f2937)}.toast-message{color:#f3f4f6;color:var(--color-text-default,#f3f4f6)}.toast-progress{background:#ffffff1a}}@media (max-width:480px){.toast-container{max-width:100%;padding:12px}.toast-bottom-left,.toast-bottom-right,.toast-top-left,.toast-top-right{left:0;right:0}.toast-bottom-left .toast-enter,.toast-enter,.toast-top-left .toast-enter{animation:toastSlideInMobile .3s ease forwards}.toast-bottom-left .toast-exit,.toast-exit,.toast-top-left .toast-exit{animation:toastSlideOutMobile .3s ease forwards}@keyframes toastSlideInMobile{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes toastSlideOutMobile{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}}
/*# sourceMappingURL=main.8effcb97.css.map*/