* {
    box-sizing:border-box;
    word-wrap:break-word;
    margin: 0px;
    padding: 0px;
}
/*設定*/
@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
body {
	font-family: 'Noto Sans Japanese', sans-serif;
}
.w100 {font-weight: 100;}
.w200 {font-weight: 200;}
.w300 {font-weight: 300;}
.w400 {font-weight: 400;}
.w500 {font-weight: 500;}
.w700 {font-weight: 700;}
.w900 {font-weight: 900;}

/*アニメーション*/
.appear1.appeartext {
    -webkit-animation:text_anime_on 0.8s ease-in-out forwards;
            animation:text_anime_on 0.8s ease-in-out forwards;
}
.appear2.appeartext {
    -webkit-animation:text_anime_on 0.8s 0.3s ease-in-out forwards;
            animation:text_anime_on 0.8s 0.3s ease-in-out forwards;
}
.appear3.appeartext {
    -webkit-animation:text_anime_on 0.8s 0.6s ease-in-out forwards;
            animation:text_anime_on 0.8s 0.6s ease-in-out forwards;
}
@-webkit-keyframes text_anime_on {
    0% {
        transform:translate3d(0,100%,0) skewY(12deg);
    }
    100% {
        transform:translate3d(0,0,0) skewY(0);
    }
}
@keyframes text_anime_on {
    0% {
        transform:translate3d(0,100%,0) skewY(12deg);
    }
    100% {
        transform:translate3d(0,0,0) skewY(0);
    }
}
.blur {
    opacity:0;
    animation-name:blurAnime;
    animation-duration:1.5s;
    animation-delay: 1.2s;
    animation-fill-mode:forwards;
}
@keyframes blurAnime {
    from {
        opacity:0;
        filter:blur(10px);
        
    }
    to {
        opacity:1;
        filter:blur(0);
        
    }
}

a {
    text-decoration: none;
    color:inherit;
}
li {
    list-style:none;
}
img {
     width:100%;
    height:100%;
    max-width:100%;
    display:block;
    object-fit: cover;
}
.bold {
    font-weight:bold;
}
.m-b40 {
    margin-bottom:40px;
}
/*wordpressログイン時*/
.wpbar {
    top: 32px !important;
}
/*header*/
.header-wrapper {
    width:100%;
    height:80px;
    position:fixed;
    z-index:100;
    top:0;
    left:0;
    background: #fff;
}
.header-inner {
    width:100%;
    height:100%;
    position:relative;
}
.logo-wrapper {
    width:150px;
    position:absolute;
    top:50%;
    left:50%;
    transform: translate(-50%,-50%);
}

main {
    display:flex;
    align-items: flex-start;
    max-width:1536px;
    margin:0 auto;
    position:relative;
    top:80px;
}
/*main-wrapper*/
.main-wrapper {
    width:calc(100% - 375px);
    container-type: inline-size;
}
/*TOP画像*/
.top-view-wrapper {
    width:100%;
    position:relative;
    color:var(--white);
}
.top-view-text,
.top-view-desc {
    position:absolute;
}
.top-view-text {
    font-size:8cqw;
    left:5%;
    display:block;
    overflow:hidden;
}
.top-view-text span {
    font-size:9.7cqw;
    color:var(--gold);
}
.text1 {
    top:5%;
}
.text2 {
    top:25%;
}
.text3 {
    top:50%;
}
.text-trigger {
    display:block;
    transform:translate3d(0,100%,0) skewY(12deg);
    transform-origin:left;
}
.top-view-desc {
    bottom:2%;
    right:2%;
    font-size:2.5cqw;
}

