:root{--primary-50: #F5F8FF;--primary-100: #EAF1FF;--primary-200: #ACC5FF;--primary-300: #63AFFF;--primary-400: #4788FF;--primary-500: #3079FF;--primary-600: #0661CC;--primary-700: #1265B6;--primary-800: #183D80;--primary-900: #133066;--gray-50: #F4F4F4;--gray-100: #E8E8E8;--gray-200: #D1D1D1;--gray-300: #B8BEC4;--gray-400: #9DA4AB;--gray-500: #8A9099;--gray-600: #717981;--gray-700: #596067;--gray-800: #434A52;--gray-900: #34404B;--green-50: #ECFDF5;--green-100: #D5FCE9;--green-200: #A8F5CF;--green-500: #22C55E;--green-700: #1B9758;--green-800: #10B75A;--green-900: #006537;--yellow-50: #FFFBE8;--yellow-500: #FFB840;--yellow-600: #E08F28;--red-50: #FEF5F5;--red-500: #EF4444;--red-600: #DC2626;--text-display-xl: 40px;--text-display-lg: 35px;--text-display-md: 32px;--text-display-sm: 28px;--text-title-xl: 24px;--text-title-lg: 20px;--text-title-md: 18px;--text-body-lg: 16px;--text-body: 14px;--text-caption: 12px;--text-caption-sm: 10px;--font: "Roboto", -apple-system, BlinkMacSystemFont, sans-serif;--bg: var(--gray-50);--bg-card: #FFFFFF;--bg-input: #FFFFFF;--text-color: var(--gray-900);--text-sub: var(--gray-600);--text-disabled:var(--gray-400);--border: var(--gray-200);--border-focus: var(--primary-500);--text: var(--gray-900);--silver: var(--gray-600);--silver-dim: var(--gray-400);--blue: var(--primary-700);--blue-dark: var(--primary-800);--blue-light: var(--primary-50);--blue-mid: var(--primary-100);--blue-glow: rgba(18, 101, 182, .2);--blue-faint: rgba(18, 101, 182, .05);--glass-bg: #FFFFFF;--glass-border: var(--gray-200);--success: #16A34A;--error: #DC2626;--white: #FFFFFF;--gradient-blue: linear-gradient(45deg, #6896FF, #4B7FFF);--gradient-blue-light: linear-gradient(45deg, #309DFD, #85C0FF);--gradient-nav: linear-gradient(45deg, #181D27, #535862);--gradient-bg: linear-gradient(180deg, #FAFAFA, #FFFFFF);--gradient-sky: linear-gradient(180deg, #8BDFFF, #53A7FF);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 100px;--shadow-xs: 0 1px 3px rgba(52, 64, 75, .06);--shadow-sm: 0 1px 6px rgba(52, 64, 75, .08), 0 2px 12px rgba(52, 64, 75, .04);--shadow-card: 0 2px 16px rgba(52, 64, 75, .09);--shadow-blue: 0 4px 20px rgba(18, 101, 182, .18);--transition: all .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);font-size:var(--text-body);line-height:1.5;color:var(--text-color);background:var(--bg);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--gray-50)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:2px}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 20px}.glass-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;background:var(--gradient-blue-light);color:#fff;font-family:var(--font);font-size:var(--text-body-lg);font-weight:700;line-height:1;border:none;border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-decoration:none;white-space:nowrap;letter-spacing:.1px}.btn-primary:hover{filter:brightness(1.08);box-shadow:var(--shadow-blue);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0);filter:brightness(.96)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:none}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 24px;background:transparent;color:var(--primary-700);font-family:var(--font);font-size:var(--text-body);font-weight:500;border:1.5px solid var(--primary-700);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-decoration:none}.btn-outline:hover{background:var(--primary-50)}.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;color:var(--gray-600);font-family:var(--font);font-size:var(--text-body);font-weight:500;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;border-radius:var(--radius-sm)}.btn-ghost:hover{color:var(--primary-700);background:var(--primary-50)}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:56px;padding:0;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow-xs)}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.navbar-badge{padding:4px 12px;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-full);font-size:var(--text-caption);font-weight:700;color:var(--primary-700);letter-spacing:.3px}.generator{min-height:100vh;padding-top:56px;background:var(--bg)}.generator-inner{padding:32px 0 80px}.generator-header{text-align:center;margin-bottom:40px}.generator-title{font-size:var(--text-display-sm);font-weight:700;line-height:1.2;color:var(--gray-900);margin-bottom:8px}.generator-sub{font-size:var(--text-body-lg);font-weight:400;color:var(--gray-600);line-height:1.5}.main-tabs{display:flex;gap:4px;margin-bottom:28px;padding:4px;background:var(--gray-100);border:1px solid var(--border);border-radius:var(--radius-lg)}.main-tab{flex:1;padding:12px 20px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--gray-500);font-family:var(--font);font-size:var(--text-body);font-weight:500;cursor:pointer;transition:var(--transition);letter-spacing:0}.main-tab:hover{color:var(--primary-700);background:var(--primary-50)}.main-tab--active{background:var(--bg-card);color:var(--primary-700);font-weight:700;box-shadow:var(--shadow-xs)}.generator-layout{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}@media (max-width: 860px){.generator-layout{grid-template-columns:1fr}}.upload-zone{border:2px dashed var(--primary-300);border-radius:var(--radius-lg);padding:32px;flex:1;min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#1265b60a,#3079ff08);position:relative;overflow:hidden}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary-500);background:linear-gradient(135deg,#1265b617,#3079ff0f)}.upload-zone.has-file{border-color:var(--success);background:var(--green-50);border-style:solid}.upload-zone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.upload-icon{width:64px;height:64px;margin:0 auto 16px;background:linear-gradient(135deg,var(--primary-100) 0%,var(--primary-50) 100%);border:1.5px solid var(--primary-200);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--primary-500);transition:var(--transition)}.upload-zone:hover .upload-icon{background:linear-gradient(135deg,var(--primary-200) 0%,var(--primary-100) 100%);border-color:var(--primary-400)}.upload-title{font-size:var(--text-title-md);font-weight:700;margin-bottom:6px;color:var(--primary-700)}.upload-sub{font-size:var(--text-body);color:var(--gray-500)}.upload-hint{font-size:var(--text-caption);color:var(--gray-400);margin-top:12px}.upload-preview{position:relative;display:inline-block;margin-bottom:12px}.upload-preview img{width:100px;height:100px;border-radius:var(--radius-md);object-fit:cover;border:2px solid var(--success)}.upload-preview-remove{position:absolute;top:-6px;right:-6px;width:22px;height:22px;background:var(--error);border:none;border-radius:50%;color:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}.form-group{margin-bottom:20px}.form-label{display:block;font-size:var(--text-caption);font-weight:700;color:var(--gray-700);margin-bottom:6px;text-transform:uppercase;letter-spacing:.4px}.form-input{width:100%;padding:12px 14px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--gray-900);font-family:var(--font);font-size:var(--text-body-lg);transition:var(--transition);outline:none}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3079ff1f}.form-input:disabled{background:var(--gray-50);color:var(--gray-700);cursor:default;border-color:var(--border)}.form-input::placeholder{color:var(--gray-400)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23717981' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px;cursor:pointer}.form-year-hint{margin-top:4px;font-size:var(--text-caption);color:var(--primary-700);font-weight:600}.gender-options{display:grid;grid-template-columns:1fr 1fr;gap:10px}.gender-option{position:relative}.gender-option input[type=radio]{position:absolute;opacity:0;pointer-events:none}.gender-option label{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:var(--bg-input);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);font-size:var(--text-body);font-weight:500;color:var(--gray-600)}.gender-option input:checked+label{border-color:var(--primary-500);background:var(--primary-50);color:var(--primary-700);font-weight:700}.generate-btn{width:100%;padding:16px;font-size:var(--text-body-lg);font-weight:700;border-radius:var(--radius-md);box-shadow:0 4px 18px #1265b640}.step-indicator{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:56px 32px;gap:20px;text-align:center}.loading-ring{width:56px;height:56px;border:4px solid var(--primary-200);border-top-color:var(--primary-700);border-right-color:var(--primary-500);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-dots{display:flex;gap:6px}.loading-dot{width:8px;height:8px;background:var(--primary-500);border-radius:50%;animation:dotBounce 1.2s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loading-title{font-size:var(--text-title-md);font-weight:700;color:var(--gray-900)}.loading-step{font-size:var(--text-body);color:var(--gray-500)}.loading-progress{width:260px;height:3px;background:var(--primary-100);border-radius:2px;overflow:hidden}.loading-progress-bar{height:100%;background:var(--gradient-blue);border-radius:2px;transition:width .5s ease}.loading-center{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px 16px 32px;text-align:center}.loading-thumb-wrap{position:relative;width:88px;height:88px;flex-shrink:0}.loading-thumb{width:88px;height:88px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid #fff;box-shadow:0 4px 16px #3079ff40;display:block}.loading-thumb-ring{position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:50%;border:3px solid transparent;border-top-color:#3079ff;border-right-color:#3079ff;animation:spin 1s linear infinite}.result-image{width:100%;border-radius:var(--radius-lg);display:block}.share-row{display:flex;gap:8px}.share-btn{flex:1;padding:10px 14px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:var(--text-caption);font-weight:700;cursor:pointer;transition:var(--transition);color:#fff;display:flex;align-items:center;justify-content:center;gap:6px;text-decoration:none}.share-btn-fb{background:#1877f2}.share-btn-zalo{background:#0661cc}.share-btn:hover{opacity:.88}.download-panel{display:flex;flex-direction:column;gap:10px}.download-title{font-size:var(--text-caption);font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.download-btn{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);text-decoration:none;color:var(--gray-900)}.download-btn:hover{border-color:var(--primary-400);background:var(--primary-50);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.download-btn-icon{width:34px;height:34px;background:var(--gray-100);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.frame-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.frame-card{position:relative;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:12px;cursor:pointer;transition:var(--transition);text-align:left;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xs)}.frame-card:hover{border-color:var(--frame-accent, var(--primary-500));box-shadow:0 4px 16px var(--frame-glow, var(--blue-glow))}.frame-card--active{border-color:var(--frame-accent, var(--primary-500));background:var(--primary-50);box-shadow:0 0 0 1px var(--frame-accent, var(--primary-500)),0 4px 16px var(--frame-glow, var(--blue-glow))}.frame-preview{width:100%;aspect-ratio:1;border-radius:8px;overflow:hidden;position:relative}.frame-info{padding:2px 0}.frame-name{font-size:var(--text-caption);font-weight:700;color:var(--gray-900);margin-bottom:2px}.frame-desc{font-size:var(--text-caption-sm);color:var(--gray-500);line-height:1.4}.frame-check{position:absolute;top:8px;right:8px;width:20px;height:20px;background:var(--frame-accent, var(--primary-500));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;animation:popIn .15s ease}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fadeInUp .35s ease forwards}.animate-delay-1{animation-delay:.08s;opacity:0}.animate-delay-2{animation-delay:.16s;opacity:0}.animate-delay-3{animation-delay:.24s;opacity:0}.animate-delay-4{animation-delay:.32s;opacity:0}.toast{position:fixed;bottom:20px;right:20px;padding:12px 18px;border-radius:var(--radius-md);font-size:var(--text-body);font-weight:500;display:flex;align-items:center;gap:10px;animation:slideInRight .25s ease;z-index:999;box-shadow:0 4px 20px #34404b1f;max-width:340px}.toast-success{background:var(--green-50);border:1px solid var(--success);color:var(--success)}.toast-error{background:var(--red-50);border:1px solid var(--error);color:var(--error)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.video-poll{display:flex;flex-direction:column;align-items:center;gap:12px;padding:28px;background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-lg);text-align:center}.app-mobile{min-height:100vh;background-image:url(/bg-main.jpg);background-size:100vw 100vh;background-position:top left;background-repeat:no-repeat;background-attachment:fixed;background-color:#c8e8f8;position:relative;overflow-x:hidden}.watermark-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.watermark-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0}.watermark-bg:after{content:""}.mobile-nav{position:fixed;top:0;left:0;right:0;z-index:100;height:54px;background:#1265b6;box-shadow:0 2px 12px #1265b659;display:flex;align-items:center;justify-content:center;padding:0 16px}.mobile-nav-logo{height:34px;object-fit:contain;border-radius:4px}.mobile-nav-badge{padding:5px 12px;border-radius:var(--radius-full);font-size:15px;font-weight:700;color:#fff;letter-spacing:.3px}.mobile-body{position:relative;z-index:1;padding:20px 14px 40px;max-width:480px;margin:0 auto}.mobile-header{text-align:center;margin-bottom:16px;padding:5px 0 10px}.header-logo{height:160px;object-fit:contain;border-radius:12px;filter:drop-shadow(0 6px 20px rgba(18,101,182,.3))}.header-title{font-size:16px;color:var(--primary-700)}.title-accent{color:var(--primary-700)}.header-sub{font-size:16px;color:var(--primary-700)}.tab-bar{display:flex;gap:4px;margin-bottom:20px;padding:4px;background:#1265b61a;border:1px solid rgba(18,101,182,.2);border-radius:var(--radius-lg)}.tab-btn{flex:1;padding:10px 8px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--primary-800);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap;opacity:.6}.tab-btn:hover{opacity:.9}.tab-btn--active{background:var(--gradient-blue-light);color:#fff;font-weight:700;opacity:1;box-shadow:0 2px 12px #3079ff59}.mobile-card{background:#fff;border:1px solid rgba(18,101,182,.15);border-top:3px solid var(--primary-400);border-radius:var(--radius-xl);padding:20px 16px;box-shadow:0 4px 24px #1265b61a;display:flex;flex-direction:column}.section-label{font-size:16px;font-weight:700;color:var(--primary-700);margin-bottom:4px}.section-hint{font-size:13px;color:var(--gray-500);margin-bottom:10px}.user-badge{padding:12px 14px;margin-bottom:16px;background:linear-gradient(135deg,#1265b614,#3079ff0d);border:1px solid rgba(18,101,182,.25);border-radius:var(--radius-md);font-size:13px}.user-badge-title{font-weight:700;color:var(--primary-500);margin-bottom:8px;font-size:12px}.user-badge-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px 12px;color:var(--gray-700)}.ld-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;min-height:400px;padding:0 16px;text-align:center}.ld-avatar-wrap{position:relative;width:150px;height:150px;margin-bottom:4px}.ld-avatar{position:relative;z-index:2;width:150px;height:150px;border-radius:50%;object-fit:cover;object-position:center top;border:3px solid #fff;box-shadow:0 4px 20px #3079ff4d;display:block}.ld-avatar-ring{position:absolute;top:-6px;right:-6px;bottom:-6px;left:-6px;border-radius:50%;border:3px solid transparent;border-top-color:#3079ff;border-right-color:#3079ff;animation:spin 1s linear infinite;z-index:3}.ld-avatar-pulse{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:50%;background:radial-gradient(circle,rgba(48,121,255,.15) 0%,transparent 70%);animation:ldPulse 2s ease-in-out infinite;z-index:1}.ld-avatar-pulse--2{top:-26px;right:-26px;bottom:-26px;left:-26px;animation-delay:.8s;background:radial-gradient(circle,rgba(48,121,255,.08) 0%,transparent 70%)}@keyframes ldPulse{0%,to{transform:scale(.95);opacity:.6}50%{transform:scale(1.05);opacity:1}}.ld-steps{display:flex;flex-direction:column;gap:8px;width:100%;max-width:280px}.ld-step{display:flex;align-items:center;gap:10px;padding:8px 14px;border-radius:10px;background:#f4f7fb;border:1.5px solid #e8eef5;transition:all .3s ease;opacity:.45}.ld-step--done{background:#e8f7e8;border-color:#a8e6b0;opacity:.75}.ld-step--active{background:linear-gradient(135deg,#e8f5fd,#d0ecf8);border-color:#3079ff;opacity:1;box-shadow:0 2px 12px #3079ff26;transform:translate(3px)}.ld-step-icon{font-size:16px;width:24px;text-align:center;flex-shrink:0}.ld-step-label{font-size:13px;font-weight:600;color:var(--gray-800)}.ld-step--active .ld-step-label{color:var(--primary-500)}.ld-step--done .ld-step-label{color:#1b9758}.ld-bar-wrap{width:100%;max-width:280px}.ld-bar-track{width:100%;height:8px;background:#e8eef5;border-radius:99px;overflow:hidden;margin-bottom:6px}.ld-bar-fill{position:relative;height:100%;background:linear-gradient(90deg,#3079ff,#1265b6);border-radius:99px;transition:width .6s cubic-bezier(.4,0,.2,1);overflow:hidden}.ld-bar-shimmer{position:absolute;top:0;bottom:0;width:60px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:ldShimmer 1.4s linear infinite}@keyframes ldShimmer{0%{left:-60px}to{left:100%}}.ld-bar-pct{font-size:12px;font-weight:700;color:#3079ff;text-align:right}.ld-msg{font-size:13px;color:var(--gray-500);min-height:20px;font-style:italic}.result-wrapper{display:flex;flex-direction:column;gap:14px}.result-badge{display:flex;align-items:center;gap:14px;padding:10px 18px;background:#1877f2;border-radius:var(--radius-lg);box-shadow:0 4px 18px #1877f259;margin-top:8px}.result-badge-icon{font-size:28px;flex-shrink:0}.result-badge-title{font-size:15px;font-weight:700;color:#fff}.result-badge-sub{font-size:12px;color:#ffffffbf;margin-top:2px}.result-media{width:100%;border-radius:var(--radius-xl);display:block;box-shadow:0 8px 32px #1265b626}.style-grid{display:flex;flex-direction:column;gap:32px}.style-item{display:flex;flex-direction:column;gap:12px}.style-item-label{font-size:13px;font-weight:700;color:var(--primary-500);text-transform:uppercase;letter-spacing:.5px}.result-meta-row{display:flex;gap:8px;flex-wrap:wrap}.meta-chip{padding:5px 12px;background:var(--gray-100);border-radius:var(--radius-full);font-size:12px;font-weight:500;color:var(--gray-700)}.meta-chip--highlight{background:var(--primary-50);color:var(--primary-500);border:1px solid var(--primary-200)}.action-panel{display:flex;flex-direction:column;gap:10px}.action-btn{display:flex;align-items:center;gap:14px;width:100%;padding:15px 18px;border:none;border-radius:var(--radius-lg);font-family:var(--font);cursor:pointer;text-decoration:none;transition:var(--transition);text-align:left}.action-btn--primary{background:var(--gradient-blue-light);color:#fff;box-shadow:0 4px 18px #3079ff4d}.action-btn--primary:hover{filter:brightness(1.08);transform:translateY(-1px)}.action-btn--fb{background:#1877f2;color:#fff;box-shadow:0 4px 18px #1877f240}.action-btn--fb:hover{filter:brightness(1.08);transform:translateY(-1px)}.action-btn:disabled{opacity:.72;cursor:not-allowed;transform:none!important;filter:none!important}.action-btn-icon{width:40px;height:40px;background:#fff3;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.action-btn-label{display:block;font-size:15px;font-weight:700;line-height:1.2}.action-btn-sub{display:block;font-size:11px;opacity:.75;margin-top:2px}.hashtag-hint{text-align:center;font-size:11px;color:var(--primary-500);background:var(--primary-50);border-radius:var(--radius-md);padding:8px 12px;line-height:1.6;word-break:break-word}.action-toast{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:500;animation:fadeInUp .2s ease}.action-toast--success{background:var(--green-100);color:var(--green-700)}.action-toast--error{background:var(--red-50);color:var(--red-600)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.caption-box{background:var(--primary-50);border:1px solid var(--primary-100);border-radius:var(--radius-md);padding:12px 14px;display:flex;flex-direction:column;gap:10px}.caption-box-text{font-size:12.5px;color:var(--gray-700);line-height:1.6;white-space:pre-line;word-break:break-word}.caption-copy-btn{align-self:flex-end;background:#fff;border:1px solid var(--primary-200);border-radius:var(--radius-sm);color:var(--primary-500);font-size:12px;font-weight:600;padding:6px 12px;cursor:pointer;transition:var(--transition);font-family:var(--font)}.caption-copy-btn:hover:not(:disabled){background:var(--primary-100)}.caption-copy-btn:disabled{opacity:.7;cursor:default}.token-screen{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 24px;text-align:center;background:var(--primary-50)}.token-screen-icon{font-size:56px;line-height:1}.token-screen-title{font-size:18px;font-weight:700;color:var(--gray-900);margin:0}.token-screen-msg{font-size:14px;color:var(--gray-600);max-width:300px;line-height:1.6;margin:0}.confirm-wrap{min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.confirm-photo-wrap{position:relative;width:160px;height:160px;margin:0 auto}.confirm-photo{width:160px;height:160px;border-radius:var(--radius-xl);object-fit:cover;border:3px solid var(--primary-500);box-shadow:0 8px 28px #1265b633}.confirm-photo-check{position:absolute;bottom:-8px;right:-8px;width:28px;height:28px;background:var(--success);border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700}.confirm-info{text-align:center;margin-bottom:24px}.confirm-info-title{font-size:17px;font-weight:700;color:var(--gray-900);margin-bottom:6px}.confirm-info-hint{font-size:13px;color:var(--gray-500);line-height:1.5}.btn-generate{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:17px;background:var(--gradient-blue-light);color:#fff;font-family:var(--font);font-size:16px;font-weight:700;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition);box-shadow:0 4px 20px #1265b64d;margin-bottom:12px;letter-spacing:.2px}.btn-generate:hover{filter:brightness(1.08);transform:translateY(-2px);box-shadow:0 6px 24px #1265b659}.btn-generate:active{transform:translateY(0)}.btn-change-photo{display:block;width:100%;padding:11px;background:transparent;border:none;color:var(--gray-400);font-family:var(--font);font-size:13px;cursor:pointer;text-align:center;transition:var(--transition)}.btn-change-photo:hover{color:var(--primary-700)}.limit-reached{text-align:center;padding:14px 20px;margin-bottom:12px;background:#fef2f2;border:1px solid #FECACA;border-radius:var(--radius-md);color:#ef4444;font-size:14px;font-weight:600}.btn-reset{width:100%;padding:12px;background:transparent;border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);color:var(--gray-500);font-family:var(--font);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-reset:hover{border-color:var(--primary-300);color:var(--primary-700);background:var(--primary-50)}.result-dots{display:flex;justify-content:center;gap:8px}.result-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--gray-300);cursor:pointer;padding:0;transition:var(--transition)}.result-dot--active{background:var(--primary-600);width:24px;border-radius:4px}.btn-regen{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px;background:transparent;color:var(--primary-500);font-family:var(--font);font-size:15px;font-weight:600;border:2px solid var(--primary-400);border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition)}.btn-regen:hover{background:var(--primary-50);border-color:var(--primary-600)}.result-done-note{width:100%;padding:12px;background:#00a1e414;border:1.5px solid rgba(0,161,228,.25);border-radius:var(--radius-lg);color:var(--blue);font-size:13px;font-weight:600;text-align:center;margin-top:4px}.tab-done-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#22c55e;margin-left:5px;vertical-align:middle;flex-shrink:0}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;margin-bottom:16px;background:#ef444414;border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error);font-size:13px}.error-retry{background:none;border:1px solid var(--error);color:var(--error);border-radius:6px;padding:3px 10px;cursor:pointer;font-size:12px;white-space:nowrap;flex-shrink:0}
