:root{--d365-blue: #0078d4;--d365-blue-dark: #106ebe;--ink: #1b1a19;--muted: #605e5c;--line: #e1dfdd;--bg: #faf9f8;--header-bg: #1b1a19;--red: #d13438;--ok: #107c10;--radius: 6px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%}body{font-family:Segoe UI,system-ui,-apple-system,Roboto,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}.app{max-width:860px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:#fff;border-left:1px solid var(--line);border-right:1px solid var(--line)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--line)}.topbar h1{font-size:18px;font-weight:600;margin:0}.close{background:var(--red);color:#fff;border:none;width:36px;height:36px;font-size:16px;line-height:1;border-radius:var(--radius);cursor:pointer}.close:hover{filter:brightness(.92)}.tabs{display:flex;border-bottom:1px solid var(--line)}.tab{flex:1;padding:12px 8px;background:#f3f2f1;border:none;border-right:1px solid var(--line);font-size:15px;font-weight:600;color:var(--muted);cursor:pointer}.tab:last-child{border-right:none}.tab.active{background:#fff;color:var(--ink);box-shadow:inset 0 -3px 0 var(--d365-blue)}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;padding:12px 16px}.search{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);opacity:.6;pointer-events:none}.search input{width:100%;padding:10px 36px 10px 12px;border:1px solid var(--line);border-radius:var(--radius);font-size:15px}.search input:focus{outline:2px solid var(--d365-blue);border-color:var(--d365-blue)}.offline-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none}.offline-banner{margin:0 16px 8px;padding:8px 12px;background:#fff4ce;border:1px solid #f2d98c;border-radius:var(--radius);font-size:13px}.content{flex:1;padding:0 16px 16px}.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius)}.grid{width:100%;border-collapse:collapse;font-size:14px}.grid thead th{background:var(--header-bg);color:#fff;text-align:left;padding:0;position:sticky;top:0}.th-btn{width:100%;background:none;border:none;color:#fff;font:inherit;font-weight:600;text-align:left;padding:10px 12px;cursor:pointer}.grid th.num,.grid td.num{text-align:right;white-space:nowrap}.caret{opacity:.9}.grid tbody td{padding:10px 12px;border-top:1px solid var(--line);vertical-align:top}.row{cursor:pointer}.row:nth-child(2n){background:#faf9f8}.row:hover{background:#eff6fc}.row.selected{background:#deecf9}.mono{font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap}.proj-code{color:var(--d365-blue);font-weight:600}.empty{text-align:center;color:var(--muted);padding:24px 12px}.detail{margin-top:16px;border:1px solid var(--line);border-radius:var(--radius);padding:16px;background:#fff}.detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.detail-head h2{margin:0;font-size:18px;font-variant-numeric:tabular-nums}.fields{display:grid;grid-template-columns:130px 1fr;gap:6px 12px;margin:0 0 16px}.fields dt{color:var(--muted);font-size:13px}.fields dd{margin:0;font-size:14px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;background:#f3f2f1;color:var(--muted)}.badge.ok{background:#dff6dd;color:var(--ok)}.photos-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.photos-head h3{margin:0;font-size:15px}.btn{border:1px solid var(--line);background:#fff;border-radius:var(--radius);padding:8px 14px;font-size:14px;font-weight:600;cursor:pointer}.btn.primary{background:var(--d365-blue);border-color:var(--d365-blue);color:#fff}.btn.primary:hover{background:var(--d365-blue-dark)}.btn:disabled{opacity:.6;cursor:default}.muted{color:var(--muted);font-size:13px}.thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.thumb{margin:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.thumb img{display:block;width:100%;height:96px;object-fit:cover}.thumb .pending{font-size:11px;text-align:center;padding:3px;background:#fff4ce;color:#8a6d00}.footer{padding:12px 16px;border-top:1px solid var(--line);color:var(--muted);font-size:12px}@media (max-width: 520px){.topbar h1{font-size:16px}.fields{grid-template-columns:1fr;gap:2px 0}.fields dd{margin-bottom:8px}}
