@charset "UTF-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700&display=swap');

.forpc, .nosp{ display: inline-block; }
.nopc, .forsp{ display: none; }
@media (max-width: 800px) {
  .nopc, .forsp{ display: inline-block; }
  .forpc, .nosp{ display: none; }
}

.mgt0{margin-top:0!important}
.mgt5{margin-top:5px!important}
.mgt10{margin-top:10px!important}
.mgt20{margin-top:20px!important}
.mgt30{margin-top:30px!important}
.mgt40{margin-top:40px!important}
.mgt50{margin-top:50px!important}
.mgt60{margin-top:60px!important}
.mgt80{margin-top:80px!important}
.mgt100{margin-top:100px!important}
.mgb0{margin-bottom:0!important}
.mgb5{margin-bottom:5px!important}
.mgb10{margin-bottom:10px!important}
.mgb15{margin-bottom:15px!important}
.mgb20{margin-bottom:20px!important}
.mgb30{margin-bottom:30px!important}
.mgb40{margin-bottom:40px!important}
.mgb50{margin-bottom:50px!important}
.mgb60{margin-bottom:60px!important}
.mgb80{margin-bottom:80px!important}
.mgb100{margin-bottom:100px!important}
.pdt0{margin-top:0!important}
.pdt0{padding-top:0!important}
.pdt10{padding-top:10px!important}
.pdt20{padding-top:20px!important}
.pdt30{padding-top:30px!important}
.pdt40{padding-top:40px!important}
.pdt50{padding-top:50px!important}
.pdt60{padding-top:60px!important}
.pdb0{margin-bottom:0!important}
.pdb0{padding-bottom:0!important}
.pdb10{padding-bottom:10px!important}
.pdb15{padding-bottom:15px!important}
.pdb20{padding-bottom:20px!important}
.pdb30{padding-bottom:30px!important}
.pdb40{padding-bottom:40px!important}
.pdb50{padding-bottom:50px!important}
.pdb60{padding-bottom:60px!important}
.pdb100{padding-bottom:200px!important}
@media (max-width: 800px) { .pdb100{padding-bottom:80px!important} }
.pd10{padding:10px;}
.pd20{padding:20px!important;}
.pd30{padding:30px;}
.pdl10{padding-left:10px!important;}
.pdlr3{padding-right:3%; padding-left:3%;}
.pdlr5{padding-right:5%; padding-left:5%;}
.pdl0{padding-left:0!important;}
.pdr0{padding-right:0!important;}
.mgl0{margin-left:0!important;}
.mgr0{margin-right:0!important;}

