@charset "utf-8";
/* ============================================================
   design.css ─ JSVES サイト デザイン現代化レイヤー (2026-05-18)
   既存 layout.css / responsive.css には触れず、最後に読み込まれて
   見た目を上書きする CSS。HTML 構造は一切変更しない方針。
   ============================================================ */

/* ===== 1. カラーパレット (CSS変数) =========================== */
:root {
    --jsves-primary: #0f4c81;      /* メインブルー (やや深め) */
    --jsves-primary-light: #2c6ca8;
    --jsves-primary-dark: #0a3559;
    --jsves-accent: #d65656;        /* 強調用 (お詫び・注意) */
    --jsves-bg: #f7f9fc;            /* 背景 (極淡ブルー) */
    --jsves-text: #2d3748;
    --jsves-text-secondary: #5a6878;
    --jsves-border: #e2e8f0;
    --jsves-card-bg: #ffffff;
    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
    --shadow-md: 0 4px 12px rgba(15, 76, 129, 0.08);
    --shadow-lg: 0 8px 24px rgba(15, 76, 129, 0.12);
    --radius-sm: 4px;
    --radius-md: 8px;
    --radius-lg: 12px;
    --transition: 0.2s ease-out;
}

/* ===== 2. ベースタイポグラフィ =============================== */
body {
    /* layout.css の font 定義を補強 (システムフォント優先) */
    font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue",
                 "Hiragino Sans", "Hiragino Kaku Gothic ProN",
                 "ヒラギノ角ゴ Pro W3", "Meiryo", "Yu Gothic", sans-serif !important;
    color: var(--jsves-text);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ===== 3. リンク =========================================== */
a {
    color: var(--jsves-primary);
    transition: color var(--transition);
}
a:link,
a:visited {
    color: var(--jsves-primary);
}
a:hover {
    color: var(--jsves-primary-light);
    text-decoration: underline;
}

/* ===== 4. ヘッダー画像エリア ================================ */
#header-area {
    box-shadow: var(--shadow-sm);
    margin-bottom: 0;
}

/* ===== 5. グローバルナビ: ホバー時の押し感 =================== */
#global-nav-area {
    background: linear-gradient(180deg, #f3f6fa 0%, #e3e9f0 100%);
    border-bottom: 2px solid var(--jsves-primary);
    padding: 4px 0;
    margin-bottom: 24px;
    box-shadow: var(--shadow-sm);
}
#global-nav-area ul li {
    transition: transform var(--transition);
}
#global-nav-area ul li a {
    transition: opacity var(--transition);
}
#global-nav-area ul li:hover {
    transform: translateY(-1px);
}
#global-nav-area ul li:hover a {
    opacity: 0.85;
}

/* ===== 6. パンくず ========================================= */
#topic_pass {
    background: var(--jsves-bg);
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--jsves-primary);
    font-size: 0.9em;
    color: var(--jsves-text-secondary);
}
#topic_pass li em {
    color: var(--jsves-primary-dark) !important;
    font-weight: 600;
}
#topic_pass a {
    text-decoration: none;
}

/* ===== 7. 見出しスタイル =================================== */
.headingA {
    border-bottom: 2px solid var(--jsves-primary);
    padding-bottom: 8px;
    margin-bottom: 20px;
}
.headingA h2 {
    color: var(--jsves-primary);
    font-size: 1.4em;
    font-weight: 700;
}
.headingA h2 .icon {
    background: var(--jsves-primary);
    color: #fff;
    padding: 4px 14px;
    border-radius: var(--radius-sm);
    display: inline-block;
    font-size: 0.95em;
}

.headingB {
    border-left: 4px solid var(--jsves-primary);
    padding-left: 12px;
    margin-bottom: 14px;
}
.headingB h3 {
    color: var(--jsves-primary-dark);
    font-size: 1.15em;
    font-weight: 600;
}

/* ===== 8. お知らせ一覧 (news_RAW.html 内含む) =============== */
#information,
.news #information,
#top #information {
    background: var(--jsves-card-bg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    border: 1px solid var(--jsves-border);
    padding: 8px 20px;
}
.liststyleA dl,
.news .liststyleA dl,
#top .liststyleA dl {
    border-bottom: 1px solid var(--jsves-border);
    background-image: none !important;  /* 古いdod_line01.gif を無効化 */
    padding: 14px 0;
}
.liststyleA dl:last-child {
    border-bottom: none;
}
.liststyleA dt {
    color: var(--jsves-text-secondary);
    font-size: 0.9em;
    font-weight: 600;
    margin-bottom: 6px;
}
.liststyleA dd {
    background-image: none !important;  /* 古い罫線 gif を無効化 */
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}
.liststyleA dd p a {
    text-decoration: none;
    line-height: 1.6;
}
.liststyleA dd p a:hover {
    text-decoration: underline;
}

/* news_RAW.html (iframe 内) 専用ベース */
body > #information,
body > div #information {
    margin: 0;
    box-shadow: none;
    border: none;
}

/* ===== 9. メインコンテンツエリア =========================== */
#main-area {
    background: var(--jsves-card-bg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    padding: 24px;
    border: 1px solid var(--jsves-border);
    box-sizing: border-box;
}

/* ===== 10. 古い <hr><p><strong><font> 見出しスタイル改善 ===
   本文中で多用されている <hr><p><strong>　<font size="+2">タイトル</font>
   を見やすく整える */
