@charset "utf-8";

/* ==========================================================================
	default archeture
   ========================================================================== */
html,
button,
input,
select,
textarea {
	color: #222;
}

html {
	font-size: 62.5%;
}

body {
	font-size: 12px;
	font-size: 1.2rem;
	font-family: "Lucida Grande", "Lucida Sans Unicode", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Helvetica, Arial, Verdana, sans-serif;
	line-height: 160%;
	color: #333;
}

ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	padding: 0;
	font-weight: normal;
}

table {
	border-collapse: collapse;
}

.btns a {
	filter: alpha(opacity=100);
	-moz-opacity: 1.00;
	opacity: 1.00;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	display: block;
	color: #fff;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */
::-moz-selection {
	background: #b3d4fc;
	text-shadow: none;
}

::selection {
	background: #b3d4fc;
	text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */
audio,
canvas,
img,
video {
	vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */
fieldset {
	border: 0;
	margin: 0;
	padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */
textarea {
	resize: vertical;
}

/* ==========================================================================
   Browse Happy prompt
   ========================================================================== */
.browsehappy {
	margin: 0.2em 0;
	background: #ccc;
	color: #000;
	padding: 0.2em 0;
}

/* ==========================================================================
   Helper classes
   ========================================================================== */
/*
 * Image replacement
 */
.ir {
	background-color: transparent;
	border: 0;
	overflow: hidden;
	/* IE 6/7 fallback */
	*text-indent: -9999px;
}

.ir:before {
	content: "";
	display: block;
	width: 0;
	height: 150%;
}

/*
 * Hide from both screenreaders and browsers: h5bp.com/u
 */
.hidden {
	display: none !important;
	visibility: hidden;
}

/*
 * Hide only visually, but have it available for screenreaders: h5bp.com/v
 */
.visuallyhidden {
	border: 0;
	clip: rect(0 0 0 0);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
	width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element to be focusable
 * when navigated to via the keyboard: h5bp.com/p
 */
.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
	clip: auto;
	height: auto;
	margin: 0;
	overflow: visible;
	position: static;
	width: auto;
}

/*
 * Hide visually and from screenreaders, but maintain layout
 */
.invisible {
	visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */
.clearfix:before,
.clearfix:after {
	content: " ";
	/* 1 */
	display: table;
	/* 2 */
}

.clearfix:after {
	clear: both;
}

/*
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.clearfix {
	*zoom: 1;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */
@media only screen and (min-width: 35em) {
	/* Style adjustments for viewports that meet the condition */
}

@media print,
(-o-min-device-pixel-ratio: 5 / 4),
(-webkit-min-device-pixel-ratio: 1.25),
(min-resolution: 120dpi) {
	/* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid required HTTP connection: h5bp.com/r
   ========================================================================== */
@media print {
	* {
		background: transparent !important;
		color: #000 !important;
		/* Black prints faster: h5bp.com/s */
		box-shadow: none !important;
		text-shadow: none !important;
	}

	a,
	a:visited {
		text-decoration: underline;
	}

	a[href]:after {
		content: " (" attr(href) ")";
	}

	abbr[title]:after {
		content: " (" attr(title) ")";
	}

	/*
   * Don't show links for images, or javascript/internal links
   */
	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content: "";
	}

	pre,
	blockquote {
		border: 1px solid #999;
		page-break-inside: avoid;
	}

	thead {
		display: table-header-group;
		/* h5bp.com/t */
	}

	tr,
	img {
		page-break-inside: avoid;
	}

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

	@page {
		margin: 0.5cm;
	}

	p,
	h2,
	h3 {
		orphans: 3;
		widows: 3;
	}

	h2,
	h3 {
		page-break-after: avoid;
	}
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */
.hide {
	display: none;
}

.spimg {
	display: block;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	background-repeat: no-repeat;
}

img.flex {
	width: 100%;
}

p {
	margin: 0;
}

dd {
	margin: 0;
	padding: 0;
}

#main .title {
	text-align: center;
	background: #313131;
}

#main .inner {
	margin: 6%;
}

#main p.img {
	margin: 1rem 0;
}

/* ==========================================================================
   	top
   ========================================================================== */
.top .news {
	padding: 6%;
}

.top .news li {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	margin: 0.4em 0;
}

.top .news a {
	color: #333;
}

/* ==========================================================================
   	greeting
   ========================================================================== */
.greeting #main .title {
	background: #f6f6f6;
}

/* ==========================================================================
   	about
   ========================================================================== */
/* ==========================================================================
   	cuisine
   ========================================================================== */
.cuisine #main h4 {
	margin: 2rem 0 1rem 0;
	font-weight: bold;
}

.cuisine #main .inner a {
	color: #333;
}

