@charset "UTF-8";
/*
	@include sc(pc) {
		width: 100%;
	}
	@include sc(sp) {
		width: 50%;
	}
*/
/*
	@include hover() {
		opacity: 0.6;
	}
*/
/*
	$line:イラレの行の値
	$size:イラレの文字の値

	@include lh(38, 15);
*/
/*
	@include taJ();
*/
/*
	@extend %rightarr;
*/
/*
@mixin f_roboto($weight:400) {
	font-family: 'Roboto',"游ゴシック","游ゴシック体","Yu Gothic",YuGothic, sans-serif;
	font-weight:$weight;
}
Robotoフォント設定
400：Regular（デフォルト）
500：Medium
700：Bold
*/
/*
	$weight:フォントの太さ

	@include f_min();
	@include f_min(500);
	@include f_min(600);
*/
/*
	$weight:フォントの太さ

	@includef_shuei();
	@includef_shuei(600);
*/
/*
	$color:色指定
	$stripe:線サイズ
	$spacing:線の空きサイズ
	$height:太さ

	@include dotted(#e6e1d2, 4,4,2);
*/
/*
example
@include dotted-y(#COLOR, WidthPX,SpaceingPX,LengthPX,); 横破線
@include dotted-y(#e6e1d2, 4,4,2,10);
*/
body {
  background: rgba(254, 239, 208, 0.5);
}

img {
  max-width: 100%;
}

.mod_header {
  height: auto;
}

.mod_main {
  overflow: hidden;
}

