body {
  background-color: #e8dcc4; 
  background-image: 
    radial-gradient(#d4c3a3 1px, transparent 1px),
    linear-gradient(rgba(180, 160, 120, 0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(180, 160, 120, 0.1) 1px, transparent 1px);
  background-size: 40px 40px, 20px 20px, 20px 20px;
}

.section {
  padding: 40px 20px;
  max-width: 1000px;
  margin: 0 auto;
}

h1 {
  text-align: center;
  font-family: serif;
  color: #5d4037;
  border-bottom: 2px dashed #5d4037;
  display: inline-block;
  width: 100%;
  padding-bottom: 10px;
  margin-bottom: 40px;
}

.stack {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  align-items: start;
}

.content-card {
  background: #fff;
  padding: 20px;
  border: 1px solid #dcd3c1;
  box-shadow: 5px 5px 15px rgba(0,0,0,0.08);
  position: relative;
  transition: transform 0.3s ease;
}

.content-card:nth-child(odd) {
  transform: rotate(-1.5deg);
}
.content-card:nth-child(even) {
  transform: rotate(1.5deg);
}

.content-card:hover {
  transform: rotate(0deg) scale(1.02);
  z-index: 10;
}

.content-card::before {
  content: "";
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 30px;
  background: rgba(211, 47, 47, 0.2); /* ほんのり赤いテープ */
  border-left: 3px dotted rgba(255,255,255,0.5);
  border-right: 3px dotted rgba(255,255,255,0.5);
}

.content-card h2 {
  font-size: 1.25rem;
  color: #d32f2f;
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.content-card h2::before {
  content: "📍";
  font-size: 1rem;
}

.placeholder-media {
  width: 100%;
  height: 180px;
  background: #f0f0f0;
  border: 8px solid #fff;
  outline: 1px solid #ddd;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #aaa;
  font-size: 0.8rem;
  margin-top: 15px;
}

.clickable {
  cursor: pointer;
  transition: all 0.3s ease;
}

.clickable:hover {
  background-color: #fffaf0;
  box-shadow: 10px 10px 20px rgba(0,0,0,0.15);
}

#modal-description {
  font-family: 'Yomogi', cursive;
  font-size: 1rem;
  line-height: 1.8;
}
body {
  background-color: #e8dcc4;
  background-image: 
    radial-gradient(#d4c3a3 1px, transparent 1px),
    linear-gradient(rgba(180, 160, 120, 0.1) 1px, transparent 1px),
    linear-gradient(90deg, rgba(180, 160, 120, 0.1) 1px, transparent 1px);
  background-size: 40px 40px, 20px 20px, 20px 20px;
}

.stack {
  display: grid;
  gap: 30px;
  grid-template-columns: 1fr; 
}

@media (min-width: 600px) {
  .stack { grid-template-columns: repeat(2, 1fr); } 
}

@media (min-width: 900px) {
  .stack { grid-template-columns: repeat(3, 1fr); } 
}

.content-card {
  background: #fff;
  padding: 20px;
  border: 1px solid #dcd3c1;
  box-shadow: 5px 5px 15px rgba(0,0,0,0.08);
  position: relative;
  cursor: pointer;
  transition: transform 0.3s ease;
}

.content-card:nth-child(3n+1) { transform: rotate(-1deg); }
.content-card:nth-child(3n+2) { transform: rotate(1.5deg); }
.content-card:nth-child(3n+3) { transform: rotate(-0.5deg); }

.content-card:hover {
  transform: rotate(0deg) translateY(-5px);
  z-index: 5;
}

.photo-slider {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 15px 0;
}

#modal-img {
  width: 100%;
  max-height: 70vh; /* 画面の高さの70%までに制限して、全体を見やすくします */
  object-fit: contain; /* 画像を切り取らずに全体を表示します */
  background: #f9f9f9; /* 背景を薄いグレーにして、余白が目立たないようにします */
  border: 5px solid #fff;
  box-shadow: 0 4px 10px rgba(0,0,0,0.2);
  border-radius: 2px;
}

.slider-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.8);
  border: none;
  font-size: 1.5rem;
  padding: 10px;
  cursor: pointer;
  z-index: 10;
  border-radius: 50%;
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.slider-btn:hover { background: #fff; }
#prev-btn { left: -10px; }
#next-btn { right: -10px; }

@media (max-width: 480px) {
  .slider-btn { width: 35px; height: 35px; font-size: 1rem; }
}

.stack {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(3, 1fr) !important; 
}

@media (max-width: 767px) {
  .content-card {
    padding: 10px 5px !important; 
  }
  .content-card h2 {
    font-size: 0.7rem !important; 
    flex-direction: column; 
    gap: 2px;
  }
  .placeholder-media {
    height: 60px !important; 
    font-size: 0.5rem !important;
    border-width: 3px !important;
  }
}

@media (min-width: 900px) {
  .stack { gap: 30px; }
}

/* 元のプレースホルダー文字を消す、または上書きするための設定 */
.placeholder-media {
  display: none; /* もしHTMLで .placeholder-media を使っている場合は非表示にする */
}

.activity-image-container img {
  display: block;
  transition: transform 0.3s ease;
}

.content-card:hover .activity-image-container img {
  transform: scale(1.1); /* ホバー時に画像を少しズームアップ */
}

/* activities.css の後半部分を修正 */

/* 全体の基本設定（PCなどの広い画面では3列） */
.stack {
  display: grid;
  gap: 15px; /* カード同士の間隔を少し広げてスッキリさせる */
  grid-template-columns: repeat(3, 1fr); 
}

/* スマホ・タブレット（画面幅 767px 以下）の設定 */
@media (max-width: 767px) {
  .stack {
    /* ここを 2列 に変更！ */
    grid-template-columns: repeat(2, 1fr) !important; 
    gap: 10px; /* スマホでは間隔を少し詰める */
  }

  .content-card {
    padding: 10px 8px !important; /* 内側の余白を微調整 */
  }

  .content-card h2 {
    font-size: 0.85rem !important; /* 2列に合わせて文字を少し大きく（0.7remから修正） */
    flex-direction: row; /* 横並びに戻す */
    justify-content: center;
    gap: 4px;
  }

  /* 画像コンテナの高さを調整（2列だと幅が広がるので少し高くする） */
  .activity-image-container {
    height: 100px !important; /* 60px から 100px にアップ */
  }
}

/* PCなどの広い画面での微調整 */
@media (min-width: 900px) {
  .stack { 
    gap: 30px; 
  }
}