@charset "utf-8";

/* 共通------------------------------------
------------------------------------------- */
*,::before,::after {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	font-weight: normal;
}
:root {
  --colorMain1: #3cd6d6;
  --colorMain2: #f293a2;
  --colorSub: #4d4d4d;
  --colorBack1: #d7f2f0;
  --colorBack2: #f2f2f2;
  --colorBack3: #f9e6ea;
  --colorShadow: #999;
	--colorAside: #1a1a1a;
  --colorLine: #e6e6e6;
  --colorText: #333333;
}
html {
	font-size: 10px;
	scroll-behavior: smooth;
}
body {
  font-family: 'Zen Kaku Gothic New', serif;
  font-size: 1.6em;
  line-height: 1;
}
img {
	max-width: 100%;
	vertical-align: bottom;
}
a {
	color: inherit;
	text-decoration: none;
}
ul {
  list-style: none;
}
.container {
  max-width: 1300px;
  width: 100%;
}
h1 {
  font-size: 30px;
}
h2 {
  font-size: 28px;
  font-weight: 500;
}
::before, ::after{
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  width: 100%;
  /* 位置 */
  display: block;
  position: absolute;
}


@media (max-width: 428px) {
  h2 {
    font-size: 20px;
  }
}

/* 共通項目------------------------------------
------------------------------------------- */
/* レイアウト */
main>section {
	padding: 0px;
	margin: 0px;
  overflow: hidden;
}
.container {
  margin: 0 auto;
  max-width: 1280px;
}
.flex {
  display: flex;
  align-items: center;
  justify-content: center;
}
.sectTtl {
  text-align: center;
  padding: 5em 0 1.2rem;
  margin: 0 0 3rem;
  background-image: linear-gradient(90deg, var(--colorMain1) 0 20%, var(--colorSub) 20%);
  background-repeat: no-repeat;
  background-size: 17rem 3px;
  background-position: bottom;
}

/* fv------------------------------------
------------------------------------------- */
#index .slider {
  /* width: 100%; */
  margin: auto;
}

#index .slider div {
  text-align: center;
}
#index .slider div img,
#index .slider div video {
  object-fit: cover;
  height: 100vh;
  width: 100%;
}
#index .slick-next {
  right: 0;
}

/* 動画の切り替え */
/* 全ての動画を非表示にする */
.video-slide video {
  display: none;
}

/* デスクトップ用動画を表示、モバイル用を非表示 */
.desktop-video {
  display: block;
}
.mobile-video {
  display: none;
}

/* glidの画像切り替え */
/* 初期状態ではデスクトップ用画像を設定 */
#responsive-image {
  content: url('../_img/top/fv_glid.jpg');
}

@media only screen and (max-width: 800px) {
  /* 動画の切り替え */
  /* モバイルの表示調整 */
  .desktop-video {
    display: none;
  }
  
  .mobile-video {
    display: block;
  }

  /* モバイルの表示調整 */
  #responsive-image {
    content: url('../_img/top/fv_glid_res1.jpg');
  }
}

/* モバイルサイズ（例: 480px以下）で画像切り替え */
@media only screen and (max-width: 450px) {
  #responsive-image {
    content: url('../_img/top/fv_glid_res2.jpg');
  }
}

/* strengths------------------------------------
------------------------------------------- */
#index .strengths {
	margin: 60px 0 30px;
	text-align: justify;
}
#index .strengths>.container {
	position: relative;
  padding: 0 1em;
}
#index .strengths p {
	text-shadow: #fff 3px 0 0, #fff 2.83487px 0.981584px 0, #fff 2.35766px 1.85511px 0, #fff 1.62091px 2.52441px 0, #fff 0.705713px 2.91581px 0, #fff -0.287171px 2.98622px 0, #fff -1.24844px 2.72789px 0, #fff -2.07227px 2.16926px 0, #fff -2.66798px 1.37182px 0, #fff -2.96998px 0.42336px 0, #fff -2.94502px -0.571704px 0, #fff -2.59586px -1.50383px 0, #fff -1.96093px -2.27041px 0, #fff -1.11013px -2.78704px 0, #fff -0.137119px -2.99686px 0, #fff 0.850987px -2.87677px 0, #fff 1.74541px -2.43999px 0, #fff 2.44769px -1.73459px 0, #fff 2.88051px -0.838247px 0;
}

/* 強み */
#index .strengths>.container>ul:first-of-type {
	text-align: center;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 5px 0;
	margin-bottom: 2em;
}
#index .strengths>.container>ul:first-of-type li {
	font-size: 2em;
	font-weight: bold;
  text-wrap: nowrap;
  text-shadow: #fff 3px 0 0, #fff 2.83487px 0.981584px 0, #fff 2.35766px 1.85511px 0, #fff 1.62091px 2.52441px 0, #fff 0.705713px 2.91581px 0, #fff -0.287171px 2.98622px 0, #fff -1.24844px 2.72789px 0, #fff -2.07227px 2.16926px 0, #fff -2.66798px 1.37182px 0, #fff -2.96998px 0.42336px 0, #fff -2.94502px -0.571704px 0, #fff -2.59586px -1.50383px 0, #fff -1.96093px -2.27041px 0, #fff -1.11013px -2.78704px 0, #fff -0.137119px -2.99686px 0, #fff 0.850987px -2.87677px 0, #fff 1.74541px -2.43999px 0, #fff 2.44769px -1.73459px 0, #fff 2.88051px -0.838247px 0;
}

