*{margin:0;padding:0;box-sizing:border-box;font-family:Heebo,sans-serif}:root{--navy: #1c2333;--navy2: #2a3450;--bg: #f4f5f7;--ink: #1a1a1a;--muted: #6a6f7a;--line: #e6e8ec;--green: #0d8a52;--blue: #2563c9}html,body{background:var(--bg);color:var(--ink)}body{padding-bottom:env(safe-area-inset-bottom)}#root{max-width:540px;margin:0 auto;min-height:100vh;background:var(--bg)}.appbar{background:var(--navy);color:#fff;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:20}.appbar .title{font-weight:700;font-size:18px}.appbar a{color:#9fb0d4;text-decoration:none;font-size:14px}.offline-banner{background:#fbbf24;color:#1a1a1a;text-align:center;font-size:13px;padding:5px;font-weight:500}.content{padding:16px}.btn{display:block;width:100%;padding:14px;border:none;border-radius:13px;font-weight:700;font-size:16px;cursor:pointer;text-align:center;text-decoration:none}.btn-pri{background:var(--navy);color:#fff}.btn-green{background:var(--green);color:#fff}.btn-sec{background:#e7e9ee;color:#3a3f4b}.btn-danger{background:#fde8e8;color:#c0392b}.cat-badge{display:inline-block;background:#eaf3ff;color:#2563c9;font-weight:600;font-size:12px;padding:2px 9px;border-radius:8px;margin-inline-start:8px;vertical-align:middle}.cat-badge.sm{font-size:11px;padding:1px 7px;margin-inline-start:5px}.room-label{display:flex;align-items:center;justify-content:space-between;margin:14px 0 6px}.room-label>span{font-size:14px;color:var(--muted);font-weight:500}.manage-rooms{font-size:13px;color:var(--blue);text-decoration:none}.btn:disabled{opacity:.5}.btn-row{display:flex;gap:10px}.btn-row .btn{flex:1}.chip-row{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}.chip{padding:8px 15px;border-radius:20px;background:#e7e9ee;color:#4a4f5a;font-size:14px;font-weight:500;border:none;cursor:pointer}.chip.on{background:var(--navy);color:#fff}.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px;margin-bottom:12px}input.txt,textarea.txt{width:100%;padding:11px;border:1px solid #d2d6dd;border-radius:10px;font-size:15px;background:#fff;color:var(--ink);margin-bottom:10px}.search{width:100%;padding:12px 14px;border:1px solid #d2d6dd;border-radius:12px;font-size:16px;margin-bottom:14px}.cam-view{background:#15151a;border-radius:16px;height:280px;display:flex;align-items:center;justify-content:center;color:#888;position:relative;overflow:hidden;cursor:pointer}.cam-view img{width:100%;height:100%;object-fit:cover}.cam-view .hint{text-align:center;font-size:15px}.cam-view .hint .big{font-size:44px;display:block;margin-bottom:8px}.items{list-style:none}.items li{background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-bottom:7px;font-size:15px;display:flex;align-items:center;gap:9px}.items li .x{margin-inline-start:auto;color:#c33;cursor:pointer;font-weight:700;background:none;border:none;font-size:18px}.box-row{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;margin-bottom:9px;display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--ink)}.box-row .num{background:var(--navy);color:#fff;width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:20px;flex-shrink:0}.box-row .info{flex:1;min-width:0}.box-row .info .r{font-weight:700;font-size:15px}.box-row .info .s{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.box-row .printed{color:var(--green);font-size:18px}.loading{text-align:center;color:var(--muted);padding:40px 0}.empty{text-align:center;color:var(--muted);padding:50px 16px}.empty .big{font-size:50px;display:block;margin-bottom:12px}.err{background:#fde8e8;color:#c33;border-radius:10px;padding:11px;font-size:14px;margin-bottom:12px}.label-preview{width:100%;background:#fff;border:1px solid #cfd2d8;border-radius:8px;image-rendering:auto}.fab{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--green);color:#fff;border:none;border-radius:50px;padding:15px 26px;font-size:16px;font-weight:700;box-shadow:0 6px 20px #00000040;cursor:pointer;z-index:15;white-space:nowrap}.pgrs{height:8px;background:#e7e9ee;border-radius:4px;overflow:hidden;margin-top:10px}.pgrs>i{display:block;height:100%;width:0;background:var(--green);transition:width .2s}.photo-big{width:100%;border-radius:12px;margin-bottom:12px;display:block}.appbar-actions{display:flex;align-items:center;gap:12px}.logout-btn{background:transparent;border:1px solid rgba(255,255,255,.25);color:#9fb0d4;font-size:13px;padding:4px 10px;border-radius:8px;cursor:pointer}.login-screen{min-height:calc(100vh - 50px);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px 24px;text-align:center;max-width:360px;width:100%;box-shadow:0 8px 30px #00000014}.login-logo{font-size:56px;margin-bottom:8px}.login-card h1{font-size:22px;font-weight:900;margin-bottom:8px}.login-card p{color:var(--muted);font-size:14px;margin-bottom:20px;line-height:1.5}.login-card .gbtn{display:flex;justify-content:center;margin:16px 0}.login-note{font-size:12px;color:#9aa0ac;margin-top:16px;margin-bottom:0}.photo-gallery{display:grid;gap:8px;margin-bottom:14px;grid-template-columns:1fr}.photo-gallery.multi{grid-template-columns:1fr 1fr}.gallery-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;display:block;background:#e7e9ee}.photo-gallery.multi .gallery-img:first-child:nth-last-child(3){grid-column:1 / -1}.thumb-grid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}.thumb{position:relative;width:92px;height:92px;border-radius:12px;overflow:hidden;flex-shrink:0}.thumb img{width:100%;height:100%;object-fit:cover}.thumb-x{position:absolute;top:4px;inset-inline-end:4px;width:26px;height:26px;border-radius:50%;background:#0009;color:#fff;border:none;font-size:18px;line-height:1;cursor:pointer;padding:0}.photos-hint{font-size:12px;color:var(--muted);text-align:center;margin:8px 0 14px}.row-thumb{width:48px;height:48px;border-radius:10px;object-fit:cover;flex-shrink:0;background:#e7e9ee}.seq-badge{display:inline-block;background:#eef1f6;color:var(--navy);font-weight:700;font-size:12px;padding:1px 7px;border-radius:6px;margin-inline-end:4px}html{-webkit-text-size-adjust:100%}*{-webkit-tap-highlight-color:transparent}img,canvas,svg{max-width:100%}.content{overflow-x:hidden;padding-bottom:90px}input,textarea,select,button{font-size:16px}.chip-row{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.chip-row::-webkit-scrollbar{display:none}.chip{white-space:nowrap;flex-shrink:0;min-height:38px}.btn{min-height:50px}.box-row{min-height:64px}.box-row .info{overflow:hidden}.appbar{padding-top:max(14px,env(safe-area-inset-top))}.fab{bottom:max(20px,env(safe-area-inset-bottom))}@media (max-width: 380px){.login-card{padding:24px 18px}.chip{padding:7px 12px;font-size:13px}}
