@charset "utf-8";

/************************************
/* P-1.トップページ
/* /
************************************/

/************************************
* reset
************************************/
.fv.outer,
.fv .inner{
    margin: 0;
    padding: 0;
    width: 100%;
}
.fv .slick-dots{
    bottom: 2rem;
}
.fv .slick-dots li.slick-active button:before{
    color: #fff;
}


/* **************************************

    Layout

*************************************** */
.headline-wrap{
    margin: auto;
    text-align: center;
}
.headline{
    font-family: var(--font-family-en);
    font-weight: 600;
}

/* topics */
.home-topics-container{
    display: flex;
    align-items: center;
    width: 95%;
    margin: auto;
}
.home-topics-container .healdine{
    width: 7em;
}
.home-topics-container .home-topics-item{
    width: 100%;
}
.home-topics-container .home-topics-item .post-contents{
    position: relative;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
.home-topics-container .home-topics-item .post-contents:hover{
    opacity: .6;
}
.home-topics-container .home-topics-item .post-contents a{
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    z-index: 2;
}
.home-topics-container .home-topics-item .slider-item .date{
    margin-right: .8rem;
}

/* hotels */
.hotels .headline{
    font-size: 7rem;
    display: inline-block;
    position: relative;
    line-height: 1;
    margin-top: 2rem;
    margin-bottom: 6rem;
}
.hotels .headline::before{
    content: '';
    position: absolute;
    top: .1em;
    left: 0;
    width: 124%;
    height: .03em;
    margin-left: -1.58em;
    background: var(--color-blk);
}
.hotels .headline::after{
    content: '';
    position: absolute;
    bottom: .1em;
    left: 0;
    width: 125%;
    height: .03em;
    margin-right: -1em;
    background: var(--color-blk);
}
.tab-head-container{
    display: flex;
    justify-content: space-between;
    margin: 1rem 15% 2rem;
}
.tab-head-item{
    width: fit-content;
    margin: 0 1rem;
    text-align: center;
    white-space: nowrap;
    cursor: pointer;
    position: relative;
}
.tab-head-item:hover{
    opacity: .6;
}
.tab-head-item.active::after{
    content: "";
    display: block;
    width: 70%;
    margin: auto;
    height: .3rem;
    border-radius: 1rem;
    background: var(--color-gry);
    position: absolute;
    bottom: -1rem;
    left: 50%;	
    transform: translateX(-50%);
    transition: .5s;
}
.tab-body-container{
    display: none;
}
.tab-body-container.active{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.tab-body-container.active::after{
    display: block;
    content: "";
    width: 32%;   
}
.tab-body-item{
    width: 32%;
    text-align: center;
    padding: .4rem .6rem;
    margin-bottom: 2rem;
    line-height: 1.6rem;
}
.tab-body-item .name{
    margin-bottom: .4rem;
}
.tab-body-item .postal-code,
.tab-body-item .address{
    line-height: 1.4;
    font-size: var(--font-small);
}
.btn-more-wrap{
    margin: 2rem auto;
}
.btn-more:hover{
    box-shadow: none;
    margin-bottom: -.2rem;
}
.btn-cta:link,
.btn-cta:visited{
    background: var(--color-wht);
    box-shadow: .1rem .1rem .2rem var(--color-main);
    border-radius: 10rem;
    color: var(--color-blk);
    font-size: var(--font-medium);
    font-weight: 600;
    padding: 1rem 2rem 1rem 4rem;
    position: relative;
    transition: .5s;
}
.cta{
    width: 100%;
    height: 100%;
    background: url(../images/top_cta_bg.jpg) no-repeat center center;
    padding: 4rem 0;
    margin-bottom: 0;
}
.cta-container{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.cta-container .headline{
    font-size: 5rem;
    font-weight: 600;
    margin-bottom: 1.8rem;
    color: var(--color-wht);
    position: relative;
}
.cta-container .headline::before{
    content: '';
    position: absolute;
    top: .1em;
    left: 0;
    width: 100%;
    height: .03em;
    background: var(--color-wht);
}
.cta-container .headline::after{
    content: '';
    position: absolute;
    bottom: .1em;
    left: 0;
    width: 100%;
    height: .03em;
    background: var(--color-wht);
}
.cta-container .headline-description p{
    text-align: left;
    color: var(--color-wht);
}

/* **************************************

    COMMON PARTS

*************************************** */
#main{
	counter-reset: headline-num 0; 
}
.main-contents{
    max-width: 1920px;
    margin: auto;
}
section .inner{
    background: var(--color-wht);
    padding: 4rem 5% 3rem;
    width: 75%;
}
.headline-wrap{
    text-align: center;
    margin: 3rem auto 4rem;
}
.headline{
    display: inline-block;
}
.headline .main-text{
    font-size: min(4rem,60px);
}
.headline .sub-text{
    text-align: center;
    background: var(--color-main);
    color: var(--color-wht);
    padding: .4rem 1rem;
}
.btn{
	text-align: center;
	text-decoration: none;
	margin: auto;
	padding: 1rem 2rem 1rem 4rem;
	font-weight: bold;
	border: 2px solid var(--color-accent);
	background: var(--color-accent);
	color: var(--color-wht);
	border-radius: 100vh;
	transition: 0.5s;
	letter-spacing: .2rem;
	white-space: nowrap;
	margin: .6rem;
}
a.btn{
    color: var(--color-wht);
}
.btn:link,
.btn:visited{
    background: var(--color-blk);
	box-shadow: .1rem .1rem .2rem var(--color-main);
    border-radius: 10rem;
    color: var(--color-wht);
	font-size: var(--font-medium);
	font-weight: 600;
	padding: .6rem 1rem .6rem 2.8rem;
	position: relative;
    transition: .5s;
}
.btn.btn-more,
.btn.btn-more:link
.btn.btn-more:visited{
    background-color: var(--color-blk);
    border: 2px solid var(--color-blk);
    width: fit-content;
    padding: .6rem 1.8rem;
    margin: auto;
}
.btn-wrap{
    text-align: center;
}
.outer{
    margin: 0 auto;
}

/* **************************************

    Layout

*************************************** */

/* fv */
#fv{
    counter-reset: index-num 0; 
    margin-top: 0;
}
.fv .inner{
    background: url(../images/hotel_takatsuki_fv_bg1.jpg) no-repeat center center;
    background-size: cover;
}
.fv .inner{
    width: 100%;
    height: 80vh;
    position: relative;
}
.fv-copy-wrap{
    text-align: center;
    width: fit-content;
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -40%);
}
.fv-main-copy{
    font-size: min(4.6rem,100px);
    font-family: var(--font-family-en);
    color: var(--color-wht);
    margin-bottom: 1rem;
    text-shadow: .1rem .1rem .6rem var(--color-blk);
    /* filter: drop-shadow(3px 3px 2px rgba(0, 0, 0, 0.3)); */
}
.fv-sub-copy{
    background: var(--color-main);
    color: var(--color-wht);
    padding: .4rem 1rem;
}
.topics-container{
    box-shadow: .1rem .1rem .6rem var(--color-gry);
    margin-bottom: 3rem;
}
.topics-item{
    padding: 1rem 2rem;
    position: relative;
    display: flex;
}
.topics-item:nth-of-type(odd){
    background: var(--color-gry-pale1);
}
.topics-item a{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
}
.topics-item:hover{
    opacity: .6;
    transition: 0.3s;
}
.topics-item .date{
    width: fit-content;
    min-width: 6rem;
}
.topics-item .title{
    margin: 0 1rem;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.page-index{
    background: rgba(0,0,0,.7);
    padding: 1rem 0;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}
.page-index-container{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 90%;
    margin: auto;
}
.page-index-item{
    color: var(--color-wht);
    width: calc(100% / 5);
    text-align: center;
    position: relative;
    white-space: nowrap;
    border-right: solid 1px var(--color-wht);
    padding: 1rem;
}
.page-index-item:last-of-type{
    border-right: none;
}
.page-index-item a{
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    z-index: 3;
}
.page-index-item:hover{
    opacity: .6;
}
.page-index-item .main-text{
    color: var(--color-wht);
}
.page-index-item .sub-text{
    font-size: var(--font-small);
    margin-top: .2rem;
    color: var(--color-wht);
}
.page-index-item.booking {
    background: #ddd;
    height: 100%;
    position: relative;
}
.page-index-item.booking::before {
    content: "只今準備中";
    position: absolute;
    top: -1.6rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 99;
    background: var(--color-blk);
    padding: .6rem 1.2rem;
    border-radius: 10rem;
    font-size: .65rem;
}

/* rooms */
.room-container{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.room-item{
    width: 33%;
    margin-right: 1rem;
    margin-bottom: 2rem;
    text-align: center;
    border-bottom: solid 1px var(--color-main);
}
.room-item .grade{
    background: var(--color-main);
    color: var(--color-wht);
    padding: .4rem 1rem;
}
.room-item .price{
    display: flex;
    flex-wrap: wrap;
}
.room-item .price .kv-item{
    width: 33.33%;
}
.room-item .kv-item .key{
    background: var(--color-gry-pale1);
    padding: .4rem 1rem;
}
.room-item .kv-item .value{
    padding: .4rem .6rem;
    margin-bottom: .4rem;
    white-space: pre-line;
}
.price .kv-item .value{
    white-space: nowrap;
}
.room-item .room-number .value{
    min-height: 2.8rem;
}
.room-item .kv-item .value.num{
    font-family: var(--font-family-num);
}

/* price */
.grade-tab-container{
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.grade-tab-item{
    width: 19%;
    margin-right: 1.25%;
    text-align: center;
    margin-bottom: 1rem;
    padding: 1rem; 
    border: solid 1px var(--color-main);
    cursor: pointer;
    white-space: nowrap;
}
.grade-tab-item.blue{
    color: var(--color-grade-blue);
    border: solid .1rem var(--color-grade-blue);
}
.grade-tab-item.purple{
    color: var(--color-grade-purple);
    border: solid .1rem var(--color-grade-purple);
}
.grade-tab-item.red{
    color: var(--color-grade-red);
    border: solid .1rem var(--color-grade-red);
}
.grade-tab-item.orange{
    color: var(--color-grade-orange);
    border: solid .1rem var(--color-grade-orange);
}
.grade-tab-item.yellow{
    color: var(--color-grade-yellow);
    border: solid .1rem var(--color-grade-yellow);
}
.grade-tab-item.green{
    color: var(--color-grade-green);
    border: solid .1rem var(--color-grade-green);
}
.grade-tab-item.aqua{
    color: var(--color-grade-aqua);
    border: solid .1rem var(--color-grade-aqua);
}
.grade-tab-item.brown{
    color: var(--color-grade-brown);
    border: solid .1rem var(--color-grade-brown);
}
.grade-tab-item.gold{
    color: var(--color-grade-gold);
    border: solid .1rem var(--color-grade-gold);
}
.grade-tab-item.platinum{
    color: var(--color-grade-platinum);
    border: solid .1rem var(--color-grade-platinum);
}
.grade-tab-item.ruby{
    color: var(--color-grade-ruby);
    border: solid .1rem var(--color-grade-ruby);
}
.grade-tab-item.aquamarine{
    color: var(--color-grade-aquamarine);
    border: solid .1rem var(--color-grade-aquamarine);
}
.grade-tab-item.pearl{
    color: var(--color-grade-pearl);
    border: solid .1rem var(--color-grade-pearl);
}
.grade-tab-item.diamond{
    color: var(--color-grade-diamond);
    border: solid .1rem var(--color-grade-diamond);
}

.grade-tab-item.active{
    text-decoration: underline;
    text-decoration-thickness: .1rem;
    text-underline-offset: 30%;
}
.grade-tab-item.blue.active{ text-decoration-color: var(--color-grade-blue); }
.grade-tab-item.purple.active{ text-decoration-color: var(--color-grade-purple); }
.grade-tab-item.red.active{ text-decoration-color: var(--color-grade-red); }
.grade-tab-item.orange.active{ text-decoration-color: var(--color-grade-orange); }
.grade-tab-item.yellow.active{ text-decoration-color: var(--color-grade-yellow); }
.grade-tab-item.green.active{ text-decoration-color: var(--color-grade-green); }
.grade-tab-item.aqua.active{ text-decoration-color: var(--color-grade-aqua); }
.grade-tab-item.brown.active{ text-decoration-color: var(--color-grade-brown); }
.grade-tab-item.platinum.active{ text-decoration-color: var(--color-grade-platinum); }
.grade-tab-item.ruby.active{ text-decoration-color: var(--color-grade-ruby); }
.grade-tab-item.aquamarine.active{ text-decoration-color: var(--color-grade-aquamarine); }
.grade-tab-item.pearl.active{ text-decoration-color: var(--color-grade-pearl); }
.grade-tab-item.diamond.active{ text-decoration-color: var(--color-grade-diamond); }

.grade-tab-item:nth-of-type(5n){
    margin-right: 0;
}

.grade-contents-container{
    margin-top: 1rem;
    box-shadow: .1rem .1rem .6rem var(--color-gry);
    padding: 3.6rem min(3rem,8%);
    margin-bottom: 2rem;
}
.grade-contents-item{
    margin-bottom: 1rem;
    display: none;
    opacity: 0;
}
.grade-contents-item.active{
    display: block;
    opacity: 1;
}
.grade-contents-container .grade-contents-item-inner{
    margin-bottom: 4rem;
}
.grade-contents-container .grade-contents-item-inner:last-of-type{
    margin-bottom: 0;
}
.grade-contents-container .grade-contents-item-head{
    font-size: var(--font-xxx-large);
    font-family: var(--font-family-copy);
    margin-bottom: 1rem;
    text-align: center;
    border-bottom: solid 1px var(--color-main);
    padding-bottom: 1rem;
}
.grade-contents-container .grade-contents-item-body{
    border-bottom: solid 1px var(--color-main);
    padding-bottom: 1rem;
    margin-bottom: 1rem;
    text-align: center;
}
.grade-contents-container .grade-contents-item-body .date{
    font-size: var(--font-medium);
    background: var(--color-accent);
    color: var(--color-wht);
    margin-bottom: .4rem;
    text-align: center;
    padding: .4rem 2rem;
    display: inline-block;
    border-radius: 10rem;
}
.grade-contents-container .grade-contents-item-body .price .amount{
    font-size: var(--font-xxx-large);
    font-family: var(--font-family-num);
    margin-right: 1rem;
}

.sub-section{
    margin-top: 6rem;
}
.sub-headline{
    text-align: center;
    margin: 2rem auto;
}
.sub-headline h3{
    font-size: var(--font-xxx-large);
    font-family: var(--font-family-copy);
}
.amenity .card-container{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.amenity .card-item.col-3{
    width: calc(100% / 3.1);
    border: unset;
}
.amenity .card-item .head-item{
    padding: .6rem .2rem;
}
.amenity .card-item img{
    height: unset;
}
.amenity .card-item .body-description{
    padding: .6rem .4rem;
    line-height: 1.25;
}
.caution{
    background: var(--color-gry-pale1);
    padding: 1rem 2rem;
    margin-bottom: 2rem;
}
.caution p{
    margin-bottom: 0;
}

/* services */
.service-container{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 3rem;
}
.service-container:nth-of-type(odd){
    flex-direction: row-reverse;
}
.service-item.image{
    width: 45%;
    margin: auto;
    text-align: center;
} 
.service-item.description{
    width: 50%;
} 
.service-container:nth-of-type(odd) .service-item.description{
    margin-right: 5%;
}
.service-container:nth-of-type(even) .service-item.description{
    margin-left: 5%;
}
.service-item.description .title{
    font-size: var(--font-x-large);
    margin-bottom: 1rem;
    font-family: var(--font-family-copy);
}

/* faq */
#faq{
	counter-reset: num 0; 
}
.faq-contents{
    width: 80%;
    margin: auto;
}
.faq-container{
	margin-bottom: 1.2rem;
	background: var(--color-gry-pale1);
	border-radius: 3rem;
	/* box-shadow: .05rem .05rem .1rem var(--color-main); */
}
.faq-container.active{
	border-radius: 1rem;
}
.faq-item{
	font-size: 1rem;
    padding: 1rem 4.2rem 1rem 6rem;
}
.faq-item.q{
	cursor: pointer;
	position: relative;
}
.faq-container .faq-item.a::before,
.faq-container .faq-item.q::before{
	position: absolute;
	left: 2rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: var(--font-x-large);
	font-weight: 900;
	font-family: var(--font-num);
	letter-spacing: .08rem;
	color: var(--color-main-dark);
}
.faq-container .faq-item.q::before{
	counter-increment: num 1;
	content: "Q" counter(num);
}
.faq-container .faq-item.a::before{
	counter-increment: num 0;
	content: "A" counter(num);
}
.faq-item.q::after{
	content: "+";
	position: absolute;
	top: 50%;
	right: 1.2rem;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 900;
	font-family: var(--font-en);
	transition: .8s;
	padding: 0 .66rem;
}
.faq-container .faq-item.q{
	background: var(--color-main);
	letter-spacing: .05rem;
	font-size: var(--font-large);
    color: var(--color-wht);
}
.faq-container.active .faq-item.q{
	border-radius: 1rem 1rem 0 0;
}
.faq-container .faq-item.q{
	border-radius: 3rem;
	transition: .6s;
	line-height: 1.25;
}
.faq-container .faq-item.q::after{
	transform: translateY(-50%) rotate(180deg);
}
.faq-container.active .faq-item.q::after{
	transform: translateY(-50%) rotate(45deg);
}

.faq-item.a{
	position: relative;
	transition: .6s;
    line-height: 1.4;
}
.faq-container .faq-item.a{
	padding: 0;
	height: 0;
	visibility: hidden;
	opacity: 0;
}
.faq-container.active .faq-item.a{
    font-size: var(--font-medium);
	padding: 1rem 4rem 1rem 6rem;
	letter-spacing: .05rem;
	height: auto;
	visibility: visible;
	opacity: 1;
}

/* ACCESS */
.access-container{
    width: 70%;
    margin: 1rem auto 2rem;
}
.access .kv-item{
    display: flex;
    align-items: center;
    margin: 0 auto;
    line-height: 1.4;
    border-top: solid 1px var(--color-main);
    padding: 1.6rem 5%;
}
.access .kv-item:last-of-type{
    border-bottom: solid 1px var(--color-main);
}
.access .kv-item .key{
    margin-right: 2rem;
    width: 6rem;
    white-space: nowrap;
}
.access .kv-item .value{
    width: 100%;
}

/* contact */
.contact .inner{
    padding-bottom: 8rem;
}
.chat-container{
    display: flex;
    align-items: center;
    justify-content: center;
}
.chat-item.image{
    overflow: hidden;
    width: 10rem;
    height: 10rem;
    margin-right: 2rem;
}
.action-item{
    margin: 0 auto;
    text-align: center;
}
.action-item .description{
    margin-bottom: 1.6rem;
    font-size: var(--font-xx-large);
    font-weight: 900;
    color: var(--color-accent);
}
.action-item .description:before{
    content: "";
    display: inline-block;
    background: url(../images/icon_contact_tel.png) no-repeat;
    background-size: contain;
    width: calc(.82rem * 1.6);
    height: calc(.88rem  * 1.6);
    vertical-align: middle;
    margin-right: .3rem;
    margin-top: -.2rem;
}

.law-container {
    width: 80%;
    margin: auto;
}
.law-container .law-item{
    text-align: center;
    margin-bottom: 1rem;
}
.law-container .law-item .item-head{
    background: var(--color-gry-pale2);
    padding: .4rem 1rem;
    margin-bottom: .6rem;
}
.law-container .law-item .item-body{
    line-height: 1.4;
    padding: 0 1.4rem;
}
@media (min-width: 768px) {
    .page-template-page-maria-theresia-takatsuki .main-contents,
    .page-template-page-maria-theresia-namba .main-contents{
        background: url(../images/hotel_bg_maria_theresia.jpg) repeat center;
        background-size: 100%;
        background-attachment: fixed;
    }
    .page-template-page-anage-kashiba .main-contents,
    .page-template-page-anage-himeji .main-contents{
        background: url(../images/hotel_bg_anage.jpg) repeat center;
        background-size: 100%;
        background-attachment: fixed;
    }
    .page-template-page-angelique-iwade .main-contents{
        background: url(../images/hotel_bg_angelique.jpg) repeat center;
        background-size: 100%;
        background-attachment: fixed;
    }
    .page-template-page-very .main-contents{
        background: url(../images/hotel_bg_very.jpg) repeat center;
        background-size: 100%;
        background-attachment: fixed;
    }
}
@media (max-width: 480px) {
    .btn-trigger{
        top: 1.6rem;
    }
    .outer {
        margin-top: 3rem;
        margin-bottom: 6rem;
    }
    section .inner{
        width: 90%;
        padding: 0;
    }
    .headline .main-text{
        font-size: min(3rem,40px);
    }
    .headline .main-text::before{
        font-size: min(4rem,60px);
    }

    .fv-copy-wrap{
        width: 95%;
    }
    .fv-main-copy {
        font-size: min(3rem,60px);
    }
    .page-index-container{
        justify-content: center;
        width: 100%;
    }
    .page-index{
        padding: 0;
    }
    .page-index-item{
        width: calc(100% / 5);
        padding: 1rem .3rem;
    }
    .page-index-item:nth-of-type(4n){
        border-right: 0;
        margin-right: 0;
    }
    .page-index-item .main-text{
        font-size: var(--font-small);
    }
    .page-index-item .sub-text{
        font-size: var(--font-x-small);
    }
    .grade-tab-item{
        width: 49%;
        margin-right: 1%;
    }
    .grade-tab-item:nth-of-type(even){
        margin-right: 0;
    }
    .grade-tab-item:nth-of-type(5n){
        margin-right: 1%;
    }
    .grade-contents-item-body .price .term{
        display: block;
        margin-top: .4rem;
    }
    .service-container{
        flex-direction: column;
    }
    .service-container:nth-of-type(odd){
        flex-direction: column;
    }
    .service-container:nth-of-type(odd) .service-item.description{
        margin-right: 0;
    }
    .service-container:nth-of-type(even) .service-item.description{
        margin-left: 0;
    }
    .service-item.image,
    .service-item.description{
        width: 100%;
    }
    .service-item.description{
        margin-top: 1rem;
    }

    .amenity .card-item.col-1-sp{
        width: 100%;    
    }
    .access-container,
    .faq-contents{
        width: 100%;
    }
    .chat-container{
        flex-direction: column;
    }
    .chat-item.image{
        margin: 0;
    }
    .chat-item.comment{
        margin: 2rem 0;
    }
    .law-container {
        width: 100%;
    }
}