/* 強み　内容 */
#index .strengths>.container>p:last-of-type {
	text-align: center;
  line-height: 1.5;
}

/* 強みの関係 */
#index .strengths>.container>ul:nth-of-type(2) {
	align-items: stretch;
  flex-flow: wrap;
	margin-top: 2em;
}
#index .strengths>.container>ul:nth-of-type(2) li {
	text-align: center;
}
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(5) {
  display: flex;
  flex-flow: column;
  gap: 5px;
}

/* 平行四辺形 */
#index .strengths>.container>ul:nth-of-type(2)>li:not(:nth-of-type(2)),
#index .strengths>.container>ul:nth-of-type(2)>li:not(:nth-of-type(4)) {
	font-size: 1.25em;
	width: 29%;
	padding: .125em .125em;
	clip-path: polygon(20% 0%, 100% 0, 80% 100%, 0% 100%);
	flex-flow: column;
  z-index: -2;
}

/* X　＝ */
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(2),
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(4) {
	width: 5%;
	font-size: 4em;
}

/* 平行四辺形　カラー */
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(1) {
  background-image: linear-gradient(90deg, rgba(60, 214, 214, 1) 70%, rgba(255, 255, 255, 0));
}
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(3) {
	background-image: linear-gradient(90deg, rgba(242, 147, 162, 1) 70%, rgba(255, 255, 255, 0));
}
#index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(5) {
	background-image: linear-gradient(90deg, #ffea00 70%, rgba(255, 255, 255, 0));
}

/* イラスト */
#index .strengths ul:nth-of-type(3) li {
	width: 100px;
	height: 100%;
	opacity: .5;
	z-index: -1;
}
#index .strengths ul:nth-of-type(3) li:nth-of-type(1) {
	position: absolute;
	top: -20px;
	left: 10px;
}
#index .strengths ul:nth-of-type(3) li:nth-of-type(2) {
	position: absolute;
	top: 50px;
	left: 50px;
}
#index .strengths ul:nth-of-type(3) li:nth-of-type(3) {
	position: absolute;
	top: -20px;
	right: 10px;
}
#index .strengths ul:nth-of-type(3) li:nth-of-type(4) {
	position: absolute;
	top: 50px;
	right: 50px;
}

@media (max-width: 760px) {
  /* 強み */
  #index .strengths>.container>ul:first-of-type {
    font-size: .75em;
    line-height: 1.5;
  }

  /* 平行四辺形 */
  #index .strengths>.container>ul:nth-of-type(2)>li:not(:nth-of-type(2)),
  #index .strengths>.container>ul:nth-of-type(2)>li:not(:nth-of-type(4)) {
    width: 45%;
    height: 60px;
    font-size: 1.0em;
  }

  /* X　＝ */
  #index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(2),
  #index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(4) {
	  width: 10%;
	  font-size: 3em;
  }

  /*　＝ */
  #index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(4) {
    transform: rotate(90deg);
    width: 100%;
  }

  /* イラスト */
  #index .strengths ul:nth-of-type(3) li {
    width: 75px;
    height: 100%;
    opacity: .5;
    z-index: -1;
  }
  #index .strengths ul:nth-of-type(3) li:nth-of-type(1) {
    position: absolute;
    top: 73%;
    left: 3%;
  }
  #index .strengths ul:nth-of-type(3) li:nth-of-type(2) {
    position: absolute;
    top: 83%;
    left: 10%;
  }
  #index .strengths ul:nth-of-type(3) li:nth-of-type(3) {
    position: absolute;
    top: 73%;
    right: 3%;
  }
  #index .strengths ul:nth-of-type(3) li:nth-of-type(4) {
    position: absolute;
    top: 83%;
    right: 10%;
  }
}

@media (max-width: 550px) {
  #index .strengths>.container>ul:nth-of-type(2)>li:nth-of-type(5) {
    width: 60%;
  }
}

@media (max-width: 430px) {
  #index .strengths>.container>p:first-of-type span {
    display: block;
  }
}

/* top_contents------------------------------------
------------------------------------------- */
#index .top_contents>div {
	height: 370px;
	width: 100%;
}
/* レイアウト */
#index .top_contents div:nth-of-type(1), 
#index .top_contents div:nth-of-type(3) {
	display: flex;
	justify-content: center;
}
#index .top_contents div:nth-of-type(2) {
	display: flex;
	justify-content: center;
	flex-flow: row-reverse;
}

/* 背景色 */
#index .top_contents>div:nth-of-type(1) {
	background-color: var(--colorMain1);
}
#index .top_contents>div:nth-of-type(2) {
	background-color: var(--colorMain2);
}
#index .top_contents>div:nth-of-type(3) {
	background-color: var(--colorSub);
}

