:root{--sidebar-w: 260px;--bg: #0b1120;--bg2: #101827;--bg3: #1e293b;--surface: #ffffff;--surface-hover: #f8fafc;--surface-alt: #f8fafc;--border: #e2e8f0;--border-light: #f1f5f9;--text-primary: #0f172a;--text-secondary: #64748b;--text-muted: #94a3b8;--accent: #3b82f6;--accent-hover: #2563eb;--accent-light: rgba(59,130,246,.08);--danger: #ef4444;--danger-hover: #dc2626;--success: #22c55e;--warning: #f59e0b;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 12px 40px rgba(0,0,0,.12);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s cubic-bezier(.4,0,.2,1)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background:#f1f5f9;color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes toastIn{0%{opacity:0;transform:translateY(16px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{to{opacity:0;transform:translateY(16px) scale(.95)}}.layout{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:var(--sidebar-w);background:var(--bg2);color:#e2e8f0;position:fixed;top:0;left:0;bottom:0;height:100vh;height:100dvh;display:flex;flex-direction:column;z-index:1200;transition:transform var(--transition-slow);will-change:transform}.sidebar.collapsed{transform:translate(calc(-1 * var(--sidebar-w)))}.sidebar-inner{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 12px 20px;-ms-overflow-style:none;scrollbar-width:none}.sidebar-inner::-webkit-scrollbar{display:none}.brand{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:20px 16px 16px;border-bottom:1px solid rgba(148,163,184,.12);margin-bottom:8px}.brand-stack{display:flex;flex-direction:column;gap:4px;min-width:0}.brand-logo{height:56px;width:auto;object-fit:contain;display:block}.brand-company{font-weight:700;font-size:15px;letter-spacing:.3px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#f1f5f9}.brand-user{font-size:12px;color:#94a3b8;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toggle-btn{border:1px solid rgba(148,163,184,.2);background:transparent;color:#e2e8f0;border-radius:var(--radius-sm);padding:6px 8px;cursor:pointer;display:flex;align-items:center;transition:background var(--transition-fast)}.toggle-btn:hover{background:#94a3b81a}.toggle-hamburger{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px}.toggle-hamburger svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sidebar-fab{position:fixed;top:14px;left:14px;z-index:1300;border:1px solid rgba(148,163,184,.2);background:var(--bg2);color:#e2e8f0;border-radius:var(--radius-md);padding:10px 12px;cursor:pointer;display:none;align-items:center;gap:8px;box-shadow:0 4px 20px #0000004d;transition:background var(--transition-fast)}.sidebar-fab:hover{background:#94a3b81a}.sidebar-fab.show{display:flex}.sidebar-fab svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.sidebar-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:1199;opacity:0;transition:opacity var(--transition-normal)}.sidebar-backdrop.visible{opacity:1}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding-top:8px}.sidebar-nav>a{display:flex;align-items:center;gap:10px;color:#94a3b8;padding:10px 12px;border-radius:var(--radius-sm);text-decoration:none;font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-nav>a:hover{background:#94a3b814;color:#e2e8f0}.sidebar-nav>a.active{background:#3b82f61f;color:#fff;position:relative}.sidebar-nav>a.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.sidebar-nav>a .nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.sidebar-nav>a .nav-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.nav-group{margin:2px 0}.nav-group summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#94a3b8;font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast);-webkit-user-select:none;user-select:none}.nav-group summary::-webkit-details-marker{display:none}.nav-group summary::marker{display:none;content:""}.nav-group summary:hover{background:#94a3b814;color:#e2e8f0}.nav-group summary.active{color:#e2e8f0}.nav-group details[open]>summary{background:#94a3b80f;color:#e2e8f0}.nav-group summary .nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0}.nav-group summary .nav-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.nav-group summary .label{flex:1}.nav-group summary .chevron{display:flex;align-items:center;transition:transform var(--transition-normal)}.nav-group summary .chevron svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.nav-group details[open]>summary .chevron{transform:rotate(90deg)}.nav-sub-wrap{overflow:hidden;background:#0000001f;border-radius:0 0 var(--radius-sm) var(--radius-sm);transition:height .5s cubic-bezier(.25,.1,.25,1)}.nav-sub{display:flex;flex-direction:column;gap:1px;padding-left:20px;padding-top:2px;padding-bottom:4px}.nav-sub a{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);color:#94a3b8;text-decoration:none;font-size:13px;font-weight:400;transition:background var(--transition-fast),color var(--transition-fast);position:relative}.nav-sub a:hover{background:#94a3b814;color:#e2e8f0}.nav-sub a.active{background:#3b82f61f;color:#fff}.nav-sub a.active:before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;background:var(--accent);border-radius:0 3px 3px 0}.nav-sub a .nav-icon{display:flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0}.nav-sub a .nav-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.nav-sub-divider{display:flex;align-items:center;gap:8px;padding:12px 12px 4px;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#64748b;-webkit-user-select:none;user-select:none}.nav-sub-divider:after{content:"";flex:1;height:1px;background:#94a3b826}.sidebar-footer{padding:12px 12px 16px;border-top:1px solid rgba(148,163,184,.12)}.sidebar-footer form{margin:0}.sidebar-footer .logout-btn{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;align-items:center;gap:10px;color:#94a3b8;padding:10px 12px;border-radius:var(--radius-sm);white-space:nowrap;font-family:inherit;font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast)}.sidebar-footer .logout-btn:hover{background:#94a3b814;color:#e2e8f0}.sidebar-footer .logout-btn .nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px}.sidebar-footer .logout-btn .nav-icon svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.content{margin-left:var(--sidebar-w);padding:0 32px 32px;flex:1;min-width:0;min-height:100vh;min-height:100dvh;transition:margin-left var(--transition-slow);will-change:margin-left;animation:fadeIn .3s ease}.content-inner{max-width:1600px;margin-left:auto;margin-right:auto}.content.collapsed{margin-left:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 0 14px;margin-bottom:4px}.topbar-title{font-size:12px;color:var(--text-muted);font-weight:500;letter-spacing:.03em;text-transform:uppercase}.topbar-title a:hover{color:var(--accent)}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.page-header h2{margin:0;font-size:1.35rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.page-header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:13.5px;font-weight:500;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;animation:slideInDown .3s ease;position:relative}.alert .alert-close{position:absolute;top:10px;right:12px;background:none;border:none;cursor:pointer;color:inherit;opacity:.6;font-size:16px;line-height:1;padding:0;transition:opacity var(--transition-fast)}.alert .alert-close:hover{opacity:1}.alert.success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.alert.danger{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert.warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column-reverse;gap:8px;max-width:400px;pointer-events:none}.toast-container .alert{margin-bottom:0;pointer-events:auto;box-shadow:0 8px 30px #0000001f;animation:toastIn .4s cubic-bezier(.21,1.02,.73,1)}.toast-container .alert.toast-out{animation:toastOut .35s ease forwards}.card{background:var(--surface);padding:24px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:40px;padding:0 18px;background:var(--accent);color:#fff;text-decoration:none;border-radius:var(--radius-md);border:none;cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;white-space:nowrap;transition:background var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast);box-shadow:0 1px 2px #0000000f}.btn:hover{background:var(--accent-hover);box-shadow:0 4px 12px #3b82f640;transform:translateY(-1px)}.btn:active{transform:translateY(0) scale(.98)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn.secondary{background:#475569;color:#fff}.btn.secondary:hover{background:#334155;box-shadow:0 4px 12px #00000026}.btn.danger{background:var(--danger);color:#fff}.btn.danger:hover{background:var(--danger-hover);box-shadow:0 4px 12px #ef444440}.btn.small{height:34px;padding:0 12px;font-size:12.5px;border-radius:var(--radius-sm)}.btn-sm{height:32px;padding:0 12px;font-size:12px;border-radius:var(--radius-sm)}.btn-lg{height:48px;padding:0 24px;font-size:15px;border-radius:var(--radius-md)}.btn.is-loading{pointer-events:none;opacity:.65;position:relative}.btn.is-loading:after{content:"";width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .55s linear infinite;margin-left:6px;flex-shrink:0}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);border:1px solid var(--border)}table{width:100%;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);text-align:left;vertical-align:middle}th:last-child,td:last-child{border-right:none}th{color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:var(--surface-alt);white-space:nowrap;position:sticky;top:0;z-index:10;border-bottom:2px solid var(--border)}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:#3b82f60b}tbody tr:last-child td{border-bottom:none}td .truncate{max-width:420px}td .input{height:34px;padding:0 8px;font-size:13px;border-radius:var(--radius-sm)}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 16px}.toolbar form{display:flex;gap:8px;align-items:center;margin:0;flex-wrap:wrap}.toolbar form .input{width:auto;min-width:200px}.input{height:40px;padding:0 12px;border:1px solid #cbd5e1;border-radius:var(--radius-md);background:var(--surface);color:var(--text-primary);font-family:inherit;font-size:14px;width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f;position:relative;z-index:20}.input::placeholder{color:var(--text-muted)}select.input{cursor:pointer;appearance:auto}textarea.input{min-height:110px;height:auto;padding:10px 12px;resize:vertical}.form-grid{display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid .full{grid-column:1 / -1}label{font-size:13px;font-weight:500;color:var(--text-secondary);display:block;margin-bottom:6px}label.required:after{content:" *";color:var(--danger);font-weight:700}.hint{font-size:12px;color:var(--text-muted);margin-top:6px}.field-error{font-size:12px;color:var(--danger);margin-top:4px}.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 2px #dc262626}.input-group{display:flex;align-items:stretch}.input-group .input{border-top-left-radius:0;border-bottom-left-radius:0;flex:1;min-width:0}.input-group-prefix{display:flex;align-items:center;padding:0 12px;background:var(--surface-alt, #f1f5f9);border:1px solid #cbd5e1;border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);font-size:14px;font-weight:600;color:var(--text-secondary);white-space:nowrap;-webkit-user-select:none;user-select:none}.section-title{margin:24px 0 12px;font-size:15px;font-weight:600;color:var(--text-primary);padding-bottom:8px;border-bottom:2px solid var(--border)}.section-title:first-child{margin-top:0}.cost-breakdown{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px}.cost-breakdown-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.cost-breakdown-fields{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;gap:0 12px;align-items:end}.cost-breakdown-fields>div:not(.cost-breakdown-op) label{display:block;margin-bottom:4px}.cost-breakdown-fields>div:not(.cost-breakdown-op) .hint{font-size:11px;margin-top:4px;min-height:16px}.cost-breakdown-op{font-size:13px;font-weight:600;color:var(--text-muted);-webkit-user-select:none;user-select:none;padding-bottom:20px;text-align:center}.profit-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px;padding:10px 0 0;border-top:1px solid var(--border)}.profit-metrics label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);font-weight:600;margin-bottom:4px}.order-totals-table{min-width:280px;max-width:360px;border-collapse:collapse}.order-totals-table td{padding:5px 0;font-size:13.5px}.order-totals-table td:first-child{padding-right:24px}.order-totals-row-total td,.order-totals-row-profit td{font-weight:700;font-size:15px!important;padding-top:8px!important;border-top:2px solid var(--border)}.order-totals-margin{font-size:12px;font-weight:600;margin-left:6px}.typeahead{position:relative}.typeahead-list{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:240px;overflow:auto;z-index:50;display:none}.typeahead-list button{width:100%;text-align:left;padding:10px 14px;border:0;background:transparent;cursor:pointer;font-family:inherit;font-size:13.5px;color:var(--text-primary);transition:background var(--transition-fast)}.typeahead-list button:hover{background:var(--surface-hover)}.tag-container{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px;min-height:0}.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:99px;font-size:12.5px;font-weight:500;color:#1d4ed8}.tag-remove{background:none;border:none;cursor:pointer;font-size:15px;line-height:1;color:#3b82f6;padding:0 0 0 2px;font-weight:700}.tag-remove:hover{color:#dc2626}.ac-dd{position:absolute;left:0;right:0;top:100%;margin-top:6px;background:#111827;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);box-shadow:0 12px 30px #00000059;z-index:50;max-height:260px;overflow:auto}.ac-dd ul{list-style:none;margin:0;padding:6px}.ac-dd li{padding:8px 10px;border-radius:var(--radius-sm);cursor:pointer;color:#e5e7eb;font-size:14px;transition:background var(--transition-fast)}.ac-dd li:hover{background:#ffffff14}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:.02em;white-space:nowrap}.badge-blue{background:#dbeafe;color:#1e40af}.badge-green{background:#dcfce7;color:#166534}.badge-red{background:#fee2e2;color:#991b1b}.badge-yellow{background:#fef3c7;color:#92400e}.badge-gray{background:#f1f5f9;color:#475569}.badge-indigo{background:#0f1689;color:#fff}.badge-orange{background:#ee4d2d;color:#fff}.badge-dark{background:#64748b;color:#fff}.badge-default{background:#e2e8f0;color:#475569}.pagination-nav{margin-top:16px}.pagination{list-style:none;display:flex;flex-wrap:wrap;gap:4px;padding:0;margin:0;align-items:center}.pagination li a,.pagination li span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text-primary);text-decoration:none;font-size:13px;font-weight:500;transition:all var(--transition-fast)}.pagination li a:hover{background:var(--surface-hover);border-color:#cbd5e1;transform:translateY(-1px)}.pagination li.active span{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px #3b82f640}.pagination li.disabled span{color:var(--text-muted);background:var(--surface-alt);cursor:default}nav[role=navigation] svg{display:none!important}.tabs{display:flex;gap:8px;padding:8px 0 2px;flex-wrap:wrap;justify-content:center}.tab{display:inline-flex;align-items:center;justify-content:center;padding:10px 22px;border-radius:var(--radius-sm);text-decoration:none;color:var(--text-secondary);background:var(--surface-alt);border:2px solid #cbd5e1;font-weight:600;font-size:14.5px;transition:all var(--transition-fast)}.tab:hover{background:#e2e8f0;color:var(--text-primary);border-color:#94a3b8}.tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 2px 6px #3b82f64d}.tab.disabled{opacity:.55;cursor:not-allowed}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.detail-section{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px}.detail-section h4{margin:0 0 12px;font-size:12.5px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.detail-body{font-size:13.5px;line-height:1.8;color:var(--text-secondary)}.detail-body strong{color:var(--text-primary)}.meta-bar{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:20px;padding:12px 16px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-md)}.meta-item{font-size:13px;color:var(--text-secondary)}.meta-item+.meta-item{padding-left:16px;border-left:1px solid var(--border)}.meta-label{font-weight:600;color:var(--text-primary);margin-right:4px}.thumb{width:52px;height:52px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.06);display:block;background:var(--surface-alt)}.thumb-sm{width:42px;height:42px;border-radius:6px}.thumb-placeholder{display:inline-block;border-radius:var(--radius-sm);background:var(--surface-alt);border:1px solid var(--border)}.history-item{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.history-date{font-size:12px;color:var(--text-muted);white-space:nowrap;min-width:140px}.history-status{font-weight:600;font-size:13px;color:var(--text-primary)}.history-comment{font-size:13px;color:var(--text-secondary);margin-top:2px}.modal-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:2000;align-items:center;justify-content:center;padding:24px}.modal-backdrop.active{display:flex}.modal{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:24px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;animation:slideInDown .25s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-header h3{margin:0;font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:20px;padding:4px;line-height:1;transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.dash-snapshot{display:flex;align-items:center;gap:20px;padding:12px 20px;background:var(--card-bg);border:1px solid var(--border-light);border-radius:10px;margin-bottom:16px}.dash-snap-item{display:flex;align-items:center;gap:8px}.dash-snap-item svg{color:var(--text-secondary);flex-shrink:0}.dash-snap-value{font-size:16px;font-weight:700;color:var(--text-primary)}.dash-snap-label{font-size:13px;color:var(--text-secondary)}.dash-snap-sep{width:1px;height:24px;background:var(--border-light)}.dash-stat-grid,.dash-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px;margin-bottom:20px}.dash-stat{display:flex;align-items:flex-start;gap:14px;padding:20px;background:var(--card-bg);border:1px solid var(--border-light);border-radius:12px;text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}.dash-stat:hover{border-color:var(--stat-accent, var(--accent));box-shadow:0 4px 16px #00000014}.dash-stat-icon{width:48px;height:48px;border-radius:12px;background:var(--stat-bg, rgba(59,130,246,.1));color:var(--stat-accent, var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.dash-stat-value{font-size:22px;font-weight:700;line-height:1.2;color:var(--text-primary)}.dash-stat-label{font-size:13px;color:var(--text-secondary);margin-top:2px}.dash-stat-breakdown{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:6px;font-size:11px;color:var(--text-secondary)}.dash-links{display:flex;flex-direction:column;gap:2px}.dash-links a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;text-decoration:none;color:var(--text-primary);font-size:14px;font-weight:500;transition:background .12s}.dash-links a:hover{background:var(--surface-alt)}.dash-links a svg{color:var(--text-secondary);flex-shrink:0}.dash-link-count{margin-left:auto;font-size:12px;font-weight:600;background:var(--surface-alt);padding:2px 8px;border-radius:10px;color:var(--text-secondary)}.chart-range-toggle{display:inline-flex;border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.chart-range-btn{padding:6px 14px;font-size:12px;font-weight:500;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.chart-range-btn:not(:last-child){border-right:1px solid var(--border-light)}.chart-range-btn:hover{background:var(--surface-alt)}.chart-range-btn.active{background:var(--accent);color:#fff}.dash-sync-grid{display:flex;flex-wrap:wrap;gap:12px}.dash-sync-store{display:flex;flex-direction:column;gap:4px;padding:10px 16px;background:var(--surface-alt);border-radius:8px;min-width:200px}.dash-sync-header{display:flex;align-items:center;gap:8px;font-size:14px}.dash-sync-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dash-sync-ok{background:#22c55e}.dash-sync-warn{background:#f59e0b}.dash-sync-fail{background:#ef4444}.dash-sync-idle{background:#94a3b8}.dash-sync-details{display:flex;flex-direction:column;gap:2px;padding-left:16px}.pie-legend-item{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--border-light)}.pie-legend-item:last-child{border-bottom:none}.pie-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.pie-legend-label{font-weight:600;flex:1}.pie-legend-value{text-align:right;white-space:nowrap}@media(max-width:900px){.dash-stat{padding:16px}.dash-stat-value{font-size:18px}}@media(max-width:768px){.dash-stat-grid,.dash-stats{grid-template-columns:repeat(2,1fr)}div[style*="grid-template-columns: 1fr 2fr"],div[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}.dash-snapshot{flex-wrap:wrap;gap:12px}.dash-snap-sep{display:none}}.marketplace-settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}@media(max-width:1024px){.marketplace-settings-grid{grid-template-columns:1fr}}.order-img-wrap{position:relative;cursor:zoom-in;z-index:1}.order-img-preview{position:fixed;z-index:9999;pointer-events:none;border-radius:8px;box-shadow:0 10px 22px #0f172a40;overflow:hidden;transform:scale(.2);opacity:0;transition:transform .18s ease,opacity .18s ease}.order-img-preview.visible{transform:scale(1);opacity:1}.order-img-preview img{display:block;width:220px;height:220px;object-fit:cover}.order-option-wrap{margin-top:6px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}.order-option-label{font-size:11px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;border-radius:999px;padding:2px 8px}.order-option-label.shopee-label{color:#9a3412;background:#ffedd5;border:1px solid #fdba74}.order-option-label.lazada-label{color:#1e3a5f;background:#dbeafe;border:1px solid #93c5fd}.order-option-pill{display:inline-block;font-size:12px;font-weight:600;color:#1e293b;background:#e2e8f0;border-radius:999px;padding:2px 10px}.action-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;color:var(--text-primary);text-decoration:none;text-align:left;transition:background var(--transition-fast);white-space:nowrap}.action-item:hover{background:var(--surface-hover)}.action-item svg{flex-shrink:0;opacity:.6}.table-wrap.menu-open{overflow:visible}.bulk-loading-overlay{display:none;position:fixed;inset:0;z-index:9999;background:#00000059;align-items:center;justify-content:center}.bulk-loading-overlay.active{display:flex}.bulk-loading-box{background:var(--surface);border-radius:var(--radius-lg);padding:28px 36px;box-shadow:var(--shadow-lg);text-align:center;max-width:320px}.bulk-loading-box .spinner{display:inline-block;width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.bulk-loading-box .msg{margin-top:12px;font-size:14px;font-weight:600;color:var(--text-primary)}.unmatched-link-row{position:relative}.unmatched-results{top:100%;left:0}.unmatched-result-item{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;font-size:12px;transition:background .1s}.unmatched-result-item:hover{background:var(--surface-hover)}.unmatched-result-item img{width:28px;height:28px;object-fit:cover;border-radius:3px;flex-shrink:0}.unmatched-result-item .result-info{flex:1;min-width:0}.unmatched-result-item .result-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unmatched-result-item .result-sku{color:var(--text-muted);font-size:11px}.laz-result-item:hover{background:var(--surface-hover)}@media(max-width:768px){.card form[style*=grid-template-columns]{grid-template-columns:1fr!important}}.api-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.api-explorer{display:grid;grid-template-columns:360px 1fr;gap:14px;margin-top:12px}@media(max-width:1100px){.api-explorer{grid-template-columns:1fr}}.api-panel{border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;background:var(--surface)}.api-search{display:flex;gap:8px;align-items:center}.api-list{margin-top:10px;max-height:520px;overflow:auto;padding-right:4px}.api-cat{margin:10px 0 6px;font-weight:700;color:#111827;font-size:13px;text-transform:uppercase;letter-spacing:.03em}.api-endpoint{width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius-md);padding:10px;margin-bottom:8px;background:var(--surface-alt);cursor:pointer}.api-endpoint:hover{background:var(--surface-hover)}.api-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface);margin-right:8px}.api-badge.get{border-color:#bfdbfe;background:#eff6ff}.api-badge.post{border-color:#bbf7d0;background:#f0fdf4}.api-hint{color:var(--text-secondary);font-size:12px;margin-top:4px}.api-kv{width:100%;border-collapse:collapse}.api-kv th,.api-kv td{border-bottom:1px solid var(--border-light);padding:8px 6px;vertical-align:top}.api-kv th{color:var(--text-primary);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.api-row-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.api-mini{font-size:12px;color:var(--text-secondary)}.api-note{margin-top:10px;padding:10px 14px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm);font-size:12.5px;color:#92400e}.api-split{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media(max-width:900px){.api-split{grid-template-columns:1fr}}.report-stat-card{background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;text-align:center}.report-stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;font-weight:600;letter-spacing:.5px;margin-bottom:6px}.report-stat-value{font-size:22px;font-weight:700;color:var(--text-primary)}.th-sort{color:inherit;text-decoration:none}.th-sort:hover{color:var(--accent)}.month-header{background:var(--surface-alt);position:sticky;top:41px;z-index:5}.month-header:hover{background:var(--surface-hover, var(--surface-alt))}.month-header td{padding-top:12px;padding-bottom:12px;background:inherit}.month-toggle{display:inline-block;width:16px;font-size:10px;color:var(--text-secondary);transition:transform .15s ease;margin-right:4px}.month-toggle.open{transform:rotate(90deg)}.month-row td:first-child{padding-left:28px}.badge-green-subtle{background:#22c55e26;color:#16a34a}.badge-yellow-subtle{background:#eab30826;color:#b45309}.badge-red-subtle{background:#ef444426;color:#dc2626}@media(max-width:1024px){div[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}div[style*="grid-template-columns:repeat(6"]{grid-template-columns:repeat(3,1fr)!important}div[style*="grid-template-columns:repeat(7"]{grid-template-columns:repeat(4,1fr)!important}div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}}@media(max-width:768px){div[style*="grid-template-columns:repeat(6"],div[style*="grid-template-columns:repeat(3"],div[style*="grid-template-columns:repeat(7"],div[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr)!important}}.oc-layout{display:flex;gap:16px;align-items:flex-start}.oc-sidebar{width:220px;flex-shrink:0;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:8px;position:sticky;top:16px}.oc-sidebar-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:6px 8px 4px;font-weight:600}.oc-sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:background .15s;font-family:inherit;font-size:13px;color:var(--text-primary)}.oc-sidebar-item:hover{background:var(--surface-alt)}.oc-sidebar-item.active{background:var(--primary-bg, #eff6ff);box-shadow:inset 3px 0 0 var(--primary, #3b82f6)}.oc-sidebar-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.oc-sidebar-text{flex:1;min-width:0}.oc-sidebar-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.oc-sidebar-url{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.oc-sidebar-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:#cbd5e1}.oc-sidebar-dot.active{background:#22c55e}.oc-content{flex:1;min-width:0}.oc-panel{display:none}.oc-panel.active{display:block}.oc-stat-card{padding:12px;background:var(--surface-alt);border-radius:var(--radius-sm);border:1px solid var(--border-light)}.oc-stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:4px}.oc-stat-value{font-weight:600;font-size:13px;color:var(--text-primary)}.oc-section{padding:16px;background:var(--surface-alt);border-radius:var(--radius-md);border:1px solid var(--border-light);margin-bottom:12px}.oc-section:last-child{margin-bottom:0}.oc-section-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.oc-section-header svg{color:var(--text-secondary)}.oc-cron-box{display:flex;align-items:center;gap:8px;background:#0f172a;border:1px solid #334155;border-radius:var(--radius-sm);padding:10px 12px;overflow-x:auto}.oc-cron-box code{flex:1;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12.5px;color:#e2e8f0;white-space:nowrap;-webkit-user-select:all;user-select:all}.oc-copy-btn{flex-shrink:0;height:30px!important;padding:0 10px!important;font-size:11.5px!important}.oc-cron-help{margin-top:12px;padding:12px 14px;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-sm)}.oc-cron-help-title{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.oc-cron-help ol{margin:0;padding-left:20px;font-size:13px;color:var(--text-secondary);line-height:1.8}.oc-cron-help ol li strong{color:var(--text-primary)}.oc-cron-help ol code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;background:#f1f5f9;padding:1px 6px;border-radius:4px;color:#0f172a}.oc-stepper{display:flex;flex-direction:column;gap:0}.oc-step{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-light);border-bottom:none;background:var(--surface);opacity:.5;transition:opacity .2s,background .2s}.oc-step:first-child{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.oc-step:last-of-type{border-bottom:1px solid var(--border-light);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.oc-step.oc-step-ready{opacity:1}.oc-step.oc-step-done{opacity:1;background:#f0fdf4;border-color:#bbf7d0}.oc-step.oc-step-done+.oc-step{border-top-color:#bbf7d0}.oc-step-number{width:24px;height:24px;border-radius:50%;background:var(--border);color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.oc-step-ready .oc-step-number{background:var(--primary, #3b82f6);color:#fff}.oc-step-done .oc-step-number{background:#22c55e;color:#fff}.oc-step-label{flex:1;font-size:13px;font-weight:600;color:var(--text-primary)}.oc-step-status{font-size:12px;color:var(--text-muted);min-width:60px;text-align:right}.oc-step-done .oc-step-status{color:#166534;font-weight:600}.oc-step-btn{flex-shrink:0}.oc-step-btn:disabled{opacity:.4;cursor:not-allowed}.oc-toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:420px}.oc-toast{padding:12px 16px;border-radius:var(--radius-sm);font-size:13px;line-height:1.5;box-shadow:0 4px 12px #00000026;display:flex;align-items:flex-start;gap:10px;animation:oc-toast-in .25s ease-out;border:1px solid transparent}.oc-toast.info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}.oc-toast.success{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.oc-toast.error{background:#fef2f2;color:#991b1b;border-color:#fecaca}.oc-toast.warning{background:#fffbeb;color:#92400e;border-color:#fde68a}.oc-toast-icon{flex-shrink:0;margin-top:1px}.oc-toast-body{flex:1}.oc-toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;font-size:16px;line-height:1;opacity:.5;padding:0;color:inherit}.oc-toast-close:hover{opacity:1}@keyframes oc-toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes oc-toast-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(20px)}}@media(max-width:768px){.oc-layout{flex-direction:column}.oc-sidebar{width:100%;position:static;display:flex;flex-wrap:wrap;gap:4px;padding:6px}.oc-sidebar-label{width:100%;padding:4px 6px 2px}.oc-sidebar-item{flex:0 0 auto;padding:6px 10px}.oc-sidebar-url{display:none}}.perm-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}.perm-toolbar-label{font-weight:700;font-size:14px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.perm-toolbar-actions{display:flex;gap:6px}.perm-toolbar-actions button{font-size:12px;padding:4px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.perm-toolbar-actions button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.perm-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;padding:1px 7px;border-radius:99px;font-size:11px;font-weight:600;line-height:1.4}.perm-badge-gray{background:#f1f5f9;color:var(--text-muted)}.perm-badge-blue{background:#3b82f61f;color:#2563eb}.perm-badge-green{background:#22c55e1f;color:#16a34a}.perm-group{border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:12px;overflow:hidden}.perm-group summary{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:600;font-size:13px;color:var(--text-primary);background:var(--surface-alt);list-style:none;transition:background var(--transition-fast)}.perm-group summary:hover{background:#f1f5f9}.perm-group summary::-webkit-details-marker{display:none}.perm-group summary:before{content:"";display:inline-block;width:0;height:0;border-left:5px solid var(--text-muted);border-top:4px solid transparent;border-bottom:4px solid transparent;transition:transform var(--transition-fast);flex-shrink:0}.perm-group[open]>summary:before{transform:rotate(90deg)}.perm-group summary .perm-badge{margin-left:auto}.perm-group-body{padding:0 16px 16px}.perm-parent-row{display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:12px;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:var(--radius-sm)}.perm-parent-row .perm-parent-info{flex:1}.perm-parent-row .perm-parent-label{font-weight:600;font-size:13px;color:var(--text-primary)}.perm-parent-row .perm-parent-desc{font-size:11.5px;color:var(--text-muted);margin-top:1px}.perm-parent-row .perm-parent-hint{font-size:11px;color:var(--accent);font-weight:500;white-space:nowrap}.perm-subgroup-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:4px 0 8px;margin-top:4px;border-bottom:1px solid var(--border-light);margin-bottom:8px}.perm-children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px}.perm-card{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);background:var(--surface)}.perm-card:hover{border-color:var(--accent);background:#3b82f608}.perm-card.is-checked{border-color:var(--accent);background:#3b82f614}.pim-wrap{margin-top:10px;border:1px solid var(--border-light, #f1f5f9);background:var(--surface-alt, #f8fafc);border-radius:var(--radius-lg, 16px);padding:16px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.06))}.pim-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.pim-drop{border:2px dashed rgba(255,255,255,.22);border-radius:16px;padding:16px;background:#0000001a;position:relative;min-height:124px}.pim-drop.dragover{border-color:#58a0ffa6;background:#58a0ff0f}.pim-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:12px}.pim-item{border:1px solid rgba(255,255,255,.14);border-radius:14px;overflow:hidden;background:#0000001f;cursor:grab;position:relative}.pim-item:active{cursor:grabbing}.pim-item-top{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:#0000001f}.pim-thumb-wrap{width:100%;aspect-ratio:1 / 1;overflow:hidden}.pim-thumb{width:100%;height:100%;object-fit:cover;display:block}.pim-badge{background:#000000a6;border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:4px 8px;font-size:12px;color:#fff;line-height:1}.pim-remove{border:none;background:transparent;color:#ff3b3b;font-size:22px;line-height:1;padding:0 4px;cursor:pointer}.pim-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#ffffffbf;pointer-events:none}.pim-empty.hidden{display:none}.pim-modal{display:none;position:fixed;inset:0;z-index:9999}.pim-modal[aria-hidden=false]{display:block}.pim-modal-backdrop{position:absolute;inset:0;background:#0000008c}.pim-modal-card{position:relative;max-width:980px;margin:6vh auto;max-height:88vh;display:flex;flex-direction:column;background:#141414f5;border:1px solid rgba(255,255,255,.12);border-radius:14px;box-shadow:0 12px 50px #00000080;color:#ffffffeb}.pim-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid rgba(255,255,255,.08)}.pim-modal-actions{display:flex;align-items:center;gap:10px}.pim-modal-msg{font-weight:700;color:#2ecc71;font-size:13px}.pim-modal-msg.error{color:#e74c3c}.pim-modal-msg.info{color:#2ecc71}.pim-modal-body{padding:14px;flex:1 1 auto;overflow:auto}.pim-server-filter-bar{display:flex;align-items:center;gap:10px;margin:0 0 12px}.pim-server-search{flex:1;min-width:0;padding:6px 10px;font-size:13px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#00000040;color:#ffffffeb;outline:none}.pim-server-search::placeholder{color:#ffffff73}.pim-server-search:focus{border-color:#58a0ff8c}.pim-server-sort{padding:6px 10px;font-size:13px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#00000040;color:#ffffffeb;outline:none;cursor:pointer}.pim-server-sort:focus{border-color:#58a0ff8c}.pim-server-nav{display:flex;align-items:center;gap:10px;margin:8px 0 12px}.pim-server-path{font-size:12px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pim-server-section-title{font-size:12px;font-weight:700;opacity:.85;margin:10px 0 8px}.pim-server-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.pim-server-item{border:1px solid rgba(255,255,255,.1);background:#00000038;border-radius:12px;overflow:hidden;cursor:pointer}.pim-server-item:hover{border-color:#58a0ff73}.pim-server-item img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}.pim-server-item .label{padding:8px;font-size:12px;opacity:.85;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pim-server-item .icon{width:100%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:46px;opacity:.9}.pim-server-empty{margin-top:12px;opacity:.75;display:none;color:#ffffffc7}.pim-server-empty.show{display:block}.pim-modal-card,.pim-modal-card *{color:#ffffffeb}.pim-modal-card .muted,.pim-modal-card small,.pim-modal-card .hint{color:#ffffffb8!important}.pim-modal-header h3{margin:0;font-size:16px;font-weight:700}.pim-modal-header .btn{color:#ffffffeb}.pim-modal-header .btn.secondary{border-color:#ffffff2e}.pim-notice{display:none;margin:8px 0 12px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:#58a0ff1a;color:#ffffffe6;font-size:13px}.pim-notice.show{display:block}.po-timeline{position:relative;padding-left:32px}.po-timeline:before{content:"";position:absolute;left:14px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-entry{position:relative;margin-bottom:16px}.timeline-icon{position:absolute;left:-32px;top:2px;width:28px;height:28px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;background:var(--surface)}.timeline-content{padding-left:8px}.timeline-text{font-size:13px;line-height:1.4}.timeline-meta{font-size:11px;color:#94a3b8;margin-top:2px}.option-header-row td{border-top:none!important}.option-value-row td{border-top:none!important;font-size:12px}.tracking-timeline{position:relative;padding-left:24px}.tracking-timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:var(--border)}.tracking-event{position:relative;padding-bottom:16px}.tracking-event:last-child{padding-bottom:0}.tracking-event:before{content:"";position:absolute;left:-20px;top:6px;width:10px;height:10px;border-radius:50%;background:var(--border);border:2px solid var(--bg)}.tracking-event:first-child:before{background:var(--accent)}.toggle-switch{position:relative;display:inline-block;width:40px;height:22px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--border-light, #ccc);border-radius:22px;transition:.2s}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s}.toggle-switch input:checked+.toggle-slider{background:var(--primary, #4f46e5)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(18px)}.product-result-item{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;font-size:13px;transition:background .1s}.product-result-item:hover{background:var(--surface-hover)}.product-result-item img{width:32px;height:32px;object-fit:cover;border-radius:3px;flex-shrink:0}.product-result-item .pr-info{flex:1;min-width:0}.product-result-item .pr-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.product-result-item .pr-meta{color:var(--text-muted);font-size:11px}.review-stars{display:inline-flex;gap:1px}.star-filled{color:#f59e0b}.star-empty{color:#d1d5db}.review-platform{display:inline-block;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.02em}.review-platform--shopee{background:#fff1f2;color:#e11d48}.review-platform--lazada{background:#eff6ff;color:#1d4ed8}.review-thumb{width:64px;height:64px;object-fit:cover;border-radius:6px;border:1px solid var(--border-light);transition:transform var(--transition-fast)}.review-thumb:hover{transform:scale(1.08)}.review-media-inline{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.review-thumb-sm{width:32px;height:32px;object-fit:cover;border-radius:4px;border:1px solid var(--border-light)}.review-media-more{font-size:11px;color:var(--text-muted);font-weight:600}.review-media-badge{display:inline-flex;align-items:center;gap:2px;font-size:11px;color:#6366f1;font-weight:600;background:#eef2ff;padding:2px 6px;border-radius:4px}.review-detail{padding:4px 0}.d-flex{display:flex}.d-none{display:none}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-20{gap:20px}.mt-0{margin-top:0}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-0{margin-bottom:0}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.p-0{padding:0}.w-full{width:100%}.max-w-300{max-width:300px}.hidden{display:none!important}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.text-right{text-align:right}.text-center{text-align:center}.text-nowrap{white-space:nowrap}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-sm{font-size:13px}.text-xs{font-size:12px}.font-semibold{font-weight:600}.font-bold{font-weight:700}.option-row td{background:var(--surface-alt)}@media print{.sidebar,.sidebar-fab,.sidebar-backdrop,.topbar{display:none!important}.content{margin-left:0!important;padding:0!important}.content-inner{max-width:none}}@media(max-width:1280px){.content{padding:0 24px 24px}}@media(max-width:1024px){.content{padding:0 20px 20px}.card{padding:20px}.detail-grid{gap:16px}}@media(max-width:768px){.sidebar{box-shadow:4px 0 24px #0000004d}.content{margin-left:0!important;padding:0 16px 24px}.content.collapsed{margin-left:0}.topbar{padding:16px 0 10px}.page-header{flex-direction:column;align-items:flex-start;gap:10px}.page-header-actions{width:100%}.form-grid,.detail-grid{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.toolbar form{flex-wrap:wrap}.card{padding:16px;border-radius:var(--radius-md)}.meta-bar{flex-direction:column;align-items:flex-start;gap:8px}.meta-item+.meta-item{padding-left:0;border-left:none;padding-top:8px;border-top:1px solid var(--border)}.cost-breakdown-fields{display:flex;flex-direction:column;gap:8px}.cost-breakdown-op{padding:0}.profit-metrics{grid-template-columns:1fr}}@media(max-width:480px){.content{padding:0 12px 20px}.card{padding:14px}.page-header h2{font-size:1.15rem}.btn{height:38px;padding:0 14px;font-size:13px}.btn.small{height:32px;padding:0 10px}.input{height:38px;font-size:13px}table th,table td{padding:10px;font-size:13px}.pagination li a,.pagination li span{min-width:32px;height:32px;padding:0 8px;font-size:12px}}
