/* style.css */

body {
    background-color: #000;
    /* 背景を黒に設定 */
    color: #fff;
    /* 文字を白に設定 */
    font-family: sans-serif;
    /* 読みやすいフォントを設定 */
    margin: 0;
    padding: 0;
}

header {
    background-color: #111;
    padding: 15px 0;
    text-align: center;
}

nav ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
}

nav ul li {
    margin: 0 15px;
}

nav ul li a {
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    transition: color 0.3s;
}

nav ul li a:hover {
    color: #aaa;
}

.container {
    max-width: 960px;
    margin: 20px auto;
    padding: 0 20px;
}

 /* works */

.works-item-title {
    font-size: 1.1em;
    /* フォントサイズ調整 */
    font-weight: bold;
    /* 太字に */
    color: #333;
    /* 文字色 */
    margin-top: 10px;
    /* 画像との間隔 */
    margin-bottom: 5px;
    /* 説明文との間隔 */
    padding: 0 15px;
    /* 左右に少しパディング */
}

.works-items {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
}

.works-item {
    flex-basis: calc(33.333% - 20px);
    min-width: 250px;
    background-color: #f9f9f9;
    /* alt-bgが白なので少し色をつける */
    /* border: 1px solid #eee; */
    /* ← この行を削除またはコメントアウト */
    border-radius: 8px;
    overflow: hidden;
    text-align: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    /* ▼▼▼ 追加・変更 ▼▼▼ */
    box-sizing: border-box;
    /* paddingとborderを要素サイズに含める */
    border: 2px solid transparent;
    /* 通常時は透明な枠線 */
    transition: box-shadow 0.3s ease, border-color 0.3s ease;
    /* transitionにborder-colorを追加 */
    /* ▲▲▲ ここまで ▲▲▲ */
}

.works-item:hover {
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
    /* ▼▼▼ 追加 ▼▼▼ */
    border-color: #5cb85c;
    /* ホバー時に緑色の枠線を表示 */
    /* ▲▲▲ ここまで ▲▲▲ */
}

.works-item-description {
    font-size: 0.9em;
    color: #555;
    padding: 0 15px 15px;
    /* 左右と下にパディング */
    margin: 0;
    min-height: 3em;
    /* 高さをある程度揃える（調整してください）*/
}

.works-item a {
    text-decoration: none;
    color: #333;
    display: block;
    /* リンク領域を全体に広げる */
}

.works-item img {
    width: 100%;
    height: 200px;
    /* 高さを固定 */
    object-fit: cover;
    /* 画像の比率を保ちつつコンテナに合わせる */
    display: block;
    /* 下部の余白をなくす */
}

.works-item p {
    padding: 15px;
    margin: 0;
    font-size: 0.9em;
    min-height: 4em;
    /* 説明文の高さをある程度揃える */
}
/* worksのセクション終わり */

section {
    margin-bottom: 40px;
}

h1,
h2,
h3 {
    border-bottom: 2px solid #fff;
    padding-bottom: 5px;
}

a {
    color: #fff;
}