.print-sheet{width:148mm;min-height:210mm;margin:0 auto;padding:6mm 8mm;background:#fce4ec;font-family:Noto Sans TC,sans-serif;font-size:10pt;color:#000;box-shadow:0 4px 20px #0000001a}.bill-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.bill-title{font-family:"Noto Serif TC",serif;font-size:18pt;font-weight:700}.bill-meta{text-align:right;font-size:10pt;line-height:1.5}.bill-table{width:100%;border-collapse:collapse;margin:8px 0}.bill-table th,.bill-table td{border:1px solid #333;padding:4px 6px;font-size:9pt}.bill-table th{background:#ffffff80;font-weight:600}.bill-table .num{text-align:right;white-space:nowrap}.bill-footer{display:flex;justify-content:space-between;margin-top:12px;font-size:9pt}.bill-totals{line-height:1.6}.bill-terms{text-align:right;line-height:1.5}.bill-terms p{margin:0}.print-time{margin-top:8px;font-size:8pt}@media print{.print-sheet{box-shadow:none;width:100%;min-height:auto;padding:0;background:#fce4ec!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}@media screen{.print-sheet{transform-origin:top center}@media(min-width:601px)and (max-width:767px){.print-sheet{transform:scale(.85);margin:-20px auto}}}.mobile-print-page{display:flex;flex-direction:column;margin:-20px -16px -24px;height:calc(100dvh - 112px - env(safe-area-inset-bottom,0px));overflow:hidden}.mobile-print-scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:12px 16px 16px;-webkit-overflow-scrolling:touch}.mobile-print-scroll .print-sheet{transform:none;margin:0 auto;width:100%;max-width:148mm;min-height:auto;box-shadow:0 2px 12px #00000014}.desktop-print-page{padding-bottom:24px}.desktop-print-actions{margin-bottom:16px}:root{--bg: #f1f5f9;--surface: #ffffff;--surface-2: #f8fafc;--border: #e2e8f0;--border-strong: #cbd5e1;--text: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-soft: rgba(37, 99, 235, .1);--cyan: #0891b2;--cyan-soft: rgba(8, 145, 178, .1);--success: #059669;--success-soft: rgba(5, 150, 105, .1);--warning: #d97706;--warning-soft: rgba(217, 119, 6, .1);--header-bg: #0f172a;--radius: 10px;--radius-sm: 6px;--font: "Noto Sans SC", "PingFang SC", system-ui, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Consolas", monospace}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--surface-2: #334155;--border: #334155;--border-strong: #475569;--text: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--primary: #3b82f6;--primary-hover: #2563eb;--primary-soft: rgba(59, 130, 246, .15);--cyan: #22d3ee;--cyan-soft: rgba(34, 211, 238, .12);--success: #34d399;--success-soft: rgba(52, 211, 153, .12);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .12);--header-bg: #020617}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}#root{position:relative}.app-layout{min-height:100vh;display:flex;flex-direction:column}.layout-desktop{min-height:100vh}.layout-desktop .app-sider{background:var(--surface)!important;border-right:1px solid var(--border)}.layout-desktop .app-sider .ant-layout-sider-children{display:flex;flex-direction:column}.sider-logo{display:flex;align-items:center;gap:10px;height:56px;padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;transition:padding .2s}.sider-logo--collapsed{justify-content:center;padding:0}.sider-logo-text{font-size:.875rem;font-weight:600;color:var(--text);white-space:nowrap;line-height:1.3}.sider-logo-icon{flex-shrink:0}.app-sider-menu{flex:1;border-inline-end:none!important;padding:8px 0}.app-sider-menu .ant-menu-item{margin:2px 8px!important;width:calc(100% - 16px)!important;border-radius:var(--radius-sm)!important}.app-sider.ant-layout-sider-collapsed .app-sider-menu .ant-menu-item{margin:2px 4px!important;width:calc(100% - 8px)!important;padding-inline:calc(50% - 14px)!important}.app-sider .ant-layout-sider-trigger{background:var(--surface-2);color:var(--text-secondary);border-top:1px solid var(--border)}.app-sider .ant-layout-sider-trigger:hover{color:var(--primary);background:var(--primary-soft)}.app-topbar{display:flex!important;align-items:center;justify-content:space-between;height:56px!important;padding:0 24px!important;background:var(--surface)!important;border-bottom:1px solid var(--border);line-height:56px}.topbar-title{margin:0;font-size:1rem;font-weight:600;color:var(--text);line-height:1}.topbar-actions{display:flex;align-items:center;gap:8px}.topbar-user{font-size:.875rem;color:var(--text-secondary)}.theme-toggle{color:var(--text-secondary)!important;font-size:.8125rem!important;gap:4px}.theme-toggle:hover{color:var(--primary)!important;background:var(--primary-soft)!important}.app-main-content{margin:0;padding:24px;background:var(--bg);min-height:calc(100vh - 56px);overflow:auto}.mobile-header{position:sticky;top:0;z-index:200;background:var(--surface);padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:48px;border-bottom:1px solid var(--border)}.mobile-header-logo{display:flex;align-items:center;gap:8px;font-size:.8125rem;font-weight:600;color:var(--text)}.mobile-header-user{color:var(--text-secondary)!important;font-size:.8125rem!important}.mobile-header--subpage{display:grid;grid-template-columns:40px 1fr 40px;align-items:center;padding:0 8px}.mobile-header--tab{display:grid;grid-template-columns:40px 1fr auto;align-items:center;padding:0 8px}.mobile-header--tab .mobile-header-user{justify-self:end}.mobile-header-back{width:40px;height:40px;padding:0!important;color:var(--text)!important;font-size:1rem!important}.mobile-header-title{margin:0;text-align:center;font-size:.9375rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-header-placeholder{width:40px}.app-content{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:20px 16px 24px}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:6px 0 calc(6px + env(safe-area-inset-bottom));z-index:100}@media(min-width:768px){.mobile-bottom-nav{display:none}.has-bottom-nav{padding-bottom:0}}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-muted);text-decoration:none;font-size:.625rem;font-weight:500;padding:4px 12px;border-radius:var(--radius-sm);transition:color .15s}.mobile-bottom-nav a.active{color:var(--primary)}.mobile-bottom-nav .anticon{font-size:1.125rem}.has-bottom-nav{padding-bottom:64px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;flex-wrap:wrap;padding-bottom:20px;border-bottom:1px solid var(--border)}.page-header-main{flex:1;min-width:0}.page-header h1{font-size:1.375rem;font-weight:600;margin:0 0 4px;color:var(--text);letter-spacing:-.02em}.page-header p{margin:0;color:var(--text-secondary);font-size:.8125rem}.page-header-action{flex-shrink:0}@media(min-width:768px){.layout-desktop .page-header h1{display:none}.layout-desktop .page-header{border-bottom:none;padding-bottom:0;margin-bottom:20px}}.card-grid{display:grid;gap:12px;grid-template-columns:1fr;margin-bottom:20px}@media(min-width:640px){.card-grid{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary)}.stat-card--cyan:before{background:var(--cyan)}.stat-card--success:before{background:var(--success)}.stat-card .label{font-size:.75rem;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.06em}.stat-card .value{font-family:var(--font-mono);font-size:2rem;font-weight:600;color:var(--text);margin-top:4px;line-height:1;letter-spacing:-.03em}.stat-card--cyan .value{color:var(--cyan)}.stat-card--success .value{color:var(--success)}.content-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.content-panel-header{padding:14px 20px;border-bottom:1px solid var(--border);font-size:.875rem;font-weight:600;color:var(--text);background:var(--surface-2);letter-spacing:.01em}.content-panel-body{padding:0}.content-panel-body--padded{padding:20px}.list-row{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border);color:inherit;text-decoration:none;transition:background .12s}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--surface-2)}.list-row-icon{margin-right:8px;color:var(--primary);font-size:.875rem}.list-row-meta{margin-left:8px;color:var(--text-muted);font-size:.8125rem;font-family:var(--font-mono)}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted);font-size:.8125rem}.status-chip{display:inline-block;font-size:.6875rem;font-weight:600;padding:3px 8px;border-radius:var(--radius-sm);line-height:1.4;letter-spacing:.02em;text-transform:uppercase}.status-chip--draft{background:var(--warning-soft);color:var(--warning)}.status-chip--confirmed{background:var(--success-soft);color:var(--success)}.status-chip--cancelled{background:var(--surface-2);color:var(--text-muted)}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.mobile-card-list{display:flex;flex-direction:column;gap:10px}.mobile-card-list--loading,.mobile-card-list--empty{display:flex;justify-content:center;padding:48px 16px}.mobile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px}.mobile-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}.mobile-card-title{font-size:.9375rem;font-weight:600;color:var(--text);line-height:1.35;word-break:break-all}.mobile-card-meta{display:flex;flex-wrap:wrap;gap:6px 14px;font-size:.8125rem;color:var(--text-secondary);margin-bottom:10px}.mobile-card-meta span{display:inline-flex;align-items:center;gap:4px}.mobile-card-meta .label{color:var(--text-muted)}.mobile-card-meta .value-mono{font-family:var(--font-mono)}.mobile-card-actions{display:flex;flex-wrap:wrap;gap:8px;padding-top:10px;border-top:1px solid var(--border)}.mobile-card-link{display:block;color:inherit;text-decoration:none}.mobile-card-link:active{opacity:.85}.mobile-card-link--chevron{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;column-gap:8px;row-gap:8px;align-items:center}.mobile-card-header--shipment{grid-column:1 / -1;margin-bottom:0}.mobile-card-link--chevron .mobile-card-meta{grid-column:1;grid-row:2;margin-bottom:0}.mobile-card-link--chevron .mobile-card-chevron{grid-column:2;grid-row:2;flex-shrink:0;font-size:.75rem;color:var(--text-muted)}.mobile-status-tag{flex-shrink:0;font-size:.6875rem;line-height:1.5;padding:0 8px;border-radius:4px;color:#fff;font-weight:500}.mobile-card-sentinel{display:flex;justify-content:center;align-items:center;min-height:40px;padding:8px 0 4px}.mobile-card-end{font-size:.75rem;color:var(--text-muted)}@media(min-width:768px){.mobile-only{display:none!important}}@media(max-width:767px){.desktop-only{display:none!important}.page-header{flex-direction:column;align-items:stretch;padding-bottom:16px;margin-bottom:16px}.layout-mobile--subpage .page-header h1{display:none}.layout-mobile--subpage .page-header:not(:has(.page-header-action,.page-header-main p)){display:none;margin:0}.layout-mobile--subpage .page-header{border-bottom:none;padding-bottom:0;margin-bottom:12px}.page-header-action{width:100%;max-width:100%;flex-shrink:1}.page-header-action .ant-space{display:flex;flex-wrap:wrap;gap:8px!important;width:100%}.page-header-action .ant-btn{font-size:.8125rem;padding-inline:10px}.mobile-shipment-page,.mobile-list-page{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}.mobile-shipment-list{margin-bottom:8px}.shipment-flow-steps{display:flex;justify-content:center;align-items:flex-start;padding:8px 12px 14px;margin-bottom:4px}.shipment-flow-steps__item{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:48px}.shipment-flow-steps__icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px}.shipment-flow-steps__label{font-size:.625rem;color:var(--text-muted);white-space:nowrap;line-height:1.2}.shipment-flow-steps__connector{flex:1;min-width:12px;max-width:28px;height:1px;background:var(--border);margin-top:11px;align-self:flex-start}.mobile-fab-center{position:fixed;left:50%;bottom:calc(76px + env(safe-area-inset-bottom,0px));transform:translate(-50%);z-index:90}.mobile-fab-center .ant-btn{display:inline-flex;align-items:center;justify-content:center;width:168px;border-radius:24px;padding-inline:16px;height:44px;box-shadow:0 4px 16px #2563eb59}.mobile-fab-center a{display:inline-flex;text-decoration:none}.mobile-filter-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.mobile-filter-row{width:100%}.mobile-filter-row--2col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mobile-filter-row--2col .ant-select,.mobile-filter-row.ant-picker-range{width:100%!important}.filter-bar .ant-input-search,.filter-bar .ant-select,.filter-bar .ant-picker{width:100%!important;max-width:none!important}.mobile-form-page{margin-bottom:16px}.shipment-lines-title{margin-bottom:10px;font-weight:600;font-size:.875rem;color:var(--text-secondary)}.mobile-line-items{display:flex;flex-direction:column;gap:12px}.mobile-line-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.mobile-line-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.mobile-line-field{margin-bottom:10px}.mobile-line-field label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:4px}.mobile-line-grid{display:flex;flex-direction:column;gap:6px}.mobile-line-grid-labels,.mobile-line-grid-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;align-items:center}.mobile-line-grid-labels span{font-size:.75rem;color:var(--text-muted)}.mobile-line-grid-meta{padding-top:2px}.mobile-line-amount{min-height:32px;display:flex;align-items:center;justify-content:flex-end;font-size:.875rem;font-weight:600;color:var(--text);padding-right:2px;line-height:32px}.mobile-form-actions .ant-space-item{width:100%}.mobile-line-stock-hint{margin-top:4px;font-size:.6875rem;color:var(--text-muted)}.line-stock-error{margin-top:4px;font-size:.6875rem;color:var(--danger, #ff4d4f);line-height:1.35}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;background-color:var(--bg)}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:36px 32px}.login-card h1{font-size:1.25rem;font-weight:600;text-align:center;margin:0 0 6px;color:var(--text);letter-spacing:-.02em}.login-card .subtitle{text-align:center;color:var(--text-muted);font-size:.8125rem;margin-bottom:28px}.brand-mark{width:48px;height:48px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center}.brand-mark:after{display:none}.btn-confirm{background:var(--success)!important;border-color:var(--success)!important}.btn-confirm:hover{background:#047857!important;border-color:#047857!important}.ant-btn{font-weight:500;border-radius:var(--radius-sm)!important;box-shadow:none!important}.ant-btn-primary{background:var(--primary)!important;border-color:var(--primary)!important}.ant-btn-primary:hover{background:var(--primary-hover)!important;border-color:var(--primary-hover)!important}.ant-input,.ant-input-affix-wrapper,.ant-input-number,.ant-picker,.ant-select-selector{border-color:var(--border)!important;border-radius:var(--radius-sm)!important;background:var(--surface)!important}.ant-input:focus,.ant-input-affix-wrapper-focused,.ant-input-number-focused,.ant-picker-focused,.ant-select-focused .ant-select-selector{border-color:var(--primary)!important;box-shadow:0 0 0 2px var(--primary-soft)!important}.ant-table-wrapper .ant-table{background:transparent!important}.ant-table-thead>tr>th{background:var(--surface-2)!important;color:var(--text-secondary)!important;font-weight:600!important;font-size:.75rem!important;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)!important}.ant-table-tbody>tr>td{border-bottom:1px solid var(--border)!important;font-size:.875rem}.ant-table-tbody>tr:hover>td{background:var(--surface-2)!important}.ant-tag{border-radius:var(--radius-sm)!important;font-weight:600;font-size:.6875rem!important;border:none!important}.ant-card{border-radius:var(--radius)!important;border-color:var(--border)!important;box-shadow:none!important;background:var(--surface)!important}.ant-card-head{border-bottom-color:var(--border)!important;background:var(--surface-2)!important}.ant-modal-content{border-radius:var(--radius)!important;box-shadow:none!important;border:1px solid var(--border)}.ant-form-item-label>label{color:var(--text-secondary)!important;font-weight:500!important;font-size:.8125rem!important}.ant-descriptions-item-label{color:var(--text-muted)!important;font-size:.8125rem!important}.ant-dropdown-menu{border-radius:var(--radius-sm)!important;border:1px solid var(--border);box-shadow:none!important;padding:4px!important}.content-panel .ant-table-wrapper{margin:0}@media print{.layout-desktop,.mobile-header,.mobile-bottom-nav,.no-print{display:none!important}body{background:#fff!important}.print-sheet{width:148mm;min-height:210mm;margin:0 auto;padding:8mm;background:#fce4ec;font-size:11pt}}@page{size:A5 portrait;margin:8mm}
