@charset "utf-8";

/*=================================
全サイズ共通開始
=================================*/
/*===============
01 base/layout
===============*/
html{
  font-size: 100%;
}

body{
  color: #333;
  font-family: 'ヒラギノ角ゴPro W3',Hiragino Kaku Gothic Pro,'メイリオ',Meiryo,'ＭＳＰゴシック',sans-serif;
  -webkit-text-size-adjust: none;  
}

header{
  padding: 0 0 3px 0;
  background: #084ca2;
}

header h1{
  text-align: center;
  background: #fff;
}

.main-title{
  background: #fff;
  border-bottom: 3px solid #6f724e;
}

.main-title h2{
  font-size:1rem;
  text-align: center;
  padding: 20px 0 5px 0;
}

.main{
  margin: 50px 0 0 0;
}

footer{
  margin: 60px 0 0 0;
  background: #084ca2;
}

.innerfooter{
  color: #fff;
  padding: 20px 0;  
  width: 500px;
  margin: 0 auto;
}

.innerfooter small{
  font-size: 0.6rem;
  display: block;
  text-align:center;
}


h3{
  font-size: 1.2rem;
  text-align: center;
  margin: 20px 0 0 0;
}

.agree .agree-check{
  margin: 25px 0 0 0;
  text-align: center;
}

.agree-check-note{
  font-size: 1.2rem;
  vertical-align: 0.2rem;
}

.complete .center{
  text-align: center;
}

.title-menu{
  display: block;
}

.notice{
  margin: 20px 0 10px;
  display: block;
  font-size: 0.8rem;
}

.example{
  margin: 10px 0 0 0;
  display: block;
  font-size: 0.8rem;  
}


.message{
  margin: 30px 0 0 0;
  font-size: 1.1rem;
  color: #C00;
}

span.hyphen{
  padding: 5px;
}

.loading{
  text-align: center;
  width: 100%;
  margin: 30px 0 0 0;
}

/*===============
02 form
===============*/
input[type="button"],
input[type="submit"] {
  -webkit-appearance: none;
}

