@charset "UTF-8";
@import "fonts.css?v=3";
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}
*{
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}
*:before,
*:after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
html {
    font-size: 62.5%;
}
body {
    line-height:1;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}
nav ul {
    list-style:none;
}
blockquote, q {
    quotes:none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}
a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
    text-decoration: none;
    cursor: pointer;
}
body{
    font-size: 1.5rem;
    line-height: 1.5;
    color: #000000;
    background: #E5F5F6;
    font-family: 'Noto Sans JP', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
    word-break: break-word;
    font-weight: 400;
}
/*remove highlight color touch on mobile*/
input,textarea,button,select,div,a,span {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}
a, input, div, select, textarea, img, button {
    outline: none;
}
a:focus, a:visited, input:focus, select:focus, textarea:focus, button:focus {
    outline: none !important;
}
li{
    list-style: none;
}
img {
    max-width: 100%;
    width /***/: auto;
    height: auto;
}
.img-full{
    width: 100%;
    display: flex;
}
.container {
    margin: 0 auto;
    max-width: 1100px;
    position: relative;
    z-index: 10;
    padding-left: 20px;
    padding-right: 20px;
}
.container.md{
    max-width: 920px;
}
.brandonGrotesque-bold-font{
    font-family: 'brandonGrotesque-bold', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
}
.brandonGrotesque-medium-font{
    font-family: 'brandonGrotesque-medium', sans-serif, "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro", "メイリオ", sans-serif;
}
/*
==============================================================
============================ common ==========================
==============================================================
*/
h2.title{
    display: inline-block;
    width: 100%;
    font-size: 1.8rem;
    font-weight: 700;
    position: relative;
    text-align: center;
    margin: 65px 0 60px;
}
h2.title:before{
    content: '';
    position: absolute;
    left: 50%;
    margin-left: -30px;
    bottom: -15px;
    height: 3px;
    width: 60px;
    background: #063A3F;
}
.lb-sp{
    display: none;
}
.lb-pc{
    display: block;
}
.anchor-link{
    position: relative;
    top: -77px;
    display: block;
    line-height: 0;
}
@media(max-width: 960px){
    .anchor-link{
        top: -53px;
    }
}
@media(max-width: 576px){
    h2.title{
        margin: 50px 0 48px;
    }
    .lb-sp{
        display: block;
    }
    .lb-pc{
        display: none;
    }
}
@media(max-width: 374px){
    h2.title{
        font-size: 1.7rem;
        margin: 40px 0 38px;
    }
}
/*
==============================================================
========================= End common =========================
==============================================================
*/
/*
==============================================================
=========================== pagetop ==========================
==============================================================
*/
#pagetop {
    color: #fff;
    width: 50px;
    height: 50px;
    text-align: center;
    line-height: 70px;
    bottom: 35px;
    right: 40px;
    position: fixed;
    z-index: 900;
    cursor: pointer;
    display: none;
    background: rgb(6, 58, 63 , 0.9);
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    border-radius: 50%;
}
#pagetop:before{
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -10px;
    margin-top: -5px;
    width: 20px;
    height: 20px;
    border-color: #fff;
    border-width: 0 2px 2px 0px;
    border-style: solid;
    display: inline-block;
    transform: rotate(-135deg);
    -webkit-transform: rotate(-135deg);
    transition: .3s;
}
#pagetop:hover:before{
    margin-top: -8px;
}
@media(max-width: 767px){
    #pagetop {
        width: 40px;
        height: 40px;
        right: 10px;
        bottom: 50px;
    }
    #pagetop:before{
        width: 16px;
        height: 16px;
        margin-left: -8px;
    }
}
/*
==============================================================
========================= End pagetop ========================
==============================================================
*/
/*
==============================================================
======================= hamburger menu =======================
==============================================================
*/
.hamburger-menu {
    position: absolute;
    right: 15px;
    top: 50%;
    width: 40px;
    height: 24px;
    margin-top: -12px;
    cursor: pointer;
    z-index: 1001;
    display: none;
}
.hamburger-menu .bar,
.hamburger-menu .bar:after,
.hamburger-menu .bar:before {
    width: 100%;
    height: 3px;
}
.hamburger-menu .bar {
    position: relative;
    transform: translateY(10px);
    background: rgba(0, 0, 0, 1);
    transition: all 0ms 300ms;
    display: block;
}
.hamburger-menu .bar.active {
    background: rgba(0, 0, 0, 0); 
}
.hamburger-menu .bar:before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 10px;
    background: rgba(0, 0, 0, 1);
    transition: bottom 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.hamburger-menu .bar:after {
    content: "";
    position: absolute;
    left: 0;
    top: 10px;
    background: rgba(0, 0, 0, 1);
    transition: top 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms cubic-bezier(0.23, 1, 0.32, 1);
}
.hamburger-menu .bar.active:after {
    top: 0px;
    transform: rotate(30deg);
    transition: top 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);;
}
.hamburger-menu .bar.active:before {
    bottom: 0px;
    transform: rotate(-30deg);
    transition: bottom 300ms cubic-bezier(0.23, 1, 0.32, 1), transform 300ms 300ms cubic-bezier(0.23, 1, 0.32, 1);;
}
@media(max-width: 960px){
    .hamburger-menu{
        display: block;
    }
}
/*
==============================================================
====================== End hamburger menu ====================
==============================================================
*/
/*
==============================================================
============================ Header ==========================
==============================================================
*/
header{
    position: sticky;
    left: 0;
    right: 0;
    top: 0;
    z-index: 100;
    background: #fff;
    line-height: 1;
}
header .container{
    max-width: 100%;
}
header .inner{
    display: flex;
}
header .logo{
    display: inline-block;
    padding: 12px 0;
}
header .logo img{
    width: 42px;
}
header nav {
    padding: 0 40px 0 10px;
    width: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
header ul a{
    color: initial;
    transition: .2s;
}
header nav > ul{
    display: flex;
}
header nav > ul > li{
    position: relative;
    padding: 15px 10px;
}
header nav > ul > li > a{
    display: inline-block;
    padding: 8px 5px;
    position: relative;
}
header nav > ul > li > a:before{
    position: absolute;
    left: 5px;
    right:  5px;
    bottom: 0px;
    border-bottom: 2px solid #063A3F;
    content: '';
    display: block;
    transform: translate(0%,0%) scale(0,1);
    z-index: -1;
    transition: .3s;
}
header nav > ul > li > a:hover:before,
header nav > ul > li.active>a:before{
    transform: translate(0%,0%) scale(1);
}
.shadow-nav header{
    background: #fff;
    transition: .2s;
    -webkit-box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.1);
            box-shadow: 0px 6px 12px 0px rgba(0, 0, 0, 0.1);
}
@media(max-width: 960px){
    header .container{
        height: 100%;
    }
    header .inner{
        display: block;
        width: 100%;
        height: 100%;
    }
    header .logo{
        padding: 10px 0;
        position: relative;
        z-index: 90;
    }
    header .logo img{
        width: 25px;
    }
    header nav{
        position: fixed;
        right: -100%;
        top: 0;
        bottom: 0;
        background: #fff;
        width: 100%;
        transition: all 0.5s;
        z-index: 1000;
        padding: 0;
        display: inline-block;
    }
    header.active nav{
        right: 0;
        width: 400px;
        box-shadow: -5px 0 20px 0 rgba(0,0,0,.4);
    }
    header nav > ul{
        display: inline-block;
        width: 100%;
        padding: 15px;
        margin-top: 53px;
        overflow: auto;
    }
     header nav > ul:before{
        content: '';
        position: absolute;
        left: 0;
        right: 0;
        top: 0;
        height: 53px;
        background: #E5F5F6;
     }
    header nav > ul > li{
        padding: 0;
    }
    header nav ul li a {
        padding: 20px 0px;
        display: inline-block;
        width: 100%;
        border-bottom: 1px solid #e2e2e0;
    }
    header nav > ul > li > a:before{
        border-bottom: none !important;
    }
    header nav > ul > li > a:hover:before,
    header nav > ul > li.active>a:before{
        transform: unset;
    }
    header .menu-backdrop{
        position: fixed;
        z-index: 100;
        left: 0;
        right: 0;
        top: 0;
        bottom: 0;
        background: rgba(0,0,0,.6);
    }
}
@media(max-width: 500px){
    header.active nav{
        width: 80%;
    }
}
/*
==============================================================
========================= End header =========================
==============================================================
*/
/*
==============================================================
=========================== footer ===========================
==============================================================
*/
footer{
    color: #fff;
    text-align: center;
    padding: 40px 0 0;
}
footer .logo{
    display: inline-block;
    width: 77px;
    margin-bottom: 25px;
}
footer .logo img{
    max-width: 100%;
}
footer p.copy-right {
    padding: 10px 10px;
    background: #063A3F;
}
@media(max-width: 576px){
    footer{
        padding: 28px 0 8px;
    }
    footer .logo{
        width: 55px;
    }
    footer .logo{
        margin-bottom: 14px;
    }
    footer .copy-right{
        font-size: 1.3rem;
    }
}
/*
==============================================================
========================= End footer =========================
==============================================================
*/
/*
==============================================================
========================= header title =======================
==============================================================
*/
.header-title{
    display: flex;
    justify-content: center;
    position: relative;
    background: #001414;
    color: #fff;
}
.header-title:before{
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 50%;
    background: #063A3F;
    z-index: 0;
}
.header-title h2{
    padding: 20px 0;
    position: relative;
    z-index: 1;
    display: inline-block;
}
.header-title h2 img{
    height: 73px;
    display: flex;
}
@media(max-width: 480px){
    .header-title h2{
        font-size: 1.9rem;
        padding: 16px 0;
    }
    .header-title .logo img{
        height: 42px;
    }
}
@media(max-width: 374px){
    .header-title .logo img{
        height: 36px;
        padding: 0;
    }
}
/*
==============================================================
====================== End header title ======================
==============================================================
*/
/*
==============================================================
=========================== banner ===========================
==============================================================
*/
.banner{
    position: relative;
    padding-top: 55%;
}
.banner ul{
    display: flex;
}
.banner li{
    overflow: hidden;
    position: relative;
    display: none;
}
.banner li img{
    display: flex;
}
.banner .banner-fixed {
    position: absolute;
    z-index: 1;
    bottom: 30px;
    left: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: column;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
}
.banner .banner-fixed img {
    width: 290px;
}
@media(max-width: 767px){
    .banner .banner-fixed img {
        width: 200px;
    }
}
@media(max-width: 576px){
    .banner {
        padding-top: 115.2%;
    }
    .banner .banner-fixed {
        left: 50%;
        -ms-transform: translate(-50%, 0);
        -moz-transform: translate(-50%, 0);
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
        flex-direction: inherit;
        -ms-flex-direction: inherit;
    }
    .banner .banner-fixed img {
        width: 150px;
    }
}
/*
==============================================================
========================== End banner ========================
==============================================================
*/
/*
==============================================================
============================ compList =========================
==============================================================
*/
.compList {
    padding-bottom: 150px;
    background: #FFFFFF;
}
.compList .slider_parent {
  position: relative;
  overflow: hidden;
}

