:root{color-scheme:light;font-family:Inter,Noto Sans Thai,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#eef2f6;color:#17202a;--surface: #ffffff;--surface-soft: #f7f9fc;--surface-info: #eaf3ff;--border: #d7e0ea;--muted: #657387;--blue: #0f69c8;--blue-dark: #0a4f99;--green: #14835d;--yellow: #a56400;--red: #ba2f3a;--shadow: 0 18px 45px rgba(25, 38, 56, .1);--shadow-soft: 0 8px 24px rgba(25, 38, 56, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:#eef2f6}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px 1fr}.sidebar{background:#101923;color:#fff;padding:20px 14px;display:flex;flex-direction:column;gap:22px}.brand{display:flex;gap:10px;align-items:center}.brand-mark{width:42px;height:42px;border-radius:8px;background:#60a5fa;display:grid;place-items:center;font-weight:800;color:#fff}.brand strong{display:block;font-size:15px}.brand span{display:block;font-size:12px;color:#a9b7c8;margin-top:2px}.sidebar nav{display:grid;gap:4px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;color:#c9d4e2;text-decoration:none;font-size:14px}.nav-item.active,.nav-item:hover{background:#1d2d3d;color:#fff}.logout{margin-top:auto;color:#c9d4e2}.main-panel{min-width:0;padding:28px 30px}.page{max-width:1500px;margin:0 auto}.records-page{max-width:1580px}.page-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}.page-header h1{font-size:22px;margin:0;letter-spacing:0}.page-header p{margin:3px 0 0;color:var(--muted);font-size:13px}.page-actions{display:flex;align-items:center;gap:8px}.record-summary{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.record-summary span{height:34px;display:inline-flex;align-items:center;gap:6px;padding:0 11px;border-radius:8px;background:var(--surface);border:1px solid var(--border);color:var(--muted);font-size:12px;box-shadow:var(--shadow-soft)}.record-summary strong{color:#17202a;font-size:13px}input,select{height:38px;border:1px solid var(--border);border-radius:8px;background:#fff;color:#17202a;padding:0 10px;min-width:0}.primary-button,.ghost-button{height:38px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 14px;border:1px solid transparent;font-weight:650}.primary-button{background:var(--blue);color:#fff}.primary-button:hover{background:var(--blue-dark)}.ghost-button{background:var(--surface);border-color:var(--border);color:#243344;text-decoration:none}.wide{width:100%}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px;margin-bottom:16px}.metric{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:15px}.metric span{display:block;color:var(--muted);font-size:13px;margin-bottom:8px}.metric strong{font-size:24px;letter-spacing:0}.metric .accent{color:var(--blue)}.metric.warning strong{color:var(--yellow)}.metric.danger strong{color:var(--red)}.chart-panel,.issue-list,.table-shell,.review-form,.slip-panel,.settings-grid{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow)}.chart-panel{padding:16px;margin-bottom:16px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;gap:8px}.chart-header span{color:var(--muted);font-size:12px}.bar-row{display:grid;grid-template-columns:140px 1fr;gap:12px;align-items:center;margin:10px 0;font-size:13px}.bar-track{height:18px;background:#edf1f5;border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:var(--green)}.bar-fill.warning{background:#d99026}.bar-fill.danger{background:var(--red)}.toolbar{display:flex;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap;background:#ffffffb8;border:1px solid rgba(215,224,234,.7);border-radius:8px;padding:10px}.preset-bar{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-bottom:10px}.preset-bar button{height:32px;border:1px solid var(--border);border-radius:999px;padding:0 13px;background:var(--surface);color:#334155;font-weight:700;font-size:12px}.preset-bar button:hover{border-color:#9bc7f4;color:var(--blue)}.preset-bar button.active{background:#0f69c8;border-color:#0f69c8;color:#fff;box-shadow:0 6px 16px #0f69c838}.search-box{width:min(520px,100%);display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:0 10px}.search-box input{border:0;flex:1;padding:0;outline:none}.filter-controls{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.filter-controls input{width:142px}.filter-controls select{min-width:150px}.table-shell{overflow:auto;box-shadow:var(--shadow-soft);max-height:calc(100vh - 190px)}.records-table{border-collapse:separate;border-spacing:0;min-width:1540px;width:100%;font-size:12.5px;white-space:nowrap;table-layout:fixed}.records-table th,.records-table td{padding:9px 10px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;background:var(--surface)}.records-table th{background:#dfeeff;color:#0b4c88;position:sticky;top:0;z-index:4;font-weight:800}.records-table tr:nth-child(2n) td{background:#f8fafc}.records-table tr:hover td{background:#eef6ff}.records-table tr.row-review td{background:#fffaf0}.records-table tr.row-review:hover td{background:#fff4dc}.records-table th:nth-child(1),.records-table td:nth-child(1){width:210px}.records-table th:nth-child(2),.records-table td:nth-child(2){width:130px}.records-table th:nth-child(3),.records-table td:nth-child(3){width:112px}.records-table th:nth-child(4),.records-table td:nth-child(4){width:140px}.records-table th:nth-child(5),.records-table td:nth-child(5){width:140px}.records-table th:nth-child(6),.records-table td:nth-child(6){width:190px}.records-table th:nth-child(7),.records-table td:nth-child(7){width:170px}.records-table th:nth-child(8),.records-table td:nth-child(8){width:165px}.records-table th:nth-child(9),.records-table td:nth-child(9){width:112px}.records-table th:nth-child(10),.records-table td:nth-child(10){width:102px}.records-table th:nth-child(11),.records-table td:nth-child(11){width:120px}.records-table th:nth-child(12),.records-table td:nth-child(12){width:76px}.records-table th:nth-child(13),.records-table td:nth-child(13){width:82px}.records-table th:nth-child(14),.records-table td:nth-child(14){width:125px}.records-table th:nth-child(15),.records-table td:nth-child(15){width:112px}.sticky-col{position:sticky;left:0;z-index:3;min-width:210px;box-shadow:10px 0 18px #19263812}th.sticky-col{z-index:5;background:#dfeeff}.ref-cell{white-space:normal}.ref-link{display:block;color:#17324d;font-weight:800;text-decoration:none;max-width:186px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ref-link:hover{color:var(--blue);text-decoration:underline}.ref-cell span{display:block;margin-top:2px;color:var(--muted);font-size:10.5px;max-width:186px;overflow:hidden;text-overflow:ellipsis}.cell-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-cell{color:#334155;font-variant-numeric:tabular-nums}.num{text-align:right!important}.mono{font-family:SFMono-Regular,Consolas,monospace}.image-button{height:28px;display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:0 8px;border-radius:7px;border:1px solid #b9d7f7;background:#eff6ff;color:var(--blue);text-decoration:none;font-weight:700}.image-button:hover{background:#dceeff}.status{display:inline-flex;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;background:#edf1f5;color:#415269}.status.completed{background:#e8f7f0;color:var(--green)}.status.needs_review,.status.retry_pending{background:#fff4df;color:var(--yellow)}.status.ocr_failed{background:#fdecef;color:var(--red)}.status.processing,.status.stored{background:var(--surface-info);color:var(--blue)}.sync-mini{font-size:11px;color:var(--muted);font-weight:700}.review-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.review-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px;display:grid;grid-template-columns:78px 1fr;gap:12px;text-decoration:none;color:inherit}.review-card:hover{border-color:#7db5ef}.review-card img{width:78px;height:96px;object-fit:cover;border-radius:6px;background:#e5eaf0}.review-card strong,.review-card span,.review-card small{display:block;margin-top:5px}.review-card span,.review-card small{color:var(--muted);font-size:12px}.detail-layout{display:grid;grid-template-columns:minmax(280px,390px) 1fr;gap:16px;align-items:start}.slip-panel{padding:12px;display:grid;gap:12px}.slip-panel img{width:100%;border-radius:8px;background:#e5eaf0}.review-form{padding:16px;display:grid;gap:12px;box-shadow:none}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}.field{display:grid;gap:5px;font-size:13px;color:var(--muted)}.field input{width:100%}.field small,.form-error{color:var(--red);margin:0}.section-title{font-size:14px;margin:4px 0 0}.alert{border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:8px;font-size:13px}.alert.warning{background:#fff4df;color:var(--yellow)}.alert.danger{background:#fdecef;color:var(--red)}.sync-panel,.settings-grid{padding:12px;display:grid;gap:8px;background:var(--surface-soft);box-shadow:none}.info-row{display:flex;justify-content:space-between;gap:14px;font-size:13px;padding:5px 0;border-bottom:1px solid var(--border)}.info-row:last-child{border-bottom:0}.info-row span{color:var(--muted)}.info-row strong{text-align:right;overflow-wrap:anywhere}.issue-list{padding:14px;display:grid;gap:10px}.empty-state{color:var(--muted);border:1px dashed var(--border);border-radius:8px;padding:22px;text-align:center;background:var(--surface-soft)}.login-page,.screen-center{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(380px,100%);background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;box-shadow:var(--shadow);display:grid;gap:14px}.login-brand{margin-bottom:6px}.login-card label{display:grid;gap:6px;font-size:13px;color:var(--muted)}.bottom-nav{display:none}@media(max-width:860px){.app-shell{display:block;padding-bottom:66px}.sidebar{display:none}.main-panel{padding:14px}.page-header{align-items:flex-start;flex-direction:column}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-layout,.two-col{grid-template-columns:1fr}.bottom-nav{position:fixed;left:0;right:0;bottom:0;display:grid;grid-template-columns:repeat(3,1fr);background:#fff;border-top:1px solid var(--border);padding:6px;z-index:20}.bottom-nav .nav-item{justify-content:center;color:#415269}.bottom-nav .nav-item span{font-size:11px}.bar-row{grid-template-columns:100px 1fr}.filter-controls,.toolbar{justify-content:stretch}.filter-controls input,.filter-controls select,.search-box{width:100%}}
