@charset "UTF-8";

/*
Theme Name: Nikoriha-wp
Author: 株式会社Compass
Version: 20260206
*/

/*レイヤー宣言*/
@layer reset, page-base;
@import url(css/reset.css) layer(reset);

@layer page-base {
    *:where(:not(#wpadminbar *)) {
        color: var(--color-p);
        border-color: #cccccc;
        font-family: YakuHanRP, "Zen Maru Gothic", sans-serif;
        font-size: clamp(12px, calc(8.8px + 0.8vw), 16px);
        font-weight: 500;
        font-variant-east-asian: proportional-width;
        letter-spacing: .05em;
        line-height: 1.5;
        text-wrap: wrap;
        max-inline-size: none;
    }

    html {
        scroll-behavior: smooth;
    }

    body {
        position: relative;
        overflow-x: hidden;
    }

    main {
        position: relative;
    }

    section {
        container-name: nikoriha-section;
        container-type: inline-size;
    }

    h1,
    h2,
    h3,
    h4,
    h5,
    h6 {
        font-weight: bold;
    }

    h1 {
        font-size: 36px;
    }

    h2 {
        font-size: clamp(22px, calc(18.8px + 0.8vw), 26px);
        text-align: center;

        &:has(img) {
            margin-top: 40px;
        }

        img {
            width: 75px;
        }
    }

    h3 {
        font-size: clamp(20px, calc(16.8px + 0.8vw), 24px);
        margin-bottom: .75em;
    }

    h4 {
        font-size: clamp(14px, calc(12.5px + 0.5vw), 18px);
        margin-bottom: .5em;
    }

    p {
        font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
        line-height: 1.5;
        margin-bottom: 1em;
    }

    strong {
        font-weight: bold;
    }

    sup {
        background-color: inherit;
        padding: 0;
        margin-left: 0;
        font-size: 0.75em;
        font-weight: inherit;
    }

    :where(ol, ul) {
        padding-inline-start: 1em;
    }

    ul {
        list-style-type: none;
    }

    a {
        text-decoration-line: none;
    }

    img {
        /*参考: https://coliss.com/articles/build-websites/operation/css/sensible-defaults-for-img-elements.html */
        max-width: 100%;
        height: auto;
        vertical-align: middle;
        font-style: italic;
        background-repeat: no-repeat;
        background-size: cover;
        shape-margin: 0.75rem;
        margin: auto;
    }

    table {
        width: 100%;
        margin: 40px auto;

        tr {
            border-top: 1px solid #040000;
            border-bottom: 1px solid #040000;

            th {
                text-align: center;

                &:first-of-type {
                    word-break: keep-all;
                    text-wrap: nowrap;
                    text-align: center;
                }
            }
        }

        th,
        td {
            padding: 20px 1em;
        }

        .button-flame {
            width: fit-content;
            margin-top: 10px;
        }
    }

    hr {
        border: 1px dotted #4AC1F1;
    }


    .container {
        padding: 40px 2em;
        margin: 0 auto;
        max-width: 1080px;
        overflow: hidden;
    }

    .sp-none,
    .tb-none {
        display: none;
    }

    .center {
        text-align: center;
    }

    .text-fit {
        width: fit-content;
        margin: auto;
    }

    .warning {
        color: #E83A29;
        font-weight: bold;
    }

    .price-num {
        font-size: clamp(22px, calc(18.8px + 0.8vw), 26px);
    }

    .marker {
        font-weight: bolder;
        text-decoration: underline;
        text-decoration-thickness: 0.6em;
        text-decoration-color: #FFBAE1;
        text-underline-offset: -0.4em;
        text-decoration-skip-ink: none;
    }

    .cols {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: flex-start;

        &>div {
            width: 100%;
            margin: 40px 0 0;
        }
    }

    .cols.reverse {
        flex-direction: row-reverse;
    }

    .button-flame {
        margin: 0 auto;

        a {
            display: block;
            width: 100%;
            padding: 10px 20px;
            border: 1px solid #4AC1F1;
            border-radius: 10px;
            text-align: center;
        }

        &.more {
            width: 200px;

            a::after {
                content: "\f105";
                font-family: "Font Awesome 6 Free";
                font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
                font-weight: 900;
                color: #4AC1F1;
                padding-left: 5px;
            }
        }

        &.insta {
            width: fit-content;

            a {
                background-color: #AD3BDB;
                color: #ffffff;
            }
        }
    }

    .flow-img {
        display: block;
        margin: auto;
        width: 100%;
        max-width: 740px;
    }

    .for-non-image {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip-path: circle(100%);
        white-space: nowrap;
        border-width: 0;
        left: -100vw;
    }

    /*header*/
    header {
        width: 100%;
        padding: 20px 30px;
        position: sticky;
        z-index: 1;
        top: 0;
        /* overflow-x: clip; */
        background: #ffffff;
        box-shadow: 0px 0px 5px #333333;

        .container {
            padding: 0;
            margin: 0 auto;
            /*max-width: 1200px;*/
        }

        .header-main {
            display: flex;
            justify-content: space-between;
            align-items: start;
            flex-wrap: wrap;
        }

        .header-logo {
            width: 120px;
            background-color: var(--main-color);

            img {
                width: 100%;
                display: block;
            }
        }

        .header-actions {
            display: flex;
            align-items: center;
            gap: 10px;

            img {
                width: 50px;
            }

            .action-item {
                position: relative;
                top: 35px;
            }
        }

        #menu-button {
            display: none;

            &:checked~.hamburger {
                span:nth-child(1) {
                    transform: translateY(17px) rotate(45deg);
                }

                span:nth-child(2) {
                    opacity: 0;
                }

                span:nth-child(3) {
                    transform: translateY(-10px) rotate(-45deg);
                }
            }

            &:checked~.header-nav {
                display: block;
                right: 0;
                opacity: 1;
            }
        }

        .hamburger {
            width: 40px;
            height: 30px;
            cursor: pointer;
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            z-index: 100;
            position: relative;
            top: 35px;

            span {
                display: block;
                width: 100%;
                height: 3px;
                background-color: #000;
                transition: all 0.3s;
            }
        }

        .sub-toggle {
            display: none;
            /* チェックボックスは隠す */
        }

        .sub-label {
            display: block;
            padding: 15px;
            cursor: pointer;
            position: relative;
            font-weight: bold;
        }

        /* スマホ時：プラン内容の横に▼マークを表示 */
        .sub-label::after {
            content: '▼';
            font-size: 10px;
            margin-left: 8px;
            display: inline-block;
            transition: transform 0.3s;
        }

        /* サブメニュー初期状態（スマホ：非表示） */
        .sub-menu {
            display: none;
            list-style: none;
            background-color: var(--sub-bg);
            padding-left: 20px;

            li a {
                font-size: 14px;
                padding: 12px 15px;
                border-bottom: 1px solid #ddd;
            }
        }

        /* スマホ：チェックが入ったら表示、▼を回転 */
        .sub-toggle:checked~.sub-menu {
            display: block;
        }

        .sub-toggle:checked~.sub-label::after {
            transform: rotate(180deg);
        }

        .header-nav {
            /*display: none;*/
            position: absolute;
            top: 100%;
            right: -100%;
            opacity: 0;
            transition: 1s ease all;
            width: 100%;
            z-index: 99;
            background-color: #ffffff;

            ul {
                list-style: none;
                padding: 0;
                margin: 0 auto;

                li {
                    border-bottom: 1px solid #eee;

                    a,
                    label {
                        display: block;
                        padding: 15px;
                        text-decoration: none;
                        color: var(--text-color);
                        font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
                        font-weight: 500;
                    }
                }
            }
        }
    }

    footer {
        position: relative;
        background: #4AC1F1;

        * {
            color: #ffffff;
            font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
            line-height: 2;
        }

        /*.container {
            max-width: 1200px;
        }*/

        .cols {
            justify-content: space-between;
        }

        .footer-logo {
            margin: 30px auto 0;

            a {
                display: block;
                margin: 0 auto;
                width: 200px;
            }

            img {
                width: 100%;
            }
        }

        .subcols {
            margin-bottom: 40px;
        }

        .footer-menu {
            margin-top: 0;

            .footer-menu-sub {
                padding-top: 0;
                list-style-type: square;
            }
        }

        .copyright p {
            text-align: center;
            margin-bottom: 0;
        }
    }

    main {
        ul {
            list-style-type: square;
            margin-bottom: 20px;

            li::marker {
                color: #4AC1F1;
            }
        }

        .container {
            width: 90%;
            margin: 0 auto;
        }
    }

    #kv {
        height: 250px;
        margin-top: 160px;
        position: relative;
        background-position: center;
        background-size: cover;

        h2 {
            width: fit-content;
            background-color: #ffffff;
            place-self: center;
            padding: 5px;
        }

        .container {
            height: 100%;
            display: grid;
        }

        .front-page & {
            background-image: url(img/front/kv.jpg);
            height: 400px;
        }

        .saikai & {
            background-image: url(img/kv/saikai.jpg);
        }

        .shokugyou & {
            background-image: url(img/kv/shokugyou.jpg);
        }

        .ninchishou & {
            background-image: url(img/kv/ninchishou.jpg);
        }

        .hyouka & {
            background-image: url(img/kv/hyouka.jpg);
        }

        .contact &,
        .thanks & {
            background-image: url(img/kv/contact.jpg);
        }

        .mailform & {
            background-image: url(img/kv/mailform.jpg);
        }

        .price-info & {
            background-image: url(img/kv/price-info.jpg);
        }

        .privacy & {
            background-image: url(img/kv/privacy.jpg);
        }

        .not-found & {
            background-image: url(img/kv/404.jpg);
        }

        .default & {
            background-image: url(img/kv/default.jpg);
        }
    }

    #breadcrumb {
        * {
            font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
        }

        a {
            color: #4AC1F1;
        }

        ul {
            list-style: none;
        }

        li {
            display: inline;

            &+li:before {
                content: "-";
                margin: .5em;
            }
        }
    }

    #plan-about {
        h2 {
            border-bottom: 3px solid #B4C8D1;
            border-left: 10px solid;
            text-align: left;
            padding-left: .5em;
            margin-top: 0;
            margin-bottom: 10px;
            /*font-size: clamp(22px, calc(18.8px + 0.8vw), 26px);*/

            .saikai & {
                border-left-color: #FF7F00;
            }

            .shokugyou & {
                border-left-color: #3C976E;
            }

            .ninchishou & {
                border-left-color: #AD3BDB;
            }

            .hyouka & {
                border-left-color: #005AA5;
                word-break: keep-all;
            }
        }

        .left {
            margin-top: 0;
        }

        .right {
            img {
                display: block;
                width: 100%;
            }
        }
    }

    #check {
        background-color: #F2F9FF;
    }

    #point {
        .cols {
            img {
                display: block;
                width: 100%;
                max-width: 400px;
            }
        }

        .point-text {
            padding: 10px 0;
            background-image: url(img/plan/point-bg.png);
            background-position: 0 0;
            background-size: 50px 50px;
            background-repeat: no-repeat;

            h3 {
                font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
                padding-bottom: 10px;
                text-align: center;
                word-break: keep-all;
            }
        }
    }

    #to-contact {
        background: #C7EEFF;

        h3 {
            margin: 0;
            text-align: center;
            font-size: clamp(18px, calc(14.8px + 0.8vw), 22px);
        }

        a {
            display: block;
            max-width: 200px;
            margin: auto;
        }

        p:last-of-type {
            margin-bottom: 0;
        }

        .button-desc {
            text-align: center;
            word-break: keep-all;
        }

        .marker {
            text-decoration: initial;
            background-color: #ffffff;
        }

        .contact-box {
            background: #ffffff;
            padding: 30px;
            border-radius: 20px;

            hr {
                border: 1px solid #cccccc;
            }

            &.to-line a {
                max-width: 80px;
            }
        }
    }

    @container nikoriha-section (width >=1120px) {
        .container {
            padding: 40px 0;
        }
    }
}

