/* ===================================================================
filename:business.css
=================================================================== */

.businessPage {
    background-color: transparent;
}
.businessPage .page-contents {
    margin-bottom: 0;
}

/* pathNavi */
.businessPage #pathNavi {
    margin: 0;
    padding: 35px 0;
    background-color: #FAF8F6;
}

/* .page-header */
.businessPage .page-contents .page-header {
    margin: 0;
    padding-bottom: 50px;
    background-color: #FAF8F6;
}
.businessPage .page-contents .page-header > .container {}
.businessPage .page-contents .page-header > .container > .row {
    padding: 0;
    margin: 0;
}
.businessPage .page-contents .page-header > .container > .row > * {
    padding: 0;
    margin: 0;
}
.businessPage .page-contents .page-title {
    height: 100%;
    min-height: 532px;
    padding: 10px 30px 30px 0;
}
.businessPage .page-contents .page-title .title { 
    margin-bottom: 45px;
}
.businessPage .page-contents .page-header .p-mv {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 0.03em;
}
.businessPage .page-contents .page-header .page-img {
    position: relative;
    height: 100%;
    margin-left: -11%;
    width: calc(50vw + 11% - 32px);
}
.businessPage .page-contents .page-header .page-img .parallax-obj {
    position: relative;
    aspect-ratio: 3.62;
    width: 100%;
    height: 532px;
    opacity: 0;
    border-radius: 8px;
}
.businessPage .page-contents .page-header .page-img .filter {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    border-radius: 8px;
}
.businessPage .page-contents .page-header .page-img .filter * {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-size: 100% 100%;
}
.businessPage .page-contents .page-header .page-img .filter .bottom {
    background-image: url(../_img/services/filter-bottom-sp.png);
    mix-blend-mode: screen;
}
.businessPage .page-contents .page-header .page-img .filter .gradation {
    background-image: url(../_img/services/filter-gradation-sp.png);
}
.businessPage .page-contents .page-header .page-img .filter .shadow {
    background-image: url(../_img/services/filter-shadow-sp.png);
    mix-blend-mode: multiply;
}
.businessPage .page-contents .page-header .page-img .filter .frame {
    background-image: url(../_img/services/filter-frame-sp.png);
    opacity: 0;
}
.businessPage .page-contents .page-header .page-img .base-name {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    text-align: center;
}
.businessPage .page-contents .page-header .page-img .base-name p {
    font-family: "Cormorant Infant", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    letter-spacing: -0.03em;
    font-size: 110px;
    text-transform: uppercase;
    line-height: 1;
    color: #ffffff;
    text-shadow: 0 0 12px rgba(197, 46, 27, 0.15);
    margin: 0;
    transform: translateY(0.2em);
}
@media (max-width: 1199px) {
    .businessPage .page-contents .page-title {
        min-height: unset;
    }
    .businessPage .page-contents .page-header .page-img {
        margin-left: 0;
        width: 100%;
    }
    .businessPage .page-contents .page-header .page-img .parallax-obj {
        aspect-ratio: 1.34 / 1;
        height: auto;
    }
}
@media (max-width: 991px) {
    .businessPage .page-contents .page-title {
        padding-right: 0;
        padding-bottom: 0;
    }
}
@media (max-width: 767px) {
    .businessPage .page-contents .page-title .title {
        margin: 37px 0 20px;
    }
    .businessPage .page-contents .page-header .p-mv {
        font-size: 15px;
    }
    .businessPage .page-contents .page-header .page-img {
        margin: 0 -12px;
        width: calc(100% + 24px);
    }
    .businessPage .page-contents .page-header .page-img .base-name p {
        font-size: 40px;
    }
    .businessPage .page-contents .page-header .page-img .parallax-obj {
        border-radius: 4px;;
    }
    .businessPage .page-contents .page-header .page-img .filter {
        border-radius: 4px;
    }
    .businessPage .page-contents .page-header .page-img .filter .bottom {
        background-image: url(../_img/services/filter-bottom-sp.png);
    }
    .businessPage .page-contents .page-header .page-img .filter .gradation {
        background-image: url(../_img/services/filter-gradation-sp.png);
    }
    .businessPage .page-contents .page-header .page-img .filter .shadow {
        background-image: url(../_img/services/filter-shadow-sp.png);
    }
    .businessPage .page-contents .page-header .page-img .filter .frame {
        background-image: url(../_img/services/filter-frame-sp.png);
        opacity: 0;
    }
}


