/** 共通パーツ
*****************************/
.l-header__logo.c-logo.head_logo img{
    width: auto !important;
    max-height: 48px !important;
}

.p-logoset img{
    width: auto !important;
    max-height: 100% !important;
}

.p-logoset{
    background: #F07799;
    border-color: #F07799;
}

.p-btn__vertical{
    height: auto !important;
}

.p-footer-link{
    max-height: 560px;
}

.p-footer-link__contents--vertical{
    height: 100%;
}

.tbl01 thead tr th,
.tbl01 thead tr td,
.tbl01 tbody tr th{
    background: #f1f9e6;
    font-weight: bold;
}

.p-logoset .p-logoset-custom-logo {
	margin-top: 8px;
}

.p-logoset .p-logoset-custom-logo img{
	width: auto;
	max-width: 48px;
	height: auto;
}

.p-global-nav > ul > li{
    border-bottom: 1px solid #fff;
}

.p-global-nav > ul > li:last-of-type{
    border-bottom: none;
}

@media screen and (max-width: 1199px) {
    .p-global-nav ul li a,
    .p-global-nav ul li a:hover,
    .p-global-nav a,
    .p-global-nav a:hover{
        background: #f07799 !important;
        color: #fff !important;
        font-weight: bold !important;
    }
}


@media screen and (max-width: 991px) {
    .p-footer-link {
        height: 560px !important;
    }
}

@media screen and (max-width: 767px) {
    /* トップページ */
    .p-index-content04__contents,
    .p-index-content04__contents--vertical{
        flex-wrap: wrap;
    }

    /* 共通パーツ */
    .p-footer-link {
        height: clamp(400px, 40vw, 560px) !important;
    }

    .p-btn__vertical{
        padding: 8px !important;
    }

    .p-footer-link__title{
        line-height: 1.75 !important;
    }

    .p-footer-link__contents,
    .p-footer-link__contents--vertical{
        flex-wrap: wrap;
    }

    .p-footer-link__contents--vertical .p-footer-link__title + .p-footer-link__btn{
        display: block;
        height: 100%;
        margin-right: 20px !important;
    }

    .p-footer-link__contents--vertical .p-footer-link__title{
        display: block;
    }

    .p-footer-link__btn .p-btn{
        box-sizing: border-box;
    }
}

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

    .c-logo img{
        width: auto;
        max-height: 40px;
    }

    .p-info__logo a img{
        max-height: 120px !important;
    }

    .p-index-content08 iframe{
        min-height: 240px !important;
        height: 60vw !important;
        max-height: 320px !important;
    }
}

/** 下層ページ 
*****************************/
/* メインイメージ */
.p-page-header__title{
    line-height: 1.5 !important;
}

.p-page-header__title--vertical span,
.p-page-header__desc--vertical span{
    line-height: 1.75;
}

/* パンくず */
.p-breadcrumb{
    background-color: #f07799 !important;
}

.p-breadcrumb__item{
    font-weight: bold;
}

/* 下層ページ共通 */
.secondpage.secondcat--page .p-second-common h1,
.secondpage.secondcat--page .p-second-common h2,
.secondpage.secondcat--page .p-second-common h3,
.secondpage.secondcat--page .p-second-common h4,
.secondpage.secondcat--page .p-second-common h5,
.secondpage.secondcat--page .p-second-common h6{
    zoom:1;
}

.secondpage.secondcat--page .p-second-common h1:before,
.secondpage.secondcat--page .p-second-common h1:after,
.secondpage.secondcat--page .p-second-common h2:before,
.secondpage.secondcat--page .p-second-common h2:after,
.secondpage.secondcat--page .p-second-common h3:before,
.secondpage.secondcat--page .p-second-common h3:after,
.secondpage.secondcat--page .p-second-common h4:before,
.secondpage.secondcat--page .p-second-common h4:after,
.secondpage.secondcat--page .p-second-common h5:before,
.secondpage.secondcat--page .p-second-common h5:after,
.secondpage.secondcat--page .p-second-common h6:before,
.secondpage.secondcat--page .p-second-common h6:after{
    content:"";
    display:table
}

.secondpage.secondcat--page .p-second-common h1:after,
.secondpage.secondcat--page .p-second-common h2:after,
.secondpage.secondcat--page .p-second-common h3:after,
.secondpage.secondcat--page .p-second-common h4:after,
.secondpage.secondcat--page .p-second-common h5:after,
.secondpage.secondcat--page .p-second-common h6:after{
    clear:both;
}

.secondpage.secondcat--page .p-second-common h1{
    font-size: 32px !important;
    font-weight: bold;
    color: #fff;
    background: #f07799;
    box-sizing: border-box;
    padding: 0.5em;
}

