.single-inner {
    padding: 5em 0;
    max-width: 1900px;
    margin: 0 auto;
    transition: all .3s;
}

@media (max-width:1440px) {
    .single-inner {
        margin: 0 0 0 auto;
    }
}

@media (max-width:1400px) {
    .single-inner {
        margin: 0 auto;
    }
}

@media (max-width:767px) {
    .single-inner {
        padding: 3em 0;
    }
}


/* single logo area wrapper */

.single-inner .post-meta-wrp {
    width: 15%;
    transition: transform .5s .1s ease;
}

@media screen and (max-width:1200px) {
    .single-inner .post-meta-wrp {
        width: 20%;
    }
}

@media screen and (max-width:767px) {
    .single-inner .post-meta-wrp {
        width: 100%;
    }
}

.single-inner .post-meta-wrp .post-meta {
    width: 100%;
    max-width: 200px;
    margin-bottom: 2em;
    margin-left: auto;
    margin-right: auto;
    position: sticky;
    top: 1em;
}


.single-inner .post-meta-wrp .post-meta .category_name {
    font-size: min(1.3em, 6vw);
    letter-spacing: .15em;
}

.single-inner .post-meta-wrp .post-meta .category_image {
    width: 50%;
    height: 0;
    padding-bottom: 50%;
    border-radius: 100%;
    margin: 0 auto 1em;
    overflow: hidden;
    position: relative;
}

@media screen and (max-width:767px) {
    .single-inner .post-meta-wrp .post-meta .category_image {
        display: none;
    }
}

.single-inner .post-meta-wrp .post-meta .category_image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}


/* single article area wrapper */

.single-article-wrp {
    width: 60%;
}

@media (max-width:1400px) {
    .single-article-wrp {
        width: 85%;
    }
}

@media (max-width:1200px) {
    .single-article-wrp {
        width: 80%;
    }
}

@media (max-width:767px) {
    .single-article-wrp {
        width: 100%;
    }
}

.single-article-inner {
    /* max-width:640px; */
    max-width: 770px;
    margin: 0 auto;
    padding: 1em 2em 5em;
}

@media (max-width:767px) {
    .single-article-inner {
        padding: 1em 2em 3em;
    }
}

.single-article-inner h2 {
    color: var(--main_subcolor);
    margin: 0 0 2em;
    padding: 0;
    line-height: 1.7;
}

@media (max-width:767px) {
    .single-article-inner h2 {
        margin: 0 0 1.5em;
    }
}

/* single related area wrapper */

.related-wrp {
    width: 25%;
    padding: 1em 0;
}

.related-wrp-inner {
    max-width: 300px;
    padding: 1em 1em 5em;
    margin-right: auto;
    position: sticky;
    top: 1em;
}

@media (max-width:1400px) {
    .related-wrp {
        width: 100%;
        max-width: 760px;
        max-width: 1200px;
        margin: 0 auto;
    }

    .related-wrp-inner {
        max-width: 100%;
        margin: 0 auto;
    }
}

.related-wrp .entry {
    width: 100%;
}


/* youtube */

.is-provider-youtube iframe {
    margin-left: auto;
    margin-right: auto;
}

.wp-embed-aspect-16-9 {
    margin-bottom: 2em;
}

.wp-embed-aspect-16-9 .wp-block-embed__wrapper {
    width: 100%;
    height: 0;
    padding-bottom: 54%;
    position: relative;
}

.wp-embed-aspect-16-9 .wp-block-embed__wrapper iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.wp-embed-aspect-16-9.frame iframe {
    border: 1px solid #ccc;
}


/* code */

.single .wp-block-code code {
    border-radius: 3px;
}

.single .item-wrp>.wp-block-group__inner-container {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    padding: 80px 15px 50px;
}

@media (min-width: 576px) {
    .single .item-wrp>.wp-block-group__inner-container {
        padding: 20px 15px 40px;
    }
}

.related-wrp .related-title {
    font-size: 1em;
    color: var(--main_color);
}

.related-wrp .entry-list {
    display: block;
}

@media (max-width:1400px) {
    .related-wrp .entry-list {
        display: flex;
        justify-content: space-between;
    }
}

.related-wrp .entry-list .entry {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid #ddd;
    padding: 1em;
}

@media (max-width:1400px) {
    .related-wrp .entry {
        width: 48%;
    }
}

@media (max-width:576px) {
    .related-wrp .entry {
        width: 100%;
    }
}

