/* Hotel Partners
========================= */
.hp-container { display: flex; flex-direction: column; align-items: center; margin: 0 2em; padding: 6em 0 3em; }
.hp-inner { display: flex; flex-direction: column; max-width: 1480px; width: 100%; }

.hp-title { display: flex; flex-direction: column; align-items: center; margin: 0; padding: 0.5em 0 0.8em; }
.hp-title span { color: #1a1a1a; font-family: 'Mulish', sans-serif; font-size: 2.6rem; font-weight: 600; line-height: 1.4; letter-spacing: .08em; padding: 0 0 0.25em; text-transform: uppercase; }
.hp-title span:last-of-type { font-family: 'Mulish', sans-serif; font-size: 2rem; letter-spacing: .02em; padding: 0; text-transform: none; }

/* Stay
========================= */
.hp-stay { display: flex; flex-direction: row; flex-wrap: wrap; margin: 0 auto; padding: .5em 0 2em 4em; width: 100%; position: relative; }

.hp-stay .stay-logo img { display: block; margin: 0 auto; padding: 0 0 .5em; max-width: 225px; width: 100%; }
.hp-stay .stay-overview { display: flex; flex-direction: column; }
.hp-stay .stay-overview span { color: #1a1a1a; font-family: 'Mulish', sans-serif; font-size: 1.8rem; font-weight: 800; line-height: 1.4; margin: 0; padding: 0 0 0.2em; text-align: center; }

.hp-stay .stay-overview a { color: #1a1a1a; font-family: 'Mulish', sans-serif; font-size: 1.8rem; font-weight: 600; line-height: 1.4; margin: 0; padding: 0 0 0.2em; text-align: center; }
.hp-stay .stay-overview a span { font-weight: 600; }
.hp-stay .stay-overview p { color: #1a1a1a; display: flex; flex-direction: row; flex-wrap: wrap; font-family: 'Mulish', sans-serif; font-size: 1.8rem; font-weight: 400; line-height: 1.4; margin: 0; padding: 0 0 0.5em; }

.hp-stay .stay-overview p:first-of-type { padding: 0.5em 0; }
.hp-stay .stay-overview p:last-of-type { padding: 0; }

.hp-stay .stay-overview-top { display: flex; flex-direction: column; }
.hp-stay .stay-overview-top:after { content: ""; border-bottom: 2px solid #fec70f; display: block; margin: 0 auto; padding-top: 0.8em; width: 15%; position: relative; }
.hp-stay .stay-overview-bottom { padding: 0.5em; }

.hp-stay .column { display: flex; flex-direction: column; margin: 0; padding: 1.5em 1em 1em; width: calc(1/2*100% - (1 - 1/2)*0px); }
.hp-stay .column .column-feat-img { background-color: #fff; display: block; max-width: 100%; min-height: 1px; max-height: 600px; overflow: hidden; }
.hp-stay .column .column-feat-img .feat-img { background-position: center center; background-repeat: no-repeat; background-size: cover; display: block; padding-bottom: 56.24%; height: 100%; width: 100%; }
.hp-stay .column .column-details { display: flex; flex-direction: column; justify-content: center; align-items: center; padding: 1em 0 0; min-height: 250px; }
.hp-stay .stay-logo { margin: 0 auto; }

/* Vertical Title
========================= */
.hp-stay .vert-title-container { display: flex; align-items: center; position: absolute; top: 0; bottom: 35px; left: 25px; right: 0; margin: 0; padding: 0; min-height: 1px; width: 20px; }
.hp-stay .vert-title-inner { width: 100%; }
.hp-stay .vert-title-inner:before { content: " "; display: table; }
.hp-stay .vert-title-divider { border-top: 1px solid transparent; display: flex; flex-direction: column; align-items: center; justify-content: center; height: 0; font-size: 0; line-height: 0; position: relative; }
.hp-stay .vert-title { margin-bottom: 1.1em; writing-mode: tb-rl; transform: rotate(-180deg); }
.hp-stay .vert-title span { color: #000; font-family: 'Mulish', sans-serif; font-weight: 800; font-size: 1.4rem; letter-spacing: .3em; line-height: 18px; text-transform: uppercase; }
.hp-stay .vert-title span:before { left: 50%; content: ''; height: 30px; width: 1px; background-color: #000; position: absolute; top: -45px; margin-left: -1px; }

/* Responsive
--------------------------------------------- */
@media only screen and (max-width: 1480px) {
.hp-stay { padding: 0.5em 0 1em 4em; }
}

@media only screen and (max-width: 1280px) {
.hp-container { padding: 2em 0; }
.hp-title span { font-size: 2.5rem; }
}

@media only screen and (max-width: 1023px) {
.hp-container { padding: 1.5em 0 2em; }
.hp-title span { font-size: 2.4rem; }
.hp-title span:last-of-type { font-size: 1.9rem; }
.hp-stay .column { padding: 1.5em 0.8em 1em; }
.hp-stay .stay-logo img { max-width: 200px; }
}

@media only screen and (max-width: 880px) {
.hp-stay { padding: .5em 2em 1em 4em; }
.hp-stay .column { padding: 1em 0.8em; width: 100%; }
}

@media only screen and (max-width: 768px) {
.hp-title span { font-size: 2.3rem; }
.hp-title span:last-of-type { font-size: 1.8rem; }
.hp-stay .vert-title-container { left: 5px; }
}

@media only screen and (max-width: 719px) {
.hp-stay .vert-title-container { left: 0px; }
.hp-stay .vert-title span { font-size: 1.3rem; }
}

@media only screen and (max-width: 640px) {
.hp-container { margin: 0 1.5em; padding: 1.5em 0; }
.hp-title { padding: 0.5em 0; }
.hp-title span { font-size: 2.2rem; }
.hp-title span:last-of-type { font-size: 1.7rem; }
.hp-stay .vert-title-container { display: none; }
.hp-stay { padding: .5em 0 1em; }
.hp-stay .column { padding: 1em 0; }
.hp-stay .column:nth-of-type(2) { padding: 0.5em 0; }
}

@media only screen and (max-width: 480px) {
.hp-container { padding: 1em 0 0.5em; }
.hp-title span { font-size: 2.1rem; }
.hp-stay .column { padding: .8em 0; }
.hp-stay .stay-overview p { font-size: 1.7rem; }
}
