@charset "utf-8";
/*
Theme Name: rex-kaitai
Theme URI: https://rex-kaitai.jp/
Description: pcbrain
Version: 1.0
Author: pcbrain.co.jp
*/

/* YUI fonts.css - font size設定
----------------------------------------------------------- */
@import url("css/cssfonts-min.css");

/* default style - リセット及びbody基本設定
----------------------------------------------------------- */
@import url("css/default.css");

/* all style
----------------------------------------------------------- */
@import url("css/style.css");
@import url("setting.css");

:root {
    --header-height: 142px;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: var(--header-height);
}

body {
    font-size: 16px;
    -webkit-text-size-adjust: 100% !important;
}

.inner {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    position: relative;
    padding: 0 15px;

    @media (min-width:1200px) {
        padding: 0;
    }

}
.taxSelect {
    .active {
        position: relative;

        &::before {
            content: "";
            display: block;
            background-color: var(--sub-color01);
            width: 100%;
            height: 5px;
            position: absolute;
            inset: 0 0 0 auto;
            border-bottom:1px solid #fff;

        }
    }
}
a:link,
a:visited {
    text-decoration: none;
    transition: 0.3s;
}

a.btn,
a .btn,
.btn a {
    text-decoration: none;
    background: var(--main-color02);
    color: var(--white);
    transition: color 0.3s ease;
}

.btn {
    position: relative;
    text-decoration: none !important;
    display: inline-block;
}

.btnC,
.btnR {
    margin-top: 5px;
    margin-bottom: 10px;
}

.btnC {
    text-align: center !important;
}

.btnR {
    text-align: right !important;
}

.btnC a,
.btnR a,
.btn a,
a .btn {
    background: var(--main-color02);
    color: var(--white) !important;
    position: relative;
    text-align: center;
    text-decoration: none !important;
    display: inline-block;
    font-weight: 600;
    padding: 5px 50px 5px 50px;
    min-width: 240px;
    transition: all 0.3s ease;
    border-radius: 100vh;
}

/*
.btnC a::after,
.btnR a::after,
.btn a::after,
a .btn::after {
    position: absolute;
    content: "";
    top: 0;
    right: 15px;
    bottom: 0;
    margin: auto 0;
    display: block;
    width: 1em;
    height: 1em;
    font-size: 9px;
    border-right: 3px solid var(--main-color02);
    border-bottom: 3px solid var(--main-color02);
    transform: rotate(-45deg);
}
*/

.btnC a:hover,
.btnR a:hover,
.btn a:hover,
a .btn:hover {
    background: var(--sub-color02);
}

.btn:has(a.mapLink) {
    margin-top: 1rem;
}

a.mapLink {
    min-width: 0;
}

.btnColor01 a,
a.btnColor01 {
    background: var(--black) !important;
    color: var(--white) !important;
    transition: all 0.3s ease;
}

.btnColor01 a::after,
a.btnColor01::after {
    border-right: 3px solid var(--white) !important;
    border-bottom: 3px solid var(--white) !important;
}

.btnColor01 a:hover,
a.btnColor01:hover {
    background: var(--main-color02) !important;
}

.btnDetailR {
    margin-top: 5px;
    margin-bottom: 10px;
    text-align: right !important;
}

.btnDetailC {
    margin-top: 5px;
    margin-bottom: 10px;
    text-align: center;
}

.btnDetailR span,
.btnDetailR a,
.btnDetailC span,
.btnDetailC a {
    display: inline-block !important;
    border-radius: 100vh;
    font-size: 14px;
    text-align: center;
    font-weight: 600;
    line-height: 1.2;
    padding: 5px 40px 5px 15px;
    text-decoration: none !important;
    position: relative;
    color: var(--black) !important;
    transition: all 0.3s ease;
}

.btnDetailR span::after,
.btnDetailR a::after,
.btnDetailC span::after,
.btnDetailC a::after {
    position: absolute;
    content: "";
    top: 0;
    right: 15px;
    bottom: 0;
    margin: auto 0;
    display: block;
    width: 1em;
    height: 1em;
    font-size: 9px;
    border-right: 3px solid var(--main-color02);
    border-bottom: 3px solid var(--main-color02);
    transform: rotate(-45deg);
}

.btnDetailR span:hover,
.btnDetailR a:hover,
.btnDetailC span:hover,
.btnDetailC a:hover,
a:hover .btnDetailR span,
a:hover .btnDetailC span {
    color: var(--main-color02) !important;
}

.txtCenter {
    text-align: center;
}

.underline01 {
    text-decoration: underline;
    /* text-decoration-color: #ffde64; */
    text-decoration-color: var(--main-color01);
    text-decoration-thickness: 7px;
    text-underline-offset: -3px;
}

.underline02 {
    text-decoration: underline;
    text-decoration-color: var(--red);
    text-decoration-thickness: 7px;
    text-underline-offset: -3px;
}

.mkr-y {
    position: relative;
    background-image: linear-gradient(transparent 80%, #fdff5d 80%, #fdff5d 100%);
}

.lime {
    color: var(--main-color01) !important;
}

.tel span.tel-link {
    font-family: var(--en-font-family);
    font-weight: 600;
    font-size: clamp(27px, 9vw, 40px);
    line-height: 1;

    a:link,
    a:visited {
        color: var(--main-color02);
    }
}

.tel span.tel-link a:link,
.tel span.tel-link a:visited {
    text-decoration: none;    
}

.tel span.tel-open {
    font-size: 15px;
    font-family: 'Noto Sans JP', "メイリオ", "Meiryo", verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: 500;
    color: #222222;
    margin-bottom: .5em;
}

.tel img {
    vertical-align: baseline;
}

.en {
    font-family: 'Roboto', sans-serif;
}


.spinline {
    display: inline;

    @media (min-width:600px) {
        display: none;
    }
}

.sptr {
    display: table-row;

    @media (min-width:600px) {
        display: none;
    }
}

.spblock {
    display: block;

    @media (min-width:600px) {
        display: none;
    }
}

.spcut {
    display: none;

    @media (min-width:600px) {
        display: block;
    }
}

img {
    image-rendering: -webkit-optimize-contrast;
}

.cats a,
.cats span {
    display: inline-block;
    text-decoration: none;
    background: var(--main-color01);
    padding: 0px 20px;
    margin: 0 2px;
    font-size: 12px;
}

.cats a {
    color: var(--main-color02);
    background: var(--main-color01);
}

.cats span {
    background: #e8e8e8;
}

.time {
    display: block;
    color: var(--black);
    width: fit-content;
    font-size: 14px;
    font-weight: 400;
}

/* -----------------------------------------------------------
    header
----------------------------------------------------------- */
header#header {
    /*position: sticky;
    width: 100%;
    z-index: 50;
    top: 0;
    background: var(--white);*/
    position: relative;
}

#top header#header {
    /*
    background: rgba(255, 255, 255, 0);
    */
}

#top header#header::before {
    /*
    opacity: 0;
    transform: translateY(-100%);
    */
}

header#header::before {
    /*
    inset: 0;
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: var(--white);
    box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
    z-index: -1;
    transition: all 0.5s ease-in-out;
    */
}

#top.scrolled header#header::before {
    /*
    opacity: 1;
    transform: translateY(0);
    */
}

#top {}

header .htxt {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #f0f0f0;
    padding: 5px;
    color: var(--black);

    @media (min-width: 768px) {
        position: static;
        background-color: transparent;
        padding: 0;
    }
}

header .htxt .inner {
    padding: 0;
}

header .htxt h1,
header .htxt p {
    font-size: 11px;
    font-weight: 600;
    display: block;
    font-weight: 400;
    line-height: 1.2;

    @media (min-width: 1024px) {
        font-size: 14px;
    }
}

header .htxt p strong {
    font-weight: 400;
}

header .hdrLogo {
    max-width: 200px;

    @media (min-width: 768px) {
        max-width: 300px;
        margin-top: 15px;
    }

    @media (min-width: 1200px) {
        width: 309px;
        max-width: none;
    }
}

.hdrMedal {
    display: none;

    @media (min-width: 1000px) {
        display: block;
        width: 160px;
    }

    @media (min-width: 1400px) {
        width: auto;
    }
}

header .hdrLogo img {
    display: block;
    width: 100%;
    height: auto;
}

header .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    overflow: visible;
    padding: 38px 15px 15px 15px;
    gap: 15px;
    max-width: 1600px;

    @media (min-width: 768px) {
        padding: 5px 15px 5px 15px;
    }
}

header .inner .boxL {
    display: flex;
    align-items: center;
    gap: 30px;
}

header .inner .boxR {
    display: flex;
    align-items: center;
}

header .inner .hdrTelContact {
    display: flex;
    align-items: stretch;
    justify-content: flex-end;
    gap: 20px;
}

header .inner .hdrTel {
    display: none;

    @media (min-width:1000px) {
        display: flex;
        align-items: center;
        line-height: 1;
        background: var(--white);
        color: var(--black);
    }
}

header .inner .hdrTel .tel {
    font-size: 16px;
    color: var(--black);
}

header .inner .hdrTel .tel img {
    width: 32px;
    height: auto;
    display: inline-block;
    margin-top: 3px;
}

header .inner .hdrTel .tel-link {
    font-size: clamp(27px, 2.5vw, 40px);
    font-weight: bold;
    color: var(--sub-color01);
    display: flex;
    gap: 10px;
    align-items: center;
    text-decoration: none;

}

header .inner .hdrTel .tel-link::before {
    content: '';
    width: 27px;
    height: 28px;
    background: url(./img/ico_tel01.png) no-repeat center/cover;
}

header .inner .hdrTel .tel-open {
    font-size: 11px;
    font-weight: 500;
    letter-spacing: -0.05em;
    display: block;
    margin-top: 5px;

}

header .inner .hdrContact {
    display: flex;
    color: var(--white);
    font-size: 18px;
    font-weight: 500;
    background: var(--main-color02);
    align-items: center;
    justify-content: center;
    padding: 15px 20px;
    line-height: 1;
    text-decoration: none;
    transition: background-color 0.3s ease;
    border-radius: 5px;
    white-space: nowrap;

    @media (min-width:1400px) {

        width: 230px;
    }

}

header .inner .hdrContact:hover {
    background-color: var(--sub-color02);
}

header .inner .hdrContact img {
    margin-right: 1rem;
    vertical-align: text-bottom;
}

header .inner .hdrLine {
    background-color: #06c755;
}

header .inner .hdrLine img {
    width: auto;
    height: 48px;
}

/* -----------------------------------------------------------
    nav
----------------------------------------------------------- */

#gNav {
    max-width: 1200px;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    margin-top: 10px;
}

#gNav>li {
    border-right: dotted 1px var(--main-color02);
}

#gNav>li:first-child {
    border-left: dotted 1px var(--main-color02);
}

#gNav>li>a {
    font-size: clamp(13px, 1.6vw, 16px);

    font-weight: bold;
    color: var(--main-color02);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 30px 0 8px;
    background-repeat: no-repeat;
    background-position: center top 6px;
}

#gNav>li>ul {
    display: none;
}

#gNav>li.top>a {
    background-image: url(./img/icon01.png);
}

#gNav>li.first>a {
    background-image: url(./img/icon02.png);
}

#gNav>li.corporate>a {
    background-image: url(./img/icon03.png);
}

#gNav>li.reason>a {
    background-image: url(./img/icon04.png);
}

#gNav>li.menu>a {
    background-image: url(./img/icon05.png);
}

#gNav>li.works>a {
    background-image: url(./img/icon06.png);
}

#gNav>li.blog>a {
    background-image: url(./img/icon07.png);
}

#gNav>li.voice>a {
    background-image: url(./img/icon08.png);
}

#gNav>li.top>a:hover {
    background-image: url(./img/icon01_on.png);
}

#gNav>li.first>a:hover {
    background-image: url(./img/icon02_on.png);
}

#gNav>li.corporate>a:hover {
    background-image: url(./img/icon03_on.png);
}

#gNav>li.reason>a:hover {
    background-image: url(./img/icon04_on.png);
}

#gNav>li.menu>a:hover {
    background-image: url(./img/icon05_on.png);
}

#gNav>li.works>a:hover {
    background-image: url(./img/icon06_on.png);
}

#gNav>li.blog>a:hover {
    background-image: url(./img/icon07_on.png);
}

#gNav>li.voice>a:hover {
    background-image: url(./img/icon08_on.png);
}

#gNav.top>li.top>a {
    background-image: url(./img/icon01_on.png);
}

#gNav.first>li.first>a {
    background-image: url(./img/icon02_on.png);
}

#gNav.corporate>li.corporate>a {
    background-image: url(./img/icon03_on.png);
}

#gNav.reason>li.reason>a {
    background-image: url(./img/icon04_on.png);
}

#gNav.menu>li.menu>a {
    background-image: url(./img/icon05_on.png);
}

#gNav.works>li.works>a {
    background-image: url(./img/icon06_on.png);
}

#gNav.blog>li.blog>a {
    background-image: url(./img/icon07_on.png);
}

#gNav.voice>li.voice>a {
    background-image: url(./img/icon08_on.png);
}



/* -----------------------------------------------------------
    footer
----------------------------------------------------------- */
footer {
    padding: 0 0 100px;
}


footer a,
footer a:link,
footer a:visited {
    color: var(--black);
    text-decoration: none;
}

.ftrNav {
    background-color: #f5f5f5;
    padding: 30px 0;

    .inner {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 0;
        border-left: dotted 1px #333;

        &>ul {
            border-right: dotted 1px #333;
            padding: 0 20px;
        }

        &>ul>li {}

        &>ul>li>a {
            font-size: 13px;
            position: relative;
            display: flex;
            width: fit-content;
            gap: 10px;
            align-items: center;

            &::before {
                content: '';
                width: 7px;
                height: 7px;
                background: url(./img/ico_footerArrow.png) no-repeat center/contain;
            }
        }

        &>ul>li>ul {
            margin-left: 20px;
        }

        &>ul>li>ul>li>a {
            font-size: 13px;
            position: relative;
            display: flex;
            width: fit-content;
            gap: 5px;
            align-items: center;
            font-weight: 500;

            &::before {
                content: '';
                width: 10px;
                height: 1px;
                border-bottom: dotted 1px #333;
            }

            &::after {
                content: '';
                position: absolute;
                left: 0;
                top: 0;
                width: 1px;
                height: calc(1em + 10px);
                border-left: dotted 1px #333;
            }
        }

        &>ul>li>ul>li:last-child a::after {
            height: calc((1em + 10px) / 2);
        }


    }
}

.ftrContent {
    padding: 30px 15px 70px;
    text-align: center;

    @media (min-width:1000px) {
        text-align: left;
        display: flex;
        justify-content: space-between;
    }

    @media (min-width:1200px) {
        padding: 30px 0px 70px;
    }
    .ftrLogo {
        display: block;
        margin-bottom: 15px;
    }
    .boxL{
        font-size: 14px;
    }
    h3{
        font-size: 14px;
        font-weight: 900;
        line-height: 1;
    }

    .boxR {
        @media (min-width:1000px) {
            display: flex;
            flex-direction: column;
            justify-content: space-between;
            align-items: flex-end;
        }
    }

    .copyRight {
        font-size: 13px;
    }

    .ftrBanner {
        margin-top: 30px;

        @media (min-width:1000px) {
            margin-top: 0;
        }
    }
}


footer .pageTop {
    a {
        background-color: var(--main-color02);
        color: var(--white);
        font-size: 18px;
        font-weight: 900;
        font-family: var(--en-font-family);
        text-align: center;
        position: relative;
        padding: 25px 15px 10px;
        display: block;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        &::before {
            content: '';
            position: absolute;
            left: 0;
            top: 15px;
            width: 100%;
            height: 10px;
            background: url(./img/ico_pageTop.png) no-repeat center/contain;
        }
    }
}

.ftrFloating {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 10px 0;
    z-index: 1;
    transition: 0.5s;
    opacity: 0;
    pointer-events: none;

    &.visible {
        transition: 0.5s;
        opacity: 1;
        pointer-events: auto;

    }

    .inner {
        display: flex;
        justify-content: space-between;
        background-color: var(--white);
        padding: 0 0 0 20px;
    }

    .ftrTelContact {
        display: flex;
        align-items: stretch;
        justify-content: flex-end;
        gap: 20px;
    }

    .ftrTel {
        display: flex;
        align-items: center;
        line-height: 1;
        background: var(--white);
        color: var(--black);
    }

    .ftrTel .tel {
        font-size: 16px;
        color: var(--black);
        display: flex;
        align-items: center;
        flex-wrap: wrap;
    }

    .ftrTel .tel-link {
        font-size: clamp(40px, 5.5vw, 56px);
        font-weight: 900;
        color: var(--sub-color01);
        display: flex;
        gap: 10px;
        align-items: center;

        a {
            text-decoration: none !important;
        }

        &::before {
            content: '';
            width: 35px;
            height: 35px;
            background: url(./img/ico_tel01.png) no-repeat center/cover;
        }

    }

    .ftrTel .tel-open {
        font-size: 11px;
        font-weight: 500;
        letter-spacing: -0.05em;
        display: block;
        margin-top: 5px;
        margin-left: 20px;
        line-height: 1.4;

    }

    .ftrContact {
        display: flex;
        color: var(--main-color02);
        font-size: 18px;
        font-weight: 500;
        background: var(--main-color01);
        align-items: center;
        justify-content: center;
        padding: 15px 20px;
        line-height: 1;
        text-decoration: none;
        transition: background-color 0.3s ease;
        border-radius: 100px;
        white-space: nowrap;

        @media (min-width:1000px) {
            width: 280px;
        }

    }

    .ftrContact:hover {
        background-color: var(--sub-color02);
    }

    .ftrContact img {
        margin-right: 1rem;
        vertical-align: text-bottom;
    }

    .ftrContactRight {
        display: flex;
        align-items: center;
        gap: 10px;
    }

    .ftrContactPageTop {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-direction: column;
        background-color: var(--main-color02);
        color: var(--white);
        font-size: 10px;
        position: relative;
        width: 76px;
        height: 70px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        &::before {
            content: '';
            width: 31px;
            height: 34px;
            background: url(./img/ico_arrowPageTop.png) no-repeat center/contain;
        }
    }

}


.bottomNav {
    background-color: var(--main-color01);

    .inner {
        padding: 0;
    }

    ul {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 2px;

        @media (min-width:1000px) {
            gap: 0;
            grid-template-columns: repeat(4, 1fr);
        }
    }

    li {
        @media (min-width:1000px) {
            &:not(:first-child) {
                border-left: solid 1px var(--white);
            }
        }
    }

    a {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
        text-align: center;
        align-items: center;
        aspect-ratio: 2/1;
        contain: paint;

        .label {
            grid-column: 1/2;
            grid-row: 1/2;
            z-index: 2;
            color: var(--white);
            font-size: 20px;
            font-weight: bold;
            text-shadow: 0 0 5px var(--main-color02),0 0 10px var(--main-color01);
        }

        img {
            grid-column: 1/2;
            grid-row: 1/2;
            z-index: 1;
            opacity: 0.5;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        &:hover {
            img {
                opacity: 1;
                scale: 1.1;
            }
        }
    }
}

.bottomFlow {
    padding: 70px 0 50px;

    .contentTitle {
        text-align: center;
        font-size: clamp(27px, 9vw, 40px);
        color: var(--main-color02);
        font-weight: 900;

        .red {
            color: var(--sub-color01);
        }
    }

    .subTitle {
        font-size: clamp(60px, 14vw, 80px);
        text-align: center;
        font-weight: 900;
        color: #e6e6e6;
        margin-bottom: -30px;
        line-height: 1;
    }

    .bottomFlowList {
        margin-top: 40px;
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
        gap: 40px;
        counter-reset: num;
    }

    .bottomFlowItem {
        border: solid 1px #ccc;
        border-radius: 10px;
        background-color: var(--white);
        position: relative;
        counter-increment: num;
        --circleSize: 60px;
        margin-top: calc(var(--circleSize) / 2);

        &::before {
            content: counter(num, decimal-leading-zero);
            position: absolute;
            left: calc(50% - var(--circleSize) / 2);
            top: calc(-1 * var(--circleSize) / 2);
            width: var(--circleSize);
            height: var(--circleSize);
            display: flex;
            justify-content: center;
            align-items: center;
            line-height: 1;
            background-color: var(--main-color03);
            color: var(--white);
            font-size: 20px;
            font-weight: bold;
            font-family: 'Roboto';
            border-radius: 100vh;
            z-index: 1;
        }
    }

    .title {
        color: var(--main-color03);
        font-size: 20px;
        font-weight: bold;
        text-align: center;
        margin-top: 10px;
    }

    .textBox {
        padding: 10px;
    }

    img {
        contain: paint;
        border-radius: 10px 10px 0 0;
        width: 100%;

    }
}


/* -----------------------------------------------------------
    共通部品
----------------------------------------------------------- */
.pageMainv {
    margin-left: auto;
    margin-right: auto;
    width: fit-content;
}

.pageMainv>img {
    display: block;
}

/*. contactTel */
.contactTel {
    font-weight: 600;
    margin-top: 60px;
}

.contactTel b {
    background: var(--sub-color04);
    color: var(--white);
    margin-right: 5px;
    padding: 0 10px;
    display: inline-block;
}

.contactTel strong {
    color: var(--red);
}


/*----- .contact01 -----*/
.contact01 {
    .tel {
        display: flex;
        align-items: flex-end;
        gap: 0px 15px;
        flex-wrap: wrap;
        justify-content: center;

        @media (min-width:1200px) {
            justify-content: flex-start;
        }
    }

    .tel-link {
        font-weight: bold;
        color: var(--sub-color01);
        display: flex;
        gap: 10px;
        align-items: center;
        font-size: clamp(24px, 5vw, 35px) !important;

        @media (min-width:1000px) {
            font-size: clamp(40px, 5.5vw, 56px) !important;
        }

        &::before {
            content: '';
            width: 27px;
            height: 28px;
            background: url(./img/ico_tel01.png) no-repeat center / cover;
        }
    }
}

#contents section.contact01 {
    padding-bottom: 0;
}

.contact01,
#contents section.contact01 {
    margin: 40px 0 0;
    padding: 20px 0 0;
    border-top: 1px dotted var(--black);
}

.box02 .contact01,
.box03 .contact01 {
    clear: both;
}

.contact01 .inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 30px 0;
}

.contact01 .title,
#main .contact01 .title {
    width: 100%;
    text-align: center !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    color: var(--main-color02);

}

.contact01 .boxL {
    width: 100%;

    @media (min-width:1200px) {
        width: 65%;
    }
}

.contact01 .boxR {
    margin-block: 0;
    width: 100%;

    @media (min-width:1200px) {
        width: 35%;
    }
}

.contact01 .boxR a,
#main .contact01 .boxR a {
    margin-left: auto;
    text-decoration: none;
    padding: 10px 20px;
    font-size: clamp(14px, 2vw, 20px);
    width: 100%;
    min-width: 0;
    font-weight: 900 !important;
}

/*----- .telBox -----*/
.telBox {
    background: var(--main-color02);
    margin: 50px 0;
    padding: 30px 80px;
    color: var(--white);
    text-align: center;
}

#contact .telBox,
#partner .telBox {
    margin: 0;
}

.telBox p {
    margin-bottom: 0 !important;
    line-height: 1;
}

.telBox .tel {
    line-height: 1;
    margin-top: 0.5rem;
}

.telBox .btnC a {
    background-image: none;
    border: solid 1px var(--white);
    font-size: 14px;
}

.telBox .tel span.tel-link {
    font-size: clamp(60px, 14vw, 80px);
    line-height: 1;
    margin-left: 5px;
    color: var(--white);
}

.telBox .tel-open {
    display: block;
}

.telBox+.wpcf7 .formBox table {
    margin-top: 2px !important;
}

/*----- .shopAccess -----*/
#main ul.shopAccess {
    margin-top: 10px;
}

#main ul.shopAccess>li {
    background: none !important;
    margin: 0 0 50px !important;
    padding: 0 !important;
}

#main ul.shopAccess li:before,
#main ul.shopAccess li:after {
    content: none;
}

.shopAccess iframe {
    width: 100%;
}

/*----- .snsShare -----*/
.fb-like>span {
    width: auto !important;
}

.fb_iframe_widget iframe {
    width: 160px !important;
    min-width: 135px !important;
    position: static !important;
}

/* -----------------------------------------------------------
    基本の記事スタイル設定
----------------------------------------------------------- */
#main p {
    margin-bottom: 15px;
    font-weight: 500;
}

a {
    color: var(--main-color02);
}

#main p+h2,
#main p+h3,
#main p+h4,
#main p+h5,
#main p+h6,
#main ul+h2,
#main ul+h3,
#main ul+h4,
#main ul+h5,
#main ul+h6,
#main ol+h2,
#main ol+h3,
#main ol+h4,
#main ol+h5,
#main ol+h6 {
    margin-top: 30px;
}

#main .inner+p+h2,
#main .inner+p+h3,
#main .inner+p+h4,
#main .inner+p+h5,
#main .inner+p+h6 {
    margin-top: 0;
}

#main h1,
#main h2,
#main h3,
#main h4,
#main h5,
#main h6 {
    line-height: 1.5;
    clear: both;
}

#main h2.headLine {
    font-weight: 500;
    display: block;
    font-size: 1.15rem;
    color: var(--main-color02);
    line-height: 1.2;
    margin-bottom: 20px;
}

#main h2.headLine span.en::first-letter {
    color: var(--main-color02);
}

#main h2.headLine span.en {
    font-family: var(--en-font-family);
    font-size: 100px;
    font-weight: 500;
    margin-right: 30px;
    display: block;
    color: var(--black)
}