.related-wrp .entry-list .entry .thumb-wrp {
    width: 25%;
    padding: .5em 0;
}

.related-wrp .entry-list .entry .entry-meta-wrp {
    width: 70%;
    /* font-size: .9em; */
}

.related-wrp .entry-list .entry-meta {
    padding: 1% 5%;
}


/* single post related (no thumbnail)*/

.post .related-wrp .entry-list .entry .entry-meta-wrp {
    width: 100%;
}

.post .related-wrp .entry-list .entry-meta {
    padding: 1% 0;
}

.postdate {
    font-size: .9em;
    letter-spacing: 0;
    color: var(--main_color);
}

.related-wrp .entry-title {
    font-size: min(1.05em, 4vw);
    margin-bottom: .5em;
    letter-spacing: 0.025em;
}

@media screen and (min-width:1400px) {
    .related-wrp .entry-title {
        font-size: 1em;
    }
}

.related-wrp .entry-list .entry .exc {
    line-height: 1.5;
    margin-top: 0;
    margin-bottom: 0;
    color: var(--main_color);
}

.related-wrp .entry-list .entry p.cat {
    letter-spacing: 0;
    margin-bottom: .5em;
}


/* single default */


/* link in single page */

.single-article-inner p a:not(.cat) {
    color: var(--main_subcolor);
    text-decoration: underline;
    transition: all .3s;
}

.single-article-inner p a:not(.cat):hover {
    color: var(--main_color);
}


/* image link in single page contents */

.classiceditor .single-article-inner a {
    display: inline-block;
    margin: 1.5em 0 2.5em;
    padding: 0.25em;
    text-align: left;
    text-decoration: none;
}

@media (max-width:767px) {
    .classiceditor .single-article-inner a {
        margin: 1.25em 0;
    }
}


/* image size */

.classiceditor .single-article-inner img.verical {
    width: auto;
    height: auto;
    max-width: 200px;
    display: inline-block;
    margin: 0;
    padding: 0;
}

.classiceditor .single-article-inner img.holizon {
    max-width: min(308px, 60vw);
}

@media (max-width:767px) {
    .classiceditor .single-article-inner img {
        width: auto;
        height: auto;
        max-width: 170px;
        display: inline-block;
        margin: 0;
        padding: 0;
    }
}

@media (max-width:580px) {
    .classiceditor .single-article-inner img.verical {
        width: auto;
        height: auto;
        max-width: 41vw;
        display: inline-block;
        margin: 0;
        padding: 0;
    }

    .classiceditor .single-article-inner img.holizon {
        max-width: calc(100% - 3em);
        margin: 0 auto;
    }
}


/* service layout */

.mainimg-wrp {
    position: relative;
    width: 100%;
    max-height: 500px;
    overflow: hidden;
}

@media screen and (max-width:767px) {
    .mainimg-wrp {
        max-height: 240px;
    }
}

.mainimg-wrp img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mainimg-wrp .title-wrp {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    padding: 0 4vw 4vw;
}

@media screen and (max-width:767px) {
    .mainimg-wrp .title-wrp {
        padding: 0 4vw 6vw;
    }
}

.mainimg-wrp .posttype-label {
    font-size: max(1.1vw, 1.25em);
    margin-bottom: .7em;
}

.mainimg-wrp .title {
    font-size: max(1.9vw, 2.4em);
    margin: 0;
}

@media screen and (max-width:767px) {
    .mainimg-wrp .posttype-label {
        font-size: 4vw;
        margin-bottom: .75em;
    }

    .mainimg-wrp .title {
        font-size: 6.5vw;
    }
}

.policy .single-article-wrp,
.company .single-article-wrp,
.service .single-article-wrp {
    margin: 0 auto;
}

.service .single-article-wrp .single-article-inner {
    max-width: 980px;
    margin: 0 auto;
}

.policy .single-article-wrp .single-article-inner,
.company .single-article-wrp .single-article-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.sales.is-layout-flex {
    width: 100%;
    align-items: unset;
    gap: unset;
}

.sales>.wp-block-image {
    /* font-size: min(.85em, 3.5vw); */
    text-align: center;
    padding: 1em .5em;
    border: 1px solid #ccc;
    margin-bottom: 1em;
    position: relative;
}

.sales>.wp-block-image img {
    display: block;
    width: 30% !important;
    margin: 0 auto;
}

.sales.flex-between.columns-3>*,
.sales.flex-between.columns-3::after {
    width: 32.5%;
}

