*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f0f;--surface: #1a1a1a;--border: #2a2a2a;--text: #e8e8e8;--muted: #888;--accent: #f97316;--radius: 12px}body{background:var(--bg);color:var(--text);font-family:system-ui,sans-serif;min-height:100dvh}.site-header{position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--border);padding:1.25rem 1rem 1rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center}.page{width:100%;max-width:600px;margin:1.5rem auto;padding:0 1rem;display:flex;flex-direction:column;gap:1.5rem}h1{font-size:2rem;font-weight:700;letter-spacing:-.03em}.subtitle{color:var(--muted);font-size:.9rem}.filters{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap}.filter-btn{background:var(--surface);color:var(--muted);border:1px solid var(--border);border-radius:999px;padding:.4rem 1rem;font-size:.85rem;cursor:pointer;text-transform:capitalize;transition:all .15s}.filter-btn:hover{color:var(--text);border-color:#444}.filter-btn.active{background:var(--accent);color:#fff;border-color:transparent}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.skeleton{width:100%;aspect-ratio:4/3;background:linear-gradient(90deg,#1f1f1f 25%,#2a2a2a,#1f1f1f 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{to{background-position:-200% 0}}.img-wrapper{position:relative}.animal-img{width:100%;height:auto;max-height:calc(70vh - var(--header-h, 0px));object-fit:contain;display:block;background:#000}.img-wrapper.size-big{position:fixed;top:var(--header-h, 0px);left:0;right:0;bottom:0;z-index:5;background:#000;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.img-wrapper.size-big .animal-img{width:100%;height:100%;max-height:none;cursor:zoom-out}.animal-img:-webkit-full-screen{object-fit:contain;width:100vw;height:100vh}.animal-img:fullscreen{object-fit:contain;width:100vw;height:100vh}.size-controls{margin-left:auto;display:flex;gap:.3rem}.size-btn{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;width:1.9rem;height:1.9rem;font-size:.95rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.size-btn:hover{color:var(--text);border-color:#444}.size-btn.active{color:var(--accent);border-color:var(--accent)}.meta{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem 0}.badge{background:var(--accent);color:#fff;border-radius:999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;text-transform:capitalize}.source{color:var(--muted);font-size:.75rem}.attribution{padding:.25rem 1rem 0;font-size:.75rem;color:var(--muted)}.attribution a{color:var(--muted);text-decoration:underline}.progress-bar{height:3px;background:var(--border);margin-top:1rem}.progress-fill{height:100%;background:var(--accent);transition:width 1s linear}.countdown{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem;font-size:.8rem;color:var(--muted)}.refresh-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;padding:.1rem .3rem;border-radius:4px;transition:color .15s}.refresh-btn:hover:not(:disabled){color:var(--text)}.refresh-btn:disabled{opacity:.4;cursor:default}.error{padding:1rem;color:#f87171;font-size:.85rem;text-align:center}@media(max-width:480px){h1{font-size:1.5rem}.site-header{padding:.6rem 1rem;gap:.5rem}.filters{flex-wrap:nowrap}.filter-btn{padding:.25rem .55rem;font-size:.75rem}}@media(pointer:coarse){.size-btn{width:2.75rem;height:2.75rem;font-size:1rem}.refresh-btn{padding:.5rem .75rem;font-size:1rem}}.admin-login{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;padding:2rem;text-align:center}.admin-login-form{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px}.admin-login-form input{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:1rem;outline:none;transition:border-color .15s}.admin-login-form input:focus{border-color:var(--accent)}.admin-login-form button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.75rem;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.admin-login-form button:hover{opacity:.85}.admin-login-error{color:#f87171;font-size:.85rem}.admin-page{min-height:100dvh}.admin-header{position:sticky;top:0;z-index:10;background:var(--bg);border-bottom:1px solid var(--border);padding:.75rem 1.25rem;display:flex;align-items:center;gap:1rem}.admin-header h1{font-size:1.2rem;font-weight:700}.admin-stats{color:var(--muted);font-size:.85rem}.admin-logout{margin-left:auto;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:.3rem .75rem;font-size:.85rem;cursor:pointer;transition:color .15s,border-color .15s}.admin-logout:hover{color:var(--text);border-color:#444}.admin-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border)}@media(max-width:900px){.admin-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.admin-grid{grid-template-columns:repeat(2,1fr)}}.admin-card{background:var(--surface);display:flex;flex-direction:column}.admin-card.is-removed{opacity:.45}.admin-card-img{position:relative;aspect-ratio:1;background:#080808;overflow:hidden}.admin-card-img img{width:100%;height:100%;object-fit:cover;display:block}.admin-card-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:.8rem}.admin-card-badges{position:absolute;bottom:.35rem;left:.35rem;display:flex;gap:.25rem;flex-wrap:wrap}.admin-badge{font-size:.6rem;font-weight:700;border-radius:999px;padding:.15rem .45rem;text-transform:uppercase;letter-spacing:.02em}.admin-badge.type-cat{background:#92400e;color:#fff}.admin-badge.type-dog{background:#1e3a5f;color:#fff}.admin-badge.type-bird{background:#14532d;color:#fff}.admin-badge.quality-high{background:#166534;color:#fff}.admin-badge.quality-mid{background:#854d0e;color:#fff}.admin-badge.quality-low{background:#7f1d1d;color:#fff}.admin-badge.status-evicted{background:#374151;color:#9ca3af}.admin-badge.status-removed{background:#450a0a;color:#fca5a5}.admin-card-actions{display:flex;border-top:1px solid var(--border)}.admin-action-btn{flex:1;background:transparent;border:none;border-right:1px solid var(--border);padding:.5rem 0;font-size:1rem;cursor:pointer;transition:background .15s;line-height:1}.admin-action-btn:last-child{border-right:none}.admin-action-btn:hover:not(:disabled){background:#ffffff0d}.admin-action-btn:disabled{opacity:.25;cursor:default}.admin-action-btn.thumb-up-active{background:#4ade801f}.admin-action-btn.thumb-down-active{background:#f871711f}.admin-action-btn.remove-btn{color:#f87171}.admin-load-more{padding:2rem;text-align:center}.admin-load-more button{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.75rem 2rem;font-size:.9rem;cursor:pointer;transition:border-color .15s}.admin-load-more button:hover:not(:disabled){border-color:#444}.admin-load-more button:disabled{opacity:.5;cursor:default}@media(pointer:coarse){.admin-action-btn{padding:.85rem 0;font-size:1.2rem}}@keyframes spin{to{transform:rotate(360deg)}}.admin-fetch-btn{display:flex;align-items:center;gap:.35rem;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:.3rem .75rem;font-size:.85rem;cursor:pointer;transition:color .2s,border-color .2s}.admin-fetch-btn:hover:not(:disabled){color:var(--text);border-color:#444}.admin-fetch-btn:disabled{cursor:default}.admin-fetch-btn.done{color:#4ade80;border-color:#166534;transition:color 1.5s,border-color 1.5s}.admin-fetch-icon{display:inline-block}.admin-fetch-icon.spinning{animation:spin .8s linear infinite}.admin-tabs{display:flex;gap:.25rem}.admin-tab{background:transparent;color:var(--muted);border:1px solid transparent;border-radius:6px;padding:.3rem .85rem;font-size:.85rem;cursor:pointer;transition:color .15s,border-color .15s}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--text);border-color:var(--border);background:var(--surface)}.admin-keys{max-width:860px;margin:0 auto;padding:2rem 1.25rem;display:flex;flex-direction:column;gap:2rem}.key-reveal{background:#1a2e1a;border:1px solid #2d5a2d;border-radius:10px;padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.key-reveal-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;font-size:.9rem;color:#86efac}.key-reveal-dismiss{background:transparent;border:none;color:#86efac;cursor:pointer;font-size:1rem;opacity:.7;flex-shrink:0}.key-reveal-dismiss:hover{opacity:1}.key-reveal-row{display:flex;align-items:center;gap:.75rem}.key-reveal-value{flex:1;font-family:monospace;font-size:.9rem;background:#0f1f0f;color:#4ade80;padding:.6rem .85rem;border-radius:6px;overflow-x:auto;white-space:nowrap}.key-copy-btn{background:#166534;color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s}.key-copy-btn:hover{opacity:.85}.admin-keys-create h2{font-size:1rem;font-weight:600;margin-bottom:.75rem}.admin-keys-form{display:flex;gap:.5rem;flex-wrap:wrap}.admin-keys-form input,.admin-keys-form select{background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.55rem .85rem;font-size:.9rem;outline:none;transition:border-color .15s}.admin-keys-form input{flex:1;min-width:160px}.admin-keys-form input:focus,.admin-keys-form select:focus{border-color:var(--accent)}.admin-keys-form button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:.55rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s}.admin-keys-form button:hover:not(:disabled){opacity:.85}.admin-keys-form button:disabled{opacity:.4;cursor:default}.admin-keys-error{color:#f87171;font-size:.85rem;margin-top:.5rem}.admin-keys-table-wrap{overflow-x:auto}.admin-keys-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-keys-table th{text-align:left;color:var(--muted);font-weight:500;padding:.4rem .75rem;border-bottom:1px solid var(--border);white-space:nowrap}.admin-keys-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-keys-table tr:last-child td{border-bottom:none}.admin-keys-table tr:hover td{background:#ffffff05}.admin-keys-name{font-weight:500}.admin-keys-date{color:var(--muted);white-space:nowrap}.admin-keys-never{color:#4b5563}.admin-keys-empty{color:var(--muted);padding:1rem 0}.admin-keys-actions{display:flex;gap:.4rem;justify-content:flex-end}.admin-keys-btn{background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px;padding:.3rem .7rem;font-size:.8rem;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.admin-keys-btn:hover{color:var(--text);border-color:#555}.admin-keys-btn--danger:hover{color:#f87171;border-color:#f87171}.tier-badge{display:inline-block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:999px;padding:.15rem .55rem}.tier-free{background:#1f2937;color:#9ca3af}.tier-pro{background:#1e3a5f;color:#93c5fd}.tier-enterprise{background:#3b1f6e;color:#c4b5fd}
