@charset "utf-8";
/*
Theme Name: kaitai-montakun.jp
Theme URI: https://kaitai-montakun.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-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: 100% !important;
    background-color: #fafafa;
}

body *,
body *::before,
body *::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.inner {
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    padding: 0;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

@media screen and (max-width : 1100px) {
    .inner {
        max-width: calc(96vw);
    }

    .inner img {
        max-width: calc(96vw);
        height: auto;
    }
}

article {
    padding: 0 0 20px;
}

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

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

.btn {}

.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 {
    border-radius: 100vh;
    border: var(--black) 3px solid;
    position: relative;
    text-align: center;
    text-decoration: none !important;
    display: inline-block;
    font-weight: 600;
    padding: 15px 50px 15px 30px;
    transition: all 0.3s ease;
    color: var(--black) !important;
    min-width: 300px;
    background-color: white;
}

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

    .btnC a,
    .btnR a,
    .btn a,
    a .btn {
        min-width: 0;
    }
}

.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: 26px;
    height: 26px;

    font-family: "Font Awesome 5 Free";
    font-size: 14px;
    font-weight: 900;
    content: '\f105';
    color: var(--white);

    border-radius: 100vh;
    background: var(--black);
}

.btnLtl a {
    padding: 5px 45px 5px 30px;
    min-width: 150px;
    font-size: 14px;
}

.btnLtl a::after {
    right: 10px;
    width: 16px;
    height: 16px;
    font-size: 11px;
    line-height: 16px;
}

.btnC a:hover,
.btnR a:hover,
.btn a:hover,
a .btn:hover {
    color: var(--white) !important;
    background: var(--main-color01);
}

.btnC a:hover::after,
.btnR a:hover::after,
.btn a:hover::after,
a .btn:hover::after {
    color: var(--black);
    background: var(--white);
}

.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-color01);
    border-bottom: 3px solid var(--main-color01);
    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-color01) !important;
}

.radiusImg {
    border-radius: 20px;
}

.txtCenter {
    text-align: center;
}

.emStr {
    color: var(--black) !important;
    font-weight: 700 !important;
    text-decoration: underline;
    text-decoration-color: #ff6;
    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%);
}

.rndBoxList li,
.rndBox {
    background-color: var(--black);
    padding: 5px 10px;
    color: var(--white);
    border-radius: 20px;
    text-align: center;
    font-weight: 700;
}

.rndBox {
    width: fit-content;
    min-width: 80%;
    font-size: 36px !important;
    margin: 0 auto !important;
}

.rndBoxList {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    counter-reset: count-rndlist;
}

.rndBoxList li {
    counter-increment: count-rndlist;
    width: calc((100% - 20px) / 2);
    font-size: 24px;
}

.rndBoxList li::before {
    content: counter(count-rndlist);
    border-radius: 100vh;
    height: 24px;
    width: 24px;
    color: var(--black);
    background-color: var(--white);
    display: inline-block;
    margin-right: 5px;
    font-size: 20px;
    line-height: 24px;
}

.rndBoxList.clm03 li {
    width: calc((100% - 40px) / 3);
}

.fadeIn,
.fadeInUp,
.fadeInUpLeft,
.fadeInUpRight,
.fadeInBottomLeft,
.fadeInBottomRight {
    opacity: 0;
    transition: 0.7s;
}

.fadeIn.is-show,
.fadeInUp.is-show,
.fadeInUpLeft.is-show,
.fadeInUpRight.is-show,
.fadeInBottomLeft.is-show,
.fadeInBottomRight.is-show {
    transform: translate(0, 0);
    opacity: 1;
}

.fadeInUp {
    transform: translate(0, 15%);
}

.fadeInUpLeft {
    transform: translate(-20%, -20%);
}

.fadeInUpRight {
    transform: translate(20%, -20%);
}

.fadeInBottomLeft {
    transform: translate(-20%, 20%);
}

.fadeInBottomRight {
    transform: translate(20%, 20%);
}


.tel,
#main .tel {
    font-size: 30px;
}

.tel span.tel-link {
    font-family: var(--en-font-family);
    font-weight: 600;
    font-size: 40px;
    line-height: 1;
    margin-left: 5px;
    color: #222222;
}

.tel span.tel-link a:link,
.tel span.tel-link a:visited {
    color: var(--white);
    text-decoration: none;
}

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

.tel img {
    vertical-align: baseline;
}

.en {
    font-family: var(--en-font-family);
    font-weight: 500 !important;
    text-transform: capitalize;
}

.spblock,
.spinline,
.sptr {
    display: none;
}

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

.cats a,
.cats span {
    display: inline-block;
    text-decoration: none !important;
    background: var(--main-color02);
    padding: 0px 20px;
    margin: 0 2px;
}

.cats a {
    color: var(--white) !important;
    background: var(--main-color02);
}

.cats span {
    background: #e7f7ed;
}

.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;
}

#top header#header {}

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

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

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

#top {}

header .hdrLogo {
    background: var(--white);
    border-radius: 0 0 20px 0;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, .08);
    box-shadow: 0 0 8px rgba(0, 0, 0, .08);
    display: inline-block;
    padding: 30px;

}

.scrolled header#header .hdrLogo {
    background: white;
    -webkit-box-shadow: 0;
    box-shadow: none;
}

header#header .hdrLogo img {
    width: 11vw;
}

@media screen and (max-width: 1899px) {
    .scrolled header#header .hdrLogo img, header#header .hdrLogo img {
        width: 100%;
    }
}

.scrolled header#header .hdrLogo img {
    width: 115px;
}

header .hdrLogo img {
    display: block;
}

header .hdrMedal {
    margin: 10px 0;
}

header .inner {
    max-width: 100vw;
    width: auto;
    display: flex;
    justify-content: space-between;
    overflow: visible;
    padding-right: 50px;
    /* align-items: center; */
    gap: 10px;
    margin: 0;
}

header .inner .boxR {
    text-align: right;
    padding: 20px 0 0 10px;
    box-sizing: border-box;
}

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

header .inner .hdrTel {
    display: flex;
    align-items: center;
    line-height: 1;
    padding: 5px 0;
    color: var(--black);
}

header .inner .hdrTel .tel {
    font-size: 16px;
    color: var(--black);
    display: flex;
    justify-content: center;
    align-items: center;
}

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

header .inner .hdrTel .tel-link {
    font-size: 32px;
    font-weight: 600;
    margin-right: 0.5rem;
    display: flex;
    gap: 10px;
    align-items: center;
}

header .inner .hdrTel .tel-open {
    font-size: 14px;
}

header .inner .hdrContact {
    display: flex;
    color: var(--white);
    font-size: 14px;
    font-weight: 500;
    background: var(--sub-color02);
    align-items: center;
    padding: 15px 20px;
    line-height: 1;
    text-decoration: none;
    transition: background-color 0.3s ease;
}

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

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

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

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

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

header nav #gNav {
    display: flex;
    font-size: 14px;
    gap: 2em;
}

header nav #gNav * {
    line-height: 1.0;
}

header nav #gNav>li {
    display: block;
    text-align: center;
    position: relative;
}

header nav #gNav>li.firstNav:before {
    position: absolute;
    content: "";
    background: center center url("./img/ico_first.png") no-repeat;
    width: 27px;
    height: 34px;
    top: -30px;
    left: 0;
    right: 0;
    margin: auto;
}

header nav #gNav>li>a:link,
header nav #gNav>li>a:visited {
    color: var(--black);
    position: relative;
    display: inline-block;
    text-decoration: none;
    font-weight: 600;
    padding: 5px 0 0;
    height: 40px;
}

#top header nav #gNav>li>a:link,
#top header nav #gNav>li>a:visited {
    transition: color 0.3s ease;
}

.scrolled header nav #gNav>li>a:link,
.scrolled header nav #gNav>li>a:visited {
    color: var(--black);
}

header nav #gNav>li>a::after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f107";
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    color: rgba(0, 0, 0, 0.5);
    opacity: 0;
}

header nav #gNav>li:hover>a::after {
    opacity: 1;
    transition: opacity 1.0s;
    transition: 0.8s;
}

header nav #gNav>li ul {
    opacity: 0;
    pointer-events: none;
    background: var(--main-color01);
    position: absolute;
    z-index: 100;
    width: 300px;
    margin-top: -5px;
    padding: 20px 10px 5px 30px;
    box-sizing: border-box;
    text-align: left;
}

header nav #gNav>li:hover ul {
    opacity: 1;
    transition: opacity 1.0s;
    pointer-events: auto;
}

header nav #gNav>li ul li {
    display: inline-block;
    margin: 0 1.5em 1.0em 0;
}

header nav #gNav>li ul li a:link,
header nav #gNav>li ul li a:visited {
    color: var(--white);
}

header nav #gNav>li ul li a:hover {
    opacity: 0.7;
    transition: 0.6s;
}

@media screen and (max-width : 1899px) {
    header .inner .boxR {
        padding: 0 0 0 10px;
    }

    header nav #gNav>li>a:link,
    header nav #gNav>li>a:visited {
        font-size: 14px;
        font-size: 0.8vw;
    }

    header#header .hdrLogo {
        width: 13vw;
    }

    .scrolled header#header .hdrLogo img,
    header#header .hdrLogo img {
        width: 100%;
    }

    header .hdrMedal {
        width: 15vw;
        margin: 3px 0;
    }

    header .hdrMedal img {
        width: 100%;
    }

    header .hdrLogo {
        padding: 0.6em 1.1em;
    }

}

@media screen and (max-width : 1500px) {
    header nav #gNav {
        gap: 1em;
        align-items: center;
    }
}

@media screen and (max-width : 1300px) {
    header .inner .boxR {
        padding-top: 0;
    }
}

@media screen and (max-width: 1100px) {
    header#header .hdrLogo {
        width: auto;
        padding: 5px;
    }

    header#header .hdrLogo img {
        height: 50px;
        width: auto;
    }

    .scrolled header#header .hdrLogo img {
        height: 50px;
        width: auto;
    }

    header .hdrMedal {
        height: 60px;
        margin: 0;
        padding: 5px 0;
    }

    header .hdrMedal img {
        height: 100%;
        width: auto;
    }

    header .inner {
        padding: 0;
    }

    header .inner .hdrTelContact,
    header nav #gNav {
        display: none;
    }
}

/* -----------------------------------------------------------
    タブレット用nav
----------------------------------------------------------- */
header .inner #spHdrBtn {
    display: flex;
    justify-content: end;
}

.spmenuBtn {
    position: fixed;
    top: 0;
    right: 0;
}

.telBtn {
    padding-right: 60px;
    background: var(--sub-color04);
}

.telBtn a,
.spmenuBtn {
    text-align: center;
    font-weight: bold;
    display: inline-block;
    height: 60px;
    width: 60px;
    vertical-align: middle;
    line-height: 1;
    box-sizing: border-box;
}

.telBtn a {
    font-size: 26px;
    background: var(--main-color02);
    padding-top: 18px;
    color: var(--white);
    text-decoration: none;
}

.spmenuBtn {
    top: 0;
    right: 0;
    z-index: 99999;
    background: var(--main-color01);
    cursor: pointer;
    position: fixed;
}

.spmenuBtn span {
    display: inline-block;
    position: absolute;
    height: 1px;
    width: auto;
    background-color: var(--white);
    transition: all .4s;
    left: 12px;
    width: 40px;
}

.spmenuBtn span:nth-of-type(1) {
    top: 26px;
}

.spmenuBtn span:nth-of-type(2) {
    top: 35px;
}

.spmenuBtn.active span:nth-of-type(1) {
    top: 23px;
    left: 15px;
    transform: translateY(6px) rotate(-45deg);
    width: 50%;
}

.spmenuBtn.active span:nth-of-type(2) {
    top: 35px;
    left: 15px;
    transform: translateY(-6px) rotate(45deg);
    width: 50%;
}

#spGNav {
    position: fixed;
    right: -120%;
    display: block;
    z-index: 5555;
    background: rgba(0, 0, 0, 0.8);
    width: 100%;
    top: 60px;
    transition: all 0.6s;
    box-sizing: border-box;
    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-color01);
    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(4),
#spGNav li:nth-last-child(5) {
    width: calc(50% - 2.5px);
}

#spGNav li:nth-last-child(4) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f075";
    margin-right: 5px;
}

#spGNav li:nth-last-child(5) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f15c";
    margin-right: 5px;
}

#spGNav li:nth-last-child(3) a {}

#spGNav li:nth-last-child(3) a::after {
    display: none;
}

#spGNav li:nth-last-child(3) a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f0e0";
    margin-right: 5px;
}

#spGNav li:nth-last-child(2) a {
    background-color: var(--main-color02);
    display: flex;
    justify-content: center;
    gap: 5px;
}

#spGNav li:nth-last-child(2) a::after {
    display: none;
}

#spGNav li:nth-last-child(2) a::before {
    content: "";
    display: block;
    width: 20px;
    height: 24px;
    background-image: url(./img/ico_srmb.png);
    align-items: center;
}

#spGNav li:last-child a {
    color: var(--black);
    background: var(--white);
}

#spGNav li:last-child a::after {
    content: "\f00d";
    margin-left: 5px;
    float: none;
}

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

    header .inner #spHdrBtn,
    #spGNav,
    #spHdrBtn {
        display: none;
    }
}

/* -----------------------------------------------------------
    footer
----------------------------------------------------------- */
footer {
    padding-top: 160px;
    position: relative;
}

footer::before {
    content: "";
    background-color: #e7f7ed;
    height: 360px;
    width: 100%;
    z-index: -1;
    position: absolute;
    top: 0;
}

