@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#gHeader .logo {
    max-width: 87px;
    width: 6.9%;
}
.comBoxInner {
    padding: 0 20px;
}
.mainVisual {
    padding: 136px 0 52px;
    position: relative;
    z-index: 1;
    box-sizing: border-box;
    background: url('../img/index/main_bg.jpg') no-repeat center center/ cover;
}
.mainVisual .txtBox {
    width: 64%;
}
.mainVisual h1 {
    margin-bottom: 59px;
    font-size: 3.6rem;
    font-weight: normal;
    line-height: 1.3;
}
.mainVisual h1 .speechbubble {
    display: inline-block;
    padding: 31px 35px;
}.mainVisual h1 .speechbubble:nth-of-type(1) {
    color: #2175d9;
    background-color: #fff;
    border-radius: 15px 15px 0 15px;
    margin: 0 0 14px 93px;
}
.mainVisual h1 .speechbubble:nth-of-type(2) {
    color: #fff;
    background-color: #2175d9;
    border-radius: 0 15px 15px 15px;
    margin-left: 24.2%;
    padding: 29px 31px;
}
.mainVisual h1 .speechbubble .text_kerning_01 {
    letter-spacing: -1rem;
}
.mainVisual h1 .speechbubble .text_kerning_02 {
    letter-spacing: 0rem;
}
.listContainer {
    background-color: #0f1a40;
}
.listContainer .comBox {
    width: 91%;
    max-width: 1303px;
}
.listContainer .listUl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.listContainer .listUl li {
    color: #fff;
    font-size: 1.6rem;
    font-weight: 400;
    text-align: left;
    box-sizing: border-box;
    margin: 40px 6px 47px 0;
    padding: 12px 5px 7px 89px;
    border-radius: 10px;
    position: relative;
    max-width: 16%;
    width: 204px;
    white-space: nowrap;
}
.listContainer .listUl li::before {
    content: '';
    position:absolute;
    width: 72px;
    height: 67px;
    top: 0;
    left: 0;
    z-index: 1;
    border-radius: 10px 0 0 10px;
}
.listContainer .listUl .yellow {
    background-color: #ffb511;
    color: #0f1941;
}
.listContainer .listUl .yellow::before {
    background: url('../img/index/t_img01.png');
    background-size: cover;
    background-color: #fff;
}
.listContainer .listUl .green {
    background-color: #6ba5b4;
}
.listContainer .listUl .green::before {
    background: url('../img/index/t_img02.png');
    background-size: cover;
    background-color: #fff;
}
.listContainer .listUl .red {
    background-color: #e74536;
}
.listContainer .listUl .red::before {
    background: url('../img/index/t_img03.png');
    background-size: cover;
    background-color: #fff;
}
.listContainer .listUl .white {
    background-color: #f7f4f0;
    color: #0f1941;
}
.listContainer .listUl .white::before {
    background: url('../img/index/t_img04.png');
    background-size: cover;
    background-color: #fff;
}
.listContainer .listUl .blue {
    background-color: #2175d9;
    color: #fff;
}
.listContainer .listUl .blue::before {
    background: url('../img/index/t_img06.png');
    background-size: cover;
    background-color: #fff;
}
.listContainer .listUl .yellow:last-of-type {
    margin: 40px 0 47px 0;
}
.listContainer .listUl .yellow:last-of-type::before {
    background: url('../img/index/t_img07.png');
    background-size: cover;
    background-color: #fff;
}
.mainVisual + .bBox {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 45px 10px 28px;
    width: 100%;
    font-size: 2.5rem;
    box-sizing: border-box;
    color: #fff;
    background-color: #2175d9;
}
.mainVisual + .bBox .comBtn {
    max-width: 310px;
}
.mainVisual + .bBox .comBtn {
    margin: 0 1%;
}
.mainVisual + .bBox .comBtn a {
    padding: 14px 5px 15px;
    font-size: 2.2rem;
}
.mainVisual + .bBox .comBtn a:hover {
    opacity: 0.7;
}
/* cv */
.cv {
    background-color: #2175d9;
    color: #fff;
    text-align: center;
}
.cv .comBoxInner {
    max-width: 994px;
    width: 100%;
    display: inline-block;
    text-align: left;
}
.cv .comTxt {
    font-size: 3.6rem;
    font-weight: 400;
    padding: 48px 0 20px;
    letter-spacing: 0;
}
.cv .comBtn {
    width: 100%;
}
.cv .comTxtSmall {
    padding-top: 18px;
    margin-bottom: 28.5px;
    padding-left:1em;
    font-size: 2.4rem;
	text-indent:-1em;
    font-weight: 300;
}
.cv .comLInk a {
    font-size: 1.6rem;
    color: #fff;
    padding-bottom: 4px;
    margin-bottom: 90px;
    border-bottom: solid 1px #fff;
    display: inline-block;
    cursor: pointer;
    position: relative;
}
.cv.cvBgNone {
    background-color: #fff;
    color: #0f1941;
    text-align: center;
}
.cv.cvBgBeige {
    background-color: #f7f4f0;
    color: #0f1941;
    text-align: center;
}
.cv.cvBgNone .comTxt {
    padding-top: 0;
}
.cv.cvBgNone .comTxtSmall {
    margin-bottom: 0;
}
.toggleBox {
    text-align: left;
    width: 100%;
    font-size: 1.6rem;
    box-sizing: border-box;
    color: #fff;
    background-color: #2175d9;
    padding-bottom: 30px;
}
.toggleSwitch {
    padding-bottom: 4px;
    border-bottom: solid 1px #fff;
    display: inline-block;
    cursor: pointer;
    position: relative
}
.toggleSwitch::after {
    content: '＞';
    position: absolute;
    top: 11px;
    right: -10px;
    width: 10px;
    height: 10px;
    transform: rotate(-90deg);
    font-size: 1.5rem;
}
.toggleSwitch.toggleUp::after {
    content: '＞';
    top: 6px;
    right: -23px;
    transform: rotate(90deg);
}
.toggleContents {
    padding: 10px 0;
    display: none;
}
/* /cv */
#main .support {
    background: #fff;
    padding: 75px 0 110px;
}
#main .support .headLine01 {
    margin-bottom: 29px;
    font-size: 4.6rem;
}
#main .support .comBox {
    width: 55.5%;
}
#main .support .supportDisc {
    font-size: 2.6rem;
    padding-top: 58px;
}
#main .support .supportDisc .red {
    color: #e74536;
}
/* slider */
#main .support .slideItems {
    width: 100%;
    height: 100%;
}
#main .support .slideItems img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.slide-arrow {
    bottom: 0;
    cursor: pointer;
    margin: auto;
    position: absolute;
    top: 0;
    width: 60px;
    z-index: 1;
    object-fit: contain;
}
#main .support .slideItems img.slide-arrow {
    bottom: 0;
    cursor: pointer;
    margin: auto;
    position: absolute;
    top: 0;
    width: 60px;
    z-index: 1;
    object-fit: contain;
}
.prev-arrow {
    left: -24px;
}
.next-arrow {
    right: -19px;
}
#main .support .slick-dots {
    width: 100%;
    bottom: -45px;
}
.slick-dots li button:before {
    opacity: 1;
}
#main .support .slick-dots li button:before {
    color: #ffe1a0;
    font-size: 13px;
    top: 6px;
}
#main .support .slick-dots li.slick-active button:before {
    color: #ffb512;
}
#main .support .slick-dots li.slick-active button:before {
    font-size: 20px;
}
/* /slider */