.infomation {
    margin:0 auto;
    padding:50px 0;
    background-color: var(--white);
}
.infomation.info2 {
    background-color: var(--primary);
}
.info-text {
    font-size:var(--font-info);
    color:var(--navy);
    text-align: center;
    margin-bottom:5px;
}
/*ボタン*/
.info-btn {
    text-align:center;
    width:280px;
    height:50px;
    background-color: var(--primary);
    margin: 0 auto;
}
.info-btn.info2 {
    background-color: var(--white);
}
.info-btn a {
    display:flex;
    justify-content: center;
    align-items: center;
    width:100%;
    height:100%;
    color:var(--black);
    transition:all .5s;
}
.info-btn a:hover {
     background-color: var(--white);
     border:1px solid var(--primary);
}
.info2 a:hover {
     background-color: var(--blue);
     color:var(--white);
}

.btn-text {
    font-size:var(--regular);
}
.btn-text span {
    font-size:var(--font-info);
}

/*section*/
.strength {
    background-color:#006FB9;
    padding:60px 20px 180px;
    clip-path: polygon(0 0,100% 0, 100% 93%, 50% 100%,0 93%);
}
.consern {
    background-color: var(--pure-white);
    padding:60px 20px 180px;
    clip-path: polygon(0 0,100% 0, 100% 95%,60% 95%, 50% 100%,40% 95%,0 95%);
}
.solution {
    background-color: var(--white);
    padding:90px 20px 60px;
    margin-top:-40px;
    position:relative;
    z-index:-1;
}
.voice,
.case,
.contact {
    background-color: var(--pure-white);
    padding:60px 20px 60px;
}
.flow,
.faq {
    background-color: var(--white);
    padding:60px 20px 60px;
}

/*タイトル*/
.title-wrapper {
    text-align:center;
    position:relative;
    margin-bottom:60px;
}
.consern .title-wrapper {
    margin-bottom:100px;
}
.solution .title-wrapper {
	margin-bottom:140px;
}
.bg-title {
    font-size:var(--bg);
}
.strength .bg-title {
    color:#223B75;
}
.consern .bg-title,
.voice .bg-title,
.case .bg-title,
.contact .bg-title {
    color:var(--white);
}
.solution .bg-title,
.faq .bg-title {
    color:var(--pure-white);
}
.flow .bg-title {
    color:var(--pure-white);
}
.section-title {
    position:absolute;
    top:65%;
    left:50%;
    transform: translateX(-50%);
    font-size:var(--middle);
	width:100%;
	max-width:380px;
    line-height: 1;
}
.strength .section-title {
    color:var(--white);
}
.consern .section-title {
    color:var(--black);
}
.solution .section-title {
	line-height:1.2;
}
.section-title span {
   display:inline-block;
}
.section-title .accent {
    font-size:var(--ex-large);
}
.accent {
    font-size:var(--accent);
}
.accent2 {
	font-size:var(--large);
}
.accent-color1 {
    color:var(--primary);
}
.accent-color2 {
    color:var(--navy);
}

/*flex-wrapper1*/
.flex-wrapper1 {
    display:flex;
    width:100%;
    max-width:600px;
    margin:0 auto;
}
.reverse {
    flex-direction: row-reverse;
}
.strength-desc,
.strength-img,
.solution-img,
.solution-desc {
    width:50%;
    aspect-ratio: 1.4 / 1;
    background-color: var(--white);
}
.strength-desc {
    padding:20px;
}
.desc-header-wrapper {
    position:relative;
}
.desc-count {
    position:absolute;
    font-size:20px;
    top:-10px;
    left:0;
    color:var(--navy);
}
.desc-count span {
    font-size:30px;
}
.desc-header-wrapper img {
    width:60px;
    margin:0 auto;
}
.desc-title,
.desc-text {
    color:var(--navy);
}
.desc-title {
    text-align:center;
    font-size:30px;
    margin:5px 0;
}
.desc-text {
    font-size: var(14px);
}

