@charset "UTF-8";
/* CSS Document */
#overlay{
    position: fixed;
    top: 0;
    z-index: 9999;
    width: 100%;
    height:100%;
    display: none;
    background: rgba(0,0,0,0.6);
}
.page-loading {
    display: block !important;
    background: #f8f8f8 !important;
}
.cv-spinner {
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.spinner {
    width: 40px;
    height: 40px;
    border: 4px #ddd solid;
    border-top: 4px #2e93e6 solid;
    border-radius: 50%;
    animation: sp-anime 0.8s infinite linear;
}
@keyframes sp-anime {
    100% {
        transform: rotate(360deg);
    }
}

.form-container > body {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    background-color: #fff;
    color: #202020;
    font-size: 1.6rem;
}

/* header */
.form-container > header {
    border-bottom: 2px solid #004680;
    background-color: #fff;
    padding: 10px 0;
}
.saleAssessmentLogoId {
    height: auto;
    margin: 0 auto;
    display: block;
}
.saleAssessmentLogoId2{
    float: left;
}
.saleAssessmentLogoLeft{
    float: left;
}
.saleAssessmentLogoRight{
    float: left;
}
.lifeInsuranceLogoId {
    height: auto;
    margin: 0 auto;
    display: block;
}
.lifeInsuranceLogoId2{
    float: left;
}
.lifeInsuranceLogoLeft{
    float: left;
}
.lifeInsuranceLogoRight{
    float: left;
}
.fireInsuranceLogoId {
    height: auto;
    margin: 0 auto;
    display: block;
}
.fireInsuranceLogoId2{
    float: left;
}
.fireInsuranceLogoLeft{
    float: left;
}
.fireInsuranceLogoRight{
    float: left;
}
.logoID {
    width: 100px;
    height: auto;
    margin: 0 auto;
    display: block;
}
.logoID2 {
    width: 100px;
    display: block;
    float: left;
}
.sorryLeft {
    margin: 0 auto;
    float: left;
}
.sorryRight {
    margin: 0 auto;
    float: left;
}
header span.tenpo-name {
    display: inline-block;
    margin-left: 1.6em;
    font-size: 80%;
    font-weight: 700;
}
header span.tenpo-name2 {
    display: inline-block;
    margin-left: 1.6em;
    font-size: 80%;
    font-weight: 700;
}
div.container-header {
    position: relative;
    width: 100%;
    margin: 0 auto;
    font-size: 123.1%;
}
.form-container > h1 {
    font-size: 128.6%;
    font-weight: 900;
    color: #fff;
    padding: 0.4em 0.8em;
    border-radius: 4px;
    background-color: #004680;
    background-image: -webkit-gradient(
        linear,
        left top,
        left bottom,
        color-stop(0, #004680),
        color-stop(1, #246399)
    );
    background-image: -o-linear-gradient(bottom, #246399 0%, #004680 100%);
    background-image: -moz-linear-gradient(bottom, #246399 0%, #004680 100%);
    background-image: -webkit-linear-gradient(bottom, #246399 0%, #004680 100%);
    background-image: -ms-linear-gradient(bottom, #246399 0%, #004680 100%);
    background-image: linear-gradient(to bottom, #246399 0%, #004680 100%);
    border: 1px solid #bec1c3;
}

h2 {
    padding-left: 0.6em;
    font-size: 128.6%;
    font-weight: 900;
    border-left: 5px solid #f3e600;
}

p {
    margin-top: 1em;
}

fieldset {
    margin-top: 30px;
}
#seminar-name {
    display:none;
}
.form-group {
    margin: 0;
    padding: 0.8em 0;
    border-bottom: 1px solid #ccc;
}
.form-group:hover {
    background-color: #f6f6f6;
}
.form-control,
.input-group-addon {
    border-color: #aaa;
    font-size: 1.6rem;
    padding:0.6rem 1rem;
    height:auto;
}

.icon-req {
    color: #d43f3a;
}

#btn {
    background-color: #666;
    color: #fff;
}

.btn {
    margin: 5px;
}


/* 入力ステータス */
*[required],
.required{
    background-color: rgba(255, 221, 221, 0.7);
}

*[required].dealed,
.dealed{
    /*background-color: rgba(223, 240, 216, 1);*/
    background-color: rgba(255, 255, 255, 1);
}

.caution{
    background-color: rgba(252, 248, 227, 1);
}

.alert{
    background-color: rgba(255, 221, 221, 0.7);
    margin-bottom: 0px;
}

div.required{
    padding: 0px 15px 5px 15px;
    /*margin-left: 15px;*/
}

.privacy {
    position: relative;
    padding-bottom: 12%;
    padding-top: 30px;
    height: 0;
    -webkit-overflow-scrolling: touch;
    overflow: auto;
}
.privacy iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 1px solid #999;
    background-color: #fff;
}

.copyright {
    margin: 0;
    padding: 0.4em;
    background-color: #004680;
    text-align: center;
    color: #c6cee3;
    font-size: 71.5%;
    bottom: 0;
    right:0;
    left: 0;
    z-index: 1030;
    margin-bottom: 0;
    margin-top: 2rem;
}

button#submit {
    margin-top: 2rem;
}
button[type="submit"] {
    height: 6rem;
}
.submit-unit {
    padding: 20px;
}
.fcInquiryDocumentList {
    padding: 0;
    width: 100%;
    height: auto;
}
.fcInquiryDocumentListArea {
    width:100%;
    height:auto;
    float:left;
    border-bottom:solid 1px #a9a9a9;
    margin-top:2px;
    margin-bottom:2px;
}
.checkBoxTd{
    vertical-align: middle;
    padding:0 ;
}
.imgTd{
    vertical-align: middle;
    padding:0 5px;
}
.titleTd{
    vertical-align: top;
    font-size: 80%;
    padding:0 10px;
}
.photoPicture {
    max-width:50px;
}
.documentTel {
    width:100%
}

.image-row, .center-content{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.form-image-box {
    border-radius: 20px;
    border: 1px solid;
    background: #FFF;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    max-width: 367px;
    max-height: 411px;
    min-width: 215px;
    /*min-height: 318px;*/
    width: fit-content;
    height: fit-content;
    flex-direction: column;
}
.center-justify-item{
    justify-items: center;
}
.name-wrap {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.wrap {
    overflow-wrap: anywhere;
}
.no-wrap {
    white-space: nowrap;
}
.hidden-wrap {
    overflow: hidden;
}
.sample-image-content {
    display: contents;
    max-width: 60%;
}
.sample-image-row {
    display: grid;
    justify-content: center;
    align-content: center;
}
.preview-image,
.sample-image {
    width: 135px;
    height: 135px;
}

.form-image-file-box {
    display: grid;
    justify-content: center;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.preview-image-object {
    width: 367px;
    height: 300px;
    object-fit: cover;
    border-radius: 20px;
}

/* Tablet Layout: 481px to 768px. Inherits styles from: Mobile Layout. */
@media only screen and (min-width: 481px) {
    .saleAssessmentLogoId {
        line-height: 52px;
    }
    .saleAssessmentLogoId2{
        display: block;
        float: left;
    }
    .saleAssessmentLogoLeft{
        float: left;
    }
    .saleAssessmentLogoRight{
        float: left;
    }
    .logoID {
        width: 199px;
        line-height: 52px;
    }
    .logoID2 {
        display: block;
        float: left;
    }
    .sorryLeft {
        float:left;
        margin-left: 20px;
        margin-right: 70px;
    }
    .sorryRight {
        float:left;
        margin-top: 20px;
    }
    header span.tenpo-name {
        display: inline-block;
        margin-left: 1.6em;
        font-size: 125%;
        font-weight: 700;
    }
    header span.tenpo-name2 {
        display: inline-block;
        margin-left: 1.6em;
        font-size: 125%;
        font-weight: 700;
    }
    div.container-header {
        position: relative;
        width: 70%;
        margin: 0 auto;
        font-size: 123.1%;
    }
    .form-container > h1 {
        font-size: 171.5%;
    }
    #fcInquiryForm {
        font-size: 114.3%;
    }
    #fcInquiryDocumentForm {
        font-size: 114.3%;
    }
    .fcInquiryDocumentList {
        padding: 0;
        width: 100%;
        height: 350px;
        overflow-y: scroll;
        border: 1px solid #ccc;
    }
    .fcInquiryDocumentListArea {
        width:50%;
        height:auto;
        float:left;
        border:none;
    }
    .fcInquiryDocumentListAreaTable{
        margin:10px 0;
    }
    .checkBoxTd{
        vertical-align: middle;
        padding:0 20px;
    }
    .imgTd{
        vertical-align: middle;
        padding:0 10px;
    }
    .photoPicture {
        max-width:50px;
    }
    .titleTd{
        vertical-align: top;
        font-size: 70%;
        padding:0 10px;
    }
    .documentTel {
        width:50%
    }
    fieldset {
        padding: 20px 30px;
        border: 1px solid #ccc;
        background-color: #fff;
    }

    .form-group {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    .control-label {
        border-right: 1px double #aaa;
    }
}

/* Desktop Layout: 769px to a max of 1232px.  Inherits styles from: Mobile Layout and Tablet Layout. */
@media only screen and (min-width: 769px) {
    .saleAssessmentLogoId {
        line-height: 52px;
        margin:0;
    }
    .saleAssessmentLogoId2 {
        float: left;
    }
    .saleAssessmentLogoLeft{
        float: left;
    }
    .saleAssessmentLogoRight{
        float: right;
    }
    .logoID {
        width: 199px;
        line-height: 52px;
    }
    .logoID2 {
        width: 199px;
        display: block;
        float: left;
    }
    .sorryLeft {
        float:left;
        margin-left: 20px;
        margin-right: 70px;
    }
    .sorryRight {
        float:left;
        margin-top: 20px;
    }
    header span.tenpo-name {
        display: inline-block;
        margin-left: 1.6em;
        font-size: 175%;
        font-weight: 700;
    }
    header span.tenpo-name2 {
        display: inline-block;
        margin-left: 200px;
        font-size: 175%;
        font-weight: 700;
    }
    div.container-header {
        position: relative;
        width: 960px;
        margin: 0 auto;
        font-size: 123.1%;
    }

    .form-container > h1 {
        font-size: 171.5%;
    }
    #fcInquiryForm {
        font-size: 114.3%;
    }
    #fcInquiryDocumentForm {
        font-size: 114.3%;
    }
    .fcInquiryDocumentList {
        padding: 0;
        width: 100%;
        height: 350px;
        overflow-y: scroll;
        border: 1px solid #ccc;
    }
    .fcInquiryDocumentListArea {
        width:50%;
        height:auto;
        float:left;
        border:none;
    }
    .fcInquiryDocumentListAreaTable{
        margin:10px 0;
    }
    .checkBoxTd{
        vertical-align: middle;
        padding:0 20px;
    }
    .imgTd{
        vertical-align: middle;
        padding:0 10px;
    }
    .photoPicture {
        max-width:50px;
    }
    .titleTd{
        vertical-align: top;
        font-size: 70%;
        padding:0 10px;
    }
    .documentTel {
        width:50%
    }
    fieldset {
        padding: 20px 30px;
        border: 1px solid #ccc;
        background-color: #fff;
    }

    .form-group {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    .control-label {
        border-right: 1px double #aaa;
    }
    .container {
        width: 970px;
    }
    .img-desc-box {
        padding: 5px 165px;
    }
}
.form-info{
    background-color: #f8f8f8;
    padding: 11px;
    margin-top: 10px;
    border: 1px dotted #333;
}
.form-info span{
    color: #004680;
    font-weight: 900;
}
/* Google Chrome, Safari, Opera 15+, Android, iOS */
.form-control::-webkit-input-placeholder {
    color: #999;
}
/* Firefox 18- */
.form-control:-moz-placeholder {
    color: #999;
    opacity: 1;
}
/* Firefox 19+ */
.form-control::-moz-placeholder {
    color: #999;
    opacity: 1;
}
/* IE 10+ */
.form-control:-ms-input-placeholder {
    color: #999;
}
@media screen and (max-width: 768px) {
    button[type="submit"] {
        font-size: 1.4rem;
        white-space: pre-line;
    }
    /*form input image*/
    .center-content {
        flex-direction: column !important;
    }
    .form-image-file-box {
        grid-template-columns: 1fr !important;
    }
    .preview-image-object {
        width: 215px !important;
        height: 215px !important;
    }
    .form-image-box {
        max-width: 215px;
    }
    .sample-image-content {
        max-width: 100%;
    }
    .sample-image-row {
    }
    .sample-image {
        width: 85px;
        height: 85px;
        object-fit: scale-down;
    }
    .preview-image {
        width: 53px;
        height: 53px;
        object-fit: scale-down;
    }
    .send-btn {
        width: 10rem !important;
    }
    .p-5 {
        width: 10rem;
    }
    .ul-list {
        margin: 0 auto;
        padding: 5px 15px;
    }
    .font-16 {
        font-size: 16px;
    }
}

.filedset-ondemand{
    background-color: #FFFEEF;
}

.filedset-ondemand .form-group:last-of-type{
    border-bottom: none;
}

.header_logo {
    font-size: 100%;
}

.header-shop-title {
    margin: 0;
    line-height: 1;
    font-size: 15px;
    font-family: Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif;
}

.official-channel-title {
    margin: 0;
    line-height: 1;
    font-size: 15px;
    font-family: Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif;
    font-weight: bold;
}

.forms-tel {
    line-height: 1;
    font-family: Helvetica , "游ゴシック" , "Yu Gothic" , sans-serif;
}

.txt-cl-b {
    color: #004680;
}

.txt-cl-r {
    color: #d43f3a;
}

.txt-cl-g {
    color: #a9a9a9;
}

.txt-underline {
    text-decoration: underline;
}

.ul-list {
    list-style: disc;
}

#inner_menu li a {
    color: inherit;
}

#inner_menu li a:hover {
    border-bottom: none;
}

.ml-2 {
    margin-left: 2rem;
}

.pt-0 {
    padding-top: 0 !important;
}

.txt-index span {
    display: inherit;
}

.terms {
    margin: 20px 0;
    line-height: 2.5rem;
}

.agreement-form {
    display: flex;
    margin-top: 20px;
}

.pl-1 {
    padding-left: 15px;
}

.agreement-modal {
    display: none;
    position: fixed;
    z-index: 10;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.agreement-modal .bg {
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.8);
}

.agreement-modal .wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 70%;
    max-width: 500px;
    padding: 40px;
    background-color: #fff;
    border-radius: 10px;
}

.title-height {
    line-height: 2rem;
}

.txt-center {
    text-align: center;
}

.send-btn {
    width: 8.33333333%;
    border: 1px solid;
    border-radius: 3px;
    background-color: #004680;
    color: #fff;
}

.p-5 {
    padding: 5px;
}

.d-flex {
    display: flex;
    justify-content: center;
}

.bt-none {
    border-top: none;
}

.ok-btn, .cancel-btn {
    width: 10rem;
    border: 1px solid;
    padding: 5px;
    font-size: 1.6rem;
    display: block;
    margin: 20px auto;
}

.ok-btn {
    background-color: #004680;
    opacity: 100%;
    color: #fff;
}

.cancel-btn {
    background-color: #FFFFFF;
    color: #000;
    opacity: 100%;
}

/* Bold and large font */
.bl-16 {
    font-size: 16px;
    font-weight: bold;
}

.cancel-btn:hover {
    background-color: #AFAFAF;
    opacity: 100%;
}