.slider_parent .slider {
  display: flex;
}

.text_scroll {
  animation: scroll 144s linear infinite;
  animation-fill-mode: forwards;
  margin-bottom: 40px;
}

.text_scroll_reverse {
  animation: scroll 108s linear infinite;
  animation-fill-mode: forwards;
  animation-direction: reverse !important; 
}

.logos {
  flex-shrink: 0;
}

.logos img#logo-top01 {
    height: 70px;
}
.logos img#logo-top02 {
    height: 37px;
}
.logos img#logo-top03 {
    height: 28px;
}
.logos img#logo-top04 {
    height: 42px;
}
.logos img#logo-top05 {
    height: 29px;
}
.logos img#logo-top06 {
    height: 69px;
}
.logos img#logo-top07 {
    height: 69px;
}
.logos img#logo-top08 {
    height: 69px;
}
.logos img#logo-top09 {
    height: 22px;
}
.logos img#logo-top10 {
    height: 52px;
}
.logos img#logo-top11 {
    height: 69px;
}
.logos img#logo-top12 {
    height: 69px;
}
.logos img#logo-top13 {
    height: 56px;
}
.logos img#logo-top14 {
    height: 30px;
}
.logos img#logo-top15 {
    height: 69px;
}
.logos img#logo-top16 {
    height: 38px;
}
.logos img#logo-top17 {
    height: 69px;
}
.logos img#logo-top18 {
    height: 69px;
}
.logos img#logo-top19 {
    height: 33px;
}
.logos img#logo-top20 {
    height: 37px;
}
.logos img#logo-top21 {
    height: 69px;
}
.logos img#logo-top22 {
    height: 43px;
}
.logos img#logo-top23 {
    height: 50px;
}
.logos img#logo-top24 {
    height: 69px;
}
.logos img#logo-top25 {
    height: 39px;
}
.logos img#logo-top26 {
    height: 42px;
}
.logos img#logo-top27 {
    height: 61px;
}
.logos img#logo-top28 {
    height: 52px;
}
.logos img#logo-top29 {
    height: 55px;
}
.logos img#logo-top30 {
    height: 52px;
}
.logos img#logo-top31 {
    height: 69px;
}
.logos img#logo-top32 {
    height: 69px;
}
.logos img#logo-top33 {
    height: 52px;
}
.logos img#logo-top34 {
    height: 46px;
}
.logos img#logo-top35 {
    height: 69px;
}
.logos img#logo-top36 {
    height: 42px;
}
.logos img#logo-top37 {
    height: 32px;
}
.logos img#logo-top38 {
    height: 59px;
}
.logos img#logo-top39 {
    height: 49px;
}
.logos img#logo-top40 {
    height: 50px;
}
.logos img#logo-top41 {
    height: 49px;
}
.logos img#logo-top42 {
    height: 53px;
}
.logos img#logo-top43 {
    height: 34px;
}
.logos img#logo-top44 {
    height: 47px;
}
.logos img#logo-top45 {
    height: 27px;
}
.logos img#logo-top46 {
    height: 69px;
}
.logos img#logo-top47 {
    height: 50px;
}
.logos img#logo-top48 {
    height: 30px;
}