#main h3.headLine {
    color: var(--white);
    background: var(--sub-color01);
    font-size: 1.25rem;
    font-weight: 500;
    margin: 0 0 20px 0;
    padding: 15px 20px;
}

#main h1.postTitle,
#main h2.postTitle,
#main h3.postTitle {
    font-size: clamp(27px, 9vw, 40px);
    color: var(--main-color02);
    line-height: 1.2;
    font-weight: 900;
    margin-top: 15px;
}

#main h2.popheading,
#main h3.popheading {
    position: relative;
    font-size: 36px;
    font-weight: 600;
    width: fit-content;
    margin: 1em auto;
    text-align: center;
    line-height: 1.25;
}

h2.popheading b>strong {
    font-size: 100px;
    font-family: var(--en-font-family);
    font-weight: 600;
    padding: 0 5px;
    vertical-align: -0.02em;
    display: inline-block;
}

#main .popheading b {
    display: inline-block;
    font-size: 46px;
    font-weight: 700;
    color: var(--red);
    width: fit-content;
    margin: 0 auto;
}

#main .popheading::before,
#main .popheading::after {
    content: "";
    display: block;
    background: center center url("./img/bg_popheading01.png") no-repeat;
    width: 50px;
    height: 77px;
    position: absolute;
    top: -100%;
    bottom: -100%;
    margin: auto 0;
}

#main .popheading::before {
    left: 0;
    transform: translateX(-200%);
}

#main .popheading::after {
    right: 0;
    transform: translateX(200%) scaleX(-1);
}

#main .popheading:has(b > strong)::before {
    transform: translate(-200%, 0.5em);
}

#main .popheading:has(b > strong)::after {
    transform: translate(200%, 0.5em) scaleX(-1);
}

#main h2.vline,
#main h3.vline {
    position: relative;
    font-size: clamp(27px, 9vw, 40px);
    font-weight: 700;
    padding: 20px 30px 88px;
    margin-bottom: 30px;
    text-align: center;
    line-height: 1.2;
}

#main .vline::before {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    content: "";
    display: block;
    width: 7px;
    height: 68px;
    background-color: var(--main-color02);
    -webkit-mask-image: url("./img/img_polygon02.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_polygon02.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
}

body:not(#top) .mainv {
    margin-bottom: 100px;
}

.mainv .mainvTxt {
    font-size: 16px;
    font-weight: 400;
    margin-top: 50px;
    margin-bottom: -50px;
    text-align: center;
}

#main table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 1px;
    border-bottom: #ccc solid 1px;
    border-top: #ccc solid 1px;
}

#main h2+table {
    margin-top: 20px;
}

#main table th,
#main table td {
    padding: 10px;
    font-size: 1rem;
    line-height: 1.7;
    text-align: left;
    vertical-align: top;
    position: static;
    border-bottom: #ccc solid 1px;

    @media (min-width:1000px) {
        padding: 10px 20px 10px 40px;

    }
}

#main table td .btn {
    margin-top: 10px;
}

#main table th p,
#main table td p {
    margin-bottom: 0 !important;
}

#main table th {
    width: 150px;
    font-weight: 900;
    vertical-align: top;
    font-size: 16px;
    background: none;
    background: var(--main-color03);
    color: var(--white);
    text-align: left;

    @media (min-width:1000px) {
        width: 25%;

    }
}

#main .pagenavi {
    clear: both;
    width: 100%;
    max-width: 1200px;
    margin: 0;
    padding: 40px 0;
}

#main .pagenavi ul {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 20px;
    align-items: center;
    margin: 0;

    @media (min-width:1000px) {
        display: flex;
        justify-content: space-between;

    }
}

#main .pagenavi ul li {
    display: block;
    padding: 0 !important;
    margin-bottom: 0;

    @media (min-width:1000px) {
        flex-basis: 33.3%;
    }
}

#main .pagenavi ul li:before {
    content: none;
}

#main .pagenavi ul li a {
    display: inline-block;
    font-size: 16px;
    font-weight: 400;
    position: relative;
    text-decoration: none;
}

#main .pagenavi ul li.list a {
    background-color: var(--black);
    border: solid 1px var(--black);
    color: var(--white);
    padding: 5px 30px;

    text-decoration: none !important;
    text-align: center;
    transition: all 0.3s ease;
}

#main .pagenavi ul li.list a:hover {
    border: solid 1px var(--black);
    color: var(--black);
    background-color: var(--white);
    transition: 0.7s;
}

#main .pagenavi ul li.prev {
    text-align: left;
}

#main .pagenavi ul li.next a,
#main .pagenavi ul li.prev a {
    color: var(--black);
    letter-spacing: 0.1em;

    @media (min-width:1000px) {
        padding-left: 20px;
        padding-right: 20px;
    }
}

#main .pagenavi ul li.next a::before {
    content: "＜";
    margin-right: 1rem;
}

#main .pagenavi ul li.prev a::after {
    content: "＞";
    margin-left: 1rem;
}

#main .pagenavi ul li.prev a i {
    margin-right: 1.0rem;
}

#main .pagenavi ul li.next {
    text-align: right;
}

#main .pagenavi ul li.next a i {
    margin-left: 1.0rem;
}

#main .pagenavi ul li.next a:hover,
#main .pagenavi ul li.prev a:hover {
    color: var(--main-color02);
}

#main .pagenavi ul li.list {
    text-align: center;
}

/*--フォーム部品--*/
h2+.wpcf7 {
    margin-top: 50px;
}

#main .formBox table {
    border-right: none !important;
    border-top: #ccc solid 1px;
    border-bottom: #ccc solid 1px;
}

.formBox table tr {
    display: block;

    @media (min-width:800px) {
        display: table-row;
    }
}

.formBox table th,
.formBox table td,
#main .formBox table th,
#main .formBox table td {
    border: none;
    line-height: 1.3;
    vertical-align: top;
    background-clip: padding-box;
    display: block;

    @media (min-width:800px) {
        display: table-cell;
    }
}

.formBox table th,
#main .formBox table th {
    width: 100%;
    font-weight: 500;
    vertical-align: middle;
    position: relative;
    background-color: transparent;
    color: var(--black);
    padding: 20px 0 0 0;

    @media (min-width:800px) {
        width: 30%;
        border-bottom: #ccc solid 1px;
        padding: 20px 20px;

    }

}

.formBox table td,
#main .formBox table td {
    background: var(--white);
    position: static;
    padding: 20px 0 20px 0px;
    border-bottom: #ccc solid 1px;

    @media (min-width:800px) {
        padding: 20px 0 20px 20px;

    }
}

.formBox table th p,
.formBox table td p {
    margin-bottom: 0 !important;
}

.formBox table th span {
    position: absolute;
    right: 10px;
    top: 20px;
    font-size: 12px;
    background: #ccc;
    color: var(--white);
    padding: 2px 7px;

    @media (min-width:800px) {
        top: calc(50% - 10px);

    }
}

.formBox table th span.req {
    background: var(--sub-color01);
}

.formBox input:not(input[type="checkbox"]):not(input[type="submit"]):not(input[type="radio"]),
.formBox select,
.formBox textarea {
    font-size: 16px;
    padding: 15px;
    width: 100%;
    border: 1px solid #ddd;
    border-radius: 5px;
    background: #ffffcc;
}

.formBox input:not(input[type="checkbox"]):not(input[type="submit"]):not(input[type="radio"])::placeholder,
.formBox textarea::placeholder {
    color: #ddd;
    font-weight: 400;
}

.formBox input[name="your-add"] {
    width: 98% !important;
}

.formBox select {
    width: 300px;
}

.formBox textarea {
    height: 60px;
    width: 100%;
}

.formBox .accept {
    text-align: center;
    margin: 30px 0;
}

.bgColor01 .formBox .accept {
    background: var(--white);
}

.formBox .accept small {
    display: block;
}

.formBox input[type="checkbox"],
.formBox input[type="radio"] {
    transform: scale(1.5);
    margin: 0 6px 0 0;
}

.formBox input[type="submit"],
.searchBox input[type="submit"] {
    display: inline-block !important;
    border-radius: 100vh;
    border: none;
    font-size: 20px;
    background: var(--main-color02);
    min-width: 240px;
    text-align: center;
    line-height: 1.2;
    padding: 20px 30px;
    text-decoration: none !important;
    color: var(--white) !important;
    font-weight: bold;
    cursor: pointer;
    transition: all 0.3s ease;

    @media (min-width:800px) {
        min-width: 360px;
    }
}

.formBox .submit {
    text-align: center;
}

.formBox input[type="submit"]:disabled {
    cursor: default;
    background: #ccc;
    transition: all 0.3s ease;
}

.formBox .wpcf7-spinner {
    display: none !important;
}

.formBox .wpcf7-list-item-label {
    vertical-align: text-bottom;
}

.formBox input[readonly="readonly"] {
    background: #f3f3f3 !important;
    color: #555;
    width: 100% !important;
}

.formBox .confirm {
    margin-top: 50px;
}

/*--写真並び（3列）--*/
#main .photoUL {
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 40px;
    margin-bottom: 50px;
}

#main .photoUL li {
    display: block;
    width: calc((100% - 80px) / 3);
    margin: 0;
    padding: 0;
    font-size: 14px;
}

#main .photoUL .otherPhoto {
    width: 100%;
    height: 270px;
    display: block;
    margin-bottom: 10px;
}

#main .photoUL .otherPhoto a {
    display: block;
}

#main .photoUL .otherPhoto img {
    width: 100%;
    height: 270px;
    object-fit: cover;
}

#main .photoUL li b {
    color: var(--main-color02);
    font-size: 16px;
    font-weight: 700;
    display: block;
}

#main .photoUL li:before,
#main .photoUL li:after,
#main .photoUL li h5:after {
    content: none;
}

/*--下層ページメインビジュアル--*/
#cornerName {
    background-color: var(--main-color01);
    height: 150px;
    background-image:
        url(./img/img_cornerName01.png),
        url(./img/img_cornerName02.png);
    background-position:
        left -100px center,
        right -100px center;
    background-repeat: no-repeat;
    background-size: contain;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;

    @media (min-width:500px) {
        background-position:
            left center,
            right center;
    }

    @media (min-width:1000px) {
        height: 200px;
    }

    .cornerNameText {
        font-size: clamp(27px, 5vw, 35px);
        color: var(--main-color02);
        font-weight: 900;

        span {
            font-size: clamp(14px, 2vw, 20px);
            color: var(--main-color02);
            display: block;
            width: fit-content;
            background-color: var(--white);
            padding: 2px 20px;
            margin: 10px auto 0;

        }
    }

}

.breadcrumbs {
    width: 100%;
    margin: 0 auto;
    font-size: 14px;
    color: var(--white);
    background-color: var(--main-color02);

    .inner {
        max-width: 1600px;
        padding: 5px 10px;
    }

    a {
        color: var(--white);
    }

    &>span {
        margin-right: 12px;
    }

    &>span:nth-of-type(n+2) {
        margin-left: 12px;
    }
}



/*--メインカラム--*/
#contents {
    margin: 0 auto 0;
}

#contents section {
    margin: 0 auto;
    position: relative;
    overflow: hidden;
}

#top #contents section {
    padding: 25px 0;

    @media (min-width:1000px) {
        padding: 50px 0;
    }
}

/*投稿画像の回り込み処理*/
img.centered {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

img.alignright {
    padding: 0;
    margin: 0 0 2px 7px;
    display: inline;
}

img.alignleft {
    padding: 0;
    margin: 0 30px 10px 0;
    display: inline;
}

img.aligncenter {
    display: block;
    margin: 0 auto;
}

.alignright {
    float: right;
    margin-left: 10px;
    margin-bottom: 2px;
}

.alignleft {
    float: left;
    margin-right: 10px;
    margin-bottom: 2px;
}

img {
    border-style: none;
}

#main .nobr br {
    display: none;
}

#main p.wp-caption {
    font-size: 0.8em;
    line-height: 1.2em;
}

#main p.wp-caption img {
    margin-bottom: 5px;
}

#main p.wp-caption .caption-text {
    text-align: left;
}

.pt-100 {
    padding-top: 100px;
}

.pb-100 {
    padding-bottom: 100px;
}

/* -----------------------------------------------------------
    #top
----------------------------------------------------------- */
#main h2,
#main .extraPart h2,
footer h2 {
    line-height: 1.25;
}

#top #main h2 small,
#main .extraPart h2 small {
    position: relative;
}

.bgColor01 {
    background-color: #f5f5f5;
}

.bgColor02 {
    background-color: var(--main-color02);
}

.bgColor03 {
    background-color: var(--main-color03);
}

.bgColor04 {
    background-color: var(--sub-color04);
}

.txtBlack {
    color: var(--black) !important;
}

.txtRed {
    color: var(--red) !important;
}

#top #main .bgColor02 h2 span.en::first-letter {
    color: var(--white);
}

#top #main .bgColor02 h2 small {
    color: var(--black);
}

#top #mainv .medals {
    order: 3;
}

#top #mainv .medals ul {
    display: flex;
    margin: 30px 0 0;
    align-items: center;
}

#top #mainv .medals ul li {
    display: block;
    margin: 0 6px;
    padding: 0;
    width: 112px;
}

#top #mainv .medals ul li:last-of-type {
    width: auto;
    flex-basis: 155px;
}

#top #mainv .medals ul li::after,
#top #mainv .medals ul li::before {
    content: none !important;
}

#top #mainv .medals ul li a {
    text-decoration: none;
    color: var(--black);
}

#top #mainv .medals ul li img {
    width: 100%;
    height: auto;
    display: block;
}

/*-------------------#mainv-----------------*/
#mainv {
    padding-top: 1px;
    border-top: solid 4px var(--main-color01);
    width: 100%;
}

.swiperMainVisual {
    visibility: hidden;
}

.swiperMainVisual.swiper-container-initialized {
    visibility: visible;
}

#mainv .swiper-slide {
    width: -moz-fit-content;
    width: fit-content;
}

#mainv .swiper-mainv-prev {
    display: block;
    width: calc(50% - 600px);
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background-color: rgba(255, 255, 255, 0.5);
    z-index: 2;
}

#mainv .swiper-mainv-prev:hover {
    cursor: pointer;
    /*    background: url(./img/leftNav.png) no-repeat right 50px center rgba(255, 255, 255, 0.5);*/
}

#mainv .swiper-mainv-next {
    display: block;
    width: calc(50% - 600px);
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    background-color: rgba(255, 255, 255, 0.5);
    z-index: 2;
}

#mainv .swiper-mainv-next:hover {
    cursor: pointer;
    /*    background: url(./img/rightNav.png) no-repeat left 50px center rgba(255, 255, 255, 0.5);*/
}

/*-------------------.topNo1-----------------*/
.topNo1 {

    .inner {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;

        @media (min-width:1200px) {
            grid-template-columns: auto 1fr;
        }

    }

    .topNo1Left {
        display: flex;
        flex-direction: row-reverse;
        align-items: flex-end;
        gap: 10px;
        margin: 0 auto;
        img {
            width: 100%;
            max-width: 400px;
            display: block;
            margin-inline: auto;
        }
        @media (min-width:1200px) {
            display: block;
            margin: none;
        }
    }

    .topNo1Left-text {
        font-size: 20px;
        background-color: var(--main-color02);
        color: var(--white);
        border-radius: 5px;
        padding: 10px 15px;
        text-align: center;
        font-weight: 900;
        line-height: 1.25;
        margin-top: 15px;
        width: fit-content;
        flex-shrink: 0;
        i{
            font-style: normal;
            display: none;
        }
        @media (min-width:1200px) {
            padding: 15px;
            font-size: 24px;
            line-height: 1;
            i{
                display: inline
            }
        }
    }

    .topNo1Right {
        display: flex;
        flex-wrap: wrap;
        align-content: flex-end;
        gap: 5px;
    }

    .topNo1Right-row1 {
        flex-basis: 100%;
        font-weight: 900;
        line-height: 1.2;
        display: flex;
        flex-wrap: wrap;
        gap: 10px 5px;

        .text1 {
            background-color: var(--main-color02);
            color: var(--white);
            font-size: clamp(20px, 3vw, 32px);
            border-radius: 5px;
            padding: 5px 10px 7px;
            display: inline-block;
        }

        .text2 {
            color: var(--main-color02);
            font-size: clamp(18px, 2.8vw, 28px);
            display: inline-block;
        }

        .textBlock {
            display: inline-block;
        }
    }

    .topNo1Right-row2 {
        font-weight: 900;
        font-feature-settings: "palt";
        line-height: 1.2;

        .text1 {
            color: var(--sub-color01);
            font-size: clamp(35px, 10vw, 73px);
            position: relative;
            display: inline-block;
        }

        .text1::before {

            content: '';
            position: absolute;
            bottom: 0px;
            left: 0;
            width: 100%;
            height: 10px;
            background-color: var(--sub-color05);
            z-index: -1;
        }

        .text2 {
            color: var(--main-color02);
            font-size: clamp(30px, 8vw, 50px);
            font-weight: 900;
        }
    }

    .topNo1Right-row3 {
        font-weight: 900;
        font-feature-settings: "palt";
        line-height: 1.2;
        color: var(--main-color02);
        font-weight: 900;
        font-size: clamp(24px, 7vw, 33px);
        letter-spacing: -0.05em;
        @media (min-width:1200px) {
            letter-spacing: 0.01em;
        }
    }
}



/*-------------------.cta-----------------*/

.cta {
    padding: 50px 0;

    .inner {
        background: url(./img/bg_orangestripe.gif);
        padding: 10px 5px 5px 5px;
        font-weight: 900;
        position: relative;
        font-feature-settings: "palt";
        display: block;
        color: #333;

        @media (min-width:1200px) {
            &::before {
                pointer-events: none;
                content: '';
                position: absolute;
                display: block;
                width: 213px;
                height: 221px;
                background: url(./img/img_cta01.png) no-repeat right bottom/contain;
                bottom: 7px;
                right: 10px;
            }
        }
    }

    .ctaTop {
        display: block;
        padding: 0px 10px 2px 10px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }
    }

    .row1 {
        line-height: 1.2;
        color: var(--sub-color05);
        font-size: clamp(20px, 4.5vw, 25px);
        text-align: center;

        @media (min-width:1200px) {
            text-align: left;
        }
    }

    .row2 {
        display: flex;
        gap: 5px;
        align-items: center;
        flex-wrap: wrap;
        justify-content: center;
        margin-top: 5px;

        @media (min-width:1200px) {
            justify-content: flex-start;
        }
    }

    .limeCircle {
        line-height: 1;
        color: var(--white);
        font-size: clamp(18px, 3vw, 25px);
        background-color:#a5ed27;
        border-radius: 100vh;
        aspect-ratio: 1;
        width: fit-content;
        padding: 16px;
        text-shadow: rgb(96, 124, 47) 2px 0px 0px, rgb(96, 124, 47) 1.75517px 0.958851px 0px, rgb(96, 124, 47) 1.0806px 1.68294px 0px, rgb(96, 124, 47) 0.141474px 1.99499px 0px, rgb(96, 124, 47) -0.832294px 1.81859px 0px, rgb(96, 124, 47) -1.60229px 1.19694px 0px, rgb(96, 124, 47) -1.97999px 0.28224px 0px, rgb(96, 124, 47) -1.87291px -0.701566px 0px, rgb(96, 124, 47) -1.30729px -1.51361px 0px, rgb(96, 124, 47) -0.421592px -1.95506px 0px, rgb(96, 124, 47) 0.567324px -1.91785px 0px, rgb(96, 124, 47) 1.41734px -1.41108px 0px, rgb(96, 124, 47) 1.92034px -0.558831px 0px;
    }

    .whiteText {
        color: var(--white);
        flex-basis: 100%;
        text-align: center;
        line-height: 1.5;

        @media (min-width:1200px) {
            flex-basis: auto;
            text-align: left;
        }


        .bigText {
            font-size: clamp(27px, 6vw, 48px);
            display: inline-block;
        }

        .smallText {
            font-size: clamp(20px, 5vw, 35px);
            display: inline-block;
        }

        &::after {
            content: '';
            width: clamp(30px, 6vw, 48px);
            height: clamp(30px, 6vw, 48px);
            display: inline-block;
            margin-left: 10px;
            background: url(./img/ico_mail02.png) no-repeat center/contain;
        }
    }

    .ctaBottom {
        background-color: var(--white);
        padding: 5px 10px;

        .tel {
            display: flex;
            align-items: flex-end;
            gap: 0px 15px;
            flex-wrap: wrap;
            justify-content: center;

            @media (min-width:1200px) {
                justify-content: flex-start;
            }
            .tel-open{
                margin-bottom: 0;
            }
        }

        .tel-link {
            font-size: clamp(36px, 5.5vw, 56px);
            font-weight: bold;
            color: var(--main-color02);
            display: flex;
            gap: 10px;
            align-items: center;
            margin-bottom: -5px;

            &::before {
                content: '';
                width: 38px;
                height: 38px;
                background: url(./img/ico_tel00.png) no-repeat center / cover;
            }
        }


    }

    .ctaFukidashi {
        display: none;
        pointer-events: none;

        @media (min-width:1200px) {
            display: block;
            position: absolute;
            bottom: 5px;
            right: 15%;
            color: var(--white);
            background: url(./img/img_cta_fukidashi.png) no-repeat center/contain;
            padding: 50px 50px 50px 50px;
            rotate: -15deg;
            text-shadow: rgb(96, 124, 47) 2px 0px 0px, rgb(96, 124, 47) 1.75517px 0.958851px 0px, rgb(96, 124, 47) 1.0806px 1.68294px 0px, rgb(96, 124, 47) 0.141474px 1.99499px 0px, rgb(96, 124, 47) -0.832294px 1.81859px 0px, rgb(96, 124, 47) -1.60229px 1.19694px 0px, rgb(96, 124, 47) -1.97999px 0.28224px 0px, rgb(96, 124, 47) -1.87291px -0.701566px 0px, rgb(96, 124, 47) -1.30729px -1.51361px 0px, rgb(96, 124, 47) -0.421592px -1.95506px 0px, rgb(96, 124, 47) 0.567324px -1.91785px 0px, rgb(96, 124, 47) 1.41734px -1.41108px 0px, rgb(96, 124, 47) 1.92034px -0.558831px 0px;
        }
    }
}

.greenCircleBox {
    position: relative;
    max-width: 1200px;
    margin-inline: auto;

    &::before {
        content: '';
        position: absolute;
        left: -400px;
        bottom: 30px;
        width: 511px;
        height: 453px;
        background: url(./img/bg_greencircle_left.png) no-repeat center/contain;
        z-index: -1;
    }

    &::after {
        content: '';
        position: absolute;
        right: -350px;
        top: 30px;
        width: 490px;
        height: 582px;
        background: url(./img/bg_greencircle_right.png) no-repeat center/contain;
        z-index: -1;

    }
}

.orangeCircleBox {
    position: relative;
    max-width: 1200px;
    margin-inline: auto;

    &::after {
        content: '';
        position: absolute;
        right: -350px;
        top: 30px;
        width: 490px;
        height: 582px;
        background: url(./img/bg_orangecircle_right.png) no-repeat center/contain;
        z-index: -1;

    }
}

.orangeStripeLine {
    display: block;
    width: 100%;
    height: 9px;
    background: url(./img/bg_orangestripe2.gif) repeat-x;
}

.greenStripeLine {
    display: block;
    width: 100%;
    height: 9px;
    background: url(./img/img_greenStripeBar.png) repeat-x;
}

#corporate .orangeStripeLine,
#subsidy .orangeStripeLine,
#first .orangeStripeLine,
#reason .orangeStripeLine/*,
#menu .orangeStripeLine*/ {
    display: none;
}

.grayBox {
    background-color: #f6f6f6;
}

.grayStripeBox {
    padding: 30px 0 50px;
    background: url(./img/bg_stripe1.gif);
}

/*-------------------.topPickup-----------------*/
.topPickup {

    .gridBox {
        margin-top: 40px;
        display: grid;
        grid-template-columns: 1fr;

        @media (min-width:768px) {
            grid-template-columns: repeat(2, 1fr);

        }
    }

    .gridBoxChild {
        text-align: center;
        padding-bottom: 30px;
    }

    .gridBoxChild+.gridBoxChild {

        @media (min-width:768px) {
            border-left: dotted 1px #333;
        }
    }

    .boxSubTitle {
        margin-top: 15px;
        color: var(--main-color01);
        font-size: clamp(15px, 4vw, 20px);
        font-weight: 900;
    }

    .boxTitle {
        color: var(--main-color02);
        font-size: clamp(27px, 9vw, 40px);
        margin-inline: auto;
        font-weight: 800 !important;
    }

    .boxText {
        margin-top: 15px;
        color: var(--main-color02);
        font-weight: 600;
    }

    .boxButton {
        font-size: 18px;
        font-weight: 900;
        margin-top: 15px;

        a {
            padding-block: 10px;
        }
    }
}

.titleBorder {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 15px;
    font-size: clamp(15px, 4vw, 20px);
    align-items: center;
    color: var(--main-color02);
    font-weight: 900;
    font-family: var(--en-font-family);
    text-transform: uppercase;

    &::before {
        content: '';
        background-color: var(--main-color02);
        height: 5px;
    }

    &::after {
        content: '';
        background-color: var(--main-color02);
        height: 5px;
    }
}

