:root{color:#1f2520;background:#f4fbf7;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--ink: #1f2520;--muted: #667168;--line: #d9e8df;--mint: #e8f7ef;--mint-strong: #0b8b78;--coral: #ff7658;--sun: #ffd166;--paper: #ffffff;--soft: #f7fcf9;--shadow: 0 22px 70px rgba(23, 48, 38, .12)}*{box-sizing:border-box}[hidden]{display:none!important}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(90deg,rgba(11,139,120,.05) 1px,transparent 1px),linear-gradient(rgba(255,118,88,.05) 1px,transparent 1px),radial-gradient(circle at 12% 8%,rgba(255,209,102,.28),transparent 22rem),radial-gradient(circle at 82% 12%,rgba(11,139,120,.18),transparent 26rem),#f4fbf7;background-size:28px 28px,28px 28px,auto,auto,auto}button,input,fieldset,summary{font:inherit}button,summary,label{-webkit-tap-highlight-color:transparent}.shell{width:min(1240px,calc(100% - 32px));margin:0 auto;padding:28px 0}.hero{display:flex;justify-content:space-between;gap:22px;align-items:center;margin-bottom:18px}.brand-lockup{display:flex;gap:16px;align-items:center}.brand-mark,.empty-mosaic{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:6px;border:1px solid rgba(31,37,32,.08);border-radius:8px;background:var(--paper);box-shadow:0 12px 30px #1730261a}.brand-mark{width:68px;height:68px;transform:rotate(-3deg)}.brand-mark span,.empty-mosaic span{display:grid;place-items:center;min-width:0;aspect-ratio:1;border-radius:4px;background:#f4fbf7;font-size:.94rem}h1,h2,p{margin:0}h1{color:var(--ink);font-size:clamp(2.45rem,6vw,5rem);line-height:.92;letter-spacing:0}.hero p:not(.privacy){margin-top:8px;color:var(--muted);font-size:1.08rem}.privacy{flex:none;max-width:280px;padding:11px 13px;border:1px solid rgba(11,139,120,.25);border-radius:8px;background:#ffffffdb;color:#286257;font-weight:800;text-align:center;box-shadow:0 10px 30px #1730260f}.studio{display:grid;grid-template-columns:304px minmax(0,1fr);gap:18px;align-items:stretch}.creator-panel{position:sticky;top:18px;display:grid;align-self:start;gap:14px;padding:14px;border:1px solid var(--line);border-radius:8px;background:#ffffffe6;box-shadow:var(--shadow)}.steps{display:grid;gap:10px;margin:0;padding:0;list-style:none}.steps li{display:grid;grid-template-columns:30px 1fr;gap:10px;align-items:start;padding:10px;border-radius:8px;background:var(--soft)}.step-number{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--ink);color:#fff;font-weight:900}.steps strong{color:var(--ink);font-size:.96rem}.steps p{margin-top:2px;color:var(--muted);font-size:.85rem;line-height:1.35}.drop-zone{display:grid;gap:8px;place-items:center;min-height:152px;padding:18px;border:2px dashed rgba(11,139,120,.38);border-radius:8px;background:linear-gradient(135deg,#0b8b7814,#ffd1661f),#fff;color:var(--ink);text-align:center;cursor:pointer;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.drop-zone:hover,.drop-zone:focus-within,.drop-zone.is-dragging{border-color:var(--mint-strong);box-shadow:0 16px 34px #0b8b7826;transform:translateY(-1px)}.drop-art{display:inline-flex;gap:7px;align-items:center;font-size:1.7rem}.drop-title{font-weight:900;font-size:1.12rem}.drop-help{color:var(--muted);font-size:.92rem}.drop-zone input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);clip-path:inset(50%)}.density-group{display:grid;gap:9px;margin:0;padding:12px;border:1px solid var(--line);border-radius:8px;background:#fff}.density-group legend{padding:0;color:var(--ink);font-weight:900}.density-group p{color:var(--muted);font-size:.86rem;line-height:1.35}.density-group label{display:flex;align-items:center;gap:10px;min-height:50px;padding:9px 10px;border:1px solid rgba(31,37,32,.1);border-radius:8px;background:var(--soft);color:var(--ink);cursor:pointer;transition:border-color .16s ease,background .16s ease,box-shadow .16s ease}.density-group label:has(input:checked){border-color:#0b8b7875;background:var(--mint);box-shadow:inset 0 0 0 1px #0b8b7829}.density-group input{flex:none;width:18px;height:18px;accent-color:var(--mint-strong)}.density-group span{display:grid;gap:1px}.density-group strong{font-size:.94rem}.density-group small{color:var(--muted);font-size:.78rem;font-weight:700}.actions{display:grid;gap:10px}button{min-height:48px;border:0;border-radius:8px;padding:0 16px;font-weight:900;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.46}.primary{background:var(--mint-strong);color:#fff;box-shadow:0 14px 28px #0b8b7833}.primary:not(:disabled):hover{background:#087767}.secondary{border:1px solid rgba(11,139,120,.22);background:#fff;color:var(--ink)}.secondary:not(:disabled):hover{background:var(--mint)}.ghost{min-height:38px;background:transparent;color:var(--mint-strong)}.ghost:hover{background:#0b8b7814}.status{min-height:42px;color:var(--muted);font-size:.93rem;font-weight:700;line-height:1.4}.stage{min-width:0;padding:14px;border:1px solid var(--line);border-radius:8px;background:#ffffffe0;box-shadow:var(--shadow)}.stage-header{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:4px 2px 14px}.stage-label{color:var(--coral);font-size:.78rem;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.stage h2{margin-top:4px;color:var(--ink);font-size:clamp(1.45rem,3vw,2.35rem);line-height:1.05;letter-spacing:0}.stage-meter{display:grid;grid-template-columns:repeat(5,13px);gap:5px;padding:7px;border-radius:8px;background:var(--soft)}.stage-meter span{aspect-ratio:1;border-radius:4px;background:var(--mint-strong)}.stage-meter span:nth-child(2){background:var(--coral)}.stage-meter span:nth-child(3){background:var(--sun)}.stage-meter span:nth-child(4){background:#3569e8}.stage-meter span:nth-child(5){background:#79b95b}.result-layout{display:grid;grid-template-columns:minmax(170px,.42fr) minmax(0,1fr);gap:14px;align-items:stretch}.source-card,.mosaic-card{min-width:0}.mini-header{display:flex;justify-content:space-between;margin-bottom:8px;color:var(--muted);font-size:.83rem;font-weight:900;text-transform:uppercase;letter-spacing:.05em}.source-frame,.mosaic-frame{position:relative;display:grid;place-items:center;overflow:auto;border-radius:8px;background:linear-gradient(45deg,rgba(31,37,32,.035) 25%,transparent 25%),linear-gradient(-45deg,rgba(31,37,32,.035) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(31,37,32,.035) 75%),linear-gradient(-45deg,transparent 75%,rgba(31,37,32,.035) 75%),#fbfefc;background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.source-frame{min-height:508px;border:1px solid var(--line)}.mosaic-frame{min-height:560px;border:2px solid rgba(31,37,32,.08);box-shadow:inset 0 0 0 8px #ffffff9e}#original-preview,#mosaic-canvas{display:block;max-width:100%;max-height:74vh;object-fit:contain}#mosaic-canvas{image-rendering:auto}.source-empty,.mosaic-empty{padding:28px;color:var(--muted);text-align:center;line-height:1.5}.mosaic-empty{display:grid;justify-items:center;gap:14px}.empty-mosaic{width:138px;height:138px}.empty-mosaic span{font-size:1.15rem}.mosaic-empty strong{color:var(--ink);font-size:1.2rem}.mosaic-empty p{max-width:320px}.state-generating .stage-meter span{animation:pulse .9s ease-in-out infinite alternate}.state-generating .stage-meter span:nth-child(2){animation-delay:90ms}.state-generating .stage-meter span:nth-child(3){animation-delay:.18s}.state-generating .stage-meter span:nth-child(4){animation-delay:.27s}.state-generating .stage-meter span:nth-child(5){animation-delay:.36s}@keyframes pulse{0%{transform:translateY(0);opacity:.55}to{transform:translateY(-5px);opacity:1}}@media(max-width:960px){.shell{width:min(100% - 22px,720px);padding:18px 0}.hero{display:grid;gap:14px}.brand-mark{width:58px;height:58px}.privacy{max-width:none;text-align:left}.studio,.result-layout{grid-template-columns:1fr}.state-generating .stage,.state-done .stage,.state-generating .mosaic-card,.state-done .mosaic-card{order:-1}.state-done .source-frame{min-height:220px;max-height:260px}.state-done #original-preview{max-height:260px}.creator-panel{position:static}.steps{grid-template-columns:1fr}.source-frame,.mosaic-frame{min-height:340px}}@media(max-width:520px){.shell{width:min(100% - 16px,460px);padding:12px 0 18px}.hero{gap:8px;margin-bottom:10px}.brand-lockup{gap:10px;align-items:center}.brand-mark{display:grid;width:46px;height:46px;padding:4px;box-shadow:0 8px 18px #17302614}.brand-mark span{font-size:.7rem}h1{font-size:2.05rem;line-height:.98}.hero p:not(.privacy){margin-top:3px;max-width:none;font-size:.94rem}.privacy{padding:8px 10px;font-size:.86rem;line-height:1.2;text-align:left}.studio{gap:10px}.creator-panel{gap:10px;padding:10px;box-shadow:0 12px 34px #1730261a}.steps{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.steps li{grid-template-columns:1fr;justify-items:center;gap:5px;min-height:62px;padding:8px 4px;text-align:center}.step-number{width:25px;height:25px;font-size:.82rem}.steps strong{font-size:.78rem;line-height:1.15}.steps p{display:none}.drop-zone{grid-template-columns:auto 1fr;column-gap:10px;row-gap:2px;place-items:center start;min-height:86px;padding:12px;text-align:left}.drop-art{grid-row:span 2;font-size:1.35rem}.drop-title{font-size:1rem}.drop-help{font-size:.82rem}.density-group{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:10px}.density-group legend,.density-group p{grid-column:1 / -1}.density-group p{display:none}.density-group label{flex-direction:column;justify-content:center;gap:5px;min-height:66px;padding:8px 4px;text-align:center}.density-group input{width:17px;height:17px}.density-group span{gap:0}.density-group strong{font-size:.84rem}.density-group small{font-size:.67rem;line-height:1.1}.actions{gap:8px}.status{min-height:0;font-size:.84rem}.stage{padding:10px}.stage-header{align-items:start;padding-bottom:8px}.stage-label{font-size:.68rem}.stage h2{font-size:1.34rem;line-height:1.08}.stage-meter{grid-template-columns:repeat(5,10px);gap:4px;padding:5px}.result-layout{gap:10px}.source-frame,.mosaic-frame{min-height:250px}.mosaic-frame{box-shadow:inset 0 0 0 5px #ffffff9e}.source-empty,.mosaic-empty{padding:18px}.empty-mosaic{width:108px;height:108px}.empty-mosaic span{font-size:.92rem}.mosaic-empty strong{font-size:1.02rem}.mosaic-empty p{font-size:.88rem}.state-done .steps,.state-done .drop-zone,.state-done .density-group{display:none}.state-done #download-button{order:-3}.state-done #reset-button{order:-2}.state-done #generate-button{order:-1}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
