@charset "UTF-8";

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

body {
    line-height: 1;
    font-family: Lato, "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

.ent-50-ttl {
    font-size: 20px;
    font-weight: 600;
    margin-top: 1em;
    margin-bottom: .4em;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    color: #fff;
}

.ent-50-ttl__in {
    position: relative;
}

.ent-50-ttl__in::before {
    content: "";
    display: block;
    width: 20px;
    height: 2px;
    background-color: #ffffff;
    position: absolute;
    left: -35px;
    top: 50%;
    transform: translateY(-50%);
}

.ent-50-ttl__in::after {
    content: "";
    display: block;
    width: 20px;
    height: 2px;
    background-color: #ffffff;
    position: absolute;
    right: -35px;
    top: 50%;
    transform: translateY(-50%);
}

.ent-50-form {
    max-width: 1200px;
    /* border: 1px solid #eceff3; */
    margin: 0 auto;
    padding: 1.4em 10px;
    background: #fff;
}

.ent-50-form-box {
    margin-bottom: 1em;
}

.ent-50-form-txt {
    margin-bottom: .2em;
    display: flex;
    align-items: center;
    font-weight: bold;
    margin-bottom: 0.8em;
}

.form-items {
    margin-bottom: 1.5em;
}

@media screen and (min-width: 992px) {
    .form-items {
        margin-bottom: 0;
    }
}

.ent-50-form-txt::before {
    content: "";
    border-top: 6px solid #cfcfcf;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    margin-right: .4em;
}

.ent-50-form-input {
    max-width: 100%;
    width: 100%;
}

.ent-50-form-input input[type=text] {
    width: 100%;
    border: 1px solid #dfdfdf;
    padding: .2em .6em;
    height: 44px;
    border-radius: 0.2em;
}

.ent-50-form-input-sm input[type=text] {
    width: 60%;
    border: 1px solid #dfdfdf;
    padding: .2em .6em;
    height: 44px;
    border-radius: 0.2em;
}

.ent-50-form-select select {
    border: 1px solid #dfdfdf;
    padding: .2em .6em;
    height: 44px;
    border-radius: 0.2em;
}

.ent-50-form-submit {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.ent-50-form-submit input[type=submit] {
    display: block;
    width: 180px;
    padding: .8em .6em;
    background-color: #007bff;
    border: none;
    border-radius: .25rem;
    color: #ffffff;
    font-weight: 600;
    cursor: pointer;
}

.ent-50-flow-list {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 !important;
}

.ent-50-flow-list__item {
    font-size: 12px;
    font-weight: 600;
    padding: .6em 1em;
    background-color: #eceff3;
    margin-right: 1em;
}

.ent-50-flow-list__item:last-of-type {
    margin-right: 0;
}

.ent-50-flow-list__item-on {
    background-color: #007bff;
    color: #ffffff;
}

.p-form-ttl-sub-body {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.c-basic-form__btn-wrap {
    display: flex;
    justify-content: center;
    align-items: center;
}

.c-basic-form__btn-wrap button {
    margin-right: 1em;
}

.c-basic-form__btn-wrap button:last-of-type {
    margin-right: 0;
}

.c-basic-form__btn {
    font-weight: 600;
    width: 120px;
}

.form-req::after {
    content: "※";
    color: red;
    font-weight: 600;
}

.btn-primary {
    /* color: #fff; */
    /* background-color: #bf4343; */
    /* border: inherit; */
}

/* ==============================================================
================================================================*/


@media screen and (min-width:768px) {

    .ent-50-ttl {
        font-size: 2em;
        font-weight: 600;
    }

    .ent-50-form {
        padding: 3em 2em;
    }

    .ent-50-form-box {
        display: flex;
        border-bottom: 1px solid #eceff3;
        padding: 1em 0;
        margin-bottom: 0;
    }

    .ent-50-form-box:first-of-type {
        border-top: 1px solid #eceff3;
    }

    .ent-50-form-txt {
        min-width: 260px;
        margin-bottom: 0;
    }

    .ent-50-form-txt::before {
        display: none;
    }

    .ent-50-form-input {
        margin-bottom: 0 !important;
    }

    .ent-50-form-input-sm {
        margin-bottom: 0 !important;
    }

    .ent-50-form-select {
        margin-bottom: 0 !important;
    }

    .ent-50-flow-list__item {
        font-size: 14px;
    }
}

.base-txt-red {
    color: red;
}

.base-txt-bold {
    font-weight: 600;
}

.base-mb-md {
    margin-bottom: 2em;
}


.form-content-radio-label {
    display: inline-block;
    margin-right: 0.5em;
    cursor: pointer;
    position: relative;
}

.form-content-radio-label input[type="radio"] {
    /* display: none; */ /* ラジオボタン自体を非表示 */
    position: absolute;
    top: 36%;
    left: 0.5em;
    width: 10px;
}

.form-content-radio-label span {
    display: inline-block;
    border: solid 1px #dfdfdf;
    padding: 0.5em;
    border-radius: 0.2em;
    transition: background-color 0.3s, border-color 0.3s;
    /* min-width: 9em; */
    text-align: left;
    padding: 0.5em 0.7em 0.5em 1.3em;
    letter-spacing: -0.01em;
}

.form-content-radio-label input[type="radio"]:checked + span {
    background-color: #e6f0ff;
    border-color: #007bff;
    font-weight: bold;
}

/*=========================================================*/

/*PCとSPの見え方切り替え*/
.pc-show {
    display: none !important;
}

@media screen and (min-width: 992px) {
    .pc-show {
        display: block !important;
    }
}

@media screen and (min-width: 992px) {
    .sp-show {
        display: none !important;
    }
}

@media screen and (min-width: 992px) {
    .u-pc-center {
        text-align: center;
    }
}

.u-sp-center {
    text-align: center;
}

@media screen and (min-width: 992px) {
    .u-sp-center {
        text-align: left;
    }
}

.c-text-description {
    color: white;
    text-align: center;
    font-size: large;
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.8;
    margin-top: 2em;
}

@media screen and (min-width: 992px) {
    .c-text-description {
        font-size: 16px;
    }

}

.form-bnrarea {

    display: flex;

    flex-direction: row;

    padding: 0.5em;

    border: solid 1px #fff;

    margin-top: 1.5em;

    padding: 0.8em 0.2em;

    justify-content: center;
}

.form-bnrarea div {
    margin-right: 2%;
    text-align: center;
    /* max-width: 29%; */
    display: block;
}

@media screen and (min-width: 992px) {
    .form-bnrarea div {

        width: inherit;

        margin-right: 6%;

    }
}



.form-bnrarea div:last-child {
    margin-right: 0;

}

.form-bnrarea img {
    display: inline-block;
    height: auto;
    max-width: 100%;
    /* height: 27px; */
    display: block;
}

@media screen and (min-width: 992px) {
    .form-bnrarea img {
        height: 40px;

        width: inherit;
    }
}


}

@media screen and (min-width: 992px) {

    .form-bnrarea {

        justify-content: center;

    }
}



.footer-logo a {
    text-align: center;
}

.footer-logo img {
    text-align: center;
    max-width: 120px;
    display: inline-block;
    height: auto;
    max-width: 100%;
    width: 127px;
}

@media screen and (min-width: 992px) {

    .footer-logo img {

        max-width: 180px;
        width: 140px;
    }

}



.footer-copy {
    font-size: 12px;
    color: #fff;
    text-align: center;
    margin-top: 1.2em;
    margin-bottom: 0.5em;
}

.form-horizontal .alert-info {
    background: #fff !important;
    text-align: center !important;
    border: inherit !important;
    padding: 2em 1em !important;
    color: #171f47;
}

textarea {
    border: 1px solid #dfdfdf;
    padding: .2em .6em;
    border-radius: 0.2em;
}

.c-responsive-img {
    display: inline-block;
    height: auto;
    max-width: 100%;
}

img {}

.error {
    margin: 1em;
    padding-top: 1em;
}


.p-present {
    margin-bottom: 40px;
}

@media screen and (min-width: 992px) {
    .p-present {}
}

.p-present .p-present__list {
    display: flex;
    flex-wrap: wrap;
}

@media screen and (min-width: 992px) {
    .p-present .p-present__list {
        justify-content: center;
    }
}

.p-present .p-present__item {
    width: 100%;
    padding: 4px;
}

@media screen and (min-width: 992px) {
    .p-present .p-present__item {
        width: 33.3%;
        padding: 5px;
    }
}

.p-present img {
    width: 100%;
}

@media screen and (min-width: 992px) {
    .p-present img {}
}
.p-present .p-present__text {
    background: #455291;
    margin-top: 1em;
    border-radius: 0.2em;
    padding: 0.8em;
    letter-spacing: 0.05em;
    line-height: 1.6;
    color: #fff;
    font-size: 13px;
    margin-bottom: 2em;
}

@media screen and (min-width: 992px) {
    .p-present .p-present__text {
        font-size: 16px;
        min-height: 6.5em;
        padding: 0.6em;
        letter-spacing: 0;
    }
}

select {
    max-width: 99% !important;
}

