/*! normalize.css v6.0.0 | MIT License | github.com/necolas/normalize.css */
html {
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    line-height: 1.15
}

article,aside,footer,header,nav,section {
    display: block
}

h1 {
    margin: .67em 0;
    font-size: 2em
}

figcaption,figure,main {
    display: block
}

figure {
    margin: 1em 40px
}

hr {
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

pre {
    font-size: 1em;
    font-family: monospace,monospace
}

a {
    -webkit-text-decoration-skip: objects;
    background-color: transparent
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

b,strong {
    font-weight: inherit
}

b,strong {
    font-weight: bolder
}

code,kbd,samp {
    font-size: 1em;
    font-family: monospace,monospace
}

dfn {
    font-style: italic
}

mark {
    background-color: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub,sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline
}

sub {
    bottom: -0.25em
}

sup {
    top: -0.5em
}

audio,video {
    display: inline-block
}

audio:not([controls]) {
    display: none;
    height: 0
}

img {
    border-style: none
}

svg:not(:root) {
    overflow: hidden
}

button,input,optgroup,select,textarea {
    margin: 0
}

button,input {
    overflow: visible
}

button,select {
    text-transform: none
}

button,html [type=button],[type=reset],[type=submit] {
    -webkit-appearance: button
}

button::-moz-focus-inner,[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner {
    padding: 0;
    border-style: none
}

button:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring {
    outline: 1px dotted ButtonText
}

legend {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: table;
    max-width: 100%;
    padding: 0;
    color: inherit;
    white-space: normal
}

progress {
    display: inline-block;
    vertical-align: baseline
}

textarea {
    overflow: auto
}

[type=checkbox],[type=radio] {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details,menu {
    display: block
}

summary {
    display: list-item
}

canvas {
    display: inline-block
}

template {
    display: none
}

[hidden] {
    display: none
}

@font-face {
    font-weight: 400;
    src: url("../fonts/Roboto/Roboto-Regular.woff") format("woff"),url("../fonts/Roboto/Roboto-Regular.ttf") format("truetype");
    font-family: "Roboto";
    font-display: swap
}

@font-face {
    font-weight: 700;
    src: url("../fonts/Roboto/Roboto-Bold.woff") format("woff"),url("../fonts/Roboto/Roboto-Bold.ttf") format("truetype");
    font-family: "Roboto";
    font-display: swap
}

@font-face {
    font-weight: 400;
    src: url("../fonts/Zen_Kaku_Gothic_New/ZenKakuGothicNew-Regular.woff") format("woff"),url("../fonts/Zen_Kaku_Gothic_New/ZenKakuGothicNew-Regular.ttf") format("truetype");
    font-family: "Zen Kaku Gothic New";
    font-display: swap
}

@font-face {
    font-weight: 700;
    src: url("../fonts/Zen_Kaku_Gothic_New/ZenKakuGothicNew-Bold.woff") format("woff"),url("../fonts/Zen_Kaku_Gothic_New/ZenKakuGothicNew-Bold.ttf") format("truetype");
    font-family: "Zen Kaku Gothic New";
    font-display: swap
}

@font-face {
    font-weight: 400;
    src: url("../fonts/Poppins/Poppins-Regular.woff") format("woff"),url("../fonts/Poppins/Poppins-Regular.ttf") format("truetype");
    font-family: "Poppins";
    font-display: swap
}

@font-face {
    font-weight: 600;
    src: url("../fonts/Poppins/Poppins-SemiBold.woff") format("woff"),url("../fonts/Poppins/Poppins-SemiBold.ttf") format("truetype");
    font-family: "Poppins";
    font-display: swap
}

@font-face {
    font-weight: 900;
    src: url("../fonts/Montserrat/Montserrat-Black.woff") format("woff"),url("../fonts/Montserrat/Montserrat-Black.ttf") format("truetype");
    font-family: "Montserrat";
    font-display: swap
}

.footer_nav,.footer_sns,.bredcrumb,.reason_list,.event_list,.columns .side_section .list,.post_item .cats,.header_brand .nav_list {
    margin: 0;
    padding: 0;
    list-style: none
}

#pagetop img,.logo img,.separator img,.hero_oem_title img,.intro_ph img,.choose_img img,.reason_ph img,.reason_img img {
    width: 100%
}

.hero_oem_title {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

.btn.square.white .icon_arrow,.slider_banner .splide__arrows,.contact_oem_box .title span::before,.contact_oem_box .title span::after,.inc_parts .btn.square.white .icon_arrow {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%)
}

.heading span::after,.inc_parts .heading span::after {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%)
}

.event_list li .thumb img,.post_item .thumb img {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center;
    object-position: center;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%)
}

html,body {
    margin: 0;
    font-size: 62.5%
}

body {
    background-color: #fff;
    color: #606470;
    line-height: 1.6;
    font-family: "Zen Kaku Gothic New",Helvetica,Arial,"Hiragino Sans",ヒラギノ角ゴシック,"Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3",メイリオ,Meiryo,"ＭＳ Ｐゴシック","MS P Gothic",sans-serif
}

a {
    color: blue;
    text-decoration: none;
    word-break: break-all;
    -webkit-transition: all .3s ease;
    -o-transition: all .3s ease;
    transition: all .3s ease
}

a:hover {
    -webkit-transition: all .3s ease;
    -o-transition: all .3s ease;
    transition: all .3s ease
}

img {
    display: block
}

input,textarea {
    border: none
}

textarea {
    resize: none
}

button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: 0;
    border: none;
    outline: none;
    background-color: transparent;
    cursor: pointer
}

::-moz-selection {
    background: #003591;
    color: #fff
}

::selection {
    background: #003591;
    color: #fff
}

* {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

*::before,*::after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.header_brand .nav_list {
    padding-bottom: 15px;
    text-align: right
}

.header_brand .nav_list li {
    display: inline-block;
    margin-left: min(1.3888888889vw,20px);
    color: #fff;
    font-weight: bold;
    font-size: 15px
}

.header_brand .nav_list li .icon_arrow {
    display: none
}

.header_brand .nav_list li a {
    color: #fff
}

.header_brand .nav_list li.nav_box {
    margin-top: .5em;
    border: 1px solid currentColor;
    font-weight: 400;
    font-family: "Roboto",sans-serif
}

.header_brand .nav_list li.nav_box a {
    display: inline-block;
    width: 140px;
    line-height: 43px;
    text-align: center
}

.header_brand .nav_list li.nav_line {
    display: none
}

@media screen and (max-width: 820px) {
    .header_brand .nav {
        display:none;
        z-index: 9998;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        padding: 0 3.90625vw;
        overflow-y: scroll;
        background-color: #003591
    }

    .header_brand .nav_list {
        max-width: 85%;
        margin: 7.8125vw auto;
        padding-bottom: 13.0208333333vw;
        border-top: 1px dashed rgba(255,255,255,.5);
        text-align: left
    }

    .header_brand .nav_list li {
        display: block;
        position: relative;
        margin-left: 0;
        padding: 0;
        border-bottom: 1px dashed rgba(255,255,255,.5);
        font-size: 4.1666666667vw
    }

    .header_brand .nav_list li a {
        display: block;
        padding: 3.90625vw 3.90625vw
    }

    .header_brand .nav_list li .icon_arrow {
        display: inline-block;
        position: absolute;
        top: 50%;
        right: 3.90625vw;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        line-height: 0
    }

    .header_brand .nav_list li .icon_arrow svg path {
        fill: #fff
    }

    .header_brand .nav_list li.nav_box {
        margin-top: 5.2083333333vw;
        padding: 0
    }

    .header_brand .nav_list li.nav_box a {
        width: 100%;
        padding: 2.6041666667vw;
        line-height: unset
    }

    .header_brand .nav_list li.nav_line {
        display: block;
        margin-top: 5.2083333333vw;
        padding: 0
    }

    .header_brand .nav_list li.nav_line a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 1.3020833333vw;
        background-color: #07c755
    }

    .header_brand .nav_list li.nav_line img {
        display: inline-block;
        width: 10.4166666667vw
    }

    .header_brand .nav_list li.nav_line span {
        padding-left: 2.6041666667vw
    }
}

