*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;font-size:.875rem;font-weight:400;line-height:1.6;background-color:#dde1e7;color:#2d3748;transition:background-color .25s ease,color .25s ease;min-height:100vh}body::-webkit-scrollbar{width:6px;height:6px}body::-webkit-scrollbar-track{background:transparent}body::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}body::-webkit-scrollbar-thumb:hover{background:#00000040}.dark body::-webkit-scrollbar-thumb{background:#ffffff26}.dark body::-webkit-scrollbar-thumb:hover{background:#ffffff40}.dark body{background-color:#1a1b2e;color:#e2e8f0}a{color:#6366f1;text-decoration:none;transition:color .15s ease}a:hover{color:#4f46e5}img{max-width:100%;display:block}button{cursor:pointer;border:none;font-family:inherit;font-size:inherit}input,select,textarea{font-family:inherit;font-size:inherit}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.mono{font-family:JetBrains Mono,monospace}.neu-card{background-color:#dde1e7;color:#2d3748}.dark .neu-card{background-color:#22243a;color:#e2e8f0}.neu-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .neu-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.neu-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:1.5rem;transition:box-shadow .25s ease}.dark .neu-card{border-color:#ffffff0f}.neu-card--sm{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .neu-card--sm{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.neu-card--sm{padding:1rem;border-radius:12px}.neu-card--flat{background-color:#dde1e7;color:#2d3748}.dark .neu-card--flat{background-color:#22243a;color:#e2e8f0}.neu-card--flat{box-shadow:none;border-radius:16px;padding:1.5rem}.neu-card--inset{background-color:#dde1e7;color:#2d3748}.dark .neu-card--inset{background-color:#22243a;color:#e2e8f0}.neu-card--inset{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .neu-card--inset{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.neu-card--inset{border-radius:12px;padding:1rem}.neu-card--interactive{cursor:pointer}.neu-card--interactive:hover{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .neu-card--interactive:hover{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.neu-card--interactive:active{box-shadow:inset 2px 2px 5px #b8bcc2,inset -2px -2px 5px #fff}.dark .neu-card--interactive:active{box-shadow:inset 2px 2px 5px #111120,inset -2px -2px 5px #2d2f4a}.neu-btn,.modal__close{background-color:#dde1e7;color:#2d3748}.dark .neu-btn,.dark .modal__close{background-color:#22243a;color:#e2e8f0}.neu-btn,.modal__close{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .neu-btn,.dark .modal__close{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.neu-btn,.modal__close{display:flex;align-items:center;justify-content:center}.neu-btn:focus-visible,.modal__close:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.neu-btn,.modal__close{display:inline-flex;gap:.5rem;padding:.5rem 1.25rem;border-radius:12px;font-weight:500;font-size:.875rem;transition:all .15s ease;line-height:1.5;white-space:nowrap}.neu-btn:hover,.modal__close:hover{box-shadow:2px 2px 4px #b8bcc2,-2px -2px 4px #fff}.dark .neu-btn:hover,.dark .modal__close:hover{box-shadow:2px 2px 4px #111120,-2px -2px 4px #2d2f4a}.neu-btn:active,.modal__close:active{box-shadow:inset 2px 2px 5px #b8bcc2,inset -2px -2px 5px #fff}.dark .neu-btn:active,.dark .modal__close:active{box-shadow:inset 2px 2px 5px #111120,inset -2px -2px 5px #2d2f4a}.neu-btn:disabled,.modal__close:disabled{opacity:.5;cursor:not-allowed}.neu-btn:disabled:hover,.modal__close:disabled:hover{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .neu-btn:disabled:hover,.dark .modal__close:disabled:hover{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.neu-btn:disabled:active,.modal__close:disabled:active{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .neu-btn:disabled:active,.dark .modal__close:disabled:active{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.neu-btn--sm{padding:.25rem .75rem;font-size:.8125rem;border-radius:8px}.neu-btn--lg{padding:.75rem 2rem;font-size:1rem;border-radius:16px}.neu-btn--primary{background:#6366f1;color:#fff;box-shadow:3px 3px 8px #4f46e566,-2px -2px 6px #818cf833}.dark .neu-btn--primary{box-shadow:3px 3px 8px #0006,-2px -2px 6px #818cf81a}.neu-btn--primary:hover{background:#4f46e5}.neu-btn--primary:active{box-shadow:inset 2px 2px 4px #0003}.neu-btn--danger{background:#ef4444;color:#fff;box-shadow:3px 3px 8px #ef44444d,-2px -2px 6px #f7a2a233}.neu-btn--danger:hover{background:#ec1e1e}.neu-btn--danger:active{box-shadow:inset 2px 2px 4px #0003}.neu-btn--success{background:#10b981;color:#fff;box-shadow:3px 3px 8px #10b9814d,-2px -2px 6px #40efb533}.neu-btn--success:hover{background:#0d9367}.neu-btn--ghost,.modal__close{background:transparent;box-shadow:none;color:#718096}.dark .neu-btn--ghost,.dark .modal__close{color:#a0aec0}.neu-btn--ghost:hover,.modal__close:hover{background-color:#dde1e7;color:#2d3748}.dark .neu-btn--ghost:hover,.dark .modal__close:hover{background-color:#22243a;color:#e2e8f0}.neu-btn--ghost:hover,.modal__close:hover{box-shadow:2px 2px 4px #b8bcc2,-2px -2px 4px #fff}.dark .neu-btn--ghost:hover,.dark .modal__close:hover{box-shadow:2px 2px 4px #111120,-2px -2px 4px #2d2f4a}.neu-btn--ghost:active,.modal__close:active{box-shadow:inset 2px 2px 5px #b8bcc2,inset -2px -2px 5px #fff}.dark .neu-btn--ghost:active,.dark .modal__close:active{box-shadow:inset 2px 2px 5px #111120,inset -2px -2px 5px #2d2f4a}.neu-btn--icon,.modal__close{padding:.5rem;border-radius:12px}.neu-input,.neu-select{background-color:#dde1e7;color:#2d3748}.dark .neu-input,.dark .neu-select{background-color:#22243a;color:#e2e8f0}.neu-input,.neu-select{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .neu-input,.dark .neu-select{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.neu-input:focus-visible,.neu-select:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.neu-input,.neu-select{color:#2d3748}.dark .neu-input,.dark .neu-select{color:#e2e8f0}.neu-input,.neu-select{display:block;width:100%;padding:.75rem 1rem;border:none;border-radius:12px;font-size:.875rem;transition:box-shadow .15s ease}.neu-input::placeholder,.neu-select::placeholder{color:#a0aec0}.dark .neu-input::placeholder,.dark .neu-select::placeholder{color:#8194ac}.neu-input:focus,.neu-select:focus{box-shadow:inset 2px 2px 4px #b8bcc2,inset -2px -2px 4px #fff,0 0 0 2px #6366f14d}.dark .neu-input:focus,.dark .neu-select:focus{box-shadow:inset 2px 2px 4px #111120,inset -2px -2px 4px #2d2f4a,0 0 0 2px #6366f14d}.neu-input--error{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff,0 0 0 2px #ef444466}.dark .neu-input--error{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a,0 0 0 2px #ef444466}.neu-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23718096' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem;cursor:pointer}.form-group{margin-bottom:1.25rem}.form-group__label{display:block;font-size:.8125rem;font-weight:500;margin-bottom:.5rem;color:#718096}.dark .form-group__label{color:#a0aec0}.form-group__error{font-size:.75rem;color:#ef4444;margin-top:.25rem}.form-group__hint{font-size:.75rem;color:#a0aec0}.dark .form-group__hint{color:#8194ac}.form-group__hint{margin-top:.25rem}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;letter-spacing:.02em;text-transform:uppercase}.status-badge__dot{width:6px;height:6px;border-radius:50%}.status-badge--not-started{background:#94a3b81f;color:#94a3b8}.dark .status-badge--not-started{background:#94a3b82e;color:#b3bdcc}.status-badge--not-started .status-badge__dot{background:#94a3b8}.status-badge--in-progress{background:#6366f11f;color:#6366f1}.dark .status-badge--in-progress{background:#6366f12e;color:#9294f5}.status-badge--in-progress .status-badge__dot{background:#6366f1}.status-badge--qc-blocked{background:#ef44441f;color:#ef4444}.dark .status-badge--qc-blocked{background:#ef44442e;color:#f37373}.status-badge--qc-blocked .status-badge__dot{background:#ef4444}.status-badge--completed{background:#10b9811f;color:#10b981}.dark .status-badge--completed{background:#10b9812e;color:#14e8a2}.status-badge--completed .status-badge__dot{background:#10b981}.status-badge--dispatched{background:#8b5cf61f;color:#8b5cf6}.dark .status-badge--dispatched{background:#8b5cf62e;color:#ad8cf9}.status-badge--dispatched .status-badge__dot{background:#8b5cf6}.status-badge--passed{background:#10b9811f;color:#10b981}.dark .status-badge--passed{background:#10b9812e;color:#14e8a2}.status-badge--passed .status-badge__dot{background:#10b981}.status-badge--failed{background:#ef44441f;color:#ef4444}.dark .status-badge--failed{background:#ef44442e;color:#f37373}.status-badge--failed .status-badge__dot{background:#ef4444}.status-badge--pending{background:#94a3b81f;color:#94a3b8}.dark .status-badge--pending{background:#94a3b82e;color:#b3bdcc}.status-badge--pending .status-badge__dot{background:#94a3b8}.status-badge--on-hold{background:#ef44441f;color:#ef4444}.dark .status-badge--on-hold{background:#ef44442e;color:#f37373}.status-badge--on-hold .status-badge__dot{background:#ef4444}.neu-table-wrapper{background-color:#dde1e7;color:#2d3748}.dark .neu-table-wrapper{background-color:#22243a;color:#e2e8f0}.neu-table-wrapper{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .neu-table-wrapper{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.neu-table-wrapper{border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden}.dark .neu-table-wrapper{border-color:#ffffff0f}.neu-table{width:100%;border-collapse:collapse;font-size:.875rem}.neu-table thead tr{border-bottom:2px solid rgba(0,0,0,.06)}.dark .neu-table thead tr{border-bottom-color:#ffffff0f}.neu-table thead th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#a0aec0}.dark .neu-table thead th{color:#8194ac}.neu-table thead th{white-space:nowrap;-webkit-user-select:none;user-select:none}.neu-table thead th.sortable{cursor:pointer}.neu-table thead th.sortable:hover{color:#6366f1}.neu-table tbody tr{border-bottom:1px solid rgba(0,0,0,.04);transition:background .15s ease}.dark .neu-table tbody tr{border-bottom-color:#ffffff0a}.neu-table tbody tr:last-child{border-bottom:none}.neu-table tbody tr:hover{background:#00000005}.dark .neu-table tbody tr:hover{background:#ffffff05}.neu-table tbody td{padding:.75rem 1rem;color:#2d3748}.dark .neu-table tbody td{color:#e2e8f0}.neu-table__empty{text-align:center;padding:3rem 1rem!important;color:#a0aec0}.dark .neu-table__empty{color:#8194ac}.pagination{display:flex;align-items:center;justify-content:space-between;padding:1rem;flex-wrap:wrap;gap:.75rem}.pagination__info{font-size:.8125rem;color:#718096}.dark .pagination__info{color:#a0aec0}.pagination__controls{display:flex;align-items:center;justify-content:center;gap:.5rem}.pagination__btn{background-color:#dde1e7;color:#2d3748}.dark .pagination__btn{background-color:#22243a;color:#e2e8f0}.pagination__btn{box-shadow:2px 2px 4px #b8bcc2,-2px -2px 4px #fff}.dark .pagination__btn{box-shadow:2px 2px 4px #111120,-2px -2px 4px #2d2f4a}.pagination__btn{display:flex;align-items:center;justify-content:center}.pagination__btn:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.pagination__btn{width:36px;height:36px;border:none;border-radius:8px;font-size:.8125rem;font-weight:500;transition:all .15s ease}.pagination__btn:hover:not(:disabled){box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .pagination__btn:hover:not(:disabled){box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.pagination__btn:active:not(:disabled){box-shadow:inset 2px 2px 5px #b8bcc2,inset -2px -2px 5px #fff}.dark .pagination__btn:active:not(:disabled){box-shadow:inset 2px 2px 5px #111120,inset -2px -2px 5px #2d2f4a}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__btn--active{background:#6366f1;color:#fff;box-shadow:2px 2px 6px #6366f14d}.skeleton{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .skeleton{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.skeleton{border-radius:8px;overflow:hidden;position:relative}.skeleton:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.8s infinite}.dark .skeleton:after{background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}.skeleton--text{height:14px;width:80%}.skeleton--title{height:20px;width:50%}.skeleton--avatar{height:40px;width:40px;border-radius:50%}.skeleton--card{height:120px;width:100%;border-radius:12px}@keyframes shimmer{to{left:100%}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:400;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal{background-color:#dde1e7;color:#2d3748}.dark .modal{background-color:#22243a;color:#e2e8f0}.modal{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .modal{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.modal{border-radius:20px;padding:2rem;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;z-index:500;animation:slideUp .25s ease}.modal::-webkit-scrollbar{width:6px;height:6px}.modal::-webkit-scrollbar-track{background:transparent}.modal::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.modal::-webkit-scrollbar-thumb:hover{background:#00000040}.dark .modal::-webkit-scrollbar-thumb{background:#ffffff26}.dark .modal::-webkit-scrollbar-thumb:hover{background:#ffffff40}.modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.modal__title{font-size:1.25rem;font-weight:700}.modal__body{margin-bottom:1.5rem}.modal__footer{display:flex;align-items:center;justify-content:center;justify-content:flex-end;gap:.75rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sort-icon{opacity:.35;flex-shrink:0}.sort-icon.active{opacity:1;color:#6366f1}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0);z-index:400;pointer-events:none;transition:background .25s ease,backdrop-filter .25s ease}.drawer-backdrop--visible{background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100vh;z-index:500;background-color:#dde1e7;color:#2d3748}.dark .drawer{background-color:#22243a;color:#e2e8f0}.drawer{box-shadow:-8px 0 32px #0000001f}.dark .drawer{box-shadow:-8px 0 32px #0006}.drawer{display:flex;flex-direction:column;transform:translate(100%);transition:transform .25s ease}.drawer--open{transform:translate(0)}.drawer__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0}.dark .drawer__header{border-bottom-color:#ffffff0f}.drawer__title{font-size:1.25rem;font-weight:700;color:#2d3748}.dark .drawer__title{color:#e2e8f0}.drawer__subtitle{font-size:.8125rem;color:#718096}.dark .drawer__subtitle{color:#a0aec0}.drawer__subtitle{margin-top:.25rem}.drawer__body{flex:1;overflow-y:auto;padding:1.5rem}.drawer__body::-webkit-scrollbar{width:6px;height:6px}.drawer__body::-webkit-scrollbar-track{background:transparent}.drawer__body::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.drawer__body::-webkit-scrollbar-thumb:hover{background:#00000040}.dark .drawer__body::-webkit-scrollbar-thumb{background:#ffffff26}.dark .drawer__body::-webkit-scrollbar-thumb:hover{background:#ffffff40}.drawer__footer{display:flex;align-items:center;justify-content:center;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;border-top:1px solid rgba(0,0,0,.06);flex-shrink:0}.dark .drawer__footer{border-top-color:#ffffff0f}.toast{background-color:#dde1e7;color:#2d3748}.dark .toast{background-color:#22243a;color:#e2e8f0}.toast{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .toast{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.toast{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;padding:1rem 1.25rem;border-radius:12px;min-width:300px;max-width:480px;animation:slideIn .25s ease}.toast--success{border-left:3px solid #10b981}.toast--error{border-left:3px solid #ef4444}.toast--warning{border-left:3px solid #f59e0b}.toast--info{border-left:3px solid #3b82f6}.toast__message{font-size:.8125rem;color:#2d3748}.dark .toast__message{color:#e2e8f0}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.kpi-card{background-color:#dde1e7;color:#2d3748}.dark .kpi-card{background-color:#22243a;color:#e2e8f0}.kpi-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .kpi-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.kpi-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;transition:all .25s ease}.dark .kpi-card{border-color:#ffffff0f}.kpi-card:hover{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .kpi-card:hover{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.kpi-card:hover{transform:translateY(-2px)}.kpi-card__icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .kpi-card__icon{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.kpi-card__icon{margin-bottom:.25rem}.kpi-card__value{font-size:1.25rem;font-weight:700;font-family:JetBrains Mono,monospace;letter-spacing:-.02em;color:#2d3748}.dark .kpi-card__value{color:#e2e8f0}.kpi-card__label{font-size:.8125rem;color:#718096}.dark .kpi-card__label{color:#a0aec0}.neu-tabs{background-color:#dde1e7;color:#2d3748}.dark .neu-tabs{background-color:#22243a;color:#e2e8f0}.neu-tabs{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .neu-tabs{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.neu-tabs{display:inline-flex;border-radius:12px;padding:.25rem;gap:.25rem}.neu-tabs__tab:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.neu-tabs__tab{padding:.5rem 1.25rem;border:none;border-radius:8px;font-size:.8125rem;font-weight:500;background:transparent;color:#718096}.dark .neu-tabs__tab{color:#a0aec0}.neu-tabs__tab{transition:all .15s ease;cursor:pointer}.neu-tabs__tab:hover:not(.neu-tabs__tab--active){color:#2d3748}.dark .neu-tabs__tab:hover:not(.neu-tabs__tab--active){color:#e2e8f0}.neu-tabs__tab--active{background-color:#dde1e7;color:#2d3748}.dark .neu-tabs__tab--active{background-color:#22243a;color:#e2e8f0}.neu-tabs__tab--active{box-shadow:2px 2px 4px #b8bcc2,-2px -2px 4px #fff}.dark .neu-tabs__tab--active{box-shadow:2px 2px 4px #111120,-2px -2px 4px #2d2f4a}.neu-tabs__tab--active{color:#2d3748}.dark .neu-tabs__tab--active{color:#e2e8f0}.file-upload{background-color:#dde1e7;color:#2d3748}.dark .file-upload{background-color:#22243a;color:#e2e8f0}.file-upload{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .file-upload{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.file-upload{border-radius:16px;padding:2rem;text-align:center;cursor:pointer;transition:all .25s ease;border:2px dashed transparent}.file-upload:hover,.file-upload--active{border-color:#6366f166}.file-upload__icon{color:#a0aec0}.dark .file-upload__icon{color:#8194ac}.file-upload__icon{margin-bottom:.75rem}.file-upload__text{font-size:.8125rem;color:#718096}.dark .file-upload__text{color:#a0aec0}.file-upload__hint{font-size:.75rem;color:#a0aec0}.dark .file-upload__hint{color:#8194ac}.file-upload__hint{margin-top:.5rem}.multi-select{position:relative}.multi-select__trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left}.multi-select__value{font-size:.875rem;color:#2d3748}.dark .multi-select__value{color:#e2e8f0}.multi-select__icon{flex-shrink:0;color:#a0aec0}.dark .multi-select__icon{color:#8194ac}.multi-select__icon{transition:transform .15s ease}.multi-select__icon--open{transform:rotate(180deg)}.multi-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:#dde1e7;color:#2d3748}.dark .multi-select__dropdown{background-color:#22243a;color:#e2e8f0}.multi-select__dropdown{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .multi-select__dropdown{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.multi-select__dropdown{border-radius:12px;padding:.5rem 0;z-index:100;max-height:240px;overflow-y:auto}.multi-select__dropdown::-webkit-scrollbar{width:6px;height:6px}.multi-select__dropdown::-webkit-scrollbar-track{background:transparent}.multi-select__dropdown::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.multi-select__dropdown::-webkit-scrollbar-thumb:hover{background:#00000040}.dark .multi-select__dropdown::-webkit-scrollbar-thumb{background:#ffffff26}.dark .multi-select__dropdown::-webkit-scrollbar-thumb:hover{background:#ffffff40}.multi-select__dropdown{animation:fadeIn .15s ease}.multi-select__item{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.multi-select__item:hover{background:#0000000a}.dark .multi-select__item:hover{background:#ffffff0a}.multi-select__item--all{border-bottom:1px solid rgba(0,0,0,.06);margin-bottom:.25rem;padding-bottom:.75rem;font-weight:500}.dark .multi-select__item--all{border-bottom-color:#ffffff0f}.multi-select__checkbox{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;flex-shrink:0;box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .multi-select__checkbox{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.multi-select__checkbox{transition:all .15s ease}.multi-select__checkbox--checked{background:#6366f1;color:#fff;box-shadow:none}.multi-select__label{font-size:.8125rem;color:#2d3748}.dark .multi-select__label{color:#e2e8f0}.app-layout{display:flex;min-height:100vh;background:#dde1e7}.dark .app-layout{background:#1a1b2e}.sidebar{position:fixed;top:0;left:0;width:260px;height:100vh;z-index:300;background-color:#dde1e7;color:#2d3748}.dark .sidebar{background-color:#22243a;color:#e2e8f0}.sidebar{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .sidebar{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.sidebar{padding:1.5rem 1rem;display:flex;flex-direction:column;transition:width .25s ease,transform .25s ease;overflow-y:auto;overflow-x:hidden}.sidebar::-webkit-scrollbar{width:6px;height:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:#00000040}.dark .sidebar::-webkit-scrollbar-thumb{background:#ffffff26}.dark .sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media(max-width:1023px){.sidebar{transform:translate(-100%)}.sidebar--open{transform:translate(0)}}.sidebar__brand{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-bottom:1.5rem}.sidebar__brand-logo{width:72px;height:72px;object-fit:contain}.sidebar__brand-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:12px;background:#6366f1;color:#fff;font-weight:700;font-size:1.125rem;flex-shrink:0}.sidebar__brand-text{font-family:Outfit,DM Sans,sans-serif;font-size:1rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;color:#b8960c;-webkit-text-stroke:.5px rgba(154,125,10,.4);paint-order:stroke fill;filter:drop-shadow(-1px -1px .5px rgba(255,255,255,.6)) drop-shadow(1px 1px 1px rgba(122,106,26,.6))}.dark .sidebar__brand-text{color:#c9a82c;-webkit-text-stroke:.5px rgba(154,125,10,.3);filter:drop-shadow(-1px -1px .5px rgba(51,53,88,.5)) drop-shadow(1px 1px 1px rgba(10,11,22,.7))}.sidebar__nav{flex:1;display:flex;flex-direction:column;gap:.25rem}.sidebar__link{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:12px;font-size:.875rem;font-weight:500;color:#718096}.dark .sidebar__link{color:#a0aec0}.sidebar__link{transition:all .15s ease;text-decoration:none}.sidebar__link:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.sidebar__link:hover{color:#2d3748}.dark .sidebar__link:hover{color:#e2e8f0}.sidebar__link:hover{box-shadow:2px 2px 4px #b8bcc2,-2px -2px 4px #fff}.dark .sidebar__link:hover{box-shadow:2px 2px 4px #111120,-2px -2px 4px #2d2f4a}.sidebar__link--active{color:#2d3748}.dark .sidebar__link--active{color:#e2e8f0}.sidebar__link--active{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .sidebar__link--active{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.sidebar__link--active{color:#6366f1}.dark .sidebar__link--active{color:#818cf8}.sidebar__link-icon{width:20px;height:20px;flex-shrink:0}.sidebar__link-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__footer{padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.dark .sidebar__footer{border-top-color:#ffffff0f}.sidebar__logout{width:100%;border:none;cursor:pointer;background:transparent;font-family:inherit;font-size:inherit;color:inherit}.sidebar__logout:hover{color:#ef4444}.dark .sidebar__logout:hover{color:#f37373}.sidebar__footer-logo{margin-top:auto;padding-top:1rem;display:flex;justify-content:center}.sidebar__footer-logo-img{width:100%;max-width:160px;height:auto;object-fit:contain;opacity:.5}.main-area{flex:1;margin-left:260px;min-height:100vh;display:flex;flex-direction:column;transition:margin-left .25s ease}@media(max-width:1023px){.main-area{margin-left:0}}.header{position:sticky;top:0;z-index:200;height:64px;background-color:#dde1e7;color:#2d3748}.dark .header{background-color:#22243a;color:#e2e8f0}.header{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .header{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;flex-shrink:0}.header__left{display:flex;align-items:center;justify-content:flex-start;gap:1rem}.header__title{font-size:1.125rem;font-weight:600;color:#2d3748}.dark .header__title{color:#e2e8f0}.header__breadcrumb{font-size:.8125rem;color:#a0aec0}.dark .header__breadcrumb{color:#8194ac}.header__right{display:flex;align-items:center;justify-content:center;gap:.75rem}.header__menu-btn{display:none}@media(max-width:1023px){.header__menu-btn{display:flex}}.header__user-menu{position:absolute;right:0;top:calc(100% + 8px);min-width:140px;background-color:#dde1e7;color:#2d3748}.dark .header__user-menu{background-color:#22243a;color:#e2e8f0}.header__user-menu{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .header__user-menu{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.header__user-menu{border-radius:12px;padding:.25rem;z-index:100}.header__user-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border:none;border-radius:8px;background:none;color:inherit;font-size:.8125rem;cursor:pointer;transition:background .15s ease}.header__user-menu-item:hover{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .header__user-menu-item:hover{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.page-content{flex:1;padding:1.5rem}@media(max-width:767px){.page-content{padding:1rem}}.page-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.page-header__title{font-size:1.5rem;font-weight:700;color:#2d3748}.dark .page-header__title{color:#e2e8f0}.page-header__subtitle{font-size:.8125rem;color:#718096}.dark .page-header__subtitle{color:#a0aec0}.page-header__subtitle{margin-top:.25rem}.page-header__actions{display:flex;align-items:center;justify-content:center;gap:.75rem}.grid-kpi{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:767px){.grid-2{grid-template-columns:1fr}}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}@media(max-width:1023px){.grid-3{grid-template-columns:1fr 1fr}}@media(max-width:767px){.grid-3{grid-template-columns:1fr}}.sidebar-overlay{display:none}@media(max-width:1023px){.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:299;animation:fadeIn .15s ease}}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:1rem;background:#dde1e7}.dark .auth-page{background:#1a1b2e}.auth-card{background-color:#dde1e7;color:#2d3748}.dark .auth-card{background-color:#22243a;color:#e2e8f0}.auth-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .auth-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.auth-card{border-radius:20px;padding:2.5rem;width:100%;max-width:420px;animation:slideUp .4s ease}.auth-card__logo{display:flex;flex-direction:column;align-items:center;margin-bottom:2rem;gap:.75rem}.auth-card__logo-img{width:64px;height:64px;object-fit:contain}.auth-card__logo-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:#6366f1;color:#fff;font-weight:700;font-size:1.25rem}.auth-card__logo-text{font-family:Outfit,DM Sans,sans-serif;font-size:1.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#d0d4da;text-shadow:-1px -1px 1px rgba(255,255,255,.8),1px 1px 1px rgba(154,159,166,.6),inset 0 0 0 transparent;background-color:transparent;-webkit-text-stroke:1px rgba(160,165,172,.4);paint-order:stroke fill;filter:drop-shadow(-1px -1px .5px rgba(255,255,255,.5)) drop-shadow(1px 1px 1px rgba(138,143,150,.5))}.dark .auth-card__logo-text{color:#1e1f32;-webkit-text-stroke:1px rgba(13,14,26,.5);filter:drop-shadow(-1px -1px .5px rgba(45,47,74,.4)) drop-shadow(1px 1px 1px rgba(10,11,22,.6))}.auth-card__title{text-align:center;font-size:1.5rem;font-weight:700;color:#2d3748}.dark .auth-card__title{color:#e2e8f0}.auth-card__title{margin-bottom:.5rem}.auth-card__subtitle{text-align:center;font-size:.8125rem;color:#718096}.dark .auth-card__subtitle{color:#a0aec0}.auth-card__subtitle{margin-bottom:2rem}.auth-card__form{display:flex;flex-direction:column;gap:1.25rem}.auth-card__footer{text-align:center;margin-top:1.5rem;font-size:.8125rem;color:#718096}.dark .auth-card__footer{color:#a0aec0}.auth-card__footer a{font-weight:500}.auth-card__error{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .auth-card__error{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.auth-card__error{border-radius:12px;padding:.75rem 1rem;background:#ef444414;color:#ef4444;font-size:.8125rem;text-align:center}.dashboard__kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}@media(max-width:1023px){.dashboard__kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:639px){.dashboard__kpi-grid{grid-template-columns:1fr}}.dashboard__charts{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:1fr;gap:1rem;margin-top:1rem}@media(max-width:1023px){.dashboard__charts{grid-template-columns:1fr;grid-auto-rows:auto}}.dashboard__chart-card{background-color:#dde1e7;color:#2d3748}.dark .dashboard__chart-card{background-color:#22243a;color:#e2e8f0}.dashboard__chart-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .dashboard__chart-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.dashboard__chart-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:1rem;display:flex;flex-direction:column}.dark .dashboard__chart-card{border-color:#ffffff0f}.dashboard__chart-card-title{font-size:.875rem;font-weight:600;color:#2d3748}.dark .dashboard__chart-card-title{color:#e2e8f0}.dashboard__chart-card-title{margin-bottom:.75rem;flex-shrink:0}.dashboard__pie-container{position:relative;flex:1;min-height:0;overflow:visible}.dashboard__pie-container .recharts-wrapper,.dashboard__pie-container .recharts-surface{overflow:visible}.dashboard__pie-center{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none}.dashboard__pie-center-value{font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace;color:#2d3748}.dark .dashboard__pie-center-value{color:#e2e8f0}.dashboard__pie-center-value{line-height:1}.dashboard__pie-center-label{font-size:.75rem;color:#718096}.dark .dashboard__pie-center-label{color:#a0aec0}.dashboard__pie-center-label{text-transform:uppercase;letter-spacing:.05em}.dashboard__pie-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem .75rem;margin-top:.5rem}.dashboard__pie-legend-item{display:flex;align-items:center;gap:.25rem;font-size:.8125rem;transition:transform .15s ease}.dashboard__pie-legend-item:hover{transform:scale(1.05)}.dashboard__pie-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:1px 1px 3px #00000026,-1px -1px 2px #ffffffb3}.dashboard__pie-legend-label{color:#2d3748}.dark .dashboard__pie-legend-label{color:#e2e8f0}.dashboard__pie-legend-label{font-weight:500}.dashboard__pie-legend-count{color:#718096}.dark .dashboard__pie-legend-count{color:#a0aec0}.dashboard__pie-legend-count{font-size:.75rem}.dashboard__wip-list{display:flex;flex-direction:column;gap:.75rem;flex:1;justify-content:center}.dashboard__wip-row{display:flex;align-items:center;gap:.75rem}.dashboard__wip-label{flex-shrink:0;width:110px;font-size:.8125rem;font-weight:500;color:#2d3748}.dark .dashboard__wip-label{color:#e2e8f0}.dashboard__wip-label{text-align:right}.dashboard__wip-bar-track{flex:1;height:12px;border-radius:9999px;box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .dashboard__wip-bar-track{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.dashboard__wip-bar-track{padding:2px}.dashboard__wip-bar-fill{height:100%;border-radius:9999px;background:linear-gradient(180deg,#818cf8,#6366f1);box-shadow:1px 1px 3px #00000026,-1px -1px 2px #fff9,inset 0 1px 1px #ffffff4d;transition:width .6s ease;min-width:6px}.dark .dashboard__wip-bar-fill{background:linear-gradient(180deg,#818cf8,#6366f1);box-shadow:1px 1px 3px #0000004d,-1px -1px 2px #ffffff0d,inset 0 1px 1px #ffffff1a}.dashboard__wip-count{flex-shrink:0;width:28px;font-size:.8125rem;font-weight:600;font-family:JetBrains Mono,monospace;color:#2d3748}.dark .dashboard__wip-count{color:#e2e8f0}.dashboard__wip-count{text-align:right}.dashboard__attention{margin-top:1rem}.dashboard__attention-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#ef4444;margin-bottom:.75rem}.dashboard__attention-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(max-width:639px){.dashboard__attention-grid{grid-template-columns:1fr}}.dashboard__attention-card{background-color:#dde1e7;color:#2d3748}.dark .dashboard__attention-card{background-color:#22243a;color:#e2e8f0}.dashboard__attention-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .dashboard__attention-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.dashboard__attention-card{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:.75rem 1rem;cursor:pointer;transition:all .15s ease;border-left:4px solid transparent}.dark .dashboard__attention-card{border-color:#ffffff0f;border-left-color:transparent}.dashboard__attention-card:hover{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .dashboard__attention-card:hover{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.dashboard__attention-card:hover{transform:translateY(-1px)}.dashboard__attention-card--stuck{border-left-color:#f59e0b}.dashboard__attention-card--failed,.dashboard__attention-card--blocked{border-left-color:#ef4444}.dashboard__attention-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.25rem}.dashboard__attention-card-spool{font-weight:700;font-family:JetBrains Mono,monospace;font-size:.875rem;color:#2d3748}.dark .dashboard__attention-card-spool{color:#e2e8f0}.dashboard__attention-card-badge{font-size:.75rem;font-weight:700;font-family:JetBrains Mono,monospace;padding:.25rem .5rem;border-radius:8px}.dashboard__attention-card-badge--stuck{color:#f59e0b;background:#f59e0b1a}.dashboard__attention-card-badge--failed{color:#ef4444;background:#ef44441a}.dashboard__attention-card-detail{font-size:.8125rem;color:#718096}.dark .dashboard__attention-card-detail{color:#a0aec0}.toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem}.toolbar__left{display:flex;align-items:center;justify-content:flex-start;gap:.75rem;flex-wrap:wrap;flex:1}.toolbar__right{display:flex;align-items:center;justify-content:center;gap:.75rem}.toolbar__search{width:100%;max-width:320px}.toolbar__filter{min-width:160px}.spool-detail{width:100%}.spool-detail__back{display:inline-flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:500;color:#6366f1;margin-bottom:1.25rem;text-decoration:none;transition:opacity .15s ease}.spool-detail__back:hover{opacity:.75}.spool-detail__info-card{margin-bottom:1.5rem}.spool-detail__info-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem}.spool-detail__info-left{flex:1;min-width:0}.spool-detail__spool-no{font-size:1.75rem;font-weight:700;font-family:JetBrains Mono,monospace;letter-spacing:-.01em;margin-bottom:.5rem}.spool-detail__meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.8125rem;color:#718096}.dark .spool-detail__meta{color:#a0aec0}.spool-detail__meta strong{font-weight:600;color:#2d3748}.dark .spool-detail__meta strong{color:#e2e8f0}.spool-detail__meta strong{font-family:JetBrains Mono,monospace}.spool-detail__qr{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .spool-detail__qr{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.spool-detail__qr{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;width:96px;height:96px;border-radius:12px;flex-shrink:0;padding:.5rem;border:1px solid rgba(0,0,0,.08)}.dark .spool-detail__qr{border-color:#ffffff0f}.spool-detail__qr-label{font-size:.75rem;color:#a0aec0}.dark .spool-detail__qr-label{color:#8194ac}.spool-detail__qr-label{font-weight:500}.spool-detail__progress{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(0,0,0,.06)}.dark .spool-detail__progress{border-top-color:#ffffff0f}.spool-detail__progress-track{display:flex;align-items:flex-start;padding:.5rem .75rem .75rem}.spool-detail__progress-step{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}.spool-detail__progress-segment{display:flex;align-items:center;width:100%}.spool-detail__progress-dot{width:14px;height:14px;border-radius:50%;flex-shrink:0;z-index:1;transition:all .15s ease}.spool-detail__progress-line{flex:1;height:4px;border-radius:2px;min-width:8px;transition:background-color .15s ease}.spool-detail__progress-line--inactive{background-color:#e5e7eb}.dark .spool-detail__progress-line--inactive{background-color:#ffffff1f}.spool-detail__progress-end{display:flex;align-items:center;flex-shrink:0}.spool-detail__progress-label{font-size:.6875rem;margin-top:.5rem;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding:0 2px;transition:color .15s ease;color:#a0aec0}.dark .spool-detail__progress-label{color:#a0aec0}.spool-detail__progress-label--active{color:#2d3748}.dark .spool-detail__progress-label--active{color:#e2e8f0}.spool-detail__history-card{margin-bottom:1.5rem}.spool-detail__section-title{font-size:1.125rem;font-weight:600;margin-bottom:1.25rem}.spool-detail__empty{box-shadow:inset 3px 3px 7px #b8bcc2,inset -3px -3px 7px #fff}.dark .spool-detail__empty{box-shadow:inset 3px 3px 7px #111120,inset -3px -3px 7px #2d2f4a}.spool-detail__empty{border-radius:12px;padding:2rem;text-align:center;color:#a0aec0}.dark .spool-detail__empty{color:#8194ac}.spool-detail__timeline{display:flex;flex-direction:column;padding-left:.5rem}.spool-detail__timeline-item{position:relative;display:flex;align-items:flex-start;gap:1rem;padding-bottom:1.5rem;padding-left:1.5rem}.spool-detail__timeline-item:last-child{padding-bottom:0}.spool-detail__timeline-dot{position:absolute;left:0;top:.25rem;width:12px;height:12px;border-radius:50%;flex-shrink:0;z-index:1}.spool-detail__timeline-line{position:absolute;left:5px;top:16px;width:2px;bottom:0;background:#e5e7eb}.dark .spool-detail__timeline-line{background:#ffffff1a}.spool-detail__timeline-content{flex:1;min-width:0}.spool-detail__timeline-name{font-weight:600;font-size:.875rem;margin-bottom:.25rem}.spool-detail__timeline-meta{font-size:.8125rem;color:#a0aec0}.dark .spool-detail__timeline-meta{color:#8194ac}@media(max-width:600px){.spool-detail__info-top{flex-direction:column}.spool-detail__qr{align-self:flex-end}.spool-detail__meta{flex-direction:column;gap:.25rem}.spool-detail__progress-label{font-size:.5625rem}}.reports__kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.25rem}@media(max-width:1023px){.reports__kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:639px){.reports__kpi-grid{grid-template-columns:1fr}}.reports__overview{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media(max-width:1023px){.reports__overview{grid-template-columns:1fr}}.reports__chart-card{background-color:#dde1e7;color:#2d3748}.dark .reports__chart-card{background-color:#22243a;color:#e2e8f0}.reports__chart-card{box-shadow:6px 6px 14px #b8bcc2,-6px -6px 14px #fff}.dark .reports__chart-card{box-shadow:6px 6px 14px #111120,-6px -6px 14px #2d2f4a}.reports__chart-card{border:1px solid rgba(0,0,0,.08);border-radius:16px;padding:1rem;display:flex;flex-direction:column}.dark .reports__chart-card{border-color:#ffffff0f}.reports__chart-card--pie{min-height:380px}.reports__chart-title{font-size:.875rem;font-weight:600;color:#2d3748}.dark .reports__chart-title{color:#e2e8f0}.reports__chart-title{margin-bottom:.75rem;flex-shrink:0}.reports__chart-body{flex:1;min-height:0}.dark .reports__chart-body .recharts-cartesian-axis-tick text,.dark .reports__chart-body .recharts-legend-item-text{fill:#a0aec0!important}.dark .reports__chart-body .recharts-cartesian-grid line{stroke:#ffffff0f}.dark .reports__chart-body .recharts-tooltip-wrapper .recharts-default-tooltip{background:#22243af2!important;border:1px solid rgba(255,255,255,.08)!important;color:#e2e8f0}.reports__pie-container{position:relative;flex:1;min-height:0;overflow:visible}.reports__pie-container .recharts-wrapper,.reports__pie-container .recharts-surface{overflow:visible}.dark .reports__pie-container .recharts-tooltip-wrapper .recharts-default-tooltip{background:#22243af2!important;border:1px solid rgba(255,255,255,.08)!important;color:#e2e8f0}.reports__pie-center{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;pointer-events:none}.reports__pie-center-value{font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace;color:#2d3748}.dark .reports__pie-center-value{color:#e2e8f0}.reports__pie-center-value{line-height:1}.reports__pie-center-label{font-size:.75rem;color:#718096}.dark .reports__pie-center-label{color:#a0aec0}.reports__pie-center-label{text-transform:uppercase;letter-spacing:.05em}.reports__pie-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem .75rem;margin-top:.5rem}.reports__pie-legend-item{display:flex;align-items:center;gap:.25rem;font-size:.8125rem;transition:transform .15s ease}.reports__pie-legend-item:hover{transform:scale(1.05)}.reports__pie-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:1px 1px 3px #00000026,-1px -1px 2px #ffffffb3}.reports__pie-legend-label{color:#2d3748}.dark .reports__pie-legend-label{color:#e2e8f0}.reports__pie-legend-label{font-weight:500}.reports__pie-legend-count{color:#718096}.dark .reports__pie-legend-count{color:#a0aec0}.reports__pie-legend-count{font-size:.75rem}.reports__severity{display:inline-block;padding:.25rem .5rem;border-radius:8px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.reports__severity--critical{color:#ef4444;background:#ef44441a}.reports__severity--high{color:#f59e0b;background:#f59e0b1a}.reports__severity--medium{color:#6366f1;background:#6366f11a}.reports__severity--low{color:#94a3b8;background:#94a3b81a}.reports__delay-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}@media(max-width:1023px){.reports__delay-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:639px){.reports__delay-summary{grid-template-columns:1fr}}.reports__delay-card{background-color:#dde1e7;color:#2d3748}.dark .reports__delay-card{background-color:#22243a;color:#e2e8f0}.reports__delay-card{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .reports__delay-card{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.reports__delay-card{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:.75rem 1rem;text-align:center;border-left:4px solid transparent}.dark .reports__delay-card{border-color:#ffffff0f;border-left-color:transparent}.reports__delay-card--critical{border-left-color:#ef4444}.reports__delay-card--high{border-left-color:#f59e0b}.reports__delay-card--medium{border-left-color:#6366f1}.reports__delay-card--low{border-left-color:#94a3b8}.reports__delay-card-value{display:block;font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace;color:#2d3748}.dark .reports__delay-card-value{color:#e2e8f0}.reports__delay-card-value{line-height:1.2}.reports__delay-card-label{display:block;font-size:.75rem;color:#718096}.dark .reports__delay-card-label{color:#a0aec0}.reports__delay-card-label{text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.reports__prod-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}@media(max-width:1023px){.reports__prod-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:639px){.reports__prod-stats{grid-template-columns:1fr}}.reports__prod-stat{background-color:#dde1e7;color:#2d3748}.dark .reports__prod-stat{background-color:#22243a;color:#e2e8f0}.reports__prod-stat{box-shadow:3px 3px 8px #b8bcc2,-3px -3px 8px #fff}.dark .reports__prod-stat{box-shadow:3px 3px 8px #111120,-3px -3px 8px #2d2f4a}.reports__prod-stat{border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:.75rem 1rem;text-align:center}.dark .reports__prod-stat{border-color:#ffffff0f}.reports__prod-stat-value{display:block;font-size:1.5rem;font-weight:700;font-family:JetBrains Mono,monospace;color:#2d3748}.dark .reports__prod-stat-value{color:#e2e8f0}.reports__prod-stat-value{line-height:1.2}.reports__prod-stat-label{display:block;font-size:.75rem;color:#718096}.dark .reports__prod-stat-label{color:#a0aec0}.reports__prod-stat-label{text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}
