@charset "UTF-8";
html {font-size: 62.5%;}
body{
	font-size: 1.6em;
	line-height: 1.4em;
	min-width: 320px;
	margin: auto;
	animation: fade_in 1.5s ease;
	-webkit-animation: fade_in 1.5s ease;
  background-image: url(../images/bg.png);
  background-size: 200px;
  margin: 0;
  padding: 0;
  text-align: center;
}
@keyframes fade_in {
	0% {opacity: 0;}
	100% {opacity: 1;}
}
@-webkit-keyframes fade_in {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

main section {
  font-size: 0;
  border: 0;
  display: inline-block;
}
main section img {
vertical-align: bottom;
    max-width: 100%;
    height: auto;
}
main section.pc_view {
  display: block;
}
main section.sp_view {
  display: none;
}

main section .sp_ttl{
  display: none;
}

.grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  max-width: 1000px;
  padding: 0 42px;
  margin: 0 auto;
}
.grid .icon{
  position: relative;
}
.grid .icon::after{
  content: url(../images/icon.svg);
  position: absolute;
  top: -10px;
  right: -10px;
  width: 65px;
}
.grid li {
  position: relative;
}
.grid li a{
  position: absolute;
  width: 47.8%;
  border-radius: 5px;
}
.grid li a:hover{
  background-color: #fff;
  opacity: 0.6;
}
.grid li .tel_rnan,
  .grid li .tel_threefourtime,
  .grid li .tel_thekiss,
  .grid li .tel_city,
  .grid li .tel_aimerfeel{
    display: none;
    width: 95%;
    height: 14.8%;
    right: 2%;
    bottom: 3.8%;
  }z
  .grid li .tel_fancl,
  .grid li .tel_thebody{
    /* background-color: #393732; */
    display: none;
    height: 8%;
    width: 95%;
    left: 2.2%;
    bottom: 14%;
  }
  .grid li .tel_osmosis,
  .grid li .tel_hinosabou{
    /* background-color: #393732; */
    display: none;
    width: 95.8%;
    height: 11%;
    left: 2.2%;
    bottom: 22%;
  }
  .grid li .tel_ronnie{
    /* background-color: #393732; */
    display: none;
    height: 11%;
    left: 2.2%;
    bottom: 22%;
  }
  .grid li .ec_ronnie{
    /* background-color: #393732; */
    height: 10%;
    right: 1.7%;
    bottom: 21.2%;
  }
  .grid li .ec_earth{
    /* background-color: #393732; */
    height: 14.8%;
    width: 46.6%;
    right: 2%;
    bottom: 3.8%;
  }
.grid li .ec_jins{
  /* background-color: #393732; */
  height: 10%;
  width: 95.8%;
  right: 2%;
  bottom: 22.6%;
}

section.pc_over_view.footer {
  display: none;
}
main section.pc .pc_menu ,
main section.sp_view .sp_menu {
  text-align: center;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center bottom;
  position: relative;
}
main section.pc .pc_menu {
  margin: 0 auto;
  max-height: 433px;
  max-width: 918px;
  width: 91.6%;
}
main section.pc .sp_menu01 {
  display: none;
}
main section.pc .pc_menu01 {
  /* margin: 0 auto;
  background-size: contain;
  height: 10vw;
  max-height: 433px;
  max-width: 918px;
  width: 100%; */
}
main section.pc .pc_menu02 {
  /* margin: 0 auto;
  background-size: contain;
  height: 55.5vw;
  max-height: 433px;
  max-width: 918px;
  width: 91.6%; */
}

main section.sp_view div:nth-child(2) {
  max-width: 712px;
  width: 95vw;
  margin: 0 auto;
}
main section.sp_view .sp_menu {
  background-image: url(../images/sp_menu_bg.png);
  height: 97vw;
  max-width: 712px;
  width: 95vw;
  background-size: contain;
}
main section.pc .pc_menu ul {
  margin: 0 auto;
  background-color: #d2a346;
/*    padding: 0 30px;
    padding-left: calc( 30px + 3% );
    padding-right: calc( 30px + 3% );*/
  padding: 0 3%;
}
main section.pc .pc_menu ul li ,
main section.sp_view .sp_menu ul li {
  font-size: 2.6rem;
  display: inline-block;
  width: calc( ( 100% / 3 ) - 10px );
  margin-right: 10px;
  font-weight: bold;
  color: #d40000;
  margin-bottom: 9px;
}
main section.sp_view .sp_menu ul li {
  width: calc( ( 100% / 2 ) - 20px );
  margin-right: 20px;
  margin-bottom: 20px;
}