.secondpage.secondcat--page .p-second-common h2{
    font-size: 140%;
    margin: 2em 0 1em !important;
    padding: 0 0 .5em;
    border-bottom: 3px solid #f07799;
    font-size: 26px !important;
}

.secondpage.secondcat--page .p-second-common h3{
    font-size: 130%;
    margin: 2em 0 1em;
    padding: 1em .2em;
    border-top: 2px solid #d0a900;
    border-bottom: 2px solid #d0a900;
    font-size: 20px;
    font-weight: 600;
    color: #d0a900;
}

.secondpage.secondcat--page .p-second-common h4{
    font-size: 120%;
    margin: 1.5em 2px 1em;
    padding: .3em 0 .3em .8em;
    border-bottom: none;
    border-left: 2px solid #000;
    font-size: 18px;
    font-weight: 400;
}

.secondpage.secondcat--page .p-second-common h5{
    font-size: 110%;
    margin: 1.25em 0 1em;
    padding: .5em .8em .3em 1em;
    background: #f5f5f5;
    -webkit-box-shadow: 0px 2px 0px 0px #f2f2f2;
    box-shadow: 0px 2px 0px 0px #f2f2f2;
    font-size: 18px;
    font-weight: 700;
}

.secondpage.secondcat--page .p-second-common h6{
    font-size: 100%;
}

.secondpage.secondcat--page .p-entry__body p{
    margin-bottom: 1em;
    min-height: 1px;
}

.secondpage.secondcat--page .p-entry__body p:after{
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
}

.secondpage.secondcat--page .p-second-common .p-entry__body ul li p{
    margin-bottom: 0 !important;
}

/* 料金表 */
.secondpage.secondcat--page .p-block01__desc--vertical{
    min-height: 0;
}

/* アクセス */
.access_map{
    width: 100%;
    height: 40vw;
    min-height: 480px;
    max-height: 480px;
}

/* ご予約・お問い合わせ */
.wpcf7{
    border: none !important;
    background: #f8f0f2 !important;
    box-sizing: border-box !important;
    padding: 16px !important;
}

.contact_form{
    width: 100%;
    display: block;
}

.contact_form tbody{
    display: block;
}

.contact_form tbody tr{
    display: flex;
    flex-direction: column;
    margin-bottom: 12px;
}

.contact_form tbody tr:last-of-type{
    margin-bottom: 0;
}

.contact_form tbody tr th,
.contact_form tbody tr td{
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding: 4px;
    text-align: left;
    background: none;
    border: none;
}

.contact_form tbody tr th p,
.contact_form tbody tr td p{
    font-size: 16px;
}

.contact_form tbody tr th p:last-of-type,
.contact_form tbody tr td p:last-of-type{
    margin-bottom: 0 !important;
}

.contact_form tbody tr th p{
    font-size: 16px !important;
    font-weight: bold;
}

.contact_form tbody tr td input,
.contact_form tbody tr td textarea{
    font-size: 17px;
}

.contact_form tbody tr td.form_confirm p{
    display: flex;
    flex-direction: row;
    font-size: 17px !important;
}

.contact_form tbody tr td input[type="checkbox"]{
    font-size: 17px !important;
    width: 1em;
}

.contact_form tbody tr td.form_confirm p .wpcf7-list-item{
    margin-left: 0 !important;
}

.contact_submit p input{
    width: 100% !important;
    max-width: 500px;
    height: auto !important;
    padding: 20px 0;
    margin: 0 auto !important;
    font-size: 24px !important;
    font-weight: bold;
    color: #fff !important;
    letter-spacing: 0.05em;
    border: none !important;
    background: #f07799 !important;
    border-radius: 100px;
    -webkit-appearance: none;
}

.contact_submit p input[disabled]{
    background: #a0a0a0 !important;
}

.required {
    background: #ec3838;
    padding: 0 5px;
    font-size: 0.8em !important;
    color: #fff;
    margin-left: 10px;
    display: inline-block;
}


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

    /* 共通パーツ */
    .p-entry__body .alignright{
        max-width: 30% !important;
        margin-left: 12px !important;
    }
}

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

    /* 共通パーツ */
    .p-entry__body .alignright{
        max-width: 40% !important;
        margin-left: 8px !important;
    }

    .secondpage.secondcat--page .p-second-common h1{
        font-size: 24px !important;
        padding: 8px 12px;
        margin-bottom: 0.75em;
    }

    .secondpage.secondcat--page .p-second-common h2{
        font-size: 20px !important;
        padding-bottom: 0.5em;
        margin: 1.5em auto 1em;
    }

    .secondpage.secondcat--page .p-second-common h3{
        font-size: 17px;
        padding: 12px 8px;
        margin: 1.5em 0 1em;
        border-width: 1px 0;
    }

    /* アクセス */
    .access_map{
        min-height: 320px;
        max-height: 320px;
    }    
}