*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.absolute{position:absolute}.relative{position:relative}.left-\[15px\]{left:15px}.top-1\/2{top:50%}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-2\.5{margin-bottom:.625rem}.mb-5{margin-bottom:1.25rem}.mb-\[15px\]{margin-bottom:15px}.mt-\[5px\]{margin-top:5px}.block{display:block}.flex{display:flex}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-\[420px\]{max-width:420px}.max-w-\[500px\]{max-width:500px}.-translate-y-1\/2{--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.overflow-hidden{overflow:hidden}.rounded-\[10px\]{border-radius:10px}.rounded-\[15px\]{border-radius:15px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-\[\#b6d4fe\]{--tw-border-opacity:1;border-color:rgb(182 212 254/var(--tw-border-opacity,1))}.border-\[\#ffc107\]{--tw-border-opacity:1;border-color:rgb(255 193 7/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.bg-\[\#e7f3ff\]{--tw-bg-opacity:1;background-color:rgb(231 243 255/var(--tw-bg-opacity,1))}.bg-\[\#fff3cd\]{--tw-bg-opacity:1;background-color:rgb(255 243 205/var(--tw-bg-opacity,1))}.bg-red-100{background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-100,.bg-white{--tw-bg-opacity:1}.bg-white{background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-\[\#1e293b\]{--tw-gradient-from:#1e293b var(--tw-gradient-from-position);--tw-gradient-to:rgba(30,41,59,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-\[\#667eea\]{--tw-gradient-from:#667eea var(--tw-gradient-from-position);--tw-gradient-to:rgba(102,126,234,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-\[\#0f172a\]{--tw-gradient-to:#0f172a var(--tw-gradient-to-position)}.to-\[\#764ba2\]{--tw-gradient-to:#764ba2 var(--tw-gradient-to-position)}.p-3{padding:.75rem}.p-5{padding:1.25rem}.p-\[15px\]{padding:15px}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-\[15px\]{padding-left:15px;padding-right:15px}.px-\[30px\]{padding-left:30px;padding-right:30px}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-\[15px\]{padding-top:15px;padding-bottom:15px}.py-\[30px\]{padding-top:30px}.pb-\[30px\],.py-\[30px\]{padding-bottom:30px}.pl-\[45px\]{padding-left:45px}.pr-3\.5{padding-right:.875rem}.pt-5{padding-top:1.25rem}.text-center{text-align:center}.text-\[13px\]{font-size:13px}.text-\[15px\]{font-size:15px}.text-\[36px\]{font-size:36px}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-\[\#d3216e\]{--tw-text-opacity:1;color:rgb(211 33 110/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.opacity-80{opacity:.8}.shadow-\[0_20px_60px_rgba\(0\2c 0\2c 0\2c 0\.3\)\]{--tw-shadow:0 20px 60px rgba(0,0,0,.3);--tw-shadow-colored:0 20px 60px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.row-rejected{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1));opacity:.7}.row-rejected td{text-decoration:line-through;text-decoration-color:#ef4444}.row-rejected td:last-child{text-decoration:none}#checkAll,.reject-check{height:1rem;width:1rem;cursor:pointer}.modal{align-items:center;justify-content:center}.reject-field{margin-right:.25rem;vertical-align:middle}.header-icon-btns{gap:.375rem}.header-icon-btn,.header-icon-btns{display:flex;align-items:center}.header-icon-btn{height:1.75rem;width:1.75rem;cursor:pointer;justify-content:center;border-radius:.375rem;border-width:0;background-color:rgb(241 245 249/var(--tw-bg-opacity,1));font-size:.75rem;line-height:1rem;color:rgb(100 116 139/var(--tw-text-opacity,1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.header-icon-btn,.header-icon-btn:hover{--tw-bg-opacity:1;--tw-text-opacity:1}.header-icon-btn:hover{background-color:rgb(226 232 240/var(--tw-bg-opacity,1));color:rgb(59 130 246/var(--tw-text-opacity,1))}.header-add-btn{display:flex;height:2rem;width:2rem;cursor:pointer;align-items:center;justify-content:center;border-radius:.5rem;border-width:0;--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1));font-size:.875rem;line-height:1.25rem;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.header-add-btn:hover{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.role-filter-group{margin-bottom:1.25rem;display:flex;flex-wrap:wrap;gap:.5rem}.role-filter-btn{display:inline-flex;cursor:pointer;align-items:center;gap:.375rem;border-radius:20px;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.5rem 1rem;font-size:13px;--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.role-filter-btn:hover{--tw-text-opacity:1;color:rgb(102 126 234/var(--tw-text-opacity,1))}.role-filter-btn.active,.role-filter-btn:hover{--tw-border-opacity:1;border-color:rgb(102 126 234/var(--tw-border-opacity,1))}.role-filter-btn.active{--tw-bg-opacity:1;background-color:rgb(102 126 234/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.role-filter-btn .count{border-radius:10px;background-color:rgba(0,0,0,.1);padding:.125rem .5rem;font-size:11px}.role-filter-btn.active .count{background-color:hsla(0,0%,100%,.2)}.user-row.hidden{display:none}#addUserModal .modal-content,#editUserModal .modal-content{overflow:visible}#addUserModal .modal-body,#editUserModal .modal-body{overflow:visible;max-height:70vh;overflow-y:auto}#addUserModal select.form-control,#editUserModal select.form-control{position:relative;z-index:10}@media (max-width:768px){.role-filter-group{gap:.375rem}.role-filter-btn{padding:.375rem .75rem;font-size:.75rem;line-height:1rem}}.empty-state{padding:60px 1.25rem;text-align:center;--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.empty-state i{margin-bottom:15px;font-size:3rem;line-height:1;opacity:.5}.empty-state p{font-size:.875rem;line-height:1.25rem}.region-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.region-card{display:flex;flex-direction:column;gap:.625rem;border-radius:.75rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:1rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.region-card:hover{--tw-border-opacity:1;border-color:rgb(102 126 234/var(--tw-border-opacity,1));--tw-shadow:0 4px 12px rgba(102,126,234,.15);--tw-shadow-colored:0 4px 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.region-card.inactive{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1));opacity:.7}.region-name{text-align:center;font-size:1rem;line-height:1.5rem;font-weight:600;--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.region-info,.region-name{padding-top:.5rem;padding-bottom:.5rem}.region-info{justify-content:space-between;border-top-width:1px;border-bottom-width:1px;--tw-border-opacity:1;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.region-count,.region-info{display:flex;align-items:center}.region-count{gap:.25rem;font-size:.75rem;line-height:1rem;--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.region-count i{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.region-status{border-radius:10px;padding:.125rem .5rem;font-size:11px;font-weight:500}.region-status.active{background-color:rgb(220 252 231/var(--tw-bg-opacity,1));color:rgb(22 101 52/var(--tw-text-opacity,1))}.region-status.active,.region-status.inactive{--tw-bg-opacity:1;--tw-text-opacity:1}.region-status.inactive{background-color:rgb(254 226 226/var(--tw-bg-opacity,1));color:rgb(153 27 27/var(--tw-text-opacity,1))}.region-actions{gap:.5rem;padding-top:.25rem}.btn-icon,.region-actions{display:flex;justify-content:center}.btn-icon{height:2.25rem;width:2.25rem;cursor:pointer;align-items:center;border-radius:.5rem;border-width:0;font-size:.875rem;line-height:1.25rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.btn-icon.edit{background-color:rgb(239 246 255/var(--tw-bg-opacity,1));color:rgb(59 130 246/var(--tw-text-opacity,1))}.btn-icon.edit,.btn-icon.edit:hover{--tw-bg-opacity:1;--tw-text-opacity:1}.btn-icon.edit:hover{background-color:rgb(59 130 246/var(--tw-bg-opacity,1));color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-icon.delete{background-color:rgb(254 242 242/var(--tw-bg-opacity,1));color:rgb(239 68 68/var(--tw-text-opacity,1))}.btn-icon.delete,.btn-icon.delete:hover{--tw-bg-opacity:1;--tw-text-opacity:1}.btn-icon.delete:hover{background-color:rgb(239 68 68/var(--tw-bg-opacity,1));color:rgb(255 255 255/var(--tw-text-opacity,1))}.checkbox-label{display:flex;cursor:pointer;align-items:center;gap:.5rem;font-weight:400}.checkbox-label input[type=checkbox]{height:18px;width:18px;cursor:pointer}@media (max-width:480px){.region-grid{grid-template-columns:repeat(2,1fr);gap:.625rem}.region-card{padding:.75rem}.region-name{font-size:.875rem;line-height:1.25rem}.region-info{flex-direction:column;gap:.375rem}.btn-icon{height:2rem;width:2rem;font-size:.75rem;line-height:1rem}}.routes-table{width:100%}.routes-table td,.routes-table th{white-space:nowrap;padding:.5rem .625rem;vertical-align:middle}.routes-table .col-no{width:50px;text-align:center;--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.routes-table .col-region{width:auto}.routes-table .col-arrow{width:50px;padding:.5rem 5px;text-align:center}.routes-table .col-fare,.routes-table .col-status{width:70px;text-align:center}.routes-table .col-action{width:100px;text-align:center}.arrow-icon{height:1.75rem;width:1.75rem;align-items:center;border-radius:9999px;--tw-bg-opacity:1;background-color:rgb(226 232 240/var(--tw-bg-opacity,1));font-size:.75rem;line-height:1rem;font-weight:600;--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.arrow-icon,.btn-group-inline{display:inline-flex;justify-content:center}.btn-group-inline{gap:.25rem}.empty-cell{text-align:center;--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1));padding:30px!important}.pagination-wrapper{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.625rem;border-top-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));padding:.75rem 15px}.pagination{display:flex;gap:.25rem}.page-link{display:inline-flex;height:2rem;min-width:32px;align-items:center;justify-content:center;border-radius:.375rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));padding-left:.5rem;padding-right:.5rem;font-size:13px;--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1));text-decoration-line:none;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.page-link:hover{border-color:rgb(203 213 225/var(--tw-border-opacity,1));background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.page-link.active,.page-link:hover{--tw-border-opacity:1;--tw-bg-opacity:1}.page-link.active{border-color:rgb(102 126 234/var(--tw-border-opacity,1));background-color:rgb(102 126 234/var(--tw-bg-opacity,1));font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.page-info{font-size:13px;--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}@media (max-width:768px){.routes-table .col-no{display:none}.routes-table .col-arrow{width:2.5rem}.arrow-icon{height:1.5rem;width:1.5rem;font-size:11px}.routes-table td,.routes-table th{padding:.5rem .375rem;font-size:13px}.btn-group-inline{flex-direction:column;gap:3px}.btn-group-inline .btn{padding:.25rem .5rem}}.section-card{margin-bottom:1.25rem}.section-card .card-header{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.section-number{margin-right:.5rem;display:inline-flex;height:26px;width:26px;align-items:center;justify-content:center;border-radius:9999px;--tw-bg-opacity:1;background-color:rgb(102 126 234/var(--tw-bg-opacity,1));font-size:13px;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.rules-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.rule-group{border-radius:.5rem;--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1));padding:15px}.rule-group h5{margin-bottom:.75rem;white-space:nowrap;font-size:13px;--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.rule-group label{margin-bottom:.5rem;display:flex;cursor:pointer;align-items:center;gap:.5rem;font-size:.75rem;line-height:1rem}.rule-group label:last-child{margin-bottom:0}.field-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.5rem}.field-item{display:flex;cursor:pointer;align-items:center;gap:.375rem;border-radius:.375rem;--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1));padding:.5rem .625rem;font-size:.75rem;line-height:1rem}.field-item:hover{background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.field-item:hover,.preview-box{--tw-bg-opacity:1}.preview-box{border-radius:.5rem;background-color:rgb(30 41 59/var(--tw-bg-opacity,1));padding:15px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;line-height:1rem;line-height:1.625;--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1));white-space:pre-wrap}.tab-buttons{margin-bottom:15px;display:flex;flex-wrap:wrap;gap:5px}.tab-btn{cursor:pointer;border-radius:.375rem;border-width:1px;--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));padding:.5rem .875rem;font-size:.75rem;line-height:1rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.tab-btn:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.tab-btn.active{--tw-border-opacity:1;border-color:rgb(102 126 234/var(--tw-border-opacity,1));--tw-bg-opacity:1;background-color:rgb(102 126 234/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.tab-content{display:none}.tab-content.active{display:block}.test-form-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.625rem}.test-form-row .form-group{margin-bottom:0;min-width:150px;flex:1 1 0%}.test-form-row .form-group label{margin-bottom:.25rem;display:block;font-size:.75rem;line-height:1rem}.company-option-inactive{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}@media (max-width:992px){.rules-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.field-grid{grid-template-columns:1fr 1fr}.test-form-row{flex-direction:column}.test-form-row .form-group{width:100%}}@media (max-width:576px){.field-grid,.rules-grid{grid-template-columns:1fr}}.dd-modal{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.5);align-items:center;justify-content:center;padding:15px}.dd-modal.show{display:flex}.dd-modal-dialog{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3)}.dd-modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid #e5e7eb;position:sticky;top:0;background:#fff;z-index:1;border-radius:12px 12px 0 0}.dd-modal-title{font-size:15px;font-weight:600;color:#111827;margin:0}.dd-modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0 4px;line-height:1}.dd-modal-body{padding:20px;overflow-y:auto;flex:1}.dd-modal-footer{padding:10px 20px;border-top:1px solid #e5e7eb;text-align:right;background:#fff;border-radius:0 0 12px 12px}.dd-status-bar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.dd-status-bar h4{margin:0;font-size:14px;font-weight:600;color:#111827}.dd-section{margin-bottom:16px;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.dd-section-head{font-size:12px;font-weight:600;letter-spacing:.03em;padding:8px 14px;display:flex;align-items:center;gap:6px}.dd-section-body{padding:10px 14px;background:#fff}.dd-section.sec-info .dd-section-head{background:#eef2ff;color:#4338ca}.dd-section.sec-pickup .dd-section-head{background:#ecfdf5;color:#047857}.dd-section.sec-delivery .dd-section-head{background:#fffbeb;color:#b45309}.dd-section.sec-cargo .dd-section-head{background:#f0f9ff;color:#0369a1}.dd-section.sec-dispatch .dd-section-head{background:#fdf2f8;color:#be185d}.dd-section.sec-freight .dd-section-head{background:#eff6ff;color:#1d4ed8}.dd-section.sec-remark .dd-section-head{background:#f5f3ff;color:#6d28d9}.dd-section.sec-cancel .dd-section-head{background:#fef2f2;color:#b91c1c}.dd-section.sec-history .dd-section-head{background:#f8fafc;color:#475569}.dd-row{display:flex;align-items:baseline;padding:5px 0;font-size:13px;border-bottom:1px solid #f3f4f6;gap:8px}.dd-row:last-child{border-bottom:none}.dd-lbl{color:#6b7280;flex-shrink:0;min-width:70px}.dd-val{font-weight:500;color:#1f2937;text-align:left;word-break:break-all;flex:1}.dd-subtitle{font-size:11px;font-weight:600;color:#64748b;margin:8px 0 4px;padding:3px 6px;background:#f8fafc;border-radius:3px;display:inline-block}.dd-empty{color:#9ca3af;font-size:12px;padding:8px 0;text-align:center}.dd-badge{display:inline-block;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:500}.dd-badge-primary{background:#dbeafe;color:#1e40af}.dd-badge-success{background:#d1fae5;color:#065f46}.dd-badge-warning{background:#fef3c7;color:#92400e}.dd-badge-danger{background:#fee2e2;color:#991b1b}.dd-badge-secondary{background:#f3f4f6;color:#4b5563}.dd-badge-info{background:#e0f2fe;color:#0369a1}.dd-hist{font-size:12px;padding:5px 0;border-bottom:1px solid #f0f0f0}.dd-hist:last-child{border-bottom:none}.dd-grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 15px}.dd-grid2.full{grid-template-columns:1fr}@media(max-width:480px){.dd-grid2{grid-template-columns:1fr}}.items-container{background:#fff;border-radius:8px;border:1px solid #e2e8f0}.vehicle-item{border-bottom:1px solid #e2e8f0}.vehicle-item:last-child{border-bottom:none}.vehicle-header{display:flex;align-items:center;padding:12px 15px;cursor:pointer;transition:background .2s;gap:10px}.vehicle-header:hover{background:#f8fafc}.vehicle-header.selected{background:#eff6ff;border-left:3px solid #3b82f6}.vehicle-toggle{width:20px;color:#64748b;transition:transform .2s}.vehicle-toggle.open{transform:rotate(90deg)}.vehicle-name{flex:1;font-weight:600;font-size:14px}.vehicle-count{font-size:11px;color:#64748b}.vehicle-actions{display:flex;gap:5px}.part-names-area{display:none;background:#f8fafc;border-top:1px solid #e2e8f0;padding:0}.part-names-area.show{display:block}.part-name-item{padding:10px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;margin:0 15px 8px;cursor:pointer;transition:all .2s}.part-name-item:first-child{margin-top:12px}.part-name-item:hover{border-color:#3b82f6}.part-name-item.selected{background:#dbeafe;border-color:#3b82f6}.part-name-header{display:flex;align-items:center;gap:10px}.part-name-badge{background:#dbeafe;color:#1e40af;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600}.part-name-text{flex:1;font-weight:500;font-size:13px}.part-numbers-area{display:none;background:#f1f5f9;margin:8px 0 0 20px;padding:10px;border-radius:6px;border-left:3px solid #10b981}.part-numbers-area.show{display:block}.part-number-item{background:#fff;border:1px solid #d1d5db;border-radius:4px;padding:8px 10px;margin-bottom:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;flex-wrap:wrap;gap:8px}.part-number-item:hover{border-color:#10b981}.part-number-item.selected{background:#dcfce7;border-color:#10b981}.part-number-badge{background:#dcfce7;color:#166534;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600}.part-number-text{font-size:12px;margin-left:8px}.processes-area{display:none;background:#fefce8;margin:6px 0 0 15px;padding:8px;border-radius:4px;border-left:3px solid #f59e0b;width:100%}.processes-area.show{display:block}.process-item{background:#fff;border:1px solid #fcd34d;border-radius:4px;padding:6px 10px;margin-bottom:4px;display:flex;align-items:center;gap:8px;font-size:12px;flex-wrap:wrap}.process-badge{background:#fef3c7;color:#92400e;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600}.process-info{flex:1;color:#64748b;font-size:11px}.inline-add{display:flex;gap:8px;padding:10px 15px;background:#f8fafc;border-top:1px solid #e2e8f0;align-items:center;flex-wrap:wrap}.inline-add input{flex:1;min-width:120px;padding:8px 10px;font-size:13px}.inline-add .btn{white-space:nowrap}.inline-add-small{display:flex;gap:6px;margin-top:8px;align-items:center;flex-wrap:wrap}.inline-add-small input{flex:1;min-width:80px;padding:6px 8px;font-size:12px}.inline-add-small .btn{padding:6px 10px;font-size:11px}.inline-message{padding:8px 12px;border-radius:4px;margin:8px 15px;font-size:12px;display:none}.inline-message.success{background:#dcfce7;color:#166534;display:block}.inline-message.error{background:#fee2e2;color:#991b1b;display:block}.btn-group-sm{display:flex;gap:4px}.pagination-wrapper{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-top:1px solid #e2e8f0;flex-wrap:wrap;gap:10px}.pagination{gap:4px}.page-link{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;border:1px solid #e2e8f0;border-radius:6px;text-decoration:none;color:#475569;font-size:13px;transition:all .2s}.page-link:hover{background:#f1f5f9;border-color:#cbd5e1}.page-link.active{background:#667eea;border-color:#667eea;color:#fff;font-weight:600}.page-info{font-size:13px;color:#64748b}@media (max-width:768px){.vehicle-header{padding:10px 12px}.vehicle-actions{flex-wrap:wrap}.part-name-item,.part-number-item{margin-left:10px;margin-right:10px}.inline-add{flex-direction:column}.inline-add .btn,.inline-add input{width:100%}.inline-add-small{flex-direction:column}.inline-add-small input{width:100%}.part-number-item{flex-direction:column;align-items:flex-start}.part-number-item .btn-group-sm{margin-left:0;margin-top:8px}.process-item{flex-direction:column;align-items:flex-start;gap:4px}.processes-area{margin-left:5px}.part-numbers-area{margin-left:10px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;background:#f4f6f9;min-height:100vh;font-size:14px;line-height:1.5}.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;z-index:1000;overflow-y:auto;transition:transform .3s ease}.sidebar-header{padding:25px 20px;border-bottom:1px solid hsla(0,0%,100%,.1);display:flex;justify-content:space-between;align-items:center}.sidebar-logo{font-size:18px;font-weight:700;color:#d3216e}.sidebar-subtitle{font-size:12px;color:hsla(0,0%,100%,.6);margin-top:5px}.sidebar-close{display:none;background:none;border:none;color:#fff;font-size:24px;cursor:pointer}.sidebar-menu{padding:15px 0}.menu-section{padding:10px 20px 5px;font-size:11px;color:hsla(0,0%,100%,.4);text-transform:uppercase;letter-spacing:.5px}.menu-item{display:flex;align-items:center;padding:12px 20px;color:hsla(0,0%,100%,.7);text-decoration:none;transition:all .2s;border-left:3px solid transparent}.menu-item:hover{background:hsla(0,0%,100%,.05);color:#fff}.menu-item.active{background:rgba(102,126,234,.2);color:#667eea;border-left-color:#667eea}.menu-item i{width:20px;margin-right:12px;font-size:14px}.main-content{margin-left:260px;min-height:100vh;transition:margin-left .3s ease}.top-header{background:#fff;padding:15px 20px;box-shadow:0 1px 3px rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center;gap:15px;position:sticky;top:0;z-index:100}.menu-toggle{display:none;background:none;border:none;font-size:20px;cursor:pointer;color:#64748b;padding:5px}.page-title{font-size:18px;font-weight:600;color:#1e293b}.user-menu{display:flex;align-items:center;gap:15px}.user-name{font-size:13px;color:#64748b}.btn-logout{background:none;border:none;cursor:pointer;color:#64748b;text-decoration:none;font-size:14px;padding:5px}.btn-logout:hover{color:#ef4444}.content-area{padding:20px}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999}.sidebar-overlay.show{display:block}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar-close{display:block}.main-content{margin-left:0}.menu-toggle{display:block}}@media (max-width:768px){.content-area{padding:15px}}.card{background:#fff;border-radius:10px;box-shadow:0 1px 3px rgba(0,0,0,.1);margin-bottom:20px;overflow:hidden}.card-header{padding:16px 20px;border-bottom:1px solid #e2e8f0;font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.card-body{padding:20px}.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse}.data-table td,.data-table th{padding:12px 15px;text-align:left;border-bottom:1px solid #e2e8f0;font-size:13px}.data-table th{font-weight:600;color:#475569;white-space:nowrap}.data-table th,.data-table tr:hover{background:#f8fafc}.text-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:13px;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:all .2s;font-family:inherit;white-space:nowrap}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a6fd6}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}.btn-secondary{background:#64748b;color:#fff}.btn-secondary:hover{background:#475569}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-info{background:#3b82f6;color:#fff}.btn-info:hover{background:#2563eb}.btn-sm{padding:6px 12px;font-size:12px}.btn-xs{padding:4px 8px;font-size:11px}.btn-group{display:flex;gap:8px;flex-wrap:wrap}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#374151;font-size:13px}.form-control{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .2s;font-family:inherit}.form-control:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:500}.badge-primary{background:#dbeafe;color:#1e40af}.badge-success{background:#dcfce7;color:#166534}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-secondary{background:#f1f5f9;color:#475569}.badge-info{background:#e0f2fe;color:#075985}.alert{padding:14px 18px;border-radius:8px;margin-bottom:20px;font-size:14px}.alert-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.alert-danger{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.alert-warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.alert-info{background:#e0f2fe;color:#075985;border:1px solid #7dd3fc}.modal{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:2000;align-items:center;justify-content:center;padding:20px}.modal.show{display:flex}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{padding:20px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:18px;color:#1e293b}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#64748b;line-height:1}.modal-body{padding:20px}.modal-footer{padding:15px 20px;border-top:1px solid #e2e8f0;justify-content:flex-end;gap:10px}.filter-area,.modal-footer{display:flex;flex-wrap:wrap}.filter-area{gap:12px;align-items:flex-end;margin-bottom:20px}.filter-area .form-group{margin-bottom:0;min-width:150px}.pagination{display:flex;justify-content:center;gap:5px;margin-top:20px;flex-wrap:wrap;padding:15px}.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid #e2e8f0;text-decoration:none;color:#475569;border-radius:6px;font-size:13px;transition:all .2s}.pagination a:hover{background:#f8fafc;border-color:#667eea;color:#667eea}.pagination .active{background:#667eea;color:#fff;border-color:#667eea}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:15px}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.grid-5{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.detail-section{margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.detail-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-label{font-size:12px;color:#64748b;margin-bottom:4px}.detail-value{font-size:14px;color:#1e293b;font-weight:500}.help-box{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:12px 15px;margin-bottom:20px;font-size:13px;color:#0369a1}.help-box i{margin-right:8px}@media (max-width:768px){.card-header{padding:12px 15px}.card-body{padding:15px}.data-table td,.data-table th{padding:10px 12px;font-size:12px}.grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:repeat(2,1fr);gap:10px}.filter-area{flex-direction:column}.filter-area .form-group{width:100%;min-width:auto}.btn-group{width:100%}.btn-group .btn{flex:1;justify-content:center}.pagination a,.pagination span{min-width:32px;height:32px;font-size:12px}.modal-footer{flex-direction:column}.modal-footer .btn{width:100%;justify-content:center}}.csv-upload-result{position:relative;padding:14px 40px 14px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;line-height:1.6}.csv-result-success{background:#dcfce7;color:#166534;border:1px solid #86efac}.csv-result-warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.csv-result-error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.csv-result-close{position:absolute;top:8px;right:10px;background:none;border:none;font-size:20px;cursor:pointer;opacity:.6;color:inherit}.csv-result-close:hover{opacity:1}.csv-error-list{margin:10px 0 0;padding:8px 0 0 20px;border-top:1px dashed;font-size:12px;opacity:.9}.csv-error-list li{margin-bottom:4px}.csv-error-more{display:block;margin-top:4px;font-style:italic;opacity:.8}.csv-result-container-fallback{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:9999;max-width:500px;width:90%}.import-result{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;line-height:1.5}.import-result.success{background:#dcfce7;color:#166534;border:1px solid #86efac}.import-result.warning{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.import-result.error{background:#fee2e2;color:#991b1b;border:1px solid #fca5a5}.import-result .error-details{margin-top:8px;padding-top:8px;border-top:1px dashed;font-size:12px;opacity:.9}.desktop-table{display:block}.mobile-table{display:none}@media (max-width:991px){.desktop-table{display:none}.mobile-table{display:block}.grid-2{grid-template-columns:1fr}.grid-5{grid-template-columns:repeat(3,1fr)}.filter-area{flex-direction:column;gap:10px}.filter-area .form-group{width:100%;min-width:auto}.filter-area .form-group input,.filter-area .form-group select{width:100%;box-sizing:border-box}.filter-area .btn-group{width:100%;display:flex;gap:8px}.filter-area .btn-group .btn{flex:1;justify-content:center}.data-table .text-ellipsis{max-width:none;white-space:normal;word-break:break-word}}@media (max-width:600px){.grid-5{grid-template-columns:repeat(2,1fr)}}.freight-container{display:flex;gap:10px;height:calc(100vh - 140px);min-height:400px}.routes-panel{width:196px;flex-shrink:0;background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1);display:flex;flex-direction:column;overflow:hidden;max-height:100%}.routes-header{padding:15px;border-bottom:1px solid #e2e8f0;justify-content:space-between;flex-shrink:0}.routes-header,.routes-title{display:flex;align-items:center}.routes-title{gap:8px;font-size:14px;font-weight:600;color:#1e293b}.routes-title i{color:#3b82f6}.routes-header-btns{display:flex;gap:6px;align-items:center}.header-icon-btn{width:28px;height:28px;background:#f1f5f9;color:#64748b;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}.header-icon-btn:hover{background:#e2e8f0;color:#3b82f6}.add-route-btn{width:32px;height:32px;background:#3b82f6;color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .2s}.add-route-btn:hover{background:#2563eb}.routes-search{padding:10px 15px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.routes-search input{width:100%;padding:8px 12px 8px 32px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;background:#f8fafc url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%2394a3b8' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m21 21-6-6m2-5a7 7 0 1 1-14 0 7 7 0 0 1 14 0'/%3E%3C/svg%3E") 8px /16px no-repeat;outline:none}.routes-search input:focus{border-color:#3b82f6}.routes-list{flex:1;overflow-y:auto;padding:8px 0;min-height:0}.route-item{display:flex;align-items:center;padding:0 8px 0 0;border-left:3px solid transparent;transition:all .15s}.route-item:hover{background:#f8fafc}.route-item.selected{background:#eff6ff;border-left-color:#3b82f6}.route-item-content{flex:1;padding:12px 8px 12px 15px;cursor:pointer}.route-delete-btn{width:24px;height:24px;background:transparent;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:11px;opacity:0;transition:all .15s}.route-item:hover .route-delete-btn{opacity:1}.route-delete-btn:hover{background:#fee2e2;color:#ef4444}.route-origin{font-size:11px;color:#64748b;margin-bottom:4px;display:flex;align-items:center;gap:6px}.route-origin:after{content:"→";color:#94a3b8}.route-destination{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:6px}.route-tiers{display:inline-block;padding:3px 8px;background:#e2e8f0;border-radius:4px;font-size:10px;font-weight:600;color:#475569}.route-item.selected .route-tiers{background:#3b82f6;color:#fff}.fare-panel{gap:20px;overflow-y:auto;min-height:0}.empty-state,.fare-panel{flex:1;display:flex;flex-direction:column}.empty-state{align-items:center;justify-content:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1);color:#94a3b8;text-align:center;padding:40px}.empty-state i{font-size:48px;margin-bottom:15px;opacity:.5}.empty-state p{font-size:14px}.empty-state small{font-size:12px;margin-top:5px}.route-details-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:15px;color:#fff;position:relative}.route-badge{display:inline-flex;align-items:center;gap:6px;background:hsla(0,0%,100%,.2);padding:5px 10px;border-radius:15px;font-size:10px;font-weight:500;margin-bottom:12px}.route-display{display:flex;align-items:center;justify-content:center;gap:20px}.route-point{text-align:center}.route-label{font-size:10px;opacity:.8;margin-bottom:5px}.route-name{font-size:18px;font-weight:700}.route-arrow{width:32px;height:32px;background:hsla(0,0%,100%,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}.delete-route-btn{position:absolute;top:15px;right:15px;width:36px;height:36px;background:hsla(0,0%,100%,.15);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;transition:background .2s}.delete-route-btn:hover{background:hsla(0,0%,100%,.25)}.fare-tiers-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.section-header{justify-content:space-between;margin-bottom:20px}.section-header,.section-title{display:flex;align-items:center}.section-title{gap:8px;font-size:14px;font-weight:600;color:#1e293b}.section-title i{color:#3b82f6}.add-tier-btn{display:flex;align-items:center;gap:5px;padding:8px 14px;background:#3b82f6;border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.add-tier-btn:hover{background:#2563eb}.tier-grid{display:grid;grid-template-columns:repeat(4,.9fr);gap:10px}.tier-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:10px;padding:10px;position:relative;transition:all .2s}.tier-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px rgba(59,130,246,.15)}.tier-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.tier-card-number{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:#3b82f6;color:#fff;border-radius:50%;font-size:10px;font-weight:600}.tier-delete-btn{width:24px;height:24px;background:#fee2e2;border:none;border-radius:5px;color:#ef4444;cursor:pointer;font-size:10px;transition:all .2s}.tier-delete-btn:hover{background:#fecaca}.tier-card-body{gap:8px}.tier-card-body,.tier-field{display:flex;flex-direction:column}.tier-field{gap:3px}.tier-field label{font-size:9px;color:#64748b;text-transform:uppercase;font-weight:500}.tier-input-group{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.tier-input-group:focus-within{border-color:#3b82f6;box-shadow:0 0 0 2px rgba(59,130,246,.1)}.tier-input-group i{padding:0 6px;color:#94a3b8;font-size:11px}.tier-input-group input{flex:1;border:none;padding:6px 0;font-size:13px;font-weight:600;color:#1e293b;outline:none;min-width:0}.tier-input-group input.fare-input{color:#3b82f6}.tier-input-group span{padding:0 6px;color:#64748b;font-size:11px;font-weight:500;background:#f8fafc}.tier-empty{grid-column:1/-1;text-align:center;padding:40px 20px;color:#94a3b8}.tier-empty i{font-size:32px;margin-bottom:10px;opacity:.5}.tier-empty p{font-size:13px}.bottom-controls{background:#fff;padding:15px 20px;border-radius:12px;box-shadow:0 1px 3px rgba(0,0,0,.1);display:flex;align-items:center;justify-content:space-between}.status-message{display:flex;align-items:center;gap:8px;font-size:13px}.status-message i{font-size:8px}.status-message.current{color:#10b981}.status-message.modified{color:#f59e0b}.control-buttons{display:flex;gap:10px}.btn-reset{padding:10px 16px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px}.btn-reset:hover{background:#e2e8f0}.btn-save-fare{padding:10px 20px;background:#3b82f6;border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px}.btn-save-fare:hover{background:#2563eb}.fare-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all .2s}.fare-modal.active{opacity:1;visibility:visible}.fare-modal-content{background:#fff;border-radius:12px;width:90%;max-width:400px;box-shadow:0 20px 40px rgba(0,0,0,.2)}.fare-modal-header{padding:20px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.fare-modal-header h3{font-size:16px;font-weight:600;color:#1e293b}.fare-modal-close{width:32px;height:32px;background:none;border:none;font-size:20px;color:#94a3b8;cursor:pointer}.fare-modal-body{padding:20px}.fare-modal-body .form-group{margin-bottom:15px}.fare-modal-body label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.fare-modal-body input,.fare-modal-body select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;outline:none}.fare-modal-body input:focus,.fare-modal-body select:focus{border-color:#3b82f6}.fare-modal-body p{font-size:12px;color:#64748b;margin-top:10px}.fare-modal-footer{padding:15px 20px;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:10px}.fare-modal-footer .btn-cancel{padding:8px 16px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#64748b;font-size:13px;cursor:pointer}.fare-modal-footer .btn-submit{padding:8px 16px;background:#3b82f6;border:none;border-radius:6px;color:#fff;font-size:13px;cursor:pointer}@media (max-width:1200px){.tier-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:900px){.freight-container{flex-direction:column}.routes-panel{width:100%;max-height:300px}.route-display{gap:15px}.route-name{font-size:18px}.tier-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.tier-grid{grid-template-columns:1fr}.bottom-controls{flex-direction:column;gap:15px}.control-buttons{width:100%}.control-buttons button{flex:1;justify-content:center}}.hover\:-translate-y-0\.5:hover{--tw-translate-y:-0.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:shadow-\[0_10px_20px_rgba\(102\2c 126\2c 234\2c 0\.3\)\]:hover{--tw-shadow:0 10px 20px rgba(102,126,234,.3);--tw-shadow-colored:0 10px 20px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\:border-\[\#667eea\]:focus{--tw-border-opacity:1;border-color:rgb(102 126 234/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-4:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-\[\#667eea\]\/10:focus{--tw-ring-color:rgba(102,126,234,.1)}@media (min-width:640px){.sm\:rounded-\[20px\]{border-radius:20px}.sm\:px-\[30px\]{padding-left:30px;padding-right:30px}.sm\:py-10{padding-top:2.5rem;padding-bottom:2.5rem}.sm\:text-\[32px\]{font-size:32px}}.dd-loading-state{text-align:center;padding:40px;color:#64748b}.dd-loading-icon{font-size:24px}.dd-loading-text{margin-top:10px}.dd-error-state{text-align:center;padding:30px;color:#ef4444}.dd-freight-total{color:#1d4ed8}.dd-hist-time{color:#64748b}.dd-hist-remark{color:#64748b;margin-left:12px}.dd-footer-actions{display:flex;justify-content:space-between}
.logout-form-inline{margin:0;padding:0}
.btn-pwd{color:#64748b;text-decoration:none;font-size:14px;padding:5px}.btn-pwd:hover{color:#3b82f6}
.nav-logout-btn{background:none;border:none;color:inherit;cursor:pointer;padding:0;font:inherit;display:flex;flex-direction:column;align-items:center;gap:2px;text-decoration:none}
.topnav-pwd-link{color:#fff}
.topnav-logout-btn{background:none;border:none;color:#fff;cursor:pointer;padding:0}
/* ── z-index 계층 통일 (B2 fix) ── */
.swal2-container{z-index:10050!important}
.confirm-overlay{z-index:3000!important}
.dd-modal.show~.modal.show{z-index:2100}
.adm-cancel-overlay{z-index:2100}
/* ── 역할 전환(Impersonation) 배너 + 드롭다운 ── */
.adm-impersonate-banner{display:flex;align-items:center;gap:10px;padding:8px 20px;background:linear-gradient(90deg,#fbbf24,#f59e0b);color:#78350f;font-size:13px;font-weight:500;position:sticky;top:0;z-index:101;}
.adm-impersonate-banner i{font-size:16px;}
.adm-impersonate-banner span{flex:1;}
.adm-impersonate-back{background:#78350f;color:#fef3c7;border:none;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:5px;white-space:nowrap;}
.adm-impersonate-back:hover{background:#451a03;}
.adm-impersonate-wrap{position:relative;}
.adm-impersonate-btn{border:1px solid #e2e8f0!important;background:#f8fafc!important;color:#475569!important;font-size:12px!important;padding:5px 10px!important;}
.adm-impersonate-btn:hover{background:#e2e8f0!important;}
.adm-imp-label{display:inline;}
.adm-impersonate-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:140px;z-index:200;overflow:hidden;}
.adm-impersonate-dropdown button{display:block;width:100%;text-align:left;padding:10px 16px;border:none;background:none;font-size:13px;color:#334155;cursor:pointer;}
.adm-impersonate-dropdown button:hover{background:#f1f5f9;color:#1e40af;}
@media(max-width:768px){.adm-imp-label{display:none;}.adm-impersonate-banner{padding:6px 12px;font-size:12px;flex-wrap:wrap;}.adm-impersonate-banner span{min-width:0;}}
.dsp-reject-overlay{z-index:2100}
/* ── 공통 Impersonate 플로팅 배너 (IMP2) ── */
.imp-floating-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:8px 16px;display:flex;align-items:center;gap:12px;font-size:13px;font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.2);}
.imp-floating-banner i.fa-user-secret{font-size:16px;}
.imp-floating-banner>span{flex:1;}
.imp-floating-actions{margin-left:auto;display:flex;gap:8px;}
.imp-btn{border:1px solid rgba(255,255,255,.5);background:rgba(255,255,255,.15);color:#fff;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;white-space:nowrap;display:inline-flex;align-items:center;gap:5px;}
.imp-btn:hover{background:rgba(255,255,255,.3);}
.imp-btn-back{background:rgba(255,255,255,.25);font-weight:600;}
.imp-switch-dropdown{position:absolute;top:100%;right:16px;background:#fff;border-radius:6px;box-shadow:0 4px 12px rgba(0,0,0,.15);overflow:hidden;min-width:140px;z-index:10000;}
.imp-switch-dropdown button{display:block;width:100%;padding:10px 16px;border:none;background:none;text-align:left;cursor:pointer;font-size:13px;color:#333;}
.imp-switch-dropdown button:hover{background:#f3f4f6;}
@media(max-width:768px){.imp-floating-banner{padding:6px 12px;font-size:12px;flex-wrap:wrap;gap:8px;}.imp-btn-text{display:none;}.imp-floating-actions{gap:5px;}}
/* ===== 시스템 전환 네비게이션 (Phase 5) ===== */
.system-nav{display:flex;gap:4px;padding:8px 15px;background:#0f172a;border-bottom:1px solid #1e293b;}
.sys-link{color:#94a3b8;text-decoration:none;font-size:12px;padding:4px 10px;border-radius:4px;display:inline-flex;align-items:center;gap:5px;transition:all .2s;}
.sys-link:hover{color:#e2e8f0;background:#1e293b;}
.sys-link.active{color:#fbbf24;background:#1e293b;font-weight:600;}
.sys-link i{font-size:11px;}
/* ===== 로고 이미지 자동 크기 조절 ===== */
.sidebar-logo img{display:block;max-width:180px;max-height:40px;width:auto;height:auto;object-fit:contain;}
.logo img{display:block;max-width:160px;max-height:36px;width:auto;height:auto;object-fit:contain;}
.login-company img{display:block;max-width:250px;max-height:50px;width:auto;height:auto;object-fit:contain;margin:0 auto;}
@media(max-width:768px){.sidebar-logo img{max-width:150px;max-height:34px;}.logo img{max-width:120px;max-height:30px;}}
/* ===== 배차회사 대시보드 — 미배차/수정 깜빡임 ===== */
@keyframes dsp-blink-bg{0%,100%{background-color:transparent}50%{background-color:#fef3c7}}
@keyframes dsp-blink-modified{0%,100%{background-color:transparent}50%{background-color:#fee2e2}}
@keyframes dsp-badge-blink{0%,100%{opacity:1}50%{opacity:.3}}
.dsp-row-pending{animation:dsp-blink-bg 2s ease-in-out infinite}
.dsp-row-modified{animation:dsp-blink-modified 1.5s ease-in-out infinite}
.dsp-blink{animation:dsp-badge-blink 1s ease-in-out infinite}
.dsp-mobile-card.dsp-row-pending{animation:dsp-blink-bg 2s ease-in-out infinite}
.dsp-mobile-card.dsp-row-modified{animation:dsp-blink-modified 1.5s ease-in-out infinite}
/* 관리자 대시보드 — 반려 항목 깜빡임 */
.dsp-blink-rejected{animation:dsp-blink-modified 1.5s ease-in-out infinite;border-radius:8px}