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

/**********************************************************/
/* リセット */
/**********************************************************/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	vertical-align: baseline;
	box-sizing:border-box;
	image-rendering: -webkit-optimize-contrast;
  background-image:  -webkit-optimize-contrast;
}

main, article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}


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

ol {
	margin: 0;
	padding: 0;
}

li {
	margin: 0;
	padding: 0;
}

dl, dt, dd {
	margin: 0;
	padding: 0;
}


table{
    border-collapse: collapse; 
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}

.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

.clear {
	clear:both;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.inline_block {  
	display: inline-block;  
	*display: inline;  
	*zoom: 1;  
}

img {
  max-width: 100%;
	vertical-align:bottom;
	image-rendering: -webkit-optimize-contrast;
}

a {
	color:#444;
	text-decoration: none;
}


/*************** PC・SP共通ベース ***************/

html{
    font-size: 62.5%;
	/*scroll-behavior: smooth;*/
}

body {
	background:#FFF;
	color: #000;
  font-family: 'Noto Serif JP', serif;
	line-height:1.7;
    -webkit-font-smoothing:antialiased;
    -moz-osx-font-smoothing:grayscale;
}

hr {
	width:100%;
	/*height:4px;
	border:none;
	background:url(../images/hr.png) 0 0 repeat-x;*/
	clear:both;
	margin:40px auto;
}

hr {
	border-top: 1px solid #EEE;
	border-bottom:none;
}

.red {
	color: #F00;
}

.dancing {
  font-family: 'Dancing Script', cursive;
	font-weight:400;
}

.yugo {
    font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体";
    font-weight: bold;
}


/* ページの先頭に戻る(すべてのページ) */

.pagetop {
    display: none;
    position: fixed;
    bottom: 10px;
    right: 30px;
}
.pagetop a {
    display: block;
    text-align: center;
    text-decoration: none;
	filter:alpha(opacity=90);
    -moz-opacity: 0.9;
    opacity: 0.9;
}
.pagetop a:hover {
    display: block;
    text-align: center;
    text-decoration: none;
	filter:alpha(opacity=80);
    -moz-opacity: 0.8;
    opacity: 1;
}

/* google map */

.gmap {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
	margin-bottom:20px;
	clear:both;
}
 
.gmap iframe,
.gmap object,
.gmap embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*.gmap {
	width:520px;
	border:solid 1px #CECECE;
	margin:0 auto;
}

.gmap iframe {
	aspect-ratio:3/1;
	width:100%;
	height:100%;
	display:block;
}*/



/* ローディング - トップページ */

.logo_fadein{
	background: #333;
	position: fixed;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 9998;
}
.logo_fadein p {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: none;
	z-index: 10000;
	width: 823px;
  height: 60px;
}
.logo_fadein p img {
  width: 823px;
  height: 60px;
}


/* ローディング - 下層ページ */

#loading {
  width: 100vw;
  height: 100vh;
  transition: all 1s;
  background-color: #FFF;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}

.loaded {
  opacity: 0;
  visibility: hidden;
}

.wrapper {
  font-size: 1.6rem;
  background: #FFF;
  width: 100%;
  height: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.visuallyhidden {
  border: 0;
  clip: rect(0 0 0 0);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.clearfix:before,
.clearfix:after {
  content: " ";
  display: table;
}

.clearfix:after {
  clear: both;
}

.clearfix {
  zoom: 1;
}

html,
body {
  width: 100%;
}

.hourglass {
  display: block;
  background: #FFF;
  margin: 3em auto;
  width: 2em;
  height: 4em;
  -webkit-animation: hourglass 1s linear infinite;
          animation: hourglass 1s linear infinite;
}

.outer {
  fill: #00b7c6;
}

.middle {
  fill: #FFF;
}

@-webkit-keyframes hourglass {
  0% {
    transform: rotate(0deg);
    box-shadow: inset #00b7c6 0 0em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -4em 0 0;
  }
  20% {
    transform: rotate(0deg);
    box-shadow: inset #00b7c6 0 -2em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -2em 0 0;
  }
  100% {
    transform: rotate(180deg);
    box-shadow: inset #00b7c6 0 -2em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -2em 0 0;
  }
}

@keyframes hourglass {
  0% {
    transform: rotate(0deg);
    box-shadow: inset #00b7c6 0 0em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -4em 0 0;
  }
  20% {
    transform: rotate(0deg);
    box-shadow: inset #00b7c6 0 -2em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -2em 0 0;
  }
  100% {
    transform: rotate(180deg);
    box-shadow: inset #00b7c6 0 -2em 0 0, inset #FFF 0 -2em 0 0, inset #00b7c6 0 -2em 0 0;
  }
}







@media screen and (min-width:768px), print{

/**********************************************************/
/* ベース部分 */
/**********************************************************/

body {
	min-width:1200px;
	font-size:1.4rem;
}

.pc_none,.hidden {
	display:none !important;
}

a[href^="tel:"] {
    pointer-events: none;
}


/**********************************************************/
/*  メインエリア */
/**********************************************************/

main {
	width:100%;
	display:block;
	margin:0 auto;
	position:relative;
}

section {
	width:100%;
	position:relative;
}

.left {
	float:left;
}

.right {
	float:right;
}

.center {
	text-align:center;
}


/* 見出し・本文・リスト設定 */

main h1,
main h2,
main h3 {

}

main h3 {
}


/**********************************************************/
/* テーブル */
/**********************************************************/

#content table {
    border-left: 2px solid #AAA;
    border-top: 2px solid #AAA;
    margin: 20px 0 50px;
}

#content th {
    background: #FFF;
    border-bottom: 2px solid #AAA;
    border-right: 2px solid #AAA;
    font-weight: 500;
    /*line-height: 1.2;*/
    padding: 5px 10px;
    text-align: center;
    vertical-align: middle;
}

#content td {
	background: #FFF;
    border-bottom: 2px solid #AAA;
    border-right: 2px solid #AAA;
	font-weight: 500;
    padding: 5px 10px;
	text-align:left;
    vertical-align: middle;
}


/**********************************************************/
/* フッター */
/**********************************************************/


footer {
	background:#222;
	width:100%;
	padding:12px 0;
	color:#FFF;
}

footer .copy {
	font-size:1.2rem;
	text-align:center;
	font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体";
}




}

