.photos-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.photos-modal-content{background:#fff;border-radius:20px;width:100%;max-width:360px;max-height:80vh;overflow:hidden;position:relative;display:flex;flex-direction:column}.photos-modal-content .modal-header{flex-shrink:0}.photos-modal-content .photos-grid{flex:1;overflow-y:auto;max-height:calc(80vh - 60px)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f0f0f0}.modal-header h4{font-size:18px;font-weight:600;color:#333;margin:0}.close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:50%;cursor:pointer;color:#666;transition:all .2s}.close-btn:hover{background:#e0e0e0}.photos-grid{display:flex;padding:20px;gap:16px}.gender-column{flex:1;display:flex;flex-direction:column}.column-header{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:12px;font-size:15px;font-weight:600;margin-bottom:12px}.column-header.male{background:#e8f4fd;color:#4a90d9}.column-header.female{background:#fff5f7;color:#ff6b9d}.gender-icon{font-size:18px}.angle-list{display:flex;flex-direction:column;gap:12px}.photo-cell{aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;position:relative;transition:all .2s}.photo-cell.empty{background:#f9f9f9;border:2px dashed #e0e0e0;display:flex;flex-direction:column;align-items:center;justify-content:center}.photo-cell.has-photo{background:#000}.photo-cell img{width:100%;height:100%;object-fit:cover;display:block}.cell-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.photo-cell:hover .cell-overlay{opacity:1}.replace-text{color:#fff;font-size:12px;font-weight:500}.empty-icon{font-size:24px;color:#ccc;margin-bottom:4px}.angle-label{font-size:12px;color:#999}.uploading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10}.spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #ff6b9d;border-radius:50%;animation:spin .8s linear infinite}.albums-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.albums-modal-content{width:100%;max-width:420px;max-height:70vh;background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;animation:slideUp .25s ease}.albums-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid #f0f0f0}.albums-modal-header h4{margin:0;font-size:17px;font-weight:600;color:#333}.albums-close-btn{background:none;border:none;color:#999;cursor:pointer;padding:4px;display:flex;border-radius:50%}.albums-close-btn:active{background:#f5f5f5}.albums-body{flex:1;overflow-y:auto;padding:12px 20px 24px}.albums-loading,.albums-empty{text-align:center;padding:40px 0;color:#999;font-size:14px}.albums-empty p{margin:0 0 16px}.albums-create-btn{padding:10px 28px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer}.albums-create-form{margin-bottom:16px;padding:14px;background:#f9f9f9;border-radius:12px;display:flex;flex-direction:column;gap:10px}.albums-input{padding:10px 14px;border:1px solid #e0e0e0;border-radius:10px;font-size:14px;outline:none;background:#fff}.albums-input:focus{border-color:#ff6b9d}.albums-form-actions{display:flex;gap:10px;justify-content:flex-end}.albums-cancel-btn{padding:8px 18px;border:1px solid #ddd;border-radius:16px;background:#fff;color:#666;font-size:13px;cursor:pointer}.albums-submit-btn{padding:8px 18px;border:none;border-radius:16px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:13px;font-weight:500;cursor:pointer}.albums-submit-btn:disabled{opacity:.5}.albums-list{display:flex;flex-direction:column;gap:2px}.albums-item{display:flex;align-items:center;gap:12px;padding:12px 8px;border-radius:12px;cursor:pointer;transition:background .15s}.albums-item:active{background:#f5f5f5}.albums-item-cover{width:48px;height:48px;border-radius:10px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.albums-item-cover img{width:100%;height:100%;object-fit:cover}.albums-item-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.albums-item-name{font-size:15px;font-weight:500;color:#333}.albums-item-desc{font-size:12px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.albums-add-btn{margin-top:12px;width:100%;padding:12px;border:1px dashed #ddd;border-radius:12px;background:transparent;color:#999;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px}.albums-add-btn:active{background:#f9f9f9}.toast-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:9999;pointer-events:none;animation:toast-fade-in .25s ease-out}.toast-message{background:#000000bf;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;line-height:1.5;max-width:260px;text-align:center;word-break:break-all;box-shadow:0 4px 12px #00000026;animation:toast-scale-in .25s ease-out}@keyframes toast-fade-in{0%{opacity:0}to{opacity:1}}@keyframes toast-scale-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.login-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.login-modal-content{background:#fff;border-radius:20px;width:100%;max-width:340px;padding:28px 24px;position:relative;animation:loginSlideUp .3s ease}@keyframes loginSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-close-btn{position:absolute;top:16px;right:16px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#f5f5f5;border:none;border-radius:50%;cursor:pointer;color:#999;transition:all .2s}.login-close-btn:hover{background:#e8e8e8;color:#666}.login-header{text-align:center;margin-bottom:24px}.login-header h3{font-size:20px;font-weight:600;color:#333;margin:0 0 6px}.login-header p{font-size:13px;color:#999;margin:0}.login-form{display:flex;flex-direction:column;gap:14px}.login-input-group{display:flex;align-items:center;border:1px solid #e8e8e8;border-radius:12px;overflow:hidden;transition:border-color .2s}.login-input-group:focus-within{border-color:#ff6b9d}.login-input-prefix{padding:0 12px;font-size:14px;color:#666;font-weight:500;border-right:1px solid #e8e8e8;line-height:44px;flex-shrink:0}.login-input-group input{flex:1;border:none;outline:none;padding:12px 14px;font-size:15px;color:#333;background:transparent}.login-input-group input::placeholder{color:#ccc}.code-group{gap:0}.code-group input{flex:1;min-width:0}.send-code-btn{padding:0 16px;height:44px;border:none;background:transparent;color:#ff6b9d;font-size:14px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s;border-left:1px solid #e8e8e8;flex-shrink:0}.send-code-btn:disabled{color:#ccc;cursor:not-allowed}.send-code-btn:not(:disabled):hover{color:#ff4d88}.login-error{color:#ff4d4f;font-size:13px;text-align:center;padding:4px 0}.login-code-hint{color:#999;font-size:12px;text-align:center;padding:2px 0}.login-submit-btn{width:100%;padding:14px;border:none;border-radius:12px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-submit-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b9d4d}.login-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:loginSpin .8s linear infinite}@keyframes loginSpin{to{transform:rotate(360deg)}}.confirm-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1200;animation:fadeIn .2s ease}.confirm-modal-content{width:280px;background:#fff;border-radius:16px;padding:28px 24px 20px;text-align:center;animation:scaleIn .2s ease}.confirm-modal-icon{margin-bottom:12px;display:flex;justify-content:center}.confirm-modal-title{margin:0 0 8px;font-size:17px;font-weight:600;color:#333}.confirm-modal-message{margin:0 0 24px;font-size:14px;color:#999;line-height:1.5}.confirm-modal-actions{display:flex;gap:12px}.confirm-modal-cancel{flex:1;padding:10px;border:1px solid #e0e0e0;border-radius:10px;background:#fff;color:#666;font-size:14px;cursor:pointer}.confirm-modal-confirm{flex:1;padding:10px;border:none;border-radius:10px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:14px;font-weight:500;cursor:pointer}.confirm-modal-confirm.danger{background:#ff4d4f}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.mobile-layout{min-height:100vh;background:linear-gradient(135deg,#fff5f7,#ffeef2);display:flex;flex-direction:column}.mobile-header{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 12px #ff6b9d4d}.header-left{display:flex;align-items:center;flex:1;min-width:0}.header-right{display:flex;align-items:center;flex-shrink:0}.back-btn{background:none;border:none;color:#fff;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.back-btn:hover{background-color:#fff3}.back-btn svg{width:24px;height:24px}.header-title-left{font-size:16px;font-weight:600;margin-left:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.manage-photos-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fff;color:#ff6b9d;border:none;border-radius:16px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.manage-photos-btn svg{stroke:#ff6b9d}.manage-photos-btn:hover{background:#fff0f3}.header-right{position:relative}.header-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001f;overflow:hidden;min-width:140px;z-index:1000;animation:dropdownIn .15s ease}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;border:none;background:transparent;color:#333;font-size:13px;cursor:pointer;white-space:nowrap;transition:background .15s}.dropdown-item svg{stroke:#999;flex-shrink:0}.dropdown-item:active{background:#f5f5f5}.dropdown-divider{height:1px;background:#f0f0f0;margin:4px 0}.dropdown-item.logout-item{color:#ff4d4f}.dropdown-item.logout-item svg{stroke:#ff4d4f}.dropdown-item.login-item{color:#ff6b9d}.dropdown-item.login-item svg{stroke:#ff6b9d}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mobile-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.mobile-content::-webkit-scrollbar{display:none}.mobile-content{-ms-overflow-style:none;scrollbar-width:none}.search-bar{display:flex;align-items:center;background:#fff;border-radius:25px;padding:10px 16px;margin:12px 16px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;border:2px solid transparent}.search-bar.focused{border-color:#ff6b9d;box-shadow:0 2px 12px #ff6b9d33}.search-icon{color:#999;margin-right:10px;display:flex;align-items:center;flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-size:15px;color:#333;background:transparent}.search-input::placeholder{color:#aaa}.clear-btn{background:none;border:none;color:#999;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s;flex-shrink:0}.clear-btn:hover{background-color:#f0f0f0;color:#666}.filter-sort-bar{background:#fff;border-bottom:1px solid #f0f0f0;position:relative}.filter-section{padding:12px 16px;border-bottom:1px solid #f5f5f5}.filter-scroll{display:flex;gap:10px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.filter-scroll::-webkit-scrollbar{display:none}.filter-btn{flex-shrink:0;padding:8px 16px;border:1px solid #e0e0e0;border-radius:20px;background:#fff;color:#666;font-size:14px;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-btn.active{background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;border-color:#ff6b9d}.filter-btn:not(.active):hover{border-color:#ff6b9d;color:#ff6b9d}.sort-section{padding:10px 16px;display:flex;justify-content:flex-end;position:relative}.sort-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid #e0e0e0;border-radius:16px;background:#fff;color:#666;font-size:13px;cursor:pointer;transition:all .2s}.sort-btn:hover{border-color:#ff6b9d;color:#ff6b9d}.sort-btn svg{transition:transform .2s}.sort-btn svg.rotate{transform:rotate(180deg)}.sort-dropdown{position:absolute;top:calc(100% + 4px);right:16px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:8px;min-width:100px;z-index:50}.sort-option{display:block;width:100%;padding:10px 16px;border:none;background:none;text-align:left;font-size:14px;color:#666;cursor:pointer;border-radius:8px;transition:all .2s}.sort-option:hover{background:#fff5f7;color:#ff6b9d}.sort-option.active{background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff}.sort-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:40}.photo-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #00000014;transition:all .3s ease;cursor:pointer}.photo-card:active{transform:scale(.98)}.card-image-wrapper{position:relative;aspect-ratio:3/4;overflow:hidden}.card-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.photo-card:hover .card-image{transform:scale(1.05)}.category-overlay{position:absolute;bottom:0;left:0;right:0;padding:12px;background:linear-gradient(transparent,#0009)}.category-count{color:#fff;font-size:13px;font-weight:500;background:#ff6b9de6;padding:4px 10px;border-radius:12px}.card-info{padding:12px}.card-title{font-size:15px;font-weight:600;color:#333;margin:0 0 8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.template-popularity{display:flex;align-items:center;gap:4px;font-size:13px;color:#ff6b9d}.template-popularity svg{flex-shrink:0}.template-tag{font-size:12px;color:#999;background:#f5f5f5;padding:2px 8px;border-radius:10px;white-space:nowrap}.category-desc{font-size:12px;color:#999;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.photo-grid{padding:16px}.grid-container{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{color:#ddd;margin-bottom:16px}.empty-text{font-size:16px;color:#999;margin:0 0 8px}.empty-subtext{font-size:14px;color:#bbb;margin:0}.loading-more{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#999;font-size:14px}.loading-spinner{width:20px;height:20px;border:2px solid #f0f0f0;border-top-color:#ff6b9d;border-radius:50%;animation:spin .8s linear infinite}.no-more{text-align:center;padding:20px;color:#bbb;font-size:13px}.load-more-trigger{height:10px}.home-page{min-height:100%}.content-area{padding-bottom:20px}.section-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 8px}.section-header h2{font-size:18px;font-weight:600;color:#333;margin:0}.section-count{font-size:13px;color:#999}.search-result-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fff5f7;margin:0 16px 8px;border-radius:8px;font-size:14px;color:#666}.result-count{color:#ff6b9d;font-weight:500}.category-page{min-height:100%}.category-header{background:#fff;margin-bottom:12px}.category-cover{position:relative;height:200px;overflow:hidden}.category-cover img{width:100%;height:100%;object-fit:cover}.category-overlay{position:absolute;bottom:0;left:0;right:0;padding:60px 20px 20px;background:linear-gradient(transparent,#000000b3);color:#fff}.category-overlay h1{font-size:24px;font-weight:600;margin:0 0 8px}.category-overlay p{font-size:14px;margin:0;opacity:.9}.category-stats{display:flex;padding:16px 20px;gap:40px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:20px;font-weight:600;color:#ff6b9d}.stat-label{font-size:13px;color:#999}.templates-section{background:#fff;min-height:calc(100vh - 300px)}.section-title{padding:16px 16px 0}.section-title h3{font-size:16px;font-weight:600;color:#333;margin:0}.error-state button{padding:12px 32px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;border:none;border-radius:25px;font-size:15px;cursor:pointer;transition:opacity .2s}.error-state button:hover{opacity:.9}.save-album-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.save-album-content{width:100%;max-width:420px;max-height:60vh;background:#fff;border-radius:20px 20px 0 0;display:flex;flex-direction:column;animation:slideUp .25s ease}.save-album-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px;border-bottom:1px solid #f0f0f0}.save-album-header h4{margin:0;font-size:17px;font-weight:600;color:#333}.save-album-close{background:none;border:none;color:#999;cursor:pointer;padding:4px;display:flex;border-radius:50%}.save-album-close:active{background:#f5f5f5}.save-album-body{flex:1;overflow-y:auto;padding:12px 20px 24px}.save-album-loading{text-align:center;padding:40px 0;color:#999;font-size:14px}.save-album-new-btn{width:100%;padding:12px;border:1px dashed #ddd;border-radius:12px;background:transparent;color:#666;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:12px}.save-album-new-btn:active{background:#f9f9f9}.save-album-create-form{margin-bottom:12px;padding:14px;background:#f9f9f9;border-radius:12px;display:flex;flex-direction:column;gap:10px}.save-album-input{padding:10px 14px;border:1px solid #e0e0e0;border-radius:10px;font-size:14px;outline:none;background:#fff}.save-album-input:focus{border-color:#ff6b9d}.save-album-form-actions{display:flex;gap:10px;justify-content:flex-end}.save-album-cancel{padding:8px 18px;border:1px solid #ddd;border-radius:16px;background:#fff;color:#666;font-size:13px;cursor:pointer}.save-album-submit{padding:8px 18px;border:none;border-radius:16px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:13px;font-weight:500;cursor:pointer}.save-album-submit:disabled{opacity:.5}.save-album-list{display:flex;flex-direction:column;gap:2px}.save-album-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 8px;border:none;border-radius:12px;background:transparent;cursor:pointer;text-align:left;transition:background .15s}.save-album-item:active{background:#f5f5f5}.save-album-item:disabled{opacity:.6}.save-album-item-cover{width:44px;height:44px;border-radius:10px;background:#f0f0f0;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.save-album-item-cover img{width:100%;height:100%;object-fit:cover}.save-album-item-name{flex:1;font-size:15px;font-weight:500;color:#333}.save-album-item-saving{font-size:12px;color:#ff6b9d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.compare-modal{position:fixed;top:50px;bottom:0;left:0;right:0;z-index:999;background:#000;display:flex;flex-direction:column;animation:compareFadeIn .3s ease}@keyframes compareFadeIn{0%{opacity:0}to{opacity:1}}.compare-modal-content{display:flex;flex-direction:column;height:100%;position:relative}.compare-close-btn{position:absolute;top:12px;left:12px;z-index:10;width:40px;height:40px;border:none;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;padding:0}.compare-close-btn:hover{background:#0009}.compare-close-btn:active{transform:scale(.92)}.compare-slider{flex:1;overflow:hidden;position:relative}.compare-slides{display:flex;height:100%;transition:transform .35s cubic-bezier(.25,.46,.45,.94)}.compare-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;background:#1a1a1a}.compare-slide img{max-width:100%;max-height:100%;object-fit:contain}.compare-badge{position:absolute;top:12px;right:12px;padding:4px 10px;color:#fff;font-size:11px;font-weight:500;z-index:5;letter-spacing:.5px}.compare-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:44px;height:44px;border-radius:50%;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .2s;padding:0}.compare-arrow.left{left:12px}.compare-arrow.right{right:12px}.compare-arrow.hidden{opacity:0;pointer-events:auto;cursor:default}.compare-arrow:not(.hidden):active{background:#000000b3}.compare-dots{display:flex;justify-content:center;gap:10px;padding:8px 0}.compare-dot{width:8px;height:8px;border-radius:50%;border:2px solid rgba(255,255,255,.4);background:transparent;cursor:pointer;transition:all .3s;padding:0}.compare-dot.active{background:#ff6b9d;border-color:#ff6b9d;transform:scale(1.3)}.compare-actions{padding:12px 16px 20px;display:flex;flex-direction:column;gap:10px}.compare-action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:26px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.compare-action-btn.primary{background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;box-shadow:0 4px 15px #ff6b9d80}.compare-action-btn.primary:active{transform:scale(.97)}.compare-action-btn.optimize{background:#ff6b9d26;color:#ff6b9d;border:1px solid rgba(255,107,157,.3)}.compare-action-btn.optimize:active{background:#ff6b9d40}.detail-page{min-height:100%;padding-bottom:50px}.template-preview{position:relative;background:#fff}.template-preview img{width:100%;aspect-ratio:3/4;object-fit:cover}.template-info{padding:16px}.template-info h2{font-size:20px;font-weight:600;color:#333;margin:0 0 12px}.template-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tag{padding:4px 12px;background:#fff5f7;color:#ff6b9d;font-size:12px;border-radius:12px}.template-desc{font-size:14px;color:#666;line-height:1.6;margin:0}.generate-section{position:fixed;bottom:0;left:0;right:0;padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom));background:#ffffff04;z-index:100}.generate-btn{width:100%;padding:16px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;border:none;border-radius:28px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .3s;box-shadow:0 4px 15px #ff6b9d66}.generate-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff6b9d80}.generate-btn.disabled{background:#e0e0e0;box-shadow:none;cursor:not-allowed}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.generate-hint{text-align:center;font-size:13px;color:#999;margin:12px 0 0}.result-section{background:#fff;margin-top:12px;padding:16px}.result-image-wrapper{position:relative;border-radius:16px;overflow:hidden}.result-image{width:100%;display:block}.result-badge{position:absolute;top:12px;right:12px;padding:6px 12px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:12px;font-weight:600;border-radius:20px}.result-actions{display:flex;flex-direction:column;gap:12px;margin-top:20px}.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.action-btn.primary{background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;box-shadow:0 4px 15px #ff6b9d66}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ff6b9d80}.action-btn.secondary{background:#f5f5f5;color:#666}.action-btn.secondary:hover{background:#e8e8e8}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.error-state p{font-size:16px;color:#999;margin-bottom:20px}.error-state button{padding:12px 32px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;border:none;border-radius:24px;font-size:15px;font-weight:600;cursor:pointer}.chat-page{display:flex;flex-direction:column;height:100%;background:#f5f5f5}.chat-messages{flex:1;overflow-y:auto;padding:16px 16px 80px;display:flex;flex-direction:column;gap:16px}.chat-message{display:flex;align-items:flex-start;gap:8px;max-width:85%}.chat-message.user{align-self:flex-end}.chat-message.ai{align-self:flex-start}.chat-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-avatar{background:linear-gradient(135deg,#ff6b9d,#ff8fab)}.user-avatar{background:#b0b0b0}.chat-bubble{background:#fff;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.6;color:#333;box-shadow:0 1px 3px #0000000f}.chat-message.user .chat-bubble{background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff}.chat-bubble p{margin:0;white-space:pre-wrap}.chat-image{margin-top:10px;max-width:240px;border-radius:12px;display:block}.chat-save-btn{margin-top:8px;padding:6px 14px;border:1px solid #ff6b9d;border-radius:16px;background:transparent;color:#ff6b9d;font-size:12px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:4px;transition:all .2s}.chat-save-btn:active{background:#ff6b9d1a}.chat-input-bar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;gap:10px;padding:10px 16px;padding-bottom:calc(10px + env(safe-area-inset-bottom));background:#fff;border-top:1px solid #eee;z-index:10}.chat-input-bar input{flex:1;padding:12px 16px;border:1px solid #e0e0e0;border-radius:24px;font-size:14px;outline:none;background:#f8f8f8;transition:border-color .2s}.chat-input-bar input:focus{border-color:#ff6b9d;background:#fff}.chat-input-bar input:disabled{opacity:.5}.chat-send-btn{width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .2s}.chat-send-btn:disabled{background:#e0e0e0;cursor:not-allowed}.chat-send-btn:not(:disabled):active{transform:scale(.93)}.spinner-small{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.album-page{padding:16px;min-height:calc(100vh - 50px)}.album-loading{text-align:center;padding:60px 0;color:#999;font-size:14px}.album-desc{margin:0 0 16px;font-size:13px;color:#999;line-height:1.5}.album-empty{text-align:center;padding:60px 0;color:#ccc}.album-empty p{margin:12px 0 0;font-size:14px}.album-photos-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.album-photo-item{position:relative;border-radius:10px;overflow:hidden;aspect-ratio:3 / 4;background:#f0f0f0}.album-photo-item img{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer}.album-photo-delete{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:#00000080;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s}.album-photo-item:hover .album-photo-delete,.album-photo-item:active .album-photo-delete{opacity:1}.album-photo-prompt{position:absolute;bottom:0;left:0;right:0;padding:8px 10px;background:linear-gradient(transparent,#0009);color:#fff;font-size:11px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.album-delete-btn{margin-top:24px;width:100%;padding:12px;border:1px solid #ff4d4f;border-radius:10px;background:transparent;color:#ff4d4f;font-size:14px;cursor:pointer;transition:all .2s}.album-delete-btn:active{background:#fff1f0}.album-preview{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.album-preview-content{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.album-preview-close{position:absolute;top:16px;right:16px;background:#ffffff26;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10}.album-preview-img{max-width:100%;max-height:70vh;object-fit:contain;display:block}.album-preview-actions{position:absolute;bottom:60px;left:0;right:0;display:flex;justify-content:center;padding:0 20px}.album-preview-optimize{display:flex;align-items:center;gap:6px;padding:12px 32px;border:none;border-radius:24px;background:linear-gradient(135deg,#ff6b9d,#ff8fab);color:#fff;font-size:15px;font-weight:500;cursor:pointer;box-shadow:0 4px 16px #ff6b9d66;transition:all .2s}.album-preview-optimize:active{transform:scale(.96)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-tap-highlight-color:transparent}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:#f5f5f5;color:#333;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}button{font-family:inherit;outline:none}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit}@media (max-width: 480px){html{font-size:14px}}.no-select{user-select:none;-webkit-user-select:none}html{scroll-behavior:smooth}
