/* ===============================
doglife（犬と暮らすページ）スコープ付き
================================ */

#doglife {
 padding: 80px 0;
 background: #fff;
}

/* --- ヘッダー --- */
#doglife .doglife-header {
 display: flex;
 align-items: flex-end;
 flex-wrap: wrap;
 margin-bottom: 40px;
 justify-content: space-between;
}

#doglife .doglife-logo-title {
 display: flex;
 align-items: center;
}

#doglife .doglife-icon {
 width: 50px;
 height: auto;
 margin-right: 16px;
}

@media screen and (min-width: 768px) {
 #doglife .doglife-icon {
  width: 90px;
 }
}

#doglife .doglife-title-group {
 display: flex;
 flex-direction: column;
}

#doglife .doglife-title-group .en-title {
 font-size: 17px;
 font-weight: 600;
 color: #5c4534;
 margin: 0;
 letter-spacing: 0.05em;
}

#doglife .doglife-title-group .jp-title {
 font-size: 2.2em;
 color: #3a2d27;
}

@media screen and (min-width: 768px) {
 #doglife .doglife-title-group .jp-title {
  font-size: 3.2em;
 }
}

#doglife .doglife-lead {
 font-size: 16px;
 color: #3a2d27;
 line-height: 1.7;
}

/* --- メインビジュアル --- */
#doglife .doglife-mainvisual img {
 width: 100%;
 height: auto;
 margin-bottom: 80px;
}

/* --- セクションタイトル --- */
#doglife .doglife-feature {
 margin-bottom: 80px;
}

#doglife .doglife-feature-title {
 color: #584c42;
 font-size: 1.75em;
 font-weight: bold;
 text-align: center;
 margin-bottom: 30px;
 position: relative;
}

@media screen and (min-width: 768px) {
 #doglife .doglife-feature-title {
  font-size: 2em;
 }
}

#doglife .doglife-title-underline {
 display: block;
 margin: 8px auto 0;
 width: 300px;
 height: auto;
}

/* --- コンテンツ：画像＋テキスト --- */
#doglife .doglife-double-block {
 display: flex;
 flex-direction: row;
 align-items: flex-start;
 gap: 50px;
}

@media screen and (max-width: 768px) {
 #doglife .doglife-double-block {
  flex-direction: column;
  gap: 30px;
 }
}

#doglife .doglife-img {
 flex: 1;
}

#doglife .doglife-img img {
 width: 100%;
 height: auto;
}

#doglife .doglife-text {
 flex: 1;
 font-size: 16px;
 line-height: 1.8;
 display: flex;
 flex-direction: column;
 gap: 20px;
 color: #3a2d27;
}

@media screen and (min-width: 768px) {
 #doglife .doglife-text {
  font-size: 17px;
 }
}

#doglife .doglife-text p {
 width: 100%;
}

@media screen and (min-width: 768px) {
 #doglife .doglife-text p {
  width: 90%;
 }
}

/* --- 三つ並び特徴ブロック --- */
#doglife .doglife-feature-row {
 display: flex;
 flex-wrap: wrap;
 justify-content: space-between;
 gap: 30px;
 margin: 60px 0;
}

#doglife .doglife-feature-box {
 flex: 1 1 30%;
 max-width: 30%;
 background-color: #fff;
 text-align: left;
}

#doglife .doglife-feature-box img {
 width: 100%;
 height: auto;
 margin-bottom: 10px;
 border: 1px solid #ccc;
 border-radius: 4px;
 box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}

#doglife .doglife-feature-box h4 {
 font-size: 1.3em;
 font-weight: bold;
 color: #3a2d27;
 margin-bottom: 10px;
}

#doglife .doglife-feature-box p {
 font-size: 15px;
 line-height: 1.7;
 color: #3a2d27;
 margin-bottom: 10px;
}

/* モバイル対応 */
@media screen and (max-width: 768px) {
 #doglife .doglife-feature-row {
  flex-direction: column;
 }

 #doglife .doglife-feature-box {
  max-width: 100%;
 }
}

/* --- 実体験紹介ブロック --- */
#doglife .doglife-episode-block {
 display: flex;
 flex-direction: row;
 gap: 50px;
 margin-bottom: 60px;
}

@media screen and (max-width: 768px) {
 #doglife .doglife-episode-block {
  flex-direction: column;
 }
}
