@charset "utf-8";

:root {
    --primary-100: #0eaf90;
    --primary-200: #7edac8;
    --primary-300: #ffffff;
    --primary1-100: #7BC3B5;
    --primary2-100: #689FB9;
    --primary3-100: #E68289;
    --accent-100: #eef08c;
    --accent-200: #888e2e;
    --text-100: #2a2a2a;
    --text-200: #525252;
    --bg-100: #ffffff;
    --bg-200: #f5f5f5;
    --bg-300: #b3b3b3;
    --error-100: #DA1333;
    --temp-min: #1359da;
}

html {
    /* 14px */
    color: var(--text-100);
    font-size: 3.5vw;
    font-family: "Zen Maru Gothic", serif;
    font-weight: 400;
    font-style: normal;
}

body {
    width: 100vw;
    margin: 0;
}

.pc {
    display: none;
}

.sp {
    display: block;
}

/* ===== ヘッダー ===== */
header {
    display: flex;
    /* ヘッダーを固定する */
    position: fixed;
    width: 100%;
    height: 5.2%;
    /* 配置の基準位置を決める */
    top: 0;
    left: 0;
    background-color: var(--bg-100);
    padding: 2.42% 3.14% 2.17% 1.93%;
    z-index: 100;
}

header h1 .logo {
    display: inline-block;
}

header h1 .logo img {
    width: 30.43%;
    object-fit: contain;
}

header .login_button {
    display: flex block;
    justify-content: center;
    align-items: center;
    white-space: nowrap;
    margin: 0 0 0 auto;
}

header .login_button i {
    display: block;
    font-size: 1.43rem;
    padding: 1% 0 0 2%;
}

/* ===== main ===== */
#service_top {
    padding: 10% 0 0 0;
}

/* 共通h2 */
#service_top section h2 {
    color: var(--primary-100);
    font-size: 1.71rem;
    text-align: center;
}

/* 共通アカウント登録ボタン */
#service_top .account_register_button {
    display: inline-block;
    width: 62.56%;
    text-align: center;
    border: 1px solid var(--accent-100);
    border-radius: 999px;
    background-color: var(--accent-100);
    box-shadow: 0.3px 0.3px 0.6px var(--accent-200);
    padding: 2.17% 0;
}

#service_top .account_register_button:hover {
    background-color: var(--bg-100);
    box-shadow: none;
}

#service_top section {
    margin: 0 9.9% 0;
}

/* section1 */
#service_top #section1 .top_image_container {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    background-image: url(../img/common/service_top/top_background_yellow.png), url(../img/common/service_top/top_background_green.png);
    background-repeat: no-repeat;
    background-position: -400% 100%, 450% -200%;
    background-size: 88.16% 88.16%, 88.16% 88.16%;
    padding: 4.59% 0 15.46% 0;
}

#service_top #section1 .top_image_container .top_app {
    height: 85vw;
}

#service_top #section1 .top_image_container .top_text {
    height: 70.29%;
}

#service_top #section1 {
    text-align: center;
    margin: 0 0 22.71% 0;
}

#service_top #section1 h2 {
    margin: 0 0 5.56%;
}

#service_top #section1 p {
    font-size: 1.14rem;
    letter-spacing: 0.4rem;
}

#service_top #section1 a {
    margin: 8.94% 0 0 0;
}

/* section2 */
#service_top #section2 {
    margin-bottom: 17.87%;
}

#service_top #section2 h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.14rem;
    margin: 0 0 4.84% 0;
}

#service_top #section2 h2 img {
    width: 75.45%;
    object-fit: cover;
    margin: 0 0.18% 0 0;
}

#service_top #section2 p {
    margin: 0 0 7.88% 0;
}

#service_top #section2 iframe {
    width: 100%;
    height: 46vw;
    border: none;
}

/* section3 */
#service_top #section3 {
    margin-bottom: 18.59%;
}

#service_top #section3 h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 0 9.7%;
}

