@charset "utf-8";
@import url(https://fonts.googleapis.com/css?family=Material+Icons|Material+Icons+Outlined|Material+Icons+Round|Material+Icons+Sharp|Material+Icons+Two+Tone);
@import url(https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20,100,0,0);

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300..700;1,300..700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=BIZ+UDPGothic:wght@400;700&family=Zen+Kaku+Gothic+New&display=swap');

:root {
    --accentPrimaryCol: #F26324;
}

html {
    font-size: 100%; 
    scroll-behavior: smooth;
}

body {
    position: relative;
	margin: 0;
	padding: 0;
	min-width: 100%;
    height: 100%;
	color: #000000;
    font-size: 16px;
    line-height: 1.6;
    font-family:
        "Cormorant Garamond",
        "Zen Kaku Gothic New",
        sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    background: #f5f5f5;
    height: 100vh;
    overflow-wrap: break-word;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

*,
*::before,
*::after {
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
}

p,
ul,
ol,
li,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

ul,ol {
    list-style-type: none;
}

img {
    display: block;
    border: none;
    max-width: 100%;
    height: auto;
    vertical-align: top;
}



input,
textarea,
select {
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
    padding: 0;
    border: none;
    outline: none;
	font-size: 16px;
    font-family:
        "Zen Kaku Gothic New",
        sans-serif;
    background: transparent;
    margin-block: calc((1em - 1lh) / 2);
    cursor: pointer;
}

button:focus ,
input:focus ,
textarea:focus {
    outline: 0;
}
textarea {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

a {
    -webkit-transition: 0.5s;
    transition: 0.5s;
    outline: none;
    color: #000000;
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
    tap-highlight-color: transparent;
}








/* -------------------------- */
.container {
    position: relative;
    margin: 0;
    padding: 0;
}


/* -------------------------- */
header {
    position: sticky;
    top: 0;
    left: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    z-index: 999999;
}
header.toppage {
    position: fixed;
}




/* ------- */
.gNav {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    padding: 16px 24px;
    max-width: 1375px;
}

.gNav__logo {
    position: absolute;
    left: 24px;
    margin: 0 32px 0 0;
    padding: 0;
    line-height: 1;
    z-index: 999;
}
.gNav__logo img {
    margin: 0;
    padding: 0;
    height: 35px;
}

/* --- */
.gNav__list {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;
}
.gNav__list ul {
    display: flex;
    align-items: center;
    gap: 32px;
    margin: 0;
    padding: 0;
}
.gNav__list ul li {
    margin: 0;
    padding: 0;
}
.gNav__list ul li a {
    font-weight: 500;
}
.gNav__list ul li a:hover {
    opacity: .25;
}
.gNav__list--snsBtn {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 0 32px;
    padding: 0;
}
.gNav__list--snsBtn a {
    margin: 0;
    padding: 0;
}
.gNav__list--snsBtn a:hover {
    opacity: .2;
}
.gNav__list--snsBtn a img {
    margin: 0;
    padding: 0;
    height: 15px;
}

@media (max-width: 991px) {
    header {
        position: static;
    }
    .gNav {
        padding: 0;
        height: auto;
        width: 100%;
    }
    /* --- */
    .gNav__logo {
        display: block;
        position: fixed;
        top: 19px;
        left: 14px;
    }
    .gNav__logo img {
        height: 35px;
    }
    /* --- */
    .gNav__list {
        display: block;
        position: fixed;
        top: 0;
        left: -350px;
        margin: 0;
        padding: 40px 24px;
        width: 300px;
        height: 100vh;
        background: #FFFFFFE6;
        box-shadow: 4px 0 10px rgba(0, 0, 0, 0.2);
        transition: left 0.5s;
        z-index: 1000;
    }
    .gNav__list ul {
        display: block;
    }
    .gNav__list li {
        margin: 0 0 32px 0!important;
    }
    .gNav__list li a {
        font-size: 18px;
    }
    .gNav__list.active {
        left: 0;
    }
    
    .gNav__list--snsBtn {
        position: absolute;
        left: 0;
        bottom: 64px;
    }
    
    /* --- */
    .gNav__hamburger {
        display: block;
        position: fixed;
        top: 12px;
        right: 16px;
        width: 32px;
        cursor: pointer;
        z-index: 2000;
    }
    .gNav__hamburger span {
        display: block;
        height: 1px;
        background: #000000;
        margin: 8px 0;
        transition: 0.3s;
    }
    .gNav__hamburger.active span:nth-child(1) {
        background: #FFFFFF;
        transform: translateY(9px) rotate(45deg);
    }
    .gNav__hamburger.active span:nth-child(2) {
        opacity: 0;
    }
    .gNav__hamburger.active span:nth-child(3) {
        background: #FFFFFF;
        transform: translateY(-9px) rotate(-45deg);
    }
}
.gNav__overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    pointer-events: none;
    transition: 0.3s;
    z-index: 900;
}
.gNav__overlay.active {
    opacity: 1;
    pointer-events: auto;
}



/* ------- */
.mv {
    position: relative;
    margin: 0;
    padding: 0;
}
.mv__slide {
    margin: 0;
    padding: 0;
}
.mv__slide li {
    margin: 0;
    padding: 0;
    width: 100%;
}
.mv__slide li img {
    width: 100%;
    height: 750px;
    object-fit: cover;
}
@media (max-width: 575px) {
    .mv__slide li img {
        display: block;
        height: 650px;
        object-fit: cover;
    }
}


/* -------------------------- */
main {
    position: relative;
    margin: 0;
    padding: 0;
}

/* -------------------------- */
.intro {
    margin: 0 auto;
    padding: 12vh 48px 13vh 48px;
    width: 100%;
}
@media (min-width: 576px) and (max-width: 991px) {
    .intro {
        padding: 10vh 48px 12vh 48px;
    }
}
@media (max-width: 576px) {
    .intro {
        padding: 15vh 24px 13vh 24px;
    }
}
/* ------------ */
.content {
    margin: 0 auto;
    padding: 12vh 48px 13vh 48px;
    width: 100%;
}
@media (min-width: 576px) and (max-width: 991px) {
    .content {
        padding: 10vh 48px 12vh 48px;
    }
}
@media (max-width: 576px) {
    .content {
        padding: 15vh 24px 13vh 24px;
    }
}










/* -------------------------- */
.intro__title {
    margin: 0 auto 5vh auto;
    padding: 0;
    max-width: 1068px;
    text-align: center;
    line-height: 1.2;
    font-size: 40px;
    font-weight: 600;
    letter-spacing: .1em;
}
.intro__title span {
    display: block;
    margin: 8px 0 0 0;
    padding: 0;
    color: var(--accentPrimaryCol);
    font-size: .5em;
    font-weight: 600;
    letter-spacing: .4em;
}
@media (min-width: 576px) and (max-width: 991px) {
    .intro__title {
        font-size: 32px;
    }
}
@media (max-width: 575px) {
    .intro__title {
        font-size: 32px;
    }
}



/* -------------------------- */
.contentTitle {
    margin: 0 auto 5vh auto;
    padding: 0;
    max-width: 1068px;
}
.contentTitle.borderB {
    margin: 0 auto 5vh auto;
    padding: 0 0 5vh 0;
    border-bottom: solid 1px #C6CED9;
}
.ct__title {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
    text-align: center;
    line-height: 1.2;
    font-size: 40px;
    font-weight: 600;
}
.ct__title span {
    display: block;
    margin: 8px 0 0 0;
    padding: 0;
    color: var(--accentPrimaryCol);
    font-size: .5em;
    font-weight: 600;
    letter-spacing: .4em;
}
@media (min-width: 576px) and (max-width: 991px) {
    .ct__title {
        font-size: 32px;
    }
}
@media (max-width: 575px) {
    .ct__title {
        font-size: 30px;
    }
    .ct__title span {
        margin: 0 0 0 0;
    }
}







.ct__lead {
    margin: 5vh 0 0 0;
    padding: 0;
}
.ct__lead > :last-child {
    margin: 0 0 0 0;
}
.ct__lead--lead {
    margin: 0 0 24px 0;
    padding: 0;
    line-height: 2;
}
.ct__lead--text {
    margin: 0 0 16px 0;
    padding: 0;
    line-height: 2;
}
.ct__lead--text a {
    color: #0000FF;
}








/* -------------------------- */
.intro-about {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
}
.intro-about__desc {
    margin: 0 0 5vh 0;
}
.intro-about__desc--textJpn {
    margin: 0 0 4vh 0;
    padding: 0;
    line-height: 2;
}
@media (max-width: 991px) {
    .intro-about__desc--textJpn {
        line-height: 1.75;
    }
}
.intro-about__desc--textEng {
    margin: 0 0 4vh 0;
    padding: 0;
    line-height: 1.6;
    font-size: 18px;
}
@media (max-width: 991px) {
    .intro-about__desc--textEng {
        line-height: 1.75;
    }
}
.intro-about__desc p:last-child {
    margin: 0 0 0 0;
}



















/* ------- */
.intro-business {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
}
.intro-business__list {
}
.intro-business__list ul {
    display: flex;
    flex-wrap: wrap;
    gap: 5%;
    margin: 0;
    padding: 0;
}
.intro-business__list ul li {
    position: relative;
    margin: 0 0 7.5vh 0;
    padding: 0 0 0 0;
    width: 30%;
    text-align: center;
}
@media (max-width: 575px) {
    .intro-business__list ul li {
        width : 47.5%;
    }
}
.intro-business__list ul li a {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
}
.intro-business__list ul li img {
    display: block;
    margin: 0 auto min(2.5vh,24px) auto;
    padding: 0;
    width: 90%;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .4);
    transition: 0.3s;
    pointer-events: none;
}
@media (max-width: 575px) {
    .intro-business__list ul li img {
        width: 95%;
    }
}
.intro-business__list ul li .lead {
    margin: 0 auto min(1.5vh,8px) auto;
    padding: 0;
    text-align: center;
    font-weight: 600;
    pointer-events: none;
}
.intro-business__list ul li .text {
    margin: 0;
    padding: 0;
    text-align: left;
    pointer-events: none;
}
.intro-business__list ul li a:hover + img ,
.intro-business__list ul li a:hover + .lead ,
.intro-business__list ul li a:hover + .text {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    opacity: .5;
    transition: 0.5s;
}


/* ------- */
.intro-brand {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
}
.intro-brand__list {
}
.intro-brand__list ul {
    display: flex;
    flex-wrap: wrap;
    gap: 5%;
    margin: 0;
    padding: 0;
}
.intro-brand__list ul li {
    position: relative;
    margin: 0 0 7.5vh 0;
    padding: 0;
    width: 30%;
}
@media (max-width: 575px) {
    .intro-brand__list ul li {
        margin: 0 0 0 0;
        width: 47.5%;
    }
}
.intro-brand__list ul li a {
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
}
.intro-brand__list ul li img {
    display: block;
    margin: 0 auto 24px auto;
    padding: 0;
    width: 90%;
    border-radius: 24px;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .4);
    transition: 0.3s;
    pointer-events: none;
}
.intro-brand__list ul li img.logo {
    width: 65%;
    border-radius: 0;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
}
@media (max-width: 575px) {
    .intro-brand__list ul li img.logo {
        width: 75%;
    }
}
.intro-brand__list ul li .lead {
    margin: 0 auto min(1.5vh,8px) auto;
    padding: 0;
    text-align: center;
    font-weight: 600;
    font-size: var(--fsXL);
    pointer-events: none;
}
.intro-brand__list li .text {
    margin: 0;
    padding: 0;
    text-align: left;
    pointer-events: none;
}
.intro-brand__list ul li a:hover + img ,
.intro-brand__list ul li a:hover + .lead ,
.intro-brand__list ul li a:hover + .text {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    opacity: .5;
    transition: 0.5s;
}

    .intro-brand__list ul.logoText {
    }
    .intro-brand__list ul.logoText li {
        padding: 0 0 3em 0;
    }
    @media (max-width: 575px) {
        .intro-brand__list ul.logoText li {
            padding: 0 0 5em 0;
        }
    }









