@charset "utf-8";
/* --------------------------------
ページ用css
-------------------------------- */
@keyframes dDetailShow {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0px);
    }
}

/*
class,id側
animation-duration: 1s;
animation: dDetailShow 0.3s linear 0s;
*/

.dl-top-msg{
    width: 93%;
    margin:20px auto 0px auto;
    text-align: center;
    font-size: 17px;
}

/*上下ナビゲーションここから*/

.dl-tblbox {
    display: table;
    border-spacing: 0;
    border-collapse: collapse;
    width: 93%;
    margin-left: 3.5%;
}

.dl-hd {
    margin-top: 20px;
    margin-bottom: 20px;
}


.dl-ft {
    margin-top: 40px;
    margin-bottom: 40px;
}


.dl-cellbox {
    display: table-cell;
    width: 50%;
}

.dl-tblbox .dl-cellbox:nth-child(1) {
    padding-right: 2%;
}



.dl-cellbox a {
    display: block;
    box-shadow: inset 2px 1px 1px rgba(255, 255, 255, 0.7), 2px 1px 1px rgba(0, 0, 0, 0.3);
    border-radius: 4px;
    background-color: #EEEEEE;
    text-decoration: none;
    color: #000000;
    font-size: 16px;
    text-align: center;
    position: relative;
    height: 58px;
    line-height: 60px;
}


.dl-cellbox a.dl-n-on {
    box-shadow: inset 2px 1px 1px rgba(255, 255, 255, 0.4), 2px 1px 1px rgba(0, 0, 0, 0.6);
    color: #FFFFFF;
    z-index: 50;
    background-color: #3573CF;
}

.dl-cellbox a::before {
    content: "";
    display: block;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    width: 6px;
    height: 6px;
    border-top: 2px solid #AAAAAA;
    border-right: 2px solid #AAAAAA;
    position: absolute;
    top: 28px;
    left: 28%;
    left: calc( 50% - 3.6em);
}

.dl-nav2 .dl-txt {
    padding-left: 18px;
}

.dl-nav2.dl-n-on .dl-txt {
    padding-left: 0px;
}

.dl-cellbox a.dl-n-on::before {
    -ms-transform: rotate(0deg);
    /*dl-n-onでない時のリセット*/
    -webkit-transform: rotate(0deg);
    /*dl-n-onでない時のリセット*/
    transform: rotate(0deg);
    /*dl-n-onでない時のリセット*/
}

.dl-hd .dl-cellbox a.dl-n-on::before {
    content: "";
    display: block;
    position: absolute;
    border-top: 9px solid rgba(0, 0, 0, 0.6);
    border-right: 9px solid transparent;
    border-bottom: 9px solid transparent;
    border-left: 9px solid transparent;
    top: 57px;
    left: 42%;
    left: calc( 50% - 7px);
}

.dl-ft .dl-cellbox a.dl-n-on::before {
    content: "";
    display: block;
    position: absolute;
    border-top: 9px solid transparent;
    border-right: 9px solid transparent;
    border-bottom: 9px solid rgba(0, 0, 0, 0.6);
    border-left: 9px solid transparent;
    top: auto;
    bottom: 56px;
    left: 42%;
    left: calc( 50% - 7px);
}



.dl-hd a.dl-n-on::after {
    background: transparent;
    /*dl-n-onでない時のリセット*/
    width: auto;
    /*dl-n-onでない時のリセット*/
    height: auto;
    /*dl-n-onでない時のリセット*/
}

.dl-hd .dl-cellbox a.dl-n-on::after {
    content: "";
    display: block;
    position: absolute;
    border-right: 9px solid transparent;
    border-bottom: 9px solid transparent;
    border-left: 9px solid transparent;
    top: 57px;
    left: 40%;
    left: calc( 50% - 9px);
    border-top: 9px solid #3573CF;
}

.dl-ft .dl-cellbox a.dl-n-on::after {
    content: "";
    display: block;
    position: absolute;
    border-top: 9px solid transparent;
    border-right: 9px solid transparent;
    border-left: 9px solid transparent;
    top: auto;
    bottom: 56px;
    left: 40%;
    left: calc( 50% - 9px);
    border-bottom: 9px solid #3573CF;
}

/*上下ナビゲーションここまで*/

/*最初から表示している部分ここから*/

.deal-bg {
    background: #F4F4F4;
    padding-top: 3.5%;
    padding-bottom: 3.5%;
}

.dttl-inbox1 {
    background-color: #FFEFE1;
    padding: 20px 0px 20px 0px;
    padding: 6.25vw 0px 6.25vw 0px;

}

.dttl-inbox2 {
    position: relative;
}


.deal-ttl {
    font-size: 35px;
    font-size: 10.9375vw;
    text-align: center;
    font-weight: 600;
    padding-top: 13px;
    /*padding-topはまだvw指定しない*/
}

.ddeco {
    display: block;
}