/*index*/
.front-page {
    #kv {
        h2 {
            padding: 20px;
            background-color: rgb(74, 193, 241, 0.8);
            text-shadow: rgba(67, 90, 255, 0.75) 0px 0px 2px;
            color: #ffffff;
            font-size: clamp(20px, calc(10px + 2.5vw), 40px);
            text-align: left;
            position: absolute;
            top: 50%;
            justify-self: left;
        }
    }

    #about {
        .cols {
            justify-content: space-between;
        }
    }

    #plan {

        h3,
        h4 {
            text-align: center;
        }

        .cols {
            img {
                display: block;
                margin: 0 auto 20px;
                width: 100%;
                max-width: 300px;
            }
        }

        .st-1 {
            color: #FF7F00;
        }

        .st-2 {
            color: #3C976E;
        }

        .st-3 {
            color: #AD3BDB;
        }

        .st-4 {
            color: #005AA5;
        }
    }

    #instagram {
        .insta-dummy {
            justify-content: space-between;

            img {
                display: block;
                width: 200px;
                height: 200px;
                margin: 20px auto;
                background-color: paleturquoise;
            }
        }
    }
}

/*運転再開リハビリプラン*/
.saikai {
    #price {
        background-color: #F2F9FF;
    }
}

/*職業運転手向けプラン*/
.shokugyou {
    #service {
        .cols {
            justify-content: space-evenly;
        }

        .img-box {
            width: 100%;

            .img-title {
                text-align: center;
                -webkit-text-stroke: 0.3px #ffffff;
                font-weight: bold;
                word-break: keep-all;
                background-image: url(img/heart-bg.png);
                background-position: center;
                background-size: contain;
                background-repeat: no-repeat;
                margin-bottom: 0;
                padding: .5em 0;
            }

            img {
                display: block;
                width: 100%;
                max-width: 400px;
                margin: auto;
            }
        }
    }

    #point {
        .point-text {
            padding: 10px;
        }

        .right {
            img {
                width: 100%;
                max-width: 400px;
                margin: auto;
            }
        }
    }

    #schedule {
        background-color: #F2F9FF;
    }
}

