/*
Theme Name: Lightning Child
Theme URI: 
Template: lightning
Description: 
Author: 
Tags: 
Version: 0.6.0
*/
/*——————————
/* フォントサイズ　中国語
/*—————————-*/
/*
body {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’, '微软雅黑'  ;
}

h1 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’, '微软雅黑' ;
}
h2 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’,  '微软雅黑';
}
h3 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’;
}

h4 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’;
}

h5 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’;
}

h6 {
font-family: ‘Microsoft YaHei’,’Microsoft JhengHei UI’, ‘SimSun’, ‘SimHei’;
}
*/

@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Noto+Sans+JP:wght@100..900&display=swap');
body {
    font-family: "Noto Sans JP", sans-serif;
    overflow-x: hidden;
    }
.below-title {
    font-family: "Barlow", sans-serif;
    font-size: 1.1rem;
    letter-spacing: 3px;
}
.entry-title--post-type--page,h2:where(:not(.wp-block-post-title)) {
    padding: .5em 0;
}
.breadcrumb {border:none;}

/* ----------------------------------------
           製造工程
   ---------------------------------------- */
.video_wrapper{
max-width:1300px;
width:100%;
margin:0 auto;
}
@media screen and (min-width: 760px) {
.video_wrapper_one{
max-width:600px;
width:50%;
margin:0 auto;
}
}
@media screen and (max-width: 759px) {
.video_wrapper_one{
max-width:600px;
width:100%;
margin:0 auto;
}
}
.video_w{
	width: 100%;
	max-width:600px;
}

.video_w video{
	width: 100%;
}
/*問い合わせ*/
/* ----------------------------------------
           共通
   ---------------------------------------- */
.required{
        color:#E21E3A;
    }
    #contact{
    margin: 0 auto;
    }
    .contact_h2{
        border: none;
        margin-bottom:0px;
    }
    .contact-column .contact_h2{
        display:block;
    max-width: 1100px;
    margin:0 auto;
    padding:0;
    }
    .contact_tel{
        display:block;
    max-width: 1100px;
    margin:0 auto;
    }
    .contact_block_list.contact_tel{
    justify-content: flex-start;
    }
    
    .contact_block_list.contact_tel .item{
     padding:0;
     border-left:none !important;
    }
div.wpcf7 .wpcf7-spinner {
    display: block;
    margin:10px auto;
}
/* ----------------------------------------
           スマートフォン
   ---------------------------------------- */
@media screen and (max-width: 782px) {
    #contact,
    #wpcf7cpcnf {
        width:100%;
     margin:0 auto;
    }
    .contact_h2.contact_tel_h{
        text-align:center;
    }
    #contact  p{
     margin-bottom:2rem;
    }
    #contact th.th_span{
        display:block;
        width:100%;
        height:30px;
        margin: 0 1rem;
        text-align: left;
    }
    #contact p{
     margin-bottom:0;   
    }
    #contact th
    {
		padding:5px 0;
        border: 0 !important;
        display:block;
    }
    #contact table
    {
        border: 0 !important;
    }
    #contact td
    {
        display:block;
        border: 0 !important;
    }
    #wpcf7cpcnf td{
		padding: 15px;
		width: 100%;
	    display: block;
		vertical-align:middle;
        border: 0 !important;
    }
    #contact .wpcf7-form-control{
		color:#000;
		width:100%;
        border-color: #000;
        border-radius: 0;
    }
    #contact .wpcf7-textarea{
		height:auto;
        border-color: #000;
        border-radius: 0;
    }
    #contact .con_submit_btn{
        text-align:center;
    }
    #contact input,
    #contact select option
    {
		color:#000;
        border-color: #000;
        border-radius: 0;
    }
    #contact input{
        margin:0;
    }
    div.wpcf7cp-btns {
        text-align: center;
    }
     .mwform-radio-field input{
    -webkit-appearance:auto;
    }
    .wpcf7 form.sent .wpcf7-response-output{
    text-align: center;
    padding: 0.5em;
    margin-top:1em;
    }
    button.wpcf7cp-cfm-edit-btn {
    margin-right: 0px;
}
 .wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output{
    text-align: center;
    padding: 0.5em;
    margin-top:1em;
}   
    
    #contact input[type="submit"],
    #contact input[type="reset"]{
        background:#fff;
        border:2px solid #000;
        color:#000;
        width:270px;
        height:50px;
        text-align:center;
        line-height:20px;
        
    }
   }
/*----------------------------------------
            PC、タブレット
   ---------------------------------------- */
