/* Business */
#business {
    background: #f0f0f0;
}
/* Service - service-header */
#business #business-details .service-header {
    position: relative;
    height: 55em;
}
#business #business-details hgroup h1 {
    font-size: 6.5em;
    letter-spacing: 0.05em;
}
#business #business-details .service-header span[lang="ja"] {
    padding-top: 30px;
    margin-top: 10px;
    padding-bottom: 0;
}
#business #business-details .service-header span[lang="ja"]::before {
    bottom: auto;
    top: 0;
}
#business #business-details .service-header > .flex {
	align-items: stretch;
    gap: calc( var(--gap) * 5 );
}
#business #business-details .service-header > .flex > div:first-child {
    position: relative;
    flex: 0 1 auto;
    z-index: 3;
    height: 35em;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
#business #business-details .service-header > .flex > div:last-child {
    flex: 0 0 auto;
    width: 100%;
    overflow: hidden;
    margin-left: auto;
    margin-right: calc(50% - 50vw);
    height: 55em;
}
#business #business-details .service-header > .flex > div:last-child img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

/* Wrap */
#business #business-details > .wrap {
    margin: 0;
}
#business #business-details > .wrap::before {
  content: "";
  position: absolute;
  left: calc(50% - 50vw);
  top: 0;
  width: 100vw;
  height: 11px;
  background: linear-gradient( to right, var(--color-orange) 0 25%, var(--color-blue) 25% 50%, transparent 50% 100%);
  pointer-events: none;
  z-index: 10;
}
#business #business-details > .wrap.customer::before {
  background: linear-gradient( to right, var(--color-orange) 0 50%, transparent 50% 100%);
}
#business #business-details > .wrap.business::before {
  background: linear-gradient( to right, var(--color-blue) 0 50%, transparent 50% 100%);
}

/* Intro */
#business #business-details #intro {
    padding: 0;
    margin-top: -18.7em;
    background: linear-gradient(to right, var(--color-white) 0 50%, transparent 50% 100%);
}
#business #business-details #intro .service-type {
    padding-top: calc( var(--padding) * 3 );
    position: relative;
}
#business #business-details #intro .service-type span[lang="en"]{
    padding: 0 var(--padding);
    font-family: "Murecho", sans-serif;
    letter-spacing: .12em;
    border-left: 1px solid var(--color-black);
    border-right: 1px solid var(--color-black);
    font-size: 1.3em;
    font-weight: 300;
    color: var(--color-text-gray);
}
#business #business-details #intro .service-type h2 {
    margin-top: 10px;
    letter-spacing: .12em;
    font-size: 4em;
}
#business #business-details #intro .service-type h2 + .flex {
    margin-top: calc( var(--margin) / 2 );
}
#business #business-details #intro .cover {
    padding-top: calc(var(--section-space) / 2);
    margin-top: 0;
    background: var(--color-white);
}