/* 画像クリップパス */
#index .top_contents>div>span {
	width: 55%;
	height: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	display: flex;
} 
#index .top_contents>div:nth-of-type(1)>span {
	clip-path: polygon(0% 0, 100% 0, 80% 100%, 0% 100%);
	background-image: url(../_img/top/room.JPG);
	background-position: 100% 70%;
	justify-content: left;
}
#index .top_contents>div:nth-of-type(2)>span {
	clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%);
	background-image: url(../_img/top/kadomako.jpg);
	background-position: 20% 30%;
	justify-content: right;
}
#index .top_contents>div:nth-of-type(3)>span {
	clip-path: polygon(0 0, 100% 0, 80% 100%, 0% 100%);
	background-image: url(../_img/top/creat.jpg);
	background-position: 50% 50%;
	justify-content: left;
}

/* 各ページのリンクボタン側 */
#index .top_content {
	flex: 1;
}
#index .top_content ul {
	color: #fff;
	max-width: 390px;
	padding: 2em 0 2em;
	display: flex;
	flex-flow: column;
	justify-content: space-between;
	align-items: center;
}
#index .top_contents ul li {
	padding: 0 1em;
  text-wrap: nowrap;
	display: flex;
  justify-content: flex-start;
	flex-flow: wrap;
	gap: 2em;
  text-align: center;
}
#index .top_contents div ul li dt,
#index .top_contents>div:last-of-type ul>li:first-of-type {
  width: 100%;
	font-size: 1.75em;
	display: block;
	margin: 0 auto;
  text-align: center;
}
#index .top_contents>div:last-of-type ul li:first-of-type {
	flex: 1;
	display: flex;
	align-items: center;
  justify-content: center;
}
#index .top_contents ul li dd {
	font-size: 1.125em;
}
#index .top_contents>div:not(:first-of-type) ul li dd {
  width: 44%;
}
#index .top_contents ul dt:hover,
#index .top_contents ul dd:hover,
#index .top_contents ul>li:last-of-type:hover,
#index .top_contents>div:nth-of-type(3) ul>li a:hover {
  opacity: 0.6;
}

/* 詳細ページボタン */
#index .top_content ul>li:last-of-type a span {
	margin-right: .5em;
}

/* 矢印 */
#index .dli-caret-circle-fill-right {
  display: inline-block;
  vertical-align: middle;
  color: #fff;
	font-size: 2em;
  line-height: 1;
  position: relative;
  width: 0.8em;
  height: 0.8em;
  border: 0.075em solid currentColor;
  background: currentColor;
  border-radius: 50%;
  box-sizing: content-box;
}
#index .top_contents>div ul .dli-caret-circle-fill-right::before {
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent;
  border-width: 0.18em 0.31177em;
  border-left-color: currentColor;
  border-right: 0;
  transform: translateX(15%);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
}
#index .top_contents>div:nth-of-type(1) ul .dli-caret-circle-fill-right::before {
  color: var(--colorMain1);
}
#index .top_contents>div:nth-of-type(2) ul .dli-caret-circle-fill-right::before {
  color: var(--colorMain2);
}
#index .top_contents>div:nth-of-type(3) ul .dli-caret-circle-fill-right::before {
  color: var(--colorSub);
}

@media (max-width: 760px) {
  /* レイアウト */
  #index .top_contents div:nth-of-type(1), 
  #index .top_contents div:nth-of-type(3) {
	  display: block;
    height: 100%;
  }
  #index .top_contents div:nth-of-type(2) {
	  flex-flow: column;
    align-items: center;
  }
  #index .top_contents>div {
	  height: 100%;
	  width: 100%;
  }

  /* 画像 */
  #index .top_contents>div>span {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    display: flex;
  }
  #index .top_contents>div:nth-of-type(1)>span {
    height: 300px;
    clip-path: none;
    background-image: url(../_img/top/room.JPG);
  }
  #index .top_contents>div:nth-of-type(2)>span {
    height: 300px;
    clip-path: none;
    background-image: url(../_img/top/kadomako.jpg);
  }
  #index .top_contents>div:nth-of-type(3)>span {
    height: 300px;
    clip-path: none;
    background-image: url(../_img/top/creat.jpg);
  }

  /* 各ページのリンクボタン側 */
  #index .top_content {
    width: 100%;
    height: 300px;
  }
  #index .top_content ul {
    max-width: none;
    width: 100%;
    height: 300px;
  }
  #index .top_content ul li {
    width: 100%;
  }
  #index .top_contents>div:nth-of-type(1) ul li dd {
    width: 100%;
  }
  #index .top_content ul>li:last-of-type {
    justify-content: center;
  }
  #index .top_content ul li dd {
    width: 45%;
    text-wrap: nowrap;
    text-align: center;
  }
  #index .top_contents>div:first-of-type>.top_content ul li dd {
    width: 70%;
    text-wrap: nowrap;
    text-align: center;
  }
}