/* タブ　画像切り替え*/
.cuisine #rotation {
	width: 100%;
	margin: 50px auto;
}

.cuisine #rotation .horizontal {
	width: 90%;
	max-width: 600px;
	font-size: 30px;
	margin: 20px auto;
	display: flex;
	align-items: center;
	justify-content: center;
	align-items: stretch;
}

.cuisine #rotation .horizontal li {
	width: 25%;
	padding: 25px 0;
	text-decoration: none;
	border-right: 1px solid #bfbfbf;
	box-sizing: border-box;
}

.cuisine #rotation .horizontal li:first-child {
	border-left: 1px solid #bfbfbf;
}

.cuisine #rotation .horizontal li a {
	color: #000000;
	display: block;
	text-decoration: none;
	margin: 0 auto;
	text-align: center;
}

.cuisine #rotation .horizontal span {
	font-size: 15px;
}

.cuisine #rotation .active {
	border-bottom: 8px solid #000000;
}

.cuisine #tab-1 img,
.cuisine #tab-2 img,
.cuisine #tab-3 img,
.cuisine #tab-4 img {
	width: 100%;
	text-align: center;
	animation: fadeIn 5s ease-out 0s 1 normal;
	-webkit-animation: fadeIn 5s ease-out 0s 1 normal;
}

.cuisine p.btn{
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

@keyframes fadeIn {
	0% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@-webkit-keyframes fadeIn {
	0% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}


/* ==========================================================================
   	hot-spring
   ========================================================================== */
.hot-spring #main h3 {
	font-weight: bold;
	text-align: center;
	font-size: 140%;
	line-height: 180%;
	padding: 0.6em 0;
}

.hot-spring #main .notes {
	margin: 1em 0;
	font-size: 85%;
}

/* ==========================================================================
   	guestroom
   ========================================================================== */
.guestroom #main {
	background: #f6f6f6;
}

.guestroom #main .rooms ul {
	width: 280px;
	margin: 0 auto;
}

.guestroom #main .rooms li {
	float: left;
	margin-bottom: 10px;
}

.guestroom #main .rooms li img {
	width: 137px;
	height: 150px;
}

.guestroom #main .rooms li:nth-child(odd) {
	margin-right: 5px;
}

.guestroom #main p.img {
	margin: 0;
}

.guestroom h3.room-name {
	background-color: #ffffff;
	text-align: center;
}

.guestroom h4 {
	text-align: center;
	margin-bottom: 10px;
	font-size: 120%;
}

.guestroom .room-type {
	padding: 1em 0;
}

.guestroom .room-type dd {
	float: right;
}

/* ==========================================================================
   	spa
   ========================================================================== */
.spa .tab {
	background-color: #f6f6f6;
	text-align: center;
}

.spa .tab ul {
	padding-top: 10px;
	height: 60px;
}

.spa .tab li {
	display: inline-block;
}

.spa .tab .spimg {
	width: 75px;
	height: 60px;
	background-size: 100% auto;
}

.spa .tab .aroma .spimg {
	background-image: url("../img/spa/tab_aroma.png");
}

.spa .tab .aayurveda .spimg {
	background-image: url("../img/spa/tab_aayurveda.png");
}

.spa .tab .oil .spimg {
	background-image: url("../img/spa/tab_oil.png");
}

.spa .tab .massage .spimg {
	background-image: url("../img/spa/tab_massage.png");
}

.spa .tab .active .spimg {
	background-position: left bottom;
	background-color: #fff;
}