main section.sp_view .sp_menu ul li:nth-child(2n) {
    margin-right: 0px;
}
main section.pc .pc_menu ul li a ,
main section.sp_view .sp_menu ul li a {
  background: #fff;
  box-shadow: 0px 5px 0px 0px #d00f0f;
/*    padding: 44px 0;*/
/*  padding: 17% 0;*/
  padding: 15% 0;
  border-radius: 10px;
  color: #d40000;
  display: block;
  position: relative;
  letter-spacing: 0px;
  font-size: 2.6vw;
  transition: 0.5s;
  font-weight: bold;
}
main section.sp_view .sp_menu ul li a {
  font-size: 4vw;
  padding: 10% 0;
/*  padding: 14% 0;*/
}
main section .pc_menu ul li a:hover ,
main section.sp_view .sp_menu ul li a:hover {
  opacity: 0.7;
}

main section .pc_menu ul li a::before ,
main section.sp_view .sp_menu ul li a::before {
  content: "";
  vertical-align: middle;
  transition: 0.5s;
  /* margin-top: 5px; */
  position: absolute;

  width: 10px !important;
  height: 10px;
  border-bottom: 4px solid #d40000;
  border-right: 4px solid #d40000;
  -webkit-transform: translateY( -50% ) rotate(45deg);
  transform: translateY( -50% ) rotate(45deg);
  /* margin-left: 2em; */
  transition: 0.5s;
  left: calc( 50% - 5px );
  bottom: 8px;
}
/* main section.pc .pc_menu ul li a img {
  max-height: 32px;
} */
main section.sp_view .sp_menu ul li a img {
  max-height: 32px;
  height: 5vw;
}
main section.pc_view .pc_menu ul li:nth-child(1) a img {
  width: 6em;
}
main section.pc_view .pc_menu ul li:nth-child(2) a img {
  width: 8em;
}
main section.pc_view .pc_menu ul li:nth-child(3) a img {
  width: 9em;
}
main section.pc_view .pc_menu ul li:nth-child(4) a img {
  width: 3.3em;
}
main section.pc_view .pc_menu ul li:nth-child(5) a img {
  width: 7.8em;
}



h1, h2, h3, h4, h5, h6, p, a,li, ol, span, small, th, td, dd, dt,b {
	font-family: 'M PLUS Rounded 1c', sans-serif;
	color: #231815;
	letter-spacing: 0.05em;
}
img {max-width: 100%;}
a, a:hover, a img, a:hover img, a::after, a:hover::after, a::before, a:hover::before, a:hover span, a span {transition: 0.3s; -webkit-transition: 0.3s;}
.absolute {position: absolute;}

.amulogo {
	text-align: right;
	padding: 20px 20px 0;
}
.amulogo a {
	width: 70px;
	display: inline-block;
}
header {
	max-width: 900px;
	margin: auto;
	position: relative;
	text-align: center;
}

header .no1 {
	top: 22%;
	left: 51%;
	transform: translateX(-50%);
	z-index: 3;
}
header .no2 {
	top: -10px;
	left: 15%;
	right: 17%;
	z-index: 2;
}
header .no3 {
	top: 9%;
	right: 11%;
	z-index: 4;
	width: 25%;
}
h1 {
	position: absolute;
	top: 44%;
	left: 50%;
	margin-left: -27%;
	z-index: 4;
	width: 56%;
	opacity: 0;
	animation: img_fade_in_anm 0.8s ease 1 forwards;
	-webkit-animation: img_fade_in_anm 0.8s ease 1 forwards;
	animation-delay: 0.5s;
}
@keyframes img_fade_in_anm {
	0% {transform: scale(1.25); opacity: 1;}
  25% {transform: scale(0.7); opacity: 1;}
  50% {transform: scale(1.2); opacity: 1;}
  75% {transform: scale(0.8); opacity: 1;}
  100% {transform: scale(1.0); opacity: 1;}
}
@-webkit-keyframes img_fade_in_anm {
	0% {transform: scale(1.25); opacity: 1;}
  25% {transform: scale(0.7);opacity: 1;}
  50% {transform: scale(1.2); opacity: 1;}
  75% {transform: scale(0.8); opacity: 1;}
  100% {transform: scale(1.0); opacity: 1;}
}
h2 {
	position: absolute;
	z-index: 3;
	top: -20px;
	left: 45%;
	transform: translate(-50%, 0);
	width: 82%;
	opacity: 0;
	animation: img_fade_in2_anm 0.3s ease forwards;
	-webkit-animation: img_fade_in2_anm 0.3s ease forwards;
	animation-delay: 1.5s;
}
@keyframes img_fade_in2_anm {
	0% {opacity: 0; transform: translate(-50%, -20px);}
	100% {opacity: 1; transform: translate(-50%, 0);}
}
@-webkit-keyframes img_fade_in2_anm {
	0% {opacity: 0; transform: translate(-50%, -20px);}
	100% {opacity: 1; transform: translate(-50%, 0);}
}
main {
	padding: 0;
	max-width: 1000px;
	margin: auto;
	display: block;
}
.applicant_area {
	text-align: center;
	margin-bottom: 60px;
}
.terms {
	height: 500px;
	overflow: scroll;
	padding: 0 30px 40px;
	border: 1px solid #000;
	margin-bottom: 60px;
}
.terms::-webkit-scrollbar {width: 7px;}
.terms::-webkit-scrollbar-thumb {background: #e9476e;}
.terms h3 {
	font-size: 3rem;
	font-weight: 700;
	color: #e9476e;
	line-height: 1;
	margin-top: 40px;
}
.policy {margin-bottom: 20px;}
.terms h6 {
	font-weight: 700;
	font-size: 1.5rem;
	margin-top: 20px;
}
.terms p {
	font-size: 1.4rem;
	line-height: 1.4;
	margin-bottom: 3px;
}
.terms p small {
	font-size: 1.3rem;
	color: #e9476e;
}
.terms li {
	font-size: 1.4rem;
	line-height: 1.3;
	text-indent: -1.3em;
	padding-left: 1.3em;
	margin-bottom: 5px;
}
.terms li:last-child {margin-bottom: 0;}
.terms li ul {margin-top: 5px;}
.terms li li:last-child {margin-bottom: 5px;}
footer {
	text-align: center;
	padding: 0 0 20px;
	background-color: #fff;
}
footer p#copyright {
	font-size: 1rem;
	font-weight: bold;
	padding-top: 2rem;
	line-height: 1.7em;
}

