@font-face{font-family:OPPOSans;src:url(/fonts/OPPOSans-Regular.ttf)format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OPPOSans;src:url(/fonts/OPPOSans-Medium.ttf)format("truetype");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:OPPOSans;src:url(/fonts/OPPOSans-Bold.ttf)format("truetype");font-weight:700;font-style:normal;font-display:swap}:root{color:#0f1724;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--page-bg:#e9eef4;--panel-bg:#ffffffd1;--panel-border:#0f172a1f;--panel-shadow:0 24px 72px #0f172a1a;--text-strong:#0f172a;--text-soft:#4b5563;--accent-warm:#0a84ff;--accent-warm-deep:#005fd1;--accent-mint:#0a84ff;--accent-mint-soft:#0a84ff29;--surface-soft:#eff4faeb;--surface-strong:#fffffff7;background:#e9eef4;font-family:OPPOSans,Avenir Next,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-weight:500;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:radial-gradient(circle at 12% 12%,#93c5fd47,#0000 20%),radial-gradient(circle at 88% 10%,#ffffff6b,#0000 18%),radial-gradient(circle at 72% 82%,#5e7ca62e,#0000 24%),repeating-linear-gradient(0deg,#0f172a08 0 1px,#0000 1px 24px),repeating-linear-gradient(90deg,#ffffff06 0 1px,#0000 1px 24px),linear-gradient(#e8eef5 0%,#dfe7f0 48%,#d6e0ea 100%);min-width:320px;min-height:100svh;margin:0;position:relative;overflow-x:hidden}body:before,body:after{content:"";pointer-events:none;z-index:0;position:fixed;inset:auto}body:before{filter:blur(6px);background:radial-gradient(circle,#ffffffb3 0%,#bfdbfe24 62%,#0000 100%);border-radius:999px;width:24vw;min-width:260px;height:24vw;min-height:260px;animation:20s ease-in-out infinite floatPanel;top:6vh;left:-6vw}body:after{filter:blur(8px);background:radial-gradient(circle,#ffffffbd 0%,#cbd5e129 58%,#0000 100%);border-radius:999px;width:22vw;min-width:220px;height:22vw;min-height:220px;animation:22s ease-in-out infinite floatDiamond;bottom:10vh;right:-6vw}button,input,select{font:inherit}#root{z-index:1;width:100%;position:relative}@keyframes floatPanel{0%,to{transform:translate(0,0)rotate(18deg)}50%{transform:translate(30px,18px)rotate(23deg)}}@keyframes floatDiamond{0%,to{opacity:.82;transform:translate(0,0)rotate(0)}50%{opacity:1;transform:translate(-20px,-24px)rotate(12deg)}}@font-face{font-family:Fusion Pixel ZhHans;src:url(/fonts/fusion-pixel-zh-hans.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}:root{--surface-radius-xl:8px;--surface-radius-lg:6px;--surface-radius-md:5px;--surface-radius-sm:4px;--surface-radius-xs:3px;--store-banner-height:64px;--store-banner-height-mobile:56px}.auth-shell{place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{border-radius:var(--surface-radius-xl);border:1px solid var(--panel-border);background:var(--panel-bg);width:min(100%,460px);box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(22px)saturate(1.12);backdrop-filter:blur(22px)saturate(1.12);padding:28px}.auth-header h1{color:var(--text-strong);letter-spacing:-.03em;margin:0;font-size:clamp(28px,4vw,38px);line-height:1.04}.auth-subtitle{color:#374151e0;margin:10px 0 0}.auth-switch{grid-template-columns:1fr 1fr;gap:10px;margin-top:22px;display:grid}.auth-switch button,.auth-submit-button{font:inherit;cursor:pointer;border:0;border-radius:16px;font-weight:700}.auth-switch button{min-height:46px;color:var(--text-soft);background:#f8fafceb;border:1px solid #0f172a14}.auth-switch button.is-active{background:linear-gradient(135deg, var(--accent-warm), var(--accent-warm-deep));color:#fff9f3}.auth-switch button.is-locked{opacity:.72}.auth-form{gap:14px;margin-top:20px;display:grid}.auth-field{gap:8px;display:grid}.auth-field span{color:var(--text-soft);font-size:13px}.auth-field input{width:100%;min-height:48px;color:var(--text-strong);font:inherit;background:#ffffffeb;border:1px solid #0f172a14;border-radius:14px;padding:0 14px}.auth-inline-field{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.auth-inline-button{color:#0f5fd6;min-width:118px;min-height:48px;font:inherit;cursor:pointer;background:#eff6fff5;border:1px solid #0f172a1a;border-radius:14px;padding:0 14px;font-size:13px;font-weight:700;transition:transform .16s,box-shadow .16s,opacity .16s,border-color .16s}.auth-inline-button:hover:not(:disabled){border-color:#0a84ff3d;transform:translateY(-1px);box-shadow:0 12px 24px #0a84ff1f}.auth-inline-button:disabled{opacity:.56;cursor:not-allowed}.auth-message{color:#b95e2d;margin:0;font-size:13px}.auth-submit-button{background:linear-gradient(135deg, var(--accent-mint), #256d5b);color:#fff;min-height:52px}.auth-helper{color:var(--text-soft);margin:0;font-size:12px}.auth-locked-panel{border-radius:var(--surface-radius-lg);color:var(--text-soft);background:#f8fafcf0;border:1px solid #0f172a14;gap:8px;margin-top:20px;padding:18px;display:grid}.site-footnote{color:#626a74c7;margin-top:14px;padding:12px 4px 0;font-size:11px;line-height:1.65}.site-footnote p{margin:0}.site-footnote p+p{margin-top:8px}.app-shell{width:min(1380px,100% - 32px);margin:0 auto;padding:0 0 28px;position:relative}.top-auth-bar{white-space:nowrap;justify-content:flex-end;align-items:center;gap:6px;min-height:20px;margin-top:8px;margin-bottom:8px;display:flex}.language-switch{white-space:nowrap;box-shadow:none;background:0 0;border:0;border-radius:999px;flex:none;order:-1;align-items:center;gap:0;padding:0;display:inline-flex}.language-separator{color:#6f78848f;margin:0 1px;font-size:11px;line-height:1}.language-link{z-index:1;letter-spacing:0;padding-inline:3px;position:relative}.language-link.is-active{color:var(--text-strong);text-underline-offset:3px;text-decoration:underline}.top-auth-text{color:#374151f5;white-space:nowrap;font-size:11px;line-height:1}.points-popover-wrap{align-items:center;display:flex;position:relative}.points-popover-trigger{align-items:center;display:inline-flex}.points-popover-card{border-radius:var(--surface-radius-md);-webkit-backdrop-filter:blur(20px)saturate(1.08);backdrop-filter:blur(20px)saturate(1.08);z-index:30;background:#fffffffa;border:1px solid #0f172a14;width:228px;padding:14px 14px 12px;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 18px 44px #0f172a1f,inset 0 0 0 1px #ffffff6b}.points-popover-label{color:#0a84ffcc;letter-spacing:.18em;text-transform:uppercase;margin:0 0 10px;font-size:11px;line-height:1}.points-popover-row{color:#374151eb;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;font-size:13px;display:flex}.points-popover-row+.points-popover-row{border-top:1px solid #0f172a0f}.points-popover-row strong{color:var(--text-strong);font-size:15px}.points-popover-tip{color:#6b7280e0;margin:10px 0 0;font-size:11px;line-height:1.5}.points-popover-action{color:#0f5fd6;width:100%;min-height:38px;font:inherit;cursor:pointer;background:#eff6fff5;border:1px solid #0a84ff29;border-radius:12px;margin-top:12px;font-size:13px;font-weight:700;transition:transform .16s,box-shadow .16s,border-color .16s}.points-popover-action:hover{border-color:#0a84ff42;transform:translateY(-1px);box-shadow:0 12px 24px #0a84ff1f}.hidden-file-input{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.hero-panel,.workspace-panel,.preview-card,.summary-card,.stats-card{border:1px solid var(--panel-border);background:var(--panel-bg);box-shadow:var(--panel-shadow);-webkit-backdrop-filter:blur(22px)saturate(1.1);backdrop-filter:blur(22px)saturate(1.1)}.hero-panel{border-radius:var(--surface-radius-md);background:linear-gradient(135deg, #ffffffdb, #f8fafcad), var(--panel-bg);grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;padding:14px 18px;display:grid;position:relative;overflow:hidden}.hero-actions{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.top-auth-link{color:#4b5563e6;font:inherit;cursor:pointer;box-shadow:none;background:0 0;border:0;padding:0;font-size:11px;line-height:1;transition:color .16s,opacity .16s,transform .16s,text-shadow .16s}.top-auth-link:hover{color:var(--text-strong);box-shadow:none;text-underline-offset:3px;text-shadow:0 0 16px #0a84ff1f;-webkit-text-decoration:underline #0a84ff6b;text-decoration:underline #0a84ff6b;transform:translateY(-1px)}.logout-button,.claim-button{width:auto;min-width:auto;min-height:auto}.claim-button.is-claimable{color:#215548}.auth-modal-layer{z-index:80;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0f172a3d;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.auth-modal-layer-in-workbench{z-index:90}.auth-modal-card{width:min(100%,460px);max-height:calc(100vh - 40px);overflow:auto;box-shadow:0 34px 84px #0f172a29,inset 0 0 0 1px #ffffff6b}.auth-header{position:relative}.auth-close-button{width:34px;height:34px;color:var(--text-strong);cursor:pointer;background:#f8fafcf5;border:1px solid #0f172a14;border-radius:999px;font-size:22px;line-height:1;position:absolute;top:-4px;right:-4px}.get-points-modal-card{width:min(100%,420px)}.get-points-copy{line-height:1.7}.get-points-contact{color:#374151eb;justify-content:center;align-items:center;gap:10px;margin-top:18px;font-size:15px;display:flex}.get-points-contact strong{color:var(--text-strong);letter-spacing:.02em;font-size:17px}.wechat-qr-image{border-radius:var(--surface-radius-lg);border:1px solid #0f172a14;width:min(100%,260px);margin:18px auto 0;display:block;box-shadow:0 18px 40px #0f172a1a}.entry-notice-modal-card{width:min(100%,440px)}.entry-notice-copy{color:#374151f0;gap:10px;margin-top:18px;font-size:14px;line-height:1.75;display:grid}.entry-notice-copy p{margin:0}.entry-notice-wechat{color:var(--text-strong);font-weight:700}.entry-notice-button{margin-top:20px}.auth-actions{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.performance-notice-actions{justify-content:stretch}.performance-notice-button{flex:1 1 0;justify-content:center;align-items:center;min-width:0;min-height:42px;margin-top:0;font-size:14px;font-weight:600;line-height:1;display:inline-flex}.store-branding-float-wrap{z-index:40;width:100vw;margin-bottom:0;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);position:sticky;top:0}.store-branding-card{min-height:var(--store-banner-height);box-shadow:none;border:0;border-radius:0;position:relative;overflow:hidden}.store-branding-card.is-compact{border-radius:var(--surface-radius-md);min-height:118px}.store-branding-card:before,.store-branding-card:after{content:"";pointer-events:none;will-change:transform;width:10px;height:10px;position:absolute}.store-branding-card:before{background:#ffffff24;animation:15s ease-in-out infinite alternate bannerPixelDriftLeft;top:12px;left:3%;box-shadow:14px 0 #ffffff1a,28px 0 #ffffff14,42px 12px #ffffff1f,56px 12px #ffffff17,70px 24px #ffffff1f,84px 10px #ffffff14,98px 22px #ffffff12,126px 8px #ffffff14,140px 20px #ffffff1a,168px 6px #ffffff12,196px 18px #ffffff17,224px 2px #ffffff14,252px 14px #ffffff12,280px 26px #ffffff14,308px 10px #ffffff0f,336px 22px #ffffff17,364px 4px #ffffff14,392px 16px #ffffff0f,420px 0 #ffffff14,448px 12px #ffffff12,476px 24px #ffffff17,504px 8px #ffffff0f,532px 18px #ffffff14,560px 2px #ffffff12,588px 14px #ffffff17,616px 26px #ffffff12}.store-branding-card:after{background:#00000014;animation:18s ease-in-out infinite alternate bannerPixelDriftRight;top:18px;right:2%;box-shadow:-16px 0 #0000000d,-30px 12px #0000000f,-44px 0 #0000000d,-58px 24px #0000000d,-72px 8px #0000000a,-100px 20px #0000000d,-128px 4px #0000000d,-156px 16px #0000000a,-184px 28px #0000000d,-212px 10px #0000000a,-240px 22px #0000000d,-268px 6px #0000000a,-296px 18px #0000000d,-324px 2px #0000000a,-352px 14px #0000000d,-380px 26px #0000000a,-408px 8px #0000000d,-436px 20px #0000000a,-464px 4px #0000000d,-492px 16px #0000000a,-520px 28px #0000000d,-548px 12px #0000000a,-576px 0 #0000000d,-604px 18px #0000000a}.store-branding-card-overlay{z-index:1;justify-content:center;align-items:center;padding:0 24px;display:flex;position:absolute;inset:0}.store-branding-card-text{letter-spacing:.08em;white-space:nowrap;text-overflow:ellipsis;text-align:center;text-shadow:none;font-family:Fusion Pixel ZhHans,OPPOSans-Regular,PingFang SC,Microsoft YaHei,sans-serif;font-size:clamp(22px,2.1vw,32px);line-height:1;overflow:hidden}.store-branding-card.is-compact .store-branding-card-text{font-size:clamp(24px,2.4vw,36px)}@keyframes bannerPixelDriftLeft{0%{transform:translate(-10px)}50%{transform:translate(10px,3px)}to{transform:translate(24px,-2px)}}@keyframes bannerPixelDriftRight{0%{transform:translate(8px)}50%{transform:translate(-14px,-3px)}to{transform:translate(-28px,2px)}}.store-branding-modal-card{width:min(100%,560px)}.store-branding-form{gap:14px;margin-top:20px;display:grid}.store-branding-color-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.store-branding-color-tile{border-radius:var(--surface-radius-md);cursor:pointer;border:1px solid #0f172a14;gap:6px;min-height:64px;padding:10px 12px;display:grid;position:relative;box-shadow:inset 0 1px #ffffff3d}.store-branding-color-input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.store-branding-color-name{color:#ffffffe0;text-shadow:0 1px 2px #0f172a47;font-size:12px;line-height:1}.store-branding-color-value{color:#fff;letter-spacing:.04em;text-shadow:0 1px 3px #0f172a52;font-size:12px}.store-branding-toggle{border-radius:var(--surface-radius-md);background:#f8fafce6;border:1px solid #0f172a14;min-height:48px;padding:0 14px}.store-branding-toggle input{accent-color:#0f5fd6}.store-branding-helper{margin-top:-2px}.store-branding-preview-block{border-radius:var(--surface-radius-lg);background:#f8fafce6;border:1px solid #0f172a14;gap:10px;padding:14px;display:grid}.store-branding-preview-header{color:#4b5563eb;justify-content:space-between;align-items:center;gap:12px;font-size:12px;display:flex}.store-branding-preview-header strong{max-width:min(100%,240px);color:var(--text-strong);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.hero-panel>*{z-index:2;position:relative}.hero-panel:after{content:none}.eyebrow,.card-label,.status-label{letter-spacing:.22em;text-transform:uppercase;color:#0a84ffd1;margin:0 0 10px;font-size:12px;line-height:1}.hero-panel h1,.workspace-header h2,.summary-card h2,.stats-card h2{color:var(--text-strong);margin:0}.hero-panel h1{letter-spacing:-.03em;white-space:nowrap;max-width:none;font-size:clamp(22px,2.2vw,30px);line-height:1.02}.hero-subtitle{color:#374151eb;white-space:nowrap;margin:7px 0 0;font-size:clamp(13px,1.2vw,15px);line-height:1.1}.hero-badges,.status-meta{flex-wrap:wrap;gap:10px;margin-top:18px;display:flex}.hero-badges span,.status-meta span{color:#374151e6;background:#f8fafcd6;border:1px solid #0f172a14;border-radius:999px;padding:9px 12px;font-size:13px}.upload-button,.secondary-button,.export-button,.source-switch button,.zoom-actions button{font:inherit;cursor:pointer;border:0;border-radius:18px;transition:transform .18s,box-shadow .18s,background-color .18s,border-color .18s,color .18s,opacity .18s}.upload-button,.secondary-button,.export-button{width:100%;min-height:52px;font-weight:700}.upload-button{color:#fff;z-index:3;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border-radius:12px;justify-content:center;align-items:center;width:auto;min-width:108px;min-height:40px;padding:0 16px;font-size:14px;display:inline-flex;position:relative;box-shadow:0 14px 32px #0074f047,inset 0 0 0 1px #ffffff42}.upload-button.is-subtle{color:#0f5fd6;background:linear-gradient(#eef5ff 0%,#dbeafe 100%);box-shadow:0 10px 22px #0a84ff1f,inset 0 0 0 1px #ffffff47}.upload-button.is-disabled,.secondary-button:disabled,.export-button:disabled,.source-switch button:disabled,.primary-action-button:disabled{opacity:.45;cursor:not-allowed}.secondary-button{color:#1f2937f5;background:#fffffff0;border:1px solid #0f172a1a;box-shadow:inset 0 1px #ffffffd1,0 1px 2px #0f172a0d}.primary-action-button{color:#fff;width:auto;min-width:136px;min-height:46px;font:inherit;letter-spacing:-.01em;cursor:pointer;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border:1px solid #0074f0e0;border-radius:14px;justify-content:center;align-items:center;padding:0 16px;font-weight:800;transition:transform .18s,box-shadow .18s,opacity .18s,background .18s,border-color .18s;display:inline-flex;box-shadow:0 16px 30px #0074f03d,inset 0 0 0 1px #ffffff2e}.primary-action-button.is-busy{cursor:progress}.upload-button:hover,.export-button:hover,.primary-action-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 34px #0074f04d,inset 0 0 0 1px #ffffff38}.secondary-button:hover,.source-switch button:hover,.zoom-actions button:hover{border-color:#0f172a24;transform:translateY(-1px);box-shadow:0 12px 24px #0f172a1a}.upload-button:active,.secondary-button:active,.export-button:active,.primary-action-button:active,.source-switch button:active,.zoom-actions button:active{transform:translateY(0)}.compact-button{width:148px;min-height:46px}.inline-upload-button{text-align:center;justify-content:center;justify-self:start;align-items:center;width:136px;min-height:38px;font-size:13px;line-height:1;display:inline-flex}.full-button{margin-top:18px}.status-strip{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;border-radius:0;margin-top:8px;padding:0}.status-inline-text{white-space:nowrap;text-overflow:ellipsis;color:#64748bd1;letter-spacing:0;margin:0;font-size:11px;font-weight:400;line-height:1.3;overflow:hidden}.workspace-panel{border-radius:var(--surface-radius-md);background:linear-gradient(180deg, #ffffffb8, #f8fafc94), var(--panel-bg);box-shadow:none;margin-top:12px;padding:14px}.workspace-header{justify-content:space-between;align-items:start;gap:14px;margin-bottom:10px;display:flex}.workspace-header-note{color:#64748be6;text-align:right;white-space:nowrap;max-width:380px;margin:0;font-size:12px;line-height:1.2}.card-header-inline{justify-content:space-between;align-items:center;gap:12px;min-height:54px;display:flex}.card-header-actions{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:10px;min-width:0;display:flex}.workspace-header h2{letter-spacing:-.02em;font-size:24px}.preview-grid{gap:10px;display:grid}.preview-grid-double{grid-template-columns:repeat(2,minmax(0,1fr))}.preview-card{border-radius:var(--surface-radius-md);background:linear-gradient(180deg, #ffffffeb, #f8fafcd1), var(--panel-bg);box-shadow:none;flex-direction:column;padding:12px;display:flex}.preview-card-plain{box-shadow:none;background:0 0;border:0;border-radius:0;padding:0}.pattern-preview-card{gap:8px;display:grid}.pattern-source-bar{justify-content:center;margin-bottom:-2px;display:flex}.preview-card-accent{background:radial-gradient(circle at 100% 0,#bfdbfe57,#0000 34%),linear-gradient(#fffffff0,#f4f7fbdb)}.preview-card header{margin-bottom:10px}.preview-card h3{color:var(--text-strong);white-space:nowrap;margin:0;font-size:18px}.preview-card canvas{aspect-ratio:1;border-radius:var(--surface-radius-sm);background-color:#0000;background-image:linear-gradient(45deg,#e2e8f07a 25%,#0000 25%),linear-gradient(-45deg,#e2e8f07a 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#e2e8f07a 75%),linear-gradient(-45deg,#0000 75%,#e2e8f07a 75%);background-position:0 0,0 11px,11px -11px,-12px 0;background-repeat:repeat,repeat,repeat,repeat;background-size:22px 22px;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;border:1px solid #0f172a1a;width:100%;display:block}.crop-stage{border-radius:var(--surface-radius-sm);touch-action:none;cursor:grab;position:relative;overflow:hidden}.crop-stage.is-empty{place-items:center;display:grid}.crop-frame{pointer-events:none;border:2px solid #fffcf7e6;position:absolute;inset:0;box-shadow:inset 0 0 0 999px #0f172a1f}.crop-placeholder{color:#374151e6;background:#ffffffeb;border:1px solid #0f172a1a;border-radius:999px;padding:8px 12px;font-size:14px;position:absolute}.crop-controls,.pattern-controls{gap:10px;margin-top:10px;display:grid}.pattern-controls-pro{gap:8px}.crop-controls span,.empty-state,.control-row span,.zoom-row span,.checkbox-row span,.progress-meta span,.summary-metrics span,.stats-tile p{color:var(--text-soft)}.control-row{grid-template-columns:max-content minmax(0,1fr) 34px;align-items:center;gap:10px;display:grid}.control-row span{white-space:nowrap}.pattern-toolbar-panel .control-row{grid-template-columns:max-content minmax(0,1fr) 52px;gap:6px}.pattern-toolbar-panel .control-row span,.pattern-toolbar-panel .zoom-row span{white-space:nowrap;color:#6a727ecc;font-size:10px;line-height:1}.pattern-toolbar-panel .control-row strong{color:#343f4ae0;font-size:10px;line-height:1}.size-control{gap:6px;display:grid}.pattern-toolbar-primary{background:linear-gradient(#fbfdfff0,#f3f6f9e6);border:1px solid #0f172a14;border-radius:9px;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:6px;padding:5px;display:flex;overflow-x:auto;box-shadow:inset 0 1px #ffffffd1}.pattern-tool-sidebar{z-index:3;background:linear-gradient(#586270f5,#444d5bfa);border:1px solid #1f293761;border-radius:6px;grid-template-rows:auto 1fr auto;gap:0;width:136px;display:grid;position:absolute;top:12px;left:12px;overflow:hidden;box-shadow:0 12px 30px #0f172a2e}.pattern-tool-sidebar-title{color:#fffffff5;letter-spacing:.04em;white-space:nowrap;cursor:grab;background:#2a313c94;border:0;border-bottom:1px solid #ffffff24;justify-content:center;align-items:center;min-height:30px;padding:0 8px;font-size:11px;font-weight:700;line-height:1;display:flex}.pattern-tool-sidebar-title:active{cursor:grabbing}.pattern-tool-sidebar-group{grid-auto-rows:32px;align-content:start;display:grid}.pattern-tool-button{color:#fffffff5;cursor:pointer;width:100%;min-height:32px;box-shadow:none;white-space:nowrap;text-align:left;background:0 0;border:0;border-bottom:1px solid #ffffff1f;border-radius:0;grid-template-columns:16px minmax(0,1fr) 16px;justify-content:flex-start;align-items:center;gap:6px;padding:0 8px;font-size:10px;font-weight:600;line-height:1;display:grid}.pattern-tool-button:not(.pattern-tool-toggle):after{content:""}.pattern-tool-button:hover:not(:disabled){background:#ffffff14}.pattern-tool-button:disabled{opacity:.48;cursor:default}.pattern-tool-button-label{text-overflow:ellipsis;white-space:nowrap;color:#fffffff5;text-align:left;min-width:0;font-size:10px;overflow:hidden}.pattern-tool-button-icon{color:#fffffff5;text-align:left;justify-content:center;align-items:center;width:16px;min-width:16px;font-size:12px;line-height:1;display:inline-flex}.pattern-tool-toggle{cursor:pointer;grid-template-columns:16px minmax(0,1fr) 16px;align-items:center;column-gap:6px;width:100%;display:grid}.pattern-tool-toggle input{accent-color:#0a84ff;justify-self:end;width:14px;height:14px;margin:0}.pattern-tool-sidebar-history{background:#29303b4d;border-top:1px solid #ffffff1f;gap:5px;padding:5px;display:grid}.pattern-tool-mini-group{grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;display:grid}.pattern-tool-mini-group-view{border-top:1px solid #ffffff1f;grid-template-columns:1fr;padding-top:5px}.pattern-tool-mini-button{color:#fffffff5;background:#ffffff1a;border:1px solid #ffffff2e;border-radius:4px;min-height:24px;padding:0 6px;font-size:10px;font-weight:700;line-height:1}.pattern-tool-mini-button-wide{width:100%}.pattern-tool-mini-button:disabled{opacity:.42;cursor:default}.pattern-toolbar-divider{background:#0f172a14;flex:none;width:1px;height:16px}.pattern-toolbar-secondary{background:#ffffff9e;border:1px solid #0f172a14;border-radius:12px;grid-template-columns:minmax(360px,1.3fr) minmax(310px,1fr) minmax(210px,.72fr);align-items:center;gap:0;padding:0 8px;display:grid;box-shadow:inset 0 1px #ffffffb8}.pattern-toolbar-panel{min-width:0;box-shadow:none;background:0 0;border:0;border-radius:0;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;padding:10px 14px;display:grid}.pattern-toolbar-panel+.pattern-toolbar-panel{border-left:1px solid #0f172a14}.pattern-toolbar-panel-heading{align-items:center;min-width:0;display:flex}.pattern-toolbar-panel-heading-inline{flex-wrap:nowrap;gap:8px}.pattern-toolbar-panel-hint{color:#6a727e94;white-space:nowrap;font-size:9px;line-height:1}.pattern-toolbar-panel-title{color:#586370e0;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;font-size:9px;font-weight:700;line-height:1}.pattern-toolbar-panel-size{grid-template-columns:minmax(0,1fr);align-items:start;gap:8px}.pattern-toolbar-panel-size .size-control{gap:7px;min-width:0}.pattern-toolbar-panel-size .control-row{grid-template-columns:minmax(90px,1fr) 46px;align-items:center}.pattern-toolbar-panel-size .control-row-ghost-label{display:none}.pattern-toolbar-panel-size .pattern-toolbar-panel-hint{text-overflow:ellipsis;flex:0 auto;overflow:hidden}.pattern-toolbar-panel-zoom{grid-template-columns:auto auto minmax(90px,1fr)}.size-control.is-locked .control-row span:before,.preset-row.is-locked>.pattern-toolbar-panel-title:before{content:"🔒";margin-right:6px}.size-control.is-locked .control-row span,.preset-row.is-locked>.pattern-toolbar-panel-title{white-space:nowrap}.size-control.is-locked .control-row span,.preset-row.is-locked>.pattern-toolbar-panel-title,.size-control.is-locked strong{color:#6b51408f}.size-control.is-locked input,.size-control.is-locked .size-toggle,.size-control.is-locked .size-extra-options button,.preset-row.is-locked .preset-actions button{opacity:.48;cursor:not-allowed}.control-row-ghost-label{visibility:hidden;width:0;min-width:0;overflow:hidden}.size-extra-options button{color:#374151e6;font:inherit;cursor:pointer;background:#f8fafcf0;border:1px solid #0f172a1a;border-radius:8px;font-weight:700}.size-extra-options button.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border-color:#0074f0e0}.size-extra-options button.is-unavailable{color:#6b7280eb;background:#f1f5f9f5;border-color:#94a3b842}.size-extra-options{scrollbar-width:none;flex-wrap:nowrap;justify-content:flex-start;gap:4px;display:flex;overflow-x:auto}.pattern-toolbar-panel-size .size-extra-options{padding-top:1px}.size-extra-options button{border-radius:7px;min-width:38px;height:24px;padding:0 6px;font-size:10px}.control-row input,.crop-controls input{width:100%}.size-range-input{justify-self:stretch;width:100%;max-width:100%}.size-number-input{width:46px;min-width:0;height:24px;color:var(--text-strong);font:inherit;text-align:center;background:#fffffff5;border:1px solid #0f172a14;border-radius:6px;padding:0 6px;font-size:10px;line-height:1}.control-row strong{color:var(--text-strong);text-align:right;min-width:0}.pattern-stage{touch-action:none;background:linear-gradient(#f8fafcf5,#edf2f8eb),#edf2f7;border:1px solid #94a3b861;border-radius:8px;height:620px;min-height:620px;padding:12px;position:relative;box-shadow:inset 0 1px #ffffffd1}.pattern-stage.has-sidepanel{padding-right:12px}.pattern-stage-wrap{min-width:0;height:100%;position:relative}.pattern-stage-scroll{touch-action:none;background-color:#eef3f8;background-image:linear-gradient(45deg,#94a3b81f 25%,#0000 25%),linear-gradient(-45deg,#94a3b81f 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#94a3b81f 75%),linear-gradient(-45deg,#0000 75%,#94a3b81f 75%),none;background-position:0 0,0 11px,11px -11px,-11px 0;background-repeat:repeat,repeat,repeat,repeat,repeat;background-size:22px 22px;background-attachment:scroll,scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box,border-box;border-radius:6px;width:100%;height:100%;overflow:auto}.pattern-stage-scroll.is-busy{filter:blur(3px)saturate(.92);opacity:.82;pointer-events:none}.pattern-stage-aligner{justify-content:center;align-items:center;min-width:100%;min-height:100%;display:flex}.pattern-stage-aligner.is-overflow-x{justify-content:flex-start}.pattern-stage-aligner.is-overflow-y{align-items:flex-start}.pattern-stage-busy-overlay{z-index:5;pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:12px}.pattern-stage-busy-card{min-height:42px;color:var(--text-strong);background:#ffffffeb;border:1px solid #0f172a1a;border-radius:999px;align-items:center;gap:10px;padding:0 16px;font-size:13px;font-weight:600;line-height:1;display:inline-flex;box-shadow:0 14px 32px #0f172a24}.pattern-stage-busy-spinner{border:2px solid #0a84ff2e;border-top-color:#0a84fff5;border-radius:999px;width:16px;height:16px;animation:.72s linear infinite pattern-stage-spin}@keyframes pattern-stage-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pattern-stage-zoomdock{z-index:4;background:#fffffff5;border:1px solid #0f172a1f;border-radius:6px;align-items:center;gap:8px;min-width:320px;max-width:min(520px,100% - 180px);padding:8px 10px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 12px 24px #0f172a24}.pattern-stage-zoomdock span,.pattern-stage-zoomdock strong{white-space:nowrap;font-size:11px;line-height:1}.pattern-stage-zoomdock strong{color:var(--text-strong)}.pattern-stage-zoomdock .zoom-slider{flex:auto}.pattern-stage-canvas-shell{flex:none;position:relative}.edit-mode-tip{z-index:2;color:var(--text-strong);pointer-events:none;background:#fffffff0;border:1px solid #0f172a14;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:700;position:absolute;top:14px;left:50%;transform:translate(-50%);box-shadow:0 10px 24px #0f172a14}.pattern-workbench{grid-template-columns:minmax(0,1fr);align-items:stretch;gap:10px;display:grid}.pattern-workbench.is-fullscreen{z-index:60;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#edf1f7f5;border-radius:0;grid-template-rows:1fr;grid-template-columns:minmax(0,1fr);padding:0;position:fixed;inset:0;box-shadow:0 24px 64px #0f172a3d}.pattern-workbench.is-fullscreen .pattern-stage-wrap,.pattern-workbench.is-fullscreen .pattern-stage{height:100%;min-height:0}.pattern-workbench.is-fullscreen .pattern-stage{border-radius:0;padding-bottom:56px}.pattern-text-item{transform:translate(-50%, -50%) rotate(var(--pattern-text-rotation,0deg));transform-origin:50%;z-index:3;pointer-events:auto;min-width:68px;max-width:min(220px,100% - 12px);position:absolute}.pattern-text-item.is-selected{z-index:4}.pattern-text-item-toolbar{-webkit-user-select:none;user-select:none;background:#fffffff5;border:1px solid #0f172a14;border-radius:8px;align-items:center;gap:4px;margin-bottom:6px;padding:4px;display:inline-flex;box-shadow:0 8px 18px #0f172a14}.pattern-text-action{color:#1f2937eb;background:#f8fafcf5;border:1px solid #0f172a14;border-radius:7px;min-width:26px;height:24px;padding:0 6px;font-size:10px;font-weight:700;line-height:1}.pattern-text-action.is-danger{color:#b42318}.pattern-text-input,.pattern-text-label{width:min(var(--pattern-text-width,108px), 220px);color:#111827;font-family:OPPOSans,Avenir Next,PingFang SC,sans-serif;font-size:var(--pattern-text-size,14px);text-align:center;white-space:pre-wrap;word-break:break-word;background:#ffffffe6;border:1px dashed #0f172a2e;border-radius:8px;padding:6px 8px;font-weight:700;line-height:1.1;display:block;box-shadow:0 6px 16px #0f172a0f}.pattern-text-input{resize:none;outline:none;min-height:42px}.pattern-text-frame{width:min(var(--pattern-text-width,108px), 220px);min-height:var(--pattern-text-height,46px);cursor:move;background:#fff3;border:1px dashed #0a84ff9e;border-radius:8px;display:block;position:relative;box-shadow:0 0 0 1px #ffffffb8}.pattern-text-frame .pattern-text-input{width:100%;min-height:var(--pattern-text-height,46px);box-shadow:none;background:#ffffffeb;border:0;border-radius:8px}.pattern-text-hitbox{width:min(var(--pattern-text-width,108px), 220px);min-height:var(--pattern-text-height,46px);background:0 0;border:0;border-radius:8px;display:block}.pattern-text-hitbox:disabled{pointer-events:none}.pattern-text-rotate-handle,.pattern-text-scale-handle{background:#fff;border:1px solid #0a84ffa3;border-radius:999px;width:14px;height:14px;padding:0;position:absolute;box-shadow:0 4px 10px #0f172a1f}.pattern-text-rotate-handle{cursor:grab;top:-8px;right:-8px}.pattern-text-scale-handle{cursor:nwse-resize;bottom:-8px;right:-8px}.ai-preview-shell{border-radius:var(--surface-radius-sm);margin-top:0;position:relative;overflow:hidden}.ai-placeholder-overlay{pointer-events:none;-webkit-user-select:none;user-select:none;background:0 0;position:absolute;inset:0}.ai-placeholder-image{object-fit:contain;opacity:.52;width:33.333%;height:auto;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.ai-placeholder-mark{z-index:1;color:#0f172ab8;letter-spacing:.08em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:.62;white-space:nowrap;background:#ffffff6b;border-radius:10px;justify-content:center;align-items:center;min-width:84px;min-height:34px;padding:0 12px;font-size:15px;font-weight:700;display:inline-flex;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.ai-mode-switch{border-radius:var(--surface-radius-md);background:#f3f4f6eb;border:1px solid #0f172a14;flex:0 380px;grid-template-columns:repeat(4,minmax(72px,1fr));gap:0;min-width:0;padding:4px;display:grid;overflow-x:auto;box-shadow:inset 0 1px #ffffffbd}.ai-mode-switch button{color:#374151e6;min-width:72px;font:inherit;white-space:nowrap;cursor:pointer;background:0 0;border:0;border-radius:9px;padding:7px 10px;font-size:11px;font-weight:700;line-height:1}.ai-mode-switch button.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);box-shadow:0 10px 20px #0074f038}.progress-block{background:0 0;border:0;border-radius:0;gap:9px;margin-top:10px;padding:10px 2px 0;display:grid}.progress-meta{justify-content:space-between;align-items:center;gap:12px;display:flex}.progress-meta strong{color:var(--text-strong);font-size:16px}.progress-track{background:linear-gradient(90deg,#b3d1ff70,#dfecffe0);border-radius:999px;height:8px;position:relative;overflow:hidden;box-shadow:inset 0 1px 2px #3d60a814}.progress-fill{border-radius:inherit;background:linear-gradient(90deg,#7bb6ff 0%,#0d6de6 100%);height:100%;transition:width .26s;position:relative}.progress-fill:after{content:"";background:linear-gradient(90deg,#0000,#ffffff6b,#0000);animation:2.2s linear infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}.progress-fill.is-running{box-shadow:0 0 24px #3e74d838}.ai-save-hint{color:var(--text-soft);margin:0;font-size:12px}.ai-save-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.ai-save-button{width:auto;min-width:106px;min-height:32px;box-shadow:none;background:#ffffffc2;border-radius:10px;flex:none;padding:0 12px;font-size:12px}.ai-menu-layer{z-index:20;position:fixed;inset:0}.ai-menu{border-radius:var(--surface-radius-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff0;border:1px solid #0f172a14;min-width:160px;padding:8px;position:fixed;transform:translate(12px,12px);box-shadow:0 20px 40px #0f172a24}.ai-menu button{text-align:left;width:100%;color:var(--text-strong);cursor:pointer;background:0 0;border:0;border-radius:12px;padding:10px 12px}.ai-menu button:hover{background:#f1f5f9eb}.preset-row{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;display:grid}.preset-row span{color:#6b5140;white-space:nowrap;font-size:10px;line-height:1}.preset-actions{scrollbar-width:none;flex-wrap:nowrap;gap:4px;display:flex;overflow-x:auto}.preset-actions button{color:#374151e6;cursor:pointer;background:#f8fafcf0;border:1px solid #0f172a1a;border-radius:7px;min-width:38px;height:24px;font-size:10px;font-weight:700;position:relative}.preset-actions button.is-recommended{overflow:visible}.preset-crown{filter:drop-shadow(0 1px 2px #0f172a2e);pointer-events:none;font-size:11px;line-height:1;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.preset-actions button.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border-color:#0074f0e0}.pattern-stage canvas{aspect-ratio:auto;width:auto;max-width:none;height:auto;image-rendering:pixelated;background:#fff}.pattern-edit-overlay{pointer-events:none;background:0 0!important}.source-switch{border-radius:var(--surface-radius-md);background:#f3f4f6eb;border:1px solid #0f172a14;flex-wrap:nowrap;gap:6px;padding:4px;display:inline-flex;box-shadow:inset 0 1px #ffffffbd}.source-switch button{color:#374151e6;min-width:0;font:inherit;white-space:nowrap;cursor:pointer;background:0 0;border:0;border-radius:10px;padding:6px 8px;font-size:11px;font-weight:700;line-height:1}.source-switch-pattern{transform:translateY(2px)}.source-switch button.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);box-shadow:0 10px 24px #0074f038}.zoom-row,.zoom-actions,.checkbox-row,.stats-color{align-items:center;display:flex}.zoom-row,.checkbox-row{justify-content:space-between}.checkbox-row-compact{justify-content:flex-start;gap:8px}.checkbox-row-emphasis{background:#fffffff5;border:1px solid #0f172a14;border-radius:8px;min-height:30px;padding:0 10px}.edit-tools-row{flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:8px;display:flex;overflow-x:auto}.checkbox-icon{font-size:13px;line-height:1}.zoom-actions{gap:6px}.zoom-actions button{width:24px;height:24px;color:var(--text-strong);background:#f8fafcf0;border:1px solid #0f172a14;border-radius:8px}.zoom-actions strong{text-align:center;min-width:30px;color:var(--text-strong);font-size:10px;line-height:1}.zoom-slider{width:100%;accent-color:var(--accent-mint)}.pattern-toolbar-panel-zoom .zoom-slider{margin-top:0}.edit-panel{border-radius:var(--surface-radius-sm);background:linear-gradient(#fafcfffa,#f4f7fbf2);border:1px solid #0f172a0f;gap:8px;padding:8px;display:grid;box-shadow:inset 0 1px #ffffffb8,0 1px 2px #0f172a08}.edit-panel-sidebar{z-index:3;align-content:start;gap:0;width:184px;min-width:0;max-height:calc(100% - 24px);padding:0;position:absolute;top:12px;overflow:hidden auto}.edit-panel-header{flex-wrap:nowrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.edit-panel-header strong{color:var(--text-strong);white-space:nowrap;letter-spacing:.02em;flex:none;font-size:11px;line-height:1}.edit-panel-header span{color:var(--text-soft);white-space:nowrap;text-align:right;flex:auto;min-width:0;font-size:10px;line-height:1}.edit-panel-drag-handle{cursor:grab;background:#2a313c94;border:0;width:100%;min-height:30px;padding:0 8px}.edit-panel-drag-handle:active{cursor:grabbing}.edit-panel-actions{border-bottom:1px solid #ffffff1f;justify-content:flex-start;align-items:center;gap:6px;padding:6px;display:flex}.edit-mini-button{min-height:28px;color:var(--text-soft);background:#f8fafcf0;border:1px solid #0f172a14;border-radius:8px;width:auto;padding:0 8px;font-size:10px;font-weight:700}.edit-mini-button:disabled{opacity:.45;cursor:default}.edit-tool-button{white-space:nowrap;width:auto;min-height:30px;color:var(--text-strong);background:#ffffffe6;border:1px solid #0f172a14;border-radius:8px;flex:none;justify-content:flex-start;align-items:center;gap:6px;padding:0 10px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.pattern-toolbar-tool{box-shadow:none;background:#ffffffe6;border-radius:8px;min-height:30px;font-size:11px}.pattern-toolbar-primary .pattern-toolbar-tool{min-height:28px;box-shadow:none;color:#1f2937f0;background:0 0;border-color:#0000;border-radius:7px;padding:0 10px}.pattern-toolbar-tool-toggle{justify-content:flex-start;gap:8px}.pattern-toolbar-tool-label{white-space:nowrap;flex:none;display:inline-block;color:#111827f5!important;opacity:1!important;visibility:visible!important}.pattern-toolbar-tool-toggle input{accent-color:#0a84ff;flex:none;width:13px;height:13px;margin:0}.pattern-toolbar-primary .pattern-toolbar-tool:hover:not(:disabled){box-shadow:none;background:#ffffffd1;border-color:#0f172a14;transform:none}.edit-panel-sidebar{background:linear-gradient(#586270f5,#444d5bfa);border:1px solid #1f293761;border-radius:6px;box-shadow:0 12px 30px #0f172a2e}.edit-panel-sidebar .edit-panel-header{border-bottom:1px solid #ffffff24}.edit-panel-sidebar .edit-panel-header strong,.edit-panel-sidebar .edit-section-title,.edit-panel-sidebar .edit-empty-state{color:#fffffff5}.edit-panel-sidebar .edit-panel-header span{color:#ffffffb8}.edit-panel-sidebar .edit-mini-button,.edit-panel-sidebar .edit-more-toggle{color:#fffffff5;background:#ffffff1a;border-color:#ffffff2e}.pattern-toolbar-tool.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border-color:#0074f0eb;box-shadow:0 8px 18px #0074f02e}.pattern-toolbar-primary .pattern-toolbar-tool.is-active{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);border-color:#0074f0eb;box-shadow:0 6px 14px #0074f02e}.pattern-toolbar-tool-toggle.is-active,.pattern-toolbar-primary .pattern-toolbar-tool-toggle.is-active{color:#111827f5;box-shadow:none;background:#0a84ff14;border-color:#0a84ff38}.pattern-toolbar-tool.is-active .checkbox-icon{color:inherit}.pattern-toolbar-tool.is-active .pattern-toolbar-tool-label{color:#111827f5!important;opacity:1!important}.edit-color-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid}.edit-color-grid-vertical{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.edit-color-option{color:var(--text-strong);cursor:pointer;background:#ffffffeb;border:1px solid #0f172a1a;border-radius:14px;justify-items:center;gap:6px;padding:10px 6px;display:grid}.edit-panel-sidebar .edit-color-option{background:#ffffff14;border-color:#ffffff29;border-radius:4px;gap:4px;padding:5px 2px}.edit-panel-sidebar .edit-color-option strong{font-size:10px}.edit-panel-sidebar .color-chip-square{width:16px;height:16px}.edit-more-block{gap:8px;display:grid}.edit-more-toggle{border-radius:4px;min-height:26px;padding:0 8px;font-size:10px}.edit-color-grid-more{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.edit-empty-state{border-radius:var(--surface-radius-sm);color:var(--text-soft);text-align:center;background:#f8fafcd1;border:1px dashed #0f172a1a;padding:10px 8px;font-size:11px;line-height:1.35}.edit-section{gap:6px;display:grid}.edit-panel-sidebar .edit-section,.edit-panel-sidebar .edit-empty-state{border-top:1px solid #ffffff1a;margin:0;padding:8px 6px}.edit-panel-sidebar .edit-empty-state{background:#ffffff14;border-color:#ffffff29}.edit-section-title{color:#6c7682d6;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;font-size:10px;font-weight:700}.edit-color-option strong{font-size:12px;line-height:1}.edit-color-option.is-active{border-color:var(--accent-mint);box-shadow:0 0 0 2px #2d7c6624}.edit-color-option:hover{transform:translateY(-1px);box-shadow:0 10px 18px #0f172a14}@keyframes shimmer{to{transform:translate(100%)}}.checkbox-row input{width:18px;height:18px}.delivery-panel{grid-template-columns:minmax(300px,.75fr) minmax(0,1.25fr);align-items:start;gap:12px;margin-top:12px;display:grid}.summary-card,.stats-card{border-radius:var(--surface-radius-md);background:linear-gradient(180deg, #ffffffeb, #f8fafcd1), var(--panel-bg);box-shadow:none;padding:14px}.summary-metrics{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:10px;display:grid}.summary-metrics div{border-radius:var(--surface-radius-xs);background:#f8fafcad;border:1px solid #0f172a0d;padding:9px 10px}.summary-metrics strong{color:var(--text-strong);margin-top:6px;font-size:20px;line-height:1;display:block}.export-actions{grid-template-columns:minmax(0,1.3fr) minmax(0,.9fr);gap:10px;margin-top:14px;display:grid}.export-checkbox{justify-content:flex-start;gap:6px}.export-checkbox input{margin:0}.export-options{flex-wrap:wrap;align-items:center;gap:14px;margin-top:10px;display:flex}.export-options .checkbox-row span{color:#64748bdb;font-size:11px;line-height:1}.export-button{color:#fff;background:linear-gradient(#1b9bff 0%,#0074f0 100%);box-shadow:0 18px 34px #0074f038}.export-button-alt{color:#1f2937;background:#fffffff5;border:1px solid #0f172a1a;box-shadow:inset 0 1px #ffffffd1,0 1px 2px #0f172a0d}.primary-export-button{border:1px solid #0074f0e0}.stats-header{margin-bottom:10px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(88px,1fr));gap:6px;max-height:440px;padding-right:4px;display:grid;overflow:auto}.stats-tile{border-radius:var(--surface-radius-xs);background:#f8fafcb8;border:1px solid #0f172a0d;justify-content:space-between;align-items:center;gap:8px;padding:7px 9px;display:flex}.stats-color{gap:8px;min-width:0}.stats-color strong{color:var(--text-strong);white-space:nowrap;font-size:12px}.stats-tile span{color:var(--text-soft);white-space:nowrap;font-size:11px;font-weight:700}.color-chip{border:1px solid #583a2424;border-radius:999px;flex:none;width:20px;height:20px}.color-chip-square{border-radius:6px}@media (width<=1100px){.preview-grid-double,.delivery-panel,.summary-metrics,.export-actions{grid-template-columns:1fr}.workspace-header,.card-header-inline{flex-direction:column;align-items:stretch}.card-header-actions{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto}.pattern-toolbar-secondary{grid-template-columns:1fr}.pattern-toolbar-panel{padding:12px 14px}.pattern-toolbar-panel+.pattern-toolbar-panel{border-top:1px solid #0f172a14;border-left:0}.pattern-stage.has-sidepanel{padding-right:12px}}@media (width<=760px){.app-shell{width:min(100% - 20px,1380px);padding-top:0}.top-auth-bar{flex-wrap:wrap;row-gap:8px}.store-branding-float-wrap{margin-bottom:0;top:0}.store-branding-card{min-height:var(--store-banner-height-mobile)}.store-branding-card.is-compact{min-height:104px}.store-branding-card-overlay{padding:0 14px}.store-branding-card-text{font-size:18px}.store-branding-card.is-compact .store-branding-card-text{font-size:22px}.store-branding-color-grid{grid-template-columns:1fr}.store-branding-preview-header{flex-direction:column;align-items:flex-start}.points-popover-card{width:min(228px,100vw - 36px);right:0}.auth-inline-field{grid-template-columns:1fr}.auth-inline-button{width:100%}.pattern-stage{height:480px;min-height:480px}.pattern-tool-sidebar{width:138px}.pattern-tool-button{gap:5px;padding:0 8px;font-size:10px}.pattern-tool-sidebar-title{font-size:10px}.pattern-tool-mini-button{min-height:24px;padding:0 4px;font-size:9px}.pattern-stage.has-sidepanel{padding-right:12px}.edit-panel-sidebar{width:138px}.hero-panel h1,.hero-subtitle{white-space:normal}.hero-panel{grid-template-columns:1fr}.hero-actions{justify-content:stretch}.upload-button{width:100%;min-height:48px;font-size:16px}.workspace-panel,.summary-card,.stats-card,.preview-card{padding:14px}.hero-panel,.workspace-panel,.summary-card,.stats-card,.preview-card{border-radius:var(--surface-radius-md)}.control-row{grid-template-columns:1fr}.pattern-toolbar-primary{gap:6px;padding:6px}.pattern-toolbar-panel{padding:0}.pattern-toolbar-panel+.pattern-toolbar-panel{border-top:1px solid #0f172a14}.size-control-main{grid-template-columns:1fr}.size-extra-options{justify-content:flex-start}.status-strip{margin-top:6px}.status-inline-text{font-size:10px;line-height:1.35}.card-header-inline{gap:12px;min-height:0}.card-header-actions{gap:10px}.compact-button{width:100%;min-height:42px}.inline-upload-button{width:124px;min-height:36px;font-size:12px}.ai-mode-switch{grid-template-columns:repeat(4,minmax(72px,1fr));gap:0;width:100%;padding:4px}.ai-mode-switch button{min-width:72px;padding:7px 8px;font-size:11px}.progress-block{gap:9px;padding:10px 2px 0}.progress-meta strong{font-size:14px}.progress-track{height:8px}.edit-color-grid,.edit-color-grid-vertical{grid-template-columns:repeat(4,minmax(0,1fr))}.edit-tool-button{width:auto}.edit-tools-row{flex-wrap:wrap;overflow-x:visible}.ai-save-actions{flex-direction:column;align-items:stretch;gap:8px}.ai-save-button{width:100%;min-height:36px;font-size:13px}.ai-save-hint{font-size:11px}.source-switch{width:100%;padding:4px;overflow-x:auto}.pattern-source-bar{justify-content:flex-start}.source-switch-pattern{transform:none}.source-switch button{white-space:nowrap;min-width:0;padding:7px 8px;font-size:12px}.workspace-header-note{text-align:left;white-space:normal;max-width:100%;font-size:11px}.pattern-workbench.is-fullscreen{border-radius:var(--surface-radius-sm);padding:8px;inset:8px}}.admin-shell{color:#162033;background:radial-gradient(circle at 0 0,#3b82f61f,#0000 28%),radial-gradient(circle at 100% 0,#8b5cf61a,#0000 26%),linear-gradient(#f7f8fc 0%,#eff3fa 100%);min-height:100vh;padding:24px}.admin-shell.login-mode{justify-content:center;align-items:center;display:flex}.admin-loading-screen{color:#344054;background:#f4f6fb;justify-content:center;align-items:center;min-height:100vh;font-size:14px;display:flex}.admin-login-card,.admin-panel,.admin-metric-card,.admin-topbar{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffffe0;border:1px solid #0f172a14;border-radius:14px;box-shadow:0 20px 48px #0f172a14}.admin-login-card{width:min(460px,100%);padding:32px}.admin-login-header{margin-bottom:24px}.admin-kicker{color:#64748b;letter-spacing:.12em;margin:0 0 8px;font-size:12px;font-weight:700}.admin-login-header h1,.admin-topbar-copy h1{margin:0;font-size:clamp(28px,3.5vw,40px);line-height:1.05}.admin-login-header p,.admin-topbar-copy p,.admin-panel-header p{color:#5c687d;margin:10px 0 0;font-size:14px;line-height:1.5}.admin-login-form,.admin-point-form{gap:14px;display:grid}.admin-login-form label,.admin-point-form label{gap:8px;display:grid}.admin-login-form span,.admin-point-form span{color:#475467;font-size:13px;font-weight:600}.admin-login-form input,.admin-point-form input,.admin-search-row input{color:#162033;background:#fff;border:1px solid #94a3b866;border-radius:12px;outline:none;width:100%;min-width:0;padding:13px 14px;font-size:14px;transition:border-color .2s,box-shadow .2s}.admin-login-form input:focus,.admin-point-form input:focus,.admin-search-row input:focus{border-color:#3b82f6a8;box-shadow:0 0 0 4px #3b82f61f}.admin-primary-button,.admin-secondary-button,.admin-range-switch button,.admin-quick-row button{cursor:pointer;border:none;border-radius:12px;transition:transform .18s,box-shadow .18s,background .18s}.admin-primary-button{color:#fff;background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 100%);min-height:46px;font-size:14px;font-weight:700;box-shadow:0 14px 28px #2563eb42}.admin-primary-button:hover,.admin-secondary-button:hover,.admin-range-switch button:hover,.admin-quick-row button:hover,.admin-user-row:hover{transform:translateY(-1px)}.admin-primary-button:disabled,.admin-secondary-button:disabled{opacity:.64;cursor:wait;transform:none}.admin-secondary-button,.admin-range-switch button,.admin-quick-row button{color:#25304a;background:#eef2ff;min-height:40px;padding:0 14px;font-size:13px;font-weight:600}.admin-topbar{justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:20px;padding:24px;display:flex}.admin-topbar-copy{min-width:0}.admin-topbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.admin-inline-message{color:#1d4ed8;margin:0;font-size:13px;line-height:1.5}.admin-inline-message.is-error{color:#dc2626}.admin-metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:20px;display:grid}.admin-metric-card{padding:18px;position:relative;overflow:hidden}.admin-metric-card:after{content:"";background:#ffffff59;border-radius:22px;width:88px;height:88px;position:absolute;inset:auto -22px -18px auto;transform:rotate(24deg)}.admin-metric-card.tone-ink{background:linear-gradient(135deg,#fff 0%,#f5f7fb 100%)}.admin-metric-card.tone-blue{background:linear-gradient(135deg,#3b82f629 0%,#fffffff2 100%)}.admin-metric-card.tone-purple{background:linear-gradient(135deg,#8b5cf629 0%,#fffffff2 100%)}.admin-metric-card.tone-green{background:linear-gradient(135deg,#10b98129 0%,#fffffff2 100%)}.admin-metric-card.tone-amber{background:linear-gradient(135deg,#f59e0b29 0%,#fffffff2 100%)}.admin-metric-card.tone-pink{background:linear-gradient(135deg,#ec489924 0%,#fffffff2 100%)}.admin-metric-card.tone-cyan{background:linear-gradient(135deg,#06b6d424 0%,#fffffff2 100%)}.admin-metric-card.tone-orange{background:linear-gradient(135deg,#f9731624 0%,#fffffff2 100%)}.admin-metric-label{color:#60708a;margin:0 0 12px;font-size:13px}.admin-metric-value{z-index:1;font-size:clamp(28px,3vw,40px);line-height:1;position:relative}.admin-chart-grid,.admin-insight-grid,.admin-user-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-bottom:20px;display:grid}.admin-panel{padding:18px}.admin-panel-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.admin-panel-header h2{margin:0;font-size:19px}.admin-chart-title-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.admin-chart-filter{color:#60708a;align-items:center;gap:8px;font-size:12px;font-weight:600;display:inline-flex}.admin-chart-filter select{color:#1f2a44;background:#fff;border:1px solid #94a3b857;border-radius:10px;outline:none;min-width:86px;padding:8px 28px 8px 10px;font-size:13px;font-weight:600}.admin-chart-filter select:focus{border-color:#3b82f69e;box-shadow:0 0 0 4px #3b82f61a}.admin-chart-legend{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.admin-chart-legend span{color:#60708a;align-items:center;gap:6px;font-size:12px;display:inline-flex}.admin-chart-legend i{border-radius:999px;width:10px;height:10px}.admin-chart-shell{background:linear-gradient(#f8fafcf5 0%,#f1f5f9eb 100%);border-radius:16px;padding:8px;overflow:hidden}.admin-chart-svg{width:100%;height:auto;display:block}.admin-chart-axis-text{fill:#73839c;font-size:11px}.admin-mode-list,.admin-activity-list,.admin-mini-list,.admin-user-list{gap:10px;display:grid}.admin-mode-row,.admin-mini-row,.admin-selected-user-row{background:#f8fafc;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;min-width:0;padding:12px 14px;display:flex}.admin-mode-row span,.admin-mini-row span,.admin-activity-row span,.admin-selected-user-row span{color:#61708a;font-size:13px}.admin-mode-row strong,.admin-mini-row strong,.admin-selected-user-row strong{flex-shrink:0}.admin-activity-row{border-bottom:1px solid #94a3b829;justify-content:space-between;align-items:center;gap:16px;padding-bottom:10px;display:flex}.admin-activity-row:last-child{border-bottom:none;padding-bottom:0}.admin-activity-row div{gap:4px;min-width:0;display:grid}.admin-activity-row strong{font-size:14px;line-height:1.45}.admin-activity-row time{color:#72829b;flex-shrink:0;font-size:12px}.admin-empty-state{color:#72829b;margin:0;font-size:14px;line-height:1.6}.admin-search-row{grid-template-columns:1fr auto;gap:10px;margin-bottom:14px;display:grid}.admin-user-row{text-align:left;cursor:pointer;background:#f8fafc;border:1px solid #94a3b833;border-radius:14px;gap:8px;width:100%;padding:14px;transition:border-color .18s,background .18s,box-shadow .18s;display:grid}.admin-user-row.is-active{background:linear-gradient(#eff6ffeb 0%,#fffffff5 100%);border-color:#2563eb70;box-shadow:0 12px 28px #2563eb1f}.admin-user-row-main,.admin-user-row-points{justify-content:space-between;align-items:center;gap:10px;display:flex}.admin-user-row-main strong{font-size:15px}.admin-user-row-main span,.admin-user-row-points span{color:#61708a;font-size:12px}.admin-selected-user{gap:10px;margin-bottom:16px;display:grid}.admin-quick-row{flex-wrap:wrap;gap:10px;display:flex}.admin-quick-row button{padding:0 12px}@media (width<=1200px){.admin-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-chart-grid,.admin-insight-grid,.admin-user-grid{grid-template-columns:1fr}}@media (width<=760px){.admin-shell{padding:16px}.admin-topbar{flex-direction:column;align-items:stretch}.admin-topbar-actions{justify-content:flex-start}.admin-metrics-grid,.admin-search-row{grid-template-columns:1fr}.admin-activity-row,.admin-user-row-main,.admin-user-row-points,.admin-mini-row,.admin-selected-user-row{flex-direction:column;align-items:flex-start}}
