@charset "UTF-8";


section {
    margin-bottom: 70px;
}

.ft-min {
    font-family: 'Times New Roman', '游明朝', 'Yu Mincho', '游明朝体', 'YuMincho', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'ＭＳ Ｐ明朝', serif;
}

h1, h2, h3, h4 {
    font-weight: 400!important;
    line-height: 1.6;
}

.bg-color-ltbl {
    background-color: #f3f5fa;
}
.bg-color-rd {
    background-color: #a10d29;
}
.bg-color-bl {
    background-color: #21489d;
}
.bg-color-gy {
    background-color: #f3f3f3; 
}
.bg-color-bg {
    background-color: #f4f2ee; 
}

.ft-color-wh {
    color: #fff;
}
.ft-color-rd {
    color: #a10d29;
}
.ft-color-bl {
    color: #21489d;
}
.ft-size-s {
    font-size: 0.8rem;
}
.ft-size-m {
    font-size: 1.15rem;
}
.ft-size-l {
    font-size: 1.25rem;
}
.ft-size-xl {
    font-size: 1.45rem;
}
.ft-size-xxl {
    font-size: 1.8rem;
}
.txt-left {
    text-align: left;
}
.txt-right {
    text-align: right;
}
.txt-center {
    text-align: center;
}
.notes {
    font-size: 0.8rem;
    line-height: 1.8;
}

.div-2 {
    width: calc(50% - 15px);
}
.div-3 {
    width: calc(33.33% - 20px);
}
.div-4 {
    width: calc(25% - 15px);
}

.flexbox {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    margin-bottom: 70px;
}
.flexbox-txt {
    padding: 30px;
    box-sizing: border-box;
}
.flexbox-txt h3 {
    font-size: 1.45rem;
    margin-bottom: 20px;
    font-weight: 600 !important;
    letter-spacing: 0.03rem;
}
.flexbox-txt h3 span {
    font-size: 0.8rem;
}
.flexbox-txt ul li {
    position: relative;
    padding-left: 1rem;
}
.flexbox-txt ul li::after {
    content: "■";
    position: absolute;
    top: 0;
    left: 0;
    line-height: 1.4;
    color: #21489d;
}

.price-sim-cv p {
    position: relative;
    font-size: 1.35rem;
    color: #780013;
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.05rem;
    padding: 10px;
    background-color: #fff;
    transition: all 0.3s ease;
}
.price-sim-cv p::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%);
    width: 26px;
    height: 26px;
    background: url(../img/price-sim-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.price-sim-cv a {
    display: block;
    padding: 15px 90px;
    background-color: #780013;
    box-sizing: border-box;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}


/* 01 intro */
.intro .intro-cont {
    position: relative;
    padding: 50px;
    background: url(../img/sec01_bg01.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.intro .intro-cont::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: 20px;
    width: 330px;
    height: 479px;
    background: url(../img/sec01_img01.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.intro .intro-cont .box-txt {
    max-width: 570px;
    font-size: 1.35rem;
    line-height: 1.6;
}
.intro .intro-cont .box-txt .txt1 {
    font-weight: 600!important;
    margin-bottom: 20px;
}
.intro .intro-cont .box-txt .txt2 {
    font-weight: 500!important;
    margin-bottom: 10px;
}
.intro .intro-cont .box-txt .txt2 span {
    font-size: 0.8rem;
}
.intro .intro-cont .box-txt .txt2:last-of-type {
    margin-bottom: 0;
}
.intro .intro-cont .box-txt h3 {
    font-size: 2.1rem;
    font-weight: 600!important;
    line-height: 1.45;
    border-bottom: 2px solid #000;
    margin-bottom: 30px;
}
.intro .intro-cont .box-txt .tab {
    display: inline-block;
    height: 28px;
    font-size: 1.6rem;
    color: #21489d;
    line-height: 1.1;
    letter-spacing: 0.05rem;
    border-bottom: 4px solid #21489d;
    margin-bottom: 10px;
}


/* 02 point */
.point .flexbox-txt {
    position: relative;
}
.point .flexbox-txt .tab {
    position: absolute;
    top: -34px;
    left: 0;
    height: 34px;
    font-size: 2.3rem;
    color: #21489d;
    letter-spacing: 0.05rem;
    border-bottom: 5px solid #21489d;
}
.point .flexbox-txt .point-spec p {
    position: relative;
    padding-left: 85px;
    margin-bottom: 10px;
}
.point .flexbox-txt .point-spec p:last-child {
    margin-bottom: 0;
}
.point .flexbox-txt .point-spec p .spec {
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    left: 0;
    width: 70px;
    height: 100%;
    line-height: 1.2;
    text-align: center;
    padding: 8px;
    border: 1px solid #21489d;
    background-color: #fff;
    box-sizing: border-box;
}
.point .flexbox-txt .point-spec p a {
    display: block;
    width: 170px;
    color: #fff;
    line-height: 1;
    text-align: center;
    padding: 8px;
    margin-top: 5px;
    background-color: #21489d;
}
.point .flexbox-img div {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin-top: 20px;
}
.point .flexbox-img div p {
    width: calc(50% - 10px);
    text-align: center;
}
.point .flexbox-img div p span {
    display: block;
    color: #fff;
    line-height: 1;
    padding: 8px;
    margin-bottom: 10px;
    background-color: #8fa3ce;
}


/* 03 house-tour */
.house-tour .house-tour-cont {
    margin-bottom: 70px;
}
.cont_title {
    font-weight: 600 !important;
    line-height: 1.45;
    text-align: center;
    margin-bottom: 40px;
    padding: 14px 20px 10px;
    font-size: 31px;
    letter-spacing: 0.05em;
}
.house-tour .house-tour-cont img {
    margin-bottom: 70px;
}
.house-tour .house-tour-cont .prop-ov {
    text-align: center;
    margin-bottom: 70px;
}
.house-tour .house-tour-cont .prop-ov p {
    font-size: 1.15rem;
}
.house-tour .house-tour-cont .prop-ov-btn {
    position: relative;
    max-width: 490px;
    line-height: 1;
    text-align: center;
    margin: 20px auto 0;
    background-color: #79796f;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .prop-ov-btn::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    width: 29px;
    height: 29px;
    background: url(../img/prop-ov-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.house-tour .house-tour-cont .prop-ov-btn a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.15rem;
    color: #fff;
    font-weight: 600;
    padding: 30px;
    box-sizing: border-box;
}
.house-tour .house-tour-cont .prop-ov-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .house-tour-cv {
    position: relative;
    max-width: 490px;
    line-height: 1;
    text-align: center;
    margin: 0 auto;
    background-color: #a10d29;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .house-tour-cv::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    width: 29px;
    height: 29px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.house-tour .house-tour-cont .house-tour-cv a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.15rem;
    color: #fff;
    font-weight: 600;
    padding: 30px;
    box-sizing: border-box;
}
.house-tour .house-tour-cont .house-tour-cv::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .flexbox .flexbox-img {
    overflow: hidden;
}
.house-tour .house-tour-cont .flexbox .flexbox-img img {
    margin-bottom: 0;
}
.house-tour .house-tour-cont .flexbox .flexbox-img .slider2 div {
    width: 475px;
    padding: 0!important;
    box-sizing: border-box;
}
.house-tour .house-tour-cont .date-event {
    font-size: 1.8rem;
    font-weight: 600 !important;
    line-height: 1.4;
    text-align: center;
    margin-bottom: 30px;
}
.house-tour .house-tour-cont .date-event span {
    font-size: 1.25rem;
}
.house-tour .house-tour-cont .venue-event {
    font-size: 1.25rem;
    font-weight: 600 !important;
    text-align: center;
    padding: 10px;
    margin-top: 30px;
    background-color: #fff;
    border-radius: 30px;
}


/* 04 plan*/
.mitsuihome-select {
    max-width: 380px;
    text-align: center;
    margin: 0 auto 110px;
}
.mitsuihome-select h2 {
    font-size: 2.1rem;
    font-weight: 600 !important;
    line-height: 1.45;
    text-align: center;
    border-bottom: 2px solid #000;
    padding-bottom: 8px;
    margin-bottom: 25px;
}
.mitsuihome-select img {
    max-width: 90%;
    margin: 0 auto;
}

.plan h2.sec_title {
    position: relative;
    font-size: 3.4rem;
    line-height: 1;
    margin-bottom: 50px;
}
.plan h2.sec_title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(100% - 190px);
    height: 1px;
    background-color: #21489d;
}
.plan .sec_leadcopy {
    font-size: 1.45rem;
    line-height: 1.8;
    margin-bottom: 50px;
}
.plan .plan-floor {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 70px;
}
.plan .plan-floor .box-left,
.plan .plan-floor .box-right {
    padding: 10px 20px;
    box-sizing: border-box;
}
.plan .plan-floor .box-left {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 200px;
    font-size: 1.25rem;
    color: #fff;
    text-align: center;
}
.plan .plan-floor .box-right {
    width: calc(100% - 200px);
}
.plan .plan-cont {
    margin-bottom: 70px;
}
.plan .plan-cont h3 {
    font-size: 2.3rem;
    line-height: 1;
    margin-bottom: 40px;
}
.plan .plan-cont h3 span {
    font-size: 0.9rem;
}
.plan .plan-cont p {
    margin-bottom: 50px;
}
.plan .plan-cont img {
    margin-bottom: 10px;
}
.plan .plan-cont.box-img {
    padding: 70px;
    box-sizing: border-box;
}


/* 05 sim */
.sim h2.sec_title {
    position: relative;
    font-size: 3.4rem;
    line-height: 1;
    margin-bottom: 50px;
}
.sim h2.sec_title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(100% - 380px);
    height: 1px;
    background-color: #21489d;
}
.sim .sec_leadcopy {
    font-size: 1.45rem;
    line-height: 1.8;
    margin-bottom: 50px;
}
.sim .sim-cont .box-img {
    padding: 40px;
    margin-bottom: 50px;
    box-sizing: border-box;
}


/* 06 spec */
.spec h2.sec_title {
    position: relative;
    font-size: 3.4rem;
    line-height: 1;
    margin-bottom: 50px;
}
.spec h2.sec_title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(100% - 440px);
    height: 1px;
    background-color: #21489d;
}
.spec .sec_leadcopy {
    font-size: 1.45rem;
    line-height: 1.8;
    margin-bottom: 50px;
}

.spec .spec-cont dl {
    margin-bottom: 20px;
    overflow: hidden;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.spec .spec-cont dl:last-of-type {
    margin-bottom: 70px;
}
.spec .spec-cont dl dt {
    cursor: pointer;
}
.spec .spec-cont dl dt.term {
    position: relative;
    font-size: 1.25rem;
    color: #fff;
    line-height: 1.1;
    padding: 30px;
    background-color: #21489d;
}
.spec .spec-cont dl:nth-last-child(-n+5) dt.term {
    color: #21489d;
    border: 1px solid #21489d;
    background-color: #fff;
}
.spec .spec-cont dl dt.term::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translateY(-50%);
    width: 2px;
    height: 21px;
    background-color: #fff;
    transition: all 0.3s ease;
}
.spec .spec-cont dl dt.term::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%);
    width: 21px;
    height: 2px;
    background-color: #fff;
    transition: all 0.3s ease;
}
.spec .spec-cont dl:nth-last-child(-n+5) dt.term::before,
.spec .spec-cont dl:nth-last-child(-n+5) dt.term::after {
    background-color: #21489d;
}
.spec .spec-cont dl dt.term.open::before {
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
}
.spec .spec-cont dl dd.desc {
    display: none;
    position: relative;
    padding: 50px;
    background-color: #fff;
}
.spec .spec-cont dl dd.desc .tab {
    display: inline-block;
    height: 34px;
    font-size: 2.3rem;
    color: #21489d;
    letter-spacing: 0.05rem;
    margin-bottom: 30px;
    border-bottom: 5px solid #21489d;
}
.spec .spec-cont dl dd.desc .flexbox {
    margin-bottom: 0;
}
.spec .spec-cont dl dd.desc h3 {
    display: inline-block;
    font-size: 1.45rem;
    font-weight: 600!important;
    border-bottom: 2px solid #21489d;
    margin-bottom: 30px;
}
.spec .spec-cont dl dd.desc.desc-box p {
    margin-bottom: 30px;
}
.spec .spec-cont dl dd.desc.desc-box img {
    display: block;
    width: auto;
    margin: 0 auto 30px;
}
.spec .spec-cont dl dd.desc.desc-box .label-1 {
    width: 300px;
    font-size: 1.15rem;
    color: #21489d;
    text-align: center;
    padding: 8px;
    margin: 0 auto 30px;
    border: 1px solid #21489d;
}
.spec .spec-cont dl dd.desc.desc-box .label-2 {
    width: 300px;
    font-size: 1.15rem;
    color: #106d52;
    text-align: center;
    padding: 8px;
    margin: 0 auto 30px;
    background-color: #d4d857;
}


