*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#e8eeea;font-family:Inter,Segoe UI,Malgun Gothic,sans-serif}.app-layout{min-height:100vh;display:flex}.main-content{flex:1;min-width:0}.sidebar{color:#e2e8f0;scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;background:linear-gradient(#1a2f23 0%,#2d4a37 100%);border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;width:260px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.sb-brand{border-bottom:1px solid #ffffff14;padding:20px 16px 16px}.sb-logo-block{flex-direction:column;gap:2px;display:flex}.sb-logo-row1,.sb-logo-row2{flex-wrap:wrap;align-items:baseline;gap:5px;display:flex}.sb-logo-woosung,.sb-logo-integrated,.sb-logo-engine{color:#e2e8f0;letter-spacing:-.3px;font-size:15px;font-weight:800}.sb-logo-divider{color:#94a3b8;margin:0 2px;font-size:18px;font-weight:300}.sb-logo-wise{color:#6ee7b7;letter-spacing:-.3px;font-size:16px;font-style:italic;font-weight:800}.sb-logo-sales{color:#fbbf24;letter-spacing:-.3px;font-size:15px;font-weight:800}.sb-quick-stats{border-bottom:1px solid #ffffff14;gap:0;padding:16px 20px;display:flex}.sb-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.sb-stat-value{color:#fff;font-size:20px;font-weight:700}.sb-stat-active{color:#34d399!important}.sb-stat-complete{color:#60a5fa!important}.sb-stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:500}.sb-section{border-bottom:1px solid #ffffff0f}.sb-section-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:14px 20px 10px;display:flex}.sb-section-header:hover{background:#ffffff08}.sb-section-title{text-transform:uppercase;letter-spacing:1.2px;color:#64748b;font-size:10px;font-weight:700}.sb-chevron{color:#475569;font-size:10px;transition:transform .2s}.sb-chevron.collapsed{transform:rotate(-90deg)}.sb-section-body{padding:0 12px 12px}.sb-customer-item{cursor:pointer;border-radius:10px;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;transition:all .2s;display:flex;position:relative}.sb-customer-item:hover{background:#ffffff12}.sb-customer-item.active{background:#3b82f626;box-shadow:inset 0 0 0 1px #3b82f64d}.sb-cust-icon-wrap{color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 8px #0003}.sb-cust-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.sb-cust-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sb-cust-meta{align-items:center;gap:8px;display:flex}.sb-cust-count{color:#64748b;font-size:11px;font-weight:500}.sb-cust-active-dot{background:#34d399;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s infinite pulse-green;box-shadow:0 0 6px #34d39980}@keyframes pulse-green{0%,to{opacity:1}50%{opacity:.5}}.sb-month-item{cursor:pointer;border-radius:8px;margin-bottom:1px;padding:7px 10px;transition:all .2s}.sb-month-item:hover{background:#ffffff0d}.sb-month-item.active{background:#3b82f626;box-shadow:inset 0 0 0 1px #3b82f64d}.sb-month-item.current-month{border-left:2px solid #3b82f6}.sb-month-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.sb-month-label{color:#cbd5e1;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.sb-current-dot{background:#3b82f6;border-radius:50%;width:6px;height:6px;display:inline-block;box-shadow:0 0 6px #3b82f699}.sb-month-count{color:#94a3b8;text-align:right;min-width:20px;font-size:12px;font-weight:700}.sb-month-bar-wrap{align-items:center;gap:8px;display:flex}.sb-month-bar-bg{background:#ffffff14;border-radius:4px;flex:1;height:4px;overflow:hidden}.sb-month-bar-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:4px;height:100%;transition:width .5s}.sb-month-bar-fill.has-delay{background:linear-gradient(90deg,#f59e0b,#f87171)}.sb-month-pct{color:#475569;text-align:right;min-width:28px;font-size:9px;font-weight:600}.sb-card{cursor:pointer;background:#ffffff0a;border:1px solid #ffffff0f;border-radius:10px;padding:10px 12px;transition:all .2s;position:relative}.sb-card:hover{background:#ffffff14;border-color:#ffffff1f;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.sb-card.active{background:#3b82f61f;border-color:#3b82f64d;box-shadow:0 0 0 1px #3b82f633,0 4px 12px #3b82f61a}.sb-card-top{align-items:center;gap:10px;margin-bottom:8px;display:flex}.sb-card-icon{color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:800;display:flex;box-shadow:0 2px 8px #00000040}.sb-card-info{flex:1;min-width:0}.sb-card-name{color:#f1f5f9;letter-spacing:-.2px;font-size:13px;font-weight:700}.sb-card-count{color:#94a3b8;font-size:11px;font-weight:500}.sb-card-meta{gap:4px;margin-top:2px;display:flex}.sb-card-badge{letter-spacing:.3px;border-radius:6px;padding:1px 6px;font-size:9px;font-weight:700}.sb-card-badge.prog{color:#6ee7b7;background:#34d39926}.sb-card-badge.done{color:#93bbfd;background:#60a5fa26}.sb-card-total{color:#e2e8f0;flex-shrink:0;font-size:20px;font-weight:800;line-height:1}.sb-card-bar{align-items:center;gap:6px;display:flex}.sb-card-bar-fill{border-radius:3px;flex-shrink:1;min-width:0;height:3px;transition:width .5s}.sb-card-bar-pct{color:#64748b;flex-shrink:0;font-size:9px;font-weight:700}.sb-card-bar{background:#ffffff0f;border-radius:3px;align-items:center;height:3px;display:flex;position:relative;overflow:visible}.sb-card-bar-fill{border-radius:3px;height:100%;position:absolute;top:0;left:0}.sb-card-bar-pct{position:absolute;top:-10px;right:0}.sb-card-months{border-left:2px solid #3b82f633;margin-top:2px;margin-left:18px;padding:4px 0 2px 12px}.update-banner{z-index:9999;pointer-events:none;justify-content:center;padding:12px 20px;animation:.4s ease-out bannerSlide;display:flex;position:fixed;top:0;left:0;right:0}@keyframes bannerSlide{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.update-banner-inner{pointer-events:auto;color:#fff;cursor:pointer;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:12px;align-items:center;gap:12px;padding:12px 24px;transition:transform .2s;display:flex;box-shadow:0 8px 32px #3b82f666,0 0 0 1px #ffffff1a}.update-banner-inner:hover{transform:scale(1.02)}.update-banner-icon{font-size:20px;animation:2s linear infinite spin}.update-banner-text{font-size:14px;font-weight:600}.update-banner-btn{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:8px;padding:6px 16px;font-size:12px;font-weight:700;transition:all .2s}.update-banner-btn:hover{background:#ffffff4d}.sb-ploc-tab{cursor:pointer;border-top:1px solid #ffffff0f;align-items:center;gap:10px;padding:12px 16px;transition:all .2s;display:flex}.sb-ploc-tab:hover{background:#ffffff0d}.sb-footer{color:#475569;border-top:1px solid #ffffff0f;align-items:center;gap:8px;margin-top:auto;padding:16px 20px;font-size:11px;display:flex}.sb-footer-dot{background:#34d399;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse-green}.header{color:#fff;background:linear-gradient(135deg,#1a2f23,#2d4a37);justify-content:space-between;align-items:center;padding:20px 32px;display:flex;box-shadow:0 2px 12px #0000001a}.header h1{letter-spacing:-.3px;font-size:20px;font-weight:700}.header .date{opacity:.7;margin-top:2px;font-size:13px}.header-actions{flex-wrap:wrap;gap:10px;display:flex}.summary{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;padding:20px 32px;display:grid}.card{background:#fff;border-radius:12px;padding:16px 18px;transition:transform .15s,box-shadow .15s;position:relative;overflow:hidden;box-shadow:0 1px 4px #0000000f}.card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.card.blue:before{background:#3d5a47}.card.green:before{background:#22c55e}.card.purple:before{background:#6b8f71}.card.red:before{background:#dc2626}.card.crimson:before{background:#be123c}.card.orange:before{background:#f97316}.card.teal:before{background:#14b8a6}.card .label{color:#94a3b8;text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;font-size:11px;font-weight:600}.card .value{font-size:24px;font-weight:700}.card.blue .value{color:#3d5a47}.card.green .value{color:#22c55e}.card.purple .value{color:#6b8f71}.card.red .value{color:#dc2626}.card.crimson .value{color:#be123c}.card.orange .value{color:#f97316}.card.teal .value{color:#14b8a6}.vs{color:#94a3b8;font-size:13px;font-weight:400}.card .sub-info{color:#94a3b8;margin-top:4px;font-size:11px}.card .sub-info strong{color:#475569}.progress-mini{align-items:center;gap:6px;display:flex}.progress-mini-bar{background:#e2e8f0;border-radius:3px;flex:1;min-width:50px;height:6px;overflow:hidden}.progress-mini-fill{border-radius:3px;height:100%;transition:width .3s}.progress-mini-pct{text-align:right;min-width:32px;font-size:10px;font-weight:700}.filter-presets{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-preset-btn{cursor:pointer;color:#475569;white-space:nowrap;background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:4px 12px;font-size:11px;font-weight:600;transition:all .2s}.filter-preset-btn:hover{color:#3b82f6;background:#eff6ff;border-color:#3b82f6}.filter-preset-btn.active{color:#fff;background:#3b82f6;border-color:#3b82f6}.filter-preset-del{cursor:pointer;opacity:.6;margin-left:4px;font-size:10px}.filter-preset-del:hover{opacity:1}.filter-save-btn{cursor:pointer;color:#94a3b8;background:0 0;border:1px dashed #94a3b8;border-radius:16px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .2s}.filter-save-btn:hover{color:#3b82f6;border-color:#3b82f6}.tabs{border-bottom:2px solid #c5d5ca;gap:0;margin-top:4px;padding:0 32px;display:flex}.tab{cursor:pointer;color:#94a3b8;-webkit-user-select:none;user-select:none;border-bottom:3px solid #0000;padding:12px 20px;font-size:13px;font-weight:600;transition:all .2s}.tab:hover{color:#1a2f23}.tab.active{color:#1a2f23;border-bottom-color:#3d5a47}.tab .cnt{color:#475569;background:#f1f5f9;border-radius:10px;margin-left:4px;padding:1px 7px;font-size:11px;font-weight:600}.tab.active .cnt{color:#3b82f6;background:#dbeafe}.controls{flex-wrap:wrap;align-items:center;gap:10px;padding:14px 32px;display:flex}.controls input,.controls select{background:#fff;border:1px solid #e2e8f0;border-radius:8px;outline:none;padding:8px 12px;font-size:13px;transition:border-color .2s,box-shadow .2s}.controls input:focus,.controls select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-input{width:260px}.btn{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:#3b82f6}.btn-primary:hover{background:#2563eb}.btn-primary:disabled{cursor:not-allowed;background:#94a3b8}.btn-outline{color:#3b82f6;background:#fff;border:1px solid #3b82f6}.btn-outline:hover{background:#eff6ff}.btn-danger{color:#ef4444;background:#fff;border:1px solid #ef4444}.btn-danger:hover{background:#fef2f2}.btn-teal{color:#fff;background:#14b8a6}.btn-teal:hover{background:#0d9488}.btn-sm{padding:4px 10px;font-size:11px}.btn-header{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff14;border:1px solid #fff3}.btn-header:hover{background:#ffffff26}.btn-header-excel{color:#fff;background:linear-gradient(135deg,#16a34a,#22c55e);font-weight:700}.btn-header-excel:hover{background:linear-gradient(135deg,#15803d,#16a34a)}.btn-header-solid{color:#fff;background:#3b82f6;font-weight:700}.btn-header-solid:hover{background:#2563eb}.table-outer{position:relative}.table-wrap{padding:0 32px;overflow:auto visible}.table-wrap::-webkit-scrollbar{display:none}.table-scroll-bar{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fffffff2;border-top:1px solid #e2e8f0;margin:0 32px;position:sticky;bottom:0;overflow:auto hidden}.table-scroll-bar::-webkit-scrollbar{height:14px}.table-scroll-bar::-webkit-scrollbar-track{background:#f1f5f9;border-radius:7px;margin:2px 0}.table-scroll-bar::-webkit-scrollbar-thumb{background:linear-gradient(#6b8f71,#3d5a47);border:3px solid #f1f5f9;border-radius:7px;min-width:60px}.table-scroll-bar::-webkit-scrollbar-thumb:hover{background:linear-gradient(#3d5a47,#2d4a37)}.table-scroll-bar-inner{height:1px}.table-wrap-bottom-pad{padding-bottom:16px}table{border-collapse:collapse;background:#fff;border-radius:12px;width:100%;min-width:1700px;overflow:hidden;box-shadow:0 1px 4px #0000000f}thead{z-index:10;background:#3d5a47;position:sticky;top:0}th{text-align:left;color:#e8f0eb;text-transform:uppercase;letter-spacing:.4px;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;background:#3d5a47;border-bottom:2px solid #2d4a37;padding:11px 12px;font-size:11px;font-weight:700}th:hover{background:#4a6b53}th .si{opacity:.4;margin-left:3px;font-size:10px}th.sorted .si{opacity:1}td{white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:10px 12px;font-size:13px}tr:hover td{background:#f8fafc}tr.overdue td{background:#fef2f2}.text-right{text-align:right}.text-center{text-align:center}.font-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px}.font-bold{font-weight:600}.material-code-cell{color:#1e293b;letter-spacing:.5px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:3px 8px;font-family:SF Mono,Fira Code,monospace;font-size:12.5px;font-weight:600;display:inline-block}.text-ellipsis{text-overflow:ellipsis;white-space:nowrap;cursor:default;max-width:160px;position:relative;overflow:hidden}.text-ellipsis-wrap{max-width:160px;display:inline-block;position:relative}.text-ellipsis-wrap .tooltip-text{visibility:hidden;opacity:0;color:#fff;white-space:normal;word-break:break-all;z-index:100;pointer-events:none;background:#1e293b;border-radius:8px;min-width:200px;max-width:360px;padding:8px 12px;font-size:12px;line-height:1.5;transition:opacity .15s,visibility .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0003}.text-ellipsis-wrap .tooltip-text:after{content:"";border:6px solid #0000;border-top-color:#1e293b;position:absolute;top:100%;left:50%;transform:translate(-50%)}.text-ellipsis-wrap:hover .tooltip-text{visibility:visible;opacity:1}.badge{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-block}.badge-inprogress{color:#2563eb;background:#eff6ff}.badge-completed{color:#16a34a;background:#f0fdf4}.badge-waiting{color:#ea580c;background:#fff7ed}.badge-shipped{color:#0d9488;background:#f0fdfa}.badge-delayed{color:#dc2626;background:#fef2f2}.badge-yes{color:#16a34a;background:#f0fdf4}.badge-no{color:#94a3b8;background:#f8fafc}.grade-badge{letter-spacing:.3px;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.grade-a{color:#fff;background:#dc2626}.grade-b{color:#fff;background:#f97316}.grade-c{color:#1a1a1a;background:#eab308}.grade-d{color:#fff;background:#6b7280}.grade-q{color:#fff;background:#3b82f6}.td-project-desc{white-space:nowrap;text-overflow:ellipsis;cursor:help;max-width:140px;overflow:hidden}.td-product-name{white-space:normal;min-width:120px;max-width:200px;line-height:1.4}.td-date{letter-spacing:-.2px;min-width:100px;font-size:13px}.delay-reason-cell{text-align:center;position:relative}.delay-reason-icon-btn{cursor:pointer;color:#cbd5e1;background:0 0;border:1px solid #e2e8f0;border-radius:6px;padding:3px 7px;font-size:12px;transition:all .2s;position:relative}.delay-reason-icon-btn:hover{color:#dc2626;background:#fef2f2;border-color:#f87171}.delay-reason-icon-btn.has-reason{color:#dc2626;background:#fef2f2;border-color:#fca5a5}.delay-reason-icon-btn.has-reason .dr-dot{display:block}.dr-dot{background:#dc2626;border-radius:50%;width:8px;height:8px;display:none;position:absolute;top:-3px;right:-3px}.change-requester-wrap{border:1px solid #e2e8f0;border-radius:8px;gap:0;margin-top:8px;display:flex;overflow:hidden}.change-requester-btn{cursor:pointer;color:#64748b;text-align:center;background:#f8fafc;border:none;flex:1;padding:8px 12px;font-size:13px;font-weight:600;transition:all .2s}.change-requester-btn.active-customer{color:#fff;background:#3b82f6}.change-requester-btn.active-internal{color:#fff;background:#f97316}.change-requester-btn:hover:not(.active-customer):not(.active-internal){background:#e2e8f0}.duedate-excel-modal{width:880px;max-width:95vw}.duedate-match-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:12px;padding:8px 12px;font-size:13px;display:flex}.duedate-match-row:hover{background:#f8fafc}.duedate-match-row .old-date{color:#94a3b8;text-decoration:line-through}.duedate-match-row .arrow{color:#3b82f6;font-weight:700}.duedate-match-row .new-date{color:#16a34a;font-weight:700}.duedate-match-row .no-match{color:#ef4444;font-size:12px}.duedate-summary-bar{flex-wrap:wrap;gap:10px;margin-bottom:14px;display:flex}.duedate-summary-badge{border-radius:16px;padding:4px 14px;font-size:12px;font-weight:600}.duedate-summary-matched{color:#1d4ed8;background:#dbeafe}.duedate-summary-notfound{color:#dc2626;background:#fef2f2}.duedate-summary-nochange{color:#94a3b8;background:#f8fafc}.customer-badge{color:#6d28d9;white-space:nowrap;background:#f5f3ff;border-radius:12px;padding:3px 8px;font-size:11px;font-weight:600}.status-flow{align-items:center;gap:2px;margin-bottom:4px;display:flex}.status-flow .step{background:#e2e8f0;border-radius:2px;width:28px;height:4px}.status-flow .step.done{background:#22c55e}.status-flow .step.current{background:#3b82f6}.status-dot{border-radius:50%;width:14px;height:14px;display:inline-block;box-shadow:0 0 8px #00000026}.status-dot.green{background:#22c55e;box-shadow:0 0 8px #22c55e80}.status-dot.orange{background:#f97316;animation:2s infinite pulse-orange;box-shadow:0 0 8px #f9731666}.status-dot.blue{background:#3b82f6;box-shadow:0 0 8px #3b82f680}@keyframes pulse-orange{0%,to{box-shadow:0 0 8px #f9731666}50%{box-shadow:0 0 14px #f97316b3}}.badge-delivered{color:#1d4ed8;background:#dbeafe}.btn-deliver{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2563eb,#3b82f6);border:none;border-radius:6px;padding:4px 12px;font-size:11px;font-weight:700;transition:all .2s}.btn-deliver:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);transform:translateY(-1px);box-shadow:0 2px 6px #2563eb4d}.delivered-badge{color:#2563eb;white-space:nowrap;background:#dbeafe;border-radius:10px;padding:3px 8px;font-size:10px;font-weight:600}.ship-date-label{color:#14b8a6;margin-top:2px;font-size:10px}.due-change-badge-btn{color:#dc2626;cursor:pointer;white-space:nowrap;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:2px;padding:2px 8px;font-size:10px;font-weight:700;transition:all .2s;display:inline-flex}.due-change-badge-btn:hover{background:#fee2e2;border-color:#f87171}.single-duedate-modal{width:440px;max-width:90vw}.due-date-change-notice{color:#b45309;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:13px}.due-date-change-notice s{color:#94a3b8}.due-date-change-notice strong{color:#1e293b}.customer-input-group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.customer-input-group select{flex:1}.add-customer-row{gap:6px;width:100%;margin-top:6px;display:flex}.add-customer-row input{flex:1}.memo-btn{cursor:pointer;background:0 0;border:1px solid #e2e8f0;border-radius:6px;padding:3px 8px;font-size:12px;transition:all .2s;position:relative}.memo-btn:hover{background:#eff6ff;border-color:#3b82f6}.memo-btn .dot{background:#ef4444;border-radius:50%;width:8px;height:8px;display:none;position:absolute;top:-3px;right:-3px}.memo-btn.has-memo .dot{display:block}.memo-btn-red{cursor:pointer;color:#94a3b8;background:0 0;border:1px solid #fecaca;border-radius:6px;padding:3px 8px;font-size:12px;transition:all .2s;position:relative}.memo-btn-red:hover{background:#fef2f2;border-color:#ef4444}.memo-btn-red.has-memo{color:#dc2626;background:#fef2f2;border-color:#f87171;font-weight:600}.memo-btn-red .dot{background:#ef4444;border-radius:50%;width:8px;height:8px;display:none;position:absolute;top:-3px;right:-3px}.memo-btn-red.has-memo .dot{display:block}.inline-date-input{color:#0f766e;background:#f0fdfa;border:1.5px solid #14b8a6;border-radius:6px;outline:none;width:120px;padding:3px 6px;font-family:inherit;font-size:12px}.inspection-date-cell{cursor:pointer;border-radius:4px;padding:2px 4px;transition:all .15s}.inspection-date-cell:hover{background:#f0fdfa}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a80;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal{background:#fff;border-radius:16px;width:580px;max-width:95vw;max-height:88vh;padding:28px;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal h2{color:#1e293b;margin-bottom:20px;font-size:18px}.modal .fg{margin-bottom:12px}.modal label{color:#64748b;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.modal label .hint{color:#94a3b8;font-size:11px;font-weight:400}.modal input,.modal select,.modal textarea{border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .2s,box-shadow .2s}.modal input:focus,.modal select:focus,.modal textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal textarea{resize:vertical;min-height:60px}.modal .btn-group{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.history-modal{width:680px}.item-info{background:#f8fafc;border-radius:10px;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:18px;padding:14px 16px;font-size:13px;display:grid}.item-info .ik{color:#94a3b8;font-size:11px}.item-info .iv{color:#1e293b;font-weight:600}.timeline{padding-left:24px;position:relative}.timeline:before{content:"";background:#e2e8f0;width:2px;position:absolute;top:0;bottom:0;left:8px}.tl-entry{margin-bottom:16px;position:relative}.tl-entry:before{content:"";z-index:1;background:#fff;border:2px solid #3b82f6;border-radius:50%;width:12px;height:12px;position:absolute;top:4px;left:-20px}.tl-entry.cat-outsource:before{border-color:#f97316}.tl-entry.cat-receive:before{border-color:#22c55e}.tl-entry.cat-inspect:before{border-color:#8b5cf6}.tl-entry.cat-ship:before{border-color:#14b8a6}.tl-entry.cat-etc:before{border-color:#94a3b8}.tl-date{color:#94a3b8;margin-bottom:2px;font-size:11px}.tl-cat{border-radius:10px;margin-bottom:4px;padding:1px 8px;font-size:10px;font-weight:700;display:inline-block}.cat-outsource .tl-cat{color:#ea580c;background:#fff7ed}.cat-receive .tl-cat{color:#16a34a;background:#f0fdf4}.cat-inspect .tl-cat{color:#7c3aed;background:#faf5ff}.cat-ship .tl-cat{color:#0d9488;background:#f0fdfa}.cat-etc .tl-cat{color:#64748b;background:#f8fafc}.tl-content{white-space:pre-wrap;background:#f8fafc;border:1px solid #f1f5f9;border-radius:8px;padding:8px 12px;font-size:13px;line-height:1.5}.tl-writer{color:#cbd5e1;text-align:right;margin-top:3px;font-size:11px}.tl-actions{position:absolute;top:0;right:0}.tl-actions button{cursor:pointer;color:#cbd5e1;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:12px}.tl-actions button:hover{color:#475569;background:#f1f5f9}.add-history{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;margin-top:16px;padding:16px}.add-history h3{color:#1e293b;margin-bottom:10px;font-size:13px}.add-history .row{gap:10px;margin-bottom:8px;display:flex}.add-history .row>div{flex:1}.add-history input,.add-history select,.add-history textarea{border:1px solid #e2e8f0;border-radius:6px;outline:none;width:100%;padding:8px 10px;font-family:inherit;font-size:12px}.add-history textarea{resize:vertical;min-height:50px}.add-history label{color:#64748b;margin-bottom:3px;font-size:11px;display:block}.batch-list{border:1px solid #e2e8f0;border-radius:8px;max-height:200px;margin-bottom:8px;overflow-y:auto}.action-btns{flex-wrap:nowrap;align-items:center;gap:4px;display:flex}.btn-ship{color:#fff;cursor:pointer;background:linear-gradient(135deg,#0d9488,#14b8a6);border:none;border-radius:6px;padding:4px 12px;font-size:11px;font-weight:700;transition:all .2s}.btn-ship:hover{background:linear-gradient(135deg,#0f766e,#0d9488);transform:translateY(-1px);box-shadow:0 2px 6px #0d94884d}.btn-ship.active{background:linear-gradient(135deg,#0f766e,#0d9488);box-shadow:0 0 0 2px #14b8a666}.ship-done-badge{color:#0d9488;white-space:nowrap;background:#f0fdfa;border-radius:10px;padding:3px 8px;font-size:10px;font-weight:600}.ship-active-row td{background:#f0fdfa!important}.ship-input-row td{background:#f0fdfa!important;border-bottom:2px solid #14b8a6!important;padding:0!important}.ship-inline{justify-content:flex-end;align-items:center;gap:16px;padding:10px 20px;animation:.15s ease-out slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.ship-inline-row{align-items:center;gap:16px;display:flex}.ship-inline-field{align-items:center;gap:6px;display:flex}.ship-inline-field label{color:#0f766e;white-space:nowrap;font-size:12px;font-weight:600}.ship-inline-input{background:#fff;border:1.5px solid #99f6e4;border-radius:8px;outline:none;width:160px;padding:6px 10px;font-family:inherit;font-size:13px;transition:border-color .2s,box-shadow .2s}.ship-inline-input:focus{border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a626}.ship-inline-input[type=number]{text-align:right;width:80px}.ship-inline-max{color:#94a3b8;font-size:11px;font-weight:500}.ship-inline-actions{gap:6px;display:flex}.excel-modal{width:820px;max-width:95vw}.excel-upload-zone{text-align:center;cursor:pointer;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:40px 24px;transition:all .2s;display:flex}.excel-upload-zone:hover{background:#f0fdf4;border-color:#22c55e}.excel-upload-text{flex-direction:column;gap:4px;display:flex}.excel-upload-text strong{color:#1e293b;font-size:15px}.excel-upload-text span{color:#94a3b8;font-size:12px}.excel-template-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin-top:20px;padding:16px}.excel-template-title{color:#475569;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;font-size:12px;font-weight:700}.excel-template-cols{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.excel-col-tag{color:#1d4ed8;background:#dbeafe;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600}.excel-template-note{color:#94a3b8;font-size:12px;line-height:1.5}.excel-file-badge{color:#16a34a;background:#f0fdf4;border-radius:12px;margin-left:10px;padding:3px 10px;font-size:12px;font-weight:600}.excel-mapping-summary{gap:12px;margin-bottom:14px;display:flex}.excel-map-ok{color:#1d4ed8;background:#dbeafe;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.excel-map-rows{color:#16a34a;background:#f0fdf4;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:600}.excel-preview-wrap{border:1px solid #e2e8f0;border-radius:10px;max-height:360px;margin-bottom:12px;overflow:auto}.excel-preview-table{border-collapse:collapse;width:100%;min-width:700px;font-size:12px}.excel-preview-table thead{z-index:1;background:#f8fafc;position:sticky;top:0}.excel-preview-table th{text-align:left;color:#475569;white-space:nowrap;border-bottom:2px solid #e2e8f0;padding:8px 10px;font-size:11px;font-weight:700}.excel-preview-table td{white-space:nowrap;border-bottom:1px solid #f1f5f9;padding:6px 10px}.excel-preview-table tr:hover td{background:#f8fafc}.excel-more-notice{text-align:center;color:#94a3b8;padding:8px;font-size:12px}.excel-result-success,.excel-result-fail{border-radius:12px;align-items:center;gap:16px;margin-bottom:16px;padding:32px 24px;display:flex}.excel-result-success{background:#f0fdf4;border:1px solid #bbf7d0}.excel-result-fail{background:#fef2f2;border:1px solid #fecaca}.excel-result-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:36px;font-weight:700;display:flex}.excel-result-success .excel-result-icon{color:#16a34a;background:#dcfce7}.excel-result-fail .excel-result-icon{color:#dc2626;background:#fee2e2}.excel-result-text{color:#1e293b;font-size:16px}.excel-result-text strong{color:#16a34a}.toast-overlay{z-index:2000;pointer-events:none;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.toast-container{pointer-events:auto;animation:.3s ease-out toastIn}@keyframes toastIn{0%{opacity:0;transform:scale(.9)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.toast-card{text-align:center;background:#fff;border-radius:16px;min-width:300px;max-width:400px;padding:32px 40px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d}.toast-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:28px;display:flex}.toast-icon.success{color:#16a34a;background:#dcfce7}.toast-icon.error{color:#dc2626;background:#fee2e2}.toast-icon.warning{color:#f59e0b;background:#fef3c7}.toast-icon.info{color:#3b82f6;background:#dbeafe}.toast-title{color:#1e293b;margin-bottom:6px;font-size:16px;font-weight:700}.toast-msg{color:#64748b;word-break:break-all;margin-bottom:16px;font-size:13px;line-height:1.5}.toast-btn{cursor:pointer;border:none;border-radius:8px;padding:8px 24px;font-size:13px;font-weight:600;transition:all .2s}.toast-btn.success{color:#fff;background:#22c55e}.toast-btn.success:hover{background:#16a34a}.toast-btn.error{color:#fff;background:#ef4444}.toast-btn.error:hover{background:#dc2626}.toast-btn.warning{color:#fff;background:#f59e0b}.toast-btn.warning:hover{background:#d97706}.toast-btn.info{color:#fff;background:#3b82f6}.toast-btn.info:hover{background:#2563eb}.toast-backdrop{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1999;background:#0f172a4d;width:100%;height:100%;position:fixed;top:0;left:0}.empty-state{text-align:center;color:#94a3b8;padding:30px;font-size:13px}.loading{text-align:center;color:#64748b;flex-direction:column;align-items:center;gap:16px;padding:60px;font-size:16px;display:flex}.loading-spinner{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{text-align:center;color:#dc2626;padding:40px}.footer{text-align:center;color:#94a3b8;padding:16px;font-size:11px}.realtime-dot{background:#22c55e;border-radius:50%;width:8px;height:8px;margin-right:6px;animation:2s infinite pulse;display:inline-block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.notif-panel{z-index:3000;pointer-events:none;flex-direction:column;gap:8px;max-width:380px;display:flex;position:fixed;bottom:20px;right:20px}.notif-card{pointer-events:auto;background:#fff;border-left:4px solid #f59e0b;border-radius:12px;align-items:flex-start;gap:12px;padding:14px 16px;animation:.4s ease-out notifSlideIn;display:flex;box-shadow:0 8px 32px #00000026,0 0 0 1px #0000000d}@keyframes notifSlideIn{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.notif-icon{color:#f59e0b;background:#fef3c7;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.notif-body{flex:1;min-width:0}.notif-title{color:#1e293b;margin-bottom:2px;font-size:13px;font-weight:700}.notif-msg{color:#64748b;font-size:12px;line-height:1.4}.notif-time{color:#94a3b8;margin-top:4px;font-size:10px}.notif-close{cursor:pointer;color:#94a3b8;background:0 0;border:none;flex-shrink:0;padding:0 2px;font-size:14px;line-height:1}.notif-close:hover{color:#475569}.notif-card.urgent{border-left-color:#dc2626}.notif-card.urgent .notif-icon{color:#dc2626;background:#fee2e2}.notif-header{pointer-events:auto;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e293be6;border-radius:10px;justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.notif-header-label{color:#fff;align-items:center;gap:6px;font-size:12px;font-weight:700;display:flex}.notif-count-badge{color:#fff;background:#ef4444;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}.notif-dismiss-all{color:#e2e8f0;cursor:pointer;background:#ffffff26;border:none;border-radius:8px;padding:4px 12px;font-size:11px;font-weight:600;transition:all .2s}.notif-dismiss-all:hover{background:#ffffff40}.notif-more{pointer-events:auto;text-align:center;color:#94a3b8;background:#ffffffe6;border-radius:8px;padding:4px;font-size:11px}@media (width<=1200px){.sidebar{width:220px}}@media (width<=1024px){.sidebar{width:72px}.sb-brand-text,.sb-quick-stats .sb-stat-label,.sb-section-title,.sb-cust-info,.sb-month-bar-wrap,.sb-month-count,.sb-footer span,.sb-chevron{display:none}.sb-brand{justify-content:center;padding:16px}.sb-quick-stats{flex-direction:column;gap:8px;padding:12px 8px}.sb-stat-value{font-size:14px}.sb-section-header{justify-content:center;padding:10px 8px}.sb-customer-item{justify-content:center;padding:6px}.sb-cust-icon-wrap{width:28px;height:28px;font-size:11px}.sb-cust-active-dot{display:none}.sb-month-item{padding:6px 8px}.sb-month-label{justify-content:center;font-size:12px}.sb-month-top{justify-content:center}.sb-section-body{padding:0 6px 8px}.sb-footer{justify-content:center}.sb-footer span{display:none}}@media (width<=768px){.app-layout{flex-direction:column}.sidebar{border-bottom:1px solid #ffffff1a;border-right:none;flex-direction:row;width:100%;height:auto;position:static;overflow-x:auto}.sb-brand{display:none}.sb-quick-stats{flex-direction:row;padding:8px 12px}.sb-quick-stats .sb-stat-label{display:block}.sb-section{align-items:center;display:flex}.sb-section-header{display:none}.sb-section-body{gap:4px;padding:4px 8px;display:flex}.sb-customer-item{padding:6px 10px}.sb-cust-info{display:flex}.sb-cust-name{font-size:11px}.sb-cust-meta{display:none}.sb-month-item{white-space:nowrap;padding:6px 10px}.sb-month-bar-wrap,.sb-footer,.sb-chevron,.sb-section-title{display:none}.header,.summary,.controls,.table-wrap,.tabs{padding-left:16px;padding-right:16px}}.auth-container{background:linear-gradient(135deg,#1a2f23 0%,#2d4a37 100%);justify-content:center;align-items:center;min-height:100vh;font-family:Inter,sans-serif;display:flex}.auth-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:48px 40px;box-shadow:0 20px 60px #0000004d}.auth-logo{text-align:center;flex-direction:column;gap:2px;margin-bottom:32px;display:flex}.auth-logo-row{flex-wrap:wrap;justify-content:center;align-items:baseline;gap:5px;display:flex}.auth-logo-woosung,.auth-logo-integrated,.auth-logo-engine{letter-spacing:-.3px;color:#1a2f23;font-size:14px;font-weight:800}.auth-logo-divider{color:#64748b;margin:0 2px;font-size:16px;font-weight:300}.auth-logo-wise{color:#34d399;letter-spacing:-.3px;font-size:15px;font-style:italic;font-weight:800}.auth-logo-sales{color:#f59e0b;letter-spacing:-.3px;font-size:14px;font-weight:800}.auth-title{color:#1a2f23;margin-bottom:8px;font-size:24px;font-weight:700}.auth-subtitle{color:#64748b;margin-bottom:28px;font-size:13px}.auth-form{flex-direction:column;gap:16px;display:flex}.auth-input{border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:12px 14px;font-family:Inter,sans-serif;font-size:14px;transition:all .2s}.auth-input:focus{border-color:#34d399;outline:none;box-shadow:0 0 0 3px #34d3991a}.auth-input::placeholder{color:#cbd5e1}.auth-button{cursor:pointer;color:#fff;background:#34d399;border:none;border-radius:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s}.auth-button:hover{background:#2ec897;transform:translateY(-1px);box-shadow:0 8px 16px #34d3994d}.auth-button:active{transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#dc2626;text-align:center;background:#fee2e2;border-radius:6px;margin-bottom:16px;padding:10px;font-size:13px}.auth-loading{opacity:.7;cursor:not-allowed}