.header_brand .nav_btn {
    display: none
}

@media screen and (max-width: 820px) {
    .header_brand .nav_btn {
        display:block;
        z-index: 9999;
        position: absolute;
        top: 50%;
        right: 5%;
        width: 6.5104166667vw;
        height: 3.90625vw;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
        cursor: pointer
    }

    .header_brand .nav_btn span {
        display: block;
        position: absolute;
        width: 6.5104166667vw;
        height: .2604166667vw;
        background-color: #fff;
        -webkit-transition: all .3s ease;
        -o-transition: all .3s ease;
        transition: all .3s ease
    }

    .header_brand .nav_btn span:nth-child(1) {
        top: 0
    }

    .header_brand .nav_btn span:nth-child(2) {
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%)
    }

    .header_brand .nav_btn span:nth-child(3) {
        bottom: 0
    }

    .header_brand .nav_btn.close span:nth-child(1) {
        -webkit-transform: translateY(1.8229166667vw) rotate(225deg);
        -ms-transform: translateY(1.8229166667vw) rotate(225deg);
        transform: translateY(1.8229166667vw) rotate(225deg)
    }

    .header_brand .nav_btn.close span:nth-child(2) {
        opacity: 0
    }

    .header_brand .nav_btn.close span:nth-child(3) {
        -webkit-transform: translateY(-1.8229166667vw) rotate(-225deg);
        -ms-transform: translateY(-1.8229166667vw) rotate(-225deg);
        transform: translateY(-1.8229166667vw) rotate(-225deg)
    }
}

.pc {
    display: block
}

.sp {
    display: none
}

@media screen and (max-width: 820px) {
    .pc {
        display:none
    }

    .sp {
        display: block
    }
}

.inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 40px
}

@media screen and (max-width: 820px) {
    .inner {
        padding:0 5%
    }
}

#pagetop {
    display: block;
    z-index: 10;
    position: fixed;
    top: auto;
    right: 20px;
    bottom: 20px;
    width: 51px
}

@media screen and (max-width: 820px) {
    #pagetop {
        display: none!important;
    }
}

.logo {
    margin: 0
}

.hidden {
    overflow: hidden
}

.header {
    z-index: 9998;
    position: relative;
    width: 100%;
    padding: 10px 0;
    background-color: #003591
}

@media screen and (max-width: 820px) {
    .header {
        position:fixed;
        padding: 2.6041666667vw 0
    }
}

.header>.inner {
    padding: 0 20px
}

.header_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

@media screen and (max-width: 820px) {
    .header_row {
        -webkit-box-pack:center;
        -ms-flex-pack: center;
        justify-content: center
    }
}

.header_logo {
    width: 230px
}

@media screen and (max-width: 820px) {
    .header_logo {
        width:45.5729166667vw
    }
}

.header_desc {
    margin: 0;
    color: #fff;
    font-weight: normal;
    font-size: 14px;
    text-align: right
}

@media screen and (max-width: 820px) {
    .header_desc {
        display:none
    }
}

.float_bnr {
    position: fixed;
    top: 115px;
    right: 0;
}

@media screen and (max-width: 820px) {
    .float_bnr {
        top: auto;
        bottom: 21px;
        right: 20px;
    }
}


.icon_sns {
    display: inline-block
}

.icon_sns svg path {
    fill: #fff
}

.footer {
    z-index: 2;
    position: relative;
    padding: 35px 0;
    background-color: #003591
}

.footer_logo {
    width: 200px
}

@media screen and (max-width: 820px) {
    .footer {
        padding: 35px 0 100px;
    }
    .footer_logo {
        width:45.5729166667vw
    }
}

.footer_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

@media screen and (max-width: 820px) {
    .footer_row {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

.footer_nav {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
}

.footer_nav li {
    display: inline-block;
    margin-left: 25px;
    color: #fff;
    font-weight: bold;
    font-size: 16px
}

.footer_nav li a {
    color: #fff
}

@media screen and (max-width: 820px) {
    .footer_nav {
        margin-top:6.5104166667vw;
        text-align: center
    }

    .footer_nav li {
        margin: 1.3020833333vw;
        font-size: 3.6458333333vw
    }
}

.footer_sns {
    margin-top: 25px;
    padding-bottom: 35px;
    text-align: right
}

.footer_sns li {
    display: inline-block;
    margin: 0 10px
}

@media screen and (max-width: 820px) {
    .footer_sns {
        margin-top:6.5104166667vw;
        padding-bottom: 6.5104166667vw;
        text-align: center
    }
}

.footer_copy {
    display: block;
    color: #fff;
    font-weight: 400;
    font-size: 12px;
    font-family: "Roboto",sans-serif;
    text-align: right
}

@media screen and (max-width: 820px) {
    .footer_copy {
        font-size:3.125vw;
        text-align: center
    }
}

#main {
    padding-top: 0
}

@media screen and (max-width: 820px) {
    #main.page-oem {
        padding-top:0 !important
    }
}

.section_oem {
    z-index: 1;
    position: relative;
    padding-top: 45px;
    padding-bottom: 112px;
    overflow: hidden
}

.section_oem.choose {
    margin-top: 17px;
    background: url("../images/text_choose.png") repeat-x;
    background-position: 0 0;
    -webkit-animation: text_choose 32s linear infinite;
    animation: text_choose 32s linear infinite
}

.section_oem.reason {
    background: url("../images/text_reason.png") repeat-x;
    background-position: 0 0;
    -webkit-animation: text_reason 22s linear infinite;
    animation: text_reason 22s linear infinite
}

.section_oem.flow {
    padding-bottom: 0;
    background: url("../images/text_flow.png") repeat-x;
    background-position: 0 0;
    -webkit-animation: text_flow 22s linear infinite;
    animation: text_flow 22s linear infinite
}

.section_oem.works {
    margin-top: 80px;
    padding-bottom: 90px;
    overflow: visible;
    background-color: #f0f5f5
}

