*{
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
-o-box-sizing: border-box;
-ms-box-sizing: border-box;
box-sizing: border-box;
}
html { scroll-behavior: smooth;}

/* カスタムCSS */
body {
font-family: "游ゴシック体",YuGothic,"游ゴシック","Yu Gothic","メイリオ",sans-serif;
font-weight: 400;
font-style: 900;
margin: 0;
padding: 0;
font-size:1.2rem;
text-align: justify;
text-justify: inter-ideograph;
}

h2 {
font-family:"Noto Serif JP", serif;
margin:100px auto 80px auto;
font-size:3.2rem;
align-items: center;
letter-spacing: 4px;
line-height: 0.7;
color:#2c1b1e;
}


h2 .small {
font-size:1.6rem;
letter-spacing: 1px;
color:#2c1b1e;
}
h3 {
font-family:"Noto Serif JP", serif;
font-size:1.8rem;
margin:80px auto 40px auto;
align-items: center;
max-width:600px;
color:#2c1b1e;

}
h4{
font-size:1.8rem;
}
h5{
font-size:1.4rem;
}

a {
color:#0383D5;
}
a:hover {
transition-duration: 0.3s;
text-decoration: none;
}

.t_gothic{
font-family: 'Noto Sans JP', "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
font-weight: 600;
}


.t_msg{
-ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
}

table {
margin:0 auto 50px auto;
width:100%;
max-width:600px;
border-radius: 10px;
background:#FFF;
padding-bottom:10px;
}
th,td {
padding: 10px 20px;
text-align: left;
background:#FFF;
}
td.cell_s{
font-size:1.0rem;
}
th {
border-bottom:1px dotted #CCC;
}
td {
border-bottom:1px dotted #CCC;
}
tr {
}
table tr:last-child th,
table tr:last-child td{
border:none;
}
p {
}
dd dt {
padding:0;
}

/* responsive */
.dsp_pc{
display: block;
}
.dsp_sp{
display: none;
}

.centered {
text-align: center;
}


/********** fadein *******************/
.fadein {
opacity: 0;
transform: translateY(20px);
transition: opacity 1s ease, transform 1s ease;
}

.fadein.scrollin {
opacity: 1;
transform: translateY(0);
}




section {

}
section {
position: relative;
padding-bottom:80px;
}
section.line::before {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
width: 100%;
height: 5px;
margin: 0 auto;
text-align: center;
background-image: -webkit-linear-gradient(left, transparent, #2c1b1e 25%, #2c1b1e 75%, transparent);
background-image: linear-gradient(to right, transparent, #2c1b1e 25%, #2c1b1e 75%, transparent);
background-position: center;
background-repeat: no-repeat;
}
section.line h2{
margin-top:100px;
}

section.service {
padding: 200px 0 0 0;
}

section.service::before{
height: 0;
}
section#news {
padding-top:10px;
}
.wave {
bottom: 0;
}


.flex {
display: flex; /* フレックスボックスで横並び */
flex-wrap: wrap; /* 横幅が足りない場合は折り返し */
}











section.no02 {
background:#F7F0E8;
}

#review iframe {
width: 100%;
aspect-ratio: 16 / 9;
height: auto;
max-width:1200px;
border: none;
margin: 0 auto;
position: relative;
}


img {
max-width: 100%;
height: auto;
}

/**** Status メッセージ ****/
#status {
padding:10px 30px 12px 30px;
border-radius: 15px;
font-size:1.2rem;
line-height:1.4;
width:600px;
height:460px;
margin:30px auto 60px auto;
text-align: center;
border:4px solid #000;
}
#status dl {
padding-bottom:30px;
border-bottom:3px solid #000;
}
#status dt {
font-size:2.0rem;
text-align: center;
font-weight:bold;
}
#status dl dd {
text-align: left;
margin:0;
padding:0;
}
#status iframe{
border:none;
width:100%;
height:290px;
overflow: auto;
}
.msg{
max-width: 640px;
margin:0 auto 50px auto;
text-align: left;
font-size:1.4rem;
font-weight: 600;
line-height: 1.6;
font-family: "Zen Kurenaido", serif;
}

#logo {
width:150px;
height:auto;
position:fixed;
top:10px;
left:20px;
z-index: 999;
}

.social_embed {
text-align: center;
width:500px;
margin:0 auto;
}
blockquote{
}


