@charset "UTF-8";

body {
  position: relative;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  color: black;
  background: white; }
  
.mt1 { margin-top: 1%; }
.mt2 { margin-top: 2%; }
.mt3 { margin-top: 3%; }
.mt4 { margin-top: 4%; }
.mt5 { margin-top: 5%; }
.mt6 { margin-top: 6%; }
.mt7 { margin-top: 7%; }
.mt8 { margin-top: 8%; }
.mt9 { margin-top: 9%; }
.mt10 { margin-top: 10%; }
.mt15 { margin-top: 15%; }
.mt20 { margin-top: 20%; }

.b { font-weight: bold; }
.center { text-align: center; }

img { width: 100%; }

a { text-decoration: none;
   color: black; } 

/* MOBILE */
@media screen and (max-width: 768px) {

.background-hack {
    z-index: -1;
    background-color: gray;
    background-image: url('img/back2.jpg');
    background-repeat: no-repeat;
    background-size: 100% auto;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
}  

p { 
   line-height: 6vw;
   font-size: 3.5vw; }
   
h1 { 
   line-height: 5vw;
   font-size: 4vw; }
   
 .pc { display: none; }
 




/*　ハンバーガーメニューボタン　*/
.hamburger {
  display : block;
  position: fixed;
  z-index : 10;
  right : 0;
  top   : 0;
  width : 13vw;
  height: 13vw;
  cursor: pointer;
  text-align: center;
  background: none;
}
.hamburger span {
  display : block;
  position: absolute;
  width   :  7vw;
  height  : 0.4vw ;
  left    : 3vw;
  background : black;
  -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: 4vw;
}
.hamburger span:nth-child(2) {
  top: 6.3vw;
}
.hamburger span:nth-child(3) {
  top: 8.5vw;
}

/* スマホメニューを開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 6.3vw;
  left: 3vw;
  background :white;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 6.3vw;
  background :white;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

/* メニュー背景　*/
nav.globalMenuSp {
  position: fixed;
  z-index : 9;
  top  : 0;
  left : 0;
  color: #fff;
  background: rgba( 20,20,20,0.6 );
  text-align: center;
  width: 100%;
  transform: translateX(-100%);
  transition: all 0.6s;
}

nav.globalMenuSp ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  transition: .4s all;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}

/*
nav.globalMenuSp ul li:hover{
  background: gray;
}
*/

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

/* クリックでjQueryで追加・削除 */
nav.globalMenuSp.active {
  opacity: 100;
  display: block;
   transform: translateX(0%);
}

#page-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  font-size: 30px;
  line-height: 0.4;
  z-index: 99;
}
#page-top a {
  background: #187ecd;
  text-decoration: none;
  color: black;
  width: 42px;
  padding: 15px 7px;
  text-align: center;
  display: block;
  border-radius: 90px;
  opacity: 0.8;
  transition: all .3s ease;
}
#page-top a:hover {
  text-decoration: none;
  opacity: .5;
}



.accordion-container .accordion-title {
  position: relative;
  padding-top: 5%;
  background: white;
  background-size: contain;
  background-repeat: no-repeat;
  width: 100%;
  height: 8vw;
  margin-left: 0%;
  font-size: 3.6vw;
  letter-spacing: 2vw;
  text-align: center;
  font-weight: bold;
  color: black;
  cursor: pointer;
}
.accordion-container .accordion-title:hover,
.accordion-container .accordion-title:active,
.accordion-title.open { 
opacity: 1;
}

.accordion-container .accordion-title::before {
  position: absolute;
  content: "+";
  top: 32%;
  right: 0%;
  width: 0%;
  height: 0%;
  background-size: cover;
  background-repeat: no-repeat;
  transform: rotate(0deg);
  transform-origin: 0% 0%;
  font-size: 4vw;
  transition: all .3s ease-in-out;
}

.accordion-container .accordion-title.open::before {
    content: "-";
}

.accordion-container .accordion-title.open::after {

}

.accordion-content {
  display: none;
  width: 110%;
  background: white;
  margin-left: -5%;
  color: black; 
}

.accordion-container {
  width: 90%;
  margin: 0 auto;
}

.aco_box {
   width: 95%;
   padding-top: 0%;
   padding-bottom: 0%;
   margin-left: 2.5%;
   border: solid 2px rgb(210,210,210); }
   
.aco_box2 {
   width: 90%;
   padding-top: 3%;
   padding-bottom: 0%;
   margin-left: 5%;  }
   
.aco_box2 p {
   margin-bottom: 3%;
   font-size: 3vw;
   line-height: 5vw; }
   
.aco_box2 h3 {
   margin-bottom: 2%;
   font-size: 3.5vw;
   line-height: 5vw; }
   
   

.header {
   background: white;
   width: 100%;
   height: 13vw; }
   