.section_oem.contact_oem {
    margin-top: 90px;
    background: url("../images/text_contact.png") repeat-x;
    background-position: 0 0;
    -webkit-animation: text_contact 22s linear infinite;
    animation: text_contact 22s linear infinite
}

@media screen and (max-width: 820px) {
    .section_oem {
        padding-top:3.90625vw;
        padding-bottom: 13.0208333333vw
    }

    .section_oem.choose {
        padding-bottom: 0
    }

    .section_oem.works {
        margin-top: 19.53125vw;
        padding-bottom: 11.71875vw
    }

    .section_oem.contact_oem {
        margin-top: 11.71875vw
    }
}

@-webkit-keyframes text_choose {
    from {
        background-position: 0 0
    }

    to {
        background-position: -3380px 0
    }
}

@keyframes text_choose {
    from {
        background-position: 0 0
    }

    to {
        background-position: -3380px 0
    }
}

@-webkit-keyframes text_reason {
    from {
        background-position: 0 0
    }

    to {
        background-position: -2060px 0
    }
}

@keyframes text_reason {
    from {
        background-position: 0 0
    }

    to {
        background-position: -2060px 0
    }
}

@-webkit-keyframes text_flow {
    from {
        background-position: 0 0
    }

    to {
        background-position: -2620px 0
    }
}

@keyframes text_flow {
    from {
        background-position: 0 0
    }

    to {
        background-position: -2620px 0
    }
}

@-webkit-keyframes text_contact {
    from {
        background-position: 0 0
    }

    to {
        background-position: -1440px 0
    }
}

@keyframes text_contact {
    from {
        background-position: 0 0
    }

    to {
        background-position: -1440px 0
    }
}

.more {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-top: 30px
}

.more a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #606470;
    font-weight: bold;
    font-size: 20px
}

@media screen and (max-width: 820px) {
    .more {
        margin-top:6.5104166667vw
    }

    .more a {
        font-size: 3.6458333333vw
    }
}

.icon_back {
    display: inline-block;
    width: 40px;
    height: 40px;
    margin-left: 12px;
    line-height: 0;
    vertical-align: middle
}

.icon_back svg {
    width: 40px;
    height: 40px
}

@media screen and (max-width: 820px) {
    .icon_back {
        position:relative;
        width: 5.859375vw;
        height: 5.859375vw;
        margin-left: 2.0833333333vw
    }

    .icon_back svg {
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%
    }
}

.heading {
    text-align: center
}

.heading span {
    display: inline-block;
    position: relative;
    color: #003591;
    font-weight: 700;
    font-size: 24px;
    line-height: 1;
    font-family: "Roboto",sans-serif
}

.heading span::after {
    display: inline-block;
    top: auto;
    bottom: -16px;
    width: 60px;
    height: 2px;
    background-color: #003591;
    content: ""
}

@media screen and (max-width: 820px) {
    .heading span {
        font-size:4.1666666667vw
    }

    .heading span::after {
        bottom: -4.1666666667vw;
        width: 10.4166666667vw
    }
}

.heading h1 {
    margin-top: 30px;
    margin-bottom: 0;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .heading h1 {
        margin-top:7.8125vw;
        font-size: 5.46875vw
    }
}

.heading h2 {
    margin-top: 30px;
    margin-bottom: 0;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .heading h2 {
        margin-top:7.8125vw;
        font-size: 5.46875vw
    }
}

.heading.left {
    text-align: left
}

.heading.noborder h2 {
    margin-top: 0
}

.heading.noborder span::after {
    content: none
}

.btn {
    display: block;
    margin: 0 auto;
    background-color: #003591;
    color: #fff;
    text-align: center
}

.btn.radius {
    z-index: 1;
    position: relative;
    width: min(29.8611111111vw,430px);
    overflow: hidden;
    border: 2px solid #003591;
    border-radius: 70px;
    font-weight: bold;
    font-size: 20px;
    line-height: 66px
}

.btn.radius::after {
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: scale(0, 1);
    -ms-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    transform-origin: left top;
    background-color: #fff;
    content: "";
    -webkit-transition: .3s ease;
    -o-transition: .3s ease;
    transition: .3s ease
}

.btn.radius:hover {
    color: #003591
}

.btn.radius:hover::after {
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1)
}

@media screen and (max-width: 820px) {
    .btn.radius {
        width:85%;
        border-radius: 13.0208333333vw;
        font-size: 4.1666666667vw;
        line-height: 9.8958333333vw
    }
}

.btn.radius.white {
    background-color: #fff;
    color: #003591
}

.btn.radius.white::after {
    display: none
}

.btn.square {
    width: 380px;
    border-radius: 6px;
    font-weight: bold;
    font-size: 20px;
    line-height: 80px
}

.btn.square.white {
    position: relative;
    width: min(26.3888888889vw,380px);
    border: 1px solid #003591;
    background-color: #fff;
    color: #003591;
    line-height: 78px
}

.btn.square.white .icon_arrow {
    display: inline-block;
    right: 24px;
    width: 10px;
    height: 21px;
    line-height: 0
}

@media screen and (max-width: 820px) {
    .btn.square {
        width:90%;
        margin-top: 5.2083333333vw;
        border-radius: 1.5625vw;
        font-size: 4.1666666667vw;
        line-height: 16.6666666667vw
    }

    .btn.square.white {
        width: 90%;
        margin-top: 0;
        line-height: 16.6666666667vw
    }
}

.bredcrumb {
    margin-top: 30px;
    padding-bottom: 40px
}

@media screen and (max-width: 820px) {
    .bredcrumb {
        margin-top:3.90625vw;
        padding-bottom: 6.5104166667vw
    }
}

.bredcrumb li {
    display: inline;
    position: relative;
    padding-right: 20px;
    font-weight: bold;
    font-size: 16px
}

.bredcrumb li::after {
    position: absolute;
    top: 50%;
    right: 7px;
    width: 8px;
    height: 8px;
    -webkit-transform: translateY(-50%) rotate(45deg);
    -ms-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    border-top: 1px solid currentColor;
    border-right: 1px solid currentColor;
    content: ""
}

.bredcrumb li a {
    color: #606470
}

.bredcrumb li:last-child::after {
    display: none
}

@media screen and (max-width: 820px) {
    .bredcrumb li {
        font-size:3.125vw
    }
}

.lead_text p {
    font-weight: normal;
    font-size: 16px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .lead_text p {
        font-size:3.125vw
    }
}

.separator {
    z-index: -1;
    position: relative;
    width: 100%;
    margin-top: -20px
}

@media screen and (max-width: 820px) {
    .separator {
        margin-top:0
    }
}

.heading_oem {
    text-align: center
}

.heading_oem h2 {
    margin: 0;
    color: #000;
    font-weight: bold;
    font-size: 40px
}

@media screen and (max-width: 820px) {
    .heading_oem h2 {
        font-size:6.5104166667vw
    }
}

.heading_oem span {
    display: inline-block;
    color: #000;
    font-weight: bold;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .heading_oem span {
        margin-top:3.90625vw;
        font-size: 5.2083333333vw
    }
}

