@charset "utf-8";

.secCmnIndexTop {
    background: url(../img/company/bgCmnIndexTop.jpg) center top / cover;
}
@media only screen and (max-width:1215px){
    .secCmnIndexTop {
        background: url(../img/company/bgCmnIndexTop_sp.jpg) center top / cover;
        height: 80vw;
    }
    .mainWrapper {
        margin-top: 0.1rem;
    }
}

/* secTop */
.secTop{
    background: url(../img/company/bgCmnTop.jpg) center top / cover;
    padding: 22.7rem 0 100rem;
    position: relative;
    text-align: center;
}
.secTop .txtTit{
    font-size: var(--pcFontSize50);
    line-height: var(--pcLineHeight50_90);
    letter-spacing: var(--pcLetterSpacing50_100);
    color: var(--mustColor);
    padding: 0.9rem 1rem;
    position: relative;
    z-index: 2;
}
.secTop .txtTit::after,
.secTop .txtTit::before{
    content: "";
    width: 79rem;
    height: 7rem;
    background: var(--Colorwhite);
    position: absolute;
    top: 2.3rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
}
.secTop .txtTit::before{
    width: 56.5rem;
    top: 11.2rem;
}
.secTop .txtAbout{
    font-size: var(--pcFontSize18);
    line-height: var(--pcLineHeight18_50);
    color: var(--Colorwhite);
    margin-top: 2.6rem;
}
.secTop .imgTxt{
    position: absolute;
    top: 14.8rem;
    left: 50%;
    transform: translateX(-50%);
}
@media only screen and (max-width:1215px){
    .secTop{
        padding: 12.5rem 0 38.9rem;
    }
    .secTop .txtTit{
        font-size: var(--spFontSize18);
        line-height: var(--spLineHeight18_45);
        letter-spacing: var(--spLetterSpacing18_50);
        padding: 0;
    }
    .secTop .txtTit::after,
    .secTop .txtTit::before{
        width: 72%;
        height: 3.5rem;
        top: 6%;
    }
    .secTop .txtTit::before{
        width: 53.334%;
        top: 57%;
    }
    .secTop .txtAbout{
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_30);
        margin-top: 1.6rem;
    }
    .secTop .imgTxt{
        width: 13rem;
        top: 9rem;
    }
}
@media only screen and (max-width:767px){
    .secTop{
        background: url(../img/company/bgCmnTop_sp.jpg) center top / cover;
    }
}

/* secMotto */
.secMotto{
    background: rgba(255, 255, 255, 0.8);
    position: absolute;
    bottom: -46.3rem;
    left: 50%;
    transform: translateX(-50%);
    padding-top: 12rem;
    border-radius: 0.5rem 0.5rem 0 0;
}
.secMotto .boxTit{
    font-size: var(--pcFontSize40);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: -6.6rem;
}
.secMotto .txtSmall{
    font-size: var(--pcFontSize30);
    margin-bottom: 1.8rem;
}
.secMotto .boxList{
    display: flex;
    margin-top: 5rem;
}
.secMotto .item{
    width: calc((100% - 24rem) / 4);
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-right: 8rem;
}
.secMotto .item:last-child{
    margin-right: 0;
}
.secMotto .txtMotto{
    font-size: var(--pcFontSize20);
    line-height: var(--pcLineHeight20_40);
    letter-spacing: var(--pcLetterSpacing20_100);
    margin-top: 2.9rem;
}
@media only screen and (max-width:1215px){
    .secMotto{
        bottom: -47.1rem;
        padding-top: 4.1rem;
    }
    .secMotto .imgTxtAiLUCKHOME{
        width: 26.8rem;
        margin: 0 auto;
    }
    .secMotto .boxTit{
        font-size: var(--spFontSize18);
        margin-top: -3rem;
    }
    .secMotto .txtSmall{
        font-size: var(--spFontSize16);
        margin-bottom: 1rem;
    }
    .secMotto .boxList{
        flex-wrap: wrap;
        max-width: 33.5rem;
        margin: 2rem auto 0;
    }
    .secMotto .item{
        width: calc((100% - 2rem) / 2);
        margin-right: 2rem;
    }
    .secMotto .item:nth-child(2n){
        margin-right: 0;
    }
    .secMotto .item:nth-child(n+3){
        margin-top: 2.1rem;
    }
    .secMotto .txtMotto{
        font-size: var(--spFontSize13);
        line-height: var(--spLineHeight13_20);
        letter-spacing: var(--spLetterSpacing13_50);
        margin-top: 1.1rem;
    }
}