#b_yoyaku {
font-family: "Zen Kurenaido", serif;
position:fixed;
bottom:0;
right:0;
font-weight:500;
color:#FFF;
text-align: center;
z-index:9999;
line-height:0.7;
}
#b_yoyaku .small {
font-size:1.0rem;
}
#b_yoyaku a {
text-decoration: none;
display: block;
padding:15px 20px 18px 20px;
color:#FFF;
font-size:2.4rem;
background-color: #2c1b1e;
}
#b_yoyaku a:hover {
background:#CC0000;
}

header {
position: relative;
}

/************************************************
Header
*************************************************/

/********* head slide-show ***********/
header {
width: 100%;
display: flex; /* 横並びにするためにflexboxを使用 */
flex-wrap: nowrap; /* 折り返さない */
height: 100vh; /* ヘッダー全体の高さ */
}

header .slide-show {
display: flex;
background-size: cover;
background-position: center;
height: 100%; /* ヘッダー全体の高さに合わせる */
animation: slideShow 30s infinite;
width: 70%; /* 幅を70%に設定 */
}

header h1 {
font-family: "Noto Serif JP", serif;
color: #2c1b1e;
font-weight: bold;
font-size: calc(1.2vw + 0.8rem); /* サイズ感を維持 */
}

header h1 .small {
font-size: calc(1.2vw + 0.5rem); /* サイズ感を維持 */
}

header h1 .t_en {
display: block;
color: #AAA;
font-size: calc(1.0vw + 0.4rem); /* サイズ感を維持 */
}

header .t_copy {
display: flex;
justify-content: center; /* コンテンツを中央に配置 */
align-items: center; /* コンテンツを垂直方向に中央揃え */
width: 30%; /* 幅を30%に設定 */
font-size: calc(2vw + 2rem); /* サイズ感を維持 */
line-height: 1.2;
letter-spacing: 2px;
box-sizing: border-box; /* パディングを含めたサイズ計算 */
padding: 10px 3%;
}

header .t_copy p {
font-family: "Zen Kurenaido", serif;
line-height: 1.0;
margin: 0 1% 0 2.5%;
font-size: calc(1.6vw + 1.5rem); /* 一番大きいフォントサイズ */
}

header .t_copy .no01 {
font-family: "Zen Kurenaido", serif;
font-weight: bold;
font-size: calc(1.0vw + 0.4rem); /* サイズ感を維持 */
line-height: 1.6;
text-orientation: upright;
}

@media (max-width: 1000px) {
header {
flex-direction: column; /* 縦並びに変更 */
height: auto; /* スマホ版では高さを自動調整 */
}

header h1 {
letter-spacing: 0;
font-size: calc(1.5vw + 1rem); /* レスポンシブ用のフォントサイズ */
}

header .t_copy {
width: 100%; /* 幅を100%に設定 */
padding: 10px; /* 内側の余白を調整 */
font-size: calc(1.2rem + 1vw); /* フォントサイズを調整 */
line-height: 1.5;
text-align: center; /* テキストを中央揃え */
}

header .t_copy p {
margin-bottom: 10px;
font-size: calc(1.2rem + 1vw); /* 調整 */
}

header .slide-show {
width: 100%; /* 幅を100%に設定 */
height: 40vh; /* 高さを40%に設定 */
background-size: cover; /* 背景画像を全体にフィットさせる */
background-position: center; /* 背景画像を中央揃え */
animation: slideShow 30s infinite;
}

header .slide-show p {
font-size: calc(1.5rem + 1vw); /* 調整 */
color: #FFF;
text-shadow: 0 0 10px #000, 0 0 20px #000, 0 0 30px #000; /* グロー効果 */
position: absolute;
bottom: 10px;
left: 20px;
}
}

@media (max-width: 768px) {
header h1 {
font-size: calc(0.6rem + 0.8vw); /* 更に小さく */
}
header h1 .t_en {
font-size: calc(0.3rem + 0.2vw); /* 更に小さく */
}

header .t_copy {
font-size: calc(1rem + 1vw); /* 更に小さく */
}

header .t_copy p {
font-size: calc(1.2rem + 0.5vw); /* 更に小さく */
}
header .t_copy .no01 {
font-size: calc(0.5rem + 0.4vw); /* 更に小さく */

}
}


/********* Navigation ***********/
.main-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #2c1b1e;
  color: white;
  padding: 0 20px;
  position: fixed;
  z-index: 99;
  width: 100%;
  top: 0;
  left: 0;
}

.main-nav .menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
}

.main-nav .menu li {
  position: relative;
}

.main-nav .menu a {
  text-decoration: none;
  color: white;
  padding: 5px 30px;
  display: block;
}

.main-nav .menu a:hover {
  background: #000;
}

.main-nav .submenu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background-color: #2c1b1e;
  list-style: none;
  margin: 0;
  padding: 10px 0;
  min-width: 150px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.5);
}