/* 07 suggest */
.suggest .suggest-cont1 {
    position: relative;
    text-align: center;
    padding: 50px;
    margin-bottom: 50px;
    background: url(../img/sec07_bg01.jpg) no-repeat;
    background-size: 100%;
    background-position: top center;
}
.suggest .suggest-cont1 .box-txt h3 {
    font-size: 2.6rem;
    font-weight: 600!important;
    line-height: 1.45;
    margin-bottom: 20px;
}
.suggest .suggest-cont1 .box-txt .txt1 {
    font-size: 1.9rem;
    font-weight: 600!important;
    line-height: 1.45;
    margin-bottom: 40px;
}
.suggest .suggest-cont1 .box-txt .img1 {
    max-width: 490px;
    margin-bottom: 20px;
}
.suggest .suggest-cont1 .box-txt .img2 {
    max-width: 600px;
    margin-bottom: 40px;
}

.suggest .suggest-cont2 {
    position: relative;
    padding: 50px;
    background: url(../img/sec07_bg02.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.suggest .suggest-cont2::after {
    content: "";
    position: absolute;
    bottom: 0;
    right: -40px;
    width: 590px;
    height: 426px;
    background: url(../img/sec07_img04.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.suggest .suggest-cont2 .box-txt {
    max-width: 490px;
    text-align: center;
}
.suggest .suggest-cont2 .box-txt img {
    margin-bottom: 30px;
}
.suggest .suggest-cont2 .box-txt .txt1 {
    font-size: 1.25rem;
    font-weight: 600!important;
    margin-bottom: 20px;
}
.suggest .suggest-cont2 .box-txt h3 {
    font-size: 2.1rem;
    font-weight: 600!important;
    line-height: 1.45;
    margin-bottom: 50px;
}
.suggest .suggest-cont2 .box-txt .suggest-cv {
    position: relative;
    max-width: 440px;
    line-height: 1.6;
    text-align: center;
    margin: 0 auto;
    background-color: #a10d29;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    z-index: 5;
    transition: all 0.3s ease;
}
.suggest .suggest-cont2 .box-txt .suggest-cv::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.suggest .suggest-cont2 .box-txt .suggest-cv a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.15rem;
    color: #fff;
    font-weight: 600;
    padding: 15px;
    box-sizing: border-box;
}


/* 08 voice */
.voice h2.sec_title {
    position: relative;
    font-size: 3.4rem;
    line-height: 1;
    margin-bottom: 50px;
}
.voice h2.sec_title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(100% - 210px);
    height: 1px;
    background-color: #21489d;
}
.voice .sec_leadcopy {
    font-size: 1.45rem;
    line-height: 1.8;
    margin-bottom: 50px;
}

.voice .flexbox-txt h3 {
    text-align: center;
}
.voice .flexbox-txt strong {
	background: linear-gradient(transparent 60%, #fce7ac 60%);
}


/* 09 faq */
.faq {
    margin-bottom: 70px;
    background-color: #f4f2ee; 
}
.faq .container {
    padding: 70px 0;
}
.faq h2.sec_title {
    position: relative;
    font-size: 3.4rem;
    line-height: 1;
    margin-bottom: 50px;
}
.faq h2.sec_title::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: calc(100% - 140px);
    height: 1px;
    background-color: #21489d;
}
.faq .sec_leadcopy {
    font-size: 1.45rem;
    line-height: 1.8;
    margin-bottom: 50px;
}

.faq .faq-cont dl {
    margin-bottom: 20px;
    overflow: hidden;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.faq .faq-cont dl:last-of-type {
    margin-bottom: 0;
}
.faq .faq-cont dl dt {
    cursor: pointer;
}
.faq .faq-cont dl dt.term {
    position: relative;
    font-size: 1.25rem;
    color: #fff;
    line-height: 1.1;
    padding: 30px;
    background-color: #79796f;
}
.faq .faq-cont dl dt.term::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 40px;
    transform: translateY(-50%);
    width: 2px;
    height: 21px;
    background-color: #fff;
    transition: all 0.3s ease;
}
.faq .faq-cont dl dt.term::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%);
    width: 21px;
    height: 2px;
    background-color: #fff;
    transition: all 0.3s ease;
}
.faq .faq-cont dl dt.term.open::before {
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
}
.faq .faq-cont dl dt.term p {
    position: relative;
    padding-left: 30px;
}
.faq .faq-cont dl dt.term p::after {
    content: "Q.";
    position: absolute;
    top: 0;
    left: 0;
    font-size: 1.25rem;
    color: #fff;
}
.faq .faq-cont dl dd.desc {
    display: none;
    position: relative;
    padding: 30px;
    border: 1px solid #79796f;
    background-color: #fff;
}
.faq .faq-cont dl dd.desc p {
    position: relative;
    padding-left: 25px;
}
.faq .faq-cont dl dd.desc p::after {
    content: "A.";
    position: absolute;
    top: 0;
    left: 0;
    font-family: 'Times New Roman', '游明朝', 'Yu Mincho', '游明朝体', 'YuMincho', 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'HiraMinProN-W3', 'ＭＳ Ｐ明朝', serif;
    font-size: 1.25rem;
    color: #79796f;
}


