@charset "utf-8";

/*-----------------------------------------------
	基本設定
-----------------------------------------------*/
html {
    margin-top: 0 !important;
    -webkit-tap-highlight-color: rgba(0, 134, 199, 0.2) !important;
    letter-spacing: 0.5px;
}

body {
    color: #000;
    background: #FFF;
    font-family: 'YakuHanJP_Noto', 'Noto Sans JP', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
    word-break: break-all;
}

ul {
    padding-left: 0;
}

li {
    list-style-type: none;
}

a:hover {
    text-decoration: none;
}

/* フォント */
.fRoboto {
    font-family: 'Roboto', sans-serif;
}

.fMont {
    font-family: 'Montserrat', sans-serif;
}

.fSerif {
    font-family: 'Noto Serif JP', '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}

.fVerdana {
    font-family: Verdana;
}

/* ロールオーバー */
.ro,
.brt {
    -webkit-transition: all 0.2s ease-out;
    transition: all 0.2s ease-out;
}

.ro:hover {
    opacity: 0.8;
}

.brt:hover {
    filter: brightness(1.1);
}

.wrapper1132 {
    width: 100%;
    max-width: none;
}

.wrapper932 {
    width: 100%;
    max-width: none;
}

@media only screen and (min-width:992px) {
    .wrapper1132 {
        width: 1132px;
        margin: 0 auto;
        max-width: calc(100% - 40px);
    }

    .wrapper932 {
        width: 932px;
        margin: 0 auto;
        max-width: calc(100% - 40px);
    }
}

/*-----------------------------------------------
	資料請求ボタン
-----------------------------------------------*/
.cmnBtnContact {
    width: 250px;
    background: #fbb731;
    height: 55px;
    border-radius: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #212529;
}
.cmnBtnContact:hover {
    color: #212529;
}

.cmnBtnContact .imgTit {
    margin-right: 10px;
    flex-shrink: 0;
    display: flex;
    height: 20px;
    align-items: center;
}

.cmnBtnContact .txtBtn {
    font-size: 16px;
    font-weight: bold;
}

/* boxLinkContactの中のボタン */
.boxLinkContact .cmnBtnContact {
    width: 360px;
    height: 48px;
    border-radius: 8px;
    margin-top: 32px;
    letter-spacing: 1px;
}
.boxLinkContact .cmnBtnContact:hover {
    opacity: 0.8;;
}

@media only screen and (max-width:992px) {
    .boxLinkContact .cmnBtnContact .imgTit {
        width: 29px;
    }
}

/*-----------------------------------------------
	無料プレゼントコンテンツ
-----------------------------------------------*/
.boxLinkContact {
    margin: 10px auto 0;
    /* width: 932px; */
    height: 342px;
    border: 1px solid rgb(238, 238, 238);
    border-radius: 8px;
    display: flex;
    gap: 18px;
    align-items: center;
    line-height: 1;
    letter-spacing: 1px;
    padding: 20px 80px;
    background: #fff;
}

.boxLinkContact.contact02 {
    margin: 50px auto 0;
}
.boxLinkContact.contact01,
.boxLinkContact.contact03,
.boxLinkContact.contact04,
.boxLinkContact.contact05{
    margin: 40px auto 0;
}

.boxLinkContact .boxLeft {
    flex-shrink: 0;
    text-align: left;
}

.boxLinkContact .boxLeft .txt01 {
    font-size: 15px;
    font-weight: bold;
    color: #E4407D;
    position: relative;
    padding: 0 13px;
    display: inline;
}

.boxLinkContact .boxLeft .txt01:before,
.boxLinkContact .boxLeft .txt01:after {
    content: '';
    position: absolute;
    width: 11px;
    height: 15px;
    top: 4px;
    left: 0;
}

.boxLinkContact .boxLeft .txt01:after {
    left: unset;
    right: 3px;
    transform: rotate(65deg);
}

.boxLinkContact.lazyloaded .boxLeft .txt01:before,
.boxLinkContact.lazyloaded .boxLeft .txt01:after {
    background: url(../img/lp/iconTxt01.png)center top / cover no-repeat;
}

.boxLinkContact .boxLeft .txt02 {
    margin: 16px 0 0 0;
    font-size: 18px;
    font-weight: bold;
    color: #E4407D;
}

.boxLinkContact .boxLeft .txt03 {
    margin: 12px 0 0 0;
    font-size: 36px;
    font-weight: bold;
    color: #E4407D;
}

.boxLinkContact .boxLeft .txt04 {
    margin: 9px 0 0 0;
    font-size: 14px;
    line-height: 2;
    text-align: left;
}

.boxLinkContact .boxRight {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* 物件を探す */
.boxLinkContact.estateSearch {
    border: 1px solid #e73462;
    position: relative;
    margin-top: 0;
    border-radius: 0 0 8px 8px;
    height: 255px;
    padding: 30px 100px;
    justify-content: space-between;
}

.boxLinkContact.estateSearch .boxLeft .txt04{
    font-size: 16px;
}

.boxLinkContact.estateSearch:before {
    content: "";
    position: absolute;
    top: -24px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 32px solid transparent;
    border-right: 32px solid transparent;
    border-bottom: 24px solid #e73462;
}

.boxLinkContact.estateSearch:after {
    content: "";
    position: absolute;
    top: -23px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 32px solid transparent;
    border-right: 32px solid transparent;
    border-bottom: 24px solid #fff;
}

.boxLinkContact .boxLeft .txt05 {
    margin: 10px 0 0 0;
    font-size: 25px;
    line-height: 1.52;
    text-align: left;
    font-weight: bold;
    color: #E4407D;
}

.boxLinkContact.estateSearch .cmnBtnContact {
    width: 360px;
    height: 48px;
    border-radius: 8px;
    margin-top: 0px;
    letter-spacing: 1px;
    background: #fff2f5;
    border: 1px solid #e73462;
}

@media only screen and (max-width:992px) {
    .spWrapper{
        padding: 0 6.4%;
    }
    .boxLinkContact {
        margin: 48px auto;
        height: auto;
        border-radius: 8px;
        display: block;
        gap: 18px;
        line-height: 1;
        letter-spacing: 1px;
        padding: 0;
        width: 87.202%;
        padding: 32px 20px 23px;
        position: relative;
    }
    .boxLinkContact.contact .boxLeft .txt01:before, 
    .boxLinkContact.contact02 .boxLeft .txt01:before, 
    .boxLinkContact.contact03 .boxLeft .txt01:before, 
    .boxLinkContact.contact04 .boxLeft .txt01:before, 
    .boxLinkContact.contact05 .boxLeft .txt01:before, 
    .boxLinkContact.contact .boxLeft .txt01:after,
    .boxLinkContact.contact02 .boxLeft .txt01:after,
    .boxLinkContact.contact03 .boxLeft .txt01:after,
    .boxLinkContact.contact04 .boxLeft .txt01:after,
    .boxLinkContact.contact05 .boxLeft .txt01:after {
        top: 1px;
    }
    .boxLinkContact.contact01{
        border: unset;
        width: 100%;
        padding: 0;
    }

    .boxLinkContact.contact .boxLeft .txt01,
    .boxLinkContact.contact02 .boxLeft .txt01,
    .boxLinkContact.contact03 .boxLeft .txt01,
    .boxLinkContact.contact04 .boxLeft .txt01,
    .boxLinkContact.contact05 .boxLeft .txt01
    {
        font-size: 12px;
        padding: 0 13px;
    }

    .boxLinkContact .boxLeft {
        text-align: center;
    }

    .boxLinkContact.contact .boxLeft,
    .boxLinkContact.contact02 .boxLeft,
    .boxLinkContact.contact03 .boxLeft,
    .boxLinkContact.contact04 .boxLeft,
    .boxLinkContact.contact05 .boxLeft
    {
        text-align: left;
    }

    .boxLinkContact .boxLeft .txt02 {
        margin: 16px 0 0 0;
        font-size: 16px;
    }
    .boxLinkContact.contact .boxLeft .txt02,
    .boxLinkContact.contact02 .boxLeft .txt02,
    .boxLinkContact.contact03 .boxLeft .txt02,
    .boxLinkContact.contact04 .boxLeft .txt02,
    .boxLinkContact.contact05 .boxLeft .txt02 {
        margin: 13px 0 0 0;
        font-size: 14px;
    }

    .boxLinkContact .boxLeft .txt03 {
        margin: 12px 0 0 0;
        font-size: 28px;
    }

    .boxLinkContact.contact .boxLeft .txt03,
    .boxLinkContact.contact02 .boxLeft .txt03, 
    .boxLinkContact.contact03 .boxLeft .txt03, 
    .boxLinkContact.contact04 .boxLeft .txt03, 
    .boxLinkContact.contact05 .boxLeft .txt03 {
        margin: 9px 0 0 0;
        font-size: 24px;
    }

    .spWhite{
        width: 100%;
        padding: 50px 0 30px;
        background: #fff;
    }
    .boxLinkContact.contact02 {
        margin: 0 auto;
    }

    .boxLinkContact.estateSearch {
        border-left: none;
        border-right: none;
        border-bottom: 1px solid rgb(238, 238, 238);
        border-radius: 0;
        height: auto;
        padding: 30px 0px;
        margin: 0 auto;
        width: 100%;
        justify-content: space-between;
        text-align: center;
    }
    .boxLinkContact.estateSearch .boxLeft .txt05 {
        margin: 10px 0 0 0;
        font-size: 24px;
        line-height: 1.583;;
        text-align: center;
    }
    .boxLinkContact.estateSearch .boxLeft .txt04 {
        font-size: 13px;
        line-height: 1.923;
    }

    .boxLinkContact.estateSearch .cmnBtnContact {
        width: 76%;
        height: 52px;
        border-radius: 50px;
        margin-top: 0px;
        letter-spacing: 1px;
    }
    .boxLinkContact .boxLeft .txt04 {
        margin: 10px 0 0 0;
        font-size: 13px;
        line-height: 1.923;
        text-align: center;
        letter-spacing: 0;
        white-space: nowrap;
    }

    .boxLinkContact .boxRight {
        margin-top: 19px;
    }

    .boxLinkContact .cmnBtnContact {
        width: 87.16%;
        height: 50px;
        border-radius: 50px;
        margin-top: 20px;
        letter-spacing: 1px;
        position: relative;
    }

    .boxLinkContact.contact .cmnBtnContact,
    .boxLinkContact.contact02 .cmnBtnContact,
    .boxLinkContact.contact03 .cmnBtnContact,
    .boxLinkContact.contact04 .cmnBtnContact,
    .boxLinkContact.contact05 .cmnBtnContact {
        width: 100%;
        margin-top: 0px;
    }

    .boxLinkContact .imgTit {
        width: 60.325%;
    }

    .boxLinkContact .imgTit.spSmall {
        width: 95px;
        position: absolute;
        right: 0;
        top: 23px;
        z-index: 0;
    }
}

/*-----------------------------------------------
	コンテナー
-----------------------------------------------*/
#container {
    padding-top: 106px;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

.menuOpen #container {
    -webkit-transform: translateX(-80%);
    transform: translateX(-80%);
}

@media only screen and (min-width:375px) {
    .menuOpen #container {
        -webkit-transform: translateX(-300px);
        transform: translateX(-300px);
    }
}