.deal-deco1 {
    width: 112px;
    height: 54px;
    width: 35vw;
    height: 16.875vw;
}

.deal-deco2 {
    width: 54px;
    height: 54px;
    position: absolute;
    top: 0px;
    left: 122px;
    width: 16.875vw;
    height: 16.875vw;
    left: 38.125vw;
}

.deal-deco3 {
    width: 30px;
    height: 54px;
    position: absolute;
    top: 0px;
    left: 186px;
    width: 9.375vw;
    height: 16.875vw;
    left: 58.125vw;
}

.deal-deco4 {
    width: 54px;
    height: 54px;
    position: absolute;
    top: 0px;
    left: 226px;
    width: 16.875vw;
    height: 16.875vw;
    left: 70.0625vw;
}

.dttl-decos {
    width: 280px;
    height: 54px;
    width: 87.5vw;
    height: 16.875vw;
    position: relative;
    overflow: visible;
    margin: 0px auto 0px auto;
}

.dmain {
    display: block;
    width: 50%;
    height: auto;
}

.deal-main2 {
    position: absolute;
    top: 0px;
    left: 50%;
}

.dmain-imgadd {
    display: block;
    width: 100px;
    height: 50px;
    position: absolute;
    bottom: 0px;
    left: 11%;
    background: radial-gradient(circle at bottom, rgba(240, 239, 238, 1.0) 8%, rgba(240, 239, 238, 0) 70%);
}

.dmtxt {
    display: block;
}

.dmain-txt1add {
    font-weight: 400;
    font-size: 12px;
    position: absolute;
    bottom: 30px;
    left: 10px;
    font-size: 3.57vw;
    bottom: 10vw;
    left: 3vw;
}

.dmain-txt1add2 {
    color: #FFFFFF;
    font-weight: 400;
    font-size: 9px;
    position: absolute;
    top: 2px;
    right: 52%;
    right: calc( 50% + 8px);

}

.dmain-txt1 {
    font-weight: 500;
    font-size: 19px;
    position: absolute;
    bottom: 6px;
    left: 10px;
    font-size: 5.5vw;
    bottom: 1.875vw;
    left: 3vw;
}

.dmain-txt2 {
    color: #FFFFFF;
    font-weight: 300;
    font-size: 19px;
    position: absolute;
    bottom: 6px;
    right: 10px;
    font-size: 5.5vw;
    bottom: 1.875vw;
    right: 3vw;
}

.de-sttl-box {
    line-height: 30px;
    padding: 15px 0px 15px 0px;
    margin: 0px 4px 0px 4px;
    border-bottom: 2px dotted #949470;
}

.de-sttl-box2 {
    line-height: 30px;
    padding: 15px 0px 15px 0px;
    margin: 0px 4px 0px 4px;
}

.de-sttl {
    font-size: 15px;
    /*padding-left:20px;*/
}

.dl-ifg1 {
    margin-right: 4px;
    position: relative;
    top: -2px;
}

.de-sttl-s {
    font-size: 11px;
}

.ds-gold {
    color: #737326;
}

.ds-gold .ds-black,
.ds-orange .ds-black {
    color: #000000;
}

.ds-orange,
.ds-gold .ds-orange,
.ds-black .ds-orange {
    color: #FF7800;
}

.de-place-box {
    position: relative;
    padding: 10px 0px;
    overflow: hidden;
}

.de-place {
    width: 54%;
    padding: 0px 4px 0px 4px;
    font-size: 13px;
    display: table;

}

.de-place:nth-child(1) {
    margin-bottom: 10px;

}

.de-p-1 {
    display: table-cell;
    vertical-align: middle;
    width: 3.3em;
    text-align: center;
    position: relative;
}

.de-p-1::after {
    content: "";
    display: block;
    width: 2px;
    height: 34px;
    background: #BBBBBB;
    position: absolute;
    top: 3px;
    left: 3.3em;
}

.de-p-2 {
    display: table-cell;
    vertical-align: middle;
    width: calc( 100% - 3.3em);
    padding-left: 6px;
}

.de-p-sp {
    text-indent: 3.5%;
    font-weight: 400;
    padding-top: 10px;
    font-size: 13px;
}

.dpb-ddb {
    margin-top: 12px;
    width: 93%;
    margin-left: auto;
    margin-right: auto;
}

.d-detail-btn {
    margin-bottom: 12px;
}

.d-detail-btn.deb-close {
    display: none;
}

.d-detail-btn span,
.d-close-btn span {
    /*ボタンの内側の要素に反応しないようにする*/
    pointer-events: none;
}

.de-photo {
    display: block;
    width: 46%;
    height: auto;
    position: absolute;
    top: 12px;
    right: 3.5%;

}

.dpb-1 {
    display: block;
    width: 5.0em;
}

.dpb-1::after {
    content: "";
    display: block;
    width: 2px;
    height: 40px;
    background: #D7E3F5;
    position: absolute;
    top: 9px;
    left: 5.0em;
}