#service_top #section3 h2 .title_min_text {
    font-size: 1rem;
    margin: 1.63% 2.12% 0;
}

#service_top #section3 .service_container {
    height: 80.92vw;
    text-align: center;
    border: 0.5px solid var(--bg-300);
    border-radius: 4px;
    background-color: var(--bg-100);
    margin: 0 0 4.54%;
    padding: 6.06% 10% 0;
}

#service_top #section3 .service_container img {
    width: 100%;
    height: 37.44vw;
    object-fit: contain;
    margin: 0 0 3.04%;
}

#service_top #section3 .service_container h3 {
    color: var(--accent-200);
    font-size: 1.14rem;
    margin: 0 0 3.04%;
}

#service_top #section3 .service_container .text_block p {
    text-align: left;
}

#service_top #section3 .lower_service_wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3.34%;
}

#service_top #section3 .lower_service_wrap .service_container {
    position: relative;
    height: 100%;
    margin: 0;
    padding: 0;
}

#service_top #section3 .lower_service_wrap .service_container img {
    width: 100%;
    height: 90%;
    object-fit: cover;
    object-position: center;
    margin: -2% 0 0 0;
}

#service_top #section3 .lower_service_wrap .service_container .service_name {
    position: absolute;
    bottom: 5%;
    width: 100%;
    color: var(--accent-200);
    font-size: 0.86rem;
}

/* section4 */
#service_top #section4 {
    margin-bottom: 6.52%;
}

#service_top #section4 h2 {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2.14rem;
    margin: 0 0 9.7%;
}

#service_top #section4 h2 .title_min_text {
    font-size: 1.14rem;
    margin: 1.63% 0.6% 0 0;
}

#service_top #section4 h3 {
    font-size: 1.71rem;
    border-bottom: 1px solid var(--text-200);
    margin: 0 0 4.54% 0;
    padding: 0 2.42% 1.82%;
}

#service_top #section4 img {
    display: block;
    width: 100%;
    height: 43.48vw;
    object-fit: contain;
    margin: 0 0 4.54%;
    padding: 0 5.46%;
}

#service_top #section4 .text_block {
    margin: 0 5.46% 13.64%;
}

#service_top #section4 .text_block p,
#service_top #section4 .text_block ul li {
    font-size: 1.14rem;
    text-align: left;
}

/* section5 */
#service_top #section5 {
    margin-bottom: 17.63%;
}

#service_top #section5 h2 {
    font-size: 2.14rem;
    margin: 0 0 6.66% 0;
}

#service_top #section5 a {
    display: block;
    width: 100%;
    color: var(--bg-100);
    text-align: center;
    font-size: 1.14rem;
    border: 0.5px solid var(--bg-300);
    border-radius: 4px;
    background-color: var(--bg-200);
    margin: 0 0 3.04%;
    padding: 2.42% 0;
}

#service_top #section5 a:nth-child(2) {
    border-color: var(--primary1-100);
    background-color: var(--primary1-100);
}

#service_top #section5 a:nth-child(2):hover {
    color: var(--primary1-100);
    background-color: var(--bg-100);
}

#service_top #section5 a:nth-child(3) {
    border-color: var(--primary2-100);
    background-color: var(--primary2-100);
}

#service_top #section5 a:nth-child(3):hover {
    color: var(--primary2-100);
    background-color: var(--bg-100);
}

#service_top #section5 a:nth-child(4) {
    border-color: var(--primary3-100);
    background-color: var(--primary3-100);
}

#service_top #section5 a:nth-child(4):hover {
    color: var(--primary3-100);
    background-color: var(--bg-100);
}

/* section contact */
#service_top #section_contact h2 {
    font-size: 2.14rem;
}

#service_top #section_contact form {
    border-radius: 4px;
    background-color: var(--bg-200);
    margin: 4% 0 12%;
    padding: 7%;
}

#service_top #section_contact .category_block {
    position: relative;
}

