:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px}html,body,#root{width:100%;height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-page{background:#f8f8f8;min-height:100vh;width:100vw;display:flex;flex-direction:column;padding:60px 20px 40px;padding-bottom:calc(120px + env(safe-area-inset-bottom,0px));box-sizing:border-box;align-items:center}.auth-page{padding-top:48px}.auth-header{text-align:center;margin-bottom:36px}.auth-title{font-size:24px;font-weight:600;color:#333;margin:0 0 8px}.auth-subtitle{font-size:14px;color:#999;margin:0}.auth-form{margin-top:0}.auth-form .input-container{margin-bottom:20px}.auth-form .gender-selection{margin-bottom:24px}.auth-switch{margin-top:24px;font-size:14px;color:#666}.auth-switch a{color:#07c160;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.field-error{display:block;font-size:12px;color:#ee0a24;margin-top:6px}.input-error{border:1px solid #ee0a24!important}.agreement-inline{position:static;margin-bottom:20px}.agreement-inline .agreement-text{color:#666}.avatar-section{margin-top:40px;margin-bottom:60px;display:flex;justify-content:center}.avatar-wrapper{padding:0;width:160px;height:160px;border-radius:50%;overflow:hidden;position:relative;background:#fff;box-shadow:0 8px 20px #0000001a;border:none;cursor:pointer;transition:transform .2s}.avatar-wrapper:hover{transform:scale(1.02)}.avatar{width:100%;height:100%;border-radius:50%;border:4px solid #fff;object-fit:cover;background-color:#f0f0f0}.avatar-mask{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);font-size:14px;color:#999;white-space:nowrap}.form-section{margin-top:40px;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.input-container{width:100%;position:relative;background:#fff;border-radius:16px;padding:16px 20px;margin-bottom:30px;box-shadow:0 4px 12px #0000000f;display:flex;align-items:center}.edit-icon{width:20px;height:20px;margin-left:10px}.gender-selection{width:100%;display:flex;justify-content:center;margin-bottom:40px}.radio-group{display:flex;flex-direction:row;justify-content:center;width:100%;gap:20px}.gender-option{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 30px;border-radius:10px;background-color:#fff;box-shadow:0 4px 12px #0000000f;position:relative;min-width:120px;text-align:center;cursor:pointer;transition:all .3s;border:2px solid transparent}.gender-option:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.gender-option.checked{border:2px solid #07c160}.gender-avatar-container{display:flex;flex-direction:column;align-items:center}.gender-avatar{width:60px;height:60px;margin-bottom:10px;border-radius:50%;object-fit:cover}.gender-option span{font-size:16px;color:#333}.submit-btn{text-align:center;width:200px;height:48px;line-height:48px;border-radius:24px;background:#07c160;color:#fff;font-size:18px;transition:opacity .3s;border:none;cursor:pointer;white-space:nowrap}.submit-btn:hover{opacity:.9}.submit-btn:active{opacity:.8}.submit-btn:disabled{background:#ccc;cursor:not-allowed}.footer{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px));left:0;right:0;color:#999;font-size:14px;display:flex;flex-direction:column;align-items:center;gap:10px}.agreement{display:flex;align-items:center;gap:8px;cursor:pointer}.contact-page{background:#f8f8f8;min-height:100vh;width:100vw;display:flex;flex-direction:column}.container-top{position:fixed;top:0;z-index:100;padding:12px 16px;height:56px;background-color:#fff;width:100%;text-align:center;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000000d}.container-top span{font-size:18px;font-weight:500;color:#333}.contact-top-add{position:absolute;right:16px;background:none;border:none;font-size:15px;color:#07c160;cursor:pointer;padding:8px}.contact-top-add:active{opacity:.8}.scroll-view{margin-top:56px;flex:1;overflow-y:auto;padding-bottom:calc(76px + env(safe-area-inset-bottom,0px));scrollbar-width:none;-ms-overflow-style:none}.scroll-view::-webkit-scrollbar{display:none}.contact-item{display:flex;align-items:center;padding:12px 16px;background:#fff;border-bottom:1px solid #eee;cursor:pointer;transition:background-color .2s}.contact-item:hover{background-color:#f5f5f5}.contact-item:active{background-color:#e8e8e8}.avatar-container{position:relative;margin-right:12px}.avatar{width:48px!important;height:48px!important;border-radius:6px;object-fit:cover;background-color:#f0f0f0;display:block}.unread-badge{position:absolute;top:-6px;right:-6px;background-color:#ff4d4f;color:#fff;font-size:12px;min-width:18px;height:18px;text-align:center;line-height:18px;border-radius:9px;padding:0 5px;z-index:10}.name{font-size:16px;color:#333;font-weight:400}.loading-container{display:flex;justify-content:center;align-items:center;padding:40px;color:#999;font-size:14px}.empty-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#999}.empty-text{font-size:14px;margin-top:16px}.section-title{padding:8px 16px;font-size:14px;color:#666;background:#f8f8f8}.contact-page .modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.contact-page .modal-content.add-friend-modal{background:#fff;border-radius:16px;padding:24px 20px;max-width:320px;width:85%}.contact-page .modal-title{font-size:18px;font-weight:600;margin-bottom:20px;color:#333;text-align:center}.contact-page .modal-field{margin-bottom:24px}.contact-page .modal-input{width:100%;box-sizing:border-box;padding:12px 16px;font-size:16px;border:1px solid #e0e0e0;border-radius:8px;outline:none}.contact-page .modal-input:focus{border-color:#07c160}.contact-page .modal-input::placeholder{color:#999}.contact-page .modal-error{margin-top:8px;font-size:13px;color:#ff4d4f}.contact-page .modal-buttons{display:flex;gap:12px;justify-content:center}.contact-page .modal-btn{flex:1;padding:12px 20px;border-radius:8px;font-size:16px;cursor:pointer;border:none;transition:background-color .2s}.contact-page .modal-btn:disabled{opacity:.6;cursor:not-allowed}.contact-page .modal-btn.cancel{background:#f0f0f0;color:#666}.contact-page .modal-btn.confirm{background:#07c160;color:#fff}.contact-page .modal-btn.confirm:hover:not(:disabled){background:#06ad56}.contact-page .modal-content.requests-modal{background:#fff;border-radius:16px;padding:20px 16px;max-width:340px;width:90%;max-height:70vh;overflow:hidden;display:flex;flex-direction:column}.contact-page .requests-modal .modal-title{margin-bottom:16px}.contact-page .requests-list{overflow-y:auto;margin-bottom:16px;max-height:50vh}.contact-page .request-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid #eee}.contact-page .request-item:last-child{border-bottom:none}.contact-page .request-item .avatar-container{margin-right:12px}.contact-page .request-item .avatar{width:44px;height:44px;border-radius:6px;object-fit:cover;background:#f0f0f0}.contact-page .request-info{flex:1;display:flex;flex-direction:column;min-width:0}.contact-page .request-name{font-size:16px;font-weight:500;color:#333}.contact-page .request-desc{font-size:13px;color:#999;margin-top:2px}.contact-page .request-actions{display:flex;gap:8px;flex-shrink:0}.contact-page .request-btn{padding:8px 16px;border-radius:8px;font-size:14px;border:none;cursor:pointer;transition:background-color .2s}.contact-page .request-btn:disabled{opacity:.6;cursor:not-allowed}.contact-page .request-btn.reject{background:#f0f0f0;color:#666}.contact-page .request-btn.reject:hover:not(:disabled){background:#e0e0e0}.contact-page .request-btn.accept{background:#07c160;color:#fff}.contact-page .request-btn.accept:hover:not(:disabled){background:#06ad56}.contact-page .modal-btn.full{width:100%}.contact-page .toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:1001;max-width:80%;text-align:center}.chat-page{background:#f5f5f5;height:100vh;height:100dvh;width:100vw;display:flex;flex-direction:column;overflow:hidden;position:relative}.status-indicator{position:absolute;left:50px;font-size:12px;color:#ff4d4f}.script-progress-bar{position:fixed;top:56px;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);padding:12px 16px;z-index:99;box-shadow:0 2px 8px #0000001a}.script-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.script-progress-title{font-size:14px;font-weight:600;color:#fff}.scene-role-switcher{display:flex;align-items:center;gap:6px}.scene-role-btn{padding:4px 12px;font-size:12px;border:1px solid rgba(255,255,255,.5);border-radius:16px;background:#ffffff26;color:#fff;cursor:pointer;transition:background .2s,border-color .2s}.scene-role-btn:hover{background:#ffffff40;border-color:#fffc}.scene-role-btn.active{background:#ffffffe6;color:#667eea;border-color:#fff}.script-progress-toggle{background:#fff3;border:none;color:#fff;font-size:12px;padding:4px 10px;border-radius:12px;cursor:pointer;transition:background .2s}.script-progress-toggle:hover{background:#ffffff4d}.script-progress-steps{display:flex;justify-content:space-between;align-items:center;gap:4px}.script-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.script-step:not(:last-child):after{content:"";position:absolute;top:12px;right:-50%;width:100%;height:2px;background:#ffffff4d;z-index:0}.script-step.completed:not(:last-child):after{background:#07c160}.step-number{width:24px;height:24px;border-radius:50%;background:#ffffff4d;color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;z-index:1;transition:all .3s}.script-step.active .step-number{background:#07c160;transform:scale(1.1);box-shadow:0 2px 8px #07c16066}.script-step.completed .step-number{background:#07c160}.step-label{font-size:10px;color:#fffc;margin-top:4px;white-space:nowrap}.script-step.active .step-label{color:#fff;font-weight:600}.scene-step-hint-sticky-wrapper{position:sticky;top:0;z-index:10;margin-bottom:12px;background:#f5f5f5;padding-bottom:4px}.current-step-hint-card{margin-bottom:12px;animation:current-step-hint-appear .4s ease-out}@keyframes current-step-hint-appear{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.current-step-hint-card-inner{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:linear-gradient(145deg,#fff9e6,#fff4d9);border-radius:14px;border:1px solid rgba(245,190,80,.4);box-shadow:0 2px 12px #667eea1a}.current-step-hint-icon{flex-shrink:0;font-size:22px;line-height:1}.current-step-hint-body{flex:1;min-width:0}.current-step-hint-header{display:flex;align-items:center;flex-wrap:wrap;gap:8px 10px;margin-bottom:0}.current-step-hint-label{font-size:13px;font-weight:600;color:#b8860b}.current-step-hint-badge{padding:2px 10px;font-size:12px;font-weight:600;color:#b8860b;background:#f5be5040;border-radius:20px}.current-step-hint-toggle{margin-left:auto;padding:4px 12px;font-size:12px;font-weight:500;color:#b8860b;background:#f5be5033;border:1px solid rgba(245,190,80,.5);border-radius:16px;cursor:pointer}.current-step-hint-toggle:hover{background:#f5be5059}.current-step-hint-text{margin:8px 0 0;font-size:14px;line-height:1.5;color:#5a4d3a}.script-line-card{margin-bottom:0;animation:current-step-hint-appear .4s ease-out}.script-line-card-inner{padding:14px 16px;background:linear-gradient(145deg,#e8f0fa,#f0eef8);border-radius:14px;border:1px solid rgba(102,126,234,.25);box-shadow:0 2px 10px #667eea14}.script-line-card-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.script-line-card-title{font-size:14px;font-weight:600;color:#4a5568}.script-line-card-badge{font-size:12px;font-weight:500;color:#667eea;background:#667eea26;padding:2px 10px;border-radius:20px}.script-line-card-toggle{display:block;width:100%;padding:8px 14px;font-size:13px;font-weight:500;color:#667eea;background:#667eea1f;border:1px solid rgba(102,126,234,.3);border-radius:8px;cursor:pointer;transition:background .2s,color .2s}.script-line-card-toggle:hover{background:#667eea33;color:#5a67d8}.script-line-card-content{margin-top:12px;padding:12px 14px;background:#fffc;border-radius:10px;border:1px solid rgba(102,126,234,.15);display:flex;flex-direction:column;gap:8px}.script-line-card-text{margin:0;font-size:15px;line-height:1.55;color:#2d3748;font-style:italic}.script-line-card-copy{align-self:flex-end;padding:4px 12px;font-size:12px;color:#666;background:#f0f0f0;border:none;border-radius:6px;cursor:pointer}.script-line-card-copy:hover{background:#e0e0e0;color:#333}.scene-hints-inline{margin-bottom:12px;padding:12px 16px;background:linear-gradient(135deg,#e8f4fd,#f0e6fa);border-radius:12px;border:1px solid rgba(102,126,234,.2);box-shadow:0 1px 4px #0000000f}.scene-hints-inline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.scene-hints-inline-title{font-size:14px;font-weight:600;color:#5a4d7a}.scene-hints-inline-toggle{background:#667eea26;border:none;color:#667eea;font-size:12px;padding:4px 10px;border-radius:8px;cursor:pointer}.scene-hints-inline-toggle:hover{background:#667eea40}.scene-hints-inline-list{margin:0;padding-left:18px;font-size:13px;color:#444;line-height:1.6}.scene-hints-inline-list li{margin-bottom:4px}.scene-hints-inline-list li:last-child{margin-bottom:0}.message-list{position:fixed;inset:56px 0 0;padding:12px 10px;padding-bottom:calc(60px + env(safe-area-inset-bottom,0px));overflow-y:auto;overflow-x:hidden;background:#f5f5f5;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;z-index:1;display:flex;flex-direction:column}.chat-page.has-script-progress .message-list{top:130px}.message-list-inner{margin-top:auto;display:flex;flex-direction:column}.tips-area{padding:10px 0;text-align:center}.tip{color:#999;font-size:12px;padding:5px 0}.tip.loading{color:#07c160}.time-divider{margin:16px 0;text-align:center;position:relative;color:#999;font-size:12px}.divider-line{position:absolute;top:50%;left:20%;right:20%;height:1px;background:#e0e0e0;z-index:0}.time-divider span{position:relative;z-index:1;background:#f5f5f5;padding:0 10px}.message-item{display:flex;align-items:flex-start;padding:6px 0;width:100%;animation:messageAppear .3s ease forwards}.message-item.me{flex-direction:row-reverse}@keyframes messageAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.avatar-wrap{width:40px;height:40px;min-width:40px;min-height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;cursor:pointer;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center}.avatar{width:100%;height:100%;min-width:100%;min-height:100%;border-radius:50%;object-fit:cover;object-position:50% 35%;display:block;background-color:#f0f0f0}.bubble{max-width:70%;margin:0 8px;padding:9px 12px;border-radius:8px;background-color:#fff;word-wrap:break-word;font-size:15px;line-height:1.5;color:#333;box-shadow:0 1px 2px #0000000d;position:relative}.message-item.me .bubble{background-color:#95ec69}.audio-bar-container{display:inline-flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0;-webkit-user-select:none;user-select:none;min-width:120px}.audio-play-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#333;flex-shrink:0}.audio-waveform{width:60px;height:20px;background-repeat:repeat-x;background-size:20px 100%;flex-shrink:0}.audio-wave-static{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M2 10h2M6 6v8M10 3v14M14 6v8M18 10h2' stroke='%23999' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");opacity:.6}.audio-wave-animation{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath d='M2 10h2M6 6v8M10 3v14M14 6v8M18 10h2' stroke='%2307c160' stroke-width='1.5' fill='none' stroke-linecap='round'%3E%3Canimate attributeName='d' values='M2 10h2M6 6v8M10 3v14M14 6v8M18 10h2;M2 6v8M6 3v14M10 6v8M14 3v14M18 6v8;M2 10h2M6 6v8M10 3v14M14 6v8M18 10h2' dur='0.6s' repeatCount='indefinite'/%3E%3C/path%3E%3C/svg%3E");animation:wavePulse .6s ease-in-out infinite}@keyframes wavePulse{0%,to{opacity:.8}50%{opacity:1}}.audio-duration{font-size:12px;color:#999;min-width:36px;text-align:right}.unread-dot{width:8px;height:8px;background-color:#ff4d4f;border-radius:50%;margin-left:4px;flex-shrink:0}.system-message{text-align:center;color:#999;font-size:12px;padding:8px;margin:8px 0}.message-item.error .bubble{background-color:#fff2f0;border:1px solid #ffccc7;color:#ff4d4f}.message-item.error .bubble .content{color:#ff4d4f}.content{display:flex;flex-wrap:wrap;gap:2px 6px}.clickable-word{cursor:pointer;border-bottom:1px dotted #999;transition:all .2s}.clickable-word:hover{color:#07c160;border-bottom-color:#07c160}.translate-btn{margin-top:6px;padding:4px 10px;font-size:12px;color:#576b95;background:transparent;border:none;cursor:pointer;text-decoration:underline;text-decoration-color:#576b9566}.translate-btn:hover{text-decoration-color:#576b95}.recall-btn{margin-top:6px;padding:2px 8px;font-size:11px;color:#999;background:transparent;border:1px solid transparent;border-radius:4px;cursor:pointer;opacity:0;transition:opacity .2s,color .2s,border-color .2s,background-color .2s;white-space:nowrap}.message-item:hover .recall-btn,.message-item:active .recall-btn{opacity:1}.recall-btn:hover{color:#666;background:#0000000a;border-color:#00000014}.recall-btn.recall-confirming{opacity:1;color:#ff4d4f;border-color:#ff4d4f;background:#ff4d4f0f;animation:recallPulse 1s ease-in-out infinite}.recall-btn.recall-confirming:hover{color:#fff;background:#ff4d4f;border-color:#ff4d4f}@keyframes recallPulse{0%,to{opacity:1}50%{opacity:.7}}@media(hover:none){.recall-btn{opacity:.6}}.translated-text{margin-top:6px;padding:8px;background:#f0f0f0;border-radius:4px;font-size:13px;color:#666}.help-item{margin-top:6px;padding:8px;background:#e6f7ff;border-radius:4px;font-size:13px}.help-label{color:#1890ff;font-weight:500}.message-image{max-width:200px;max-height:200px;border-radius:8px;cursor:pointer;object-fit:cover}.input-area{position:fixed;bottom:0;left:0;right:0;padding:6px 12px calc(6px + env(safe-area-inset-bottom,0px));background-color:#f7f7f7;border-top:1px solid #e0e0e0;display:flex;align-items:center;gap:8px;z-index:100}.mode-switch-group{display:flex;align-items:center}.switch-btn{width:44px;height:44px;min-width:44px;min-height:44px;border-radius:50%;border:none;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 3px #0000001a;transition:all .2s}.switch-btn:hover{background:#f0f0f0}.switch-icon,.switch-icon-fallback{width:28px;height:28px;min-width:28px;min-height:28px;color:#333;flex-shrink:0}.switch-icon-img{width:28px;height:28px;min-width:28px;min-height:28px;object-fit:contain;display:block}.voice-input-mode{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:8px}.no-sound-prompt{color:#ff6b6b;font-size:14px;animation:pulse 1s infinite}.voice-no-recognition-tip{margin-bottom:8px;padding:8px 14px;font-size:14px;color:#c45c26;background:#fff5eb;border-radius:8px;border:1px solid rgba(196,92,38,.25);text-align:center}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.voice-btn{width:100%;max-width:280px;height:36px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:none;-webkit-touch-callout:none;transition:all .1s}.voice-btn:active{background:#e0e0e0}.voice-btn:disabled{opacity:.6;cursor:not-allowed}.text-input-mode{flex:1;display:flex;gap:10px;align-items:center}.text-input-mode .input{flex:1;height:40px;padding:0 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:15px;background:#fff}.text-input-mode .input:focus{outline:none;border-color:#07c160}.send-btn{height:40px;padding:0 20px;background:#07c160;color:#fff;border:none;border-radius:6px;font-size:15px;cursor:pointer;transition:all .2s}.send-btn:hover{background:#06ad56}.send-btn:disabled{background:#ccc;cursor:not-allowed}.floating-btns{position:fixed;bottom:88px;left:50%;transform:translate(-50%);display:flex;gap:40px;z-index:10002;pointer-events:none}.circle-btn{width:80px;height:80px;border-radius:50%;border:none;font-size:16px;font-weight:500;cursor:pointer;pointer-events:auto;transition:all .2s;box-shadow:0 4px 12px #00000026}.cancel-btn{background:#ff4d4f;color:#fff}.cancel-btn.active{transform:scale(1.1);box-shadow:0 6px 20px #ff4d4f66}.help-btn{background:#07c160;color:#fff}.help-btn.active{transform:scale(1.1);box-shadow:0 6px 20px #07c16066}.floating-help-box{position:fixed;bottom:200px;left:50%;transform:translate(-50%);width:85%;max-width:360px;max-height:50vh;background:#fff;border-radius:16px;box-shadow:0 8px 32px #0003;z-index:9999;overflow:hidden;display:flex;flex-direction:column}.help-box-content{padding:20px;overflow-y:auto}.help-box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #f0f0f0}.help-title{font-size:16px;font-weight:700;color:#333}.close-btn{width:28px;height:28px;border-radius:50%;background-color:#999;color:#fff;font-size:14px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.close-btn:hover{background-color:#666}.help-box-body{display:flex;flex-direction:column;gap:12px}.help-box-body .help-item{padding:12px;border-radius:8px}.help-box-body .help-item-user{background-color:#f0f9eb}.help-box-body .help-item-ai{background-color:#e6f7ff}.help-text-content{display:block;margin-top:4px;font-size:14px;line-height:1.6;color:#333}.help-audio-player{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:6px 12px;border-radius:20px;background:#0000000d;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.help-audio-player:hover{background:#00000014}.help-audio-player.is-playing{background:#07c1601f}.help-audio-player .audio-play-icon{color:#07c160}.help-audio-player.is-playing .audio-play-icon{color:#06ad56}.help-audio-player .audio-waveform{width:48px;height:18px}.help-audio-label{font-size:12px;color:#666;white-space:nowrap}.help-audio-player.is-playing .help-audio-label{color:#07c160}.help-explain-result{padding:12px;border-radius:8px;background-color:#fff7e6}.explain-btn{width:100%;padding:12px;background:#07c160;color:#fff;border:none;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.explain-btn:hover{background:#06ad56}.explain-btn:disabled{background:#ccc;cursor:not-allowed}.mask{position:fixed;inset:0;background-color:#00000080;z-index:9998}.role-picker-mask{top:56px;z-index:9998}.role-picker-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:85%;max-width:320px;padding:24px;background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;z-index:9999}.role-picker-title{margin:0 0 8px;font-size:18px;font-weight:600;color:#333;text-align:center}.role-picker-desc{margin:0 0 20px;font-size:14px;color:#666;text-align:center}.role-picker-btns{display:flex;flex-direction:column;gap:12px}.role-picker-btn{width:100%;padding:14px 20px;font-size:16px;font-weight:500;color:#333;background:linear-gradient(135deg,#e8f0fa,#f0eef8);border:1px solid rgba(102,126,234,.3);border-radius:12px;cursor:pointer;transition:background .2s,border-color .2s}.role-picker-btn:hover{background:linear-gradient(135deg,#dce8f8,#e8e4f5);border-color:#667eea80}.role-picker-btn:active{background:#e0e4f0}.help-box-open .input-area{z-index:9999}.help-box-open .floating-btns{z-index:10010;pointer-events:auto}.help-box-open .floating-btns .circle-btn{pointer-events:auto}.popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;max-width:300px;padding:20px;background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #0003;z-index:9999}.popup-content{font-size:14px;line-height:1.6;color:#333}.user-info-page{background:#f8f8f8;min-height:100vh;width:100vw;display:flex;flex-direction:column;overflow-x:hidden}.container_top{position:fixed;top:0;left:0;z-index:100;height:56px;padding:0 16px;width:100%;display:flex;justify-content:center;align-items:center;background-color:#fff;box-shadow:0 2px 4px #0000000d}.container_top .back-btn{position:absolute;left:16px;background:none;border:none;font-size:20px;color:#333;cursor:pointer;padding:8px}.container_top span{font-size:18px;font-weight:500;color:#333}.container{display:flex;flex-direction:column;width:min(100%,480px);margin:0 auto;min-height:100vh;padding:76px 20px calc(84px + env(safe-area-inset-bottom,0px));justify-content:flex-start;align-items:center;box-sizing:border-box}.avatar-section{margin-top:20px;margin-bottom:24px;width:100%;display:flex;justify-content:center;align-items:center}.avatar-wrapper{padding:0;width:96px;height:96px;border-radius:50%;overflow:hidden;position:relative;background:linear-gradient(145deg,#f5f5f5,#e8e8e8);box-shadow:0 0 0 3px #fff,0 0 0 4px #0000000f,0 6px 16px #0000001f;border:none;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.avatar-wrapper:hover{transform:scale(1.02);box-shadow:0 0 0 4px #fff,0 0 0 5px #00000014,0 12px 28px #00000026}.avatar-wrapper:active{transform:scale(.98)}.avatar{width:100%;height:100%;min-width:100%;min-height:100%;border-radius:50%;object-fit:cover;object-position:center;display:block;background:linear-gradient(145deg,#f0f0f0,#e5e5e5);box-sizing:border-box}.avatar-mask{position:absolute;bottom:-22px;left:50%;transform:translate(-50%);font-size:11px;color:#999;white-space:nowrap}.form-section{margin-top:28px;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center}.current-nickname{font-size:14px;color:#666;margin-bottom:20px;text-align:center}.current-phone{font-size:14px;color:#666;margin-bottom:16px;text-align:center}.input-container{width:100%;position:relative;background:#fff;border-radius:12px;padding:12px 16px;margin-bottom:20px;box-shadow:0 4px 12px #0000000f;display:flex;align-items:center}.nickname-input{font-size:16px;color:#333;height:24px;line-height:24px;border:none;outline:none;flex:1;background:transparent}.nickname-input::placeholder{color:#ccc}.submit-wrapper{width:100%;display:flex;justify-content:center;margin-top:8px}.submit-btn{display:inline-flex;align-items:center;justify-content:center;width:min(72%,260px);height:48px;padding:0 20px;border-radius:24px;background:linear-gradient(180deg,#08d269,#07c160,#06ad56);color:#fff;font-size:17px;font-weight:600;letter-spacing:.5px;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease;border:none;cursor:pointer;white-space:nowrap;box-shadow:0 4px 14px #07c16066}.submit-btn:hover{opacity:.95;transform:translateY(-1px);box-shadow:0 6px 18px #07c16073}.submit-btn:active{opacity:1;transform:translateY(0);box-shadow:0 2px 10px #07c16059}.submit-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.logout-wrapper{width:100%;display:flex;justify-content:center;margin-top:24px}.logout-btn{display:inline-flex;align-items:center;justify-content:center;width:min(72%,260px);height:48px;padding:0 20px;border-radius:24px;background:#ee0a240a;color:#c50824;font-size:17px;font-weight:500;letter-spacing:.5px;border:1.5px solid rgba(238,10,36,.5);cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #ee0a241f}.logout-btn:hover{background:#ee0a2414;border-color:#c50824;color:#b30720;transform:translateY(-1px);box-shadow:0 4px 12px #ee0a242e}.logout-btn:active{transform:translateY(0);background:#ee0a241f;box-shadow:0 1px 4px #ee0a2426}.footer{margin-top:auto;width:100%;padding:16px 0 4px;text-align:center;color:#999;font-size:14px;display:flex;flex-direction:column;align-items:center;gap:8px}.agreement{display:flex;align-items:center;gap:8px;cursor:pointer;justify-content:center;flex-wrap:wrap}.agreement-checkbox{width:18px;height:18px;cursor:pointer}.agreement-text{color:#999;font-size:14px}.version-info{font-size:12px;color:#999;text-align:center}.hidden-input{display:none}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:16px;padding:30px 20px;max-width:320px;width:80%;text-align:center}.modal-title{font-size:18px;font-weight:700;margin-bottom:15px;color:#333}.modal-text{font-size:14px;color:#666;margin-bottom:25px;line-height:1.5}.modal-buttons{display:flex;gap:15px;justify-content:center}.modal-btn{padding:10px 30px;border-radius:8px;font-size:16px;cursor:pointer;border:none;transition:all .3s}.modal-btn.cancel{background:#f0f0f0;color:#666}.modal-btn.cancel:hover{background:#e0e0e0}.modal-btn.confirm{background:#07c160;color:#fff}.modal-btn.confirm:hover{background:#06ad56}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;z-index:1001}@media(max-width:360px){.container{padding-left:14px;padding-right:14px}.submit-btn,.logout-btn{width:82%}}.scene-page{min-height:100vh;width:100vw;background:#f8f8f8;display:flex;flex-direction:column}.scene-header{position:fixed;top:0;left:0;z-index:100;height:56px;width:100%;background:#fff;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 4px #0000000d}.scene-header span{font-size:18px;font-weight:500;color:#333}.scene-content{margin-top:56px;padding:20px 16px calc(84px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:12px}.scene-card{background:#fff;border-radius:14px;padding:0;box-shadow:0 6px 16px #0000000f;display:flex;overflow:hidden}.scene-card-left{width:120px;min-width:120px;aspect-ratio:1;position:relative;background:#1a1a1a;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.scene-card-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.scene-card-play-icon{position:absolute;width:40px;height:40px;border-radius:50%;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;padding-left:4px;z-index:1;pointer-events:none}.scene-card-play-label{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:12px;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.6);z-index:1;pointer-events:none}.scene-card-no-video{font-size:13px;color:#fffc;text-align:center;padding:8px}.scene-card-right{flex:1;padding:16px 18px;display:flex;flex-direction:column;justify-content:center;min-width:0}.scene-card h2{margin:0 0 8px;font-size:18px;color:#222}.scene-card p{margin:0 0 18px;color:#666;font-size:14px;line-height:1.6}.scene-task-goal{margin:0 0 14px;font-size:13px;line-height:1.5;color:#444;flex:1}.scene-start-btn{border:none;border-radius:24px;height:44px;padding:0 22px;background:#07c160;color:#fff;font-size:15px;cursor:pointer;align-self:flex-start}.scene-learn-page{min-height:100vh;width:100vw;background:#f8f8f8;display:flex;flex-direction:column}.scene-learn-header{position:fixed;top:0;left:0;z-index:100;height:56px;width:100%;background:#fff;display:flex;align-items:center;padding:0 16px;box-shadow:0 2px 4px #0000000d}.scene-learn-back{border:none;background:none;padding:8px 0;margin-right:12px;font-size:16px;color:#07c160;cursor:pointer}.scene-learn-header span{font-size:18px;font-weight:500;color:#333}.scene-learn-content{margin-top:56px;padding:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;gap:16px}.scene-learn-video-wrap{border-radius:12px;overflow:hidden;background:#000}.scene-learn-video{width:100%;display:block;min-height:280px;max-height:70vh;object-fit:contain}.scene-learn-script{background:#fff;border-radius:14px;padding:16px 18px;box-shadow:0 6px 16px #0000000f}.scene-learn-script h3{margin:0 0 12px;font-size:16px;color:#222}.scene-learn-script-list{margin:0;padding-left:20px;font-size:14px;line-height:1.7;color:#444}.scene-learn-script-list li{margin-bottom:8px}.scene-learn-practice-btn{border:none;border-radius:24px;height:48px;padding:0 22px;background:#07c160;color:#fff;font-size:16px;font-weight:500;cursor:pointer}.bottom-tab-bar{position:fixed;left:0;right:0;bottom:0;height:calc(56px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:#fff;border-top:1px solid #e9e9e9;display:grid;grid-template-columns:repeat(3,1fr);z-index:200}.bottom-tab-item{border:none;background:transparent;color:#666;font-size:14px;display:flex;align-items:center;justify-content:center;padding:0}.bottom-tab-item:hover{border-color:transparent;color:#333}.bottom-tab-item.active{color:#07c160;font-weight:600}.bottom-tab-item:focus-visible{outline:2px solid #07c160;outline-offset:-2px}.bottom-tab-label{line-height:1}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1c2e,#2d1b4e,#1a1c2e);padding:20px}.admin-login-card{width:100%;max-width:420px;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:48px 36px;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #0000004d}.admin-login-header{text-align:center;margin-bottom:36px}.admin-login-icon{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff}.admin-login-header h1{font-size:22px;font-weight:600;color:#fff;margin:0 0 8px}.admin-login-header p{font-size:14px;color:#ffffff80;margin:0}.admin-login-form{display:flex;flex-direction:column;gap:20px}.admin-input-group{display:flex;flex-direction:column;gap:8px}.admin-input-group label{font-size:13px;color:#fff9;font-weight:500}.admin-input-group input{height:48px;padding:0 16px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;color:#fff;font-size:15px;transition:all .2s}.admin-input-group input::placeholder{color:#ffffff4d}.admin-input-group input:focus{border-color:#6366f1;background:#ffffff1a;box-shadow:0 0 0 3px #6366f126}.admin-login-btn{height:48px;border:none;border-radius:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px;letter-spacing:4px}.admin-login-btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 20px #6366f166}.admin-login-btn:active{transform:translateY(0)}.admin-login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.admin-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000c;color:#fff;padding:12px 28px;border-radius:8px;font-size:14px;z-index:1001}.admin-layout{display:flex;min-height:100vh;background:#f0f2f5}.admin-sidebar{width:220px;background:#1a1c2e;display:flex;flex-direction:column;transition:width .25s ease;flex-shrink:0}.admin-sidebar.collapsed{width:64px}.admin-sidebar-header{height:60px;display:flex;align-items:center;gap:10px;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-sidebar.collapsed .admin-sidebar-header{justify-content:center;padding:0}.admin-logo{width:32px;height:32px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.admin-logo-text{font-size:16px;font-weight:600;color:#fff;white-space:nowrap}.admin-nav{flex:1;padding:16px 8px;display:flex;flex-direction:column;gap:4px}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:10px;color:#ffffff8c;text-decoration:none;font-size:14px;transition:all .2s}.admin-sidebar.collapsed .admin-nav-item{justify-content:center;padding:10px}.admin-nav-item:hover{color:#fff;background:#ffffff0f}.admin-nav-item.active{color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6)}.admin-main{flex:1;display:flex;flex-direction:column;min-width:0}.admin-topbar{height:60px;background:#fff;border-bottom:1px solid #e8e8e8;display:flex;align-items:center;justify-content:space-between;padding:0 24px;flex-shrink:0}.admin-toggle-btn{background:none;border:none;cursor:pointer;color:#666;padding:6px;border-radius:6px;display:flex;align-items:center;transition:background .2s}.admin-toggle-btn:hover{background:#f0f0f0}.admin-topbar-right{display:flex;align-items:center;gap:16px}.admin-user-name{font-size:14px;color:#333}.admin-logout-btn{padding:6px 16px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s}.admin-logout-btn:hover{color:#ff4d4f;border-color:#ff4d4f}.admin-content{flex:1;padding:24px;overflow-y:auto}@media screen and (max-width:768px){.admin-sidebar{width:64px}.admin-logo-text,.admin-nav-item span{display:none}.admin-sidebar-header{justify-content:center;padding:0}.admin-nav-item{justify-content:center;padding:10px}.admin-content{padding:16px}}.dashboard{max-width:1200px}.dash-title{font-size:20px;font-weight:600;color:#1a1a2e;margin:0 0 24px}.dash-loading{display:flex;align-items:center;justify-content:center;height:300px;color:#999;font-size:15px}.dash-loading.dash-error{flex-direction:column;color:#666;text-align:center;padding:24px}.dash-loading.dash-error p{margin:0;max-width:400px}.dash-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.dash-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 4px #0000000f;transition:transform .2s,box-shadow .2s}.dash-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.dash-card-label{font-size:13px;color:#999;margin-bottom:10px}.dash-card-value{font-size:32px;font-weight:700;line-height:1}.dash-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-chart-box{background:#fff;border-radius:14px;padding:24px;box-shadow:0 1px 4px #0000000f}.dash-chart-box h3{font-size:15px;font-weight:600;color:#333;margin:0 0 20px}@media screen and (max-width:1024px){.dash-cards{grid-template-columns:repeat(2,1fr)}.dash-charts{grid-template-columns:1fr}}@media screen and (max-width:640px){.dash-cards{grid-template-columns:1fr}.dash-card-value{font-size:26px}}.user-list-page{max-width:1200px}.ul-header{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}.ul-header h2{font-size:20px;font-weight:600;color:#1a1a2e;margin:0}.ul-total{font-size:13px;color:#999}.ul-search{display:flex;gap:8px;margin-bottom:16px}.ul-search input{flex:1;max-width:320px;height:40px;padding:0 14px;border:1px solid #d9d9d9;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s}.ul-search input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.ul-search button{height:40px;padding:0 20px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-size:14px;cursor:pointer;transition:opacity .2s}.ul-search button:hover{opacity:.85}.ul-loading{text-align:center;padding:60px 0;color:#999}.ul-table-wrap{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.ul-table{width:100%;border-collapse:collapse;font-size:14px}.ul-table th{background:#fafafa;color:#666;font-weight:500;padding:14px 16px;text-align:left;white-space:nowrap;border-bottom:1px solid #f0f0f0}.ul-table td{padding:12px 16px;color:#333;border-bottom:1px solid #f5f5f5;vertical-align:middle}.ul-table tbody tr:hover{background:#fafbff}.ul-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.ul-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:#e8e8ff;color:#6366f1;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.ul-role-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:12px}.ul-role-badge.admin{background:#ede9fe;color:#6366f1}.ul-role-badge.user{background:#f0fdf4;color:#22c55e}.ul-action-btn{padding:4px 12px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;color:#666;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.ul-action-btn:hover{color:#6366f1;border-color:#6366f1}.ul-empty{text-align:center;color:#ccc;padding:40px 0!important}.ul-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px}.ul-pagination button{padding:6px 16px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;font-size:13px;cursor:pointer;transition:all .2s;color:#333}.ul-pagination button:hover:not(:disabled){color:#6366f1;border-color:#6366f1}.ul-pagination button:disabled{opacity:.4;cursor:not-allowed}.ul-pagination span{font-size:13px;color:#666}@media screen and (max-width:768px){.ul-table-wrap{overflow-x:auto}.ul-table{min-width:700px}}.friendship-list-page{max-width:1200px}.fl-header{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}.fl-header h2{font-size:20px;font-weight:600;color:#1a1a2e;margin:0}.fl-total{font-size:13px;color:#999}.fl-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.fl-search{display:flex;gap:8px;flex:1;min-width:200px}.fl-search input{flex:1;max-width:320px;height:40px;padding:0 14px;border:1px solid #d9d9d9;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s}.fl-search input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a;outline:none}.fl-search button{height:40px;padding:0 20px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-size:14px;cursor:pointer;transition:opacity .2s}.fl-search button:hover{opacity:.85}.fl-add-btn{height:40px;padding:0 20px;border:none;border-radius:8px;background:#22c55e;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:opacity .2s}.fl-add-btn:hover{opacity:.85}.fl-loading{text-align:center;padding:60px 0;color:#999}.fl-table-wrap{background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.fl-table{width:100%;border-collapse:collapse;font-size:14px}.fl-table th{background:#fafafa;color:#666;font-weight:500;padding:14px 16px;text-align:left;white-space:nowrap;border-bottom:1px solid #f0f0f0}.fl-table td{padding:12px 16px;color:#333;border-bottom:1px solid #f5f5f5;vertical-align:middle}.fl-table tbody tr:hover{background:#fafbff}.fl-user-cell{display:flex;align-items:center;gap:10px}.fl-user-info{display:flex;flex-direction:column;gap:2px}.fl-name{font-weight:500;color:#1a1a2e}.fl-sub{font-size:12px;color:#999}.fl-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.fl-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:#e8e8ff;color:#6366f1;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.fl-arrow{display:flex;justify-content:center}.fl-time{white-space:nowrap;color:#999;font-size:13px}.fl-delete-btn{padding:4px 12px;border:1px solid #fca5a5;border-radius:6px;background:#fff;color:#ef4444;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.fl-delete-btn:hover{background:#fef2f2;border-color:#ef4444}.fl-empty{text-align:center;color:#ccc;padding:40px 0!important}.fl-pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:20px}.fl-pagination button{padding:6px 16px;border:1px solid #d9d9d9;border-radius:6px;background:#fff;font-size:13px;cursor:pointer;transition:all .2s;color:#333}.fl-pagination button:hover:not(:disabled){color:#6366f1;border-color:#6366f1}.fl-pagination button:disabled{opacity:.4;cursor:not-allowed}.fl-pagination span{font-size:13px;color:#666}.fl-modal-mask{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.fl-modal{background:#fff;border-radius:16px;width:480px;max-width:92vw;box-shadow:0 20px 60px #00000026;animation:fl-modal-in .2s ease}@keyframes fl-modal-in{0%{opacity:0;transform:translateY(-20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.fl-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.fl-modal-header h3{margin:0;font-size:17px;font-weight:600;color:#1a1a2e}.fl-modal-close{background:none;border:none;font-size:22px;color:#999;cursor:pointer;padding:0 4px;line-height:1}.fl-modal-close:hover{color:#333}.fl-modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:18px}.fl-field label{display:block;font-size:13px;font-weight:500;color:#666;margin-bottom:6px}.fl-autocomplete{position:relative}.fl-autocomplete input{width:100%;height:40px;padding:0 14px;border:1px solid #d9d9d9;border-radius:8px;font-size:14px;background:#fff;transition:border-color .2s;box-sizing:border-box}.fl-autocomplete input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a;outline:none}.fl-dropdown{position:absolute;top:44px;left:0;right:0;background:#fff;border:1px solid #e8e8e8;border-radius:10px;box-shadow:0 6px 20px #0000001a;max-height:200px;overflow-y:auto;list-style:none;margin:0;padding:4px;z-index:10}.fl-dropdown li{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:13px;color:#333;transition:background .15s}.fl-dropdown li:hover{background:#f5f3ff}.fl-selected-user{display:flex;align-items:center;gap:10px;padding:8px 12px;background:#f5f3ff;border:1px solid #e0dbff;border-radius:8px;font-size:14px;color:#333}.fl-clear-btn{margin-left:auto;background:none;border:none;font-size:18px;color:#999;cursor:pointer;padding:0 4px;line-height:1}.fl-clear-btn:hover{color:#ef4444}.fl-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:0 24px 20px}.fl-cancel-btn{height:38px;padding:0 20px;border:1px solid #d9d9d9;border-radius:8px;background:#fff;color:#666;font-size:14px;cursor:pointer;transition:all .2s}.fl-cancel-btn:hover{color:#333;border-color:#bbb}.fl-confirm-btn{height:38px;padding:0 24px;border:none;border-radius:8px;background:#6366f1;color:#fff;font-size:14px;cursor:pointer;transition:opacity .2s}.fl-confirm-btn:hover:not(:disabled){opacity:.85}.fl-confirm-btn:disabled{opacity:.5;cursor:not-allowed}@media screen and (max-width:768px){.fl-table-wrap{overflow-x:auto}.fl-table{min-width:600px}.fl-toolbar{flex-direction:column;align-items:stretch}.fl-search{max-width:none}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow-x:hidden}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f8f8}.app{width:100%;min-height:100vh;display:flex;flex-direction:column}.app-main{width:100%;min-height:100vh}.app-main.with-bottom-tab{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}@media screen and (max-width:768px){html{font-size:14px}}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#999}.no-select{user-select:none;-webkit-user-select:none}button,input,textarea{font-family:inherit;outline:none}img{max-width:100%;height:auto;display:block}