@media screen and (max-width:767px) {

    .sales.flex-between.columns-3>*,
    .sales.flex-between.columns-3::after {
        width: 49%;
    }
}


.sales span.sml {
    display: block;
    margin-top: .5em;

}

.service .related-wrp {
    width: 100%;
}

.service .related-wrp .entry-list {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

.service .related-wrp .entry-list .entry {
    width: 32%;
}

@media screen and (max-width:767px) {
    .service .related-wrp .entry-list .entry {
        width: 100%;
    }
}

.service .related-wrp-inner {
    max-width: 1440px;
    margin: 0 auto;
}

.message .ceo-message {
    width: 100%;
    max-width: 700px;
    margin: 0 auto;
}

.message .ceo-message p {
    font-size: min(.9em, 3.3vw);
    line-height: 2.2;
}

@media screen and (max-width:767px) {
    .message .ceo-message p {
        line-height: 2;
    }

    .message .ceo-message p br {
        display: none;
    }
}

.mission.single-inner {
    /* padding-top: 3em; */
}

h2.mission-title-en {
    font-size: min(1.8em, 6vw);
    margin-bottom: .5em;
    color: var(--main_subcolor);
}

.mission-title-jp {
    font-size: min(1.3em, 4vw);
    margin-bottom: 3em;
}

h3.mission-text1 {
    font-size: min(1.2em, 3.5vw);
    padding-top: 1em;
    margin-bottom: 1em;
}

h2.mission-text2 {
    font-size: min(1.6em, 5vw);
    margin-bottom: 2em;
}

.mission-frame {
    width: 100%;
    border: 1px solid #ccc;
    margin: 1em auto;
    padding: 2em;
}

.mission-list {
    width: 100%;
    max-width: 100% !important;
    margin: 0 !important;
}

.mission-list li {
    font-size: min(.8em, 3.5vw);
    line-height: 1.8;
    position: relative;
    text-align: center;
    width: 33.33%;
    padding: 2em;
    counter-increment: number;
}

@media screen and (max-width:767px) {
    .mission-list li {
        width: 100%;
    }
}

.mission-list li::before {
    content: "0" counter(number);
    display: block;
    width: 1.5em;
    font-size: min(2.5em, 7vw);
    font-weight: 100;
    font-family: var(--enL);
    color: var(--main_subcolor);
    border-bottom: 2px solid #ccc;
    padding-bottom: .5em;
    margin: 0 auto 1em;
}


.mission-list li:nth-child(1),
.mission-list li:nth-child(2),
.mission-list li:nth-child(4),
.mission-list li:nth-child(5) {
    border-right: 1px solid #ccc;
}

.mission-list li:nth-child(1),
.mission-list li:nth-child(2),
.mission-list li:nth-child(3) {
    border-bottom: 1px solid #ccc;
}

@media screen and (max-width:767px) {

    .mission-list li:nth-child(1),
    .mission-list li:nth-child(2),
    .mission-list li:nth-child(4),
    .mission-list li:nth-child(5) {
        border-right: none;
        border-bottom: 1px solid #ccc;
    }
}

.wp-block-table thead {
    border-bottom: 2px solid;
}

.wp-block-table th,
.wp-block-table td {
    padding: 1em 0;
    font-weight: normal;
}

.wp-block-table table {
    margin-bottom: 1em;
}

.technology-list {
    padding: 5em 1em;
    background-color: rgba(243, 243, 240, 0.7);
    z-index: 10;
}

.technology-list .title {
    color: var(--main_subcolor);
}

.technology-list .entry-list {
    max-width: 1200px;
    margin: 0 auto;
}

.technology-list .entry-list.columns-4 .entry {
    /* padding: 2em 2em 0; */
}

@media screen and (max-width:767px) {
    .technology-list .entry-list.columns-4 .entry {
        width: 100%;
        display: flex;
        justify-content: space-between;
        padding: 3%;
    }

    .technology-list .entry-list.columns-4 .entry .thumb-wrp {
        width: 25%;
        padding: .5em 0;
    }

    .technology-list .entry-list.columns-4 .entry .thumb-wrp .thumb16-9 {
        padding-bottom: 100%;
    }

    .technology-list .entry-list.columns-4 .entry .entry-meta-wrp {
        width: 70%;
    }

    .technology-list .entry-list.columns-4 .entry .entry-meta {
        padding: 1% 5%;
    }
}

.contents-menu-wrp {
    padding: 2em 1em;
}

@media screen and (max-width:767px) {
    .contents-menu-wrp {
        padding: 1em 0 0;
    }
}

.contents-menu-wrp a {
    display: block;
    padding: 1em;
    text-align: center;
    width: 15%;
    border-right: 1px solid #ccc;
}

.contents-menu-wrp a:last-child {
    border-right: none;
}

/* policy */
.policy .policy-frame {
    max-width: 900px;
    margin: 0 auto;
    border: 1px solid #ccc;
    padding: 3em 4em;
    font-size: min(.9em, 3.3vw);
}

@media screen and (max-width:767px) {
    .policy .policy-frame {
        border: 1px solid #ccc;
        padding: 1.5em 1em;
    }
}

.policy .policy-frame li,
.policy .policy-frame p {
    margin-bottom: .5em;
    font-size: min(.9em, 3.3vw);
    line-height: 1.8;
    text-align: justify;
}

.policy .policy-frame .contact {
    margin: 2em auto;
    border: 1px solid #ccc;
    padding: 2.5em 1em;
}

.policy .policy-frame .contact h3 {
    color: var(--main_subcolor);
}

@media screen and (max-width:767px) {
    .contents-menu-wrp a {
        padding: .5em;
        width: 25%;
    }

    .policy .contents-menu-wrp a {
        width: 33%;
        margin-bottom: 1em;
    }

    .policy .contents-menu-wrp a:nth-child(2) {
        border-right: none;
    }
}

.policy .policy-frame h2 {
    font-size: min(1.15em, 4vw);
    margin-bottom: 1em;
}

.policy .policy-frame h3 {
    font-size: min(1em, 4vw);
    margin-bottom: 1em;
}

.security .title-wrp .title,
.business-policy .title-wrp .title,
.privacy-policy .title-wrp .title {
    font-size: min(1.3em, 4.5vw);
    margin-bottom: 1em;
}

.contents-menu-wrp .label.en {
    display: block;
    font-size: min(1em, 3vw);
    letter-spacing: 0;
    color: var(--main_subcolor);
    line-height: 1.5;
}

.contents-menu-wrp .label.jp {
    display: block;
    font-size: min(.7em, 2.75vw) !important;
    line-height: 1.5;
}


/* archive */
.archive .entry-list .thumb-wrp {
    padding: 0;
}

.archive .entry-list .entry-meta {
    padding: 5%;
    font-size: .9em;
}

@media screen and (max-width:767px) {

    .archive .post .columns-3 .entry,
    .archive .technology .columns-3 .entry {
        width: 100%;
        display: flex;
        justify-content: space-between;
    }

    .archive .post .columns-3 .entry .thumb-wrp,
    .archive .technology .columns-3 .entry .thumb-wrp {
        width: 25%;
        padding-top: .5em;
    }

    .archive .post .columns-3 .entry .thumb-wrp .thumb,
    .archive .technology .columns-3 .entry .thumb-wrp .thumb {
        padding-bottom: 100%;
    }

    .archive .post .entry-list .entry-meta-wrp,
    .archive .technology .entry-list .entry-meta-wrp {
        width: 70%;
    }
}

/* company */
.company-profile-table {
    width: 100%;
}

.policy .single-inner,
.company .single-inner {
    padding: 2em 1.5em 5em;
}

@media screen and (max-width:767px) {

    .policy .single-inner,
    .company .single-inner {
        padding: 1em 1.5em 3em;
    }

    .policy .single-inner,
    .company .single-inner {
        padding: 1em 1.5em 3em;
    }

    .company .single-article-inner {
        padding: 0;
    }
}

.company-profile-table .label,
.company-profile-table .text-box {
    padding: 1.5em 0;
    border-bottom: 1px solid #ccc;
}

.company-profile-table .label {
    width: 20%;
    font-size: min(.9em, 3.3vw);
}

@media screen and (max-width:767px) {
    .company-profile-table .label {
        width: 100%;
        padding: 1.5em 0 0;
        border-bottom: none;
    }

    .company-profile-table .label::before {
        content: '';
        display: inline-block;
        width: .3em;
        height: .3em;
        border-radius: 50%;
        border: 4px solid var(--main_subcolor);
        margin-right: .5em;
    }
}

.company-profile-table .text-box {
    width: 80%;
    font-size: min(.9em, 3.5vw);
}

@media screen and (max-width:767px) {
    .company-profile-table .text-box {
        width: 100%;
        padding-top: 1em;
    }
}

.company-profile-table .text-box .box h4 {
    font-size: min(.9em, 3.5vw);
    margin-top: .5em;
}

.company-profile-table .text-box .box {
    width: 50%;
    margin-bottom: 1.5em;
}

@media screen and (max-width:767px) {
    .company-profile-table .text-box .box {
        width: 100%;
    }
}

.company-profile-table .text-box ul {
    width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
}

.company-profile-table .text-box li {
    display: block;
    font-size: .9em;
    margin: 0;
    padding: 0;
    padding-left: 1.3em;
    list-style: none;
    position: relative;
    margin-bottom: 1em;
}

.company-profile-table .text-box ul.org li {
    width: 50%;
}

@media screen and (max-width:767px) {
    .company-profile-table .text-box ul.org li {
        width: 100%;
    }
}

.company-profile-table .text-box li::before {
    content: '';
    width: .3em;
    height: .3em;
    border: 3px solid #ccc;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 50%;
    transform: translateY(.4em);
}

/* certification */
.company .certification .certification-table {
    max-width: 780px;
}

.certification-table td,
.certification-table th {
    padding: 1.5em .5em;
    font-size: min(.9em, 3.5vw);
}

.certification-table td:nth-child(2n) {
    text-align: right;
    width: 15%;
}

/* branch */
.company .branch .office-wrp {

    font-size: min(.9em, 3.3vw);
    border-bottom: 1px solid #ccc;
    padding-bottom: 2em;
    margin-bottom: 2em;
}

.company .branch-table .office-wrp {}

.company .branch-table .office-wrp .office,
.company .branch-table .office-wrp .address,
.company .branch-table .office-wrp .tel {
    display: block;
    width: 33%;
}

@media screen and (max-width:767px) {

    .company .branch-table .office-wrp .office,
    .company .branch-table .office-wrp .address,
    .company .branch-table .office-wrp .tel {
        display: block;
        width: 100%;
        border: none;
        padding: 0 0 1em;
    }

}

/* history */
.company .history .history-table {
    width: 100%;
    max-width: 800px;
}

.history .flex-between {
    border-bottom: 1px solid #ddd;
}

.history .flex-between>div {
    display: flex;
    align-items: center;
}

.history .year-wrp {
    width: 25%;
    display: flex;
    flex-wrap: wrap;
}

@media screen and (max-width:767px) {

    .history .year-wrp {
        width: 30%;
        display: block !important;
        text-align: center;
        padding: 1.5em 1em 1em 0;
    }
}

.history .year {
    width: 50%;
    font-size: min(1.7em, 7vw);
    line-height: 1;
    font-family: var(--enL);
    text-align: left;
    color: var(--main_subcolor);
}

.history .year-jp {
    width: 50%;
    font-size: min(.85em, 3vw);
}

@media screen and (max-width:767px) {

    .history .year,
    .history .year-jp {
        display: block;
        width: 100%;
        text-align: center;
    }
}


.history .text-box {
    width: 70%;
    text-align: left;
    position: relative;
    padding: 2em 0;
}

@media screen and (max-width:767px) {
    .history .text-box {
        width: 60%;
    }
}

.history .text-box p {
    font-size: min(.9em, 3.3vw);
    line-height: 1.6;
    text-align: left;
    padding-bottom: 0;
    margin-bottom: 0;
    position: relative;
}

.history .text-box p::before {
    display: block;
    content: '';
    width: 4px;
    height: 4px;
    border: 4px solid var(--main_subcolor);
    background-color: #fff;
    border-radius: 100%;
    position: absolute;
    top: .5em;
    left: -40px;
    z-index: 2;
}

.history .text-box::after {
    display: block;
    content: '';
    width: 1px;
    height: 110%;
    background-color: #ccc;
    position: absolute;
    top: -5%;
    left: -35px;
}

/* sub image area */
@media screen and (max-width:767px) {
    .subimg-wrp {
        padding: 0 1em 1em;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        gap: unset;
    }

    .subimg-wrp>.wp-block-column {
        width: 49% !important;
        flex-basis: unset !important;
        flex-grow: unset !important;
        margin: 0 0 2%;
        padding: 0;
    }

    .subimg-wrp.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
        flex-basis: unset !important;
        flex-grow: unset !important;

    }

    .subimg-wrp>.wp-block-column figure {
        aspect-ratio: 1/1;
    }

    .subimg-wrp>.wp-block-column figure img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}