/* -----------------------------------------------------------
	header
----------------------------------------------------------- */
.s-txt {
  font-size: 75%;
}
.ro-container section {
  scroll-margin-top: 15px
}
#cocktail_header .uk-background-primary {
  background-color: rgba(0, 0, 0, 1);
}
.header1 {
  box-sizing: border-box;
}
.header1 img {
  margin: 0 auto;
  display: block;
}
.header2 img {
  margin: 0 auto;
  display: block;
  height: 90px;
}
.uk-navbar-container:not(.uk-navbar-transparent) {
  background-color: rgba(0, 0, 0, 1);
}
#cocktail_header .cocktail_menu {
  background-color: rgba(0, 0, 0, 1);
}
#cocktail_header .cocktail_subnav > * > :first-child {
  color: rgba(255, 255, 255, 1.00);
}
/*menu*/
#nav_offcanvas_menu .uk-background-primary {
  background-color: rgba(0, 0, 0, 1);
}
#nav_offcanvas_language .uk-background-primary {
  background-color: rgba(0, 0, 0, 1);
}
/*パンくず*/
.header-breadcrumb2 {
  background-color: rgba(0, 0, 0, 1);
}
.header-breadcrumb2 .cocktail_bread > :last-child > *, .header-breadcrumb2 .cocktail_bread > * > * {
  color: rgba(255, 255, 255, 1.00);
  font-size: 1rem;
}
.header-breadcrumb2 .cocktail_bread h1 {
  margin: 0;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
}
.hotel_title {
  border-bottom: 1px #666 solid;
}
@media only screen and (max-width: 640px) {
  .header-breadcrumb2 .cocktail_bread > :last-child > *, .header-breadcrumb2 .cocktail_bread > * > * {
    font-size: 0.8rem;
  }
  .ro-container section {
  scroll-margin-top:0
}
}
/*footer*/
#cocktailstay_footer .uk-background-primary {
  background-color: rgba(0, 0, 0, 1);
}
ul {
  list-style: none;
}
.sns_fix {
  position: fixed;
  right: 0;
  bottom: 150px;
  z-index: 100
}
.sns_fix ul {
  list-style-type: none;
  width: 100px;
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: flex-start
}
.sns_fix ul li {
  width: 80px;
  height: 80px;
  box-sizing: border-box;
  border: 2px solid rgb(58, 72, 97);
  padding: 18px;
  font-size: 0;
  border-radius: 15px 0 10px 0;
  box-shadow: 5px 5px 5px rgb(58 72 97)
}
.sns_fix ul li img {
  width: 34px;
  height: 34px
}
.sns_fix ul li:first-child {
  box-shadow: 5px 0 5px rgb(58 72 97)
}
@media (max-width:767px) {
  .sns_fix {
    bottom: 180px
  }
  .sns_fix ul {
    width: 70px
  }
  .sns_fix ul li {
    width: 60px;
    height: 60px;
    padding: 13px
  }
}
/* -----------------------------------------------------------
	rooms
----------------------------------------------------------- */
.ro-container {
  width: 95%;
  margin: 0 auto;
}
.ameni_img {
  width: 50%;
}
.ameni_img img {
  width: 90%;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .ameni_img {
    width: 100%;
  }
  .ameni_img img {
    width: 90%;
    text-align: center;
  }
}
.room_img {
  padding: 1em;
}
.w80 {
  width: 80% !important;
}
.w85 {
  width: 85% !important;
}
.w90 {
  width: 90% !important;
}
.w95 {
  width: 95% !important;
}
h2.rooms_ttl {
  position: relative;
  padding: .5em .75em;
  background-color: #f6f6f6;
  font-size: 30px;
}
h2.rooms_ttl::before, h2.rooms_ttl::after {
  position: absolute;
  bottom: 8px;
  z-index: -1;
  content: '';
  width: 30%;
  height: 50%;
  box-shadow: 0 10px 15px rgba(0, 0, 0, .2);
}
h2.rooms_ttl::before {
  -webkit-transform: rotate(-3deg);
  transform: rotate(-3deg);
  left: .3em;
}
h2.rooms_ttl::after {
  -webkit-transform: rotate(3deg);
  transform: rotate(3deg);
  right: .3em;
}
ul.ro_list1 {
  padding: 0.5em;
  list-style: none;
}
ul.ro_list1 li {
  position: relative;
  padding: 0.5em 1em 0.5em 2.3em;
  margin-bottom: 5px;
  border-bottom: 1px solid rgba(0, 35, 199, 1);
}
ul.ro_list1 li:after, ul.ro_list1 li:before {
  content: '';
  position: absolute;
  transform: rotate(45deg);
}
ul.ro_list1 li:before {
  top: 0.7em;
  left: 0.2em;
  width: 12px;
  height: 12px;
  border: 2px solid rgba(0, 35, 199, 1);
}
ul.ro_list1 li:after {
  top: 0.9em;
  left: 0.7em;
  width: 14px;
  height: 14px;
  background: rgba(0, 35, 199, 0.5);
  transform: rotate(60deg);
}
/* 20220713 */
.rooms-info {
  margin: 0 0 30px;
}
.rooms-box {
  padding: 20px 20px 20px 5%;
}
/* .rooms-reserve a {
  padding: 20px;
  border: 1px solid #ddd;
  border-radius: 5px;
  box-shadow: 2px 2px 0 #000;
  font-size: 18px;
  background: #f1e767;
  background: -webkit-gradient(linear, left top, left bottom, from(#fdfbfb), to(#ebedee));
  background: -webkit-linear-gradient(top, #fdfbfb 0%, #ebedee 100%);
  background: linear-gradient(to bottom, #fdfbfb 0%, #ebedee 100%);
  -webkit-box-shadow: inset 1px 1px 1px #fff;
  box-shadow: 2px 2px 0px #000;
  display: inline-block;
} */
.rooms-reserve a {
  padding: 10px 30px;
  color: #333;
  border: 1px solid #ccc;
  border-radius: 1px;
  font-size: 15px;
  display: inline-block;
}
.rooms-reserve a:after {
  font-family: 'fontawesome';
  content: '\f0da';
  margin-left: 5px;
}
.rooms-reserve a:hover {
  text-decoration: none;
  color: #333;
  border: 1px solid #333;
}
/* .rooms-reserve a:hover {
  box-shadow: none;
  text-decoration: none;
  color: #3A4861;
} */
.rooms-box h3 {
  font-size: 25px;
  margin-bottom: 15px;
}
.rooms-box ul li {
  font-size: 18px;
}

