/* ========================================
   問題作成マニュアルページ
   - h3で挟まれた見出しは中央配置
   - <d>ブロック = 左に画像・右に説明（タブレット以上）
   - 画像はビューポートが大きくても拡大しない
   ======================================== */

/* h3で挟まれている見出し（セクション名）は中央配置 */
.manual-section-title {
    text-align: center;
    font-size: 1.1rem;
    font-weight: 600;
    color: #4a5568;
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

/* <d>ブロック = 1行（画像+説明） */
/* スマホ幅: 説明文→画像の順（column-reverseで表示） */
.manual-row {
    display: flex;
    flex-direction: column-reverse;
    gap: 1rem;
    margin: 1.25rem 0;
    align-items: flex-start;
}

/* タブレット幅以上: 左に画像、右に説明文 */
@media (min-width: 768px) {
    .manual-row {
        flex-direction: row;
        align-items: flex-start;
        gap: 1.5rem;
    }
}

/* 画像エリア: 拡大しない（最大幅で固定） */
.manual-row-image {
    flex-shrink: 0;
    max-width: 320px;
    width: 100%;
}

.manual-row-image img {
    max-width: 100%;
    height: auto;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
    display: block;
}

/* 複数画像を1つのd内に含む場合（大元のアスペクト比を保持） */
.manual-row-image--multi {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    max-width: 320px;
    align-items: flex-start; /* 画像同士で高さを揃えず、各画像の元の比率を保持 */
}

.manual-row-image--multi img {
    max-width: calc(50% - 0.25rem);
    width: auto;
    height: auto;
    object-fit: contain; /* はみ出さず元の比率で表示 */
}

@media (min-width: 768px) {
    .manual-row-image--multi {
        max-width: 320px;
    }
}

/* 説明文エリア */
.manual-row-text {
    flex: 1;
    min-width: 0;
}

.manual-row-text .document-text,
.manual-row-text p {
    margin: 0 0 0.5rem 0;
}

.manual-row-text ul {
    margin: 0;
    padding-left: 1.5rem;
}

.manual-row-text ul li {
    margin-bottom: 0.25rem;
}

/* スマホ幅では画像を中央寄せで表示 */
@media (max-width: 767px) {
    .manual-row-image {
        margin: 0 auto;
    }

    .manual-row-image--multi {
        justify-content: center;
    }
}
