@charset "utf-8";
@media screen and (max-width: 1536px) {}
@media screen and (max-width: 1280px) {}
@media screen and (max-width: 1024px) {}
@media screen and (max-width: 767px) {}
/* ==============================
   common
============================== */
html {
  scroll-behavior: smooth;
}
body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.4rem;
  color: #333;
  background: url("../images/bg_back01.png") repeat, #f0eff3;
}
.Afacad {
  font-family: 'Afacad', sans-serif;
  font-weight: 400 !important;
}
.Noto {
  font-family: 'Noto Sans JP', sans-serif;
}
.pc {
  display: block !important;
}
.pci {
  display: inline-block !important;
}
a .pci {
  text-decoration: underline;
}
.sp {
  display: none !important;
}
.spi {
  display: none !important;
}
.spt {
  display: none !important;
}
a {
  text-decoration: underline;
  transition: 0.5s;
}
a:hover {
  opacity: 0.7;
}
a img {
  transition: 0.5s;
}
a img:hover {
  opacity: 0.5;
}
.attention {
  color: #FF0000;
}
img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
  .pci {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .spi {
    display: inline-block !important;
  }
  .spt {
    display: table-cell !important;
  }
  a {
    text-decoration: underline;
    transition: 0s;
  }
  a:hover {
    opacity: 1;
  }
  a img {
    transition: 0s;
  }
  a img:hover {
    opacity: 1;
  }
}
/* ==============================
   prts
============================== */
.wh {
  color: #FFFFFF;
}
.bk {
  color: #333;
}
.h1txt {
  font-size: 3.6rem;
  line-height: 1.2;
  padding: 0 0 0 35px;
  background: url("../images/ico_logo01.png") no-repeat left center;
}
.h1txt a {
  color: #333;
  text-decoration: none;
}
.h2txt {
  font-size: 6.5rem;
  line-height: 1.2
}
p {
  padding: 0 0 1em;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .h1txt {
    font-size: 2.0rem;
    font-weight: 700;
    line-height: 1.2;
    padding: 0 0 0 22px;
    background: url("../images/ico_logo01.png") no-repeat left center/15px auto;
  }
  .h2txt {
    font-size: 5.5rem;
    line-height: 1.2
  }
}
/* ==============================
   mainarea
============================== */
#mainarea {
  height: 65vh;
  position: relative;
  background: url("../images/bg_green01.png") no-repeat 16.5% 0/auto 65vh, url("../images/bg_green02.png") no-repeat right bottom, #f0eff3;
}
#mainarea .maintxt {
  position: absolute;
  text-align: center;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 90%;
  height: 19vh;
  font-size: 10.0rem;
  line-height: 1;
}
#mainarea .maintxt span {
  font-size: 2.4rem;
  font-weight: 700;
  display: block;
  margin-top: 20px;
}
#header {
  max-width: 80vw;
  margin: 0 auto;
  position: relative;
}
#header .logo {
  position: absolute;
  top: 15px;
  left: 0;
}
#header #navi {
  position: absolute;
  top: 15px;
  right: 0;
  display: flex;
}
#header #navi ul {
  display: flex;
  padding: 10px 0 0 0;
}
#header #navi ul li {
  margin: 0 15px;
  font-size: 1.8rem;
  font-weight: 400;
  margin-right: 35px;
}
#header #navi ul li a {
  color: #333;
  text-decoration: none;
}
#header #navi ul li a:hover {
  text-decoration: underline;
}
#header #navi .cbtn {
  width: 180px;
}
#header #navi .cbtn a {
  font-size: 1.8rem;
  display: block;
  padding: 10px 0;
  background: url("../images/ico_arrow01.png") no-repeat 96% center, linear-gradient(90deg, rgba(51, 51, 51, 1), rgba(0, 0, 0, 1));
  text-align: center;
  color: #FFF;
  text-decoration: none;
}
#header #navi .cbtn a:hover {
  opacity: 0.7
}
#mainarea .hamburger {
  display: none
}
#mainarea .sclbtn {}
#mainarea .sclbtn a {
  display: block;
  position: absolute;
  right: 3vw;
  bottom: 0;
  transition-duration: 0.5s;
}
#mainarea .sclbtn a:hover {
  position: absolute;
  bottom: -20px;
}
#mainarea .sclbtn img {
  width: 13px !important;
  height: 205px !important;
}
@media screen and (max-width: 1586px) {
  #header {
    max-width: 90vw;
  }
}
@media screen and (max-width: 1024px) {
  #mainarea {
    position: relative;
  }
  #mainarea .maintxt {
    font-size: 9.5vw;
  }
  #mainarea .maintxt span {
    font-size: 3vw;
  }
  @media screen and (max-width: 767px) {
    
#mainarea .sclbtn a {
  right: 2vw;
}
#mainarea .sclbtn img {
  width: 10px !important;
  height: auto!important;
}
    
    
  }
  /* ===============================================
ハンバーガーボタンのスタイリング
=============================================== */
  #mainarea .hamburger {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    width: 7vw;
    height: 7vw;
    appearance: none;
    border: 0;
    padding: 0;
    margin: 0;
    background-color: #333;
    cursor: pointer;
    z-index: 9999;
    text-align: center
  }
  #mainarea .hamburger span {
    position: absolute;
    display: block;
    content: "";
    width: 60%;
    height: 2px;
    left: 0%;
    right: 0;
    margin: 0 auto 0 auto;
    background: linear-gradient(90deg, rgba(51, 51, 51, 1) 0%, rgba(51, 51, 51, 1) 26%, rgba(255, 255, 255, 1) 26%);
    transition: all 0.5s;
  }
  #mainarea .hamburger span::before {
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 2px;
    background-color: #fff;
    transition: all 0.5s;
  }
  #mainarea .hamburger span::after {
    position: absolute;
    display: block;
    content: "";
    width: 100%;
    height: 2px;
    background: linear-gradient(90deg, rgba(51, 51, 51, 1) 0%, rgba(51, 51, 51, 1) 51%, rgba(255, 255, 255, 1) 51%);
    transition: all 0.5s;
  }
  #mainarea .hamburger span::before {
    top: -12px;
  }
  #mainarea .hamburger span::after {
    bottom: -12px;
  }
  #mainarea .hamburger.open span {
    background: transparent;
  }
  #mainarea .hamburger.open span::before {
    top: 0;
    transform: rotate(45deg);
  }
  #mainarea .hamburger.open span::after {
    bottom: 0;
    background: #fff;
    transform: rotate(-45deg);
  }
  #header #navi {}
  #header #navi {
    position: fixed;
    width: 50%;
    top: 0.5%;
    right: -50%;
    padding: 50px 0;
    transition: all 0.5s;
    z-index: 999;
    display: block;
  }
  #header #navi.open {
    right: 0;
  }
  #header #navi ul {
    display: block;
    padding: 0px 0 0 0;
  }
  #header #navi ul li {
    margin: 0;
    font-size: 1.6rem;
    font-weight: 400;
    margin-right: 0;
    background: #FFFFFF;
    border-bottom: 1px #ccc solid;
  }
  #header #navi ul li a {
    display: block;
    padding: 10px;
    color: #333;
    background: url("../images/ico_arrow02.png") no-repeat 96% center;
    text-decoration: none;
  }
  #header #navi ul li a:hover {
    text-decoration: underline;
  }
  #header #navi .cbtn {
    width: auto;
  }
  #header #navi .cbtn a {
    font-size: 1.8rem;
    display: block;
    padding: 10px;
    background: url("../images/ico_arrow01.png") no-repeat 96% center, linear-gradient(90deg, rgba(51, 51, 51, 1), rgba(0, 0, 0, 1));
    text-align: left;
    color: #FFF;
    text-decoration: none;
  }
  #header #navi .cbtn a:hover {
    opacity: 0.7
  }
}
@media screen and (max-width: 767px) {
  #mainarea {
    height: 65vh;
    position: relative;
    background: url("../images/bg_green01.png") no-repeat left 0/auto 45vh, url("../images/bg_green02.png") no-repeat right bottom/auto 15vh, #f0eff3;
  }
  #mainarea .maintxt {
    font-size: 16vw;
  }
  #mainarea .maintxt span {
    font-size: 4.8vw;
  }
  #mainarea .hamburger {
    width: 12vw;
    height: 12vw;
  }
  #mainarea .hamburger span::before {
    top: -9px;
  }
  #mainarea .hamburger span::after {
    bottom: -9px;
  }
}
/* ==============================
  service
============================== */
#service {
  background: #333;
}
#service .inner {
  display: flex;
  width: 80vw;
  margin: 0 auto;
}
#service .img {
  margin-top: -40px;
  margin-bottom: 30px;
  width: 50%;
  order: 1;
  z-index: 998;
}
#service .txts {
  padding: 4%;
  width: 50%;
  order: 2;
}
#service .subtxt {
  font-size: 1.8rem;
  margin-bottom: 30px;
}
#service .txts p {
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 2;
}
@media screen and (max-width: 1586px) {
  #service .inner {
    width: 100vw;
  }
}
@media screen and (max-width: 1024px) {
  #service .inner {
    display: flex;
    flex-wrap: wrap;
    width: 100vw;
  }
  #service .img {
    margin-top: -20px;
    margin-bottom: 30px;
    width: 90%;
  }
  #service .txts {
    padding: 2%;
    width: 90%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  #service .img {
    margin-top: -20px;
    margin-bottom: 10px;
    width: 90%;
  }
  #service .subtxt {
    font-size: 1.6rem;
    margin-bottom: 20px;
  }
  #service .txts p {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 2;
  }
}
/* ==============================
  product
============================== */
.bgg {
  background: url("../images/bg_green03.png") no-repeat right top/auto 100vh, #f0eff3;
}
#product {
  padding: 90px 0;
}
#product .inner7 {
  width: 65vw;
  margin: 0 auto
}
#product .inner7 .h2txt {
  margin-bottom: 30px;
}
#product .inner7 .txt {
  margin-bottom: 30px;
}
#product .site {
  display: flex;
  justify-content: space-between;
}
#product .site .sitebox {
  width: 48.2%;
}
#product .site .sitebox .img {
  margin-bottom: 15px;
}
#product .site .sitebox .txts {}
#product .site .sitebox .txts .h3txt {
  margin-bottom: 10px
}
#product .site .sitebox .txts .h3txt a {
  color: #333;
  background: url("../images/ico_outlink01.png") no-repeat right center;
  padding: 0 30px 0 0;
}
#product .site .sitebox .txts .h3txt a:hover {
  text-decoration: none;
}
#product .site .sitebox .txts p {
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 2;
}
@media screen and (max-width: 1586px) {
  #product .inner7 {
    width: 75vw;
  }
}
@media screen and (max-width: 1024px) {
  #product .inner7 {
    width: 90vw;
  }
}
@media screen and (max-width: 767px) {
  .bgg {
    background: #f0eff3;
  }
  #product {
    padding: 50px 0;
  }
  #product .inner7 {}
  #product .inner7 .h2txt {
    margin-bottom: 30px;
  }
  #product .inner7 .txt {
    margin-bottom: 30px;
  }
  #product .site {
    display: block;
  }
  #product .site .sitebox {
    width: 92%;
    margin: 0 auto;
  }
  #product .site .sitebox .img {
    margin-bottom: 15px;
  }
  #product .site .sitebox .txts {}
  #product .site .sitebox .txts .h3txt {
    margin-bottom: 10px
  }
  #product .site .sitebox .txts .h3txt a {
    color: #333;
    background: url("../images/ico_outlink01.png") no-repeat right center;
    padding: 0 30px 0 0;
  }
  #product .site .sitebox .txts .h3txt a:hover {
    text-decoration: none;
  }
  #product .site .sitebox .txts p {
    font-size: 1.4rem;
    font-weight: normal;
    line-height: 2;
  }
}
/* ==============================
  contact
============================== */
#company {
  padding: 45px;
  width: 80vw;
  background: #FFFFFF;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  margin-bottom: 50px;
}
#company .txts {
  width: 46%;
  margin-right: 4%;
}
#company .txts .h2txt {
  margin-bottom: 30px
}
#company table {
  width: 100%;
}
#company table tr th {
  width: 25%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  border-bottom: 1px #CCC dotted;
}
#company table tr td {
  padding: 20px 0;
  font-size: 1.4rem;
  font-weight: 400;
  border-bottom: 1px #CCC dotted;
}
#company .img {
  width: 50%;
}
@media screen and (max-width: 1586px) {
  #company {
    width: 90vw;
  }
}
@media screen and (max-width: 1024px) {
  #company {
    width: 90vw;
  }
}
@media screen and (max-width: 767px) {
  #company {
    width: 90%;
    padding: 17px 17px 25px 17px;
    display: block;
    margin: 0 auto;
    margin-bottom: 70px;
  }
  #company .txts {
    width: 100%;
    margin-right: 0%;
    margin-bottom: 20px;
  }
  #company .txts .h2txt {
    margin-bottom: 20px
  }
  #company table {
    width: 100%;
  }
  #company table tr th {
    width: 25%;
    padding: 20px 0;
    font-size: 1.4rem;
    text-align: left;
    border-bottom: 1px #CCC dotted;
  }
  #company table tr td {
    padding: 20px 0;
    font-size: 1.4rem;
    border-bottom: 1px #CCC dotted;
  }
  #company .img {
    width: 100%;
  }
}
/* ==============================
  contact
============================== */
#contact {
  padding: 50px 0;
  background: #333;
}
#contact .inner7 {
  padding: 50px 0;
  width: 65vw;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
}
#contact .txts {
  width: 40%;
  margin-right: 5%
}
#contact .txts .h2txt {
  margin-bottom: 30px
}
#contact .txts p {
  margin-bottom: 30px;
  font-size: 1.4rem;
  font-weight: normal;
}
#contact table {
  width: 100%;
  margin-bottom: 20px;
}
#contact table tr th {
  width: 30%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  border-bottom: 1px #FFF dotted;
}
#contact table tr td {
  padding: 20px 0;
  font-size: 1.4rem;
  border-bottom: 1px #FFF dotted;
}
#contact .form {
  width: 55%;
}
#contact .winputtext {
  width: 100%;
  height: 50px;
  border-radius: 10px;
  padding: 0 0 0 15px;
}
#contact .wwinputtext {
  width: 100%;
  border-radius: 10px;
  padding: 15px;
}
#contact .otoiawase {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
#contact .otoiawase label {
  margin-bottom: 20px;
  width: 45%;
  margin-right: 2%;
}
#contact input[type=checkbox] {
  vertical-align: bottom;
  height: 20px;
  width: 20px;
  border-radius: 5px;
  margin-right: 5px;
}
.formbtn {
  background: url("../images/ico_arrow01.png") no-repeat 96% center, #f79726;
  width: 200px;
  height: 50px;
  color: #FFF;
  border-radius: 4px;
  border: 0;
  margin-top: 20px;
}
.formbtn:hover {
  opacity: 0.7;
}