.text_oem {
    color: #000;
    font-weight: bold;
    font-size: 18px;
    line-height: 2.22;
    text-align: center
}

@media screen and (max-width: 820px) {
    .text_oem {
        font-size:3.6458333333vw;
        line-height: 1.8
    }
}

.hero_oem {
    z-index: 1;
    position: relative;
    width: 100%;
    height: min(40.2777777778vw,580px);
    overflow: hidden;
    background-image: url(../images/hero_oem-1.webp);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (max-width: 820px) {
    .hero_oem {
        height:100vh;
        background-image: url(../images/sp_hero_oem-1.webp)
    }
}

.hero_oem_title {
    z-index: 3;
    max-width: 771px;
    margin: 0 auto
}

@media screen and (max-width: 820px) {
    .hero_oem_title {
        width:80%;
        max-width: auto
    }
}

.fade_in_trigger {
    opacity: 0
}

.fade_in_trigger.fade_in {
    -webkit-animation-duration: 3s;
    animation-duration: 3s;
    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
    -webkit-animation-name: fade_in;
    animation-name: fade_in;
    opacity: 1
}

@-webkit-keyframes fade_in {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fade_in {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.banner_area {
    max-width: 1340px;
    margin: 0 auto;
    padding: 35px 50px 0
}

@media screen and (max-width: 820px) {
    .banner_area {
        padding:6.5104166667vw;
        padding-bottom: 0
    }
}

.splide .splide__list li img {
    width: 100%
}

.slider_banner {
    position: relative
}

.slider_banner .splide__track {
    height: min(328px,22.7777777778vw)
}

@media screen and (max-width: 820px) {
    .slider_banner .splide__track {
        height:min(377px,49.0885416667vw)
    }
}

.slider_banner .splide__slide {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-item-align: center;
    align-self: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.slider_banner .splide__arrows {
    z-index: 1;
    left: 0;
    width: 100%
}

@media screen and (max-width: 820px) {
    .slider_banner .splide__arrows {
        display:none
    }
}

.slider_banner .prev,.slider_banner .next {
    width: 56px;
    height: 56px
}

.slider_banner .prev::before,.slider_banner .next::before {
    display: block;
    position: absolute;
    top: 25px;
    left: 25px;
    width: 20px;
    height: 3px;
    border-radius: 3px;
    background-color: #003591;
    content: ""
}

.slider_banner .prev::after,.slider_banner .next::after {
    display: block;
    position: absolute;
    top: 25px;
    left: 25px;
    width: 3px;
    height: 20px;
    border-radius: 3px;
    background-color: #003591;
    content: ""
}

@media screen and (max-width: 820px) {
    .slider_banner .prev,.slider_banner .next {
        width:13.0208333333vw;
        height: 13.0208333333vw
    }

    .slider_banner .prev::before,.slider_banner .next::before {
        top: 4.8177083333vw;
        left: 4.8177083333vw;
        width: 4.5572916667vw
    }

    .slider_banner .prev::after,.slider_banner .next::after {
        top: 4.8177083333vw;
        left: 4.8177083333vw;
        height: 4.5572916667vw
    }
}

.slider_banner .prev {
    position: absolute;
    top: 50%;
    left: -56px;
    -webkit-transform: translateY(-50%) rotate(-45deg);
    -ms-transform: translateY(-50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg)
}

.slider_banner .next {
    position: absolute;
    top: 50%;
    right: -56px;
    -webkit-transform: translateY(-50%) rotate(135deg);
    -ms-transform: translateY(-50%) rotate(135deg);
    transform: translateY(-50%) rotate(135deg)
}

@media screen and (max-width: 820px) {
    .slider_banner .prev {
        left:-7.8125vw
    }

    .slider_banner .next {
        right: -7.8125vw
    }
}

.slider_banner:not(.is-overflow) .splide__list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.slider_banner:not(.is-overflow) .splide__slide:last-child {
    margin: 0 !important
}

@media screen and (max-width: 820px) {
    .slider_oem {
        max-width:90%;
        margin-top: 7.8125vw;
        margin-right: auto;
        margin-left: auto
    }
}

.slider_oem_page {
    width: 10px;
    height: 10px;
    margin: 5px;
    border-radius: 50%;
    background-color: #d9d9d9;
    -webkit-transition: all .3s ease;
    -o-transition: all .3s ease;
    transition: all .3s ease
}

.slider_oem_page.is-active {
    background-color: #003591
}

@media screen and (max-width: 820px) {
    .slider_oem_page {
        width:2.6041666667vw;
        height: 2.6041666667vw;
        margin: 1.3020833333vw
    }
}

.slider_oem_pager {
    padding-top: 25px;
    padding-left: 0
}

@media screen and (max-width: 820px) {
    .slider_oem_pager {
        padding-top:6.5104166667vw
    }
}

.intro {
    padding-top: 63px
}

@media screen and (max-width: 820px) {
    .intro {
        padding-top:8.203125vw
    }
}

.intro_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between
}

.intro_inner:nth-child(2) {
    padding-top: 100px
}

@media screen and (max-width: 820px) {
    .intro_inner {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }

    .intro_inner:nth-child(2) {
        padding-top: 7.8125vw
    }
}

.intro_left {
    width: 623px
}

@media screen and (max-width: 820px) {
    .intro_left {
        width:100%
    }
}

.intro_right {
    width: 604px
}

@media screen and (max-width: 820px) {
    .intro_right {
        width:100%
    }
}

.intro_title {
    color: #000;
    font-weight: bold;
    font-size: 32px;
    line-height: 1.4
}

.intro_title span {
    display: block
}

.intro_title span.red {
    color: #e1002a
}

@media screen and (max-width: 820px) {
    .intro_title {
        font-size:5.46875vw;
        text-align: center
    }
}

.intro_sub {
    margin-top: 1em;
    color: #003591;
    font-weight: bold;
    font-size: 20px
}

@media screen and (max-width: 820px) {
    .intro_sub {
        margin:7.8125vw auto;
        font-size: 4.6875vw;
        text-align: center
    }
}

.intro_text {
    color: #000;
    font-weight: bold;
    font-size: 18px;
    line-height: 2
}

.intro_text .color {
    color: #003591
}

@media screen and (max-width: 820px) {
    .intro_text {
        max-width:95%;
        margin-right: auto;
        margin-left: auto;
        font-size: 3.90625vw;
        text-align: justify
    }
}

.intro_note {
    padding: 15px 20px;
    border-radius: 10px;
    background-color: rgba(0,53,145,.2)
}

.intro_note p {
    margin: 0;
    color: #000;
    font-size: 18px
}

@media screen and (max-width: 820px) {
    .intro_note {
        max-width:90%;
        margin-right: auto;
        margin-left: auto;
        padding: 5.2083333333vw
    }

    .intro_note p {
        font-size: 3.6458333333vw
    }
}

.intro_ph {
    max-width: 604px
}

@media screen and (max-width: 820px) {
    .intro_ph {
        margin:5.2083333333vw auto
    }
}

.choose_boxes {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: 50px
}

@media screen and (max-width: 820px) {
    .choose_boxes {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-top: 7.8125vw
    }
}

.choose_box {
    width: 32%
}

@media screen and (max-width: 820px) {
    .choose_box {
        width:100%;
        padding-bottom: 13.8888888889vw
    }
}

.choose_label {
    width: min(22.2222222222vw,320px);
    margin: 0 auto;
    border-radius: 30px;
    background-color: #242424;
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    line-height: 60px;
    text-align: center
}

.choose_label.red {
    background-color: #e1002a
}

.choose_label.blue {
    background-color: #003591
}

@media screen and (max-width: 820px) {
    .choose_label {
        width:90%;
        border-radius: 6.5104166667vw;
        font-size: 4.1666666667vw;
        line-height: 13.0208333333vw
    }
}

.choose_logo {
    margin: 24px 0 20px;
    color: #242424;
    font-weight: 900;
    font-size: 40px;
    line-height: 1;
    font-family: "Montserrat",sans-serif;
    text-align: center
}

@media screen and (max-width: 820px) {
    .choose_logo {
        margin:5.2083333333vw 0;
        font-size: 10.4166666667vw
    }
}

.choose_sub {
    color: #003591;
    font-weight: bold;
    font-size: 20px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .choose_sub {
        font-size:5.2083333333vw
    }
}

.choose_text {
    display: inline-block;
    width: 100%;
    height: 60px;
    margin-bottom: 0;
    color: #000;
    font-size: 16px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .choose_text {
        height:auto;
        font-size: 4.1666666667vw
    }
}

.choose_inner {
    margin-top: 128px;
    padding-top: 178px;
    padding-bottom: 32px;
    background-color: #f0f5f5
}

.choose_inner .choose_label {
    margin: 18px auto
}

@media screen and (max-width: 820px) {
    .choose_inner {
        margin-top:31.25vw;
        padding-top: 15.625vw;
        padding-bottom: 4.1666666667vw
    }
}

.choose_img {
    position: relative;
    margin: -266px auto 0;
    padding-bottom: 22px
}

.choose_img.img01 {
    width: 230px
}

.choose_img.img02 {
    width: 154px
}

.choose_img.img03 {
    width: 120px
}

@media screen and (max-width: 820px) {
    .choose_img {
        margin:-39.0625vw auto 0
    }

    .choose_img.img01 {
        width: 59.8958333333vw;
        padding-bottom: 0
    }

    .choose_img.img02 {
        width: 40.1041666667vw
    }

    .choose_img.img03 {
        width: 31.25vw
    }
}

.reason_area {
    margin-top: 40px;
    padding: 20px 0 50px;
    background-image: url(../images/bg_oem.png);
    background-position: right top;
    background-repeat: no-repeat;
    background-color: #003591
}

@media screen and (max-width: 820px) {
    .reason_area {
        margin-top:5.2083333333vw;
        background-position: right bottom 20%;
        background-size: 90%
    }
}

.reason_list {
    max-width: 700px;
    margin: 0 auto
}

@media screen and (max-width: 820px) {
    .reason_list {
        max-width:90%
    }
}

.reason_list li {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.reason_list li .num {
    display: block;
    width: 45px;
    margin-right: 25px;
    color: #fff;
    font-style: italic;
    font-weight: 700;
    font-size: 40px;
    font-family: "Roboto",sans-serif
}

@media screen and (max-width: 820px) {
    .reason_list li .num {
        width:11.71875vw;
        margin-right: 3.2552083333vw;
        font-size: 7.8125vw
    }
}

.reason_list li .text {
    width: 100%
}

.reason_list li .text p {
    margin: 25px 0;
    padding: 0 20px;
    color: #fff;
    font-size: 18px
}

@media screen and (max-width: 820px) {
    .reason_list li .text p {
        margin:6.5104166667vw 0;
        padding-right: 0;
        padding-left: 3.90625vw;
        font-size: 3.90625vw
    }
}

.reason_list li .dashed {
    position: relative;
    width: 100%;
    height: 1px
}

.reason_list li .dashed::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-image: -webkit-linear-gradient(left, white, white 10px, transparent 10px, transparent 20px);
    background-image: -o-linear-gradient(left, white, white 10px, transparent 10px, transparent 20px);
    background-image: linear-gradient(to right, white, white 10px, transparent 10px, transparent 20px);
    background-size: 20px 1px;
    background-repeat: repeat-x;
    content: ""
}

.reason_row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    max-width: 793px;
    margin: 30px auto -130px
}

.reason_row_inner {
    width: 50%
}

@media screen and (max-width: 820px) {
    .reason_row {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        max-width: 90%;
        margin: 3.90625vw auto 0
    }

    .reason_row_inner {
        width: 100%
    }
}

.reason_ph {
    max-width: 325px;
    margin: 11px auto 0
}

@media screen and (max-width: 820px) {
    .reason_ph {
        max-width:80%
    }
}

.reason_img {
    max-width: 373px;
    margin: 0 auto
}

@media screen and (max-width: 820px) {
    .reason_img {
        max-width:70%;
        padding-bottom: 6.5104166667vw
    }
}

.reason_title {
    color: #000;
    font-weight: bold;
    font-size: 20px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .reason_title {
        font-size:4.1666666667vw
    }
}

.reason_title2 {
    margin-top: 40px;
    color: #003591;
    font-weight: bold;
    font-size: 32px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .reason_title2 {
        font-size:5.2083333333vw
    }
}

.reason_text {
    color: #000;
    font-size: 20px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .reason_text {
        font-size:4.1666666667vw
    }
}

.flow_boxes {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-top: 130px
}

@media screen and (max-width: 820px) {
    .flow_boxes {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-top: 0
    }
}

.flow_box {
    width: 32%;
    padding: 47px 34px;
    background-color: #f0f5f5
}

@media screen and (max-width: 820px) {
    .flow_box {
        width:100%;
        margin-top: 13.0208333333vw;
        padding: 10.4166666667vw 7.8125vw
    }
}

.flow_title {
    margin-top: -70px
}

@media screen and (max-width: 820px) {
    .flow_title {
        margin-top:-14.3229166667vw
    }
}

.flow_title .num {
    display: inline-block;
    padding-right: 22px;
    color: #003591;
    font-weight: 600;
    font-size: 48px;
    line-height: 1;
    font-family: "Roboto",sans-serif;
    vertical-align: middle
}

@media screen and (max-width: 820px) {
    .flow_title .num {
        font-size:9.1145833333vw
    }
}

.flow_title .title {
    display: inline-block;
    color: #003591;
    font-weight: 700;
    font-size: 32px;
    line-height: 1;
    font-family: "Roboto",sans-serif;
    vertical-align: middle
}

@media screen and (max-width: 820px) {
    .flow_title .title {
        font-size:7.8125vw
    }
}

.flow_sub {
    margin-top: 20px;
    color: #003591;
    font-weight: 700;
    font-size: 20px;
    font-family: "Roboto",sans-serif
}

@media screen and (max-width: 820px) {
    .flow_sub {
        margin-top:5.2083333333vw;
        font-size: 4.9479166667vw
    }
}

.flow_text {
    color: #000;
    font-size: 16px;
    line-height: 1.875
}

@media screen and (max-width: 820px) {
    .flow_text {
        font-size:3.90625vw
    }
}

.works>.inner {
    max-width: 1272px
}

.works .more {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.works .more a {
    color: #003591;
    font-size: 14px
}

.works .more a .icon_arrow {
    padding-left: 5px;
    line-height: 0
}

@media screen and (max-width: 820px) {
    .works .more a {
        font-size:3.6458333333vw
    }
}

.works .heading {
    margin-top: -100px
}

.works .heading span {
    font-size: 20px
}

.works .heading span::after {
    display: none
}

.works .heading h2 {
    margin-top: 0;
    font-size: 36px
}

@media screen and (max-width: 820px) {
    .works .heading {
        margin-top:-15.625vw
    }

    .works .heading span {
        font-size: 5.2083333333vw
    }

    .works .heading h2 {
        font-size: 7.8125vw
    }
}

.event_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 100%;
    margin: 40px auto 0;
    gap: 40px 2%
}

@media screen and (max-width: 820px) {
    .event_list {
        gap:5.2083333333vw 6%
    }
}

.event_list li {
    position: relative;
    width: 23.5%;
    overflow: hidden;
    border-radius: 10px
}

@media screen and (max-width: 820px) {
    .event_list li {
        width:47%
    }
}

.event_list li .thumb {
    position: relative;
    width: 100%;
    height: auto;
    padding-top: 100%;
    overflow: hidden
}

@media screen and (max-width: 820px) {
    .event_list li .thumb {
        padding-top:100%;
        border-radius: 10px
    }
}

.event_list li .mask {
    position: absolute;
    top: auto;
    bottom: -100%;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 20px 16px;
    background-color: rgba(0,53,145,.8);
    -webkit-transition: all .3s ease;
    -o-transition: all .3s ease;
    transition: all .3s ease
}

@media screen and (max-width: 1280px) {
    .event_list li .mask {
        padding:1.3888888889vw 1.1111111111vw
    }
}

@media screen and (max-width: 820px) {
    .event_list li .mask {
        display:none
    }
}

.event_list li .title {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    overflow: hidden;
    color: #fff;
    font-weight: 700;
    font-size: 20px;
    font-family: "Roboto",sans-serif
}

@media screen and (max-width: 1280px) {
    .event_list li .title {
        font-size:1.25vw
    }
}

@media screen and (max-width: 820px) {
    .event_list li .title {
        display:none
    }
}

.event_list li .exc {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    margin-top: 10px;
    overflow: hidden;
    color: #fff;
    font-weight: 400;
    font-size: 14px;
    font-family: "Roboto",sans-serif
}

@media screen and (max-width: 1280px) {
    .event_list li .exc {
        -webkit-line-clamp:2;
        font-size: .8333333333vw
    }
}

@media screen and (max-width: 820px) {
    .event_list li .exc {
        display:none
    }
}

.event_list li a:hover .mask {
    bottom: -50%
}

@media screen and (max-width: 820px) {
    .event_list li a:hover .mask {
        bottom:auto
    }
}

.page-event>.inner {
    padding-bottom: 95px
}

@media screen and (max-width: 1280px) {
    .page-event>.inner {
        max-width:90%
    }
}

@media screen and (max-width: 820px) {
    .page-event>.inner {
        max-width:100%;
        padding-bottom: 10.4166666667vw
    }
}

.columns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 55px
}

@media screen and (max-width: 1024px) {
    .columns {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-top: 7.8125vw
    }
}

.columns .contents {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    max-width: 894px
}

@media screen and (max-width: 1024px) {
    .columns .contents {
        max-width:100%
    }
}

.columns .post_content {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    max-width: 963px
}

@media screen and (max-width: 1024px) {
    .columns .post_content {
        max-width:100%
    }
}

.columns .side {
    width: 320px;
    margin-left: 90px
}

@media screen and (max-width: 1280px) {
    .columns .side {
        width:280px;
        margin-left: 70px
    }
}

@media screen and (max-width: 1024px) {
    .columns .side {
        width:100%;
        margin-left: 0
    }
}

.columns .side_section {
    padding: 35px 0
}

.columns .side_section .list li {
    display: inline-block;
    margin-top: 16px;
    margin-right: 16px;
    font-size: 16px
}

.columns .side_section .list li a {
    display: block;
    padding: 0 25px;
    border: 1px solid #003591;
    border-radius: 38px;
    color: #003591;
    line-height: 36px
}

.columns .side_section .list li a:hover {
    background-color: #003591;
    color: #fff
}

@media screen and (max-width: 820px) {
    .columns .side_section .list li {
        font-size:3.6458333333vw
    }

    .columns .side_section .list li a {
        padding: 0 3.90625vw;
        line-height: 7.8125vw
    }
}

.columns .side_section .select {
    width: 82%;
    height: 38px;
    margin: 16px auto;
    padding: 0 10px;
    border: 1px solid #003591;
    border-radius: 4px;
    background-color: #fff;
    font-size: 16px;
    cursor: pointer
}

@media screen and (max-width: 820px) {
    .columns .side_section .select {
        height:8.8541666667vw;
        font-size: 3.6458333333vw
    }
}

.columns .side_heading {
    margin: 0;
    padding-bottom: 5px;
    border-bottom: 2px solid #003591;
    font-weight: bold;
    font-size: 20px
}

@media screen and (max-width: 820px) {
    .columns .side_heading {
        font-size:4.6875vw
    }
}

.search_area {
    margin-top: 20px
}

.search_text {
    width: 82%;
    padding: .5em;
    background-color: #f0f5f5;
    font-size: 16px
}

@media screen and (max-width: 820px) {
    .search_text {
        font-size:4.1666666667vw
    }
}

.search_submit {
    width: 45px;
    height: 34px;
    background-color: #003591;
    color: #fff;
    font-weight: bold;
    cursor: pointer
}

@media screen and (max-width: 820px) {
    .search_submit {
        width:11.71875vw;
        height: 8.8541666667vw;
        font-size: 4.1666666667vw
    }
}

.post_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding: 35px 0;
    border-bottom: 1px dashed #003591
}

