﻿@charset "utf-8";


.copy02 {
  font-size: 14px;
  line-height: 180%;
}
.copy03 {
  font-size: 14px;
  line-height: 180%;
  text-align: left;
}
#contents.sub { padding: 10px 0 160px 0; }

/* =============================== header =============================== */

#mainimg { position: relative; }
#mainimg .base::after {
  background: url(../img/submain_on_sp.png) no-repeat bottom;
  background-size: 100%;
}
#mainimg .base img { width: 100%; }
#mainimg h2 {
  text-align: center;
  background: url(../img/sub_mainline.png) no-repeat center bottom;
  font-size: 16px;
  margin-top: -10px;
  padding-top: 10px;
  padding-bottom: 16px;
}
#mainimg h2 span { text-align: center; }
#mainimg h2 span img { width: 20px; }

/* =============================== bread =============================== */

#bread {
  width: 94%;
  margin: 20px auto 25px;
}
#bread li {
  display: inline-block;
  letter-spacing: normal;
  vertical-align: top;
  margin-right: 10px;
  line-height: 120%;
  font-size: 11px;
  word-break: keep-all;
}
#bread li#home {
  padding-left: 20px;
  background: url(../img/icon_home.png) no-repeat left center;
}
#bread li:last-child { margin-right: 0; }
#bread li a {
  font-size: 11px;
  line-height: 120%;
  background: url(../img/icon_arrow_03.png) no-repeat right center;
  padding-right: 15px;
  color: #38A1C9;
}

/* =============================== common =============================== */

.list01 li {
  width: 100%;
  margin-bottom: 30px;
}
.list01 li:nth-child(2n+1){
  margin-right: 0;
}
.list01 li .ttl {
  font-size: 18px;
  padding: 16px 0 10px;
  margin-bottom: 12px;
}
.list01 li p {
  line-height: 160%;
}

  
.list02 li {
  width: 48%;
  margin-bottom: 25px;
  margin-right: 4%;
}
.list02 li:nth-child(3n){
  margin-right: 4%;
}
.list02 li:nth-child(2n){
  margin-right: 0;
}
.list02 li:nth-last-child(-n+3){
  margin-bottom: 25px;
}
.list02 li .ttl {
  font-size: 16px;
  padding: 15px 0 5px;
}
.list02 li p {
  font-size: 12px;
}

.list03 li {
  margin-bottom: 30px;
  display: block;
  width: 100%;
}
.list03 li > div {  display: block; }
.list03 .photo { width: 100%; padding-right: 0; padding-bottom: 10px; }
.list03 .txt { width: 100%; }


.box01 .f_l ,
.box01 .f_r { float: none; width: 100%; }
  

.tbl01 { }
.tbl01 th ,
.tbl01 td { display: block; width: 100%; box-sizing: border-box; }
.tbl01 th {
  font-size: 15px;
  padding: 3% 4%;
}
.tbl01 td {
  padding: 3% 4%;
}

.tbl02 { }
.tbl02 th ,
.tbl02 td { display: inline-block; }
.tbl02 th {
  font-size: 14px;
  padding: 9px 4%;
  width: 74%;
  box-sizing: border-box;
}
.tbl02 td {
  padding: 9px 4%;
  width: 26%;
  box-sizing: border-box;
}

.tbl03 { }
.tbl03 th ,
.tbl03 td { display: block; box-sizing: border-box; }
.tbl03 th {
  font-size: 14px;
  padding: 9px 4%;
  width: 100%; 
}
.tbl03 td {
  padding: 9px 4%;
  width: 100%; 
}
.tbl03 th .required {
  font-size: 13px;
}

/* =============================== policy =============================== */

#policy .copy02 { margin-bottom: 30px; }
#policy dt {
  font-size: 16px;
}
#policy dd {
  margin-bottom: 30px;
}
#policy dd p ,
#policy dd p strong ,
#policy dd p a ,
#policy dd li {
  line-height: 180%;
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif;
}
#policy dd p strong { font-weight: bold; font-size: 15px; }
#policy dd p a { color: #38A1C9; }
#policy dd ul {
  margin-left: 15px;
}
#policy dd li::before {
  content: "●";
  color: #389FC9;
  font-size: 10px;
  margin-right: 10px;
}