@media print,screen and (min-width: 783px) {
    #contact,
    #wpcf7cpcnf {
        width:100%;
     margin:0 auto;
    }
    #contact  p{
     margin-bottom:2rem;
     font-size:1rem !important;
    }
    #contact th.th_span
    {
        display:block;
        height:30px;
    }
    #contact th
    {
        height:30px;
     font-size:1.25rem !important;
     padding:0;
        border: 0 !important;
        height:30px;
        text-align:left;
    }
    #contact td{
		max-width: 900px; 
     padding:0 0 15px 0;
     font-size:1.25rem !important;
        border: 0 !important;
        width:80%;
    }
    #contact .wpcf7-form-control{
		width:100%;
        border-color: #000;
        border-radius: 0;
    }
    #contact .wpcf7-textarea{
		height:auto;
        border-color: #000;
        border-radius: 0;
    }
    #contact .con_submit_btn{
        text-align:center;
    }
    
    #contact input,
    #contact select option
    {
		color:#000;
        border-color: #000;
        border-radius: 0;
    }
    #contact  table{
        width: 100%;
		max-width: 1100px; 
		margin-bottom:15px;
		border:0 !important;
    }
    .wpcf7-form-control-wrap{
        width: 80%;
    }
    #contact input{
        margin:0;
    }
     #contact .form-text{
        width:430px;
        vertical-align: mithle;
    }
    div.wpcf7cp-btns {
        text-align: center;
    }
    .wpcf7 form.sent .wpcf7-response-output{
    text-align: center;
    padding: 0.5em;
    }
    .wpcf7cp-btns button{
        background:#fff;
        border:2px solid #000;
        color:#000;
        width:270px;
        height:50px;
        border-radius:40px;
        text-align:center;
        line-height:20px;
    }
 .wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output{
    text-align: center;
    padding: 0.5em;
}   
    
    #contact input[type="submit"],
    #contact input[type="reset"]{
        background:#fff;
        border:2px solid #000;
        color:#000;
        width:270px;
        height:50px;
        text-align:center;
        line-height:20px;
    }
}
/*--------------------------------------
        TOP
----------------------------------------*/

/*共通　外観*/
footer .site-footer-copyright p:nth-child(2) {
	display:none !important;
}
.site-footer {
	border-top: none;
}
.site-header-logo img{
	max-height: 30px;
}
.global-nav-list li img {
	min-width: 100px;
}
.site-body {
	padding: 0;
}
:where(.wp-block-columns) {
    margin-bottom: 0!important;
}
.main-section--margin-bottom--on {
    margin-bottom: 0;
}
@media (max-width: 991.98px) {
    .main-section {
        margin-bottom: 0;
    }
}

/*PC モバイル　オリジナルボタン*/
.menu_btn a{
	padding: 5px!important;
}

/* HOME */
.top_image_wraper{
   font-size:30px;
　position: relative;
}
.top_text{
     position: absolute!important;
    top: 30px;
    left: 60px;
    font-family: "Barlow", sans-serif;
    font-weight: 500;
}
/*上線*/
.is-style-vk-heading-plain::before{
    content: '';
    position: relative;
    display: block;
    width: 5rem;
    height: 1px;
    margin-bottom: 1.4rem;
    background-color:currentColor !important;
     /*Lightning見出しデザイン設定のCSS対策*/
    border: unset;
    top:unset;
    left:unset;
    bottom:unset;
    }    
/*中央寄せ*/
.is-style-vk-heading-plain::before{
    margin-left: auto;
    margin-right: auto;
}
.below-title{
    font-size:1.1rem;
    letter-spacing:3px;
    margin-top: 10px !important;
}
.is-style-vk-heading-plain {
    margin-bottom: 0 !important;
}

.btn_line .btn{
    border: solid 2px !important;
    width: 200px;
    font-size: 1.05em !important;
}
.btn-pd{
    padding-bottom: 40px!important;
}
.size-full{
    margin-bottom: 0;
}
.cover-pd-b{
    padding-bottom: 40px;
}
.flex-btn{
    gap: 10px;
    margin-bottom: 20px !important;
}
.services-item{
    margin-top: 70px !important;
}
.service-bg-image{
    background-image: url(./img/support_china.jpg);
    background-size:  cover;
    display: flex;
    flex-wrap: nowrap;
    flex-direction: column-reverse;
    background-position: 50% 50%;
}
.services_mg70{
    margin: 35px 0!important;
}
.services_block{
    margin-bottom: 50px;
}
.services_block, .support-block, .company_block{
    padding-top: 60px!important;
    
}