#contact footer::before {
    content: none;
}

#contact footer {
    padding-top: 15px;
}

footer:not(:has(.inner.ftrRequest)) {
    padding-top: 15px;
}

footer:not(:has(.inner.ftrRequest))::before {
    display: none;
}

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

footer .bnrAccel {
    margin-bottom: 50px;
}

footer .bnrAccel a {
    width: 50%;
    display: block;
    margin: 0 auto;
}

footer .bnrAccel a img {
    width: 100%;
}

footer .ftrScroll {
    position: fixed;
    top: 30%;
    right: 0;
    width: 160px;
    z-index: 100;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

footer .ftrScroll li a {
    color: var(--white) !important;
    background-color: #016462;
    border-radius: 20px 0 0 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 140px;
    gap: 5px;
    padding-top: 7px;
    transition: none;
    position: relative;
}

footer .ftrScroll li a.ftrScrollShowroom {
    background-color: #eb611e;
}

footer .ftrScroll li a::before {
    content: "";
    margin: 5px 0;
}

footer .ftrScrollN li a::after {
    content: "";
    position: absolute;
}

footer .ftrScroll li a.ftrScrollContact::before {
    width: 28px;
    height: 18px;
    background-image: url(./img/ico_mail_ac.png);
}

footer .ftrScroll li a.ftrScrollShowroom::before {
    width: 20px;
    height: 24px;
    background-image: url(./img/ico_srmb.png);
}

footer .ftrScroll li a.ftrScrollContact:hover::before {
    background-image: url(./img/ico_mail.png);
}

footer .ftrScroll li a.ftrScrollShowroom:hover::before {
    background-image: url(./img/ico_srmb_ac.png);
}

footer .ftrScroll li a .icoFree {
    background-color: var(--red);
    border-radius: 6px;
    padding: 0 10px;
    font-size: 14px;
}

footer .ftrScroll li a:hover {
    color: #016462 !important;
    background-color: var(--white);
    border-width: 3px;
    border-style: solid;
    border-color: #016462;
    border-right-color: var(--white);
}

footer .ftrScroll li a.ftrScrollShowroom:hover {
    color: #eb611e !important;
    background-color: var(--white);
    border-color: #eb611e;
    border-right-color: var(--white);
}

footer .ftrScroll li a:hover .icoFree {
    color: var(--white) !important;
}



footer .ftrRequest {
    padding: 50px 0 50px 380px;
    position: relative;
    overflow: visible;
    display: flex;
    flex-direction: column;
    align-items: center;
}

footer .ftrRequest .ftrItn {
    position: absolute;
    left: 50px;
    bottom: 0;
}

footer .ftrRequest::before {
    content: "";
    width: 92vw;
    height: 100%;
    background: var(--main-color01) url(./img/bg_contactbfr.png) left 50px top 0 no-repeat;
    border-radius: 0 20px 20px 0;
    position: absolute;
    top: -1px;
    left: calc(50% - 50vw);
    z-index: -1;
}

footer .ftrContent {
    margin-top: 100px;
}

.contactBtnList {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 30px;
    padding: 40px 0 0;
    position: relative;
}

.ftrContactBtn,
.ContactBtn01,
.ftrContactSrmBtn,
.ContactSrmBtn01 {
    min-width: 260px;
    border-radius: 100vh;
    border: #016462 3px solid;
    position: relative;
    text-align: center;
    text-decoration: none !important;
    display: inline-block;
    font-weight: 600;
    padding: 15px 50px 15px 30px;
    transition: all 0.3s ease;
    color: white !important;
    background-color: #016462;
}

.ftrContactSrmBtn,
.ContactSrmBtn01 {
    border: var(--main-color02) 3px solid;
    color: var(--white) !important;
    background-color: var(--main-color02);
}

.ftrContactBtn:hover,
.ContactBtn01:hover {
    background-color: var(--white);
    color: #016462 !important;
}

.ftrContactSrmBtn:hover,
.ContactSrmBtn01:hover {
    background-color: var(--white);
    color: var(--main-color02) !important;
}

.ftrContactBtn::before,
.ContactBtn01::before,
.ftrContactSrmBtn::before,
.ContactSrmBtn01::before {
    content: "";
    display: inline-block;
    vertical-align: text-bottom;
    margin-right: 1rem;
}

.ftrContactBtn::before,
.ContactBtn01::before {
    width: 28px;
    height: 18px;
    background-image: url(./img/ico_mail_ac.png);
}

.ftrContactSrmBtn::before,
.ContactSrmBtn01::before {
    width: 20px;
    height: 24px;
    background-image: url(./img/ico_srmb.png);
}

.ftrContactBtn:hover::before,
.ContactBtn01:hover::before {
    
    background-image: url(./img/ico_mail.png);
}

.ftrContactSrmBtn:hover::before,
.ContactSrmBtn01:hover::before {
    background-image: url(./img/ico_srmb_ac.png);
}

.ftrContactBtn::after,
.ContactBtn01::after,
.ftrContactSrmBtn::after,
.ContactSrmBtn01::after {
    position: absolute;
    content: "";
    top: 0;
    right: 15px;
    bottom: 0;
    margin: auto 0;
    display: block;
    width: 26px;
    height: 26px;

    font-family: "Font Awesome 5 Free";
    font-size: 14px;
    font-weight: 900;
    content: '\f105';
    color: #016462;

    border-radius: 100vh;
    background: white;

}

.ftrContactSrmBtn::after,
.ContactSrmBtn01::after {
    color: var(--main-color02);
    background: var(--white);
}

.ftrContactBtn:hover::after,
.ContactBtn01:hover::after {
    color: white;
    background: #016462;
}

.ftrContactSrmBtn:hover::after,
.ContactSrmBtn01:hover::after {
    color: var(--white);
    background: var(--main-color02);
}

.ftrContactBtn .icoFtrContact {
    position: absolute;
    top: -89px;
    left: -170px;
}

.ftrLogo {
    float: left;
    margin-right: 50px;
    width: 260px;
    display: block;
}

.ftrLogo img {
    width: 180px;
}

.ftrLogo+h3 {
    display: inline-block;
    font-size: 16px;
    font-weight: 600;
}


footer .boxL dl {
    display: flex;
    flex-wrap: wrap;
    font-size: 16px;
}

footer .boxL dt,
footer .boxL dd {
    margin-top: 15px;
}

footer .boxL dt {
    width: 20%;
}

footer .boxL dd {
    width: 80%;
}

.ftrNav {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 90px;
}

.ftrNav ul {
    font-size: 14px;
    min-width: 150px;
}

.ftrNav ul li a::before {
    content: "─";
    margin-right: 1em;
}

.ftrNav ul li a:hover {
    opacity: 0.8;
}

.ftrbox {
    display: flex;
    align-items: center;
    margin-top: 50px;
}

.ftrSns {
    display: flex;
    justify-content: flex-start;
    gap: 20px;
    /* margin-top: 50px; */
    flex-grow: 3;
    width: 50%;
}

ul.ftrSns li a::before {
    content: none !important;
}

.ftrSns li::before {
    content: none;
}

ul.ftrNavBanners {
    /* width: 50%; */
    display: flex;
    justify-content: right;
    /* margin-top: 30px; */
    width: 100%;
}

ul.ftrNavBanners li a::before {
    content: none;
    align-items: flex-end;
}

ul.ftrNavBanners li {
    /* width: calc((100% - 40px) / 3); */
    max-width: 350px;
}

ul.ftrNavBanners li a {
    display: flex;
    align-items: flex-end;
    height: 100%;
}

ul.ftrNavBanners li a img {
    width: 100%;
}

.ftrBnrs {
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
    margin-top: 20px;
}

.ftrBnrs li {
    margin: 0 10px 10px 0;
}

@media screen and (max-width: 1100px) {
    .ftrNav ul {
        min-width: 0;
    }

    .ftrNav ul.ftrNavBanners {
        flex-grow: inherit;
        width: auto;
    }
}

footer .copyRight {
    font-size: 11px;
    margin-left: auto;
    margin-bottom: 10px;
    text-align: center;
    margin-top: 50px;
}

.pageTop {
    position: fixed;
    right: 0;
    bottom: 0;
    width: fit-content;
    height: fit-content;
    z-index: 100;
    opacity: 0;
    transition: all 0.5s ease;
}

.scrolled .pageTop {
    opacity: 1;
}

.pageTop a {
    display: block;
    background: var(--black);
    border-radius: 20px 20px 0 0;
    transition: all 0.3s ease;
}

.pageTop a:hover {
    background: var(--main-color01);
}

footer .ftrFab {
    display: none;
}

@media screen and (max-width: 1100px) {
    footer .ftrContent {
        padding-bottom: 100px;
    }

    footer .ftrScroll {
        display: none;
    }

    .pageTop {
        bottom: 72px;
    }

    footer .ftrFab {
        display: block;
        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(--main-color02);
        color: var(--white);
        text-decoration: none;
        font-weight: 400;
        padding: 10px 5px;
        line-height: 1.3;
    }

    footer .ftrFab li.ftrFabShowroom a {}

    footer .ftrFab li.ftrFabContact a {
        background-color: var(--main-color01);
    }

    footer .ftrFab li a::before {
        content: "";
        margin: 5px auto;
        display: block;
    }

    footer .ftrFab li.ftrFabContact a::before {
        height: 24px;
        background: center url(./img/ico_mail_ac.png) no-repeat;
    }

    footer .ftrFab li.ftrFabShowroom a::before {
        width: 20px;
        height: 24px;
        background: center /cover url(./img/ico_srmb.png) no-repeat;
    }

    footer .ftrFab li.ftrLine a {
        background-color: #06c755;
        padding-top: 0;
        padding-bottom: 0;
    }

    footer .ftrFab li.ftrLine img {
        width: auto;
        height: 67.6px;
    }
}


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

.pageMainv>img {
    display: block;
}

/*. contactTel */
.contactTel {
    font-weight: 600;
    color: var(--white);
}

.contactTelTtl {
    font-weight: 400;
    font-size: 22px;
    color:#222222;
}

.contactTel b {
    font-weight: bold;
    background: white;
    color: #222222;
    margin-right: 5px;
    padding: 0 10px;
    display: inline-block;
}

.contactTel strong {
    font-weight: 400;
    background: var(--red);
    color: white;
    border-radius: 5px;
    margin: 0 5px;
    padding: 0 10px;
    display: inline-block;
}

.contactTel .tel {
    display: block;
    font-size: 16px;
    font-weight: 400;
    text-align: center;
    width: fit-content;
    margin: 20px auto 0;
    color: #222222;
}

.contactTel .tel .tel-link {
    font-size: 72px;
    color: #222222;
}

.contactTel .tel .tel-link img {
    margin-right: 10px;
}

@media screen and (max-width: 1100px) {
    footer .ftrRequest {
        padding: 50px 0 50px 30vw;
    }

    footer .ftrRequest .ftrItn img {
        width: 30vw;
    }

    .contactBtnList {
        flex-direction: column;
        gap: 10px;
        padding: 20px 0 0;
    }

    .contactTel {
        padding-right: 8.2vw;
    }

    .contactTel .tel .tel-link {
        font-size: 5vmin;
    }

    .contactTelTtl {
        font-size: 2vmin;
    }

    .ftrContactBtn .icoFtrContact {
        top: -32px;
        left: -180px;
    }
}

@media screen and (max-width: 860px) {
    .ftrContactBtn .icoFtrContact {
        display: none;
    }
}

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

.contact01,
#contents section.contact01 {
    margin: 50px 0 0;
    padding: 50px 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;
}

.contact01 .title,
#main .contact01 .title {
    width: 100%;
    text-align: center !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    margin: 0 !important;
    padding: 0 20px 5px !important;
    background: none !important;
    box-sizing: border-box;
}

.contact01 .title strong {
    font-weight: 500 !important;
}

.contact01 .boxL,
.contact01 .boxR {
    width: 50%;
}

.contact01 .boxR a,
#main .contact01 .boxR a {
    margin-left: auto;
    text-decoration: none;
}

.contact01 .tel .tel-link {
    font-size: 80px;
    margin-left: 15px;
}

.contact01 .tel .tel-open {
    display: block;
    text-align: center;
    margin-top: -10px;
    font-size: 18px;
    font-weight: 400;
}

/*----- .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: 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%;
}

/*----- .msgArea -----*/
#main .messageBox {
    /* background: url(./img/bg_message.png); */
    padding: 60px 0;
    background: repeating-linear-gradient(130deg, #ffe4c7, #ffe4c7 2px, #fff4e9 0px, #fff4e9 5px);
}

#main .msgArea {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 50px;
    margin-top: 30px;
    color: #222222;
}

#main .msgTxt {
    flex: 1;
}

#main .msgPhoto {
    width: 306px;
    text-align: right;
    margin-top: -15px;
}

#main .msgPhoto img {
    height: 242px;
    width: 100%;
    object-fit: cover;
    border-radius: 10px;
    border: 3px solid #d5d5d5;
}

#main .msgPhoto p.corp {
    display: inline-block;
    font-size: 18px;
    font-weight: 800;
    margin: 10px 0;
    padding: 1px 0 2px;
    line-height: 1.3;
}

#main .msgPhoto p.name {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 15px;
    line-height: 1.3;
}


/*----- .leadCts -----*/
.leadCts {
    display: flex;
    justify-content: space-between;
    margin-bottom: 60px;
}

.leadCts .stcCtx {
    padding-right: 60px;
}