/* 10 nav */
.nav {
    margin-bottom: 0;
}
.nav .nav-cont {
    width: 100%;
    height: 90px;
    padding: 30px 0;
    margin-bottom: 50px;
    border-top: 1px solid #a9a9a9;
    border-bottom: 1px solid #a9a9a9;
    box-sizing: border-box;
}
.nav .nav-cont ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
}
.nav .nav-cont ul li:not(:last-child) {
    border-right: 1px solid #a9a9a9;
    padding-right: 25px;
    margin-right: 25px;
}
.nav .nav-cont ul li a {
    position: relative;
    transition: all 0.3s ease;
}
.nav .nav-cont ul li a::after {
    content: "";
    position: absolute;
    bottom: -4px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 2px;
    background-color: #a10d29;
    transition: all 0.3s ease;
}
.nav .nav-cont ul li a:hover {
    opacity: 1;
}
.nav .flexbox {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 100vw;
    padding: 30px 0;
    margin: 0 calc(50% - 50vw);
    background-color: #a10d29;
}
.nav .flexbox div {
    position: relative;
    max-width: 320px;
    font-size: 1.25rem;
    font-weight: 600;
    background-color: #fff;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.nav .flexbox div::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 10px;
    height: 10px;
    border-top: 2px solid #a10d29;
    border-right: 2px solid #a10d29;
    transition: all 0.3s ease;
}
.nav .flexbox div.tel::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    width: 33px;
    height: 33px;
    background: url(../img/icon-tel2.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.nav .flexbox div.reserve::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 20px;
    transform: translateY(-50%);
    width: 33px;
    height: 33px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.nav .flexbox div a {
    display: block;
    text-align: center;
    padding: 20px;
    box-sizing: border-box;
}
.nav .flexbox div a:hover {
    opacity: 1;
}


/* header */
.header {
    position: fixed;
    top: 0;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    background-color: rgba(255, 255, 255, 0.85);
    z-index: 9999;
}
.header .container {
    max-width: 1200px;
}
.header .content {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
    height: 90px;
    margin: 0 auto;
    column-gap: 30px;
}
.header .content .logo {
    width: 160px;
    margin: 0 auto 0 0;
}
.header .content .header-cv {
    display: flex;
    flex-wrap: wrap;
    width: 460px;
    gap: 15px;
}
.header .content .header-cv div {
    position: relative;
    width: calc(50% - 7.5px);
    line-height: 1.4;
    text-align: center;
    background-color: #a10d29;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.header .content .header-cv div::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.header .content .header-cv div.tel::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/icon-tel1.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.header .content .header-cv div.reserve::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.header .content .header-cv div a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.08rem;
    color: #fff;
    font-weight: 600;
    padding: 16px 16px 16px 34px;
    box-sizing: border-box;
}


/* top-kv */
.top-kv {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 30px;
}
.top-kv .container {
    position: relative;
    max-width: 100%;
    height: 100%;
    margin-top: 90px;
    background: url(../img/top-kv_pc.jpg) no-repeat;
    background-size: cover;
    background-position: center;
}
.top-kv .content {
    position: relative;
    width: 100%;
    height: 630px;
    z-index: 5;
}
.top-kv .content .kv-mhlogo {
    position: absolute;
    top: 30px;
    right: 30px;
    width: 270px;
    height: 46px;
    padding: 15px;
    background-color: rgba(255, 255, 255, 1);
    border-radius: 10px;
    box-sizing: border-box;
}
.top-kv .content .kv-title {
    position: absolute;
    top: 42%;
    z-index: 5;
    width: 100%;
    text-align: center;
}
.top-kv .content .kv-title h1 {
    font-family: 'TsukuGoPro-B', 'ヒラギノ角ゴ Pro','Hiragino Kaku Gothic Pro','メイリオ','Meiryo','游ゴシック','Yu Gothic','ＭＳ Ｐゴシック',sans-serif!important;
    font-size: 50px;
    font-weight: 600!important;
    color: #fff;
    line-height: 1.4;
    filter: drop-shadow(0 0 10px rgb(0, 0, 0, 0.5));
}
.top-kv .content .kv-area {
    position: absolute;
    color: #fff;
    border: 2px solid #fff;
    padding: 10px;
    line-height: 1;
    font-size: 26px;
    font-weight: bold;
    top: 35px;
    left: 35px;
}
.top-kv .cp-bnr {
    margin: 20px auto 30px;
    /*width: 51.04%;*/
    max-width: 880px;
    z-index: 1;
    position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 15px 26px;
}
.top-kv .cp-bnr a {
    display: block;
    transition: opacity 0.3s;
	width: 100%;
}
.top-kv .cp-bnr .col_2 {
	width: calc(50% - 13px);
}
.top-kv .cp-bnr a:hover {
    opacity: .7;
}

.float-btn {
    z-index: 10;
    right: 4%;
    bottom: 30px;
    box-shadow: 0 0 15px rgba(0,0,0,.5);
    border-radius: 11px;
    overflow: hidden;
    position: absolute;
    width: 18.59%;
    max-width: 254px;
}
.float-btn a {
    display: block;
    transition: 0.3s;
}
.float-btn a:hover {
    opacity: .7;
}

/* slider */
.lineup {
    max-width: 980px;
    padding-top: 10px;
    margin: -90px auto 0;
    overflow: hidden;
}
.lineup .slider1 .slick-list {
    overflow: visible;
}
.lineup .slider1 div img {
    width: 240px;
    margin: 0 7.5px;
    transition: all 0.3s ease;
}


/* footer */
.footer {
    border-top: 1px solid #e4e4e4;
}
.footer .container {
    text-align: center;
    padding: 110px 0;
}
.footer .content .logo {
    width: 210px;
    margin: 0 auto 40px;
}


/* page top */
.page-top a {
    position: fixed;
    z-index: 999;
    width: 50px;
    height: 50px;
    background: #808080;
    border-radius: 50%;
    transition-duration: 0.3s;
}
.page-top a:before {
    content: "";
    width: 10px;
    height: 10px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    position: absolute;
    top: 21px;
    left: 19px;
}
@media screen and (max-width: 768px) {
    .page-top a {
        right: 13px;
        bottom: 13px;
    }
}
@media screen and (min-width: 769px) {
    .page-top a {
        right: 20px;
        bottom: 20px;
    }
}


/* floating */
.floating {
    position: fixed;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    transition: all 0.3s ease;
    z-index: 999;
}
.floating ul {
    display: flex;
    flex-flow: column;
}
.floating ul li a {
    display: flex;
}
.floating ul li p {
    display: flex;
    justify-content: center;
    align-items: center;
    width: calc(100% - 55px);
    padding: 10px;
    box-sizing: border-box;
}
.floating ul li {
    height: 55px;
    font-size: 0.85rem;
    line-height: 1.2;
    text-align: center;
    margin-bottom: 2px;
    background-color: #f3f2ef;
    transition: all 0.3s ease;
}
.floating ul li:last-child {
    position: relative;
    height: 25px;
    background-color: #e8e6df;
    transition: all 0.3s ease;
}
.floating ul li:last-child::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%) rotate(45deg);
    width: 6px;
    height: 6px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    transition: all 0.3s ease;
}
.floating ul li .icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 55px;
    height: 55px;
    background-color: #e8e6df;
    transition: all 0.3s ease;
}
.floating ul li .icon img {
    width: 25px;
    height: 25px;
}

