body {
    background: transparent;
}

main {
    z-index: 1;
}

.container {
    border: none;
    max-width: inherit;
    padding: 0 0 30px;
    background: none;
}

@media all and (min-width: 899px) {
    .container {
        padding: 100px 0;
    }
}

.content-form,
.content-confirmation,
.content-complete,
#message-container {
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
    padding-left: 20px;
    padding-right: 20px;
}

@media all and (min-width: 899px) {

    .content-form,
    .content-confirmation,
    .content-complete,
    #message-container {
        max-width: 940px;
        margin-left: auto;
        margin-right: auto;
        padding-right: 10px;
        padding-left: 10px;
        box-sizing: border-box;
    }
}

.content-form .form-column,
.content-confirmation .form-column {
    position: relative;
    padding: 30px 0;
    margin-bottom: 0;
    border: none;
    border-top: 1px dotted #C1C1C1;
}


.content-form .form-column .label,
.content-confirmation .form-column .label {
    width: 100%;
    font-size: 1.3rem;
    font-weight: 400;
    position: relative;
    line-height: 1.8;
    margin-bottom: 5px;
    padding: 0;
}

@media all and (min-width: 899px) {

    .content-form .form-column,
    .content-confirmation .form-column {
        padding: 22px;
        border-top: 1px solid #C1C1C1;
        display: -webkit-box;
        display: flex;
        flex-wrap: wrap;
        -webkit-box-pack: start;
        justify-content: flex-start;
        -webkit-box-align: center;
        align-items: center;
    }

    .content-form .form-column:before,
    .content-confirmation .form-column:before {
        content: '';
        display: block;
        position: absolute;
        left: 0px;
        top: -1px;
        width: 240px;
        height: 1px;
        background: #357EEC;
    }

    .content-form .form-column .description-block {
        margin-left: 240px;
    }

    .content-form .form-column-note .description-block {
        margin-left: auto;
    }

    .content-form .form-column .label,
    .content-confirmation .form-column .label {
        width: 240px;
        flex-shrink: 0;
        font-size: 1.5rem;
        line-height: 1.55;
        margin-bottom: 0;
    }
}

.content-form .form-column .label .badge-required,
.content-confirmation .form-column .label .badge-required {
    display: inline-block;
    font-size: 1.3rem;
    font-weight: normal;
    color: #fff;
    text-align: center;
    letter-spacing: 0.075em;
    width: 45px;
    height: 22px;
    border-radius: 0;
    line-height: 23px;
    background-color: #357EEC;
    margin-right: 15px;
    float: left;
    margin-left: 0;
    padding: 0;
}

@media all and (max-width: 898px) {

    .content-form .form-column .label .badge-required,
    .content-confirmation .form-column .label .badge-required {
        margin-left: 0;
    }
}

.content-form .form-column-note,
.content-confirmation .form-column-note {
    padding: 15px 0;
}

@media (min-width: 899px) {

    .content-form .form-column-note,
    .content-confirmation .form-column-note {
        padding: 30px 0;
    }
}

.content-form .description-block p,
.content-confirmation .description-block p {
    letter-spacing: .05em;
    line-height: 2;
    font-size: 1.4rem;
    margin-top: 18px;
    color: #333;
}

@media (min-width: 899px) {

    .content-form .description-block p,
    .content-confirmation .description-block p {
        margin-top: 22px;
        font-size: 1.5rem;
    }
}

.content-form .description-block p a,
.content-confirmation .description-block p a {
    text-decoration: underline;
}

.content-form .button-group,
.content-confirmation .button-group {
    margin-top: 10px;
    text-align: center;
}

@media all and (min-width: 899px) {

    .content-form .button-group,
    .content-confirmation .button-group {
        margin-top: 40px;
    }
}

.content-form .button-group .button-confirm,
.content-form .button-group .button-submit,
.content-confirmation .button-group .button-confirm,
.content-confirmation .button-group .button-submit {
    text-align: center;
    background-color: #0064B8;
    border: none;
    height: 50px;
    color: #fff;
    border: 1px solid #0064B8;
    font-weight: bold;
    width: 80%;
    font-size: 1.4rem;
    letter-spacing: .075em;
    margin-bottom: 50px;
    border-radius: 0;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
    cursor: pointer;
}