/*認知症予防プラン*/
.ninchishou {
    #price {
        background-color: #F2F9FF;

        .goriyou-hindo {
            width: fit-content;
            padding: 20px;
            margin-bottom: 20px;
            background-color: #ABE6FF;
            border-radius: 20px;

            p {
                background-color: #ffffff;
                padding: 10px 20px;
                border-radius: 20px;
                margin-bottom: 0;
            }

            span {
                color: #4674D1;
            }
        }

        .shokai {
            background-color: #ffffff;
            border: 3px solid #FF5FF8;
            border-radius: 20px;
            padding: 0 30px;
            margin-top: 50px;
            position: relative;

            img {
                width: 100%;
                max-width: 260px;
                margin-top: -45px;
            }

            .marker {
                -webkit-text-stroke: 0.5px #ffffff;
            }

            .price-num {
                font-weight: inherit;
            }
        }
    }
}

/*運転に必要な認知機能・高次脳機能評価プラン*/
.hyouka {
    #plan-about {
        h3 {
            word-break: keep-all;
        }
    }

    #point {
        background-color: #F2F9FF;

        p {
            margin-bottom: 0;
        }

        .point-text {
            padding: 10px;
        }
    }
}

/*お問い合わせ*/
.contact,
.mailform {
    #to-contact {
        background-color: #ffffff;

        .container {
            background-color: #C7EEFF;
            border-radius: 20px;
            margin-bottom: 80px;
            padding: 40px 2em;
        }
    }
}