.floating.active {
    margin-right: -156px;
}
.floating.active ul li:last-child::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 25px;
    transform: translateY(-50%) rotate(225deg);
    width: 6px;
    height: 6px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
}


@media screen and (max-width: 880px) {
    .header .content .header-cv {
        width: 400px;
    }
    .header .content .header-cv div a {
        font-size: 14px;
    }
    .header .content .logo {
        width: 140px;
    }
    .header .content .logo-mfd {
        width: 170px;
    }
}

@media screen and (min-width: 769px) {
    .price-sim-cv a:hover {
        padding: 12px 87px;
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .price-sim-cv a:hover p {
        padding: 13px;
    }
    
    /* 03 house-tour */
    .house-tour .house-tour-cont .prop-ov-btn:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .house-tour .house-tour-cont .prop-ov-btn:hover::after {
        right: 22px;
    }
    .house-tour .house-tour-cont .house-tour-cv:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .house-tour .house-tour-cont .house-tour-cv:hover::after {
        right: 22px;
    }
    
    /* 06 spec */
    .spec .spec-cont dl:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    
    /* 07 suggest */
    .suggest .suggest-cont2 .box-txt .suggest-cv:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .suggest .suggest-cont2 .box-txt .suggest-cv:hover:after {
        right: 22px;
    }

    /* 09 faq */
    .faq .faq-cont dl:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    
    /* 10 nav */
    .nav .nav-cont ul li a:hover::after {
        width: 100%;
        height: 2px;
    }
    .nav .nav-cont ul li a:hover {
        color: #a10d29;
    }
    .nav .flexbox div:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .nav .flexbox div:hover::before {
        right: 17px;
    }
    .nav .flexbox div a:hover {
        color: #a10d29;
    }

    /* slider */
    .lineup .slider1 div img:hover {
        margin-top: -10px;
    }

    /* header */
    .header .content .header-cv div:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .header .content .header-cv div:hover::before {
        right: 17px;
    }
    
    /* floating */
    .floating ul li:hover {
        background-color: #f9f8f7;
    }
    .floating ul li:hover .icon {
        background-color: #f3f2ef;
    }
    .floating ul li:last-child:hover {
        background-color: #f3f2ef;
    }
}


@media screen and (max-width: 768px) {
    section {
        margin-bottom: 40px;
        overflow: hidden;
    }
    .div-2 {
        width: 100%;
    }
    .flexbox {
        display: block;
        gap: 20px;
        margin-bottom: 40px;
    }
    .flexbox-txt {
        padding: 20px;
    }
    .price-sim-cv p {
        font-size: 1.15rem;
        line-height: 1.4;
    }
    .price-sim-cv p::before {
        display: none;
    }
    .price-sim-cv a {
        display: block;
        padding: 10px;
        background-color: #780013;
        box-sizing: border-box;
    }


    /* 01 intro */
    .intro .container {
        padding: 0 20px;
    }
    .intro .intro-cont {
        width: 100vw;
        padding: 40px 20px;
        margin: 0 calc(50% - 50vw);
        box-sizing: border-box;
    }
    .intro .intro-cont::after {
        display: none;
    }
    .intro .intro-cont .box-txt {
        max-width: 100%;
        font-size: 1.15rem;
    }
    .intro .intro-cont .box-txt h3 {
        font-size: 1.65rem;
        margin-bottom: 20px;
    }


    /* 02 point */
    .point .container {
        padding: 0 20px;
    }
    .point .flexbox-txt .tab {
        top: -32px;
        height: 28px;
        font-size: 1.6rem;
        border-bottom: 4px solid #21489d;
        margin-bottom: 20px;
    }
    .point .flexbox {
        margin-top: 60px;
        margin-bottom: 40px;
    }
    .point .flexbox:last-of-type {
        margin-top: 60px;
        margin-bottom: 0;
    }
    .point .flexbox .flexbox-txt h3 {
        font-size: 1.25rem;
    }
    .point .flexbox .flexbox-txt .point-spec p .spec {
        width: 60px;
    }
    .point .flexbox .flexbox-txt .point-spec p {
        padding-left: 75px;
    }
    .point .flexbox .flexbox-img img {
        width: 100%;
        height: 250px;
        object-fit: cover;
    }

    
    /* 03 house-tour */
    .house-tour .container {
        padding: 0;
    }
    .house-tour .house-tour-cont {
        margin-bottom: 40px;
    }
    .cont_title {
        font-size: calc(17 / 375 * 100vw);
        line-height: 1.6;
        margin-bottom: 30px;
    }
    .house-tour .container .cont_title {
        margin: 0 20px 30px;
    }
    .house-tour .house-tour-cont img {
        width: 100%;
        margin-bottom: 40px;
    }
    .house-tour .house-tour-cont .prop-ov {
        margin-bottom: 40px;
    }
    .house-tour .house-tour-cont .prop-ov-btn::before {
        width: 25px;
        height: 25px;
    }
    .house-tour .house-tour-cont .prop-ov-btn a {
        font-size: 1.15rem;
    }
    .house-tour .house-tour-cont .prop-ov-btn:after {
        right: 20px;
        width: 8px;
        height: 8px;
    }
    .house-tour .house-tour-cont .flexbox .flexbox-img .slider2 div {
        width: 100%;
        height: 250px;
        object-fit: cover;
    }
    .house-tour .house-tour-cont .date-event {
        /* font-size: 1.65rem; */
        font-size: min(5.9vw, 1.65rem);
        margin-bottom: 20px;
    }
    .house-tour .house-tour-cont .date-event span {
        font-size: 1.15rem;
    }
    .house-tour .house-tour-cont .venue-event {
        font-size: 1.15rem;
        margin-top: 20px;
    }

    .house-tour .house-tour-cont .house-tour-cv {
        position: relative;
        max-width: 490px;
        line-height: 1;
        text-align: center;
        margin: 0 auto;
        background-color: #a10d29;
        box-sizing: border-box;
        border-radius: 10px;
    }
    .house-tour .house-tour-cont .house-tour-cv::before {
        width: 25px;
        height: 25px;
    }
    .house-tour .house-tour-cont .house-tour-cv a {
        font-size: 1.15rem;
    }
    .house-tour .house-tour-cont .house-tour-cv:after {
        right: 20px;
        width: 8px;
        height: 8px;
    }


    /* 04 plan*/
    .mitsuihome-select {
        max-width: 100%;
        text-align: center;
        margin: 0 auto 40px;
    }
    .mitsuihome-select h2 {
        font-size: 1.65rem;
        margin-bottom: 20px;
    }
    .mitsuihome-select img {
        max-width: 280px;
        margin: 0 auto;
    }

    .plan .container {
        padding: 0 20px;
    }
    .plan h2.sec_title {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }
    .plan h2.sec_title::after {
        width: calc(100% - 120px);
    }
    .plan .sec_leadcopy {
        font-size: 1.15rem;
        margin-bottom: 30px;
    }
    .plan .plan-floor {
        margin-bottom: 40px;
    }
    .plan .plan-floor .box-left,
    .plan .plan-floor .box-right {
        padding: 15px;
    }
    .plan .plan-floor .box-left {
        width: 100%;
        font-size: 1.15rem;
        line-height: 1.1;
    }
    .plan .plan-floor .box-right {
        width: 100%;
    }
    .plan .plan-cont {
        margin-bottom: 40px;
    }
    .plan .plan-cont:last-of-type {
        margin-bottom: 20px!important;
    }
    .plan .plan-cont h3 {
        font-size: 1.85rem;
        line-height: 1;
        margin-bottom: 30px;
    }
    .plan .plan-cont h3 span {
        font-size: 0.9rem;
    }
    .plan .plan-cont p {
        margin-bottom: 40px;
        text-align: left;
    }
    .plan .plan-cont.box-img {
        padding: 20px;
    }


    /* 05 sim */
    .sim .container {
        padding: 0 20px;
    }
    .sim h2.sec_title {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }
    .sim h2.sec_title::after {
        width: calc(100% - 260px);
    }
    .sim .sec_leadcopy {
        font-size: 1.15rem;
        margin-bottom: 30px;
    }
    .sim .sim-cont .box-img {
        padding: 0;
        margin-bottom: 40px;
    }


    /* 06 spec */
    .spec .container {
        padding: 0 20px;
    }
    .spec h2.sec_title {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }
    .spec h2.sec_title::after {
        width: calc(100% - 310px);
    }
    .spec .sec_leadcopy {
        font-size: 1.15rem;
        margin-bottom: 30px;
    }
    .spec .spec-cont dl {
        margin-bottom: 10px;
    }
    .spec .spec-cont dl:last-of-type {
        margin-bottom: 20px;
    }
    .spec .spec-cont dl dt.term {
        font-size: 1rem;
        padding: 20px;
    }
    .spec .spec-cont dl dt.term::before {
        right: 27px;
        height: 16px;
    }
    .spec .spec-cont dl dt.term::after {
        right: 20px;
        width: 16px;
    }
    .spec .spec-cont dl dd.desc {
        padding: 20px;
    }
    .spec .spec-cont dl dd.desc .tab {
        height: 28px;
        font-size: 1.6rem;
        border-bottom: 4px solid #21489d;
        margin-bottom: 20px;
    }
    .spec .spec-cont dl dd.desc h3 {
        font-size: 1.25rem;
        margin-bottom: 20px;
    }
    .spec .spec-cont dl dd.desc.desc-box p {
        margin-bottom: 20px;
    }
    .spec .spec-cont dl dd.desc.desc-box img {
        margin: 0 auto 30px;
    }
    .spec .spec-cont dl dd.desc.desc-box .label-1,
    .spec .spec-cont dl dd.desc.desc-box .label-2 {
        width: 210px;
        font-size: 1rem;
        padding: 6px;
        margin: 0 auto 20px;
    }
    .spec .spec-cont dl dd.desc.desc-box img.sec06_logo {
        width: 180px;

    }


    /* 07 suggest */
    .suggest .container {
        padding: 0 20px;
    }
    .suggest .suggest-cont1 {
        width: 100vw;
        padding: 40px 20px 0;
        margin: 0 calc(50% - 50vw) 40px;
        box-sizing: border-box;
    }
    .suggest .suggest-cont1 .box-txt h3 {
        font-size: 1.85rem;
        margin-bottom: 20px;
    }
    .suggest .suggest-cont1 .box-txt .txt1 {
        font-size: 1.35rem;
        line-height: 1.6;
        margin-bottom: 30px;
    }
    .suggest .suggest-cont1 .box-txt .img2 {
        max-width: 100%;
        margin-bottom: 20px;
    }

    .suggest .suggest-cont2 {
        width: 100vw;
        padding: 40px 20px;
        margin: 0 calc(50% - 50vw) 40px;
        box-sizing: border-box;
    }
    .suggest .suggest-cont2::after {
        display: none;
    }
    .suggest .suggest-cont2 .box-txt {
        max-width: 100%;
    }
    .suggest .suggest-cont2 .box-txt img {
        margin-bottom: 30px;
    }
    .suggest .suggest-cont2 .box-txt .txt1 {
        font-size: 1.35rem;
    }
    .suggest .suggest-cont2 .box-txt h3 {
        font-size: 1.85rem;
        margin-bottom: 40px;
    }
    .suggest .suggest-cont2 .box-txt .suggest-cv {
        max-width: 100%;
    }
    .suggest .suggest-cont2 .box-txt .suggest-cv:after {
        right: 20px;
        width: 8px;
        height: 8px;
    }
    .suggest .suggest-cont2 .box-txt .suggest-cv a {
        font-size: 1rem;
        padding: 15px;
    }


    /* 08 voice */
    .voice .container {
        padding: 0 20px;
    }
    .voice h2.sec_title {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }
    .voice h2.sec_title::after {
        width: calc(100% - 140px);
    }
    .voice .sec_leadcopy {
        font-size: 1.15rem;
        margin-bottom: 30px;
    }
    .voice .flexbox:last-of-type {
        margin-bottom: 0;
    }
    .voice .flexbox .flexbox-img {
        margin-bottom: 30px;
    }
    .voice .flexbox .flexbox-img img {
        width: 100%;
        height: 250px;
        object-fit: cover;
    }
    .voice .flexbox .flexbox-txt {
        padding: 0!important;
    }
    .voice .flexbox .flexbox-txt h3 {
        font-size: 1.15rem;
    }


    /* 09 faq */
    .faq {
        margin-bottom: 40px;
    }
    .faq .container {
        padding: 40px 20px;
    }
    .faq h2.sec_title {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }
    .faq h2.sec_title::after {
        width: calc(100% - 100px);
    }
    .faq .sec_leadcopy {
        font-size: 1.15rem;
        margin-bottom: 30px;
    }

    .faq .faq-cont dl {
        margin-bottom: 10px;
    }
    .faq .faq-cont dl dt.term {
        padding: calc(20 / 375 * 100vw) calc(40 / 375 * 100vw) calc(20 / 375 * 100vw) calc(20 / 375 * 100vw);
        font-size: calc(16 / 375 * 100vw);
        line-height: 1.4;
    }
    .faq .faq-cont dl dt.term::before {
        right: 27px;
        height: 16px;
    }
    .faq .faq-cont dl dt.term::after {
        right: 20px;
        width: 16px;
    }
    .faq .faq-cont dl dt.term p,
    .faq .faq-cont dl dd.desc p {
        padding-left: calc(25 / 375 * 100vw);
    }
    .faq .faq-cont dl dt.term p::after,
    .faq .faq-cont dl dd.desc p::after {
        font-size: calc(18 / 375 * 100vw);
        line-height: 1.2;
    }
    .faq .faq-cont dl dd.desc {
        padding: 20px;
    }


    /* 10 nav */
    .nav .container {
        padding: 0 20px;
    }
    .nav .nav-cont {
        height: auto;
        padding: 0;
        margin-bottom: 0;
        border-top: 0;
        border-bottom: 0;
    }
    .nav .nav-cont ul {
        width: 100vw;
        margin: 0 calc(50% - 50vw);
        border-top: 1px solid #a9a9a9;
    }
    .nav .nav-cont ul li {
        width: 50%;
        font-size: 0.85rem;
        text-align: center;
        padding: 8px!important;
        margin: 0!important;
        border-bottom: 1px solid #a9a9a9;
        box-sizing: border-box;
    }
    .nav .nav-cont ul li:nth-child(2n) {
        border-right: 0;
    }
    .nav .nav-cont ul li:nth-last-child(-n+2) {
        border-bottom: 0;
    }
    .nav .flexbox {
        gap: 15px;
        padding: 20px;
        box-sizing: border-box;
    }
    .nav .flexbox div {
        max-width: 100%;
        width: 100%;
        font-size: 1.15rem;
        line-height: 1.1;
    }
    .nav .flexbox div::before {
        width: 8px;
        height: 8px;
    }
    .nav .flexbox div.tel::after {
        left: 15px;
        width: 28px;
        height: 28px;
    }
    /* .nav .flexbox div.online::after {
        left: 15px;
        width: 28px;
        height: 28px;
    } */
    .nav .flexbox div.reserve::after {
        left: 15px;
        width: 28px;
        height: 28px;
    }


    /* header */
    .header {
        background-color: rgba(255, 255, 255, 0.85);
    }
    .header .container {
        padding: 0 20px;
    }
    .header .content {
        width: 100%;
        height: 60px;
        justify-content: space-between;
    }
    .header .content .logo {
        width: 96px;
    }
    .header .content .logo-mfg {
        position: absolute;
        right: 20px;
        width: 125px;
    }
    /* .header .content .header-cv {
        width: auto;
        gap: 10px;
    } */
    .header .content .header-cv {
        position: fixed;
        bottom: 0;
        width: 100vw;
        margin: 0 -10px 5px;
        gap: 5px;
        
        left: 0;
        margin: 0 auto;
        padding: 0 10px 5px;
        box-sizing: border-box;
    }
    .header .content .header-cv div {
        width: calc(50% - 12.5px);
        height: 55px;
        flex: 1;
    }
    .header .content .header-cv div.modelhouse a {
        padding: 0;
    }
    .header .content .header-cv div.modelhouse a img {
        max-height: 55px;
        width: auto;
    }
    .header .content .header-cv div::before {
        display: none;
    }
    .header .content .header-cv div.tel::after,
    .header .content .header-cv div.reserve::after {
        top: 50%;
        left: calc(20 / 375 * 100vw);
        transform: translate(-50%,-50%);
        width: calc(20 / 375 * 100vw);
        height: calc(20 / 375 * 100vw);
    }
    .header .content .header-cv div a {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: calc(14 / 375 * 100vw);
        font-weight: 500;
        padding: 4px 4px 4px 16px;
    }


    /* top-kv */
    .top-kv {
        margin: 0 calc(50% - 50vw) calc(30 / 375 * 100vw);
    }
    .top-kv .container {
        margin-top: 60px;
        background: url(../img/top-kv_sp.jpg) no-repeat;
        background-size: cover;
        background-position: center;
        padding: 0;
    }
    .top-kv .container::before,
    .top-kv .container::after {
        width: 140px;
        height: 140px;
    }
    .top-kv .container::after {
        content: "";
        position: absolute;
        bottom: 0;
        left: auto;
        right: 0;
        transform: scale(-1, 1);
        z-index: 0;
    }
    .top-kv .content {
        height: calc(324 / 375 * 100vw);
    }
    .top-kv .content .kv-mhlogo {
        top: -15px;
        right: 0;
        width: 180px;
        height: 30px;
        padding: 10px;
    }
    .top-kv .content .kv-title {
        top: calc(139 / 375 * 100vw);
        left: 0;
    }
    .top-kv .content .kv-title .txt1 {
        font-size: 1.85rem;
        margin-bottom: 20px;
    }
    .top-kv .content .kv-title .txt2 {
        font-size: 1.35rem;
        margin-bottom: 40px;
    }
    .top-kv .content .kv-title h1 {
        /* font-size: 2.3rem ; */
        font-size: calc(22 / 375 * 100vw);
        line-height: 1.1;
    }
    .top-kv .content .kv-title h1 span {
        font-weight: 400!important;
    }
    
    .top-kv .content .kv-area {
        padding: calc(7 / 375 * 100vw) calc(9 / 375 * 100vw);
        font-size: calc(16 / 375 * 100vw);
        top: calc(15 / 375 * 100vw);
        left: calc(15 / 375 * 100vw);
    }

    .top-kv .cp-bnr {
        margin: calc(15 / 375 * 100vw) auto 0;
		width: 100%;
		padding: 0 20px;
		box-sizing: border-box;
		gap: calc(15 / 375 * 100vw);
    }
    
	.top-kv .cp-bnr .col_2 {
		width: calc(50% - calc(8 / 375 * 100vw));
	}
	
    .float-btn {
        right: calc(10 / 375 * 100vw);
        bottom: calc(55 / 375 * 100vw);
        border-radius: calc(6 / 375 * 100vw);
        width: calc(165 / 375 * 100vw);
    }


    /* slider */
    .lineup {
        padding-top: 0;
        margin: -70px auto 0;
    }
    .lineup .slider1 div img {
        width: 200px;
        pointer-events: none;
    }


    /* footer */
    .footer .container {
        text-align: center;
        padding: 40px 0;
    }
    .footer .content .logo {
        width: 170px;
        margin: 0 auto 30px;
    }
    .footer .content p {
        line-height: 1.1;
    }
    .copyright {
        font-size: 0.75rem;
    }


    /* floating */
    .floating {
        width: 100%;
        top: auto;
        right: auto;
        bottom: 0;
        left: 50%;
        transform: translateX(-50%);
    }
    .floating ul li:last-child {
        display: none;
    }
    .floating ul {
        display: flex;
        flex-direction: row;  
        width: 100%;
    }
    .floating ul li a {
        display: block;
    }
    .floating ul li p {
        width: 100%;
        padding: 5px 0 10px;
    }
    .floating ul li {
        position: relative;
        width: 33.33%;
        height: auto;
        font-size: 0.6rem;
        line-height: 1.3;
        margin-bottom: 0;
    }
    .floating ul li::after {
        content: "";
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        height: 50px;
        border-right: 1px solid #a9a9a9;
    }
    .floating ul li:nth-last-child(-n+2)::after {
        border-right: 0;
    }
    .floating ul li .icon {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        height: auto;
        padding-top: 10px;
        background-color: #f3f2ef;
    }
    .floating ul li .icon img {
        width: 22px;
        height: 22px;
    }
}


/* 2025.02 revamp
---------------------------------------*/
.lineup .slider1 div p {
    font-weight: 600;
    text-align: center;
    margin-top: 5px;
}

.point-cont .flexbox:last-of-type .flexbox-img img {
    border: 1px solid #e4e4e4;
}

.plan-cont.slider3 {
    margin-bottom: 90px!important;
}
.plan-cont .slick-list {
    padding: 0!important;
}
.plan-cont .slick-list h3 {
    margin-bottom: 15px;
}
.plan-cont .slick-list .price {
    color: #000;
    text-align: center;
    margin-bottom: 40px;
}
.plan-cont .slick-list .price span {
    font-size: 180%;
    margin: 0 5px;
}
.plan-cont.note {
    padding: 20px;
    border: 1px solid #21489d;
    box-sizing: border-box;
}
.plan-cont.note p {
    font-size: 0.85rem;
    line-height: 1.8;
    margin-bottom: 0;
}
.plan-cont .slick-prev:before,
.plan-cont .slick-next:before {
    font-size: 0!important;
}
.plan-cont .slick-prev {
    left: 20px;
    z-index: 5;
}
.plan-cont .slick-next {
    right: 20px;
    font-size: 0;
    z-index: 5;
}
.plan-cont .slick-prev:before {
    content: "";
    position: absolute;
    top: calc(50% + 50px);
    left: 0;
    transform: translateY(-50%) rotate(45deg);
    width: 18px;
    height: 18px;
    border-bottom: 2px solid #fff;
    border-left: 2px solid #fff;
    opacity: 1!important;
    transition: all 0.3s ease;
}
.plan-cont .slick-next:before {
    content: "";
    position: absolute;
    top: calc(50% + 50px);
    right: 0;
    transform: translateY(-50%) rotate(45deg);
    width: 18px;
    height: 18px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    opacity: 1!important;
    transition: all 0.3s ease;
}
.plan-cont .slick-dots li {
    margin: 0 2px!important;
}
.plan-cont .slick-dots li button:before {
    font-size: 8px!important;
}

.plan-cont .price-list {
    margin-top: 40px;
}
.plan-cont .price-list ul li:not(:last-child) {
    margin-bottom: 30px;
}
.plan-cont .price-list ul li dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.plan-cont .price-list ul li dl dt {
    width: fit-content;
}
.plan-cont .price-list ul li dl dd {
    width: fit-content;
    text-align: right;
}
.plan-cont .price-list ul li dl dt span,
.plan-cont .price-list ul li dl dd span {
    font-size: 180%;
}
.plan-cont .price-list ul li dl dd.dot-line {
    position: relative;
    flex-grow: 1;
    font-size: 1.15rem;
    margin: 0 8px;
    box-sizing: border-box;
    overflow: hidden;
}
.plan-cont .price-list ul li dl dd.dot-line::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    width: 100%;
    height: 1px;
    border-top: 2px dotted #000;
}