/*worries*/
.worries-wrapper {
    width:100%;
    max-width:750px;
    margin:0 auto;
}
.worries {
    display:flex;
    border:1px solid var(--navy);
}
.worries:not(:last-child) {
    margin-bottom:35px;
}
.worries-title,
.worries-text {
    display:flex;
    align-items: center;
}
.worries-title {
    justify-content: center;
    width:25%;
    padding:10px 30px;
    font-size:var(--middle);
    color:var(--white);
    background-image:linear-gradient(to bottom, var(--navy) ,var(--blue));
    clip-path: polygon(0% 0%,100% 0%,90% 100%,0% 100%);
}
.worries-text {
    justify-content: flex-start;
    padding:20px;
    font-size:var(--regular);
}

/*solution*/
.flex-wrapper2 {
    display:flex;
    width:100%;
    max-width:700px;
    margin:0 auto;
}
.solution-desc {
	padding:0 20px 20px;
}
.solution-title {
    margin:30px 0 20px;
    font-size:var(--middle);
	line-height:1.1;
}
.solution-text {
    font-size:var(--font-solution);
}
.solution-title span {
	display:inline-block;
}

/*card*/
.flex-wrapper3 {
    display:flex;
    width:100%;
    max-width:960px;
    column-gap:30px;
    flex-wrap: wrap;
    justify-content: center;
    margin:0 auto;
}
.card {
    width:300px;
    padding:20px;
    box-shadow:4px 4px 7px 0 rgb(0 0 0 / 30%);
    background-color: var(--white);
    margin-bottom:30px;
}
.card-title {
    text-align:center;
    color:var(--navy);
    font-size:var(--regular);
}
.card-icon-wrapper {
    display:flex;
    justify-content: flex-start;
	align-items: center;
    column-gap: 15px;
    margin:20px 0;
}
.card-icon {
    width:40px;
    height:auto;
}
.card-icon img {
    width:100%;
    height:100%;
    object-fit: cover;
}
.card-val {
    padding:6px 10px;
    border-radius:4px;
}
.card-val.man {
    color:var(--blue);
    border:solid 1px var(--blue);
}
.card-val.woman {
    color:red;
    border:solid 1px red;
}
.card-img {
    margin-bottom:20px;
}
.card-text span {
	font-weight:bold;
}

/*flow*/
.flow-item-wrapper {
    width:100%;
    max-width:735px;
    margin:0 auto;
}
.flow-item {
    width:calc(100% - 35px);
    max-width:700px;
    height:auto;
    display:flex;
    margin:0 auto;
    background-color: var(--pure-white);
    margin-left:35px;
    margin-bottom:30px;
}
.flow-item-left {
    width:200px;
    position:relative;
}
.flow-step {
    width:70px;
    height:70px;
    display:flex;
    flex-direction: column;
    justify-content: center;
    align-items:center;
    color:var(--white);
    background-color: var(--blue);
    text-align:center;
    position:absolute;
    top:50%;
    transform:translate(-50%,-50%);
}
.step-text {
    font-size:var(--small);
    line-height:1;
}
.step-num {
    font-size:var(--middle);
    line-height:0.9;
}
.flow-title {
    font-size:var(--regular);
    position:absolute;
    top:50%;
    left:70px;
    transform:translateY(-50%);
}
.flow-item-right {
    display:flex;
    justify-content: flex-start;
    align-items: center;
    padding:20px;
    width:calc(100% - 200px);
}

/*case*/
.case-title {
    text-align:center;
    font-size:var(--large);
    margin-bottom:60px;
}
.case-title span {
    font-size:var(--ex-large);
    color:var(--primary);
}

.case-card-wrapper {
    display:flex;
    flex-wrap:nowrap;
    column-gap:20px;
    overflow-x:scroll;
    background-color: var(--white);
    padding:20px;
}
.case-card {
    padding:20px;
    border:1px solid var(--navy);
    width:300px;
    min-width:300px;
    background-color: var(--pure-white);
}
.case-head-wrapper {
    display:flex;
    column-gap:10px;
    align-items: center;
    margin-bottom:20px;
}
.case-head-img {
    width:100px;
    aspect-ratio: 1.4/1;
}
.case-head-img img {
    width:100%;
    height:100%;
}
.case-head-text {
    font-size:20px;
}
.case-head-text span {
    font-size:36px;
    color:var(--navy);
    line-height: 1;
}
.gray {
    color:var(--light-gray);
}
.case-before {
    text-align: center;
    background-color: var(--white);
    color:var(--gray);
    padding:6px 0;
    margin-bottom:10px;
}
.case-text-wrapper {
    display:flex;
    justify-content: space-between;
    align-items: center;
    font-size:12px;
    color:var(--light-gray);
}