@media screen and (max-width: 820px) {
    .post_item {
        padding:5.2083333333vw 0
    }
}

.post_item_left {
    width: 250px;
    margin-right: 20px
}

@media screen and (max-width: 820px) {
    .post_item_left {
        width:31.25vw;
        margin-right: 3.90625vw
    }
}

.post_item_right {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1
}

.post_item .thumb {
    position: relative;
    width: 100%;
    height: auto;
    padding-top: 248px;
    overflow: hidden;
    border: 1px solid #d9d9d9;
    border-radius: 10px
}

@media screen and (max-width: 820px) {
    .post_item .thumb {
        padding-top:30.7291666667vw
    }
}

.post_item .title {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    margin-top: 0;
    margin-bottom: 20px;
    overflow: hidden;
    color: #003591;
    font-weight: bold;
    font-size: 28px;
    line-height: 1.5
}

.post_item .title a {
    color: #003591
}

@media screen and (max-width: 820px) {
    .post_item .title {
        -webkit-line-clamp:3;
        margin-bottom: 2.6041666667vw;
        font-size: 4.1666666667vw
    }
}

.post_item .date {
    display: inline-block;
    margin-right: 15px;
    font-weight: bold;
    font-size: 16px
}

@media screen and (max-width: 820px) {
    .post_item .date {
        font-size:3.6458333333vw
    }
}