/*-------------------.topPrice-----------------*/
.topPrice {
    background: url(./img/bg_limedot.gif);
    padding: 60px 0 50px;
    margin-top: 5px;

    .priceTitle {
        font-size: clamp(30px, 8vw, 50px);
        font-weight: 700;
        text-align: center;

        span {
            font-weight: 900;
            position: relative;
            width: auto;
            z-index: 0;
            display: inline-block;
            color: var(--white);
            background: linear-gradient(to top, var(--main-color03) 0%, var(--main-color03) 90%, transparent 90%);
            line-height: 1;
            padding: 5px;
            /*
            &::before {
                content: '';
                position: absolute;
                z-index: -1;
                display: block;
                width: 100%;
                height: 10px;
                background-color: var(--white);
                left: 0;
                bottom: -4px;
            }*/
        }
    }

    .gridBox {
        display: grid;
        grid-template-columns: 1fr;
        gap: 45px;
        margin-top: 40px;

        @media (min-width:1024px) {
            grid-template-columns: repeat(3, 1fr);

        }
    }

    .boxAnker {
        display: flex;
        background-color: rgba(255, 255, 255, 1);
        padding: 15px;
        border-radius: 10px;
        transition: background-color 0.5s;
        flex-wrap: wrap;
        text-decoration: none;
        justify-content: center;
        height: 100%;
        color: var(--main-color02);
        box-shadow: 0 0 5px rgba(0,0,0,0.2),0 0 10px rgba(0,0,0,0.2);

        @media (min-width:1024px) {
            padding: 30px;
        }


        &:hover {
            background-color: rgba(255, 255, 255, 0.7);
            transition: background-color 0.5s;
        }
    }

    .boxTitle {
        text-align: center;
        flex-basis: 100%;
        font-size: clamp(30px, 9vw, 48px);

        margin-top: 15px;
        font-weight: 900;
    }

    .boxText {
        text-align: center;
        flex-basis: 100%;
    }
}

/*-------------------.topInformation-----------------*/
.topInformation {
    background-color: #31444d;
    padding: 45px 0 60px;

    .gridBox {
        display: grid;
        grid-template-columns: 1fr;
        gap: 20px;

        @media (min-width:1024px) {
            grid-template-columns: repeat(2, 1fr);
            gap: 40px;
        }
    }

    .boxTitle {
        color: var(--white);
        position: relative;
        text-align: center;
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;

        &::after {
            content: '';
            display: block;
            width: 107px;
            height: 4px;
            background-color: var(--main-color01);
            margin: 20px auto 0;
        }
    }

    .boxTitle+* {
        margin-top: 20px;
    }

    .boxInquiry {
        background-color: var(--white);
        height: 200px;
        border: solid 1px #ccc;
    }

    .boxInquiryList {
        padding: 0 25px;
        height: 100%;
        overflow-y: scroll;
    }

    .boxInquiryItem {
        padding: 15px 0;
        border-bottom: dotted 1px #333;
    }

    .boxInquiryDate {
        color: #e36711;
        font-weight: 900;
    }

    .boxLeftRow2 {
        margin-top: 48px;
    }

    .boxRecentInquiry {
        background-color: var(--white);
        display: grid;
        grid-template-columns: 30% 1fr;
        border: solid 1px #ccc;

        dt {
            background-color: var(--main-color01);
            color: var(--main-color02);
            height: 50px;
            display: flex;
            justify-content: center;
            align-items: center;
            font-size: clamp(15px, 5vw, 20px);
            font-weight: 900;
            border-left: solid 1px #ccc;

            &:not(:last-of-type) {
                border-bottom: solid 1px #ccc;
            }
        }

        dd {
            height: 50px;
            display: flex;
            align-items: center;
            font-size: clamp(15px, 5vw, 20px);
            font-weight: 900;
            padding-left: 20px;

            &:not(:last-of-type) {
                border-bottom: solid 1px #ccc;
            }
        }

        span {
            color: var(--sub-color01);
        }
    }

    .boxBlog {
        height: 350px;
        border: solid 1px #ccc;
    }

    .boxBlogList {
        background-color: var(--white);
        height: 100%;
        overflow-y: scroll;
        padding: 0 25px;
    }

    .boxBlogItem {
        border-bottom: dotted 1px #333;
    }

    .boxBlogAnker {
        display: block;
        padding: 15px 0;
        color: var(--main-color02);

    }

    .boxBlogDate {
        color: #e36711;
        font-weight: 900;
        display: block;
    }

    .boxBlogTitle {
        font-weight: 900;
    }

    .boxBlogText {
        display: -webkit-box;
        text-overflow: ellipsis;
        -webkit-box-orient: block-axis;
        -webkit-line-clamp: 2;
        contain: content;
        max-block-size: 3lh;
    }
}

/*-------------------.topVoice-----------------*/
.topVoice {
    padding-inline: 15px;

    .topVoiceInner {
        max-width: 1000px;
        margin-inline: auto;
    }

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            text-transform: uppercase;
            width: 136px;
            padding: 2px 0;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
        }
    }

    .voiceBlock {
        margin-top: 40px;
        position: relative;
    }

    .prevButton {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: 30%;
        left: 10px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        rotate: 180deg;
        cursor: pointer;

        &:hover {
            opacity: 0.7;
        }

        @media (min-width:1000px) {
            left: -25px;
            top: calc(50% - 25px);
        }
    }

    .nextButton {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: 30%;
        right: 10px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        cursor: pointer;

        &:hover {
            opacity: 0.7;
        }

        @media (min-width:1024px) {
            right: -25px;
            top: calc(50% - 25px);

        }
    }

    .voiceAnker {
        display: grid;
        grid-template-columns: 1fr;
        gap: 0;
        background-color: var(--white);
        color: var(--main-color02);

        @media (min-width:1024px) {
            grid-template-columns: repeat(2, 1fr);

        }
    }

    .voiceFig {
        margin: 0;
        display: flex;
        justify-content: center;
        align-items: center;
        height: 240px;

        @media (min-width: 1024px) {
            height: 350px;
          }

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .voiceRight {
        padding: 45px 35px;
    }

    .title {
        padding: 10px 0;
        border-top: solid 1px var(--main-color02);
        border-bottom: solid 1px var(--main-color02);
    }

    .title span {
        color: var(--main-color02);
        font-size: 24px;
        font-weight: 900;
        overflow: hidden;
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        contain: content;
        max-block-size: 3lh;
    }

    .cst {
        margin-top: 15px;
        display: -webkit-box;
        text-overflow: ellipsis;
        -webkit-box-orient: block-axis;
        -webkit-line-clamp: 3;
        contain: content;
        max-block-size: 3lh;
    }

    .owner {
        margin-top: 10px;
        color: var(--main-color02);
        font-weight: 900;
    }
}


/*-------------------.topGoogleReview-----------------*/
.topVoice + .topGoogleReview {
    padding-top: 0;
}
.topGoogleReview {
    padding-top: 80px;
    padding-bottom: 60px;
    padding-inline: 15px;

    .contentTitle {
        font-size: clamp(27px, 6vw, 40px);
        font-weight: 900;
        text-align: center;
        position: relative;
        color: var(--sub-color01);
        position: relative;
        display: flex;
        width: fit-content;
        margin-inline: auto;
        align-items: center;
        padding: 0 1.5em;

        &::before {
            content: '';
            position: absolute;
            left: 1em;
            top: calc(50% - 0.5em);
            width: 2px;
            height: 1em;
            background-color: var(--sub-color01);
            rotate: -45deg;
            transform-origin: 50% 100%;
        }

        &::after {
            content: '';
            position: absolute;
            right: 1em;
            top: calc(50% - 0.5em);
            width: 2px;
            height: 1em;
            background-color: var(--sub-color01);
            rotate: 45deg;
            transform-origin: 50% 100%;
        }
    }

    .googleTitle {
        color: #777;
        font-size: clamp(15px, 4vw, 20px);
        text-align: center;
        display: flex;
        justify-content: center;
        font-weight: 900;

        .g1 {
            color: #4285f4;
        }

        .g2 {
            color: #ea4335;
        }

        .g3 {
            color: #fbbc04;
        }

        .g4 {
            color: #34a853;
        }

        span:last-child {
            margin-left: 10px;
        }
    }

    .reviewBlock {
        max-width: 1000px;
        margin-inline: auto;
        margin-top: 20px;

        .wp-google-place {
            background-color: var(--main-color02) !important;
            text-align: center !important;
            font-size: 24px !important;
            font-weight: 800 !important;
            padding: 20px 15px !important;
            line-height: 1.2 !important;

            a {
                color: var(--white) !important;
            }

            .wp-google-left,
            .wp-google-wr,
            .wp-google-powered img {
                display: none !important;
            }

            .wp-google-name+div {
                margin-top: 10px !important;
                display: inline-block !important;
            }
        }
        .wp-gr .wp-google-rating {
            font-size: 24px !important;
            font-weight: 900 !important;
        }
        .wp-gr .wp-google-based{
            display: inline-block;
            font-weight: 500  !important;
            font-size: 14px !important;
            margin-left: 1rem !important;
            margin-right: 1rem !important;
            font-family: 'Noto Sans JP',sans-serif;
        }
        .wp-gr .wp-google-powered {
            color: var(--white) !important;
            font-weight: 500 !important;
            font-size: 14px !important;
            display: inline-block !important;
        }

        .wp-google-content-inner {
            height: 280px;
            overflow-y: scroll;
            border: dotted 1px #333 !important;
            background-color: var(--white) !important;
            padding: 20px !important;
        }

        .wp-google-review {
            padding-bottom: 15px !important;
            border-bottom: dotted 1px #333 !important;
        }
    }
}

/*-------------------.topStaff-----------------*/
.topStaff {
    background: url(./img/bg_orangedot.gif);
    padding: 60px 0 50px;

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--white);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color02);
            color: var(--white);
            width: 136px;
            padding: 2px 0;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
            text-transform: uppercase;
        }
    }

    .topStaffBlock {
        /* margin-top: 40px; */
        margin: 40px -15px 0;
        position: relative;
         @media (min-width:1200px) {
            margin-left: 0;
            margin-right: 0;
         }

    }

    .topStaffList {
        padding-bottom: 10px;

    }

    .topStaffItem {
        max-width: 230px;
        height: auto;
        box-shadow: 10px 10px 0px #fff;
    }

    .topStaffAnker {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: auto 1fr;
        height: 100%;
    }

    .staffFig {
        contain: paint;
        margin: 0;
        max-height: 230px;
    }

    .staffImg {
        width: 100%;
        /*height: 100%;*/
        height: 230px;
        object-fit: cover;
        object-position: center top;
    }

    .data {
        background-color: var(--main-color01);
        color: var(--main-color02);
        text-align: center;
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 10px 10px;
    }

    .dataSub {
        display: flex;
        justify-content: center;
        gap: 15px;
        line-height: 1;
    }

    .position {
        font-size: 14px;
    }

    .department {
        font-size: 14px;
    }

    .staffName {
        font-weight: 900;
        font-size: clamp(15px, 4vw, 20px);

    }

    .prevButton {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        left: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        rotate: 180deg;
        cursor: pointer;

        @media (min-width:1200px) {
            left: -25px;
        }

        &:hover {
            opacity: 0.7;
        }

    }

    .nextButton {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        right: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        cursor: pointer;

        @media (min-width:1200px) {
            right: -25px;
        }
        &:hover {
            opacity: 0.7;
        }
    }
}