/* =============================== tree =============================== */

#tree .copy03 { margin-bottom: 30px; }

/* =============================== stone =============================== */

#stone .copy03 { margin-bottom: 30px; }

/* =============================== family =============================== */

#family .copy03 { margin-bottom: 30px; }
#family .family_box { }
#family .family_box p {
  text-align: left;
  padding: 20px 1em;
  font-size: 14px;
  line-height: 160%;
  pointer-events: auto;
}
#family .family_box p a {
  font-size: 18px;
}
  

  

/* =============================== news =============================== */

#news_list .inbox { margin-bottom: 35px; }
#news_list .f_l { width: 100%; margin-bottom: 20px; }
#news_list .f_r { width: 100%; }

#news_list .listbox li {
  padding: 1em 0;
}
#news_list .listbox .thumb {
  width: 28%;
}
#news_list .listbox .txt {
  padding: 10px 5% 0 5%;
}

#news_list .listbox .date {
  color: #38A1C9;
  font-size: 12px;
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
}
#news_list .listbox .tag {
  background: #B8A666;
  color: #fff;
  display: inline-block;
  line-height: 1;
  padding: 5px 0;
  width: 80px;
  text-align: center;
  font-size: 11px;
  margin-left: 10px;
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
}
#news_list .listbox p {
  margin-top: 10px;
  font-size: 14px;
  line-height: 160%;
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
}

#news_list .sidebox li {
  border-bottom: 1px solid #38A1C9;
}
#news_list .sidebox li a{
  display: block;
  text-decoration: none;
  padding: 14px 10px;
}



#news_detail .inbox { margin-bottom: 35px; }
#news_detail .f_l { width: 100%; margin-bottom: 20px; }
#news_detail .f_r { width: 100%; }

#news_detail .mainbox .btn01 a ,
#news_detail .mainbox .btn01 a:hover {
  background: #137EAB;
}

#news_detail .sidebox li {
  border-bottom: 1px solid #38A1C9;
}
#news_detail .sidebox li a{
  display: block;
  text-decoration: none;
  padding: 14px 10px;
}



/* calendar */
.linklist {
  width:  100%;
  margin: 30px auto;
  display: flex;
  justify-content: space-between;
}

.linklist a ,
.linklist a:hover {
  width: 8em;
  padding: 10px 0px;
  font-size: 14px;
  background: #137EAB;
  color: #fff;
}
/* =============================== sitemap =============================== */

#sitemap li {
  width: 100%;
}
#sitemap li:nth-child(2n) { margin-right: 0; }
#sitemap li.w100p { width:100%; margin-right: 0;}
#sitemap li a {
  font-size: 15px;
  padding: 12px 10px 12px 30px;
  background: url(../img/icon_arrow_01.png) no-repeat left center;
  background-size: 14px;
}
#sitemap li .no_list {
  padding-left: 22px;
  margin-top: -5px;
  margin-bottom: 10px;
}
#sitemap li .no_list li {
  margin-bottom: 5px;
}
#sitemap li .no_list li a { }


/* =============================== shopping =============================== */

#shopping .copy03 { margin-bottom: 30px; }

/* =============================== location =============================== */

#location .copy03 { margin-bottom: 30px; }
#location .line01 { margin: 40px 0;}

#location .ttl06 { padding-top: 5px; }
#location .box01 { margin-bottom: 40px; }
#location .box01 .f_r { margin-bottom: 25px; }
#location .box01 .photo p { margin-top: 5px; }
#location .box01 .photo img {
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;  
}
#location .box01 .photo.double {
  margin-top: 14px;
}
#location .box01 .photo.double div {
  width: 48%;
}
#location .box01 p {
  font-size: 13px;
}

