@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Noto+Serif+JP:wght@200..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap');

/*===================================
基本設定
===================================*/

* {
    box-sizing: border-box;
    padding: 0;
    margin: 0;
}

html {
    font-size: 16px;
    font-weight: 400;
    letter-spacing: 5%;
    line-height: 1.5;
}

body {
    width: min(1440px, 100%);
    min-width: 0;
    margin: 0 auto;
    color: #333;
    font-family: "Roboto", "Noto Sans", sans-serif;
    box-shadow: 0 0 16px rgba(0, 0, 0, .3);
}

img {
    display: block;
    max-width: 100%;
    vertical-align: top;
}

a {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
}

ul {
    list-style: none;
}

.logo {
    width: 271px;
}

section {
    padding: 4rem 0;
}

.br {
    display: none;
}

@media screen and (max-width:768px) {

    html {
        font-size: 15px;
    }

    .br {
        display: block;
    }
}

/*===================================
フォント
===================================*/

.serif {
    font-family: "Noto Serif JP", "Noto Sans", sans-serif;
}

.font28 {
    font-size: 1.75rem;
}

.font24 {
    font-size: 1.5rem;
}

.font20 {
    font-size: 1.25rem;
}

.bold {
    font-weight: 600;
}

.blue {
    color: #003A7F;
}

.center {
    text-align: center;
}

.heading-line {
    position: relative;
    display: block;
    margin-bottom: 4rem;
    font-family: "Noto Serif JP", "Noto Sans", sans-serif;
    font-size: clamp(2.625rem, 2.255rem + 1.38vw, 3.5rem);
    font-weight: 700;
    color: #003A7F;
    text-align: center;

    &::before {
        position: absolute;
        bottom: -1rem;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
        content: '';
        width: 5rem;
        height: 2px;
        background-color: #003A7F;
    }
}

.heading-diamond {
    position: relative;
    font-family: "Noto Serif JP", "Noto Sans", sans-serif;
    font-size: 1.25rem;
    font-weight: 600;
    padding-left: 1.5rem;
    margin-bottom: .5rem;

    &::before {
        position: absolute;
        top: 0;
        left: 0;
        content: '◆';
        color: #003A7F;
        width: 1rem;
        height: 1rem;
    }
}

/*===================================
ヘッダー
===================================*/

header {
    position: fixed;
    z-index: 100;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: min(1440px, 100%);
    height: 6rem;
    background: linear-gradient(180deg, #000000cc, #00000000);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 1.5rem;

    nav {
        display: flex;
        align-items: center;
        gap: 1rem;
    }

    ul {
        display: flex;
        gap: 1rem;

        li {
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
            font-weight: 500;
            padding: 1rem 0;
            color: #fff;
        }
    }

    .contact-header-button {
        width: 216px;
        margin: 0;
    }
}

/*===================================
ほまれにある！誇れる仕事！
===================================*/

#concept {
    background-image: url(../img/recruitment/concept-bg.jpg);
    background-size: cover;

    .concept-container {
        position: relative;
        color: #fff;
        font-weight: 500;
    }

    .concept-text {
        position: relative;
        z-index: 2;
        display: flex;
        flex-direction: column-reverse;
        justify-content: space-between;
        gap: 2rem;
        width: min(1200px, 92%);
        margin: 0 auto;
    }

    h2 {
        font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        font-style: italic;
        font-size: clamp(3.2rem, 2.862rem + 1.26vw, 4rem);
        line-height: 1.2;
        letter-spacing: 0;
        text-shadow: 4px 4px 0px rgba(0, 0, 0, .3);
    }

    span {
        font-size: clamp(1.8rem, 1.504rem + 1.11vw, 2.5rem);
    }

    p {
        font-size: 1.125rem;
        line-height: 1.7;
        text-shadow: 2px 2px 0px rgba(0, 0, 0, .3);

        &:not(:first-of-type) {
            margin-top: 1.25rem;
        }
    }

    .concept-img {
        position: absolute;
        z-index: 1;
        top: 0;
        right: 0;
        width: min(720px, 100%);
        height: 100%;
        background: linear-gradient(rgba(0, 0, 0, .4), rgba(0, 0, 0, .4)), url("../img/recruitment/concept.jpg");
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
    }
}

/*===================================
誇れる仕事とは
===================================*/

#pride {
    background: #E6F4F9;

    .pride {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 2rem;
        width: min(1200px, 92%);
        margin: 0 auto;
    }

    .pride-img {
        width: min(580px, 100%);
        height: 400px;
        background: url("../img/greeting.jpg");
        background-size: cover;
        background-repeat: no-repeat;
        background-position: top left;
    }

    p {
        font-size: 1.125rem;
        font-weight: 500;
        line-height: 1.7;

        &:not(:first-of-type) {
            margin-top: 1.25rem;
        }
    }

    .pride-youtube {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 1.5rem;
        margin-top: 3rem;
        width: min(1200px, 92%);
        margin: 3rem auto 0;
    }

    iframe {
        max-width: 100%;
    }
}

