@charset "utf-8";
/* CSS Document */


/* bootstrap.css基本の打消し（同じclass名での書き換え）
---------------------------------------------------- */
body{ margin:0px; padding:0px;}
h1,h2,h3,h4,h5,h6{ margin:0px; padding:0px; font-weight:normal; clear:both}
p{ margin:0px; padding:0px}

.navbar {
  margin-bottom:0px;
  border:none;
}
.table-striped > tbody > tr:nth-of-type(odd) { background-color: #efefef;}
.table{ margin-bottom:30px}
.table th{ width:30%}

@media (min-width: 768px) {.btn-group-vertical a{ padding-top:15px;padding-bottom:15px}}

img.img-fluid {display: block;}


/* 全体構造
---------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
    zoom:1;/*for IE 5.5-7*/
	overflow:hidden;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}

.clear{clear:both;}

img{border:0;vertical-align:bottom;}

a {
	outline:none;
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}

hr {
    display:block;
    height:1px;
    border-top:1px dotted #000;
    margin:0;
    padding:0;
	margin-bottom:20px;
}

body{
	font-size:85%;/* 基本のフォントサイズ */
	line-height:185%;/* 基本の行間 */
	font-family:FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color:#000;
}

sup {font-size: 80%;}

header,
main,
footer{
	font-family: "Zen Kaku Gothic New", serif;
	font-weight: 700;
}
.en{
	font-family: "Outfit", serif;
	font-weight: 700;
	letter-spacing: 0;
}
.en.normal{
	font-weight: 400;
}


/* link
---------------------------------------------------- */
a:link,a:visited,a:hover,a:active{text-decoration:none; color:#000; }
/*.link_kon a:link,a:visited,a:hover,a:active{text-decoration:none; color:#f58599}*/


/* header
---------------------------------------------------- */
header{
	/*
	width: 100%;
	padding-top: 0;
	padding-bottom: 0;
	position: fixed;
	background:none;
	top: 0;
	z-index: 100!important;
	*/
	background: #fff!important;
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
}
.head_in{
	width: 100%;
	padding-top: 0;
	padding-bottom: 0;
	position: fixed;
	background:none;
	top: 0;
	z-index: 100!important;
}
h1{width: 250px;}
h2.ezoumi{width: 90px; margin: 0 auto;}
h2.michimaro{width: 160px; margin: 0 auto;}

h1 img{
	width: 100%;
	height: auto;
}
@media only screen and (max-width: 767px) {
	header h1 {
		position: absolute;
		left: 0;
		top: 0;
		z-index: 100;
		/*float: left;*/
	}
	h1 img{padding-top: 12px; padding-left: 10px;}
}
@media print, screen and (min-width: 768px) {
	header{position: relative;}
	h1{width: 300px; padding-top: 24px; margin: 0 auto;}
	h2.ezoumi{width: 95px;}
	h2.michimaro{width: 170px;}
}
@media print, screen and (min-width: 992px) {
	h1{width: 330px;}
	h2.ezoumi{width: 130px;}
	h2.michimaro{width: 220px;}
}
@media print, screen and (min-width: 1600px) {
	h1{width: 500px;}
	h2.ezoumi{width: 180px;}
	h2.michimaro{width: 300px;}
}



@media print, screen and (min-width: 768px) {
	#top_page .head_in{
		display: none;
	}
}


.navi_cnter{display: none;}
@media print, screen and (min-width: 768px) {
	.navi_cnter {
		width: 100%;
		display: block;
		margin: 20px 0;
	}
	.cb-header .navi_cnter {
		padding: 20px 0;
		background-color: #fff;
		margin-top: 0;
		margin-bottom: 0;
	}
	
	.navi_cnter ul{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		justify-content: center;
		font-family: "Zen Kaku Gothic New", serif;
		font-weight: 700;
		font-size: 100%;
	}
	.navi_cnter li{
		list-style: none;
		margin: 0 10px;
	}
	
	.navi_cnter a{position: relative; padding-bottom: 12px;}	
	.navi_cnter a::after {
		position: absolute;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background: #000;
		bottom: 4px; /*アンダーラインが現れ始める位置（aタグの下辺からの高さ）*/
		opacity: 0;
		visibility: hidden;
		transition: 0.3s;
	}
	.navi_cnter a:hover{opacity: 1;}
	.navi_cnter a:hover::after {
		visibility: visible;
		bottom: 9px;
		opacity: 1;
	}
	.navi_cnter .navi-on a::after {
		visibility: visible;
		left: 0;
		content: '';
		width: 100%;
		height: 2px;
		background: #000;
		bottom: 9px; /*アンダーラインが現れ始める位置（aタグの下辺からの高さ）*/
		opacity: 1;
	}

}
@media print, screen and (min-width: 992px) {
	.navi_cnter { margin: 25px 0;}
	.navi_cnter ul{
		font-size: 110%;
	}
	.navi_cnter li{
		margin: 0 20px;
	}
}
@media print, screen and (min-width: 1200px) {
	.navi_cnter ul{
		font-size: 130%;
	}
}
@media print, screen and (min-width: 1600px) {
	.navi_cnter { margin: 30px 0;}
	.navi_cnter ul{
		font-size: 160%;
	}
	
}


.cb-header {
	position: fixed; /* ヘッダーバーを固定 */
	top: -145px;
	left: 0;
	width: 100%;
	z-index: 1000;
	background:#fff;
}


/* ついてくるナビ
---------------------------------------------------- */
.global-nav {
  position: fixed;
  /* right: -320px; これで隠れる */
	right: -100%;
  top: 0;
   /*width: 300px; スマホに収まるくらい */
	width: 100%;
  height: 100%;
  padding-top: 40px;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  transition: all .6s;
  z-index: 200;
  overflow-y: auto; /* メニューが多くなったらスクロールできるように */
}
.global-nav .container-fluid {
  margin-top: auto;
  margin-bottom: auto;
}
/* スクロールバー　デザイン */
.global-nav {
  scrollbar-color: rgba(0,0,0,0.1) rgba(0,0,0,0.05);
  scrollbar-width: thin;
}
.global-nav::-webkit-scrollbar {
  width: 5px;
  height: 5px;
  /* display: none; // 消す場合は有効してください */
}
.global-nav::-webkit-scrollbar-track {
  background: rgba(0,0,0,0.05);
}
.global-nav::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.1)
}


.hamburger {
  position: absolute;
  right: 5px;
  top: 5px;
  width: 55px; /* クリックしやすいようにちゃんと幅を指定する */
  height: 55px; /* クリックしやすいようにちゃんと高さを指定する */
  cursor: pointer;
  z-index: 300;
  background-color: #000;
  border-radius: 5px;
}
@media print, screen and (min-width: 768px) {
	.hamburger {
	  right: 10px;
	  top: 10px;
	  border-radius: 15px;
	}
}

.global-nav__list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.global-nav__item {
  text-align: center;
  padding: 0 14px;
}
.global-nav__item a {
  display: block;
  padding: 8px 0;
  /*border-bottom: 1px solid #eee;*/
  border-bottom: 1px solid #d2c5b2;
  text-decoration: none;
  color: #524631;
}
.global-nav__item a:hover,
.global-nav__item.navi-on a{
  /*background-color: #eee;*/
  background-color: #fff;
}
.hamburger__line {
  position: absolute;
  left: 13px;
  width: 28px;
  height: 1px;
  background-color: #fff;
  transition: all .6s;
}
.hamburger__line--1 {
  top: 16px;
}
.hamburger__line--2 {
  top: 22px;
}
.hamburger__line--3 {
  top: 28px;
}
.hamburger__moji {
  position: absolute;
  left: 13px;
  width: 25px;
  transition: all .6s;
}
.hamburger__line--moji {
  top: 25px;
  color: #fff;
  font-size: 80%;
}
@media print, screen and (min-width: 768px) {
	.hamburger__line--moji {
	  font-size: 90%;
	}
}
.black-bg {
  position: fixed;
  left: 0;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  background-color: #524631;
  opacity: 0;
  visibility: hidden;
  transition: all .6s;
  cursor: pointer;
}
@media print, screen and (min-width: 768px) {
	.global-nav {
	  padding-top: 80px;
	}
	.global-nav__item a {
	  padding: 16px 0;
	}
	.hamburger {
	  width: 75px; /* クリックしやすいようにちゃんと幅を指定する */
	  height: 80px; /* クリックしやすいようにちゃんと高さを指定する */
	}
	.hamburger__line {
	  left: 23px;
	  width: 30px;
	}
	.hamburger__line--1 {
	  top: 25px;
	}
	.hamburger__line--2 {
	  top: 33px;
	}
	.hamburger__line--3 {
	  top: 41px;
	}
	.hamburger__moji {
	  left: 23px;
	  width: 25px;
	}
	.hamburger__line--moji {
	  top: 40px;
	}
}
/* 表示された時用のCSS */
.nav-open .global-nav {
  right: 0;
	background-color: #fff;
	opacity: 0.8;
}
.nav-open .black-bg {
  opacity: .8;
  visibility: visible;
}
.nav-open .hamburger__line--1 {
  transform: rotate(45deg);
  top: 22px;
}
.nav-open .hamburger__line--2 {
  width: 0;
  left: 50%;
}
.nav-open .hamburger__line--3 {
  transform: rotate(-45deg);
  top: 22px;
}
@media print, screen and (min-width: 768px) {
	.nav-open .hamburger__line--1 {
	  top: 33px;
	}
	.nav-open .hamburger__line--3 {
	  top: 33px;
	}
}


