*,:before,:after{box-sizing:border-box}:root{--bg:#0f0f13;--surface:#1a1a22;--border:#2c2c38;--text:#c9c9d4;--text-dim:#6b6b80;--accent:#7c6af7;--accent-hover:#9280ff;--danger:#f87171;--success:#34d399;--radius:10px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font:15px/1.5 system-ui,sans-serif}body{margin:0}#root,.page{flex-direction:column;min-height:100svh;display:flex}.nav{border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.nav-brand{font-size:1.05rem;font-weight:600}.nav-links{align-items:center;gap:12px;display:flex}.nav-links a{color:var(--text-dim);text-decoration:none}.nav-links a:hover{color:var(--text)}button,.btn-primary{cursor:pointer;border-radius:var(--radius);font:inherit;border:none;transition:background .15s}.btn-primary{background:var(--accent);color:#fff;padding:10px 22px;font-weight:600;text-decoration:none;display:inline-block}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{color:var(--text-dim);background:0 0;padding:6px 12px}.btn-ghost:hover{color:var(--text);background:#ffffff0d}.btn-ghost.small{padding:2px 8px;font-size:13px}.btn-capture{color:#fff;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:68px;height:68px;font-size:28px;display:flex;box-shadow:0 0 0 4px #ef444440}.btn-capture:hover{background:#dc2626}.btn-capture:disabled{opacity:.5;cursor:not-allowed}.auth-wrap{flex:1;justify-content:center;align-items:center;padding:24px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:380px;padding:36px 32px}.auth-card h1{margin:0 0 6px;font-size:1.8rem}.auth-sub{color:var(--text-dim);margin:0 0 24px}.tab-row{gap:4px;margin-bottom:20px;display:flex}.tab{color:var(--text-dim);background:0 0;border-radius:8px;flex:1;padding:8px;font-weight:500}.tab.active{background:var(--accent);color:#fff}form{flex-direction:column;gap:12px;display:flex}input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font:inherit;width:100%;padding:10px 14px}input:focus{outline:2px solid var(--accent);border-color:#0000}.error{color:var(--danger);margin:0;font-size:13px}.capture-wrap{flex-direction:column;flex:1;align-items:center;gap:20px;padding:24px 16px;display:flex}.viewfinder{aspect-ratio:4/3;border:1px solid var(--border);background:#000;border-radius:16px;justify-content:center;align-items:center;width:100%;max-width:540px;display:flex;overflow:hidden}.viewfinder video,.viewfinder img{object-fit:cover;width:100%;height:100%}.viewfinder-placeholder{color:var(--text-dim);font-size:14px}.capture-thumb{object-fit:cover;border:2px solid var(--border);border-radius:12px;width:160px;height:160px}.controls{justify-content:center;align-items:center;gap:16px;display:flex}.status-banner{border-radius:var(--radius);align-items:center;gap:10px;width:100%;max-width:540px;padding:10px 18px;font-size:14px;display:flex}.status-banner.uploading{color:var(--accent);background:#7c6af726}.status-banner.success{color:var(--success);background:#34d39926}.status-banner.error{color:var(--danger);background:#f8717126}.gallery-wrap{flex:1;width:100%;max-width:900px;margin:0 auto;padding:24px 20px}.gallery-wrap h2{margin:0 0 20px}.count{color:var(--text-dim);font-size:.85em;font-weight:400}.grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.grid-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.grid-item img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.grid-item-placeholder{aspect-ratio:1;background:var(--surface);width:100%;animation:1.5s ease-in-out infinite pulse}.grid-item-processing{aspect-ratio:1;background:var(--surface);width:100%;color:var(--text-dim);justify-content:center;align-items:center;font-size:11px;animation:1.5s ease-in-out infinite pulse;display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.lightbox-loading{color:var(--text-dim);padding:40px;font-size:.9em}.grid-item-meta{justify-content:space-between;align-items:center;gap:4px;padding:6px 8px;display:flex}.grid-item-name{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.empty-state{color:var(--text-dim);flex-direction:column;align-items:center;gap:16px;padding:60px 0;display:flex}.lightbox{z-index:100;background:#000000e0;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-inner{flex-direction:column;max-width:min(92vw,1200px);max-height:92vh;display:flex;position:relative}.lightbox-inner img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:calc(92vh - 36px);display:block}.lightbox-close{align-self:flex-end;margin-bottom:6px}.spinner-wrap{flex:1;justify-content:center;align-items:center;padding:40px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
