@charset "utf-8";

/* ==================================================
contents
================================================== */

/* セクションタイトル */
.sec_ttl {
    display: block;
    margin-bottom: 30px;
    text-align: center;
    font-feature-settings: "palt";
    font-size: 200%;
    position: relative;
}
.sec_ttl::before {
    display: block;
    content: '';
    width: 100%;
    height: 1px;
    background-size: 6px 1px;
    background-image: linear-gradient(to right, #648b61 3px, transparent 3px);
    background-repeat: repeat-x;
    background-position: left bottom;
    position: absolute;
    top: 62%;
    left: 0;
    transform: translateY(-62%);
    z-index: -1;
}
.sec_ttl .ttl {
    display: inline-block;
    padding: 0 12px;
    background-color: #ffffff;
    color: inherit;
}

/* メインビジュアル
================================================== */
.sec_mainvisual {
    min-height: 513px;
    padding: 150px 0 50px;
    overflow: hidden;
    position: relative;
    z-index: 2;    
}
.sec_mainvisual::before {
    display: block;
    content: "";
    position: absolute;
    inset: 0;
    height: 513px;
    z-index: -1;
    color: inherit;
    background-color: transparent;
    background-image: url(/shared/templates/miyagi_oem_top/images/main_slide_pc_img.jpg);
    background-repeat: repeat-x;
    background-position: center center;
    animation: slide 40s linear infinite;
    transform: translateZ(0);
    will-change: background-position;
}
.effcts_off .sec_mainvisual::before {
    animation-play-state: paused;
}
@keyframes slide {
	from { background-position: 0 0; }
	to { background-position: -1920px 0; }
}

/* キャッチコピー */
.sec_mainvisual .visual_cnt {
    display: inline-block;
    min-width: 925px;
    position: absolute;
    top: 34%;
    left: 50%;
    transform: translateX(-50%);
}
.sec_mainvisual .visual_ttl {
    display: block;
    padding: 1em 1em 1.5em 1em;
    background-color: rgb(49, 101, 45, 0.89);
    color: #ffffff;
    font-weight: 600;
    position: relative;
}
.sec_mainvisual .visual_ttl::before,
.sec_mainvisual .visual_ttl::after {
    display: block;
    content: "";
    position: absolute;
}
.sec_mainvisual .visual_ttl::before {
    width: 52px;
    height: 59px;
    background-image: url(/shared/templates/miyagi_oem_top/images/main_decoration_bottom.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    left: -12px;
    bottom: -26px;
}
.sec_mainvisual .visual_ttl::after {
    width: 113px;
    height: 86px;
    background-image: url(/shared/templates/miyagi_oem_top/images/main_decoration_top.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    top: -18px;
    right: -5px;
}
.sec_mainvisual .visual_ttl span {
    display: block;
    text-align: center;
    line-height: 1.4;
}
.sec_mainvisual .visual_ttl .main_ttl {
    font-size: 133.5%;
}
.sec_mainvisual .visual_ttl .sub_ttl {
    font-size: 106.7%;
}
.sec_mainvisual .visual_ttl .pc_show {
    display: inline;
}
.sec_mainvisual .visual_ttl .sp_show {
    display: none;
}

/* 探すボタン */
.sec_mainvisual .btn_list {
    display: none;
}

/* アニメーション制御ボタン */
.sec_mainvisual .animation_stop {
    position: absolute;
    right: 34px;
    bottom: 20px;
    display: inline-block;
}
.no_javascript .sec_mainvisual .animation_stop {
    display: none;
}
.no_javascript .sec_mainvisual::before,
.no_javascript .sec_mainvisual::after {
	animation: none;
}

.sec_mainvisual .animation_stop a {
	position: relative;
    z-index: 1;
	display: inline-block;
	text-decoration: none;
    line-height: 1.2;
	padding: 5px 15px 4px 30px;
	min-width: 117px;
    min-height: 37px;
	text-align: left;
    border: 1px solid #000000;
    background-color: #000000;
    color: #ffffff !important;
    font-size: 112%;
    border-radius: 30px;
}
.sec_mainvisual .animation_stop a:before,
.sec_mainvisual .animation_stop a:after {
	content: '';
	width: 3px;
	height: 15px;
	position: absolute;
	top: 11px;
	left: 14px;
	background-color: #ffffff;
}
.sec_mainvisual .animation_stop a:after {
	left: 19px;
}
.effcts_off .sec_mainvisual .animation_stop a:after {
	content: none;
}
.effcts_off .sec_mainvisual .animation_stop a:before {
	top: 10px;
	border-style: solid;
	border-width: 7px 0 7px 8px;
	border-color: transparent transparent transparent #ffffff;
	background-color: transparent;
}
.sec_mainvisual .animation_stop a:hover {
    background-color: #000000;
    color: #ffffff !important;
}


/* 理想のOEMパートナーを見つけよう
================================================== */
.sec_partner {
    padding: 86px 0 95px;
}

.sec_partner .sec_ttl .decoration_text {
    display: inline-block;
    color: #ec6d65;
    font-size: 117.5%;
    position: relative;
}
.sec_partner .sec_ttl .decoration_text::after {
    display: block;
    content: "";
    width: 36px;
    height: 35px;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_sec_partner_ttl.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    position: absolute;
    right: -18px;
    bottom: -2px;
}

/* アイテム */
.sec_partner .partner_list {
    display: flex;
    justify-content: center;
}
.sec_partner .partner_item {
    flex: 1;
    max-width: 270px;
    padding: 0 11px 8px 11px;
    text-decoration: none;
    position: relative;
}
.sec_partner .partner_item:first-child {
    padding-bottom: 0;
}
.sec_partner .partner_item:not(:last-child)::after {
    display: block;
    content: "";
    width: 4px;
    height: 70px;
    background-color: #dfebe0;
    color: inherit;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
}
.sec_partner .partner_item:last-child {
    border-right: none;
}

/* アイコン */
.sec_partner .partner_item .partner_icon {
    display: block;
    width: 105px;
    height: 58px;
    text-align: center;
    margin: 0 auto;
}
.sec_partner .partner_item .partner_icon img {
    max-width: 100%;
    width: auto;
    height: 100%;
    object-fit: contain;
    opacity: 1;
    transition: opacity 0.3s ease;
}
.sec_partner .partner_item:not(div):hover .partner_icon img,
.sec_partner .partner_item:not(div):focus .partner_icon img {
    opacity: 0.7;
}

/* タイトル */
.sec_partner .partner_item .partner_ttl {
    display: block;
    text-align: center;
    color: #282828;
    font-weight: 500;
    font-size: 110%;
    position: relative;
}
.sec_partner .partner_item .partner_ttl .pc_show {
    display: inline-block;
}
.sec_partner .partner_item .partner_ttl .sp_show {
    display: none;
}
.sec_partner .partner_item .partner_ttl:not(.gsearch_ttl) {
    padding-bottom: 18px;
}
.sec_partner .partner_item .partner_ttl:not(.gsearch_ttl)::after {
    display: block;
    content: "";
    width: 9px;
    height: 6px;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_arrow_down_bl.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    color: inherit;
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
}
.sec_partner .partner_item:not(div):hover .partner_ttl,
.sec_partner .partner_item:not(div):focus .partner_ttl {
    text-decoration: underline;
}

/* 検索窓 */
.sec_partner .partner_item .gsearch_ttl {
    margin-bottom: 11px;
    font-feature-settings: "palt";
}
#tmp_gsearch {
    position: relative;
}
/* 入力フィールド */
#tmp_gsearch #tmp_query {
    min-height: 42px;
    width: 100%;
    padding: 0 0 2px 6px;
    border: 2px solid #a6a6a6;
}
#tmp_gsearch #tmp_query::placeholder {
    color: #282828;
    font-size: 90%;
}
#tmp_gsearch #tmp_query:focus-visible {
    outline-color: #31652d;
}

