*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Pretendard,Noto Sans KR,sans-serif;background:#fff5f7;color:#4a3540;overflow:hidden}.app{height:100vh;position:relative}.header{position:absolute;top:0;left:0;right:0;z-index:10;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between;pointer-events:none;flex-wrap:wrap;gap:.6rem}.header h1{margin:0;font-size:1rem;font-weight:600;letter-spacing:.02em;background:#ffffffbf;padding:.45rem .95rem;border-radius:999px;pointer-events:auto;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #4a35400f}.tabs{display:flex;gap:.3rem;pointer-events:auto;background:#ffffffbf;padding:.3rem;border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #4a35400f}.tabs button{border:0;background:transparent;padding:.45rem .95rem;border-radius:999px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .18s ease;color:#6b5560;font-family:inherit}.tabs button:hover{background:#f5a4af2e}.tabs button.active{background:#4a3540;color:#fff}.badge{display:inline-block;margin-left:.4rem;font-size:.62rem;font-weight:700;letter-spacing:.04em;padding:.08rem .36rem;border-radius:4px;vertical-align:middle}.badge.glb{background:#4a8f6a;color:#fff}.tabs button.active .badge.glb{background:#7ed3a3;color:#1f3d2a}.hint code{background:#4a354014;padding:.05rem .35rem;border-radius:4px;font-size:.7rem}.hint{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);font-size:.75rem;color:#8a7580;background:#ffffffb3;padding:.35rem .85rem;border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}canvas{display:block}.moodboard{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;overflow:hidden;background:#f3e8ee;transition:background .25s ease;overscroll-behavior:none}.moodboard canvas{width:100%!important;height:100%!important;touch-action:none}.story-frame{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;transition:all .3s ease}.moodboard.story-mode{background:#1a1422}.moodboard.story-mode .story-frame{inset:auto;top:50%;left:50%;transform:translate(-50%,-50%);height:100vh;aspect-ratio:9 / 16;max-width:100vw;border-radius:18px;box-shadow:0 20px 60px #00000073}.story-toggle{position:fixed;top:1.2rem;right:1.2rem;z-index:10;border:0;padding:.45rem .85rem;border-radius:999px;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font:600 .78rem/1 system-ui,-apple-system,Segoe UI,sans-serif;color:#4a3540;cursor:pointer;box-shadow:0 2px 10px #4a35401f;transition:transform .15s ease,background .2s ease}.story-toggle:hover{background:#fffffff2;transform:translateY(-1px)}.story-toggle.is-on{background:#4a3540;color:#ffe0c0}.audio-toggle{position:absolute;right:1.2rem;bottom:1.2rem;width:44px;height:44px;border-radius:999px;border:0;background:#ffffffb3;color:#8a7580;font-size:1.1rem;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 6px #4a35401f;transition:all .18s ease;z-index:20}.audio-toggle:hover{background:#fffffff2;transform:translateY(-1px)}.audio-toggle.is-playing{background:#4a3540;color:#ffe0c0;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 2px 6px #4a35401f}50%{box-shadow:0 2px 14px #f5a4af66}}.action-hud{position:absolute;left:1.2rem;bottom:1.2rem;display:inline-flex;flex-direction:column;gap:.25rem;padding:.6rem .95rem;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:14px;font:500 .82rem/1 system-ui,-apple-system,Segoe UI,sans-serif;color:#4a3540;box-shadow:0 2px 10px #4a35401f;pointer-events:none;-webkit-user-select:none;user-select:none}.action-hud-row{display:inline-flex;align-items:baseline;gap:.45rem}.action-hud-label{opacity:.55;min-width:3.4rem}.action-hud-value{font-weight:700;color:#d77895}.action-hud-hint{margin-top:.25rem;padding-top:.35rem;border-top:1px solid rgba(74,53,64,.14);font-size:.72rem;opacity:.6}