.btn_submit {
  background: url("../images/ico_arrow02.png") no-repeat 5% center, #CCC;
  width: 200px;
  height: 50px;
  color: #FFF;
  border-radius: 4px;
  border: 0;
  margin-top: 20px;
}
.btn_submit:hover {
  opacity: 0.7;
}



#contact .formprivacy {
  background: #FFFFFF;
  color: #333;
  padding: 20px;
  height: 200px;
  overflow: auto;
  border-radius: 10px;
  font-size: 1.4rem;
  margin-top: 20px;
}
#contact .validation{
  display: none;
  color: #FF0004;
  font-weight: 400;
  font-size: 1.4rem;
}

.comfirm table {
  width: 60%;
  margin: 0 auto;
}
.comfirm table tr th {
  width: 30%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  border-bottom: 1px #ccc dotted;
}
.comfirm table tr td {
  padding: 20px 0;
  font-size: 1.4rem;
  border-bottom: 1px #ccc dotted;
}



@media screen and (max-width: 1586px) {
  #contact .inner7 {
    width: 90vw;
  }
}
@media screen and (max-width: 1024px) {
  #contact .inner7 {
    padding: 40px 0;
    width: 90vw;
    display: flex;
    flex-wrap: wrap;
  }
  #contact .txts {
    width: 100%;
    margin-right: 0%;
  }
  #contact .txts p {
    margin-bottom: 10px;
  }
  #contact .form {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #contact {
    padding: 20px 0;
  }
  #contact .inner7 {}
  #contact .txts .h2txt {
    text-align: center;
    margin-bottom: 20px;
  }
  #contact .form {
    width: 100%;
  }
  #contact table th, td {
    display: block;
    float: left;
    clear: both;
    width: 100%;
  }
  #contact table tr th {
    width: 100%;
    padding: 3px 0;
    font-size: 1.4rem;
    text-align: left;
    border-bottom: 0px #FFF dotted;
  }
  #contact table tr td {
    width: 100%;
    padding: 10px 0;
    font-size: 1.2rem;
    border-bottom: 1px #FFF dotted;
    margin-bottom: 10px
  }
  #contact .formbtn {
    width: 100%;
  }
  #contact .winputtext {
    width: 100%;
  }
  #contact .wwinputtext {
    width: 100%;
  }
  

