:root{--bg: #0d1b2a;--bg-alt: #1b263b;--fg: #e0e1dd;--muted: #8d99ae;--accent: #f4d35e;--line: #415a77;--max-width: 760px;--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Hiragino Sans", "Noto Sans JP", sans-serif;--font-pixel: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, "Hiragino Sans", "Noto Sans JP", monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:16px;line-height:1.6;min-height:100dvh}html{overflow-x:hidden}img{image-rendering:crisp-edges;image-rendering:pixelated}.app{max-width:var(--max-width);margin:0 auto;padding:24px 16px 48px;min-height:100dvh}.town__header{margin-bottom:24px}.town__title{font-family:var(--font-pixel);font-size:24px;margin:0 0 8px;letter-spacing:.02em;color:var(--accent)}.town__subtitle{margin:0;font-size:14px;color:var(--muted)}.town__map{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:4px;aspect-ratio:1 / 1;width:100%;max-width:480px;margin:0 auto 24px;padding:12px;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.08) 1px,transparent 1.6px),radial-gradient(circle at 70% 70%,rgba(0,0,0,.12) 1px,transparent 1.6px),#4a7c2c;background-size:24px 24px,24px 24px,100%;border:4px solid #2c1810;border-radius:6px;box-shadow:0 4px 12px #0000004d}.town__cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;min-width:0;min-height:0}.town__cell--gate{text-decoration:none;color:inherit;background:#0000002e;border-radius:4px;padding:4px;cursor:pointer;transition:background .12s ease;min-block-size:44px;min-inline-size:44px}.town__cell--gate:hover,.town__cell--gate:focus-visible{background:#f4d35e38;outline:2px solid var(--accent);outline-offset:2px}.town__cell--center{background:#d4a57452;border-radius:50%}.town__cell-label{font-family:var(--font-pixel);font-size:10px;color:#fff;text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000;letter-spacing:.04em;white-space:nowrap}.town__note{margin:0;font-size:13px;color:var(--muted);text-align:center}.idle-sprite{display:inline-block;width:calc(var(--sprite-w) * var(--sprite-scale));height:calc(var(--sprite-h) * var(--sprite-scale));line-height:0;overflow:hidden}.idle-sprite__frame{display:block;width:100%;height:100%;background-image:url(/sprites/characters.png);background-repeat:no-repeat;background-position:var(--sprite-bg-x) var(--sprite-bg-y);background-size:var(--sprite-bg-w) var(--sprite-bg-h);transform-origin:center bottom;transform:scale(var(--sprite-scale)) translateY(0);image-rendering:pixelated;animation:idle-bounce 1s steps(2,jump-none) infinite}@keyframes idle-bounce{0%{transform:scale(var(--sprite-scale)) translateY(0)}to{transform:scale(var(--sprite-scale)) translateY(-1px)}}@media(prefers-reduced-motion:reduce){.idle-sprite__frame{animation:none}}.npc-button{display:inline-block;padding:4px;background:none;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:border-color .12s ease,background .12s ease;min-block-size:44px;min-inline-size:44px}.npc-button:hover,.npc-button:focus-visible{border-color:var(--accent);background:#f4d35e1f;outline:none}.dialog-overlay{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:16px}.dialog-overlay__backdrop{position:absolute;inset:0;background:#0000008c}.dialog-window{position:relative;width:100%;max-width:600px;min-width:min(280px,88vw);box-sizing:border-box;background:#fff;color:#1a1a24;border:4px solid #2c1810;border-radius:4px;box-shadow:0 6px 16px #00000080;font-family:var(--font-pixel);outline:2px solid #fff;outline-offset:-8px}.dialog-window__main{display:block;width:100%;box-sizing:border-box;margin:0;padding:18px 18px 14px;background:none;border:none;font:inherit;color:inherit;text-align:left;cursor:pointer;min-block-size:96px}.dialog-window__main:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.dialog-window__text{font-size:16px;line-height:1.7;margin:0;white-space:pre-wrap;word-break:normal;overflow-wrap:anywhere;letter-spacing:.02em}.dialog-window__cursor{display:inline-block;margin-left:1px;color:#2c1810;animation:dialog-cursor-blink .6s steps(2) infinite}@keyframes dialog-cursor-blink{0%{opacity:1}to{opacity:0}}.dialog-window__advance-icon{display:inline-block;margin-left:8px;color:#c0392b;font-size:14px;animation:dialog-advance-blink .6s steps(2) infinite}@keyframes dialog-advance-blink{0%{opacity:1}to{opacity:.25}}.dialog-window__close{position:absolute;top:6px;right:6px;width:32px;height:32px;background:#fff;border:2px solid #2c1810;border-radius:50%;font-family:var(--font-pixel);font-size:16px;font-weight:700;line-height:1;color:#2c1810;cursor:pointer;padding:0}.dialog-window__close:hover,.dialog-window__close:focus-visible{background:#2c1810;color:#fff;outline:none}@media(prefers-reduced-motion:reduce){.dialog-window__cursor,.dialog-window__advance-icon{animation:none}}.dialog-window__actions{display:flex;gap:12px;padding:0 18px 18px}.dialog-window__action{flex:1;min-block-size:44px;padding:10px 12px;font:inherit;font-family:var(--font-pixel);font-size:14px;color:#1a1a24;background:#fff;border:2px solid #2c1810;border-radius:2px;cursor:pointer;transition:background .12s ease,color .12s ease}.dialog-window__action:hover,.dialog-window__action:focus-visible{background:#2c1810;color:#fff;outline:none}.dialog-window__action--bye{background:#f5f5f5}.dialog-window__meta{margin:0;padding:0 18px 14px;font-family:var(--font-pixel);font-size:11px;color:#6b6b7a;text-align:right;letter-spacing:.04em}.detail-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center}.detail-overlay__backdrop{position:absolute;inset:0;background:#0000008c}.detail-panel{--detail-anim-duration: .25s;position:relative;width:100%;max-width:600px;max-height:90dvh;background:#fff;color:#1a1a24;border-top-left-radius:14px;border-top-right-radius:14px;box-shadow:0 -4px 20px #0006;font-family:var(--font-sans);display:flex;flex-direction:column;animation:detail-slide-up var(--detail-anim-duration) ease-out}.detail-panel--closing{animation:detail-slide-down var(--detail-anim-duration) ease-in}@keyframes detail-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes detail-slide-down{0%{transform:translateY(0)}to{transform:translateY(100%)}}@media(prefers-reduced-motion:reduce){.detail-panel,.detail-panel--closing{animation:none}}.detail-panel:focus{outline:none}.detail-panel__header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #e5e5ec;flex-shrink:0}.detail-panel__back{display:inline-flex;align-items:center;gap:4px;padding:8px 14px;background:#f5f5f7;color:#1a1a24;border:none;border-radius:6px;font-family:inherit;font-size:14px;cursor:pointer;min-block-size:44px;transition:background .12s ease;flex-shrink:0}.detail-panel__back:hover,.detail-panel__back:focus-visible{background:#e5e5ec;outline:2px solid #4a90e2;outline-offset:2px}.detail-panel__back-arrow{font-weight:700;color:#4a90e2}.detail-panel__title{margin:0;font-size:18px;font-weight:700;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-panel__body{padding:16px;overflow-y:auto;flex:1}.detail-panel__section{margin-bottom:22px}.detail-panel__section:last-child{margin-bottom:0}.detail-panel__section-label{margin:0 0 6px;font-size:11px;font-weight:700;color:#6b6b7a;letter-spacing:.08em;text-transform:uppercase}.detail-panel__section-text{margin:0;font-size:15px;line-height:1.7;color:#1a1a24;word-break:break-word}.detail-panel__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.detail-panel__link-item{margin:0}.detail-panel__link{display:block;padding:12px 14px;background:#f5f5f7;color:#1a1a24;text-decoration:none;border-radius:6px;font-size:13px;line-height:1.5;transition:background .12s ease;min-block-size:44px;word-break:break-word}.detail-panel__link:hover,.detail-panel__link:focus-visible{background:#e5e5ec;color:#4a90e2;outline:2px solid #4a90e2;outline-offset:2px}.detail-panel__empty{margin:0;font-size:14px;color:#6b6b7a;text-align:center;padding:24px 8px;line-height:1.7}.detail-panel__footer{padding:10px 16px 16px;border-top:1px solid #e5e5ec;flex-shrink:0}.detail-panel__meta{margin:0;font-size:11px;color:#6b6b7a;text-align:right}
