*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #e9ecef;--text-primary: #212529;--text-secondary: #6c757d;--text-muted: #adb5bd;--border-color: #dee2e6;--border-hover: #ced4da;--accent: #6366f1;--accent-hover: #4f46e5;--accent-light: #e0e7ff;--success: #10b981;--success-light: #d1fae5;--danger: #ef4444;--danger-light: #fee2e2;--warning: #f59e0b;--warning-light: #fef3c7;--shadow: 0 2px 8px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 25px -5px rgba(99, 102, 241, .1), 0 4px 10px -3px rgba(99, 102, 241, .06)}[data-theme=dark]{--bg-primary: #18181b;--bg-secondary: #1f1f23;--bg-tertiary: #27272a;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--border-color: #3f3f46;--border-hover: #52525b;--accent: #818cf8;--accent-hover: #a5b4fc;--accent-light: #312e81;--success: #34d399;--success-light: #064e3b;--danger: #f87171;--danger-light: #450a0a;--warning: #fbbf24;--warning-light: #422006;--shadow: 0 4px 12px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 30px -8px rgba(129, 140, 248, .15), 0 5px 12px -4px rgba(129, 140, 248, .1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}button{transition:background-color .2s,color .2s}a{transition:color .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1)}input,textarea,select{transition:border-color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),background-color .2s cubic-bezier(.4,0,.2,1)}input:focus,textarea:focus,select:focus{outline:none}.card,.friend-card,.message,.user-card{transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:fadeIn .35s cubic-bezier(.4,0,.2,1) forwards}.fade-in-up{animation:fadeInUp .4s cubic-bezier(.4,0,.2,1) forwards}.fade-in-down{animation:fadeInDown .4s cubic-bezier(.4,0,.2,1) forwards}.fade-in-scale{animation:fadeInScale .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.8) translateY(10px)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1) translateY(0)}}.message.sent{animation:slideInRight .3s cubic-bezier(.4,0,.2,1)}.message.received{animation:slideInLeft .3s cubic-bezier(.4,0,.2,1)}img{transition:opacity .25s ease}@keyframes gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gradient-bg{background:linear-gradient(-45deg,#6366f1,#8b5cf6,#a855f7,#6366f1);background-size:400% 400%;animation:gradient 15s ease infinite}[data-theme=dark] input,[data-theme=dark] textarea,[data-theme=dark] select{background-color:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] input:focus,[data-theme=dark] textarea:focus,[data-theme=dark] select:focus{border-color:var(--accent)}[data-theme=dark] input[type=date]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=datetime-local]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=month]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=week]::-webkit-calendar-picker-indicator,[data-theme=dark] input[type=time]::-webkit-calendar-picker-indicator{filter:invert(1)}[data-theme=dark] input[type=date]::-moz-calendar-picker-indicator,[data-theme=dark] input[type=datetime-local]::-moz-calendar-picker-indicator,[data-theme=dark] input[type=month]::-moz-calendar-picker-indicator,[data-theme=dark] input[type=week]::-moz-calendar-picker-indicator,[data-theme=dark] input[type=time]::-moz-calendar-picker-indicator{filter:invert(1)}[data-theme=dark] option{background-color:var(--bg-primary);color:var(--text-primary)}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);padding:20px}.login-container{background-color:var(--bg-primary);border-radius:8px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:30px}.login-header .welcome-text{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.login-header h1{font-size:32px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.password-label-row{display:flex;justify-content:space-between;align-items:center}.forgot-password-link{font-size:14px;color:var(--accent);text-decoration:none;transition:color .2s}.forgot-password-link:hover{color:var(--accent-hover)}.error-message{background-color:#dc35451a;border:1px solid var(--danger);color:var(--danger);padding:12px 16px;border-radius:6px;font-size:14px}.input-error{border-color:var(--danger)!important}.field-error{color:var(--danger);font-size:12px;margin-top:-8px}.submit-btn{padding:14px 24px;background-color:var(--accent);color:#212529;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}[data-theme=dark] .submit-btn{color:#212529}.login-footer{margin-top:20px;text-align:center}.toggle-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:color .2s}.toggle-btn:hover:not(:disabled){color:var(--text-primary)}.demo-info{margin-top:24px;padding-top:20px;border-top:1px solid var(--border-color);text-align:center}.demo-info p{font-size:13px;color:var(--text-muted)}.verification-code-container{display:flex;gap:12px}.verification-code-input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);outline:none;transition:border-color .2s,box-shadow .2s}.verification-code-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4950571a}.verification-code-input:disabled{opacity:.6;cursor:not-allowed}.send-code-btn{padding:12px 20px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.send-code-btn:hover:not(:disabled){background-color:var(--border-color)}.form-group input[type=date]{cursor:pointer}[data-theme=dark] .form-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}[data-theme=dark] .form-group input[type=date]::-moz-calendar-picker-indicator{filter:invert(1)}.optional-label{color:var(--text-muted);font-weight:400;font-size:13px}.birthday-input-container{display:flex;gap:12px;align-items:center}.clear-btn{padding:12px 20px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.deletion-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.deletion-modal{background-color:var(--bg-primary);border-radius:12px;width:100%;max-width:450px}.deletion-modal-header{text-align:center;padding:30px 30px 10px}.warning-icon-large{width:56px;height:56px;color:var(--danger)}.deletion-modal-content{text-align:center;padding:0 30px 25px}.deletion-modal-content h3{font-size:22px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.deletion-time{font-size:15px;color:var(--text-secondary);margin-bottom:8px}.deletion-time-value{font-size:18px;font-weight:600;color:var(--danger);margin-bottom:24px;padding:12px;background-color:#dc35451a;border:1px solid var(--danger);border-radius:8px}.deletion-info{font-size:15px;color:var(--text-secondary);margin-bottom:8px;line-height:1.6}.deletion-warning{font-size:16px;font-weight:600;color:var(--text-primary);margin-top:20px}.deletion-modal-actions{display:flex;gap:12px;padding:0 30px 30px}.cancel-deletion-btn,.continue-login-btn{flex:1;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-deletion-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.cancel-deletion-btn:hover{background-color:var(--border-color)}.continue-login-btn{background-color:var(--accent);color:#212529}.continue-login-btn:hover{background-color:var(--accent-hover)}.sponsor-container{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px;text-align:center}.terms-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.terms-content-wrapper{background-color:var(--bg-primary);border-radius:16px;padding:32px;max-width:500px;width:90%;position:relative}.terms-close-btn{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.terms-close-btn:hover{background-color:var(--bg-secondary)}.terms-content{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:20px;text-align:left;margin:20px 0;max-height:300px;overflow-y:auto}.terms-content h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.terms-list{list-style:none;padding:0;margin:0}.terms-list li{color:var(--text-secondary);font-size:14px;line-height:1.8;margin-bottom:12px;padding-left:24px;position:relative}.terms-list li:before{content:"•";position:absolute;left:8px;color:var(--accent)}.terms-checkbox-label{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;cursor:pointer;-webkit-user-select:none;user-select:none}.terms-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.terms-checkbox-label span{color:var(--text-primary);font-size:14px}.continue-btn{padding:12px 32px;background-color:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:16px;font-weight:500;cursor:not-allowed;transition:all .2s;width:100%}.continue-btn.active{background-color:var(--accent);color:#fff;border:none;cursor:pointer}.continue-btn.active:hover{background-color:var(--accent-hover)}.sponsor-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.sponsor-header p{color:var(--text-secondary);font-size:14px;margin:0 0 24px}.sponsor-options{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}.sponsor-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.sponsor-btn:hover:not(:disabled){opacity:.9}.sponsor-icon{font-size:20px}.afadian-btn{background-color:#7c3aed;color:#fff}.afadian-btn:hover:not(:disabled){background-color:#6d28d9}.alipay-btn{background-color:#1677ff;color:#fff}.alipay-btn:hover:not(:disabled){background-color:#0958d9}.wechat-btn{background-color:#07c160;color:#fff}.wechat-btn:hover:not(:disabled){background-color:#06ad56}.sponsor-tips p{color:var(--text-muted);font-size:13px;margin:0}.qr-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.qr-content{background-color:var(--bg-primary);border-radius:16px;padding:32px;max-width:400px;width:90%;position:relative;text-align:center}.qr-close-btn{position:absolute;top:12px;right:12px;background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.qr-close-btn:hover{background-color:var(--bg-secondary)}.qr-image{width:100%;max-width:300px;height:auto;border-radius:8px;margin:16px 0}.qr-tip{color:var(--text-secondary);font-size:14px;margin:0}.home-page{padding:24px;min-height:calc(100vh - 48px)}.page-header{margin-bottom:28px}.page-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:10px;letter-spacing:-.02em}.page-header p{color:var(--text-secondary);font-size:15px}.search-bar{margin-bottom:24px;position:relative;display:flex;align-items:center}.search-bar svg{position:absolute;left:16px}.search-input{width:100%;padding:14px 18px 14px 48px;border:2px solid var(--border-color);border-radius:14px;background-color:var(--bg-primary);color:var(--text-primary);font-size:16px;transition:border-color .2s}.search-input:focus{border-color:var(--border-hover)}.search-input:hover{border-color:var(--border-hover)}.users-list{display:flex;flex-direction:column;gap:14px}.empty-state{text-align:center;padding:60px 24px;color:var(--text-secondary)}.user-card{display:flex;align-items:center;gap:16px;padding:18px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;transition:border-color .2s ease;cursor:pointer;position:relative;overflow:hidden}.user-card:hover{border-color:var(--border-hover)}.user-avatar-section{flex-shrink:0}.user-avatar-wrapper{position:relative;width:68px;height:68px}.user-avatar-large{width:68px;height:68px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;color:var(--text-primary);overflow:hidden;border:3px solid var(--border-color)}.online-dot{position:absolute;bottom:4px;right:4px;width:20px;height:20px;background-color:var(--success);border:3px solid var(--bg-primary);border-radius:50%;z-index:10}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.user-info-section{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.user-name-row{display:flex;align-items:center;gap:12px;margin-bottom:6px}.user-name{font-size:19px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.user-level{font-size:13px;font-weight:700;color:#21254f;background-color:var(--bg-tertiary);padding:5px 12px;border-radius:14px;border:1px solid var(--border-color)}[data-theme=dark] .user-level{color:#fff}.user-stats{display:flex;align-items:center;gap:18px;flex-wrap:wrap}.user-stats span{font-size:14px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.online-indicator{font-size:12px;font-weight:600;color:var(--success)!important;background-color:var(--success-light);padding:4px 10px;border-radius:12px}.mutual-indicator{font-size:12px;font-weight:600;color:var(--accent)!important;background-color:var(--accent-light);padding:4px 10px;border-radius:12px}.user-action-section{flex-shrink:0}.action-btn{padding:11px 22px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s cubic-bezier(.4,0,.2,1),transform .15s ease,box-shadow .2s ease;border:none;display:flex;align-items:center;gap:8px}.follow-btn{background-color:var(--accent);color:#fff!important}.follow-btn:hover{background-color:var(--accent-hover)}[data-theme=dark] .follow-btn{background-color:var(--accent);color:#fff!important}[data-theme=dark] .follow-btn:hover{background-color:var(--accent-hover)}.unfollow-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.unfollow-btn:hover{background-color:var(--border-color)}.mutual-btn{background-color:var(--accent-light);color:var(--accent);border:1px solid rgba(99,102,241,.3)}.mutual-btn:hover{background-color:#6366f133}.error-state{text-align:center;padding:60px 24px}.error-state .error-icon{font-size:64px;margin-bottom:20px}.error-state h2{font-size:24px;color:var(--text-primary);margin-bottom:10px;font-weight:700}.error-state p{color:var(--text-secondary);font-size:15px}.user-info-header{margin-bottom:28px;padding:20px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:18px}.user-info-header-top{display:flex;align-items:center;gap:18px;position:relative;z-index:1}.user-avatar-wrapper-large{position:relative;width:72px;height:72px;flex-shrink:0}.user-avatar-large-header{width:72px;height:72px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:var(--text-primary);overflow:hidden;border:3px solid var(--border-color)}.user-avatar-large-header img{width:100%;height:100%;object-fit:cover}.online-dot-large{position:absolute;bottom:4px;right:4px;width:20px;height:20px;background-color:var(--success);border:3px solid var(--bg-primary);border-radius:50%;z-index:10}.daily-reward-section{display:flex;align-items:center;gap:12px;margin-left:auto}.toggle-sign-in-records-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--border-color);background-color:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease,transform .15s ease}.toggle-sign-in-records-btn:hover{background-color:var(--border-color);transform:scale(1.05)}.sign-in-records{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color);animation:fadeInUp .3s ease}.sign-in-records-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.sign-in-records-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.monthly-points{font-size:14px;color:var(--text-secondary);font-weight:600;padding:6px 12px;background:var(--bg-tertiary);border-radius:12px}.sign-in-calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;max-width:420px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:10px;background-color:var(--bg-tertiary);color:var(--text-secondary);font-size:11px;padding:4px;gap:2px;min-height:40px;transition:transform .15s ease,box-shadow .15s ease}.calendar-day:hover:not(.empty){box-shadow:0 2px 8px #0000001a}.calendar-day.empty{background-color:transparent}.calendar-day.today{border:2px solid var(--accent);background:var(--accent-light);color:var(--accent);font-weight:700}.calendar-day.signed{background-color:var(--success-light);color:var(--success);font-weight:600}.calendar-day.holiday{background-color:var(--warning-light);color:var(--warning)}.calendar-day.holiday.signed{background-color:var(--success-light)}.holiday-emoji{font-size:12px;line-height:1}.day-number{font-weight:600}.sign-in-info{display:flex;align-items:center;gap:2px;color:var(--success);font-weight:700;font-size:10px}.user-level-info{display:flex;align-items:center;gap:14px}.level-badge{font-size:19px;font-weight:800;color:#21254f;background-color:var(--bg-tertiary);padding:10px 18px;border-radius:18px;border:2px solid var(--border-color)}[data-theme=dark] .level-badge{color:#fff}.points-info{font-size:16px;color:var(--text-secondary);font-weight:600}.daily-reward-btn{padding:13px 26px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:background-color .2s;border:none;display:flex;align-items:center;gap:10px}.daily-reward-btn.available{background-color:#4caf50;color:#fff}.daily-reward-btn.available:hover{background-color:#388e3c}.daily-reward-btn.claimed{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;border:1px dashed var(--border-color)}.daily-reward-btn:disabled{opacity:.7}.add-friend-btn{background-color:#495057!important;color:#fff!important}.add-friend-btn:hover{background-color:#6c757d!important}[data-theme=dark] .add-friend-btn{background-color:#495057!important;color:#fff!important}[data-theme=dark] .add-friend-btn:hover{background-color:#6c757d!important}.friend-btn{background-color:var(--bg-tertiary);color:var(--text-secondary);cursor:not-allowed;border:1px dashed var(--border-color)}.developer-birthday-section{margin-bottom:16px}.developer-birthday-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.developer-birthday-left{display:flex;align-items:center;gap:16px;flex:1}.developer-avatar-wrapper{position:relative}.developer-avatar{width:60px;height:60px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--text-primary);overflow:hidden;border:3px solid var(--border-color)}.developer-avatar img{width:100%;height:100%;object-fit:cover}.developer-info{display:flex;flex-direction:column;gap:8px}.developer-name{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.developer-description{font-size:14px;color:var(--text-secondary);margin:0}.developer-birthday-right{flex-shrink:0}.birthday-btn{background-color:#ff4081;color:#fff}.birthday-btn:hover{background-color:#e91e63}.birthday-countdown strong{font-size:28px;font-weight:800;color:#ff4081}.feedback-section{margin-bottom:16px}.feedback-card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.feedback-card-left{flex:1}.feedback-card-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.feedback-card-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.feedback-card-right{flex-shrink:0}.feedback-btn{background-color:#495057;color:#fff}.feedback-btn:hover{background-color:#6c757d}[data-theme=dark] .feedback-btn{background-color:#495057;color:#fff}[data-theme=dark] .feedback-btn:hover{background-color:#6c757d}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.feedback-modal{background:var(--bg-primary);border-radius:16px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.feedback-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.feedback-modal .modal-header h2{margin:0;font-size:20px;color:var(--text-primary)}.feedback-modal .close-btn{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.feedback-modal .close-btn:hover{background:var(--bg-secondary)}.feedback-modal .modal-body{padding:24px}.feedback-modal .form-group{margin-bottom:20px}.feedback-modal .form-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.image-upload-area{border:2px dashed var(--border-color);border-radius:12px;padding:24px;text-align:center;transition:border-color .2s}.upload-btn{display:inline-block;padding:12px 24px;background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s}.upload-btn:hover{background:#495057;color:#fff}.uploaded-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-top:16px}.uploaded-image{position:relative;border-radius:8px;overflow:hidden}.uploaded-image img{width:100%;height:100px;object-fit:cover}.remove-image-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#000000b3;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.remove-image-btn:hover{background:#dc3545e6}.feedback-modal textarea{width:100%;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box}.feedback-modal textarea:focus{outline:none;border-color:#495057}.feedback-modal .modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:20px 24px;border-top:1px solid var(--border-color)}.feedback-modal .btn-secondary,.feedback-modal .btn-primary{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.feedback-modal .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.feedback-modal .btn-secondary:hover:not(:disabled){background:var(--border-color)}.feedback-modal .btn-primary{background:#495057;color:#fff;border:none}.feedback-modal .btn-primary:hover:not(:disabled){background:#6c757d}.feedback-modal .btn-primary:disabled,.feedback-modal .btn-secondary:disabled{opacity:.5;cursor:not-allowed}.dashboard-page{padding:32px;min-height:calc(100vh - 48px)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px}.stat-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:24px;display:flex;align-items:center;gap:16px;transition:border-color .2s}.stat-card:hover{border-color:var(--border-hover)}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{flex:1}.stat-value{font-size:32px;font-weight:600;color:var(--text-primary);line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:var(--text-secondary)}.content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.card-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.card-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.card-body{padding:24px}.status-list{display:flex;flex-direction:column;gap:16px}.status-item{display:flex;align-items:center;gap:12px;color:var(--text-primary);font-size:14px}.status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-indicator.online{background-color:var(--success);box-shadow:0 0 0 4px #28a74533}.system-stats{display:flex;justify-content:space-around;flex-wrap:wrap;gap:24px}.system-stat-item{display:flex;flex-direction:column;align-items:center;gap:12px}.stat-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-primary)}.pie-chart-container{position:relative;display:flex;align-items:center;justify-content:center}.pie-chart-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center}.percentage{font-size:18px;font-weight:600;color:var(--text-primary)}.pie-chart-progress{transition:stroke-dashoffset .5s ease}.memory-info{font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.dashboard-page{padding:20px}.content-grid{grid-template-columns:1fr}.system-stats{flex-direction:column;align-items:center}}.messages-page{padding:32px;min-height:calc(100vh - 48px)}.messages-page.chat-mode{display:flex;padding:0;height:calc(100vh - 48px)}.error-icon{font-size:48px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.header-left h1{font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.header-left p{color:var(--text-secondary);font-size:14px}.header-actions{display:flex;gap:8px}.action-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.select-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.select-btn:hover{background-color:var(--border-color)}.cancel-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.delete-btn{background-color:#e53935;color:#fff}.delete-btn:hover:not(:disabled){background-color:#c62828}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.messages-list{display:flex;flex-direction:column;gap:12px}.message-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;transition:all .2s;cursor:pointer;position:relative}.message-card:hover{box-shadow:var(--shadow)}.message-card.unread{border-left:3px solid var(--accent)}.message-card.selectable,.message-card.follow-message{cursor:pointer}.message-checkbox{width:20px;height:20px;border:2px solid var(--border-color);border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.message-checkbox.checked{background-color:var(--accent);border-color:var(--accent);color:#fff}.message-avatar{width:48px;height:48px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.message-avatar img{width:100%;height:100%;object-fit:cover}.message-content{flex:1;min-width:0}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.message-title{font-size:16px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clickable-name{color:var(--accent);cursor:pointer}.clickable-name:hover{text-decoration:underline}.action-text{color:var(--text-secondary)}.message-time{font-size:12px;color:var(--text-secondary);white-space:nowrap}.message-text{font-size:14px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unread-dot{width:10px;height:10px;border-radius:50%;background-color:var(--accent);flex-shrink:0}.delete-message-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s;opacity:0}.message-card:hover .delete-message-btn{opacity:1}.delete-message-btn:hover{background-color:#e539351a;color:#e53935}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:16px;color:var(--text-secondary)}.empty-state h2{color:var(--text-primary)}.chat-sidebar{width:280px;background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column}.chat-sidebar-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.chat-sidebar-header h3{font-size:18px;font-weight:600;color:var(--text-primary)}.close-chat-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s}.close-chat-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.mutual-friends-list{flex:1;overflow-y:auto;padding:8px}.no-friends{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-size:14px}.friend-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background-color .2s;position:relative}.friend-item:hover,.friend-item.active{background-color:var(--bg-tertiary)}.friend-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;font-weight:600;color:var(--text-primary)}.friend-info{flex:1;min-width:0}.friend-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.friend-level{font-size:12px;color:var(--text-secondary)}.online-dot-message{width:8px;height:8px;border-radius:50%;background-color:#4caf50;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.chat-view{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary)}.chat-header{padding:16px 20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px;background-color:var(--bg-secondary)}.chat-header .back-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s}.chat-header .back-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.chat-friend-info{display:flex;align-items:center;gap:12px}.chat-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;font-weight:600;color:var(--text-primary)}.chat-avatar img{width:100%;height:100%;object-fit:cover}.chat-friend-name{font-size:16px;font-weight:500;color:var(--text-primary)}.chat-friend-level{font-size:12px;color:var(--text-secondary)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}.chat-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary)}.chat-message{display:flex;max-width:70%}.chat-message.sent{align-self:flex-end}.chat-message.received{align-self:flex-start}.chat-message-content{padding:12px 16px;border-radius:16px;position:relative}.chat-message.sent .chat-message-content{background-color:var(--accent);color:#fff;border-bottom-right-radius:4px}.chat-message.received .chat-message-content{background-color:var(--bg-secondary);color:var(--text-primary);border-bottom-left-radius:4px}.chat-message-content p{margin:0;font-size:14px;line-height:1.4}.chat-time{font-size:10px;opacity:.7;display:block;margin-top:4px;text-align:right}.chat-input-container{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;gap:12px;background-color:var(--bg-secondary)}.chat-input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:24px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px;outline:none}.chat-input:focus{border-color:var(--accent)}.send-btn{padding:12px 24px;background-color:var(--accent);color:#fff;border:none;border-radius:24px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.send-btn:hover:not(:disabled){opacity:.9}.send-btn:disabled{opacity:.5;cursor:not-allowed}.friend-requests-section{margin-bottom:24px}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.friend-requests-list{display:flex;flex-direction:column;gap:12px}.friend-request-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px}.friend-request-card .request-avatar{width:56px;height:56px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:var(--text-primary);overflow:hidden;flex-shrink:0}.friend-request-card .request-avatar img{width:100%;height:100%;object-fit:cover}.friend-request-card .request-info{flex:1}.friend-request-card .request-name-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}.friend-request-card .request-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.friend-request-card .request-level{font-size:14px;font-weight:600;color:var(--accent);background-color:var(--bg-tertiary);padding:4px 10px;border-radius:12px}.friend-request-card .request-time{font-size:14px;color:var(--text-secondary);margin:0}.friend-request-card .request-actions{flex-shrink:0;display:flex;gap:12px}.friend-request-card .request-actions .accept-btn{background-color:var(--success);color:#fff}.friend-request-card .request-actions .accept-btn:hover:not(:disabled){background-color:#2e7d32}.friend-request-card .request-actions .reject-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.friend-request-card .request-actions .reject-btn:hover:not(:disabled){background-color:var(--border-color)}.friend-request-card .request-actions .action-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 768px){.messages-page{padding:20px}.page-header{flex-direction:column;gap:16px}.chat-sidebar{width:100%;position:fixed;left:0;top:0;bottom:0;z-index:100}.friend-request-card{flex-direction:column;align-items:flex-start}.friend-request-card .request-actions{width:100%}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media (pointer: coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.avatar-cropper-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000}.avatar-cropper-modal{background-color:var(--bg-primary);border-radius:12px;padding:24px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.avatar-cropper-modal h3{margin:0 0 8px;color:var(--text-primary);font-size:20px}.avatar-cropper-modal p{margin:0 0 20px;color:var(--text-secondary);font-size:14px}.crop-container{display:flex;flex-direction:column;align-items:center;margin-bottom:20px}.cropper-actions{display:flex;justify-content:flex-end;gap:12px}.cropper-actions button{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cropper-actions .btn-secondary{background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary)}.cropper-actions .btn-secondary:hover{background-color:var(--border-color)}.cropper-actions .btn-primary{background-color:#495057!important;border:1px solid #495057!important;color:#fff!important}.cropper-actions .btn-primary:hover{background-color:#6c757d!important}[data-theme=dark] .cropper-actions .btn-primary{background-color:#495057!important;border-color:#495057!important;color:#fff!important}[data-theme=dark] .cropper-actions .btn-primary:hover{background-color:#adb5bd!important;color:#212529!important}.settings-page{padding:24px;min-height:calc(100vh - 48px);width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.settings-container{max-width:800px;width:100%;display:flex;flex-direction:column;gap:24px;box-sizing:border-box}.settings-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:24px;width:100%;box-sizing:border-box;overflow:hidden}.settings-section h2{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.avatar-section{display:flex;gap:24px;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap}.avatar-preview{width:120px;height:120px;border-radius:50%;background-color:var(--bg-tertiary);overflow:hidden;flex-shrink:0}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:600;color:var(--text-primary)}.avatar-actions{display:flex;flex-direction:column;gap:12px;padding-top:8px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.btn-primary{background-color:#495057;color:#fff;border:none}[data-theme=dark] .btn-primary{background-color:#6c757d}[data-theme=dark] .btn-primary:hover:not(:disabled){background-color:#adb5bd}.btn-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background-color:var(--border-color);border-color:var(--border-hover)}.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;width:100%}.info-item{display:flex;flex-direction:column;gap:4px;min-width:0}.info-item label{font-size:13px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;color:var(--text-primary);word-break:break-all;overflow-wrap:break-word}.info-value input[type=date]{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:14px;transition:border-color .2s,box-shadow .2s;outline:none}.info-value input[type=date]:focus{border-color:var(--accent);box-shadow:0 0 0 3px #6366f11a}[data-theme=dark] .info-value input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}[data-theme=dark] .info-value input[type=date]::-moz-calendar-picker-indicator{filter:invert(1)}.optional-label{color:var(--text-muted);font-weight:400;font-size:12px;text-transform:none;letter-spacing:normal}.birthday-value{display:flex;flex-direction:column;gap:8px}.birthday-input-container{display:flex;gap:12px;align-items:center;width:100%}.birthday-input-container input[type=date]{flex:1}.clear-btn{padding:10px 20px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.clear-btn:hover:not(:disabled){background-color:var(--border-color)}.clear-btn:disabled{opacity:.6;cursor:not-allowed}.setting-item{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:20px}.setting-item:last-child{margin-bottom:0}.setting-info{flex:1;min-width:0}.setting-info label{display:block;font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.setting-info p{font-size:13px;color:var(--text-secondary)}.theme-options{display:flex;gap:12px;flex-shrink:0}.theme-option{padding:10px 16px;border-radius:6px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.theme-option:hover{background-color:var(--border-color);border-color:var(--border-hover)}.theme-option.active{background-color:#495057;color:#fff;border-color:#495057}[data-theme=dark] .theme-option.active{background-color:#6c757d;color:#fff;border-color:#6c757d}.about-info{text-align:center}.about-info p{font-size:14px;color:var(--text-primary);margin-bottom:8px}.about-description{color:var(--text-secondary)!important;margin-top:16px;line-height:1.6}.social-links{margin-top:24px;display:flex;justify-content:center}.social-link{display:flex;align-items:center;gap:12px;padding:12px 24px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);text-decoration:none;font-size:15px;font-weight:500;transition:all .2s;cursor:pointer}.social-link:hover{background-color:var(--border-color);border-color:var(--border-hover)}.danger-section{border:1px solid #dc3545;border-radius:8px;padding:16px}.danger-section h2{color:#dc3545}.danger-item{background-color:#f8d7da;border:1px solid #dc3545;border-radius:8px;padding:16px}[data-theme=dark] .danger-item{background-color:#2c0b0e;border-color:#dc3545}.btn-danger{padding:10px 20px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover:not(:disabled){background-color:#bb2d3b}.btn-danger:disabled{opacity:.4;cursor:not-allowed}.delete-warning{background-color:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:20px;margin-bottom:20px;display:flex;align-items:flex-start;gap:16px}[data-theme=dark] .delete-warning{background-color:#332701;border-color:#856404}.warning-icon-large{font-size:36px;color:#ffc107;flex-shrink:0}.warning-text h4{margin:0 0 12px;color:#856404;font-size:16px}[data-theme=dark] .warning-text h4{color:#ffc107}.warning-text p{margin:8px 0;color:#856404;font-size:14px;line-height:1.6}[data-theme=dark] .warning-text p{color:#ffc107}.success-message{background-color:#28a7451a;border:1px solid #28a745;color:#28a745;padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:20px}.btn-link{background:none;border:none;color:#495057;font-size:14px;cursor:pointer;padding:4px 8px;margin-left:8px;text-decoration:underline;white-space:nowrap}.btn-link:hover:not(:disabled){color:#6c757d}.btn-link:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .btn-link{color:#fff}[data-theme=dark] .btn-link:hover:not(:disabled){color:#dee2e6}.toggle-switch{position:relative;display:inline-block;width:50px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-switch label{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:26px;border:1px solid var(--border-color)}.toggle-switch label:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:2px;background-color:var(--text-secondary);transition:.3s;border-radius:50%}.toggle-switch input:checked+label{background-color:#495057;border-color:#495057}[data-theme=dark] .toggle-switch input:checked+label{background-color:#6c757d;border-color:#6c757d}.toggle-switch input:checked+label:before{transform:translate(22px);background-color:var(--bg-primary)}.toggle-switch input:disabled+label{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background-color:var(--bg-primary);border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-close{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:24px}.modal-body .form-group{margin-bottom:20px}.modal-body .form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.modal-body .form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.modal-body .form-group input:focus{outline:none;border-color:var(--border-hover)}.modal-body .form-group input:disabled{opacity:.6;cursor:not-allowed}.modal-body .input-error{border-color:var(--danger)!important}.modal-body .field-error{color:var(--danger);font-size:12px;margin-top:4px}.modal-body .verification-code-container{display:flex;gap:12px}.modal-body .verification-code-input{flex:1}.modal-body .send-code-btn{padding:12px 20px;background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.modal-body .send-code-btn:hover:not(:disabled){background-color:var(--border-color)}.modal-body .send-code-btn:disabled{opacity:.6;cursor:not-allowed}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:24px;border-top:1px solid var(--border-color)}@media (max-width: 768px){.settings-page{padding:20px}.avatar-section{flex-direction:column;align-items:center;text-align:center}.avatar-actions{align-items:center}.setting-item{flex-direction:column;align-items:flex-start}.theme-options{width:100%}.theme-option{flex:1}.modal-content{width:95%;margin:10px}.modal-header,.modal-body,.modal-footer{padding:20px}}.user-profile-page{padding:32px;min-height:calc(100vh - 48px)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.error-state h2{color:var(--text-primary)}.error-state button{padding:10px 24px;background-color:var(--accent);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.profile-header{margin-bottom:24px}.back-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;padding:8px 12px;border-radius:6px;transition:background-color .2s,color .2s}.back-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.profile-card{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden;max-width:100%}.profile-banner{height:100px;background-color:var(--accent);position:relative}.profile-avatar-large{width:100px;height:100px;border-radius:50%;background-color:var(--bg-tertiary);border:4px solid var(--bg-secondary);position:absolute;bottom:-50px;left:24px;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:600;color:var(--text-primary);overflow:hidden}.profile-avatar-large img{width:100%;height:100%;object-fit:cover}.profile-info{padding:60px 24px 24px}.profile-name-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.profile-name-row h1{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.profile-level{background-color:var(--bg-tertiary);color:var(--text-secondary);padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.online-badge{background-color:#4caf5033;color:#4caf50;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.profile-stats{display:flex;gap:32px;margin-bottom:20px}.profile-stat{display:flex;flex-direction:column;gap:4px}.stat-number{font-size:20px;font-weight:600;color:var(--text-primary)}.stat-label{font-size:13px;color:var(--text-secondary)}.profile-meta{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.meta-item{display:flex;gap:12px;font-size:14px}.meta-label{color:var(--text-secondary);min-width:80px}.meta-value{color:var(--text-primary)}.profile-actions{display:flex;gap:12px}.add-friend-btn,.friend-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none;background-color:#495057;color:#fff}.add-friend-btn:hover:not(:disabled){background-color:#6c757d}.add-friend-btn:disabled,.friend-btn{opacity:.6;cursor:not-allowed}[data-theme=dark] .add-friend-btn{background-color:#495057;color:#fff}[data-theme=dark] .add-friend-btn:hover:not(:disabled){background-color:#6c757d}.friend-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}@media (max-width: 768px){.user-profile-page{padding:20px}.profile-card{margin:0 -20px;border-radius:0}.profile-stats{gap:24px}}.announcements-page{padding:24px;min-height:calc(100vh - 48px);width:100%;max-width:100%;box-sizing:border-box;overflow-x:hidden}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary);font-size:16px}.announcements-list{display:flex;flex-direction:column;gap:20px;width:100%;max-width:100%}.announcement-card{padding:24px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;position:relative;transition:border-color .2s}.announcement-card:hover{border-color:var(--border-hover)}.announcement-card.latest{border-left:4px solid #495057}.latest-badge{background-color:#495057;color:#fff;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600}.announcement-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.announcement-header-left{display:flex;flex-direction:column;gap:8px;flex:1;min-width:0}.announcement-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;word-break:break-word}.announcement-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.delete-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background-color:#dc35451a;color:var(--danger);border:1px solid var(--danger);flex-shrink:0}.delete-btn:hover{background-color:var(--danger);color:#fff}.announcement-date{font-size:13px;color:var(--text-secondary)}.announcement-content{color:var(--text-secondary);line-height:1.8}.announcement-content p{margin:0;white-space:pre-wrap;word-wrap:break-word}.announcement-author{margin-top:16px;text-align:right;font-size:14px;color:var(--text-secondary);font-style:italic}.btn-primary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;background-color:#495057;color:#fff;border:none}.btn-primary:hover:not(:disabled){background-color:#6c757d}@media (max-width: 768px){.announcements-page,.announcement-card{padding:20px}.announcement-header{flex-direction:column;align-items:flex-start}.announcement-title{font-size:18px}}.friend-requests-page{padding:24px;min-height:calc(100vh - 48px)}.requests-list{display:flex;flex-direction:column;gap:16px}.request-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px}.request-avatar{width:56px;height:56px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:var(--text-primary);overflow:hidden;flex-shrink:0}.request-avatar img{width:100%;height:100%;object-fit:cover}.request-info{flex:1}.request-name-row{display:flex;align-items:center;gap:12px;margin-bottom:4px}.request-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.request-level{font-size:14px;font-weight:600;color:var(--accent);background-color:var(--bg-tertiary);padding:4px 10px;border-radius:12px}.request-time{font-size:14px;color:var(--text-secondary);margin:0}.request-actions{flex-shrink:0;display:flex;gap:12px}.accept-btn{background-color:var(--success);color:#fff}.accept-btn:hover:not(:disabled){background-color:#2e7d32}.reject-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.reject-btn:hover:not(:disabled){background-color:var(--border-color)}.friends-page{padding:24px;min-height:calc(100vh - 48px)}.page-header{margin-bottom:24px}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-secondary)}.error-state{text-align:center;padding:48px 24px}.error-state h2{font-size:24px;color:var(--text-primary);margin-bottom:8px}.error-state p{color:var(--text-secondary);font-size:16px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;gap:16px}.friends-list{display:flex;flex-direction:column;gap:16px}.friend-card{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;transition:border-color .2s;cursor:pointer}.friend-card:hover{border-color:var(--border-hover)}.friend-avatar-section{flex-shrink:0}.friend-avatar-wrapper{position:relative;width:64px;height:64px}.friend-avatar{width:64px;height:64px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:var(--text-primary);overflow:hidden}.friend-avatar img{width:100%;height:100%;object-fit:cover}.online-dot{position:absolute;bottom:0;right:0;width:18px;height:18px;background-color:var(--success);border:3px solid var(--bg-primary);border-radius:50%;z-index:10}.unread-badge{position:absolute;top:-4px;right:-4px;background-color:#e53935;color:#fff;font-size:11px;font-weight:600;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;z-index:10;border:2px solid var(--bg-primary)}.friend-info-section{flex:1}.friend-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.friend-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.friend-level{font-size:14px;font-weight:600;color:#21254f;background-color:var(--bg-tertiary);padding:4px 10px;border-radius:12px}[data-theme=dark] .friend-level{color:#fff}.role-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px;white-space:nowrap}.developer-badge{background-color:#ff6b35;color:#fff}.admin-badge{background-color:#4a90d9;color:#fff}.birthday-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px;white-space:nowrap;background-color:#ff4081;color:#fff}.online-indicator{font-size:12px;font-weight:500;color:var(--success)!important;background-color:#28a7451a;padding:3px 8px;border-radius:10px}.friend-action-section{flex-shrink:0;display:flex;gap:12px}.action-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;border:none;display:flex;align-items:center;gap:6px}.action-btn:disabled{opacity:.7;cursor:not-allowed}.chat-btn{background-color:#495057;color:#fff}.chat-btn:hover:not(:disabled){background-color:#343a40}.remove-btn{background-color:var(--bg-tertiary);color:var(--text-primary)}.remove-btn:hover:not(:disabled){background-color:#d32f2f;color:#fff}[data-theme=dark] .chat-btn{background-color:#495057;color:#fff}[data-theme=dark] .chat-btn:hover:not(:disabled){background-color:#6c757d}.chat-page{height:calc(100vh - 48px);display:flex;flex-direction:column;background-color:var(--bg-primary)}.loading-container{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-secondary)}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:24px;text-align:center}.error-state h2{font-size:24px;color:var(--text-primary);margin:16px 0 8px;font-weight:700}.error-state p{color:var(--text-secondary);font-size:16px;margin-bottom:24px}.back-btn{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s cubic-bezier(.4,0,.2,1),transform .15s ease;border:none;background-color:var(--bg-tertiary);color:var(--text-primary);display:flex;align-items:center;gap:8px}.back-btn:hover{background-color:var(--border-color)}.chat-header{display:flex;align-items:center;gap:16px;padding:18px 24px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color);position:relative;z-index:10}.chat-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background-color:var(--border-color);opacity:.3}.chat-header .back-btn{padding:10px;background-color:transparent;border-radius:12px}.chat-header .back-btn:hover{background-color:var(--bg-tertiary)}.chat-friend-info{display:flex;align-items:center;gap:14px;flex:1}.chat-friend-avatar{width:52px;height:52px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:var(--text-primary);border:2px solid var(--border-color);position:relative}.chat-friend-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.chat-friend-details{display:flex;flex-direction:column;gap:3px}.chat-friend-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chat-friend-details h3{font-size:19px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.01em}.chat-friend-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.chat-level-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px;white-space:nowrap;background-color:var(--bg-tertiary);color:var(--text-primary)}.chat-role-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px;white-space:nowrap}.chat-developer-badge{background-color:#ff6b35;color:#fff}.chat-admin-badge{background-color:#4a90d9;color:#fff}.chat-birthday-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:12px;white-space:nowrap;background-color:#ff4081;color:#fff}.online-status{font-size:14px;color:var(--text-secondary);font-weight:500;display:flex;align-items:center;gap:6px}.online-status:before{content:"";width:8px;height:8px;border-radius:50%;background-color:var(--text-muted)}.online-status.online{color:var(--success)}.online-status.online:before{background-color:var(--success)}.chat-messages{flex:1;overflow-y:auto;padding:26px 24px;display:flex;flex-direction:column;gap:14px}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:10px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.empty-messages{display:flex;align-items:center;justify-content:center;flex:1;color:var(--text-secondary);font-size:15px}.message{display:flex;max-width:72%;position:relative}.message.sent{align-self:flex-end}.message.received{align-self:flex-start}.message-content{padding:14px 18px;border-radius:18px;position:relative;transition:transform .1s ease;word-wrap:break-word;word-break:break-word}.message:hover .message-content{opacity:.95}.message.sent .message-content{background-color:var(--accent);color:#fff;border-bottom-right-radius:6px}[data-theme=dark] .message.sent .message-content{background-color:var(--accent);color:#fff}[data-theme=dark] .message.sent .message-time{color:#ffffffd9}.message.received .message-time{color:var(--text-secondary)}.message.received .message-content{background:var(--bg-primary);color:var(--text-primary);border-bottom-left-radius:6px;border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000d}.message.recalled .message-content{opacity:.5;font-style:italic;background:var(--bg-tertiary)!important;color:var(--text-muted)!important;box-shadow:none!important;border:1px dashed var(--border-color)!important}.message-content p{margin:0 0 6px;font-size:15px;line-height:1.5}.message-time{font-size:12px;opacity:.75;display:block;text-align:right;font-weight:500}.message-date-divider{display:flex;align-items:center;justify-content:center;margin:12px 0}.message-date-divider span{background-color:var(--bg-tertiary);padding:8px 20px;border-radius:20px;font-size:13px;color:var(--text-secondary);font-weight:600;border:1px solid var(--border-color)}.delete-chat-btn{width:42px;height:42px;border-radius:12px;border:none;background-color:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.delete-chat-btn:hover{background-color:var(--danger-light);color:var(--danger)}.context-menu{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;padding:8px;box-shadow:0 8px 24px #0003;z-index:1000;min-width:140px;animation:fadeInScale .15s ease}.context-menu-item{width:100%;padding:12px 18px;border:none;background:none;color:var(--text-primary);font-size:14px;font-weight:600;text-align:left;cursor:pointer;border-radius:10px;transition:all .15s ease}.context-menu-item:hover{background:var(--danger-light);color:var(--danger)}.chat-input-container{padding:18px 24px;background:var(--bg-primary);border-top:1px solid var(--border-color);width:100%;box-sizing:border-box;position:relative}.chat-input-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background-color:var(--border-color);opacity:.2}.chat-input-form{display:flex;gap:14px;width:100%;align-items:flex-end}.chat-input{flex:1;min-width:0;padding:14px 20px;border:2px solid var(--border-color);border-radius:26px;background:var(--bg-secondary);color:var(--text-primary);font-size:15px;transition:border-color .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),background-color .2s ease;box-sizing:border-box;resize:none;min-height:52px;max-height:140px;overflow-y:auto;line-height:1.5;font-family:inherit}.chat-input:focus{outline:none;border-color:var(--accent);background:var(--bg-primary);box-shadow:0 0 0 4px var(--accent-light)}.chat-input:hover{border-color:var(--border-hover)}.chat-input:disabled{opacity:.6;cursor:not-allowed}.send-btn{width:48px;height:48px;border-radius:50%;border:none;background-color:var(--accent);color:#fff;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.send-btn:hover:not(:disabled){background-color:var(--accent-hover)}.send-btn:active:not(:disabled){transform:scale(.95)}.send-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary);box-shadow:none;transform:none}.send-btn svg{display:block;width:28px;height:28px}.stats-page{padding:32px;min-height:calc(100vh - 48px)}.page-header h1{font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.page-header p{color:var(--text-secondary);font-size:14px}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}.level-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:32px;margin-bottom:24px;box-shadow:var(--shadow)}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.level-number{font-size:48px;font-weight:700;color:var(--accent);text-align:center}.stats-right{display:flex;gap:32px;align-items:flex-end}.exp-display{display:flex;flex-direction:column;align-items:flex-start}.exp-label{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.exp-value{font-size:32px;font-weight:700;color:var(--text-primary)}.points-display{display:flex;flex-direction:column;align-items:flex-start}.points-label{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.points-value{font-size:20px;font-weight:700;color:var(--success)}.progress-section{margin-bottom:24px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;color:var(--text-secondary)}.progress-bar{height:12px;background-color:var(--bg-tertiary);border-radius:6px;overflow:hidden}.progress-fill{height:100%;background-color:var(--accent);border-radius:6px;transition:width .3s ease}.level-actions{display:flex;gap:12px}.upgrade-btn{flex:1;padding:16px 32px;border:none;border-radius:12px;background-color:var(--accent);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.upgrade-btn:hover:not(:disabled){background-color:var(--accent-hover)}.upgrade-btn:disabled{opacity:.6;cursor:not-allowed}.convert-btn{padding:16px 32px;border:1px solid var(--border-color);border-radius:12px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.convert-btn:hover{background-color:var(--border-color)}.info-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:32px;box-shadow:var(--shadow)}.info-card h3{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:24px}.info-list{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;align-items:center;gap:16px;padding:16px;background-color:var(--bg-secondary);border-radius:12px}.info-icon{font-size:32px}.info-text{flex:1;text-align:center}.info-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.info-desc{font-size:14px;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background-color:var(--bg-primary);border-radius:16px;padding:32px;width:90%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h3{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.modal-close{width:40px;height:40px;border:none;border-radius:8px;background-color:transparent;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.modal-close:hover{background-color:var(--bg-tertiary)}.modal-body{margin-bottom:24px}.modal-body p{margin:0 0 16px;color:var(--text-secondary)}.form-group{margin-bottom:16px}.input-group{display:flex;gap:12px}.input-group input{flex:1;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:16px;transition:border-color .2s}.input-group input:focus{outline:none;border-color:var(--accent)}.btn-secondary{padding:12px 20px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{padding:12px 24px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-cancel:hover{background-color:var(--border-color)}.btn-confirm{padding:12px 24px;border:none;border-radius:8px;background-color:var(--accent);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.btn-confirm:hover:not(:disabled){background-color:var(--accent-hover)}.btn-confirm:disabled{opacity:.6;cursor:not-allowed}.convert-modal{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;padding:32px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto}.convert-info{display:flex;justify-content:space-between;padding:16px;background-color:var(--bg-secondary);border-radius:12px;margin-bottom:24px}.convert-item{display:flex;flex-direction:column;align-items:flex-start}.convert-label{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.convert-value{font-size:18px;font-weight:600;color:var(--text-primary)}.convert-input-wrapper{display:flex;gap:12px}.convert-input-wrapper input{flex:1;padding:14px 16px;border:1px solid var(--border-color);border-radius:10px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:16px;transition:border-color .2s}.convert-input-wrapper input:focus{outline:none;border-color:var(--accent)}.convert-input-wrapper input:disabled{opacity:.6;cursor:not-allowed}.convert-all-btn{padding:14px 20px;border:1px solid var(--border-color);border-radius:10px;background-color:var(--bg-tertiary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.convert-all-btn:hover:not(:disabled){background-color:var(--border-color)}.convert-all-btn:disabled{opacity:.6;cursor:not-allowed}.convert-preview{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background-color:var(--bg-secondary);border-radius:12px;margin-top:16px;color:var(--text-secondary)}.preview-amount{font-size:18px;font-weight:600;color:var(--success)}.modal-footer{display:flex;gap:12px;justify-content:flex-end}.btn-primary{padding:14px 28px;border:none;border-radius:10px;background-color:var(--accent);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.stats-page{padding:20px}.level-card,.info-card{padding:24px}.level-header{flex-direction:column;align-items:center;gap:16px}.exp-display{align-items:center}.level-actions,.input-group{flex-direction:column}.modal-content{padding:24px}}.connected-apps-page{padding:24px;max-width:1200px;margin:0 auto}.connected-apps-page.loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.loading-spinner{font-size:18px;color:var(--text-secondary)}.error-state{text-align:center;padding:80px 24px}.error-icon{font-size:64px;margin-bottom:24px}.error-state h3{margin:0 0 12px;font-size:20px;font-weight:600;color:var(--text-primary)}.error-state p{color:var(--text-secondary);font-size:14px;max-width:400px;margin:0 auto 24px}.retry-btn{padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.retry-btn:hover{background:var(--accent-hover)}.page-header{margin-bottom:32px}.page-header h1{margin:0 0 8px;font-size:28px;font-weight:600;color:var(--text-primary)}.subtitle{margin:0;color:var(--text-secondary);font-size:14px}.empty-state{text-align:center;padding:80px 24px}.empty-icon{font-size:64px;margin-bottom:24px}.empty-state h3{margin:0 0 12px;font-size:20px;font-weight:600;color:var(--text-primary)}.empty-state p{color:var(--text-secondary);font-size:14px;max-width:400px;margin:0 auto}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.app-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:16px;transition:all .2s ease}.app-card:hover{border-color:var(--border-hover);box-shadow:0 4px 12px #0000001a}.app-icon{width:64px;height:64px;border-radius:12px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.app-icon img{width:100%;height:100%;border-radius:12px;object-fit:cover}.app-icon-placeholder{font-size:32px}.app-info{flex:1}.app-name{margin:0 0 8px;font-size:18px;font-weight:600;color:var(--text-primary)}.app-description{margin:0 0 12px;font-size:14px;color:var(--text-secondary);line-height:1.5}.app-meta{display:flex;flex-direction:column;gap:4px}.meta-item{font-size:12px;color:var(--text-tertiary)}.disconnect-btn{width:100%;padding:10px 16px;border:1px solid var(--danger-color);background:transparent;color:var(--danger-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.disconnect-btn:hover{background:var(--danger-color);color:#fff}@media (max-width: 768px){.connected-apps-page{padding:16px}.apps-grid{grid-template-columns:1fr}}.open-platform-layout{display:flex;min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.open-platform-sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width .3s ease;position:fixed;left:0;top:0;bottom:0;z-index:100}.open-platform-sidebar.closed{width:80px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-color);overflow:hidden}.logo{display:flex;flex-direction:column;gap:2px;overflow:hidden;flex-shrink:1}.logo span:first-child{font-size:20px;font-weight:700;color:var(--primary-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logo .subtitle{font-size:12px;color:var(--text-secondary);white-space:nowrap}.open-platform-sidebar.closed .logo{display:none}.open-platform-sidebar.closed .sidebar-header{justify-content:center;padding:20px 0}.toggle-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .2s}.toggle-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-nav{flex:1;padding:16px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:var(--text-secondary);text-decoration:none;margin-bottom:4px;transition:all .2s}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--primary-color);color:#fff}.open-platform-sidebar.closed .nav-item span{display:none}.open-platform-sidebar.closed .nav-item{justify-content:center;padding:12px}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.theme-toggle{background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:12px;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.back-to-main{background:none;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;padding:12px 16px;border-radius:10px;text-decoration:none;text-align:center;transition:all .2s;font-size:14px}.back-to-main:hover{background:var(--bg-hover);color:var(--text-primary)}.open-platform-sidebar.closed .back-to-main{display:none}.logout-btn{background:none;border:1px solid var(--danger-color);color:var(--danger-color);cursor:pointer;padding:12px 16px;border-radius:10px;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s}.logout-btn:hover{background:var(--danger-color);color:#fff}.open-platform-sidebar.closed .logout-btn span{display:none}.user-info-btn{display:flex;align-items:center;gap:12px;width:100%;background:none;border:1px solid var(--border-color);cursor:pointer;padding:12px 16px;border-radius:10px;transition:all .2s;justify-content:center}.open-platform-sidebar.open .user-info-btn{justify-content:flex-start}.user-info-btn:hover{background:var(--bg-hover)}.user-avatar{width:40px;height:40px;border-radius:50%;background-color:var(--bg-hover);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:600;font-size:16px;overflow:hidden;flex-shrink:0}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--text-secondary)}.user-menu{position:fixed;bottom:80px;left:16px;margin-bottom:8px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow);min-width:200px;overflow:hidden;z-index:9999}.open-platform-sidebar.closed~.user-menu,.open-platform-sidebar.closed .user-menu{left:86px}.user-menu-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-primary);text-decoration:none;font-size:14px;cursor:pointer;transition:background-color .2s;background:none;border:none;width:100%;text-align:left;box-sizing:border-box}.user-menu-item:hover{background-color:var(--bg-hover)}.user-menu-divider{height:1px;background-color:var(--border-color);margin:4px 0}.logout-item{color:#e53935!important}.logout-item:hover{background-color:#e539351a!important}.open-platform-main{flex:1;margin-left:260px;padding:32px;overflow-y:auto;transition:margin-left .3s ease}.open-platform-layout:has(.open-platform-sidebar.closed) .open-platform-main{margin-left:80px}@media (max-width: 768px){.open-platform-sidebar{transform:translate(-100%)}.open-platform-sidebar.open{transform:translate(0)}.open-platform-main{margin-left:0}.open-platform-layout:has(.open-platform-sidebar.closed) .open-platform-main{margin-left:0}}.api-keys-page{max-width:900px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-header h1{margin:0;font-size:28px;color:var(--text-primary)}.create-btn{background:var(--primary-color);color:#fff;border:none;padding:12px 24px;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.create-btn:hover{background:var(--primary-hover)}.error-message{background:#ef44441a;border:1px solid var(--danger-color);color:var(--danger-color);padding:12px 16px;border-radius:8px;margin-bottom:20px}.empty-state{text-align:center;padding:60px 20px;background:var(--bg-secondary);border-radius:16px;border:1px dashed var(--border-color)}.empty-state h3{margin:0 0 8px;font-size:20px;color:var(--text-primary)}.empty-state p{margin:0;color:var(--text-secondary)}.api-keys-list{display:flex;flex-direction:column;gap:16px}.api-key-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:20px;transition:all .2s}.api-key-card:hover{border-color:var(--primary-color);box-shadow:0 4px 12px #00000014}.api-key-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.api-key-name-section{flex:1}.api-key-name{margin:0;font-size:18px;color:var(--text-primary)}.edit-name{display:flex;gap:8px;align-items:center}.edit-name input{flex:1;max-width:300px;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:15px}.edit-name input:focus{outline:none;border-color:var(--primary-color)}.save-btn{background:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.save-btn:hover{background:var(--primary-hover)}.cancel-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:8px 16px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.status-badge{padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.status-badge.enabled{background:#10b9811a;color:#10b981}.status-badge.disabled{background:#6b72801a;color:#6b7280}.api-key-details{margin-bottom:16px}.api-key-value{display:flex;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.api-key-value .label{font-weight:500;color:var(--text-secondary);font-size:14px}.api-key-value code{background:var(--bg-primary);padding:8px 12px;border-radius:6px;font-family:Monaco,Consolas,monospace;font-size:14px;color:var(--text-primary);word-break:break-all}.full-key{color:var(--primary-color)}.masked-key{color:var(--text-secondary)}.copy-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.copy-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary-color)}.eye-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.eye-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary-color)}.api-key-meta{display:flex;gap:24px;flex-wrap:wrap}.meta-item{display:flex;gap:6px;font-size:14px;color:var(--text-secondary)}.meta-item .label{font-weight:500}.api-key-actions{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--border-color)}.action-btn{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:8px 16px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.action-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--primary-color)}.action-btn.delete{border-color:var(--danger-color);color:var(--danger-color)}.action-btn.delete:hover{background:var(--danger-color);color:#fff}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--bg-secondary);border-radius:16px;padding:24px;max-width:450px;width:100%;box-shadow:0 20px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{margin:0;font-size:20px;color:var(--text-primary)}.close-btn{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:4px;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.form-group input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-primary);color:var(--text-primary);font-size:15px;box-sizing:border-box;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.modal-actions .cancel-btn,.modal-actions .create-btn{padding:12px 24px;font-size:15px}.docs-page{max-width:900px}.docs-page h1{font-size:32px;margin:0 0 32px;color:var(--text-primary)}.doc-section{margin-bottom:40px}.doc-section h2{font-size:24px;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid var(--border-color);color:var(--text-primary)}.doc-section h3{font-size:18px;margin:24px 0 12px;color:var(--text-primary)}.doc-section h4{font-size:16px;margin:20px 0 10px;color:var(--text-primary)}.doc-section p{margin:0 0 16px;color:var(--text-secondary);line-height:1.7}.api-endpoint{display:flex;gap:12px;align-items:center;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;margin:12px 0}.method{padding:4px 12px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.method.get{background:#22c55e26;color:#22c55e}.method.post{background:#3b82f626;color:#3b82f6}.method.put{background:#fbbf2426;color:#fbbf24}.method.delete{background:#ef444426;color:#ef4444}.url{font-family:Monaco,Consolas,monospace;font-size:15px;color:var(--text-primary)}.code-block{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin:12px 0;overflow-x:auto}.code-block pre{margin:0;font-family:Monaco,Consolas,monospace;font-size:14px;line-height:1.6;color:var(--text-primary);white-space:pre-wrap;word-break:break-all}.warning-box{background:#fbbf241a;border:1px solid #fbbf24;border-radius:8px;padding:16px;margin:16px 0}.warning-box strong{color:#f59e0b}.warning-box code{background:#fbbf2433;padding:2px 6px;border-radius:4px;font-family:Monaco,Consolas,monospace;font-size:13px}.forgot-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);padding:20px}.forgot-password-container{background-color:var(--bg-primary);border-radius:8px;padding:40px;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.forgot-password-header{text-align:center;margin-bottom:30px}.forgot-password-header .welcome-text{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.forgot-password-header h1{font-size:32px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.forgot-password-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input{padding:12px 16px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #4950571a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#dc35451a;border:1px solid var(--danger);color:var(--danger);padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:20px}.success-message{background-color:#10b9811a;border:1px solid #10b981;color:#10b981;padding:12px 16px;border-radius:6px;font-size:14px;margin-bottom:20px}.submit-btn{padding:14px 24px;background-color:var(--accent);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.submit-btn:hover:not(:disabled){background-color:var(--accent-hover)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.forgot-password-footer{margin-top:20px;text-align:center}.toggle-btn{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;padding:8px 16px;border-radius:6px;transition:background-color .2s}.toggle-btn:hover:not(:disabled){background-color:var(--bg-hover)}.toggle-btn:disabled{opacity:.6;cursor:not-allowed}.sent-message{text-align:center;padding:20px 0}.sent-message p{color:var(--text-primary);font-size:16px;margin-bottom:12px}.sent-message .note{color:var(--text-secondary);font-size:14px}.disabled-input{background-color:var(--bg-secondary)!important;cursor:not-allowed}.code-input-group{display:flex;gap:10px}.code-input-group input{flex:1}.send-code-btn{padding:12px 16px;background-color:var(--accent);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .2s}.send-code-btn:hover:not(:disabled){background-color:var(--accent-hover)}.send-code-btn:disabled{opacity:.6;cursor:not-allowed}.layout{display:grid;grid-template-columns:auto 1fr;height:100vh;max-width:100vw;overflow:hidden}.sidebar{background-color:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;transition:width .3s;overflow:hidden;height:100%;position:relative}.sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#fff}.sidebar.open{width:270px}.sidebar.closed{width:76px}.sidebar-header{padding:20px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;min-height:70px;box-sizing:border-box}.sidebar-header h1{font-size:28px;font-weight:700;color:var(--text-primary);white-space:nowrap;margin:0;letter-spacing:-1px}.toggle-sidebar-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:10px;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.toggle-sidebar-btn:hover{background-color:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.05)}.sidebar-nav{flex:1;padding:18px 10px;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.nav-item{display:flex;align-items:center;gap:14px;padding:14px 16px;margin:4px 8px;color:var(--text-secondary);text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;box-sizing:border-box;border-radius:12px;position:relative}.sidebar.closed .nav-item{padding:14px 0;justify-content:center}.nav-item:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background-color:var(--bg-tertiary);color:#21254f;font-weight:600}[data-theme=dark] .nav-item.active{color:#fff}.nav-icon-wrapper{position:relative;min-width:26px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.nav-icon{min-width:26px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.unread-badge{position:absolute;top:-6px;right:-10px;background-color:var(--danger);color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;line-height:1}.nav-label{font-size:14px;font-weight:600}.sidebar-footer{padding:18px 12px;border-top:1px solid var(--border-color);box-sizing:border-box}.user-menu-container{position:relative}.user-info-btn{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;cursor:pointer;padding:10px;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);justify-content:center;box-sizing:border-box}.sidebar.open .user-info-btn{justify-content:flex-start}.user-info-btn:hover{background-color:var(--bg-tertiary)}.user-avatar{width:44px;height:44px;border-radius:50%;background-color:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;color:var(--text-primary);font-weight:700;font-size:18px;overflow:hidden;flex-shrink:0;border:2px solid var(--border-color);box-shadow:0 2px 8px #0000000d}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-details{flex:1;min-width:0;text-align:left;overflow:hidden}.user-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.3px}.user-role{font-size:13px;color:#21254f;font-weight:600}[data-theme=dark] .user-role{color:#fff}.user-menu{position:fixed;bottom:90px;left:16px;margin-bottom:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 10px 30px #00000026;min-width:220px;overflow:hidden;z-index:9999;animation:fadeInScale .2s ease}.sidebar.closed~.user-menu,.sidebar.closed .user-menu{left:92px}.user-menu-item{display:flex;align-items:center;gap:14px;padding:14px 18px;color:var(--text-primary);text-decoration:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);background:none;border:none;width:100%;text-align:left;box-sizing:border-box}.user-menu-item:hover{background-color:var(--bg-tertiary)}.theme-item{justify-content:space-between}.theme-label{display:flex;align-items:center;gap:14px}.theme-toggle-small{background-color:var(--bg-tertiary);border:1px solid rgba(99,102,241,.2);border-radius:8px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--accent);cursor:pointer;transition:background-color .2s}.theme-toggle-small:hover{background-color:var(--accent);color:#fff}.user-menu-divider{height:1px;background-color:var(--border-color);margin:6px 0}.user-menu-info{padding:10px 18px;display:flex;flex-direction:column;gap:6px}.user-menu-info .version,.user-menu-info .developer{font-size:12px;color:var(--text-muted);font-weight:500}.logout-item{color:var(--danger)!important}.logout-item:hover{background-color:var(--danger-light)!important}.main-content{overflow-x:hidden;overflow-y:auto;background-color:var(--bg-primary);height:100%;max-width:100%;min-width:0}@media (max-width: 768px){.layout{grid-template-columns:auto 1fr}.sidebar.open{width:100%;position:fixed;z-index:100}.sidebar.closed{width:70px}.main-content{max-width:100%}}.open-platform-landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.landing-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;padding:60px 80px;text-align:center;max-width:500px;width:100%}.landing-icon{margin-bottom:24px;display:flex;align-items:center;justify-content:center;color:var(--text-primary)}.landing-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.landing-description{font-size:16px;color:var(--text-secondary);margin:0 0 40px}.enter-btn{padding:16px 48px;font-size:16px;font-weight:600;border:none;border-radius:12px;background:#495057;color:#fff;cursor:pointer;transition:background-color .2s}.enter-btn:hover{background:#6c757d}[data-theme=dark] .enter-btn{background:#495057}[data-theme=dark] .enter-btn:hover{background:#6c757d}
