body{margin:0;padding:0;background:#f2f2f7}.main-container{position:relative;width:100%;height:100vh;overflow:hidden}.design-container{position:absolute;top:0;left:0;width:100%;bottom:0;margin-bottom:var(--controls-height);background-color:#999;overflow:hidden;box-sizing:border-box}.letter-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;transition:opacity .3s}.letter{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:400px;color:#000;-webkit-user-select:none;user-select:none;pointer-events:none}.texture-image{width:100%;height:100%;object-fit:cover}.controls-container{position:absolute;bottom:0;left:0;width:100%;background:#ffffffe6;border-radius:20px 20px 0 0;padding:20px 0;box-shadow:0 -2px 10px #0000001a;z-index:10;display:flex;gap:1px;box-sizing:border-box}.size-control{width:40px;min-width:40px;height:154px;background:#a9a9a9cc;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;margin-left:10px;flex-shrink:0}.size-label{position:absolute;top:5px;color:#fff;font-size:14px}.size-value{position:absolute;bottom:0;color:#fff;font-size:14px}.size-slider{transform:rotate(-90deg);width:110px;margin:0;position:relative;top:-10px}.controls-main{flex:1;display:flex;flex-direction:column;gap:1px;margin-right:10px;min-width:0}.control-row{display:flex;align-items:center;margin-bottom:1px;height:50px;min-width:0}.control-label{min-width:70px;height:50px;line-height:50px;background:#a9a9a9cc;color:#fff;padding-left:10px;position:relative;flex-shrink:0}.add-font-button{position:absolute;right:0;top:0;bottom:0;width:40px;background:none;border:none;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center}.control-content{flex:1;height:50px;background:#a9a9a980;margin-left:1px;padding:0;display:flex;align-items:center;overflow:hidden;min-width:0}.generate-button{width:248px;height:50px;margin:8px auto;display:block;background:#ff2d55;color:#fff;border:none;border-radius:5px;font-size:19px}.collection-view{display:flex;overflow-x:auto;gap:8px;padding:0 8px;height:100%;align-items:center;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;flex:1;min-width:0}.collection-view::-webkit-scrollbar{display:none}.collection-item{flex:0 0 auto;height:35px;background:#fff;border-radius:5px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s;padding:0 8px}.collection-item:hover{transform:scale(1.1)}#fontCollection .collection-item{width:45px;font-size:16px;padding:0}#strokeCollection .collection-item{width:25px;padding:0}#charsetCollection .collection-item{padding:0 12px;white-space:nowrap;font-size:12px}.color-list{flex:0 0 auto;margin-left:1px;padding:0 5px;display:flex;align-items:center}.more-button{flex:0 0 40px}.nav-button{position:absolute;top:0;width:50px;height:50px;background:none;border:none;color:#000;font-size:24px}.nav-button.left{left:10px}.nav-button.right{right:70px}.nav-button.account{right:10px;top:0;width:50px;height:50px;background:none;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1001}.nav-button .icon-account{width:24px;height:24px;transition:transform .2s}.nav-button .icon-account path{stroke:currentColor}.nav-button:hover .icon-account{transform:scale(1.1)}.stroke-width-slider{transform:rotate(-90deg);width:110px;margin:0;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-90deg);-webkit-appearance:none;background:transparent}.stroke-width-slider::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#fff;border-radius:50%;cursor:pointer;margin-top:-8px}.stroke-width-slider::-webkit-slider-runnable-track{width:100%;height:4px;background:#ffffff80;border-radius:2px;cursor:pointer}.letter-mask{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.cropped-letter{pointer-events:none;max-width:80%;max-height:80%;object-fit:contain}.collection-item.active{box-shadow:0 0 0 2px #999;transform:scale(1.1)}#strokeCollection .collection-item.active{box-shadow:0 0 0 2px #999}#fontCollection .collection-item.active,#charsetCollection .collection-item.active{box-shadow:0 0 0 2px #999;transform:scale(1.1);background:#f0f0f0}#letterCanvas{width:100%;height:100%;position:absolute;top:0;left:0;background-size:cover;background-position:center}.help-tooltip{position:absolute;background:#000c;color:#fff;padding:10px 15px;border-radius:6px;font-size:14px;z-index:1000;animation:bounce 2s infinite;white-space:nowrap}.help-tooltip:after{content:"";position:absolute;top:50%;left:100%;margin-top:-5px;border-width:5px;border-style:solid;border-color:transparent transparent transparent rgba(0,0,0,.8)}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(0)}40%{transform:translate(-10px)}60%{transform:translate(-5px)}}.detail-dialog{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1500;opacity:0;animation:fadeIn .3s ease forwards}.detail-content{position:relative;background:#fff;padding:40px;border-radius:20px;width:90%;max-width:500px;text-align:center}.detail-nav{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;background:#00000080;border:none;border-radius:50%;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}.detail-nav:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.detail-nav.prev{left:-60px}.detail-nav.next{right:-60px}@media (max-width: 768px){.detail-nav.prev{left:10px}.detail-nav.next{right:10px}}.detail-original{margin-top:10px;font-size:16px;color:#999}.detail-image{max-width:100%;max-height:60vh;object-fit:contain;margin-bottom:20px}.detail-info{margin-bottom:20px;font-size:18px;color:#333}.detail-close{position:absolute;top:15px;right:15px;width:36px;height:36px;border:none;border-radius:50%;background:#ff3b30;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.detail-close:hover{background:#ff453a;transform:rotate(90deg)}.detail-image-container{position:relative;width:100%;overflow:hidden;margin-bottom:20px;min-height:300px;display:flex;align-items:center;justify-content:center}.detail-image{position:absolute;max-width:100%;max-height:60vh;object-fit:contain;will-change:transform;backface-visibility:hidden;transform:translateZ(0)}.slide-left-enter{position:absolute;animation:slideLeftEnter .3s cubic-bezier(.4,0,.2,1) forwards}.slide-left-exit{position:absolute;animation:slideLeftExit .3s cubic-bezier(.4,0,.2,1) forwards}.slide-right-enter{position:absolute;animation:slideRightEnter .3s cubic-bezier(.4,0,.2,1) forwards}.slide-right-exit{position:absolute;animation:slideRightExit .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideLeftEnter{0%{transform:translate3d(100%,0,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes slideLeftExit{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(-100%,0,0);opacity:0}}@keyframes slideRightEnter{0%{transform:translate3d(-100%,0,0);opacity:0}to{transform:translateZ(0);opacity:1}}@keyframes slideRightExit{0%{transform:translateZ(0);opacity:1}to{transform:translate3d(100%,0,0);opacity:0}}.detail-actions{display:flex;justify-content:center;margin-top:20px}.detail-content .download-btn{margin:0 auto;min-width:200px}*{touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;-khtml-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.celebration-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fffffff2;padding:30px 40px;border-radius:20px;text-align:center;box-shadow:0 10px 30px #0003;z-index:2001;opacity:0;animation:messageIn .5s ease forwards}.celebration-title{font-size:24px;color:#333;margin-bottom:15px;font-weight:700}.celebration-text{font-size:18px;color:#666;line-height:1.5}@keyframes messageIn{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes messageOut{0%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-60%)}}.result-header{margin-bottom:20px;padding:0 10px}.result-title-row{display:flex;align-items:center;gap:15px;margin-bottom:15px}.result-title{font-size:24px;font-weight:700;color:#333;flex:1}.result-actions{display:flex;gap:10px;justify-content:center;margin-bottom:20px}.save-font-btn,.design-btn,.download-btn,.download-zip-btn,.shop-btn{padding:8px 16px;border:none;border-radius:8px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.save-font-btn{background:#4caf50;color:#fff}.design-btn{background:#007aff;color:#fff}.download-btn{background:#ff9500;color:#fff}.download-zip-btn{background:#28a745;color:#fff}.shop-btn{background:#5e3fbe;color:#fff}.close-btn{width:36px;height:36px;border:none;border-radius:50%;background:#ff3b30;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.save-font-btn:hover{background:#45a049}.design-btn:hover{background:#06c}.download-btn:hover{background:#ff9500}.download-zip-btn:hover{background:#218838}.shop-btn:hover{background:#4e2fae}.close-btn:hover{background:#ff453a}.download-btn:disabled{opacity:.7;cursor:not-allowed}.btn-icon{font-size:16px}.result-container{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;animation:fadeIn .3s ease forwards}.result-content{background:#fff;padding:30px;border-radius:20px;width:90%;max-width:900px;max-height:85vh;overflow-y:auto;transform:translateY(20px);opacity:0;animation:slideUp .4s ease .1s forwards;box-shadow:0 10px 30px #0003}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.shop-btn{background:#5e3fbe;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:14px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .2s}.shop-btn:hover{background:#4e2fae;transform:translateY(-1px)}.shop-btn .btn-icon{font-size:16px}.account-dropdown{position:absolute;top:100%;right:0;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;min-width:150px;display:none;z-index:1002;margin-top:5px;overflow:hidden}.nav-button.account.active .account-dropdown{display:block}.dropdown-item{display:block;padding:12px 16px;color:#333;text-decoration:none;transition:background-color .2s;text-align:left;width:100%;background:none;font-size:14px;cursor:pointer;border:none;box-sizing:border-box}.dropdown-item:hover{background-color:#f5f5f5}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.dropdown-item+.dropdown-item{border-top:1px solid #eee}#logout-form{margin:0;padding:0}#logout-form a.dropdown-item{border-top:1px solid #eee}.login-link{display:inline-block;margin-top:15px;padding:8px 20px;background:#007aff;color:#fff!important;text-decoration:none;border-radius:5px;transition:all .2s}.login-link:hover{background:#06c;transform:translateY(-1px)}.save-font-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;padding:0;border-radius:12px;box-shadow:0 10px 25px #00000026;z-index:1000;width:90%;max-width:480px;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.save-font-dialog:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;z-index:-1;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.dialog-header{background:linear-gradient(135deg,#007aff,#5856d6);color:#fff;padding:20px 30px;border-radius:12px 12px 0 0;display:flex;align-items:center;gap:12px}.dialog-header h2{margin:0;font-size:22px;font-weight:600;color:#fff}.dialog-header svg{width:28px;height:28px}.dialog-content{padding:25px 30px}.font-limit-info{background-color:#f0f7ff;padding:12px 15px;border-radius:8px;margin-bottom:25px;color:#345995;font-size:14px;border-left:4px solid #007AFF;display:flex;align-items:center;gap:10px}.font-limit-info svg{width:20px;height:20px;fill:#007aff;flex-shrink:0}.font-limit-info .limit-text{flex-grow:1}.font-limit-progress{background:#e0ecff;height:6px;border-radius:3px;margin-top:8px;overflow:hidden;width:100%}.font-limit-progress .progress-bar{height:100%;background:#007aff;border-radius:3px;transition:width .3s ease}.form-group{margin-bottom:22px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:15px}.form-group input,.form-group textarea{width:100%;padding:12px 15px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:all .2s;background:#fafafa}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#007aff;box-shadow:0 0 0 3px #007aff26;background:#fff}.form-group textarea{min-height:90px;resize:vertical}.font-preview{margin-bottom:25px;background:#fafafa;border-radius:8px;padding:15px;border:1px solid #eee}.preview-title{font-size:14px;color:#666;margin-bottom:10px;display:flex;align-items:center;gap:5px}.preview-title svg{width:16px;height:16px}.preview-characters{display:flex;flex-wrap:wrap;gap:8px}.preview-char{width:30px;height:30px;background:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;border:1px solid #ddd}.dialog-buttons{display:flex;justify-content:flex-end;gap:12px;margin-top:25px;padding-top:20px;border-top:1px solid #eee}.dialog-btn{padding:12px 22px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;border:none;transition:all .2s;display:flex;align-items:center;gap:8px}.save-btn{background-color:#007aff;color:#fff}.save-btn:hover{background-color:#0062cc;transform:translateY(-1px)}.save-btn:active{transform:translateY(1px)}.cancel-btn{background-color:#f2f2f2;color:#555}.cancel-btn:hover{background-color:#e6e6e6;transform:translateY(-1px)}.cancel-btn:active{transform:translateY(1px)}.save-btn:disabled{background-color:#b3d7ff;cursor:not-allowed;transform:none}.save-btn.saving{position:relative;color:transparent;pointer-events:none}.save-btn.saving:after{content:"";position:absolute;width:20px;height:20px;top:50%;left:50%;margin-left:-10px;margin-top:-10px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s infinite linear}.font-generate-btn{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;border-radius:8px;padding:12px 20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #28a7454d}.font-generate-btn:hover{background:linear-gradient(135deg,#218838,#1ca085);transform:translateY(-1px);box-shadow:0 4px 12px #28a74566}.font-generate-btn.generating{background:linear-gradient(135deg,#6c757d,#5a6268);cursor:not-allowed;pointer-events:none}.font-generate-btn.success{background:linear-gradient(135deg,#007bff,#0056b3)}.font-generate-btn.error{background:linear-gradient(135deg,#dc3545,#c82333)}.generate-animation{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top:2px solid white;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.font-generation-progress{margin-top:15px;padding:15px;background:#f8f9fa;border-radius:8px;border-left:4px solid #28a745}.progress-step{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:13px;color:#495057}.progress-step.active{color:#28a745;font-weight:500}.progress-step .step-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.progress-step.completed .step-icon{color:#28a745}.progress-step.active .step-icon{animation:pulse 1.5s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.pattern-add-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:10001;display:flex;justify-content:center;align-items:center}.pattern-category-btn{padding:6px 12px;border:1px solid #ddd;background:#fff;border-radius:20px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s;color:#666}.pattern-category-btn:hover{background:#f5f5f5;border-color:#ccc}.pattern-category-btn.active{background:#007bff;color:#fff;border-color:#007bff}.pattern-item{cursor:pointer;border-radius:8px;overflow:hidden;transition:all .2s;border:2px solid transparent;background:#f8f9fa;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.pattern-item:hover{border-color:#007bff;transform:scale(1.05);box-shadow:0 4px 12px #007bff33}.pattern-item img{width:100%;height:100%;object-fit:cover}.pattern-pagination button{transition:all .2s}.pattern-pagination button:hover:not(:disabled){background:#f8f9fa;border-color:#007bff;color:#007bff}.pattern-pagination button:disabled{opacity:.5;cursor:not-allowed}
/*# sourceMappingURL=/cdn/shop/t/7/assets/pattern.css.map */
