@charset "utf-8";

/*--- reset */
* {
    margin:0;
    padding:0;
    outline:0;
    vertical-align:baseline;
}


h1, h2, h3, h4, h5, h6, p {
	margin: 0;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {
    display:block;
}

hr {
    display:block;
    height:1px;
    border:0;
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

ul {
	list-style:none;
	padding:0;
}

li {
	padding:0;
}

table {
  border-collapse: collapse;
}


input, select {
    vertical-align:middle;
}

a{
	color: #d81946;
    -webkit-tap-highlight-color:transparent;
}

a:hover{
	color: #999;
	text-decoration:none;
}

a img {
    border-style:none;
}

.pink{
	color: #ea65a1;
	font-weight: bold;
}

.red{
	color: #ff0000;
	font-weight: bold;
}

.blue{
	color: #1732D3;
	font-weight: bold;
}

.green{
	color: #2A901A;
	font-weight: bold;
}

.yline {
    background: linear-gradient(transparent 74%, #ff0 0%);
    font-weight: bold;
}

.b {
	font-size:18px;
    font-weight: bold;
}

.txt34{
	font-size: 34px;
	line-height: 44px;
}


.txt18{
	font-size: 18px;
	line-height: 28px;
}

.txt20{
	font-size: 20px;
	line-height: 30px;
}

.txt24{
	font-size: 24px;
	line-height: 34px;
}

.r18{
	text-align: center;
	color: #ff0000;
}
.txt1{
	text-align: center;
	margin: 5%;
}
.txt2{
	color: #06c755;
	font-weight: bold;
	border:3px solid #06c755;
	border-radius: 10px;
	padding: 4% 6%;
	margin: 5%;
	line-height: 26px;
}
.txt3{
	color: #ec0e0d;
	text-align: center;
	font-weight: bold;
}

.txt4{
	margin: 10% 5%;
	font-size: 10px;
	line-height: 20px;
	
}

html,body {
  -webkit-text-size-adjust: none;
}


.clearfix:after {
	content: ".";
	display: block;
	height: 0.1px;
	font-size: 0.1em;
	line-height: 0; 
	clear: both;
	visibility: hidden; 
}


body {
	width:100%; 
	height: auto;
	margin: 0 auto;
	font-family:"メイリオ",meiryo,Arial,san-serif;
	color:#333;
	font-size:14px;
	line-height: 24px; 
	background:#fff;
}



img{
	height: auto;
	max-width: 100%;
	vertical-align: bottom;
}

#wrap{
	background: url("../images/bg.png");
	background-size: 375px;
	
}


#container {
	text-align:left;
	min-width: 320px;
	max-width: 750px;
	margin: 0 auto;
	overflow: hidden;

}

.mt01{
	margin-top: 20px;
}

.myicon{
	border-radius: 50%;
	background:#000;
	height: 50px;
	width: 50px;
	overflow: hidden;
    align-items: center;
    display: flex;
    justify-content: center;
	float:left;
	position:absolute;
	left:10px;
	top:130px;
}


.title{
	background: #d81946;
	color: #fff;
	padding: 3px 6px;
	font-weight: bold;
	overflow: hidden;
}


.title2{
/*
	background: #390843;
	color: #fff;
	*/
	background: #000000;
	color:#DC9FB4;
	font-weight: bold;
	font-size: 16px;
	padding: 10px 15px 0px;
	margin:0px;
}

.title3{
	background: #b0c4de;
	color: #fff;
	text-align: center;
	font-weight: bold;
	padding: 3px 6px;
	margin:0px;
}

.title4{
	font-weight: bold;
	padding: 6px 6px 3px;
	margin:0px;
}

.title5{
	background: #333;
	color: #fff;
	text-align: center;
	font-weight: bold;
	padding: 3px 6px;
	margin:0px;
}

.txt-area{
	padding: 10px 20px 10px;
	font-size:14px;
}



.btn-top-r {
	color: #fff;
	font-size:18px;
	font-weight: bold;
	text-decoration: none;
	-webkit-animation-fill-mode: forwards;
	 animation-duration: 1s;
	 animation-name: z;
	 background-color: #fff;
     background: linear-gradient(45deg,#0ecae6 0%, #5757ff 20%, #fc449b 80%,#ff8687 100%);
      background-size: 400% 400%;
      display: inline-block;
	width: 80%;
	padding: 0.6em;
	border-radius: 60px;
	transition: 0.7s;
	box-shadow: 0 5px 10px rgba(211,0,100,0.3);
	border: none;
}

.btn-top-r:hover {
      -webkit-animation-fill-mode: forwards;
      animation-duration: 0.7s;
      animation-name: x;
      box-shadow: 0 3px 7px rgba(53,53,235,0.5);
      text-decoration: none;
      color: #fff;
}

.btn-top-r:active {
      outline: none;
      box-shadow: 0 4px 8px rgba(87,81,255,0.6);
}

 @keyframes z {
      0% {
    
        background-position: 0 0;
      }
      100% {
    
        background-position: 100% 0;
      }
    }

    @keyframes x{
      0% {
    
           background-position: 100% 0;
      }
      100% {
    
           background-position: 0 0;
      }
    }
	
.login-page {
  width: 100%;
  padding: 0 0 0;
  margin: auto;
}

.login-form {
  position: relative;
  z-index: 1;
   max-width: 360px;
  margin: 0 auto ;
  padding: 25px;
  text-align: center;

}

.login-form input {
  outline: 0;
  background: #f2f2f2;
  width: 100%;
  border: 0;
  margin: 0 0 15px;
  padding: 15px 15px 15px 35px;
  box-sizing: border-box;
  font-size: 16px;
  border-radius: 100px;
}

 
.login {
	position: relative;
}
  
 .login-icon{
  	position: absolute;	
	top:18px;
	left: 10px;
	font-size: 16px;
	color: #ccc;	
  }

.login-form button {
  cursor: pointer;
}

.login-help{
	margin: 15px auto;
}





.r-area {
	appearance: none;
	-webkit-appearance: none;
  outline: 0;
  background: #f2f2f2;
  width: 100%;
  border: 0;
  margin: 0 0 15px;
  padding: 15px 15px 15px 35px;
  box-sizing: border-box;
  font-size: 16px;
  border-radius: 100px;
}

.regist {
	position: relative;
	outline: 0;
	background: #f2f2f2;
	width: 100%;
	border: 0;
	margin: 0 0 15px;
	padding: 15px 15px 15px 30px;
	box-sizing: border-box;
	font-size: 16px;
	border-radius: 100px;
	text-align: left;
}

.regist select{
	appearance: none;
	-webkit-appearance: none;
	outline: 0;
	background: #f2f2f2;
	border: 0;
	margin: 0 ;
	padding: 0 10px;
	box-sizing: border-box;
	font-size: 16px;
 
}

.radiobox{
	margin-bottom: 20px;
	width: 100%;
}
.male,.female{
  display: none;
}

label {
  background: #f2f2f2;
  	border-radius: 100px;
  font-size: 16px;
  padding: 10px 17%;
}

@media screen and (min-width: 320px) and (max-width: 320px) {
label {
  padding: 10px 16%;
}
}


.male:checked + label {
  background: #426fba;
  color: #fff;
}

.female:checked + label {
  background: #fb7cac;
  color: #fff;
}


.form-prof{
	width: 100%;
	text-align: left;
	margin-bottom: 15px;
 
}

.form-prof tr{
	border-bottom:1px solid #c6c6c6; 
}

.form-prof th{
	padding: 10px 0px;
	width: 40%;
	font-weight: normal;
}

.form-prof td{
	padding: 10px 0px;
	font-weight:bold;
	font-size:16px;
}

.form-red{
	color: #ff0000;
}

.form-conf{
	text-align: left;
	border: 1px solid #4D648D;
	margin: 10px auto;
	padding: 10px;
}

.stepBar {
  display: flex;
  position: relative;
  margin: 20px auto;
  text-align: center;
}
.stepBar li {
  font-size: 12px;
  list-style: none;
  position: relative;
  width: 33.333%;
}
.stepBar li:after {
  background: #D0E1F9;
  content: "";
  width: calc(100% - 24px);
  height: 4px;
  position: absolute;
  left: calc(-50% + 12px);
  top: 10px;
}
.stepBar li:first-child:after {
  display: none;
}
.stepBar li span {
  background: #D0E1F9;
  color: #ffffff;
  display: inline-block;
  height: 24px;
  margin-bottom: 5px;
  line-height: 24px;
  width: 24px;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
  border-radius: 50%;
}
.stepBar .visited:after {
  background: #4D648D;
}
.stepBar .visited span {
  background: #4D648D;
}


.btn-message {
  width:55px;
  height: 47px;
  padding-top: 8px;
  text-align:center;
  display: inline-block;
  text-decoration: none;
  color: #FFF;
  background: #fd9535;
  border-radius: 4px;
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.2), inset 0 -2px 0 rgba(0, 0, 0, 0.05);
  font-size: 12px;
  line-height: 19px;
  border: solid 2px #d27d00;
  position: fixed;
  bottom: 60px;
  right: 5px;
  z-index: 1000;
}

.btn-message:active {
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.30);
  color:#dddddd;
}
a.btn-message:hover{
	color:#ddd;
}