@media only screen and (min-width:992px) {
    .menuOpen #container {
        -webkit-transform: none;
        transform: none;
    }
}
@media only screen and (max-width:992px) {
    #container {
        padding-top: 54px;
    }
}
/*-----------------------------------------------
	ヘッダー
-----------------------------------------------*/
#header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
    height: 106px;
    background: #fff;
    width: 100%;
    display: flex;
    align-items: center;
    padding: 0 50px;
}

#header .headerIn {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

#header .logoHoldings {
    display: flex;
    align-items: center;
}

#header .txtDescription {
    font-size: 12px;
    padding: 1px 0;
    margin: 0 0 0 30px;
    line-height: 1.667;
}

#header .boxList {
    display: flex;
    gap: 30px;
    margin: 0;
}

#header .linkItem {
    font-size: 16px;
    color: #E4407D;
    font-weight: bold;
}

#header .listItem:last-child {
    margin-right: 48px;
}

#header .boxNavi {
    display: flex;
    align-items: center;
}

@media only screen and (max-width:1540px) {
    .cmnBtnContact .txtBtn {
        font-size: 14px;
    }
    .cmnBtnContact .txtBtn:hover{
        color: #212529;
    }

    #header .txtDescription {
        font-size: 12px;
    }

    #header .linkItem {
        font-size: 14px;
    }
}

@media only screen and (max-width:1450px) {
    .cmnBtnContact .txtBtn {
        font-size: 13px;
    }

    #header .txtDescription {
        font-size: 11px;
    }

    #header .linkItem {
        font-size: 12px;
    }
}

@media only screen and (max-width:1350px) {
    #header {
        padding: 0px 15px;
    }

    .cmnBtnContact {
        width: 180px;
        ;
    }

    .cmnBtnContact .txtBtn {
        font-size: 12px;
    }

    #header .linkItem {
        font-size: 10px;
        letter-spacing: 0;
    }

    #header .boxList {
        gap: 15px;
    }

    #header .txtDescription {
        font-size: 10px;
        margin: 0 0 0 15px;
        letter-spacing: 0;
    }

    #header .listItem:last-child {
        margin-right: 15px;
    }
}

@media only screen and (max-width:992px) {
    #header .boxNavi {
        display: none;
    }

    #header .imgLogo {
        width: 17.105%;
    }

    #header .txtDescription {
        font-size: 10px;
        margin: 0 0 0 10px;
    }

    #header {
        height: auto;
        padding: 0;
    }

    .cmnBtnContact .txtBtn {
        font-size: 16px;
    }

    #header .boxMenu {
        width: 54px;
        height: 54px;
    }
    #header .logoHoldings {
        padding-left: 10px;
    }
}

/*-----------------------------------------------
    ヒーローイメージここから
-----------------------------------------------*/
.secHero {
    position: relative;
    height: 680px;
    background: url(../img/lp/imgMain.jpg)center top no-repeat;
    max-width: 1920px;
}

.secHero .titMain {
    position: absolute;
    bottom: -11px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 30px;
    color: #E4407D;
    font-weight: bold;
    padding: 25px 40px 0;
    background: #fff;
    border-radius: 8px 8px 0 0;
    margin: 0;
    z-index: 2;
}

@media only screen and (max-width:992px) {
    .secHero {
        position: relative;
        height: 80vw;
        background: url(../img/lp/imgMain_sp.jpg)center top / cover no-repeat;
        max-width: unset;
    }

    .secHero .titMain {
        bottom: -11px;
        left: 0;
        transform: unset;
        font-size: 24px;
        padding: 13px 25px 0;
        border-radius: 0px 8px 0 0;
        margin: 0;
    }
}

/*-----------------------------------------------
	パンくずリスト
-----------------------------------------------*/

/*-----------------------------------------------
	メイン部分
-----------------------------------------------*/
/* ラッパー */
.mainWrapper {
    width: calc(100% - 6rem);
    max-width: 1022px;
}

/* secTopCon */
.secTopCon .txtTop {
    font-size: 16px;
    font-weight: bold;
    margin-top: 32px;
    text-align: center;
}

@media only screen and (max-width:992px) {
    .secTopCon .txtTop {
        font-size: 12px;
        margin-top: 25px;
        text-align: left;
        padding: 0 6.4%;
        line-height: 1.833;
        letter-spacing: 0;
    }
}

/*-----------------------------------------------
	secFood
-----------------------------------------------*/
.bgPink {
    background: #fff2f5;
    padding: 48px 0;
    margin-top: 48px;
}

.secFood {
    background-color: #fff;
    border-radius: 8px;
    text-align: center;
    max-width: 1132px;
    padding: 48px 0;
    margin: 0 auto;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.secFood .foodTitle {
    color: #e73462;
    font-size: 25px;
    font-weight: bold;
    margin-bottom: 32px;
    position: relative;
    padding-bottom: 24px;
    letter-spacing: 1px;
}

.secFood .foodTitle::before {
    content: "";
    display: block;
    width: 80px;
    /* 線の長さ */
    height: 3px;
    /* 線の太さ */
    background-color: #e53960;
    /* 線の色 */
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0;
}

.secFood .foodTitle::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 100%;
    /* 線の下に配置 */
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 7px solid #e53960;
    /* 三角形の色 */
}

.secFood .foodDescription {
    font-size: 16px;
    line-height: 1.75;
}

.secFood .foodDescription.txt02 {
    margin-top: 28px;
}

.secFood .foodSlider {
    overflow: hidden;
    width: 100%;
    margin: 42px auto 0;
    position: relative;
    border-radius: 10px;
}

.secFood .foodSlideBox {
    display: flex;
    width: calc(327px * 8 + 30px * 7);
    /* スライドの合計幅 */
    animation: infiniteSlide 20s linear infinite;
}

.secFood .foodImage {
    width: 327px;
    margin-right: 30px;
    flex-shrink: 0;
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.5s ease-in-out;
}

/* スライドを無限ループさせる */
.secFood .foodSlideBox::after {
    content: "";
    display: flex;
}