.arrow{ position: relative; display: block; text-align:center; margin:auto; padding-top:30px; }
.arrow::before, .arrow::after{ position: absolute; top: 0; bottom: 0; left: 0; right:0; margin: auto; content: ""; vertical-align: middle; }
.arrow::before{ width: 16px; height: 16px; border-top: 1px solid #707070; border-right: 1px solid #707070; -webkit-transform: rotate(135deg); transform: rotate(135deg); }


  body { font-family: 'Noto Sans JP', sans-serif; }
  .font_en { font-family:"Montserrat"; }
  div.bg-video-wrap { position: fixed; overflow: hidden; z-index: 1 !important; width: 100%; height: 100vh; background: url("../../img/video_bg.jpg") no-repeat center center/cover; }
  video { min-width: 100%; min-height: 100vh; z-index: 1; position: absolute; z-index: -1;top: 50%;left: 50%; transform: translate(-50%, -50%); }
  .overlay { width: 100%; height: 100vh; position: absolute; top: 0; left: 0; /***background-image: linear-gradient(45deg, rgba(0,0,0,.3) 50%, rgba(0,0,0,.7) 50%); background-size: 3px 3px;***/ z-index: 2; }

  div.g_nav{ position:fixed; z-index: 1000; top:20px; right:10px; }
  div.g_nav > div{ display: inline-block; margin-right:10px; }
  div.g_nav > div a{ color:#020202; font-weight: bold; font-size:16px; }
  img.insta_icon{ width:30px; vertical-align: middle; margin-left:10px; }

  h1 { text-align: center; position: absolute; top: 0; bottom: 0; left: 0; right: 0; margin: auto; z-index: 3; width: 100%; height: 280px; }
  h1 > img { width:70%; max-width: 560px;  fill: #fff; } 
  h1 span.title_en{ font-family:"Montserrat"; color:#fefefe; font-size:40px; }


  div.wrap { position:relative; z-index: 100; padding-top:100vh; }
  div.wrap div.white_bg{ background-color:#fefefe; margin-top:-3px; }
  div.wrap div.gra_bg{ background: linear-gradient(90deg, rgba(248,236,248,0.8) 0%, rgba(242,221,255,0.8) 35%, rgba(203,231,255,0.8) 100%); }

  div.scroll_img{ position: absolute; left: 50%; transform: translateX(-50%); margin-top:-150px; font-weight: bold; letter-spacing: 0.1em; font-size:14px; }
  p.v_line_fix{ margin:30px auto;  width: 1px; height: 160px; background-color: #000; }
  div.wrap div.copy_txt{ font-weight: bold; font-size: 20px; text-align:center; letter-spacing: 0.2em; line-height: 2.2; padding-top:150px; padding-bottom:50px; }
  div.wrap div.copy_txt > p{ margin-bottom:40px; }
  
  
  div.about_title{ font-weight: bold; text-align:center; margin:auto;  margin-top:-30px; margin-bottom:50px; }
  div.about_title img{ width: 40%; max-width: 400px; }
  div.about_content{ font-weight: bold; font-size: 18px; text-align:center; letter-spacing: 0.1em; line-height: 2; margin-bottom:30px; }

  div.what_title{ font-weight: bold; text-align:center; margin:auto; letter-spacing: 0.1em; }
  div.what_title > span.font_b{ font-size:70px; line-height: 1.2; }
  
  div.icon_block{ margin:30px auto; text-align:center; }
  div.icon_block div.icon_bg { display: inline-block; vertical-align: top; background-color:#fefefe; text-align:center; font-size:14px; font-weight: bold; letter-spacing: 0.1em; height:200px; width:200px; border-radius:50%; text-align:center; margin:5px; line-height:1.2; }
  div.icon_block div.icon_bg > img{ width: 40%; padding:20% 10% 10%; }

  div.icon_block02{ text-align:center; padding-bottom:30px; }
  div.icon_block02 > div{ display: inline-block; width:20%; max-width: 240px; vertical-align: top; }
  div.icon_block02 > div > a{ color:#020202; letter-spacing: 0.1em; }
  div.icon_block02 > div > a div.icon_bg { display: inline-block; vertical-align: top; background-color:#f2f2f2; text-align:center; font-size:14px; font-weight: bold; letter-spacing: 0.1em; height:160px; width:160px; border-radius:50%; text-align:center; margin:5px; margin-bottom:20px; line-height:1.2; }
  div.icon_block02 > div > a div.icon_bg > img{ width: 50%; padding:24% 10% 10%; }

  div.content_block{ text-align:center; margin:30px auto 0; }
  div.content_block p.date_txt{ font-size:40px; font-weight: 600; margin-top:50px; margin-bottom:50px; letter-spacing: 0.1em; }
  div.content_block p.date_txt > span.font_b{ font-size:60px; letter-spacing: 0 !important; }
  div.content_block p.txt01{ font-weight: 400; font-size: 18px; text-align:center; letter-spacing: 0.1em; line-height: 2; }
  div.content_block p.txt02{ font-weight: 600; font-size: 16px; text-align:center; letter-spacing: 0.1em; line-height: 2; }

  a.link_button{ font-weight: 600; font-size: 16px; text-align:center; letter-spacing: 0.1em; line-height: 2; color:#020202; border:solid 2px #020202; display: block; width:60%; max-width:360px; margin:auto; padding:10px; margin-top:20px; }
  a.link_button:hover{ cursor: pointer; background-color:#020202; color:#fefefe; }
  a.txt_link{ color:#020202; text-decoration: underline; }

  div.photo_block{ margin:50px auto; text-align:center; }
  div.photo_block > img{ width:90%; max-width:1200px; }

  div.txt_block{ width:80%; max-width:900px; margin:auto; padding-bottom:50px; }
  div.txt_block > p{ font-weight: 500; font-size: 15px; text-align:center; letter-spacing: 0em; line-height: 2; text-align:left; }

  div.txt_block > p.subtitle{ text-align:center; font-size: 32px; font-weight: 500; letter-spacing: 0.1em; padding-top:30px; padding-bottom:20px; }

  div.colmun2_txt{ margin:20px auto; border-top:solid 1px #020202; border-bottom:solid 1px #020202; padding-top:20px; padding-bottom:20px; }
  div.colmun2_txt > div{ display: inline-block; width:47%; margin:auto; padding-left:2%; }
  div.colmun2_txt p.txt01{ font-weight: 600; letter-spacing: 0.1em; line-height: 1.6; }
  div.colmun2_txt p.txt02{ font-weight: 300; letter-spacing: 0.1em; line-height: 1.6; }



  div.sampleset_block{ margin: 50px auto; text-align: center; }
  div.sampleset_block > div{ display: inline-block; width:32%; max-width: 480px; text-align:center; vertical-align: top; margin-left: 2%; margin-right:2%; }
  div.sampleset_block .maru_txt{ border:solid 1px #000; height:60px; width:60px; border-radius:50%; line-height:55px; text-align:center; font-size:32px; margin:auto; }
  div.sampleset_block .maru_txt > span.font_en{ font-weight: 10 !important; }
  div.sampleset_block h2{ font-size:40px; font-weight: normal; line-height: 1.4; margin-top:20px; margin-bottom:30px; }
  div.sampleset_block .line_block{ font-size:18px; font-weight: bold; letter-spacing: 0.1em; border-top:solid 1px #000; border-bottom:solid 1px #000; padding-top:15px; padding-bottom:15px; margin-bottom:15px; }
  div.sampleset_block .sample_txt{ font-size:16px; font-weight: normal; letter-spacing: 0.1em; text-align:left; line-height: 1.5; margin-bottom:30px; }

  div.side_logo{ position: fixed; width:600px; z-index: 1000; top:45vh; left:-600px; transform: rotate(90deg); transition: all 1s; }
  div.side_logo.isActive{  left:-210px; transition: all 1s; }


  section.modalArea{display:none;position:fixed;z-index:2000;top:0;left:0;width:100%;height:100%}
  .modalBg{width:100%;height:100%; background: radial-gradient(rgba(145, 193, 234, 1),rgba(248, 236, 248, 0.9));}
  .modalWrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70%;max-width:800px;padding:30px 30px; color:#020202; }
  .closeModal{position:absolute;top:.5rem;right:1rem;cursor:pointer; font-size:42px;}
  
  div.modalContents > p.txt02{ font-weight: bold; font-size:16px; letter-spacing: 0.1em; line-height: 1.6; text-align:center;  margin-top:20px; margin-bottom:20px; }
  div.modalContents > form{ font-weight: bold; font-size:16px; letter-spacing: 0.1em; text-align:center; }
  div.modalContents > form .bottom_line{ border-bottom:solid 1px #020202; width:70%; max-width:500px; margin:auto; padding-bottom:10px; }


  div.modalContents > form input[type="password"]{ font-size:18px; border:none; background-color:rgba(255,255,255,0); padding:7px 20px; margin-left:20px; width:12em;  }
  div.modalContents > form input[type="button"]{ display: block; margin:auto; margin-top:30px; background-color:rgba(255,255,255,0); font-weight: 600; font-size: 16px; text-align:center; letter-spacing: 0.1em; line-height: 2; color:#020202; border:solid 2px #020202; display: block; width:60%; max-width:360px; margin:auto; padding:10px; margin-top:40px; border-radius: 0; }
  div.modalContents > form input[type="button"]:hover{ cursor: pointer; }
  *:focus { outline: none; }

  div#caution{ color:#b71f1f; font-weight: normal; padding-top:10px; }
  div.display_none{ display: none; }
  div.putOut{ display: block; }




  #navArea{ position: fixed; top:20vh; z-index: 10000; }
  nav { display: none; width:100%; position: fixed; z-index: 10001; top: 10vh; left: -400px; bottom: 0; overflow-x: hidden; overflow-y: auto; -webkit-overflow-scrolling: touch;transition: all 1s;opacity: 0;}
  .open nav { left: 0; right:0; margin:auto; opacity: 1; }
  nav .inner { padding: 25px;  margin-right:15%; }
  nav .inner ul { list-style: none; margin: 0; padding: 0; }
  nav .inner ul li { position: relative; text-align:right; font-size:15px; font-weight: bold; letter-spacing: 0.1em;}
  nav .inner ul li a { display: block; color:#fefefe;; font-size: 14px; padding: 1em; text-decoration: none; transition-duration: 0.2s;}
  nav .inner ul li a:hover { text-decoration: underline; }
  nav div.nav_logo{ width:60%; max-width:400px; text-align:center; margin:auto; margin-top:30px; }

  .toggle_btn { display: none; position: fixed; top: 15px; right: 15px; width: 30px; height: 30px; transition: all .5s; cursor: pointer; z-index: 3; }
  .toggle_btn span { display: block; position: absolute; left: 0; width: 30px; height: 1px; background-color: #333; border-radius: 4px; transition: all 1s; }
  .toggle_btn span:nth-child(1) { top: 4px; }
  .toggle_btn span:nth-child(2) { top: 14px; }
  .toggle_btn span:nth-child(3) { bottom: 4px; }
  .open .toggle_btn span { background-color: #fff; }
  .open .toggle_btn span:nth-child(1) { -webkit-transform: translateY(10px) rotate(-315deg); transform: translateY(10px) rotate(-315deg); }
  .open .toggle_btn span:nth-child(2) { opacity: 0; }
  .open .toggle_btn span:nth-child(3) { -webkit-transform: translateY(-10px) rotate(315deg); transform: translateY(-10px) rotate(315deg); }

  /*
  @media (max-width: 800px) { .toggle_btn {display: block;} nav { display: block;} }
  */
  #mask { display: none; transition: all 1s; -webkit-overflow-scrolling: touch;transition: all 1s;opacity: 0; }
  .open #mask { display: block; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(rgba(145,193,234,1) 0%, rgba(242,221,255,1) 95%, rgba(248,236,248,1) 100%); opacity: 1; z-index: 2; cursor: pointer;  transition: all 1s; }






  @media (max-width: 800px) {
    h1 { height:160px; }
    h1 span.title_en{ font-size:21px; }
    div.wrap { padding-top:90vh; }
    div.wrap div.copy_txt{ padding-top:100px; }

    /*div.g_nav{ display: none !important; }*/
    div.side_logo{ display: none !important; }

    div.about_title{ margin-top:0; }

    div.wrap div.copy_txt, div.about_content{ font-size:14px; }
    div.what_title{ font-size:14px; }
    div.what_title > span.font_b{ font-size:26px; }
    div.icon_block div.icon_bg { width:140px; height:140px; font-size:13px; }
    div.icon_block div.icon_bg > img{ width: 40%; padding:15% 5% 7%; }

    div.icon_block02 > div{ width:40%; font-size:12px; font-weight: bold; letter-spacing: 0; }
    div.icon_block02 > div > a div.icon_bg { width:120px; height:120px; }

    div.content_block{ margin-bottom:30px; }
    div.content_block p.date_txt{ font-size:18px; line-height: 1.6; margin-top:30px; margin-bottom:30px; }
    div.content_block p.date_txt > span.font_b{ font-size:26px; }
    div.content_block p.txt01, div.content_block p.txt02{ font-size: 13px; }

    a.link_button{ font-size:14px;}

    div.photo_block{ margin:30px auto; }

    div.txt_block > p{ font-size:13px; }
    div.txt_block > p.subtitle{ font-size:16px; }

    div.colmun2_txt{ padding-top:5px; padding-bottom:5px; }
    div.colmun2_txt > div{ width:96%; margin:10px auto; }
    div.colmun2_txt p.txt01, div.colmun2_txt p.txt02{ font-size:13px; }
    
    div.txt_block, div.about_content{ width:90%; margin:auto;}


    div.sampleset_block{ margin:30px auto; }
    div.sampleset_block > div{ display: block; width:86%; max-width:86%; margin:auto; }
    div.sampleset_block .maru_txt{ margin-top:40px; }
    div.sampleset_block h2{ font-size:18px; }
    div.sampleset_block .line_block{ font-size:15px; }
    div.sampleset_block .sample_txt{ font-size:13px; }


    div.modalContents > p.txt02{ font-size:13px; }
    div.modalContents > form{ font-size:13px; }
    div.modalContents > form .bottom_line{ border-bottom:solid 1px #020202; width:90%; max-width:90%; margin-top:30px; }
    div.modalContents > form input[type="password"]{ font-size:15px;  padding:5px 5%; margin-left:0; width:80%; margin-top:20px; }
    div.modalContents > form input[type="button"]{ font-size: 13px; width:80%; padding:10px; margin-top:30px; }
    .closeModal{position:absolute;top:-2rem;right:1rem;cursor:pointer; font-size:42px;}
  }