/* secFormTit */
.secFormTit{
    text-align: center;
    margin-bottom: 4.5rem;
}
.secFormTit .titEng{
    position: relative;
    padding-bottom: 2rem;
    margin-bottom: 1rem;
}
.secFormTit .titEng::before{
    content: '';
    position: absolute;
    bottom: 0;
    left: calc(50% - 5rem);
    width: 10rem;
    height: 0.1rem;
    background: var(--formUnderLine);
}
.secFormTit .titJpn{
    font-size: var(--pcFontSize15);
    line-height: var(--pcLineHeight15_15);
    margin-top: 0.4rem;
    letter-spacing: var(--pcLetterSpacing15_100);
}
@media only screen and (max-width:1215px){
    .formWrapperSp{
        background: var(--formBgColor);
        padding: 4rem 0 2.5em;
    }
    .secFormTit{
        margin-bottom: 1.6rem;
    }
    .secFormTit .titEng{
        margin: 0 auto 0.8rem;
        padding-bottom: 1rem;
    }
    .secFormTit .titEng.imgFormModel{
        width: 19.8rem;
    }
    .secFormTit .titEng.imgFormReserve{
        width: 11.2rem;
    }
    .secFormTit .titEng::before {
        left: calc(50% - 1.75rem);
        width: 3.5rem;
    }
    .secFormTit .titJpn{
        font-size: var(--spFontSize11);
        margin-top: 0.5rem;
    }
}

/* secAbout */
.secAbout{
    margin-top: 60.3rem;
}
.secAbout .imgTop{
    position: relative;
}
.secAbout .imgTop::after,
.secAbout .imgTop::before{
    content: "";
    width: 0.1rem;
    height: 4rem;
    background: rgba(255, 255, 255, 0.8);
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
}
.secAbout .imgTop::before{
    background: var(--mustColor);
    bottom: -4rem;
}
.secAbout .secFormTit{
    margin-top: 10rem;
}
.secAbout .boxTable{
    width: 100%;
}
.secAbout .txtTr{
    font-size: var(--pcFontSize15);
    letter-spacing: var(--pcLetterSpacing15_100);
    display: flex;
    line-height: var(--pcLineHeight15_30);
    border: 0.1rem solid var(--formBorderColor);
    border-bottom: none;
}
.secAbout .txtTr:last-child{
    border-bottom: 0.1rem solid var(--formBorderColor);
}
.secAbout .txtTh{
    width: 15rem;
    min-height: 6.8rem;
    height: auto;
    background: var(--formFlowBox);
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 0.1rem solid var(--formBorderColor);
    flex-shrink: 0;
    vertical-align: top;
}
.secAbout .txtTd{
    width: 100%;
    padding: 0.8rem 2.5rem;
    text-align: left;
    display: flex;
    align-items: center;
}
.secAbout .txtTd.txtTdBig{
    padding: 1.8rem 2.5rem;
}
@media only screen and (max-width:1215px){
    .secAbout{
        margin-top: 51.7rem;
    }
    .secAbout .imgTop::after,
    .secAbout .imgTop::before{
        width: 0.1rem;
        height: 1rem;
    }
    .secAbout .imgTop::before{
        bottom: -1rem;
    }
    .secAbout .secFormTit{
        margin-top: 4rem;
    }
    .secAbout .secFormTit .titEng{
        width: 9.5rem;
        margin: 0 auto;
    }
    .secAbout .txtTr{
        font-size: var(--spFontSize13);
        letter-spacing: var(--spLetterSpacing13_50);
        line-height: var(--spLineHeight13_22);
    }
    .secAbout .txtTh{
        width: 8rem;
        height: auto;
        min-height: 3.6rem;
        text-align: center;
        padding: 0.9rem 0 0.7rem;
    }
    .secAbout .txtTd{
        padding: 0.5rem 1.5rem;
        display: flex;
        align-items: center;
    }
    .secAbout .txtTd.txtTdAddress{
        padding: 0.8rem 1.5rem;
    }
    .secAbout .txtTd.txtTdBig{
        padding: 1rem 1.5rem;
    }
}