/*-------------------.topMenu-----------------*/
.topMenu {
    padding-top: 50px;

    .topMenuBlock {
        padding: 0 10px 10px;

        &.building_demolition {
            background-color: var(--sub-color04);
        }

        &.small {
            background-color: #ffa302;
        }

        &.others {
            background-color: #ff7887;
        }

        &.interior_demolition {
            background-color: #51bb7b;
        }

        &+& {
            margin-top: 50px;
        }


        h2 {
            text-align: center;
            color: var(--white);
            font-size: clamp(27px, 9vw, 40px);
            font-weight: 900;
            padding: 20px;
        }
    }

    .topMenuList {

        &.type1 {
            display: grid;
            gap: 15px 10px;
            grid-template-columns: 1fr;

            @media (min-width:500px) {
                grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
            }

            h3 {
                color: var(--white);
                background-color: var(--main-color02);
                text-align: center;
                font-weight: 900;
                font-size: clamp(18px, 3vw, 25px);
                padding: 10px;
            }



        }

        &.type2 {
            display: grid;
            gap: 15px 1px;
            grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));

            .subTitle {
                color: var(--white);
                background-color: var(--main-color02);
                text-align: center;
                font-size: clamp(15px, 4vw, 20px);
                font-weight: 900;
                padding: 2px;
            }

            h3 {
                color: var(--main-color02);
                background-color: var(--sub-color05);
                text-align: center;
                font-weight: 900;
                font-size: clamp(20px, 7.5vw, 30px);
            }

            .priceBox {
                padding-bottom: 10px;

                @media (min-width:800px) {
                    margin-top: -10px;
                }
            }

            .price {
                justify-content: center;
            }

            .notice {
                text-align: center;
            }
        }

        &.type3 {
            display: grid;
            gap: 15px 1px;
            grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
            .topMenuItem {
                display: grid;
                grid-template-columns: 50% 50%;
                grid-template-areas:
                    "title title"
                    "image1 image2"
                    "subtitle subtitle"
                    "price price";
                gap: 0;
                padding-bottom: 10px;
                @media (min-width:600px) {
                    display: grid;
                    grid-template-columns: 50% 25% 25%;
                    grid-template-areas:
                        "title title title"
                        "subtitle image1 image2"
                        "price image1 image2";
                    gap: 10px 0;
                    padding-bottom: 10px;
                }
            }


            .subTitle {
                color: var(--white);
                background-color: var(--main-color02);
                text-align: center;
                font-size: clamp(15px, 4vw, 20px);
                font-weight: 900;
                padding: 2px;
                grid-area: title;
            }

            h3 {
                color: var(--main-color02);
                background-color: var(--sub-color05);
                font-weight: 900;
                font-size: clamp(20px, 7vw, 30px);
                grid-area: subtitle;
                margin: 0;
                padding: 10px;
                #main &{
                line-height: 1.233;
               }
               @media (min-width:600px) {
                margin: 0 15px 0 10px;
               }
            }

            .priceBox {
                padding-bottom: 10px;
                grid-area: price;
                margin: 0 auto;

                @media (min-width:800px) {
                    margin-top: -10px;
                    margin: -10px auto 10px 20px;
                }
            }

            .price {
                justify-content: center;
                @media (min-width:600px) {
                justify-content: flex-start;
                }
            }

            .notice {
                text-align: center;
            }
            .image{
                grid-area: image1;
                height: 100%;
                width: 100%;
                object-fit: cover;
                box-sizing: border-box;
                + .image{
                   grid-area: image2;                
                }
                @media (min-width:600px) {
                    padding-right: 10px;
                }
            }
            
        }
    }

    .topMenuItem {
        background-color: var(--white);
    }

    .column {
        display: flex;
        align-items: flex-end;
        flex-wrap: wrap;
        padding: 10px;
        gap: 10px;
        justify-content: center;

        @media (min-width:800px) {
            margin-top: -12px;
        }

        @media (min-width:1000px) {
            justify-content: flex-start;
        }
    }

    .chara4 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 2px;

        .chara {
            line-height: 0.75;
            aspect-ratio: 1;
            width: clamp(40px, 9.5vw, 50px);
            height: auto;
            background-color: var(--sub-color05);
            color: var(--main-color02);
            font-size: clamp(27px, 9vw, 40px);
            font-weight: 900;
            display: flex;
            justify-content: center;
            align-items: center;
        }
    }

    .image {
        height: 150px;
        /* border-top: solid 1px var(--white); */

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .priceBox {
        line-height: 1;

        .price {
            display: flex;
            align-items: flex-end;
        }

        .price1 {
            font-size: clamp(65px, 12vw, 105px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 1;
        }

        .price2 {
            font-size: clamp(50px, 10vw, 85px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 1;

        }

        .price3 {
            font-size: clamp(50px, 10vw, 85px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 1;
        }

        .price4 {
            font-weight: 900;
            color: var(--sub-color01);
            line-height: 1;
            font-size: clamp(18px, 3vw, 25px);
            margin-left: 7px;
        }

        .notice {
            font-size: 12px;
            font-weight: 600;
        }
    }

    .supplementaryList {
        flex-basis: 100%;
        display: flex;
        gap: 3px;


        li {
            flex-grow: 1;
            border: solid 2px var(--main-color02);
            font-size: clamp(15px, 4vw, 20px);
            font-weight: 900;
            color: var(--main-color02);
            display: flex;
            justify-content: center;
            align-items: center;
            background-color: var(--white);
            border-radius: 5px;
        }
    }

    .button {
        border-top: dashed 1px var(--white);
        padding-top: 10px;
        margin-top: 10px;

        a {
            display: flex;
            font-size: clamp(15px, 4vw, 20px);
            justify-content: center;
            align-items: center;
            max-width: 400px;
            margin-inline: auto;
            border-radius: 100vh;
            background-color: rgba(0, 0, 0, 0.4);
            color: var(--white);
            font-weight: 700;
            padding: 10px 15px;
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }


}

/*-------------------.menuArchive-----------------*/
.menuArchive {
    padding-top: 50px;

    h2 {
        text-align: center;
        color: var(--main-color02);
        font-size: clamp(50px, 10vw, 70px);
        font-weight: 900;
    }

    .menuArchiveBlock {
        padding: 10px;
        margin-top: 30px;

        &.building_demolition {
            background-color: var(--sub-color04);
        }

        &.small {
            background-color: #ffa302;
        }

        &.others {
            background-color: #ff7887;
        }
        &.interior_demolition {
            background-color: #51bb7b;
        }

        &+& {
            margin-top: 50px;
        }
    }

    .menuArchiveList {

        &.type1 {
            display: grid;
            gap: 15px 10px;
            grid-template-columns: 1fr;

            /*@media (min-width:500px) {
                grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
            } */

            h3 {
                color: var(--white);
                background-color: var(--main-color02);
                font-weight: 900;
                font-size: clamp(18px, 3vw, 25px);
                padding: 10px;
            }

            .block {
                flex-grow: 1;
            }

            .image {
                display: flex;
                gap: 10px;
                height: 100%;
                width: 100%;
                > * {
                    flex: 1;
                    max-height: 204px;
                }
                @media (min-width:1000px) {
                    width: 50%;
                }
            }
        }

        &.type2 {
            display: grid;
            gap: 1px;
            grid-template-columns: 1fr;

            @media (min-width:800px) {
                grid-template-columns: repeat(2, 1fr);

            }

            .menuArchiveItem {
                padding: 10px;
            }

            .subTitle {
                color: var(--white);
                background-color: var(--main-color02);
                text-align: center;
                font-weight: 900;
            }

            h3 {
                color: var(--main-color02);
                background-color: var(--sub-color05);
                text-align: center;
                font-weight: 900;
                font-size: clamp(20px, 7.5vw, 30px);

                span {
                    font-size: clamp(16px, 4vw, 22px);
                }
            }

            .priceBox {
                padding-bottom: 10px;
            }

            .price {
                justify-content: center;

                @media (min-width:1200px) {
                    justify-content: flex-start;
                }
            }

            .column {
                display: flex;
                align-items: flex-start;
                gap: 5px;
                flex-wrap: wrap;

                @media (min-width:1200px) {
                    flex-wrap: nowrap;

                }
            }

            .leftBlock {
                flex-grow: 1;
            }

            .rightBlock {
                width: 100%;
                height: 150px;

                @media (min-width:1200px) {
                    width: 280px;
                    height: 100%;
                }

                .image {
                    width: 100%;
                    height: 100%;
                }

                img {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                }
            }

            .priceBox {
                display: block;
                padding: 0;
            }

            .notice {
                text-align: center;

                @media (min-width:1200px) {
                    text-align: left;
                }
            }
        }
        &.type3 {
            display: grid;
            gap: 1px;
            grid-template-columns: 1fr;

            .menuArchiveItem {
                padding: 10px;
            }

            .subTitle {
                color: var(--white);
                background-color: var(--main-color02);
                text-align: center;
                font-weight: 900;
            }

            h3 {
                color: var(--main-color02);
                background-color: var(--sub-color05);
                /* text-align: center; */
                font-weight: 900;
                font-size: clamp(20px, 7.5vw, 30px);
                line-height: 1.233 !important;
                padding: 10px;

                span {
                    font-size: clamp(16px, 4vw, 22px);
                }
            }

            .priceBox {
                padding-bottom: 10px;
            }

            .price {
                justify-content: center;
                /* justify-content: flex-start; */

                @media (min-width:1200px) {
                    justify-content: flex-start;
                }
            }

            .column {
                display: flex;
                flex-direction: column;
                align-items: stretch;
                gap: 10px;
                flex-wrap: wrap;
                > * {
                    /* flex: 1; */
                }

                @media (min-width:1200px) {
                    flex-wrap: nowrap;
                    flex-direction: row;
                    gap: 0;
                }
            }

            .leftBlock {
                /* flex-grow: 1; */
                width: 100%;
            }

            .rightBlock {
                /* width: 100%; */
                width: 100%;
                /* height: 150px; */

                /* @media (min-width:1200px) {
                    width: 280px;
                    height: 100%;
                } */

                /* .image {
                    width: 100%;
                    height: 100%;
                } */
                .image {
                    display: flex;
                    gap: 10px;
                    height: 100%;
                    /* width: 50%; */
                    > * {
                        flex: 1;
                        /* max-height: 204px; */
                    }
                }
                img {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                }
            }
            @media (min-width:1200px) {

                .leftBlock,
                .rightBlock {
                    width: 50%;
                }

                .leftBlock {
                    padding-right: 10px;
                    box-sizing: border-box;
                }

            }

            .priceBox {
                display: block;
                padding: 0;
            }

            .notice {
                text-align: center;

                @media (min-width:1200px) {
                    text-align: left;
                }
            }
        }
    }

    .menuArchiveItem {
        background-color: var(--white);
    }

    .menuArchiveItem+.menuArchiveLabel {
        margin-top: 15px;
    }

    .menuArchiveLabel {
        font-size: clamp(18px, 3vw, 25px);
        background-color: var(--main-color02);
        font-weight: 900;
        color: var(--white);
        padding: 10px;
        line-height: 1.3;

        @media (min-width:800px) {
            grid-column: 1/3;
        }
    }



    .chara4 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 4px;

        .chara {
            line-height: 0.75;
            aspect-ratio: 1;
            width: clamp(80px, 19vw, 100px);
            height: auto;
            background-color: var(--sub-color05);
            color: var(--main-color02);
            font-size: clamp(54px, 18vw, 80px);
            font-weight: 900;
            display: flex;
            justify-content: center;
            align-items: center;
        }
    }

    .image {
        height: 150px;
        border-top: solid 1px var(--white);

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .priceBox {
        line-height: 1;
        display: flex;
        flex-wrap: wrap;
        align-items: flex-end;
        justify-content: center;
        padding: 10px;
        gap: 10px;

        @media (min-width:1000px) {
            flex-wrap: nowrap;
            justify-content: space-between;
        }


        .price {
            display: flex;
            align-items: flex-end;
            justify-content: center;

            @media (min-width:400px) {
                justify-content: flex-start;

            }

        }

        .price1 {
            font-size: clamp(90px, 15vw, 160px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 0.8;
        }

        .price2 {
            font-size: clamp(65px, 12vw, 100px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 0.8;

        }

        .price3 {
            font-size: clamp(65px, 12vw, 100px);
            font-family: "Barlow Condensed", sans-serif;
            font-weight: 700;
            color: var(--sub-color01);
            line-height: 0.8;
        }

        .price4 {
            font-weight: 900;
            color: var(--sub-color01);
            line-height: 1;
            font-size: clamp(27px, 5.5vw, 30px);
            margin-left: 7px;
        }

        .notice {
            font-size: 12px;
            font-weight: 600;
            margin-top: 10px;
            text-align: center;

            @media (min-width:400px) {
                text-align: left;
            }

            br {
                display: none !important;
            }
        }
    }

    .supplementaryList {
        flex-basis: 100%;
        display: flex;
        gap: 5px;
        margin-top: 10px;

        li {
            flex-grow: 1;
            border: solid 3px var(--main-color02);
            font-size: clamp(15px, 4vw, 20px);
            font-weight: 900;
            color: var(--main-color02);
            display: flex;
            justify-content: center;
            align-items: center;
            background-color: var(--white);
            border-radius: 5px;
            padding: 5px 10px;
        }
    }

    .button {
        border-top: dotted 1px var(--white);
        padding-top: 10px;
        margin-top: 10px;

        a {
            display: flex;
            font-size: clamp(15px, 4vw, 20px);
            justify-content: center;
            align-items: center;
            max-width: 400px;
            margin-inline: auto;
            border-radius: 100vh;
            background-color: rgba(0, 0, 0, 0.4);
            color: var(--white);
            font-weight: 900;
            padding: 10px 15px;
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }
}

/*-------------------.menuAfter-----------------*/
.menuAfter {
    .menuAfterService {
        h2 {
            color: var(--main-color02);
            font-size: clamp(40px, 10vw, 70px);
            text-align: center;
            font-weight: 900;
        }

        .lead {
            color: var(--main-color02);
            font-size: clamp(18px, 3vw, 25px);
            text-align: center;
            font-weight: 900 !important;
            margin-top: 30px;
        }

        .afterBox {
            margin-top: 50px;
            display: flex;
            align-items: flex-start;
            justify-content: center;
            flex-wrap: wrap;
            gap: clamp(30px, 8vw, 50px);

            .image {
                text-align: center;
            }

            .text {
                flex-grow: 1;
            }
        }

        h3 {
            color: var(--main-color03);
            font-weight: 900;
            font-size: clamp(18px, 2.8vw, 32px);

        }

        ul {
            margin-top: 15px;
        }

        li {
            position: relative;
            padding-left: calc(0.5em + 10px);

            &::before {
                content: '';
                width: 0.5em;
                height: 0.5em;
                background-color: var(--main-color03);
                position: absolute;
                left: 0;
                top: 12px;
            }
        }
    }


    .redBaloon {
        margin-top: 50px;
        font-size: clamp(18px, 5vw, 45px);
        color: white;
        background-color: var(--sub-color01);
        border-radius: 100px;
        padding: 20px 40px;
        position: relative;
        text-align: center;
        line-height: 1.3;
        font-weight: 900;
        z-index: 1;

        span {
            display: block;
            font-size: clamp(18px, 3vw, 25px);
            margin-top: 5px;
        }

        &::before {
            content: '';
            position: absolute;
            bottom: -30px;
            left: calc(50% - 18px);
            width: 36px;
            height: 32px;
            background-color: var(--sub-color01);
            clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
        }
    }

    .demeritPoint {
        margin-top: 15px;
        padding: 50px 0;
        background-color: var(--sub-color06);

        &.limeDotBar {
            position: relative;
            z-index: 0;
            padding-top: 60px;

            &::before {
                content: '';
                position: absolute;
                top: 0;
                left: 0;
                background: url(./img/bg_limedot.gif);
                width: 100%;
                height: 250px;
                z-index: -1;
            }
        }

        h2 {
            font-size: clamp(30px, 8vw, 50px);
            color: var(--main-color02);
            text-align: center;

            .underLine {
                position: relative;
                display: inline-block;
                font-weight: 900;

                &::before {
                    content: '';
                    position: absolute;
                    bottom: 0px;
                    left: 0;
                    width: 100%;
                    height: 10px;
                    background-color: var(--main-color03);
                    z-index: -1;
                }
            }
        }

        h2+.pointBox {
            margin-top: 50px;
        }

        .pointBox {
            border: solid 6px var(--main-color03);
            border-radius: 10px;
            background-color: var(--white);

            &+& {
                margin-top: 40px;
            }

            h3 {
                background-color: var(--main-color03);
                padding: 4px 15px 10px;
                text-align: center;
                font-size: clamp(18px, 2.8vw, 32px);
                color: var(--white);
                font-weight: 900;
            }

            .box {
                padding: clamp(30px, 8vw, 50px);

                @media (min-width:1000px) {
                    display: flex;
                    gap: 40px;
                }
            }

            .image {
                text-align: center;
                flex-basis: 350px;
                flex-shrink: 0;
            }

            .text {
                flex-grow: 1;
            }
        }

        .illustBox {
            margin-top: 50px;
            position: relative;
            padding-bottom: 150px;
            max-width: 800px;
            margin-inline: auto;

            &.inner {
                padding: 0 0 150px;
            }

            p {
                font-size: clamp(18px, 3vw, 25px);
                color: var(--main-color02);
                font-weight: 800 !important;
                text-align: center;

                span {
                    color: var(--sub-color01);
                }
            }

            &::before {
                content: '';
                position: absolute;
                left: 0;
                bottom: -50px;
                width: calc(312px * 0.6);
                height: calc(250px * 0.6);
                background: url(./img/bg_first_point01.png) no-repeat center/contain;
                z-index: -1;
            }

            &::after {
                content: '';
                position: absolute;
                right: 0;
                bottom: -50px;
                width: calc(220px * 0.6);
                height: calc(250px * 0.6);
                background: url(./img/bg_first_point02.png) no-repeat center/contain;
                z-index: -1;
            }

            @media (min-width:1200px) {
                padding-bottom: 0;
                max-width: none;

                &::before {
                    content: '';
                    position: absolute;
                    left: 0;
                    bottom: -50px;
                    width: 312px;
                    height: 250px;
                    background: url(./img/bg_first_point01.png) no-repeat center/contain;
                }

                &::after {
                    content: '';
                    position: absolute;
                    right: 0;
                    bottom: -50px;
                    width: 220px;
                    height: 250px;
                    background: url(./img/bg_first_point02.png) no-repeat center/contain;
                }
            }
        }
    }
}


/*-------------------.topWorks-----------------*/
.topWorks {
    .pickupTitle1 {
        text-align: center;
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;
        color: var(--white);
        background-color: var(--main-color02);
        width: fit-content;
        margin-inline: auto;
        padding: 10px 10px;
        line-height: 1.2;
        border-radius: 5px;

        span {
            color: var(--main-color01);
        }
    }

    .pickupTitle2 {
        font-size: clamp(27px, 9vw, 44px);
        font-weight: 900;
        color: var(--main-color02);
        text-align: center;
        margin-top: 10px;

        strong {
            font-size: clamp(40px, 12vw, 70px);
            display: inline-block;
        }

        span {
            color: var(--sub-color01);
            font-weight: 900;
        }
    }

    .pickupTitle3 {
        text-align: center;
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;
        color: var(--main-color02);
        margin-top: 20px;
        position: relative; 
        display: flex;
        width: fit-content;
        align-items: center;
        padding-left: 1.5em;
        padding-right: 1.5em;
        margin-inline: auto;
        letter-spacing: -0.05em;

        @media (min-width:600px) {
            letter-spacing: 0;
        }

        &::before {
            content: '';
            position: absolute;
            left: 1em;
            top: calc(50% - 0.5em);
            width: 2px;
            height: 1em;
            background-color: var(--main-color02);
            rotate: -45deg;
            transform-origin: 50% 100%;
        }

        &::after {
            content: '';
            position: absolute;
            right: 1em;
            top: calc(50% - 0.5em);
            width: 2px;
            height: 1em;
            background-color: var(--main-color02);
            rotate: 45deg;
            transform-origin: 50% 100%;
        }

        span {
            position: relative;
            line-height: 1.25;

            &::before {
                content: '';
                position: absolute;
                bottom: 0px;
                left: 0;
                z-index: -1;
                width: 100%;
                height: 10px;
                background-color: var(--sub-color05);
            }

        }
    }
    .pickupTitle3 + .topWorksList {
        margin-bottom: 60px;
    }
    .topWorksList+.contentTitle {
        margin-top: 60px;
    }

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            width: 136px;
            padding: 2px 0;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
            text-transform: uppercase;
        }
    }

    .topWorksList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 30px;
        margin-top: 25px;
    }

    .topWorksAnker {
        display: block;
        background-color: var(--main-color02);
        padding-bottom: 10px;

        &:hover {
            opacity: 0.7;
        }
    }

    .topWorksTitle {
        color: var(--white);
        text-align: center;
        margin-top: 10px;
        font-weight: 500;
    }

    .topWorksFig {
        /* max-height: 250px; */
        contain: paint;
        width: 100%;
        height: auto;
        aspect-ratio: 380 / 250;

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .recommend {
        position: relative;
        &::before{
            content: "";
            display: block;
            position: absolute;
            inset: 0;
            width: 100%;
            height: 100%;
            box-sizing: border-box;
            border: solid 5px var(--main-color01);
            z-index: 1;
        }
        &::after {
            content: 'おすすめ!!';
            position: absolute;
            z-index: 2;
            right: -60px;
            bottom: 24px;
            background-color: var(--sub-color01);
            color: var(--white);
            font-weight: 900;
            width: 200px;
            text-align: center;
            rotate: -45deg;
        }
    }

    .topWorksDetail {
        color: var(--white);
        text-align: center;
        width: fit-content;
        margin: 10px auto 0;
        border: solid 1px var(--white);
        padding: 2px 10px;
        font-size: 14px;
        line-height: 1.5;
    }

    .topWorksButton {
        border-top: dotted 1px #333;
        padding-top: 20px;
        margin-top: 50px;

        a {
            display: block;
            max-width: 500px;
            margin-inline: auto;
            border-radius: 100px;
            background-color: var(--main-color01);
            color: var(--main-color02);
            font-weight: 900;
            text-align: center;
            padding: 10px;
            font-size: clamp(15px, 4vw, 20px);
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }

    .taxArea {
        max-width: 950px;
        margin-inline: auto;
        margin-top: 40px;
    }

    .taxAreaList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
        gap: 10px;
    }

    .taxAreaAnker {
        display: flex;
        color: var(--white);
        background: url(./img/ico_arrow_white02.png) no-repeat left 13px center #31444d;
        gap: 15px;
        justify-content: space-between;
        align-items: center;
        line-height: 1;
        padding: 10px 15px 10px 35px;
        font-weight: 900;
        font-size: 18px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        span {
            color: var(--main-color02);
            background-color: var(--white);
            border-radius: 10px;
            padding: 5px 10px;
            font-size: 15px;
        }
    }

    .taxMenu {
        max-width: 950px;
        margin-inline: auto;
        margin-top: 10px;
    }

    .taxMenuList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(182px, 1fr));
        gap: 10px;
    }

    .taxMenuAnker {
        display: flex;
        color: var(--white);
        background: url(./img/ico_arrow_white02.png) no-repeat left 13px center #f3722e;
        gap: 5px;
        justify-content: space-between;
        align-items: center;
        line-height: 1;
        padding: 10px 15px 10px 35px;
        font-weight: 900;
        font-size: 17px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        span {
            color: #f3722e;
            background-color: var(--white);
            border-radius: 10px;
            padding: 5px 10px;
            font-size: 15px;
        }
    }
}

/*-------------------.reasonWorks-----------------*/
.reasonWorks {
    padding: 70px 0 60px;

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            width: 136px;
            padding: 2px 0;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
        }
    }

    .reasonWorksWrapper {
        /* margin-inline: calc(-50vw + 50%); */
    }

    .reasonWorksList {
        /* display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 30px; */
        margin-top: 25px;
    }

    .reasonWorksItem {
        max-width: 380px;
    }

    .reasonWorksAnker {
        display: block;
        background-color: var(--main-color02);
        padding-bottom: 10px;

        &:hover {
            opacity: 0.7;
        }
    }

    .reasonWorksTitle {
        color: var(--white);
        text-align: center;
        margin-top: 10px;
    }

    .reasonWorksFig {
        max-height: 250px;
        contain: paint;

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .reasonWorksDetail {
        color: var(--white);
        text-align: center;
        width: fit-content;
        margin: 10px auto 0;
        border: solid 1px var(--white);
        padding: 2px 5px;
        font-size: 14px;
    }

    .reasonWorksButton {
        margin-top: 50px;

        a {
            display: block;
            max-width: 500px;
            margin-inline: auto;
            border-radius: 100px;
            background-color: var(--main-color01);
            color: var(--main-color02);
            font-weight: 900;
            text-align: center;
            padding: 10px;
            font-size: clamp(15px, 4vw, 20px);
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }

    .prevButtonWorks {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        left: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        rotate: 180deg;
        cursor: pointer;

        @media (min-width:1200px) {
            left: calc(50% - 600px - 25px);
        }

        &:hover {
            opacity: 0.7;
        }
    }

    .nextButtonWorks {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        right: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        cursor: pointer;

        @media (min-width:1200px) {
            right: calc(50% - 600px - 25px);
        }

        &:hover {
            opacity: 0.7;
        }
    }
}

.reasonVoice {
    padding: 50px 0 70px;
}


/*-------------------.menuWorks-----------------*/
.menuWorks {
    padding: 70px 0 60px;
    margin-inline: calc(-50vw + 50%) !important;

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        @media (min-width:1000px) {
            max-width: 1200px;
            margin-inline: auto;
            padding-block: 33px;

            &.building_demolition {
                background: url(./img/img_menu_fukidashi01.png) no-repeat left top;
            }

            &.small {
                background: url(./img/img_menu_fukidashi02.png) no-repeat left top;
            }

            &.others {
                background: url(./img/img_menu_fukidashi03.png) no-repeat left top;
            }
            &.interior_demolition {
                background: url(./img/img_menu_fukidashi04.png) no-repeat left top;
            }
        }

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            width: 136px;
            padding: 2px 0;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
        }
    }

    .menuWorksWrapper {
        /* margin-inline: calc(-50vw + 50%); */
    }

    .menuWorksList {
        /* display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 30px; */
        margin-top: 25px;

        @media (min-width:1000px) {
            margin-top: 0;
        }
    }

    .menuWorksItem {
        max-width: 380px;
    }

    .menuWorksAnker {
        display: block;
        background-color: var(--main-color02);
        padding-bottom: 10px;

        &:hover {
            opacity: 0.7;
        }
    }

    .menuWorksTitle {
        color: var(--white);
        text-align: center;
        margin-top: 10px;
    }

    .menuWorksFig {
        max-height: 250px;
        contain: paint;

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .menuWorksDetail {
        color: var(--white);
        text-align: center;
        width: fit-content;
        margin: 10px auto 0;
        border: solid 1px var(--white);
        padding: 2px 5px;
        font-size: 14px;
    }

    .menuWorksButton {
        margin-top: 50px;

        a {
            display: block;
            max-width: 500px;
            margin-inline: auto;
            border-radius: 100px;
            background-color: var(--main-color02);
            color: var(--white);
            font-weight: 900;
            text-align: center;
            padding: 10px;
            font-size: clamp(15px, 4vw, 20px);
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }

    .prevButtonWorks {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        left: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        rotate: 180deg;
        cursor: pointer;

        @media (min-width:1200px) {
            left: calc(50% - 600px - 25px);
        }

        &:hover {
            opacity: 0.7;
        }
    }

    .nextButtonWorks {
        z-index: 1;
        position: absolute;
        width: 50px;
        height: 50px;
        top: calc(50% - 25px);
        right: 5px;
        border-radius: 100vh;
        background: url(./img/ico_arrow_white01.png) no-repeat center/auto var(--main-color02);
        cursor: pointer;

        @media (min-width:1200px) {
            right: calc(50% - 600px - 25px);
        }

        &:hover {
            opacity: 0.7;
        }
    }
}

/*-------------------.topReason-----------------*/
.topReason {
    .green {
        color: var(--main-color03);
    }

    .red {
        color: var(--sub-color01);
    }

    .yellow {
        color: var(--sub-color05);
    }

    .subTitle {
        font-size: clamp(60px, 14vw, 80px);
        text-align: center;
        font-weight: 900;
        color: var(--white);
        margin-bottom: -30px;
        line-height: 1;
    }

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        text-align: center;
        font-weight: 900;

    }

    .reasonBox {
        position: relative;
        padding-bottom: 34vw;
        background: #fff left bottom / contain url(./img/bg_reason_sp.jpg) no-repeat;
        margin-top: 20px;
        border-radius: 10px;

        @media (min-width:1200px) {
            contain: paint;
            padding-bottom: 0;
            background: url(./img/bg_reason.jpg) no-repeat center/cover var(--white);
        }

        .reasonList {
            text-align: center;
            padding: 30px 0;

            li {
                font-size: clamp(18px, 3vw, 25px);
                border-bottom: dotted 1px #333;
                width: fit-content;
                margin: 0 auto;
                font-weight: 900;
                text-shadow: rgb(255, 255, 255) 3px 0px 0px, rgb(255, 255, 255) 2.83487px 0.981584px 0px, rgb(255, 255, 255) 2.35766px 1.85511px 0px, rgb(255, 255, 255) 1.62091px 2.52441px 0px, rgb(255, 255, 255) 0.705713px 2.91581px 0px, rgb(255, 255, 255) -0.287171px 2.98622px 0px, rgb(255, 255, 255) -1.24844px 2.72789px 0px, rgb(255, 255, 255) -2.07227px 2.16926px 0px, rgb(255, 255, 255) -2.66798px 1.37182px 0px, rgb(255, 255, 255) -2.96998px 0.42336px 0px, rgb(255, 255, 255) -2.94502px -0.571704px 0px, rgb(255, 255, 255) -2.59586px -1.50383px 0px, rgb(255, 255, 255) -1.96093px -2.27041px 0px, rgb(255, 255, 255) -1.11013px -2.78704px 0px, rgb(255, 255, 255) -0.137119px -2.99686px 0px, rgb(255, 255, 255) 0.850987px -2.87677px 0px, rgb(255, 255, 255) 1.74541px -2.43999px 0px, rgb(255, 255, 255) 2.44769px -1.73459px 0px, rgb(255, 255, 255) 2.88051px -0.838247px 0px;
                &:nth-of-type(4){
                    letter-spacing: -0.1em;
                    @media (min-width:600px) {
                        letter-spacing: 0;
                    }
                }
            }

        }
    }
}

.topPermit {
    margin-top: 65px;

    .permitTitle {
        text-align: center;
    }

    .permitImage {
        width: fit-content;
        margin: 15px auto 0;
        position: relative;

        &::before {
            content: '';
            position: absolute;
            width: 331px;
            height: 228px;
            background: url(./img/img_permitIllustLeft.png) no-repeat center/contain;
            left: -50px;
            bottom: 0px;
            scale: 0.5;
            transform-origin: 0% 100%;
        }

        &::after {
            content: '';
            position: absolute;
            width: 309px;
            height: 242px;
            background: url(./img/img_permitIllustRight.png) no-repeat center/contain;
            right: -205px;
            bottom: 0px;
            scale: 0.5;
            transform-origin: 0% 100%;
        }

        @media (min-width:1000px) {
            &::before {
                scale: 1;
                left: -285px
            }

            &::after {
                scale: 1;
                right: -263px;
            }

        }


    }
}

.topDakara {
    margin: 10px 0 25px;
    .topPermit + & {
        margin-top: 0;
    }
    .inner{
        max-width: 1000px;
    }

    .dakaraTitle {
        color: var(--white);
        background-color: var(--main-color02);
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;
        text-align: center;
        padding: 10px 5px;
        border-radius: 5px;
    }

    .dakaraList {
        background-color: var(--white);
        padding: clamp(15px, 6vw, 40px);
        border-radius: 10px;
        margin-top: 20px;

        .dakaraItem {
            padding-left: 30px;
            position: relative;
            font-size: 18px;

            &::before {
                content: '' !important;
                display: block;
                position: absolute;
                left: 0;
                top: 8px;
                width: 18px;
                height: 18px;
                background: url(./img/ico_arrow_lime.png) no-repeat center/contain;
            }
        }

        .dakaraItem+.dakaraItem {
            margin-top: 5px;
        }


    }
}


/*-------------------.topMessage-----------------*/

.topMessage {
    padding: 50px 0;

    .msgArea {
        display: grid;
        grid-template-columns: 1fr;
        gap: 50px;
        margin-top: 50px;

        @media (min-width:1024px) {
            grid-template-columns: 1fr auto;
        }
    }

    .msgTitle {
        color: var(--main-color02);
        font-size: clamp(18px, 2.8vw, 32px);
        font-weight: 900;
    }

    .msgTxt {
        margin-top: 50px;
    }

    .msgPhoto {
        width: 300px;
        margin-inline: auto;
    }

    .msgPhoto img {
        height: 340px;
        width: 100%;
        object-fit: cover;
    }

    .president {
        background-color: var(--main-color02);
        text-align: center;
        color: var(--white);
        padding: 10px;
        line-height: 1.2;
        font-weight: 900;
    }

    .corp {
        font-size: 15px;
    }

    .name {
        font-size: 24px;
        margin-top: 5px;
    }
}

.topMessage2 {
    padding: 50px 0;
    background-color: #f6f6f6;

    .msgArea {
        display: grid;
        grid-template-columns: 1fr;
        gap: 50px;

        @media (min-width:1024px) {
            grid-template-columns: 1fr auto;
        }
    }

    .msgTitle {
        color: var(--main-color02);
        font-size: clamp(18px, 3vw, 25px);
    }

    .msgTxt {
        margin-top: 30px;
        font-size: clamp(15px, 4vw, 20px);
        color: var(--main-color02);
    }

    .msgPhoto {
        width: 300px;
        margin-inline: auto;
    }

    .msgPhoto img {
        height: 340px;
        width: 100%;
        object-fit: cover;
    }

    .president {
        background-color: var(--main-color02);
        text-align: center;
        color: var(--white);
        padding: 10px;
        line-height: 1.2;
        font-weight: 900;
    }

    .corp {
        font-size: 15px;
    }

    .name {
        font-size: 24px;
        margin-top: 5px;
    }

    .msgTel {
        margin-top: 30px;

        .row1 {
            display: flex;
            flex-wrap: wrap;
            align-items: center;
            font-size: clamp(18px, 3vw, 25px);
            color: var(--main-color02);
            font-weight: 900;
            line-height: 1.3;

            .block {
                color: var(--white);
                background-color: var(--main-color02);
                border-radius: 5px;
                padding: 2px 15px;
                margin-right: 5px;
            }

            .red {
                color: var(--sub-color01);
            }

        }

        .tel {
            margin-top: 10px;
            display: flex;
            align-items: flex-end;
            gap: 0px 15px;
            flex-wrap: wrap;
            justify-content: flex-start;
        }

        .tel-link {
            font-size: clamp(40px, 5.5vw, 56px) !important;
            font-weight: bold;
            color: var(--main-color02);
            display: flex;
            gap: 10px;
            align-items: center;

            &::before {
                content: '';
                width: 38px;
                height: 40px;
                background: url(./img/ico_tel00.png) no-repeat center / cover;
            }
        }
    }





}

/*-------------------.topUnderNav-----------------*/
.topUnderNav {
    padding: 0 0 50px;
    max-width: 1200px;

    .inner {
        display: grid;
        gap: 30px;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));

    }

    .bannerAnker {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: 1fr;
        gap: 0;
        align-items: flex-end;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }
    }

    .img {
        grid-column: 1/2;
        grid-row: 1/2;
        z-index: 1;

        img {
            width: 100%;
        }
    }

    .text {
        grid-column: 1/2;
        grid-row: 1/2;
        z-index: 2;
        color: var(--main-color02);
        background-color: var(--main-color01);
        font-weight: 900;
        padding: 3px 15px;
        font-size: clamp(18px, 3vw, 25px);
    }
}

/*-------------------.topPoint-----------------*/
.topPoint {
    background: url(./img/img_greenStripeBar.png) repeat-x left top;
    padding: 60px 0 40px;

    .contentTitle {
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;
        text-align: center;
        width: fit-content;
        background-color: var(--main-color02);
        color: var(--white);
        padding: 5px 20px;
        border-radius: 5px;
        margin-inline: auto;
   }

    .title2 {
        text-align: center;
        font-size: clamp(30px, 7vw, 44px);
        color: var(--main-color02);
        margin-top: 20px;
        font-weight: 900;
        line-height: 1.2;
        letter-spacing: -0.05em;
    }

    .title3 {
        text-align: center;
        font-size: clamp(50px, 10vw, 70px);
        color: var(--main-color02);
        font-weight: 900;
        line-height: 1.2;

        span {
            color: var(--sub-color01);
        }
    }

    .pointList {
        margin-top: 30px;
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 30px;
        padding-bottom: 20px;
        border-bottom: dotted 1px #333;

        img {
            width: 100%;
        }
    }

    .pointText {
        margin-top: 15px;
    }


    .greenButton {
        margin-top: 20px;

        a {
            display: block;
            max-width: 500px;
            margin-inline: auto;
            border-radius: 100px;
            background-color: var(--main-color01);
            color: var(--main-color02);
            font-weight: 900;
            text-align: center;
            padding: 10px;
            font-size: clamp(15px, 4vw, 20px);
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }
}

/*-------------------.topArea-----------------*/
.topArea {
    background-color: #f6f6f6;
    padding: 30px 0 50px;

    .green {
        color: var(--main-color03);
    }

    .red {
        color: var(--sub-color01);
    }

    .yellow {
        color: var(--sub-color05);
    }

    .subTitle {
        font-size: clamp(60px, 14vw, 80px);
        text-align: center;
        font-weight: 900;
        color: #dfdfdf;
        margin-bottom: -30px;
        line-height: 1;
    }

    .contentTitle {
        font-size: clamp(27px, 9vw, 40px);
        text-align: center;
        font-weight: 900;
    }

    .areaLabel {
        text-align: center;
        width: fit-content;
        margin: 20px auto 0;
        background-color: var(--main-color01);
        color: var(--main-color02);
        font-weight: 900;
        padding: 0 20px;
        font-size: clamp(15px, 4vw, 20px);
        line-height: 1.5;
    }

    .areaTitle {
        text-align: center;
        font-size: clamp(18px, 3vw, 25px);
        color: var(--main-color02);
        font-weight: 900;
        margin-top: 10px;
    }

    .gridBox {
        margin-top: 50px;
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;

        @media (min-width:1024px) {
            grid-template-columns: auto 1fr;

        }

        img {
            display: block;
            width: fit-content;
            margin-inline: auto;
        }
    }
}

/*-------------------.topVacant-----------------*/
.topVacant {
    padding: 55px 15px 50px;

    .red {
        color: var(--sub-color01);
    }

    /* .lime {
        color: var(--main-color02);
    } */

    .vacantInner {
        max-width: 1600px;
        margin: 0 auto;
    }

    .contentTitle {
        font-size: clamp(45px, 10vw, 70px);
        text-align: center;
        font-weight: 900;
        color: var(--main-color02);
        letter-spacing: -0.05em;
    }

    .subTitle {
        background-color: var(--main-color02);
        color: var(--white);
        padding: 5px 40px;
        border-radius: 5px;
        width: fit-content;
        margin: 10px auto;
        font-size: clamp(20px, 7.5vw, 30px);
        font-weight: 900;
        line-height: 1.3;
    }

    .vacantBox {
        margin-top: 70px;


        @media (min-width:900px) {
            display: flex;
            gap: 40px;

            .image {
                flex-basis: min(700px, 50%);
                flex-shrink: 1;
            }

            .text {
                flex-basis: 50%;
                flex-grow: 1;
            }

            &:nth-child(2n) {
                flex-direction: row-reverse;
            }

        }

        h3 {
            font-size: clamp(30px, 8vw, 50px);
            font-weight: 900;
            color: var(--main-color02);
            margin-top: 15px;
            margin-bottom: 10px;

            @media (min-width:900px) {
                margin-top: 0;
            }
        }

        .image {
            text-align: center;
        }
    }
}

/*-------------------.bnrList01-----------------*/
#contents .bnrList01 {
    margin: 0 auto 60px;
    padding-top: 30px;
}

