@charset "utf-8";

/*---------------------------------------------
	初期化
  ---------------------------------------------*/
 html {
	overflow-y: scroll;
}
* { margin: 0; padding: 0; }
*,
*::before,
*::after {
	box-sizing: border-box;
}
h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: normal; }
ul { list-style: none; }
table { border-collapse: collapse; border-spacing: 0; }
form label { cursor: pointer; }
a img { border: none; }
img { vertical-align: bottom; -ms-interpolation-mode: bicubic; }
th { font-weight: normal; }


/*---------------------------------------------
	body
  ---------------------------------------------*/

body {
	background-color: #17150D;
	color: #eeeeee;
	line-height: 1.9;
	text-align: left;
	-webkit-text-size-adjust: none;
	overflow-x:hidden;
	animation: fadeIn 4.0s ease 0s 1 normal;
	-webkit-animation: fadeIn 4.0s ease 0s 1 normal;
}
@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

/*---------------------------------------------
	Text
  ---------------------------------------------*/

html {
	font-family: "Hiragino Maru Gothic W4 JIS2004", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic","ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-weight: 500;
	font-size: 10px;
	letter-spacing: 0.1em;
	-webkit-font-feature-settings: "palt" 1;
	font-feature-settings: "palt" 1;
}
@media all and (-ms-high-contrast:none) {
    html { font-family: 'メイリオ', 'Meiryo', sans-serif; }
}
body { font-size: 16px; font-size: 1.6rem; }
h2 { font-size: 36px; font-size: 3.6rem; }
h3 { font-size: 26px; font-size: 2.6rem; }
h4 { font-size: 20px; font-size: 2.0rem; }
p { font-size: 16px; font-size: 1.6rem; }

h2, h3, h4 {
	font-family: "I-OTF楷書E";
	font-weight: 400;
	font-style: normal;
	color: #EF6C16;
	letter-spacing: 0.1em;
	text-align: center;
	line-height: 1.6;
}
h2 { margin: 60px 0 30px; }
h3 { margin: 50px 0 20px; }
h4 { margin: 20px 0 15px; }
p { margin-top: 1em; }
i.fa { margin: 0 0.3em 0 0.6em; }
h2 .fa { margin-left:0; }
h2.top { margin-top:0; }

.text11 { font-size: 11px; font-size: 1.1rem; }
.text12 { font-size: 12px; font-size: 1.2rem; }
.text13 { font-size: 13px; font-size: 1.3rem; }
.text14 { font-size: 14px; font-size: 1.4rem; }
.text15 { font-size: 15px; font-size: 1.5rem; }
.text16 { font-size: 16px; font-size: 1.6rem; }
.text18 { font-size: 18px; font-size: 1.8rem; }
.text20 { font-size: 20px; font-size: 2.0rem; }
.text24 { font-size: 24px; font-size: 2.4rem; font-family: "I-OTF楷書E"; }

@media screen and (max-width: 768px) {
	html { font-size: 10px;} /* = 10px */
	body { font-size: 1.6rem; } /* = 16px */
	h2 { font-size: 3.0rem; }
	h3 { font-size: 2.1rem; }
	h4 { font-size: 1.7rem; }
	.text20 { font-size: 1.8rem; }
	p { font-size: 1.6rem; }
}


/*---------------------------------------------
	Table
  ---------------------------------------------*/
table {
	width:100%;
    border-collapse: collapse;
    border-spacing: 0;
	font-size:inherit;
}

/*---------------------------------------------
	Anchor
  ---------------------------------------------*/