.contact_block_list{
    display: flex;
    align-items: center;
    justify-content: center;
}
.contact_block_list .item:first-child {   
    display: flex;
}
.contact_block_list .item:last-child {
    border-left: 1px solid #333333;
    padding-top: 10px;
    padding-bottom: 10px;
}
.contact_block_list .item {
    padding: 0 40px;
}
.contact_block_list .item .number {
    font-family: "Barlow", sans-serif;;
    font-size: 3.5rem;
    letter-spacing: .02em;
    font-weight: 400;
    color: #000;
    margin-bottom: 5px;
    line-height: .6;
}
.contact_block_list .item .number img {
    display: inline-block;
    margin-right: 12px;
    vertical-align: middle;
    max-width: 30px;
}
.contact_block_list .item .note {
    font-size: 1.1rem;
    margin-left: 5px;
}
.contact-column{
    background-color: #DBDBDB;
    padding: 70px 15px 50px;
    margin-left: calc(-50vw + 50%);
    margin-right: calc(-50vw + 50%);
}
.support-block{
    margin-top: 70px;
}
.support-block div .support_wrap{
    margin-top: 35px;
}
.contact_btn .btn_line .btn{
    width:250px!important;
}
.contact_block_list .item .tel-number{
    font-family: "Barlow", sans-serif;
    font-size: 3em;
    margin-bottom: -10px;
}
.contact_block_list .item .tel-img{
   width: 40px;
   margin-right: 10px;
   padding-top: 30px;
}
.btn-wrap .wp-container-core-group-is-layout-4.wp-container-core-group-is-layout-4{
    flex-wrap: wrap;
}
.opacity:hover img {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}
@media screen and (max-width: 430px){    
    .button-bg .btn{
        width: 6em!important;
    }
    .service-bg-image {
        min-height: 250px!important;
    }
    .servises-4btn{
        gap: 10px;
    }
    .servises-4btn > div{
        gap: 10px;
    }
    .services_mg70 {
        margin: 30px 0 65px !important;
    }
    }
@media screen and (max-width: 453px){
    .btn-first .btn{
        margin-bottom: 20px!important;
    }
    .servises-4btn figure img{
        width: 40vw!important;
    }
    .top_text {
        left: 20px!important;
        top: 20px!important;
    }

}
@media screen and (max-width: 782px){
    h2{
        font-size: 1.75em!important;
    }
    .top_text{
        left: 40px;
    }
    .services_block, .support-block, .company_block{
        min-height: 400px !important;
    }
    .support-block{
        padding-bottom: 70px;
        margin-top: 60px!important;
    }
    .contact_block_list{
        display: block;
        align-items: center;
        justify-content: center;
    }
    .service-bg-image{
        min-height: 330px;
    }
    .contact-column{
        padding: 60px 15px;
    }
    .contact_block_list .item:first-child{        
        justify-content: center;
    }
    .contact_block_list .item:last-child {
        border-left: none!important;
    }
    .contact_block_list .item .tel-number{
        font-size: 3em!important;
    }
    .contact_block_list .item {
        padding: 0 10px;
    } 
    .contact_block_list .item .tel-img{
        width: 35px;
        padding-top: 25px;
     }
    .flex-btn {
        margin-bottom: 18px !important;
    }
    .button-bg .btn{
        width: 8em;
    }
    .servises-4btn figure img{
        width: 150px!important;
    }
}
@media screen and (min-width: 767px) and (max-width: 782px){
.support_wrap{
    flex-direction: column!important;
    width: 500px!important;
}

}
@media screen and (min-width: 783px) and (max-width: 991px){
    .flex-btn{
        margin-bottom: 8px!important;
    }
}
@media screen and (max-width: 797px){
    .contact_block_list .item .tel-number{
        font-size: 3.2em;
    }
}
@media screen and (max-width: 991.98px){
    /*.flex-btn{
        margin-bottom: 8px !important;
    }*/
    .support-block{
        min-height: 550px!important;
    }
    /*モバイル用メニュー　オリジナルボタン*/
    .menu_btn a{
        width: 130px;
        border: none!important;
        text-align: center;
        color: #fff!important;
        font-size: 16px;
        font-weight: 500;
    }
    .mobile_btn_custom{
        display: inline-block;
        /*position: relative;*/
        padding: 8px 5px;
        /*color: #FFF;*/
        border-radius: 10rem;
        background: -webkit-gradient(45deg, #0712FF, #0788A8, #169D67, #BFE71F 80%);
        background: linear-gradient(45deg, #0712FF 10%, #0788A8, #169D67, #BFE71F 80%);
        margin-top: 15px;
        
    }
    }
@media print,screen and (max-width: 759px){
    .line-height{
        line-height: 2em;
        font-size: 1.15em;
    }
    .top_text p{
        font-size:2.4rem!important
    }
    .top_image_wraper {
        min-height: 280px !important;
    }
}

@media print,screen and (min-width: 760px){
    .services_block, .support-block{
        padding: 70px 0! important;    
    }
    .line-height{
        line-height: 2em;
        font-size: 1em;
    }
}
@media (min-width: 768px){
    /*メニュー　下線*/
    .global-nav-list>li:before {
        border-bottom:none;
    }
    .support-block div .support_wrap{
        width: 950px;
    }
}
@media (min-width: 991px){
    .servises-4btn{
        flex-wrap: nowrap!important;
    }
    .button-bg .btn{
        width: 8em;
    }

}
@media screen and  (min-width: 992px) {
    /*ヘッダースクロール*/
    .header_scrolled .site-header-logo {
        display: block;
        position: absolute;
        padding-top: 15px;
    }    
    .site-header--layout--nav-float .site-header-logo {
        margin-right: 0;
        width: auto;
    }    
    .header_scrolled .site-header-logo img {
        width: auto;
        height: 40px;
    }    
    .header_scrolled .site-header .global-nav {
        margin-right: 0;
    }
    
}

@media screen and  (min-width: 1200px) {
    .top_image_wraper{
        min-height: 650px!important;
    }
}