@media screen and (max-width:1023px) {

    #pride {
        .pride {
            flex-wrap: wrap;
        }
    }
}

@media screen and (max-width:428px) {
    #pride {
        .pride-img {
            height: 320px;
        }
    }
}

/*===================================
人生コンサルとは
===================================*/

#consulting {
    background: #E6F4F9;

    .consulting-container {
        li {
            position: relative;

            &:not(:first-of-type) {
                margin-top: 2rem;
            }
        }

        img {
            position: relative;
            z-index: 1;
            width: min(1200px, 96%);
        }

        .consulting-inner {
            position: absolute;
            z-index: 2;
            bottom: clamp(0.5rem, -0.134rem + 2.37vw, 2rem);
            left: 4%;
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        }

        .step {
            font-style: italic;
            font-size: clamp(1.7rem, 1.15rem + 2.06vw, 3rem);
            font-weight: 700;
            line-height: 1.2;
            color: #003A7F;
            text-shadow: 1px 1px 0px rgba(255, 255, 255, 1);
            margin-bottom: clamp(0.5rem, 0.289rem + 0.79vw, 1rem);
        }

        h3 {
            color: #fff;
            font-size: clamp(1.7rem, 1.15rem + 2.06vw, 3rem);
            font-weight: 500;
        }

        span {
            display: block;
            background: linear-gradient(90deg, #002958 0%, #3366A1 100%);
            box-shadow: 1px 1px 0px rgba(255, 255, 255, 1);
            padding: 0 1rem;
            width: fit-content;

            &:not(:first-of-type) {
                margin-top: clamp(0.5rem, 0.289rem + 0.79vw, 1rem);
            }

        }
    }

    .consulting-text {
        width: min(1200px, 92%);
        margin: 3rem auto 0;

        p:not(:first-of-type) {
            margin-top: 1rem;
        }
    }
}

/*===================================
CTA
===================================*/
#cta {
    display: flex;
    justify-content: center;
    align-items: center;
    background: #f5f5f5;
    padding: 2rem 0;

    .cta-left {
        width: 50%;
        height: 100%;
        object-fit: cover;
    }

    .cta-right {
        flex: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 1rem;
        width: 50%;
        text-align: center;
    }

    .cta-copy {
        font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        font-size: clamp(1.75rem, 1.433rem + 1.19vw, 2.5rem);
        font-weight: 700;
    }

    .cta-tel {
        font-family: "Roboto", "Noto Sans", sans-serif;
        font-weight: 500;

        .tel {
            position: relative;
            color: #003A7F;
            font-size: 2.5rem;
            width: fit-content;
            margin: 0 auto;
            padding-left: 3rem;

            &::before {
                position: absolute;
                top: 50%;
                left: 0;
                transform: translateY(-50%);
                content: '';
                width: 3rem;
                height: 3rem;
                background: left center / contain no-repeat url(../img/recruitment/tel.png);
            }
        }
    }

    .cta-entry-button {
        width: min(400px, 92%);
        margin: 0 auto;
    }
}

@media screen and (max-width:1024px) {
    #cta {
        flex-direction: column;
        gap: 2rem;

        .cta-left {
            width: min(768px, 92%);
        }

        .cta-right {
            width: 100%;
        }
    }
}

