@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";html,body,#root{margin:0;min-height:100%}body{min-width:320px}:root{--bg: #f6f8fb;--panel: rgba(255, 255, 255, .92);--text: #1f2937;--muted: #6b7280;--line: #e5e7eb;--brand: #f97316;--brand-strong: #ea580c}*{box-sizing:border-box}.app-shell{min-height:100vh;color:var(--text);background:radial-gradient(1200px 400px at 80% -50px,rgba(249,115,22,.12),transparent),linear-gradient(180deg,#fcfdff 0%,var(--bg) 100%)}.container{width:min(1120px,calc(100% - 2rem));margin:0 auto}.topbar{position:sticky;top:0;z-index:20;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-bottom:1px solid rgba(229,231,235,.75)}.topbar-inner{display:flex;justify-content:space-between;align-items:center;min-height:68px}.brand{display:flex;gap:.6rem;align-items:center}.brand-icon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#fb923c,#ef4444);color:#fff}.brand h1{margin:0;font-size:1.2rem;letter-spacing:-.02em}.tagline{margin:0;color:var(--muted);font-size:.9rem;font-weight:500}.topbar-actions{display:flex;align-items:center;gap:.75rem}.fruit-link-btn{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 .95rem;border-radius:10px;border:1px solid #fdba74;background:#fff7ed;color:#9a3412;font-size:.88rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:.2s ease}.fruit-link-btn:hover{background:#ffedd5}.page-main{padding:2rem 0 3rem}.hero{text-align:center;margin-bottom:1.6rem}.hero h2{margin:0;font-size:clamp(1.8rem,3vw,2.6rem);letter-spacing:-.025em}.hero h2 span{color:var(--brand)}.hero p{margin:.7rem 0 0;color:var(--muted)}.work-grid{display:grid;gap:1rem;grid-template-columns:1fr}.panel{border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:1.2rem;background:var(--panel);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 12px 40px #1f29370f}.panel-head{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem}.step{width:30px;height:30px;border-radius:999px;background:#fff1e8;color:var(--brand-strong);display:inline-flex;align-items:center;justify-content:center;font-weight:700;flex:0 0 auto}.panel-head h3{margin:0;font-size:1.1rem}.upload-area{border:2px dashed #cbd5e1;border-radius:16px;min-height:300px;cursor:pointer;padding:1rem;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;background:#fff;transition:.2s ease}.upload-area.dragover{border-color:var(--brand);background:#fff7ed}.upload-icon{margin:0;font-size:2.5rem}.upload-title{margin:.4rem 0 0;font-weight:600}.upload-sub{margin:.4rem 0 0;color:#94a3b8;font-size:.9rem}.preview-image{width:100%;max-height:400px;object-fit:contain;border-radius:12px}.hidden{display:none}.generate-btn{margin-top:1rem;width:100%;border:0;border-radius:14px;min-height:52px;background:linear-gradient(135deg,var(--brand),var(--brand-strong));color:#fff;font-weight:700;font-size:1rem;cursor:pointer}.generate-btn:disabled{background:#cbd5e1;cursor:not-allowed}.result-panel{min-height:520px;position:relative}.empty-state,.loading-state{min-height:420px;border:1px dashed var(--line);border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;color:var(--muted);padding:1rem}.empty-icon{margin:0 0 .6rem;font-size:2rem}.loader{width:42px;height:42px;border-radius:999px;border:4px solid #f1f5f9;border-top-color:var(--brand);animation:spin 1s linear infinite}.loading-title{margin:1rem 0 .3rem;font-weight:700;color:#111827}.loading-text{margin:0;color:var(--brand-strong)}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:720px){.topbar-inner{min-height:auto;padding:.85rem 0;flex-direction:column;align-items:flex-start;gap:.55rem}.topbar-actions{width:100%;justify-content:space-between;gap:.5rem}.fruit-link-btn{min-height:34px;font-size:.8rem;padding:0 .7rem}}.result-content{display:grid;gap:1rem}.result-content h4{margin:0 0 .5rem;font-size:.9rem;color:#475569}.image-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.image-card{position:relative;border-radius:14px;overflow:hidden;background:#e2e8f0;aspect-ratio:1 / 1}.image-card img{width:100%;height:100%;object-fit:cover}.image-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#64748b;background:#f8fafc;font-size:.85rem}.badge{position:absolute;top:8px;left:8px;z-index:2;color:#fff;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:999px;padding:.2rem .5rem;font-size:.72rem}.image-card button{position:absolute;bottom:8px;right:8px;border:0;border-radius:8px;padding:.35rem .6rem;font-size:.76rem;background:#ffffffe6;cursor:pointer}.name-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.name-list li{display:flex;align-items:center;gap:.6rem;border:1px solid #fed7aa;border-radius:12px;padding:.7rem;background:#fff}.name-list span{font-size:.8rem;font-weight:700;color:var(--brand-strong);background:#fff1e8;border-radius:8px;padding:.2rem .45rem}.name-list strong{font-size:.93rem}.description-head{display:flex;justify-content:space-between;align-items:center}.description-head button{border:0;border-radius:8px;background:#fff1e8;color:var(--brand-strong);padding:.35rem .6rem;font-size:.77rem;cursor:pointer}.description-box{margin:0;border:1px solid var(--line);background:#f8fafc;border-radius:12px;padding:.9rem;line-height:1.65;white-space:pre-wrap}.modal-overlay{position:fixed;inset:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:40;padding:1rem}.modal-card{width:min(360px,100%);background:#fff;border-radius:16px;padding:1.3rem;text-align:center}.modal-icon{margin:0 0 .5rem;font-size:2rem}.modal-card h4{margin:0}.modal-card p{color:var(--muted)}.modal-card button{width:100%;border:0;border-radius:10px;min-height:44px;background:linear-gradient(135deg,var(--brand),var(--brand-strong));color:#fff;font-weight:700;cursor:pointer}@media(min-width:960px){.work-grid{grid-template-columns:1fr 1fr;align-items:start}.panel{padding:1.5rem}}@media(max-width:760px){.tagline{display:none}.image-grid{grid-template-columns:1fr}}