/* case */
#main .case .slick-list {
    overflow: visible;
}
#main .case {
    background-color: #f7f4f0;
    padding: 90px 0;
}
#main .caseSliderItem {
    width: auto;
    height: auto !important;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    border-radius: 30px;
    overflow: hidden;
}
#main .caseSliderItem .item {
    width: 950px;
    height: 100%;
    background-color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border-radius: 30px;
    overflow: hidden;
}
#main .caseSliderItem .itemInfo {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%;
    text-align: left;
    padding: 40px 36px;
}
#main .caseSliderItem .itemInfo .catch {
    font-size: 2.3rem;
    text-align: left;
    font-weight: 400;
    color: #0f1a40;
}
#main .caseSliderItem .itemInfo .place {
    padding: 20px 0 8px;
    float: left;
}
#main .caseSliderItem .itemInfo .place span {
    background-color: #ffb511;
    border-radius: 13.020833333333334vw;
    padding: 5px 25px;
    font-size: 1.8rem;
    font-weight: 500;
}
#main .caseSliderItem .itemInfo .title {
    font-size: 2.6rem;
    text-align: left;
    font-weight: 400;
    margin-bottom: 2.083333333333333vw;
    clear: both;
}
#main .caseSliderItem .itemInfo .wage {
    font-size: 2.6rem;
    text-align: left;
    font-weight: 400;
}
#main .caseSliderItem .itemInfo .cat {
    font-weight: bold;
}
#main .caseSliderItem .itemInfo .wage .num {
    padding-left: 0.78125vw;
    font-size: 4.8rem;
    color: #e74536;
    vertical-align: -0.26041666666666663vw;
    line-height: 1;
}
#main .caseSliderItem .itemInfo .wage .yen {
    color: #e74536;
}
#main .caseSliderItem .itemInfo .tagList {
    display: flex;
    justify-content: space-between;
    padding: 20px 0 0;
}
#main .caseSliderItem .itemInfo .tag-item {
    min-width: 225px;
    height: 47px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: #f7f5f0;
    border-radius: 13.020833333333334vw;
    font-size: 1.5rem;
}
#main .caseSliderItem .itemInfo .tag-item::before {
    content: '';
    width: 30px;
    height: 28px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
    margin: 0 12px 0 -8px;
}
#main .caseSliderItem .item__img-wrap {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 389px;
    flex: 0 0 389px;
}
#main .caseSliderItem .item__img-wrap img {
    width: 100%;
}
#main .caseSliderItem .itemInfo .tag-item--heart:before {
    background-image: url(../img/index/icon_heart.svg);
}
#main .caseSliderItem .itemInfo .tag-item--circle:before {
    background-image: url(../img/index/icon_circle.svg);
}
#main .caseSliderItem .itemInfo .tag-item--support:before {
    background-image: url(../img/index/icon_support.svg);
}
#main .caseSliderItem .itemInfo .tag-item--human:before {
    background-image: url(../img/index/icon_human.svg);
}
#main .caseSliderItem .itemInfo .tag-item--time:before {
    background-image: url(../img/index/icon_time.svg);
}
#main .caseSliderItem .itemInfo .tag-item--voice:before {
    background-image: url(../img/index/icon_voice.svg);
}
#main .caseSliderItem .itemInfo .tag-item--calendar:before {
    background-image: url(../img/index/icon_calendar.svg);
}
#main .caseSliderItem .itemInfo .tag-item--office:before {
    background-image: url(../img/index/icon_office.svg);
}
#main .caseSliderItem .itemInfo .tag-item--work:before {
    background-image: url(../img/index/icon_work.svg);
}
#main .caseSlide .next-arrow {
    right: 50px;
}
#main .caseSlide .prev-arrow {
    left: 45px;
}
#main .caseSlide .slick-dots {
    width: 100%;
    bottom: -45px;
}
.slick-dots li button:before {
    opacity: 1;
}
#main .caseSlide .slick-dots li button:before {
    color: #ffe1a0;
    font-size: 13px;
    top: 6px;
}
#main .caseSlide .slick-dots li.slick-active button:before {
    color: #ffb512;
}
#main .caseSlide .slick-dots li.slick-active button:before {
    font-size: 20px;
}