.case-text-right span {
    font-size:28px;
}
.arrow {
    width:15px;
    height:auto;
    margin:20px auto 10px;
}
.case-after {
    text-align: center;
    background-color: var(--purple);
    color:var(--white);
    padding:6px 0;
    margin-bottom:10px;
}
.scroll-text {
    margin-top:15px;
}
/*FAQ*/
.faq-container {
    width:100%;
    max-width:700px;
    margin:0 auto;
}
.faq-wrapper {
    border:1px solid var(--blue);
    margin-bottom:10px;
    padding:15px 20px;
    background-color: var(--pure-white);
}
.faq-wrapper dl {
    display:flex;
    justify-content: flex-start;
    align-items: center;
}
.faq-wrapper dl:nth-of-type(2) {
	padding-top:10px;
}
.faq-wrapper dt {
    width:70px;
    text-align:center;
    font-size:var(--large);
}
.faq-wrapper dd {
    max-width:calc(100% - 70px);
}
.faq-wrapper a {
	color:var(--primary);
}
.faq-title {
    font-size:var(--regular);
}
.faq-text {
    font-size:var(--small);
}
.faq-q {
    color:var(--blue);
}
.faq-a {
    color:red;
}
.under-line {
    padding-bottom:10px;
    border-bottom:1px solid var(--light-gray);
}
/*footer*/
footer {
    width:100%;
    height:250px;
    background-color: var(--navy);
    margin-top:80px;
}
.footer-inner {
    width:100%;
    height:100%;
    display:flex;
    justify-content: center;
    align-items: center;
}
.footer-logo {
     width:150px;
     height:auto;
}
.copy-right {
    background-color: var(--navy);
    font-size:var(--small);
    color:var(--white);
    text-align:center;
}

/*サイドバー*/
.sidebar {
    width:375px;
    background: linear-gradient(to bottom, var(--navy) ,var(--blue));
    position:sticky;
    top:80px;
    padding:20px;
}
.wp-side.sidebar {
    top:112px;
}
.form-inner {
    background-color: var(--pure-white);
    width:100%;
    padding:20px 10px;
}
.sidebar-title {
    color:var(--white);
    font-size:26px;
    text-align:center;
    margin-bottom:10px;
}

/*contact*/
.contact-inner {
    width:100%;
    max-width:700px;
    padding:30px 20px 40px;
    background:var(--primary);
    margin:0 auto;
}
.contact-comment {
    width:100%;
    max-width:700px;
    font-size:16px;
    margin:0 auto 10px;
    color:#333;
}
.contact-comment .red {
    display: inline-block;
    padding-bottom:7px;
}

[data-name="your-name"],[data-name="your-email"],[data-name="tel-num"],textarea {
    color:#333;
}
.wpcf7-form p {
    margin-bottom:40px;
}
.wpcf7-form label {
    font-size:24px;
    color:#fff;
}
.wpcf7-form label .red {
    display: inline-block;
    padding-bottom:8px;
}
[data-name="your-name"] input,[data-name="your-email"] input,[data-name="tel-num"] input {
    width:100%;
    height:40px;
    font-size:16px;
    margin:10px 0;
    padding:5px 15px;
    border-width:1px;
    border:1px solid #707070;
}
.wpcf7-spinner {
    display: none !important;
}
.wpcf7-form textarea {
    width:100%;
    height:200px;
    font-size:20px;
    margin:10px 0;
    padding:5px 15px;
    border:1px solid #707070;
    border-radius:8px;
}

