@charset "UTF-8";

/* ---------- ここから共通 ---------- */
html {
    font-size: 62.5%;
    scroll-behavior: smooth;
}
body {
    font-size: 1.4rem;
    font-family:"Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3",sans-serif;
    color: #333;
    box-sizing: border-box;
    line-height: 1;
    letter-spacing: 0.05em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt";
}
main {
    background: #f6f6f6;
}
img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}
a {
    color: #333;
    text-decoration: none;
    transition: 0.6s;
}
a:hover {
    opacity: 0.7;
}
li {
    list-style: none;
}
picture {
    display: block;
}
  
@media (min-width:431px) {
    body {
        font-size: 1.8rem;
    }
}
.wrapper {
    max-width: 1300px;
    margin: 0 auto;
    padding: 0 20px;
}
h3.sec-ttl {
    font-size: 1.4rem;
    width: fit-content;
    padding: 0 5px 11px;
    border-bottom: 2.5px solid #000;
    text-transform: uppercase;
    margin-bottom: 40px;
}
h2.sec-ttl-ja {
    font-size: 2rem;
}
.emphasis {
    font-size: 2rem;
    font-weight: bold;
    display: block;
}
.scroll-btn-container {
    width: 32.5px;
    height: 32.5px;
    position: fixed;
    z-index: 4;
    right: 20px;
    bottom: 64px;
}
@media(min-width:1025px) {
    .pc-none {
        display: none;
    }
}
@media(min-width:431px) {
    h3.sec-ttl {
       font-size: 2rem;
       padding-bottom: 7px;
       border-bottom: 3px solid #000;
    }
    h2.sec-ttl-ja {
        font-size: 3rem;
    }
    .emphasis {
        font-size: 3rem;
        display: block;
    }
}




/* ---------- ここからヘッダー ---------- */
.header {
    padding: 13.5px 14px 0;
}
.header .drawer-navbar-header .logo-container {
    max-width: 113.5px;
    height: 44.5px;
    display: flex;
    align-items: center;
}
.header .logo-container img {
    min-width: 113px;
}
.header .header-nav {
    background: #005769;
    padding: 68px 25px;
    height: 100vh;
}
.header .nav-item {
    font-size: 1.9rem;
    text-align: center;
    padding-bottom: 15px;
    border-bottom: 1px solid #fff;
    margin-bottom: 17.5px;
}
.header .nav-item a {
    font-size: 1.9rem;
    font-weight: bold;
    color: #fff;
    text-transform: uppercase;
    text-underline-offset: 4px;
}
.header .nav-item .nav-ja {
    font-size: 1.2rem;
    color: #fff;
    display: block;
    margin-top: 10px;
}
.header .sns-item {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 32px;
}
.header .sns-item .img-container {
    width: 39.5px;
    height: 39.5px;
}

.header .drawer-hamburger:hover {
    background-color: #005769;
}
.header .sns-item .img-container:first-child {
    margin-right: 17px;
}
.header .sns-item .img-container:last-child {
    margin-left: 17px;
}
@media(min-width: 1280px) {
    .header {
        padding: 20px;
    }
    .header .logo-container img {
        min-width: 188px;
    }
    .header .header-nav {
        background: none;
        padding: 0;
        height: inherit;
    }
    .header .header-flex {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .header .nav-item:last-child {
        margin-right: 0;
    }
    .header .nav-item a {
        color: #005769;
        font-size: 1.6rem;
    }
    .header .nav-item:last-child {
        margin-bottom: 0;
        margin-right: 0;
    }
    .header .nav-item .nav-ja {
        display: none;
    }
    .header .sns-item {
        display: none;
    }   
}
@media(min-width:1280px) {
    .header .logo-container {
        max-width: 188px;
    }
    .header .nav-item {
        font-size: 1.6rem;
        padding-bottom: 0;
        border-bottom: none;
        margin-bottom: 0;
        margin-right: 40px;
    }
}



/* ---------- ここからキービジュアル ---------- */
.sec-kv {
    background: #fff;
    height: 80vh;
}
.sec-kv .kv-logo-container {
    height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 255.5px;
    margin: 0 auto;
}

@media(min-width:431px) {
    .sec-kv {
        height: 100vh;
    }
    .sec-kv .kv-logo-container {
        max-width: 511px;
        height: 100vh;
  
    }  
}
#layer.ready .cls-1 {
    fill: none;
    stroke: #005769;
}
#layer.done .cls-1 {
    fill: #005769;
    stroke: #005769;
    fill-opacity: 1;
}