/* 無限ループアニメーション */
@keyframes infiniteSlide {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(calc(-327px * 4 - 30px * 4));
    }

    /* 画像4枚分だけ左へ */
}

@media only screen and (max-width:992px) {
    .bgPink {
        padding: 30px 0 0;
        margin-top: 40px;
        background: linear-gradient(to bottom, #fff2f5 calc(100% - 50px), #ffffff 100%);
    }
    
    .secFood {
        background-color: unset;
        border-radius: 8px;
        text-align: center;
        max-width: unset;
        padding:0;
        margin: 0 auto;
        box-shadow: unset;
    }

    .secFood .foodTitle {
        font-size: 20px;
        margin-bottom: 27px;
        padding-bottom: 14px;
        letter-spacing: 0px;
        line-height: 1.9;
    }

    .secFood .foodTitle::after {
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        border-top: 5px solid #e53960;
    }

    .secFood .foodTitle::before {
        width: 69px;
    }

    .secFood .foodDescription {
        font-size: 13px;
        line-height: 1.923;
    }

    .secFood .spFoodImg {
        width: 74.4%;
        margin: 20px auto 0; 
    }
    .secFood .foodImageSp {
        border-radius: 16px;
        overflow: hidden;
    }
    .secFood .foodImage {
        width: 179px;
        margin-right: 20px;
        overflow: visible;
    }
    .secFood .foodSlider {
        overflow: visible;
        width: 100%;
        margin: 20px auto 0;
        position: relative;
        border-radius: 0;
    }
    @keyframes infiniteSlide {
        0% {
            transform: translateX(0);
        }
    
        100% {
            transform: translateX(calc(-179px * 3 - 20px * 3));
        }
    
        /* 画像4枚分だけ左へ */
    }
}

/*-----------------------------------------------
	secMerit
-----------------------------------------------*/
.secMerit {
    padding: 40px 0;
    border-radius: 8px;
}

.secMerit .meritTitle {
    color: #e44e63;
    font-size: 25px;
    font-weight: bold;
    margin-bottom: 30px;
    text-align: center;
}

.secMerit .meritBox {
    display: flex;
    justify-content: center;
    gap: 40px;
    flex-wrap: wrap;
    max-width: 1132px;
}

.secMerit .meritItem {
    width: calc((100% - 80px) / 3);
    background-color: #fff;
    border-radius: 10px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    /* overflow: hidden; */
    text-align: left;
    position: relative;
}

.secMerit .meritNumber {
    position: absolute;
    width: 40px;
    height: 40px;
    top: 0px;
    left: 0px;
    background: #fff;
    color: #e73462;
    font-size: 20px;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px 0 6px 0;
}

.secMerit .meritImage img {
    width: 100%;
    height: auto;
    display: block;
}

.secMerit .meritText {
    padding: 22px 25px 5px;
}

.secMerit .meritHeading {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 8px;
    letter-spacing: 1px;
}

.secMerit .meritDescription {
    font-size: 16px;
    line-height: 1.75;
}

@media only screen and (max-width:992px) {
    .secMerit {
        padding: 0 6.4%;
        padding-top: 40px;
    }

    .secMerit .meritTitle {
        font-size: 20px;
        margin-bottom: 15px;
        letter-spacing: 0;
    }

    .secMerit .meritText {
        padding: 13px 15px 0px;
    }

    .secMerit .meritImage {
        width: 36.7%;
        flex-shrink: 0;
        min-height: 150px;
    }

    .secMerit .meritHeading {
        font-size: 16px;
        margin-bottom: 8px;
        letter-spacing: 0px;
    }

    .secMerit .meritDescription {
        font-size: 13px;
        line-height: 1.692;
    }

    .secMerit .meritBox {
        display: block;
    }

    .secMerit .meritItem {
        display: flex;
        width: 100%;
        border-radius: 10px;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    }

    .secMerit .meritItem:nth-child(n+2) {
        margin-top: 20px;
    }

    .secMerit .meritNumber {
        top: 0px;
        left: 0px;
        background: #fff;
        color: #ff6384;
        font-size: 16px;
        padding: 0;
        border-radius: 0 0 5px 0;
        width: 33px;
        height: 33px;
        display: flex;
        align-items: center;
        justify-content: center;
    }
}

/*-----------------------------------------------
	secProperty
-----------------------------------------------*/

.secProperty {
    background: #fff2f5;
    padding: 40px 50px;
    margin-top: 50px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    gap: 30px;
}

.secProperty .secProperty .boxRight {
    flex-shrink: 0;
}

.secProperty .propertyTitle {
    color: #e73462;
    font-size: 25px;
    font-weight: bold;
    margin-bottom: 10px;
    letter-spacing: 2px;
}

.secProperty .propertyText {
    font-size: 16px;
    line-height: 1.75;
    white-space: nowrap;
    margin: 0;
    /* letter-spacing: 1px; */
}

.secProperty .propertyButton {
    width: 360px;
    background: #fff;
    padding: 10px 20px;
    font-size: 16px;
    border-radius: 8px;
    text-decoration: none;
    border: 1px solid #e73462;
    font-weight: bold;
    color: #212529;
    display: flex;
    align-items: center;
    justify-content: center;
}

.secProperty .propertyButton {}

.secProperty .propertyIcon {
    margin-right: 5px;
}

.secProperty .propertyNote {
    font-size: 12px;
    margin: 10px 0 0;
    letter-spacing: 0;
}

@media only screen and (max-width:992px) {
    .secProperty {
        padding: 25px 20px 10px;
        margin-top: 30px;
        border-radius: 8px;
        display: block;
    }

    .secProperty .propertyButton {
        width: 87.16%;
        height: 52px;
        border-radius: 50px;
        margin: 0 auto;
        letter-spacing: 0px;
    }

    .secProperty .propertyIcon {
        margin-right: 5px;
        width: 30px;
    }

    .secProperty .propertyTitle {
        font-size: 20px;
        margin-bottom: 15px;
        letter-spacing: 0px;
        text-align: center;
    }

    .secProperty .propertyText {
        font-size: 13px;
        line-height: 1.923;
        margin: 0;
        text-align: center;
        color: #e73462;
    }

    .secProperty .propertyNote {
        font-size: 10px;
        text-align: center;
        margin: 5px 0 0;
    }

    .secProperty .boxRight {
        margin-top: 10px;
    }
}

/*-----------------------------------------------
	secMeritList
-----------------------------------------------*/
.secMeritList {
    margin-top: 45px;
}

.secMeritList .boxListTitle {
    background: #fff2f5;
    position: relative;
    border-radius: 5px;
    border-left: 5px solid #e73462;
    height: 85px;
    padding: 14px 0 14px 26px;
}

.secMeritList .meritCategory {
    color: #e73462;
    font-size: 14px;
    margin: 0;
}

.secMeritList .meritTitle {
    font-size: 25px;
    color: #e73462;
    font-weight: bold;
    margin: 1px 0 0;
}

.secMeritList .meritContent {
    display: flex;
    align-items: center;
    gap: 45px;
    padding: 17px 0 0;
}

.secMeritList .boxPickUp .meritContent {
    border-top: 1px solid #bcbdbe;
    flex-direction: row-reverse;
}

.secMeritList .meritImage img{
    border-radius: 8px;
}

.secMeritList .meritImage .txtImgSmall {
    font-size: 12px;
    text-align: right;
    letter-spacing: 0;
    line-height: 1;
    margin: 16px 0 0 0;
}

.secMeritList .meritText {
    text-align: left;
    margin-top: 12px;
}

.secMeritList .meritHeading {
    font-size: 20px;
    font-weight: bold;
    margin: 0;
}

.secMeritList .meritDescription {
    font-size: 16px;
    line-height: 1.75;
    margin: 10px 0 0;
}

.secMeritList .boxPickUp {
    background: #fff2f5;
    padding: 0 100px 73px;
    margin-top: 96px;
    border-radius: 8px;
    position: relative;
    text-align: center;
}

.secMeritList .boxPickUp:before {
    content: "";
    position: absolute;
    top: -45px;
    /* 三角形を上部に配置 */
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 53px solid transparent;
    border-right: 53px solid transparent;
    border-bottom: 46px solid #fff1f5;
    /* 三角形の色を背景と合わせる */
}

.secMeritList .boxPickUpTitle {
    font-size: 17px;
    font-weight: bold;
    color: #e73462;
    position: relative;
    padding: 10px 0;
    margin-bottom: 22px;
}

.secMeritList .boxPickUpTitle:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 25px;
    height: 2px;
    background: #e73462;
}

.secMeritList .boxPickUpText {
    font-size: 20px;
    font-weight: bold;
    margin: 0;
    color: #e73462;
    line-height: 2;
}

