:root{color:#1f2937;background:#f4f6f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}button{border:0;border-radius:6px;background:#1f6feb;color:#fff;cursor:pointer;font:inherit;font-weight:700;padding:10px 14px}button:disabled{cursor:not-allowed;opacity:.65}button.secondary{background:#e2e8f0;color:#1f2937}.inline-button{min-height:40px;white-space:nowrap}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar{background:#172033;color:#fff;display:flex;flex-direction:column;padding:22px 16px}.sidebar-account{border-top:1px solid rgba(255,255,255,.12);display:grid;gap:6px;margin-top:auto;padding-top:14px}.sidebar-user{display:flex;flex-direction:column;line-height:1.3;padding:6px 12px 10px}.sidebar-user span{font-weight:700}.sidebar-user small{color:#94a3b8}.brand{align-items:center;display:flex;font-size:18px;font-weight:800;gap:10px;margin-bottom:28px}.sidebar nav{display:grid;gap:6px}.nav-item{align-items:center;border-radius:6px;background:transparent;color:#dbe4f0;display:flex;gap:10px;padding:10px 12px;text-align:left;width:100%}.nav-item.active,.nav-item.selected,.nav-item:hover{background:#263653;color:#fff}.nav-group{display:grid;gap:6px}.nav-group-title{flex:1}.nav-chevron{flex-shrink:0;transition:transform .15s ease}.nav-chevron.open{transform:rotate(180deg)}.nav-children{display:grid;gap:6px;margin-top:6px}.nav-subitem{font-size:14px;padding-left:40px}main{padding:28px}.topbar{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:22px}.topbar-user{align-items:center;display:flex;flex-shrink:0;gap:12px}.user-chip{display:flex;flex-direction:column;font-weight:700;line-height:1.2;text-align:right}.user-chip small{color:#64748b;font-weight:600}.inline-button{align-items:center;display:inline-flex;gap:6px}.auth-loading{align-items:center;color:#64748b;display:flex;justify-content:center;min-height:100vh}.login-shell{align-items:center;background:#172033;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:14px;box-shadow:0 18px 40px #0f172a59;display:flex;flex-direction:column;gap:16px;padding:32px;width:100%;max-width:360px}.login-brand{align-items:center;display:flex;font-size:20px;font-weight:800;gap:10px}.login-subtitle{margin:0}.login-field{display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:6px}.login-field input{border:1px solid #cbd5e1;border-radius:8px;font:inherit;padding:10px 12px}.login-field input:focus{border-color:#1f6feb;outline:none}.login-error{background:#fef2f2;border-radius:8px;color:#b91c1c;font-size:14px;margin:0;padding:10px 12px}.modal-backdrop{align-items:center;background:#0f172a80;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:20px;position:fixed;z-index:50}.modal-card{background:#fff;border-radius:14px;box-shadow:0 18px 40px #0f172a59;display:flex;flex-direction:column;gap:14px;padding:28px;width:100%;max-width:360px}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.settings-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.pill-tab{background:#e2e8f0;border-radius:999px;color:#1f2937;font-weight:700;padding:8px 18px}.pill-tab.active{background:#1f6feb;color:#fff}.row-actions{display:flex;flex-wrap:wrap;gap:6px}.tag-self{background:#dbeafe;border-radius:6px;color:#1e40af;font-size:11px;font-weight:700;margin-left:6px;padding:1px 6px}.guide-doc{max-width:900px}.guide-toc{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:22px;padding:16px 20px}.guide-toc strong{display:block;margin-bottom:8px}.guide-toc ol{margin:0;padding-left:20px}.guide-toc a{color:#1f6feb;text-decoration:none}.guide-toc a:hover{text-decoration:underline}.guide-block{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:18px}.guide-block h3{font-size:20px;margin:0 0 10px}.guide-block h4{font-size:15px;margin:18px 0 8px}.guide-block p{color:#334155;line-height:1.7;margin:8px 0}.guide-purpose{background:#f0f9ff;border-left:4px solid #0ea5e9;border-radius:0 8px 8px 0;padding:10px 14px}.guide-list,.guide-steps,.guide-sublist{color:#334155;line-height:1.7;margin:8px 0}.guide-steps{padding-left:22px}.guide-steps>li{margin-bottom:10px}.guide-sublist{margin:6px 0;padding-left:20px}.guide-sublist li{list-style:disc}.guide-callout{background:#f1f5f9;border-radius:8px;color:#1f2937;line-height:1.6;margin:12px 0;padding:12px 16px}.guide-callout.warn{background:#fff7ed;border-left:4px solid #f97316}.guide-note{color:#64748b;display:block;font-size:13px;margin-top:4px}.guide-table{border-collapse:collapse;margin:12px 0;width:100%}.guide-table th,.guide-table td{border:1px solid #e2e8f0;font-size:14px;padding:8px 12px;text-align:left;vertical-align:top}.guide-table th{background:#f8fafc}.pill{background:#e2e8f0;border-radius:6px;font-size:12px;font-weight:700;padding:1px 8px;white-space:nowrap}.guide-block code{background:#f1f5f9;border-radius:4px;font-size:13px;padding:1px 5px}.ocr-panel{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:10px;margin-bottom:14px;padding:12px 14px}.ocr-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.ocr-upload{align-items:center;background:#0ea5e9;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:14px;font-weight:700;gap:6px;padding:9px 14px}.ocr-upload:hover{background:#0284c7}.ocr-hint{color:#64748b;font-size:13px}.ocr-result{margin-top:12px}.ocr-summary{display:flex;flex-wrap:wrap;gap:6px 18px;font-size:14px}.ocr-warn{background:#fff7ed;border-left:4px solid #f97316;border-radius:0 8px 8px 0;color:#9a3412;font-size:13px;margin-top:8px;padding:8px 12px}.link-button{background:none;color:#0ea5e9;font-size:13px;font-weight:600;margin-top:8px;padding:4px 0}.ocr-raw{background:#0f172a;border-radius:8px;color:#e2e8f0;font-size:12px;margin-top:6px;max-height:280px;overflow:auto;padding:12px;white-space:pre-wrap;word-break:break-all}.dash-head{margin-bottom:18px}.dash-head h2{margin:0}.dash-head p{margin-top:4px}.dash-recent{display:grid;gap:16px;grid-template-columns:repeat(3,minmax(0,1fr))}.dash-panel{background:#fff;border:1px solid #d9e1ea;border-radius:10px;display:flex;flex-direction:column;overflow:hidden}.dash-panel-head{align-items:center;border-bottom:1px solid #eef2f6;display:flex;gap:8px;padding:14px 16px}.dash-panel-head h3{font-size:15px;margin:0}.dash-panel-head.dash-in{color:#15803d}.dash-panel-head.dash-out{color:#b91c1c}.dash-panel-head.dash-prod{color:#7c3aed}.dash-list{display:flex;flex-direction:column;list-style:none;margin:0;padding:0}.dash-item{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:10px;justify-content:space-between;padding:11px 16px}.dash-item:last-child{border-bottom:0}.dash-item-main{display:flex;flex-direction:column;gap:2px;min-width:0}.dash-item-title{font-weight:700}.dash-item-sub{color:#64748b;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-item-side{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:4px}.dash-amount{font-size:13px;font-weight:700}.dash-empty{color:#94a3b8;font-size:14px;padding:22px 16px;text-align:center}@media (max-width: 1100px){.dash-recent{grid-template-columns:1fr}}.stock-ok{color:#15803d}.stock-low{color:#b91c1c}.doc-form{display:flex;flex-direction:column;gap:22px;padding:20px}.doc-form input,.doc-form select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#111827;font:inherit;font-weight:500;min-height:40px;padding:8px 10px;width:100%}.doc-form input:focus,.doc-form select:focus{border-color:#1f6feb;box-shadow:0 0 0 3px #1f6feb1f;outline:none}.form-block{display:flex;flex-direction:column;gap:12px}.form-block-title{align-items:center;color:#0f172a;display:flex;font-size:14px;font-weight:800;gap:8px}.form-block-title:before{background:#1f6feb;border-radius:2px;content:"";height:14px;width:3px}.form-fields{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.form-field{color:#334155;display:flex;flex-direction:column;font-size:13px;font-weight:700;gap:6px}.form-field-wide{grid-column:1 / -1}.lines-scroll{overflow-x:auto}.lines{display:flex;flex-direction:column;gap:8px;min-width:760px}.lines-head,.line-row{align-items:center;display:grid;gap:10px;grid-template-columns:minmax(180px,2.4fr) minmax(130px,1.4fr) 80px minmax(96px,1fr) minmax(96px,1fr) minmax(120px,1.4fr) 40px}.lines-head{color:#64748b;font-size:12px;font-weight:800;padding:0 2px 2px}.lines-head .num,.line-amount,.line-row input[type=number]{text-align:right}.line-row{background:#f8fafc;border:1px solid #eef2f6;border-radius:10px;padding:10px}.line-amount{color:#0f172a;font-weight:700;padding-right:2px}.line-add{align-self:flex-start}.doc-form-footer{align-items:center;border-top:1px solid #e5eaf0;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding-top:16px}.doc-form-total{color:#334155;font-size:14px}.doc-form-total strong{color:#111827;font-size:19px;margin-left:6px}@media (max-width: 720px){.form-fields{grid-template-columns:1fr}}.success-msg{background:#f0fdf4;border-radius:8px;color:#15803d;font-size:14px;padding:10px 12px}.password-form{max-width:420px}.doc-table .doc-col-toggle{padding-left:10px;padding-right:0;width:34px}.doc-table .doc-col-num{text-align:right}.doc-expand-btn{background:transparent;color:#64748b;display:inline-flex;padding:4px}.doc-expand-btn:hover{color:#1f2937}.doc-chevron{transition:transform .15s ease}.doc-chevron.open{transform:rotate(90deg)}.doc-num{font-weight:700}.doc-row.open>td{background:#f8fafc}.doc-status{border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;padding:4px 9px}.doc-status.draft{background:#e2e8f0;color:#475569}.doc-status.confirmed{background:#dcfce7;color:#166534}.doc-status.cancelled{background:#fee2e2;color:#991b1b}.doc-confirmed-at{color:#94a3b8;font-size:12px}.doc-detail-row>td{background:#f1f5f9;padding:4px 18px 14px;white-space:normal}.doc-detail-table{background:#fff;border:1px solid #e5eaf0;border-radius:8px;min-width:0;overflow:hidden}.doc-detail-table th,.doc-detail-table td{font-size:13px;padding:8px 12px;white-space:nowrap}.doc-detail-table tr:last-child td{border-bottom:0}.doc-itemcode{color:#94a3b8}.doc-detail-modal{max-width:780px}.doc-detail-head{align-items:center;display:flex;gap:12px}.doc-detail-head h2{margin:0}.doc-meta{display:grid;gap:8px 24px;grid-template-columns:repeat(2,minmax(0,1fr));margin:4px 0 6px}.doc-meta>div{display:flex;gap:8px}.doc-meta dt{color:#64748b;min-width:64px}.doc-meta dd{font-weight:600;margin:0}.doc-detail-modal .doc-detail-table{width:100%}.doc-detail-table tfoot td{background:#f8fafc;font-weight:700}h1,h2,p{margin:0}h1{font-size:28px}h2{font-size:20px}p{color:#64748b;margin-top:6px}.dashboard-grid{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:18px}.metric,.panel,.section{background:#fff;border:1px solid #d9e1ea;border-radius:8px}.metric{display:grid;gap:8px;padding:18px}.metric span{color:#64748b;font-size:13px;font-weight:700}.metric strong{color:#111827;font-size:24px}.master-tabs{background:#fff;border:1px solid #d9e1ea;border-radius:8px;display:grid;gap:0;grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:18px;overflow:hidden}.tab-button{background:#fff;border-radius:0;border-right:1px solid #d9e1ea;color:#334155;display:grid;gap:4px;padding:14px 16px;text-align:left}.tab-button:last-child{border-right:0}.tab-button span{font-size:15px;font-weight:900}.tab-button small{color:#64748b;font-size:12px;font-weight:700}.tab-button.active{background:#eaf2ff;box-shadow:inset 0 -3px #1f6feb;color:#174ea6}.tab-button.active small{color:#315f9f}.section{overflow:hidden}.section-header{align-items:center;border-bottom:1px solid #d9e1ea;display:flex;justify-content:space-between;gap:16px;padding:18px}.panel{margin:18px;padding:18px}.entry-form{background:#f8fafc;border-bottom:1px solid #d9e1ea;display:grid;gap:14px;grid-template-columns:repeat(4,minmax(0,1fr));padding:18px}.sub-entry-form{background:#eef6ff}.entry-form label{color:#334155;display:grid;font-size:13px;font-weight:800;gap:6px}.entry-form input,.entry-form select,.filter-bar input,.filter-bar select{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#111827;font:inherit;font-weight:500;min-height:40px;padding:8px 10px;width:100%}.field-hint{color:#64748b;font-size:12px;font-weight:700;line-height:1.35}.filter-bar{background:#fff;border-bottom:1px solid #d9e1ea;display:grid;gap:14px;grid-template-columns:240px minmax(260px,1fr);padding:14px 18px}.filter-bar label{color:#334155;display:grid;font-size:13px;font-weight:800;gap:6px}.input-with-action{display:grid;gap:8px;grid-template-columns:minmax(0,1fr) auto}.checks{align-items:end;display:flex;gap:14px}.checks label{align-items:center;display:flex;gap:7px;min-height:40px}.checks input{min-height:0;width:auto}.form-actions{align-items:end;display:flex;gap:8px}.production-form{border-bottom-color:#cbd5e1}.bom-lines{display:grid;gap:10px;grid-column:1 / -1}.bom-line,.receipt-line{align-items:end;display:grid;gap:10px;grid-template-columns:minmax(180px,1.5fr) minmax(140px,.8fr) minmax(160px,1fr) auto}.receipt-lines{display:grid;gap:10px;grid-column:1 / -1}.receipt-line{grid-template-columns:minmax(180px,1.3fr) minmax(150px,1fr) minmax(100px,.6fr) minmax(120px,.7fr) minmax(140px,1fr) auto}.receipt-total{align-self:end;color:#334155;font-size:13px;font-weight:900;min-height:40px;padding:10px 0}.icon-button{align-items:center;display:inline-flex;height:40px;justify-content:center;padding:10px;width:40px}.inline-add{align-items:center;display:inline-flex;gap:6px;justify-self:start}.production-preview{align-self:end;color:#475569;font-size:13px;font-weight:800;min-height:40px;padding:10px 0}.serial-lines{display:grid;gap:10px;grid-column:1 / -1}.serial-line{align-items:end;display:grid;gap:10px;grid-template-columns:minmax(180px,1fr) minmax(180px,1fr) minmax(180px,1fr)}.error{background:#fef2f2;border-bottom:1px solid #fecaca;color:#991b1b;font-size:13px;font-weight:800;padding:12px 18px}.header-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.sub-section{border-top:1px solid #d9e1ea}.sub-section-header{background:#fff;padding:16px 18px 8px}h3{font-size:16px;margin:0}.table-wrap{overflow-x:auto}table{border-collapse:collapse;min-width:760px;width:100%}th,td{border-bottom:1px solid #e5eaf0;padding:12px 18px;text-align:left;white-space:nowrap}th{background:#f8fafc;color:#475569;font-size:13px}.empty{color:#64748b;padding:32px;text-align:center}.badge{border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;padding:4px 9px}.badge.active{background:#dcfce7;color:#166534}.badge.inactive{background:#fee2e2;color:#991b1b}@media (max-width: 860px){.app-shell{grid-template-columns:1fr}.sidebar{position:static}.dashboard-grid,.master-tabs{grid-template-columns:1fr}.tab-button{border-bottom:1px solid #d9e1ea;border-right:0}.tab-button:last-child{border-bottom:0}.entry-form,.filter-bar,.bom-line,.receipt-line,.serial-line{grid-template-columns:1fr}main{padding:18px}}
