@charset "utf-8";

/*
==============
top.css
==============
*/

/* -----------------
■ contents
------------------- */
.contents {
  padding-bottom: 174px;
  background-color: #DAEEEB; }


/* -----------------
■ mv
------------------- */
.mv {
  position: relative; }

.mv img {
  width: 100%; }

.mv .slick-dots {
  position: absolute;
  left: 0;
  bottom: 37px;
  width: 100%;
  font-size: 0;
  text-align: center;
  line-height: 0; }

.mv .slick-dots li {
  display: inline-block;
  padding: 8px;
  cursor: pointer; }

.mv .slick-dots li span {
  display: inline-block;
  width: 48px;
  height: 4px;
  transition: background .4s;
  background-color: #fff; }

.mv .slick-dots li.slick-active span {
  background-color: #00A29A; }


/* -----------------
■ container
------------------- */
.container {
  max-width: 1352px;
  margin: 0 auto; }

.container__left {
  width: 49.26%;
  box-sizing: border-box; }

.container__right {
  width: 43%; }


/* -----------------
■ bnr
------------------- */
.bnr {
  margin-top: 80px;
  padding: 0 20px;
  text-align: center; }


/* -----------------
■ suggestion
------------------- */
.suggestion {
  display: flex;
  max-width: 1190px;
  padding: 163px 20px 0; }

.suggestion .container__left {
  padding-right: 7.8%;
  text-align: center; }

.suggestion__deco {
  display: inline-flex;
  gap: 0 15px;
  position: relative;
  margin-top: 42px; }

.suggestion__deco-box {
  position: relative;
  width: 152px;
  height: 152px;
  text-align: center;
  border-radius: 100%;
  background-color: #fff; }

.suggestion__deco-box img {
  position: absolute;
  top: 51%;
  left: 52%;
  transform: translate(-50%, -50%); }

.suggestion__deco-box-svg1 {
  transform: rotate(20deg); }

.suggestion__deco-box-svg2 {
  transform: rotate(-160deg); }

.circle {
  fill: none;
  stroke:#00A29A;
  stroke-width: 2px;
  stroke-dasharray: 476;
  stroke-dashoffset: -476; }

.circle__cover {
  fill: none;
  stroke:#fff;
  stroke-width: 3px;
  stroke-dasharray: 472;
  stroke-dashoffset: -476; }

.circle__cover1 {
  stroke-dashoffset: 526; }

.circle__cover2 {
  stroke-dashoffset: 526; }

.suggestion__deco.is-view .circle1 {
  animation: circle forwards linear 1s; }

.suggestion__deco.is-view .circle2 {
  animation: circle forwards linear 1s; }

@keyframes circle {
  0% { stroke-dashoffset: -476; }
  100% { stroke-dashoffset: 0; }
}

.suggestion__deco-plus {
  position: absolute;
  top: 50%;
  left: 50%;
  opacity: 0;
  transition: opacity .4s;
  transition-delay: 1s;
  transform: translate(-50%, -50%); }

.suggestion__deco.is-view .suggestion__deco-plus {
  opacity: 1; }

.suggestion__text {
  color: #3E3A39;
  font-size: 18px;
  font-weight: 500;
  line-height: 2; }

.suggestion__text + .suggestion__text {
  margin-top: 38px; }

.suggestion__caption {
  margin-top: 25px;
  color: #3E3A39;
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
  text-align: right; }


/* -----------------
■ concept
------------------- */
.concept {
  margin-top: 160px;
  padding: 0 20px; }

.concept__inner {
  display: flex;
  position: relative;
  padding: 65px 0 64px;
  border-radius: 14px;
  background-color: #F0F4F3; }

.concept .container__left {
  padding: 93px 20px 0;
  text-align: center; }

.concept .container__right {
  padding-right: 20px;
  box-sizing: border-box; }

.concept__logo {
  margin-top: 67px; }

.concept__text {
  max-width: 606px;
  color: #3E3A39;
  font-size: 18px;
  font-weight: 500;
  line-height: 2; }

.concept__text + .concept__text {
  margin-top: 40px; }

.concept__deco {
  position: absolute; }

.concept__deco1 {
  top: -63px;
  left: 28px; }

.concept__deco2 {
  bottom: -36px;
  right: 22px;  }


/* -----------------
■ lineup
------------------- */
.lineup {
  margin-top: 153px; }

.lineup__body {
  max-width: 1192px;
  margin: 39px auto 0;
  padding: 0 20px; }

.lineup__list {
  display: flex;
  justify-content: space-between; }

.lineup__list li {
  overflow: hidden;
  width: 31.544%;
  text-align: center;
  box-sizing: border-box;
  border-radius: 14px;
  background-color: #fff; }

.lineup__list-item1 {
  border: 1px solid #00A29A; }

.lineup__list-item1 .lineup__list-head {
  background-color: #00A29A; }

.lineup__list-item1 .lineup__list-body-text {
  color: #00A29A; }

.lineup__list-item2 {
  border: 1px solid #D9526D; }

.lineup__list-item2 .lineup__list-head {
  background-color: #D9526D; }

.lineup__list-item2 .lineup__list-body-text {
  color: #D9526D; }

.lineup__list-item3 {
  border: 1px solid #03BCD7; }

.lineup__list-item3 .lineup__list-head {
  background-color: #03BCD7; }

.lineup__list-item3 .lineup__list-body-text {
  margin-top: 0;
  color: #03BCD7; }

.lineup__list-head {
  display: flex;
  align-items: center;
  height: 78px; }

.lineup__list-head h3 {
  flex-grow: 1;
  line-height: 0; }

.lineup__list-body {
  padding: 23px 0 23px; }

.lineup__list-body-img {
  padding: 0 20px;
  text-align: center; }

.lineup__list-body-text {
  margin-top: 24px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.5; }

.lineup__list-body-link {
  margin-top: 8px; }

.lineup__list-body-link a {
  display: inline-block;
  position: relative;
  padding-right: 35px;
  color: #3E3A39;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.25;
  text-decoration: none; }

.lineup__list-body-link a::after {
  content: "";
  position: absolute;
  top: -3px;
  right: 3px;
  width: 26px;
  height: 26px;
  background: url(../img/top/icon_lineup_arrow@2x.png) no-repeat;
  background-size: 26px auto; }




/* ----------------------------------
■ SP
------------------------------------ */
@media print, screen and (max-width: 768px)
{
/* -----------------
■ contents
------------------- */
.contents {
  padding-bottom: 28vw; }


/* -----------------
■ mv
------------------- */
.mv .slick-dots {
  bottom: 3.5vw; }

.mv .slick-dots li {
  padding: 3vw 1.067vw; }

.mv .slick-dots li span {
  width: 6.4vw;
  height: 2px; }

.mv.is-last .slick-dots li span {
  background-color: #E6E6E6; }

.mv .slick-dots li.slick-active span {
  background-color: #00A29A; }


/* -----------------
■ container
------------------- */
.container {
  display: block;
  margin: 0 auto; }

.container__left,
.container__right {
  width: auto; }


/* -----------------
■ bnr
------------------- */
.bnr {
  width: 90.133vw;
  margin: 16.4vw auto 0;
  padding: 0; }


/* -----------------
■ suggestion
------------------- */
.suggestion {
  display: block;
  padding: 16.4vw 0 0; }

.suggestion .container__left {
  padding-right: 0; }

.suggestion .container__right {
  margin-top: 9vw;
  text-align: center; }

.suggestion__title {
  padding-left: 0;
  text-align: center; }

.suggestion__title img {
  width: 77.867vw; }

.suggestion__deco {
  display: flex;
  gap: 0 2.133vw;
  width: 47.467vw;
  margin: 6vw auto 0; }

.suggestion__deco-box {
  width: 22.667vw;
  height: 22.667vw; }

.suggestion__deco-box1 img {
  top: 53%;
  width: 15.733vw;
  margin-left: 0.2vw; }

.suggestion__deco-box2 img {
  left: 50%;
  width: 10.667vw; }

.circle {
  stroke-dashoffset: 476; }

@keyframes circle {
  0% { stroke-dashoffset: 476; }
  100% { stroke-dashoffset: 952; }
}

.suggestion__deco-plus {
  width: 4.533vw; }

.suggestion__text {
  font-size: 3.733vw;
  line-height: 2.3; }

.suggestion__text + .suggestion__text {
  margin-top: 8.2vw; }

.suggestion__caption {
  margin-top: 6.2vw;
  padding: 0 5.333vw;
  font-size: 3.2vw;
  line-height: 1.5; }


/* -----------------
■ concept
------------------- */
.concept {
  position: relative;
  margin-top: 28vw;
  padding: 0 5.333vw; }

.concept__inner {
  display: block;
  position: static;
  padding: 7.8vw 5.6vw 10.5vw;
  border-radius: 3.733vw; }

.concept .container__left {
  padding: 0; }

.concept__title {
  padding-left: 5vw; }

.concept__title img {
  width: 61.867vw; }

.concept__logo img {
  width: 16.533vw; }

.concept .container__right {
  margin-top: 8.5vw;
  padding-right: 0; }

.concept__logo {
  margin-top: 7vw; }

.concept__text {
  font-size: 3.733vw;
  line-height: 2; }

.concept__text + .concept__text {
  margin-top: 7.5vw; }

.concept__deco1 {
  top: -16.5vw;
  right: 0;
  left: auto;
  width: 23.733vw; }

.concept__deco2 {
  display: none;  }


/* -----------------
■ lineup
------------------- */
.lineup {
  margin-top: 27vw; }

.lineup__title {
  text-align: center; }

.lineup__title img {
  width: 49.6vw; }

.lineup__head-text {
  margin-top: 5vw;
  padding: 0 5.333vw; }

.lineup__body {
  margin: 4.2vw auto 0;
  padding: 0 5.333vw; }

.lineup__list {
  display: block; }

.lineup__list li {
  width: auto;
  border-radius: 3.733vw; }

.lineup__list li + li {
  margin-top: 4.2vw; }

.lineup__list-item1 .lineup__list-head img {
  width: 42.133vw; }

.lineup__list-item2 .lineup__list-head img {
  width: 37.333vw; }

.lineup__list-item3 .lineup__list-head img {
  width: 41.067vw; }

.lineup__list-head {
  height: 18.667vw; }

.lineup__list-body {
  padding: 0 0 4.5vw; }

.lineup__list-item1 .lineup__list-body {
  padding-top: 2vw; }

.lineup__list-item2 .lineup__list-body {
  padding-top: 7.5vw; }

.lineup__list-item3 .lineup__list-body {
  padding-top: 10vw; }

.lineup__list-body-column {
  display: flex;
  align-items: center;
  flex-direction: row-reverse; }

.lineup__list-body-img {
  padding: 0;
  text-align: center; }

.lineup__list-item1 .lineup__list-body-img {
  padding-right: 4vw; }

.lineup__list-item2 .lineup__list-body-img {
  padding-right: 4vw; }

.lineup__list-item3 .lineup__list-body-img {
  padding-right: 14vw; }

.lineup__list-item1 .lineup__list-body-img img {
  width: 43.733vw; }

.lineup__list-item2 .lineup__list-body-img img {
  width: 45.333vw; }

.lineup__list-item3 .lineup__list-body-img img {
  width: 25.067vw; }

.lineup__list-item1 .lineup__list-body-text {
  width: 37.333vw; }

.lineup__list-item2 .lineup__list-body-text {
  width: 35.733vw; }

.lineup__list-item3 .lineup__list-body-text {
  width: 46vw; }

.lineup__list-body-text {
  margin-top: 2vw;
  padding-left: 4vw;
  font-size: 4.267vw;
  line-height: 1.7;
  text-align: left; }

.lineup__list-body-link {
  margin-top: 3.4vw; }

.lineup__list-item3 .lineup__list-body-link {
  margin-top: 9.5vw; }

.lineup__list-body-link a {
  padding-right: 8vw;
  font-size: 3.733vw;
  line-height: 1.4; }

.lineup__list-body-link a::after {
  top: -0.6vw;
  right: -0.5vw;
  width: 6.4vw;
  height: 6.4vw;
  background-size: 6.4vw auto; }




/* ■ SP | END------------------- */
}