.spa .colors {
	font-weight: bold;
}

.spa.aayurveda #main .colors,
.spa.aayurveda #main h4 {
	color: #a40035;
}

.spa.massage #main .colors {
	color: #638c0b;
}

.spa #main .attn {
	margin-top: 20px;
}

.spa.massage #main section li {
	border-bottom: 1px solid #ccc;
}

.spa.massage #main section li:first-child {
	border-top: 1px solid #ccc;
}

.spa.massage #main section li dt {
	padding: 1em 0;
}

.spa.massage #main .notes {
	margin: 1em 0;
	font-size: 90%;
}

.spa.oil #main .inner {
	margin-top: 0;
}

.spa.oil #main .colors {
	color: #a40035;
}

.spa.oil #main .notes li {
	list-style: disc;
}

.spa.oil #main .notes ul {
	margin-left: 1.4em;
}

.spa.oil #main h4 {
	color: #333;
	font-weight: normal;
}

.spa.oil #main section {
	padding: 1em 0 0 0;
}

.spa.oil #main section ul {
	display: flex;
	justify-content: space-around;
	align-items: stretch;
}

.spa.oil #main section ul li {
	width: 31%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.spa.oil #main section ul li p {
	font-weight: 600;
	text-align: center;
	line-height: 1.2;
	padding: 0;
	margin-bottom: 0;
	font-size: 7px;
}

.spa.oil #main section ul li p.pack_title {
	font-size: 12px;
	margin-bottom: 5px;
}

.spa.oil #main section ul li p.last {
	text-align: left;
	font-size: 10px;
	margin: auto;
}

.spa.oil #main section ul li img {
	width: 100%;
	margin: 8px auto;
}

.spa.oil #main .caution {
	padding: 1em 0 0 1em;
	margin: 50px auto 30px;
}

.spa.oil #main p.pink {
	color: #a40035;
	font-weight: normal;
}

.spa.oil #main p.tag01 {
	color: #fff;
	background: #a4005b;
	display: inline-block;
	padding: 3px 10px;
	font-size: 10px;
	margin-bottom: 10px;
}

.spa.aroma #main .colors {
	color: #00736d;
}

.spa.aroma #main section {
	padding-top: 1em;
}

.spa.aroma #main .head p {
	font-size: 12px;
}

.spa.aroma #main .head ul li {
	font-weight: normal;
}

.spa #main h4 {
	color: #00736d;
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 120%;
	font-weight: bold;
}

.spa #main h4 small {
	font-weight: normal;
}

.spa #main p {
	margin-bottom: 2em;
}

.spa #main p.tax {
	margin: 1em 0 0.5em 0;
	font-size: 100% !important;
}

.spa #main dl dt {
	font-weight: bold;
}

.spa #main dl dd {
	margin-bottom: 2em;
	font-size: 90%;
}

.spa #main h5 {
	font-size: 1em;
	font-weight: bold;
}



/* ==========================================================================
   	access
   ========================================================================== */
.access body {
	background-color: #f6f6f6;
}

.access #main {
	padding-bottom: 50px;
}

.access #main .address {
	text-align: center;
}

.access #main .gmap {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
	max-width: 100%;
	height: auto;
}

.access #main .gmap iframe,
.access #main .gmap object,
.access #main .gmap embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.access #main .gmap iframe {
	width: 100% !important;
}

.access #main .start-point {
	text-align: center;
	padding: 1em 0 2em 0;
	font-size: 140%;
}

.access #main .case {
	padding: 10px;
	background-color: #fff;
	margin-bottom: 20px;
}

.access #main .case h4 {
	font-size: 140%;
	font-weight: bold;
	margin-bottom: 1em;
}

.access #main .case h4 .colors {
	color: #e22e47;
}

.access #main .case .root {
	line-height: 160%;
}

.access #main .case .root .colors {
	color: #b7406d;
}

/* ==========================================================================
   	contact
   ========================================================================== */
.contact #main .contact {
	padding-bottom: 50px;
}

.contact #main .contact h3 {
	text-align: center;
}