/*スクロール後固定*/
.navi_nakami{
	padding: 20px 10px;
	width: 100%;
	margin: 0 auto;
	font-family: "Zen Kaku Gothic New", serif;
	font-weight: 700;
}
.navi_nakami .name{
	max-width: 680px;
	margin: 0 auto 30px auto;
}
.navi_nakami .name img{
	width: 100%;
	height: auto;
	margin: 0 auto;
}



.nakami_navi .box h3{
	font-size: 100%;
	color: #000;
	margin-bottom: 5px;
	font-weight: 700;
}

.nakami_navi .box ul li{
	list-style: none;
	margin-bottom: 10px;
}
.nakami_navi .box ul li a:link,
.nakami_navi .box ul li a:visited{
	color: #000;
}
.nakami_navi .box ul li a:hover,
.nakami_navi .box ul li.navi-on a{
	color: #900;
	opacity: 1;
}

@media only screen and (max-width: 767px) {
	.nakami_navi .box {font-size: 95%;}
}


img.nav_logo01{
	max-width: 130px;
	width: 100%;
	height: auto;
}
img.nav_logo02{
	max-width: 70px;
	width: 100%;
	height: auto;
}

.nakami_navi .room > div {margin-bottom: 20px;}
.nakami_navi .room > div img {margin-top: 7px; display: none;}

.nakami_navi .room a{display: block;}
.nakami_navi .room a:hover h3{
	color: #900;
	opacity: 1;
}
.nakami_navi .room a.active h3{
	color: #900;
	opacity: 1;
}
.nakami_navi .room a:hover{
	opacity: 1;
}

.nakami_navi{
    display: -webkit-flex;
    display: flex;
    justify-content: center;
}
.nakami_navi .box:first-child{ margin-right: 20px;}

.nakami_navi .box ul li:before,
.nakami_navi .room h3:before{
    font-family: bootstrap-icons;
    font-weight: 900;
    content: "\F231";
    margin-right: 5px;
    color: #900;
    font-size: 80%;
    margin-left: -18px;
    padding-bottom: 10px;
}
@media only screen and (max-width: 767px) {
	.nakami_navi .box{width: 50%;}
}

@media print, screen and (min-width: 576px) {
	.navi_nakami .name img{ width: 70%;}
	.nakami_navi .box{margin: 0 30px;}
	.nakami_navi .box ul > li {margin-bottom: 10px;}
	.nakami_navi .box h3 {margin-bottom: 10px;}
}
@media print, screen and (min-width: 768px) {
	.navi_nakami .name{
		margin: 0 auto 50px auto;
	}
	.nakami_navi {font-size: 120%;}
	.nakami_navi .box{margin: 0 0;}
	.nakami_navi .box ul li{ margin-bottom: 20px;}
	img.nav_logo01{ max-width: 200px;}
	img.nav_logo02{	max-width: 95px;}
}
@media print, screen and (min-width: 992px) {
	.navi_nakami .name img{ width: 80%;}
	.nakami_navi .box h2{
		font-size: 200%;
		margin-bottom: 15px;
	}
	.nakami_navi .room > div {margin-bottom: 30px;}
	.nakami_navi {font-size: 140%;}
	.nakami_navi .box:first-child{ margin-right: 40px;}
}
@media print, screen and (min-width: 1200px) {
	.nakami_navi {font-size: 160%;}
	.nakami_navi .box ul li{ margin-bottom: 30px;}
	img.nav_logo01{ max-width: 300px;}
	img.nav_logo02{	max-width: 130px;}
}



/*-----------------スマホのトグル-----------------*/
.menu-mobile {height: 60px;}
.menu-mobile::after {
  content: ""!important;
  padding: 0;
	background-image: -webkit-linear-gradient( 0deg, rgb(22,45,87) 0%, rgb(0,200,255) 0%, rgb(17,228,151) 100%);
	-moz-background-size:100% auto;
	background-size:100% auto; 
	width: 65px;
	height: 70px;
	 margin-right: -15px!important;
	 margin-top: -23px!important;

}
.menu-mobile {
  padding: 0!important;
}




@media print, screen and (min-width: 768px) {
	.navi_nakami{ padding: 50px 0;}
}


/* midashi
---------------------------------------------------- */
.fs60 {font-size:60%; line-height: 1.6em;}
.fs70 {font-size:70%; line-height: 1.6em;}
.fs75 {font-size:75%; line-height: 1.6em;}
.fs80 {font-size:80%; line-height: 1.6em;}
.fs85 {font-size:85%; line-height: 1.6em;}
.fs90 {font-size:90%; line-height: 1.6em;}
.fs110 {font-size:110%; line-height: 1.6em;}
.fs120 {font-size:120%; line-height: 1.6em;}
.fs140 {font-size:130%; line-height: 1.6em;}
.fs160 {font-size:160%; line-height: 1.6em;}
.fs180 {font-size:180%; line-height: 1.6em;}

.fs100_sm90_md90_lg100 {font-size: 100%;}
@media print, screen and (min-width: 768px) {
	.fs100_sm90_md90_lg100 {font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs100_sm90_md90_lg100 {font-size: 100%;}
}

@media print, screen and (min-width: 768px){
	.fs90_smmd{ font-size: 90%;}
}
@media print, screen and (min-width: 1200px){
	.fs90_smmd{ font-size: 100%;}
}

.fs60_sm80_md70{font-size: 80%;}
@media print, screen and (min-width: 992px){
	.fs60_sm80_md70{font-size: 70%;}
}
@media print, screen and (min-width: 1200px) {
	.fs60_sm80_md70{font-size: 60%;}
}

.fs160_sp140 {font-size: 140%;}
@media print, screen and (min-width: 768px) {
	.fs160_sp140 {font-size: 160%;}
}

.text_large{font-size: 100%; line-height: 1.8em;}
@media print, screen and (min-width: 768px){
	.text_large{font-size: 110%;line-height: 2.0em;}
}
@media print, screen and (min-width: 992px){
}
@media print, screen and (min-width: 1200px){
	.text_large{font-size: 120%;}
}


/*--------------------------*/

/*タイトルエフェクト*/
.title_waku {display: inline-block;}
.block-revealer__element {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #000;
    pointer-events: none;
    opacity: 0;
}

/* 画像を使うときはvertical-align bottomをしないと下に余白ができてしまうので注意！！ */
.revealImg {
    width: 300px;
    height: 200px;
    -o-object-fit: cover;
       object-fit: cover;
    vertical-align: bottom;
}

/*--------------------------*/

.midashi_tate_area{
	position: relative;
	overflow: hidden;
}

.midashi_tate{
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode:vertical-rl;
	font-size: 90%;
	margin-bottom: 0;
	display: inline-block;
	position: absolute;
	left: 10px;
	top: 0;
	padding-top: 40px;
	color: #000;
	background: url(../images/midashi_tate.gif) no-repeat center top;
	-moz-background-size:1px 32px;
	background-size:1px 32px; 
	font-family: 'Roboto', sans-serif;
	font-weight: 700;
}
.midashi_tate.white{
	color: #fff;
	background: url(../images/midashi_tate_white.gif) no-repeat center top;
}
.midashi_tate.migi{
	left: auto;
	right: 10px;
}
@media print, screen and (min-width: 1200px){
	.midashi_tate.migi{
		right: 40px;
	}
}


/**/


.pankuzu{
	font-size: 85%;
	font-family: "Zen Kaku Gothic New", serif;
	font-weight: 500;
	margin-bottom: 10px;
}
.pankuzu a:link,
.pankuzu a:visited{
	text-decoration: underline;
	color: #fff;
}
@media print, screen and (min-width: 768px){
	.pankuzu{
		margin-bottom: 20px;
	}
}


#midashi_h2{
	background-color: #900;
	color: #fff;
	margin-top: 65px;
	position: relative;
	z-index: 0;
}
#midashi_h2 h2{
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	font-size: 160%;
	line-height: 1.4em;
   display:flex;
   align-items:center;
   justify-content:center;
}
#midashi_h2 h2 .maru{
   width:60px;
   height:60px;
   border-radius:50%;
   border: 1px solid #fff;

   /*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
	font-size: 150%;
	margin-right: 10px;
}
#midashi_h2 h3{
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	font-size: 100%;
	line-height: 1.6em;
	margin-top: 20px;
	text-align: center;
}

@media print, screen and (min-width: 768px){
	#midashi_h2{ margin-top: 25px;}
	
	#midashi_h2 h2{ font-size: 180%;}
	#midashi_h2 h2 .maru{
	   width:80px;
	   height:80px;
		font-size: 160%;
	}
	#midashi_h2 h3{ font-size: 110%;}
}
@media print, screen and (min-width: 992px){
	#midashi_h2 h2{ font-size: 220%;}
	#midashi_h2 h2 .maru{
	   width:100px;
	   height:100px;
	}
}
@media print, screen and (min-width: 1200px){
	#midashi_h2 h2{ font-size: 260%;}
	#midashi_h2 h3{ font-size: 130%;}
}
@media print, screen and (min-width: 1600px){
	#midashi_h2 h3{ font-size: 140%;}
}


#midashi_h2 .image{
	max-width: 70px;
	position: absolute;
	right: 5%;
	bottom: -30px;
}
@media print, screen and (min-width: 768px){
	#midashi_h2 .image{
		max-width: 150px;
		bottom: -50px;
	}
}
@media print, screen and (min-width: 1200px){
	#midashi_h2 .image{
		max-width: 250px;
		right: 5%;
		bottom: -80px;
	}
}

/*------------------*/