#service_top #section_contact .category_block::after {
position: absolute;
    content: "\f0d7";
    color: var(--primary-100);
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 1.43rem;
    pointer-events: none;
    top: 20%;
    right: 4%;
}

#service_top #section_contact #category {
    width: 100%;
    background-color: var(--bg-100);
    font-size: 1.14rem;
    margin: 0 0 1.12%;
    padding: 2.22% 4.16%;
}

#service_top #section_contact #category option {
    width: 100%;
    font-size: 1.14rem;
}

#service_top #section_contact .mgmt_textarea {
    margin-bottom: 5%;
}


/* section6 */
#service_top #section6 {
    text-align: center;
    margin-bottom: 21.98%;
}

#service_top #section6 h2 {
    font-size: 2.14rem;
    margin: 0 0 6.66% 0;
}

#service_top #section6 p {
    font-size: 1.14rem;
    margin: 0 0 5.46% 0;
}

#service_top #section6 .sns_block.sp {
    display: flex;
    justify-content: center;
    margin: 10% 0 0;
}

#service_top #section6 .sns_block.sp a {
    display: flex;
    width: 9vw;
    height: 9vw;
    justify-content: center;
    align-items: center;
    margin: 0 2%;
}

#service_top #section6 .sns_block.sp a img {
    width: 8vw;
    height: 8vw;
    object-fit: contain;
    margin: auto;
}

/* ===== フッター ===== */
footer {
    background-color: var(--text-200);
    padding: 7.97% 0 2.42%;
}

footer p {
    color: var(--bg-100);
    font-size: 0.86rem;
    text-align: center;
}