.imgRFull {
    width: 440px;
}

.imgRFull>p {
    width: 50vw;
}

.imgRFull>p>img {
    width: auto;
    border-radius: 20px 0 0 20px;
}

@media screen and (max-width: 1100px) {
    .leadCts {
        flex-direction: column;
    }

    .leadCts .stcCtx {
        padding-right: 0;
    }

    .imgRFull>p>img {
        max-width: none;
    }
}

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

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

/*----- .bnrListBtn -----*/
.bnrListBtn {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
    padding: 30px 0;
}

.bnrListBtn li {
    width: calc((100% - 60px) / 4);
}

.bnrListBtn li a {
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    text-decoration: none !important;
    font-size: 20px;
    background-color: #016462;
    color: var(--white) !important;
    border-radius: 10px;
    padding: 20px 20px 20px 50px;
    box-shadow: 0 5px 0 #00362B;
    text-align: center;
}

.bnrListBtn li a span.bnrCmnt {
    font-size: 0.9rem;
    display: inline-block;
    width: 100%;
    margin-bottom: 0.5em;
    padding: 0.2rem 0.5rem;
    color: #016462;
    border-radius: 4px;
    background: var(--white);
}

.bnrListBtn li a:hover {
    -webkit-transform: translate(0, 3px);
    transform: translate(0, 3px);
    box-shadow: 0 2px 0 #3c7965;
}

.bnrListBtn li a::before {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f30b";
    font-size: 1.2rem;
    line-height: 1;
    position: absolute;
    top: calc(50% - 0.6rem);
    left: 1rem;
    margin: 0;
    padding: 0;
    -webkit-transition: all .3s;
    transition: all .3s;

}

.bnrListBtn li a:hover::before {
    left: 1.5rem;
}

/*----- .firstList -----*/
#main .firstList {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    counter-reset: count;
    gap: 60px 40px;
    margin-bottom: 50px;
}

#main .firstList li {
    margin: 0;
    border-radius: 20px;
    padding: 0 0 30px;
    background-color: var(--main-color01);
    position: relative;
    width: calc((100% - 80px) / 3);

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1;
}

#main .firstList li:nth-child(2n) {
    background: var(--main-color02);
}

#main .firstList li p {
    color: var(--white);
    font-size: 22px;
    font-weight: 700;
    text-align: center;
    margin: 0;
}

#main .firstList li strong {
    color: var(--yellow);
    font-weight: 700;
}

#main .firstList li .iconFirstList {
    margin: -40px 0 0;
}

#main .firstList2Cl {}

#main .firstList2Cl li {
    margin: 0;
    width: calc((100% - 60px) / 2);
}

#main .firstList2Cl li:nth-child(2n) {
    background: var(--main-color01);
}

#main .firstList2Cl li:nth-child(4n + 2),
#main .firstList2Cl li:nth-child(4n + 3) {
    background: var(--main-color02);
}


/*----- .menuPlanCnt -----*/
.menuPlanCnt {
    border: 2px solid #d6d6d6;
    padding: 30px;
    background-color: var(--white);
    border-radius: 20px;
    margin-bottom: 70px;
}

.menuPlanTtl {
    background-color: var(--main-color01);
    padding: 15px 50px;
    color: var(--white);
    border-radius: 20px;
    text-align: center;
    width: fit-content;
    margin: -60px auto 30px;
}

#top .menuPlanTtl {
    background-color: var(--red);
}

#main .menuPlanCnt p.lead {
    margin: 10px 0 1rem;
    font-size: 20px !important;
    font-weight: 600;
    color: var(--main-color01);
    line-height: 1.25;
}

.detailCnt {
    padding: 30px 50px 50px;
    margin-bottom: 100px;
}

.detailCnt .menuPlanTtl {
    font-size: 24px;
    margin-bottom: 50px;
    padding: 10px 50px;
    counter-increment: count-detail;
}

.detailCnt .menuPlanTtl::before {
    content: "0" counter(count-detail);
    font-size: 20px;
    padding: 5px 20px;
    border-radius: 10px;
    color: var(--main-color01);
    background-color: var(--white);
    display: inline-block;
    margin-right: 15px;
}

.detailInr {
    display: flex;
    justify-content: space-between;
    gap: 60px;
}

.detailInr .inrCtx {
    width: 100%;
}

.detailInr .inrCtxImg img {
    border-radius: 20px;
}

.detailCnt .supplementCnt {
    margin: 50px 0 0;
    padding: 50px 0 0;
    border-top: 1px dotted var(--black);
}

/* -----------------------------------------------------------
    基本の記事スタイル設定
----------------------------------------------------------- */
#main p {
    font-size: 16px;
    margin-bottom: 15px;
    line-height: 1.9;
}

#main p strong {
    color: var(--main-color02);
    font-weight: normal;
}

#main a {
    color: var(--main-color01);
    text-decoration: underline;
}

#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: 700;
    line-height: 1.25;
    font-size: 40px;
    text-align: center;
    margin-bottom: 50px;
}

#main h2.headLine.mainvtxt {
    margin-bottom: 30px;
}

#main h2.headLine span.en {
    font-family: var(--en-font-family02);
    font-size: 20px;
    font-weight: 600;
    display: block;
    color: var(--main-color01);
}

#main h2.headLine span.subHdng {
    font-size: 16px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
}

#main h2.headLine span.subHdng::before,
#main h2.headLine span.subHdng::after {
    content: "";
    background: url(./img/bgh2sub.png) no-repeat;
    display: block;
    width: 30px;
    height: 38px;
}

#main h2.headLine span.subHdng::before {
    /* transform: rotate(-30deg); */
    margin-right: 15px;
}

#main h2.headLine span.subHdng::after {
    transform: rotate(65deg);
    margin-left: 15px;
}

#main h2.headLine span.en {
    font-family: var(--en-font-family02);
    font-size: 20px;
    font-weight: 600;
    display: block;
    color: var(--main-color01);
    margin-top: 5px;
}

#main h3.headLine {
    background: white;
    border-color: #ccc;
    border-width: 2px 0;
    border-style: solid;
    font-size: 1.8rem;
    font-weight: 700;
    margin: 0 0 50px 0;
    padding: 20px 0;
    text-align: center;
}

#main h3 strong {
    color: var(--main-color02);
}

#main h4.headLine {
    border-color: var(--main-color01);
    border-width: 0 0 4px 0;
    border-style: solid;
    font-size: 1.8rem;
    font-weight: 700;
    margin: 0 0 30px 0;
    width: fit-content;
}

#main h1.postTitle,
#main h2.postTitle,
#main h3.postTitle {
    border-left: 5px solid var(--main-color01);
    font-size: 30px;
    padding: 20px 30px;
    margin-bottom: 50px;
}

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

#main .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,
#main .popheading strong {
    display: inline-block;
    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/bgh3sub.png") no-repeat;
    width: 50px;
    height: 77px;
    position: absolute;
    top: -100%;
    bottom: -100%;
    margin: auto 0;
}

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

#main .popheading::after {
    right: 0;
    transform: translateX(200%) rotate(30deg);
}

/*#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: 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;
    margin-bottom: 30px;
    margin-top: 30px;
    border-bottom: var(--black) solid 1px;
    border-top: var(--black) solid 1px;
}

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

#main table th,
#main table td {
    padding: 10px 20px;
    font-size: 1rem;
    line-height: 1.7;
    text-align: left;
    vertical-align: top;
    position: static;
    border-bottom: var(--black) dotted 1px;
}

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

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

#main table th {
    width: 20%;
    font-weight: 400;
    vertical-align: top;
    font-size: 16px;
    background: none;
    background: #e8f7ed;
    text-align: center;
}

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

#main .pagenavi ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0;
}

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

#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 10px 5px 10px;
    width: 40%;
    box-sizing: border-box;
    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 {
    padding-left: 20px;
    padding-right: 20px;
    color: var(--black);
    letter-spacing: 0.1em;
}

#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-color01);
}

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

/*--フォーム部品--*/
#main .formBox table {
    border-right: none !important;
    border-top: 1px solid var(--black);
    border-bottom: 1px solid var(--black);
}

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

.formBox table th,
#main .formBox table th {
    width: 30%;
    font-weight: 500;
    vertical-align: middle;
    background: #e7f7ed;
    color: var(--black);
    position: static;
    border-bottom: var(--white) dotted 1px;
}

.formBox table td,
#main .formBox table td {
    background: var(--white);
    position: static;
    border-bottom: var(--black) dotted 1px;
}

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

.formBox table th span {
    display: block;
    font-size: 14px;
    background: #373737;
    color: var(--white);
    margin-left: 10px;
    padding: 0 10px;
    display: inline-block;
}

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

.formBox input:not(input[type="checkbox"]):not(input[type="submit"]):not(input[type="radio"]),
.formBox select,
.formBox textarea {
    font-size: 16px;
    padding: 5px;
    height: 40px;
    width: 340px;
    border: 1px solid #ddd;
    box-sizing: border-box;
    background: var(--white);
}

.formBox .dateTbl input:not(input[type="checkbox"]):not(input[type="submit"]):not(input[type="radio"]) {
    margin-bottom: 5px;
}

.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: 98%;
}

.formBox .accept {
    border-radius: 6px;
    text-align: center;
    padding: 20px;
    margin: 30px 0;
    background: var(--white);
}

.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: 16px;
    background: var(--main-color02);
    border-radius: 6px;
    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;
}

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

.formBox input[type="submit"]:disabled {
    font-size: 16px;
    color: var(--white) !important;
    cursor: default;
    background: #ccc;
    border-radius: 6px;
    min-width: 240px;
    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 .wpcf7-free-text {
    margin-left: 5px;
}

/*--チェックリスト--*/
#main .checkTtl {
    font-size: 20px;
    position: relative;
    line-height: 1.8;
    padding-left: 1.5em;
}

#main .checkTtl::after {
    content: '';
    display: block;
    position: absolute;
    top: .5em;
    left: 0;
    width: 1em;
    height: 0.5em;
    border-left: 4px solid #9c9c9c;
    border-bottom: 4px solid #9c9c9c;
    transform: rotate(-45deg);
}

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

/*--写真並び（3列）--*/
#main .photoUL li {
    display: block;
    width: calc((100% - 80px) / 3);
    margin: 0;
    padding: 0;
    font-size: 14px;
}

#main .photoUL li img {
    border-radius: 20px;
    width: 100%;
    height: 270px;
    object-fit: cover;
}

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

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

#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;
}

/*--写真並び（2列）--*/
#main .photoULLrg li {
    display: block;
    width: calc((100% - 40px) / 2);
    margin: 0;
    padding: 0;
    font-size: 14px;
}

#main .photoULLrg li img {
    border-radius: 20px;
    width: 100%;
    height: auto;
    max-height: 360px;
    object-fit: cover;
}

/*--下層ページメインビジュアル--*/
#cornerName {
    position: relative;
    height: 312px;
    width: 100%;
    z-index: 3;
    background: url(./img/bg_sttl.png) repeat-x center top;
    margin: -50px 0 0 0;
}

@media screen and (max-width : 1899px) {
    #cornerName {
        margin-top: 0;
    }
}

@media screen and (max-width: 1100px) {
    #cornerName {
        margin-top: 1vh;
    }
}


#cornerName h1,
#cornerName div {
    position: relative;
    display: block;
    width: 100%;
    margin: 0 auto;
    padding: 96px 0 0 0;
    max-width: 1100px;
    box-sizing: border-box;
    color: var(--black);
    font-size: 46px;
    font-weight: 700;
    line-height: 1.2;
    z-index: 4;
    text-align: center;
}

#cornerName:before {
    content: "";
    width: 255px;
    height: 231px;
    background: url(./img/wood01.png) no-repeat;
    position: absolute;
    bottom: -15px;
    left: calc(50% - 850px)
}

#cornerName:after {
    content: "";
    width: 210px;
    height: 248px;
    background: url(./img/wood02.png) no-repeat;
    position: absolute;
    bottom: -20px;
    right: calc(50% - 820px);
}

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

    #cornerName:before,
    #cornerName:after {
        display: none;
    }
}

#cornerName h1 span.subTtl,
#cornerName div span.subTtl {
    font-size: 24px;
    font-weight: 700;
    display: block;
    color: var(--white);
}

.breadcrumbs {
    width: 100%;
    margin: 0 auto;
    max-width: 1100px;
    font-size: 14px;
    color: var(--black);
    padding: 20px;
}

/*body:not(#top) .breadcrumbs {
    margin-top: -50px;
    z-index: 10;
    position: relative;
}*/

.breadcrumbs a {
    color: var(--blue);
}

.breadcrumbs>span {
    margin-right: 10px;
}

.breadcrumbs>span:nth-of-type(n+2) {
    margin-left: 10px;
}

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

#top #contents {
    margin: 30px auto 0;
}

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

#contents #main section+section {
    padding: 0 0 50px 0;
}

#top #contents #main section+section {
    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;
    max-width: 100vw;
}

#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
----------------------------------------------------------- */
#top #contents section#main {
    padding: 0;
}

.bgColor01 {
    background-color: #f5f5f5;
}

.bgColor02 {
    background-color: #e7f7ed;
}

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

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

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

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

/*-------------------#mainv-----------------*/
#mainv {
    position: relative;
    width: calc(100% - 110px);
    max-width: 1820px;
    height: 550px;
    z-index: 9;
    display: flex;
    align-items: center;
}

#top #mainv {
    width: 100%;
    max-width: 100%;
    height: auto;
    display: block;
}

