*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #8c2bee;--primary-dark: #7a1fd6;--primary-light: rgba(140, 43, 238, .1);--primary-glow: rgba(140, 43, 238, .3);--secondary: #00D2D3;--accent: #FF6B6B;--bg-dark: #191022;--bg-card: rgba(140, 43, 238, .05);--bg-card-solid: #1f1530;--bg-input: rgba(140, 43, 238, .1);--bg-surface: rgba(140, 43, 238, .1);--text-primary: #f1f0f3;--text-secondary: #94a3b8;--text-muted: #64748b;--kakao: #FEE500;--instagram: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);--success: #00b894;--border-color: rgba(140, 43, 238, .1);--border-radius: 1rem;--border-radius-lg: 2rem;--border-radius-full: 9999px;--shadow: 0 4px 20px rgba(0, 0, 0, .3);--shadow-primary: 0 0 40px -10px rgba(140, 43, 238, .3)}body{font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;line-height:1.6}#root{width:100%;max-width:480px;margin:0 auto;min-height:100vh}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-smoothing:antialiased}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.app{min-height:100vh;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{to{opacity:0}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.app-header{position:sticky;top:0;z-index:50;background:#191022cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color);padding:12px 16px;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:8px}.header-logo{background:var(--primary);padding:6px;border-radius:10px;display:flex;align-items:center;justify-content:center}.header-logo .material-symbols-outlined{color:#fff;font-size:24px}.header-title{font-size:20px;font-weight:700;letter-spacing:-.5px;color:var(--primary)}.header-actions{display:flex;gap:12px}.header-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-full);background:var(--bg-surface);border:none;color:var(--primary);cursor:pointer;transition:background .2s}.header-btn:hover{background:#8c2bee33}.header-pro-btn{height:32px;padding:0 14px;border-radius:var(--border-radius-full);background:linear-gradient(135deg,#8c2bee,#5b21b6);border:none;color:#fff;font-size:13px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:opacity .2s}.header-pro-btn:hover{opacity:.85}.header-pro-btn:disabled{opacity:.5;cursor:not-allowed}.header-text-btn{height:32px;padding:0 12px;border-radius:var(--border-radius-full);background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.header-text-btn:hover{background:#ffffff0d;color:var(--text-primary)}.header-user-email{font-size:12px;color:var(--text-secondary);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:8px}.screen-home{display:flex;flex-direction:column;min-height:100vh}.home-main{flex:1;padding-bottom:0}.lp-hero{padding:48px 20px 32px;text-align:center;position:relative}.lp-hero-badge{display:inline-block;background:#8c2bee26;border:1px solid rgba(140,43,238,.3);border-radius:9999px;padding:5px 16px;font-size:12px;font-weight:700;color:var(--primary);letter-spacing:.5px;margin-bottom:20px}.lp-hero-title{font-size:32px;font-weight:800;line-height:1.15;letter-spacing:-.5px;color:#f1f0f3;margin-bottom:14px}.lp-hero-gradient{background:linear-gradient(135deg,#8c2bee,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lp-hero-subtitle{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:28px;max-width:320px;margin-left:auto;margin-right:auto}.lp-hero-cta{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:#fff;border:none;padding:16px 32px;border-radius:9999px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;box-shadow:0 8px 32px #8c2bee59;transition:all .2s}.lp-hero-cta:hover{transform:translateY(-2px);box-shadow:0 12px 40px #8c2bee73}.lp-hero-cta .material-symbols-outlined{font-size:20px}.lp-demo-note{margin-top:12px;font-size:11px;color:var(--text-muted)}.lp-upload-section{padding:0 20px 8px}.lp-dropzone{border:2px dashed rgba(140,43,238,.3);border-radius:16px;padding:36px 20px;text-align:center;cursor:pointer;transition:all .3s;background:#8c2bee0a}.lp-dropzone:hover{border-color:var(--primary);background:#8c2bee14}.lp-dropzone.dragging{border-color:var(--primary);background:#8c2bee1f;transform:scale(1.01)}.lp-dropzone-icon{width:52px;height:52px;background:#8c2bee26;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.lp-dropzone-icon .material-symbols-outlined{font-size:26px;color:var(--primary)}.lp-dropzone-text{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.lp-dropzone-sub{font-size:13px;color:var(--text-muted);margin-bottom:8px}.lp-browse{color:var(--primary);font-weight:600}.lp-dropzone-formats{font-size:11px;color:var(--text-muted);opacity:.7}.lp-how{padding:40px 20px}.lp-section-title{font-size:20px;font-weight:800;color:var(--text-primary);margin-bottom:24px;text-align:center}.lp-steps{display:flex;align-items:flex-start;gap:8px}.lp-step{flex:1;text-align:center;position:relative}.lp-step-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--primary);border-radius:50%;font-size:11px;font-weight:700;color:#fff;margin-bottom:8px}.lp-step-icon{font-size:28px;margin-bottom:8px;line-height:1}.lp-step h3{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.lp-step p{font-size:11px;color:var(--text-muted);line-height:1.5}.lp-step-arrow{font-size:18px;color:var(--primary);opacity:.4;margin-top:32px;flex-shrink:0}.lp-templates{padding:0 20px 40px}.lp-templates-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.lp-templates-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.lp-template-card{border-radius:14px;overflow:hidden;background:var(--bg-card);border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.lp-template-card:hover{border-color:#8c2bee66;transform:translateY(-2px)}.lp-template-bg{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;transition:transform .3s}.lp-template-card:hover .lp-template-bg{transform:scale(1.04)}.lp-template-emoji{font-size:44px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.lp-template-info{padding:10px 12px;display:flex;align-items:center;justify-content:space-between}.lp-template-name{font-size:12px;font-weight:600;color:var(--text-primary)}.lp-template-use{font-size:11px;color:var(--primary);font-weight:700}.lp-features{padding:0 20px 40px}.lp-features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.lp-feature{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:18px 16px;transition:border-color .2s}.lp-feature:hover{border-color:#8c2bee4d}.lp-feature-icon{font-size:24px;display:block;margin-bottom:10px;line-height:1}.lp-feature h3{font-size:13px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.lp-feature p{font-size:11px;color:var(--text-muted);line-height:1.5}.api-warning{background:#ff6b6b26;border:1px solid rgba(255,107,107,.3);border-radius:var(--border-radius);padding:14px 16px;margin:8px 16px 0;font-size:13px;color:var(--accent)}.demo-badge{background:var(--bg-surface);border:1px solid rgba(140,43,238,.2);border-radius:var(--border-radius);padding:10px 16px;margin:8px 16px 0;font-size:13px;font-weight:600;text-align:center;color:var(--primary)}.search-container{padding:20px 16px 16px}.search-bar{position:relative}.search-icon{position:absolute;top:50%;left:16px;transform:translateY(-50%);color:var(--text-muted);font-size:22px;pointer-events:none}.search-input{width:100%;background:var(--bg-surface);border:2px solid transparent;border-radius:var(--border-radius-full);padding:14px 16px 14px 48px;font-size:15px;color:var(--text-primary);outline:none;transition:all .2s;font-family:inherit}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:#8c2bee80;box-shadow:0 0 0 3px #8c2bee1a}.category-chips{display:flex;gap:12px;padding:0 16px 8px;overflow-x:auto}.category-chip{flex-shrink:0;padding:8px 20px;border-radius:var(--border-radius-full);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all .2s;background:var(--bg-surface);color:var(--text-secondary);font-family:inherit}.category-chip.active{background:var(--primary);color:#fff;font-weight:600}.category-chip:hover:not(.active){background:#8c2bee33}.hero-upload{padding:16px}.hero-upload-area{position:relative;overflow:hidden;border-radius:var(--border-radius);background:linear-gradient(135deg,#8c2bee33,#8c2bee0d);border:2px dashed rgba(140,43,238,.3);padding:40px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:16px;cursor:pointer;transition:all .3s}.hero-upload-area:hover{border-color:var(--primary)}.hero-upload-area.dragging{border-color:var(--primary);background:#8c2bee26;transform:scale(1.01)}.hero-icon{width:64px;height:64px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #8c2bee4d;transition:transform .3s}.hero-upload-area:hover .hero-icon{transform:scale(1.1)}.hero-icon .material-symbols-outlined{font-size:32px}.hero-text h2{font-size:20px;font-weight:700;margin-bottom:4px}.hero-text p{font-size:13px;color:var(--text-secondary)}.hero-upload-btn{margin-top:8px;background:var(--primary);color:#fff;border:none;font-weight:700;padding:10px 32px;border-radius:var(--border-radius-full);font-size:14px;cursor:pointer;box-shadow:0 4px 16px #8c2bee4d;transition:all .2s;font-family:inherit}.hero-upload-btn:hover{opacity:.9;transform:translateY(-1px)}.upload-policy-note{margin-top:8px;font-size:11px;color:var(--text-secondary);opacity:.7;text-align:center}.upload-policy-note a{color:var(--primary);text-decoration:underline}.home-footer{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 16px 96px;flex-wrap:wrap}.home-footer a{font-size:13px;color:var(--text-muted);text-decoration:none;transition:color .2s}.home-footer a:hover{color:var(--primary)}.footer-dot{font-size:13px;color:var(--text-muted);opacity:.4}.templates-section{padding:0 16px;margin-top:16px}.templates-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.templates-header h3{font-size:17px;font-weight:700}.see-all-btn{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit}.templates-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.template-card{position:relative;border-radius:var(--border-radius);overflow:hidden;aspect-ratio:1;background:var(--bg-card);cursor:pointer}.template-card img{width:100%;height:100%;object-fit:cover;transition:transform .5s}.template-card:hover img{transform:scale(1.1)}.template-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .5s}.template-card:hover .template-placeholder{transform:scale(1.05)}.template-emoji{font-size:48px;line-height:1;filter:drop-shadow(0 2px 8px rgba(0,0,0,.3))}.template-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent,transparent);opacity:0;transition:opacity .3s;display:flex;flex-direction:column;justify-content:flex-end;padding:12px}.template-card:hover .template-overlay{opacity:1}.template-overlay p{color:#fff;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px}.template-fav{position:absolute;top:8px;right:8px;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--border-radius-full);padding:6px;color:#fff;display:flex;align-items:center;justify-content:center}.template-fav .material-symbols-outlined{font-size:16px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:#191022f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);padding:8px 24px 24px;display:flex;align-items:center;justify-content:space-between;z-index:50}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-muted);text-decoration:none;transition:color .2s}.nav-item.active,.nav-item:hover{color:var(--primary)}.nav-item .material-symbols-outlined{font-size:28px}.nav-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:-.5px}.nav-create{position:relative;top:-32px}.nav-create-btn{width:56px;height:56px;background:var(--primary);color:#fff;border:4px solid var(--bg-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 16px #8c2bee66;transition:transform .2s}.nav-create-btn:hover{transform:scale(1.05)}.nav-create-btn .material-symbols-outlined{font-size:28px}.screen-editor{display:flex;flex-direction:column;min-height:100vh}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:sticky;top:0;z-index:10;background:#191022cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-color)}.editor-back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-full);background:none;border:none;color:var(--text-primary);cursor:pointer;transition:background .2s}.editor-back-btn:hover{background:var(--bg-surface)}.editor-title{font-size:17px;font-weight:700;letter-spacing:-.3px}.editor-reset-btn{background:none;border:none;color:var(--primary);font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;padding:8px 12px;border-radius:var(--border-radius-full);transition:background .2s}.editor-reset-btn:hover{background:var(--bg-surface)}.editor-main{flex:1;padding:16px 16px 100px;display:flex;flex-direction:column;gap:24px}.editor-canvas{position:relative;width:100%;aspect-ratio:1;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 8px 32px #8c2bee26;background:#1e1e2e}.canvas-image{position:absolute;inset:0;background-size:cover;background-position:center}.canvas-text-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:24px;pointer-events:none}.canvas-text{text-align:center;word-break:break-word;text-shadow:2px 2px 0 rgba(0,0,0,.8),-2px -2px 0 rgba(0,0,0,.8),2px -2px 0 rgba(0,0,0,.8),-2px 2px 0 rgba(0,0,0,.8);line-height:1.2;margin:0}.editor-controls{display:flex;flex-direction:column;gap:24px}.text-inputs{display:flex;flex-direction:column;gap:16px}.input-group label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:8px;margin-left:16px}.text-input{width:100%;background:var(--bg-card);border:2px solid rgba(140,43,238,.2);border-radius:var(--border-radius-full);padding:14px 24px;font-size:15px;color:var(--text-primary);outline:none;transition:all .2s;font-family:inherit}.text-input::placeholder{color:var(--text-muted)}.text-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8c2bee26}.styling-toolbar{background:var(--bg-surface);border-radius:var(--border-radius);padding:24px;border:1px solid var(--border-color);display:flex;flex-direction:column;gap:24px}.font-controls{display:flex;align-items:center;justify-content:space-between;gap:16px}.format-buttons{display:flex;background:var(--bg-dark);padding:4px;border-radius:var(--border-radius-full);border:1px solid rgba(140,43,238,.2)}.format-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-full);background:none;border:none;color:var(--text-muted);cursor:pointer;transition:all .2s}.format-btn .material-symbols-outlined{font-size:20px}.format-btn.active{background:var(--primary);color:#fff}.format-btn:hover:not(.active){background:#8c2bee1a}.font-size-control{flex:1;display:flex;align-items:center;gap:12px;padding-left:16px}.size-icon{color:var(--text-secondary);font-size:20px}.size-slider{width:100%;height:6px;background:#8c2bee33;border-radius:10px;-webkit-appearance:none;appearance:none;cursor:pointer;outline:none}.size-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #8c2bee66}.color-section label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:12px}.color-swatches{display:flex;align-items:center;gap:12px;overflow-x:auto;padding-bottom:4px}.color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.1);cursor:pointer;flex-shrink:0;transition:all .2s;padding:0}.color-swatch.active{border-color:var(--primary);box-shadow:0 0 0 3px #8c2bee33}.color-custom{background:linear-gradient(135deg,var(--primary),#ec4899)!important;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.color-custom .material-symbols-outlined{font-size:14px;color:#fff}.color-custom input[type=color]{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer}.template-select-section label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:12px}.template-chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.template-chip{flex-shrink:0;padding:8px 16px;background:var(--bg-dark);border:1px solid transparent;border-radius:var(--border-radius-full);font-size:13px;color:var(--text-primary);cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:4px;font-family:inherit}.template-chip:hover{background:#8c2bee26}.template-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.chip-icon{font-size:14px}.editor-footer{position:fixed;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:#191022e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));display:flex;gap:12px;z-index:20}.generate-btn{flex:1;background:var(--primary);color:#fff;border:none;font-weight:700;padding:16px;border-radius:var(--border-radius-full);font-size:15px;cursor:pointer;box-shadow:0 4px 16px #8c2bee33;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;font-family:inherit}.generate-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.generate-btn:active:not(:disabled){transform:scale(.98)}.generate-btn:disabled{opacity:.5;cursor:not-allowed}.share-quick-btn{width:56px;height:56px;border-radius:var(--border-radius-full);background:var(--bg-surface);border:none;color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.share-quick-btn:hover{background:#8c2bee33}.screen-loading{display:flex;flex-direction:column;min-height:100vh}.loading-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.loading-spinner{width:60px;height:60px;border:4px solid var(--bg-card-solid);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:24px}.loading-text{font-size:16px;color:var(--text-primary);font-weight:600}.loading-text span{display:block;margin-top:8px;font-size:13px;color:var(--text-secondary);font-weight:400}.loading-sub{display:block;margin-top:8px;font-size:12px;color:var(--text-muted);opacity:.7}.screen-error{display:flex;flex-direction:column;min-height:100vh}.error-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.error-icon{margin-bottom:16px}.error-icon .material-symbols-outlined{font-size:64px;color:var(--accent)}.error-container h3{font-size:20px;margin-bottom:12px;color:var(--accent)}.error-container p{color:var(--text-secondary);font-size:14px;margin-bottom:24px;line-height:1.6}.error-retry-btn{background:var(--primary);color:#fff;border:none;padding:14px 32px;border-radius:var(--border-radius-full);font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;font-family:inherit;transition:all .2s}.error-retry-btn:hover{opacity:.9}.screen-result{display:flex;flex-direction:column;min-height:100vh}.result-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;position:sticky;top:0;z-index:50;background:#191022cc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.result-main{flex:1;padding:0 16px 100px;animation:fadeIn .5s ease}.success-toast{display:flex;align-items:center;justify-content:center;gap:8px;background:#8c2bee1a;border:1px solid rgba(140,43,238,.2);padding:8px 16px;border-radius:var(--border-radius-full);margin:8px auto 24px;width:fit-content}.success-toast .material-symbols-outlined{font-size:16px;color:var(--primary)}.success-toast span:last-child{font-size:12px;font-weight:500;color:var(--primary)}.demo-notice{background:#8c2bee1a;border:1px solid rgba(140,43,238,.2);border-radius:var(--border-radius);padding:12px 16px;margin-bottom:16px;font-size:13px;text-align:center;color:var(--text-secondary)}.result-preview-container{position:relative;margin-bottom:16px}.result-meme-preview{border-radius:var(--border-radius);overflow:hidden;aspect-ratio:1;background:#1e1e2e;box-shadow:var(--shadow-primary);border:4px solid rgba(140,43,238,.15);cursor:pointer;transition:transform .2s}.result-meme-preview:hover{transform:scale(1.01)}.result-meme-preview img{width:100%;height:100%;object-fit:cover}.result-badge{position:absolute;bottom:-12px;right:-12px;background:var(--primary);color:#fff;padding:12px;border-radius:50%;box-shadow:0 4px 16px #8c2bee66}.more-memes{margin-bottom:24px}.more-memes-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;margin-bottom:12px}.more-memes-title .material-symbols-outlined{font-size:20px;color:var(--primary)}.more-memes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.more-meme-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s}.more-meme-item:hover{transform:scale(1.03)}.more-meme-item img{width:100%;height:100%;object-fit:cover}.more-meme-item.is-gif{border:2px solid rgba(0,210,211,.3)}.gif-badge{position:absolute;top:6px;left:6px;background:#000000b3;color:var(--secondary);font-size:10px;font-weight:800;padding:3px 6px;border-radius:4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);text-transform:uppercase;letter-spacing:.5px;z-index:2}.meme-download-btn{position:absolute;bottom:6px;right:6px;width:32px;height:32px;background:#0009;border:none;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transition:opacity .2s}.more-meme-item:hover .meme-download-btn{opacity:1}.meme-download-btn .material-symbols-outlined{font-size:18px}.result-actions{display:flex;flex-direction:column;gap:12px;margin:24px 0}.action-download{width:100%;background:var(--primary);color:#fff;border:none;font-weight:700;padding:18px;border-radius:var(--border-radius-full);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 20px #8c2bee40;transition:all .2s;font-family:inherit}.action-download:hover{opacity:.9;transform:translateY(-1px)}.action-download:active{transform:scale(.95)}.action-create{width:100%;background:transparent;color:var(--text-primary);border:2px solid rgba(148,163,184,.3);font-weight:700;padding:18px;border-radius:var(--border-radius-full);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s;font-family:inherit}.action-create:hover{background:var(--bg-surface);border-color:var(--primary)}.action-create:active{transform:scale(.95)}.action-email{width:100%;background:transparent;color:var(--text-secondary);border:2px solid rgba(148,163,184,.2);font-weight:600;padding:16px;border-radius:var(--border-radius-full);font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .2s;font-family:inherit}.action-email:hover{border-color:var(--primary);color:var(--primary)}.email-form{display:flex;flex-direction:column;gap:10px}.email-input{width:100%;background:var(--bg-card);border:2px solid rgba(140,43,238,.3);border-radius:var(--border-radius-full);padding:14px 20px;font-size:15px;color:var(--text-primary);outline:none;transition:border-color .2s;font-family:inherit}.email-input::placeholder{color:var(--text-muted)}.email-input:focus{border-color:var(--primary)}.email-form-actions{display:flex;gap:10px}.email-send-btn{flex:1;background:var(--primary);color:#fff;border:none;padding:14px;border-radius:var(--border-radius-full);font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .2s}.email-send-btn:disabled{opacity:.6;cursor:not-allowed}.email-cancel-btn{background:transparent;color:var(--text-muted);border:2px solid rgba(148,163,184,.2);padding:14px 20px;border-radius:var(--border-radius-full);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.email-cancel-btn:hover{border-color:var(--text-muted)}.result-captions{margin-bottom:24px}.captions-title{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:700;margin-bottom:12px}.captions-title .material-symbols-outlined{font-size:20px;color:var(--primary)}.captions-list{display:flex;flex-direction:column;gap:8px}.caption-item{display:flex;align-items:center;gap:12px;background:var(--bg-card);padding:14px 16px;border-radius:12px;cursor:pointer;transition:all .2s;border:1px solid transparent}.caption-item:hover{background:var(--bg-surface)}.caption-item:active{transform:scale(.98)}.caption-item.copied{background:#00b8941a;border-color:var(--success)}.caption-number{width:28px;height:28px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;color:#fff}.caption-text{flex:1;font-size:13px;line-height:1.5}.copy-icon{color:var(--text-muted);flex-shrink:0;display:flex;align-items:center}.copy-icon .material-symbols-outlined{font-size:18px}.caption-item.copied .copy-icon{color:var(--success)}.share-section{margin-bottom:24px}.share-title{text-align:center;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:20px}.share-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.share-item{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}.share-icon-btn{width:56px;height:56px;border-radius:50%;background:var(--bg-card-solid);border:none;display:flex;align-items:center;justify-content:center;color:var(--text-primary);cursor:pointer;transition:all .2s}.share-icon-btn:hover{background:#8c2bee33;color:var(--primary)}.share-label{font-size:11px;font-weight:500;opacity:.7}.trend-card{padding:20px;border-radius:var(--border-radius);background:var(--bg-card-solid);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.trend-card-left{display:flex;align-items:center;gap:14px}.trend-icon-wrap{width:40px;height:40px;border-radius:50%;background:#8c2bee33;display:flex;align-items:center;justify-content:center;color:var(--primary)}.trend-icon-wrap .material-symbols-outlined{font-size:22px}.trend-title{font-size:14px;font-weight:700}.trend-desc{font-size:11px;color:var(--text-muted)}.trend-score{color:var(--primary);font-weight:700;font-size:14px}.result-nav{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.result-nav .nav-item{flex:1;text-align:center}.modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;animation:fadeIn .3s ease}.modal-content{max-width:100%;max-height:80vh;border-radius:var(--border-radius);overflow:hidden;position:relative}.modal-content img{max-width:100%;max-height:80vh;object-fit:contain}.modal-close{position:absolute;top:12px;right:12px;width:40px;height:40px;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.modal-actions{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:12px}.modal-action-btn{padding:12px 24px;background:var(--primary);border:none;border-radius:var(--border-radius-full);color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;font-family:inherit}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:12px 24px;border-radius:var(--border-radius-full);font-size:13px;font-weight:600;animation:slideUp .3s ease,fadeOut .3s ease 2s forwards;z-index:300;white-space:nowrap;box-shadow:0 4px 20px #8c2bee4d}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh}.screen-auth{display:flex;flex-direction:column;min-height:100vh}.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:24px 16px}.auth-card{width:100%;max-width:400px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:32px 24px;animation:fadeIn .4s ease}.auth-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#8c2bee,#5b21b6);display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.auth-icon .material-symbols-outlined{font-size:28px;color:#fff}.auth-title{font-size:22px;font-weight:700;text-align:center;margin-bottom:4px}.auth-subtitle{font-size:14px;color:var(--text-secondary);text-align:center;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-input-group{display:flex;flex-direction:column;gap:6px}.auth-input-group label{font-size:13px;font-weight:600;color:var(--text-secondary)}.auth-input{width:100%;height:44px;padding:0 14px;border-radius:var(--border-radius);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s;box-sizing:border-box}.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #8c2bee26}.auth-input::placeholder{color:var(--text-tertiary)}.auth-submit-btn{width:100%;height:44px;border-radius:var(--border-radius);background:linear-gradient(135deg,#8c2bee,#5b21b6);border:none;color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:opacity .2s;margin-top:4px}.auth-submit-btn:hover{opacity:.9}.auth-submit-btn:disabled{opacity:.5;cursor:not-allowed}.auth-google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;border-radius:var(--border-radius);border:1px solid var(--border-color);background:#ffffff0d;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.auth-google-btn:hover{background:#ffffff1a}.auth-divider{display:flex;align-items:center;gap:12px;margin:4px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{font-size:12px;color:var(--text-tertiary);text-transform:uppercase}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--border-radius);color:#f87171;padding:10px 14px;font-size:13px;text-align:center}.auth-switch{text-align:center;font-size:13px;color:var(--text-secondary);margin-top:20px}.auth-switch button{background:none;border:none;color:var(--primary);font-weight:600;cursor:pointer;font-size:13px;text-decoration:underline}.auth-switch button:hover{opacity:.8}.auth-success{text-align:center;padding:16px 0}.auth-success .material-symbols-outlined{font-size:48px;color:#22c55e;margin-bottom:12px}.auth-success h3{font-size:18px;font-weight:700;margin-bottom:8px}.auth-success p{font-size:14px;color:var(--text-secondary);line-height:1.5;margin-bottom:20px}.auth-success strong{color:var(--text-primary)}