#top #contents .bnrList01 {
    margin-bottom: 0;
    padding-bottom: 0;
}

.bnrList01 .swipswiperTopBnrer {
    width: 100%;
    margin: auto;
}

.bnrList01 .swiperTopBnr .swiper-button-next,
.bnrList01 .swiperTopBnr .swiper-button-prev {
    width: 33px;
    height: 55px;
}

.bnrList01 .swiperTopBnr .swiper-button-next::after,
.bnrList01 .swiperTopBnr .swiper-button-prev::after {
    content: none;
}

.bnrList01 .swiperTopBnr .swiper-button-next {
    background: url(./img/arrowR.png) no-repeat;
}

.bnrList01 .swiperTopBnr .swiper-button-prev {
    background: url(./img/arrowL.png) no-repeat;
}

.bnrList01 .swiper-container {
    width: 1032px;
}

.bnrList01 .mainBtnList {
    margin: 0 auto !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-align-items: center;
    align-items: center;
    overflow: visible;
}

#main .bnrList01 li {
    margin: 0;
    padding: 0 66px;

    text-align: center;
}

.bnrList01 li::before {
    display: none !important;
}

.bnrList01 li img {
    width: 100%;
    height: auto;
    object-fit: contain;
    border: 1px solid #ccc;
}

.bnrList01 li p {
    width: 180px;
    height: 180px;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    font-size: 16px;
    font-weight: 500;
}


/*-------------------.pageFirst-----------------*/
.pageFirst {
    .firstNotice {
        padding: 50px 0;
        background-color: #f6f6f6;

        .inner {
            @media (min-width:1000px) {
                display: flex;
                gap: 40px;
            }

            h2 {
                font-size: clamp(18px, 3vw, 25px);
                color: var(--main-color02);
                --h2Height: 60px;
                padding-left: calc(var(--h2Height) + 25px);
                height: var(--h2Height);
                background: url(./img/ico_first.png) no-repeat left center/contain;
                display: flex;
                align-items: center;

                @media (min-width:1000px) {
                    --h2Height: 120px;
                }

            }

            .image {
                text-align: center;
                flex-basis: 450px;
                flex-shrink: 0;
            }

            h2+p {
                margin-top: 20px;
            }

            p {
                font-size: clamp(15px, 4vw, 20px);
                color: var(--main-color02);
                font-weight: 600;
            }
        }
    }

    .firstChoice {
        padding: 50px 0;

        h2 {
            font-size: clamp(50px, 10vw, 70px);
            color: var(--main-color02);
            text-align: center;
            font-weight: 900;

            .red {
                color: var(--sub-color01);
                display: inline-block;
            }
        }

        .box {
            margin-top: 30px;

            @media (min-width:1000px) {
                display: flex;
                gap: 40px;
                flex-direction: row-reverse;
            }
        }

        .image {
            text-align: center;
            flex-basis: 450px;
            flex-shrink: 0;
        }

        h3 {
            font-size: clamp(18px, 3vw, 25px);
            color: var(--main-color02);
            font-weight: 900;
        }

        h3+p {
            margin-top: 15px;
        }

        .text {
            margin-top: 20px;
        }
    }

    .firstPoint {
        padding: 50px 0;
        background-color: var(--sub-color06);

        h2 {
            font-size: clamp(30px, 8vw, 50px);
            /* color: var(--white); */
            text-align: center;

            .underLine {
                position: relative;
                display: inline-block;
                font-weight: 900;

                &::before {
                    content: '';
                    position: absolute;
                    bottom: 0px;
                    left: 0;
                    width: 100%;
                    height: 10px;
                    background-color: var(--main-color03);
                    z-index: -1;
                }
            }
        }

        .pointBox {
            margin-top: 50px;
            background-color: var(--white);
            border-radius: 20px;
            padding: clamp(15px, 4vw, 40px);
            box-shadow: 0px 5px 0px var(--main-color02);

            .box {
                margin-top: clamp(15px, 4vw, 40px);

                @media (min-width:1000px) {
                    display: flex;
                    gap: 40px;
                }
            }

            &:nth-child(2n+1) .box {
                flex-direction: row-reverse;
            }

            h3 {
                /* color: var(--main-color03); */
                color: var(--main-color03);
                text-align: center;
                font-weight: 900;
                font-size: clamp(18px, 2.8vw, 32px);

                span {
                    display: block;
                    width: fit-content;
                    margin: 10px auto 0;
                    font-size: clamp(18px, 3vw, 25px);
                    font-family: 'Roboto';
                    background-color: var(--main-color02);
                    color: var(--white);
                    padding: 0px 25px;
                }
            }

            .image {
                text-align: center;
                flex-basis: 450px;
                flex-shrink: 0;
            }

            .text {
                flex-shrink: 1;
            }
        }

        .illustBox {
            margin-top: 50px;
            position: relative;
            padding-bottom: 150px;
            max-width: 800px;
            margin-inline: auto;

            p {
                font-size: clamp(18px, 3vw, 25px);
                color: var(--main-color02);
                font-weight: 800 !important;
                text-align: center;
                margin-left: -15px;
                margin-right: -15px;
                letter-spacing: -0.1em;
                @media (min-width:600px) {
                    letter-spacing: 0;
                }
            }

            &::before {
                content: '';
                position: absolute;
                left: 0;
                bottom: -50px;
                width: calc(312px * 0.6);
                height: calc(250px * 0.6);
                background: url(./img/bg_first_point01.png) no-repeat center/contain;
            }

            &::after {
                content: '';
                position: absolute;
                right: 0;
                bottom: -50px;
                width: calc(220px * 0.6);
                height: calc(250px * 0.6);
                background: url(./img/bg_first_point02.png) no-repeat center/contain;
            }

            @media (min-width:1200px) {
                padding-bottom: 0;
                max-width: none;

                &::before {
                    content: '';
                    position: absolute;
                    left: 0;
                    bottom: -65px;
                    width: 312px;
                    height: 250px;
                    background: url(./img/bg_first_point01.png) no-repeat center/contain;
                }

                &::after {
                    content: '';
                    position: absolute;
                    right: 0;
                    bottom: -65px;
                    width: 220px;
                    height: 250px;
                    background: url(./img/bg_first_point02.png) no-repeat center/contain;
                }
            }
        }
    }

    .firstTarget {
        padding: 50px 0;
        background-color: var(--sub-color06);

        h2 {
            font-size: clamp(30px, 8vw, 50px);
            color: var(--main-color02);
            text-align: center;

            .underLine {
                position: relative;
                display: inline-block;
                font-weight: 900;

                &::before {
                    content: '';
                    position: absolute;
                    bottom: 0px;
                    left: 0;
                    width: 100%;
                    height: 10px;
                    background-color: var(--white);
                    z-index: -1;
                }
            }
        }

        .targetBox {
            margin-top: 50px;
            background-color: var(--white);
            border-radius: 20px;

            border: solid 6px var(--main-color03);

            .box1 {
                margin-top: 40px;
                padding: 0 clamp(15px, 4vw, 40px) clamp(15px, 4vw, 40px);

                @media (min-width:1000px) {
                    display: flex;
                    gap: 40px;
                }
            }

            .box2 {
                margin-top: 40px;
                padding: 0 clamp(15px, 4vw, 40px) clamp(15px, 4vw, 40px);
            }

            &:nth-child(2n+1) .box {
                flex-direction: row-reverse;
            }

            h3 {
                color: var(--white);
                background-color: var(--main-color03);
                text-align: center;
                font-weight: 900;
                font-size: clamp(18px, 2.8vw, 32px);
                padding: 12px 15px 15px;
                position: relative;

                &.check {
                    font-size: clamp(18px, 3vw, 25px);
                    padding: 0px 0px 10px;
                    text-align: left;
                    background-color: var(--main-color02);
                    display: flex;
                    flex-wrap: wrap;
                    gap: 10px 15px;
                    align-items: center;
                    text-align: center;
                    justify-content: center;

                    &::before {
                        content: 'CHECK!!';
                        background-color: var(--main-color01);
                        color: var(--main-color02);
                        padding: 8px clamp(15px, 4vw, 20px);
                        flex-basis: 100%;
                        text-align: center;
                    }

                    @media (min-width:500px) {
                        flex-wrap: nowrap;
                        text-align: left;
                        justify-content: flex-start;
                        padding: 0px;

                        &::before {
                            flex-basis: auto;
                            text-align: left;

                        }
                    }
                }
            }

            .image {
                text-align: center;
                flex-basis: 450px;
                flex-shrink: 0;

                img {
                    display: inline-block;
                }

                img+img {
                    margin-top: 5px;
                }
            }

            .text {
                flex-shrink: 1;
            }

            .imageList {
                display: grid;
                gap: 30px;
                grid-template-columns: 1fr;

                @media (min-width:400px) {
                    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
                }

                img {
                    width: 100%;
                }

                span {
                    display: block;
                    text-align: center;
                    color: var(--white);
                    background-color: var(--main-color02);
                    padding: 2px 10px;
                    font-size: 20px;
                    font-weight: 900;
                }
            }

            .imageList+p {
                margin-top: 30px;
            }

            .iconList {
                margin-top: 30px;
                display: grid;
                gap: 5px;
                grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));

                li {
                    background-color: #f6f6f6;
                    height: 150px;
                    display: flex;
                    justify-content: center;
                    align-items: center;
                    text-align: center;
                    flex-wrap: wrap;
                    gap: 5px;
                    align-content: center;
                }

                span {
                    display: block;
                    text-align: center;
                    color: var(--main-color02);
                    font-size: 20px;
                    font-weight: 900;
                    flex-basis: 100%;
                }
            }
        }
    }

    .limeDotBar {
        position: relative;
        z-index: 0;

        &::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: url(./img/bg_limedot.gif);
            width: 100%;
            height: 250px;
            z-index: -1;
        }
    }

}

/*-------------------.corpConcept-----------------*/
.corpConcept {
    background: 
        linear-gradient(to bottom,rgba(255,255,255,0.5),rgba(255,255,255,0.5)),
        url(./img/bg_corpConcept.jpg) no-repeat center top/cover;
    padding: 50px 0;

    @media (min-width:1000px) {
        padding: 50px 0 120px;
    }

    .inner {
        max-width: 900px;
    }

    .subTitle {
        font-size: clamp(60px, 14vw, 80px);
        text-align: center;
        font-weight: 900;
        color: var(--white);
        margin-bottom: -30px;
        line-height: 1;
    }

    .contentTitle {
        text-align: center;
        font-size: clamp(27px, 9vw, 40px);
        color: var(--main-color02);
        font-weight: 900;
    }

    .contentTitle+h3 {
        margin-top: 60px;
    }

    h3 {
        font-size: clamp(30px, 8vw, 50px);
        color: var(--main-color02);
        text-align: center;
        font-weight: 900;

        .red {
            color: var(--sub-color01);
            display: inline-block;
        }
    }

    h3+p {
        margin-top: 40px;
    }

    p {

        font-size: clamp(15px, 4vw, 20px);
        color: var(--main-color02);
    }
}

/*-------------------.corpData-----------------*/
.corpData {
    padding: 50px 0;
    background-color: var(--sub-color06);

    h2 {
        font-size: clamp(30px, 8vw, 50px);
        color: var(--main-color02);
        text-align: center;

        .underLine {
            position: relative;
            display: inline-block;
            font-weight: 900;

            &::before {
                content: '';
                position: absolute;
                bottom: 0px;
                left: 0;
                width: 100%;
                height: 10px;
                background-color: var(--white);
                z-index: -1;
            }
        }
    }

    &.limeDotBar {
        position: relative;
        z-index: 0;

        &::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: url(./img/bg_limedot.gif);
            width: 100%;
            height: 250px;
            z-index: -1;
        }
    }

    .whiteBox {
        margin-top: 50px;
        background-color: var(--white);
        padding: clamp(15px, 4vw, 40px);


        h3 {
            font-size: clamp(18px, 2.8vw, 32px);
            color: white;
            background-color: var(--main-color02);
            border-radius: 100px;
            padding: 20px;
            position: relative;
            text-align: center;

            &::before {
                content: '';
                position: absolute;
                bottom: -30px;
                left: calc(50% - 18px);
                width: 36px;
                height: 32px;
                background-color: var(--main-color02);
                clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
            }
        }

        .boxInner {
            margin-top: 60px;

            @media (min-width:1000px) {
                display: flex;
                gap: 40px;
            }
        }

        &:nth-child(2n) .boxInner {
            flex-direction: row-reverse;
        }

        .boxMap {
            margin-top: 60px;

            iframe {
                display: block;
                width: 100%;
                height: auto;
                aspect-ratio: 16/9;
            }

            .text {
                margin-top: 10px;
            }
        }

        .text {
            width: 100%;
        }

        .image {
            flex-basis: 450px;
            flex-shrink: 0;
            text-align: center;
            margin-top: 20px;

            @media (min-width:1000px) {
                margin-top: 0;
            }
        }

        dl {
            width: 100%;

            border-top: solid 1px #ccc;

            @media (min-width:500px) {
                display: grid;
                grid-template-columns: min(230px, 35%) 1fr;
            }
        }

        dt {
            background-color: var(--main-color03);
            color: var(--white);
            border-bottom: solid 1px #ccc;
            padding: 10px 15px 10px 25px;
            font-weight: 900;
            span {
                display: grid;
                grid-template-columns: 4.5em 2.5em;
                width: fit-content;
                b.center{
                    justify-self: center;
                }
                b:last-of-type{
                    justify-self: flex-end;
                }
            }
        }

        dd {
            border-bottom: solid 1px #ccc;
            padding: 10px 0 10px 25px;

        }
    }
}

/*-------------------.beginnersGuideList-----------------*/
.beginnersGuideList {
    position: relative;
    z-index: 1;
}

#top .beginnersGuideList {
    margin-top: -70px !important;
}

#top .beginnersGuideList::before {
    content: "";
    display: block;
    width: 499px;
    height: 482px;
    position: absolute;
    background-color: #f5f5f5;
    margin: auto;
    inset: -100%;
    transform: translate(-152%, -10%);
    z-index: -1;
    pointer-events: none;
    -webkit-mask-image: url("./img/img_polygon01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_polygon01.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
}

.beginnersGuideList .inner {
    display: flex;
    flex-wrap: wrap;
}

.beginnersGuideList h2 {
    width: 100% !important;
    margin-bottom: 60px;
}

#top .beginnersGuideList h2 {
    margin-top: 80px;
}

.beginnersGuideList .inner>a:first-of-type {
    border-left: 1px solid #ccc;
}

.beginnersGuideList .inner>a {
    padding: 45px 65px;
    flex: 1;
    border-right: 1px solid #ccc;
    display: flex;
    flex-direction: column;
    text-align: center;
    color: var(--black) !important;
    text-decoration: none !important;
}

.bgColor03 .beginnersGuideList .inner>a:first-of-type {
    border-left-color: rgba(255, 255, 255, 0.75);
}

.bgColor03 .beginnersGuideList .inner>a {
    border-right-color: rgba(255, 255, 255, 0.75);
}

.beginnersGuideList .inner>a b {
    font-size: 36px;
    font-weight: 500;
    margin-bottom: 5px;
}

.beginnersGuideList .inner>a img {
    display: block;
    width: auto;
    height: auto;
    margin: 0 auto 20px;
}

.beginnersGuideList .btn {
    min-width: 100%;
}

#first .beginnersGuideList a .btn {
    padding-bottom: 20px;
    transition: all 0.3s ease;
}

#first .beginnersGuideList a .btn::after {
    top: auto;
    bottom: 10px;
    left: 0;
    right: 0;
    margin: 0 auto;
    transform: rotate(45deg);
    transition: all 0.3s ease;
}

#first .beginnersGuideList a:hover .btn::after {
    transform: rotate(45deg) translate(25%, 25%);
}

.bgColor03 a:hover .btn {
    background: var(--white) !important;
}


/*-------------------.voiceArchive-----------------*/
.voiceArchive {
    padding: 60px 0;

    .voiceArchiveList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 30px;
    }

    .voiceArchiveItem {}

    .voiceArchiveAnker {
        display: block;
        background-color: var(--main-color02);

        &:hover {
            opacity: 0.7;
        }
    }

    .voiceArchiveText {
        padding: 0 10px 10px;
    }

    .voiceArchiveTitle {
        color: var(--white);
        text-align: center;
        margin-top: 10px;
    }

    .voiceArchiveSubtitle {
        color: var(--white);
        text-align: center;
        margin-top: 10px;
        font-size: 14px;
    }

    .voiceArchiveFig {
        max-height: 250px;
        contain: paint;

        img {
            width: 100%;
            /* height: 100%; */
            aspect-ratio: 3 / 2;
            object-fit: cover;
        }
    }

    .voiceArchiveDetail {
        color: var(--white);
        text-align: center;
        width: fit-content;
        margin: 10px auto 0;
        border: solid 1px var(--white);
        padding: 2px 5px;
        font-size: 14px;
    }

    .voiceArchiveButton {
        border-top: dotted 1px #333;
        padding-top: 20px;
        margin-top: 50px;

        a {
            display: block;
            max-width: 500px;
            margin-inline: auto;
            border-radius: 100px;
            background-color: var(--main-color01);
            color: var(--main-color02);
            font-weight: 900;
            text-align: center;
            padding: 10px;
            font-size: clamp(15px, 4vw, 20px);
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }
    }

    .taxArea {
        max-width: 950px;
        margin-inline: auto;
        margin-top: 40px;
    }

    .taxAreaList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
        gap: 10px;
    }

    .taxAreaAnker {
        display: flex;
        color: var(--white);
        background: url(./img/ico_arrow_white02.png) no-repeat left 13px center var(--sub-color01);
        gap: 15px;
        justify-content: space-between;
        align-items: center;
        line-height: 1;
        padding: 10px 15px 10px 35px;
        font-weight: 900;
        font-size: 15px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        span {
            color: var(--sub-color01);
            background-color: var(--white);
            border-radius: 10px;
            padding: 5px 10px;
        }
    }

    .taxMenu {
        max-width: 950px;
        margin-inline: auto;
        margin-top: 10px;
    }

    .taxMenuList {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(182px, 1fr));
        gap: 10px;
    }

    .taxMenuAnker {
        display: flex;
        color: var(--white);
        background: url(./img/ico_arrow_white02.png) no-repeat left 13px center var(--sub-color02);
        gap: 15px;
        justify-content: space-between;
        align-items: center;
        line-height: 1;
        padding: 10px 15px 10px 35px;
        font-weight: 900;
        font-size: 15px;
        transition: 0.5s;

        &:hover {
            opacity: 0.7;
            transition: 0.5s;
        }

        span {
            color: var(--sub-color02);
            background-color: var(--white);
            border-radius: 10px;
            padding: 5px 10px;
        }
    }
}

/*-------------------.voiceSingle-----------------*/
.voiceSingle {
    padding: clamp(50px, 10vw, 70px) 0;

    .date {
        font-size: 14px;
        color: var(--main-color03);
        font-weight: 900;
    }

    .postTitle {
        color: var(--main-color02);
        font-weight: 900;
        font-size: clamp(27px, 9vw, 40px);
        margin-top: 20px;
    }

    .subTitle {
        color: var(--white);
        background-color: var(--main-color02);
        font-weight: 900;
        font-size: clamp(20px, 7.5vw, 30px);
        padding: 10px clamp(20px, 7.5vw, 30px);
        margin-top: 50px;

    }

    .column {
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;
        margin-top: 30px;

        @media (min-width:1000px) {
            grid-template-columns: 1fr 60%;
        }

        .image {
            height: 100%;
            text-align: center;
        }

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .data {
            table {}
        }
    }

    .survey {
        margin-top: 50px;
        text-align: center;

        img {
            border: solid 1px #ccc;
        }
    }

    .wysiwyg {
        margin-top: 50px;
    }

    .staff {
        border: solid 6px var(--main-color03);
        border-radius: 10px;
        padding: clamp(27px, 9vw, 40px);
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;
        margin-top: 50px;

        @media (min-width:800px) {
            grid-template-columns: 350px 1fr;
        }


        .image {
            grid-row: 2/3;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 1/2;
            }

            img {
                width: 100%;
            }
        }

        .text {
            grid-row: 1/2;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 2/3;

            }
        }

        .title {
            color: var(--white);
            background-color: var(--main-color03);
            padding: 10px clamp(20px, 7.5vw, 30px);
            font-size: clamp(18px, 2.8vw, 32px);
        }

        .staffName {
            text-align: center;
            color: var(--white);
            background-color: var(--main-color02);
            font-size: 20px;
            padding: 10px;

            span {
                display: block;
                font-size: 15px;
            }
        }
    }

    .staff--none {
        border: solid 6px var(--sub-color01);
        border-radius: 10px;
        padding: clamp(27px, 9vw, 40px);
        margin-top: 50px;

        @media (min-width:800px) {
            grid-template-columns: 350px 1fr;
        }


        .image {
            grid-row: 2/3;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 1/2;
            }

            img {
                width: 100%;
            }
        }

        .text {
            grid-row: 1/2;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 2/3;

            }
        }

        .title {
            color: var(--white);
            background-color: var(--sub-color01);
            padding: 10px clamp(20px, 7.5vw, 30px);
            font-size: clamp(18px, 2.8vw, 32px);
        }

        .staffName {
            text-align: center;
            color: var(--white);
            background-color: var(--main-color02);
            font-size: 20px;
            padding: 10px;

            span {
                display: block;
                font-size: 15px;
            }
        }
    }
}

/*-------------------.worksArchive-----------------*/
.worksArchive {
    .taxSelect {
        padding: 50px 0;
        background-color: #f6f6f6;

        h2 {
            font-size: clamp(18px, 2.8vw, 32px);
            color: var(--main-color02);
            background-color: var(--main-color01);
            border-radius: 100px;
            padding: 20px;
            position: relative;
            text-align: center;

            &::before {
                content: '';
                position: absolute;
                bottom: -30px;
                left: calc(50% - 18px);
                width: 36px;
                height: 32px;
                background-color: inherit;
                clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
            }
        }

        .taxArea {
            max-width: 950px;
            margin-inline: auto;
            margin-top: clamp(40px, 12vw, 60px);
        }

        .taxArea+.fukidashi {
            margin-top: clamp(40px, 12vw, 60px);
        }

        .taxAreaList {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
            gap: 10px;
        }

        .taxAreaAnker {
            display: flex;
            color: var(--white);
            background: url(./img/ico_arrow_white02.png) no-repeat left 13px center #31444d;
            gap: 10px;
            justify-content: space-between;
            align-items: center;
            line-height: 1;
            padding: 10px 15px 10px 35px;
            font-weight: 900;
            font-size: 18px;
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }

            span {
                color: #31444d;
                background-color: var(--white);
                border-radius: 10px;
                padding: 5px 10px;
                font-size: 15px;

            }
        }

        .taxMenu {
            max-width: 950px;
            margin-inline: auto;
            margin-top: clamp(40px, 12vw, 60px);
        }

        .taxMenuList {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(182px, 1fr));
            gap: 5px;
        }

        .taxMenuAnker {
            display: flex;
            color: var(--white);
            background: url(./img/ico_arrow_white02.png) no-repeat left 13px center #f3722e;
            gap: 5px;
            justify-content: space-between;
            align-items: center;
            line-height: 1;
            padding: 10px 15px 10px 35px;
            font-weight: 900;
            font-size: 18px;
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }

            span {
                color: #f3722e;
                background-color: var(--white);
                border-radius: 10px;
                padding: 5px 10px;
                font-size: 15px;
            }
        }
    }

    .worksList {
        display: grid;
        gap: 40px;
        grid-template-columns: 1fr;
        padding: 50px 0 90px;

        @media (min-width:800px) {
            grid-template-columns: repeat(2, 1fr);
        }

        .worksItem {
            background-color: var(--main-color02);
        }

        .worksAnker {
            display: block;
            transition: 0.5s;

            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }

        .pic {
            display: grid;
            grid-template-columns: repeat(2, 1fr);
            gap: 1px;

            figure {
                position: relative;

                img {
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                }
            }

            figcaption {
                position: absolute;
                left: 0;
                top: 0;
                background-color: var(--sub-color01);
                color: var(--white);
                padding: 2px 20px;
                font-size: 14px;
            }
        }

        .before {}

        .after {}



        .text {
            padding: 10px;
            color: var(--white);
            text-align: center;

            .title {
                font-size: 16px;
            }

            .data {
                font-size: 14px;

                span {
                    display: inline-block;
                }
            }

            .area+.period {
                margin-left: 15px;
            }

            .detail {
                color: var(--white);
                text-align: center;
                width: fit-content;
                margin: 10px auto 0;
                border: solid 1px var(--white);
                padding: 2px 5px;
                font-size: 12px;
            }
        }
    }
}

