@charset "UTF-8";
/*font*/
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W1.otf') format('opentype');
	font-weight: 100;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W2.otf') format('opentype');
	font-weight: 200;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W3.otf') format('opentype');
	font-weight: 300;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W4.otf') format('opentype');
	font-weight: 400;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W5.otf') format('opentype');
	font-weight: 500;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W6.otf') format('opentype');
	font-weight: 600;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W7.otf') format('opentype');
	font-weight: 700;
}
@font-face {
	font-family: 'hiragino sans';
	src: url('../fonts/hiragino_std_W9.otf') format('opentype');
	font-weight: 900;
}

html {
	font-size: 1.042vw;
	-ms-overflow-style: auto;
	-webkit-font-smoothing: antialiased;
}
body {
	font-family: 'hiragino sans', sans-serif;
	margin: 0px;
	padding: 0px;
	color: #000;
	font-weight: 300;
	-webkit-font-smoothing: subpixel-antialiased;
	line-height: 1em;
}
body * {
  box-sizing: border-box;
}
@-ms-viewport {
	width: auto!important;
	initial-scale: 1;
}

h1,h2,h3,h4,h5,h6,p {
	font-size: 17px;
	text-align: left;
	overflow-wrap: break-word;
	line-height: 1em;
	margin: 0;
}
a {
	text-decoration: underline;
	
	/* animation */
	
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
a:hover {
	opacity: 0.7;
	text-decoration: none;
}
img {
	border: 0;
	vertical-align: top;
	font-size: 0;
	line-height: 0; 
	-ms-interpolation-mode: bicubic;
	max-width: 100%;
	height: auto;
}
ol,ul {
  list-style:none;
  margin: 0;
  padding: 0;
}

/* content */
#menu {
  display: none;
}

#wrap {
  background: #000;
  display: flex;
}
#contents {
  width: 100%;
}
#nav {
  width: 4.7rem;
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  background: #3BC6D9;
  z-index: 1;
}
#menu:checked + #wrap #nav {
  background: #E9241B;
}
.menu-box {
  width: 100%;
  position: absolute;
  top: 46%;
  padding: 2rem 0;
}
.menu-box span {
  display: block;
  height: 0.35rem;
  background: #fff;
  width: 54%;
  margin: auto;
  position: relative;
}
.menu-box span::after,
.menu-box span::before {
  content: "";
  display: block;
  height: 0.35rem;
  background: #fff;
  width: 100%;
  position: absolute;
  top: -0.85rem;
}
.menu-box span::after {
  top: 0.85rem;
}
/*
#menu:checked + #wrap #nav .menu-box span {
  background: transparent;
}*/
#menu:checked + #wrap #nav .menu-box span::after,
#menu:checked + #wrap #nav .menu-box span::before {
  background: transparent;
