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{position:relative;margin-bottom:4rem;overflow:hidden;min-height:100vh}.hero-background-video{position:fixed;top:0;left:0;width:100vw;height:100vh;object-fit:cover;z-index:-1;opacity:.4}.hero-background-desktop{display:block}.hero-background-mobile{display:none}@media(max-width:768px){.hero-background-desktop{display:none}.hero-background-mobile{display:block}}.hero-content{position:relative;text-align:center;max-width:900px;margin:0 auto;padding:3rem 1rem;z-index:1;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.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-logo{display:flex;justify-content:center;margin-bottom:2rem;animation:fadeInScale .8s ease-out}.hero-logo img{height:80px;width:auto;filter:drop-shadow(0 4px 20px rgba(255,255,255,.1))}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.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;display:flex;flex-direction:column}.gallery-item:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000004d}.gallery-image{position:relative;aspect-ratio:1;overflow:hidden;border-radius:20px 20px 0 0}.image-placeholder{width:100%;height:100%;background:var(--bg-darker)}.placeholder-gradient{width:100%;height:100%;background:var(--gradient-3);opacity:.3}.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 1.25rem 1rem;flex:1}.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}.gallery-actions{display:flex;gap:.5rem;padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border)}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.action-btn:hover{background:var(--surface-hover);border-color:var(--accent-blue);color:var(--accent-blue)}.action-btn.delete{color:var(--text-secondary)}.action-btn.delete:hover{background:#ef44441a;border-color:#ef4444;color:#ef4444}.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}.google-button{width:100%;padding:1rem;background:#fff;border:1px solid #dadce0;border-radius:12px;color:#3c4043;font-size:1rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1rem}.google-button:hover{background:#f8f9fa;box-shadow:0 1px 3px #0000001f}.google-button:disabled{opacity:.6;cursor:not-allowed}.auth-divider{position:relative;text-align:center;margin:1.5rem 0;color:var(--text-secondary);font-size:.875rem}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border);z-index:0}.auth-divider span{position:relative;padding:0 1rem;background:var(--surface);z-index:1}.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;cursor:pointer}.video-play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .3s;pointer-events:none}.video-thumbnail:hover .video-play-overlay{opacity:1}.play-button{width:80px;height:80px;background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transform:scale(1);transition:all .3s}.video-thumbnail:hover .play-button{transform:scale(1.1);background:#000000d9}.modal-overlay,.video-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s}.video-modal{background:var(--bg-darker);border:1px solid var(--border);border-radius:20px;max-width:90vw;max-height:90vh;width:1000px;display:flex;flex-direction:column;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.video-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.video-modal-header h3{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.modal-close-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.modal-close-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--text-secondary)}.video-modal-body{padding:1.5rem;flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.modal-video{width:100%;height:auto;max-height:calc(90vh - 200px);border-radius:12px;background:var(--bg-dark)}.video-modal-footer{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid var(--border)}@media(max-width:768px){.video-modal{max-width:95vw;max-height:95vh}.video-modal-header h3{font-size:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-video{max-height:calc(95vh - 200px)}}.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}.credit-display{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--surface);border-radius:12px;margin-bottom:1rem;border:1px solid var(--border);transition:all .3s ease}.credit-display.credit-normal{background:#22c55e1a;border-color:#22c55e4d}.credit-display.credit-low{background:#ffc1071a;border-color:#ffc1074d}.credit-display.credit-critical{background:#fb923c1a;border-color:#fb923c4d}.credit-display.credit-depleted{background:#ef44441a;border-color:#ef44444d}.credit-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--gradient-1);border-radius:10px}.credit-info{flex:1}.credit-label{font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.credit-amount{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.credit-warning-icon{color:#fb923c}.credit-display.credit-depleted .credit-warning-icon{color:#ef4444}.credit-display-compact{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--surface);border-radius:8px;font-size:.9rem;font-weight:600}.warning-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.5rem;margin-bottom:2rem;border-radius:12px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.warning-banner.warning-low{background:#ffc1071a;border:1px solid rgba(255,193,7,.3)}.warning-banner.warning-critical{background:#fb923c1a;border:1px solid rgba(251,146,60,.3)}.warning-banner.warning-depleted{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.warning-content{display:flex;align-items:center;gap:.75rem;font-weight:500;flex:1}.warning-banner.warning-low .warning-content{color:#ffc107}.warning-banner.warning-critical .warning-content{color:#fb923c}.warning-banner.warning-depleted .warning-content{color:#ef4444}.warning-upgrade-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--gradient-1);border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.warning-upgrade-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.tutorial-modal{background:var(--bg-darker);border:1px solid var(--border);border-radius:20px;max-width:90vw;max-height:90vh;width:1200px;display:flex;flex-direction:column;animation:slideUp .3s}.modal-content{background:var(--bg-darker);border:1px solid var(--border);border-radius:20px;max-width:90vw;max-height:90vh;animation:slideUp .3s}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.5rem;font-weight:600;margin:0;color:var(--text-primary)}.close-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.close-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--text-secondary)}.tutorial-video-container{padding:1.5rem;width:100%;aspect-ratio:16 / 9;max-height:calc(90vh - 100px);min-height:400px;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.warning-banner{flex-direction:column;align-items:stretch;gap:.75rem}.warning-upgrade-btn{width:100%;justify-content:center}.tutorial-modal{width:95vw}.tutorial-video-container{padding:1rem}}.avatar-card{display:flex;gap:1rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:all .2s}.avatar-card:hover{background:var(--surface-hover);border-color:var(--accent-blue)}.avatar-image-container{flex-shrink:0}.avatar-thumbnail{width:80px;height:80px;object-fit:cover;border-radius:10px}.avatar-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.avatar-info h3{font-size:1rem;font-weight:600;margin:0}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:100px;font-size:.75rem;font-weight:500;width:fit-content}.status-ready{background:#22c55e1a;color:#22c55e}.status-creating{background:#fbbf241a;color:#fbbf24}.status-failed{background:#ef44441a;color:#ef4444}.copy-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--accent-blue);border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;width:fit-content}.copy-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3b82f666}.avatar-list{display:flex;flex-direction:column;gap:1rem}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.75rem;margin-top:1rem}.character-option{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.character-option:hover{border-color:var(--border);transform:scale(1.05)}.character-option.selected{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f633}.character-image{width:100%;height:100%;object-fit:cover}.upload-area-container{margin-top:1rem;display:flex;flex-direction:column;gap:1rem}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;border:2px dashed var(--border);border-radius:12px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.upload-area:hover{border-color:var(--accent-blue);background:var(--surface)}.upload-text{display:flex;flex-direction:column;align-items:center;gap:.25rem}.upload-title{font-weight:500;color:var(--text-primary)}.upload-subtitle{font-size:.875rem;color:var(--text-secondary)}.uploaded-preview{width:120px;height:120px;border-radius:12px;overflow:hidden;border:3px solid var(--accent-blue);box-shadow:0 0 0 3px #3b82f633}.preview-image{width:100%;height:100%;object-fit:cover}.hidden-input{display:none}.avatar-card-item{padding:0;overflow:hidden;display:flex;flex-direction:column;transition:all .3s}.avatar-card-item:hover{transform:translateY(-4px);box-shadow:0 10px 30px #0000004d}.avatar-card-item .avatar-image-container{width:100%;aspect-ratio:1;overflow:hidden;flex-shrink:0}.avatar-card-item .avatar-thumbnail{width:100%;height:100%;object-fit:cover}.avatar-card-item .avatar-info{padding:1.25rem;flex:1;display:flex;flex-direction:column;gap:.75rem;background:var(--surface)}.avatar-card-item .avatar-info h3{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.avatar-card-item .copy-button{margin-top:auto}