.mailform {
    form {
        container-name: nikoriha-form;
        container-type: inline-size;

        p {
            margin-bottom: 0;

            &+.wpcf7-form-control-wrap {
                margin-bottom: 1em;
                display: block;

                input,
                textarea {
                    padding: 5px .5em;
                    width: 100%;
                    border-radius: 10px;
                }
            }
        }

        input[type="text"].js-readonly,
        input[type="tel"].js-readonly,
        input[type="email"].js-readonly,
        textarea.js-readonly {
            background: #eeeeee;
        }

        .radio-wrapper {
            margin-bottom: 1em;

            a {
                display: inline;
                color: #4F61E2;
                text-decoration: underline #4F61E2;
            }
        }

        .hissu,
        .nini {
            font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
            color: #ffffff;
            padding: 2px 5px;
            display: inline-block;
            margin-bottom: 10px;
            margin-right: .5em;
            border-radius: 5px;
        }

        .hissu {
            background-color: #E83A29;
        }

        .nini {
            background-color: #4F61E2;
        }

    }

    .button-flame {
        width: 100%;
        margin-bottom: 20px;
        border: none;

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

        .wpcf7-spinner {
            display: none;
            margin: 0 auto;
        }
    }

    .container>p {
        margin-bottom: revert;
    }

    .wpcf7-list-item {
        margin-left: 0;
    }

    .wpcf7-radio {
        .wpcf7-list-item {
            display: block;
            padding: 5px .5em;
            margin-bottom: 10px;
            border-radius: 10px;
            background-color: #ffffff;
        }
    }

    .kakunin {
        display: grid;

        &>* {
            grid-area: 1/1;
            visibility: visible;
            opacity: 1;
            display: flex;
            flex-wrap: wrap;
            justify-content: space-between;
        }

        &>[aria-hidden="true"] {
            opacity: 0;
            visibility: hidden;
            display: none;
            z-index: -1;
            pointer-events: none;
        }

        input {
            text-align: center;
            width: 100%;
            padding: 20px;
            border-radius: 7px;
            border: none;
            border-bottom: 4px solid #3a5ca1;
            font-family: "Font Awesome 6 Free", "Zen Maru Gothic", sans-serif;
            color: #ffffff;
            background-color: #4674d1;
        }
    }

    .js-read-only {
        pointer-events: none;
        cursor: not-allowed;
        user-select: none;

        .wpcf7-list-item {
            background: #eeeeee;
        }
    }
}

