/*!
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=Caveat:wght@400..700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Oswald:wght@200..700&display=swap');
/************************************************************/
:root{
    --logo-color1:#30365A;
    --logo-color2:#E1512E;
    --logo-color3:#F7F5F6;
    --font-thin-color:#000;
    --bk-grey-color:#f2f2f2;
    --bk-bk-thin-orange:#fff4e1;
    --bk-bk-thin-blue:#30365A;
    --bk-page-header-color:#30365A;
    --hd-gradient-color1:#30365A;
    --tbl-bd-color:#c0c0c0;
    --tab-bk-color:#e6eaee;
    --caveat:"Caveat", serif;
    --oswald:"Oswald", sans-serif;
    --yugoshic:"Noto Sans JP", "ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN","游ゴシック","Yu Gothic","ＭＳ ゴシック","ＭＳ ゴシック",serif;
    --yumincho:"Noto Serif JP","ヒラギノ明朝 ProN","Hiragino Mincho ProN","游明朝","Yu Mincho","ＭＳ 明朝","MS Mincho",serif;
    --business1-gradient-color:linear-gradient(45deg, #FFA500 20%, #FF5B0A);
    --business2-gradient-color:linear-gradient(45deg, #e8cd00 20%, #d4c237);
    --business3-gradient-color:linear-gradient(45deg, #4666FF 20%, #9F45FF);
    --business4-gradient-color:linear-gradient(45deg, #30d812 20%, #28af11);
}
/*==========================================================*/
/* defalt define											*/
/*==========================================================*/
body, p{
    font-size:17px;
    font-family:var(--yugoshic);
}
body a{
    color:#333;
    font-family:var(--yugoshic);
    text-decoration:none;
}
body a:hover{
    color:#333;
}
.nodata{
    color:#ff0000;
}
@media print {
    #mobile-menu {
        display: none !important;
    }
}
/*==========================================================*/
/* common       											*/
/*==========================================================*/
.page-section{
    padding:80px 0;
}
.front-page .page-section{
    padding:40px 0;
}
/*==========================================================*/
/* header       											*/
/*==========================================================*/
.home .site-header.ptnB{
    height:auto;
}
.site-header-wrap{
    position:fixed;
    top:0;
    left:0;
    z-index:1800;
    width:100%;
    height: var(--ptnB-sp-header-height);
    box-shadow:none;
}
.site-header-logo{
    width:100%;
    height:100%;
}
.site-header-logo a{
    display:block;
    width:100%;
    height:100%;
}
.site-header-logo a img{
    width:auto;
    height:100%;
}
.site-header-logo a:hover{
    filter:brightness(1.2);
}
/*==========================================================*/
/* mobile menu     											*/
/*==========================================================*/
.mobile-navi-btn.right{
    width: var(--ptnB-sp-header-height);
    height: var(--ptnB-sp-header-height);
    top:-20px;
    right:0;
    opacity:0;
    animation: fadeIn2 1500ms cubic-bezier(0.77, 0, 0.175, 1) 500ms forwards;
    position:fixed;
    background:transparent;
}
.mobile-navi-btn>span {
    position: absolute;
    background: #aaa;
    height: 2px;
    width: 30px;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: all .3s;
}
/* enable setting movie only
.front-page .mobile-navi-btn>span {
    background:#fff;
}
*/
.scrolled .mobile-navi-btn>span {
    background: #aaa;
}
.mobile-navi-btn span:first-of-type{
    top:30%;
}
.mobile-navi-btn span:nth-of-type(2) {
    top: 50%;
}
.mobile-navi-btn span:last-of-type {
    top: 70%;
}
.mobile-navi-btn.mobile-navi-open span:nth-child(1){
    top: 32%;
    left: calc(50% - 4px);
    transform: rotate(-45deg) translate(-50%, -50%);
}
.mobile-navi-btn.mobile-navi-open span:nth-of-type(2){
    opacity:0;
}
.mobile-navi-btn.mobile-navi-open span:last-of-type {
    top: 68%;
    left: calc(50% - 6px);
    transform: rotate(45deg) translate(-50%, -50%);
}
.mobile-menu-slide{
    left:auto;
    right:-100%;
    width:75%;
    transition: right 0.5s ease-in;
}
.mobile-menu-slide.mobile-menu-open{
    left:auto;
    right:0;
}
/*==========================================================*/
/* before footer   											*/
/*==========================================================*/
.site-beforefooter{
    padding:40px 0;
    background:var(--logo-color2);
}
.page-contact .site-beforefooter{
    display:none;
}
.site-beforefooter p{
    color:#fff;
}
.site-beforefooter .ctt_btn{
    margin-bottom:20px;
}
.bftel .tellink{
    font-size:36px;
    letter-spacing:1px;
    color:#fff;
    font-weight:700;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:all 0.5s;
}
.tellink i{
    font-size:75%;
    margin-right:5px;
}
.bftel .tellink:hover{
    color:var(--bk-bk-thin-blue);
}
.ctt_btn>a{
    padding:15px 20px;
    border-radius:3px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:#fff;
    color:var(--logo-color1);;
    font-weight:600;
    letter-spacing:1px;
    font-size:20px;
    transition:all 0.5s;
}
.ctt_btn i{
    font-size:110%;
    margin-right:5px;
}
.ctt_btn>a:hover{
    background:var(--bk-bk-thin-blue);
    color:#fff;
}
@media(min-width:768px){
    /* beforefooter */
    .beforefooter_widget{
        display:flex;
        flex-wrap:wrap;
        align-items:center;
        justify-content:center;
    }
    .site-beforefooter p{
        width:100%;
        text-align:center;
    }
    .site-beforefooter .ctt_btn{
        width:350px;
        margin:0 2rem 0 0;
    }
    .bftel .tellink{
        pointer-events:none;
    }
}
@media(min-width:992px){
    .site-beforefooter .ctt_btn{
        max-width:420px;
        width:420px;
    }
}
/*==========================================================*/
/* footer       											*/
/*==========================================================*/
.site-footer{
    padding-bottom:100px;
}
.footer_widget{
    display:block;
    width:100%;
    margin-bottom:40px;
}
.ft-logo-sec{
    width:100%;
}
.ft-logo-wrap{
    width:100%;
}
.ft-logo-wrap a{
    display:table;
    max-width:200px;
    margin:0 auto;
    transition:all 0.5s;
}
.ft-logo-wrap a:hover{
    opacity:0.8;
}
.footerwidget ul>li a{
    font-size:15px;
    font-weight:400;
    letter-spacing:2px;
    position: relative;
    padding-left: 20px;
    transition: all 0.5s;
}
.footerwidget ul>li a:before{
    content: "\f105";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: var(--fa-display, inline-block);
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    transition: all 0.5s;
}
.footerwidget ul>li a:after{
    content:'';
    width:0;
    height:1px;
    background:#fff;
    position:absolute;
    bottom:0;
    left:20px;
    transition: all 0.5s;
}
.footerwidget ul>li a:hover:before{
    left:5px;
}
.footerwidget ul>li a:hover:after{
    width:calc(100% - 20px);
}
.last-ft-wrap a{
    color:#fff;
    display:table;
    margin:0 auto;
    position:relative;
    margin-bottom:10px;
    transition:all 0.5s;
    font-size:15px;
    font-weight:400;
}
.last-ft-wrap a:before{
    content:'';
    width:0;
    height:1px;
    background:#fff;
    position:absolute;
    bottom:0;
    left:0;
    transition:all 0.5s;
}
.last-ft-wrap a:hover{
    color:#fff;
}
.last-ft-wrap a:hover:before{
    width:100%;
}
.copyright{
    font-weight:400;
}
@media(min-width:768px){
    .footerwidget{
        margin-bottom:40px;
    }
    .footer_widget{
        display:inline-block;
        width:50%;
        margin-bottom:0;
    }
    .ft-logo-wrap a{
        display:table;
        max-width:200px;
        margin:0 auto 0 0;
    }
    #menu-footermenu{
        margin-bottom:0;
    }
}
@media(min-width:992px){
    .footerwidget .footer_widget:first-of-type{
        width:300px;
    }
    .footerwidget .footer_widget:last-of-type{
        width:calc(100% - 300px);
        display:flex;
        align-items:center;
    }
    .menu-footermenu-container{
        width:100%;
    }
    #menu-footermenu{
        display:flex;
        flex-flow:row wrap;
        width:100%;
        padding:0;
    }
    #menu-footermenu>li{
        display:inline-block;
        width:calc(100% / 5);
    }
    .last-ft-wrap{
        display:flex;
        flex-flow:row nowrap;
        align-items:center;
        justify-content:flex-end;
    }
    .last-ft-wrap a{
        margin:0;
        margin-right:20px;
    }
}
/*==========================================================*/
/* global menu     											*/
/*==========================================================*/
.ptnB .site-header-menu>li{
    margin-left:10px;
}
.site-header-menu>li>a{
    font-size:15px;
    font-weight:500;
    letter-spacing:2px;
}
/*==========================================================*/
/* fade-in scroll-in           								*/
/*==========================================================*/
.fade-in{
    opacity:0;
    transition:all 1s ease;
}
.fade-in.scroll-in{
    opacity:1;
}
/*==========================================================*/
/* topslide       											*/
/*==========================================================*/
.home.front-page{
    background:var(--bk-grey-color);
}
/*==========================================================*/
/* topslide       											*/
/*==========================================================*/
.topslide-sec{
    position:relative;
    height:100vh;
    padding:0;
    margin-bottom:80vh;
}
.topslide-wrap{
    width:100%;
    height:100%;
    position:relative;
}
.toplogo{
    position:fixed;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
}
.toplogo h1{
    opacity:0;
    animation: fadeIn 1000ms cubic-bezier(0.77, 0, 0.175, 1) 500ms forwards;
    animation-delay: 0.5s;
    margin-bottom:40px;
}
.toplogo h1 img{
    display:table;
    width: min(60vw, 730px);
    margin-left:auto;
    margin-right:auto;
}
.toplogo h1 .en_name{
    font-weight:400;
    font-size:min(4.0vw, 32px);
    text-align:center;
    display:block;
    font-style:italic;
    color:var(--logo-color1);
}
.catch-wrap{
    position:relative;
    overflow:hidden;
}
.catch-wrap:before{
    content:'';
    width:0;
    height:100%;
    background:var(--logo-color1);
    position:absolute;
    top:0;
    left:0;
    transition:all 1s;
    animation: showAnime 3000ms cubic-bezier(0.77, 0, 0.175, 1) 500ms forwards;
    animation-delay: 1s;
    z-index:5;
}
.catch-wrap:after{
    content:'';
    width:0;
    height:100%;
    background:var(--logo-color2);
    position:absolute;
    top:0;
    left:0;
    transition:all 1s;
    animation: showAnime2 3000ms cubic-bezier(0.77, 0, 0.175, 1) 1000ms forwards;
    animation-delay: 1s;
    z-index:5;
}
.toplogo .jp_catch{
    font-weight:900;
    text-align:center;
    color:var(--logo-color1);
    font-family:var(--yumincho);
    opacity:0;
    animation: fadeIn 100ms cubic-bezier(0.77, 0, 0.175, 1) 2000ms forwards;
    font-size: min(4.9vw, 44px);
    line-height:1.4;
}
.toplogo .jp_catch span{
    color:var(--logo-color2);
}
.toplogo .en_catch{
    white-space:nowrap;
    font-style:italic;
    color:var(--font-thin-color);
    opacity:0;
    animation: fadeIn 100ms cubic-bezier(0.77, 0, 0.175, 1) 2000ms forwards;
    text-align:center;
    font-size: min(4.9vw, 44px);
    font-family:var(--yugoshic);
    line-height:1.4;
}
@keyframes showAnime {
    0% {
        width: 0;
    }
    30% {
        width:100%;
    }
    60%{
        width:100%;
        left:0;
    }
    80%{
        left:100%;
    }
    100%{
        width:100%;
        left:100%;
    }
}
@keyframes showAnime2 {
    0% {
        width: 0;
    }
    40% {
        width:100%;
    }
    50%{
        width:100%;
        left:0;
    }
    70%{
        left:100%;
    }
    100%{
        width:100%;
        left:100%;
    }
}
@keyframes fadeIn {
    0% {
      opacity: 0;
    }
    50% {
      opacity: 0;
    }
    100%{
        opacity: 1;
    }
}
@keyframes fadeIn2 {
    0% {
      opacity: 0;
      top:-20px;
    }
    30% {
      opacity: 0;
      top:-20px;
    }
    100%{
        opacity: 1;
        top:0;
    }
}
@media(min-width:768px){
    .topslide-sec{
        margin-bottom:60vh;
    }
}
/*==========================================================*/
/* topconcept      											*/
/*==========================================================*/
.front-page .topconcept-sec{
    padding:0;
    padding-bottom:40px;
}
.topconcept-sec{
    background:var(--bk-grey-color);
}
.topslide-bk{
    width:100%;
    padding-top:70%;
    position:relative;
}
.topslide-bk video{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.topconcept-wrap{
    display:flex;
    width:100%;
    justify-content: center;
    align-items: center;
    position:absolute;
    left:0;
    top:50%;
    transform:translateY(-50%);
    z-index:2;
}
.sub_phrase{
    display:flex;
    width:100%;
    justify-content:center;
    align-items:center;
}
.sub_phrase p{
    font-size:16px;
    font-weight:500;
    color:#fff;
}
@media(min-width:768px){
    .sub_phrase p{
        font-size:32px;
    }
    .topslide-bk{
        padding-top:56.25%;
    }
}
/*==========================================================*/
/* topstrength-sec 											*/
/*==========================================================*/
.topstrength-sec{
    position:relative;
    padding-bottom:80px;
}
.hd-style{
    width:100%;
    margin-bottom:30px;
}
.hd-style h2{
    font-size:20px;
    color:var(--logo-color2);
    margin-bottom:8px;
}
.hd-style h2{
    font-size:20px;
    color:var(--logo-color2);
}
.hd-style p{
    font-weight:600;
    font-size:24px;
}
.topstrength-wrap{
    width:100%;
}
.dl-topstrength{
    width:100%;
    margin-bottom:20px;
    display:block;
}
.dl-topstrength>dt{
    margin:0;
    display:block;
    width:100%;
}
.dl-topstrength>dd{
    margin:0;
    display:block;
    width:100%;
}
.dl-topstrength img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
    object-position:center center;
}
.hd-btn{
    position:relative;
}
.circlebtn-link{
    display:flex;
    flex-flow:row nowrap;
    align-items:center;
    font-weight:500;
    justify-content:flex-end;
    transition:all 0.5s;
}
.circlebtn-link .circle{
    display:inline-block;
    width:80px;
    height:80px;
    border-radius:50%;
    background:linear-gradient(45deg,
        red 16%, 
        orange 32%, 
        yellow 48%, 
        green 64%, 
        blue 80%, 
        indigo 90%, 
        violet 100%);
    position:relative;
    margin-left:20px;
    transition:all 0.5s;
}
.circlebtn-link .circle:before{
    content:'';
    width:78px;
    height:78px;
    border-radius:50%;
    background:var(--bk-grey-color);
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    z-index:1;
    transition:all 0.5s;
}
.circlebtn-link .circle span{
    display:inline-block;
    position:absolute;
    z-index:5;
    width:39px;
    height:1px;
    background:var(--logo-color1);
    top:50%;
    left:20.5px;
    transform:translateY(-50%);
    transition:all 0.5s;
}
.circlebtn-link .circle span:before{
    content:'';
    width:10px;
    height:1px;
    background:var(--logo-color1);
    transform-origin:bottom right;
    transform:rotate(45deg);
    position:absolute;
    top:0;
    right:0;
    transition:all 0.5s;
}
.circlebtn-link:hover .circle{
    background:#000;
}
.circlebtn-link:hover .circle span{
    left:30.5px;
}
@media(min-width:768px){
    .dl-topstrength{
        margin-bottom:20px;
        display:flex;
        flex-flow:row nowrap;
    }
    .dl-topstrength>dt{
        display:inline-block;
        width:50%;
    }
    .dl-topstrength>dd{
        display:inline-block;
        width:50%;
    }
    .dl-topstrength img{
        width:100%;
        aspect-ratio:1/1;
        object-fit:cover;
        object-position:center center;
    }
    .hd-style p{
        font-size:32px;
    }
}
@media(min-width:992px){
    .tbbr{
        display:none;
    }
    .topstrength-sec{
        padding-bottom:0;
    }
    .dl-topstrength{
        margin-bottom:0;
    }
    .dl-topstrength img{
        aspect-ratio:4/3;
    }
    .topstrength-sec .hd-btn{
        position:absolute;
        top:60px;
        right:calc((100% - 960px) / 2);
    }

}
@media(min-width:1200px){
    .dl-topstrength img{
        aspect-ratio:5/3;
    }
    .topstrength-sec .hd-btn{
        right:calc((100% - 1140px) / 2);
    }
}
@media(min-width:1400px){
    .dl-topstrength img{
        aspect-ratio:2/1;
    }
    .topstrength-sec .hd-btn{
        right:calc((100% - 1320px) / 2);
    }
}
/*==========================================================*/
/* topstrength-sec 											*/
/*==========================================================*/
.topservice-sec{
    display:block;
    position:relative;
    background:#fff;
}
.front-page .topservice-sec{
    padding:0;
}
.topservice-frm{
    width:100%;
    padding-top:100%;
    position:relative;
    z-index:10;
}
.topservice-frm .contains-frm{
    position:absolute;
    left:0;
    top:50%;
    transform:translateY(-50%);
}
.topservice-sec .circlebtn-link .circle:before{
    background:#fff;
}
.mv-wrap{
    width:100%;
    padding-top:56.25%;
    position:relative;
}
.mv-wrap video{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    object-fit:cover;
    object-position:center center;
}
/**/
.circlebtn-link2{
    display:flex;
    flex-flow:row nowrap;
    align-items:center;
    font-weight:500;
    justify-content:flex-end;
    transition:all 0.5s;
}
.circlebtn-link2 .circle{
    display:inline-block;
    width:80px;
    height:80px;
    border-radius:50%;
    background:linear-gradient(45deg,
    red 16%, 
    orange 32%, 
    yellow 48%, 
    green 64%, 
    blue 80%, 
    indigo 90%, 
    violet 100%);
    position:relative;
    margin-left:20px;
    transition:all 0.5s;
}
.circlebtn-link2 .circle:before{
    content:'';
    width:78px;
    height:78px;
    border-radius:50%;
    background:#fff;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    z-index:1;
    transition:all 0.5s;
}
.circlebtn-link2 .circle span{
    display:inline-block;
    position:absolute;
    z-index:5;
    width:39px;
    height:1px;
    background:var(--logo-color1);
    top:50%;
    left:20.5px;
    transform:translateY(-50%);
    transition:all 0.5s;
}
.circlebtn-link2 .circle span:before{
    content:'';
    width:10px;
    height:1px;
    background:var(--logo-color1);
    transform-origin:bottom right;
    transform:rotate(45deg);
    position:absolute;
    top:0;
    right:0;
    transition:all 0.5s;
}
.topservice-sec:hover .circlebtn-link2 .circle span{
    left:30.5px;
}
@media(min-width:768px){
    .topservice-frm .contains-frm{
        left:calc((100% - 720px) / 2);
    }
    .topservice-frm{
        padding-top:56.25%;
    }
   .mv-wrap{
        width:100%;
        padding-top:56.25%;
        position:absolute;
        top:0;
        left:0;
        z-index:1;
    }
    .mv-wrap:before{
        content:'';
        width:100%;
        height:100%;
        background:rgba(0,0,0,0.2);
        position:absolute;
        top:0;
        left:0;
        z-index:2;
    }
    .mv-wrap:after{
        content:'';
        width:100%;
        height:100%;
        background:#fff;
        position:absolute;
        top:0;
        left:0;
        z-index:3;
        transition:all 1s;
    }
    .topservice-sec:hover .mv-wrap:after{
        background:transparent;
    }
    .topservice-sec:hover .hd-style h2{
        color:#fff;
    }
    .topservice-sec:hover .hd-style p{
        color:#fff;
    }
    /**/
    .circlebtn-link2 .circle{
        border:solid 1px #000;
        background:transparent;
    }
    .circlebtn-link2 .circle:before{
        content:none;
    }
    .topservice-sec:hover .circlebtn-link2{
        color:#fff;
    }
    .topservice-sec:hover .circlebtn-link2 .circle{
        border:solid 1px #fff;
    }
    .topservice-sec:hover .circlebtn-link2 .circle span{
        background:#fff;
        left:30.5px;
    }
    .topservice-sec:hover .circlebtn-link2 .circle span:before{
        background:#fff;
    }
}
@media(min-width:992px){
    .topservice-frm .contains-frm{
        left:calc((100% - 960px) / 2);
    }
}
@media(min-width:1200px){
    .topservice-frm .contains-frm{
        left:calc((100% - 1140px) / 2);
    }
}
@media(min-width:1400px){
    .topservice-frm .contains-frm{
        left:calc((100% - 1320px) / 2);
    }
}
/*==========================================================*/
/* topcompany-sec 											*/
/*==========================================================*/
.topcompany-sec{
    position:relative;
}
.dl-topcompany{
    width:100%;
}
.dl-topcompany>dt{
    width:100%;
}
.dl-topcompany>dt{
    width:100%;
}
.slide-wrap{
    width:100%;
}
.ul-topcompany{
    padding:0;
    margin:0;
}
.ul-topcompany li.slick-slide{
    width:100%;
    padding:0 5px;
}
.ul-topcompany li.slick-slide figure{
    padding-top:60%;
}
.slick-dots li button:before{
    font-size:12px;
}
@media(min-width:992px){
    .topcompany-sec{
        padding-top:80px;
    }
    .ul-topcompany li.slick-slide figure{
        padding-top:56.25%;
    }
    .ul-topcompany{
        width:70%;
        margin-right:0;
        margin-left:auto;
    }
}
/*==========================================================*/
/* company-sec   											*/
/*==========================================================*/
/* original page header */
.org-pgheader{
    position:relative;
    height:300px;
    background:var(--bk-page-header-color);
    padding:0;
}
.org-pgheader .contains-frm{
    height:100%;
}
.org-pgheader .contains-wrap{
    height:100%;
    display:flex;
    align-items:center;
}
.org-pgheader-wrap{
    width:100%;
}
.h1org{
    font-size:42px;
    font-weight:400;
    transform:scalex(1.2);
    transform-origin: left center;
    margin-bottom:40px;
    color:#fff;
}
.h1org small{
    display:block;
    font-size:16px;
    transform-origin: left center;
    transform: scalex(0.9);
}
.ul-pghead-menu{
    display:flex;
    list-style:none;
    width:100%;
    margin:0;
    padding:0;
    justify-content:space-between;
    flex-flow:row wrap;
}
.ul-pghead-menu>li{
    display:inline-block;
    width:48%;
    margin-bottom:15px;
}
.ul-pghead-menu>li:nth-of-type(5){
    width:100%;
}
.ul-pghead-menu>li a{
    display:inline-block;
    width:100%;
    padding-top:15px;
    padding-bottom:15px;
    position:relative;
    border-bottom:solid 1px #fff;
    line-height:1.2;
    color:#fff;
}
.ul-pghead-menu>li a i, .ul-pghead-menu>li a svg{
    position:absolute;
    top:50%;
    right:0;
    transform:translateY(-50%);
    color:#fff;
}
.dl-company{
    display:block;
    margin:0;
    width:100%;
}
.dl-company>dt{
    display:block;
    margin:0 0 50px 0;
    width:100%;
}
.dl-company>dd{
    display:block;
    margin:0;
    width:100%;
}
.dl-company>dd .message p{
    margin-bottom:10px;
}
.rep-wrap{
    width:100%;
    margin-top:40px;
    display:flex;
    justify-content: flex-end;
}
.rep-wrap p{
    font-family:var(--yumincho);
    font-weight:700;
    font-size:18px;
}
.rep-wrap p span:first-of-type{
    margin-right:10px;
}
.h2page{
    font-weight:500;
    transform:scalex(1.1);
    transform-origin: left center;
    font-size:28px;
    margin-bottom:1em;
    color:var(--logo-color2);
}
.p_page{
    font-weight:500;
    color:var(--logo-color1);
}
.dl-company>dd p{
    line-height:2;
    text-align:justify;
}
.tbl-company{
    width:100%;
    border-bottom:solid 1px var(--tbl-bd-color);
}
.tbl-company tr{
    display:block;
    width:100%;
    margin-bottom:20px;
    border-top:solid 1px var(--tbl-bd-color);
    padding-top:10px;
    padding-left:10px;
}
.tbl-company th{
    display:block;
    width:100%;
    padding:0.5em 0.5em 0.5em 20px;
    position:relative;
}
.tbl-company th:before{
    content:'■';
    display:inline-block;
    position:absolute;
    top:50%;
    left:0;
    transform:translateY(-50%);
}
.tbl-company td{
    display:block;
    width:100%;
}
.tbl-company td ul{
    padding-left:20px;
    margin-bottom:0;
}
.dl-company>dd p.address{
    line-height:1.6;
    margin-bottom:10px;
}
.tbl-company td dl{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    margin-bottom:0;
    max-width:300px;
}
.tbl-company td dl dt{
    display:inline-block;
    width:50%;
    font-weight:400;
    margin-bottom:4px;
}
.tbl-company td dl dd{
    display:inline-block;
    width:50%;
    margin-bottom:4px;
}
.map{
    width:100%;
    padding-top:100%;
    position:relative;
    overflow:hidden;
}
.map iframe{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
}
.map iframe.sp_iframe{
    display:block;
}
.map iframe.pc_iframe{
    display:none;
}
@media(min-width:768px){
    .org-pgheader-wrap{
        width:100%;
        display:flex;
        flex-flow:row nowrap;
    }
    .org-pgheader-wrap .h1org{
        width:50%;
        font-size:50px;
        margin-bottom:0;
    }
    .org-pgheader-wrap .ul-pghead-menu{
        width:50%;
    }
    .tbl-company tr{
        display: table-row;
        width:100%;
        margin-bottom:0;
    }
    .tbl-company th{
        display: table-cell;
        padding:20px 10px;
        position:relative;
        width:150px;
        font-weight:400;
        vertical-align:top;
    }
    .tbl-company th:before{
        content:none;
    }
    .tbl-company td{
        display: table-cell;
        padding:20px 10px;
        width:calc(100% - 150px);
    }
    .zipbr{
        display:none;
    }
    .map{
        width:100%;
        padding-top:500px;
    }
    .map iframe.sp_iframe{
        display:none;
    }
    .map iframe.pc_iframe{
        display:block;
    }
}
@media(min-width:992px){
    .dl-company{
        display:flex;
        flex-flow:row nowrap;
        margin-bottom:50px;
    }
    .dl-company>dt{
        display:inline-block;
        margin:0;
        width:250px;
    }
    .dl-company>dd{
        display:inline-block;
        width:calc(100% - 250px);
    }
}
/*==========================================================*/
/* about us        											*/
/*==========================================================*/
/* philosophy */
.philosophy h3{
    font-size:32px;
    font-weight:700;
    margin-bottom:20px;
    line-height:2;
}
.philosophy h4{
    font-size:24px;
    font-style:italic;
    line-height:2;
}
.philosophy .desc{
    margin-top:40px;
}
/* mission */
#mission{
    background:var(--bk-bk-thin-orange);
}
.mission h3{
    font-size:32px;
    font-weight:700;
    margin-bottom:20px;
}
.mission .desc{
    margin-top:40px;
}
/* our strength */
.strength h3{
    font-size:32px;
    font-weight:700;
    margin-bottom:20px;
    letter-spacing:-2px;
}
.strength .desc{
    margin-top:40px;
}
@media(min-width:768px){
    .philosophy h3{
        font-size:50px;
    }
    .philosophy h4{
        font-size:32px;
    }
    .mission h3{
        font-size:50px;
    }
    .strength h3{
        font-size:50px;
    }
}
/*==========================================================*/
/* service       											*/
/*==========================================================*/
#service01, #service02, #service03, #service04, #service05{
    padding:40px 0;
}
.org-pgheader-sv{
    padding:0;
}
.h1org{
    margin-bottom:20px;
}
.page-service .h2page{
    font-family:var(--caveat);
    transform:rotate(-5deg);
    margin-bottom:0;
}
.page-service .h2page .num{
    font-size:1.5em;
}
.page-service .p_page{
    font-size:24px;
    color:var(--logo-color1);
    font-family:var(--yumincho);
    font-weight:700;
}
.org-pgheader-sv-wrap{
    position:relative;
    z-index:5;
}
.page-service .mv-wrap{
    margin-top:20px;
}
.dl-service{
    margin:0;
    display:block;
    width:100%;
}
.dl-service>dt{
    margin:0;
    display:block;
    width:100%;
}
.dl-service>dd{
    margin:0;
    display:block;
    width:100%;
}
.dl-service>dt .pict{
    width:100%;
}
.dl-service>dt .pict>img{
    width:100%;
    aspect-ratio:7/4;
    object-fit:cover;
    object-position:center center;
}
.dl-service>dd .desc{
    padding:10px;
}
.company-sec.even{
    background:var(--bk-bk-thin-orange);
}
/* tabpage-sec */
.tabpage-sec{
    position:relative;
}
.tabpage-wrap{
    width:100%;
}
.ul-tabpage-hd{
    margin:0;
    padding:0;
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    list-style:none;
    justify-content:center;
}
.ul-tabpage-hd>li{
    display:block;
    padding-top:10px;
}
.arrow-mark{
    color:#888;
    font-family:var(--oswald);
}
.tb-name{
    display:none;
    font-family:var(--yumincho);
    font-weight:700;
    font-size:18px;
    letter-spacing: 1px;
    color:#888;
}
.tab-btn{
    width:70px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background: var(--tab-bk-color);
    box-shadow: 8px 10px 20px rgba(0, 0, 0, 0.21), -6px 0 10px #ffffff, -6px -5px 15px #ffffff;
    border: solid #ffffff;
    border-width: 1px 0 0 1px;
    border-radius: 5px 5px 0 0;
    z-index:0;
    position:relative;
    cursor: pointer;
    transition:box-shadow 0.5s;
}
.tab-btn:hover{
    box-shadow: 4px 5px 20px rgba(0, 0, 0, 0.21), -3px 0 5px #ffffff, -3px -2.5px 7px #ffffff;
}
.after-active .tab-btn{
    padding-right:20px;
}
.before-active .tab-btn{
    padding-left:20px;
}
.ul-tabpage-hd>li:first-of-type .tab-btn{
    z-index:4;
 
}
.ul-tabpage-hd>li:nth-of-type(2) .tab-btn{
   z-index:3;
    
}
.ul-tabpage-hd>li:nth-of-type(3) .tab-btn{
   z-index:2;
    
}
.ul-tabpage-hd>li:last-of-type .tab-btn{
   z-index:1;
}
.ul-tabpage-hd>li.before-active:first-of-type .tab-btn{
    z-index:1;
 
}
.ul-tabpage-hd>li.before-active:nth-of-type(2) .tab-btn{
   z-index:2;
    
}
.ul-tabpage-hd>li.before-active:nth-of-type(3) .tab-btn{
   z-index:3;
    
}
.ul-tabpage-hd>li.before-active:last-of-type .tab-btn{
   z-index:4;
}
.ul-tabpage-hd>li.active{
    padding-top:0;
}
.ul-tabpage-hd>li.active .tab-btn{
    padding-bottom:5px;
    z-index:5;
    opacity:1;
    overflow:hidden;
    width:80px;
    height:70px;
    box-shadow: 8px 10px 20px rgba(0, 0, 0, 0.21), -6px 0 10px #ffffff, -6px -5px 15px #ffffff;
    padding:0;
    cursor:unset;
    pointer-events:none;
    font-weight:900;
}
/* arrow mark */
.ul-tabpage-hd>li:first-of-type.active .tab-btn .arrow-mark{
    background:var(--business1-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:1.5em;
}
.ul-tabpage-hd>li:nth-of-type(2).active .tab-btn .arrow-mark{
    background:var(--business2-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:1.5em;
}
.ul-tabpage-hd>li:nth-of-type(3).active .tab-btn .arrow-mark{
    background:var(--business3-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:1.5em;
}
.ul-tabpage-hd>li:last-of-type.active .tab-btn .arrow-mark{
    background:var(--business4-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:1.5em;
}
/* tab-name */
.ul-tabpage-hd>li:first-of-type.active .tab-btn .tb-name{
    background:var(--business1-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:24px;
    font-weight:900;
}
.ul-tabpage-hd>li:nth-of-type(2).active .tab-btn .tb-name{
    background:var(--business2-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:24px;
    font-weight:900;
}
.ul-tabpage-hd>li:nth-of-type(3).active .tab-btn .tb-name{
    background:var(--business3-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:24px;
    font-weight:900;
}
.ul-tabpage-hd>li:last-of-type.active .tab-btn .tb-name{
    background:var(--business4-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
    font-size:24px;
    font-weight:900;
}
.business-wrap{
    width:100%;
    background:var(--tab-bk-color);
    position:relative;
    z-index:10;
    display:none;
    border-radius: 10px;
    padding-top:20px;
    padding-bottom:20px;
}
.business-wrap.active{
    display:block;
}
.h2org{
    font-family:var(--yumincho);
    font-weight:900;
    margin:0;
    width:100%;
    padding:10px 0;
    margin:0 0 10px 0;
}
.h2org strong{
    font-size:32px;
    display:block;
    margin-bottom:4px;
}
.h2org span{
    font-size:20px;
    display:block;
    color:#000;
}
#bz01 .h2org strong{
    background:var(--business1-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
}
#bz02 .h2org strong{
    background:var(--business2-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
}
#bz03 .h2org strong{
    background:var(--business3-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
}
#bz04 .h2org strong{
    background:var(--business4-gradient-color);
    color:transparent;
    -webkit-background-clip: text;
    background-clip:text;
}
.business-wrap .inner{
    width:100%;
}
.business-wrap .inner p{
    line-height:2;
}
.dl-biz{
    width:100%;
    margin-top:40px;
    display:flex;
    flex-flow:row wrap;
}
.dl-biz>dt{
    width:100%;
    display:block;
    margin-bottom:40px;
}
.dl-biz>dd{
    width:100%;
    display:block;
    margin-bottom:0;
}
.dl-biz>dd .desc h3{
    margin-top:40px;
    font-size:20px;
    color:var(--logo-color1);
    margin-bottom:10px;
    font-size:24px;
    font-weight:700;
}
.dl-biz>dd .desc .add-pict{
    margin-top:40px;
    overflow:hidden;
    border-radius:10px;
}
.ul-merit{
    padding-left:20px;
}
.ul-merit>li{
    font-size:17px;

}
.biz-wrap{
    width:100%;
    margin-top:40px;
}
.biz-wrap h3{
    font-size:24px;
    margin-bottom:20px;
    color:var(--logo-color1);
    font-weight:700;
}
.h2srv{
    font-size:24px;
    margin-bottom:60px;
    font-weight:900;
}
@media(min-width:768px){
    .page-service .p_page{
        font-size:32px;
    }
    .org-pgheader-sv{
        height:300px;
    }
    .org-pgheader-sv .contains-frm{
        height:100%;
    }
    .org-pgheader-sv .contains-wrap{
        display:flex;
        height:100%;
        align-items:center;
    }
    .page-service .org-pgheader{
        padding-top:100px;
        padding-bottom:none;
    }
    .page-service .h1org{
        color:#fff;
    }
    .pghd_p{
        color:#fff;
    }
    .page-service .mv-wrap{
        margin-top:0;
        padding-top:300px;
        pointer-events: auto;
        transition:all 0.5s;
    }
    .page-service .mv-wrap:after{
        content:none;
    }
    .page-service .mv-wrap:hover .mv-wrap:after{
        content:none;

    }
    /* tabpage-sec */
    .arrow-mark{
        display:none;
    }
    .tb-name{
        display:block;
    }
    .tab-btn{
        width:180px;
        height:80px;
    }
    .ul-tabpage-hd>li.active .tab-btn{
        width:180px;
        height:90px;
    }
    .business-wrap{
        padding-top:40px;
        padding-bottom:40px;
    }
    .h2org{
        display:flex;
        align-items:center;
        margin-bottom:30px;
    }
    .h2org strong{
        font-size:40px;
        display:inline-block;
        margin-bottom:0;
        margin-right:20px;
    }
    .h2org span{
        font-size:24px;
        display:inline-block;
    }
    /* add */
    .h2srv{
        text-align:center;
        font-size:32px;
    }
}
@media(min-width:992px){
    .org-pgheader-sv{
        height:500px;
    }
    .page-service .mv-wrap{
        height:500px;
    }
    .page-service .h1org{
        font-size:80px;
    }
    .pghd_p{
        font-size:24px;
    }
    .page-service .dl-company{
        display:block;
        width:100%;
    }
    .page-service .dl-company>dt{
        display:block;
        width:100%;
        margin-bottom:40px;
    }
    .page-service .dl-company>dd{
        display:block;
        width:100%;
    }
    .page-service .even .dl-company>dt{
        display:flex;
        justify-content: flex-end;
    }
    .dl-service{
        display:flex;
        flex-flow:row nowrap;
    }
    .dl-service>dt{
        width:50%;
        display:inline-block;
    }
    .dl-service>dd{
        width:50%;
        display:flex;
        align-items:center;
    }
    .dl-service>dt .pict{
        width:110%;
    }
    .dl-service>dt .pict>img{
        aspect-ratio:5/3;
    }
    .dl-service>dd .desc{
        padding:10px;
        background:rgba(255,255,255,0.9);
        box-shadow:0 0 5px rgb(0,0,0,0.1);
        position:relative;
        z-index:1;
    }
    .even .dl-service dt{
        order:2;
    }
    .even .dl-service dt .pict{
        position:relative;
        top:0;
        right:10%;
    }
    .even .dl-service dd{
        order:1;
    }
    /* tab function */
    .business-wrap{
        padding-top:80px;
        padding-bottom:80px;
    }
    .tab-btn{
        width:230px;
    }
    .ul-tabpage-hd>li.active .tab-btn{
        width:230px;
    }
    .tb-name{
        font-size:22px;
    }
    .dl-biz{
        justify-content: space-between;
        margin-top:80px;
    }
    .dl-biz>dt{
        width:38%;
        display:inline-block;
        margin-bottom:0;
        order:2;
    }
    .dl-biz>dd{
        width:58%;
        display:inline-block;
        margin-bottom:0;
    }
    .dl-biz>dt .pict{
        width:100%;
        border-radius:10px;
        overflow:hidden;
    }
    .dl-biz>dt .pict img{
        width:100%;
        aspect-ratio:1/1;
        object-fit:cover;
    }
    /* tab-name */
    .ul-tabpage-hd>li:first-of-type.active .tab-btn .tb-name{
        font-size:34px;
    }
    .ul-tabpage-hd>li:nth-of-type(2).active .tab-btn .tb-name{
        font-size:34px;
    }
    .ul-tabpage-hd>li:nth-of-type(3).active .tab-btn .tb-name{
        font-size:34px;
    }
    .ul-tabpage-hd>li:last-of-type.active .tab-btn .tb-name{
        font-size:34px;
    }

}
@media(min-width:1200px){
    .org-pgheader-sv{
        height:600px;
    }
    .page-service .mv-wrap{
        height:600px;
    }
    .page-service .h1org{
        font-size:80px;
    }
    /* tab function */
    .business-wrap{
        padding-top:80px;
        padding-bottom:80px;
    }
    .dl-biz>dt .pict img{
        aspect-ratio:4/3;
    }
    .tab-btn{
        width:260px;
    }
    .ul-tabpage-hd>li.active .tab-btn{
        width:260px;
    }
    .tb-name{
        font-size:24px;
    }
}
/*==========================================================*/
/* contact       											*/
/*==========================================================*/
.page-privacy-policy .h1org{
    transform:unset;
}
.org-pghead-contact p{
    color:#fff;
}
.org-pghead-contact p .telnolink{
    color:#fff;
    display:inline-block;
    position:relative;
    transition:all 0.5s;
}
.org-pghead-contact p .telnolink:before{
    content:'';
    width:0;
    height:1px;
    background:#fff;
    position:absolute;
    bottom:0;
    left:0;
    transition:all 0.5s;
}
.org-pghead-contact p .telnolink:hover:before{
    width:100%;
}
.div-contactfm{
    width:100%;
    margin-bottom:20px;
}
.div-contactfm label{
    width:100%;
    font-weight:700;
    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 #c7c7c7;
}
input[type='text']:focus, input[type='email']:focus, input[type='tel']:focus{
    outline:solid 1px var(--logo-color1);
}
textarea{
    width:100%;
    padding:5px;
    background-color: #fff;
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #c7c7c7;
}
textarea:focus{
    outline:solid 1px var(--logo-color1);
}
input[type='submit']{
    width:100%;
    max-width:460px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--hd-gradient-color1);
    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{
    color:var(--hd-gradient-color2);
    text-decoration:underline;
    transition:all 0.3s;
    margin-right:5px;
}
.pripol-btn a:hover{
    color:var(--hd-gradient-color2);
    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:#ff0000;
}
.require{
    font-weight:400;
    display:flex;
    width:50px;
    height:26px;
    justify-content:center;
    align-items:center;
    background:var(--logo-color2);
    color:#fff;
    font-size:12px;
    border-radius:13px;
    position:absolute;
    top:50%;
    right:0;
    transform:translateY(-50%);
}
.page-privacy-policy .dl-company>dd .contactlink{
    display:inline-block;
    position:relative;
    transition:all 0.5s;
}
.page-privacy-policy .dl-company>dd .contactlink:before{
    content:'';
    width:0;
    height:1px;
    display:inline-block;
    background:#000;
    position:absolute;
    left:0;
    bottom:0;
    transition:all 0.5s;
}
.page-privacy-policy .dl-company>dd .contactlink:hover{
    opacity:0.8;
}
.page-privacy-policy .dl-company>dd .contactlink:hover:before{
    width:100%;
}
@media(min-width:768px){
    .page-privacy-policy .org-pgheader-wrap{
        display:block;
        width:100%;
    }
    .page-privacy-policy .h1org{
        width:100%;
        transform:scalex(1.2);
        transform-origin: left center;
    }
    .page-privacy-policy .h1org small{
        transform:scalex(0.9);
    }
    .org-pghead-contact p .telnolink{
        pointer-events: none;
    }
    .tab-center{
        text-align:center;
    }
    .page-privacy-policy .dl-company>dd .contents .telnolink{
        pointer-events: none;
    }
}