/* Common parts */
#business #business-details h3 {
    text-align: left;
    padding-left: var(--padding);
    letter-spacing: .12em;
    line-height: 1.2;
    border-left: 10px solid var(--color-gray);
    font-size: 3.1em;
}
#business #business-details h3.customer {
    border-left: 8px solid var(--color-orange);
}
#business #business-details h3.business {
    border-left: 8px solid var(--color-blue);
}
#business #business-details .target {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: calc(( var(--gap) ) / 3);
}
#business #business-details .target .circle {
    content: '';
    width: 1em;
    height: 1em;
    display: block;
    border-radius: 50%;
    background: var(--color-lightgray);
}
#business #business-details .target.business .circle {
    background: var(--color-blue);
}
#business #business-details .target.customer .circle {
    background: var(--color-orange);
}
#business #business-details .target .circle + p {
    margin-top: 0;
    line-height: 1.6;
    letter-spacing: .12em;
    font-weight: 600;
    font-size: 1.5em;
    font-family: "Murecho", sans-serif;
}
#business #business-details .target.business .circle + p {
    color: var(--color-blue);
}
#business #business-details .target.customer .circle + p {
    color: var(--color-orange);
}
#business #business-details .target-cover.customer {
    padding: 0 var( --padding );
    border-radius: 1.8em;
    background: var(--color-orange);
}
#business #business-details .target-cover.business {
    padding: 0 var( --padding );
    border-radius: 1.8em;
    background: var(--color-blue);
}
#business #business-details .target-cover.customer .circle ,
#business #business-details .target-cover.business .circle {
    background: var(--color-white);
}
#business #business-details .target-cover.customer .circle + p ,
#business #business-details .target-cover.business .circle + p {
    color: var(--color-white);
}
#business #business-details .parts-title {
    display: flex;
    justify-content: center;
    align-items: center;
}
#business #business-details .parts-title::before {
    flex: 1 0 auto;
    height: 3px;
    display: block;
    content: '';
    background: var(--color-black);
}
#business #business-details .parts-title::after {
    flex: 1 0 auto;
    height: 3px;
    display: block;
    content: '';
    background: var(--color-black);
}
#business #business-details .parts-title p {
    padding: 0 var(--padding);
    letter-spacing: .12em;
    font-size: 2.3em;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    border-left: 3px solid var(--color-black);
    border-right: 3px solid var(--color-black);
}
#business #business-details .parts-title p > .number {
    padding: 0 2px;
    font-size: 1.2em;
	font-family: "Murecho", sans-serif;
}

#business #business-details .parts-box-vertical {
    padding: calc(var(--padding) / 2) 0;
    margin-top: calc(var(--margin) * 1.5);
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    gap: calc(var(--gap) * 1.5);
    border-top: 1px solid var(--color-black);
    border-bottom: 1px solid var(--color-black);
}
#business #business-details .parts-box-vertical .title {
    text-orientation: upright;
    writing-mode: vertical-lr;
    text-align: center;
    font-size: 1.8em;
    color: var(--color-white);
    background: var(--color-orange);
}
#business #business-details .parts-box-vertical .title + div {
    margin: 0;
}
#business #business-details .parts-box-vertical .card {
    margin: 0;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: calc(var(--gap) * 2);
}
#business #business-details .parts-box-vertical .card:last-child {
    margin-top: 10px;
    padding-top: calc(var(--padding) / 2);
    border-top: 1px solid var(--color-black);
}
#business #business-details .parts-box-vertical .card > div:first-child {
    margin: 0;
    flex: 1 1 auto;
}
#business #business-details .parts-box-vertical .card > div:first-child .buttons {
    justify-content: space-between;
    width: 100%;
    margin-top: calc(var(--margin) / 3);
}
#business #business-details .parts-box-vertical .card > div:first-child .buttons a {
    width: 47%;
    font-weight: 700;
}
#business #business-details .parts-box-vertical .card > div:first-child {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: var(--gap);
}
#business #business-details .parts-box-vertical .card > div:last-child {
    margin: 0;
    flex: 0 0 480px;
    width: min(480px, 100%);
    aspect-ratio: 24 / 17;
    overflow: hidden;
}
#business #business-details .parts-box-vertical .card:last-child > div:last-child {
    padding: 5px 0;
    margin: 0;
    flex: 0 0 480px;
    width: min(480px, 100%);
    aspect-ratio: 24 / 19;
    overflow: hidden;
}
#business #business-details .parts-box-vertical .card > div img {
    max-width: 100%;
    margin: 0;
    width: auto;
    height: 114%;
    object-fit: cover;
    object-position: 40% 100%;
    display: block;
}
#business #business-details .parts-box-vertical .card > div:last-child img {
    max-width: 100%;
    margin: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 100% 100%;
    display: block;
}
#business #business-details .parts-box-vertical .card > div:first-child .arrow-link {
    margin-top: calc(var(--margin) / 2);
}
#business #business-details a.outer-link {
    min-width: 180px;
	border-radius:0;
	letter-spacing:0;
	padding:calc(var(--padding) * 0.25) calc(var(--padding) - 5px) calc(var(--padding) * 0.25) var(--padding);
	margin:auto 0;
	display:flex;
	align-items: center;
	justify-content:center;
	gap:var(--gap);
    font-size: 1.3em;
    border:solid 1px var(--color-black);
}
#business #business-details a.outer-link::after {
    content:'';
    width:1.3em;
    aspect-ratio: 1;
    transition: var(--transition);
    translate: -5px 0;
    background:url(../_img/icon/new_tab_black.svg) right center / contain no-repeat;
    translate: -5px 0;
}
#business #business-details a.outer-link:hover::after {
    translate: 0 0;
}