.thanks {
    a {
        color: #4AC1F1;
    }
}

/*料金案内*/
.price-info {
    .table-scroll {
        overflow-x: scroll;
    }

    .center.warning {
        margin-bottom: 0;
    }

    table {
        width: 100%;
        min-width: 1200px;

        tr,
        th {
            border: none;
        }

        tr {
            &:nth-of-type(2) th {
                background-color: #F7F4F0;
            }

            &:last-of-type th {
                background-color: #E6E3DF;
            }
        }

        td {
            border: 1px solid #B0ADAB;
            border-collapse: collapse;
            vertical-align: top;

            li,
            p {
                font-size: clamp(13px, calc(11.875px + 0.375vw), 16px);
            }

            strong,
            span {
                &:not(.price-num) {
                    font-size: inherit;
                }
            }

            p:last-of-type {
                margin-bottom: 0;
            }
        }


        img {
            width: 100%;
        }

        .plan-head {
            th {
                color: #ffffff;
                vertical-align: bottom;
            }

            th:nth-of-type(2n) {
                background-color: #4674D1;
            }

            th:nth-of-type(2n+1) {
                background-color: #4174FF;
            }

            th:first-of-type {
                background-color: #E6E3DF;
                color: inherit;
                vertical-align: middle;
            }
        }

        .table-name {
            color: inherit;
        }

        .button-flame a {
            border: 1px solid #ffffff;
            padding: 5px 10px;
        }

        .price-num {
            font-size: clamp(16px, calc(12.8px + 0.8vw), 20px);
            font-weight: inherit;
        }
    }
}

/*プライバシーポリシー*/
.privacy {
    h2 {
        margin-bottom: 1em;
    }

    ol {
        list-style-type: decimal;
        padding-inline-start: 1.5em;
        margin-bottom: 20px;
    }

    a {
        color: #4AC1F1;
    }
}

/*Not Found*/
.not-found {
    a {
        color: #4AC1F1;
    }
}

@media (min-width: 600px) {
    .mailform {
        .wpcf7-radio {
            .wpcf7-list-item {
                display: inline-block;
                margin-bottom: 0;
            }
        }

        .wpcf7-list-item:not(:first-of-type) {
            margin-left: 1em;
        }

        .button-flame {
            width: fit-content;
            margin-bottom: 0;
        }


        .kakunin {
            display: grid;

            &>[aria-hidden="true"] {
                display: flex;
            }
        }
    }
}

