@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;
    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: #9A63FF;
}
.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(80, 0, 182, 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 #9A63FF;
    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: #9A63FF;
     }
    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{
    background: #D7D8D8;
    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: #5000B6;
}
@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: #5000B6;
    color: #fff;
}
.header-title:before{
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 50%;
    background: #6734E0;
    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{
    padding-top: 55%;
}
.banner ul{
    display: flex;
}
.banner li{
    overflow: hidden;
    position: relative;
    display: none;
}
.banner li img{
    display: flex;
}
.banner li .desc{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 45px;
    color: #fff;
    font-size: 2.5rem;
    font-weight: 700;
    text-align: center;
}
.banner li .desc .item{
    display: block;
}
.banner li .desc .item p{
    display: inline-block;
    text-align: center;
    padding: 0 15px;
    margin-bottom: 5px;
    background: #9A63FF;
}
.banner li .desc p span{
    padding-top: 2px;
    padding-bottom: 2px;
    display: inline-block;
}
.banner li .desc .item .lb{
    display: none;
}
.banner li .desc p span.hdn-pc{
    display: none;
}
@media(max-width: 768px){
    .banner li .desc{
        font-size: 2.2rem;
    }
}
@media(max-width: 767px){
    .banner li .desc .item p{
        display: inline-block;
        padding: 0;
        margin-bottom: 2px;
        background: none;
    }
    .banner li .desc .item .lb{
        display: block;
        padding: 0 !important;
        line-height: 0;
        background: none !important;
        margin: 0 !important;
    }
    .banner li .desc p span{
        background: #9A63FF;
        margin-bottom: 5px;
        padding: 2px 10px;
    }
    .banner li .desc p span.hdn-pc{
        padding: 0;
        background: none;
        margin: 0;
        display: inline-block;
    }
}
@media(max-width: 576px){
    .banner{
        padding-top: 115.2%;
    }
    .banner li .desc{
        font-size: 1.4rem;
        bottom: 10px;
    }
}
/*
==============================================================
========================== End banner ========================
==============================================================
*/
/*
==============================================================
============================ connect =========================
==============================================================
*/
.connect{
    padding-bottom: 64px;
}
.connect .container{
    max-width: 788px;
}
.connect ul{
    display: flex;
    flex-wrap: wrap;
    margin: 0 -13px;
}
.connect ul li{
    width: 50%;
    padding: 0 13px;
    margin-bottom: 26px;
    font-weight: 700;
}
.connect ul li .inner{
    display: block;
    width: 100%;
    height: 100%;
    border: 1px solid #e1e1e1;
    padding: 35px;
}
.connect ul li .icon,
.connect ul li .point,
.connect ul li h3{
    text-align: center;
}
.connect ul li .icon img{
    height: 64px;
}
.connect ul li .point{
    color: #9A63FF;
    font-size: 1.2rem;
    text-transform: uppercase;
    padding: 20px 0 5px;
}
.connect ul li h3{
    position: relative;
    margin-bottom: 40px;
}
.connect ul li h3:before{
    content: '';
    position: absolute;
    left: 50%;
    margin-left: -13px;
    bottom: -18px;
    height: 1px;
    width: 26px;
    background: #9A63FF;
}
@media(max-width: 576px){
    .connect{
        padding-bottom: 40px;
    }
    .connect .container{
        padding-left: 30px;
        padding-right: 30px;
    }
    .connect ul{
        margin: 0;
    }
    .connect ul li{
        width: 100%;
        padding: 0;
        font-size: 1.4rem;
    }
    .connect ul li .inner{
        padding-bottom: 28px;
    }
}
@media(max-width: 374px){
    .connect{
        padding-bottom: 40px;
    }
    .connect .container{
        padding-left: 20px;
        padding-right: 20px;
    }
    .connect ul li .inner{
        padding: 25px;
    }
}
/*
==============================================================
========================== End connect =======================
==============================================================
*/
/*
==============================================================
=========================== workvivo ========================
==============================================================
*/
.workvivo{
    background: #d7d8d8;
    padding-bottom: 105px;
}
.workvivo .container{
    max-width: 920px;
}
.workvivo .desc{
    display: inline-block;
    width: 100%;
    text-align: center;
    font-weight: 700;
    margin-bottom: 40px;
    line-height: 1.7;
}
.workvivo .desc .sp{
    display: none;
}
.workvivo ul{
    display: flex;
    flex-wrap: wrap;
    margin: 0 -8px;
}
.workvivo ul li{
    width: 33.33%;
    padding: 0 8px;
    margin-bottom: 16px;
    text-align: center;
    font-size: 1.2rem;
    font-weight: 700;
}
.workvivo ul li .inner{
    display: block;
    width: 100%;
    height: 100%;
    background: #fff;
    padding: 30px 20px;
}
.workvivo ul li .icon img{
    height: 64px;
}
.workvivo ul li:nth-child(1) .icon img{
    padding: 5px 0;
}
.workvivo ul li:nth-child(3) .icon img{
    padding: 10px 0;
}
.workvivo ul li h3{
    font-size: 1.7rem;
    padding: 20px 0 7px;
}
.workvivo ul li .text{
    min-height: 110px;
    text-align: justify;
    text-justify: inter-ideograph;
    text-justify: inter-character;
    line-height: 1.7;
}
.workvivo ul li .img{
    margin-top: 20px;
}
.workvivo ul li .img img{
    width: 100%;
    display: flex;
}
@media(max-width: 767px){
    .workvivo .container{
        padding-left: 30px;
        padding-right: 30px;
    }
    .workvivo ul li{
        width: 50%;
    }
}
@media(max-width: 576px){
    .workvivo{
        padding-bottom: 66px;
    }
    .workvivo .container{
        padding-left: 30px;
        padding-right: 30px;
    }
    .workvivo .desc{
        text-align: left;
    }
    .workvivo .desc .pc{
        display: none;
    }
    .workvivo .desc .sp{
        display: block;
    }
    .workvivo ul li .inner{
        padding: 30px 35px;
    }
    .workvivo ul li .text {
        min-height: auto;
    }
    .workvivo ul{
        margin: 0;
    }
    .workvivo ul li{
        width: 100%;
        padding: 0;
        margin-bottom: 30px;
    }
    .workvivo ul li:last-child{
        margin-bottom: 0;
    }
}
@media(max-width: 374px){
    .workvivo .container{
        padding-left: 20px;
        padding-right: 20px;
    }
    .workvivo ul li .inner{
        padding: 30px 25px;
    }
    .workvivo .desc{
        font-size: 1.4rem;
    }
}
/*
==============================================================
========================= End workvivo ======================
==============================================================
*/
/*
==============================================================
============================ example ========================
==============================================================
*/
.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: #9A63FF;
}
.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: #9A63FF;
    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;
    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: #9A63FF;
}
.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 ======================
==============================================================
*/
/*
==============================================================
============================ use-plan ========================
==============================================================
*/
.use-plan{
    padding-bottom: 25px;
}
.use-plan .content-box{
    display: flex;
    flex-wrap: wrap;
}
.use-plan .content-box .left{
    width: 67%;
    padding-right: 45px;
}
.use-plan .content-box .right{
    width: 33%;
}
.use-plan .group-title{
    display: inline-block;
    width: 100%;
    text-align: center;
    border-bottom: 1px solid #e1e1e1;
    padding-bottom: 10px;
    margin-bottom: 30px;
}
.use-plan .group-title h2{
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 7px;
}
.use-plan .items{
    display: inline-block;
    width: 100%;
    position: relative;
    padding-bottom: 20px;
    margin-bottom: 30px;
    font-size: 1.2rem;
}
.use-plan .items:before{
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 20px;
    background: #e1e1e1;
}
.use-plan .items .head,
.use-plan .items ul li{
    display: flex;
}
.use-plan .items .head,
.use-plan .items ul{
    padding-left: 40px;
    padding-right: 40px;
}
.use-plan .items ul:first-child {
    padding-right: 20px;
}
.use-plan .items ul:last-child {
    padding-left: 20px;
}
.use-plan .items .head {
    background: #e1e1e1;
    padding-top: 20px;
    padding-bottom: 14px;
}
.use-plan .items .content{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.use-plan .items .content .col {
    padding-left: 30px;
}
.use-plan .items .content .col:before{
    content: '';
    position: absolute;
    left: 5px;
    top: 14px;
    height: 12px;
    width: 15px;
    background: url('../img/ic-check.svg') no-repeat;
}
.use-plan .items ul{
    width: 50%;
    background: #f8f6f5;
}
.use-plan .items ul.ul-all {
    width: 100%;
    padding-left: 40px;
    padding-right: 40px;
}
.use-plan .items .col{
    position: relative;
    flex: 1;
    padding: 10px 0;
    border-bottom: 1px solid #e1e1e1;
}
.use-plan .items li:last-child .col{
    border-bottom: none;
}
.use-plan .items h3{
    font-size: 1.7rem;
    font-weight: 700;
    margin-bottom: 7px;
}
.use-plan .items .note{
    font-size: 1.2rem;
}
.use-plan .items ul li{
    gap: 50px;
    align-items: center;
}
.use-plan .items ul li .rd{
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid #000;
}
.use-plan .right ul{
    text-align: center;
    margin-bottom: 30px;
}
.use-plan .right ul li{
    padding: 30px 10px;
    border: 1px solid #e1e1e1;
    margin-bottom: 15px;
    font-size: 1.2rem;
    font-weight: 700;
}
.use-plan .right ul li:last-child{
    margin-bottom: 0;
}
.use-plan .right ul li .icon img{
    width: 74px;
}
.use-plan .right ul li:nth-child(2) .icon img{
    width: 62px;
}
.use-plan .right ul li:nth-child(3) .icon img{
    width: 44px;
}
.use-plan .right ul li h3{
    font-size: 1.7rem;
    padding: 15px 0 6px;
}
@media(max-width: 960px){
    .use-plan .content-box .left{
        width: 65%;
        padding-right: 25px;
    }
    .use-plan .content-box .right{
        width: 35%;
    }
    .use-plan .items .head,
    .use-plan .items ul{
        padding-left: 25px;
        padding-right: 15px;
    }
}
@media(max-width: 767px){
    .use-plan .container{
        max-width: 620px;
    }
    .use-plan .content-box .left,
    .use-plan .content-box .right{
        width: 100%;
    }
    .use-plan .content-box .left{
        padding-right: 0;
        flex: auto;
    }
}
@media(max-width: 576px){
    .use-plan{
        padding-bottom: 32px;
    }
    .use-plan .container{
        padding-left: 0;
        padding-right: 0;
    }
    .use-plan .group-title{
        padding-bottom: 30px;
        margin-bottom: 20px;
    }
    .use-plan .items .head{
        padding-left: 15px;
        padding-right: 15px;
    }
    .use-plan .items .head .col:first-child{
        padding-right: 0;
        flex: auto;
        text-align: center;
    }
    .use-plan .items .content{
        flex-direction: column;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
    }
    .use-plan .items ul{
        width: 100%;
        padding-left: 30px;
        padding-right: 30px;
    }
    .use-plan .items ul:first-child{
        padding-right: 30px;
    }
    .use-plan .items ul:last-child{
        padding-left: 30px;
    }
    .use-plan .items ul .col:last-child{
        width: 50px;
        min-width: 50px;
        padding-left: 30px;
    }
    .use-plan .items.no-right-txt ul li .col:last-child{
        text-align: right;
        padding-left: 0px !important;
        padding-right: 12px;
    }
    .use-plan .items .col:first-child{
        padding-right: 5px;
    }
    .use-plan .right ul{
        padding: 0 30px;
    }
}
/*
==============================================================
========================== End use-plan ======================
==============================================================
*/
/*
==============================================================
========================== group-contact =====================
==============================================================
*/
.group-contact {
    background: #d7d8d8;
    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: #9A63FF;
    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;
    }
}
@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 ====================
==============================================================
*/