.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px}.login-container{background:var(--bg-primary);padding:40px;border-radius:20px;box-shadow:0 10px 40px var(--shadow-strong);width:100%;max-width:400px;text-align:center;transition:background .3s ease}@media (max-width: 768px){.login-container{padding:30px 25px;max-width:90%}}.login-container h1{color:#667eea;font-size:32px;margin-bottom:10px}.subtitle{color:#666;margin-bottom:30px;font-size:16px}.login-form{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.login-form input{padding:15px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;transition:border-color .3s;background:var(--bg-secondary);color:var(--text-primary)}@media (max-width: 768px){.login-form input{font-size:16px}}.login-form input:focus{border-color:#667eea}.login-form input:disabled{background:#f5f5f5;cursor:not-allowed}.password-field{position:relative;width:100%;display:flex;align-items:center}.password-field input{width:100%;padding-right:40px!important;box-sizing:border-box}.password-toggle{position:absolute;right:8px;background:none;border:none;cursor:pointer;font-size:16px;padding:8px;display:flex;align-items:center;justify-content:center;opacity:.4;transition:opacity .2s;color:#000;line-height:1;min-width:30px;height:30px}.password-toggle:hover{opacity:.7}@media (max-width: 768px){.password-field input{padding-right:35px!important}.password-toggle{right:5px;font-size:14px;padding:6px;min-width:26px;height:26px}}.login-form button{padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:16px;font-weight:600;border-radius:10px;transition:transform .2s,opacity .3s}.login-form button:hover:not(:disabled){transform:translateY(-2px)}.login-form button:active:not(:disabled){transform:translateY(0)}.login-form button:disabled{opacity:.6;cursor:not-allowed}.error{background:#ffebee;color:#c62828;padding:12px;border-radius:8px;font-size:14px}.toggle-btn{background:transparent;color:#667eea;font-size:14px;padding:10px;transition:color .3s}.toggle-btn:hover:not(:disabled){color:#764ba2;text-decoration:underline}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.checkbox-label{display:flex;align-items:flex-start;gap:10px;text-align:left;padding:10px 0;cursor:pointer;color:var(--text-primary)}.checkbox-label input[type=checkbox]{margin-top:3px;width:18px;height:18px;cursor:pointer;flex-shrink:0}.checkbox-label span{font-size:14px;line-height:1.5}.link-btn{background:none;color:#667eea;padding:0;font-size:inherit;text-decoration:underline;cursor:pointer;border:none;transition:color .2s}.link-btn:hover{color:#764ba2}.checkbox-link{color:#667eea;text-decoration:underline;cursor:pointer;transition:color .2s}.checkbox-link:hover{color:#764ba2}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .2s ease}.modal-content{background:var(--bg-primary);padding:30px;border-radius:16px;box-shadow:0 10px 50px var(--shadow-strong);max-width:500px;width:100%;max-height:80vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}.modal-large{max-width:600px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:15px;right:15px;width:32px;height:32px;border-radius:50%;background:var(--bg-secondary);color:var(--text-primary);font-size:18px;display:flex;align-items:center;justify-content:center;transition:background .3s,transform .2s;border:none;cursor:pointer}.modal-close:hover{background:var(--border-color);transform:rotate(90deg)}.modal-content h3{color:var(--text-primary);margin:0 0 20px;font-size:22px;padding-right:40px}.modal-text{color:var(--text-primary);text-align:left;line-height:1.6;margin-bottom:25px}.modal-text h4{color:var(--text-primary);margin:20px 0 10px;font-size:16px}.modal-text h4:first-child{margin-top:0}.modal-text p{margin:10px 0;font-size:14px;color:var(--text-secondary)}.modal-text ul{margin:10px 0;padding-left:25px}.modal-text li{margin:8px 0;font-size:14px;color:var(--text-secondary)}.modal-btn{width:100%;padding:14px;background:#667eea;color:#fff;border-radius:10px;font-size:16px;font-weight:600;transition:background .3s,transform .2s;border:none;cursor:pointer}.modal-btn:hover{background:#5568d3;transform:translateY(-2px)}.modal-btn:active{transform:translateY(0)}@media (max-width: 768px){.modal-content{padding:25px 20px;max-height:85vh}.modal-content h3{font-size:20px}.modal-text{font-size:14px}}.password-hint{font-size:12px;color:#666;text-align:left;margin-top:-10px;margin-bottom:10px;line-height:1.4;padding:0 5px}.theme-toggle{padding:8px 12px;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:20px;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{transform:scale(1.1) rotate(20deg);border-color:#667eea}.theme-toggle:active{transform:scale(.95)}@media (max-width: 768px){.theme-toggle{padding:6px 10px;font-size:18px}}.announcement-banner{margin:20px auto;max-width:900px;border-radius:15px;overflow:hidden;box-shadow:0 8px 32px #0003;transition:all .3s ease}.announcement-banner.announcement-info{background:#696969}.announcement-banner.announcement-warning{background:#dc143c}.announcement-banner.announcement-success{background:green}.announcement-header{padding:18px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .3s}.announcement-header:hover{background:#0000001a}.announcement-title{color:#fff;font-size:18px;font-weight:600;flex:1;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.02)}}.announcement-toggle{color:#fff;font-size:20px;margin-left:15px;transition:transform .3s}.announcement-body{padding:0 24px 20px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:1000px}}.announcement-content{color:#fff;font-size:15px;line-height:1.6;white-space:pre-wrap;margin-bottom:15px;padding:15px;background:#00000026;border-radius:10px}.announcement-collapse-btn{padding:10px 20px;background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.announcement-collapse-btn:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px)}@media (max-width: 768px){.announcement-banner{margin:15px;border-radius:12px}.announcement-header{padding:15px 18px}.announcement-title{font-size:16px}.announcement-body{padding:0 18px 15px}.announcement-content{font-size:14px;padding:12px}}.main-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.main-page .header{background:var(--bg-primary);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.main-page .header{padding:15px 20px;flex-wrap:wrap;gap:10px}}.main-page .user-info{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.main-page .user-avatar-header{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid #667eea;flex-shrink:0}.main-page .user-avatar-placeholder{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid #667eea;flex-shrink:0}.main-page .username{color:var(--text-primary);font-weight:500}.main-page .compcoins-summary{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-size:14px;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;font-weight:500}.main-page .compcoins-summary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.main-page .logout-btn{padding:8px 20px;background:#f44336;color:#fff;border-radius:8px;font-size:14px;transition:background .3s;border:none;cursor:pointer}.main-page .logout-btn:hover{background:#d32f2f}.main-page .main-content{max-width:1200px;margin:0 auto;padding:60px 20px}@media (max-width: 768px){.main-page .main-content{padding:30px 15px}}.welcome-section{text-align:center;margin-bottom:50px;color:var(--text-primary)}.welcome-section h2{font-size:36px;margin:0 0 10px;font-weight:700}@media (max-width: 768px){.welcome-section h2{font-size:28px}}.welcome-section p{font-size:18px;opacity:.9;margin:0}@media (max-width: 768px){.welcome-section p{font-size:16px}}.activation-guide{background:var(--bg-primary);border-radius:20px;padding:30px;margin:20px auto 0;max-width:700px;box-shadow:0 4px 20px var(--shadow);text-align:left;border:2px solid #667eea}@media (max-width: 768px){.activation-guide{padding:20px;margin:15px auto 0}}.activation-guide .guide-intro{font-size:16px;margin:0 0 20px;color:var(--text-primary);font-weight:500}@media (max-width: 768px){.activation-guide .guide-intro{font-size:15px}}.activation-guide .guide-steps{margin:0 0 20px;padding-left:20px;color:var(--text-primary)}.activation-guide .guide-steps li{margin-bottom:15px;line-height:1.6;font-size:15px}@media (max-width: 768px){.activation-guide .guide-steps li{font-size:14px;margin-bottom:12px}}.activation-guide .guide-steps li strong{color:#667eea}.activation-guide .highlight{color:#667eea;font-weight:600;white-space:nowrap}@media (max-width: 768px){.activation-guide .highlight{white-space:normal}}.activation-guide .guide-footer{margin:0;padding-top:15px;border-top:1px solid var(--border-color);font-size:15px;color:var(--text-secondary)}@media (max-width: 768px){.activation-guide .guide-footer{font-size:14px}}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin-top:40px}@media (max-width: 768px){.menu-grid{grid-template-columns:1fr;gap:20px}}.menu-card{background:var(--bg-primary);border-radius:20px;padding:35px 25px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px var(--shadow);display:flex;flex-direction:column;align-items:center;text-align:center;border:2px solid transparent}.menu-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--shadow);border-color:#667eea}.menu-card-icon{font-size:64px;margin-bottom:20px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}@media (max-width: 768px){.menu-card-icon{font-size:56px;margin-bottom:15px}}.menu-card-title{font-size:22px;font-weight:700;margin:0 0 10px;color:var(--text-primary)}@media (max-width: 768px){.menu-card-title{font-size:20px}}.menu-card-description{font-size:15px;color:var(--text-secondary);margin:0;line-height:1.5}@media (max-width: 768px){.menu-card-description{font-size:14px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-card{animation:fadeIn .5s ease-out forwards}.menu-card:nth-child(1){animation-delay:.1s}.menu-card:nth-child(2){animation-delay:.2s}.menu-card:nth-child(3){animation-delay:.3s}.menu-card:nth-child(4){animation-delay:.4s}.menu-card:nth-child(5){animation-delay:.5s}@media (max-width: 768px){.main-page .username{display:none}.main-page .user-info{gap:8px}}.characters-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.header{background:var(--bg-primary);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.header{padding:15px 20px;flex-wrap:wrap;gap:10px}}.header-left{display:flex;align-items:center;gap:15px}@media (max-width: 768px){.header-left{gap:10px}}.header h1{color:#667eea;font-size:24px;margin:0}.back-btn{padding:8px 16px;background:transparent;color:var(--text-primary);border:1px solid var(--text-secondary);border-radius:8px;font-size:14px;transition:all .3s;cursor:pointer}.back-btn:hover{background:#667eea;color:#fff;border-color:#667eea}@media (max-width: 768px){.back-btn{padding:6px 12px;font-size:13px}}.user-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.username{color:var(--text-primary)}@media (max-width: 768px){.username{display:none}.user-info{gap:8px}}.tier-badge{background:#667eea;color:#fff;padding:5px 15px;border-radius:20px;font-size:14px;font-weight:600}.settings-btn{padding:8px 20px;background:#667eea;color:#fff;border-radius:8px;font-size:14px;transition:background .3s}.settings-btn:hover{background:#5568d3}.logout-btn{padding:8px 20px;background:#f44336;color:#fff;border-radius:8px;font-size:14px;transition:background .3s}.logout-btn:hover{background:#d32f2f}.limits-bar{background:var(--bg-primary);padding:15px 40px;box-shadow:0 2px 5px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.limits-bar{padding:12px 20px}}.limits-info{display:flex;gap:20px;align-items:center;font-size:14px;color:var(--text-primary);flex-wrap:wrap}@media (max-width: 768px){.limits-info{font-size:13px;gap:10px}}.limit-warning{color:#f44336;font-weight:600}.slowdown-warning{color:#ff9800;font-weight:600;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.subscription-required{color:#ff9800;font-weight:600;background:#ff98001a;padding:8px 16px;border-radius:8px;border-left:4px solid #ff9800}.main-content{max-width:1200px;margin:0 auto;padding:40px 20px}@media (max-width: 768px){.main-content{padding:20px 15px}}.characters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;color:var(--text-inverse)}@media (max-width: 768px){.characters-header{flex-direction:column;align-items:stretch;gap:15px}}.characters-header h2{font-size:28px;margin:0}.create-btn{padding:12px 24px;background:#fff;color:#667eea;border-radius:10px;font-weight:600;font-size:16px;transition:transform .2s}.create-btn:hover{transform:scale(1.05)}.empty-state{text-align:center;padding:60px 20px;color:#fff}.empty-state p{font-size:20px;margin-bottom:30px}.create-btn-large{padding:15px 40px;background:#fff;color:#667eea;border-radius:12px;font-size:18px;font-weight:600;transition:transform .2s}.create-btn-large:hover{transform:scale(1.05)}.characters-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.character-card{background:var(--bg-primary);padding:25px;border-radius:15px;transition:transform .2s,box-shadow .2s,background .3s ease;box-shadow:0 4px 15px var(--shadow);position:relative}@media (max-width: 768px){.character-card{padding:20px}}.character-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px var(--shadow-strong)}@media (hover: none){.character-card:hover{transform:none}.character-card:active{transform:scale(.98)}}.char-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;position:relative}.locked-badge{background:#ff9800;color:#fff;padding:4px 10px;border-radius:12px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:5px}.character-card.locked{border:2px solid #ff9800;background:var(--bg-secondary)}.character-card.locked:hover{transform:none;box-shadow:0 4px 15px var(--shadow)}.char-card-content{cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:15px}.char-avatar{width:120px;height:120px;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d}.char-avatar img{width:100%;height:100%;object-fit:cover}.char-avatar-default{background:linear-gradient(135deg,#e0e0e0,silver)}[data-theme=dark] .char-avatar-default{background:linear-gradient(135deg,#3a3a3a,#2a2a2a)}.avatar-icon{font-size:48px;opacity:.5}.character-card h3{color:#667eea;margin:0 0 10px;font-size:20px;text-align:center}.character-card .label{display:inline-block;background:#e8eaf6;color:#667eea;padding:4px 12px;border-radius:12px;font-size:12px;margin-bottom:10px}.character-card .description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:10px 0 0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.three-dot-btn{width:30px;height:30px;border-radius:50%;background:var(--bg-secondary);color:var(--text-primary);font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s;z-index:10;cursor:pointer;border:none}.three-dot-btn:hover{background:var(--bg-hover);transform:scale(1.1)}.char-menu{position:absolute;top:35px;right:0;background:var(--bg-primary);border-radius:8px;box-shadow:0 4px 15px var(--shadow-strong);overflow:hidden;z-index:100;min-width:180px;border:1px solid var(--border-color)}.menu-item{width:100%;padding:12px 16px;background:var(--bg-primary);color:var(--text-primary);border:none;text-align:left;font-size:14px;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px}.menu-item:hover{background:var(--bg-hover)}.menu-item-delete{color:#f44336}.menu-item-delete:hover{background:#f443361a}.loading{display:flex;justify-content:center;align-items:center;height:100vh;color:var(--text-inverse);font-size:24px}.placeholder-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%)}.placeholder-page .header{background:var(--bg-primary);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.placeholder-page .header{padding:15px 20px;flex-wrap:wrap;gap:10px}}.placeholder-page .header h1{color:#667eea;font-size:24px;margin:0}.placeholder-page .user-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.placeholder-page .username{color:var(--text-primary)}@media (max-width: 768px){.placeholder-page .username{display:none}.placeholder-page .user-info{gap:8px}}.placeholder-page .logout-btn{padding:8px 20px;background:#f44336;color:#fff;border-radius:8px;font-size:14px;transition:background .3s;border:none;cursor:pointer}.placeholder-page .logout-btn:hover{background:#d32f2f}.placeholder-content{max-width:800px;margin:0 auto;padding:100px 20px;text-align:center;color:#fff}@media (max-width: 768px){.placeholder-content{padding:60px 20px}}.placeholder-icon{font-size:120px;margin-bottom:30px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));animation:float 3s ease-in-out infinite}@media (max-width: 768px){.placeholder-icon{font-size:80px;margin-bottom:20px}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.placeholder-content h2{font-size:42px;margin:0 0 20px;font-weight:700}@media (max-width: 768px){.placeholder-content h2{font-size:32px}}.placeholder-content p{font-size:20px;opacity:.9;margin:0 0 40px}@media (max-width: 768px){.placeholder-content p{font-size:18px}}.back-btn{padding:15px 40px;background:#fff;color:#667eea;border-radius:12px;font-weight:600;font-size:18px;transition:all .3s;border:none;cursor:pointer;box-shadow:0 4px 15px #0003}.back-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d;background:#f5f5f5}@media (max-width: 768px){.back-btn{padding:12px 30px;font-size:16px}}.tariffs-content{max-width:900px;margin:0 auto;padding:40px 20px;color:var(--text-primary)}.welcome-section{background:var(--bg-secondary);padding:30px;border-radius:16px;margin-bottom:30px;box-shadow:0 4px 20px var(--shadow);text-align:center}.welcome-section h2{color:#667eea;font-size:28px;margin-bottom:20px;font-weight:700}.welcome-section p{font-size:16px;line-height:1.6;margin-bottom:15px;opacity:.9}.divider{height:2px;background:linear-gradient(90deg,transparent,#667eea,transparent);margin:30px 0;opacity:.3}.tariff-card{background:var(--bg-secondary);padding:35px;border-radius:20px;margin-bottom:30px;box-shadow:0 8px 30px var(--shadow);border:2px solid transparent;transition:all .3s ease}.tariff-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px var(--shadow)}.tariff-card.premium{border-color:#f59e0b}.tariff-card.vip{border-color:#8b5cf6}.tariff-icon{font-size:64px;margin-bottom:20px;text-align:center;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.tariff-card h3{font-size:32px;margin-bottom:10px;text-align:center;font-weight:700}.tariff-card.premium h3{color:#f59e0b}.tariff-card.vip h3{color:#8b5cf6}.tariff-subtitle{font-size:18px;text-align:center;opacity:.8;margin-bottom:20px;font-style:italic}.tariff-description{font-size:16px;margin-bottom:20px;text-align:center;font-weight:500}.features-list{list-style:none;padding:0;margin:25px 0}.features-list li{font-size:15px;line-height:1.8;margin-bottom:12px;padding-left:10px;opacity:.95}.pricing{background:#667eea1a;padding:20px;border-radius:12px;margin-top:25px}.pricing h4{font-size:20px;margin-bottom:15px;text-align:center;color:#667eea}.price-item{font-size:16px;padding:10px;margin:8px 0;background:var(--bg-primary);border-radius:8px;text-align:center;font-weight:500}.info-section{background:var(--bg-secondary);padding:25px;border-radius:16px;margin-bottom:25px;box-shadow:0 4px 20px var(--shadow)}.info-section h3{font-size:24px;margin-bottom:15px;color:#667eea;text-align:center}.info-section p{font-size:15px;line-height:1.7;margin-bottom:10px;opacity:.9}.social-links{background:var(--bg-secondary);padding:30px;border-radius:16px;margin-bottom:30px;box-shadow:0 4px 20px var(--shadow)}.social-links h3{font-size:24px;margin-bottom:20px;color:#667eea;text-align:center}.links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-top:20px}.social-link{display:block;padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;border-radius:12px;text-align:center;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.social-link:hover{transform:translateY(-3px);box-shadow:0 6px 25px #667eea80}.back-btn-top{margin-bottom:30px}.payment-links{margin-top:25px;padding-top:20px;border-top:2px solid rgba(102,126,234,.2)}.payment-links h4{text-align:center;font-size:20px;color:#667eea;margin-bottom:15px}.payment-buttons{display:flex;gap:15px;justify-content:center;flex-wrap:wrap}.payment-btn{display:inline-block;padding:15px 40px;border-radius:12px;text-decoration:none;font-weight:600;font-size:18px;color:#fff;transition:all .3s ease;box-shadow:0 4px 15px #0003;text-align:center}.payment-btn.boosty{background:linear-gradient(135deg,#f59e0b,#d97706)}.payment-btn.boosty:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-2px);box-shadow:0 6px 20px #f59e0b66}.payment-btn.hipolink{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.payment-btn.hipolink:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.contact-buttons{display:flex;gap:15px;justify-content:center;margin-top:20px;flex-wrap:wrap}.contact-btn{padding:15px 30px;border-radius:12px;font-weight:600;font-size:16px;color:#fff;border:none;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;text-decoration:none;display:inline-block;text-align:center}.contact-btn.support-btn{background:linear-gradient(135deg,#667eea,#764ba2)}.contact-btn.support-btn:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.contact-btn.telegram-btn{background:linear-gradient(135deg,#08c,#069)}.contact-btn.telegram-btn:hover{background:linear-gradient(135deg,#069,#004d73);transform:translateY(-2px);box-shadow:0 6px 20px #08c6}@media (max-width: 768px){.tariffs-content{padding:20px 15px}.welcome-section{padding:20px}.welcome-section h2{font-size:22px}.tariff-card{padding:25px 20px}.tariff-icon{font-size:48px}.tariff-card h3{font-size:26px}.features-list li{font-size:14px}.links-grid{grid-template-columns:1fr}.payment-buttons,.contact-buttons{flex-direction:column}.payment-btn,.contact-btn{width:100%}}.support-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);display:flex;flex-direction:column}.support-page .header{background:var(--bg-primary);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.support-page .header{padding:15px 20px;flex-wrap:wrap;gap:10px}}.support-page .header-left{display:flex;align-items:center;gap:15px}.support-page .header h1{color:#667eea;font-size:24px;margin:0}.support-page .back-btn{padding:8px 16px;background:transparent;color:var(--text-primary);border:1px solid var(--text-secondary);border-radius:8px;font-size:14px;transition:all .3s;cursor:pointer}.support-page .back-btn:hover{background:#667eea;color:#fff;border-color:#667eea}.support-page .user-info{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.support-page .username{color:var(--text-primary)}@media (max-width: 768px){.support-page .username{display:none}}.support-page .logout-btn{padding:8px 20px;background:#f44336;color:#fff;border-radius:8px;font-size:14px;transition:background .3s;border:none;cursor:pointer}.support-page .logout-btn:hover{background:#d32f2f}.support-content{flex:1;display:flex;flex-direction:column;max-width:100%;width:100%;margin:0;padding:0}@media (max-width: 768px){.support-content{padding:0}}.support-header{text-align:center;margin-bottom:20px;color:#fff;padding:20px}.support-header h2{font-size:28px;margin:0 0 10px}.support-header p{font-size:16px;opacity:.9;margin:0}.support-messages-container{flex:1;background:var(--bg-primary);padding:20px;overflow-y:auto;min-height:400px;transition:background .3s ease}@media (max-width: 768px){.support-messages-container{padding:15px;min-height:300px}}.loading-messages{display:flex;justify-content:center;align-items:center;height:100%;color:var(--text-secondary);font-size:18px}.empty-messages{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;text-align:center;color:var(--text-secondary)}.empty-icon{font-size:80px;margin-bottom:20px;opacity:.5}.empty-messages p{font-size:20px;margin:0 0 10px;color:var(--text-primary)}.empty-messages small{font-size:14px;opacity:.7}.messages-list{display:flex;flex-direction:column;gap:15px}.support-message{display:flex;gap:10px;align-items:flex-start;animation:fadeIn .3s ease-in}.support-message.own{flex-direction:row-reverse;align-self:flex-end}.support-message.own .message-body{background:linear-gradient(135deg,#667eea,#764ba2)}.support-message.own .message-username{color:#ffffffe6}.support-message.own .message-time{color:#ffffffb3}.support-message.own .message-content{color:#fff}.message-image{margin-top:8px}.message-image img{max-width:100%;max-height:300px;border-radius:8px;cursor:pointer;transition:transform .2s}.message-image img:hover{transform:scale(1.02)}.message-input-form{display:flex;gap:10px;background:var(--bg-primary);padding:15px 20px;box-shadow:0 -2px 10px var(--shadow);align-items:flex-end;flex-shrink:0;transition:background .3s ease}@media (max-width: 768px){.message-input-form{padding:12px 15px;align-items:stretch}}.support-input-wrapper{flex:1;display:flex;flex-direction:column;gap:6px}.message-input{width:100%;padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:20px;color:var(--text-primary);font-size:15px;transition:border-color .3s,background .3s;font-family:inherit;line-height:1.4;resize:none;min-height:44px;max-height:200px;overflow-y:auto}.message-input:focus{outline:none;border-color:#667eea}.message-input:disabled{opacity:.6;cursor:not-allowed}.send-button{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-size:20px;cursor:pointer;transition:all .3s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.5;cursor:not-allowed}.community-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary);transition:background .3s ease}.community-header{background:var(--bg-primary);padding:15px 20px;box-shadow:0 2px 10px var(--shadow);display:flex;align-items:center;gap:20px;position:sticky;top:0;z-index:100;transition:background .3s ease}.community-header h1{flex:1;animation:fadeIn .3s;align-self:flex-start}.community-message.own{flex-direction:row-reverse;align-self:flex-end}.message-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--border-color);background:var(--bg-secondary)}.message-avatar .avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--text-secondary)}.message-body{flex:1;background:var(--bg-primary);padding:12px 16px;border-radius:12px;box-shadow:0 2px 6px var(--shadow);transition:background .3s ease;min-width:0}.community-message.own .message-body{background:linear-gradient(135deg,#667eea,#764ba2)}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:10px}.message-username{font-weight:600;font-size:13px;color:var(--text-primary)}.community-message.own .message-username{color:#ffffffe6}.message-time{font-size:11px;color:var(--text-secondary);opacity:.7}.community-message.own .message-time{color:#ffffffb3}.message-content{font-size:15px;line-height:1.5;word-wrap:break-word;white-space:pre-wrap;color:var(--text-primary)}.community-message.own .message-content{color:#fff}.message-image{margin-top:8px;background:var(--bg-primary);padding:15px 20px;box-shadow:0 -2px 10px var(--shadow);display:flex;gap:10px;align-items:flex-end;flex-shrink:0;transition:background .3s ease}@media (max-width: 768px){.community-input-form{padding:12px 15px;align-items:stretch}}.community-input-wrapper{flex:1;display:flex;flex-direction:column;gap:6px}.image-url-input{width:100%;padding:8px 12px;border:2px solid var(--border-color);border-radius:12px;font-size:13px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s;font-family:inherit}.image-url-input:focus{border-color:#667eea;outline:none}.community-input-form textarea{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:20px;font-size:15px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s;resize:none;font-family:inherit;line-height:1.4;min-height:42px;max-height:100px;overflow-y:auto}.community-input-form textarea:focus{border-color:#667eea;outline:none}.emoji-bar{display:flex;flex-wrap:wrap;gap:4px;padding:4px 4px 0;max-height:90px;overflow-y:auto}.emoji-btn{background:transparent;border:none;font-size:20px;line-height:1;cursor:pointer;padding:2px;transition:transform .12s ease}.emoji-btn:hover{transform:translateY(-1px) scale(1.1)}.emoji-btn:active{transform:translateY(0) scale(.95)}@media (max-width: 768px){.emoji-bar{gap:3px;justify-content:flex-start}.emoji-btn{font-size:18px}}.community-input-form button{width:48px;height:48px;border-radius:50%;font-size:20px;transition:all .3s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.emoji-toggle-btn{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);font-size:20px}.emoji-toggle-btn:hover:not(:disabled){background:var(--border-color);transform:scale(1.05)}.community-error .back-btn{padding:10px 24px;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:10px;font-weight:500;transition:all .3s}.community-error .back-btn:hover{background:var(--border-color);border-color:#667eea;transform:translateY(-2px)}.logout-btn{padding:8px 16px;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:14px;transition:all .3s}.logout-btn:hover{background:var(--border-color);border-color:#667eea}.loading{display:flex;justify-content:center;align-items:center;height:100vh;color:var(--text-primary);font-size:24px}.back-btn-header{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.back-btn-header:hover{background:#5568d3;transform:translateY(-1px)}.back-btn-header:active{transform:translateY(0)}.faq-page{min-height:100vh}.faq-content{max-width:1000px;margin:0 auto;padding:40px 20px}.faq-header{text-align:center;margin-bottom:40px}.faq-header h1{color:#667eea;font-size:32px;font-weight:700;margin:0}.faq-section{background:var(--bg-secondary);border-radius:12px;margin-bottom:15px;overflow:hidden;box-shadow:0 4px 15px var(--shadow);transition:all .3s ease}.faq-section:hover{box-shadow:0 6px 20px var(--shadow)}.faq-title{padding:20px 25px;margin:0;font-size:22px;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease;color:var(--text-primary)}.faq-title:hover{background:#667eea1a}.faq-body{padding:0 25px 25px;color:var(--text-primary)}.faq-body h3{color:#667eea;font-size:20px;margin-top:20px;margin-bottom:15px}.faq-body p{line-height:1.7;margin-bottom:15px;opacity:.9}.faq-body ul,.faq-body ol{line-height:1.8;margin-bottom:20px;padding-left:25px}.faq-body li{margin-bottom:10px;opacity:.9}.faq-body strong{color:var(--text-primary);font-weight:600}.tip-box{background:#667eea26;border-left:4px solid #667eea;padding:15px 20px;border-radius:8px;margin:20px 0}.warning-box{background:#f59e0b26;border-left:4px solid #f59e0b;padding:15px 20px;border-radius:8px;margin:20px 0}.error-box{background:#ef444426;border-left:4px solid #ef4444;padding:15px 20px;border-radius:8px;margin:20px 0}.code-block{background:var(--bg-primary);padding:15px;border-radius:8px;font-family:Courier New,monospace;margin:15px 0;overflow-x:auto;border:1px solid rgba(102,126,234,.2)}@media (max-width: 768px){.faq-content{padding:20px 15px}.faq-header h1{font-size:24px}.faq-title{padding:15px 20px;font-size:18px}.faq-body{padding:0 20px 20px}.faq-body h3{font-size:18px}.faq-body ul,.faq-body ol{padding-left:20px}}.color-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.color-picker-modal{background:var(--bg-primary);border-radius:20px;box-shadow:0 10px 50px var(--shadow-strong);width:90%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.color-picker-header{display:flex;align-items:center;justify-content:space-between;padding:20px 25px;border-bottom:2px solid var(--border-color)}.color-picker-header h3{margin:0;color:var(--text-primary);font-size:22px}.close-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-secondary);color:var(--text-primary);font-size:20px;display:flex;align-items:center;justify-content:center;transition:background .3s,transform .2s;flex-shrink:0}.close-btn:hover{background:var(--border-color);transform:rotate(90deg)}.color-picker-content{padding:25px;display:flex;flex-direction:column;gap:25px}.color-section{background:var(--bg-secondary);padding:20px;border-radius:15px;transition:background .3s ease}.color-section h4{margin:0 0 15px;color:var(--text-primary);font-size:18px}.color-row{display:flex;align-items:center;gap:15px;margin-bottom:15px}.color-row:last-child{margin-bottom:0}.color-row label{min-width:60px;color:var(--text-secondary);font-weight:500;font-size:14px}.color-row input[type=color]{width:60px;height:40px;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:border-color .3s;flex-shrink:0}.color-row input[type=color]:hover{border-color:#667eea}.preview-bubble{flex:1;padding:10px 18px;border-radius:18px;font-size:14px;text-align:center;box-shadow:0 2px 8px var(--shadow);transition:all .3s ease}.user-preview{border-bottom-right-radius:4px}.bot-preview{border-bottom-left-radius:4px}.preview-chat-bg{flex:1;padding:15px;border-radius:12px;display:flex;flex-direction:column;gap:8px;min-height:80px;border:2px solid var(--border-color)}.mini-bubble{padding:8px 14px;border-radius:14px;font-size:13px;max-width:70%;box-shadow:0 2px 6px var(--shadow)}.mini-bubble:first-child{align-self:flex-end;border-bottom-right-radius:4px}.mini-bubble:last-child{align-self:flex-start;border-bottom-left-radius:4px}.font-size-control{display:flex;flex-direction:column;gap:15px}.font-size-control label{color:var(--text-primary);font-weight:600;font-size:16px}.font-size-slider{width:100%;height:8px;border-radius:4px;background:linear-gradient(to right,#667eea,#764ba2);outline:none;-webkit-appearance:none;cursor:pointer}.font-size-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 8px #667eea66;transition:transform .2s}.font-size-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.font-size-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid #667eea;cursor:pointer;box-shadow:0 2px 8px #667eea66;transition:transform .2s}.font-size-slider::-moz-range-thumb:hover{transform:scale(1.2)}.font-size-labels{display:flex;justify-content:space-between;color:var(--text-secondary);font-size:12px;margin-top:-8px}.preview-text{padding:15px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;color:var(--text-primary);line-height:1.6;text-align:center;transition:font-size .2s ease}.color-code{font-family:monospace;font-size:13px;color:var(--text-secondary);padding:6px 12px;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);min-width:80px;text-align:center}.color-picker-actions{display:flex;gap:12px;width:100%}.reset-btn{flex:1;padding:14px;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:12px;font-size:15px;font-weight:500;transition:all .3s}.reset-btn:hover{background:var(--border-color);transform:translateY(-2px)}.reset-btn:active{transform:translateY(0)}.done-btn{flex:2;padding:14px;background:#667eea;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;transition:all .3s}.done-btn:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.done-btn:active{transform:translateY(0)}@media (max-width: 768px){.color-picker-modal{width:95%;max-height:85vh}.color-picker-header{padding:15px 20px}.color-picker-header h3{font-size:18px}.color-picker-content{padding:20px;gap:20px}.color-section{padding:15px}.color-section h4{font-size:16px}.color-row{flex-wrap:wrap;gap:10px}.color-row label{width:100%;min-width:auto}.color-row input[type=color]{width:50px;height:35px}.preview-bubble{flex:1 1 100%;padding:12px}.color-code{flex:1}.font-size-control label{font-size:14px}.preview-text{padding:12px}}:root{--user-msg-bg: #667eea;--user-msg-text: #ffffff;--bot-msg-bg: #ffffff;--bot-msg-text: #333333;--chat-bg: #f5f5f5;--chat-font-size: 15px}[data-theme=dark]{--bot-msg-bg: #1a1a2e;--bot-msg-text: #e8e8e8;--chat-bg: #1a1a2e}.chat-page{height:100vh;display:flex;flex-direction:column;background:var(--chat-bg);transition:background .3s ease;overflow:hidden}.chat-header{background:var(--bg-primary);padding:15px 20px;box-shadow:0 2px 10px var(--shadow);display:flex;align-items:center;gap:20px;position:sticky;top:0;z-index:100;transition:background .3s ease}@media (max-width: 768px){.chat-header{padding:12px 10px;gap:8px;flex-wrap:wrap}.chat-menu{margin-left:auto}.menu-dropdown,.generating-badge{position:fixed;top:65px;left:50%;right:auto;transform:translate(-50%);margin-top:0;width:90vw;max-width:340px}}@media (max-width: 480px){.chat-header{padding:10px 8px;gap:6px;flex-wrap:wrap}}.nav-buttons{display:flex;gap:10px}@media (max-width: 480px){.nav-buttons{gap:6px}}.back-btn{padding:8px 16px;background:#667eea;color:#fff;border-radius:8px;font-size:14px;transition:background .3s,transform .2s}.back-btn:hover{background:#5568d3;transform:translateY(-2px)}.back-btn:active{transform:translateY(0)}@media (max-width: 480px){.back-btn{padding:6px 12px;font-size:13px}}.home-btn{padding:8px 16px;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;font-size:14px;transition:background .3s,transform .2s,border-color .3s}.home-btn:hover{background:var(--border-color);border-color:#667eea;transform:translateY(-2px)}.home-btn:active{transform:translateY(0)}@media (max-width: 480px){.home-btn{padding:6px 12px;font-size:13px}}.character-info{flex:1}.character-info h2{margin:0;font-size:20px;color:var(--text-primary)}@media (max-width: 768px){.character-info h2{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}}@media (max-width: 480px){.character-info h2{font-size:14px;max-width:120px}}.color-btn{padding:8px 12px;background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;font-size:20px;transition:background .3s,transform .2s;flex-shrink:0}.color-btn:hover{background:var(--border-color);transform:scale(1.1)}.color-btn:active{transform:scale(.95)}@media (max-width: 768px){.color-btn{padding:6px 10px;font-size:18px}}@media (max-width: 480px){.color-btn{padding:5px 8px;font-size:16px}}.chat-menu{position:relative}.menu-btn{padding:8px 12px;background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;font-size:20px;font-weight:700;transition:background .3s}@media (max-width: 480px){.menu-btn{padding:6px 10px;font-size:18px}}.menu-btn:hover{background:var(--border-color)}.menu-btn:disabled{opacity:.6;cursor:not-allowed}.menu-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 20px var(--shadow-strong);overflow:hidden;z-index:100;min-width:220px}.menu-dropdown button{display:block;width:100%;padding:12px 20px;text-align:left;background:var(--bg-primary);color:var(--text-primary);border:none;transition:background .2s;font-size:14px}.menu-dropdown button:hover{background:var(--bg-secondary)}.menu-dropdown button.danger{color:#f44336}.menu-dropdown button.danger:hover{background:#f443361a}.generating-badge{position:absolute;top:100%;right:0;margin-top:8px;padding:10px 16px;background:#667eea;color:#fff;border-radius:8px;font-size:14px;white-space:nowrap;box-shadow:0 4px 12px #667eea4d;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.messages-container{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px;background:var(--chat-bg);transition:background .3s ease}@media (max-width: 768px){.messages-container{padding:15px 10px;gap:12px}}.message{max-width:80%;animation:fadeIn .3s;position:relative}.delete-msg-btn-corner{position:absolute;top:3px;right:3px;width:16px;height:16px;background:#f44336cc;color:#fff;border:none;border-radius:50%;font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s,transform .2s,background .2s;z-index:10;line-height:1;padding:0}.message:hover .delete-msg-btn-corner{opacity:1}.delete-msg-btn-corner:hover{background:#d32f2f;transform:scale(1.15)}.delete-msg-btn-corner:active{transform:scale(.95)}@media (max-width: 768px){.delete-msg-btn-corner{opacity:.6;width:20px;height:20px;font-size:12px}.delete-msg-btn-corner:active{opacity:1}}@media (max-width: 768px){.message{max-width:90%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-wrapper{display:flex;align-items:flex-start;gap:10px;width:100%}.message-content-wrapper{flex:1;min-width:0}.message-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #667eea4d}.message-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:20px;opacity:.7}.message-content{padding:12px 18px;border-radius:18px;line-height:1.6;word-wrap:break-word;white-space:pre-wrap;transition:background .3s ease,color .3s ease,font-size .2s ease;font-size:var(--chat-font-size)}.message.user .message-content{background:var(--user-msg-bg);color:var(--user-msg-text);border-bottom-right-radius:4px}.message.assistant .message-content{background:var(--bot-msg-bg);color:var(--bot-msg-text);box-shadow:0 2px 8px var(--shadow);border-bottom-left-radius:4px}.message-content.typing{font-style:italic;opacity:.7}.message-actions{display:flex;gap:5px;margin-top:5px;opacity:0;transition:opacity .2s}.message:hover .message-actions{opacity:1}.regenerate-msg-btn,.edit-msg-btn,.delete-msg-btn{padding:4px 8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s}.regenerate-msg-btn:hover{background:#3f51b5;border-color:#3f51b5;transform:scale(1.1)}.regenerate-msg-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.edit-msg-btn:hover{background:#667eea;border-color:#667eea;transform:scale(1.1)}.delete-msg-btn:hover{background:#f44336;border-color:#f44336;transform:scale(1.1)}.message-edit-container{width:100%;min-width:500px;display:flex;flex-direction:column;gap:10px}@media (max-width: 768px){.message-edit-container{min-width:auto}}.message-edit-input{width:100%;padding:12px;border:2px solid var(--border-color);border-radius:10px;font-size:var(--chat-font-size);font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);resize:vertical;min-height:120px;transition:border-color .3s}.message-edit-input:focus{border-color:#667eea;outline:none}.message-edit-actions{display:flex;gap:10px}.save-edit-btn,.cancel-edit-btn{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.save-edit-btn{background:#4caf50;color:#fff;border:none}.save-edit-btn:hover{background:#45a049;transform:translateY(-1px)}.cancel-edit-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.cancel-edit-btn:hover{background:var(--border-color);transform:translateY(-1px)}@media (max-width: 768px){.message-actions{opacity:1}.regenerate-msg-btn,.edit-msg-btn,.delete-msg-btn{padding:6px 10px;font-size:16px}.message-edit-input{font-size:16px}.save-edit-btn,.cancel-edit-btn{flex:1;padding:10px}}.input-form{background:var(--bg-primary);padding:10px 15px;box-shadow:0 -2px 10px var(--shadow);display:flex;gap:10px;align-items:center;flex-shrink:0;transition:background .3s ease}@media (max-width: 768px){.input-form{padding:8px 10px}}.input-form textarea{flex:1;padding:10px 14px;border:2px solid var(--border-color);border-radius:20px;font-size:16px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s;resize:none;font-family:inherit;line-height:1.4;min-height:38px;max-height:80px;overflow-y:auto}.input-form textarea:focus{border-color:#667eea;outline:none}@media (max-width: 768px){.input-form textarea{font-size:16px}}.input-form button{padding:10px 24px;background:#667eea;color:#fff;border-radius:20px;font-weight:600;font-size:15px;transition:background .3s;flex-shrink:0;white-space:nowrap}.send-text-mobile{display:none}@media (max-width: 768px){.input-form button{padding:12px 16px;font-size:18px;min-width:50px}.send-text-desktop{display:none}.send-text-mobile{display:inline}}.input-form button:hover:not(:disabled){background:#5568d3}.input-form button:disabled{opacity:.5;cursor:not-allowed}.setup-container{max-width:600px;margin:40px auto;padding:40px;background:var(--bg-primary);border-radius:20px;box-shadow:0 10px 40px var(--shadow-strong);transition:background .3s ease}@media (max-width: 768px){.setup-container{margin:20px auto;padding:25px 20px;max-width:90%}}.setup-container h2{color:var(--text-primary);margin:20px 0 30px;font-size:28px}@media (max-width: 768px){.setup-container h2{font-size:24px}}.setup-form{display:flex;flex-direction:column;gap:15px}.setup-form input,.setup-form textarea{padding:15px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;resize:vertical;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s}.setup-form input:focus,.setup-form textarea:focus{border-color:#667eea}.setup-form button{padding:15px;background:#667eea;color:#fff;font-size:16px;font-weight:600;border-radius:10px;margin-top:10px}.setup-form button:disabled{opacity:.6;cursor:not-allowed}.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.confirm-modal{background:var(--bg-primary);padding:30px;border-radius:16px;box-shadow:0 10px 40px var(--shadow-strong);max-width:400px;width:90%;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-modal h3{margin:0 0 10px;color:var(--text-primary);font-size:20px;text-align:center}.confirm-modal p{margin:0 0 25px;color:var(--text-secondary);font-size:14px;text-align:center}.confirm-actions{display:flex;gap:12px}.confirm-cancel,.confirm-delete{flex:1;padding:12px;border-radius:10px;font-size:15px;font-weight:600;transition:all .3s}.confirm-cancel{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.confirm-cancel:hover{background:var(--border-color);transform:translateY(-2px)}.confirm-delete{background:#f44336;color:#fff;border:none}.confirm-delete:hover{background:#d32f2f;transform:translateY(-2px);box-shadow:0 4px 12px #f443364d}@media (max-width: 768px){.confirm-modal{padding:25px 20px}.confirm-modal h3{font-size:18px}.confirm-actions{flex-direction:column}.confirm-cancel,.confirm-delete{width:100%}}.ooc-button-container{display:flex;justify-content:center;margin:10px 0}.ooc-button{padding:8px 20px;background:transparent;border:1px solid #666;color:#999;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s;font-weight:500}.ooc-button:hover:not(:disabled){background:#333;border-color:#888;color:#fff}[data-theme=dark] .ooc-button:hover:not(:disabled){background:#2a2a2a}.ooc-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.ooc-button{padding:10px 24px;font-size:14px}}.ooc-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.ooc-modal{background:var(--bg-primary);padding:0;border-radius:16px;box-shadow:0 10px 50px #0006;max-width:500px;width:90%;animation:slideUp .3s ease;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.ooc-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.ooc-modal-header h3{margin:0;color:var(--text-primary);font-size:18px;font-weight:600}.ooc-close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color .2s;line-height:1}.ooc-close-btn:hover{color:var(--text-primary)}.ooc-form{padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.ooc-form label{color:var(--text-primary);font-size:14px;font-weight:500;margin-bottom:-8px}.ooc-textarea{width:100%;padding:12px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:15px;font-family:inherit;resize:vertical;min-height:100px;transition:border-color .3s}.ooc-textarea:focus{border-color:#667eea;outline:none}.ooc-examples{background:var(--bg-secondary);padding:12px 16px;border-radius:8px;font-size:13px}.ooc-examples strong{color:var(--text-primary);display:block;margin-bottom:8px}.ooc-examples ul{margin:0;padding-left:20px;color:var(--text-secondary)}.ooc-examples li{margin:4px 0}.ooc-actions{display:flex;gap:12px;margin-top:8px}.ooc-cancel-btn,.ooc-send-btn{flex:1;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.ooc-cancel-btn{background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color)}.ooc-cancel-btn:hover{background:var(--border-color);transform:translateY(-2px)}.ooc-send-btn{background:#667eea;color:#fff;border:none}.ooc-send-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.ooc-send-btn:disabled{opacity:.5;cursor:not-allowed}.message.user .message-content[data-ooc=true],.message.user.ooc .message-content{background:#5a5a5a;border-left:3px solid #999;opacity:.9}[data-theme=dark] .message.user .message-content[data-ooc=true],[data-theme=dark] .message.user.ooc .message-content{background:#2a2a2a;border-left:3px solid #666}@media (max-width: 768px){.ooc-modal{width:95%;max-height:85vh}.ooc-modal-header{padding:16px 20px}.ooc-modal-header h3{font-size:16px}.ooc-form{padding:20px}.ooc-textarea{font-size:16px}.ooc-actions{flex-direction:column}.ooc-cancel-btn,.ooc-send-btn{width:100%}}.admin-community-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);display:flex;flex-direction:column}.admin-header{background:#0f3460f2;padding:15px 20px;display:flex;align-items:center;justify-content:space-between;color:#fff;box-shadow:0 2px 10px #00000059}.admin-header h1{margin:0;font-size:22px}.admin-header-right{display:flex;align-items:center;gap:12px}.admin-username{opacity:.85;font-size:14px}.admin-announcement-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.admin-announcement-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.admin-logout-btn{padding:6px 12px;background:#f44336;color:#fff;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s ease,transform .1s ease}.admin-logout-btn:hover{background:#d32f2f;transform:translateY(-1px)}.admin-content{flex:1;padding:20px;max-width:1100px;margin:0 auto}.admin-login-card{max-width:420px;margin:80px auto;padding:30px 25px;background:#0f3460f5;border-radius:16px;box-shadow:0 15px 40px #00000073;color:#fff}.admin-login-card h1{margin-top:0;margin-bottom:10px;font-size:24px}.admin-login-card .hint{margin:0 0 20px;font-size:13px;opacity:.8}.admin-login-form{display:flex;flex-direction:column;gap:12px}.admin-login-form input{padding:10px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.25);background:#00000040;color:#fff;font-size:14px}.admin-login-form input::placeholder{color:#fff9}.admin-login-form button{margin-top:4px;padding:10px 16px;border-radius:8px;background:#4caf50;color:#fff;font-weight:600;font-size:15px;cursor:pointer;transition:background .2s ease,transform .1s ease}.admin-login-form button:hover:not(:disabled){background:#43a047;transform:translateY(-1px)}.admin-login-form button:disabled{opacity:.6;cursor:not-allowed}.admin-error{background:#f4433626;border-radius:8px;padding:8px 10px;font-size:13px;color:#ffcdd2}.admin-empty{margin-top:40px;text-align:center;color:#fff;font-size:16px;opacity:.8}.admin-messages-table{margin-top:20px;display:flex;flex-direction:column;gap:10px}.admin-message-row{background:#0f3460f5;border-radius:10px;padding:12px 14px;box-shadow:0 4px 14px #0006;color:#fff}.admin-message-meta{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:6px}.admin-message-user{display:flex;flex-direction:column;gap:2px}.admin-msg-username{font-weight:600;font-size:14px}.admin-msg-userid,.admin-msg-time{font-size:12px;opacity:.8}.admin-message-text{font-size:14px;line-height:1.4;margin-bottom:8px;white-space:pre-wrap}.admin-message-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-message-actions button{padding:6px 10px;border-radius:6px;font-size:13px;cursor:pointer;border:none;transition:background .2s ease,transform .1s ease}.btn-delete{background:#f57c00;color:#fff}.btn-delete:hover{background:#ef6c00;transform:translateY(-1px)}.btn-ban{background:#1976d2;color:#fff}.btn-ban:hover{background:#1565c0;transform:translateY(-1px)}.btn-ban-danger{background:#d32f2f;color:#fff}.btn-ban-danger:hover{background:#c62828;transform:translateY(-1px)}.btn-unban{background:#388e3c;color:#fff}.btn-unban:hover{background:#2e7d32;transform:translateY(-1px)}@media (max-width: 768px){.admin-content{padding:15px 10px}.admin-message-meta{flex-direction:column;align-items:flex-start}}.announcement-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.announcement-modal{background:var(--bg-primary);border-radius:20px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.announcement-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:2px solid var(--border-color)}.announcement-modal-header h2{margin:0;color:var(--text-primary);font-size:22px}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.announcement-modal-body{padding:20px}.current-announcement-section{margin-bottom:20px}.current-announcement-section h3{margin:0 0 15px;color:var(--text-primary);font-size:16px}.announcement-preview{padding:15px;border-radius:12px;margin-bottom:15px;color:#fff}.announcement-preview.announcement-info{background:#696969}.announcement-preview.announcement-warning{background:#dc143c}.announcement-preview.announcement-success{background:green}.preview-title{font-weight:600;font-size:16px;margin-bottom:8px}.preview-content{font-size:14px;line-height:1.5;white-space:pre-wrap}.deactivate-btn{padding:10px 20px;background:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;transition:background .3s}.deactivate-btn:hover:not(:disabled){background:#d32f2f}.deactivate-btn:disabled{opacity:.6;cursor:not-allowed}hr{border:none;border-top:2px solid var(--border-color);margin:20px 0}form h3{margin:0 0 20px;color:var(--text-primary);font-size:16px}label{display:block;margin-bottom:15px;color:var(--text-primary);font-size:14px;font-weight:500}input[type=text],textarea,select{width:100%;padding:12px;margin-top:8px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;transition:border-color .3s}input[type=text]:focus,textarea:focus,select:focus{outline:none;border-color:#667eea}textarea{resize:vertical;min-height:120px}.modal-actions{display:flex;gap:10px;margin-top:20px}.create-btn,.cancel-btn{flex:1;padding:12px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.create-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.cancel-btn{background:var(--bg-secondary);color:var(--text-primary)}.cancel-btn:hover{background:var(--border-color)}@media (max-width: 768px){.announcement-modal{max-width:100%;margin:0;border-radius:0;max-height:100vh}.modal-actions{flex-direction:column}}.wizard-page{min-height:100vh;background:var(--bg-primary);color:var(--text-primary);transition:background .3s ease,color .3s ease}.wizard-header{display:flex;align-items:center;justify-content:space-between;padding:20px;background:var(--bg-secondary);box-shadow:0 2px 10px var(--shadow);position:sticky;top:0;z-index:100;transition:background .3s ease}.wizard-header h1{font-size:24px;font-weight:600;margin:0;color:var(--text-primary)}.generation-panel{max-width:900px;margin:20px auto 0;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 4px 20px #667eea4d}.generate-btn{width:100%;padding:16px 24px;background:#fff;color:#667eea;border:none;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 2px 10px #0000001a}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #0003}.generate-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.generation-info{margin-top:12px;text-align:center;color:#fff;font-size:14px}.attempts-left{color:#ffffffe6}.attempts-exhausted{color:#ffcdd2;font-weight:500}.cooldown-text{color:#ffeb3b;font-weight:500}.wizard-form{max-width:900px;margin:0 auto;padding:30px 20px 80px}.wizard-section{margin-bottom:40px;padding:24px;background:var(--bg-secondary);border-radius:16px;box-shadow:0 2px 12px var(--shadow);transition:background .3s ease}.wizard-section h3{font-size:18px;font-weight:600;margin:0 0 16px;color:var(--text-primary);line-height:1.4}.wizard-bullets{margin:0 0 16px 20px;padding:0;color:var(--text-secondary)}.wizard-bullets li{margin-bottom:6px;line-height:1.5}.wizard-examples{margin:16px 0;padding:16px;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.example-good,.example-bad{margin-bottom:12px}.example-good:last-child,.example-bad:last-child{margin-bottom:0}.example-label{display:block;font-weight:600;margin-bottom:6px;font-size:14px}.example-good .example-label{color:#4caf50}.example-bad .example-label{color:#f44336}.example-good p,.example-bad p{margin:0;padding:10px;border-radius:8px;font-size:14px;line-height:1.6;background:var(--bg-secondary);color:var(--text-secondary);transition:background .3s ease}.example-good p{border-left:3px solid #4caf50}.example-bad p{border-left:3px solid #f44336}.manual-only-badge{display:inline-block;padding:6px 12px;background:#3f51b5;color:#fff;border-radius:12px;font-size:12px;font-weight:500;margin-bottom:12px}.wizard-input{width:100%;padding:14px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);resize:vertical;min-height:60px;transition:border-color .3s,background .3s,color .3s;box-sizing:border-box}.wizard-input:focus{border-color:#667eea;outline:none}.wizard-input::placeholder{color:var(--text-secondary);opacity:.6}.wizard-preview{margin:30px 0;padding:20px;background:var(--bg-secondary);border-radius:16px;box-shadow:0 2px 12px var(--shadow);transition:background .3s ease}.preview-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.preview-header h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.copy-btn{padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s;color:var(--text-primary)}.copy-btn:hover{background:#667eea;border-color:#667eea;color:#fff;transform:translateY(-1px)}.preview-content{margin:0;padding:16px;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-color);white-space:pre-wrap;word-wrap:break-word;font-family:inherit;font-size:14px;line-height:1.6;color:var(--text-secondary);max-height:400px;overflow-y:auto;transition:background .3s ease,border-color .3s ease,color .3s ease}.wizard-message{padding:14px 18px;border-radius:10px;margin:20px 0;font-size:15px;text-align:center;animation:slideIn .3s ease-out}.wizard-message.success{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.wizard-message.error{background:#f4433626;color:#f44336;border:1px solid rgba(244,67,54,.3)}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.wizard-actions{margin-top:30px;text-align:center}.wizard-submit{padding:16px 40px;background:#667eea;color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;min-width:250px}.wizard-submit:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.wizard-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (max-width: 768px){.wizard-header{padding:15px}.wizard-header h1{font-size:20px}.wizard-form{padding:20px 15px 80px}.wizard-section{padding:18px;margin-bottom:30px}.wizard-section h3{font-size:16px}.wizard-input{font-size:16px;padding:12px}.wizard-bullets{margin-left:16px;font-size:14px}.wizard-examples{padding:12px}.example-good p,.example-bad p{font-size:13px}.preview-content{font-size:13px;max-height:300px}.wizard-submit{width:100%;min-width:0}}@media (prefers-color-scheme: dark){.wizard-examples{background:#0003}.example-good p,.example-bad p{background:#0000004d}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-primary);border-radius:16px;padding:30px;max-width:500px;width:100%;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h3{margin:0 0 12px;font-size:22px;font-weight:600;color:var(--text-primary)}.modal-content p{margin:0 0 20px;color:var(--text-secondary);line-height:1.5}.modal-input{width:100%;padding:14px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;font-family:inherit;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s;box-sizing:border-box}.modal-input:focus{border-color:#667eea;outline:none}.modal-actions{display:flex;gap:12px;margin-top:24px}.modal-btn{flex:1;padding:14px 24px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.modal-btn-cancel{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.modal-btn-cancel:hover:not(:disabled){background:var(--border-color)}.modal-btn-save{background:#667eea;color:#fff}.modal-btn-save:hover:not(:disabled){background:#5568d3;transform:translateY(-1px)}.modal-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.modal-content{padding:24px}.modal-content h3{font-size:20px}.modal-actions{flex-direction:column}.modal-btn{width:100%}}.avatar-hint{font-size:14px;color:var(--text-secondary);margin:8px 0 12px;line-height:1.5}.avatar-hint a{color:#667eea;text-decoration:none}.avatar-hint a:hover{text-decoration:underline}.avatar-input{margin-top:8px}.avatar-preview-label{margin-top:10px;font-size:14px;font-weight:600;color:var(--text-primary)}.avatar-preview{margin-top:8px;padding:16px;background:var(--bg-secondary);border-radius:12px;text-align:center}.avatar-preview img{display:block;margin:0 auto}.remove-avatar-btn{padding:6px 12px;background:#f44336;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.remove-avatar-btn:hover{background:#d32f2f;transform:translateY(-1px);box-shadow:0 2px 8px #f443364d}.avatar-preview p{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.avatar-preview img{max-width:200px;max-height:200px;border-radius:12px;box-shadow:0 4px 12px #00000026;object-fit:cover}.avatar-error{color:#f44336;font-size:14px;display:block;margin-top:8px}@media (max-width: 768px){.avatar-preview img{max-width:150px;max-height:150px}}.pin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pin-modal{background:var(--bg-secondary);border-radius:20px;padding:40px;max-width:450px;width:90%;box-shadow:0 20px 60px #00000080;position:relative;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.pin-modal-close{position:absolute;top:15px;right:15px;background:transparent;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.pin-modal-close:hover{background:var(--bg-primary);color:var(--text-primary)}.pin-modal h2{color:var(--text-primary);margin-bottom:10px;text-align:center}.pin-modal-description{color:var(--text-secondary);margin-bottom:30px;text-align:center;font-size:14px}.pin-modal-actions{display:flex;gap:12px;margin-top:30px}.pin-modal-actions button{flex:1;padding:14px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--accent-rgb),.3)}.btn-secondary{background:transparent;color:var(--text-secondary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-primary);border-color:var(--accent-color);color:var(--accent-color)}.pin-hint{color:var(--text-secondary);font-size:12px;text-align:center;margin-top:20px;opacity:.8}.settings-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);transition:background .3s ease}.settings-header{background:var(--bg-primary);padding:20px 40px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.settings-header{padding:15px 20px}}.settings-header h1{margin:0;color:var(--text-primary);font-size:28px}@media (max-width: 768px){.settings-header h1{font-size:22px}}.settings-header .back-btn{padding:8px 16px;background:#667eea;color:#fff;border-radius:8px}.settings-content{max-width:900px;margin:0 auto;padding:40px 20px}.settings-section{background:var(--bg-primary);padding:30px;border-radius:15px;margin-bottom:30px;box-shadow:0 4px 15px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.settings-section{padding:20px}}.settings-section h2{margin:0 0 20px;color:var(--text-primary);font-size:24px}@media (max-width: 768px){.settings-section h2{font-size:20px}}.section-description{color:var(--text-secondary);margin-bottom:20px}.vip-status-card{padding:20px;background:var(--bg-secondary);border-radius:10px;margin-bottom:20px;text-align:center;transition:background .3s ease;width:100%;box-sizing:border-box}.status-badge{display:inline-block;padding:10px 30px;border-radius:25px;font-weight:600;font-size:18px;margin-bottom:10px}.status-badge[data-tier=free]{background:#e0e0e0;color:#666}.status-badge[data-tier=premium]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.status-badge[data-tier=vip]{background:linear-gradient(135deg,#f09433,#e6683c,#dc2743);color:#fff}.expires-text{margin:10px 0 0;color:var(--text-secondary);font-size:14px}.vip-form{display:flex;gap:10px;width:100%;box-sizing:border-box}@media (max-width: 768px){.vip-form{flex-direction:column;gap:15px}}.vip-form input{flex:1;padding:12px 18px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s;width:100%;box-sizing:border-box}@media (max-width: 768px){.vip-form input{width:100%}}.vip-form input:focus{border-color:#667eea}.vip-form button{padding:12px 30px;background:#667eea;color:#fff;border-radius:10px;font-weight:600;transition:background .3s;white-space:nowrap}@media (max-width: 768px){.vip-form button{width:100%;padding:14px}}.vip-form button:hover:not(:disabled){background:#5568d3}.vip-form button:disabled{opacity:.5;cursor:not-allowed}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;width:100%;box-sizing:border-box}@media (max-width: 768px){.models-grid{grid-template-columns:1fr;width:100%}}.model-card{padding:20px;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .3s;background:var(--bg-secondary)}.model-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.model-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a)}.model-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.model-header h3{margin:0;font-size:16px;color:var(--text-primary)}.check-mark{color:#667eea;font-size:20px;font-weight:700}.model-provider{display:inline-block;padding:4px 12px;background:var(--bg-secondary);color:#667eea;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.activation-required-banner{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:30px;border-radius:15px;margin-bottom:30px;text-align:center;box-shadow:0 4px 20px #ff6b6b4d}.activation-required-banner h2{margin:0 0 15px;font-size:26px;color:#fff}.activation-required-banner p{margin:10px 0;font-size:16px;line-height:1.5}@media (max-width: 768px){.activation-required-banner{padding:20px}.activation-required-banner h2{font-size:22px}.activation-required-banner p{font-size:14px}}.avatar-settings{display:flex;gap:20px;align-items:center;flex-wrap:wrap}@media (max-width: 768px){.avatar-settings{flex-direction:column;align-items:stretch}}.avatar-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;border:3px solid var(--border-color);display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);flex-shrink:0}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:40px;color:var(--text-secondary)}.avatar-input-group{flex:1;display:flex;gap:10px;min-width:0}@media (max-width: 768px){.avatar-input-group{flex-direction:column}}.avatar-input-group input{flex:1;padding:12px 18px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s;min-width:0}.avatar-input-group input:focus{border-color:#667eea;outline:none}.save-avatar-btn{padding:12px 30px;background:#667eea;color:#fff;border-radius:10px;font-weight:600;transition:background .3s;white-space:nowrap;border:none;cursor:pointer}.pin-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.pin-toggle input[type=checkbox]{display:none}.toggle-slider{position:relative;width:50px;height:26px;background:var(--border-color);border-radius:13px;transition:background .3s ease}.pin-toggle input:checked+.toggle-slider{background:#667eea}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0003}.pin-toggle input:checked+.toggle-slider:after{transform:translate(24px)}.toggle-label{font-weight:500;color:var(--text-primary);font-size:15px}.pin-info{margin-top:15px;padding:15px;background:#667eea1a;border-radius:8px;border:1px solid rgba(102,126,234,.3)}.pin-info p{margin:0 0 10px;color:var(--text-primary);font-weight:500}.change-pin-btn{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease}.change-pin-btn:hover{background:#5568d3;transform:translateY(-1px)}.change-pin-btn:active{transform:translateY(0)}.memory-page{min-height:100vh;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);transition:background .3s ease}.memory-header{background:var(--bg-primary);padding:20px 40px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 10px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.memory-header{padding:15px 20px;flex-wrap:wrap}}.memory-header h1{margin:0;color:var(--text-primary);font-size:28px}@media (max-width: 768px){.memory-header h1{font-size:22px}}.character-name{color:var(--text-secondary);font-size:18px}@media (max-width: 768px){.character-name{font-size:16px}}.back-btn{padding:8px 16px;background:#667eea;color:#fff;border-radius:8px;font-size:14px}.memory-content{max-width:800px;margin:0 auto;padding:40px 20px}.memory-text{background:var(--bg-primary);padding:30px;border-radius:15px;margin-bottom:20px;box-shadow:0 4px 15px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.memory-text{padding:20px}}.memory-text h2{margin:0 0 20px;color:var(--text-primary);font-size:24px}@media (max-width: 768px){.memory-text h2{font-size:20px}}.memory-box{background:var(--bg-secondary);padding:20px;border-radius:10px;line-height:1.8;color:var(--text-primary);white-space:pre-wrap;max-height:400px;overflow-y:auto;transition:background .3s ease,color .3s ease}.memory-edit{width:100%;padding:20px;border:2px solid var(--border-color);border-radius:10px;font-size:16px;line-height:1.8;font-family:inherit;resize:vertical;min-height:300px;background:var(--bg-secondary);color:var(--text-primary);transition:border-color .3s,background .3s}.memory-edit:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}@media (max-width: 768px){.memory-edit{font-size:16px;padding:15px}}.memory-actions{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}@media (max-width: 768px){.memory-actions{gap:10px}.memory-actions button{flex:1 1 calc(50% - 5px);min-width:140px}}.edit-btn{flex:1;padding:15px;background:#667eea;color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:background .3s}.edit-btn:hover{background:#5568d3}.regen-btn{flex:1;padding:15px;background:#667eea;color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:background .3s}.regen-btn:hover:not(:disabled){background:#5568d3}.regen-btn:disabled{opacity:.6;cursor:not-allowed}.save-btn{flex:1;padding:15px;background:#4caf50;color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:background .3s}.save-btn:hover{background:#45a049}.cancel-btn{padding:15px 30px;background:#9e9e9e;color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:background .3s}.cancel-btn:hover{background:#757575}.delete-btn{padding:15px 30px;background:#f44336;color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:background .3s}.delete-btn:hover{background:#d32f2f}.memory-info{background:var(--bg-primary);padding:25px;border-radius:15px;box-shadow:0 4px 15px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.memory-info{padding:20px}}.memory-info p{margin:0 0 15px;color:var(--text-secondary);line-height:1.6}.memory-info p:last-child{margin-bottom:0}.empty-memory{background:var(--bg-primary);padding:60px 40px;border-radius:15px;text-align:center;box-shadow:0 4px 15px var(--shadow);transition:background .3s ease}@media (max-width: 768px){.empty-memory{padding:40px 20px}}.empty-memory h2{margin:0 0 15px;color:var(--text-primary);font-size:28px}@media (max-width: 768px){.empty-memory h2{font-size:24px}}.empty-memory p{color:var(--text-secondary);font-size:16px;margin-bottom:30px}.create-btn{padding:15px 40px;background:#667eea;color:#fff;border-radius:12px;font-size:18px;font-weight:600;transition:transform .2s}.create-btn:hover:not(:disabled){transform:scale(1.05)}.create-btn:disabled{opacity:.6;cursor:not-allowed}.loading{display:flex;justify-content:center;align-items:center;height:100vh;color:#fff;font-size:24px}.compcoins-page{min-height:100vh;padding:20px;color:#fff}.compcoins-content{display:flex;flex-direction:column;gap:24px}.compcoins-section{background:#0006;border-radius:12px;padding:16px 20px}.balance-card,.daily-card{display:flex;flex-direction:column;gap:8px}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.package-card{background:#00000080;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:8px}.package-title{font-weight:600}.package-cost{font-size:18px}.package-meta{font-size:12px;opacity:.8;display:flex;justify-content:space-between}.badge{display:inline-block;margin-top:4px;padding:2px 6px;border-radius:6px;font-size:11px}.badge.popular{background:#ffd70033}.badge.best{background:#ff450040}.code-form{display:flex;gap:8px}.code-form input{flex:1}.cc-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 14px;border-radius:999px;border:none;cursor:pointer;font-weight:600;font-size:14px;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #00000040;transition:background .2s ease,transform .1s ease,box-shadow .2s ease,opacity .2s ease}.cc-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #00000059}.cc-btn:disabled{opacity:.6;cursor:default;box-shadow:none}.cc-btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a)}.cc-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d)}.daily-bonus-btn{margin-top:8px;align-self:flex-start}.code-submit-btn{min-width:150px}.package-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.cc-btn-boosty{background:linear-gradient(135deg,#f59e0b,#d97706)}.cc-btn-boosty:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309)}.cc-btn-hipolink{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.cc-btn-hipolink:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#6d28d9)}@media (max-width: 600px){.compcoins-page{padding:12px}.compcoins-section{padding:12px 14px}.code-form{flex-direction:column}.code-form input,.code-form button{width:100%}.packages-grid{grid-template-columns:1fr}}.compcoins-history-page{min-height:100vh;padding:20px;color:#fff}.compcoins-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.compcoins-content{background:#0006;border-radius:12px;padding:16px 20px;width:100%;box-sizing:border-box}.history-table{width:100%;border-collapse:collapse;margin-bottom:16px}.history-table th,.history-table td{border-bottom:1px solid rgba(255,255,255,.08);padding:6px 8px;font-size:14px}.history-table th{text-align:left;opacity:.8}.history-table td.pos{color:#6ee7b7}.history-table td.neg{color:#fca5a5}.empty{text-align:center;opacity:.8}.pagination{display:flex;justify-content:center;align-items:center;gap:12px}@media (max-width: 600px){.compcoins-history-page{padding:12px}.compcoins-content{padding:12px;overflow-x:auto}.history-table{min-width:520px;font-size:12px}.history-table th,.history-table td{padding:4px 6px}}.referral-page{min-height:100vh;padding:20px;color:#fff}.referral-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.back-btn{background:transparent;border:1px solid rgba(255,255,255,.3);color:inherit;padding:6px 10px;border-radius:6px;cursor:pointer}.referral-content{display:flex;flex-direction:column;gap:20px}.referral-section{background:#0006;border-radius:12px;padding:16px 20px}.referral-link-block{display:flex;gap:10px;align-items:center;margin-top:8px}.referral-link-text{flex:1;padding:6px 10px;border-radius:6px;background:#0009;word-break:break-all}.referral-summary,.referral-monthly{margin-top:10px;display:flex;flex-wrap:wrap;gap:12px;font-size:14px;opacity:.9}.referral-table{width:100%;border-collapse:collapse;margin-top:10px}.referral-table th,.referral-table td{border-bottom:1px solid rgba(255,255,255,.1);padding:6px 8px;font-size:14px}.referral-table th{text-align:left;opacity:.8}.empty{opacity:.8}.loading{padding:40px;text-align:center}.admin-stats-page{padding:20px;max-width:1400px;margin:0 auto;color:#e0e0e0}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.admin-header h1{margin:0;font-size:24px}.refresh-btn,.logout-btn{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:700;margin-left:10px}.refresh-btn{background-color:#2196f3;color:#fff}.logout-btn{background-color:#f44336;color:#fff}.admin-login-container{display:flex;justify-content:center;align-items:center;height:80vh}.admin-login-form{background-color:#1e1e1e;padding:30px;border-radius:8px;box-shadow:0 4px 12px #00000080;display:flex;flex-direction:column;gap:15px;width:300px}.admin-login-form input{padding:10px;border-radius:4px;border:1px solid #333;background-color:#2d2d2d;color:#fff}.admin-login-form button{padding:10px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700}.table-container{overflow-x:auto;background-color:#1e1e1e;border-radius:8px;box-shadow:0 4px 12px #0000004d}table{width:100%;border-collapse:collapse}th,td{padding:12px 15px;text-align:left;border-bottom:1px solid #333}th{background-color:#2d2d2d;cursor:pointer;-webkit-user-select:none;user-select:none}th:hover{background-color:#3d3d3d}tr:hover{background-color:#2a2a2a}.vip-row{background-color:#ffd7000d}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.status-badge.free{background-color:#757575;color:#fff}.status-badge.premium{background-color:#2196f3;color:#fff}.status-badge.vip{background-color:#ffc107;color:#000}.note-cell{cursor:pointer;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.note-cell:hover{background-color:#333}.add-note{color:#888;font-style:italic;font-size:12px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#1e1e1e;padding:20px;border-radius:8px;width:400px;display:flex;flex-direction:column;gap:15px}.modal-content textarea{background-color:#2d2d2d;border:1px solid #333;color:#fff;padding:10px;border-radius:4px;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.modal-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer}.save-btn{background-color:#4caf50;color:#fff}.error-message{color:#f44336;font-size:14px;text-align:center}.pin-verify-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary);padding:20px}.pin-verify-card{background:var(--bg-secondary);border-radius:20px;padding:50px 40px;max-width:450px;width:100%;box-shadow:0 10px 40px #0000004d;text-align:center}.pin-icon{font-size:64px;margin-bottom:20px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.pin-verify-card h2{color:var(--text-primary);margin-bottom:10px;font-size:28px}.pin-description{color:var(--text-secondary);margin-bottom:40px;font-size:15px;line-height:1.5}.pin-inputs{display:flex;gap:15px;justify-content:center;margin:30px 0}.pin-digit{width:70px;height:80px;font-size:36px;font-weight:700;text-align:center;border:3px solid var(--border-color);border-radius:16px;background:var(--bg-primary);color:var(--text-primary);transition:all .2s ease}.pin-digit:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 4px rgba(var(--accent-rgb),.1);transform:scale(1.05)}.pin-digit:disabled{opacity:.6;cursor:not-allowed}.pin-error{color:var(--error-color, #ff4444);text-align:center;margin-top:15px;font-size:14px;font-weight:500;padding:10px;background:#ff44441a;border-radius:8px}.pin-warning{color:var(--warning-color, #ffa500);text-align:center;margin-top:10px;font-size:13px;padding:8px;background:#ffa5001a;border-radius:8px}.pin-actions{margin-top:30px;display:flex;flex-direction:column;gap:12px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--text-secondary);border:2px solid var(--border-color);padding:14px 28px;border-radius:12px;font-size:14px;cursor:pointer;transition:all .2s ease;font-weight:500}.btn-secondary:hover{background:var(--bg-primary);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-2px)}.btn-secondary:active{transform:translateY(0)}@media (max-width: 480px){.pin-verify-card{padding:40px 20px}.pin-inputs{gap:10px}.pin-digit{width:60px;height:70px;font-size:32px}.pin-icon{font-size:48px}}.app{min-height:100vh}:root{--bg-gradient-start: #667eea;--bg-gradient-end: #764ba2;--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8eaf6;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--text-inverse: #ffffff;--border-color: #e0e0e0;--shadow: rgba(0, 0, 0, .1);--shadow-strong: rgba(0, 0, 0, .15)}[data-theme=dark]{--bg-gradient-start: #1a1a2e;--bg-gradient-end: #16213e;--bg-primary: #0f3460;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--text-primary: #e8e8e8;--text-secondary: #b0b0b0;--text-tertiary: #808080;--text-inverse: #ffffff;--border-color: #2a2a3e;--shadow: rgba(0, 0, 0, .3);--shadow-strong: rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--bg-gradient-start) 0%,var(--bg-gradient-end) 100%);min-height:100vh;color:var(--text-primary);transition:background .3s ease,color .3s ease}#root{min-height:100vh}button{cursor:pointer;border:none;outline:none;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent}input,textarea{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}@media (max-width: 768px){body{font-size:14px}}