/* -----------------------------------------------------------
	レストラン
----------------------------------------------------------- */
.bf-block {
  margin-bottom: 15px;
}
.bf-txt h2 {
  font-size: 35px;
  margin-bottom: 15px;
}
.bf-txt p {
  margin-top: 0;
  font-size: 18px;
}
.bf-txt th, .bf-txt td {
  font-size: 18px;
  padding: 10px;
}
.bf-txt th {
  width: 40%;
}
.carino-tel-link {
font-size: 150%;
font-family: 'Cinzel', serif;
}
.carino-tel-link:hover {
text-decoration: none;
color: #000;
}
@media (max-width: 766px) {
  .bf-block {
    margin-bottom: 30px;
  }
}
/* -----------------------------------------------------------
	breakfast
----------------------------------------------------------- */
.breakfast-txt {
  text-align: center;
  font-size: 150%;
  font-weight: 500;
}
.calino_menu {
  padding: 3em;
  text-align: center
}
.carino_recommend h2 {
  font-size: 2rem;
  padding: 3rem;
}
@media only screen and (max-width: 767px) {
  .breakfast-txt {
    font-size: 115%;
  }
  .calino_menu {
    padding: 0
  }
  .carino_recommend h2 {
    padding: 1rem 0;
  }
}
/* 1周年記念朝食付予約ボタン　*/
.rr_buttonca {
  background-color: rgba(0, 0, 0, 1.00);
  overflow: hidden;
  position: relative;
  letter-spacing: 0.1em;
}
.rr_buttonca span {
  color: rgba(255, 255, 255, 1.00);
  position: relative;
  z-index: 1;
}
a.rr_buttonca:hover span {
  color: rgba(0, 0, 0, 1.00);
}
a.rr_buttonca:before {
  position: absolute;
  top: 0;
  left: calc(-100% + 10px);
  width: 100%;
  height: 100%;
  content: '';
  -webkit-transition: all .5s ease-in-out;
  transition: all .5s ease-in-out;
  -webkit-transform: translateX(0) translateY(0);
  transform: translateX(0) translateY(0);
  background: #FBCA60;
}
a.rr_buttonca:after {
  position: absolute;
  top: 0;
  right: calc(-100% + 10px);
  width: 100%;
  height: 100%;
  content: '';
  -webkit-transition: all .5s ease-in-out;
  transition: all .5s ease-in-out;
  -webkit-transform: translateX(0) translateY(0);
  transform: translateX(0) translateY(0);
  background: #FBCA60;
}
a.rr_buttonca:hover:before {
  -webkit-transform: translateX(50%) translateY(0);
  transform: translateX(50%) translateY(0);
}
a.rr_buttonca:hover:after {
  -webkit-transform: translateX(-50%) translateY(0);
  transform: translateX(-50%) translateY(0);
}
/* -----------------------------------------------------------
	アクティビティ
----------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;400;500;700;800&display=swap');
.activty_annotation {
  border: 1px solid rgba(0, 12, 152, 1.00);
  padding: 1rem 2rem;
  margin: 0 0 1em;
  width: 55%;
  text-align: left;
  margin: 0 auto
}
.seasir-h3 {
  font-size: 1.6em;
  margin-top: 0;
  margin-bottom: 2.5em;
}
@media (max-width:767px) {
  .activty_annotation {
    width: 80%
  }
}
/* -----------------------------------------------------------
	FAQ
----------------------------------------------------------- */
.check_input {
  display: none;
}
.check_label {
  display: block;
  color: #fff;
  border-bottom: 1px solid #fff;
  padding: 10px;
  background-repeat: no-repeat;
  background-size: 16px;
  background-position: 98% center;
}
/*ラベルホバー時*/
.accbox label:hover {
  background: #fff5ee;
}
.arrow {
  position: relative;
  display: inline-block;
  padding-left: 20px;
}
.arrow::before {
  content: '';
  width: 7px;
  height: 7px;
  border: 0px;
  border-top: solid 3px #F54D28;
  border-right: solid 3px #F54D28;
  -ms-transform: rotate(133deg);
  -webkit-transform: rotate(133deg);
  transform: rotate(133deg);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -13px;
  margin-left: 15px;
}
/*クリックで中身表示-*/
.check_input:checked + .arrow {
  height: auto;
  padding: 5px;
  background: #eaeaea;
  opacity: 1;
  transform: rotate(-52deg);
}
/* コンテンツ非表示 */
.contents {
  display: none;
}
/* checkをクリックしたらコンテンツを表示 */
.check_input:checked + .check_label + .contents {
  display: block;
}
#qa div[id^='qa_'] {
  box-sizing: border-box;
  width: 95%;
  margin: 0 auto 2rem;
  border-radius: 2%;
  box-shadow: 0 5px 15px rgb(0 0 0 / 8%);
  padding: 2rem
}
#qa h2.qa_h2 {
  font-size: 1.3rem;
}
/* -----------------------------------------------------------
	アクセス
----------------------------------------------------------- */
.parking-map {
  margin: 20px 0 0;
}
/* -----------------------------------------------------------
	access parking
----------------------------------------------------------- */
#parking .parking_h2 {
  background-color: rgba(33, 22, 0, 1.00);
  color: rgba(255, 255, 255, 1.00);
  padding: 15px 0 15px 2rem;
  margin: 0
}
#parking .flex-width1-2 {
  width: 50%;
  padding: 0 0 0 2em;
}
#parking .parking_list .parking_info {
  margin: 1rem 0 0;
  padding: 0
}
.parking_annotation {
  list-style: none
}
.parkingbox {
  margin: 2rem 0
}
.parkingbox .parkingimg {
  max-width: 1200px;
  width: 80%;
  margin: 0 auto 2rem
}
.map_link {
  margin: 1rem 0 0
}
.map_link .pdflink {
  text-align: right
}
.map_link .pdflink a {
  padding: 0.2rem;
  border: 1px solid rgba(0, 0, 0, 1.00)
}
.map_link .pdflink a:hover {
  color: rgba(0, 0, 0, 1.00)
}
.txtbl span {
  background-color: rgba(0, 0, 0, 1.00);
  color: rgba(255, 255, 255, 1.00);
  padding: 0.3rem;
  display: inline-block;
  margin: 0 0.5rem 0 0
}
.txtbl2 span {
  background-color: rgba(56, 87, 35, 1.00);
  color: rgba(255, 255, 255, 1.00);
  padding: 0.3rem;
  display: inline-block;
  margin: 0 0.5rem 0 0;
}
.parking_list .parking_box {
  margin-left: 0;
  width: 100%;
  justify-content: flex-start;
}
.parking_list .parking_ttl {
  margin-left: 0;
  width: 100%;
  justify-content: space-between
}
.parking_list .uk-child-width-1-2 {
  justify-content: space-between
}
.parking_box {
  margin: 1rem 0 0;
}
h3.parkingttl {
  width: 80%;
  padding: 0;
}
h3.parkingttl > div {
  display: flex;
  align-items: center;
  height: 100%;
}
.googlemapimg {
  width: 20%;
  padding: 0;
  margin: 0
}
span.pink {
  background-color: #e61673;
  color: #fff;
  padding: 5px;
  margin: 0 1rem 0 0;
  width: 2.8rem;
  text-align: center;
}
.parking_list .parking_infor [class*="txtbl"], .parking_list .parking_infor .parking_ttl {
  margin: 0 0 0 5%;
}
table.parking_table {
  margin: 1rem 5% 0 0;
  border-collapse: collapse;
  width: 95%;
}
.parking_list .parking_infor > table.parking_table {
  margin: 1rem 0 0 5%;
}
table.parking_table th, table.parking_table td {
  border: 1px solid #000;
  padding: 0.4rem 0.5rem;
}
table.parking_table th {
  background-color: #efefef;
  width: 24%
}
table.parking_table td {
  width: 76%
}
@media (max-width: 768px) {
  #parking .flex-width1-2 {
    width: 100%
  }
  .parkingbox .parkingimg {
    width: 95%
  }
  .parkingttl span {
    display: block
  }
  table.parking_table {
    width: 100%;
    font-size: 0.8rem;
  }
  .parking_list [class*="uk-child-width"] div:nth-child(2) div:first-child {
    margin: 0 auto;
  }
  .parking_list [class*="uk-child-width"] div:nth-child(2) table.parking_table {
    margin: 1rem auto;
  }
  .parking_list .parking_infor [class*="txtbl"], .parking_list .parking_infor .parking_ttl {
    margin: 0;
  }
}
/* -----------------------------------------------------------
	新breakfast 20250326
----------------------------------------------------------- */
.new-bk-info {
  width: 1200px;
  margin: 50px auto 80px;
  max-width: 100%;
}
.new-bk-info-box h2 {
font-size: 90px;
    font-weight: 600;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
    text-align: center;
    line-height: 0.8;
    margin-bottom: 20px;
}
.new-bk-info-box h3 {
font-size: 30px;
    font-weight: 600;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
    text-align: center;
    margin-bottom: 45px;
}
.new-bk-info-box h2 span {
  font-size: 60%;
  font-weight: 500;
}
.new-bk-info-box p {
  font-size: 22px;
  font-weight: 500;
  text-align: center;
}
.new-bk-menu-section {
  width: 1200px;
  margin: 0 auto;
}
.new-bk-menu-section h2 {
  text-align: center;
  display: block;
  font-size: 60px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
  font-weight: 600;
  line-height: 0.8;
  margin-bottom: 30px;
}
.new-bk-menu-section h2 span {
  font-size: 55%;
  font-weight: 500;
}
.new-bk-menu-section img {
  width: 100%;
}
.new-bk-menu-block {
  margin-bottom: 50px;
}
.new-bk-menu-section-txt {
  margin-bottom: 30px;
}
.new-bk-menu-section-txt h3 {
  font-size: 26px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
}
.new-bk-menu-section-txt p {
  font-size: 18px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", Meiryo, Verdana, sans-serif;
}
.faded-image-r {
    -webkit-mask-image: linear-gradient(to right, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(to right, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
}
.faded-image-l {
    -webkit-mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(to left, rgba(0, 0, 0, 1) 70%, rgba(0, 0, 0, 0) 100%);
}
.new-bk-menu-section02 h3 {
  text-align: center;
font-size: 26px;
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", 游ゴシック, YuGothic, メイリオ, Meiryo, Verdana, sans-serif;
}
.new-bk-menu-section02 p {
font-size: 18px;
}
.new-bk-menu-section02 {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto;
}
.new-bk-menu-section02 .uk-slideshow-items img {
  width: 100%;
}

@media (max-width: 1200px) {
.new-bk-menu-section {
  width: 100%;
}
.new-bk-info-box p br {
  display: none;
}
.new-bk-menu-section-txt br {
  display: none;
}
}
@media (max-width: 700px) {
.new-bk-info-box h2 {
font-size: 55px;
}
.new-bk-info-box h3 {
font-size: 20px;
}
  .new-bk-info-box p {
    font-size: 18px;
  text-align: left;
}
.new-bk-menu-section-txt h3 {
  font-size: 20px;
}
.new-bk-menu-section-txt p {
  font-size: 20px;
  text-align: left;
}
.new-bk-menu-section h2 {
  font-size: 40px;
}
.new-bk-menu-section02 h3 {
  font-size: 20px;
}
.new-bk-menu-section02 p {
font-size: 20px;
}
}
/* 時刻表 */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Arial', sans-serif;
    line-height: 1.6;
    background-color: #f5f5f5;
}

.tab-container {
    max-width: 100%;
    margin: 15px auto 0;
    background-color: white;
    border-radius: 5px;
}

/* ラジオボタンを非表示にする */
.tab-radio {
    display: none;
}

/* タブナビゲーションのスタイル */
.tabs {
    display: flex;
    background-color: #f1f1f1;
    border-bottom: 1px solid #f1f1f1;
}

.tab {
    padding: 10px 5px;
    cursor: pointer;
    transition: background-color 0.3s ease;
    text-align: center;
    flex: 1;
    background-color: #b5bcca;
    color: #fff;
    border-radius: 10px 10px 0 0;
    margin-right: 5%;
}

.tab:hover {
    background-color: #e9e9e9;
}

/* タブコンテンツのスタイル */
.tab-content {
    position: relative;
    min-height: 200px; /* 最小高さを設定 */
    margin-bottom: 50px;
}

.content {
    position: absolute;
    width: 100%;
    opacity: 0;
    visibility: hidden;
    padding: 20px;
    transition: opacity 0.3s ease;
}

.content h2 {
    margin-bottom: 10px;
    color: #333;
}

.content p {
    color: #666;
    margin-bottom: 10px;
}

/* チェックボックスハックを使用したタブ切り替え */
#tab1-radio:checked ~ .tabs label[for="tab1-radio"],
#tab2-radio:checked ~ .tabs label[for="tab2-radio"],
#tab3-radio:checked ~ .tabs label[for="tab3-radio"] {
    background-color: white;
    font-weight: bold;
    color: #666;
}