#top #mainv .maianVFgr {
    height: 580px;
    margin: -50px 50px 0 170px;
    padding-top: 0;
    width: calc(100vw - (230px));
    border-radius: 20px;
    overflow: hidden;
}

#top #mainv .maianVFgr img {
    height: 100%;
    width: 100%;
    object-fit: cover;
}

#top #mainv::before {
    content: "";
    width: 255px;
    height: 231px;
    background: url(./img/wood01.png) no-repeat;
    position: absolute;
    bottom: -60px;
    left: 15px;
}

#top #mainv::after {
    content: "";
    width: 210px;
    height: 248px;
    background: url(./img/wood02.png) no-repeat;
    position: absolute;
    bottom: -80px;
    right: 15px;
}

@media screen and (max-width: 1899px) {
    #top #mainv .maianVFgr {
        margin: -1.3vh 2vw;
        width: 96vw;
    }
}

@media screen and (max-width: 1300px) {
    #top #mainv .maianVFgr {
        height: auto;
        width: calc(100% - 60px);
        margin: 0 30px 0;
    }

    #top #mainv::before,
    #top #mainv::after {
        content: none;
    }
}

#top #mainv h2 {
    order: 2;
    white-space: nowrap;
}

#top #mainv h2 img {
    width: 133px;
    height: auto;
    display: inline-block;
    margin-right: -23px;
    position: relative;
}

#top #mainv h2 small {
    color: var(--white);
    position: relative;
    display: block;
    z-index: 2;
    width: fit-content;
    padding: 0 60px;
    font-weight: 500;
    margin: 0 0 -30px 176px;
    letter-spacing: 0.32em;
}

#top #mainv h2 small::before {
    content: "";
    display: block;
    position: absolute;
    inset: 0;
    margin: auto;
    background: var(--sub-color01);
    z-index: -1;
    transform: skew(-30deg);
}

#top #mainv h2 span {
    font-size: 100px;
    color: var(--white);
    background: var(--main-color02);
    line-height: 1;
    width: 1em;
    height: 1em;
    display: inline-block;
    margin: 1px;
    padding: 5px 10px 15px;
    z-index: 1;
}

/* :nth-of-type(n+数字)は数字以降対象 */
#top #mainv h2 span:nth-of-type(n+5) {
    background: var(--white);
    color: var(--main-color02);
}

#top #mainv h2+p {
    order: 1;
    color: var(--white);
    margin-left: 30px;
}

#top #mainv h2+p>span:first-of-type {
    display: block;
    font-size: 26px;
    margin-bottom: -20px;
    padding: 10px 30px 20px;
    background: var(--sub-color04);
    --s: 10px;
    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(40% + calc(var(--s) / 2)) calc(100% - var(--s)),
            40% 100%,
            calc(40% - calc(var(--s) / 2)) calc(100% - var(--s)),
            var(--s) calc(100% - var(--s)));
    position: relative;
    width: fit-content;
    line-height: 1;
    font-weight: 600;
}

#top #mainv h2+p>span:first-of-type::before {
    content: "";
    display: block;
    position: absolute;
    width: 10px;
    height: 12px;
    background: var(--sub-color04);
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    transform: translateY(100%);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
}

#top #mainv h2+p>span:last-of-type {
    font-size: 42px;
    font-weight: 600;
    line-height: normal;
}

#top #mainv h2+p span b {
    font-size: 80px;
    font-weight: bold;
}

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

#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;
    right: -20px;
}

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

@media screen and (max-width : 1100px) {
    .bnrList01 .swiperTopBnr .swiper-button-next {
        right: 5px;
    }

    .bnrList01 .swiperTopBnr .swiper-button-prev {
        left: 5px;
    }
}

.bnrList01 .swiper-container {
    max-width: 1000px;
    overflow: visible;
}

.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 50px;
    box-sizing: border-box;
    text-align: center;
}

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

.bnrList01 li img {
    width: 100%;
    height: auto;
    object-fit: contain;
    border-radius: 30px;
}

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

/*-------------------.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%;
}

.bgColor03 a:hover .btn {
    background: var(--white) !important;
}

/*-------------------.firstIntroduction-----------------*/
#main .firstIntroduction {
    padding-bottom: 50px !important;
}

#top #main .firstIntroduction {
    padding: 10vw 0 50px !important;
}

#main .firstIntroduction .accessCts {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}

#main .firstIntroduction .accessCts img.addressImg {
    border-radius: 20px;
    width: 300px;
    height: 220px;
    object-fit: cover;
}

#main .firstIntroduction .addressCts {
    width: 760px;
}

#main .firstIntroduction .addressCts .addressBox {
    background-color: var(--white);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    padding: 30px 40px;
}

#main .firstIntroduction .addressCts .addressBox p {
    font-size: 18px;
    margin-bottom: 0;
}

#main .firstIntroduction .addressCts .addressBox .addressTtl {
    padding-right: 2em;
    font-weight: 600;
}

#main .firstIntroduction .addressCts .addressTelBox {
    display: flex;
    justify-content: space-between;
    align-items: center;
    justify-content: flex-end;
    padding: 30px 0;
    gap: 0 30px;
    flex-wrap: wrap;
    align-items: center;
}

#main .firstIntroduction .addressCts .addressTelBox p {
    margin: 0;
}

#main .firstIntroduction .addressCts .addressTelBox .tel {
    display: flex;
    align-items: center;
    gap: 10px;
}

#main .firstIntroduction .addressCts .addressTelBox .tel-link {
    color: var(--main-color02);
    display: flex;
    align-items: center;
    gap: 10px;
}

#main .firstIntroduction .addressCts .addressTelBox .tel img {
    width: 43px;
    height: auto;
    display: inline-block;
}

/* #first */
#first {
    counter-reset: count-detail;
    background-color: #fafafa;
}

#first .leadCts {
    padding-top: 20px;
}

#first .leadCts .imgRFull {
    margin-top: -20px;
}

@media screen and (max-width: 1100px) {
    #first .leadCts .imgRFull {
        margin-top: 10px;
    }
}

.firstDetails {
    padding: 240px 0 0 !important;
    clip-path: polygon(0 calc(0% + 9vw), 100% 0, 100% 100%, 0 100%);
    background-color: #e8f7ed;
    margin-bottom: -100px;
}

.detailCnt.firstCtx {
    position: relative;
}

.detailCnt.firstCtx .firstLead {
    margin-bottom: 50px;
}

.detailCnt.firstCtx .menuPlanTtl::before {
    content: "POINT 0" counter(count-detail);
}

.firstIco02 {
    position: absolute;
    bottom: 40px;
    left: 100px;
}

@media screen and (max-width: 1100px) {
    .firstIco02 {
        bottom: 10px;
        left: auto;
        right: 10px;
        width: 16%;
        margin: 0;
    }

    .firstIco02 img {
        width: 100%;
        height: auto;
    }
}

/*-------------------.quickRequest-----------------*/
#main .quickRequest {
    padding-bottom: 75px !important;
}

#blog #main .quickRequest {
    padding-top: 0;
    margin-top: -30px;
}

#main .quickRequest h2 {
    text-align: center;
    padding: 80px 0 50px;
    margin: 0 auto;
}

#main .quickRequest h2 small img {
    left: -80px !important;
    transform: translateX(-100%);
}

#main .quickRequest h2+p {
    text-align: center;
}

#main .quickRequest .formBox table {
    margin-top: 0;
}

#contact #main .quickRequest {
    margin-bottom: 0;
    padding-bottom: 30px !important;
}

/*-------------------.reasonList-----------------*/
#main .reasonList {
    overflow: visible;
    position: relative;
    padding-top: 100px !important;
    padding-bottom: 0 !important;
}

#main .reasonList::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    background: url("./img/wood03.png") no-repeat;
    width: 288px;
    height: 203px;
}

#main .reasonList.extraPart::before {
    top: 200px;
}

#main .reasonList::after {
    content: "";
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    background: url("./img/btmrsn.png") no-repeat;
    width: 435px;
    height: 293px;
    z-index: 2;
}


#main .reasonList h2 {
    margin-bottom: 60px;
}

#main .reasonList ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    counter-reset: count;
    gap: 40px;
    align-items: flex-start;
    margin-bottom: 50px;
}

#main .reasonList ul li {
    margin: 0;
    border-radius: 20px;
    padding: 50px 30px 70px;
    background: repeating-linear-gradient(130deg, #ffe4c7, #ffe4c7 2px, #fff4e9 0px, #fff4e9 5px);
    position: relative;
    width: calc((100% - 40px) / 2);
}

#main .reasonList ul li::before {
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto 60px;
    transform: translateY(-60%);
    counter-increment: count;
    content: "0" counter(count) !important;
    color: var(--main-color01);
    text-align: center;
    top: 10px;
    font-size: 70px;
    font-weight: 600;
    font-family: var(--en-font-family02);
}

#main .reasonList ul li:nth-of-type(2) {
    margin-top: 40px;
}

#main .reasonList ul li:nth-of-type(3) {
    margin-top: 40px;
}

#main .reasonList ul li:nth-of-type(4) {
    margin-top: 80px;
}

#main .reasonList ul li a {
    color: var(--black);
    text-decoration: none;
}

.reasonList ul li h3 {
    font-size: 21px;
    font-weight: 600;
    margin: 0 0 20px;
}

.reasonList ul li h3 strong {
    color: var(--main-color01);
}

.reasonList .reasonListImg {
    position: relative;
    overflow: hidden;
    border-radius: 50px;
    margin-bottom: 15px;
    text-align: center;
}

.reasonList .reasonListImg img {
    border-radius: 10px;
}

.reasonList li p {
    margin-bottom: 0 !important;
}

.reasonList h3 b {
    color: var(--red);
    font-weight: 500;
}

#main .reasonList>.inner {
    overflow: visible;
}

#main .reasonList>.inner:last-of-type {
    padding-bottom: 150px;
}

/*-------------------.reasonDetails-----------------*/
#reason {
    counter-reset: count-detail;
}

.reasonDetails {
    padding: 140px 0 0 !important;
    clip-path: polygon(0 calc(0% + 9vw), 100% 0, 100% 100%, 0 100%);
    background-color: #e7f7ed;
    top: -100px;
    position: relative;
    margin-bottom: -100px;
}

.reasonDetails .inner {
    padding: 50px 0 0;
}

.reasonDetails .detailCnt.reasonDetailCnt:last-child {
    margin-bottom: 0;
}

.reasonDetailCnt .menuPlanTtl::before {
    content: "理由 0" counter(count-detail);
    display: block;
    padding: 5px 10px;
    width: fit-content;
    margin: 0 auto 5px;
}

#reason01 .detailInr .reasonImg,
#reason02 .detailInr .reasonImg {
    margin-top: -20px;
}

#reason03 {
    position: relative;
}

#reason03 img.rsonItn03 {
    position: absolute;
    bottom: 0;
    left: 50px;
}


@media screen and (max-width: 1100px) {
    #reason03 img.rsonItn03 {
        left: 10PX;
        width: auto;
        height: 40%;
    }
}

/*------------------- swiper -----------------*/
#main ul.swiper-wrapper {
    margin-bottom: 0;
    align-items: stretch;
}

#main .swiper-slide {
    height: auto;
}

/*------------------- .swiper01 -----------------*/
.swiper01 .swiper-container {
    max-width: 1100px;
}

.swiper01 .inner {
    overflow: visible;
    margin-bottom: 45px;
}

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

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

.swiper01 .swiper-button-next {
    right: -20px;
    background: url(./img/arrowR.png) no-repeat;
    transform: translateX(100%);
}

.swiper01 .swiper-button-prev {
    left: -20px;
    background: url(./img/arrowL.png) no-repeat;
    transform: translateX(-100%);
}

@media screen and (max-width: 1100px) {
    .swiper01 .inner {
        max-width: calc(100% - 90px);
    }

    .swiper01 .swiper-button-next {
        right: -5px;
    }

    .swiper01 .swiper-button-prev {
        left: -5px;
    }
}


.swiper01 .swiper-slide {
    background: var(--white);
    border-radius: 20px;
    margin-bottom: 1px;
    box-sizing: border-box;
    background-clip: border-box;
    text-align: center;
    padding: 1px 0;
    margin: 0;
}

.swiper01:not(.slide-inner-a-wrap) .swiper-slide {
    border: 1px solid var(--sub-color04);
    border-radius: 20px;
    padding: 30px;
}

.swiper01.slide-inner-a-wrap .swiper-slide a {
    border: 1px solid #d6d6d6;
    margin: 0;
    padding: 30px;
    box-sizing: border-box;
    display: block;
    height: 100%;
    border-radius: 20px;
}

.swiper01.slide-inner-a-wrap .swiper-slide a:hover img {
    opacity: 1;
}

.swiper01 .swiper-slide a {
    text-decoration: none !important;
}

.swiper01:not(.slide-inner-a-wrap) .swiper-slide>a {
    display: block;
    margin: -30px;
    padding: 30px;
}

.swiper01 .swiper-slide a:hover {
    opacity: 0.7;
}

.swiper01 li img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    border-radius: 20px;
}

.swiper01 .title,
.swiper01 .title a {
    display: block;
    text-align: center;
    font-size: 22px;
    font-weight: 400;
    color: var(--black) !important;
    text-decoration: none !important;
}

.swiper01 .title {
    width: 100%;
    margin: 15px 0;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

.swiper01 .title+.subtitle {
    margin-top: -15px;
}

.swiper01 .subtitle {
    color: var(--main-color01);
    margin-bottom: 5px;
}

.swiper01 .cats,
#main .swiper01 p.cats {
    text-align: center;
}

