/* ブラウザのデフォルト余白をリセット */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: sans-serif;
    color: #333;
    background-color: #fff;
    /* 【変更点】overflow: hidden を削除し、ブラウザ本来のスクロールに任せます */
}

/* 画面を左右に分ける大枠のコンテナ */
.page-layout {
    display: flex;
    /* 【変更点】height: 100vh ではなく、最低限の高さとして min-height を指定 */
    min-height: 100vh; 
}

/* =========================================
   左側：サイドバー（リンクブロック領域）
   ========================================= */
.sidebar {
    width: 280px;
    flex-shrink: 0; /* 画面が狭くなっても280pxを維持 */
    padding: 32px 20px;
    border-right: 1px solid #bbbbbb;
    background-color: #f3f4f6;
}

.article-links {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* モノクロの四角いリンクブロック本体 */
.link-block {
    display: flex; /* 中身を左右に並べる */
    text-decoration: none;
    color: #454949;
    background-color: #fff;
    transition: all 0.2s ease;
    
    /* 高さを固定することで、レイアウトのガタつきを防ぎます */
    height: 100px; 
    overflow: hidden; /* ブロック全体からはみ出したものを隠す */
}

/* ホバー時の白黒反転（画像以外の部分に適用） */
.link-block:hover {
    background-color: #000;
    color: #fff;
}

/* =========================================
   左半分：画像エリア
   ========================================= */
.link-image {
    width: 50%; /* 左半分を占有 */
    border-right: 2px solid #a8a8a8; /* 真ん中の仕切り線 */
    flex-shrink: 0; /* 画像エリアが潰れるのを防ぐ */
}

.link-image img {
    width: 100%;
    height: 100%;
    /* どんな縦横比の画像でも、枠いっぱいに隙間なく表示する魔法のプロパティ */
    object-fit: cover; 
    display: block;
}

/* （おまけ）ホバー時に画像を少し暗くしたり、モノクロにするのもお洒落です */
.link-block:hover .link-image img {
    opacity: 0.8;
}

/* =========================================
   右半分：テキストエリア
   ========================================= */
.link-text {
    width: 50%; /* 右半分を占有 */
    padding: 12px;
    display: flex;
    align-items: flex-start; /* テキストを上揃えにする */
}

.link-title {
    font-weight: bold;
    font-size: 0.9rem; /* 少し小さめに調整 */
    line-height: 1.4;
    
    /* 複数行のはみ出しを「...」で綺麗に省略するCSS */
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3; /* ここを「3」にすると、3行目ではみ出した分をカットします */
    overflow: hidden;
}

/* =========================================
   右側：Vueアプリを囲うラッパー
   ========================================= */
.vue-wrapper {
    flex-grow: 1; 
    /* 【変更点】overflow の記述をすべて削除。
       中身の Vue アプリが広がれば、そのままページ全体が広がります */
}