/* secAccess */
.secAccess{
    margin-top: 12rem;
}
.secAccess .boxMap{
    width: 100%;
    position: relative;
    padding-top: 36.232%;
}
.secAccess .boxMap iframe{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
@media only screen and (max-width:1215px){
    .secAccess{
        margin-top: 5rem;
    }
    .secAccess .secFormTit .titEng{
        width: 10.1rem;
        margin: 0 auto;
    }
    .secAccess .boxMap{
        padding-top: 59.705%;
    }
}

/* secStaff */
.secStaff{
    margin-top: 15rem;
}
.secStaff .boxList{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.secStaff .item{
    width: 28rem;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.secStaff .item:nth-child(n+5){
    margin-top: 6rem;
}
.secStaff .txtNameJp{
    font-size: var(--pcFontSize20);
    letter-spacing: var(--pcLetterSpacing20_50);
    margin-top: 3rem;
}
.secStaff .txtNameEng{
    margin-top: 2rem;
}
.secStaff .txtPost{
    font-size: var(--pcFontSize15);
    letter-spacing: var(--pcLetterSpacing15_50);
    color: var(--mustColor);
    height: 2rem;
    display: flex;
    align-items: center;
    margin-top: 2.3rem;
}
.secStaff .txtPost.lazyloaded{
    background: url(../img/company/iconStaff.png);
    background-size: 2rem;
    background-repeat: no-repeat;
    padding-left: 3rem;
}
@media only screen and (max-width:1215px){
    .secStaff{
        margin-top: 5rem;
    }
    .secStaff .secFormTit .titEng{
        width: 7.5rem;
        margin: 0 auto;
    }
    .secStaff .boxList{
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        max-width: 33.5rem;
        margin: 0 auto;
    }
    .secStaff .item{
        width: calc((100% - 2rem) / 2);
        margin-right: 2rem;
    }
    .secStaff .item:nth-child(2n){
        margin-right: 0;
    }
    .secStaff .item:nth-child(n+3){
        margin-top: 3rem;
    }
    .secStaff .txtNameJp{
        font-size: var(--spFontSize16);
        letter-spacing: var(--spLetterSpacing16_50);
        margin-top: 1.5rem;
    }
    .secStaff .txtNameEng{
        height: 0.9rem;
        margin-top: 0.9rem;
    }
    .secStaff .txtNameEng img{
        width: auto;
        height: 100%;
    }
    .secStaff .txtPost{
        font-size: var(--spFontSize13);
        letter-spacing: 0;
        white-space: nowrap;
        height: 1.6rem;
        margin-top: 1.5rem;
    }
    .secStaff .txtPost.lazyloaded{
        background-size: 1.6rem;
        padding-left: 2.4rem;
    }
}

/* secMessage */
.secMessage{
    height: 70rem;
    display: flex;
    align-items: center;
    margin-top: 15rem;
}
.secMessage.lazyloaded{
    background: url(../img/company/bgCmnMessage.jpg) center top / cover;
}
.secMessage .wrapper{
    display: flex;
    justify-content: space-between;
}
.secMessage .boxLeft{
    position: relative;
}
.secMessage .txtMessage{
    position: absolute;
    top: -1.9rem;
    left: -4.4rem;
}
.secMessage .txtLeft{
    font-size: var(--pcFontSize18);
    line-height: var(--pcLineHeight18_50);
    letter-spacing: var(--pcLetterSpacing18_50);
    color: var(--Colorwhite);
    margin-top: 6.4rem;
}
.secMessage .boxRight{
    display: flex;
    flex-direction: column;
    align-items: center;
}
.secMessage .boxRight .txtPost{
    font-size: var(--pcFontSize16);
    letter-spacing: var(--pcLetterSpacing16_50);
    color: var(--Colorwhite);
    margin-top: 3rem;
}
.secMessage .boxRight .txtName{
    font-size: var(--pcFontSize20);
    letter-spacing: var(--pcLetterSpacing20_100);
    color: var(--Colorwhite);
    margin-top: 1.8rem;
}
@media only screen and (max-width:1215px){
    .secMessage{
        height: auto;
        margin-top: 5rem;
        padding: 3rem 0 5rem;
    }
    .secMessage.lazyloaded{
        background: url(../img/company/bgCmnMessage_sp.jpg) center top / cover;
    }
    .secMessage .wrapper{
        flex-direction: column-reverse;
    }
    .secMessage .txtMessage{
        width: 18.6rem;
        top: 2.4rem;
        left: -0.8rem;
    }
    .secMessage .txtLeft{
        font-size: var(--spFontSize12);
        line-height: var(--spLineHeight12_30);
        letter-spacing: -0.02em;
        margin-top: 5rem;
    }
    .secMessage .boxRight .imgMessage{
        width: 16rem;
        margin: 0 auto;
    }
    .secMessage .boxRight .txtPost{
        font-size: var(--spFontSize12);
        letter-spacing: var(--spLetterSpacing12_100);
        margin-top: 1.5rem;
    }
    .secMessage .boxRight .txtName{
        font-size: var(--spFontSize14);
        letter-spacing: var(--spLetterSpacing14_100);
        margin-top: 1rem;
    }
}

/* secCompany */
.secCompany{
    text-align: center;
    padding-top: 12rem;
}
.secCompany.lazyloaded{
    background: url(../img/company/bgCmnCompany.png) center top;
    background-repeat: no-repeat;
}
.secCompany .imgAward{
    margin-top: 2.7rem;
}
.secCompany .boxTit{
    position: relative;
    margin-top: 12.9rem;
}
.secCompany .imgTit{
    position: absolute;
    top: -5rem;
    left: 50%;
    transform: translateX(-50%);
}
.secCompany .txtTit{
    font-size: var(--pcFontSize40);
    letter-spacing: var(--pcLetterSpacing40_100);
}
.secCompany .imgGroup{
    width: 100%;
    margin-top: 11.1rem;
}
@media only screen and (max-width:1215px){
    .secCompany{
        padding-top: 4rem;
    }
    .secCompany.lazyloaded{
        background: url(../img/company/bgCmnCompany_sp.png) center top / contain no-repeat, #fff;
    }
    .secCompany .imgTop{
        width: 25rem;
        margin: 0 auto;
    }
    .secCompany .imgAward{
        width: 24.4rem;
        margin: 1rem auto 0;
    }
    .secCompany .boxTit{
        margin-top: 4.2rem;
    }
    .secCompany .imgTit{
        width: 13.8rem;
        top: -1.1rem;
    }
    .secCompany .txtTit{
        font-size: var(--spFontSize18);
        letter-spacing: var(--spLetterSpacing18_50);
    }
    .secCompany .imgGroup{
        margin-top: 3.2rem;
    }
}
/* secTicker */
.secTicker{
    margin-top: 15rem;
    overflow: hidden;
}
.secTicker .boxTicker {
    display: flex;
}
.secTicker .itemTicker:nth-child(odd) {
    animation: loop 180s -90s linear infinite;
    backface-visibility: hidden;
    will-change: transform;
    transform: translate3d(0, 0, 0);
}
.secTicker .itemTicker:nth-child(even) {
    animation: loop2 180s linear infinite;
}
@keyframes loop {
    0% {
        transform: translateX(100%);
    }
    to {
        transform: translateX(-100%);
    }
}
@keyframes loop2 {
    0% {
        transform: translateX(0);
    }
    to {
        transform: translateX(-200%);
    }
}
.secTicker .boxTicker2 {
    display: flex;
}
.secTicker .itemTicker2:nth-child(odd) {
    animation: loop3 180s -90s linear infinite;
    backface-visibility: hidden;
    will-change: transform;
    transform: translate3d(0, 0, 0);
}
.secTicker .itemTicker2:nth-child(even) {
    animation: loop4 180s linear infinite;
}
@keyframes loop3 {
    0% {
        transform: translateX(-100%);
    }
    to {
        transform: translateX(100%);
    }
}
@keyframes loop4 {
    0% {
        transform: translateX(-200%);
    }
    to {
        transform: translateX(0);
    }
}
@media only screen and (max-width:767px){
    .secTicker{
        margin-top: 5rem;
    }
    .secTicker .imgTicker{
        width: 252rem;
        height: 13.75rem;
    }
}