/* ------- */
.intro-news {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
}
.intro-news__list {
}
.intro-news__list ul {
    display: flex;
    flex-wrap: wrap;
    gap: 3%;
    margin: 0;
    padding: 0;
    padding-bottom: 2vh;
}
.intro-news__list ul li {
    position: relative;
    margin: 0 0 4vh 0;
    padding: 0;
    width : 31%;
    background: #FFFFFF;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .2);
    transition: 0.5s;
}
.intro-news__list ul li:hover {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    transition: 0.5s;
}

@media (max-width: 575px) {
    .intro-news__list ul li {
        width : 48%;
    }
}
.intro-news__list ul li a {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    color: #000000;
    transition: 0.5s;
}
.intro-news__list ul li a:hover + img {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    opacity: .5;
    transition: 0.5s;
}
.intro-news__list ul li img {
    display: block;
    margin: 0;
    padding: 0;
    pointer-events: none;
    transition: 0.5s;
}
.intro-news__list--lead {
    margin: 0;
    padding: min(1.75vh,16px);
    padding-bottom: min(3vh,20px);
}
.intro-news__list--lead .date {
    margin: 0 0 min(1.5vh,16px) 0;
    padding: 0
    color: #777777;
}
.intro-news__list--lead .stitle {
    margin: 0 0 min(1vh,12px) 0;
    padding: 0;
    line-height: 1.2;
    font-weight: 600;
}
.intro-news__list--lead .text {
    margin: 0 0 1.5vh 0;
    padding: 0;
    line-height: 1.6;
}
.intro-news__list--lead .cate {
    display: inline-block;
    margin: 8px 4px 0 0;
    padding: 3px min(2vw,12px);
    color: #AAAAAA;
    line-height: 1.2;
    font-weight: 600;
    border: solid 1px #AAAAAA;
    border-radius: 50px;
}
    #intro-news__list li {
        display: none;
        opacity: 0;
        transform: translateY(10px);
        transition: opacity 1s ease, transform 1s ease;
        transition: 0.5s;

    }
    #intro-news__list li.intro-news-fadein {
        opacity: 1;
        transform: translateY(0);
    }