a { outline: none; }
a:link, a:visited { text-decoration: none; color: #eeeeee; font-weight: 600; }
a:hover, a:active { text-decoration: underline; color: #EF6C16; }

a img:hover {
	filter: alpha(opacity=75);
	-moz-opacity:0.75;
	opacity:0.75;
}
h2 a:link, h2 a:visited { text-decoration: none; color: #EF6C16; }


/*---------------------------------------------
	全体設定
  ---------------------------------------------*/
img { max-width: 100%; height: auto; width: auto\9; /* ie8 */ }
.text-center { text-align: center; }
.zero-top {	margin-top: 0; padding-top: 0; }
.zero-bottom {	margin-bottom: 0; padding-bottom: 0; }
.round { border-radius: 8px; }
.circle { border-radius: 50%; }
.center { text-align:center; }
.left { text-align:left; }
.right { text-align:right; }
.space10 { margin-bottom: 10px; }
.space15 { margin-bottom: 15px; }
.space20 { margin-bottom: 20px; }
.space30 { margin-bottom: 30px; }
.space40 { margin-bottom: 40px; }
.space50 { margin-bottom: 50px; }
.underline-dot { border-bottom: 1px dotted #999999; margin-bottom: 30px; padding-bottom: 30px; }
.float-right { float: right; position: relative; }
.float-left { float: left; position: relative; }
.caution { color:#c00; }
.copy-guard { pointer-events: none; }
i.fa { margin: 0 0.3em 0 0.6em; }
.read span { display:inline-block }
iframe { width: 100%; }
.img-right { float: right; position: relative; margin-bottom: 20px; margin-left: 30px; margin-top: 8px; }
.img-left { float: left; position: relative; margin-bottom: 20px; margin-right: 30px; margin-top: 8px; }
.img-right.w120, .img-left.w120 { width: 120px; }
.img-right.w140, .img-left.w140 { width: 140px; }
.img-right.w180, .img-left.w180 { width: 180px; }
.img-right.w210, .img-left.w210 { width: 210px; }
.img-right.w240, .img-left.w240 { width: 240px; }
@media (max-width: 768px) {
	.img-right { margin-left: 20px; margin-top: 1em; }
	.img-right.w240 { width: 160px; }
	.img-right.w210 { width: 160px; }
}

/* ------ float clear ------ */
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix { min-height: 1px; }
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}
.clear { clear: both; }


/*---------------------------------------------
	スライダー
  ---------------------------------------------*/
header .swiper-container {
	width: 100%;
	height: 100vh;
}
header .swiper-slide img {
	width: 100%;
	height: 100vh;
	object-fit: cover;
	font-family: 'object-fit: cover;';
}
header .swiper-container .logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	margin: auto;
	color: #fff;
	z-index: 1001;
}
header .swiper-container .logo img {
	width: 320px;
}
header .scroll {
	position: absolute;
	bottom: 0;
	margin-bottom: 10px;
	color: #fff;
	z-index: 1001;
	font-size: 250%;
	width: 100%;
	text-align: center;
}


/*---------------------------------------------
	コンテンツ
  ---------------------------------------------*/
#contents-container { max-width: 100%; margin: 0 auto 40px; padding: 0; }
.contents { max-width: 960px; margin: 0 auto; padding: 30px 0 20px; }
.contents.w800 { max-width: 800px; }
@media (max-width: 1000px) {
	.contents, .contents.w800 { padding: 10px 20px 25px; }
}
.contents.tour h3 {
	text-align: left;
}

/* ------ コンテンツページヘッダ ------ */
.header-photo img { width: 100%; height: 320px; object-fit: cover; font-family: 'object-fit: cover;'; }
@media (max-width: 979px) {
	.header-photo img { height: 240px; }
}


/* ------ ブログフィード ------ */
#feed { margin: 30px 0 0; }
#feed.list-line li {
	padding-bottom:10px;
	border-bottom: 1px dotted #727171;
	margin-bottom:10px;
}
#feed.list-line li:last-child { border-bottom:none; }

/* ------ ティッカー ------ */
.item-ticker { width: 100vw; position: relative; left: 50%; transform: translateX(-50%); margin: 70px 0 90px; }
.ticker li img.ofi,
.ticker-left li img.ofi {
	height: 200px; width: 300px;
	box-sizing: border-box;
    object-fit: cover;
	object-position: center;
	font-family: 'object-fit: cover; object-position: bottom;';
}
@media (max-width: 767px) {
	.ticker li img.ofi,
	.ticker-left li img.ofi { height: 120px; width: 180px; }
}

/* ------ コラム ------ */
	.column {
		flex-wrap: wrap;
		display: -webkit-box; /* Android 2~4 */
		display: -webkit-flex; /* Safari */
		display: flex;
		margin-left: -25px;
	}
	.column img { width:100%;}
	.column section {
		-webkit-box-flex: 1;
		-webkit-flex: 1;
		flex: 1;
		margin-left: 30px;
	}
	.column section { margin-top:10px; }

@media (max-width: 768px) {
	.column section { margin-bottom:20px; }
}
@media (max-width: 520px) {
	.column section { flex: 100%; }
	.column.reverse section:nth-child(1) { order: 2; }
	.column.reverse section:nth-child(2) { order: 1; }
}

/* ------ アイキャッチ ------ */
.eyecatch { width: 300px; margin: 90px auto;}
.eyecatch-h { max-width: 400px; margin: 40px auto; }
.eyecatch-h.large { max-width: 600px; }
@media (max-width: 768px) {
	.eyecatch { width: 260px; margin: 60px auto;}
	.eyecatch-h.large { max-width: 480px; }
}

p.logo-w {
	width: 160px;
	margin: 30px auto 40px;
}
p.logo-orange {
	width: 280px;
	margin: 50px auto 80px;
}
p.logo-inasato {
	width: 220px;
	margin: 40px auto 60px;
}
@media (max-width: 768px) {
	p.logo-inasato { width: 180px; }
}

/* ------ 縦書き ------ */
.vertical-wrap {
	text-align: center;
}

.vertical {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	line-height: 3;
	display: inline-block;
	text-align: left;
}
.vertical p {
	font-family: "I-OTF楷書E";
	font-weight: 400;
	font-size: 20px; font-size: 2.0rem;
	letter-spacing: -0.1em;
}
@media screen and (max-width: 640px) {
	.vertical { line-height: 1.8; }
	.vertical p { font-family: initial; font-size: 16px; font-size: 1.6rem; letter-spacing: 0.1em; }
}

/* ------ 三原色 ------ */
.color h5 {
	text-align: center;
	padding: 6px;
}
.color .blue h5 {
	background-color: #44617b;
}
.color .red h5 {
	background-color: #cd5e3c;
}
.color .yellow h5 {
	background-color: #ffdb4f;
	color: #302833;
}

/* ------ アコーディオン ------ */
.button {
	cursor: pointer;
	padding: 10px 15px;
	background-color: #455765;
	border-radius: 4px;
	margin-top: 40px;
	color: #eeeeee;
}
.button h4 {
	margin-bottom: 0;
	color: #eeeeee;
}

/* ------ チェックマーク ------ */
/*
ul.list-check li {
	background-image: url(../image/check.png);
	background-repeat: no-repeat;
	background-position: left top 6px;
	background-size: 20px auto;
	padding-left: 35px;
	margin-bottom: 1em;
	font-size: 18px; font-size: 1.8rem;
}
@media screen and (max-width: 640px) {
	ul.list-check li {
		background-position: left top 6px;
		background-size: 16px auto;
		padding-left: 25px;
		font-size: 16px; font-size: 1.6rem;
	}
}
*/

/* ------ 二重丸 ------ */
ul.list-check li {
	background-image: url(../image/icon-circle.png);
	background-repeat: no-repeat;
	background-position: left top 8px;
	background-size: 18px auto;
	padding-left: 32px;
	margin-bottom: 1em;
	font-size: 18px; font-size: 1.8rem;
}
@media screen and (max-width: 768px) {
	ul.list-check li {
		background-position: left top 6px;
		background-size: 16px auto;
		padding-left: 25px;
		font-size: 16px; font-size: 1.6rem;
	}
}
ul.list-check.small {
	margin-top: 20px;
}
ul.list-check.small li {
	background-position: left top 6px;
	background-size: 12px auto;
	padding-left: 20px;
	margin-bottom: 0.5em;
	font-size: 14px; font-size: 1.4rem;
}
@media screen and (max-width: 640px) {
	ul.list-check.small li {
		background-position: left top 6px;
		background-size: 16px auto;
		padding-left: 25px;
	}
}


/* トップページ商品一覧 */
.topitem  {
	-webkit-flex-wrap: wrap;
	flex-wrap: wrap;
	display: -webkit-box; /* Android 2~4 */
	display: -webkit-flex; /* Safari */
	display: flex;
	margin-left: -30px;
	margin-top: 40px;
	font-size: 13px;
}
.topitem a,
#left_side_col a { color: #ffffff; }

.topitem section {
	-webkit-box-flex: 150px;
	-webkit-flex: 150px;
	flex: 150px;
	margin: 0 0 20px 30px;
	line-height: 1.5;
}
.topitem section img { margin-bottom: 15px; width: 100%; }
.topitem section .name { text-align: center; font-weight: 400; }

@media (max-width: 768px) {
	.topitem  { margin-left: -20px; }
	.topitem section { margin: 0 0 10px 20px; }
}
@media (max-width: 480px) {
	.topitem  { margin-left: -20px; font-size: 12px; }
	.topitem section {
		-webkit-box-flex: 85px;
		-webkit-flex: 85px;
		flex: 85px;
		margin: 0 0 10px 20px;
	}
}

/* flexbox余白 */
section.empty {
	height: 0;
	margin-top: 0; margin-bottom: 0;
	padding-top: 0; padding-bottom: 0;
}

.map-e {
	text-align: center;
	padding: 30px;
	margin: 60px 0 0;
	background-color: #ffffff;
}


/*---------------------------------------------
	耳たぶ
  ---------------------------------------------*/
#extra {
	position: fixed;
	_position: absolute;
	left: 0;
	width: 57px;
	z-index: 1000;
}
#extra { top: 70px; }
#extra img { cursor: pointer; }
@media (max-width: 979px) {
	#extra { display: none; }
}

/* ------ GoogleMap ------ */
#map_canvas {
	width: 100vw;
	position: relative;
	left: 50%;
	transform: translateX(-50%);
	height: 480px;
	margin: 30px 0 0;
}
@media screen and (max-width: 479px) {
	#map_canvas {
		height: 320px;
		margin-top:30px;
	}
}