.house-tour .house-tour-cont h4 {
    font-size: 1.8rem;
    font-weight: 600 !important;
    text-align: center;
    margin-bottom: 40px;
}
.house-tour .house-tour-cont .flexbox.merit .div-3 {
    font-size: 1.2rem;
    font-weight: 600;
    text-align: center;
    border: 1px solid #79796f;
    background-color: #f4f2ee;
}
.house-tour .house-tour-cont .flexbox .div-3 span {
    font-size: 2.3rem;
    line-height: 1.45;
}
.house-tour .house-tour-cont .flexbox.model-house .div-3 {
    padding: 0!important;
}
.house-tour .house-tour-cont .flexbox.model-house .div-3 .box-txt {
    min-height: 130px;
}
.house-tour .house-tour-cont .flexbox.model-house .div-3 .box-txt a {
	pointer-events: none !important;
	text-decoration: none !important;
}
.house-tour .house-tour-cont .flexbox.model-house img {
    margin-bottom: 20px;
}
.house-tour .house-tour-cont .flexbox.model-house .txt1 {
    font-size: 1.15rem;
    font-weight: 600;
    margin-bottom: 10px;
}
.house-tour .house-tour-cont .flexbox.model-house .reserve {
    position: relative;
    width: 100%;
    line-height: 1.4;
    text-align: center;
    margin-top: 20px;
    background-color: #a10d29;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .flexbox.model-house .reserve a {
    display: block;
    width: 100%;
    height: 100%;
    color: #fff;
    font-weight: 600;
    padding: 16px;
    box-sizing: border-box;
}
.house-tour .house-tour-cont .flexbox.model-house .reserve::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.house-tour .house-tour-cont .flexbox.model-house .reserve::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
/*.house-tour .house-tour-cont .slick-list {
    padding: 0!important;
}*/
.house-tour .house-tour-cont .slick-dots li {
    margin: 0 2px!important;
}
.house-tour .house-tour-cont .slick-dots li button:before {
    font-size: 8px!important;
}
.house-tour .house-tour-cont .slick-list img {
    margin-bottom: 0;
}