.logos img#logo-bottom01 {
    height: 33px;
}
.logos img#logo-bottom02 {
    height: 33px;
}
.logos img#logo-bottom03 {
    height: 28px;
}
.logos img#logo-bottom04 {
    height: 55px;
}
.logos img#logo-bottom05 {
    height: 45px;
}
.logos img#logo-bottom06 {
    height: 69px;
}
.logos img#logo-bottom07 {
    height: 65px;
}
.logos img#logo-bottom08 {
    height: 15px;
}
.logos img#logo-bottom09 {
    height: 52px;
}
.logos img#logo-bottom10 {
    height: 60px;
}
.logos img#logo-bottom11 {
    height: 69px;
}
.logos img#logo-bottom12 {
    height: 45px;
}
.logos img#logo-bottom13 {
    height: 29px;
}
.logos img#logo-bottom14 {
    height: 69px;
}
.logos img#logo-bottom15 {
    height: 69px;
}
.logos img#logo-bottom16 {
    height: 48px;
}
.logos img#logo-bottom17 {
    height: 59px;
}
.logos img#logo-bottom18 {
    height: 32px;
}
.logos img#logo-bottom19 {
    height: 38px;
}
.logos img#logo-bottom20 {
    height: 30px;
}
.logos img#logo-bottom21 {
    height: 31px;
}
.logos img#logo-bottom22 {
    height: 23px;
}
.logos img#logo-bottom23 {
    height: 58px;
}
.logos img#logo-bottom24 {
    height: 40px;
}
.logos img#logo-bottom25 {
    height: 46px;
}
.logos img#logo-bottom26 {
    height: 35px;
}
.logos img#logo-bottom27 {
    height: 69px;
}
.logos img#logo-bottom28 {
    height: 43px;
}
.logos img#logo-bottom29 {
    height: 45px;
}
.logos img#logo-bottom30 {
    height: 42px;
}
.logos img#logo-bottom31 {
    height: 65px;
}
.logos img#logo-bottom32 {
    height: 28px;
}
.logos img#logo-bottom33 {
    height: 42px;
}
.logos img#logo-bottom34 {
    height: 56px;
}
.logos img#logo-bottom35 {
    height: 69px;
}
.logos img#logo-bottom36 {
    height: 26px;
}