.post_item .cats {
    display: inline-block
}

.post_item .cats li {
    display: inline-block;
    margin-right: 15px;
    font-weight: normal;
    font-size: 16px
}

@media screen and (max-width: 820px) {
    .post_item .cats {
        display:block
    }

    .post_item .cats li {
        font-size: 3.125vw
    }
}

.post_item .exc {
    -webkit-box-orient: vertical;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    margin-top: 30px;
    overflow: hidden;
    font-weight: normal;
    font-size: 14px;
    line-height: 2.1
}

.post_item .exc a {
    color: #606470
}

@media screen and (max-width: 820px) {
    .post_item .exc {
        -webkit-line-clamp:2;
        margin-top: 2.6041666667vw;
        font-size: 3.125vw
    }
}

.post_item.columns_header {
    padding-top: 20px;
    padding-bottom: 0;
    border-bottom-width: 0
}

@media screen and (max-width: 820px) {
    .post_item.columns_header {
        -webkit-box-orient:vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse
    }
}

.post_item.columns_header .post_item_left {
    width: min(35.4166666667vw,510px);
    margin-right: 50px
}

.post_item.columns_header .post_item_left .thumb {
    padding-top: min(35.4166666667vw,510px)
}

.post_item.columns_header .post_item_left .thumb img {
    width: auto
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .post_item_left {
        display:none
    }
}