@media all and (min-width: 899px) {

    .content-form .button-group .button-confirm,
    .content-form .button-group .button-submit,
    .content-confirmation .button-group .button-confirm,
    .content-confirmation .button-group .button-submit {
        -webkit-transition: all 0.3s linear;
        transition: all 0.3s linear;
        overflow: hidden;
        display: block;
        position: relative;
        z-index: 1;
        width: 400px;
        height: 60px;
        font-size: 1.5rem;
        display: inline-block;
    }

    .content-form .button-group .button-confirm:before,
    .content-form .button-group .button-submit:before,
    .content-confirmation .button-group .button-confirm:before,
    .content-confirmation .button-group .button-submit:before {
        z-index: -1;
        position: absolute;
        content: '';
        display: block;
        width: 0;
        left: 0;
        top: 0;
        width: 130%;
        height: 100%;
        -webkit-transform-origin: right top;
        transform-origin: right top;
        -webkit-transform: skewX(-30deg) scale(0, 1);
        transform: skewX(-30deg) scale(0, 1);
        background-color: #fff;
        -webkit-transition: -webkit-transform 0.5s ease;
        transition: -webkit-transform 0.5s ease;
        transition: transform 0.5s ease;
        transition: transform 0.5s ease, -webkit-transform 0.5s ease;
    }

    .content-form .button-group .button-confirm:hover:before,
    .content-form .button-group .button-submit:hover:before,
    .content-confirmation .button-group .button-confirm:hover:before,
    .content-confirmation .button-group .button-submit:hover:before {
        -webkit-transform-origin: left top;
        transform-origin: left top;
        -webkit-transform: skewX(-30deg) scale(1, 1);
        transform: skewX(-30deg) scale(1, 1);
    }

    .content-form .button-group .button-confirm:hover,
    .content-form .button-group .button-submit:hover,
    .content-confirmation .button-group .button-confirm:hover,
    .content-confirmation .button-group .button-submit:hover {
        color: #0064B8;
    }
}

.content-form .button-group .button-back,
.content-confirmation .button-group .button-back {
    text-align: center;
    background-color: #fff;
    border: none;
    height: 50px;
    color: #0064B8;
    border: 1px solid #0064B8;
    font-weight: bold;
    width: 80%;
    font-size: 1.4rem;
    letter-spacing: .075em;
    margin-bottom: 50px;
    border-radius: 0;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
    cursor: pointer;
}

@media all and (max-width: 898px) {

    .content-form .button-group .button-back,
    .content-confirmation .button-group .button-back {
        margin-bottom: 15px;
    }
}

@media all and (min-width: 899px) {

    .content-form .button-group .button-back,
    .content-confirmation .button-group .button-back {
        width: 400px;
        height: 60px;
        font-size: 1.5rem;
        display: inline-block;
        -webkit-transition: all 0.3s linear;
        transition: all 0.3s linear;
    }

    .content-form .button-group .button-back:hover,
    .content-confirmation .button-group .button-back:hover {
        color: #989898;
        border-color: #989898;
        background-color: #F4F5F6;
    }
}

.content-form .button-group button,
.content-confirmation .button-group button {
    margin: 0 10px;
}

/* 送信画面 */
.content-form input[type="text"],
.content-form input[type="email"],
.content-form input[type="tel"],
.content-form textarea {
    box-sizing: border-box;
    padding: .5em .8em;
    background: #fff;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    font-size: 1.4rem;
    border-radius: 0;
    border: none;
    background: #F4F5F6;
}

@media all and (min-width: 899px) {

    .content-form input[type="text"],
    .content-form input[type="email"],
    .content-form input[type="tel"],
    .content-form textarea {
        font-size: 1.5rem;
    }
}

.content-form input[type="text"]::-webkit-input-placeholder,
.content-form input[type="email"]::-webkit-input-placeholder,
.content-form input[type="tel"]::-webkit-input-placeholder,
.content-form textarea::-webkit-input-placeholder {
    color: #969696;
}

.content-form input[type="text"]::-moz-placeholder,
.content-form input[type="email"]::-moz-placeholder,
.content-form input[type="tel"]::-moz-placeholder,
.content-form textarea::-moz-placeholder {
    color: #969696;
}

.content-form input[type="text"]:-ms-input-placeholder,
.content-form input[type="email"]:-ms-input-placeholder,
.content-form input[type="tel"]:-ms-input-placeholder,
.content-form textarea:-ms-input-placeholder {
    color: #969696;
}

.content-form input[type="text"]::placeholder,
.content-form input[type="email"]::placeholder,
.content-form input[type="tel"]::placeholder,
.content-form textarea::placeholder {
    color: #969696;
}