.main-nav .submenu li {
  margin: 0;
}

.main-nav .submenu a {
  padding: 5px 20px;
  white-space: nowrap;
}

.submenu-parent:hover .submenu {
  display: block;
  width: max-content;
}

.hamburger-menu {
  display: none;
  padding:2px 8px;
  background: #000;
  border: none;
  color: white;
  cursor: pointer;
  position: absolute;
  right: 10px;
  top: 10px;
  z-index: 99999;
  border-radius: 2px;
}

.menu-toggle {
  display: none;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .main-nav {
    justify-content: flex-end;
  }

  .main-nav .menu {
    display: none;
    flex-direction: column;
    background-color: #333;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    padding: 60px 0 0 0;
    z-index: 1000;
    text-align: left;
    height: 100vh;
    overflow-y: auto;
  }

  .menu-toggle:checked ~ .menu {
    display: flex;
  }

  .main-nav .menu li {
    margin: 0;
    padding-left: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
  }

  .main-nav .submenu {
    display: block;
    position: static;
    background-color: transparent;
    box-shadow: none;
    padding: 0;
    margin-left: 20px;
  }

  .main-nav a {
    font-size: 1.5rem;
    padding: 15px 0;
  }

  .main-nav .submenu a {
    padding: 10px 0;
    font-size: 1.6rem;
  }

  .hamburger-menu {
    display: block;
    color: white;
  }

  .submenu-parent > a::after {
    content: '▼';
    margin-left: 10px;
    font-size: 0.7em;
  }

  .submenu-parent .submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
  }

  .submenu-parent:hover .submenu,
  .submenu-parent:focus-within .submenu {
    max-height: 500px;
  }
}

/* デスクトップ時のサブメニュー表示 */
@media (min-width: 769px) {
  .submenu-parent:hover .submenu {
    display: block;
  }
}



/* 大スライドショー */
.carousel-container {
position: relative;
overflow: hidden;
width: 100%; /* コンテナの幅を画面幅いっぱいに */
margin: auto;
}

.carousel {
display: flex;
transition: transform 0.5s ease;
}

.carousel img {
min-width: 100%; /* 画像の幅をコンテナの幅に合わせる */
display: block;
opacity: 0.3; /* 非アクティブな画像の透明度を下げる */
transition: opacity 0.5s ease;
}

.carousel img.active {
opacity: 1; /* アクティブな画像の透明度を通常に */
}

.carousel-button {
position: absolute;
top: 50%;
transform: translateY(-50%);
background-color: rgba(0, 0, 0, 0.5);
color: white;
border: none;
cursor: pointer;
padding: 10px;
font-size: 18px;
}

.carousel-button.prev {
left: 10px;
}
.carousel-button.next {
right: 10px;
}
.carousel-container p {
width:200px;
}


/************************************************
小湊鉄道スライド
*************************************************/
.access_by_train {
display: flex;
justify-content: center; /* コンテンツを水平中央に配置 */
align-items: center;
height: 900px;
position: relative;
max-width:1080px;
margin:0 auto;
padding:0;
background:#FFF;
}
.slide {
flex: 0 0 auto;
display: flex;
opacity: 0;
transition: opacity 0.5s ease;
position: absolute;
top: 50px; /* 上に50ピクセルの余白を設定 */
bottom: 50px; /* 下に50ピクセルの余白を設定 */
width:900px;
align-items: center;
}
.active-slide {
opacity: 1; /* アクティブなスライドはフェードイン */
}
.image {
flex: 1;
}
.text {
font-family: "Zen Kurenaido", serif;
font-weight:500;
flex: 1;
padding: 20px;
height:auto;
display: flex;
flex-direction: column;
justify-content:center; /* 垂直方向の上寄せ */
align-items: flex-start; /* 水平方向の左寄せ */
overflow: hidden; /* テキストがはみ出た場合にはみ出しを隠す */
max-height: 100%; /* 最大高さを親要素に合わせる */
text-align:center;
margin:0 auto;
-ms-writing-mode: tb-rl;
writing-mode: vertical-rl;
}
.text p {
margin: 0; /* デフォルトの段落マージンをリセット */
vertical-align:middle;
text-align: left;
}
.slide img {
max-width: 100%;
height: auto;
}

/* カーソルボタンのスタイル */
.prev, .next {
position: absolute;
top: 50%;
transform: translateY(-50%);
font-size: 20px;
cursor: pointer;
padding: 10px;
background-color: #CCC;
color: white;
border: none;
width:40px;
}

