@charset "utf-8";
/*--------------------------------------------------------
    会員情報
--------------------------------------------------------*/
.form-sec .comp-name th, 
.form-sec .add-sec th {
    padding-top: 15px;
}
.form-sec table ,.form-sec td,.form-sec th {
    border: 1px solid #e7e7e7;
    border-collapse: collapse;
}
.form-sec td,.form-sec th {
    padding: 3px;
    width: 30px;
    height: 25px;
}
.form-sec th {
    background: #e7e7e7;
    font-size: 14px;
    font-weight: bold;
    color: #000;
    vertical-align: top;
    text-align: left;
    padding: 21px 10px 7px 10px;
    width: 243px;
    border-bottom: 1px solid #fff;
    line-height: 1.2;
}
.form-sec td {
    width: 895px;
    padding: 11px 30px;
}
.form-sec .even {
    background: #fbf8f0;
}
.form-sec .odd {
    background: #fefcf9;
}
.form-sec .required {
    font-size: 13px;
    color: #fff;
    background: #ff7520;
    width: 40px;
    display: block;
    padding: 4px 0;
    float: right;
    text-align: center;
    position: relative;
    bottom: 4px;
}
.item-ttl {
    display: block;
    float: left;
}
.input-outer {
    border: 1px solid #cccccc;
    margin-top: 5px;
    padding: 5px 13px 5px 0;
    width: 445px;
}
.input-outer p {
    display: inline-block;
    padding: 3px 0 3px 0;
    border-right: 1px solid #ccc;
    font-size: 13px;
    width: 70px;
    text-align: center;
    vertical-align: middle;
}
.input-outer input {
    border: none;
    display: inline-block;
    width: 359px;
    outline: none;
    vertical-align: middle;
    height: 20px;
}

