:root{color-scheme:dark;--bg: #0d0f12;--surface: #161a20;--surface-2: #1f242c;--border: #2a313b;--text: #e7ecf2;--muted: #8b94a3;--accent: #4f8bff;--danger: #ff6b6b;--radius: 10px}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}button{font:inherit;cursor:pointer}.muted{color:var(--muted)}.centered{display:grid;place-items:center;min-height:100vh}.login-body{display:grid;place-items:center;min-height:100vh;padding:24px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:100%;max-width:360px;text-align:center}.login-card h1{margin:0 0 8px;font-size:28px;letter-spacing:.04em}.login-card .subtitle{margin:0 0 24px;color:var(--muted);font-size:14px}.login-card form{display:grid;gap:12px}.login-card input{background:var(--surface-2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:12px 14px;font-size:15px;outline:none;transition:border-color .15s}.login-card input:focus{border-color:var(--accent)}.login-card button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px 14px;font-weight:600;font-size:15px;transition:filter .15s}.login-card button:disabled{opacity:.6;cursor:not-allowed}.login-card button:not(:disabled):hover{filter:brightness(1.1)}.login-card .error{color:var(--danger);margin:0;font-size:14px}.gallery-body{min-height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10}.topbar h1{margin:0;font-size:20px;letter-spacing:.04em}.topbar .ghost{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:8px;padding:8px 14px;font-size:13px;transition:color .15s,border-color .15s}.topbar .ghost:hover{color:var(--text);border-color:var(--text)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;padding:24px}.grid .status{grid-column:1 / -1;text-align:center;color:var(--muted);padding:48px 0;margin:0}.grid .status.error{color:var(--danger)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;text-align:left;padding:0;color:inherit;font:inherit;transition:transform .15s,border-color .15s,opacity .15s;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media(hover:hover){.card:hover{transform:translateY(-2px);border-color:var(--accent)}}.card:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.card.dimmed{opacity:.4;pointer-events:none}.card .thumb{position:relative;aspect-ratio:16 / 9;background:#000;overflow:hidden}.card .thumb img{width:100%;height:100%;object-fit:cover;display:block}.card .thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1f242c,#2a313b)}.card .thumb .play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.55));opacity:0;transition:opacity .15s}@media(hover:hover){.card:hover .thumb .play-overlay{opacity:1}}.card .thumb .play-icon{width:56px;height:56px;border-radius:50%;background:#00000080;display:grid;place-items:center;border:2px solid rgba(255,255,255,.85)}.card .thumb .play-icon:before{content:"";width:0;height:0;border-left:14px solid white;border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:4px}.card .thumb .duration{position:absolute;right:8px;bottom:8px;background:#000000b3;color:#fff;font-size:12px;padding:2px 6px;border-radius:4px;font-variant-numeric:tabular-nums}.card .thumb .card-menu{position:absolute;top:8px;right:8px;width:32px;height:32px;border:none;border-radius:50%;background:#000000a6;color:#fff;font-size:18px;line-height:1;display:grid;place-items:center;opacity:0;transition:opacity .15s,background .15s}@media(hover:hover){.card:hover .card-menu{opacity:1}.card .card-menu:hover{background:#000000d9}}.card .card-menu:focus-visible{opacity:1}@media(hover:none){.card .card-menu{opacity:1}}.card .meta{padding:12px 14px;display:grid;gap:4px}.card .meta .name{font-size:14px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card .meta .date{font-size:12px;color:var(--muted);margin:0}body:has(.modal){overflow:hidden}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;z-index:100;display:grid;place-items:center;padding:24px;overscroll-behavior:contain;touch-action:none}.modal .player,.modal .info-card{touch-action:auto}.modal-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:22px;line-height:1;z-index:20;transition:opacity .2s ease,visibility 0s}.modal-close:hover{background:#fff3}.modal-close-hidden{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,visibility 0s linear .2s}.menu{min-width:160px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;display:grid;gap:2px;box-shadow:0 8px 24px #00000073}.menu.floating{position:fixed;z-index:200}.menu button{background:transparent;border:none;color:var(--text);text-align:left;padding:10px 12px;border-radius:6px;font-size:14px}.menu button:hover:not(:disabled){background:var(--surface-2)}.menu button:disabled{opacity:.6;cursor:not-allowed}.menu button.danger{color:var(--danger)}.menu button.danger:hover:not(:disabled){background:#ff6b6b1f}.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:480px;padding:0;position:relative;overflow:hidden}.info-card header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.info-card header h2{margin:0;font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:16px}.info-card header .modal-close{position:static;flex-shrink:0}.info-card dl{margin:0;padding:16px 20px 20px;display:grid;grid-template-columns:90px 1fr;gap:8px 14px;font-size:14px}.info-card dt{color:var(--muted)}.info-card dd{margin:0;word-break:break-all}.info-card dd.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12.5px}.player{width:100%;max-width:min(1100px,calc((100vh - 48px) * 16 / 9));aspect-ratio:16 / 9;background:#000;border-radius:var(--radius);overflow:hidden;position:relative}.player-stage{position:absolute;top:0;right:0;bottom:0;left:0}.player-stage .art-state{display:none!important}.player-stage video::-webkit-media-controls,.player-stage video::-webkit-media-controls-panel,.player-stage video::-webkit-media-controls-start-playback-button,.player-stage video::-webkit-media-controls-overlay-play-button{display:none!important;-webkit-appearance:none}.player-error{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--danger);padding:24px;text-align:center}