/*  top: 0;
  width: 117%;
  transform: rotate(40deg);
  left: -0.2rem;*/
}/*
#menu:checked + #wrap #nav .menu-box span::after {
  transform: rotate(-40deg);
}*/
.manu-mail {
  position: absolute;
  bottom: 0;
}
#menu:checked + #wrap .manu-mail {
  display: none;
}
.cont-box {
  width: 100%;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.box-1 {
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: self-end;
  padding-bottom: 2.5rem;
  background-image: url(img/over_bg.webp),url(img/logo__8.webp),url(img/main_bg_1.webp);
  background-size: auto,18% auto,cover;
  background-repeat: repeat,no-repeat,no-repeat;
  background-position: center top,right 4.7rem bottom 3rem,center top;
}
.box-2 {
  padding-bottom: 5rem;
  background-image: url(img/over_bg.webp),url(img/main_bg_2.webp);
  background-size: auto,cover;
  background-repeat: repeat,no-repeat;
  background-position: center top;
}
.logo-2 {
  display: flex;
  justify-content: center;
  padding: 5.7rem 0 1.4rem;
}
.cont-box p{
  text-align: center;
  color: #fff;
  line-height: 2.95em;
  font-size: 17px;
}
.box-3 {
  background-image: url(img/over_bg.webp),url(img/main_bg_3.webp);
  background-size: auto,cover;
  background-repeat: repeat,no-repeat;
  background-position: center top;
}
.logo-3 {
  display: flex;
  justify-content: center;
  padding: 11rem 0 3rem;
}
.title_2 {
  width: 100%;
  text-align: center;
  padding-bottom: 0.5rem;
  color: #fff;
}
.cont_1 {
  width: 100%;
  padding: 32rem 0 6.5rem;
  text-align: center;
}
.box-4 {
  padding-bottom: 6.5rem;
  background-image: url(img/over_bg.webp),url(img/main_bg_4.webp);
  background-size: auto,cover;
  background-repeat: repeat,no-repeat;
  background-position: center top;
}
.logo-4 {
  width: 100%;
  text-align: center;
  padding: 8rem 0 4.3rem;
}
.box-4 ul {
  width: 100%;
  max-width: 1200px;
  display: flex;
  flex-wrap: wrap;
}
.box-4 ul li {
  width: 31%;
  margin-right: 3.3%;
  margin-bottom: 1.8rem;
}
.box-4 ul li:nth-child(3n) {
  margin-right: 0;
}
.box-4 ul li label {
  display: block;
  padding: 130px 40px 0 46px;
  height: 420px;
  background-image: url(img/li_bg__2.webp);
  background-size: 100% auto;
  background-repeat: no-repeat;
}
.box-4 ul li .box-a {
  background-image: url(img/li_bg__1.webp);
  color: #fff;
}
.box-4 input,
.box-4 ul li .box-a,
.box-4 ul li input:checked ~ .box-q {
  display: none;
}
.box-4 ul li input:checked ~ .box-a {
  display: block;
}
.box-4 ul li .title_3 {
  letter-spacing: 0.05em;
  line-height: 2em;
  padding-bottom: 0.9rem;
}
.box-4 ul li p {
  line-height: 2.3em;
  font-size: 15px;
  text-align: justify;
  text-align: left;
}
.box-5 {
  background-image: url(img/over_bg.webp),url(img/main_bg_5.webp);
  background-size: auto,cover;
  background-repeat: repeat,no-repeat;
  background-position: center top;
}
.logo-5 {
  max-width: 1200px;
  margin: auto;
  padding: 7.5rem 0 5rem;
  text-align: right;
}
.logo-5 > img {
  margin: 0 5.8rem 3rem 0;
}
.logo-5 .mail-button {
  padding-right: 3rem;
}
footer {
  padding-top: 4rem;
  text-align: center;
  background-color: #3BC6D9;
}
#menu:checked ~ footer {
  position: fixed;
  top: 0;
  width: 100%;
  height: 100vh;
}
#menu:checked ~ footer .logo-6 {
  padding: 17rem 0 3rem;
}
footer .mail-button {
  display: none;
}
#menu:checked ~ footer .mail-button {
  display: block;
}
footer p {
  text-align: center;
  font-size: 14px;
  letter-spacing: 1px;
  color: #fff;
  padding: 3.2rem 0 3.7rem;
}