.midashi1{
	font-size: 130%;
	line-height: 1.4em;
	font-weight: 700;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.midashi1 img{
	width: 17px;
	height: auto;
	margin-right: 10px;
}

.midashi2{
	font-size:80%;
	line-height: 1.4em;
	font-weight: 700;
	background-color: #000;
	color: #fff;
	padding: 5px 10px;
	display: inline-block;
}

.midashi3{
	font-size:110%;
	line-height: 1.4em;
	font-weight: 700;
	text-align: center;
}
.midashi3 .en{
	display: block;
	font-size: 16px;
	color: #900;
	letter-spacing: 0.05em;
}
.midashi3.sen{
	border-collapse: collapse;
	border-bottom: 1px solid #000;
	padding-bottom: 20px;
}


.midashi4{
	font-size:130%;
	line-height: 1.4em;
	font-weight: 700;
}
.midashi4 img{
	max-width: 180px;
	width: 100%;
	height: auto;
	margin: 10px auto 0 auto;
}

.midashi5{
	font-size:130%;
	line-height: 1.4em;
	font-weight: 700;
	background-color: #000;
	color: #fff;
	padding: 5px 10px;
	display: inline-block;
}



.midashi_en{
	font-family: "Outfit", serif;
	font-weight: 700;
	font-size: 300%;
	line-height: 1.4em;
}

@media print, screen and (min-width: 768px){
	.pr_text{padding-right: 30px;}
	.pl_text{padding-left: 30px;}
	
	.midashi1.tac_sptal{
		justify-content:center;
	}
	.midashi3{ font-size:130%;}
	.midashi3 .en{ font-size: 18px;}
	.midashi_en{ font-size: 400%;}
}
@media print, screen and (min-width: 992px){
	.midashi4{ font-size:150%;}
	.midashi5{ font-size:150%;}
	.midashi_en{ font-size: 500%;}
}
@media print, screen and (min-width: 1200px){
	.midashi3{ font-size:150%;}
	.midashi3 .en{ font-size: 20px;}
	.midashi4{ font-size:160%;}
	.midashi5{ font-size:160%;}
	.midashi_en{ font-size: 600%;}
}
@media print, screen and (min-width: 1800px){
}



.midashi_en.tate{
	writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode:vertical-rl;
	margin-bottom: 0;
	display: inline-block;
	position: absolute;
	left: 10px;
	top: 0;
}
@media print, screen and (min-width: 768px){
	.midashi_en.tate{
		left: 8.333333%;
	}
}
@media print, screen and (min-width: 1500px){
	.midashi_en.tate{
		left: 16.666667%;
	}
}



/*リンク・ボタン関係
---------------------------------------------------- */
a:hover{opacity:0.7;filter: alpha(opacity=70);/*transition: 0.5s;*/}

.btn{ padding-top:10px; padding-bottom:10px;}
@media print, screen and (min-width: 768px) {.btn{ padding:10px 25px;}}

.btn.dsb_sp {display: block;}
@media print, screen and (min-width: 768px) {.btn.dsb_sp {display: inline-block;}}




.mannaka .button1,
.mannaka .button2{
	margin: 0 auto;
}
.migi .button1{
	margin-left: auto;
}
@media only screen and (max-width: 767px) {
	.mannaka_sp .button1{
		margin: 0 auto;
	}
}


.button1 {
  width:max-content;
  height:auto;
  position:relative
}
.button1 a {
  font-size:100%;
  font-weight:700;
  letter-spacing:0;
  line-height:1.5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s cubic-bezier(0.33, 1, 0.68, 1);
	background: none;
	/*padding: 8px 8px 8px 28px;*/
	border-radius: 50px;
	/*border: 1px solid #222;*/
}
.button1 a:link,
.button1 a:visited{
	text-decoration: none;
	color: #000;
}
.button1 .moji{
	border-bottom: 1px solid #000;
	padding-bottom: 3px;
}
.button1 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button1 a .arrow {
  width:50px;
  height:50px;
  margin-left:20px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button1 a .arrow i {
	color: #fff;
}
.button1 a:hover .arrow {
  width:60px;
  height:60px;
}



.button2 {
  width:max-content;
  height:auto;
  position:relative
}
.button2 a {
  font-size:100%;
  font-weight:700;
  letter-spacing:0;
  line-height:1.5;
  display:flex;
  justify-content:space-between;
  align-items:center;
  transition:color .2s cubic-bezier(0.33, 1, 0.68, 1);
	background: #fff;
padding: 8px 8px 8px 28px;
	border-radius: 50px;
	border: 1px solid #222;
}
.button2 a:link,
.button2 a:visited{
	text-decoration: none;
	color: #000;
}
.button2 .moji{
	border-bottom: 1px solid #000;
	padding-bottom: 3px;
}
.button2 a:hover {
  /*color:#0083c5;*/
  opacity:1
}
.button2 a .arrow {
  width:50px;
  height:50px;
  margin-left:20px;
  transition:width .2s cubic-bezier(0.33, 1, 0.68, 1),height .2s cubic-bezier(0.33, 1, 0.68, 1)
}
.button2 a .arrow i {
	color: #fff;
}
.button2 a:hover .arrow {
  width:60px;
  height:60px;
}





.arrow {
  display:flex;
  justify-content:center;
  align-items:center;
  flex-shrink:0;
  width:50px;
  height:50px;
  position:relative;
  border-radius:50%;
  transition:transform .64s cubic-bezier(0, 0.55, 0.45, 1)
}
.arrow::before {
  content:"";
  width:100%;
  height:100%;
  position:absolute;
  inset:0 auto auto 0;
  /*background-color:#0083c5;*/
  border-radius:50%;
  transition:transform .64s cubic-bezier(0, 0.55, 0.45, 1);
	background-color: #900;
	/*border: 1px solid #fff;*/
}
a:hover .arrow::before {
  background-color:#900;
}
.arrow.red::before {
  background-color:#e71b17;
}
.arrow.red i {
  fill:#7d8386
}
.arrow.gray::before {
  background-color:#f6f6f6
}
.arrow.gray i {
  fill:#0083c5
}
.arrow.white::before {
  background-color:#7d8386
}
.arrow.white i {
  fill:#0083c5
}
.arrow i {
  fill:#7d8386;
  position:relative
}





.btn1{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
}
.btn1:link,
.btn1:visited{
	color:#000;
	padding:8px 0;
	text-decoration: none;
	position: relative;
	z-index: 2;
	border-bottom: 1px solid #000;
}
.btn1:hover{
	opacity: 1;
	background-color: #000;
	color: #fff;
	padding:8px 15px;
}

.btn1 i {margin-left: 20px; font-size: 100%; color: #000;}
.btn1:hover i {color: #fff;}
.btn1.btn {border-radius: 0; }





.btn2{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	padding-bottom: 1px;
	margin-bottom: 1px;
}
.btn2:link,
.btn2:visited{
	color:#000;
	padding:17px 10px;
	text-decoration: none;
	background-color: #fff;
	border: 1px solid #000;
	display: -webkit-flex;
    display: flex;
    align-items: center;
	justify-content: center;
}
.btn2:hover{
	opacity: 1;
	background-color: #000;
	color: #fff;
}

.btn2 i {margin-left: 15px; font-size: 120%;}

.btn2.btn {border-radius: 5px; }
@media print, screen and (min-width: 992px) {
	.btn2:link,
	.btn2:visited{
		padding:20px 20px;
		width: 400px;
	}
	.btn2:hover{
		padding:20px 30px;
	}
}



.btn_head{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
}
.btn_head:link,
.btn_head:visited{
	color:#fff;
	padding:10px 30px!important;
	text-decoration: none;
	position: relative;
	z-index: 2;
	background-color: #65bbe9;
	font-weight: 700;
}
.btn_head.pink_bg:link,
.btn_head.pink_bg:visited{
	background-color: #fb9086;
	
}
.btn_head:hover,
.btn_head.navi-on{
	opacity: 1;
	background-color: #000!important;
}

.btn_head i {margin-right: 7px; font-size: 100%;}

.btn_head.btn {border-radius: 50px; }
@media print, screen and (min-width: 1200px) {
	.btn_head:link,
	.btn_head:visited{
		padding:12px 30px!important;

	}
}


.btn_line{
	font-size: 100%;
	line-height:1.4em;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	z-index: 0;
}
.btn_line:link,
.btn_line:visited{
	color:#fff;
	padding:15px 15px!important;
	text-decoration: none;
	position: relative;
	z-index: 2;
	background-color: #04b404;
	font-weight: 700;
	display: -webkit-flex;
    display: flex;
    align-items: center;
	justify-content: center;
}
.btn_line:hover,
.btn_line.navi-on{
	opacity: 1;
	background-color: #000!important;
}
.btn_line i {margin-right: 7px; font-size: 160%;}
.btn_line.btn {border-radius: 5px; }



.btn_pdf{
	font-size:20px;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	margin-left: 10px;
}
.btn_pdf:link,
.btn_pdf:visited{
	color:#900!important;
	text-align: center;
	vertical-align: middle;
}
.btn_pdf.btn {border-radius: 50px; padding:0; border: 0;}






.btn_yaji{
	font-size: 80%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	width: 35px;
	height: 35px;
	line-height: 35px;
}
.btn_yaji:link,
.btn_yaji:visited{
	color: #000;
	font-size: 160%;
}
.btn_yaji:hover{
	opacity: 1;
	color: #7d8386;
	font-size: 180%;
}
.btn_yaji.btn {border-radius: 0; padding:0; border: 0;}




.btn_detail{
	font-size: 80%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	position: relative;
	font-family: 'Roboto', sans-serif;
	font-weight: 700;
	width: 35px;
	height: 35px;
	line-height: 35px;
}
.btn_detail:link,
.btn_detail:visited{
	color:#fff;
	background: #000;
	width: 35px;
	height: 35px;
	line-height: 35px;
	text-align: center;
	vertical-align: middle;
	font-family: 'Roboto', sans-serif;
	font-weight: 400;	
}
.btn_detail:hover{
	opacity: 1;
	width: 40px;
	height: 40px;
	line-height: 40px;
}
.btn_detail.btn {border-radius: 50px; padding:0; border: 0;}


.btn_map{
	font-size: 130%;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
  /*display: flex;*/
	display: inline-flex;
  justify-content: center;
  align-items: center;
	margin-left: 10px;
}
.btn_map:link,
.btn_map:visited{
	color:#900;
	text-decoration: none;
}
.btn_map:hover{
	opacity: 1;
	background-color: #000;
}
.btn_map.btn {border-radius: 0; padding:0; border: 0;}





.pdf_list li{
	list-style: none;
	margin-bottom: 3px;
}
.pdf_list li a:link,
.pdf_list li a:visited{
	padding: 10px 15px;
	background: #900;
	color: #fff;
	display: block;
	text-decoration: none;
	font-size: 90%;
	border-radius: 0;
	/*ゆっくり動かす（ポイントはhoverではなくaの箇所のcssに記載）*/
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	transition: 0.8s;
	/*ここまで*/
	border-radius: 5px;
	display: -webkit-flex;
    display: flex;
    align-items: center;
}
.pdf_list li a:hover{
	padding: 10px 15px;
	opacity: 1;
	border-radius: 50px;
}
.pdf_list li i {margin-right: 10px; font-size: 160%;}
@media print, screen and (min-width: 768px){
	.pdf_list{
		margin-left: -1%;
		margin-right: -1%;
	}
	.pdf_list li{
		width: 31.3%;
		float: left;
		margin: 1%;
	}
}

.text_link_area a {text-decoration: underline; color: #7d8386;}
.text_link i { color: #000; margin-left: 10px; font-size: 110%;}

a.text_link {text-decoration: underline; color: #7d8386;}
a.text_link2 {text-decoration: underline; color: #fff;}

.cate_text a:link,
.cate_text a:visited{
	text-decoration: underline;
	color: #00ac9a;
}
@media only screen and (max-width: 767px) {
	.text_link_sp {text-decoration: underline; color: #7d8386;}
	.text_link_sp2 {text-decoration: underline!important; color: #fff;}
}
/* リスト
---------------------------------------------------- */
ol.list_ol{
	list-style:decimal;
	margin-left:25px;
}
ul.list_ul{
	list-style:disc;
	margin-left:20px;
}


ol.list_num {
  counter-reset: my-counter;
  list-style: none;
  padding: 0;
}
 
ol.list_num > li {
  margin-bottom: 10px;
  padding-left: 35px;
  position: relative;
}
ol.list_num > li:before {
  content: counter(my-counter);
  counter-increment: my-counter;
  background-color: #900;
  color: #fff;
  display: block;
  float: left;
  line-height: 25px;
  margin-left: -35px;
  text-align: center;
  height: 25px;
  width: 25px;
  border-radius: 50%;
	font-family: 'Roboto', sans-serif;
font-weight: 300;
	margin-top: 5px;
}


ul.list_check li{ list-style:none;text-indent: -1em; padding-left:1em;}
ul.list_check li:before{
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f14a";
	margin-right: 5px;
	color: #0062b2;
}

ul.list_maru li{
	list-style:none;
	text-indent: -1.2em;
	padding-left:1.2em;
	padding-bottom: 5px;
	line-height: 1.6em;
}
ul.list_maru li:before{
	font-family: bootstrap-icons;
	font-weight: 900;
	content: "\F517";
	margin-right: 5px;
	color: #900;
	font-size: 80%;
}



/* color
---------------------------------------------------- */
.red{color:#900;}
.white{color:#fff;}
.black{color:#000;}

/* hanyo
---------------------------------------------------- */
.large{font-size:130%;line-height:1.7em}
.small{font-size:80%;line-height:1.5em; font-weight:normal}
.lsn{ list-style:none;}
.ln{ line-height:normal}
.dsb{ display:block}
.dsi{ display:inline}
@media print, screen and (min-width: 992px) {
	.dsi_lg {display:inline}
}


.kome {text-indent:-1em; margin-left:1em;}
.kome_num {text-indent:-2.8em; margin-left:2.8em;}


.tal{ text-align:left}
.tac{ text-align:center}
.tar{ text-align:right}
.bold {font-weight:bold;}

.tar_sptac {text-align:center;}
@media print, screen and (min-width: 768px) {
.tar_sptac {text-align:right;}
}

.tar_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px) {
.tar_spsmtac {text-align:right;}
}

.tar_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tar_sptal {text-align:right;}
}

.tal_lgtar {text-align:left;}
@media print, screen and (min-width: 1200px){
.tal_lgtar {text-align:right;}
}

.tal_smtac {text-align:center;}
@media print, screen and (min-width: 576px){
.tal_smtac {text-align:left;}
}

.tal_sptac {text-align:center;}
@media print, screen and (min-width: 768px){
.tal_sptac {text-align:left;}
}

.tal_spsmtac {text-align:center;}
@media print, screen and (min-width: 992px){
.tal_spsmtac {text-align:left;}
}

.tac_smtal {text-align:left;}
@media print, screen and (min-width: 576px){
.tac_smtal {text-align:center;}
}
.tac_sptal {text-align:left;}
@media print, screen and (min-width: 768px){
.tac_sptal {text-align:center;}
}
.tac_sptal2 {text-align:left;}
@media print, screen and (min-width: 576px){
.tac_sptal2 {text-align:center;}
}

.img_c img{
	margin: 0 auto;
}

/* dl
---------------------------------------------------- */
/*
.dl_list dt{
	background: url(../images/dl_sen.jpg) no-repeat left center;
	padding: 3px 0 3px 25px;
}
.dl_list dd{
	line-height: 1.8em;
	padding-left: 25px;
}
*/

/* テーブル
---------------------------------------------------- */
table{border-spacing:0;border-collapse:separate;}
table ul.list_ul, table ol.list_ol{margin-left:20px;}

.nw {width:1%; white-space:nowrap;}
@media only screen and (max-width: 767px){
	.nw_sp {width:1%; white-space:nowrap;}
}
@media print, screen and (min-width: 768px){
	.nw_spnone {width:1%; white-space:nowrap;}
}

.table1{
	width:100%;
	border-collapse: collapse;
	border-top: 1px solid #dadada;
}
.table1 th{
	width:100%;
	padding:10px 10px 0 10px;
	display: block;
	color: #666;
	font-weight: normal;
}
.table1 td{
	width:100%;
	padding:0 10px 10px 10px;
	display: block;
	border-bottom: 1px solid #dadada;
}
@media print, screen and (min-width: 768px) {
	.table1 th{
		width:27%;
		padding:12px 12px;
		vertical-align:middle;
		text-align:center;
		display:table-cell;
		border-bottom: 1px solid #dadada;
		font-weight: normal;
		color: #000;
	}
	.table1 td{
		width:100%;
		padding:12px 12px;
		display:table-cell;
		vertical-align: middle;
	}
}
@media print, screen and (min-width: 992px) {
	.table1 th{ width:35%;}
}
@media print, screen and (min-width: 1200px) {
	.table1 th{ width:30%;}
}





/* サイズ指定
---------------------------------------------------- */
.mb05{ margin-bottom:5px}
.mb10{ margin-bottom:10px}
.mb15{ margin-bottom:15px}
.mb20{ margin-bottom:20px}
.mb30{ margin-bottom:30px}
.mb40{ margin-bottom:40px}
.mb50{ margin-bottom:50px}
.mb60{ margin-bottom:60px}
.mb70{ margin-bottom:70px}
.mt10{ margin-top:10px}
.mt20{ margin-top:20px}
.mt40{ margin-top:40px}
.ml20{ margin-left:20px}
.ml05{ margin-left:5px}
.ml10{ margin-left:10px}

.pl40 {padding-left: 40px;}
.mt10{ margin-top:10px}

@media print, screen and (min-width: 768px) {.pr30_sp0 {padding-right: 30px;}}

@media print, screen and (min-width: 1600px) {.mb60_1600 { margin-bottom: 60px;}}

.mb10_sp {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb10_sp {margin-bottom:0;}}

.mb15_sp {margin-bottom:15px;}
@media print, screen and (min-width: 768px) {.mb15_sp {margin-bottom:0;}}

.mb20_sp {margin-bottom:20px;}
@media print, screen and (min-width: 768px) {.mb20_sp {margin-bottom:0;}}

.mb30_sp_sm0 {margin-bottom:30px;}
@media print, screen and (min-width: 576px) {.mb30_sp_sm0 {margin-bottom:0;}}

.mb30_sp {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sp {margin-bottom:0;}}

.mb50_sp {margin-bottom:50px;}
@media print, screen and (min-width: 768px) {.mb50_sp {margin-bottom:0;}}

.mb50_lg0 {margin-bottom:50px;}
@media print, screen and (min-width: 992px) {.mb50_lg0 {margin-bottom:0;}}

.mb50_sp_sm0 {margin-bottom:50px;}
@media print, screen and (min-width: 576px) {.mb50_sp_sm0 {margin-bottom:0;}}

@media print, screen and (min-width: 768px) {.mb30_sp0 {margin-bottom:30px;}}

@media print, screen and (min-width: 992px) {.mb30_spsm0 {margin-bottom:0;}}

.mt10_sm20_md30 {margin-top: 10px;}
@media print, screen and (min-width: 768px) {.mt10_sm20_md30 {margin-top: 20px;}}
@media print, screen and (min-width: 992px) {.mt10_sm20_md30 {margin-top: 30px;}}

.mt20_sm40_md50 {margin-top: 20px;}
@media print, screen and (min-width: 768px) {.mt20_sm40_md50 {margin-top: 40px;}}
@media print, screen and (min-width: 992px) {.mt20_sm40_md50 {margin-top: 50px;}}

.mb10_md0 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md0 {margin-bottom: 0;}}

.mb10_lg0 {margin-bottom: 10px;}
@media print, screen and (min-width: 1200px) {.mb10_lg0 {margin-bottom: 0;}}

.mb10_sm30 {margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {.mb10_sm30 {margin-bottom: 30px;}}

.mb10_md20 {margin-bottom: 10px;}
@media print, screen and (min-width: 992px) {.mb10_md20 {margin-bottom: 20px;}}

@media print, screen and (min-width: 768px) {.mb20_sp0 {margin-bottom: 20px;}}

.mb20_md0 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md0 {margin-bottom: 0;}}

.mb20_sm30 {margin-bottom: 20px;}
@media print, screen and (min-width: 768px) {.mb20_sm30 {margin-bottom: 30px;}}

.mb20_md30 {margin-bottom: 20px;}
@media print, screen and (min-width: 992px) {.mb20_md30 {margin-bottom: 30px;}}

.mb30_md0 {margin-bottom: 30px;}
@media print, screen and (min-width: 992px) {.mb30_md0 {margin-bottom: 0;}}

.mb30_sm50 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm50 {margin-bottom:50px;}}

.mb30_md50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_md50 {margin-bottom:50px;}}

.mb30_lg40_xl50 {margin-bottom:30px;}
@media print, screen and (min-width: 992px) {.mb30_lg40_xl50 {margin-bottom:40px;}}
@media print, screen and (min-width: 1200px) {.mb30_lg40_xl50 {margin-bottom:50px;}}

.mb40_md50 {margin-bottom:40px;}
@media print, screen and (min-width: 992px) {.mb40_md50 {margin-bottom:50px;}}

.mb30_sm60 {margin-bottom:30px;}
@media print, screen and (min-width: 768px) {.mb30_sm60 {margin-bottom:60px;}}

.mb30_sp10 {margin-bottom:10px;}
@media print, screen and (min-width: 768px) {.mb30_sp10 {margin-bottom:30px;}}

.pl50_sm0 {padding-left: 50px;}
@media print, screen and (min-width: 768px) {.pl50_sm0 {padding-left: 0;}}


@media print, screen and (min-width: 768px) {
	.mt20_sp0 {margin-top: 20px;}
}

@media print, screen and (min-width: 992px) {
	.mt40_sm0 {margin-top: 40px;}
	.mt40_md_20_sm0 {margin-top: 20px;}
}
@media print, screen and (min-width: 1200px) {
	.mt40_md_20_sm0 {margin-top: 40px;}
}

.mb_content {margin-bottom: 50px;}
.mt_content {margin-top: 50px;}
@media print, screen and (min-width: 768px) {
	.mb_content {margin-bottom: 60px;}
	.mt_content {margin-top: 60px;}
}
@media print, screen and (min-width: 992px) {
	.mb_content {margin-bottom: 80px;}
	.mt_content {margin-top: 80px;}
}
@media print, screen and (min-width: 1200px){
	.mb_content {margin-bottom: 100px;}
	.mt_content {margin-top: 100px;}
}


.lh160 {line-height: 160%;}
.lh200 {line-height: 200%;}

/* content
---------------------------------------------------- */
main { line-height: 2.0em; font-size: 105%; letter-spacing: 0.1em;}

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


.content_pd {padding-top: 50px; padding-bottom: 50px;}
.content_pd2 {padding-top: 30px; padding-bottom: 30px;}
.pd20 { padding: 20px;}
.pd30 { padding: 30px;}
@media only screen and (max-width: 767px){
	.content_pd.pt0_sp {padding-top: 0;}
}
@media print, screen and (min-width: 768px){
	main {font-size: 100%;}
	.content_pd {padding-top: 60px; padding-bottom: 60px;}
	.content_pd2 {padding-top: 50px; padding-bottom: 50px;}
}
@media print, screen and (min-width: 992px){
	main {font-size: 105%;}
	.content_pd {padding-top: 80px; padding-bottom: 80px;}
}
@media print, screen and (min-width: 1200px){
	main {font-size: 120%;}
	.content_pd {padding-top: 100px; padding-bottom: 100px;}
	.content_pd.xl0 {padding-top: 0; padding-bottom: 0;}
}
@media print, screen and (min-width: 1600px){
	main {font-size: 125%;}
	.content_pd {padding-top: 130px; padding-bottom: 130px;}
}
.content_pd.pt0{padding-top: 0;}
.content_pd2.pt0{padding-top: 0;}
.content_pd.pb0{padding-bottom: 0;}
.content_pd2.pb0{padding-bottom: 0;}
.content_pd.pb10{padding-bottom: 10px;}
.content_pd.pb30{padding-bottom: 30px;}



/* mainimage
---------------------------------------------------- */
/* 画面用 */
@media screen {
#main_print { display: none; }
}

/* 印刷用 */
@media print {
#main_print img { margin: 0 auto;}
}


#mainimage {
	position: relative;
	width:100%;
	overflow: hidden;
	margin-top: 65px;
}
@media print, screen and (min-width: 768px){
	#mainimage { margin-top: 0;}
}

/* ヘッダー固定で上空ける
---------------------------------------------------- */


/* 背景
---------------------------------------------------- */
.bg_mokomoko{
	background: url("../images/bg_mokomoko.jpg") no-repeat left top #f4ebe5;
	-moz-background-size:100% auto;
	background-size:100% auto; 
}

.bg_beijyu{ background-color: #f4ebe5;}


.box26 {
    position: relative;
    margin: 2em 0;
    padding: 0.5em 1em;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    border-left: solid 1px #000;
}
.box26 .box-title {
    position: absolute;
    top: -25px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    display: inline-block;
    padding: 0 9px;
    line-height: 1;
    background: #FFF;
}
.box26 .nakami {
    padding: 60px 20px 20px 20px;
}
.box26 .nakami2 {
    padding: 20px 10px;
}
@media print, screen and (min-width: 1200px){
	.box26 .nakami {
		padding: 80px 20px 30px 20px;
	}
	.box26 .nakami2 {
		padding: 20px 10px;
	}
}

.box27 {
    position: relative;
    margin: 2em 0 30px 0;
    padding: 0.5em 1em;
    border: solid 1px #000;
}
.box27 .box-title {
    position: absolute;
    top: -20px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    display: block;
    padding: 0 9px;
    line-height: 1;
    background: #FFF;
	white-space: nowrap;
}

.box27 .nakami {
    padding: 30px 10px 20px 10px;
}
@media print, screen and (min-width: 768px){
	.box27 .nakami {
		padding: 30px 10px 20px 10px;
	}
}
@media print, screen and (min-width: 992px){
	.box27 {
		margin: 2em 0 60px 0;
	}
	.box27 .nakami {
		padding: 40px 10px 20px 10px;
	}
}
@media print, screen and (min-width: 1200px){
	.box27 {
		margin: 2em 0 100px 0;
	}
	.box27 .nakami {
		padding: 50px 10px 20px 10px;
	}
}


/* 背景固定
---------------------------------------------------- */


/* レイアウト
---------------------------------------------------- */

/* 共通
---------------------------------------------------- */
a:hover img {
	opacity:0.9;
	filter: alpha(opacity=90);
}

.close {
    float: none;
}

/* 縦横比固定 */
.photo-ofi {
	 height: 0;
	 display: block;
	padding-bottom: 75%; /* 高さを指定（ボックスの横幅を基準） */
	/*background-color: #EFEFEF;*/
	overflow: hidden;
	position: relative;
	/*margin-bottom: 10px;*/
}

/* スクロールアニメーション
-------------------------------------*/
.animate {
    opacity: 0;
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.animate.from-bottom {
    transform: translateY(100px);
}

.animate.from-right {
    transform: translateX(100px);
}

.animate.from-left {
    transform: translateX(-100px);
}

.animate.scale-up {
    transform: scale(0.8);
}

.animate.pop {
    opacity: 0;
    transform: scale(0.5);
    transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

.animate.fade-in {
    opacity: 0;
    transform: none;
    transition: opacity 2s ease-out;
    /* 2秒でフェードイン */
}

.animate.visible {
    opacity: 1;
    transform: none;
    /* 透明度のみを変化させる */
}

.animate:nth-child(1) {
    transition-delay: 0s;
}

.animate:nth-child(2) {
    transition-delay: 0.4s;
}

.animate:nth-child(3) {
    transition-delay: 0.8s;
}
.animate:nth-child(4) {
    transition-delay: 1.2s;
}

.animate:nth-child(5) {
    transition-delay: 1.6s;
}


/*------画像を徐々に表示------*/
@media print {
   .img-wrap {
     opacity: 1 !important;
     transform: none !important; }
}


.img-wrap {
  opacity: 0;
}

.img-animation {
  animation: img-opacity 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  overflow: hidden;
  position: relative;
}

.img-animation::before {
  animation: img-animation 2s cubic-bezier(0.4, 0, 0.2, 1) forwards;
  background: #fff;
  content: '';
  inset: 0;
  pointer-events: none;
  position: absolute;
  z-index: 1;
}

.kon.img-animation::before {
  background: #7d8386;
}

@keyframes img-opacity {
  100% {
    opacity: 1;
  }
}

@keyframes img-animation {
  100% {
    transform: translateX(100%);
  }
}
/*------*/


.ugoki{
	animation:rumble 0.1s linear infinite;
}
@keyframes rumble {
    0%   { transform:translate(0); }
    25%  { transform:translate(2px); }
    50%  { transform:translate(0); }
    75%  { transform:translate(-2px); }
    100% { transform:translate(0); }
}

.photo-ofi img {
	 max-width: inherit;
	 max-height: inherit;
	width: 100%;
	height: 100%;
	 object-fit: scale-down;
	 font-family: 'object-fit: scale-down;';
	 position: absolute;
	 left: 0;
	 top: 0;
}

.object-fit img{
	object-fit: cover;
	font-family: 'object-fit: cover;'; /*IE対策*/
}


div.paging { text-align: center; font-size: 90%; margin-top: 20px; line-height: 1.4em;font-family: "Outfit", serif; font-weight: 500;}
div.paging span.current,
div.paging span.paging-text{
	margin:0px 0.5px;
	color:#000;
	border:1px solid #000;
	display:inline;
	zoom:1;
	display:inline-block;
	overflow:hidden;
	text-decoration:none;
}
div.paging span.paging-text a{
	padding:5px 8.5px;
	display:block;
	color: #000;
}
div.paging span.current{
	background: #000;
	border:1px solid #000;
	color:#fff;
	zoom:1;
	padding:5px 8.5px;
	text-decoration:none;
	display:inline-block;
	cursor:pointer;
}
div.paging span.paging-text a:hover{
	background: #000;
	color:#fff;
	text-decoration:none;
	cursor:pointer;
	opacity: 1;
}

/*左右の余白*/
@media print, screen and (min-width: 576px){
	.yohaku2{
		margin-left: 16.666667%;
		margin-right: 16.666667%;
	}
}


@media print, screen and (min-width: 768px){
	.yohaku{
		margin-left: 8.333333%;
		margin-right: 8.333333%;
	}
}
@media print, screen and (min-width: 1500px){
	.yohaku{
		margin-left: 16.666667%;
		margin-right: 16.666667%;
	}
}



.ovh{overflow: hidden;}

/* 01 index
---------------------------------------------------- */
#top01{position: relative; z-index: 0; overflow: hidden;}
#top02{position: relative; z-index: 0; overflow: hidden;}
#top03{position: relative; z-index: 0; overflow: hidden;}


.top_time .box{margin-bottom: 20px;}

.tel_box{
	text-align: center;
}
.tel_box .tel{
	font-size: 180%;
	line-height: 1.4em;
	margin-top: 10px;
}
.tel_box .tel i{
	font-size: 80%;
	margin-right: 5px;
}
/*
@media screen and (min-width: 768px) and (max-width: 1199px)  {
	.top_time .box {width: 48%;}
}
*/
@media print, screen and (min-width: 768px){
	.top_time{
		display: -webkit-flex;
		display: flex;
	}
	.top_time .box:first-child {margin-right: 40px;}
}
@media print, screen and (min-width: 1200px){
	.top_time .box:first-child {margin-right: 60px;}
	.tel_box .tel{ font-size: 250%;}
}
@media print, screen and (min-width: 1600px){
	.top_time .narabi{
		display: -webkit-flex;
		display: flex;
	}
	.top_time .narabi > div:last-child {margin-left: 20px;}
	
}
@media print, screen and (min-width: 1700px){
	.top_time .box:first-child {margin-right: 100px;}
}


.top03_photo{
	max-width: 1037px;
	margin: 0 auto;
}
.top03_photo img{
	width: 70%;
	height: auto;
	margin: 0 auto;
}
@media print, screen and (min-width: 1200px){
	.top03_photo img{ width: 100%;}
}



.sns{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	justify-content: center;
}
.sns li{
	list-style: none;
	margin: 0;
}

.sns01{
	max-width: 49px;
	width: 70%;
	height: auto;
}
.sns02{
	max-width: 142px;
	width: 70%;
	height: auto;
}
@media print, screen and (min-width: 576px){
	.sns01{ width: 100%;}
	.sns02{ width: 100%;}
	.sns li{
		margin: 0 10px;
	}
}
@media print, screen and (min-width: 1200px){
	.sns li{
		margin: 0 20px;
	}
}


.nakami_navi_area .sns{
	background-color: #fff;
	padding: 10px 20px;
	border-radius: 5px;
	margin-top: 20px;
}
@media print, screen and (min-width: 576px){
	.nakami_navi_area .sns{
		padding: 20px 20px;
	}
}

/* 02 ezoumi
---------------------------------------------------- */
#cate_head,
#cate_head2,
#cate_head3,
#cate_head4,
#cate_head5,
#cate_head6,
#cate_head7,
#cate_head8,
#cate_head9,
#cate_head10,
#cate_head11,
#cate_head12,
#cate_head13,
#cate_head14,
#cate_head15,
#cate_head16,
#cate_head17,
#cate_head18,
#cate_head19,
#cate_head20,
#cate_head21,
#cate_head22,
#cate_head23,
#cate_head24,
#cate_head25,
#cate_head26,
#cate_head27,
#cate_head28,
#cate_head29,
#cate_head30{
	margin-top:-200px;
	padding-top:200px;
}
@media print, screen and (min-width: 768px){
	#cate_head,
	#cate_head2,
	#cate_head3,
	#cate_head4,
	#cate_head5,
	#cate_head6,
	#cate_head7,
	#cate_head8,
	#cate_head9,
	#cate_head10,
	#cate_head11,
	#cate_head12,
	#cate_head13,
	#cate_head14,
	#cate_head15,
	#cate_head16,
	#cate_head17,
	#cate_head18,
	#cate_head19,
	#cate_head20,
	#cate_head21,
	#cate_head22,
	#cate_head23,
	#cate_head24,
	#cate_head25,
	#cate_head26,
	#cate_head27,
	#cate_head28,
	#cate_head29,
	#cate_head30{
		margin-top:-70px;
		padding-top:70px;
	}
}
@media print, screen and (min-width: 1200px){
	#cate_head,
	#cate_head2,
	#cate_head3,
	#cate_head4,
	#cate_head5,
	#cate_head6,
	#cate_head7,
	#cate_head8,
	#cate_head9,
	#cate_head10,
	#cate_head11,
	#cate_head12,
	#cate_head13,
	#cate_head14,
	#cate_head15,
	#cate_head16,
	#cate_head17,
	#cate_head18,
	#cate_head19,
	#cate_head20,
	#cate_head21,
	#cate_head22,
	#cate_head23,
	#cate_head24,
	#cate_head25,
	#cate_head26,
	#cate_head27,
	#cate_head28,
	#cate_head29,
	#cate_head30{
		margin-top:-130px;
		padding-top:130px;
	}
}


.cate_navi {
    width: 100%;
    display: block;
	/*padding-bottom: 10px;*/
}
.cate_navi{
    font-family: "Zen Kaku Gothic New", serif;
    font-weight: 700;
    font-size: 100%;
}
.cate_navi li{
    list-style: none;
    margin: 0 10px;
}

.cate_navi a{position: relative; padding-bottom: 12px;}
.cate_navi a:link,
.cate_navi a:visited{
    text-decoration: none;
	display: inline-block;
}
.cate_navi a::after {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #000;
    bottom: 4px; /*アンダーラインが現れ始める位置（aタグの下辺からの高さ）*/
    opacity: 0;
    visibility: hidden;
    transition: 0.3s;
}
.cate_navi a:hover{opacity: 1;}
.cate_navi .navi-on a::after {
    visibility: visible;
    left: 0;
    content: '';
    width: 100%;
    height: 2px;
    background: #000;
    bottom: 9px; /*アンダーラインが現れ始める位置（aタグの下辺からの高さ）*/
    opacity: 1;
}
	.cate_navi a:hover::after {/*sp時はホバーの動きさせない*/
		visibility: visible;
		bottom: 9px;
		opacity: 1;
	}

@media only screen and (max-width: 767px){
	.cate_navi{
		margin-left: -1%;
		margin-right: -1%;
	}
	.cate_navi li{
		width: 48%;
		float: left;
		margin: 0 1%;
		padding-left: 18px;
		line-height: 1.4em;
		display:flex;
		align-items:center;
		/*height: 50px;*/
	}
	.cate_navi li:nth-of-type(2n+1) { clear: both;}
	.cate_navi li:before{
		font-family: bootstrap-icons;
		font-weight: 900;
		content: "\F231";
		margin-right: 5px;
		color: #900;
		font-size: 80%;
		margin-left: -18px;
		padding-bottom: 10px;
	}
}
@media print, screen and (min-width: 768px) {
	.cate_navi{
		display: -webkit-flex;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.fixed .cate_navi {
		padding-bottom: 0;
	}
}
@media print, screen and (min-width: 992px) {
	.cate_navi{
		font-size: 110%;
	}
	.cate_navi li{
		margin: 0 20px;
	}
}
@media print, screen and (min-width: 1200px) {
	.cate_navi{
		font-size: 130%;
	}
}
@media print, screen and (min-width: 1600px) {
	.cate_navi{
		font-size: 160%;
	}
}



#menu-wrap {
  width: 100%;
  /*height: 83px;*/
	background-color: #fff;
	padding: 30px 0;
}
#menu-wrap.pb0 {padding-bottom: 0;}
#menu-wrap.fixed{
  position: fixed;
  top: 0px;
  z-index: 10;
 padding: 15px 0 0 0;
}
@media only screen and (max-width: 575px) {
	#menu-wrap.fixed{
	 padding: 15px 60px 0 0;
		font-size: 80%;
	}
}
@media print, screen and (min-width: 768px) {
	#menu-wrap.fixed{
	 padding: 15px 0 10px 0;
	}
}
@media print, screen and (min-width: 1200px) {
	#menu-wrap {
		padding: 60px 0;
	}
	#menu-wrap.fixed{
	 padding: 15px 0 10px 0;
	}
}

/* 03 michimaro
---------------------------------------------------- */
.michimaro_time .box{margin-bottom: 30px;}
@media print, screen and (min-width: 768px){
	.michimaro_time{
		display: -webkit-flex;
		display: flex;
	}
	.michimaro_time .box:first-child {margin-right: 25px;}
}
@media print, screen and (min-width: 992px){
	.michimaro_time{
		justify-content:center;
	}
	.michimaro_time .box:first-child {margin-right: 40px;}
}
@media print, screen and (min-width: 1200px){
	.michimaro_time .box:first-child {margin-right: 60px;}
}
@media print, screen and (min-width: 1600px){
	.michimaro_time .narabi{
		display: -webkit-flex;
		display: flex;
	}
	.michimaro_time .narabi > div:last-child {margin-left: 20px;}
	
}
@media print, screen and (min-width: 1700px){
	.michimaro_time .box:first-child {margin-right: 100px;}
}



/*youtube*/
.video{
width:100%;              /*横幅いっぱいにwidthを指定*/
padding-bottom: 56.25%;  /*高さをpaddingで指定(16:9)*/
height:0px;              /*高さはpaddingで指定するためheightは0に*/
position: relative;
}
.video iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}


/* 04 drink
---------------------------------------------------- */



/* contact
---------------------------------------------------- */

/*フォームのテーブル*/
.table_form{
	width:100%;
	border-collapse:collapse;
	border-top:1px solid #fff;
	line-height: 2.0em;
}
.table_form th{
	width:100%;
	padding:10px 5px 3px 5px;
	display: block;
	color: #000;
	font-weight: 700;
}
.table_form td{
	width:100%;
	border-bottom:1px solid #fff;
	padding:3px 5px 10px 5px;
	display: block;
}
.table_form th span{/*必須*/
	font-size:70%;
	color:#fff;
	padding:5px 6px;
	float:right;
	border-radius:3px; 
	font-weight: normal;
	background-color: #900;
	line-height: 1.4em;
}
.table_form td.last {border-bottom:none;}


.table_form th.sen_none,
.table_form td.sen_none{
	border:0;
}

@media print, screen and (min-width: 768px) {
	.table_form th{
		width:35%;
		border-bottom:1px solid #fff;
		padding:15px 20px;
		vertical-align:middle;
		text-align:left;
		display:table-cell;
	}
	.table_form td{
		width:100%;
		padding:15px 20px;
		display:table-cell;
	}
	
	.table_form.sen_none .last td{padding-bottom: 10px;}
	.table_form.sen_none th{
		padding:10px 20px 0 20px;
	}
	.table_form.sen_none td{
		padding:10px 25px 0 25px;
	}

}
@media print, screen and (min-width: 992px) {
	.table_form th{width:30%;}
}

/* フォーム関係 */
.required input[type="text"], .required input[type="password"], .required select, .required textarea{border:1px solid #c36;}
input[type="checkbox"], input[type="radio"] {vertical-align:middle; margin:5px 5px 5px 0;}
input{font-size:100%;vertical-align:middle; padding:9px}
input[type="file"]{width: 99%;}
input[type="text"], select{border:1px solid #ccc; border-radius:3px; color: #000;}
input[type="email"]{color: #000;}

input:focus[type="text"]{border:1px solid #06c;}
textarea{font-size:100%;border:1px solid #ccc;width:99%; border-radius:3px; }
input,textarea{ 
  /*display: inline-block; 
  font-family: FontAwesome; */
  font-style: normal; 
  font-weight: normal; 
  line-height: 1; 
  -Webkit-font-smoothing: antialiased; 
  -moz-osx-font-smoothing: grayscale;
} 
select {padding: 9px; color: #000; }

.form-control {color: #000;}
.form-control.w50 {width:100px; display: inline-block; margin-right: 10px;}
.form-control.w300 {width:200px;}
@media (min-width: 768px) {
.form-control.w300 {width:250px;}
}


.privacy_waku{
	padding:30px 20px;
	font-size: 90%;
	background-color: #fff;
}
@media print, screen and (min-width: 992px){
	.privacy_waku{	padding:40px 20px;}
}


.privacy_scroll {
  max-height:200px;
  overflow-y: scroll;
  padding-right:10px;
	z-index: 1;
	word-break: break-all;
}
@media print, screen and (min-width: 768px) {
.privacy_scroll {max-height:400px;}
}


.midashi_box{
	border-collapse: collapse;
	border-left: 4px solid #dadada;
	padding: 5px 0 5px 15px;
}

.midashi_box2{
	border-collapse: collapse;
	border-left: 2px solid #000;
	padding: 5px 0 5px 20px;
	margin-left: 8px;
}
@media print, screen and (min-width: 992px){
	.midashi_box2{
		padding: 5px 0 5px 30px;
	}
}


.midashi_waku{
	border-collapse: collapse;
	border: 1px solid #000;
	padding: 30px 20px;
	border-radius: 20px;
}



.btn-primary{
	border-radius:5px;
	font-size: 100%;
}
.btn-primary:hover{
	background-color: #2ab4c9;
	background-image: none;
	opacity: 1;
}


.form-control {
    height: 50px;
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.42857143;
    background-image: none;
    border: 1px solid #cccccc;
    border-radius: 4px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
    -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}



/*▼メールフォームの「例」のカラー変更*/
::placeholder {
  color: #959595!important;
}
/* 旧Edge対応 */
::-ms-input-placeholder {
  color: #959595!important;
}
/* IE対応 */
:-ms-input-placeholder {
  color: #959595!important;
}


.privacy_text{
	border-collapse: collapse;
	border-left: 6px solid #dadada;
	padding: 10px 0 10px 15px;
}
.privacy_text .name{
	font-weight: 700;
	line-height: 1.4em;
	margin-bottom: 10px;
}


/* footer
---------------------------------------------------- */
footer {
	font-size: 100%;
	line-height: 1.6em;
	position: relative;
	border-collapse: collapse;
	border-top: 1px solid #000;
}
footer .in {padding: 30px 0;}


footer .foot_logo{
	max-width: 420px;
	margin: 0 auto 30px auto;
}
footer .foot_logo img{
	width: 70%;
	height: auto;
	margin: 0 auto;
}



footer a:link,
footer a:visited{
	color: #000;
}

footer .foot_navi {
	display: none;
}
@media print, screen and (min-width: 576px) {
}
@media print, screen and (min-width: 768px) {
	footer{
		text-align: left;
	}
	footer .in {padding: 50px 0;}
	footer .foot_logo img{ width: 70%;}
	
	footer .foot_navi {
		font-size: 100%;
		display: flex;
		display: -webkit-flex;
		justify-content: flex-end;
	}
	footer .foot_navi ul{
		margin-right: 30px;
	}
	footer .foot_navi li{
		list-style: none;
		margin-bottom: 5px;
		font-size: 90%;
	}
	footer .foot_navi li.title{
		font-weight: 700;
		font-size: 110%;
	}
}
@media print, screen and (min-width: 992px) {
	footer {font-size: 110%;}
	footer .foot_navi {
		font-size: 100%;
	}
}
@media print, screen and (min-width: 1200px) {
	footer {font-size: 120%;}
	footer .foot_logo{ margin: 0 auto 50px auto;}
	footer .foot_logo img{ width: 100%;}
	footer .foot_navi {
		font-size: 100%;
	}
}

/*copy*/
.copy {
	text-align: center;
	font-size: 80%;
}
@media print, screen and (min-width: 768px) {
	.copy { text-align: left;}
}


/* pagetop
---------------------------------------------------- */

/* scroll */
footer #pagetop{
	position: absolute;
	right: 0;
	bottom: 0;
	cursor: pointer;
	
}
footer #pagetop .scroll {
  position: absolute;
  bottom: 106px;
  right: min(3.91vw, calc(30px + 16px + 10px));
  writing-mode: vertical-rl;
  white-space: nowrap;
	/*
  font-family: "Oswald", sans-serif;
  font-weight: 500;
	*/
  font-size: 10px;
  color: #000;
  letter-spacing: 0.1em;
  z-index: 4;
	font-family: "Outfit", serif;
	font-weight: 700;
}
footer #pagetop .scroll::before {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  /*background: rgba(29, 32, 135, 0.5);*/
	background: none;
}
footer #pagetop .scroll::after {
  content: "";
  position: absolute;
  bottom: -106px;
  left: calc(16px + 10px);
  width: 1px;
  height: 160px;
  background: #000;
  animation: lineAnime2 3s cubic-bezier(1, 0, 0, 1) infinite;
}

@keyframes lineAnime2 {
  100% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }

  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }

  50% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }

  0% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

/*20250325*/
.box27.wakunashi {
    border: none;
	margin-top: 0;
	margin-bottom: 0;
}
.box27.wakunashi .nakami {
	padding-top: 0;
	padding-bottom: 0;
}

/*20250421*/
.medeia_index .box {margin-bottom: 30px;}
.medeia_index .box .photo {margin-bottom: 10px;}
@media print, screen and (min-width: 768px) {
	.medeia_index{
		margin-left: -1%;
		margin-right: -1%;
	}
	.medeia_index .box {
		width: 48%;
		float: left;
		margin: 0 1% 50px 1%;
	}
	.medeia_index .box:nth-of-type(2n+1) { clear: both;}
}

/*20250514*/
.gaibu{
	display: -webkit-flex;
    display: flex;
    align-items: center;
	justify-content: center;
	margin-top: 15px;
}
.gaibu li{
	list-style: none;
}
.kitanosakura{
	max-width: 150px;
	width: 100%;
	height: auto;
	min-height: 55px;
	background-color: #131313;
	border-radius: 5px;
	margin-right: 15px;
	/*display:flexで中央配置*/
   display:flex;
   align-items:center;
   justify-content:center;
}
.kitanosakura img{
	width: 100%;
	height: auto;
}



#otoiawase_form{
	margin-top:-200px;
	padding-top:200px;
}
@media print, screen and (min-width: 768px){
	#otoiawase_form{
		margin-top:-70px;
		padding-top:70px;
	}
}
@media print, screen and (min-width: 1200px){
	#otoiawase_form{
		margin-top:-130px;
		padding-top:130px;
	}
}