/*===================================
職場環境
===================================*/
#environment {
    .container {
        width: min(1200px, 92%);
        margin: 0 auto;
    }

    .container-li {
        background: #fff;
        box-shadow: 0 0 16px rgba(0, 0, 0, .3);

        &:not(:first-of-type) {
            margin-top: 4rem;
        }

        h3 {
            color: #fff;
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
            font-size: clamp(2rem, 1.789rem + 0.79vw, 2.5rem);
            font-weight: 500;
            text-align: center;
            background: linear-gradient(90deg, #002958 0%, #3366A1 100%);
            padding: 1rem;
        }
    }

    .inner {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 2rem;
        padding: 2rem clamp(1rem, 0.366rem + 2.37vw, 2.5rem);
    }

    .lead {
        color: #003A7F;
        font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        font-size: 1.25rem;
        font-weight: 600;
        text-align: center;
    }

    /* 給与制度 */

    .laurel-wreath {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 1.5rem;

        li {
            position: relative;
            z-index: 2;
            display: flex;
            flex-direction: column;
            justify-content: center;
            color: #003A7F;
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
            font-size: 1.5rem;
            font-weight: 600;
            text-align: center;
            width: 320px;
            height: 120px;

            &::before {
                position: absolute;
                top: 0;
                left: 0;
                z-index: 1;
                content: '';
                background: url(../img/recruitment/laurel-wreath-left.png);
                width: 50px;
                height: 120px;
            }

            &::after {
                position: absolute;
                top: 0;
                right: 0;
                z-index: 1;
                content: '';
                background: url(../img/recruitment/laurel-wreath-right.png);
                width: 50px;
                height: 120px;
            }
        }
    }

    .example {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 2rem;

        li {
            width: min(292px, 100%);
        }
    }

    .alumni {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2rem;
        background: #f5f5f5;
        width: 100%;
        padding: 2rem 1rem;

        h4 {
            color: #003A7F;
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
            font-size: 1.75rem;
            font-weight: 600;
            text-align: center;
        }

        dl {
            width: min(960px, 100%);
            margin: 0 auto;

            div {
                display: flex;
                flex-wrap: wrap;

                &:not(:first-of-type) {
                    margin-top: 1px;
                }
            }

            dt {
                flex: 1;
                display: flex;
                justify-content: center;
                align-items: center;
                font-weight: 500;
                text-align: center;
                background: #ddd;
                padding: 1rem;
            }

            dd {
                flex: 2;
                display: flex;
                align-items: center;
                background: #fff;
                padding: 1rem;
            }
        }
    }

    .campaign {
        width: min(800px, 100%);
    }

    /* 教育制度 */

    .training {
        width: min(1024px, 100%);
        margin: 0 auto;

        div {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            gap: 1rem;

            &:not(:first-of-type) {
                margin-top: 1.5rem;
            }
        }

        dt {
            width: 320px;
            height: 80px;
            display: flex;
            justify-content: center;
            align-items: center;
            font-weight: 500;
            text-align: center;
            color: #fff;
            background: #003A7F;
            border-radius: 40px;
            padding: 1rem;
        }

        dd {
            flex: 1;
            min-width: 50%;
            display: flex;
            align-items: center;
            background: #fff;
        }
    }

    .thumbnail {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 1rem;

        img {
            width: 300px;
        }
    }

    /* カリキュラム */

    .curriculum {
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 3rem;
        width: min(1024px, 100%);
        list-style: none;
        margin: 0 auto;

        li {
            position: relative;
            border: solid 1px #003A7F;
        }

        li:not(:last-of-type)::after {
            position: absolute;
            bottom: -2.5rem;
            left: 50%;
            transform: translateX(-50%);
            content: '';
            background: center center / contain no-repeat url(../img/recruitment/arrow.jpg);
            width: 2rem;
            height: 2rem;
        }

        .curriculum-title {
            display: flex;
            align-items: center;
            gap: 1rem;
            color: #fff;
            font-size: 1.125rem;
            background: #003A7F;
            padding: 1rem;

            .period {
                display: inline-block;
                color: #003A7F;
                background: #fff;
                font-weight: 500;
                padding: .5rem 1rem;
            }
        }

        .content {
            display: flex;
            justify-content: center;
            align-items: center;
            flex-wrap: wrap;
            gap: 1rem;
            padding: 1rem;

            p {
                flex: 1;
                min-width: 50%;
            }

            img {
                width: min(300px, 100%);
            }
        }
    }

    /* 職場環境 */

    .workplace {
        li {
            display: flex;
            align-items: stretch;
            margin: 0;
        }

        img {
            width: 50%;
            object-fit: cover;
        }

        div {
            display: flex;
            flex-direction: column;
            justify-content: center;
            width: 50%;
            padding: 1rem;
        }

        p:not(:first-of-type) {
            margin-top: 1rem;
        }

        h4 {
            color: #003A7F;
            font-family: "Noto Serif JP", "Noto Sans", sans-serif;
            font-size: 1.5rem;
            font-weight: 600;
            margin-bottom: 1rem;
        }

        @media (max-width: 640px) {

            li {
                flex-direction: column;
            }

            img,
            div {
                width: 100%;
            }

            img {
                height: 240px;
                display: block;
            }

            /* 2番目・4番目を画像→テキストの順に揃える */
            li:nth-child(even) {
                flex-direction: column-reverse;
            }
        }
    }

    /* 福利厚生 */

    .employee-benefits {
        width: 100%;

        ul {
            display: flex;
            justify-content: center;
            flex-wrap: wrap;
            gap: 1.5rem;
            margin-top: 1rem;
        }

        img {
            width: 340px;
            height: 256px;
            object-fit: cover;
        }
    }

    .employee-benefits-youtube {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 1.5rem;
        margin: 1.5rem auto 0;
    }

    iframe {
        max-width: 100%;
    }

    .employee {
        width: 100%;
    }
}

/*===================================
社員の声
===================================*/

