@import"https://fonts.googleapis.com/css2?family=ZCOOL+KuaiLe&family=Nunito:wght@400;600;700;800&display=swap";:root{--c-bg: #FDF9F6;--c-bg-card: #FFFFFF;--c-bg-input: #FFFFFF;--c-primary: #E08E79;--c-primary-hover: #D47B65;--c-primary-active: #C56852;--c-primary-light: #F7E9E5;--c-text-main: #5C4B47;--c-text-light: #8E7C77;--radius-sm: 8px 12px 10px 8px;--radius-md: 16px 20px 18px 16px;--radius-lg: 28px 32px 30px 28px;--shadow-sm: 2px 4px 10px rgba(224, 142, 121, .15);--shadow-md: 4px 8px 16px rgba(224, 142, 121, .12);--shadow-lg: 8px 16px 32px rgba(224, 142, 121, .15);--font-sans: "Nunito", "Quicksand", "PingFang SC", "Microsoft YaHei", sans-serif;--font-serif: "ZCOOL KuaiLe", "Nunito", cursive, sans-serif;--moe-dot-bg-image: linear-gradient(to right, rgba(224, 142, 121, .05) 1px, transparent 1px), linear-gradient(to bottom, rgba(224, 142, 121, .05) 1px, transparent 1px);--moe-dot-bg-size: 30px 30px;--moe-dot-bg-position: 0 0}*{box-sizing:border-box}body{margin:0;min-width:320px;background-color:var(--c-bg);background-image:var(--moe-dot-bg-image);background-size:var(--moe-dot-bg-size);background-position:var(--moe-dot-bg-position);color:var(--c-text-main);font-family:var(--font-sans);line-height:1.6}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffd1dc;border-radius:10px;border:2px solid var(--c-bg)}::-webkit-scrollbar-thumb:hover{background:var(--c-primary)}button,input,select,textarea{font:inherit}button{border:0}a{color:var(--c-primary);text-decoration:none;border-bottom:2px solid transparent;transition:border-bottom-color .2s ease}a:hover{border-bottom-color:var(--c-primary)}.appShell{width:min(1500px,calc(100% - 48px));margin:0 auto;padding:48px 0 64px}.centerShell{min-height:100vh;display:grid;place-items:center;align-content:center;gap:16px;font-family:var(--font-serif)}.appNav{display:flex;gap:16px;align-items:center}.navLink{color:var(--c-text-main);font-family:var(--font-serif);font-weight:700;font-size:16px;padding:8px 16px;border-radius:var(--radius-sm);text-decoration:none;transition:all .2s ease;border:2px solid transparent}.navLink:hover{background:var(--c-primary-light);color:var(--c-primary-active);transform:translateY(-2px)}.navLink.active{background:#ffe5e9;color:var(--c-primary-active);border-color:#ffb7c5;box-shadow:var(--shadow-sm)}.appHeader{display:flex;justify-content:space-between;gap:24px;align-items:center;padding:24px 32px;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-lg);border:3px dashed #F2D5CC;box-shadow:var(--shadow-md);margin-bottom:40px;transform:rotate(-.5deg)}.appHeader:hover{transform:rotate(0) translateY(-2px);transition:transform .3s ease}.eyebrow{margin:0 0 4px;font-size:14px;color:var(--c-primary);font-weight:700;letter-spacing:1px}h1,h2,h3{font-family:var(--font-serif);font-weight:700;margin-top:0;color:var(--c-text-main)}h1{margin-bottom:8px;font-size:32px;line-height:1.2}.headerCopy{margin:0;color:var(--c-text-light);font-size:14px;font-weight:600}.headerStats{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:12px}.headerStats span{padding:8px 16px;background:var(--c-primary-light);color:var(--c-primary);border-radius:var(--radius-sm);font-size:14px;font-weight:700;border:1px solid #FFB7C5;box-shadow:0 2px #ffb7c5}.workspace{display:grid;grid-template-columns:minmax(380px,420px) minmax(0,1fr);gap:40px;align-items:start}.controlRail{display:grid;gap:24px}.panel,.resultPane{background:var(--c-bg-card);border-radius:var(--radius-lg);box-shadow:4px 6px #e08e7926,inset 0 0 0 2px #fff,var(--shadow-sm);border:3px solid var(--c-primary-light);position:relative;transition:transform .3s ease,box-shadow .3s ease}.panel:hover,.resultPane:hover{transform:translateY(-2px) rotate(.5deg);box-shadow:6px 8px #e08e7933,inset 0 0 0 2px #fff,var(--shadow-md)}.panel{padding:24px}.panelHeader,.resultToolbar{display:flex;justify-content:space-between;gap:16px;align-items:start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px dashed #FFF0F3}.panelHeader h2,.resultToolbar h2{margin:0 0 8px;font-size:22px;color:var(--c-primary-active)}.panelHeader p,.resultToolbar p,.metaText{margin:0;color:var(--c-text-light);font-size:13px;font-weight:600;line-height:1.6}.field,.fieldGrid{display:grid;gap:8px;margin-bottom:20px}.fieldGrid{grid-template-columns:1fr 1fr;gap:16px}.field span{color:var(--c-text-main);font-size:14px;font-family:var(--font-sans);font-weight:700;margin-left:4px}.field input,.field select,.field textarea,.toggleRow select{width:100%;border-radius:var(--radius-sm);background-color:var(--c-bg-input);border:2px solid #F0F0F0;color:var(--c-text-main);font-weight:600;padding:10px 16px;outline:none;font-size:14px;transition:all .2s ease}.field input:focus,.field select:focus,.field textarea:focus,.toggleRow select:focus{border-color:var(--c-primary);box-shadow:0 0 0 4px var(--c-primary-light);background-color:#fff}.field textarea{min-height:120px;resize:vertical;line-height:1.6}.modeSwitch{display:flex;gap:8px;background:var(--c-bg);padding:6px;border-radius:var(--radius-md);margin-bottom:24px;border:2px solid #FFF0F3}.modeSwitch button{flex:1;padding:10px;color:var(--c-text-light);background:transparent;cursor:pointer;font-family:var(--font-serif);font-weight:700;font-size:15px;border-radius:var(--radius-sm);transition:all .2s cubic-bezier(.34,1.56,.64,1)}.modeSwitch button:hover{background:#ffffffb8;color:var(--c-text-main);transform:translateY(-2px)}.modeSwitch button.active{color:#fff;background:var(--c-primary);box-shadow:0 4px 12px #ff9eb566}.modeCards button{min-height:70px;padding:12px;display:flex;align-items:center;gap:12px;text-align:left;font-family:var(--font-sans)}.modeCards button.active{color:var(--c-primary-active);background:#fff;box-shadow:0 6px #e08e7938,0 8px 18px #e08e792e}.modeText{display:grid;gap:2px}.modeText strong{font-size:15px;line-height:1.2}.modeText small{color:var(--c-text-light);font-size:12px;line-height:1.2;font-weight:700}.modeIcon{width:38px;height:38px;flex:0 0 38px;border-radius:14px;position:relative;background:linear-gradient(145deg,#fff,var(--c-primary-light));border:2px solid rgba(224,142,121,.25);box-shadow:inset 0 0 0 2px #ffffffbf,0 4px 10px #e08e792e}.modeIconGenerate:before{content:"";position:absolute;left:9px;top:9px;width:20px;height:20px;border-radius:7px;background:linear-gradient(135deg,transparent 55%,rgba(92,75,71,.24) 56%),linear-gradient(145deg,#fff,#f9d8ce);border:2px solid var(--c-primary)}.modeIconGenerate:after{content:"";position:absolute;right:6px;top:7px;width:8px;height:8px;border-radius:50%;background:var(--c-primary);box-shadow:-13px 16px 0 -2px var(--c-primary-active)}.modeIconReference:before{content:"";position:absolute;left:8px;top:8px;width:18px;height:22px;border-radius:6px;background:linear-gradient(145deg,#fff,#f9d8ce);border:2px solid var(--c-primary);transform:rotate(-7deg)}.modeIconReference:after{content:"";position:absolute;right:7px;bottom:7px;width:18px;height:18px;border-radius:7px;background:linear-gradient(135deg,transparent 54%,rgba(255,255,255,.78) 55%),var(--c-primary-active);border:2px solid #fff;box-shadow:0 2px 7px #5c4b472e}.primaryButton,.secondaryButton,.ghostButton,.cardActions button,.cardActions a{cursor:pointer;font-family:var(--font-serif);font-weight:700;font-size:14px;border-radius:var(--radius-md);transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.primaryButton{width:100%;padding:14px 24px;color:#fff;background:var(--c-primary);border:none;box-shadow:0 6px 0 var(--c-primary-active),0 4px 12px #ff9eb566;margin-top:12px;font-size:16px}.primaryButton:hover:not(:disabled){background:var(--c-primary-hover);box-shadow:0 6px 0 var(--c-primary-active),0 6px 16px #ff9eb580;transform:translateY(-2px)}.primaryButton:active:not(:disabled){transform:translateY(4px);box-shadow:0 2px 0 var(--c-primary-active),0 2px 8px #ff9eb566}.secondaryButton{border:2px solid #F0F0F0;background:#fff;color:var(--c-text-main);padding:8px 16px;box-shadow:0 4px #0000000d}.secondaryButton:hover:not(:disabled){border-color:var(--c-primary);color:var(--c-primary);transform:translateY(-2px);box-shadow:0 6px #ff9eb533}.secondaryButton:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #0000000d}.ghostButton{border:none;background:var(--c-primary-light);color:var(--c-primary);padding:8px 16px}.ghostButton:hover:not(:disabled){background:#ffe5e9}button:disabled{opacity:.4;cursor:not-allowed}.dropZone{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:12px;padding:32px 20px;border:2px dashed #FFB7C5;background:var(--c-primary-light);border-radius:var(--radius-md);margin-bottom:20px;transition:all .2s ease;cursor:pointer}.dropZone:hover{border-color:var(--c-primary);background:#ffe5e9;transform:translateY(-3px);box-shadow:0 8px 18px #e08e792e}.dropZone.activeDrop{border-color:var(--c-primary);background:#ffe5e9;transform:translateY(-4px) scale(1.02);box-shadow:0 12px 24px #e08e7938}.uploadMark{width:42px;height:42px;border-radius:16px;background:linear-gradient(145deg,#fff,#f9d8ce);border:2px solid rgba(224,142,121,.28);position:relative;box-shadow:inset 0 0 0 2px #ffffffbf,0 4px 10px #e08e7929}.uploadMark:before{content:"";position:absolute;left:12px;top:10px;width:14px;height:14px;border-left:3px solid var(--c-primary);border-top:3px solid var(--c-primary);transform:rotate(45deg)}.uploadMark:after{content:"";position:absolute;left:19px;top:12px;width:3px;height:20px;border-radius:99px;background:var(--c-primary)}.dropZone strong{font-family:var(--font-serif);font-size:18px;color:var(--c-primary-active)}.dropZone p{margin:0;color:var(--c-text-light);font-size:13px;font-weight:600}.advancedOptions{margin-top:14px;border:2px dashed #F2D5CC;border-radius:var(--radius-md);background:#ffffffd1;overflow:hidden}.advancedOptions summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;color:var(--c-text-main);font-weight:700}.advancedOptions summary::-webkit-details-marker{display:none}.advancedOptions summary span{font-family:var(--font-serif);color:var(--c-primary-active)}.advancedOptions summary small{color:var(--c-text-light);font-size:12px;font-weight:700;text-align:right}.advancedOptionsBody{display:grid;gap:14px;padding:0 16px 16px;border-top:2px dashed #FFF0F3}.imageSubMeta{display:block;font-size:10px;color:#0006;font-family:monospace;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.5px}.advancedToggle{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--c-text-main);margin-top:14px}.advancedToggle input{width:16px;height:16px;accent-color:var(--c-primary)}.compactGrid{gap:12px;margin-bottom:0}.advancedHint{margin:0;color:var(--c-text-light);font-size:12px;font-weight:600;line-height:1.6}.referenceGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:12px}.referenceItem{position:relative;aspect-ratio:1;background:transparent;border:none;transition:transform .2s}.referenceItem:hover{transform:scale(1.02) rotate(-1deg);z-index:10}.referenceItem img{width:100%;height:100%;object-fit:cover;border-radius:2px;border:4px solid #fffdf5;border-bottom-width:16px;box-shadow:0 2px 5px #0000001a;box-sizing:border-box}.mainRefBadge{position:absolute;top:-8px;left:-8px;background-color:var(--c-primary);color:#fff;font-size:10px;padding:2px 6px;border-radius:8px 4px 6px;display:flex;align-items:center;gap:4px;box-shadow:1px 2px 4px #00000026;z-index:5;border:1px dashed rgba(255,255,255,.5)}.removeRefBtn{position:absolute;top:-6px;right:-6px;background:#a83232;color:#fff;border:1px dashed rgba(255,255,255,.4);border-radius:50% 40% 50% 45%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;box-shadow:1px 2px 4px #0003;transition:all .2s}.removeRefBtn:hover{background:#d64545;transform:scale(1.1) rotate(5deg)}.refStatus{position:absolute;bottom:24px;left:50%;transform:translate(-50%);font-size:10px;padding:2px 6px;border-radius:4px;display:flex;align-items:center;gap:4px;white-space:nowrap;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2}.refStatus.success{background:#eafbe6e6;color:#3b7b3b;border:1px dashed #b8dfb8}.refStatus.error{background:#ffeae6e6;color:#a83232;border:1px dashed #ffb8b8}.refRetryBtn{background:transparent;border:1px solid currentColor;border-radius:2px;color:inherit;font-size:9px;padding:1px 4px;cursor:pointer;margin-left:2px}.refRetryBtn:hover{background:#0000000d}.maskPanel{display:grid;gap:12px;margin:0 0 18px;padding:14px;border:2px solid rgba(255,183,197,.7);border-radius:var(--radius-md);background:#ffffffe0}.maskPanelHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.maskPanelHeader strong{color:var(--c-primary-active);font-family:var(--font-serif);font-size:17px}.maskPanelHeader p,.maskEmptyState,.maskMeta span{margin:4px 0 0;color:var(--c-text-light);font-size:12px;font-weight:700;line-height:1.5}.maskPreviewRow{display:flex;gap:12px;align-items:center;min-width:0}.maskPreviewBox{width:72px;height:72px;flex:0 0 auto;overflow:hidden;border-radius:var(--radius-sm);border:1px solid rgba(255,183,197,.9);background:linear-gradient(45deg,#f4f4f4 25%,transparent 25%),linear-gradient(-45deg,#f4f4f4 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f4f4f4 75%),linear-gradient(-45deg,transparent 75%,#f4f4f4 75%);background-size:14px 14px;background-position:0 0,0 7px,7px -7px,-7px 0}.maskPreviewBox img{width:100%;height:100%;object-fit:cover}.maskMeta{min-width:0;display:grid;gap:4px}.maskMeta strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--c-text-main)}.maskStatusError{color:#ff4d4f!important}.maskActionRow{display:flex;flex-wrap:wrap;gap:10px}.maskEditorBackdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:stretch;justify-content:stretch;padding:0;background:#2d262994;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.maskEditorModal{position:relative;width:100vw;height:100vh;max-height:100vh;display:grid;grid-template-rows:auto minmax(0,1fr);overflow:hidden;border:0;border-radius:0;background:var(--c-bg);background-image:var(--moe-dot-bg-image);background-size:var(--moe-dot-bg-size);background-position:var(--moe-dot-bg-position);box-shadow:none}.maskEditorModal.immersiveMode{grid-template-rows:minmax(0,1fr);background:#312d30}.maskEditorModal.immersiveMode .maskEditorHeader,.maskEditorModal.immersiveMode .maskEditorControls,.maskEditorModal.immersiveMode .maskPropertiesSide,.maskEditorModal.immersiveMode .maskToolbarSide{display:none}.maskEditorWorkspace{display:flex;height:100%;overflow:hidden}.maskToolbarSide{width:72px;background:#ffffffb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-right:2px dashed #F2D5CC;display:flex;flex-direction:column;align-items:center;padding:24px 0;gap:24px;z-index:10}.maskToolGroup.vertical,.maskUtilityGroup.vertical{display:flex;flex-direction:column;gap:12px;align-items:center}.iconToolButton{width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:#fff;border:2px solid #F2D5CC;color:var(--c-text-main);cursor:pointer;transition:all .2s ease;position:relative;box-shadow:2px 4px #e08e791a;padding:0}.iconToolButton:hover{transform:translateY(-2px) rotate(-3deg);border-color:var(--c-primary);color:var(--c-primary);box-shadow:3px 6px #e08e7926}.iconToolButton.active{background:var(--c-primary-light);border-color:var(--c-primary);color:var(--c-primary-active);box-shadow:inset 0 2px 6px #e08e7933;transform:translateY(1px)}.toolShortcut{position:absolute;bottom:-6px;right:-6px;background:var(--c-bg-card);border:1.5px solid #F2D5CC;font-size:10px;font-weight:900;padding:0 4px;border-radius:6px;color:var(--c-text-light);font-family:var(--font-sans);pointer-events:none}.iconToolButton.active .toolShortcut{border-color:var(--c-primary);color:var(--c-primary-active)}.toolbarDivider{width:32px;height:2px;background:#f2d5cc;border-radius:2px;margin:4px 0}.maskCanvasArea{flex:1;position:relative;display:flex;flex-direction:column;min-width:0;background:#312d30}.maskPropertiesSide{width:300px;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-left:2px dashed #F2D5CC;display:flex;flex-direction:column;padding:24px;gap:20px;z-index:10;overflow-y:auto}.propertiesSection{display:flex;flex-direction:column;gap:16px;background:#fff;padding:18px;border-radius:var(--radius-md);border:2px solid #FFF0F3;box-shadow:var(--shadow-sm)}.propertiesSection h3{margin:0 0 4px;font-size:16px;color:var(--c-primary-active);font-family:var(--font-serif);border-bottom:2px dashed #FFF0F3;padding-bottom:10px}.controlHeader{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:800;color:var(--c-text-main)}.maskBrushControl input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:10px;background:var(--c-primary-light);border-radius:5px;outline:none;border:2px solid #FFF0F3;margin:4px 0;padding:0}.maskBrushControl input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;border:3px solid var(--c-primary);cursor:pointer;box-shadow:0 2px 4px #e08e794d;transition:transform .15s cubic-bezier(.34,1.56,.64,1)}.maskBrushControl input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.zoomReadout{font-weight:800;font-size:14px;color:var(--c-primary-active);font-family:var(--font-sans)}.zoomQuickActions{display:flex;gap:8px}.zoomQuickActions button{flex:1}.maskPolygonActions{position:absolute;bottom:32px;left:50%;transform:translate(-50%);display:flex;gap:12px;background:#ffffffe6;padding:14px 24px;border-radius:30px;box-shadow:var(--shadow-md);border:2px dashed #FFB7C5;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20}.maskEditorHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:2px dashed #FFF0F3}.maskEditorHeaderActions{display:flex;align-items:center;gap:10px}.maskEditorHeader h2{margin:0;color:var(--c-primary-active);font-size:24px}.maskEditorHeader p{margin:6px 0 0;color:var(--c-text-light);font-size:13px;font-weight:700}.maskEditorClose{width:36px;height:36px;border-radius:50%;color:#fff;background:var(--c-primary);font-size:24px;line-height:1}.maskCanvasViewport{position:relative;min-height:0;overflow:auto;padding:18px;background:#312d30;overscroll-behavior:contain;overflow-anchor:none;scroll-behavior:auto;scrollbar-gutter:stable;touch-action:none;contain:layout paint}.maskCanvasStack{position:relative;width:fit-content;margin:0;line-height:0;background:linear-gradient(45deg,#474247 25%,transparent 25%),linear-gradient(-45deg,#474247 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#474247 75%),linear-gradient(-45deg,transparent 75%,#474247 75%);background-color:#3d383d;background-size:18px 18px;background-position:0 0,0 9px,9px -9px,-9px 0;transform-origin:top left;will-change:width,height}.maskCanvasStack.pixelPreview .maskBaseCanvas,.maskCanvasStack.pixelPreview .maskPaintCanvas{image-rendering:pixelated;image-rendering:crisp-edges}.maskCanvasStack.pixelGrid:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background-image:linear-gradient(to right,rgba(255,255,255,.18) 1px,transparent 1px),linear-gradient(to bottom,rgba(255,255,255,.18) 1px,transparent 1px);background-size:var(--pixel-size) var(--pixel-size);mix-blend-mode:overlay}.maskBaseCanvas,.maskPaintCanvas{display:block;width:100%;height:100%;max-width:none;max-height:none}.maskBaseCanvas{opacity:.92}.maskPaintCanvas{position:absolute;top:0;right:0;bottom:0;left:0;touch-action:none}.maskPaintCanvas.drawingCursor{cursor:none}.maskPaintCanvas.panCursor{cursor:grab}.maskPaintCanvas.shapeCursor{cursor:crosshair}.maskCanvasStack.isPanning .maskPaintCanvas{cursor:grabbing}.maskBrushCursor{position:absolute;pointer-events:none;border:1.5px solid rgba(237,246,248,.96);border-radius:50%;background:#5b768414;box-shadow:0 0 0 1px #21272a8c,0 0 10px #edf6f833;transform:translate(-50%,-50%);z-index:3}.maskBrushCursor.restoreCursor{border-style:dashed;background:#ffffff14}.maskCanvasLoading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;min-width:260px;min-height:180px;color:#fff;font-weight:800;background:#2d26298c}.maskFloatingStatus,.maskFloatingToolbar,.maskFloatingBrushPanel{display:none}.maskEditorModal.immersiveMode .maskFloatingStatus{position:fixed;top:max(10px,env(safe-area-inset-top));left:50%;z-index:10;transform:translate(-50%);display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:8px 10px;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-sm);background:#1c191cb8;color:#fff;font-size:12px;font-weight:800;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.maskEditorModal.immersiveMode .maskFloatingStatus span{white-space:nowrap}.maskEditorModal.immersiveMode .maskFloatingToolbar{position:fixed;top:calc(max(10px,env(safe-area-inset-top)) + 52px);left:max(10px,env(safe-area-inset-left));z-index:10;display:flex;flex-direction:column;gap:6px;max-height:calc(100vh - 76px - env(safe-area-inset-bottom));padding:8px;overflow:auto;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-sm);background:#1c191cc2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.maskEditorModal.immersiveMode .maskCanvasViewport{padding-bottom:96px}.maskEditorModal.immersiveMode .maskFloatingBrushPanel{position:fixed;left:50%;bottom:max(12px,env(safe-area-inset-bottom));z-index:10;width:min(520px,calc(100vw - 24px));transform:translate(-50%);display:grid;grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:10px;padding:10px 12px;border:1px solid rgba(255,255,255,.16);border-radius:14px 12px 16px;background:#1c191cd1;box-shadow:0 14px 34px #00000047;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.maskFloatingBrushPanel button{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:#fffffff0;color:var(--c-text-main);font-size:20px;font-weight:900}.maskFloatingBrushPanel button:disabled{opacity:.45}.maskFloatingBrushPanel label{min-width:0;display:grid;gap:6px;color:#fff;font-size:12px;font-weight:900}.maskFloatingBrushPanel input[type=range]{width:100%;height:30px;accent-color:var(--c-primary);touch-action:none}.maskFloatingToolbar button{min-width:54px;padding:8px 9px;border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);background:#fffffff0;color:var(--c-text-main);font-size:12px;font-weight:900}.maskFloatingToolbar button.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.maskFloatingToolbar button:disabled{opacity:.45}.maskFloatingToolbar hr{width:100%;margin:4px 0;border:0;border-top:1px solid rgba(255,255,255,.16)}.maskEditorControls{display:grid;grid-template-columns:minmax(0,1fr) minmax(220px,.8fr);gap:14px;align-items:center;padding:16px 20px;border-top:2px dashed #FFF0F3;background:#fff8faf0}.maskToolGroup,.maskZoomGroup,.maskUtilityGroup,.maskEditorActions{display:flex;flex-wrap:wrap;gap:8px}.maskToolGroup button,.maskZoomGroup button,.maskUtilityGroup button{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid #FFB7C5;background:#fff;color:var(--c-text-main);font-weight:800}.maskToolGroup button.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary);box-shadow:0 3px 0 var(--c-primary-active)}.maskBrushControl{display:grid;gap:6px;color:var(--c-text-main);font-size:13px;font-weight:800}.maskBrushControl input{width:100%}.maskToggleControl{display:flex;align-items:center;gap:8px;color:var(--c-text-main);font-size:13px;font-weight:800}.maskToggleControl input{width:16px;height:16px;accent-color:var(--c-primary)}.maskZoomGroup{align-items:center}.maskZoomGroup label{min-width:180px;flex:1 1 220px;display:grid;grid-template-columns:52px minmax(120px,1fr);gap:8px;align-items:center;color:var(--c-text-main);font-size:13px;font-weight:800}.maskZoomGroup label input{width:100%}.maskUtilityGroup{grid-column:1 / -1}.maskEditorInfo{grid-column:1 / -1;display:flex;flex-wrap:wrap;gap:8px}.maskEditorInfo span{padding:5px 8px;border:1px solid rgba(255,183,197,.7);border-radius:var(--radius-sm);background:#fff;color:var(--c-text-light);font-size:12px;font-weight:800}.maskEditorActions{grid-column:1 / -1;justify-content:flex-end}.toggleRow{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:20px 0 12px;padding-top:16px;border-top:2px dashed #FFF0F3}.toggleRow label{display:flex;gap:12px;align-items:center;color:var(--c-text-main);font-size:14px;font-weight:700}.toggleRow select{max-width:120px;border:2px solid #F0F0F0;border-radius:var(--radius-sm);padding:6px 12px}.notice{display:flex;align-items:center;gap:12px;padding:16px;margin-bottom:24px;font-size:14px;font-weight:700;border-radius:var(--radius-sm)}.notice.compact{padding:10px 12px;font-size:13px;margin-top:12px}.errorNotice{background:#fff5f7;border:2px dashed #FFB7C5;color:var(--c-primary-active)}.statusNotice{background:#f6ffed;border:2px dashed #B7EB8F;color:#52c41a}.pulseDot{width:8px;height:8px;border-radius:50%;background:#52c41a;animation:pulse 1.5s ease-in-out infinite;box-shadow:0 0 8px #52c41a}.resultPane{min-height:800px;padding:40px}.toolbarActions{display:flex;gap:12px}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:32px}.imageCard{background:#fff;padding:12px 12px 40px;border-radius:2px;box-shadow:0 4px 16px #8a717626,0 8px 32px #8a71761a,-4px 4px 12px #8a71760d;position:relative;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.imageCard:hover{transform:translateY(-8px) scale(1.02) rotate(1deg);box-shadow:2px 12px 20px #00000026;z-index:10}.imageCard .imageSubMeta{position:absolute;bottom:8px;right:12px;font-size:10px;color:var(--c-text-light);font-family:Courier New,Courier,monospace}.imageCard:after{content:"✦";position:absolute;top:-10px;right:20px;color:#ffc857;font-size:24px;text-shadow:0 2px 4px rgba(255,200,87,.4);transform:rotate(15deg);opacity:.8}.imageCard:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%) rotate(-3deg);width:60px;height:24px;background:#ffb7c54d;box-shadow:0 1px 2px #0000000d;z-index:10}.imageFrame{display:block;min-height:280px;background:#222;overflow:hidden;position:relative}.imageFrame img{width:100%;height:100%;display:block;object-fit:cover;transition:transform .5s ease}.imageCard:hover .imageFrame img{transform:scale(1.05)}.imageMeta{position:absolute;bottom:0;left:0;right:0;height:40px;display:flex;align-items:center;justify-content:center}.imageMeta span,.imageMeta strong{font-family:var(--font-serif);font-size:14px;color:var(--c-text-main);font-weight:700;transform:rotate(-2deg)}.cardActions{display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);gap:12px;opacity:0;transition:opacity .3s;z-index:20}.imageCard:hover .cardActions{opacity:1}.cardActions a,.cardActions button{background:#ffffffe6;color:var(--c-primary);width:32px;height:32px;border-radius:50% 40% 50% 45%;display:flex;align-items:center;justify-content:center;border:1px dashed var(--c-primary);transition:all .2s;box-shadow:1px 2px 4px #0000001a;padding:0}.cardActions a:hover,.cardActions button:hover{background:var(--c-primary);color:#fff;transform:scale(1.15) rotate(-5deg);border-style:solid}.cardActions a:active,.cardActions button:active{transform:translateY(2px)}.emptyState{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:40px;border:2px dashed #FFB7C5;background:var(--c-primary-light);border-radius:var(--radius-lg);text-align:center}.emptyState h3{font-size:24px;margin-bottom:12px;color:var(--c-primary-active)}.emptyState p{max-width:480px;margin:0;color:var(--c-text-main);font-weight:600;line-height:1.6;font-size:15px}.loader{width:40px;height:40px;border:4px solid var(--c-primary-light);border-top-color:var(--c-primary);border-radius:50%;animation:spin 1s cubic-bezier(.68,-.55,.26,1.55) infinite}.miniButton{padding:8px 12px;min-height:0}.authShell{min-height:100vh;display:flex;align-items:center;justify-content:center}.authCard{width:min(520px,100%)}.authCard h1{margin:8px 0 20px}.authForm{display:grid;gap:16px;margin-top:18px}.adminPanel{margin-bottom:24px}.adminGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:18px}.subPanel{display:grid;gap:14px;padding:18px;border:1px solid rgba(255,183,197,.75);border-radius:var(--radius-md);background:#ffffffb8}.subPanel h3{margin:0;color:var(--c-primary-active)}.adminList{display:grid;gap:10px}.adminRow{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.4fr) auto auto;gap:10px;align-items:center;padding:10px 12px;border:1px solid rgba(255,183,197,.65);border-radius:var(--radius-sm);background:#fff}.adminRow strong,.adminRow span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.adminRow button{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid #FFB7C5;background:var(--c-primary-light);color:var(--c-primary-active);font-weight:700}.nodeHint{display:grid;gap:6px;padding:14px;border:1px solid rgba(255,183,197,.8);border-radius:var(--radius-md);background:var(--c-primary-light)}.nodeHint span{color:var(--c-text-muted);font-size:14px;overflow-wrap:anywhere}.folderGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.folderCard{min-height:112px;display:flex;flex-direction:column;justify-content:center;gap:10px;padding:18px;text-align:left;border:2px solid rgba(255,183,197,.8);border-radius:var(--radius-md);background:#fff;box-shadow:0 8px #ffb7c540;transition:transform .16s ease,box-shadow .16s ease}.folderCard:hover{transform:translateY(-3px);box-shadow:0 11px #ffb7c547}.folderCard strong{color:var(--c-primary-active);font-size:17px;overflow-wrap:anywhere}.folderCard span{color:var(--c-text-muted);font-weight:700}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.3}}@media (max-width: 1200px){.workspace{grid-template-columns:1fr}}@media (max-width: 640px){.appShell{width:100%;padding:24px 16px}.panel,.resultPane{padding:20px}.fieldGrid,.adminGrid,.adminRow{grid-template-columns:1fr}.maskPanelHeader,.maskPreviewRow,.maskEditorHeader{align-items:stretch}.maskPanelHeader,.maskEditorHeader{flex-direction:column}.maskEditorBackdrop{padding:0;align-items:stretch}.maskEditorModal{width:100%;max-height:100vh;border-radius:0;border-left:0;border-right:0}.maskCanvasViewport{padding:12px}.maskEditorModal.immersiveMode .maskCanvasViewport{padding-bottom:104px}.maskEditorModal.immersiveMode .maskFloatingBrushPanel{bottom:max(8px,env(safe-area-inset-bottom));width:calc(100vw - 16px);grid-template-columns:42px minmax(0,1fr) 42px;gap:8px;padding:9px 10px}.maskFloatingBrushPanel button{width:42px;height:42px}.maskEditorControls{grid-template-columns:1fr;padding:14px}.maskZoomGroup label{min-width:100%}.maskUtilityGroup,.maskToolGroup,.maskZoomGroup{gap:6px}.maskEditorActions{justify-content:stretch}.maskEditorActions button{flex:1 1 44%}}.toastContainer{position:fixed;top:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toastPaper{pointer-events:auto;min-width:280px;max-width:380px;padding:12px 16px;background-color:#fff9e6;border:2px dashed #d1c7a3;border-radius:4px 8px 6px 4px;box-shadow:2px 4px 8px #0000000d,inset 0 0 10px #ffffff80;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;animation:slideInPaper .3s cubic-bezier(.175,.885,.32,1.275) forwards;color:#4a4a4a;font-family:inherit;position:relative}.toastPaper:after{content:"";position:absolute;bottom:0;right:0;width:12px;height:12px;background:linear-gradient(135deg,transparent 50%,rgba(0,0,0,.05) 50%);border-top-left-radius:4px}.toast-error{background-color:#ffeae6;border-color:#ffb8b8;color:#a83232}.toast-success{background-color:#eafbe6;border-color:#b8dfb8;color:#3b7b3b}.toast-warning{background-color:#fff4d4;border-color:#ffd885;color:#9c6c19}.toast-info{background-color:#e6f4ff;border-color:#b8d4ff;color:#325a96}.toastContent{font-size:14px;line-height:1.5;flex-grow:1;word-break:break-word}.toastCloseBtn{background:none;border:none;cursor:pointer;padding:4px;margin:-4px;color:inherit;opacity:.5;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.toastCloseBtn:hover{opacity:1}.toastConfirmOverlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10001;display:flex;align-items:center;justify-content:center;padding:24px;background:#2a23256b;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.toastConfirmPaper{width:min(420px,100%);padding:22px;color:#5b4a4f;background:#fff9e6;border:2px dashed #e0b3a5;border-radius:8px 12px 10px 8px;box-shadow:0 20px 50px #58384033,inset 0 0 16px #ffffff8c;transform:rotate(-.4deg);animation:confirmPaperIn .18s ease-out}.toastConfirmTitle{margin-bottom:10px;font-size:18px;font-weight:800;color:#b65f6f}.toastConfirmContent{font-size:15px;line-height:1.65;word-break:break-word}.toastConfirmActions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.toastCancelBtn,.toastConfirmBtn{min-width:82px;padding:9px 14px;border-radius:8px 6px 9px 7px;border:1px dashed #d7b9ad;cursor:pointer;font-weight:700}.toastCancelBtn{color:#6b5960;background:#fff}.toastConfirmBtn{color:#fff;background:#e8788e;border-color:#d96b81}.toastCancelBtn:hover:not(:disabled),.toastConfirmBtn:hover:not(:disabled){transform:translateY(-1px) rotate(-1deg)}@keyframes slideInPaper{0%{transform:translate(120%) rotate(5deg);opacity:0}to{transform:translate(0) rotate(0);opacity:1}}@keyframes confirmPaperIn{0%{opacity:0;transform:translateY(10px) scale(.98) rotate(-1.5deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(-.4deg)}}.comboboxWrapper{position:relative;width:100%}.comboboxInputArea{display:flex;position:relative;background-color:var(--c-surface);border:2px dashed var(--c-border);border-radius:4px 6px 3px 5px;transition:border-color .2s,box-shadow .2s}.comboboxInputArea:focus-within{border-color:var(--c-primary);border-style:solid;box-shadow:2px 2px #dc969633}.comboboxInput{flex:1;border:none;background:transparent;padding:8px 12px;font-family:inherit;font-size:14px;color:var(--c-text);outline:none;min-width:0}.comboboxToggle{background:transparent;border:none;border-left:1px dashed var(--c-border);color:var(--c-text-light);padding:0 10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.comboboxToggle:hover{color:var(--c-primary);background-color:#fff0f380;border-top-right-radius:6px;border-bottom-right-radius:5px}.comboboxDropdown{position:absolute;top:calc(100% + 4px);left:0;width:100%;max-height:240px;overflow-y:auto;background-color:#fffdf5;border:1px solid var(--c-border);border-radius:2px 5px 3px 4px;box-shadow:3px 5px 12px #00000014;z-index:100;list-style:none;padding:4px 0;margin:0;animation:foldOut .2s cubic-bezier(.175,.885,.32,1.275);transform-origin:top center}.comboboxOption{padding:8px 16px;font-size:14px;color:var(--c-text);cursor:pointer;display:flex;align-items:center;gap:8px;border-bottom:1px dashed transparent}.comboboxOption:hover{background-color:var(--c-primary-light);color:#fff}.comboboxOption.selected{background-color:#ff8c961a;color:var(--c-primary);font-weight:700}.recommendedStar{color:#f5b041;font-size:12px}.comboboxEmpty{padding:12px 16px;color:var(--c-text-light);font-size:13px;font-style:italic;text-align:center}@keyframes foldOut{0%{opacity:0;transform:scaleY(.8) translateY(-10px)}to{opacity:1;transform:scaleY(1) translateY(0)}}.previewOverlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#191714f2;z-index:10000;display:flex;flex-direction:column;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.previewToolbar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:linear-gradient(to bottom,rgba(0,0,0,.4),transparent);color:#fff9e6;z-index:2}.previewFileName{display:block;max-width:min(54vw,720px);font-family:monospace;font-size:14px;opacity:.8;letter-spacing:.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.previewActions{display:flex;gap:12px}.previewBtn{background:transparent;border:1px dashed rgba(255,249,230,.3);color:#fff9e6;width:36px;height:36px;border-radius:50% 40% 45% 50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.previewBtn:hover{background:#fff9e61a;border-color:#fff9e6cc;transform:scale(1.05) rotate(2deg)}.previewBtn.closeBtn:hover{background:#a83232;border-color:#ffb8b8;color:#fff}.previewCanvas{flex:1;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.previewImageMount{position:relative;display:inline-block;line-height:0;transition:transform .1s ease-out}.previewPinkTape{position:absolute;top:-11px;left:50%;z-index:2;width:60px;height:24px;background:#ffb7c54d;transform:translate(-50%) rotate(-3deg);pointer-events:none}.previewImageId{position:absolute;right:16px;bottom:10px;z-index:2;max-width:calc(100% - 32px);color:#5a4c5294;font-family:Courier New,Courier,monospace;font-size:10px;font-weight:700;line-height:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;pointer-events:none}.previewImage{max-width:90vw;max-height:80vh;object-fit:contain;border:12px solid #fff9e6;border-bottom-width:36px;box-shadow:0 10px 30px #00000080;border-radius:2px;box-sizing:border-box;-webkit-user-select:none;user-select:none}@media (max-width: 720px){.previewToolbar{align-items:flex-start;gap:12px;padding:12px}.previewFileName,.previewImageId{max-width:56vw}.previewPinkTape{width:52px;height:20px}.previewImageId{right:12px;bottom:9px;max-width:calc(100% - 24px);font-size:9px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.adminSection{background:var(--c-surface);border:2px solid rgba(255,183,197,.4);border-radius:var(--radius-lg);padding:24px;margin-top:24px;box-shadow:0 4px 12px #ff9eb50d}.sectionHeader{margin-bottom:24px;border-bottom:2px dashed rgba(255,183,197,.4);padding-bottom:16px}.sectionHeader h3{margin:0;color:var(--c-primary-active);font-family:var(--font-serif);font-size:20px}.adminTable{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px;border:1px solid rgba(255,183,197,.3);border-radius:var(--radius-md);overflow:hidden}.adminTable th,.adminTable td{padding:12px 16px;text-align:left;border-bottom:1px dashed rgba(255,183,197,.3);color:var(--c-text-main);font-size:14px}.adminTable th{background:#ffb7c51a;font-weight:700;color:var(--c-primary-active)}.adminTable tr:last-child td{border-bottom:none}.adminTable tbody tr:hover{background:#ffb7c50d}.adminTable button{background:transparent;border:1px dashed var(--c-primary);color:var(--c-primary);padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;font-weight:600}.adminTable button:hover{background:var(--c-primary);color:#fff;border-style:solid;transform:translateY(-1px) rotate(-2deg)}.inlineForm.stickyNote{background:#fff9c4;padding:12px 16px;border-radius:2px 8px 4px 6px;box-shadow:2px 4px 8px #0000001a;display:flex;gap:8px;align-items:center;position:relative;border:1px solid rgba(0,0,0,.05);transform:rotate(1deg);z-index:10;animation:popIn .3s cubic-bezier(.34,1.56,.64,1) forwards}.inlineForm.stickyNote .stickyPin{position:absolute;top:-6px;left:50%;transform:translate(-50%);width:12px;height:12px;border-radius:50%;background:#ff5252;box-shadow:inset -2px -2px 4px #0003,1px 2px 2px #0003}.inlineForm.stickyNote .handDrawnInput{background:transparent;border:none;border-bottom:2px dashed rgba(0,0,0,.2);border-radius:0;padding:4px 0;font-family:var(--font-serif);font-weight:700;color:#333;width:100px}.inlineForm.stickyNote .handDrawnInput:focus{outline:none;border-bottom-color:var(--c-primary)}@keyframes popIn{0%{opacity:0;transform:scale(.9) rotate(-5deg) translateY(-10px)}to{opacity:1;transform:scale(1) rotate(1deg) translateY(0)}}.adminFormRow{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.adminFormRow label{font-weight:700;color:var(--c-primary-active);font-size:14px}.adminFormRow input[type=text],.adminFormRow input[type=password]{background:#fff;border:2px solid rgba(255,183,197,.4);border-radius:6px 4px 8px;padding:8px 12px;font-family:var(--font-sans);color:var(--c-text-main);transition:border-color .2s}.adminFormRow input:focus{outline:none;border-color:var(--c-primary);border-style:dashed}.adminFormRow.checkbox{flex-direction:row;align-items:center;gap:8px}.adminFormRow.checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--c-primary)}
