 @charset "UTF-8";
 
 /* ------------- PC ---------------- */
 @media screen and (min-width: 769px) { 
 
 .mb { display: none; }
 
 .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;
}  
 
a:hover {
   opacity: 0.5; }
 
 
  p {
     font-size: 1.6vw;
      line-height: 3vw; }
      
h1 { 
   line-height: 2vw;
   font-size: 2.2vw; }

.accordion-container .accordion-title {
  position: relative;
  padding-top: 5%;
  background: white;
  background-size: contain;
  background-repeat: no-repeat;
  width: 100%;
  height: 4vw;
  margin-left: 0%;
  font-size: 1.6vw;
  letter-spacing: 1.6vw;
  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: 30%;
  right: 0%;
  width: 0%;
  height: 0%;
  background-size: cover;
  background-repeat: no-repeat;
  transform: rotate(0deg);
  transform-origin: 0% 0%;
  font-size: 2vw;
  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: 1.4vw;
   line-height: 3vw; }
   
.aco_box2 h3 {
   margin-bottom: 0%;
   font-size: 1.8vw;
   line-height: 5vw; }   

.header {
   background: white;
   width: 100%;
   position: fixed;
    z-index: 100;
   height: 4vw; }
   
.header_logo {
   width: 100%;
   padding-top: 5%;
   padding-left: 7% }

.pc_header_left {
   width: 25%;
   vertical-align: top;
   display: inline-block; }
   
.pc_header_right {
   width: 65%;
   margin-left: 9%;
   display: inline-block; }
   
.pc_header_right p {
   margin-top: 1%;
   margin-left: 25%;
   letter-spacing: 0.4vw;
   font-size: 1.2vw; }
   
.mb_menu_pad {
   height: 10vw; }
   
.mb_menu_pad2 {
   height: 5vw; }
   
.mb_menu_list {
  margin-bottom: 3%;
   font-size: 4vw; }
   
.brush {
   width: 10%; 
   position: fixed; 
   right: 5%;
   bottom: -2%;
   z-index: -1;
    }
    
.pc_box {
   width: 60%;
   margin-left: 20%; }
    


 .top_logo {
    margin-top: 25%;
    margin-bottom: 20%;
    margin-left: 35%;
    width: 30%; }
    
.box_back {
   width: 100%; }

.box {
   width: 95%;
   margin-top: 1.5%;
   margin-left: 2.5%;
   background: white; }
   
.pad1 {
   height: 0.6vw; }
   
.name_box {
   width: 27%;
   margin-left: 36.5%;
   border: solid 0.4vw rgb(180,180,180); }
   
.name {
   text-align: center;
   letter-spacing: 1.6vw; 
   padding: 5% 4% 5% 10%; }
   
.pad2 {
   padding-top: 5vw; }
   
.top_photo {
   margin-top: 2.5%;
   margin-bottom: 1%;
   margin-left: 2.5%;
   width: 95%; }
   
.top_prof_h2 {
   font-size: 2vw; }
   
 .photo_back {
   margin-top: 10%;
   margin-left: 25%;
   width: 50%;  
   background: rgb(210,210,210); }
   
.prof_box {
   width: 80%;
   margin-top: 10%;
   margin-left: 10%; }
   
.more_box  {
   margin-top: 10%; 
   width: 35%;
   margin-left: 32.5%;
   border: solid 0.4vw rgb(180,180,180); }
   
.more {
   padding: 2% 4% 2% 15%; }
   
.name_box2 {
   width: 80%;
   margin-left: 2%;
   background: white; }
   
.name_box3 {
   width: 80%;
   margin-left: 2%;
   position: relative;
   padding-top: 4.5vw; }
   
.slide_box {
   margin-top: -15%; }
   
.name2 {
   font-size: 1.8vw;
   letter-spacing: 1vw; 
   padding: 1% 4% 4% 6%; }
   
.name2xx {
   padding-top: 4%; }
   
.pad3 {
   height: 2vw; }
   
.in_box {
   width: 95%;
   margin-left: 2.5%;
   background: rgb(210,210,210); }
   