.swiper01 .cats a,
.swiper01 .cats span {
    display: inline-block;
    text-decoration: none !important;
    color: var(--white) !important;
    background: var(--main-color01);
    padding: 0px 20px;
}

.swiper01 .time {
    display: block;
    margin-left: auto;
    margin-right: auto;
    background: #eee;
    color: var(--black);
    width: fit-content;
    padding: 0 10px;
    font-size: 14px;
    font-weight: 400;
}

#main .swiper01 p {
    margin-bottom: 0;
    text-align: left;
}

/*-------------------#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;
    box-sizing: border-box;
    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;
}

/*-------------------.voiceList-----------------*/
.voiceList {
    position: relative;
    padding-bottom: 90px !important;
}

#main .voiceList.extraPart {
    border-top: var(--white) 1px solid;
    background-color: var(--white);
    padding-top: 0 !important;
    overflow: visible;
}

#main .voiceList.extraPart::before {
    content: "";
    display: block;
    position: absolute;
    left: calc(50% - 170px);
    top: -20px;
    margin: auto;
    background: url(./img/bfr_voice.png) no-repeat;
    width: 584px;
    height: 99px;
    z-index: 2;
}

#main .voiceList.extraPart h2 {
    background: url(./img/bg_voicehdng.png) repeat-x;
    padding-top: 180px;
}

#main .voiceList.extraPart h2::before {
    content: "お客様のお声が私たちの励みです";
    font-size: 16px;
    text-align: right;
    font-weight: 400;
    display: block;
    position: absolute;
    left: calc(50% - 500px);
    top: -160px;
    margin: auto;
    background: url(./img/chara_voice.png) no-repeat left top;
    width: 500px;
    height: 220px;
    padding-top: 80px;
    z-index: 2;
}

@media screen and (max-width : 1100px) {
    #main .voiceList.extraPart h2::before {
        left: 20px;
    }
}

#main .voiceList:not(.extraPart) ul {
    display: flex;
    flex-wrap: wrap;
    gap: 40px;
}

#main .voiceList ul li .subtitle {
    margin: 0 0 10px;
}

#main .voiceList ul li .time {
    display: block;
    margin-left: auto;
    margin-right: auto;
    background: #e7f7ed;
    color: var(--black);
    width: fit-content;
    padding: 0 10px;
    font-size: 14px;
    font-weight: 400;
}

#main .voiceList ul li p {
    margin-bottom: 0;
}

#main .voiceList ul li .btnDetailR {
    margin-top: 20px;
    transform: translate(15px, 10px);
}

#main .voiceList ul li {
    display: block;
    width: calc((100% - 80px) / 3);
    margin: 0;
    text-align: center;
    align-items: stretch;
}

@media screen and (max-width : 1100px) {
    #main .voiceList ul li {
        width: calc((100% - 40px) / 2);
    }
}

#main .voiceList ul li a {
    height: 100%;
    border: 1px solid #d6d6d6;
    margin: 0;
    padding: 30px;
    box-sizing: border-box;
    display: block;
    text-decoration: none;
    border-radius: 20px;
}

#main .voiceList ul li a .cats {
    pointer-events: none;
}

#main .voiceList ul li img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 20px;
}

#main .voiceList .title {
    width: 100%;
    margin: 15px 0 5px;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

#main .voiceList .title,
#main .voiceList .title a {
    font-size: 16px;
    display: block;
    text-align: center;
    font-weight: 400;
    color: var(--black) !important;
    text-decoration: none !important;
}

/*-------------------.staffList-----------------*/
.staffList {
    position: relative;
}

#top #contents #main .staffList.extraPart {
    padding: 100px 0;
    background-color: #fafafa;
}

#main .staffList h2 {
    margin-bottom: 50px;
    position: relative;
    width: fit-content;
    margin: 0 auto 50px;
    max-width: calc(100% - 380px);
}

#main .staffList .swiperStaff ul li {
    display: block;
    width: calc((100% - 80px) / 3);
}

@media screen and (max-width : 1100px) {
    #main .staffList .swiperStaff ul li {
        width: calc((100% - 40px) / 2);
    }
}

#main .staffList .swiperStaff ul li a {
    width: 100%;
}

#main .staffList .swiperStaff .cats a {
    pointer-events: none;
}

/*-------------------.menuList-----------------*/
#contents #main .menuList.extraPart {
    padding: 140px 0 !important;
    clip-path: polygon(0 calc(0% + 9vw), 100% 0, 100% 100%, 0 calc(100% - 9vw));
    background-color: #e8f7ed;
    top: -100px;
    margin-bottom: -100px;
}

#main .menuList.extraPart h2 {
    width: fit-content;
    max-width: calc(100% - 440px);
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

/* #main .menuList.extraPart h2:before {
    content: "";
    display: block;
    position: absolute;
    left: -215px;
    top: calc(50% - 88px);
    background: url(./img/itn_menu_ico.png) no-repeat;
    width: 205px;
    height: 176px;
    z-index: 2;
} */

.petitMenuList,
.menuList .inner>ul {
    display: flex;
    gap: 40px 40px;
    justify-content: center;
    flex-wrap: wrap;
    margin-top: 50px;
    margin-bottom: 60px;
}

.menuDetails {
    padding-top: 30px;
}

.petitMenuList li,
.menuList .inner>ul>li,
.menuDetailsItem {
    --menu-color: 0, 0, 0;
    background: var(--white);
    box-sizing: border-box;
    background-clip: border-box;
    text-align: center;
    display: block;
    padding: 30px;
    margin: 0;
    margin-bottom: 1px;
    border-radius: 20px;
    overflow: hidden;
}

.menuList .menuDetailsItem .title {
    font-size: 50px;
    font-weight: 800;
    line-height: 1;
    padding: 0;
}

.menuDetailsItem .price01>small {
    margin-right: 20px;
}

.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: 20px;
    font-weight: 500;
    padding: 10px;
}

.petitMenuList li,
.menuList .inner>ul>li {
    width: calc((100% - 80px) / 3);
    text-align: right;
}

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

    .petitMenuList li,
    .menuList .inner>ul>li {
        width: calc((100% - 40px) / 2);
    }
}

.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.5;
    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;
    text-align: center;
}

.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: flex;
    gap: 20px;
}

.menuDetailsItemHead .img {
    margin-bottom: 0 !important;
    width: 400px;
}


.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 .detailLnk {
    display: block;
    text-align: right;
    border-top: 1px dotted var(--black);
    font-size: 16px;
    margin-top: 15px;
    padding-top: 15px;
}

.menuDetailsItem .content .detailLnk li:hover {
    opacity: 1;
    transition: opacity 1.0s;
    transition: 0.8s;
}

.menuDetailsItem .content .detailLnk li label.popup-open {
    position: relative;
    padding-right: 1.5rem;
}

.menuDetailsItem .content .detailLnk li label.popup-open::after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f055";
    font-size: 1.2rem;
    line-height: 1;
    position: absolute;
    top: calc(50% - 0.5rem);
    right: 0;
    margin: 0;
    padding: 0;
    color: var(--main-color02);
}

.popupImp {
    display: none;
    /* label でコントロールするので input は非表示に */
}

.popup-open {
    cursor: pointer;
    /* マウスオーバーでカーソルの形状を変えることで、クリックできる要素だとわかりやすいように */
}

.popup-overlay {
    display: none;
    /* input にチェックが入るまでは非表示に */
}

.popupImp:checked~.popup-overlay {
    display: block;
    z-index: 99999;
    background-color: #00000070;
    position: fixed;
    width: 100%;
    height: 100vh;
    top: 0;
    left: 0;
}

.popup-window {
    width: 90vw;
    max-width: 1100px;
    padding: 20px;
    background-color: #e8f7ed;
    border-radius: 6px;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.popup-window .menuPlanTtl {
    background-color: var(--red);
}

.popup-window .menuPlanCnt {
    margin: 70px 0 30px;
}

.popup-window .menuPlanList {
    width: 90%;
}

.popup-text {
    margin: 0;
}

.popup-text:not(:last-of-type) {
    margin-bottom: 1em
}

.popup-close {
    cursor: pointer;
    position: absolute;
    top: -26px;
    right: 0;
}




.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;
}

.menuDetailsItem p.note {
    text-align: right;
    font-size: 14px !important;
    font-weight: normal;
    margin: 5px 0 !important;
}

.menuList .title {
    color: rgba(var(--menu-color), 1);
    font-size: 40px;
    font-weight: 600;
    padding: 20px;
    line-height: 1;
    text-align: center;
}

.menuList .menuimgbox {
    position: relative;
}

.menuList img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 20px;
    margin-bottom: 20px;
}

.menuList .recommended_plan {
    position: absolute;
    top: -15px;
    left: -25px;
}

.menuDetails .img img {
    margin-bottom: 0;
}

.menuList img:hover {
    opacity: 1 !important;
}

.menuList .price {
    margin-top: 5px;
}

.menuList a>small {
    text-align: left;
    display: block;
    font-size: 16px;
    margin-top: 10px;
    font-weight: normal;
}

.menuList .badges {
    margin: 10px 0;
}

/* .menuPlanList */
.menuPlanList {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    width: 70%;
    margin: auto;
}

.menuPlanList li {
    padding: 5px 15px 5px 40px;
    color: var(--white);
    border-radius: 6px;
    background: var(--black) url(./img/ico_check.png) no-repeat left 8px center;
}

/* .menuDetailsItem */
.menuDetailsItem {
    border: 1px solid rgba(var(--menu-color), 1);
    margin: 0 0 70px;
    padding: 50px;
}

/* .petitMenu */
#main .petitMenuTtl {
    position: relative;
}

#main .petitMenuTtl:before {
    content: "";
    display: block;
    position: absolute;
    left: 10px;
    top: -88px;
    background: url(./img/chara_menu_petit.png) no-repeat;
    width: 223px;
    height: 154px;
    z-index: 2;
}

#main .petitMenuList {}

#main .petitMenuList li .catch {
    margin-bottom: 30px;
    text-align: center;
}

#main .petitMenuList li img {
    height: 160px;
    object-fit: cover;
}

#main .petitMenuList li .petitMenuPrice {
    display: flex;
    justify-content: center;
    gap: 10px;
}

#main .petitMenuList li .price01Top b {
    font-size: 40px;
}

#main .petitMenuList li .price01Top>span i:last-of-type {
    font-size: 14px;
}

#main .petitMenuList li .price01Top>span i:first-of-type {
    font-size: 20px;
}

#main .petitMenuList li .price01>small {
    font-size: 14px !important;
    text-align: right;
}

#main .petitMenuList small {
    font-size: 14px !important;
    text-align: right;
}

#main .petitMenuList li .price01>small i {
    vertical-align: 0;
}

#main .petitMenuList li .workingHours {
    width: 80px;
    padding-left: 10px;
    border-left: 1px dotted var(--black);
}

#main .petitMenuList li .workingHours .hoursTtl {
    display: block;
    font-weight: 600;
}

#main .petitMenuList li .workingHours .hoursTime {
    font-size: 30px;
    color: var(--blue);
    font-family: var(--en-font-family);
    font-weight: 600;
    line-height: 1;
}

/* .menu2 */
.menu2 {
    display: flex;
    gap: 40px 40px;
    flex-wrap: wrap;
    margin-bottom: 70px;
    justify-content: center;
}

.menu2 .individual-menu {
    --menu-color: 0, 0, 0;
    /* width: 22vw; */
    width: calc((1100px - 2 * 40px) / 3);
    background: var(--white);
    box-sizing: border-box;
    background-clip: border-box;
    text-align: center;
    display: block;
    padding: 30px;
    margin: 0;
    margin-bottom: 1px;
    border-radius: 20px;
    overflow: hidden;
}

@media (min-width: 640px) and (max-width: 1024px) {
    .menu2 .individual-menu {
        width: calc((96vw - 40px) / 2);
    }
}

.menu2 .menu-section h3 {
    background: rgba(var(--menu-color), 1);
    color: var(--white);
    box-sizing: content-box;
    line-height: 0.7 !important;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    margin: -30px -30px 0;
    padding: 20px 5px;
}

.menu2 .headLine span {
    color: var(--red);
    background: none !important;
}

.menu2 .menu-name {
    font-size: 40px;
    color: rgba(var(--menu-color), 1);
    font-weight: bold;
    margin: 20px 0;
}

.menu2 .explanatory-text {
    background-color: #f2f2f2;
    padding: 15px;
    text-align: center;
    margin: 10px auto 0 !important;
    width: 100%;
}

.menu2 .price-hosoku {
    text-align: left;
    font-weight: bold;
}

.menu-item {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.menu2 .menu-section {
    display: flex;
    gap: 40px 40px;
    flex-grow: 1;
}

.menu2 .price-supplement {
    font-size: 28px !important;
    color: var(--red);
    font-weight: bold;
}

.menu2 .price-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.menu2 .price-list .price {
    border-bottom: 1px solid #cccccc;
    padding-bottom: 20px;
}

.menu2 .price-list .price:last-child {
    border-bottom: none;
}

.menu2 .supplementary-sentence {
    text-align: left;
    font-weight: bold;
    border-top: 1px solid #cccccc;
    padding-top: 10px;
    margin-bottom: 0 !important;
}

#menu .menu2 .individual-menu {
    border: 1px solid rgba(var(--menu-color), 1);
}

#menu .petitMenuList li {
    border: 1px solid rgba(var(--menu-color), 1);
}