@media screen and (min-width: 769px) {
    .house-tour .house-tour-cont .flexbox.model-house .reserve:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .house-tour .house-tour-cont .flexbox.model-house .reserve:hover::before {
        right: 17px;
    }
}


@media screen and (max-width: 768px) {
    .house-tour .house-tour-cont h4 {
        font-size: 1.35rem;
        margin-bottom: 30px;
    }

    .plan-cont .slick-dots li {
        margin: 0!important;
    }
    .plan-cont .slick-list .price {
        margin-bottom: 30px;
    }    
    .plan-cont .slick-prev:before,
    .plan-cont .slick-next:before {
        top: calc(50% + 70px);
        width: 11px;
        height: 11px;
    }
    .plan-cont.note {
        padding: 15px;
    }

    .plan-cont .price-list {
        margin-top: 20px;
    }
    .plan-cont .price-list ul li:not(:last-child) {
        margin-bottom: 15px;
    }
    .plan-cont .price-list ul li dl dd {
        text-align: left;
    }
    .plan-cont .price-list ul li dl dd.dot-line {
        display: none;
    }
    .plan-cont .price-list ul li dl dt span,
    .plan-cont .price-list ul li dl dd span {
        font-size: 140%;
    }

    .house-tour .house-tour-cont:last-of-type {
        margin-bottom: 20px!important; 
    }
    .house-tour .house-tour-cont .flexbox.model-house {
        margin-bottom: 0!important;
    }
    .house-tour .house-tour-cont .flexbox.merit .div-3,
    .house-tour .house-tour-cont .flexbox.model-house .div-3  {
        width: 100%;
    }
	.house-tour .house-tour-cont .flexbox.model-house .div-3 {
		padding: 0 12px !important;
	}
    .house-tour .house-tour-cont .flexbox.merit .div-3:not(:last-of-type) {
        margin-bottom: 30px; 
    }
    .house-tour .house-tour-cont .flexbox.model-house .div-3:not(:last-of-type)  {
       margin-bottom: 40px;
    }
    .house-tour .house-tour-cont .flexbox.model-house .div-3 img {
        width: 100%;
        height: 190px;
        object-fit: cover;
    }
    .house-tour .house-tour-cont .flexbox.model-house .div-3 .box-txt {
        min-height: auto;
    }
    .house-tour .house-tour-cont .slick-dots li {
        margin: 0px!important;
    }
    .house-tour .house-tour-cont .slick-prev {
		left: 8.5%;
		top: 46%;
		z-index: 10;
		width: 25px;
		height: 25px;
	}
    .house-tour .house-tour-cont .slick-prev::before {
		content: "";
		width: 25px;
		height: 25px;
		background: url("../img/ico_arrow_slide.svg") no-repeat;
		background-size: 100% 100%;
		position: absolute;
		left: 0;
		top: 0;
		transform: scale(-1,-1);
	}
    .house-tour .house-tour-cont .slick-next {
		right: 8.5%;
		top: 46%;
		z-index: 10;
		width: 18px;
		height: 18px;
	}
	.house-tour .house-tour-cont .slick-next::before {
		content: "";
		width: 25px;
		height: 25px;
		background: url("../img/ico_arrow_slide.svg") no-repeat;
		background-size: 100% 100%;
		position: absolute;
		right: 0;
		top: 0;
	}
}