.secMeritList .bonInner {
    text-align: left;
    margin-top: 50px;
}

.secMeritList .bonInner.inner02 {
    margin-top: 32px;
}

.secMeritList .bonInner .meritText {
    margin-top: 0px;
}

.secMeritList.meritList02 .meritContent {
    padding: 32px 0 0;
}

.secMeritList.meritList03 .meritContent {
    padding: 32px 0 0;
}
.secMeritList .foodMeritImage {
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
}

.secMeritList .meritSubHeading {
    font-size: 14px;
    font-weight: bold;
    margin: 0;
    margin-bottom: 6px;
}

/* チェックリスト */
.secMeritList .checkList {
    display: flex;
    justify-content: center;
    gap: 31px;
    flex-wrap: wrap;
    margin-top: 70px;
}

.secMeritList .checkItem {
    background: #fff;
    padding: 36px 20px;
    border-radius: 8px;
    text-align: center;
    width: 290px;
    height: 174px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    position: relative;
}

.secMeritList .checkNumber {
    background: #ff3c55;
    color: #fff;
    font-size: 9px;
    font-weight: bold;
    border-radius: 50%;
    position: absolute;
    top: -25px;
    left: calc(50% - 25px);
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.secMeritList .checkNumber .num {
    font-size: 16px;
    line-height: 1;
}

.secMeritList .checkItem:nth-child(2) .checkNumber {
    background: #478bca;
}

.secMeritList .checkItem:nth-child(3) .checkNumber {
    background: #ffca5b;
}

.secMeritList .checkText {
    font-size: 16px;
    margin: 0;
    font-weight: bold;
    line-height: 1.75;
}

/* 画像コンテンツ */
.secMeritList .imgContents {
    background-color: #fff;
    border-radius: 8px;
    padding: 48px 0 21px;
    margin: 45px auto 0;
    text-align: center;
    border: 1px solid #e73462;
    position: relative;
}

.secMeritList .imgContents .titTop {
    font-size: 20px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 1px;
    margin: 0;
}

.secMeritList .imgContents .txtTop {
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0px;
    margin: 22px 0 0;
}

.secMeritList .imgContents .boxImg {
    margin: 22px auto 55px;
}

.secMeritList .imgContents .boxImg02 {
    margin: 37px auto 55px;
}

.secMeritList .imgContents .boxBottom {
    position: relative;
    border-top: 1px solid #e73462;
}

.secMeritList .imgContents .boxBottom:before {
    content: "";
    position: absolute;
    top: -24px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-bottom: 24px solid #e73462;
}

.secMeritList .imgContents .boxBottom:after {
    content: "";
    position: absolute;
    top: -22px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-bottom: 24px solid #fff;
}

.secMeritList .imgContents .txtBottom {
    font-size: 20px;
    font-weight: bold;
    margin: 25px 0 0;
    line-height: 1.8;
}

.secMeritList .txtSmall {
    font-size: 12px;
    line-height: 1;
    letter-spacing: 0px;
    text-align: center;
    margin: 24px 0 0;
}

/* pickup内の画像リスト */
.secMeritList .boxPickUp .listPickUpImg {
    display: flex;
    align-items: center;
}

.secMeritList .boxPickUp .listItem {
    margin-right: 25px;
    width: 294px;
}

.secMeritList .boxPickUp .listItem:last-child {
    margin-right: 0px;
}

.secMeritList .boxPickUp .imgPickUp {
    border-radius: 4px;
    overflow: hidden;
}

@media only screen and (max-width:992px) {
    .secMeritList {
        padding: 0;
    }

    .secMeritList .meritTitle {
        font-size: 20px;
    }

    .secMeritList .meritCategory {
        letter-spacing: 0;
    }

    .secMeritList .boxListTitle {
        height: 70px;
        padding: 12px 0 12px 16px;
        width: 87.2%;
        margin: 0 auto;
    }

    .secMeritList .meritContent {
        display: block;
        padding: 32px 12.8% 0;
    }

    .secMeritList.meritList02 .meritContent {
        padding: 32px 12.8% 0;
    }
    .secMeritList.meritList03 .meritContent {
        padding: 32px 12.8% 0;
    }
    .secMeritList .foodMeritImage {
        border-radius: 4px;
    }
    .secMeritList .meritHeading {
        font-size: 16px;
        font-weight: bold;
        margin: 0;
        text-align: left;
    }

    .secMeritList .boxPickUp .meritHeading {
        text-align: center;
    }

    .secMeritList .meritDescription {
        font-size: 13px;
        margin: 10px 0 0;
        line-height: 1.923;
        text-align: left;
        letter-spacing: 0;
    }

    .secMeritList .meritSubHeading {
        font-size: 12px;
        margin: 10px 0 0;
        text-align: left;
        letter-spacing: 0;
        font-weight: bold;
    }

    .secMeritList .boxPickUpTitle {
        font-size: 14px;
        padding: 0 0 5px;
        margin-bottom: 22px;
        width: 87.2%;
        margin: 0 auto;
    }

    .secMeritList .boxPickUp .listPickUpImg{
        margin: 18px 0;
        overflow: hidden;
        width: 125.07%;
        left: calc(50% - 62.5%);
        position: relative;
    }

    .secMeritList .boxPickUp .listItem {
        margin-right: 11px;
        width: calc((100% - 22px) / 3);
    }

    .secMeritList .boxPickUp {
        padding: 0;
        margin-top: 66px;
    }
    .secMeritList .boxPickUp .spBox {
        width: 87.202%;
        margin: 0 auto;
        padding-bottom: 30px;
    }

    .secMeritList .bonInner .meritText {
        padding-top: 25px;
    }

    .secMeritList .bonInner {
        margin-top: 20px;
    }

    .secMeritList .boxPickUpText {
        font-size: 18px;
        line-height: 1.778;
        margin-top: 8px;
    }

    .secMeritList .checkList {
        gap: 16px;
        margin-top: 32px;
        margin-bottom: 32px;
    }

    .secMeritList .meritImage {
        width: 85.325%;
    }

    .secMeritList .boxPickUp .meritContent {
        flex-direction: column-reverse;
        display: flex;
        padding: 0;
        gap: 21px;
    }

    .secMeritList .imgContents {
        border-radius: 6px;
        padding: 25px 0 21px;
        margin: 32px auto 0;
    }

    .secMeritList .meritText {
        text-align: center;
    }

    .secMeritList .checkNumber {
        background: #ff3c55;
        color: #fff;
        font-size: 9px;
        font-weight: bold;
        border-radius: 5px 0 0 5px;
        position: static;
        top: -25px;
        left: calc(50% - 25px);
        width: 50px;
        height: 100%;
        margin: 0 14px 0 0;
    }

    .secMeritList .checkItem {
        background: #fff;
        padding: 0;
        border-radius: 5px;
        text-align: center;
        width: 100%;
        height: 101px;
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
        position: relative;
        display: flex;
        align-items: center;
    }

    .secMeritList .checkText {
        font-size: 14px;
        text-align: left;
        line-height: 1.714;
    }

    .secMeritList .imgContents .titTop {
        font-size: 16px;
    }

    .secMeritList .imgContents .txtTop {
        font-size: 13px;
        line-height: 1.923;
        letter-spacing: 0px;
        margin: 12px 0 0;
    }

    .secMeritList .imgContents .openBtn {
        font-size: 14px;
        position: relative;
        width: 69.85%;
        margin: 23px auto 0;
        border: 1px solid #bcbebf;
        border-radius: 50px;
        height: 46px;
        padding: 11px 0;
        z-index: 2;
        background: #fff;
        pointer-events: all;
        cursor: pointer;
    }
    .secMeritList .imgContents .closeBtn{
        font-size: 14px;
        position: relative;
        width: 69.85%;
        margin: 23px auto 0;
        border: 1px solid #bcbebf;
        border-radius: 50px;
        height: 46px;
        padding: 11px 0;
        z-index: 2;
        background: #fff;
        pointer-events: all;
        cursor: pointer;
        display: none;
    }

    .secMeritList .imgContents .openBtn:before {
        content: '';
        position: absolute;
        top: 50%;
        left: -22.075%;
        width: 22.075%;
        height: 1px;
        background: #bcbebf;
        z-index: 1;
    }
    .secMeritList .imgContents .openBtn::after {
        content: '';
        position: absolute;
        top: 50%;
        right: -22.075%;
        width: 22.075%;
        height: 1px;
        background: #bcbebf;
        z-index: 1;
    }
    .secMeritList .imgContents .closeBtn:before {
        content: '';
        position: absolute;
        top: 50%;
        left: -22.075%;
        width: 22.075%;
        height: 1px;
        background: #bcbebf;
        z-index: 1;
    }
    .secMeritList .imgContents .closeBtn::after {
        content: '';
        position: absolute;
        top: 50%;
        right: -22.075%;
        width: 22.075%;
        height: 1px;
        background: #bcbebf;
        z-index: 1;
    }

    .secMeritList .imgContents .boxImg {
        margin: 15px auto 35px;
        /* width: 90.465%; */
        width: 86.77%;
    }

    .slide .boxImg {
        display: none;
    }
    .slide .boxBottom {
        display: none;
    }

    .secMeritList .imgContents .txtBottom {
        font-size: 14px;
        margin: 15px 0 0;
        line-height: 2;
    }

    .secMeritList .txtSmall {
        font-size: 10px;
        line-height: 1.5;
        letter-spacing: 0px;
        margin: 24px 0 0;
    }

    .secMeritList .meritImage .txtImgSmall {
        text-align: left;
        margin: 16px 0 0 0;
    }
    .secMeritList .imgContents .boxBottom:after {
        top: -15px;
        border-left: 8px solid transparent;
        border-right: 8px solid transparent;
        border-bottom: 18px solid #fff;
    }
    .secMeritList .imgContents .boxBottom:before {
        top: -18px;
        border-left: 8px solid transparent;
        border-right: 8px solid transparent;
        border-bottom: 18px solid #e73462;
    }
}

/*-----------------------------------------------
	お問い合わせ
-----------------------------------------------*/
/*-----------------------------------------------
	フォーム
-----------------------------------------------*/
.secCmnForm {
    margin-top: 52px;
}

.secCmnForm .titForm {
    background: #E4407D;
    color: #FFF;
    font-size: 13px;
    font-weight: bold;
}

.secCmnForm .boxTable>dl:nth-child(2n+1) {
    background: #EEF5F9;
}

.secCmnForm .boxTable dl .txtNote {
    color: #000;
    font-size: 12px;
}

.secCmnForm .boxTable dl dd .boxList li {
    font-size: 13px;
}

.secCmnForm .boxTable dl dd .boxList li .custom-control-label::before,
.secCmnForm .boxTable dl dd .boxList li .custom-control-label::after {
    top: 2px;
}

.secCmnForm .boxTable dl dd .boxList li .custom-control-input:checked~.custom-control-label::before {
    background: #343434;
    border-color: #343434;
}

.secCmnForm .boxTable>dl>dt,
.secCmnForm .boxTable .boxChild dt {
    font-size: 13px;
    color: #28537C;
}

.secCmnForm .boxTable .boxChild dt {
    font-weight: normal;
}

.secCmnForm .boxTable dl dt .must {
    background: #D9534F;
}

.secCmnForm .boxTable dl dt .optional {
    background: #28537C;
}

.secCmnForm .boxTable dl dt .must,
.secCmnForm .boxTable dl dt .optional {
    font-size: 11px;
}

.secCmnForm .boxTable dl dd input[type="text"],
.secCmnForm .boxTable dl dd input[type="email"],
.secCmnForm .boxTable dl dd input[type="tel"] {
    font-size: 16px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1) inset;
    color: #000;
    height: 44px;
}

