body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#333;font-family:PingFang SC,Helvetica Neue,Arial,sans-serif}.App{display:flex;flex-direction:column;min-height:100vh;text-align:center}.app-header{align-items:center;background-color:#fff;box-shadow:0 2px 8px #0000000d;display:flex;padding:20px 30px;position:relative}.logo{color:#6c5ce7;font-size:1.5rem;font-weight:700;left:30px}.logo,nav{position:absolute}nav{display:flex;gap:20px;left:50%;transform:translateX(-50%)}nav a{border-radius:4px;color:#666;padding:5px 10px;text-decoration:none;transition:all .3s ease}nav a.active{color:#6c5ce7;font-weight:500}nav a:hover{background-color:#f0f0f0}.user-info{align-items:center;display:flex;gap:15px;position:absolute;right:30px}.daily-points-display,.user-status-container{align-items:center;display:flex;gap:8px}.daily-points-display{background-color:#f0f4ff;border-radius:15px;box-shadow:0 1px 3px #0000001a;color:#6c5ce7;font-size:.85rem;font-weight:500;padding:5px 10px;transition:all .3s ease}.daily-points-display:hover{background-color:#e4e9ff;box-shadow:0 2px 5px #00000026}.points-text{display:inline-block}.history-link-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;padding:4px 8px;text-decoration:none;transition:all .3s ease}.history-link-btn:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);box-shadow:0 4px 8px #667eea66;color:#fff;text-decoration:none;transform:translateY(-1px)}.membership-badge{align-items:center;border-radius:12px;box-shadow:0 1px 3px #00000026;display:flex;font-size:.75rem;font-weight:600;gap:4px;padding:2px 6px;transition:all .3s ease}.membership-badge.free{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:1px solid #90caf9;color:#1976d2}.membership-badge.pro{background:linear-gradient(135deg,#fff8e1,#ffecb3);border:1px solid #ffcc02;box-shadow:0 2px 8px #ffc1074d;color:#f57c00}.membership-badge.pro:hover{background:linear-gradient(135deg,#fff3c4,#ffe082);box-shadow:0 3px 12px #ffc10766;transform:translateY(-1px)}.membership-icon{font-size:.8rem;line-height:1}.membership-text{font-size:.7rem;letter-spacing:.3px}.user-avatar-container{cursor:pointer;position:relative}.user-icon{align-items:center;background-color:#6c5ce7;border-radius:50%;color:#fff;display:flex;font-weight:700;height:30px;justify-content:center;text-decoration:none;transition:all .3s ease;width:30px}.user-avatar-container:hover .user-icon{background-color:#5a4bd1;box-shadow:0 2px 8px #6c5ce766;transform:scale(1.05)}.user-dropdown-menu{animation:fadeInDown .3s ease-out;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden;position:absolute;right:0;top:40px;transition:opacity .3s ease;width:220px;z-index:100}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info-section{background-color:#f8f9ff;border-bottom:1px solid #eee;padding:15px}.user-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.username{color:#333;font-size:.95rem;font-weight:700}.status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:500;padding:3px 8px}.status-badge.regular{background-color:#e0e7ff;color:#6c5ce7}.status-badge.pro{background-color:gold;box-shadow:0 2px 4px #b8860b33;color:#b8860b}.menu-divider{background-color:#eee;height:1px;margin:0}.menu-items{padding:8px 0}.menu-item{align-items:center;background:none;border:none;color:#333;cursor:pointer;display:flex;font-size:.9rem;padding:10px 15px;text-align:left;text-decoration:none;transition:background-color .2s ease;width:100%}.menu-item:hover{background-color:#f5f7ff}.menu-icon{background-position:50%;background-repeat:no-repeat;background-size:contain;display:inline-block;height:16px;margin-right:10px;width:16px}.profile-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236c5ce7' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E")}.recharge-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ff9500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='2' y='5' width='20' height='14' rx='2'/%3E%3Cpath d='M2 10h20'/%3E%3C/svg%3E")}.history-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234cd964' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='M12 6v6l4 2'/%3E%3C/svg%3E")}.logout-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23e74c3c' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4M16 17l5-5-5-5M21 12H9'/%3E%3C/svg%3E")}.logout-button{color:#e74c3c;font-weight:500}.login-btn{background-color:#6c5ce7;border-radius:20px;color:#fff;font-size:.9rem;padding:5px 15px;text-decoration:none;transition:all .3s ease}.login-btn:hover{background-color:#5a4bd1}.loading-container{color:#666;font-size:1.2rem;min-height:300px}.app-main{max-width:900px}.language-selector{max-width:500px}.image-preview{gap:20px;width:100%}.image-preview img{max-height:400px}.translate-button{background-color:#6c5ce7;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:12px 30px;transition:all .3s ease}.translate-button:hover:not(:disabled){background-color:#5a4bd1}.translate-button:disabled{background-color:#a29ddb;cursor:not-allowed}.app-footer{background:#fff;border-top:1px solid #eee;color:#888;font-size:.95rem;letter-spacing:.5px;margin-top:auto;padding:16px 0 12px;text-align:center;width:100%}.app-footer a{color:#6c5ce7;margin-left:4px;text-decoration:none}.app-footer a:hover{text-decoration:underline}.refine-page{background-color:#f5f5f5;overflow:hidden;width:100%}.refine-header{background-color:#fff;border-bottom:1px solid #e0e0e0;height:50px;padding:10px 20px}.back-button{color:#333;cursor:pointer;font-size:14px;padding:5px 10px}.back-button:hover{color:#6c5ce7}.header-buttons{display:flex;gap:10px}.download-button,.save-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:14px;justify-content:center;padding:6px 12px;transition:all .2s ease}.save-button{background-color:#6c5ce7;color:#fff}.save-button:hover{background-color:#5a4bd1}.download-button{background-color:#f0f0f0;color:#333}.download-button:hover{background-color:#e0e0e0}.refine-title{color:#333;font-size:16px;font-weight:500}.thumbnail-panel{background-color:#fff;border-right:1px solid #e0e0e0;overflow-y:auto;padding:10px;width:70px}.thumbnail-container{border:2px solid #0000;border-radius:4px;cursor:pointer;height:50px;margin-bottom:10px;overflow:hidden;position:relative;width:50px}.thumbnail-container.selected{border-color:#6c5ce7}.thumbnail-container img{height:100%;object-fit:cover;width:100%}.thumbnail-check{align-items:center;background-color:#6c5ce7;border-radius:50%;bottom:2px;color:#fff;display:flex;font-size:10px;height:14px;justify-content:center;position:absolute;right:2px;width:14px}.edit-panel{align-items:stretch;background-color:#f0f0f0;flex:1 1;padding:10px}.edit-panel,.image-container{display:flex;justify-content:center;overflow:hidden}.image-container{align-items:center;background-color:#fff;box-shadow:0 0 10px #0000001a;height:100%;width:100%}.image-container img{display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}.settings-panel{background-color:#fff;border-left:1px solid #e0e0e0;display:flex;flex-direction:column;overflow:hidden;width:280px}.settings-tabs{border-bottom:1px solid #e0e0e0;display:flex}.tab{border-bottom:2px solid #0000;color:#666;cursor:pointer;font-size:14px;padding:12px 15px;transition:all .2s ease}.tab.active{border-bottom-color:#6c5ce7;color:#6c5ce7;font-weight:500}.settings-content{flex:1 1;overflow-y:auto;padding:15px}.setting-section{margin-bottom:20px}.setting-title{border-bottom:1px solid #f0f0f0;color:#333;font-size:14px;font-weight:500;margin-bottom:10px;padding-bottom:5px}.setting-row{align-items:center;display:flex;margin-bottom:10px}.setting-label{color:#666;font-size:13px;width:80px}.setting-control{align-items:center;display:flex;flex:1 1}.font-select{flex:1 1;margin-right:5px}.font-select,.font-size-input{border:1px solid #e0e0e0;border-radius:4px;font-size:13px;padding:5px}.font-size-input{text-align:center;width:50px}.color-options{display:flex;gap:10px}.color-option{border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;font-size:13px;padding:5px 10px}.color-option.selected{background-color:#f8f7ff;border-color:#6c5ce7;color:#6c5ce7}.color-picker{border-radius:4px;height:24px;overflow:hidden;width:24px}.color-preview{border:1px solid #e0e0e0;height:100%;width:100%}.color-picker input[type=color]{height:150%;width:150%}.format-buttons{display:flex;gap:5px;margin-bottom:10px}.format-button{align-items:center;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;display:flex;height:30px;justify-content:center;width:30px}.format-button:hover{background-color:#f8f7ff}.format-icon{font-size:14px;font-weight:700}.border-width-input,.line-height-input{border:1px solid #e0e0e0;border-radius:4px;font-size:13px;padding:5px;text-align:center;width:50px}.switch{display:inline-block;height:20px;position:relative;width:40px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;bottom:2px;content:"";height:16px;left:2px;width:16px}input:checked+.slider{background-color:#6c5ce7}input:checked+.slider:before{transform:translateX(20px)}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.image-comparison{display:flex;gap:10px;height:100%;overflow:hidden;padding:10px;width:100%}.image-column{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;margin:0;min-height:0;overflow:hidden}.layer-settings{margin-bottom:10px}.layer-row{align-items:center;background-color:#f8f8f8;border-radius:4px;cursor:pointer;display:flex;margin-bottom:5px;padding:8px}.layer-row:hover{background-color:#f0f0f0}.layer-icon{align-items:center;background-color:#6c5ce7;border-radius:4px;color:#fff;display:flex;font-weight:700;height:24px;justify-content:center;margin-right:8px;width:24px}.layer-name{color:#333;flex:1 1;font-size:13px}.layer-name.selected{color:#6c5ce7;font-weight:500}.layer-actions{display:flex;gap:5px}.layer-action-btn{background:none;border:none;color:#666;cursor:pointer;font-size:14px;padding:2px}.layer-action-btn:hover{color:#6c5ce7}.translation-settings{margin-bottom:10px}.setting-control.full-width{width:100%}.text-input{border:1px solid #e0e0e0;border-radius:4px;font-size:13px;min-height:60px;padding:8px;resize:vertical;width:100%}.translation-actions{align-items:center;display:flex;gap:10px;margin:10px 0}.language-select{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;flex:1 1;font-size:13px;padding:8px}.translate-btn{background-color:#6c5ce7;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:8px 15px;transition:background-color .2s}.translate-btn:hover{background-color:#5a4bd1}.image-header{background-color:#f8f8f8;border-bottom:1px solid #e0e0e0;color:#333;font-size:14px;font-weight:500;padding:12px 15px;text-align:center}.image-subheader{color:#333;font-size:14px;padding:0 15px 15px;text-align:left}.image-column .image-container{align-items:center;background-color:#f8f8f8;box-shadow:none;display:flex;flex:1 1;justify-content:center;margin:0;min-height:0;overflow:hidden;padding:10px}.image-column .image-container img{display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}.image-description{color:#555;font-size:13px;line-height:1.4;padding:15px;text-align:left}.image-features{background-color:#f8f8f8;border-top:1px solid #eee;display:flex;justify-content:space-between;padding:10px 15px 15px}.feature{flex-direction:column;gap:5px}.feature,.feature-icon{align-items:center;display:flex}.feature-icon{background-color:#fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;font-size:14px;height:30px;justify-content:center;width:30px}.feature-text{color:#666;font-size:11px}@media (max-width:768px){.refine-content{flex-direction:column}.thumbnail-panel{display:flex;height:60px;overflow-x:auto;padding:5px 10px;width:100%}.thumbnail-container{margin-bottom:0;margin-right:10px}.settings-panel{max-height:300px;width:100%}.image-comparison{flex-direction:column;height:auto;min-height:400px}.image-column{min-height:200px}.app-header{padding:16px 20px}.logo{font-size:1.4rem;left:20px}.user-info{right:20px}.user-status-container{gap:6px}.daily-points-display{font-size:.8rem;gap:6px;padding:4px 8px}.points-text{font-size:.8rem}.history-link-btn{font-size:.7rem;padding:3px 6px}.membership-badge{font-size:.7rem;padding:2px 4px}.membership-text{font-size:.65rem}}@media (max-width:480px){.app-header{padding:14px 15px}.logo{font-size:1.3rem;left:15px}nav{gap:15px;left:50%;transform:translateX(-50%)}nav a{font-size:.9rem;padding:4px 8px}.user-info{gap:10px;right:15px}.daily-points-display{font-size:.75rem;gap:4px;padding:3px 6px}.points-text{font-size:.75rem}.history-link-btn{font-size:.65rem;padding:2px 5px}.membership-badge{font-size:.65rem;padding:1px 3px}.membership-text{font-size:.6rem}}.canvas-container{background-color:#fafafa;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;position:relative}.canvas-toolbar{gap:8px}.canvas-toolbar,.tool-button{align-items:center;display:flex}.tool-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;justify-content:center;padding:6px 10px;transition:all .3s ease}.tool-button:hover{background-color:#e8e8e8;border-color:#999}.tool-button.active{background-color:#6c5ce7;border-color:#6c5ce7;color:#fff}.tool-button:disabled{background-color:#f9f9f9;border-color:#eee;color:#ccc;cursor:not-allowed}.text-box-controls{display:flex;gap:8px;margin-bottom:15px}.add-text-button,.delete-text-button{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 12px;transition:all .3s ease}.add-text-button{background-color:#6c5ce7;color:#fff}.add-text-button:hover{background-color:#5a4bd1;box-shadow:0 4px 8px #6c5ce74d;transform:translateY(-1px)}.delete-text-button{background-color:#e74c3c;color:#fff}.delete-text-button:hover{background-color:#c0392b;box-shadow:0 4px 8px #e74c3c4d;transform:translateY(-1px)}.text-box-list{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:6px;max-height:120px;overflow-y:auto}.text-box-item{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;justify-content:space-between;padding:8px 12px;transition:all .3s ease}.text-box-item:hover{background-color:#f0f0f0}.text-box-item.selected{background-color:#6c5ce7;color:#fff}.text-box-item:last-child{border-bottom:none}.text-preview{flex:1 1;font-size:13px;text-align:left}.selected-text-info{background-color:#f0f4ff;border:1px solid #d4edda;border-radius:8px;padding:12px}.selected-text-info p{color:#28a745;font-size:14px;font-weight:500;margin:0 0 10px}.no-selection-info{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:12px;text-align:center}.no-selection-info p{color:#856404;font-size:14px;margin:0}.border-width-slider,.font-size-slider,.line-height-slider{background:#ddd;border-radius:3px;flex:1 1;height:6px;margin-right:10px;opacity:.7;outline:none;transition:opacity .2s}.border-width-slider:hover,.font-size-slider:hover,.line-height-slider:hover{opacity:1}.border-width-slider::-webkit-slider-thumb,.font-size-slider::-webkit-slider-thumb,.line-height-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#6c5ce7;border-radius:50%;box-shadow:0 2px 6px #6c5ce74d;cursor:pointer;height:18px;width:18px}.border-width-slider::-moz-range-thumb,.font-size-slider::-moz-range-thumb,.line-height-slider::-moz-range-thumb{background:#6c5ce7;border:none;border-radius:50%;box-shadow:0 2px 6px #6c5ce74d;cursor:pointer;height:18px;width:18px}.border-width-input,.font-size-input,.line-height-input{border:1px solid #ddd;border-radius:4px;font-size:13px;padding:4px 8px;text-align:center;width:60px}.color-picker,.color-preview{position:relative}.color-preview{border:2px solid #ddd;border-radius:6px;cursor:pointer;height:30px;overflow:hidden;transition:all .3s ease;width:40px}.color-preview:hover{border-color:#6c5ce7;transform:scale(1.05)}.color-picker input[type=color]{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}canvas{transition:all .3s ease}canvas:hover{border-color:#6c5ce7}@media (max-width:768px){.canvas-container{margin-bottom:20px}.tool-button{font-size:16px;padding:8px}.text-box-controls{flex-direction:column}.add-text-button,.delete-text-button{width:100%}.text-box-list{max-height:80px}.border-width-slider,.font-size-slider,.line-height-slider{margin-bottom:10px}}.refine-page{background:#f8f9fa;display:flex;flex-direction:column;height:100vh}.refine-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;padding:1rem 2rem}.refine-header h2{color:#333;font-size:1.5rem;margin:0}.refine-actions{display:flex;gap:.75rem}.refine-actions button{border:none;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.btn-add-text{background:#4caf50;color:#fff}.btn-add-text:hover{background:#45a049}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover:not(:disabled){background:#da190b}.btn-delete:disabled{background:#ccc;cursor:not-allowed}.btn-cancel{background:#6c757d;color:#fff}.btn-cancel:hover{background:#5a6268}.btn-save{background:#007bff;color:#fff;font-weight:500}.btn-save:hover:not(:disabled){background:#0056b3}.btn-save:disabled{background:#ccc;cursor:not-allowed}.refine-content{display:flex;flex:1 1;gap:1rem;overflow:hidden;padding:1rem}.original-image-section{flex-direction:column;width:350px}.canvas-section,.original-image-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;overflow:hidden}.canvas-section{flex:1 1;flex-direction:column;margin:0 .5rem}.style-panel-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;width:300px}.section-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1rem}.section-header h3{color:#333;font-size:1rem;margin:0}.header-actions{display:flex;gap:.5rem}.image-display-container{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:1rem}.display-image{border-radius:4px;box-shadow:0 2px 4px #0000001a;max-height:100%;max-width:100%;object-fit:contain}.no-image-placeholder{color:#666;padding:2rem;text-align:center}.canvas-area{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:1rem}.fabric-canvas{border:1px solid #e9ecef;border-radius:4px;box-shadow:0 2px 4px #0000001a;height:auto;max-width:100%}.canvas-error{align-items:center;background:#ffebee;border:2px dashed #f44336;border-radius:8px;color:#c62828;display:flex;flex-direction:column;height:400px;justify-content:center;max-width:800px;padding:2rem;text-align:center;width:100%}.canvas-error p{font-size:1rem;margin-bottom:1rem}.canvas-error button{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;padding:.75rem 1.5rem}.canvas-error button:hover{background:#d32f2f}.style-actions{background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;gap:.5rem;padding:1rem}.btn-add-text-panel,.btn-delete-panel{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:.9rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s}.btn-add-text-panel{background:#4caf50;color:#fff}.btn-add-text-panel:hover:not(:disabled){background:#45a049;transform:translateY(-1px)}.btn-delete-panel{background:#f44336;color:#fff}.btn-delete-panel:hover:not(:disabled){background:#da190b;transform:translateY(-1px)}.btn-add-text-panel:disabled,.btn-delete-panel:disabled{background:#ccc;cursor:not-allowed;transform:none}.textbox-list-section{background:#f8f9fa;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.textbox-list-header{align-items:center;background:#e9ecef;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:.75rem 1rem}.textbox-list-header h4{color:#495057;font-size:.9rem;font-weight:600;margin:0}.textbox-count{background:#fff;border-radius:12px;color:#6c757d;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.textbox-list{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:.5rem}.textbox-item{align-items:center;background:#fff;border-bottom:1px solid #dee2e6;cursor:pointer;display:flex;padding:.75rem 1rem;transition:all .2s}.textbox-item:hover{background:#f8f9fa;border-left:3px solid #4caf50}.textbox-item.selected{background:#e8f5e8;border-left:3px solid #4caf50;box-shadow:inset 0 0 0 1px #4caf50}.textbox-index{align-items:center;background:#6c757d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:600;height:24px;justify-content:center;margin-right:.75rem;width:24px}.textbox-item.selected .textbox-index{background:#4caf50}.textbox-content{align-items:center;display:flex;flex:1 1;justify-content:flex-start;min-width:0}.textbox-text{color:#212529;font-size:.9rem;font-weight:500;margin:0;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap;width:100%}.empty-textbox-list{align-items:center;color:#6c757d;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem 1rem;text-align:center}.empty-textbox-list p{font-size:.9rem;margin:.25rem 0}.empty-textbox-list p:first-child{color:#495057;font-weight:500}.style-panel-header{background:#e9ecef;border-bottom:1px solid #dee2e6;border-top:1px solid #dee2e6;padding:.75rem 1rem}.style-panel-header h4{color:#495057;font-size:.9rem;font-weight:600;margin:0}.style-form{display:flex;flex-direction:column;gap:1rem}.style-row{align-items:center;display:flex;gap:1rem;min-height:40px}.style-label{color:#333;flex-shrink:0;font-size:.9rem;font-weight:500;text-align:left;width:80px}.style-control{align-items:center;display:flex;flex:1 1;gap:.5rem}.font-select-form{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.font-size-control{align-items:center;display:flex;gap:.5rem}.font-size-input-form{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem;text-align:center;width:80px}.font-size-unit-form{color:#666;font-size:.9rem;font-weight:500}.color-input-form{border:1px solid #ddd;border-radius:4px;cursor:pointer;height:40px;padding:2px;width:60px}.align-buttons-form{display:flex;gap:.25rem}.align-btn-form{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;height:40px;justify-content:center;position:relative;transition:all .2s;width:40px}.align-btn-form:hover{background:#f0f0f0}.align-btn-form.active{background:#6c5ce7;border-color:#6c5ce7;color:#fff}.align-icon{display:none}.align-btn-form:before{background:linear-gradient(currentColor,currentColor) 0 2px /100% 2px no-repeat,linear-gradient(currentColor,currentColor) 0 5px /80% 2px no-repeat,linear-gradient(currentColor,currentColor) 0 8px /90% 2px no-repeat;content:"";display:block;height:12px;position:relative;width:18px}.align-left:before{background:linear-gradient(currentColor,currentColor) 0 2px /100% 2px no-repeat,linear-gradient(currentColor,currentColor) 0 5px /70% 2px no-repeat,linear-gradient(currentColor,currentColor) 0 8px /85% 2px no-repeat}.align-center:before{background:linear-gradient(currentColor,currentColor) 50% 2px /100% 2px no-repeat,linear-gradient(currentColor,currentColor) 50% 5px /60% 2px no-repeat,linear-gradient(currentColor,currentColor) 50% 8px /80% 2px no-repeat}.align-right:before{background:linear-gradient(currentColor,currentColor) 100% 2px /100% 2px no-repeat,linear-gradient(currentColor,currentColor) 100% 5px /70% 2px no-repeat,linear-gradient(currentColor,currentColor) 100% 8px /85% 2px no-repeat}.font-effects-form{display:flex;gap:.25rem}.effect-btn-form{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;transition:all .2s;width:40px}.effect-btn-form:hover{background:#f0f0f0}.effect-btn-form.active{background:#4caf50;border-color:#4caf50;color:#fff}.textbox-list-section .style-panel{background:#fff;border-top:1px solid #dee2e6;margin-top:.5rem}.textbox-list-section .style-panel .style-form{padding:1rem}.style-panel h3{border-bottom:2px solid #4caf50;color:#333;font-size:1.2rem;margin:0 0 1.5rem;padding-bottom:.5rem}.style-group{margin-bottom:1.5rem}.style-group label{color:#555;display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.style-group input[type=number],.style-group input[type=text],.style-group select{border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.style-group input[type=range]{margin:.5rem 0;width:100%}.style-group input[type=color]{border:none;border-radius:4px;cursor:pointer;height:40px;width:60px}.color-with-transparent{align-items:center;display:flex;gap:.5rem}.btn-transparent{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.8rem;padding:.5rem 1rem;transition:all .2s}.btn-transparent:hover{background:#f0f0f0}.btn-transparent.active{background:#4caf50;border-color:#4caf50;color:#fff}.font-effects{display:flex;gap:.5rem}.font-effects button{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-weight:700;height:35px;transition:all .2s;width:35px}.font-effects button:hover{background:#f0f0f0}.font-effects button.active{background:#4caf50;border-color:#4caf50;color:#fff}.align-buttons{display:flex;gap:.5rem}.align-buttons button{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;flex:1 1;font-size:.8rem;padding:.5rem;transition:all .2s}.align-buttons button:hover{background:#f0f0f0}.align-buttons button.active{background:#4caf50;border-color:#4caf50;color:#fff}@media (max-width:1200px){.original-image-section{width:300px}.style-panel-section{width:250px}.fabric-canvas{max-width:700px}}@media (max-width:1024px){.refine-content{flex-direction:column;gap:1rem}.original-image-section{max-height:300px;width:100%}.canvas-section{margin:0;min-height:400px;width:100%}.style-panel-section{width:100%}.style-panel{max-height:200px}.fabric-canvas{max-width:600px}}@media (max-width:768px){.refine-header{flex-direction:column;gap:1rem;padding:1rem}.refine-actions{flex-wrap:wrap;justify-content:center;width:100%}.section-header{flex-direction:column;gap:.5rem;padding:.75rem}.original-image-section{max-height:250px}.canvas-section{min-height:350px}.style-panel{max-height:150px}.fabric-canvas{max-width:500px}.textbox-list-section{max-height:120px}.textbox-list{max-height:80px}.textbox-item{padding:.5rem .75rem}.textbox-text{font-size:.8rem}.font-size-row{flex-direction:column;gap:.25rem}.font-select-compact,.font-size-input-compact{font-size:.8rem;padding:.4rem}.font-size-input-compact{width:50px}.color-type-btn{font-size:.8rem;padding:.4rem .75rem}.color-input-compact{height:35px;width:50px}.btn-transparent-compact{font-size:.7rem;padding:.4rem .6rem}.align-effects-row{flex-direction:column;gap:.5rem}.align-btn-compact,.effect-btn-compact{font-size:1rem;height:35px;width:35px}.align-btn-compact:before{height:10px;width:15px}}.app-main{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100vh;margin:0 auto;max-width:1200px;padding:40px 20px;width:100%}.app-header-section{margin-bottom:20px;text-align:center;width:100%}.app-title{color:#333;font-size:2rem;margin-bottom:10px}.app-description{color:#666;margin-bottom:20px}.points-info{background-color:#f0f4ff;color:#6c5ce7}.login-info,.points-info{border-radius:20px;font-size:.9rem;margin-bottom:30px;padding:5px 15px}.login-info{background-color:#fff3e0;color:#ff9800}.login-reminder{background-color:#fff3e0;border-left:3px solid #ff5722;color:#ff5722}.login-reminder,.points-reminder{border-radius:6px;font-size:.85rem;margin-top:10px;padding:8px 12px;text-align:center}.points-reminder{background-color:#fff8e1;border-left:3px solid #ff9800;color:#ff9800}.recharge-link{color:#6c5ce7;cursor:pointer;font-weight:700;margin-left:5px;text-decoration:underline;transition:color .3s ease}.recharge-link:hover{color:#5649c0}.language-selector{align-items:center;display:flex;gap:15px;margin-bottom:30px;max-width:600px;width:100%}.language-dropdown{flex:1 1}.language-dropdown select{-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:1rem;padding:10px 15px;width:100%}.swap-button{align-items:center;background-color:#f0f4ff;border:none;border-radius:50%;color:#6c5ce7;cursor:pointer;display:flex;font-size:1.2rem;height:40px;justify-content:center;transition:all .3s ease;width:40px}.swap-button:hover{background-color:#e0e7ff}.upload-area{display:flex;flex:1 1;justify-content:center;margin-bottom:30px;max-height:600px;min-height:300px;overflow:visible;position:relative;width:100%}.image-preview-container{border-radius:12px;box-shadow:0 4px 20px #00000014;flex-direction:row;margin:0 auto;max-width:800px;overflow:visible;padding:15px;position:relative;width:80%}.image-preview-container,.upload-placeholder{background-color:#fff;display:flex;gap:15px;height:100%;max-height:350px;min-height:250px}.upload-placeholder{align-items:center;border:2px dashed #ddd;border-radius:12px;cursor:pointer;flex:1 1;flex-direction:column;justify-content:center;padding:40px 20px;transition:all .3s ease;width:100%}.upload-placeholder:hover{background-color:#f8f9ff;border-color:#6c5ce7}.upload-placeholder.drag-over{background-color:#e8f0ff;border-color:#6c5ce7;border-style:solid;box-shadow:0 8px 25px #6c5ce726;transform:scale(1.02);transition:all .3s ease}.upload-placeholder.drag-over .upload-icon{animation:bounce .6s ease-in-out infinite alternate;color:#6c5ce7;font-size:2.5rem}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.upload-icon{color:#6c5ce7;font-size:2rem;margin-bottom:10px}.or-text{color:#999;font-size:.9rem}.upload-button{background-color:#6c5ce7;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:all .3s ease}.upload-button:hover{background-color:#5a4bd1}.format-hint{color:#666;font-size:.8rem}.format-hint,.login-hint{margin-top:10px;text-align:center}.login-hint{animation:pulse 2s ease-in-out infinite;background-color:#f0f4ff;border-radius:8px;color:#6c5ce7;font-size:.9rem;padding:8px 15px}.error-message{animation:fadeIn .3s ease-in-out;background-color:#fdeaea;border-left:3px solid #e74c3c;border-radius:5px;color:#e74c3c;font-size:.9rem;margin-top:15px;max-width:90%;padding:10px 15px;text-align:center;white-space:pre-line}.error-with-button{align-items:center;display:flex;flex-direction:column;gap:10px;width:100%}.recharge-button{background-color:#6c5ce7;border:none;border-radius:4px;box-shadow:0 2px 5px #0000001a;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 15px;transition:all .3s ease}.recharge-button:hover{background-color:#5649c0;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.image-preview{align-items:center;background-color:#fafafa;border-radius:8px;display:flex;flex-direction:column;gap:15px;height:100%;justify-content:center;max-height:320px;min-height:220px;padding:10px;position:relative;width:75%}.image-actions-top{gap:10px}.zoom-image-button{align-items:center;background-color:#6c5ce7cc;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:30px;justify-content:center;transition:all .2s ease;width:30px;z-index:10}.zoom-image-button:hover{background-color:#6c5ce7;transform:scale(1.1)}.zoom-image-button.magnifier{font-size:14px}.zoom-icon{display:inline-block;line-height:1}.download-image-button{align-items:center;background-color:#4caf50cc;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:30px;justify-content:center;transition:all .2s ease;width:30px;z-index:10}.download-image-button:hover{background-color:#4caf50;transform:scale(1.1)}.download-icon{display:inline-block;line-height:1}.refine-image-button{align-items:center;background-color:#ffc107cc;border:none;color:#fff;cursor:pointer;display:flex;font-size:16px;height:30px;justify-content:center;transition:all .2s ease;width:30px;z-index:10}.refine-image-button:hover{background-color:#ffc107;transform:scale(1.1)}.refine-icon{display:inline-block;line-height:1}.image-actions{bottom:10px;display:flex;gap:10px;position:absolute;right:10px}.image-modal-overlay{animation:fadeIn .3s ease;height:100%;width:100%}.image-modal-content{background-color:#fff;border-radius:5px;box-shadow:0 5px 15px #0000004d;overflow:auto}.image-modal-content img{display:block}.close-modal-button{align-items:center;background-color:#e74c3ccc;border-radius:50%;display:flex;font-size:20px;font-weight:700;height:30px;justify-content:center;right:10px;top:10px;transition:all .2s ease;width:30px;z-index:1001}.close-modal-button:hover{background-color:#e74c3c;transform:scale(1.1)}.thumbnails-container{align-items:center;border-left:1px solid #ddd;border-radius:0 8px 8px 0;max-height:320px;overflow:visible;padding:10px 0 10px 10px;width:25%}.thumbnails-container,.thumbnails-scroll{background-color:#f5f7ff;display:flex;flex-direction:column;height:100%}.thumbnails-scroll{border-radius:8px;box-shadow:inset 0 0 5px #0000000d;gap:10px;max-height:300px;overflow-y:scroll;padding:10px 5px;position:relative;scrollbar-color:#6c5ce7 #f0f4ff;scrollbar-width:thin;width:100%}.thumbnails-scroll::-webkit-scrollbar{width:6px}.thumbnails-scroll::-webkit-scrollbar-track{background:#f0f4ff;border-radius:10px}.thumbnails-scroll::-webkit-scrollbar-thumb{background-color:#6c5ce7;border:2px solid #f0f4ff;border-radius:10px}.thumbnails-scroll::-webkit-scrollbar-thumb:hover{background-color:#5a4bd1}.thumbnail{border:2px solid #0000;border-radius:6px;cursor:pointer;flex-shrink:0;height:80px;margin-bottom:5px;overflow:hidden;position:relative;transition:all .2s ease;width:100%}.remove-thumbnail-button{align-items:center;background-color:#ff0000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;line-height:1;opacity:0;position:absolute;right:2px;top:2px;transition:opacity .2s ease;width:20px;z-index:10}.thumbnail:hover .remove-thumbnail-button{opacity:.8}.remove-thumbnail-button:hover{background-color:#ff0000e6;opacity:1!important}.thumbnail.active{border-color:#6c5ce7;box-shadow:0 0 0 2px #6c5ce74d}.thumbnail:hover:not(.active){border-color:#ddd}.thumbnail img{height:100%;object-fit:cover;width:100%}.thumbnail-number{background-color:#0009;bottom:5px;font-size:.7rem;right:5px}.main-image-container{display:inline-block;margin:0 auto;max-width:100%;position:relative}.image-preview img{border-radius:8px;box-shadow:0 4px 12px #0000001a;height:auto;margin:0 auto;max-height:220px;max-width:100%;object-fit:contain;width:auto}.remove-image-button{align-items:center;background-color:#ff0000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;line-height:1;opacity:.8;position:absolute;right:5px;top:5px;transition:all .2s ease;width:30px}.remove-image-button:hover{background-color:#ff0000e6;opacity:1;transform:scale(1.1)}.preview-section{display:flex;gap:20px;max-width:1200px}.action-buttons,.preview-section{align-items:center;flex-direction:column;width:100%}.translate-button-container{align-items:center;display:flex;gap:20px;justify-content:center;min-height:48px;width:100%}.inline-progress-container{background-color:#f8f9ff;border:1px solid #e0e7ff;border-radius:8px;display:flex;flex-direction:column;gap:8px;justify-content:center;max-width:400px;min-width:280px;padding:12px 15px}.inline-progress-info{align-items:center;display:flex;gap:8px;margin-bottom:4px}.inline-progress-stage{align-items:center;animation:pulse 1.5s ease-in-out infinite;display:flex;font-size:16px}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.7}}.inline-progress-message{color:#6c5ce7;flex:1 1;font-size:13px;font-weight:500;line-height:1.4}.progress-time-info{color:#888;display:flex;font-size:11px;justify-content:space-between;margin-top:2px}.progress-elapsed{font-weight:500}.progress-estimated{font-style:italic}.inline-progress-bar{background-color:#e0e7ff;box-shadow:inset 0 1px 2px #0000001a;height:6px;width:100%}.inline-progress-bar,.inline-progress-fill{border-radius:3px;overflow:hidden;position:relative}.inline-progress-fill{background:linear-gradient(90deg,#6c5ce7,#a29bfe,#74b9ff);height:100%;transition:width .5s ease-out}.inline-progress-fill:before{animation:progressShimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes progressShimmer{0%{left:-100%}to{left:100%}}.progress-percentage{color:#6c5ce7;font-size:11px;font-weight:600;margin-left:8px;min-width:35px;text-align:right}.reupload-button{align-items:center;background-color:#ff9500;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:48px;justify-content:center;min-width:120px;padding:12px 20px;text-align:center;transition:all .3s ease}.reupload-button:hover{background-color:#e68600}.translate-all-button{align-items:center;background-color:#4cd964;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:48px;justify-content:center;min-width:120px;padding:12px 20px;text-align:center;transition:all .3s ease}.translate-all-button:hover:not(:disabled){background-color:#3cba54}.translate-all-button:disabled{background-color:#9edea4;cursor:not-allowed}.remove-text-button{align-items:center;background-color:#ff6b6b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;height:48px;justify-content:center;margin:0 10px;min-width:120px;padding:12px 20px;text-align:center;transition:all .3s ease}.remove-text-button:hover:not(:disabled){background-color:#ff5252}.remove-text-button:disabled{background-color:#ffb3b3;cursor:not-allowed}.translation-result{background-color:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;padding:20px;text-align:left;width:100%}.translation-result h3{color:#333;font-size:1.2rem;margin-bottom:15px}.translation-result p{color:#555;line-height:1.6}.translation-container{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;display:flex;max-height:550px;min-height:400px;padding:20px;width:100%}.original-image-column{border-right:1px solid #eee}.original-image-column,.translated-image-column{display:flex;flex:1 1;flex-direction:column;padding:15px}.image-display{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;overflow:hidden}.image-display img{border-radius:8px;box-shadow:0 2px 10px #0000001a;max-height:300px;object-fit:contain}.translation-text{background-color:#f8f9ff;border-radius:8px;max-height:100px;overflow-y:auto;width:100%}.translation-text p{color:#555;line-height:1.6}.original-image-column h3,.translated-image-column h3{font-size:1.2rem}.side-thumbnails-container{background-color:#fff;border-radius:0 12px 12px 0;box-shadow:0 4px 12px #0000000d;display:flex;flex-direction:column;height:100%;padding:15px 0;position:absolute;right:-130px;top:0;width:120px}.side-thumbnails-scroll{flex-direction:column;height:100%;overflow-y:auto;padding:5px;scrollbar-color:#6c5ce7 #f0f4ff;scrollbar-width:thin;width:100%}.side-thumbnails-scroll::-webkit-scrollbar{width:4px}.side-thumbnails-scroll::-webkit-scrollbar-track{background:#f0f4ff;border-radius:10px}.side-thumbnails-scroll::-webkit-scrollbar-thumb{background-color:#6c5ce7;border:1px solid #f0f4ff;border-radius:10px}.side-thumbnail{border-radius:6px;flex-shrink:0;height:70px;margin-bottom:5px;transition:all .2s ease;width:100px}.side-thumbnail.active{border-color:#6c5ce7;box-shadow:0 0 0 2px #6c5ce74d}.side-thumbnail:hover:not(.active){border-color:#ddd}.download-all-button{align-items:center;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;border-radius:8px;box-shadow:0 4px 15px #6c5ce74d;cursor:pointer;display:flex;font-size:1rem;height:48px;justify-content:center;min-width:120px;overflow:hidden;padding:12px 20px;position:relative;text-align:center;transition:all .3s ease}.download-all-button:hover{background-color:#388e3c;box-shadow:0 2px 8px #4caf504d;transform:translateY(-2px)}.download-all-button:active{box-shadow:0 1px 3px #4caf5033;transform:translateY(0)}.download-all-button:before{content:""}.download-all-button:disabled{background-color:#a5d6a7;opacity:.7}.download-all-button:disabled:before{content:""}.download-all-button:disabled:after{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;content:"";height:20px;margin-right:10px;position:absolute;width:20px}.progress-container{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:20px 0;padding:15px}.progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.progress-stage{color:#2c3e50;font-weight:600}.progress-message{color:#6c757d;font-size:14px}.progress-bar{background-color:#e9ecef;border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#007bff,#0056b3);border-radius:4px;height:100%;transition:width .3s ease}.batch-limit-error{animation:fadeIn .3s ease-in forwards;background:linear-gradient(135deg,#fff3e0,#fff8e1);border:2px solid #ff9800;border-radius:12px;box-shadow:0 4px 15px #ff980026;margin:15px 0;opacity:0;padding:20px}.batch-limit-error .error-title{border-bottom:1px solid #ffcc80;color:#f57c00;font-size:1.1rem;font-weight:700;margin-bottom:15px;padding-bottom:8px;text-align:center}.batch-limit-error .error-content{color:#e65100;line-height:1.6}.batch-limit-error .error-content p{margin:8px 0}.batch-limit-error .membership-limits{background-color:#fff;border:1px solid #ffcc80;border-radius:8px;margin:15px 0;padding:12px}.batch-limit-error .membership-limits p{font-size:.9rem;margin:5px 0}.batch-limit-error .upgrade-button{background:linear-gradient(135deg,#6c5ce7,#5649c0);border:none;border-radius:8px;box-shadow:0 2px 8px #6c5ce74d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:700;margin-top:15px;padding:10px 20px;transition:all .3s ease;width:100%}.batch-limit-error .upgrade-button:hover{background:linear-gradient(135deg,#5649c0,#4c3fb8);box-shadow:0 4px 15px #6c5ce766;transform:translateY(-1px)}.batch-limit-hint{background-color:#f8f9ff;border:1px solid #e0e7ff;border-radius:6px;color:#666;font-size:.8rem;margin-top:8px;padding:6px 12px;text-align:center}.upgrade-hint-link{color:#6c5ce7;cursor:pointer;font-weight:500;text-decoration:underline;transition:color .3s ease}.upgrade-hint-link:hover{color:#5649c0}.batch-limit-warning{background-color:#fff3e0;box-shadow:0 1px 3px #ff98001a;color:#f57c00;font-size:.9rem;margin:10px 0;padding:8px 15px}.batch-limit-reminder,.batch-limit-warning{border-left:3px solid #ff9800;border-radius:6px;text-align:center}.batch-limit-reminder{background-color:#fff8e1;color:#ff9800;font-size:.85rem;margin-top:10px;padding:8px 12px}.pricing-container{margin:0 auto;max-width:1200px;padding:60px 20px;text-align:center}.pricing-title{color:#333;font-size:2.5rem;font-weight:700;margin-bottom:10px}.pricing-subtitle{color:#666;font-size:1.2rem;margin-bottom:50px}.pricing-plans{display:flex;flex-wrap:wrap;gap:30px;justify-content:center}.pricing-card{background-color:#fff;border-radius:12px;box-shadow:0 5px 20px #0000000d;display:flex;flex-direction:column;padding:40px 30px;position:relative;transition:all .3s ease;width:300px}.pricing-card:hover{box-shadow:0 10px 30px #0000001a;transform:translateY(-10px)}.pricing-card.featured{border:2px solid #6c5ce7;transform:scale(1.05)}.pricing-card.featured:hover{transform:scale(1.05) translateY(-10px)}.plan-name{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:20px}.plan-price{margin-bottom:30px}.price{color:#6c5ce7;font-size:3rem;font-weight:700}.period{color:#888;font-size:1rem}.contact{color:#6c5ce7;font-size:1.8rem;font-weight:700}.plan-features{flex-grow:1;list-style:none;margin:0 0 30px;padding:0;text-align:left}.plan-features li{color:#555;font-size:1rem;padding:10px 0 10px 25px;position:relative}.plan-features li:before{color:#6c5ce7;content:"✓";font-weight:700;left:0;position:absolute}.plan-button{background-color:#6c5ce7;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 0;transition:all .3s ease;width:100%}.plan-button:hover{background-color:#5a4bd1}.contact-button{background-color:#fff;border:2px solid #6c5ce7;color:#6c5ce7}.contact-button:hover{background-color:#f8f7ff}@media (max-width:768px){.pricing-plans{align-items:center;flex-direction:column}.pricing-card{margin-bottom:30px;max-width:350px;width:100%}.pricing-card.featured{order:-1;transform:none}.pricing-card.featured:hover{transform:translateY(-10px)}}.payment-container{background:#f5f5f5;margin:0 auto;max-width:1200px;min-height:calc(100vh - 160px);padding:20px}.payment-content{align-items:flex-start;display:flex;gap:20px}.payment-header{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:20px}.payment-title{font-size:1.8rem;margin:0}.left-section{display:flex;flex:2 1;flex-direction:column;gap:20px}.right-section{display:flex;flex:1 1;flex-direction:column;gap:20px}.order-info-card,.payment-method-card,.price-summary-card,.product-info-card{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.card-header{background:#fafafa;border-bottom:1px solid #e5e5e5;padding:15px 20px}.card-title{color:#333;font-size:1.1rem;font-weight:600;margin:0}.order-details{padding:20px}.order-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.order-row:last-child{border-bottom:none}.order-row .label{color:#666;font-size:.95rem;font-weight:500}.order-row .value{color:#333;font-family:Monaco,Menlo,monospace;font-size:.95rem;font-weight:500}.product-list{padding:20px}.product-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:15px 0}.product-item:last-child{border-bottom:none}.product-main{flex:1 1;gap:15px}.product-icon,.product-main{align-items:center;display:flex}.product-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;font-size:1.5rem;height:50px;justify-content:center;width:50px}.product-details{flex:1 1}.product-name{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:8px}.product-meta{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.product-expiry,.product-quantity{color:#666;font-size:.9rem}.product-quantity{font-weight:500}.product-expiry{color:#1890ff;font-weight:500}.product-features{display:flex;flex-wrap:wrap;gap:8px}.feature-tag{background:#f0f8f0;border:1px solid #d9f7be;border-radius:4px;color:#52c41a;font-size:.85rem;padding:2px 8px}.product-price{text-align:right}.price-summary-card{padding:20px}.promo-code-section{border-bottom:1px solid #f0f0f0;border-top:1px solid #f0f0f0;margin:10px 0;padding:15px 0}.promo-code-label{color:#666;font-size:.95rem;font-weight:500;margin-bottom:10px}.promo-code-input-area{display:flex;flex-direction:column;gap:8px}.promo-code-input-group{align-items:center;display:flex;gap:8px}.promo-code-input{border:1px solid #d9d9d9;border-radius:4px;flex:1 1;font-size:.9rem;padding:8px 12px;text-transform:uppercase;transition:all .2s ease}.promo-code-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a;outline:none}.promo-code-input.error{border-color:#ff4d4f}.promo-code-input.success{border-color:#52c41a}.promo-code-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.promo-code-btn{background:#1890ff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.9rem;min-width:80px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.promo-code-btn:hover:not(:disabled){background:#40a9ff}.promo-code-btn.loading,.promo-code-btn:disabled{background:#d9d9d9;cursor:not-allowed}.promo-code-message{align-items:center;animation:slideIn .3s ease;border-radius:4px;display:flex;font-size:.85rem;gap:6px;padding:6px 12px}.promo-code-message.error{background:#fff2f0;border:1px solid #ffccc7;color:#ff4d4f}.promo-code-message.success{background:#f6ffed;border:1px solid #b7eb8f;color:#52c41a}.message-icon{font-size:.8rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.discount-row{color:#52c41a!important;font-weight:500}.discount-value{color:#52c41a!important;font-weight:600}.discounted-price{align-items:flex-end;display:flex;flex-direction:column;gap:4px;margin-top:8px}.final-price{color:#52c41a;font-size:1.1rem;font-weight:600}.discount-badge{background:#52c41a;border-radius:4px;color:#fff;font-size:.75rem;font-weight:500;padding:2px 6px}.current-price{color:#ff4757;font-size:1.3rem;font-weight:600}.current-price.discounted{color:#999!important;font-size:1.1rem;font-weight:400;text-decoration:line-through}.price-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.price-row:last-child{border-bottom:none}.price-row.total-row{border-top:1px solid #e5e5e5;font-weight:600;margin-top:10px;padding-top:15px}.price-label{color:#666;font-size:.95rem}.price-value{color:#333;font-size:.95rem;font-weight:500}.total-price{color:#ff4757;font-size:1.1rem;font-weight:600}.payment-method-card{padding:20px}.payment-title{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 15px}.payment-options{display:flex;flex-direction:column;gap:12px}.payment-option{align-items:center;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;padding:15px;transition:all .3s ease}.payment-option:hover{background:#f8fdff;border-color:#1890ff}.payment-option.selected{background:#e6f7ff;border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a}.payment-option.disabled{cursor:not-allowed;opacity:.5}.payment-option.disabled,.payment-option.disabled:hover{background:#f5f5f5;border-color:#d9d9d9}.payment-option.disabled .payment-name{color:#999}.payment-option.disabled .payment-icon{opacity:.6}.payment-left{gap:12px}.payment-icon,.payment-left{align-items:center;display:flex}.payment-icon{border-radius:4px;height:32px;justify-content:center;width:32px}.payment-icon img{height:28px;object-fit:contain;width:28px}.payment-name{color:#333;font-size:1rem;font-weight:500;position:relative}.payment-disabled-text{color:#999;font-size:.75rem;font-weight:400;margin-left:4px}.radio-check{align-items:center;border:2px solid #d9d9d9;border-radius:50%;display:flex;height:20px;justify-content:center;transition:all .3s ease;width:20px}.payment-option.selected .radio-check{background:#1890ff;border-color:#1890ff}.check-icon{color:#fff;font-size:.8rem;font-weight:700}.submit-section{display:flex;flex-direction:column;gap:12px}.submit-button{background:linear-gradient(135deg,#1890ff,#096dd9);border:none;border-radius:6px;box-shadow:0 2px 4px #1890ff33;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:15px;transition:all .3s ease;width:100%}.submit-button:hover:not(:disabled){background:linear-gradient(135deg,#40a9ff,#1890ff);box-shadow:0 4px 8px #1890ff4d;transform:translateY(-1px)}.submit-button:disabled{background:#f5f5f5;box-shadow:none;color:#bfbfbf;cursor:not-allowed;transform:none}.cancel-link{background:#0000;border:1px solid #d9d9d9;border-radius:6px;color:#666;cursor:pointer;font-size:.95rem;padding:12px;transition:all .3s ease;width:100%}.cancel-link:hover:not(:disabled){background:#f8fdff;border-color:#1890ff;color:#1890ff}.qrcode-payment-card{animation:fadeInScale .3s ease-out;background:#fff;border:2px solid #1890ff;border-radius:6px;box-shadow:0 1px 3px #0000001a;overflow:hidden}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.qrcode-header{align-items:center;background:linear-gradient(135deg,#e6f7ff,#bae7ff);border-bottom:1px solid #91d5ff;display:flex;justify-content:space-between;padding:15px 20px}.qrcode-title{color:#1890ff;font-size:1.1rem;font-weight:600;margin:0}.close-qrcode-btn{align-items:center;background:#fffc;border:1px solid #d9d9d9;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;transition:all .2s ease;width:28px}.close-qrcode-btn:hover{background:#fff;border-color:#ff4757;color:#ff4757;transform:scale(1.1)}.qrcode-container{align-items:center;background:#fafafa;border-bottom:1px solid #f0f0f0;display:flex;justify-content:center;min-height:325px;padding:15px}.qrcode-iframe{background:#fff;border:none;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:block;height:315px;max-height:375px;min-height:300px;width:100%}.payment-status{align-items:center;animation:pulse 2s infinite;border-radius:6px;display:flex;font-size:.95rem;font-weight:500;gap:8px;justify-content:center;margin:0 20px;padding:12px 20px}.status-pending{background:#fff7e6;border:1px solid #ffd591;color:#fa8c16}.status-success{animation:successPulse .6s ease-out;background:#f6ffed;border:1px solid #b7eb8f;color:#52c41a}.status-failed{background:#fff2f0;border:1px solid #ffccc7;color:#ff4d4f}.status-timeout{background:#f5f5f5;border:1px solid #d9d9d9;color:#8c8c8c}.status-icon{font-size:1.1rem}.status-text{font-weight:500}@keyframes successPulse{0%{box-shadow:0 0 0 0 #52c41a66;transform:scale(1)}50%{box-shadow:0 0 0 10px #52c41a00;transform:scale(1.05)}to{box-shadow:0 0 0 0 #52c41a00;transform:scale(1)}}.qrcode-actions{align-items:center;display:flex;flex-direction:column;gap:12px;padding:20px}.check-status-btn{background:linear-gradient(135deg,#52c41a,#389e0d);border:none;border-radius:6px;box-shadow:0 2px 4px #52c41a33;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .3s ease}.check-status-btn:hover:not(:disabled){background:linear-gradient(135deg,#73d13d,#52c41a);box-shadow:0 4px 8px #52c41a4d;transform:translateY(-1px)}.check-status-btn:disabled{background:#f5f5f5;box-shadow:none;color:#bfbfbf;cursor:not-allowed;transform:none}.order-info-small{color:#8c8c8c;font-family:Monaco,Menlo,monospace;font-size:.85rem;text-align:center}@media (max-width:768px){.payment-container{padding:15px}.payment-content{flex-direction:column;gap:15px}.left-section,.right-section{flex:1 1}.payment-header{padding:15px}.payment-title{font-size:1.5rem}.card-header{padding:12px 15px}.card-title{font-size:1rem}.order-details,.payment-method-card,.price-summary-card,.product-list{padding:15px}.product-main{gap:12px}.product-icon{font-size:1.2rem;height:40px;width:40px}.feature-tag{font-size:.8rem;padding:1px 6px}.promo-code-section{padding:12px 0}.promo-code-label{font-size:.9rem;margin-bottom:8px}.promo-code-input-group{flex-direction:column;gap:10px}.promo-code-input{font-size:.95rem;padding:10px 12px}.promo-code-btn{font-size:.95rem;padding:10px 16px;width:100%}.promo-code-message{font-size:.9rem;padding:8px 12px}.discounted-price{margin-top:6px}.final-price{font-size:1rem}.discount-badge{font-size:.7rem;padding:1px 4px}.qrcode-header{padding:12px 15px}.qrcode-title{font-size:1rem}.qrcode-container{padding:15px}.qrcode-iframe{min-height:300px}.qrcode-actions{padding:15px}.payment-status{font-size:.9rem;margin:0 15px;padding:10px 15px}}.pay-button:disabled{animation:pulse 1s infinite}.payment-processing-modal{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.payment-modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;max-height:50vh;max-width:750px;overflow:hidden;padding:0;position:relative;width:95%}.payment-modal-header{align-items:center;background:#1677ff;color:#fff;display:flex;justify-content:space-between;padding:20px 20px 15px;position:relative}.payment-modal-header h3{font-size:1.1rem;font-weight:500;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .2s;width:30px}.close-button:hover{background:#fff3}.payment-status-area{background:#f8f9fa;border-top:1px solid #e9ecef;padding:20px;text-align:center}.payment-waiting{align-items:center;display:flex;flex-direction:column;gap:15px}.payment-waiting p{align-items:center;color:#666;display:flex;font-size:.95rem;gap:8px;margin:0}.payment-waiting .hourglass{animation:rotate 2s linear infinite;font-size:1.2rem}@media (max-width:768px){.payment-modal-content{margin:10px;max-height:45vh;max-width:95vw;width:98%}.qrcode-iframe{height:290px;min-height:275px}.qrcode-container{min-height:310px;padding:15px}}@media (min-width:769px) and (max-width:1024px){.payment-modal-content{max-height:48vh;max-width:650px}.qrcode-iframe{height:300px}.qrcode-container{min-height:320px}}@media (min-width:1025px){.payment-modal-content{max-width:750px}.qrcode-iframe{height:315px}}.payment-result{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.payment-result-container{animation:slideUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000026;max-width:600px;padding:40px;position:relative;text-align:center;width:100%;z-index:10}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.status-section{margin-bottom:30px}.status-icon{animation:iconBounce .8s ease-out;display:block;font-size:80px;margin-bottom:20px}@keyframes iconBounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.status-icon.success{animation:iconBounce .8s ease-out,pulse 2s infinite}.status-title{font-size:32px;font-weight:700;letter-spacing:-.5px;margin-bottom:15px}.status-title.success{color:#52c41a}.status-title.error{color:#ff4d4f}.status-title.pending{color:#1890ff}.status-title.loading{color:#722ed1}.status-title.unknown{color:#8c8c8c}.status-message{color:#666;font-size:18px;line-height:1.6;margin-bottom:0}.order-info-section,.url-params-section,.user-info-section{background:#f8f9fa;border:1px solid #e8e8e8;border-radius:12px;margin:25px 0;padding:25px;text-align:left}.order-info-section h3,.url-params-section h3,.user-info-section h3{align-items:center;color:#333;display:flex;font-size:18px;font-weight:600;gap:8px;margin-bottom:20px}.order-details,.user-details{display:flex;flex-direction:column;gap:12px}.order-item,.user-item{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:8px 0}.order-item:last-child,.user-item:last-child{border-bottom:none}.order-item .label,.user-item .label{color:#666;font-weight:500;min-width:120px}.order-item .value,.user-item .value{color:#333;flex:1 1;font-weight:600;text-align:right;word-break:break-all}.value.amount{color:#f5222d;font-size:18px;font-weight:700}.value.status.success{color:#52c41a}.value.status.error{color:#ff4d4f}.value.status.pending{color:#1890ff}.value.membership.pro{color:#722ed1}.value.membership.free{color:#8c8c8c}.value.points{color:#1890ff;font-weight:700}.action-buttons{display:flex;flex-wrap:wrap;gap:15px;margin:30px 0}.action-buttons,.btn{justify-content:center}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;min-width:140px;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,#1890ff,#40a9ff);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#40a9ff,#69c0ff)}.btn-secondary{background:#f0f0f0;border:1px solid #d9d9d9;color:#333}.btn-secondary:hover{background:#e6f7ff;border-color:#91d5ff;color:#1890ff}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn:disabled:hover{box-shadow:none;transform:none}.support-section{border-top:1px solid #f0f0f0;margin:30px 0 20px;padding-top:20px}.support-text{color:#666;font-size:14px;margin:0}.support-link{color:#1890ff;margin-left:5px;text-decoration:none}.support-link:hover{text-decoration:underline}.footer-section{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:15px}.footer-section p{color:#999;font-size:12px;margin:0}.success-animation{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.confetti{animation:confetti-fall 3s linear infinite;background:gold;height:10px;position:absolute;width:10px}.confetti:first-child{animation-delay:0s;background:#ff6b6b;left:10%}.confetti:nth-child(2){animation-delay:.5s;background:#4ecdc4;left:30%}.confetti:nth-child(3){animation-delay:1s;background:#45b7d1;left:50%}.confetti:nth-child(4){animation-delay:1.5s;background:#f9ca24;left:70%}.confetti:nth-child(5){animation-delay:2s;background:#6c5ce7;left:90%}@keyframes confetti-fall{0%{opacity:1;transform:translateY(-100vh) rotate(0deg)}to{opacity:0;transform:translateY(100vh) rotate(2turn)}}.status-icon.loading{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.payment-result{padding:15px}.payment-result-container{margin:0;padding:30px 20px}.status-icon{font-size:60px}.status-title{font-size:24px}.status-message{font-size:16px}.action-buttons{flex-direction:column;gap:12px}.btn{min-width:auto;width:100%}.order-item,.user-item{align-items:flex-start;flex-direction:column;gap:5px}.order-item .label,.user-item .label{min-width:auto}.order-item .value,.user-item .value{text-align:left}}@media (max-width:480px){.payment-result-container{padding:25px 15px}.status-icon{font-size:48px}.status-title{font-size:20px}.order-info-section,.url-params-section,.user-info-section{padding:20px 15px}}.payment-result-container.success{border:2px solid #52c41a}.payment-result-container.error{border:2px solid #ff4d4f}.payment-result-container.pending{border:2px solid #1890ff}@media (prefers-color-scheme:dark){.payment-result{background:linear-gradient(135deg,#2c3e50,#34495e)}.payment-result-container{background:#1f1f1f;color:#fff}.order-info-section,.url-params-section,.user-info-section{background:#2a2a2a;border-color:#404040}.order-item .label,.user-item .label{color:#bbb}.order-item .value,.user-item .value{color:#fff}.btn-secondary{background:#404040;border-color:#606060;color:#fff}.support-text{color:#bbb}.footer-section p{color:#888}}.auth-container{align-items:center;background-color:#f5f7fa;display:flex;justify-content:center;min-height:calc(100vh - 70px);padding:40px 20px}.auth-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;max-width:450px;padding:40px;width:100%}.auth-title{color:#333;font-size:1.8rem;margin-bottom:10px;text-align:center}.auth-subtitle{color:#666;margin-bottom:30px;text-align:center}.auth-error{background-color:#fff2f0;color:#ff4d4f}.auth-error,.auth-success{border-radius:8px;font-size:.9rem;margin-bottom:20px;padding:10px 15px}.auth-success{background-color:#f6ffed;color:#52c41a}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#333;font-size:.9rem;font-weight:500}.form-group input{border:1px solid #ddd;border-radius:8px;font-size:1rem;padding:12px 15px;transition:all .3s ease}.form-group input:focus{border-color:#6c5ce7;box-shadow:0 0 0 2px #6c5ce71a;outline:none}.password-label-group{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.forgot-password-link{color:#6c5ce7;font-size:.85rem;text-decoration:none}.forgot-password-link:hover{text-decoration:underline}.code-input-container,.code-input-group{display:flex;gap:10px}.code-input-group input{flex:1 1}.code-btn{background-color:#f0f4ff;border:none;border-radius:8px;color:#6c5ce7;cursor:pointer;font-size:.9rem;padding:0 15px;transition:all .3s ease;white-space:nowrap}.code-btn:hover:not(:disabled){background-color:#e0e7ff}.code-btn:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.code-input-container input{flex:1 1}.send-code-btn{background-color:#f0f4ff;border:none;border-radius:8px;color:#6c5ce7;cursor:pointer;font-size:.9rem;padding:0 15px;transition:all .3s ease;white-space:nowrap}.send-code-btn:hover:not(:disabled){background-color:#e0e7ff}.send-code-btn:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.auth-submit-btn{background-color:#6c5ce7;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;margin-top:10px;padding:14px;transition:all .3s ease}.auth-submit-btn:hover:not(:disabled){background-color:#5a4bd1}.auth-submit-btn:disabled{background-color:#a29ddb;cursor:not-allowed}.auth-agreement{color:#999;font-size:.8rem;margin-top:30px;text-align:center}.auth-agreement a{color:#6c5ce7;text-decoration:none}.auth-agreement a:hover{text-decoration:underline}.profile-container{margin:0 auto;max-width:600px;padding:20px}.profile-header{align-items:center;display:flex;gap:20px;margin-bottom:30px}.profile-avatar{align-items:center;background-color:#6c5ce7;border-radius:50%;color:#fff;display:flex;font-size:2rem;font-weight:700;height:80px;justify-content:center;width:80px}.profile-info h2{font-size:1.5rem;margin:0 0 5px}.profile-info p{color:#666;margin:0}.profile-badge{background-color:#f0f4ff;border-radius:4px;color:#6c5ce7;display:inline-block;font-size:.8rem;margin-left:10px;padding:3px 8px}.profile-section{margin-bottom:30px}.profile-section h3{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:10px}.profile-logout{background-color:#f5f5f5;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:.9rem;padding:10px 15px;transition:all .3s ease}.profile-logout:hover{background-color:#e0e0e0}.result-page{background-color:#f5f5f5;display:flex;flex-direction:column;font-family:PingFang SC,Microsoft YaHei,sans-serif;height:100vh;overflow:hidden;width:100%}.result-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.result-header h1{color:#333;font-size:24px;margin:0}.result-actions{display:flex;gap:10px}.back-button,.download-all-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s}.back-button:hover,.download-all-button:hover{background-color:#e0e0e0}.download-all-button{background-color:#1890ff;border-color:#1890ff;color:#fff}.download-all-button:hover{background-color:#40a9ff;border-color:#40a9ff}.download-all-button:disabled{background-color:#ccc;border-color:#ccc;cursor:not-allowed}.loading-overlay{align-items:center;background-color:#fffc;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-spinner{border:5px solid #f3f3f3;border-top-color:#1890ff;height:50px;width:50px}.loading-text{color:#333;font-size:16px;margin-top:20px}.message-container{background-color:#f0f8ff;border-bottom:1px solid #e0e0e0;border-left:4px solid #1890ff;flex-shrink:0;margin:0;padding:10px 20px}.message{color:#333;font-size:14px}.language-info{align-items:center;background-color:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;padding:15px 20px}.language-text{color:#333;font-size:16px;font-weight:500}.translation-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;grid-template-rows:auto;position:relative}.original-image-column,.translated-image-column{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:15px}.original-image-column h3,.translated-image-column h3{color:#333;font-size:18px;margin-bottom:15px;margin-top:0;text-align:center}.image-display{position:relative;text-align:center}.image-display img{border-radius:4px;max-height:400px;max-width:100%}.translation-text{background-color:#f5f5f5;border-radius:4px;margin-top:15px;padding:10px;text-align:left}.translation-text p{line-height:1.5;margin:0}.image-actions-top{display:flex;gap:5px;justify-content:flex-end;margin-bottom:10px}.download-image-button,.refine-image-button,.refine-image-button-top,.zoom-image-button{background:none;border:none;border-radius:50%;color:#666;cursor:pointer;font-size:18px;padding:5px;transition:background-color .3s}.download-image-button:hover,.refine-image-button-top:hover,.refine-image-button:hover,.zoom-image-button:hover{background-color:#f0f0f0}.refine-image-button{background-color:#fffc;border-radius:50%;bottom:10px;box-shadow:0 2px 5px #0003;padding:8px;position:absolute;right:10px}.side-thumbnails-container{grid-column:1/span 2;margin-top:20px;overflow:hidden}.side-thumbnails-scroll{display:flex;gap:10px;overflow-x:auto;padding:10px 0}.side-thumbnail{background-color:#fff;border:2px solid #0000;border-radius:4px;cursor:pointer;flex:0 0 100px;height:100px;overflow:hidden;position:relative;transition:all .3s}.side-thumbnail.active{border-color:#1890ff}.thumbnail-image-container{height:100%;overflow:hidden;position:relative;width:100%}.side-thumbnail img{display:block;height:100%;object-fit:cover;width:100%;z-index:1}.thumbnail-number{background-color:#0006;border-radius:10px;color:#fff;font-size:12px;height:auto;left:5px;padding:2px 6px;pointer-events:none;position:absolute;top:5px;width:auto;z-index:2}.image-modal-overlay{align-items:center;background-color:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.image-modal-content{max-height:90%;max-width:90%;position:relative}.image-modal-content img{max-height:90vh;max-width:100%;object-fit:contain}.close-modal-button{background:none;border:none;color:#fff;cursor:pointer;font-size:30px;position:absolute;right:0;top:-40px}.result-content{display:flex;flex:1 1;overflow:hidden}.result-thumbnail-panel{background-color:#fff;border-right:1px solid #e0e0e0;overflow-y:auto;padding:10px;width:80px}.result-thumbnails-scroll{display:flex;flex-direction:column;gap:10px}.result-thumbnail-container{border:2px solid #0000;border-radius:4px;cursor:pointer;height:60px;overflow:hidden;position:relative;transition:all .3s ease;width:60px}.result-thumbnail-container.selected{border-color:#1890ff}.result-thumbnail-container img{height:100%;object-fit:cover;width:100%}.result-thumbnail-check{align-items:center;background-color:#1890ff;border-radius:50%;bottom:2px;color:#fff;display:flex;font-size:10px;height:14px;justify-content:center;position:absolute;right:2px;width:14px}.result-thumbnail-number{background-color:#0009;border-radius:8px;color:#fff;font-size:10px;left:2px;min-width:16px;padding:2px 4px;position:absolute;text-align:center;top:2px}.result-edit-panel{align-items:stretch;background-color:#f0f0f0;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:10px}.result-image-comparison{display:flex;gap:10px;height:100%;overflow:hidden;width:100%}.result-image-column{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.result-image-header{align-items:center;background-color:#f8f8f8;border-bottom:1px solid #e0e0e0;color:#333;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:12px 15px}.result-image-actions{display:flex;gap:5px}.result-image-container{align-items:center;background-color:#f8f8f8;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:0;overflow:hidden;padding:10px;position:relative}.result-image-container img{display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;width:auto}.result-translation-text{background-color:#fffffff2;border-radius:4px;bottom:10px;box-shadow:0 2px 8px #0000001a;color:#333;font-size:13px;left:10px;line-height:1.4;max-height:80px;overflow-y:auto;padding:8px 12px;position:absolute;right:10px}.result-translation-text p{margin:0}.download-image-button,.refine-image-button-top,.zoom-image-button{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:16px;height:28px;justify-content:center;padding:4px;transition:background-color .3s;width:28px}.download-image-button:hover,.refine-image-button-top:hover,.zoom-image-button:hover{background-color:#f0f0f0}@media (max-width:768px){.result-content{flex-direction:column}.result-thumbnail-panel{display:flex;height:80px;overflow-x:auto;padding:5px 10px;width:100%}.result-thumbnails-scroll{flex-direction:row;gap:10px}.result-thumbnail-container{flex-shrink:0}.result-image-comparison{flex-direction:column;height:auto;min-height:400px}.result-image-column{min-height:200px}.result-translation-text{margin-top:10px;position:static}}.rendering-indicator{animation:pulse 2s ease-in-out infinite;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000c;border:1px solid #fff3;border-radius:8px;color:#fff;font-size:14px;left:50%;padding:8px 16px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:10}.rendering-indicator span{align-items:center;display:flex;gap:8px}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}.history-page{background:#f5f5f5;min-height:100vh;padding:20px}.history-container{background:#fff;border-radius:12px;box-shadow:0 2px 12px #0000001a;margin:0 auto;max-width:1200px;overflow:hidden}.history-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 30px}.history-header h1{color:#1f2937;font-size:24px;font-weight:600;margin:0}.refresh-button{background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.refresh-button:hover{background:#4f46e5;transform:translateY(-1px)}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 40px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f4f6;border-radius:50%;border-top-color:#6366f1;height:32px;margin-bottom:16px;width:32px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:80px 40px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-container h3{color:#dc2626;font-size:20px;margin-bottom:8px}.error-container p{color:#6b7280;font-size:16px;margin-bottom:24px}.retry-button{background:#6366f1;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.retry-button:hover{background:#4f46e5;transform:translateY(-1px)}.history-content{padding:30px}.pagination-info{background:#f8fafc;border-radius:8px;color:#6b7280;font-size:14px;font-weight:500;margin-bottom:20px;padding:10px}.empty-state,.pagination-info{display:flex;justify-content:center}.empty-state{align-items:center;flex-direction:column;padding:80px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state h3{color:#374151;font-size:20px;margin-bottom:10px}.empty-state p{color:#6b7280;font-size:16px}.empty-state a{color:#6366f1;font-weight:500;text-decoration:none}.empty-state a:hover{text-decoration:underline}.history-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:0}.history-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;overflow:hidden;transition:all .2s ease}.history-card:hover{border-color:#6366f1;box-shadow:0 8px 25px #0000001a;transform:translateY(-2px)}.history-image{background:#f8fafc;height:180px}.history-image,.placeholder-image{align-items:center;display:flex;justify-content:center;position:relative;width:100%}.placeholder-image{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);color:#64748b;flex-direction:column;height:100%}.placeholder-text{font-size:16px;font-weight:500;margin-bottom:8px}.image-badge{background:#000000b3;border-radius:6px;color:#fff;font-size:12px;font-weight:500;padding:4px 8px;position:absolute;right:12px;top:12px}.history-info{padding:16px}.language-pair{align-items:center;display:flex;gap:8px;margin-bottom:12px}.src-lang,.tgt-lang{background:#6366f1;border-radius:6px;color:#fff;font-size:12px;font-weight:500;padding:4px 8px}.tgt-lang{background:#10b981}.arrow{color:#6b7280;font-size:16px;font-weight:600}.history-time{color:#6b7280;font-size:14px;margin-bottom:8px}.image-count{color:#374151;font-size:14px;font-weight:500}.pagination{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:30px;padding:20px 0}.pagination-btn{background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;min-width:40px;padding:8px 12px;transition:all .2s ease}.pagination-btn:hover:not(.disabled){background:#f3f4f6;border-color:#6366f1;color:#6366f1}.pagination-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.pagination-btn.active:hover{background:#4f46e5;border-color:#4f46e5}.pagination-btn.disabled{background:#f9fafb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed}.pagination-btn.page-number{align-items:center;display:flex;height:36px;justify-content:center;min-width:36px}@media (max-width:768px){.history-page{padding:10px}.history-header{flex-direction:column;gap:12px;padding:16px 20px;text-align:center}.history-header h1{font-size:20px}.history-content{padding:20px}.pagination-info{font-size:13px;margin-bottom:16px;padding:8px}.history-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.history-image{height:160px}.history-info{padding:12px}.language-pair{gap:6px;margin-bottom:10px}.src-lang,.tgt-lang{font-size:11px;padding:3px 6px}.arrow{font-size:14px}.pagination{flex-wrap:wrap;gap:6px;margin-top:20px;padding:15px 0}.pagination-btn{font-size:13px;min-width:32px;padding:6px 10px}.pagination-btn.page-number{height:32px;min-width:32px}}@media (max-width:480px){.history-grid{gap:12px;grid-template-columns:1fr}.history-image{height:140px}.pagination{gap:4px;padding:10px 0}.pagination-btn{font-size:12px;min-width:28px;padding:5px 8px}.pagination-btn.page-number{height:28px;min-width:28px}}