.house-tour .house-tour-event {
    padding: 40px;
    box-sizing: border-box;
}
.house-tour .house-tour-event h4 {
    font-size: 1.8rem;
    font-weight: 600 !important;
    text-align: center;
    margin-bottom: 10px;
}
.house-tour .house-tour-event .txt1 {
    font-size: 1.15rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 20px;
}
.house-tour .house-tour-event .txt2 {
    margin-bottom: 30px;
}
.house-tour .house-tour-event .consult-btn {
    position: relative;
    max-width: 260px;
    line-height: 1.4;
    text-align: center;
    margin: 0 auto;
    background-color: #21489d;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.house-tour .house-tour-event .consult-btn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.house-tour .house-tour-event .consult-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.house-tour .house-tour-event .consult-btn a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.08rem;
    font-weight: 600;
    color: #fff;
    padding: 20px;
    box-sizing: border-box;
}

@media screen and (max-width: 768px) {
    .house-tour .house-tour-event {
        padding: 30px 20px;
        box-sizing: border-box;
    }
    .house-tour .house-tour-event h4 {
        font-size: 1.35rem;
    }
    .house-tour .house-tour-event .txt2 {
        margin-bottom: 20px;
    }
    .house-tour .house-tour-event .consult-btn {
        max-width: 100%;
    }
    .house-tour .house-tour-event .consult-btn a {
        font-size: 1rem;
        padding: 16px;
    }
}

@media screen and (min-width: 769px) {
    .house-tour-event .consult-btn:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
}

.selfstyling h3 {
    font-size: 1.35rem;
    font-weight: 600!important;
    line-height: 1.6;
    text-align: center;
    margin-bottom: 20px;
}
.selfstyling img {
    margin-bottom: 30px;
}
.selfstyling .ss-btn,
.ad-copy .ss-btn {
    position: relative;
    max-width: 430px;
    line-height: 1.4;
    text-align: center;
    margin: 0 auto;
    background-color: #21489d;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.selfstyling .ss-btn::before,
.ad-copy .ss-btn::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.selfstyling .ss-btn::after,
.ad-copy .ss-btn::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 29px;
    height: 29px;
    background: url(../img/mobile.svg) no-repeat;
    background-size: cover;
    background-position: center;
}
.selfstyling .ss-btn a,
.ad-copy .ss-btn a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.08rem;
    font-weight: 600;
    color: #fff;
    padding: 20px;
    box-sizing: border-box;
}

@media screen and (min-width: 769px) {
    .selfstyling .ss-btn:hover,
    .ad-copy .ss-btn:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
}


/* ad-copy */
.lineup {
    margin: 70px auto 0;
}
.ad-copy {
    position: relative;
    max-width: 980px;
    width: 100%;
    font-size: 1.08rem;
    font-weight: 600;
    text-align: center;
    padding: 30px;
    margin: -40px auto 0;
    border: 3px solid #21489d;
    background-color: #f3f5fa;
    box-sizing: border-box;
    z-index: 1;
}
.ad-copy p span {
    color: #21489d;
}
.ad-copy .ss-btn {
    margin-top: 20px;
}

@media screen and (max-width: 768px) {
    .lineup {
        margin: 40px auto 0;
    }
    .ad-copy {
        width: auto;
        text-align: left;
        padding: 20px;
        margin: -40px 20px 0;
        box-sizing: border-box;
    }
}

@media screen and (max-width: 380px) {
    .top-kv .content .kv-title .txt1 {
        font-size: clamp(27px, 8.65vw, 3.4rem);
    }
    .top-kv .content .kv-title .txt2 {
        font-size: clamp(18px, 5.8vw, 1.35rem);
    }
    .top-kv .content .kv-title h1 {
        font-size: calc(25 / 375 * 100vw);
    }
}