.header_logo {
   width: 70%;
   padding-top: 4%;
   padding-left: 4% }
   
.mb_menu_pad {
   height: 10vw; }
   
.mb_menu_pad2 {
   height: 5vw; }
   
.mb_menu_list {
  margin-bottom: 3%;
   font-size: 4vw; }
   
.brush {
   width: 25%; 
   position: fixed; 
   right: 5%;
   bottom: -2%;
   z-index: -1;
    }

 .top_logo {
    margin-top: 50%;
    margin-bottom: 50%;
    margin-left: 25%;
    width: 50%; }
    
.box_back {
   width: 100%;
   background: rgba(200,200,200,0.6); }
   
.box_backxx {
   width: 100%;
   background: rgba(200,200,200,0.6); }
   
.box_back2 {
   width: 100%;
   background: rgba(200,200,200,0.6); }

.box {
   width: 95%;
   margin-top: 1.5%;
   margin-left: 2.5%;
   background: white; }
   
.pad1 {
   height: 1vw; }
   
.name_box {
   width: 27%;
   margin-left: 36.5%;
   border: solid 0.6vw rgb(180,180,180); }
   

.name {
   text-align: center;
   letter-spacing: 2vw; 
   padding: 4% 4% 4% 10%; }
 
 .namexx {
   text-align: center;
   letter-spacing: 2vw;  }  
   
.pad2 {
   padding-top: 10vw; }
   
.top_photo {
   margin-top: 2.5%;
   margin-bottom: 1%;
   margin-left: 2.5%;
   width: 95%; }
   
.top_prof_h2 {
   font-size: 4vw; }
   
 .photo_back {
   margin-top: 10%;
   margin-left: 25%;
   width: 50%;  
   background: rgb(210,210,210); }
 
 .flyer_back {
   margin-top: -5%;
   margin-left: 5%;
   width: 90%;  
   background: rgb(210,210,210); }
   
.prof_box {
   width: 80%;
   margin-top: 10%;
   margin-left: 10%; }
   
.more_box  {
   margin-top: 10%; 
   width: 40%;
   margin-left: 30%;
   border: solid 0.6vw rgb(180,180,180); }
   
.more {
   padding: 2% 4% 2% 10%; }
   
.name_box2 {
   width: 70%;
   margin-left: 2%;
   background: white; }
   
.name_box3 {
   width: 75%;
   margin-left: 4%;
   position: relative;
   padding-top: 4.5vw; }
   
.slide_box {
   margin-top: -15.7%; }
   
.name2 {
   font-size: 3.4vw;
   letter-spacing: 1.6vw; 
   padding: 5% 4% 4% 6%; }
   
.pad3 {
   height: 2vw; }
   
.in_box {
   width: 95%;
   margin-left: 2.5%;
   background: rgb(210,210,210); }
   
.g_back {
   width: 100%;
   height: 90vw;
   background-size: 100%;
   background-image: url(img/g_backx.png); }
   
.g_link {
   position: absolute;
   margin-left: 62.5%;
   margin-top: -47%;
   width: 24%;
   height: 18vw;
   z-index: 2;
   background: white; }
   
.slide {
   position: relative;
   z-index: 1; }

.g_more {
   margin-left: 18%;
   margin-top: 50%; } 
   
.pad4 {
   height: 2.5vw; }
   
.news_box {
   width: 96%;
   background: white;
   margin-left: 2%;
   margin-top: 3%; }
   