@media all and (min-width: 899px) {

    .content-form input[type="text"]::-webkit-input-placeholder,
    .content-form input[type="email"]::-webkit-input-placeholder,
    .content-form input[type="tel"]::-webkit-input-placeholder,
    .content-form textarea::-webkit-input-placeholder {
        font-size: 1.6rem;
    }

    .content-form input[type="text"]::-moz-placeholder,
    .content-form input[type="email"]::-moz-placeholder,
    .content-form input[type="tel"]::-moz-placeholder,
    .content-form textarea::-moz-placeholder {
        font-size: 1.6rem;
    }

    .content-form input[type="text"]:-ms-input-placeholder,
    .content-form input[type="email"]:-ms-input-placeholder,
    .content-form input[type="tel"]:-ms-input-placeholder,
    .content-form textarea:-ms-input-placeholder {
        font-size: 1.6rem;
    }

    .content-form input[type="text"]::placeholder,
    .content-form input[type="email"]::placeholder,
    .content-form input[type="tel"]::placeholder,
    .content-form textarea::placeholder {
        font-size: 1.6rem;
    }
}

.content-form input[type="text"],
.content-form input[type="email"],
.content-form input[type="tel"] {
    height: 38px;
}

@media all and (min-width: 899px) {

    .content-form input[type="text"],
    .content-form input[type="email"],
    .content-form input[type="tel"] {
        max-width: 400px;
    }

    .content-form textarea {
        max-width: 600px;
    }
}

.content-form input[type="radio"],
.content-form input[type="checkbox"] {
    vertical-align: -1px;
}

.content-form textarea {
    width: 100%;
    height: 130px;
}

@media all and (min-width: 899px) {
    .content-form textarea {
        height: 200px;
    }
}

.content-form .input-group label {
    font-size: 1.3rem;
    font-weight: 400;
    margin-top: 1em;
}

@media all and (min-width: 899px) {
    .content-form .input-group label {
        margin-top: 0;
        font-size: 1.5rem;
    }
}

.content-form .input-group label+label {
    margin-top: 1em;
}

.content-form .form-column[data-column="個人情報の取り扱いについて"] {
    border: none;
    text-align: center;
    padding: 0 0 30px;
}

.content-form .form-column[data-column="個人情報の取り扱いについて"]:before {
    content: none;
}

.content-form .form-column[data-column="個人情報の取り扱いについて"] .label {
    display: none;
}

.content-form .form-column[data-column="個人情報の取り扱いについて"] .input-group {
    display: inline-block;
    margin: 0 auto;
}

.content-form .form-column[data-column="個人情報の取り扱いについて"] .input-group label {
    font-size: 1.5rem;
}

@media (min-width: 899px) {
    .content-form .form-column[data-column="個人情報の取り扱いについて"] .input-group label {
        font-size: 1.8rem;
    }
}


}


/* 確認画面 */
.content-confirmation .message-block {
    letter-spacing: .05em;
    line-height: 2;
    font-size: 1.4rem;
    margin-top: 5px;
    text-align: center;
    margin-bottom: 10px;
    color: #333;
}

.message-block-error{
    text-align: left;
}

@media all and (min-width: 899px) {
    .message-block {
        font-size: 1.5rem;
    }
}

.content-confirmation .form-column .description-block {
    display: none;
}


.content-confirmation .preview-block {
    font-size: 1.3rem;
}

@media all and (min-width: 899px) {
    .content-confirmation .preview-block {
        font-size: 1.5rem;
    }
}

.content-confirmation .form-column[data-column="個人情報の取り扱いについて"] {
    display: none;
}
.content-confirmation .form-column[data-column="テキスト表示エリア"] {
    display: none;
}

#message-container,
.form-column[data-column="introduction_text"] {
    display: block;
    padding: 0;
    border: none;
    text-align: center;
}

@media all and (min-width: 899px) {

    #message-container,
    .form-column[data-column="introduction_text"] {
        padding: 0 0 30px;
    }
}

.form-column[data-column="introduction_text"]::before {
    display: none;
}

.content-confirmation .form-column[data-column="introduction_text"] {
    display: none;
}


.message-block-complete {
    height: 200px;
    font-size: 1.5rem;
    line-height: 2;
    text-align: center;
}

/* 202302追記 */
fieldset {
    display: contents;
}

@media all and (min-width: 899px) {
    .fieldset {
        /* IE用 */
        display: flex;
        align-items: center;
    }
}

.form-column[data-column="個人情報の取り扱いについて"] fieldset {
    border: none;
    display: block;
    width: 100%;
}