.eazy-add p {
    display: inline-block;
    font-size: 16px;
    font-weight: bold;
    padding: 6px 0 3px 32px;
    background: url(/images/search/icon_search.png) no-repeat left;
    margin: 0 26px 0 0;
    vertical-align: middle;
}
.eazy-add input {
    display: inline-block;
    width: 250px;
    height: 30px;
    margin: 0 10px 0 0;
    vertical-align: middle;
}
.eazy-add button {
    width: 160px;
    background: #0c8400;
    border: none;
    padding: 7px 0;
    color: #fff;
    font-size: 14px;
    display: inline-block;
    vertical-align: middle;
}
.eazy-add button:hover {
    opacity: 0.7;
}
.eazy-add {
    background: #e7e7e7;
    width: 640px;
    padding: 5px 12px;
    font-size: 0;
    border-radius: 5px;
    text-align: center;
    margin: 5px 0 0 0;
}
.input-outer.add {
    width: 570px;
}
.form-add select {
    width: 330px;
    height: 33px;
    display: block;
    margin-top: 5px;
    border: 1px solid #cccccc;
    background: url(/images/search/icon_select.png) no-repeat 320px;
    cursor: pointer;
}
.password:last-child th {
    border-bottom: 1px solid #e7e7e7;
}
.build-license select {
    background: url(/images/search/icon_select.png) no-repeat 320px;
    border: 1px solid #cccccc;
}
.form-add select:last-child {
    margin-bottom: 0;
}
.form-tel input, .form-tel div, .form-tel div p {
    display: inline-block;
    vertical-align: middle;
}
.comp-same th {
    background: #fff;
    border-bottom: 1px solid #e7e7e7;
    vertical-align: middle;
    padding: 10px;
}
input {
    height: 28px;
    padding: 2px 5px;
    border: 1px solid #cccccc;
}
.confirm input {
    height: 13px;
    vertical-align: -2px;
}
.form-mail td input {
    width: 560px;
}
.comp-same th input[type="checkbox"] {
    height: auto;
}
.input-wrap {
    margin: 0 0 5px 0;
}
.input-wrap:last-child{
    margin: 0;
}
.form-tel th {
    width: 232px;
}
.form-tel td {
    width: 322px;
}
.form-tel td input {
    width: 310px;
}
.change-pass-wrap input {
    height: auto;
    vertical-align: middle;
    margin: 0 5px 0 0;
}
.change-pass-wrap p, 
.build-license select,
 .build-license div{
    display: inline-block;
    vertical-align: middle;
}
.item-description {
    font-size: 12px;
    color: #e60012;
    font-weight: bold;
    display: inline-block;
    vertical-align: bottom;
    padding: 31px 0 0 12px;
    position: relative;
}
.person-charge .input-wrap .input-outer {
    display: inline-block;
    width: 350px;
    vertical-align: middle;
}
.person-charge .input-wrap input {
    width: 264px;
}
.person-charge .input-wrap .input-outer {
    margin: 0;
}
.password input,
.loginId input[type="text"] {
    width: 654px;
    margin-top: 5px;
}
.password p {
    font-size: 13px;
    color: #000;
}
label {
    cursor: pointer;
}
select {
    height: 30px;
    cursor: pointer;
}
button{
    cursor: pointer;
}
.build-license select{
    width: 335px;
    display: inline-block;
}
.license-num {
    width: 45px;
    margin: 0 5px;
}
.license-issue {
    width: 110px;
    margin: 0 5px;
}
.build-license .license-description {
    font-size: 13px;
    color: #b5b5b5;
    display: inline-block;
    margin: 0 0 0 5px;
}
.mail-add input {
    width: 560px;
}
:placeholder-shown {
    color: #b5b5b5; }

/* Google Chrome, Safari, Opera 15+, Android, iOS */
::-webkit-input-placeholder {
    color: #b5b5b5; }

/* Firefox 18- */
:-moz-placeholder {
    color: #b5b5b5; opacity: 1; }

/* Firefox 19+ */
::-moz-placeholder {
    color: #b5b5b5; opacity: 1; }

/* IE 10+ */
:-ms-input-placeholder {
    color: #b5b5b5; }

.bt-send {
    font-size: 25px;
    font-weight: bold;
    color: #fff;
    background: #0c8400;
    border: none;
    width: 420px;
    box-shadow: 0 5px 0 #0b5903;
    padding: 15px 0 9px;
}
.c-checkbox span {
    font-weight: normal;
    vertical-align: middle;
}
.btn.bt-send:hover,.bt-return:hover {
    position: relative;
    top: 5px;
    box-shadow: 0 0 0;
    text-decoration: none;
}
.bt-return {
    font-size: 25px;
    font-weight: bold;
    color: #0c8400;
    background: #fff;
    border: 2px solid #0c8400;
    width: 326px;
    box-shadow: 0 5px 0 #0b5903;
    padding: 13px 0 8px;
    outline: none;
}
select {
  -moz-appearance: none;
  text-indent: 0.01px;
  text-overflow: '';
}
select::-ms-expand {
  display: none;
}
select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
  margin: 0;
  padding: 0 5px;
  background: none transparent;
  vertical-align: middle;
  font-size: inherit;
  box-sizing: content-box;
  border-color:#cccccc;
}
.bracket {
    font-size: 21px;
    vertical-align: middle;
}
.item-description:before {
    content: "※";
    position: absolute;
    left: 0;
}


/*ラジオボックス*/
.radiobox-wrap input{
    display: none;
}
.radiobox-wrap label {
    display: inline-block;
    position: relative;
    cursor: pointer;
    margin-left: 18px;
    padding: 10px 14px;
    border-radius: 2px;
    color: #3e4956;
    font-size: 14px;
    text-align: center;
    line-height: 1;
}
.radiobox-wrap label:before {
    position: absolute;
    content: "";
    top: 50%;
    left: -9px;
    width: 16px;
    height: 16px;
    margin-top: -9px;
    background: linear-gradient(to bottom, #fbfbfb, #d3d3d3);
    border-radius: 50%;
    border: 1px solid #a8a8a8;
}
.radiobox-wrap input[type="radio"]:checked + label:after {
    position: absolute;
    content: "";
    top: 50%;
    left: -4px;
    width: 8px;
    height: 8px;
    margin-top: -4px;
    border-radius: 50%;
    background: #4d4d49;
}
.radiobox {
    display: inline-block;
}
.radiobox-wrap {
    font-size: 0;
}

.comp-same .radiobox-wrap label:before {
    position: absolute;
    content: "";
    top: 50%;
    left: -9px;
    width: 16px;
    height: 16px;
    margin-top: -9px;
    background: linear-gradient(to bottom, #fbfbfb, #d3d3d3);
    border-radius: 0;
    border: 1px solid #a8a8a8;
}

/*チェックボックス*/
/* input要素の代替 */
.c-checkbox__input {
    position: relative;
    display: inline-block;
    vertical-align: bottom;
    width: 16px;
    height: 16px;
}
.c-checkbox__input::before,
.c-checkbox__input::after{
    content: "";
    display: block;
    position: absolute;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

/* input要素の代替（外側） */
.c-checkbox__input::before {
    width: 16px;
    height: 16px;
    border: 1px solid #ccc;
    top: 0;
    left: 0;
    background: linear-gradient(to bottom, #fbfbfb, #d3d3d3);
}

/* 本来のinput[type="checkbox"]を非表示 */
.c-checkbox input[type="checkbox"]{
    display: none;
}

/* input要素の代替（外側）：チェック後 */
.c-checkbox input[type="checkbox"]:checked + .c-checkbox__input::before{
    background-color: #fcfcfc;
    border-radius: 0;
}

/* input要素の代替（内側）：チェック後 */
.c-checkbox input[type="checkbox"]:checked + .c-checkbox__input::after {
    width: 16px;
    height: 16px;
    top: 2px;
    left: 3px;
    content: "✔";
    border-radius: 0;
}
.form-sec th.last {
    border-bottom: 1px solid #e7e7e7;
}
.multiple-bt{
    text-align: center;
}
.btnwrap {
    display: inline-block;
}
.input-outer.add input {
    width: 483px;
}

.required {
    font-size: 25px;
    color: #0c8301;
    font-weight: bold;
}
.issue {
    font-size: 13px;
    color: #000000;
}
.multiple-bt .btnwrap:first-child {
    margin: 0 20px 0 0;
}
.already-member {
    text-align: center;
}
.c-checkbox .already-check {
    font-size: 15px;
    font-weight: bold;
    color: #e60012;
}
.check-description {
    font-size: 13px;
}
.alreadywrap {
    padding: 20px 40px 35px;
}
.already-member {
    margin: 0 0 25px 0;
}
.registration {
    margin: 0 0 20px 0;
}
.form-mobile input {
    width: 322px;
}
.already-member .c-checkbox input[type="checkbox"]:checked + .c-checkbox__input::after {
    top: 0px;
    left: 0px;
}
.registration p {
    text-align: center;
}
.confirm dt {
    float: left;
    font-size: 14px;
    font-weight: bold;
    padding: 5px;
    border-right: 1px solid #ccc;
}
.confirm dd {
    float: left;
    padding: 5px;
    font-size: 14px;
}
.confirm.form-sec th {
    padding: 20px 10px 7px 10px;
}
.confirm.form-sec td {
    padding: 5px 30px;
}
.confirm .description {
    color: #e60012;
    font-weight: bold;
}
.bt-return-top {
    outline: none;
    background: #ff751f;
    color: #fff;
    width: 500px;
    font-size: 27px;
    display: block;
    padding: 17px 0;
    box-shadow: 0 5px 0 #ae4c0f;
    font-weight: bold;
}
.bt-return-top:hover {
    position: relative;
    top: 5px;
    box-shadow: 0 0 0;
    text-decoration: none;
}
.error-area {
    padding: 10px
}
.complete {
    padding: 40px 0 5px;
}
.complete p {
    font-size: 16px;
    color    : #000;
    text-align: center;
    margin: 0 0 30px 0;
}
.complete p span {
    display: block;
}
.complete p .bottom-contact {
    font-size: 14px;
    font-weight: bold;
    margin: 10px 0 0 0;
}
.complete p.title-txt {
    font-size: 36px;
    font-weight: bold;
    color: #0c8301;
    margin: 0 0 10px 0;
}
.complete p.attention {
    font-size: 13px;
}
.complete p.description {
    font-size: 13px;
    text-align: left;
    margin: 5px 0 0 0;
}
.error {
    padding: 40px 0 5px;
}
.error p {
    font-size: 16px;
    color: #000;
    text-align: center;
    margin: 0 0 30px 0;
}
.policy-link-area {
    text-align: center;
    margin-bottom: 20px;
}
.policy-link-area a {
    color: #07519A;
}
.policy-link-area a:hover {
    color: #CC0000;
}