/* =============================== relaxation =============================== */

#relaxation .box01 { margin-bottom: 50px; }
#relaxation .box01 .f_r { margin-bottom: 25px; }
#relaxation .box01 .photo p { margin-top: 5px; }
#relaxation .box01 .photo img {
  border-radius: 20px;
  -webkit-border-radius: 20px;
  -moz-border-radius: 20px;  
}
#relaxation .box01 .photo.double {
  margin-top: 14px;
}
#relaxation .box01 .photo.double div {
  width: 48%;
}
#relaxation .box01 .f_r > p {
  font-size: 13px;
}
#relaxation .box01 .m_b_30 {
  margin-bottom: 15px;
}

#relaxation .border_box01 {
  padding: 20px 15px;
}
#relaxation .border_box01 p {
  font-size: 15px;
  line-height: 160%;
}
#relaxation .border_box01 p br.sp {
    display: inline-block;
}
#relaxation .border_box01 p small {
  font-size: 14px;
}
#relaxation .border_box01 p span {
  font-size: 15px;
}
#relaxation .btnlist li {
  margin-bottom: 15px;
}

/* =============================== restaurant =============================== */

#restaurant01 { margin-bottom: 50px; }
#restaurant01 .photo {
  margin-bottom: 15px;
}
#restaurant01 .detail {
  display: block;
}
#restaurant01 .closed {
  text-align: left;
}
#restaurant01 .detail .d_box {
  width: 100%;
}
#restaurant01 .detail .d_box h4 {
  padding: 4px 0;
  font-size: 18px;
  margin-bottom: 15px;
}
#restaurant01 .detail .d_box li::before {
  content: "●";
  color: #38A1C9;
  font-size: 10px;
  margin-right: 5px;
  vertical-align: middle;
}
#restaurant01 .detail .d_box li {
  font-size: 16px;
  margin-bottom: 15px;
}
#restaurant01 .detail .d_box li span {  
  display: block;
  margin: 5px 0 0 15px;
}
#restaurant02 .lunch { margin-bottom: 50px; }
#restaurant02 .btn01 { margin-top: 0; }
#restaurant02 .list02 .tag {
  margin-top: 10px;
  display:  inline-block;
  padding: 6px 8px;
  font-size: 12px;
}
#restaurant01 .border_box01 {
  padding: 20px 0;
}
#restaurant01 .border_box01 p {
  font-size: 15px;
  line-height: 160%;
}
#restaurant01 .border_box01 p a {
  pointer-events: auto;
}
#restaurant01 .border_box01 p br.sp {
    display: inline-block;
}
#restaurant01 .border_box01 p small {
  font-size: 14px;
}
#restaurant01 .border_box01 p span {
  font-size: 15px;
}

/* =============================== faq =============================== */

#faq .copy03 { margin-bottom: 30px; }
#faq #pagenav { margin-bottom: 40px; }
#faq #pagenav li {
  width: 48%;
  margin-bottom:4%;
}
#faq #pagenav li:nth-last-of-type(n+2) { margin-right: 4%; }
#faq #pagenav li:nth-child(2n) { margin-right: 0; }
#faq #pagenav li a ,
#faq #pagenav li a:hover {
  font-size: 16px;
  padding: 12px 0;
  background: #137EAB;
  color: #fff;
  transition: 1;
}
#faq dl { margin-bottom: 50px; }
#faq dt{
  padding-top: 30px;
  font-size: 20px;
  margin-bottom: 28px;
}
#faq dt::before {
  content: "Q";
  font-size: 20px;
  color: #fff;
  text-align: center;
  display: inline-block;
  line-height: 1;
  padding: 5px 8px;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  background: #38A1C9;
  border: 2px solid #38A1C9;
  font-weight: normal;
  margin-right: 10px;
}
#faq dd {
  padding: 6px 0 30px 47px;
  border-bottom: 1px solid #9ACCDD;
  position: relative;
}
#faq dd:last-of-type { border-bottom: none; }
#faq dd p {
  font-size: 14px;
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
}
#faq dd p a { color: #137EAB; }
#faq dd::before {
  content: "A";
  font-size: 20px;
  padding: 5px 8px 5px 9px;
  background: #fff;
  border: 2px solid #38A1C9;
  font-weight: normal;
  margin-right: 10px;
  position: absolute;
  top: 0;
  left: 0;
	font-family: 游明朝,"Yu Mincho",YuMincho,serif;
}

