/* ------------------------------
   ベース設定
------------------------------ */
body {
  font-family: Arial, sans-serif;
  line-height: 1.6;
  color: #333;
  background-color: #fff;
  margin: 0;
  padding: 0;
}

/* コンテナ：中央寄せ＋最大幅指定 */
.container {
  width: 80%;
  max-width: 800px;
  margin: 0 auto;
  padding: 20px;
}

/* ------------------------------
   タイトル・見出し
------------------------------ */
h1 {
  background-position: 6px center;
  background-repeat: no-repeat;
  background-color: #1d8a1d;
  background-size: 70px 70px;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  margin-bottom: 30px;
  padding: 10px;
}

h2 {
  color: #000;
  background-color: #daffda;
  margin-bottom: 15px;
  padding: 6px 10px;
  border-radius: 4px;
}


#manual h3 {
  margin-top: 24px;
}

/* キャッチコピーなど */
.catch {
  background: #ffffff;
  text-align: center;
  margin-bottom: 20px;
}

/* ------------------------------
   セクション
------------------------------ */
section {
  background-color: #f8f8f8;
  border: 1px solid #e8e8e8;
  border-radius: 5px;
  padding: 20px;
  margin-bottom: 20px;
}

/* ------------------------------
   画像関連
------------------------------ */
img {
  margin-left: 30px;
  border-radius: 2%;
  max-width: 100%; /* ✅ 画面幅に合わせて縮小 */
  height: auto;
}

/* section 内の画像（上余白） */
section img {
  margin-top: 20px;
}

/* 拡大効果付き（旧 clickable-image） */
.clickable-image {
  margin-left: 30px;
  transition: transform 0.3s ease;
  cursor: pointer;
}

.clickable-image:hover {
  transform: scale(2.5);
}

/* ------------------------------
   説明カード
------------------------------ */
#cards {
  flex-wrap: wrap;
  display: flex;
  justify-content: center;
  gap: 10px;
}

.setumei-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 20px;
  border: 2px solid #1b1b1b;
  border-radius: 5px;
  font-weight: bold;
  width: 200px;
  background: #fff;
  padding: 10px;
}

/* ------------------------------
   「使い方の流れ」セクション
------------------------------ */
.flow-step {
  margin: 32px 0;
  border-left: 4px solid #1d8a1d;
  padding-left: 16px;
}

.flow-step h3 {
  margin-top: 0.5em;
  font-size: clamp(1.1rem, 2.5vw, 1.3rem);
}

.flow-step img {
  display: block;
  margin: 12px auto;
  border-radius: 10px;
  border: 1px solid #ddd;
  box-shadow: 0 3px 8px rgba(0,0,0,0.08);
  max-width: 600px;      /* これ以上は広がらない */
  width: 60%;            /* 通常は画面の6割に */
  height: auto;
}

/* スマホ画面で余白を調整 */
@media (max-width: 640px) {
  .flow-step {
    padding-left: 12px;
    border-left-width: 3px;
  }

  img,
  .clickable-image {
    margin-left: 0;
  }

  .container {
    width: 94%;
    padding: 12px;
  }
}

/* ------------------------------
   フッター
------------------------------ */
footer {
  margin-top: 80px;
  position: relative;
  font-size: 0.9em;
  text-align: center;
  color: #666;
}