.secCmnForm .boxTable dl dd select {
    font-size: 16px;
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1) inset;
    color: #000;
    height: 44px;
    width: auto;
    max-width: 100%;
}

.secCmnForm .boxTable dl dd input[type="text"].inputRequired,
.secCmnForm .boxTable dl dd input[type="email"].inputRequired,
.secCmnForm .boxTable dl dd input[type="tel"].inputRequired,
.secCmnForm .boxTable dl dd select.inputRequired {
    background: #FEFAE6;
}

.secCmnForm .boxTable dl dd textarea {
    box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1) inset;
    height: 100px;
    font-size: 16px;
    line-height: 25px;
}

.secCmnForm .boxTable dl .w80 {
    width: 60px;
}

.secCmnForm .boxTable dl .w100 {
    width: 70px;
}

.secCmnForm .boxTable dl .inputName {
    width: 49%;
}

.secCmnForm .boxTable .btnZip {
    font-size: 12px;
    height: 34px;
    border: 1px solid #C1C1C1;
    background: #FFF;
    display: inline-flex;
    display: -webkit-inline-flex;
    align-items: center;
    -webkit-align-items: center;
    justify-content: center;
    -webkit-justify-content: center;
    box-shadow: 0 -2px #E5E5E5 inset;
    color: #222;
    padding: 0 10px;
    border-radius: 4px;
}

.secCmnForm .boxPrivacy .tit {
    font-size: 13px;
}

.secCmnForm .boxPrivacy .titPd {
    text-align: center;
}

.secCmnForm .boxPrivacy .titPd .inner {
    display: inline-block;
    vertical-align: top;
    position: relative;
    text-decoration: underline;
    color: #000;
}
.secCmnForm .boxPrivacy .txtSub {
    text-align: center;
}

/* .secCmnForm .boxPrivacy .titPd .inner::after {
    content: "";
    width: 8px;
    height: 8px;
    display: inline-block;
    vertical-align: top;
    margin-top: 4px;
    margin-left: 5px;
    border: 0px;
    border-bottom: solid 2px #2B3137;
    border-right: solid 2px #2B3137;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
} */

