/*!
Template:rishun
Theme Name: rishun_child
Theme URI: https://rishuntrading.co.jp
Description: Rishun is a very simple & easy to customize theme which is based on the Bootstrap. It is also very friendly with custom post types and custom taxonomies. When you add a new one, the breadcrumbs will be adjusted and posts will look beautifully without editing or adding a template files.
Author: RishunTrading Limited.
Author URI: https://rishuntrading.co.jp
Version: 1.0.0
Requires at least: 1.0
Tested up to: 1.0.0
Requires PHP: 5.6.0
Tags: blog, one-column, custom-background, custom-colors, custom-logo, custom-menu, editor-style, featured-images, footer-widgets, full-width-template, sticky-post, theme-options, threaded-comments, translation-ready, block-styles, wide-blocks

License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html

Rishun WordPress theme, Copyright (C) 2022 RishunTrading Limited.
Rishun WordPress theme is licensed under the GPL.
Update Author:RishunTrading Limited
Update Author URI:https://rishuntrading.co.jp/
Version:1.0.0
*/
@charset "utf-8";
/************************************************************/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Russo+One&display=swap');
:root{
    --font-color:#000000;
    --font-color2:#565252;
    --thin-font-color:#f7f7f7;
    --site-blue:#020c7c;
    --site-deep-blue:#2d305f;
    --site-contact-blue:#2b62a9;
    --site-red:#C70202;
    --site-yellow:#C70202;
    --footer-last-color:#172439;
    --bk-grey-color:#f0f0f0;
    --single-bk-color:#020c7c;
    --linear-gradient:linear-gradient(90deg, #ff805d 20%, #C70202 80%);
    --soldout-font-color:#ff8000;
    --ask-font-color:#ff8000;
    --focus-color:#020c7c;
    --submit-btn:#ff8000;
    --require-color:#C70202;
    --th-color:#d7edf2;
    --bd-color:rgb(2, 12, 124, 0.1);
    --btn-hover-color:#020c7c;
    --noto-sans:"Noto Sans JP", sans-serif;
    --noto-serif:"Noto Serif JP", serif;
    --russo:"Russo One", sans-serif;
    --sp-pgheader-height: 250px;
    --tb-pgheader-height: 300px;
    --pc-pgheader-height: 350px;    
}
/*==========================================================*/
/* defalt define											*/
/*==========================================================*/
body, p{
    font-size:16px;
    font-family:var(--noto-sans);
}
body a{
    color:#333;
    font-family:var(--noto-sans);
}
body a:hover{
    color:#333;
}
.nodata{
    color:var(--font-color);
}
img{
    width:100%;
    height:auto;
}
.entry-body img{
    display:unset;
    width:auto;
    height: auto;
    max-width: 100%;
}
@media print {
    #mobile-menu {
        display: none !important;
    }
}
/***********************************************************/
/* 本文領域のスコープ（テーマに合わせて .single-sales-wrap は調整） */
.single-sales-wrap img{
  max-width: 100%;
  height: auto;
}
.single-sales-wrap img.aligncenter{
  display: block;
  margin: 0 auto;
  width: auto;
  max-width: 100%;
}
.single-sales-wrap img.alignleft{
  display: block;
  width: auto;
  margin: 0 auto 1em 0;
  max-width: 100%;
}
.single-sales-wrap img.alignright{
  display: block;
  width: auto;
  margin: 0 0 1em auto;
  max-width: 100%;
}
.single-sales-wrap img.alignnone{
  display: block;
  width: auto;
  max-width: 100%;
}
.single-sales-wrap .alignleft,
.single-sales-wrap .alignright{
  clear: both;
}
.single-sales-wrap figure.wp-block-image.aligncenter{
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.single-sales-wrap figure.wp-block-image.aligncenter img{
  display: inline-block;
  width: auto;
  max-width: 100%;
  height: auto;
}
/*==========================================================*/
/* Common         											*/
/*==========================================================*/
.h2editor{  /* for jp */
    font-size:20px;
    position:relative;
    padding-bottom:10px;
    margin-bottom:40px;
    border-bottom:solid 2px var(--site-blue);
}
.h2editor2{ /* for en */
    font-size: 20px;
    font-family: var(--russo);
    text-align: center;
    color: var(--site-blue);
    font-weight: 500;
    margin-bottom:40px;
}
.h3editor{  /* for jp */
    font-size:20px;
    position:relative;
    padding-left:10px;
    margin-bottom:40px;
}
.h3editor::before{
    content:'';
    width:4px;
    height:95%;
    background:var(--site-blue);
    position:absolute;
    top:50%;
    left:0;
    translate:0 -50%;
}
.h3editor2{ /* for en */
    font-size: 20px;
    font-family: var(--russo);
    text-align: center;
    color: var(--font-color);
    font-weight: 500;
    position:relative;
    padding-bottom:10px;
    margin-bottom:40px;
}
.h3editor2::before{ /* for en */
    content:'';
    width:60px;
    height:4px;
    background:var(--site-blue);
    position:absolute;
    bottom:0;
    left:50%;
    translate:-50% 0;
}
@media(min-width:768px){
    .h2editor{  /* for jp */
        font-size:24px;
    }
    .h2editor2{ /* for en */
        font-size: 24px;
    }
    .h3editor{  /* for jp */
        font-size:24px;
    }
    .h3editor2{ /* for en */
        font-size: 24px;
        padding-bottom:20px;
    }
}
/*==========================================================*/
/* header         											*/
/*==========================================================*/
.site-header.ptnB{
    height:0;
}
.site-header-wrap{
    width:100%;
    height:var(--ptnB-sp-header-height);
    position:fixed;
    top:0;
    left:0;
    z-index:1950;
    box-shadow:none;
}
.scrolled .ptnB .site-header-wrap{
    background:rgb(1, 8, 91, 0.9);
}
.ptnB .site-header-inner{
    justify-content:flex-start;
}
.site-header-logo{
    height:100%;
}
.site-header-logo a{
    display:flex;
    justify-content:flex-start;
    flex-flow:row nowrap;
    align-items:center;
    height:100%;
    color:#fff;
    transition:all 0.5s;
}
.site-header-logo a img{
    width:auto;
    height:calc(100% - 20px);
    margin:10px 5px 10px 0;
}
.site-header-logo a .logo-ttl{
    font-size:20px;
    font-family:var(--noto-sans);
}
.site-header-logo a:hover{
    color:#fff;
}
.site-header-contact{
    display:none;
}
.site-header-lang{
    display:flex;
    flex-flow:row nowrap;
    margin-left:10px;
}
.site-header-lang a{
    font-family:var(--russo);
    color:#ccc;
    font-size:17px;
    transition:all 0.5s;
    opacity:0.8;
}
.site-header-lang a:hover{
    color:#fff;
}
.site-header-lang a.active{
    color:#fff;
    pointer-events:none;
}
.site-header-lang span{
    color:#ccc;
    margin:0 5px;
}
/* header menu */
@media(min-width:992px){
    .site-header-logo a img{
        width:auto;
        height:calc(100% - 10px);
        margin:5px 5px 5px 0;
    }
    .ptnB .container.site-header-container{
        display: grid;
        grid-template-columns: 275px 1fr 220px;
        grid-template-rows: 1fr;
    }
    .ptnB .site-header-nav{
        width:100%;
        grid-column:2/3;
        justify-content:center;
    }
    .menu-globalmenu-container{
        width:100%;
    }
    .site-header-menu{
        width:100%;
        display:flex;
        justify-content:space-evenly;
    }
    .site-header-menu>li>a{
        font-size:16px;
        font-weight:400;
        font-family:var(--noto-sans);
        position:relative;
        letter-spacing: 0;
    }
    .site-header-menu>li>a::before{
        content:'';
        width:100%;
        height:1px;
        border-radius:0;
        transition:transform 0.5s;
        transform:scale(0,1);
        transform-origin: right center;
    }
    .site-header-menu>li>a:hover::before{
        transform:scale(1,1);
        transform-origin: left center;
    }
    .site-header-menu>li>a:hover{
        color:#fff;
    }
    /* site header contact */
    .site-header-contact{
        display:flex;
        flex-flow:row nowrap;
        width:100%;
        grid-column:3/4;
        grid-row:1/2;
        align-items:center;
        justify-content:flex-end;
    }
    .site-header-tel{
        display:flex;
        flex-flow:row nowrap;
        color:#fff;
        margin-right:10px;
    }
    .site-header-tel .tel-mark{
        display:flex;
        align-items:center;
        font-size:32px;
    }
    .site-header-tel .tel-wrap span{
        display:block;
        white-space:nowrap;
        line-height:1;
    }
    .site-header-tel .tel-wrap .tel{
        font-family:var(--russo);
        font-size:20px;
    }
    .site-header-tel .tel-wrap .biztime{
        font-size:12px;
    }
    .site-header-mail>a{
        width:130px;
        height:45px;
        display:flex;
        justify-content:center;
        align-items:center;
        background:var(--site-yellow);
        color:#fff;
        border-radius:5px;
        transition:all 0.5s;
        font-size:15px;
        position:relative;
        transition:all 0.5s;
        line-height:1;
        padding-right:15px;
    }
    .site-header-mail>a i{
        position:absolute;
        top:50%;
        right:10px;
        translate:0 -50%;
        transition:all 0.5s;
        font-size:14px;
    }
    .site-header-mail>a:hover{
        color:#fff;
        filter:brightness(1.1);
    }
    .site-header-mail>a:hover i{
        right:5px;
    }
    .site-header-mail>a{
        width:150px;
    }
    .cl_en_site .ptnB .container.site-header-container{
        grid-template-columns: 280px 1fr 220px;
    }
    .cl_en_site .site-header-logo a .logo-ttl{
        font-size:18px;
        white-space:nowrap;
    }
}
@media(min-width:1200px){
    .site-header-logo a .logo-ttl{
        font-size:24px;
        white-space:nowrap;
    }
    .cl_en_site .site-header-logo a .logo-ttl{
        font-size:22px;
    }
    .site-header-lang{
        margin-right:10px;
    }
    .cl_en_site .ptnB .container.site-header-container{
        grid-template-columns: 330px 1fr 230px;
    }
}
@media(min-width:1400px){
    .ptnB .container.site-header-container{
        grid-template-columns: 1fr 1fr 1fr;
    }
}
/*==========================================================*/
/* mobile menu  											*/
/*==========================================================*/
.mobile-navi-btn.right{
    width:59px;
    height:59px;
    top:0;
    right:0;
    background:transparent;
}
.scrolled .mobile-navi-btn.right{
    box-shadow:none;
}
.mobile-navi-btn span{
    position: absolute;
    background:var(--thin-font-color);
    height:2px;
    width:30px;
    left:50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    transition: all .3s;
}
.mobile-navi-btn span:nth-child(1){
    top:34%;
}
.mobile-navi-btn span:nth-child(2){
    top:50%;
}
.mobile-navi-btn span:nth-child(3){
    top:66%;
}
.mobile-navi-btn.mobile-navi-open{
    box-shadow:none;
}
/* mobile btn */
.mobile-navi-btn.mobile-navi-open span:nth-child(1){
    transform-origin: top center;
    top:50%;
    left:15px;
    transform: rotate(135deg) translate(0, -50%);
}
.mobile-navi-btn.mobile-navi-open span:nth-child(2){
    opacity: 0;
}
.mobile-navi-btn.mobile-navi-open span:nth-child(3){
    transform-origin: top center;
    left:15px;
    top:50%;
    transform: rotate(45deg) translate(0, -50%);
}
.site-mobile-nav{
    padding:20px 15px 30px;
}
.site-mobile-nav>div{
    padding:0;
    background:rgba(255, 255, 255, 0);
    padding-right:20px;
}
.site-mobile-menu>li>a{
    color:#fff;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    padding-left: 30px;
    transition: all 0.5s;
}
.site-mobile-menu>li{
    border:none;
    margin:0;
    padding:0;
    font-size:16px;
}
.mobile-lang.site-header-lang{
    margin-top:20px;
    display:flex;
    justify-content:center;
    align-items: center;
}
.mobile-lang.site-header-lang a{
    font-size:24px;
}
.mobile-lang.site-header-lang span{
    font-size:20px;
    margin:0 15px;
}
/*==========================================================*/
/* common         											*/
/*==========================================================*/
.page-section{
    padding:80px 0;
}
.hd-style{
    margin-bottom:40px;
}
.hd-style h2{
    font-size:24px;
    font-family:var(--russo);
    text-align:center;
    color:var(--site-blue);
    font-weight:500;
}
.hd-style p{
    font-size:14px;
    text-align:center;
    font-weight:500;
}
.viewmore-btn{
    margin-top:40px;
}
.viewmore-btn a{
    width:250px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    margin:0 auto;
    background:var(--site-blue);
    color:#fff;
    position:relative;
    transition:all 0.5s;
}
.viewmore-btn a i{
    position:absolute;
    top:50%;
    right:20px;
    translate:-0 -50%;
    transition:all 0.5s;
}
.viewmore-btn a:hover{
    filter:brightness(1.1);
    color:#fff;
}
.viewmore-btn a:hover i{
    right:10px;
}
@media(min-width:768px){
    .hd-style h2{
        font-size:36px;
    }
    .hd-style p{
        font-size:16px;
    }
}
/*==========================================================*/
/* fade-in       											*/
/*==========================================================*/
.fade-in{
    opacity:0;
    transition:all 1s;
    transform:translateY(20px);
}
.fade-in.scroll-in{
    animation: fade-in ease 1s forwards;
}
.hd-style.scroll-in h2>span:before{
    animation: passing-bar 1s ease 0s 1 normal forwards;
    animation-delay: 1s;
}
.hd-style.scroll-in h2>span{
    animation:passing-txt 0s ease .5s 1 normal forwards;
    animation-delay: 1s;
}
.fade-right{
    transform:translateX(-100%);
    opacity:0;
    transition:all 1s cubic-bezier(0.77, 0, 0.175, 1);
}
.fade-left{
    transform:translateX(100%);
    opacity:0;
    transition:all 1s cubic-bezier(0.77, 0, 0.175, 1);
}
.fade-right.scroll-in{
    transform:translateX(0);
    opacity:1;
}
.fade-left.scroll-in{
    transform:translateX(0);
    opacity:1;
}
/* ribon */
.anime-slide{
    position: relative;
    display: table;
    overflow: hidden;
    margin:0 auto;
}
.anime-slide>.anime-word{
    opacity: 0;
    transform: translateY(6px); /* a little move */
    transition: opacity .2s linear, transform .2s ease;
    transition-delay: 0s;
}
.anime-slide::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--btn-hover-color);
  z-index: 5;
  transform: scaleX(0);
  transform-origin: left center;
}
.anime-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background: var(--btn-hover-color);
  z-index: 5;
  transform: scaleX(1);
  transform-origin: right center;
  opacity: 0;
}
/* active */
.anime-slide.active>.anime-word{
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.6s;
}
.anime-slide.active::before{
    animation: ribbon-in 0.6s cubic-bezier(0.77,0,0.175,1) forwards;
}
.anime-slide.active::after{
  animation: ribbon-out 0.6s cubic-bezier(0.77,0,0.175,1) forwards;
  animation-delay: 0.6s;
}
@keyframes ribbon-in{
    0%   { transform: scaleX(0); opacity: 1; }
    99.9999% { transform: scaleX(1); opacity: 1; }
    100% { transform: scaleX(1); opacity: 0; }
}
@keyframes ribbon-out{
    0%   { transform: scaleX(1); opacity: 1; }
    100% { transform: scaleX(0); opacity: 1; }
}
@keyframes passing-bar{
	0% {
		left: 0;
		width: 0;
	}
	50% {
		left: 0;
		width: 100%;
	}
	51% {
		left: 0;
		width: 100%;
	}
	100% {
		left: 100%;
		width: 0;
	}
}
@keyframes passing-txt{
	0% { opacity:0; }
	70% { opacity:0; }
	100% { opacity:1; }
}
@keyframes fade-in{
	0% {
         opacity:0;
         transform:translateY(20px);
    }
	100% {
        opacity:1;
        transform:translateY(0);
    }
}
/*==========================================================*/
/* top slide      											*/
/*==========================================================*/
.front-page{
    position:relative;
}
.front-page::before{
    content:'';
    width:100%;
    height:100vh;
    background:url('./img/bk-company.jpg') center center / cover no-repeat;
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
}
.tpslide-sec{
    position:relative;
    padding:0;
}
.tpslider-wrap{
    width:100%;
    position:relative;
}
.tpslider-wrap:before{
    content:'';
    width:100%;
    height:100%;
    background:#000;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
    transition:all 1s;
}
.tpslider-wrap.is_slider:before{
    background:rgba(0,0,0,0.2);
}
#km_slider {
  direction: rtl;
}
#km_slider .slick-slide {
  direction: ltr;
}
#km_slider .slick-dots {
  direction: ltr;
  position:absolute;
  left:20px;
  bottom:20px;
  z-index:20;
  width:fit-content;
}
#km_slider .slick-dots li{
    display:block;
    width:fit-content;
    width:30px;
    height:30px;
}
#km_slider .slick-dots li button{
    width:30px;
    height:30px;
}
#km_slider .slick-dots li button:before{
    width:30px;
    height:30px;
    color:#fff;
    line-height:30px;
    font-size:20px;
    opacity:0.4;
}
#km_slider .slick-dots li.slick-active button:before{
    color:var(--site-red);
    opacity:0.8;
}
.ul-km-slider{
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
}
.tpslider-wrap .slick-dotted.slick-slider{
    margin:0;
}
.ul-km-slider li{
    width:100%;
}
.ul-km-slider li img{
    width:100%;
    height:100vh;
    object-fit:cover;
}
/* catch copy */
.tpcatch-wrap{
    display:flex;
    position:absolute;
    top:50%;
    left:20px;
    translate:0 -50%;
    z-index:5;
}
.tpcatch-wrap h2{
    color:#fff;
    font-size:36px;
    font-family:var(--noto-sans);
    font-weight:900;
    opacity:0;
    transition:all 1s;
    transform:translateY(30px);
}
.cl_en_site .tpcatch-wrap h2{
    font-family:var(--russo);
}
.tpcatch-wrap p{
    color:#fff;
    font-size:18px;
    font-family:var(--russo);
    white-space:nowrap;
    opacity:0;
    transition:all 1s;
    transform:translateY(30px);
    font-weight:400;
}
.tpcatch-wrap.is_catch h2{
    opacity:1;
    transform:translateY(0);
}
.tpcatch-wrap.is_catch p{
    opacity:1;
    transform:translateY(0);
}
.scroll-wrap{
    position:absolute;
    bottom:10px;
    left:50%;
    translate:-50% 0;
    color:#fff;
    z-index:10;
}
.scroll-wrap a{
    color:#fff;
    display:flex;
    justify-content:center;
    transition:all 0.5s;
}
.scroll-wrap a:hover{
    color:#fff;
}
.scroll-wrap a .wrap{
    text-align:center;
}
.scroll-text{
    font-size:14px;
    display:block;
    letter-spacing:1px;
    font-family:var(--russo);
}
.icon-outer{
    display:flex;
    justify-content:center;
    position:relative;
    height:18px;
    overflow:hidden;
}
.icon-outer i{
    display:block;
    transform:translateY(-100%);
    animation:scrollArrow 2s ease-in-out infinite;
}
@keyframes scrollArrow {
    0%{
        transform:translateY(-100%);
        opacity:0;
    }
    30%{
        opacity:1;
    }
    60%{
        transform:translateY(0);
        opacity:1;
    }
    100%{
        transform:translateY(100%);
        opacity:0;
    }
}
@media(min-width:768px){
    .tpcatch-wrap{
        padding-left:10%;
    }
    .tpcatch-wrap h2{
        font-size:60px;
    }
    .tpcatch-wrap p{
        font-size:30px;
    }
    .scroll-text{
        font-size:16px;
        display:block;
        letter-spacing:1px;
        font-family:var(--russo);
    }
    .icon-outer{
        height:20px;
    }
}
@media(min-width:992px){
    .tpcatch-wrap h2{
        font-size:80px;
    }
    .tpcatch-wrap p{
        font-size:40px;
    }
    .scroll-wrap{
        bottom:40px;
    }
    .scroll-text{
        font-size:17px;
        margin-bottom:4px;
    }
    /* dots */
    #km_slider .slick-dots{
        position:absolute;
        left:60px;
        bottom:60px;
    }
    #km_slider .slick-dots li{
        width:40px;
        height:40px;
    }
    #km_slider .slick-dots li button{
        width:40px;
        height:40px;
    }
    #km_slider .slick-dots li button:before{
        font-size:30px;
        width:40px;
        height:40px;
    }