.btn-base{
  color: #333;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: rgb(255,255,255);	
  background: -moz-linear-gradient(top,  rgba(255,255,255,1) 0%, rgba(251,251,251,1) 3%, rgba(228,228,228,1) 50%, rgba(207,207,207,1) 94%, rgba(202,202,202,1) 97%, rgba(219,219,219,1) 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,1)), color-stop(3%,rgba(251,251,251,1)), color-stop(50%,rgba(228,228,228,1)), color-stop(94%,rgba(207,207,207,1)), color-stop(97%,rgba(202,202,202,1)), color-stop(100%,rgba(219,219,219,1)));
  background: -webkit-linear-gradient(top,  rgba(255,255,255,1) 0%,rgba(251,251,251,1) 3%,rgba(228,228,228,1) 50%,rgba(207,207,207,1) 94%,rgba(202,202,202,1) 97%,rgba(219,219,219,1) 100%);
  background: -o-linear-gradient(top,  rgba(255,255,255,1) 0%,rgba(251,251,251,1) 3%,rgba(228,228,228,1) 50%,rgba(207,207,207,1) 94%,rgba(202,202,202,1) 97%,rgba(219,219,219,1) 100%);
  background: -ms-linear-gradient(top,  rgba(255,255,255,1) 0%,rgba(251,251,251,1) 3%,rgba(228,228,228,1) 50%,rgba(207,207,207,1) 94%,rgba(202,202,202,1) 97%,rgba(219,219,219,1) 100%);
  background: linear-gradient(to bottom,  rgba(255,255,255,1) 0%,rgba(251,251,251,1) 3%,rgba(228,228,228,1) 50%,rgba(207,207,207,1) 94%,rgba(202,202,202,1) 97%,rgba(219,219,219,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#dbdbdb',GradientType=0 );
}

.btn-yellow{
  color: #333;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: rgb(248,217,122);
  background: -moz-linear-gradient(top,  rgba(248,217,122,1) 0%, rgba(243,212,119,1) 48%, rgba(236,206,112,1) 53%, rgba(249,218,124,1) 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(248,217,122,1)), color-stop(48%,rgba(243,212,119,1)), color-stop(53%,rgba(236,206,112,1)), color-stop(100%,rgba(249,218,124,1)));
  background: -webkit-linear-gradient(top,  rgba(248,217,122,1) 0%,rgba(243,212,119,1) 48%,rgba(236,206,112,1) 53%,rgba(249,218,124,1) 100%);
  background: -o-linear-gradient(top,  rgba(248,217,122,1) 0%,rgba(243,212,119,1) 48%,rgba(236,206,112,1) 53%,rgba(249,218,124,1) 100%);
  background: -ms-linear-gradient(top,  rgba(248,217,122,1) 0%,rgba(243,212,119,1) 48%,rgba(236,206,112,1) 53%,rgba(249,218,124,1) 100%);
  background: linear-gradient(to bottom,  rgba(248,217,122,1) 0%,rgba(243,212,119,1) 48%,rgba(236,206,112,1) 53%,rgba(249,218,124,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f8d97a', endColorstr='#f9da7c',GradientType=0 );
}

.btn-black{
  color: #fff;
  text-decoration: none;
  border:1px #ccc solid;
  border-radius: 15px;
  background: rgb(125,126,125);
  background: -moz-linear-gradient(top,  rgba(125,126,125,1) 0%, rgba(14,14,14,1) 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(125,126,125,1)), color-stop(100%,rgba(14,14,14,1)));
  background: -webkit-linear-gradient(top,  rgba(125,126,125,1) 0%,rgba(14,14,14,1) 100%);
  background: -o-linear-gradient(top,  rgba(125,126,125,1) 0%,rgba(14,14,14,1) 100%);
  background: -ms-linear-gradient(top,  rgba(125,126,125,1) 0%,rgba(14,14,14,1) 100%);
  background: linear-gradient(to bottom,  rgba(125,126,125,1) 0%,rgba(14,14,14,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#7d7e7d', endColorstr='#0e0e0e',GradientType=0 );
}

.btn-blue{
  color: #fff;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: rgb(20,83,160);
  background: -moz-linear-gradient(top,  rgba(20,83,160,1) 0%, rgba(20,83,160,1) 48%, rgba(3,74,160,1) 53%, rgba(8,76,162,1) 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(20,83,160,1)), color-stop(48%,rgba(20,83,160,1)), color-stop(53%,rgba(3,74,160,1)), color-stop(100%,rgba(8,76,162,1)));
  background: -webkit-linear-gradient(top,  rgba(20,83,160,1) 0%,rgba(20,83,160,1) 48%,rgba(3,74,160,1) 53%,rgba(8,76,162,1) 100%);
  background: -o-linear-gradient(top,  rgba(20,83,160,1) 0%,rgba(20,83,160,1) 48%,rgba(3,74,160,1) 53%,rgba(8,76,162,1) 100%);
  background: -ms-linear-gradient(top,  rgba(20,83,160,1) 0%,rgba(20,83,160,1) 48%,rgba(3,74,160,1) 53%,rgba(8,76,162,1) 100%);
  background: linear-gradient(to bottom,  rgba(20,83,160,1) 0%,rgba(20,83,160,1) 48%,rgba(3,74,160,1) 53%,rgba(8,76,162,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1453a0', endColorstr='#084ca2',GradientType=0 );
}

.btn-red{
  color: #fff;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: rgb(255,48,25);
  background: -moz-linear-gradient(top,  rgba(255,48,25,1) 0%, rgba(207,4,4,1) 100%);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,48,25,1)), color-stop(100%,rgba(207,4,4,1)));
  background: -webkit-linear-gradient(top,  rgba(255,48,25,1) 0%,rgba(207,4,4,1) 100%);
  background: -o-linear-gradient(top,  rgba(255,48,25,1) 0%,rgba(207,4,4,1) 100%);
  background: -ms-linear-gradient(top,  rgba(255,48,25,1) 0%,rgba(207,4,4,1) 100%);
  background: linear-gradient(to bottom,  rgba(255,48,25,1) 0%,rgba(207,4,4,1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ff3019', endColorstr='#cf0404',GradientType=0 );
}

.btn-orange{
  position: relative;
  color: #333;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: #ffaf4b; /* Old browsers */
  background: -moz-linear-gradient(top,  #ffaf4b 0%, #ff920a 100%); /* FF3.6+ */
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffaf4b), color-stop(100%,#ff920a)); /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(top,  #ffaf4b 0%,#ff920a 100%); /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(top,  #ffaf4b 0%,#ff920a 100%); /* Opera 11.10+ */
  background: -ms-linear-gradient(top,  #ffaf4b 0%,#ff920a 100%); /* IE10+ */
  background: linear-gradient(to bottom,  #ffaf4b 0%,#ff920a 100%); /* W3C */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffaf4b', endColorstr='#ff920a',GradientType=0 ); /* IE6-9 */
  background-image: url(/img/arrow-next-bk.png) no-repeat;
}

.btn-green{
  color: #333;
  text-decoration: none;
  border:1px #333 solid;
  border-radius: 15px;
  background: rgb(205,235,142); /* Old browsers */
  background: -moz-linear-gradient(top,  rgba(205,235,142,1) 0%, rgba(165,201,86,1) 100%); /* FF3.6+ */
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(205,235,142,1)), color-stop(100%,rgba(165,201,86,1))); /* Chrome,Safari4+ */
  background: -webkit-linear-gradient(top,  rgba(205,235,142,1) 0%,rgba(165,201,86,1) 100%); /* Chrome10+,Safari5.1+ */
  background: -o-linear-gradient(top,  rgba(205,235,142,1) 0%,rgba(165,201,86,1) 100%); /* Opera 11.10+ */
  background: -ms-linear-gradient(top,  rgba(205,235,142,1) 0%,rgba(165,201,86,1) 100%); /* IE10+ */
  background: linear-gradient(to bottom,  rgba(205,235,142,1) 0%,rgba(165,201,86,1) 100%); /* W3C */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#cdeb8e', endColorstr='#a5c956',GradientType=0 ); /* IE6-9 */
}

input[type="submit"].btn-orange:after{
  content:"";
  position: absolute;
  background: url(/img/arrow-next-bk.png) no-repeat;
  background-size: 10px 10px;
  background-position: right center;
}

input[type="submit"].btn-base:disabled {
  background: #dcdcdc;
  color: #888b7a;
  border: solid 1px #6f6f6f;
}

a.btn-green,
a.btn-orange,
a.btn-base,
a.btn-red,
a.btn-blue,
a.btn-yellow,
button,
input[type="button"],
input[type="submit"]{
  font-size: 1.2rem;
  width: 100%;
  height: 45px;
  display: block;
}

a.btn-green,
a.btn-orange,
a.btn-base,
a.btn-red,
a.btn-blue,
a.btn-yellow {
  line-height: 45px;
  text-align: center;
}


td .btn-base{
  font-size: 1.1rem;
  width: 100%;
  height: auto;
  padding: 5px 0;
  display: block;
  border-radius: 5px;
  line-height: 1;
}

input[type="button"].btn-long{
  font-size: 1.1rem;
}

.add-fml{
  margin-top: 50px;
  border-top: 3px dotted #f7d614;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="number"],
input[type="file"]{
  margin-top: 4px;
}

.agree-check{
  margin: 20px 0 0 0;
}

.agree-check input[type="checkbox"]{
  display: inline-block;
  width: 25px;
  height: 25px;
    -webkit-transform-origin: top left;
    -webkit-transform: scale( 1.4 , 1.4 );
    -moz-transform-origin: top left;
    -moz-transform: scale( 1.4 , 1.4 );      
}

input.invalid,
span.invalid input,
p.invalid input,
li.invalid input
{
background: #fee;
}

.photo_upload img,
.doc_upload img{
  width: 100%;
  height: auto;
  display: block;
  margin: 20px 0;
}



/*=========================
 03 menu
=========================*/

.fmlinfo-group + .fmlinfo-group{
  margin-top: 60px;
}

.fmlinfo-group_header{
  line-height: 1.5;
  margin-bottom: 20px;
}
.fmlinfo-group_header h3{
  text-align: left;
  font-weight: bold;
}
.fmlinfo-group_header .note{
  margin-top: 5px;
}
.fmlinfo-group_body + .fmlinfo-group_body{
  margin-top: 45px;
}

.fmlinfo_box{
  width: 100%;
}
.fmlinfo_box th,
.fmlinfo_box td{
  padding: 10px 5px;
  text-align: center;
  width: 33.33%;
}
.fmlinfo_box_menu th{
  border-bottom: 1px solid #666;
}
.fmlinfo_box_menu--btn{
  width: 30%;
}
.fmlinfo-group_body.fmlinfo-listType .fmlinfo_box,
.fmlinfo-group_body.fmlinfo-listType .fmlinfo_box td{
 border-bottom: 1px solid #ccc;
}

.fmlinfo_btnArea{
  /*width: 40%;*/
  margin: 30px auto 0 auto;
}

.fmlinfo_box.daisan th:first-child{
  width: 66.66%;
}

/*=================================
全サイズ共通終了
=================================*/

/*=================================
768px以上開始
=================================*/
@media screen and (min-width:768px){
html,body{
  height: 100%;
}

.wrapper{
  width: 768px;
  margin: 0 auto;
  border-left: 1px solid #ccc;
  border-right: 1px solid #ccc;
}

.main,
.loading{
  max-width: 500px;
  margin: 0 auto;
}

.row{
  margin: 25px 0 0 0;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="number"],
input[type="file"]{
  width: 98%;
  height: 30px;
  padding: 3px;
  font-size: 1.1rem;
}

input[type="text"].text-mini{
  width: 150px;
}

input[type="text"].number-mini{
  width: 139px;
}

.mn input[type="text"].number-mini{
  width: 153px;
}

.box-number li input[type="text"].number-mini{
  width: 100%;
  box-sizing: border-box;
}

.box-number li{
  display: inline-block;
  width: 33.33%;
}

input[type="button"].btn-mini{
  width: 100px;
  height: 38px;
  border-radius: 5px;
  display: inline;
}

.note{
  line-height:1.5;
  width: 500px;
  margin: 20px auto 0;
  font-size: 1rem;
}

.number-code{
  font-size: 1.5rem;
  text-align: center;
  margin: 20px 0 0 0;
}

.confilm-image{
  text-align: center;
}

.cover {
    display: inline-block;
    background-color: #ccc;
    background-position: center center;
    background-repeat: no-repeat;
    margin: 5px;
    width: 200px;
    height: 200px;
    border: 1px solid #ccc;
    background-size: cover;
}

.image-box{
  display: inline-block;
  width: 48.9%;
}

.confilm .title-menu{
  text-align: center;
}

/*agree list*/
.user-policy h4{
  font-weight: bold;
  font-size: 15px;
  margin: 30px 0 7px 0;
}

.policy-list-wrap{
  border: 3px dashed #084ca2;
  margin: 20px  0 0 0;
  padding: 10px 10px 20px;
}

.policy-list-wrap{
  border: 1px solid #084ca2;
  padding: 5px 10px 10px;
  background-color: #fff;
  border-radius: 10px;
}

.policy-list{
  display: table-row-group;
}

.policy-list dl{
  display: table-row;
}

.policy-list dt,
.policy-list dd {
  display: table-cell;
}

.policy-list dt{
  font-weight: bold;
  padding: 10px 10px 0 0;
}

.policy-list dd{
  line-height: 1.3;
}

}
/*=================================
768px以上終了
=================================*/


/*=================================
767px以下開始
=================================*/
@media screen and (max-width:767px){
body{
  background: #f6f6f6;
}

.wrapper{
  width: 100%;
  overflow: hidden;
}

header h1 img{
  width: 100%;
  vertical-align: bottom; 
}

.main{
  max-width: 767px;
  margin: 30px 10% 0;
}

.row{
  margin: 25px 0 0 0;
}

.form-list{
  font-weight: bold;
  color: #053166;
  margin: 20px 0 0 0;
}

.form-list-child{
  font-weight: bold;  
}

.mb-16{
  margin-bottom: -16px;
}

.form-inline-block{
  display: inline-block;
  width: 30%;
}



/*form*/
input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="number"]{
  width: 97%;
  height: 30px;
  padding: 3px;
  font-size: 1.1rem;
}

input[type="file"]{
  width: 99%;
  padding: 3% 0;
  font-size: 0.6rem;
}

.row p.mn{
  margin: 10px 0 0 0;
}

input[type="text"].number-mini{
  width: 20%;
}

.box-number li input[type="text"].number-mini{
  width: 100%;
  box-sizing: border-box;
  height: 36px;
}

.box-number li{
  display: inline-block;
  width: 33.33%;
  padding: 1px;
  box-sizing: border-box;
}


input[type="button"].btn-mini{
  width: 35%;
  height: 38px;
  border-radius: 5px;
  vertical-align: bottom;
  display: inline;
}

.check-address{
  display: block;
  margin: 4px 0 0 0;
}

input[type="radio"]{
  display: inline-block;
  width: 25px;
  height: 25px;
  box-sizing: border-box;
  vertical-align: 0.5rem; 
}

input[type="radio"] + label{
  display: inline-block;
  vertical-align: 0.7rem;
  font-size: 1.2rem;
}

.form-inline-block + input[type="text"]{
  display: inline-block;
  width: 63%;
}


.note{
  line-height:1.5;
  width: 100%;
  margin: 20px 0 0 0;
  font-size: 1rem;
}

.user-policy h4.small-note,
.small-note{
  font-size: 0.8rem;
}

.user-policy h4.small-note{
  margin-top: 40px;
}

.number-code{
  font-size: 1.5rem;
  text-align: center;
  margin: 20px 0 0 0;
}

.self.complete{
  text-align: left;
}

.innerfooter{  
  width: 100%;
}

.result{
  margin: 10px 0 0 0;
  display: inline-block; 
}

.image-box{
  display: inline-block;
  width: 48%;
  margin: 0 0 10px 0;
}

.confilm-image{
  text-align: center;
  width: 100%;  
}

.confilm-image img{
  max-width: 90%;
  max-height: 173px;
  vertical-align: middle;
}

.cover {
    display: inline-block;
    background-color: #ccc;
    background-position: center center;
    background-repeat: no-repeat;
    margin: 5px;
    width: 100px;
    height: 100px;
    border: 1px solid #ccc;
    background-size: contain;
}

.confilm .title-menu{
  text-align: center;
}

.self.complete a.btn-orange,
.register.complete a.btn-orange{
  font-size: 0.8rem;
}

.register input[type="button"].btn-orange,
.self input[type="button"].btn-orange{
  font-size: 1rem;
}

.agree-check input[type="checkbox"]{
  display: inline-block;
  width: 25px;
  height: 25px;
    -webkit-transform-origin: top left;
    -webkit-transform: scale( 1.1 , 1.1 );
    -moz-transform-origin: top left;
    -moz-transform: scale( 1.1 , 1.1 );      
}

.agree-check {
  margin: 20px auto 0 auto;
}

.agree-check label{
  line-height: 25px;
  margin: 0 0 0 5px;
}

/*agree list*/
.user-policy h4{
  font-weight: bold;
  font-size: 15px;
  margin: 30px 0 7px 0;
}

.policy-list-wrap{
  border: 3px dashed #084ca2;
  margin: 20px  0 0 0;
  padding: 10px 10px 20px;
}

.policy-list-wrap{
  border: 1px solid #084ca2;
  padding: 5px 10px 10px;
  background-color: #fff;
  border-radius: 10px;
}

.policy-list{
  display: table-row-group;
}

.policy-list dl{
  display: table-row;
}

.policy-list dt,
.policy-list dd {
  display: table-cell;
}

.policy-list dt{
  font-weight: bold;
  padding: 10px 10px 0 0;
}

.policy-list dd{
  line-height: 1.3;
}

/*========inline-box=========*/

.self input[type="text"].number-mini{
  width: 30%;
  box-sizing: border-box;
  height: 36px;
}

.self span.hyphen{
    width: 5%;
    display: inline-block;
    text-align: center;
    padding: 0;
}

body.haigusha p.mn,
body.hihokensha p.mn,
body.register p.mn,
body.self p.mn,
body.fuyou p.mn{
  margin-left: -3%;
}

body.haigusha p.mn input[type="text"].number-mini,
body.hihokensha p.mn input[type="text"].number-mini,
body.register p.mn input[type="text"].number-mini,
body.self p.mn input[type="text"].number-mini,
body.fuyou p.mn input[type="text"].number-mini {
    width: 30.33%;
    box-sizing: border-box;
    height: 36px;
    margin: 0 0 0 3%;
}

.haigusha .form-inline-block,
.hihokensha .form-inline-block,
.self .form-inline-block,
.fuyou .form-inline-block{
  width: 45.99%;
}

span.warning_color{
  color: #900;
  font-size: 0.7rem;
}

.haigusha .form-inline-block + input[type="text"],
.hihokensha .form-inline-block + input[type="text"],
.self .form-inline-block + input[type="text"],
.fuyou .form-inline-block + input[type="text"]{
  display: inline-block;
  width: 54%;
  box-sizing: border-box;
  height: 36px;
}

/*.haigusha .form-inline-block + .message + input[type="text"],
.hihokensha .form-inline-block + .message + input[type="text"],
.self .form-inline-block + .message + input[type="text"],
.fuyou .form-inline-block + .message + input[type="text"] {
  display: inline-block;
  width: 69%;
  margin: 0 0 0 30.99%;
}*/

.self input[type="button"].btn-mini{
  width: 32%;
  margin: 0 0 0 3%;
  box-sizing: border-box;
  display: inline-block;
}

/*.form-inline-block + .message{
  margin: 0;
  display: inline-block !important;
  width: 69%;
}

.form-inline-block + .message + input[type="text"] {
  display: inline-block;
  width: 60%;
  margin: 0 0 0 30%;
}*/

/*========inlinebox=========*/


}

/*=================================
767px以下終了
=================================*/