#business #business-details .treat-h4 {
    padding: 0 0 calc(var(--padding) / 2) var(--padding);
    letter-spacing: .12em;
    font-size: 2.1em;
    color: var(--color-orange);
    border-left: 2px solid var(--color-orange);
    border-bottom: 2px solid var(--color-orange);
}

#business #business-details .treat-h4.blue {
    color: var(--color-blue);
    border-left: 2px solid var(--color-blue);
    border-bottom: 2px solid var(--color-blue);
}

@media (max-width: 920px) {
    #business #business-details .target .circle + p {
        font-size: 1.3em;
    }
    #business #business-details .parts-title p {
        font-size: 2em;
    }
    #business #business-details .parts-title::before ,
    #business #business-details .parts-title::after {
        content: none;
    }
    #business #business-details .service-header {
        max-height: none;
        height: auto;
    }
    #business #business-details .service-header .flex {
        flex-direction: column;
        gap: var(--gap);
    }
    #business #business-details .service-header .flex > div:first-child {
        order: 2;
        height: auto;
        padding-bottom: calc(var(--padding) * 2);
    }
    #business #business-details .service-header .flex > div:last-child {
        width: 100%;
        margin-right: 0;
        order: 1;
    }
    #business #business-details > .wrap::before {
        background: linear-gradient(to right, var(--color-orange) 0 50%, var(--color-blue) 50% 100%);
    }
    #business #business-details > .wrap.customer::before {
        background: var(--color-orange);
    }
    #business #business-details > .wrap.business::before {
        background: var(--color-blue);
    }
    #business #business-details #intro {
        margin-top: 0;
        background: var(--color-white);
    }
    #business #business-details #intro .service-type {
        padding-top: calc(var(--padding) * 2);
    }
    #business #business-details #intro .cover {
        padding-top: calc(var(--section-space) * 2);
    }
    #business #business-details .parts-box-vertical {
        flex-direction: column;
    }
    #business #business-details .parts-box-vertical .title {
        writing-mode: horizontal-tb;
    }
    #business #business-details .parts-box-vertical .card {
        flex-direction: column;
    }
    #business #business-details .parts-box-vertical .card:last-child {
        margin-top: var(--margin);
    }
    #business #business-details .parts-box-vertical .card > div:first-child {
        width: 100%;
        flex: 0 0 auto;
    }
    #business #business-details .parts-box-vertical .card > div:first-child .buttons a {
        width: 100%;
    }
    #business #business-details .parts-box-vertical .card > div:last-child {
        flex: 0 0 auto;
    }
    #business #business-details .parts-box-vertical .card:last-child > div:last-child {
        flex: 0 0 auto;
    }
    #business #business-details a.outer-link {
        min-width: fit-content;
    }

}
@media (max-width: 820px) {}
@media (max-width: 520px) {
    #business #business-details .service-header>.flex>div:last-child {
    height: 35em;
}
    #business #business-details hgroup h1{
        font-size: 4em;
    }
    #business #business-details #intro .service-type h2{
        font-size: 3em;
    }
    #business #business-details #intro .service-type h2 + .flex {
        margin-top: calc(var(--margin) / 4);
    }
    #business #business-details h3 {
        font-size: 2.4em;
    }
}