/* .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: center;
    gap: 5px;
}

.badges li,
#main .badges li {
    display: block;
    font-size: 30px;
    font-weight: 600;
    color: var(--red);
    border: 1px solid currentColor;
    margin: 0;
    padding: 5px;
    line-height: 1;
    width: fit-content;
}

.badges li small,
#main .badges li small {
    font-size: 1.2rem;
}

/* .price01 */
.price01 {
    font-weight: 600;
}

.price01 b {
    font-weight: 600;
    font-family: var(--en-font-family);
    letter-spacing: -0.01em;
}

.price01Top i {
    font-style: normal;
}

.price01Top {
    display: flex;
    white-space: nowrap;
    line-height: 1;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
}

.price01 .total_pricebox {
    display: flex;
    align-items: center;
    gap: 5px;
}

.price01 .unit {
    text-align: left !important;
    line-height: 1.2;
}

.price01 .unit span {
    font-size: 13px;
}

.price01Top b {
    font-family: var(--en-font-family);
    font-size: 50px;
    color: var(--red);
}

.price01Top>span {
    display: flex;
    flex-direction: column;
    color: var(--black);
    line-height: 1;
    text-align: left;
    /* 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);
}

.price01 .special_menu_title {
    text-align: left;
    font-size: 20px;
    font-weight: bold;
    margin-top: 10px;
}

#menu .special_menubox {
    width: fit-content;
    margin: 30px 0 0 auto;
}

#menu .price01 .unit {
    font-size: 25px;
}

#menu .petitMenuPrice .price01 .unit {
    font-size: 20px;
}

/*-------------------.worksList-----------------*/
#contents #main section.worksList {
    padding-top: 50px;
}

#works .worksList {}

#top #contents #main .worksList.extraPart {
    padding-bottom: 150px;
    overflow: visible;
}

#top #contents #main .worksList.extraPart::before {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: -300px;
    background: url(./img/bg_menubtn.png) no-repeat;
    width: 289px;
    height: 237px;
    z-index: 2;
}


#main .worksList h2 {
    width: fit-content;
    max-width: calc(100% - 450px);
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

/*タブ切り替え全体のスタイル*/
.selectWorkstabs {
    margin-top: 50px;
    padding-bottom: 40px;
    width: 100%;
    margin: 0 auto;
}

/* タブのスタイル */
.selectWorkstabs .tab {
    width: calc((100% - 20px) / 2);
    background-color: var(--white);
    padding: 20px 50px 20px 20px;
    line-height: 1.5;
    font-size: 26px;
    font-weight: 500;
    text-align: center;
    color: var(--black);
    display: block;
    float: left;
    text-align: center;
    border-left: 3px solid var(--black);
    border-top: 3px solid var(--black);
    border-right: 3px solid var(--black);
    border-radius: 20px 20px 0 0;
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease;
}

.selectWorkstabs .tab::before {
    content: "";
    background: center center url("./img/ico_tab_house.png") no-repeat;
    width: 60px;
    height: 38px;
    display: inline-block;
    vertical-align: text-bottom;
    margin-right: 0.5rem;
}

.selectWorkstabs .tab::after {
    content: "";
    display: block;
    position: absolute;
    width: 32px;
    height: 32px;
    background: center center / contain no-repeat url(./img/arrowR.png);
    margin: auto 0;
    top: 0;
    right: 20px;
    bottom: 0;
    transform-origin: center;
    transition: all 0.3s ease;
}

.selectWorkstabs input:checked+.tab::after,
.selectWorkstabs .tab:hover::after {
    background-image: url(./img/arrowRw.png);
}

.selectWorkstabs input:checked+.tab::after {
    transform: rotate(90deg) translate(15%, 25%);
}

#selectWorksType+.tab::before {
    background-image: url("./img/ico_tab_house.png");
}

#selectWorksType:checked+.tab::before,
#selectWorksType+.tab:hover::before {
    background-image: url("./img/ico_tab_houseAC.png");
}

#selectWorksArea+.tab::before {
    background-image: url("./img/ico_tab_area.png");
}

#selectWorksArea:checked+.tab::before,
#selectWorksArea+.tab:hover::before {
    background-image: url("./img/ico_tab_areaAC.png");
}

#main .worksList .tab {}

.selectWorkstabs .tab:first-of-type {
    margin-right: 20px;
}

/*ラジオボタンを全て消す*/
input[name="tab"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
.tabContent {
    display: none;
    padding: 20px;
    clear: both;
    overflow: hidden;
    border: 1px solid var(--sub-color01);
}

.tabContent .cats>a,
#works .tabContent .cats>a {
    background: var(--white);
    border-radius: 6px;
    color: var(--black) !important;
    font-weight: 500;
    padding: 5px 10px;
    margin: 0 3px 5px 0;
    line-height: 1;
    transition: all 0.3s ease;
}

.tabContent .cats>a:first-of-type {
    margin-right: 30px !important;
    padding-left: 30px !important;
    padding-right: 30px !important;
}

.tabContent .cats>a.active,
.tabContent .cats>a:hover,
#works .tabContent .cats>a.active,
#works .tabContent .cats>a:hover {
    background: var(--black);
    color: var(--white) !important;
}

/*選択されているタブのコンテンツのみを表示*/
#selectWorksType:checked~#selectWorksTypeContent,
#selectWorksArea:checked~#selectWorksAreaContent {
    display: block;
    border-color: var(--main-color01);
    background-color: var(--main-color01);
}

/*選択されているタブのスタイルを変える*/
.selectWorkstabs input:checked+.tab,
.selectWorkstabs .tab:hover {
    border-color: rgba(255, 255, 255, 0);
    background-color: var(--main-color01);
    color: var(--white);
}

.worksList li a {
    text-decoration: none !important;
}

.worksList ul {
    display: flex;
    gap: 40px 40px;
    justify-content: flex-start;
    flex-wrap: wrap;
    margin-bottom: 50px;
}

.worksList li {
    border: 1px solid #d6d6d6;
    background: var(--white);
    background-clip: border-box;
    text-align: center;
    display: block;
    width: calc((100% - 80px) / 3);
    padding: 0;
    margin: 0;
    margin-bottom: 1px;
    position: relative;
    border-radius: 20px;
}

@media screen and (max-width : 1100px) {
    .worksList li {
        width: calc((100% - 40px) / 2);
    }
}

.worksList li a {
    display: block;
    padding: 30px 30px 40px;
    box-sizing: border-box;
}

.worksList li a:hover {
    opacity: 0.7;
}

.worksList li img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 20px;
}

.worksList li a:hover img {
    opacity: 1;
}

.worksList li .title {
    display: block;
    text-align: center;
    font-size: 16px;
    font-weight: 400;
    color: var(--black) !important;
    text-decoration: none !important;
    width: 100%;
    margin: 15px 0;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

.worksList li dl {
    border-top: 1px dotted var(--black);
    display: block;
}

.worksList li dt,
.worksList li dt {
    display: block;
    color: var(--black);
}

.worksList li dt {
    font-size: 14px;
    padding-top: 10px;
}

.worksList li dt,
.worksList li dd.cats {
    text-align: left;
}

.worksList li dd.cats span {
    color: var(--black);
}

.worksList li dd {
    padding-bottom: 10px;
    border-bottom: 1px dotted var(--black);
}

.worksList li dd.price {
    color: var(--red);
}

.worksList .time {
    margin-top: 10px;
    text-align: left;
}

.worksList li .btnDetailR {
    position: absolute;
    right: 30px;
    bottom: 20px;
    margin: 0;
    transform: translate(15px, 15px);
}

/*-------------------.blogList-----------------*/
.blogList {
    position: relative;
    padding-bottom: 90px !important;
}

.blogList.extraPart {
    margin: 0 0 0 0 !important;
    padding: 50px 0 5px !important;
    position: relative;
    background-color: var(--white);
    overflow: visible !important;
}

#main .blogList.extraPart:after {
    width: 0;
    height: 0;
    position: absolute;
    bottom: calc(-8vw + 1px);
    content: "";
    border-style: solid;
    border-width: 8vw 50vw 0 50vw;
    border-color: var(--white) transparent transparent transparent;
    background: transparent;
    z-index: 2;
}

#works .blogList.extraPart {
    padding-bottom: 150px !important;
    overflow: visible;
}

#works .blogList.extraPart::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    transform: translate(100%, 50%);
    width: 647px;
    height: 301px;
    background: url(./img/bg_image02.png) left top no-repeat;
    z-index: 9;
}

#works .voiceList {
    overflow: visible;
}

#voice .blogList.extraPart {
    padding-bottom: 150px !important;
    overflow: visible;
}

#voice .blogList.extraPart::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0 auto;
    transform: translate(100%, 50%);
    width: 655px;
    height: 305px;
    background: url(./img/bg_image01.png) left top no-repeat;
    z-index: 9;
}

.blogList.extraPart h2 {
    margin-top: 50px;
    text-align: center;
}

#main .blogList.extraPart h2::before {
    content: "解体工事のお役立ち情報\Aなども掲載中です！";
    white-space: pre;
    font-size: 16px;
    text-align: right;
    font-weight: 400;
    display: block;
    position: absolute;
    left: calc(50% - 550px);
    top: 30px;
    margin: auto;
    background: url(./img/chara_blog.png) no-repeat right top;
    width: 410px;
    height: 170px;
    padding: 40px 210px 0 0;
}

@media screen and (max-width : 1100px) {
    .blogList.extraPart h2 {
        padding-right: 380px;
    }

    #main .blogList.extraPart h2::before {
        left: auto;
        right: 10px;
    }
}

#main .blogList ul {
    display: flex;
    flex-direction: column;
    margin-bottom: 30px;
    text-align: left;
}

.blogList li {
    display: flex;
    padding-left: 0 !important;
    padding-bottom: 40px;
    border-bottom: 1px dotted var(--black);
    margin-bottom: 40px !important;
}

.blogList .mainThumb {
    width: 260px;
    height: 160px;
    object-fit: cover;
    margin-right: 25px;
    border-radius: 20px;
}

.blogList .outline {
    width: calc(100% - 260px - 25px);
}

#main .blogList p {
    margin-bottom: 0;
}

#main .blogList a,
#main .blogList a:hover {
    text-decoration: none;
}

.blogList .tit {
    margin-top: 10px;
    color: var(--main-color02);
    font-weight: 500;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.blogList .excerpt {
    font-size: 14px;
}

.blogList .time {
    text-align: left;
    font-size: 12px;
    display: inline-block;
}

.blogList .cats {
    display: inline-block;
    margin-left: 20px;
}

#works .cats a,
.infoBox .cats a,
.blogList .cats a {
    display: inline-block;
    color: var(--black) !important;
    background: #e7f7ed;
    text-decoration: none !important;
    line-height: 1;
    padding: 5px 10px;
    margin: 0 10px 10px 0;
    border-radius: 0;
    transition: all 0.3s ease;
}

.blogList .outline .cats a {
    margin-right: 0;
}

#works .cats a:hover,
.infoBox .cats a:hover,
.blogList .cats a:hover {
    background: var(--main-color01);
    color: var(--white) !important;
}

.blogList .link {
    margin-top: 0.5rem;
    text-align: right;
}

.blogList>.btn {
    text-align: center;
}

/*-------------------.blogCategories-----------------*/
.blogCategories {
    border: 1px solid #ccc;
    background-color: var(--white);
    padding: 30px 40px 20px 40px;
    margin: 70px 0;
}

.blogCategories h4 {
    font-size: 16px;
    font-weight: 400;
}

.blogCategories h4 i {
    font-size: 1.8rem;
    margin-right: 15px;
    vertical-align: sub;
}

.blogCategories .cats {
    margin: 30px 0 0;
}

.blogCategories .cats a {
    padding: 10px 30px;
}

.blogCategories .cats a.active {
    background: var(--black);
    color: var(--white) !important;
}

/*------------------- #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));
}


/*------------------- #staff スタッフ紹介 -----------------*/

.staffListVertical {
    display: flex;
    flex-direction: column;
}

.staffListVertical li {
    display: grid;
    gap: 40px;
    grid-template-columns: auto 330px;
    border-bottom: 2px solid var(--black);
    margin-bottom: 50px;
    padding-bottom: 50px;
}

.staffListVertical li .cats span {
    color: var(--white);
    background: var(--main-color02);
    font-size: 16px;
    font-weight: 400;
    vertical-align: text-bottom;
    padding: 5px 15px;
}

.staffListVertical li h3.title {
    font-size: 26px;
    font-weight: 500;
}

.staffListVertical li .img img {
    width: 100%;
    object-fit: contain;
}

.staffListVertical li table {
    border: 0 !important;
    margin: 30px 0 0 !important;
    position: static;
}

.staffListVertical li th,
.staffListVertical li td {
    border-bottom: 1px solid var(--white) !important;
    position: static !important;
    padding: 10px 20px !important;
}

.staffListVertical li th {
    background: #e8f7ed !important;
    border-left: 0 !important;
    border-right: 1px solid var(--white) !important;
    width: 33% !important;
    text-align: center !important;
    vertical-align: middle !important;
    font-weight: bold !important;
}

.staffListVertical li td {
    border-left: 0 !important;
    border-right: 0 !important;
}

.staffListVertical li tr:first-of-type th,
.staffListVertical li tr:first-of-type td {
    border-top: 1px solid var(--black) !important;
}

.staffListVertical li tr:last-of-type th,
.staffListVertical li tr:last-of-type td {
    border-bottom: 1px solid var(--black) !important;
}

/*------------------- 投稿系共通 -----------------*/
.worksSingle .infoBox .time,
.blogSingle .infoBox .time {
    font-size: 1rem;
    font-weight: 400;
    margin-bottom: 20px;
}

.worksSingle .infoBox>i[class^='fa'],
.blogSingle .infoBox>i[class^='fa'] {
    font-size: 21px;
}

.worksSingle .infoBox .cats,
.blogSingle .infoBox .cats {
    padding-left: 15px;
}

.worksSingle .outline .cats a,
.blogList .outline .cats a,
.blogSingle .infoBox .cats a {
    font-size: 14px;
    padding: 8px 15px;
}

.worksSingle .infoBox,
.blogSingle .infoBox {
    margin-bottom: 40px;
}

/*------------------- .blogSingle 現場ブログ -----------------*/
.blogSingle .mainThumb {
    margin-top: -40px;
    padding: 40px 60px;
    box-sizing: border-box;
    width: 100%;
    height: auto;
    display: block;
}

.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;
}


