/*　パーツごとのCSS  */

/* =========================================================
  TOP：横スワイプ写真ストリップ（ここはあなたのCSSを維持）
========================================================= */
.top-photo-strip{
  margin: 12px 0 22px;
}

.top-photo-strip__inner{
  max-width: 1150px;
  margin: 0 auto 1.5rem;
  padding: 0 14px;
}

/* 横スクロール本体 */
.top-photo-strip__list{
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 6px 2px 12px;
  margin: 0;
  list-style: none;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

@media (min-width: 1024px){
  .top-photo-strip__list{
    justify-content: center;
  }
}

@media (min-width: 768px){
  .top-photo-strip__list{
    scroll-padding-left: 14px;
    scroll-padding-right: 14px;
  }
}

@media (max-width: 425px){
  .top-photo-strip__list{
    padding-left: 14px;
    padding-right: 14px;
    scroll-padding-left: 14px;
    scroll-padding-right: 14px;
  }
}

/* スクロールバー */
.top-photo-strip__list::-webkit-scrollbar{
  height: 6px;
}
.top-photo-strip__list::-webkit-scrollbar-thumb{
  background: rgba(0,0,0,0.12);
  border-radius: 999px;
}

.top-photo-strip__item{
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.top-photo-strip__link{
  display: block;
  text-decoration: none;
}

/* 画像カード */
.top-photo-strip__card{
  position: relative;
  width: 150px;
  height: 110px;
  border-radius: 12px;
  overflow: hidden;
  margin: 0;
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
  background: #f5f5f5;
}

.top-photo-strip__card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
}

.top-photo-strip__tag{
  position: absolute;
  left: 8px;
  bottom: 8px;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
  color: #fff;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(2px);
}

@media (min-width: 768px){
  .top-photo-strip{
    margin: 14px 0 26px;
  }
  .top-photo-strip__card{
    width: 180px;
    height: 120px;
    border-radius: 14px;
  }
}

/* lity */
.lity-video-box{
  width: min(92vw, 960px);
}
.lity-video-box-vw42{
  width: min(42vw, 960px);
}
.lity-container{
  max-width: 90%;
}


/* =========================================================
 * ここから追記
  TOP：横スワイプ写真ストリップ
  - スライド直下に「写真量」を増やしてSPの見栄えを改善
========================================================= */

.top-photo-strip{
  margin: 12px 0 22px;
}

.top-photo-strip__inner{
  max-width: 1150px;
  margin: 0 auto 1.5rem;
  padding: 0 14px;
}

/* 横スクロール本体 */
.top-photo-strip__list{
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 6px 2px 12px;
  margin: 0;
  list-style: none;
  /* スワイプ体験を良くする */
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
@media (min-width: 1024px){
  .top-photo-strip__list{
	justify-content: center;
  }
}
@media (min-width: 768px){
  .top-photo-strip__list{
    scroll-padding-left: 14px;
    scroll-padding-right: 14px;
  }
}
@media (max-width: 425px){
.top-photo-strip__list{
  padding-left: 14px;
  padding-right: 14px;
  scroll-padding-left: 14px;
  scroll-padding-right: 14px;
  }
}

/* スクロールバーは控えめに（不要なら消してOK） */
.top-photo-strip__list::-webkit-scrollbar{
  height: 6px;
}
.top-photo-strip__list::-webkit-scrollbar-thumb{
  background: rgba(0,0,0,0.12);
  border-radius: 999px;
}

.top-photo-strip__item{
  flex: 0 0 auto;
  scroll-snap-align: start;
}

.top-photo-strip__link{
  display: block;
  text-decoration: none;
}

/* 画像カード */
.top-photo-strip__card{
  position: relative;
  width: 150px;
  height: 110px;
  border-radius: 12px;
  overflow: hidden;
  margin: 0;

  /* 上品に浮かせる */
  box-shadow: 0 8px 18px rgba(0,0,0,0.10);
  background: #f5f5f5;
}

/* 画像 */
.top-photo-strip__card img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
}

/* タグ（写真の上に載せる短いラベル） */
.top-photo-strip__tag{
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: 8px;
  padding: 5px 8px;
  border-radius: 999px;
  font-size: 12px;
  line-height: 1;
  color: #fff;

  /* 黒ベタではなく、写真を活かす暗幕 */
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(2px);
}

/* PC時は横並びの見え方を少し広げる */
@media (min-width: 768px){
  .top-photo-strip{
    margin: 14px 0 26px;
  }
  .top-photo-strip__card{
    width: 180px;
    height: 120px;
    border-radius: 14px;
  }
}

.lity-video-box{
  width: min(92vw, 960px);
}
.lity-video-box-vw42{
  width: min(31vw, 960px);
	margin: auto;
}
.lity-container {
    max-width: 90%;
}
.fvhero-wrap {
    background: #6c6c6c;
}

/* lity inline 共通 */
.lity-inline-box{
  width: min(920px, 92vw);
  margin: 0 auto;
}

/* 動画 */
.lity-video{
  width: 100%;
  height: auto;
  display: block;
  border-radius: 12px;
}

/* 要点3行ボックス */
.lity-points-box{
  margin-top: 14px;
  background: rgba(255,255,255,.96);
  border-radius: 12px;
  padding: 14px 16px;
}

.lity-points{
  margin: 0;
  padding-left: 1.2em;
  line-height: 1.8;
  font-size: 14px;
}

.lity-actions{
  margin-top: 10px;
  text-align: center;
}

.lity-btn{
  display: inline-block;
  padding: 10px 16px;
  border-radius: 999px;
  background: #7d55c7;
  color: #fff;
  text-decoration: none;
  font-weight: 700;
}

/* 横型（movie-01） */
.lity-inline-box--landscape .lity-video{
  max-height: 62vh;
  object-fit: contain;
}

/* 縦型（movie-04） */
.lity-inline-box--portrait .lity-video{
  max-height: 78vh;
  object-fit: contain;
}

@media (max-width: 425px) {
  .lity-inline-box--portrait .lity-video-box-vw42 {
    width: min(60vw, 960px);
  }
}
@media (max-width: 375px) {
  .lity-inline-box--portrait .lity-video-box-vw42 {
    width: min(46vw, 960px);
  }
}
@media (max-width: 320px) {
  .lity-inline-box--portrait .lity-video-box-vw42 {
    width: min(69vw, 960px);
  }
}

/*	こころ屋3つの特徴 */
.area-feature-section h3 {
  position: relative;
  margin: 0;
  text-align: center;
  padding: 0 0 2em 0;
  display: flex;
  justify-content: center;
  align-items: center;
}
.feature-header {
  display: flex;
  justify-content: left;
  align-items: center;
  padding: 0 0 1rem 0;
}

.feature-list {
  display: flex;
  flex-wrap: wrap;
}

.area-feature-section li {
  margin: 0 3% 0 0;
  padding: 0 10px 25px;
  width: 29.72%;
  max-width: 330px;
  border: 2px solid #ccc;
  border-radius: 10px;
  background: #fff;
  justify-content: center;
}

.feature-title img {
  max-width: 80%;
}
  .flx_feature_aria {
    flex-direction: column;
  }

  .area-feature-section li figure {
    position: relative;
    margin: 0;
    text-align: center;
  }

  .area-feature-section h4 img {
    max-width: 50px;
  }

  .feature-heading {
    display: flex;
    font-weight: bold;
    padding: 0rem 0 0rem .5rem;
    margin-block: 2rem;
  }

  .area-feature-section p {
    display: table;
    max-width: 100%;
  }

  .feature-header h4 {
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .area-feature-section li figure {
    position: relative;
    margin: 0;
  }


.area-feature-section li:nth-of-type(1) {
  border-color: #355D9D;
  background: #f5f5f5;
}

.area-feature-section li:nth-of-type(2) {
  border-color: #355D9D;
  background: #f5f5f5;
}

.area-feature-section li:nth-of-type(3) {
  border-color: #355D9D;
  background: #f5f5f5;
}

.area-feature-section li:nth-of-type(3n) {
  margin-right: 0;
}


.single p {
    display: block;
    margin-top: 0em;
    margin-bottom: 0em;
}