.comfirm table {
  width: 100%;
  margin: 0 auto;
}
.comfirm table th, td {
    display: block;
    float: left;
    clear: both;
    width: 100%;
  }
.comfirm table tr th {
    width: 100%;
    padding: 3px 0;
    font-size: 1.4rem;
    text-align: left;
    border-bottom: 0px #FFF dotted;
  }
.comfirm table tr td {
    width: 100%;
    padding: 10px 0;
    font-size: 1.2rem;
    border-bottom: 1px #FFF dotted;
    margin-bottom: 10px
  }
  
  
}





/* ==============================
  footer
============================== */
#footer {
  padding: 20px 0;
  background: #FFF;
}
#footer .h1txt {
  margin-top: -55px;
  background: url("../images/ico_logo01.png") no-repeat 20px center, #FFF;
  padding: 0 20px 0 60px;
  width: 370px;
}
#footer .innerall {
  padding: 30px 0 50px 0;
  margin: 30px auto 20px auto;
  border-top: 3px #333 solid;
  border-bottom: 3px #333 solid;
}
#footer .inner7 {
  width: 65vw;
  margin: 0 auto;
}
#footer .footerconts {
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
}
#footer .footerconts .left {
  width: 30%;
}
#footer .footerconts .left ul {
  margin-left: -20px;
}
#footer .footerconts .left ul li {
  margin: 0 0 15px 0;
  font-size: 1.8rem;
  font-weight: 400;
}
#footer .footerconts .left ul li a {
  color: #333;
  text-decoration: none;
}
#footer .footerconts .left ul li a:hover {
  text-decoration: underline;
}
#footer .footerconts .left .cbtn {
  width: 180px;
  margin-top: 40px;
  margin-left: 20px;
}
#footer .footerconts .left .cbtn a {
  font-size: 1.8rem;
  display: block;
  padding: 10px 0;
  background: url("../images/ico_arrow01.png") no-repeat 96% center, linear-gradient(90deg, rgba(51, 51, 51, 1), rgba(0, 0, 0, 1));
  text-align: center;
  color: #FFF;
  text-decoration: none;
}
#footer .footerconts .left .cbtn a:hover {
  opacity: 0.7
}
#footer .footerconts .center {
  width: 30%;
}
#footer table {
  width: 100%;
}
#footer table tr th {
  width: 25%;
  padding: 20px 0;
  font-size: 1.4rem;
  text-align: left;
  border-bottom: 1px #CCC dotted;
  vertical-align: top;
}
#footer table tr td {
  padding: 20px 0;
  font-size: 1.4rem;
  border-bottom: 1px #CCC dotted;
}
#footer .footerconts .right {
  width: 30%;
}
#footer .copy {
  text-align: center;
  font-size: 1.2rem;
}
@media screen and (max-width: 1586px) {
  #footer .inner7 {
    width: 80vw;
  }
}
@media screen and (max-width: 767px) {
  #footer .footerconts {
    display: block;
    margin-top: 30px;
  }
  #footer .footerconts .left, #footer .footerconts .center, #footer .footerconts .right {
    width: 100%;
  }
  #footer .footerconts .left {
    border-bottom: 2px #CCC solid;
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  #footer .footerconts .left ul {
    margin-left: -30px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
  }
  #footer .footerconts .left ul li {
    margin: 0 0 25px 0;
    font-size: 1.8rem;
    width: 48%
  }
  #footer .footerconts .left .cbtn {
    width: 180px;
    margin-top: 0px;
    margin-left: 10px;
  }
  #footer table {
    width: 100%;
    margin-bottom: 10px
  }
  #footer table tr th {
    width: 15%;
    padding: 5px 0;
    font-size: 1.2rem;
    border-bottom: 0px;
  }
  #footer table tr td {
    padding: 5px 0;
    font-size: 1.2rem;
    border-bottom: 0px;
  }
  #footer .h1txt {
    margin-top: -45px;
    background: url("../images/ico_logo01.png") no-repeat 10px center/15px auto, #FFF;
    padding: 0 0px 0 30px;
    width: 200px;
  }
  #footer .innerall {
    padding: 30px 0 30px 0;
    margin: 30px auto 20px auto;
    border-top: 3px #333 solid;
    border-bottom: 3px #333 solid;
  }
}

