/* ========================================= */
/* Committee Page Styles (委員會與團隊頁面)
/* ========================================= */
/* --- 1. 委員會：一塊大網邊 (單欄往下排列) --- */
.team-grid {
    display: grid;
    grid-template-columns: 1fr; /* 強制單欄往下排列 */
    background-color: #eaeaea; /* 大外框與內部格線的顏色 */
    border: 1px solid #d0d7de;
    border-radius: 8px;
    overflow: hidden; /* 確保圓角生效 */
    gap: 1px; /* 利用 1px 的縫隙露出背景色，形成內部格線 */
}

.team-card {
    background: #ffffff; /* 每個項目的底色 */
    padding: 20px 24px;
    display: flex; /* 改用 Flexbox 讓內部內容橫向對齊 */
    align-items: center; /* 垂直置中 */
    transition: background 0.3s ease;
    border: none; /* 移除原本個別的邊框 */
    border-radius: 0; /* 移除原本個別的圓角 */
    box-shadow: none; /* 移除陰影 */
}


.team-card .role {
    flex: 0 0 220px; /* 固定職稱寬度，讓下方每一列都對齊 */
    font-size: 14px;
    color: #888888;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 0; /* 移除原本的底部間距 */
}

.team-card .name {
    flex: 0 0 180px; /* 固定姓名寬度，讓下方每一列都對齊 */
    font-size: 18px;
    font-weight: 700;
    color: #333333;
    margin-bottom: 0; /* 移除原本的底部間距 */
}

.team-card .org {
    flex: 1; /* 機構名稱填滿剩餘的所有空間 */
    font-size: 15px;
    color: #555555;
    line-height: 1.4;
}

/* --- 2. 工作人員：一塊大網邊 (Table-like Grid) --- */

.staff_role {
    flex: 0 0 140px; 
    font-size: 14px;
    font-weight: 600;
    color: #666666;
}

.staff_name {
    font-size: 16px;
    font-weight: 500;
    color: var(--dark_color);
}
/* --- 3. 貢獻者/連結模組：Logo Grid --- */
.contributors_grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 20px;
}

.sponsor_logo {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 110px;
    background: #ffffff;
    border: 1px solid #d0d7de;
    border-radius: 8px;
    padding: 20px;
    transition: all 0.3s ease;
    text-decoration: none;
}

/* --- 貢獻者/連結 Hover 動畫效果 --- */
.sponsor_logo:hover {
    
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); /* 增加卡片浮現的陰影 */
    transform: translateY(-4px); /* 整個區塊微微向上浮動 */
}

.sponsor_logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* 確保各種比例的 Logo 都能完美塞入且不變形 */
    transition: transform 0.3s ease; /* 讓圖片縮放時有平滑的過渡效果 */
}

.sponsor_logo:hover img {
    transform: scale(1.05); /* 滑鼠移入時，Logo 圖片本身也會微微放大 5% */
}

.sponsor_logo img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* 確保各種比例的 Logo 都能完美塞入且不變形 */
}


@media (max-width: 768px) {
    /* 讓委員會的內容在螢幕變窄時，改為上下堆疊顯示 */
    .team-card {
        flex-direction: column;
        align-items: flex-start;
        padding: 16px 20px;
    }
    
    .team-card .role {
        flex: auto;
        margin-bottom: 4px;
        font-size: 13px;
    }
    
    .team-card .name {
        flex: auto;
        margin-bottom: 6px;
    }
    
    .team-card .org {
        flex: auto;
    }
}
/* --- 手機版 RWD 微調 --- */
@media (max-width: 576px) {
    .text_area li {
        flex-direction: column;
        align-items: flex-start;
        padding: 14px 18px;
    }
    
    .staff_role {
        flex: auto;
        margin-bottom: 6px;
        font-size: 13px;
        color: #888888; /* 手機板職稱稍微調淡，讓名字更凸顯 */
    }
    
    .contributors_grid {
        grid-template-columns: repeat(2, 1fr); 
        gap: 15px;
    }
    .sponsor_logo {
        height: 90px;
        padding: 15px;
    }
}