.wpcf7-form .wpcf7-submit {
    position:relative;
    display:block;
    width:100%;
    max-width:500px;
    height:auto;
    color:var(--black);
    background:var(--pure-white);
    font-size:40px;
    padding:5px 20px;
    margin:0 auto;
    -webkit-transition:all .5s;
    -o-transition:all .5s;
    transition:all .5s;
	border-radius:8px;
}
.wpcf7-form .wpcf7-submit:hover,
.button:hover,
.button2:hover {
    background-color:var(--black);
    color:var(--white);
}

.wpcf7-form-control-wrap {
    display:flex;
    flex-direction: column;
}
.wpcf7-list-item.first {
    margin: 0;
  }
  .wpcf7-list-item-label {
    cursor: pointer;
    display:flex;
    font-size:20px;
  }
  /* デフォルトのボタン */
  input[type="radio"] {
    opacity: 0; /* デフォルトのボタンを非表示 */
    position: absolute;
  }
  /* チェック前のボタン */
  .wpcf7-list-item-label::before {
    background: #fff;
    border: 1px solid #333;
    border-radius: 100%; /* ラジオボタンっぽく丸くする */
    content: "";
    height: 1.2em;
    margin-bottom: auto;
    margin-right: .5em;
    margin-top: auto;
    transition: background-color .5s; /* 色をじんわり変化させる */
    width: 1.2em;
  }
  /* チェック後のボタン */
  input[type="radio"]:checked + .wpcf7-list-item-label::before {
    background-color: #333; /* チェック後の中心の色 */
    box-shadow: inset 0 0 0 3px #fff; /* 中心の色のスタイル */
  }

 .red {
    color:red;
 }
 /*contact(top)*/
 .form-inner .contact-inner {
    width:100%;
}
.form-inner .wpcf7-form p {
    margin-bottom:20px;
}
.form-inner .wpcf7-form label {
    font-size:18px;
    color:var(--black);
}
.form-inner .wpcf7-form label .red {
    display: inline-block;
    padding-bottom:8px;
}
.form-inner [data-name="your-name"] input,[data-name="your-email"] input {
    width:100%;
    height:28px;
    font-size:16px;
    margin:0;
    padding:10px 15px;
    border-width:1px;
    border:1px solid var(--gray);
}
.form-inner [data-name="tel-num"] input {
    width:100%;
    height:28px;
    font-size:16px;
    margin-top:8px;
    padding:10px 15px;
    border-width:1px;
    border:1px solid var(--gray);
}
.form-inner .wpcf7-spinner {
    display: none !important;
}
.form-inner .wpcf7-form textarea {
    width:100%;
    height:200px;
    font-size:20px;
    margin:10px 0;
    padding:5px 15px;
    border:1px solid var(--gray);
}

.form-inner .wpcf7-form .wpcf7-submit {
    position:relative;
    display:block;
    width:100%;
    max-width:250px;
    height:auto;
    color:var(--black);
    background:var(--pure-white);
    font-size:24px;
    padding:4px 20px;
    margin:0 auto;
    -webkit-transition:all .5s;
    -o-transition:all .5s;
    transition:all .5s;
}
.form-inner .wpcf7-form .wpcf7-submit:hover,
.form-inner .button:hover,
.form-inner .button2:hover {
    background-color:var(--black);
    color:var(--white);
}

.form-inner .wpcf7-form-control-wrap {
    display:flex;
    flex-direction: column;
}
.form-inner .wpcf7-list-item.first {
    margin: 0;
  }
.form-inner .wpcf7-list-item-label {
    cursor: pointer;
    display:flex;
    font-size:20px;
 }

 /*thanks*/
 .thanks-text {
    padding:0 20px;
    margin:30px auto;
    width:100%;
    max-width:420px;
    font-size:var(--regular);
    line-height:1.5;
 }