.slider_parent ul {
    display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0;
  margin: 0;
}


.slider_parent ul li {
    display: inline-block;
  margin-left: 10px;
  margin-right: 10px;
}




.slider_parent ul li > a img {
  transition: 0.4s;
}
.slider_parent ul li > a img {
  max-width: 100% !important;
}

@keyframes scroll {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}

@media only screen and (max-width: 991px) {
    .compList {
        padding-bottom: 50px;
    }
    .slider_parent ul li {
        margin-left: 5px;
        margin-right: 5px;
    }
    .slider_parent ul li img {
        height: 50px;
        width: auto;
    }
}
@media(max-width: 767px){
    .text_scroll {
        margin-bottom: 30px;
    }
}

/*
==============================================================
========================== End compList =======================
==============================================================
*/
/*
==============================================================
=========================== uptale ========================
==============================================================
*/
.uptale {
    padding: 50px;
}
.uptale ul {
    display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: bold;
}
.uptale ul li {
    flex: 1;
}
.uptale ul li:last-child {
    flex: 1.2;
    background: #FFFFFF;
    text-align: center;
}
.uptale ul li h3 span {
    display: inline-block;
    padding: 2px 10px;
    margin: 2px 0;
    font-size: 2.5rem;
    background: #002337;
    color: #FFFFFF;
}
.uptale ul li p {
    margin-top: 30px;
    font-size: 1.5rem;
    line-height: 2.2;
}
.uptale ul li img {
    max-width: 537px;
    margin: auto;
}
@media(max-width: 1100px){
    .uptale ul li:last-child {
        flex: 1;
    }
    .uptale ul li img {
        max-width: 400px;
        padding: 20px 0;
    }
}
@media(max-width: 960px){
    .uptale {
        padding: 20px 0;
    }
    .uptale ul li h3 span {
        font-size: 2rem;
    }
    .uptale ul li img {
        max-width: 250px;
    }
}
@media(max-width: 767px){
    .uptale ul {
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
    }
    .uptale ul li img {
        max-width: 300px;
    }
    .uptale ul li h3 span {
        font-size: 1.8rem;
    }
    .uptale ul li p {
        margin: 20px auto;
        font-size: 1.4rem;
    }
}
@media(max-width: 576px){
   
}
@media(max-width: 374px){
    .uptale ul li img {
        max-width: 200px;
    }
}
/*
==============================================================
========================= End uptale ======================
==============================================================
*/
/*
==============================================================
=========================== reason ========================
==============================================================
*/
.reason {
    padding-bottom: 50px;
    background: #FFFFFF;
}
.reason ul {
    text-align: center;
}
.reason ul li {
    display: inline-block;
    width: 665px;
    margin: 10px auto;
    border: 1px solid #E0E0E0;
}
.reason ul li .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: flex-start;
    padding: 30px 20px;
}
.reason ul li .inner .icon {
    flex: 1;
}
.reason ul li:nth-child(1) .icon img {
    width: 137px;
}
.reason ul li:nth-child(2) .icon img {
    width: 117px;
}
.reason ul li:nth-child(3) .icon img {
    width: 108px;
}
.reason ul li .inner .desc {
    flex: 2;
    font-size: 1.5rem;
    font-weight: bold;
    text-align: justify;
    text-justify: inter-ideograph;
    text-justify: inter-character;
}
.reason ul li .inner .desc h3 {
    margin: 10px 0 30px;
    font-size: 3.0rem;
}
.reason ul li .inner .desc p {
    line-height: 2;
}
@media(max-width: 767px){
    .reason ul li {
        max-width: 100%;
    }
    .reason ul li .inner {
        align-items: center;
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
    }
    .reason ul li:nth-child(1) .icon img {
        width: 99px;
    }
    .reason ul li:nth-child(2) .icon img {
        width: 80px;
    }
    .reason ul li:nth-child(3) .icon img {
        width: 74px;
    }
    .reason ul li .inner .desc {
        text-align: center;
        font-size: 1.2rem;
    }
    .reason ul li .inner .desc h3 {
        margin: 10px auto;
        font-size: 2.2rem;
    }
}
/*
==============================================================
========================== End reason =======================
==============================================================
*/
/*
==============================================================
=========================== step ========================
==============================================================
*/
.step {
    padding-bottom: 50px;
}
.step ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: stretch;
    gap: 50px;
}
.step ul li {
    position: relative;
    flex: 1;
    padding: 40px 20px 10px;
    margin-top: 50px;
    background: #FFFFFF;
    text-align: center;
}
.step ul li:after {
    content: "";
    position: absolute;
    top: 50%;
    right: -35px;
    -ms-transform: translate(0, -50%);
    -moz-transform: translate(0, -50%);
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    display: inline-block;
    background: url('../img/ic-arrow-step.svg') no-repeat center center;
    width: 20px;
    height: 25px;
}
.step ul li:last-child:after {
    display: none;
}
.step ul li .num {
    position: absolute;
    top: -35px;
    left: 50%;
    -ms-transform: translate(-50%, 0);
    -moz-transform: translate(-50%, 0);
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    font-size: 3.0rem;
    font-weight: bold;
    color: #D95A3B;
    white-space: nowrap;
}
.step ul li .num span:last-child {
    font-size: 7.9rem;
    line-height: 0;
}
.step ul li .box {
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 2;
}
.step ul li .box h3 {
    font-size: 3.0rem;
}
.step ul li .box p {
    margin: 10px 0 20px;
}
.step ul li:nth-child(1) .box img {
    width: 90px;
}
.step ul li:nth-child(2) .box img {
    width: 257px;
}
.step ul li:nth-child(3) .box img {
    width: 237px;
}
@media(max-width: 767px){
    .step ul {
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
    }
    .step ul li {
        padding: 10px;
        margin-top: 70px;
    }
    .step ul li:after {
        top: auto;
        bottom: -45px;
        right: auto;
        left: 45%;
        -ms-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
        -webkit-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        transform: rotate(90deg);
        width: 40px;
        height: 35px;
    }
}