/* -------------------------- */
.contentExpl {
    margin: 0 auto;
    padding: 0;
    max-width: 1068px;
}





/* -------------------------- */
.privacypolicy {
}
/* ---- */
.pp__desc {
    margin: 0 0 10vh 0;
    padding: 0;
    font-size: 14px;
}
.pp__desc h2 {
    margin: 3vh 0 1vh 0;
    padding: 0;
    width: 100%;
    font-size: 18px;
    font-weight: 600;
}
@media screen and (max-width: 575px) {
    .pp__desc h2 {
        margin: 5vh 0 1vh 0;
    }
}
.pp__desc p {
    margin: 0;
    padding: 0;
    line-height: 2;
}
.pp__desc--right {
    text-align: right;
}
.pp__desc ol {
    margin: 0;
    padding: 0 0 0 2em;
    list-style-type: decimal;
}
.pp__desc ol li {
    margin: 0;
    padding: 0;
    line-height: 2;
}


/* -------------------------- */
.about {
}
/* ---- */
.about__lead {
    margin: 0 0 10vh 0;
    padding: 0;
}
.about__lead--textJpn {
    margin: 0 0 4vh 0;
    padding: 0;
    line-height: 2;
}
@media (max-width: 991px) {
    .about__lead--textJpn {
        line-height: 1.75;
    }
}
.about__lead--textEng {
    margin: 0 0 4vh 0;
    padding: 0;
    line-height: 1.6;
    font-size: 18px;
}
@media (max-width: 991px) {
    .about__lead--textEng {
        line-height: 1.75;
    }
}

