:root{--bg: #0d0d10;--bg-elev: #16161b;--bg-elev-2: #1d1d24;--border: #2a2a32;--fg: #e8e8ec;--muted: #8a8a94;--accent: #a78bfa;--bar-bg: rgba(13, 13, 16, .85);--overlay-bg: rgba(13, 13, 16, .85);--thumb-bg: linear-gradient(135deg, #1a1a22, #0f0f14);--delete-bg: rgba(13, 13, 16, .7);--danger: #ff6b6b;--shadow: 0 4px 16px rgba(0, 0, 0, .3);--radius: 14px;color-scheme:dark}[data-theme=light]{--bg: #f3e8ca;--bg-elev: #fbf5e3;--bg-elev-2: #ede1bf;--border: #d8c89a;--fg: #3a2e1e;--muted: #8a7a5e;--accent: #6c4ad9;--bar-bg: rgba(243, 232, 202, .85);--overlay-bg: rgba(243, 232, 202, .85);--thumb-bg: linear-gradient(135deg, #ede1bf, #fbf5e3);--delete-bg: rgba(251, 245, 227, .85);--danger: #b91c1c;--shadow: 0 4px 16px rgba(101, 75, 31, .12);color-scheme:light}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--fg);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;transition:background-color .2s ease,color .2s ease}code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:.9em;background:var(--bg-elev);padding:.1em .4em;border-radius:6px;border:1px solid var(--border)}.muted{color:var(--muted)}.state{min-height:100%;display:grid;place-items:center;text-align:center;padding:2rem}.page{max-width:1200px;margin:0 auto;padding:3rem 1.5rem 6rem}.page-head{margin-bottom:2.5rem;border-bottom:1px solid var(--border);padding-bottom:1.5rem}.page-head h1{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:clamp(1.6rem,3vw,2.2rem);letter-spacing:-.02em;margin:0 0 .4rem}.page-head p{margin:0}.empty{border:1px dashed var(--border);border-radius:var(--radius);padding:3rem 1.5rem;text-align:center}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.card{position:relative;display:flex;flex-direction:column;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .12s ease,border-color .12s ease,background .12s ease,box-shadow .12s ease}.card:hover{transform:translateY(-2px);border-color:var(--accent);background:var(--bg-elev-2);box-shadow:var(--shadow)}.card-busy{opacity:.5;pointer-events:none}.card-thumb-btn{all:unset;cursor:pointer;display:block}.card-delete{all:unset;position:absolute;top:8px;right:8px;width:26px;height:26px;display:grid;place-items:center;border-radius:999px;background:var(--delete-bg);border:1px solid var(--border);color:var(--muted);font-size:18px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s ease,color .12s ease,border-color .12s ease}.card:hover .card-delete,.card-delete:focus-visible{opacity:1}.card-delete:hover{color:var(--danger);border-color:var(--danger)}.card-thumb{aspect-ratio:4 / 3;background:var(--thumb-bg);display:grid;place-items:center;overflow:hidden}.card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.card-thumb-image{object-fit:contain!important;background:linear-gradient(45deg,var(--bg-elev-2) 25%,transparent 25%) 0 0/16px 16px,linear-gradient(-45deg,var(--bg-elev-2) 25%,transparent 25%) 0 8px/16px 16px,linear-gradient(45deg,transparent 75%,var(--bg-elev-2) 75%) 8px -8px/16px 16px,linear-gradient(-45deg,transparent 75%,var(--bg-elev-2) 75%) -8px 0/16px 16px,var(--bg-elev)}.card-thumb-placeholder{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:1.5rem;color:var(--muted);letter-spacing:.1em}.card-body{padding:.9rem 1rem 1rem}.card-name{font-weight:600;margin-bottom:.25rem}.card-notes{font-size:.85rem;line-height:1.4;min-height:1.2em}.editable{cursor:text;border-radius:4px;padding:1px 4px;margin:-1px -4px;transition:background .12s ease}.editable:hover{background:var(--bg-elev-2);outline:1px dashed var(--border)}.placeholder{font-style:italic;opacity:.55}.card-input{all:unset;display:block;width:100%;padding:1px 4px;margin:-1px -4px;border-radius:4px;background:var(--bg);outline:1px solid var(--accent);font:inherit;color:var(--fg);box-sizing:border-box}.card-input.card-name{font-weight:600}.card-input.card-notes{font-size:.85rem;line-height:1.4;resize:vertical}.dropzone-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:grid;place-items:center;z-index:100;pointer-events:none;border:3px dashed var(--accent);border-radius:0;animation:dropzone-in .12s ease-out}@keyframes dropzone-in{0%{opacity:0}to{opacity:1}}.dropzone-inner{text-align:center}.dropzone-title{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:clamp(1.4rem,3vw,2rem);letter-spacing:-.02em;margin-bottom:.5rem}.dropzone-sub{font-size:.95rem}.viewer{position:fixed;top:0;left:0;right:0;bottom:0;height:100dvh;display:flex;flex-direction:column;background:var(--bg)}.viewer-bar{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);background:var(--bar-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1}.back{all:unset;cursor:pointer;padding:.4rem .8rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;transition:border-color .12s ease,background .12s ease,color .12s ease}.back:hover,.back:focus-visible{border-color:var(--accent);background:var(--bg-elev)}.back.danger:hover,.back.danger:focus-visible{border-color:var(--danger);color:var(--danger);background:var(--bg-elev)}.viewer-title-input{all:unset;font:inherit;font-weight:600;color:var(--fg);padding:2px 6px;margin:-2px -6px;border-radius:4px;background:var(--bg);outline:1px solid var(--accent);min-width:200px;max-width:50%}.viewer-title{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.viewer-hint{font-size:.8rem}.viewer-canvas{flex:1;min-height:0}.image-stage{flex:1;min-height:0;min-width:0;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:grab;background:linear-gradient(45deg,var(--bg-elev) 25%,transparent 25%) 0 0/24px 24px,linear-gradient(-45deg,var(--bg-elev) 25%,transparent 25%) 0 12px/24px 24px,linear-gradient(45deg,transparent 75%,var(--bg-elev) 75%) 12px -12px/24px 24px,linear-gradient(-45deg,transparent 75%,var(--bg-elev) 75%) -12px 0/24px 24px,var(--bg);-webkit-user-select:none;user-select:none;touch-action:none}.image-stage:active{cursor:grabbing}.image-stage-img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transform-origin:center center;transition:transform 80ms ease-out;pointer-events:none;-webkit-user-drag:none}.admin-badge{display:inline-block;margin-left:.6em;padding:.15em .5em;font-size:.55em;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;letter-spacing:.15em;font-weight:700;color:var(--accent);border:1px solid var(--accent);border-radius:4px;vertical-align:middle}.viewer-bar .admin-badge{font-size:.7rem;margin-left:0}.theme-toggle{all:unset;position:fixed;bottom:1rem;right:1rem;width:40px;height:40px;display:grid;place-items:center;border-radius:999px;background:var(--bg-elev);border:1px solid var(--border);color:var(--fg);cursor:pointer;z-index:200;box-shadow:var(--shadow);transition:border-color .12s ease,background .12s ease,transform .12s ease}.theme-toggle:hover,.theme-toggle:focus-visible{border-color:var(--accent);background:var(--bg-elev-2);transform:scale(1.05)}.theme-toggle svg{width:18px;height:18px;display:block}@media (max-width: 600px){.viewer-hint{display:none}.page{padding:2rem 1rem 4rem}}