@media only screen and (min-width: 1921px) {
html {
  font-size: 20px;
}
.menu-box span {
  height: 7px;
}
.box-1 {
  padding-bottom: 8.5vh;
}
.box-3 {
  background-size: auto,auto 100%;
  background-position: top center;
}
}
@media only screen and (max-width: 1280px) {
h1, h2, h3, h4, h5, h6, p {
  font-size: 1.33vw;
}
.box-4 ul li label {
  padding: 6.5rem 2rem 0 2.3rem;
  height: 21rem;
}
.box-4 ul {
  width: 88%;
}
.box-4 ul li label {
  padding: 9.5rem 2rem 0 2.6rem;
  height: 29rem;
}
.box-4 ul li p {
  font-size: 1.1vw;
}
.logo-5 {
  width: 90%;
}
}
@media only screen and (max-width: 568px) {
}
@media only screen and (min-width: 769px) {
.sp {
  display: none !important;
}
}
@media only screen and (max-width: 768px) {
.pc {
  display: none !important;
}
#nav {
  width: 11.7rem;
  height: 23rem;
  background: #3BC6D9;
  z-index: 1;
}
#menu:checked + #wrap #nav {
  height: 11rem;
}
.menu-box {
  width: 100%;
  position: absolute;
  top: 0;
  padding: 5.3rem 0;
}
.menu-box span {
  height: 3px;
}
.menu-box span::before {
  height: 3px;
  top: -2rem;
}
.menu-box span::after {
  height: 3px;
  top: 2rem;
}
.box-1 {
  height: 137rem;
  padding-bottom: 4.5rem;
  background-image: url(img/over_bg.webp),url(img/main_bg_1_sp.webp);
  background-size: auto,100% auto;
  background-repeat: repeat,no-repeat;
  background-position: center top;
  max-height: 100vh;
}
.mein-logo {
  padding: 0 15rem 0 12rem;
}
.box-2 {
  background-image: url(img/over_bg.webp),url(img/main_bg_2_sp.webp);
  padding-bottom: 18rem;
}
.logo-2 {
  padding: 23.5rem 20% 7.5rem 17%;
}
.logo-2 img {
  width: 100%;
}
.cont-box p {
  line-height: 2.5em;
  font-size: 3.5rem;
}
.box-3 {
  background-image: url(img/over_bg.webp),url(img/main_bg_3_sp.webp);
}
.logo-3 {
  padding: 28rem 32.5% 7.5rem;
}
.logo-3 img {
  width: 100%;
}
.title_2 {
  font-size: 3.5rem;
  padding-bottom: 3.5rem;
}
.cont_1 {
  padding: 130rem 23% 19.5rem;
}
.cont_1 img {
  width: 100%;
}
.logo-4 {
  padding: 18rem 40% 3rem;
}
.logo-4 img {
  width: 100%;
}
.box-4 ul {
  display: initial;
  width: 100%;
}
.box-4 ul li {
  width: 100%;
  margin: auto;
}
.box-4 ul li label {
  padding: 24.5rem 12.5rem 0 13.5rem;
  height: 69rem;
  background-image: url(img/li_bg__2_sp.webp);
  background-size: 100% auto;
}
.box-4 ul li .title_3 {
  padding-bottom: 0.9rem;
  font-size: 4.5rem;
}
.box-4 ul li p {
  line-height: 1.9em;
  font-size: 3.1rem;
  letter-spacing: 0.1em;
}
.box-4 ul li .box-a {
  background-image: url(img/li_bg__1_sp.webp);
}
.box-4 ul li img {
  width: 100%;
}
.box-5 {
  background-image: url(img/over_bg.webp),url(img/main_bg_5_sp.webp);
}
.logo-5 {
  width: 100%;
  padding: 59rem 0 7rem;
}
.logo-5 > img {
  width: 45%;
  margin: 0 auto 5rem;
  display: block;
  padding-left: 3%;
}
.logo-5 .mail-button {
  padding-right: 0;
  margin: auto;
  width: 89%;
}
.logo-5 .mail-button img {
  width: 100%;
}
footer {
  padding-top: 11rem;
}
.logo-6 {
  width: 60%;
  margin: auto;
}
footer p {
  font-size: 11px;
  padding: 7.2rem 0 11.7rem;
}
#menu:checked ~ footer p {
  padding-top: 9rem;
}
footer .mail-button {
  margin: auto;
  width: 89%;
}
#menu:checked ~ footer .logo-6 {
  padding: 23rem 0 15rem;
}
}
@media only screen and (max-width: 480px) {
}


/* 印刷時 */

@media print {
}

#wrap {
  position: relative;
  cursor: none;
}
#cursor{
  position: fixed;
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -10px;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
}
#stalker{
  position: fixed;
  background: #00f;
  margin: -111px  0 0 -65px;
  z-index: 999;
  pointer-events: none;
  opacity: 0.8;
  width: 75px;
  height: 121px;
  background: url(img/icon01.webp) no-repeat;
  background-size: cover;
  animation: stepsline 0.5s steps(2) alternate infinite;
  transition: transform ease .1s;
}

@keyframes stepsline {
  to {
    background-position: -150px 0;
  }
}