/*------------------- #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 補助金・助成金 -----------------*/
#subsidy {
    counter-reset: count-detail;
}

#subsidy .leadCts {
    padding-top: 20px;
}

#subsidy .leadCts .imgRFull {
    margin-top: -20px;
}

#subsidy .detailCnt.subsidyCtx:last-child {
    margin-bottom: 0;
}


.subsidyFlow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    justify-content: flex-start;
    gap: 30px;
}

.subsidyFlow>li {
    flex-basis: calc((100% - 120px) / 5);
    padding-left: 0 !important;
}

.subsidyFlow>li::before {
    content: none !important;
}

.subsidyFlow>li .icon {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    line-height: 50px;
    width: 50px;
    color: #fff;
    background: var(--main-color01);
    margin: 0 auto 20px;
    display: block;
    border-radius: 50%;
    text-align: center;
    position: relative;
    letter-spacing: 2px;
}

.subsidyFlow>li .icon::before {
    content: "";
    border: solid transparent;
    border-width: 8px;
    border-top-color: var(--main-color01);
    position: absolute;
    top: calc(100% - 2px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

.subsidyFlow>li p {
    padding: 20px 10px;
    margin: 0;
    border: 3px solid var(--main-color01);
    position: relative;

    font-size: 20px;
    font-weight: 600;
    color: var(--main-color01);
    text-align: center;
}


.subsidyFlow>li:not(:last-child) p::before {
    content: "";
    width: 14px;
    height: 14px;
    margin-right: 10px;
    display: inline-block;
    border-top: 4px solid var(--main-color01);
    border-right: 4px solid var(--main-color01);
    position: absolute;
    top: calc(50% - 14px);
    left: 104%;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.subsidyFlowFgr {
    display: block;
    margin: 0 auto 5px;
}

#subsidy #main {
    padding-bottom: 130px;
}

.subsidyIndex {
    padding: 50px 0;
}

.subsidyIndex .title {
    position: relative;
    display: block;
    font-size: 26px;
    font-weight: 500;
    padding: 20px 0;
    text-align: center;
    background-color: var(--main-color01);
    color: var(--white);
    text-decoration: none;
    border-radius: 20px;
}


.subsidyIndex ul,
.subsidyIndex ol {
    display: flex;
    justify-content: center;
    gap: 30px 40px;
    flex-wrap: wrap;
    margin: 50px 0;
}

.subsidyIndex li {
    width: calc((100% - 80px) / 3);
    display: block;
}

.subsidyIndex li a {
    display: block;
    position: relative;
    text-align: left;
    font-size: 16px;
    font-weight: 500;
    padding: 0 0 30px;
    color: var(--black) !important;
    border-bottom: 1px solid currentColor;
    text-decoration: none !important;
}

.subsidyIndex li a:hover {
    color: var(--main-color02) !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: 100px !important;
    padding-bottom: 100px !important;
}

.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;
}


/*------------------- #flow 施工の流れ -----------------*/
#flow #main {
    padding-top: 65px;
}

#flow {
    counter-reset: count-detail;
}

.detailCnt.flowCtx .firstLead {}

.detailCnt.flowCtx .menuPlanTtl::before {
    content: "FLOW 0" counter(count-detail);
}

#flow #main>div:first-of-type .inner {
    padding-top: 10px;
    padding-bottom: 100px;
}

#flow .flow {
    padding-top: 100px;
}

.flowIndex {
    display: flex;
    justify-content: space-between;
}

.flowIndex ol {
    counter-reset: my-counter;
    display: flex;
    justify-content: center;
    gap: 0 35px;
}

.flowIndex li {
    position: relative;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-lr;
    font-size: 20px;
    font-weight: bold;
}

.flowIndex li::before {
    font-family: Roboto, sans-serif;
    content: counter(my-counter);
    counter-increment: my-counter;
    color: var(--main-color01);
    display: block;
    transform: translateY(-25%) rotate(-90deg);
    position: absolute;
    top: 20px;
    left: 0;
    right: 0;
    margin: 0 auto;
    z-index: 5;
}

.flowIndex li:hover::before {
    color: var(--white) !important;
}

.flowIndex li::after {
    position: absolute;
    content: "";
    border-top: 9px solid var(--ts);
    border-left: 10px solid var(--black);
    border-bottom: 9px solid var(--ts);
    display: block;
    top: 0;
    right: -10px;
    bottom: 0;
    margin: auto 0;
    width: 0;
    height: 0;
    transform: translateX(100%);
}

.flowIndex li:last-of-type::after {
    display: none;
}

.flowIndex li a {
    position: relative;
    display: block;
    background: var(--white);
    padding: 50px 10px 40px;
    font-weight: 500;
    text-decoration: none !important;
    color: var(--black) !important;
    transition: all 0.3s ease;
    z-index: 2;
    overflow: hidden;
}

.flowIndex li a:hover {
    background-color: var(--main-color01) !important;
    color: var(--white) !important;
}

.flowIndex li a::after {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    margin: 0 auto;
    bottom: 15px;
    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;

}

.flowIndex li a:hover::after {
    color: var(--white) !important;
}

.flowIndex .img {
    width: 263px;
    height: 400px;
    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;
}

@media screen and (max-width : 1100px) {
    .flowIndex {
        flex-direction: column;
    }

    .flowIndex .img {
        width: auto;
        height: auto;
        display: flex;
        justify-content: center;
        gap: 10px;
        align-items: center;
        margin-top: 15px;
    }

    .flowIndex .img img {
        position: relative;
    }

}


.flowList {
    counter-reset: my-counter;
}

.flowList .flowItem {
    margin-bottom: 80px;
    position: relative;
}

.flowList .flowItem .title {
    position: relative;
    padding-left: 90px;
}

.flowList .flowItem .title::before {
    content: counter(my-counter);
    counter-increment: my-counter;
    color: var(--main-color02);
    display: block;
    position: absolute;
    top: 0;
    left: 20px;
    bottom: 0;
    margin: auto 0;
    width: 1em;
    height: 1em;
    font-size: 26px;
    font-weight: 700;
    background: var(--white);
    text-align: center;
    border-radius: 50%;
    color: var(--main-color02);
    line-height: 1;
    padding: 14px;
}

.flowList .flowItem .img {
    width: 320px;
    height: auto;
}

.flowList .flowItem.box03 .img.alignright {
    margin-bottom: 0;
}

.flowList .flowItem::before {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-left: 25px solid var(--ts);
    border-top: 26px solid var(--black);
    border-right: 25px solid var(--ts);
    position: absolute;
    margin: 0 auto;
    left: 0;
    right: 0;
    bottom: 0;
    transform: translateY(200%);
}

.flowList .flowItem:last-of-type {
    margin-bottom: 10px;
}

.flowList .flowItem:last-of-type::before {
    display: none;
}

#main .flowList .wysiwyg p,
#main .flowList .wysiwyg ul {
    margin-bottom: 0.5em;
}

#main .flowList .wysiwyg li {
    padding-left: 1.25em;
    line-height: 1.5;
}

#main .flowList .wysiwyg li::before {
    background: currentColor;
    width: 3px;
    height: 3px;
    top: 0.7em;
    left: 0.5em;
}

/*------------------- #partner 協力業者募集 -----------------*/
#partner #main h2+.telBox {
    margin-top: 0;
}

#partner .mainv {
    margin-bottom: 20px !important;
}

#partner #contents .partnerContact {
    padding-bottom: 50px;
}

/*------------------- #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 .dataT {
    margin-bottom: 50px;
}

#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 .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 */
#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: #016462;
    color: var(--white);
    font-size: 26px;
    font-weight: 500;
    margin: 0 0 20px 0;
    padding: 20px 30px;
}

#main .wysiwyg h1 a,
#main .wysiwyg h2 a {
    color: var(--white);
}

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

#main .wysiwyg h4:not([class]) {
    font-size: 1.25rem;
    font-weight: 500;
    border-top: solid 2px #016462;
    border-bottom: solid 2px #016462;
    margin: 0 0 20px 0;
    padding: 10px 10px 12px 10px;
}

#main .wysiwyg h5:not([class]) {
    font-size: 16px;
    font-weight: 500;
    border-bottom: double 3px var(--main-color01);
    margin: 0 0 20px 0;
    padding: 0 10px 15px 10px;
}

#main .wysiwyg h6:not([class]) {
    font-size: 16px;
    font-weight: 500;
    border-bottom: dotted 2px var(--main-color01);
    margin: 0 0 20px 0;
    padding: 0 10px 15px 10px;
}

#main .wysiwyg blockquote {
    border: 1px dotted var(--black);
    background: #f9f9f9;
    margin-bottom: 20px;
    padding: 50px;
}

#main .wysiwyg blockquote p:last-of-type {
    margin-bottom: 0;
}

#main .wysiwyg ul+h3:not([class]) {
    margin-top: 40px;
}

#main ul.normalList,
#main .wysiwyg ul {
    margin: 0 0 20px 0;
}

#main ul.normalList li,
#main .wysiwyg ul li {
    list-style: none;
    line-height: 1.8;
    margin-bottom: 10px;
    padding-left: 30px;
    position: relative;
}

#main ul.normalList li::before,
#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 ul {
    list-style: none;
    counter-reset: alpha;
}

#main .wysiwyg ul li.alphaList::before {
    counter-increment: alpha;
    content: counter(alpha, lower-alpha) ". "; 
    font-weight: bold;
    margin-right: 0.5em;
    background-color: transparent;
    width: auto;
    height: auto;
    top: auto;
}

#main .wysiwyg p.text-indent {
    text-indent: -1em;
    padding-left: 1em;
}

#main .wysiwyg .border-box {
    border: 2px solid var(--main-color01);
    padding: 10px 0 10px 10px;
    font-weight: bold;
}

#main .wysiwyg .btnC {
    margin-top: 20px;
}

#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;
}

#privacy .wysiwyg table th,
#privacy .wysiwyg table td {
    border: none;
    border-bottom: var(--black) dotted 1px;
}

/* .box */

.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;
    box-sizing: border-box;
    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);
    box-sizing: border-box;
    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: 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;
    box-sizing: border-box;
    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: 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;
}

/*------------------- #lp01 ランディングページ -----------------*/
.lpBody header .inner .hdrTel .tel-link {
    font-size: 3vw;
}

.lpBody header .inner .hdrTel {
    padding: 20px 0 0;
}

.lpBody .telBtn {
    padding-right: 0;
}

.lpBody footer .ftrFab {
    display: none;
}

.lpBody .pageTop {
    bottom: 0;
}

.cttLpBtn {
    text-align: center;
    font-weight: bold;
    display: inline-block;
    height: 60px;
    width: 60px;
    vertical-align: middle;
    line-height: 1;
}

.cttLpBtn {
    background: var(--main-color01);
}

.cttLpBtn a {
    font-size: 26px;
    background: var(--main-color01);
    padding-top: 18px;
    color: var(--white);
    text-decoration: none;

    text-align: center;
    font-weight: bold;
    display: inline-block;
    height: 60px;
    width: 60px;
    vertical-align: middle;
    line-height: 1;
}

#partner .subMainV img {
    border-radius: 20px;
}

.subMainVLp {
    margin: -2vw 0 0;
    width: 100%;
    position: relative;
}

.subMainVLp img {
    width: 100%;
    object-fit: cover;
    max-width: 1923px;
}

.subMainVLp::before {
    content: "";
    width: 255px;
    height: 231px;
    background: url(./img/wood01.png) no-repeat;
    position: absolute;
    bottom: -40px;
    left: 15px;
    z-index: 10;
}

.subMainVLp::after {
    content: "";
    width: 210px;
    height: 248px;
    background: url(./img/wood02.png) no-repeat;
    position: absolute;
    bottom: -50px;
    right: 15px;
    z-index: 10;
}

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

    .subMainVLp::before,
    .subMainVLp::after {
        content: none;
    }
}

.lpBody #contents section#main {
    padding: 0;
}

#lp01 .subMainVLp {
    background: center center url("./img/bg_sky.png");
}

.lpLead {
    background-image: url("./img/bg_lplead02.png"), url("./img/bg_lplead.png");
    background-position: left, center;
    background-repeat: repeat, no-repeat;
    background-size: auto, cover;
    padding: 100px 0;
}

.lpLeadFgr {}

#main a.button_box {
    text-decoration: none;
    background: linear-gradient(to bottom, #e9601e 0, #e9601e 50%, #be4f18 50%, #be4f18 100%);
    font-size: 46px;
    font-weight: 700;
    color: var(--white);
    display: block;
    width: fit-content;
    text-align: center;
    box-sizing: border-box;
    box-shadow: 0 5px 0 0 #74300f;
    padding: 10px 3em;
    border: 3px solid #fff;
    border-radius: 100vh;
    position: relative;
    margin: 0 auto;
    z-index: 10;
}