.post_item.columns_header .post_item_right {
    padding-left: 0
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .post_item_right {
        width:100%
    }

    .post_item.columns_header .post_item_right .thumb {
        width: 89.84375vw;
        margin: 5.2083333333vw auto;
        padding-top: 89.3229166667vw
    }

    .post_item.columns_header .post_item_right .thumb img {
        width: 100%
    }
}

.post_item.columns_header .post_item_right.nopadding {
    padding-left: 0
}

.post_item.columns_header .title {
    display: block;
    -webkit-line-clamp: unset;
    overflow: auto
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .title {
        font-size:4.6875vw
    }
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .date {
        font-size:3.6458333333vw
    }
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .cats {
        display:inline-block
    }

    .post_item.columns_header .cats li {
        font-size: 3.6458333333vw
    }

    .post_item.columns_header .cats li a {
        color: #606470
    }
}

.post_item.columns_header .exc {
    display: block;
    -webkit-line-clamp: unset;
    overflow: auto;
    line-height: 2
}

@media screen and (max-width: 820px) {
    .post_item.columns_header .exc {
        font-size:3.6458333333vw
    }
}

.post_pager {
    color: #003591;
    font-weight: 700;
    font-size: 16px;
    font-family: "Roboto",sans-serif;
    text-align: right
}

.post_pager a {
    display: inline-block;
    width: 57px;
    border-radius: 18px;
    background-color: #003591;
    color: #fff;
    font-weight: 700;
    font-size: 24px;
    line-height: 36px;
    font-family: "Roboto",sans-serif;
    text-align: center
}

.post_pager a.prev {
    margin-right: 20px
}

.post_pager a.next {
    margin-left: 20px
}

@media screen and (max-width: 820px) {
    .post_pager {
        font-size:4.1666666667vw
    }

    .post_pager a {
        width: 11.71875vw;
        border-radius: 7.5520833333vw;
        font-size: 4.9479166667vw;
        line-height: 7.5520833333vw
    }

    .post_pager a.prev {
        margin-right: 3.90625vw
    }

    .post_pager a.next {
        margin-left: 3.90625vw
    }
}

.post_content {
    padding: 20px 50px;
    background-color: #fff
}

@media screen and (max-width: 1280px) {
    .post_content {
        padding:0 0 50px
    }
}

@media screen and (max-width: 820px) {
    .post_content {
        padding:0 0 6.5104166667vw
    }
}

.post_content h2,.post_content h3,.post_content h4 {
    font-weight: bold;
    font-size: 20px
}

@media screen and (max-width: 820px) {
    .post_content h2,.post_content h3,.post_content h4 {
        font-size:4.6875vw
    }
}

.post_content p {
    font-weight: normal;
    font-size: 15px;
    line-height: 2
}

.post_content p a {
    color: #003591;
    font-weight: bold
}

@media screen and (max-width: 820px) {
    .post_content p {
        font-size:3.6458333333vw;
        line-height: 2
    }
}

.post_content ul,.post_content ol {
    margin-top: 10px;
    margin-bottom: 20px
}

.post_content ul li,.post_content ol li {
    font-size: 15px;
    line-height: 2
}

@media screen and (max-width: 820px) {
    .post_content ul li,.post_content ol li {
        font-size:3.6458333333vw
    }
}

.post_content img {
    max-width: 100%;
    height: auto;
    margin: 30px auto
}

.post_content hr {
    margin: 40px 0;
    border-color: #789
}

@media screen and (max-width: 820px) {
    .post_content hr {
        margin:6.5104166667vw 0
    }
}

.post_content .box {
    margin: 30px 0;
    padding: 20px 30px;
    border: 1px solid #003591;
    background-color: #fff;
    color: #003591
}

.post_content .box h2,.post_content .box h3,.post_content .box h4 {
    margin: 0;
    padding-bottom: 10px
}

.post_content .box p {
    margin: 0
}

@media screen and (max-width: 820px) {
    .post_content .box {
        padding:5.2083333333vw
    }
}

.contact_oem_boxes {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 1310px;
    margin: 85px auto 0
}

@media screen and (max-width: 820px) {
    .contact_oem_boxes {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        margin: 11.71875vw auto 0
    }
}

.contact_oem_box {
    width: 30%;
    text-align: center
}

@media screen and (max-width: 820px) {
    .contact_oem_box {
        width:100%;
        margin: 7.8125vw auto
    }
}

.contact_oem_box .title {
    position: relative;
    color: #003591;
    font-weight: bold;
    font-size: 20px
}

.contact_oem_box .title span {
    display: block;
    position: relative
}

.contact_oem_box .title span::before,.contact_oem_box .title span::after {
    width: 2px;
    height: 30px;
    background-color: #003591;
    content: ""
}

.contact_oem_box .title span::before {
    left: 0;
    -webkit-transform: translateY(-50%) rotate(-17deg);
    -ms-transform: translateY(-50%) rotate(-17deg);
    transform: translateY(-50%) rotate(-17deg)
}

.contact_oem_box .title span::after {
    right: 0;
    -webkit-transform: translateY(-50%) rotate(17deg);
    -ms-transform: translateY(-50%) rotate(17deg);
    transform: translateY(-50%) rotate(17deg)
}