.news_left {
   display: inline-block;
   width: 23.2%; 
   height: 20vw;
   vertical-align: top;
   background: #f2f2f2; }
   
.news_right {
   width: 70%;
   display: inline-block;
   margin-top: 3%;
   margin-left: 3%; }
   
.news_right h2 {
   line-height: 4.6vw;
   font-size: 3.4vw; }
   
.news_right p {
   color: rgb(100,100,100);
   line-height: 4vw;
   font-size: 2.5vw; }
   
.news_thumb_img {
   width: 100%;
   margin-left: 0%;
   margin-top: 12%; }
   
.news_thumb_img2 {
   width: 100%;
   margin-left: 0%;
   margin-top: 0%; }
   
.news_more {
   background: white;
   margin-left: 68%;
   margin-top: 4%;
   width: 30%; }


.news_more p {
   padding-left: 25%; }
   
.act_box {
   width: 96%;
   margin-left: 2%;
   margin-top: 2%;
   background: white; }
   
.act_img {
   padding-top: 2.5%;
   width: 95%;
   margin-left: 2.5%; }
   
.act_comment {
   width: 95%;
   margin-top: 3%;
   margin-left: 2.5%; }
   
.act_link {
   margin-left: 50%;
   padding-bottom: 4%;
   margin-top: 6%; }
   
.act_link2 {
   margin-left: 50%;
   padding-bottom: 4%;
   margin-top: 6%; }
 
 .bunner_box {
   width: 95%;
   padding-top: 15%;
   margin-left: 2.5%; }
   
.sns_box {
   width: 50%;
   margin-left: 37%;
   margin-top: 12%; }
   
.sns_icon {
   width: 20%;
   margin-right: 15%;
   display: inline-block; }
   
.footer_menu {
   width: 90%;
   margin-top: 10%;
   margin-left: 5%; }
   
.footer_menu p {
   letter-spacing: 1vw;
   font-size: 3vw;
   line-height: 8vw; }
   
.footer_menu_left {
   display: inline-block;
   width: 45%; }
   
.footer_menu_right {
   display: inline-block;
   vertical-align: top;
   width: 45%;
   margin-left: 4.5%; }
   
.footer_comment {
   width: 90%;
   margin-top: 10%;
   margin-left: 5%; }
   
.footer_comment  p { 
   color: rgb(50,50,50);
   line-height: 4vw;
   font-size: 2.5vw; }
   
.footer {
   background: rgba(255,255,255,0.4);
   margin-top: 6%; }
   
.footer p {
   text-align: center;
   padding: 3% 0% 3% 0%; }
   
/* ------------------------------------------- PROFILE PAGE ------------------------------------------- */

.title_box {
   background: white;
   margin-top: 2%;
   width: 55%;
   margin-left: 2.5%; }
   
.title_box h1 {
   letter-spacing: 2vw;
   padding-top: 4%; 
   padding-left: 7%;
   padding-bottom: 3%; }
   
.title_box h2 {
   letter-spacing: 2vw;
   padding-top: 4%; 
   padding-left: 7%;
   font-size: 3.6vw;
   padding-bottom: 3%; }
   
.prof_hr {
   margin-bottom: 3%; }
   
.prof_bottom_pad {
   height: 3vw; }
   
/* ------------------------------------- GALLERY PAGE -------------------------------------------- */

.title_box_gallery {
   background: white;
   margin-top: 2%;
   width: 70%;
   margin-left: 2.5%; }
   
.title_box_gallery h1 {
   letter-spacing: 2vw;
   padding-top: 4%; 
   padding-left: 7%;
   padding-bottom: 3%; }
  
.g_h2 {
   color: gray;
   font-size: 3.6vw; 
   padding-top: 5%; 
   margin-bottom: 2.5%;
   padding-left: 2.5%; }
   
.g_box {
   width: 95%;
   padding-top: 2.5%;
   margin-left: 2.5%; }
   
.g_list {
   margin-right: 2.3%;
   width: 30.5%; }
   
.g_list2 {
   margin-right: 0%;
   width: 30.5%; }
   
.g_pad {
   height: 2vw; }
   
/* ----------------------------------- NEWS PAGE -------------------------------------- */

.news_page_box {
   width: 90%;
   padding-top: 5%;
   margin-left: 5%; }
 
 .n_h1 {
   line-height: 6vw;
   font-size: 4vw; }
   
.n_day {
   margin-top: 2%;
   color: gray; }
   
.news_page_img {
   margin-top: 5%;
   margin-bottom: 0%; }
   
.n_comment p {
   word-break: break-all;
   margin-top: 5%; }  

.n_link {   
   color: gray;
   text-decoration: underline;  }
   
.n_pad {
   height: 4vw; }
   
.news_top_img_box {
   width: 100%; 
   margin-top: 5%;}
   
.n_img1 {
   width: 46%; 
   display: inline-block; }
   
.n_img2 {
   width: 46%;
   margin-left: 6%;
   display: inline-block; }
  
/* ------------------------------------- CONTACT PAGE ---------------------------------- */

.contact_box {
   width: 90%;
   margin-left: 5%;
   padding-top: 3%; }
   
.mail {
   text-align: center;
   font-size: 4vw; 
   margin-top: 5%; }
   
.henshin {
   color: gray;
   font-size: 3.3vw;
   margin-top: 7%; }
   
.henshin2 {
   color: gray;
   font-size: 3.3vw;
   margin-top: 3%; }
   
.contact_hr {
   width: 60%;
   margin-left: 20%; 
   border-top: dotted 3px gray;
   margin-top: 5%; }
 
.xp1 {
   text-align: center;
   margin-top: 3%;
   font-size: 4vw; }
 
 .xp2 {
   text-align: center;
   margin-top: 1%;
   font-size: 4vw; }
 
 .more_boxxx  {
   margin-top: 5%; 
   width: 90%;
   margin-left: 5%;
   border: solid 0.6vw rgb(180,180,180); }
   
.morexx {
   padding: 2% 0% 2% 0%;
   text-align: center; }
   
.on_img {
   margin-top: 2.5%;
   margin-bottom: 2.5%;
   margin-left: 2.5%;
   width: 95%; }
 
 }