/* ---------- ここからコンセプト ---------- */
.sec-concept {
    margin-bottom: 57.5px;
}
.sec-concept .flex-left {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 40px;
}
.sec-concept .message {
    line-height: 2;
}
.sec-concept .message .emphasis {
    margin: 50px 0 24.5px;
}

@media(min-width:1280px) {
    .sec-concept {
        margin-bottom: 79px;
    }
    .sec-concept .concept-flex {
        display: flex;
    }
    .sec-concept .flex-left {
        margin: 0 50px 0 calc(50% - 50vw);
        padding: 0;
        flex: 1;
        width: 60%;
        position: relative;
    }
    .sec-concept .flex-left img {
        min-width: 828px;
        position: absolute;
        top: 0;
        right: 0;
    }
    .sec-concept .flex-right {
        width: 40%;
        min-width: 600px;
        padding: 95px 0 0;
    }

    .sec-concept .message {
        line-height: 2.11111111;
    }
    .sec-concept .message .emphasis {
        margin: 54px 0 35px;
    }  
}



/* ---------- ここから「人を集め、愛される」看板を一緒に作りましょう ---------- */
.sec-invite {
    margin-bottom: 85px;
}
.sec-invite .catch {
    font-size: 2.6rem;
    line-height: 1.53846154;
    text-align: center;
    width: fit-content;
    padding: 42.5px 5.5px 16px;
    border-bottom: 4px solid #003963;
    color: #003963;
    margin: 0 auto 18px;
    position: relative;
}
.sec-invite .catch::before, .sec-invite .catch::after {
    content: "";
    display: block;
    width: 69px;
    height: 69px;
    background-size: cover;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
} 
.sec-invite .catch::before {
    background-image: url(../images/sparkl-left.png) ;
    left: 0;
} 
.sec-invite .catch::after {
    background-image: url(../images/sparkl-right.png);
    left: 81%;
} 
.sec-invite .invite-flex {
    display: flex;
    flex-direction: column-reverse;
}
.sec-invite .flex-right{
    margin-bottom: 35px;
}
.sec-invite .flex-left .message {
   line-height: 2;
}
.sec-invite .flex-left .emphasis{
   line-height: 1.68421053;
   margin: 48px 0 37.5px;
}

@media(min-width:1025px) {
    .sec-invite {
        margin-bottom: 94px;
        overflow-x: hidden;
    }
   
    .sec-invite .invite-flex {
        flex-direction: row;
        align-items: center;
    }
    .sec-invite .flex-item {
        width: calc((100% - 64px) / 2);
    }
    .sec-invite .flex-right {
        flex-grow: 1;
        margin: 0 calc(50% - 50vw) 0 64px;
    }
    .sec-invite .flex-left .message {
        line-height: 2.11111111;
    }
    .sec-invite .flex-left .emphasis{
       line-height: 1.66666667;
       margin: 66px 0 45px;
    } 
}

@media(min-width: 431px) {
    .sec-invite .catch {
        font-size: 5.2rem;
        padding: 85px 35px 32px;
        border-bottom: 8px solid #003963;
        width: fit-content;
        margin: 0 auto 14px;
    }
    .sec-invite .catch::before, .sec-invite .catch::after {
        width: 138px;
        height: 138px;
    } 
    .sec-invite .catch::before {
        left: 0;
    } 
    .sec-invite .catch::after {
        left: 79%;
    } 
}