.cp-cv {
    margin-bottom: 70px;
    font-family: 'TsukuGoPro-B', 'ヒラギノ角ゴ Pro','Hiragino Kaku Gothic Pro','メイリオ','Meiryo','游ゴシック','Yu Gothic','ＭＳ Ｐゴシック',sans-serif!important;
}
.cp-cv .container {
    border: 5px solid #A00E2A;
    padding: 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cp-cv-ttl {
    font-size: 30px;
    font-weight: 600;
    color: #A00E2A;
    line-height: 1.33;
}
.cp-cv-text {
    width: 460px;
}
.cp-cv-text > p {
    font-size: 28px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 26px;
}

.cp-cv-btn {
    display: flex;
    flex-wrap: wrap;
    gap: 15px;
}
.cp-cv-btn div {
    position: relative;
    width: calc(50% - 7.5px);
    line-height: 1.4;
    text-align: center;
    background-color: #a10d29;
    box-sizing: border-box;
    border-radius: 10px;
    filter: drop-shadow(0 0 0px rgb(0, 0, 0, 0.3));
    transition: all 0.3s ease;
}
.cp-cv-btn div::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transition: all 0.3s ease;
}
.cp-cv-btn div.tel::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/icon-tel1.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.cp-cv-btn div.reserve::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 15px;
    transform: translateY(-50%);
    width: 23px;
    height: 23px;
    background: url(../img/reserve-icon.png) no-repeat;
    background-size: cover;
    background-position: center;
}
.cp-cv-btn div a {
    display: block;
    width: 100%;
    height: 100%;
    font-size: 1.08rem;
    color: #fff;
    font-weight: 600;
    padding: 16px 16px 16px 34px;
    box-sizing: border-box;
}


@media screen and (min-width: 769px) {
    .cp-cv-btn div:hover {
        filter: drop-shadow(0 0 8px rgb(0, 0, 0, 0.35));
    }
    .cp-cv-btn div:hover::before {
        right: 17px;
    }
}


@media screen and (max-width: 768px) {
    .cp-cv {
        margin-bottom: 40px;
        padding: 0 20px;
    }
    .cp-cv .container {
        border: 3px solid #A00E2A;
        padding: calc(20 / 375 * 100vw) calc(15 / 375 * 100vw);
        display: block;
    }
    .cp-cv-ttl {
        font-size: calc(20 / 375 * 100vw);
        width: 100%;
        text-align: center;
        margin-bottom: calc(20 / 375 * 100vw);
    }
    .cp-cv-text {
        width: 100%;
    }
    .cp-cv-text > p {
        font-size: calc(18 / 375 * 100vw);
        margin-bottom: calc(15 / 375 * 100vw);
    }

    .cp-cv-btn {
        width: 100%;
        margin: 0 auto;
        gap: 10px;
    }
    .cp-cv-btn div {
        width: 100%;
        height: 55px;
    }
    .cp-cv-btn div::before {
        display: none;
    }
    .cp-cv-btn div.tel::after,
    .cp-cv-btn div.reserve::after {
        top: 50%;
        left: 20px;
        transform: translate(-50%,-50%);
        width: 18px;
        height: 18px;
    }
    .cp-cv-btn div a {
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 1rem;
        font-weight: 500;
        padding: 4px 4px 4px 16px;
    }
}


.flow {
	background: #E8E6DF;
	padding: 40px 0 37px;
}
.flow .flow-cont h4 {
	text-align: center;
	font-size: 29px;
	font-weight: bold !important;
	letter-spacing: 0.03em;
	margin-bottom: 40px;
}
.flow .flow-cont .flexbox {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	margin-bottom: 30px;
}
.flow .flow-cont .flexbox-txt {
	padding: 25px 15px 35px;
	background: #fff;
	border-radius: 10px;
	flex: 1;
	position: relative;
}
.flow .flow-cont .flexbox-txt:not(:last-child)::before {
	content: "";
	position: absolute;
	top: 50%;
	right: -18px;
	transform: translateY(-50%) rotate(45deg);
	width: 12px;
	height: 12px;
	border-top: 2px solid #a10d29;
	border-right: 2px solid #a10d29;
	transition: all 0.3s ease;
}
.flow .flow-cont .flexbox-txt .num {
	position: absolute;
	top: -17px;
	left: 0;
	right: 0;
	text-align: center;
}
.flow .flow-cont .flexbox-txt .num .ft-color-rd {
	background: #A10D29;
	color: #fff;
	display: inline-block;
	width: 34px;
	height: 34px;
	line-height: 35px;
	border-radius: 50%;
	font-size: 19px;
	font-weight: 500;
	text-align: center;
}
.flow .flow-cont .flexbox-txt .ico {
	max-width: 50px;
	margin: 0 auto 10px;
}
.flow .flow-cont .flexbox-txt p {
	font-size: 13px;
	font-weight: 500;
	line-height: 1.42;
}
.flow .flow-cont .flexbox-txt p.sttl {
	font-size: 14px;
	font-weight: bold;
	text-align: center;
	line-height: 1.42;
	margin-bottom: 10px;
}
.flow .flow-cont .cp-cv-btn {
	justify-content: center;
}
.flow .flow-cont .cp-cv-btn div {
	width: 550px;
}
.flow .flow-cont .cp-cv-btn div.reserve::after {
	display: none;
}

@media screen and (max-width: 768px) {
	.flow {
		padding: 10px 0;
	}
	.flow .flow-cont h4 {
		font-size: calc(18 / 375 * 100vw);
		margin-bottom: calc(30 / 375 * 100vw);
	}
	.flow .flow-cont .flexbox {
		gap: calc(18 / 375 * 100vw);
		margin-bottom: calc(40 / 375 * 100vw);
	}
	.flow .flow-cont .flexbox-txt {
		width: 100%;
		padding: calc(20 / 375 * 100vw) calc(18 / 375 * 100vw) calc(16 / 375 * 100vw) calc(10 / 375 * 100vw);
		border-radius: calc(10 / 375 * 100vw);
		flex: initial;
		display: flex;
		align-items: center;
		column-gap: calc(12 / 375 * 100vw);
	}
	.flow .flow-cont .flexbox-txt:not(:last-child)::before {
		display: none;
	}
	.flow .flow-cont .flexbox-txt .num {
		top: calc(-14 / 375 * 100vw);
    	left: calc(-15 / 375 * 100vw);
		right: inherit;
	}
	.flow .flow-cont .flexbox-txt .num .ft-color-rd {
		width: calc(34 / 375 * 100vw);
		height: calc(34 / 375 * 100vw);
		line-height: calc(35 / 375 * 100vw);
		font-size: calc(19 / 375 * 100vw);
	}
	.flow .flow-cont .flexbox-txt .ico {
		max-width: calc(50 / 375 * 100vw);
		margin: 0 auto;
	}
	.flow .flow-cont .flexbox-txt p {
		font-size: calc(13 / 375 * 100vw);
	}
	.flow .flow-cont .flexbox-txt p.sttl {
		text-align: left;
		font-size: calc(14 / 375 * 100vw);
		margin-bottom: calc(10 / 375 * 100vw);
	}
	.flow .flow-cont .cp-cv-btn div {
		width: calc(290 / 375 * 100vw);
	}
	.flow .flow-cont .cp-cv-btn div a {
		padding: 4px;
		font-weight: bold;
	}
	.flow .flow-cont .cp-cv-btn div.reserve::before {
		display: block;
	}
}

.select .select-cont h3 {
	text-align: center;
	background: #A10E28;
	color: #fff;
	font-size: 31px;
	font-weight: bold !important;
	letter-spacing: 0.03em;
	line-height: 1.45;
	padding: 17px 0 15px;
	margin-bottom: 30px;
}
.select .select-cont h4 {
	text-align: center;
	font-size: 23px;
	font-weight: bold !important;
	letter-spacing: 0.03em;
	line-height: 1.47;
	margin-top: 30px;
	margin-bottom: 25px;
}
.select .select-cont h4 + p {
	text-align: center;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.03em;
	line-height: 1.64;
	margin-bottom: 27px;
}
.select .select-cont .bnr {
	max-width: 730px;
	margin: 50px auto 0;
}
.select .select-cont .bnr a {
	display: block;
	transition: opacity 0.3s;
}
.select .select-cont .bnr a:hover {
	opacity: 0.7;
}

@media screen and (max-width: 768px) {
	.select .container {
		padding-block: 0; 
	}
	.select .select-cont h3 {
		font-size: calc(17 / 375 * 100vw);
		padding: calc(17 / 375 * 100vw) 0 calc(14 / 375 * 100vw);
		margin-bottom: calc(25 / 375 * 100vw);
	}
	.select .select-cont h4 {
		font-size: calc(17 / 375 * 100vw);
		margin-top: calc(30 / 375 * 100vw);
		margin-bottom: calc(20 / 375 * 100vw);
	}
	.select .select-cont h4 + p {
		font-size: calc(14 / 375 * 100vw);
		margin-bottom: calc(49 / 375 * 100vw);
		text-align: left;
	}
	.select .select-cont .bnr {
		max-width: calc(315 / 375 * 100vw);
		margin: calc(30 / 375 * 100vw) auto 0;
	}
}


