:root{--bg: #0f0f10;--bg-elev: #17171a;--bg-elev-2: #1f1f24;--border: #2a2a30;--text: #e8e8ea;--text-muted: #9a9aa0;--accent: #5b8cff;--accent-hover: #7aa4ff;--danger: #e05262;--warn: #f5a524;--ok: #2ecc71;--radius: .5rem}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.45}h1,h2,h3{margin:0 0 .75rem;font-weight:500}h1{font-size:1.4rem}h3{font-size:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}code{background:var(--bg-elev-2);padding:.1em .4em;border-radius:.3em;font-family:ui-monospace,monospace;font-size:.9em}.code-block{display:block;padding:.75rem 1rem;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius);word-break:break-all;margin:.5rem 0}.boot{display:grid;place-items:center;min-height:100vh;color:var(--text-muted)}.login{display:grid;place-items:center;min-height:100vh;padding:1.5rem}.login__card{width:min(400px,100%);background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;display:grid;gap:1rem}.login__error{background:#e0526226;color:var(--danger);border:1px solid rgba(224,82,98,.4);padding:.5rem .75rem;border-radius:var(--radius);font-size:.9rem}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;gap:1.5rem;align-items:center;padding:.75rem 1.5rem;background:var(--bg-elev);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.topbar__brand{font-weight:600;letter-spacing:.02em}.topbar__nav{flex:1;display:flex;gap:.25rem}.nav-link{padding:.5rem .9rem;border-radius:var(--radius);color:var(--text-muted)}.nav-link:hover,.nav-link--active{color:var(--text);background:var(--bg-elev-2)}.topbar__user{display:flex;gap:.75rem;align-items:center;color:var(--text-muted)}.topbar__username{font-size:.9rem}.content{padding:1.5rem;max-width:1400px;width:100%;margin:0 auto}.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.muted{color:var(--text-muted)}.ok{color:var(--ok)}.err{color:var(--danger)}.back-link{display:inline-block;margin-bottom:.25rem;color:var(--text-muted);font-size:.85rem}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1rem;display:grid;gap:.75rem}.card--success{border-color:var(--ok);background:#2ecc7114}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.frame-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;color:var(--text);display:grid;gap:.5rem}.frame-card:hover{border-color:var(--accent);background:var(--bg-elev-2)}.frame-card__head{display:flex;justify-content:space-between;align-items:center}.frame-card__head h2{margin:0;font-size:1.1rem}.frame-card__slug{font-family:ui-monospace,monospace;color:var(--text-muted);font-size:.85rem}.frame-card__stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem 1rem;margin:.5rem 0 0;font-size:.85rem}.frame-card__stats dt{color:var(--text-muted)}.frame-card__stats dd{margin:0;font-size:1.05rem;font-weight:500}.pill{display:inline-block;padding:.15rem .6rem;border-radius:999px;font-size:.8rem;background:var(--bg-elev-2);color:var(--text-muted)}.pill--ok{color:var(--ok);background:#2ecc711f}.pill--muted{color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem 1rem;margin:0}.stats-grid dt{color:var(--text-muted);font-size:.8rem}.stats-grid dd{margin:0;font-size:1.05rem;font-weight:500}label{display:grid;gap:.3rem}label>span{font-size:.85rem;color:var(--text-muted)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=time],select,textarea{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);padding:.55rem .7rem;border-radius:var(--radius);font:inherit;min-width:0}input[type=file]{color:var(--text-muted);padding:.35rem 0}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);outline-offset:-1px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;align-items:end}.checkbox{display:flex;flex-direction:row;gap:.5rem;align-items:center}fieldset{border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1rem;margin:0}fieldset legend{color:var(--text-muted);font-size:.85rem;padding:0 .4rem}.btn{display:inline-flex;gap:.4rem;align-items:center;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);padding:.55rem .9rem;border-radius:var(--radius);cursor:pointer;font:inherit}.btn:hover{background:#25252b}.btn:disabled{opacity:.5;cursor:wait}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff;justify-self:start}.btn--primary:hover{background:var(--accent-hover)}.btn--danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn--warn{background:var(--warn);border-color:var(--warn);color:#1a1a1a;font-weight:500}.btn--ghost{background:transparent}.btn--sm{padding:.3rem .6rem;font-size:.85rem}.btn-row{display:flex;flex-wrap:wrap;gap:.5rem}.alert{padding:.6rem .9rem;border-radius:var(--radius);border:1px solid transparent;font-size:.9rem}.alert--error{background:#e052621a;border-color:#e0526280;color:var(--danger)}.alert--ok{background:#2ecc711a;border-color:#2ecc7180;color:var(--ok)}.table{width:100%;border-collapse:collapse;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table th,.table td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid var(--border);vertical-align:top;font-size:.9rem}.table th{background:var(--bg-elev-2);color:var(--text-muted);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.table tr:last-child td{border-bottom:none}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;gap:.4rem;align-items:center;padding:.3rem .7rem;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;cursor:pointer;font-size:.9rem}.filter-card{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid!important}.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem}.thumb{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;padding:0;aspect-ratio:4 / 3;display:block}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb--hidden img{opacity:.35;filter:grayscale(.7)}.thumb__fav{position:absolute;top:.4rem;left:.4rem;color:#ffd53a;text-shadow:0 0 4px rgba(0,0,0,.5)}.thumb__status{position:absolute;top:.4rem;right:.4rem;padding:.1rem .45rem;font-size:.7rem;border-radius:999px;background:#0009;color:#fff;text-transform:uppercase;letter-spacing:.04em}.thumb__status--approved{background:#2ecc71cc}.thumb__status--pending{background:#f5a524d9;color:#1a1a1a}.thumb__status--hidden{background:#646464e6}.thumb__meta{position:absolute;left:0;right:0;bottom:0;padding:.3rem .5rem;background:linear-gradient(to top,#000000d9,#0000);font-size:.72rem;color:#ffffffd9;text-align:left}.modal{position:fixed;inset:0;background:#000000bf;display:grid;place-items:center;padding:1rem;z-index:100}.modal__card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);width:min(100%,1000px);max-height:90vh;overflow:auto;display:grid;grid-template-columns:1fr 320px;gap:1rem}@media(max-width:720px){.modal__card{grid-template-columns:1fr}}.modal__img{width:100%;height:100%;object-fit:contain;background:#000;min-height:300px}.modal__body{padding:1.25rem;display:grid;gap:1rem}.upload-results{margin:0;padding:0;list-style:none;display:grid;gap:.3rem}.upload-result{padding:.4rem .6rem;border-radius:var(--radius);font-size:.85rem;background:var(--bg-elev-2);border:1px solid var(--border)}.upload-result--created{border-color:#2ecc7180;color:var(--ok)}.upload-result--duplicate{border-color:#f5a52480;color:var(--warn)}.upload-result--error{border-color:#e0526280;color:var(--danger)}.thumb-wrap{display:flex;flex-direction:column;gap:.25rem}.thumb-card{position:relative}.thumb-wrap--selected .thumb{outline:2px solid var(--accent, #38bdf8);outline-offset:-2px}.thumb__select{position:absolute;bottom:.35rem;right:.35rem;background:#0f172ac7;border-radius:4px;padding:2px 5px;display:inline-flex;align-items:center;z-index:3;cursor:pointer}.thumb__select input{margin:0;cursor:pointer;width:18px;height:18px;accent-color:var(--accent, #38bdf8)}.thumb__chips{display:flex;flex-wrap:wrap;gap:.2rem;padding:0 .1rem}.chip{display:inline-flex;align-items:center;gap:.25rem;padding:.1rem .5rem;font-size:.7rem;border-radius:999px;background:var(--bg-elev-2, #1e293b);border:1px solid var(--border, #334155);color:#cbd5e1;text-decoration:none;cursor:pointer;font-family:inherit;line-height:1.4}.chip:hover{background:var(--bg-elev, #1f2a3a);color:#f1f5f9}.chip--approved{border-color:#2ecc718c;color:#8ce2b2}.chip--pending{border-color:#f5a5248c;color:#fcc882}.chip--hidden{border-color:#78787899;color:#b4b4b4;text-decoration:line-through}.chip--add{border-style:dashed;color:var(--accent, #38bdf8)}.chip__x{font-size:.95em;line-height:1;padding:0 .15rem;border-radius:999px;cursor:pointer;opacity:.65}.chip__x:hover{opacity:1;color:var(--danger, #ef4444)}.chips-row{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.add-frame-wrap{position:relative;display:inline-block}.add-frame-pop{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg-elev, #1f2a3a);border:1px solid var(--border, #334155);border-radius:6px;box-shadow:0 4px 16px #00000080;z-index:110;min-width:180px;max-height:240px;overflow:auto}.add-frame-pop__item{width:100%;text-align:left;padding:.45rem .7rem;background:transparent;border:0;color:#e2e8f0;cursor:pointer;font:inherit}.add-frame-pop__item:hover{background:var(--bg-elev-2, #1e293b)}.bulk-toolbar{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:.75rem;padding:.5rem .85rem;margin-bottom:.75rem;background:var(--bg-elev, #1f2a3a);border:1px solid var(--accent, #38bdf8);border-radius:var(--radius);box-shadow:0 2px 8px #00000059}.bulk-toolbar strong{color:#f1f5f9}.modal__card--narrow{grid-template-columns:1fr!important;width:min(100%,480px)!important}.bulk-frames{display:flex;flex-direction:column;gap:.4rem;max-height:50vh;overflow:auto;padding:.25rem 0}.bulk-frames__item{display:grid;grid-template-columns:auto 1fr auto;gap:.6rem;align-items:center;padding:.45rem .6rem;background:var(--bg-elev-2, #1e293b);border:1px solid var(--border, #334155);border-radius:6px;cursor:pointer}.bulk-frames__item:hover{border-color:var(--accent, #38bdf8)}.bulk-frames__item input[type=checkbox]{width:16px;height:16px;cursor:pointer}