@media screen and (max-width: 820px) {
    .contact_oem_box .title {
        font-size:4.6875vw
    }
}

.contact_oem_box .logo {
    margin: 24px 0 20px;
    color: #242424;
    font-weight: 900;
    font-size: 40px;
    line-height: 1;
    font-family: "Montserrat",sans-serif;
    text-align: center
}

@media screen and (max-width: 820px) {
    .contact_oem_box .logo {
        font-size:9.1145833333vw
    }
}

.contact_oem_box .text {
    color: #000;
    font-weight: bold;
    font-size: 18px
}

@media screen and (max-width: 820px) {
    .contact_oem_box .text {
        font-size:4.1666666667vw
    }
}

@media screen and (max-width: 820px) {
    .contact_oem_box .btn {
        margin-top:6.5104166667vw !important
    }
}

.contact_oem_btns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 1310px;
    margin: 0 auto
}

@media screen and (max-width: 820px) {
    .contact_oem_btns {
        display:none
    }
}

.contact_oem_btn {
    width: 30%;
    margin-top: 20px
}

.contact_oem_btn.large {
    width: 66%
}

.contact_oem_btn.large .btn {
    width: 100%
}

@-webkit-keyframes tab_fade {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes tab_fade {
    from {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

.inc_parts {
    margin-top: 60px;
    padding-top: 55px;
    background-color: #fff
}

.inc_parts_news {
    width: 100%;
    height: 751px
}

@media screen and (max-width: 820px) {
    .inc_parts_news {
        height:173.5677083333vw
    }
}

.inc_parts .heading {
    text-align: center
}

.inc_parts .heading span {
    display: inline-block;
    position: relative;
    color: #003591;
    font-weight: 700;
    font-size: 24px;
    line-height: 1;
    font-family: "Roboto",sans-serif
}

.inc_parts .heading span::after {
    display: inline-block;
    top: auto;
    bottom: -16px;
    width: 60px;
    height: 2px;
    background-color: #003591;
    content: ""
}

@media screen and (max-width: 820px) {
    .inc_parts .heading span {
        font-size:4.1666666667vw
    }

    .inc_parts .heading span::after {
        bottom: -4.1666666667vw;
        width: 10.4166666667vw
    }
}

.inc_parts .heading h1 {
    margin-top: 30px;
    margin-bottom: 0;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .inc_parts .heading h1 {
        margin-top:7.8125vw;
        font-size: 5.46875vw
    }
}

.inc_parts .heading h2 {
    margin-top: 30px;
    margin-bottom: 0;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .inc_parts .heading h2 {
        margin-top:7.8125vw;
        font-size: 5.46875vw
    }
}

.inc_parts .heading.left {
    text-align: left
}

.inc_parts .heading.noborder h2 {
    margin-top: 0
}

.inc_parts .heading.noborder span::after {
    content: none
}

.inc_parts .heading.nospan h1 span {
    margin-top: 30px;
    margin-bottom: 0;
    color: #606470;
    font-size: 32px
}

@media screen and (max-width: 820px) {
    .inc_parts .heading.nospan h1 span {
        margin-top:7.8125vw;
        font-size: 5.46875vw
    }
}

.inc_parts .heading.nospan span::after {
    content: none
}

.inc_parts .btn {
    display: block;
    margin: 0 auto;
    background-color: #003591;
    color: #fff;
    text-align: center
}

.inc_parts .btn.radius {
    z-index: 1;
    position: relative;
    width: min(29.8611111111vw,430px);
    overflow: hidden;
    border: 2px solid #003591;
    border-radius: 70px;
    font-weight: bold;
    font-size: 20px;
    line-height: 66px
}

.inc_parts .btn.radius::after {
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    -webkit-transform: scale(0, 1);
    -ms-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: left top;
    -ms-transform-origin: left top;
    transform-origin: left top;
    background-color: #fff;
    content: "";
    -webkit-transition: .3s ease;
    -o-transition: .3s ease;
    transition: .3s ease
}

.inc_parts .btn.radius:hover {
    color: #003591
}

.inc_parts .btn.radius:hover::after {
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    transform: scale(1, 1)
}

@media screen and (max-width: 820px) {
    .inc_parts .btn.radius {
        width:85%;
        border-radius: 13.0208333333vw;
        font-size: 4.1666666667vw;
        line-height: 9.8958333333vw
    }
}

.inc_parts .btn.radius.white {
    background-color: #fff;
    color: #003591
}

.inc_parts .btn.radius.white::after {
    display: none
}

.inc_parts .btn.square {
    width: 380px;
    border-radius: 6px;
    font-weight: bold;
    font-size: 20px;
    line-height: 80px
}

.inc_parts .btn.square.white {
    position: relative;
    width: min(26.3888888889vw,380px);
    border: 1px solid #003591;
    background-color: #fff;
    color: #003591;
    line-height: 78px
}

.inc_parts .btn.square.white .icon_arrow {
    display: inline-block;
    right: 24px;
    width: 10px;
    height: 21px;
    line-height: 0
}

@media screen and (max-width: 820px) {
    .inc_parts .btn.square {
        width:90%;
        margin-top: 5.2083333333vw;
        border-radius: 1.5625vw;
        font-size: 4.1666666667vw;
        line-height: 16.6666666667vw
    }

    .inc_parts .btn.square.white {
        width: 90%;
        margin-top: 0;
        line-height: 16.6666666667vw
    }
}

.inc_parts .section.parts {
    padding-top: 55px;
    padding-bottom: 120px;
    background-color: #f0f5f5
}

@media screen and (max-width: 820px) {
    .inc_parts .section.parts {
        padding-bottom:15.625vw
    }
}

.inc_parts .section.parts .inner.row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 1350px
}

@media screen and (max-width: 820px) {
    .inc_parts .section.parts .inner.row {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

.inc_parts .section.parts .row_left {
    width: 380px;
    margin-right: 5%
}

@media screen and (max-width: 820px) {
    .inc_parts .section.parts .row_left {
        width:100%;
        margin-right: 0
    }
}

.inc_parts .section.parts .row_right {
    width: 780px
}

@media screen and (max-width: 820px) {
    .inc_parts .section.parts .row_right {
        width:100%;
        margin-top: 10.4166666667vw
    }
}

.inc_parts .section.parts .heading {
    padding-bottom: 40px
}

@media screen and (max-width: 820px) {
    .inc_parts .section.parts .heading {
        padding-bottom:6.5104166667vw
    }
}

.inc_parts .section.parts .product .btn_wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 20px
}

.inc_parts .section.parts .company .btn_wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 20px
}

.page-notfound {
    min-height: 60vh
}

.heading_notfound {
    font-weight: bold;
    font-size: 40px;
    text-align: center
}

@media screen and (max-width: 820px) {
    .heading_notfound {
        font-size:7.8125vw
    }
}

.text_notfound {
    margin: 60px auto;
    font-weight: bold;
    font-size: 16px;
    text-align: center
}

.text_notfound a {
    color: #003591
}

.btn.square.white.btn_contact {
    margin: 50px auto 0;
}
