html,body{min-height:100vh}body{overflow-x:hidden;display:flex;flex-direction:column}body>header{flex:0 0 auto}body>main{flex:1 0 auto}body>.site-footer,body>footer{flex:0 0 auto;margin-top:0}.hq-page{max-width:980px;margin:0 auto;padding:.6rem .9rem .8rem}.hq-bar{display:flex;align-items:center;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.5rem}.hq-title{font-size:1.15rem;font-weight:800;margin:0;letter-spacing:.02em}.hq-title-sub{font-size:.78rem;color:#646464b3;margin-left:.5rem;font-weight:500}.hq-stats{display:flex;gap:.4rem;font-size:.82rem;flex-wrap:wrap}.hq-stats span{padding:.18em .65em;background:#0000000d;font-weight:600}.hq-stats .hq-correct{background:#4a9e5c26;color:#2c6f3c}.hq-stats .hq-partial{background:#c49a2a2e;color:#8a6614}.hq-stats .hq-wrong{background:#c0392b21;color:#9a2d24}.hq-stats .hq-streak{background:linear-gradient(135deg,#f9731638,#ea580c26);color:#c2410c}.hq-stats .hq-streak[hidden]{display:none}.hq-share{background:var(--primary-color, #446e72);color:#fff;border:none;font-size:.78rem;font-weight:700;padding:.18em .7em;cursor:pointer;display:inline-flex;align-items:center;gap:.3em;transition:filter .12s}.hq-share:hover:not(:disabled){filter:brightness(1.12)}.hq-share:disabled{background:#b9c9ca;cursor:not-allowed}.hq-toast{position:fixed;top:70px;left:50%;transform:translate(-50%) translateY(-200%);background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;padding:.75rem 1.4rem;font-weight:800;font-size:1.05rem;letter-spacing:.04em;box-shadow:0 8px 28px #00000038;z-index:9999;display:flex;align-items:center;gap:.5em;pointer-events:none;transition:transform .45s cubic-bezier(.34,1.56,.64,1);max-width:90vw;text-align:center}.hq-toast.shown{transform:translate(-50%) translateY(0)}.hq-toast-icon{font-size:1.4rem;line-height:1}.hq-question{position:relative;text-align:center;padding:.7rem 1rem .8rem;background:linear-gradient(135deg,#446e721a,#446e720a);border:1px solid var(--border-soft, #e0e0e0);margin-bottom:.5rem;transition:border-color .2s,background .2s}.hq-prompt{font-size:.78rem;color:#646464cc;margin:0 0 .15rem}.hq-name{font-size:1.85rem;font-weight:800;letter-spacing:.04em;margin:0;line-height:1.15}.hq-result-inline{margin-top:.4rem;min-height:2.9rem;font-size:.85rem;font-weight:600;line-height:1.4;visibility:hidden}.hq-result-inline.shown{visibility:visible}.hq-result-mark{display:inline-block;font-size:1.2rem;vertical-align:middle;margin-right:.3em}.hq-question[data-r=correct]{border-color:#4a9e5c80;background:linear-gradient(135deg,#4a9e5c29,#4a9e5c0d)}.hq-question[data-r=partial]{border-color:#c49a2a80;background:linear-gradient(135deg,#c49a2a2e,#c49a2a0f)}.hq-question[data-r=wrong]{border-color:#c0392b73;background:linear-gradient(135deg,#c0392b24,#c0392b0a)}.hq-question[data-r=revealed]{border-color:#6c7a8980;background:linear-gradient(135deg,#6c7a8924,#6c7a890a)}.hq-question[data-r=correct] .hq-result-inline{color:#2c6f3c}.hq-question[data-r=partial] .hq-result-inline{color:#8a6614}.hq-question[data-r=wrong] .hq-result-inline{color:#9a2d24}.hq-question[data-r=revealed] .hq-result-inline{color:#4d5a68}.hq-slots-bar{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.45rem}.hq-slot-card{display:flex;align-items:center;gap:.45rem;padding:.45rem .7rem;border:1.5px solid var(--border-soft, #d8d4ca);background:#fff;min-height:2.2rem}.hq-slot-card-start{border-left:4px solid #446e72}.hq-slot-card-end{border-left:4px solid #d97706}.hq-slot-card.is-filled.hq-slot-card-start{background:#446e7214}.hq-slot-card.is-filled.hq-slot-card-end{background:#d9770614}.hq-slot-icon{font-size:1.05rem;line-height:1}.hq-slot-name{font-size:.74rem;font-weight:800;letter-spacing:.04em;color:#505050d9}.hq-slot-card-start .hq-slot-name{color:#446e72}.hq-slot-card-end .hq-slot-name{color:#b45c00}.hq-slot-value{font-size:.92rem;font-weight:700;color:var(--text-color);margin-left:auto}.hq-slot-value:empty:before{content:"未選択";font-weight:500;color:#64646480;font-size:.82rem}.hq-tap-hint{text-align:center;font-size:.68rem;color:#646464a6;margin:0 0 .4rem;line-height:1.4}.hq-region{display:flex;align-items:center;gap:.3rem;margin-bottom:.18rem}.hq-region-label{flex:0 0 auto;width:2.4em;font-size:.65rem;color:#64646499;letter-spacing:.04em;text-align:center;font-weight:700}.hq-prefs{flex:1 1 auto;display:flex;flex-wrap:wrap;gap:.22rem}.hq-pref{flex:1 1 60px;min-width:56px;max-width:100px;padding:.28rem .15rem;border:1.5px solid var(--border-soft, #d8d8d8);background:#fff;color:#333;font-size:.74rem;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,color .12s,transform .08s;user-select:none;text-align:center;line-height:1.1}.hq-pref:hover:not(:disabled){border-color:var(--primary-color, #446e72);transform:translateY(-1px)}.hq-pref.is-start{background:#446e72;color:#fff;border-color:#446e72}.hq-pref.is-end{background:#d97706;color:#fff;border-color:#d97706}.hq-pref.is-both{background:linear-gradient(135deg,#446e72 50%,#d97706 50%);color:#fff;border-color:#446e72}.hq-pref:disabled{cursor:not-allowed}.hq-pref.reveal-correct{background:#4a9e5cd9!important;color:#fff!important;border-color:#3d8b50!important}.hq-pref.reveal-missed{background:#fff!important;color:#2c6f3c!important;border-color:#3d8b50!important;border-style:dashed!important}.hq-pref.reveal-wrong{background:#c0392b2e!important;color:#9a2d24!important;border-color:#c0392b!important;text-decoration:line-through}.hq-actions{display:flex;gap:.5rem;justify-content:center;align-items:center;margin-top:.7rem;flex-wrap:wrap}.hq-btn{padding:.5rem 1.2rem;border:none;font-weight:700;font-size:.92rem;cursor:pointer;transition:all .12s}.hq-btn-primary{background:var(--primary-color, #446e72);color:#fff}.hq-btn-primary:hover:not(:disabled){filter:brightness(1.08)}.hq-btn-primary:disabled{background:#b9c9ca;cursor:not-allowed}.hq-btn-secondary{background:#efeae1;color:#333}.hq-btn-secondary:hover:not(:disabled){background:#e3dccd}.hq-btn-secondary:disabled{background:#efeae1;color:#b5b0a7;cursor:not-allowed;opacity:.6}.hq-skip{font-size:.78rem;color:#646464b3;text-decoration:none;cursor:pointer;padding:.4rem .6rem}.hq-skip:hover{color:var(--primary-color);text-decoration:underline}.hq-shortcuts{text-align:center;font-size:.72rem;color:#6464648c;margin:.4rem 0 0;line-height:1.6}.hq-shortcuts kbd{display:inline-block;padding:.05em .45em;margin:0 .15em;font-size:.72rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#0000000f;border:1px solid rgba(0,0,0,.1);color:#505050d9}.hq-ad-rail{display:none}.hq-history-rail{display:block}.hq-history-toggle,.hq-history-close{display:none}.hq-ad-inner{position:sticky;top:80px;width:100%;max-width:200px;margin:0 auto;min-height:600px}.hq-ad-inner .adsbygoogle{display:block;min-height:600px}.hq-history-inner{position:sticky;top:80px;max-height:calc(100vh - 100px);overflow:hidden;display:flex;flex-direction:column;background:var(--surface-color, #fff);border:1px solid var(--border-soft, #d8d4ca)}.hq-history-header{flex-shrink:0;padding:.6rem .85rem;background:#00000006;border-bottom:1px solid var(--border-soft, #d8d4ca)}.hq-history-title{display:flex;align-items:baseline;gap:.4rem;margin:0;font-size:.8rem;font-weight:800;letter-spacing:.08em;color:var(--primary-color, #446e72);text-transform:uppercase}.hq-history-count{font-size:.72rem;font-weight:600;color:#646464bf;letter-spacing:0;text-transform:none}.hq-history-hint{font-size:.66rem;color:#646464a6;margin:.2rem 0 0;line-height:1.4}.hq-history-list{list-style:none;padding:0;margin:0;overflow-y:auto;flex:1 1 auto;min-height:0}.hq-history-empty{color:#64646499;font-size:.78rem;padding:1.2rem .8rem;text-align:center}.hq-history-item{display:grid;grid-template-columns:30px 1fr;align-items:stretch;cursor:pointer;border-bottom:1px solid var(--border-soft, #efece6);position:relative;transition:background .12s}.hq-history-item:last-child{border-bottom:none}.hq-history-grade{display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;color:#fff;line-height:1}.hq-history-grade-correct{background:#4a9e5c}.hq-history-grade-partial{background:#c49a2a}.hq-history-grade-wrong{background:#c0392b}.hq-history-grade-revealed{background:#6c7a89}.hq-history-grade-fresh{background:#d8d4ca;color:#888}.hq-history-item-correct{background:#4a9e5c0f}.hq-history-item-partial{background:#c49a2a12}.hq-history-item-wrong{background:#c0392b0d}.hq-history-item-revealed{background:#6c7a890f}.hq-history-item-fresh{background:transparent}.hq-history-item:hover{background:#0000000d}.hq-history-item-correct:hover{background:#4a9e5c29}.hq-history-item-partial:hover{background:#c49a2a2e}.hq-history-item-wrong:hover{background:#c0392b21}.hq-history-item-revealed:hover{background:#6c7a8924}.hq-history-item.is-current{outline:2px solid var(--primary-color, #446e72);outline-offset:-2px;z-index:1}.hq-history-item.is-current:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);border-style:solid;border-width:5px 0 5px 6px;border-color:transparent transparent transparent var(--primary-color, #446e72)}.hq-history-body{padding:.5rem .7rem;min-width:0;display:flex;flex-direction:column;gap:.1rem}.hq-history-name{font-weight:700;font-size:.82rem;color:var(--text-color);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hq-history-route{font-size:.7rem;color:#646464c7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-theme=dark] .hq-pref{background:#2a2f33;color:#ddd;border-color:#444}[data-theme=dark] .hq-pref:hover:not(:disabled){border-color:#6fa7ac}[data-theme=dark] .hq-question{background:linear-gradient(135deg,#6ea0a52e,#6ea0a50f);border-color:#3a4045}[data-theme=dark] .hq-stats span{background:#ffffff0f}[data-theme=dark] .hq-history-inner{background:#2a2f33;border-color:#3a4045}[data-theme=dark] .hq-history-header{background:#ffffff0a;border-color:#3a4045}[data-theme=dark] .hq-history-name{color:#e3e3e3}[data-theme=dark] .hq-history-item{border-color:#3a4045}@media(max-width:760px){.hq-page{padding:.5rem .6rem}.hq-name{font-size:1.55rem}.hq-pref{font-size:.7rem;padding:.24rem .1rem;min-width:50px}.hq-region-label{width:2.2em;font-size:.6rem}.hq-title-sub{display:none}}@media(min-height:800px){.hq-page{padding:1rem 1.2rem 1.2rem}.hq-bar{margin-bottom:.8rem}.hq-title{font-size:1.3rem}.hq-stats{font-size:.92rem}.hq-question{padding:1rem 1.2rem 1.1rem;margin-bottom:.7rem}.hq-prompt{font-size:.88rem;margin:0 0 .3rem}.hq-name{font-size:2.3rem}.hq-result-inline{font-size:.95rem;min-height:3.2rem}.hq-result-mark{font-size:1.4rem}.hq-region{margin-bottom:.3rem;gap:.4rem}.hq-region-label{font-size:.78rem;width:2.6em}.hq-prefs{gap:.3rem}.hq-pref{font-size:.88rem;padding:.5rem .25rem;flex:1 1 80px;min-width:70px;max-width:120px}.hq-actions{margin-top:1rem;gap:.7rem}.hq-btn{font-size:1rem;padding:.65rem 1.4rem}.hq-skip{font-size:.85rem}.hq-slot-label{font-size:.88rem;margin:.5rem 0 .35rem}}@media(min-height:1000px){.hq-name{font-size:2.7rem}.hq-pref{font-size:.96rem;padding:.7rem .3rem}}@media(min-width:1280px){main.hq-shell{display:grid;grid-template-columns:minmax(170px,1fr) minmax(0,1000px) minmax(220px,1fr);gap:1.2rem;max-width:1640px;margin:0 auto;align-items:start;width:100%}.hq-shell>.hq-page{max-width:none;margin:0}.hq-ad-rail{display:block;min-width:0}}@media(min-width:1500px){main.hq-shell{grid-template-columns:minmax(220px,1fr) minmax(0,1140px) minmax(260px,1fr);gap:1.5rem}.hq-ad-inner{max-width:220px}}@media(max-width:1279px){.hq-history-rail .hq-history-inner{display:none}.hq-history-toggle{display:flex;flex-direction:column;align-items:center;gap:.25rem;position:fixed;right:0;top:35%;z-index:200;background:var(--primary-color, #446e72);color:#fff;border:none;padding:.7rem .45rem;font-weight:700;font-size:.78rem;cursor:pointer;letter-spacing:.06em;box-shadow:-2px 2px 8px #0000002e}.hq-history-toggle:hover{filter:brightness(1.1)}.hq-history-toggle-icon{font-size:1.1rem;line-height:1}.hq-history-toggle-letters{display:flex;flex-direction:column;line-height:1.05}.hq-history-toggle-count{font-size:.72rem;background:#ffffff2e;padding:.05em .35em;font-weight:800}.hq-history-rail.is-expanded .hq-history-inner{display:flex;position:fixed;top:60px;right:0;bottom:16px;width:320px;max-width:92vw;max-height:none;z-index:201;box-shadow:-10px 0 28px #00000040}.hq-history-rail.is-expanded .hq-history-toggle{display:none}.hq-history-rail.is-expanded .hq-history-close{display:block;position:absolute;top:6px;right:6px;background:none;border:none;color:#505050d9;font-size:1.5rem;line-height:1;cursor:pointer;padding:.2rem .5rem;z-index:1;font-weight:700}.hq-history-rail.is-expanded .hq-history-close:hover{color:#c0392b}.hq-history-rail.is-expanded:before{content:"";position:fixed;inset:0;background:#00000052;z-index:200}}