.secCmnForm .boxPrivacy .titPd.active .inner::after {
    margin-top: 9px;
    -ms-transform: rotate(225deg);
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

.secCmnForm .boxPrivacy .titPd+.boxTxt {
    display: none;
}

.secCmnForm .boxPrivacy .boxTxt {
    background: #EEE;
    border: 1px solid #E5E5E5;
    border-radius: 3px;
}

.secCmnForm .boxPrivacy .boxTxt .txt {
    font-size: 11px;
    line-height: 17px;
}

.secCmnForm .boxAuto {
    font-size: 13px;
}

.secCmnForm .boxAuto .custom-control-label::before,
.secCmnForm .boxAuto .custom-control-label::after {
    top: 1px;
}

.secCmnForm .boxAuto .custom-control-input:checked~.custom-control-label::before {
    background: #343434;
    border-color: #343434;
}

.secCmnForm .btnNext {
    margin-bottom: 0;
}

.secCmnForm .btnNext a {
    box-shadow: 0 -3px rgba(0, 0, 0, 0.1) inset;
    font-size: 15px;
    background: #E4407D;
}

@media only screen and (min-width:992px) {
    .secCmnForm:not(.co) {
        margin-top: 150px;
        padding-top: 70px;
        background: #FFF;
    }

    .secCmnForm .titForm {
        background: none;
        color: #2B3137;
        font-size: 22px;
    }

    .secCmnForm .boxStep li {
        background: #EFEFEF;
        color: #9D9D9D;
        height: 50px;
        font-size: 13px;
    }

    .secCmnForm .boxStep li:not(:first-child)::before {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border: 25px solid transparent;
        border-left: 17px solid #FFF;
        position: absolute;
        top: 0;
        left: 10px;
    }

    .secCmnForm .boxStep li:not(:first-child)::after {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border: 25px solid transparent;
        border-left: 17px solid #EFEFEF;
        position: absolute;
        top: 0;
        left: 0;
    }

    .secCmnForm .boxStep li:not(:first-child) span::after {
        content: "";
        display: block;
        width: 10px;
        height: 100%;
        background: #FFF;
        position: absolute;
        top: 0;
        left: 0;
    }

    .secCmnForm .boxStep li.on {
        background: #E4407D;
    }

    .secCmnForm .boxStep li.on+li::after {
        border-left-color: #E4407D;
    }

    .secCmnForm .boxTable {
        border-top: 1px solid #D1DEE5;
    }

    .secCmnForm .boxTable dl {
        border: 1px solid #D1DEE5;
        border-top: none;
    }

    .secCmnForm .boxTable dl.boxChild {
        border-left: none;
        border-right: none;
    }

    .secCmnForm .boxTable dl.boxChild:last-child {
        border-bottom: none;
    }

    .secCmnForm .boxTable>dl>dt {
        width: 200px;
        border-right: 1px solid #D1DEE5;
        font-size: 13px;
    }

    .secCmnForm .boxTable .boxChild dt {
        width: 110px;
        border-right: 1px solid #D1DEE5;
        font-size: 13px;
        font-weight: bold;
    }

    .secCmnForm .boxTable>dl>dd {
        width: calc(100% - 200px);
    }

    .secCmnForm .boxTable .boxChild dd {
        width: calc(100% - 110px);
    }

    .secCmnForm .boxTable dl dd .boxList li {
        font-size: 12px;
    }

    .secCmnForm .boxTable dl .w400 {
        width: 400px;
        max-width: calc(100% - 100px);
    }

    .secCmnForm .boxTable dl.boxChild .w400 {
        max-width: 100%;
    }

    .secCmnForm .boxTable dl dd textarea {
        height: 150px;
        font-size: 13px;
        line-height: 20px;
    }

    .secCmnForm .boxTable dl dd input[type="text"],
    .secCmnForm .boxTable dl dd input[type="email"],
    .secCmnForm .boxTable dl dd input[type="tel"],
    .secCmnForm .boxTable dl dd select {
        font-size: 13px;
    }

    .secCmnForm .boxPrivacy .tit {
        font-size: 15px;
        font-weight: bold;
    }

    .secCmnForm .boxPrivacy .titPd {
        text-align: left;
    }

    .secCmnForm .boxPrivacy .titPd .inner {
        /* text-decoration: none; */
        color: #000;
        margin-bottom: 10px;
    }

    .secCmnForm .boxPrivacy .txtSub {
        text-align: left;
    }

    .secCmnForm .boxPrivacy .titPd .inner::after {
        display: none;
    }

    .secCmnForm .boxPrivacy .titPd+.boxTxt {
        display: block;
    }

    .secCmnForm .boxPrivacy .boxTxt {
        border-radius: 0;
    }

    .secCmnForm .boxPrivacy .boxTxt .txt {
        font-size: 12px;
        line-height: 24px;
    }

    .secCmnForm .btnNext {
        padding-bottom: 71px;
    }

    .secCmnForm .btnNext a {
        font-size: 18px;
    }

}

@media only screen and (min-width:1200px) {
    .secCmnForm .boxTable dl .w80 {
        width: 80px;
    }

    .secCmnForm .boxTable dl .w100 {
        width: 100px;
    }

    .secCmnForm .boxTable dl .inputName {
        width: 192.5px;
    }

    .secCmnForm .boxTable dl .inputName2 {
        margin-left: 15px;
    }
}

@media only screen and (min-width:1580px) {
    .secCmnForm .boxTable dl dd .boxList li {
        font-size: 13px;
        -ms-flex: 0 0 33.333333%;
        flex: 0 0 33.333333%;
        max-width: 33.333333%;
    }
}

/* 確認画面・完了画面 */
.secCmnForm.co dl dd {
    font-size: 13px;
}

.secCmnForm.co .titOk {
    font-size: 14px;
    line-height: 26px;
}

.secCmnForm.co .txtOk {
    font-size: 11px;
    line-height: 17px;
}

.secCmnForm.co .boxOk+.btnNext {
    margin-top: 30px;
}

@media only screen and (min-width:360px) {
    .secCmnForm.co .titOk {
        font-size: 15px;
        line-height: 28px;
    }

    .secCmnForm.co .txtOk {
        font-size: 12px;
        line-height: 19px;
    }
}

@media only screen and (min-width:992px) {
    .secCmnForm.co dl dd {
        background: #FFF;
    }

    .secCmnForm.co dl dt {
        background: #EEF5F9;
    }

    .secCmnForm.co .boxOk {
        margin-top: 64px;
    }

    .secCmnForm.co .titOk {
        font-size: 19px;
    }

    .secCmnForm.co .txtOk {
        font-size: 14px;
        line-height: 26px;
    }

    .secCmnForm.co .btnNext {
        padding-bottom: 0;
    }

    .secCmnForm.co .boxOk+.btnNext {
        margin-top: 65px;
    }
}

/* フォーム */
.secContact {
    max-width: 1132px;
    width: 100%;
    margin: 40px auto 0;
}

.secContact .formTitleBox {
    background: #fff2f5;
    position: relative;
    border-radius: 5px;
    border-left: 5px solid #e73462;
    height: 85px;
    padding: 24px 0 24px 26px;
}

.secContact .formTitle {
    font-size: 25px;
    color: #e73462;
    font-weight: bold;
    margin: 0;
}

.secContact .formTxt {
    font-size: 16px;
    margin: 42px 0 0;
    text-align: center;
}

.secContact .listStep {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin: 32px 0 48px;
}

.secContact .listStep .stepItem {
    width: 95px;
    height: 36px;
    background: #eeeeee;
    display: flex;
    align-items: center;
    font-size: 14px;
    justify-content: center;
    border-radius: 50px;
}

.secContact .listStep .stepItem.on {
    background: none;
    border: 1px solid #e73462;
    color: #e73462;
}

.secContact .mainWrapper {
    padding: 48px;
    max-width: unset;
    width: 100%;
    background: #faf9f9;
}

.secCmnForm:not(.co) {
    margin-top: 0;
    padding-top: 0;
    background: none;
}

.secCmnForm .boxTable {
    margin: 0 !important;
}

@media only screen and (max-width: 992px) {
    .secContact {
        width: 100%;
        max-width: 100%;
    }

    .secContact .mainWrapper {
        padding: 0 !important;
        max-width: unset;
        width: 100%;
        margin-top: 30px;
        padding-bottom: 135px !important;
    }

    .secCmnForm .btnNext {
        padding-bottom: 0;
    }

    .secContact .formTitleBox {
        height: 70px;
        padding: 22px 0 22px 16px;
        width: 87.2%;
        margin: 0 auto;
    }

    .secContact .formTitle {
        font-size: 20px;
    }
    .secContact .formTxt {
        font-size: 11px;
        margin: 17px 0 0;
    }
    .secContact .listStep {
        gap: 10px;
        width: 74.4%;
        margin: 20px auto;
    }
    .secCmnForm .boxPrivacy .boxTxt{
        display: none;
    }
}
/*-----------------------------------------------
	フッター上のロゴ
-----------------------------------------------*/
.secFooterLogo{
    width: 100%;
    height: 90px;
    margin-top: 48px;
    padding: 17px 0;
    position: relative;
    border-top:1px solid rgba(0, 0, 0, 0.2);
}
.secFooterLogo .innerWrapper{
    max-width: 1132px;
    margin: 0 auto;
}
.mainWrapper a.inner{
    color: #000;
}
@media only screen and (max-width: 992px) {
    .secFooterLogo{
        height: 65px;
        margin-top: 0;
        padding: 11px 0;
    }
    .secFooterLogo .innerWrapper{
        max-width: unset;
        width: 68px;
        margin: 0 auto;
    }
    .secFooterTop{
        position: relative;
    }
    .secFooterTop .btnTop {
        width: 90px;
        height: 44px;
        border: 1px solid #C2C7CA;
        font-size: 12px;
        color: #E4407D;
        line-height: 42px;
        border-radius: 22px;
        position: absolute;
        top: -155px;
        right: 3.125%;
        z-index: 9999;
        display: flex;
        gap: 5px
    }
}
/*-----------------------------------------------
	フッター
-----------------------------------------------*/
#footer {
    background: #2B3137;
}

#footer .footerWrapper {
    max-width: 1132px;
    width: 100%;
    display: block;
    position: relative;
    margin: 0 auto;
}

@media only screen and (min-width:992px) {
    #footer .wrapperPc {
        max-width: 1132px;
        width: 100%;
    }
}

/* ページ先頭へボタン */
@media only screen and (min-width:992px) {
    .secFooterTop .btnTop {
        width: 90px;
        height: 44px;
        border: 1px solid #C2C7CA;
        font-size: 12px;
        color: #E4407D;
        line-height: 42px;
        border-radius: 22px;
        position: fixed;
        bottom: 3.125%;
        right: 3.125%;
        z-index: 9999;
    }

    .secFooterTop .btnTop:hover {
        opacity: 1;
        -webkit-filter: brightness(1.1);
        filter: brightness(1.1);
    }

    .secFooterTop img {
        margin-right: 6px;
    }
}

/* secFooterTxt */
.secFooterTxt {
    color: #AAABAC;
    background: #24292E;
    border-bottom: solid 1px #3a3f43;
    font-size: 11px;
    line-height: 1.7;
    padding: 12px 0;
    width: 100%;
}

@media only screen and (min-width:992px) {
    .secFooterTxt {
        color: #fff;
        font-size: 12px;
    }
}

/* secFooterLink */
.secFooterLink {
    background: #24292E;
}

.secFooterLink .txtItem {
    border-bottom: 1px solid #434343;
    font-size: 13px;
    line-height: 1;
    background: url(../img/common/footerArrow.gif) calc(100% - 21px) center / 6px auto no-repeat;
}

.secFooterLink .schoolWrap {
    margin: 0;
    width: 100%;
}

.secFooterLink .schoolWrap .schoolTit {
    font-size: 13px;
    padding: 1rem;
    background: url(../img/common/footerArrowBottom.gif) calc(100% - 21px) center / 9px auto no-repeat;
    cursor: pointer;
    margin-bottom: 0;
}