/*-------------------.worksSingle-----------------*/
.worksSingle {
    padding: 40px 0 60px;

    .taxAndArea {
        .cats {
            display: flex;
            gap: 5px 0px;
            flex-wrap: wrap;
            font-weight: 500;
        }
    }

    .date {
        font-size: 14px;
        color: var(--main-color03);
        font-weight: 900;
        margin-top: 10px;
    }

    .postTitle {
        color: var(--main-color02);
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
    }

    .column {
        margin-top: 50px;
        display: grid;
        gap: 50px;
        grid-template-columns: 1fr;

        @media (min-width:1000px) {
            grid-template-columns: 500px 1fr;
        }
    }

    .pic {
        figure {
            position: relative;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        figure+figure {
            margin-top: 30px;
        }

        figcaption {
            position: absolute;
            left: 0;
            top: 0;
            background-color: var(--sub-color01);
            color: var(--white);
            padding: 2px 20px;
            font-size: 14px;
        }
    }

    .data {
        th {
            @media (min-width:1000px) {
                width: 180px !important;
            }
        }
    }

    .contact {
        margin-top: 30px;

        a {
            padding-block: 10px;
            font-size: 20px;
            font-weight: 900;
        }
    }

    .gallery {
        margin-top: 50px;

        h2 {
            font-size: clamp(18px, 3vw, 25px);
            font-weight: 900;
            background-color: var(--sub-color06);
            padding: 10px 20px;
        }

        ul {
            display: grid;
            gap: 40px;
            grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
            margin-top: 30px;
            text-align: center;
        }

        li b {
            color: var(--main-color02);
            font-size: 16px;
            font-weight: 700;
            display: block;
        }
    }

    .wysiwyg {
        margin-top: 50px;
    }

    .staff {
        border: solid 6px var(--main-color03);
        border-radius: 10px;
        padding: clamp(27px, 9vw, 40px);
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;
        margin-top: 50px;

        @media (min-width:800px) {
            grid-template-columns: 350px 1fr;
        }


        .image {
            grid-row: 2/3;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 1/2;
            }

            img {
                width: 100%;
            }
        }

        .text {
            grid-row: 1/2;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 2/3;

            }
        }

        .title {
            color: var(--white);
            background-color: var(--main-color03);
            padding: 10px clamp(20px, 7.5vw, 30px);
            font-size: clamp(18px, 2.8vw, 32px);
        }

        .staffName {
            text-align: center;
            color: var(--white);
            background-color: var(--main-color02);
            font-size: 20px;
            padding: 10px;

            span {
                display: block;
                font-size: 15px;
            }
        }
    }

    .staff--none {
        border: solid 6px var(--sub-color01);
        border-radius: 10px;
        padding: clamp(27px, 9vw, 40px);
        margin-top: 50px;

        @media (min-width:800px) {
            grid-template-columns: 350px 1fr;
        }


        .image {
            grid-row: 2/3;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 1/2;
            }

            img {
                width: 100%;
            }
        }

        .text {
            grid-row: 1/2;
            grid-column: auto;

            @media (min-width:800px) {
                grid-row: 1/2;
                grid-column: 2/3;

            }
        }

        .title {
            color: var(--white);
            background-color: var(--sub-color01);
            padding: 10px clamp(20px, 7.5vw, 30px);
            font-size: clamp(18px, 2.8vw, 32px);
        }

        .staffName {
            text-align: center;
            color: var(--white);
            background-color: var(--main-color02);
            font-size: 20px;
            padding: 10px;

            span {
                display: block;
                font-size: 15px;
            }
        }
    }

    .redBaloon {
        margin-top: 50px;
        font-size: clamp(22px, 8vw, 45px);
        color: white;
        background-color: var(--sub-color01);
        border-radius: 100px;
        padding: 20px 40px;
        position: relative;
        text-align: center;
        line-height: 1.3;
        font-weight: 900;

        span {
            display: block;
            font-size: clamp(18px, 3vw, 25px);
            margin-top: 5px;
        }

        &::before {
            content: '';
            position: absolute;
            bottom: -30px;
            left: calc(50% - 18px);
            width: 36px;
            height: 32px;
            background-color: var(--sub-color01);
            clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
        }
    }
}

/*-------------------.StaffArchive-----------------*/
.staffArchive {
    .introStaff {
        padding: 50px 0;
        background-color: #f6f6f6;

        .column {
            display: grid;
            grid-template-columns: 1fr;
            gap: 50px;

            @media (min-width:800px) {
                grid-template-columns: 1fr 450px;
            }
        }

        .text {
            @media (min-width:800px) {
                display: flex;
                flex-wrap: wrap;
                align-content: center;
            }

            h2 {
                color: var(--main-color02);
                font-size: clamp(18px, 3vw, 25px);
            }

            h2+p {
                margin-top: 40px;
            }

            p {
                font-size: clamp(15px, 4vw, 20px);
                color: var(--main-color02);
            }
        }

        .image {
            text-align: center;
        }
    }

    .staffList {
        padding: clamp(50px, 10vw, 70px) 0;

        .title {
            background-color: var(--main-color02);
            color: var(--white);
            font-weight: 900;
            font-size: clamp(20px, 7.5vw, 30px);
            padding: 10px 20px;
            display: flex;
            flex-wrap: wrap;
            gap: 5px 15px;
            align-items: baseline;

            span {
                font-size: 20px;
                color: var(--sub-color05);
                display: inline-block;
            }
        }

        .catch {
            color: var(--main-color03);
            font-size: clamp(18px, 3vw, 25px);
            font-weight: 900;
            margin-top: 10px;

        }

        .column {
            margin-top: 20px;
            display: grid;
            grid-template-columns: 1fr;
            gap: 50px;

            @media (min-width:800px) {
                grid-template-columns: 350px 1fr;
            }
        }

        .staffItem {
            h4 {
                background-color: var(--sub-color06);
                padding: 10px 20px;
                font-size: 20px;
                font-weight: 900;
            }

            h4+.text {
                margin-top: 15px;
            }

            .text+h4 {
                margin-top: 25px;
            }
        }

        .staffItem+.staffItem {
            margin-top: 70px;
        }

        .img {
            text-align: center;
            max-height: 400px;
            max-width: 350px;
            width: 100%;
            margin-inline: auto;
            aspect-ratio: 7/8;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }
    }
}


/*-------------------.partnerPage-----------------*/
.partnerPage {
    .intro {
        padding: 50px 0;
        background-color: #f6f6f6;

        h2 {
            font-size: clamp(18px, 3vw, 25px);
            color: var(--main-color02);
            font-weight: 900;
            margin-top: 40px;
        }

        p {
            font-size: clamp(15px, 4vw, 20px);
            color: var(--main-color02);
            margin-top: 20px;
        }
    }

    .together {
        padding: 50px 0;

        h2 {
            font-size: clamp(18px, 2.8vw, 32px);

            color: white;
            background-color: var(--main-color02);
            border-radius: 100px;
            padding: 20px 40px;
            position: relative;
            text-align: center;
            line-height: 1.3;
            font-weight: 900;

            span {
                display: block;
                font-size: clamp(18px, 3vw, 25px);
                margin-top: 5px;
            }

            &::before {
                content: '';
                position: absolute;
                bottom: -30px;
                left: calc(50% - 18px);
                width: 36px;
                height: 32px;
                background-color: var(--main-color02);
                clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
            }
        }

        .column {
            margin-top: 50px;
            display: grid;
            grid-template-columns: 1fr;
            gap: 50px;

            @media (min-width:800px) {
                grid-template-columns: 1fr 450px;
            }
        }

        .image {
            text-align: center;
        }
    }

    .features {
        padding: 50px 0;

        h2 {
            font-size: clamp(27px, 9vw, 40px);
            font-weight: 900;
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            color: var(--main-color02);

            span {
                font-size: clamp(15px, 4vw, 20px);
                background-color: var(--main-color01);
                color: var(--main-color02);
                width: fit-content;
                padding: 5px 15px;
                display: flex;
                text-align: center;
                justify-content: center;
                align-items: center;
            }
        }

        .featuresList {
            margin-top: 40px;
            display: grid;
            grid-template-columns: 1fr;
            gap: 30px 80px;

            @media (min-width:1000px) {
                grid-template-columns: repeat(3, 1fr);
            }

            li {
                text-align: center;
            }

            h3 {
                color: var(--main-color02);
                font-size: clamp(20px, 3vw, 25px);
            }

            p {
                font-size: 15px;
            }
        }
    }

    .jobDescription {
        padding: 50px 0;

        h2 {
            font-size: clamp(27px, 9vw, 40px);
            font-weight: 900;
            text-align: center;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            color: var(--main-color02);

            span {
                font-size: clamp(15px, 4vw, 20px);
                background-color: var(--main-color01);
                color: var(--main-color02);
                width: fit-content;
                padding: 5px 15px;
                display: flex;
                text-align: center;
                justify-content: center;
                align-items: center;
            }
        }

        h3 {
            background-color: var(--main-color02);
            color: var(--white);
            font-weight: 900;
            font-size: clamp(18px, 3vw, 25px);
            text-align: center;
            padding: 5px 10px;
        }

        *+h3 {
            margin-top: 40px;
        }

        .job {
            font-size: clamp(18px, 3vw, 25px);
            color: var(--main-color02);
            font-weight: 900;
            line-height: 1.2;
            margin: 15px;
            display: flex;
            gap: 10px;
            justify-content: center;
            align-items: center;
            flex-wrap: wrap;
            flex-direction: column;

            span {
                display: block;
                width: 100%;
                text-align: center;
                /* margin-inline: auto; */
                border: solid 3px var(--main-color01);
                padding: 10px 15px;
                border-radius: 100vh;
            }
            @media (min-width:500px) {
                flex-direction: row;
                span{
                    width: fit-content;
                }
            }

        }

        .column {
            margin-top: 50px;
            display: grid;
            grid-template-columns: 1fr;
            gap: 50px;

            @media (min-width:800px) {
                grid-template-columns: 380px 1fr;
            }
        }

        .image {
            text-align: center;
        }

        h4 {
            font-size: clamp(18px, 3vw, 25px);
            color: var(--main-color02);
            font-weight: 900;
        }

        h4+p {
            margin-top: 30px;
        }
    }

    .point {
        padding: 0 0 60px;
        background-color: var(--sub-color06);

        h2 {
            font-size: clamp(30px, 8vw, 50px);
            font-weight: 500;
            color: var(--main-color02);
            text-align: center;
            background: url(./img/bg_limedot.gif);
            padding: 60px 0;

            .underLine {
                position: relative;
                display: inline-block;
                font-weight: 900;
                z-index: 0;

                &::before {
                    content: '';
                    position: absolute;
                    bottom: 0px;
                    left: 0;
                    width: 100%;
                    height: 10px;
                    background-color: var(--main-color03);
                    z-index: -1;
                }
            }
        }

        .inner {
            padding-top: 50px;
        }

        .catch {
            text-align: center;

            .catch1 {
                font-size: clamp(20px, 5vw, 35px);
                color: var(--main-color03);
                font-weight: 900;
            }

            .catch2 {
                font-size: clamp(18px, 3vw, 25px);
                color: var(--main-color02);
                font-weight: 900;
                margin-top: 10px;
            }

            p {
                margin-top: 25px;
                font-size: clamp(15px, 4vw, 20px);
                color: var(--main-color02);
            }
        }

        h3 {
            margin-top: 50px;
            background-color: var(--main-color02);
            color: var(--white);
            font-weight: 900;
            font-size: clamp(18px, 3vw, 25px);
            text-align: center;
            padding: 5px 10px;
        }

        .pointList {
            margin-top: 50px;
            display: grid;
            gap: 40px;
            grid-template-columns: 1fr;

            @media (min-width:1000px) {
                grid-template-columns: repeat(2, 1fr);
            }

            li {
                container-type: inline-size;
                border: solid 6px var(--main-color02);
                border-radius: 10px;
                background-color: var(--white);
                position: relative;
                padding: 43px clamp(15px, 4.5vw, 30px) 20px;

            }

            li:first-child img {
                margin-bottom: -20px;

                @media (min-width:1000px) {
                    margin-bottom: -60px;
                }
            }

            li:nth-child(2) img {
                margin-bottom: -20px;

                @media (min-width:1000px) {
                    margin-bottom: -70px;
                }
            }

            li:nth-child(6) img {
                margin-bottom: -20px;

                @media (min-width:1000px) {
                    margin-bottom: -90px;
                }
            }

            li:last-child {
                @media (min-width:1000px) {
                    grid-column: 1/3;
                }
            }

            .num {
                position: absolute;
                left: 15px;
                top: -30px;
                font-family: 'Roboto';
                font-weight: 900;
                text-align: center;
                width: fit-content;
                background: url(./img/img_pin.svg) no-repeat center/contain;
                line-height: 1;
                color: var(--main-color02);
                padding: 20px 24px 46px;

                .num1 {
                    font-size: 16px;
                }

                .num2 {
                    font-size: 35px;
                }
            }

            h4 {
                padding-left: 80px;
                font-size: clamp(27px, 5vw, 35px);
                font-weight: 900;
                color: var(--main-color02);
            }

            .content {
                display: flex;
                gap: 20px;
                justify-content: center;
                align-items: center;
                flex-wrap: wrap;

                @container (min-width:400px) {
                    flex-wrap: nowrap;
                    justify-content: space-between;
                }
            }

            p {
                margin-top: 30px;
            }
        }
    }
}

/*-------------------.contactPage-----------------*/
.contactPage {
    padding: 0 0 50px;

    .limeDotBar {
        position: relative;
        z-index: 0;

        &::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: url(./img/bg_limedot.gif);
            width: 100%;
            height: 300px;
            z-index: -1;
        }
    }

    .contactSupport {
        background-color: var(--sub-color06);
        padding: 60px 0 50px;


        h2 {
            font-size: clamp(30px, 8vw, 50px);
            letter-spacing: -0.05em;
            color: var(--main-color02);
            text-align: center;
            font-weight: 500;
            padding-inline: 15px;

            @media (min-width:1000px) {
                padding-inline: 0;
            }

            .underLine {
                position: relative;
                display: inline-block;
                font-weight: 900;

                &::before {
                    content: '';
                    position: absolute;
                    bottom: 0px;
                    left: 0;
                    width: 100%;
                    height: 10px;
                    background-color: var(--white);
                    z-index: -1;
                }
            }
        }

        .contactList {
            margin-top: 50px;
            display: grid;
            gap: 40px;
            grid-template-columns: 1fr;

            @media (min-width:1000px) {
                grid-template-columns: repeat(3, 1fr);
            }

            li {
                max-width: 600px;
                margin-inline: auto;
                border: solid 6px var(--main-color02);
                border-radius: 10px;
                background-color: var(--white);
                position: relative;
                padding: 15px 5px 15px;
                display: flex;
                align-content: flex-end;
                flex-wrap: wrap;
                justify-content: center;
            }

            .num {
                position: absolute;
                left: 15px;
                top: -30px;
                font-family: 'Roboto';
                font-weight: 900;
                text-align: center;
                width: fit-content;
                background: url(./img/img_pin.svg) no-repeat center/contain;
                line-height: 1;
                color: var(--main-color02);
                padding: 20px 24px 46px;

                .num1 {
                    font-size: 16px;
                }

                .num2 {
                    font-size: 35px;
                }
            }

            .free {
                position: absolute;
                top: 5px;
                right: 5px;
                width: clamp(60px, 12vw, 97px);
                height: clamp(60px, 12vw, 97px);
                display: flex;
                justify-content: center;
                align-items: center;
                background: url(./img/ico_redFree.svg) no-repeat center/contain;
                color: var(--white);
                font-weight: 900;
                font-size: clamp(15px, 4.5vw, 30px);
            }

            h3 {
                flex-basis: 100%;
                margin-top: 5px;
                text-align: center;
                font-size: clamp(20px, 7.5vw, 30px);
                font-weight: 900;
                color: var(--main-color02);
            }
        }

        .msg {
            text-align: center;
            color: var(--main-color02);
            font-size: clamp(30px, 8vw, 50px);
            font-weight: 900;
            margin-top: 50px;
            line-height: 1.25;
        }
    }

}

/*-------------------.partnerContact-----------------*/
.partnerContact {
    padding: 60px 0;

    h2 {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            width: fit-content;
            padding: 2px 15px;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
        }
    }
}


/*-------------------.quickRequest-----------------*/
.quickRequest {
    padding: clamp(50px, 10vw, 70px) 0 0;

    h2 {
        font-size: clamp(27px, 9vw, 40px);
        font-weight: 900;
        text-align: center;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        color: var(--main-color02);

        span {
            font-size: clamp(15px, 4vw, 20px);
            background-color: var(--main-color01);
            color: var(--white);
            width: fit-content;
            padding: 2px 15px;
            display: flex;
            text-align: center;
            justify-content: center;
            align-items: center;
        }
    }
}


/*-------------------.reasonIndex-----------------*/
.reasonIndex {
    padding: clamp(50px, 10vw, 70px) 0;
    background-color: #f6f6f6;

    h2 {
        color: var(--main-color02);
        font-weight: 900;
        font-size: clamp(18px, 4vw, 25px);
    }

    h2+p {
        margin-top: 20px;
    }

    p {
        font-size: clamp(15px, 4vw, 20px);
        color: var(--main-color02);
    }

    .column {
        display: grid;
        grid-template-columns: 1fr;
        gap: 50px;

        @media (min-width:900px) {
            grid-template-columns: 1fr 450px;
        }
    }

    .image {
        text-align: center;
    }
}

.reasonDetail+.reasonDetail {
    padding-top: 40px;
}



.reasonDetail {
    background-color: var(--sub-color06);

    &.limeDotBar {
        position: relative;
        z-index: 0;
        padding-top: 60px;

        &::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: url(./img/bg_limedot.gif);
            width: 100%;
            height: 250px;
            z-index: -1;
        }
    }

    &:last-of-type {
        padding-bottom: clamp(50px, 10vw, 70px);
    }



    h2 {
        font-size: clamp(30px, 8vw, 50px);
        color: var(--main-color02);
        text-align: center;
        font-weight: 500;
        padding-inline: 15px;

        @media (min-width:1000px) {
            padding-inline: 0;
        }

        .underLine {
            position: relative;
            display: inline-block;
            font-weight: 900;

            &::before {
                content: '';
                position: absolute;
                bottom: 0px;
                left: 0;
                width: 100%;
                height: 10px;
                background-color: var(--main-color03);
                z-index: -1;
            }
        }
    }

    h2+.reasonBox {
        margin-top: 50px;
    }

    .reasonBox {
        border: solid 6px var(--main-color03);
        border-radius: 10px;
        background-color: var(--white);

        h3 {
            background-color: var(--main-color03);
            padding: 4px 15px 10px;
            text-align: center;
            font-size: clamp(18px, 2.8vw, 32px);
            color: var(--white);
            font-weight: 900;
        }

        .column {
            display: grid;
            grid-template-columns: 1fr;
            gap: clamp(30px, 8vw, 50px);
            padding: clamp(30px, 8vw, 50px);

            @media (min-width:900px) {
                grid-template-columns: 450px 1fr;
            }

            h4 {
                font-size: clamp(18px, 2.8vw, 32px);
                color: var(--main-color02);
                font-weight: 900;
            }

            h4+p {
                margin-top: 20px;
            }
        }

        .image {
            text-align: center;
        }
    }
}




/*-------------------#voice お客様の声-----------------*/
.voicephotList {
    display: flex;
    gap: 10px;
}

.voicephotList li {
    flex: 1;
}

.voicephotList li img {
    max-width: 100%;
    height: auto;
    display: block;
}

.voicephotList li.enqImg a {
    position: relative;
    width: 100%;
    height: 100%;
    border: 1px solid #ccc;

    background: #eee;
}

.voicephotList li.enqImg img {
    display: block;
    position: absolute;
    inset: 0;
    margin: auto;
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
}

.voicephotList li.enqImg a {
    display: block;
    position: relative;
}

.voicephotList li.enqImg a span {
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    padding: 10px;
    font-size: 1.25rem;
    line-height: 1;
    width: 1em;
    height: 1em;
    box-sizing: content-box;
    background: rgba(255, 255, 255, 0.5);
    color: var(--black) !important;
}



/*-------------------.staffList-----------------*/
.staffList {
    position: relative;
}

.staffList::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    transform: translateX(45%);
    width: 1056px;
    height: 580px;
    background: url(./img/bg_staffList.png) left top no-repeat;
    z-index: -1;
}

#main .staffList h2 {
    margin-bottom: 50px;
}

#main .staffList>.inner:first-of-type h3 {
    font-weight: 500;
    line-height: 1.25;
    font-size: 46px;
    margin-bottom: 20px;
    text-align: left;
}

#main .staffList>.inner:first-of-type p {
    margin-bottom: 0.5rem;
}

#main .staffList>.inner:first-of-type p:nth-of-type(2) {
    margin-bottom: 1rem;
}

#main .staffList .swiperStaff ul li {
    display: block;
    width: 340px;
}

#main .staffList .swiperStaff ul li a {
    width: 100%;
}

#main .staffList .swiperStaff .cats a {
    pointer-events: none;
}

/*-------------------.menuList-----------------*/
.menuList.extraPart {
    position: relative;
    overflow: visible !important;
    padding-top: 70px !important;
    z-index: 1;
    min-height: 822px;
}

#main .menuList.extraPart::before {
    content: "";
    display: block;
    width: 557px;
    height: 302px;
    background-image: url("./img/bg_menuList.png");
    position: absolute;
    top: -35px;
    left: 0;
    right: 0;
    margin: 0 auto;
    transform: translateX(50%);
    z-index: -1;
}

#main .menuList.extraPart::after {
    content: "";
    display: block;
    width: 1610px;
    height: 520px;
    background-image: url("./img/bg_construction.png");
    position: absolute;
    top: 267px;
    left: calc(((100% - 1100px) / 2) - 100px);
    right: 0;
    margin: 0 auto;
    z-index: -1;
}

#main .menuList.extraPart h2 {
    margin-bottom: 50px;
}

.menuList .inner>ul {
    display: flex;
    gap: 40px 40px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 50px;
    margin-bottom: 30px;
}

.menuDetails {
    padding-top: 30px;
}

.menuList .inner>ul>li,
.menuDetailsItem {
    --menu-color: 0, 0, 0;
    background: var(--white);

    background-clip: border-box;
    text-align: center;
    display: block;
    padding: 30px;
    margin: 0;
    margin-bottom: 1px;
}

.menuDetailsItem .title {
    font-size: 110px;
    font-weight: 900;
    line-height: 1;
    gap: 1px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
}

.menuDetailsItem .title span {
    display: block;
    color: var(--white);
    background-color: rgba(var(--menu-color), 1);
    line-height: 1;
    width: 1em;
    height: 1em;
    padding: 2px 10px 12px;
}

.menuDetailsItem .plans+.singles {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--black);
}

.menuDetailsItem .price01>small {
    margin-right: 20px;
}

.singles {
    padding-top: 20px;
}

dl.planTotal,
.singles dl {
    display: flex;
    align-items: center;
}

dl.planTotal {
    justify-content: flex-end;
    margin-right: 50px;
}

.singles dl {
    justify-content: space-between;
}

.planTotal dt,
.planTotal dd,
.singles dt,
.singles dd {
    display: block;
}

.planTotal dt,
.singles dt {
    margin: 0;
    padding: 10px 40px;
}

.planTotal dt {
    text-align: center;
    font-size: 46px;
    font-weight: 500;
    line-height: 1.2;
}

.singles dt {
    text-align: left;
    flex: auto;
    padding: 10px 40px 10px 0;
}

.planTotal dd,
.singles dd {
    padding: 10px 40px;
    position: relative;
}

.singles dd {
    padding: 10px 0 10px 40px;
}

.planTotal dd::before,
.singles dd::before {
    content: "";
    width: 1px;
    height: 50%;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto 0;
    background: var(--black);
}

.planTotal dt small,
.singles dt small {
    display: block;
    font-size: 16px;
    font-weight: 400;
}

.planTotal dd .price01Top,
.planTotal dd b,
.singles dd .price01Top,
.singles dd b {
    color: var(--sub-color03) !important;
}

.planTotal dd .price01Top,
.singles dd .price01Top {
    align-items: flex-end;
}


.planTotal dd .price01Top small,
.singles dd .price01Top small {
    font-size: 26px;
    font-weight: 500;
}

.planTotal dd .price01Top b,
.singles dd .price01Top b {
    display: inline-block;
    line-height: 0.8;
    margin: 0 10px -5px;

}

.planTotal dd small,
.singles dd small {
    margin-top: 10px;
}

.menuDetailsItem .plans {
    margin: 20px 0;
}

.menuDetailsItem .plan+.plan {
    margin-top: 50px;
}

.menuDetails .menuDetailsItem:last-of-type {
    margin-bottom: 110px;
}

.menuDetailsItem .plan table,
#main .menuDetailsItem .plan table {
    margin-top: 0 !important;
    margin-bottom: 15px;
    border: 0;
    border-bottom: 1px solid var(--black);
    table-layout: fixed;
}

.menuDetailsItem .plan table th,
#main .menuDetailsItem .plan table th,
.menuDetailsItem .plan table td,
#main .menuDetailsItem .plan table td {
    position: static;
    /* Firefox border消失対策用 */
}

.menuDetailsItem .plan table td.txtRight,
#main .menuDetailsItem .plan table td.txtRight {
    text-align: right;
}

.menuDetailsItem .plan table th,
#main .menuDetailsItem .plan table th {
    background: #4e4e4e !important;
    color: var(--white);
    text-align: center;
    font-weight: 400;
    border-left: 0;
    border-right: 1px dotted var(--white);
}

.menuDetailsItem .plan table tr td:first-of-type,
#main .menuDetailsItem .plan table tr td:first-of-type {
    background: #ededed;
}

.menuDetailsItem .plan table tr td:first-of-type:empty,
#main .menuDetailsItem .plan table tr td:first-of-type:empty {
    text-align: center;
}

.menuDetailsItem .plan table tr td:first-of-type:empty::before,
#main .menuDetailsItem .plan table tr td:first-of-type:empty::before {
    content: "－";
}

.menuDetailsItem .plan table tr th:last-of-type,
#main .menuDetailsItem .plan table tr th:last-of-type {
    border-right: 0;
}