.ms-txt{
	font-size: 26px;
}

.cam-area01{
	margin: 10px;
	padding: 10px 20px 10px;
	font-size:14px;
	background: #f9f9f9;
    border: 1px solid #e5e5e5;
}


.uncer{
	background: #f8f6f4;
	margin: 0 20px;
	padding: 10px;
}

.uncer li{
	font-size: 14px;
}

.uncer li:before {
	content: " \f14a";
	font-family:'Font Awesome 5 Free';
	font-weight: 900;
	color: #d81946;
	margin-right: 4px;
  }

#container2 {
	overflow:hidden;
	text-align:left;
	margin: 0 auto;
	padding: 52px 0 0;
}


.btn-square-so-pop {
  width:50%;
  text-align:center;
  position: relative;
  display: inline-block;
  padding: 10px;
  text-decoration: none;
  color: #FFF;
  background: #d81946;
  border-radius: 60px;
   font-weight: bold;
   border:none;
  }

.btn-square-so-pop:active {
	  background: #333;
}

.btn-square-so-pop:hover{
	  background: #333;
}

#header{
	background: #333;
	height: 50px;
	line-height: 50px;
	text-align: center;
	color: #d2b48c;
	font-size: 14px;
	font-weight: bold;
	width: 100%;
	margin: 0 auto;
}