/*
==============================================================
========================== End step =======================
==============================================================
*/

/*
==============================================================
============================ example ========================
==============================================================
*/
.example {
    padding-bottom: 100px;
    background: #FFFFFF;
}
.example .example-slider ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 50px;
}
.example .example-slider ul li {
    flex: 1;
    padding: 20px;
    border: 1px solid #E1E1E1;
    font-size: 1.2rem;
    text-align: justify;
    text-justify: inter-ideograph;
    text-justify: inter-character;
}
.example .example-slider ul li img {
    margin: 0 auto;
}
.example .example-slider ul li h3 {
    position: relative;
    font-size: 1.7rem;
    padding: 10px 0 0;
    margin-bottom: 40px;
    text-align: center;
}
.example .example-slider ul li h3:before {
    content: '';
    position: absolute;
    left: 50%;
    margin-left: -13px;
    bottom: -18px;
    height: 1px;
    width: 26px;
    background: #063A3F;
}
.example .example-slider ul li p.text {
    margin-bottom: 15px;
}
.example .example-slider ul li p.comp {
    margin-bottom: 10px;
    font-size: 1.0rem;
    color: #808080;
    text-align: right;
}
.example .example-slider ul li .btn label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    height: 40px;
    background: #063A3F;
    color: #FFFFFF;
    cursor: pointer;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
}
.example .example-slider ul li .btn label:hover {
    opacity: 0.7;
}
.example .example-slider ul li .btn label span {
    font-size: 1.2rem;
    margin-right: 10px;
}
.example .example-slider ul li .btn label img {
    width: 16px;
    margin: 0;
}