/* 検索ボタン */
#tmp_gsearch #tmp_func_sch_btn {
    position: absolute;
    top: 0;
    right: 0;
    padding: 2px 5px;
    width: 42px;
    min-height: 41px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    cursor: pointer;
    letter-spacing: 1px;
    border: 1px solid #a6a6a6;
    color: #FFFFFF;
    font-size: 0;
    background-color: #000000;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_search_func.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 22px;
}


/* 生産者と理想のOEM先を結ぶためのマッチングサイトです
================================================== */
.sec_intro {
    padding: 57px 0 34px;
    background-image: url(/shared/templates/miyagi_oem_top/images/intro_area_pc_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    position: relative;
}
.sec_intro::before {
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    background-color: #dfebe0;
    opacity: 0.8;
    position: absolute;
    top: 0;
    left: 0;
}
.sec_intro .container {
    position: relative;
    z-index: 2;
}
.sec_intro .intro_wrap {
    display: flex;
    gap: 0 43px;
}
.sec_intro .intro_map {
    max-width: 267px;
    padding-top: 25px;
    flex: 1;
}
.sec_intro .intro_map img {
    max-width: 100%;
    height: auto;
}
.sec_intro .intro_cnt {
    max-width: 790px;
    flex: 2;
}
.sec_intro .intro_ttl {
    margin-bottom: 18px;
    text-align: center;
    line-height: 1.3;
    font-feature-settings: "palt";
    font-size: 130%;
    font-weight: 600;
}
.sec_intro .intro_text {
    font-feature-settings: "palt";
}
.sec_intro .intro_illust {
    text-align: center;
}
.sec_intro .intro_illust img {
    max-width: 100%;
    height: auto;
}


/* 本サイトでできること
================================================== */
.sec_service {
    padding: 110px 0 165px;
}
.sec_service .sec_ttl {
    margin-bottom: 76px;
}

.sec_service .service_link_list {
    display: none;
}

.sec_service .service_wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0 48px;
}

