:root{--text:#f2eaee;--muted:#9e8fa0;--bg:#141016;--surface:#1a151a;--surface-2:#242024;--border:#3a343c;--border-strong:#554e56;--accent:#e891b8;--accent-strong:#f5c0d8;--accent-soft:#e891b824;--caution-bg:#2a1f24;--caution-border:#5c3d4a;--caution-text:#e8d4dc;--shadow-btn:0 2px 0 #00000059;--shadow-card:0 8px 24px #0006;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Zen Kaku Gothic New,Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{background-color:var(--bg);min-height:100dvh;margin:0}#root{flex-direction:column;max-width:40rem;min-height:100dvh;margin:0 auto;display:flex}.app{text-align:center;flex-direction:column;flex:1;min-height:100%;display:flex}.header{padding:1.75rem 1.25rem 1rem}.header__brand{text-align:left;justify-content:center;align-items:center;gap:.85rem;display:flex}.header__icon{color:var(--accent);flex-shrink:0}.header__text{min-width:0}.header__eyebrow{color:var(--muted);margin:0 0 .2rem;font-size:.8rem}.header__title{letter-spacing:.02em;color:var(--text);margin:0;font-size:clamp(1.45rem,4vw,1.85rem);font-weight:700}.main{box-sizing:border-box;flex:1;width:100%;max-width:32rem;margin:0 auto;padding:0 1.25rem 2rem}.landing .lead{text-align:left;color:var(--text);margin:0 0 1.25rem;line-height:1.75}.landing .lead strong{color:var(--accent-strong);font-weight:600}.disclaimer{text-align:left;color:var(--muted);background:var(--surface-2);border:1px solid var(--border);border-radius:12px;margin:0 0 1.75rem;padding:1rem 1.1rem;font-size:.85rem;line-height:1.6}.disclaimer strong{color:var(--text)}.disclaimer--compact{margin-top:.5rem;margin-bottom:1.5rem}.btn{font:inherit;cursor:pointer;border:2px solid #0000;border-radius:999px;padding:.75rem 1.5rem;font-weight:600;transition:background .2s,border-color .2s,transform .12s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--accent);color:#1a1216;box-shadow:var(--shadow-btn)}.btn--primary:hover:not(:disabled){background:var(--accent-strong);transform:translateY(-1px)}.btn--ghost{color:var(--text);border-color:var(--border);background:0 0}.btn--ghost:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-strong)}.quiz__heading{justify-content:flex-start;align-items:center;gap:.65rem;margin-bottom:1rem;display:flex}.quiz__icon{color:var(--accent);flex-shrink:0}.quiz .progress{color:var(--muted);margin:0;font-size:.9rem}.fieldset{text-align:left;border:none;margin:0;padding:0}.question{color:var(--text);margin:0 0 1.25rem;padding:0;font-size:1.08rem;font-weight:600;line-height:1.55}.choices{flex-direction:column;gap:.5rem;display:flex}.choice{border:2px solid var(--border);background:var(--surface);cursor:pointer;border-radius:12px;align-items:center;gap:.65rem;padding:.65rem .85rem;transition:border-color .2s,background .2s;display:flex}.choice:hover{border-color:var(--border-strong);background:var(--surface-2)}.choice:focus-within{outline:2px solid var(--accent);outline-offset:2px}.choice--active{border-color:var(--accent);background:var(--accent-soft)}.choice input{opacity:0;pointer-events:none;width:0;height:0;position:absolute}.choice__label{text-align:left;flex:1;font-size:.95rem}.actions{flex-wrap:wrap;justify-content:space-between;gap:.75rem;margin-top:2rem;display:flex}.actions--result{justify-content:center}.result .score-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:20px;margin-bottom:1.5rem;padding:1.5rem 1.5rem 1.75rem}.score-card__head{justify-content:center;align-items:center;gap:.5rem;margin-bottom:.35rem;display:flex}.score-card__icon{color:var(--accent)}.score-card__label{color:var(--muted);letter-spacing:.06em;margin:0;font-size:.85rem}.score-card__value-row{justify-content:center;align-items:baseline;gap:.35rem;margin-top:.15rem;display:flex}.score-card__value{color:var(--accent-strong);font-variant-numeric:tabular-nums;margin:0;font-size:clamp(3rem,12vw,4.5rem);font-weight:800;line-height:1}.score-card__unit{color:var(--muted);margin:0;font-size:1.35rem;font-weight:600}.level-section{margin-bottom:1.5rem}.level-section__name{color:var(--text);margin:0 0 .5rem;font-size:1.3rem;font-weight:700}.level-section__desc{text-align:left;color:var(--muted);margin:0;font-size:.95rem;line-height:1.65}.caution{text-align:left;background:var(--caution-bg);border:1px solid var(--caution-border);border-radius:16px;margin-bottom:1.5rem;padding:1.1rem 1.15rem 1.2rem}.caution__head{align-items:center;gap:.55rem;margin-bottom:.65rem;display:flex}.caution__icon{color:var(--accent-strong);flex-shrink:0}.caution__title{color:var(--caution-text);margin:0;font-size:1.05rem;font-weight:700}.caution__intro{color:var(--muted);margin:0 0 .75rem;font-size:.9rem;line-height:1.6}.caution__heavy{color:var(--caution-text);border:1px solid var(--caution-border);background:#0003;border-radius:10px;margin:0 0 .85rem;padding:.65rem .75rem;font-size:.88rem;line-height:1.55}.caution__list{color:var(--caution-text);margin:0;padding-left:1.15rem;font-size:.88rem;line-height:1.65}.caution__list li{margin-bottom:.4rem}.caution__list li:last-child{margin-bottom:0}.breakdown{text-align:left;margin-bottom:.5rem}.breakdown__head{align-items:center;gap:.45rem;margin-bottom:1rem;display:flex}.breakdown__icon{color:var(--accent);flex-shrink:0}.breakdown__title{color:var(--text);margin:0;font-size:.95rem;font-weight:600}.breakdown__list{flex-direction:column;gap:1rem;margin:0;padding:0;list-style:none;display:flex}.breakdown__row{color:var(--text);justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem;font-size:.88rem;display:flex}.breakdown__label{align-items:center;gap:.4rem;min-width:0;display:inline-flex}.breakdown__glyph{color:var(--accent);opacity:.9;flex-shrink:0}.breakdown__pct{color:var(--accent-strong);font-variant-numeric:tabular-nums;align-items:baseline;gap:.15rem;font-weight:700;display:inline-flex}.breakdown__hebe-unit{color:var(--muted);font-size:.75rem;font-weight:600}.breakdown__bar{background:var(--surface-2);border-radius:999px;height:8px;overflow:hidden}.breakdown__fill{background:var(--accent);border-radius:999px;height:100%;transition:width .4s;display:block}.footer{margin-top:auto;padding:1rem 1.25rem 1.5rem}.footer small{color:var(--muted);font-size:.75rem}
