@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Roboto&display=swap');
@import url('https://use.fontawesome.com/releases/v5.11.2/css/all.css');

* {
  box-sizing:border-box;
  /* tap */
  -webkit-tap-highlight-color: rgba(0,0,0,0);
  -webkit-box-shadow: none;
  box-shadow: none;
  outline: none;
}
*:focus { outline:none; }

html { overflow-x:hidden; overflow-y:scroll; font-size:62.5%; -webkit-font-smoothing: antialiased; }
body {
	width:100%; margin:0; padding:0;
	font-size:1.4em; line-height:1.7;
	color:#222;
	font-family: "メイリオ", Meiryo, "游ゴシック", YuGothic, 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", sans-serif;
	font-display:swap;
	background:#fff;
  min-width: 1000px;
}
body.fixed { position:fixed; width:100%; height:100%; }

ol, ul, li, dl, dt, dd, h1, h2, h3, h4, h5, h6, h7, form, p, figure { margin:0; padding:0; }
img { border:0; }
li { list-style-type:none; }

a { overflow:hidden; -webkit-transition:.2s linear; transition:.2s linear; }
a:link		{ color:#000; text-decoration: none; }
a:visited	{ color:#000; }
/*a:hover		{ color:#f26522; }*/
a:active	{ color:#999; }
a img { -webkit-transition:.2s linear; transition:.2s linear; }
a:hover img { opacity:0.7; }
a.underline { text-decoration:underline; }

img { max-width:100%; height:auto; vertical-align:top; }

/* clearfix */
.clearfix:after { visibility:hidden; display:block; font-size:0; content:" "; clear:both; height:0; }
* html .clearfix { zoom: 1; } /* IE6 */
*:first-child+html .clearfix { zoom: 1; } /* IE7 */

.serif { font-family: "游明朝", YuMincho, "Noto Serif JP", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", serif; }
.en { font-family: 'Roboto', sans-serif; font-weight:400; }
.bold  { font-weight:bold; }
.txt_l { text-align:left; }
.txt_c { text-align:center; }
.txt_r { text-align:right; }
.red { color:#ec404d; }
.pink { color:#ce4692; }
.orange { color:#de5c02; }

.float_l { float:left; }
.float_r { float:right; }
.pt-0 { padding-top:0; }
.pb-0 { padding-bottom:0; }

/* common */
p { margin-bottom:1em; }
p:last-child { margin-bottom:0; }
.con { position:relative; width:1000px; margin:auto; text-align:left; }
.btn a, .btn > span { display:inline-block; min-width:180px; height:40px; padding:0 20px; line-height:38px; font-size:1.3rem; font-weight:bold; text-align:center; background:#222; color:#fff; border:1px solid #222; }
.btn a:hover { opacity:0.6; }

/* header */
header { width:100%; z-index:1000; }
header .catch { padding:3px 0; font-size:1.2rem; background:#f4f4f4; }
header .header-main { padding:20px 0; background:#fff; }
header .header-main .con { display:flex; justify-content:space-between; align-items:center; }
header .header-main .link { display:flex; justify-content:flex-end; align-items:center; }
header .header-main .link div + div { margin-left:20px; }
header .header-main .link .tel { line-height:1.3; text-align:right; }
header .header-main .link .tel .en { font-size:2.4rem; letter-spacing:0.1em; }
header .header-main .link .tel small { font-size:1.2rem; }
header .header-main .link .contact a { display:inline-block; width:160px; height:40px; line-height:40px; text-align:center; color:#fff; font-weight:bold; background:#f26522; }
header .header-main .link .contact a:hover { opacity:0.6; }
header .header-main .link .social ul { display:flex; }
header .header-main .link .social li + li { margin-left:10px; }
header nav { background:#222; }
header nav a { color:#fff!important; }
header .header-fixed { display:none; }

/* footer */
footer { color:#fff; background:#222222; }
footer #pagetop { display:block; height:44px; padding:15px; text-align:center; border-bottom:1px solid #4e4e4e; }
footer #pagetop:hover { background:#444; }
footer .footer-main { padding:30px 0; }
footer .footer-main .con { text-align:center; }
footer .footer-main .logo { margin-bottom:30px; }
footer .footer-main .address { margin:0; }
footer .footer-main .address .tel { font-size:2rem; letter-spacing:0.1em; }
footer .footer-main nav { margin-top:30px; }
footer .footer-main nav ul { display:flex; justify-content:center; flex-wrap:wrap; }
footer .footer-main nav li + li { margin-left:3em; }
footer .footer-main nav a { color:#fff; }
footer .footer-main nav a:hover { color:#999; }
footer .footer-bottom { padding:20px 0; border-top:1px solid #4e4e4e; }
footer .footer-bottom .con { display:flex; justify-content:space-between; }
footer .footer-bottom .subnav { display:flex; }
footer .footer-bottom .subnav a { color:#fff; font-size:1.2rem; }
footer .footer-bottom .copy { color:#656565; font-size:1.2rem; }

/* contents共通 */
.event-list { display:flex; justify-content:flex-start; flex-wrap:wrap; }
.event-list li { width:31%; margin-right:3.5%; }
.event-list li a { display:block; font-weight:bold; }
.event-list .img { height:0; margin-bottom:15px; padding-top:56%; background:#ccc center/cover no-repeat; position:relative; }
.event-list .img:after { content:""; display:block; width:100%; height:100%; background:rgba(0,0,0,0.3); position:absolute; top:0; left:0; opacity:0; transition:.3s; }
.event-list li a:hover .img:after { opacity:1; }

@media (max-width: 1000px) {
	html { font-size:58%; }
  body { min-width:320px; }
  .con { width:100%; padding:0 5%; }
}
@media (min-width: 801px) {
  .sp { display:none; }
	a[href^="tel:"] { pointer-events:none; }

	header #logo a { display:flex; height:100%; justify-content:flex-start; align-items:center; }
	header #btn_menu { display:none; }
	header nav .gnav { display:flex; }
	header nav .gnav li { margin-right:3em; }
	header nav .gnav li:last-child { margin:0; }
	header nav .gnav .sp { display:none; }
	header nav .gnav li a { display:inline-block; padding:18px 0; vertical-align:top; position:relative; }
	header nav .gnav li a:after { content:""; display:block; width:100%; height:4px; background:#5b8d36; position:absolute; left:0; bottom:0; transform-origin:right top; transform:scale(0, 1); transition:transform .3s; }
	header nav .gnav li.active a:after,
	header nav .gnav li.hover a:after,
	header nav .gnav li a:hover:after { transform-origin:left top; transform:scale(1, 1); }

	header.scroll { position:fixed; }
	header.scroll .catch, header.scroll .header-main { display:none; }
	header.scroll nav .con { display:flex; justify-content:space-between; align-items:center; }
	header.scroll nav .gnav li a { padding:15px 0; }
	
	header .header-fixed { display:block; height:60px; position:fixed; left:0; width:100%; z-index:1000; transition:.5s top ease,.5s opacity ease; top:-60px; opacity:0; }
	header .header-fixed.show { top:0; opacity:1; }
	header .header-fixed .con { display:flex; justify-content:space-between; align-items:center; }
	header .header-fixed h1 { display:block; padding:5px 0; }
	header .header-fixed h1 a { display:flex; align-items:center; height:100%; }
	
	.event-list li:nth-child(3n) { margin-right:0; }
	.event-list li:nth-child(n+4) { margin-top:4%; }

	/* animation */
  .fadein { transition:1s; opacity:0; -webkit-backface-visibility:hidden; backface-visibility:hidden; }
  .fadein.inview-show { opacity:1; }
  .fadeup { transition:1s; -webkit-transform:translate(0,10px); transform:translate(0,10px); opacity:0; -webkit-backface-visibility:hidden; backface-visibility:hidden; }
  .fadeup.inview-show { -webkit-transform:translate(0,0); transform:translate(0,0); opacity:1; }
  .fadein_list > li { opacity:0; }
  .slidein_list > li { opacity:0; margin-left:-15px; }

}
@media (max-width: 800px) {
	.pc { display:none; }

	header { position:fixed; top:0; left:0; transition:1s; }
	header .catch, header .header-main .link { display:none; }
	header .header-main { height:50px; padding:5px 0; position:relative; z-index:1002; }
	header .header-main .con { padding:0 20px; }
	header .header-main .con > div { display:flex; justify-content:flex-end; }
	header .header-main #logo img { width:100px; vertical-align:sub; }
	header #btn_menu { width:25px; height:40px; }
	header #btn_menu a { display:flex; width:100%; height:100%; justify-content:center; align-items:center; }
	header #btn_menu .btn_wrap { display:block; width:25px; height:20px; position:relative; }
	header #btn_menu .btn_wrap span { display:block; width:25px; height:2px; background:#333; position:absolute; transition:.2s; }
	header #btn_menu .btn_wrap span:nth-child(1) { top:0; left:0; }
	header #btn_menu .btn_wrap span:nth-child(2) { top:9px; left:0; }
	header #btn_menu .btn_wrap span:nth-child(3) { bottom:0; left:0; }
	header.open #btn_menu .btn_wrap span:nth-child(1) { -webkit-transform: translateY(9px) rotate(-45deg); transform: translateY(9px) rotate(-45deg); }
	header.open #btn_menu .btn_wrap span:nth-child(2) { opacity:0; }
	header.open #btn_menu .btn_wrap span:nth-child(3) { -webkit-transform: translateY(-9px) rotate(45deg); transform: translateY(-9px) rotate(45deg); }
	
	header nav { display:none; position:fixed; top:0; left:0; width:100%; height:100%; padding-top:50px; overflow:auto; z-index:1001; background:#222; }
	header nav .con { height:100%; padding:0; }
	header nav .con > div { height:100%; display:flex; justify-content:center; align-items:center; }
	header nav .gnav { width:100%; }
	header nav .gnav li a { display:block; padding:4px 15px; text-align:center; font-size:16px; }
	/*header nav .gnav li a:hover, header nav .gnav li.active a { background:#5b8d36; color:#fff; }*/
	header nav .gnav li.contact, header nav .gnav li.tel { margin-top:10px; padding:0 5%; }
	header nav .gnav li.contact a, header nav .gnav li.tel a { height:84px; padding:5px; line-height:1.1; display:flex; justify-content:center; align-items:center; }
	header nav .gnav li.tel a { border:1px solid #fff; }
	header nav .gnav li.tel .en { font-size:24px; letter-spacing:0.1em; }
	header nav .gnav li.tel a:hover { background:#999; }
	header nav .gnav li.contact a { font-weight:bold; background:#f26522; }
	header nav .gnav li.contact a small { font-size:10px; font-weight:normal; }
	header nav .gnav li.social { display:flex; justify-content:center; padding:15px; }
	header nav .gnav li.social a { display:inline; margin:0 10px; padding:0; }
	header nav .gnav li.social a:hover { background:none; }
	
	footer .footer-main nav { display:none; }
	
	.event-list li { width:48%; margin-right:4%; }
	.event-list li:nth-child(2n) { margin-right:0; }
	.event-list li:nth-child(n+3) { margin-top:4%; }

}
@media (max-width: 600px) {
	html { font-size:54%; }
}
@media (max-width: 480px) {
}