#voice {
    background: #E6F4F9;

    /* スライド */
    .slider {
        display: flex;
        justify-content: center;
        width: 94%;
        margin: 0 auto;
        cursor: grab;
    }

    .slider:active {
        cursor: grabbing;
    }

    .slick-track {
        height: 100%;
    }

    .slider .slick-slide {
        width: min(800px, 100%);
        margin: 0 1rem;

        img {
            width: 800px;
        }
    }

    /*矢印の設定*/
    .slick-prev,
    .slick-next {
        position: absolute;
        top: 42%;
        cursor: pointer;
        outline: none;
        border-top: 2px solid #003A7F;
        border-right: 2px solid #003A7F;
        height: 24px;
        width: 24px;
    }

    .slick-prev {
        left: -2%;
        transform: rotate(-135deg);
    }

    .slick-next {
        right: -2%;
        transform: rotate(45deg);
    }

    .content {
        background: #fff;
        padding: 2rem clamp(1rem, 0.757rem + 1.04vw, 2rem);
        height: 100%;
        width: 100%;
    }

    h3 {
        color: #003A7F;
        font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        font-size: 1.5rem;
        font-weight: 600;
        text-align: center;
        margin-bottom: 2rem;
    }

    p {
        line-height: 1.7;

        &:not(:first-of-type) {
            margin-top: 1rem;
        }
    }
}


/* 募集要項 */
#application-requirements {

    dl {
        width: min(960px, 100%);
        margin: 0 auto 4rem;
        border: 1px solid #ddd;

        div {
            display: flex;
            flex-wrap: wrap;

        }

        dt {
            flex: 1;
            font-weight: 500;
            background: #ddd;
            padding: 1rem;
            border-bottom: solid 1px #fff;
        }

        div:nth-of-type(11) dt {
            border: none;
        }

        dd {
            flex: 3;
            background: #fff;
            padding: 1rem;
            border-bottom: solid 1px #ddd;
        }

        div:nth-of-type(11) dd {
            border: none;
        }
    }

    ol {

        li {
            list-style-type: none;
            counter-increment: number;
            text-indent: -2.5rem;
            padding-left: 2.5rem;
        }

        li::before {
            content: "（" counter(number) "）";
        }
    }

    p {
        text-indent: 0;
        padding-left: 0;
        margin-top: 1rem;
    }
}

.campaign {
    width: 800px;
    margin: 0 auto;
}

/* FAQ */
#faq {
    background: #E6F4F9;
}

.faq {
    width: 1024px;
    margin: 0 auto;
}

/*アコーディオン*/
.accordion-area {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    width: min(1024px, 100%);
    margin: 0 auto;

    dl {
        background: #003A7F;
    }

    /*アコーディオンタイトル*/
    .title {
        position: relative;
        cursor: pointer;
        padding: 1.5rem 2.5rem 1.5rem 4rem;
        transition: all .4s ease-in-out;

        h3 {
            position: relative;
            color: #fff;
            font-size: 1.25rem;
            font-weight: 500;
        }

        h3::before {
            position: absolute;
            top: 50%;
            left: -3rem;
            transform: translateY(-50%);
            content: 'Q';
            width: 2rem;
            height: 2rem;
            background: #fff;
            border-radius: 50%;
            color: #333;
            font-size: 1.2rem;
            line-height: 1.7;
            text-align: center;
        }
    }

    /*アイコンの＋と×*/
    .title::before,
    .title::after {
        position: absolute;
        content: '';
        width: 20px;
        height: 4px;
        background-color: #fff;
    }

    .title::before {
        top: 48%;
        right: 16px;
        transform: rotate(0deg);
    }

    .title::after {
        top: 48%;
        right: 16px;
        transform: rotate(90deg);
    }

    .title.close::before {
        transform: rotate(45deg);
    }

    .title.close::after {
        transform: rotate(-45deg);
    }

    .box {
        position: relative;
        display: none;
        background: #fff;
        padding: 1.5rem 1.5rem 1.5rem 4rem;
        font-size: 1.125rem;

        p:not(:first-of-type) {
            margin-top: 1rem;
        }

        ul {
            margin-top: 1rem;
        }

        &::before {
            position: absolute;
            top: 1.5rem;
            left: 1rem;
            content: 'A';
            width: 2rem;
            height: 2rem;
            background: #003A7F;
            border-radius: 50%;
            color: #fff;
            font-size: 1.2rem;
            line-height: 1.7;
            font-weight: 500;
            text-align: center;
        }
    }
}

footer {
    font-family: "Noto Serif JP", "Noto Sans", sans-serif;
    background: linear-gradient(45deg, #002958, #3366A1);
    color: #fff !important;
}

/*===================================
エントリーフォーム
===================================*/

#entry {
    background: #E6F4F9;

    .information {
        margin: 4rem auto;
        text-align: center;
    }

    form {
        font-family: "Noto Serif JP", "Noto Sans", sans-serif;
        width: 800px;
        margin: 0 auto;
    }
}