.mv {
  position: relative;
}
@media print, screen and (min-width: 641px) {
  .mv .mv_image {
    padding-bottom: 3.4rem;
  }
}
@media screen and (max-width: 640px) {
  .mv .mv_image {
    height: 5.2rem;
    padding-bottom: 0.5rem;
  }
}
.mv .mv_image img {
  display: block;
  width: 100%;
  height: 100%;
}
.mv .mv_hokkaido {
  position: absolute;
  right: 0;
  opacity: 0;
}
@media print, screen and (min-width: 641px) {
  .mv .mv_hokkaido {
    top: 0;
  }
}
@media screen and (max-width: 640px) {
  .mv .mv_hokkaido {
    top: 0.5rem;
  }
}
.mv .mv_hokkaido img {
  width: 100%;
}
.mv .mv_cloud {
  display: flex;
  position: absolute;
  top: 0;
  left: 50%;
  width: 100%;
  overflow: hidden;
  transform: translateX(-50%);
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .mv .mv_cloud {
    height: 100%;
  }
}
.mv .mv_cloud img {
  width: 100%;
}
.mv .mv_cloud img:first-child {
  animation: loop 100s -50s linear infinite;
}
.mv .mv_cloud img:last-child {
  margin-left: 0.15rem;
  animation: loop2 100s linear infinite;
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes loop2 {
  0% {
    transform: translateX(0);
  }
  to {
    transform: translateX(-200%);
  }
}
.mv .mv_yakultman {
  opacity: 0;
  position: absolute;
  right: 0;
}
@media print, screen and (min-width: 641px) {
  .mv .mv_yakultman {
    top: 0;
  }
}
@media screen and (max-width: 640px) {
  .mv .mv_yakultman {
    top: 0.5rem;
  }
}
.mv .mv_yakultman img {
  width: 100%;
}
.mv .mv_yakultman_txt {
  opacity: 0;
  position: absolute;
  right: 0;
}
@media print, screen and (min-width: 641px) {
  .mv .mv_yakultman_txt {
    top: 0;
  }
}
@media screen and (max-width: 640px) {
  .mv .mv_yakultman_txt {
    top: 0.5rem;
  }
}
.mv .mv_yakultman_txt img {
  width: 100%;
}
.mv .mv_text {
  position: absolute;
  font-family: "dnp-shuei-mgothic-std", sans-serif;
  font-weight: 600;
  font-style: normal;
  color: #595757;
}
@media print, screen and (min-width: 641px) {
  .mv .mv_text {
    left: 2.26rem;
    top: 2.31rem;
    font-size: 0.43rem;
    line-height: 2.06;
    letter-spacing: 0.27em;
  }
}
@media screen and (max-width: 640px) {
  .mv .mv_text {
    top: 0.7rem;
    left: 0.3rem;
    font-size: 0.25rem;
    line-height: 2;
    letter-spacing: 0.24em;
  }
}
.mv .mv_pict {
  position: absolute;
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .mv .mv_pict {
    bottom: 0.49rem;
    left: 0.17rem;
  }
}
@media print, screen and (min-width: 641px) {
  .mv .mv_pict {
    bottom: 3.4rem;
    left: 0.97rem;
  }
}
.mv .mv_pict img {
  display: block;
}
@media screen and (max-width: 640px) {
  .mv .mv_pict img {
    width: 0.83rem;
    height: 0.99rem;
  }
}
@media print, screen and (min-width: 641px) {
  .mv .mv_pict img {
    width: 1.66rem;
    height: 1.98rem;
  }
}

.about {
  position: relative;
}
@media screen and (max-width: 640px) {
  .about {
    background: url("/img/index/bg01_sp.svg") no-repeat 0.26rem 0.11rem/3.2rem auto;
    margin-top: -0.53rem;
    padding-block: 1.45rem 1.11rem;
  }
}
@media print, screen and (min-width: 641px) {
  .about {
    background: url("/img/index/bg01.svg") no-repeat 0.27rem 2.12rem/13.31rem auto;
    margin: -3.42rem auto 0;
    max-width: 14.4rem;
    padding-block: 0.27rem 1.66rem;
  }
}
.about .about_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media print, screen and (min-width: 641px) {
  .about .about_load {
    top: 1rem;
    left: 60%;
    width: 11.45rem;
    height: 12.93rem;
  }
}
@media screen and (max-width: 640px) {
  .about .about_load {
    top: 0;
    left: 45%;
    width: 6.5rem;
    height: 9.37rem;
  }
}
.about .about_pict {
  position: absolute;
  transform: rotate(-30deg);
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .about .about_pict {
    bottom: auto;
    top: 2rem;
    left: 0.4rem;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_pict {
    top: 3.5rem;
    left: 2.9rem;
  }
}
@media screen and (max-width: 640px) {
  .about .about_pict img {
    height: 0.5rem;
    width: 0.7rem;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_pict img {
    height: 1rem;
    width: 1.41rem;
  }
}
.about .about_inner {
  margin-inline: auto;
  max-width: 10rem;
  position: relative;
}
@media screen and (max-width: 640px) {
  .about .about_inner {
    padding-inline: 0.14rem;
  }
}
@media screen and (max-width: 640px) {
  .about .about_image {
    margin-bottom: 1.1rem;
    text-align: right;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_image {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 640px) {
  .about .about_image img {
    width: 1.93rem;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_image img {
    width: 3.17rem;
  }
}
.about .about_main {
  margin-left: auto;
}
@media screen and (max-width: 640px) {
  .about .about_main {
    padding-inline: 0.16rem;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_main {
    margin-right: 0.54rem;
    width: fit-content;
  }
}
.about .about_main h3 {
  color: #595757;
}
@media print, screen and (min-width: 641px) {
  .about .about_main h3 {
    margin-bottom: 0.45rem;
    font-size: 0.32rem;
    line-height: 1.875;
    letter-spacing: 0.22em;
  }
}
@media screen and (max-width: 640px) {
  .about .about_main h3 {
    margin-bottom: 0.3rem;
    font-size: 0.2rem;
    line-height: 1.8;
    letter-spacing: 0.2em;
  }
}
@media print, screen and (min-width: 641px) {
  .about .about_main p {
    font-size: 0.2rem;
    line-height: 2.7;
  }
}
@media screen and (max-width: 640px) {
  .about .about_main p {
    font-size: 0.14rem;
    line-height: 2.42;
  }
}

.topics {
  position: relative;
  background: #fff;
}
@media screen and (max-width: 640px) {
  .topics {
    padding: 0.5rem 0.3rem 0.36rem;
    position: relative;
  }
}
@media print, screen and (min-width: 641px) {
  .topics {
    padding-block: 0.56rem 0.5rem;
  }
}
.topics::before {
  background: url("/img/index/bg02_sp.svg") no-repeat left top/cover;
  content: "";
  display: block;
  position: absolute;
}
@media screen and (max-width: 640px) {
  .topics::before {
    height: 0.77rem;
    right: 0.3rem;
    top: -0.5rem;
    width: 2.47rem;
  }
}
.topics .topics_inner {
  position: relative;
}
.topics .topics_inner::after {
  background: url("/img/index/bg02.svg") no-repeat left top/cover;
  content: "";
  display: block;
  position: absolute;
}
@media print, screen and (min-width: 641px) {
  .topics .topics_inner::after {
    bottom: -0.28rem;
    height: 0.81rem;
    right: -1.27rem;
    width: 0.72rem;
  }
}
.topics .topics_pict {
  position: absolute;
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .topics .topics_pict {
    right: 0.3rem;
    top: -1.5rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_pict {
    right: -0.9rem;
    top: -1.02rem;
  }
}
@media screen and (max-width: 640px) {
  .topics .topics_pict img {
    height: 0.42rem;
    width: 0.77rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_pict img {
    height: 0.83rem;
    width: 1.53rem;
  }
}
@media screen and (max-width: 640px) {
  .topics .ttl01::after {
    bottom: 0.1rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .ttl01::after {
    bottom: 0.14rem;
  }
}
@media screen and (max-width: 640px) {
  .topics .ttl01 img {
    height: 0.34rem;
    width: 1.05rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .ttl01 img {
    height: 0.46rem;
    width: 1.4rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list {
    margin-bottom: 0.27rem;
  }
}
.topics .topics_list li {
  align-items: center;
  display: flex;
}
@media screen and (max-width: 640px) {
  .topics .topics_list li {
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 640px) {
  .topics .topics_list li:not(:first-child) {
    border-top: 1px dashed #939393;
    margin-top: 0.25rem;
    padding-top: 0.25rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list li:not(:first-child) {
    margin-top: 0.34rem;
  }
}
@media screen and (max-width: 640px) {
  .topics .topics_list .topics_date {
    font-size: 0.13rem;
    margin-right: 0.1rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list .topics_date {
    font-size: 0.18rem;
    margin-right: 0.24rem;
  }
}
.topics .topics_list .topics_new {
  background: #feefd0;
  color: var(--color-red);
  display: -ms-grid;
  display: grid;
  flex-shrink: 0;
  place-content: center;
}
@media screen and (max-width: 640px) {
  .topics .topics_list .topics_new {
    font-size: 0.1rem;
    height: 0.18rem;
    margin-right: 0.1rem;
    width: 0.4rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list .topics_new {
    font-size: 0.16rem;
    height: 0.25rem;
    margin-right: 0.2rem;
    width: 0.6rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list .topics_category {
    margin-right: 0.22rem;
  }
}
.topics .topics_list .topics_category a {
  border: 1px solid var(--color-red);
  color: var(--color-red);
  display: -ms-grid;
  display: grid;
  flex-shrink: 0;
  place-content: center;
}
@media screen and (max-width: 640px) {
  .topics .topics_list .topics_category a {
    font-size: 0.1rem;
    height: 0.18rem;
    padding-block: 0.01rem;
    width: 0.8rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list .topics_category a {
    font-size: 0.16rem;
    height: 0.25rem;
    width: 1.4rem;
  }
}
@media screen and (max-width: 640px) {
  .topics .topics_list .topics_text {
    margin-top: 0.15rem;
    width: 100%;
  }
}
@media screen and (max-width: 640px) {
  .topics .topics_list .topics_text a {
    font-size: 0.13rem;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_list .topics_text a {
    font-size: 0.16rem;
  }
}
.topics .topics_button {
  display: flex;
}
@media screen and (max-width: 640px) {
  .topics .topics_button {
    margin-top: 0.4rem;
    justify-content: center;
  }
}
@media print, screen and (min-width: 641px) {
  .topics .topics_button {
    justify-content: flex-end;
  }
}

.product {
  position: relative;
}
@media screen and (max-width: 640px) {
  .product figure {
    background: url("/img/index/bg04_sp.svg") no-repeat right 0.22rem top 0.2rem/2.22rem auto;
    margin: 0 -0.3rem 0.15rem;
    padding-top: 0.63rem;
    position: relative;
  }
}
@media print, screen and (min-width: 641px) {
  .product figure {
    left: 0;
    position: absolute;
    top: 3.4rem;
  }
}
@media screen and (max-width: 640px) {
  .product figure img {
    width: 3.5rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product figure img {
    width: 7.3rem;
  }
}
.product figure p {
  position: absolute;
}
@media screen and (max-width: 640px) {
  .product figure p {
    left: 0.35rem;
    top: 0.2rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product figure p {
    left: 1.2rem;
    top: -1.17rem;
  }
}
@media screen and (max-width: 640px) {
  .product figure p img {
    height: 0.61rem;
    width: 0.52rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product figure p img {
    height: 1.22rem;
    width: 1.04rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_pic {
    width: 50%;
  }
}
@media screen and (max-width: 640px) {
  .product .product_pic {
    width: calc(100% + 0.3rem);
  }
}
.product .product_pic .product_img01 {
  width: 100%;
  object-fit: cover;
  border-radius: 0 5rem 5rem 0;
}
@media print, screen and (min-width: 641px) {
  .product .product_pic .product_img01 {
    height: 5rem;
  }
}
@media screen and (max-width: 640px) {
  .product .product_pic .product_img01 {
    height: 2.5rem;
  }
}
.product .product_pic .product_pict_anime01 {
  transform: rotate(-15deg);
  opacity: 0;
}
.product .product_pic .product_pict_anime02 {
  opacity: 0;
}
.product .product_main {
  position: relative;
}
@media screen and (max-width: 640px) {
  .product .product_main {
    background: url("/img/index/bg03_sp.svg") no-repeat 0.45rem 0/3rem auto;
    margin-top: -0.08rem;
    padding: 1.23rem 0.3rem 0;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main {
    background: url("/img/index/bg03.svg") no-repeat;
    padding-block: 3.42rem 4.43rem;
    height: 12.4rem;
  }
}
@media screen and (max-width: 640px) {
  .product .product_main .product_inner {
    background: url("/img/index/bg05_sp.svg") no-repeat left bottom 0.31rem/3rem auto;
    padding-bottom: 1.8rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner {
    display: flex;
    justify-content: flex-end;
    gap: 0.6rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner .product_detail {
    padding: 0.76rem 0.2rem 0;
    width: 4.6rem;
  }
}
.product .product_main .product_inner .ttl01 {
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 640px) {
  .product .product_main .product_inner .ttl01 {
    margin-bottom: 0.2rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner .ttl01 {
    margin-bottom: 0.45rem;
    width: 4.2rem;
  }
}
@media screen and (max-width: 640px) {
  .product .product_main .product_inner .ttl01 img {
    height: 0.29rem;
    width: 1.37rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner .ttl01 img {
    height: 0.39rem;
    width: 1.84rem;
  }
}
@media screen and (max-width: 640px) {
  .product .product_main .product_inner .product_text {
    font-size: 0.14rem;
    line-height: 2.42;
    margin-bottom: 0.35rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner .product_text {
    font-size: 0.16rem;
    line-height: 2.375;
    margin-bottom: 0.79rem;
  }
}
.product .product_main .product_inner ul {
  display: flex;
}
@media screen and (max-width: 640px) {
  .product .product_main .product_inner ul {
    align-items: center;
    flex-direction: column;
    gap: 0.15rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_main .product_inner ul {
    justify-content: space-between;
    margin-inline: -0.2rem;
  }
}
.product .product_pict {
  position: absolute;
  animation: jump 3s ease-in-out infinite;
}
@media screen and (max-width: 640px) {
  .product .product_pict {
    bottom: 0.4rem;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_pict {
    bottom: 0.37rem;
    left: 8.84rem;
  }
}
@keyframes jump {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0);
  }
}
@media screen and (max-width: 640px) {
  .product .product_pict img {
    height: 0.6rem;
    width: 0.4rem;
  }
}
@media print, screen and (min-width: 641px) {
  .product .product_pict img {
    height: 1.2rem;
    width: 0.8rem;
  }
}
.product .product_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media print, screen and (min-width: 641px) {
  .product .product_load {
    left: 46%;
    width: 12.64rem;
    height: 7.12rem;
  }
}
@media screen and (max-width: 640px) {
  .product .product_load {
    top: -0.8rem;
    left: 50%;
    width: 4.555rem;
    height: 2.23rem;
  }
}

.yakult_txt {
  overflow: hidden;
  display: flex;
}
.yakult_txt img {
  display: block;
  max-width: none;
}
@media screen and (max-width: 640px) {
  .yakult_txt img {
    padding-left: 0.15rem;
    height: 0.3rem;
  }
}
@media print, screen and (min-width: 641px) {
  .yakult_txt img {
    padding-left: 0.3rem;
    height: 0.63rem;
  }
}
.yakult_txt img:first-child {
  animation: loop 50s -25s linear infinite;
}
.yakult_txt img:last-child {
  animation: loop2 50s linear infinite;
}
@keyframes loop {
  0% {
    transform: translateX(100%);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes loop2 {
  0% {
    transform: translateX(0);
  }
  to {
    transform: translateX(-200%);
  }
}

.service {
  position: relative;
}
@media print, screen and (min-width: 641px) {
  .service {
    background: url("/img/index/bg05.svg") no-repeat left 2.26rem bottom 0.48rem/11.15rem auto;
    padding-block: 1.12rem 6rem;
  }
}
.service .service_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media print, screen and (min-width: 641px) {
  .service .service_load {
    top: -4.8rem;
    left: 50%;
    width: 17.95rem;
    height: 20.01rem;
  }
}
@media screen and (max-width: 640px) {
  .service .service_load {
    top: -2.35rem;
    left: 50%;
    width: 6.45rem;
    height: 16.74rem;
  }
}
.service .service_inner {
  position: relative;
}
@media screen and (max-width: 640px) {
  .service .service_inner {
    background: url("/img/index/bg07_sp.svg") no-repeat left 1.25rem bottom 0.27rem/0.81rem auto;
    padding: 0.56rem 0.3rem 2.8rem;
  }
}
.service .service_inner::before {
  background: url("/img/index/bg04.svg") no-repeat right top/cover;
  content: "";
  display: block;
  position: absolute;
}
@media print, screen and (min-width: 641px) {
  .service .service_inner::before {
    height: 1.09rem;
    left: -1.6rem;
    top: 3.9rem;
    width: 0.81rem;
  }
}
.service .service_inner .service_pict {
  display: block;
  position: absolute;
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .service .service_inner .service_pict {
    bottom: 2.06rem;
    right: 0.28rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_inner .service_pict {
    bottom: -0.07rem;
    right: -1rem;
  }
}
@media screen and (max-width: 640px) {
  .service .service_inner .service_pict img {
    height: 0.52rem;
    width: 0.9rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_inner .service_pict img {
    height: 1.01rem;
    width: 1.82rem;
  }
}
.service .ttl01 {
  align-items: center;
  flex-direction: column;
  gap: 0;
}
@media screen and (max-width: 640px) {
  .service .ttl01 {
    margin-bottom: 0.2rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .ttl01 {
    margin-bottom: 0.3rem;
  }
}
.service .ttl01::after {
  display: none;
}
.service .ttl01 h2 {
  line-height: 1;
  position: relative;
  width: 100%;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .service .ttl01 h2 {
    margin-bottom: 0.12rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .ttl01 h2 {
    margin-bottom: 0.18rem;
  }
}
.service .ttl01 h2::after {
  background: var(--color-red);
  bottom: 0;
  content: "";
  display: block;
  height: 0.02rem;
  position: absolute;
  left: 0;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .service .ttl01 img {
    height: 0.25rem;
    width: 1.18rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .ttl01 img {
    height: 0.34rem;
    width: 1.58rem;
  }
}
@media screen and (max-width: 640px) {
  .service .service_lead {
    font-size: 0.13rem;
    line-height: 2;
    margin-bottom: 0.2rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_lead {
    font-size: 0.16rem;
    line-height: 2.5;
    margin-bottom: 0.6rem;
    text-align: center;
  }
}
@media screen and (max-width: 640px) {
  .service .service_list {
    background: url("/img/index/bg06_sp.svg") no-repeat 0.32rem 0/3.06rem auto;
    margin-inline: -0.3rem;
    padding-top: 0.2rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.9rem;
  }
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-direction: row-reverse;
    gap: 0.15rem;
    position: relative;
    border-radius: 0 40px 40px 0;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list .service_item {
    display: flex;
    flex-direction: column-reverse;
    width: 3rem;
  }
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item:nth-child(2n) {
    flex-direction: row;
    margin-block: 0.4rem;
  }
  .service .service_list .service_item:nth-child(2n) figure {
    border-radius: 40px 0 0 40px;
  }
}
.service .service_list .service_item figure {
  overflow: hidden;
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item figure {
    flex-shrink: 0;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list .service_item figure {
    position: relative;
    margin-bottom: 0.25rem;
    border-radius: 40px;
  }
}
.service .service_list .service_item figure:before, .service .service_list .service_item figure:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s;
}
.service .service_list .service_item figure:before {
  background-color: #FBE5BB;
}
.service .service_list .service_item figure:after {
  border: 5px solid #fff;
  border-radius: 40px;
}
.service .service_list .service_item img {
  width: 100%;
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item img {
    width: 2.32rem;
  }
}
.service .service_list .service_item p {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item p {
    padding-bottom: 0.17rem;
    position: relative;
    width: 1.05rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list .service_item p {
    width: fit-content;
    margin: 0 auto;
  }
}
.no-touchevents .service .service_list .service_item p:hover ~ figure:before {
  opacity: 0.3;
}
.no-touchevents .service .service_list .service_item p:hover ~ figure:after {
  opacity: 1;
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item p::after {
    background: var(--color-red);
    bottom: 0;
    content: "";
    display: block;
    height: 0.04rem;
    left: 0;
    position: absolute;
    width: 100%;
  }
}
.service .service_list .service_item a {
  background: url("/common/img/icon-arrow04.svg") no-repeat right center/0.1rem 0.18rem;
  display: inline-block;
}
@media screen and (max-width: 640px) {
  .service .service_list .service_item a {
    background-size: 0.07rem 0.14rem;
    font-size: 0.14rem;
    padding-right: 0.23rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list .service_item a {
    font-size: 0.18rem;
    padding-right: 0.3rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_list .service_item a.arrow_down {
    background: url("/common/img/icon-arrow05.svg") no-repeat right center/0.18rem 0.1rem;
  }
}
.service .service_button {
  display: flex;
}
@media screen and (max-width: 640px) {
  .service .service_button {
    align-items: center;
    flex-direction: column;
    gap: 0.15rem;
    margin-top: 0.51rem;
  }
}
@media print, screen and (min-width: 641px) {
  .service .service_button {
    justify-content: center;
    gap: 0.2rem;
  }
}

.company {
  position: relative;
}
@media screen and (max-width: 640px) {
  .company figure {
    margin-bottom: 0.3rem;
    text-align: right;
  }
}
@media print, screen and (min-width: 641px) {
  .company figure {
    position: absolute;
    right: 0;
    top: 0;
  }
}
@media screen and (max-width: 640px) {
  .company figure img {
    width: 3.5rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company figure img {
    width: 7.19rem;
  }
}
.company .company_main {
  position: relative;
}
@media screen and (max-width: 640px) {
  .company .company_main {
    background: url("/img/index/bg08_sp.svg") no-repeat right 0.3rem bottom 0/3.2rem auto;
    padding: 0 0.3rem 2.05rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main {
    background: url("/img/index/bg06.svg") no-repeat center bottom/12.97rem auto;
    padding-bottom: 3.63rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .company_inner {
    display: flex;
    gap: 110px;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .company_detail {
    padding-top: 0.28rem;
    width: 3.9rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_main .ttl01 {
    margin-bottom: 0.3rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_main .ttl01::after {
    bottom: 0.08rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .ttl01::after {
    bottom: 0.14rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_main .ttl01 img {
    height: 0.35rem;
    width: 1.55rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .ttl01 img {
    height: 0.5rem;
    width: 2.07rem;
  }
}
.company .company_main .company_text {
  letter-spacing: 0.1em;
}
@media screen and (max-width: 640px) {
  .company .company_main .company_text {
    font-size: 0.13rem;
    line-height: 2;
    margin-bottom: 0.4rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .company_text {
    font-size: 0.16rem;
    line-height: 2.5;
    margin-bottom: 1.12rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_main .company_button a {
    margin-inline: auto;
  }
}
.company .company_main .company_pict {
  position: absolute;
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .company .company_main .company_pict {
    bottom: 0.78rem;
    left: 0.25rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .company_pict {
    bottom: 1.1rem;
    left: 0.9rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_main .company_pict img {
    height: 0.5rem;
    width: 0.7rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_main .company_pict img {
    height: 1rem;
    width: 1.41rem;
  }
}
@media print, screen and (min-width: 641px) {
  .company .company_pic {
    width: 50%;
  }
}
@media screen and (max-width: 640px) {
  .company .company_pic {
    width: calc(100% + 0.3rem);
  }
}
.company .company_pic .company_img01 {
  width: 100%;
  object-fit: cover;
  border-radius: 5rem 0 0 5rem;
}
@media print, screen and (min-width: 641px) {
  .company .company_pic .company_img01 {
    height: 5rem;
  }
}
@media screen and (max-width: 640px) {
  .company .company_pic .company_img01 {
    height: 2.5rem;
    object-position: center left;
  }
}
.company .company_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media screen and (max-width: 640px) {
  .company .company_load {
    top: -0.3rem;
    left: 58%;
    width: 6.515rem;
    height: 8.255rem;
  }
}

.recruit {
  position: relative;
}
@media screen and (max-width: 640px) {
  .recruit {
    background: url("/img/index/bg09_sp.svg") no-repeat left 0.5rem bottom 0.1rem/2.87rem auto;
    padding-bottom: 2.25rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit {
    background: url("/img/index/bg07.svg") no-repeat left 1.4rem bottom 0.25rem/12.5rem auto;
    padding-bottom: 2.9rem;
  }
}
.recruit .recruit_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_load {
    top: -2.3rem;
    left: 57%;
    width: 17.89rem;
    height: 13.51rem;
  }
}
@media screen and (max-width: 640px) {
  .recruit .recruit_load {
    top: 3.1rem;
    left: 42%;
    width: 4.185rem;
    height: 3.37rem;
  }
}
.recruit h2 {
  font-size: 0;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 640px) {
  .recruit h2 img {
    height: 0.25rem;
    width: 2.05rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit h2 img {
    height: 0.44rem;
    width: 3.83rem;
  }
}
.recruit .recruit_body {
  margin-inline: auto;
}
@media screen and (max-width: 640px) {
  .recruit .recruit_body {
    background: url(/img/index/img-recruit_2_sp.png) no-repeat center / 100% 100%;
    padding-top: 0.1rem;
    width: calc(100% - .4rem);
    background-color: #fff;
    border-radius: .3rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_body {
    background: url("/img/index/img-recruit_2.png") no-repeat center/cover;
    height: 6.41rem;
    padding-top: 0.25rem;
    width: 10.81rem;
    background-color: #fff;
    border-radius: .7rem;
  }
}
.recruit .recruit_lead {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .recruit .recruit_lead {
    font-size: 0.14rem;
    letter-spacing: 0.3em;
    margin-bottom: 0.23rem;
    padding-left: 0.3em;
    font-weight: 700;
  }
  .recruit_body {
    position: relative;
  }
  .recruit_button_box {
    gap: .1rem;
    width: 100%;
    padding: 2rem 0 .2rem;
    display: grid;
    justify-content: center;
    grid-template-columns: 1fr;
  }
  .recruit_button .btn02 {
    height: 0.48rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_lead {
    font-size: 0.24rem;
    letter-spacing: 0.35em;
    margin-bottom: 0.4rem;
    padding-left: 0.35em;
    font-weight: 700;
  }
  .recruit_body {
    position: relative;
  }
  .recruit_button_box {
    position: absolute;
    bottom: .4rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-wrap: wrap;
    gap: 0 .3rem;
    width: 100%;
    margin: 0 auto;
    justify-content: center;
  }
}
.recruit .recruit_catch {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .recruit .recruit_catch {
    margin-bottom: 0.18rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_catch {
    margin-bottom: 0.24rem;
  }
}
@media screen and (max-width: 640px) {
  .recruit .recruit_catch img {
    width: 2.8rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_catch img {
    height: 0.37rem;
    width: 5.24rem;
  }
}
.recruit .recruit_text {
  text-align: center;
}
@media screen and (max-width: 640px) {
  .recruit .recruit_text {
    line-height: 2;
    margin-bottom: 1.15rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_text {
    font-size: 0.16rem;
    line-height: 2.375;
    margin-bottom: 2.7rem;
  }
}
.recruit .recruit_button a {
  margin-inline: auto;
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_button a {
    width: 3.3rem;
  }
}
.recruit .recruit_pict {
  position: absolute;
  animation: jump 3s ease-in-out infinite;
}
@media screen and (max-width: 640px) {
  .recruit .recruit_pict {
    bottom: 1.27rem;
    right: 0.13rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_pict {
    bottom: 4.5rem;
    right: 0.8rem;
  }
}
@media screen and (max-width: 640px) {
  .recruit .recruit_pict img {
    width: 0.78rem;
  }
}
@media print, screen and (min-width: 641px) {
  .recruit .recruit_pict img {
    width: 1.56rem;
  }
}
@keyframes jump {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(0);
  }
}

.bottom {
  position: relative;
}
@media screen and (max-width: 640px) {
  .bottom {
    background: url("/img/index/bg10_sp.svg") no-repeat 0.17rem 0.11rem/3.38rem auto;
    height: 2.25rem;
  }
}
@media print, screen and (min-width: 641px) {
  .bottom {
    background: url("/img/index/bg08.svg") no-repeat 2.5rem 0.35rem/10.73rem 1.54rem;
    height: 2.14rem;
  }
}
.bottom .bottom_pict {
  position: absolute;
  opacity: 0;
}
@media screen and (max-width: 640px) {
  .bottom .bottom_pict {
    bottom: 0.03rem;
    left: 0.19rem;
  }
}
@media print, screen and (min-width: 641px) {
  .bottom .bottom_pict {
    bottom: 0;
    left: 0.83rem;
  }
}
@media screen and (max-width: 640px) {
  .bottom .bottom_pict img {
    height: 0.61rem;
    width: 0.58rem;
  }
}
@media print, screen and (min-width: 641px) {
  .bottom .bottom_pict img {
    height: 1.22rem;
    width: 1.17rem;
  }
}

.contact {
  margin-bottom: 0;
}
.contact .contact_load {
  position: absolute;
  transform: translateX(-50%);
  z-index: -1;
}
@media print, screen and (min-width: 641px) {
  .contact .contact_load {
    top: 3.3rem;
    left: 56%;
    width: 14.73rem;
    height: 3.67rem;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 640px) {
  .contact .contact_load {
    top: 2.2rem;
    left: 24%;
    width: 2.39rem;
    height: 2.36rem;
  }
}