@media (min-width: 900px) {
    @layer page-base {
        .cols {
            justify-content: space-around;
            align-items: stretch;

            .left,
            .right {
                width: 45%;
            }
        }

        .cols.reverse {
            flex-direction: row-reverse;
        }

        header {
            .container {
                overflow: visible;
            }

            .header-actions {
                /* 重要：この要素自体のボックスを無視し、子要素を .header-main の直下に配置したかのように扱う */
                display: contents;

                /* ボタン類（.action-item）の設定 */
                .action-item {
                    display: flex;
                    flex-direction: column;
                    align-items: center;
                    margin-left: 20px;
                    top: 0;

                    img {
                        width: 160px;
                    }

                    p {
                        font-size: 10px;
                        margin: 0 auto;
                        text-align: center;
                    }
                }
            }

            .header-logo {
                /* ロゴを左端に固定し、残りのスペースをボタンに譲る */
                margin-right: auto;
            }


            /* メニュー（.main-nav）の設定 */
            .header-nav {
                display: block;
                position: static;
                /* 強制的に100%幅にすることで、ロゴやボタンの列の下へ回り込ませる */
                width: 100%;
                margin-top: 20px;
                opacity: 1;

                ul {
                    display: flex;
                    justify-content: space-between;

                    li {
                        flex: 1;
                        border-left: 1px solid #00aecf;
                        border-bottom: none;
                        text-align: center;
                        position: relative;

                        &:last-child {
                            border-right: 1px solid #00aecf;
                        }

                        a,
                        .sub-label {
                            display: block;
                            padding: 0;
                            text-align: center;
                            text-decoration: none;
                        }

                        /*add start20260409*/
                        .sub-label {

                            position: absolute;
                            height: 44px;
                            top: 0;
                            width: 100%;
                        }

                        .sub-label:hover .sub-menu {
                            display: block;
                        }

                        /*add end*/
                    }
                }

                /* PC：サブメニューのレイアウト（浮いた状態） */
                .sub-menu {
                    display: none;
                    position: absolute;
                    top:
                        /*100%*/
                        44px;
                    left: 0;
                    width: 250px;
                    background: #fff;
                    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
                    z-index: 1000;
                    padding: 0;
                    border: 1px solid #00aecf;

                    li {
                        border: none;
                        border-bottom: 1px solid #eee;
                        text-align: left;

                        a {
                            text-align: left;
                            padding: 12px 15px;
                            white-space: normal;
                            line-height: 1.4;

                            &:hover {
                                background-color: aliceblue;
                            }
                        }
                    }
                }
            }

            /* デスクトップではハンバーガーを隠す */
            .hamburger,
            #menu-button {
                display: none;
            }

            /* PC：ホバーで表示する設定 */
            .header-sub {
                &:hover .sub-menu {
                    display: block;
                }

                .sub-label::after {
                    display: none;
                    /* PCでは矢印不要なら隠す */
                }
            }
        }

        .sp-none {
            display: block;
        }

        .pc-none {
            display: none;
        }

        footer {

            .footer-logo,
            .subcols,
            .footer-menu {
                width: fit-content;
            }

            .footer-logo {
                margin-left: 0;
            }

            /*.footer-menu {
                width: fit-content;
            }*/
        }

        /*#kv {
            height: 400px;
        }*/

        #plan-about {
            .right {
                margin-top: 0;
            }
        }

        #to-contact {

            .cols {
                justify-content: space-around;
                align-items: stretch;
            }

            .contact-box {
                width: 45%;

                /*a {
                    max-width: 280px;
                }

                &.to-line a {
                    max-width: 110px;
                }*/
            }
        }

        #point {
            justify-content: space-around;

            .point-box {
                width: 30%;
            }
        }
    }

    .front-page {
        #about {
            .left {
                width: 50%;
            }
        }

        #profile {
            .left {
                width: 30%;
            }

            .right {
                width: 60%;
            }
        }

        #plan {
            .cols {
                align-items: stretch;
            }

            .plan-box {
                width: 46%;
            }
        }

        #instagram {
            .insta-dummy {
                img {
                    display: block;
                    width: 250px;
                    height: 250px;
                }
            }
        }
    }

    .shokugyou {
        #service {
            .img-box {
                width: 30%;
            }
        }

        #point {
            background-color: #F2F9FF;

            .cols {
                width: fit-content;
                margin: auto;
            }

            .right,
            .left {
                width: fit-content;
            }
        }
    }

    /* 富本追加 */
    #kv {
        margin-top: 204px;
    }

    footer .footer-menu {
        padding-left: 1em;
    }

    footer .footer-menu * {
        line-height: 1.5 !important;
        margin-bottom: .5em;
    }

    /* 〆 富本追加 */
}