/*popup template design*/
.popup-background{
    position: fixed;
    z-index : 100;
    top : 0;
    left : 0;
    height : 100vh;
    width : 100%;
    background-color: #000000;
    opacity : 0.7;
}
.popup{
    --height : 50vh;
    --width : 70vw;
    z-index : 101;
    position: fixed;
    top : calc(50vh - calc(var(--height) / 2));
    left : calc(50vw - calc(var(--width) / 2));
    height : var(--height);
    width : var(--width);
    padding: 30px;
    overflow : auto;
    background-color: white;
}
.popup > .close-button{
    --size : 30px;
    position:absolute;
    z-index: 1;
    top : 20px;
    right : 20px;
    height : var(--size);
    width : var(--size);
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: transparent;
    color : #000000;
    font-size: var(--size);
    border-radius: calc(var(--size)/5);
    cursor: pointer;
}
.popup .content{
    position: relative;
}
.popup h3{
    position: relative;
    font-size: 2.0rem;
    text-align: center;
}
.popup h3:before{
    content: '';
    position: absolute;
    left: 50%;
    margin-left: -13px;
    bottom: -10px;
    height: 1px;
    width: 26px;
    background: #063A3F;
}
.popup .comp{
    position: absolute;
    top: 0;
    left: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 1.5rem;
}
.popup .comp img{
    width: 30px;
    margin-right: 10px;
}
.popup .contents{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 30px;
    margin-top: 50px;
}
.popup .contents .img{
    flex: 1.5;
}
.popup .contents .img img{
    width: 100%;
}
.popup .contents .itemList{
    flex: 2.5;
    font-size: 1.2rem;
    font-weight: bold;
    line-height: 1.7;
    text-align: justify;
    text-justify: inter-ideograph;
    text-justify: inter-character;
}
.popup .contents .itemList .item:first-child {
    margin-bottom: 20px;
}
.popup .contents .itemList .item h4{
    padding-bottom: 10px;
    margin-bottom: 5px;
    font-size: 1.4rem;
    color: #949494;
    border-bottom: 1px solid #AEAEAE;
}

