@charset "UTF-8";
:root {
  /*===================== Color =====================*/
  --color-toyopet: #005952;
  --color-hac-base: #005952;
  --color-chubase-red: #F40013;
  --color-hac-base: #0F5E75;
  --color-kinto: #20A5C0;
  --color-main: #1F1F1F;
  --color-light-blue: #44A0BE;
  --color-blue: #178BD2;
  --color-red: #DB0011;
  --color-red02: #E54956;
  --color-pink: #EB6B76;
  --color-orange: #F28212;
  --color-gold: #B18B31;
  --color-light-gray: #C8C8C8;
  --color-white-blue: #E1ECEF;
  --color-gray: #DEE4E8;
  --color-blue-gray-light: rgba(235, 241, 245, 0.9);
  --color-blue-gray: #8E9FA4;
  --color-used: #EC1223;
  --color-light-green: #46B41E;
  --color-dark-green: #3A4246;
  --color-green: #00A941;
  --color-green02: #46B196;
  --color-green03: #00CDA4;
  --color-02: #556168;
  --color-03: #2970C0;
  --color-navy: #38405C;
  --color-sub-txt: #818181;
  --color-sub-txt-v02: #6F6F6F;
  --color-sub: #9D9D9D;
  --color-sub-line05: #d6d6d6;
  /*表*/
  --color-table: #494949;
  /*Table*/
  --color-table-bg: #F2F2F2;
  --color-table-menu: #79888D;
  /*===================== Gradient =====================*/
  --gradient-green-blue: linear-gradient(90deg,#78B50F 1%,#69D04D 35%,#38B5CE 72%,#3C64A1 100%);
  --gradient-red-yellow: linear-gradient(90deg,#F05353,#E7B500);
  /*===================== Font =====================*/
  --font-montserrat: "Montserrat", sans-serif;
  --font-manrope: "Manrope", sans-serif;
  --font-bungee: "Bungee", sans-serif;
  /*===================== CONT radius =====================*/
  --ease-bounce-s:linear(0, 0.271 8.8%, 0.542 19.9%, 0.837 34.2%, 1 44.7%, 0.943 51.1%, 0.925 57.5%, 0.937 63.1%, 1 77.4%, 0.991 84.2%, 1);
  --ease-bounce:linear(0, 0.247 13.2%, 0.415 20.5%, 0.624 27.4%, 1 37.8%, 0.794 44.9%, 0.747 47.9%, 0.731 50.8%, 0.744 53.5%, 0.785 56.4%, 0.999 65.5%, 0.927 69.6%, 0.904 73.4%, 0.921 77%, 1 84.5%, 0.981 89.4%, 1);
}

/*================================= 見出し =================================*/
/*======================= SP-VW =======================*/
/*======================= PC-VW =======================*/
/*------ 使用例 ------
.text {
	font-size: spvw(16);
}
*/
/*======================= PCLG-VW =======================*/
/*================================= マウスオーバー =================================*/
/*================================= コンテンツ 角丸 =================================*/
/*================================= アニメーション =================================*/
@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes big {
  0% {
    transform: scale(0);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes flipcard01 {
  0% {
    transform: rotateY(0);
  }
  100% {
    transform: rotateY(180deg);
  }
}
@keyframes flipcard02 {
  0% {
    transform: rotateY(180deg);
  }
  100% {
    transform: rotateY(360deg);
  }
}
/*================================= メニュー左寄せ =================================*/
.l-lower-title-area h1 .large .wrap .img.w01 {
  width: 97%;
  transform: translate(-70%, -48%);
}
.l-lower-title-area h1 .large .wrap .img.w02 {
  width: 64%;
  transform: translate(-50%, -45%);
}
.l-lower-title-area h1 .large .wrap .img.w03 {
  width: 75%;
  transform: translate(-50%, -55%);
}
.l-lower-title-area h1 .large .wrap .img.w04 {
  width: 55%;
  transform: translate(-50%, -45%);
}
.l-lower-title-area h1 .large .wrap .img.w05 {
  width: 50%;
  transform: translate(-50%, -45%);
}
.l-lower-title-area h1 .large .wrap .img.w06 {
  width: 67%;
  transform: translate(-55%, -45%);
}
.l-lower-title-area h1 .large .wrap .img.w07 {
  width: 67%;
  transform: translate(-55%, -45%);
}

a.lineservice-link {
  display: block;
  width: calc(644 / 750 * 100vw);
  margin: auto;
  background-color: #46B41E;
  color: #fff;
  border-radius: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  a.lineservice-link {
    border-radius: 10px;
  }
}
a.lineservice-link {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 0 calc(30 / 750 * 100vw) 0 calc(38 / 750 * 100vw);
  box-sizing: border-box;
}
@media screen and (min-width: 768px) {
  a.lineservice-link {
    width: 100%;
    border-radius: 5px;
    padding: 0 calc(23 / 1366 * 100vw) 0 calc(56 / 1366 * 100vw);
    pointer-events: none;
  }
}
a.lineservice-link p {
  font-size: calc(36 / 750 * 100vw);
  font-weight: bold;
  line-height: 1.4em;
}
@media screen and (min-width: 768px) {
  a.lineservice-link p {
    font-size: calc(35 / 1366 * 100vw);
  }
}
a.lineservice-link p .small {
  display: block;
  line-height: 1.4em;
  font-size: calc(22 / 750 * 100vw);
  font-weight: 500;
}
@media screen and (min-width: 768px) {
  a.lineservice-link p .small {
    font-size: 0.56em;
  }
}
a.lineservice-link div.img-wrap {
  width: 30%;
}
@media screen and (min-width: 768px) {
  a.lineservice-link div.img-wrap {
    width: 38%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
@media screen and (min-width: 768px) {
  a.lineservice-link div.img-wrap div.kumaru-img {
    width: 51%;
  }
}
@media screen and (min-width: 768px) {
  a.lineservice-link div.img-wrap div.qr-img {
    width: 41%;
    overflow: hidden;
    isolation: isolate;
    border-radius: 5px;
  }
}

section.sec-line {
  background: linear-gradient(146.76deg, #EEFEE6 0.16%, #CCF0C0 100.33%);
  box-sizing: border-box;
  padding: calc(100 / 750 * 100vw) calc(33 / 750 * 100vw);
  border-radius: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-line {
    border-radius: 10px;
  }
}
@media screen and (min-width: 768px) {
  section.sec-line {
    padding: calc(130 / 1366 * 100vw) 56px calc(90 / 1366 * 100vw);
  }
}
section.sec-line h2 {
  text-align: center;
  font-size: calc(60 / 750 * 100vw);
  line-height: 1.16em;
  margin-bottom: calc(55 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-line h2 {
    font-size: clamp(10px, 60 / 1366 * 100vw, 1000px);
    margin-bottom: 0.85em;
  }
}
section.sec-line h2 .small {
  display: block;
  font-size: calc(30 / 750 * 100vw);
  line-height: 1.2em;
  margin-bottom: 0.4em;
}
@media screen and (min-width: 768px) {
  section.sec-line h2 .small {
    font-size: 0.5em;
    margin-bottom: 0.1em;
  }
}
section.sec-line h2 .green {
  color: var(--color-light-green);
}
section.sec-line div.line-media-box {
  margin-bottom: calc(70 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-line div.line-media-box {
    margin-bottom: calc(50 / 1366 * 100vw);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
section.sec-line div.line-media-box div.line-img {
  margin-bottom: calc(50 / 750 * 100vw);
  border-radius: calc(5 / 750 * 100vw);
  overflow: hidden;
  isolation: isolate;
}
@media screen and (min-width: 768px) {
  section.sec-line div.line-media-box div.line-img {
    width: 45.2%;
    border-radius: 5px;
    margin: 0;
  }
}
section.sec-line div.line-media-box p {
  font-size: calc(26 / 750 * 100vw);
  line-height: 1.92em;
  font-weight: 500;
  box-sizing: border-box;
  padding: 0 calc(31 / 750 * 100vw);
  letter-spacing: 0.02em;
}
@media screen and (min-width: 768px) {
  section.sec-line div.line-media-box p {
    font-weight: 400;
    line-height: 2em;
    letter-spacing: 0.03em;
    font-size: clamp(10px, 18 / 1366 * 100vw, 24px);
    width: 46.6%;
    padding: 0;
  }
}
section.sec-line div.line-media-box p .red {
  font-weight: bold;
  color: var(--color-red02);
}

section.sec-flow {
  background: var(--color-dark-green);
  box-sizing: border-box;
  border-radius: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-flow {
    border-radius: 10px;
  }
}
section.sec-flow {
  margin-top: calc(20 / 750 * 100vw);
  padding: calc(100 / 750 * 100vw) calc(33 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-flow {
    padding: calc(100 / 1366 * 100vw) 56px;
    margin-top: 18px;
  }
}
section.sec-flow h2 {
  color: #fff;
  line-height: 1.5em;
  font-weight: 700;
  font-size: calc(40 / 750 * 100vw);
  line-height: 1.32em;
  letter-spacing: 0.04em;
  margin-bottom: calc(80 / 750 * 100vw);
  margin-left: calc(32 / 750 * 100vw);
  opacity: 0;
}
@media screen and (min-width: 768px) {
  section.sec-flow h2 {
    font-size: clamp(10px, 35 / 1366 * 100vw, 1000px);
    margin-bottom: calc(80 / 1366 * 100vw);
    margin-left: 0;
  }
}
section.sec-flow h2.animation {
  animation: fade 1s 0s forwards;
}
section.sec-flow h2 .small {
  display: block;
  font-weight: 400;
  font-size: 0.6em;
  line-height: 1.4em;
  margin-bottom: 0.6em;
}
@media screen and (min-width: 768px) {
  section.sec-flow h2 .small {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  section.sec-flow ul {
    border-top: solid 1px var(--color-light-gray);
  }
}
section.sec-flow li {
  box-sizing: border-box;
  padding: calc(70 / 750 * 100vw) calc(32 / 750 * 100vw);
  border-top: solid 1px var(--color-light-gray);
  opacity: 0;
}
@media screen and (min-width: 768px) {
  section.sec-flow li {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 5px 0;
    border: none;
  }
}
section.sec-flow li.animation {
  animation: fade 1s 0s forwards;
}
@media screen and (min-width: 768px) {
  section.sec-flow li:first-child {
    padding-top: 18px;
  }
}
section.sec-flow li:last-child {
  border-bottom: solid 1px var(--color-light-gray);
}
@media screen and (min-width: 768px) {
  section.sec-flow li:last-child {
    padding-bottom: 18px;
  }
}
section.sec-flow li:last-child p.step-txt::after, section.sec-flow li:last-child .flow-txt-box::after {
  content: none;
}
section.sec-flow li p.step-txt {
  font-family: var(--font-montserrat);
  color: #50CF21;
  line-height: 1em;
  position: relative;
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  section.sec-flow li p.step-txt {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    border-radius: 50em;
    width: 21.2%;
    order: 0;
  }
}
@media screen and (min-width: 1000px) {
  section.sec-flow li p.step-txt {
    width: 18%;
  }
}
@media screen and (min-width: 1280px) {
  section.sec-flow li p.step-txt {
    width: 21.2%;
  }
}
@media screen and (min-width: 768px) {
  section.sec-flow li p.step-txt::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 1px;
    background: var(--color-light-gray);
  }
}
section.sec-flow li p.step-txt .step {
  display: inline-block;
  font-weight: bold;
  line-height: 1em;
  font-size: calc(24 / 750 * 100vw);
  margin-bottom: 0.2em;
}
@media screen and (min-width: 768px) {
  section.sec-flow li p.step-txt .step {
    display: block;
    font-size: clamp(10px, 20 / 1366 * 100vw, 1000px);
  }
}
section.sec-flow li p.step-txt .number {
  display: inline-block;
  line-height: 0.84em;
  font-size: calc(24 / 750 * 100vw);
  font-weight: bold;
}
@media screen and (min-width: 768px) {
  section.sec-flow li p.step-txt .number {
    display: block;
    font-size: clamp(10px, 50 / 1366 * 100vw, 1000px);
  }
}
section.sec-flow li .flow-img {
  border-radius: calc(5 / 750 * 100vw);
  isolation: isolate;
  overflow: hidden;
  width: 67.2%;
  margin-top: calc(60 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-img {
    width: 27%;
    margin-top: 0;
    order: 1;
    border-radius: 5px;
  }
}
section.sec-flow li .flow-txt-box {
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  margin-top: calc(40 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box {
    width: 46.8%;
    margin-top: 0;
    order: 2;
    padding-left: 4%;
    box-sizing: border-box;
  }
}
@media screen and (min-width: 1000px) {
  section.sec-flow li .flow-txt-box {
    width: 49%;
    padding-left: 3%;
  }
}
@media screen and (min-width: 1280px) {
  section.sec-flow li .flow-txt-box {
    width: 46.8%;
    padding-left: 3%;
  }
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box::after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 1px;
    background: var(--color-light-gray);
  }
}
section.sec-flow li .flow-txt-box h3 {
  margin-bottom: 0.6em;
  font-weight: 700;
  font-size: calc(36 / 750 * 100vw);
  line-height: 1.44em;
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box h3 {
    margin-bottom: 1em;
    font-weight: 700;
    font-size: clamp(17px, 26 / 1366 * 100vw, 35px);
    line-height: 1.46em;
    letter-spacing: 0.02em;
  }
}
section.sec-flow li .flow-txt-box h4 {
  font-weight: bold;
  line-height: 1.6em;
  margin-top: 2em;
  margin-bottom: 0.6em;
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box h4 {
    font-size: clamp(10px, 14 / 1366 * 100vw, 1000px);
  }
}
section.sec-flow li .flow-txt-box p {
  font-weight: 400;
  font-size: calc(24 / 750 * 100vw);
  line-height: 1.75em;
  letter-spacing: 0.02em;
  color: #E2E2E2;
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box p {
    font-size: clamp(10px, 16 / 1366 * 100vw, 1000px);
    line-height: 1.8em;
    color: #fff;
  }
}
section.sec-flow li .flow-txt-box p a.green-link {
  color: var(--color-green03);
  text-decoration: underline;
}
section.sec-flow li .flow-txt-box .note {
  margin-top: 0.4em;
  font-weight: 400;
  font-size: calc(18 / 750 * 100vw);
  line-height: 1.5em;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 768px) {
  section.sec-flow li .flow-txt-box .note {
    font-weight: 400;
    font-size: clamp(10px, 10 / 1366 * 100vw, 100px);
    line-height: 1.4em;
    letter-spacing: 0.02em;
  }
}
section.sec-flow p.flow-completion-txt {
  text-align: center;
  color: #fff;
  font-weight: 700;
  font-size: calc(30 / 750 * 100vw);
  line-height: 1.72em;
  letter-spacing: 0.03em;
  padding-top: calc(75 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-flow p.flow-completion-txt {
    font-weight: 700;
    font-size: clamp(17px, 26 / 1366 * 100vw, 35px);
    line-height: 1.46em;
    letter-spacing: 0.02em;
    padding-top: calc(92 / 1366 * 100vw);
  }
}
section.sec-flow p.flow-completion-txt .green {
  color: #50CF21;
}

section.sec-movie {
  border-radius: calc(10 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-movie {
    border-radius: 10px;
  }
}
section.sec-movie {
  background-color: #fff;
  box-sizing: border-box;
  padding: calc(120 / 750 * 100vw) calc(56 / 750 * 100vw);
  margin-top: calc(20 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  section.sec-movie {
    padding: calc(90 / 1366 * 100vw) 56px;
    margin-top: 18px;
  }
}
section.sec-movie h2 {
  font-size: calc(40 / 750 * 100vw);
  line-height: 1.35em;
  padding: 0 0 1em 0.6em;
  margin-bottom: calc(40 / 750 * 100vw);
  border-bottom: solid 1px var(--color-sub);
  opacity: 0;
}
@media screen and (min-width: 768px) {
  section.sec-movie h2 {
    font-size: clamp(10px, 35 / 1366 * 100vw, 1000px);
    padding: 0 0 1.7em 0;
    margin-bottom: calc(20 / 1366 * 100vw);
  }
}
section.sec-movie h2.animation {
  animation: fade 1s 0s forwards;
}
section.sec-movie div.movie-box {
  opacity: 0;
}
@media screen and (min-width: 768px) {
  section.sec-movie div.movie-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
  }
}
section.sec-movie div.movie-box.animation {
  animation: fade 1s 0s forwards;
}
@media screen and (min-width: 768px) {
  section.sec-movie div.movie-box div.movie-box-inner {
    width: 66%;
  }
}
section.sec-movie div.movie-box div.m-youtube-wrap {
  border-radius: calc(10 / 750 * 100vw);
  overflow: hidden;
  isolation: isolate;
}
@media screen and (min-width: 768px) {
  section.sec-movie div.movie-box div.m-youtube-wrap {
    border-radius: 10px;
  }
}
section.sec-movie div.movie-box p {
  text-align: center;
  font-size: calc(24 / 750 * 100vw);
  line-height: 1.2em;
  margin-top: calc(40 / 750 * 100vw);
  color: var(--color-sub-txt-v02);
}
@media screen and (min-width: 768px) {
  section.sec-movie div.movie-box p {
    text-align: left;
    font-size: clamp(10px, 20 / 1366 * 100vw, 1000px);
    line-height: 1.62em;
    margin: 0;
    width: 28.2%;
  }
}

div.line-link-wrap {
  box-sizing: border-box;
  padding: calc(90 / 750 * 100vw) calc(33 / 750 * 100vw) 0;
}
@media screen and (min-width: 768px) {
  div.line-link-wrap {
    padding: calc(40 / 1366 * 100vw) 56px calc(80 / 1366 * 100vw);
  }
}
div.line-link-wrap h3 {
  font-size: calc(22 / 750 * 100vw);
  font-weight: 500;
  line-height: 1.2em;
  margin-bottom: 1.5em;
}
@media screen and (min-width: 768px) {
  div.line-link-wrap h3 {
    font-size: clamp(10px, 18 / 1366 * 100vw, 1000px);
  }
}
div.line-link-wrap section {
  padding: calc(35 / 750 * 100vw) 0 calc(70 / 750 * 100vw);
}
@media screen and (min-width: 768px) {
  div.line-link-wrap section {
    padding: calc(70 / 1366 * 100vw) 0 0;
  }
}
div.line-link-wrap a.zeals-link {
  display: block;
  margin: calc(70 / 750 * 100vw) auto 0;
  width: calc(320 / 750 * 100vw);
  font-size: calc(16 / 750 * 100vw);
  line-height: 1.2em;
}
@media screen and (min-width: 768px) {
  div.line-link-wrap a.zeals-link {
    width: 19.2em;
    margin: calc(70 / 1366 * 100vw) auto 0;
    font-size: clamp(10px, 13 / 1366 * 100vw, 1000px);
  }
  div.line-link-wrap a.zeals-link:hover div.zeals-logo {
    transform: scale(0.96);
  }
  div.line-link-wrap a.zeals-link:hover p {
    color: #020fb0;
  }
}
div.line-link-wrap a.zeals-link div.zeals-logo {
  width: calc(174 / 750 * 100vw);
  margin: auto;
  transition: all 0.3s;
}
@media screen and (min-width: 768px) {
  div.line-link-wrap a.zeals-link div.zeals-logo {
    width: 69.6%;
  }
}
div.line-link-wrap a.zeals-link p {
  text-align: center;
  margin-top: 1em;
  transition: color 0.3s;
}/*# sourceMappingURL=lineservice.css.map */