#faq .line { margin-bottom: 40px;}

/* =============================== point =============================== */

#point .border_box01 {
  width: 100%;
  margin-bottom: 30px;
  width: calc( 100% - 6px );
  box-sizing: border-box;
}
#point .border_box01 img { width: 80%; }

#point .f_l {
  width: 100%;
  padding-right: 0;
  margin-bottom: 25px;
  float: none;
}
#point .f_l img { width: 60%; }
#point .f_l p { font-size: 18px; margin-top: 5px; }
#point .f_r { width: 100%; float: none; }
#point .f_r li {
  line-height: 160%;
  font-size: 14px;
}
#point .f_r li::before { }
#point .bigger { font-size: 20px; line-height: 155%; }
#point .line { margin: 30px 0 40px; } 

#point .tbl01 li {
  line-height: 180%;
}
#point .tbl01 li::before { }



/* =============================== hot_springs =============================== */

#hot_springs #main .m_b_40 { margin-bottom: 20px; }
#hot_springs #main .copy {
  font-size: 16px;
  margin-bottom: 20px;
}
#hot_springs #main .onimg {
  position: absolute;
  width: 12.2%;
  bottom: -24%;
  left: inherit;
  right: 3%;
}
#hot_springs #main p {
  width: 100%;
  line-height: 160%;
  font-size: 13px;
}

#hot_springs #natural .copy { margin-bottom: 30px; }
#hot_springs #natural li { width: 100%; }
#hot_springs #natural li:nth-last-of-type(n+2) { margin-right: 0; margin-bottom: 20px; }
#hot_springs #natural .photo {
  margin: 0 auto 25px;
  width: 69%;
}
#hot_springs #natural .onimg {
  bottom: -14px;
  width: 25%;
}
#hot_springs #natural li h3 {
  font-size: 18px;
  letter-spacing: .1em;
  margin-bottom: 5px;
}
#hot_springs #natural li h3 strong {
  font-size: 26px;
}
#hot_springs #natural li p { text-align: left; }


#hot_springs .line_01 { margin: 20px 0 30px; } 
#hot_springs .line_02 { margin: 30px 0 40px; } 

#hot_springs .tbl01 li {
  line-height: 180%;
}
#hot_springs .tbl01 li::before { }

/* =============================== facility =============================== */


#facility .list03 { margin-bottom: 60px; }
#facility .list03 .ttl06 {
  padding-left: 36px;
  position: relative;
  margin-bottom: 15px;
}
#facility .list03 .ttl06.no_pl {
  padding-left: 0;
}
#facility .list03 .num {;
  top: 9px;
}
#facility .list03 p {
  line-height: 170%;
  margin-bottom: 20px;
}
#facility .list03 .btn01 a {
  margin: 0 auto;
}

#facility .ttl07.m_b_50 { margin-bottom: 25px; }
#facility .about li {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  padding: 10px 4%;
  margin-right: 0;
  margin-bottom: 30px;
  vertical-align: top;
}
#facility .about li:nth-child(3n) { margin-right: 0; }
#facility .about li:nth-last-of-type(n+2) {
  background: url(../../img/facility/bg_01.png) no-repeat center top -30px #E1F1F7;
  background-size: 100%;
}
#facility .about li p ,
#facility .about li small {
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
  text-align: left;
  line-height: 150%;
}
#facility .about li p { height: auto !important; }
#facility .about li small { font-size: 12px; }

