*,:before,:after{box-sizing:border-box}body{color:#5c3d2e;-webkit-font-smoothing:antialiased;background:linear-gradient(#faf3e8 0%,#f5ebe0 100%);min-height:100vh;margin:0;font-family:Tsukushi A Round Gothic,Hiragino Maru Gothic ProN,Yu Gothic UI,Hiragino Sans,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,system-ui,-apple-system,sans-serif;font-weight:500}#root{min-height:100vh}button{font-family:inherit}.app{flex-direction:column;align-items:center;gap:1rem;min-height:100vh;padding:0 1rem 2rem;display:flex}.site-header{background:#e8a87c;width:100%;margin:0 -1rem;padding:0;box-shadow:0 4px 16px #5c3d2e1a}.site-header-inner{justify-content:space-between;align-items:center;gap:1rem;width:min(1120px,100% - 2rem);min-height:4.25rem;margin:0 auto;padding:.8rem 0;display:flex}.brand-btn,.nav-btn{color:#fff;cursor:pointer;background:0 0;border:none}.brand-btn{padding:0;font-size:1.1rem;font-weight:800}.site-nav{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.35rem;display:flex}.nav-btn{border-radius:999px;padding:.4rem .7rem;font-size:.9rem;font-weight:700}.nav-btn:disabled{color:#ffffff94;cursor:not-allowed}.header{text-align:center;max-width:900px}.title{color:#5c3d2e;letter-spacing:.02em;margin:0;font-size:clamp(1.45rem,3.4vw,2rem);line-height:1.35}.subtitle{color:#8b6f5c;margin:.35rem 0 0;font-size:1rem}.mobile-break{display:none}.card{background:#fffaf3;border:2px solid #f0e0d0;border-radius:24px;width:100%;max-width:760px;padding:1.25rem;box-shadow:0 8px 24px #5c3d2e14}.quiz-card{flex-direction:column;gap:.75rem;max-width:860px;padding:.9rem 1rem 1rem;display:flex}.quiz-header{margin-top:-.25rem}.quiz-subtitle{color:#2f2520;margin:0;font-size:clamp(1.15rem,2.6vw,1.55rem);font-weight:800}.home-header{width:100%;margin:.9rem 0 1.35rem}.home-title{font-size:clamp(1.25rem,2.6vw,1.75rem)}.home-card{flex-direction:column;gap:1.25rem;width:100%;max-width:1120px;display:flex}.quiz-type-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem;display:grid}.quiz-type-card{background:#fffaf3;border:2px solid #f0e0d0;border-radius:24px;flex-direction:column;gap:1rem;min-height:520px;padding:1.25rem;display:flex;box-shadow:0 8px 24px #5c3d2e14}.quiz-type-visual{background:#f5ebe0;border-radius:20px;min-height:260px;overflow:hidden}.quiz-type-image{object-fit:cover;object-position:center;width:100%;height:100%;min-height:260px;display:block}.quiz-type-body{flex-direction:column;flex:1;gap:.6rem;display:flex}.quiz-type-heading{justify-content:space-between;align-items:flex-start;gap:.75rem;display:flex}.quiz-type-title{color:#5c3d2e;margin:0;font-size:1.35rem;line-height:1.35}.quiz-type-status{color:#5c3d2e;background:#ffe8d6;border-radius:999px;flex:none;padding:.25rem .65rem;font-size:.8rem;font-weight:700}.quiz-type-description{color:#6d5344;margin:0;line-height:1.7}.quiz-type-action{width:100%}.about-page{flex-direction:column;gap:1.25rem;width:100%;max-width:960px;display:flex}.about-hero{text-align:center;background:#fffaf3;border:2px solid #f0e0d0;border-radius:24px;padding:2rem 1.5rem;box-shadow:0 8px 24px #5c3d2e14}.about-title{color:#5c3d2e;margin:.3rem 0 0;font-size:clamp(1.8rem,5vw,2.5rem)}.about-lead{color:#6d5344;max-width:42rem;margin:.75rem auto 0;line-height:1.8}.about-actions{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.features{background:#fffaf3;border:2px solid #f0e0d0;border-radius:24px;padding:1.25rem;box-shadow:0 8px 24px #5c3d2e14}.features-title{color:#5c3d2e;text-align:center;margin:0 0 .9rem;font-size:1.2rem}.features-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;display:grid}.feature-item{background:#fff;border:2px solid #ead8c9;border-radius:16px;min-height:8rem;padding:1rem}.feature-item h3{color:#5c3d2e;margin:0 0 .45rem;font-size:1rem}.feature-item p{color:#6d5344;margin:0;font-size:.92rem;line-height:1.6}.start-card{flex-direction:column;gap:1rem;display:flex}.start-title{color:#5c3d2e;text-align:center;margin:0;font-size:1.35rem}.difficulty-list{gap:.75rem;display:grid}.difficulty-btn{color:#5c3d2e;cursor:pointer;background:#fff;border:2px solid #e8d4c4;border-radius:16px;justify-content:space-between;align-items:center;gap:1rem;min-height:4rem;padding:.85rem 1rem;font-size:1rem;font-weight:700;transition:background .15s,border-color .15s,transform .1s;display:flex}.difficulty-btn:not(:disabled):active{transform:scale(.98)}.difficulty-btn:disabled{color:#a58d7c;cursor:not-allowed;opacity:.75;background:#f7efe7}.difficulty-status{color:#8b6f5c;flex:none;font-size:.85rem;font-weight:700}.start-message,.start-error{text-align:center;margin:0;font-weight:700;line-height:1.6}.start-message{color:#7a5c4a}.start-error{color:#c62828}.progress{color:#7a5c4a;flex-wrap:wrap;justify-content:flex-start;align-items:center;gap:.75rem;font-size:.95rem;font-weight:600;display:flex}.score-badge{color:#5c3d2e;background:#ffe8d6;border-radius:999px;padding:.25rem .75rem;font-size:.85rem}.reset-btn{color:#7a5c4a;cursor:pointer;background:#fff;border:2px solid #e8d4c4;border-radius:999px;margin-left:auto;padding:.25rem .75rem;font-size:.85rem;font-weight:700;transition:background .15s,border-color .15s,transform .1s}.reset-btn:active{transform:scale(.98)}.quiz-image{aspect-ratio:16/8.2;object-fit:contain;object-position:center;background:#f5ebe0;border-radius:16px;width:100%;max-height:min(42vh,410px);display:block}.question-prompt{color:#2f2520;text-align:center;margin:0;font-size:clamp(1.05rem,2vw,1.25rem);font-weight:800;line-height:1.55}.prompt{text-align:center;color:#5c3d2e;margin:0;font-size:.92rem;font-weight:600}.choices{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.choice-btn{color:#5c3d2e;cursor:pointer;background:#fff;border:2px solid #e8d4c4;border-radius:16px;height:3rem;padding:.45rem .65rem;font-size:clamp(.78rem,1.45vw,.95rem);font-weight:600;line-height:1.2;transition:background .15s,border-color .15s,transform .1s}.choice-btn:active{transform:scale(.98)}.result{text-align:center;border-radius:20px;flex-direction:column;align-items:center;gap:.75rem;padding:1.25rem;display:flex}.result-correct{background:#e8f5e9;border:2px solid #a5d6a7}.result-incorrect{background:#ffebee;border:2px solid #ef9a9a}.result-label{margin:0;font-size:1.5rem;font-weight:700}.result-correct .result-label{color:#2e7d32}.result-incorrect .result-label{color:#c62828}.result-answer{color:#5c3d2e;margin:0;font-size:1.05rem}.result-answer strong{font-size:1.28em}.result-description{color:#6d5344;max-width:46rem;margin:0;font-size:1rem;line-height:1.6}.btn{cursor:pointer;border:none;border-radius:16px;padding:.85rem 1.5rem;font-size:1rem;font-weight:700;transition:background .15s,transform .1s}.btn-primary{color:#fff;background:#e8a87c;box-shadow:0 4px 12px #e8a87c66}.btn-secondary{color:#5c3d2e;background:#fff;border:2px solid #e8d4c4}.btn:disabled{color:#fffaf3;box-shadow:none;cursor:not-allowed;background:#d8c8ba}.btn-primary:active{transform:scale(.98)}@media (hover:hover){.difficulty-btn:not(:disabled):hover,.choice-btn:hover,.reset-btn:hover{background:#fff5eb;border-color:#d4a574}.nav-btn:not(:disabled):hover{background:#ffffff2e}.btn-primary:hover{background:#d4956a}.btn-secondary:hover{background:#fff5eb}.btn:disabled:hover{background:#d8c8ba}}.site-footer{color:#8b6f5c;justify-content:space-between;gap:1rem;width:100%;max-width:1120px;padding:1rem .25rem 0;font-size:.85rem;display:flex}.site-footer p{margin:0}.score-card{text-align:center;max-width:760px;margin-top:2rem;padding:2.5rem 1.5rem}.eyebrow{color:#8b6f5c;margin:0;font-weight:600}.score-title{color:#5c3d2e;margin:.5rem 0 0;font-size:1.5rem}.score-value{color:#e8a87c;margin:.5rem 0;font-size:clamp(3rem,12vw,4.5rem);font-weight:800;line-height:1.1}.score-total{color:#8b6f5c;font-size:.45em;font-weight:600}.score-message{color:#6d5344;margin:0 0 1.5rem;line-height:1.6}.summary{text-align:left;margin:1.5rem 0}.summary-title{color:#5c3d2e;text-align:center;margin:0 0 .75rem;font-size:1.1rem}.summary-list{gap:.75rem;display:grid}.summary-item{background:#fff;border:2px solid #ead8c9;border-radius:16px;grid-template-columns:120px 1fr;align-items:center;gap:.9rem;padding:.75rem;display:grid}.summary-correct{border-color:#a5d6a7}.summary-incorrect{border-color:#ef9a9a}.summary-image{aspect-ratio:4/3;object-fit:contain;object-position:center;background:#f5ebe0;border-radius:12px;width:100%;display:block}.summary-body{flex-direction:column;gap:.35rem;min-width:0;display:flex}.summary-heading{color:#5c3d2e;justify-content:space-between;gap:.75rem;font-size:.95rem;font-weight:700;display:flex}.summary-result{flex:none}.summary-answer{color:#6d5344;margin:0;font-size:.95rem;line-height:1.4}@media (width<=480px){.site-header{margin:0 -1rem}.site-header-inner{flex-direction:row;align-items:center;gap:.55rem;min-height:3.2rem;padding:.45rem 0}.brand-btn{flex:none;font-size:.95rem}.site-nav{scrollbar-width:none;flex-wrap:nowrap;flex:1;justify-content:flex-start;gap:.2rem;min-width:0;overflow-x:auto}.site-nav::-webkit-scrollbar{display:none}.nav-btn{flex:none;padding:.25rem .45rem;font-size:.74rem}.quiz-type-grid{grid-template-columns:1fr}.quiz-type-card{border-radius:20px;min-height:420px;padding:1rem}.quiz-type-visual{border-radius:16px;min-height:190px}.home-header{margin:.7rem 0 1.1rem}.home-title{font-size:1.2rem}.mobile-break{display:block}.features{border-radius:20px;padding:1rem}.features-grid{grid-template-columns:1fr}.about-hero{border-radius:20px;padding:1.5rem 1rem}.progress{flex-wrap:nowrap;align-items:center;gap:.35rem;font-size:.8rem}.score-badge{padding:.2rem .45rem;font-size:.74rem}.reset-btn{white-space:nowrap;padding:.2rem .45rem;font-size:.74rem}.choices{grid-template-columns:1fr 1fr;gap:.5rem}.card{border-radius:20px;padding:1rem}.quiz-image{aspect-ratio:16/9;border-radius:16px;max-height:34vh}.choice-btn{height:2.8rem;padding:.35rem .45rem;font-size:clamp(.68rem,3vw,.86rem)}.result{border-radius:16px;gap:.45rem;padding:.75rem}.result-label{font-size:1.15rem}.result-answer{font-size:.9rem}.result-description{max-width:none;font-size:.86rem;line-height:1.45}.summary-item{grid-template-columns:88px 1fr}.summary-heading{flex-direction:column;gap:.2rem}.site-footer{text-align:center;flex-direction:column;gap:.35rem}}