.menuDetailsItem .plan table td,
#main .menuDetailsItem .plan table td {
    border-left: 0;
    border-right: 1px dotted var(--black);
}

.menuDetailsItem .plan table tr td:last-of-type,
#main .menuDetailsItem .plan table tr td:last-of-type {
    border-right: 0;
}

.menuDetailsItem .plan .planName {
    background: var(--black);
    color: var(--white);
    font-size: clamp(15px, 4vw, 20px);
    font-weight: 500;
    padding: 10px;
}

.menuList .inner>ul>li {
    width: 340px;
}

.menuList li a,
#main .menuList li a {
    text-decoration: none !important;
    color: var(--black);
}

.menuList li a:hover,
#main .menuList li a:hover {
    opacity: 0.7;
}

.menuDetailsItem .catch,
.menuList li .catch {
    background: rgba(var(--menu-color), 1);
    color: var(--white);
    box-sizing: content-box;
    line-height: 1;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

.menuList li .catch {
    padding: 20px 5px;
    margin: -30px -30px 0;
    width: calc(100% + 50px);
    font-size: 18px;
    font-weight: 600;
}

.menuList li .arrow {
    width: 40px;
    height: 40px;
    background: rgba(var(--menu-color), 1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 20px auto 0;
    transition: all 0.3s ease;
}

.menuList li a:hover .arrow {
    transform: translateY(15%);
}

.menuList li .arrow img {
    width: 14px;
    height: auto;
    object-fit: contain;
    display: inline-block;
    transform: rotate(90deg);
}

.menuDetailsItem .catch {
    width: calc(100% + 100px);
    margin: -50px -50px 50px;
    padding: 15px 5px;
    font-size: 26px;
    font-weight: 600;
}

.menuDetailsItemHead {
    display: grid;
    gap: 20px;
    grid-template-columns: min-content 340px auto;
}

.menuDetailsItemHasImages .menuDetailsItemHead {
    grid-template-columns: min-content 3fr;
}

.menuDetailsItemHead .img {
    display: flex;
    gap: 10px;
}

.menuDetailsItemHead .img li {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
}

.menuDetailsItemHead .img li img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.menuDetailsItemHead .content {
    flex-grow: 3;
}

.menuDetailsItemImages {
    margin: 10px 0;
    ;
}

.menuDetailsItemImages ul {
    display: flex;
    gap: 10px
}

.menuDetailsItemImages li {
    flex: 1;
}

.menuDetailsItemImages li img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.menuDetailsItem>.content {
    margin-top: 20px;
    margin-left: auto;
    margin-right: 90px;
    width: 33%;
}

.menuDetailsItem .content small.note {
    display: block;
    text-align: right;
    border-top: 1px dotted var(--black);
    font-size: 16px;
    margin-top: 15px;
    padding-top: 15px;
}

.menuDetailsItem .badges {
    justify-content: flex-start;
    align-items: flex-start;
}

.menuDetailsItem .badges li {
    flex: none !important;
}

.menuDetailsItem .price01Top {
    margin-top: 10px;
}

.menuDetailsItem .price01Top b {
    font-size: 90px;
}

.menuDetailsItem .price b {
    color: var(--red);
}

.menuDetailsItem .price01Top>span {
    margin: 1em 0 0;
}

.menuList li .title {
    color: rgba(var(--menu-color), 1);
    font-size: 46px;
    font-weight: 600;
    padding: 20px;
    line-height: 1;
}

.menuList li img {
    display: block;
    width: 100%;
    height: auto;
}

.menuList li img:hover {
    opacity: 1 !important;
}

.menuList li .price {
    margin-top: 5px;
}

.menuList li a>small {
    text-align: left;
    display: block;
    font-size: 16px;
}

.menuList li .badges {
    margin: 10px 0;
}

/* .menuDetailsItem */
.menuDetailsItem {
    border: 1px solid rgba(var(--menu-color), 1);
    margin: 70px 0 70px;
    padding: 50px;
}

/* .underConstruction */
.underConstruction,
#main p.underConstruction {
    text-align: center;
    background: var(--black);
    color: var(--white);
    width: fit-content;
    margin: 50px auto;
    padding: 20px;
    line-height: 1;
}

/* .badges */
.badges {
    display: flex;
    margin: 0;
    padding: 0;
    justify-content: space-between;
    gap: 5px;
}

.badges li,
#main .badges li {
    display: block;
    font-size: 36px;
    font-weight: 600;
    color: var(--red);
    border: 1px solid currentColor;
    margin: 0;
    padding: 5px;
    flex: 1;
    line-height: 1;
}

/* .price01 */
.price01 {
    font-weight: 600;
}

.price01 b {
    font-weight: 600;
    font-family: var(--en-font-family);
    letter-spacing: -0.01em;
}

.price01 i {
    font-style: normal;
}

.price01Top {
    display: flex;
    white-space: nowrap;
    line-height: 1;
    align-items: center;
    justify-content: flex-end;
}

.price01Top b {
    font-size: clamp(50px, 10vw, 70px);
    color: var(--red);
}

.price01Top>span {
    display: flex;
    flex-direction: column;
    color: var(--black);
    line-height: 1;
    margin: 0 -0.5rem;
}

.price01Top>span i {
    display: block;
}

.price01Top>span i:first-of-type {
    font-size: 26px;
    order: 2;
}

.price01Top>span i:last-of-type {
    font-size: 16px;
    order: 1;
}

.price01>small {
    display: block;
    margin-left: auto;
    width: fit-content;
    font-size: 26px;
    line-height: 1;
    margin-right: 12px;
}

.price01>small i {
    color: var(--black);
    font-size: 14px;
    vertical-align: 0.25em;
}

.price01>small b {
    margin: 0 0.25em;
    color: var(--black);
}


/*-------------------.blogArchive-----------------*/


.blogLayout {
    padding: 50px 0 100px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;

    @media (min-width:1000px) {
        grid-template-columns: 1fr 30%;
    }

    .main {
        container-type: inline-size;
    }
}


.blogArchive {
    .blogList {
        display: grid;
        grid-template-columns: 1fr;
        gap: 40px;

        @container (min-width: 600px) {
            grid-template-columns: repeat(2, 1fr);
        }
    }

    .blogItem {
        a {
            display: block;
            background-color: var(--main-color02);
            height: 100%;
            transition: 0.5s;


            &:hover {
                opacity: 0.7;
                transition: 0.5s;
            }
        }

        .thumbnail {
            aspect-ratio: 3/2;

            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .outline {
            padding: 10px;

            @media (min-width:1000px) {
                padding: 20px;
            }
        }

        .cats {
            display: flex;
            flex-wrap: wrap;
            height: calc(1em + 8px);
            font-size: 13px;
            font-weight: 600;
            line-height: 1;
            overflow: hidden;

            li {
                color: var(--main-color02);
                background-color: var(--main-color01);
                padding: 4px 8px;
                margin-right: 5px;
            }
        }

        .title {
            margin-top: 5px;
            color: var(--white);
            font-weight: bold;
            overflow: hidden;
            display: -webkit-box;
            text-overflow: ellipsis;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 1;
        }

        .excerpt {
            color: var(--white);
            font-size: 15px;
            overflow: hidden;
            display: -webkit-box;
            text-overflow: ellipsis;
            -webkit-box-orient: vertical;
            -webkit-line-clamp: 1;
        }

        .time {
            margin-top: 5px;
            color: var(--sub-color05);
            font-weight: bold;
            font-size: 15px;
        }
    }
}

.categoryBox {
    background-color: #f6f6f6;
    padding: 50px 0 40px;

    .contentTitle {
        font-size: clamp(18px, 2.8vw, 32px);
        color: white;
        background-color: var(--main-color03);
        border-radius: 100px;
        padding: 20px;
        position: relative;
        text-align: center;

        &::before {
            content: '';
            position: absolute;
            bottom: -30px;
            left: calc(50% - 18px);
            width: 36px;
            height: 32px;
            background-color: var(--main-color03);
            clip-path: polygon(0% 0%, 100% 0%, 50% 80%);
        }
    }
}

.blogSide {
    h3 {
        font-size: clamp(20px, 4.5vw, 25px);
        font-weight: bold;
        color: var(--main-color02);
        border-bottom: solid 3px var(--main-color02);
        padding-bottom: 10px;

        span {
            font-size: 15px;
            color: var(--main-color03);
            display: inline-block;
            margin-left: 20px;
        }

    }

    h3+* {
        margin-top: 15px;
    }

    *+h3 {
        margin-top: 50px;
    }

    .ranking {
        counter-reset: num;

        li {
            counter-increment: num;

            &::before {
                z-index: 1;
                content: counter(num, decimal-leading-zero);
                position: absolute;
                top: -5px;
                left: 5px;
                background-color: var(--main-color01);
                border-radius: 100vh;
                display: flex;
                justify-content: center;
                align-items: center;
                width: 30px;
                height: 30px;
                color: var(--main-color02);
                font-size: 14px;
                font-weight: bold;
            }
        }
    }

    li {
        position: relative;
        display: grid;
        grid-template-columns: auto 1fr;
    }

    li+li {
        margin-top: 20px;
    }

    .thumbnail {
        width: 110px;
        height: 110px;

        a {
            display: block;
            height: 100%;
        }

        img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
    }

    .text {
        background-color: var(--sub-color06);
        transition: 0.5;
        padding: 15px;

        &:hover {
            opacity: 0.7;
            transition: 0.5;
        }
    }

    .title {
        color: var(--main-color02);
        font-weight: bold;
        line-height: 1.2;
        overflow: hidden;
        display: -webkit-box;
        text-overflow: ellipsis;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;

    }

    .date {
        margin-top: 5px;
        color: var(--main-color03);
        font-weight: bold;
    }
}



/*-------------------.blogCategories-----------------*/
.blogCategories {
    margin-top: 50px;

    .cats {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
        gap: 10px;

        a {
            background-color: var(--white);
            display: flex;
            justify-content: center;
            align-items: center;
            border: solid 3px var(--main-color02);
            color: var(--main-color02);
            font-size: 20px;
            font-weight: bold;
        }

        a.active {
            background-color: var(--main-color02);
            color: var(--white);
        }
    }


}

/*-------------------.prCorporate-----------------*/
.prCorporate {
    background-image: linear-gradient(to bottom, var(--white) 100px, #f5f5f5);
    padding-bottom: 70px;
}

.prCorporateHeader {
    position: relative;
    z-index: 1;
    padding: 54px 0;
}

.prCorporateHeader::before {
    position: absolute;
    top: 54px;
    left: 0;
    content: "";
    display: block;
    background: var(--sub-color01) url("img/bg_stripe01.png");
    width: 100%;
    height: 400px;
    z-index: -1;
}

.prCorporateHeader::after {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    content: "";
    display: block;
    background: center / cover url("./img/img_character.png") no-repeat;
    width: 181px;
    height: 195px;
    z-index: 2;
    transform: translateX(550px);
}

.prCorporateHeader h2+img {
    display: block;
    margin: -24px auto 0;
    z-index: 2;
}

.prCorporate h2 {
    transform: translate(50%, -50%) rotate(-9.99deg);
    position: absolute;
    text-align: center;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: fit-content;
}

.prCorporate h2::before {
    content: "";
    display: block;
    position: absolute;
    top: -125px;
    right: 130px;
    margin: 0;
    background: url("./img/img_deco01.png") no-repeat;
    width: 65px;
    height: 34px;
}

.prCorporate h2 small {
    display: block;
    position: absolute;
    font-size: 34px;
    background: var(--main-color02);
    color: var(--white);
    transform: translateY(-100%);
    top: 0;
    right: 110px;
    padding: 2px 30px 21px;
    --s: 14px;
    clip-path: polygon(0 calc(100% - (var(--s) * 2)),
            0 var(--s),
            var(--s) 0%,
            calc(100% - var(--s)) 0%,
            100% var(--s),
            100% calc(100% - (var(--s) * 2)),
            calc(100% - var(--s)) calc(100% - (var(--s) * 1)),
            calc(50px + calc(var(--s) * 1.25)) calc(100% - var(--s)),
            50px 100%,
            50px calc(100% - var(--s)),
            var(--s) calc(100% - var(--s)));
}

.prCorporate h2 small::before {
    content: "";
    display: block;
    position: absolute;
    width: 10px;
    height: 12px;
    background: var(--main-color02);
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    transform: translateY(100%);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.prCorporate h2 span {
    background: var(--black);
    color: var(--white);
    font-size: clamp(27px, 9vw, 40px);
    font-weight: 700;
    display: block;
    width: fit-content;
    margin: 5px 0;
    padding: 0 5px 10px;
    line-height: 1;
    font-feature-settings: "palt";
}

.prCorporate h2 span:last-of-type {
    padding: 2px 5px 8px;
}

.prCorporate h2 span b {
    color: var(--main-color03);
    font-size: clamp(60px, 14vw, 80px);
    font-weight: 700;
}

.prCorporate .inner {
    text-align: center;
}

.prCorporate .inner h3 {
    text-align: center;
    color: var(--main-color02);
    margin-bottom: 30px;
    font-size: clamp(15px, 4vw, 20px);
    font-weight: 500;
}

.prCorporate .inner .btnColor01 {
    margin-top: 35px;

}

/*------------------- #corporate 会社案内 -----------------*/
.corporateOutline {
    margin-top: -50px;
    padding-bottom: 0;
    z-index: 6;
}

.corporateOutline table td {
    background: var(--white);
}

#corporate .medals {
    position: relative;
    margin-top: 0;
    margin-bottom: 10px;
    z-index: 5;
}

#corporate .medals::before {
    background-color: var(--red);
    background-image: url("img/bg_stripe01.png"), url("img/bg_stripe01.png"), url("img/bg_stripe01.png"), url("img/bg_stripe01.png");
    /* 重ねて濃さの調整 */
    display: block;
    content: "";
    width: 100%;
    height: 200%;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto 0;

    -webkit-mask-image: url("./img/img_polygon01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: -50% 13%;
    -webkit-mask-size: cover;
    mask-image: url("./img/img_polygon01.svg");
    mask-repeat: no-repeat;
    mask-position: -50% 13%;
    mask-size: cover;
    height: 150%;
}

#corporate .medals ul {
    display: flex;
    gap: 0 5px;
    justify-content: center;
    margin: 0px auto;
    padding: 50px 50px;
    max-width: 1100px;
}

#corporate .medals ul li {
    display: block;
    padding: 10px;
}

#corporate .medals ul li.no-medal {
    display: none;
}

#corporate .medals ul li img {
    width: 100%;
    height: auto;
    display: block;
    filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.5));
}

#corporate #main .reasonList {
    margin-top: 100px;
}

#corporate #main .reasonList>.inner:last-of-type {
    overflow: visible;
    padding-bottom: 0;
}

#corporate #main .reasonList>.inner:last-of-type::before {
    top: -60px;
    bottom: auto;
    z-index: 5;
}


/*------------------- .blogSingle 現場ブログ -----------------*/
.blogSingle {
    .main {
        .time {
            margin-top: 5px;
            color: var(--main-color03);
            font-weight: bold;
            font-size: 15px;
        }

        .cats {
            display: flex;
            flex-wrap: wrap;
            height: calc(1em + 8px);
            font-size: 13px;
            font-weight: 600;
            line-height: 1;
            overflow: hidden;

            li>a {
                color: var(--main-color02);
                background-color: var(--main-color01);
                padding: 4px 8px;
            }
        }
    }

    .infoBox+.wysiwyg {
        margin-top: 50px;
    }
}

.editorBox,
.editorProf {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 30px;
}

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

.editorProf {
    margin-bottom: 0;
}

.editorProf .photoBox {
    width: 60px;
    height: 60px;
}

.editorProf .photoBox img {
    width: 100%;
    height: 100%;
    border-radius: 50vh;
    object-fit: cover;
}

.editorProf .staffName {
    margin: 0 0 0 15px;
    font-weight: 500;
}

/*------------------- #contact お問い合わせ -----------------*/

#contact #main {
    padding-bottom: 0;
}

#contact #main .messageBox {
    padding: 0 0 50px;
}

/*------------------- #faq よくあるご質問 -----------------*/
#faq #main {
    padding-top: 0;
}

#faq #main .ftrFaq .faqAnswer {
    max-height: 500px !important;
    border-bottom-width: 1px !important;
    transition: all 1.5s !important;
}

#faq #main .ftrFaq .title::after,
#faq #main .ftrFaq .title::before {
    content: none;
}

/*------------------- #subsidy 補助金・助成金 -----------------*/
.subsidyPage {
    .intro {
        padding: 50px 0;
        background-color: #f6f6f6;

        p {
            text-align: center;
            margin-top: 35px;
        }
    }
}

.subsidyIndex {
    padding: 50px 0;
    background-color: var(--sub-color06);
}

.subsidyIndex .title a {
    position: relative;
    display: block;
    font-size: 26px;
    font-weight: 500;
    padding: 15px;
    text-align: left;
    background-color: var(--white);
    color: var(--black) !important;
    text-decoration: none !important;

    @media (min-width:1000px) {
        padding: 35px 50px 35px 380px;
    }
}

.subsidyIndex .title a:hover {
    color: var(--main-color02) !important;
}

@media (min-width:1000px) {
    .subsidyIndex .title a::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 323px;
        height: 100%;
        background-position: left center;
        background-repeat: no-repeat;
        background-size: cover;
        clip-path: polygon(0 0, 70% 0, 100% 100%, 0% 100%);
    }
}

.subsidy01Index .title a::before {
    background-image: url(img/bg_subsidy_menu01.jpg);
}

.subsidy02Index .title a::before {
    background-image: url(img/bg_subsidy_menu02.jpg);
}

.subsidyIndex .title a::after {
    position: absolute;
    display: block;
    top: 0;
    right: 25px;
    bottom: 0;
    margin: auto 0;
    content: "";
    width: 18px;
    height: 30px;
    background: currentColor;
    -webkit-mask-image: url("./img/arrowR.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/arrowR.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    transform: rotate(90deg);
    transition: all 0.3s ease;

    @media (min-width:1000px) {
        right: 45px;
    }
}

.subsidyIndex ul,
.subsidyIndex ol {
    display: flex;
    justify-content: center;
    gap: 30px 40px;
    flex-wrap: wrap;
    margin: 50px 0;
}

.subsidyIndex li {
    display: block;
    width: 100%;

    @media (min-width:1000px) {
        width: calc((100% - 80px) / 3);

    }
}

.subsidyIndex li a {
    display: block;
    position: relative;
    text-align: left;
    font-size: 16px;
    font-weight: 500;
    padding: 0 0 10px;
    color: var(--black) !important;
    border-bottom: 1px solid currentColor;
    text-decoration: none !important;

    @media (min-width:1000px) {
        padding: 0 0 30px;

    }
}

.subsidyIndex li a:hover {
    color: var(--red) !important;
}

.subsidyIndex li a::after {
    position: absolute;
    display: block;
    top: 0.6em;
    right: 15px;
    margin: 0;
    content: "";
    width: 11px;
    height: 17px;
    background: currentColor;
    -webkit-mask-image: url("./img/arrowR.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/arrowR.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    transform: rotate(90deg);
    transition: all 0.3s ease;
}

#subsidy01,
#subsidy02 {
    padding-top: 60px;
    padding-bottom: 60px;
    background-color: var(--sub-color06);
    position: relative;
    z-index: 0;
    padding-top: 60px;

    &::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        /* background: url(./img/bg_orangedot.gif); */
        background: url(./img/bg_limedot.gif);
        width: 100%;
        height: 250px;
        z-index: -1;
    }

    h2 {
        font-size: clamp(30px, 8vw, 50px);
        color: var(--main-color02);
        text-align: center;
        font-weight: 500;
        padding-inline: 15px;

        @media (min-width:1000px) {
            padding-inline: 0;
        }

        .underLine {
            position: relative;
            display: inline-block;
            font-weight: 900;

            &::before {
                content: '';
                position: absolute;
                bottom: 0px;
                left: 0;
                width: 100%;
                height: 10px;
                /* background-color: var(--white); */
                background-color: var(--main-color03);
                z-index: -1;
            }
        }
    }
}

.subsidyIndex ol {
    counter-reset: count;
}

.subsidyIndex ol li a::before {
    counter-increment: count;
    content: "条件 0" counter(count);
    border-radius: 25px;
    background: var(--main-color02);
    color: var(--white);
    padding: 2px 15px;
    display: inline-block;
    margin-right: 10px;
}

.subsidy01List,
.subsidy02List {
    margin-top: 50px;
}

.subsidy01List .alignright,
.subsidy02List .alignright {
    @media (max-width:1000px) {
        float: none;
        margin-left: 0 !important;
        text-align: center !important;
    }
}

.subsidy01List li+li,
.subsidy02List li+li {
    margin-top: 70px;
}


.subsidy02List {
    counter-reset: count;
}

.subsidy02List li .title {
    display: flex;
    flex-wrap: wrap;
    gap: 5px 20px;
    align-items: center;
    justify-content: center;
}

.subsidy02List li .title::before {
    counter-increment: count;
    content: "条件 0" counter(count);
    border-radius: 30px;
    background: var(--main-color02);
    color: var(--white);
    padding: clamp(5px, 1.5vw, 15px) 30px;
    font-size: clamp(15px, 4vw, 20px);
    font-weight: 700;
}

.subsidy02List .box02 {
    width: 100%;
    overflow: hidden;
}

/*------------------- #flow 施工の流れ -----------------*/
.flowIndexBox {
    padding: 50px 0 30px;

    h2 {
        font-size: clamp(20px, 4.5vw, 25px);
        color: var(--main-color02);
        font-weight: 900;
        text-align: center;
    }
}

.flowIndex {
    margin-top: 30px;


    @media (min-width:650px) {
        display: flex;
        justify-content: space-between;
        width: fit-content;
        margin-inline: auto;

    }
}

.flowIndex ol {
    counter-reset: my-counter;

    @media (min-width:650px) {
        display: flex;
        flex-direction: row;
        justify-content: center;
        gap: 0 35px;
    }
}

.flowIndex li {
    position: relative;

    &::before {
        font-family: Roboto, sans-serif;
        content: counter(my-counter);
        counter-increment: my-counter;
        color: var(--white);
        display: block;
        position: absolute;
        top: 10px;
        left: 15px;
        margin: 0 auto;
        z-index: 5;
    }

    &::after {
        position: absolute;
        content: "";
        border-top: 9px solid var(--ts);
        border-left: 10px solid var(--main-color02);
        border-bottom: 9px solid var(--ts);
        display: none;
        width: 0;
        height: 0;
        transform: translateX(100%);
    }

    &:last-of-type::after {
        display: none;
    }

    @media (min-width:650px) {
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-lr;

        &::before {
            transform: translateY(-25%) rotate(-90deg);
            top: 20px;
            left: 0;
            right: 0;
        }

        &::after {
            display: block;
            top: calc(50% - 5px);
            right: -10px;

        }
    }
}

.flowIndex li+li {
    margin-top: 5px;

    @media (min-width:650px) {
        margin-top: 0;

    }

}

.flowIndex li a {
    position: relative;
    display: block;
    background-color: var(--main-color03);
    color: var(--white);
    padding: 4px 50px 4px 40px;
    font-weight: 500;
    font-size: 20px;
    text-decoration: none;
    transition: all 0.3s ease;
    z-index: 2;
    overflow: hidden;

    @media (min-width:650px) {
        padding: 50px 10px 40px;

    }
}

.flowIndex li a:hover {
    background-color: var(--sub-color02);
}

.flowIndex li a::after {
    content: "";
    position: absolute;
    right: 23px;
    bottom: 17px;
    margin: 0 auto;
    width: 1em;
    height: 1em;
    font-size: 10px;
    border-right: 3px solid currentColor;
    border-bottom: 3px solid currentColor;
    transform: translate(0%, 0%) rotate(45deg);
    transition: all 0.3s ease;

    @media (min-width:650px) {
        right: 0;
        left: 0;
        bottom: 15px;
    }

}

.flowIndex li a:hover::after {
    transform: translate(0%, 25%) rotate(45deg);
}

.flowIndex .img {
    width: 263px;
    height: 339px;
    position: relative;
}

.flowIndex .img img {
    position: absolute;
    display: block;
}

.flowIndex .img img:first-of-type {
    left: 0;
    bottom: 0;
}

.flowIndex .img img:last-of-type {
    top: 0;
    right: 0;
}

.flowBox {
    padding: 50px 0 0;
    background-color: var(--sub-color06);

    &.limeDotBar {
        position: relative;
        z-index: 0;

        &::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            background: url(./img/bg_limedot.gif);
            width: 100%;
            height: 250px;
            z-index: -1;
        }
    }

    h2 {
        font-size: clamp(30px, 8vw, 50px);
        color: var(--main-color02);
        text-align: center;

        .underLine {
            position: relative;
            display: inline-block;
            font-weight: 900;

            &::before {
                content: '';
                position: absolute;
                bottom: 0px;
                left: 0;
                width: 100%;
                height: 10px;
                background-color: var(--main-color03);
                z-index: -1;
            }
        }
    }

    .cta {
        padding-top: 100px;
    }
}

