:root{color:#0f172a;background:#f1f5f0;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,sans-serif;--primary: #1d6b56;--primary-dark: #145042;--surface: #ffffff;--border: #d8e4de;--muted: #5b6b70;--warn: #c46a1a;--sidebar: #132f2c}*{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased}button,input,select,textarea{font:inherit}button{cursor:pointer;transition:background .2s,border-color .2s,color .2s}button:disabled{cursor:not-allowed;opacity:.55}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px minmax(0,1fr)}.app-shell:has(>.login-shell),.app-shell:has(>.auth-loading){display:block;grid-template-columns:unset}.auth-loading{min-height:100vh;display:grid;place-items:center;color:var(--muted);font-size:15px}.login-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:#f1f5f0}.login-hero{position:relative;background:linear-gradient(155deg,#0f2a26,#1d6b56 55%,#2a8a6e);color:#ecfdf5;overflow:hidden;display:flex;align-items:center;padding:48px 40px}.login-hero-inner{position:relative;z-index:1;max-width:420px}.login-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:#ffffff1f;font-size:13px;font-weight:600;margin-bottom:24px}.login-hero h1{margin:0 0 14px;font-size:clamp(1.75rem,3vw,2.25rem);line-height:1.2;letter-spacing:-.02em}.login-hero>.login-hero-inner>p,.login-hero-inner>p{margin:0 0 28px;color:#ecfdf5d1;font-size:.95rem;line-height:1.55}.login-flow-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.login-flow-list li{display:flex;align-items:center;gap:10px;font-size:14px;color:#ecfdf5e6}.login-hero-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 80%,rgba(255,255,255,.08) 0%,transparent 45%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.06) 0%,transparent 40%);pointer-events:none}.login-panel{display:flex;align-items:center;justify-content:center;padding:32px 24px}.login-panel-inner{width:min(400px,100%)}.login-panel-head{margin-bottom:28px}.login-panel-head h2{margin:0 0 8px;font-size:1.65rem;color:#0f172a;letter-spacing:-.02em}.login-panel-head p{margin:0;color:var(--muted);font-size:.92rem}.login-form{display:flex;flex-direction:column;gap:12px}.input-wrap{position:relative;display:flex;align-items:center}.input-wrap .input-icon{position:absolute;left:12px;color:var(--muted);pointer-events:none}.input-wrap input{width:100%;padding:12px 44px 12px 40px;border:1px solid var(--border);border-radius:10px;background:#fff;transition:border-color .2s,box-shadow .2s}.input-wrap input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #1d6b5626}.input-action{position:absolute;right:4px;width:40px;height:40px;border:none;background:transparent;color:var(--muted);border-radius:8px;display:grid;place-items:center;cursor:pointer}.input-action:hover{color:var(--primary);background:#f4faf7}.login-error{color:#b42318;font-size:13px;margin:0}.login-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;min-height:48px}.demo-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--border)}.demo-title{margin:0 0 12px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.demo-card{text-align:left;padding:12px 14px;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;transition:border-color .2s,background .2s}.demo-card:hover{border-color:var(--primary);background:#f7fbf9}.demo-card b{display:block;font-size:14px;color:#0f172a;margin-bottom:4px}.demo-card span{display:block;font-size:12px;color:var(--muted);line-height:1.4}.demo-card em{display:block;margin-top:6px;font-size:11px;font-style:normal;color:var(--primary);font-weight:600}@media(max-width:900px){.login-shell{grid-template-columns:1fr}.login-hero{min-height:auto;padding:32px 24px}.login-hero h1{font-size:1.5rem}.login-flow-list{grid-template-columns:1fr 1fr;display:grid}}@media(max-width:480px){.demo-grid{grid-template-columns:1fr}}.admin-tabs{display:flex;gap:8px;margin-bottom:4px}.admin-tabs button{padding:10px 18px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;transition:background .2s,color .2s,border-color .2s}.admin-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}.admin-tabs button:hover:not(.active){border-color:var(--primary);color:var(--primary)}.admin-table code{font-size:12px;color:var(--primary)}.tag{display:inline-block;padding:2px 8px;border-radius:6px;background:#eef6f2;color:#145042;font-size:12px;font-weight:600}.tag.muted{background:#f1f5f9;color:var(--muted)}.status-pill{font-size:12px;font-weight:600;padding:2px 8px;border-radius:6px}.status-pill.on{background:#dcfce7;color:#166534}.status-pill.off{background:#fee2e2;color:#991b1b}.role-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}.role-card{border:1px solid var(--border);border-radius:12px;padding:16px;background:#fafcfb;transition:border-color .2s,box-shadow .2s}.role-card.active,.role-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #1d6b561a}.role-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px}.role-card-head b{display:block;color:#0f172a;margin-bottom:4px}.role-card-head code{font-size:11px;color:var(--muted)}.role-perm-preview{margin:0 0 12px;font-size:13px;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0f172a73;display:grid;place-items:center;padding:20px}.modal-card{width:min(480px,100%);max-height:min(90vh,720px);overflow:auto;background:#fff;border-radius:14px;padding:22px;box-shadow:0 20px 50px #00000026}.modal-card.wide{width:min(560px,100%)}.modal-card h3{margin:0 0 18px;font-size:1.15rem;color:#0f172a}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.form-stack.compact-top{margin-top:16px}.hint.warn{color:var(--warn)}.perm-editor{max-height:50vh;overflow:auto}.perm-group{margin-bottom:16px}.perm-group h4{margin:0 0 8px;font-size:13px;color:var(--muted);font-weight:700}.perm-checks{display:flex;flex-direction:column;gap:6px}.perm-check{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:2px 10px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .15s}.perm-check:hover{background:#f7fbf9}.perm-check input{grid-row:1 / 3;align-self:center;width:18px;height:18px;cursor:pointer}.perm-check span{font-size:14px;color:#0f172a;font-weight:500}.perm-check code{grid-column:2;font-size:11px;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:12px}.user-chip{font-size:13px;color:var(--muted);white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.role-gate{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(165deg,#e8f0ec,#f1f5f0 45%,#dfeae4)}.role-gate-inner{width:min(480px,100%)}.role-brand{text-align:center;margin-bottom:28px;color:var(--sidebar)}.role-brand h1{margin:12px 0 6px;font-size:1.75rem}.role-brand p{margin:0;color:var(--muted)}.role-cards{display:flex;flex-direction:column;gap:14px}.role-card{width:100%;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:20px;text-align:left;display:flex;flex-direction:column;gap:8px;min-height:120px;box-shadow:0 8px 24px #132f2c0f}.role-card:hover{border-color:var(--primary);background:#f7fbf9}.role-card.staff{border-color:#b8d4c8}.role-card b{font-size:1.1rem;color:#0f172a}.role-card span{color:var(--muted);font-size:.9rem;line-height:1.45}.role-card svg{color:var(--primary)}.sidebar{position:sticky;top:0;height:100vh;background:var(--sidebar);color:#e8f4ef;padding:20px 12px;display:flex;flex-direction:column;gap:4px;overflow-y:auto}.brand{display:flex;gap:10px;align-items:center;padding:4px 10px 18px}.brand strong,.brand span{display:block}.brand span{color:#9bb8b0;font-size:12px;margin-top:2px}.sidebar button{border:0;color:inherit;background:transparent;min-height:44px;display:flex;align-items:center;gap:10px;border-radius:8px;padding:0 12px;position:relative}.nav-group-label{margin:14px 12px 6px;padding:0 4px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#ffffff6b}.sidebar button em{margin-left:auto;font-style:normal;font-size:11px;background:#2a5a52;padding:2px 7px;border-radius:999px}.sidebar button.active,.sidebar button:hover{background:#1f4a44;color:#fff}.switch-role{margin-top:auto!important;color:#9bb8b0!important;font-size:13px}.content{padding:24px 28px 32px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}.eyebrow{margin:0 0 4px;font-size:12px;font-weight:700;color:var(--primary);letter-spacing:.04em;text-transform:uppercase}h1{margin:0;font-size:1.65rem;font-weight:700;color:#0f172a}h2,h3{margin:0;font-size:1rem;display:flex;align-items:center;gap:8px;color:#0f172a}.topbar p{margin:6px 0 0;color:var(--muted);font-size:.92rem}.primary,.ghost{min-height:44px;border-radius:8px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600}.primary{border:0;background:var(--primary);color:#fff}.primary:hover:not(:disabled){background:var(--primary-dark)}.ghost{border:1px solid var(--border);background:var(--surface);color:#1e3a34}.ghost:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.icon-btn{width:44px;padding:0}.slim{min-height:40px;padding-inline:14px}.full{width:100%}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;top:16px;left:50%;transform:translate(-50%);z-index:30;background:#0f172a;color:#fff;padding:12px 18px;border-radius:10px;font-size:14px;max-width:min(92vw,420px);box-shadow:0 12px 32px #0f172a33}.page-stack{display:flex;flex-direction:column;gap:14px}.single-col{max-width:560px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:0 4px 16px #132f2c0a}.panel.highlight{border-color:#b8d4c8;background:linear-gradient(180deg,#f8fcfa,#fff)}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.hint{margin:0 0 14px;color:var(--muted);font-size:.9rem;line-height:1.5}.pill{display:inline-flex;align-items:center;min-height:26px;border-radius:999px;background:#e4f0eb;color:var(--primary);padding:0 10px;font-size:12px;font-weight:700}.pill.warn{background:#fff3e6;color:var(--warn)}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.metric span{color:var(--muted);font-size:13px}.metric strong{display:block;font-size:1.75rem;margin-top:8px;color:#0f172a}.metric small{font-size:.85rem;margin-left:4px;color:var(--muted);font-weight:500}.scenario-banner{background:linear-gradient(135deg,#edf7f2,#fff);border:1px solid #c5ddd2;border-radius:12px;padding:18px}.scenario-banner h2{margin-bottom:8px}.scenario-banner p{margin:0 0 14px;color:var(--muted)}.scenario-actions{display:flex;flex-wrap:wrap;gap:10px}.step-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.step-card{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:14px;text-align:left;min-height:88px;display:flex;flex-direction:column;gap:4px}.step-card:hover:not(:disabled){border-color:var(--primary)}.step-no{width:28px;height:28px;border-radius:50%;background:#e4f0eb;color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:13px}.step-card b{color:#0f172a}.step-card small{color:var(--muted)}.form-stack{display:flex;flex-direction:column;gap:10px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field-label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:-4px}.field-label em{color:#dc2626;font-style:normal}.form-stack input,.form-stack select,.form-stack textarea,.panel>select,.track-select{width:100%;min-height:44px;border:1px solid var(--border);border-radius:8px;padding:0 12px;background:#fff;color:#0f172a}.form-stack textarea{min-height:80px;padding:10px 12px;resize:vertical}.file-input{min-height:44px;border:1px dashed var(--border);border-radius:8px;display:flex;align-items:center;gap:10px;padding:0 12px;color:var(--muted);cursor:pointer}.file-input input{display:none}.customer-field{display:flex;flex-direction:column;gap:10px}.segmented{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#f4f7f5}.segmented button{min-height:40px;border:0;background:transparent;color:var(--muted);font-weight:600;font-size:13px}.segmented button.active{background:var(--surface);color:var(--primary);box-shadow:inset 0 0 0 1px var(--border)}.segmented.three-col{grid-template-columns:1fr 1fr 1fr}.payment-due-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:8px;background:#f4f7f5;border:1px solid var(--border);font-size:14px}.payment-due-row strong{color:var(--primary);font-size:16px}.payment-hint{margin:0;font-size:13px;color:var(--muted);line-height:1.45}.payment-hint.warn{color:var(--warn)}.payment-form-panel{display:flex;flex-direction:column;gap:14px}.payment-field{display:flex;flex-direction:column;gap:6px}.payment-field-label{font-size:12px;font-weight:600;color:#334155}.payment-control{width:100%;height:40px;padding:0 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease}.payment-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent)}.payment-summary-card{padding:12px 14px;border-radius:10px;background:#f8fafc;border:1px solid var(--border)}.payment-kv{margin:0;display:grid;gap:8px}.payment-kv>div{display:flex;justify-content:space-between;gap:12px;font-size:14px}.payment-kv dt{color:var(--muted)}.payment-kv dd{margin:0;color:#0f172a}.payment-kv .highlight-row dd strong{color:var(--primary);font-size:1.1rem}.payment-amount-block{display:flex;flex-direction:column;gap:8px}.payment-amount-label{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:#0f172a}.payment-amount-label em{font-style:normal;font-size:11px;color:#dc2626;font-weight:600}.payment-amount-input-wrap{display:flex;align-items:stretch;border:2px solid color-mix(in srgb,var(--primary) 35%,var(--border));border-radius:12px;background:#fff;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.payment-amount-input-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 15%,transparent)}.payment-currency{display:flex;align-items:center;padding:0 14px;font-size:1.25rem;font-weight:700;color:var(--primary);background:#f4faf7;border-right:1px solid var(--border)}.payment-amount-input{flex:1;min-width:0;border:none;padding:12px 14px;font-size:1.35rem;font-weight:600;color:#0f172a;background:transparent}.payment-amount-input:focus{outline:none}.payment-fill-due{align-self:flex-start}.payment-status-card{display:flex;gap:12px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);transition:background .2s ease,border-color .2s ease}.payment-status-card.is-full{background:#f0fdf4;border-color:#86efac}.payment-status-card.is-full .payment-status-icon{color:#15803d}.payment-status-card.is-partial{background:#fffbeb;border-color:#fcd34d}.payment-status-card.is-partial .payment-status-icon{color:#b45309}.payment-status-card.is-debt{background:#fef2f2;border-color:#fecaca}.payment-status-card.is-debt .payment-status-icon{color:#b91c1c}.payment-status-body strong{display:block;font-size:14px;margin-bottom:4px;color:#0f172a}.payment-status-body p{margin:0;font-size:13px;color:#475569;line-height:1.45}.payment-status-body b{color:#0f172a}.payment-tolerance-note{color:var(--muted);font-size:12px}.payment-method-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:end}.payment-voucher{margin:0}.payment-submit:disabled{opacity:.55;cursor:not-allowed}@media(max-width:640px){.payment-method-row{grid-template-columns:1fr}}.attachment-gallery{margin-top:12px;padding-top:12px;border-top:1px dashed var(--border)}.attachment-title{margin:0 0 10px;font-size:13px;font-weight:600;color:var(--muted)}.attachment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.attachment-item{display:flex;flex-direction:column;gap:4px;text-decoration:none;color:inherit;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:var(--surface);transition:box-shadow .2s,border-color .2s}.attachment-item:hover{border-color:var(--primary);box-shadow:0 4px 12px #1d6b561f}.attachment-item img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;background:#eef3f0}.attachment-caption{padding:0 8px;font-size:12px;font-weight:600;color:var(--primary)}.attachment-meta{padding:0 8px 8px;font-size:11px;color:var(--muted)}.attachment-file{display:grid;place-items:center;min-height:88px;padding:12px;font-size:13px;color:var(--primary);font-weight:600}.weight-compare-block .attachment-gallery{margin-top:14px;padding-top:14px}.attachment-tag{display:inline-block;margin-top:2px;color:var(--primary);font-weight:600}.ocr-provider{color:var(--primary);font-weight:600}.pill.warn{background:#c46a1a26;color:var(--warn);border-color:#c46a1a59}.debt-panel{border-color:#c46a1a59}.debt-card{border-left:3px solid var(--warn)}.settings-panel h3{margin:0 0 12px;font-size:15px}.toggle-row{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;font-weight:600;color:#0f172a;line-height:1.45}.toggle-row input{width:18px;height:18px;margin-top:2px;accent-color:var(--primary);cursor:pointer}.settings-panel.readonly{background:#f4f7f5}.task-list{display:flex;flex-direction:column;gap:10px}.task-card,.release-card,.flow-list-item{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:14px;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left;width:100%}.task-card strong,.task-card b,.release-card b,.flow-list-item strong{display:block;color:#0f172a}.task-card span,.release-card span,.flow-list-item span{display:block;margin-top:4px;color:var(--muted);font-size:13px}.task-card small,.release-card small{display:block;margin-top:4px;color:#94a3b8;font-size:12px}.task-card.selected{border-color:var(--primary);background:#f4faf7}.release-card.allowed{border-color:#6eb592;background:#f4faf7}.release-card.blocked{border-color:#e8c48a;background:#fffbf5}.release-card.released{opacity:.85}.empty{padding:32px 16px;text-align:center;color:#94a3b8;border:1px dashed var(--border);border-radius:10px;background:#fafcfb}.flow-timeline{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:0}.flow-step{display:flex;gap:14px;padding:12px 0;position:relative}.flow-step:not(:last-child):after{content:"";position:absolute;left:15px;top:40px;bottom:-4px;width:2px;background:var(--border)}.flow-step.done .flow-step-marker{background:var(--primary);color:#fff;border-color:var(--primary)}.flow-step.current .flow-step-marker{border-color:var(--primary);color:var(--primary);box-shadow:0 0 0 3px #d4ebe3}.flow-step.pending{opacity:.65}.flow-step-marker{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);display:grid;place-items:center;flex-shrink:0;font-size:12px;font-weight:700;background:#fff;z-index:1}.flow-step-body b{display:block;font-size:14px}.flow-step-body span{display:block;margin-top:3px;font-size:13px;color:var(--muted)}.flow-step-body small{display:block;margin-top:4px;font-size:11px;color:var(--primary);font-weight:600}.flow-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:4px}.flow-header h3{font-size:1.25rem}.flow-header p{margin:4px 0 0;color:var(--muted);font-size:13px}.progress-ring{width:56px;height:56px;border-radius:50%;background:conic-gradient(var(--primary) calc(var(--p) * 1%),#e4ece8 0);display:grid;place-items:center;flex-shrink:0}.progress-ring span{width:42px;height:42px;border-radius:50%;background:#fff;display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--primary)}.order-summary{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.order-summary strong{font-size:1.2rem;color:var(--primary)}.flow-list{display:flex;flex-direction:column;gap:8px}.flow-list-item:hover{border-color:var(--primary)}.data-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-top:12px;border:1px solid var(--border);border-radius:8px}.data-scroll table{width:100%;min-width:520px;border-collapse:collapse;font-size:13px}.data-scroll th,.data-scroll td{padding:10px 12px;text-align:left;border-bottom:1px solid #eef2ef;white-space:nowrap}.data-scroll th{background:#eef4f1;font-weight:700;color:#36545a;position:sticky;top:0}.data-block h3{font-size:15px}.data-block .count{font-size:12px;background:#e4f0eb;color:var(--primary);padding:2px 8px;border-radius:999px;margin-left:8px}.material-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.material-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px}.material-card.warn{border-color:#e8a55c;background:#fff9f2}.material-card strong{display:block;font-size:1.4rem;margin-top:6px}.material-card.clickable{text-align:left;cursor:pointer;width:100%;border:1px solid var(--border)}.material-card.clickable:hover{border-color:var(--primary)}.material-card.clickable.active{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary);background:#f4faf7}.material-card-wrap{position:relative}.material-card-wrap.active .material-card.clickable{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary);background:#f4faf7}.material-card-wrap.warn .material-card{border-color:#e8a55c;background:#fff9f2}.material-card-wrap .material-card{width:100%;padding-right:40px}.material-delete{position:absolute;top:8px;right:8px;width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#64748b;display:grid;place-items:center;cursor:pointer;transition:color .2s ease,border-color .2s ease,background .2s ease}.material-delete:hover{color:#dc2626;border-color:#fca5a5;background:#fef2f2}.form-row-actions{display:flex;gap:10px;margin-top:4px}.form-row-actions .ghost,.form-row-actions .primary{flex:1}.panel-head .primary.slim{display:inline-flex;align-items:center;gap:6px}.customer-workspace{display:grid;grid-template-columns:minmax(260px,300px) minmax(0,1fr);gap:12px;align-items:stretch;min-height:calc(100vh - 108px)}.customer-list-pane{display:flex;flex-direction:column;min-height:0;padding:0;overflow:hidden}.customer-list-toolbar{display:flex;gap:8px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border)}.search-field{flex:1;display:flex;align-items:center;gap:8px;padding:0 10px;height:36px;border:1px solid var(--border);border-radius:8px;background:#fff}.search-field input{flex:1;border:none;background:transparent;padding:0;min-width:0;font-size:13px}.search-field input:focus{outline:none}.search-field svg{color:var(--muted);flex-shrink:0}.customer-list-toolbar .icon-only{width:36px;height:36px;padding:0;display:grid;place-items:center;flex-shrink:0}.customer-table-wrap{flex:1;min-height:0;max-height:none;border:none;border-radius:0}.customer-table{width:100%}.customer-table th,.customer-table td{padding:7px 10px;font-size:13px;vertical-align:middle}.customer-table th.num,.customer-table td.num{width:40px;text-align:right;white-space:nowrap}.customer-table tbody tr{cursor:pointer;transition:background .15s ease}.customer-table tbody tr:hover{background:#f8fafc}.customer-table tbody tr.active{background:#eef8f3;box-shadow:inset 3px 0 0 var(--primary)}.customer-table tbody tr.editing{background:#fffbeb}.customer-name-cell{display:block;font-size:13px;font-weight:600;color:var(--text);line-height:1.3}.customer-sub{display:block;font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.customer-list-footer{padding:8px 12px;font-size:12px;color:var(--muted);border-top:1px solid var(--border)}.customer-detail-pane{display:flex;flex-direction:column;gap:10px;min-height:0;min-width:0}.customer-detail-card{padding:12px 14px}.customer-detail-card.flex-grow{flex:1;display:flex;flex-direction:column;min-height:0}.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.detail-head h3{margin:0;font-size:1.05rem}.detail-meta{margin:4px 0 0;font-size:13px;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:6px}.stat-chips{display:flex;flex-wrap:wrap;gap:6px}.stat-chip{font-size:12px;color:var(--muted);padding:4px 10px;border-radius:999px;background:#f1f5f9;border:1px solid var(--border)}.stat-chip b{color:var(--text);font-weight:700;margin-left:4px}.stat-chip.accent{background:#eef8f3;border-color:#c6e7d8;color:#145042}.stat-chip.accent b{color:var(--primary)}.stat-chip.warn{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.stat-chip.warn b{color:#c2410c}.orders-panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px}.orders-panel-head h3{margin:0;font-size:1rem}.detail-actions{display:flex;gap:8px;flex-shrink:0}.portal-account-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:10px;padding:10px 12px;border-radius:8px;border:1px dashed var(--border);background:#f8fafc}.portal-account-bar.active{border-style:solid;border-color:#c6e7d8;background:#f4faf7}.portal-account-bar.disabled{border-color:#fed7aa;background:#fff7ed}.portal-account-main{display:flex;align-items:flex-start;gap:10px;min-width:0}.portal-account-main svg{color:var(--primary);flex-shrink:0;margin-top:2px}.portal-account-text b{display:block;font-size:13px;margin-bottom:2px}.portal-account-text span{font-size:12px;color:var(--muted);line-height:1.45}.portal-account-text code{font-size:12px}.portal-account-actions{display:flex;gap:8px;flex-shrink:0}.compact-identity .identity-line{margin:6px 0 4px;font-size:1.05rem}.compact-identity .hint{margin:0}.portal-reserve-identity{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;margin-bottom:4px;border-radius:10px;border:1px solid #c6e7d8;background:#f4faf7}.portal-reserve-identity svg{color:var(--primary);flex-shrink:0}.portal-reserve-identity strong{display:block;font-size:1.05rem;color:var(--text);margin-top:2px}.portal-reserve-identity small{display:block;margin-top:4px;font-size:12px;color:var(--muted)}.inventory-page{gap:10px}.inventory-stock-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.inventory-stock-chip{padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.inventory-stock-chip:hover{border-color:var(--primary)}.inventory-stock-chip.active{border-color:var(--primary);background:#f4faf7;box-shadow:inset 0 0 0 1px var(--primary)}.inventory-stock-chip.warn{border-color:#e8a55c;background:#fff9f2}.inventory-stock-chip .chip-name{display:block;font-size:13px;font-weight:600;color:var(--text)}.inventory-stock-chip strong{display:block;font-size:1.25rem;margin:4px 0 2px;color:var(--primary)}.inventory-stock-chip strong.negative{color:#c2410c}.inventory-stock-chip strong small{font-size:12px;font-weight:500;margin-left:2px;color:var(--muted)}.inventory-stock-chip>small{font-size:11px;color:var(--muted)}.inventory-inbound-panel{padding:0;overflow:hidden}.inventory-inbound-panel.open{border-color:color-mix(in srgb,var(--primary) 35%,var(--border))}.inbound-panel-head{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;border:none;background:transparent;text-align:left;cursor:pointer;transition:background .2s ease}.inbound-panel-head:hover{background:#f8fafc}.inbound-head-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:color-mix(in srgb,var(--primary) 12%,#fff);color:var(--primary);flex-shrink:0}.inbound-head-text{flex:1;min-width:0}.inbound-head-text strong{display:block;font-size:15px;font-weight:600;color:var(--text)}.inbound-head-text small{display:block;margin-top:2px;font-size:12px;color:var(--muted);line-height:1.4}.inbound-head-chevron{flex-shrink:0;color:var(--muted);transition:transform .2s ease}.inbound-head-chevron.open{transform:rotate(180deg)}.inbound-panel-body{padding:0 16px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.inbound-selected-banner{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 12px;border-radius:8px;background:color-mix(in srgb,var(--primary) 8%,#fff);border:1px solid color-mix(in srgb,var(--primary) 22%,var(--border));font-size:13px;color:var(--text)}.inbound-selected-banner b{color:var(--primary);font-weight:600}.inbound-form-card{padding:14px;border-radius:10px;background:#fafbfc;border:1px solid var(--border)}.inbound-form-card-muted{background:#fff}.inbound-card-title{margin:0 0 12px;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.inbound-fields-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px 14px}.inbound-fields-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.inbound-field{display:flex;flex-direction:column;gap:6px;min-width:0}.inbound-field.span-2{grid-column:span 2}.inbound-field-label{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#334155}.inbound-field-label em{font-style:normal;color:#dc2626}.inbound-control{width:100%;height:40px;padding:0 12px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:14px;color:var(--text);transition:border-color .2s ease,box-shadow .2s ease}.inbound-control:hover{border-color:#cbd5e1}.inbound-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 18%,transparent)}.inbound-input-wrap{position:relative;display:flex;align-items:stretch}.inbound-input-wrap .inbound-control{padding-right:52px}.inbound-unit{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;font-weight:600;color:var(--muted);pointer-events:none}.inbound-form-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;margin:0 -16px -16px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-top:1px solid var(--border);border-radius:0 0 10px 10px}.inbound-total-preview{display:flex;flex-direction:column;gap:2px}.inbound-total-preview>span{font-size:12px;color:var(--muted)}.inbound-total-preview strong{font-size:1.35rem;font-weight:700;color:var(--primary);line-height:1.2}.inbound-total-preview small{font-size:11px;color:var(--muted)}.inbound-form-actions{display:flex;align-items:center;gap:10px}.inbound-submit{display:inline-flex;align-items:center;gap:6px;padding:0 18px;height:42px;font-weight:600}.inventory-records-panel{padding-top:12px}.inventory-tabs{display:flex;gap:8px;margin-bottom:10px}.inventory-tabs button{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.inventory-tabs button em{font-style:normal;font-size:11px;opacity:.85}.inventory-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}.inventory-table-wrap{max-height:min(50vh,420px)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:900px){.inbound-fields-grid{grid-template-columns:1fr 1fr}.inbound-field.span-2{grid-column:span 2}.inbound-fields-grid-2{grid-template-columns:1fr}.inbound-form-footer{flex-direction:column;align-items:stretch}.inbound-form-actions{flex-direction:column-reverse}.inbound-form-actions .ghost,.inbound-form-actions .inbound-submit{width:100%;justify-content:center}}@media(max-width:520px){.inbound-fields-grid{grid-template-columns:1fr}.inbound-field.span-2{grid-column:span 1}}.order-filters{display:flex;flex-wrap:wrap;gap:6px}.order-filters button{padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:600;color:var(--muted);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.order-filters button em{font-style:normal;margin-left:4px;font-size:11px;opacity:.85}.order-filters button.active{background:var(--primary);border-color:var(--primary);color:#fff}.order-table-wrap{flex:1;min-height:120px;max-height:min(58vh,520px)}.order-table td.num.strong{font-weight:700;color:var(--text)}.order-table td.num.due{color:#c2410c;font-weight:600}.detail-tabs{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.detail-tabs button{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease}.detail-tabs button em{font-style:normal;font-size:11px;background:#e2e8f0;padding:1px 6px;border-radius:999px;margin-left:2px}.detail-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}.detail-tabs button.active em{background:#ffffff40;color:#fff}.detail-tab-body{flex:1;display:flex;flex-direction:column;min-height:0}.link-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px}.link-toolbar input[type=text]{width:120px;min-width:100px;font-size:13px}.checkbox-inline{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);cursor:pointer;white-space:nowrap}.checkbox-inline input{width:14px;height:14px;cursor:pointer}.orphan-table-wrap{flex:1;min-height:120px;max-height:min(52vh,480px)}.dense-table th,.dense-table td{padding:6px 8px;font-size:12px}.dense-table .check-col{width:32px}.dense-table .time-col{width:88px;white-space:nowrap}.dense-table .ellipsis{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dense-table tbody tr.clickable-row{cursor:pointer}.dense-table tbody tr.clickable-row:hover,.dense-table tbody tr.selected{background:#f4faf7}.compact-form .form-row{margin-bottom:0}.customer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--muted);min-height:240px}.customer-empty svg{opacity:.35}.empty.compact{margin:12px;padding:12px;font-size:13px}@media(max-width:900px){.customer-workspace{grid-template-columns:1fr;min-height:0}.customer-table-wrap{max-height:220px}.customer-list-pane .hide-sm,.customer-table .hide-sm{display:none}}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:12px;border-radius:10px;background:#f4faf7;border:1px solid #c5ddd2}.compare-grid.warn{background:#fff8f0;border-color:#e8c48a}.compare-col b{display:block;font-size:12px;color:var(--muted)}.compare-col strong{display:block;font-size:1.2rem;margin-top:4px;color:#0f172a}.compare-col small{display:block;margin-top:4px;color:var(--muted);font-size:11px}.price-box{padding:14px;border-radius:10px;border:1px solid var(--border);background:#fafcfb;display:flex;flex-direction:column;gap:10px}.price-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.price-row.highlight strong{color:var(--primary);font-size:1.15rem}.price-note{color:var(--warn);font-size:12px}.billing-price-mode{margin:4px 0 8px}.price-row.muted{font-size:13px;color:var(--muted)}.price-row.muted strong{color:var(--muted);font-size:14px}.price-discount{margin:0;padding:8px 10px;border-radius:8px;background:#c46a1a1a;color:var(--warn);font-size:13px;font-weight:600;line-height:1.4}.price-discount.markup{background:#1d6b561a;color:var(--primary)}.check-row{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.check-row input{width:18px;height:18px}.verify-card{border:1px solid #b8d4c8;border-radius:12px;padding:16px;background:linear-gradient(180deg,#f8fcfa,#fff)}.verify-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.verify-head h3{margin:0;font-size:1rem;display:flex;align-items:center;gap:8px}.verify-section{margin-bottom:16px}.verify-section h4{margin:0 0 10px;font-size:13px;color:var(--muted);font-weight:700}.verify-section.compact{margin-bottom:0}.verify-alert{color:#b45309;font-size:13px;margin:8px 0 0}.verify-ok{font-size:14px;color:#0f172a}.verify-ok strong{color:var(--primary)}.meta-line{margin:0;font-size:13px;color:var(--muted)}.kv-list{margin:0;display:flex;flex-direction:column;gap:8px}.kv-list.compact{gap:6px}.kv-list>div{display:flex;justify-content:space-between;gap:12px;font-size:14px}.kv-list dt{color:var(--muted);flex-shrink:0}.kv-list dd{margin:0;text-align:right;color:#0f172a}.kv-list .highlight-row dd strong{color:var(--primary)}.card-actions{display:flex;gap:8px;flex-shrink:0}@media(max-width:900px){.card-actions{width:100%}.task-card .card-actions,.release-card .card-actions{flex-direction:column}.task-card .card-actions button,.release-card .card-actions button{width:100%}}.step-details{display:flex;flex-direction:column;gap:10px;margin-top:16px}.step-detail-card{border:1px solid var(--border);border-radius:10px;padding:12px;background:#fafcfb}.step-detail-card.current{border-color:var(--primary);background:#f4faf7}.step-detail-card.done{opacity:.92}.step-detail-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}.step-badge{width:24px;height:24px;border-radius:50%;background:#e4f0eb;color:var(--primary);display:grid;place-items:center;font-size:12px;font-weight:800}.step-detail-head em{margin-left:auto;font-style:normal;font-size:12px;color:var(--muted)}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#0f172a73;display:flex;align-items:flex-end;justify-content:center;padding:0}.detail-sheet{width:min(560px,100%);max-height:min(88vh,900px);background:#fff;border-radius:16px 16px 0 0;display:flex;flex-direction:column;box-shadow:0 -12px 40px #0f172a2e}@media(min-width:768px){.detail-overlay{align-items:center;padding:24px}.detail-sheet{border-radius:16px;max-height:85vh}}.detail-sheet-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 18px 12px;border-bottom:1px solid var(--border)}.detail-sheet-head h2{margin:4px 0 0;font-size:1.2rem}.detail-sheet-body{overflow-y:auto;padding:16px 18px calc(18px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}.detail-block{margin-bottom:20px}.detail-block h3{margin:0 0 12px;font-size:15px}.mini-card{border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:8px}.mini-card strong{display:block}.mini-card span{font-size:13px;color:var(--muted)}.data-row-clickable{cursor:pointer;transition:background .15s}.data-row-clickable:hover{background:#f4faf7}.row-action{color:var(--primary);font-weight:700;width:28px;text-align:center}.mobile-nav,.more-sheet{display:none}@media(max-width:900px){.app-shell{display:block;padding-bottom:72px}.sidebar{display:none}.content{padding:16px 16px 24px}.kpi-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr}.task-card,.release-card{flex-direction:column;align-items:stretch}.task-card button,.release-card button{width:100%}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:20;height:64px;display:flex;background:#fff;border-top:1px solid var(--border);box-shadow:0 -8px 24px #0f172a14;padding-bottom:env(safe-area-inset-bottom,0)}.mobile-nav button,.mobile-nav .more-trigger{flex:1;border:0;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:11px;min-height:64px;padding:0}.mobile-nav button.active,.mobile-nav .more-trigger.active{color:var(--primary);background:#f0f7f4}.more-sheet{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:25;background:#0f172a66}.more-sheet-panel{position:absolute;left:0;right:0;bottom:0;background:#fff;border-radius:16px 16px 0 0;padding:16px 16px calc(16px + env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.more-sheet-panel button{min-height:48px;border:1px solid var(--border);border-radius:10px;background:#fafcfb;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:600;color:#1e3a34;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.more-sheet-panel button:hover{background:#f0f7f4;border-color:#9fd4b8}.more-sheet-panel--account{grid-template-columns:1fr}.more-sheet-user{margin:0 0 4px;padding:12px 4px 8px;font-size:15px;font-weight:700;color:#0f172a}.more-sheet-user small{display:block;margin-top:4px;font-size:13px;font-weight:400;color:var(--muted)}.more-sheet-logout{grid-column:1 / -1;margin-top:4px;border-color:#fecaca!important;color:#b91c1c!important;background:#fef2f2!important}.more-sheet-logout:hover{background:#fee2e2!important;border-color:#fca5a5!important}.mobile-logout-btn{display:none}.topbar-actions .mobile-logout-btn{display:grid;color:var(--muted)}.topbar-actions .mobile-logout-btn:hover{color:#b91c1c;background:#fef2f2}}@media(max-width:380px){.mobile-nav button span,.mobile-nav .more-trigger span{font-size:10px}}.explorer-page .explorer-intro{margin-bottom:0}.explorer-intro h2{margin:0 0 8px;display:flex;align-items:center;gap:8px}.explorer-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 0}.explorer-tabs button{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;border:1px solid var(--border);background:#fff;color:var(--muted);font-weight:600;font-size:14px;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.explorer-tabs button em{font-style:normal;font-size:12px;padding:2px 7px;border-radius:999px;background:#eef2f0;color:#475569}.explorer-tabs button.active{background:#eef6f2;border-color:var(--primary);color:var(--primary)}.explorer-tabs button.active em{background:var(--primary);color:#fff}.explorer-tabs button:hover:not(.active){border-color:#b8d4c8;color:#1e3a34}.explorer-panel{padding-top:0}.explorer-panel .query-toolbar{margin:0 -4px 16px}.query-toolbar{display:flex;flex-direction:column;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:16px}.query-toolbar-main{display:flex;flex-wrap:wrap;align-items:center;gap:10px}.query-search{flex:1 1 200px;position:relative;min-width:160px}.query-search .query-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.query-search input{width:100%;padding:10px 12px 10px 40px;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:14px}.query-search input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #1d6b561f}.query-select,.query-date{padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:#fff;font-size:14px;min-height:42px}.query-date{width:auto;min-width:130px}.query-date-sep{color:var(--muted);font-size:13px}.query-reset{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.query-toolbar-extra{padding-top:4px}.check-row.inline{margin:0;font-size:14px}.table-wrap{overflow:auto;max-height:min(56vh,520px);border:1px solid var(--border);border-radius:10px}.table-wrap.sticky-head thead th{position:sticky;top:0;z-index:2;background:#f4f7f5;box-shadow:0 1px 0 var(--border)}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{padding:11px 14px;text-align:left;border-bottom:1px solid #eef2f0;white-space:nowrap}.data-table th{font-size:12px;font-weight:700;color:var(--muted);text-transform:none;letter-spacing:.02em}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{color:var(--primary)}.sort-ind{margin-left:4px;color:var(--primary);font-size:11px}.data-table tbody tr.data-row-clickable{cursor:pointer;transition:background .15s}.data-table tbody tr.data-row-clickable:hover{background:#f7fbf9}.data-table .col-action,.data-table .row-action{width:40px;text-align:right;color:var(--muted)}.data-table tfoot .table-foot{font-weight:700;background:#f8faf9;color:#0f172a}.data-table tr.row-warn{background:#fffbf5}.report-kpi{margin-top:16px}.report-kpi-material{grid-template-columns:repeat(4,minmax(0,1fr))}@media(max-width:900px){.report-kpi-material{grid-template-columns:repeat(2,1fr)}}.data-table-wide{min-width:880px}.cell-sub{display:block;margin-top:2px;font-size:11px;font-weight:400;color:var(--muted)}.warn-text{color:var(--warn)!important}.pagination-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.pagination-meta{margin:0;font-size:13px;color:var(--muted)}.pagination-meta strong{color:#0f172a}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-size{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}.pagination-size select{padding:6px 8px;border:1px solid var(--border);border-radius:8px;background:#fff}.pagination-page{min-width:64px;text-align:center;font-size:13px;font-weight:600;color:#0f172a}.pagination-bar.compact{margin-top:10px;padding-top:10px;gap:8px}.pagination-bar.compact .pagination-meta,.pagination-bar.compact .pagination-size{font-size:12px}.pagination-bar.compact button.icon-only{width:36px;height:36px}.paginated-task-block .pagination-bar{margin-top:12px}.customer-list-pane .pagination-bar{flex-shrink:0;padding:10px 12px 12px;margin-top:0;border-top:1px solid var(--border)}.pagination-empty{margin:24px 0 0;text-align:center;color:var(--muted);font-size:14px}button.icon-only{width:40px;height:40px;padding:0;display:grid;place-items:center}@media(max-width:768px){.query-toolbar-main{flex-direction:column;align-items:stretch}.query-search{flex:1 1 auto}.query-select,.query-date{width:100%}.table-wrap{max-height:50vh}.pagination-bar{flex-direction:column;align-items:flex-start}}.task-card-clickable{cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.task-card-clickable:hover:not(.disabled){border-color:#9fd4b8;background:#f8fcfa;box-shadow:0 2px 8px #0f172a0f}.task-card-clickable:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.task-card-clickable.disabled{cursor:default;opacity:.72}.task-card-clickable .task-card-main{flex:1;min-width:0}.task-card-static{cursor:default}.task-card-static .task-card-main{flex:1;min-width:0}.enter-confirm-btn{min-width:88px;font-weight:600}.row-hint{font-size:12px;color:#64748b;white-space:nowrap}.segmented.two-col{grid-template-columns:1fr 1fr}.track-mode{margin-top:12px}.track-search-actions{display:flex;gap:10px;margin-top:12px}.track-empty-hint{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 16px}.track-group-list{display:flex;flex-direction:column;gap:12px}.track-group-head{width:100%;display:flex;justify-content:space-between;align-items:center;gap:12px;padding:0;border:none;background:transparent;text-align:left;cursor:pointer}.track-group-head:hover strong{color:var(--primary)}.track-history-toggle{width:100%;display:flex;align-items:center;gap:8px;margin-top:10px;padding:10px 12px;border:1px dashed var(--border);border-radius:8px;background:#fafcfb;color:#475569;font-size:13px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.track-history-toggle:hover{background:#f0f7f3;border-color:#9fd4b8}.track-history-toggle .rotated{transform:rotate(180deg)}.track-history-list{margin-top:8px;display:flex;flex-direction:column;gap:6px}.flow-list-item.compact{padding:10px 12px}.compact-top{margin-top:8px}.settings-block{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.settings-block h3{margin:0 0 10px;font-size:15px}.storage-pill{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin:0 12px 10px;padding:8px 10px;border-radius:8px;font-size:11px;line-height:1.35;color:#cbd5e1}.storage-pill.mysql{background:#22c55e1f;border:1px solid rgba(74,222,128,.25);color:#bbf7d0}.storage-pill.memory{background:#fbbf241f;border:1px solid rgba(251,191,36,.35);color:#fde68a}.storage-pill small{opacity:.85;font-size:10px}.storage-dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}.storage-pill.mysql .storage-dot{background:#4ade80;box-shadow:0 0 6px #4ade80}.ai-fab{position:fixed;right:20px;bottom:20px;z-index:1200;display:inline-flex;align-items:center;gap:6px;padding:12px 16px;border:none;border-radius:999px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;font-weight:700;font-size:14px;box-shadow:0 8px 24px #1d6b5659;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,transform .2s ease}.ai-fab:hover{box-shadow:0 10px 28px #1d6b5673}.ai-fab.open{opacity:0;pointer-events:none;transform:scale(.9)}.ai-fab-label{letter-spacing:.02em}.ai-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1201;background:#0f172a59;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.ai-drawer{position:fixed;top:0;right:0;z-index:1202;width:min(420px,100vw);height:100vh;height:100dvh;display:flex;flex-direction:column;background:#fff;border-left:1px solid var(--border);box-shadow:-12px 0 40px #0f172a1f}.ai-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 16px 12px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#f4faf7,#fff)}.ai-drawer-brand{display:flex;gap:12px;align-items:flex-start}.ai-drawer-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:color-mix(in srgb,var(--primary) 14%,#fff);color:var(--primary);flex-shrink:0}.ai-drawer-head h2{margin:0;font-size:1.05rem;color:#0f172a}.ai-drawer-head p{margin:4px 0 0;font-size:12px;color:var(--muted)}.ai-drawer-tools{display:flex;gap:4px;flex-shrink:0}.icon-only{padding:8px;min-width:36px;justify-content:center}.ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f8fafc}.ai-msg{display:flex;flex-direction:column;gap:8px;max-width:92%}.ai-msg.user{align-self:flex-end;align-items:flex-end}.ai-msg.assistant{align-self:flex-start}.ai-msg-bubble{padding:10px 12px;border-radius:12px;font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.ai-msg.user .ai-msg-bubble{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.ai-msg.assistant .ai-msg-bubble{background:#fff;border:1px solid var(--border);color:#0f172a;border-bottom-left-radius:4px}.ai-msg.error .ai-msg-bubble{border-color:#fecaca;background:#fef2f2}.ai-msg-time{display:block;margin-top:6px;font-size:10px;opacity:.65}.ai-msg.user .ai-msg-time{color:#fffc}.ai-confirm-btn{align-self:flex-start}.ai-msg-bubble.typing{display:flex;gap:4px;padding:14px 16px}.ai-msg-bubble.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:ai-typing 1s ease-in-out infinite}.ai-msg-bubble.typing span:nth-child(2){animation-delay:.15s}.ai-msg-bubble.typing span:nth-child(3){animation-delay:.3s}@keyframes ai-typing{0%,80%,to{opacity:.35;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}@media(prefers-reduced-motion:reduce){.ai-msg-bubble.typing span{animation:none;opacity:.6}}.ai-quick{display:flex;flex-wrap:wrap;gap:8px;padding:0 12px 10px;border-top:1px solid var(--border);background:#fff}.ai-quick-chip{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#f8fafc;font-size:12px;color:#334155;cursor:pointer;transition:background .2s ease,border-color .2s ease;max-width:100%;text-align:left;line-height:1.35}.ai-quick-chip:hover:not(:disabled){border-color:var(--primary);background:#f4faf7}.ai-quick-chip:disabled{opacity:.5;cursor:not-allowed}.ai-composer{display:flex;gap:10px;padding:12px;border-top:1px solid var(--border);background:#fff}.ai-input{flex:1;min-height:44px;max-height:120px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:10px;resize:none;font-size:14px;line-height:1.45;transition:border-color .2s ease,box-shadow .2s ease}.ai-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 15%,transparent)}.ai-send{width:44px;height:44px;padding:0;display:grid;place-items:center;border-radius:10px;flex-shrink:0}.ai-drawer-recharge{padding:8px 12px 0;border-top:1px solid var(--border);background:#fff}.ai-recharge-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:var(--primary);border-color:color-mix(in srgb,var(--primary) 35%,var(--border))}.ai-recharge-btn:hover{background:#f4faf7}.ai-recharge-page{display:flex;flex-direction:column;gap:16px;padding-bottom:24px}.ai-recharge-loading,.ai-recharge-error{min-height:16rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;color:var(--muted)}.ai-recharge-error p{margin:0;color:#b45309}.ai-recharge-spin{animation:ai-recharge-spin .9s linear infinite}@keyframes ai-recharge-spin{to{transform:rotate(360deg)}}.ai-recharge-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:16px}@media(max-width:960px){.ai-recharge-grid{grid-template-columns:1fr}}.ai-recharge-balance{padding:20px 22px 18px;background:linear-gradient(145deg,#fff,#f4faf7);border-color:color-mix(in srgb,var(--primary) 18%,var(--border))}.ai-recharge-balance-head{display:grid;grid-template-columns:auto 1fr auto;gap:12px 16px;align-items:start}.ai-recharge-icon-wrap{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:#f8fafc;border:1px solid var(--border);color:var(--muted)}.ai-recharge-icon-wrap--primary{background:#e8f5f0;border-color:color-mix(in srgb,var(--primary) 22%,var(--border));color:var(--primary)}.ai-recharge-eyebrow{margin:0;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--muted)}.ai-recharge-balance-value{margin:4px 0 0;font-size:clamp(1.75rem,4vw,2.2rem);font-weight:800;line-height:1.1;letter-spacing:-.03em}.ai-recharge-currency{margin-right:2px;font-size:.72em;font-weight:700;color:var(--primary-dark)}.ai-recharge-refresh{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-size:12px;font-weight:600}.ai-recharge-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}@media(max-width:640px){.ai-recharge-stats{grid-template-columns:1fr}}.ai-recharge-stat{padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid var(--border)}.ai-recharge-stat span{display:block;margin-bottom:4px;font-size:11px;font-weight:600;color:var(--muted)}.ai-recharge-stat strong{font-size:14px;font-weight:700}.ai-recharge-account{padding:18px 20px}.ai-recharge-section-head{display:flex;gap:12px;margin-bottom:14px}.ai-recharge-section-head h3{margin:0 0 4px;font-size:16px}.ai-recharge-section-head p{margin:0;font-size:13px;line-height:1.5;color:var(--muted)}.ai-recharge-fields{margin:0;display:flex;flex-direction:column;gap:10px}.ai-recharge-field{display:grid;grid-template-columns:4.5rem 1fr;gap:8px 12px;align-items:center;padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid var(--border)}.ai-recharge-field dt{margin:0;font-size:12px;font-weight:600;color:var(--muted)}.ai-recharge-field dd{margin:0;display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.ai-recharge-field code,.ai-recharge-field span{font-size:14px;font-weight:600;word-break:break-all}.ai-recharge-field code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.ai-recharge-copy{flex-shrink:0;padding:4px 8px;border:none;border-radius:6px;background:transparent;color:var(--primary);font-size:12px;font-weight:600}.ai-recharge-copy:hover{background:#e8f5f0}.ai-recharge-notice{margin-top:14px;padding:12px 14px;border-radius:10px;background:#eef6ff;border:1px solid #dbeafe;font-size:12px;line-height:1.55;color:#475569}.ai-recharge-notice strong{font-weight:600;color:#0f172a;word-break:break-all}.ai-recharge-warn{margin:10px 0 0;padding:10px 12px;border-radius:10px;background:#fffbeb;border:1px solid #fde68a;color:#92400e;font-size:12px;line-height:1.5}.ai-recharge-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;flex-wrap:wrap}.ai-recharge-footer-text{display:flex;align-items:flex-start;gap:10px;color:var(--muted)}.ai-recharge-footer-text strong{display:block;margin-bottom:4px;font-size:14px;color:#0f172a}.ai-recharge-footer-text p{margin:0;font-size:13px;line-height:1.5}.ai-recharge-cta{min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px}.ai-recharge-inline-err{margin:0;padding:10px 14px;border-radius:10px;background:#fef2f2;color:#b91c1c;font-size:13px;font-weight:600}.ai-backdrop-enter-active,.ai-backdrop-leave-active,.ai-drawer-enter-active,.ai-drawer-leave-active{transition:opacity .25s ease}.ai-drawer-enter-active,.ai-drawer-leave-active{transition:transform .25s ease,opacity .25s ease}.ai-drawer-enter-from,.ai-drawer-leave-to{transform:translate(100%);opacity:.9}.ai-backdrop-enter-from,.ai-backdrop-leave-to{opacity:0}@media(prefers-reduced-motion:reduce){.ai-drawer-enter-active,.ai-drawer-leave-active,.ai-backdrop-enter-active,.ai-backdrop-leave-active{transition-duration:.01ms}.ai-drawer-enter-from,.ai-drawer-leave-to{transform:none}}@media(max-width:480px){.ai-drawer{width:100vw}.ai-fab{right:14px;bottom:72px}}