.sec_service .service_genre_cnt .genre_main {
    margin-bottom: 55px;
}
.sec_service .service_entrusted_cnt .entrusted_main {
    margin-bottom: 28px;
}
.sec_service .service_genre_cnt .genre_img,
.sec_service .service_entrusted_cnt .entrusted_img {
    margin-bottom: 55px;
    line-height: 1;
}
.sec_service .service_genre_cnt .genre_img img,
.sec_service .service_entrusted_cnt .entrusted_img img {
    max-width: 100%;
    height: auto;
}
.sec_service .service_genre_cnt .step_list,
.sec_service .service_entrusted_cnt .step_list {
    counter-reset: listnum;
    list-style: none;
}
.sec_service .service_entrusted_cnt .step_list {
    max-width: 442px;
    margin: 0 auto;
}
.sec_service .service_genre_cnt .step_list li,
.sec_service .service_entrusted_cnt .step_list li {
    margin-bottom: 41px;
    padding-left: 42px;
    font-feature-settings: "palt";
    position: relative;
}
.sec_service .service_entrusted_cnt .step_list li {
    margin-bottom: 13px;
}
.sec_service .service_genre_cnt .step_list .sp_show,
.sec_service .service_entrusted_cnt .step_list .sp_show {
    display: none;
}
.sec_service .service_genre_cnt .step_list li:last-child,
.sec_service .service_entrusted_cnt .step_list li:last-child {
    margin-bottom: 0;
}
.sec_service .service_genre_cnt .step_list li::before,
.sec_service .service_entrusted_cnt .step_list li::before {
    display: inline-block;
    width: 34px;
    height: 33px;
    padding-top: 6px;
    text-align: center;
    border-radius: 50%;
	counter-increment: listnum;
	content: counter(listnum);
    line-height: 1;
    font-weight: 600;
    position: absolute;
    top: 0;
    left: 0;
}
.sec_service .service_genre_cnt .step_list li::before {
    background-color: #dfebe0;
    color: #31652d;
}
.sec_service .service_entrusted_cnt .step_list li::before {
    background-color: #e7dccd;
    color: #9d7719;
}

.sec_service .service_entrusted_cnt .flow_list {
    list-style: none;
}
.sec_service .service_entrusted_cnt .flow_list li {
    margin-bottom: 52px;
    padding: 8px;
    background-color: #faf8f5;
    color: #000000;
    text-align: center;
    font-size: 110%;
    font-weight: 500;
    position: relative;
}
.sec_service .service_entrusted_cnt .flow_list li:not(:last-child):after {
    display: inline-block;
    content: "";
    width: 9px;
    height: 6px;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_arrow_down_bl.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 9px;
    position: absolute;
    left: 50%;
    bottom: -30px;
    transform: translateX(-50%);
}
.sec_service .service_entrusted_cnt .flow_list li:last-child {
    margin-bottom: 0;
}

.sec_service .genre_cnt:not(:last-child) {
    margin-bottom: 59px;
}
.sec_service .entrusted_cnt:not(:last-child) {
    margin-bottom: 83px;
}

.sec_service .genre_cnt .genre_ttl,
.sec_service .entrusted_cnt .entrusted_ttl {
    margin-bottom: 30px;
    padding: 10px;
    text-align: center;
    font-feature-settings: "palt";
    font-size: 130%;
}
.sec_service .genre_cnt .genre_ttl {
    background-color: #dfebe0;
    color: #31652d;
}
.sec_service .entrusted_cnt .entrusted_ttl {
    background-color: #e7dccd;
    color: #9d7719;
}
.sec_service .entrusted_cnt .entrusted_ttl.flow_ttl {
    margin-bottom: 42px;
}
.sec_service .genre_cnt p,
.sec_service .entrusted_cnt p {
    font-feature-settings: "palt";
}
.sec_service .btn_default {
    margin-top: 30px;
    text-align: center;
}
.sec_service .btn_default a {
    display: inline-block;
    max-width: 100%;
    min-width: 237px;
    padding: 6px 45px 10px 20px;
    border-radius: 11px;
    border: 2px solid #ffffff;
    background-color: #31652d;
    box-shadow: 5px 7px 15px -1px #b8b8b8;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_arrow_next_wh.png);
    background-repeat: no-repeat;
    background-size: auto 9px;
    background-position: center right 30px;
    text-decoration: none;
    color: #ffffff;
}
.sec_service .btn_default a:hover,
.sec_service .btn_default a:focus {
    text-decoration: underline;
}