/*hide popup*/
.popup-flag{
    display: none;
}
.popup-flag:not(:checked) + .popup-background{
    display:none;
}
.popup-flag:not(:checked) + * + .popup{
    display:none;
}
@media(max-width: 767px){
    .example .example-slider ul{
        gap: 20px;
    }
}
@media(max-width: 576px){
    .example{
        padding-bottom: 80px;
    }
    .example .example-slider ul li{
        margin: 2vw;
    }
    .example .example-slider ul li .btn{
        text-align: center;
    }
    .example .example-slider ul li .btn label{
        width: 100%;
        height: auto;
        padding: 10px 0;
        margin: 0 auto;
        text-align: center;
    }
    .example .example-slider ul li .btn label span{
        display: inline-block;
        vertical-align: middle;
    }
    .example .example-slider ul li .btn label img{
        display: inline-block;
        vertical-align: middle;
    }
    .example .slick-prev:before,
    .example .slick-next:before {
        content: '';
    }
    .example .slick-prev,
    .example .slick-next {
        top: auto;
        bottom: -120px;
    }
    .example .slick-prev {
        background: url('../img/ic-arrow-left.svg') no-repeat center center;
        width: 40px;
        height: 40px;
        left: 25vw;
    }
    .example .slick-next {
        background: url('../img/ic-arrow-right.svg') no-repeat center center;
        width: 40px;
        height: 40px;
        right: 25vw;
    }
    .example .slick-dots li button{
        width: 30px;
        height: 30px;
    }
    .example .slick-dots li button:before{
        width: 30px;
        height: 30px;
        font-size: 50px;
    }
    .example .example-slider ul.slick-dots {
        display: block;
    }
    .example .example-slider ul.slick-dots li {
        padding: 0;
        margin: 0 5px;
        border: none;
    }

    .popup{
        --height: 70vh;
        padding: 20px;
    }
    .popup > .close-button{
        top: 10px;
        right: 10px;
    }
    .popup h3{
        font-size: 1.6rem;
    }
    .popup h3:before{
        height: 3px;
    }
    .popup .comp{
        font-size: 1.2rem;
        top: 40px;
        right: 0;
        left: auto;
    }
    .popup .comp img{
        width: 20px;
    }
    .popup .contents{
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        gap: 10px;
        margin-top: 70px;
    }
}

/*
==============================================================
========================= End example ======================
==============================================================
*/
/*
==============================================================
========================== group-contact =====================
==============================================================
*/
.meta-quest {
    text-align: center;
    padding: 70px 10px 0;
}
.meta-quest .container {
    max-width: 944px;
    background: #fff;
    padding: 50px 140px;
}
.meta-quest .container ul {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 50px;
    padding: 100px 0 30px;
}
.meta-quest .container ul li {
    flex: 1;
}
.meta-quest .container ul li:first-child {
    position: absolute;
    top: 20px;
}
.meta-quest .container ul li:first-child img {
    width: 108px;
}
.meta-quest .container ul li img {
    width: 375px;
}
.meta-quest .container ul li p {
    line-height: 2;
}

@media(max-width: 767px){
    .meta-quest {
        padding-bottom: 30px;
    }
    .meta-quest .container {
        padding: 20px 5px;
    }
    .meta-quest .container ul {
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        gap: 30px;
        padding-top: 130px;
    }
    .meta-quest .container ul li img {
        width: 70%;
        max-width: 375px;
    }
}