/* .floating-obj */
@media (min-width: 768px) {
    .businessPage .page-contents .floating-obj {
        position: sticky;
		top: 75px;
    }
}
@media (min-width: 992px) {
    .businessPage .page-contents .floating-obj {
		top: 150px;
	}
}

/* .page-body */
.businessPage .page-contents .page-body {
    padding-top: 0;
}
@media (min-width: 992px) {
    .businessPage .page-contents .page-body {
        padding-top: 0;
    }
}
@media (max-width: 767px) {
    .businessPage .page-contents .page-body {
        padding-top: 0;
    }
}

/* .domain-sec */
.businessPage .page-contents .domain-sec {
    padding-top: 125px;
    padding-bottom: 30px;
    margin: 0;
    background-color: #FAF8F6;
}
@media (max-width: 767px) {
    .businessPage .page-contents .domain-sec {
        padding-top: 0;
        padding-bottom: 70px;
    }
}

/* .sec-title */
.businessPage .page-contents .sec-title {
    width: 1174px;
    max-width: calc(100% - 60px);
    margin-left: auto;
    margin-right: auto;
}
.businessPage .page-contents .sec-title .en-title {
    margin-bottom: 5px;
}
.businessPage .page-contents .sec-title h2 {
    font-size: 20px;
    color: #856D47;
}
.businessPage .page-contents .domain-content > .row {
    margin: 0;
    padding: 0;
}
.businessPage .page-contents .domain-content > .row > * {
    margin: 0;
    padding: 0;
}
.businessPage .page-contents .domain-content h3 {
    font-size: 30px;
    line-height: 1.8;
    letter-spacing: 0.03em;
    margin-bottom: 55px;
}
.businessPage .page-contents .domain-content p {
    letter-spacing: 0.03em;
}
.businessPage .page-contents .domain-content .business-dl-wrap  {
    padding-left: 23px;
    margin: 60px 0 30px;
}
.businessPage .page-contents .domain-content .business-dl-wrap dl dt {}
.businessPage .page-contents .domain-content .business-dl-wrap dl dd {}
.businessPage .page-contents .domain-content .business-dl-wrap h4 {
    position: relative;
    line-height: 1.4;
    font-size: 25px;
    font-weight: 500;
    color: #856D47;
    margin: 40px 0 15px;
}
.businessPage .page-contents .domain-content .business-dl-wrap h4::before {
    content: "";
    position: absolute;
    top: 0.7em;
    left: -23px;
    transform: translateY(-50%);
    width: 12px;
    height: 12px;
    border: solid 2px #856D47;
    border-radius: 50%;
    display: inline-block;
    margin-right: 10px;
}
.businessPage .page-contents .domain-content .business-dl-wrap h5 {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 10px;
}
.businessPage .page-contents .domain-content .business-dl-wrap p {
    font-size: 15px;
    line-height: 1.8;
    letter-spacing: 0;
}

