.header{background:transparent!important;border-bottom:none!important;padding:6px 0;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:none;backdrop-filter:none;margin:0;width:100%;position:relative}.header-content{display:flex;align-items:center;gap:16px;position:relative;justify-content:space-between;padding-left:10px;padding-right:24px;margin-left:0;height:60px;overflow:visible}.logo-section{display:flex;align-items:center;gap:12px;margin-left:80px;margin-right:24px}.logo{display:flex;align-items:center;gap:6px;text-decoration:none}.logo-image{height:90px;width:auto;object-fit:contain;display:block}.logo-text{font-size:56px;font-weight:400;font-family:Pinyon Script,cursive,serif;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px;line-height:1;transform:translateY(8px)}.vip-badge{display:flex;align-items:center;gap:6px;background:linear-gradient(135deg,#fbbf24,#f59e0b);padding:6px 12px;border-radius:12px;font-weight:700;font-size:14px;color:#000;box-shadow:0 2px 8px #fbbf244d;animation:vip-glow 2s ease-in-out infinite}.vip-crown{font-size:16px;color:#000}.vip-text{color:#000;font-weight:700;letter-spacing:.5px}.search-form{display:flex;align-items:center;gap:8px;flex:1;max-width:500px;margin-right:auto}.search-input{flex:1;padding:10px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:24px;color:#fff;font-size:14px;outline:none;transition:all .2s ease}.search-input::placeholder{color:#ffffff80}.search-input:focus{background:#8b5cf633;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.search-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;transition:all .2s ease;flex-shrink:0}.search-button:hover{transform:scale(1.05);box-shadow:0 4px 12px #a855f766}.search-button:active{transform:scale(.98)}.sign-in-button{display:flex;align-items:center;gap:8px;padding:10px 20px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:24px;color:#fff;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;position:absolute;right:24px;top:50%;transform:translateY(-50%);z-index:1001}.sign-in-button:hover{transform:translateY(-50%) scale(1.05);box-shadow:0 4px 12px #a855f766}.sign-in-button:active{transform:translateY(-50%) scale(1)}.sign-in-button svg{font-size:16px}.header>:not(.container){position:absolute;right:24px;top:50%;transform:translateY(-50%);z-index:1001}.header-right-actions{display:flex;align-items:center;gap:12px}.upload-character-button{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:8px;color:#fff;text-decoration:none;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-right:40px}.upload-character-button:hover{background:linear-gradient(135deg,#c084fc,#f472b6);transform:scale(1.05);box-shadow:0 4px 12px #a855f766}.upload-icon{font-size:20px;color:#fff}.profile-picture-button{width:44px;height:44px;border-radius:50%;overflow:hidden;cursor:pointer;transition:all .2s ease;border:2px solid rgba(139,92,246,.5);background:#8b5cf61a;display:flex;align-items:center;justify-content:center;text-decoration:none;flex-shrink:0}.profile-picture-button:hover{transform:scale(1.1);border-color:#8b5cf6cc;box-shadow:0 4px 12px #a855f766}.profile-picture-img{width:100%;height:100%;object-fit:cover}.profile-picture-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:18px;text-transform:uppercase}.header-token-balance{display:flex;align-items:center;gap:0px;padding:6px 12px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#fff;text-decoration:none;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.header-token-balance:hover{background:#8b5cf640;border-color:#8b5cf680}.header-token-icon{margin-right:-4px}.header-token-balance:hover{background:#8b5cf61a;transform:scale(1.02)}.header-token-icon{width:64px;height:64px;object-fit:contain;flex-shrink:0}.header-token-icon-fallback{font-size:64px;line-height:1;color:#fbbf24}.header-token-value{font-size:20px;font-weight:700;color:#fff}.hamburger-menu{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:24px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1003;margin:0;transition:all .3s ease}.sidebar-menu:not(.open) .hamburger-menu{margin:0 auto}.hamburger-menu span{width:100%;height:3px;background:linear-gradient(135deg,#a855f7,#ec4899);border-radius:3px;transition:all .3s ease;transform-origin:center}.hamburger-menu:hover span{background:linear-gradient(135deg,#c084fc,#f472b6)}.mobile-sidebar-toggle{display:none;position:fixed;left:0;top:50%;transform:translateY(-50%);width:40px;height:60px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:0 12px 12px 0;color:#fff;font-size:18px;cursor:pointer;z-index:1003;box-shadow:2px 0 8px #0000004d;transition:all .3s ease;align-items:center;justify-content:center;padding:0}.mobile-sidebar-toggle:hover{background:linear-gradient(135deg,#c084fc,#f472b6);box-shadow:2px 0 12px #a855f766;transform:translateY(-50%) translate(4px)}.mobile-sidebar-toggle:active{transform:translateY(-50%) translate(2px)}.mobile-sidebar-toggle svg{transition:transform .3s ease}.mobile-sidebar-toggle.open{transform:translateY(-50%) translate(280px)}.mobile-sidebar-toggle.open svg{transform:rotate(180deg)}.sidebar-menu{position:fixed;top:0;left:0;width:70px;height:100vh;background:linear-gradient(180deg,#1a0a2e,#2d1b4e);box-shadow:4px 0 20px #00000080;transition:width .3s ease,transform .3s ease;z-index:1002;display:flex;flex-direction:column;border-right:1px solid rgba(139,92,246,.3);overflow:hidden}.sidebar-menu.open{width:280px}.menu-header{padding:20px 20px 16px;border-bottom:none;display:flex;justify-content:space-between;align-items:center;min-height:60px}.sidebar-menu:not(.open) .menu-header{justify-content:center;padding:20px 10px 16px}.close-menu{background:transparent;border:none;color:#fff;font-size:32px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;line-height:1;padding:0}.close-menu:hover{background:#8b5cf633;color:#c084fc}.menu-content{padding:24px 20px 20px;display:flex;flex-direction:column;gap:12px;flex:1;overflow-y:auto}.menu-bottom{margin-top:auto;padding-top:20px;border-top:1px solid rgba(139,92,246,.2);display:flex;flex-direction:column;gap:12px}.menu-divider{height:1px;background:#8b5cf633;margin:8px 0}.footer-link-menu{color:var(--text-secondary)!important;font-size:14px;padding:12px 18px}.footer-link-menu:hover{color:var(--accent-primary)!important;background:#8b5cf61a}.sidebar-menu:not(.open) .menu-content{padding:24px 10px 20px}.token-balance-menu{background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:12px;padding:16px;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;white-space:nowrap;text-decoration:none;color:inherit;cursor:pointer;transition:all .2s ease}.token-balance-menu:hover{background:#8b5cf640;border-color:#8b5cf680;transform:translate(4px)}.token-balance-icon{position:relative;display:flex;align-items:center;justify-content:center;padding:14px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:10px;margin-bottom:8px;cursor:pointer;text-decoration:none;color:inherit;transition:all .2s ease}.token-balance-icon:hover{background:#8b5cf640;border-color:#8b5cf680;transform:scale(1.05)}.token-badge{position:absolute;top:-4px;right:-4px;background:#ec4899;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;border:2px solid #1a0a2e}.token-label{color:#c084fc;font-size:14px;font-weight:500}.token-value{color:#fff;font-size:18px;font-weight:700}.menu-item{display:flex;align-items:center;gap:16px;padding:14px 18px;color:#fff;text-decoration:none;border-radius:10px;font-weight:500;font-size:15px;transition:all .2s ease;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);text-align:left;white-space:nowrap;justify-content:flex-start}.sidebar-menu:not(.open) .menu-item{justify-content:center;padding:14px}.menu-item:hover{background:#8b5cf640;border-color:#8b5cf666;transform:translate(4px);color:#c084fc}.menu-icon{font-size:20px;min-width:20px;flex-shrink:0;transition:all .2s ease}.menu-coin-icon{width:28px;height:28px;object-fit:contain}.menu-icon-fallback{font-size:28px;line-height:1}.menu-icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.message-badge{position:absolute;top:-6px;right:-6px;background:#ec4899;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;border:2px solid #1a0a2e;line-height:1.2}.menu-text{opacity:1;transition:opacity .2s ease}.sidebar-menu:not(.open) .menu-text{opacity:0;width:0;overflow:hidden}.menu-item-button{width:100%;background:#ec489926;border:1px solid rgba(236,72,153,.3);color:#f472b6;cursor:pointer;font-family:inherit}.menu-item-button:hover{background:#ec489940;border-color:#ec489980;color:#f9a8d4}.menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:1001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@media (max-width: 640px){.menu-overlay{z-index:1001}.sidebar-menu{z-index:1002}.mobile-sidebar-toggle{z-index:1003}}@media (max-width: 768px){.header-content{padding-left:80px;padding-right:12px;gap:12px}.logo-section{margin-left:0;margin-right:12px}.logo-image{height:60px}.search-form{flex:1;max-width:none;min-width:0}.search-input{font-size:13px;padding:8px 12px}.header-right-actions{gap:8px}.header-token-balance{padding:6px 12px;gap:6px}.header-token-icon{font-size:16px}.header-token-value{font-size:14px}.upload-character-button,.profile-picture-button{width:38px;height:38px}.upload-icon{font-size:18px}}@media (max-width: 640px){.mobile-sidebar-toggle{display:flex}.logo-image{height:50px}.logo-text{font-size:24px}.sidebar-menu{width:280px;transform:translate(-100%)}.sidebar-menu.open{transform:translate(0)}.header-content{padding-left:24px;padding-right:8px;flex-wrap:wrap;gap:8px}.logo-section{margin-left:0}.sidebar-menu .hamburger-menu{display:none}.logo-section{margin-right:8px}.search-form{max-width:100%;order:3;width:100%;margin-top:8px;margin-right:0}.search-input{font-size:14px;padding:8px 12px}.search-button{width:40px;height:40px;font-size:14px}.header-right-actions{gap:6px;margin-right:0}.header-token-balance{padding:6px 10px;gap:4px}.header-token-icon{font-size:14px}.header-token-value{font-size:13px}.upload-character-button{margin-right:8px}}@media (max-width: 480px){.header-content{padding-left:16px;padding-right:6px;gap:6px}.logo-image{height:40px}.search-input{font-size:13px;padding:6px 10px}.search-button,.upload-character-button,.profile-picture-button{width:36px;height:36px}}.site-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:32px 24px;margin-top:auto;width:100%}.footer-content{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px}.footer-links{display:flex;gap:24px;flex-wrap:wrap;justify-content:center}.footer-link{background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;text-decoration:underline;transition:color .2s ease;padding:0}.footer-link:hover{color:var(--accent-primary)}.footer-copyright{text-align:center}.footer-copyright p{color:var(--text-tertiary);font-size:12px;margin:0}.terms-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;overflow-y:auto;animation:fadeIn .3s ease-out}.terms-modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:slideUp .3s ease-out}.terms-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-card);z-index:1}.terms-modal-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.terms-close-btn{background:transparent;border:none;color:var(--text-secondary);font-size:32px;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;line-height:1;padding:0}.terms-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.terms-modal-body{padding:24px;overflow-y:auto;flex:1;color:var(--text-primary);line-height:1.7}.terms-modal-body p{margin:0 0 16px;color:var(--text-secondary)}.terms-modal-body h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:32px 0 16px}.terms-modal-body h3:first-child{margin-top:0}.terms-modal-body h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:20px 0 12px}.terms-modal-body ol,.terms-modal-body ul{margin:0 0 16px;padding-left:24px;color:var(--text-secondary)}.terms-modal-body li{margin:8px 0;color:var(--text-secondary)}.terms-modal-body ul ul,.terms-modal-body ol ul{margin-top:8px;margin-bottom:8px}.terms-summary{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:20px;margin-top:32px}.terms-summary h3{margin-top:0;color:var(--accent-primary)}.terms-summary ul{margin-bottom:16px}.terms-summary p:last-child{margin-bottom:0;font-weight:600;color:var(--text-primary)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.terms-modal-content{max-width:100%;max-height:95vh}.terms-modal-header,.terms-modal-body{padding:16px}.terms-modal-body h3{font-size:18px}}.banner-container{flex:1;margin-top:0;display:flex;justify-content:center;align-items:center;overflow:hidden;background:transparent;padding:8px 8px 8px 0;min-width:200px}.banner-image.banner-clickable{cursor:pointer;transition:opacity .2s ease}.banner-image.banner-clickable:hover{opacity:.9}.banner-image{max-width:100%;max-height:300px;height:auto;width:auto;display:block;object-fit:contain;background:transparent}@media (max-width: 768px){.banner-image{max-width:100%;max-height:200px}}@media (max-width: 480px){.banner-image{max-width:100%;max-height:150px}}.token-store-banner-container{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden;background:transparent;padding:8px 8px 8px 0;min-height:100px;min-width:200px}.token-store-banner-image.token-store-banner-clickable{cursor:pointer;transition:opacity .2s ease}.token-store-banner-image.token-store-banner-clickable:hover{opacity:.9}.token-store-banner-image{max-width:100%;max-height:300px;height:auto;width:auto;display:block;object-fit:contain;background:transparent}@media (max-width: 768px){.token-store-banner-container{padding:8px 0}.token-store-banner-image{max-width:100%;max-height:200px}}@media (max-width: 480px){.token-store-banner-image{max-width:100%;max-height:150px}}.favorite-button{background:#00000080;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);position:absolute;top:12px;right:12px;z-index:10}.favorite-button:hover{background:#000000b3;transform:scale(1.1)}.favorite-button:disabled{opacity:.6;cursor:not-allowed}.favorite-button.favorited{background:#ec4899cc}.favorite-button.favorited:hover{background:#ec4899}.favorite-icon{font-size:18px;color:#fff;transition:all .2s ease}.favorite-icon.filled{color:#fff}.favorite-button:hover .favorite-icon{transform:scale(1.15)}.gallery-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.banners-row{display:flex;width:100%;gap:12px;padding:20px;box-sizing:border-box;max-width:1400px;margin:0 auto}@media (max-width: 768px){.banners-row{flex-direction:column;gap:12px;padding:16px}}.gallery-header{text-align:center;padding:0;margin:0}.gallery-header h1{font-size:48px;font-weight:400;font-family:Pattaya,cursive,serif;margin-bottom:12px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px}.container{max-width:1400px;margin:0 auto;padding:24px}.filter-button-container{display:flex;justify-content:flex-start;margin-bottom:20px}.filter-toggle-btn{display:flex;align-items:center;gap:10px;padding:12px 24px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#c084fc;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.filter-toggle-btn:hover{background:#8b5cf633;border-color:#8b5cf680;transform:translateY(-2px);box-shadow:0 4px 12px #a855f733}.filter-toggle-btn svg{font-size:16px}.gallery-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;padding:24px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;margin-bottom:32px;box-shadow:0 4px 16px #0003}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-size:13px;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.5px}.filter-select,.filter-input{padding:10px 36px 10px 14px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:10px;color:#e9d5ff;font-size:14px;min-width:150px;transition:all .2s ease;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23c084fc' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.filter-select option{background:#1a0a2e;color:#fff;padding:8px}.filter-select::-ms-expand{display:none}.filter-select:hover,.filter-input:hover{border-color:#8b5cf680;background-color:#8b5cf626}.filter-select:focus,.filter-input:focus{outline:none;border-color:#8b5cf699;box-shadow:0 0 0 3px #8b5cf61a;background-color:#8b5cf626}.filter-input{width:100%;min-width:100%}.filter-clear-btn{padding:10px 20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:10px;color:#c084fc;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;grid-column:1 / -1;justify-self:start}.filter-clear-btn:hover{background:#8b5cf633;border-color:#8b5cf680;transform:translateY(-2px)}.active-tag-filter{margin-bottom:24px;padding:16px 20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px;display:flex;align-items:center;gap:12px;font-size:14px;color:#fffc}.active-tag-label{font-weight:700;color:#c084fc}.clear-tag-filter-btn{padding:6px 14px;border-radius:10px;border:1px solid rgba(139,92,246,.4);background:#8b5cf61a;color:#c084fc;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-left:auto}.clear-tag-filter-btn:hover{background:#8b5cf633;border-color:#8b5cf699;color:#e9d5ff}.character-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding-bottom:48px;max-width:100%}@media (min-width: 1025px){.character-grid{grid-template-columns:repeat(3,1fr)!important;gap:32px!important}}@media (min-width: 769px) and (max-width: 1024px){.character-grid{grid-template-columns:repeat(2,1fr)!important}}.character-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;overflow:hidden;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #0000004d;position:relative}.character-card:hover{transform:translateY(-6px);border-color:#8b5cf680;box-shadow:0 12px 40px #a855f74d}.character-image{width:100%;aspect-ratio:2/3;overflow:hidden;background:#8b5cf61a;position:relative}.featured-model-badge{position:absolute;top:12px;left:12px;padding:8px 16px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;z-index:10;box-shadow:0 4px 12px #a855f766}.delete-character-button{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;line-height:1;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.featured-toggle-button{position:absolute;top:12px;left:12px;width:36px;height:36px;border-radius:50%;background:#8b5cf6e6;color:#fff;border:none;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:15;line-height:1;padding:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #0000004d}.character-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.character-card:hover .character-image img{transform:scale(1.05)}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff6;font-size:14px;background:#8b5cf61a}.character-info-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:5}.character-name-overlay{font-size:26px;font-weight:700;color:#fff;margin:0 0 8px;text-shadow:0 2px 8px rgba(0,0,0,.8);line-height:1.2}.character-uploader-overlay{font-size:13px;color:#ffffffe6;margin:0 0 8px;font-weight:400;text-shadow:0 2px 8px rgba(0,0,0,.8)}.uploader-link{color:#c084fc;text-decoration:none;font-weight:600;transition:color .2s ease}.uploader-link:hover{color:#e9d5ff;text-decoration:underline}.character-location-overlay{font-size:14px;color:#ffffffe6;margin:0 0 6px;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8);display:flex;align-items:center;gap:6px}.character-age-overlay{font-size:14px;color:#ffffffe6;margin:0 0 12px;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8)}.character-tag{display:inline-block;padding:5px 12px;background:#8b5cf64d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);white-space:nowrap;border:1px solid rgba(255,255,255,.2);cursor:pointer;transition:all .2s ease}.character-tag-more{display:inline-block;padding:5px 12px;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.2)}.character-tag:hover{transform:translateY(-2px);background:#8b5cf680;border-color:#fff6;box-shadow:0 4px 12px #a855f74d}.character-tag:active{transform:translateY(0)}.character-description-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .3s ease;z-index:6;overflow-y:auto}.character-description-text{color:#fff;font-size:14px;line-height:1.7;text-align:center;margin:0;max-height:100%;overflow-y:auto;padding:8px}.loading,.error{text-align:center;padding:40px;color:#ffffffb3;font-size:16px}.error{color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:20px}.empty-state{text-align:center;padding:60px 20px;color:#ffffffb3}.empty-state h3{font-size:24px;font-weight:600;color:#e9d5ff;margin-bottom:8px}.empty-state p{font-size:16px;color:#ffffff80}@media (max-width: 768px){.container{padding:16px}.gallery-filters{grid-template-columns:1fr;padding:20px}.filter-clear-btn{grid-column:1;width:100%}.character-grid{grid-template-columns:repeat(2,1fr);gap:16px}.character-name-overlay{font-size:20px}.character-location-overlay,.character-age-overlay{font-size:12px}}@media (max-width: 480px){.container{padding:12px}.character-grid{grid-template-columns:1fr;gap:16px}.character-card{border-radius:16px}.character-name-overlay{font-size:22px}.character-tag{font-size:10px;padding:4px 10px}}.browse-page{min-height:100vh;background:transparent}.browse-header{text-align:center;padding:48px 0 32px}.browse-header h1{font-size:48px;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:#fff;font-size:28px;font-weight:500;margin:0;font-family:Comic Sans MS,Comic Sans,cursive,sans-serif;letter-spacing:.5px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.subtitle-highlight{color:#a855f7;font-weight:600}.subtitle-pink{color:#ff91a4;font-weight:600}.subtitle-white{color:#fff}.browse-sections{display:flex;flex-direction:column;gap:48px;padding-bottom:48px}.category-section{width:100%}.category-section-title{font-size:36px;font-weight:700;margin-bottom:24px;color:var(--text-primary);padding-bottom:12px;border-bottom:2px solid var(--border-color)}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px}.character-card{background:var(--bg-card);border:1px solid rgba(244,114,182,.4);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s ease;box-shadow:0 0 0 1px #f472b659}.character-card:hover{transform:translateY(-4px);border-color:#f472b6;box-shadow:0 0 12px #f472b6a6,0 12px 24px #8b5cf640}.character-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease,opacity .5s ease}.character-card:hover .character-image img{transform:scale(1.05);filter:blur(8px)}.character-age-overlay{font-size:20px;color:#fff;margin:0;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8)}.loading,.error,.empty-state{text-align:center;padding:48px 0;color:var(--text-secondary)}.empty-state h3{color:var(--text-primary);margin-bottom:8px}@media (max-width: 768px){.browse-header h1{font-size:36px}.browse-sections{gap:32px}.category-section-title{font-size:28px;margin-bottom:16px}.character-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}}.search-section{margin-bottom:48px}.search-section-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid rgba(139,92,246,.3)}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:32px}.user-card{display:flex;align-items:center;gap:16px;padding:20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;text-decoration:none;color:inherit;transition:all .2s ease}.user-card:hover{border-color:#8b5cf680;background:#8b5cf61a;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf633}.user-avatar,.user-avatar-placeholder{width:64px;height:64px;border-radius:50%;flex-shrink:0;border:2px solid rgba(139,92,246,.3)}.user-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:24px;text-transform:uppercase}.user-info{flex:1;min-width:0}.user-username{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.user-bio{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.4}@media (max-width: 768px){.users-grid{grid-template-columns:1fr}}.google-signin-container{width:100%;margin:20px 0}.google-signin-button{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 24px;background:#fff;border:1px solid #dadce0;border-radius:8px;font-size:16px;font-weight:500;color:#3c4043;cursor:pointer;transition:all .2s ease}.google-signin-button:hover:not(:disabled){background:#f8f9fa;box-shadow:0 2px 4px #0000001a}.google-signin-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{width:20px;height:20px}.google-signin-error{color:#dc3545;font-size:14px;margin-bottom:12px;text-align:center}.auth-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:48px 24px}.auth-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:48px 40px;width:100%;max-width:480px;box-shadow:0 8px 32px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.auth-card h1{font-size:42px;font-weight:700;margin-bottom:12px;text-align:center;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2}.auth-subtitle{text-align:center;color:#ffffffb3;margin-bottom:32px;font-size:16px}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:14px;font-weight:600;color:#e9d5ff;margin-bottom:4px}.form-group input{width:100%;padding:14px 18px;background:#0f172a99;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#fff;font-size:15px;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#a855f799;box-shadow:0 0 0 3px #a855f71a;background:#0f172acc}.form-group input::placeholder{color:#fff6}.checkbox-group{flex-direction:row;align-items:center}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:14px;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-primary)}.auth-submit{width:100%;padding:14px 28px;font-size:16px;font-weight:600;margin-top:8px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #a855f74d}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #a855f766}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;color:#ffffffb3;font-size:14px}.auth-footer a{color:#c084fc;font-weight:600;text-decoration:none;transition:color .2s ease}.auth-footer a:hover{color:#a855f7}.auth-info{text-align:center;color:var(--text-secondary);font-size:14px;line-height:1.6;margin:12px 0}.link-button{background:none;border:none;color:var(--accent-primary);font-weight:500;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.link-button:hover{color:var(--accent-secondary)}.auth-divider{display:flex;align-items:center;text-align:center;margin:24px 0;color:#ffffff80;font-size:14px}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid rgba(139,92,246,.3)}.auth-divider span{padding:0 16px}@media (max-width: 640px){.auth-card{padding:32px 24px}}.token-display{display:inline-flex;align-items:center;gap:6px}.token-coin-icon{width:20px;height:20px;object-fit:contain;flex-shrink:0}.token-coin-fallback{font-size:20px;line-height:1}.token-amount{font-weight:600;color:inherit}.token-label-text{font-size:.9em;opacity:.8;margin-left:2px}.token-display-small .token-coin-icon{width:16px;height:16px}.token-display-small .token-coin-fallback{font-size:16px}.token-display-small .token-amount{font-size:14px}.token-display-medium .token-coin-icon{width:40px;height:40px}.token-display-medium .token-coin-fallback{font-size:40px}.token-display-medium .token-amount{font-size:16px}.token-display-large .token-coin-icon{width:80px;height:80px}.token-display-large .token-coin-fallback{font-size:80px}.token-display-large .token-amount{font-size:24px;font-weight:700}.chat-page{height:100vh;background:transparent;display:flex;flex-direction:column;overflow:hidden;position:fixed;top:0;left:0;right:0;bottom:0}.chat-container{display:flex;flex:1;height:calc(100vh - 60px);overflow:hidden;margin-left:70px;transition:margin-left .3s ease;position:relative}.chat-list-sidebar{width:320px;background:#8b5cf61a;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.chat-list-header{padding:20px;border-bottom:1px solid var(--border-color);background:#8b5cf61a}.chat-list-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text-primary)}.chat-list-content{flex:1;overflow-y:auto;padding:8px 0}.chat-list-loading,.chat-list-empty{padding:40px 20px;text-align:center;color:var(--text-secondary)}.chat-list-empty-subtitle{font-size:14px;margin-top:8px;opacity:.7}.chat-list-item{display:flex;align-items:center;padding:12px 20px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-color);gap:12px}.chat-list-item:hover{background:var(--bg-tertiary)}.chat-list-item.active{background:#a855f71a;border-left:3px solid var(--accent-primary)}.chat-list-avatar{width:50px;height:50px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--bg-tertiary);border:2px solid var(--border-color)}.chat-list-avatar img{width:100%;height:100%;object-fit:cover}.chat-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.chat-list-name-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.chat-list-name{font-weight:600;font-size:15px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-time{font-size:12px;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.chat-list-preview{font-size:13px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.chat-list-preview.empty{font-style:italic;opacity:.6}.chat-sidebar{width:400px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;padding:24px}.character-image-container{width:100%;aspect-ratio:2/3;border-radius:12px;overflow:hidden;background:var(--bg-tertiary);margin-bottom:20px;border:1px solid var(--border-color);min-height:400px}.character-image{width:100%;height:100%;object-fit:cover}.character-info{margin-bottom:24px}.character-info h2{font-size:24px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.character-personality{color:var(--text-secondary);font-size:14px;line-height:1.6}.token-display{margin-top:auto;padding:16px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.token-label{color:var(--text-secondary);font-size:14px}.token-value{color:var(--accent-primary);font-size:18px;font-weight:600}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);min-width:0;height:100%;max-height:100%}.character-info-sidebar{width:350px;background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;padding:24px}.character-image-carousel{margin-bottom:24px}.carousel-container{position:relative;width:100%;aspect-ratio:2/3;border-radius:12px;overflow:hidden;background:var(--bg-tertiary);border:1px solid var(--border-color);margin-bottom:8px}.carousel-image{width:100%;height:100%;object-fit:cover;display:block}.carousel-container.no-image{display:flex;align-items:center;justify-content:center}.no-image-placeholder{color:var(--text-secondary);font-size:16px}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);background:transparent;color:#fff;border:none;width:50px;height:50px;border-radius:50%;font-size:40px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .2s ease;z-index:10;text-shadow:0 2px 8px rgba(0,0,0,.8)}.carousel-arrow:hover{opacity:.8}.carousel-arrow-left{left:12px}.carousel-arrow-right{right:12px}.carousel-indicator{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.carousel-hint{text-align:center;font-size:12px;color:var(--text-secondary);margin-top:8px}.character-info-panel{flex:1;display:flex;flex-direction:column}.character-info-name{font-size:24px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.character-info-details{flex:1;display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.character-info-item{display:flex;flex-direction:column;gap:4px}.character-info-item.personality{flex:1}.info-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;color:var(--text-primary)}.personality-text{line-height:1.6;margin:0}.character-tags-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.character-tag-badge{display:inline-block;padding:6px 12px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:12px;font-size:12px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);white-space:nowrap}.token-display-sidebar{padding:16px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.share-section-sidebar{margin-top:auto}.share-section-sidebar .share-button{width:100%}.chat-main-empty{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.empty-chat-state{text-align:center;color:var(--text-secondary);padding:40px}.empty-chat-state p{font-size:18px;margin:0}.messages-container{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;display:flex;flex-direction:column;gap:16px;min-height:0;max-height:100%}.empty-chat{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);text-align:center}.message{max-width:70%;word-wrap:break-word;margin-left:16px;margin-right:16px}.message-user{align-self:flex-end}.message-assistant{align-self:flex-start}.message-content{padding:12px 16px;border-radius:12px;line-height:1.5}.message-user .message-content{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-bottom-right-radius:4px}.message-assistant .message-content{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color);border-bottom-left-radius:4px}.message-purple-text{color:var(--accent-primary);font-weight:500}.typing-indicator{display:flex;gap:4px;padding:12px 16px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--text-tertiary);animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.chat-error{padding:12px 24px;background:#ef44441a;border-top:1px solid var(--error);color:var(--error);font-size:14px;text-align:center;flex-shrink:0}.chat-input-form{display:flex;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;position:relative;z-index:10;margin-top:auto}.chat-input{flex:1;padding:12px 16px}.send-button{padding:12px 24px;white-space:nowrap}.share-button.gradient-button{background:linear-gradient(135deg,#a855f7,#ec4899);border:none;color:#fff;font-weight:600}.share-button.gradient-button:hover{background:linear-gradient(135deg,#c084fc,#f472b6);transform:scale(1.02);box-shadow:0 4px 12px #a855f766}.share-button.gradient-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.share-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;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.share-modal{background:var(--bg-secondary);border-radius:16px;width:90%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;border:1px solid var(--border-color)}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.share-modal-header h2{margin:0;font-size:24px;font-weight:600;color:var(--text-primary)}.close-modal-button{background:transparent;border:none;color:var(--text-secondary);font-size:32px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;line-height:1}.close-modal-button:hover{background:#8b5cf61a;color:var(--text-primary)}.share-modal-content{padding:24px;overflow-y:auto;flex:1}.share-modal-instructions{color:var(--text-secondary);font-size:14px;margin-bottom:20px;line-height:1.6}.share-messages-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto;margin-bottom:24px}.share-message-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;border:2px solid var(--border-color);background:var(--bg-tertiary);cursor:pointer;transition:all .2s ease}.share-message-item:hover{border-color:#8b5cf680;background:#8b5cf60d}.share-message-item.selected{border-color:#a855f7;background:#a855f71a}.message-checkbox{margin-top:4px;cursor:pointer;width:20px;height:20px;flex-shrink:0}.share-message-content{flex:1;min-width:0}.share-message-role{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:4px;text-transform:capitalize}.share-message-text{font-size:14px;color:var(--text-primary);line-height:1.5;word-wrap:break-word}.share-message-content.user-message .share-message-role{color:#a855f7}.share-message-content.assistant-message .share-message-role{color:#ec4899}.share-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px;border-top:1px solid var(--border-color)}.share-modal-footer .btn{padding:10px 20px;font-size:14px;font-weight:600}.share-modal-footer .gradient-button{background:linear-gradient(135deg,#a855f7,#ec4899);border:none;color:#fff}.share-modal-footer .gradient-button:hover:not(:disabled){background:linear-gradient(135deg,#c084fc,#f472b6);transform:scale(1.02);box-shadow:0 4px 12px #a855f766}.share-modal-footer .gradient-button:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.chat-container{flex-direction:column;margin-left:70px;height:calc(100vh - 60px)}.chat-list-sidebar{width:100%;max-height:200px;border-right:none;border-bottom:1px solid var(--border-color)}.character-info-sidebar{width:100%;max-height:300px;border-left:none;border-top:1px solid var(--border-color);padding:16px}.carousel-container{max-height:250px}.chat-sidebar{width:100%;max-height:200px;flex-direction:row;padding:12px;border-right:none;border-bottom:1px solid var(--border-color);overflow-y:auto}.character-image-container{width:80px;height:120px;margin-bottom:0;margin-right:12px;flex-shrink:0;min-height:auto}.character-info{flex:1;margin-bottom:0}.character-info h2{font-size:18px;margin-bottom:4px}.character-personality{font-size:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.token-display{display:none}.share-section{margin-top:12px}.share-button{width:100%;font-size:13px;padding:8px 16px}.chat-main{height:calc(100% - 200px)}.messages-container{padding:16px}.message{max-width:85%}.chat-input-form{padding:12px 16px;gap:8px}.chat-input{font-size:14px;padding:10px 12px}.send-button{padding:10px 20px;font-size:14px}}@media (max-width: 480px){.chat-container{margin-left:70px}.chat-sidebar{max-height:160px;padding:8px}.character-image-container{width:60px;height:90px;margin-right:8px}.character-info h2{font-size:16px}.character-personality{font-size:11px;-webkit-line-clamp:1}.messages-container{padding:12px;gap:12px}.message{max-width:90%}.message-content{padding:10px 12px;font-size:14px}.chat-input-form{padding:10px 12px}.send-button{padding:10px 16px;font-size:13px}.share-modal{width:95%;max-height:90vh}.share-modal-header{padding:16px}.share-modal-header h2{font-size:20px}.share-modal-content{padding:16px}.share-messages-list{max-height:300px}.share-modal-footer{padding:16px;flex-direction:column}.share-modal-footer .btn{width:100%}}.vip-badge-inline{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,#fbbf24,#f59e0b);padding:2px 8px;border-radius:8px;font-weight:700;margin-left:8px;vertical-align:middle}.vip-badge-small{padding:1px 6px;font-size:11px}.vip-badge-medium{padding:2px 8px;font-size:12px}.vip-crown-inline{font-size:12px;color:#000}.vip-badge-small .vip-crown-inline{font-size:10px}.vip-text-inline{color:#000;font-weight:700;letter-spacing:.3px}.purchase-tokens-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.tokens-container{max-width:1400px;margin:0 auto;padding:24px}.tokens-hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:40px}.balance-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 8px 32px #0000004d}.balance-icon{font-size:48px;width:160px;height:160px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);border-radius:16px;flex-shrink:0}.balance-coin-icon{width:160px;height:160px;object-fit:contain;background:transparent;border-radius:0}.balance-icon-fallback{font-size:160px;line-height:1}.balance-info{display:flex;flex-direction:column;gap:4px}.balance-label{font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.balance-amount{font-size:36px;font-weight:700;color:#e9d5ff;line-height:1;display:inline-flex;align-items:center}.balance-unit{font-size:16px;color:#ffffff80}.vip-status-card{background:linear-gradient(135deg,#fbbf241a,#f59e0b0d);border:1px solid rgba(251,191,36,.3);border-radius:20px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 8px 32px #fbbf2433}.vip-icon{font-size:48px;width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:16px;flex-shrink:0}.vip-icon .vip-badge-inline{margin-left:0;transform:scale(2);animation:vip-glow 2s ease-in-out infinite;box-shadow:0 2px 8px #fbbf244d}@keyframes vip-glow{0%,to{box-shadow:0 2px 8px #fbbf244d}50%{box-shadow:0 4px 16px #fbbf2480}}.vip-info{display:flex;flex-direction:column;gap:6px}.vip-title{font-size:20px;font-weight:700;color:#fbbf24}.vip-details{font-size:14px;color:#ffffffe6}.vip-cancel-notice{font-size:12px;color:#f59e0b;margin-top:4px}.error-banner{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:16px 20px;border-radius:12px;margin-bottom:32px;text-align:center;font-weight:500}.section-title{font-size:32px;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center;-webkit-text-stroke:.5px rgba(255,255,255,.5);text-stroke:.5px rgba(255,255,255,.5);paint-order:stroke fill}.section-description{text-align:center;color:#ffffffb3;font-size:16px;margin-bottom:32px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:16px}.member-badge{padding:10px 20px;background:linear-gradient(135deg,#a855f7,#ec4899);border-radius:12px;color:#fff;-webkit-text-fill-color:#ffffff;font-weight:600;font-size:14px;box-shadow:0 4px 16px #a855f74d;text-shadow:0 0 6px rgba(0,0,0,.6)}.comparison-section{margin-bottom:60px}.comparison-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;max-width:900px;margin:0 auto}.comparison-card-modern{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:32px;text-align:center;position:relative;box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.comparison-card-modern:hover{transform:translateY(-4px);border-color:#8b5cf666;box-shadow:0 12px 40px #a855f733}.comparison-card-vip{border-color:#fbbf2466;background:linear-gradient(135deg,#fbbf241a,#f59e0b0d)}.vip-badge-top{position:absolute;top:-12px;right:24px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;padding:6px 16px;border-radius:20px;font-size:12px;font-weight:700;letter-spacing:.5px;box-shadow:0 4px 12px #fbbf2466}.comparison-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(139,92,246,.2)}.comparison-header h3{font-size:24px;font-weight:600;color:#e9d5ff;margin:0}.vip-header-title{color:#fbbf24!important}.comparison-badge-modern{padding:6px 14px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:#8b5cf633;color:#c084fc;border:1px solid rgba(139,92,246,.3)}.comparison-badge-modern.vip-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#000;border:none}.comparison-price{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.price-amount{font-size:48px;font-weight:700;color:#e9d5ff;line-height:1}.price-amount.vip-price{color:#fbbf24}.price-label{font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.comparison-example-modern{padding-top:20px;border-top:1px solid rgba(139,92,246,.2)}.comparison-example-modern p{font-size:14px;color:#ffffffb3;margin:0 0 8px}.comparison-example-modern .vip-example{color:#fbbf24;font-weight:500}.savings-badge{display:inline-block;background:#fbbf2433;color:#fbbf24;padding:6px 14px;border-radius:12px;font-size:13px;font-weight:600;margin-top:8px}.subscription-section{margin-bottom:60px}.subscription-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:24px;max-width:1000px;margin:0 auto}.subscription-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:32px;text-align:center;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.subscription-card:hover{transform:translateY(-4px);border-color:#8b5cf666;box-shadow:0 12px 40px #a855f733}.subscription-card-header{margin-bottom:24px}.subscription-card-header h3{font-size:24px;font-weight:600;color:#e9d5ff;margin-bottom:12px}.subscription-price{font-size:36px;font-weight:700;color:#a855f7;line-height:1}.price-period{font-size:18px;font-weight:500;color:#fff9}.subscription-tokens{padding:24px;background:#8b5cf61a;border-radius:16px;border:1px solid rgba(139,92,246,.2);margin-bottom:20px;display:flex;flex-direction:column;align-items:center;gap:8px}.subscription-amount{font-size:42px;font-weight:700;color:#e9d5ff;display:block;line-height:1;margin-bottom:8px}.subscription-label{font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.subscription-description{font-size:14px;color:#ffffffb3;margin-bottom:24px;flex:1}.btn-subscribe{width:100%;padding:14px 28px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #a855f74d}.btn-subscribe:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #a855f766}.btn-subscribe:disabled{opacity:.6;cursor:not-allowed}.active-subscription-card{background:linear-gradient(135deg,#10b9811a,#10b9810d);border:2px solid rgba(16,185,129,.4);border-radius:20px;padding:32px;max-width:500px;margin:0 auto;text-align:center;box-shadow:0 8px 32px #0000004d}.subscription-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;justify-content:center}.subscription-icon{font-size:40px;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:16px}.subscription-header h3{font-size:24px;font-weight:600;color:#e9d5ff;margin:0}.subscription-status{font-size:14px;color:#10b981;font-weight:600;margin-top:4px}.subscription-details{margin-bottom:24px}.subscription-details p{color:#ffffffb3;font-size:14px;margin:0}.btn-cancel-subscription{width:100%;padding:12px 24px;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel-subscription:hover{background:#ef444433;border-color:#ef444480}.affiliate-code-section{margin-bottom:40px}.affiliate-code-card{max-width:600px;margin:0 auto;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:24px;box-shadow:0 8px 32px #0000004d}.affiliate-code-header{text-align:center;margin-bottom:20px}.affiliate-code-header h3{font-size:22px;font-weight:600;color:#e9d5ff;margin:0 0 8px}.affiliate-code-description{font-size:14px;color:#ffffffb3;margin:0}.affiliate-code-input-wrapper{position:relative;display:flex;align-items:center;gap:10px}.affiliate-code-input{flex:1;padding:14px 40px 14px 18px;background:#0f172a99;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#fff;font-size:15px;font-weight:500;letter-spacing:.5px;transition:all .2s ease}.affiliate-code-input:focus{outline:none;border-color:#a855f799;box-shadow:0 0 0 3px #a855f71a;background:#0f172acc}.affiliate-code-input::placeholder{color:#fff6}.affiliate-code-clear{position:absolute;right:90px;background:transparent;border:none;color:#fff9;font-size:24px;line-height:1;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;transition:all .2s ease}.affiliate-code-apply{padding:10px 18px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 4px 14px #a855f759;white-space:nowrap;transition:all .2s ease}.affiliate-code-apply:hover{transform:translateY(-1px);box-shadow:0 6px 18px #a855f780}.affiliate-code-status{margin-top:12px;font-size:13px;color:#ffffffb3;text-align:left}.affiliate-code-clear:hover{background:#ef444433;color:#ef4444}.affiliate-code-note{margin-top:16px;padding:12px;background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:8px;color:#10b981;font-size:13px;text-align:center;font-weight:500}.packages-section{margin-bottom:60px}.packages-grid-modern{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.package-card-modern{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:28px;text-align:center;display:flex;flex-direction:column;position:relative;box-shadow:0 8px 32px #0000004d;transition:all .3s ease}.package-card-modern:hover{transform:translateY(-4px);border-color:#8b5cf666;box-shadow:0 12px 40px #a855f733}.package-card-modern.member-discount{border-color:#10b98166;background:linear-gradient(135deg,#10b9810d,#8b5cf60d)}.discount-badge{position:absolute;top:16px;right:16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:700;box-shadow:0 4px 12px #10b98166}.package-card-top{margin-bottom:20px}.package-name{font-size:22px;font-weight:600;color:#e9d5ff;margin-bottom:16px}.package-pricing{display:flex;flex-direction:column;align-items:center;gap:8px}.price-original{font-size:20px;font-weight:600;color:#fff6;text-decoration:line-through}.price-current{font-size:32px;font-weight:700;color:#a855f7;line-height:1}.package-tokens-modern{padding:24px;background:#8b5cf61a;border-radius:16px;border:1px solid rgba(139,92,246,.2);margin-bottom:16px}.tokens-number{font-size:40px;font-weight:700;color:#e9d5ff;display:block;line-height:1;margin-bottom:8px}.tokens-text{font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:.5px}.member-savings{background:#10b98126;color:#10b981;padding:8px 16px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:16px;display:inline-block}.package-value-modern{font-size:13px;color:#ffffff80;margin-bottom:24px}.btn-purchase{width:100%;padding:14px 28px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #a855f74d;margin-top:auto}.btn-purchase:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 24px #a855f766}.btn-purchase:disabled{opacity:.6;cursor:not-allowed}.payment-header{text-align:center;padding:32px 0;margin-bottom:32px}.payment-header h1{font-size:42px;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.balance-display{display:flex;align-items:center;justify-content:center;gap:8px;color:#ffffffb3;font-size:16px}.balance-display strong{color:#c084fc;font-size:20px}.stripe-payment-form{max-width:600px;margin:0 auto;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:32px;box-shadow:0 8px 32px #0000004d}.payment-form-header{text-align:center;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.2)}.payment-form-header h3{font-size:24px;font-weight:600;margin-bottom:12px;color:#e9d5ff}.payment-form-header p{color:#ffffffb3;font-size:16px;margin:8px 0}.payment-amount{font-size:32px;font-weight:700;color:#a855f7;margin-top:12px!important}.payment-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:12px;margin:16px 0;font-size:14px}.payment-form-actions{display:flex;gap:12px;margin-top:24px;justify-content:flex-end}.payment-form-actions .btn{padding:12px 24px;font-size:16px;font-weight:600;border-radius:12px;border:none;cursor:pointer;transition:all .2s ease}.payment-form-actions .btn-secondary{background:#8b5cf61a;color:#c084fc;border:1px solid rgba(139,92,246,.3)}.payment-form-actions .btn-secondary:hover{background:#8b5cf633}.payment-form-actions .btn-primary{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff}.payment-form-actions .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 16px #a855f766}.payment-form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.loading-state{text-align:center;padding:40px;color:#ffffffb3;font-size:16px}@media (max-width: 768px){.tokens-container{padding:16px}.tokens-hero{grid-template-columns:1fr}.section-title{font-size:28px}.comparison-cards,.subscription-grid,.packages-grid-modern{grid-template-columns:1fr}.payment-header h1{font-size:32px}.stripe-payment-form{padding:24px}.payment-form-actions{flex-direction:column}.payment-form-actions .btn{width:100%}}.admin-template-upload-page{min-height:100vh;background:transparent}.admin-template-upload-container{display:flex;justify-content:center;padding:48px 24px}.admin-template-upload-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;width:100%;max-width:700px}.admin-template-upload-card h1{font-size:32px;font-weight:700;margin-bottom:8px;text-align:center;color:var(--text-primary)}.subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px}.admin-template-upload-form{display:flex;flex-direction:column;gap:24px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input[type=file]{padding:8px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer}.form-group input[type=file]::file-selector-button{padding:8px 16px;margin-right:12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-weight:500}.form-group input[type=file]::file-selector-button:hover{background:var(--bg-secondary)}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit}.image-previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-top:12px}.image-preview-item{position:relative;border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:var(--bg-tertiary);aspect-ratio:2/3}.image-preview{width:100%;height:100%}.image-preview img{width:100%;height:100%;object-fit:cover;display:block}.remove-image-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;cursor:pointer;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:1}.remove-image-btn:hover{background:#ef4444}.images-count{margin-top:8px;font-size:14px;color:var(--text-secondary);font-weight:500}.form-hint{font-size:12px;color:var(--text-tertiary)}.error-message{background:#ef44441a;border:1px solid var(--error);color:var(--error);padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px}.success-message{background:#22c55e1a;border:1px solid rgb(34,197,94);color:#22c55e;padding:12px 16px;border-radius:8px;font-size:14px;margin-bottom:20px}.submit-button{width:100%;padding:14px;font-size:16px;margin-top:8px}@media (max-width: 640px){.admin-template-upload-card{padding:32px 24px}.image-preview{max-width:100%}}.edit-character-page{min-height:100vh;background:transparent}.edit-character-container{max-width:800px;margin:0 auto;padding:24px}.edit-character-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:32px;box-shadow:var(--shadow-lg)}.edit-character-card h1{font-size:32px;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.edit-character-form{display:flex;flex-direction:column;gap:24px}.form-group textarea{width:100%;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;min-height:150px}.form-group textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf61a}.form-group input[type=file]{padding:8px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer}.form-hint{color:var(--text-tertiary);font-size:12px}.existing-images-grid,.image-previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-top:12px}.existing-image-item,.image-preview-item{position:relative;background:var(--bg-tertiary);border-radius:8px;overflow:hidden}.image-preview{width:100%;aspect-ratio:2/3;overflow:hidden;background:var(--bg-secondary)}.remove-image-btn{position:absolute;bottom:8px;left:50%;transform:translate(-50%);padding:6px 12px;background:#ef4444e6;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.remove-image-btn:hover{background:#dc2626;transform:translate(-50%) translateY(-2px)}.images-count{color:var(--text-secondary);font-size:14px;margin-top:8px}.no-images{color:var(--text-tertiary);font-style:italic;padding:16px;text-align:center;background:var(--bg-tertiary);border-radius:8px}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:16px}.success-message{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981;padding:12px 16px;border-radius:8px;margin-bottom:16px}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.btn{padding:12px 24px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;border:none}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.loading{text-align:center;padding:48px;color:var(--text-secondary)}@media (max-width: 768px){.edit-character-container{padding:16px}.edit-character-card{padding:24px}.edit-character-card h1{font-size:24px}.existing-images-grid,.image-previews-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.form-actions{flex-direction:column}.btn{width:100%}}.report-button{padding:8px 16px;border:1px solid #ffc107;background-color:transparent;color:#ffc107;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.report-button:hover{background-color:#ffc107;color:#000}.report-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.report-modal{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.report-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.report-modal-header h2{margin:0;font-size:20px;color:#333}.report-modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:#666;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.report-modal-close:hover{background-color:#f0f0f0}.report-modal-form{padding:20px}.report-modal-section{margin-bottom:20px}.report-modal-section label{display:block;margin-bottom:8px;font-weight:500;color:#333}.report-modal-section select,.report-modal-section textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px;font-family:inherit;resize:vertical}.report-modal-section select:focus,.report-modal-section textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.report-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.report-modal-actions button{padding:10px 20px;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s}.report-modal-actions button[type=button]{background:#f0f0f0;border:1px solid #ddd;color:#333}.report-modal-actions button[type=button]:hover:not(:disabled){background:#e0e0e0}.report-modal-actions button[type=submit]{background:#dc3545;border:1px solid #dc3545;color:#fff}.report-modal-actions button[type=submit]:hover:not(:disabled){background:#c82333;border-color:#bd2130}.report-modal-actions button:disabled{opacity:.6;cursor:not-allowed}.character-detail-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.character-detail-container{max-width:1400px;margin:0 auto;padding:24px}.back-button{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff!important;border:none;padding:12px 24px;border-radius:12px;cursor:pointer;font-size:15px;font-weight:600;transition:all .2s ease;margin-bottom:24px;display:inline-flex;align-items:center;gap:8px}.back-button:hover{transform:translate(-4px);box-shadow:0 6px 24px #a855f766}.character-hero-section{display:grid;grid-template-columns:400px 1fr;gap:32px;margin-bottom:40px}.character-image-column{display:flex;flex-direction:column;gap:16px}.character-image-card{position:relative;border-radius:20px;overflow:hidden;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);box-shadow:0 8px 32px #0000004d}.character-main-image{width:100%;aspect-ratio:2/3;overflow:hidden;cursor:pointer;transition:transform .3s ease;position:relative}.character-main-image:hover{transform:scale(1.02)}.character-main-image img{width:100%;height:100%;object-fit:cover}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff6;font-size:16px;background:#8b5cf61a}.character-header-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:32px;display:flex;flex-direction:column;gap:24px;box-shadow:0 8px 32px #0000004d}.character-title-section{display:flex;flex-direction:column;gap:16px}.character-online-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:linear-gradient(135deg,#10b981,#059669);border:1px solid rgba(16,185,129,.3);border-radius:12px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;width:fit-content;box-shadow:0 0 10px #10b98199,0 0 20px #10b98166,0 0 30px #10b98133;position:relative;animation:glow-pulse 2s ease-in-out infinite}.character-online-badge:before{content:"";width:8px;height:8px;background:#fff;border-radius:50%;display:inline-block;animation:pulse-online 2s ease-in-out infinite}@keyframes glow-pulse{0%,to{box-shadow:0 0 10px #10b98199,0 0 20px #10b98166,0 0 30px #10b98133}50%{box-shadow:0 0 15px #10b981cc,0 0 30px #10b98199,0 0 45px #10b98166}}.character-title-section h1{font-size:42px;font-weight:700;margin:0;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.2;-webkit-text-stroke:1px rgba(255,255,255,.5);text-stroke:1px rgba(255,255,255,.5);paint-order:stroke fill}.character-meta-row{display:flex;gap:12px;flex-wrap:wrap}.meta-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#e9d5ff;font-size:14px;font-weight:500}.meta-icon{font-size:16px}.location-flag{display:inline-block;vertical-align:middle;flex-shrink:0}.character-tags-row{display:flex;gap:8px;flex-wrap:wrap}.tag-button{display:inline-block;padding:5px 12px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);white-space:nowrap;border:none;cursor:pointer;transition:all .2s ease}.tag-button:hover{background:linear-gradient(135deg,#b76bff,#f472b6);transform:translateY(-2px);box-shadow:0 4px 12px #a855f74d}.character-actions-bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.character-age-line{margin-top:12px;font-size:24px;color:#fff}.character-age-label{font-weight:600;margin-right:6px}.character-age-value{font-weight:500}.start-chat-button-primary{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border:none;padding:14px 28px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;box-shadow:0 4px 16px #a855f74d}.start-chat-button-primary:hover{transform:translateY(-2px);box-shadow:0 6px 24px #a855f766}.start-chat-button-primary:active{transform:translateY(0)}.action-buttons-group{display:flex;gap:8px;align-items:center}.detail-favorite-button{position:relative;top:auto;right:auto}.action-button-secondary{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:#c084fc;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:18px}.action-button-secondary:hover{background:#8b5cf633;border-color:#8b5cf680;transform:translateY(-2px)}.action-button-secondary.featured-active{background:#fbbf2433;border-color:#fbbf2480;color:#fbbf24}.action-button-secondary.featured-active:hover{background:#fbbf244d;border-color:#fbbf24b3}.uploader-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;text-decoration:none;transition:all .2s ease}.uploader-card:hover{background:#8b5cf61a;border-color:#8b5cf666;transform:translate(4px)}.uploader-avatar,.uploader-avatar-placeholder{width:48px;height:48px;border-radius:50%;flex-shrink:0;border:2px solid rgba(139,92,246,.5)}.uploader-avatar{object-fit:cover}.uploader-avatar-placeholder{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:20px}.uploader-info{display:flex;flex-direction:column;gap:2px}.uploader-label{font-size:12px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.uploader-name{font-size:15px;color:#c084fc;font-weight:600}.uploader-under-image{margin-top:8px}.character-bio-section{margin-top:20px;padding-top:0}.character-bio-title{font-size:22px;font-weight:600;margin:0 0 8px;color:#e9d5ff}.character-bio-text{margin:0;font-size:18px;line-height:1.7;color:#ffffffd9}.character-tags-below-bio{margin-top:16px}.character-content-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px;margin-bottom:40px}.info-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:24px;box-shadow:0 4px 16px #0003}.info-card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.2)}.info-icon{font-size:24px}.info-card-header h2{font-size:20px;font-weight:600;margin:0;color:#e9d5ff}.info-content{color:#fffc;line-height:1.7;font-size:15px;margin:0}.details-list{display:flex;flex-direction:column;gap:12px}.detail-item{display:flex;gap:12px;padding:12px;background:#8b5cf60d;border-radius:10px;border:1px solid rgba(139,92,246,.1)}.detail-label{font-weight:600;color:#c084fc;min-width:60px;font-size:14px}.detail-value{color:#fffc;font-size:14px;flex:1}.character-gallery-section{margin-top:40px}.gallery-title{font-size:28px;font-weight:700;margin-bottom:24px;color:#e9d5ff;background:linear-gradient(135deg,#6366f1,#ec4899,#facc15);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.images-grid-modern{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.gallery-image-card{position:relative;aspect-ratio:2/3;border-radius:16px;overflow:hidden;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0003}.gallery-image-card:hover{transform:translateY(-4px);border-color:#8b5cf680;box-shadow:0 8px 24px #a855f74d}.gallery-image-card img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-image-card:hover img{transform:scale(1.05)}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.gallery-image-card:hover .image-overlay{opacity:1}.view-icon{font-size:32px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.image-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center}.image-modal-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 60px #00000080}.image-modal-close{position:absolute;top:-50px;right:0;background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);width:44px;height:44px;border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.image-modal-close:hover{background:#fff3;transform:scale(1.1)}@media (max-width: 1024px){.character-hero-section{grid-template-columns:350px 1fr;gap:24px}.character-content-grid{grid-template-columns:1fr}}@media (max-width: 768px){.character-detail-container{padding:16px}.character-hero-section{grid-template-columns:1fr;gap:24px}.character-image-card{max-width:400px;margin:0 auto}.character-header-card{padding:24px}.character-title-section h1{font-size:32px}.character-actions-bar{flex-direction:column;align-items:stretch}.start-chat-button-primary{width:100%;justify-content:center}.action-buttons-group{justify-content:center}.character-content-grid{grid-template-columns:1fr}.images-grid-modern{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.gallery-title{font-size:24px}}@media (max-width: 480px){.character-detail-container{padding:12px}.character-header-card{padding:20px}.character-title-section h1{font-size:28px}.meta-badge{font-size:12px;padding:6px 12px}.info-card{padding:20px}.info-card-header h2{font-size:18px}.images-grid-modern{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.image-modal-close{top:-40px;right:-10px;width:36px;height:36px;font-size:24px}}.follow-button{padding:10px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:8px;color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.follow-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.follow-button.following{background:#8b5cf633;border:1px solid rgba(139,92,246,.5);color:var(--accent-primary)}.follow-button.following:hover:not(:disabled){background:#8b5cf64d;border-color:#8b5cf6b3}.follow-button:disabled{opacity:.6;cursor:not-allowed}.block-button{padding:8px 16px;border:1px solid #dc3545;background-color:transparent;color:#dc3545;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.block-button:hover:not(:disabled){background-color:#dc3545;color:#fff}.block-button.blocked{border-color:#6c757d;color:#6c757d}.block-button.blocked:hover:not(:disabled){background-color:#6c757d;color:#fff}.block-button:disabled{opacity:.6;cursor:not-allowed}.block-status-message{padding:8px 16px;color:#6c757d;font-size:14px;font-style:italic}.profile-home-tab{padding:24px 0}.followers-section,.following-section{margin-bottom:40px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.see-all-link{color:var(--accent-primary);text-decoration:none;font-weight:500;font-size:14px;transition:all .2s ease}.see-all-link:hover{color:var(--accent-secondary);text-decoration:underline}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}.user-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;text-decoration:none;transition:all .2s ease}.user-card:hover{background:#8b5cf61a;border-color:#8b5cf666;transform:translateY(-2px)}.user-avatar,.user-avatar-placeholder{width:80px;height:80px;border-radius:50%;border:2px solid rgba(139,92,246,.3)}.user-avatar{object-fit:cover}.user-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:32px;text-transform:uppercase}.user-username{color:var(--text-primary);font-size:14px;font-weight:500;text-align:center;word-break:break-word}@media (max-width: 768px){.users-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.user-avatar,.user-avatar-placeholder{width:60px;height:60px;font-size:24px}}.profile-gallery-tab{padding:24px 0}.gallery-section{margin-bottom:32px}.gallery-section-title{font-size:22px;font-weight:600;margin-bottom:16px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.gallery-character-card{cursor:pointer;transition:all .2s ease}.gallery-character-card:hover{transform:translateY(-4px)}.gallery-character-image{position:relative;width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;border:2px solid rgba(139,92,246,.3)}.gallery-character-image img{width:100%;height:100%;object-fit:cover}.gallery-character-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);padding:16px;color:#fff}.gallery-character-name{margin:0 0 4px;font-size:18px;font-weight:600}.gallery-character-location,.gallery-character-age{margin:2px 0;font-size:12px;opacity:.9}.profile-shared-chats-section{margin-top:24px}.profile-shared-chats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.profile-shared-chat-card{background:linear-gradient(135deg,#12061f,#1f0b3a,#3b0764);border-radius:16px;padding:16px 16px 14px;border:1px solid rgba(139,92,246,.4);box-shadow:0 10px 32px #0f172acc;position:relative}.profile-shared-chat-header{display:flex;align-items:center;gap:12px;margin-bottom:10px}.profile-shared-chat-character-image{width:56px;height:56px;border-radius:12px;object-fit:cover;flex-shrink:0}.profile-shared-chat-meta{flex:1}.profile-shared-chat-title{margin:0 0 4px;font-size:16px;font-weight:600;color:#f9fafb}.profile-shared-chat-date{margin:0;font-size:12px;color:#9ca3af}.profile-shared-chat-delete{width:26px;height:26px;border-radius:999px;border:none;background:#ef4444f2;color:#fff;font-size:16px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0009;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.profile-shared-chat-delete:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 16px #000000b3}.profile-shared-chat-delete:active{transform:translateY(0);box-shadow:0 3px 10px #0009}.profile-shared-chat-description{margin:0 0 8px;font-size:13px;color:#e5e7eb}.profile-shared-chat-preview{background:linear-gradient(135deg,#12061f,#1f0b3a,#3b0764);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}.profile-shared-chat-message{font-size:13px;line-height:1.5;color:#e5e7eb}@media (max-width: 768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}}.profile-showcase-tab{padding:24px 0}.showcased-chats-list{display:flex;flex-direction:column;gap:20px}.showcased-chat-messages{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:300px;overflow-y:auto}.showcased-message{padding:8px 12px;border-radius:6px;font-size:13px;line-height:1.4}.message-role{font-weight:600;margin-right:6px;color:var(--accent-primary)}.more-messages{text-align:center;color:var(--text-secondary);font-size:12px;font-style:italic;margin-top:8px}.showcased-chat-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(139,92,246,.2)}.view-full-chat-link{color:var(--accent-primary);text-decoration:none;font-weight:500;font-size:14px;transition:all .2s ease}.view-full-chat-link:hover{color:var(--accent-secondary);text-decoration:underline}.profile-favorites-tab{padding:24px 0}.favorites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.favorite-character-card{cursor:pointer;transition:all .2s ease}.favorite-character-card:hover{transform:translateY(-4px)}.favorite-character-image{position:relative;width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;border:2px solid rgba(139,92,246,.3)}.favorite-character-image img{width:100%;height:100%;object-fit:cover}.favorite-character-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.9),transparent);padding:16px;color:#fff}.favorite-character-name{margin:0 0 4px;font-size:18px;font-weight:600}.favorite-character-location,.favorite-character-age{margin:2px 0;font-size:12px;opacity:.9;display:flex;align-items:center;gap:4px}.favorite-character-description{position:absolute;top:0;left:0;right:0;background:linear-gradient(to bottom,rgba(0,0,0,.7),transparent);padding:12px;color:#fff;font-size:11px;line-height:1.3;max-height:60px;overflow:hidden}.favorite-character-description p{margin:0}@media (max-width: 768px){.favorites-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}}.profile-page{min-height:100vh;background:transparent}.profile-container{max-width:800px;margin:0 auto;padding:40px 24px}.profile-header{display:flex;align-items:flex-start;gap:32px;margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid rgba(139,92,246,.3)}.profile-picture-container{flex-shrink:0}.profile-picture{width:150px;height:150px;border-radius:50%;object-fit:cover;border:3px solid rgba(139,92,246,.5)}.profile-picture-placeholder{width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#ec4899);display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:700;color:#fff;border:3px solid rgba(139,92,246,.5)}.profile-info{flex:1;display:flex;flex-direction:column;gap:16px}.profile-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.profile-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-stats{display:flex;gap:24px;margin-top:12px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:20px;font-weight:700;color:var(--accent-primary)}.stat-label{font-size:14px;color:var(--text-secondary)}.showcased-chats-button{display:inline-block;margin-top:16px;padding:10px 20px;background:#8b5cf633;border:1px solid rgba(139,92,246,.5);border-radius:8px;color:var(--accent-primary);font-weight:600;font-size:14px;text-decoration:none;transition:all .2s ease}.showcased-chats-button:hover{background:#8b5cf64d;border-color:#8b5cf6b3;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf633}.send-message-button{padding:10px 20px;background:#8b5cf633;border:1px solid rgba(139,92,246,.5);border-radius:8px;color:var(--accent-primary);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.send-message-button:hover{background:#8b5cf64d;border-color:#8b5cf6b3;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf633}.profile-username{font-size:36px;font-weight:700;color:var(--text-primary);margin:0}.edit-profile-button{display:inline-block;padding:10px 20px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s ease;align-self:flex-start}.edit-profile-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.profile-bio{margin-bottom:32px;padding:20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px}.profile-bio p{color:var(--text-primary);font-size:16px;line-height:1.6;margin:0}.profile-sections{display:flex;flex-direction:column;gap:24px}.profile-section{padding:24px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px}.profile-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.profile-joined{color:var(--text-secondary);font-size:14px;margin:0}.profile-tabs{display:flex;gap:8px;margin:32px 0 0;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.3)}.profile-tab{padding:12px 24px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;bottom:-1px}.profile-tab:hover{color:var(--text-primary)}.profile-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.profile-tab-content{padding:24px 0}.back-link{display:inline-block;margin-top:16px;color:var(--accent-primary);text-decoration:none}.back-link:hover{text-decoration:underline}.showcased-chats-list{display:flex;flex-direction:column;gap:20px;margin-top:16px}.showcased-chat-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:20px;transition:all .2s ease}.showcased-chat-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.2)}.showcased-chat-character-image{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid rgba(139,92,246,.3)}.showcased-chat-info h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.showcased-chat-messages{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:400px;overflow-y:auto}.showcased-message{padding:10px 14px;border-radius:8px;font-size:14px;line-height:1.5}@media (max-width: 768px){.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-info{align-items:center}.edit-profile-button{align-self:center}.profile-username{font-size:28px}.showcased-message{max-width:90%}}.profile-settings-page{min-height:100vh;background:transparent}.settings-container{max-width:700px;margin:0 auto;padding:40px 24px}.settings-container h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 32px}.profile-form{display:flex;flex-direction:column;gap:32px}.form-section{padding:24px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px}.form-section h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.section-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 16px}.manage-showcases-link{display:inline-block;padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s ease}.manage-showcases-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.profile-picture-upload{display:flex;flex-direction:column;align-items:flex-start;gap:16px}.profile-picture-preview{width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid rgba(139,92,246,.5)}.preview-image{width:100%;height:100%;object-fit:cover}.preview-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#a855f7,#ec4899);display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#fff}.upload-button{padding:10px 20px;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);border-radius:8px;color:var(--text-primary);cursor:pointer;font-weight:500;transition:all .2s ease}.upload-button:hover{background:#8b5cf64d;border-color:#8b5cf699}.file-name{color:var(--text-secondary);font-size:14px;margin:0}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:8px;color:var(--text-primary);font-weight:500}.form-group input,.form-group textarea{width:100%;padding:12px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-size:16px;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;background:#8b5cf626;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.form-group textarea{resize:vertical;min-height:120px}.form-hint{margin:8px 0 0;color:var(--text-secondary);font-size:14px}.error-message{padding:12px 16px;background:#ec489926;border:1px solid rgba(236,72,153,.3);border-radius:8px;color:#f472b6;font-size:14px}.error{padding:24px;text-align:center;background:#ec48991a;border:1px solid rgba(236,72,153,.3);border-radius:12px;color:#f472b6}.error p{margin:0 0 16px;font-size:16px;font-weight:500}.loading{padding:24px;text-align:center;color:var(--text-secondary)}.loading p{margin:0;font-size:16px}.form-actions{display:flex;gap:16px;justify-content:flex-end}.save-button{padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:8px;color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s ease}.cancel-button{padding:12px 24px;background:transparent;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-weight:500;font-size:16px;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background:#8b5cf61a;border-color:#8b5cf680}.privacy-toggles{display:flex;flex-direction:column;gap:20px}.privacy-toggle-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:8px}.toggle-info{flex:1;margin-right:16px}.toggle-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:4px;cursor:pointer}.toggle-description{font-size:14px;color:var(--text-secondary);margin:0}.switch{position:relative;display:inline-block;width:50px;height:26px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#8b5cf64d;transition:.3s;border-radius:26px}.slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background:linear-gradient(135deg,#a855f7,#ec4899)}input:checked+.slider:before{transform:translate(24px)}@media (max-width: 768px){.form-actions{flex-direction:column}.save-button,.cancel-button{width:100%}.privacy-toggle-item{flex-direction:column;align-items:flex-start;gap:12px}.toggle-info{margin-right:0}.switch{align-self:flex-end}}.tag-selector{display:flex;flex-direction:column;gap:16px}.tag-selector-loading,.tag-selector-error{padding:12px;border-radius:8px;background:#8b5cf61a;color:var(--text-primary);text-align:center}.tag-selector-error{background:#ec48991a;color:#f472b6}.tag-selector-selected label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary)}.selected-tags-list{display:flex;flex-wrap:wrap;gap:8px;min-height:40px;padding:12px;border:1px solid rgba(139,92,246,.3);border-radius:8px;background:#8b5cf60d}.no-tags-hint{color:var(--text-secondary);font-style:italic}.selected-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:16px;font-size:14px;font-weight:500}.remove-tag-btn{background:#ffffff4d;border:none;color:#fff;width:18px;height:18px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;padding:0;transition:all .2s ease}.remove-tag-btn:hover{background:#ffffff80;transform:scale(1.1)}.tag-selector-controls{display:flex;gap:12px}.tag-search-input{flex:1;padding:10px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;transition:all .2s ease}.tag-search-input:focus{background:#8b5cf633;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.tag-category-select{padding:10px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-size:14px;outline:none;cursor:pointer;transition:all .2s ease}.tag-category-select:focus{background:#8b5cf633;border-color:#8b5cf680}.tag-selector-options{display:flex;flex-wrap:wrap;gap:8px;max-height:300px;overflow-y:auto;padding:12px;border:1px solid rgba(139,92,246,.3);border-radius:8px;background:#8b5cf60d}.tag-option{padding:8px 16px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);border-radius:16px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.tag-option:hover:not(.disabled){background:#8b5cf640;border-color:#8b5cf680;transform:translateY(-1px)}.tag-option.selected{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-color:transparent}.tag-option.disabled{opacity:.5;cursor:not-allowed}.tag-limit-warning{padding:8px 12px;background:#ec489926;border:1px solid rgba(236,72,153,.3);border-radius:8px;color:#f472b6;font-size:13px;text-align:center}.upload-character-page{min-height:100vh;background:transparent}.upload-character-container{max-width:800px;margin:0 auto;padding:40px 24px}.upload-character-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:32px}.upload-character-card h1{font-size:32px;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:var(--text-secondary);font-size:16px;margin-bottom:24px}.upload-character-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:var(--text-primary);font-size:14px}.form-group input,.form-group textarea,.form-group select{padding:12px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-size:16px;font-family:inherit;transition:all .2s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;background:#8b5cf626;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.form-group textarea{resize:vertical;min-height:100px}.form-hint{color:var(--text-secondary);font-size:12px;margin-top:4px}.images-count{color:var(--accent-primary);font-size:14px;font-weight:500;margin-top:8px}.image-previews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;margin-top:16px}.image-preview-item{position:relative}.image-preview{width:100%;aspect-ratio:2/3;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);border:1px solid rgba(139,92,246,.3)}.image-preview img{width:100%;height:100%;object-fit:cover}.remove-image-btn{position:absolute;top:-8px;right:-8px;width:28px;height:28px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;padding:0}.remove-image-btn:hover{background:#dc2626;transform:scale(1.1)}.error-message{padding:12px 16px;background:#ec489926;border:1px solid rgba(236,72,153,.3);border-radius:8px;color:#f472b6;font-size:14px;margin-bottom:20px}.success-message{padding:12px 16px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:8px;color:#4ade80;font-size:14px;margin-bottom:20px}.submit-button{padding:14px 28px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:8px;color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s ease;margin-top:8px}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.submit-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.upload-character-container{padding:24px 16px}.upload-character-card{padding:24px}.upload-character-card h1{font-size:24px}}.my-uploads-page{min-height:100vh;background:transparent}.my-uploads-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid rgba(139,92,246,.3)}.my-uploads-header h1{font-size:36px;font-weight:700;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.upload-new-button{padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:8px;color:#fff;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s ease}.upload-new-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.uploads-section{margin-bottom:48px}.uploads-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.character-status-overlay{position:absolute;top:12px;left:12px;z-index:10}.status-badge-container{display:flex;flex-direction:column;gap:8px}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.status-pending{background:#fbbf24cc;color:#78350f}.status-approved{background:#22c55ecc;color:#14532d}.status-rejected{background:#ef4444cc;color:#7f1d1d}.rejection-reason{background:#000000b3;color:#fff;padding:8px 12px;border-radius:8px;font-size:12px;max-width:200px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.rejection-reason strong{display:block;margin-bottom:4px}.delete-upload-button{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:999px;border:none;background:#ef4444e6;color:#fff;font-size:18px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #0009;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;z-index:12}.delete-upload-button:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 16px #000000b3}.delete-upload-button:active{transform:translateY(0);box-shadow:0 3px 10px #0009}@media (max-width: 768px){.my-uploads-header{flex-direction:column;align-items:flex-start;gap:16px}.my-uploads-header h1{font-size:28px}.upload-new-button{width:100%}}.moderation-dashboard-page{min-height:100vh;background:transparent}.moderation-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.moderation-header h1{font-size:36px;font-weight:700;margin-bottom:24px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.moderation-stats{display:flex;gap:20px;flex-wrap:wrap}.stat-card{flex:1;min-width:150px;padding:20px;border-radius:12px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);text-align:center}.stat-pending{background:#fbbf241a;border-color:#fbbf244d}.stat-approved{background:#22c55e1a;border-color:#22c55e4d}.stat-rejected{background:#ef44441a;border-color:#ef44444d}.stat-value{font-size:32px;font-weight:700;margin-bottom:8px}.stat-pending .stat-value{color:#fbbf24}.stat-approved .stat-value{color:#22c55e}.stat-rejected .stat-value{color:#ef4444}.stat-label{font-size:14px;color:var(--text-secondary);font-weight:500}.pending-characters-list{display:flex;flex-direction:column;gap:24px}.moderation-character-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:24px;transition:all .2s ease}.moderation-character-card:hover{border-color:#8b5cf666;box-shadow:0 4px 12px #8b5cf61a}.character-preview-section{display:grid;grid-template-columns:300px 1fr;gap:24px;margin-bottom:24px}.character-images{display:flex;flex-direction:column;gap:12px}.image-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;position:relative}.preview-image{width:100%;aspect-ratio:2/3;object-fit:cover;border-radius:8px;border:1px solid rgba(139,92,246,.2)}.more-images-indicator{position:absolute;bottom:8px;right:8px;background:#000000b3;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.character-info-section{display:flex;flex-direction:column;gap:16px}.character-header h2{font-size:24px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.character-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.meta-item{font-size:14px;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.character-personality h3,.character-tags h3,.uploader-info h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.character-personality p{color:var(--text-primary);line-height:1.6;font-size:15px}.tags-list{display:flex;flex-wrap:wrap;gap:8px}.tag{padding:4px 12px;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:16px;font-size:12px;color:var(--accent-primary)}.uploader-info p{color:var(--text-primary);font-weight:500;margin-bottom:4px}.uploader-info small{color:var(--text-secondary);font-size:12px}.moderation-actions{display:flex;gap:12px;padding-top:20px;border-top:1px solid rgba(139,92,246,.2)}.btn-approve,.btn-reject{flex:1;padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-approve{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-approve:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.btn-reject{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-reject:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-approve:disabled,.btn-reject:disabled{opacity:.6;cursor:not-allowed}.reject-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;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.reject-modal{background:var(--bg-card);border:1px solid rgba(139,92,246,.3);border-radius:16px;padding:24px;width:90%;max-width:500px;box-shadow:0 8px 32px #0000004d}.reject-modal h3{font-size:20px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.reject-modal p{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.reject-modal textarea{width:100%;padding:12px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;resize:vertical;margin-bottom:16px}.reject-modal textarea:focus{outline:none;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-cancel,.btn-confirm-reject{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel{background:#8b5cf61a;color:var(--text-primary);border:1px solid rgba(139,92,246,.3)}.btn-cancel:hover{background:#8b5cf633}.btn-confirm-reject{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-confirm-reject:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-confirm-reject:disabled{opacity:.6;cursor:not-allowed}.moderation-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.moderation-tab{padding:12px 24px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;bottom:-1px}.moderation-tab:hover{color:var(--text-primary)}.moderation-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.stat-open{background:#fbbf241a;border-color:#fbbf244d}.stat-open .stat-value{color:#fbbf24}.stat-reviewing{background:#3b82f61a;border-color:#3b82f64d}.stat-reviewing .stat-value{color:#3b82f6}.stat-resolved{background:#22c55e1a;border-color:#22c55e4d}.stat-resolved .stat-value{color:#22c55e}.stat-dismissed{background:#6b72801a;border-color:#6b72804d}.stat-dismissed .stat-value{color:#6b7280}.reports-management-section{margin-top:24px}.reports-filters{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.filter-select{padding:10px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s ease}.filter-select:focus{outline:none;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.reports-list{display:flex;flex-direction:column;gap:16px}.report-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:20px;transition:all .2s ease}.report-card:hover{border-color:#8b5cf666;box-shadow:0 4px 12px #8b5cf61a}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.2)}.report-meta{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.report-status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.report-status-badge.status-open{background:#fbbf2433;color:#fbbf24}.report-status-badge.status-reviewing{background:#3b82f633;color:#3b82f6}.report-status-badge.status-resolved{background:#22c55e33;color:#22c55e}.report-status-badge.status-dismissed{background:#6b728033;color:#6b7280}.report-type-badge{padding:4px 12px;background:#8b5cf633;color:var(--accent-primary);border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize}.report-date{color:var(--text-secondary);font-size:12px}.view-report-button{padding:8px 16px;background:#8b5cf633;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--accent-primary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.view-report-button:hover{background:#8b5cf64d;border-color:#8b5cf680}.report-content{display:flex;flex-direction:column;gap:12px}.report-reason,.report-details,.report-reporter{color:var(--text-primary);font-size:14px;line-height:1.6}.report-reason strong,.report-details strong,.report-reporter strong{color:var(--text-secondary);margin-right:8px}.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;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.report-detail-modal{background:var(--bg-card);border:1px solid rgba(139,92,246,.3);border-radius:16px;padding:24px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.2)}.modal-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0}.close-modal{background:none;border:none;font-size:32px;color:var(--text-secondary);cursor:pointer;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.close-modal:hover{color:var(--text-primary);transform:rotate(90deg)}.modal-content{display:flex;flex-direction:column;gap:24px}.report-detail-section{padding:16px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px}.report-detail-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.report-detail-section p{color:var(--text-primary);line-height:1.6;margin:0}.detail-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.detail-row:last-child{margin-bottom:0}.detail-row strong{color:var(--text-secondary);min-width:120px}.detail-row span{color:var(--text-primary)}.target-image{max-width:200px;max-height:200px;border-radius:8px;margin-top:12px;border:1px solid rgba(139,92,246,.3)}.report-actions-section{padding:20px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px}.report-actions-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.action-notes{width:100%;padding:12px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;resize:vertical;margin-bottom:16px}.action-notes:focus{outline:none;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn-action{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-ban{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-remove{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-resolve{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-dismiss{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.btn-reviewing{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-reopen{background:linear-gradient(135deg,#a855f7,#9333ea);color:#fff}.btn-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-action:disabled{opacity:.6;cursor:not-allowed}.resolved-message{color:var(--text-secondary);font-size:14px;margin-bottom:16px}@media (max-width: 768px){.character-preview-section{grid-template-columns:1fr}.image-gallery{grid-template-columns:repeat(3,1fr)}.moderation-stats{flex-direction:column}.stat-card{min-width:100%}.moderation-actions,.reports-filters{flex-direction:column}.filter-select{width:100%}.report-header{flex-direction:column;align-items:flex-start;gap:12px}.action-buttons{flex-direction:column}.btn-action{width:100%}.report-detail-modal{padding:16px}}.messages-page{min-height:100vh;background:transparent;padding-bottom:48px}.messages-hero{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding:32px 0;border-bottom:1px solid rgba(139,92,246,.2)}.messages-hero-content h1{font-size:42px;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 10px rgba(0,0,0,.5);-webkit-text-stroke:.5px rgba(255,255,255,.5);paint-order:stroke fill}.messages-subtitle{font-size:16px;color:var(--text-secondary);margin:0}.new-message-button{padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:12px;color:#fff;font-weight:600;font-size:15px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #a855f74d}.new-message-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #a855f766}.new-message-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:24px;margin-bottom:32px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.new-message-title{font-size:20px;font-weight:600;margin:0 0 20px;color:var(--text-primary)}.search-wrapper{position:relative;margin-bottom:16px}.user-search-input{width:100%;padding:14px 18px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:var(--text-primary);font-size:15px;font-family:inherit;outline:none;transition:all .3s ease}.user-search-input:focus{background:#8b5cf626;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.searching-indicator{display:flex;align-items:center;gap:8px;margin-top:12px;color:var(--text-secondary);font-size:14px}.spinner{width:16px;height:16px;border:2px solid rgba(139,92,246,.3);border-top-color:#a855f7;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.user-search-results{display:flex;flex-direction:column;gap:10px;margin-top:16px}.user-search-result-item{display:flex;align-items:center;gap:14px;padding:14px;background:#8b5cf614;border:1px solid rgba(139,92,246,.2);border-radius:12px;cursor:pointer;transition:all .3s ease}.user-search-result-item:hover{background:#8b5cf626;border-color:#8b5cf666;transform:translate(4px)}.search-result-avatar-wrapper{position:relative;flex-shrink:0}.search-result-avatar,.search-result-avatar-placeholder{width:48px;height:48px;border-radius:50%;border:2px solid rgba(139,92,246,.3);flex-shrink:0}.search-result-avatar{object-fit:cover}.search-result-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:18px;text-transform:uppercase}.search-result-info{flex:1;display:flex;flex-direction:column;gap:4px}.search-result-username{font-weight:600;color:var(--text-primary);font-size:15px}.existing-thread-badge{font-size:12px;color:#a855f7;font-weight:500}.no-results{text-align:center;padding:24px}.no-results-text{color:var(--text-secondary);font-size:14px;margin:0}.error-card{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:16px 20px;margin-bottom:24px}.error-card p{margin:0;color:#ef4444;font-size:14px}.threads-section{margin-top:32px}.threads-section-title{font-size:24px;font-weight:600;margin:0 0 20px;color:var(--text-primary);background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.threads-list{display:flex;flex-direction:column;gap:12px}.thread-card{display:flex;align-items:center;gap:16px;padding:18px 20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;text-decoration:none;color:inherit;transition:all .3s ease;position:relative;overflow:hidden}.thread-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(135deg,#a855f7,#ec4899);transition:width .3s ease}.thread-card:hover{border-color:#8b5cf680;background:#8b5cf61a;transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf633}.thread-card:hover:before{width:4px}.thread-avatar-wrapper{position:relative;flex-shrink:0}.thread-avatar-img,.thread-avatar-placeholder{width:60px;height:60px;border-radius:50%;border:2px solid rgba(139,92,246,.3);object-fit:cover}.thread-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:22px;text-transform:uppercase}.online-indicator{position:absolute;bottom:2px;right:2px;width:14px;height:14px;background:#22c55e;border:2px solid var(--bg-primary);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.unread-badge{position:absolute;top:-4px;right:-4px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-radius:50%;min-width:22px;height:22px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--bg-primary);padding:0 6px}.thread-card-content{flex:1;min-width:0}.thread-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.thread-username{font-size:17px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:8px}.thread-time{font-size:12px;color:var(--text-secondary);flex-shrink:0;font-weight:500}.thread-preview{font-size:14px;color:var(--text-secondary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.thread-preview.unread{color:var(--text-primary);font-weight:500}.empty-state-card{text-align:center;padding:80px 20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;margin-top:32px}.empty-state-icon{font-size:64px;margin-bottom:20px;opacity:.6}.empty-state-card h3{font-size:24px;margin:0 0 12px;color:var(--text-primary);font-weight:600}.empty-state-card p{color:var(--text-secondary);font-size:15px;max-width:400px;margin:0 auto}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary)}.loading p{font-size:16px;margin:0}@media (max-width: 768px){.messages-hero{flex-direction:column;gap:16px;align-items:stretch}.messages-hero-content h1{font-size:32px}.new-message-button{width:100%}.thread-card{padding:14px 16px}.thread-avatar-img,.thread-avatar-placeholder{width:52px;height:52px}.thread-username{font-size:16px}}.message-thread-page{min-height:100vh;background:transparent;display:flex;flex-direction:column;position:relative;z-index:1}.message-thread-page header.header{flex:0 0 auto;flex-shrink:0;flex-grow:0;height:auto;min-height:auto;max-height:none}.message-thread-page .container{display:flex;flex-direction:column;height:100vh;max-width:1600px;width:100%;margin:0 auto;padding:24px 24px 24px 90px;position:relative;z-index:1;flex:1;overflow:hidden}.thread-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.3)}.back-button{color:var(--accent-primary);text-decoration:none;font-weight:500;transition:all .2s ease}.thread-user-info{display:flex;align-items:center;gap:12px;flex:1}.thread-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.user-avatar-small,.user-avatar-small-placeholder{width:40px;height:40px;border-radius:50%;border:2px solid rgba(139,92,246,.3)}.user-avatar-small{object-fit:cover}.user-avatar-small-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:16px;text-transform:uppercase}.thread-username-link{color:var(--text-primary);text-decoration:none;font-weight:600;font-size:18px}.thread-username-link:hover{color:var(--accent-primary);text-decoration:underline}.messages-container{flex:1;overflow-y:auto;padding:20px 0;display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:#8b5cf61a;border-radius:4px}.messages-container::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:#8b5cf680}.message-bubble{max-width:70%;padding:12px 16px;border-radius:16px;word-wrap:break-word}.message-bubble.own{align-self:flex-end;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-bottom-right-radius:4px}.message-bubble.other{align-self:flex-start;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:var(--text-primary);border-bottom-left-radius:4px}.message-content{font-size:15px;line-height:1.5;margin-bottom:4px}.message-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:4px}.message-bubble.other .message-footer{justify-content:flex-start}.message-time{font-size:11px;opacity:.7}.empty-messages{text-align:center;padding:40px 20px;color:var(--text-secondary)}.message-input-form{display:flex;gap:12px;padding-top:16px;border-top:1px solid rgba(139,92,246,.3)}.message-input{flex:1;padding:12px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:24px;color:var(--text-primary);font-size:15px;font-family:inherit;outline:none;transition:all .2s ease}.message-input:focus{background:#8b5cf626;border-color:#8b5cf680;box-shadow:0 0 0 3px #8b5cf61a}.message-input:disabled{opacity:.6;cursor:not-allowed}.send-button{padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);border:none;border-radius:24px;color:#fff;font-weight:600;font-size:15px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.send-button:disabled{opacity:.6;cursor:not-allowed}.online-indicator{display:inline-block;width:8px;height:8px;background:#22c55e;border-radius:50%;margin-left:8px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.typing-indicator{display:flex;justify-content:flex-start;padding:8px 0;margin-bottom:8px;animation:fadeIn .3s ease}.typing-indicator-content{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:18px;max-width:fit-content}.typing-dots{display:inline-flex;align-items:center;gap:4px;height:8px}.typing-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent-primary);animation:typingDot 1.4s infinite ease-in-out}.typing-dots span:nth-child(1){animation-delay:0s}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.typing-text{color:var(--text-secondary);font-size:13px;font-weight:500;white-space:nowrap}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-8px);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.message-thread-page .container{height:calc(100vh - 80px);padding:16px}.message-bubble{max-width:85%}}.my-showcases-page{min-height:100vh;background:transparent}.my-showcases-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.my-showcases-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.subtitle{color:var(--text-secondary);font-size:16px;margin:0}.showcases-section,.sessions-section{margin-bottom:40px}.showcases-section h2,.sessions-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.empty-state{color:var(--text-secondary);font-style:italic;padding:20px;text-align:center}.showcases-list,.sessions-list{display:flex;flex-direction:column;gap:16px}.showcase-item,.session-item{display:flex;align-items:center;gap:16px;padding:20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;transition:all .2s ease}.showcase-item:hover,.session-item:hover{background:#8b5cf61a;border-color:#8b5cf666}.showcase-character-image,.session-character-image{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid rgba(139,92,246,.3)}.showcase-item-header,.session-item-info{flex:1}.showcase-item-header{display:flex;align-items:center;gap:12px}.showcase-item-info h3,.session-item-info h3{margin:0 0 4px;font-size:18px;font-weight:600;color:var(--text-primary)}.showcase-item-info p,.session-item-info p{margin:0;font-size:14px;color:var(--text-secondary)}.showcase-meta{margin-top:4px!important;font-size:12px!important}.showcase-item-actions,.session-item-actions{display:flex;align-items:center;gap:8px}.toggle-visibility-button,.edit-button,.delete-button,.create-showcase-button{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid}.toggle-visibility-button{background:transparent;border-color:#8b5cf64d;color:var(--text-primary)}.toggle-visibility-button:hover{background:#8b5cf61a}.edit-button{background:#8b5cf633;border-color:#8b5cf680;color:var(--accent-primary)}.edit-button:hover{background:#8b5cf64d}.delete-button{background:transparent;border-color:#dc3545;color:#dc3545}.delete-button:hover{background:#dc3545;color:#fff}.create-showcase-button{background:linear-gradient(135deg,#a855f7,#ec4899);border:none;color:#fff}.create-showcase-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.showcased-badge{padding:8px 16px;background:#8b5cf633;border:1px solid rgba(139,92,246,.5);border-radius:6px;color:var(--accent-primary);font-size:14px;font-weight:500}.showcase-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.showcase-modal{background:var(--bg-secondary);border:1px solid rgba(139,92,246,.3);border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000080}.showcase-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(139,92,246,.3)}.showcase-modal-header h2{margin:0;font-size:24px;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:32px;cursor:pointer;color:var(--text-secondary);padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:#8b5cf61a;color:var(--text-primary)}.showcase-modal-content{padding:20px}.modal-section{margin-bottom:24px}.modal-section label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.modal-section input[type=text]{width:100%;padding:10px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:6px;font-size:14px;font-family:inherit;color:var(--text-primary)}.modal-section input[type=text]:focus{outline:none;border-color:#8b5cf699;box-shadow:0 0 0 2px #8b5cf633;background:#8b5cf626}.messages-selection{max-height:400px;overflow-y:auto;border:1px solid rgba(139,92,246,.3);border-radius:6px;padding:12px;background:#8b5cf60d}.message-selection-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:6px;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.message-selection-item:hover{background:#8b5cf60d}.message-selection-item.selected{background:#8b5cf626;border:1px solid rgba(139,92,246,.3)}.message-selection-item input[type=checkbox]{margin-top:4px;cursor:pointer;width:20px;height:20px;min-width:20px;flex-shrink:0;accent-color:var(--accent-primary);pointer-events:auto;position:relative;z-index:1}.message-selection-content{flex:1;display:flex;flex-direction:column;gap:4px}.message-role-label{font-weight:600;color:var(--accent-primary);font-size:13px}.message-content-preview{color:var(--text-primary);font-size:14px;line-height:1.4}.selection-hint{margin-top:12px;font-size:13px;color:var(--text-secondary);font-style:italic}.showcase-modal-actions{display:flex;gap:12px;justify-content:flex-end;padding:20px;border-top:1px solid rgba(139,92,246,.3)}.cancel-button,.save-button{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);color:var(--text-primary)}.cancel-button:hover{background:#8b5cf633;border-color:#8b5cf680}.save-button{background:linear-gradient(135deg,#a855f7,#ec4899);border:none;color:#fff}.save-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.save-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.showcase-item,.session-item{flex-direction:column;align-items:flex-start}.showcase-item-actions,.session-item-actions{width:100%;justify-content:flex-end}.showcase-modal{width:95%;max-height:95vh}}.user-showcases-page{min-height:100vh;background:transparent}.showcases-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.showcases-title-section{display:flex;align-items:center;gap:16px}.profile-picture-small{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid rgba(139,92,246,.3)}.showcases-title-section h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.showcases-subtitle{color:var(--text-secondary);font-size:16px;margin:0}.empty-state p{font-size:18px;margin-bottom:20px}.back-to-profile-link{display:inline-block;padding:12px 24px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s ease}.back-to-profile-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.showcased-chats-list{display:flex;flex-direction:column;gap:24px}.showcased-chat-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:24px;transition:all .2s ease}.showcased-chat-card:hover{background:#8b5cf61a;border-color:#8b5cf666}.showcased-chat-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(139,92,246,.2)}.showcased-chat-character-image{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid rgba(139,92,246,.3)}.showcased-chat-info h3{margin:0 0 4px;font-size:20px;font-weight:600;color:var(--text-primary)}.showcased-chat-character-name{margin:0;font-size:14px;color:var(--text-secondary)}.showcased-chat-messages{display:flex;flex-direction:column;gap:12px;margin-bottom:20px;max-height:500px;overflow-y:auto}.showcased-message{padding:12px 16px;border-radius:8px;font-size:14px;line-height:1.5}.showcased-message.user-message{background:#8b5cf626;border-left:3px solid rgba(139,92,246,.5);align-self:flex-end;max-width:80%}.showcased-message.assistant-message{background:#8b5cf614;border-left:3px solid rgba(139,92,246,.3);align-self:flex-start;max-width:80%}.message-role{font-weight:600;margin-right:8px;color:var(--accent-primary)}.showcased-chat-footer{display:flex;justify-content:flex-end;padding-top:12px;border-top:1px solid rgba(139,92,246,.2)}.showcased-chat-date{font-size:12px;color:var(--text-secondary)}@media (max-width: 768px){.showcases-title-section{flex-direction:column;align-items:flex-start}.showcases-title-section h1{font-size:24px}.showcased-message{max-width:90%}}.profile-followers-page{min-height:100vh;background:transparent}.followers-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.followers-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0}.followers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.follower-card{display:flex;align-items:center;gap:16px;padding:20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;text-decoration:none;transition:all .2s ease}.follower-card:hover{background:#8b5cf61a;border-color:#8b5cf666;transform:translateY(-2px)}.follower-avatar,.follower-avatar-placeholder{width:60px;height:60px;border-radius:50%;border:2px solid rgba(139,92,246,.3);flex-shrink:0}.follower-avatar{object-fit:cover}.follower-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:24px;text-transform:uppercase}.follower-info{display:flex;flex-direction:column;gap:4px;flex:1}.follower-username{color:var(--text-primary);font-size:16px;font-weight:600}.follower-date{color:var(--text-secondary);font-size:12px}.profile-following-page{min-height:100vh;background:transparent}.following-header{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(139,92,246,.3)}.back-button{display:inline-block;margin-bottom:20px;color:var(--accent-primary);text-decoration:none;font-weight:500;transition:all .2s ease}.back-button:hover{color:var(--accent-secondary);text-decoration:underline}.following-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0}.following-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.following-card{display:flex;align-items:center;gap:16px;padding:20px;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;text-decoration:none;transition:all .2s ease}.following-card:hover{background:#8b5cf61a;border-color:#8b5cf666;transform:translateY(-2px)}.following-avatar,.following-avatar-placeholder{width:60px;height:60px;border-radius:50%;border:2px solid rgba(139,92,246,.3);flex-shrink:0}.following-avatar{object-fit:cover}.following-avatar-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-weight:700;font-size:24px;text-transform:uppercase}.following-info{display:flex;flex-direction:column;gap:4px;flex:1}.following-username{color:var(--text-primary);font-size:16px;font-weight:600}.following-date{color:var(--text-secondary);font-size:12px}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.community-page{min-height:100vh;background:transparent}.community-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:8px}.community-title-left{font-size:56px;font-weight:400;font-family:Birthstone,cursive,serif;margin:12px 0 20px;text-align:left;background:linear-gradient(to right,#a855f7,#c084fc,#f472b6 60%,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px;line-height:1;transform:translateY(8px)}.community-header-actions{display:flex;align-items:center;gap:10px}.community-sort-wrapper{display:flex;align-items:center;gap:6px;padding:10px 22px;border-radius:999px;background:linear-gradient(135deg,#4c1d95,#a855f7);border:none;box-shadow:0 8px 20px #4c1d9566;position:relative;cursor:pointer}.community-sort-label{font-size:14px;color:#fff;font-weight:600;letter-spacing:.03em}.community-sort-current{font-size:14px;color:#e5e7eb;font-weight:600}.community-sort-chevron{font-size:10px;color:#e5e7eb}.community-sort-menu{position:absolute;top:100%;right:0;margin-top:6px;background:#0f172af2;border-radius:12px;box-shadow:0 12px 30px #0f172abf;padding:6px;min-width:180px;z-index:20}.community-sort-option{width:100%;text-align:left;padding:8px 10px;background:transparent;border:none;color:#e5e7eb;font-size:13px;border-radius:8px;cursor:pointer;transition:background .15s ease,color .15s ease}.community-sort-option:hover{background:#1e40afb3}.community-sort-option.active{background:#3b82f6cc;color:#fff}.community-upload-button{padding:10px 22px;border-radius:999px;border:none;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;font-size:14px;font-weight:600;letter-spacing:.03em;cursor:pointer;box-shadow:0 8px 20px #ec489959;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;white-space:nowrap}.community-share-button{padding:10px 22px;border-radius:999px;border:none;background:linear-gradient(135deg,#4c1d95,#a855f7);color:#fff;font-size:14px;font-weight:600;letter-spacing:.03em;cursor:pointer;box-shadow:0 8px 20px #4c1d9566;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;white-space:nowrap}.community-upload-button:hover{transform:translateY(-1px);box-shadow:0 10px 24px #ec489973;filter:brightness(1.05)}.community-upload-button:active{transform:translateY(0);box-shadow:0 5px 14px #ec489959}.community-share-button:hover{transform:translateY(-1px);box-shadow:0 10px 24px #4c1d958c;filter:brightness(1.05)}.community-share-button:active{transform:translateY(0);box-shadow:0 5px 14px #4c1d9566}.section-header{font-size:32px;font-weight:700;margin:48px 0 24px;color:var(--text-primary);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.community-characters-section{margin-bottom:48px}.character-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;padding-bottom:48px}.community-unified-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;padding-bottom:48px}.character-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s ease}.character-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 12px 24px #8b5cf633}.character-image{width:100%;aspect-ratio:2/3;overflow:hidden;background:var(--bg-tertiary);position:relative}.character-image-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease,opacity .5s ease}.character-card:hover .character-image-img{transform:scale(1.05);filter:blur(8px)}.image-slider-container{position:relative;width:100%;height:100%;overflow:hidden}.sliding-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transform:translate(100%);transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .6s ease-in-out;z-index:1}.sliding-image.active{opacity:1;transform:translate(0);z-index:2}.sliding-image.prev{opacity:0;transform:translate(-100%);z-index:1}.sliding-image.hidden{opacity:0;transform:translate(100%);z-index:0}.image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:14px}.delete-character-button{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:#ef4444e6;color:#fff;border:none;font-size:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;line-height:1;padding:0}.delete-character-button:hover{background:#dc2626;transform:scale(1.1)}.delete-character-button:active{transform:scale(.95)}.featured-toggle-button{position:absolute;top:8px;left:8px;width:32px;height:32px;border-radius:50%;background:#8b5cf6e6;color:#fff;border:none;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:15;line-height:1;padding:0;box-shadow:0 2px 8px #0000004d}.featured-toggle-button:hover{background:#7c3aed;transform:scale(1.1)}.featured-toggle-button:active{transform:scale(.95)}.featured-toggle-button.featured-active{background:#fbbf24e6}.featured-toggle-button.featured-active:hover{background:#f59e0b}.character-info-overlay{position:absolute;bottom:12px;left:12px;z-index:5;text-align:left}.character-online-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:linear-gradient(135deg,#10b981,#059669);border:1px solid rgba(16,185,129,.3);border-radius:10px;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;width:fit-content;box-shadow:0 0 8px #10b98199,0 0 16px #10b98166,0 0 24px #10b98133;margin-bottom:4px;position:relative;animation:glow-pulse 2s ease-in-out infinite}.character-online-badge:before{content:"";width:6px;height:6px;background:#fff;border-radius:50%;display:inline-block;animation:pulse-online 2s ease-in-out infinite}@keyframes pulse-online{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 8px #10b98199,0 0 16px #10b98166,0 0 24px #10b98133}50%{box-shadow:0 0 12px #10b981cc,0 0 24px #10b98199,0 0 36px #10b98166}}.character-name-overlay{font-size:28px;font-weight:700;color:#fff;margin:0 0 6px;text-shadow:0 2px 8px rgba(0,0,0,.8)}.character-location-overlay{font-size:20px;color:#fff;margin:0 0 4px;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8);display:flex;align-items:center;gap:6px}.location-flag{display:inline-block;vertical-align:middle;margin-left:4px;flex-shrink:0}.character-age-overlay{font-size:20px;color:#fff;margin:0 0 8px;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8)}.character-tags-overlay{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.character-tag{display:inline-block;padding:4px 10px;background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5);white-space:nowrap}.character-tag-more{display:inline-block;padding:4px 10px;background:#ffffff4d;color:#fff;border-radius:12px;font-size:11px;font-weight:600;text-shadow:0 1px 3px rgba(0,0,0,.5)}.character-uploader-overlay{font-size:14px;color:#fff;margin:8px 0 0;font-weight:500;text-shadow:0 2px 8px rgba(0,0,0,.8)}.character-description-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s ease;z-index:6;overflow-y:auto}.character-card:hover .character-description-overlay{opacity:1}.character-description-text{color:#fff;font-size:14px;line-height:1.6;text-align:center;margin:0;max-height:100%;overflow-y:auto;padding:8px}.shared-chats-section{padding-bottom:48px}.shared-chat-card{background:linear-gradient(135deg,#12061f,#1f0b3a,#3b0764);border:1px solid var(--border-color);border-radius:16px;padding:20px;cursor:pointer;transition:all .3s ease;grid-column:span 1}.shared-chat-card:hover{transform:translateY(-4px);border-color:var(--accent-primary);box-shadow:0 12px 24px #8b5cf633}.chat-header{display:flex;gap:16px;margin-bottom:16px}.chat-character-image{width:80px;height:80px;border-radius:12px;object-fit:cover;flex-shrink:0}.chat-meta{flex:1}.chat-title{font-size:20px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.chat-user-info{display:flex;align-items:center;gap:8px}.user-avatar-small{width:24px;height:24px;border-radius:50%;object-fit:cover}.user-avatar-placeholder-small{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.chat-username{font-size:14px;color:var(--text-secondary)}.chat-description{color:var(--text-secondary);margin-bottom:16px;line-height:1.6}.chat-preview{background:linear-gradient(135deg,#12061f,#1f0b3a,#3b0764);border-radius:8px;padding:12px;margin-bottom:16px}.chat-messages-preview{display:flex;flex-direction:column;gap:8px}.full-chat-header{display:flex;gap:16px;margin-bottom:16px}.full-chat-meta{flex:1}.full-chat-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.full-chat-messages{max-height:360px;overflow-y:auto;margin-top:8px;display:flex;flex-direction:column;gap:8px}.preview-message{font-size:14px;line-height:1.5}.preview-message.user{color:var(--accent-primary)}.preview-message.assistant{color:var(--text-secondary)}.message-role{font-weight:600;margin-right:8px}.message-content{color:var(--text-primary)}.chat-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border-color)}.chat-date{font-size:12px;color:var(--text-secondary)}.empty-state{text-align:center;padding:64px 24px;color:var(--text-secondary)}.empty-state h3{font-size:24px;margin-bottom:8px;color:var(--text-primary)}.empty-state p{font-size:16px;margin-bottom:24px}@media (max-width: 768px){.community-header-row{flex-direction:row;align-items:flex-end;padding:0 12px}.community-title-left{font-size:42px;padding-left:0}.community-upload-button,.community-share-button{padding:8px 14px;font-size:13px}.community-unified-grid{grid-template-columns:1fr;gap:16px}.character-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.shared-chat-card{padding:16px}.chat-header{gap:12px}.chat-character-image{width:60px;height:60px}.chat-title{font-size:18px}}@media (max-width: 480px){.community-header-row{flex-direction:column;align-items:flex-start;padding:8px 12px 0;gap:10px}.community-title-left{font-size:32px;padding:0}.community-header-actions{width:100%}.community-upload-button,.community-share-button{width:100%;text-align:center;justify-content:center}.community-unified-grid{gap:12px}.character-card{border-radius:8px}.character-name-overlay{font-size:20px!important}.shared-chat-card{padding:12px}.chat-character-image{width:50px;height:50px}.chat-title{font-size:16px}.chat-description{font-size:13px}}.affiliate-apply-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.affiliate-apply-container{max-width:800px;margin:0 auto;padding:24px}.affiliate-apply-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:20px;padding:40px;box-shadow:0 8px 32px #0000004d}.affiliate-apply-card h1{font-size:36px;font-weight:700;margin:0 0 12px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.affiliate-subtitle{font-size:18px;color:#ffffffb3;margin:0 0 32px}.affiliate-terms{margin-top:32px}.affiliate-terms h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:32px 0 16px}.affiliate-terms h2:first-child{margin-top:0}.affiliate-terms ul{list-style:none;padding:0;margin:0 0 24px}.affiliate-terms li{padding:12px 0 12px 28px;position:relative;color:#ffffffd9;line-height:1.6}.affiliate-terms li:before{content:"✓";position:absolute;left:0;color:#a855f7;font-weight:700;font-size:18px}.btn-large{width:100%;padding:16px 32px;font-size:18px;font-weight:600;margin-top:24px}.affiliate-status-section{margin-top:32px}.status-badge{display:inline-block;padding:12px 24px;border-radius:12px;font-weight:600;font-size:16px;margin-bottom:24px}.status-pending{background:#fbbf2433;border:1px solid rgba(251,191,36,.5);color:#fbbf24}.status-approved{background:#22c55e33;border:1px solid rgba(34,197,94,.5);color:#22c55e}.status-rejected{background:#ef444433;border:1px solid rgba(239,68,68,.5);color:#ef4444}.status-suspended{background:#9ca3af33;border:1px solid rgba(156,163,175,.5);color:#9ca3af}.affiliate-info{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:24px;margin-top:24px}.affiliate-info p{margin:12px 0;color:#ffffffd9;font-size:16px}.affiliate-info code{background:#8b5cf633;padding:4px 12px;border-radius:6px;font-family:Courier New,monospace;color:#c084fc;font-size:16px;font-weight:600}.approved-message,.pending-message,.rejection-message{margin-top:24px;padding:20px;background:#8b5cf61a;border-radius:12px;border:1px solid rgba(139,92,246,.3)}.approved-message p,.pending-message p{color:#ffffffe6;margin:0 0 16px;font-size:16px}.rejection-message p{color:#ffffffe6;margin:8px 0}@media (max-width: 768px){.affiliate-apply-container{padding:16px}.affiliate-apply-card{padding:24px}.affiliate-apply-card h1{font-size:28px}}.affiliate-dashboard-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.affiliate-dashboard-container{max-width:1000px;margin:0 auto;padding:24px}.affiliate-dashboard-container h1{font-size:42px;font-weight:700;margin:0 0 32px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:24px;text-align:center}.stat-label{font-size:14px;color:#fff9;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:#e9d5ff}.stat-value.pending{color:#fbbf24}.stat-value.paid{color:#22c55e}.affiliate-link-section{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:32px;margin-bottom:32px}.affiliate-link-section h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:0 0 20px}.link-container{display:flex;gap:12px;margin-bottom:12px}.affiliate-link-input{flex:1;background:#0f172ab3;border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:12px 16px;color:#fff;font-size:14px;font-family:Courier New,monospace}.affiliate-link-input:focus{outline:none;border-color:#8b5cf680}.copy-button{padding:12px 24px;white-space:nowrap}.link-help-text{color:#fff9;font-size:14px;margin:0}.payout-info{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:32px;margin-bottom:32px}.payout-info h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:0 0 20px}.payout-details p{margin:12px 0;color:#ffffffd9;font-size:16px}.payout-ready{color:#22c55e!important;font-weight:600;margin-top:16px!important}.payout-pending{color:#fbbf24!important;margin-top:16px!important}.commissions-section{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:32px}.commissions-section h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:0 0 24px}.commissions-list{display:flex;flex-direction:column;gap:12px}.commission-item{background:#0f172a80;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:16px 20px}.commission-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.commission-type{font-size:16px;color:#ffffffe6;font-weight:500}.commission-amount{font-size:20px;font-weight:700;color:#c084fc}.commission-details{display:flex;justify-content:space-between;align-items:center;font-size:14px}.commission-status{padding:4px 12px;border-radius:6px;font-weight:500}.commission-status.status-pending{background:#fbbf2433;color:#fbbf24}.commission-status.status-paid{background:#22c55e33;color:#22c55e}.commission-status.status-cancelled{background:#ef444433;color:#ef4444}.commission-date{color:#fff9}.no-commissions{text-align:center;color:#fff9;padding:40px 20px;font-size:16px}@media (max-width: 768px){.affiliate-dashboard-container{padding:16px}.affiliate-dashboard-container h1{font-size:32px}.dashboard-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.link-container{flex-direction:column}.copy-button{width:100%}}.admin-affiliates-page{min-height:100vh;background:linear-gradient(135deg,#0a0a0f,#1a0a2e,#2d1b4e);padding-bottom:60px}.admin-affiliates-container{max-width:1400px;margin:0 auto;padding:24px}.admin-affiliates-container h1{font-size:42px;font-weight:700;margin:0 0 32px;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.affiliates-layout{display:grid;grid-template-columns:400px 1fr;gap:32px}.affiliates-list h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:0 0 20px}.no-affiliates{text-align:center;color:#fff9;padding:40px 20px}.affiliates-table{display:flex;flex-direction:column;gap:12px}.affiliate-row{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease}.affiliate-row:hover{background:#8b5cf61a;border-color:#8b5cf666}.affiliate-row.selected{background:#8b5cf626;border-color:#8b5cf680}.affiliate-row-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.affiliate-info{flex:1}.affiliate-name{font-size:16px;font-weight:600;color:#e9d5ff;margin-bottom:4px}.affiliate-code{font-size:13px;color:#fff9;font-family:Courier New,monospace}.affiliate-stats-row{display:flex;gap:16px;font-size:13px;color:#ffffffb3}.status-badge{display:inline-block;padding:4px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:capitalize}.status-pending{background:#fbbf2433;color:#fbbf24}.status-approved{background:#22c55e33;color:#22c55e}.status-rejected{background:#ef444433;color:#ef4444}.status-suspended{background:#9ca3af33;color:#9ca3af}.affiliate-details{background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:16px;padding:32px;max-height:calc(100vh - 200px);overflow-y:auto}.affiliate-details h2{font-size:24px;font-weight:600;color:#e9d5ff;margin:0 0 24px}.details-section{margin-bottom:32px}.detail-item{margin:16px 0;color:#ffffffd9;font-size:15px}.detail-item code{background:#8b5cf633;padding:4px 8px;border-radius:6px;font-family:Courier New,monospace;color:#c084fc}.action-section,.payout-section{margin:32px 0;padding:24px;background:#0f172a80;border-radius:12px;border:1px solid rgba(139,92,246,.2)}.action-section h3,.payout-section h3{font-size:18px;font-weight:600;color:#e9d5ff;margin:0 0 16px}.action-buttons{display:flex;flex-direction:column;gap:12px}.reject-section{display:flex;gap:8px}.reject-input{flex:1;background:#0f172ab3;border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:10px 12px;color:#fff;font-size:14px}.reject-input:focus{outline:none;border-color:#8b5cf680}.payout-form{display:flex;gap:8px;margin-bottom:8px}.payout-input{flex:1;background:#0f172ab3;border:1px solid rgba(139,92,246,.3);border-radius:8px;padding:10px 12px;color:#fff;font-size:14px}.payout-input:focus{outline:none;border-color:#8b5cf680}.payout-help{font-size:13px;color:#fff9;margin:8px 0 0}.commissions-section,.referrals-section{margin-top:32px}.commissions-section h3,.referrals-section h3{font-size:18px;font-weight:600;color:#e9d5ff;margin:0 0 16px}.commissions-list,.referrals-list{display:flex;flex-direction:column;gap:8px}.commission-row,.referral-row{background:#0f172a80;border:1px solid rgba(139,92,246,.2);border-radius:8px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center}.commission-info{display:flex;gap:16px;align-items:center}.commission-amount{font-weight:600;color:#c084fc}.commission-meta{display:flex;gap:12px;align-items:center}.commission-date,.referral-date{font-size:13px;color:#fff9}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:24px}.loading{text-align:center;color:#ffffffb3;padding:40px;font-size:18px}.btn{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}.btn-primary{background:linear-gradient(135deg,#a855f7,#ec4899);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #a855f766}.btn-secondary{background:#8b5cf633;border:1px solid rgba(139,92,246,.4);color:#c084fc}.btn-secondary:hover{background:#8b5cf64d}@media (max-width: 1024px){.affiliates-layout{grid-template-columns:1fr}.affiliates-list{order:2}.affiliate-details{order:1;max-height:none}}@media (max-width: 768px){.admin-affiliates-container{padding:16px}.admin-affiliates-container h1{font-size:32px}.affiliate-stats-row{flex-direction:column;gap:4px}}.app{min-height:100vh;background:transparent}.app-layout{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1920px;margin:0 auto;padding:0 24px 0 90px}.header .container{padding-left:0;margin-left:0}@media (max-width: 640px){.container{padding:0 16px}}@media (max-width: 480px){.container{padding:0 12px}}.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);background:#141414cc}.header-content{display:flex;justify-content:space-between;align-items:center}.logo{font-size:24px;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;gap:12px;align-items:center}.btn{padding:10px 20px;border-radius:8px;font-weight:500;font-size:14px;transition:all .2s ease}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-hover)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.btn-outline:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-hover)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .2s ease}.card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.grid{display:grid;gap:24px}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-cols-4{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(1,1fr)}}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;color:var(--text-secondary)}.error{color:var(--error);text-align:center;padding:24px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-secondary)}.empty-state h3{margin-bottom:8px;color:var(--text-primary)}.desire-watermark{position:fixed;bottom:24px;right:24px;font-size:56px;font-weight:400;font-family:Pinyon Script,cursive,serif;background:linear-gradient(135deg,#a855f7,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:1px;line-height:1;z-index:10;pointer-events:none;-webkit-user-select:none;user-select:none}@media (max-width: 768px){.desire-watermark{font-size:36px;bottom:16px;right:16px}}@media (max-width: 480px){.desire-watermark{font-size:24px;bottom:12px;right:12px}}.age-gate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.age-gate-modal{background:radial-gradient(circle at top,#1f2933,#020617 55%,#020617);border-radius:24px;border:1px solid rgba(248,113,169,.5);box-shadow:0 24px 80px #000000e6;padding:32px 32px 28px;max-width:480px;width:100%;text-align:center;position:relative}.age-gate-title{font-size:28px;margin-bottom:16px;background:linear-gradient(135deg,#f97316,#f97316,#f97316,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.age-gate-text{color:#e5e7eb;font-size:15px;line-height:1.6;margin-bottom:24px}.age-gate-buttons{display:flex;gap:12px;justify-content:center;margin-bottom:14px}.age-gate-button{padding:10px 20px;border-radius:999px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;white-space:nowrap}.age-gate-confirm{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 8px 22px #22c55e66}.age-gate-confirm:hover{transform:translateY(-1px);box-shadow:0 11px 28px #22c55e8c;filter:brightness(1.05)}.age-gate-confirm:active{transform:translateY(0);box-shadow:0 5px 16px #22c55e66}.age-gate-exit{background:transparent;color:#fecaca;border:1px solid rgba(248,113,169,.6)}.age-gate-exit:hover{background:#0f172ae6;filter:brightness(1.05)}.age-gate-subtext{font-size:12px;color:#9ca3af}@media (max-width: 480px){.age-gate-modal{margin:0 16px;padding:24px 20px 22px}.age-gate-title{font-size:22px}.age-gate-buttons{flex-direction:column}.age-gate-button{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0}:root{--bg-primary: #0a0a0a;--bg-secondary: #141414;--bg-tertiary: #1a1a1a;--bg-card: #1f1f1f;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #b3b3b3;--text-tertiary: #808080;--accent-primary: #8b5cf6;--accent-hover: #7c3aed;--accent-secondary: #ec4899;--border-color: #2a2a2a;--border-hover: #3a3a3a;--error: #ef4444;--success: #10b981;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5)}html{background:#0a0a0a;min-height:100vh}body{font-family:Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a0a0a;color:var(--text-primary);line-height:1.6;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all .2s ease}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font-family:inherit;background-color:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;padding:12px 16px;transition:all .2s ease}input:focus,textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #8b5cf61a}input::placeholder,textarea::placeholder{color:var(--text-tertiary)}a{color:var(--accent-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-hover)}