@media screen and (min-width: 1001px) {
  section.pc_over_view.footer {
    display: block;
    height: 295px;
    overflow: hidden;
    background: linear-gradient(transparent 245px, #ead67f 245px);
	margin-top: 50px;
  }
	section.pc_over_view.footer div {
    position: relative;
	bottom: -50px;
  }
	section.pc_over_view.footer div::after {
    content: "";
	position: absolute;
    background: url(../images/pc_fukubukuro_17.png);
	width: 1000px;
	height: 245px;
	left: 0;
	bottom: 0;
	margin-bottom: 50px;
	z-index: -2;
  }
	section.pc_over_view.footer div::before {
    content: "";
	position: absolute;
    background: url(../images/pc_fukubukuro_18.png);
	width: 1000px;
	height: 245px;
	right: 0;
	bottom: 0;
	margin-bottom: 50px;
	z-index: -1;
  }
  main section.pc_view {
    display: none;
  }
  main section.pc_view .pc_menu {
    height: 571px;
  }
  main section.pc_view .pc_menu ul {
/*    max-width: 840px;*/
    margin: 0 auto;
/*    padding: 0 30px;*/
    padding: 0 2%;
    position: absolute;
    left: 0;
    right: 0;
/*    bottom: 64px;*/
    bottom: 9%;
  }
  main section.pc_view .pc_menu ul li a {
  font-size: 2.6rem;
  }
}
@media screen and (max-width: 950px) {
  .pc_menu ul li a img{
    height: 3vw;
  }
  .grid{
    max-width: 90vw;
    padding: 0 18px;
  }
  .grid li .tel_rnan,
  .grid li .tel_threefourtime,
  .grid li .tel_thekiss,
  .grid li .tel_city,
  .grid li .tel_aimerfeel{
    display: block;
    width: 96%;
    height: 14.8%;
    right: 2%;
    bottom: 3.8%;
  }
  .grid li .tel_fancl,
  .grid li .tel_thebody{
    display: block;
    height: 9.5%;
    width: 95.8%;
    left: 2%;
    bottom: 13.2%;
  }
  .grid li .tel_osmosis,
  .grid li .tel_hinosabou{
    display: block;
    left: 2%;
    bottom: 20.9%;
  }
  .grid li .tel_ronnie{
    display: block;
    height: 14.8%;
    width: 46.6%;
    right: 2%;
    bottom: 3.8%;
  }
  .grid li .ec_ronnie{
    height: 10.5%;
    right: 2%;
    bottom: 20.9%;
  }
  /* .grid li .ec_earth{
    right: 10px;
    bottom: 22%;
  } */
  .grid li .ec_jins{
    right: 2.2%;
    bottom: 22.7%;
  }
}
@media screen and (max-width: 768px) {
  html {font-size: 55%;}
	.terms {padding: 0 20px 20px; height: 300px;}
	.terms h3 {margin-top: 30px;}
	.applicant_area {margin-bottom: 30px;}
	.amulogo {padding: 10px;}
	.amulogo a {width: 12%;}
	.terms h6 {margin-top: 10px;}
	.policy {margin-bottom: 10px;}

  main section.pc .pc_menu{
    max-height: 620px;
  }
  main section.pc .pc_menu01{
    display: none;
  }
  main section.pc .sp_menu01{
    display: block;
  }
  main section.pc .pc_menu ul li{
    width: calc( ( 100% / 2 ) - 10px );
  }
  main section.pc .pc_menu ul li a{
    padding: 11% 0 14%;
  }
  .pc_menu ul li a img{
    height: 5vw;
  }

  main section .pc_ttl{
    display: none;
  }
  main section .sp_ttl{
    display: block;
  }

}
@media screen and (max-width: 750px) {
  body {
    background-size: 20%;
  }
  main section.pc_view {
    display: none;
  }
  main section.sp_view {
    display: block;
  }

  .grid{
    display: block;
    max-width: 90vw;
  }
  .grid .icon::after{
    top: -10px;
    right: -10px;
    width: 16%;
  }
  .grid li{
    padding-bottom: 15px;
  }
  .grid li img{
    width: 100%;
  }
  .grid li .tel_rnan,
  .grid li .tel_threefourtime,
  .grid li .tel_thekiss,
  .grid li .tel_city,
  .grid li .tel_aimerfeel{
    bottom: 6.6%;
  }
  .grid li .tel_fancl,
  .grid li .tel_thebody{
    bottom: 15.4%;
  }
  .grid li .tel_osmosis,
  .grid li .tel_hinosabou{
    bottom: 23%;
  }
  .grid li .tel_ronnie{
    height: 14.8%;
    width: 46.6%;
    left: 2%;
    bottom: 3.8%;
  }
  .grid li .ec_ronnie{
    bottom: 23.7%;
  }
  .grid li .ec_earth{
    bottom: 6.6%;
    width: 46.8%;
  }
  .grid li .tel_ronnie{
    bottom: 6.6%;
    width: 46.8%;
  }
  .grid li .ec_jins{
    bottom: 25.1%;
  }
}
@media screen and (max-width: 600px) {
  main section.sp_view .sp_menu ul {
    bottom: 4%;
  }
  main section.sp_view .sp_menu ul li {
    margin-bottom: 3vw;
    margin-right: 3%;
    width: 47%;
  }
  main section.sp_view .sp_menu ul li a {
/*    padding: 13% 0;*/
    padding: 5vw 0;
  }

}


@media screen and (max-width: 480px) {
  html {font-size: 50%;}
	.terms {height: 200px; padding: 0 10px 20px; margin-bottom: 40px;}
  .grid li .tel_rnan,
  .grid li .tel_threefourtime,
  .grid li .tel_thekiss,
  .grid li .tel_city,
  .grid li .tel_aimerfeel{
    bottom: 8.6%;
  }

  main section .pc_menu ul li a::before{
    width: 6px !important;
    height: 6px;
    border-bottom: 2px solid #d40000;
    border-right: 2px solid #d40000;
    bottom: 8%;
  }

  .grid li .tel_fancl,
  .grid li .tel_thebody{
    bottom: 18%;
  }
  .grid li .tel_osmosis,
  .grid li .tel_hinosabou{
    bottom: 25%;
  }
  .grid li .tel_ronnie{
    bottom: 25%;
  }
  .grid li .ec_ronnie{
    bottom: 25%;
  }
  .grid li .ec_earth{
    bottom: 8.6%;
  }
  .grid li .tel_ronnie{
    bottom: 8.6%;
  }
  .grid li .ec_jins{
    bottom: 26%;
  }

}



/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝
  ページトップ
＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
#page-top a {
  position: relative;
  display: block;
  background: #af1b1a;
  width: 65px;
  height: 65px;
  transition: all 0.3s;
  border-radius: 50%;
}

#page-top a::before {
  content: "";
  position: absolute;
  top: calc(50% + 3px);
  left: 50%;
  width: 12px;
  height: 12px;
  border-top: 4px solid #fff;
  border-left: 4px solid #fff;
  transform: translate(-50%, -50%) rotate(45deg);
}

#page-top a:hover {
  opacity: .7;
}

#page-top {
  position: fixed;
  right: 30px;
  bottom: 30px;
  z-index: 2;
  opacity: 0;
  transform: translateY(100px);
}

#page-top.UpMove {
  animation: UpAnime 0.5s forwards;
}

@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#page-top.DownMove {
  animation: DownAnime 0.5s forwards;
}

@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0);
  }

  to {
    opacity: 1;
    transform: translateY(100px);
  }
}

@media screen and (max-width: 768px) {
  #page-top {
    right: 15px;
    bottom: 15px;
  }

  #page-top a {
    width: 45px;
    height: 45px;
  }
}






.amukuji {
  position: absolute;
  top: -3%;
  right: -4%;
  width: 24%;
}

@media screen and (max-width: 768px) {
  .amukuji {
    top: -2%;
    right: -4%;
    width: 36%;
  }
}
