/* ======================================================================
/* root
====================================================================== */
:root {
    --color-black: #333333;
    --color-white: #ffffff;
    --color-gray: #f8f8f8;
    --color-theme: #00a9c8;
    --color-light-blue: #cbf7ff;
    --color-green: #34ab8d;
}

/* ======================================================================
/* html
====================================================================== */
html {
    overflow-y: scroll;
    overflow-x: hidden;
    scroll-behavior: smooth;
    scroll-padding-top: 120px;
}

/* ======================================================================
/* body
====================================================================== */
body {
    inline-size: 100%;
    block-size: auto;
    font-size: 16px;
    font-family: 'Hiragino Kaku Gothic ProN', 'Hiragino Sans';
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-black);
    word-break: break-all;
    letter-spacing: 1px;
}

@media screen and (width <=768px) {
    body {
        font-size: 14px;
    }
}

/* ======================================================================
/* fonts
====================================================================== */
.Hiragino-Maru {
    font-family: 'ヒラギノ丸ゴ Pro W4', 'ヒラギノ丸ゴ Pro',
        'Hiragino Maru Gothic Pro';
}

/* ======================================================================
/* ul ol
====================================================================== */
ul,
ol {
    margin: 0;
    padding: 0;

    & li {
        list-style-type: none;
    }
}

/* ======================================================================
/* a
====================================================================== */
a {
    text-decoration: none;

    &:link {
        color: var(--color-black);
    }

    &:hover {
        opacity: 0.8;
    }

    &:visited {
        color: var(--color-black);
    }

    &:active {
        color: var(--color-black);
    }
}

a.c-header-button,
a.p-global-nav__link-btn {
    color: #ffffff;
}

/* ======================================================================
/* img
====================================================================== */
img {
    display: block;
    margin: 0 auto;
    max-inline-size: 100%;
    vertical-align: bottom;
}

/* ======================================================================
/* inner
====================================================================== */
.inner {
    max-inline-size: 1080px;
    margin: 0 auto;
}

@media screen and (width <=768px) {
    .inner {
        inline-size: 100%;
        block-size: auto;
        padding-inline: 15px;
    }
}

/* ======================================================================
/* #secFv
====================================================================== */
#secFv {
    position: relative;
    inline-size: 100%;
    block-size: auto;
    margin-top: 65px;

    & img {
        inline-size: 100%;
    }
}

@media screen and (width <=768px) {
    #secFv {
        margin-block-start: 70px;
    }
}

/* ======================================================================
/* #secIndex
====================================================================== */
#secIndex {
    inline-size: 100%;

    & .bg-lightBlue {
        inline-size: 800px;
        margin: 0 auto;
        padding: 50px;
        background: var(--color-light-blue);

        & h1 {
            position: relative;
            font-size: 32px;
            font-weight: bold;
            text-align: center;
            padding-block-end: 20px;
            margin-block-end: 40px;
            border-block-end: solid 2px var(--color-theme);
        }

        & dl {
            display: flex;
            align-items: center;
            gap: 20px;
            margin-block-end: 30px;
            font-size: 26px;

            &:last-of-type {
                margin: 0;
            }

            & dt {
                display: grid;
                place-items: center;
                padding: 0 8px;
                color: var(--color-white);
                background: var(--color-theme);
                border-radius: 4px;
            }

            & dd {
                font-weight: bold;
            }
        }
    }
}

@media screen and (width <=768px) {
    #secIndex {
        & .bg-lightBlue {
            inline-size: 100%;
            padding: 10px;

            & dl {
                font-size: 16px;
                gap: 20px;
                margin-block-end: 20px;

                &:last-of-type {
                    margin: 0;
                }

                & dt {
                    inline-size: 30px;
                }

                & dd {
                    inline-size: calc(100% - 30px);
                }
            }
        }
    }
}

/* ======================================================================
/* #secAnchor_01
====================================================================== */
#secAnchor_01 {
    margin-block: 150px 0;
}

@media screen and (width <=768px) {
    #secAnchor_01 {
        margin-block: 40px 0;
    }
}

/* ======================================================================
/* #secAnchor_02
====================================================================== */
#secAnchor_02 {
    margin-block: 150px 0;
}

@media screen and (width <=768px) {
    #secAnchor_02 {
        margin-block: 40px 0;
    }
}

/* ======================================================================
/* #secAnchor_03
====================================================================== */
#secAnchor_03 {
    margin-block: 150px 0;

    & .bg-green {
        position: relative;
        inline-size: 100%;
        block-size: 187px;
        background: var(--color-green);

        & img {
            position: absolute;
            top: -28%;
            left: 50%;
            transform: translate(-50%, 0);
        }
    }
}

@media screen and (width <=768px) {
    #secAnchor_03 {
        margin-block: 40px 0;

        & .bg-green {
            max-block-size: 81px;

            & img {
                position: absolute;
                top: -9px;
                left: 50%;
                transform: translate(-50%, 0);
            }
        }
    }
}

/* ======================================================================
/* #secAnchor_04
====================================================================== */
#secAnchor_04 {
    margin-block: 150px 0;

    & .bg-blue {
        position: relative;
        inline-size: 100%;
        block-size: 187px;
        background: var(--color-theme);

        & img {
            position: absolute;
            top: -28%;
            left: 50%;
            transform: translate(-50%, 0);
        }
    }
}

@media screen and (width <=768px) {
    #secAnchor_04 {
        margin-block: 40px 0;

        & .bg-blue {
            max-block-size: 81px;

            & img {
                top: -9px;
                left: 50%;
                transform: translate(-50%, 0);
            }
        }
    }
}

/* ======================================================================
/* #secAnchor_05
====================================================================== */
#secAnchor_05 {
    margin-block: 150px 0;
}

@media screen and (width <=768px) {
    #secAnchor_05 {
        margin-block: 40px 0;
    }
}

/* ======================================================================
/* #secAnchor_06
====================================================================== */
#secAnchor_06 {
    margin-block: 150px 0;
}

@media screen and (width <=768px) {
    #secAnchor_06 {
        margin-block: 40px 0;
    }
}

/* ======================================================================
/* #secAnchor_07
====================================================================== */
#secAnchor_07 {
    margin-block: 150px 0;
}

@media screen and (width <=768px) {
    #secAnchor_07 {
        margin-block: 40px 0;
    }
}

/* ======================================================================
/* floating
====================================================================== */
.floating {
    position: fixed;
    right: 50px;
    bottom: 50px;
    z-index: 9999;
    inline-size: 150px;
    block-size: auto;

    & .is-close {
        position: absolute;
        top: 10px;
        left: 10px;
        inline-size: 25px;
        height: auto;
        cursor: pointer;
    }
}

@media screen and (width <=768px) {
    .floating {
        inline-size: 125px;
        right: 0;
        bottom: 50px;
        transform: translate(0, 0);

        & .is-close {
            position: absolute;
            top: 15px;
            left: 10px;
            inline-size: 25px;
        }
    }
}

/* ======================================================================
/* top
====================================================================== */
.top {
    position: fixed;
    bottom: 15px;
    right: 100px;

    & img {
        inline-size: 32px;
        block-size: 32px;
    }
}

@media screen and (width <=768px) {
    .top {
        position: fixed;
        bottom: 15px;
        right: 50px;
    }
}
