/* =========================================
   令和8年度版 高校デジタルAI教科書 サポートサイト
   メインスタイルシート
========================================= */

/* 指定の3色をベースにしたカラーパレット */
:root {
    --color-navy: #235180;   /* メインカラー（利用者向け・ヘッダー・タイトル） */
    --color-orange: #FF9800; /* アクセントカラー（管理者向け・注意喚起） */
    --color-gray: #B6B6B6;   /* ニュートラルカラー（枠線・補足テキスト） */
    
    --text-main: #333333;
    --bg-page: #f4f7f9;      /* ネイビーとオレンジが映える薄いグレー背景 */
    --bg-section: #ffffff;
    --shadow-soft: 0 8px 30px rgba(0,0,0,0.05);
}

/* --- 1. 全体のベース（弱） --- */
body {
    font-family: 'Inter', 'Noto Sans JP', sans-serif;
    color: #4a5568; /* 少しグレーにして見出しとの差をつける */
    font-weight: 400; /* 基本は普通の太さ */
    line-height: 1.8;
    letter-spacing: 0.03em;
    margin: 0;
    padding: 0;
    background-color: var(--bg-page);
    -webkit-font-smoothing: antialiased;
}

/* --- メインコンテンツの幅と余白 --- */
main {
    max-width: 900px;  /* 画面が横に広がりすぎないように最大幅を制限 */
    margin: 60px auto; /* 上下に60pxの余白、左右は自動（auto）で中央揃え */
    padding: 0 20px;   /* スマホなどで画面幅が狭い時に端にくっつかないための余白 */
}

/* ヘッダーとフッター（ネイビーで統一） */
.site-header, .site-footer {
    background-color: var(--color-navy);
    color: #ffffff;
}

/* --- ヘッダー領域 --- */
.site-header {
    /* 1. ベースのグラデーション（ネイビーから少し明るいブルーへ） */
    /* 2. デジタル感のあるドットパターン（20px間隔の薄い白い点）を重ねる */
    background-image: 
        radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px), 
        linear-gradient(135deg, var(--color-navy) 0%, #1e4066 100%);
    background-size: 20px 20px, 100% 100%;
    
    padding: 70px 20px; /* アイコンが入る分、上下の余白を少し広げました */
    text-align: center;
    color: #ffffff;
    position: relative;
    overflow: hidden;
}

.header-container {
    max-width: 800px;
    margin: 0 auto;
    position: relative;
    z-index: 2; /* 背景のドットより手前に文字を出す */
}

/* 会社名のスタイル */
.header-company {
    margin: 0 0 10px 0;
    font-size: 0.8rem;
    font-family: 'Inter', sans-serif;
    letter-spacing: 0.15em;
    color: var(--color-orange);
    font-weight: 700;
}

/* メインタイトル */
.header-container h1 { 
    font-family: 'Mochiy Pop One', sans-serif; 
    margin: 0 0 20px 0; 
    font-size: 1.8rem; 
    font-weight: 400; 
    letter-spacing: 0.05em; 
    line-height: 1.5; 
    text-shadow: 0 2px 4px rgba(0,0,0,0.2); 
}

/* サイトの目的を伝えるリード文 */
.header-lead {
    margin: 0;
    font-size: 0.95rem;
    color: #e0e7ff; 
    line-height: 1.8;
    font-weight: 400;
}

/* スマホ用のサイズ調整部分 */
@media (max-width: 600px) {
    .site-header { padding: 50px 20px; }
    .header-container h1 { font-size: 1.3rem; }
    .header-lead { font-size: 0.85rem; }
    .header-lead br { display: none; }
}

/* --- セクション設定 --- */
.section-container {
    background-color: var(--bg-section);
    border-radius: 16px;
    padding: 60px 50px;
    margin-bottom: 50px;
    box-shadow: var(--shadow-soft);
}
@media (max-width: 600px) { .section-container { padding: 40px 20px; } }

/* --- 2. 各種見出し（強） --- */
.section-title {
    font-family: 'Mochiy Pop One', sans-serif; /* セクション見出しにもMochiyを適用 */
    text-align: center;
    font-size: 1.6rem;
    font-weight: 400; /* Mochiyは元々太いので400で丁度よくなります */
    color: var(--color-navy);
    margin-top: 0;
    margin-bottom: 50px;
    letter-spacing: 0.05em;
}