#facility .about li:nth-child(1)::after ,
#facility .about li:nth-child(2)::after ,
#facility .about li:nth-child(3)::after ,
#facility .about li:nth-child(4)::after {
  display: block;
  width: 10px;
  height: 18px;
  content: "▼";
  color: #38A1C9;
  background: none;
	position:absolute;
	top: inherit;
	-webkit-transform: translate(0, 0);
	transform: translate(0, 0);
  right: 0; left: 0;
  margin: auto;
  bottom: -30px;
}

#facility .about .num {
  display: inline-block;
  font-size: 20px;
  text-align: center;
  width:  20px;
  color: #fff;
  line-height: 1;
  padding: 5px 5px 4px;
  border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  background: #38A1C9;
  margin-right: 5px;
  vertical-align: middle;
  margin: 0 auto;
}
#facility .about li .ttl {
  font-size: 16px;
  padding: 12px 0 25px;
}
#facility .about li:nth-child(6) {
  padding: 10px;
}
#facility .about li:nth-child(6) h5 {
  font-size: 20px;
  padding: 15px 0 5px;
  margin-bottom: 10px;
  border-bottom: 1px solid #38A1C9;
  text-align: left;
}
#facility .about li:nth-child(6) p {
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 8px;
}
#facility .about li:nth-child(6) p::before {
  content: "■";
  color: #38A0C9;
  font-size: 10px;
  margin-right: 4px;
}


#facility #f_time {
  padding: 0 0 45px;
}
#facility #f_time p {
  font-size: 28px;
}
#facility #f_time p span {
  font-size: 16px;
}

#facility .tbl01 small ,
#facility .tbl01 span ,
#facility .tbl01 p {
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
}
#facility .tbl01 small { color: #137EAB; font-size: 14px; }
#facility .tbl01 td p {
  text-indent: -1em;
  padding-left: 1em;
}
#facility .tbl01.m_b_60 ,
#facility .tbl02.m_b_60 { margin-bottom: 30px; }


/* =============================== contact =============================== */

#contact .copy03 { margin-bottom: 30px; }
#contact #contact_tel { margin-bottom: 50px; }
#contact #contact_tel .border_box01 { padding: 25px 0 20px; }
#contact #contact_tel .border_box01 p {
  pointer-events: auto;
}
#contact #contact_tel .border_box01 p a {
  font-size: 28px;
}
#contact #contact_tel .border_box01 p a small {
  font-size: 16px;
}
#contact #contact_tel .border_box01 p span {
  font-size: 14px;
  display: block;
  margin-left: 0px;
  margin-top: 10px;
  vertical-align: text-bottom;
}


#contact #contact_mail .policy {
  width: 94%;
  padding: 3%;
  height: 220px;
}
#contact #contact_mail .policy p ,
#contact #contact_mail .policy p strong ,
#contact #contact_mail .policy dt ,
#contact #contact_mail .policy dd ,
#contact #contact_mail .policy li {
  font-size: 13px;
}
#contact #contact_mail .agree { margin: 15px 0 50px; }
#contact #contact_mail .agree label span {
  font-family: 游ゴシック,"Yu Gothic",YuGothic,sans-serif; 
  font-size: 16px;
}

.btn_submit input ,
.mw_wp_form_input .btn input ,
.mw_wp_form_confirm .btn input ,
#backbtn input ,
.btn_submit input:hover ,
.mw_wp_form_input .btn input:hover ,
.mw_wp_form_confirm .btn input:hover {
  display: block;
  width: 88%;
  margin: 0 auto;
  padding: 15px 0;
  font-size: 16px;
  color: #fff;
  background: url(../img/icon_arrow_01w.png) no-repeat right 6% center #137EAB;
  background-size: 5%;
}
#backbtn input ,
#backbtn input:hover {
  width: 88%;
  color: #fff;
  margin-bottom: 15px;
  background: url(../img/icon_arrow_06w.png) no-repeat left 6% center #666;
  background-size: 5%;
}

.w_s { width: 30%; }
.w_l { width: 90%; }
textarea.w_l { width: 96%; }




