.centered{min-height:100vh;display:flex;align-items:center;justify-content:center}.muted{color:var(--muted)}.small{font-size:.875rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(ellipse 80% 60% at 50% -20%,#1e3a5f 0%,transparent 55%),var(--bg)}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;box-shadow:0 24px 48px #00000059}.auth-card h1{margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.auth-card form{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.875rem;color:var(--muted)}.auth-card input{padding:.65rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface2);color:var(--text)}.auth-card input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #3b82f640}.error{color:var(--danger);margin:0;font-size:.9rem}.footer-link{margin-top:1.5rem;text-align:center;color:var(--muted);font-size:.9rem}.btn{border:none;border-radius:8px;padding:.65rem 1rem;font-weight:600;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-dim) 100%);color:#fff}.btn.primary:hover:not(:disabled){filter:brightness(1.05)}.btn.secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn.secondary:hover:not(:disabled){background:#243044}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn.ghost:hover{color:var(--text);border-color:var(--muted)}.btn.small{padding:.35rem .65rem;font-size:.8rem}.btn.danger-text{background:transparent;color:var(--danger);padding:.25rem 0;font-weight:500;align-self:flex-start}.btn.danger-text:hover{text-decoration:underline}.dashboard{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.topbar h1{margin:0;font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.panel h2{margin:0 0 .5rem;font-size:1.15rem}.dropzone{margin-top:1rem;border:2px dashed var(--border);border-radius:var(--radius);padding:2.5rem 1rem;text-align:center;cursor:pointer;background:var(--surface2);transition:border-color .15s,background .15s}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:#3b82f614}.dropzone p{margin:0 0 .35rem;font-weight:600}.dropzone .hint{font-size:.8rem;color:var(--muted)}.row-between{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.actions{display:flex;flex-wrap:wrap;gap:.5rem}.toast{margin:.75rem 0 0;padding:.65rem .85rem;background:#22c55e1f;border:1px solid rgba(34,197,94,.35);border-radius:8px;color:#86efac;font-size:.9rem}.image-grid{list-style:none;margin:1rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.image-card{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface2);display:flex;flex-direction:column}.thumb-wrap{aspect-ratio:4 / 3;background:#0a0c10;display:flex;align-items:center;justify-content:center}.thumb-wrap img{max-width:100%;max-height:100%;object-fit:contain}.meta{padding:.75rem;display:flex;flex-direction:column;gap:.35rem;flex:1}.meta .name{font-size:.85rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.url-row{display:flex;gap:.35rem;margin-top:.25rem}.url-row input{flex:1;min-width:0;font-size:.75rem;padding:.4rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--muted)}:root{--bg: #0c0f14;--surface: #151a22;--surface2: #1c2330;--border: #2a3344;--text: #e8ecf4;--muted: #8b95a8;--accent: #3b82f6;--accent-dim: #2563eb;--success: #22c55e;--danger: #ef4444;--radius: 12px;font-family:DM Sans,system-ui,sans-serif;line-height:1.5;font-weight:400;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,button{font-size:1rem}