/* --- 4. 英語のアクセント（引き締め） --- */
.en-title {
    display: block;
    font-family: 'Mochiy Pop One', sans-serif; /* 英語のサブタイトルも揃える */
    font-size: 0.8rem; /* フォントに合わせて少し調整 */
    color: var(--color-gray);
    letter-spacing: 0.15em;
    margin-top: 12px;
    font-weight: 400; /* こちらも400に調整 */
}

/* --- 3. 説明文・補足（弱） --- */
.section-desc { 
    text-align: center; 
    color: #718096; 
    margin-bottom: 40px; 
    font-size: 0.95rem;
    font-weight: 400;
}

/* 🌟ログインカードの差別化🌟 */
.button-container { display: flex; gap: 30px; }
@media (max-width: 650px) { .button-container { flex-direction: column; } }

.login-card {
    flex: 1;
    background: #ffffff;
    padding: 40px 30px 30px;
    border: 1px solid var(--color-gray);
    border-radius: 16px;
    text-align: center;
    position: relative;
    transition: all 0.3s ease;
}
.login-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-soft); }

/* 上部の太いライン */
.admin-card { border-top: 6px solid var(--color-orange); }
.user-card { border-top: 6px solid var(--color-navy); }

/* 役割を示す小さなバッジ */
.card-badge {
    position: absolute;
    top: -15px;
    left: 50%;
    transform: translateX(-50%);
    padding: 4px 16px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 700;
    color: #fff;
}
.admin-badge { background-color: var(--color-orange); }
.user-badge { background-color: var(--color-navy); }