.prev {
left: 10px;
}
.next {
right: 10px;
}


@media (max-width: 768px) {
/* 小湊鉄道スライド */
.access_by_train {
display: block;
width:100%;
max-width:380px;
}
.slide {
flex: 0 0 auto;
display:block;
width:100%;
}
.image {
flex: 1;
}
.text {
flex: 1;
padding: 20px;
height:auto;
display: flex;
flex-direction: column;
justify-content: flex-start; /* 垂直方向の上寄せ */
align-items: flex-start; /* 水平方向の左寄せ */
overflow: hidden; /* テキストがはみ出た場合にはみ出しを隠す */
max-height: 100%; /* 最大高さを親要素に合わせる */
}

}


/*** スライドショー画像 TOP ***/
@keyframes slideShow {
0%, 100% {background-image: url('../img/TK-tei_gaikan_01.jpg');}
12% {background-image: url('../img/TK-tei_Kominka_Gallery_and_Dining_20231029_121732.jpg');}
20% {background-image: url('../img/TK-tei_hanabi_01.jpg');}
30% {background-image: url('../img/TK-tei_BBQ_Party_01.jpg');}
45% {background-image: url('../img/TK-tei_Kominka_Gallery_and_Dining_20231029_124909.jpg');}
60% {background-image: url('../img/line_oa_chat_240717_002725_group_0.jpg');}
75% {background-image: url('../img/TK-tei_dogrun_BBQ_01.jpg');}
}



/************************************************
section service 
*************************************************/

section .box {
max-width:1080px;
margin:0 auto;
position: relative;
} 

section.service h2 {
text-align: left;
align-items: baseline;
}
section#shukuhaku h2:first-child {
margin-top:0;
}
section.service h2 .small {
padding-left:5px;
}

section.service .s_header{
width:100%;
height: 420px;
background-size: cover!important;;
background-position: center center!important;
background-attachment: fixed!important;
margin:0 0 30px 0;
vertical-align: middle;
text-align: center;
}

section#shukuhaku .s_header{
background:url("../img/shukuhaku/20241227_140733.jpg");
}
section#BBQ .s_header{
background:url("../img/bbq/bbq_01.jpg");
}
section#sauna .s_header {
background:url("../img/sauna/09.jpg");
}
section#pizza .s_header {
background:url("../img/line_oa_chat_240717_002725_group_0.jpg");

}
section#dogrun .s_header {
background:url("../img/dogrun/p_dogrun_04.jpg");
}
section#camp .s_header {
background:url("../img/camp/02.jpg");
}
section#food .s_header {
background:url("../img/cafe/lunch_menu.jpg");
}

/** サービス タブ切り替え **/
/* タブコンテナを縦に並べる */
tab-container {
  width: 100%;

}

		


input,label{
margin:0;
}

/* ラジオボタンを隠す */
input[type="radio"] {
display: none;
}

/* タブのラベル部分を横並びにする */
.tab-container .tab-label {
display: inline-block;
padding: 10px 20px;
background-color: #FFF;
border: 1px solid #2c1b1e;
cursor: pointer;
text-align: center;
border-bottom: none;
box-sizing: border-box;
width: 30%; /* 横並び */
flex: 1;
margin:0;
}

.tab-container .tab-label:hover {

transition-duration: 0.3s;
color:#0383D5;
border:1px solid #0383D5;
border-bottom:none;
}

/* タブが選択されているときのスタイル */
input[type="radio"]:checked + .tab-label {
background-color: #2c1b1e;
color: white;
}

/* タブのコンテンツ部分 */
.tab-content {
display: none;
padding: 20px;
border: 1px solid #2c1b1e;
margin:0;
}

/* タブの内容を表示する */
input[type="radio"]:nth-of-type(1):checked ~ .content1,
input[type="radio"]:nth-of-type(2):checked ~ .content2 {
display: block;
}


.area_button{
margin:0 auto 80px auto;
}
.area_button a{
display: block;
padding:15px 30px;
margin:0 auto 30px auto;
color:#FFF;
text-decoration: none;
min-width:240px;
max-width:300px;
text-align: center;
font-size:1.2rem;
background:#FFF;
color:#000;
border:1px solid #333;
letter-spacing: 1px;
}
.area_button a:hover {
color:#0383D5;
border:1px solid #0383D5;
}
a.more_photo{
}
a.b_price{
}








/*********** コンテンツ写真ならび *****************/

/** 3枚画像 左右カラム **/

.right{
}
.left{
}
section .photo_3grid {
display: flex;
align-items: stretch; /* 左右のカラムの高さを揃える */
gap: 16px; /* カラム間および右カラムの画像間のマージンを設定 */
margin:40px 0;
}

