:root{--primary: #1565c0;--primary-dark: #0d47a1;--primary-light: #e3f0fd;--danger: #c0392b;--success: #27ae60;--info: #2980b9;--bg: #f3f4f7;--card: #ffffff;--text: #202124;--text-secondary: #5f6368;--border: #e3e4e8;--shadow: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .06);--radius: 12px;--topbar-h: 56px;--bottomnav-h: 60px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Roboto,Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);font-size:15px;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}h1,h2,h3{margin:0;font-weight:500}.app-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--primary);color:#fff;display:flex;align-items:center;padding:0 16px;gap:8px;box-shadow:0 2px 4px #0003;z-index:50}.topbar-title{font-size:18px;font-weight:500;letter-spacing:.2px}.topbar-back{background:none;border:none;color:#fff;padding:6px;margin-left:-8px;cursor:pointer;display:flex;align-items:center}.app-main{flex:1;margin-top:var(--topbar-h);margin-bottom:var(--bottomnav-h);width:100%;max-width:760px;margin-left:auto;margin-right:auto}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottomnav-h);background:var(--card);border-top:1px solid var(--border);display:flex;z-index:50;padding-bottom:env(safe-area-inset-bottom)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--text-secondary);font-size:11px}.nav-item.active{color:var(--primary);font-weight:500}.page{padding:16px 14px 24px}.page-title{font-size:20px;margin-bottom:12px}.page-head-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.page-head-row .page-title{margin-bottom:0}.page-loading{padding:48px 16px;text-align:center;color:var(--text-secondary)}.section-title{font-size:14px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-secondary);margin:18px 2px 8px}.empty-state{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 16px;text-align:center;color:var(--text-secondary);margin-bottom:12px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px;margin-bottom:10px}.card-title{font-size:15px;margin-bottom:10px}.card-list{display:flex;flex-direction:column}.task-card{display:flex;align-items:center;gap:10px;color:inherit}.task-card-main{flex:1;min-width:0}.task-card-title{font-weight:500;overflow:hidden;text-overflow:ellipsis}.task-card-sub{font-size:13px;color:var(--text-secondary);margin-top:2px}.task-card-meta{font-size:12px;color:var(--text-secondary);margin-top:2px}.priority-dot{display:inline-block;width:10px;height:10px;border-radius:50%;flex-shrink:0}.muted{color:var(--text-secondary)}.strike{text-decoration:line-through}.chip{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.chip-done{background:#ececef;color:var(--text-secondary)}.chip-pending{background:var(--primary-light);color:var(--primary-dark)}.chip-overdue{background:#fdecea;color:var(--danger);border:1px solid #f5c6c0}.chip-neutral{background:#f1f3f4;color:var(--text)}.badge{background:var(--primary);color:#fff;border-radius:999px;font-size:12px;padding:2px 9px;font-weight:500}.tabs{display:flex;gap:6px;overflow-x:auto;margin-bottom:14px;padding-bottom:2px;-webkit-overflow-scrolling:touch}.tab{flex-shrink:0;background:var(--card);border:1px solid var(--border);border-radius:999px;padding:7px 14px;font-size:13px;color:var(--text-secondary);cursor:pointer}.tab.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;text-align:center}.btn:disabled{opacity:.6;cursor:default}.btn-primary{background:var(--primary);color:#fff}.btn-secondary{background:var(--primary-light);color:var(--primary-dark)}.btn-danger{background:#fdecea;color:var(--danger)}.btn-done{background:var(--success);color:#fff;font-size:16px;padding:13px 16px}.btn-ghost{background:transparent;color:var(--primary)}.btn-block{display:flex;width:100%;margin-top:12px}.btn-small{padding:6px 12px;font-size:13px}.btn-row{display:flex;gap:8px;margin-top:14px}.btn-row.wrap{flex-wrap:wrap;margin-top:0}.btn-row .btn{flex:1}.btn-row.wrap .btn{flex:initial}.link-btn{background:none;border:none;color:var(--danger);cursor:pointer;font-size:inherit;padding:0}.field{display:block;margin-bottom:12px}.field-label{display:block;font-size:12.5px;font-weight:500;color:var(--text-secondary);margin-bottom:5px}.field input[type=text],.field input[type=email],.field input[type=password],.field input[type=number],.field input[type=tel],.field input[type=url],.field input[type=search],.field input[type=date],.field input[type=datetime-local],.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit;background:#fff;color:var(--text)}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--primary);outline-offset:-1px;border-color:var(--primary)}.field-inline{display:flex;align-items:center;gap:8px}.field-inline .field-label{margin-bottom:0}.form-card{padding:16px}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-error{background:#fdecea;color:var(--danger);border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:12px}.hint{display:block;font-size:12px;color:var(--text-secondary);margin-top:4px}.search-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:999px;font-size:14px;margin-bottom:12px;font-family:inherit}.segmented{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.segment{flex:1;background:#fff;border:none;padding:10px 0;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;font-family:inherit}.segment+.segment{border-left:1px solid var(--border)}.segment.seg-high.active{background:#c0392b;color:#fff}.segment.seg-medium.active{background:#2980b9;color:#fff}.segment.seg-low.active{background:#27ae60;color:#fff}.inline-form{display:flex;gap:8px;margin-top:10px}.inline-form input{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-family:inherit}.detail-card.overdue-card{border-left:4px solid var(--danger)}.detail-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.detail-head h2{font-size:18px}.detail-subheader{font-size:13px;color:var(--text-secondary);margin:4px 0 12px}.detail-row{display:flex;padding:7px 0;border-bottom:1px solid #f3f3f5;gap:12px}.detail-row:last-of-type{border-bottom:none}.detail-label{width:110px;flex-shrink:0;font-size:13px;color:var(--text-secondary)}.detail-value{flex:1;word-break:break-word}.detail-image{width:100%;max-height:260px;object-fit:cover;border-radius:8px;margin-bottom:10px}.update-card{border-left:3px solid var(--primary-light)}.update-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px}.update-summary{font-size:12.5px;color:var(--text-secondary)}.update-line{font-size:14px;margin-top:4px;word-break:break-word}.update-image{max-width:100%;max-height:180px;border-radius:8px;margin-top:6px}.table-wrap{padding:0;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-secondary);padding:11px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table td{padding:11px 12px;border-bottom:1px solid #f3f3f5;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover{background:#f8f9fb}.chart-card{padding-bottom:6px}.pie-counts{display:flex;flex-wrap:wrap;gap:12px;padding:8px 2px 10px;font-size:13px;color:var(--text-secondary);align-items:center}.pie-count{display:inline-flex;align-items:center;gap:5px}.group-card{padding:0;overflow:hidden}.group-head{width:100%;display:flex;align-items:center;gap:8px;background:none;border:none;padding:13px 14px;font-size:15px;font-weight:500;cursor:pointer;font-family:inherit;color:var(--text);text-align:left}.group-name{flex:1}.group-body{padding:0 10px 10px}.group-body .task-card{box-shadow:none;border:1px solid var(--border);margin-bottom:8px}.calendar-card{padding:10px}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.cal-head .btn{padding:4px 14px;font-size:18px}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.cal-dow{font-size:11px;color:var(--text-secondary);text-align:center;margin-bottom:4px}.cal-dow>div{padding:2px 0;text-align:center}.cal-cell{aspect-ratio:1 / 1;border:none;background:#fafafa;border-radius:8px;font-size:13px;font-family:inherit;color:var(--text);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:0}.cal-cell.empty{background:transparent;cursor:default}.cal-cell.today{outline:1.5px solid var(--primary)}.cal-cell.selected{background:var(--primary);color:#fff}.cal-dots{display:flex;gap:2px}.cal-dots i{width:5px;height:5px;border-radius:50%;display:inline-block}.job-row{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid #f3f3f5;cursor:pointer}.job-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--success)}.ledger-totals{display:flex;gap:16px;background:#f8f9fb;border-radius:8px;padding:9px 12px;margin-bottom:10px;font-size:13px;color:var(--text-secondary)}.ledger-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid #f3f3f5}.ledger-main{flex:1;min-width:0}.ledger-amount{font-weight:600;white-space:nowrap}.cr{color:var(--success)}.dr{color:var(--danger)}.ledger-form{margin-top:12px;border-top:1px dashed var(--border);padding-top:12px}.tool-card{display:flex;align-items:center;gap:10px}.tool-card-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.user-card{display:flex;align-items:center;gap:13px}.avatar{width:46px;height:46px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:500;flex-shrink:0}.user-name{font-weight:500;font-size:16px}.menu-list{padding:4px 0}.menu-item{display:flex;align-items:center;gap:13px;width:100%;padding:13px 16px;color:var(--text);font-size:15px;background:none;border:none;border-bottom:1px solid #f3f3f5;cursor:pointer;font-family:inherit;text-align:left}.menu-item:last-child{border-bottom:none}.menu-icon{width:26px;text-align:center;font-size:17px}.menu-arrow{margin-left:auto;color:var(--text-secondary);font-size:18px}.menu-logout{color:var(--danger)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,var(--primary) 0%,var(--primary-dark) 60%)}.login-card{width:100%;max-width:380px;padding:28px 24px}.login-logo{width:56px;height:56px;border-radius:14px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:14px}.login-logo-img{height:64px;margin-bottom:14px;align-self:flex-start}.topbar-logo{height:28px;width:28px;border-radius:6px;background:#fff;margin-right:10px}.pie-count-btn{border:1px solid transparent;background:none;font:inherit;cursor:pointer;border-radius:14px;padding:2px 8px}.pie-count-btn.active{border-color:var(--primary);background:#1565c014}.login-card h1{font-size:21px}.login-sub{color:var(--text-secondary);font-size:13.5px;margin:6px 0 18px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:100}.modal-card{background:var(--card);width:100%;max-width:560px;max-height:88vh;border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .18s ease-out}@keyframes slideUp{0%{transform:translateY(40px);opacity:.6}to{transform:translateY(0);opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px}.modal-head h3{font-size:17px}.modal-close{background:none;border:none;font-size:26px;line-height:1;color:var(--text-secondary);cursor:pointer;padding:0 4px}.modal-body{padding:8px 16px 18px;overflow-y:auto}.modal-foot{padding:10px 16px 16px;border-top:1px solid var(--border)}@media (min-width: 640px){.modal-overlay{align-items:center;padding:24px}.modal-card{border-radius:16px}}.toast{position:fixed;bottom:calc(var(--bottomnav-h) + 14px);left:50%;transform:translate(-50%);background:#323232;color:#fff;padding:11px 20px;border-radius:999px;font-size:14px;box-shadow:0 3px 10px #0000004d;z-index:200;max-width:calc(100vw - 32px);animation:toastIn .2s ease-out}@keyframes toastIn{0%{transform:translate(-50%,12px);opacity:0}to{transform:translate(-50%);opacity:1}}.toast-error{background:var(--danger)}.checkin-card p{margin:0 0 4px;color:var(--text-secondary);font-size:14px}.tile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (min-width: 520px){.tile-grid{grid-template-columns:repeat(3,1fr)}}.tile{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text);font-weight:500;font-size:14px;text-align:center}.tile-icon{font-size:30px}.filter-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}.filter-row select,.filter-row input[type=date]{flex:1;min-width:130px;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:#fff;color:var(--text)}.btn-row-inline{display:inline-flex;gap:8px;align-items:center}.data-table tr.row-low td{background:#fdecea}.chip-amber{background:#fdf3da;color:#9a6700}.chip-blue{background:var(--primary-light);color:var(--primary-dark)}.chip-green{background:#e6f6ec;color:#1d7a3e}.stock-card{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:6px 0 10px}.stock-qty{font-size:34px;font-weight:600;color:var(--primary-dark);line-height:1}.line-card{border:1px solid var(--border);border-radius:10px;padding:10px 10px 8px;margin-bottom:10px;background:var(--card)}.line-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:12.5px;color:var(--text-secondary)}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.warn-text{display:block;color:var(--danger);font-size:12px;margin-top:4px}.totals-grand{font-weight:700;font-size:16px}.bom-select{width:100%;min-width:160px;padding:7px 8px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit;background:#fff;color:var(--text)}.bom-qty{width:76px;padding:7px 8px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit}.check-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:8px 10px;margin-bottom:12px}.check-list label{display:flex;gap:8px;align-items:center;font-size:14px}.print-slip{display:none}.slip-head{text-align:center;margin-bottom:12px}.slip-head h2{font-size:18px;margin-bottom:2px}.slip-meta{display:flex;flex-wrap:wrap;gap:4px 24px;font-size:12px;margin-bottom:10px}.slip-table{width:100%;border-collapse:collapse;font-size:12px}.slip-table th,.slip-table td{border:1px solid #888;padding:5px 7px;text-align:left}.slip-totals{margin-top:10px;font-size:12px;text-align:right}.slip-sign{display:flex;justify-content:space-between;gap:16px;margin-top:48px;font-size:12px}@media print{body *{visibility:hidden}.topbar,.bottom-nav,.no-print{display:none!important}.print-slip.print-active{display:block;visibility:visible;position:absolute;left:0;top:0;width:100%;background:#fff;color:#000;padding:12px}.print-slip.print-active *{visibility:visible}}
