body{margin:0;min-height:100vh}#root{min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-dark: #0a0a0f;--bg-darker: #050508;--surface: rgba(255, 255, 255, .05);--surface-hover: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .1);--text-primary: #ffffff;--text-secondary: #a0a0b0;--accent-blue: #3b82f6;--accent-purple: #8b5cf6;--accent-pink: #ec4899;--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-3: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-dark);color:var(--text-primary);line-height:1.6}.app-container{display:flex;min-height:100vh}.sidebar{width:280px;background:var(--bg-darker);border-right:1px solid var(--border);padding:2rem 1.5rem;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.logo{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;margin-bottom:3rem;color:var(--text-primary)}.logo svg{color:var(--accent-blue)}.nav-menu{display:flex;flex-direction:column;gap:.5rem;flex:1}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;border-radius:12px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.95rem;font-weight:500;text-align:left}.nav-item:hover{background:var(--surface);color:var(--text-primary)}.nav-item.active{background:var(--surface);color:var(--text-primary);box-shadow:0 0 20px #3b82f633}.sidebar-footer{margin-top:auto;padding-top:1.5rem}.credits-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--gradient-1);border-radius:12px;font-weight:600;font-size:.9rem}.main-content{flex:1;margin-left:280px;padding:3rem;max-width:1600px;width:100%}.glass-card{background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:20px;padding:2rem}.hero-section{margin-bottom:4rem}.hero-content{text-align:center;max-width:900px;margin:0 auto}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:100px;font-size:.875rem;font-weight:500;margin-bottom:2rem;color:var(--text-secondary)}.badge-pulse{width:8px;height:8px;background:var(--accent-blue);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.hero-title{font-size:4rem;font-weight:800;line-height:1.1;margin-bottom:1.5rem;letter-spacing:-.02em}.gradient-text{background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-description{font-size:1.25rem;color:var(--text-secondary);margin-bottom:3rem;line-height:1.7}.hero-stats{display:flex;justify-content:center;gap:4rem;margin-top:3rem}.stat-item{text-align:center}.stat-value{font-size:2.5rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{color:var(--text-secondary);font-size:.9rem;margin-top:.5rem}.generation-dashboard{margin-top:3rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h2{font-size:2rem;margin-bottom:.5rem}.dashboard-header p{color:var(--text-secondary);font-size:1.05rem}.generation-card,.prompt-section{margin-bottom:2rem}.prompt-section label{display:block;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.prompt-input{width:100%;padding:1rem;background:var(--bg-darker);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:1rem;font-family:inherit;resize:vertical;transition:all .2s}.prompt-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.generation-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.option-group label{display:block;font-weight:600;margin-bottom:.5rem;font-size:.9rem}.select-input{width:100%;padding:.75rem;background:var(--bg-darker);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s}.select-input:focus{outline:none;border-color:var(--accent-blue)}.generate-btn{width:100%;padding:1.25rem;background:var(--gradient-1);border:none;border-radius:12px;color:#fff;font-size:1.05rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .3s}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.browse-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.browse-btn:hover{background:var(--surface-hover);border-color:var(--accent-blue)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.preview-section{margin-top:3rem}.preview-section h3{font-size:1.5rem;margin-bottom:1.5rem}.preview-grid{display:grid;gap:1.5rem}.preview-card{min-height:400px;display:flex;align-items:center;justify-content:center}.preview-placeholder{text-align:center;color:var(--text-secondary)}.preview-placeholder svg{margin-bottom:1rem;opacity:.5}.generating-animation{text-align:center}.pulse-loader{width:60px;height:60px;margin:0 auto 1.5rem;border-radius:50%;background:var(--gradient-1);animation:pulse-scale 1.5s ease-in-out infinite}@keyframes pulse-scale{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.example-prompts{margin-top:2rem}.example-label{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.example-chips{display:flex;flex-wrap:wrap;gap:.75rem}.chip{padding:.625rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:100px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.chip:hover{background:var(--surface-hover);border-color:var(--accent-blue)}.gallery-header{margin-bottom:2rem}.gallery-header h2{font-size:2rem;margin-bottom:.5rem}.gallery-header p{color:var(--text-secondary);font-size:1.05rem}.gallery-filters{display:flex;gap:1rem;margin-bottom:2rem}.filter-btn{padding:.75rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.filter-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.gallery-item{padding:0;overflow:hidden;transition:all .3s}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000004d}.gallery-image{position:relative;aspect-ratio:1;overflow:hidden}.image-placeholder{width:100%;height:100%;background:var(--bg-darker)}.placeholder-gradient{width:100%;height:100%;background:var(--gradient-3);opacity:.3}.image-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;gap:.75rem;opacity:0;transition:opacity .3s}.gallery-item:hover .image-overlay{opacity:1}.icon-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);cursor:pointer;transition:all .2s}.icon-btn:hover{background:var(--surface-hover);transform:scale(1.1)}.icon-btn.liked{color:var(--accent-pink)}.icon-btn.delete{color:#ef4444}.gallery-info{padding:1.25rem}.gallery-prompt{font-weight:500;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-date{color:var(--text-secondary);font-size:.85rem}.subscription-header{text-align:center;margin-bottom:3rem}.subscription-header h2{font-size:2.5rem;margin-bottom:.5rem}.subscription-header p{color:var(--text-secondary);font-size:1.1rem}.current-plan{margin-bottom:3rem}.plan-status{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.plan-status h3{font-size:1.5rem;margin-bottom:.25rem}.plan-status p{color:var(--text-secondary)}.credits-display{text-align:center}.credits-number{display:block;font-size:2.5rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.credits-label{color:var(--text-secondary);font-size:.9rem}.plan-progress{margin-top:1.5rem}.progress-bar{height:8px;background:var(--bg-darker);border-radius:100px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--gradient-1);border-radius:100px;transition:width .3s}.progress-text{color:var(--text-secondary);font-size:.85rem}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:3rem}.plan-card{position:relative;transition:all .3s}.plan-card:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000004d}.plan-card.popular{border-color:var(--accent-blue);box-shadow:0 0 30px #3b82f633}.popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);padding:.375rem 1rem;background:var(--accent-blue);color:#fff;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.plan-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:var(--gradient-1);border-radius:16px;margin-bottom:1.5rem;color:#fff}.plan-name{font-size:1.75rem;margin-bottom:1rem}.plan-price{margin-bottom:.5rem}.price-currency{font-size:1.5rem;vertical-align:super}.price-amount{font-size:3.5rem;font-weight:800;line-height:1}.price-period{color:var(--text-secondary);font-size:1rem}.plan-credits{color:var(--text-secondary);margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--border)}.plan-features{list-style:none;margin-bottom:2rem}.plan-features li{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.875rem;color:var(--text-secondary)}.plan-features svg{color:var(--accent-blue);flex-shrink:0;margin-top:.25rem}.plan-btn{width:100%;padding:1rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.plan-btn.primary{background:var(--gradient-1);color:#fff}.plan-btn.primary:hover{transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.plan-btn.secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.plan-btn.secondary:hover{background:var(--surface-hover)}.credits-info{margin-top:3rem}.credits-info h3{font-size:1.5rem;margin-bottom:1.5rem}.credits-breakdown{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.credit-item{display:flex;flex-direction:column;gap:.5rem}.credit-cost{font-size:1.5rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.credit-desc{color:var(--text-secondary)}.auth-card{max-width:400px;margin:2rem auto;padding:2rem;background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:20px}.auth-card h2{font-size:1.75rem;margin-bottom:1.5rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form input{width:100%;padding:1rem;background:var(--bg-darker);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-size:1rem;font-family:inherit;transition:all .2s}.auth-form input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.error-message{padding:.75rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.9rem}.primary-button{padding:1rem;background:var(--gradient-1);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s}.primary-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 30px #667eea66}.primary-button:disabled{opacity:.5;cursor:not-allowed}.auth-toggle{text-align:center;margin-top:1rem;color:var(--text-secondary);font-size:.9rem}.link-button{background:none;border:none;color:var(--accent-blue);cursor:pointer;margin-left:.5rem;font-weight:600}.link-button:hover{text-decoration:underline}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.reference-upload{margin-bottom:2rem}.reference-upload label{display:block;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.upload-area{width:100%}.upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem;background:var(--bg-darker);border:2px dashed var(--border);border-radius:12px;cursor:pointer;transition:all .2s;min-height:200px}.upload-label:hover{border-color:var(--accent-blue);background:var(--surface)}.reference-preview{max-width:100%;max-height:300px;border-radius:8px;object-fit:contain}.generated-image{width:100%;border-radius:12px;object-fit:contain}.generated-video{width:100%;border-radius:12px}.gallery-thumbnail{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease-in-out}.image-skeleton{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,var(--bg-darker) 0%,var(--surface) 50%,var(--bg-darker) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;z-index:1}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.video-thumbnail{position:relative}.video-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.type-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;margin-bottom:.5rem}.loading-state,.empty-state{text-align:center;padding:4rem;color:var(--text-secondary)}.load-more-trigger{display:flex;justify-content:center;align-items:center;text-align:center}.load-more-trigger .loading-state{padding:1rem;font-size:.95rem}.credits-info-compact{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:var(--bg-darker);border-radius:10px;margin-bottom:1rem}.credit-row{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary)}.user-info{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--surface);border-radius:10px;font-size:.9rem;margin-bottom:.5rem}.logout-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:transparent;border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .2s;font-size:.9rem;font-weight:500}.logout-btn:hover{background:var(--surface);color:#ef4444;border-color:#ef4444}.credits-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin:1.5rem 0}.credit-badge{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-darker);border-radius:12px}.credit-number{font-size:2rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.credit-label{font-size:.85rem;color:var(--text-secondary)}.cancel-btn{margin-top:1rem;padding:.75rem 1.5rem;background:transparent;border:1px solid #ef4444;border-radius:10px;color:#ef4444;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#ef44441a}.plan-credits-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.credit-line{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem}.settings-header{margin-bottom:2rem}.settings-header h2{font-size:2rem;margin-bottom:.5rem}.settings-header p{color:var(--text-secondary);font-size:1.05rem}.settings-card{margin-bottom:2rem}.settings-card h3{font-size:1.5rem;margin-bottom:1.5rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;align-items:flex-start;gap:1rem}.info-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-darker);border-radius:10px;color:var(--accent-blue);flex-shrink:0}.info-content{flex:1}.info-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:.25rem}.info-value{font-size:1rem;font-weight:500;word-break:break-all}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-box{padding:1.5rem;background:var(--bg-darker);border-radius:12px;text-align:center}.stat-number{font-size:2rem;font-weight:700;background:var(--gradient-1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem}.stat-label{font-size:.9rem;color:var(--text-secondary)}.settings-placeholder{text-align:center;padding:4rem}.settings-placeholder h2{font-size:2rem;margin-bottom:1rem}.settings-placeholder p{color:var(--text-secondary);font-size:1.1rem}.reference-selector{margin-bottom:2rem}.reference-selector>label{display:block;font-weight:600;margin-bottom:1rem;font-size:.95rem}.reference-upload-section{display:flex;flex-direction:column;gap:1.5rem}.reference-preview-box{position:relative;width:100%;max-width:400px;background:var(--bg-darker);border-radius:12px;overflow:hidden;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto;transition:aspect-ratio .3s ease}.selected-reference-image{width:100%;height:100%;object-fit:cover}.reference-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center;opacity:.6}.reference-placeholder p{font-size:.9rem;color:var(--text-secondary)}.change-reference-btn{position:absolute;bottom:1rem;right:1rem;padding:.5rem 1rem;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:8px;color:#fff;font-size:.85rem;cursor:pointer;transition:all .2s}.change-reference-btn:hover{background:#000000e6;border-color:var(--accent-blue)}.upload-custom-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:var(--bg-darker);border-radius:12px;border:2px dashed var(--border)}.upload-reference-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;background:var(--accent-blue);color:#fff;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.upload-reference-btn:hover{background:#2563eb;transform:translateY(-1px)}.reference-characters-section{display:flex;flex-direction:column}.reference-characters-section label{display:block;font-weight:500;margin-bottom:.75rem;font-size:.95rem}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem;max-height:300px;overflow-y:auto;overflow-x:hidden;padding:1rem;background:var(--bg-darker);border-radius:12px}.character-option{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.character-option:hover{border-color:var(--accent-blue);transform:scale(1.05)}.character-option.selected{border-color:var(--accent-blue);box-shadow:0 0 20px #3b82f666}.character-option img{width:100%;height:100%;object-fit:cover}.upload-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.upload-section label{display:block;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.voice-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-darker);border-radius:12px}.voice-toggle{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.voice-toggle label{font-weight:600;cursor:pointer}.checkbox-input{width:18px;height:18px;cursor:pointer}.credit-desc-small{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem}@media(max-width:1024px){.sidebar{width:240px}.main-content{margin-left:240px;padding:2rem}.hero-title{font-size:3rem}.plans-grid{grid-template-columns:1fr}}@media(max-width:768px){.sidebar{display:none}.main-content{margin-left:0;margin-top:70px;padding:1.5rem}.hero-title{font-size:2rem}.hero-stats{flex-direction:column;gap:2rem}.gallery-grid{grid-template-columns:1fr}}.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;height:70px;background:var(--bg-darker);border-bottom:1px solid var(--border);padding:0 1rem;align-items:center;justify-content:space-between;gap:1rem;z-index:100}@media(max-width:768px){.mobile-nav{display:flex}}.mobile-nav-buttons{display:flex;gap:.5rem;flex:1}.mobile-nav-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.mobile-nav-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.mobile-nav-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.mobile-menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-primary);cursor:pointer;transition:all .2s}.mobile-menu-toggle:hover{background:var(--surface-hover);border-color:var(--accent-blue)}.mobile-menu-overlay{position:fixed;inset:0;background:#00000080;z-index:200;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{position:fixed;top:70px;right:0;width:280px;max-width:90vw;background:var(--bg-darker);border-left:1px solid var(--border);border-bottom:1px solid var(--border);border-radius:0 0 0 20px;padding:1rem;z-index:201;animation:slideIn .3s}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.mobile-menu-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--surface);border-radius:10px;margin-bottom:.5rem}.mobile-menu-email{font-size:.9rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-divider{height:1px;background:var(--border);margin:.5rem 0}.mobile-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:transparent;border:none;border-radius:10px;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.mobile-menu-item:hover{background:var(--surface);color:var(--text-primary)}.mobile-menu-item.logout{color:#ef4444}.mobile-menu-item.logout:hover{background:#ef44441a}.character-source-selector{margin-bottom:2rem}.character-source-selector label{display:block;font-weight:600;margin-bottom:1rem;font-size:.95rem}.source-tabs{display:flex;gap:.75rem;padding:.5rem;background:var(--bg-darker);border-radius:12px}.source-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:transparent;border:1px solid transparent;border-radius:8px;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.source-tab:hover{background:#ffffff0d;color:var(--text-primary)}.source-tab.active{background:var(--gradient-1);color:#fff;border-color:var(--accent-blue);box-shadow:0 4px 12px #3b82f64d}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;background:var(--bg-darker);border-radius:12px;color:var(--text-secondary);text-align:center;gap:1rem}.empty-state svg{opacity:.5}.empty-state p{margin:0}.upload-option{position:relative;background:var(--bg-darker);display:flex;align-items:center;justify-content:center}.upload-character-label{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;color:var(--text-secondary);font-size:.75rem}.upload-character-label img{width:100%;height:100%;object-fit:cover}.cancel-subscription-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.cancel-subscription-btn:hover:not(:disabled){background:#ef444433;border-color:#ef444480}.cancel-subscription-btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.icon-btn:hover{background:var(--bg-darker);color:var(--text-primary);border-color:var(--accent-blue)}.edit-form{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}.form-section h4{font-size:1.1rem;margin-bottom:1rem;color:var(--text-primary)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.9rem;font-weight:500;color:var(--text-secondary)}.form-input{width:100%;padding:.75rem 1rem;background:var(--bg-darker);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.95rem;transition:all .2s}.form-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.form-actions{display:flex;gap:.75rem;margin-top:1.5rem}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:var(--gradient-1);border:none;border-radius:8px;color:#fff;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:var(--surface);color:var(--text-primary);border-color:var(--text-secondary)}.btn-outline{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-outline:hover:not(:disabled){background:var(--surface);border-color:var(--accent-blue);color:var(--accent-blue)}.btn-outline:disabled{opacity:.5;cursor:not-allowed}
