@charset "UTF-8";

/* ==========================================================
   EVENT PAGE STYLES (2026 Refactor - Image Animation Fix)
   ========================================================== */

/* ----------------------------------------------------------
   アニメーション定義 (不透明度のみ)
   ---------------------------------------------------------- */
@keyframes tnsbFadeIn {
    0%   { opacity: 0; }
    100% { opacity: 1; }
}

/* ----------------------------------------------------------
   基本レイアウト
   ---------------------------------------------------------- */
.event_list-wrap {
    max-width: 1000px;
    margin: 0 auto 120px;
}

/* ----------------------------------------------------------
   イベントリスト (Event Item)
   ---------------------------------------------------------- */
.event_item {
    display: flex;
    justify-content: space-between; /* 左右に配置 */
    align-items: flex-start;
    padding: 40px 0;
    border-bottom: 1px solid #eee;
    text-decoration: none;
    color: inherit;
    transition: opacity 0.3s;
    /* カード全体のアニメーションは削除 */
}
.event_item:hover {
    opacity: 0.7;
}

/* ▼ テキストエリア（左側） */
.event_item .txt {
    width: 55%; /* テキスト幅 */
    padding-right: 40px;
    box-sizing: border-box;
}

/* サブタイトル */
.event_item .txt .sub {
    font-size: 1em;
    font-weight: 500;
    margin-bottom: 0.5em;
    line-height: 1.4;
    display: block;
}

/* メインタイトル */
.event_item .txt h3 {
    font-size: 1.5em;
    font-weight: 700;
    line-height: 1.2;
    margin: 0 0 0.5em;
    letter-spacing: 0.02em;
}

/* 日付・場所 */
.event_item .txt .meta {
    font-size: 0.85em;
    color: #959595;
    font-weight: 500;
    letter-spacing: 0.05em;
}
.event_item .txt .meta span {
    margin-right: 0.5em;
}
.event_item .txt .meta span + span:before {
    content: "|";
    color: #bdbdbd;
    margin-right: 0.5em;
}

/* ▼ 画像エリア（右側） */
.event_item .img {
    width: 40%;
    border: 1px solid #e8e8e8;
    box-sizing: border-box;
    
    /* ガタつき防止：読み込み前のスペース確保 */
    aspect-ratio: 16 / 10;
    background-color: #f5f5f5; /* 読み込み中はグレー */
    overflow: hidden;
}

.event_item .img img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* 枠いっぱいにトリミング表示 */
    display: block;
    
    /* ▼▼▼ 画像のみふわっと表示 ▼▼▼ */
    opacity: 0;
    animation: tnsbFadeIn 0.4s ease-out forwards;
}

/* ----------------------------------------------------------
   スマホ対応
   ---------------------------------------------------------- */
@media (max-width: 780px) {
    .event_list-wrap {
        padding: 0;
        margin-bottom: 60px;
    }

    .event_item {
        display: flex;
        flex-direction: column-reverse; 
        padding: 0 0 60px;
        border: none;
    }

    /* 画像：横幅いっぱい */
.event_item .img {
width: 110%;
margin-bottom: 12px;
border: none;
aspect-ratio: 16 / 10;
left: -5%;
position: relative;
}

    /* 画像はみ出し配置（元のデザイン維持） */
    .event_item .img img {
        width: 110%;
        height: 100%;
        position: relative;
        left: -5%;
    }
    
    /* テキスト */
    .event_item .txt {
        width: 100%;
        padding-right: 0;
    }
    
    .event_item .txt .sub {
        font-size: 0.9em;
    }
    .event_item .txt h3 {
        font-size: 1.4em;
    }
}