/*
    #km_slider .slick-dots{
        display:flex;
        flex-flow:row nowrap;
        left:30px;
        bottom:40px;
    }
    #km_slider .slick-dots li{
        display:block;
        width:fit-content;
        width:50px;
        height:4px;
    }
    #km_slider .slick-dots li button{
        width:50px;
        height:4px;
    }
    #km_slider .slick-dots li button:before{
        content:'';
        width:50px;
        height:4px;
        color:transparent;
        line-height:1;
        font-size:20px;
        opacity:0.5;
        background:rgba(255,255,255,0.4);
    }
    #km_slider .slick-dots li.slick-active button:before{
        background:var(--site-red);
        opacity:0.8;
    }
*/
}
/*==========================================================*/
/* top stock list  											*/
/*==========================================================*/
.tpstocklist-sec{
    position:relative;
    background:#f7f7f7;
}
/* slick */
.tpstocklist-sec .slick-prev, .slick-next{
    width:40px;
    height:40px;
    transition:all 0.5s;
    z-index:30;
}
.tpstocklist-sec .slick-prev::before, .slick-next::before{
    width:40px;
    height:40px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:rgb(60, 103, 152, 0.8);
    opacity:1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "Font Awesome 7 Free";
    font-feature-settings: normal;
    font-style: normal;
    font-synthesis: none;
    font-variant: normal;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    text-rendering: auto;
    color:#fff;
    font-size:16px;
    transition:all 0.5s;
}
.tpstocklist-sec .slick-prev:hover::before, .slick-next:hover::before{
    background:rgb(60, 103, 152);
}
.tpstocklist-sec .slick-prev:before{
    content:"\f104";
}
.tpstocklist-sec .slick-next:before{
    content:"\f105";
}
.tpstocklist-sec .slick-prev{
    left:5px;
}
.tpstocklist-sec .slick-next{
    right:5px;
}
.tpstocklist-sec .slick-dots{
    bottom:-40px;
}
.tpstocklist-sec .slick-dots li button{
    width:30px;
    height:30px;
    padding:0;
    transition:all 0.5s;
}
.tpstocklist-sec .slick-dots li button:before{
    width:30px;
    height:30px;
    font-size:16px;
    color:var(--site-blue);
    transition:all 0.5s;
}
.tpstocklist-wrap{
    width:100%;
}
.ul-stocklist{
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content:flex-start;
    gap:10px;
}
.ul-stocklist>li{
    flex: 0 0 calc(50% - 5px);
    margin-bottom:30px;
}
.machinelink{
    display:block;
    width:100%;
    box-shadow:0 0 5px rgb(0,0,0,0.3);
}
.machinelink .pict{
    width:100%;
    position:relative;
    overflow:hidden;
}
.machinelink .pict>img{
    width:100%;
    aspect-ratio: 4/3;
    object-fit:cover;
    transition:all 0.5s;
}
.machinelink:hover .pict>img{
    transform:scale(1.1);
    filter:brightness(1.1);
}
.machinelink .pict .machine-new{
    width:80px;
    height:80px;
    display:flex;
    justify-content:center;
    align-items:center;
    color:#fff;
    font-weight:400;
    font-size:11px;
    overflow:hidden;
    position:absolute;
    top:0;
    left:0;
    z-index:20;
}
.machinelink .pict .machine-new span{
    position: absolute;
    top: -15px;
    left: -45px;
    width: 120px;
    padding: 24px 0 6px 0;
    background:var(--site-red);
    color: #fff;
    font-size: 14;
    font-weight: bold;
    text-align: center;
    transform: rotate(-45deg);
    box-shadow: 0 2px 4px rgba(0,0,0,.25);    
}
.machinelink .pict .machine-sold_out{
    width:80px;
    height:50px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:transparent;
    border:solid 5px var(--site-red);
    border-radius:10px;
    color:var(--site-red);
    font-weight:400;
    font-size:20px;
    position:absolute;
    top:50%;
    left:50%;
    z-index:20;
    translate:-50% -50%;
    line-height:1;
    text-align:center;
    transform:rotate(-5deg);
    font-family:var(--russo);
}
.machinelink .pict .machine-thanks{
    color:#fff;
    position:absolute;
    bottom:2px;
    left:0;
    width:100%;
    text-align:center;
    font-weight:500;
    font-family:var(--russo);
}
.machinelink .desc{
    padding:10px;
    position:relative;
    overflow:hidden;
    background:#fff;
}
.hd-stock, .bd-stock{
    width:100%;
}
.hd-stock{
    margin-bottom:10px;
    min-height:65px;
}
.bd-stock{
    min-height:80px;
}
.hd-stock .maker{
    font-size:12px;
    color:var(--font-color2);
}
.hd-stock .code{
    font-size:16px;
}
.bd-stock .price{
    display:block;
    margin-bottom:10px;
}
.bd-stock .price .num{
    display:inline-block;
    transform:scaleY(1.2);
    font-weight:700;
    font-size:16px;
    color:var(--site-blue);
    font-family:var(--russo);
    font-weight:400;
}
.bd-stock .price .currency{
    font-family:var(--noto-sans);
    font-size:0.8em;
    margin-left:5px;
    font-weight:400;
    color:var(--font-color2);
}
.bd-stock .ask{
    display:block;
    font-weight:700;
    font-size:16px;
    margin-bottom:10px;
    color:var(--site-blue);
    font-family:var(--russo);
    font-weight:400;
    transform:scaleY(1.2);
}
.dl-machines-desc{
    width:100%;
    margin:0;
    display:flex;
    flex-flow:row wrap;
}
.dl-machines-desc dt{
    width:32%;
    font-size:10px;
    font-weight:400;
    margin:0;
}
.dl-machines-desc dd{
    width:68%;
    font-size:10px;
    font-weight:500;
    margin:0;
    white-space:nowrap;
}
.cl_en_site .dl-machines-desc dt{
    width:60%;
}
.cl_en_site .dl-machines-desc dd{
    width:40%;
}
.tpstocklist-sec .viewmore-btn{
    margin-top:80px;
}
@media(min-width:768px){
    .ul-stocklist{
        gap:12px;
    }
    .ul-stocklist>li{
        flex: 0 0 calc(33.333% - 8px);
    }
    .machinelink .pict .machine-sold_out{
        width:120px;
        height:70px;
        font-size:24px;
        padding:0 10px;
    }
    .machinelink .pict .machine-thanks{
        font-size:20px;
    }
}
@media(min-width:992px){
    .ul-stocklist{
        gap:16px;
    }
    .ul-stocklist>li{
        flex: 0 0 calc(25% - 12px);
        margin-bottom:40px;
    }
    .bd-stock .price .num, .bd-stock .ask{
        font-size:24px;
    }
    .bd-stock .price .currency{
        font-family:var(--noto-sans);
        font-size:0.8em;
        margin-left:5px;
        font-weight:400;
        color:var(--font-color2);
    }
    .machinelink .desc{
        min-height:170px;
        padding:20px;
    }
    .dl-machines-desc dt{
        font-size:11px;
    }
    .dl-machines-desc dd{
        font-size:11px;
    }
    .hd-stock, .bd-stock{
        min-height:unset;
    }
}
@media(min-width:1200px){
    .ul-stocklist{
        gap:30px;
    }
    .ul-stocklist>li{
        flex: 0 0 calc(25% - 22.5px);
    }
    .dl-machines-desc dt{
        font-size:12px;
    }
    .dl-machines-desc dd{
        font-size:12px;
    }
    .machinelink .pict .machine-sold_out{
        width:130px;
        height:80px;
        font-size:30px;
        padding:0 15px;
    }
    .machinelink .pict .machine-thanks{
        font-size:26px;
    }
}
/*==========================================================*/
/* category list  											*/
/*==========================================================*/
.tpcategory-sec{
    position:relative;
    background:var(--bk-grey-color);
}
.tpcategory-sec .hd-style h2{
    color:var(--site-red);
}
.tpcategory-sec .hd-style p{
    color:var(--font-color2);
}
.tpcategory-wrap{
    width:100%;
}
.ul-machine_type{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    margin:0;
    padding:0;
    list-style:none;
    justify-content:flex-start;
    gap:10px;
}
.ul-machine_type li{
    flex: 0 0 calc(50% - 5px);
    margin-bottom:0;
    background: var(--linear-gradient);
    overflow:visible;
}
.machine_type_link{
    display:block;
    width:100%;
    transition:all 0.3s ease-in-out;
    background:#fff;
    border:solid 1px #ccc;
}
.machine_type_link:hover{
    transform:translate(-15px,-15px);
    border:solid 1px #ccc;
}
.machine_type_link .pict{
    width:100%;
    background:#fff;
    padding:10px;
    margin-bottom:10px;
}
.machine_type_link .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:contain;
}
.machine_type_link h3{
    font-size:12px;
    white-space:nowrap;
    color:var(--font-color);
    text-align:center;
    padding-bottom:15px;
    margin-bottom:0;
}
@media(min-width:768px){
    .ul-machine_type{
        gap:12px;
    }
    .ul-machine_type>li{
        flex: 0 0 calc(33.333% - 8px);
    }
}
@media(min-width:992px){
    .ul-machine_type{
        gap:14px;
    }
    .ul-machine_type>li{
        flex: 0 0 calc(20% - 11.2px);
    }
    .cl_en_site .machine_type_link h3{
        letter-spacing:-1px;
    }
}
@media(min-width:1200px){
    .ul-machine_type{
        gap:20px;
    }
    .ul-machine_type>li{
        flex: 0 0 calc(16.666% - 16.666px);
    }
    .cl_en_site .machine_type_link h3{
        letter-spacing:0px;
    }
}
/*==========================================================*/
/* tpsales-sec  											*/
/*==========================================================*/
.tpsales-sec{
    position:relative;
    background:#f7f7f7;
}
.ul-soldlist .slick-slide{
    padding:0 5px 5px 5px;
}
.tpsales-sec .viewmore-btn{
    margin-top:80px;
}
.ul-soldlist:not(.slick-initialized){
    margin: 0 auto;
    padding:0 20px;
}
.tpsales-sec .slick-prev, .slick-next{
    width:40px;
    height:40px;
    transition:all 0.5s;
    z-index:30;
}
.tpsales-sec .slick-prev::before, .slick-next::before{
    width:40px;
    height:40px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:rgb(60, 103, 152, 0.8);
    opacity:1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "Font Awesome 7 Free";
    font-feature-settings: normal;
    font-style: normal;
    font-synthesis: none;
    font-variant: normal;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    text-rendering: auto;
    color:#fff;
    font-size:16px;
    transition:all 0.5s;
}
.tpsales-sec .slick-prev:hover::before, .slick-next:hover::before{
    background:rgb(60, 103, 152);
}
.tpsales-sec .slick-prev:before{
    content:"\f104";
}
.tpsales-sec .slick-next:before{
    content:"\f105";
}
.tpsales-sec .slick-prev{
    left:5px;
}
.tpsales-sec .slick-next{
    right:5px;
}
.tpsales-sec .slick-dots{
    bottom:-40px;
}
.tpsales-sec .slick-dots li button{
    width:30px;
    height:30px;
    padding:0;
    transition:all 0.5s;
}
.tpsales-sec .slick-dots li button:before{
    width:30px;
    height:30px;
    font-size:16px;
    color:var(--site-blue);
    transition:all 0.5s;
}
.ul_archive_sales li .machinelink{
    background:#000;
}
.ul_archive_sales li .machinelink .pict>img{
    opacity:0.6;
}
@media(min-width:576px){
    .ul-soldlist:not(.slick-initialized){
        max-width: 540px;
    }
    .tpsales-sec .slick-prev{
        left:10px;
    }
    .tpsales-sec .slick-next{
        right:10px;
    }
}
@media(min-width:768px){
    .ul-soldlist:not(.slick-initialized){
        max-width: 720px;
    }
}
@media(min-width:992px){
    .ul-soldlist:not(.slick-initialized){
        max-width: 960px;
    }
    .ul-soldlist .slick-slide{
        padding:0 10px 5px 10px;
    }
    .tpsales-sec .slick-prev{
        left:20px;
    }
    .tpsales-sec .slick-next{
        right:20px;
    }
}
@media(min-width:1200px){
    .ul-soldlist:not(.slick-initialized){
        max-width: 1140px;
    }
    .ul-soldlist .slick-slide{
        padding:0 15px 5px 15px;
    }
}
@media(min-width:1400px){
    .ul-soldlist:not(.slick-initialized){
        max-width: 1200px;
    }
}
/*==========================================================*/
/* tpcompany-sec  											*/
/*==========================================================*/
.tpcompany-sec{
    position:relative;
    background:rgb(2, 12, 124, 0.3);
}
.tpcompany-sec .hd-style h2{
    color:var(--thin-font-color);
}
.tpcompany-sec .hd-style p{
    color:var(--thin-font-color);
}
.tpcompany-wrap{
    width:100%;
}
.tpcompany-msg{
    width:100%;
    display:flex;
    justify-content:center;
}
.tpcompany-msg p{
    color:var(--thin-font-color);
}
.tpcompany-sec .viewmore-btn a{
    background:var(--site-red);
}
/*==========================================================*/
/* bf-contact-sec  											*/
/*==========================================================*/
.bf-contact-sec{
    background:var(--site-contact-blue);
    padding:40px 0;
}
.bf-contact-sec .hd-style h2{
    color:var(--thin-font-color);
}
.bf-contact-sec .hd-style p{
    color:var(--thin-font-color);
}
.bf-contact-wrap{
    display:flex;
    width:100%;
    justify-content:center;
}
.bf-contact-wrap p{
    color:#fff;
    display:inline;
}
.bf-contact-btn{
    width:100%;
    margin-top:30px;
}
.bf-contact-tel{
    width:100%;
}
.bf-contact-mail{
    width:100%;
   
}
.bf-contact-tel a{
    width:100%;
    max-width:280px;
    height:55px;
    border-radius:28px;
    border:solid 1px var(--site-red);
    background:#fff;
    display:flex;
    justify-content: center;
    align-items:center;
    margin:0 auto;
    color:var(--site-red);
    font-size:24px;
    font-family:var(--russo);
    transition:all 0.5s;
}
.bf-contact-tel a i{
    margin-right:5px;
}
.bf-contact-tel a:hover{
    background:var(--site-red);
    color:#fff;
}
.bf-contact-tel p{
    text-align:center;
    color:var(--thin-font-color);
}
.bf-contact-mail{
    margin-top:10px;
}
.bf-contact-mail a{
    width:100%;
    max-width:280px;
    height:55px;
    border-radius:28px;
    border:solid 1px var(--site-red);
    background:var(--site-red);
    display:flex;
    justify-content: center;
    align-items:center;
    margin:0 auto;
    color:#fff;
    position:relative;
    transition:all 0.5s;
}
.bf-contact-mail a:hover{
    filter:brightness(1.1);
    color:#fff;
}
.bf-contact-mail a i{
    font-size:20px;
    position:absolute;
    top:50%;
    right:20px;
    translate:0 -50%;
}
.insta-wrap{
    text-align:center;
    margin-top:10px;
}
.insta-wrap a{
    display:flex;
    justify-content:center;
    align-items:center;
    width:40px;
    height:40px;
    background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
    color:#fff;
    font-size:32px;
    margin:0 auto;
    transition:all 0.5s;
    border-radius:5px;
    overflow:hidden;
}
.insta-wrap a:hover{
    color:#fff;
    filter:brightness(1.1);
    transform:scale(1.1);
}
@media(min-width:768px){
    .bf-contact-wrap p{
        color:#fff;
        display:block;
    }
    .bf-contact-btn{
        display:flex;
        flex-flow:row wrap;
        align-items:flex-start;
    }
    .bf-contact-btn>div{
        width:50%;
        margin:0;
    }
    .bf-contact-tel a{
        pointer-events:none;
    }
    .bf-contact-wrap p{
        text-align:center;
    }
    .insta-wrap{
        margin-top:0;
    }
}
/*==========================================================*/
/* bf-contact-sec  											*/
/*==========================================================*/
.site-footer{
    padding-bottom:0;
}
.footer_widget{
    display:flex;
    width:100%;
    justify-content:center;
    align-items:center;
    margin-bottom:30px;
}
.footer_widget:last-of-type{
    margin-bottom:0;
}
.ft-companyinfo{
    width:100%;
    padding:0 10px;
}
.ft-logo>a{
    display:flex;
    flex-flow:row nowrap;
    justify-content:center;
    align-items:center;
    transition:all 0.5s;
}
.ft-logo>a:hover{
    opacity:0.8;
}
.ft-logo>a img{
    width:45px;
    margin-right:10px;
}
.ft-logo>a .logo-ttl{
    color:#fff;
    font-weight:700;
    font-size:20px;
}
.ft-companyinfo>p{
    color:#fff;
    letter-spacing:0.1em;
    text-align:justify;
}
.ft-companyinfo>p>span{
    width:40px;
    display:inline-block;
}
.ft-companyinfo .telnolink{
    color:#fff;
    position:relative;
}
.ft-companyinfo .telnolink::before{
    content:'';
    width:100%;
    height:1px;
    border-radius:0;
    transition:transform 0.5s;
    transform:scale(0,1);
    transform-origin: right center;
    background:#fff;
    position:absolute;
    left:0;
    bottom:0;
}
.ft-companyinfo .telnolink:hover::before{
    transform:scale(1,1);
    transform-origin: left center;
}
.ft-companyinfo .faxnolink{
    color:#fff;
}
.faxnolink{
    pointer-events: none;
}
.footerwidget ul{
    display:flex;
    margin:0;
    justify-content:flex-start;
    align-items:center;
    gap:10px;
    width:100%;
    flex-flow:row wrap;
}
.footerwidget ul li{
    width:calc(50% - 5px);
}
.footerwidget ul li a{
    font-size:16px;
    position:relative;
}
.footerwidget ul li a::before{
    content:'';
    width:100%;
    height:1px;
    border-radius:0;
    transition:transform 0.5s;
    transform:scale(0,1);
    transform-origin: right center;
    background:#fff;
    position:absolute;
    left:0;
    bottom:0;
}
.footerwidget ul li a:hover::before{
    transform:scale(1,1);
    transform-origin: left center;
}
.privacy-wrap{
    width:100%;
    display:flex;
    justify-content:center;
    margin-top:30px;
    margin-bottom:10px;
}
.privacy-wrap>a{
    color:#fff;
    position:relative;
    font-size:14px;
}
.privacy-wrap>a::before{
    content:'';
    width:100%;
    height:1px;
    border-radius:0;
    transition:transform 0.5s;
    transform:scale(0,1);
    transform-origin: right center;
    background:#fff;
    position:absolute;
    left:0;
    bottom:0;
}
.privacy-wrap>a:hover{
    color:#fff;
}
.privacy-wrap>a:hover::before{
    transform:scale(1,1);
    transform-origin: left center;
}
.site-footer-last-wrap{
    width:100%;
    background:var(--footer-last-color);
    padding:10px 20px 100px 20px;
}
.site-footer-last-wrap .wrap{
    width:100%;
    margin-bottom:20px;
}
.cl_address{
    width:100%;
    color:#fff;
    font-size:12px;
    margin:0;
}
.site-footer-last-wrap .wrap p{
    color:#fff;
    font-size:12px;
}
.site-footer-last-wrap .wrap .telnolink{
    color:#fff;
    position:relative;
}
.site-footer-last-wrap .wrap .telnolink::before{
    content:'';
    width:100%;
    height:1px;
    border-radius:0;
    transition:transform 0.5s;
    transform:scale(0,1);
    transform-origin: right center;
    background:#fff;
    position:absolute;
    left:0;
    bottom:0;
}
.site-footer-last-wrap .wrap .telnolink:hover::before{
    transform:scale(1,1);
    transform-origin: left center;
}
.site-footer-last-wrap .wrap .faxnolink{
    color:#fff;
}
.ft-last-tel{
    width:100%;
    display:flex;
    gap:10px;
}
.copyright{
    font-weight:400;
}
@media(min-width:768px){
    .privacy-wrap{
        margin-top:40px;
        margin-bottom:10px;
    }
    .ft-companyinfo{
        padding:0;
    }
    .ft-companyinfo .telnolink{
        pointer-events:none;
    }
    .footer_widget:first-of-type{
        width:300px;
        margin:0;
    }
    .footer_widget:last-of-type{
        width:calc(100% - 300px);
        margin:0;
    }
    .menu-footermenu-container{
        width:100%;
        margin-top:0;
    }
    .footerwidget ul{
        gap:10px;
    }
    .footerwidget ul li{
        width:calc((100% - 20px) / 3);
    }
    .site-footer-last-wrap .wrap{
        display:flex;
        gap:10px;
    }
    .cl_address{
        white-space:nowrap;
        width:fit-content;
    }
    .site-footer-last-wrap .wrap .telnolink{
        pointer-events:none;
    }
}
@media(min-width:992px){
    .br_zipcode{
        display:none;
    }
    .footerwidget ul{
        gap:10px;
    }
    .footerwidget ul li{
        width:calc((100% - 40px) / 5);
    }
    .cl_en_site .footerwidget ul li{
        display:flex;
        justify-content: center;
    }
}
/*==========================================================*/
/* page header  											*/
/*==========================================================*/
.page-header-ttl .jp{
    font-family:var(--russo);
    font-size:32px;
}
.page-header-ttl{
    transform:translateY(calc(-50% + 30px));
}
@media(min-width:768px){
    .page-header-ttl .jp{
        font-size:50px;
    }
}
/*==========================================================*/
/* archive machine 											*/
/*==========================================================*/
.archive-machines{
    background:#f0f0f0;
}
.machines-category-sec.page-section{
    padding:40px 0;
}
.machines-sec.page-section{
    padding:40px 0;
}
.pg-style{
    margin-bottom:20px;    
}
.pg-style h2{
    font-size:32px;
    font-family:var(--russo);
    color:var(--site-blue);
    font-weight:500;
}
.pg-style p{
    font-size:14px;
    font-weight:500;
}
.ul-m_categorylist{
    display:flex;
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
}
.ul-m_categorylist li{
    background:var(--linear-gradient);
}
.ul-m_categorylist .slick-prev, .slick-next{
    width:40px;
    height:40px;
    transition:all 0.5s;
    z-index:30;
}
.ul-m_categorylist .slick-prev::before, .slick-next::before{
    width:40px;
    height:40px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:rgb(60, 103, 152, 0.8);
    opacity:1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "Font Awesome 7 Free";
    font-feature-settings: normal;
    font-style: normal;
    font-synthesis: none;
    font-variant: normal;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    text-rendering: auto;
    color:#fff;
    font-size:16px;
    transition:all 0.5s;
}
.ul-m_categorylist .slick-prev:hover::before, .slick-next:hover::before{
    background:rgb(60, 103, 152);
}
.ul-m_categorylist .slick-prev:before{
    content:"\f104";
}
.ul-m_categorylist .slick-next:before{
    content:"\f105";
}
.ul-m_categorylist .slick-prev{
    left:5px;
}
.ul-m_categorylist .slick-next{
    right:5px;
}
.ul-m_categorylist>div{
    padding-top:20px!important;
}
.ul-m_categorylist li.current .machine_type_link{
    background:var(--site-blue);
    pointer-events:none;
}
.ul-m_categorylist li.current .machine_type_link h3{
    color:#fff;
}
.page-numbers{
    font-weight:400;
}
/*==========================================================*/
/* taxonomy      											*/
/*==========================================================*/
.tax-tax_machine_type{
    background:#f0f0f0;
}
/*==========================================================*/
/* signle         											*/
/*==========================================================*/
.single-machines{
    background:#f0f0f0;
}
.single-machines-pgheader .page-header-ttl .p_maker{
    text-align:center;
    font-size:18px;
    font-weight:700;
}
.single-machines-pgheader .page-header-ttl h1.model{
    text-align:center;
    font-size:24px;
    font-weight:700;
}
.single-machines-sec.page-section{
    padding:40px 0;
}
.single-machines-wrap{
    width:100%;
}
.dl-spec{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    margin-bottom:40px;
}
.dl-spec>dt{
    display:block;
    width:100%;
    margin-bottom:40px;
}
.dl-spec>dd{
    display:block;
    width:100%;
    margin-bottom:0;
}
.tbl-spec{
    width:100%;
}
.tbl-spec th{
    width:40%;
    border:solid 1px rgba(255,255,255,0.5);
    font-size:14px;
    background:rgba(255,255,255,0.1);
    padding:10px;
}
.tbl-spec td{
    width:60%;
    border:solid 1px rgba(255,255,255,0.5);
    font-size:14px;
    padding:10px;
}
.tbl-spec td p{
    font-size:14px;
}
.tbl-spec td a{
    transition:all 0.3s;
    text-decoration:underline;
}
.tbl-spec td a:hover{
    text-decoration:none;
    color:#ffff00;
}
/* property picture */
.pict-wrap{
    display:block;
    width:100%;
    margin-bottom:40px;
}
.pict-left{
    display:block;
    width:100%;
    position:relative;
    margin-bottom:20px;
}
.pict-right{
    display:block;
    width:100%;
}
.carousel-item img{
    width:100%;
    aspect-ratio:4/4;
    object-fit:cover;
    object-position:top center;
    border:solid 1px #fff;
}
.pict-right .org-indicators{
    margin: 0;
    border: 0;
    padding: 0;
    display: flex;
    flex-flow: row wrap;
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    right: auto;
    justify-content: flex-start;
    gap:6px;
}
.pict-right .carousel-indicators [data-bs-target]{
    display:inline-block;
    flex: 0 0 calc((100% - 18px) / 4);
    width:auto;
    height:auto;
    margin:0;
    border:0;
    box-sizing:border-box;
    background:#000;
    opacity:1;
}
.pict-right .carousel-indicators [data-bs-target] img{
    display:block;
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
    object-position:center center;
    border:solid 1px #fff;
    opacity:0.7;
}
.pict-right .carousel-indicators .active img{
    opacity:1;
}
.carousel-control-next, .carousel-control-prev{
    width:50px;
    height:50px;
    top:50%;
    transform:translateY(-50%);
}
.carousel-control-prev-icon{
    filter: drop-shadow(2px 2px 0 rgba(0,0,0,0.2))
             drop-shadow(-2px -2px 0 rgba(0,0,0,0.2))
             drop-shadow(-2px 2px 0 rgba(0,0,0,0.2))
             drop-shadow(2px -2px 0 rgba(0,0,0,0.2));
}
.carousel-control-next-icon{
    filter: drop-shadow(2px 2px 0 rgba(0,0,0,0.2))
             drop-shadow(-2px -2px 0 rgba(0,0,0,0.2))
             drop-shadow(-2px 2px 0 rgba(0,0,0,0.2))
             drop-shadow(2px -2px 0 rgba(0,0,0,0.2));
}
/* spec-wrap */
.spec-wrap{
    width:100%;
    background:#fff;
    padding:20px 10px;
    border-radius:5px;
}
.dl-spec{
    width:100%;
    margin:0;
}
.dl-spec dt{
    width:100%;
    margin:0;
    font-weight:400;
}
.tbl-spec{
    width:100%;
}
.tbl-spec tr{
    display:block;
    width:100%;
    margin-bottom:20px;
}
.tbl-spec th{
    display:block;
    width:100%;
    padding:1em;
    background:var(--site-blue);
    color:#fff;
    font-size:16px;
    border:solid 1px #ccc;
    font-weight:400;
}
.tbl-spec td{
    display:block;
    width:100%;
    font-size:16px;
    padding:1em;
    border-left:solid 1px #ccc;
    border-right:solid 1px #ccc;
    border-bottom:solid 1px #ccc;
}
.div_price{
    width:100%;
    margin-top:20px;
    margin-bottom:20px;
    display:flex;
    justify-content:center;
}
.div_price .price{
    display:flex;
    flex-flow:row nowrap;
    align-items:flex-end;
    font-family:var(--russo);
}
.div_price .price .num, .div_price .ask{
    font-size:40px;
    margin-right:5px;
    color:var(--site-blue);
}
.div_price .ask{
    font-family:var(--russo);
    color:var(--ask-font-color);
}
.div_price .price .currency{
    font-size:14px;
    padding-bottom:10px;
}
.ul_machine_type{
    list-style:none;
    margin:0;
    padding:0;
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content: flex-end;
}
.ul_machine_type li a{
    display:table;
    padding:10px 20px;
    font-size:14px;
    background:var(--site-red);
    color:#fff;
    border-radius:5px;
    transition:all 0.5s;
    line-height:1;
    margin-left:5px;
}
.ul_machine_type li a:hover{
    filter:brightness(1.1);
}
@media(min-width:768px){
    .single-machines-pgheader .page-header-ttl .p_maker{
        font-size:24px;
    }
    .single-machines-pgheader .page-header-ttl h1.model{
        font-size:40px;
    }
    .carousel-item img{
        aspect-ratio:4/3;
    }
    /* spec */
    .tbl-spec{
        border-bottom:solid 1px #ccc;
        margin-bottom:40px;
    }
    .tbl-spec tr{
        display: table-row;
        width:100%;
        margin-bottom:0;
    }
    .tbl-spec th{
        display: table-cell;
        width:30%;
        border:solid 1px #ccc;
        border-bottom:none;
    }
    .tbl-spec td{
        display: table-cell;
        width:70%;
        border-left:none;
        border-right:solid 1px #ccc;
        border-top:solid 1px #ccc;
        border-bottom:none;
    }
}
@media(min-width:992px){
    .single-machines-sec.page-section{
        padding-bottom:80px;
    }
    .pict-wrap{
        height:600px;
    }
    .pict-wrap{
        height:600px;
    }
    .org-carousel{
        display:flex;
        width:100%;
        flex-flow:row nowrap;
        height:100%;
    }
    .pict-left{
        display:inline-block;
        width:calc(75% - 10px);
        height:100%;
        margin-right:10px;
        margin-bottom:0;
    }
    .carousel-inner{
        height:100%;
    }
    .carousel-item{
        height:100%;
    }
    .carousel-item img{
        width:100%;
        height:100%;
        aspect-ratio:4/3;
        object-fit:cover;
        border:none;
    }
    .pict-right{
        display:inline-block;
        width:25%;
    }
    .pict-right .carousel-indicators [data-bs-target]{
        flex: 0 0 calc((100% - 12px) / 3);
    }
    .spec-wrap{
        padding:40px 20px;
        margin-bottom:80px;
    }
    .div_price .price .num{
        font-size:50px;
    }
    .div_price .price .currency{
        font-size:18px;
        padding:18px;
    }
    .tbl-spec{
        margin:0;
    }
    .dl-spec dt{
        width:50%;
        padding-right:10px;
    }
    .dl-spec dd{
        width:50%;
        padding-left:10px;
    }
    .cl_en_site .tbl-spec th{
        width:40%;
    }
    .cl_en_site .tbl-spec td{
        width:60%;
       
    }
}
@media(min-width:1200px){
    .pict-wrap{
        height:650px;
        margin-bottom:80px;
    }
    .pict-right .carousel-indicators [data-bs-target]{
        flex: 0 0 calc((100% - 12px) / 3);
    }
}
/*==========================================================*/
/* sales record archive 									*/
/*==========================================================*/
.archive-sales{
    background:#f0f0f0;
}
.sales-sec.page-section{
    padding:40px 0;
}
.ul_archive_sales .ul_machine_type{
    width:fit-content;
    position:absolute;
    top:0;
    left:0;
    z-index:10;
}
.ul_machine_type li p{
    width:auto;
    min-width:80px;
    height:30px;
    display:flex;
    align-items:center;
    justify-content:center;
    line-height:1;
    font-size:11px;
    background:var(--site-red);
    color:#fff;
    white-space:nowrap;
}
/*==========================================================*/
/* sales record single   									*/
/*==========================================================*/
.single-sales{
    background:#f0f0f0;
}
.single-sales-sec.page-section{
    padding:40px 0;
}
.single-sales-wrap{
    width:100%;
}
.single-sales-wrap h1{
    margin-bottom:40px;
    background:var(--site-blue);
    color:#fff;
    padding:10px;
    font-size:24px;
    font-weight:500;
    position:relative;
    margin:0;
}
.single-sales-wrap .wrap{
    padding:20px 10px;
    background:#fff;
}
.machine-sold_out{
    font-family:var(--russo);
    color:var(--soldout-font-color);
    font-size:32px;
}
@media(min-width:768px){
    .single-sales-wrap .wrap{
        padding:20px;
    }
}
/*==========================================================*/
/* company                 									*/
/*==========================================================*/
.page-company .section.breadSection{
    background:#f0f0f0;
}
.company-sec{
    position:relative;
}
.company-sec.page-section, .value-sec.page-section, .profile-sec.page-section{
    padding:80px 0;
    background:#f0f0f0;
}
.company-head{
    margin-bottom:80px;
}
.company-lead{
    text-align:justify;
    font-size:24px;
    font-weight:700;
    color:var(--site-blue);
    font-family:var(--noto-serif);
}
.cl_en_site .company-lead{
    text-align:left;
}
.company-lead br{
    display:none;
}
h2.toptitle{
    display:flex;
    font-size:24px;
    margin:0 auto 0 auto;
    color:var(--soldout-font-color);
    font-weight:700;
    white-space:nowrap;
    justify-content: center;
    padding:10px;
}
.company-mission-box{
    width:100%;
    margin-top:40px;
}
.company-mission-ttl{
    font-size:24px;
    margin-bottom:40px;
    display:flex;
    justify-content:center;
    font-weight:700;
    font-family:var(--noto-serif);
}
.company-mission-desc{
    line-height:2;
    text-align:justify;
}
.ul-basic{
    display:flex;
    flex-flow:row wrap;
    margin:0;
    padding:0;
    width:100%;
    list-style:none;
    gap:6px;
    justify-content: center;
    margin-top:40px;
}
.ul-basic>li{
    flex:0 0 calc((100% - 6px) / 2);
    background:#fff;
    border:solid 1px #aaa;
    padding:20px 5px;
    border-radius:5px;
}
.company-value-ttl{
    font-size:16px;
    font-weight:500;
    text-align:center;
    margin-bottom:20px;
    color:var(--site-red);
}
.ul-basic>li p{
    font-size:14px;
    line-height:2;
}
.dl-basic{
    width:100%;
    margin:0;
    margin-top:40px;
}
.company-profile-row{
    width:100%;
    margin-bottom:20px;
}
.dl-basic dt{
    width:100%;
    padding:1em;
    font-weight:500;
    background:var(--th-color);
    margin:0;
}
.dl-basic dd{
    padding:1em;
    background:#fff;
    margin:0;
}
.dl-basic .telnolink{
    position:relative;
}
.dl-basic .telnolink::before{
    content:'';
    width:100%;
    height:1px;
    border-radius:0;
    transition:transform 0.5s;
    transform:scale(0,1);
    transform-origin: right center;
    background:#000;
    position:absolute;
    left:0;
    bottom:0;
}
.dl-basic .telnolink:hover{
    opacity:0.8;
}
.dl-basic .telnolink:hover::before{
    transform:scale(1,1);
    transform-origin: left center;
}
.faxnolink{
    pointer-events:none;
}
/* fix btn */
.fixed-bk-sec.page-section{
    padding:0;
}
.fix-bk-frm{
    width:100%;
    height:200px;
    background:rgb(31, 46, 60, 0.4);
}
.fixed-bk-wrap{
    position:fixed;
    width:100%;
    height:100vh;
    top:0;
    left:0;
    z-index:-1;
    opacity:0;
    transition:all 0.5s;
}
.fixed-bk-wrap>img{
    width:100%;
    height:100%;
    object-fit:cover;
    filter:blur(1px), grayscale(50%);
}
.fixed-bk-sec.active .fixed-bk-wrap{
    opacity:1;
}
@media(min-width:768px){
    .company-lead{
        text-align:center;
        font-size:32px;
    }
    .company-lead br{
        display:block;
    }
    h2.toptitle{
        font-size:36px;
    }
    .company-mission-ttl{
        font-size:32px;
    }
    .company-mission-ttl br{
        display:none;
    }
    .ul-basic>li{
        flex:0 0 calc((100% - 12px) / 3);
        background:#fff;
        border:solid 1px #aaa;
        padding:20px 10px;
        border-radius:5px;
    }
    .company-value-ttl{
        font-size:18px;
    }
    .ul-basic>li p{
        font-size:16px;
        min-height:130px;
    }
    .company-profile-row{
        display:flex;
        flex-flow:row wrap;
        margin-bottom:0;
        border-top:solid 1px var(--bd-color);
    }
    .dl-basic dt{
        width:40%;
        padding:1em;
        font-weight:500;
        background:var(--th-color);
        border-bottom:solid 1px  var(--bd-color);
        border-left:solid 1px  var(--bd-color);
        border-right:solid 1px  var(--bd-color);
    }
    .dl-basic dd{
        width:60%;
        padding:1em;
        background:#fff;
        border-bottom:solid 1px  var(--bd-color);
        border-right:solid 1px  var(--bd-color);
    }
}
@media(min-width:992px){
    .ul-basic{
        gap:20px;
        max-width:920px;
        margin-left:auto;
        margin-right:auto;
    }
    .company-value-ttl{
        font-size:20px;
    }
    .ul-basic>li{
        flex:0 0 calc((100% - 40px) / 3);
        padding:40px;
    }
}
/*==========================================================*/
/* contact                 									*/
/*==========================================================*/
.page-contact{
    background:#f0f0f0;
}
.page-contact .bf-contact-sec{
    display:none;
}
.contact-sec{
    position:relative;
    padding:40px 0;
}
.contact-inner{
    width:100%;
}
.before-contact-wrap{
    width:100%;
    margin-bottom:40px;
}
.contact-wrap{
    width:100%;
}
.contact-wrap .inner{
    margin-bottom:40px;
}
.h2org{
    font-size:24px;
    margin-bottom:40px;
}
/* contact form */
.div-contactfm{
    width:100%;
    margin-bottom:20px;
}
.div-contactfm label{
    width:100%;
    font-weight:500;
    margin-bottom:10px;
    position:relative;
}
input[type='text'], input[type='email'], input[type='tel']{
    width:100%;
    height:60px;
    padding:5px;
    background-color:#fff;
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #ccc;
}
input[type='text']:focus, input[type='email']:focus, input[type='tel']:focus{
    outline:solid 1px var(--focus-color);
}
textarea{
    width:100%;
    padding:5px;
    background-color:#fff;    
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #ccc;
}
textarea:focus{
    outline:solid 1px var(--focus-color);
}
input[type='submit']{
    width:100%;
    max-width:460px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--submit-btn);
    color:#fff;
    border:none;
    margin:0 auto;
    transition:all 0.3s;
}
input[type='submit']:hover{
    filter:brightness(1.1);
}
input[type='submit']:disabled{
    filter:brightness(0.8);
}
input[type='submit']:hover:disabled{
    filter:brightness(0.8);
}
.pripol-btn{
    padding:10px 0;
}
.pripol-btn>div{
    margin-bottom:30px;
}
.pripol-btn a{
    text-decoration:underline;
    margin-right:5px;
    transition:0.5s;
    width:fit-content;
    position:relative;
}
.pripol-btn a:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--font-color);
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.pripol-btn a:hover:before{
    transform-origin: left top;
    transform: scale(1, 1);
}
.pripol-btn a:hover{
    text-decoration:none;
    opacity:0.8;
}
.pripol-btn .square{
    display:inline-block;
    position:relative;
    padding:10px;
}
.pripol-btn .square:before{
    content:'';
    width:13px;
    height:13px;
    border:solid 1px #555;
    border-radius:2px;
    background:#fff;
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.checkbox-pripol{
    display:flex;
    justify-content:center;
    align-items:center;
}
.checkbox-pripol label{
    display:flex;
    align-items:center;
}
input[name='acceptance-privacypolicy']{
    width:18px;
    height:18px;
    margin-right:10px;
}
.pripol-desc{
    display:flex;
    justify-content:center;
}
.p-desc .require{
    color:var(--require-color);
}
.require{
    font-weight:400;
    display:flex;
    width:50px;
    height:26px;
    justify-content:center;
    align-items:center;
    background:var(--require-color);
    color:#fff;
    font-size:12px;
    border-radius:13px;
    position:absolute;
    top:50%;
    right:0;
    transform:translateY(-50%);
}
.cl_en_site .require{
    width:80px;
}
@media(min-width:768px){
    .h2org{
        font-size:32px;
    }
}
/*==========================================================*/
/* privacy policy          									*/
/*==========================================================*/
.page-privacy-policy{
    background:#f0f0f0;
}
.pri_sec{
    position:relative;
}
.detail-wrap{
    margin-top:60px;
}
.detail-wrap .h2org{
    text-align:left;
    margin-bottom:30px;
}
.ul_pri{
    margin-top:20px;
    padding-left:20px;
    margin-bottom:0;
}
.ul_pri li{
    margin-top:10px;
    font-size:16px;
}
.detail-wrap a{
    color:var(--site-blue);
    font-weight:700;
    position:relative;
}
.detail-wrap a:hover{
    color:var(--site-blue);
}
.detail-wrap a::before{
    content:'';
    width:100%;
    height:1px;
    background:var(--site-blue);
    transform:scale(0, 1);
    transform-origin:right center;
    transition:transform 0.5s;
    position:absolute;
    bottom:0;
    left:0;
}
.detail-wrap a:hover:before{
    transform:scale(1, 1);
    transform-origin:left center;
}
@media(min-width:768px){
    .detail-wrap .h2org{
        font-size:24px;
    }
}