@media screen and (min-width: 800px) {

    /* ===== 共通 ===== */
    html {
        font-size: 0.73vw;
        /* スクロール設定 */
        scroll-behavior: smooth;
        /* ページ内リンク　着地位置設定 */
        scroll-snap-type: y proximity;
        scroll-padding-top: 3vw;
    }

    body {
        /* 横スクロール防止 */
        overflow-x: clip;
    }

    .pc {
        display: block;
    }

    .sp {
        display: none;
    }

    .inview.fadeup {
        opacity: 0;
        transition-duration: .5s;
        transform: translateY(10px);
    }

    .inview.fadeup.active {
        opacity: 1;
        transform: translateY(0px);
    }

    /* ===== header ==== */
    header {
        height: 3.33vw;
        padding: 0.94vw 1.46vw;
    }

    header h1 .logo img {
        width: initial;
        height: 1.5vw;
    }

    /* ===== contents ===== */
    .container_wrap {
        background-image: url('/img/common/service_top/top_pc_background.png');
        background-repeat: no-repeat;
        background-size: cover;
        background-attachment: fixed;
        padding: 5vw 0 3vw;
    }

    /* left container */
    .container_wrap .left_container {
        position: fixed;
        top: 16vw;
        left: 9vw;
    }

    .container_wrap .left_container h2 img {
        height: 6.56vw;
    }

    .container_wrap .left_container .pc_account_register_button {
        display: block;
        color: var(--accent-200);
        font-size: 1.43rem;
        border: 0.12vw solid var(--bg-100);
        border-radius: 1vw;
        background-color: var(--bg-100);
        margin: 1.8vw 3vw 0;
        padding: 1.56vw 4.95vw;
    }

    .container_wrap .left_container .pc_account_register_button:hover {
        color: var(--bg-100);
        background-color: var(--primary-100);
    }

    .container_wrap .left_container .sns_block {
        display: flex;
        justify-content: center;
        margin: 0.8vw 0 0;
    }

    .container_wrap .left_container .sns_block a {
        display: flex;
        width: 3.7vw;
        height: 3.7vw;
        justify-content: center;
        align-items: center;
    }

    .container_wrap .left_container .sns_block a img {
        width: 2.08vw;
        height: 2.08vw;
        object-fit: contain;
        margin: auto;
    }

    /* right_container */
    .container_wrap .right_container {
        position: fixed;
        top: 13.32vw;
        right: 3vw;
    }

    .container_wrap .right_container nav {
        text-align: right;
        margin: 0 4vw 4vw 0;
    }

    .container_wrap .right_container nav ul li {
        margin: 0 0 1vw;
    }

    .container_wrap .right_container nav ul li a {
        display: inline-block;
        position: relative;
        color: var(--bg-100);
        font-size: 1.43rem;
        padding: 0 0.1vw;
    }

    .container_wrap .right_container nav ul li a::after {
        position: absolute;
        content: "";
        height: 0.03vw;
        left: 0;
        bottom: -0.05vw;
        background-color: var(--bg-100);
        transform: scale(0, 1);
        transform-origin: right top;
        transition: transform 0.3s;
        width: 100%;
    }

    .container_wrap .right_container nav ul li a:hover::after {
        transform: scale(1, 1);
    }

    .container_wrap .right_container .top_back_button {
        position: absolute;
        right: 21vw;
        top: 27vw;
        width: 8vw;
        color: var(--bg-100);
        font-size: 1.2rem;
        font-weight: bold;
        line-height: 1.5rem;
        letter-spacing: 0.3rem;
        text-align: right;
        border-bottom: solid 0.15vw;
        transform: rotate(90deg);
        padding: 0 1vw 0 0;
    }

    .container_wrap .right_container .top_back_button::before {
        content: "";
        display: block;
        position: absolute;
        bottom: -0.13vw;
        left: 0;
        width: 0.8vw;
        border-top: solid 0.15vw;
        transform: rotate(-35deg);
        transform-origin: left top;
    }

    .container_wrap .right_container .mobile_access {
        text-align: center;
    }

    .container_wrap .right_container .mobile_access p {
        position: relative;
        color: var(--bg-100);
        font-size: 1.43rem;
        margin: 0 0 0.8vw;
    }

    .container_wrap .right_container .mobile_access p::before,
    .container_wrap .right_container .mobile_access p::after {
        content: "";
        height: 90%;
        width: 0.05vw;
        background-color: var(--bg-100);
        position: absolute;
        bottom: 0;
    }

    .container_wrap .right_container .mobile_access p::before {
        left: 2.8vw;
        transform: rotate(-30deg);
    }

    .container_wrap .right_container .mobile_access p::after {
        right: 2.8vw;
        transform: rotate(30deg);
    }


    .container_wrap .right_container .mobile_access .upper_text::after {
        content: "\A";
        white-space: pre;
    }

    .container_wrap .right_container .mobile_access img {
        height: 10.53vw;
    }


    #service_top {
        width: 23.44vw;
        border-radius: 4vw;
        background-color: var(--bg-100);
        margin: 0 0 0 45.93vw;
        padding: 0;
    }

    #service_top #section1 .top_image_container {
        padding-top: 4vw;
        background-position: -400% 250%, 500% -70%;
    }

    #service_top #section6 .copyright {
        color: var(--primary-100);
        margin-top: 20%;
    }



    /* ===== pc用サイズ調整 ===== */
    #service_top #section1 .top_image_container .top_text {
        height: 18vw;
    }

    #service_top #section1 .top_image_container .top_app {
        height: 18vw;
    }

    #service_top #section2 iframe {
        height: 9.92vw;
    }

    #service_top #section3 .service_container {
        height: 17.45vw;
    }

    #service_top #section3 .service_container img {
        height: 8vw;
    }

    #service_top #section4 img {
        height: 9.38vw;
    }

    #service_top #section6 .sns_block.sp a {
        width: 2.5vw;
        height: 2.5vw;
    }
    
    #service_top #section6 .sns_block.sp a img {
        width: 2vw;
        height: 2vw;
    }

    #service_top #section6 {
        margin-bottom: 0;
        padding-bottom: 5%;
    }
}