:root{--font-display:"Outfit", sans-serif;--font-body:"Noto Sans SC", sans-serif;--radius-sm:12px;--radius:18px;--radius-lg:24px;--radius-full:9999px;--transition:.35s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--bg:#0f0f12;--surface:#ffffff0d;--surface-hover:#ffffff14;--border:#ffffff14;--text:#f0f0f2;--text-dim:#f0f0f280;--accent:#f5b842;--accent-soft:#f5b8421f;--accent-mid:#f5b84238;--shadow:0 4px 20px #0000004d;--shadow-hover:0 8px 40px #0006}[data-theme=light]{--bg:#f8f6f1;--surface:#fff9;--surface-hover:#ffffffd9;--border:#0000000f;--text:#1a1a1a;--text-dim:#1a1a1a73;--accent:#ef9f27;--accent-soft:#ef9f271a;--accent-mid:#ef9f2733;--shadow:0 4px 20px #00000014;--shadow-hover:0 8px 40px #0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100dvh;font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;font-size:16px;line-height:1.6;transition:background .4s,color .4s;overflow-x:hidden}::-webkit-scrollbar{background:0 0;width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:999px}::selection{background:var(--accent-mid);color:var(--text)}#bg{z-index:0;background:var(--bg);transition:background .4s;position:fixed;inset:0}#bg:before{content:"";background:radial-gradient(ellipse 80% 50% at 10% 0%, var(--accent-soft) 0%, transparent 50%), radial-gradient(ellipse 60% 40% at 90% 100%, var(--accent-soft) 0%, transparent 50%);opacity:.6;z-index:0;pointer-events:none;position:fixed;inset:0}#bg:after{content:"";background-image:radial-gradient(var(--border) 1px, transparent 1px);opacity:.5;z-index:0;pointer-events:none;background-size:28px 28px;position:fixed;inset:0}#bg-img,#bg-grad{display:none}.bg-blobs{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.bg-blob{filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.bg-blob-1{background:linear-gradient(135deg, var(--accent), var(--accent-mid));width:400px;height:400px;animation:25s ease-in-out infinite blobFloat1;top:-100px;right:-80px}.bg-blob-2{background:linear-gradient(135deg,#0d9488,#0f766e);width:300px;height:300px;animation:30s ease-in-out infinite blobFloat2;bottom:-80px;left:5%}@keyframes blobFloat1{0%,to{transform:translate(0)scale(1)}25%{transform:translate(-40px,60px)scale(1.1)}50%{transform:translate(20px,40px)scale(.9)}75%{transform:translate(-20px,-20px)scale(1.05)}}@keyframes blobFloat2{0%,to{transform:translate(0)scale(1)}30%{transform:translate(50px,-30px)scale(1.15)}60%{transform:translate(-30px,40px)scale(.85)}80%{transform:translate(30px,20px)scale(1.1)}}#app{z-index:1;flex-direction:column;height:100dvh;display:flex;position:relative;overflow:hidden}header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:48px 18px 14px;display:flex;position:relative}.hdr-left{align-items:center;gap:12px;display:flex}.hdr-right{align-items:center;gap:10px;display:flex}.hdr-ava{border:2px solid var(--border);width:42px;height:42px;box-shadow:var(--shadow);border-radius:50%;flex-shrink:0;transition:border-color .3s;overflow:hidden}.hdr-ava:hover{border-color:var(--accent-mid)}.hdr-ava img{object-fit:cover;width:100%;height:100%;display:block}.hdr-name{font-family:var(--font-display);color:var(--text);letter-spacing:.04em;font-size:16px;font-weight:600}.hdr-sub{color:var(--text-dim);margin-top:2px;font-size:11px}.usage-pill{color:var(--text-dim);background:var(--surface);border:1px solid var(--border);letter-spacing:.03em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;padding:10px 14px;font-size:11px;transition:color .3s,border-color .3s,background .3s}.usage-pill.warn{color:var(--accent);border-color:var(--accent-mid)}.icon-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:15px;text-decoration:none;transition:all .3s;display:flex}.icon-btn:hover{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent)}.icon-btn svg{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.icon-btn:hover svg{transform:scale(1.15)rotate(8deg)}.theme-toggle-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .3s;display:flex;position:relative}.theme-toggle-btn:hover{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent);box-shadow:0 0 12px var(--accent-soft)}.theme-toggle-btn:active{transform:scale(.96)}.theme-toggle-btn svg{width:20px;height:20px;transition:all .5s cubic-bezier(.4,0,.2,1);position:absolute}.theme-sun{opacity:1;transform:scale(1)rotate(0)}.sun-rays{transform-origin:12px 12px}.theme-toggle-btn.dark .theme-sun{opacity:0;transform:scale(.5)rotate(45deg)}.theme-moon{opacity:0;transform:scale(.5)rotate(-30deg)}.theme-toggle-btn.dark .theme-moon{opacity:1;transform:scale(1)rotate(0)}.theme-toggle-btn:hover .theme-sun,.theme-toggle-btn:hover .theme-moon{transform:scale(1.15)rotate(8deg)}.theme-toggle-btn.dark:hover .theme-sun{opacity:0;transform:scale(.5)rotate(45deg)}.theme-toggle-btn.dark:hover .theme-moon{opacity:1;transform:scale(1.15)rotate(8deg)}.icon-btn:active{transform:scale(.96)}#messages{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex-direction:column;flex:1;gap:6px;padding:16px 18px 8px;display:flex;overflow:hidden auto}#messages::-webkit-scrollbar{display:none}.msg-row{flex-direction:column;gap:0;animation:.35s cubic-bezier(.4,0,.2,1) fadeUp;display:flex}.msg-row.user{align-items:flex-end}.msg-row.assistant{align-items:flex-start}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.ai-row{align-items:flex-end;gap:10px;max-width:86%;display:flex}.ai-ava{border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;width:30px;height:30px;transition:border-color .3s;overflow:hidden}.ai-ava:hover{border-color:var(--accent-mid)}.ai-ava img{object-fit:cover;width:100%;height:100%;display:block}.ai-ava.hidden{visibility:hidden}.bubble{border-radius:var(--radius);word-break:break-word;white-space:pre-wrap;-webkit-backdrop-filter:blur(24px);margin-bottom:4px;padding:12px 16px;font-size:15px;line-height:1.7;transition:box-shadow .3s}.user .bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow);border-bottom-right-radius:4px;max-width:78vw}.user .bubble:hover{box-shadow:var(--shadow-hover)}.ai-bubbles-wrap .bubble{background:var(--surface);border:1px solid var(--border);color:var(--text);box-shadow:var(--shadow);border-bottom-left-radius:4px}.ai-bubbles-wrap .bubble:hover{box-shadow:var(--shadow-hover)}.act{color:var(--accent);font-size:13.5px;font-style:italic}.ts{color:var(--text-dim);text-align:center;letter-spacing:.04em;margin:6px 0 2px;font-size:11px}.err{color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:10px 14px;font-size:12px}.summary-tag{color:var(--text-dim);text-align:center;letter-spacing:.06em;margin:8px 0;font-size:11px}.think-wrap{max-width:calc(86% - 40px);margin-bottom:6px;margin-left:40px}.think-toggle{color:var(--text-dim);cursor:pointer;touch-action:manipulation;-webkit-user-select:none;user-select:none;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;gap:6px;padding:4px 10px;font-size:11.5px;transition:all .3s;display:inline-flex}.think-toggle:hover{border-color:var(--accent-mid);color:var(--accent)}.t-arrow{opacity:.5;width:12px;height:12px;transition:transform .25s}.think-toggle.open .t-arrow{transform:rotate(90deg)}.t-dot{background:var(--accent);opacity:.65;border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}.think-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-dim);white-space:pre-wrap;word-break:break-word;-webkit-overflow-scrolling:touch;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);max-height:220px;margin-top:8px;padding:12px 14px;font-size:12px;line-height:1.72;display:none;overflow-y:auto}.think-body.open{display:block}.typing-bubble{align-items:flex-end;gap:10px;max-width:86%;margin-bottom:4px;animation:.3s fadeUp;display:flex}.typing-bubble .bub{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom-left-radius:4px;align-items:center;gap:5px;padding:14px 18px;display:flex}.typing-bubble .bub span{background:var(--accent);border-radius:50%;width:5px;height:5px;animation:1.2s ease-in-out infinite pulse}.typing-bubble .bub span:nth-child(2){animation-delay:.15s}.typing-bubble .bub span:nth-child(3){animation-delay:.3s}footer{padding:10px 16px 20px;padding-bottom:max(20px, env(safe-area-inset-bottom));border-top:1px solid var(--border);background:linear-gradient(to top, var(--bg) 60%, transparent);flex-shrink:0;position:relative}.toolbar{align-items:flex-end;gap:10px;display:flex}.inp-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex:1;padding:12px 18px;transition:border-color .3s,box-shadow .3s}.inp-wrap:focus-within{border-color:var(--accent-mid);box-shadow:0 0 0 3px var(--accent-soft)}#input{width:100%;font-family:var(--font-body);color:var(--text);resize:none;-webkit-appearance:none;background:0 0;border:none;outline:none;max-height:100px;font-size:16px;line-height:1.5;display:block}#input::placeholder{color:var(--text-dim)}.send-btn{background:var(--surface);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;width:44px;height:44px;box-shadow:var(--shadow);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .3s,border-color .3s,box-shadow .3s;display:flex}.send-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--accent), var(--accent-mid));box-shadow:var(--shadow-hover), 0 0 20px var(--accent-soft);border-color:#0000}.send-btn svg{transition:transform .3s}.send-btn:hover:not(:disabled) svg{transform:translate(3px)}.send-btn:active{transform:scale(.96)}.send-btn:disabled{opacity:.3;box-shadow:none}.send-btn svg{width:18px;height:18px;stroke:var(--text)}.send-btn:hover:not(:disabled) svg{stroke:#fff}#welcome{pointer-events:none;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:10px;padding:0 24px 28px;display:flex}#welcome .w-ava{border:2px solid var(--border);width:72px;height:72px;box-shadow:var(--shadow);border-radius:50%;margin-bottom:6px;transition:border-color .3s,box-shadow .3s;overflow:hidden}#welcome .w-ava:hover{border-color:var(--accent-mid);box-shadow:0 0 30px var(--accent-soft)}#welcome .w-ava img{object-fit:cover;width:100%;height:100%;display:block}#welcome .wname{font-family:var(--font-display);color:var(--text);letter-spacing:.1em;font-size:28px;font-weight:700}#welcome .wsub{color:var(--text-dim);letter-spacing:.08em;font-size:13px}.select-page{background:var(--bg);min-height:100dvh;color:var(--text);position:relative}.sel-nav{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#0f0f12b3;justify-content:space-between;align-items:center;height:60px;padding:0 24px;display:flex;position:fixed;top:0;left:0;right:0}[data-theme=light] .sel-nav{background:#f8f6f1b3}.sel-logo{font-family:var(--font-display);letter-spacing:.08em;color:var(--text);align-items:center;font-size:18px;font-weight:600;display:flex;position:relative}.sel-logo-icon{border-radius:4px;flex-shrink:0;width:20px;height:20px;margin:0;display:block;position:absolute;top:50%;left:-9px;transform:translateY(-50%)}.sel-logo-text{margin-left:26px}.sel-icon-btn{background:var(--surface);border:1px solid var(--border);width:36px;height:36px;color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;justify-content:center;align-items:center;padding:0;font-size:15px;text-decoration:none;transition:all .3s;display:flex}.sel-icon-btn svg{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.sel-icon-btn:hover svg{transform:scale(1.15)rotate(8deg)}.sel-icon-btn:hover{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent)}.sel-icon-btn:active{transform:scale(.96)}.sel-main{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:100dvh;padding:100px 20px 40px;display:flex}.sel-title{font-family:var(--font-display);letter-spacing:.15em;color:var(--text-dim);text-transform:uppercase;margin-bottom:8px;font-size:13px}.cards{justify-content:center;gap:24px;width:100%;max-width:600px;display:flex}.card{border-radius:var(--radius-lg);cursor:pointer;aspect-ratio:3/4;background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex:1;min-width:140px;max-width:260px;transition:border-color .3s,box-shadow .3s;position:relative;overflow:hidden}.card:hover{border-color:var(--accent-mid);box-shadow:0 20px 50px var(--shadow), 0 0 40px var(--accent-soft)}.card img{transition:transform .5s}.card:hover img{transform:scale(1.04)}.card:active{transform:scale(.98)}.card:before{content:"";opacity:0;z-index:1;pointer-events:none;background:linear-gradient(135deg,#ffffff0f 0%,#0000 50%);transition:opacity .4s;position:absolute;inset:0}.card:hover:before{opacity:1}.card-img{opacity:.7;background-position:top;background-size:cover;transition:opacity .4s;position:absolute;inset:0}.card:hover .card-img{opacity:.85}.card-overlay{background:linear-gradient(to bottom, transparent 35%, var(--bg) 100%);position:absolute;inset:0}.card-info{z-index:2;padding:24px 20px;position:absolute;bottom:0;left:0;right:0}.card-name{font-family:var(--font-display);color:var(--text);letter-spacing:.04em;margin-bottom:4px;font-size:22px;font-weight:700}.card-desc{color:var(--text-dim);letter-spacing:.05em;margin-bottom:16px;font-size:12px}.card-btn{font-size:12px;font-family:var(--font-body);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(12px);color:var(--text);cursor:pointer;letter-spacing:.04em;touch-action:manipulation;padding:8px 18px;transition:all .3s;display:inline-block}.card:hover .card-btn{background:var(--surface-hover);border-color:var(--accent-mid);color:var(--accent);box-shadow:0 4px 15px var(--accent-soft)}@media (width<=400px){.cards{flex-direction:column;align-items:center}.card{width:100%;max-width:320px}}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0f0f1299;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}[data-theme=light] .modal-overlay{background:#f8f6f199}.modal-overlay.hidden{display:none}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);width:100%;max-width:340px;box-shadow:var(--shadow-hover);flex-direction:column;align-items:center;gap:28px;padding:40px 32px;display:flex}.modal-title{font-family:var(--font-display);color:var(--text);letter-spacing:.06em;font-size:22px;font-weight:700}.modal-sub{color:var(--text-dim);text-align:center;letter-spacing:.03em;margin-top:-20px;font-size:13px}.modal-btns{gap:12px;width:100%;display:flex}.modal-btn{border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font-body);cursor:pointer;touch-action:manipulation;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);flex:1;padding:14px 0;font-size:15px;transition:all .3s}.modal-btn:hover{border-color:var(--accent-mid);background:var(--surface-hover)}.modal-btn:active{transform:scale(.96)}.modal-btn.selected{background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;box-shadow:0 4px 15px var(--accent-soft);border-color:#0000}.sel-nav-right{align-items:center;gap:10px;display:flex}.user-pill{background:var(--surface);border:1px solid var(--border);height:36px;color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:10px;align-items:center;gap:8px;padding:0 12px 0 6px;font-size:13px;display:flex}.user-pill>button:not(.sel-icon-btn){color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.user-pill>button:not(.sel-icon-btn):hover{color:var(--accent)}.user-pill-avatar{object-fit:cover;border-radius:50%;flex-shrink:0;width:24px;height:24px}.user-pill-initial{background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:600;display:flex}.user-pill-level{background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;border-radius:10px;margin-left:2px;padding:1px 6px;font-size:10px;font-weight:600}.login-modal-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000080;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.login-modal{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:360px;box-shadow:var(--shadow-hover);padding:28px;animation:.25s scaleIn}.login-modal h3{font-family:var(--font-display);color:var(--text);text-align:center;margin-bottom:20px;font-size:20px;font-weight:600}.login-modal input{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);width:100%;color:var(--text);outline:none;margin-bottom:12px;padding:12px 16px;font-size:15px;transition:border-color .3s}.login-modal input:focus{border-color:var(--accent-mid)}.login-modal .gender-select{color:var(--text);gap:20px;margin-bottom:12px;font-size:14px;display:flex}.radio-label{cursor:pointer;color:var(--text);align-items:center;gap:8px;font-size:14px;display:flex}.radio-label input{opacity:0;width:0;height:0;position:absolute}.radio-dot{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .2s;display:flex}.radio-dot:after{content:"";background:var(--accent);border-radius:50%;width:8px;height:8px;transition:transform .2s;transform:scale(0)}.radio-label input:checked+.radio-dot{border-color:var(--accent)}.radio-label input:checked+.radio-dot:after{transform:scale(1)}.login-modal .error{color:#ef4444;text-align:center;margin-bottom:12px;font-size:13px}.login-modal button[type=submit]{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;cursor:pointer;border:none;width:100%;padding:14px;font-size:15px;font-weight:600;transition:opacity .3s,transform .2s}.login-modal button[type=submit]:hover{opacity:.9}.login-modal button[type=submit]:active{transform:scale(.98)}.login-modal button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.login-modal .link{text-align:center;width:100%;color:var(--accent);cursor:pointer;background:0 0;border:none;margin-top:14px;font-size:13px;display:block}.login-modal .link:hover{text-decoration:underline}.login-modal .forgot-link{text-align:left;width:auto;margin-top:4px;margin-bottom:8px}.login-modal-links{justify-content:center;gap:12px;display:flex}.login-modal .success{color:#22c55e;text-align:center;margin-bottom:12px;font-size:13px}.admin-verify-method{border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text-sec);cursor:pointer;flex:1;padding:10px;font-size:14px;transition:all .15s}.admin-verify-method.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.settings-verify-status.error{color:#ef4444}.admin-steps{border-bottom:1px solid var(--border);justify-content:center;align-items:center;gap:8px;margin-bottom:24px;padding-bottom:16px;display:flex}.admin-step{color:var(--text-dim);align-items:center;gap:6px;font-size:13px;transition:color .3s;display:flex}.admin-step.active{color:var(--accent)}.admin-step-num{background:var(--surface);border:1.5px solid var(--border);border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:600;transition:all .3s;display:flex}.admin-step.active .admin-step-num{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.admin-step-line{background:var(--border);border-radius:1px;width:32px;height:1.5px}.admin-overlay{z-index:2000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#000000bf;justify-content:center;align-items:center;animation:.4s adminFadeIn;display:flex;position:fixed;inset:0}.admin-modal{background:linear-gradient(#1a1a1a 0%,#0f0f0f 100%);border:1px solid #fbbf2426;border-radius:20px;width:90%;max-width:420px;padding:40px 32px 32px;animation:.5s cubic-bezier(.16,1,.3,1) adminScaleIn;position:relative;overflow:hidden;box-shadow:0 0 0 1px #fbbf240d,0 20px 60px #0009,0 0 80px #fbbf240f}.admin-modal-glow{background:linear-gradient(90deg,#0000,#fbbf24,#f59e0b,#fbbf24,#0000) 0 0/200% 100%;height:2px;animation:3s linear infinite adminGlowFlow;position:absolute;top:0;left:0;right:0}.admin-modal-scan{pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#fbbf2404 2px 4px);position:absolute;inset:0}@keyframes adminGlowFlow{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes adminFadeIn{0%{opacity:0}to{opacity:1}}@keyframes adminScaleIn{0%{opacity:0;transform:scale(.88)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.admin-modal-close{color:#ffffff59;cursor:pointer;background:#ffffff0a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:14px;right:14px}.admin-modal-close:hover{color:#ffffffb3;background:#ffffff14}.admin-modal-icon{color:#fbbf24;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 20px;display:flex;position:relative}.admin-icon-ring{border:1.5px solid #fbbf2433;border-radius:50%;animation:2.5s ease-out infinite adminRingPulse;position:absolute;inset:0}.admin-icon-ring.delay{animation-delay:1.25s}@keyframes adminRingPulse{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.admin-modal-title{text-align:center;color:#fbbf24;letter-spacing:.08em;text-shadow:0 0 20px #fbbf2433;margin:0 0 6px;font-size:22px;font-weight:700}.admin-modal-desc{text-align:center;color:#ffffff59;letter-spacing:.04em;margin:0 0 28px;font-size:13px}.admin-verify-methods{gap:10px;margin-bottom:20px;display:flex}.admin-verify-method{color:#ffffff73;cursor:pointer;background:#ffffff05;border:1px solid #ffffff14;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 14px;font-size:13px;font-weight:500;transition:all .25s;display:flex}.admin-verify-method:hover{color:#ffffffb3;border-color:#fbbf2440}.admin-verify-method.active{color:#fbbf24;background:#fbbf2414;border-color:#fbbf2480;box-shadow:0 0 20px #fbbf2414}.admin-verify-form{flex-direction:column;gap:14px;display:flex}.admin-input-wrap{position:relative}.admin-input{color:#fbbf24;letter-spacing:.15em;text-align:center;background:#00000059;border:1px solid #ffffff14;border-radius:12px;outline:none;width:100%;padding:14px 18px;font-family:monospace;font-size:16px;font-weight:600;transition:all .3s}.admin-input::placeholder{color:#fff3;letter-spacing:.04em;font-family:system-ui,sans-serif;font-weight:400}.admin-input:focus{border-color:#fbbf2466;box-shadow:0 0 0 3px #fbbf2414,inset 0 0 20px #fbbf2408}.admin-input-cursor{opacity:0;background:#fbbf24;width:2px;height:20px;transition:opacity .2s;animation:1s step-end infinite adminCursorBlink;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.admin-input:focus+.admin-input-cursor{opacity:.6}@keyframes adminCursorBlink{0%,to{opacity:.6}50%{opacity:0}}.admin-verify-hint{text-align:center;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 12px;font-size:13px;display:flex}.admin-verify-hint.success{color:#22c55e;background:#22c55e14}.admin-verify-hint.error{color:#ef4444;background:#ef444414}.admin-verify-actions{gap:10px;margin-top:4px;display:flex}.admin-btn{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:12px 20px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.admin-btn.secondary{color:#ffffff80;background:#ffffff0d;border:1px solid #ffffff14}.admin-btn.secondary:hover{color:#ffffffbf;background:#ffffff14}.admin-btn.primary{color:#000;background:linear-gradient(135deg,#f59e0b,#fbbf24);box-shadow:0 4px 20px #fbbf2440}.admin-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 30px #fbbf2459}.admin-btn.primary:active{transform:translateY(0)scale(.98)}.admin-btn.primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.admin-btn-spinner{border:2px solid #0003;border-top-color:#000;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite adminSpin}@keyframes adminSpin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.settings-page{background:var(--bg);min-height:100dvh;color:var(--text);position:relative}.settings-nav .sel-nav-left{align-items:center;gap:12px;display:flex}.settings-title{font-family:var(--font-display);letter-spacing:.04em;color:var(--text);font-size:18px;font-weight:600}.settings-toast{z-index:200;border-radius:var(--radius);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-hover);align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:500;animation:.35s cubic-bezier(.4,0,.2,1) toastSlide;display:flex;position:fixed;top:76px;left:50%;transform:translate(-50%)}@keyframes toastSlide{0%{opacity:0;transform:translate(-50%)translateY(-12px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.settings-toast.success{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40}.settings-toast.error{color:#ef4444;background:#ef44441f;border:1px solid #ef444440}.settings-layout{min-height:100dvh;padding-top:60px;display:flex}.settings-sidebar{border-right:1px solid var(--border);background:var(--surface);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);flex-direction:column;flex-shrink:0;justify-content:space-between;width:220px;height:calc(100dvh - 60px);padding:24px 12px;display:flex;position:sticky;top:60px}.settings-sidebar-top{flex-direction:column;gap:4px;display:flex}.settings-sidebar-item{color:var(--text-dim);cursor:pointer;text-align:left;-webkit-appearance:none;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:14px;transition:all .2s;display:flex;position:relative}.settings-sidebar-item:hover{background:var(--surface-hover);color:var(--text)}.settings-sidebar-item.active{background:var(--surface-hover);color:var(--accent)}.settings-sidebar-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.settings-sidebar-item.logout{color:var(--text-dim);margin-top:auto}.settings-sidebar-item.logout:hover{color:#ef4444;background:#ef444414}.settings-content{z-index:1;flex:1;width:100%;max-width:720px;margin:0 auto;position:relative}.settings-banner{border-bottom:1px solid var(--border);align-items:center;gap:20px;padding:32px;display:flex}.settings-avatar{background:linear-gradient(135deg, var(--accent), var(--accent-mid));width:64px;height:64px;font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #00000026;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:26px;display:flex}.settings-banner-avatar-wrap{flex-shrink:0;position:relative}.avatar-upload{cursor:pointer;border-radius:50%;flex-shrink:0;position:relative;overflow:hidden}.avatar-upload-img{object-fit:cover;border-radius:50%;width:100%;height:100%;display:block}.avatar-upload-fallback{background:linear-gradient(135deg, var(--accent), var(--accent-mid));width:100%;height:100%;font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #00000026;border-radius:50%;justify-content:center;align-items:center;font-size:26px;display:flex}.avatar-upload-overlay{color:#fff;opacity:0;pointer-events:none;background:#00000080;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;gap:2px;font-size:11px;transition:opacity .2s;display:flex;position:absolute;inset:0}.avatar-upload:hover .avatar-upload-overlay{opacity:1}.settings-avatar-remove{color:#fff;border:2px solid var(--card);cursor:pointer;z-index:2;background:#ef4444;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:transform .15s,background .15s;display:flex;position:absolute;top:-2px;right:-2px}.settings-avatar-remove:hover{background:#dc2626;transform:scale(1.1)}.settings-banner-info{flex-direction:column;gap:6px;display:flex}.settings-banner-name{font-family:var(--font-display);color:var(--text);letter-spacing:.02em;font-size:22px;font-weight:700}.settings-banner-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.settings-badge{background:var(--accent-soft);color:var(--accent);letter-spacing:.02em;border-radius:999px;align-items:center;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.settings-badge.outline{border:1px solid var(--border);color:var(--text-dim);background:0 0}.settings-badge-refresh{background:var(--accent-soft);color:var(--accent);border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;font-weight:500;transition:opacity .2s;display:inline-flex}.settings-badge-refresh:hover{opacity:.85}.settings-refresh-icon{opacity:.7;transition:opacity .2s}.settings-badge-refresh:hover .settings-refresh-icon{opacity:1}.settings-refresh-icon.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.settings-panel{padding:32px}.settings-form{flex-direction:column;gap:20px;display:flex}.settings-section-title{font-family:var(--font-display);color:var(--text);letter-spacing:.02em;margin-bottom:4px;font-size:18px;font-weight:600}.settings-field{flex-direction:column;gap:6px;display:flex}.settings-field label{color:var(--text);opacity:.7;font-size:13px;font-weight:500}.settings-input{background:var(--surface);border:1px solid var(--border);width:100%;height:44px;color:var(--text);font-size:15px;font-family:var(--font-body);-webkit-appearance:none;border-radius:12px;outline:none;padding:0 16px;transition:border-color .2s,box-shadow .2s}.settings-input::placeholder{color:var(--text-dim);opacity:.75}.settings-input:focus{border-color:var(--accent-mid);box-shadow:0 0 0 3px var(--accent-soft)}.settings-input:disabled{opacity:.5;cursor:not-allowed}.settings-input-wrap{align-items:center;display:flex;position:relative}.settings-input-wrap .settings-input{padding-right:44px}.settings-input-eye{width:36px;height:36px;color:var(--text-dim);cursor:pointer;-webkit-appearance:none;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:color .2s,background .2s;display:flex;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.settings-input-eye:hover{color:var(--accent);background:var(--surface-hover)}.settings-radio-group{gap:24px;display:flex}.settings-danger-card{border-radius:var(--radius-lg);background:var(--surface);border:1px solid #ef444433;flex-direction:column;gap:14px;padding:24px;display:flex}.settings-danger-header{color:var(--text);align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.settings-danger-card>p{color:var(--text-dim);font-size:13px;line-height:1.6}.settings-danger-btn{border-radius:var(--radius);color:#fff;cursor:pointer;background:#ef4444;border:none;align-self:flex-start;padding:10px 24px;font-size:14px;font-weight:600;transition:opacity .3s,transform .2s,box-shadow .3s}.settings-danger-btn:hover{opacity:.9;box-shadow:0 4px 15px #ef444440}.settings-danger-btn:active{transform:scale(.98)}.settings-submit{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;cursor:pointer;border:none;justify-content:center;align-self:flex-start;align-items:center;gap:8px;min-width:120px;padding:12px 32px;font-size:15px;font-weight:600;transition:opacity .3s,transform .2s,box-shadow .3s;display:flex}.settings-submit:hover{opacity:.9;box-shadow:0 4px 15px var(--accent-soft)}.settings-submit:active{transform:scale(.98)}.settings-submit:disabled{opacity:.6;cursor:not-allowed}.settings-field-desc{color:var(--text-sec);margin-bottom:16px;font-size:14px;line-height:1.5}.settings-redeem-btn{border-radius:var(--radius);background:linear-gradient(135deg, var(--accent), var(--accent-mid));color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;min-width:64px;padding:7px 18px;font-size:14px;font-weight:500;transition:opacity .15s;display:flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.settings-redeem-btn:hover{opacity:.9}.settings-redeem-btn:disabled{opacity:.5;cursor:not-allowed}.settings-verify-status{color:var(--text-sec);align-items:center;gap:6px;font-size:14px;display:flex}.settings-verify-box{margin-top:10px}.settings-verify-btn{color:#000;cursor:pointer;background:linear-gradient(135deg,#60a5fa,#fcd34d);border:none;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600;transition:opacity .2s}.settings-verify-btn:hover{opacity:.9}.settings-verify-btn:disabled{opacity:.5;cursor:not-allowed}.settings-verify-input-row{align-items:center;gap:10px;display:flex}.settings-verify-input-row .settings-input{flex:1;max-width:160px}.settings-email-card{background:var(--card-bg,#ffffff08);border:1px solid var(--border,#ffffff0f);border-radius:16px;margin-bottom:20px;padding:24px}.settings-email-current{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:16px;display:flex}.settings-email-label{color:var(--text-dim);font-size:13px}.settings-email-value{color:var(--text);letter-spacing:.02em;font-family:monospace;font-size:15px;font-weight:500}.settings-email-status{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.settings-email-status.verified{color:#22c55e;background:#22c55e1f}.settings-email-status.unverified{color:#f59e0b;background:#f59e0b1f}.settings-email-verify-section,.settings-email-change-section{margin-top:12px}.settings-email-desc{color:var(--text-dim);margin:0 0 12px;font-size:13px;line-height:1.5}.settings-email-change-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:500;transition:all .2s}.settings-email-change-btn:hover{background:var(--accent-soft);border-color:var(--accent)}.settings-email-change-btn.secondary{border-color:var(--border);color:var(--text-dim)}.settings-email-change-btn.secondary:hover{border-color:var(--border);background:#ffffff0d}.settings-email-change-form{flex-direction:column;gap:12px;display:flex}.settings-email-change-actions{align-items:center;gap:10px;display:flex}.settings-redeem-hint{color:var(--text-sec);align-items:center;gap:6px;margin-top:8px;font-size:13px;display:flex}.settings-redeem-hint strong{color:var(--accent)}.settings-stats-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;display:grid}.settings-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:20px 16px;transition:border-color .2s,transform .2s}.settings-stat-card:hover{border-color:var(--accent);transform:translateY(-2px)}.settings-stat-value{color:var(--accent);margin-bottom:4px;font-size:24px;font-weight:700}.settings-stat-label{color:var(--text-sec);font-size:13px}.settings-stats-loading{color:var(--text-sec);justify-content:center;align-items:center;gap:10px;padding:40px;font-size:14px;display:flex}.settings-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@media (width<=768px){.settings-sidebar{display:none}.settings-banner,.settings-panel{padding:24px 20px}.settings-content{max-width:100%}}.register-method-tabs{gap:8px;margin-bottom:12px;display:flex}.register-method-tabs button{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-faint);cursor:pointer;flex:1;padding:8px 12px;font-size:13px;transition:all .2s}.register-method-tabs button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.email-code-row{gap:8px;margin-bottom:12px;display:flex}.email-code-row input{margin-bottom:0!important}.code-btn{border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);color:var(--accent);cursor:pointer;white-space:nowrap;padding:0 14px;font-size:13px;font-weight:500;transition:all .2s}.code-btn:hover:not(:disabled){background:var(--accent);color:#fff;border-color:var(--accent)}.code-btn:disabled{opacity:.5;cursor:not-allowed}.sync-bar{align-items:center;gap:6px;display:flex}.sync-pill{background:var(--surface);border:1px solid var(--border);border-radius:10px;align-items:stretch;height:34px;font-size:13px;display:flex;overflow:hidden}.sync-half{height:100%;color:var(--text-dim);cursor:pointer;-webkit-appearance:none;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;padding:0 12px;font-size:14px;transition:background .2s,color .2s;display:flex}.sync-half:hover:not(:disabled){background:var(--accent);color:#fff}.sync-arrow{transition:transform .25s cubic-bezier(.34,1.56,.64,1);display:inline-block}.sync-up:hover:not(:disabled) .sync-arrow{transform:translateY(-2px)}.sync-down:hover:not(:disabled) .sync-arrow{transform:translateY(2px)}.sync-half:disabled{opacity:.4;cursor:not-allowed}.sync-divider{background:var(--border);width:1px;height:100%}.sync-msg{color:var(--accent);font-size:12px;animation:.3s fadeIn}
