.loading-border{width:100%;border-radius:0 0 20px 20px;background:none;overflow:hidden;position:relative;background-color:var(--accent-highlight-color)}.loading-border:before{content:"";display:block;position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,var(--highlight-color) 50%,var(--highlight-color) 50%,transparent 100%);animation:gradient-loading-bar .8s linear infinite;border-radius:0 0 20px 20px;will-change:transform,opacity}@keyframes gradient-loading-bar{0%{transform:translate(-75%);opacity:.5}50%{opacity:1}to{transform:translate(75%);opacity:.5}}.loading-border-top{margin-top:0;margin-bottom:-16px;height:20px;border-radius:20px 20px 0 0}.loading-border-bottom{margin-top:-16px;margin-bottom:0;height:20px;border-radius:0 0 20px 20px}@keyframes spin-and-pulse{0%{transform:rotate(0) scale(1);filter:hue-rotate(0deg);opacity:.8}25%{transform:rotate(90deg) scale(1.1);filter:hue-rotate(90deg);opacity:1}50%{transform:rotate(180deg) scale(1);filter:hue-rotate(180deg);opacity:.8}75%{transform:rotate(270deg) scale(1.1);filter:hue-rotate(270deg);opacity:1}to{transform:rotate(360deg) scale(1);filter:hue-rotate(360deg);opacity:.8}}@keyframes bellPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bounceIn{0%{transform:scale(0)}50%{transform:scale(1.3)}to{transform:scale(1)}}.loading-icon{font-size:24px;animation:spin-and-pulse 2s ease-in-out infinite;filter:hue-rotate(0deg)}.loading-cell{background-color:color-mix(in srgb,var(--secondary-color) 10%,transparent)!important;opacity:.7!important;cursor:not-allowed!important;position:relative}.loading-cell:after{content:"\23f3";position:absolute;right:8px;top:50%;transform:translateY(-50%);opacity:.8;font-size:12px;animation:spin-and-pulse 2s ease-in-out infinite;filter:hue-rotate(0deg)}.loading-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;color:var(--text-color)}.loading-message{font-size:14px;opacity:.8;font-weight:500}.button-form{background-color:var(--accent-color);color:var(--text-color);border-radius:50px;padding:5px 10px;cursor:pointer;box-shadow:var(--shadow-container);border:none;transition:all .3s}.button-form:hover{color:var(--text-color);background-color:var(--accent-color);box-shadow:var(--accent-highlight)}.button-form:active:focus{color:var(--text-color);background-color:var(--accent-highlight-color);box-shadow:var(--accent-highlight)}.button-form:disabled{color:var(--disabled-text-color);background-color:var(--disabled-color);box-shadow:none;pointer-events:none}.button-item{background-color:none;color:var(--text-color);border-radius:50px;padding:5px 10px;cursor:pointer;box-shadow:var(--shadow-container);border:none;transition:all .3s}.button-item:hover{background-color:var(--accent-highlight-color)}.button-item:active:focus{background-color:var(--primary-color);box-shadow:var(--accent-highlight)}.button-item:disabled{color:var(--disabled-text-color);background-color:var(--disabled-color);box-shadow:none;pointer-events:none}.btn-clear{background-color:var(--warning-secondary-color);color:var(--text-color);border-radius:50px;padding:5px 10px;cursor:pointer;box-shadow:var(--shadow-container);border:none;transition:all .3s;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.1rem}.btn-clear:hover:not(:disabled){background-color:var(--error-color);box-shadow:0 4px 12px #dc35454d}.btn-clear:disabled{color:var(--disabled-text-color);background-color:var(--disabled-color);box-shadow:none;pointer-events:none}.btn-clear-integrated{position:absolute;right:6px;top:50%;transform:translateY(-50%);background-color:var(--error-color);color:#fff;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:all .2s ease;padding:0}.btn-clear-integrated:hover:not(:disabled){background-color:#c82333;transform:translateY(-50%) scale(1.1)}.btn-clear-integrated:disabled{background-color:var(--disabled-color);color:var(--disabled-text-color);cursor:not-allowed}.warning-bell-btn{position:relative;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}.warning-bell-btn.has-warnings{background-color:var(--warning-color);color:#fff;animation:bellPulse 2s infinite}.warning-bell-btn.has-warnings:hover{background-color:var(--warning-color);animation:none}.warning-count{position:absolute;top:-6px;right:-6px;background-color:#e74c3c;color:#fff;border:2px solid var(--container-color);border-radius:50%;width:24px;height:24px;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;animation:bounceIn .3s ease}.file-select-btn{display:flex;align-items:center;justify-content:flex-start;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative;padding-right:16px}.file-select-btn.file-selected{box-shadow:none}.file-select-btn.file-selected:hover:not(:disabled){box-shadow:var(--change-highlight)}.file-select-btn[disabled]{opacity:.6;cursor:not-allowed}.file-select-btn[disabled]:hover{background-color:var(--background-alt-color)}.file-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spares-btn{background:linear-gradient(135deg,var(--accent-color, #17a2b8) 0%,#138496 100%);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;font-size:.9rem;transition:all .3s ease;position:relative;overflow:hidden}.spares-btn:hover:not(:disabled){background:linear-gradient(135deg,#138496,#0f6c7c);transform:translateY(-1px);box-shadow:0 4px 8px #17a2b84d}.spares-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.spares-btn.has-spares{background:linear-gradient(135deg,var(--success-color, #28a745) 0%,#1e7e34 100%)}.spares-btn.has-spares:hover:not(:disabled){background:linear-gradient(135deg,#1e7e34,#155724);box-shadow:0 4px 8px #28a7454d}.spares-text{display:inline-block}.spares-count{font-size:.8rem;margin-left:4px;opacity:.9;font-weight:600}.spares-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;background-color:var(--primary-color, #4a90c2);color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;margin-left:8px;padding:0 4px;line-height:1;box-shadow:0 1px 3px #0003}.btn-group.file-button-group{display:flex;border-radius:50px;overflow:hidden}.btn-group-left{border-top-left-radius:50px!important;border-bottom-left-radius:50px!important;box-shadow:var(--shadow-container)}.btn-group-right{border-top-right-radius:50px!important;border-bottom-right-radius:50px!important;box-shadow:var(--shadow-container)}.btn-group .file-select-btn{border-radius:0;box-shadow:var(--shadow-container)}.btn-clear-group{min-width:40px;width:40px;padding:5px 8px;display:flex;align-items:center;justify-content:center;background-color:var(--error-color);color:#fff}.btn-clear-group:hover:not(:disabled){background-color:#c82333;color:#fff;box-shadow:none;border:none}.btn-clear-group:disabled{background-color:var(--disabled-color);color:var(--disabled-text-color)}@media (max-width: 768px){.spares-btn{padding:6px 12px;font-size:.85rem}.spares-btn .spares-text{display:none}.spares-btn .bi-tools{margin-right:0!important}}:root{--primary-gradient: linear-gradient( 180deg, var(--primary-color), var(--secondary-color) );--primary-inverted-gradient: linear-gradient( 180deg, var(--secondary-color), var(--primary-color) );--accent-gradient: linear-gradient( 90deg, var(--accent-color), var(--highlight-color) );--background-gradient: radial-gradient( circle, var(--primary-color), var(--secondary-color) );--background-inverted-gradient: radial-gradient( circle, var(--secondary-color), var(--primary-color) )}.dark-mode{--background-gradient: radial-gradient( circle, var(--primary-color), var(--accent-color) );--shadow-color: #00213b3d;--shadow-container: 0px 0px 10px 3px var(--shadow-color);--text-color: #cccccc;--text-alt-color: #cccccc;--text-inverted-color: #181818;--disabled-color: #4d0707;--disabled-text-color: #8d8d8d}.dark-mode.var-blue{--primary-color: #22577a;--secondary-color: #84d0ff23;--warning-secondary-color: #c035355e;--accent-color: #00213b;--accent-highlight-color: #003157;--change-highlight-color: #bd6f30;--container-color: #062844b6;--container-solid-color: #0f3553;--highlight-color: #0068b8;--success-color: #4da04d;--error-color: #b14c4c;--warning-color: #b1694c;--button-warning-color: #572e00;--accent-highlight: 0 0 0 3px #0066b4;--accent-highlight-alt: 0 0 0 3px #009625;--change-highlight: 0 0 0 3px #bd6f30;--glow-container: 0 0 5px #0066b481}.dark-mode.var-gray{--primary-color: #494e52;--secondary-color: #def2ff23;--accent-color: #1a1c1d;--glow-container: 0 0 10px #3481b4}.dark-mode.var-red{--primary-color: #742121;--secondary-color: #ffb3b31e;--accent-color: #310e0f;--glow-container: 0 0 10px #ad1b1b}.light-mode{--background-gradient: radial-gradient( circle, var(--background-color), var(--background-color) );--shadow-color: #0000001a;--shadow-container: 0px 0px 6px 1px var(--shadow-color);--text-color: #2d3748;--text-alt-color: #4a5568;--text-inverted-color: #ffffff;--background-color: #f7fafc;--disabled-color: #e2e8f0;--disabled-text-color: #a0aec0}.light-mode.var-blue{--primary-color: #4a90c2;--secondary-color: #f0f8ff;--warning-secondary-color: #fef5e7;--accent-color: #ffffff;--accent-highlight-color: #f1f5f9;--change-highlight-color: #f6ad55;--container-color: #ffffff;--container-solid-color: #ffffff;--highlight-color: #5a9fd4;--success-color: #48bb78;--error-color: #e53e3e;--warning-color: #ed8936;--button-warning-color: #fef5e7;--primary-color-rgb: 74, 144, 194;--secondary-color-rgb: 240, 248, 255;--accent-color-rgb: 255, 255, 255;--highlight-color-rgb: 90, 159, 212;--accent-highlight: 0 0 0 2px #a3d2f0;--accent-highlight-alt: 0 0 0 2px #9ae6b4;--change-highlight: 0 0 0 2px #f6ad55;--glow-container: 0 0 6px #d6ebf7}.light-mode.var-gray{--primary-color: #4a5568;--secondary-color: #f7fafc;--warning-secondary-color: #fed7d7;--accent-color: #ffffff;--accent-highlight-color: #e2e8f0;--change-highlight-color: #ed8936;--container-color: #ffffff;--highlight-color: #718096;--success-color: #38a169;--error-color: #e53e3e;--warning-color: #d69e2e;--button-warning-color: #fef5e7;--glow-container: 0 0 8px #cbd5e0}.light-mode.var-red{--primary-color: #c53030;--secondary-color: #fed7d7;--warning-secondary-color: #fef5e7;--accent-color: #ffffff;--accent-highlight-color: #e2e8f0;--change-highlight-color: #ed8936;--container-color: #ffffff;--highlight-color: #e53e3e;--success-color: #38a169;--error-color: #e53e3e;--warning-color: #d69e2e;--button-warning-color: #fef5e7;--glow-container: 0 0 8px #fed7d7}.duplicate-warning{background-color:#e74c3c26!important;box-shadow:inset 0 0 0 1px #e74c3c4d!important;color:#e74c3c!important;font-weight:500!important}.mismatch-warning{background-color:#ffc10726!important;box-shadow:inset 0 0 0 1px #ffc1074d!important;color:#ffc107!important;font-weight:500!important}.nonexistent-warning{background-color:#ff980026!important;box-shadow:inset 0 0 0 1px #ff98004d!important;color:#ff9800!important;font-weight:500!important}.warning-alert{background-color:color-mix(in srgb,var(--warning-color) 20%,transparent);color:var(--warning-color);padding:8px 16px;border-radius:20px;margin-bottom:10px;font-weight:500;border-left:4px solid var(--warning-color)}.warning-count-badge{background-color:#ffffff26;color:var(--text-color);padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:600;min-width:20px;text-align:center}.light-mode .warning-count-badge{background-color:var(--accent-highlight-color);color:var(--text-color)}.warning-count-badge.duplicate-type{background-color:#e74c3c33;color:#e74c3c}.warning-count-badge.mismatch-type{background-color:#ffc10733;color:#ffc107}.warning-count-badge.nonexistent-type{background-color:#ff980033;color:#ff9800}.warning-chip{background-color:#ffffff1a;color:var(--text-color);padding:4px 8px;border-radius:6px;font-size:.85rem;font-weight:500;border:none;transition:all .2s ease}.warning-icon.duplicate-type{color:#e74c3c}.warning-icon.mismatch-type{color:#ffc107}.warning-icon.nonexistent-type{color:#ff9800}.container-glass{background-color:var(--secondary-color);border-radius:20px;box-shadow:var(--shadow-container);padding:10px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.warning-glass{background-color:var(--warning-secondary-color)}.ct-v-c{display:flex;flex-direction:column;align-items:center}.ct-v-s{display:flex;flex-direction:column;align-items:start}.ct-v-e{display:flex;flex-direction:column;align-items:end}.ct-h-c{display:flex;flex-direction:row;align-items:center}.ct-h-s{display:flex;flex-direction:row;align-items:start}.ct-h-e{display:flex;flex-direction:row;align-items:end}.s-ct-v-c{display:flex;flex-direction:column;align-items:center}.s-ct-h-c{display:flex;flex-direction:row;align-items:center}.header-layout{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}.header-left{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.header-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.control-group{display:flex;flex-direction:row;gap:16px;align-items:center}.control-group-vertical{display:flex;flex-direction:column;gap:8px;align-items:stretch}.input-group-horizontal{display:flex;gap:16px;align-items:center}.input-group-with-label,.btn-group-horizontal{display:flex;gap:8px;align-items:center}.checkbox-group{display:flex;align-items:center;gap:8px;margin:0;white-space:nowrap}@media (max-width: 768px){.header-layout{flex-direction:column;align-items:stretch;gap:16px}.header-left{flex-direction:column;gap:16px}.header-right{justify-content:space-between}}.selected-file-name{color:var(--text-color);border-top-right-radius:10px;border-bottom-right-radius:10px;padding:10px}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:16px;color:var(--text-alt-color);font-size:1rem;z-index:2}.search-input{width:100%;padding:5px 10px 5px 48px;border:none;border-radius:50px;background-color:var(--secondary-color);color:var(--text-color);transition:all .3s}.search-input::placeholder{color:#cacaca}.search-input:focus{outline:3px solid var(--highlight-color);box-shadow:none;background-color:var(--secondary-color)}.file-input-wrapper{position:relative;display:flex}.file-input-enhanced{width:100%;padding:5px 10px;border:none;border-radius:50px;background-color:var(--secondary-color);color:var(--text-color);transition:all .3s}.file-input-enhanced:focus{outline:3px solid var(--highlight-color);box-shadow:none;background-color:var(--secondary-color)}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon .input-icon{position:absolute;left:16px;color:var(--text-alt-color);font-size:1rem;z-index:2}.input-with-icon input{padding-left:48px}.form-check{display:flex;align-items:center;gap:8px}.form-check-input{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.form-check-input:disabled{cursor:not-allowed;opacity:.6}.form-check-label{font-size:.875rem;color:var(--text-color);cursor:pointer;margin:0;-webkit-user-select:none;user-select:none}.modal{-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transition:backdrop-filter .2s ease-in-out}.modal.show{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:translateY(0)}.modal-dialog{opacity:0;transform:translateY(-50px);transition:opacity .5s ease-in-out,transform .5s ease-in-out;transition-delay:.2s}.modal.show .modal-dialog{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:1}.modal-content{background-color:var(--secondary-color);border-radius:10px;box-shadow:var(--shadow-container);padding:20px}.dropdown-enhanced{position:absolute;top:calc(100% + 8px);right:0;min-width:350px;max-width:450px;background-color:var(--primary-color);border-radius:12px;border:1px solid rgba(255,255,255,.15);box-shadow:0 8px 32px #00000040;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.95);transition:all .3s cubic-bezier(.25,.8,.25,1);z-index:1000;color:var(--text-color)}.dropdown-enhanced.show{opacity:1;visibility:visible;transform:translateY(0) scale(1)}.dropdown-header{display:flex;justify-content:flex-start;align-items:center;padding:16px 20px 12px;border-bottom:1px solid rgba(255,255,255,.1)}.dropdown-title{font-weight:600;font-size:1.1rem;color:var(--text-color)}.dropdown-content{padding:12px 0;max-height:400px;overflow-y:auto}.dropdown-content::-webkit-scrollbar{width:.6rem}.dropdown-content::-webkit-scrollbar-track{background-color:var(--accent-color)}.dropdown-content::-webkit-scrollbar-thumb{background-color:var(--secondary-color);border-radius:5px}.dropdown-content::-webkit-scrollbar-thumb:hover{background-color:var(--highlight-color);border-radius:20px}.dropdown-item{padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.05);transition:background-color .2s ease}.light-mode .dropdown-item{border-bottom:1px solid var(--accent-highlight-color)}.dropdown-item:last-child{border-bottom:none}.dropdown-item-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.dropdown-item-icon{font-size:1rem;flex-shrink:0}.dropdown-item-title{font-weight:600;font-size:.95rem;flex:1}.warning-item{padding:12px 20px;border-bottom:1px solid rgba(255,255,255,.05);transition:background-color .2s ease}.light-mode .warning-item{border-bottom:1px solid var(--accent-highlight-color)}.warning-item:last-child{border-bottom:none}.warning-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.warning-title{font-weight:600;font-size:.95rem;flex:1}.no-items-message{display:flex;align-items:center;gap:8px;padding:20px;justify-content:center;color:var(--text-color);opacity:.7}.no-items-message .text-success{color:#28a745}.vehicle-list{display:flex;flex-wrap:wrap;gap:6px}.vehicle-chip{background-color:#ffffff1a;color:var(--text-color);padding:4px 8px;border-radius:6px;font-size:.85rem;font-weight:500;border:none;transition:all .2s ease}.mismatch-chip{min-width:120px;padding:6px 10px;font-size:.8rem;text-align:center}.mismatch-card{background-color:#a0a0a01a;border-radius:8px;padding:8px 12px;margin:4px;text-align:center;min-width:100px;transition:all .2s ease}.vehicle-number{font-weight:600;font-size:.9rem;color:var(--text-color);margin-bottom:4px}.type-comparison{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem}.actual-type{color:#ff9800;font-weight:500}.arrow{color:var(--text-alt-color);font-weight:700;font-size:1rem}.required-type{color:#4caf50;font-weight:500}.no-select{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}hr.gradient{margin:0;opacity:1;border:none;height:3px;background:radial-gradient(circle,var(--primary-color) 50%,transparent 90%)}.gap-h{display:flex;flex-direction:row;gap:10px}.gap-v{display:flex;flex-direction:column;gap:10px}.txt-sep{color:var(--accent-color);font-weight:700}.txt-sep-alt{color:var(--primary-color);font-weight:700}.enhanced-scrollbar::-webkit-scrollbar{width:.5rem;height:.5rem}.enhanced-scrollbar::-webkit-scrollbar-track{background-color:var(--accent-color);border-radius:5px}.enhanced-scrollbar::-webkit-scrollbar-thumb{background-color:var(--primary-color);border-radius:5px;transition:background-color .2s ease}.enhanced-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--highlight-color)}.thin-scrollbar::-webkit-scrollbar{width:.6rem}.thin-scrollbar::-webkit-scrollbar-track{background-color:var(--accent-color)}.thin-scrollbar::-webkit-scrollbar-thumb{background-color:var(--secondary-color);border-radius:5px}.thin-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--highlight-color);border-radius:20px}.control-label{font-size:.875rem;font-weight:600;color:var(--text-alt-color);margin:0;text-transform:uppercase;letter-spacing:.5px}.smooth-transition{transition:all .3s ease}.quick-transition{transition:all .15s ease}.rounded-standard{border-radius:20px}.rounded-full{border-radius:50px}.empty-state{color:var(--text-color);font-size:1.1rem;padding:20px;text-align:center;opacity:.8}.focus-highlight:focus{outline:3px solid var(--highlight-color);box-shadow:none}.hover-lift:hover{transform:translateY(-1px)}.hover-scale:hover{transform:scale(1.05)}html,body{display:flex;margin:0;padding:0;font-family:Arial,Helvetica,sans-serif;height:100dvh;width:100dvw;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#app-root{background:var(--background-gradient);display:flex;flex-direction:column;justify-content:space-between;height:100%;width:100%}
