:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;--bg: #f4f7f8;--surface: #ffffff;--surface-soft: #f8fafb;--line: #dfe7eb;--line-strong: #cbd6dc;--text: #172026;--muted: #687580;--muted-2: #8b97a1;--teal: #079985;--teal-dark: #047a6e;--teal-soft: #e5f6f3;--coral: #f6657d;--yellow: #ffd338;--navy: #26324d;--shadow: 0 18px 40px rgba(33, 51, 63, .08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;margin:0;background:var(--bg);color:var(--text)}button,input,select{font:inherit}button{border:0}.app{min-height:100vh;background:linear-gradient(180deg,#ffffffeb 0,#f4f7f800 170px),var(--bg)}.app-header{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:minmax(240px,1fr) auto minmax(260px,1fr);align-items:center;min-height:66px;padding:0 24px;background:#fffffff0;border-bottom:1px solid var(--line);box-shadow:0 8px 24px #1720260a;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand{display:inline-flex;align-items:center;width:fit-content;gap:12px;color:var(--text);font-size:24px;font-weight:700;letter-spacing:0;text-decoration:none}.brand strong{color:var(--teal)}.brand-mark{display:grid;grid-template-columns:repeat(4,8px);gap:4px;padding:2px}.brand-mark span{width:8px;height:8px;border-radius:50%;background:var(--teal);box-shadow:inset 0 0 0 1px #17202633}.brand-mark span:nth-child(4n+1){background:var(--coral)}.brand-mark span:nth-child(5n+2){background:var(--yellow)}.brand-mark span:nth-child(3n){background:#71c8f3}.main-nav,.header-actions{display:flex;align-items:center;gap:18px}.main-nav a,.header-actions button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;color:var(--text);font-size:15px;font-weight:700;text-decoration:none;white-space:nowrap}.main-nav a{padding:0 10px}.main-nav a.active{color:var(--teal)}.main-nav a.active:after{position:absolute;right:0;bottom:-14px;left:0;height:3px;content:"";background:var(--teal);border-radius:99px}.header-actions{justify-content:flex-end;gap:12px}.header-actions button{padding:0 6px;background:transparent;cursor:pointer}.language-select{display:inline-flex;align-items:center;gap:7px;min-height:38px;color:var(--text);font-size:15px;font-weight:700}.language-select select{width:auto;min-width:104px;height:34px;padding:0 8px;border:0;background:transparent;cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.header-actions .settings-button{width:38px;padding:0}.header-grid-icon{color:var(--muted-2)}.studio-layout{display:grid;grid-template-columns:340px minmax(560px,1fr) 300px;min-height:calc(100vh - 66px)}.control-panel,.inspector{background:#fffffff5}.control-panel{display:flex;flex-direction:column;gap:22px;padding:22px 24px 24px;border-right:1px solid var(--line)}.panel-section h2,.gallery-title h2,.inspector h2{margin:0 0 14px;font-size:15px;line-height:1.3;letter-spacing:0}.upload-box{display:grid;grid-template-columns:88px 1fr;align-items:center;min-height:114px;gap:18px;padding:14px;border:1px dashed var(--line-strong);border-radius:8px;background:var(--surface-soft);cursor:pointer}.upload-box input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.upload-box strong,.upload-box small{display:block}.upload-box strong{max-width:155px;overflow:hidden;font-size:15px;line-height:1.35;text-overflow:ellipsis;white-space:nowrap}.upload-box small{margin-top:9px;color:var(--muted);font-size:12px;line-height:1.45}.upload-preview{display:grid;place-items:center;width:88px;height:88px;color:var(--teal);background:radial-gradient(circle at 45% 45%,rgba(255,211,56,.38) 0 18%,transparent 19%),radial-gradient(circle at 56% 58%,rgba(246,101,125,.36) 0 22%,transparent 23%),#fff;border:1px solid var(--line);border-radius:8px;box-shadow:inset 0 0 0 6px #0799850d}.input-row,.range-row,.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px}.input-row+.input-row{margin-top:10px}.icon-label,.range-row span{display:inline-flex;align-items:center;min-width:112px;gap:8px;color:var(--muted);font-size:13px;font-weight:700}select,.range-row output{height:38px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:7px}select{width:118px;padding:0 12px;font-size:14px;font-weight:700}.icon-only{display:grid;place-items:center;width:38px;height:38px;color:var(--teal);background:var(--surface);border:1px solid var(--line);border-radius:7px;cursor:pointer}.range-row output{display:grid;place-items:center;min-width:58px;padding:0 8px;font-size:13px;font-weight:800}input[type=range]{width:100%;height:5px;margin:16px 0;appearance:none;background:linear-gradient(90deg,var(--teal),#74c9bf);border-radius:99px}input[type=range]::-webkit-slider-thumb{width:18px;height:18px;appearance:none;background:var(--teal);border:3px solid #ffffff;border-radius:50%;box-shadow:0 3px 8px #07998559}.toggle-row{align-items:center}.toggle-row span{display:grid;gap:4px}.toggle-row strong{font-size:14px}.toggle-row small{color:var(--muted);font-size:12px}.toggle-row input{position:relative;width:44px;height:26px;flex:0 0 auto;appearance:none;background:#cfd9df;border-radius:999px;cursor:pointer;transition:background .16s ease}.toggle-row input:after{position:absolute;top:3px;left:3px;width:20px;height:20px;content:"";background:#fff;border-radius:50%;box-shadow:0 2px 7px #17202633;transition:transform .16s ease}.toggle-row input:checked{background:var(--teal)}.toggle-row input:checked:after{transform:translate(18px)}.export-section{display:grid;gap:12px;margin-top:auto}.primary-action,.export-grid button,.reset-button{display:inline-flex;align-items:center;justify-content:center;min-height:44px;gap:9px;border-radius:7px;cursor:pointer}.primary-action{color:#fff;font-size:15px;font-weight:800;background:linear-gradient(135deg,var(--teal),var(--teal-dark));box-shadow:0 13px 24px #07998538}.export-grid,.project-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.export-grid button,.reset-button{color:var(--text);font-size:13px;font-weight:800;background:#fff;border:1px solid var(--line)}.project-grid{gap:10px}.primary-action:disabled,.export-grid button:disabled{cursor:not-allowed;opacity:.55}.bead-total{display:flex;align-items:center;justify-content:center;gap:7px;margin:0;color:var(--muted);font-size:12px;font-weight:800}.workspace{display:grid;grid-template-columns:minmax(0,1fr);grid-template-rows:auto minmax(420px,1fr) auto;min-width:0;padding:20px;background:linear-gradient(90deg,rgba(223,231,235,.75) 1px,transparent 1px),linear-gradient(0deg,rgba(223,231,235,.55) 1px,transparent 1px),#f6f8f9;background-size:28px 28px}.canvas-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;width:100%;min-width:0;min-height:62px;margin-bottom:12px}.tool-group{display:flex;align-items:center;gap:8px;min-width:0;max-width:100%;padding:7px;background:#ffffffeb;border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 26px #1e2d370d}.tool-group button{display:inline-flex;align-items:center;justify-content:center;min-width:40px;min-height:38px;gap:7px;padding:0 12px;color:var(--text);font-size:13px;font-weight:800;white-space:nowrap;background:transparent;border-radius:7px;cursor:pointer}.tool-group button.selected{color:var(--teal);background:var(--teal-soft)}.tool-group button:disabled{color:var(--muted-2);cursor:not-allowed;opacity:.5}.tool-group output{min-width:52px;text-align:center;color:var(--text);font-size:13px;font-weight:800}.active-color{width:28px;height:28px;margin:0 4px;background:var(--active-color);border:3px solid #ffffff;border-radius:50%;box-shadow:0 0 0 1px var(--line-strong),0 5px 12px #1720261f}.canvas-shell{display:grid;place-items:center;min-height:0;overflow:auto}.bead-grid{display:grid;grid-template-columns:repeat(var(--cols),minmax(0,1fr));grid-template-rows:repeat(var(--rows),minmax(0,1fr));width:min(100%,calc(750px * var(--zoom)));max-width:calc((100vh - 285px) * var(--zoom));min-width:min(100%,360px);aspect-ratio:var(--cols) / var(--rows);gap:1px;padding:8px;touch-action:none;background:#eef3f5;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.bead-cell{width:100%;min-width:0;aspect-ratio:1;padding:0;border-radius:50%;cursor:crosshair}.bead-cell.empty{background:radial-gradient(circle at center,rgba(255,255,255,.96) 0 17%,transparent 18%),radial-gradient(circle at 35% 30%,#fff 0 28%,#eef2f4 68%,#dfe8ec);box-shadow:inset 0 0 0 1px #7b8b9624}.bead-cell.filled{background:radial-gradient(circle at center,rgba(255,255,255,.85) 0 15%,transparent 16%),radial-gradient(circle at 35% 28%,rgba(255,255,255,.62) 0 22%,transparent 44%),var(--bead-color);box-shadow:inset 0 -1px 2px #00000047,inset 0 0 0 1px #00000021}.gallery-strip{margin-top:18px}.gallery-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.gallery-items{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(104px,1fr);gap:12px;overflow-x:auto;padding:2px 2px 7px}.pattern-card{position:relative;display:grid;align-content:center;justify-items:center;min-height:126px;gap:7px;color:var(--text);background:#fffffff0;border:1px solid var(--line);border-radius:8px;cursor:pointer}.pattern-card.selected{border-color:var(--teal);box-shadow:0 0 0 2px #07998529}.pattern-card span:last-child{max-width:92px;overflow:hidden;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.favorite-icon{position:absolute;top:9px;right:9px;color:var(--teal);fill:#07998524}.mini-grid{display:grid;grid-template-columns:repeat(var(--mini-cols),1fr);width:70px;height:70px;padding:4px;background:#f2f6f7;border:1px solid var(--line);border-radius:7px}.mini-grid i{display:block;border-radius:50%}.mini-grid i[style]{background:var(--mini-color);box-shadow:inset 0 -1px 1px #0003}.add-card{color:var(--muted);background:#ffffff94;border-style:dashed}.inspector{display:flex;flex-direction:column;min-width:0;padding:22px 16px 24px;border-left:1px solid var(--line)}.inspector-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:0 6px 12px;border-bottom:1px solid var(--line)}.inspector-header h2{margin-bottom:4px}.inspector-header p{margin:0;color:var(--muted);font-size:12px;font-weight:800}.inspector-header strong{font-size:18px}.inspector-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:12px 6px;border-bottom:1px solid var(--line)}.inspector-summary div{display:grid;gap:4px;min-width:0}.inspector-summary span{color:var(--muted-2);font-size:11px;font-weight:900}.inspector-summary strong{overflow:hidden;color:var(--text);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.color-table{display:grid;min-height:0;overflow:auto}.table-row{display:grid;grid-template-columns:42px minmax(54px,.8fr) minmax(60px,.9fr) minmax(58px,.8fr);align-items:center;min-height:41px;gap:6px;padding:0 6px;border-bottom:1px solid var(--line)}.table-head{position:sticky;top:0;z-index:1;color:var(--muted);font-size:12px;font-weight:800;background:var(--surface)}.color-row{width:100%;color:var(--text);font-size:13px;font-weight:700;text-align:left;background:transparent;cursor:pointer}.color-row.selected{background:var(--teal-soft)}.swatch{width:22px;height:22px;background:var(--swatch);border:1px solid rgba(23,32,38,.12);border-radius:50%;box-shadow:inset 0 0 8px #ffffff61,0 3px 8px #17202614}.empty-inspector{display:grid;place-items:center;gap:8px;margin:auto;color:var(--muted)}.library-section,.support-sections,.seo-guide-section{width:min(1180px,calc(100% - 48px));margin:0 auto}.library-section{padding:54px 0 24px}.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:20px}.section-heading h2{margin:0;color:var(--text);font-size:25px;line-height:1.2;letter-spacing:0}.section-heading p{max-width:660px;margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.7}.section-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.section-actions span,.library-tags span,.challenge-target>div>span{display:inline-flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;font-weight:800}.category-tabs{display:flex;align-items:center;gap:8px;margin-bottom:18px;overflow-x:auto;color:var(--muted)}.category-tabs button{min-height:36px;padding:0 14px;color:var(--text);font-size:13px;font-weight:800;white-space:nowrap;background:#fff;border:1px solid var(--line);border-radius:7px;cursor:pointer}.category-tabs button.selected{color:var(--teal);background:var(--teal-soft);border-color:#07998547}.pattern-library-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.library-card{display:grid;grid-template-rows:auto 1fr;min-width:0;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 26px #1e2d370d}.library-card.selected{border-color:var(--teal);box-shadow:0 0 0 2px #07998524,0 10px 26px #1e2d370d}.library-preview{display:grid;place-items:center;min-height:160px;padding:16px;background:linear-gradient(90deg,rgba(223,231,235,.65) 1px,transparent 1px),linear-gradient(0deg,rgba(223,231,235,.55) 1px,transparent 1px),#f7fafb;background-size:18px 18px;cursor:pointer}.library-mini-grid,.challenge-mini-grid{display:grid;grid-template-columns:repeat(var(--mini-cols),1fr);width:118px;height:118px;padding:5px;background:#ffffffe0;border:1px solid var(--line);border-radius:8px}.library-mini-grid i,.challenge-mini-grid i{display:block;border-radius:50%}.library-mini-grid i[style],.challenge-mini-grid i[style]{background:var(--mini-color);box-shadow:inset 0 -1px 1px #0003}.library-card-body{display:grid;align-content:start;gap:12px;padding:15px}.library-card-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.library-card h3,.resource-card h3,.challenge-target h3{margin:0;color:var(--text);font-size:15px;line-height:1.35}.library-card-title span{flex:0 0 auto;padding:4px 7px;color:var(--teal);font-size:11px;font-weight:900;background:var(--teal-soft);border-radius:6px}.library-card p,.resource-card p,.challenge-target p{margin:0;color:var(--muted);font-size:12px;line-height:1.6}.library-card dl{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin:0}.library-card dl div{display:grid;gap:3px;min-width:0}.library-card dt{color:var(--muted-2);font-size:11px;font-weight:800}.library-card dd{margin:0;overflow:hidden;color:var(--text);font-size:12px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.library-tags{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.library-color-list{display:flex;align-items:center;gap:5px;min-height:18px}.library-color-list span{width:16px;height:16px;background:var(--swatch);border:1px solid rgba(23,32,38,.14);border-radius:50%;box-shadow:inset 0 0 5px #ffffff6b}.support-sections{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:20px;padding:30px 0 64px}.seo-guide-section{padding:36px 0 20px}.guide-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:16px;margin-bottom:16px}.guide-panel{min-width:0;padding:18px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 10px 26px #1e2d370d}.guide-panel-large{align-content:start}.guide-kicker{display:inline-flex;align-items:center;gap:7px;margin-bottom:14px;color:var(--teal);font-size:12px;font-weight:900}.guide-steps{display:grid;gap:12px}.guide-step{display:grid;grid-template-columns:36px minmax(0,1fr);gap:12px;align-items:start;padding:12px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px}.guide-step>svg{color:var(--teal)}.guide-step h3,.tip-item h3{margin:0;color:var(--text);font-size:15px;line-height:1.35}.guide-step p,.guide-intro,.tip-item p,.faq-grid p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.7}.plain-list{display:grid;gap:10px;margin:14px 0 0;padding:0;list-style:none}.plain-list li{position:relative;padding-left:20px;color:var(--muted);font-size:13px;line-height:1.7}.plain-list li:before{position:absolute;top:.67em;left:0;width:7px;height:7px;content:"";background:var(--yellow);border:1px solid rgba(23,32,38,.18);border-radius:50%}.guide-tips{margin-bottom:16px}.tip-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.tip-item{min-width:0;padding:14px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px}.faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:10px}.faq-grid details{min-width:0;height:fit-content;padding:13px 14px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px}.faq-grid summary{color:var(--text);font-size:14px;font-weight:900;line-height:1.45;cursor:pointer}.site-footer{background:#172026;color:#f6f8f9;border-top:1px solid rgba(255,255,255,.08)}.footer-inner{width:min(1180px,calc(100% - 48px));margin:0 auto;padding:34px 0 28px}.footer-brand{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:14px;padding-bottom:22px}.footer-brand h2{margin:0;font-size:24px}.footer-brand p{max-width:720px;margin:7px 0 0;color:#f6f8f9b8;font-size:13px;line-height:1.7}.footer-brand-mark{display:grid;grid-template-columns:repeat(4,8px);gap:4px;padding:2px}.footer-brand-mark span{width:8px;height:8px;background:var(--teal);border-radius:50%}.footer-brand-mark span:nth-child(3n+1){background:var(--coral)}.footer-brand-mark span:nth-child(4n){background:var(--yellow)}.footer-links{display:flex;flex-wrap:wrap;gap:10px;padding:0 0 20px}.footer-links a{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;color:#f6f8f9;font-size:13px;font-weight:800;text-decoration:none;background:#ffffff12;border:1px solid rgba(255,255,255,.1);border-radius:7px}.footer-policy-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.footer-policy-grid section{min-width:0;padding:15px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px}.footer-policy-grid span{display:inline-flex;align-items:center;gap:7px;color:#fff;font-size:13px;font-weight:900}.footer-policy-grid svg{color:var(--yellow)}.footer-policy-grid p{margin:9px 0 0;color:#f6f8f9b8;font-size:12px;line-height:1.75}.footer-bottom{display:flex;justify-content:space-between;gap:12px;margin-top:20px;padding-top:18px;color:#f6f8f994;font-size:12px;border-top:1px solid rgba(255,255,255,.09)}.resource-section,.challenge-section{min-width:0}.resource-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.resource-card{display:grid;grid-template-columns:38px minmax(0,1fr);gap:12px;min-height:126px;padding:16px;background:#fff;border:1px solid var(--line);border-radius:8px}.resource-card>svg{color:var(--teal)}.resource-card strong{display:block;margin:5px 0 7px;color:var(--navy);font-size:12px}.challenge-board{display:grid;gap:16px;padding:16px;background:#fff;border:1px solid var(--line);border-radius:8px}.challenge-target{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:14px}.challenge-mini-grid{width:112px;height:112px}.challenge-target h3{margin-top:6px;font-size:18px}.challenge-progress{display:grid;gap:8px}.progress-label{display:flex;align-items:center;justify-content:space-between;gap:12px}.progress-label strong{font-size:24px}.progress-label span{color:var(--muted);font-size:13px;font-weight:900}.progress-track{height:9px;overflow:hidden;background:#e8eef1;border-radius:99px}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),#61c8bc);border-radius:inherit;transition:width .18s ease}.challenge-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.challenge-actions button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;gap:7px;color:var(--text);font-size:12px;font-weight:900;background:var(--surface-soft);border:1px solid var(--line);border-radius:7px;cursor:pointer}.challenge-actions button:first-child{color:#fff;background:var(--teal);border-color:var(--teal)}.challenge-score{display:inline-flex;align-items:center;gap:9px;color:var(--navy);font-size:13px;font-weight:900}.challenge-score svg{color:var(--yellow);fill:#ffd33840}body.challenge-open,body.three-open,body.project-open{overflow:hidden}.project-dialog-backdrop{position:fixed;inset:0;z-index:130;display:grid;place-items:center;padding:20px;background:#1720266b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.project-dialog{display:grid;gap:16px;width:min(680px,100%);max-height:min(720px,calc(100vh - 40px));overflow:auto;padding:18px;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 24px 70px #1720263d}.project-dialog-header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:start}.project-dialog-header span{display:inline-flex;align-items:center;gap:7px;color:var(--teal);font-size:12px;font-weight:900}.project-dialog-header h2{margin:5px 0 0;font-size:24px;line-height:1.2}.project-dialog-header p{margin:8px 0 0;color:var(--muted);font-size:13px;line-height:1.65}.dialog-close{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;color:var(--text);background:var(--surface-soft);border:1px solid var(--line);border-radius:7px;cursor:pointer}.saved-project-card{display:grid;grid-template-columns:48px minmax(0,1fr) auto;gap:14px;align-items:start;padding:15px;background:var(--surface-soft);border:1px solid var(--line);border-radius:8px}.saved-project-icon{display:grid;place-items:center;width:42px;height:42px;color:var(--teal);background:var(--teal-soft);border:1px solid rgba(7,153,133,.24);border-radius:8px}.saved-project-copy{min-width:0}.saved-project-copy h3,.empty-project-state h3{margin:0;color:var(--text);font-size:17px;line-height:1.35}.saved-project-copy p,.empty-project-state p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.6}.saved-project-copy dl{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:14px 0 0}.saved-project-copy dt{color:var(--muted-2);font-size:11px;font-weight:800}.saved-project-copy dd{margin:3px 0 0;color:var(--text);font-size:13px;font-weight:900}.saved-project-actions{display:flex;flex-direction:column;gap:8px}.saved-project-actions button{display:inline-flex;align-items:center;justify-content:center;min-width:112px;min-height:38px;gap:7px;padding:0 12px;color:#fff;font-size:13px;font-weight:900;white-space:nowrap;background:var(--teal);border:1px solid var(--teal);border-radius:7px;cursor:pointer}.saved-project-actions .danger-action{color:var(--red, #c91f37);background:#fff5f6;border-color:#c91f373d}.empty-project-state{display:grid;place-items:center;min-height:180px;padding:24px;text-align:center;background:var(--surface-soft);border:1px dashed var(--line-strong);border-radius:8px}.empty-project-state svg{color:var(--teal)}.challenge-overlay{position:fixed;inset:0;z-index:100;display:grid;grid-template-rows:auto minmax(0,1fr);color:var(--text);background:linear-gradient(90deg,rgba(223,231,235,.7) 1px,transparent 1px),linear-gradient(0deg,rgba(223,231,235,.55) 1px,transparent 1px),#f4f7f8;background-size:28px 28px}.challenge-overlay-header{display:grid;grid-template-columns:minmax(220px,1fr) auto auto;align-items:center;gap:18px;padding:14px 20px;background:#fffffff5;border-bottom:1px solid var(--line);box-shadow:0 8px 24px #1720260d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.challenge-overlay-header span,.challenge-hint-panel .hint-copy span{display:inline-flex;align-items:center;gap:7px;color:var(--teal);font-size:12px;font-weight:900}.challenge-overlay-header h2{margin:5px 0 0;font-size:22px;line-height:1.25}.challenge-overlay-stats{display:grid;justify-items:end;gap:2px}.challenge-overlay-stats strong{font-size:26px;line-height:1}.challenge-overlay-stats span{color:var(--muted);font-size:13px;font-weight:900}.overlay-exit,.hint-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:38px;gap:8px;color:var(--text);font-size:13px;font-weight:900;background:#fff;border:1px solid var(--line);border-radius:7px;cursor:pointer}.overlay-exit{padding:0 14px}.challenge-overlay-body{display:grid;grid-template-columns:310px minmax(0,1fr);min-height:0;gap:18px;padding:18px}.challenge-hint-panel{display:grid;align-content:start;gap:14px;min-width:0;padding:16px;overflow:auto;background:#fffffff5;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.challenge-hint-panel.collapsed{align-content:start}.hint-toggle{width:100%}.hint-preview{display:grid;place-items:center;min-height:210px;background:linear-gradient(90deg,rgba(223,231,235,.65) 1px,transparent 1px),linear-gradient(0deg,rgba(223,231,235,.55) 1px,transparent 1px),#f7fafb;background-size:18px 18px;border:1px solid var(--line);border-radius:8px}.hint-mini-grid{display:grid;grid-template-columns:repeat(var(--mini-cols),1fr);width:180px;height:180px;padding:6px;background:#ffffffe6;border:1px solid var(--line);border-radius:8px}.hint-mini-grid i{display:block;border-radius:50%}.hint-mini-grid i[style]{background:var(--mini-color);box-shadow:inset 0 -1px 1px #0003}.hint-copy{display:grid;gap:8px}.hint-copy h3{margin:0;font-size:22px}.hint-copy p{margin:0;color:var(--muted);font-size:13px;line-height:1.6}.overlay-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.challenge-play-area{display:grid;grid-template-rows:auto minmax(0,1fr) auto;min-width:0;min-height:0}.challenge-play-area .canvas-toolbar{margin-bottom:14px}.challenge-play-area .canvas-shell{min-height:0}.challenge-play-area .bead-grid{width:min(100%,calc(82vh * var(--zoom)));max-width:min(100%,calc((100vw - 410px) * var(--zoom)))}.overlay-score{justify-content:center;min-height:40px;margin-top:10px;background:#ffffffdb;border:1px solid var(--line);border-radius:8px}.three-preview-overlay{position:fixed;inset:0;z-index:120;display:grid;grid-template-rows:auto minmax(0,1fr);color:var(--text);background:linear-gradient(90deg,rgba(203,214,220,.52) 1px,transparent 1px),linear-gradient(0deg,rgba(203,214,220,.42) 1px,transparent 1px),#f4f7f8;background-size:32px 32px}.three-preview-overlay.loading{grid-template-rows:1fr;place-items:center}.three-preview-loading{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 18px;color:var(--teal-dark);font-size:14px;font-weight:900;background:#fffffff0;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.three-preview-header{display:grid;grid-template-columns:minmax(180px,1fr) auto auto;align-items:center;gap:16px;padding:14px 20px;background:#fffffff5;border-bottom:1px solid var(--line);box-shadow:0 8px 24px #1720260d;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.three-title-lockup span{display:inline-flex;align-items:center;gap:7px;color:var(--teal);font-size:12px;font-weight:900}.three-title-lockup h2{margin:5px 0 0;font-size:22px;line-height:1.2}.three-preview-stats,.three-preview-actions{display:flex;align-items:center;gap:8px}.three-preview-stats{justify-content:flex-end;min-width:0}.three-preview-stats span{display:grid;min-width:74px;gap:2px;color:var(--muted);font-size:11px;font-weight:900;text-align:center;text-transform:uppercase}.three-preview-stats strong{color:var(--text);font-size:17px;line-height:1;text-transform:none}.three-preview-actions{justify-content:flex-end}.three-preview-actions button{display:inline-flex;align-items:center;justify-content:center;min-height:38px;gap:8px;padding:0 12px;color:var(--text);font-size:13px;font-weight:900;white-space:nowrap;background:#fff;border:1px solid var(--line);border-radius:7px;cursor:pointer}.three-preview-actions button.selected{color:var(--teal-dark);background:var(--teal-soft);border-color:#0799854d}.three-scene-stage{position:relative;min-width:0;min-height:0;overflow:hidden;touch-action:none}.three-canvas{display:block;width:100%;height:100%;cursor:grab;touch-action:none}.three-scene-stage:active .three-canvas{cursor:grabbing}@media(max-width:1180px){.app-header{grid-template-columns:1fr auto}.main-nav{display:none}.studio-layout{grid-template-columns:300px minmax(520px,1fr)}.inspector{grid-column:1 / -1;max-height:360px;border-top:1px solid var(--line);border-left:0}.pattern-library-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.guide-layout,.footer-policy-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.guide-panel-large{grid-column:1 / -1}.tip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.support-sections{grid-template-columns:1fr}}@media(max-width:860px){.app-header{position:static;grid-template-columns:1fr;gap:12px;padding:16px}.brand{font-size:20px}.header-actions{justify-content:flex-start;flex-wrap:wrap}.studio-layout{display:block}.control-panel,.workspace,.inspector{border:0}.control-panel{padding:18px 16px}.workspace{padding:16px}.canvas-toolbar{align-items:stretch;flex-direction:column;overflow:hidden}.tool-group{flex-wrap:wrap;width:100%}.bead-grid{width:100%;max-width:100%;min-width:0}.gallery-items{grid-auto-columns:104px}.library-section,.support-sections,.seo-guide-section{width:min(100% - 32px,760px)}.section-heading{align-items:flex-start;flex-direction:column}.pattern-library-grid,.resource-grid,.guide-layout,.faq-grid,.footer-policy-grid{grid-template-columns:1fr}.footer-inner{width:min(100% - 32px,760px)}.footer-bottom{align-items:flex-start;flex-direction:column}.challenge-overlay-header{grid-template-columns:1fr auto;gap:10px;padding:12px}.challenge-overlay-header h2{font-size:18px}.challenge-overlay-stats{justify-items:start;grid-column:1 / -1;grid-row:2}.overlay-exit{grid-column:2;grid-row:1;padding:0 10px}.challenge-overlay-body{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);gap:12px;padding:12px;overflow:auto}.challenge-hint-panel{grid-template-columns:auto minmax(0,1fr);align-items:center;max-height:none;overflow:visible}.challenge-hint-panel .hint-toggle,.challenge-hint-panel .challenge-progress,.challenge-hint-panel .challenge-actions{grid-column:1 / -1}.hint-preview{min-height:112px}.hint-mini-grid{width:104px;height:104px}.challenge-play-area .bead-grid{width:100%;max-width:100%}.three-preview-header{grid-template-columns:minmax(0,1fr);gap:10px;padding:12px}.three-title-lockup h2{font-size:18px}.three-preview-stats,.three-preview-actions{justify-content:flex-start;flex-wrap:wrap}.three-preview-stats span{min-width:68px;text-align:left}.three-preview-actions button{flex:1 1 132px}.saved-project-card{grid-template-columns:42px minmax(0,1fr)}.saved-project-actions{grid-column:1 / -1;flex-direction:row}.saved-project-actions button{flex:1 1 0}}@media(max-width:560px){.header-actions .settings-button,.header-grid-icon{display:none}.upload-box{grid-template-columns:72px 1fr}.upload-preview{width:72px;height:72px}.input-row,.toggle-row{align-items:flex-start;flex-direction:column}.input-row select{width:100%}.icon-only{display:none}.export-grid,.project-grid{grid-template-columns:1fr}.tool-group button{flex:0 0 auto}.canvas-toolbar .tool-group:first-child button{flex:1 1 calc(50% - 8px)}.table-row{grid-template-columns:34px 48px 1fr 50px;font-size:12px}.library-section{padding-top:36px}.seo-guide-section{padding-top:28px}.section-heading h2{font-size:21px}.library-preview{min-height:138px}.library-card dl{grid-template-columns:repeat(2,minmax(0,1fr))}.tip-grid{grid-template-columns:1fr}.guide-step{grid-template-columns:30px minmax(0,1fr);padding:11px}.footer-brand{align-items:flex-start;grid-template-columns:1fr}.project-dialog-backdrop{align-items:end;padding:10px}.project-dialog{max-height:calc(100vh - 20px)}.project-dialog-header h2{font-size:21px}.saved-project-copy dl{grid-template-columns:repeat(2,minmax(0,1fr))}.challenge-target{grid-template-columns:88px minmax(0,1fr)}.challenge-mini-grid{width:88px;height:88px}.challenge-actions,.challenge-overlay-header{grid-template-columns:1fr}.overlay-exit,.challenge-overlay-stats{grid-column:auto;grid-row:auto}.challenge-hint-panel{grid-template-columns:1fr}.hint-preview{min-height:98px}.hint-mini-grid{width:92px;height:92px}.overlay-actions{grid-template-columns:1fr}.three-preview-header{gap:9px}.three-preview-stats span{flex:1 1 30%;min-width:0}.three-preview-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.three-preview-actions .overlay-exit{grid-column:1 / -1}}