/* ---- */
.about__companyProfile {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 10vh 0;
    padding: 0;
}
.about__companyProfile--title {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin: 0 0 3vh 0;
    padding: 0;
    width: 100%;
    line-height: 2.5;
    font-size: 22px;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.about__companyProfile--title .eng {
    margin: 0;
    padding: 0 0 4px 0;
    color: var(--accentPrimaryCol);
    font-size: .75em;
}
.about__companyProfile--desc {
    margin: 0;
    padding: 0;
    width: 50%;
}
@media (max-width: 575px) {
    .about__companyProfile--desc {
        margin:  0 0 2vh 0;
        width: 100%;
    }
}
.about__companyProfile--desc tr {
    margin: 0;
    padding: 0;
}
.about__companyProfile--desc th {
    margin: 0;
    padding: 0 16px 16px 0;
    text-align: left;
    line-height: 2;
    vertical-align: top;
    white-space: nowrap;
}
.about__companyProfile--desc td {
    margin: 0;
    padding: 0 16px 16px 0;
    line-height: 2;
    font-size: 15px;
}

.about__companyProfile--map {
    position: relative;
    padding-top: 40%;
    width: 50%;
    height: 0;
}
@media (min-width: 576px) and (max-width: 991px) {
    .about__companyProfile--map {
        padding-top: 75%;
    }
}
@media (max-width: 575px) {
    .about__companyProfile--map {
        padding-top: 100%;
        width: 100%;
    }
}
.about__companyProfile--map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .4);
}
/* ---- */
.about__history {
    margin: 0 0 5vh 0;
    padding: 0;
}
.about__history--title {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin: 0 0 3vh 0;
    padding: 0;
    width: 100%;
    line-height: 2.5;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.about__history--title .eng {
    margin: 0;
    padding: 0 0 4px 0;
    color: var(--accentPrimaryCol);
    font-size: .75em;
}
.about__history dl {
    display: flex;
    margin: 0 0 0 0;
    padding: 0;
}
.about__history dl dt {
    position: relative;
    margin: 0 0 0 0;
    padding: 24px 40px 24px 0;
    color: #AAAAAA;
    font-weight: 600;
}
.about__history dl:first-of-type dt {
    padding: 0 40px 24px 0;
}
.about__history dl dt::before {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    display: block;
    content: '';
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #000000;
}
.about__history dl dt::after {
    position: absolute;
    top: 50%;
    right: 4.5px;
    transform: translateY(-50%);
    display: block;
    content: '';
    width: 1px;
    height: 100%;
    background: #000000;
}
.about__history dl:first-of-type dt::after {
    position: absolute;
    top: 75%;
    height: 50%;
}
.about__history dl dd {
    position: relative;
    margin: 0;
    padding: 0;
    width: calc(100% - 24px);
    vertical-align: middle;
}
.about__history dl dd p {
    position: absolute;
    top: 50%;
    left: 24px;
    transform: translateY(-50%);
    margin: 0 0 0 0;
    padding: 0;
}






/* -------------------------- */
.biz {
}
/* ---- */
.biz__lead {
    margin: 0 0 10vh 0;
    padding: 0;
}
.biz__lead--text {
    margin: 0 0 4vh 0;
    padding: 0;
    font-size: 18px;
}
@media (max-width: 575px) {
    .biz__lead--text {
        line-height: 2;
    }
}
.biz__lead--title {
    margin: 0 0 2.5vh 0;
    padding: 0;
    line-height: 1.4;
    font-weight: 600;
}

/* ---- */
.biz__item {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 0 10vh 0;
    padding: 0;
    gap: 5%;
}
.biz__item > .half {
    width: calc(50% - 2.5%);
}
@media (max-width: 575px) {
    .biz__item > .half {
        width: 100%;
    }
}
.biz__item--title {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    width: 100%;
    font-size: 30px;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.biz__item--title::first-letter {
    font-size: 1.75em;
    font-weight: 900;
}
.biz__item--img {
    margin: 24px 0 0 0;
    padding: 0;
}
.biz__item--img img {
}
.biz__item--text {
    margin: 24px 0 0 0;
    padding: 0;
    line-height: 2;
}











/* -------------------------- */
.news {
}
/* ↑↑↑ intro-news___listを使用 */









/* -------------------------- */
.newsItem-mv {
    position: relative;
    margin: 0;
    padding: 0;
}
.content-news-item-mv img {
    width: 100%;
    height: 750px;
    object-fit: cover;
}

/* ------------ */
.newsItem{
}
/* --- */
.newsItem__desc {
    margin: 0 0 5vh 0;
    padding: 0;
}
    .newsItem__desc > :last-child {
        margin: 0;
    }

.newsItem__desc--title {
    margin: 5vh 0 2.5vh 0;
    padding: 0;
    text-align: left;
    font-weight: 600;
    letter-spacing: .1em;
}
.newsItem__desc--lead {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin: 0 0 2.5vh 0;
    padding: 0;
    width: 100%;
    font-weight: 600;
}
.newsItem__desc--text {
    margin: 0 0 2.5vh 0;
    padding: 0;
    line-height: 1.8;
}
.newsItem__desc--column2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 5%;
    margin: 0 0 2.5vh 0;
    padding: 0;
}
.newsItem__desc--column2 li {
    margin: 0;
    padding: 0;
    width: 47.5%;
}
.newsItem__desc--column2 li img {
    margin: 0 0 1vh 0;
    padding: 0;
    width: 100%;
}
.newsItem__desc--column2 li p {
    margin: 0 0 2vh 0;
    padding: 0;
    line-height: 1.8;
}
.newsItem__desc--column2 li p:last-child {
    margin: 0 0 0 0;
}







/* -------------------------- */
.brand {
}
.brand__list {
    margin: 0;
    padding: 0;
}
.brand__list ul {
    margin: 0;
    padding: 0;
}
.brand__list ul li {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 5%;
    margin: 0 0 10vh 0;
    padding: 0 0 10vh 0;
    border-bottom: solid 1px #000000;
}
.brand__list ul li:last-child {
    margin: 0 0 0 0;
    padding: 0 0 0 0;
    border-bottom: 0;
}



.brand__list ul li .brand__kv {
    margin: 0;
    padding: 0;
    width: 47.5%;
}
.brand__list ul li .brand__kv img {
    margin: 24px 0 0 0;
}
.brand__list ul li .brand__kv img:first-child {
    margin: 0 0 0 0;
}
@media (max-width: 575px) {
    .brand__list ul li .brand__kv {
        margin: 0 0 24px 0;
        width: 100%;
    }
}





.brand__desc {
    position: relative;
    margin: 0;
    padding: 0;
    width: 47.5%;
}
@media (max-width: 575px) {
    .brand__desc {
        width: 100%;
    }
}
.brand__desc .logoSq {
    margin: 0 0 0 0;
    padding: 0;
    width: 33%;
}
.brand__desc .logoRc {
    margin: 0 0 0 0;
    padding: 0;
    width: 44%;
}
@media (max-width: 575px) {
    .brand__desc .logoSq ,
    .brand__desc .logoRc {
        margin: 24px auto 32px auto;
        width: 45%;
    }
}

.brand__desc .lead {
    margin: 16px 0 0 0;
    padding: 0;
    font-weight: 600;
}
.brand__desc .text {
    margin: 16px 0 0 0;
    padding: 0;
    line-height: 1.8;
}

.brand__desc .storeinfo {
    margin: 32px 0 0 0;
    padding: 0;
    line-height: 1.8;
}
.storeinfo__name {
    display: flex;
    align-items: center;
    margin: 16px 0 0 0;
    padding: 0;
    line-height: 1.8;
}
.storeinfo__name a {
    display: block;
}
.storeinfo__name img {
    margin-left: 16px;
    width: 20px;
}


.brand__desc .btnPrimary {
    margin: 24px 0 0 0;
}
@media (max-width: 575px) {
    .brand__desc .btnPrimary {
        width: 85%;
    }
}





/* -------------------------- */
.message {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 5%;
}
.message__item {
    display: flex;
    flex-wrap: wrap;
    gap: 5%;
    margin: 0 0 7.5vh 0;
    padding: 0 0 7.5vh 0;
    width: 100%;
    border-bottom: solid 1px #000000;
}
.message__item:nth-last-child(-n+2) {
    margin: 0 0 0 0;
}
@media (max-width: 575px) {
    .message__item:nth-last-child(-n+2) {
        margin: 0 0 7.5vh 0;
    }
}
.message__item.half {
    gap: 0;
    width: 47.5%;
}
@media (max-width: 575px) {
    .message__item.half {
        width: 100%;
    }
}
.message__item--face {
    margin: 0;
    padding: 0;
    width: 45%;
}
.message__item--face.half {
    margin: 0 0 32px 0;
    padding: 0;
    width: 100%;
}
@media (max-width: 575px) {
    .message__item--face ,
    .message__item--face.half {
        margin: 0 0 32px 0;
        width: 100%;
    }
}
.message__item--face img {
}
.message__item--face.half img {
    margin: 0 auto;
}

.message__item--desc {
    position: relative;
    margin: 0;
    padding: 0;
    width: 50%;
}
.message__item--desc.half {
    width: 100%;
}
@media (max-width: 575px) {
    .message__item--desc ,
    .message__item--desc.half {
        width: 100%;
    }
}

.message__item--desc .lead {
    margin: 0 0 16px 0;
    padding: 0;
    font-weight: 600;
}

.message__item--desc .text {
    margin: 0 0 32px 0;
    padding: 0;
    line-height: 2;
}
.message__item--desc .text:last-child {
    margin: 0 0 32px 0;
}
.message__item--desc .profile {
    position: absolute;
    left: 0;
    bottom: 0;
    margin: 0 0 0 0;
    padding: 0;
    width: 100%;
    text-align: right;
    line-height: 1.5;
    letter-spacing: .3em;
}
.message__item--desc.half .profile {
    position: static;
}
@media (max-width: 991px) {
    .message__item--desc .profile {
        position: static;
    }
}
.message__item--desc .profile .position {
    display: block;
    color: #777777;
    font-weight: 600;
}
.message__item--desc .profile .eng {
    display: block;
    color: var(--accent-primary);
    font-weight: 600;
}
.message__item--desc .profile .name {
    display: block;
    margin: 4px 0;
    padding: 0;
    font-weight: 600;
}
.message__item--desc .profile a {
    display: inline-block;
    margin: 12px 0 0 8px;
    padding: 0;
    height: 14px;
}
.message__item--desc .profile a img {
    height: 14px;
    opacity: .5;
}







/* -------------------------- */
.inquiry {
}










/* -------------------------- */
.recruit {
}
.recruit__mv {
    margin: 0 0 min(5vh,56px) 0;
    padding: 0;
    width: 100%;
}
.recruit__mv img {
    width: 100%;
    height: 500px;
    object-fit: cover;
}
@media (max-width: 575px) {
    .recruit__mv img {
        display: none;
    }
}

.recruitItem__mv {
    margin: 0 0 min(5vh,56px) 0;
    padding: 0;
    width: 100%;
}
.recruitItem__mv img {
    width: 100%;
    height: 500px;
    border-radius: 24px;
    object-fit: cover;
}
@media (max-width: 575px) {
    .recruitItem__mv img {
        display: block;
        height: 380px;
        object-fit: cover;
    }
}

.recruit__catchphrase {
    margin: 0 0 min(8vh,88px) 0;
    padding: 0;
    font-weight: 600;
}

.recruit__type {
    margin: 0;
    padding: 0;
}
.recruit__type--title {
    margin: 0 0 24px 0;
    padding: 0 0 16px 0;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.recruit__type ul {
    display: flex;
    flex-wrap: wrap;
    gap: 3%;
    margin: 0;
    padding: 0;
    padding-bottom: 2vh;
}
.recruit__type ul li {
    position: relative;
    margin: 0 0 6vh 0;
    padding: 0;
    width : 31%;
    background: #FFFFFF;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .2);
    transition: 0.5s;
}
.intro-recruit__type ul li:hover {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    transition: 0.5s;
}
@media (max-width: 575px) {
    .recruit__type ul li {
        width : 100%;
    }
}
.recruit__type ul li:hover {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
}
.recruit__type ul li a {
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    color: #000000;
}
.recruit__type ul li a:hover + img {
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, 0);
    opacity: .5;
    transition: 0.5s;
}
.recruit__type ul li img {
    margin: 0;
    padding: 0;
    pointer-events: none;
    transition: 0.5s;
}
.recruit__type--lead {
    margin: 0;
    padding: min(3vh,18px);
    padding-bottom: min(4vh,24px);
}
.recruit__type--lead .type {
    display: inline-block;
    margin: 0 0 min(1vh,12px) 0;
    padding: 5px min(2vw,12px);
    color: #FFFFFF;
    line-height: 1.2;
    background: #000000;
    border-radius: 3px;
}
.recruit__type--lead .lead {
    margin: 0 0 min(1vh,12px) 0;
    padding: 0;
    line-height: 1.2;
    font-weight: 600;
}
.recruit__type--lead .text {
    margin: 0 0 1.5vh 0;
    padding: 0;
    line-height: 1.6;
}
.recruit__type--lead > :last-child {
    margin: 0 0 0 0;
}
.recruit__type--lead .btnSecondary {
    width: 100%;
}


.recruit__typeTitle {
    margin: 0 0 min(3vh,32px) 0;
    padding: 0;
}
.recruit__typeTitle .type {
    display: inline-block;
    margin: 0 0 8px 0;
    padding: 5px min(2vw,12px);
    color: #FFFFFF;
    line-height: 1.2;
    background: #000000;
    border-radius: 3px;
}
.recruit__typeTitle .typeTitle {
    margin: 0;
    padding: 0;
    line-height: 1.2;
    font-weight: 600;
}
.recruit__typeExpl {
    margin: 0 0 min(5vh,56px) 0;
    padding: min(4vh,48px) min(4vw,40px);
    background: #FFFFFF;
    border-radius: 24px
}
.recruit__typeExpl--title {
    margin: 0 0 24px 0;
    padding: 0 0 16px 0;
    font-weight: 600;
    border-bottom: solid 1px #000000;
}
.recruit__typeExpl table {
    margin: 0;
    padding: 0;
}
.recruit__typeExpl table tr {
    margin: 0;
    padding: 0;
}
.recruit__typeExpl table tr th {
    margin: 0;
    padding: 0 32px 5vh 0;
    vertical-align: top;
    text-align: left;
    white-space: nowrap;
}
.recruit__typeExpl table tr:last-child th {
    padding: 0 32px 0 0;
}
.recruit__typeExpl table tr td {
    margin: 0;
    padding: 0 0 5vh 0;
}
.recruit__typeExpl table tr:last-child td {
    margin: 0;
    padding: 0 0 0 0;
}
.recruit__typeExpl table tr td p {
    margin: 0 0 8px 0;
}
.recruit__typeExpl table tr td p:last-child {
    margin: 0 0 0 0;
}
@media (max-width: 575px) {
    .recruit__typeExpl table tr th {
        display: block;
        padding: 0 0 8px 0;
    }
    .recruit__typeExpl table tr td {
        display: block;
        padding: 0 0 5vh 16px;
    }
}









/* ------- */
footer {
    margin: 0;
    padding: 0;
    background: #FFFFFF;
}
.fNav {
    margin: 0 auto;
    padding: 56px 24px 8px 24px;
    max-width: 1375px;
}

.fNav__logo {
    display: block;
    margin: 0 0 40px 0;
    padding: 0;
    width: 175px;
}
.fNav__list {
    margin: 0 0 min(5vw,48px) 0;
    padding: 0;
}
.fNav__list ul {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin: 0;
    padding: 0;
}
.fNav__list ul li {
    margin: 0;
    padding: 0;
}
@media (max-width: 575px) {
    .fNav__list ul li {
        margin: 0 0 1.5em 0;
        width: 100%;
    }
}
.fNav__list ul li a {
    margin: 0;
    padding: 0;
    color: #000000;
    font-weight: 600;
}
.fNav__list ul li a:hover {
    opacity: .25;
}
.fNav__copy {
    margin: 0;
    padding: 0;
    text-align: center;
    font-size: 12px;
}








/* ----------------------- */
.inputWrap {
    margin: 0;
    padding: 0;
}
.inputWrap form {
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
    margin: 0;
    padding: 0;
}
@media (min-width: 576px) and (max-width: 991px) {
    .inputWrap form {
        gap: 48px 24px;
    }
}
@media (max-width: 575px) {
    .inputWrap form {
        gap: 48px 0;
    }
}

/* ------- */
.textInput ,
.textareaInput {
    display: block;
    margin: 0;
    padding: 0;
    width: 100%;
}
.textInput.half ,
.textareaInput.half {
    width: calc(50% - 24px);
}
@media (min-width: 576px) and (max-width: 991px) {
    .textInput.half ,
    .textareaInput.half {
        width: calc(50% - 12px);
    }
}
@media (max-width: 575px) {
    .textInput.half ,
    .textareaInput.half {
        width: 100%;
    }
}

/* ------- */
.textInput .upper ,
.textareaInput .upper ,
.radioSelect .upper ,
.checkSelect .upper ,
.selectBox .upper {
    display: block;
    margin: 0 0 12px 4px;
    padding: 0;
    width: 100%;
    font-size: 15px;
    font-weight: 600;
}
    .radioSelect .upper ,
    .checkSelect .upper {
        margin: 0 0 8px 4px;
    }
.textInput .req::before ,
.textareaInput .req::before ,
.radioSelect .req::before ,
.checkSelect .req::before ,
.selectBox .req::before {
    content: '※';
    color: #FF0000;
}
.textInput .upper b ,
.textareaInput .upper b ,
.radioSelect .upper b ,
.checkSelect .upper b ,
.selectBox .upper b {
    margin: 0 0 0 1em;
    padding: 0;
    font-size: .8em;
    font-weight: 400;
    color: #949AA6;
}
.textInput .lower ,
.textareaInput .lower ,
.radioSelect .lower ,
.checkSelect .lower ,
.selectBox .lower {
    display: block;
    margin: 8px 0 0 4px;
    padding: 0;
    width: 100%;
    color: #949AA6;
    font-size: .75em;
}
    .radioSelect .lower ,
    .checkSelect .lower {
        margin: 0 0 0 14px;
    }

.textInput .lower b ,
.textareaInput .lower b ,
.radioSelect .lower b ,
.checkSelect .lower b ,
.selectBox .lower b {
    margin: 0 0 0 .5em;
    padding: 0;
}

.radioSelect .upper-expl ,
.checkSelect .upper-expl ,
.selectBox .upper-expl {
    display: block;
    margin: 0 0 0 4px;
    padding: 0;
    width: 100%;
    line-height: 1.75;
    font-size: .75em;
}
.radioSelect .upper-expl a ,
.checkSelect .upper-expl a ,
.selectBox .upper-expl a {
    color: #0000FF;
}

.textInput .checked ,
.textareaInput .checked ,
.radioSelect .checked ,
.checkSelect .checked ,
.selectBox .checked {
    display: block;
    margin: 0;
    padding: 0 0 16px 16px;
    width: 100%;
    line-height: 1.6;
    border-bottom: solid 1px #C6CED9;
}



.textInput input ,
.textareaInput textarea {
    display: block;
    margin: 0;
    padding: 1em;
    width: 100%;
    line-height: 1.6;
    border: solid 1px #FFFFFF;
    border-radius: 16px;
    transition: 0.5s;
}
.textInput input:focus,
.textareaInput textarea:focus  {
  border: solid 1px var(--accentPrimaryCol);
}

.textInput input::placeholder ,
.textareaInput textarea::placeholder {
    color: #C6CED9;
}



.selectBox {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    width: 100%;
}
.selectBox.half {
    width: calc(50% - 24px);
}
@media (min-width: 576px) and (max-width: 991px) {
    .selectBox.half {
        width: calc(50% - 12px);
    }
}
@media (max-width: 575px) {
    .selectBox.half {
        width: 100%;
    }
}
.selectBox__flame {
    display: block;
    position: relative;
    margin: 0;
    padding: 0;
}
.selectBox__flame::after {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    font-family: "Material Icons";
    content: "\e5c5";
    color: #000000;
    font-size: 2px;
    pointer-events: none;
}
.selectBox__flame select {
    display: block;
    margin: 0;
    padding: 1em;
    width: 100%;
    line-height: 1.6;
    border: solid 1px #FFFFFF;
    border-radius: 16px;
    transition: 0.5s;
}





.radioSelect ,
.checkSelect {
    display: flex;
    flex-wrap: wrap;
    align-content: flex-start;
    gap: 1em 1em;
    margin: 0;
    padding: 0;
    width: 100%;
    border: none;
}
.radioSelect.half ,
.checkSelect.half {
    width: calc(50% - 24px);
}
@media (min-width: 576px) and (max-width: 991px) {
    .radioSelect.half ,
    .checkSelect.half {
        width: calc(50% - 12px);
    }
}
@media screen and (max-width: 575px) {
    .radioSelect.half,
    .checkSelect.half {
        width: 100%;
    }
}

    .radioSelect.border-bottom ,
    .checkSelect.border-bottom {
        padding: 0 0 24px 0;
        border-bottom: solid 1px #C6CED9;
    }
    .radioSelect.center ,
    .checkSelect.center {
        justify-content: center;
        text-align: center;
    }
    .radioSelect.bg ,
    .checkSelect.bg {
        padding: 24px;
        background: #FFFFFF;
        border-radius: 16px
    }

.radioSelect label,
.checkSelect label {
    position: relative;
    display: flex;
    align-items: center;
    gap: 0 .5em;
    margin: 0 0 0 1em;
    padding: 0;
    cursor: pointer;
    user-select: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
}
.radioSelect label::before,
.radioSelect label::after {
    border-radius: 50%;
    content: '';
}
.radioSelect label::before {
    width: 18px;
    height: 18px;
}
.radioSelect label::after {
    position: absolute;
    top: 50%;
    left: 9px;
    transform: translate(-50%, -50%);
    width: 21px;
    height: 21px;
    background: #F263241A;
}
.radioSelect label:has(:checked)::after {
    background: var(--accentPrimaryCol);
    animation: animradio .3s linear;
}
@keyframes animradio {
    0% {
        box-shadow: 0 0 0 1px transparent;
    }
    50% {
        box-shadow: 0 0 0 10px #F263241A;
    }
    100% {
        box-shadow: 0 0 0 10px transparent;
    }
}

.checkSelect label::before ,
.checkSelect label:has(:checked)::after {
    content: '';
}
.checkSelect label::before {
    width: 23px;
    height: 23px;
    border-radius: 3px;
    background: #F263241A;
}
.checkSelect label:has(:checked)::before {
    background: var(--accentPrimaryCol);
    transition: 0.5s;
}
.checkSelect label:has(:checked)::after {
    position: absolute;
    top: 4px;
    left: 9px;
    transform: rotate(45deg);
    width: 6px;
    height: 12px;
    border: solid #FFFFFF;
    border-width: 0 2px 2px 0;
}

.radioSelect label.invalid ,
.checkSelect label.invalid {
    pointer-events: none;
}

.radioSelect input ,
.checkSelect input {
    display: none;
}


/* ------- */
.errorMsg {
    display: block;
    margin: 4px 0 0 0;
    padding: 0 0 0 8px;
    width: 100%;
    color: #FF0000;
}







/* ------- */
.btnMulti {
    margin: 0;
    padding: 0;
    width: 100%;
}
.btnMulti__btn {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 24px;
    margin: 0;
    padding: 0;
    width: 100%;
}

.btnMulti .upper {
    display: block;
    margin: 0 0 24px 0;
    padding: 0;
    width: 100%;
    text-align: center;
    font-weight: 500;
}
.btnMulti .upper b {
    margin: 0 0 0 .5em;
    padding: 0;
    font-size: .8em;
    font-weight: 400;
    color: #949AA6;
}
.btnMulti .lower {
    position: relative;
    display: block;
    margin: 24px 0 0 0;
    padding: 0;
    width: 100%;
    text-align: center;
    color: #949AA6;
}
.btnMulti .lower b {
    margin: 0 0 0 .5em;
    padding: 0;
    font-size: .8em;
    font-weight: 400;
}
.btnMulti .lower a {
    margin: 0;
    padding: 0;
    color: #0000FF;
}


/* -------------------------- */
.btnPrimary {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    width: clamp(300px,40vw,380px);
    height: 56px;
    color: #000000;
    font-weight: 600;
    letter-spacing: .1em;
    background: #FFFFFF;
    border-radius: 50px;
    cursor: pointer;
    box-shadow: 0 3px 6px 0 rgba(0, 0, 0, .2);
    transition: 0.3s;
}
.btnPrimary:hover {
    box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
}
.btnSecondary {
    position: relative;
    display: block;
    margin: 0;
    padding: 0;
    width: clamp(300px,40vw,380px);
    height: 56px;
    color: #000000;
    font-weight: 600;
    letter-spacing: .1em;
    background: #FFFFFF;
    border-radius: 50px;
    border: solid 1px #000000;
    cursor: pointer;
    transition: 0.3s;
}

    .btnPrimary.centered ,
    .btnSecondary.centered {
        margin: 0 auto;
    }
    .btnPrimary.thin ,
    .btnSecondary.thin {
        height: 40px;
    }

    @media screen and (max-width: 639px) {
        .btnOrder1 { order: 1; }
        .btnOrder2 { order: 2; }
        .btnOrder3 { order: 3; }
        .btnOrder4 { order: 4; }
        .btnOrder5 { order: 5; }
    }

.btnPrimary.arrowNext ,
.btnSecondary.arrowNext {
}
.btnPrimary.arrowBack ,
.btnSecondary.arrowBack {
}
.btnPrimary.arrowDown ,
.btnSecondary.arrowDown {
}

.btnPrimary.arrowNext::after ,
.btnSecondary.arrowNext::after {
    position: absolute;
    top: 50%;
    right: 24px;
    transform: translateY(-50%);
    content: "\e5c8";
    font-size: 25px;
    font-family: "Material Symbols Outlined";
    transition: transform .3s ease;
}
.btnPrimary.arrowNext:hover::after ,
.btnSecondary.arrowNext:hover::after {
    transform: translate(5px, -50%);
}

.btnPrimary.arrowBack::before ,
.btnSecondary.arrowBack::before {
    position: absolute;
    top: 50%;
    left: 24px;
    transform: translateY(-50%);
    content: "\e5c4";
    font-size: 26px;
    font-family: "Material Symbols Outlined";
    transition: transform .3s ease;
}
.btnPrimary.arrowBack:hover::before ,
.btnSecondary.arrowBack:hover::before {
    transform: translate(-5px, -50%);
}

.btnPrimary.arrowDown::after ,
.btnSecondary.arrowDown::after {
    position: absolute;
    top: 50%;
    right: 24px;
    transform: translateY(-50%);
    content: "\e5db";
    font-size: 25px;
    font-family: "Material Symbols Outlined";
    transition: transform .3s ease;
}
.btnPrimary.arrowDown:hover::after ,
.btnSecondary.arrowDown:hover::after {
    transform: translate(5px, -50%);
}

@media (min-width: 576px) and (max-width: 991px) {
    .btnPrimary.arrowNext::after ,
    .btnSecondary.arrowNext::after {
        right: 8px;
    }
    .btnPrimary.arrowBack::before ,
    .btnSecondary.arrowBack::before {
        left: 8px;
    }
}




















/* --------------------- */
.order1 { order: 1; }
.order2 { order: 2; }
.order3 { order: 3; }
.order4 { order: 4; }
.order5 { order: 5; }


/* --------------------- */
.mgnB0 { margin-bottom: 0; }

/* --------------------- */
.accentPrimaryCol { color: var(--accentPrimaryCol); }

/* --------------------- */
.bgGry { background: #E8E8E8; }
.bgTrans { background: transparent; }

/* --------------------- */
.center { text-align: center; }
.left { text-align: left; }
.right { text-align: right; }

/* --------------------- */
.p0 { padding: 0; }
.pt0 { padding-top: 0; }
.pb0 { padding-bottom: 0; }
.pl0 { padding-left: 0; }
.pr0 { padding-right: 0; }

.m0 { margin: 0; }
.mt0 { margin-top: 0; }
.mb0 { margin-bottom: 0; }
.ml0 { margin-left: 0; }
.mr0 { margin-right: 0; }

.m8 { margin: 8px; }
.mt8 { margin-top: 8px; }
.mb8 { margin-bottom: 8px; }
.ml8 { margin-left: 8px; }
.mr8 { margin-right: 8px; }

.m16 { margin: 16px; }
.mt16 { margin-top: 16px; }
.mb16 { margin-bottom: 16px; }
.ml16 { margin-left: 16px; }
.mr16 { margin-right: 16px; }














