.g_back {
   width: 100%;
   height: 53vw;
   background-size: 100%;
   background-image: url(img/g_backx.png); }
   
.g_link {
   position: absolute;
   margin-left: 38%;
   margin-top: -30%;
   width: 16.5%;
   height: 18vw;
   z-index: 10;
   background: none; }
   
.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: 30%; 
   height: 12vw;
   vertical-align: top;
   background: #f2f2f2; }
   
.news_right {
   width: 60%;
   display: inline-block;
   margin-top: 3%;
   margin-left: 3%; }
   
.news_right h2 {
   line-height: 2.8vw;
   font-size: 1.8vw; }
   
.news_right p {
   line-height: 2.6vw;
   font-size: 1.3vw; }
   
.news_thumb_img {
   width: 90%;
   margin-left: 5%;
   margin-top: 5%; }
   
.news_thumb_img2 {
   width: 70%;
   margin-left: 15%;
   margin-top: 3%; }
   
.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: 65%;
   padding-bottom: 4%;
   margin-top: 6%; }
   
.act_link2 {
   margin-left: 65%;
   padding-bottom: 4%;
   margin-top: 6%; }
 
 .bunner_box {
   width: 80%;
   margin-top: 5%;
   margin-left: 13%; }
   
.bunner_box_img {
   width: 43%;
   margin-left: 2%;
   display: inline-block; }
   
.sns_box {
   width: 30%;
   margin-left: 40%;
   margin-top: 5%; }
   
.sns_icon {
   width: 20%;
   margin-right: 15%;
   display: inline-block; }
   
.footer_menu {
   width: 90%;
   margin-top: 5%;
   margin-left: 5%; }
   
.footer_menu p {
   letter-spacing: 0.6vw;
   font-size: 1.4vw;
   line-height: 4vw; }
   
.footer_menu_left {
   display: inline-block;
   width: 30%; }
   
.footer_menu_right {
   display: inline-block;
   vertical-align: top;
   width: 45%;
   margin-left: 4.5%; }
   
.footer_comment {
   width: 90%;
   margin-top: 5%;
   margin-left: 5%; }
   
.footer_comment  p { 
   color: rgb(50,50,50);
   line-height: 2.6vw;
   font-size: 1.2vw; }
   
.footer {
   background: rgba(255,255,255,0.4);
   margin-top: 3%; }
   
.footer p {
   text-align: center;
   padding: 1% 0% 1% 0%; }
   
/* ------------------------------------------- PROFILE PAGE ------------------------------------------- */

.title_box {
   background: white;
   margin-top: 1%;
   width: 55%;
   margin-left: 2.5%; }
   
.title_box h1 {
   letter-spacing: 1.5vw;
   padding-top: 3%; 
   padding-left: 7%;
   font-size: 1.6vw;
   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: 1vw;
   padding-top: 4%; 
   padding-left: 7%;
   font-size: 2vw;
   padding-bottom: 3%; }
  
.g_h2 {
   color: gray;
   font-size: 2vw; 
   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 -------------------------------------- */

.news_page_box {
   width: 90%;
   padding-top: 5%;
   margin-left: 5%; }
 
 .n_h1 {
   line-height: 3vw;
   font-size: 2vw; }
   
.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: 2vw; 
   margin-top: 5%; }
   
.henshin {
   color: gray;
   font-size: 1.5vw;
   margin-top: 7%; }
   
.henshin2 {
   color: gray;
   font-size: 1.5vw;
   margin-top: 3%; }
   
.contact_hr {
   width: 60%;
   margin-left: 20%; 
   border-top: dotted 3px gray;
   margin-top: 5%; }
      
 .flyer_back {
   margin-top: -5%;
   margin-left: 5%;
   width: 90%;  
   background: rgb(210,210,210); }
   
.xp1 {
   text-align: center;
   margin-top: 3%;
   font-size: 1.8vw; }
 
 .xp2 {
   text-align: center;
   margin-top: 1%;
   font-size: 1.8vw; }
 
 .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%; }
      
      
     }