*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--teal-50:#E1F5EE;--teal-100:#9FE1CB;--teal-200:#5DCAA5;--teal-400:#1D9E75;--teal-600:#0F6E56;--teal-800:#085041;--gray-50:#F6F6F4;--gray-100:#EAEAE6;--gray-200:#D3D1C7;--gray-400:#888780;--gray-600:#5F5E5A;--gray-800:#2C2C2A;--coral-50:#FAECE7;--coral-400:#D85A30;--coral-600:#993C1D;--amber-50:#FAEEDA;--amber-400:#BA7517;--green-50:#EAF3DE;--green-400:#639922;--green-600:#3B6D11;--blue-50:#E6F1FB;--blue-400:#378ADD;--blue-600:#185FA5;--purple-50:#F0E8F8;--purple-400:#8A4FC1;--shadow-lg:0 10px 30px rgba(0,0,0,.12),0 4px 10px rgba(0,0,0,.06);--radius-sm:8px;--radius-md:12px;--radius-lg:16px}body{font-family:Sarabun,IBM Plex Sans Thai,sans-serif;background:var(--gray-50);color:var(--gray-800);min-height:100vh;font-size:15px;line-height:1.6}.auth-wrap{min-height:100vh;display:flex}.auth-side{width:420px;min-height:100vh;background:linear-gradient(160deg,var(--teal-600) 0%,var(--teal-800) 100%);display:flex;flex-direction:column;justify-content:center;padding:56px 48px;color:#fff;position:relative;overflow:hidden}.auth-side:before{content:"";position:absolute;width:320px;height:320px;border-radius:50%;border:1px solid rgba(255,255,255,.1);top:-80px;right:-80px}.auth-side:after{content:"";position:absolute;width:200px;height:200px;border-radius:50%;border:1px solid rgba(255,255,255,.08);bottom:40px;left:-60px}.auth-side .logo{display:flex;align-items:center;gap:12px;margin-bottom:48px}.auth-side .logo-text{font-size:22px;font-weight:600;letter-spacing:-.3px}.auth-side h1{font-size:28px;font-weight:600;line-height:1.3;margin-bottom:16px;letter-spacing:-.5px}.auth-side p{font-size:15px;opacity:.75;line-height:1.65}.auth-feature-list{margin-top:40px;list-style:none;display:flex;flex-direction:column;gap:14px}.auth-feature-list li{display:flex;align-items:center;gap:12px;font-size:14px;opacity:.85}.feat-dot{width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}.logo-mark{width:36px;height:36px;border-radius:8px;background:var(--teal-600);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:15px;letter-spacing:-.5px}.logo-mark-lg{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;letter-spacing:-.5px}.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.auth-card{width:100%;max-width:420px}.auth-card h2{font-size:24px;font-weight:600;color:var(--gray-800);margin-bottom:8px;letter-spacing:-.3px}.auth-card .sub{font-size:14px;color:var(--gray-400);margin-bottom:32px}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-600);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:15px;font-family:inherit;color:var(--gray-800);background:white;outline:none;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--teal-400);box-shadow:0 0 0 3px #1d9e751f}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.btn-primary{width:100%;padding:12px;background:var(--teal-600);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .15s,transform .1s;margin-top:8px}.btn-primary:hover{background:var(--teal-800)}.btn-primary:disabled{background:var(--gray-200);color:var(--gray-400);cursor:not-allowed}.btn-sm{padding:8px 16px;background:var(--teal-600);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer}.btn-sm:hover{background:var(--teal-800)}.btn-sm:disabled{background:var(--gray-200);color:var(--gray-400);cursor:not-allowed}.btn-ghost{padding:8px 16px;background:white;color:var(--gray-600);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer}.btn-ghost:hover{border-color:var(--gray-400);color:var(--gray-800)}.btn-link{background:none;border:none;color:var(--teal-600);cursor:pointer;font-size:13px;font-weight:500;font-family:inherit;padding:0}.btn-link:hover{text-decoration:underline}.btn-link.danger{color:var(--coral-400)}.auth-switch{text-align:center;margin-top:24px;font-size:14px;color:var(--gray-400)}.auth-switch a{color:var(--teal-600);text-decoration:none;font-weight:500;cursor:pointer}.auth-switch a:hover{text-decoration:underline}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.alert-error{background:#FEE2E2;color:#991b1b;border:1px solid #FECACA}.alert-success{background:var(--teal-50);color:var(--teal-800);border:1px solid var(--teal-100)}.app-wrap{min-height:100vh;display:flex}.sidebar{width:240px;background:white;border-right:1px solid var(--gray-100);position:fixed;top:0;left:0;height:100vh;display:flex;flex-direction:column;padding:24px 0}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 20px 24px;border-bottom:1px solid var(--gray-100);margin-bottom:8px}.sidebar-logo span{font-size:17px;font-weight:600;color:var(--gray-800);letter-spacing:-.3px}.nav-section-title{font-size:11px;font-weight:600;color:var(--gray-400);text-transform:uppercase;letter-spacing:.6px;padding:14px 20px 6px}.nav-item{position:relative;display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:14px;color:var(--gray-600);cursor:pointer;transition:background .12s,color .12s;margin:1px 8px;border-radius:var(--radius-sm);text-decoration:none}.nav-item:hover{background:var(--gray-50);color:var(--gray-800)}.nav-item.active{background:var(--teal-50);color:var(--teal-600);font-weight:500}.nav-item svg{width:18px;height:18px}.nav-badge{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:var(--coral-400);color:#fff;font-size:10px;font-weight:600;padding:2px 7px;border-radius:10px;min-width:18px;text-align:center}.sidebar-footer{margin-top:auto;padding:16px 20px;border-top:1px solid var(--gray-100)}.user-chip{display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--teal-50);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--teal-600);flex-shrink:0}.user-name{font-size:13px;font-weight:500;color:var(--gray-800)}.user-role{font-size:12px;color:var(--gray-400)}.icon-btn{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--gray-400);padding:4px 6px;border-radius:6px}.icon-btn:hover{color:var(--coral-400);background:var(--gray-50)}.notif-summary{margin:8px;padding:10px 12px;background:var(--coral-50);border:1px solid #F4C5B3;border-radius:var(--radius-sm);font-size:12px;color:var(--coral-600);cursor:pointer}.notif-summary:hover{background:#F8DAD0}.notif-title{font-weight:600;display:flex;align-items:center;gap:6px}.notif-count{font-size:11px;opacity:.85;margin-top:2px}.content-area{margin-left:240px;padding:32px 36px;min-height:100vh;background:var(--gray-50);flex:1}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.page-header h2{font-size:22px;font-weight:600;color:var(--gray-800);letter-spacing:-.3px}.page-header .subtitle{font-size:13px;color:var(--gray-400);margin-top:4px}.page-header .actions{display:flex;gap:8px;align-items:center}.date-tag{font-size:13px;color:var(--gray-400);background:white;border:1px solid var(--gray-100);border-radius:20px;padding:4px 14px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.metric-card{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:20px;position:relative;overflow:hidden}.metric-card .mc-label{font-size:12px;color:var(--gray-400);font-weight:500;text-transform:uppercase;letter-spacing:.4px;margin-bottom:8px}.metric-card .mc-value{font-size:26px;font-weight:600;color:var(--gray-800);letter-spacing:-1px;line-height:1;margin-bottom:6px}.metric-card .mc-sub{font-size:12px;color:var(--gray-400)}.metric-card .mc-badge{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center}.mc-badge svg{width:18px;height:18px}.mc-teal .mc-badge{background:var(--teal-50)}.mc-teal .mc-value{color:var(--teal-600)}.mc-coral .mc-badge{background:var(--coral-50)}.mc-coral .mc-value{color:var(--coral-600)}.mc-amber .mc-badge{background:var(--amber-50)}.mc-amber .mc-value{color:var(--amber-400)}.mc-blue .mc-badge{background:var(--blue-50)}.mc-blue .mc-value{color:var(--blue-600)}.mc-green .mc-badge{background:var(--green-50)}.mc-green .mc-value{color:var(--green-600)}.mc-purple .mc-badge{background:var(--purple-50)}.mc-purple .mc-value{color:var(--purple-400)}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.col-2-1{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px}.card{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--gray-100);gap:12px;flex-wrap:wrap}.card-title{font-size:14px;font-weight:600;color:var(--gray-800)}.badge{display:inline-block;font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;vertical-align:middle}.badge-teal{background:var(--teal-50);color:var(--teal-600)}.badge-amber{background:var(--amber-50);color:var(--amber-400)}.badge-blue{background:var(--blue-50);color:var(--blue-600)}.badge-green{background:var(--green-50);color:var(--green-600)}.badge-coral{background:var(--coral-50);color:var(--coral-600)}.badge-purple{background:var(--purple-50);color:var(--purple-400)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.status-pill{display:inline-block;font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px}.sp-ok{background:var(--green-50);color:var(--green-600)}.sp-warn{background:var(--amber-50);color:var(--amber-400)}.sp-low{background:var(--coral-50);color:var(--coral-600)}.sp-info{background:var(--blue-50);color:var(--blue-600)}.sp-neutral{background:var(--gray-100);color:var(--gray-600)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{text-align:left;padding:12px 14px;background:var(--teal-50);font-weight:600;color:var(--teal-800);font-size:11px;border-bottom:2px solid var(--teal-200);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.data-table td{padding:14px;border-bottom:1px solid var(--gray-100);color:var(--gray-800);background:white}.data-table tbody tr:nth-child(2n) td{background:var(--gray-50)}.data-table tbody tr:hover td{background:#F5FBF8}.data-table tr:last-child td{border-bottom:none}.text-right{text-align:right}.text-mono{font-family:Courier New,monospace;font-size:12px;color:var(--gray-600)}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.filter-pills{display:flex;gap:6px;flex-wrap:wrap}.filter-pill{padding:6px 12px;background:white;border:1.5px solid var(--gray-200);border-radius:20px;font-size:12px;cursor:pointer;transition:all .15s;font-family:inherit;color:var(--gray-600)}.filter-pill:hover{border-color:var(--gray-400)}.filter-pill.active{background:var(--teal-600);border-color:var(--teal-600);color:#fff}.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;vertical-align:middle}.dot-green{background:var(--green-400)}.dot-red{background:var(--coral-400)}.cat-section{margin-bottom:28px}.cat-section .card{padding:0;overflow:hidden;border-left-width:4px}.cat-section.cat-CAP .card{border-left-color:var(--purple-400)}.cat-section.cat-TUBE .card{border-left-color:var(--blue-400)}.cat-section.cat-LABEL .card{border-left-color:var(--amber-400)}.cat-section.cat-CHEMICAL .card{border-left-color:var(--coral-400)}.cat-section.cat-FINISHED .card{border-left-color:#8a4fc1}.cat-header{display:flex;align-items:center;gap:14px;padding:16px 20px;background:white;border-bottom:1px solid var(--gray-100)}.cat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cat-icon svg{width:18px;height:18px}.cat-CAP{background:var(--purple-50);color:var(--purple-400)}.cat-TUBE{background:var(--blue-50);color:var(--blue-600)}.cat-LABEL{background:var(--amber-50);color:var(--amber-400)}.cat-CHEMICAL{background:var(--coral-50);color:var(--coral-600)}.cat-FINISHED{background:var(--purple-50);color:var(--purple-400)}.cat-title{font-size:16px;font-weight:600;color:var(--gray-800);letter-spacing:-.2px}.cat-subtitle{font-size:12px;color:var(--gray-400);margin-top:2px}.cat-meta{font-size:13px;color:var(--gray-600);margin-left:auto;background:var(--gray-50);padding:6px 14px;border-radius:20px;border:1px solid var(--gray-100);font-weight:500}.cat-meta strong{color:var(--gray-800);font-weight:600}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:rgba(44,44,42,.55);display:flex;align-items:center;justify-content:center;padding:16px}.modal{background:white;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:560px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-lg{max-width:720px}.modal-xl{max-width:1400px;width:95vw}.modal-xl .modal-body{padding:18px 24px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--gray-100)}.modal-header h3{font-size:16px;font-weight:600;color:var(--gray-800)}.modal-close{background:none;border:none;cursor:pointer;font-size:22px;color:var(--gray-400);line-height:1;padding:4px 8px;border-radius:6px}.modal-close:hover{color:var(--gray-800);background:var(--gray-50)}.modal-body{padding:22px;overflow-y:auto}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--gray-100);background:var(--gray-50)}.waste-list{border:1px solid var(--gray-100);border-radius:var(--radius-sm);overflow:hidden;background:white}.waste-row{display:grid;grid-template-columns:1fr 130px;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--gray-100)}.waste-row:last-child{border-bottom:none}.waste-row:nth-child(2n){background:var(--gray-50)}.waste-row .w-name{font-size:13px;color:var(--gray-800);font-weight:500}.waste-row .w-meta{font-size:11px;color:var(--gray-400);margin-top:2px}.ship-flow{display:grid;grid-template-columns:minmax(0,1fr) 24px minmax(0,1.2fr) 24px minmax(0,1.2fr);align-items:stretch;gap:10px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);margin-bottom:18px}.ship-flow-node{background:white;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);padding:14px;display:flex;flex-direction:column;gap:8px;justify-content:center;min-width:0}.ship-flow-node.from{background:var(--teal-50);border-color:var(--teal-200)}.ship-flow-node-head{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.ship-flow-node.from .ship-flow-node-head{color:var(--teal-600)}.ship-flow-node-value{font-size:14px;font-weight:600;color:var(--gray-800);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ship-flow-node-sub{font-size:11px;color:var(--gray-400)}.ship-flow-node select,.ship-flow-node input[type=text]{width:100%;padding:7px 10px;border:1.5px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:13px;background:white;color:var(--gray-800);transition:border-color .15s,box-shadow .15s}.ship-flow-node select:focus,.ship-flow-node input[type=text]:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 2px #0f6e561a}.ship-flow-arrow{display:flex;align-items:center;justify-content:center;color:var(--gray-400)}.ship-flow-arrow svg{width:18px;height:18px}.lot-card-list{display:flex;flex-direction:column;gap:8px}.lot-card{display:grid;grid-template-columns:24px 1fr 130px;align-items:center;gap:14px;padding:12px 14px;background:white;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer}.lot-card:hover{border-color:var(--gray-400)}.lot-card.selected{border-color:var(--teal-400);background:var(--teal-50);box-shadow:0 0 0 3px #1d9e7514}.lot-check-box{width:22px;height:22px;border:1.5px solid var(--gray-200);border-radius:5px;display:flex;align-items:center;justify-content:center;background:white;color:#fff}.lot-card.selected .lot-check-box{background:var(--teal-600);border-color:var(--teal-600)}.lot-check-box svg{width:14px;height:14px;opacity:0}.lot-card.selected .lot-check-box svg{opacity:1}.lot-product{font-size:13px;font-weight:600;color:var(--gray-800)}.lot-meta{font-size:11px;color:var(--gray-400);margin-top:3px;display:flex;gap:10px;flex-wrap:wrap}.lot-qty-input{width:100%;padding:8px 12px;text-align:right;border:1.5px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:13px;outline:none}.lot-qty-input:disabled{background:var(--gray-50);color:var(--gray-400)}.ship-summary{margin-top:14px;padding:12px 16px;background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius-sm);font-size:13px;display:flex;justify-content:space-between;align-items:center;color:var(--teal-800)}.alert-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--amber-50);border-radius:var(--radius-sm);margin-bottom:8px}.alert-row.critical{background:var(--coral-50)}.alert-row .ar-name{font-size:13px;color:var(--gray-800);font-weight:500}.alert-row .ar-meta{font-size:11px;color:var(--gray-400);margin-top:2px}.alert-row .ar-days{font-size:13px;font-weight:600}.ar-days-warn{color:var(--amber-400)}.ar-days-critical{color:var(--coral-600)}.banner-alert{display:flex;align-items:flex-start;gap:14px;padding:14px 18px;border-radius:var(--radius-md);border:1px solid;margin-bottom:20px}.banner-alert.warn{background:var(--amber-50);border-color:#fcd9a6;color:var(--amber-400)}.banner-alert.danger{background:var(--coral-50);border-color:#f4c5b3;color:var(--coral-600)}.banner-alert .ba-icon{width:36px;height:36px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.banner-alert.warn .ba-icon{background:rgba(186,117,23,.15)}.banner-alert.danger .ba-icon{background:rgba(153,60,29,.12)}.banner-alert .ba-body{flex:1}.banner-alert .ba-title{font-weight:600;font-size:14px;margin-bottom:4px;color:var(--gray-800)}.banner-alert .ba-desc{font-size:13px;color:var(--gray-600);line-height:1.5}.empty-state{text-align:center;padding:32px 16px;color:var(--gray-400);font-size:13px}.icon-sm{width:14px;height:14px}.toast{position:fixed;bottom:24px;right:24px;z-index:60;padding:12px 18px;border-radius:var(--radius-sm);font-size:14px;box-shadow:var(--shadow-lg);color:#fff}.toast-info{background:var(--gray-800)}.toast-success{background:var(--teal-600)}.toast-error{background:var(--coral-400)}.view-toggle{display:inline-flex;background:var(--gray-50);border:1px solid var(--gray-100);border-radius:999px;padding:3px}.view-toggle button{padding:6px 16px;border:none;background:transparent;color:var(--gray-600);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;border-radius:999px;transition:all .15s}.view-toggle button.active{background:var(--teal-600);color:#fff;box-shadow:0 1px 3px #00000014}.view-toggle button:hover:not(.active){color:var(--gray-800)}.visual-view{display:grid;grid-template-columns:minmax(320px,380px) 1fr;gap:24px;align-items:start}@media (max-width: 980px){.visual-view{grid-template-columns:1fr}}.visual-tube-card{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:24px;position:sticky;top:16px}.visual-tube-meta{font-size:12px;color:var(--gray-400);margin-top:8px;text-align:center}.tube-illustration{position:relative;padding:8px 0}.tube-illustration.animate .tube-cap{transform-box:fill-box;transform-origin:center bottom;animation:capDrop .7s cubic-bezier(.34,1.4,.64,1) backwards}.tube-illustration .tube-liquid{transform-box:fill-box;transform-origin:center bottom;transform:scaleY(var(--fill-level, .6));transition:transform .4s ease-out}.tube-illustration.animate .tube-liquid{animation:liquidFill .9s .3s ease-out backwards}.tube-illustration.animate .tube-label{transform-box:fill-box;transform-origin:center;animation:labelStick .6s .7s ease-out backwards}@keyframes capDrop{0%{transform:translateY(-60px);opacity:0}60%{transform:translateY(6px);opacity:1}80%{transform:translateY(-2px)}to{transform:translateY(0);opacity:1}}@keyframes liquidFill{0%{transform:scaleY(0);opacity:.3}to{transform:scaleY(var(--fill-level, .6));opacity:1}}@keyframes labelStick{0%{transform:translate(-50px) rotate(-3deg);opacity:0}70%{transform:translate(2px) rotate(0);opacity:1}to{transform:translate(0)}}.tube-anno{position:absolute;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--gray-600);font-weight:500;background:white;padding:2px 8px;border-radius:12px;border:1px solid var(--gray-100)}.tube-anno-dot{width:6px;height:6px;border-radius:50%;background:var(--gray-400)}.tube-anno-cap{top:38px;right:16px}.tube-anno-tube{top:113px;right:16px}.tube-anno-label{top:253px;right:16px}.tube-anno-chem{top:343px;left:16px}.material-card-list{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-content:start}@media (max-width: 1200px){.material-card-list{grid-template-columns:1fr}}.material-card{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:16px 18px;transition:border-color .15s,box-shadow .15s}.material-card:hover{border-color:var(--gray-200)}.inline-add-form{background:var(--gray-50);border:1px dashed var(--gray-200);border-radius:var(--radius-sm);padding:14px;margin-bottom:14px}.inline-add-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--gray-800);margin-bottom:10px}.inline-add-form .form-group label{font-size:11px;color:var(--gray-600);font-weight:500}.inline-add-form input,.inline-add-form select{width:100%;padding:7px 10px;border:1.5px solid var(--gray-200);border-radius:6px;font-family:inherit;font-size:13px;background:white;color:var(--gray-800)}.inline-add-form input:focus,.inline-add-form select:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 2px #0f6e561a}.ship-step-indicator{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding:12px 14px;background:var(--gray-50);border-radius:var(--radius-sm)}.ship-step{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gray-400);font-weight:500}.ship-step span{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;background:var(--gray-200);color:var(--gray-600)}.ship-step.active{color:var(--teal-700)}.ship-step.active span{background:var(--teal-600);color:#fff}.ship-step.done{color:var(--green-600)}.ship-step.done span{background:var(--green-600);color:#fff}.ship-step-line{flex:1;height:2px;background:var(--gray-200)}.ship-step-line.done{background:var(--green-600)}.ship-summary-bar{display:flex;justify-content:space-between;align-items:baseline;padding:10px 14px;background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius-sm);margin-bottom:14px;font-size:14px;color:var(--gray-800)}.ship-lot-table tbody tr.ship-lot-row{cursor:pointer}.ship-lot-table tbody tr.ship-lot-row:hover{background:var(--gray-50)}.ship-lot-table tbody tr.ship-lot-row.selected{background:var(--teal-50)}.ship-lot-table tbody tr.ship-lot-row.selected td{border-color:var(--teal-100)}.po-section-header{display:flex;align-items:center;gap:8px;padding:6px 4px;margin-bottom:8px;font-size:13px;color:var(--gray-600)}.po-section-title{font-weight:600;color:var(--gray-800)}.po-section-title:before{content:"▸ ";color:var(--gray-400)}.po-section-count{color:var(--gray-400);font-size:12px}.po-section-body{display:flex;flex-direction:column;gap:10px}.po-card{background:white;border:1px solid var(--gray-200);border-radius:var(--radius-md);padding:14px 18px;display:grid;grid-template-columns:minmax(180px,1fr) minmax(0,2.5fr) auto;gap:18px;align-items:center;transition:border-color .15s,box-shadow .15s}.po-card:hover{border-color:var(--gray-400);box-shadow:0 2px 6px #0000000a}.po-card.stale{border-color:#fcd9a6;background:#FFFBF1}.po-card-main{min-width:0}.po-card-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.po-card-no{font-family:var(--font-mono);font-size:14px;font-weight:600;color:var(--gray-800)}.po-card-product{font-size:13px;color:var(--gray-600);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.po-stale-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;color:var(--amber-400);background:var(--amber-50);padding:2px 8px;border-radius:999px}.po-stale-badge.critical{color:var(--coral-600);background:var(--coral-50)}.po-card-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:14px;min-width:0}.po-stat{min-width:0}.po-stat-label{font-size:11px;color:var(--gray-400);margin-bottom:2px;text-transform:uppercase;letter-spacing:.3px;font-weight:500}.po-stat-value{font-size:15px;font-weight:600;color:var(--gray-800)}.po-stat-unit{font-size:11px;font-weight:400;color:var(--gray-400)}.po-stat-progress{grid-column:span 2}.po-progress-bar{height:6px;background:var(--gray-100);border-radius:999px;overflow:hidden;margin-top:4px}.po-progress-fill{height:100%;background:var(--teal-400);transition:width .3s ease-out}.po-progress-label{font-size:11px;color:var(--gray-600);margin-top:4px}.po-card-action{white-space:nowrap}@media (max-width: 900px){.po-card{grid-template-columns:1fr}.po-card-action{text-align:right}}.po-form-card{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:12px}.po-form-section{padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.po-form-section:last-child{border-bottom:0;padding-bottom:0}.po-form-section-title{font-size:12px;font-weight:600;color:var(--gray-600);margin-bottom:8px;display:flex;align-items:center;gap:6px;text-transform:uppercase;letter-spacing:.3px}.po-product-picker{display:grid;grid-template-columns:1fr 1fr;gap:8px}.po-product-picker-stack{grid-template-columns:1fr}.po-3col{display:grid;grid-template-columns:minmax(0,260px) minmax(0,1fr) minmax(0,360px);gap:16px;align-items:start}@media (max-width: 1200px){.po-3col{grid-template-columns:1fr}}.po-visual-area{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:16px;display:grid;grid-template-columns:200px 1fr;gap:18px;align-items:start;min-width:0;height:calc(90vh - 180px);min-height:660px;overflow-y:auto}.po-tube-section{position:sticky;top:0;text-align:center;background:linear-gradient(180deg,var(--gray-50) 0%,white 100%);border-radius:var(--radius-sm);padding:14px 8px 10px}.po-tube-section .tube-illustration{padding:0}.po-tube-section svg{max-width:180px!important}.po-tube-meta{font-size:12px;color:var(--gray-600);text-align:center;white-space:nowrap;margin-top:10px;padding-top:8px;border-top:1px solid var(--gray-200)}.po-mat-list{display:flex;flex-direction:column;gap:8px;min-width:0}.po-mat-card{background:white;border:1.5px solid var(--gray-100);border-radius:var(--radius-sm);padding:10px 12px}.po-mat-card.insufficient{border-color:#f4c5b3;background:var(--coral-50)}.po-mat-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}.po-mat-name{font-size:13px;font-weight:600;color:var(--gray-800)}.po-mat-sku{font-size:10px;color:var(--gray-400);margin-left:4px;font-weight:400}.po-mat-deduct{font-size:14px;font-weight:700;color:var(--gray-800);white-space:nowrap}.po-mat-deduct.insufficient{color:var(--coral-600)}.po-mat-unit{font-size:11px;font-weight:400;color:var(--gray-400)}.po-mat-stock{font-size:11px;color:var(--gray-400);margin-top:4px}.po-mat-stock.insufficient{color:var(--coral-600);font-weight:500}.po-product-card{display:flex;align-items:center;gap:8px;padding:10px 12px;background:white;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;text-align:left;font-family:inherit;transition:all .15s}.po-product-card:hover{border-color:var(--gray-400)}.po-product-card.active{border-color:var(--teal-600);background:var(--teal-50);box-shadow:0 0 0 3px #0f6e5614}.po-product-name{font-size:13px;font-weight:600;color:var(--gray-800)}.po-product-sku{font-size:11px;color:var(--gray-400);margin-top:2px}.po-big-input{width:100%;padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:16px;font-weight:600;font-family:inherit;color:var(--gray-800);text-align:right;transition:border-color .15s,box-shadow .15s}.po-big-input:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 3px #0f6e561a}.po-chem-rate{margin-top:8px;background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius-sm);overflow:hidden}.po-chem-rate-row{display:flex;justify-content:space-between;align-items:baseline;padding:8px 12px;font-size:13px;border-bottom:1px solid var(--teal-100)}.po-chem-rate-row:last-child{border-bottom:0}.po-chem-rate-row span{color:var(--gray-600)}.po-chem-rate-row strong{color:var(--teal-800);font-size:14px;font-weight:600}.po-chem-rate-row.alt{background:rgba(15,110,86,.05)}.po-chem-rate-row.alt span{font-size:11px;color:var(--gray-500)}.po-chem-rate-row.alt strong{font-size:13px;color:var(--gray-700)}.ship-checkout{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:20px;align-items:start}@media (max-width: 1100px){.ship-checkout{grid-template-columns:1fr}}.ship-catalog{min-width:0}.ship-summary-side{background:white;border:1px solid var(--gray-100);border-radius:var(--radius-md);padding:20px 22px;position:sticky;top:0;max-height:calc(90vh - 180px);overflow:hidden;display:flex;flex-direction:column}.ship-summary-side h4{font-size:16px;font-weight:600;color:var(--gray-800);padding-bottom:14px;border-bottom:1px solid var(--gray-100);margin-bottom:14px;display:flex;align-items:center;gap:8px}.ship-summary-side h4 svg{width:20px;height:20px;flex-shrink:0}.ship-summary-dest{background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:16px;font-size:14px}.ship-summary-dest-row{display:flex;justify-content:space-between;gap:8px;padding:2px 0}.ship-summary-dest-label{color:var(--gray-400);font-size:11px}.ship-summary-dest-value{color:var(--gray-800);font-weight:500;text-align:right}.ship-summary-items{flex:1;overflow-y:auto;margin:0 -4px;padding:0 4px}.ship-summary-empty{color:var(--gray-400);font-size:13px;text-align:center;padding:24px 0}.ship-summary-item{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:12px 0;border-bottom:1px solid var(--gray-100);font-size:14px}.ship-summary-item-name{font-size:14px}.ship-summary-item-qty{font-size:15px}.ship-summary-item:last-child{border-bottom:0}.ship-summary-item-name{font-weight:500;color:var(--gray-800)}.ship-summary-item-meta{font-size:11px;color:var(--gray-400);margin-top:2px}.ship-summary-item-qty{font-weight:600;color:var(--teal-700);white-space:nowrap}.ship-summary-item-remove{background:transparent;border:0;color:var(--gray-400);cursor:pointer;font-size:16px;padding:4px 6px;border-radius:4px;line-height:1}.ship-summary-item-remove:hover{background:var(--coral-50);color:var(--coral-600)}.ship-summary-totals{border-top:1.5px solid var(--gray-200);margin-top:8px;padding-top:12px}.ship-summary-total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.ship-summary-total-row.grand{border-top:1px solid var(--gray-100);margin-top:6px;padding-top:10px;font-size:15px;font-weight:700;color:var(--gray-800)}.ship-summary-total-row.grand strong{color:var(--teal-700);font-size:18px}.ship-submit-btn{width:100%;padding:12px;margin-top:14px;background:var(--teal-600);color:#fff;border:0;border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s}.ship-submit-btn:hover:not(:disabled){background:var(--teal-700)}.ship-submit-btn:disabled{background:var(--gray-200);color:var(--gray-400);cursor:not-allowed}.search-input{position:relative;display:inline-flex;align-items:center}.search-input input{padding:8px 14px 8px 34px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:13px;font-family:inherit;width:280px;background:white;color:var(--gray-800);transition:border-color .15s,box-shadow .15s}.search-input input:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 3px #0f6e561a}.search-input:before{content:"🔍";position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:12px;opacity:.5;pointer-events:none}.report-toolbar{display:grid;grid-template-columns:1fr 200px auto;gap:16px;align-items:end}@media (max-width: 720px){.report-toolbar{grid-template-columns:1fr}}.report-toolbar .rt-field{display:flex;flex-direction:column;gap:6px}.report-toolbar .rt-field label{font-size:12px;font-weight:500;color:var(--gray-600);margin:0;text-transform:uppercase;letter-spacing:.3px}.report-toolbar .rt-field select,.report-toolbar .rt-field input{padding:10px 14px;border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;background:white;color:var(--gray-800);height:42px;transition:border-color .15s,box-shadow .15s}.report-toolbar .rt-field select:focus,.report-toolbar .rt-field input:focus{outline:none;border-color:var(--teal-600);box-shadow:0 0 0 3px #0f6e561a}.report-toolbar .rt-actions{display:flex;gap:10px}.report-toolbar .rt-actions .btn-sm,.report-toolbar .rt-actions .btn-ghost{height:42px;padding:0 18px}.cmp-table{width:100%;border-collapse:collapse}.cmp-table thead th{padding:12px 14px;font-size:13px;font-weight:600}.cmp-table .cmp-label-col{text-align:left;color:var(--gray-600);padding-left:18px}.cmp-table .cmp-red-head{background:#FCEBEC;color:var(--coral-600);border-bottom:1px solid #F4C5B3}.cmp-table .cmp-green-head{background:#E9F4D9;color:var(--green-600);border-bottom:1px solid #C9DFA0}.cmp-table .cmp-sub{font-size:11px;font-weight:500;padding:6px 14px;color:var(--gray-600)}.cmp-table .cmp-red-sub{background:#FCEBEC}.cmp-table .cmp-green-sub{background:#E9F4D9}.cmp-table tbody tr{border-bottom:1px solid var(--gray-100)}.cmp-table tbody tr:last-child{border-bottom:0}.cmp-table .cmp-label{padding:12px 18px;font-size:14px;color:var(--gray-800);font-weight:500}.cmp-table .cmp-num{padding:12px 14px;text-align:right;font-size:14px;font-weight:600;color:var(--gray-800)}.cmp-table .cmp-days{padding:12px 14px;text-align:right;font-size:13px;color:var(--green-600)}.cmp-table .cmp-num.cmp-low,.cmp-table .cmp-days.cmp-low{color:var(--amber-400)}.cmp-table .cmp-num.cmp-critical,.cmp-table .cmp-days.cmp-critical{color:var(--coral-600)}.cmp-table .cmp-section{background:var(--gray-50);padding:8px 18px;font-size:12px;font-weight:600;color:var(--gray-600);text-transform:uppercase;letter-spacing:.3px}.cmp-table .cmp-shared{padding:12px 14px;text-align:right;font-size:14px;color:var(--gray-800)}.cmp-table .cmp-shared.cmp-low{color:var(--amber-400)}.cmp-table .cmp-shared.cmp-critical{color:var(--coral-600)}.material-card.low{border-color:#fcd9a6;background:#FFFBF1}.material-card.critical{border-color:var(--coral-600);background:var(--coral-50);border-width:1.5px}.mat-card-alert{font-size:11px;font-weight:500;margin-top:8px;padding:6px 10px;border-radius:6px;display:flex;align-items:center;gap:6px}.mat-card-alert.low{background:var(--amber-50);color:var(--amber-400)}.mat-card-alert.critical{background:rgba(216,90,48,.12);color:var(--coral-600)}.mat-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.mat-card-name{font-size:14px;font-weight:600;color:var(--gray-800)}.mat-card-sku{font-size:11px;color:var(--gray-400);margin-left:6px;font-weight:400}.mat-card-usage{font-size:11px;color:var(--gray-400);white-space:nowrap}.mat-card-row{display:flex;justify-content:space-between;align-items:baseline;margin:4px 0 10px}.mat-card-value{font-size:26px;font-weight:700;color:var(--gray-800);letter-spacing:-.5px;line-height:1}.mat-card-unit{font-size:12px;font-weight:400;color:var(--gray-400);margin-left:4px}.days-badge{font-size:11px;padding:4px 10px;border-radius:999px;font-weight:500;white-space:nowrap}.days-badge.ok{background:var(--green-50);color:var(--green-600)}.days-badge.warn{background:var(--amber-50);color:var(--amber-400)}.days-badge.critical{background:var(--coral-50);color:var(--coral-600)}.days-badge.muted{background:var(--gray-100);color:var(--gray-600)}.mat-progress-bar{display:flex;height:6px;background:var(--gray-100);border-radius:999px;overflow:hidden}.mat-progress-fill,.mat-progress-deduct{height:100%;transition:width .3s ease-out}.mat-progress-fill{background:var(--teal-400);transition:width .6s ease}.mat-progress-fill.warn{background:var(--amber-400)}.mat-progress-fill.critical{background:var(--coral-400)}.mat-progress-deduct{background:#F4A584}.mat-progress-deduct.critical{background:var(--coral-600)}.bottleneck-alert{display:flex;align-items:center;gap:10px;background:var(--coral-50);border:1px solid #F4C5B3;border-radius:var(--radius-md);padding:12px 16px;font-size:13px;color:var(--coral-600);margin-top:16px}.bottleneck-alert .ba-dot{width:8px;height:8px;border-radius:50%;background:var(--coral-400);flex-shrink:0}.bottleneck-alert strong{font-weight:600}.product-toggle{display:inline-flex;gap:8px;align-items:center;margin-bottom:16px}.product-toggle button{padding:8px 16px;border:1.5px solid var(--gray-200);background:white;border-radius:var(--radius-sm);font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s;color:var(--gray-600);display:flex;align-items:center;gap:8px}.product-toggle button:hover{border-color:var(--gray-400)}.product-toggle button.active.green{background:var(--green-50);border-color:var(--green-400);color:var(--green-600);font-weight:600}.product-toggle button.active.red{background:var(--coral-50);border-color:var(--coral-400);color:var(--coral-600);font-weight:600}@media (max-width: 980px){.auth-side{display:none}.metrics-grid{grid-template-columns:repeat(2,1fr)}.two-col,.col-2-1{grid-template-columns:1fr}}