.pagetop{
  opacity: 0;
  position: fixed;
  bottom:1vw;
  right: 10px;
  width: 40px;
}


/* ==============================
  page
============================== */
#mainarea.page {
  height: auto;
  position: relative;
  background: url(../images/bg_green01.png) no-repeat 16.5% 0/auto 65vh, #f0eff3;
}
#mainarea.page .contents {
  width: 55vw;
  margin: 0 auto 90px auto;
  padding-top: 15vh
}
#mainarea.page .contents .ttl {
  font-size: 5.0rem;
  font-weight: bold;
  margin-bottom: 50px;
}
#mainarea.page .contents .ttl span {
  font-size: 2.0rem;
  font-weight: 400;
  display: block;
}
#mainarea.page .contents .privacytxt {
  background: #FFFFFF;
  padding: 30px;
  font-weight: 400;
  font-size: 1.4rem
}
#mainarea.page .contents .privacytxt p {
  padding: 0 0 30px 0;
}
#mainarea.page .contents .privacytxt p .txtBold {
  font-size: 1.8rem;
  font-weight: 700
}
@media screen and (max-width: 1586px) {
  #mainarea.page .contents {
    width: 90vw;
    margin: 0 auto 80px auto;
  }
}
@media screen and (max-width: 767px) {
  
  .pagetop{
  opacity: 0;
  position: fixed;
  bottom:1.5vw;
  right: 5px;
  width: 36px;
}

  
  
}