section .photo_3grid .left {
flex: 3; /* 左カラムの幅を指定 */
margin-right: 0; /* gapにより調整されるため明示的なマージンは不要 */
display: flex;
}

section .photo_3grid .right {
flex: 2; /* 右カラムの幅を指定 */
display: flex;
flex-direction: column;
gap: 16px; /* 画像間のマージンを設定 */
}

section .photo_3grid .img_wrap {
position: relative;
width: 100%;
height: 100%; /* 高さを親要素に完全にフィット */
}

section .photo_3grid img {
width: 100%;
height: 100%; /* コンテナ全体を埋める */
object-fit: cover; /* コンテナを埋めるようにクロップ */
display: block;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
section .photo_3grid {
flex-direction: column;
}

section .photo_3grid .left, 
section .photo_3grid .right {
width: 100%;
margin-right: 0;
}

section .photo_3grid .img_wrap {
height: auto; /* 小さい画面では高さを自動調整 */
}

section .photo_3grid img {
object-fit: contain; /* 小さい画面ではクロップを解除 */
}
}


/** スクエアクロップ **/
section .photo_sq_crop {
display: flex;
justify-content: center; /* 水平方向にセンターに配置 */
flex-wrap: wrap;
}
section .photo_sq_crop .item {
display: flex;
justify-content: center; /* 水平方向にセンターに配置 */
align-items: center;
margin:0 auto 5%;
}
section .photo_sq_crop .item img{
width: 300px;
height: 300px;
object-fit: cover;
}

section .photo_sq_crop.no02 .item {
margin:0 1% 5%;
}
section .photo_sq_crop.no02 .item img{
width: 500px;
height: 600px;
}


/****************** Highlight ****************************/

/* PC表示 */
section#highlight-section {
display: flex;
flex-direction: column;
gap: 40px;
margin: 0 auto;
}
section#highlight-section h2 {
line-height:1.2 ;
text-align: center;
margin:0 auto!important;
}

.highlight {
display: flex;
width: 100%;
height: 800px;
margin: 0 auto 100px;
text-orientation: upright;
}

.golf-content, .tourist-content {
display: flex;
flex-direction: row;
}

.image-wrapper {
height: 100%;
}

.image-wrapper img {
width: 100%;
height: 100%;
object-fit: cover;
}

.text-wrapper {
padding: 20px;
max-width: 450px;
margin: 0 auto;
display: flex;
justify-content: space-between;
align-items: center;
}

.text-wrapper h2 {
writing-mode: vertical-rl;
font-size: 2rem;
text-align: center;
}

.text-wrapper p {
writing-mode: vertical-rl;
font-size: 1.2rem;
line-height: 1.6;
}

.golf-content .image-wrapper, .tourist-content .image-wrapper {
width: 70vw;
max-width: 2000px;
}

/* モバイル対応 */
@media (max-width: 960px) {
section#highlight-section {
padding-top: 100px;
}

.highlight {
flex-direction: column;
height: auto;
gap: 20px;
margin-bottom: 40px;
}

.golf-content, .tourist-content {
flex-direction: column;
align-items: center;

}
.golf-content .image-wrapper, 
.tourist-content .image-wrapper {
width:100%;
}
.image-wrapper {
order: -1; /* 画像を上に配置 */
height: auto;
}

.image-wrapper img {
width: 100%; /* 横幅100% */
height: auto; /* 高さを画像比率に合わせる */
}

.text-wrapper {
padding: 10px;
height:500px;
max-width: 90%; /* コンテンツを画面幅に収める */
}

.text-wrapper h2,
.text-wrapper p {
writing-mode: vertical-rl; /* 縦書きのまま */
line-height: 1.5;
letter-spacing:0;
}

.text-wrapper h2 {
font-size: 1.3rem;
}
.text-wrapper p {
writing-mode: vertical-rl; /* 縦書きのまま */
font-size: 1.0rem;
height:400px;
}

}




.photo_4grid {
    width: 100%;
    margin: 0 auto;
    max-width: 1200px;
    text-align: center;
}

.vertical_box {
    display: flex;
    align-items: center;
    box-sizing: border-box;
    max-width: 1500px;
    text-align: left;
    margin: 0 0 60px 0;
    width: 100%;
}

.photo_4grid .left {
    width: 50%;
    flex-shrink: 0;
}

.photo_4grid .left img {
    width: 100%;
    height: 300px;
    object-fit: cover;
    aspect-ratio: 16 / 9;
    object-position: center;
}

