.tabbar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--footer-h);display:flex;background:var(--bg-elev);border-top:1px solid var(--border);z-index:9}.tabbar a{width:20%;flex:0 0 20%;min-width:0;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-mute);font-size:11px;text-decoration:none}.tabbar a>span:not(.ic){display:block;width:100%;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tabbar a.active{color:var(--primary)}.tabbar a .ic{font-size:20px;line-height:1;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}.tab-badge{position:absolute;top:-6px;right:-10px;min-width:16px;height:16px;line-height:16px;padding:0 5px;background:var(--primary);color:var(--on-primary);font-size:10px;font-weight:700;border-radius:999px;text-align:center;box-shadow:0 2px 6px #00000040;pointer-events:none}:root{--bg: #0f1117;--bg-elev: #161a23;--bg-elev-2: #1f2533;--border: #2a3140;--text: #ecedef;--text-mute: #8b93a7;--muted: var(--text-mute);--primary: #ff7a59;--primary-2: #ffa371;--primary-rgb: 255, 122, 89;--accent: #5fb3ff;--success: #4ade80;--success-rgb: 74, 222, 128;--danger: #f87171;--danger-rgb: 248, 113, 113;--on-primary: #ffffff;--scrim: rgba(0, 0, 0, .6);--media-bg: #000;--balance-from: #1a1f33;--balance-to: #2a334d;--gift-from: #ffe7d6;--gift-to: #ffd0b0;--gift-text: #6b3a1f;--game-from: #6c5ce7;--game-to: #341f97;--dice-bg: #ffffff;--dice-text: #333333;--qr-bg: #ffffff;--shadow: 0 10px 30px rgba(0,0,0,.35);--radius: 14px;--radius-sm: 10px;--header-h: 56px;--footer-h: 64px;--font: -apple-system, BlinkMacSystemFont, "Pretendard", "Segoe UI", Roboto, "Noto Sans KR", "Helvetica Neue", Arial, sans-serif;--divider: var(--border);--ring-grad: linear-gradient(135deg, var(--primary), var(--primary-2));--dating-grad: linear-gradient(135deg, #ff5e7d 0%, #ff7a59 50%, #ffa57a 100%);--female: #ec4899;--female-soft: rgba(236, 72, 153, .14);--male: #2563eb;--male-soft: rgba(37, 99, 235, .14);--female-grad: linear-gradient(135deg, #f9a8d4 0%, #ec4899 60%, #be185d 100%);--male-grad: linear-gradient(135deg, #93c5fd 0%, #3b82f6 60%, #1d4ed8 100%);--mission-image: linear-gradient(135deg, #f59e0b 0%, #ef6c00 100%);--mission-puzzle: linear-gradient(135deg, #a78bfa 0%, #7c3aed 100%);--mission-video: linear-gradient(135deg, #60a5fa 0%, #2563eb 100%);--mission-paid: linear-gradient(135deg, #34d399 0%, #059669 100%);--status-accepted: #34a853;--status-declined: #6a6a72;--status-expired: #9a9aa3;--media-radius: 0;--text-rgb: 236, 237, 239;--primary-soft: rgba(255, 122, 89, .16);--success-soft: rgba(74, 222, 128, .16);--neutral-chip: rgba(255, 255, 255, .1);--text-faint: rgba(236, 237, 239, .5);--diff-easy: #34a853;--diff-normal: #f59e0b;--diff-hard: #ff7a59;--diff-expert-grad: linear-gradient(135deg, #d9407a 0%, #7c3aed 100%);--status-waiting: #6a6a72;--status-solved: #34a853}@media (prefers-color-scheme: light){:root{--bg: #fafafa;--bg-elev: #ffffff;--bg-elev-2: #f1f3f7;--border: #e3e6ec;--text: #1d2128;--text-mute: #6a7180;--success: #16a34a;--success-rgb: 22, 163, 74;--danger: #dc2626;--danger-rgb: 220, 38, 38;--scrim: rgba(0, 0, 0, .5);--media-bg: #0b0d12;--text-rgb: 29, 33, 40;--neutral-chip: rgba(0, 0, 0, .06);--text-faint: rgba(29, 33, 40, .45);--shadow: 0 10px 30px rgba(20,30,60,.08)}}:root[data-theme=light]{--bg: #fafafa;--bg-elev: #ffffff;--bg-elev-2: #f1f3f7;--border: #e3e6ec;--text: #1d2128;--text-mute: #6a7180;--success: #16a34a;--success-rgb: 22, 163, 74;--danger: #dc2626;--danger-rgb: 220, 38, 38;--scrim: rgba(0, 0, 0, .5);--media-bg: #0b0d12;--text-rgb: 29, 33, 40;--neutral-chip: rgba(0, 0, 0, .06);--text-faint: rgba(29, 33, 40, .45);--shadow: 0 10px 30px rgba(20,30,60,.08)}:root[data-theme=dark]{--bg: #0f1117;--bg-elev: #161a23;--bg-elev-2: #1f2533;--border: #2a3140;--text: #ecedef;--text-mute: #8b93a7;--success: #4ade80;--success-rgb: 74, 222, 128;--danger: #f87171;--danger-rgb: 248, 113, 113;--scrim: rgba(0, 0, 0, .6);--media-bg: #000;--text-rgb: 236, 237, 239;--neutral-chip: rgba(255, 255, 255, .1);--text-faint: rgba(236, 237, 239, .5);--shadow: 0 10px 30px rgba(0,0,0,.35)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;touch-action:manipulation;overflow-x:hidden}body{margin:0;font-family:var(--font);font-size:15px;line-height:1.5;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overscroll-behavior:none}input,textarea,select{font-size:16px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer}img{max-width:100%;display:block}.app-shell{max-width:480px;margin:0 auto;min-height:100dvh;background:var(--bg);display:flex;flex-direction:column;position:relative}.app-header{position:sticky;top:0;z-index:10;height:var(--header-h);display:flex;align-items:center;padding:0 14px;gap:10px;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.app-header .title{font-weight:700;font-size:17px;flex:1}.app-header .back{background:none;border:0;color:var(--text);font-size:20px;padding:8px;margin-left:-8px}.app-header .wordmark{font-size:17px;font-weight:800;letter-spacing:-.02em;background:var(--ring-grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;flex:1}.app-header .icon-btn{background:none;border:0;color:var(--text);width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;padding:0;-webkit-tap-highlight-color:transparent}.app-header .icon-btn svg{display:block}.app-header .h-title{font-size:17px;font-weight:700;color:var(--text);line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header .h-sub{font-size:12px;color:var(--text-mute);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header .grow{flex:1;min-width:0}.app-main{flex:1;padding:14px;padding-bottom:calc(var(--footer-h) + 14px)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;color:var(--text-mute)}.input,.textarea,.select{width:100%;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;outline:none;color:var(--text);transition:border-color .15s}.input:focus,.textarea:focus,.select:focus{border-color:var(--primary)}.input:disabled,.input[disabled],.textarea:disabled,.textarea[disabled],.select:disabled,.select[disabled]{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed;opacity:.85}.textarea{resize:vertical;min-height:80px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);font-weight:600}.btn:hover{filter:brightness(1.05)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 100%);border:0;color:var(--on-primary);box-shadow:var(--shadow)}.btn-ghost{background:transparent}.btn-danger{background:var(--danger);color:var(--on-primary);border:0}.btn-block{width:100%}.btn-sm{padding:8px 12px;font-size:13px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.empty{text-align:center;padding:40px 20px;color:var(--text-mute)}.empty .big{font-size:40px;margin-bottom:8px}.spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--text-mute)}.center{text-align:center}.row{display:flex;align-items:center;gap:10px}.row.between{justify-content:space-between}.hstack{display:flex;align-items:center;gap:8px}.vstack{display:flex;flex-direction:column;gap:8px}.grow{flex:1}.tag{display:inline-block;font-size:11px;padding:3px 8px;border-radius:999px;background:var(--bg-elev-2);color:var(--text-mute)}.divider{height:1px;background:var(--border);margin:12px 0}.toast-wrap{position:fixed;bottom:calc(var(--footer-h) + 18px);left:50%;transform:translate(-50%);z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-left:3px solid var(--primary);padding:10px 14px;border-radius:999px;font-size:13px;box-shadow:var(--shadow);max-width:calc(100vw - 28px);animation:toastIn .22s ease-out}.toast.success{border-left-color:var(--success)}.toast.danger{border-left-color:var(--danger)}.toast.info{border-left-color:var(--primary)}@keyframes toastIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.scroll-pad{padding-bottom:env(safe-area-inset-bottom,0)}.splash{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px;text-align:center;background:radial-gradient(80% 60% at 50% 0%,color-mix(in srgb,var(--primary) 25%,transparent),transparent 60%),var(--bg)}.splash .logo{font-size:32px;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,var(--primary),var(--primary-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.splash .sub{color:var(--text-mute);margin-top:6px;margin-bottom:26px}.splash form{width:100%;max-width:320px}.list{display:flex;flex-direction:column;gap:8px}.list-item{display:grid;grid-template-columns:44px 1fr auto;gap:12px;align-items:center;padding:10px 12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:inherit}.list-item:hover{background:var(--bg-elev-2)}.list-item .avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--on-primary);overflow:hidden}.list-item .avatar img{width:100%;height:100%;object-fit:cover}.list-item .meta .name{font-weight:600}.list-item .meta .sub{color:var(--text-mute);font-size:12px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item .right{color:var(--text-mute);font-size:11px;text-align:right}.list-item .badge{display:inline-block;min-width:18px;padding:0 6px;height:18px;line-height:18px;background:var(--primary);color:var(--on-primary);font-size:11px;border-radius:999px;text-align:center;margin-top:4px}.empty-state{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 24px;text-align:center;color:var(--text-mute)}.empty-state-illust{width:160px;height:160px;flex:0 0 auto;margin-bottom:4px;user-select:none;-webkit-user-drag:none}.empty-state-title{margin:0;font-size:15px;font-weight:700;color:var(--text);line-height:1.4}.empty-state-desc{margin:0;font-size:13px;color:var(--text-mute);line-height:1.5;max-width:280px}.empty-state-cta{margin-top:10px;position:relative;animation:ctaPulse 2.6s ease-out infinite}@keyframes ctaPulse{0%{box-shadow:0 0 rgba(var(--primary-rgb),.38)}70%{box-shadow:0 0 0 14px rgba(var(--primary-rgb),0)}to{box-shadow:0 0 rgba(var(--primary-rgb),0)}}@media (prefers-reduced-motion: reduce){.empty-state-cta{animation:none}}.empty-state.draft{padding:24px 16px;gap:8px}.empty-state.draft .empty-state-illust{width:120px;height:120px}@media (max-width: 360px){.empty-state{padding:32px 16px}.empty-state-illust{width:132px;height:132px}.empty-state.draft .empty-state-illust{width:100px;height:100px}}.apple-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--apple-btn-bg);color:var(--apple-btn-fg);border:0;border-radius:var(--radius);padding:14px;font:inherit;font-size:15px;font-weight:600;cursor:pointer;text-decoration:none;-webkit-tap-highlight-color:transparent}.apple-btn:active{opacity:.85}.apple-btn .apple-logo{display:inline-block;width:16px;height:16px;background:currentColor;-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M17.05 20.28c-.98.95-2.05.8-3.08.35-1.09-.46-2.09-.48-3.24 0-1.44.62-2.2.44-3.06-.35C2.79 15.25 3.51 7.59 9.05 7.31c1.35.07 2.29.74 3.08.8 1.18-.24 2.31-.93 3.57-.84 1.51.12 2.65.72 3.4 1.8-3.12 1.87-2.38 5.98.48 7.13-.57 1.5-1.31 2.99-2.54 4.09l.01-.01zM12.03 7.25c-.15-2.23 1.66-4.07 3.74-4.25.29 2.58-2.34 4.5-3.74 4.25z'/></svg>") center / contain no-repeat;mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M17.05 20.28c-.98.95-2.05.8-3.08.35-1.09-.46-2.09-.48-3.24 0-1.44.62-2.2.44-3.06-.35C2.79 15.25 3.51 7.59 9.05 7.31c1.35.07 2.29.74 3.08.8 1.18-.24 2.31-.93 3.57-.84 1.51.12 2.65.72 3.4 1.8-3.12 1.87-2.38 5.98.48 7.13-.57 1.5-1.31 2.99-2.54 4.09l.01-.01zM12.03 7.25c-.15-2.23 1.66-4.07 3.74-4.25.29 2.58-2.34 4.5-3.74 4.25z'/></svg>") center / contain no-repeat}.empty-state-v2{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;gap:12px}.empty-state-v2__icon{font-size:64px;line-height:1;opacity:.85}.empty-state-v2__title{font-size:16px;font-weight:700;color:var(--text)}.empty-state-v2__hint{font-size:14px;color:var(--text-mute);line-height:1.5;max-width:280px}.empty-state-v2__cta{margin-top:8px;display:inline-block;padding:12px 22px;background:var(--ring-grad);color:var(--on-primary);border:0;border-radius:var(--radius);font:inherit;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none}.av-wrap{position:relative;display:inline-flex;flex-shrink:0}.av-wrap.has-dating-ring{border-radius:50%;border:3px solid transparent;background-origin:border-box;padding:0}.av-wrap.has-dating-ring.ring-female{background:var(--female-grad) border-box}.av-wrap.has-dating-ring.ring-male{background:var(--male-grad) border-box}.g-badge{position:absolute;bottom:-2px;right:-2px;width:16px;height:16px;border-radius:999px;border:1.5px solid var(--bg);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;line-height:1;z-index:2;pointer-events:none}.g-badge.female{background:var(--female)}.g-badge.male{background:var(--male)}.av-wrap.av-wrap--hero .g-badge{width:28px;height:28px;font-size:14px;border-width:2.5px;bottom:2px;right:2px}.av-wrap.av-wrap--strip .g-badge{width:18px;height:18px;font-size:10px}.sticky-friend-banner{display:flex;align-items:center;gap:8px;background:var(--primary-soft);border:1px solid var(--primary);border-radius:12px;padding:10px 14px;margin:8px 14px;font-size:13px}.sticky-friend-banner__text{flex:1;color:var(--text);font-weight:600}.sticky-friend-banner__cta{background:var(--primary);color:var(--on-primary);border:0;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;text-decoration:none}.sticky-friend-banner__close{background:none;border:0;color:var(--text-mute);width:24px;height:24px;font-size:14px;cursor:pointer;border-radius:50%}.sticky-friend-banner[hidden]{display:none}.profile-section-mini-add{background:var(--bg-elev);border:1px solid var(--primary);color:var(--primary);padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;cursor:pointer;text-decoration:none;margin-left:auto;margin-right:8px}.invite-tabs{display:flex;gap:6px;background:var(--bg-elev-2);border-radius:10px;padding:4px;margin-bottom:14px}.invite-tabs button{flex:1;background:transparent;border:0;padding:10px 8px;border-radius:8px;font-size:13px;font-weight:700;color:var(--text-mute);cursor:pointer;font:inherit}.invite-tabs button.is-active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #0003}.welcome-modal__two-ways{text-align:left;background:var(--bg-elev-2);border-radius:10px;padding:12px 14px;font-size:12px;color:var(--text);line-height:1.7}.welcome-modal__two-ways .head{font-size:11px;font-weight:700;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.welcome-modal__cta-secondary{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--divider);padding:12px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font:inherit}.home-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px 80px;text-align:center}.home-empty__icon{font-size:56px;margin-bottom:12px}.home-empty__title{font-size:17px;font-weight:800;color:var(--text);margin:0 0 6px}.home-empty__sub{font-size:14px;color:var(--text-mute);margin:0 0 24px;line-height:1.5}.oauth-provider-badge{display:inline-flex;align-items:center;justify-content:center;gap:8px;max-width:320px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:8px 14px;margin:0 0 16px;box-shadow:0 1px 3px #0000000f;box-sizing:border-box}.oauth-provider-badge[hidden]{display:none}.oauth-provider-badge__logo{flex-shrink:0;display:block}.oauth-provider-badge__email{font-size:13px;font-weight:600;color:#1a1a1d;word-break:break-all;line-height:1.3;text-align:center}.modal-mask{position:fixed;inset:0;background:var(--scrim);display:flex;align-items:flex-end;justify-content:center;z-index:100}.modal-sheet{width:100%;max-width:480px;background:var(--bg-elev);border-top-left-radius:20px;border-top-right-radius:20px;padding:18px;padding-bottom:calc(18px + env(safe-area-inset-bottom));max-height:80dvh;overflow-y:auto}.modal-sheet h3{margin:0 0 12px}.modal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.modal-grid .gift-cell{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;text-align:center;cursor:pointer}.modal-grid .gift-cell .emoji{font-size:30px}.modal-grid .gift-cell .name{font-size:12px;margin-top:4px}.modal-grid .gift-cell .price{color:var(--primary);font-weight:700;font-size:12px}.dropdown-menu{position:fixed;z-index:1000;min-width:220px;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:6px;display:flex;flex-direction:column}.dropdown-menu .dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:0;color:var(--text);font:inherit;font-size:14px;border-radius:8px;cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent}.dropdown-menu .dropdown-item:hover,.dropdown-menu .dropdown-item:focus-visible{background:var(--bg-elev-2);outline:none}.dropdown-menu .dropdown-item .ic{font-size:16px;width:20px;text-align:center}.dropdown-menu .dropdown-item.is-danger{color:var(--danger)}.dropdown-menu .dropdown-sep{height:1px;background:var(--divider);margin:4px 6px}.dropdown-backdrop{position:fixed;inset:0;z-index:999;background:transparent}.dropdown-menu .dropdown-header{display:flex;align-items:center;gap:8px;padding:6px 10px 10px;border-bottom:1px solid var(--divider);margin-bottom:4px}.dropdown-menu .dropdown-back{background:none;border:0;color:var(--text);padding:4px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.dropdown-menu .dropdown-back svg{display:block}.dropdown-menu .dropdown-title{font-weight:700;font-size:14px;color:var(--text);flex:1}.dropdown-menu .dropdown-radio{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:0;color:var(--text);font:inherit;font-size:14px;border-radius:8px;cursor:pointer;text-align:left}.dropdown-menu .dropdown-radio:hover{background:var(--bg-elev-2)}.dropdown-menu .dropdown-radio .check{margin-left:auto;color:var(--primary);font-weight:800;width:18px;text-align:right}.dropdown-menu .dropdown-toggle{display:flex;align-items:center;gap:10px;padding:10px 12px;background:transparent;border:0;color:var(--text);font:inherit;font-size:14px;border-radius:8px;cursor:pointer;text-align:left}.dropdown-menu .dropdown-toggle:hover{background:var(--bg-elev-2)}.dropdown-menu .dropdown-toggle .switch{margin-left:auto;width:36px;height:20px;border-radius:999px;background:var(--bg-elev-2);border:1px solid var(--border);position:relative;transition:background .15s}.dropdown-menu .dropdown-toggle .switch:after{content:"";position:absolute;width:14px;height:14px;border-radius:50%;background:var(--text-mute);top:2px;left:2px;transition:transform .15s,background .15s}.dropdown-menu .dropdown-toggle .switch.is-on{background:var(--ring-grad);border-color:transparent}.dropdown-menu .dropdown-toggle .switch.is-on:after{transform:translate(16px);background:#fff}.friend-add-result-overlay{position:fixed;inset:0;z-index:1100;background:#000000b3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .2s ease}.friend-add-result-overlay.is-open{opacity:1}.friend-add-result-modal{position:relative;background:var(--bg-elev);border:1px solid var(--divider);border-radius:20px;padding:24px;display:flex;flex-direction:column;gap:14px;text-align:center;width:100%;max-width:360px}.friend-add-result-modal__close{position:absolute;top:12px;right:12px;width:32px;height:32px;background:transparent;border:0;color:var(--text-mute);font-size:18px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.friend-add-result-modal__close:hover{background:var(--bg-elev-2);color:var(--text)}.friend-add-result-modal__avatar{width:72px;height:72px;border-radius:50%;background:var(--ring-grad);color:var(--on-primary);margin:0 auto;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;box-shadow:0 0 0 3px var(--bg-elev),0 0 0 6px var(--success);overflow:hidden}.friend-add-result-modal__avatar img{width:100%;height:100%;object-fit:cover}.friend-add-result-overlay.is-existing .friend-add-result-modal__avatar{box-shadow:0 0 0 3px var(--bg-elev),0 0 0 6px var(--primary)}.friend-add-result-modal__title{font-size:19px;font-weight:800;color:var(--text)}.friend-add-result-modal__handle{background:var(--bg-elev-2);border-radius:8px;padding:6px 12px;font-family:SF Mono,JetBrains Mono,monospace;font-size:12px;color:var(--text-mute);display:inline-block;margin:0 auto}.friend-add-result-modal__handle .hash{color:var(--primary)}.friend-add-result-modal__sub{font-size:13px;color:var(--text-mute);line-height:1.5}.friend-add-result-modal__cta-row{display:flex;flex-direction:column;gap:8px;margin-top:4px}.friend-add-result-modal__cta-primary{background:var(--primary);color:var(--on-primary);border:0;padding:12px;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;-webkit-tap-highlight-color:transparent}.friend-add-result-modal__cta-primary:hover{opacity:.92}.friend-add-result-modal__cta-secondary{background:transparent;color:var(--text-mute);border:0;padding:8px;font-size:13px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.friend-add-result-modal__cta-secondary:hover{color:var(--text)}body.modal-open{overflow:hidden}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;padding:0;margin:-1px}.sheet__scrim{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:999;animation:scrimFade .22s ease-out}@keyframes scrimFade{0%{opacity:0}to{opacity:1}}.sheet{position:fixed;left:0;right:0;bottom:0;background:var(--bg-elev);border-radius:20px 20px 0 0;box-shadow:0 -8px 28px #00000038;padding:8px 14px calc(14px + env(safe-area-inset-bottom,0px));z-index:1000;display:flex;flex-direction:column;overflow-y:auto;animation:sheetUp .35s cubic-bezier(.32,.72,0,1);max-width:482px;margin:0 auto}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet__handle{width:36px;height:4px;background:var(--text-mute);opacity:.35;border-radius:999px;margin:0 auto 10px;flex-shrink:0}@media (prefers-reduced-motion: reduce){.sheet__scrim,.sheet{animation:none}}.puzzle-modal-v2{position:fixed;left:0;right:0;bottom:0;max-width:482px;margin:0 auto;background:var(--bg-elev);border-radius:20px 20px 0 0;box-shadow:0 -8px 28px #00000038;padding:8px 14px calc(14px + env(safe-area-inset-bottom,0px));max-height:90%;overflow-y:auto;z-index:1000;animation:sheetUp .35s cubic-bezier(.32,.72,0,1)}.puzzle-modal-v2[hidden]{display:none}.puzzle-modal-v2__scrim{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:999;animation:scrimFade .22s ease-out}@media (prefers-reduced-motion: reduce){.puzzle-modal-v2,.puzzle-modal-v2__scrim{animation:none}}.pm-handle{width:36px;height:4px;background:var(--text-mute);opacity:.35;border-radius:999px;margin:0 auto 10px;flex-shrink:0}.chat-input-v3__btn--game.is-active{background:var(--primary-soft);color:var(--primary)}.game-modal__scrim{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:999;animation:scrimFade .22s ease-out}.game-modal{position:fixed;left:0;right:0;bottom:0;max-width:482px;margin:0 auto;background:var(--bg-elev);border-radius:20px 20px 0 0;box-shadow:0 -8px 28px #00000038;padding:8px 14px calc(14px + env(safe-area-inset-bottom,0px));max-height:86%;overflow-y:auto;z-index:1000;display:flex;flex-direction:column;gap:12px;animation:sheetUp .35s cubic-bezier(.32,.72,0,1)}@media (prefers-reduced-motion: reduce){.game-modal,.game-modal__scrim{animation:none}}.gm-handle{width:36px;height:4px;background:var(--text-mute);opacity:.35;border-radius:999px;margin:0 auto 4px;flex-shrink:0}.gm-head{display:flex;align-items:flex-start;gap:12px}.gm-head__text{flex:1;min-width:0}.gm-title{font-size:18px;font-weight:800;margin:0 0 4px;color:var(--text)}.gm-sub{font-size:12px;color:var(--text-mute);margin:0;line-height:1.5}.gm-close{flex:0 0 auto;width:32px;height:32px;border-radius:50%;background:var(--bg-elev-2);border:0;color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}.gm-close:hover{background:var(--bg-elev)}.gm-game-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.gm-game-card{background:var(--bg-elev-2);border:2px solid transparent;border-radius:14px;padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;text-align:center;font:inherit;color:var(--text);transition:background .15s,border-color .15s,transform .12s}.gm-game-card:active{transform:scale(.97)}.gm-game-card.is-on{background:var(--primary-soft);border-color:var(--primary)}.gm-game-card.is-on .gm-game-card__name{color:var(--primary)}.gm-game-card__emj{font-size:36px;line-height:1}.gm-game-card__name{font-size:14px;font-weight:800;color:var(--text)}.gm-game-card__desc{font-size:11px;color:var(--text-mute);line-height:1.4;min-height:30px}.gm-settings-head{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:800;color:var(--text);margin-top:4px}.gm-soon-badge{font-size:10px;font-weight:800;background:var(--bg-elev-2);color:var(--text-mute);padding:3px 8px;border-radius:999px;letter-spacing:.02em}.gm-settings{opacity:.55;pointer-events:none}.gm-set-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;border-top:1px solid var(--divider)}.gm-set-row:first-child{border-top:0}.gm-set-row .key{color:var(--text-mute)}.gm-set-row .val{color:var(--text);font-weight:700}.gm-set-row .switch{width:36px;height:20px;background:var(--bg-elev-2);border-radius:999px;position:relative}.gm-set-row .switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:var(--text-mute);border-radius:50%}.gm-cta{display:flex;gap:8px;margin-top:6px}.gm-btn{flex:1;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--bg-elev-2);color:var(--text);font:inherit;font-size:14px;font-weight:700;cursor:pointer}.gm-btn:hover{background:var(--bg-elev)}.gm-btn--primary{background:var(--primary);color:var(--on-primary);border-color:transparent}.gm-btn--primary:hover{background:color-mix(in srgb,var(--primary) 88%,#000)}.gm-btn--primary.is-disabled,.gm-btn--primary:disabled{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed;border-color:var(--border)}.pm-head{display:flex;align-items:flex-start;gap:8px;margin-bottom:14px}.pm-head__text{flex:1}.pm-title{font-size:18px;font-weight:800;margin:0;color:var(--text)}.pm-sub{font-size:12px;color:var(--text-mute);margin:2px 0 0}.pm-close{width:32px;height:32px;border-radius:999px;border:0;background:var(--bg-elev-2);color:var(--text);font-size:16px;cursor:pointer}.pm-picker{position:relative}.pm-picker__empty[hidden],.pm-picker__filled[hidden],.pm-grid-overlay[hidden]{display:none!important}.pm-picker__empty{width:100%;aspect-ratio:1/1;background:var(--bg-elev-2);border:2px dashed var(--border);border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background .15s,border-color .15s}.pm-picker__empty:hover,.pm-picker__empty:focus-visible{background:var(--bg-elev);border-color:var(--primary);outline:none}.pm-picker__icon{width:52px;height:52px;border-radius:999px;background:var(--ring-grad);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:600}.pm-picker__title{font-size:15px;font-weight:700;color:var(--text)}.pm-picker__sub{font-size:12px;color:var(--text-mute)}.pm-picker__filled{position:relative;width:100%;aspect-ratio:1/1;border-radius:14px;overflow:hidden;background:var(--media-bg)}.pm-picker__filled img{width:100%;height:100%;object-fit:fill;display:block}.pm-picker__replace{position:absolute;top:8px;right:8px;width:36px;height:36px;border-radius:999px;background:#0000008c;color:#fff;border:0;font-size:14px;backdrop-filter:blur(6px);cursor:pointer}.pm-grid-overlay{position:absolute;inset:0;pointer-events:none;display:grid}.pm-grid-overlay>div{border:1px solid rgba(255,122,89,.85);box-shadow:0 0 0 1px #ffffff59 inset}.pm-section-label{font-size:13px;color:var(--text-mute);margin:14px 0 6px;font-weight:600}.pm-diff-seg{display:grid;grid-template-columns:repeat(5,1fr);background:var(--bg-elev-2);border-radius:10px;padding:4px;gap:4px}.pm-diff-seg__btn{padding:8px 0;border-radius:8px;background:transparent;border:0;font-size:12px;font-weight:700;color:var(--text);display:flex;flex-direction:column;align-items:center;gap:1px;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.pm-diff-seg__btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.pm-diff-seg__btn.is-on{background:var(--bg-elev);box-shadow:0 2px 6px #00000014;color:var(--primary)}.pm-diff-seg__sz{font-size:13px}.pm-diff-seg__pc{font-size:10px;color:var(--text-mute);font-weight:600}.pm-diff-seg__btn.is-on .pm-diff-seg__pc{color:var(--primary)}.pm-rotate-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding:12px;background:var(--bg-elev-2);border-radius:12px;transition:opacity .15s}.pm-rotate-row.is-disabled{opacity:.5;pointer-events:none}.pm-rotate-row.is-hint-flash{animation:pmHintFlash 1s ease-out}@keyframes pmHintFlash{0%{background:var(--bg-elev-2)}20%{background:#ff7a592e}to{background:var(--bg-elev-2)}}.pm-rotate-row__text{flex:1}.pm-rotate-row__main{font-size:14px;font-weight:700;color:var(--text)}.pm-rotate-row__hint{font-size:11px;color:var(--text-mute);margin-top:2px}.pm-switch{width:38px;height:22px;background:var(--border);border-radius:999px;position:relative;flex-shrink:0;border:0;cursor:pointer;padding:0;transition:background .18s}.pm-switch__thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:999px;transition:left .18s;box-shadow:0 1px 2px #0003}.pm-switch[aria-checked=true]{background:var(--primary)}.pm-switch[aria-checked=true] .pm-switch__thumb{left:18px}.pm-cta{display:flex;gap:8px;margin-top:14px}.pm-btn{flex:1;padding:12px 0;border-radius:12px;border:1px solid var(--border);background:var(--bg-elev);color:var(--text);font-size:14px;font-weight:700;cursor:pointer}.pm-btn--primary{background:var(--ring-grad);color:var(--on-primary);border-color:transparent}.pm-btn--primary.is-disabled{background:var(--bg-elev-2);color:var(--text-mute);border-color:var(--border);cursor:not-allowed}.pm-toast{position:absolute;left:50%;bottom:-52px;transform:translate(-50%);background:#0f1219eb;color:#fff;font-size:13px;font-weight:600;padding:10px 16px;border-radius:999px;animation:pmToast 1.5s ease-out forwards;white-space:nowrap}.pm-toast[hidden]{display:none}@keyframes pmToast{0%{opacity:0;transform:translate(-50%,6px)}15%{opacity:1;transform:translate(-50%)}85%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-6px)}}@media (prefers-reduced-motion: reduce){.pm-toast{animation:none;opacity:1}.pm-rotate-row.is-hint-flash{animation:none}}.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.fg label,.fg__label{font-size:13px;font-weight:700;color:var(--text)}.fg .input,.fg .textarea,.fg .select,.fg__input{width:100%;height:44px;padding:0 14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;font-size:15px;color:var(--text);transition:border-color .15s,box-shadow .15s}.fg .textarea{height:auto;min-height:88px;padding:10px 14px;resize:vertical}.fg .input:focus,.fg .textarea:focus,.fg .select:focus,.fg__input:focus{outline:0;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.fg .input:disabled,.fg .input.is-locked,.fg .input.is-readonly,.fg__input.is-locked,.fg__input.is-readonly,.fg__input:disabled{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed}.fg__hint{font-size:12px;color:var(--text-mute);margin-top:0}.fg__hint.is-locked{color:var(--primary);font-weight:600}.confirm-frame{position:fixed;inset:0;background:var(--scrim);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:1100;display:flex;align-items:center;justify-content:center;padding:24px;animation:confirmFade .18s ease-out}@keyframes confirmFade{0%{opacity:0}to{opacity:1}}.confirm{width:100%;max-width:360px;background:var(--bg-elev);border-radius:18px;padding:22px;box-shadow:0 12px 36px #0000004d;text-align:center;animation:confirmRise .22s cubic-bezier(.16,1,.3,1)}@keyframes confirmRise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.confirm__title{font-size:17px;font-weight:800;margin:0 0 8px;color:var(--text)}.confirm__body{font-size:14px;color:var(--text-mute);line-height:1.55;margin:0 0 18px}.confirm__body b{color:var(--text)}.confirm__cta{display:flex;gap:8px}.confirm__cta .btn{flex:1;height:44px;border-radius:12px;border:1px solid var(--border);background:var(--bg-elev-2);color:var(--text);font-size:14px;cursor:pointer;font:inherit;font-weight:700}.confirm__cta .btn--primary{background:var(--primary);color:var(--on-primary);border-color:transparent}.confirm__cta .btn--primary:hover{background:color-mix(in srgb,var(--primary) 88%,#000)}@media (prefers-reduced-motion: reduce){.confirm-frame,.confirm{animation:none}}.consent-card{margin-top:14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-align:left}.consent-card__head{padding:10px 14px;font-size:11px;font-weight:700;color:var(--text-mute);letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--divider);background:var(--bg-elev-2)}.consent-row{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-bottom:1px solid var(--divider);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s ease;margin:0}.consent-row:last-of-type{border-bottom:0}.consent-row:hover{background:var(--bg-elev-2)}.consent-row.is-flash{animation:consent-flash .6s ease}@keyframes consent-flash{0%,to{background:var(--bg-elev)}50%{background:rgba(var(--primary-rgb),.12)}}.consent-row__checkbox{flex:0 0 22px;width:22px;height:22px;border:1.5px solid var(--border);border-radius:6px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--on-primary);font-size:13px;font-weight:800;transition:background .15s ease,border-color .15s ease;margin-top:1px}.consent-row.is-checked .consent-row__checkbox{background:var(--ring-grad);border-color:transparent}.consent-row.is-checked .consent-row__checkbox:before{content:"✓"}.consent-row__main{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.consent-row__title{display:block;font-size:14px;font-weight:700;color:var(--text);line-height:1.4}.consent-row__title .req{color:var(--primary);margin-left:4px;font-size:11px;font-weight:700;vertical-align:middle}.consent-row__help{display:block;font-size:12px;color:var(--text-mute);line-height:1.5}.consent-row__help a{color:var(--primary);text-decoration:underline;text-underline-offset:2px;font-weight:600}.consent-row__help a:hover{color:var(--primary-2)}.consent-row:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.profile-bio-handle{display:flex;align-items:center;gap:6px}.profile-bio-handle .handle-text{user-select:all}.handle-actions{display:inline-flex;gap:4px;margin-left:4px}.handle-actions .handle-btn{background:var(--bg-elev);border:1px solid var(--divider);color:var(--text);width:26px;height:26px;padding:0;border-radius:6px;font-size:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.handle-actions .handle-btn:hover{background:var(--bg-elev-2);border-color:var(--primary)}.handle-actions .handle-btn.is-copied{background:var(--success-soft);color:var(--success);border-color:var(--success)}.friend-code-inline{width:100%;padding-top:14px;margin-top:4px;border-top:1px dashed var(--divider);display:flex;flex-direction:column;gap:8px;text-align:center}.friend-code-inline__label{font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.5px;font-weight:700}.friend-code-inline__code{font-size:22px;font-weight:800;font-family:SF Mono,JetBrains Mono,monospace;letter-spacing:.5px;user-select:all;color:var(--text)}.friend-code-inline__actions{display:flex;gap:8px;width:100%}.friend-code-inline__actions .btn{flex:1;background:var(--bg-elev-2);border:1px solid var(--divider);color:var(--text);border-radius:8px;padding:8px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px;-webkit-tap-highlight-color:transparent}.friend-code-inline__actions .btn.is-primary{background:var(--primary);color:var(--on-primary);border-color:var(--primary)}.friend-code-inline__actions .btn:hover{background:var(--bg-elev)}.friend-code-inline__actions .btn.is-primary:hover{opacity:.9}.field.is-invalid input,.field.is-invalid select,.field.is-invalid textarea{border-color:var(--danger);animation:field-shake .4s ease}.field.is-invalid .gender-radio{border-color:var(--danger)}.field-error{margin:6px 0 0;font-size:12px;color:var(--danger);min-height:0;line-height:1.4;display:none}.field.is-invalid .field-error{display:block;animation:field-error-fade .25s ease}@keyframes field-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes field-error-fade{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.field.is-invalid input,.field.is-invalid select,.field.is-invalid textarea,.field.is-invalid .field-error{animation:none}}.feed-grid{display:grid;grid-template-columns:1fr;gap:14px}.post{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.post .head{display:flex;align-items:center;gap:10px;padding:10px 12px}.post .head .avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-elev-2);display:flex;align-items:center;justify-content:center;font-weight:700}.post .media{position:relative;width:100%;aspect-ratio:1/1;background:var(--media-bg)}.post .media img,.post .media canvas{width:100%;height:100%;object-fit:cover;display:block}.post .body{padding:10px 12px}.post .actions{display:flex;gap:16px;padding:6px 12px 10px;color:var(--text-mute)}.post .actions .btn-ic{background:none;border:0;color:inherit;padding:4px 0}.story-strip{display:flex;gap:12px;overflow-x:auto;padding:12px 14px;scrollbar-width:none;border-bottom:1px solid var(--divider)}.story-strip::-webkit-scrollbar{display:none}.story-item{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;position:relative;background:none;border:0}.story-ring{width:64px;height:64px;border-radius:50%;padding:2.5px;background:var(--ring-grad);display:flex;align-items:center;justify-content:center;transition:transform .15s}.story-item.is-seen .story-ring{background:var(--bg-elev-2)}.story-ring-inner{width:100%;height:100%;border-radius:50%;background:var(--bg);padding:2px;display:flex;align-items:center;justify-content:center}.story-avatar{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;overflow:hidden}.story-avatar img{width:100%;height:100%;object-fit:cover;display:block}.story-name{font-size:11px;color:var(--text);max-width:64px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.story-item.is-selected .story-ring{background:var(--ring-grad);transform:scale(1.04)}.story-item.is-selected:after{content:"×";position:absolute;top:2px;right:0;width:20px;height:20px;border-radius:50%;background:var(--bg);border:2px solid var(--primary);color:var(--primary);font-size:13px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #00000040;line-height:1}.story-item.is-selected .story-name{color:var(--primary);font-weight:700}.host-filter-banner{display:flex;align-items:center;gap:10px;padding:8px 14px;background:rgba(var(--primary-rgb),.1);border-bottom:1px solid rgba(var(--primary-rgb),.25);font-size:12px;color:var(--text)}.host-filter-banner b{color:var(--primary)}.host-filter-banner .clear{margin-left:auto;background:none;border:0;color:var(--primary);font:inherit;font-size:12px;font-weight:700;cursor:pointer}.section-h{margin:0;font-size:14px;font-weight:700;color:var(--text)}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.profile-summary{display:flex;flex-direction:column;align-items:stretch;padding:0;overflow:hidden;position:relative}.profile-avatar{position:relative;width:100%;aspect-ratio:1 / 1;border:0;border-radius:0;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-2) 100%);display:flex;align-items:center;justify-content:center;color:var(--on-primary);font-size:130px;font-weight:800;overflow:hidden;margin:0;box-shadow:none}.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}.avatar-edit-btn{position:absolute;bottom:14px;right:14px;margin:0;background:var(--scrim);color:var(--on-primary);border:0;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:600;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);cursor:pointer;z-index:2}.avatar-edit-btn:hover{background:#000000bf}.profile-body{width:100%;text-align:center;padding:18px 16px 20px}.profile-view{background:transparent;border-radius:0;padding:0;box-shadow:none;color:var(--text)}.profile-view .p-name{font-size:22px;font-weight:800;color:var(--text);margin-bottom:2px}.profile-view .p-handle{font-size:13px;margin-bottom:10px;color:var(--text-mute)}.profile-view .p-chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-bottom:10px}.p-chip{background:var(--bg-elev-2);border:1px solid var(--border);padding:4px 10px;border-radius:999px;font-size:12px;color:var(--text)}.profile-view .p-bio{font-size:13px;color:var(--text);margin-top:4px;white-space:pre-wrap;line-height:1.5}.profile-edit{background:transparent;border-radius:0;padding:0;text-align:left;box-shadow:none}.profile-edit .field{margin-bottom:12px}.stats-grid{margin-top:12px;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px 10px}.stat-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:6px 4px}.stat-emoji{font-size:22px;line-height:1}.stat-val{font-size:15px;font-weight:800;color:var(--text)}.stat-label{font-size:11px;color:var(--text-mute)}.points-card .points-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}.points-cell{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;text-align:center}.points-val{font-size:18px;font-weight:800;color:var(--primary);margin-top:2px}.muted.small,.small.muted,.small{font-size:12px}.muted.small{color:var(--text-mute)}.h-strip{display:flex;overflow-x:auto;gap:12px;scrollbar-width:none;padding:4px 0}.h-strip::-webkit-scrollbar{display:none}.strip-item{background:none;border:0;display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 auto;cursor:pointer;padding:0}.strip-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;overflow:hidden;flex:0 0 auto}.strip-avatar img{width:100%;height:100%;object-fit:cover}.strip-name{font-size:14px;color:var(--text);max-width:76px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gift-strip{display:flex;overflow-x:auto;gap:12px;padding:4px 0;scrollbar-width:none}.gift-strip::-webkit-scrollbar{display:none}.gift-cell-small{display:flex;flex-direction:column;align-items:center;flex:0 0 auto;gap:4px;min-width:76px}.gift-cell-small .emoji{font-size:34px;line-height:1}.gift-cell-small .name{font-size:14px;color:var(--text-mute);max-width:76px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.puzzle-thumb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.puzzle-thumb{position:relative;border-radius:10px;overflow:hidden;background:var(--bg-elev-2);aspect-ratio:1 / 1}.puzzle-thumb img{width:100%;height:100%;object-fit:cover;display:block}.puzzle-status{position:absolute;left:4px;right:4px;bottom:4px;font-size:10px;font-weight:700;padding:3px 6px;border-radius:999px;text-align:center}.puzzle-status.solved{background:rgba(var(--success-rgb),.85);color:var(--on-primary)}.puzzle-status.unsolved{background:var(--scrim);color:var(--on-primary)}.settings-list .settings-row{display:flex;align-items:center;gap:12px;width:100%;padding:12px 4px;border:0;background:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;font:inherit;color:var(--text)}.settings-list .settings-row:last-of-type{border-bottom:0}.settings-list .settings-row.soon{opacity:.5;cursor:default}.settings-emoji{font-size:18px}.settings-label{flex:1;font-size:14px}.settings-arrow{color:var(--text-mute);font-size:13px}.logout-wrap{display:flex;justify-content:flex-end;margin-top:14px;padding-top:10px;border-top:1px solid var(--border)}.btn-link{background:none;border:0;padding:6px 4px;color:var(--text-mute);cursor:pointer;font:inherit;font-size:13px}.btn-link:hover{color:var(--text)}.logout-link{color:var(--text-mute)}.logout-link:hover{color:var(--primary)}.more-link{color:var(--primary);font-weight:600;font-size:12px}.edit-dim{opacity:.35;pointer-events:none;filter:grayscale(.4);transition:opacity .15s ease,filter .15s ease}.modal-tabs{display:flex;gap:6px;margin-bottom:12px;border-bottom:1px solid var(--border);padding-bottom:0}.modal-tab{background:none;border:0;padding:8px 12px;font:inherit;font-size:13px;font-weight:600;color:var(--text-mute);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.modal-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.modal-friend-list{display:flex;flex-direction:column;gap:4px}.modal-friend-row{display:flex;align-items:center;gap:10px;padding:10px 6px;border:0;background:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left;font:inherit;color:var(--text)}.modal-friend-row:hover{background:var(--bg-elev-2)}.modal-friend-row .grow{flex:1;min-width:0}.modal-gift-list{display:flex;flex-direction:column;gap:2px}.modal-gift-row{display:flex;align-items:center;gap:12px;padding:10px 6px;border:0;background:none;border-bottom:1px solid var(--border);text-align:left;font:inherit;color:var(--text)}.modal-gift-row.clickable{cursor:pointer}.modal-gift-row.clickable:hover{background:var(--bg-elev-2)}.modal-gift-row .emoji{font-size:24px;flex:0 0 32px;text-align:center}.modal-gift-row .grow{flex:1;min-width:0}.modal-puzzle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.notif-toggles{display:flex;flex-direction:column}.notif-row{display:flex;align-items:center;padding:12px 4px;border-bottom:1px solid var(--border);cursor:pointer}.notif-row:last-of-type{border-bottom:0}.notif-row .grow{flex:1;font-size:14px}.notif-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary)}.profile-shell{padding:16px 18px 0}.profile-hero-v2{display:flex;align-items:center;gap:20px;padding:8px 0 18px}.profile-av-v2{width:96px;height:96px;border-radius:50%;background:var(--bg-elev-2);color:var(--text);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:36px;border:2px solid var(--bg-elev-2);flex:0 0 96px;overflow:hidden}.profile-av-v2 img{width:100%;height:100%;object-fit:cover;display:block}.profile-av-v2.has-ring{border-color:transparent;background:linear-gradient(var(--bg),var(--bg)) padding-box,var(--ring-grad) border-box;border:3px solid transparent}.profile-hero-stats{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.phs-cell{text-align:center;cursor:pointer;background:none;border:0;padding:4px 0;color:inherit;-webkit-tap-highlight-color:transparent}.phs-num{font-size:24px;font-weight:800;color:var(--text)}.phs-lab{font-size:14px;color:var(--text-mute);margin-top:4px}.profile-bio-block{padding:8px 0 18px}.profile-bio-name{font-size:22px;font-weight:800;color:var(--text)}.profile-bio-handle{font-size:14px;color:var(--text-mute);margin-top:4px}.profile-bio-name{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;white-space:nowrap;overflow:hidden;min-width:0}.profile-bio-name .g-chip{flex-shrink:0}.bio__email-link{background:none;border:0;padding:0;margin:0;color:inherit;font:inherit;display:inline-flex;align-items:center;gap:5px;cursor:pointer;-webkit-tap-highlight-color:transparent;min-width:0;flex-shrink:0}.bio__email-link[hidden]{display:none}.bio__email-link:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:4px}.bio__email-text{font-size:13px;font-weight:400;color:var(--text-mute);transition:color .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.bio__email-icon{width:28px;height:28px;background:var(--bg-elev-2);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-mute);transition:background .15s,color .15s;flex-shrink:0}.bio__email-icon svg{width:16px;height:16px;display:block}.bio__email-link:hover .bio__email-text,.bio__email-link.is-active .bio__email-text{color:var(--primary)}.bio__email-link:hover .bio__email-icon,.bio__email-link.is-active .bio__email-icon{background:var(--primary-soft);color:var(--primary)}.profile-bio-block{position:relative}.email-pop{position:absolute;top:38px;left:0;right:0;z-index:10;animation:emailPopIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes emailPopIn{0%{opacity:0;transform:translateY(-4px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.email-pop__arrow{position:absolute;top:-5px;width:10px;height:10px;background:var(--bg-elev);border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg)}.email-pop__body{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:8px;box-shadow:0 6px 18px #0000001f;cursor:pointer;transition:background .15s,transform .1s,border-color .15s}.email-pop__body:hover{background:var(--primary-soft)}.email-pop__body:active{transform:scale(.97)}.email-pop__ic{width:28px;height:28px;border-radius:8px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s}.email-pop__ic svg{width:16px;height:16px;display:block}.email-pop__text{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--text);word-break:break-all;line-height:1.3}.email-pop__hint{font-size:10px;color:var(--text-mute);margin-top:1px;font-weight:400}.email-pop__copy{font-size:11px;font-weight:800;color:var(--primary);background:var(--primary-soft);padding:3px 8px;border-radius:6px;flex-shrink:0;transition:background .15s,color .15s}.email-pop__body.is-copied{background:#16a34a14;border-color:#16a34a}.email-pop__body.is-copied .email-pop__ic,.email-pop__body.is-copied .email-pop__copy{background:#16a34a2e;color:#16a34a}@media (prefers-reduced-motion: reduce){.email-pop{animation:none}.email-pop__body:active{transform:none}}.profile-bio-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.p-chip{background:var(--bg-elev-2);border:1px solid var(--border);padding:5px 12px;border-radius:999px;font-size:14px;color:var(--text)}.profile-bio-text{font-size:16px;margin-top:12px;line-height:1.55;color:var(--text);white-space:pre-wrap}.profile-edit-row{display:flex;gap:8px;padding:4px 0 14px}.profile-edit-row .btn{flex:1;padding:12px 14px;border-radius:10px;background:var(--bg-elev-2);color:var(--text);border:0;font:inherit;font-size:16px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.view-toggle{display:flex;gap:0;border-bottom:1px solid var(--divider);margin:0 -14px}.view-toggle button{flex:1;background:none;border:0;padding:16px 6px 14px;color:var(--text-mute);font:inherit;font-size:26px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;line-height:1;-webkit-tap-highlight-color:transparent}.view-toggle button.is-active{color:var(--text);border-bottom-color:var(--text)}.view-toggle button .lbl{display:block;font-size:13px;font-weight:600;margin-top:6px;color:inherit;text-transform:uppercase;letter-spacing:.04em}.profile-grid-3col{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin:0 -14px}.pg-cell{position:relative;aspect-ratio:3 / 4;background:var(--bg-elev-2);overflow:hidden;cursor:pointer;text-decoration:none;color:inherit;display:block}.pg-cell img{width:100%;height:100%;object-fit:cover;display:block}.pg-cell.kind-quest-photo{background:linear-gradient(135deg,#ff7a59,#ffd76b)}.pg-cell.kind-quest-route{background:linear-gradient(135deg,#5fb3ff,#5fdcff)}.pg-cell.kind-quest-info{background:linear-gradient(135deg,#ffd76b,#ff7a59)}.pg-cell.kind-quest-food{background:linear-gradient(135deg,#ffae5f,#ff7a59)}.pg-cell.kind-quest-review{background:linear-gradient(135deg,#ffd76b,#ffae5f)}.pg-cell.kind-quest-meetup{background:linear-gradient(135deg,#5fdcff,#5fb3ff)}.pg-cell.kind-quest-translate{background:linear-gradient(135deg,#b48cff,#5fb3ff)}.pg-cell.kind-quest-culture{background:linear-gradient(135deg,#ff8ec3,#ff7a59)}.pg-cell.kind-quest-shopping{background:linear-gradient(135deg,#ff7a59,#b48cff)}.pg-cell.kind-quest-etc{background:linear-gradient(135deg,#6a7180,#2a3140)}.pg-cell.kind-puzzle{background:linear-gradient(135deg,#6c5ce7,#341f97)}.pg-cell .cat-emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:56px;opacity:.9}.pg-cell.kind-quest-etc .cat-emoji{font-size:48px}.pg-cell.kind-puzzle .cat-emoji{font-size:42px;color:#ffffffb3}.pg-cell .pg-badge{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0000008c;backdrop-filter:blur(4px);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;z-index:2}.pg-cell .pg-badge.is-winner{background:var(--primary);color:var(--on-primary)}.pg-cell .pg-cat{position:absolute;top:4px;left:4px;font-size:10px;font-weight:600;background:#0000008c;backdrop-filter:blur(4px);color:#fff;padding:2px 6px;border-radius:999px;z-index:2}.pg-cell .pg-meta{position:absolute;bottom:4px;left:4px;font-size:10px;font-weight:600;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.4);display:inline-flex;align-items:center;gap:8px;z-index:2}.pg-cell .pg-meta .ic{font-size:11px}.pg-cell .pg-reward{position:absolute;bottom:4px;right:4px;font-size:10px;font-weight:700;color:var(--on-primary);background:var(--ring-grad);padding:2px 6px;border-radius:999px;z-index:2}.grid-filter{display:flex;gap:6px;overflow-x:auto;padding:10px 14px;scrollbar-width:none;border-bottom:1px solid var(--divider);margin:0 -14px}.grid-filter::-webkit-scrollbar{display:none}.grid-filter button{flex:0 0 auto;background:var(--bg-elev-2);color:var(--text);border:1px solid transparent;padding:8px 16px;border-radius:999px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.grid-filter button.is-active{background:var(--primary);color:var(--on-primary)}.profile-section{padding:18px 0;border-top:1px solid var(--divider)}.profile-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.profile-section-h{font-size:18px;font-weight:800;margin:0;color:var(--text)}.profile-section-more{font-size:14px;color:var(--primary);font-weight:600;cursor:pointer;background:none;border:0;padding:0;text-decoration:none}.quest-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.qs-cell{background:none;border:0;border-radius:0;padding:0;text-align:center}.qs-num{font-size:24px;font-weight:800;color:var(--text)}.qs-lab{font-size:14px;color:var(--text-mute);margin-top:4px}.points-card-v2{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:18px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.points-card-v2 .points-cell{background:none;border:0;border-radius:0;padding:0;text-align:center}.points-card-v2 .points-cell .v{font-size:24px;font-weight:800;color:var(--primary)}.points-card-v2 .points-cell .l{font-size:14px;color:var(--text-mute);margin-top:4px}.profile-strip{display:flex;gap:18px;overflow-x:auto;scrollbar-width:none;padding:4px 0 6px}.profile-strip::-webkit-scrollbar{display:none}.strip-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:0 0 auto;background:none;border:0;padding:0;cursor:pointer;color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}.strip-av{width:64px;height:64px;border-radius:50%;background:var(--bg-elev-2);color:var(--text);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;border:2px solid var(--border);overflow:hidden}.strip-av img{width:100%;height:100%;object-fit:cover;display:block}.strip-name{font-size:13px;max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.gift-cell-small{display:flex;flex-direction:column;align-items:center;gap:6px}.gift-cell-small .emoji{font-size:40px;line-height:1}.gift-cell-small .name{font-size:13px;color:var(--text-mute);max-width:72px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.puzzle-grid-v2{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.puzzle-thumb-v2{aspect-ratio:1 / 1;border-radius:var(--radius-sm);background:var(--bg-elev-2);position:relative;overflow:hidden;cursor:pointer;border:0;padding:0}.puzzle-thumb-v2 img{width:100%;height:100%;object-fit:cover;display:block}.puzzle-thumb-v2.m1{background:linear-gradient(135deg,#693a3a,#c97558)}.puzzle-thumb-v2.m2{background:linear-gradient(135deg,#0a0e1a,#1a2240)}.puzzle-thumb-v2.m3{background:linear-gradient(135deg,#2a4838,#6ba472)}.puzzle-thumb-v2.m4{background:linear-gradient(135deg,#4a2828,#8a4a32)}.avatar-viewer{position:fixed;inset:0;z-index:1000;background:#000000eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.avatar-viewer.is-open{opacity:1;pointer-events:auto}.avatar-viewer__img{max-width:90vw;max-height:80vh;border-radius:50%;object-fit:cover;box-shadow:0 20px 60px #00000080}.avatar-viewer__initials{width:min(80vw,320px);height:min(80vw,320px);border-radius:50%;background:var(--ring-grad);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-size:96px;font-weight:800;box-shadow:0 20px 60px #00000080}.avatar-viewer__close{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:50%;background:#ffffff1f;color:#fff;border:0;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.avatar-viewer__close:hover{background:#fff3}.avatar-viewer__edit{position:absolute;bottom:32px;left:50%;transform:translate(-50%);padding:10px 24px;border-radius:999px;background:#ffffff1f;color:#fff;border:0;font-size:14px;font-weight:600;cursor:pointer;backdrop-filter:blur(8px);-webkit-tap-highlight-color:transparent}.avatar-viewer__edit:hover{background:#fff3}body.viewer-open{overflow:hidden}.edit-avatar-field{display:flex;flex-direction:column;align-items:center;gap:10px;padding:14px 0 20px;border-bottom:1px solid var(--divider);margin-bottom:16px}.edit-avatar-field__preview{width:140px;height:140px;border-radius:50%;background:var(--bg-elev-2);overflow:hidden;flex:0 0 140px;display:flex;align-items:center;justify-content:center}.edit-avatar-field__preview img{width:100%;height:100%;object-fit:cover}.edit-avatar-field__preview-initials{font-size:48px;font-weight:800;color:var(--on-primary);background:var(--ring-grad);width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:50%}.edit-avatar-field__actions{display:flex;flex-direction:row;gap:12px;align-items:center;justify-content:center}.edit-avatar-field__btn{background:transparent;color:var(--text);border:1px solid var(--divider);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .15s ease}.edit-avatar-field__btn:hover{background:var(--bg-elev-2)}.edit-avatar-field__btn:disabled{opacity:.5;cursor:not-allowed}.edit-avatar-field__btn svg{width:18px;height:18px}.edit-avatar-field__btn.is-danger{color:var(--text-mute)}.edit-avatar-field__sub{font-size:12px;color:var(--text-mute);font-weight:500;text-align:center}.dm-card{border-radius:16px;padding:16px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:background .18s,border-color .18s,box-shadow .18s;position:relative;-webkit-tap-highlight-color:transparent}.dm-card.is-on{background:var(--dating-grad);color:#fff;border:0;box-shadow:0 8px 20px #ff5e7d52}.dm-card.is-off{background:var(--bg-elev);color:var(--text);border:1px solid var(--divider)}.dm-card__emj{width:48px;height:48px;border-radius:12px;background:#ffffff38;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}.dm-card.is-off .dm-card__emj{background:var(--bg-elev-2);filter:grayscale(.55);opacity:.7}.dm-card__text{flex:1;min-width:0}.dm-card__title-row{display:flex;align-items:center;gap:6px;margin-bottom:2px}.dm-card__title{font-size:15px;font-weight:800}.dm-card__pill{display:inline-flex;align-items:center;font-size:10px;font-weight:800;padding:2px 8px;border-radius:999px;letter-spacing:.04em}.dm-card.is-on .dm-card__pill{background:#fffffff2;color:#c93a5b}.dm-card.is-off .dm-card__pill{background:var(--bg-elev-2);color:var(--text-mute)}.dm-card__desc{font-size:12px;line-height:1.5;opacity:.92}.dm-card.is-off .dm-card__desc{color:var(--text-mute);opacity:1}.dm-card__switch{width:44px;height:26px;border-radius:999px;position:relative;flex-shrink:0;border:0;padding:0;cursor:pointer;transition:background .18s}.dm-card.is-on .dm-card__switch{background:#fffffff2}.dm-card.is-off .dm-card__switch{background:#cfd4de}.dm-card__switch:after{content:"";position:absolute;top:3px;width:20px;height:20px;border-radius:999px;background:#fff;box-shadow:0 1px 3px #0003;transition:left .22s cubic-bezier(.32,.72,0,1)}.dm-card.is-on .dm-card__switch:after{left:20px;background:var(--primary)}.dm-card.is-off .dm-card__switch:after{left:3px}.dm-hint{font-size:12px;color:var(--text-mute);margin-top:8px;padding:0 4px}.dm-hint.is-on{color:var(--primary);font-weight:600}@media (prefers-reduced-motion: reduce){.dm-card,.dm-card__switch,.dm-card__switch:after{transition:none}}.dm-card.just-toggled-on{animation:dmCardPopOn .55s cubic-bezier(.34,1.56,.64,1)}@keyframes dmCardPopOn{0%{transform:scale(1);box-shadow:0 8px 20px #ff5e7d52}35%{transform:scale(1.025);box-shadow:0 14px 32px #ff5e7d8c}70%{transform:scale(1.005);box-shadow:0 10px 24px #ff5e7d61}to{transform:scale(1);box-shadow:0 8px 20px #ff5e7d52}}.dm-card.just-toggled-off{animation:dmCardPopOff .4s cubic-bezier(.4,0,.2,1)}@keyframes dmCardPopOff{0%{transform:scale(1)}40%{transform:scale(.985)}to{transform:scale(1)}}.dm-card.just-toggled-on .dm-card__emj{animation:dmHeartBeat .7s cubic-bezier(.34,1.56,.64,1)}@keyframes dmHeartBeat{0%{transform:scale(1) rotate(0)}20%{transform:scale(1.35) rotate(-8deg)}40%{transform:scale(.92) rotate(4deg)}60%{transform:scale(1.18) rotate(-3deg)}80%{transform:scale(.98) rotate(1deg)}to{transform:scale(1) rotate(0)}}.dm-card.just-toggled-off .dm-card__emj{animation:dmHeartShake .4s ease-out}@keyframes dmHeartShake{0%,to{transform:translate(0)}25%{transform:translate(-3px) rotate(-4deg)}75%{transform:translate(3px) rotate(4deg)}}.dm-card__pill.just-swapped{animation:dmPillSwap .32s cubic-bezier(.4,0,.2,1)}@keyframes dmPillSwap{0%{transform:scale(.55);opacity:0}60%{transform:scale(1.12);opacity:1}to{transform:scale(1);opacity:1}}.dm-card__ripple{position:absolute;inset:0;border-radius:16px;pointer-events:none;border:2px solid rgba(255,255,255,.85);opacity:0;animation:dmRipple .7s cubic-bezier(.16,1,.3,1) forwards}@keyframes dmRipple{0%{transform:scale(.92);opacity:.85;border-width:2px}to{transform:scale(1.18);opacity:0;border-width:.5px}}.dm-hint.just-swapped{animation:dmHintSlide .35s ease-out}@keyframes dmHintSlide{0%{transform:translateY(4px);opacity:0}to{transform:translateY(0);opacity:1}}@media (prefers-reduced-motion: reduce){.dm-card.just-toggled-on,.dm-card.just-toggled-off,.dm-card__pill.just-swapped,.dm-card.just-toggled-on .dm-card__emj,.dm-card.just-toggled-off .dm-card__emj,.dm-card__ripple,.dm-hint.just-swapped{animation:none!important}}.input.is-readonly{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed}.input.is-readonly:focus{border-color:var(--border)}.fg__hint.locked{color:var(--text-mute)}.g-chip{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:800;padding:3px 9px;border-radius:999px;vertical-align:middle;line-height:1.2}.g-chip.female{background:var(--female-soft);color:var(--female)}.g-chip.male{background:var(--male-soft);color:var(--male)}.chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.4;white-space:nowrap;border:1px solid transparent}.chip--success{background:rgba(var(--success-rgb),.14);color:var(--success)}.chip--danger{background:rgba(var(--danger-rgb),.14);color:var(--danger)}.chip--neutral{background:var(--neutral-chip);color:var(--text-mute)}.chip--primary{background:var(--primary-soft);color:var(--primary)}.chip--refund{background:var(--neutral-chip);color:var(--text-mute)}.chip--coral-grad{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:var(--on-primary)}.category-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:999px;background:var(--bg-elev-2);color:var(--text);line-height:1.4;white-space:nowrap;border:1px solid transparent;cursor:pointer;font:inherit;font-size:12px;font-weight:500}.category-chip .ic{font-size:14px;line-height:1}.category-chip:hover{filter:brightness(1.04)}.category-chip.is-active{background:var(--primary);color:var(--on-primary)}.category-chip.is-active .ic{filter:brightness(1.2)}.category-filter{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:8px 14px;margin:0 -14px;scroll-snap-type:x proximity}.category-filter::-webkit-scrollbar{display:none}.category-filter .category-chip{scroll-snap-align:start;flex:0 0 auto}.quest-card{display:flex;flex-direction:column;gap:10px;padding:14px 16px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);text-decoration:none;color:inherit;position:relative;transition:transform .12s ease,box-shadow .15s ease}.quest-card:hover{transform:translateY(-1px);box-shadow:0 12px 28px #0000002e}.quest-card:active{transform:translateY(0)}.quest-card__head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0}.quest-card__head-left,.quest-card__head-right{display:flex;align-items:center;gap:6px;min-width:0}.quest-card__head-right{gap:8px;flex:0 0 auto}.quest-card__deadline{font-size:12px;font-weight:400;color:var(--text-mute);white-space:nowrap}.quest-card__deadline.is-urgent-hours{font-size:13px;font-weight:600;color:var(--primary)}.quest-card__deadline.is-urgent-minutes{font-size:13px;font-weight:700;color:var(--primary)}.quest-card__title{margin:0 0 4px;font-size:16px;font-weight:700;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.quest-card__body{margin:0;font-size:13px;color:var(--text-mute);line-height:1.5;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.quest-card__body.is-2line{-webkit-line-clamp:2}.quest-card__media-thumb{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;background:var(--media-bg);flex:0 0 80px}.quest-card__media-thumb img{width:100%;height:100%;object-fit:cover;display:block}.quest-card__media-wide{width:calc(100% + 32px);margin:0 -16px -14px;aspect-ratio:4 / 3;background:var(--media-bg);border-radius:0 0 var(--radius) var(--radius);overflow:hidden}.quest-card__media-wide img{width:100%;height:100%;object-fit:cover;display:block}.quest-card__main{display:flex;gap:12px;align-items:flex-start}.quest-card__main .quest-card__text{flex:1;min-width:0}.quest-card__foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:2px;min-height:32px}.quest-card__host{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 auto}.quest-card__host .avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;overflow:hidden;flex:0 0 28px}.quest-card__host .avatar img{width:100%;height:100%;object-fit:cover}.quest-card__host .name{font-size:12px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.quest-card__host .dot{font-size:11px;color:var(--text-mute);margin:0 -2px;flex:0 0 auto}.quest-card__host .submissions{font-size:11px;font-weight:400;color:var(--text-mute);flex:0 0 auto}.quest-card__reward{flex:0 0 auto;font-size:22px;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums;letter-spacing:-.5px;line-height:1;display:inline-flex;align-items:baseline;gap:2px}.quest-card__reward .unit{font-size:14px;font-weight:600}.quest-card.is-completed{opacity:.85}.quest-card.is-refunded{opacity:.7;border-color:var(--bg-elev-2)}.submissions-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.submission-card{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);min-width:0}.submission-card__head{display:flex;align-items:center;gap:8px;min-width:0}.submission-card__head .avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;overflow:hidden;flex:0 0 28px}.submission-card__head .avatar img{width:100%;height:100%;object-fit:cover}.submission-card__head .name{font-size:12px;font-weight:600;color:var(--text);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.submission-card__media{width:100%;aspect-ratio:1 / 1;background:var(--media-bg);border-radius:var(--radius-sm);overflow:hidden}.submission-card__media img{width:100%;height:100%;object-fit:cover;display:block}.submission-card__body{font-size:13px;color:var(--text);line-height:1.5;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;margin:0;min-height:39px}.submission-card__actions{display:flex;gap:6px;margin-top:2px}.submission-card__actions .btn{flex:1;padding:8px 10px;font-size:12px;border-radius:var(--radius-sm);min-width:0}@media (max-width: 360px){.submissions-grid{grid-template-columns:1fr}}@media (max-width: 360px){.quest-card{padding:12px 14px;gap:8px}.quest-card__title{font-size:15px}.quest-card__media-thumb{width:64px;height:64px;flex-basis:64px}.quest-card__reward{font-size:20px}.quest-card__reward .unit{font-size:13px}.category-filter{padding:6px 12px;margin:0 -12px}.category-chip{padding:5px 10px;font-size:11px}}.filter-line{display:flex;gap:8px;overflow-x:auto;padding:10px 14px;scrollbar-width:none;align-items:center}.filter-line::-webkit-scrollbar{display:none}.filter-line.category-line{border-bottom:1px solid var(--divider)}.filter-line.visibility-line{border-bottom:1px solid var(--divider);background:rgba(var(--primary-rgb),.04)}.filter-line .label{flex:0 0 auto;font-size:12px;font-weight:700;color:var(--text-mute);letter-spacing:.02em;padding-right:4px}.chip-tag{flex:0 0 auto;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:999px;font:inherit;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent}.chip-tag.is-active{background:var(--ring-grad);color:var(--on-primary);border-color:transparent}.chip-tag.is-disabled{opacity:.45;cursor:not-allowed;position:relative}.chip-tag.is-disabled:after{content:"Q-2";position:absolute;top:-6px;right:-4px;font-size:8px;font-weight:800;background:var(--bg-elev);color:var(--text-mute);padding:1px 4px;border-radius:4px;border:1px solid var(--border);letter-spacing:.04em}.feed-item{display:flex;flex-direction:column;border-bottom:1px solid var(--divider)}.feed-item__head{display:flex;align-items:center;gap:10px;padding:10px 14px}.feed-item__avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex:0 0 36px;overflow:hidden}.feed-item__avatar img{width:100%;height:100%;object-fit:cover}.feed-item__head-text{flex:1;min-width:0}.feed-item__host{font-size:16px;font-weight:700;color:var(--text)}.feed-item__sub{font-size:12px;color:var(--text-mute)}.feed-item__more{background:none;border:0;color:var(--text);cursor:pointer;padding:4px;display:inline-flex;align-items:center;justify-content:center}.feed-item__follow{background:transparent;border:1px solid var(--border);color:var(--text);padding:5px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.feed-item__follow:hover{background:var(--bg-elev-2)}.feed-item__follow.is-following{background:var(--ring-grad);color:var(--on-primary);border-color:transparent}.feed-item__chips{display:flex;gap:6px;padding:0 14px 6px}.feed-item__title{margin:0;padding:4px 14px 8px;font-size:18px;font-weight:800;line-height:1.4}.qmedia{position:relative;width:100%;aspect-ratio:4 / 5;background:var(--bg-elev-2);overflow:hidden;flex-shrink:0}.qmedia__track{display:flex;width:100%;height:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-padding:0;scrollbar-width:none;touch-action:pan-x;overscroll-behavior-x:contain}.qmedia__track::-webkit-scrollbar{display:none}.qmedia__slide{flex:0 0 92%;scroll-snap-align:start;scroll-snap-stop:always;position:relative;height:100%}.qmedia__slide.is-single{flex-basis:100%}.qmedia__slide img{width:100%;height:100%;object-fit:cover;display:block}.qmedia__slide.is-locked{position:relative}.qmedia__slide.is-locked>.bg{position:absolute;inset:0;filter:blur(28px);transform:scale(1.2);pointer-events:none}.qmedia__slide.is-locked>.lock-veil{position:absolute;inset:0;background:#00000059;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#fff}.qmedia__slide.is-locked .lock-icon{font-size:32px}.qmedia__slide.is-locked .lock-text{font-size:12px;font-weight:600;text-align:center;max-width:220px;line-height:1.4}.qmedia__slide.is-locked .lock-text small{display:block;font-size:10px;opacity:.8;margin-top:2px;font-weight:400}.qmedia__default{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:80px}.qmedia__text-bg{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 24px;position:relative}.qmedia__text-bg .emj{font-size:48px;line-height:1;opacity:.85}.qmedia__text-body{font-size:15px;line-height:1.55;color:#fff;text-align:center;max-width:100%;overflow:hidden;display:-webkit-box;-webkit-line-clamp:7;-webkit-box-orient:vertical;text-shadow:0 1px 4px rgba(0,0,0,.4)}.qmedia__text-bg.cat-photo{background:linear-gradient(135deg,#ff7a59,#ffd76b)}.qmedia__text-bg.cat-route{background:linear-gradient(135deg,#5fb3ff,#5fdcff)}.qmedia__text-bg.cat-info{background:linear-gradient(135deg,#ffd76b,#ff7a59)}.qmedia__text-bg.cat-food{background:linear-gradient(135deg,#ffae5f,#ff7a59)}.qmedia__text-bg.cat-review{background:linear-gradient(135deg,#ffd76b,#ffae5f)}.qmedia__text-bg.cat-meetup{background:linear-gradient(135deg,#5fdcff,#5fb3ff)}.qmedia__text-bg.cat-translate{background:linear-gradient(135deg,#b48cff,#5fb3ff)}.qmedia__text-bg.cat-culture{background:linear-gradient(135deg,#ff8ec3,#ff7a59)}.qmedia__text-bg.cat-shopping{background:linear-gradient(135deg,#ff7a59,#b48cff)}.qmedia__text-bg.cat-etc{background:linear-gradient(135deg,#6a7180,#2a3140)}.qmedia__default.cat-photo{background:linear-gradient(135deg,#ff7a59,#ffd76b)}.qmedia__default.cat-route{background:linear-gradient(135deg,#5fb3ff,#5fdcff)}.qmedia__default.cat-info{background:linear-gradient(135deg,#ffd76b,#ff7a59)}.qmedia__default.cat-food{background:linear-gradient(135deg,#ffae5f,#ff7a59)}.qmedia__default.cat-review{background:linear-gradient(135deg,#ffd76b,#ffae5f)}.qmedia__default.cat-meetup{background:linear-gradient(135deg,#5fdcff,#5fb3ff)}.qmedia__default.cat-translate{background:linear-gradient(135deg,#b48cff,#5fb3ff)}.qmedia__default.cat-culture{background:linear-gradient(135deg,#ffae5f,#b48cff)}.qmedia__default.cat-shopping{background:linear-gradient(135deg,#ff7a59,#b48cff)}.qmedia__default.cat-etc{background:linear-gradient(135deg,#6a7180,#2a3140)}.qmedia__label{position:absolute;top:10px;left:10px;font-size:11px;font-weight:600;background:#0000008c;backdrop-filter:blur(6px);color:#fff;padding:4px 10px;border-radius:999px;display:inline-flex;align-items:center;gap:6px;z-index:2}.qmedia__label.is-winner{background:var(--primary);color:var(--on-primary)}.qmedia__label .av{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--on-primary);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:800}.qmedia__deadline{position:absolute;top:10px;right:10px;font-size:11px;font-weight:600;background:#0000008c;backdrop-filter:blur(6px);color:#fff;padding:4px 10px;border-radius:999px;z-index:2}.qmedia__deadline.is-urgent{background:var(--primary);color:var(--on-primary)}.qmedia__dots{display:flex;gap:4px;justify-content:center;padding:6px 0}.qmedia__dots span{width:6px;height:6px;border-radius:50%;background:var(--text-mute);opacity:.4;transition:opacity .2s,background .2s}.qmedia__dots span.is-active{background:var(--primary);opacity:1}.action-row{display:flex;align-items:center;padding:8px 12px;gap:4px}.action-icon{background:none;border:0;color:var(--text);width:40px;height:40px;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:22px;-webkit-tap-highlight-color:transparent}.action-icon.is-liked{color:var(--primary)}.action-row .spacer{flex:1}.feed-item__reward{padding:0 14px;font-size:15px;color:var(--text)}.feed-item__reward b{color:var(--primary);font-weight:700}.feed-item__reward .urgent{color:var(--primary);font-weight:600}.feed-item__reward .paid{color:var(--success);font-weight:700}.feed-item__reward .refund-tag{color:var(--text-mute);font-weight:600}.feed-item__reward-row{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;padding:4px 14px 0}.feed-item__reward-row .frr-left{min-width:0}.feed-item__reward-row .frr-label{font-size:12px;font-weight:600;color:var(--text-mute)}.feed-item__reward-row .frr-deadline{font-size:13px;color:var(--text-mute);margin-top:2px}.feed-item__reward-row .frr-deadline.is-urgent{color:var(--primary);font-weight:600}.feed-item__reward-row .frr-hero{font-size:24px;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.5px;white-space:nowrap;font-variant-numeric:tabular-nums}.feed-item__reward-row .frr-hero .frr-p{font-size:14px;font-weight:700;margin-left:1px}.feed-item__engage{padding:4px 14px;font-size:14px;font-weight:600}.feed-item__caption{padding:4px 14px 12px;font-size:15px;line-height:1.5}.feed-item__caption b{font-weight:700}.feed-item__caption .more{color:var(--text-mute);cursor:pointer}.feed-item__comments{padding:0 14px 10px;font-size:13px;color:var(--text-mute)}.feed-item.is-closed{opacity:.62;background:var(--bg-elev-2)}.feed-item.is-selected{opacity:.78;background:var(--bg-elev-2)}.feed-item.is-refunded{opacity:.66;background:var(--bg-elev-2)}.qmedia__overlay{position:absolute;inset:0;z-index:1;pointer-events:none}.feed-item.is-closed .qmedia__overlay{background:#00000040}.feed-item.is-selected .qmedia__overlay{background:#0000002e}.feed-item.is-refunded .qmedia__overlay{background:#0000004d}.qmedia__label.is-refund,.qmedia__deadline.is-closed{background:#000000b3;color:#d4d4d8}.group-header{display:flex;align-items:center;gap:10px;margin:24px 14px 14px;font-size:14px;font-weight:700;color:var(--text-mute)}.group-header:after{content:"";flex:1;height:1px;background:var(--divider)}.group-header .count{font-size:12px;font-weight:600;color:var(--text-faint)}.feed-puzzle-cover{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0006;backdrop-filter:blur(6px);font-size:14px;font-weight:700;color:#fff;flex-direction:column;gap:4px;cursor:pointer}.feed-puzzle-cover .ic{font-size:36px}.form-shell{padding:16px}.form-row{margin-bottom:16px}.form-row .label{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:8px;letter-spacing:.01em}.form-row .helper{font-size:12px;color:var(--text-mute);margin-top:6px;line-height:1.5}.form-row input[type=text],.form-row input[type=number],.form-row input[type=datetime-local],.form-row textarea,.form-row select{width:100%;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font:inherit;font-size:15px;color:var(--text);outline:none;-webkit-tap-highlight-color:transparent}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--primary)}.form-row textarea{resize:vertical;min-height:120px}.form-row select{appearance:none;-webkit-appearance:none;cursor:pointer}.form-row .media-upload{border:1.5px dashed var(--border);border-radius:var(--radius);padding:28px 20px;text-align:center;color:var(--text-mute);cursor:pointer;background:var(--bg-elev);display:flex;flex-direction:column;align-items:center;gap:8px;-webkit-tap-highlight-color:transparent}.form-row .media-upload:hover{border-color:var(--primary);color:var(--text)}.form-row .media-upload .ic{font-size:36px;line-height:1}.form-row .media-upload .lbl{font-size:14px}.form-row .media-upload.has-file{border-style:solid;border-color:var(--primary);color:var(--text)}.form-row .notice{background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.25);border-radius:var(--radius-sm);padding:12px 14px;font-size:13px;line-height:1.55;color:var(--text)}.create-balance{display:flex;align-items:center;gap:6px;margin-top:6px;font-size:13px;color:var(--text-mute)}.create-balance b{color:var(--text);font-weight:700}.create-balance.is-low b{color:var(--primary)}.insuf-block{margin-top:8px;background:rgba(var(--danger-rgb),.1);border:1px solid rgba(var(--danger-rgb),.22);border-radius:var(--radius-sm);padding:12px 14px}.insuf-block__msg{font-size:13px;color:var(--text);line-height:1.5}.insuf-block__msg b{color:var(--primary);font-weight:700}.insuf-block__acts{display:flex;gap:8px;margin-top:10px}.insuf-block__acts button{flex:1;padding:10px 0;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;border:0;font-family:inherit}.insuf-block__acts .insuf-charge{background:var(--ring-grad);color:var(--on-primary)}.quest-resume-banner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:12px 16px 0;padding:12px 14px;background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.25);border-radius:var(--radius-sm)}.quest-resume-banner .qrb-text{flex:1;min-width:0;font-size:13px;color:var(--text);line-height:1.5}.quest-resume-banner .qrb-back{flex-shrink:0;text-decoration:none;font-size:13px;font-weight:700;padding:8px 14px;border-radius:var(--radius-sm);background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border)}.quest-resume-banner.is-charged{border-color:var(--primary)}.quest-resume-banner.is-charged .qrb-back{background:var(--ring-grad);color:var(--on-primary);border-color:transparent}.quest-summary{padding:14px 16px;background:var(--bg-elev);border-bottom:1px solid var(--divider);display:flex;gap:14px;align-items:center}.quest-summary__thumb{width:64px;height:64px;border-radius:var(--radius-sm);flex:0 0 64px;overflow:hidden;background:var(--bg-elev-2);display:flex;align-items:center;justify-content:center;font-size:28px}.quest-summary__thumb img{width:100%;height:100%;object-fit:cover;display:block}.quest-summary__main{flex:1;min-width:0}.quest-summary__title{font-size:16px;font-weight:700;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}.quest-summary__meta{font-size:12px;color:var(--text-mute);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quest-summary__meta b{color:var(--primary);font-weight:700}.btn-primary-block{display:block;width:100%;padding:14px 16px;background:var(--ring-grad);color:var(--on-primary);border:0;border-radius:12px;font:inherit;font-size:16px;font-weight:700;text-align:center;text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .12s,opacity .12s}.btn-primary-block:active{transform:scale(.98)}.btn-primary-block:disabled,.btn-primary-block.is-disabled{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed}.dating-subtab{position:relative}.dating-subtab.is-dating:before{content:"💖";font-size:12px;margin-right:4px}.dating-subtab.is-active{color:var(--primary)}.dating-subtab.is-active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--ring-grad)}.gender-chip-row{display:flex;gap:6px;overflow-x:auto;padding:8px 14px;scrollbar-width:none;background:var(--bg-elev);border-bottom:1px solid var(--divider)}.gender-chip-row::-webkit-scrollbar{display:none}.gender-chip{flex:0 0 auto;background:var(--bg-elev-2);color:var(--text);border:1px solid transparent;border-radius:999px;padding:6px 14px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px}.gender-chip.is-active{background:var(--primary);color:var(--on-primary)}.gender-chip[data-gender=female]:before{content:"♀ "}.gender-chip[data-gender=male]:before{content:"♂ "}.cat-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.cat-grid-tile{aspect-ratio:1 / 1;background:var(--bg-elev-2);border:2px solid transparent;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:4px 2px;cursor:pointer;font:inherit;color:var(--text);-webkit-tap-highlight-color:transparent;transition:transform .15s,background .15s,border-color .15s,box-shadow .15s}.cat-grid-tile:hover{transform:scale(1.04);background:#e6e7ec}.cat-grid-tile:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.cat-grid-tile.is-on{background:var(--primary-soft);border-color:var(--primary);transform:scale(1.04);box-shadow:0 4px 12px #ff7a5938}.cat-grid-tile__emj{font-size:22px;line-height:1}.cat-grid-tile__lab{font-size:10px;font-weight:700;color:var(--text);text-align:center}.cat-grid-tile.is-on .cat-grid-tile__lab{color:var(--primary)}@media (prefers-reduced-motion: reduce){.cat-grid-tile{transition:none}.cat-grid-tile:hover,.cat-grid-tile.is-on{transform:none}}.dice{width:80px;height:80px;border-radius:16px;background:var(--dice-bg);color:var(--dice-text);display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:800;box-shadow:0 12px 30px #0000004d;margin:0 auto}.dice.rolling{animation:rollAnim .9s ease-out}@keyframes rollAnim{0%{transform:rotate(0) scale(1)}50%{transform:rotate(540deg) scale(1.2)}to{transform:rotate(720deg) scale(1)}}.dice-area{padding:24px 0;text-align:center}.game-log{background:var(--bg-elev);border-radius:var(--radius);padding:10px;max-height:200px;overflow-y:auto;font-size:13px;margin-top:12px}.players{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.player-chip{background:var(--bg-elev-2);border:1px solid var(--border);padding:6px 10px;border-radius:999px;font-size:12px}.player-chip.turn{background:var(--primary);color:var(--on-primary);border:0}.player-chip.host{border-color:var(--primary)}.game-lobby{display:flex;flex-direction:column;align-items:stretch;gap:18px;padding:18px 4px 8px}.lobby-hero{text-align:center;padding:22px 16px 8px}.lobby-emoji{font-size:56px;line-height:1;margin-bottom:10px}.lobby-title{margin:0 0 8px;font-size:22px;font-weight:700;color:var(--text)}.lobby-sub{margin:0;font-size:14px;color:var(--text-mute);line-height:1.5}.lobby-choices{display:grid;grid-template-columns:1fr 1fr;gap:12px}.lobby-card{display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;gap:6px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:18px 14px;cursor:pointer;text-align:left;font:inherit;color:var(--text);transition:transform .08s ease,box-shadow .15s ease,border-color .15s ease}.lobby-card:hover,.lobby-card:focus-visible{border-color:var(--primary);box-shadow:0 4px 14px rgba(var(--primary-rgb),.18);transform:translateY(-1px);outline:none}.lobby-card:active{transform:translateY(0)}.lobby-card:disabled{opacity:.6;cursor:not-allowed}.lobby-card-emoji{font-size:36px;line-height:1}.lobby-card-name{font-size:16px;font-weight:700}.lobby-card-desc{font-size:12px;color:var(--text-mute);min-height:32px}.lobby-card-cta{margin-top:6px;font-size:13px;font-weight:600;color:var(--primary)}.lobby-footnote{text-align:center;font-size:12px;padding:6px 12px 0}@media (max-width: 360px){.lobby-choices{grid-template-columns:1fr}.lobby-card-desc{min-height:0}}.qr-box{margin:24px auto;width:240px;height:240px;background:var(--qr-bg);border-radius:14px;padding:14px;display:flex;align-items:center;justify-content:center}.invite-link{display:flex;gap:8px;margin-top:14px}.invite-link .input{font-size:12px}.balance-card{background:linear-gradient(135deg,var(--balance-from) 0%,var(--balance-to) 100%);border-radius:16px;padding:18px;color:var(--on-primary);margin-bottom:14px}.balance-card .label{color:#ffffffa6;font-size:12px}.balance-card .amount{font-size:28px;font-weight:800;margin-top:4px}.balance-card .row{margin-top:10px}.bucket-pills{display:flex;gap:6px;margin-bottom:12px}.bucket-pills .pill{flex:1;background:var(--bg-elev);border:1px solid var(--border);padding:8px;border-radius:10px;text-align:center;font-size:12px}.bucket-pills .pill .v{font-weight:700;font-size:16px;color:var(--primary)}.puzzle-board{display:grid;gap:2px;background:var(--media-bg);border-radius:8px;overflow:hidden;margin-bottom:8px}.puzzle-cell{position:relative;overflow:hidden;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.puzzle-cell__bg{position:absolute;inset:0;background-repeat:no-repeat;transition:transform .18s cubic-bezier(.16,1,.3,1);pointer-events:none}.puzzle-cell.is-blank{background:#ff7a590d;box-shadow:inset 0 0 0 1px #ff7a5947;border-radius:4px;animation:puzzleBlankPulse 2.4s cubic-bezier(.45,0,.55,1) infinite}@keyframes puzzleBlankPulse{0%,to{background:#ff7a590d;box-shadow:inset 0 0 0 1px #ff7a5947}50%{background:#ff7a5924;box-shadow:inset 0 0 0 1px #ff7a598c,inset 0 0 12px #ff7a592e}}@media (prefers-reduced-motion: reduce){.puzzle-cell.is-blank{animation:none;background:#ff7a591a;box-shadow:inset 0 0 0 1px #ff7a5966}}.puzzle-progress{font-size:13px;color:var(--text-mute)}.puzzle-difficulty-chip.is-readonly,.puzzle-rotate-toggle.is-readonly{cursor:not-allowed;opacity:.85}.puzzle-difficulty-chip.is-readonly:hover{color:inherit}.puzzle-difficulty-row.is-readonly{pointer-events:none}.notif-stack{position:fixed;top:14px;right:14px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.notif-card{pointer-events:auto;display:grid;grid-template-columns:36px 1fr 18px;gap:10px;align-items:center;width:280px;max-width:calc(100vw - 28px);background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;padding:10px 12px;text-align:left;cursor:pointer;box-shadow:var(--shadow);opacity:0;transform:translate(28px);transition:opacity .25s,transform .25s;color:inherit;font:inherit}.notif-card.show{opacity:1;transform:translate(0)}.notif-card:hover{background:var(--bg-elev-2)}.notif-card .notif-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;color:var(--on-primary);font-weight:700;font-size:14px;overflow:hidden}.notif-card .notif-avatar img{width:100%;height:100%;object-fit:cover}.notif-card .notif-text{min-width:0}.notif-card .notif-title{font-weight:700;font-size:13px}.notif-card .notif-body{color:var(--text-mute);font-size:12px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.notif-card .notif-close{color:var(--text-mute);font-size:18px;line-height:1;width:18px;height:18px;text-align:center}.notif-card .notif-close:hover{color:var(--text)}.dating-mode-dot{width:8px;height:8px;border-radius:50%;background:var(--dating-mode-active);box-shadow:0 0 6px rgba(var(--primary-rgb),.5);display:inline-block;margin-left:4px}.game-grid-v2{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px}.game-card-v2{display:flex;flex-direction:column;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;text-decoration:none;color:inherit;transition:transform .12s,box-shadow .15s,border-color .15s}.game-card-v2:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:var(--primary)}.game-card-v2__media{width:100%;aspect-ratio:4 / 3;background:var(--bg-elev-2);display:flex;align-items:center;justify-content:center;font-size:56px}.game-card-v2__body{padding:12px 14px}.game-card-v2__title{margin:0;font-size:16px;font-weight:700;color:var(--text);line-height:1.3}.game-card-v2__sub{margin-top:4px;font-size:14px;color:var(--text-mute)}.game-card-v2__reward{margin-top:8px;font-size:14px;font-weight:700;color:var(--primary)}.game-card-v2.is-active{border-color:transparent;background:linear-gradient(var(--bg-elev),var(--bg-elev)) padding-box,var(--ring-grad) border-box;border:2px solid transparent}.puzzle-difficulty-row{display:flex;gap:6px;flex-wrap:wrap}.puzzle-difficulty-chip{flex:0 0 auto;padding:7px 12px;border-radius:999px;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-mute);font:inherit;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.puzzle-difficulty-chip:hover{color:var(--text)}.puzzle-difficulty-chip.is-active{background:var(--ring-grad);color:var(--on-primary);border-color:transparent}.puzzle-rotate-toggle{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);font:inherit;font-size:14px;font-weight:600;cursor:pointer;width:fit-content;transition:opacity .15s,background .15s}.puzzle-rotate-toggle .switch{width:32px;height:18px;border-radius:999px;background:var(--border);position:relative;transition:background .18s}.puzzle-rotate-toggle .switch:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .18s}.puzzle-rotate-toggle.is-on .switch{background:var(--primary)}.puzzle-rotate-toggle.is-on .switch:after{transform:translate(14px)}.puzzle-rotate-toggle.is-disabled,.puzzle-rotate-toggle:disabled{opacity:.4;pointer-events:none}.puzzle-modal{position:fixed;inset:0;z-index:1100;background:var(--scrim);display:flex;align-items:center;justify-content:center;padding:14px}.puzzle-modal__inner{position:relative;width:100%;max-width:480px;max-height:92vh;overflow-y:auto;background:var(--bg-elev);border:1px solid var(--border);border-radius:18px;padding:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}.puzzle-modal__close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:transparent;border:0;color:var(--text);font-size:18px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;z-index:2}.puzzle-modal__close:hover{background:var(--bg-elev-2)}.puzzle-modal__top{display:flex;flex-direction:column;gap:10px;padding-right:36px}.puzzle-modal__board{width:100%}.chat-wrap{display:flex;flex-direction:column;flex:1;min-height:0;position:relative}.scroll-bottom-btn{position:fixed;right:max(14px,calc(50vw - 226px));bottom:calc(132px + env(safe-area-inset-bottom,0px));width:44px;height:44px;border-radius:50%;background:var(--bg-elev);border:1px solid var(--border);color:var(--text);box-shadow:0 6px 16px #0000002e;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:50;padding:0;transition:transform .12s ease,box-shadow .15s ease;animation:scrollBtnIn .18s ease-out}.scroll-bottom-btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px #00000038}.scroll-bottom-btn:active{transform:translateY(0)}.chat-wrap.has-attach-open .scroll-bottom-btn,.chat-wrap.has-focus .scroll-bottom-btn{display:none!important}.scroll-bottom-arrow{font-size:20px;line-height:1;font-weight:700}.scroll-bottom-badge{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--primary);color:var(--on-primary);font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(var(--primary-rgb),.45);pointer-events:none}@keyframes scrollBtnIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 360px){.scroll-bottom-btn{right:10px;bottom:calc(124px + env(safe-area-inset-bottom,0px));width:40px;height:40px}.scroll-bottom-arrow{font-size:18px}}.chat-stream{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px;scroll-behavior:smooth}.bubble{max-width:75%;padding:10px 12px;border-radius:16px;background:var(--bg-elev);border:1px solid var(--border);word-break:break-word;position:relative}.bubble .translated{margin-top:6px;padding-top:6px;border-top:1px dashed var(--border);color:var(--text-mute);font-size:13px}.bubble .time{font-size:10px;color:var(--text-mute);margin-top:4px}.bubble.me{align-self:flex-end;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:var(--on-primary);border:0}.bubble.me .translated{color:#ffffffd9;border-top-color:#fff6}.bubble.other{align-self:flex-start}.bubble.system{align-self:center;background:transparent;border:0;color:var(--text-mute);font-size:12px}.bubble .name{font-size:11px;color:var(--text-mute);margin-bottom:2px}.bubble.me .name{display:none}.bubble.gift{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--gift-from),var(--gift-to));color:var(--gift-text);border:0}.bubble.gift .emoji{font-size:28px}.bubble.game{background:linear-gradient(135deg,var(--game-from),var(--game-to));color:var(--on-primary);border:0}.bubble img.attach{max-width:240px;border-radius:10px}.chat-input{position:sticky;bottom:0;background:var(--bg);border-top:1px solid var(--border);padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom));display:flex;gap:8px;align-items:flex-end}.chat-input textarea{flex:1;background:var(--bg-elev);border:1px solid var(--border);border-radius:18px;padding:10px 14px;resize:none;max-height:120px;min-height:40px;color:var(--text)}.chat-input .iconbtn{width:40px;height:40px;border-radius:50%;background:var(--bg-elev);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:18px}.chat-input .iconbtn.primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));border:0;color:var(--on-primary)}.composer-actions{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 8px}.composer-actions .chip{background:var(--bg-elev-2);border:1px solid var(--border);padding:6px 10px;border-radius:999px;font-size:12px;color:var(--text)}.topics{display:flex;gap:8px;overflow-x:auto;padding:8px 12px 0;scrollbar-width:none}.topics::-webkit-scrollbar{display:none}.topics .topic{flex:0 0 auto;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:6px 12px;font-size:12px;white-space:nowrap}.list-item.room-arrival{opacity:0;transform:translateY(-12px);transition:opacity .28s ease,transform .28s ease}.list-item.room-arrival.show{opacity:1;transform:translateY(0)}.draft-placeholder{align-self:stretch;margin:auto 16px;padding:18px 14px;background:var(--bg-elev-2);border:1px dashed var(--border);border-radius:var(--radius);text-align:center;color:var(--text)}.draft-placeholder .muted{color:var(--text-mute)}.bubble.optimistic{opacity:.65}.msg-divider{display:flex;align-items:center;gap:12px;margin:20px 4px 14px;font-size:12px;font-weight:700;color:var(--primary);letter-spacing:.02em}.msg-divider:before,.msg-divider:after{content:"";flex:1;height:2px;background:linear-gradient(to right,transparent,var(--primary),transparent)}.msg-divider:after{background:linear-gradient(to left,transparent,var(--primary),transparent)}.msg-divider span{white-space:nowrap;padding:6px 14px;background:rgba(var(--primary-rgb),.14);border:1px solid rgba(var(--primary-rgb),.35);border-radius:999px;box-shadow:0 2px 6px rgba(var(--primary-rgb),.18)}.quest-alert{margin:10px 14px 8px;padding:12px 16px;border-radius:12px;background:linear-gradient(135deg,rgba(var(--primary-rgb),.16),rgba(var(--primary-rgb),.06));border:1px solid rgba(var(--primary-rgb),.3);font-size:15px;font-weight:600;display:flex;align-items:center;gap:10px;cursor:pointer;color:var(--text);width:calc(100% - 28px)}.quest-alert .badge-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex:0 0 8px;box-shadow:0 0 8px rgba(var(--primary-rgb),.5)}.quest-alert .grow{flex:1;min-width:0}.quest-alert .arrow{color:var(--text-mute)}.search-bar{margin:10px 14px;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-elev-2);border:0;border-radius:10px;color:var(--text-mute);font-size:15px}.search-bar .ic{font-size:16px}.search-bar input{flex:1;min-width:0;background:transparent;border:0;outline:none;color:var(--text);font-size:15px;font-family:inherit}.search-bar input::placeholder{color:var(--text-mute)}.dm-tabs{display:flex;gap:18px;padding:4px 14px 0;border-bottom:1px solid var(--divider)}.dm-tabs button{background:none;border:0;color:var(--text-mute);font:inherit;font-size:16px;font-weight:700;padding:10px 0 12px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px;-webkit-tap-highlight-color:transparent}.dm-tabs button.is-active{color:var(--text);border-bottom-color:var(--primary)}.dm-tabs .tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 7px;background:var(--ring-grad);color:var(--on-primary);font-size:11px;font-weight:800;border-radius:999px}.dm-list{display:flex;flex-direction:column}.dm-row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--divider);cursor:pointer;text-decoration:none;color:inherit}.dm-row:last-of-type{border-bottom:0}.dm-row__avatar{position:relative;width:56px;height:56px;flex:0 0 56px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--primary));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;overflow:hidden}.dm-row__avatar img{width:100%;height:100%;object-fit:cover;display:block}.dm-row__avatar.is-active:after{content:"";position:absolute;bottom:2px;right:2px;width:14px;height:14px;border-radius:50%;background:var(--primary);border:2.5px solid var(--bg)}.dm-row__main{flex:1;min-width:0}.dm-row__name{font-size:16px;font-weight:700;color:var(--text)}.dm-row__last{font-size:15px;color:var(--text-mute);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px;margin-top:3px}.dm-row__meta{text-align:right;font-size:12px;color:var(--text-mute)}.dm-row__unread{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 7px;background:var(--ring-grad);color:var(--on-primary);font-weight:700;font-size:12px;border-radius:999px;margin-top:4px}.dm-row.room-arrival{opacity:0;transform:translateY(-6px);transition:opacity .25s,transform .25s}.dm-row.room-arrival.show{opacity:1;transform:translateY(0)}.chat-header-v2{display:flex;align-items:center;gap:8px;padding:10px 14px;min-height:52px;border-bottom:1px solid var(--divider);background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(12px);position:sticky;top:0;z-index:10}.chat-header-v2 .icon-btn{background:none;border:0;color:var(--text);width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;padding:0;-webkit-tap-highlight-color:transparent}.chat-header-v2 .icon-btn svg{display:block}.chat-header-v2 .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;overflow:hidden}.chat-header-v2 .avatar img{width:100%;height:100%;object-fit:cover}.chat-header-v2 .title{font-size:17px;font-weight:700;flex:1;min-width:0;color:var(--text)}.topics-strip{display:flex;gap:8px;overflow-x:auto;padding:8px 12px 0;scrollbar-width:none}.topics-strip::-webkit-scrollbar{display:none}.topics-strip .topic{flex:0 0 auto;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:8px 14px;font-size:15px;white-space:nowrap;color:var(--text);cursor:pointer}body.chat-page,body.chat-page .app-shell{height:100dvh;max-height:100dvh;overflow:hidden}.chat-stream-v2{flex:1 1 0;min-height:0;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.chat-stream-v2>*{flex-shrink:0}.bubble-v2{max-width:75%;padding:10px 14px;border-radius:18px;font-size:15px;line-height:1.45;word-break:break-word}.bubble-v2.other{align-self:flex-start;background:var(--bg-elev-2);color:var(--text);border-bottom-left-radius:4px}.bubble-v2.me{align-self:flex-end;background:var(--ring-grad);color:var(--on-primary);border-bottom-right-radius:4px}.bubble-v2 .time{display:block;font-size:12px;margin-top:4px;opacity:.7}.bubble-v2.system{align-self:center;background:transparent;border:0;color:var(--text-mute);font-size:12px;max-width:100%;border-radius:0;padding:4px 0}.bubble-v2.gift{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--gift-from),var(--gift-to));color:var(--gift-text);border:0}.bubble-v2.gift .emoji{font-size:28px}.bubble-v2.game{background:linear-gradient(135deg,var(--game-from),var(--game-to));color:var(--on-primary);border:0}.bubble-v2 .name{font-size:11px;color:var(--text-mute);margin-bottom:2px}.bubble-v2.me .name{display:none}.bubble-v2 img.attach{max-width:240px;border-radius:10px}.bubble-v2.optimistic{opacity:.6}.suggestion-bar{flex:0 0 auto;display:flex;gap:8px;padding:0;max-height:0;overflow:hidden;border-top:0;transition:max-height .24s cubic-bezier(.16,1,.3,1),padding .24s ease,border-top-width .24s ease}.chat-wrap.has-focus .suggestion-bar{max-height:60px;padding:8px 14px;border-top:1px solid var(--divider)}.suggestion-bar .chip{flex:0 0 auto;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);padding:8px 14px;border-radius:999px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;opacity:0;transform:translateY(8px);transition:opacity .22s ease-out,transform .22s cubic-bezier(.16,1,.3,1),background .15s}.chat-wrap.has-focus .suggestion-bar .chip{opacity:1;transform:translateY(0)}.chat-wrap.has-focus .suggestion-bar .chip:nth-child(1){transition-delay:.04s}.chat-wrap.has-focus .suggestion-bar .chip:nth-child(2){transition-delay:.1s}.chat-wrap.has-focus.is-first-show .suggestion-bar .chip{animation:chipPulse .42s cubic-bezier(.16,1,.3,1) .14s 1}@keyframes chipPulse{0%{box-shadow:0 0 rgba(var(--primary-rgb),.6);border-color:var(--primary)}to{box-shadow:0 0 0 8px rgba(var(--primary-rgb),0);border-color:var(--border)}}.attach-sheet{flex:0 0 auto;max-height:0;overflow:hidden;background:var(--bg-elev);border-top:0;border-bottom:0;transition:max-height .26s cubic-bezier(.16,1,.3,1),border-top-width .26s ease,border-bottom-width .26s ease}.attach-sheet.is-open{max-height:140px;border-top:1px solid var(--divider);border-bottom:1px solid var(--divider)}.attach-sheet .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px}.attach-sheet .cell{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font:inherit;color:var(--text);-webkit-tap-highlight-color:transparent}.attach-sheet .cell:hover,.attach-sheet .cell:focus-visible{background:var(--bg-elev);outline:none}.attach-sheet .cell .emj{font-size:26px}.attach-sheet .cell .lbl{font-size:13px;font-weight:600}.chat-input-v2 .plus{transition:transform .15s,background .15s}.chat-input-v2 .plus.is-open{background:var(--ring-grad);color:var(--on-primary);border:0;transform:rotate(45deg)}.chat-input-v2 textarea:focus{background:var(--bg-elev)}@media (prefers-reduced-motion: reduce){.suggestion-bar,.suggestion-bar .chip,.attach-sheet,.chat-input-v2 .plus{transition:max-height .12s ease,padding .12s ease,opacity .12s ease;transform:none!important}.chat-wrap.has-focus.is-first-show .suggestion-bar .chip{animation:none}}.chat-input-v2{flex:0 0 auto;display:flex;gap:8px;padding:8px 12px 12px;border-top:1px solid var(--divider);align-items:flex-end;background:var(--bg)}.chat-input-v2 .plus{width:44px;height:44px;border-radius:50%;background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text);font-size:20px;cursor:pointer;transition:transform .18s cubic-bezier(.16,1,.3,1),background .15s,color .15s,border-color .15s}.chat-input-v2 .plus.is-open{background:var(--ring-grad);color:var(--on-primary);border-color:transparent;transform:rotate(45deg)}.chat-input-v2 textarea{flex:1;background:var(--bg-elev-2);border:0;border-radius:22px;padding:12px 16px;font:inherit;font-size:15px;color:var(--text);resize:none;max-height:96px;min-height:44px}.chat-input-v2 .send{width:44px;height:44px;border-radius:50%;background:var(--ring-grad);border:0;color:var(--on-primary);font-size:18px;cursor:pointer}.suggestion-bar{display:flex;gap:8px;padding:0;max-height:0;overflow:hidden;border-top:0;transition:max-height .24s cubic-bezier(.16,1,.3,1),padding .24s ease,border-top-width .24s ease}.chat-wrap.has-focus .suggestion-bar{max-height:56px;padding:8px 14px;border-top:1px solid var(--divider)}.suggestion-bar .chip-suggest{flex:0 0 auto;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);padding:6px 12px;border-radius:999px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:4px;opacity:0;transform:translateY(8px);transition:opacity .22s ease-out,transform .22s cubic-bezier(.16,1,.3,1),background .15s,border-color .15s,box-shadow .15s}.chat-wrap.has-focus .suggestion-bar .chip-suggest{opacity:1;transform:translateY(0)}.chat-wrap.has-focus .suggestion-bar .chip-suggest:nth-child(1){transition-delay:.04s}.chat-wrap.has-focus .suggestion-bar .chip-suggest:nth-child(2){transition-delay:.1s}.chat-wrap.has-focus.is-first-show .suggestion-bar .chip-suggest{animation:chipSuggestPulse .42s cubic-bezier(.16,1,.3,1) .14s 1}@keyframes chipSuggestPulse{0%{box-shadow:0 0 rgba(var(--primary-rgb),.6);border-color:var(--primary)}to{box-shadow:0 0 0 8px rgba(var(--primary-rgb),0);border-color:var(--border)}}@media (prefers-reduced-motion: reduce){.suggestion-bar,.suggestion-bar .chip-suggest{transition:max-height .12s ease,padding .12s ease,opacity .12s ease;transform:none!important}.chat-wrap.has-focus.is-first-show .suggestion-bar .chip-suggest{animation:none}}.attach-sheet{max-height:0;overflow:hidden;background:var(--bg-elev);border-top:0;border-bottom:0;transition:max-height .26s cubic-bezier(.16,1,.3,1),border-top-width .26s ease,border-bottom-width .26s ease}.attach-sheet.is-open{max-height:132px;border-top:1px solid var(--divider);border-bottom:1px solid var(--divider)}.attach-sheet__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px}.attach-sheet__cell{background:var(--bg-elev-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;font:inherit;color:var(--text);-webkit-tap-highlight-color:transparent;transition:background .15s,border-color .15s,transform .12s}.attach-sheet__cell:hover{background:var(--bg-elev);border-color:var(--primary)}.attach-sheet__cell:active{transform:scale(.96)}.attach-sheet__cell .emj{font-size:28px;line-height:1}.attach-sheet__cell .lbl{font-size:14px;font-weight:600;color:var(--text)}.composer-actions-v2 .chip-btn.is-gift{position:relative;background:var(--gift-ring);color:var(--on-primary);border:0;font-weight:700;box-shadow:0 2px 6px rgba(var(--primary-rgb),.25)}.composer-actions-v2 .chip-btn.is-gift.is-disabled{opacity:.4;pointer-events:none;position:relative}.composer-actions-v2 .chip-btn.is-gift.is-disabled:after{content:"🔒";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:10px}.gift-sheet-mask{position:fixed;inset:0;z-index:1000;background:var(--scrim);display:flex;align-items:flex-end;justify-content:center;animation:gsFade .22s ease-out}@keyframes gsFade{0%{opacity:0}to{opacity:1}}.gift-sheet{width:100%;max-width:480px;background:var(--bg-elev);border-top-left-radius:22px;border-top-right-radius:22px;padding:18px 18px 24px;padding-bottom:calc(24px + env(safe-area-inset-bottom));animation:gsRise .26s cubic-bezier(.16,1,.3,1)}@keyframes gsRise{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.gift-sheet__title{font-size:18px;font-weight:800;margin:0 0 14px;color:var(--text);text-align:center}.gift-sheet__types{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px}.gift-sheet__type{background:var(--bg-elev-2);border:1.5px solid transparent;border-radius:var(--radius-sm);padding:14px 6px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;font:inherit;color:var(--text);transition:border-color .15s,transform .12s,background .15s}.gift-sheet__type:active{transform:scale(.96)}.gift-sheet__type.is-active{border-color:var(--primary);background:var(--primary-soft)}.gift-sheet__type .emj{font-size:28px;line-height:1}.gift-sheet__type .lbl{font-size:14px;font-weight:600}.gift-sheet__upload{border:1.5px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center;color:var(--text-mute);cursor:pointer;margin-bottom:14px;background:var(--bg)}.gift-sheet__upload .ic{font-size:32px}.gift-sheet__upload .lbl{font-size:14px;margin-top:6px}.gift-sheet__price-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}.gift-sheet__price-row label{font-size:14px;color:var(--text-mute);flex:1}.gift-sheet__price-row input{width:100px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font:inherit;font-size:15px;font-weight:700;color:var(--primary);text-align:right;outline:none}.gift-sheet__send{width:100%;display:block;text-align:center;background:var(--gift-ring);color:var(--on-primary);border:0;padding:14px;border-radius:var(--radius);font:inherit;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 4px 14px rgba(var(--primary-rgb),.3)}.gift-sheet__send:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}@media (prefers-reduced-motion: reduce){.gift-sheet-mask,.gift-sheet{animation:none}.gift-sheet__type:active{transform:none}}.friend-code-card{display:flex;flex-direction:column;gap:10px;padding:18px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius)}.friend-code-card__label{font-size:14px;color:var(--text-mute);font-weight:600}.friend-code-card__value-row{display:flex;align-items:center;gap:10px}.friend-code-card__value{font-size:24px;font-weight:800;background:var(--ring-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.01em;flex:1}.friend-code-card__copy{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:999px;padding:6px 14px;font:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,transform .12s}.friend-code-card__copy:active{transform:scale(.97)}.friend-code-card__copy.is-copied{background:var(--success-soft);color:var(--success)}.friend-code-card__hint{font-size:12px;color:var(--text-mute);line-height:1.5}.friend-add-input{width:100%;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;font:inherit;font-size:15px;color:var(--text);outline:none;font-feature-settings:"tnum"}.friend-add-input:focus{border-color:var(--primary)}.chat-input-v3{position:relative;flex:0 0 auto;border-top:1px solid var(--divider);background:var(--bg);padding-bottom:env(safe-area-inset-bottom)}.chat-input-v3__editor{padding:10px 14px 6px}.chat-input-v3__editor textarea{width:100%;background:var(--bg-elev-2);border:0;border-radius:18px;padding:10px 14px;font:inherit;font-size:16px;line-height:1.4;color:var(--text);resize:none;max-height:120px;min-height:40px;outline:none;transition:background .15s,box-shadow .15s}.chat-input-v3__editor textarea:focus{background:var(--bg-elev);box-shadow:inset 0 0 0 1.5px var(--primary)}.chat-input-v3__actions{display:flex;align-items:center;gap:4px;padding:4px 8px 10px}.chat-input-v3__btn{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:transparent;border:0;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;font-size:22px;-webkit-tap-highlight-color:transparent;transition:background .15s,transform .12s,color .15s}.chat-input-v3__btn:hover{background:var(--bg-elev-2)}.chat-input-v3__btn:active{transform:scale(.92)}.chat-input-v3__btn--plus{background:var(--bg-elev-2);border:1px solid var(--border);font-size:20px;font-weight:600;transition:transform .18s cubic-bezier(.16,1,.3,1),background .15s,color .15s,border-color .15s}.chat-input-v3__btn--plus.is-open{background:var(--ring-grad);color:var(--on-primary);border-color:transparent;transform:rotate(45deg)}.chat-input-v3__btn--game{font-size:22px}.chat-input-v3__btn--gift{background:var(--ring-grad);color:var(--on-primary);font-size:18px;box-shadow:0 2px 6px rgba(var(--primary-rgb),.25)}.chat-input-v3__btn--gift.is-disabled{opacity:.4;pointer-events:none;background:var(--bg-elev-2);color:var(--text-mute);box-shadow:none}.chat-input-v3__spacer{flex:1}.chat-input-v3__send{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--ring-grad);border:0;color:var(--on-primary);font-size:16px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:opacity .15s,transform .12s}.chat-input-v3__send:disabled,.chat-input-v3__send.is-disabled{opacity:.35;cursor:not-allowed;background:var(--bg-elev-2);color:var(--text-mute)}.chat-input-v3__send:active{transform:scale(.92)}.attach-popup{position:absolute;bottom:56px;left:12px;min-width:168px;background:var(--bg-elev);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:6px;z-index:20;animation:apRise .18s cubic-bezier(.16,1,.3,1);transform-origin:bottom left}.attach-popup[hidden]{display:none}@keyframes apRise{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.attach-popup__row{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;cursor:pointer;font:inherit;color:var(--text);background:none;border:0;width:100%;text-align:left;-webkit-tap-highlight-color:transparent}.attach-popup__row:hover{background:var(--bg-elev-2)}.attach-popup__row .emj{font-size:20px;line-height:1}.attach-popup__row .lbl{font-size:15px;font-weight:600;flex:1}@media (prefers-reduced-motion: reduce){.attach-popup{animation:none}.chat-input-v3__btn,.chat-input-v3__btn--plus,.chat-input-v3__send{transition:none}}.chat-input-v3>.scroll-bottom-btn{position:absolute;inset:-52px 14px auto auto;width:40px;height:40px;border-radius:50%;background:var(--bg-elev);border:1px solid var(--border);color:var(--text);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px #00000040;cursor:pointer;font-size:18px;z-index:5;animation:sbIn .18s ease-out}.chat-input-v3>.scroll-bottom-btn[hidden]{display:none}@keyframes sbIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-input-v3>.scroll-bottom-btn .scroll-bottom-btn__badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;background:var(--ring-grad);color:var(--on-primary);font-size:11px;font-weight:800;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;line-height:1}.chat-input-v3>.scroll-bottom-btn .scroll-bottom-btn__badge[hidden]{display:none}.puzzle-bubble-preview{width:88%;max-width:320px;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;position:relative;align-self:flex-start}.puzzle-bubble-preview.me{align-self:flex-end;background:var(--primary);color:var(--on-primary)}.puzzle-bubble-preview.other{align-self:flex-start;background:var(--bg-elev-2);color:var(--text)}.pbp__head{padding:10px 12px 6px;display:flex;align-items:center;gap:8px}.pbp__icon{font-size:15px}.pbp__title{font-size:14px;font-weight:800;flex:1}.pbp__diff{display:inline-flex;align-items:center;font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;color:#fff}.pbp__diff.is-easy{background:var(--diff-easy)}.pbp__diff.is-normal{background:var(--diff-normal)}.pbp__diff.is-hard{background:var(--diff-hard)}.pbp__diff.is-expert{background:var(--diff-expert-grad)}.puzzle-bubble-preview.me .pbp__diff.is-hard{background:#ffffff38;color:#fff;box-shadow:inset 0 0 0 1px #ffffff80}.pbp__meta{padding:0 12px 10px;display:flex;flex-wrap:wrap;gap:5px}.pbp__chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:#ffffff38}.puzzle-bubble-preview.other .pbp__chip{background:#0000000f;color:var(--text)}.puzzle-bubble-preview__thumb{display:block;width:100%;height:200px;object-fit:cover;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08);cursor:pointer}.pbp__thumb-wrap{position:relative;width:100%;height:200px;overflow:hidden;cursor:pointer}.pbp__thumb-wrap .puzzle-bubble-preview__thumb{width:100%;height:100%;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08);cursor:pointer}.pbp__thumb-wrap.is-locked .puzzle-bubble-preview__thumb{filter:blur(18px) brightness(.78);transform:scale(1.08)}.lock-scrim{position:absolute;inset:0;background:linear-gradient(180deg,#0000001a,#00000059 60%,#00000080);display:flex;align-items:center;justify-content:center}.lock-scrim__play{width:52px;height:52px;border-radius:50%;background:var(--ring-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 6px 20px #ff4d8d80}.puzzle-bubble-preview__cta{padding:10px 12px;background:#ffffff1f;border-top:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s;border:0;color:inherit}.puzzle-bubble-preview.other .puzzle-bubble-preview__cta{background:#0000000a;border-top:1px solid rgba(0,0,0,.06);color:var(--text)}.puzzle-bubble-preview__cta:hover{background:#fff3}.puzzle-bubble-preview.other .puzzle-bubble-preview__cta:hover{background:#00000014}.puzzle-bubble-preview__cta.is-solved{background:#34a8532e;color:#1e7a3c}.puzzle-bubble-preview.me .puzzle-bubble-preview__cta.is-solved{background:#34a85352;color:#fff}.pbp__cta-emj{font-size:14px}.pbp__cta-lbl{font-weight:700}.pbp__cta-time{font-size:11px;font-weight:600;opacity:.8;margin-left:4px}.pbp__foot{padding:6px 12px 10px;font-size:11px;opacity:.75;display:flex;justify-content:flex-end;gap:6px}.delta-line{align-self:flex-end;background:#34a85326;color:#1e7a3c;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;margin-top:-4px;animation:deltaLineFade 1.5s ease-in forwards}@keyframes deltaLineFade{0%{opacity:0;transform:translateY(4px)}15%{opacity:1;transform:translateY(0)}85%{opacity:1}to{opacity:0;transform:translateY(-4px)}}.pbp__thumb-zoom{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#00000073;backdrop-filter:blur(6px);color:#fff;border:0;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .15s,transform .12s}.pbp__thumb-zoom:hover{background:#0009}.pbp__thumb-zoom:active{transform:scale(.92)}.image-viewer{position:fixed;inset:0;z-index:1000;background:#000000eb;display:flex;flex-direction:column;animation:viewerFadeIn .22s ease-out}@keyframes viewerFadeIn{0%{opacity:0}to{opacity:1}}.image-viewer__head{display:flex;align-items:center;gap:10px;padding:14px 14px 10px;color:#fff}.image-viewer__close,.image-viewer__action{width:36px;height:36px;border-radius:50%;background:#ffffff1a;color:#fff;border:0;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:background .15s}.image-viewer__close:hover,.image-viewer__action:hover{background:#ffffff2e}.image-viewer__title{flex:1;min-width:0;font-size:15px;font-weight:700;display:flex;flex-direction:column;gap:2px}.image-viewer__title .sub{font-size:11px;font-weight:500;opacity:.85;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-viewer__status.is-waiting{opacity:.9}.image-viewer__status.is-solved{color:#7ee7a3;font-weight:800}.image-viewer__body{flex:1 1 0;min-height:0;display:flex;align-items:center;justify-content:center;padding:8px 14px}.image-viewer__body img{max-width:100%;max-height:100%;object-fit:contain;display:block;touch-action:pinch-zoom}.image-viewer__foot{display:flex;flex-wrap:wrap;gap:6px;padding:12px 14px 18px;justify-content:center}.image-viewer__chip{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:#ffffff26;color:#fff}.image-viewer__chip.is-easy{background:#34a8534d}.image-viewer__chip.is-normal{background:#f59e0b4d}.image-viewer__chip.is-hard{background:#ff7a594d}.image-viewer__chip.is-expert{background:var(--diff-expert-grad)}.image-viewer__chip.is-solved{background:#34a85352;color:#7ee7a3}.rc-body{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:20px}.rc-section{display:flex;flex-direction:column;gap:10px}.rc-h{font-size:14px;font-weight:800;color:var(--text);margin:0}.rc-mission-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.rc-mission-card{background:var(--bg-elev-2);border:2px solid transparent;border-radius:14px;padding:16px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;text-align:center;font:inherit;color:var(--text);position:relative;transition:background .15s,border-color .15s,transform .12s}.rc-mission-card:active{transform:scale(.97)}.rc-mission-card.is-active{background:var(--primary-soft);border-color:var(--primary)}.rc-mission-card.is-active .lbl{color:var(--primary)}.rc-mission-card.is-disabled{opacity:.55;cursor:not-allowed}.rc-mission-card .emj{font-size:32px;line-height:1}.rc-mission-card .lbl{font-size:13px;font-weight:800;color:var(--text)}.rc-mission-card .soon{position:absolute;top:6px;right:6px;font-size:9px;font-weight:800;background:var(--bg-elev);color:var(--text-mute);padding:2px 6px;border-radius:999px;letter-spacing:.02em}.rc-upload{background:var(--bg-elev-2);border:2px dashed var(--border);border-radius:12px;padding:24px 12px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}.rc-upload.has-image{padding:0;border:0;overflow:hidden}.rc-upload-btn{background:var(--bg-elev);border:1px solid var(--border);border-radius:10px;padding:10px 18px;font-size:13px;font-weight:700;color:var(--text);cursor:pointer}.rc-upload img{width:100%;max-height:200px;object-fit:cover;border-radius:12px;display:block}.rc-row{display:flex;align-items:center;gap:10px;padding:8px 0}.rc-row label{font-size:13px;font-weight:700;color:var(--text);flex:1}.rc-row input[type=number],.rc-row select{flex:0 0 auto;height:36px;padding:0 12px;border-radius:10px;border:1px solid var(--border);background:var(--bg-elev);color:var(--text);font:inherit;font-size:14px}.rc-access-options{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;background:var(--bg-elev-2);border-radius:10px;padding:4px}.rc-access-options label{display:flex;align-items:center;justify-content:center;padding:8px 0;border-radius:8px;cursor:pointer;font-size:12px;font-weight:700;color:var(--text)}.rc-access-options label:has(input:checked){background:var(--bg-elev);color:var(--primary);box-shadow:0 2px 6px #00000014}.rc-access-options input{display:none}.rc-footer{padding:14px;border-top:1px solid var(--divider);background:var(--bg)}.rc-footer .btn-primary{width:100%;height:48px;border-radius:12px;background:var(--primary);color:var(--on-primary);border:0;font-size:15px;font-weight:700;cursor:pointer}.rc-footer .btn-primary:disabled{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed}.rr-tabs{display:flex;border-bottom:1px solid var(--divider);background:var(--bg)}.rr-tab{flex:1;padding:12px 0;background:transparent;border:0;font:inherit;font-size:14px;font-weight:700;color:var(--text-mute);cursor:pointer;position:relative}.rr-tab.is-active{color:var(--primary)}.rr-tab.is-active:after{content:"";position:absolute;bottom:-1px;left:12px;right:12px;height:2px;background:var(--primary);border-radius:2px}.rr-body{flex:1;overflow-y:auto;padding:14px}.rr-list{list-style:none;margin:0;padding:0}.rr-list li{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--divider);cursor:pointer}.rr-list .rr-av{width:40px;height:40px;border-radius:50%;background:var(--ring-grad);color:var(--on-primary);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;overflow:hidden}.rr-list .rr-av img{width:100%;height:100%;object-fit:cover}.rr-list .rr-info{flex:1}.rr-list .rr-name{font-size:14px;font-weight:700;color:var(--text)}.rr-list .rr-handle{font-size:11px;color:var(--text-mute)}.rr-list input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary)}#searchInput{width:100%;height:40px;padding:0 12px;border:1px solid var(--border);border-radius:10px;background:var(--bg-elev);color:var(--text);font:inherit;font-size:14px;margin-bottom:12px}.rr-qr-card{text-align:center;padding:24px;background:var(--bg-elev);border-radius:14px}.rr-qr-card canvas{width:200px;height:200px;background:#fff;padding:12px;border-radius:10px;margin:0 auto 14px;display:block}.rr-qr-card p{font-size:12px;color:var(--text-mute);margin:0}.rr-footer{padding:12px 14px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--divider);background:var(--bg);display:flex;align-items:center;gap:10px}.rr-count{flex:1;font-size:13px;color:var(--text-mute)}.rr-footer .btn-primary{flex:0 0 auto;height:44px;padding:0 24px;border-radius:12px;background:var(--primary);color:var(--on-primary);border:0;font-size:14px;font-weight:700;cursor:pointer}.rr-footer .btn-primary:disabled{background:var(--bg-elev-2);color:var(--text-mute);cursor:not-allowed}.rcard{width:84%;max-width:300px;align-self:flex-start;background:var(--bg-elev);border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;position:relative}.rcard.me{align-self:flex-end}.rcard.other{align-self:flex-start}.rcard__head{padding:12px 14px 10px;color:#fff;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden}.rcard__head.image{background:var(--mission-image)}.rcard__head.puzzle{background:var(--mission-puzzle)}.rcard__head.video{background:var(--mission-video)}.rcard__head.paid{background:var(--mission-paid)}.rcard__head:after{content:"";position:absolute;right:-20px;top:-20px;width:100px;height:100px;background:radial-gradient(circle,rgba(255,255,255,.2),transparent 70%);pointer-events:none}.rcard__type-row{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;opacity:.9}.rcard__title{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:800;letter-spacing:-.2px}.rcard__title-emj{font-size:22px}.rcard__body{padding:14px}.rcard__sender{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-mute);margin-bottom:10px}.rcard__sender-av{width:22px;height:22px;border-radius:50%;background:var(--ring-grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0;overflow:hidden}.rcard__sender-av img{width:100%;height:100%;object-fit:cover}.rcard__sender b{color:var(--text);font-weight:700}.rcard__meta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}.rcard__chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;background:var(--bg-elev-2);color:var(--text)}.rcard__chip.is-reward{background:var(--primary-soft);color:var(--primary);font-weight:800}.rcard__chip.is-reward .num{font-size:13px;font-weight:900;letter-spacing:-.3px}.rcard__cta{display:flex;gap:6px}.rcard__btn{flex:1;height:40px;border:0;border-radius:12px;font:inherit;font-size:14px;font-weight:800;cursor:pointer}.rcard__btn--decline{background:var(--bg-elev-2);color:var(--text)}.rcard__btn--accept{background:var(--ring-grad);color:#fff;box-shadow:0 4px 12px #ff7a5952}.rcard__btn:disabled{opacity:.55;cursor:not-allowed}.rcard__btn--perform{width:100%;margin-top:10px;height:40px;border:0;border-radius:12px;background:var(--ring-grad);color:#fff;font:inherit;font-size:14px;font-weight:800;cursor:pointer;box-shadow:0 4px 12px #ff7a5952}.rcard__result{padding:12px 14px;border-radius:12px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px}.rcard__result.is-accepted{background:#34a8531f;color:var(--status-accepted)}.rcard__result.is-declined{background:var(--bg-elev-2);color:var(--status-declined)}.rcard__result.is-expired{background:var(--bg-elev-2);color:var(--status-expired)}.rcard.is-declined .rcard__head{filter:grayscale(.5);opacity:.8}.rcard.is-declined .rcard__chip.is-reward{background:var(--bg-elev-2);color:var(--text-mute)}.rcard.is-expired{filter:grayscale(.7);opacity:.7;pointer-events:none}.rcard.is-expired .rcard__chip.is-reward{background:var(--bg-elev-2);color:var(--text-mute)}
