:root{--bg-primary: #0f0f14;--bg-secondary: #1a1a24;--bg-tertiary: #252532;--bg-card: #1e1e2a;--bg-hover: #2a2a3a;--text-primary: #e8e8f0;--text-secondary: #a0a0b0;--text-muted: #6a6a7a;--accent-primary: #7c5cff;--accent-secondary: #9d7fff;--accent-glow: rgba(124, 92, 255, .3);--success: #4ade80;--warning: #fbbf24;--error: #f87171;--info: #60a5fa;--border-color: #2a2a3a;--border-radius: 12px;--border-radius-sm: 8px;--border-radius-lg: 16px;--bubble-user: linear-gradient(135deg, #342756 0%, #2a1f45 100%);--bubble-ai: linear-gradient(135deg, #2a2a3a 0%, #1e1e2a 100%);--bubble-ooc: linear-gradient(135deg, #3a3a4a 0%, #2a2a3a 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px var(--accent-glow);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--font-xs: .75rem;--font-sm: .875rem;--font-md: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 2rem}[data-theme=light]{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #e8e8ec;--bg-card: #ffffff;--bg-hover: #f0f0f4;--text-primary: #1a1a2e;--text-secondary: #4a4a5a;--text-muted: #8a8a9a;--border-color: #d0d0d8;--bubble-ai: linear-gradient(135deg, #e8e8ec 0%, #f0f0f4 100%);--bubble-ooc: linear-gradient(135deg, #e0e0e8 0%, #d8d8e0 100%);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12)}[data-font-size=small]{--font-sm: .75rem;--font-md: .875rem;--font-lg: 1rem}[data-font-size=large]{--font-sm: 1rem;--font-md: 1.125rem;--font-lg: 1.25rem}[data-font-size=xlarge]{--font-sm: 1.125rem;--font-md: 1.25rem;--font-lg: 1.5rem}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:var(--font-3xl)}h2{font-size:var(--font-2xl)}h3{font-size:var(--font-xl)}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-size:var(--font-md);font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-normal);outline:none;position:relative;overflow:hidden}.btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn:hover:before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,#7c5cff,#9d7fff,#b89fff);color:#fff;box-shadow:0 4px 15px #7c5cff66;border:1px solid rgba(255,255,255,.1)}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 6px 25px #7c5cff99}.btn-primary:active{transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:0 2px 8px #0003}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent-primary);box-shadow:0 4px 12px #7c5cff4d;transform:translateY(-2px)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.btn-danger{background:linear-gradient(135deg,#f87171,#ef4444);color:#fff;box-shadow:0 4px 15px #f8717166}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f8717199}.btn-sm{padding:8px 16px;font-size:var(--font-sm)}.btn-icon{width:40px;height:40px;padding:0;border-radius:50%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn:disabled:before{display:none}.form-group{margin-bottom:20px}.form-label{display:block;margin-bottom:10px;font-size:var(--font-sm);font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.form-input,.form-textarea,.form-select{width:100%;padding:14px 18px;font-size:var(--font-md);color:var(--text-primary);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-normal);outline:none;box-shadow:0 2px 8px #0000001a}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 4px var(--accent-glow),0 4px 12px #7c5cff4d;transform:translateY(-1px)}.form-input:disabled,.form-textarea:disabled,.form-select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}.form-textarea{min-height:120px;resize:vertical}.form-select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%237c5cff' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:48px}.form-select:disabled{cursor:not-allowed}.form-error{color:var(--error);font-size:var(--font-sm);margin-top:6px;display:flex;align-items:center;gap:4px}.form-error:before{content:"⚠️";font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:24px;transition:all var(--transition-normal);box-shadow:0 2px 8px #0003;position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transform:scaleX(0);transition:transform var(--transition-normal)}.card:hover{border-color:var(--accent-primary);box-shadow:0 8px 30px #7c5cff4d;transform:translateY(-2px)}.card:hover:before{transform:scaleX(1)}.card-clickable{cursor:pointer}.card-clickable:hover{transform:translateY(-6px);box-shadow:0 12px 40px #7c5cff66}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 20px}.page{flex:1;padding:24px 0}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.page-title{font-size:var(--font-2xl)}.grid{display:grid;gap:24px}.grid-2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:16px 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 10px #0000004d}.header-content{display:flex;align-items:center;justify-content:space-between}.logo{font-size:var(--font-xl);font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary),#b89fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-size:200% 200%;animation:gradientFlow 3s ease infinite;letter-spacing:.5px;text-shadow:0 0 30px rgba(124,92,255,.5)}@keyframes gradientFlow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.nav{display:flex;align-items:center;gap:24px}.nav-link{color:var(--text-secondary);font-weight:600;transition:all var(--transition-fast);position:relative;padding:4px 0}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width var(--transition-normal)}.nav-link:hover,.nav-link.active{color:var(--accent-primary)}.nav-link:hover:after,.nav-link.active:after{width:100%}.character-card{display:flex;gap:16px;align-items:flex-start}.character-avatar{width:80px;height:80px;border-radius:var(--border-radius);object-fit:cover;background:var(--bg-tertiary);flex-shrink:0}.character-avatar-placeholder{width:80px;height:80px;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-size:var(--font-2xl);font-weight:600;color:#fff;flex-shrink:0}.character-info{flex:1;min-width:0}.character-name{font-size:var(--font-lg);font-weight:600;margin-bottom:4px}.character-meta{font-size:var(--font-sm);color:var(--text-muted)}.chat-container{display:flex;flex-direction:column;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;--chat-bg: var(--bg-primary);--user-bubble-bg: #342756;--ai-bubble-bg: #2a2a3a;--user-text-color: #ffffff;--ai-text-color: var(--text-primary);background-color:var(--chat-bg);position:relative}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:10}.chat-header-info{display:flex;align-items:center;gap:12px}.chat-header-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.chat-header-name{font-weight:600}.chat-header-scenario{font-size:var(--font-sm);color:var(--text-muted)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}.chat-input-container{padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));background:var(--bg-secondary);border-top:1px solid var(--border-color);flex-shrink:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;z-index:10}.chat-input-wrapper{display:flex;gap:12px;align-items:stretch}.chat-input{flex:1;min-height:48px;max-height:100px;resize:none;padding:12px 16px;font-size:var(--font-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-primary);outline:none}.chat-input:focus{border-color:var(--accent-primary)}.chat-input-buttons{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.chat-input-buttons .btn-icon{width:44px;height:44px}.ooc-btn-small{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#fbbf2426;border:1px solid var(--warning);border-radius:50%;font-size:11px;font-weight:700;color:var(--warning);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;letter-spacing:.5px}.ooc-btn-small:hover{background:#fbbf2440;box-shadow:0 0 10px #fbbf244d}.message{max-width:80%;animation:fadeIn .3s ease}@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-bubble{padding:12px 16px;border-radius:var(--border-radius-lg);line-height:1.5;word-wrap:break-word;font-size:var(--font-md)}.message-user .message-bubble{background:var(--user-bubble-bg);color:var(--user-text-color);border-bottom-right-radius:4px}.message-assistant .message-bubble{background:var(--ai-bubble-bg);color:var(--ai-text-color);border:1px solid var(--border-color);border-bottom-left-radius:4px}.message-ooc .message-bubble{background:var(--bubble-ooc);border:1px dashed var(--border-color);opacity:.8}.message-meta{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:var(--font-xs);color:var(--text-muted)}.message-actions{display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.message:hover .message-actions{opacity:1}.message-action-btn{padding:4px 8px;font-size:var(--font-xs);background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:4px}.message-action-btn:hover{background:var(--bg-hover);color:var(--text-primary)}[data-bubble-style=classic] .message-bubble{border-radius:4px}[data-bubble-style=minimal] .message-bubble{background:transparent!important;border:none!important;padding:8px 0}[data-bubble-style=minimal] .message-user .message-bubble{color:var(--accent-primary)}.chat-container[style*=background-image] .chat-messages:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0f0f14d9;z-index:0;pointer-events:none}.sidebar{position:fixed;top:0;left:-300px;width:300px;height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);z-index:200;transition:left var(--transition-normal);overflow-y:auto}.sidebar.open{left:0}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:199;opacity:0;visibility:hidden;transition:all var(--transition-normal)}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.sidebar-content{padding:16px}.sidebar-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:transparent;border:none;border-radius:var(--border-radius);color:var(--text-primary);font-size:var(--font-md);cursor:pointer;transition:background var(--transition-fast);text-align:left}.sidebar-menu-item:hover{background:var(--bg-hover)}.sidebar-divider{border:none;border-top:1px solid var(--border-color);margin:12px 0}.scenario-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--border-radius);cursor:pointer;transition:background var(--transition-fast)}.scenario-item:hover{background:var(--bg-hover)}.scenario-item.active{background:var(--accent-glow);border:1px solid var(--accent-primary)}.stats-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);padding:16px}.stats-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color)}.stats-item:last-child{border-bottom:none}.stats-label{color:var(--text-muted);font-size:var(--font-sm)}.stats-value{font-weight:600}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width var(--transition-normal)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:300;padding:20px;animation:overlayFadeIn .3s ease}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--accent-primary);border-radius:var(--border-radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:modalIn .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px #7c5cff4d;position:relative}.modal:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),#b89fff);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}@keyframes modalIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:var(--font-xl);font-weight:700;background:linear-gradient(135deg,var(--text-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.ooc-toggle{display:flex;align-items:center;gap:8px;padding:8px 12px;background:transparent;border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-muted);cursor:pointer;font-size:var(--font-sm);transition:all var(--transition-fast)}.ooc-toggle:hover{border-color:var(--accent-primary);color:var(--text-primary)}.ooc-toggle.active{background:var(--warning);border-color:var(--warning);color:#000}.loading{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:50px;height:50px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);border-radius:50%;animation:spin 1s cubic-bezier(.68,-.55,.265,1.55) infinite;box-shadow:0 0 20px #7c5cff4d}@keyframes spin{to{transform:rotate(360deg)}}.loading-small{display:flex;align-items:center;justify-content:center;padding:20px;font-size:var(--font-sm);color:var(--text-muted)}.loading-small:before{content:"⏳";margin-right:8px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.modal-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;border-radius:var(--border-radius-lg);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-loading-spinner{width:60px;height:60px;border:5px solid rgba(124,92,255,.2);border-top-color:var(--accent-primary);border-right-color:var(--accent-secondary);border-bottom-color:#b89fff;border-radius:50%;animation:spinFancy 1.2s cubic-bezier(.68,-.55,.265,1.55) infinite;box-shadow:0 0 30px #7c5cff80;position:relative}.modal-loading-spinner:after{content:"";position:absolute;top:50%;left:50%;width:30px;height:30px;border:3px solid transparent;border-top-color:#b89fff;border-radius:50%;transform:translate(-50%,-50%);animation:spinReverse .8s linear infinite}@keyframes spinFancy{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(360deg) scale(1)}}@keyframes spinReverse{to{transform:translate(-50%,-50%) rotate(-360deg)}}.modal-loading-text{margin-top:20px;color:var(--text-primary);font-size:var(--font-md);font-weight:600;text-align:center;animation:pulse 1.5s ease-in-out infinite}.modal-loading-subtext{margin-top:8px;color:var(--text-secondary);font-size:var(--font-sm);text-align:center}.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted)}.empty-state-icon{font-size:64px;margin-bottom:20px;animation:floatIcon 3s ease-in-out infinite;filter:drop-shadow(0 4px 12px rgba(124,92,255,.3))}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.empty-state-title{font-size:var(--font-xl);color:var(--text-primary);margin-bottom:12px;font-weight:700}.empty-state-text{margin-bottom:28px;font-size:var(--font-md);line-height:1.6}@media (max-width: 768px){.container{padding:0 12px}.page{padding:16px 0}.page-header{flex-direction:column;align-items:flex-start;margin-bottom:20px}.page-title{font-size:var(--font-xl)}.header{padding:10px 0}.header-content{flex-wrap:wrap;gap:8px}.logo{font-size:var(--font-md)}.nav{gap:4px;flex-wrap:wrap;justify-content:flex-end;flex:1}.nav-link{font-size:var(--font-xs);padding:4px 6px}.nav .btn-sm{padding:4px 8px;font-size:var(--font-xs)}.card{padding:16px}.grid-2,.grid-3{grid-template-columns:1fr;gap:16px}.character-card{flex-direction:row;text-align:left}.character-avatar,.character-avatar-placeholder{width:60px;height:60px;margin:0}.character-name{font-size:var(--font-md)}.chat-container{height:100vh;height:100dvh}.chat-header{padding:12px;flex-wrap:wrap;gap:8px}.chat-header-info{gap:8px}.chat-header-name{font-size:var(--font-md)}.chat-header-scenario{font-size:var(--font-xs)}.chat-header .form-select{padding:6px 28px 6px 8px;font-size:var(--font-xs);max-width:120px}.chat-messages{padding:12px;gap:12px}.message{max-width:85%}.message-meta{flex-wrap:wrap}.message-bubble{padding:10px 14px;font-size:var(--font-sm)}.chat-input-container{padding:12px}.chat-input-wrapper{gap:8px}.chat-input{min-height:44px;max-height:88px;padding:10px 12px;font-size:16px}.chat-input-buttons{gap:4px}.chat-input-buttons .btn-icon{width:40px;height:40px}.ooc-btn-small{width:40px;height:40px;font-size:10px}.ooc-toggle{padding:6px 10px;font-size:var(--font-xs)}.btn-icon{width:44px;height:44px}.modal-overlay{padding:12px;align-items:flex-end}.modal{max-height:80vh;border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}.modal-header,.modal-body,.modal-footer{padding:16px}.sidebar{width:280px;left:-280px}.form-input,.form-textarea,.form-select{padding:10px 12px;font-size:16px}.btn{padding:10px 20px}.btn-sm{padding:8px 14px}}@media (max-width: 380px){.nav-link{font-size:var(--font-xs);padding:4px 6px}.chat-header .form-select{max-width:100px}.message{max-width:90%}}.search-bar{display:flex;align-items:center;gap:12px;padding:8px 20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.search-bar .form-input{flex:1;padding:8px 12px}.search-count{font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-sm{font-size:var(--font-sm)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:8px}.gap-2{gap:16px}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.credit-banner{display:flex;align-items:center;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#2a2015,#1a1510);border:2px solid #4a3a20;border-radius:var(--border-radius-lg);margin-bottom:24px;cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:hidden;box-shadow:0 4px 20px #ffd70033}.credit-banner:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,215,0,.1) 0%,transparent 70%);animation:creditGlow 3s ease-in-out infinite}@keyframes creditGlow{0%,to{transform:translate(0);opacity:.5}50%{transform:translate(10%,10%);opacity:.8}}.credit-banner:hover{border-color:#8a7a40;box-shadow:0 8px 35px #ffd70066;transform:translateY(-2px)}.credit-amount{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.credit-icon{font-size:36px;animation:coinPulse 2s ease-in-out infinite;filter:drop-shadow(0 0 10px rgba(255,215,0,.6))}@keyframes coinPulse{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.1) rotate(-5deg)}75%{transform:scale(1.1) rotate(5deg)}}.credit-value{font-size:var(--font-3xl);font-weight:800;color:gold;text-shadow:0 0 20px rgba(255,215,0,.8),0 0 40px rgba(255,215,0,.4);letter-spacing:1px}.credit-expire{font-size:var(--font-sm);color:#d4af37;position:relative;z-index:1;display:flex;align-items:center;gap:4px}.credit-expire:before{content:"⏱️";font-size:14px}.credit-buttons{display:flex;gap:8px;margin-left:auto}.credit-add-btn{padding:10px 20px;background:linear-gradient(135deg,#5a4a30,#4a3a20);border:2px solid #6a5a30;border-radius:var(--border-radius);color:gold;font-weight:700;font-size:var(--font-md);cursor:pointer;transition:all var(--transition-fast);position:relative;z-index:1;box-shadow:0 4px 15px #0000004d}.credit-add-btn:hover{background:linear-gradient(135deg,#6a5a40,#5a4a30);border-color:#8a7a50;box-shadow:0 6px 25px #ffd70066;transform:scale(1.05)}.credit-buy-btn{padding:10px 20px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:2px solid var(--accent-primary);border-radius:var(--border-radius);color:#fff;font-weight:700;font-size:var(--font-md);cursor:pointer;transition:all var(--transition-fast);position:relative;z-index:1;box-shadow:0 4px 15px #7c5cff4d}.credit-buy-btn:hover{box-shadow:0 6px 25px #7c5cff80;transform:scale(1.05)}.credit-mini{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#ffd7001a;border-radius:var(--border-radius);font-weight:600;color:gold}.credit-icon-sm{font-size:14px}.credits-spent{color:var(--error);font-size:var(--font-xs)}.stories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.story-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);cursor:pointer;transition:all var(--transition-normal);position:relative;overflow:visible;box-shadow:0 2px 8px #0003}.story-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),#b89fff);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}.story-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 12px 35px #7c5cff66}.story-card:hover:before{transform:scaleX(1)}.story-avatar{width:70px;height:70px;border-radius:var(--border-radius);overflow:hidden;flex-shrink:0;background:var(--bg-tertiary);box-shadow:0 4px 12px #0000004d;transition:all var(--transition-normal)}.story-card:hover .story-avatar{transform:scale(1.05);box-shadow:0 6px 20px #7c5cff80}.story-avatar img{width:100%;height:100%;object-fit:cover}.story-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));animation:gradientShift 3s ease infinite}@keyframes gradientShift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.story-info{flex:1;min-width:0}.story-title{font-size:var(--font-lg);font-weight:600;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:linear-gradient(135deg,var(--text-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.story-meta{font-size:var(--font-sm);color:var(--text-muted);display:flex;align-items:center;gap:4px}.story-meta:before{content:"💬";font-size:14px}.story-menu-container{position:relative;z-index:10}.story-menu-btn{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);font-size:20px;font-weight:700;cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary)}.story-menu-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary)}.story-menu{position:fixed;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);z-index:9999;min-width:180px;overflow:visible;animation:fadeIn var(--transition-fast);white-space:nowrap}.story-menu-item{width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-primary);font-size:var(--font-md);text-align:left;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px}.story-menu-item:hover{background:var(--bg-hover)}.story-menu-item-danger{color:var(--error)}.story-menu-item-danger:hover{background:#f871711a}.slider-options{display:flex;gap:10px;flex-wrap:wrap}.slider-option{flex:1;min-width:100px;padding:14px 18px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--border-radius);color:var(--text-secondary);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-normal);text-align:center;position:relative;overflow:hidden}.slider-option:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(124,92,255,.2),transparent);transition:left .5s}.slider-option:hover:before{left:100%}.slider-option:hover{border-color:var(--accent-primary);color:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 12px #7c5cff4d}.slider-option:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.slider-option:disabled:hover{border-color:var(--border-color);box-shadow:none}.slider-option.active{background:linear-gradient(135deg,#7c5cff,#9d7fff);border-color:var(--accent-primary);color:#fff;box-shadow:0 6px 20px #7c5cff80;transform:translateY(-2px)}.slider-option.active:before{display:none}.cost-badge{display:inline-block;margin-left:8px;padding:3px 10px;background:#ffd70033;border:1px solid rgba(255,215,0,.4);border-radius:12px;font-size:var(--font-xs);color:gold;font-weight:700;box-shadow:0 0 10px #ffd7004d}.cost-summary{display:flex;justify-content:space-between;align-items:center;padding:20px;background:linear-gradient(135deg,#7c5cff1a,#9d7fff0d);border:2px solid var(--accent-primary);border-radius:var(--border-radius);margin-top:20px;box-shadow:0 4px 15px #7c5cff33}.cost-summary span:first-child{font-weight:600;color:var(--text-primary)}.cost-total{font-size:var(--font-2xl);font-weight:800;color:gold;text-shadow:0 0 20px rgba(255,215,0,.6);display:flex;align-items:center;gap:4px}.cost-total:before{content:"¤";font-size:var(--font-xl);animation:coinSpin 3s linear infinite}@keyframes coinSpin{0%,to{transform:rotateY(0)}50%{transform:rotateY(180deg)}}.ooc-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:0 12px;height:44px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:18px;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;flex-shrink:0}.ooc-btn span{font-size:var(--font-sm);font-weight:600}.ooc-btn:hover{border-color:var(--warning);background:#fbbf241a}.ooc-hint{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:16px;line-height:1.5}.chat-header-cost{font-size:var(--font-xs);color:gold}.chat-header-free{font-size:var(--font-xs);color:var(--success);font-weight:600}.modal-create{max-width:480px}.modal-warning{max-width:380px;text-align:center}.modal-warning .modal-body{padding:24px}.modal-warning p{font-size:var(--font-lg);margin:0}.modal-warning .modal-footer{justify-content:center}.profile-card{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-tertiary) 100%);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);padding:32px;margin-bottom:28px;display:flex;align-items:center;gap:24px;box-shadow:0 4px 15px #0003;position:relative;overflow:hidden}.profile-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),#b89fff)}.profile-avatar{flex-shrink:0}.profile-avatar-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800;color:#fff;box-shadow:0 8px 25px #7c5cff80;animation:profilePulse 3s ease-in-out infinite}@keyframes profilePulse{0%,to{box-shadow:0 8px 25px #7c5cff80}50%{box-shadow:0 8px 35px #7c5cffcc}}.profile-info{flex:1}.profile-name{font-size:var(--font-2xl);font-weight:800;margin-bottom:8px;background:linear-gradient(135deg,var(--text-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.profile-meta{color:var(--text-secondary);font-size:var(--font-md)}.credits-balance-card{background:linear-gradient(135deg,#2a2015,#1a1510);border:2px solid #4a3a20;border-radius:var(--border-radius-lg);padding:28px;margin-bottom:28px;box-shadow:0 8px 30px #ffd7004d;position:relative;overflow:hidden}.credits-balance-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,215,0,.15) 0%,transparent 70%);animation:creditGlowCard 4s ease-in-out infinite}@keyframes creditGlowCard{0%,to{transform:translate(0) rotate(0);opacity:.5}50%{transform:translate(5%,5%) rotate(180deg);opacity:.8}}.credits-balance-header{display:flex;align-items:center;gap:20px;position:relative;z-index:1;margin-bottom:20px}.credits-balance-icon{font-size:3.5rem;animation:coinFloat 3s ease-in-out infinite;filter:drop-shadow(0 0 15px rgba(255,215,0,.8))}@keyframes coinFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(180deg)}}.credits-balance-info{flex:1}.credits-balance-label{font-size:var(--font-sm);color:#d4af37;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:8px}.credits-balance-value{font-size:3rem;font-weight:900;color:gold;text-shadow:0 0 30px rgba(255,215,0,.8);letter-spacing:2px}.credits-balance-expiry{position:relative;z-index:1}.credits-expiry-text{display:flex;align-items:center;gap:8px;color:#d4af37;font-size:var(--font-sm);margin-bottom:12px;font-weight:600}.credits-expiry-progress{height:8px;background:#ffd70033;border-radius:4px;overflow:hidden;box-shadow:inset 0 2px 4px #0000004d}.credits-expiry-progress-bar{height:100%;background:linear-gradient(90deg,gold,#ffed4e,gold);background-size:200% 100%;animation:progressShine 2s linear infinite;border-radius:4px;box-shadow:0 0 10px #ffd70099;transition:width .5s ease}@keyframes progressShine{0%{background-position:200% 0}to{background-position:-200% 0}}.about-section{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-tertiary) 100%)}.about-content{display:grid;grid-template-columns:1fr auto;gap:32px;align-items:start}.about-text p{margin-bottom:16px;line-height:1.7;color:var(--text-secondary)}.about-text strong{color:var(--text-primary);font-weight:700}.about-features{list-style:none;padding:0;margin:16px 0}.about-features li{padding:12px 0;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:12px;font-size:var(--font-md)}.about-features li:last-child{border-bottom:none}.about-actions{min-width:250px}.about-version{margin-top:24px;padding-top:20px;border-top:2px solid var(--border-color);display:flex;align-items:center;gap:12px;justify-content:center;color:var(--text-muted);font-size:var(--font-sm)}@media (max-width: 768px){.profile-card{flex-direction:column;text-align:center;padding:24px}.profile-avatar-circle{width:70px;height:70px;font-size:2rem}.profile-name{font-size:var(--font-xl)}.credits-balance-card{padding:20px}.credits-balance-header{flex-direction:column;text-align:center}.credits-balance-value{font-size:2.5rem}.about-content{grid-template-columns:1fr}.about-actions{min-width:100%}.theme-grid{grid-template-columns:1fr}.theme-item-wide{grid-column:span 1}}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:24px}.theme-item{display:flex;flex-direction:column;gap:8px}.theme-item-wide{grid-column:span 2}.color-input-group{display:flex;gap:12px;align-items:center}.color-picker{width:60px;height:48px;border:2px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary)}.color-picker:hover{border-color:var(--accent-primary);transform:scale(1.05)}.color-input-group .form-input{flex:1}.theme-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:2px solid var(--border-color)}.theme-actions .btn{min-width:180px}.settings-section{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);padding:28px;margin-bottom:28px;box-shadow:0 4px 15px #0003;transition:all var(--transition-normal);position:relative;overflow:hidden}.settings-section:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary),#b89fff)}.settings-section:hover{border-color:var(--accent-primary);box-shadow:0 6px 20px #7c5cff4d}.settings-section h2{font-size:var(--font-xl);font-weight:700;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--border-color);background:linear-gradient(135deg,var(--text-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--border-color)}.settings-header h2{margin:0;padding:0;border:none}.settings-info p{margin-bottom:10px;font-size:var(--font-md);display:flex;align-items:center;gap:8px}.settings-info strong{color:var(--accent-primary);font-weight:700}.codes-list{display:flex;flex-direction:column;gap:12px}.code-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(135deg,var(--bg-tertiary) 0%,var(--bg-secondary) 100%);border:2px solid var(--border-color);border-radius:var(--border-radius);font-size:var(--font-sm);transition:all var(--transition-normal);box-shadow:0 2px 8px #0000001a}.code-item:hover{border-color:var(--accent-primary);transform:translate(4px);box-shadow:0 4px 12px #7c5cff4d}.code-item.used{opacity:.6;filter:grayscale(.5)}.code-item code{font-family:Courier New,monospace;font-size:var(--font-md);font-weight:700;cursor:pointer;padding:6px 12px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);transition:all var(--transition-fast);color:var(--accent-primary);letter-spacing:1px}.code-item code:hover{background:var(--accent-glow);border-color:var(--accent-primary);transform:scale(1.05);box-shadow:0 0 15px #7c5cff66}.error-message{color:var(--error);font-size:var(--font-sm);margin-top:12px;padding:12px 16px;background:#f8717126;border:1px solid rgba(248,113,113,.3);border-radius:var(--border-radius);display:flex;align-items:center;gap:8px}.error-message:before{content:"⚠️";font-size:18px}@media (max-width: 768px){.credit-banner{flex-wrap:wrap;padding:12px 16px}.credit-value{font-size:var(--font-xl)}.credit-buttons{width:100%;margin-top:8px}.credit-add-btn,.credit-buy-btn{flex:1;text-align:center;padding:10px 12px;font-size:var(--font-sm)}.stories-grid{grid-template-columns:1fr}.story-card{padding:12px}.story-avatar{width:50px;height:50px}.slider-options{flex-direction:column}.slider-option{width:100%}.settings-header{flex-direction:column;align-items:flex-start;gap:12px}.code-item{flex-wrap:wrap;gap:8px;padding:12px}.code-item code{font-size:var(--font-sm);padding:4px 8px;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.code-item .btn{padding:6px 10px;font-size:var(--font-xs)}.codes-list{gap:8px}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:20px}.stat-card{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-tertiary) 100%);padding:24px;border-radius:var(--border-radius-lg);border:2px solid var(--border-color);text-align:center;transition:all var(--transition-normal);position:relative;overflow:hidden;box-shadow:0 4px 12px #0003}.stat-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(124,92,255,.1) 0%,transparent 70%);opacity:0;transition:opacity var(--transition-normal)}.stat-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 8px 25px #7c5cff66}.stat-card:hover:before{opacity:1}.stat-card-wide{grid-column:span 2;display:flex;align-items:center;justify-content:center;gap:20px;text-align:left}.stat-icon{font-size:3rem;margin-bottom:12px;filter:drop-shadow(0 4px 8px rgba(124,92,255,.3));animation:iconFloat 3s ease-in-out infinite;position:relative;z-index:1}@keyframes iconFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.stat-card-wide .stat-icon{margin-bottom:0;font-size:2.5rem}.stat-value{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px;position:relative;z-index:1}.stat-card-wide .stat-value{font-size:1.5rem;margin-bottom:4px}.stat-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;position:relative;z-index:1}.stat-content{flex:1}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr}.stat-card-wide{grid-column:span 1}}.table-container{overflow-x:auto;margin-top:16px;border-radius:var(--border-radius);border:1px solid var(--border-color)}.users-table{width:100%;border-collapse:collapse;font-size:var(--font-sm)}.users-table thead{background:var(--bg-tertiary);position:sticky;top:0;z-index:10}.users-table th{padding:12px 16px;text-align:left;font-weight:600;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:all var(--transition-fast)}.users-table th:hover{background:var(--bg-hover);color:var(--accent-primary)}.users-table tbody tr{border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.users-table tbody tr:hover{background:var(--bg-hover)}.users-table tbody tr:last-child{border-bottom:none}.users-table td{padding:12px 16px;color:var(--text-primary);white-space:nowrap}.users-table td strong{color:var(--accent-primary)}@media (max-width: 1200px){.users-table{font-size:var(--font-xs)}.users-table th,.users-table td{padding:8px 12px}}.modal-large{max-width:900px;width:90%}.user-details-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);margin-bottom:16px}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:var(--font-sm);color:var(--text-secondary)}.info-value{font-size:1.25rem;font-weight:600;color:var(--accent-primary)}.users-table tbody tr{cursor:default}@media (max-width: 768px){.modal-large{width:95%;max-height:90vh;overflow-y:auto}.user-details-info{grid-template-columns:1fr}}.faq-container{display:flex;flex-direction:column;gap:12px}.faq-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden;transition:all var(--transition-normal)}.faq-item.open{border-color:var(--accent-primary);box-shadow:0 0 0 1px var(--accent-primary)}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:transparent;border:none;color:var(--text-primary);font-size:var(--font-lg);font-weight:600;text-align:left;cursor:pointer;transition:all var(--transition-fast)}.faq-question:hover{background:var(--bg-hover)}.faq-icon{font-size:var(--font-2xl);font-weight:300;color:var(--accent-primary);transition:transform var(--transition-normal);min-width:24px;text-align:center}.faq-item.open .faq-icon{transform:rotate(180deg)}.faq-answer{padding:0 24px 24px;color:var(--text-secondary);font-size:var(--font-md);line-height:1.7;animation:fadeIn var(--transition-normal)}.faq-answer p{margin-bottom:12px}.faq-answer p:last-child{margin-bottom:0}.faq-answer ul,.faq-answer ol{margin-top:8px}.faq-answer li{margin-bottom:8px}.faq-answer a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}.faq-answer a:hover{color:var(--accent-secondary);text-decoration:underline}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.catalog-filters{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:24px;padding:16px;background:var(--bg-card);border-radius:var(--border-radius);border:1px solid var(--border-color)}.filter-group{display:flex;align-items:center;gap:12px}.filter-label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:600}.filter-buttons{display:flex;gap:8px}.filter-btn{padding:8px 16px;font-size:var(--font-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.filter-select{padding:8px 32px 8px 12px;font-size:var(--font-sm);min-width:160px}.catalog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.catalog-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-normal)}.catalog-card:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 12px 40px #7c5cff4d}.catalog-card-avatar{position:relative;width:100%;height:360px;background:var(--bg-tertiary)}.catalog-card-avatar img{width:100%;height:100%;object-fit:cover;object-position:top}.catalog-card-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.catalog-card-gender{position:absolute;top:12px;right:12px;background:#0009;padding:4px 8px;border-radius:var(--border-radius-sm);font-size:var(--font-md)}.catalog-card-info{padding:16px}.catalog-card-name{font-size:var(--font-lg);font-weight:600;margin-bottom:8px}.catalog-card-desc{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.catalog-card-stats{display:flex;gap:16px;font-size:var(--font-sm);color:var(--text-muted)}.catalog-stat{display:flex;align-items:center;gap:4px}.like-btn{background:none;border:none;cursor:pointer;font-size:var(--font-sm);color:var(--text-muted);padding:4px 8px;border-radius:var(--border-radius-sm);transition:all var(--transition-fast)}.like-btn:hover{background:var(--bg-hover)}.like-btn.liked{color:#ff6b6b}.modal-character{max-width:600px}.character-detail{display:flex;gap:20px;margin-bottom:24px}.character-detail-avatar{width:150px;height:150px;border-radius:var(--border-radius);overflow:hidden;flex-shrink:0}.character-detail-avatar img{width:100%;height:100%;object-fit:cover}.character-detail-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.character-detail-meta{display:flex;flex-direction:column;gap:12px}.character-detail-gender{font-size:var(--font-md);color:var(--text-secondary)}.like-btn-large{background:var(--bg-tertiary);border:1px solid var(--border-color);padding:8px 16px;border-radius:var(--border-radius-sm);cursor:pointer;font-size:var(--font-md);color:var(--text-secondary);transition:all var(--transition-fast)}.like-btn-large:hover{border-color:var(--accent-primary)}.like-btn-large.liked{background:#ff6b6b1a;border-color:#ff6b6b;color:#ff6b6b}.character-detail-uses{font-size:var(--font-sm);color:var(--text-muted)}.character-detail-description{background:var(--bg-tertiary);padding:16px;border-radius:var(--border-radius)}.character-detail-description h4{font-size:var(--font-md);margin-bottom:12px;color:var(--text-primary)}.character-detail-description p{font-size:var(--font-md);color:var(--text-secondary);line-height:1.6;white-space:pre-wrap}@media (max-width: 768px){.catalog-filters{flex-direction:column;gap:12px}.filter-group{flex-direction:column;align-items:flex-start;gap:8px}.filter-buttons{flex-wrap:wrap}.catalog-grid{grid-template-columns:1fr}.character-detail{flex-direction:column;align-items:center;text-align:center}.character-detail-meta{align-items:center}}.templates-admin-list{display:flex;flex-direction:column;gap:12px}.template-admin-item{display:flex;gap:16px;padding:16px;background:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border-color);align-items:flex-start}.template-admin-avatar{width:60px;height:60px;border-radius:var(--border-radius-sm);overflow:hidden;flex-shrink:0}.template-admin-avatar img{width:100%;height:100%;object-fit:cover}.template-admin-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.template-admin-info{flex:1;min-width:0}.template-admin-name{font-weight:600;font-size:var(--font-md);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.template-status{font-size:var(--font-xs);padding:2px 8px;border-radius:4px;font-weight:500}.template-status.published{background:#4ade8033;color:var(--success)}.template-status.draft{background:#fbbf2433;color:var(--warning)}.template-admin-meta{font-size:var(--font-sm);color:var(--text-muted);margin-top:4px}.template-admin-desc{font-size:var(--font-sm);color:var(--text-secondary);margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.template-admin-actions{display:flex;gap:8px;flex-shrink:0}.modal-large{max-width:700px}@media (max-width: 768px){.template-admin-item{flex-direction:column}.template-admin-avatar{width:80px;height:80px}.template-admin-actions{width:100%;justify-content:flex-end}}.trial-notice{background:linear-gradient(135deg,#fbbf2426,#fbbf240d);border:1px solid rgba(251,191,36,.3);border-radius:var(--border-radius);padding:12px 16px;margin-bottom:20px;font-size:var(--font-sm);color:var(--warning);line-height:1.5}.trial-lock{margin-left:8px;font-size:var(--font-xs)}.slider-option:disabled{opacity:.4;cursor:not-allowed}.instructions-body{max-height:60vh;overflow-y:auto;font-size:var(--font-sm)}.instruction-item{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border-color)}.instruction-item:last-child{border-bottom:none}.instruction-icon{font-size:24px;flex-shrink:0;width:32px;text-align:center}.instruction-item strong{display:block;color:var(--text-primary);margin-bottom:6px;font-size:var(--font-md)}.instruction-item p{margin:0;color:var(--text-secondary);line-height:1.5}.payment-hero{text-align:center;padding:40px 0}.payment-title{font-size:var(--font-3xl);margin-bottom:12px;background:linear-gradient(135deg,#a78bfa,#f472b6,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.payment-subtitle{font-size:var(--font-lg);color:var(--text-secondary);max-width:500px;margin:0 auto}.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:48px}.package-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--border-radius-lg);padding:32px 24px;text-align:center;position:relative;transition:all var(--transition-normal)}.package-card:hover{border-color:var(--package-color);transform:translateY(-4px);box-shadow:0 12px 40px #0000004d}.package-popular{border-color:var(--accent-primary);background:linear-gradient(135deg,#a78bfa1a,#7c5cff0d)}.package-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;padding:6px 16px;border-radius:20px;font-size:var(--font-sm);font-weight:600;white-space:nowrap}.package-savings{background:#4ade8026;color:var(--success);padding:6px 12px;border-radius:var(--border-radius-sm);font-size:var(--font-xs);font-weight:600;margin-bottom:16px;display:inline-block}.package-coins{margin:16px 0}.package-coins-value{font-size:48px;font-weight:800;background:linear-gradient(135deg,var(--package-color),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;display:block;line-height:1}.package-coins-label{font-size:var(--font-md);color:var(--text-muted);text-transform:uppercase;letter-spacing:2px}.package-price{margin:20px 0 8px}.package-price-value{font-size:var(--font-2xl);font-weight:700;color:var(--text-primary)}.package-price-currency{font-size:var(--font-lg);color:var(--text-secondary);margin-left:4px}.package-per-coin{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:24px}.package-buttons{display:flex;flex-direction:column;gap:10px}.btn-package{padding:14px 20px;font-size:var(--font-md);font-weight:600;border-radius:var(--border-radius);transition:all var(--transition-fast)}.btn-boosty{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border:none}.btn-boosty:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b3566}.btn-hipolink{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.btn-hipolink:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.payment-info-section{margin-bottom:48px}.payment-section-title{font-size:var(--font-xl);margin-bottom:24px;text-align:center}.payment-guides{display:flex;flex-direction:column;gap:12px;max-width:600px;margin:0 auto}.payment-guide{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);overflow:hidden}.payment-guide-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:transparent;border:none;color:var(--text-primary);font-size:var(--font-md);font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.payment-guide-header:hover{background:var(--bg-hover)}.payment-guide-header.open{background:var(--bg-tertiary)}.payment-guide-arrow{color:var(--text-muted);font-size:var(--font-sm)}.payment-guide-content{padding:0 20px 20px;border-top:1px solid var(--border-color);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.payment-guide-content ol{margin:16px 0 0;padding-left:20px}.payment-guide-content li{margin-bottom:12px;line-height:1.5;color:var(--text-secondary)}.payment-guide-content a{color:var(--accent-primary)}.payment-after-section{margin-bottom:48px}.payment-after-card{background:linear-gradient(135deg,#7c5cff26,#a78bfa1a);border:2px solid var(--accent-primary);border-radius:var(--border-radius-lg);padding:40px;text-align:center;max-width:600px;margin:0 auto}.payment-after-icon{font-size:48px;margin-bottom:16px}.payment-after-card h3{font-size:var(--font-xl);margin-bottom:12px}.payment-after-card p{color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.btn-lg{padding:16px 32px;font-size:var(--font-lg)}.payment-community{margin-bottom:48px}.community-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;max-width:600px;margin:0 auto}.community-link{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all var(--transition-fast);text-decoration:none}.community-link:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 8px 24px #7c5cff33}.community-icon{font-size:32px}.community-link strong{display:block;color:var(--text-primary);margin-bottom:4px}.community-link p{margin:0;font-size:var(--font-sm);color:var(--text-muted)}.payment-back{text-align:center;padding-bottom:40px}@media (max-width: 768px){.payment-hero{padding:24px 0}.payment-title{font-size:var(--font-2xl)}.packages-grid{gap:16px}.package-card{padding:24px 16px}.package-coins-value{font-size:36px}.payment-after-card{padding:24px}}.notifications-list{display:flex;flex-direction:column;gap:16px}.notification-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:20px;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:flex-start}.notification-card:hover{border-color:var(--accent-primary)}.notification-unread{background:linear-gradient(135deg,#7c5cff1a,#7c5cff0d);border-color:var(--accent-primary)}.notification-content{flex:1;min-width:0}.notification-image{margin-bottom:16px;border-radius:var(--border-radius);overflow:hidden}.notification-image img{width:100%;max-height:300px;object-fit:cover}.notification-image-preview{width:80px;height:80px;border-radius:var(--border-radius);overflow:hidden;flex-shrink:0;margin-right:16px}.notification-image-preview img{width:100%;height:100%;object-fit:cover}.notification-image-full{margin-bottom:16px;border-radius:var(--border-radius);overflow:hidden}.notification-image-full img{width:100%;max-height:400px;object-fit:contain}.notification-text-preview{color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-full-text{color:var(--text-primary);line-height:1.7;white-space:pre-wrap}.notification-modal-date{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color);font-size:var(--font-sm);color:var(--text-muted)}.notification-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px}.notification-title{font-size:var(--font-lg);font-weight:600;display:flex;align-items:center;gap:8px}.notification-dot{color:var(--accent-primary);font-size:12px}.notification-date{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap}.notification-text{color:var(--text-secondary);line-height:1.6;white-space:pre-wrap;margin-bottom:12px}.notification-link{color:var(--accent-primary);font-weight:600;font-size:var(--font-sm)}.notification-link:hover{text-decoration:underline}.notification-admin-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.notification-bell{position:relative;display:flex;align-items:center;justify-content:center;background:transparent;border:none;font-size:14px;cursor:pointer;transition:transform var(--transition-fast);text-decoration:none;padding:4px}.notification-bell:hover{transform:scale(1.1)}.notification-badge{position:absolute;top:-4px;right:-6px;min-width:14px;height:14px;background:var(--error);color:#fff;font-size:9px;font-weight:700;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}@media (max-width: 768px){.notification-bell{font-size:12px}.notification-badge{min-width:12px;height:12px;font-size:8px;top:-3px;right:-5px}.notification-header{flex-direction:column;gap:4px}.notification-admin-actions{flex-direction:column}.notification-image-preview{width:60px;height:60px}}