#tab1-radio:checked ~ .tab-content #tab1,
#tab2-radio:checked ~ .tab-content #tab2,
#tab3-radio:checked ~ .tab-content #tab3 {
    opacity: 1;
    visibility: visible;
    z-index: 1;
    background-color: #fff;
}

/* コンテンツの高さを動的に調整するための設定 */
.tab-content:after {
    content: "";
    display: block;
    clear: both;
}

#tab1-radio:checked ~ .tab-content {
    height: auto;
    min-height: 200px;
}

#tab2-radio:checked ~ .tab-content {
    height: auto;
    min-height: 200px;
}

#tab3-radio:checked ~ .tab-content {
    height: auto;
    min-height: 200px;
}

/* アクティブなタブのコンテンツに対するスタイリング */
#tab1-radio:checked ~ .tab-content #tab1,
#tab2-radio:checked ~ .tab-content #tab2,
#tab3-radio:checked ~ .tab-content #tab3 {
    position: relative;
    height: auto;
}
#bus .parking_h2 {
    background-color: rgba(33, 22, 0, 1.00);
    color: rgba(255, 255, 255, 1.00);
    padding: 15px 0 15px 2rem;
    margin: 0;
}
.picup-point-img {
  text-align: center;
}
.time-table-txt {
  padding: 0 20px 10px;
}
.route-img {
  text-align: center;
  margin: 50px auto;
}
