:root{--bg: #ece7f9;--bg2: #f6f3fd;--card-bg: #ffffff;--accent: #9576e0;--accent-d: #7857c9;--accent-soft: #c9b8f5;--text: #36304a;--muted: #8b82a8;--border: #ded4f2;--err: #d6447a}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,Segoe UI,Roboto,Noto Sans KR,sans-serif;-webkit-tap-highlight-color:transparent}#app{min-height:100%}.hearts-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}video-stream .info{display:none!important}.login-wrap{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(120% 80% at 50% 0%,var(--bg2),var(--bg))}.login-card{position:relative;z-index:1;width:100%;max-width:360px;display:flex;flex-direction:column;gap:14px;background:var(--card-bg);padding:32px 24px;border-radius:20px;box-shadow:0 12px 40px #7857c938;border:1px solid var(--border)}.heart{color:var(--accent);text-align:center;filter:drop-shadow(0 4px 12px rgba(149,118,224,.45))}.brand{text-align:center;font-size:22px;margin:0 0 8px;font-weight:700;letter-spacing:.3px}.brand-heart{color:var(--accent)}.field{background:var(--bg2);border:1px solid var(--border);color:var(--text);padding:13px 14px;border-radius:12px;font-size:15px;outline:none}.field::placeholder{color:var(--muted)}.field:focus{border-color:var(--accent)}.btn-primary{background:linear-gradient(180deg,var(--accent),var(--accent-d));color:#fff;border:none;padding:13px;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer}.btn-primary:disabled{opacity:.6}.err{color:var(--err);font-size:13px;min-height:16px;margin:2px 0 0;text-align:center}.list-wrap{position:relative;min-height:100vh;overflow:hidden}.list-wrap>.topbar,.list-wrap>.card-list{position:relative;z-index:1}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f6f3fde6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}.brand-sm{font-weight:700;font-size:16px}.topbar-actions{display:flex;gap:6px}.icon-btn{background:var(--card-bg);color:var(--text);border:1px solid var(--border);width:38px;height:38px;border-radius:10px;font-size:18px;cursor:pointer;display:grid;place-items:center}.icon-btn.light{background:#ffffff2e;border-color:transparent;color:#fff}.card-list{padding:14px;display:grid;grid-template-columns:1fr;gap:14px}@media(min-width:768px){.card-list{grid-template-columns:1fr 1fr;max-width:1400px;margin:0 auto}}.hint{color:var(--muted);text-align:center;padding:40px 0}.hint.light{color:#eee}.card{position:relative;background:#000;border-radius:16px;overflow:hidden;aspect-ratio:16 / 9;box-shadow:0 6px 20px #7857c92e}.card video-stream,.card .player{display:block;width:100%;height:100%}.card video{object-fit:cover}.card-label{position:absolute;left:0;bottom:0;right:0;padding:10px 14px;background:linear-gradient(0deg,rgba(0,0,0,.7),transparent);color:#fff;font-weight:600;font-size:15px;cursor:pointer}.full-wrap{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;touch-action:none;overflow:hidden}.full-player{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotate(var(--rot, 0deg));transition:transform .25s;transform-origin:center center}.full-player video{width:100%;height:100%;object-fit:contain}.full-player.rot-quarter{inset:auto;top:50%;left:50%;width:100vh;height:100vw;transform:translate(-50%,-50%) rotate(var(--rot))}.full-menu{position:absolute;left:0;right:0;bottom:0;z-index:5;display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:14px 16px calc(14px + env(safe-area-inset-bottom));background:linear-gradient(0deg,rgba(0,0,0,.8),transparent);transform:translateY(110%);transition:transform .25s;pointer-events:none}.full-menu.show{transform:translateY(0);pointer-events:auto}.fm-btn{background:#ffffff29;color:#fff;border:1px solid rgba(255,255,255,.3);padding:10px 14px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer}.fm-btn.rec-on{background:var(--err);border-color:var(--err)}.fm-name{color:#fff;font-weight:700;margin-left:4px}.fm-count{color:#ddd;font-size:13px;margin-left:auto}.full-clock{position:absolute;left:auto;right:calc(12px + env(safe-area-inset-right));bottom:calc(10px + env(safe-area-inset-bottom));z-index:4;text-align:right;pointer-events:none;font-variant-numeric:tabular-nums;font-weight:700;font-size:clamp(7px,1.67vw,13px);letter-spacing:1px;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.8)}.full-toast{position:absolute;left:50%;top:18px;transform:translate(-50%) translateY(-12px);background:#000000d9;color:#fff;padding:8px 16px;border-radius:999px;font-size:14px;opacity:0;transition:opacity .2s,transform .2s;z-index:6;pointer-events:none}.full-toast.show{opacity:1;transform:translate(-50%) translateY(0)}.modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#36304a73;display:flex;align-items:flex-start;justify-content:center;padding:24px 14px;overflow:auto;z-index:50}.modal{width:100%;max-width:440px;background:var(--bg2);border-radius:18px;padding:18px;border:1px solid var(--border);box-shadow:0 16px 50px #7857c947}.modal.small{max-width:360px}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.modal-head h2{margin:0;font-size:18px}.admin-sec{margin-top:16px}.admin-sec h3{margin:0 0 8px;font-size:14px;color:var(--muted)}.admin-list{display:flex;flex-direction:column;gap:6px;margin-bottom:10px}.admin-row{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--card-bg);padding:8px 12px;border-radius:10px;font-size:14px;border:1px solid var(--border)}.admin-row small{color:var(--muted)}.admin-row-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.del{background:#f3d9e6;color:#b8336a;border:1px solid #e6c4d6;padding:6px 10px;border-radius:8px;cursor:pointer}.mini{background:#efe9fb;color:var(--text);border:1px solid var(--border);padding:6px 10px;border-radius:8px;cursor:pointer;font-size:13px}.mini.save{background:var(--accent-d);border-color:var(--accent-d);color:#fff}.inline-edit{flex:1;min-width:0;padding:8px 10px}.admin-form,.setting-row{display:flex;flex-direction:column;gap:8px}.setting-row label.opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--card-bg);border:1px solid var(--border);cursor:pointer}.setting-note{color:var(--muted);font-size:12px;line-height:1.5}.card-ghost{opacity:.35}.card-chosen{transform:scale(1.03);box-shadow:0 10px 30px #9576e080;outline:2px solid var(--accent)}.card{touch-action:pan-y}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%) translateY(20px);background:#36304a;color:#fff;padding:10px 18px;border-radius:999px;border:1px solid var(--accent);font-size:14px;opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:100}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}
