@charset "UTF-8";

:root {
    --bg-wood: #3e2723;
    --paper: #fdfbf7;
    --ink: #2b2b2b;
    --gold: #c5a059;
    --accent-science: #2e7d32;
    --font-main: 'Shippori Mincho', serif;
}

* { box-sizing: border-box; touch-action: manipulation; }

body {
    margin: 0; padding: 0;
    background-color: var(--bg-wood);
    color: var(--ink);
    font-family: var(--font-main);
    min-height: 100vh;
    font-size: 16px; /* スマホでの文字サイズ確保 */
}

#app {
    max-width: 800px; margin: 0 auto; padding: 15px;
    width: 100%;
}

header {
    text-align: center; padding: 20px 0;
    border-bottom: 2px solid var(--gold); margin-bottom: 20px;
}
h1 { color: var(--paper); margin: 0; font-size: 1.8rem; }
.subtitle { color: var(--gold); margin-top: 5px; font-size: 0.9rem; }

.panel {
    background-color: var(--paper);
    border-radius: 4px; padding: 20px; margin-bottom: 20px;
    border-left: 6px solid var(--gold); /* スマホ用に少し細く */
    display: none; opacity: 0; transition: opacity 0.5s;
}
.panel.active { display: block; opacity: 1; }

.form-group { margin-bottom: 20px; }
label { display: block; font-weight: bold; margin-bottom: 8px; border-bottom: 1px solid #ccc; width: fit-content; }
select, input[type="text"] {
    width: 100%; padding: 12px; font-size: 1rem;
    border: 1px solid #ccc; border-radius: 4px; font-family: sans-serif;
    background: #fff;
}

/* 単元選択チェックボックス（スマホ対応強化） */
.unit-checkbox-container {
    border: 1px solid #ccc;
    border-radius: 4px;
    background: #fff;
    max-height: 250px; /* 少し高く */
    overflow-y: auto;
    padding: 5px;
    -webkit-overflow-scrolling: touch; /* iOSスクロール滑らかに */
}
.unit-option {
    display: flex; /* フレックスボックスで配置 */
    align-items: center;
    margin-bottom: 0;
    cursor: pointer;
    padding: 12px 8px; /* タップ領域を広げる */
    border-bottom: 1px dashed #eee;
    font-size: 1rem;
}
.unit-option:active { background-color: #f0f0f0; }
.unit-option input {
    margin-right: 12px;
    transform: scale(1.3); /* チェックボックスを大きく */
}

.subject-tabs { display: flex; gap: 10px; margin-bottom: 20px; }
.tab-btn {
    flex: 1; padding: 12px; background: #eee; border: 1px solid #ccc; 
    cursor: pointer; font-size: 1rem; border-radius: 4px;
    font-weight: bold;
}
.tab-btn.active { background: var(--gold); color: white; border-color: var(--gold); }

.btn-action {
    width: 100%; padding: 16px; font-size: 1.1rem; font-weight: bold;
    color: white; background: var(--bg-wood); border: none; cursor: pointer;
    margin-top: 15px; border-radius: 6px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.1);
    transition: transform 0.1s;
}
.btn-action:active { transform: translateY(2px); box-shadow: none; }

/* 問題表示周り */
.question-box { margin-top: 15px; }
#q-text { font-size: 1.1rem; line-height: 1.6; }
.image-area img { max-width: 100%; height: auto; border-radius: 4px; margin-top: 10px; }

/* 正誤判定ボタンエリア */
.judge-buttons {
    display: grid; 
    grid-template-columns: 1fr 1fr; 
    gap: 15px;
    margin-top: 20px;
}

/* 結果画面 */
.score-display {
    font-size: 3.5rem; text-align: center; color: var(--bg-wood); 
    font-weight: bold; font-family: 'Zen Kurenaido';
    margin: 20px 0;
}
.review-list {
    max-height: 50vh; overflow-y: auto; 
    border: 1px solid #ddd; border-radius: 4px;
}

/* スマホ横幅が狭い場合への対応 */
@media (max-width: 480px) {
    h1 { font-size: 1.5rem; }
    .panel { padding: 15px; border-left-width: 4px; }
    .btn-action { font-size: 1rem; padding: 14px; }
    .score-display { font-size: 2.8rem; }
}