:root{--bg:#fffdf8;--card:#ffffff;--ink:#333;--accent:#b61e5f;--line:#eadfda}
*{box-sizing:border-box}
body{font-family:"Hiragino Sans","Noto Sans JP","Noto Color Emoji",system-ui,sans-serif;background:var(--bg);color:var(--ink);line-height:1.85;margin:0}
.hero{padding:22px 20px 8px;text-align:center}
.hero h1{margin:.2rem 0}
.hero p{margin:0;color:#6b5660}
main{padding:0 20px 24px}
#progress{position:relative;height:10px;background:#f4e9ef;border-radius:999px;margin:10px auto 8px;max-width:760px}
#bar{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,#ff7aa0,#b61e5f);border-radius:999px}
#count{display:block;text-align:right;font-size:12px;color:#7d6973;margin:2px auto 10px;max-width:760px}
.q{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px;margin:14px auto;max-width:760px}
.q-title{margin:0 0 10px;font-weight:700}
.grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.btn{border:1px solid #ddd;background:#fff;color:#333;border-radius:10px;padding:12px 8px;cursor:pointer;font-weight:700;transition:.15s;text-align:center}
.btn small{display:block;color:#8b7b83;font-weight:600}
.btn:hover{background:#fafafa}
.btn.active{border-color:#b61e5f;box-shadow:0 0 0 2px rgba(182,30,95,.15)}
.legend{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;font-size:12px;color:#8b7b83;margin:8px 0 12px}
.cta{display:block;width:100%;max-width:560px;margin:12px auto;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:14px 18px;font-size:16px;font-weight:800;cursor:pointer}
.note{text-align:center;font-size:12px;color:#8b7b83;margin:8px 0 12px}
.result{background:var(--card);border:2px solid #f3c;border-radius:14px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.05);margin:20px auto;max-width:820px}
.result-img{max-width:300px;width:100%;display:block;margin:8px auto 14px;border-radius:12px;box-shadow:0 8px 24px rgba(0,0,0,.09)}
.badge{display:inline-block;padding:6px 10px;border:1px solid #f0d7e8;border-radius:999px;font-size:12px;margin:4px 6px;background:#fff6fb}
.catch{color:#7a3a53;font-weight:800;text-align:center;margin:.3rem 0 .8rem}
.area h4{margin:.6rem 0 .2rem}
.area ul{margin:.2rem 0 .8rem 1.1rem}
.score{background:#fffafc;border:1px dashed #f2aac8;border-radius:12px;padding:12px;margin:12px 0}
.score ul{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin:.2rem 0 .2rem 1rem}
.chart{width:100%;max-width:760px;margin:10px auto 16px;border:1px solid #f0e0ea;border-radius:12px;padding:10px;background:#fff}
.bar{display:flex;align-items:center;gap:10px;margin:8px 0}
.bar span{width:84px;text-align:right;font-size:13px;color:#6d5c64}
.bar .track{flex:1;height:14px;background:#f6eef2;border-radius:999px;overflow:hidden}
.bar .fill{height:14px;width:0;background:linear-gradient(90deg,#ffd1e1,#ff91b4);border-radius:999px}
.premium{background:#fff8fb;border:1px dashed #f3aac7;padding:12px;border-radius:12px;margin-top:12px}
.premium h3{margin:.2rem 0 .6rem;color:#b61e5f;text-align:left}
.premium ul{margin:.2rem 0 .4rem 1.1rem}
.share{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:10px}
.share a{border:1px solid #e8d2df;border-radius:8px;padding:8px 10px;text-decoration:none;color:#b61e5f;font-weight:700;background:#fff}
@media (max-width:720px){.grid{grid-template-columns:1fr 1fr;} .btn{padding:12px} .score ul{grid-template-columns:1fr}}