.site-icon{
	margin: 0 auto;
	padding-top: 14px;
	width: 200px;
}

.top-heder{
	margin-bottom: 30px;
}

.k18{
	text-align: center;
	margin: 10px auto;
}  


.help li {
	height:40px;
	border-bottom: 1px dotted #c9c9c9;
	font-size:12px;
}


.help li a {
	text-align:left;
	height:40px;
	display:block;
	line-height:42px;
	text-decoration:none;
	text-indent:5px;
	color:#999;
	font-weight:bold;
    background: url(../images/arrow.svg) 99% center no-repeat #fff;
    background-size: 8px;
}

.helpmsg{
	margin-bottom: 15px;
}

.bank{
	margin: 1%;
}

.bank table{
	width:100%;
	border:#bababa 1px solid;
	background-color:#fff;
	margin:0 auto;
	color: #000;
}

.bank th{
	text-align:center;
	padding:5px;
	border:#bababa 1px solid;
	font-weight:normal;
	background:#ddd;
	width: 30%;
	vertical-align: middle;
}

.bank td{
	padding:5px;
	height:22px;
	text-align:left;
	border:#bababa 1px solid;
	vertical-align:middle;
}

.marquee {
    width: 100%;
    padding-left: 100%;
    white-space: nowrap;
    animation-name: marquee;
    animation-duration: 8s;
    animation-timing-function: linear;
    animation-iteration-count: infinite;
	
}


.button-wrap {
	width: 100%;
	height: auto;
	box-sizing: border-box;
	position: relative;
	margin: 0px auto;
	padding: 15px 0;
}


.button-wrap img.button {
	width: 100%;
	height: auto;
}

.button-wrap img.arw {
    height: 100%;
    left: -5px;
    padding: 10px 0;
    position: absolute;
    top: -5%;
    width: auto;
}

.button-wrap img.arw{
	z-index:100;animation:btn_arrow .9s linear 0s infinite
}

@keyframes btn_arrow{0%,100%,50%{transform:scale(1,1) translate(0,0)}10%{transform:scale(1,1) translate(5%,5%)}40%,85%{transform:scale(1,1) translate(10%,0)}60%{transform:scale(1,1) translate(-40%,0)}75%{transform:scale(1,1) translate(-15%,0)}}




.ph{
	margin: 10px auto;
}

.ph li{
	float: left;
	width: 33.3%;
	box-sizing: border-box;
	padding: 1%;
}

.ph li img{
	border:1px solid #eb0379;
	box-sizing: border-box;
}



.mt01{
	margin-top: 20px;
}


#top-footer{
	background:#333;
	padding:10px 0 0;
	text-align:center;
	color: #d2b48c;
	font-size: 12px;
}

#top-footer a{
	color: #d2b48c;
	text-decoration: none;
}


address {
	border-top:1px dotted #fff; 
	margin-top: 10px;
	padding:10px 0;
	font-size: 12px;
	font-style: normal;
}