/* SVGイラストを囲む丸い背景 */
.icon-wrapper {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}
.admin-icon { background-color: #fff4e6; color: var(--color-orange); }
.user-icon { background-color: #eaf0f6; color: var(--color-navy); }

.login-card h3 { 
    font-size: 1.1rem; 
    font-weight: 700; 
    margin-top: 0; 
    line-height: 1.6;
    color: #1a202c;
}
.login-card p { 
    font-size: 0.85rem; 
    color: #718096; 
    margin-bottom: 30px;
    font-weight: 400;
}

/* --- 5. ボタン（強） --- */
.btn {
    display: inline-block;
    padding: 16px 0;
    color: white;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700; 
    letter-spacing: 0.05em;
    border-radius: 8px;
    transition: all 0.3s ease;
    width: 100%;
}
.btn-admin { background-color: var(--color-orange); }
.btn-admin:hover { background-color: #e68900; }
.btn-user { background-color: var(--color-navy); }
.btn-user:hover { background-color: #1d436a; }

/* --- 新着情報 --- */
.news-wrapper { max-width: 650px; margin: 0 auto; }
.news-list { list-style: none; padding: 0; margin: 0; border-top: 1px solid var(--color-gray); }
.news-item { padding: 20px 0; border-bottom: 1px solid var(--color-gray); font-size: 0.95rem; display: flex; }
@media (max-width: 500px) { .news-item { flex-direction: column; } }
.news-item .date { 
    font-family: 'Inter', sans-serif; 
    color: var(--color-navy); 
    margin-right: 25px; 
    font-size: 0.9rem; 
    font-weight: 700; 
    min-width: 90px; 
}
.extra-news { display: none; opacity: 0; transition: opacity 0.4s ease; }

.btn-more {
    display: block;
    margin: 40px auto 0;
    padding: 10px 30px;
    background-color: #ffffff;
    border: 1px solid var(--color-gray);
    color: var(--text-main);
    border-radius: 30px;
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 700;
    transition: all 0.3s ease;
}
.btn-more:hover { border-color: var(--color-navy); color: var(--color-navy); }

/* --- マニュアル --- */
.doc-links { display: flex; gap: 15px; flex-wrap: wrap; margin-bottom: 40px; justify-content: center; }
.doc-link {
    display: flex;
    align-items: center;
    padding: 15px 25px;
    background-color: #ffffff;
    border: 1px solid var(--color-gray);
    border-radius: 8px;
    text-decoration: none;
    color: var(--text-main);
    font-size: 0.95rem;
    font-weight: 700;
    transition: all 0.3s;
}
.doc-link:hover { border-color: var(--color-navy); background-color: #f4f7f9; }

.attention-box {
    background-color: #fff9f0; 
    padding: 25px 30px;
    border-radius: 8px;
    border-left: 4px solid var(--color-orange);
    font-size: 0.85rem;
    color: #718096;
    font-weight: 400;
}
.attention-box p { margin: 0; line-height: 1.8; }

/* --- FAQ アコーディオン --- */
.faq-container { max-width: 700px; margin: 0 auto; border-top: 2px solid var(--color-navy); }
.faq-item { border-bottom: 1px solid var(--color-gray); }
.faq-question {
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    padding: 25px 10px;
    font-size: 1rem;
    font-weight: 700; 
    color: #2d3748;
    cursor: pointer;
    position: relative;
    outline: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.faq-question::after { content: '＋'; color: var(--color-gray); transition: transform 0.3s; font-weight: 400; }
.faq-question.active::after { transform: rotate(45deg); color: var(--color-orange); }
.faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
.faq-answer p { 
    padding: 0 10px 25px 10px; 
    margin: 0; 
    color: #718096; 
    font-size: 0.95rem; 
    line-height: 1.8; 
    font-weight: 400;
}

/* --- FAQ内のテーブル用スタイル --- */
.env-wrapper {
    overflow-x: auto; 
    margin: 15px 10px 20px 10px;
}
.env-table {
    width: 100%;
    border-collapse: collapse; 
    background-color: #ffffff;
    font-size: 0.9rem;
}
.env-table th, 
.env-table td {
    border: 1px solid var(--color-gray);
    padding: 12px 15px;
    text-align: left;
    font-weight: 400;
    color: #4a5568;
}
.env-table th {
    background-color: #f4f7f9; 
    color: var(--color-navy);
    font-weight: 700;
}
.faq-notes {
    font-size: 0.85rem;
    color: #718096;
    margin-top: 0;
    font-weight: 400;
}
.faq-answer a {
    color: var(--color-navy);
    text-decoration: underline;
    font-weight: 700;
}
.faq-answer a:hover {
    opacity: 0.7;
}

/* FAQ内の画像スタイル */
.faq-answer img {
    display: block;
    max-width: 100%;   /* 枠からはみ出さない */
    height: auto;      /* 縦横比を維持 */
    margin: 10px 0;    /* 上下に少し隙間を作る */
    border-radius: 8px; /* 少し角を丸くして柔らかい印象に */
}

/* --- お問い合わせ --- */
.contact-cards { display: flex; gap: 20px; max-width: 800px; margin: 0 auto; }
@media (max-width: 600px) { .contact-cards { flex-direction: column; } }
.contact-card {
    flex: 1;
    background-color: #ffffff;
    border: 1px solid var(--color-gray);
    padding: 40px 30px;
    border-radius: 12px;
    text-align: center;
}
.contact-card h4 { 
    margin: 0 0 10px 0; 
    font-size: 1rem; 
    font-weight: 700; 
    color: #1a202c; 
}
.contact-card p { 
    font-size: 0.85rem; 
    color: #718096; 
    margin-bottom: 25px; 
    font-weight: 400; 
}
.email-link {
    display: inline-block;
    color: var(--color-navy);
    font-family: 'Inter', sans-serif;
    text-decoration: none;
    font-size: 1rem;
    font-weight: 700;
    border-bottom: 2px solid var(--color-navy);
    padding-bottom: 2px;
    transition: opacity 0.3s;
}
.email-link:hover { opacity: 0.6; }

/* --- フッター --- */
.footer {
    text-align: center;
    padding: 60px 20px;
    max-width: 900px;
    margin: 0 auto;
    font-size: 0.85rem;
}
.footer .f_logo { margin: 0 0 20px 0; }
.footer .f_logo img { max-width: 300px; height: auto; }
.footer .copy { margin: 0 0 15px 0; color: var(--color-gray); font-family: 'Inter', sans-serif;}
.footer a.wb { color: var(--color-gray); text-decoration: none; transition: color 0.3s; }
.footer a.wb:hover { color: #ffffff; }

/* --- スクロールフェードイン用 --- */
.fade-in {
    opacity: 0; 
    transform: translateY(30px); 
    transition: opacity 0.8s ease, transform 0.8s ease; 
}
.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* --- トップへ戻るボタン --- */
.back-to-top {
    position: fixed; 
    bottom: 30px;    
    right: 30px;     
    width: 50px;
    height: 50px;
    background-color: var(--color-navy); 
    color: #ffffff;
    border: none;
    border-radius: 50%; 
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15); 
    
    opacity: 0;
    visibility: hidden;
    transform: translateY(20px);
    transition: all 0.3s ease; 
    z-index: 1000; 
}
.back-to-top.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.back-to-top:hover {
    background-color: var(--color-orange);
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}
@media (max-width: 600px) {
    .back-to-top {
        bottom: 20px;
        right: 20px;
        width: 45px;
        height: 45px;
    }
}