/*!
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&display=swap');
/************************************************************/
:root{
    --logo-color:#015BE7;
    --thin-logo-color:#6189e8;
    --font-middle-color:#555;
    --font-thin-color:#fff;
    --bk-color:#f3f3f3;
    --bk-transparent-color:rgb(243, 243, 243, 0.8);
    --bk-transparent-color:rgb(190, 190, 190, 0.8);
    --tbl-th-color:#f3f3f3;
    --tbl-bd-color:#D2D2D2;
    --ptnB-pc-header-height:110px;
    --sp-pgheader-height: 200px;
    --tb-pgheader-height: 250px;
    --pc-pgheader-height: 300px;
    --com-first-color:#00405e;
    --com-second-color:#004d70;
    --com-third-color:#01628f;
    --com-fourth-color:#0373a7;
    --com-fifth-color:#0484c0;
    --work-odd-color:#fdfdfd;
    --work-ev-color:#f0f0f0;
    --topcontact-font-color:#fff;
    --header-bk-color2:rgb(243, 243, 243, 0.9);
    --bar-btn-color:#ccc;
    --text-color:#555;
    --caveat:"Caveat", 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;
}
/*==========================================================*/
/* defalt define											*/
/*==========================================================*/
body, p{
    font-size:17px;
    font-family:var(--yumincho);
}
body a{
    color:#333;
    text-decoration:none;
    font-family:var(--yumincho);
}
body a:hover{
    color:#333;
}
.nodata{
    color:#ff0000;
}
img{
    width:100%;
    height:auto;
}
.entry-body img{
    display:block;
    width:auto;
}
@media print {
    #mobile-menu {
        display: none !important;
    }
}
/*==========================================================*/
/* header       											*/
/*==========================================================*/
.site-header-wrap{
    position:fixed;
    top:0;
    left:0;
    background: var(--header-bk-color);
    height: var(--ptnB-sp-header-height);
    z-index:1905;
    box-shadow:none;
}
.ptnB .site-header-inner{
    justify-content:flex-start;
}
.site-header-logo a{
    width:fit-content;
    display:flex;
    align-items:center;
    transition:all 0.5s;
}
.site-header-logo a img{
    width:auto;
    height:calc(var(--ptnB-sp-header-height) - 10px);
}
.site-header-logo a:hover{
    filter:brightness(1.2);
}
.logo-ttl{
    font-family:var(--yumincho);
    color:var(--font-middle-color);
    font-weight:700;
}
/*==========================================================*/
/* scrolled       											*/
/*==========================================================*/
.scrolled .site-header-wrap{
    background:var(--header-bk-color2);
}
/*==========================================================*/
/* mobilemenu      											*/
/*==========================================================*/
.mobile-navi-btn.right{
    width: var(--ptnB-sp-header-height);
    height: var(--ptnB-sp-header-height);
    top:0;
    right:0;
    position:fixed;
    background:#333;
}
.mobile-navi-btn>span {
    position: absolute;
    background: #f3f3f3;
    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;
}
.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{
    padding-top:var(--ptnB-sp-header-height);
    left:auto;
    right:-100%;
    width:75%;
    transition: right 0.5s ease-in;
}
.mobile-menu-slide.mobile-menu-open{
    left:auto;
    right:0;
}
.site-mobile-nav>div{
    background:var(--mobile-menu-bkcolor);
    padding:0;
}
.site-mobile-menu>li{
    border-bottom:none;
}
.site-mobile-menu>li>a{
    width:100%;
    height:40px;
    padding:0;
    font-family:var(--yumincho);
    display:flex;
    justify-content: flex-start;
    align-items:center;
    position:relative;
    transition:all 0.5s;
    padding-left:10px;
}
.site-mobile-menu>li>a:before{
    content: "\f105";
    font-weight: 900;
    font-family: "Font Awesome 6 Free";
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    line-height: 1;
    text-rendering: auto;
    color:var(--sp-menu-font-color);
    font-size:14px;
    position:absolute;
    top:50%;
    right:20px;
    transform:translateY(-50%);
    transition:all 0.5s;
}
.site-mobile-menu>li>a:hover{
    color:var(--sp-menu-font-color);
    background:#666;
}
.site-mobile-menu>li>a:hover:before{
    right:10px;
}
.mb-ctn-btn{
    width:100%;
}
.mb-ctn-btn>a{
    display:flex;
    width:100%;
    height:60px;
    background:var(--sp-menu-font-color);
    color:var(--mobile-menu-bkcolor);
    justify-content:center;
    align-items:center;
    font-family:var(--yumincho);
    font-weight:700;
    transition:all 0.5s;
}
.mb-ctn-btn>a i{
    margin-right:10px;
    font-size:20px;
}
.mb-ctn-btn>a>span{
    display:flex;
    align-items:center;
}
.mb-ctn-btn>a:hover{
    background:#666;
    color:var(--sp-menu-font-color);
}
.mb-tel-btn{
    margin-top:20px;
    width:100%;
}
.mb-tel-btn a{
    display:block;
    width:fit-content;
    color:var(--sp-menu-font-color);
    margin-left:auto;
    margin-right:auto;
    font-weight:700;
    font-size:22px;
    font-family:var(--yumincho);
}
.mb-tel-btn a i{
    margin-right:10px;
}
.mb-tel-btn p{
    display:block;
    width:fit-content;
    margin-left:auto;
    margin-right:auto;
    color:#fff;
    line-height:1.2;
    font-family:var(--yumincho);
}
.no-scroll{
    position:relative;
    overflow:hidden;
}
.no-scroll:before{
    content:'';
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    background:rgba(0,0,0,0.4);
    z-index:1800;
}
/*==========================================================*/
/* globalmenu      											*/
/*==========================================================*/
.pchd-ctn-btn{
    display:none;
}
@media(min-width:992px){
    .site-header-wrap{
        height:var(--ptnB-pc-header-height);
    }
    .ptnB .container.site-header-container{
        grid-template-columns: 1fr 1fr;
        grid-template-rows:60px 50px;
    }
    .site-header-menu>li>a{
        font-family:var(--yumincho);
        font-size:17px;
    }
    .site-header-menu>li>a:before{
        width:100%;
        transform: scale(0, 1);
        transform-origin: right top;
        transition:transform 0.5s;
    }
    .site-header-menu>li>a:hover:before{
        transform-origin: left top;
        transform: scale(1, 1);
    }
    .site-header-logo{
        font-size:24px;
    }
    .ptnB .site-header-nav{
        grid-row: 2 / 3;
        grid-column: 1 / 4;
        justify-content:center;
        padding-bottom:8px;
    }
    .pchd-ctn-btn{
        display:flex;
        width:100%;
        justify-content:flex-end;
        align-items:center;
        grid-row: 1 / 2;
        grid-column: 2 / 3;
    }
    .telnolink-wrap{
        margin-right:20px;
        line-height:1;
    }
    .telnolink-wrap p{
        line-height:1;
        color:var(--font-middle-color);
        text-align:center;
    }
    .telnolink-wrap p small{
        font-size:14px;
    }
    .pchd-ctn-btn .telnolink{
        line-height:1;
        font-size:24px;
        font-weight:700;
        color:var(--font-middle-color);
        pointer-events:none;
    }
    .pchd-ctn-btn .telnolink i{
        margin-right:10px;
    }
    .pchd-ctn-btn .contactlink{
        width:180px;
        height:50px;
        display:flex;
        align-items:center;
        justify-content:center;
        border:solid 1px var(--menu-gradient2);
        color:var(--menu-gradient2);
        font-weight:700;
        position:relative;
        transition:0.5s;
    }
    .pchd-ctn-btn .contactlink span{
        display:flex;
        align-items:center;
    }
    .pchd-ctn-btn .contactlink i{
        margin-right:10px;
        font-size:18px;
    }
    .pchd-ctn-btn .contactlink:hover{
        background:var(--menu-gradient2);
        color:var(--font-thin-color);
    }
    .site-header-menu>li{
        position:relative;
    }
    .site-header-menu>li:before{
        content:'';
        width:1px;
        height:50%;
        background:var(--font-middle-color);
        position:absolute;
        top:50%;
        left:0;
        transform:translateY(-50%) rotate(10deg);
    }
    .site-header-menu>li:first-of-type:before{
        content:none;
    }
    .site-header-menu>li>a{
        margin:0 20px;
    }
}
/*==========================================================*/
/* common         											*/
/*==========================================================*/
.h2org{
    font-size:1.5em;
    padding-bottom:30px;
    margin-bottom:40px;
    position:relative;
    text-align:center;
    font-weight:700;
    color:var(--font-middle-color);
}
.h2org:before{
    content:'';
    width:60px;
    height:2px;
    background:var(--font-middle-color);
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.viewmore-btn a{
    display:flex;
    width:250px;
    height:60px;
    justify-content: center;
    align-items: center;
    border:solid 1px var(--font-middle-color);
    font-weight:600;
    font-size:18px;
    position:relative;
    margin-left:auto;
    margin-right:auto;
}
.viewmore-btn a:before{
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    height: 1px;
    margin: auto 0;
    background: var(--font-middle-color);
    -webkit-transition: all .5s ease-out;
    transition: all .5s ease-out;
    left: -40px;
    width: 80px;
}
.viewmore-btn a:after{
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    height: 1px;
    margin: auto 0;
    background: var(--font-middle-color);
    -webkit-transition: all .5s ease-out;
    transition: all .5s ease-out;
    left: 18px;
    width: 0;
    -webkit-transform: rotate(-140deg) translateX(-1.8em) translateY(1.55em);
    transform: rotate(-140deg) translateX(-1.8em) translateY(1.55em);
    -webkit-transform-origin: left bottom;
    transform-origin: left bottom;
}
.viewmore-btn a:hover:before{
    width: 100px;
}
.viewmore-btn a:hover:after{
    width: 10px;
}
.brtb{
    display:none;
}
@media(min-width:768px){
    .h2org{
        font-size:2em;
    }
    .brtb{
        display:block;
    }
}
/*==========================================================*/
/* fade-in scroll-in           								*/
/*==========================================================*/
.fade-in{
    opacity:0;
    transition:all 2s ease;
}
.fade-in.scroll-in{
    opacity:1;
}
/*==========================================================*/
/* footer         											*/
/*==========================================================*/
.site-footer{
    padding-top:80px;
    padding-bottom:100px;
    background:linear-gradient(45deg, var(--footer-bk-color), #d4dae4);
}
.footerwidget{
    display:block;
}
.ft-logo{
    width:100%;
}
.ft-logo .wrap{
    width:100%;
}
.ft-logo-link{
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    justify-content:center;
    align-items:center;
    margin-bottom:10px;
    transition:all 0.5s;
}
.ft-logo-link>img{
    width:100px;
    height:auto;
    margin-right:10px;
}
.ft-logo-link>span{
    font-size:1.5em;
    font-weight:600;
}
.ft-logo-link:hover{
    opacity:0.8;
}
.ft-priv-link{
    display:table;
    margin-left:auto;
    margin-right:auto;
    color:var(--footer-font-color);
    font-size:17px;
    transition:all 0.5s;
    margin-bottom:20px;
    position:relative;
}
.ft-priv-link:after{
    content:'';
    width:100%;
    height:1px;
    background:var(--footer-font-color);
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.ft-priv-link:hover:after{
    transform-origin: left top;
    transform: scale(1, 1);
}
.ft-logo-link:hover{
    color:var(--footer-font-color);
}
.ft-priv-link:hover{
    color:var(--footer-font-color);
}
/* menu */
.footerwidget ul{
    margin-bottom:40px;
}
.footerwidget ul>li{
    margin:5px 0;
}
.footerwidget ul>li a{
    font-size:17px;
    display:table;
    transition:all 0.5s;
    position:relative;
}
.footerwidget ul>li a:after{
    content:'';
    width:100%;
    height:1px;
    background:var(--footer-font-color);
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.footerwidget ul>li a:hover:after{
    transform-origin: left top;
    transform: scale(1, 1);
}
@media(min-width:768px){
    .footerwidget{
        display:flex;
        justify-content:space-between;
    }
    .footer_widget{
        display:inline-block;
        width:48%;
    }
    .footerwidget ul{
        width:100%;
        display:flex;
        flex-flow:row wrap;
        justify-content:space-between;
        align-items:flex-start;
    }
    .footerwidget ul>li{
        width:48%;
        display:inline-block;
    }
    .ft-logo-link{
        width:fit-content;
        margin-left:auto;
        margin-right:auto;
    }
}
@media(min-width:992px){
    .footer_widget:first-of-type{
        width:38%;
    }
    .footer_widget:last-of-type{
        width:58%;
    }
    .footerwidget ul>li{
        width:32%;
        display:inline-block;
    }
}
/*==========================================================*/
/* page-header     											*/
/*==========================================================*/
.page-header{
    overflow:hidden;
}
.page-header-ttl{
    font-family: var(--yumincho);
    font-weight:700;
}
.page-header .bk-pict{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    filter:blur(4px);
    background:url('./img/pghead-def.jpg') center center / cover no-repeat;
}
.about-us-pgheader .bk-pict{
    background:url('./img/pghead-aboutus.jpg') center center / cover no-repeat;
}
.service-pgheader .bk-pict{
    background:url('./img/pghead-srv.jpg') center center / cover no-repeat;
}
.works-pgheader .bk-pict{
    background:url('./img/pghead-works.jpg') center center / cover no-repeat;
}
.recruit-pgheader .bk-pict{
    background:url('./img/pghead-recruit.jpg') center center / cover no-repeat;
}
.contact-pgheader .bk-pict{
    background:url('./img/pghead-contact.jpg') center center / cover no-repeat;
}
.post-pgheader .bk-pict{
    background:url('./img/pghead-info.jpg') center center / cover no-repeat;
}
/*==========================================================*/
/* topslide      											*/
/*==========================================================*/
.section.breadSection{
    background:var(--bk-color);
}
/*==========================================================*/
/* topslide      											*/
/*==========================================================*/
.topslide-sec{
    position:relative;
    padding:0 0 80px 0;
    background:var(--bk-color);
    z-index:1;
}
.topslide-wrap{
    width:100%;
    position:relative;
}
.topslide-pict{
    width:100%;
    height:calc(100vh - var(--ptnB-sp-header-height));
    overflow:hidden;
    position:relative;
}
.topslide-pict .wrap{
    width:100%;
    height:100%;
    position:relative;
}
.topslide-pict img{
    width:auto;
    height:100%;
    position:absolute;
    top:0;
    left:-60%;
    opacity: 0;
    animation: slider-1 48s linear infinite;
}
.topslide-pict .t1{
    animation-delay: 0s;
}
.topslide-pict .t2{
    animation-delay: 8s;
}
.topslide-pict .t3{
    animation-delay: 16s;
}
.topslide-pict .t4{
    animation-delay: 24s;
}
.topslide-pict .t5{
    animation-delay: 32s;
}
.topslide-pict .t6{
    animation-delay: 40s;
}
.topslide-catch{
    position:absolute;
    bottom:0;
    left:0;
    padding:20px;
}
.topslide-catch .wrap{
    width:100%;
}
.topslide-catch .wrap h2{
    color:#fff;
    font-size:32px;
    line-height:1.5;
    font-weight:500;
    margin-bottom:20px;
}
.topslide-catch .wrap p{
    color:#fff;
    font-weight:500;
    font-size:16px;
}
/* scroll arrow */
.scroll-arrow {
    display: flex;
    writing-mode: vertical-rl;
    position: absolute;
    right: 20px;
    bottom: 1%;
    z-index:15;
}
.scroll-arrow a{
    letter-spacing: 10px;
    font-size: 14px;
    position: relative;
    padding-top: 10px;
    text-decoration: none;
    transition:all 0.3s;
    color:#fff;
    padding:20px 0;
}
.scroll-arrow a:hover{
    color:#fff;
    opacity:0.8;
}
.scroll-arrow a:before{
    content: '';
    width: 1px;
    height: 5px;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    animation: extend-anime 2s ease-out infinite;
    z-index: 2;
}
.scroll-arrow a:after{
    content: '';
    width: 1px;
    height: 10px;
    background: #fff;
    transform: rotate(-45deg);
    position: absolute;
    top: -3px;
    left: -4px;
    animation: move-anime 2s ease-out infinite;
}
@keyframes slider-1 {
    0% {
        opacity: 0;
        transform:translateX(0);
        filter:grayscale(100%) blur(1px);
    }
    6.25% {
        opacity: 1;
    }
    16.667% {
        opacity: 1;
        filter:grayscale(0) blur(1px);
    }
    22.917% {
        opacity: 0;
        transform:translateX(-20%);
        filter:grayscale(0) blur(1px);
    }
    100% {
        opacity: 0;
    }
}
@keyframes slider-2 {
    0% {
        opacity: 0;
        transform:translateX(0);
        filter:grayscale(100%);
    }
    6.25% {
        opacity: 1;
    }
    16.667% {
        opacity: 1;
        filter:grayscale(0);
    }
    22.917% {
        opacity: 0;
        transform:translateX(-20%);
        filter:grayscale(0);
    }
    100% {
        opacity: 0;
    }
}
@keyframes slider-3 {
    0% {
        opacity: 0;
        -webkit-transform: scale(1);
        -moztransform: scale(1);
        -ms-transform: scale(1);
        transform: scale(1);
    }
    8.333% {
        opacity: 1;
    }
    16.667% {
        opacity: 1;
    }
    25% {
        opacity: 0;
        -webkit-transform: scale(1.2);
        -moz-transform: scale(1.2);
        -ms-transform: scale(1.2);
        transform: scale(1.2);
    }
    100% {
        opacity: 0;
    }
}
@keyframes extend-anime{
    0% {
        height:5px;
    }
    100%{
        height:100%;
    }
}
@keyframes move-anime{
    0% {
        top:-3px;
    }
    100%{
        top:calc(100% - 10px);
    }
}
@media(min-width:768px){
    .topslide-pict{
        height:auto;
    }
    .topslide-pict .wrap{
        width:100%;
        height:auto;
        aspect-ratio:1 / 1;
    }
    .topslide-pict img{
        left:0;
    }
    .topslide-catch{
        position:absolute;
        left:10%;
        top:50%;
        bottom:auto;
        transform:translateY(-50%);
        padding:20px;
    }
    .topslide-catch .wrap{
        width:100%;
    }
    .topslide-catch .wrap h2{
        font-size:50px;
    }
    .topslide-catch .wrap p{
        font-size:18px;
    }
    .scroll-arrow {
        right: auto;
        left:10%;
        bottom: 1%;
    }
}
@media(min-width:992px){
    .topslide-wrap{
        display:flex;
        flex-flow:row nowrap;
        justify-content:space-between;
        align-items:flex-end;
        max-width:960px;
        padding:20px;
        margin-left:auto;
        margin-right:auto;
    }
    .topslide-pict{
        width:58%;
        height:auto;
        padding-bottom:5%;
        order:2;
    }
    .topslide-pict .wrap{
        aspect-ratio: 10 / 9;
    }
    .topslide-catch{
        position:relative;
        width:38%;
        transform:unset;
        padding:0;
        left:auto;
        top:auto;
        height:480px;
        order:1;
    }
    .topslide-catch:after{
        content:'';
        width:100%;
        height:100%;
        background:rgba(230,230,230,0.8);
        position:absolute;
        top:-5%;
        left:5%;
        z-index:-1;
    }
    .topslide-pict .wrap{
        width:100%;
        position:relative;
    }
    .topslide-pict img{
        width:auto;
        height:100%;
        object-position:center center;
        animation: slider-2 48s linear infinite;
    }
    .topslide-catch .wrap{
        display:flex;
        justify-content:center;
        align-items:center;
        position:relative;
        overflow:hidden;
        width:100%;
        height:100%;
    }
    .topslide-catch .wrap:before{
        content:'';
        width:100%;
        height:100%;
        background:url('./img/bk-topcatch.jpg') center center / cover no-repeat;
        filter:blur(2px) grayscale(100%);
        position:absolute;
        top:0;
        left:0;
        z-index:1;
    }
    .topslide-catch .wrap:after{
        content:'';
        width:100%;
        height:100%;
        background:rgba(240,240,240,0.8);
        position:absolute;
        top:0;
        left:0;
        z-index:2;
    }
    .topslide-catch .wrap .inner{
        position:relative;
        z-index:5;
        display:table;
    }
    .topslide-catch .wrap h2{
        display:table;
        color:var(--font-middle-color);
    }
    .topslide-catch .wrap p{
        display:table;
        color:var(--font-middle-color);
    }
    .scroll-arrow {
        right: auto;
        left:3%;
        bottom: -10%;
    }
    .scroll-arrow a{
        color:#000;
        padding:20px 0 40px 0;
    }
    .scroll-arrow a:hover{
        color:#000;
    }
    .scroll-arrow a:before{
        background: #000;
    }
    .scroll-arrow a:after{
        background: #000;
    }
}
@media(min-width:1200px){
    .topslide-wrap{
        max-width:1140px;
    }
    .topslide-catch{
        height:570px;
    }
    .topslide-catch .wrap{
        padding:40px;
    }
}
@media(min-width:1400px){
    .topslide-wrap{
        max-width:1320px;
    }
    .topslide-catch{
        height:670px;
    }
}
/*==========================================================*/
/* topaboutus-sec  											*/
/*==========================================================*/
.topaboutus-sec{
    position:relative;
    z-index:1;
    background:var(--bk-color);
}
.topaboutus-wrap{
    width:100%;
}
.topaboutus-wrap{
    width:100%;
    margin-bottom:40px;
}
.topaboutus-wrap p{
    line-height:2;
    margin-top:10px;
}
.topaboutus-wrap p:first-of-type{
    margin-top:0;
}
@media(min-width:768px){
    .topaboutus-wrap p{
        text-align:center;
    }
}
/*==========================================================*/
/* topbusiness-hd-sec										*/
/*==========================================================*/
.topbusiness-hd-sec{
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    z-index: -1;
}
.topbusiness-hd-sec>.wrap{
    width:100%;
    height:100%;
    position:relative;
}
.topbusiness-hd-sec>.wrap img{
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center center;
    filter:grayscale(100%) blur(1px);
}
.topbusiness-hd-sec>.wrap:before{
    content:'';
    width:100%;
    height:100%;
    background:var(--bk-transparent-color);
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
/*==========================================================*/
/* topbusiness-sec  										*/
/*==========================================================*/
.topbusiness-sec{
    position:relative;
    padding-bottom:80px;
}
.bk-topbusiness{
    width:100%;
    height:500px;
    background:var(--bk-color);
    display:block;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.topbusiness-wrap{
    position:relative;
    z-index:2;
    padding:80px 20px;
    background:#fff;
}
.ul-topbusiness{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
    justify-content: space-between;
    align-items: center;
}
.ul-topbusiness li{
    display:block;
    width:100%;
    margin-bottom:40px;
}
.ul-topbusiness li>a{
    display:block;
    width:100%;
    position:relative;
}
.ul-topbusiness li>a .pict{
    width:100%;
    position:relative;
    overflow:hidden;
}
.ul-topbusiness li>a .pict>img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:cover;
    filter:blur(1px);
    transition:all 1s;
}
.ul-topbusiness li>a .pict:before{
    content:'';
    width:100%;
    height:100%;
    background:var(--bk-transparent-color);
    position:absolute;
    top:0;
    left:0;
}
.ul-topbusiness li>a .desc{
    width:80%;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    padding:20px;
    background:rgba(0,0,0,0.3);
}
.ul-topbusiness li>a .desc h3{
    font-size:24px;
    color:#fff;
}
.ul-topbusiness li>a .desc p{
    font-size:14px;
    color:#fff;
}
.ul-topbusiness li>a:hover .pict>img{
    transform:scale(1.2);
    filter:grayscale(0) blur(0);
}
@media(min-width:768px){
    .topbusiness-wrap{
        padding:80px 40px;
    }
    .ul-topbusiness li{
        display:inline-block;
        width:47%;
    }
}
@media(min-width:992px){
    .ul-topbusiness li{
        display:inline-block;
        width:32%;
    }
    .bk-topbusiness{
        height:300px;
    }
}
@media(min-width:1200px){
    .ul-topbusiness li>a .pict>img{
        aspect-ratio:5/4;
    }
}
@media(min-width:1400px){
    .ul-topbusiness li>a .desc p{
        font-size:16px;
    }
}
/*==========================================================*/
/* topwork-sec      										*/
/*==========================================================*/
.topwork-sec{
    position:relative;
    z-index:2;
    background:#fff;
    padding:80px 0 40px 0;
}
.ul-works{
    margin:0;
    padding:0;
    list-style: none;
    display:flex;
    flex-flow:row wrap;
    justify-content: space-between;
    align-items:flex-start;
}
.ul-works li{
    margin-bottom:40px;
    padding:0 10px;
}
.ul-works li .box{
    width:100%;
}
.ul-works li .box .pict{
    width:100%;
}
.ul-works li .box .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
.ul-works li .box .type{
    padding:10px;
    background:var(--bk-color);
}
.ul-works_type{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
}
.ul-works_type>li{
    margin-top:10px;
    margin-right:10px;
    margin-bottom:0;
    padding:5px 10px;
    background:var(--font-middle-color);
    color:#fff;
    font-size:14px;
}
.ul-works li .box .desc{
    background:var(--bk-color);
    padding:10px;
}
.ul-works li .box .desc dl>dt{
    font-size:14px;
}
.ul-works li .box .desc dl>dd{
    font-size:14px;
}
@media(min-width:768px){
    .topwork-sec .viewmore-btn a{
        margin-right:0;
    }
    .ul-works>li{
        width:48%;
        margin-bottom:40px;
    }
}
@media(min-width:992px){
    .ul-works>li{
        width:32%;
        margin-bottom:40px;
    }
}
/*==========================================================*/
/* topcompany-sec      										*/
/*==========================================================*/
.topcompany-sec{
    position:relative;
    background:#fff;
    padding-bottom:80px;
}
.topcompany-wrap{
    margin-bottom:20px;
}
.tbl-company{
    width:100%;
    max-width:680px;
    margin-left:auto;
    margin-right:auto;
}
.tbl-company tr{
    display:block;
    width:100%;
    margin-bottom:30px;
}
.tbl-company th{
    width:100%;
    padding:0.5em;
    display:block;
    background:var(--tbl-th-color);
    border:solid 1px var(--tbl-bd-color);
}
.tbl-company td{
    width:100%;
    padding:0.5em;
    display:block;
    border:solid 1px var(--tbl-bd-color);
    background:#fff;
    border-top:none;
}
.tbl-company td>small{
    display:block;
    font-size:12px;
    padding-left:4.5em;
}
.tbl-company td>span{
    display:block;
    letter-spacing:1px;
}
@media(min-width:768px){
    .topcompany-wrap{
        margin-bottom:40px;
    }
    .tbl-company{
        border-top:solid 1px var(--tbl-bd-color);
    }
    .tbl-company tr{
        display: table-row;
        width:100%;
        margin-bottom:0;
    }
    .tbl-company th{
        width:30%;
        padding:1em;
        display: table-cell;
        background:var(--tbl-th-color);
        border:solid 1px var(--tbl-bd-color);
        border-top:none;
    }
    .tbl-company td{
        width:70%;
        padding:1em;
        display: table-cell;
        border:solid 1px var(--tbl-bd-color);
        border-top:none;
        border-left:none;
    }
    .topcompany-sec .viewmore-btn a{
        margin-left:0;
    }
}
/*==========================================================*/
/* topcontact-sec      										*/
/*==========================================================*/
.topcontact-sec{
    position:relative;
}
.topcontact-sec:before{
    content:'';
    width:calc(100% - 20px);
    height:calc(100% - 20px);
    border:solid 1px #fff;
    position:absolute;
    top:10px;
    left:10px;
    z-index:2;
}
.topcontact-sec:after{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.3);
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.topcontact-wrap{
    position:relative;
    z-index:5;
}
.topcontact-sec .h2org{
    color:var(--topcontact-font-color);
}
.topcontact-sec .h2org:before{
    background:var(--topcontact-font-color);
}
.topcontact-wrap p{
    color:var(--topcontact-font-color);
}
.dl-topcontact{
    margin-top:40px;
    position:relative;
    z-index:5;
}
.dl-topcontact{
    margin-bottom:0;
    width:100%;
}
.dl-topcontact>dd{
    margin-top:20px;
}
.dl-topcontact>dd a{
    width:100%;
    height:60px;
    max-width:280px;
    display:flex;
    justify-content: center;
    align-items: center;
    margin-left:auto;
    margin-right:auto;
    font-weight:600;
    font-size:18px;
    border:solid 1px var(--font-middle-color);
    color:var(--font-middle-color);
    background:var(--bk-color);
    transition:all 0.5s;
}
.dl-topcontact>dd a i{
    font-size:24px;
    margin-right:10px;
    vertical-align: bottom;
}
.dl-topcontact>dd a:hover{
    background:var(--font-middle-color);
    color:var(--bk-color);
}
.dl-topcontact>dd p{
    text-align: center;
    font-weight:500;
}
@media(min-width:768px){
    .topcontact-sec:before{
        content:'';
        width:calc(100% - 40px);
        height:calc(100% - 20px);
        border:solid 1px #fff;
        position:absolute;
        top:10px;
        left:20px;
    }
    .dl-topcontact{
        display:flex;
        flex-flow:row wrap;
        justify-content: space-between;
        align-items:flex-start;
    }
    .dl-topcontact>dd{
        width:48%;
        margin-top:0;
    }
    .topcontact-wrap p{
        text-align:center;
    }
    .dl-topcontact>dd a.telnolink{
        pointer-events:none;
    }
}
/*==========================================================*/
/* topinfo-sec      										*/
/*==========================================================*/
.topinfo-sec{
    position:relative;
    z-index:2;
    background:var(--bk-color);
    padding:80px 0;
}
.topinfo-wrap{
    width:100%;
}
.ul-infolist{
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content: space-between;
    align-items:flex-start;
}
.ul-infolist>li{
    display:block;
    width:100%;
    margin-bottom:40px;
}
.ul-infolist>li a{
    position:relative;
    display:block;
    width:100%;
}
.ul-infolist>li a .pict{
    position:relative;
    display:block;
    width:100%;
    overflow:hidden;
}
.ul-infolist>li a .pict .info-new{
    padding:0.5em 1em;
    line-height:1;
    background:#333;
    color:#fff;
    position:absolute;
    top:0;
    left:0;
    font-size:14px;
    z-index:5;
}
.ul-infolist>li a .pict>img{
    width:100%;
    aspect-ratio: 16/9;
    object-fit:cover;
    transition:all 1s;
}
.ul-infolist>li a .desc{
    width:100%;
    padding:10px;
    background:#fff;
}
.ul-infolist>li a .desc .cat{
    width:100%;
}
.ul-infolist>li a:hover img{
    transform:scale(1.2);
    filter:grayscale(0);
}
.ul-infolist>li a:hover .p-ttl{
    text-decoration:underline;
}
.ul-post_cat{
    margin:0;
    padding:0;
    list-style: none;
    display:flex;
    flex-flow:row wrap;
    margin-bottom:10px;
}
.ul-post_cat>li{
    font-size:14px;
    margin-top:5px;
    margin-right:5px;
    width:100px;
    height:30px;
    background:var(--com-first-color);
    color:#fff;
    display:flex;
    justify-content:center;
    align-items: center;
    border-radius:15px;
}
.ul-post_cat>li.ul-news{
    background:var(--com-second-color);
}
.ul-post_cat>li.ul-topics{
    background:var(--com-third-color);
}
.ul-post_cat>li.ul-column{
    background:var(--com-fourth-color);
}
.p-ttl{
    width:100%;
    height:100px;
    overflow:hidden;
    margin-bottom:10px;
}
.ul-infolist>li a .desc time{
    color:var(--font-middle-color);
}
@media(min-width:768px){
    .ul-infolist>li{
        display:inline-block;
        width:48%;
        margin-bottom:40px;
    }
}
@media(min-width:992px){
    .ul-infolist{
        justify-content:flex-start;
    }
    .ul-infolist>li a .pict>img{
        aspect-ratio: 5/3;
    }
    .ul-infolist>li{
        display:inline-block;
        width:25%;
        margin-bottom:40px;
        padding:0 5px;
    }
}
/*==========================================================*/
/* about-us-sec      										*/
/*==========================================================*/
.about-us-sec{
    position:relative;
    background:var(--bk-color);
    padding-top:20px;
    padding-bottom:80px;
}
.ul-about-us{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    list-style:none;
    justify-content:space-between;
    align-items:center;
    padding:0;
    margin:0;
}
.ul-about-us li{
    width:32%;
    margin-top:10px;
}
.ul-about-us li a{
    width:100%;
    height:40px;
    border-radius:20px;
    display:flex;
    justify-content: center;
    align-items:center;
    border:solid 1px #333;
    transition:all 0.5s;
    font-size:14px;
}
.ul-about-us li a:hover{
    background:var(--com-first-color);
    color:#fff;
}
/* message */
.message-sec{
    position:relative;
    background:var(--bk-color);
    padding:80px 0;
}
.h2pg{
    font-size:1.5em;
    padding-bottom:20px;
    margin-bottom:40px;
    position:relative;
    text-align:center;
    font-weight:700;
}
.h2pg:before{
    content:'';
    width:60px;
    height:1px;
    background:#333;
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.message-wrap{
    width:100%;
}
.dl-message{
    display:flex;
    margin:0;
    width:100%;
    flex-flow:row wrap;
    justify-content:space-between;
}
.dl-message>dt{
    width:100%;
    display:block;
    margin:0;
    order:2;
}
.dl-message>dd{
    width:100%;
    display:block;
    margin:0;
    order:1;
    margin-bottom:1em;
}
.dl-message>dt .pict{
    width:80%;
    margin-left:auto;
    margin-right:auto;
}
.dl-message>dt .pict>img{
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
}
.dl-message>dd .desc p{
    line-height:2;
    justify-content:justify;
    margin-bottom:0.5em;
}
.rep{
    margin-top:10px;
}
.rep p{
    text-align:center;
}
/* background */
.background-sec{
    background:#fff;
    padding:80px 0;
}
.background-wrap{
    width:100%;
}
.background-wrap .wrap{
    width:100%;
    margin-bottom:40px;
}
.background-wrap h3{
    font-size:20px;
    position:relative;
    font-weight:700;
    padding:10px;
    border-top:solid 1px #ddd;
    border-bottom:solid 1px #ddd;
    margin-bottom:20px;
    text-align:center;
}
.dl-bg{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    margin:0;
    position:relative;
}
.dl-bg:before{
    content:'';
    width:4px;
    height:100%;
    background:#ccc;
    position:absolute;
    top:0;
    left:20px;
    z-index:1;
}
.dl-bg>dt{
    width:100%;
    margin:0;
    font-weight:500;
}
.dl-bg>dd{
    width:100%;
    margin:0;
    padding:10px 0 10px 30px;
    margin-bottom:10px;
    font-weight:500;
}
.dl-bg>dt span:first-of-type{
    margin-right:10px;
}
.b_date{
    display:flex;
    width:250px;
    height:40px;
    background:var(--com-second-color);
    color:#fff;
    border-radius:5px;
    justify-content:flex-start;
    padding-left:20px;
    align-items: center;
    position:relative;
    z-index:5;
    font-size:16px;
}
.background-wrap .wrap:first-of-type .dl-bg:before{
    height:calc(100% - 60px);
}
.background-wrap .wrap:nth-of-type(2) .dl-bg:before{
    height:calc(100% - 90px);
}
.background-wrap .wrap:nth-of-type(3) .dl-bg:before{
    height:calc(100% - 90px);
}
.dl-bg>dd .inner{
    width:100%;
}
.dl-bg>dd .inner:first-of-type{
    margin-bottom:10px;
}
.dl-bg>dd .inner p{
    display:flex;
    font-size:16px;
}
.dl-bg>dd .inner p>span:first-of-type{
    display:inline-block;
    width:80px;
}
.dl-bg>dd .inner p>span:last-of-type{
    display:inline-block;
    width:calc(100% - 80px);
}
.dl-bg>dd .inner.osaka p>span:first-of-type{
    width:120px;
}
.dl-bg>dd .inner.osaka p>span:last-of-type{
    width:calc(100% - 120px);
}
.dl-bg>dd .inner.nara p>span:first-of-type{
    width:140px;
}
.dl-bg>dd .inner.nara p>span:last-of-type{
    width:calc(100% - 140px);
}
/* comapny */
.company-sec{
    position:relative;
    background:var(--bk-color);
    padding:80px 0;
}
.company-sec .tbl-company th{
    background:#dfdfdf;
}
.com-add{
    display:flex;
    flex-flow:row wrap;
    margin-bottom:0;
}
.com-add dt{
    display:block;
    width:100%;
    font-weight:400;
}
.com-add dd{
    display:block;
    width:100%;
    margin-bottom:20px;
}
.com-add dd:last-of-type{
    margin-bottom:0;
}
.com-add.com-qual dt{
    display:inline-block;
    width:calc(100% - 50px);
}
.com-add.com-qual dd{
    display:inline-block;
    width:50px;
    margin-bottom:10px;
    padding-right:10px;
    text-align:right;
}
.com-add.com-repre dt{
    display:inline-block;
    width:130px;
}
.com-add.com-repre dd{
    display:inline-block;
    width:calc(100% - 130px);
    margin-bottom:4px;
}
.tbl-company .telnolink{
    display:inline-block;;
    position:relative;
    transition:all 0.5s;
}
.tbl-company .telnolink:after{
    content:'';
    background:#333;
    width:100%;
    height:1px;
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.tbl-company .telnolink:hover:after{
    transform-origin: left top;
    transform: scale(1, 1);
}
.tbl-company .faxnolink{
    pointer-events:none;
}
/* organization */
.organization-sec{
    position:relative;
    padding:80px 0;
    background:#fff;
}
.organization-sec p{
    width:80px;
    height:50px;
    display:flex;
    justify-content:center;
    align-items:center;
    border:solid 1px #333;
    font-size:14px;
    line-height:1;
    position:relative;
    background:#fff;
    border-radius:10px;
    font-weight:500;
}
.organization-sec p:before{
    content:'';
    width:1px;
    height:52%;
    background:#333;
    position:absolute;
    bottom:-52%;
    left:50%;
    transform:translateX(-50%);
}
.organization-sec p:after{
    content:'';
    width:1px;
    height:52%;
    background:#333;
    position:absolute;
    top:-52%;
    left:50%;
    transform:translateX(-50%);
}
.organization-wrap{
    width:100%;
    max-width:335px;
    margin-left:auto;
    margin-right:auto;
}
.organization-grid{
    display:grid;
    width:100%;
    height:450px;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    grid-template-rows: 100px 100px 100px 100px 50px;
}
.organization-grid .president{
    display:flex;
    grid-row:1/2;
    grid-column:1/5;
    width:100%;
    justify-content:center;
}
.organization-grid .director{
    display:flex;
    grid-row:2/3;
    grid-column:1/5;
    width:100%;
    justify-content:center;
}
.organization-grid .organization-second{
    grid-row:3/4;
    grid-column:1/5;
    width:100%;
    display:grid;
    grid-template-rows:1fr;
    grid-template-columns:1fr 1fr 1fr 1fr;
    position:relative;
}
.manage-dep{
    grid-row:1/2;
    grid-column:1/2;
}
.sales-dep{
    grid-row:1/2;
    grid-column:2/3;
}
.tech-dep{
    grid-row:1/2;
    grid-column:3/5;
    display:flex;
    justify-content:center;
}
.organization-grid .organization-third{
    grid-row:4/5;
    grid-column:1/5;
    width:100%;
    display:grid;
    grid-template-rows:1fr;
    grid-template-columns:1fr 1fr 1fr 1fr;
    position:relative;
}
.manage-sec{
    grid-row:1/2;
    grid-column:1/2;
}
.sales-sec{
    grid-row:1/2;
    grid-column:2/3;
}
.survey-sec{
    grid-row:1/2;
    grid-column:3/4;
}
.design-sec{
    grid-row:1/2;
    grid-column:4/5;
}
.organization-grid .organization-fourth{
    grid-row:5/6;
    grid-column:1/5;
    width:100%;
    display:grid;
    grid-template-rows:1fr;
    grid-template-columns:1fr 1fr 1fr 1fr;
    position:relative;
}
.osaka-branch{
    grid-row:1/2;
    grid-column:1/2;
}
.nara-branch{
    grid-row:1/2;
    grid-column:2/3;
}
.iwade-branch{
    grid-row:1/2;
    grid-column:3/4;
}
.kinokawa-branch{
    grid-row:1/2;
    grid-column:4/5;
}
/* line */
.president p:before{
    content:'';
    width:1px;
    height:100%;
    background:#333;
    position:absolute;
    bottom:-100%;
    left:50%;
    transform:translateX(-50%);
}
.president p:after{
    content:none;
}
.director p:before{
    content:'';
    width:1px;
    height:52%;
    background:#333;
    position:absolute;
    bottom:-52%;
    left:50%;
    transform:translateX(-50%);
}
.manage-dep p:before{
    height:102%;
    bottom:-102%;
}
.sales-dep p:before{
    height:102%;
    bottom:-102%;
}
.manage-sec p:after{
    content:none;
}
.sales-sec p:before{
    height:102%;
    bottom:-102%;
}
.sales-sec p:after{
    content:none;
}
.manage-sec p:before, .survey-sec p:before, .design-sec p:before{
    content:none;
}
.organization-grid .organization-fourth p:before{
    content:none;
}
.nara-branch p:after{
    content:none;
}
/* yokosen */
.organization-second:before{
    content:'';
    width:64%;
    height:1px;
    background:#333;
    position:absolute;
    top:-25px;
    left:38px;
}
.organization-third:before{
    content:'';
    width:86px;
    height:1px;
    background:#333;
    position:absolute;
    top:-25px;
    right:43px;
}
.organization-fourth:before{
    content:'';
    width:250px;
    height:1px;
    background:#333;
    position:absolute;
    top:-25px;
    left:50%;
    transform:translateX(-51%);
}
/* color */
.president p{
    background:var(--com-first-color);
    color:#fff;
}
.director p{
    background:var(--com-second-color);
    color:#fff;
}
.organization-second p{
    background:var(--com-third-color);
    color:#fff;
}
.organization-third p{
    background:var(--com-fourth-color);
    color:#fff;
}
.organization-fourth p{
    background:var(--com-fifth-color);
    color:#fff;
}
/* access */
.access-sec{
    position:relative;
    background:var(--bk-color);
    padding:80px 0;
}
.access-wrap{
    width:100%;
}
.access-wrap .map{
    width:100%;
    padding-top:100%;
    position:relative;
    overflow:hidden;
    margin-top:20px;
}
.access-wrap .map iframe{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
}
@media(min-width:768px){
    .ul-about-us li{
        width:19%;
    }
    .h2pg{
        font-size:2em;
    }
    .dl-message>dt{
        width:28%;
        padding-top:0.6em;
    }
    .dl-message>dd{
        width:68%;
        display:inline-block;
        margin-bottom:0;
    }
    .dl-message>dt .pict{
        width:100%;
    }
    .dl-message>dt .pict>img{
        aspect-ratio:4/5;
    }
    /* background */
    .dl-bg>dt{
        width:35%;
    }
    .dl-bg>dd{
        width:65%;
    }
    .background-wrap h3{
        font-size:24px;
        margin-bottom:30px;
    }
    .dl-bg:before{
        left:125px;
    }
    .dl-bg>dd .spbr{
        display:none;
    }
    .background-wrap .wrap:first-of-type .dl-bg:before{
        height:calc(100% - 30px);
    }
    .background-wrap .wrap:nth-of-type(2) .dl-bg:before{
        height:calc(100% - 30px);
    }
    .background-wrap .wrap:nth-of-type(3) .dl-bg:before{
        height:calc(100% - 30px);
    }
    /* company */
    .com-add dt{
        display:inline-block;
        width:100px;
    }
    .com-add dd{
        display:inline-block;
        width:calc(100% - 100px);        
    }
    .com-add.com-lic dt{
        display:inline-block;
        width:180px;
    }
    .com-add.com-lic dd{
        display:inline-block;
        width:calc(100% - 180px);
        margin-bottom:4px;    
    }
    .tbl-company .telnolink{
        pointer-events: none;
    }
    /* organization */
    .organization-wrap{
        max-width:680px;
    }
    .organization-sec p{
        width:120px;
        height:60px;
        font-size:17px;
    }
    .organization-grid{
        height:540px;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        grid-template-rows: 120px 120px 120px 120px 60px;
    }
    /* yokosen */
    .organization-second:before{
        content:'';
        width:66.3%;
        height:1px;
        background:#333;
        position:absolute;
        top:-30px;
        left:60px;
    }
    .organization-third:before{
        content:'';
        width:170px;
        height:1px;
        background:#333;
        position:absolute;
        top:-30px;
        right:85px;
    }
    .organization-fourth:before{
        content:'';
        width:510px;
        height:1px;
        background:#333;
        position:absolute;
        top:-30px;
        left:50%;
        transform:translateX(-55%);
    }
    .survey-sec{
        display:flex;
        justify-content:center;
    }
    .design-sec{
        display:flex;
        justify-content:center;
    }
    .access-wrap .map{
        padding-top:70%;
    }
    .access-wrap>p br{
        display:none;
    }
}
@media(min-width:992px){
    .dl-message>dt{
        width:22%;
    }
    .dl-message>dd{
        width:72%;
        display:inline-block;
    }
    /* background */
    .b_date{
        font-size:17px;
    }
    .dl-bg>dt{
        width:300px
    }
    .dl-bg>dd{
        width:calc(100% - 300px);
        font-size:17px;
    }
    .dl-bg>dd .inner p{
        font-size:17px;
    }
    /* company */
    .company-sec .tbl-company{
        max-width:960px;
    }
    .company-sec .tbl-company th{
        padding-left:40px;
    }
    .company-sec .tbl-company td{
        padding-left:40px;
    }
    .access-wrap .map{
        padding-top:400px;
    }
}
/*==========================================================*/
/* business-sec      										*/
/*==========================================================*/
.business-sec{
    position:relative;
    background:var(--bk-color);
}
.ul-biz{
    width:100%;
    display:block;
    margin:0;
    padding:0;
    list-style:none;
}
.ul-biz>li{
    width:100%;
    padding:40px 0;
}
.ul-biz>li:nth-of-type(2n){
    background:#fff;
}
.dl-biz{
    display:flex;
    flex-flow:row wrap;
    width:100%;
    margin:0;
}
.dl-biz dt{
    width:100%;
    display:block;
    order:2;
}
.dl-biz dd{
    width:100%;
    display:block;
    order:1;
    margin-bottom:20px;
}
.dl-biz .pict{
    width:100%;
    display:flex;
    flex-flow:row wrap;
}
.dl-biz .pict .img_wrap{
    width:50%;
}
.dl-biz .pict .img_wrap a{
    width:105%;
    position:relative;
    overflow:hidden;
    border-radius:10px;
    transition:all 0.5s;
    display:block;
}
.dl-biz .pict .img_wrap a:hover img{
    transform:scale(1.1);
    filter:brightness(1.1);
}
.dl-biz .pict .img_wrap a:before{
    content:'';
    width:100%;
    height:100%;
    box-shadow:inset 0 0 0 10px #f0f0f0;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.ul-biz>li:nth-of-type(2n + 1) .dl-biz .pict .img_wrap a:before{
    box-shadow:inset 0 0 0 10px #ffffff;
}
.dl-biz .pict .img_wrap:last-of-type a:before{
    z-index:3;
}
.dl-biz .pict .img_wrap:last-of-type img{
    position:relative;
    z-index:2;
}
.dl-biz .pict .img_wrap img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:cover;
    transition:all 0.5s;
}
.dl-biz .pict .img_wrap p{
    text-align:center;
    margin-top:10px;
    width:105%;
    position:relative;
    z-index:10;
}
.dl-biz .pict .img_wrap:first-of-type{
    padding-top:20px;
}
.dl-biz .pict .img_wrap:last-of-type div{
    transform:translateX(-5%);
    z-index:5;
}
.dl-biz .pict .img_wrap:last-of-type p{
    transform:translateX(-5%);
}
@media(min-width:768px){
    .dl-biz{
        justify-content: space-between;
    }
    .dl-biz dt{
        display:inline-block;;
        width:49%;
    }
    .dl-biz dd{
        display:flex;
        width:49%;
        align-items:center;
    }
    .ul-biz>li:nth-of-type(2n) .dl-biz dt{
        order:1;
    }
    .ul-biz>li:nth-of-type(2n) .dl-biz dd{
        order:2;
    }
}
/*==========================================================*/
/* works-sec      	    									*/
/*==========================================================*/
/* archive taxonomy */
.works-sec{
    position:relative;
    background:var(--bk-color);
    padding-top:20px;
}
.work_type{
    width:100%;
    padding-bottom:20px;
}
.ul-work_type{
    display:flex;
    flex-flow:row wrap;
    justify-content:space-between;
    margin:0;
    padding:0;
    list-style:none;
}
.ul-work_type>li{
    margin-top:10px;
    width:48%;
}
.ul-work_type>li a{
    font-size:14px;
}
.ul-work_type>li a{
    display:flex;
    justify-content:center;
    align-items:center;
    width:100%;
    height:30px;
    transition:all 0.5s;
    border:solid 1px #333;
}
.ul-work_type>li a:hover{
    background:var(--com-first-color);
    color:#fff;
    border-color:var(--com-first-color);
}
.ul-work_type>li a.current{
    pointer-events:none;
}
/* data */
.works-box{
    width:100%;
    padding:80px 0;
}
.h2works{
    font-size:1.5em;
    padding-bottom:20px;
    margin-bottom:40px;
    position:relative;
    text-align:center;
    font-weight:700;
}
.h2works:before{
    content:'';
    width:60px;
    height:1px;
    background:#333;
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.dl-works-hd{
    margin-bottom:40px;
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    justify-content: space-between;
}
.dl-works-hd dt{
    width:19%;
    order:2;
}
.dl-works-hd dd{
    width:79%;
    order:1;
    margin-bottom:0;
}
.dl-works-hd dt .pict{
    width:100%;
}
.dl-works-hd dt .pict>img{
    width:100%;
    object-fit:cover;
    aspect-ratio:1/1;
}
.ul_worksparts{
    margin:0;
    padding:0;
    list-style:none;
}
.ul_worksparts li{
    margin-top:20px;
}
.dl-works-bd{
    display:flex;
    flex-flow:row wrap;
    width:100%;
    list-style:none;
    margin:0;
    padding:0;
    justify-content:space-between;
    border:solid 1px #ddd;
}
.dl-works-bd dt{
    width:15%;
    display:flex;
    align-items:center;
    justify-content:center;
}
.dl-works-bd dd{
    width:85%;
    display:inline-block;
    margin-bottom:0;
}
.dl-works-bd dd.dt_none{
    width:100%;
}
.dl-works-bd dt .pict{
    width:100%;
}
.dl-works-bd dt .pict>img{
    width:100%;
    object-fit:cover;
    aspect-ratio:2/3;
}
.dl-works-bd dd .desc{
    width:100%;
}
.worksdata{
    width:100%;
}
.metadata{
    display:flex;
    font-size:14px;
    padding:5px;
}
.metadata span:first-of-type{
    display:flex;
    width:70px;
    justify-content:flex-start;
    align-items:center;
}
.metadata span:last-of-type{
    display:inline-block;
    width:calc(100% - 70px);
}
.work_year, .work_orderer{
    background:var(--work-odd-color);
}
.work_workname{
    background:var(--work-ev-color);
}
.work_category .ul-works_type li{
    margin-top:0;
}
@media(min-width:768px){
    .ul-work_type>li{
        width:19%;
    }
    .h2works{
        font-size:2em;
    }
    .dl-works-hd dt{
        width:100px;
    }
    .dl-works-hd dd{
        display:flex;
        width:calc(99% - 100px);
        align-items:center;
    }
    .dl-works-hd dd .desc{
        font-size:17px;
    }
    /* body */
    .ul_worksparts li:nth-of-type(2n) .dl-works-bd dt{
        order:2;
    }
    .ul_worksparts li:nth-of-type(2n) .dl-works-bd dd{
        order:1;
    }
    .dl-works-bd{
        border:none;
    }
    .dl-works-bd dt{
        width:29%;
    }
    .dl-works-bd dd{
        width:69%;
        display:flex;
        align-items:center;
    }
    .dl-works-bd dt .pict>img{
        width:100%;
        object-fit:cover;
        aspect-ratio:4/3;
    }
    .dl-works-bd dd .desc{
        border:solid 1px #ddd;        
    }
    .metadata{
        font-size:17px;
    }
}
@media(min-width:992px){
    .dl-works-hd dt{
        width:200px;
    }
    .dl-works-hd dd{
        display:flex;
        width:calc(99% - 200px);
        align-items:center;
    }
    .dl-works-hd dt .pict>img{
        aspect-ratio:4/3;
    }
}
@media(min-width:1200px){
    .dl-works-hd dt{
        width:300px;
    }
    .dl-works-hd dd{
        display:flex;
        width:calc(99% - 300px);
        align-items:center;
    }
    .dl-works-hd dt .pict>img{
        aspect-ratio:5/3;
    }
    .ul-work_type{
        justify-content: flex-start;
    }
    .ul-work_type>li{
        width:16.666%;
        padding:0 5px;
    }
}
/*==========================================================*/
/* recruit-sec     	    									*/
/*==========================================================*/
.recruit-sec{
    position:relative;
    background:var(--bk-color);
    padding-bottom:80px;
}
.dl-recruit{
    margin-bottom:0;
    display:flex;
    flex-flow:row wrap;
    width:100%;
    justify-content:space-between;
}
.dl-recruit dt{
    width:100%;
    margin-bottom:10px;
}
.dl-recruit dd{
    width:100%;
    margin-bottom:0;
}
.dl-recruit dt .pict{
    width:100%;
}
.dl-recruit dt .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
.dl-recruit dd .desc p{
    line-height:2;
}
.application-sec{
    position:relative;
    background:#fff;
    padding:80px 0;
}
.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;
}
.tab-btn{
    width:150px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background: var(--work-ev-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:2;
 
}
.ul-tabpage-hd>li:last-of-type .tab-btn{
   z-index:1;
    
}
.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:150px;
    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;
}
.application-wrap{
    width:100%;
    background:var(--work-ev-color);
    position: relative;
    z-index: 10;
    display: none;
    border-top-right-radius: 20px;
    border-top-left-radius: 20px;
    padding-top: 40px;
    padding-bottom: 20px;
}
.application-wrap.active{
    display:block;
}
#common{
    display:block!important;
    border-top-right-radius: 0;
    border-top-left-radius: 0;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    padding-top:20px;
    padding-bottom:40px;
}
.application-wrap h3{
    font-size:20px;
    font-weight:700;
    margin-bottom:40px;
}
.tbl-recruit{
    width:100%;
    margin-bottom:30px;
}
.tbl-recruit tr{
    display:block;
    width:100%;
    margin-bottom:30px;
}
.tbl-recruit th{
    width:100%;
    padding:0.5em;
    display:block;
    background:var(--tbl-th-color);
    border:solid 1px var(--tbl-bd-color);
    font-size:17px;
    font-weight:500;
}
.tbl-recruit td{
    width:100%;
    padding:0.5em;
    display:block;
    border:solid 1px var(--tbl-bd-color);
    background:#fff;
    border-top:none;
    font-size:17px;
}
.ul-tbl-recruit{
    padding-left:20px;
    margin-bottom:0;
}
.tbl-recruit td .emphasis{
    display:block;
    text-decoration:underline;
}
.tbl-recruit td .p2{
    margin-bottom:8px;
}
@media(min-width:768px){
    .dl-recruit dt{
        width:38%;
        margin-bottom:0;
        order:2;
    }
    .dl-recruit dd{
        width:58%;
        order:1;
    }
    .dl-recruit dt .pict>img{
        aspect-ratio:1/1;
    }
    .tab-btn{
        font-size:1.5em;
        width:250px;
        height:90px;
    }
    .ul-tabpage-hd>li.active .tab-btn{
        width:250px;
        height:100px;
    }
    .tbl-recruit{
        border-top:solid 1px var(--tbl-bd-color);
    }
    .tbl-recruit tr{
        display: table-row;
        width:100%;
        margin-bottom:0;
    }
    .tbl-recruit th{
        width:30%;
        padding:1em;
        display: table-cell;
        background:var(--tbl-th-color);
        border:solid 1px var(--tbl-bd-color);
        border-top:none;
    }
    .tbl-recruit td{
        width:70%;
        padding:1em;
        display: table-cell;
        border:solid 1px var(--tbl-bd-color);
        border-top:none;
        border-left:none;
    }
}
@media(min-width:992px){
    .dl-recruit dt .pict>img{
        aspect-ratio:4/3;
    }
}
@media(min-width:1200px){
    .dl-recruit dt .pict>img{
        aspect-ratio:5/3;
    }
}
/*==========================================================*/
/* contact-sec     	    									*/
/*==========================================================*/
.page-contact .site-beforefooter{
    display:none;
}
.contact-sec{
    position:relative;
    background:var(--bk-color);
}
.contact-sec .contains-wrap{
    max-width:800px;
    margin-left:auto;
    margin-right:auto;
}
.contact-wrap{
    margin-top:80px;
}
.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(--font-middle-color);
}
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(--font-middle-color);
}
input[type='submit']{
    width:100%;
    max-width:460px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--com-third-color);
    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-color);
    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;
    }
}
/*==========================================================*/
/* privacy policy 	    									*/
/*==========================================================*/
.privacy-sec{
    position:relative;
    background:var(--bk-color);
    padding-bottom:80px;
}
.detail-wrap{
    margin-top:40px;
}
.h3org{
    font-size:2em;
    color:#fff;
    padding-left:10px;
    position:relative;
    margin-bottom:20px;
}
.h3org:before{
    content:'';
    width:4px;
    height:95%;
    background:var(--font-middle-color);
    position:absolute;
    left:0;
    top:50%;
    transform:translateY(-50%);
}
.privacy-sec .h3org{
    color:var(--font-middle-color);
    font-size:1.5em;
    padding-top:5px;
    padding-bottom:10px;
    padding-left:15px;
    border-bottom: dashed 1px #aaa;
}
.ul_pri{
    padding-left:20px;
    margin-top:1em;
    margin-bottom:0;
}
.ul_pri>li{
    font-size:17px;
    margin-top:4px;
}
.privacy-sec .detail-wrap a{
    font-weight:700;
    color:var(--font-middle-color);
    transition:all 0.5s;    
}
.privacy-sec .detail-wrap a:hover{
    color:var(--font-middle-color);
    opacity:0.8;
}
/*==========================================================*/
/* archive       	    									*/
/*==========================================================*/
.post-sec{
    position:relative;
    background:var(--bk-color);
    padding-top:20px;
}
.post-sec .ul-infolist{
    justify-content:flex-start;
}
.post-sec .ul-infolist>li{
    width:100%;
    padding:0 5px;
}
/* category */
.category-wrap{
    width:100%;
    margin-bottom:80px;
}
.ul-categorylist{
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content:space-between;
}
.ul-categorylist li{
    width:24%;
    margin-top:10px;
}
.ul-categorylist li a{
    display:flex;
    width:100%;
    height:40px;
    justify-content:center;
    align-items:center;
    font-size:14px;
    border:solid 1px #333;
    transition:all 0.5s;
}
.ul-categorylist li a:hover{
    background:var(--com-second-color);
    color:#fff;
}
@media(min-width:768px){
    .ul-categorylist li{
        width:23%;
    }
    .post-sec .ul-infolist>li{
        width:50%;

    }
}
@media(min-width:992px){
    .ul-categorylist li{
        width:22%;
    }
    .post-sec .ul-infolist>li{
        width:33.333%;

    }
}
@media(min-width:1200px){
    .post-sec .ul-infolist>li{
        width:33.333%;

    }
}
/*==========================================================*/
/* archive       	    									*/
/*==========================================================*/
.page-ttl{
    padding-bottom:10px;
    border-bottom:solid 2px #dddddd;
}
.page-ttl .jp{
    color:var(--font-middle-color);
    font-weight:700;
    font-family:var(--yumincho);
}
.entry-body{
    margin-bottom:40px;
}