/*
==============================================================
======================= End meta-quest ====================
==============================================================
*/
/*
==============================================================
========================== group-contact =====================
==============================================================
*/
.group-contact {
    text-align: center;
    padding: 70px 0px 0;
}
.group-contact .container{
    max-width: 944px;
    background: #fff;
    padding-left: 140px;
    padding-right: 140px;
}
.group-contact .usage-fee{
    display: inline-block;
    width: 100%;
    padding: 0 10px 45px 10px;
}
.group-contact .core-plan{
    background: #f4f3f2;
    padding: 25px 20px 40px 20px;
    display: inline-block;
    width: 100%;
    margin-bottom: 50px;
}
.group-contact .core-plan .btn{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin: 30px auto 10px;
    width: 350px;
    height: 75px;
    background: #063A3F;
    color: #FFFFFF;
}
.group-contact .core-plan .btn a{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%;
    height: 100%;
    color: #FFFFFF;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
}
.group-contact .core-plan .btn a:hover{
    opacity: 0.7;
}
.group-contact .core-plan .btn a h3{
    display: inline-block;
    margin-right: 20px;
    font-size: 2.4rem;
}
.group-contact .core-plan .btn a img{
    width: 28px;
}
.group-contact .core-plan .txt{
    display: inline-block;
    width: 100%;
    font-size: 1.4rem;
    line-height: 2;
    padding-top: 20px;
}
.group-contact .core-plan .phone {
    margin-top: 40px;
}
.group-contact .core-plan .phone a{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-transition: all ease-in-out .3s;
    transition: all ease-in-out .3s;
    color: initial;
    font-size: 1.7rem;
    font-weight: 700;
}
.group-contact .core-plan .phone a:hover{
    opacity: 0.7;
}
.group-contact .core-plan .phone a img{
    width: 45px;
}
.group-contact .core-plan .phone a span{
    margin-left: 10px;
}
.group-contact .about{
    display: inline-block;
    width: 100%;
    border: 1px solid #9A63FF;
    margin-bottom: 65px;
    padding: 0 20px 32px 20px;
}
.group-contact .about h2.title{
    color: #9A63FF;
    margin: 45px 0 50px;
}
.group-contact .about .txt{
    display: inline-block;
    width: 100%;
    line-height: 2;
}
@media(max-width: 960px){
    .group-contact .container{
        padding-left: 50px;
        padding-right: 50px;
    }
}
@media(max-width: 767px){
    .group-contact .about .txt{
        text-align: justify;
        text-justify: inter-ideograph;
        text-justify: inter-character;
    }
    .group-contact .core-plan .btn{
        width: 90%;
        height: 55px;
        margin: 20px auto;
    }
    .group-contact .core-plan .btn a h3{
        font-size: 1.6rem;
    }
    .group-contact .core-plan .txt {
        padding-top: 0;
    }
    .group-contact .core-plan .phone {
        margin-top: 20px;
    }
}
@media(max-width: 576px){
    .group-contact{
        padding-top: 11px;
        padding-bottom: 0;
    }
    .group-contact .container{
        padding-left: 20px;
        padding-right: 20px;
    }
    .group-contact .usage-fee{
        padding-bottom: 12px;
    }
    .group-contact .about .txt{
        font-size: 1.4rem;
    }
    .group-contact .usage-fee h2.title{
        margin: 15px 0 38px;
    }
    .group-contact .core-plan {
        padding: 20px 5px 30px 5px;
        margin-bottom: 70px;
    }
    .group-contact .core-plan .txt p{
        padding-bottom: 10px;
    }
    .group-contact .core-plan .txt p:last-child{
        padding-bottom: 0;
    }
    .group-contact .about{
        padding: 8px 15px 20px 15px;
        margin-bottom: 24px;
    }
    .group-contact .about h2.title{
        margin-bottom: 30px;
    }
}
@media(max-width: 374px){
    .group-contact .about h2.title{
        font-size: 1.4rem;
    }
    .group-contact .core-plan .txt,
    .group-contact .about .txt{
        font-size: 1.3rem;
    }
}
/*
==============================================================
======================= End group-contact ====================
==============================================================
*/