.photo_4grid .right {
    width: 50%;
    padding: 0 0 0 30px;
    margin: 0;
}

.photo_4grid dl {
    display: block;
}

.photo_4grid .right dt {
    font-family: "Noto Serif JP", serif;
    font-size: 1.6rem;
    font-weight: 600;
    letter-spacing: 5px;
}

.photo_4grid .right dd {
    font-size: 1.2rem;
    padding: 0;
    margin: 0;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
    .vertical_box {
        flex-direction: column;
        width: 70%;
        margin: 0 auto 30px auto;
        text-align: center;
    }

    .photo_4grid .left,
    .photo_4grid .right {
        width: 100%;
    }

    .photo_4grid .left img {
        height: auto;
        width: 80%;
        aspect-ratio: 1 / 1;
        margin: 0 auto;
    }

    .photo_4grid .right {
        padding-left: 0;
        margin-top: 15px;
    }

    .photo_4grid .right dl {
        margin-top: 0;
    }

    .photo_4grid .right dd {
        font-size: 0.8rem;
        text-align: left;
    }

    .photo_4grid .right dt {
        font-size: 1.1rem;
        letter-spacing: 2px;
    }
}

/* レスポンシブ対応 */


@media (max-width: 768px) {
.vertical_box {
display: block!important;
width:70%;
margin:0 auto 30px auto;
text-align: center;
}
.photo_4grid .left img {
    width: 80%;
    aspect-ratio: 1 / 1; /* アスペクト比を1:1に固定 */
	margin:0 auto!important;
}
.photo_4grid .right {
    padding-left:0!important;
    margin: 0;
}
.photo_4grid .right dl {
margin-top:0;
}
.photo_4grid .right dd {
    font-size: 0.8rem;
	text-align: left;
}
.photo_4grid .right dt {
	font-size: 1.1rem;
    letter-spacing: 2px;
}
}




/*********** 宿泊 *****************/

section#shukuhaku {
    padding:0;
}

#shukuhaku .content01 {
overflow:hidden;
margin:80px auto;
}
#shukuhaku h3 {
margin:0 auto 20px auto;
}

#shukuhaku .content01 .left {
float:left;
width:56%;
text-align: left;
}

#shukuhaku .content01 .right {
float:right;
width:40%;
}
#shukuhaku .right h3 {
margin:0;
padding:0;
}


#shukuhaku table th,
#shukuhaku table td{
}





#shukuhaku .left {
max-width:80%;
}
#shukuhaku .left h3 {
max-width:100%;
font-size:1.2rem;
}
#shukuhaku .content01 {
margin: 30px auto!important;
}
#shukuhaku iframe {
text-align: center;
margin:0 auto!important;
}
}




section#shukuhaku .tab-container {
  margin-left: 20px;
  padding: 0 ; /* パディングをゼロに設定 */
}
section#shukuhaku .tab-container .no01{
 text-align: left;
}
section#shukuhaku table {
max-width:1000px;
}
section#shukuhaku table th,
section#shukuhaku table td{
border:none;
}
section#shukuhaku table tr:last-child th,
section#shukuhaku table tr td:last-child td{
border-bottom:none;
}
section#shukuhaku table td{
border-bottom:1px dotted #CCC;
}
section#shukuhaku .tab-container ul {
margin:0 0 60px 10px;
text-align: left;
font-size:1.1rem;
}		

section#shukuhaku .tab-container h3 {
margin:40px auto 40px auto;
font-size:2.2rem;
}
section#shukuhaku .tab-container h4 {
font-size:1.5rem;
margin:60px auto 40px auto;
display: flex;
align-items: center;
max-width:600px;
}
section#shukuhaku .tab-container h4:after {
margin-left: 1rem;
}
section#shukuhaku .tab-container h4:before,
section#shukuhaku .tab-container h4:after {
content: "";
height: 1px;
flex-grow: 1;
background-color: #000;
}
section#shukuhaku .tab-container h4:before {
margin-right: 1rem;
}

section#shukuhaku .tab-container .table_frame {
width:80%;
margin:0 auto;
}
/* テーブルのスタイル調整 */
#shukuhaku table {
width: 100%; /* テーブルの幅を右カラムに合わせる */
border-collapse: collapse; /* ボーダーを重ならないようにする */
margin:0 auto;
justify-content: center;
align-items: center;
}

#shukuhaku th, #shukuhaku td {
border: 1px solid #ddd; /* セルの境界線 */
padding: 8px;
text-align: left; /* 左揃え */
}

