:root{--pink:#ff8fab;--pink-light:#ffc2d1;--pink-bg:#fff0f3;--purple:#c9b1ff;--purple-light:#e8deff;--blue:#a0d2db;--blue-light:#d4f0f7;--yellow:#ffe66d;--green:#b8e6c8;--orange:#ffb088;--text:#5a4a6a;--text-light:#9a8aaa;--bg:#fef6f9;--card:#fff;--shadow:#ff8fab26;--radius:16px}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);background-image:radial-gradient(circle at 10% 20%,#ff8fab0f 0%,#0000 50%),radial-gradient(circle at 90% 80%,#c9b1ff0f 0%,#0000 50%);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif}.page{max-width:860px;margin:0 auto;padding:20px 16px 40px}.page-center{text-align:center}.hero{text-align:center;padding:24px 16px 16px}.hero h1{color:var(--pink);text-shadow:2px 2px #ff8fab26;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:2em}.hero .subtitle{color:var(--text-light);margin-top:4px;font-size:.95em;font-weight:600}.sparkle-row{justify-content:center;gap:8px;margin:6px 0;font-size:1.1em;display:flex}.hero-mascot{margin-bottom:6px;animation:2s ease-in-out infinite bounce}.layout{height:100vh;display:flex;overflow:hidden}.panel-left{background:linear-gradient(180deg, var(--pink-bg) 0%, var(--bg) 100%);border-right:2px solid var(--pink-light);flex-direction:column;flex-shrink:0;gap:12px;width:340px;min-width:300px;padding:16px;display:flex;overflow-y:auto}.panel-right{flex-direction:column;flex:1;gap:16px;padding:20px 24px;display:flex;position:relative;overflow-y:auto}.kawaii-card{background:var(--card);border-radius:var(--radius);box-shadow:0 3px 16px var(--shadow), 0 0 0 2px var(--pink-light);padding:20px;transition:transform .15s,box-shadow .15s}.kawaii-card.compact{padding:14px 16px}.card-title{color:var(--pink);align-items:center;gap:6px;margin-bottom:10px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.05em;display:flex}.card-title .emoji{font-size:1.15em}.upload-zone{border:3px dashed var(--pink-light);text-align:center;cursor:pointer;background:var(--pink-bg);border-radius:14px;padding:36px 20px;transition:all .2s}.upload-zone:hover{border-color:var(--pink);background:#fff5f7}.upload-zone.dragover{border-color:var(--purple);background:var(--purple-light)}.upload-zone .mascot-wrap{margin-bottom:10px}.upload-zone p{color:var(--text-light);margin-bottom:8px;font-weight:600}.upload-zone .hint{color:#bbb;font-size:.78em}.preview-wrap{text-align:center;flex-direction:column;align-items:center;gap:6px;display:flex}.preview-wrap img{border:2px solid var(--pink-light);max-width:100%;max-height:160px;image-rendering:pixelated;border-radius:10px}.preview-wrap .info{color:var(--text-light);margin:6px 0;font-size:.8em;font-weight:600}.preview-tabs{border:1px solid var(--pink);border-radius:6px;gap:2px;width:100%;margin-bottom:6px;display:flex;overflow:hidden}.preview-tabs button{background:var(--bg);cursor:pointer;color:var(--text);border:none;flex:1;padding:6px 4px;font-size:.75em;font-weight:500}.preview-tabs button:first-child{border-radius:5px 0 0 5px}.preview-tabs button:last-child{border-radius:0 5px 5px 0}.preview-tabs button.active{background:var(--pink);color:#fff}.image-fullscreen-overlay{z-index:200;cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.image-fullscreen-overlay img{max-width:90vw;max-height:90vh;image-rendering:pixelated;border-radius:12px;box-shadow:0 8px 40px #00000080}.image-fullscreen-close{color:#fff;cursor:pointer;opacity:.7;font-size:1.5em;position:absolute;top:20px;right:24px}.image-fullscreen-close:hover{opacity:1}.image-float-overlay{z-index:150;background:#000000e6;border-radius:12px;flex-direction:column;width:400px;height:400px;display:flex;position:fixed;overflow:hidden;box-shadow:0 8px 40px #00000080}.float-header{background:#ffffff1a;border-bottom:1px solid #fff3;flex-shrink:0;padding:8px 10px}.float-controls{align-items:center;gap:8px;display:flex}.float-controls button{color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:6px;padding:4px 10px;font-size:12px}.float-controls button:hover{background:#ffffff4d}.float-controls span{color:#fff;text-align:center;min-width:45px;font-size:12px}.float-content{flex:1;justify-content:center;align-items:center;padding:10px;display:flex;overflow:auto}.float-content img{max-width:100%;max-height:100%;image-rendering:pixelated;-webkit-user-select:none;user-select:none;border-radius:4px;transition:transform .1s ease-out}.btn{cursor:pointer;border:none;border-radius:50px;align-items:center;gap:5px;padding:8px 18px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.9em;font-weight:700;transition:all .12s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-pink{background:var(--pink);color:#fff;box-shadow:0 3px 10px #ff8fab40}.btn-pink:hover{background:#ff7da0}.btn-purple{background:var(--purple);color:#fff;box-shadow:0 3px 10px #c9b1ff40}.btn-blue{background:var(--blue);color:#fff;box-shadow:0 3px 10px #a0d2db40}.btn-gradient{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;font-weight:600;box-shadow:0 3px 15px #667eea66}.btn-gradient:hover{transform:translateY(-2px);box-shadow:0 5px 20px #667eea80}.btn-success{color:#fff;background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%);border:none;font-weight:600;box-shadow:0 3px 15px #38ef7d4d}.btn-success:hover{transform:translateY(-2px)}.btn-outline{color:var(--pink);border:2px solid var(--pink-light);box-shadow:none;background:#fff}.btn-outline.active{background:var(--pink);color:#fff;border-color:var(--pink);box-shadow:0 3px 10px #ff8fab40}.btn-sm{padding:5px 12px;font-size:.82em}.btn-lg{border-radius:12px;padding:14px 32px;font-size:1.15em}.convert-btn-full{letter-spacing:1px;width:100%;border-radius:14px!important;padding:12px!important;font-size:1.1em!important}.btn-row{flex-wrap:wrap;gap:6px;display:flex}.slider-wrap{padding:2px 0}.slider-labels{color:var(--text-light);justify-content:space-between;align-items:center;margin-bottom:2px;font-size:.75em;font-weight:700;display:flex}.slider-value{color:var(--pink);background:var(--pink-bg);border:2px solid var(--pink-light);text-align:center;border-radius:16px;min-width:72px;padding:1px 12px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.3em}.kawaii-slider{appearance:none;background:linear-gradient(90deg, var(--pink-light), var(--purple-light), var(--blue-light));cursor:pointer;border:2px solid var(--pink-light);border-radius:6px;outline:none;width:100%;height:12px}.kawaii-slider:hover{box-shadow:0 0 10px #ff8fab40}.kawaii-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--pink);cursor:pointer;border:3px solid #fff;border-radius:50%;width:26px;height:26px;transition:transform .12s;box-shadow:0 2px 8px #ff8fab59}.kawaii-slider::-webkit-slider-thumb:hover{transform:scale(1.12)}.kawaii-slider::-webkit-slider-thumb:active{background:#ff7da0}.kawaii-slider::-moz-range-thumb{background:var(--pink);border:3px solid #fff;border-radius:50%;width:24px;height:24px;box-shadow:0 2px 8px #ff8fab59}.slider-marks{justify-content:space-between;padding:4px 6px 0;display:flex}.slider-marks span{color:var(--text-light);cursor:pointer;border-radius:8px;padding:1px 6px;font-size:.68em;font-weight:700;transition:all .12s}.slider-marks span:hover{color:var(--pink);background:var(--pink-bg)}.size-hint{color:var(--text-light);margin-top:4px;font-size:.78em;font-weight:600}.toggle-list{flex-direction:column;gap:6px;display:flex}.toggle-item{cursor:pointer;border-radius:10px;align-items:center;gap:8px;padding:5px 8px;font-size:.85em;font-weight:600;transition:background .12s;display:flex}.toggle-item:hover{background:var(--pink-bg)}.toggle-item input[type=checkbox]{display:none}.toggle-check{background:#ddd;border:2px solid #ccc;border-radius:10px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.toggle-check:after{content:"";background:#fff;border-radius:50%;width:12px;height:12px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #00000026}.toggle-item input:checked+.toggle-check{background:var(--pink);border-color:var(--pink)}.toggle-item input:checked+.toggle-check:after{transform:translate(16px)}.sub-slider{align-items:center;gap:8px;margin-left:52px;padding:2px 0;display:flex}.sub-label{color:var(--purple);min-width:50px;font-size:.78em;font-weight:700}.kawaii-slider.mini{flex:1;max-width:160px;height:6px}.kawaii-slider.mini::-webkit-slider-thumb{width:18px;height:18px}.kawaii-slider.mini::-moz-range-thumb{width:16px;height:16px}.empty-state{color:var(--text-light);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;font-weight:600;display:flex}.empty-state .hint{opacity:.6;font-size:.8em}.progress-overlay{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:2px solid var(--pink-light);pointer-events:none;background:#ffffffe0;align-items:center;gap:10px;padding:6px 20px;display:flex;position:absolute;top:0;left:0;right:0}.progress-bar-slim{background:var(--pink-bg);border-radius:3px;flex:1;height:6px;overflow:hidden}.progress-bar-slim .progress-bar-inner{background:linear-gradient(90deg, var(--pink), var(--purple));border-radius:3px;height:100%;transition:width .2s}.progress-hint{color:var(--purple);white-space:nowrap;flex-shrink:0;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.72em}.compare-col{flex-direction:column;align-items:center;gap:8px;display:flex}.compare-item-full{text-align:center;width:100%}.compare-label{color:var(--pink);margin-bottom:6px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.95em;display:block}.compare-item-full canvas{max-width:100%;max-height:480px;image-rendering:pixelated;border:2px solid var(--pink-light);background:#fff;border-radius:10px}.compare-arrow-down{color:var(--pink);font-size:1.4em;line-height:1}.stats-summary{background:var(--pink-bg);border-radius:10px;margin-bottom:10px;padding:8px 12px;font-size:.85em;font-weight:600;line-height:1.8}.color-grid{flex-wrap:wrap;gap:5px;display:flex}.color-chip{border:2px solid var(--pink-light);background:#fff;border-radius:16px;align-items:center;gap:4px;padding:3px 8px 3px 3px;font-size:.72em;font-weight:700;display:inline-flex}.color-swatch{border:1.5px solid #0000001a;border-radius:50%;flex-shrink:0;width:16px;height:16px}.grid-scroll{padding:6px 0;overflow-x:auto}.grid-scroll canvas{border-radius:6px;max-width:100%;display:block}.download-area{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.footer{text-align:center;color:var(--text-light);margin-top:30px;padding:16px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.85em}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes float{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-4px)rotate(3deg)}}.sparkle-row span{animation:3s ease-in-out infinite float}.sparkle-row span:nth-child(2){animation-delay:.3s}.sparkle-row span:nth-child(3){animation-delay:.6s}.sparkle-row span:nth-child(4){animation-delay:.9s}.sparkle-row span:nth-child(5){animation-delay:1.2s}@media (width<=768px){.layout{flex-direction:column;height:auto;overflow:visible}.panel-left{border-right:none;border-bottom:2px solid var(--pink-light);width:100%;min-width:auto;max-height:none;overflow:visible}.panel-right{overflow:visible}}@media (width<=1023px){.sidebar.open{width:240px}}@media (width<=767px){.sidebar{display:none!important}.header-logo h1{font-size:1em}}.panel-left::-webkit-scrollbar{width:6px}.panel-right::-webkit-scrollbar{width:6px}.panel-left::-webkit-scrollbar-thumb{background:var(--pink-light);border-radius:3px}.panel-right::-webkit-scrollbar-thumb{background:var(--pink-light);border-radius:3px}.panel-left::-webkit-scrollbar-track{background:0 0}.panel-right::-webkit-scrollbar-track{background:0 0}.floating-toolbar-wrapper{z-index:10;flex-direction:column;align-items:center;gap:6px;max-width:95vw;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.floating-toolbar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 16px var(--shadow), 0 0 0 2px var(--pink-light);white-space:nowrap;background:#ffffffeb;border-radius:50px;align-items:center;gap:4px;padding:6px 10px;display:flex;overflow-x:auto}.floating-toolbar .btn-sm{white-space:nowrap;padding:4px 8px;font-size:.78em}.toolbar-divider{color:var(--pink-light);font-weight:300}.paint-palette{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 16px var(--shadow), 0 0 0 2px var(--pink-light);background:#ffffffeb;border-radius:16px;align-items:center;gap:6px;max-width:95vw;padding:6px 10px;display:flex}.paint-palette-current{flex-shrink:0;min-width:60px}.paint-palette-grid{gap:3px;max-width:50vw;padding:2px;display:flex;overflow-x:auto}.paint-swatch{cursor:pointer;border:2px solid #0000;border-radius:4px;flex-direction:column;flex-shrink:0;align-items:center;gap:1px;padding:2px;display:flex}.paint-swatch.selected{border-color:var(--pink);background:var(--pink-bg)}.paint-swatch-color{border:1px solid #00000014;border-radius:4px;width:22px;height:22px}.paint-swatch-code{color:var(--text-light);white-space:nowrap;text-overflow:ellipsis;max-width:32px;font-size:.55em;font-weight:600;overflow:hidden}.eyedropper-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.eyedropper-panel{background:var(--card);border-radius:var(--radius);box-shadow:0 8px 32px var(--shadow);flex-direction:column;align-items:center;width:85vw;max-width:900px;height:80vh;padding:12px;display:flex}.eyedropper-header{width:100%;color:var(--text-light);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.8em;font-weight:600;display:flex}.eyedropper-zoom-label{background:var(--pink-bg);color:var(--pink);border-radius:10px;padding:2px 8px;font-size:.85em;font-weight:700}.eyedropper-viewport{border:2px solid var(--pink-light);background:repeating-conic-gradient(#eee 0% 25%,#fff 0% 50%) 0 0/16px 16px;border-radius:8px;flex:1;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.eyedropper-viewport canvas{max-width:100%;max-height:100%;transition:transform .1s}.eyedropper-actions{gap:8px;margin-top:8px;display:flex}.grid-align-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.grid-align-panel{background:var(--card);border-radius:var(--radius);box-shadow:0 8px 32px var(--shadow);flex-direction:column;width:90vw;max-width:1000px;height:88vh;padding:14px;display:flex}.grid-align-header{justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.95em;display:flex}.grid-align-hint{color:var(--text-light);font-size:.8em}.grid-align-controls{background:var(--pink-bg);border-radius:10px;flex-wrap:wrap;gap:16px;margin-bottom:8px;padding:8px;display:flex}.grid-align-group{align-items:center;gap:4px;font-size:.78em;font-weight:600;display:flex}.grid-align-group label{min-width:48px;color:var(--text-light)}.grid-align-group .btn-sm{min-width:24px;padding:2px 6px;font-size:.75em}.grid-align-value{text-align:center;min-width:36px;color:var(--pink);font-weight:700}.grid-align-viewport{border:2px solid var(--pink-light);background:repeating-conic-gradient(#eee 0% 25%,#fff 0% 50%) 0 0/16px 16px;border-radius:8px;flex:1;justify-content:center;align-items:center;display:flex;overflow:hidden}.grid-align-viewport canvas{max-width:100%;max-height:100%;transition:transform .1s}.grid-align-tip{text-align:center;color:var(--text-light);margin:6px 0;font-size:.72em}.grid-align-actions{justify-content:flex-end;gap:8px;display:flex}.konva-container{width:100%;height:100%;position:relative}.app-header{background:linear-gradient(90deg, var(--pink-bg), #fff);border-bottom:2px solid var(--pink-light);z-index:20;flex-shrink:0;justify-content:space-between;align-items:center;height:48px;padding:0 12px;display:flex}.header-logo{align-items:center;gap:8px;display:flex}.header-logo h1{color:var(--pink);margin:0;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.2em}.header-btn{cursor:pointer;background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:1.2em;transition:background .12s}.header-btn:hover{background:var(--pink-bg)}.header-right{gap:4px;display:flex}.sidebar{background:linear-gradient(180deg, var(--pink-bg) 0%, var(--bg) 100%);border-right:2px solid var(--pink-light);flex-shrink:0;transition:width .2s;position:relative;overflow:visible}.sidebar.open{width:280px}.sidebar.collapsed{width:36px}.sidebar-toggle{z-index:15;background:var(--pink-light);border:2px solid var(--pink-light);cursor:pointer;width:20px;height:48px;color:var(--text);border-left:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;font-size:.7em;transition:background .12s;display:flex;position:absolute;top:50%;right:-20px;transform:translateY(-50%)}.sidebar-toggle:hover{background:var(--pink);color:#fff}.sidebar-content{flex-direction:column;gap:10px;max-height:calc(100vh - 104px);padding:12px;display:flex;overflow-y:auto}.palette-info{align-items:center;gap:6px;display:flex}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-body{flex:1;display:flex;overflow:hidden}.canvas-area{flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.canvas-original{max-width:80%;max-height:80%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.cartoon-compare{flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex}.compare-images{gap:40px;margin-bottom:24px;display:flex}.compare-item{text-align:center}.compare-item p{color:var(--text-light);margin-bottom:8px;font-weight:600}.compare-item img{border:3px solid var(--pink-light);border-radius:12px;max-width:300px;max-height:300px;box-shadow:0 4px 20px #0000001a}.compare-actions{gap:16px;display:flex}.cartoon-progress-container{text-align:center;width:260px}.cartoon-progress-bar{border:2px solid var(--pink-light);background:#ffffff80;border-radius:10px;width:100%;height:20px;overflow:hidden}.cartoon-progress-fill{background:linear-gradient(90deg, var(--pink), var(--purple));border-radius:8px;height:100%;transition:width .5s;position:relative;overflow:hidden}.cartoon-progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#fff6,#0000);width:100%;height:100%;animation:1.5s infinite shimmer;position:absolute;top:0;left:-100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.cartoon-progress-text{color:var(--text-light);margin-top:8px;font-size:.9em;font-weight:500}.modal-container{z-index:100;width:0;height:0;position:fixed;top:0;left:0}.modal-overlay{z-index:100;background:#00000040;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--card);border-radius:var(--radius);box-shadow:0 8px 32px var(--shadow), 0 0 0 2px var(--pink-light);width:90%;max-width:520px;max-height:80vh;padding:24px;overflow-y:auto}.modal-title{color:var(--pink);text-align:center;margin-bottom:16px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.2em}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.color-search-input{border:2px solid var(--pink-light);border-radius:10px;outline:none;width:100%;margin-bottom:8px;padding:6px 12px;font-family:Nunito,sans-serif;font-size:.85em}.color-search-input:focus{border-color:var(--pink)}.color-stats-bar{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 12px var(--shadow);border:2px solid var(--pink-light);z-index:8;background:#ffffffeb;border-radius:12px;max-height:120px;position:absolute;bottom:70px;left:8px;right:8px;overflow:hidden}.stats-bar-header{color:var(--pink);cursor:pointer;justify-content:space-between;align-items:center;padding:6px 12px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.82em;display:flex}.stats-bar-chips{flex-wrap:wrap;gap:4px;max-height:80px;padding:0 10px 8px;display:flex;overflow-y:auto}.slider-value-group{align-items:center;gap:4px;display:flex}.step-btn{border:2px solid var(--pink-light);background:var(--card);width:24px;height:24px;color:var(--pink);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.9em;font-weight:700;line-height:1;transition:all .12s;display:flex}.step-btn:hover{background:var(--pink);color:#fff;border-color:var(--pink)}.step-btn:active{transform:scale(.9)}.step-btn-mini{flex-shrink:0;width:18px;height:18px;font-size:.75em}.offset-controls{flex-direction:column;align-items:center;gap:2px;display:flex}.offset-row{align-items:center;gap:8px;display:flex}.offset-value{color:var(--text-light);text-align:center;min-width:40px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.85em}.swap-drawer-overlay{z-index:100;background:#0000001a;position:fixed;inset:0}.swap-drawer{background:var(--card);width:320px;max-width:90vw;height:100vh;box-shadow:-4px 0 24px var(--shadow);padding:20px;animation:.2s ease-out slideInRight;position:fixed;top:0;right:0;overflow-y:auto}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.module-tab-bar{background:var(--card);border-top:2px solid var(--pink-light);z-index:20;flex-shrink:0;align-items:stretch;height:56px;display:flex}.module-tab{cursor:pointer;background:0 0;border:none;border-radius:0;flex-direction:row;flex:1;justify-content:center;align-items:center;gap:4px;padding:6px 0;font-family:PingFang SC,Microsoft YaHei,sans-serif;transition:background .15s,color .15s;display:flex;position:relative}.module-tab:hover,.module-tab.active{background:var(--pink-bg)}.module-tab.active:before{content:"";background:var(--pink);border-radius:0 0 3px 3px;height:3px;position:absolute;top:0;left:20%;right:20%}.module-tab .tab-icon{font-size:1.2em;line-height:1}.module-tab .tab-label{color:var(--text-light);font-size:.88em;font-weight:700}.module-tab.active .tab-label{color:var(--pink)}.craft-panel{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius);box-shadow:0 4px 20px var(--shadow), 0 0 0 2px var(--pink-light);background:#fffffff2;font-size:.85em;position:absolute;bottom:70px;right:12px}.craft-panel-collapsed{cursor:pointer;color:var(--pink);align-items:center;gap:8px;padding:8px 14px;font-family:PingFang SC,Microsoft YaHei,sans-serif;display:flex}.craft-panel-expanded{flex-direction:column;width:220px;max-height:400px;display:flex;overflow:hidden}.craft-panel-header{color:var(--pink);justify-content:space-between;align-items:center;padding:10px 14px 6px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1em;display:flex}.craft-panel-toggle{cursor:pointer;color:var(--text-light);background:0 0;border:none;padding:0 4px;font-size:1.2em}.craft-panel-toggle:hover{color:var(--pink)}.craft-progress-bar{background:var(--pink-bg);border-radius:4px;height:8px;margin:0 14px;overflow:hidden}.craft-progress-fill{background:linear-gradient(90deg, var(--pink), var(--purple));border-radius:4px;height:100%;transition:width .3s}.craft-progress-text{text-align:center;color:var(--text-light);padding:4px 0;font-size:.8em;font-weight:700}.craft-color-list{flex:1;max-height:220px;padding:0 10px 8px;overflow-y:auto}.craft-color-item{cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:4px 8px;font-weight:600;transition:background .12s;display:flex}.craft-color-item:hover{background:var(--pink-bg)}.craft-color-item.highlighted{background:var(--pink-bg);border:1px solid var(--pink)}.craft-color-item.complete{opacity:.5}.craft-color-swatch{border:1.5px solid #0000001a;border-radius:50%;flex-shrink:0;width:14px;height:14px}.craft-color-code{flex:1;font-size:.85em}.craft-color-count{color:var(--text-light);font-size:.78em}.craft-done-btn{border:2px solid var(--pink-light);background:var(--card);width:22px;height:22px;color:var(--text-light);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:.75em;transition:all .12s;display:flex}.craft-done-btn:hover{border-color:var(--pink);color:var(--pink)}.craft-done-btn.done{background:var(--green);border-color:var(--green);color:#fff;font-weight:700}.craft-actions{border-top:1px solid var(--pink-light);gap:6px;padding:8px 10px;display:flex}.craft-complete-msg{text-align:center;color:var(--pink);padding:8px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.1em;animation:1s ease-in-out infinite bounce}.header-user{align-items:center;display:flex}.user-menu-wrapper{position:relative}.user-menu-trigger{cursor:pointer;color:var(--text);background:0 0;border:none;align-items:center;gap:6px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.9em;display:flex}.user-avatar-sm{object-fit:cover;border:2px solid var(--pink-light);border-radius:50%;width:28px;height:28px}.user-avatar-placeholder{font-size:1.2em}.caret{font-size:.6em}.user-dropdown{background:var(--card);min-width:120px;box-shadow:0 4px 16px var(--shadow), 0 0 0 2px var(--pink-light);z-index:200;border-radius:12px;position:absolute;top:110%;right:0;overflow:hidden}.user-dropdown button{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:10px 16px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.88em;display:block}.user-dropdown button:hover{background:var(--pink-bg)}.auth-form{flex-direction:column;gap:12px;margin:16px 0;display:flex}.auth-input{border:2px solid var(--pink-light);box-sizing:border-box;border-radius:12px;outline:none;width:100%;padding:10px 14px;font-size:.9em}.auth-input:focus{border-color:var(--pink)}.auth-error{color:#e74c3c;text-align:center;margin-bottom:8px;font-size:.85em}.auth-switch{text-align:center;color:var(--text-light);margin-top:12px;font-size:.85em}.auth-switch span{color:var(--pink);cursor:pointer;text-decoration:underline}.auth-code-row{align-items:center;gap:8px;display:flex}.auth-code-row .auth-input{flex:1}.auth-send-code-btn{white-space:nowrap;flex-shrink:0;min-width:90px}.auth-hint{color:#ef4444;margin-top:-4px;padding-left:2px;font-size:12px}.community-page{width:100%;max-width:1200px;margin:0 auto;padding:16px}.community-search{gap:8px;margin-bottom:16px;display:flex}.community-search .auth-input{flex:1}.community-tabs{border-bottom:2px solid var(--pink-light);gap:4px;margin-bottom:16px;display:flex}.community-tab{cursor:pointer;color:var(--text-light);background:0 0;border:none;border-bottom:3px solid #0000;padding:8px 20px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.95em;transition:all .2s}.community-tab.active{color:var(--pink);border-bottom-color:var(--pink)}.community-tab:hover{color:var(--pink)}.community-filters{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.filter-group{align-items:center;gap:6px;display:flex}.filter-group label{color:var(--text-light);font-size:.85em}.filter-group select{border:2px solid var(--pink-light);background:var(--card);border-radius:8px;outline:none;padding:6px 10px;font-size:.85em}.filter-group select:focus{border-color:var(--pink)}.blueprint-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.blueprint-card{background:var(--card);border-radius:var(--radius);box-shadow:0 2px 12px var(--shadow);cursor:pointer;transition:transform .2s,box-shadow .2s;overflow:hidden}.blueprint-card:hover{box-shadow:0 6px 20px var(--shadow);transform:translateY(-4px)}.bp-card-thumb{aspect-ratio:1;background:var(--pink-bg);width:100%;overflow:hidden}.bp-card-thumb img{object-fit:cover;width:100%;height:100%}.bp-card-info{padding:10px 12px}.bp-card-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.95em;overflow:hidden}.bp-card-meta{color:var(--text-light);gap:8px;margin-bottom:6px;font-size:.75em;display:flex}.bp-card-tags{flex-wrap:wrap;gap:4px;margin-bottom:6px;display:flex}.bp-perm-tag{white-space:nowrap;border-radius:4px;padding:2px 6px;font-size:.65em}.bp-perm-free{background:var(--pink-light);color:var(--pink-dark)}.bp-perm-no{color:#888;background:#f5f5f5;border:1px solid #e0e0e0}.bp-card-footer{justify-content:space-between;align-items:center;display:flex}.bp-card-author{color:var(--text-light);align-items:center;gap:4px;font-size:.8em;display:flex}.bp-card-avatar{object-fit:cover;border-radius:50%;width:20px;height:20px}.bp-card-avatar-placeholder{font-size:.9em}.bp-card-stats{color:var(--text-light);gap:8px;font-size:.8em;display:flex}.community-empty{text-align:center;color:var(--text-light);padding:40px}.community-loading{text-align:center;color:var(--text-light);padding:20px}.community-load-more{margin:20px auto;display:block}.blueprint-detail-page{width:100%;max-width:900px;margin:0 auto;padding:16px}.bp-detail-content{flex-wrap:wrap;gap:24px;margin-top:16px;display:flex}.bp-detail-image{flex:1;min-width:280px;max-width:400px}.bp-detail-image img{border-radius:var(--radius);width:100%;box-shadow:0 4px 16px var(--shadow)}.bp-detail-info{flex:1;min-width:280px}.bp-detail-title{color:var(--pink);margin-bottom:8px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.4em}.bp-detail-desc{color:var(--text-light);margin-bottom:12px;font-size:.9em;line-height:1.5}.bp-detail-meta{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.bp-detail-author{align-items:center;gap:6px;font-size:.9em;display:flex}.bp-detail-avatar{object-fit:cover;border:2px solid var(--pink-light);border-radius:50%;width:32px;height:32px}.bp-detail-avatar-placeholder{font-size:1.4em}.bp-detail-date{color:var(--text-light);font-size:.8em}.bp-detail-specs{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.spec-item{gap:6px;font-size:.85em;display:flex}.spec-label{color:var(--text-light)}.bp-detail-tags{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.bp-tag{border-radius:20px;padding:4px 10px;font-size:.78em;font-weight:600}.tag-free{background:var(--green);color:#2d6a4f}.tag-disabled{background:var(--bg-secondary);color:var(--text-light)}.bp-locked-banner{color:#e65100;text-align:center;background:#fff3e0;border:1px solid #ffb74d;border-radius:6px;margin-bottom:12px;padding:12px;font-size:.9em}.bp-detail-actions{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.bp-detail-views{color:var(--text-light);font-size:.82em}.comment-section{border-top:2px solid var(--pink-light);margin-top:24px;padding-top:16px}.comment-title{color:var(--text);margin-bottom:12px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.1em}.comment-input-area{margin-bottom:16px}.comment-textarea{border:2px solid var(--pink-light);resize:vertical;box-sizing:border-box;border-radius:12px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:.9em}.comment-textarea:focus{border-color:var(--pink)}.comment-input-area .btn{float:right;margin-top:8px}.comment-login-hint{color:var(--text-light);text-align:center;padding:12px;font-size:.9em}.comment-list{clear:both;flex-direction:column;gap:12px;display:flex}.comment-item{background:var(--pink-bg);border-radius:12px;padding:12px}.comment-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.comment-user{align-items:center;gap:6px;display:flex}.comment-avatar{object-fit:cover;border-radius:50%;width:24px;height:24px}.comment-avatar-placeholder{font-size:1em}.comment-username{font-size:.85em;font-weight:600}.comment-time{color:var(--text-light);font-size:.75em}.comment-delete{color:#e74c3c;cursor:pointer;background:0 0;border:none;font-size:.8em}.comment-content{font-size:.88em;line-height:1.5}.share-modal{max-width:420px}.share-preview{align-items:center;gap:12px;margin-bottom:12px;display:flex}.share-thumb{object-fit:contain;background:var(--pink-bg);border:2px solid var(--pink-light);border-radius:8px;width:100px;height:100px}.share-specs{color:var(--text-light);flex-direction:column;gap:4px;font-size:.82em;display:flex}.share-tags{margin-bottom:16px}.share-tag-group{align-items:center;gap:10px;margin-bottom:8px;display:flex}.share-tag-group>label{color:var(--text-light);min-width:70px;font-size:.85em}.share-tag-options{gap:12px;font-size:.85em;display:flex}.share-tag-options label{cursor:pointer;align-items:center;gap:4px;display:flex}.ranking-panel{margin-top:8px}.ranking-time-tabs{gap:4px;margin-bottom:16px;display:flex}.ranking-time-tab{border:2px solid var(--pink-light);background:var(--card);cursor:pointer;color:var(--text-light);border-radius:20px;padding:6px 16px;font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:.85em;transition:all .2s}.ranking-time-tab.active{background:var(--pink);color:#fff;border-color:var(--pink)}.ranking-time-tab:hover{border-color:var(--pink)}.ranking-list{flex-direction:column;gap:8px;display:flex}.ranking-item{background:var(--card);box-shadow:0 2px 8px var(--shadow);cursor:pointer;border-radius:12px;align-items:center;gap:12px;padding:10px 14px;transition:transform .2s;display:flex}.ranking-item:hover{transform:translate(4px)}.ranking-top{background:linear-gradient(135deg, var(--pink-bg), var(--card))}.ranking-rank{text-align:center;min-width:36px;font-size:1.2em}.ranking-user{flex:1;align-items:center;gap:8px;display:flex}.ranking-avatar{object-fit:cover;border:2px solid var(--pink-light);border-radius:50%;width:36px;height:36px}.ranking-avatar-placeholder{font-size:1.4em}.ranking-username{font-size:.9em;font-weight:600}.ranking-stats{color:var(--text-light);gap:12px;font-size:.8em;display:flex}.ranking-score{color:var(--orange)}.profile-page{align-self:flex-start;width:100%;max-width:900px;max-height:calc(100vh - 104px);margin:0 auto;padding:16px;overflow-y:auto}.profile-header-card{background:var(--card);border-radius:var(--radius);box-shadow:0 2px 12px var(--shadow);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:20px;display:flex}.profile-user-info{align-items:center;gap:16px;display:flex}.profile-avatar-lg{object-fit:cover;border:3px solid var(--pink-light);border-radius:50%;width:64px;height:64px}.profile-avatar-lg-placeholder{font-size:3em}.profile-username{color:var(--pink);font-family:PingFang SC,Microsoft YaHei,sans-serif;font-size:1.3em}.profile-bio{color:var(--text-light);margin-top:2px;font-size:.85em}.profile-email{color:var(--text-light);margin-top:2px;font-size:.8em}.profile-stats-row{color:var(--text-light);gap:12px;margin-top:4px;font-size:.85em;display:flex}.profile-actions{gap:8px;display:flex}.profile-info-card{border-radius:var(--radius);background:#fff8e1;border:1px solid #ffecb3;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;display:flex}.profile-info-card-content{align-items:center;gap:12px;display:flex}.profile-info-card-icon{font-size:1.5em}.profile-info-card-content h3{color:var(--text);margin:0;font-size:.95em}.profile-info-card-content p{color:var(--text-light);margin:2px 0 0;font-size:.8em}.profile-avatar-edit{align-items:center;gap:16px;margin-bottom:16px;display:flex}.avatar-upload-btn{cursor:pointer}.bp-list-item{position:relative}.bp-delete-btn{color:#e74c3c;cursor:pointer;border-radius:0 0 var(--radius) var(--radius);background:#fff0f0;border:none;width:100%;margin-top:-8px;padding:6px;font-size:.82em;display:block}.bp-delete-btn:hover{background:#ffe0e0}.history-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.history-card{background:var(--card);border-radius:var(--radius);box-shadow:0 2px 8px var(--shadow);cursor:pointer;transition:transform .2s;position:relative;overflow:hidden}.history-card:hover{transform:translateY(-2px)}.history-thumb{aspect-ratio:1;object-fit:cover;background:var(--pink-bg);width:100%}.history-info{color:var(--text-light);flex-direction:column;gap:2px;padding:8px 10px;font-size:.8em;display:flex}.history-date{font-size:.75em}@media (width<=768px){.blueprint-grid{grid-template-columns:repeat(2,1fr);gap:10px}.bp-detail-content{flex-direction:column}.bp-detail-image{max-width:100%}.community-filters{flex-direction:column;gap:8px}.profile-header-card{text-align:center;flex-direction:column}.profile-user-info{flex-direction:column}.profile-actions{justify-content:center}.history-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=480px){.blueprint-grid,.history-grid{grid-template-columns:1fr}.bp-detail-actions{flex-direction:column}.bp-detail-specs{grid-template-columns:1fr}}