/* ------ スクロールフェード ------ */
.fade-up,
.fade-left,
.fade-right { opacity : 0; transition:all 800ms; }
.fade-up { transform : translate(0, 80px); }
.fade-left { transform : translate(-80px, 0); }
.fade-right { transform : translate(80px, 0); }
.fade-up.scrollin,
.fade-left.scrollin,
.fade-right.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

/* ページの先頭へ */
#page-top { width:50px; height:50px; display:none; position:fixed; right:16px; bottom:16px; }
#page-top p { margin: 0; padding: 0; text-align: center; background-color: #274a78; }
#page-top p:hover{ background-color: #EA6E15; }
#move-page-top{ color:#fff; line-height:50px; text-decoration:none; display:block; cursor:pointer; }


footer { max-width: 100%; background-color:#2b2b2b; }
#footer-inner {
	max-width: 960px;
	margin: 0 auto;
	position: relative;
	padding:20px 0 30px;
	color: #ffffff;
	text-align: center;
}
#footer-inner a {
	color: #ffffff;
}
@media (max-width: 1000px) {
	#footer-inner {
		padding:10px 20px 30px;
		text-align: left;
	}
}


/* レスポンシブ */
@media (min-width: 1000px) {
	.forSP { display:none }
	.forPC { display:block }
}
@media (max-width: 1000px) {
	.forPC { display:none }
	.forSP { display:block }
}