.flowList {
    counter-reset: my-counter;

    .flowItem {
        margin-top: 30px;
        position: relative;
        background-color: var(--white);
        border-radius: 20px;
        contain: paint;
        border: solid 1px #ccc;

        &:first-child {
            margin-top: 50px;
        }

        @media (min-width:800px) {
            display: grid;
            grid-template-columns: min(40%, 450px) 1fr;
            gap: 0;
        }

        .img {
            img {
                width: 100%;
                height: 100%;
                object-fit: cover;
            }
        }

        .textBox {
            padding: clamp(20px, 7.5vw, 30px);
        }

        .title {
            position: relative;
            display: flex;
            align-items: center;
            gap: 15px;
            font-size: clamp(27px, 5vw, 35px);
            font-weight: 900;
            color: var(--main-color03);

            &::before {
                flex-shrink: 0;
                --icon-size: clamp(40px, 12vw, 60px);
                content: counter(my-counter, decimal-leading-zero);
                counter-increment: my-counter;
                color: var(--white);
                display: flex;
                justify-content: center;
                align-items: center;
                width: var(--icon-size);
                height: var(--icon-size);
                font-size: 20px;
                font-family: 'Roboto';
                font-weight: 700;
                background: var(--main-color03);
                border-radius: 100vh;
                line-height: 1;
            }
        }

        .wysiwyg {
            margin-top: 30px;
        }
    }
}





/*------------------- #works 施工事例 -----------------*/

#works #main h1.pageTitle {
    margin-bottom: 20px;
}

#works #main .picBox {
    display: flex;
    gap: 40px;
    margin-bottom: 50px;
    justify-content: space-between;
    flex-direction: row-reverse;
}

#main .picBox .photo {
    width: 60%;
    height: 470px;
    position: relative;
}

#main .picBox .photo img {
    object-fit: cover;
    width: 100%;
    height: 470px;
}

#main .picBox .btmPhoto {
    width: 40%;
    height: 330px;
    position: relative;
}

#main .picBox .btmPhoto img {
    object-fit: cover;
    width: 100%;
    height: 330px;
}

#main .picBox span.after,
#main .picBox span.before {
    position: absolute;
    top: 0;
    left: 0;
    background: var(--black);
    display: inline-block;
    z-index: 10;
    font-size: 15px;
    font-weight: 700;
    color: var(--white);
    padding: 3px 10px 2px 10px;
}

#main .picBox span.after {
    background: var(--red);
}

#main .picBox span span {
    opacity: 0.5;
    margin-left: 5px;
}

#main .picBox02 {
    margin-top: 40px;
}

/*------------------- #menu 解体メニュー -----------------*/
#menu #main .menuList {
    margin-top: 60px;
    padding: 60px 0;
    background: center center url("./img/bg_construction.jpg") no-repeat;
}

#menu .menuList .inner>ul {
    margin-top: 0;
    margin-bottom: 0;
}

/*------------------- #reason 選ばれる理由 -----------------*/
#reason h2.popheading {
    font-size: 46px;
}

/* .wp-pagenavi */
.wp-pagenavi {
    text-align: center;
    margin: 50px 0;
}

.wp-pagenavi .pages {
    border: 0;
}

.wp-pagenavi a {
    text-decoration: none !important;
}

.wp-pagenavi a,
.wp-pagenavi span {
    border: 1px solid var(--black);
    color: var(--black) !important;
    padding: 2px 10px 8px;
    line-height: 1;
    transition: all 0.3s ease;
}

.wp-pagenavi a:hover,
.wp-pagenavi span.current {
    background: var(--black);
    color: var(--white) !important;
}

#main .wysiwyg {
    overflow: hidden;
}

#main .freeCom,
#main .cstCom,
#main .cstStaff {
    margin: 20px 0 50px 0;
}

/* .wysiwyg */
.inner.wysiwyg {
    padding-block: 50px;
}

#main .wysiwyg * {
    word-break: break-word;
}

#main .wysiwyg img {
    max-width: 100%;
    height: auto;
}

#main .wysiwyg p {
    margin: 0 0 20px 0;
}

#main .wysiwyg iframe {
    width: 100%;
    height: 500px;
}

#main .wysiwyg h1,
#main .wysiwyg h2 {
    background: var(--main-color02);
    color: var(--white);
    font-size: clamp(20px, 7.5vw, 30px);
    font-weight: 500;
    margin: 0 0 20px 0;
    padding: 20px 30px;
    font-weight: 900;
    line-height: 1.2;
}

#main .wysiwyg h1 a,
#main .wysiwyg h2 a {
    color: var(--white);
}

#main .wysiwyg h3:not([class]) {
    color: #333;
    background: var(--sub-color06);
    font-size: 1.25rem;
    font-weight: 900;
    margin: 0 0 20px 0;
    padding: 15px 20px;
    line-height: 1.2;
}

#main .wysiwyg h4:not([class]) {
    font-size: 1.25rem;
    font-weight: 900;
    border-bottom: solid 5px var(--main-color02);
    margin: 0 0 20px 0;
    padding: 10px 10px 12px 0px;
    line-height: 1.2;
}

#main .wysiwyg h5:not([class]) {
    font-size: 16px;
    font-weight: 900;
    background-color: var(--main-color02);
    color: var(--white);
    margin: 0 0 20px 0;
    padding: 10px 20px;
    width: fit-content;
    line-height: 1.2;
}

#main .wysiwyg h6:not([class]) {
    font-size: 16px;
    font-weight: 900;
    color: var(--main-color03);
    margin: 0 0 20px 0;
    padding: 0 10px 15px 0px;
    line-height: 1.2;
}

#main .wysiwyg blockquote {
    border: 1px dotted var(--black);
    background: #f6f6f6;
    margin-bottom: 20px;
    padding: 20px;
}

#main .wysiwyg blockquote p:last-of-type {
    margin-bottom: 0;
}

#main .wysiwyg ul+h3:not([class]) {
    margin-top: 40px;
}

#main .wysiwyg ul {
    margin: 0 0 20px 0;
}

#main .wysiwyg ul li {
    list-style: none;
    line-height: 1.8;
    margin-bottom: 10px;
    padding-left: 30px;
    position: relative;
}

#main .wysiwyg ul li::before {
    content: '';
    display: block;
    left: 7px;
    top: 10px;
    width: 10px;
    height: 10px;
    background: var(--main-color02);
    border-radius: 50%;
    position: absolute;
}

#privacy #main .wysiwyg ul li::before {
    background: #ccc;
}

#main .wysiwyg ol {
    counter-reset: my-counter;
    list-style: none;
    padding: 0;
    margin-bottom: 30px;
}

#main .wysiwyg ol li {
    list-style: none;
    line-height: 1.8;
    margin-bottom: 10px;
    padding-left: 36px;
    position: relative;
}

#main .wysiwyg ol li:before {
    font-family: Roboto, sans-serif;
    font-size: 16px;
    content: counter(my-counter);
    counter-increment: my-counter;
    background-color: var(--main-color02);
    color: var(--white);
    display: block;
    float: left;
    line-height: 28px;
    margin-left: -36px;
    text-align: center;
    height: 28px;
    width: 28px;
    border-radius: 50%;
}

#main .wysiwyg table th,
#main .wysiwyg table td {
    padding: 30px 20px;
}

#main .wysiwyg table th {
    width: unset;
}

/* .box */
.boxList {
    display: flex;
    justify-content: space-between;
    gap: 40px;
}

.box01 {
    --box-color: var(--main-color02);
}

.box02 {
    --box-color: var(--main-color03);
}

.box03 {
    --box-color: var(--main-color02);
}

.box03::after {
    content: "";
    display: block;
    clear: both;
}

.box01,
.box02,
.box03 {
    flex: 1;
    outline-offset: -1px;
    padding: clamp(30px, 8vw, 50px);
    border-radius: 10px;

    background: var(--white);
    outline: 6px solid var(--box-color);
}

#rebuilding,
#demolition {
    margin-top: 50px;
}

#demolition {
    padding-bottom: 90px;
}

#landselling .inner,
#rebuilding .inner,
#demolition .inner {
    overflow: visible;
}

.box01 .title,
.box02 .title,
.box03 .title {
    font-size: clamp(18px, 2.8vw, 32px);
    font-weight: 900;
    color: var(--white);
    margin: clamp(-50px, -8vw, -30px) clamp(-50px, -8vw, -30px) clamp(30px, 8vw, 50px);
    padding: 25px;
    background: var(--box-color);
    text-align: center;
}


#landselling .box02>.title,
#rebuilding .box02>.title,
#demolition .box02>.title {
    position: relative;
    padding-left: 200px;
}

#landselling .box02>.title::before,
#rebuilding .box02>.title::before,
#demolition .box02>.title::before {
    position: absolute;
    top: 0;
    left: 30px;
    bottom: 0;
    margin: auto 0;
    content: "";
    display: block;
    background: #fff5ce;
    width: 160px;
    height: 142px;
    -webkit-mask-image: url("./img/img_polygon01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_polygon01.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
}

#landselling .box02>.title::after,
#rebuilding .box02>.title::after,
#demolition .box02>.title::after {
    display: block;
    position: absolute;
    content: "";
    top: -100%;
    left: 30px;
    bottom: -100%;
    margin: auto 0;
    width: 160px;
    height: 142px;
}

#landselling .box02>.title::after {
    background-image: url("img/img_beginners01.png");
    background-repeat: no-repeat;
    background-size: 110px auto;
    background-position: center;
    transform: translateY(-10px);
}

#rebuilding .box02>.title::after {
    background-image: url("img/img_beginners02.png");
    background-repeat: no-repeat;
    background-size: 110px auto;
    background-position: center;
}

#demolition .box02>.title::after {
    background-image: url("img/img_beginners03.png");
    background-repeat: no-repeat;
    background-size: 110px auto;
    background-position: center;
    transform: translateY(-10px);
}

.box01.box01Check .title {
    position: relative;
}

.box01.box01Check .title::before {
    position: absolute;
    content: "";
    display: block;
    top: 0;
    left: 0;
    width: 121px;
    height: 77px;
    background: url("img/check01.png") center / contain no-repeat;
    transform: translate(8%, -72%);
}

.box01 .img {
    max-width: 100%;
    height: auto;
    display: block;
}

.box02 .img.alignright,
.box03 .img.alignright {
    margin-left: 30px;
    margin-bottom: clamp(30px, 8vw, 50px);
}

.box02 .img img,
.box03 .img img {
    max-width: 100%;
    height: auto;
}

#main .box01 p.lead,
#main .box02 p.lead,
#main .box03 p.lead {
    margin: 35px 0 1rem;
    font-size: 20px !important;
    font-weight: 900;
    color: var(--main-color03);
    line-height: 1.25;
}

#main .box01 p {
    margin-bottom: 0;
}

.figureGroup {
    display: flex;
    gap: 20px;
    margin-bottom: 0;
}

.figureGroup>figure {
    flex: 1;
}

.figureGroup>figure img {
    display: block;
    width: fit-content;
    height: auto;
    max-width: 100%;
    margin: auto;
}

.figureGroup>figure figcaption {
    color: var(--white);
    font-size: 18px;
    font-weight: 600;
    text-align: center;
    margin-top: 10px;
    padding: 10px;
    line-height: 1;
}

.costcut {
    margin: 40px 0 0;
}

.costcut+br {
    display: none;
}

.costcut b {
    border: 1px solid #ccc;
    background: #f4f4f4;
    font-size: 18px;
    font-weight: 400;
    height: calc(100% - 20px);
    display: block;
    margin: 10px;
    padding: 5px 23px;

    letter-spacing: -0.05em;
}

.costcut img {
    display: block;
    margin: 0 0 20px;
}

.costcut .title {
    padding: 0;
    margin: 0;
    color: var(--white);
    font-size: 30px !important;
    padding: 20px;
    line-height: 1;
}

.costcut01 .title {
    background: var(--sub-color04);
}

.costcut02 .title {
    background: var(--main-color02);
}

.costcut01,
.costcut02 {
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-lr;
    text-align: center;
    display: flex;
    width: 100%;
    flex-direction: column;
    background-image: url("img/bg_stripe01.png");
    height: 280px;
    margin-bottom: 20px;
}

.costcut01 {
    background-color: #d4d4d4;
}

.costcut02 {
    background-color: var(--main-color03);
}

.costcutFlow {
    background: var(--white);
    display: flex;
    flex-direction: column;
    margin: 20px;
    padding: 10px;
    width: calc(100% - 40px);

    justify-content: space-between;
}

.costcutFlow div {
    position: relative;
}

.costcutFlow em {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto 0;
    -ms-writing-mode: horizontal-tb;
    writing-mode: horizontal-tb;
    line-height: 1;
    color: var(--red);
    height: fit-content;
    transform: translateX(100%);
    font-size: 18px;
    background: var(--white);
    border-radius: 2px;
    z-index: 10;
    text-shadow: 2px 2px 0px var(--white), -2px 2px 0px var(--white), 2px -2px 0px var(--white), -2px -2px 0px var(--white);
    width: 60px;
    height: 10px;
}

.costcut02 .costcutFlow em {
    width: 590px;
    color: var(--main-color02);
}

.costcutFlow em i {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    display: block;
    transform: translateY(40px) scaleX(0.9);
    width: 80px;
    white-space: nowrap;
    text-align: center;
    font-style: normal;
    background: var(--white);
    height: fit-content;
}

.costcutFlow em::before,
.costcutFlow em::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    margin: auto 0;
}

.costcutFlow em::before {
    width: 100%;
    height: 23px;
    background: currentColor;
    border-radius: 2px 0 0 2px;
}

.costcutFlow em::after {
    width: 28px;
    height: 48px;
    background: currentColor;
    -webkit-mask-image: url("./img/img_triangle01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_triangle01.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    transform: translate(90%, -25%);
}

.costcutFlow>div:first-of-type {
    margin-right: 40px;
}

.costcut02 .costcutFlow>div:first-of-type {
    margin-right: 0;
}

.costcutFlow>div:first-of-type em::before {
    transform: none;
}

.costcut01 .costcutFlow>div:first-of-type em {
    width: 40px;
    color: var(--sub-color04);
}

.costcut01 .costcutFlow>div:first-of-type em:first-of-type {
    width: 218px;
    transform: translate(100%, -75px);
}

.costcut01 .costcutFlow>div:first-of-type em:last-of-type {
    transform: translate(100%, 40px);
}

.costcutFlow>div:nth-of-type(2) {
    margin: 10px;
    border: 1px dashed var(--red);
    display: flex;
    gap: 83px 0;
    margin: 0px auto;
    padding: 0 60px 0 0;
    flex-direction: column;
    justify-content: space-between;
}

.costcutFlow>div:nth-of-type(2) div:nth-of-type(n+2)>b {
    padding-bottom: 0;
}

.costcutFlow>div:nth-of-type(2) div:first-of-type {
    align-self: flex-end;
    height: fit-content;
    margin-bottom: 0;
}

.costcutFlow>div:nth-of-type(2) em {
    transform: translate(100%, -3px);
}

.costcut02 .costcutFlow>div:nth-of-type(2) {
    width: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #ffeeee;
    z-index: 10;
    padding: 0;
    width: 450px;
    gap: 0;
}

.costcut02 .costcutFlow>div:nth-of-type(2)>div {
    -ms-writing-mode: horizontal-tb;
    writing-mode: horizontal-tb;
    font-size: clamp(30px, 8vw, 50px);
    font-weight: 700;
    line-height: 1.25;
    width: fit-content;
    height: fit-content;
    margin: auto;
    color: var(--sub-color03);
    letter-spacing: -0.05em;
    transform: scaleX(0.9);
}

.costcutFlow>div:last-of-type {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    width: 122px;
    margin: 0 10px 0 30px;
}

.costcutFlow>div:last-of-type b {
    -ms-writing-mode: horizontal-tb;
    writing-mode: horizontal-tb;
    background: var(--sub-color04);
    color: var(--white);
    width: 100%;
    height: fit-content;
    font-size: 16px;
    padding: 5px 0;

    line-height: 1;
    border: 0;
}

.costcut02 .costcutFlow>div:last-of-type b {
    background: var(--main-color02);
}

.costcutFlow>div:last-of-type img {
    margin: 20px auto;
    display: block;
    width: fit-content;
    height: auto;
    max-width: 100%;
}

.costcut02 .costcutFlow>div:last-of-type img {
    max-width: 77px;
}

.costcut03 {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.costcut03>figure img {
    width: fit-content;
    height: auto;
    max-width: 100%;
    margin: auto;
}

.corporateConditions {
    display: flex;
    padding-bottom: 100px;
    gap: 0 10px;
}

.corporateConditions>div {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
}

.corporateConditions>div>span {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 210px;
    height: 210px;
    position: relative;
    z-index: 1;
}

.corporateConditions>div>span::before {
    content: "";
    position: absolute;
    display: block;
    inset: 0;
    margin: auto;
    width: 100%;
    height: 100%;
    background: #f6e5a5;
    z-index: -1;
    -webkit-mask-image: url("./img/img_polygon01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center top;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_polygon01.svg");
    mask-repeat: no-repeat;
    mask-position: center top;
    mask-size: contain;
}

.corporateConditions>div:nth-of-type(1) b,
.corporateConditions>div:nth-of-type(3) b {
    letter-spacing: 0.25em;
    text-indent: 0.25em;
}

.corporateConditions>div:nth-of-type(5) b {
    letter-spacing: -0.05em;
}

.corporateConditions>div:nth-of-type(3)>span::before {
    background: #b4d8ba;
    -webkit-mask-image: url("./img/img_polygon03.svg");
    mask-image: url("./img/img_polygon03.svg");
}

.corporateConditions>div:nth-of-type(5)>span::before {
    background: #aad1e9;
    -webkit-mask-image: url("./img/img_polygon04.svg");
    mask-image: url("./img/img_polygon04.svg");
}

.corporateConditions>div {
    font-size: clamp(30px, 8vw, 50px);
    font-weight: 900;
}

.corporateConditions>div b {
    font-size: 36px;
    font-weight: 700;
}

.corporateConditions small {
    margin-top: 20px;
    font-size: 16px;
    line-height: 1.2;
    text-align: center;
    position: absolute;
    display: block;
    left: 0;
    right: 0;
    bottom: 0;
    transform: translateY(100%);
    padding-top: 20px;
    font-weight: 400;
}

.corporateConditions>div:last-of-type {
    color: var(--red);
    line-height: 1.1;
    text-align: center;
    font-weight: 700;
}

.ownershipRisks {
    margin: 50px 0 0;
    padding: 45px;
}

.ownershipRisks .title {
    background: none;
    font-size: 22px !important;
    font-weight: 500;
    text-align: center;
    margin: 0;
    padding: 0 0 20px;
}

.ownershipRisks .title strong {
    font-weight: 500;
}

.ownershipRisks .figureGroup {
    margin-bottom: -20px;
}

.ownershipRisks .figureGroup figure {
    aspect-ratio: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.ownershipRisks .figureGroup figcaption {
    padding: 10px 10px 0;
}

#top #main .top_photobook {
    padding: 20px 0;
}

#top #main .top_photobook h2 {
    width: inherit;
    text-align: center;
}

#main .top_photobook_catch {
    font-size: clamp(15px, 4vw, 20px);
    font-weight: 600;
    text-align: center;
}

#top #main .top_photobook_box {
    display: flex;
    padding: 20px;
}

#main .photobook_R {
    margin-left: 30px;
}

#main .photobook_R dl {
    position: relative;
    background: rgba(255, 201, 0, 0.2);
    padding: 20px;
}

#main .photobook_R a {
    color: inherit;
    text-decoration: none;
}

#main .photobook_R dt {
    font-weight: 600;
    border-bottom: 1px dotted var(--black);
    margin-bottom: 10px;
}

#main .img_photobook03 {
    position: absolute;
    right: 40px;
    bottom: 30px;
}

.moviePart {
    position: relative;
}

.moviePart::before {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    position: absolute;
    text-align: center;
    background-color: var(--main-color02);
    -webkit-mask-image: url("./img/img_polygon01.svg");
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-position: center;
    -webkit-mask-size: contain;
    mask-image: url("./img/img_polygon01.svg");
    mask-repeat: no-repeat;
    mask-position: center;
    mask-size: contain;
    opacity: 0.2;
    transform: translateX(25%);
}

.moviePart h2 {
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 50px;
}

/* -----------------------------------------------------------
    spGNav
----------------------------------------------------------- */
#spGNav {
    position: fixed;
    right: -120%;
    display: block;
    z-index: 5555;
    background: rgba(0, 0, 0, 0.8);
    width: 100%;
    top: 84px;
    transition: all 0.6s;

    padding: 4% 3%;
}

#spGNav .spblock {
    display: block;
}

#spGNav.navActive {
    right: 0;
}

#spGNav {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    justify-content: flex-start;
}

#spGNav li {
    display: block;
    width: 100%;
}

#spGNav li a {
    display: block;
    background: var(--main-color02);
    color: var(--white);
    text-align: center;
    padding: 7px 10px;
    overflow: hidden;
    text-decoration: none;
}

#spGNav li a:hover {
    text-decoration: none;
}

#spGNav li a::after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f054";
    float: right;
}

#spGNav li:nth-last-child(3),
#spGNav li:nth-last-child(4) {
    width: calc(50% - 2.5px);
}

#spGNav li:nth-last-child(3) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f075";
    margin-right: 5px;
}

#spGNav li:nth-last-child(4) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f15c";
    margin-right: 5px;
}

#spGNav li:nth-last-child(2) a {
    color: var(--main-color02);
    background-color: var(--main-color01);
}

#spGNav li:nth-last-child(2) a::after {
    display: none;
}

#spGNav li:nth-last-child(2) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f0e0";
    margin-right: 5px;
}

#spGNav li:last-child a {
    color: var(--sub-color04);
    background: var(--white);
}

#spGNav li:last-child a::after {
    content: "\f00d";
    margin-left: 5px;
    float: none;
}

/* -----------------------------------------------------------
    ftrFab
----------------------------------------------------------- */

footer .ftrFab {
    position: fixed;
    bottom: 70px;
    right: 0;
    z-index: 1000;

    bottom: 0;
    left: 0;
}

footer .ftrFab ul {
    display: flex;
    justify-content: space-between;
    gap: 0 1px;
}

footer .ftrFab li {
    flex: 1;
    display: block;
}

footer .ftrFab li img {
    display: block;
    margin: 0 auto;
}

footer .ftrFab li.spnone {
    display: none;
}

footer .ftrFab li a i {
    display: block;
    font-size: 2.0rem;
}

footer .ftrFab li a {
    text-align: center;
    display: block;
    background-color: var(--sub-color01);
    color: var(--white);
    text-decoration: none;
    font-weight: 400;

    padding: 10px 5px;
    line-height: 1.3;
}

footer .ftrFab li.ftrFabRequest a {
    background-color: var(--red);
}

footer .ftrFab li.ftrFabContact a {
    background-color: var(--main-color02);
}

footer .ftrFab li.ftrLine a {
    background-color: #06c755;
    padding-top: 0;
    padding-bottom: 0;
}

footer .ftrFab li.ftrLine img {
    width: auto;
    height: 67.6px;
}

/* -----------------------------------------------------------
    spHdrBtn
----------------------------------------------------------- */

header .inner #spHdrBtn {
    display: flex;
    justify-content: end;
    gap: 1px;
}

.telBtn {
    padding-right: 31px;
}

.telBtn a,
.mailBtn a,
.spmenuBtn {
    text-align: center;
    font-weight: bold;
    display: inline-block;
    height: 45px;
    width: 45px;
    vertical-align: middle;
    line-height: 1;

}

.telBtn a {
    font-size: 26px;
    background: var(--sub-color01);
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--white);
    text-decoration: none;
}

.mailBtn a {
    font-size: 26px;
    background: var(--main-color02);
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--white);
    text-decoration: none;
}

.spmenuBtn {
    top: 38px;
    right: 0;
    z-index: 99999;
    background: var(--main-color01);
    cursor: pointer;
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    align-content: center;
    gap: 10px;

    @media (min-width: 768px) {
        top: 30px;
    }

    @media (min-width:1200px) {
        top: 50px;
    }
}

.spmenuBtn span {
    height: 1px;
    width: auto;
    background-color: var(--main-color02);
    transition: all .4s;
    width: 70%;
}

.spmenuBtn span:nth-of-type(1) {}

.spmenuBtn span:nth-of-type(2) {}

.spmenuBtn.active span:nth-of-type(1) {
    transform: translateY(6px) rotate(-45deg);
    width: 50%;
}

.spmenuBtn.active span:nth-of-type(2) {
    transform: translateY(-6px) rotate(45deg);
    width: 50%;
}



/* -----------------------------------------------------------
    共通部品
----------------------------------------------------------- */

/*. contactTel */
.contactTel {
    font-weight: 600;
    margin-top: 60px;
    font-size: 1rem;
    text-align: center;
}

.contactTel b {
    background: var(--sub-color04);
    color: var(--white);
    margin-right: 5px;
    padding: 0 10px;
    display: inline-block;
}

.contactTel strong {
    color: var(--red);
}

.contactTel .tel {
    display: block;
    font-size: 1.15rem;
    font-weight: 400;
    text-align: center;
    width: fit-content;
    margin-right: auto;
}

.catchTtl {
    margin-top: 20px;
}

.sp-menu {
    margin: 30px auto 0;
    max-width: 600px;
}

#snavi select {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    margin: 0 auto;
    display: block;
    padding: 10px;
    border: solid 3px rgba(255, 255, 255, 0.46);
    border-radius: 8px;
    width: 95%;
    font-size: 16px;
    cursor: pointer;
    font-weight: bold;
    background: var(--main-color02) !important;
    background-size: 18px !important;
    color: var(--white);
}

.catchTtl {
    margin-top: 20px;
}

.sp-menu {
    margin: 30px auto 0;
    max-width: 600px;
}

#snavi select {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    margin: 0 auto;
    display: block;
    padding: 10px;
    border: solid 3px rgba(255, 255, 255, 0.46);
    border-radius: 8px;
    width: 95%;
    font-size: 16px;
    cursor: pointer;
    font-weight: bold;
    background: var(--main-color02) !important;
    background-size: 18px !important;
    color: var(--white);
}