:root{--color-bg: #FAF7F2;--color-bg-alt: #F3EEE7;--color-bg-card: #FFFFFF;--color-text-primary: #1A1A1A;--color-text-secondary: #6B6B6B;--color-text-tertiary: #9B9B9B;--color-accent: #B8860B;--color-accent-light: #D4A84B;--color-accent-dark: #8B6914;--color-border: #E8E2D9;--color-border-light: #F0EBE3;--color-success: #2D5A27;--color-error: #8B2635;--color-gold-gradient: linear-gradient(135deg, #D4A84B 0%, #B8860B 50%, #8B6914 100%);--shadow-sm: 0 2px 8px rgba(26, 26, 26, .04);--shadow-md: 0 8px 24px rgba(26, 26, 26, .08);--shadow-lg: 0 16px 48px rgba(26, 26, 26, .12);--shadow-gold: 0 4px 20px rgba(184, 134, 11, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-full: 999px;--font-display: "Cormorant Garamond", "Noto Serif SC", serif;--font-body: "Inter", "Noto Serif SC", -apple-system, BlinkMacSystemFont, sans-serif;--nav-height: 56px;--tabbar-height: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px)}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text-primary);line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}#app{min-height:100vh;display:flex;flex-direction:column;background:var(--color-bg);position:relative}.page{flex:1;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.page-exit{animation:fadeOut .2s ease-in forwards}.top-nav{position:sticky;top:0;z-index:100;background:#faf7f2eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border-light);height:var(--nav-height)}.nav-inner{max-width:1200px;margin:0 auto;height:100%;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.nav-left,.nav-right{display:flex;align-items:center;gap:12px}.nav-back{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:background .2s}.nav-back svg{width:20px;height:20px}.nav-back:active{background:var(--color-bg-alt)}.logo{display:flex;align-items:center;gap:8px}.logo-img{width:32px;height:32px;object-fit:contain}.logo-text{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:2px;background:var(--color-gold-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.nav-icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);position:relative;transition:background .2s}.nav-icon-btn svg{width:20px;height:20px;stroke:var(--color-text-primary)}.nav-icon-btn:active{background:var(--color-bg-alt)}.nav-auth{display:flex;align-items:center;gap:8px}.nav-auth-btn{padding:6px 14px;font-size:13px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;font-weight:500}.nav-auth-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.nav-auth-btn-primary{background:var(--color-gold-gradient);border-color:transparent;color:#fff}.nav-auth-btn-primary:hover{background:var(--color-gold-gradient);color:#fff;box-shadow:var(--shadow-gold)}.nav-user{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 10px 4px 4px;border-radius:var(--radius-full);transition:background .2s}.nav-user:hover{background:var(--color-bg-alt)}.nav-user-avatar{width:30px;height:30px;border-radius:50%;background:var(--color-gold-gradient);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;font-family:var(--font-display)}.nav-user-phone{font-size:13px;color:var(--color-text-secondary);font-weight:500}.nav-user:hover .nav-user-phone{color:var(--color-accent)}@media (max-width: 480px){.nav-auth-btn{padding:5px 10px;font-size:12px}.nav-user-phone{display:none}}.cart-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;background:var(--color-accent);color:#fff;font-size:10px;font-weight:600;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px}.page-container{flex:1;max-width:1200px;width:100%;margin:0 auto;padding-bottom:calc(var(--tabbar-height) + var(--safe-bottom));position:relative}.page{animation:pageEnter .4s cubic-bezier(.16,1,.3,1)}@keyframes pageEnter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.bottom-tabbar{position:fixed;bottom:0;left:0;right:0;height:calc(var(--tabbar-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--color-border-light);display:flex;justify-content:space-around;align-items:center;z-index:100}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:100%;color:var(--color-text-tertiary);transition:color .25s;position:relative}.tab-item svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.5}.tab-item span{font-size:11px;font-weight:500;letter-spacing:.5px}.tab-item.active{color:var(--color-accent)}.tab-item.tab-center{position:relative}.tab-item.tab-center:before{content:"";position:absolute;top:-10px;width:48px;height:48px;border-radius:var(--radius-full);background:var(--color-gold-gradient);box-shadow:var(--shadow-gold);z-index:-1}.tab-item.tab-center svg,.tab-item.tab-center span{color:#fff}.tab-item.tab-center svg{stroke:#fff;width:24px;height:24px;margin-top:6px}.tab-item.tab-center span{color:var(--color-text-secondary);margin-top:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:var(--radius-full);font-size:14px;font-weight:500;letter-spacing:1px;transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer;border:none;text-transform:uppercase}.btn-primary{background:var(--color-gold-gradient);color:#fff;box-shadow:var(--shadow-gold)}.btn-primary:active{transform:scale(.97);box-shadow:0 2px 10px #b8860b4d}.btn-outline{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-accent)}.btn-outline:active{background:#b8860b14;transform:scale(.97)}.btn-ghost{background:var(--color-bg-alt);color:var(--color-text-primary)}.btn-ghost:active{background:var(--color-border);transform:scale(.97)}.btn-block{width:100%}.btn-lg{padding:16px 32px;font-size:15px}.btn-sm{padding:10px 20px;font-size:12px}.section-title{font-family:var(--font-display);font-size:28px;font-weight:500;letter-spacing:2px;margin-bottom:24px;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-6px;left:0;width:40px;height:2px;background:var(--color-gold-gradient)}.card{background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;transition:all .3s cubic-bezier(.16,1,.3,1)}.card:active{transform:scale(.98);box-shadow:var(--shadow-md)}.price{font-family:var(--font-display);font-weight:600;color:var(--color-accent)}.price .currency{font-size:.7em;margin-right:2px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1a1a1a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:none;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .3s}.modal-overlay.show{display:flex;opacity:1}.modal-content{background:var(--color-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-height:85vh;overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);padding:24px 20px calc(24px + var(--safe-bottom))}.modal-overlay.show .modal-content{transform:translateY(0)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-family:var(--font-display);font-size:22px;font-weight:500;letter-spacing:1px}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg-alt)}.modal-close svg{width:18px;height:18px;stroke:var(--color-text-secondary)}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);background:#1a1a1ae6;color:#fff;padding:14px 24px;border-radius:var(--radius-md);font-size:14px;z-index:10000;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.16,1,.3,1)}.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.home-hero{position:relative;padding:40px 20px 60px;background:linear-gradient(180deg,var(--color-bg-alt) 0%,var(--color-bg) 100%);overflow:hidden}.home-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(184,134,11,.08) 0%,transparent 70%);border-radius:50%}.hero-content{position:relative;z-index:1}.hero-eyebrow{font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--color-accent);margin-bottom:12px;font-weight:500}.hero-title{font-family:var(--font-display);font-size:42px;font-weight:400;line-height:1.15;margin-bottom:16px;letter-spacing:1px}.hero-title em{font-style:italic;background:var(--color-gold-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:14px;color:var(--color-text-secondary);margin-bottom:28px;max-width:320px;line-height:1.8}.hero-buttons{display:flex;gap:12px}.home-section{padding:40px 20px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.section-header .section-title{margin-bottom:0}.section-more{font-size:13px;color:var(--color-accent);display:flex;align-items:center;gap:4px;font-weight:500}.section-more svg{width:14px;height:14px;stroke:currentColor}.pattern-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.pattern-card{position:relative;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-bg-alt);cursor:pointer}.pattern-card .pattern-image{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.16,1,.3,1)}.pattern-card:active .pattern-image{transform:scale(1.05)}.pattern-card .pattern-overlay{position:absolute;bottom:0;left:0;right:0;padding:40px 16px 16px;background:linear-gradient(transparent,#000000b3);color:#fff}.pattern-card .pattern-title{font-family:var(--font-display);font-size:18px;font-weight:500;margin-bottom:6px;letter-spacing:1px}.pattern-card .pattern-price{font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--color-accent-light)}.pattern-card .pattern-tag{position:absolute;top:12px;left:12px;background:#ffffffe6;color:var(--color-accent-dark);font-size:10px;padding:4px 10px;border-radius:var(--radius-full);font-weight:600;letter-spacing:1px;text-transform:uppercase}.customize-entry{margin:40px 20px;position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/9;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);display:flex;align-items:center;justify-content:center;cursor:pointer}.customize-entry:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23B8860B' fill-opacity='0.08'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.customize-entry-content{position:relative;text-align:center;padding:40px}.customize-entry h3{font-family:var(--font-display);font-size:28px;color:#fff;font-weight:400;margin-bottom:8px;letter-spacing:3px}.customize-entry h3 em{font-style:italic;color:var(--color-accent-light)}.customize-entry p{color:#fff9;font-size:13px;margin-bottom:20px;letter-spacing:1px}.customize-entry .btn-primary{padding:12px 28px}.home-features{padding:40px 20px;background:var(--color-bg-alt)}.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.feature-item{text-align:center;padding:20px 8px}.feature-icon{width:44px;height:44px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.feature-icon svg{width:22px;height:22px;stroke:var(--color-accent)}.feature-item h4{font-size:12px;font-weight:600;margin-bottom:4px}.feature-item p{font-size:10px;color:var(--color-text-tertiary)}.detail-gallery{position:relative;background:var(--color-bg-alt);aspect-ratio:4/5;overflow:hidden}.gallery-slider{display:flex;height:100%;transition:transform .4s cubic-bezier(.16,1,.3,1)}.gallery-slide{min-width:100%;height:100%;display:flex;align-items:center;justify-content:center}.gallery-slide img{width:100%;height:100%;object-fit:cover}.gallery-dots{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px}.gallery-dot{width:6px;height:6px;border-radius:var(--radius-full);background:#fff6;transition:all .3s}.gallery-dot.active{width:20px;background:#fff}.gallery-actions{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:10px}.gallery-action-btn{width:40px;height:40px;background:#ffffffe6;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm)}.gallery-action-btn svg{width:18px;height:18px;stroke:var(--color-text-primary)}.gallery-action-btn.active svg{stroke:var(--color-accent);fill:var(--color-accent)}.detail-info{padding:24px 20px;background:var(--color-bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-top:-20px;position:relative;z-index:1}.detail-title{font-family:var(--font-display);font-size:26px;font-weight:500;margin-bottom:8px;letter-spacing:1px;line-height:1.3}.detail-subtitle{font-size:13px;color:var(--color-text-tertiary);margin-bottom:16px;letter-spacing:2px;text-transform:uppercase}.detail-price-row{display:flex;align-items:baseline;gap:12px;margin-bottom:20px}.detail-price{font-family:var(--font-display);font-size:32px;font-weight:600;color:var(--color-accent)}.detail-price .currency{font-size:18px;margin-right:2px}.detail-price-origin{font-size:14px;color:var(--color-text-tertiary);text-decoration:line-through}.detail-section{padding:20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light)}.detail-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.detail-section-title{font-size:15px;font-weight:600;letter-spacing:1px}.detail-section-header .more{font-size:12px;color:var(--color-text-tertiary)}.spec-group{margin-bottom:20px}.spec-group:last-child{margin-bottom:14px}.spec-label{font-size:13px;color:var(--color-text-secondary);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.spec-label .spec-selected{color:var(--color-accent);font-weight:500}.spec-options{display:flex;flex-wrap:wrap;gap:10px}.spec-option{padding:10px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-size:13px;background:var(--color-bg);transition:all .25s;cursor:pointer;position:relative}.spec-option .option-price{font-size:11px;color:var(--color-accent);margin-left:4px;font-weight:500}.spec-option.active{border-color:var(--color-accent);background:#b8860b0f;color:var(--color-accent-dark);font-weight:500}.color-options{display:flex;flex-wrap:wrap;gap:12px}.color-option{width:40px;height:40px;border-radius:var(--radius-full);position:relative;cursor:pointer;border:2px solid transparent;transition:all .25s}.color-option:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:var(--radius-full);border:2px solid var(--color-border)}.color-option.active{transform:scale(1.1)}.color-option.active:after{border-color:var(--color-accent)}.color-option .color-check{position:absolute;bottom:-2px;right:-2px;width:16px;height:16px;background:var(--color-accent);border-radius:var(--radius-full);display:none;align-items:center;justify-content:center}.color-option.active .color-check{display:flex}.color-option .color-check svg{width:10px;height:10px;stroke:#fff}.size-options{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.size-option{padding:12px 0;text-align:center;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;font-weight:500;cursor:pointer;transition:all .25s}.size-option.active{border-color:var(--color-accent);background:#b8860b0f;color:var(--color-accent-dark)}.size-option.disabled{opacity:.4;cursor:not-allowed}.size-guide-link{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-accent);cursor:pointer}.size-guide-link svg{width:14px;height:14px;stroke:currentColor}.size-table{width:100%;border-collapse:collapse;font-size:12px}.size-table th,.size-table td{padding:10px 8px;text-align:center;border-bottom:1px solid var(--color-border-light)}.size-table th{background:var(--color-bg-alt);font-weight:600;color:var(--color-text-secondary)}.detail-rich-media{padding:24px 20px 100px;background:var(--color-bg-card)}.rich-section{margin-bottom:32px}.rich-section:last-child{margin-bottom:0}.rich-section h3{font-family:var(--font-display);font-size:20px;margin-bottom:16px;text-align:center;position:relative;padding-bottom:12px}.rich-section h3:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:30px;height:2px;background:var(--color-gold-gradient)}.rich-section p{font-size:14px;line-height:1.8;color:var(--color-text-secondary);margin-bottom:16px}.rich-image{width:100%;border-radius:var(--radius-md);margin:16px 0;aspect-ratio:4/3;object-fit:cover;background:var(--color-bg-alt)}.detail-bottom-bar{position:fixed;bottom:0;left:0;right:0;background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:12px 20px calc(12px + var(--safe-bottom));display:flex;gap:12px;border-top:1px solid var(--color-border-light);z-index:50}.bottom-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 12px;font-size:10px;color:var(--color-text-secondary);gap:2px}.bottom-action svg{width:22px;height:22px;stroke:currentColor}.bottom-action.active svg{stroke:var(--color-accent);fill:var(--color-accent)}.detail-bottom-bar .btn{flex:1;padding:14px;font-size:14px}.custom-page{display:flex;flex-direction:column;height:calc(100vh - var(--nav-height))}.custom-main{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;position:relative}.custom-editor-area{flex:1;position:relative;background:var(--color-bg);min-height:0;display:flex;flex-direction:column}.canvas-container{flex:1;position:relative;overflow:hidden;display:flex;justify-content:center;align-items:center;min-height:200px}.custom-panel{background:var(--color-bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px 20px calc(20px + var(--safe-bottom));box-shadow:0 -4px 20px #0000000f;max-height:50vh;overflow-y:auto}@media (min-width: 768px){.custom-main{flex-direction:row;align-items:stretch;overflow:visible}.custom-editor-area{flex:1;order:1;min-height:0;overflow:hidden}.custom-panel{width:380px;max-width:380px;max-height:none;height:auto;border-radius:0;box-shadow:-4px 0 20px #0000000f;order:2;padding-bottom:20px;overflow-y:visible;overflow-x:visible;display:flex;flex-direction:column;flex-shrink:0}.custom-panel .price-summary{flex-shrink:0}.custom-panel .panel-content{flex:0 0 auto;overflow-y:visible;overflow-x:visible}.custom-panel .custom-bottom-bar{position:relative!important;flex-shrink:0;margin-top:16px;border-top:none;padding:0;background:transparent}.custom-page{height:auto;min-height:calc(100vh - var(--nav-height))}}.pattern-selector-wrapper{position:relative;padding:12px 20px;background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.pattern-selector-trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:6px 12px;border-radius:var(--radius-md);transition:background .2s ease}.pattern-selector-trigger:hover{background:var(--color-bg-alt)}.pattern-selector-trigger .trigger-label{font-size:13px;font-weight:600;color:var(--color-text-primary)}.pattern-selector-trigger .trigger-current{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--color-text-secondary)}.pattern-selector-trigger .trigger-current img{width:24px;height:24px;border-radius:4px;object-fit:cover}.pattern-selector-trigger .trigger-arrow{transition:transform .2s ease}.pattern-selector-trigger.expanded .trigger-arrow{transform:rotate(180deg)}.pattern-selector-dropdown{position:absolute;top:100%;left:20px;right:20px;background:var(--color-bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:16px;z-index:200;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s ease;border:1px solid var(--color-border-light)}.pattern-selector-dropdown.expanded{opacity:1;visibility:visible;transform:translateY(8px)}.pattern-dropdown-label{font-size:12px;font-weight:600;color:var(--color-text-tertiary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.pattern-selector-list{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.pattern-selector-list::-webkit-scrollbar{display:none}.pattern-selector-item{flex-shrink:0;width:72px;text-align:center;cursor:pointer;transition:all .2s ease}.pattern-thumb{width:60px;height:60px;margin:0 auto 6px;border-radius:var(--radius-md);overflow:hidden;border:2px solid transparent;background:var(--color-bg-alt)}.pattern-selector-item.active .pattern-thumb{border-color:var(--color-accent);box-shadow:0 0 0 2px #b8860b26}.pattern-thumb img{width:100%;height:100%;object-fit:cover}.pattern-name{font-size:11px;color:var(--color-text-secondary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.pattern-selector-item.active .pattern-name{color:var(--color-accent);font-weight:500}@media (min-width: 768px){.canvas-container{max-width:none;padding-top:80px}}.garment-base{width:80%;max-width:360px;aspect-ratio:3/4;position:relative;transition:transform .35s ease,width .35s ease,max-width .35s ease;background:transparent}.garment-area-front,.garment-area-back{width:85%;max-width:400px}.garment-area-leftShoulder{width:70%;max-width:320px;transform:translate(5%) scale(1.15)}.garment-area-rightShoulder{width:70%;max-width:320px;transform:translate(-5%) scale(1.15)}.garment-base svg{width:100%;height:100%}.garment-svg-wrapper{width:100%;height:100%;position:absolute;top:0;left:0}.garment-svg-wrapper svg{width:100%;height:100%}.garment-svg-wrapper svg path{fill:currentColor}.view-tabs{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;background:#fffffff2;border-radius:var(--radius-full);padding:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);z-index:10}.view-tab{display:flex;flex-direction:row;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-full);cursor:pointer;transition:all .25s;border:none;background:transparent;font-size:12px;font-weight:500;letter-spacing:1px}.view-tab.active{background:var(--color-gold-gradient);color:#fff}.view-tab:not(.active):hover{background:#00000008}.view-tab-text{font-size:12px;font-weight:500;color:var(--color-text-secondary);letter-spacing:1px;line-height:1}.view-tab.active .view-tab-text{color:#fff}.view-tab-craft{font-size:10px;font-weight:400;opacity:.9;padding:2px 6px;background:#ffffff4d;border-radius:var(--radius-sm);line-height:1;cursor:pointer;transition:all .2s}.view-tab:not(.active) .view-tab-craft{color:var(--color-text-secondary)}.view-tab.active .view-tab-craft{color:#ffffffd9;background:#ffffff40}.custom-area-tabs{position:absolute;top:16px;left:50%;transform:translate(-50%);display:flex;background:#fffffff2;border-radius:var(--radius-full);padding:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);z-index:10}.area-tab{padding:8px 16px;font-size:12px;border-radius:var(--radius-full);color:var(--color-text-secondary);transition:all .25s;cursor:pointer;font-weight:500;letter-spacing:1px}.area-tab.active{background:var(--color-gold-gradient);color:#fff}.area-tab{display:flex;align-items:center;gap:6px}.area-tab-text{line-height:1}.area-tab-craft{font-size:10px;font-weight:400;opacity:.9;padding:2px 6px;background:#ffffff4d;border-radius:var(--radius-sm);line-height:1}.area-tab.active .area-tab-craft{background:#ffffff40}.craft-selector{position:absolute;top:56px;left:50%;transform:translate(-50%) translateY(-10px);background:#fffffffa;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px;z-index:9;opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}.craft-selector.open{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.craft-options{display:flex;gap:16px}.craft-option{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;border-radius:var(--radius-md);cursor:pointer;transition:all .2s;border:2px solid transparent}.craft-option:active{transform:scale(.95)}.craft-option:hover{background:var(--color-bg-alt)}.craft-option.active{border-color:var(--color-gold);background:var(--color-bg-alt)}.craft-thumb{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border-radius:var(--radius-md);color:var(--color-gold);overflow:hidden}.craft-thumb img{width:100%;height:100%;object-fit:cover}.craft-thumb-default{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);color:var(--color-accent);font-size:18px;font-weight:600}.craft-thumb svg{width:24px;height:24px}.craft-name{font-size:12px;color:var(--color-text-primary);font-weight:500;letter-spacing:1px}.custom-area-zone{position:absolute;border:2px dashed rgba(184,134,11,.5);border-radius:var(--radius-sm);background:#b8860b0d;cursor:pointer;transition:all .25s}.custom-area-zone.active{border-color:var(--color-accent);background:#b8860b1a}.custom-area-zone .zone-label{position:absolute;top:8px;left:8px;font-size:10px;color:var(--color-accent);font-weight:600;letter-spacing:1px}.pattern-layer{position:absolute;cursor:move;user-select:none;-webkit-user-select:none}.pattern-layer img,.pattern-layer svg,.pattern-layer .text-layer-content{width:100%;height:100%;pointer-events:none}.pattern-layer .text-layer-content{display:flex;align-items:center;justify-content:center;color:#111;font-size:18px;font-weight:500;line-height:1.2;text-align:center;word-break:break-word;white-space:pre-wrap;overflow:hidden}.pattern-layer.selected{outline:2px solid var(--color-accent);outline-offset:4px}.resize-handle{position:absolute;width:20px;height:20px;background:#fff;border:2px solid var(--color-accent);border-radius:var(--radius-full);z-index:10}.resize-handle.br{right:-10px;bottom:-10px;cursor:nwse-resize}.rotate-handle{position:absolute;width:20px;height:20px;background:#fff;border:2px solid var(--color-accent);border-radius:var(--radius-full);top:-30px;left:50%;transform:translate(-50%);cursor:grab;z-index:10}.rotate-handle:before{content:"";position:absolute;width:2px;height:15px;background:var(--color-accent);bottom:-15px;left:50%;transform:translate(-50%)}.custom-toolbar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;background:#fffffff2;border-radius:var(--radius-full);padding:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow-md);gap:4px;z-index:10}@media (min-width: 768px){.custom-toolbar{background:var(--color-bg-card);padding:8px 16px}.custom-toolbar .tool-btn{width:36px;height:36px}.custom-toolbar .tool-btn svg{width:18px;height:18px}}.tool-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);transition:all .25s;color:var(--color-text-secondary)}.tool-btn svg{width:18px;height:18px;stroke:currentColor}.tool-btn.active{background:var(--color-bg-alt);color:var(--color-accent)}.tool-btn:active{transform:scale(.92)}.custom-panel-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--color-bg-alt);border-radius:var(--radius-full);padding:4px}.panel-tab{flex:1;padding:10px;text-align:center;font-size:13px;border-radius:var(--radius-full);color:var(--color-text-secondary);font-weight:500;transition:all .25s;cursor:pointer}.panel-tab.active{background:var(--color-bg-card);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.price-summary{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--color-bg-alt);border-radius:var(--radius-md);margin-top:26px;margin-bottom:18px}.price-item{text-align:center}.price-item .price-label{font-size:11px;color:var(--color-text-tertiary);margin-bottom:4px;letter-spacing:1px}.price-item .price-value{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-accent)}.price-divider{width:1px;height:36px;background:var(--color-border)}.upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:32px 20px;text-align:center;cursor:pointer;transition:all .25s;margin-bottom:16px}.upload-area:active{border-color:var(--color-accent);background:#b8860b08}.upload-icon{width:48px;height:48px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border-radius:var(--radius-full)}.upload-icon svg{width:24px;height:24px;stroke:var(--color-accent)}.upload-area h4{font-size:14px;margin-bottom:6px}.upload-area p{font-size:12px;color:var(--color-text-tertiary)}.pattern-library{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.pattern-lib-item{aspect-ratio:1;border-radius:var(--radius-md);background:var(--color-bg-alt);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;overflow:hidden;border:2px solid transparent}.pattern-lib-item:active{transform:scale(.95);border-color:var(--color-accent)}.pattern-lib-item img,.pattern-lib-item svg{width:60%;height:60%}.layer-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-bg-alt);border-radius:var(--radius-md);cursor:pointer;transition:all .25s}.layer-item.active{background:#b8860b1a}.layer-thumb{width:40px;height:40px;background:var(--color-bg-card);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden}.layer-thumb img{width:80%;height:80%;object-fit:contain}.layer-info{flex:1}.layer-name{font-size:13px;font-weight:500}.layer-area{font-size:11px;color:var(--color-text-tertiary)}.layer-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--color-bg-card);color:var(--color-text-secondary)}.layer-action-btn svg{width:14px;height:14px;stroke:currentColor}.custom-bottom-bar{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--color-border-light)}.custom-bottom-bar .btn{flex:1}.order-page{padding-bottom:120px}.order-preview{background:var(--color-bg-card);padding:24px 20px;display:flex;gap:16px}.order-preview-img{width:100px;height:120px;border-radius:var(--radius-md);background:var(--color-bg-alt);overflow:hidden;flex-shrink:0}.order-preview-img img{width:100%;height:100%;object-fit:cover}.order-preview-info{flex:1;display:flex;flex-direction:column;justify-content:center}.order-preview-title{font-family:var(--font-display);font-size:18px;font-weight:500;margin-bottom:6px}.order-preview-spec{font-size:12px;color:var(--color-text-tertiary);margin-bottom:8px}.order-preview-price{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--color-accent)}.order-section{background:var(--color-bg-card);margin-top:12px;padding:20px}.order-section-title{font-size:14px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:8px;letter-spacing:1px}.order-section-title:before{content:"";width:3px;height:14px;background:var(--color-gold-gradient);border-radius:2px}.spec-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.spec-summary-item{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--color-bg-alt);border-radius:var(--radius-md)}.spec-summary-label{font-size:11px;color:var(--color-text-tertiary);letter-spacing:1px}.spec-summary-value{font-size:13px;font-weight:500}.quantity-selector{display:flex;align-items:center;justify-content:center;gap:20px;padding:16px;background:var(--color-bg-alt);border-radius:var(--radius-md)}.qty-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:var(--color-bg-card);box-shadow:var(--shadow-sm);font-size:18px;font-weight:300;transition:all .2s}.qty-btn:active{transform:scale(.92)}.qty-value{font-family:var(--font-display);font-size:24px;font-weight:600;min-width:40px;text-align:center}.order-total{display:flex;align-items:center;justify-content:space-between;padding:20px;background:var(--color-bg-alt);border-radius:var(--radius-md)}.order-total-label{font-size:14px;color:var(--color-text-secondary)}.order-total-value{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--color-accent)}.order-bottom-bar{position:fixed;bottom:var(--tabbar-height);left:0;right:0;background:var(--color-bg-card);padding:12px 20px;display:flex;gap:12px;border-top:1px solid var(--color-border-light);z-index:50}.order-bottom-bar .btn{flex:1}.btn-share{background:var(--color-bg-alt);color:var(--color-text-primary);display:flex;align-items:center;justify-content:center;gap:6px}.btn-share svg{width:16px;height:16px;stroke:currentColor}.share-modal{text-align:center}.qr-code{width:200px;height:200px;margin:0 auto 20px;background:var(--color-bg-card);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;padding:16px;box-shadow:var(--shadow-sm)}.qr-code svg{width:100%;height:100%}.share-link{display:flex;gap:8px;margin-bottom:20px}.share-link-input{flex:1;padding:12px 16px;background:var(--color-bg-alt);border:none;border-radius:var(--radius-md);font-size:12px;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.share-link-copy{padding:12px 20px;background:var(--color-accent);color:#fff;border-radius:var(--radius-md);font-size:13px;font-weight:500;flex-shrink:0}.share-info{font-size:12px;color:var(--color-text-tertiary);line-height:1.6}.form-page{padding-bottom:100px}.form-header{background:var(--color-bg-card);padding:24px 20px;text-align:center}.form-header-title{font-family:var(--font-display);font-size:22px;font-weight:500;margin-bottom:8px;letter-spacing:2px}.form-header-subtitle{font-size:13px;color:var(--color-text-tertiary)}.form-preview{display:flex;justify-content:center;gap:12px;padding:24px 20px;background:var(--color-bg-card);margin-top:1px;overflow-x:auto}.form-preview-item{width:80px;height:100px;border-radius:var(--radius-md);background:var(--color-bg-alt);flex-shrink:0;overflow:hidden}.form-preview-item img{width:100%;height:100%;object-fit:cover}.form-section{background:var(--color-bg-card);margin-top:12px;padding:24px 20px}.form-section-title{font-size:15px;font-weight:600;margin-bottom:20px;letter-spacing:1px}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:13px;color:var(--color-text-secondary);margin-bottom:10px}.form-label .required{color:var(--color-error);margin-left:4px}.form-input{width:100%;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;background:var(--color-bg);transition:all .25s}.form-input:focus{outline:none;border-color:var(--color-accent);background:var(--color-bg-card)}.form-select-wrapper{position:relative}.form-select-wrapper:after{content:"";position:absolute;right:16px;top:50%;transform:translateY(-50%) rotate(45deg);width:8px;height:8px;border-right:2px solid var(--color-text-tertiary);border-bottom:2px solid var(--color-text-tertiary);pointer-events:none}.form-select{width:100%;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;background:var(--color-bg);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.form-size-options{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}.form-color-options{display:flex;flex-wrap:wrap;gap:12px}.form-size-table{margin-top:12px;overflow-x:auto}.form-size-table table{width:100%;min-width:400px}.form-submit-bar{position:fixed;bottom:0;left:0;right:0;padding:12px 20px calc(12px + var(--safe-bottom));background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:50}.form-submit-bar .btn{width:100%}.profile-page{padding-bottom:calc(var(--tabbar-height) + 20px)}.profile-header{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);padding:40px 20px 60px;position:relative;overflow:hidden}.profile-header:before{content:"";position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,rgba(184,134,11,.15) 0%,transparent 70%);border-radius:50%}.profile-info{position:relative;display:flex;align-items:center;gap:16px}.profile-avatar{width:64px;height:64px;border-radius:var(--radius-full);background:var(--color-gold-gradient);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:24px;font-weight:600;color:#fff}.profile-text{flex:1;color:#fff}.profile-name{font-family:var(--font-display);font-size:22px;font-weight:500;margin-bottom:4px}.profile-id{font-size:12px;color:#ffffff80}.profile-setting-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background:#ffffff1a;color:#fff}.profile-setting-btn svg{width:18px;height:18px;stroke:currentColor}.profile-stats{position:relative;display:grid;grid-template-columns:repeat(4,1fr);background:var(--color-bg-card);margin:-30px 20px 0;border-radius:var(--radius-lg);padding:20px 10px;box-shadow:var(--shadow-md);z-index:1}.profile-stat{text-align:center}.profile-stat-num{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--color-accent);margin-bottom:4px}.profile-stat-label{font-size:11px;color:var(--color-text-tertiary);letter-spacing:1px}.profile-menu{margin:24px 20px;background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.profile-menu-item{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background .2s}.profile-menu-item:last-child{border-bottom:none}.profile-menu-item:active{background:var(--color-bg-alt)}.profile-menu-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border-radius:var(--radius-md);color:var(--color-accent)}.profile-menu-icon svg{width:20px;height:20px;stroke:currentColor}.profile-menu-text{flex:1;font-size:15px}.profile-menu-arrow{color:var(--color-text-tertiary)}.profile-menu-arrow svg{width:16px;height:16px;stroke:currentColor}.orders-page{padding-bottom:calc(var(--tabbar-height) + 20px)}.orders-tabs{position:sticky;top:var(--nav-height);background:var(--color-bg);z-index:10;display:flex;padding:0 20px;border-bottom:1px solid var(--color-border-light)}.order-tab{padding:16px 20px;font-size:14px;color:var(--color-text-secondary);position:relative;white-space:nowrap;cursor:pointer}.order-tab.active{color:var(--color-text-primary);font-weight:600}.order-tab.active:after{content:"";position:absolute;bottom:-1px;left:20px;right:20px;height:2px;background:var(--color-gold-gradient);border-radius:2px}.orders-list{padding:16px 20px}.order-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.order-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--color-border-light)}.order-card-no{font-size:12px;color:var(--color-text-tertiary)}.order-card-status{font-size:12px;font-weight:600;color:var(--color-accent)}.order-card-body{display:flex;gap:12px;margin-bottom:12px}.order-card-img{width:80px;height:100px;border-radius:var(--radius-md);background:var(--color-bg-alt);overflow:hidden;flex-shrink:0}.order-card-img img{width:100%;height:100%;object-fit:cover}.order-card-info{flex:1;display:flex;flex-direction:column;justify-content:space-between}.order-card-title{font-size:14px;font-weight:500;margin-bottom:4px;line-height:1.4}.order-card-spec{font-size:11px;color:var(--color-text-tertiary);margin-bottom:8px}.order-card-price{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--color-accent)}.order-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--color-border-light)}.order-card-total{font-size:13px;color:var(--color-text-secondary)}.order-card-total strong{font-family:var(--font-display);font-size:18px;color:var(--color-text-primary);margin-left:4px}.order-card-actions{display:flex;gap:8px}.order-action-btn{padding:8px 16px;border-radius:var(--radius-full);font-size:12px;font-weight:500;border:1px solid var(--color-border);background:transparent;color:var(--color-text-secondary);cursor:pointer}.order-action-btn.primary{background:var(--color-gold-gradient);color:#fff;border-color:transparent}.works-page{padding-bottom:calc(var(--tabbar-height) + 20px)}.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:20px}.work-card{background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer}.work-card-img{aspect-ratio:3/4;background:var(--color-bg-alt);position:relative;overflow:hidden}.work-card-img img{width:100%;height:100%;object-fit:cover}.work-card-badge{position:absolute;top:10px;right:10px;background:#0009;color:#fff;font-size:10px;padding:4px 8px;border-radius:var(--radius-full);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.work-card-info{padding:12px}.work-card-title{font-size:13px;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.work-card-stats{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--color-text-tertiary)}.work-card-collected{display:flex;align-items:center;gap:4px}.work-card-collected svg{width:12px;height:12px;stroke:var(--color-accent)}.empty-state{text-align:center;padding:60px 20px}.empty-icon{width:80px;height:80px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border-radius:var(--radius-full)}.empty-icon svg{width:36px;height:36px;stroke:var(--color-text-tertiary)}.empty-title{font-size:16px;margin-bottom:8px;color:var(--color-text-secondary)}.empty-desc{font-size:13px;color:var(--color-text-tertiary);margin-bottom:20px}.collect-list-page{padding-bottom:100px}.collect-list-header{background:var(--color-bg-card);padding:20px;display:flex;align-items:center;gap:16px}.collect-list-img{width:60px;height:72px;border-radius:var(--radius-md);background:var(--color-bg-alt);overflow:hidden}.collect-list-info h3{font-size:15px;margin-bottom:4px}.collect-list-info p{font-size:12px;color:var(--color-text-tertiary)}.collect-export-bar{position:sticky;top:var(--nav-height);background:var(--color-bg);padding:12px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-border-light);z-index:10}.collect-count{font-size:13px;color:var(--color-text-secondary)}.collect-count strong{color:var(--color-accent);font-weight:600}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--color-bg-card);border-radius:var(--radius-full);font-size:12px;font-weight:500;color:var(--color-accent);border:1px solid var(--color-border)}.export-btn svg{width:14px;height:14px;stroke:currentColor}.collect-table{overflow-x:auto;padding:0 20px}.collect-table table{width:100%;min-width:500px;border-collapse:collapse;font-size:12px}.collect-table th{background:var(--color-bg-alt);padding:12px 10px;text-align:left;font-weight:600;color:var(--color-text-secondary);position:sticky;top:0}.collect-table td{padding:12px 10px;border-bottom:1px solid var(--color-border-light)}.collect-table tr:hover{background:var(--color-bg-alt)}.favorites-page,.shared-page{padding-bottom:calc(var(--tabbar-height) + 20px)}.shared-list{padding:16px 20px}.shared-item{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:16px;margin-bottom:12px;display:flex;gap:14px;box-shadow:var(--shadow-sm);cursor:pointer}.shared-item-img{width:70px;height:88px;border-radius:var(--radius-md);background:var(--color-bg-alt);overflow:hidden;flex-shrink:0}.shared-item-info{flex:1;display:flex;flex-direction:column;justify-content:space-between}.shared-item-title{font-size:14px;font-weight:500;margin-bottom:4px}.shared-item-from{font-size:12px;color:var(--color-text-tertiary)}.shared-item-status{font-size:11px;padding:4px 10px;border-radius:var(--radius-full);background:var(--color-bg-alt);display:inline-block;align-self:flex-start}.shared-item-status.submitted{background:#2d5a271a;color:var(--color-success)}.settings-page{padding-bottom:calc(var(--tabbar-height) + 20px)}.settings-group{margin:24px 20px;background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.settings-item{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid var(--color-border-light);cursor:pointer}.settings-item:last-child{border-bottom:none}.settings-item:active{background:var(--color-bg-alt)}.settings-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border-radius:var(--radius-md);color:var(--color-text-secondary)}.settings-icon svg{width:18px;height:18px;stroke:currentColor}.settings-text{flex:1;font-size:14px}.settings-value{font-size:13px;color:var(--color-text-tertiary)}.settings-arrow{color:var(--color-text-tertiary)}.settings-arrow svg{width:16px;height:16px;stroke:currentColor}@media (min-width: 768px){.bottom-tabbar{max-width:1200px;left:50%;transform:translate(-50%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.page-container{padding-bottom:var(--tabbar-height)}.home-section{padding:60px 40px}.hero-title{font-size:56px}.pattern-grid{grid-template-columns:repeat(4,1fr);gap:24px}.customize-entry{margin:40px;aspect-ratio:21/9}.feature-grid{grid-template-columns:repeat(4,1fr);gap:20px}.detail-gallery{aspect-ratio:16/10}.detail-info,.detail-section,.detail-rich-media{padding-left:40px;padding-right:40px}.detail-bottom-bar{max-width:1200px;left:50%;transform:translate(-50%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.order-bottom-bar,.form-submit-bar{max-width:1200px;left:50%;transform:translate(-50%)}.profile-header{padding:60px 40px 80px}.profile-stats{margin:-40px 40px 0}.profile-menu{margin:32px 40px}.works-grid{grid-template-columns:repeat(3,1fr);gap:24px;padding:32px 40px}}@media (min-width: 1024px){.pattern-grid,.works-grid{grid-template-columns:repeat(4,1fr)}}.text-gold{color:var(--color-accent)}.text-muted{color:var(--color-text-tertiary)}.text-center{text-align:center}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mb-24{margin-bottom:24px}.hidden{display:none!important}.auth-page{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}.auth-hero{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 24px 40px;background:linear-gradient(180deg,#faf7f2,#f3eee7);position:relative;overflow:hidden}.auth-hero:before{content:"";position:absolute;top:-50%;right:-30%;width:400px;height:400px;background:radial-gradient(circle,rgba(184,134,11,.08) 0%,transparent 70%);border-radius:50%}.auth-hero:after{content:"";position:absolute;bottom:-20%;left:-20%;width:300px;height:300px;background:radial-gradient(circle,rgba(212,168,75,.06) 0%,transparent 70%);border-radius:50%}.auth-hero-content{text-align:center;position:relative;z-index:1}.auth-logo{font-family:var(--font-display);font-size:48px;font-weight:600;letter-spacing:8px;background:var(--color-gold-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:12px}.auth-subtitle{font-size:14px;color:var(--color-text-secondary);letter-spacing:4px;font-weight:300}.auth-form-container{background:var(--color-bg-card);border-radius:24px 24px 0 0;padding:32px 24px 40px;margin-top:-24px;position:relative;z-index:2;box-shadow:0 -4px 24px #0000000a}.auth-form-title{font-size:24px;font-weight:600;margin-bottom:8px;font-family:var(--font-display);letter-spacing:2px}.auth-form-desc{font-size:13px;color:var(--color-text-tertiary);margin-bottom:28px}.auth-form-group{margin-bottom:18px}.auth-form-label{display:block;font-size:13px;color:var(--color-text-secondary);margin-bottom:8px;font-weight:500}.auth-input-wrapper{position:relative}.auth-input{width:100%;padding:14px 16px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;background:var(--color-bg);transition:all .25s}.auth-input:focus{outline:none;border-color:var(--color-accent);background:var(--color-bg-card)}.auth-input-code{padding-right:120px}.auth-code-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);padding:8px 14px;font-size:12px;color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius-sm);background:transparent;cursor:pointer;transition:all .2s;white-space:nowrap}.auth-code-btn:hover:not(:disabled){background:var(--color-accent);color:#fff}.auth-code-btn:disabled{color:var(--color-text-tertiary);border-color:var(--color-border);cursor:not-allowed}.auth-password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-tertiary);background:none;border:none}.auth-password-toggle svg{width:18px;height:18px}.auth-submit-btn{width:100%;padding:16px;background:var(--color-gold-gradient);color:#fff;border:none;border-radius:var(--radius-md);font-size:16px;font-weight:500;cursor:pointer;margin-top:8px;transition:all .3s;letter-spacing:2px}.auth-submit-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-gold)}.auth-submit-btn:active{transform:translateY(0)}.auth-footer{display:flex;justify-content:center;align-items:center;margin-top:24px;font-size:13px;color:var(--color-text-secondary)}.auth-footer-link{color:var(--color-accent);margin-left:6px;cursor:pointer;font-weight:500}.auth-footer-link:hover{text-decoration:underline}.auth-forgot-link{text-align:right;margin-top:-10px;margin-bottom:20px;font-size:13px;color:var(--color-text-tertiary);cursor:pointer}.auth-forgot-link:hover{color:var(--color-accent)}.auth-agreement{display:flex;align-items:flex-start;gap:8px;margin-bottom:20px;font-size:12px;color:var(--color-text-tertiary);line-height:1.6}.auth-agreement input{margin-top:2px;flex-shrink:0}.auth-agreement a{color:var(--color-accent);cursor:pointer}.auth-divider{display:flex;align-items:center;gap:16px;margin:28px 0 20px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.auth-divider-text{font-size:12px;color:var(--color-text-tertiary)}.auth-social{display:flex;justify-content:center;gap:24px}.auth-social-btn{width:44px;height:44px;border-radius:50%;border:1.5px solid var(--color-border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--color-bg)}.auth-social-btn:hover{border-color:var(--color-accent);transform:translateY(-2px)}.auth-social-btn svg{width:20px;height:20px}.btn{transition:all .2s ease;transform:translateY(0)}.btn:active{transform:scale(.98)}.btn-primary:hover{background:var(--color-accent-dark);box-shadow:var(--shadow-gold)}.btn-outline:hover{border-color:var(--color-accent);color:var(--color-accent)}.btn-lg:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.pattern-card,.work-card,.order-card,.shared-item{transition:all .3s ease}.pattern-card:hover,.work-card:hover,.shared-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.pattern-card:active,.work-card:active,.shared-item:active{transform:translateY(0)}.gallery-main-img,.pattern-card img,.work-card img{transition:transform .3s ease}.pattern-card:hover img{transform:scale(1.05)}.loading{opacity:.6;pointer-events:none}.loading:after{content:"";position:absolute;top:50%;left:50%;width:24px;height:24px;margin:-12px 0 0 -12px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{animation:fadeInOverlay .3s ease}.modal-content{animation:scaleIn .3s ease}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.address-page{padding-bottom:100px}.page-header{padding:20px 20px 16px;background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light)}.page-title{font-size:20px;font-weight:600;color:var(--color-text-primary)}.address-list{padding:16px 20px}.address-item{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:20px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.address-content{cursor:pointer}.address-top{display:flex;align-items:center;gap:12px;margin-bottom:8px}.address-name{font-size:16px;font-weight:600;color:var(--color-text-primary)}.address-phone{font-size:14px;color:var(--color-text-secondary)}.address-tag{font-size:11px;padding:2px 8px;background:var(--color-gold-gradient);color:#fff;border-radius:var(--radius-full)}.address-detail{font-size:14px;color:var(--color-text-secondary);line-height:1.5}.address-actions{display:flex;justify-content:flex-end;gap:16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border-light)}.address-action-btn{font-size:13px;color:var(--color-text-secondary);background:none;border:none;cursor:pointer;padding:4px 8px}.address-action-btn.delete{color:var(--color-error)}.address-bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:16px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:100}.btn-full{width:100%}.btn-danger{background:var(--color-error);color:#fff;border:none;padding:14px 24px;border-radius:var(--radius-full);font-size:15px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-danger:hover{opacity:.9}.address-edit-page{padding:0 0 100px}.form-group{padding:16px 20px;background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light)}.form-label{display:block;font-size:14px;color:var(--color-text-secondary);margin-bottom:8px}.form-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background:var(--color-bg);outline:none;transition:border-color .3s ease;box-sizing:border-box}.form-input:focus{border-color:var(--color-accent)}.form-textarea{width:100%;min-height:100px;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;color:var(--color-text-primary);background:var(--color-bg);outline:none;resize:vertical;transition:border-color .3s ease;box-sizing:border-box;font-family:inherit}.form-textarea:focus{border-color:var(--color-accent)}.form-switch-group{display:flex;align-items:center;justify-content:space-between}.form-switch-group .form-label{margin-bottom:0}.form-switch{width:48px;height:28px;background:var(--color-border);border-radius:14px;position:relative;cursor:pointer;transition:background .3s ease}.form-switch.active{background:var(--color-accent)}.switch-dot{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 2px 4px #0000001a}.form-switch.active .switch-dot{transform:translate(20px)}.form-bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:16px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:100}.form-input-wrapper{position:relative;display:flex;align-items:center}.form-input-wrapper .form-input{padding-right:44px}.password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:4px}.password-toggle svg{width:20px;height:20px;stroke:currentColor}.form-input-row{display:flex;gap:12px;align-items:center}.form-input-row .form-input{flex:1}.form-code-btn{padding:12px 16px;background:var(--color-bg-alt);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;color:var(--color-accent);cursor:pointer;white-space:nowrap;transition:all .3s ease}.form-code-btn:disabled{opacity:.5;cursor:not-allowed}.form-checkbox{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-box{width:20px;height:20px;border:2px solid var(--color-border);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.form-checkbox.checked .checkbox-box{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.checkbox-box svg{width:14px;height:14px;stroke:currentColor;opacity:0;transition:opacity .2s ease}.form-checkbox.checked .checkbox-box svg{opacity:1}.checkbox-label{font-size:14px;color:var(--color-text-secondary)}.my-info-page{padding-bottom:100px}.info-avatar-section{padding:30px 20px;text-align:center;background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light)}.info-avatar{width:80px;height:80px;border-radius:50%;background:var(--color-gold-gradient);color:#fff;font-size:32px;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.info-avatar-hint{font-size:13px;color:var(--color-text-tertiary)}.info-list{margin-top:12px;background:var(--color-bg-card)}.info-item{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--color-border-light)}.info-item:last-child{border-bottom:none}.info-label{font-size:14px;color:var(--color-text-secondary)}.info-value{font-size:14px;color:var(--color-text-primary)}.info-bottom-bar{position:fixed;bottom:0;left:0;right:0;padding:16px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:100}.account-security-page{padding-bottom:20px}.security-list{margin:16px 20px;background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.security-item{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid var(--color-border-light);cursor:pointer}.security-item:last-child{border-bottom:none}.security-item:active{background:var(--color-bg-alt)}.security-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-alt);border-radius:var(--radius-md);color:var(--color-text-secondary)}.security-icon svg{width:18px;height:18px;stroke:currentColor}.security-text{flex:1;font-size:14px}.security-arrow{color:var(--color-text-tertiary)}.security-arrow svg{width:16px;height:16px;stroke:currentColor}.security-tip{display:flex;align-items:flex-start;gap:8px;margin:24px 20px;padding:14px 16px;background:#d9770614;border-radius:var(--radius-md);font-size:12px;color:var(--color-text-secondary);line-height:1.5}.security-tip svg{width:16px;height:16px;stroke:#d97706;flex-shrink:0;margin-top:1px}.change-password-page,.cancel-account-page{padding-bottom:100px}.cancel-warning{margin:20px;padding:24px;background:#dc26260d;border:1px solid rgba(220,38,38,.15);border-radius:var(--radius-lg);text-align:center}.cancel-warning-icon{width:48px;height:48px;margin:0 auto 12px;color:var(--color-error)}.cancel-warning-icon svg{width:48px;height:48px;stroke:currentColor}.cancel-warning-title{font-size:16px;font-weight:600;color:var(--color-error);margin-bottom:8px}.cancel-warning-desc{font-size:13px;color:var(--color-text-secondary);line-height:1.6;text-align:left}.empty-state{padding:60px 20px;text-align:center;color:var(--color-text-tertiary)}.empty-icon{width:64px;height:64px;margin:0 auto 16px;opacity:.3}.empty-icon svg{width:64px;height:64px;stroke:currentColor}.empty-state p{font-size:14px}.min-order-hint{font-size:12px;color:var(--color-text-tertiary);font-weight:400;margin-left:8px}.qty-warning{display:flex;align-items:center;gap:8px;margin-top:12px;padding:10px 12px;background:#d9770614;border-radius:var(--radius-md);font-size:13px;color:#d97706}.qty-warning svg{width:16px;height:16px;stroke:currentColor;flex-shrink:0}.delivery-options{margin-top:12px}.delivery-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.delivery-label{font-size:14px;color:var(--color-text-primary)}.delivery-input-group{display:flex;align-items:center;gap:6px}.delivery-input{width:60px;padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;text-align:center;color:var(--color-text-primary);background:var(--color-bg);outline:none}.delivery-input:focus{border-color:var(--color-accent)}.delivery-unit{font-size:14px;color:var(--color-text-secondary)}.delivery-date-hint{font-size:13px;color:var(--color-text-tertiary);margin-bottom:16px;padding-left:2px}.express-option{padding:14px 16px;background:var(--color-bg-alt);border-radius:var(--radius-md);cursor:pointer;transition:background .2s ease}.express-option:active{background:var(--color-border)}.express-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.express-label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.express-fee{font-size:14px;color:#d97706;font-weight:500}.express-hint{font-size:12px;color:var(--color-text-tertiary)}.express-fee-row{display:flex;justify-content:space-between;padding:8px 0 0;font-size:13px;color:#d97706}.express-fee-value{font-weight:500}.total-qty-badge{float:right;font-size:13px;font-weight:400;color:var(--color-text-secondary)}.total-qty-badge strong{color:var(--color-accent);font-size:16px;margin:0 2px}.sku-list{background:var(--color-bg-alt);border-radius:var(--radius-md);overflow:hidden;margin-top:12px}.sku-table-header{display:flex;padding:10px 16px;background:#00000008;font-size:12px;color:var(--color-text-tertiary);font-weight:500;border-bottom:1px solid var(--color-border-light)}.sku-col-color{flex:1.2;display:flex;align-items:center;gap:8px}.sku-col-size{flex:.8;display:flex;align-items:center}.sku-col-qty{flex:1;display:flex;align-items:center;justify-content:flex-end}.sku-item{display:flex;padding:14px 16px;border-bottom:1px solid var(--color-border-light);align-items:center}.sku-item:last-child{border-bottom:none}.sku-color-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid rgba(0,0,0,.1);flex-shrink:0}.sku-color-name{font-size:14px;color:var(--color-text-primary)}.sku-size-text{font-size:14px;color:var(--color-text-primary);font-weight:500}.sku-qty-selector{display:flex;align-items:center;background:var(--color-bg-card);border-radius:var(--radius-md);border:1px solid var(--color-border-light);overflow:hidden}.sku-qty-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;font-size:16px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease}.sku-qty-btn:hover{color:var(--color-accent);background:#b8860b14}.sku-qty-btn:active{transform:scale(.95)}.sku-qty-value{min-width:32px;text-align:center;font-size:14px;font-weight:500;color:var(--color-text-primary)}.delivery-date-input-group{display:flex;align-items:center}.delivery-date-input{padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;color:var(--color-text-primary);background:var(--color-bg);outline:none;font-family:inherit}.delivery-date-input:focus{border-color:var(--color-accent)}.delivery-date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .2s ease}.delivery-date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.modal-footer{display:flex;gap:12px;padding:0 24px 24px}.modal-footer .btn{flex:1}@media (min-width: 768px){.address-bottom-bar,.form-bottom-bar,.info-bottom-bar{max-width:1200px;left:50%;transform:translate(-50%)}}.order-detail-page{padding-bottom:100px}.order-detail-header{padding:24px 20px;background:linear-gradient(135deg,var(--color-accent) 0%,#B45309 100%);color:#fff}.order-status-badge{display:inline-block;padding:6px 16px;background:#fff3;border-radius:var(--radius-full);font-size:14px;font-weight:500;margin-bottom:8px}.order-status-desc{font-size:13px;opacity:.9}.order-detail-section{margin:12px 0;padding:16px 20px;background:var(--color-bg-card)}.section-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:12px}.order-detail-product{display:flex;gap:12px}.order-product-img{width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.order-product-img img{width:100%;height:100%;object-fit:cover}.order-product-info{flex:1}.order-product-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.order-product-spec{font-size:13px;color:var(--color-text-secondary);margin-bottom:2px}.order-product-price{font-size:14px;color:var(--color-text-primary);margin-top:6px}.detail-info-list{background:var(--color-bg-card);border-radius:var(--radius-lg);overflow:hidden}.detail-info-item{display:flex;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border-light)}.detail-info-item:last-child{border-bottom:none}.detail-info-item.total{background:var(--color-bg-alt)}.detail-info-label{font-size:14px;color:var(--color-text-secondary)}.detail-info-value{font-size:14px;color:var(--color-text-primary)}.detail-info-value.express-fee{color:#d97706}.detail-info-value.total-price{font-size:16px;font-weight:600;color:var(--color-accent)}.order-total-final{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light)}.order-total-final span:first-child{font-size:14px;color:var(--color-text-secondary)}.final-price{font-size:20px;font-weight:600;color:var(--color-accent)}.order-detail-bottom{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:100}.order-actions-final{display:flex;gap:10px}.order-actions-final .btn{padding:10px 20px;font-size:14px}.btn-outline{background:transparent;border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-outline:hover{border-color:var(--color-text-primary)}.btn-block{width:100%;margin-top:12px}.logistics-page{padding-bottom:20px}.logistics-header{padding:24px 20px;background:linear-gradient(135deg,#2b6cb0,#1a365d);color:#fff}.logistics-status{display:flex;align-items:center;gap:16px;margin-bottom:20px}.logistics-status-icon{width:56px;height:56px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center}.logistics-status-icon svg{width:28px;height:28px;stroke:currentColor}.logistics-status-info{flex:1}.logistics-status-text{font-size:18px;font-weight:600;margin-bottom:4px}.logistics-status-time{font-size:13px;opacity:.8}.logistics-express-info{background:#ffffff1a;border-radius:var(--radius-md);padding:12px 16px}.express-row{display:flex;justify-content:space-between;margin-bottom:8px}.express-row:last-child{margin-bottom:0}.express-label{font-size:13px;opacity:.8}.express-value{font-size:13px;font-weight:500}.tracking-no{font-family:monospace;letter-spacing:1px}.logistics-timeline{margin:16px 20px;padding:20px;background:var(--color-bg-card);border-radius:var(--radius-lg)}.timeline-item{position:relative;padding-left:24px;padding-bottom:24px;border-left:2px solid var(--color-border-light)}.timeline-item:last-child{padding-bottom:0;border-left-color:transparent}.timeline-item.current{border-left-color:var(--color-accent)}.timeline-dot{position:absolute;left:-6px;top:0;width:10px;height:10px;background:var(--color-border);border-radius:50%;border:2px solid var(--color-bg-card)}.timeline-item.current .timeline-dot{width:14px;height:14px;left:-8px;top:-2px;background:var(--color-accent)}.timeline-item.completed .timeline-dot{background:var(--color-accent)}.timeline-content{padding-left:8px}.timeline-desc{font-size:14px;color:var(--color-text-primary);line-height:1.5;margin-bottom:4px}.timeline-item.current .timeline-desc{color:var(--color-accent);font-weight:500}.timeline-time{font-size:12px;color:var(--color-text-tertiary)}.payment-success-page{min-height:100vh;display:flex;flex-direction:column;padding:40px 20px;text-align:center}.payment-success-content{padding:40px 0}.payment-success-icon{width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.payment-success-icon svg{width:40px;height:40px;stroke:currentColor}.payment-success-title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.payment-success-amount{font-size:32px;font-weight:700;color:var(--color-accent);margin-bottom:8px}.payment-success-order{font-size:13px;color:var(--color-text-tertiary)}.payment-success-tips{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:20px;margin:20px 0;text-align:left}.tip-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--color-border-light)}.tip-item:last-child{border-bottom:none}.tip-item svg{width:20px;height:20px;stroke:var(--color-accent);flex-shrink:0}.tip-item span{font-size:14px;color:var(--color-text-secondary)}.payment-success-actions{margin-top:auto;padding-top:20px}.payment-success-actions .btn{margin-bottom:12px}.payment-success-footer{margin-top:20px;padding-top:20px;font-size:13px;color:var(--color-text-tertiary)}.payment-success-footer a{color:var(--color-accent);text-decoration:none}.footer-dot{margin:0 8px}.cancel-order-page{padding-bottom:100px}.cancel-order-header{padding:30px 20px;text-align:center;background:#dc26260d}.cancel-order-icon{width:64px;height:64px;margin:0 auto 16px;color:var(--color-error)}.cancel-order-icon svg{width:64px;height:64px;stroke:currentColor}.cancel-order-title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.cancel-order-desc{font-size:13px;color:var(--color-text-secondary);line-height:1.5}.cancel-order-product{display:flex;gap:12px;padding:16px 20px;margin:16px 0;background:var(--color-bg-card)}.cancel-product-img{width:70px;height:70px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.cancel-product-img img{width:100%;height:100%;object-fit:cover}.cancel-product-info{flex:1}.cancel-product-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.cancel-product-spec{font-size:13px;color:var(--color-text-secondary);margin-bottom:2px}.cancel-product-price{font-size:15px;font-weight:500;color:var(--color-text-primary);margin-top:6px}.cancel-order-form{padding:16px 20px;background:var(--color-bg-card)}.form-section-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:16px}.cancel-reason-list{margin-bottom:16px}.cancel-reason-item{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--color-border-light);cursor:pointer}.cancel-reason-item:last-child{border-bottom:none}.cancel-reason-item.selected{color:var(--color-accent)}.reason-radio{width:20px;height:20px;border:2px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.cancel-reason-item.selected .reason-radio{border-color:var(--color-accent)}.radio-dot{width:10px;height:10px;background:var(--color-accent);border-radius:50%;opacity:0;transform:scale(0);transition:all .2s ease}.cancel-reason-item.selected .radio-dot{opacity:1;transform:scale(1)}.cancel-reason-item span{font-size:14px;color:var(--color-text-primary)}.cancel-reason-other{margin-top:12px}.cancel-order-bottom{position:fixed;bottom:0;left:0;right:0;display:flex;gap:12px;padding:16px 20px;background:var(--color-bg-card);border-top:1px solid var(--color-border-light);z-index:100}.cancel-order-bottom .btn{flex:1;padding:14px}.cancel-order-bottom .btn-danger:disabled{opacity:.5;cursor:not-allowed}.search-page{min-height:100%;background:var(--color-bg)}.search-bar{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--color-bg-card);position:sticky;top:0;z-index:10;border-bottom:1px solid var(--color-border-light)}.search-input-wrap{flex:1;position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:14px;width:18px;height:18px;color:var(--color-text-secondary);pointer-events:none}.search-input{width:100%;height:42px;padding:0 40px;border:1px solid var(--color-border-light);border-radius:var(--radius-full);background:var(--color-bg-alt);font-size:14px;color:var(--color-text-primary);outline:none;transition:all .2s}.search-input:focus{border-color:var(--color-gold);background:var(--color-bg-card)}.search-clear{position:absolute;right:12px;width:22px;height:22px;border:none;background:var(--color-text-tertiary);border-radius:50%;color:#fff;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0}.search-clear svg{width:12px;height:12px}.search-btn{flex-shrink:0;height:42px;padding:0 20px;border:none;background:var(--color-gold-gradient);color:#fff;border-radius:var(--radius-full);font-size:14px;font-weight:500;cursor:pointer}.search-hot{padding:20px}.search-section-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin-bottom:14px}.hot-tags{display:flex;flex-wrap:wrap;gap:10px}.hot-tag{padding:7px 16px;background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-full);font-size:13px;color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.hot-tag:active{background:var(--color-bg-alt);color:var(--color-gold);border-color:var(--color-gold)}.search-results{padding:16px 20px 20px}.search-result-header{margin-bottom:14px}.result-count{font-size:13px;color:var(--color-text-secondary)}.result-count em{color:var(--color-gold);font-style:normal;font-weight:600}.pattern-list{display:flex;flex-direction:column;gap:14px}.pattern-list-item{display:flex;gap:14px;background:var(--color-bg-card);border-radius:var(--radius-lg);padding:14px;cursor:pointer;transition:all .2s}.pattern-list-item:active{transform:scale(.98)}.pattern-list-img{width:100px;height:120px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0;background:var(--color-bg-alt)}.pattern-list-info{flex:1;display:flex;flex-direction:column;min-width:0}.pattern-list-title{font-size:15px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.4}.pattern-list-desc{font-size:12px;color:var(--color-text-tertiary);margin:0 0 8px;font-family:Inter,sans-serif;letter-spacing:.5px}.pattern-list-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.mini-tag{padding:2px 8px;background:var(--color-bg-alt);border-radius:var(--radius-sm);font-size:11px;color:var(--color-text-secondary)}.pattern-list-price{margin-top:auto;display:flex;align-items:baseline;gap:2px}.price-symbol{font-size:12px;color:var(--color-gold);font-weight:500}.price-num{font-size:18px;color:var(--color-gold);font-weight:700;font-family:Inter,sans-serif}.price-suffix{font-size:11px;color:var(--color-text-tertiary);margin-left:4px}.search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--color-text-tertiary)}.search-empty svg{width:64px;height:64px;margin-bottom:16px;opacity:.4}.search-empty p{font-size:15px;margin:0 0 6px;color:var(--color-text-secondary)}.search-empty span{font-size:13px}.hl{background:transparent;color:var(--color-gold);font-weight:600}.cs-modal{width:320px;background:var(--color-bg-card);border-radius:var(--radius-xl);overflow:hidden}.cs-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--color-border-light)}.cs-modal-header h3{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.cs-close-btn{width:28px;height:28px;border:none;background:var(--color-bg-alt);border-radius:50%;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.cs-close-btn svg{width:14px;height:14px}.cs-modal-body{padding:24px 20px 28px;text-align:center}.cs-qrcode{margin-bottom:20px;display:flex;justify-content:center}.qrcode-placeholder{width:180px;height:180px;background:#fff;border:1px solid var(--color-border-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);padding:12px}.qrcode-placeholder svg{width:100%;height:100%}.cs-info h4{margin:0 0 8px;font-size:17px;font-weight:600;color:var(--color-text-primary)}.cs-wx-id{font-size:14px;color:var(--color-gold);margin:0 0 6px;font-weight:500;letter-spacing:.5px}.cs-tip{font-size:12px;color:var(--color-text-tertiary);margin:0 0 20px}.cs-hours{background:var(--color-bg-alt);border-radius:var(--radius-md);padding:14px 16px;text-align:left}.cs-hour-item{display:flex;justify-content:space-between;align-items:center;font-size:13px}.cs-hour-label{color:var(--color-text-secondary)}.cs-hour-value{color:var(--color-text-primary);font-weight:500}.tab-item{position:relative}.tab-badge{position:absolute;top:4px;right:calc(50% - 24px);min-width:18px;height:18px;padding:0 5px;background:var(--color-error);color:#fff;font-size:11px;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif;line-height:1;pointer-events:none}.order-detail-header{display:flex;align-items:flex-start;justify-content:space-between}.order-detail-cs-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;border:1px solid var(--color-border-light);background:var(--color-bg-card);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:11px;cursor:pointer;flex-shrink:0}.order-detail-cs-btn svg{width:18px;height:18px}.order-detail-cs-btn:active{background:var(--color-bg-alt)}@media (min-width: 768px){.search-page{max-width:600px;margin:0 auto}.cs-modal{width:360px}.pattern-list-item:hover{box-shadow:0 4px 16px #0000000f}.hot-tag:hover{color:var(--color-gold);border-color:var(--color-gold)}}.panel-tabs{display:flex;gap:8px;padding:0 0 16px;border-bottom:1px solid var(--color-border);margin-bottom:16px}.panel-tab{flex:1;padding:8px 12px;border:none;border-radius:8px;font-size:14px;font-weight:500;color:var(--color-text-muted);background:transparent;cursor:pointer;transition:all .2s}.panel-tab.active{color:var(--color-gold);background:var(--color-bg-alt)}.panel-tab:hover:not(.active){background:var(--color-bg-alt)}.pattern-panel{padding:0}.upload-area{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--color-bg-alt);border-radius:12px;border:1px dashed var(--color-border);cursor:pointer;margin-bottom:16px}.upload-area:hover{border-color:var(--color-gold);background:#b8860b0d}.upload-area svg{width:32px;height:32px;color:var(--color-gold);margin-bottom:8px}.upload-text{font-size:14px;font-weight:500;color:var(--color-text)}.upload-hint{font-size:12px;color:var(--color-text-muted);margin-top:4px}.pattern-library{padding:0}.library-title{font-size:13px;font-weight:500;color:var(--color-text-muted);margin-bottom:12px}.library-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.library-item{display:flex;align-items:center;justify-content:center;padding:12px;background:var(--color-bg-alt);border-radius:12px;cursor:pointer;transition:all .2s}.library-item:hover{background:#b8860b1a;transform:scale(1.05)}.library-icon{font-size:24px;color:var(--color-gold)}.layers-panel{padding:0}.layers-empty{display:flex;flex-direction:column;align-items:center;padding:30px 0;color:var(--color-text-muted)}.layers-empty p{font-size:13px;margin:0}.layers-hint{font-size:11px;margin-top:4px}.layer-list{display:flex;flex-direction:column;gap:8px}.layer-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-bg-alt);border-radius:8px;cursor:pointer;border:1px solid transparent;transition:all .2s}.layer-item.active{border-color:var(--color-gold);background:#b8860b1a}.layer-thumb{width:36px;height:36px;background:var(--color-bg);border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden}.layer-thumb img{width:100%;height:100%;object-fit:contain}.layer-text-thumb{font-size:16px;color:var(--color-gold)}.layer-info{flex:1;min-width:0}.layer-name{font-size:13px;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-area{font-size:11px;color:var(--color-text-muted)}.layer-actions{display:flex;gap:4px}.layer-btn{width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center}.layer-btn:hover{background:var(--color-bg)}.layer-btn svg{width:14px;height:14px}.layer-btn.delete{color:#8b2635}.layer-btn.delete:hover{background:#8b26351a}.logo[data-v-0e405e09]{cursor:pointer}.logo[data-v-0e405e09]:hover{opacity:.8}.logo[data-v-0e405e09]:active{opacity:.6}.fade-enter-active[data-v-0ded7e93],.fade-leave-active[data-v-0ded7e93]{transition:opacity .3s}.fade-enter-from[data-v-0ded7e93],.fade-leave-to[data-v-0ded7e93]{opacity:0}.modal-overlay[data-v-d19ffb9f]{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;opacity:1}.modal-content[data-v-d19ffb9f]{animation:modalSlideUp-d19ffb9f .3s ease}@keyframes modalSlideUp-d19ffb9f{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-content[data-v-d19ffb9f]{transform:none;width:auto;border-radius:var(--radius-xl);padding:0;max-height:none;background:transparent}.cs-modal[data-v-d19ffb9f]{width:320px;background:var(--color-bg-card);border-radius:var(--radius-xl);overflow:hidden}.cs-modal-header[data-v-d19ffb9f]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--color-border-light)}.cs-modal-header h3[data-v-d19ffb9f]{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.cs-close-btn[data-v-d19ffb9f]{width:28px;height:28px;border:none;background:var(--color-bg-alt);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;color:var(--color-text-secondary)}.cs-close-btn svg[data-v-d19ffb9f]{width:14px;height:14px}.cs-modal-body[data-v-d19ffb9f]{padding:24px 20px 28px;text-align:center}.cs-qrcode[data-v-d19ffb9f]{margin-bottom:20px;display:flex;justify-content:center}.qrcode-image[data-v-d19ffb9f]{width:180px;height:180px;background:#fff;border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center}.qrcode-image img[data-v-d19ffb9f]{width:100%;height:100%;object-fit:contain}.qrcode-placeholder[data-v-d19ffb9f]{width:180px;height:180px;background:#fff;border:1px solid var(--color-border-light);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);padding:12px;box-sizing:border-box}.qrcode-placeholder svg[data-v-d19ffb9f]{width:100%;height:100%}.cs-info h4[data-v-d19ffb9f]{margin:0 0 8px;font-size:17px;font-weight:600;color:var(--color-text-primary)}.cs-wx-id[data-v-d19ffb9f]{font-size:14px;color:var(--color-accent);margin:0 0 6px;font-weight:500;letter-spacing:.5px}.cs-tip[data-v-d19ffb9f]{font-size:12px;color:var(--color-text-tertiary);margin:0 0 20px}.cs-hours[data-v-d19ffb9f]{background:var(--color-bg-alt);border-radius:var(--radius-md);padding:14px 16px;text-align:left}.cs-hour-item[data-v-d19ffb9f]{display:flex;justify-content:space-between;align-items:center;font-size:13px}.cs-hour-label[data-v-d19ffb9f]{color:var(--color-text-secondary)}.cs-hour-value[data-v-d19ffb9f]{color:var(--color-text-primary);font-weight:500}.fade-enter-active[data-v-d19ffb9f],.fade-leave-active[data-v-d19ffb9f]{transition:opacity .3s}.fade-enter-from[data-v-d19ffb9f],.fade-leave-to[data-v-d19ffb9f]{opacity:0}#app-root{min-height:100vh}