/* search */
#main .search {
    background-color: #2175d9;
    padding: 90px 0;
    color: #fff;
}
#main .search .comBox {
    width: 67%;
}
#main .search .headLine01 {
    margin-bottom: 29px;
    font-size: 4.6rem;
}
#main .search .comCenterTxt {
    margin-bottom: 50px;
    font-size: 1.6rem;
}
#main .search .comCenterTxt a {
    padding-bottom: 4px;
    border-bottom: solid 1px #fff;
    color: #fff;
}
#main .search .comCenterTxt a:hover {
    opacity: 0.7;
}
#main .search .listUl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin: 25px auto 30px;
}
#main .search .listUl li {
    margin: 10px;
    width: 47%;
}
#main .search .listUl li a {
    background: #ffb512;
    color: #0f1a40;
    display: block;
    width: 100%;
    font-size: 2.5rem;
    text-align: center;
    padding: 18px 0;
    border-radius: 7.5px;
}
#main .search .listUl li a:hover {
    opacity: 0.7;
}

#main .work {
    background-color: #2175d9;
    padding: 112px 0 150px;
}
#main .work .cv .comBoxInner {
    max-width: 904px;
    display: inline-block;
    text-align: left;
}
#main .work .headLine01 {
    margin-bottom: 31px;
    color: #fff;
}
#main .work .headLine01 span {
    color: #ffb511;
}
#main .work .comBox {
    width: 70%;
}
#main .work .comCenterTxt {
    margin-bottom: 100px;
    color: #fff;
}
#main .work .imgUl {
    margin-top: -20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#main .work .imgUl li {
    margin: 20px 4.5% 0 0;
    text-align: center;
    width: 16%;
}
#main .work .imgUl li:nth-of-type(5n) {
    margin-right: 0;
}
#main .work .imgUl li img {
    width: 77%;
    margin: 13px auto 20px;
}
#main .work .imgUl li:nth-of-type(4) img {
    margin: 20px auto 20px;
    width: 90%;
}
#main .work .imgUl li div {
    margin: 0 auto 14px;
    height: 150px;
    width: 150px;
    border-radius: 50%;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}
#main .work .imgUl li span {
    font-size: 2.6rem;
    font-weight: 400;
    text-align: left;
    line-height: 1.3;
    letter-spacing: -1px;
    margin-top: 5px;
    color: #fff;
}
#main .work .imgUl li span, #main .work .imgUl li img {
    display: inline-block;
}
#main .work .cv.cvBgBeige {
    background-color: #2175d9;
}
#main .work .cv.cvBgBeige p {
    color: #fff;
}
#main .work .comBtn {
    transition: all 0.3s;
}
#main .work .comBtn:hover {
    opacity: .7;
}

#main .register {
    background-color: #f7f4f0;
    padding: 112px 0 167px;
}
#main .register .comBox {
    width: 70%;
}
#main .register .headLine01 {
    margin-bottom: 36px;
}
#main .register .comCenterTxt {
    margin-bottom: 84px;
    letter-spacing: 2px;
}
#main .register .imgUl {
    margin-top: -20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#main .register .imgUl li {
    margin: 20px 0 0;
    text-align: center;
    width: 31%;
}
#main .register .imgUl li:nth-of-type(3n-1) {
    margin: 20px 1.3% 0;
}
#main .register .imgUl li .img {
    margin: 0 auto 14px;
    height: 150px;
    width: 150px;
    border-radius: 50%;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
}
#main .register .imgUl li h3 {
    margin-bottom: 5px;
    font-size: 2.6rem;
    font-weight: 400;
    line-height: 1.3;
}
#main .register .imgUl li p {
    letter-spacing: 1px;
    font-size: 2rem;
}
#main .register .comBtnBox .comBtn {
    width: 100%;
    max-width: 904px;
}
#main .inhouse .headLine01 .size {
    font-size: 2.6rem;
    color: #0f1941;
}
#main .inhouse .imgUl {
    position: relative;
    margin: 0 6px 90px;
}
#main .inhouse .imgUl:after {
    content: "";
    position: absolute;
    bottom: -80px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    border: 21px solid transparent;
    border-top: 23px solid #2175d9;
}
#main .inhouse .imgUl + .text {
    text-align: center;
}
#main .inhouse .imgUl + .text p {
    display: inline-block;
    font-size: 2.6rem;
    font-weight: 400;
    text-align: left;
    margin-bottom: 70px;
}
#main .flow {
    padding: 60px 0 148px;
}
#main .flow .bBox {
    display: inline-block;
    text-align: left;
    width: 75.3%;
}
#main .flow .headLine01 {
    margin-bottom: 54px;
}
#main .flow .stepUl {
    margin: -20px 0 101px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