.sec_service .genre_cnt.area_cnt {
    margin-bottom: 37px;
}
.sec_service .area_cnt .btn_default {
    margin-top: 10px;
}
.sec_service .business_cnt .btn_default {
    margin-top: 18px;
}


/* コラム
================================================== */
.sec_column {
    padding: 92px 0 83px;
    background-color: #31652d;
    color: inherit;
}
.sec_column .column_title {
    display: block;
    margin-bottom: 47px;
    text-align: center;
    background-color: transparent;
    color: #ffffff;
    font-feature-settings: "palt";
    font-size: 200%;
}
.sec_column .column_title span {
    display: inline-block;
    margin-left: -32px;
    padding-left: 33px;
    position: relative;
}
.sec_column .column_title span::before {
    display: inline-block;
    content: "";
    width: 23px;
    height: 22px;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_column.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 23px;
    position: absolute;
    top: 56%;
    left: 0;
    transform: translateY(-56%);
}
.sec_column .column_list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 30px 70px;
    list-style: none;
}
/* サムネイル */
.sec_column .column_item .column_img {
    margin-bottom: 12px;
    line-height: 0;
    opacity: 1;
    transition: opacity 0.3s ease;
}
.sec_column .column_item.active .column_img {
    opacity: 0.7;
}
.sec_column .column_item .column_img img {
    max-width: 100%;
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 16 / 10;
}
/* テキスト */
.sec_column .column_item a {
    background-color: transparent;
    color: #ffffff;
    line-height: 1.7;
    text-decoration: none;
    font-feature-settings: "palt";
    font-weight: 600;
}
.sec_column .column_item.active a {
    text-decoration: underline;
    text-underline-offset: 7px;
}

.sec_column .btn_default {
    margin-top: 68px;
    text-align: center;
}
.sec_column .btn_default a {
    display: inline-block;
    max-width: 100%;
    min-width: 230px;
    padding: 6px 45px 10px 20px;
    border-radius: 11px;
    border: 2px solid #31652d;
    background-color: #ffffff;
    box-shadow: 5px 7px 15px -1px #153313;
    background-image: url(/shared/templates/miyagi_oem_top/images/icon_arrow_next_gr.png);
    background-repeat: no-repeat;
    background-size: auto 9px;
    background-position: center right 30px;
    text-decoration: none;
    color: #31652d;
    font-weight: 600;
}
.sec_column .btn_default a:hover,
.sec_column .btn_default a:focus {
    text-decoration: underline;
}


@media screen and (max-width : 1280px) {
    /* メインビジュアル
    ================================================== */
    /* キャッチコピー */
    .sec_mainvisual .visual_ttl .main_ttl {
        font-size: 120%;
    }
    .sec_mainvisual .visual_ttl .sub_ttl {
        font-size: 100%;
    }

    /* 本サイトでできること
    ================================================== */
    .sec_service .service_wrap {
        gap: 0 30px;
    }

    /* コラム
    ================================================== */
    .sec_column .column_list {
        gap: 0 50px;
    }
}
@media screen and (max-width : 1020px) {
    /* メインビジュアル
    ================================================== */
    /* キャッチコピー */
    .sec_mainvisual .visual_cnt {
        display: inline-block;
        max-width: 85%;
        min-width: auto;
        width: 100%;
        position: absolute;
        top: 34%;
        left: 50%;
        transform: translateX(-50%);
    }
    .sec_mainvisual .visual_ttl::before {
        top: -26px;
        left: -12px;
        bottom: auto;
    }
    .sec_mainvisual .visual_ttl::after {
        top: auto;
        right: -62px;
        bottom: -12px;
    }

    /* 本サイトでできること
    ================================================== */
    .sec_service .service_wrap {
        gap: 30px 20px;
    }

    /* コラム
    ================================================== */
    .sec_column .column_list {
        gap: 30px 30px;
    }
}

/* ==================================================
print
================================================== */
@media print {
}