.dpb-2 {
    display: block;
    width: calc( 100% - 5.0em);
    position: absolute;
    top: 0px;
    left: 5.0em;
    padding-top: 6px;
}

.dpb-2in1 {
    display: block;
    line-height: 23px;
    height: 23px;
}

.dpb-2in2 {
    display: block;
    font-size: 19px;
    font-weight: 500;
    line-height: 23px;
    height: 23px;
}

.dpbp-w,
.dpbp-b {
    width: 22px;
    height: 16px;
    display: inline-block;
    padding-right: 6px;
    position: relative;
    top: -1px;
}

.ddb-1 {
    font-weight: 400;
}

.dpbp-b {
    display: none;

}

.ddb-caret {
    display: inline-block;
    width: 2px;
    height: 12px;
    background-color: #FFFFFF;
    margin: 23px 0px 0px 18px;
    position: relative;

}

.ddb-caret::after {
    content: "";
    display: inline-block;
    width: 2px;
    height: 12px;
    background-color: #FFFFFF;
    position: absolute;
    top: 0px;
    left: 0px;
    -ms-transform: rotate(90deg);
    / -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

/*最初から表示している部分ここまで*/

/*詳細　ここから*/

.dsd-e-wrap {
    position: relative;
    z-index: 2;
}

.dsd-e-wrap::after {
    content: "";
    display: block;
    width: 100%;
    height: 203px;
    position: absolute;
    top: 0px;
    left: 0px;
    background: -webkit-linear-gradient(top, rgba(238, 238, 238, 1) 0%, rgba(238, 238, 238, 0) 100%);
    background: linear-gradient(to bottom, rgba(238, 238, 238, 1) 0%, rgba(238, 238, 238, 0) 100%);
    z-index: -1;
}

.dsd-ttl {
    font-size: 22px;
    line-height: 34px;
    text-align: center;
    padding-top: 30px;
    padding-bottom: 30px;

}

.dsd-t-s1 {
    font-size: 15px;
}

.dsd-t-s2 {
    font-size: 15px;
}

.dl-ifg2 {
    margin-right: 10px;
    position: relative;
    top: -4px;
}

.deal-tbl {
    width: 93%;
    margin-left: auto;
    margin-right: auto;
    border-top: 1px solid #DFDFDF;
    border-left: 1px solid #DFDFDF;
}

.deal-tbl tbody,
.deal-tbl tr {
    width: 100%;
}

.deal-tbl td {
    vertical-align: middle;
    height: 50px;
    border-right: 1px solid #DFDFDF;
    border-bottom: 1px solid #DFDFDF;
}

.deal-tbl tr:nth-child(1) td {
    white-space: nowrap;
    background-color: #F4F4F4;
}

.deal-tbl tr td:nth-child(1) {
    text-align: right;
    width: 16%;
    background-color: #F4F4F4;
    padding-right: 4px;
}

.deal-tbl tr td:nth-child(2) {
    text-align: center;
    width: 42%;
}

.deal-tbl tr td:nth-child(3) {
    text-align: center;
    width: 42%;
}

.deal-price1 {
    font-size: 20px;
    font-weight: 700;
    line-height: 20px;
}

.yen1 {
    font-size: 14px;
}

.deal-att {
    line-height: 1.7em;
    width: 93%;
    margin-left: auto;
    margin-right: auto;
}

.deal-att-s {
    display: block;
    padding-left: 1.3em;
    margin-bottom: 8px;
    position: relative;
}

.deal-att-s::after {
    content: "※";
    display: block;
    width: 1em;
    height: 1.7em;
    position: absolute;
    top: 0px;
    left: 0px;
}

.dsd-t-s-grp {
    line-height: 1.9em;
    text-align: center;
    margin-top: -10px;
}

.dsd-t-o1 {
    font-weight: 600;
    display: block;
}

.de-tbl-kara {
    display: block;
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    position: relative;
    top: -10px;
}

.deal-sch {
    border-top: 2px dotted #CCCCCC;
    width: 93%;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.deal-sch-ttl1 {
    display: inline-block;
    background-color: #FCF7AD;
    padding: 2px 8px;
    margin-top: 20px;
    font-size: 17px;
    font-weight: 400;
}

.deal-sch-ttl2 {
    font-size: 17px;
    margin-top: 10px;

}

.deal-sch-ttl3 {
    margin-top: 10px;
}


.setTblCalendar:after {
    clear: both;
    display: block;
    content: "";
}


table.setTblCalendar {
    border: 1px dashed #cccccc;
    text-align: center;
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
    margin-top: 16px;
    font-weight: 400;
}

.setTblCalendar th,
.setTblCalendar td {
    border: 1px solid #cccccc;
    vertical-align: middle;
    text-align: center;
}

.setTblCalendar th {
    background: #F4F4F4;
    height: 24px;
}

.setTblCalendar td {
    height: 30px;
}


.setTblCalendar .cellSat {
    color: #0164B3;
}

.setTblCalendar .cellSun,
.setTblCalendar .cellHoli {
    color: #BC121B;
}

.setTblCalendar td.color-set {
    background-color: #FCF7AD;
}

.deal-opt-ttl1 {
    font-size: 19px;
    text-align: center;
    line-height: 1em;
    padding-bottom: 20px;
    padding-left: 6px;
    padding-right: 6px;
}

.deal-opt-img {
    width: 93%;
    margin-left: auto;
    margin-right: auto;
    position: relative;
}

.deal-opt-img img {
    display: block;
    width: 100%;
}

.deal-opt-img-add {
    display: block;
    position: absolute;
    bottom: 6px;
    right: 6px;
    color: #FFFFFF;
    line-height: 1em;
    font-size: 9px;
}

.deal-opt-txt-l {
    font-size: 17px;
    width: 93%;
    margin-left: auto;
    margin-right: auto;
}

.deal-opt-txt-s {
    width: 93%;
    margin-left: auto;
    margin-right: auto;
}

.deal-inq-ttl1 {
    font-weight: 500;
    text-align: center;
    line-height: 1em;
    padding-left: 6px;
    padding-right: 6px;
}



.d-each-box {
    border: 2px solid #949470;
    background-color: #FFFFFF;
    width: 93%;
    margin-right: auto;
    margin-left: auto;
    margin-bottom: 40px;

}

.d-each-box:last-child {
    margin-bottom: 0px;
}

.de-detail-box {
    display: none;
    margin-top: 12px;
}
.att-detail {
    margin-top: 0px;
}
.ded-open {
    display: block;
    animation-duration: 1s;
    animation: dDetailShow 0.3s linear 0s;
}

/*詳細　ここまで*/


/*利用上の注意 詳細　ここから*/

.d-att-tbl,
.d-att-tbl caption,
.d-att-tbl tbody,
.d-att-tbl tr,
.d-att-tbl th,
.d-att-tbl td{
    display: block;  
}

.d-att-tbl{
    width: 93%;
    margin-left:auto;
    margin-right:auto;
    margin-bottom: 50px;
    
    
}

.d-att-tbl td{
    padding:0.5em;
    margin-bottom:30px;
    
}
.d-att-tbl caption{
    width: 100%;
    font-weight: 500;
    border-bottom: 1px solid #505050;
    font-size: 16px;
    margin-bottom: 1em;
    padding: 14px 0em 14px 0em;
}


.d-att-tbl tbody{
    width: 100%;
}


.d-att-tbl th{
  padding: 0em 0.5em 10px 1em;
    font-weight: 400;
    position: relative;
}
.d-att-tbl th::after{
    content:"●";
    display: block;
    font-size: 9px;
    color: #505050;
    width: 1em;
    height: 1em;
    position: absolute;
    top:3px;
    left:0px;
}
.d-att-tbl td{
  
}
/*利用上の注意 詳細　ここまで*/

#d-close-btn {
    margin-top: 12px;
    width: 10em;

    position: fixed;
    bottom: 20px;
    left: calc( 50% - 4.5em);
    display: none;
}

#d-close-btn.dcd-app {
    display: block;
    z-index: 88;
}