#shukuhaku th {
background-color:#F3F0E9; /* ヘッダー背景色 */
font-weight: bold;
}
#shukuhaku table td {
width:80%
}
#shukuhaku .haba {
border-left:1px dotted #CCC;
backgorund:#CCC;
}


@media (max-width: 768px) {
#shukuhaku .content01 .left,
#shukuhaku .content01 .right {
float: none; /* Floatを解除 */
width: 100%; /* 横幅100%に設定 */
}
section#shukuhaku .flex {
flex-direction: column; /* 縦並びに変更 */
}
section#shukuhaku .left, section#shukuhaku .right {
flex: 1 1 100%; /* 幅を100%に */
margin: 0 auto;
}
section#shukuhaku iframe {
max-width: 100%; /* スマホ画面での幅を最大に */
}

.tab-container .tab-label {
font-size:0.8rem;
font-family: "游ゴシック体",YuGothic,"游ゴシック","Yu Gothic","メイリオ",sans-serif!important;
font-weight: bold;
}
.tab-container {
width: 96%;
margin: 0 auto!important;
}

section#shukuhaku .tab-container {
  margin-left: 0;
  margin-top: 20px;
}
section#shukuhaku .tab-container .table_frame {
width:92%;
margin:0 auto;
}

section#shukuhaku .tab-container h3 {
font-size:1.3rem;
}
section#shukuhaku .tab-container h4 {
    font-size: 1.1rem;
}
section#shukuhaku .tab-container ul {
    margin: 0 0 30px 0;
    font-size: 0.9rem;
}


}
/*********** ピザ焼き体験 *****************/



/*********** テントサウナ *****************/



/*********** ドッグラン *****************/



/*********** 食事 *****************/
section#food .no01 .left {
float:left;
width:50%;
}
section#food .no01 .right {
float:right;
width:48%;
vertical-align: middle;
}
section#food .no02 .left {
float:left;
width:48%;
}
section#food .no02 .right {
float:right;
width:50%;
}
section#food .float{
overflow: hidden;
padding-bottom:100px;
border-bottom:1px dashed #CCC;
}

@media (max-width: 768px) {
section#food .float {
padding-bottom:0!important;

}
section#food .left,
section#food .right{
float:none!important;
width:100%!important;
}
section#food img {
width:60%;
}
}


/*********** アクセス *****************/
section#access ul{
margin:0 auto;
max-width:500px;
}
section#access ul li {
text-align: left;
}

/** スポット **/
section#access #spots{
padding:10px;
margin:0 auto;
}
section#access .flex {
justify-content: center;
}
section#access #spots .left,section#access #spots .right {
margin:10px;
text-align: left;
}

section#access #spots h4{
font-size:1.2rem;
background:#DCD9D3;
padding:2px 10px 3px 10px;
margin:40px 0 10px 0;
}
section#access #spots dl{
margin:0 auto;
padding:5px;
}
section#access #spots a {
color:#000;
}



/* FAQ セクション */
section#FAQ .box {
text-align: left;
}

section#FAQ dl {
max-width: 800px;
margin: 30px auto;
background: #fff;
padding: 10px;
border: 1px solid #ddd;
}

section#FAQ dl dt,
section#FAQ dl dd {
position: relative;
cursor: pointer;
}

section#FAQ dl dt {
font-size: 1.5rem;
font-weight: bold;
padding: 8px 50px 8px 15px;
}

section#FAQ dl dd {
padding: 15px 15px 30px 15px;
margin: 0;
display: none;
background-color: #f9f9f9; /* Aの背景を淡いグレーに */
border-radius: 5px;
}

/* 表示状態のスタイル */
section#FAQ dl.active dd {
display: block;
}

section#FAQ dl dt::before {
content: "Q.";
font-weight: bold;
margin-right: 10px;
color: #0778CB;
}

section#FAQ dl dd::before {
content: "A.";
font-weight: bold;
margin-right: 10px;
color: #f00;
}

section#FAQ dl dt::after {
content: "＋";
font-family:"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
font-weight: bold;
position: absolute;
right: 15px;
top: 50%;
transform: translateY(-50%);
color:#0778CB;
}

section#FAQ dl.active dt::after {
content: "ー";
color: #f00;
font-family:"Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";

}




/* mason */
.item {/*各ボックスのスタイル*/
position:relative;
}
.item img{
width: 100%;
max-width: 360px!important;
}
.item span {
padding:3px 5px;
line-height:1.2;
text-align:left;
position:absolute;
bottom:50px;
right:50px;
z-index:999999999;
background:rgba(255,255,255,0.7);
color:#000;
transform: rotate(-8deg);
max-width:70%;
font-family: ta-koigokoro, sans-serif;
font-weight: 400;
font-style: normal;
}