#main .flow .stepUl li {
    margin: 20px 3.2% 0 0;
    width: 16.15%;
}
#main .flow .stepUl li:nth-of-type(5n) {
    margin-right: 0;
}
#main .flow .stepUl li .ttl {
    font-size: 1.3rem;
}
#main .flow .stepUl li h3 {
    margin-bottom: 15px;
    text-align: left;
    font-size: 1.8rem;
    font-weight: 400;
}
#main .flow .stepUl li h3 .center {
    display: inline-block;
    text-align: left;
    margin-bottom: 5px;
}
#main .flow .stepUl li .img {
    margin-bottom: 11px;
}
#main .flow .stepUl li p {
    font-size: 1.3rem;
    text-align: left;
    margin-top: 7px;
}
#main .flow .note {
    margin-bottom: 70px;
    text-align: center;
    font-size: 1.3rem;
}
#main .flow .note span {
    display: inline-block;
    margin: 0 1%;
}
#main .faq {
    padding: 110px 0 136px;
    background-color: #f7f4f0;
}
#main .faq .comBox {
    width: 66%;
}
#main .faq .headLine01 {
    margin-bottom: 80px;
    font-size: 5.2rem;
}
#main .faq .faqDl {
    box-sizing: border-box;
    background-color: #fff;
}
#main .faq .faqDl dt {
    margin-bottom: 25px;
    padding: 0 6% 0 5%;
    min-height: 110px;
    display: flex;
    align-items: center;
    color: #fff;
    font-size: 2.8rem;
    cursor: pointer;
    border-radius: 15px 15px 0 0;
    background: #2175d9 url("../img/index/icon03.png") no-repeat center right 4%;
}
#main .faq .faqDl dt:after {
    content: '';
    min-height: inherit;
    font-size: 0;
}
#main .faq .faqDl .on {
    background-image: url("../img/index/icon02.png");
}
#main .faq .faqDl dd {
    display: none;
    padding: 0 5% 38px 4.2%;
    font-size: 2rem;
    line-height: 1.8;
}
#main .faq .faqDl .red {
    color: #e74536;
}
#main .information h4 {
    color: #fff;
    font-weight: 400;
    font-size: 1.4rem;
    /* text-decoration: underline; */
}
#main .information {
    background-color: #2175d9;
    padding: 40px 20px;
    color: #fff;
}
#main .information h2 {
    margin-bottom: 27px;
    text-align: left;
    font-size: 3.8rem;
    font-weight: 400;
}
#main .information .text {
    margin-bottom: 32px;
    text-align: left;
    font-size: 2rem;
}
#main .information h3 {
    margin-bottom: 13px;
    padding: 5px 0;
    font-size: 2.5rem;
    text-align: center;
    color: #2175d9;
    border-radius: 26px;
    background-color: #fff;
}
#main .information h3:not(:first-of-type) {
    margin-top: 30px;
}
#main .information h4 {
    margin-bottom: 5px;
    /* padding-left: 14px; */
    display: inline-block;
    font-size: 2.3rem;
    /* background: url("../img/index/arrow02.png") no-repeat center left 2px;
    background-size: 8px auto; */
}
.fix-cta {
    width: 140px;
    height: 167px;
    position: fixed;
    bottom: 100px;
    right: 0;
    z-index: 1000;
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    -webkit-transition: -webkit-transform .5s ease;
    transition: -webkit-transform .5s ease;
    -o-transition: transform .5s ease;
    transition: transform .5s ease;
    transition: transform .5s ease, -webkit-transform .5s ease;
    will-change: transform;
    border-radius: 40px 0 0 40px;
}
.fix-cta.fix {
    -webkit-transform: translateX(0);
            transform: translateX(0);
}
.fix-cta .cta__btn {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0;
    font-size: 2.2rem;
    line-height: 1.6;
    font-weight: 400;
    letter-spacing: .05em;
    text-align: center;
    color: #fff;
    padding-bottom: 36px;
    background-color: #ffb511;
    border-radius: 40px 0 0 40px;
    border-bottom: 7px solid #d19715;
}
    .fix-cta .cta__btn:before {
    content: "";
    width: 27px;
    height: 27px;
    bottom: 13px;
    right: 0;
    left: 0;
    margin: auto;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    }
    .fix-cta .cta__btn:after {
    content: "";
    width: 6px;
    height: 6px;
    border-top: solid 3px #ffb511;
    border-right: solid 3px #ffb511;
    border-width: 2px;
    right: 0;
    left: 0;
    bottom: 19px;
    margin: auto;
    -webkit-transform: translate(-1px, -50%) rotateZ(45deg);
            transform: translate(-1px, -50%) rotateZ(45deg);
    position: absolute;
    }
    .fix-cta .pcOnly {
        display: block;
    }