#main-area > hr:first-of-type,
#main-area > p > strong > font[size="+2"] {
    /* 古い見出しの font タグを保持しつつ表示改善 */
}
#main-area font[size="+2"] {
    color: var(--jsves-primary) !important;
    font-weight: 700 !important;
    font-family: inherit;
}
#main-area font[size="+1"] {
    font-family: inherit;
}
#main-area hr {
    border: none;
    border-top: 1px solid var(--jsves-border);
    margin: 18px 0;
}

/* ===== 11. 本文中の inline-style 背景セクション ============
   <p style="background-color:#000080"><font color="#FFFFFF"> 形式の
   "セクション見出し" を現代風に */
#main-area p[style*="background-color:#000080"] {
    background: var(--jsves-primary) !important;
    padding: 10px 16px !important;
    border-radius: var(--radius-sm);
    margin: 18px 0 12px !important;
    box-shadow: var(--shadow-sm);
}
#main-area p[style*="background-color:#3b86b1"],
#main-area p[style*="background-color:#4169e1"] {
    background: var(--jsves-primary-light) !important;
    padding: 12px 16px !important;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition), box-shadow var(--transition);
}
#main-area p[style*="background-color:#4169e1"]:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
#main-area a:has(p[style*="background-color"]) {
    text-decoration: none;
    display: inline-block;
}
#main-area p[style*="background-color:#B60B0B"] {
    background: var(--jsves-accent) !important;
    padding: 14px 20px !important;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
}

/* ===== 12. 右サイド: バナー画像 ============================ */
#right-area #banner-area li a {
    display: block;
    transition: transform var(--transition), opacity var(--transition);
}
#right-area #banner-area li a:hover {
    transform: translateY(-2px);
    opacity: 0.92;
}
#right-area #banner-area li a img {
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-sm);
}

/* ===== 13. 文字サイズ切替: 非表示 (要望により) ============== */
#font-size {
    display: none !important;
}

/* ===== 14. フッターナビ =================================== */
#footer-nav {
    background: var(--jsves-bg);
    border: none;
    border-top: 1px solid var(--jsves-border);
    padding: 16px 0;
    margin-top: 30px;
    margin-bottom: 0;
}
#footer-nav ul li {
    font-size: 0.9em;
}
#footer-nav a {
    text-decoration: none;
    color: var(--jsves-text);
    transition: color var(--transition);
}
#footer-nav a:hover {
    color: var(--jsves-primary);
}

#footer-area {
    background: var(--jsves-primary-dark) !important;
    padding: 8px 0;
}
#footer-area address {
    color: rgba(255, 255, 255, 0.85);
    font-size: 0.85em;
}

.footer_block {
    padding: 14px 10px;
    border-bottom: 1px solid var(--jsves-border);
}
.footer_block .boxR li {
    font-size: 0.85em;
}
.footer_block .boxR a {
    color: var(--jsves-text) !important;
    transition: color var(--transition);
}
.footer_block .boxR a:hover {
    color: var(--jsves-primary) !important;
}

/* ===== 15. 表組み (役員一覧 / 訂正表 など) ================= */
#main-area table {
    border-collapse: collapse;
    width: 100%;
    margin: 12px 0;
    background: var(--jsves-card-bg);
    border-radius: var(--radius-sm);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
}
#main-area table td,
#main-area table th {
    padding: 10px 14px;
    border-bottom: 1px solid var(--jsves-border);
}
#main-area table tr:last-child td {
    border-bottom: none;
}
#main-area table tr:hover td {
    background: var(--jsves-bg);
}

/* ===== 16. リスト (sectionB 等) ============================ */
#main-area .liststyleB {
    background: var(--jsves-bg);
    padding: 14px 18px;
    border-radius: var(--radius-sm);
    border-left: 3px solid var(--jsves-primary);
    margin: 12px 0;
}

/* ===== 17. iframe (お知らせ枠) スタイル化 ================== */
iframe[src*="news_RAW"] {
    border: 1px solid var(--jsves-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    background: var(--jsves-card-bg);
}

/* ===== 18. body 全体 (デスクトップ時) ====================== */
@media (min-width: 941px) {
    body {
        background: var(--jsves-bg) !important;
    }
    #wrapper {
        background: var(--jsves-card-bg);
        box-shadow: var(--shadow-lg);
        border-radius: var(--radius-md);
        overflow: hidden;
        margin-top: 16px !important;
        margin-bottom: 16px !important;
    }
    /* #contents-area は元 900px の中に main-area(670) + right-area(210) = 880px を
       float で配置している。padding を追加すると right-area が下に押し出される。
       垂直方向の padding のみ追加する。 */
    #contents-area {
        padding-top: 12px;
        padding-bottom: 24px;
    }
}

/* ===== 19. レスポンシブ調整 (タブレット以下) ================ */
@media (max-width: 768px) {
    #main-area {
        padding: 16px;
    }
    #right-area #banner-area li a img {
        max-width: 200px;
    }
    .headingA h2 {
        font-size: 1.2em;
    }
}

/* ===== 20. フォーカス可視化 (アクセシビリティ) ============== */
a:focus-visible,
button:focus-visible {
    outline: 2px solid var(--jsves-primary);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}

/* ===== 21. 印刷時のクリーンアップ ========================== */
@media print {
    #global-nav-area,
    #right-area,
    #font-size,
    #footer-nav {
        display: none !important;
    }
    #wrapper {
        box-shadow: none !important;
    }
}
