*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}:root{--bg: #f7f3ec;--surface: #ffffff;--surface2: #f2ede3;--surface3: #ece5d6;--dark: #141210;--dark2: #1e1a16;--dark3: #2a2520;--border: #ddd5c2;--border-hi: #c8b890;--gold: #c8a020;--gold-hi: #ddb830;--gold-dark: #9a7818;--gold-glow: rgba(200, 160, 32, .2);--text: #1a1610;--text-hi: #0d0b08;--muted: #7a7060;--muted-hi: #5a5248;--green: #4a8a46;--red: #a84848;--radius: 10px;--radius-sm: 7px;--font: system-ui, -apple-system, "Segoe UI", sans-serif;--font-serif: Georgia, "Times New Roman", serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:var(--dark);border-bottom:2px solid var(--gold-dark);padding:1.75rem 2rem 1.5rem}.header-inner{max-width:1160px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.logo{font-family:var(--font-serif);font-size:2.6rem;font-weight:700;letter-spacing:.03em;line-height:1;color:var(--gold)}.tagline{margin-top:.4rem;font-size:.88rem;color:#8a7f6e}.main{flex:1;max-width:1160px;margin:0 auto;width:100%;padding:2.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 2rem;box-shadow:0 1px 4px #0000000f}.card h2{font-family:var(--font-serif);font-size:1.2rem;font-weight:700;letter-spacing:.01em;color:var(--text-hi);margin-bottom:.3rem}.step-tag{font-size:.63rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:.35rem}.muted{font-size:.86rem;color:var(--muted);margin-bottom:1.25rem;max-width:640px;line-height:1.6}.btn{border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font);font-size:.92rem;font-weight:600;padding:.65rem 1.35rem;transition:opacity .15s,transform .1s;white-space:nowrap}.btn:hover{opacity:.88;transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-primary{background:var(--gold);border:none;color:#0e0b04;font-weight:700}.btn-primary:hover{background:var(--gold-hi);opacity:1}.btn-accent{background:var(--dark);color:var(--gold);font-weight:700;border:1px solid var(--gold-dark)}.btn-accent:hover{background:var(--dark2);opacity:1}.upload-row{display:flex;flex-direction:column;gap:1.1rem}.thumb-row{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.thumb{width:68px;height:68px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border-hi);background:var(--surface2)}.success-label{font-size:.7rem;font-weight:700;color:var(--green);letter-spacing:.07em;text-transform:uppercase;margin-bottom:.2rem}.public-id{font-size:.73rem;color:var(--muted);word-break:break-all}.env-warning{font-size:.86rem;color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.7rem 1rem}.step2-layout{display:grid;grid-template-columns:1fr 270px;gap:2rem;align-items:start}.step2-controls{display:flex;flex-direction:column;gap:1.1rem}.scene-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.45rem}.scene-chip{display:flex;flex-direction:column;align-items:center;gap:.28rem;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--muted-hi);cursor:pointer;font-family:var(--font);font-size:.74rem;font-weight:600;padding:.6rem .4rem .5rem;transition:border-color .14s,color .14s,background .14s}.scene-chip:hover{border-color:var(--gold);color:var(--text);background:var(--surface3)}.scene-chip--active{background:var(--dark);border-color:var(--gold-dark);color:var(--gold)}.scene-emoji{font-size:1.35rem;line-height:1}.prompt-wrap{position:relative}.prompt-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.86rem;line-height:1.55;outline:none;padding:.7rem 1rem 1.7rem;resize:vertical;transition:border-color .14s;width:100%}.prompt-input::placeholder{color:var(--muted)}.prompt-input:focus{border-color:var(--gold)}.prompt-count{position:absolute;bottom:.45rem;right:.7rem;font-size:.65rem;color:var(--muted);pointer-events:none}.generate-row{display:flex;gap:.65rem;flex-wrap:wrap;align-items:center}.name-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.92rem;flex:1;min-width:180px;outline:none;padding:.62rem 1rem;transition:border-color .14s}.name-input::placeholder{color:var(--muted)}.name-input:focus{border-color:var(--gold)}.scene-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:.45rem}.preview-label{font-size:.63rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--gold-dark);align-self:flex-start}.scene-preview{width:100%;aspect-ratio:1/1;border-radius:var(--radius-sm);overflow:hidden;position:relative;background:var(--surface2);border:1px solid var(--border-hi)}.scene-preview__shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.8s infinite}.scene-preview__img{display:block;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .45s}.scene-preview__img.loaded{opacity:1}.scene-preview__error{display:flex;align-items:center;justify-content:center;height:100%;font-size:.76rem;color:var(--muted);padding:1rem;text-align:center}.preview-hint{font-size:.64rem;color:var(--muted);text-align:center}.results-header{margin-bottom:1.5rem}.scene-label{color:var(--gold-dark);font-style:italic;font-weight:500}.section-title{font-family:var(--font-serif);font-size:1rem;font-weight:700;color:var(--text-hi);margin-bottom:.25rem;display:flex;align-items:center;gap:.45rem}.section-count{background:var(--dark);border-radius:999px;color:var(--gold);font-family:var(--font);font-size:.66rem;font-weight:700;padding:.1rem .5rem}.section-sub{font-size:.78rem;color:var(--muted);margin-bottom:1rem}.assets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1.1rem}.asset-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 1px 4px #0000000d;transition:border-color .18s,transform .14s,box-shadow .18s}.asset-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.asset-preview{background:var(--surface2);overflow:hidden;position:relative;max-height:240px}.asset-preview img{display:block;width:100%;height:100%;object-fit:cover;transition:opacity .3s}.asset-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--surface2) 25%,var(--surface3) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.8s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.asset-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;min-height:100px;padding:1rem;text-align:center;color:var(--muted)}.asset-error span{font-size:.8rem;font-weight:600;color:var(--red)}.asset-error small{font-size:.7rem;line-height:1.45}.asset-info{padding:.8rem .95rem .65rem;flex:1}.asset-info-top{display:flex;align-items:baseline;justify-content:space-between;gap:.4rem;margin-bottom:.18rem}.asset-info-top h3{font-size:.84rem;font-weight:700;color:var(--text-hi);white-space:nowrap}.asset-ratio-badge{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--muted);font-size:.61rem;font-weight:600;padding:.08rem .32rem;white-space:nowrap;flex-shrink:0}.asset-platform{font-size:.67rem;color:var(--gold-dark);font-weight:600;margin-bottom:.18rem;letter-spacing:.03em}.asset-desc{color:var(--muted);font-size:.72rem;line-height:1.4}.asset-actions{border-top:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr}.copy-btn{background:transparent;border:none;border-right:1px solid var(--border);color:var(--muted);cursor:pointer;font-family:var(--font);font-size:.74rem;font-weight:600;padding:.58rem;text-align:center;transition:background .14s,color .14s}.copy-btn:hover{background:var(--surface2);color:var(--text)}.copy-btn--success{color:var(--green)}.download-btn{color:var(--gold-dark);display:block;font-size:.74rem;font-weight:600;padding:.58rem;text-align:center;text-decoration:none;transition:background .14s,color .14s}.download-btn:hover{background:var(--gold);color:#0e0b04}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(136px,1fr));gap:.9rem}.color-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 1px 3px #0000000a;transition:border-color .18s,transform .14s}.color-card:hover{border-color:var(--gold);transform:translateY(-1px)}.color-card__preview{aspect-ratio:1/1;background:#f6f3ee;position:relative;overflow:hidden}.color-card__preview img{display:block;width:100%;height:100%;object-fit:contain;transition:opacity .3s}.color-card__error{display:flex;align-items:center;justify-content:center;height:100%;font-size:.7rem;color:var(--muted);padding:.5rem;text-align:center}.color-card__info{display:flex;align-items:center;gap:.38rem;padding:.48rem .6rem}.color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.12)}.color-card__label{font-size:.73rem;font-weight:600;color:var(--text)}.footer{background:var(--dark);border-top:1px solid var(--gold-dark);color:#6a6050;font-size:.76rem;padding:1.1rem 2rem;text-align:center}.footer a{color:var(--gold-dark);text-decoration:none}.footer a:hover{color:var(--gold)}@media(max-width:860px){.step2-layout{grid-template-columns:1fr}.scene-preview-wrap{flex-direction:row;align-items:center;gap:1rem}.scene-preview{width:110px;flex-shrink:0}.preview-label,.preview-hint{display:none}}@media(max-width:600px){.main{padding:1.1rem .9rem;gap:1rem}.card{padding:1.25rem 1rem}.header{padding:1.25rem 1rem 1rem}.assets-grid{grid-template-columns:1fr 1fr}.color-grid{grid-template-columns:repeat(3,1fr)}.generate-row{flex-direction:column;align-items:stretch}.name-input{width:100%}.scene-grid{grid-template-columns:repeat(3,1fr)}.step2-layout{grid-template-columns:1fr}.scene-preview-wrap{display:none}}@media(max-width:420px){.assets-grid{grid-template-columns:1fr}.color-grid{grid-template-columns:repeat(3,1fr)}}