.dcb-in {
    line-height: 22px;
    padding-right: 2em;
    padding-top: 7px;
    position: relative;
}

.dcb-caret {
    display: inline-block;
    width: 2px;
    height: 12px;
    background-color: #FFFFFF;
    position: relative;
    left: 2.5em;
    top: -0.3em;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.dcb-caret::after {
    content: "";
    display: inline-block;
    width: 2px;
    height: 12px;
    background-color: #FFFFFF;
    position: absolute;
    top: 0px;
    left: 0px;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}






@media (min-width: 360px) {
    /*最初から表示している部分ここから*/
    .deal-deco1 {
        width: 138px;
        height: 66px;
        width: 34.5vw;
        height: 16.5vw;
    }
    .deal-deco2 {
        width: 66px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 148px;
        width: 16.5vw;
        height: 16.5vw;
        left: 37vw;
    }
    .deal-deco3 {
        width: 37px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 221px;
        width: 9.25vw;
        height: 16.5vw;
        left: 55.25vw;
    }
    .deal-deco4 {
        width: 66px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 265px;
        width: 16.5vw;
        height: 16.5vw;
        left: 66.25vw;
    }
    .dttl-decos {
        height: 66px;
        width: 331px;
        width: 82.75vw;
        height: 16.5vw;
    }
    .deal-ttl {
        font-size: 38px;
        font-size: 10.5vw;
        padding-top: 14px;
        padding-top: 4vw;
    }

    .dmain-txt1add {
        font-size: 15px;
    }
    .dmain-txt1 {
        font-size: 22px;
        font-size: 6.1111vw;
    }
    .dmain-txt2 {
        font-size: 22px;
        font-size: 6.1111vw;
    }
    .de-sttl {
        font-size: 17px;
        font-size: 4.7222vw;
    }

    .de-sttl-s {
        font-size: 13px;
    }
    .dmain-imgadd {
        left: 12%;
    }
    .dpb-1 {
        width: 6.0em;
    }

    .dpb-1::after {
        left: 6.0em;
    }
    .dpb-2 {
        left: 6.0em;
        width: calc( 100% - 6.0em);
    }
    .de-p-1 {
        width: 4em;
    }

    .de-p-1::after {
        left: 4em;
    }

    .de-p-2 {
        width: calc( 100% - 4em);
        padding-left: 12px;
    }
    .de-sttl-box,
    .de-sttl-box2 {
        margin: 0px 14px 0px 14px;
    }
    /*最初から表示している部分ここまで*/
    /*詳細　ここから*/
    .deal-price1 {
        font-size: 22px;
        line-height: 22px;
    }
    .yen1 {
        position: relative;
        top: 2px;
        left: 2px;
    }
    .dsd-ttl {
        font-size: 24px;
    }
    /*詳細　ここまで*/
}

/*end min-width: 360px*/

@media (min-width: 400px) {
    /*最初から表示している部分ここから*/   
    .de-sttl {
        font-size: 18px;
    }

    .de-sttl-s {
        font-size: 14px;
    }
    .dpb-ddb {
        width: 328px;
    }
    .de-place-box {
        padding: 5% 0px;
    }
    .de-place {
        font-size: 15px;
    }
    .de-place:nth-child(1) {
        margin-bottom: 3%;
    }
    .de-p-sp {
        font-size: 15px;
    }
    /*最初から表示している部分ここまで*/
    /*詳細　ここから*/
    .de-tbl-kara {
        top: -15px;
    }
    /*詳細　ここまで*/
}

/*end min-width: 400px*/

@media (min-width: 440px) {
  .deal-deco1 {
        width: 138px;
        height: 66px;
    }
    .deal-deco2 {
        width: 66px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 162px;
    }
    .deal-deco3 {
        width: 37px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 245px;
    }
    .deal-deco4 {
        width: 66px;
        height: 66px;
        position: absolute;
        top: 0px;
        left: 299px;
    }
    .dttl-decos {
        height: 66px;
        width: 365px;
    }
.deal-ttl {
    font-size: 46px;
    padding-top: 17px;
}
    .dmain-txt1 {
        font-size: 26px;

    }

    .dmain-txt2 {
        font-size: 26px;

    }


}

/*end min-width: 440px*/


@media (min-width: 550px) {

    .dmain-txt1 {
        font-size: 4.8vw;
        bottom: 2vw;
        left: 3vw;
    }
    .dmain-txt1add {
        bottom: 9vw;
        left: 3vw;
    }
    .dmain-txt2 {
        font-size: 4.8vw;
        bottom: 2vw;
        right: 3vw;

    }
    .dmain-imgadd {
        left: 10%;
        width: 150px;
        height: 100px;
    }
        .dttl-inbox1 {
        padding: 40px 0px 40px 0px;
    }
}

/*end min-width: 550px*/

@media (min-width: 600px) {
    .de-p-br {
        display: none;
    }
    .de-p-1::after {
        height: 17px;
    }
    .de-place-box {
        padding: 15px 0px 20% 0px;
    }
    .dmain-txt1add2 {
        top: auto;
        bottom: 6px;
        right: calc( 50% + 8px);
    }
}


/*end min-width: 600px*/

@media (min-width: 740px) {
    .dl-top-msg{
    margin:40px auto 40px auto;
}
    
    /*最初から表示している部分ここから*/
    /*deal-deco は550pxで設定したまま*/
    .dmain-txt1 {
        font-size: 35px;
        bottom: 15px;
        left: 22px;
    }
    .dmain-txt1add {
        bottom: 65px;
        left: 22px;
    }
    .dmain-txt2 {
        font-size: 35px;
        bottom: 15px;
        right: 22px;

    }
    .dl-hd {
        margin-top: 30px;
        margin-bottom: 30px;
    }
    .d-detail-btn {
        margin-bottom: 16px;
        margin-top: 16px;
    }
    .de-place-box {
        overflow: visible;
        position: static;
    }
    .d-phone-btn1 {
        position: relative;
    }
    .dpb-addbg::after {
        content: "";
        display: block;
        width: 100%;
        height: 15px;
        position: absolute;
        top: -15px;
        left: 0px;
        background: #FFFFFF;
    }
    .de-place {
        width: 100%;
        width: calc( 70% - 58px);
        padding: 0px 0px 0px 16px;
    }
    .de-outline-box {
        position: relative;
    }
    .de-photo {
        width: 33%;
        /*max-width: 346px;*/
        top: 16px;
        right: 16px;
    }
    .de-sttl-box {
        padding: 16px 0px 16px 0px;
        margin: 0px 0px 0px 16px;
        width: 70%;
        /*76*.93=70.68*/
        width: calc( 70% - 74px);
    }
    .de-sttl-box2 {
        padding: 16px 0px 16px 0px;
        margin: 0px 0px 0px 16px;
    }
    .de-place-box {
        padding: 16px 0px 16px 0px;
    }
    .d-phone-btn1,
    .d-phone-btn2 {
        width: 93%;
        width: calc( 100% - 32px);
    }
    .dpb-ddb a.b-btn-1 {
        background-color: #EEEEEE;
        box-shadow: none;
        border-radius: 0px;
        color: #000000;
        font-weight: 500;
        display: table;
        width: 100%;
    }
    .dpbp-w {
        display: none;

    }
    .dpbp-b {
        display: inline-block;
    }
    .dpb-2in1 {
        display: inline-block;
        padding-right: 20px;
        line-height: 58px;
        height: 58px;
    }
    .dpb-2in2 {
        display: inline-block;
        /*padding-left:22px;
        background:transparent url(../img/common/icon-photo-b.png) no-repeat 0px 22px / 16px 16px;*/
        line-height: 58px;
        height: 58px;
    }
    .dpb-1 {
        position: relative;
        width: 30%;
        font-size: 17px;
        display: table-cell;
    }
    .dpb-1::after {
        content: "";
        display: block;
        width: 2px;
        height: 40px;
        background: #BBBBBB;
        position: absolute;
        top: 9px;
        left: auto;
        right: 0px;
    }
    .dpb-2 {
        width: 70%;
        padding-top: 0px;
        display: table-cell;
        left: 0px;
        position: static;
    }
    .de-sttl {
        font-size: 20px;
        line-height: 2em;
    }
    /*最初から表示している部分ここまで*/
    /*詳細　ここから*/
    .de-detail-box {
        margin-top: 30px;
    }
    .att-detail {
    margin-top: 0px;
}
    .dsd-ttl {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    .dsd-t-o1 {
        display: inline;
    }
    .deal-sch-ttl1 {
        margin-top: 30px;
    }
    .deal-sch-ttl2 {
        display: inline-block;
        margin-top: 30px;
        padding: 2px 8px;
    }
    .deal-sch-ttl3 {
        margin-top: 30px;
    }
    .calendar-box {

        margin-top: 30px;
    }
    table.setTblCalendar {

        width: 48.5%;
        float: left;
    }
    .calendar-box table.setTblCalendar:nth-child(2n-1) {
        margin-right: 3%;
    }
    .de-tbl-kara {
        display: inline;
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
        top: 0px;
    }
    .deal-tbl tr td:nth-child(1) {
        padding-right: 12px;
    }
    .deal-opt-ttl1 {
        padding-bottom: 30px;
    }
    .dsd-t-s2 {
        font-size: 18px;
        display: inline-block;
    }
    /*詳細　ここまで*/
    /*利用上の注意 詳細　ここから*/
    .d-att-tbl{
        display: table;
        border:1px solid #DFDFDF;
        border-collapse: collapse;
        max-width: 1000px;
    }
    .d-att-tbl caption{
        display: table-caption;
        padding: 0.5em 0em 14px 0em;
    }
.d-att-tbl tbody{
    display: table-row-group;
    }
.d-att-tbl tr{
    display: table-row;
    border-bottom: 1px solid #DFDFDF;
    }
.d-att-tbl th{
    display: table-cell;
    padding: 0.5em 0em 0.5em 0.5em;
    width: 8em;
    vertical-align: top;
    background: #F4F4F4;
    border-right: 1px solid #DFDFDF;
    }
.d-att-tbl td{
    display: table-cell;
    vertical-align: top;
}
    .d-att-tbl th::after{
    display: none;
}
    
    /*利用上の注意 詳細　ここまで*/
}

/*end min-width: 740px*/

@media (min-width: 960px) {
    /*最初から表示している部分ここから*/
      .deal-deco1 {
        width: 116px;
        height: 56px;
    }
    .deal-deco2 {
        width: 56px;
        height: 56px;
        position: absolute;
        top: 0px;
        left: 130px;
    }
    .deal-deco3 {
        width: 32px;
        height: 56px;
        position: absolute;
        top: 0px;
        left: 196px;
    }
    .deal-deco4 {
        width: 56px;
        height: 56px;
        position: absolute;
        top: 0px;
        left: 239px;
    }
    .dttl-decos {
        height: 56px;
        width: 294px;
    }
    .deal-ttl {
        font-size: 36px;
        padding-top:1.875vw;
    }
    
    
    .dl-hd {
        margin-top: 30px;
        margin-top: 3.4375vw;
        margin-bottom: 50px;
    }
    .dl-ft {
        margin-top: 50px;
        margin-bottom: 60px;
    }
  
    .dttl-box {
        position: relative;
    }
    .dttl-inbox1 {
        width: 340px;
        margin-left: 310px;
        position: relative;
        z-index: 5;
        width: 35.4167vw;
        margin-left: 32.2917vw;
        padding-top: 4.1667vw;
        height: 198px;
        height: 20.6vw;
        padding-bottom: 0px;
    }
    .dttl-inbox2 {
        width: 100%;
        position: absolute;
        top: 0px;
        left: 0px;
        height: 198px;
        height: 20.6vw;
        overflow: hidden;
    }
    .deal-main1,
    .deal-main2 {
        width: 351px;
        height: 226px;
        position: absolute;
        top: auto;
        bottom: 0px;
        width: 33.3%;
        height: auto;
    }
    .deal-main1 {}
    .deal-main2 {
        left: auto;
        right: 0px;
    }

    .dmain-txt1 {
        font-size: 32px;
        bottom: 4%;
        left: 2%;
        font-size: 2.3vw;
        bottom: 1.2vw;
        left: 2vw;
    }
    .dmain-txt1add {
        font-size: 15px;
        bottom: 54px;
        bottom: calc( 4% + 46px);
        left: 2%;
        bottom: 4.5vw;
        left: 2vw;
    }
    .dmain-txt2 {
        font-size: 32px;
        bottom: 4%;
        right: 2%;
        font-size: 2.3vw;
        bottom: 1.2vw;
        right: 2vw;

    }


    .dmain-txt1add2 {
        right:68%;
    }
    .de-sttl {
        font-size: 23px;
    }
    .de-place {
        display: inline-block;
        width: auto;
    }
    .de-place:nth-child(1) {
        margin-bottom: 0px;
    }
    .de-p-1 {
        width: auto;
    }
    .de-p-2 {
        width: auto;
        padding-left: 2em;
    }
    .de-p-1::after {
        left: auto;
        right: -1em;
    }
    .de-sttl-box {
        margin-left: 3.5%;
        width: 58.5%;
    }
    .de-sttl-box2 {
        margin-left: 0;
        margin-right: 0;
        text-align: center;
    }
    .de-place {
        padding-left: 3.5%;
    }

    .de-p-sp {
        display: inline-block;
        padding-top: 0px;
        width: 58.5%;
        text-indent: 0;
        padding-left: 3.5%;
    }
    .de-outline-box .d-phone-btn1,
    .de-outline-box .d-phone-btn2 {
        width: 58.5%;
        margin-left: 3.5%;
    }
    .de-detail-box .d-phone-btn1,
    .de-detail-box .d-phone-btn2,
    .de-att-inq .d-phone-btn1,
    .de-att-inq .d-phone-btn2 {
        width: 70%;
        width: calc( 70% - 74px);

    }
    .dpb-1 {
        width: 23%;
    }
    .dpb-2 {
        width: 77%;
    }
    .dpb-addbg::after {
        display: none;
    }
    .de-place {
        font-size: 16px;
    }
    .de-p-sp {
        font-size: 16px;
        padding-bottom: 10px;
    }
    .dpb-ddb {
        /*margin-top: 16px;*/
    }

    /*最初から表示している部分ここまで*/
    /*詳細　ここから*/
    table.setTblCalendar {
        width: 32%;
        float: left;
        margin-top: 2%;
    }
    .calendar-box table.setTblCalendar:nth-child(2n-1) {
        margin-right: 0;
    }
    .calendar-box table.setTblCalendar:nth-child(3n-1),
    .calendar-box table.setTblCalendar:nth-child(3n-2) {
        margin-right: 2%;
    }

    .dsd-ttl {
        font-size: 26px;
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .dsd-t-s2 {
        font-size: 19px;
    }
    .deal-opt-wrap {
        display: table;
        width: 93%;
        margin-left: auto;
        margin-right: auto;
    }
    .deal-opt-img {
        display: table-cell;
        vertical-align: top;
        width: 46%;
    }
    .deal-opt-tbox {
        display: table-cell;
        vertical-align: top;
        width: 54%;
    }
    .deal-opt-txt-l {
        width: 100%;
        margin: 0;
        padding: 0px 0px 0px 5%;
    }
    .deal-opt-txt-s {
        width: 100%;
        margin: 0;
        padding: 5% 0px 0px 5%;
    }
    /*詳細　ここまで*/
}

/*end min-width: 960px*/



@media (min-width: 1150px) {
    .de-photo {
        width: 346px;
        height: 260px;
    }
    .de-sttl-box {
        margin-left: 34px;
        width: calc( 100% - 430px);
    }

    .de-place {
        padding-left: 34px;
    }

    .de-p-sp {
        width: calc( 100% - 430px);
        padding-left: 34px;
    }
    .de-outline-box .d-phone-btn1,
    .de-outline-box .d-phone-btn2 {
        width: calc( 100% - 430px);
        margin-left: 34px;
    }
        .deal-ttl {
        font-size: 38px;
    }
}

/*end min-width: 1150px*/

@media (min-width: 1180px) {
    .deal-tbl,
    .deal-sch,
    .deal-opt-wrap {
        width: 1000px;
    }
    .dpb-wrap2 {
        display: table;
        width: 1000px;
        margin-left: auto;
        margin-right: auto;
    }
    .setTblCalendar td {
        height: 44px;
    }
    .de-detail-box .d-phone-btn1,
    .de-att-inq .d-phone-btn1 {
        display: table-cell;
        width: 50%;
        padding-right: 10px;
        white-space: nowrap;
    }
    .de-detail-box .d-phone-btn2,
    .de-att-inq .d-phone-btn2 {
        display: table-cell;
        width: 50%;
        padding-left: 10px;
        white-space: nowrap;
    }
    .dpb-1 {
        width: 20%;
    }
    .dpb-2 {
        width: 80%;
    }
    .dpb-2in1 {
        padding-right: 10px;
    }
}

/*end min-width: 1180px*/

@media (min-width: 1280px) {
    .dl-top-msg{
    font-size: 21px;
        margin:60px auto 60px auto;
}
    /*最初から表示している部分ここから*/
      .deal-deco1 {
        width: 124px;
        height: 60px;
    }
    .deal-deco2 {
        width: 60px;
        height: 60px;
        top: 0px;
        left: 144px;
    }
    .deal-deco3 {
        width: 34px;
        height: 60px;
        top: 0px;
        left: 220px;
    }
    .deal-deco4 {
        width: 60px;
        height: 60px;
        top: 0px;
        left: 270px;
    }
    .dttl-decos {
        height: 60px;
        width: 330px;
    }
        .deal-ttl {
            font-size: 42px;
        line-height: 1em;
        padding-top: 38px;
        padding-top: 3.125vw;
    }
    .dl-hd {
        margin-top: 60px;
        margin-bottom: 60px;
    }
    .dl-ft {
        margin-top: 60px;
        margin-bottom: 80px;
    }
    .de-sttl {
        font-size: 26px;
    }

}


/*end min-width: 1280px*/

@media (min-width: 1430px) {
          .deal-deco1 {
        width: 138px;
        height: 66px;
        width: 8.6458vw;
        height: 4.1667vw;
    }
    .deal-deco2 {
        width: 66px;
        height: 66px;
        top: 0px;
        left: 148px;
        width: 4.1667vw;
        height: 4.1667vw;
        left: 10.3646vw;
    }
    .deal-deco3 {
        width: 37px;
        height: 66px;
        top: 0px;
        left: 221px;
        width: 2.3438vw;
        height: 4.1667vw;
        left: 16.1458vw;
    }
    .deal-deco4 {
        width: 66px;
        height: 66px;
        top: 0px;
        left: 265px;
        width: 4.1667vw;
        height: 4.1667vw;
        left: 20.1042vw;
    }
    .dttl-decos {
        height: 66px;
        width: 331px;
        width: 24.28vw;
        /*多め*/
        height: 4.1667vw;
    }
        .deal-ttl {
        font-size: 42px;
        font-size: 3.125vw;
    }


    .dl-tblbox,
    .d-each-box {
        width: 1280px;
        margin-left: auto;
        margin-right: auto;
    }

    /*詳細　ここから*/
    .dpb-wrap1 {
        display: table;
        width: calc( 100% - 430px);
        margin-left: 34px;
    }
    .de-outline-box .d-phone-btn1 {
        display: table-cell;
        white-space: nowrap;
        padding-right: 7px;

    }
    .de-outline-box .d-phone-btn2 {
        display: table-cell;
        white-space: nowrap;
        padding-left: 7px;
    }
    .de-outline-box .dpb-1 {
        font-size: 15px;

    }
    .de-outline-box .dpb-2 {}
    .de-outline-box .dpb-2in1 {
        font-size: 15px;
        padding-right: 8px;
    }
    .de-outline-box .dpb-2in2 {
        font-size: 18px;
        /*background: transparent url(../img/common/icon-photo-b.png) no-repeat 0px 22px / 15px 15px;
        padding-left: 18px;*/
    }
    .de-place-box {
        padding: 28px 0px 28px 0px;
    }
    .d-detail-btn {
        margin-bottom: 28px;
        margin-top: 28px;
        position: relative;
        z-index: 20;
    }
    .d-detail-btn::after {
        content: "";
        display: block;
        width: 1268px;
        height: 110px;
        background: #FFFFFF;
        position: absolute;
        top: -28px;
        left: -470px;
        z-index: -1;
    }
    /*詳細　ここまで*/
}

/*end min-width: 1430px*/


@media (min-width: 1800px) {
    .deal-main1,
    .deal-main2 {
        width: 34%;
    }
}