.secFooterLink .schoolWrap .schoolTit.on {
    background: url(../img/common/footerArrowTop.gif) calc(100% - 21px) center / 9px auto no-repeat;
}

.secFooterLink .schoolWrap .schoolListOut {
    display: none;
}

.secFooterLink .schoolWrap .schoolList {
    display: flex;
    display: -webkit-flex;
    flex-wrap: wrap;
    padding: 0 1rem 1rem;
}

.secFooterLink .schoolWrap .schoolItem {
    padding: 0 23px 0 0;
    position: relative;
}

.secFooterLink .schoolWrap .schoolItem::after {
    position: absolute;
    content: "";
    right: 8px;
    bottom: 3px;
    width: 1px;
    height: 13px;
    background: #AAABAC;
}

.secFooterLink .schoolWrap .schoolItem:last-child::after {
    display: none;
}

.secFooterLink .schoolWrap .schoolItem:first-child {
    padding-left: 0;
}

.secFooterLink .schoolWrap .schoolItem:nth-child(5) {
    padding-left: 0;
}

.secFooterLink .schoolWrap .schoolItem a {
    font-size: 12px;
    color: #AAABAC;
    position: relative;
    letter-spacing: 0.5px;
}

.secFooterLink .schoolWrap .schoolItem a::after {
    content: "";
    top: -1px;
    right: -8px;
    position: absolute;
    width: 6px;
    height: 6px;
    background: url(../img/common/imgFooterLink.gif) center top / cover no-repeat;
}

@media only screen and (min-width:992px) {
    .secFooterLink .item:nth-child(1) {
        width: 22%;
    }

    .secFooterLink .item:nth-child(2) {
        width: 22%;
    }

    .secFooterLink .item:nth-child(3) {
        width: 20%;
    }

    .secFooterLink .item:nth-child(4) {
        width: 20%;
    }

    .secFooterLink .item:nth-child(5) {
        width: 16%;
    }

    .secFooterLink .txtItem {
        font-size: 11px;
        border-bottom: none;
        background: none;
    }

    .secFooterLink .menuItem {
        font-size: 10px;
        line-height: 15px;
    }

    .secFooterLink .menuItem li {
        padding: 2.5px 0;
    }

    .secFooterLink .menuItem a {
        color: #AAABAC;
    }

    .secFooterLink .schoolWrap {
        margin: 30px auto 0;
        width: 89.584%;
        padding-left: 4px;
    }

    .secFooterLink .schoolWrap .schoolListOut {
        display: block;
    }

    .secFooterLink .schoolWrap .schoolList {
        padding: 0;
    }

    .secFooterLink .schoolWrap .schoolTit {
        font-size: 11px;
        padding: 0;
        background: none;
        cursor: text;
        margin-bottom: 1rem;
    }

    .secFooterLink .schoolWrap .schoolItem a {
        font-size: 10px;
    }
}

@media only screen and (min-width:1200px) {
    .secFooterLink .txtItem {
        font-size: 13px;
    }

    .secFooterLink .menuItem {
        font-size: 12px;
        line-height: 18px;
    }

    .secFooterLink .menuItem li {
        padding: 3px 0;
    }

    .secFooterLink .schoolWrap .schoolTit {
        font-size: 13px;
    }

    .secFooterLink .schoolWrap .schoolItem a {
        font-size: 12px;
    }
}

/* secFooterDescription */
.secFooterDescription {
    border-bottom: 1px solid #616B76;
}

.secFooterDescription .txtDescription {
    font-size: 10px;
    line-height: 16px;
    height: 64px;
    color: #AAABAC;
}

.secFooterDescription .txtDescription.on {
    height: auto;
}

.secFooterDescription .txtAccordion {
    font-size: 10px;
    color: #3B3939;
}

.secFooterDescription .txtAccordion02,
.secFooterDescription .txtDescription.on+.txtAccordion .txtAccordion01 {
    display: none;
}

.secFooterDescription .txtDescription.on+.txtAccordion .txtAccordion02 {
    display: inline;
}

@media only screen and (min-width:992px) {
    .secFooterDescription {
        border-bottom: none;
        padding-top: 45px !important;
    }

    .secFooterDescription .txtDescription {
        font-size: 12px;
        line-height: 2.33;
        height: auto;
    }
}

/* secFooterCompany */
.secFooterCompany .txtLogo02 {
    font-size: 11px;
    margin-top: 50px !important;
}

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

    .secFooterCompany .txtLogo02,
    .secFooterCompany .txtCorp {
        font-size: 12px;
        line-height: 22px;
    }

    .secFooterCompany .txtCorp a {
        color: #AAABAC;
    }

    .secFooterCompany .txtCorp a::after {
        content: "";
        top: 2px;
        right: -3px;
        position: absolute;
        width: 6px;
        height: 6px;
        background: url(../img/common/imgFooterLink.gif) center top / cover no-repeat;
    }
}

/* secFooterContact */
.secFooterContact .titTel {
    font-size: 13px;
}

.secFooterContact .titNum {
    font-size: 12px;
    line-height: 15px;
    background: #EB6100;
    width: 40px;
    height: 40px;
}

.secFooterContact .txtNum {
    font-size: 24px;
    padding-left: 39px;
    letter-spacing: 1px;
    background: url(../img/common/footerTel.gif) 12px center / 22px auto no-repeat;
}

.secFooterContact .txtTime {
    font-size: 11px;
    line-height: 17px;
    color: #FFF;
}

.secFooterContact .txtTime .space {
    display: none;
}

.secFooterContact .btnContact {
    width: 81.333%;
    background: #FBB731;
    color: #401e02;
    height: 66px;
    border-radius: 33px;
}

.secFooterContact .btnContact:hover {
    background: #FCC55A;
}

.secFooterContact .btnContact01 {
    font-size: 14px;
}

.secFooterContact .btnContact02 {
    width: 40px;
    height: 26px;
    font-size: 12px;
    line-height: 18px;
    border: 1px solid #401e02;
    margin-left: 8px;
}

.secFooterContact .boxCorpSp {
    border-top: 1px solid #616B76;
    border-bottom: 1px solid #616B76;
}

.secFooterContact .boxCorpSp.jc-c {
    justify-content: center;
}

.secFooterContact .boxCorpSp a {
    font-size: 12px;
    height: 58px;
    color: #AAABAC;
}

.secFooterContact .boxCorpSp a.mr40 {
    margin: 0 20px;
    padding-top: 21px;
}

.secFooterContact .boxCorpSp .inner::after {
    content: "";
    top: -4px;
    right: -6px;
    position: absolute;
    width: 6px;
    height: 6px;
    background: url(../img/common/imgFooterLink.gif) center top / cover no-repeat;
}

@media only screen and (min-width:992px) {
    .secFooterContact .titTel {
        font-size: 13px;
    }

    .secFooterContact .btnContact {
        width: 250px;
        height: 66px;
        transition: 0.2s all ease-in-out;
        -webkit-transition: 0.2s all ease-in-out;
    }

    .secFooterContact .btnContact01 {
        font-size: 15px;
        letter-spacing: -1px;
    }

    .secFooterContact .btnContact02 {
        font-size: 12px;
        letter-spacing: -1px;
        margin: 0 0 0 8px;
    }

    .secFooterContact .txtTime {
        font-size: 11px;
        line-height: 20px;
        text-align: left !important;
    }
}

@media only screen and (min-width:1350px) {
    .secFooterContact .btnContact {
        width: 320px;
    }

    .secFooterContact .txtTime {
        font-size: 12px;
    }
}

@media only screen and (max-width:992px) {
    .secFooterContact .cmnBtnContact {
        width: 76.41%;
        margin: 0 auto;
        height: 50px;
        border-radius: 50px;
        margin-top: 32px;
        letter-spacing: 1px;
    }
    .secFooterContact .cmnBtnContact .imgTit {
        width: 29px;
    }
    .secFooterContact .txtTime {
        text-align: center !important;
    }
}

/* secFooterHoldings */
.secFooterHoldings {
    padding-bottom: 25px;
}

.secFooterHoldings .logoHoldings {
    width: 175px;
    margin: 0 auto 14px !important;
}

.secFooterHoldings .txtGroup {
    font-size: 10px;
    text-align: center;
    font-weight: bold;
    color: #fff;
}
.secFooterHoldings .txtCopy {
    font-size: 10px;
    opacity: 0.5;
    letter-spacing: 0.5px;
}

@media only screen and (min-width:992px) {
    .secFooterHoldings {
        padding-bottom: 78px;
    }

    .secFooterHoldings .logoHoldings {
        width: 217px;
        margin: 0 !important;
    }
}

/* 749.jpバナー */
.secFooterSite {
    display: block;
    background: #e73462;
    color: #fff;
    height: 80px;
    position: relative;
}