.grid {
display: grid;
gap: 1rem;
padding: 4rem;
grid-template-columns: repeat(3, 1fr);
}
.grid img {
width: auto;  /* 幅は自動調整 */
max-width:400px;
height: 300px; /* すべての画像の高さを200pxに固定 */
object-fit: cover; /* 画像をトリミングせずにフィットさせる */
border-radius:20px;
}


/**** footer ********************/
footer {
background-color:#2c1b1e;
color: #FFF;
text-align: center;
padding: 100px 0;
line-height: 1.7;
}
footer h2,footer h2 .small {
color:#FFF;
}
footer #contact a {
background:#FFF;
color:#000;
padding:2px 15px 5px 15px;
border-radius: 5px;
line-height:2.2;
text-decoration: none;
}
footer #contact a:hover {

}
footer a {
color:#FFF;
}
footer p.copyrights {
width:100%;
font-size:0.98rem;
padding-right:10px;
margin-top:80px;
}
footer.centered{
padding-bottom: 0;
}



/******************************************** news ************************************/
#SUB {
width:90%;
margin:0 auto;
}
#SUB h2 {
line-height: 1.2;
}
#SUB h3 {
margin:0 0 30px 0;
}
#SUB section{
padding-top:20px;
}
#SUB .detailText {

}
#SUB .detailUpfile {
text-align: center;
}




/******************************************** Smartphone  ************************************/

@media (max-width: 768px) {
body {
font-size:1.0rem
}

/* 見出し */
h2 {
font-size: 1.5rem;
font-weight: bold;
line-height:0.8;
margin:20px auto 20px auto;
}
h2 .small {
font-size:0.9rem;
}
section.service h2{
text-align: center;
margin-left:0!important;
letter-spacging:0;
}
h3 {
font-size:1.3rem;
max-width:90%;
margin-top:60px;
margin-bottom:20px;
}

.dsp_pc {
display: none;
}
.dsp_sp{
display: block;
}

/* 予約ボタン */
#b_yoyaku {
}
#b_yoyaku a {
padding:20px;
}
#b_yoyaku .small {
display: none;
}
#b_yoyaku a {
padding:10px 12px 10px 6px;
font-size:1.0rem;
}

#logo {
width:60px;
height:auto;
position:fixed;
top:10px;
left:5px;
z-index: 9999;
}

.social_embed {
width:70%;
margin-top:30px;
}
table {
max-width:94%;
}
th,td {
padding:8px 12px;
font-size:0.8rem;
}
th{

}


.text {
justify-content:center; /* 垂直方向の上寄せ */
align-items: flex-start; /* 水平方向の左寄せ */
overflow: hidden; /* テキストがはみ出た場合にはみ出しを隠す */
max-height: 100%; /* 最大高さを親要素に合わせる */
text-align:center;
margin:0 auto;
-ms-writing-mode:none;
writing-mode: horizontal-tb;
}

section {
padding:4rem 0;
}


    section.service .s_header {
        background-attachment: scroll !important;
        background-size: cover !important;
        background-position: center center !important;

}

section#news p {
text-align: justify;
text-justify: inter-ideograph;
max-width:80%;
margin-left:auto;
margin-right:auto;
text-align: left;
}
section#news .text p {
}



.box {
width:100%!important;
}


/* service */
section {
margint-top:30px;
}
section.service {
padding: 60px 0 0 0;
}


.carousel-container {
position: relative;
overflow: hidden;
width: 90%;
margin: auto;
}

.grid {
grid-template-columns: repeat(1, 1fr);
gap: 0.5rem;
padding: 2rem 3rem 2rem 3rem ;
}
.grid img {
max-width:100%;
height: auto; /* すべての画像の高さを200pxに固定 */
}
section.service .msg {
font-size:1.0rem!important;
}


#status {
margin:20px auto 0 auto;
width:90%;
padding:5px 10px 5px 10px;
}
#status strong {
font-size:1.4rem;
}
#status dt {
font-size:1.5rem;
}

.item img{
width: 100%;
max-width: 100%!important;
}





section#access #spots .left,
section#access #spots .right {
width:90%;
}

section#FAQ .box {
text-align: left;
}
section#FAQ dl {
margin:15px auto;
max-width:90%;
}
section#FAQ dl dt {
font-size:1.0rem;
padding:5px 30px 5px 10px;
line-height:1.4;
}
section#FAQ dl dd {
font-size:0.8rem;
margin:0;
}




}



@media (max-width: 480px) {
.social_embed {
display:none;
}
}