@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');

html{color:#000;background:#FFF}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}fieldset,img{border:0}address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal}q:before,q:after{content:''}abbr,acronym{border:0;font-variant:normal}sup{vertical-align:text-top}sub{vertical-align:text-bottom}input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;*font-size:100%}legend{color:#000}#yui3-css-stamp.cssreset{display:none}

a:link { color: #000; }
a:visited { color: #000; }
a:hover { color: #000; }
a:active { color: #000; }


body{
/*font-family: "Noto Sans JP";*/
/*  font-family: "游ゴシック体", "YuGothic", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;*/
/*font-family: "太ゴB101", YuGothic, "Yu Gothic", "游ゴシック", "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif, Helvetica, Arial;*/
font-family: "游ゴシック体", "YuGothic", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic","Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 768px) {/*SP*/
  body{
    font-family: "游ゴシック体", "YuGothic", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic","Zen Kaku Gothic New", sans-serif;
  }
}

/*
.bold{
  font-weight: bold;
}
*/

#macy-container{
width: 1200px;
margin:0 auto;
}
@media screen and (max-width: 768px) {/*SP*/
  #macy-container{
    width:95%;
  }
}

#maincontainer {
    margin: 0 auto;
    text-align:center;
}

/*SP表示*/
@media screen and (max-width: 767.98px) {
.pcdisp{display:none !important;}
.spdisp{}
}
/*PC表示*/
@media(min-width: 768px) {
.pcdisp{}
.spdisp{display:none !important;}
}

/*********************************
LOGO
*********************************/

.logoarea{
  width: 100%;
  text-align: center;
  margin-top: 55px;
}
.logoarea img{
width:400px;
margin-bottom: 65px;
}
@media screen and (max-width: 768px) {/*SP*/
  .logoarea img{
    width:70%;
    margin-bottom: 35px;
	margin-left: 6%;
  }
}

/*********************************
MENU 
*********************************/

.menu_box{
    width: 1200px;
    margin: auto;
    text-align: center;
}
@media screen and (max-width: 768px) {/*SP*/
  .menu_box{
    width: 100%;
    margin: auto;
    text-align: center;
    }
}

.menu{
    text-align: center;
    margin-bottom: 20px;
    width: 100%;
}
.menu ul {
  display: flex;
  list-style: none;
}

.menu ul li {
  margin-left: 0.5em;
  margin-right: 0.5em;
  width:245px;
}
@media screen and (max-width: 768px) {/*SP*/
.menu ul li {
  width:50px;
}
}
.menu img{
height:20px;
}
.menu img:hover {
	opacity: 0.5 ;
	filter: alpha(opacity=50);
  -moz-opacity: 0.5;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}


/*********************************
Works
*********************************/

.gallery_box{
width: 100%;
max-width:1230px;
margin:0 auto;
}
@media screen and (max-width: 768px) {/*SP*/
  .gallery_box{
  width:auto;
  }
}


.item{
/*border:1px solid #eeeeee;*/
}

.item{
width:300px;
/*background:#111;*/
}
@media screen and (max-width: 768px) {/*SP*/
  .item{
  width:40%;
  }
}
.item img{
width:100%;
}
.item img:hover{
	transition:0.3s;/*0.3秒かけて*/
    -webkit-filter:brightness(0.7);
    -moz-filter:brightness(0.7);
    -ms-filter:brightness(0.7);
    filter:brightness(0.7);s
}


/*********************************
Works FadeIn
*********************************/
/*
.fadein_box {
animation-name:fadeInAnime;
animation-duration:3s;
animation-fill-mode:forwards;
opacity:0;
}
*/

@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}


.fadein {
  opacity : 0;
  transition : all 1s;
}
  
.fadein.active{
  opacity : 1;
}


/*----------------------------------------------
 ハンバーガーボタン
----------------------------------------------*/
.hamburger {
  display : block;
  position: fixed;
  z-index : 3;
  right : 13px;
  top   : 12px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}
.hamburger span {
  display : block;
  position: absolute;
  width   : 30px;
  height  : 2px ;
  left    : 6px;
  background : #000;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 10px;
}
.hamburger span:nth-child(2) {
  top: 20px;
}
.hamburger span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 16px;
  left: 6px;
  background :#000;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 16px;
  background :#000;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

nav.globalMenuSp {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
    background: #FFFFFF;
    opacity: 0.9;
  text-align: center;
	width: 100%;
	/*
  opacity: 0;
  transition: opacity .6s ease, visibility .6s ease;
  */
	display:none;
	height:100%;
}

nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
	width: 100%;
	padding-top: 150px;
	letter-spacing: 0.15em;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  height:30px;
  margin-bottom:50px;
  transition: .4s all;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp ul li:hover{
/*  background :#ddd;*/
}

nav.globalMenuSp ul li a {
  display: block;
  color: #fff;
  padding: 1em 0;
  text-decoration :none;
}

nav.globalMenuSp ul li img{
height:100%;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
	/*
  opacity: 100;
	height: 100%;
	*/
}

.navtitleimg{
	width: 400px;
	margin-top: 120px;
}

@media (max-width: 767px) {
	.navtitleimg{
		width: 80%;
	}

}

/*********************************
メインコンテンツ
*********************************/

.maincont{
margin:150px auto;
/*font-family: 'Lato', sans-serif;*/
letter-spacing: 0.1em;
}
@media (max-width: 767px) {
.maincont{margin:35px auto 0 auto;}
}

/*********************************
NEWS
*********************************/

.newsbox{
width: 500px;
border-top:1px solid #000000;
/*border-bottom:1px solid #000000;*/
padding:40px 20px 40px 20px;
text-align:left;
margin:0 auto 0px auto;
font-size:13px;
line-height: 1.8em;
letter-spacing:0.05em;
}
@media (max-width: 767px) {
.newsbox{
width: 80%;
font-size:11px;
}
}

/*********************************
ABOUT
*********************************/

.aboutbox{
width: 400px;
padding:20px 20px 20px 20px;
text-align:left;
margin:0 auto 100px auto;
font-size:13px;
line-height: 1.8em;
}
@media (max-width: 767px) {
.aboutbox{
width: 80%;
font-size:11px;
}
}

.about_logo{
width: 215px;
margin-bottom: 15px;
}
@media (max-width: 767px) {
.about_logo{
width: 150px;
}
}