/* ---------- ここからCATEGORY ---------- */
.sec-category {
    margin-bottom: 80px;
}
.sec-category .flex-left {
    display: block;
    width: 100vw;
    margin: 0 calc(50% - 50vw) 31px;
}
.sec-category .sec-ttl-ja {
    margin-bottom: 28px;
}
.sec-category .desc {
    margin-bottom: 53.5px;
    line-height: 1.78571429;
}
.sec-category .signboad-list {
    margin-bottom: 25px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.sec-category .signboad-item {
    text-align: center;
    width: calc((100% - 14px) / 3);
    margin-right: 7px;
    margin-bottom: 30px;
}
.sec-category .signboad-item .img-container {
    margin-bottom: 17.5px;
}
.sec-category .signboad-item:nth-child(3n) {
    margin-right: 0;
}
.sec-category .signboad-name {
    font-weight: bold;
    text-align: center;
    background: #fff;
   padding: 7px 0;
   border: 1px solid #bbb;
}
.sec-category .message {
    line-height: 1.78571429;
}

@media(min-width:1280px) {
    .sec-category {
        margin-bottom: 130px;
    }
    .sec-category .category-flex {
        display: flex;
        margin-bottom: 66px;
    }
    .sec-category .flex-item {
        width: calc((100% - 64px) / 2);
    }
    .sec-category .flex-left {
        display: block;
        margin: 0 64px 0 calc(50% - 50vw);
        flex: 1;
    }
    .sec-category .flex-right {
        padding: 40px 0 0;
    }
    .sec-category .sec-ttl {
        margin-bottom: 88px;
    }
    .sec-category .sec-ttl-ja {
        margin-bottom: 55px;
    }
    .sec-category .desc {
        margin-bottom: 0;
        line-height: 2.11111111;;
    }
    .sec-category .signboad-list {
        margin-bottom: 75px;
        width: 100%;
    }
    .sec-category .signboad-item .img-container {
        margin-bottom: 36px;
    }
    .sec-category .signboad-item:nth-child(3n) {
        margin-right: 14px;
    }
    .sec-category .signboad-item:last-child {
        margin-right: 0;
    }
    .sec-category .signboad-name {
        padding: 14px 0;
    }
    .sec-category .message {
        line-height: 1.78571429;
    }
}

@media(min-width:835px) {
    .sec-category .signboad-item {
        width: calc((100% - 70px) / 6);
        margin-right: 14px;
        margin-bottom: 30px;
    }
}



/* ---------- ここからFLOW ---------- */
.sec-flow {
    margin-bottom: 75.5px;   
}
.sec-flow .sec-ttl-ja {
    margin-bottom: 33px;
}
.sec-flow .desc {
    line-height: 1.78571429;
    margin-bottom: 27px;
}
.sec-flow .flow-bg {
    background: #fff;
}
.sec-flow .flow-flex {
    display: flex;
}
.sec-flow .flex-left {
    max-width: 72.5px;
    margin-right: 7.5px;
}
.sec-flow .flex-left img {
    object-fit: cover;
    height: 100%;
}
.sec-flow .flex-right {
    width: calc(100% - (72.5px + 7.5px));
    padding-top: 44.5px;
    padding-right: 33px;
}
.sec-flow .flow-item {
    margin-bottom: 46px;
}
.sec-flow .flow-item .number {
    font-size: 1.3rem;
    padding-left: 23px;
    margin-bottom: 11.5px;
    position: relative;
}
.sec-flow .flow-item .number:before {
    content: "";
    display: block;
    width: 11px;
    height: 1.5px;
    background: #333;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
}
.sec-flow .flow-item .flow-title {
    font-size: 1.5rem;
    font-weight: bold;
    padding-left: 23px;
    margin-bottom: 15px;
}
.sec-flow .flow-item .flow-desc {
    line-height: 1.64285714;
    padding-left: 23px;
}
.sec-flow .flex-left picture {
    height: 100%;
}
.sec-flow .flex-left img {
    width: 100%;
}
@media(min-width:1025px) {
    .sec-flow {
        margin-bottom: 90px;   
    }
    .sec-flow .sec-ttl-ja {
        margin-bottom: 37px;
    }
    .sec-flow .desc {
        line-height: 1.78571429;
        margin-bottom: 27px;
    }
    .sec-flow .flow-bg {
        background: #fff;
    }
    .sec-flow .flex-right {
        display: flex;
        flex-wrap: wrap;
        width: calc(100% - (461px + 35px));
        padding-top: 44.5px;
        padding-right: 33px;
    }
    .sec-flow .flow-item {
        width: calc((100% - 112px) / 2);
        margin-bottom: 118px;
        margin-right: 112px;
    }
    .sec-flow .flow-item:nth-child(2n) {
        margin-right: 0;
    }
    .sec-flow .flow-item:last-child {
        margin-bottom: 115px;
    }
}

@media(min-width:431px) {
    .sec-flow .flex-left {
        max-width: 461px;
        margin-right: 35px;
    }
    .sec-flow .flow-item .number {
        font-size: 2.6rem;
        padding-left: 31px;
        margin-bottom: 25px;
    }
    .sec-flow .flow-item .number:before {
        width: 22px;
        height: 3px;
    }
    .sec-flow .flow-item .flow-title {
        font-size: 2.6rem;
        padding-left: 31px;
        margin-bottom: 33px;
    }
    .sec-flow .flow-item .flow-desc {
        line-height: 2.11111111;
        padding-left: 31px;
        font-size: 1.8rem;
    }
}


/* ---------- ここからINFORMATION ---------- */
.sec-info {
    margin-bottom: 97.5px;
}
.sec-info .info-flex  {
    display: flex;
    flex-direction: column-reverse;
}
.sec-info .flex-left .sec-ttl-ja {
    margin-bottom: 20px;
}
.sec-info .flex-right .sec-visual {
    margin-bottom: 42px;
}
.sec-info .to-ig {
    text-align: center;
    margin-bottom: 52.5px;
}
.sec-info .info-item {
    padding: 20px 0;
    border-bottom: .5px solid #dfdedf;
    display: flex;
    }
.sec-info .info-title {
    width: max(15.231231%, 100px);
    padding-left: 6px;
    line-height: 1.64285714;
}
.sec-info .info-data {
    width: calc(100% - max(15.231231%, 100px));
    line-height: 1.64285714;
}
.sec-info .info-data address {
    font-style: normal;
}

@media(min-width:1025px) {
    .sec-info {
        margin-bottom: 187px;
    }
    .sec-info .info-flex  {
        flex-direction: row;
    }
    .sec-info .flex-left {
        width: 43.346154%;
        margin-right: 75px;
    }
    .sec-info .flex-left .sec-ttl-ja {
        margin-bottom: 75px;
    }
    .sec-info .flex-right {
        width: calc(100% - (43.346154% + 75px));
    }
    .sec-info .flex-right .sec-visual {
        margin-bottom: 74px;
    }
    .sec-info .to-ig {
        margin-bottom: 0;
    }
    .sec-info .info-item {
        padding: 34px 0;
        border-bottom: 1px solid #dfdedf;
    }
    .sec-info .info-title {
        width: max(31.913386%, 209px);
        padding-left: 22px;
    }
    .sec-info .info-data {
        width: calc(100% - max(31.913386%, 209px));
        line-height: 2.11111111;
    }
}



/* ---------- ここからCONTACT ---------- */
.sec-contact {
    padding-bottom: 88px;
}
.sec-contact .flex-left {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 61px;
}
.sec-contact .flex-right .sec-ttl-ja {
    margin-bottom: 30px;
}
.sec-contact .flex-right .desc {
    line-height: 1.71428571;
    margin-bottom: 70px;
}
.sec-contact form .form-item {
    font-size: 1.6rem;
    padding-bottom: 31.5px;
}
.sec-contact form .form-item:last-of-type {
    padding-bottom: 35px;
    border-bottom: 1px solid #dfdedf;
    margin-bottom: 22.5px;
}
.sec-contact form .form-title {
    margin-bottom: 12px;
}
.sec-contact form .required {
    font-size: 1.2rem;
    color: #fff;
    padding: 4px 5px;
    background: #f2383c;
    display: inline-block;
    line-height: 1;
}
.sec-contact form .form-area {
    font-size: 1.6rem;
}
.sec-contact form input:not([type="radio"]) {
    font-size: 1.6rem;
    background: #fff;
    padding: 10px;
    border: 1px solid #dfdedf;
    width: 100%;
    height: 44.5px;
}
.sec-contact .radio-list {
    display: flex;
}
.sec-contact .radio-item {
    display: flex;
    align-items: center;
    margin-right: 24px;
}
.sec-contact .radio-item:last-child {
   margin-right: 0;
}

.sec-contact form input[type="radio"] {
    position: relative;
    background: #fff;
    border: 1px solid #dfdedf;
    width: 19px;
    height: 19px;
    cursor: pointer;
}
.sec-contact form input[type="radio"]:checked:before {
    position: absolute;
    top: 1px;
    left: 5px;
    transform: rotate(50deg);
    width: 8px;
    height: 12px;
    border-right: 3px solid #00576a;
    border-bottom: 3px solid #00576a;
    content: '';
  }
.sec-contact form label {
    padding-left: 8.5px;
}
.sec-contact form textarea {
    font-size: 1.6rem;
    background: #fff;
    padding: 10px;
    border: 1px solid #dfdedf;
    width: 100%;
    height: 133px;
    line-height: 1.6;
}
.sec-contact form .pp-confirm {
    font-size: 1.2rem;
    line-height: 1.41666667;
    background: #fff;
    padding: 16.5px 12.5px;
    border: .5px solid #c3c3c3;
    height: 152px;
    overflow-y: scroll;
    margin-bottom: 33.5px;
    }
.sec-contact form .pp-confirm .strong{
    font-weight: bold;
    display: block;
}
.sec-contact form .alert {
    font-size: 1.2rem;
    text-align: left;
    line-height: 1.41666667;
    margin-bottom: 50px;
}
.sec-contact form .btn-container {
    text-align: center;
}
.sec-contact form input[type="submit"] {
    font-size: 2rem;
    background: #2f3739;
    color: #fff;
    padding: 29px 90px;
    border-radius: 10px;
    width: 100%;
    height: 77px;
}
.sec-contact form input {
    appearance: none;
}
.sec-contact label.error {
    display: block;
    color: #C00;
    line-height: 1.6;
    font-size: 14px;
}
.sec-contact.complete .thanks {
    text-align: center;
    line-height: 2;
    margin: 40px 0;
}
.sec-contact.complete .to-top {
    font-size: 2rem;
    background: #2f3739;
    color: #fff;
    padding: 29px 90px;
    border-radius: 10px;
    display: block;
    width: fit-content;
    height: 77px;
    margin: 0 auto;
}
.sec-contact .btn_correct {
    padding: 2em;
    display: block;
}


@media(min-width:1025px) {
    .sec-contact {
        padding-bottom: 154px;
    }
    .sec-contact .contact-flex {
        display: flex;
        align-items: center;
        margin-bottom: 100px;
    }
    .sec-contact .flex-item {
        width: calc((100% - 64px) / 2);
    }
    .sec-contact .flex-left {
        margin: 0 64px 0 calc(50% - 50vw);
        flex: 1;
    }
    .sec-contact .flex-right .sec-ttl-ja {
        margin-bottom: 60px;
    }
    .sec-contact .flex-right .desc {
        line-height: 2.11111111;
        margin-bottom: 0;
    }
    .sec-contact form .form-item {
        font-size: 1.8rem;
        display: flex;
        padding-bottom: 40px;
    }
    .sec-contact form .form-item:last-of-type {
        padding-bottom: 37px;
        margin-bottom: 22px;
    }
    .sec-contact form .form-title {
        margin-bottom: 0;
        width: max(2.6470588vw, 252px);
        margin-right: 54px;
    }
    .sec-contact form .required {
        font-size: 1.4rem;
        padding: 6px 5px;
    }
    .sec-contact form .form-area {
        font-size: 1.8rem; 
        width: calc(100% - (max(2.6470588vw, 252px) + 54px));
    }

    .sec-contact form input:not([type="radio"]) {
        font-size: 1.8rem;
        width: 700px;
        height: 32px;
    }
    .sec-contact .radio-item {
        margin-right: 48px;
    }
    .sec-contact .radio-item:last-child {
       margin-right: 0;
    }
    .sec-contact .radio-item label {
        cursor: pointer;
    }
    .sec-contact form input[type="radio"] {
        width: 28px;
        height: 28px;
    }
    .sec-contact form input[type="radio"]:checked:before {
        top: 2px;
        left: 8px;
        width: 12px;
        height: 18px;
        border-right: 4px solid #00576a;
        border-bottom: 4px solid #00576a;
    }
    .sec-contact form input:not([type="radio"]) > label {
        padding-left: 8px;
    }
    .sec-contact form textarea {
        width: 610px;
        height: 130px;
    }
    .sec-contact form .pp-confirm {
        font-size: 1.4rem;
        line-height: 1.42857143;
        padding: 22px;
        border: 1px solid #c3c3c3;
        height: 170px;
        margin-bottom: 26px;
    }
    .sec-contact form .alert {
        line-height: 1.42857143;
        font-size: 1.4rem;
        margin-bottom: 40px;
        text-align: center;
    }
    .sec-contact form input[type="submit"] {
        font-size: 2.2rem;
        padding: 32px 100px;
        border-radius: 5px;
        width: fit-content;
        height: 85px;
        transition: all .3s ease;
    }
    .sec-contact form input[type="submit"]:hover {
        background: #00576a;
    }
    .sec-contactcomplete .thanks {
        line-height: 2.11111111;
    }
    .sec-contact .btn_correct {
        margin: 0 1em;
        display: inline-block;
    }
}




/* ---------- ここからフッター ---------- */
.footer .footer-bg {
    background: #13205e;
    padding: 31.5px 0 58px;
}
.footer .logo-container {
    max-width: 113px;
    margin: 0 auto 34px;
}
.footer .copyright {
    color: #bac9d0;
    font-size: 1.2rem;
    display: block;
    text-align: center;
}

@media(min-width:1025px) {
    .footer .footer-bg {
        padding: 26px 0 17px;
    }
    .footer .logo-container {
        max-width: 110px;
        margin: 0 auto 19px;
    }
    .footer .copyright {
        font-size: 1.4rem;
    }
}
/* ---------- ここから固定フッター ---------- */
.fixed-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
}
.fixed-footer .fixed-footer-flex {
    display: flex;
}
.fixed-footer .fixed-footer-flex a {
    width: 50%;
    height: 44px;
    display: block;
    display: flex;
    justify-content: center;
    align-items: center;
}
.fixed-footer .fixed-footer-flex a p {
    color: #fff;
    font-size: 1.4rem;
    font-weight: bold;
}
.fixed-footer .flex-left {
    background: #00576a;
}
.fixed-footer .flex-left .img-container {
    max-width: 26.5px;
    margin-right: 8.5px;
}
.fixed-footer .flex-right {
    background: #06c755;
}
.fixed-footer .flex-right .img-container {
    max-width: 43px;
    margin-right: 3px;
}