.businessPage .page-contents .domain-content ul.work-list {
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 15px;
    line-height: 1.8;
    font-weight: 500;
}
.businessPage .page-contents .domain-content ul.work-list > li {
    display: flex;
    align-items: center;
    padding: 0;
    margin-bottom: 3px;
}
.businessPage .page-contents .domain-content ul.work-list > li::before {
    content: "";
    width: 8px;
    height: 8px;
    background-color: #856D47;
    display: inline-block;
    margin-right: 10px;
}
.businessPage .page-contents .domain-content .domain-img {
    padding: 30px 20px;
    text-align: center;
}
@media (min-width: 768px) {
    .businessPage .page-contents .domain-content .domain-img {
        width: calc(50vw - 10px);
        max-width: 710px;
    }
    .businessPage .page-contents .domain-content .domain-img-left {
        margin-left: 100%;
        transform: translateX(-100%);
    }
}
@media (max-width: 767px) {
    .businessPage .page-contents .sec-title {
        max-width: calc(100vw - 48px);
    }
    .businessPage .page-contents .sec-title h2 {
        font-size: 16px;;
    }
    .businessPage .page-contents .domain-content .domain-img {
        padding: 0;
        margin: 0 -12px 15px;
    }  
    .businessPage .page-contents .domain-content h3 {
        font-size: 22px;
        margin-bottom: 25px;
    }
    .businessPage .page-contents .domain-content h3 br {
        display: initial;
    }
    .businessPage .page-contents .domain-content .business-dl-wrap h5 {
        font-size: 15px;
        line-height: 1.6;
    }
    .businessPage .page-contents .domain-content .business-dl-wrap {
        margin-top: 45px;
    }
    .businessPage .page-contents .domain-content .business-dl-wrap h4 {
        font-size: 18px;
        margin-top: 20px;
        margin-bottom: 10px;
    }
    .businessPage .page-contents .domain-content .business-dl-wrap p {
        font-size: 14px;
        letter-spacing: 0.02em;
    }
    .businessPage .page-contents .domain-content ul.work-list {
        font-size: 13px;
        line-height: 1.6;
    }
}
/* .domain01 */
.businessPage .page-contents .domain01 {
    padding-top: 60px;
    padding-bottom: 75px;
}
@media (min-width: 992px) {
    .businessPage .page-contents .domain01 {
        padding-top: 190px;
        padding-bottom: 30px;
    }
}

/* .domain03 */
.businessPage .page-contents .domain03 {
    padding-bottom: 80px;
}
.businessPage .page-contents .domain03 .sec-title {
    margin-bottom: 80px;
}
.businessPage .page-contents .domain03 .domain-content h3 {
    text-wrap: pretty;
}
.businessPage .page-contents .domain03 .domain-content p {
    letter-spacing: 0.05em;
}
.businessPage .page-contents .domain03 .domain-content .domain-img {
    text-align: right;
    padding: 0 30px;
}
.businessPage .page-contents .domain03 .domain-content .domain-img .inner-mask {
    width: 523px;
    max-width: 100%;
    overflow: hidden;
    margin-left: auto;
    aspect-ratio: 0.8;
    transform: translateY(100%);
    transition: transform 1.2s;
}
.businessPage .page-contents .domain03 .domain-content .domain-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 8px;
    transform: translateY(-100%);
    transition: transform 1.2s;
}
.businessPage .page-contents .domain03 .domain-content .domain-img.js-add-class-active .inner-mask {
    transform: translateY(0%);
}
.businessPage .page-contents .domain03 .domain-content .domain-img.js-add-class-active img {
    transform: translateY(0%);
}
@media (max-width: 991px) {
    .businessPage .page-contents .domain03 .sec-title {
        max-width: 100%;
    }
    .businessPage .page-contents .domain03 .domain-content .domain-img {
        padding: 0 15px;
        width: calc(100% + 15px);
    }
}
@media (max-width: 767px) {
    .businessPage .page-contents .domain03 .sec-title {
        margin-bottom: 30px;
    }
    .businessPage .page-contents .domain03 .domain-content .domain-img {
        width: calc(100% + 24px);
        padding: 0;
        margin-bottom: 30px;
    }
    .businessPage .page-contents .domain03 .domain-content .domain-img .inner-mask {
        width: 100%;;
        aspect-ratio: 1.78;
    }
    .businessPage .page-contents .domain03 .domain-content p {
        letter-spacing: 0.03em;
    }
}
@media (min-width: 768px) {
}
@media (min-width: 992px) {
    .businessPage .page-contents .domain03 .sec-title {
        width: calc(100% + 76px);
        max-width: calc(50vw - 30px);
        margin-left: 100%;
        transform: translateX(-100%);
    }

    .businessPage .page-contents .domain03 .domain-content .domain-img {
        padding: 0 15px;
    }
}
@media (min-width: 1199px) {
    .businessPage .page-contents .domain03 .domain-content h3 {
        margin-right: -1em;
    }
}

