*{box-sizing:border-box}html{height:100%;min-width:320px;background:#f5f7fb}body{height:100%;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2937;overflow:hidden}#root{height:100%}button,input,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.42}.app{height:100%;overflow:hidden;padding:8px;background:radial-gradient(circle at 88% 0%,rgba(125,211,252,.12),transparent 28%),radial-gradient(circle at 8% 8%,rgba(191,219,254,.16),transparent 34%),linear-gradient(180deg,#fbfcff,#eef3f8)}.shell{display:grid;grid-template-columns:360px minmax(0,1fr);gap:8px;height:100%;width:100%;min-height:0}.mobile-view-switch{display:none}.palette-panel,.preview-panel{min-width:0;border:1px solid rgba(148,163,184,.22);border-radius:8px;background:#ffffffe6;box-shadow:0 18px 44px #47556912}.palette-panel{height:100%;min-height:0;overflow:auto;padding:14px}.preview-panel{display:grid;grid-template-rows:auto minmax(0,1fr);height:100%;min-height:0;padding:14px}.preview-canvas{position:relative;height:100%;min-height:0;overflow:auto;border:1px solid rgba(148,163,184,.22);border-radius:8px}.canvas-toolbar{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:8px;align-items:stretch;margin-bottom:8px}.preview-controls{display:grid;gap:8px;min-width:0}.zoom-control{display:grid;grid-template-columns:42px minmax(0,1fr) 44px 58px;gap:8px;align-items:center;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:8px;background:#ffffff9e}.zoom-control span,.zoom-control strong{color:#475569;font-size:12px;font-weight:900}.zoom-control input{width:100%;height:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;outline:0}.zoom-control input::-webkit-slider-runnable-track{height:3px;border:0;border-radius:999px;background:linear-gradient(90deg,#38bdf8 0 var(--zoom-value),rgba(148,163,184,.18) var(--zoom-value) 100%)}.zoom-control input::-webkit-slider-thumb{width:13px;height:13px;margin-top:-5px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:999px;background:#38bdf8;box-shadow:0 1px 3px #0e749029}.zoom-control input::-moz-range-track{height:3px;border:0;border-radius:999px;background:#94a3b82e}.zoom-control input::-moz-range-progress{height:3px;border-radius:999px;background:#38bdf8}.zoom-control input::-moz-range-thumb{width:13px;height:13px;border:0;border-radius:999px;background:#38bdf8;box-shadow:0 1px 3px #0e749029}.zoom-control button{min-height:30px;border:1px solid rgba(148,163,184,.3);border-radius:8px;background:#ffffffd1;color:#1f2937;font-size:12px;font-weight:900}.canvas-scroll-size{position:relative}.canvas-world{position:relative;transform-origin:0 0}.canvas-stage{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2}.canvas-module{position:absolute;overflow:hidden;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#ffffff8a;box-shadow:0 18px 44px #4755691f}.module-drag-handle{display:flex;align-items:center;width:100%;min-height:28px;border:0;border-bottom:1px solid rgba(148,163,184,.18);background:#f8fafcd1;color:#475569;cursor:grab;font-size:12px;font-weight:900;padding:0 9px;text-align:left}.module-drag-handle:active{cursor:grabbing}.module-body{padding:10px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-head h1{margin:0;color:#172033;font-size:25px;line-height:1.1}.icon-action,.color-row button,.panel-actions button,.stepper button{display:inline-grid;min-height:38px;place-items:center;border:1px solid rgba(148,163,184,.26);border-radius:8px;background:#ffffffe0;color:#1f2937}.icon-action{width:40px}.count-row{display:grid;grid-template-columns:72px 1fr;align-items:center;gap:10px;margin-bottom:10px;padding:10px;border:1px solid rgba(148,163,184,.24);border-radius:8px;background:#f8fafc9e}.palette-section{display:grid;gap:8px;margin-bottom:10px}.palette-section-toggle{display:flex;align-items:center;justify-content:space-between;min-height:36px;width:100%;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:0 10px;background:#f8fafc9e;color:#334155;font-size:13px;font-weight:900}.palette-section-toggle svg{transition:transform .16s ease}.palette-section.open .palette-section-toggle svg{transform:rotate(180deg)}.palette-section-content{display:grid;gap:10px}.count-row>span{color:#475569;font-size:13px;font-weight:800}.stepper{display:grid;grid-template-columns:38px 1fr 38px;gap:8px}.stepper input{width:100%;min-height:38px;border:1px solid rgba(148,163,184,.22);border-radius:8px;background:#fffffff0;color:#1f2937;text-align:center;font-size:17px;font-weight:900}.section-title{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.section-title span{color:#475569;font-size:13px;font-weight:900}.section-title button{display:grid;width:28px;height:28px;place-items:center;border:1px solid rgba(148,163,184,.28);border-radius:8px;background:#ffffffe6;color:#334155}.image-sampler{padding:10px;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#f8fafc94}.ai-generator{display:grid;gap:8px;padding:10px;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#ffffffb8}.ai-generator-actions{display:flex;justify-content:flex-end}.ai-generate-button{width:auto;min-width:82px;height:30px;padding:0 13px;border:1px solid rgba(14,165,233,.18);border-radius:8px;background:#f0f9ffc7;color:#0369a1;font-size:12px;font-weight:850;line-height:1;white-space:nowrap;box-shadow:none}.ai-generate-button:hover:not(:disabled){border-color:#0ea5e94d;background:#e0f2fed1}.ai-generate-button:disabled{border-color:#94a3b82e;background:#f8fafcb8;color:#94a3b8}.ai-generator textarea{width:100%;min-height:70px;resize:vertical;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:9px;background:#f8fafc94;color:#1f2937;font-size:13px;line-height:1.35;outline:0}.ai-generator textarea:focus{border-color:#60a5fa75}.ai-loading-status{display:flex;align-items:center;gap:8px;min-height:24px;padding:0 2px;color:#64748b;font-size:12px;font-weight:750}.ai-loading-dots{display:inline-flex;align-items:center;gap:4px}.ai-loading-dots i{width:5px;height:5px;border-radius:999px;background:#38bdf8;animation:ai-dot-pulse .9s ease-in-out infinite}.ai-loading-dots i:nth-child(2){animation-delay:.12s}.ai-loading-dots i:nth-child(3){animation-delay:.24s}.ai-error{margin:0;color:#b91c1c;font-size:12px;font-weight:800}.candidate-grid{display:grid;grid-template-columns:1fr;gap:8px}.candidate-card{display:grid;gap:7px;min-width:0;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:9px;background:#f8fafc94;color:#1f2937;text-align:left}.candidate-card:hover{border-color:#0ea5e947;background:#f0f9ffb3}.candidate-heading{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.candidate-heading strong,.candidate-card p,.candidate-card>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.candidate-heading strong{font-size:12px}.candidate-heading small{flex:0 0 auto;color:#0284c7;font-size:10px;font-weight:900;letter-spacing:0;text-transform:uppercase}.candidate-card p{margin:0;color:#475569;font-size:11px;font-weight:760}.candidate-card>span{color:#64748b;font-size:11px}.candidate-tags{display:flex;flex-wrap:wrap;gap:4px;min-width:0}.candidate-tags span{max-width:100%;overflow:hidden;border-radius:999px;padding:3px 6px;background:#e2e8f08c;color:#64748b;font-size:10px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.candidate-swatches{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:3px;min-width:0}.candidate-swatches i{height:18px;border:1px solid rgba(255,255,255,.3);border-radius:5px}@keyframes ai-dot-pulse{0%,80%,to{opacity:.28;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.upload-box{position:relative;display:flex;align-items:center;justify-content:center;gap:8px;min-height:62px;border:1px dashed rgba(148,163,184,.28);border-radius:8px;color:#334155;font-weight:900;cursor:pointer}.upload-box input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.image-preview{position:relative;display:block;width:100%;overflow:hidden;border:1px solid rgba(148,163,184,.22);border-radius:8px;padding:0;background:#fbfdff}.image-clear-button{position:absolute;top:8px;right:8px;z-index:3;display:grid;width:30px;height:30px;place-items:center;border:1px solid rgba(148,163,184,.24);border-radius:8px;background:#ffffffdb;color:#334155;box-shadow:0 8px 18px #4755691f}.image-preview img{display:block;width:100%;max-height:150px;object-fit:cover;cursor:crosshair}.image-preview span{position:absolute;right:8px;bottom:8px;border-radius:999px;padding:5px 8px;background:#020617b8;color:#f8fafc;font-size:12px;font-weight:900}.image-preview span.sample-flash{background:#22c55ee6;color:#052e16}.sample-history{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:6px;margin-top:8px}.sample-history button{min-height:24px;border:1px solid rgba(248,250,252,.22);border-radius:6px}.pixel-loupe{position:absolute;z-index:4;width:96px;border:1px solid rgba(248,250,252,.5);border-radius:8px;padding:6px;background:#020617eb;box-shadow:0 14px 38px #00000061;pointer-events:none}.pixel-grid{display:grid;grid-template-columns:repeat(9,1fr);overflow:hidden;border:1px solid rgba(248,250,252,.18);border-radius:5px}.pixel-grid i{aspect-ratio:1;border-right:1px solid rgba(0,0,0,.2);border-bottom:1px solid rgba(0,0,0,.2)}.pixel-grid i.center{outline:2px solid #fff;outline-offset:-2px}.pixel-loupe strong{display:block;margin-top:5px;color:#f8fafc;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;text-align:center}.picker-list{display:grid;gap:10px}.color-row{display:grid;grid-template-columns:54px minmax(0,1fr) 48px 34px;gap:8px;align-items:center;padding:8px;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#ffffffb8}.color-row.active{border-color:#60a5fa7a;background:#eff6ff8f}.color-picker-cell{position:relative;width:52px;height:52px;overflow:hidden;border:1px solid rgba(148,163,184,.24);border-radius:8px}.color-picker-cell span{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--chip-color)}.color-picker-cell input[type=color]{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;width:100%;height:100%;padding:0;border:0;opacity:0;cursor:pointer}.color-row label{display:grid;gap:4px;min-width:0}.color-row label span{color:#64748b;font-size:13px;font-weight:900}.color-row label input{width:100%;min-height:24px;border:0;background:transparent;color:#1f2937;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:14px;font-weight:800}.color-row button{width:34px;min-height:34px}.alpha-control{display:grid;justify-items:center;min-width:0}.alpha-control input[type=number]{width:48px;min-height:32px;border:0;border-radius:6px;background:#f8fafcad;color:#1f2937;box-shadow:none;text-align:center;font-size:12px;font-weight:900}.alpha-detail-slider input[type=range]{width:100%;height:11px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;outline:0}.alpha-detail-slider input[type=range]::-webkit-slider-runnable-track{height:3px;border:0;border-radius:999px;background:linear-gradient(90deg,#38bdf8 0 var(--alpha-value),rgba(148,163,184,.18) var(--alpha-value) 100%)}.alpha-detail-slider input[type=range]::-webkit-slider-thumb{width:11px;height:11px;margin-top:-4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:999px;background:#38bdf8;box-shadow:0 1px 2px #0e749024}.alpha-detail-slider input[type=range]::-moz-range-track{height:3px;border:0;border-radius:999px;background:#94a3b82e}.alpha-detail-slider input[type=range]::-moz-range-progress{height:3px;border-radius:999px;background:#38bdf8}.alpha-detail-slider input[type=range]::-moz-range-thumb{width:11px;height:11px;border:0;border-radius:999px;background:#38bdf8;box-shadow:0 1px 2px #0e749024}.color-details{display:none;margin-top:-4px;margin-bottom:4px;border:1px solid rgba(96,165,250,.2);border-radius:8px;padding:8px;background:#eff6ff75}.color-details.show{display:grid;gap:8px}.alpha-bg.checker{background:linear-gradient(45deg,rgba(148,163,184,.18) 25%,transparent 25%),linear-gradient(-45deg,rgba(148,163,184,.18) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(148,163,184,.18) 75%),linear-gradient(-45deg,transparent 75%,rgba(148,163,184,.18) 75%),#f8fafc;background-position:0 0,0 6px,6px -6px,-6px 0;background-size:12px 12px}.alpha-bg.white{background:#fff}.alpha-bg.black{background:#000}.format-grid{display:grid;grid-template-columns:44px minmax(0,1fr);gap:5px 8px;align-items:center}.format-grid span{color:#64748b;font-size:11px;font-weight:900}.format-grid code{overflow:hidden;color:#2563eb;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;text-overflow:ellipsis;white-space:nowrap}.panel-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:12px;padding-top:8px;border-top:1px solid rgba(148,163,184,.16)}.panel-actions button{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;font-weight:900;white-space:nowrap}.saved-list{display:grid;gap:8px}.saved-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.saved-card,.saved-tools button{border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#ffffffb8;color:#1f2937}.saved-card{display:grid;gap:7px;min-width:0;padding:9px}.saved-card input{width:100%;min-height:24px;border:0;background:transparent;color:#334155;font-size:13px;font-weight:800;outline:0}.saved-card input:focus{color:#2563eb}.saved-load{display:flex;gap:7px;min-width:0;border:0;background:transparent;padding:0;text-align:left}.saved-load i{width:22px;height:16px;border:1px solid rgba(255,255,255,.18);border-radius:4px}.saved-load i+i{margin-left:-5px}.saved-tools{display:grid;gap:5px}.saved-tools button{display:grid;width:30px;min-height:30px;place-items:center}.saved-tools button.active{border-color:#facc156b;background:#fef9c3b8;color:#a16207}.role-map{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:0}.alpha-backdrop-control{display:grid;grid-template-columns:minmax(130px,1fr) repeat(3,minmax(76px,96px));gap:8px;align-items:center;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:8px;background:#ffffffb8}.alpha-backdrop-control span{color:#475569;font-size:13px;font-weight:900}.alpha-backdrop-control button{min-height:32px;border:1px solid rgba(148,163,184,.24);border-radius:8px;background:#ffffffe0;color:#334155;font-size:12px;font-weight:900;text-transform:capitalize}.alpha-backdrop-control button.active{border-color:#60a5fa94;background:#dbeafeb8;color:#075985}.template-control{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:6px;background:#ffffffb8}.template-control button{min-height:28px;overflow:hidden;border:0;border-radius:6px;background:transparent;color:#64748b;font-size:11px;font-weight:850;text-overflow:ellipsis;white-space:nowrap}.template-control button.active{background:#e0f2fed9;color:#075985}.role-assignment{display:grid;gap:7px;min-width:0;border:1px solid rgba(148,163,184,.2);border-radius:8px;padding:8px;background:#ffffffc2;color:#1f2937}.role-assignment span{overflow:hidden;min-width:0;color:#475569;font-size:12px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.role-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(26px,1fr));gap:5px}.role-options button{display:grid;min-width:0;height:26px;place-items:center;border:1px solid rgba(148,163,184,.22);border-radius:7px;background:linear-gradient(#ffffffbd,#ffffffbd),var(--role-color);color:#334155;font-size:12px;font-weight:900;line-height:1}.role-options button.active{border-color:#1e40af4d;background:var(--role-color);color:var(--role-text);box-shadow:inset 0 0 0 1px #ffffff6b}.swatches{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:8px}.swatch{position:relative;display:flex;min-height:132px;flex-direction:column;justify-content:space-between;overflow:hidden;border-radius:8px;padding:12px;box-shadow:inset 0 0 0 1px #ffffff38}.swatch-fill{position:absolute;top:0;right:0;bottom:0;left:0}.swatch span{position:relative;width:28px;height:28px;display:grid;place-items:center;border-radius:999px;background:#ffffff2e;font-size:13px;font-weight:900}.swatch strong{position:relative;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:17px;letter-spacing:0}.swatch small{position:relative;font-size:12px;font-weight:900;opacity:.8}.canvas-grid{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;opacity:.22;background-image:linear-gradient(rgba(148,163,184,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.18) 1px,transparent 1px);background-size:34px 34px}.floating-panel{position:relative;border:1px solid rgba(148,163,184,.18);border-radius:8px;box-shadow:0 18px 46px #47556929}.main-panel{min-height:306px;padding:16px}.panel-nav{display:flex;align-items:center;gap:10px;min-height:44px;margin-bottom:14px;border:1px solid rgba(148,163,184,.18);border-radius:8px;padding:0 10px}.panel-nav span{width:28px;height:28px;border-radius:8px}.panel-nav strong{margin-right:auto}.panel-nav button,.input-panel button{min-height:36px;border:0;border-radius:8px;padding:0 14px;font-weight:900}.prompt-card{position:relative;overflow:hidden;border:1px solid rgba(148,163,184,.16);border-radius:8px;min-height:218px;padding:20px;background:#f8fafcb8}.prompt-glow{position:absolute;inset:0 0 auto;height:5px}.prompt-card p{margin:0 0 7px;color:#94a3b8;font-size:13px;font-weight:900}.prompt-card h2{max-width:500px;margin:0;color:#1f2937;font-size:clamp(24px,3vw,34px);line-height:1.08}.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.chips span{border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900}.stats-panel{padding:14px}.panel-kicker{margin-bottom:18px;font-size:12px;font-weight:900}.stats-panel strong{display:block;margin-bottom:7px;font-size:34px}.stats-panel p{margin-bottom:14px;line-height:1.45}.meter{height:8px;overflow:hidden;border-radius:999px}.meter i{display:block;height:100%;border-radius:inherit}.block-panel{min-height:150px;padding:16px}.block-panel span{display:block;width:32px;height:6px;margin-bottom:30px;border-radius:999px}.block-panel p,.input-panel label{display:block;margin:0 0 5px;font-size:13px;font-weight:900}.block-panel strong{font-size:28px}.input-panel{padding:14px}.fake-input{margin:9px 0 12px;border:1px solid rgba(148,163,184,.18);border-radius:8px;padding:11px;font-size:13px}.table-panel{padding:14px}.preview-table{display:grid;gap:8px}.preview-table div{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:8px;min-height:34px;border-bottom:1px solid rgba(148,163,184,.16)}.preview-table span{width:9px;height:9px;border-radius:999px}.preview-table strong{font-size:13px}.preview-table em{font-size:12px;font-style:normal;opacity:.75}.sampler-canvas{display:none}@media(max-width:1120px){.role-map{grid-template-columns:repeat(4,minmax(0,1fr))}.canvas-toolbar{grid-template-columns:1fr}}@media(max-width:860px){html,body,#root{height:auto;min-height:100%}body{overflow:auto}.app{height:auto;min-height:100dvh;overflow:visible;padding:8px}.mobile-view-switch{position:sticky;top:8px;z-index:20;display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-bottom:8px;padding:4px;border:1px solid rgba(148,163,184,.2);border-radius:8px;background:#ffffffe6;box-shadow:0 10px 26px #47556914;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.mobile-view-switch button{height:34px;border:0;border-radius:6px;background:transparent;color:#64748b;font-size:13px;font-weight:850}.mobile-view-switch button.active{background:#e0f2fed9;color:#075985}.shell{grid-template-columns:1fr;height:auto;min-height:0}.palette-panel,.preview-panel{display:none;height:auto;min-height:auto}.palette-panel.mobile-active{display:block}.preview-panel.mobile-active{display:grid;grid-template-rows:auto minmax(0,1fr);height:calc(100dvh - 64px);min-height:680px}.preview-panel.mobile-active .preview-canvas{height:100%;min-height:0}.role-map{grid-template-columns:repeat(2,minmax(0,1fr))}.alpha-backdrop-control{grid-template-columns:1fr}.color-row{grid-template-columns:46px minmax(0,1fr) 38px}.alpha-control{grid-column:1 / -1}.preview-canvas{min-height:620px;overflow:auto}}