.secFooterSite:hover {
    color: #fff;
}

.secFooterSite::after {
    content: "";
    width: 8px;
    height: 12px;
    background: url(../img/common/bnrLinkArrow.gif) left top no-repeat;
    background-size: 8px;
    position: absolute;
    top: 35px;
    right: 18px;
}

.secFooterSite .txtSearch {
    position: absolute;
    bottom: -100px;
    left: 5px;
    margin: 0;
}

.secFooterSite .txt {
    position: absolute;
    top: 28px;
    right: 0;
    width: 100%;
    text-align: center;
    margin: 0;
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0.8px;
}

@media only screen and (min-width:992px) {
    .secFooterSite {
        height: 100px;
    }

    .secFooterSite::after {
        width: 12px;
        height: 18px;
        background-size: 12px;
        top: 42px;
        right: calc(50% - 565px);
    }

    .secFooterSite .txtSearch {
        left: 20px;
    }

    .secFooterSite .txt {
        top: 55px;
        font-size: 18px;
        letter-spacing: 1.8px;
        text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.3);
    }

    .secFooterSite .logo {
        position: absolute;
        width: 100%;
        top: 17px;
        left: 0;
        margin: 0;
        text-align: center;
    }
}

@media only screen and (min-width:1400px) {
    .secFooterSite .txtSearch {
        left: 0px;
    }

    .secFooterSite .txt {
        width: auto;
        top: 36px;
        right: 25px;
        text-align: right;
    }

    .secFooterSite .logo {
        width: auto;
        top: 37px;
        left: 164px;
        text-align: left;
    }
}
@media only screen and (max-width:992px) {
    .secFooterSite .txtSearch {
        bottom: -80px;
    }
}
/*-----------------------------------------------
	オーバーレイ
-----------------------------------------------*/
#overlay {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    opacity: 0;
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10000;
    width: calc(100% - 300px);
}

.menuOpen #overlay {
    display: block;
    animation: menuOpenOpacity 0.3s linear forwards;
}

.menuClose #overlay {
    display: block;
    animation: menuCloseOpacity 0.3s linear forwards;
}

@keyframes menuOpenOpacity {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes menuCloseOpacity {
    0% {
        opacity: 1;
    }

    100% {
        opacity: 0;
    }
}

#overlay .btnClose {
    position: absolute;
    top: 35px;
    right: 27px;
}

#overlay .txtClose {
    font-size: 10px;
}

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

    #overlay,
    .menuOpen #overlay,
    .menuClose #overlay {
        display: none;
    }
}

/*-----------------------------------------------
	スマホメニュー
-----------------------------------------------*/
#spMenu {
    width: 80%;
    height: 100%;
    top: 0;
    right: 0;
    z-index: -1;
    opacity: 0;
    position: fixed !important;
}

.menuOpen #spMenu {
    z-index: 0;
    background: #222;
    opacity: 1;
}

#spMenu .boxList01 li {
    border-bottom: 1px solid #434343;
}

#spMenu .boxList01 a {
    font-size: 14px;
    line-height: 68px;
}

#spMenu .boxList02 li {
    border-bottom: 1px solid #222;
}

#spMenu .boxList02 a {
    font-size: 13px;
    line-height: 50px;
    background: #313131;
}

@media only screen and (min-width:375px) {
    #spMenu {
        width: 300px;
    }
}

@media only screen and (min-width:992px) {
    #spMenu {
        display: none;
    }
}

/* ▼coPage */
.coPage .secCmnForm .btnNext a {
    display: block;
}
.coPage #header {
    position: absolute;
}
.coPage .sendFormbox{
    text-align: center;
}
.coPage .btnSendCo .btnFormtxt{
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}
.coPage .btnNext {
    padding-bottom: 20px;
}
.coPage .btnSendCoBack{
    display: block;
    width: 50%;
    height: 80px;
    background: #eeeeee;
    margin: 0 auto 60px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: #000;
    font-weight: bold;
    text-decoration: none;
}
.coPage .btnSendCoBack .btnFormtxt{
    margin: 0;
}

.coPage .secFormTable th {
    padding: 30px 0;
    vertical-align: middle;
}
.coPage .secFormTable td {
    vertical-align: middle;
    padding: 20px 0px;
}
.btnSendCo.no_tap,
.btnSendCoBack.no_tap{
    opacity: 0.3!important;
    pointer-events: none!important;
    transition: none!important;
}
.btnSendCo.no_tap{
    background: url(../img/common/iconLoader.png) center center / 32px auto no-repeat,#fff!important;
    font-size: 0!important;
}
.btnSendCo.no_tap .btnFormtxt{
    font-size: 0!important;
}
.secForm .btnForm + .btnForm{
    margin-top: 20px;
}

@media only screen and (max-width:992px) {
    .coPage #header {
        padding: 10px 0;
    }
    .coPage .secForm .formIn{
        padding-top: 20px;
    }
    .coPage .secFormTable th {
        padding: 10px 0 0;
        vertical-align: middle;
    }
    .coPage .secFormTable td {
        padding: 5px 0px 10px;
        font-size: 13px;
    }
    .secForm .btnSendCoBack{
        max-width: 260px;
        width: 92%;
        height: 50px;
    }
    .coPage .btnSendCo .btnFormtxt {
        height: 65px;
        font-size: 15px;
    }
    .coPage .btnNext {
        padding-bottom: 0;
        margin-top: 20px;
    }
    .coPage .btnSendCoBack {
        width: 72%;
        height: 60px;
        margin: 0 auto 60px;
        font-size: 14px;
    }
}
.coPage.ok .oktxt{
    text-align: center;
    font-size: 18px;
    line-height: 2;
}
.coPage.ok .secCmnBack{
    margin-top: 30px;
}
@media only screen and (max-width:992px) {
    .coPage.ok .oktxt{
        text-align: left;
        font-size: 13px;
        width: 87.2%;
        margin: 40px auto;
    }
    .coPage.ok .secCmnBack{
        margin-top: 20px;
    }
}

@media only screen and (max-width:360px) {
    .boxLinkContact .boxLeft .txt04 {
        font-size: 11px;
    }
    .boxLinkContact .boxLeft .txt01 {
        font-size: 14px;
    }
    .boxLinkContact .boxLeft .txt03 {
        font-size: 25px;
    }
    .secMerit .meritTitle {
        font-size: 17px;
    }
    .secFood .foodTitle {
        font-size: 18px;
    }
    .secFood .foodDescription {
        font-size: 12px;
    }
    .secProperty .propertyTitle {
        font-size: 18px;
    }
    .secProperty .propertyButton {
        font-size: 14px;
    }
    .secMerit .meritHeading {
        font-size: 13px;
    }
    .secMerit .meritDescription {
        font-size: 10px;
    }
    .secMerit .meritImage {
        min-height: 128px;
    }
    .boxLinkContact.contact .boxLeft .txt02, .boxLinkContact.contact02 .boxLeft .txt02, .boxLinkContact.contact03 .boxLeft .txt02, .boxLinkContact.contact04 .boxLeft .txt02, .boxLinkContact.contact05 .boxLeft .txt02 {
        font-size: 11px;
    }
    .boxLinkContact.contact .boxLeft .txt01, .boxLinkContact.contact02 .boxLeft .txt01, .boxLinkContact.contact03 .boxLeft .txt01, .boxLinkContact.contact04 .boxLeft .txt01, .boxLinkContact.contact05 .boxLeft .txt01 {
        font-size: 11px;
    }
    .boxLinkContact .imgTit.spSmall {
        width: 70px;
        top: 63px;
    }
    .boxLinkContact.contact .boxLeft .txt03, .boxLinkContact.contact02 .boxLeft .txt03, .boxLinkContact.contact03 .boxLeft .txt03, .boxLinkContact.contact04 .boxLeft .txt03, .boxLinkContact.contact05 .boxLeft .txt03 {
        font-size: 20px;
    }
    .secFood .foodDescription {
        font-size: 12px;
    }
    .secMeritList .meritHeading {
        font-size: 14px;
    }
    .secMeritList .meritDescription {
        font-size: 12px;
    }
    .secMeritList .boxPickUpText {
        font-size: 15px;
    }
    .secMeritList .checkText {
        font-size: 12px;
    }
    .secMeritList .meritSubHeading {
        font-size: 10px;
    }
    .secMeritList .meritImage .txtImgSmall {
        font-size: 10px;
    }
    .boxLinkContact.estateSearch .boxLeft .txt05 {
        font-size: 20px;
    }
    .boxLinkContact .boxLeft .txt01 {
        font-size: 13px;
    }
    .secMerit .meritTitle {
        font-size: 16px;
    }
}