@charset "shift_jis";

/* 既存のスタイルを保持しつつ、現代的な構造をサポート */

/* 基本リセット */
* {
    box-sizing: border-box;
}

body {
    margin: 0;
    padding: 0;
    background-color: #FFFF99;
    color: #333333;
    font-family: "MS Gothic", "Osaka", monospace;
}

/* リンクスタイル（既存と同じ） */
a {
    color: #009900;
    text-decoration: underline;
}

a:visited {
    color: #009900;
}

a:hover {
    color: #FF6600;
}

a:active {
    color: #FF6600;
}

/* 現代的なレイアウト用のコンテナ */
.page-container {
    display: grid;
    grid-template-areas: 
        "header header"
        "nav main";
    grid-template-columns: 170px 1fr;
    grid-template-rows: 110px 1fr;
    min-height: 100vh;
    max-width: 1200px;
    margin: 0 auto;
}

.site-header {
    grid-area: header;
    background-color: #FFFF66;
    padding: 0;
    margin: 0;
}

.site-nav {
    grid-area: nav;
    background-color: #FFFF99;
    width: 170px;
    overflow-y: auto;
}

.main-content {
    grid-area: main;
    background-color: #FFFF99;
    padding: 0;
    margin: 0;
}

/* 記事コンテンツのスタイル（既存のテーブルレイアウトを模倣） */
.report-container {
    width: 601px;
    margin: 0;
    padding: 0;
    background-color: #FFFFFF;
}

.report-content {
    width: 561px;
    margin: 0 auto;
    padding: 20px;
    text-align: center;
}

.report-content h1 {
    font-size: 16px;
    font-weight: bold;
    margin: 0;
    padding: 0;
}

.report-content h2 {
    font-size: 14px;
    font-weight: bold;
    margin: 20px 0 10px 0;
    text-align: left;
}

.report-content h3 {
    font-size: 12px;
    font-weight: bold;
    margin: 15px 0 5px 0;
    text-align: left;
}

.report-content p {
    font-size: 12px;
    line-height: 1.6;
    margin: 10px 0;
    text-align: left;
}

/* 画像のスタイル */
.report-content img {
    border: 0;
    max-width: 100%;
    height: auto;
}

/* テーブルスタイル（既存のものを保持） */
.report-content table {
    border-collapse: collapse;
    margin: 10px 0;
}

.report-content table td {
    padding: 2px;
    vertical-align: top;
}

/* フッターナビゲーション */
.report-footer {
    width: 500px;
    margin: 20px auto 0;
    background-color: #FFFFFF;
}

.report-nav {
    border-collapse: collapse;
    width: 100%;
}

.report-nav td {
    padding: 2px;
    text-align: center;
}

.report-nav .nav-back {
    text-align: left;
    width: 120px;
}

.report-nav .nav-center {
    text-align: center;
    width: 260px;
}

.report-nav .nav-forward {
    text-align: right;
    width: 120px;
}

/* 著作権表示 */
.copyright {
    font-size: 10px;
    color: #333333;
    text-align: center;
    margin: 20px 0;
}

/* 外部リンク情報ボックス */
.info-box {
    width: 500px;
    margin: 0 auto;
    background-color: #FFFFCC;
    border: 0;
    padding: 3px;
    text-align: center;
}

.info-box font {
    font-size: 10px;
}

/* レスポンシブ対応（既存のデザインを崩さない範囲で） */
@media (max-width: 800px) {
    .page-container {
        grid-template-areas:
            "header"
            "nav"
            "main";
        grid-template-columns: 1fr;
        grid-template-rows: auto auto 1fr;
    }
    
    .site-nav {
        width: 100%;
        overflow-x: auto;
    }
    
    .report-container {
        width: 100%;
        max-width: 601px;
    }
    
    .report-content {
        width: 100%;
        max-width: 561px;
        padding: 10px;
    }
    
    .report-footer {
        width: 100%;
        max-width: 500px;
    }
}

/* 既存の画像ホバー効果をサポート */
.nav-image {
    transition: opacity 0.1s ease;
}

.nav-image:hover {
    opacity: 0.8;
}