:root{--primary:#ff4f64;--secondary:#00a884;--bg:#d9d2bf;--card:#fff7df;--text:#1f1f1f;--muted:#635d4d;--border:#2a2824;--ink:#1e312c;--pixel-shadow:#2a2824}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Courier New,PingFang SC,Microsoft YaHei,monospace;background:var(--bg);background-image:linear-gradient(rgba(42,40,36,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(42,40,36,.08) 1px,transparent 1px);background-size:12px 12px;color:var(--text);line-height:1.45;overflow:hidden}body.project-body-scroll{overflow:auto}button,input,select{font:inherit}button{border:0}header{text-align:left;height:54px;padding:7px 16px;background:#1d2a25;color:#fff;display:flex;align-items:center;gap:12px;border-bottom:3px solid var(--border)}.brand-logo{display:inline-flex;align-items:center;gap:8px;position:relative;font-size:1.25em;margin-bottom:0;letter-spacing:.04em;white-space:nowrap;padding:4px 10px 4px 6px;background:#fff7df;color:#1d2a25;border:3px solid var(--border);box-shadow:4px 4px #ff4f64;text-shadow:2px 0 0 #ffd166}.logo-mark{position:relative;width:30px;height:30px;display:grid;grid-template-columns:repeat(2,12px);grid-template-rows:repeat(2,12px);gap:2px;flex:0 0 auto;padding:1px;background:#20342f;border:2px solid var(--border);box-shadow:2px 2px #ffd166}.logo-bead{width:12px;height:12px;border:2px solid var(--border);box-shadow:inset 2px 2px #ffffff73}.bead-a{background:#ff4f64}.bead-b{background:#ffd166}.bead-c{background:#00a884}.bead-d{background:#74c7f3}.logo-spark{position:absolute;right:-7px;top:-7px;width:8px;height:8px;background:#ffd166;border:2px solid var(--border);box-shadow:-10px 18px #ff4f64}.logo-word{line-height:1;font-weight:900}header p{opacity:.78;font-size:.9em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-link{margin-left:0;color:#1d2a25;background:#fff7df;border:3px solid var(--border);box-shadow:3px 3px 0 var(--primary);padding:5px 10px;text-decoration:none;font-size:.88em;font-weight:800;white-space:nowrap}header p+.header-link{margin-left:auto}.header-button{cursor:pointer}.header-link:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--primary)}.landing-header{justify-content:space-between}.landing-nav{display:flex;align-items:center;gap:8px;margin-left:auto}.landing-page{min-height:calc(100vh - 54px);max-width:1280px;margin:0 auto;padding:14px 14px 30px}.landing-hero{position:relative;min-height:560px;overflow:hidden;border:3px solid var(--border);background:#20342f;box-shadow:7px 7px 0 var(--pixel-shadow)}.landing-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,247,223,.08) 2px,transparent 2px),linear-gradient(90deg,rgba(255,247,223,.08) 2px,transparent 2px);background-size:26px 26px}.landing-hero:after{content:"";position:absolute;inset:auto 0 0 0;height:122px;background:#fff0c8;border-top:3px solid var(--border)}.hero-scene{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.bead-board{position:absolute;background:#fff7df;border:3px solid var(--border);box-shadow:6px 6px #111f1b;padding:10px}.bead-board-main{right:54px;top:44px;width:min(42vw,460px);transform:rotate(2deg)}.bead-board-source{right:410px;top:80px;width:150px;transform:rotate(-7deg);z-index:2}.bead-board-list{right:28px;bottom:34px;width:245px;display:grid;grid-template-columns:1fr;gap:6px;transform:rotate(-2deg);z-index:2}.bead-board-source>span,.bead-board-list>span{display:inline-flex;align-self:flex-start;margin-bottom:6px;padding:2px 6px;background:#ffd166;border:2px solid var(--border);font-size:.74em;font-weight:900;color:#1d2a25}.bead-board-list b{padding:5px 7px;background:#fff0c8;border:2px solid var(--border);font-size:.8em;color:var(--ink)}.sheet-top{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:8px;padding:5px 7px;background:#1d2a25;color:#fff;border:2px solid var(--border)}.sheet-top b{font-size:.8em}.sheet-top span{font-size:.68em;color:#fff0c8;font-weight:900;white-space:nowrap}.sheet-codes{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:8px}.sheet-codes span{padding:4px 2px;background:#fff0c8;border:2px solid var(--border);text-align:center;font-size:.68em;font-weight:900;color:var(--ink)}.hero-copy{position:relative;z-index:3;width:min(720px,66%);min-height:560px;display:flex;flex-direction:column;justify-content:center;padding:44px 38px 132px;color:#fff}.pixel-kicker{display:inline-flex;align-self:flex-start;padding:4px 8px;margin-bottom:16px;background:#ffd166;color:#1d2a25;border:2px solid var(--border);box-shadow:3px 3px #111f1b;font-size:.74em;font-weight:900;letter-spacing:.08em}.hero-copy h2{max-width:720px;font-size:clamp(2.35rem,6vw,5.2rem);line-height:.98;color:#fff7df;margin-bottom:18px;letter-spacing:0;text-shadow:5px 5px 0 #111f1b}.hero-copy>p{max-width:610px;color:#fff7df;font-size:1.04em;font-weight:900;line-height:1.7;text-shadow:2px 2px 0 #111f1b}.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}.hero-btn{min-height:44px;padding:9px 16px;text-decoration:none}.privacy-chip{align-self:flex-start;margin-top:18px;padding:6px 9px;background:#fff7df;border:2px solid var(--border);box-shadow:3px 3px #111f1b;color:var(--ink);font-size:.8em;font-weight:900}.landing-pattern{display:grid;grid-template-columns:repeat(6,1fr);gap:2px;width:100%;aspect-ratio:1;background:#1d2a25;border:3px solid var(--border);padding:5px;image-rendering:pixelated}.landing-pattern.dense{gap:3px;padding:7px}.landing-pattern span{border:1px solid rgba(29,42,37,.45)}.landing-band{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}.landing-band article,.landing-cta{background:#fff7df;border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow);padding:14px}.landing-band strong{display:inline-flex;margin-bottom:10px;padding:2px 7px;background:#ff4f64;color:#fff;border:2px solid var(--border);box-shadow:2px 2px 0 var(--pixel-shadow);font-size:.78em}.landing-band h3{font-size:1em;color:var(--ink);margin-bottom:7px}.landing-band p,.landing-cta p{font-size:.84em;color:var(--muted);font-weight:800;line-height:1.65}.landing-proof{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;align-items:center;margin-top:16px;padding:18px;background:#20342f;color:#fff7df;border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow)}.proof-label{display:inline-flex;margin-bottom:8px;padding:3px 7px;background:#ffd166;color:#1d2a25;border:2px solid var(--border);font-size:.72em;font-weight:900}.landing-proof h2{font-size:1.35em;line-height:1.25}.landing-proof p{font-size:.9em;font-weight:900;line-height:1.75;color:#fff0c8}.landing-cta{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:16px;background:#fff0c8}.landing-cta h2{font-size:1.25em;color:var(--ink);margin-bottom:5px}.container{height:calc(100vh - 54px);max-width:1720px;margin:0 auto;padding:10px 12px;display:grid;grid-template-columns:286px minmax(0,1fr) 330px;gap:10px;align-items:stretch;overflow:hidden}.setup-grid{grid-column:1;display:flex;flex-direction:column;gap:10px;max-height:100%;overflow:auto;padding-right:2px}.setup-grid .panel{margin-bottom:0}.setup-grid .controls{grid-template-columns:1fr}.setup-grid .btn-group{display:grid;grid-template-columns:1fr}.workspace{grid-column:2/4;min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:10px;align-items:stretch}.main-stage{min-width:0;min-height:0}.side-rail{display:flex;flex-direction:column;gap:10px;max-height:100%;overflow:auto;padding-right:2px}.panel{background:var(--card);border:3px solid var(--border);border-radius:0;padding:12px;margin-bottom:10px;box-shadow:4px 4px 0 var(--pixel-shadow)}.workspace .panel,.side-rail .panel{margin-bottom:0}.panel-title{font-size:.95em;font-weight:700;margin-bottom:9px;display:flex;align-items:center;gap:7px;color:var(--ink);line-height:1}.panel-title:before{content:"";width:8px;height:16px;background:var(--primary);border:2px solid var(--border);border-radius:0}.panel-note{margin:-4px 0 8px;color:var(--muted);font-size:.78em}.upload-area{display:block;border:3px dashed var(--border);border-radius:0;padding:18px 12px;text-align:center;transition:all .12s;cursor:pointer;background:#fff0c8}.upload-area:hover{background:#ffe1ad;transform:translate(-1px,-1px)}.upload-area input{display:none}.upload-icon{font-size:1.65em;margin-bottom:4px}.hint{color:#999;font-size:.84em;margin-top:4px}.upload-status{margin-top:8px;color:#666;font-size:.86em}.upload-status strong{color:var(--text)}.crop-open-btn{width:100%;margin-top:8px}.placeholder{display:flex;align-items:center;justify-content:center;min-height:96px;padding:12px;border:2px dashed var(--border);border-radius:0;background:#fff0c8;color:var(--muted);font-size:.9em;text-align:center}.preview-box .placeholder{min-height:150px}.placeholder.compact{min-height:64px}.project-save-row{display:grid;grid-template-columns:1fr;gap:7px}.project-current{padding:6px 8px;border:2px solid var(--border);background:#fff0c8;color:var(--muted);font-size:.78em;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-list{display:flex;flex-direction:column;gap:7px;margin-top:8px;max-height:220px;overflow:auto;padding:2px}.project-item{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:7px;align-items:center;padding:6px;background:#fff0c8;border:2px solid var(--border)}.project-item.active{outline:2px solid var(--primary);outline-offset:-4px;background:#ffe1ad}.project-thumb{width:48px;height:48px;border:2px solid var(--border);background:#fffdf2;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.project-thumb img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}.project-thumb span{font-size:.58em;color:var(--muted);font-weight:800}.project-meta{min-width:0;display:flex;flex-direction:column;gap:1px;text-align:left}.project-meta strong{font-size:.78em;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-meta span,.project-meta small{font-size:.68em;color:var(--muted);font-weight:800}.project-actions{display:grid;grid-template-columns:1fr;gap:4px}.project-actions .tool-btn{height:22px;min-width:28px;padding:0 5px;font-size:.68em}.project-actions .tool-btn.danger{background:#ff4f64;color:#fff}.palette-grid .placeholder,.edit-palette .placeholder{grid-column:1/-1}.controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:8px}.control-group{display:flex;flex-direction:column;gap:4px}.control-group span{font-size:.78em;color:var(--muted);font-weight:700}.control-group input,.control-group select{padding:7px 9px;border:2px solid var(--border);border-radius:0;font-size:.88em;transition:background .12s;background:#fffdf2;color:var(--text)}.control-group input:focus,.control-group select:focus{outline:2px solid var(--secondary);outline-offset:1px}.inline-check{display:flex;align-items:center;gap:8px;padding:7px 9px;border:2px solid var(--border);background:#fffdf2;font-size:.88em;font-weight:800;cursor:pointer}.inline-check input{width:16px;height:16px;accent-color:var(--secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:7px 12px;border:3px solid var(--border);border-radius:0;font-size:.88em;font-weight:800;cursor:pointer;transition:all .12s;min-height:34px;box-shadow:3px 3px 0 var(--pixel-shadow)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#ff7584;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--pixel-shadow)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#10c99f;transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--pixel-shadow)}.btn:disabled{opacity:.48;cursor:not-allowed;transform:none}.btn-group{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.action-bar{position:sticky;top:0;z-index:2;margin:0 0 10px;padding:6px;background:#fff0c8;border:3px solid var(--border);box-shadow:3px 3px 0 var(--pixel-shadow);display:grid;grid-template-columns:1fr}.action-bar .btn-primary{font-size:.98em;min-height:40px}.smart-toggle{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:8px;margin-bottom:7px;padding:6px 8px;background:#fff0c8;border:2px solid var(--border);box-shadow:2px 2px 0 var(--pixel-shadow);cursor:pointer}.smart-toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-track{position:relative;width:34px;height:18px;background:#d9d2bf;border:2px solid var(--border);box-shadow:1px 1px 0 var(--pixel-shadow)}.toggle-track:after{content:"";position:absolute;left:2px;top:2px;width:10px;height:10px;background:#fffdf2;border:2px solid var(--border);transition:transform .12s}.smart-toggle input:checked+.toggle-track{background:var(--secondary)}.smart-toggle input:checked+.toggle-track:after{transform:translate(14px)}.smart-copy{display:flex;align-items:baseline;justify-content:space-between;gap:8px;min-width:0}.smart-copy strong{font-size:.82em;color:var(--ink);white-space:nowrap}.smart-copy small{font-size:.68em;color:var(--muted);font-weight:800;white-space:nowrap}.quality-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:3px;margin:-2px 0 7px}.quality-strip span{padding:3px 2px;background:#fffdf2;border:2px solid var(--border);font-size:.64em;font-weight:800;text-align:center;color:var(--ink);white-space:nowrap}#resultPanel{height:100%;display:flex;flex-direction:column;min-height:0}.result-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}.result-head .panel-title{margin-bottom:0}.result-actions{display:flex;align-items:flex-start;justify-content:flex-end;gap:5px;position:relative;flex-wrap:wrap}.stage-action-btn,.save-project-btn{min-height:28px;padding:3px 8px;font-size:.74em;box-shadow:2px 2px 0 var(--pixel-shadow)}.recent-projects{position:relative}.recent-projects summary{list-style:none;min-height:28px;padding:3px 8px;border:3px solid var(--border);background:#fffdf2;color:var(--ink);box-shadow:2px 2px 0 var(--pixel-shadow);font-size:.74em;font-weight:800;cursor:pointer}.recent-projects summary::-webkit-details-marker{display:none}.recent-menu{position:absolute;right:0;top:38px;z-index:10;width:260px;padding:6px;background:#fff7df;border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow);display:flex;flex-direction:column;gap:5px}.recent-menu button{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:7px;padding:6px;border:2px solid var(--border);background:#fff0c8;cursor:pointer;text-align:left}.recent-menu button:hover{background:#ffe1ad}.recent-thumb{width:42px;height:42px;border:2px solid var(--border);background:#fffdf2;display:flex;align-items:center;justify-content:center;overflow:hidden;font-size:.62em;font-weight:800;color:var(--muted)}.recent-thumb img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}.recent-info{min-width:0;display:flex;flex-direction:column;gap:3px}.recent-info strong{max-width:100%;font-size:.78em;font-weight:800;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-info small,.recent-empty{font-size:.68em;color:var(--muted);font-weight:800}.preview-container{position:relative;margin-top:6px;min-height:0;flex:1;display:flex}.preview-box{background:#fff0c8;border:3px solid var(--border);border-radius:0;padding:8px;text-align:center;overflow:hidden}.preview-box h3{font-size:.8em;color:var(--muted);margin-bottom:6px}.preview-box canvas{max-width:100%;border-radius:0;image-rendering:pixelated;box-shadow:3px 3px 0 var(--pixel-shadow)}.pattern-preview{flex:1;min-height:0;padding:8px;display:flex;flex-direction:column}.original-preview{position:fixed;z-index:12;background:#fff7df;box-shadow:4px 4px 0 var(--pixel-shadow);display:grid;grid-template-rows:28px minmax(0,1fr);gap:0;min-width:120px;min-height:120px;max-width:520px;max-height:520px;-webkit-user-select:none;user-select:none;padding:0;text-align:center}.original-preview h3{display:flex;align-items:center;justify-content:center;font-size:.74em;margin-bottom:0;padding:3px 22px 3px 6px;background:#20342f;color:#fff;cursor:move;border-bottom:2px solid var(--border);min-height:28px}.original-preview .placeholder{min-height:0;flex:1;font-size:.72em;padding:6px}.original-canvas-wrap{min-height:0;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:6px;background:#fff0c8}.original-canvas-wrap canvas{position:static;display:block;max-width:100%;max-height:100%;object-fit:contain;box-shadow:none}.resize-handle{position:absolute;right:-3px;bottom:-3px;width:18px;height:18px;border:3px solid var(--border);background:var(--primary);cursor:nwse-resize;box-shadow:2px 2px 0 var(--pixel-shadow)}.resize-handle:before{content:"";position:absolute;right:3px;bottom:3px;width:5px;height:5px;background:#fff7df;box-shadow:-6px 0 #fff7df,0 -6px #fff7df}.pattern-toolbar{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-bottom:4px}.tool-btn{border:2px solid var(--border);background:#fffdf2;color:var(--ink);border-radius:0;height:24px;min-width:26px;padding:0 6px;font-size:.78em;font-weight:800;cursor:pointer;box-shadow:1px 1px 0 var(--pixel-shadow)}.tool-btn:hover{border-color:var(--secondary);color:var(--secondary)}.tool-btn.active{background:#ffd166}.pattern-viewport{position:relative;flex:1;min-height:0;overflow:hidden;border-radius:0;background:#d7ccb4;background-image:linear-gradient(45deg,rgba(42,40,36,.12) 25%,transparent 25%),linear-gradient(-45deg,rgba(42,40,36,.12) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(42,40,36,.12) 75%),linear-gradient(-45deg,transparent 75%,rgba(42,40,36,.12) 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;cursor:grab;touch-action:none}.pattern-viewport.dragging{cursor:grabbing}.pattern-viewport canvas{position:absolute;left:0;top:0;max-width:none;transform-origin:0 0;image-rendering:pixelated;box-shadow:4px 4px 0 var(--pixel-shadow)}.range-box{position:absolute;z-index:5;border:2px dashed #ffd166;background:#ffd1662e;pointer-events:none}.range-box.remove{border-color:#ff4f64;background:#ff4f6429}.stats{display:flex;align-items:center;gap:4px;margin-bottom:4px;min-height:24px}.stat-card{display:flex;align-items:baseline;justify-content:center;gap:4px;background:#20342f;color:#fff;padding:3px 6px;border:2px solid var(--border);border-radius:0;text-align:center;box-shadow:1px 1px 0 var(--pixel-shadow);min-width:0;flex:1}.stat-card .number{font-size:.88em;font-weight:800;line-height:1}.stat-card .label{font-size:.64em;opacity:.88;white-space:nowrap;line-height:1}.palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(46px,1fr));gap:5px;margin-top:8px;max-height:140px;overflow-y:auto;padding:6px;background:#fff0c8;border:2px solid var(--border);border-radius:0}.palette-item{display:flex;flex-direction:column;align-items:center;padding:4px;border-radius:0;cursor:pointer;transition:all .12s;border:2px solid var(--border);background:#fffdf2}.palette-item:hover{background:#ffe1ad;transform:translate(-1px,-1px)}.palette-item.excluded{opacity:.3;border-color:#f44;text-decoration:line-through}.palette-swatch{width:24px;height:24px;border-radius:0;border:2px solid var(--border);margin-bottom:2px}.palette-code{font-size:.75em;font-weight:600;color:#333}.palette-count{font-size:.7em;color:#999}.edit-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch;margin-bottom:8px}.edit-status{grid-column:1/-1;padding:9px 10px;background:#fff0c8;border:2px solid var(--border);border-radius:0;color:#555;min-height:40px;font-size:.84em}.edit-mode-switch{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}.edit-mode-switch button{min-height:28px;border:2px solid var(--border);background:#fffdf2;color:var(--ink);font-size:.78em;font-weight:900;cursor:pointer;box-shadow:1px 1px 0 var(--pixel-shadow)}.edit-mode-switch button.active{background:#ffd166}.edit-mode-switch button:disabled{opacity:.45;cursor:not-allowed}.candidate-strip{display:grid;grid-template-columns:auto repeat(4,minmax(0,1fr));gap:5px;align-items:center;margin-bottom:8px;padding:6px;background:#fff0c8;border:2px solid var(--border)}.candidate-strip>span{font-size:.76em;font-weight:900;color:var(--muted)}.candidate-strip button{display:flex;align-items:center;justify-content:center;gap:4px;min-height:26px;border:2px solid var(--border);background:#fffdf2;color:var(--ink);font-size:.72em;font-weight:900;cursor:pointer}.candidate-strip button span{width:14px;height:14px;border:2px solid var(--border)}.edit-palette{display:grid;grid-template-columns:repeat(auto-fill,minmax(54px,1fr));gap:5px;max-height:45vh;overflow-y:auto;padding:6px;background:#fff0c8;border:2px solid var(--border);border-radius:0}.edit-color{display:flex;align-items:center;justify-content:center;gap:4px;padding:5px 4px;border:2px solid var(--border);border-radius:0;background:#fffdf2;cursor:pointer;transition:all .12s}.edit-color:hover{border-color:var(--secondary);transform:translate(-1px,-1px)}.edit-color.active{border-color:var(--primary);box-shadow:0 0 0 2px #ff6b6b26}.edit-color .swatch{width:18px;height:18px;border-radius:0;border:2px solid var(--border);flex:0 0 auto}.edit-color .code{font-size:.78em;font-weight:800;line-height:1}.loading{position:absolute;top:0;right:0;bottom:0;left:0;z-index:6;display:none;align-items:center;justify-content:center;background:#d9d2bfb8;text-align:center;border-radius:0}.loading.active{display:flex}.loading p{padding:10px 14px;background:#fff7df;border:3px solid var(--border);border-radius:0;color:var(--ink);font-weight:800;box-shadow:4px 4px 0 var(--pixel-shadow)}.spinner{width:24px;height:24px;border:4px solid #fff7df;border-top:4px solid var(--primary);border-radius:0;animation:spin 1s steps(8) infinite;margin:0 auto 8px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hidden{display:none!important}.color-page{height:calc(100vh - 54px);overflow:auto;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:12px;max-width:1720px;margin:0 auto}.chart-panel{background:var(--card);border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow);padding:12px;min-width:0}.chart-heading{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:10px;border-bottom:3px solid var(--border);padding-bottom:8px}.chart-heading h2{font-size:1.05em;color:var(--ink)}.chart-heading p{font-size:.78em;color:var(--muted);font-weight:800;text-align:right}.chart-groups{display:flex;flex-direction:column;gap:10px}.chart-group{background:#fff0c8;border:2px solid var(--border);padding:8px}.chart-group h3{font-size:.88em;margin-bottom:7px;display:flex;justify-content:space-between;color:var(--ink)}.chart-group h3 span{background:#1d2a25;color:#fff;padding:0 6px;border:2px solid var(--border)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:6px}.color-card{background:#fffdf2;border:2px solid var(--border);padding:5px;display:grid;grid-template-columns:22px 1fr;grid-template-areas:"chip code" "chip hex";align-items:center;gap:1px 5px;min-width:0}.color-card.transparent{background-image:linear-gradient(45deg,rgba(42,40,36,.12) 25%,transparent 25%),linear-gradient(-45deg,rgba(42,40,36,.12) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(42,40,36,.12) 75%),linear-gradient(-45deg,transparent 75%,rgba(42,40,36,.12) 75%);background-size:10px 10px;background-position:0 0,0 5px,5px -5px,-5px 0}.color-chip{grid-area:chip;width:22px;height:22px;border:2px solid var(--border)}.color-card strong{grid-area:code;font-size:.82em;line-height:1}.color-card small{grid-area:hex;font-size:.62em;color:var(--muted);white-space:nowrap}.crop-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:flex;align-items:center;justify-content:center;padding:18px;background:#1d2a25b8}.crop-dialog{width:min(840px,100%);max-height:calc(100vh - 36px);display:flex;flex-direction:column;gap:10px;background:var(--card);border:3px solid var(--border);box-shadow:6px 6px 0 var(--pixel-shadow);padding:12px}.crop-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.crop-header div{display:flex;align-items:center;gap:10px;font-weight:800;color:var(--ink)}.crop-header span{padding:3px 7px;background:#fff0c8;border:2px solid var(--border);font-size:.78em;color:var(--muted)}.crop-aspects{display:flex;gap:6px;flex-wrap:wrap}.crop-aspects button{padding:5px 8px;border:2px solid var(--border);background:#fffdf2;color:var(--ink);font-size:.78em;font-weight:800;cursor:pointer;box-shadow:2px 2px 0 var(--pixel-shadow)}.crop-aspects button.active{background:var(--primary);color:#fff}.crop-canvas{max-width:100%;height:auto;align-self:center;background:#fff0c8;border:3px solid var(--border);image-rendering:pixelated;touch-action:none;cursor:crosshair}.crop-actions{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:8px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:16px;background:#1d2a25b8}.name-dialog{width:min(380px,100%);padding:14px;background:var(--card);border:3px solid var(--border);box-shadow:6px 6px 0 var(--pixel-shadow)}.dialog-title{font-size:1em;font-weight:800;color:var(--ink);margin-bottom:10px}.dialog-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.toast-stack{position:fixed;right:18px;bottom:18px;z-index:45;width:min(360px,calc(100vw - 32px));pointer-events:none}.toast-notice{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:start;padding:10px 10px 10px 12px;background:#fff7df;border:3px solid var(--border);box-shadow:5px 5px 0 var(--pixel-shadow);pointer-events:auto}.toast-notice strong{display:block;margin-bottom:4px;color:var(--ink);font-size:.9em;font-weight:900}.toast-notice p{color:var(--muted);font-size:.78em;font-weight:800;line-height:1.45}.toast-notice button{width:24px;height:24px;border:2px solid var(--border);background:#fffdf2;color:var(--ink);font-size:.78em;font-weight:900;line-height:1;cursor:pointer;box-shadow:1px 1px 0 var(--pixel-shadow)}.toast-notice.success{background:#dcffe9}.toast-notice.warn{background:#fff0c8}.guide-dialog{width:min(820px,calc(100vw - 32px));max-height:calc(100vh - 40px);display:flex;flex-direction:column;background:var(--card);border:3px solid var(--border);box-shadow:6px 6px 0 var(--pixel-shadow)}.guide-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px;border-bottom:3px solid var(--border);background:#fff0c8}.guide-head h2{font-size:1.2em;color:var(--ink);margin-bottom:4px}.guide-head p{font-size:.82em;color:var(--muted);font-weight:800}.guide-body{overflow:auto;padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.guide-section{background:#fff0c8;border:2px solid var(--border);padding:10px}.guide-section h3{font-size:.95em;color:var(--ink);margin-bottom:8px}.guide-item{padding:8px 0;border-top:2px dashed rgba(42,40,36,.25)}.guide-item:first-of-type{border-top:0}.guide-item strong{display:inline-block;background:#ffd166;border:2px solid var(--border);padding:1px 5px;margin-bottom:5px;color:#1d2a25;font-size:.78em}.guide-item p{font-size:.8em;color:var(--muted);font-weight:800;line-height:1.55}.project-page{min-height:calc(100vh - 54px);padding:14px;max-width:1180px;margin:0 auto}.project-page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;padding:12px;background:var(--card);border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow)}.project-page-head h2{font-size:1.15em;color:var(--ink)}.project-page-head p{font-size:.82em;color:var(--muted);font-weight:800;margin-top:3px}.import-btn{position:relative;overflow:hidden}.import-btn input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.project-table{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;align-items:stretch}.project-table .placeholder{grid-column:1/-1}.project-row{display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:9px;padding:9px;background:var(--card);border:3px solid var(--border);box-shadow:4px 4px 0 var(--pixel-shadow);min-width:0}.project-row-thumb{width:100%;aspect-ratio:1.25;border:2px solid var(--border);background:#fffdf2;display:flex;align-items:center;justify-content:center;overflow:hidden;color:var(--muted);font-size:.76em;font-weight:800;text-decoration:none}.project-row-thumb img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}.project-row-main{min-width:0;display:flex;flex-direction:column;gap:6px}.project-row-main strong{font-size:.98em;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-row-main span{font-size:.76em;color:var(--muted);font-weight:800}.project-card-meta{display:flex;gap:5px;flex-wrap:wrap}.project-card-meta span{display:inline-flex;align-items:center;min-height:22px;padding:2px 6px;background:#fff0c8;border:2px solid var(--border);color:var(--ink);font-size:.72em;box-shadow:1px 1px 0 var(--pixel-shadow)}.project-row-actions{display:grid;grid-template-columns:1fr 1fr;gap:7px}.project-row-actions .btn{text-decoration:none;min-height:30px;padding:5px 7px;font-size:.76em}.danger-btn{background:#ff4f64;color:#fff}@media (max-width:1280px){.container{grid-template-columns:260px minmax(0,1fr)}.workspace{grid-column:2;grid-template-columns:1fr}.side-rail{max-height:none;overflow:auto}}@media (max-width:900px){body{overflow:auto}.container{height:auto;display:block;overflow:visible}.setup-grid{max-height:none;overflow:visible;margin-bottom:10px}.workspace{display:block}.preview-container{height:60vh;min-height:360px}.pattern-preview{min-height:0}.pattern-preview canvas{max-width:none}.color-page{height:auto;grid-template-columns:1fr}.chart-heading{display:block}.chart-heading p{text-align:left;margin-top:4px}.header-link{margin-left:0;display:inline-flex;margin-top:8px}.crop-modal{align-items:flex-start;overflow:auto}.crop-actions{grid-template-columns:1fr}.project-table{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.guide-body{grid-template-columns:1fr}.landing-hero{min-height:720px}.hero-copy{width:100%;min-height:430px;padding:30px 24px 110px}.bead-board-main{left:24px;right:auto;top:390px;width:min(420px,calc(100% - 48px))}.bead-board-source{display:none}.bead-board-list{right:24px;bottom:26px;width:210px}.landing-band,.landing-proof{grid-template-columns:1fr}.landing-cta{display:block}.landing-cta .btn{margin-top:12px}}@media (max-width:600px){.container{padding:8px}header{height:auto;padding:8px 10px;display:block}.brand-logo{font-size:1.2em}.landing-nav{display:flex;flex-wrap:wrap;margin-left:0}.landing-page{padding:10px 8px 22px}.landing-hero{min-height:660px}.hero-copy{padding:22px 16px 104px}.hero-copy h2{font-size:2.25rem}.hero-copy>p{font-size:.92em}.hero-actions{display:grid;grid-template-columns:1fr}.bead-board-main{top:380px}.bead-board-list{display:none}.sheet-codes{grid-template-columns:repeat(2,1fr)}.controls{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}.edit-toolbar{grid-template-columns:1fr}.preview-box{padding:8px}.result-head{display:block}.result-actions{margin-top:8px}.recent-menu{right:auto;left:0}}