.contact #main .tel-front {
	margin-bottom: 80px;
}

.contact #main .tel-front dt {
	padding: 1em 0;
	font-size: 120%;
	text-align: center;
}

.contact #main .tel-front dd {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	text-align: center;
	font-size: 40px;
	line-height: 40px;
}

.contact #main .tel-front dd a {
	color: #333;
}


footer #ext-link {
	text-align: center;
	margin: 2em 0 1em;
}






/* 2019.02.22 追加*/

.spa #main .oil_sp {
	padding: 30px 0;
	text-align: center;
	background: #f6f6f6;
}

.spa #main .oil_sp p {
	width: 90%;
	margin-left: auto;
	margin-right: auto;
}

.spa #main .oil_sp p.emphasis {
	width: 70%;
	margin: 0 auto 30px;
}

.spa #main .oil_sp p.emphasis img {
	width: 100%;
}

.spa #main .oil_sp p.telnam a {
	font-size: 26px;
	text-decoration: none;
	color: #000;
}

.spa #main .oil_sp p:last-child {
	margin-bottom: 0;
}


/* 2019.03.18 追加*/
.spa h4 span.greentag {
	font-size: 10px;
	color: #fff;
	background: #00736d;
	padding: 2px 5px;
}

.spa.aroma #main .head p.bold {
	font-weight: bold;
	font-size: 12px;
}

.spa.aroma #main dd p.bold {
	font-weight: bold;
	margin: 2px auto;
}

/* 2019.04.08 追加*/
.spa.aroma #main p.bold {
	font-weight: bold;
	margin: 2px auto;
	font-size: 11px;
}

/*2019.04.25 追加*/
.spa.aroma #main dd p.bold {
	font-weight: bold;
	margin: 7px auto;
}

/*2020.04.09 追加*/

.corona #main h2 {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	text-align: center;
	font-size: 180%;
	margin-top: 1em;
	line-height: 1.5;
}

.corona #main h4 {
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	text-align: center;
	font-size: 130%;
	line-height: 1.5;
}

.corona #main h3 {
	font-weight: bold;
	text-align: center;
	font-size: 140%;
	line-height: 180%;
	padding: 0.6em 0;
}

.corona #main ul {
	list-style: circle;
	padding-left: 1.4em;
	margin-top: 1em;
	margin-bottom: 1em;
}

.corona #main ul li {
	padding-bottom: 10px;
}

.corona #main ul.sub {
	list-style: square;
	padding-left: 3em;
	margin-top: -1em;
}


/* リニューアルバルーン ----------------------------------------- 2024年2月2日*/
.guestroom #main .rooms ul {
	display: flex;
	align-items: stretch;
	flex-wrap: wrap;
}

.guestroom #main .rooms li {
	float: none;
	width: 50%;
}

.guestroom #main .rooms li.is-balloon-renewal {
	width: 50%;
}

.guestroom #main .rooms li:nth-child(2n+1) {
	margin-right: 5px;
	width: calc(50% - 5px);
}

.guestroom #main .rooms li a {
	position: relative;
	display: block;
	color: #000;
	text-decoration: none;
}

.guestroom #main .rooms li a img {
	display: block;
	width: 100%;
}

.guestroom #main .rooms .balloon-renewal {
	position: relative;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	/* width: calc(100% + 1px); */
	width: 100%;
	height: auto;
	background-color: #ce065b;
	z-index: 100;
	color: #fff;
	font-size: 11px;
	text-align: center;
	padding: 12px 3px;
	margin-top: 14px;
	font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Helvetica, Arial, Verdana, sans-serif;
	/* font-feature-settings: "palt"; */

}

.guestroom #main .rooms .balloon-renewal>span {
	letter-spacing: -0.1em;
}

/* 三角 */
.guestroom #main .rooms .balloon-renewal::before {
	content: "";
	position: absolute;
	display: block;
	top: -12px;
	width: 0;
	height: 0;
	border-style: solid;
	border-right: 5px solid transparent;
	border-left: 5px solid transparent;
	border-bottom: 12px solid #ce065b;
	border-top: 0;
}