/* .domain04 */
.businessPage .page-contents .domain04 {
    position: relative;
    min-height: calc(100vh + 200px);
    min-height: calc(100vh + 200px);
    padding: 0;
    background-color: transparent;
}
.businessPage .page-contents .domain04 .domain04-inner {
    position: sticky;
    top: 112px;
    height: calc(100vh - 112px);
    height: calc(100vh - 112px);
    z-index: -1;
}
.businessPage .page-contents .domain04 .domain04-bg {
    position: fixed;
    top: 112px;
    right: 0;
    bottom: 0;
    left: 0;
    margin: 0;
    padding: 0;
    background-color: #FAF8F6;
    overflow: hidden;
}
.businessPage .page-contents .domain04 .domain04-bg img {
    height: 100lvh;
    width: 100%;
    object-fit: cover;
    will-change: transform;
    opacity: 0;
}
.businessPage .page-contents .domain04 .domain04-content {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    padding: 0;
    margin: 0;
}
.businessPage .page-contents .domain04 .domain04-content .innner-box {
    position: fixed;
    top: 112px;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100vw - 60px);
    max-width: 1024px;
}
.businessPage .page-contents .domain04 .domain04-content .sec-title {
    width: auto;
    max-width: 100%;
    margin: 0;
    transform: none;
}
.businessPage .page-contents .domain04 .domain04-content .en-title-wrap {
    top: 112px;
    bottom: 0;
    left: 50%;
    width: calc(100vw - 60px);
    max-width: 1024px;
}
.businessPage .page-contents .domain04 .domain04-content .en-title {
    position: absolute;
    top: 100px;
    left: 50%;
    transform: translateX(-50%);
    color: #DDC08B;
    max-width: 1174px;
    width: calc(100vw - 60px);
    z-index: 10;
}
.businessPage .page-contents .domain04 .domain04-content .h2-wrap {
    opacity: 0;
}
.businessPage .page-contents .domain04.textVisible .domain04-content .h2-wrap {
    animation: fadeIn;
    animation-fill-mode: forwards;
    animation-duration: 3s;
    animation-delay: 0.3s;
}
.businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 {
    position: absolute;
    writing-mode: vertical-rl;
    top: 125px;
    right: 30px;
    color: #FFFFFF;
    font-size: 30px;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.2em;
    white-space: nowrap;
    z-index: 10;
}
.businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 span {
    display: block;
}
.businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 span:nth-child(2) {
    padding-top: 1.75em;
}
.businessPage .page-contents .domain04 .domain04-content .p-wrap {
    opacity: 0;
}
.businessPage .page-contents .domain04.textVisible .domain04-content .p-wrap {
    animation: fadeIn;
    animation-fill-mode: forwards;
    animation-duration: 3s;
    animation-delay: 0.8s;
}
.businessPage .page-contents .domain04 .domain04-content .p-wrap .p {
    position: absolute;
    bottom: 85px;
    left: 0;
    color: #FFFFFF;
    font-size: 18px;
    line-height: 2.5;
    letter-spacing: 0.03em;
    margin: 0;
    z-index: 10;
}
@media (max-width: 767px) {
    .businessPage .page-contents .domain04 {
        min-height: calc(100vh + 120px);
        min-height: calc(100vh + 120px);
    }
    .businessPage .page-contents .domain04 .domain04-content .en-title {
        top: 35px;
        font-size: 15px;
        width: calc(100vw - 48px);
    }
    .businessPage .page-contents .domain04 .domain04-content .en-title .num {
        font-size: 20px;
    }
    .businessPage .page-contents .domain04 .domain04-content .innner-box {
        width: calc(100vw - 48px);
    }
    .businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 {
        top: 40px;
        right: 5px;
        letter-spacing: 0.08em;
        line-height: 1.75;
    }
    .businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 span:nth-child(2) {
        padding-top: 1.5em;
    }
    .businessPage .page-contents .domain04 .domain04-content .p-wrap .p {
        bottom: 35px;
        line-height: 2;
    }
}
@media (max-width: 575px) {
    .businessPage .page-contents .domain04 .domain04-content .h2-wrap h2 {
        font-size: 25px;
    }
    .businessPage .page-contents .domain04 .domain04-content .p-wrap .p {
        font-size: 15px;
    }        
}

.businessPage .footer {
    padding-top: 30px;
    background-color: #FAF8F6;
}