#edari-game { all: initial; font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji"; }
#edari-game * { box-sizing: border-box; }
#edari-game.edari-root { display: block; }
#edari-game .edari-wrap { max-width: 860px; margin: 20px auto; padding: 16px; background: linear-gradient(180deg, #fff5f6, #ffffff 40%); border-radius: 18px; border: 1px solid #ffd6db; }
.edari-header { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.edari-header h2 { all: initial; font-family: inherit; font-size: 24px; font-weight: 700; color: #222; }
.edari-inventory { background: #fff; border: 1px solid #eee; border-radius: 14px; padding: 12px 14px; margin: 8px 0 16px; }
.edari-inventory h3 { all: initial; font-family: inherit; font-weight: 700; font-size: 16px; display: block; margin-bottom: 8px; color: #333; }
.edari-inventory-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.edari-inventory-empty { margin: 6px 0 0; font-size: 13px; color: #6b7280; }
.edari-pill { display: inline-flex; align-items: center; gap: 6px; border: 1px solid #eee; border-radius: 999px; padding: 6px 10px; background: #fff; box-shadow: 0 1px 0 rgba(0,0,0,.04); font-size: 14px; }
.edari-progress { position: relative; height: 10px; background: #ffe6ea; border-radius: 999px; overflow: hidden; margin: 10px 0 16px; border: 1px solid #ffd6db; }
.edari-progress-bar { width: 0%; height: 100%; background: #f43f5e; transition: width 0.1s linear; }
.edari-track { position: relative; height: 90px; border-radius: 14px; background: #fff; border: 1px solid #eee; overflow: hidden; box-shadow: inset 0 1px 0 rgba(0,0,0,.03); }
.edari-track-grid { position: absolute; inset: 0; display: grid; grid-template-columns: repeat(12, 1fr); }
.edari-track-grid > * { border-right: 1px dashed #eee; }
.edari-hat { position: absolute; top: 50%; left: 8px; transform: translateY(-50%); width: 56px; height: 56px; display: grid; place-items: center; font-size: 30px; background: #ffe4e6; border-radius: 50%; box-shadow: 0 2px 6px rgba(244,63,94,.25); }
.edari-card { background: #fff; border: 1px solid #eee; border-radius: 14px; padding: 14px; margin-top: 14px; }
.edari-qa-header { display: flex; align-items: center; justify-content: space-between; }
.edari-qa-title { font-weight: 600; color: #222; }
.edari-qa-step { font-size: 14px; color: #555; }
.edari-qa-options { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 12px; }
.edari-btn { appearance: none; border: 1px solid #e5e7eb; background: #fff; padding: 14px 16px; border-radius: 14px; font-size: 16px; cursor: pointer; text-align: center; transition: transform .05s ease, background .15s ease, border-color .15s ease, box-shadow .15s ease; }
.edari-btn:hover { background: #f9fafb; }
.edari-btn:active { transform: translateY(1px); }
.edari-btn-secondary { background: #fff; border-color: #e5e7eb; font-size: 14px; padding: 8px 12px; }
.edari-option { display: flex; align-items: center; justify-content: center; gap: 8px; min-height: 64px; font-weight: 600; }
.edari-left::before { content: "⟵"; }
.edari-right::after { content: "⟶"; }
.edari-feedback { margin-top: 10px; font-size: 14px; }
.edari-feedback.ok { color: #166534; background: #ecfdf5; border: 1px solid #bbf7d0; border-radius: 10px; padding: 8px 10px; }
.edari-feedback.err { color: #991b1b; background: #fef2f2; border: 1px solid #fecaca; border-radius: 10px; padding: 8px 10px; }
.edari-result h3 { all: initial; font-family: inherit; font-weight: 700; font-size: 20px; display: block; margin: 0 0 6px; color: #222; }
.edari-result p { margin: 6px 0 10px; font-size: 16px; }
.edari-sub { font-size: 13px; color: #6b7280; margin-bottom: 12px; }
.edari-footer { margin-top: 12px; font-size: 12px; color: #6b7280; text-align: center; }
@media (max-width: 480px) {
  .edari-header h2 { font-size: 20px; }
  .edari-option { min-height: 56px; font-size: 15px; }
  .edari-hat { width: 52px; height: 52px; }
}