#main .information .txt {
    font-size: 1.8rem;
}
#main .information .tel {
    font-size: 1.8rem;
    text-indent: 3em;
}
#main .information .telInhouse {
    margin-bottom: 30px;
    text-indent: 0;
}
#main .information .tel a {
    color: #fff;
}

#main .company {
    padding: 56px 0 46px;
    background-color: #878ca0;
    color: #fff;
}
#main .company h2 {
    margin-bottom: 48px;
    font-size: 3rem;
    font-weight: normal;
    text-align: center;
}
#main .company table {
    margin-left: 14.7%;
    width: 72.72%;
    color: #fff;
}
#main .company table th {
    width: 17.04%;
    text-align: left;
    vertical-align: top;
}
#main .company table td, #main .company table th {
    padding: 0 0 28px 0;
    font-size: 1.8rem;
}
#main .company table td a {
    color: #FFFFFF;
}
#main .company table td a:hover {
    opacity: .7;
}
@media all and (min-width: 768px) and (max-width: 1355px) {
    .mainVisual h2 {
        font-size: 3rem;
    }
    .mainVisual h2 span {
        font-size: 2.4rem;
    }
    .headLine01 {
        font-size: 3.8rem;
    }
    .comBtnBox .comBtn a {
        font-size: 1.7rem;
    }
    .listContainer .listUl li {
        width: 310px;
        max-width: 28%;
    }
    #main .search .comBox {
        width: 72%;
    }
    #main .work .comCenterTxt {
        font-size: 2.1rem;
    }
    #main .work .imgUl li span {
        font-size: 1.9rem;
    }
    #main .work .comBtn {
        width: 100%;
        font-size: 2.2rem;
    }
    #main .register .imgUl li p {
        font-size: 1.5rem;
    }
    #main .faq .faqDl dt {
        font-size: 2.4rem;
    }
    .mainVisual + .bBox .comBtn {
        width: 100%;
    }
    #gHeader h1 {
        margin-top: 0;
    }
    #main .company table td, #main .company table th {
        font-size: 1.4rem;
    }
    .mainVisual + .bBox .comBtn a {
        padding-top: 11px;
    }
    #main .faq .faqDl dd {
        font-size: 1.6rem;
    }
}
@media all and (max-width: 1100px) {
    .mainVisual .txtBox {
        width: 85%;
    }
}
@media all and (min-width: 768px) and (max-width: 1000px) {
    .comBtnBox .comBtn {
        width: 100% !important;
    }
    .mainVisual .listUl li {
        font-size: 2.3rem;
        width: 47%;
    }
    .campaignBox {
        font-size: 2.3rem;
    }
    #main .search .listUl li {
        width: 46%;
    }
    #main .search .listUl li a {
        font-size: 1.8rem;
    }
    #main .work .comCenterTxt {
        font-size: 1.6rem;
    }
    #main .work .imgUl li span {
        font-size: 1.5rem;
    }
    #main .register .comCenterTxt {
        font-size: 1.9rem;
    }
    #main .register .imgUl li h3 {
        font-size: 2.2rem;
    }
    #main .register .imgUl li p {
        font-size: 1.1rem;
    }
    #main .flow .note {
        font-size: 1.2rem;
    }
    #main .faq .faqDl dt {
        font-size: 1.8rem;
    }
}
@media all and (max-width: 767px) {
    /*--------------------------
	ヘッダー
    ----------------------------*/
    #gHeader {
        padding-top: 18px;
    }
    #gHeader .logo {
        max-width: 108px;
        width: 16.1%;
    }
    .comBtn a {
        line-height: 1.4;
        font-weight: 400;
    }
    .mainVisual {
        padding: 80px 0 0;
        min-height: auto;
        background-image: url("../img/index/sp_main_bg.jpg");
    }
    /*--------------------------
	mainVisual
    ----------------------------*/
    .mainVisual {
        padding: 98px 0 38px;
        min-height: auto;
        background: url(../img/index/sp_main_bg.jpg) no-repeat center center/ cover;
    }
    .mainVisual .sp {
        display: block;
        content: "";
        margin: -1px;
    }
    .mainVisual .txtBox {
        width: 100%;
    }
    .mainVisual h1 {
        margin-bottom: 0;
        font-size: 1.7rem;
        line-height: 1.3;
        letter-spacing: -0.01em;
    }
    .mainVisual h1 .speechbubble {
        padding: 14px;
    }
    .mainVisual h1 .speechbubble:nth-of-type(1) {
        border-radius: 7.5px 7.5px 0 7.5px;
        margin: 12px 0 6px -2px;
    }
    .mainVisual h1 .speechbubble:nth-of-type(2) {
        margin-left: 12.5%;
        border-radius: 0 7.5px 7.5px 7.5px;
        padding: 15px 16px;
    }
    .mainVisual h1 .speechbubble .text_kerning_01 {
        letter-spacing: -0.3rem;
    }
    .mainVisual h1 .speechbubble .text_kerning_02 {
        letter-spacing: 0;
    }
    .listContainer {
        padding: 6px 0 11px;
    }
    .listContainer .listUl {
        margin-bottom: 9px;
        width: 100%;
    }
    .listContainer .listUl li {
        padding: 5px 3% 5px 15.5%;
        margin: 12px 6px 0 0;
        font-size: 1.4rem;
        font-feature-settings: 'palt';
        width: 47%;
        max-width: none;
        border-radius: 5px;
        line-height: 1;
    }
    .listContainer .listUl li::before {
        width: 38px;
        height: 38px;
        top: 0;
        left: 0;
        border-radius: 5px 0 0 5px;
    }
    .listContainer .listUl li:nth-of-type(even) {
        margin: 12px 0 0 0;
    }
    .listContainer .listUl .yellow:last-of-type {
        margin: 12px 0 0 0;
    }
    .mainVisual + .bBox {
        text-align: center;
        padding: 30px 10px 15px;
        display: block;
        box-sizing: border-box;
    }
    .mainVisual + .bBox .comBtn {
        width: 67%;
        margin: 0 auto;
    }
    .mainVisual + .bBox .comBtn a {
        padding: 3px 5px 4px;
        line-height: 1.4;
        font-weight: 400;
    }
    .cv .comBoxInner {
        width: 100%;
    }
    .cv .comTxt {
        font-size: 1.6rem;
        padding: 24px 0 10px;
    }
    .cv .comTxtSmall {
        font-size: 1.2rem;
        padding-top: 9px;
    }
    .cv .comLInk a {
        font-size: 1.4rem;
        margin-bottom: 45px;
    }
    .toggleBox {
        padding-bottom: 25px;
    }
    .toggleBox .toggleSwitch {
        font-size: 1.4rem;
    }
    .toggleBox .toggleSwitch::after {
        top: 8px;
        font-size: 1.2rem;
    }
    .toggleBox .toggleSwitch.toggleUp::after {
        right: -19px;
    }
    .toggleBox .toggleContents {
        font-size: 1.3rem;
        line-height: 1.7;
    }
    .toggleBox .comBox {
        text-align: left;
        margin: 0 23px;
    }
    #main .faq .headLine01 {
        font-weight: 400;
    }
    #main .support {
        padding: 50px 0 30px;
    }
    #main .support .supportDisc {
        font-size: 1.3rem;
    }
    /* slider */
    #main .support .slick-dots {
        bottom: -25px;
    }
    .slick-dots li {
        width: 10px;
        height: 10px;
    }
    .slick-dots li button {
        width: 10px;
        height: 10px;
    }
    #main .support .slick-dots li button:before {
        font-size: 6px;
    }
    #main .support .slick-dots li.slick-active button:before {
        font-size: 10px;
    }
    #main .support .slideItems img.slide-arrow {
        width: 32px;
        height: 31px;
    }
    #main .case {
        padding: 45px 0;
    }
    #main .case .comBoxInner {
        padding: 0;
    }
    #main .case .slick-list {
        overflow: hidden;
    }
    #main .caseSliderItem {
        overflow: hidden;
        height: auto !important;
    }
    #main .caseSliderItem {
        border-radius: 7.5px;
    }
    #main .caseSliderItem .item {
        width: 100%;
        height: 100% !important;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        background-color: #fff;
        height: 100%;
        border-radius: 7.5px;
        overflow: hidden;
    }
    #main .caseSliderItem .item__img-wrap {
        width: 100%;
        height: auto;
        flex: 0;
    }
    #main .caseSliderItem .itemInfo {
        -webkit-box-flex: 1;
        -ms-flex: 1 1 100%;
        flex: 1 1 100%;
        text-align: center;
        padding: 5.208333333333334vw 23px;
    }
    #main .caseSliderItem .itemInfo .tagList {
        display: block;
    }
    #main .caseSliderItem .itemInfo .catch {
        font-size: 1.6rem;
        padding-bottom: 0.78125vw;
    }
    #main .caseSliderItem .itemInfo .title {
        font-size: 1.9rem;
    }
    #main .caseSliderItem .itemInfo .wage {
        font-size: 1.8rem;
    }
    #main .caseSliderItem .itemInfo .wage .num {
        font-size: 3.3rem;
    }
    #main .caseSliderItem .itemInfo .place {
        padding: 4.166666666666666vw 0 1.0416666666666665vw;
        margin-bottom: 1.5625vw;
    }
    #main .caseSliderItem .itemInfo .place span {
        font-size: 1.3rem;
    }
    #main .caseSliderItem .itemInfo .tag-item {
        height: 32.5px;
    }
    #main .caseSliderItem .itemInfo .tag-item:before {
        content: '';
        width: 6.770833333333333vw;
        height: 5.46875vw;
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        position: relative;
        margin: 0 1.125vw 0 0;
    }
    #main .caseSliderItem .itemInfo .tag-item:not(:last-child) {
        margin-bottom: 2.604166666666667vw;
    }
    #main .caseSlide .slick-dots {
        bottom: -28px;
    }
    #main .caseSlide .slick-dots li button:before {
        font-size: 6px;
    }
    #main .caseSlide .slick-dots li.slick-active button:before {
        font-size: 13px;
    }
    #main .slide-arrow {
        top: -25px;
        width: 30px;
    }
    #main .caseSlide .prev-arrow {
        left: -16px;
    }
    #main .caseSlide .next-arrow {
        right: -14px;
    }
    #main .search {
        padding: 35px 0 20px;
    }
    #main .search .comCenterTxt {
        margin-bottom: 0;
        font-size: 1.3rem;
    }
    #main .search .listUl {
        justify-content: center;
    }
    #main .search .listUl li {
        margin: 5px;
        width: 43%;
    }
    #main .search .listUl li a {
        font-size: 1.8rem;
        padding: 14px  0;
    }
    #main .work {
        padding: 45px 0;
    }
    #main .work .cv .comBoxInner {
        width: 100%;
    }
    #main .work .headLine01 {
        margin-bottom: 22px;
    }
    #main .work .imgUl li div {
        margin: 0 10px 0 0;
        width: 91px;
        height: 91px;
    }
    #main .work .imgUl li div img {
        width: 74px;
    }
    #main .work .imgUl li span {
        font-size: 1.45rem;
        line-height: 1.4;
    }
    #main .work .comCenterTxt {
        margin-bottom: 28px;
    }
    #main .work .imgUl li img {
        margin: -5px 0 0 -5px;
    }
    #main .work .imgUl {
        margin-top: -38px;
    }
    #main .work .imgUl li {
        margin: 38px 15px 0 !important;
        width: 80px;
    }
    #main .work .imgUl li:nth-of-type(4){
        width: 105px;
    }
    #main .work .imgUl li:nth-of-type(4) img {
        margin: 5px auto 10px;
        width: 218px;
    }
    #main .work .comBtn {
        transition: all 0.3s;
    }
    #main .register {
        padding: 49px 0;
    }
    #main .register .headLine01 {
        margin-bottom: 24px;
    }
    #main .register .comCenterTxt {
        letter-spacing: 0;
        margin-bottom: 38px;
        font-weight: 300;
    }
    #main .register .imgUl {
        margin: 0 6px 0;
        display: block;
    }
    #main .register .imgUl li {
        margin: 0 0 26px 0 !important;
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: flex-start;
    }
    #main .register .imgUl li:last-of-type {
        margin-bottom: 0 !important;
    }
    #main .register .imgUl li .img {
        margin: 0 10px 0 0;
        width: 91px;
        height: 91px;
    }
    #main .register .imgUl li .img img {
        width: 62px;
    }
    #main .register .imgUl li .txtBox {
        text-align: left;
        width: calc(100% - 101px);
    }
    #main .register .imgUl li h3 {
        margin-bottom: 8px;
        letter-spacing: -0.3px;
        font-size: 1.6rem;
        font-weight: 500;
    }
    #main .register .imgUl li p {
        line-height: 1.35;
        font-size: 1.3rem;
        letter-spacing: -0.3px;
        font-weight: 300;
    }
    #main .register .imgUl li p .note {
        display: block;
        font-size: 1.2rem;
    }
    #main .inhouse .headLine01 .size {
        font-size: 1.4rem;
        color: #0f1941;
    }
    #main .inhouse .imgUl li {
        align-items: center;
    }
    #main .inhouse .comCenterTxt {
        margin-bottom: 19px;
    }
    #main .inhouse .imgUl {
        position: relative;
        margin: 0 6px 50px;
    }
    #main .inhouse .imgUl:after {
        content: "";
        position: absolute;
        bottom: -53px;
        left: 50%;
        transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
        border: 21px solid transparent;
        border-top: 23px solid #2175d9;
    }
    #main .inhouse .imgUl + .text p {
        font-size: 1.6rem;
        margin-bottom: 15px;
        padding: 0 20px;
    }
    #main .flow {
        padding: 37px 0 50px;
    }
    #main .flow .bBox {
        width: auto;
    }
    #main .flow .headLine01 {
        margin-bottom: 40px;
    }
    #main .flow .headLine01 .size {
        font-size: 1.4rem;
    }
    #main .flow .stepUl {
        max-width: 335px;
        margin: -28px auto 32px;
        justify-content: flex-start;
    }
    #main .flow .stepUl li {
        margin: 28px 12px 0 0;
        width: 30%;
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    #main .flow .stepUl li:nth-of-type(3) {
        margin-right: 0;
    }
    #main .flow .stepUl li:nth-of-type(1) img {
        width: 77%;
    }
    #main .flow .stepUl li:nth-of-type(2) img {
        width: 74%;
    }
    #main .flow .stepUl li:nth-of-type(5) img {
        width: 80%;
    }
    #main .flow .stepUl li::after {
        position: absolute;
        content: '';
        background: url("../img/index/arrow.png") no-repeat center right;
        height: 12px;
        width: 10px;
        top: 20%;
        right: -12%;
    }
    #main .flow .stepUl li:nth-of-type(2n)::after {
        right: -10%;
    }
    #main .flow .stepUl li:nth-of-type(3n)::after, #main .flow .stepUl li:last-of-type::after {
        display: none;
    }
    #main .flow .stepUl li:nth-of-type(4n)::after {
        top: 26%;
    }
    #main .flow .stepUl li h3 {
        margin-bottom: 5px;
        font-size: 1.4rem;
    }
    #main .flow .stepUl li .img {
        margin: 0;
        width: 59%;
        text-align: center;
    }
    #main .flow .stepUl li .ttl {
        font-size: 1.3rem;
        font-weight: 200;
    }
    #main .flow .note {
        text-align: center;
        font-weight: 300;
        font-size: 1.2rem;
        margin: 0 -6px 45px;
    }
    #main .flow .note span {
        display: block;
        text-align: left;
        text-indent: -13px;
        margin-left: 13px;
        padding: 0 10px;
    }
    #main .faq .headLine01 {
        margin-bottom: 29px;
    }
    #main .faq {
        padding: 34px 0 62px;
    }
    #main .faq .faqDl dt {
        margin-bottom: 12px;
        padding: 0 30px 0 20px;
        font-size: 1.4rem;
        min-height: 55px;
        background-size: 10px auto;
        background-position: center right 19px;
        border-radius: 7.5px 7.5px 0 0;
    }
    #main .faq .faqDl dt p {
        padding-left: 2em;
        text-indent: -2em;
        line-height: 1.35;
    }
    #main .faq .faqDl dd {
        padding: 0 15px 15px 18px;
        font-size: 1.25rem;
        line-height: 1.45;
        font-weight: 300;
    }
    #main .company {
        padding: 28px 0;
    }
    #main .company h2 {
        font-size: 2.3rem;
        font-weight: normal;
        margin-bottom: 24px;
    }
    #main .company table {
        margin-left: 0;
        width: auto;
    }
    #main .company table td, #main .company table th {
        padding-bottom: 20px;
        font-size: 1.4rem;
        float: left;
        width: 100%;
    }
    #main .company table th {
        padding-bottom: 10px;
    }
    #main .information {
        padding: 23px 0 30px;
    }
    #main .information h2 {
        margin-bottom: 27px;
        font-size: 2.3rem;
    }
    #main .information .text {
        margin-bottom: 32px;
        font-size: 1.6rem;
    }
    #main .information h3 {
        margin-bottom: 13px;
        padding: 2px 0 3px;
        font-size: 1.4rem;
        border-radius: 13px;
    }
    #main .information h3:not(:first-of-type) {
        margin-top: 30px;
    }
    #main .information h4 {
        margin-bottom: 5px;
        /* padding-left: 14px; */
        font-size: 1.4rem;
        /* background: url("../img/index/arrow02.png") no-repeat center left 2px;
        background-size: 8px auto; */
    }
    #main .information .txt {
        font-size: 1.4rem;
    }
    #main .information .tel {
        font-size: 1.4rem;
    }
    #main .information .telInhouse {
        margin-bottom: 23px;
    }
    #main .information .tel a {
        color: #fff;
    }
    .fix-cta {
        width: 100%;
        height: 15.625vw;
        background-color: #ffb511;
        position: fixed;
        bottom: 0;
        left: 0;
        z-index: 1000;
        -webkit-transform: translateY(100%);
        transform: translateY(100%);
        -webkit-transition: -webkit-transform .5s ease;
        transition: -webkit-transform .5s ease;
        -o-transition: transform .5s ease;
        transition: transform .5s ease;
        transition: transform .5s ease, -webkit-transform .5s ease;
        will-change: transform;
        border-radius: 0;
    }
    .fix-cta.fix {
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
    .fix-cta .cta__btn {
        width: 100%;
        height: 100%;
        border-radius: 0;
        font-size: 4.427083333333334vw;
        font-weight: 700;
        letter-spacing: .15em;
        color: #fff;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 0 3.125vw 0 0;
    }
    .fix-cta .cta__btn:before {
        content: '';
        width: 6.510416666666667vw;
        height: 6.510416666666667vw;
        right: 20px;
        left: auto;
        top: 63%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        background: #fff;
        border-radius: 50%;
        position: absolute;
    }
    .fix-cta .cta__btn:after {
        content: "";
        width: 1.5625vw;
        height: 1.5625vw;
        right: 30px;
        left: auto;
        border-top: solid 0.5208333333333333vw #ffb511;
        border-right: solid 0.5208333333333333vw #ffb511;
        top: 44%;
        -webkit-transform: translateY(-50%) rotateZ(45deg);
        transform: translateY(-50%) rotateZ(45deg);
        position: absolute;
    }
    .fix-cta .pcOnly {
        display: none;
    }
}
@media all and (max-width: 374px) {
    .comBtn {
        width: 270px !important;
    }
    .mainVisual .listUl li {
        font-size: 1rem;
        padding: 4px 3% 7px 13%;
    }
    .mainVisual .listUl li::before {
        width: 30px;
        height: 30px;
    }
    .mainVisual h2 {
        font-size: 2rem;
    }
    .campaignBox {
        font-size: 1.2rem;
    }
    .mainVisual .campaignBox::before {
        width: 43px;
        height: 36px;
    }
    #main .work .imgUl li {
        margin: 38px 5px 0 !important;
    }
    #main .flow .note {
        font-size: 1rem;
    }
    #main .flow .stepUl li h3 {
        font-size: 1.2rem;
    }
    #main .flow .stepUl li p {
        font-size: 1.1rem;
    }
    #main .faq .faqDl dt {
        font-size: 1.2rem;
    }
    #main .register .imgUl li .img {
        width: 70px;
        height: 70px;
    }
    #main .register .imgUl li .img img {
        width: 50px;
    }
    #main .register .imgUl li .txtBox {
        width: calc(100% - 80px);
    }
    #main .register .imgUl li h3 {
        font-size: 1.3rem;
    }
    #main .comCenterTxt {
        font-size: 1.1rem;
    }
    #main .headLine01 {
        font-size: 2rem !important;
    }
    #main .company table td, #main .company table th {
        font-size: 1.3rem;
    }
}