#main a.button_box:hover {
    transition: all 0.3s;
    box-shadow: none;
    transform: translateY(4px);
}

#main a.button_box::after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f30b";
    font-size: 0.7em;
    line-height: 1;
    position: absolute;
    top: calc(50% - 0.8rem);
    right: 2.5em;
    margin: 0;
    padding: 0;
    -webkit-transition: all .3s;
    transition: all .3s;
}

#main a.button_box::before {
    content: "";
    position: absolute;
    width: 205px;
    height: 220px;
    right: -160px;
    top: -20px;
    background: url(./img/ico_leadchara.png) center center / cover no-repeat;

}

#main a.button_box .icoOk {
    position: absolute;
    left: 0;
    top: -100px;
}

#main .lpLeadList li {
    line-height: 1.5;
    position: relative;
    padding-top: 30px;
}

#main .lpLeadList {
    margin-bottom: 250px;
}

#main .lpLeadList .leadTtl {
    position: absolute;
    background-color: var(--white);
    font-size: 25px;
    font-weight: bold;
    color: var(--green);
    padding: 0 30px;
    border-radius: 10px;
    text-align: center;
    line-height: 1.5;
    width: fit-content;
    top: -20px;
    right: 0;
    left: 0;
    margin: auto;
}

#main .lpLeadList li:nth-child(2n) .leadTtl {
    color: var(--blue);
}

#main .wryBox {
    background: url(./img/bg_wrybox.png);
}

#main .wryTtl {
    background: var(--main-color02);
    color: var(--white);
    font-size: 50px;
    font-weight: 900;
    text-align: center;
    padding: 10px 0;
    position: relative;
}

#main .wryTtl::after {
    content: '' !important;
    height: 0;
    position: absolute;
    width: 0;
    border: 20px solid transparent;
    border-top: 30px solid var(--main-color02);
    top: 100%;
    left: 0;
    right: 0;
    bottom: inherit;
    margin: auto;
    background: none;
}

#main .wryBox .wryInner {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 50px 0;
}

.wrtList li {
    font-size: 18px;
    padding: 5px 15px 5px 40px;
    margin-bottom: 10px;
    color: var(--white);
    border-radius: 6px;
    background: var(--black) url(./img/ico_check.png) no-repeat left 8px center;
    width: fit-content;
}

.taxTtl {
    padding: 50px 0;
    text-align: center;
}

#main .riskBox {
    background-image: url(./img/bg_risk.png), url(./img/bg_risk.png);
    background-repeat: repeat-x, repeat-x;
    background-position: top, bottom;
    padding: 50px 0 80px;
}

#main .riskTtl {
    display: flex;
    justify-content: space-between;
    align-items: center;

}

#main .riskTtl img:first-child {
    max-width: 79%;
    height: auto;
}

#main .riskTtl img:last-child {
    max-width: 20%;
    height: auto;
}

#main .imgRisk {
    text-align: center;
    padding: 20px 0;
}

#main .riskList {
    display: flex;
    justify-content: space-between;
    gap: 20px;
}

#main .riskList li {
    width: calc((100% - 100px) / 5);
}

#main .riskList li img {
    max-width: 100%;
    height: auto;
}

.selectTtl {
    padding: 50px 0;
    text-align: center;
}

#main .selectList {
    display: flex;
    justify-content: space-between;
    gap: 30px 40px;
    flex-wrap: wrap;
}

#main .selectList li {
    width: calc((100% - 80px) / 3);
    font-size: 23px;
    padding: 10px 10px 10px 40px;
    color: var(--white);
    border-radius: 20px;
    background: var(--black) url(./img/ico_check.png) no-repeat left 10px top 20px;
}

#main .selectList li strong {
    color: var(--main-color03);
}

#main .voiceList.extraPart.voiceLp {
    border-top: none;
    background-color: transparent;
    padding-top: 100px !important;
}

#main .voiceList.extraPart.voiceLp::before {
    content: none;
}

#main .voiceList.extraPart.voiceLp h2 {
    background: none;
    padding-top: 50px;
    width: fit-content;
    margin-right: auto;
    margin-left: auto;
}

#main .voiceList.extraPart.voiceLp h2::before {
    content: "";
    right: calc(50% - 550px);
    left: auto;
    top: 10px;
    background: url(./img/staff_voice.png) no-repeat left top;
    width: 407px;
    height: 266px;
}

.menuDetails.extraPart {
    padding: 200px 0 !important;
    clip-path: polygon(0 calc(0% + 9vw), 100% 0, 100% 100%, 0 calc(100% - 9vw));
    background-color: var(--sub-color02);
    top: -100px;
    margin-bottom: -100px;
}

.menuDetails.extraPart h2 {
    width: fit-content;
    max-width: calc(100% - 440px);
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

.menuDetails.extraPart h2::before {
    content: "";
    display: block;
    position: absolute;
    left: -400px;
    top: calc(50% - 100px);
    background: url(./img/stf_menu_ico.png) no-repeat;
    width: 336px;
    height: 180px;
    z-index: 2;
}

.menuDetailsItem .catch .menu_catch_sub {
    font-size: 20px;
    margin-top: 3px;
}

#main .worksList h2.wksHeadLineEtr {
    /* padding-top: 100px; */
}

#main .worksList h2.wksHeadLineEtr::before {
    right: -400px;
    top: calc(50% - 60px);
    background: url(./img/stf_works_ico.png) no-repeat;
    width: 373px;
    height: 189px;
}

#lp01 .corporateOutline {
    margin-top: 0;
}

#main .faqList {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    margin-bottom: 50px;
}

#main .faqList li {
    width: calc((100% - 30px) / 2);
    background: var(--white);
    border: var(--sub-color04) solid 5px;
    padding: 5px;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
}

#main .faqList li h4.questionH {
    margin: 0 0 10px;
    border: none;
    border-bottom: var(--sub-color04) solid 1px;
    padding: 10px;
}

#main .faqList li h4.answerH {
    margin: 0 0 5px;
    font-weight: 900;
    color: var(--red);
}

@media screen and (max-width : 1100px) {
    #main .voiceList.extraPart.voiceLp h2::before {
        right: calc(50% - 400px);
        top: 50px;
        width: 300px;
        height: 196px;
        background-size: contain;
    }

    .menuDetails.extraPart h2::before {
        content: none;
    }

    #main .worksList h2.wksHeadLineEtr::before {
        right: -320px;
        top: calc(50% - 60px);
        width: 300px;
        height: 141px;
        background-size: contain;
    }

    #main a.button_box::before {
        display: none;
    }

}

/*#lp02*/
.lpRndBox {
    background-color: var(--black);
    padding: 5px 50px;
    color: var(--white);
    border-radius: 20px;
    text-align: center;
    font-weight: 700;

    width: fit-content;
    font-size: 36px !important;
    margin: 0 auto 30px !important;
}

.lpRndBox strong {
    color: var(--yellow) !important;
}

.tskDetails {
    padding: 100px 0 50px;
}

#lp02 {
    counter-reset: count-detail;
}

.tskDetails .menuPlanTtl::before {
    content: "対策 0" counter(count-detail);
}

.failureList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    gap: 40px;
    overflow: visible;
    margin: 40px 0 0;
}

.failureList>li {
    width: 100%;
    position: relative;
    padding: 25px 15px 20px;
    box-sizing: border-box;
    background: var(--sub-color02);
    border-radius: 10px;
    margin-bottom: 0;
}

.failureList li p {
    font-size: 14px !important;
}

.failureList .failureNo {
    background: var(--red);
    text-align: center;
    color: #fff;
    border-radius: 100vh;
    position: absolute;
    top: -1em;
    width: fit-content;
    box-sizing: border-box;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
    padding: 4px 50px;
    font-size: 16px !important;
}

.failureList .failureNo::before {
    content: '';
    position: absolute;
    bottom: -28px;
    left: 50%;
    margin-left: -10px;
    border: solid transparent;
    border-width: 15px 10px;
    border-top-color: var(--red);
}

.failureList .failureListHedding {
    font-size: 16px;
    border-radius: 10px;
    background-color: var(--red);
    color: var(--white);
    text-align: center;
    margin: 20px 0 5px !important;
    padding: 5px 0;
}

.failureList li .fChekList li {
    position: relative;
    padding: 0 0 0 30px;
    font-size: 14px !important;
}

.failureList li .fChekList li::before {
    content: '';
    background: center center url("./img/ico_check_r.png") no-repeat;
    display: block;
    left: 0;
    top: 0.5em;
    position: absolute;
    width: 22px;
    height: 15px;
}

.rknDetails {
    padding: 50px 0;
}

.lpPriceList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    gap: 20px;
    overflow: visible;
    margin: 40px 0;
}

.lpPriceList li {
    width: 100%;
    position: relative;
    box-sizing: border-box;
    border: 2px solid #ccbdaa;
    background: var(--white);
    border-radius: 8px;
    text-align: center;
    margin-bottom: 0;
    padding: 35px 20px 20px;
}

.lpPriceList li p {
    margin: 0;
    text-align: left;
    font-size: 14px !important;
}

.lpPriceList .lpPriceListHedding {
    background: var(--main-color01);
    color: var(--white);
    border-radius: 20px;
    position: absolute;
    top: -30px;
    width: 90%;
    box-sizing: border-box;
    right: 0;
    left: 0;
    margin: auto;
    text-align: center;
    padding: 2px 0 8px;
    font-size: 22px;
    line-height: 1 !important;
}

.lpPriceList .lpPriceListHedding b {
    font-size: 36px;
    color: var(--yellow) !important;
}

.lpPriceList .lpPriceListHedding::before {
    content: '';
    position: absolute;
    bottom: -28px;
    left: 50%;
    margin-left: -10px;
    border: solid transparent;
    border-width: 15px 10px;
    border-top-color: var(--main-color01);
}

.lpPriceList .lpPriceListHeddingL4 {
    font-size: 18px;
    text-align: center;
    font-weight: 700;
    margin-bottom: 10px;
}

.lpPriceList .lpPriceListHeddingL5 {
    font-size: 28px;
    text-align: center;
    color: var(--white);
    font-weight: 700;
    background: var(--black);
    border-radius: 10px;
    width: fit-content;
    padding: 2px 10px;
    margin: 0 auto 10px;
}

.lpPriceList .price01Top {
    border-bottom: 1px var(--black) dotted;
    padding-bottom: 2px;
    margin-bottom: 10px;
    justify-content: center;
}

.lpPriceList .price01Top b {
    font-size: 40px;
}

.lpPriceList .price01Top>span i {
    font-weight: 700;
}

.lpPriceList .price01Top>span i:first-of-type {
    font-size: 20px;
}

.lpPriceList .price01Top>span i:last-of-type {
    font-size: 14px;
}

.btnsLpBox {
    padding: 100px 0;
}

/*#lp03*/
.claimBox {
    background: url(./img/bg_claim.png);
    margin-top: -2vw;
    padding-top: 20px;
}

.claimBox .bgClaimBox {
    background: url(./img/bg_claim02.png) no-repeat top left;
    overflow: hidden;
    padding: 20px 0 50px;
}

.claimBox .taxTtl img:last-child {
    margin-bottom: 3px;
}

.countermeasureList {
    display: flex;
    justify-content: center;
    gap: 30px;
    position: absolute;
    z-index: 1;
    top: -2vw;
    right: 0;
    left: 0;
    margin: auto;
    max-width: calc(100% - 20px);
}

.countermeasureList img {
    max-width: calc((100% - 80px) / 3);
    height: auto;
}

#lp03 #contents section#main {
    overflow: visible;
}

#main .claimSt {
    position: relative;
    z-index: 2;
    margin-left: 20vw;
    padding: 20px 0;
}

#main .claimSt::before {
    content: "";
    width: 100vw;
    height: 100%;
    background: var(--white);
    border-radius: 20px 0 0 20px;
    position: absolute;
    top: -1px;
    left: -20px;
    z-index: -1;
}

.claimPtList {
    z-index: 1;
}

.claimPtList li {
    position: absolute;
}

.claimPtList li:first-child {
    right: 300px;
    top: 50px;
}

.claimPtList li:nth-child(2) {
    right: 50px;
    top: 0;
}

.claimPtList li:last-child {
    bottom: -45px;
    left: 0;
}

.claimYinList {
    display: flex;
    justify-content: center;
    gap: 30px;
    z-index: 2;
    position: relative;
    padding: 60px 0 120px 0;
}

.claimYinList li {
    background-color: var(--red);
    border-radius: 100vh;
    color: var(--white);
    padding: 5px 50px;
    font-size: 36px;
    font-weight: 700;
}

#lp03 {
    counter-reset: count-detail;
}

.tymDetails {
    padding: 100px 0 50px;
}

.tymDetails .menuPlanTtl::before {
    content: "強み 0" counter(count-detail);
}

#showroom #cornerName,
#contact #cornerName {
    margin-top: 0;
}

.bnr_campaign {
    width: 100%;
}

.bnr_campaign img {
    width: 100%;
}



.topHoliday {
    text-align: center;
    padding-top: 70px;
}
    padding-top: 70px;
}0px;
}
    padding-top: 70px;
}
    padding-top: 70px;
}
    padding-top: 70px;
}    padding-top: 70px;
}
    padding-top: 70px;
}0px;
}  padding-top: 70px;
}
    padding-top: 70px;
}0px;
}