:root{--brand: #031a2e;--brand-dark: #0a3358;--bg: #f4f6f4;--card: #ffffff;--border: #d7ddd7;--text: #1f2a1f;--muted: #6b756b;--error: #c62828}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}input,textarea,button{font:inherit}.app{max-width:720px;margin:0 auto}.topbar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--brand);color:#fff;position:sticky;top:0;z-index:10}.topbar .brand{font-weight:700}.topbar nav{display:flex;gap:10px}.topbar nav a{color:#e7eef5;text-decoration:none;padding:4px 8px;border-radius:6px}.topbar nav a.active{background:#fff3;color:#fff}.topbar .spacer{flex:1}.topbar .user{font-size:.85rem;opacity:.9}main{padding:14px}.card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:14px}.field{margin-bottom:12px;position:relative}.field label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:4px}.field input[type=text],.field input[type=email],.field input[type=password],.field input[type=search],.field textarea,.toolbar input[type=search]{width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fff}button{background:var(--brand);color:#fff;border:none;border-radius:8px;padding:10px 16px;cursor:pointer}button:hover{background:var(--brand-dark)}button:disabled{opacity:.6;cursor:default}button.link{background:none;color:var(--brand-dark);padding:2px 4px;text-decoration:underline}.centered{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}.centered .card{width:100%;max-width:360px}.centered h1{margin-top:0;color:var(--brand-dark)}.req,.error{color:var(--error)}.info{color:var(--brand-dark)}.muted{color:var(--muted)}.badge{font-size:.7rem;background:#e7eef5;color:var(--brand-dark);border-radius:6px;padding:1px 6px;margin-left:6px}.badge-manual{background:#fff3e0;color:#e65100}.search-select .dropdown{list-style:none;margin:2px 0 0;padding:0;border:1px solid var(--border);border-radius:8px;background:#fff;position:absolute;width:100%;z-index:20;max-height:220px;overflow-y:auto;box-shadow:0 4px 14px #0000001a}.search-select .dropdown li{padding:10px;cursor:pointer}.search-select .dropdown li:hover{background:#eef3f8}.hint{font-size:.75rem;color:var(--muted)}.preview,.history .thumb,img.preview{max-width:100%;border-radius:8px;margin-top:8px}.banner{padding:8px 12px;border-radius:8px;margin-bottom:12px;font-size:.9rem}.banner.offline{background:#fff3e0;color:#e65100}.queue ul{list-style:none;padding:0;margin:0}.queue-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}.queue-item .qname{flex:1}.queue-item .qstatus{font-size:.8rem;padding:2px 8px;border-radius:6px;background:#eee}.status-pending .qstatus{background:#fff8e1;color:#f57f17}.status-uploading .qstatus{background:#e3f2fd;color:#1565c0}.status-error .qstatus{background:#ffebee;color:var(--error)}.status-done .qstatus{background:#e7eef5;color:var(--brand-dark)}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.photo-card{margin:0;padding:8px}.thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;background:#eef2ee}.thumb-loading{display:block}.thumb-failed{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.8rem}.photo-card figcaption{display:flex;flex-direction:column;gap:2px;margin-top:6px;font-size:.85rem}.photo-card .meta{color:var(--muted);font-size:.78rem}.photo-card .filename{color:var(--muted);font-size:.7rem;word-break:break-all}.toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.toolbar input[type=search]{flex:1;min-width:0}.checkbox input[type=checkbox]{width:16px;height:16px;flex:none}.checkbox{flex:none;white-space:nowrap;display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--muted)}.m-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.m-topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top));background:var(--brand);color:#fff}.m-brand{font-weight:700}.m-profile{width:36px;height:36px;border-radius:50%;background:#fff;color:var(--brand-dark);font-weight:700;display:grid;place-items:center;padding:0}.m-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:25}.m-menu{position:absolute;right:12px;top:calc(100% + 6px);z-index:26;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 6px 20px #00000026;padding:12px 14px;display:flex;flex-direction:column;gap:8px;min-width:160px}.m-menu-user{color:var(--muted);font-size:.85rem}.m-main{flex:1;padding:16px;padding-bottom:calc(76px + env(safe-area-inset-bottom))}.m-tabbar{position:fixed;left:0;right:0;bottom:0;z-index:20;display:flex;background:#fff;border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom)}.m-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 0;text-decoration:none;color:var(--muted);font-size:.75rem}.m-tab.active{color:var(--brand-dark);font-weight:600}.m-tab-icon{font-size:1.3rem}.m-home{display:flex;flex-direction:column;align-items:center;min-height:60vh}.m-greeting{align-self:flex-start;font-size:1.6rem;margin:4px 0 0}.m-shutter-wrap{margin-top:auto;margin-bottom:auto;display:flex;flex-direction:column;align-items:center;padding:32px 0}.m-shutter{position:relative;width:168px;height:168px;border-radius:50%;background:var(--brand);display:grid;place-items:center;box-shadow:0 10px 28px #031a2e4d;padding:0;transition:transform .08s ease}.m-shutter:active{transform:scale(.96)}.m-shutter-ring{position:absolute;top:10px;right:10px;bottom:10px;left:10px;border:4px solid rgba(255,255,255,.85);border-radius:50%}.m-shutter-icon{font-size:3.2rem}.m-shutter-hint{margin-top:16px;color:var(--muted)}.m-queue-status{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:8px}.chip{padding:5px 12px;border-radius:999px;font-size:.8rem}.chip-pending{background:#e3f2fd;color:#1565c0}.chip-error{background:#ffebee;color:var(--error)}.m-back{background:none;color:var(--brand-dark);padding:4px 0;margin-bottom:8px;text-decoration:underline}.capture-preview{width:100%;max-height:42vh;object-fit:cover;border-radius:10px;margin-bottom:14px}.brand-logo{height:34px;width:34px;border-radius:50%;background:#fff;object-fit:contain;padding:2px;flex:none}.topbar .brand,.m-brand{display:flex;align-items:center;gap:8px}.login-logo{display:block;width:132px;height:132px;margin:0 auto 12px;object-fit:contain}.topbar .link{color:#fff}.m-brand{font-size:.92rem;line-height:1.1}.range-row{display:flex;align-items:center;gap:8px}.range-row input{flex:1;width:100%;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fff}.range-sep{color:var(--muted);font-weight:600}.search-select .add-new{margin-top:6px;background:#e7eef5;color:var(--brand-dark);border:1px dashed var(--brand-dark);border-radius:8px;padding:8px 10px;width:100%;text-align:left;font-size:.85rem}.search-select .add-new:hover{background:#dbe6f1}.queue-list{list-style:none;margin:0;padding:0}.queue-list .queue-item{display:flex;flex-direction:column;align-items:stretch;gap:4px;padding:10px 0;border-bottom:1px solid var(--border)}.queue-list .qmain{display:flex;align-items:center;gap:10px}.queue-list .qname{flex:1}.queue-list .qactions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.queue-list .qerror{flex:1;min-width:120px;color:var(--error);font-size:.78rem;word-break:break-word}.m-queue h2{font-size:1rem;margin:8px 0 4px}
