/*!
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=Montserrat:ital,wght@0,100..900;1,100..900&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
/************************************************************/
:root{
    --sp-header-height:60px;
    --pc-header-height:100px;
    --main-color:#1F4B9B;
    --sub-color:#3DA8E5;
    --deep-color:#3f5887;
    --thin-color:#6381b4;
    --grey-btn-color:#3b3b41;
    --thin-font-color:#747480;
    --font-color:#242424;
    --font-color1:#00A79B;
    --font-color2:#0083B3;
    --faq-bk-color:#e0e9fb;
    --q-mark-color:#1F4B9B;
    --emphasis-yellow:#FFF200;
    --grey-color:#666;
    --bk-thin-color:#f5f5f5;
    --thin-bk-color:#e0f5f7;
    --require-color:#B61D22;
    --focus-color:#f93;
    --bk-category-btn:#dfdfdf;
    --thin-line-color:#e1fae1;
    --line-btn-color:#00c41a;
    --tbl-bd-color:#ddd;
    --tbl-th-color:#f0f0f0;
    --tbl-bd-color2:rgba(0,0,0,0.1);
    --tbl-th-color2:#ddf5ff;
    --yellow-deep:color-mix(in srgb, var(--emphasis-yellow) 60%, orange);
    --yellow-line:linear-gradient(rgba(255, 255, 255, 0) 90%, var(--emphasis-yellow) 10%);
    --yellow-thick-line:linear-gradient(rgba(255, 255, 255, 0) 60%, var(--emphasis-yellow) 40%);
    --linear-gradient-icon:linear-gradient(45deg, #1F4B9B 20%, #3DA8E5 80%);
    --linear-gradient-icon2:linear-gradient(45deg, #c2d7fe 20%, #dee9fc 80%);
    --submit-btn:linear-gradient(45deg, #5b83b1 20%, #4170a7 80%);
    --side-fixed-btn-color:linear-gradient(45deg, #d60000 20%, #ff0000 80%);
    --noto-sans:"Noto Sans JP", sans-serif;
    --noto-serif:"Noto Serif JP", serif;
    --montserrat:"Montserrat", sans-serif;
    --thin-attention-bk-color:#e0f5f7;
    --sp-pgheader-height: 200px;
    --tb-pgheader-height: 250px;
    --pc-pgheader-height: 350px;
}
/*==========================================================*/
/* defalt define											*/
/*==========================================================*/
body, p{
    font-size:16px;
    letter-spacing:0.1em;
    color:var(--font-color);
    font-family:var(--noto-serif);
    font-weight:400;
}
body a{
    color:var(--font-color);
    font-family:var(--noto-serif);
    font-weight:400;
}
.nodata{
    color:#ff0000;
}
img{
    width:100%;
    height:auto;
}
.entry-body img{
    display:unset;
    width:auto;
    height: auto;
    max-width: 100%;
}
@media print {
    #mobile-menu {
        display: none !important;
    }
}
.h2option1{
	display: table;
    margin-left: auto;
    margin-right: auto;
    font-size: 32px;
    letter-spacing: 0.1em;
    font-weight: 700;
    margin-bottom: 20px;
}
.h2option2{
	font-size:24px;
    font-weight: 700;
    padding-bottom: 20px;
    margin-bottom: 40px;
    position: relative;
    text-align: center;
}
.h2option2:before{
	content: '';
    width: 80px;
    height: 4px;
    background: var(--main-color);
    position: absolute;
    bottom: 0;
    left: 50%;
    translate: -50% 0;
}
.h3option1{
	display: table;
    font-weight: 700;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    font-size: 14px;
}
.h3option1:before{
	content: '';
    width: 16px;
    height: 8px;
    background: var(--main-color);
    position: absolute;
    left: -30px;
    top: 50%;
    transform: translateY(-50%);
}
.h3option2{
	font-size: 24px;
    font-weight: 700;
    margin-bottom: 20px;
    padding-bottom: 10px;
    position: relative;
}
.h3option2:before{
	content: '';
    width: 100%;
    height: 1px;
    background: var(--main-color);
    position: absolute;
    bottom: 0;
    left: 0;
}
.bar-btn a{
    color:var(--deep-color);
    padding: 1em 36px 1em 64px;
    font-size:16px;
    background:#ddf5ff;
}
.bar-btn a:hover{
    color:var(--deep-color);
    filter:none;
}
.bar-btn a:before, .bar-btn a:after{
    background:var(--deep-color);
}
@media(min-width:768px){
	.h2option1{
		font-size:32px;
	}
	.h2option2{
		font-size:32px;
	}
	.h3option1{
		font-size:32px;
	}
	.h3option2{
		font-size:32px;
	}
}
@media(min-width:992px){
	.h3option1{
		font-size: 18px;
        letter-spacing: 0.2em;
	}
}
/*==========================================================*/
/* fixed-btn    											*/
/*==========================================================*/
.fixed-btn{
    position:fixed;
    bottom:0;
    left:0;
    z-index:100;
    height:70px;
}
.fixed-btn.contact-btn .linelink{
    width:25%;
    line-height:1;
    text-align:center;
    color:var(--hd-left-bt-color);
    background:#fff;
    border-top:solid 1px var(--hd-left-bt-color);
    font-weight:900;
    font-size:20px;
    letter-spacing:0;
}
.fixed-btn.contact-btn .maillink{
    width:25%;
    background:var(--hd-left-bt-color);
    color:#fff;
}
.fixed-btn.contact-btn .telnolink{
    width:50%;
    background:var(--main-color);
    color:#fff;
    display:flex;
    justify-content:center;
}
.fixed-btn.contact-btn .maillink p{
    color:#fff;
    font-size:18px;
    letter-spacing:-1px;
    font-weight:700;
    text-align:center;
}
.fixed-btn.contact-btn .maillink p .font-emphasis{
    color:var(--emphasis-yellow);
}
.fixed-btn.contact-btn .maillink p small{
    display:block;
    letter-spacing:-1px;
    font-size:12px;
}
.dl-contact-tel{
    width:100%;
    display:flex;
    margin:0;
    flex-flow:row nowrap;
    max-width:190px;
}
.dl-contact-tel>dt{
    width:45px;
    height:70px;
    padding-left:10px;
    margin:0;
    display:flex;
    align-items:center;
}
.dl-contact-tel>dd{
    width:calc(100% - 45px);
    margin:0;
    display:flex;
    align-items: center;
}
.dl-contact-tel>dt i{
    font-size:38px;
}
.dl-contact-tel>dd p, .dl-contact-tel>dd small{
    display:block;
    color:#fff;
    line-height:1;
}
.dl-contact-tel>dd p{
    font-size:20px;
    letter-spacing: -1px;
    transform:scaleY(1.2);
    font-weight:700;
}
.dl-contact-tel>dd small{
    letter-spacing: -1px;
}
.dl-contact-tel>dd small .font-emphasis{
    color:var(--emphasis-yellow);
}
@media(min-width:768px){
    .fixed-btn.contact-btn .linelink{
        width:33.333%;
    }
    .fixed-btn.contact-btn .maillink{
        width:33.333%;
    }
    .fixed-btn.contact-btn .telnolink{
        width:33.333%;
    }
}
@media(min-width:992px){
    .fixed-btn{
        display:none!important;
    }
}
/*==========================================================*/
/* site-header    											*/
/*==========================================================*/
.front-page .site-header{
    height:0;
}
.site-header-wrap{
    height:var(--sp-header-height);
    position:fixed;
    z-index:1800;
    background:var(--header-bk-color);
    box-shadow:none;
}
.scrolled .site-header-wrap{
    background:rgba(255,255,255,0.9);
    backdrop-filter: blur(2px);
}
.site-header-inner{
    height:100%;
}
.site-header-logo{
    height:100%;
    padding:10px 0;
}
.site-header-logo a{
    display:block;
    height:100%;
}
/* mobile button */
.mobile-navi-btn.right{
    width:59px;
    height:59px;
    top:0;
    right:0;
    background:var(--burger-bkcolor);
}
.scrolled .mobile-navi-btn.right{
    box-shadow:none;
}
.mobile-navi-btn span{
    position: absolute;
    background:#fff;
    height:2px;
    width:30px;
    left:50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    transition: all .3s;
}
.mobile-navi-btn span:nth-child(1){
    top:34%;
}
.mobile-navi-btn span:nth-child(2){
    top:50%;
}
.mobile-navi-btn span:nth-child(3){
    top:66%;
}
.mobile-navi-btn.mobile-navi-open{
    background:var(--burger-bkcolor);
    box-shadow:none;
}
.mobile-navi-btn.mobile-navi-open span:nth-child(1){
    transform-origin: top center;
    top:50%;
    left:15px;
    transform: rotate(135deg) translate(0, -50%);
}
.mobile-navi-btn.mobile-navi-open span:nth-child(2){
    opacity: 0;
}
.mobile-navi-btn.mobile-navi-open span:nth-child(3){
    transform-origin: top center;
    left:15px;
    top:50%;
    transform: rotate(45deg) translate(0, -50%);
}
.site-mobile-nav{
    padding:20px 15px 30px;
}
.site-mobile-nav>div{
    padding:0;
    background:rgba(255, 255, 255, 0);
    height:calc(100vh - 60px);
    padding-right:20px;
}
/* mobile menu */
.mobile-menu-slide{
    top:0;
    left:auto;
    right:-100%;
    transition:right 0.5s ease-in;
    width:80%;
}
.mobile-menu-slide.mobile-menu-open{
    left:auto;
    right:0;
}
/* original menu */
.site-mobile-menu>li.mobile_menu .top-menu{
    padding-left:20px;
}
.site-mobile-menu>li.mobile_menu .top-menu>span{
    width:100%;
    height:50px;
    display:flex;
    align-items:center;
    cursor: pointer;
    position:relative;
}
.site-mobile-menu>li.mobile_menu .top-menu>span:before{
    content: '';
    position: absolute;
    top: 50%;
    width: 15px;
    height: 2px;
    background: var(--main-color);
    transition: all .3s;
    right: 10px;
    transform: translateY(-50%);    
}
.site-mobile-menu>li.mobile_menu .top-menu.clicked>span:before{
    opacity:0;
}
.site-mobile-menu>li.mobile_menu .top-menu>span:after{
    content: '';
    position: absolute;
    top: 50%;
    width: 15px;
    height: 2px;
    background: var(--main-color);
    transition: all .3s;
    right: 11px;
    top: calc(50% - 1px);
    transform: rotate(90deg) translateY(-50%);
}
.site-mobile-menu>li.mobile_menu .top-menu.clicked>span:after{
    transform: rotate(0deg) translateY(-50%);
}
.site-mobile-menu>li.mobile_menu .ul-service-menu{
    display:block;
    width:100%;
    margin:0 0 20px 0;
    padding:0;
    list-style:none;
}
.site-mobile-menu>li.mobile_menu .ul-service-menu>li>a{
    display:flex;
    height:40px;
    align-items:center;
}
.site-mobile-menu>li.mobile_menu .service-menu-sec{
    display:none;
}
body.no-scroll{
    overflow-y:hidden;
    height:100vh;
    position:relative;
}
body.no-scroll:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.2);
    backdrop-filter: blur(3px);
    position:absolute;
    top:0;
    left:0;
    z-index:1850;
}
.mobile-menu-slide{
    padding-top:0;
}
.mobile-sitelogo{
    width:100%;
    height:var(--sp-header-height);
    display:flex;
    justify-content:center;
    align-items:center;
    padding:10px 80px 10px 20px;
    border-bottom:solid 1px #cccccc;
}
.mobile-sitelogo>a{
    display:table;
}
.mobile-sitelogo>a img{
    width:100%;
    height:100%;
    object-fit:contain;
}
.site-mobile-nav{
    padding:0;
}
.site-mobile-menu>li{
    margin:0;
    padding:0;
}
.site-mobile-menu>li>a{
    width:100%;
    padding:0;
    height:50px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    padding-left:20px;
    font-family:var(--noto-serif);
    font-weight:400;
}
.site-mobile-nav>div{
    overflow-y:auto;
}
.pc-contact-btn{
    display:none;
}
/* top logo control */
.site-header-logo a.front-page-logo{
    display:none;
}
.front-page .site-header-logo a.front-page-logo{
    display:block;
}
.front-page .site-header-logo a.other-page-logo{
    display:none;
}
.front-page.scrolled .site-header-logo a.front-page-logo{
    display:none;
}
.front-page.scrolled .site-header-logo a.other-page-logo{
    display:block;
}
@media(min-width:992px){
    .site-header-wrap{
        height:var(--pc-header-height);
    }
    .container.site-header-container{
        grid-template-columns: 150px calc(100% - 150px);
        grid-template-rows: 50px calc(100% - 50px);
    }
    .pc-contact-btn{
        display:flex;
        grid-row:1/2;
        grid-column:2/3;
        justify-content: flex-end;
        align-items: flex-end;
    }
    .pc-contact-btn a{
        display:flex;
        height:auto;
        align-items:center;
        background:transparent;
        color:#333;
        letter-spacing:0;
        font-size:13px;
        font-weight:400;
        margin-left:10px;
        transition:all 0.5s;
        position:relative;
    }
    .pc-contact-btn a:hover{
        filter:brightness(1.1);
    }
    .pc-contact-btn a.telnolink{
        pointer-events:none;
        letter-spacing:0.1em;
        font-size:16px;
        font-family:var(--montserrat);
        transform:scaleY(1.4);
        font-weight:700;
        margin-bottom:5px;
    }
    .front-page .pc-contact-btn a.telnolink{
        color:#fff;
    }
    .scrolled .pc-contact-btn a.telnolink{
        color:var(--font-color);
    }
    .pc-contact-btn a.telnolink i{
        margin-right:5px;
        transform:scaleY(0.8);
        font-size:16px;
    }
    .pc-contact-btn a.telnolink:before{
        content:none;
    }
    .pc-contact-btn a.linelink{
        width:150px;
        height:40px;
        display:flex;
        justify-content:center;
        align-items:center;
        position:relative;
        background:var(--hd-left-bt-color);
        color:#fff;
        padding-left:20px;
    }
    .pc-contact-btn a.linelink i{
        font-size:16px;
        position:absolute;
        top:50%;
        left:20px;
        translate:0 -50%;
    }
    .pc-contact-btn a.maillink{
        width:150px;
        height:40px;
        display:flex;
        justify-content:center;
        align-items:center;
        position:relative;
        background:var(--main-color);
        color:#fff;
        padding-left:20px;
    }
    .pc-contact-btn a.maillink i{
        font-size:16px;
        position:absolute;
        top:50%;
        left:20px;
        translate:0 -50%;
    }
    .site-header-inner{
        grid-row:1/3;
        display:flex;
        align-items:flex-end;
    }
    .site-header-nav{
        grid-row:2/3;
        grid-column:2/3;
        justify-content: flex-end;
    }
    .site-header-menu>li{
        align-items:center;
    }
    .site-header-menu>li>a{
        font-weight:400;
        letter-spacing:0.1em;
        font-size:15px;
        font-family:var(--noto-serif);
    }
    .front-page .site-header-menu>li>a{
        color:#fff;
    }
    .scrolled .site-header-menu>li>a{
        color:var(--menu-gradient2);
    }
    .site-header-logo{
        height:auto;
        padding-top:0;
        padding-bottom:18px;
    }
    .site-header-menu>li>a:before{
        border-radius:0;
    }
    .front-page .site-header-menu>li>a:before{
        background:#fff;
    }
    .scrolled .site-header-menu>li>a:before{
        background:var(--bar-gradient2);
    }
    .fixed-btn{
        display:none;
    }
    /* org menu */
    .top-menu{
        display:flex;
        align-items:center;
        font-family:var(--noto-serif);
        position:relative;
        overflow:hidden;
        padding:0 5px;
        pointer-events:auto;
        cursor:pointer;
        height:50px;
    }
    .front-page .top-menu{
        color:#fff;
    }
    .front-page.scrolled .top-menu{
        color:var(--font-color);
    }
    .top-menu:hover{
        background:rgb(31, 75, 155, 0.9);
        color:#fff;
    }
    .scrolled .top-menu:hover{
        color:#fff;
    }
    .service-menu-sec{
        display:none;
        width:100%;
        position:fixed;
        top:100px;
        left:0;
        background:rgb(31, 75, 155, 0.9);
        z-index:100;
        transition:all 0.5s;
    }
    .service-menu-sec.active{
        display:block;
    }
    .service-menu-wrap{
        padding:40px 0 30px 0;
    }
    .ul-service-menu{
        margin:0;
        padding:0;
        list-style:none;
        width:100%;
        display:flex;
        flex-flow:row wrap;
        justify-content:flex-start;
    }
    .ul-service-menu li{
        width:auto;
        margin-bottom:10px;
    }
    .ul-service-menu li:empty{
        display:none;
    }
    .ul-service-menu li a{
        display:table;
        width:fit-content;
        white-space:nowrap;
        color:#fff;
        font-family:var(--noto-serif);
        margin-left:auto;
        margin-right:auto;
        position:relative;
        transition:all 0.5s;
        padding-bottom:2px;
        padding:5px;
        margin:0 20px;
        font-size:15px;
    }
    .ul-service-menu li a:before{
        content:'';
        width:100%;
        height:1px;
        background:#fff;
        transform:scale(0, 1);
        transform-origin:right center;
        transition:transform 0.5s;
        position:absolute;
        bottom:0;
        left:0;
    }
    .ul-service-menu li a:hover:before{
        transform:scale(1, 1);
        transform-origin:left center;
    }
    .ul-service-menu li a:hover{
        opacity:0.8;
    }
}
@media(min-width:1200px){
    .container.site-header-container{
        grid-template-columns: 200px calc(100% - 200px);
    }
    .site-header-menu>li{
        padding-left:5px;
        padding-right:5px;
    }
    .site-header-menu>li>a{
        font-size:16px;
    }
    .ul-service-menu li a{
        font-size:16px;
    }
}
/*==========================================================*/
/* loading      											*/
/*==========================================================*/
.intro-layers{
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    z-index:3000;
}
.intro-layers .wrap{
    width:100%;
    height:100%;
    background:#f0f0f0;
    display:flex;
    justify-content:center;
    align-items:center;
}
.logo_title{
    width:200px;
    opacity:0;
}
@media(min-width:768px){
    .logo_title{
        width:300px;
        opacity:0;
    }
}
/*==========================================================*/
/* fade-in       											*/
/*==========================================================*/
.fade-in{
    opacity:0;
    transition:all 1s;
    transform:translateY(20px);
}
.fade-in.scroll-in{
    animation: fade-in ease 1s forwards;
}
.hd-style.scroll-in h2>span:before{
    animation: passing-bar 1s ease 0s 1 normal forwards;
    animation-delay: 1s;
}
.hd-style.scroll-in h2>span{
    animation:passing-txt 0s ease .5s 1 normal forwards;
    animation-delay: 1s;
}
.fade-right{
    transform:translateX(-100%);
    opacity:0;
    transition:all 1s cubic-bezier(0.77, 0, 0.175, 1);
}
.fade-left{
    transform:translateX(100%);
    opacity:0;
    transition:all 1s cubic-bezier(0.77, 0, 0.175, 1);
}
.fade-right.scroll-in{
    transform:translateX(0);
    opacity:1;
}
.fade-left.scroll-in{
    transform:translateX(0);
    opacity:1;
}
@keyframes passing-bar{
	0% {
		left: 0;
		width: 0;
	}
	50% {
		left: 0;
		width: 100%;
	}
	51% {
		left: 0;
		width: 100%;
	}
	100% {
		left: 100%;
		width: 0;
	}
}
@keyframes passing-txt{
	0% { opacity:0; }
	70% { opacity:0; }
	100% { opacity:1; }
}
@keyframes fade-in{
	0% {
         opacity:0;
         transform:translateY(20px);
    }
	100% {
        opacity:1;
        transform:translateY(0);
    }
}
/*==========================================================*/
/* common         											*/
/*==========================================================*/
strong.yellow_line{
    font-weight:700;
    background:var(--yellow-line);
}
strong.yellow_line2{
    font-weight:700;
    background:var(--yellow-thick-line);
}
/*==========================================================*/
/* top slide      											*/
/*==========================================================*/
.topslide-sec{
    position:relative;
    padding:0;
    background:#fff;
}
.slider-wrapper{
    width:100%;
    position:relative;
    height:calc(100vh - 70px);
}
.slider-wrapper:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.2);
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.slider-wrapper .slide{
    width:100%;
    position:absolute;
    top:0;
    left:0;
    opacity:0;
    overflow:hidden;
}
.slider-wrapper .slide img{
    width:100%;
    height:calc(100vh - 70px);
    object-fit:cover;
}
.catchcopy{
    width:100%;
    height:100%;
    position:absolute;
    top:20px;
    left:0;
    padding-left:20px;
    display:flex;
    align-items:center;
    z-index:2;
    opacity:0;
}
.catchcopy h2{
    color:#fff;
    font-size:23px;
    font-weight:700;
    letter-spacing:0;
    line-height:2;
    margin-bottom:20px;
}
.catchcopy p{
    color:#fff;
    font-size:14px;
    font-weight:700;
    letter-spacing:0;
}
.tpslide-btn{
    display:none;
    position:absolute;
    bottom:20px;
    right:20px;
    opacity:0;
}
@media(min-width:768px){
    .catchcopy{
        padding-left:calc((100vw - 700px) / 2);
    }
    .catchcopy h2{
        font-size:30px;
    }
    .catchcopy p{
        font-size:20px;
    }
    .br_catchcopy{
        display:none;
    }
}
@media(min-width:992px){
    .catchcopy{
        padding-left:calc((100vw - 940px) / 2);
    }
    .catchcopy h2{
        font-size:40px;
    }
    .catchcopy p{
        font-size:24px;
    }
    .slider-wrapper{
        height:100vh;
        max-height:1100px;
    }
    .slider-wrapper .slide img{
        height:100vh;
        max-height:1100px;
    }
    .tpslide-btn{
        display:block;
        right:calc((100vw - 940px) / 2);
        flex-flow:row nowrap;
        z-index:5;
    }
    .tpslide-btn a{
        display:flex;
        width:200px;
        height:50px;
        border-radius:25px;
        align-items:center;
        justify-content:center;
        position:relative;
        color:#fff;
        font-weight:700;
        padding-left:10px;
        transition:all 0.5s;
    }
    .tpslide-btn a:hover{
        filter:brightness(1.1);
    }
    .tpslide-btn a i{
        content:'';
        font-size:24px;
        position:absolute;
        top:50%;
        left:20px;
        transform:translateY(-50%);
    }
    .tpslide-btn .linelink{
        background:var(--hd-left-bt-color);
        margin-bottom:10px;
    }
    .tpslide-btn .emaillink{
        background:var(--sub-color);
        margin-bottom:10px;
    }
    .tpslide-btn .telnolink{
        background:#fff;
        color:var(--main-color);
        pointer-events:none;
        border:solid 1px var(--main-color);
        line-height:1.2;
    }
    .tpslide-btn .telnolink small{
        display:block;
        font-size:12px;
        font-weight:400;
        text-align:center;
    }
}
@media(min-width:1200px){
    .catchcopy{
        padding-left:calc((100vw - 1120px) / 2);
    }
    .catchcopy h2{
        letter-spacing:0.1em;
    }
    .catchcopy p{
        letter-spacing:0.1em;
    }
    .tpslide-btn{
        display:flex;
        right:calc((100vw - 1120px) / 2);
    }
    .tpslide-btn .linelink{
        margin-bottom:0;
        margin-right:5px;
    }
    .tpslide-btn .emaillink{
        margin-bottom:0;
        margin-right:5px;
    }
}
@media(min-width:1400px){
    .catchcopy{
        padding-left:calc((100vw - 1300px) / 2);
    }
    .tpslide-btn{
        right:calc((100vw - 1300px) / 2);
    }
}
/*==========================================================*/
/* top reason     											*/
/*==========================================================*/
.tpreason-sec{
    position:relative;
    background:var(--bk-thin-color);
    padding:40px 0 20px 0;
}
.tpreason-inner{
    width:100%;
}
.ul-tpreason{
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
}
.ul-tpreason>li{
    width:100%;
    margin-top:60px;
}
.ul-tpreason>li:first-of-type{
    margin-top:30px;
}
.ul-tpreason>li .box{
    width:100%;
    position:relative;
}
.ul-tpreason>li .box .num{
    width:60px;
    height:60px;
    font-size:24px;
    font-weight:700;
    display:flex;
    justify-content: center;
    align-items: center;
    color:var(--main-color);
    background:#fff;
    border:solid 2px var(--main-color);
    border-radius:50%;
    position:absolute;
    top:-30px;
    left:50%;
    transform:translateX(-50%);
    z-index:10;
    line-height:1;
    letter-spacing: 0;
}
.ul-tpreason>li .box>.desc{
    width:100%;
    position:relative;
    overflow:hidden;
    border-radius:5px;
    border:solid 2px var(--main-color);
}
.ul-tpreason>li .box>.desc img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:cover;
}
.ul-tpreason>li .box>.desc:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.4);
    backdrop-filter: blur(1px);
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.ul-tpreason>li .box>.desc .wrap{
    position:absolute;
    width:100%;
    top:50%;
    left:0;
    transform:translateY(-50%);
    z-index:5;
    padding:20px;
}
.ul-tpreason>li .box>.desc .wrap h3{
    color:#fff;
    font-size:24px;
    font-weight:700;
    text-align:center;
    margin-bottom:20px;
}
.ul-tpreason>li .box>.desc .wrap h3 small{
    display:block;
    font-size:14px;
}
.ul-tpreason>li .box>.desc .wrap p{
    color:#fff;
    font-size:14px;
}
.ul-tpreason>li .box>.desc .wrap p.attention{
    padding-left:1em;
    position:relative;
    margin-top:0.5em;
}
.ul-tpreason>li .box>.desc .wrap p.attention:before{
    content:'※';
    position:absolute;
    top:0;
    left:0;
}
@media(min-width:768px){
    .ul-tpreason{
        justify-content: space-evenly;
    }
    .ul-tpreason>li{
        width:46%;
    }
    .ul-tpreason>li:nth-of-type(2){
        margin-top:30px;
    }
    .ul-tpreason>li .box>.desc img{
        aspect-ratio:unset;
        height:280px;
    }
    .ul-tpreason>li .box>.desc .wrap{
        min-height:201px;
    }
    .ul-tpreason>li:last-of-type{
        width:65%;
    }
}
@media(min-width:992px){
    .tpreason-sec{
        padding:80px 0 40px 0;
    }
    .tpreason-sec .hd-style{
        margin-bottom:40px;
    }
    .ul-tpreason{
        justify-content: space-between;
    }
    .ul-tpreason>li{
        width:31%;
        margin-top:50px;
    }
    .ul-tpreason>li:first-of-type{
        margin-top:50px;
    }
    .ul-tpreason>li:nth-of-type(2){
        margin-top:50px;
    }
    .ul-tpreason>li:nth-of-type(4){
        width:48%;
    }
    .ul-tpreason>li:last-of-type{
        width:48%;
    }
}
@media(min-width:1200px){
    .ul-tpreason>li{
        width:30%;
    }
    .ul-tpreason>li:nth-of-type(4){
        width:47%;
    }
    .ul-tpreason>li:last-of-type{
        width:47%;
    }
}
@media(min-width:1400px){
}
/*==========================================================*/
/* top concept     											*/
/*==========================================================*/
.bk-img-wrap{
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    z-index:-1;
}
.bk-img-wrap>.pict{
    width:100%;
    height:100%;
}
.bk-img-wrap>.pict>img{
    width:100%;
    height:100%;
    object-fit:cover;
}
.tpconcept-sec{
    position:relative;
    padding:150px 0;
    backdrop-filter: blur(1px);
    background:rgba(0,0,0,0.2);
}
.tpconcept-wrap{
    width:100%;
}
.tpconcept-wrap{
    letter-spacing:0.2em;
    line-height:1.7;
}
.tpconcept-wrap h2{
    font-size:24px;
    line-height:1.8;
    font-weight:700;
    margin-bottom:60px;
    color:#fff;
}
.tpconcept-wrap p{
    margin-bottom:30px;
    color:#fff;
    font-weight:600;
}
.tpconcept-wrap p .brtb{
    display:none;
}
@media(min-width:768px){
    .tpconcept-wrap h2{
        font-size:32px;
    }
    .tpconcept-wrap h2 br{
        display:none;
    }
}
@media(min-width:992px){
    .tpconcept-sec{
        padding:300px 0;
    }
    .tpconcept-wrap h2{
        text-align:center;
    }
    .tpconcept-wrap p{
        text-align:center;
        font-size:20px;
    }
    .tpconcept-wrap p br{
        display:none;
    }
}
/*==========================================================*/
/* tpphotoslider-sec										*/
/*==========================================================*/
.tpbizslide-sec{
    position:relative;
    background:var(--bk-thin-color);
    padding:20px 0 40px 0;
}
/* 横スクロール */
.bizslide-pict {
    width: 100%;
    overflow: hidden;
    position: relative;
    height: auto;
    height:150px;
}
.bizslide-pict .wrap {
    display: flex;
    white-space: nowrap;
    position: absolute;
    top: 0;
    left: 0;
    z-index:1;
}
.bizslide-pict .wrap img {
    display:block;
    width: 50%;
    height:150px;
    object-fit:cover;
    max-width:none;
    flex-shrink: 0;
    filter:grayscale(10%);
    margin:0 4px;
}
@media(min-width:768px){
    .bizslide-pict {
        height:180px;
    }
    .bizslide-pict .wrap img {
        width:30%;
        height:180px;
    }
}
@media(min-width:992px){
    .tpbizslide-sec{
        padding:40px 0 80px 0;
    }
    .bizslide-pict .wrap img {
        width:25%;
    }
}
@media(min-width:1200px){
    .bizslide-pict .wrap img {
        width:20%;
    }
}
/*==========================================================*/
/* tpphotoslider-sec										*/
/*==========================================================*/
.tpbusiness-sec{
    background:#F7F7F7;
    position:relative;
}
.tpbusiness-catch{
    width:100%;
    position:absolute;
    top:-250px;
    left:0;
}
.dl-catch-sec{
    display:flex;
    flex-flow:row nowrap;
    margin:0;
}
.dl-catch-sec dt{
    width:55%;
    margin:0;
}
.dl-catch-sec dd{
    width:45%;
    margin:0;
}
.dl-catch-sec dt .pict{
    width:100%;
    aspect-ratio:2/3;
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
    overflow:hidden;
}
.dl-catch-sec dt .pict>img{
    width:100%;
    aspect-ratio:2/3;
    object-fit:cover;
}
.dl-catch-sec dt .pict>video{
    width:100%;
    aspect-ratio:2/3;
    object-fit:cover;
}
.vertical-box{
    display:flex;
    justify-content:center;
}
.vertical-box>div{
    display:flex;
    flex-flow:row nowrap;
    padding-top:20px;
}
.vertical-box h2{
    display:block;
    writing-mode: vertical-rl;
    margin:0;
    font-weight:700;
    letter-spacing:0.1em;
    margin-right:20px;
    font-size:30px;
}
.vertical-box p{
    display:block;
    writing-mode: vertical-rl;
    text-orientation: upright;
    margin:0;
    font-size:14px;
    color:var(--thin-font-color);
    line-height:1.4;
    letter-spacing:0.1em;
    font-weight:700;
}
.tpbusiness-catch .summary{
    padding:0 20px;
    margin-top:40px;
}
.tpbusiness-catch .summary{
    font-weight:500;
    font-size:15px;
}
.hd-style{
    width:100%;
    margin-bottom:40px;
}
.hd-style .pict{
    display:flex;
    justify-content:center;
    margin-bottom:10px;
}
.hd-style .pict>span{
    position:relative;
    padding-right:40px;
}
.hd-style .pict strong{
    font-size:32px;
    font-weight:700;
    position:absolute;
    bottom:-5px;
    right:0;
}
.hd-style .pict img{
    width:250px;
    display:inline-block;
}
.hd-style h2{
    display:table;
    margin-left:auto;
    margin-right:auto;
    font-size:32px;
    letter-spacing: 0.1em;
    font-weight:700;
    margin-bottom:20px;
}
.hd-style p{
    display:table;
    font-weight:700;
    margin-left:auto;
    margin-right:auto;
    position:relative;
    font-size:14px;
}
.hd-style p:before{
    content:'';
    width:16px;
    height:8px;
    background:var(--main-color);
    position:absolute;
    left:-30px;
    top:50%;
    transform:translateY(-50%);
}
.tpbusiness-wrap{
    width:80%;
    margin-left:auto;
    margin-right:auto;
}
.ul-tpbusiness{
    display:flex;
    flex-flow:row wrap;
    margin:0;
    padding:0;
    list-style: none;
}
.ul-tpbusiness li{
    margin-top:60px;
}
.ul-tpbusiness li:first-of-type{
    margin-top:0;
}
.ul-tpbusiness li .box{
    width:100%;
}
.ul-tpbusiness li .pict{
    width:100%;
    overflow:hidden;
    border-radius:10px;
    margin-bottom:30px;
}
.ul-tpbusiness li .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
.ul-tpbusiness li .desc{
    width:100%;
    margin-bottom:30px;
}
.ul-tpbusiness li .desc h3{
    letter-spacing: 0.1em;
    font-size:18px;
    font-weight:700;
    margin-bottom:25px;
}
.ul-tpbusiness li .desc p{
    letter-spacing:0.1em;
    line-height:2;
    font-size:14px;
    text-align:justify;
    font-weight:500;
    color:#000;
}
.biz-btn{
    width:100%;
}
.biz-btn a{
    width:100%;
    height:50px;
    display:flex;
    justify-content:center;
    align-items: center;
    background:var(--grey-btn-color);
    color:#fff;
    font-size:16px;
    border-radius:25px;
    overflow:hidden;
    font-weight:700;
    letter-spacing:0.1em;
    max-width:250px;
    transition:all 0.5s;
    margin-left:auto;
    margin-right:auto;
}
.biz-btn a i{
    margin-left:20px;
}
.biz-btn a:hover{
    opacity:0.6;
    color:#fff;
}
@media(min-width:576px){
    .dl-catch-sec dt .pict{
        height:325px;
    }
    .dl-catch-sec dt .pict>img{
        width:100%;
        height:325px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .dl-catch-sec dt .pict>video{
        width:100%;
        height:325px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .tpbusiness-catch .summary{
        max-width:540px;
        margin-left:auto;
        margin-right:auto;
    }
}
@media(min-width:768px){
    .dl-catch-sec dt .pict>img{
        height:325px;
    }
    .dl-catch-sec dt .pict>img{
        width:100%;
        height:325px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .dl-catch-sec dt .pict>video{
        width:100%;
        height:325px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .tpbusiness-catch .summary{
        max-width:720px;
    }
    .vertical-box h2{
        font-size:42px;
    }
    .vertical-box p{
        font-size:18px;
    }
    .tpbusiness-wrap{
        width:100%;
    }
    .ul-tpbusiness{
        justify-content:space-between;
    }
    .ul-tpbusiness li{
        width:45%;
        margin-bottom:80px;
        margin-top:0;
    }
    .ul-tpbusiness li .desc{
        min-height:160px;
    }
}
@media(min-width:992px){
    .tpbusiness-sec{
        padding:80px 0;
    }
    .tpbusiness-catch{
        top:-250px; /* adjust value */
    }
    .tpbusiness-catch .summary{
        max-width:960px;
    }
    .dl-catch-sec dt{
        width:60%;
        margin:0;
    }
    .dl-catch-sec dd{
        width:40%;
        margin:0;
    }
    .dl-catch-sec dt .pict>img{
        height:500px;
    }
    .dl-catch-sec dt .pict>img{
        width:100%;
        height:500px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .dl-catch-sec dt .pict>video{
        width:100%;
        height:500px;
        aspect-ratio:unset;
        object-fit:cover;
    }
    .vertical-box>div{
        padding-top:40px;
    }
    .hd-style .pict>span{
        padding-right:60px;
    }
    .hd-style .pict img{
        width:350px;
    }
    .hd-style .pict strong{
        font-size:40px;
    }
    .hd-style h2{
        font-size:40px;
        letter-spacing: 0.2em;
        font-weight:700;
        margin-bottom:20px;
    }
    .hd-style p{
        font-size:18px;
        letter-spacing: 0.2em;
    }
    /* update */
    .ul-tpbusiness{
        justify-content:flex-start;
    }
    .ul-tpbusiness li{
        width:33.333%;
    }
    .ul-tpbusiness li:nth-of-type(3n + 1){
        padding-right:20px;
    }
    .ul-tpbusiness li:nth-of-type(3n + 2){
        padding:0 10px;
    }
    .ul-tpbusiness li:nth-of-type(3n){
        padding-left:20px;
    }
    .ul-tpbusiness li .desc{
        min-height:190px;
    }
}
@media(min-width:1200px){
    .tpbusiness-catch .summary{
        max-width:1140px;
    }
}
@media(min-width:1400px){
    .tpbusiness-catch .summary{
        max-width:1320px;
    }
}
/*==========================================================*/
/* tpworks-sec       										*/
/*==========================================================*/
.tpworks-sec .nodata p{
    color:#fff;
}
.adjust-padding{
    padding-top:0;
    padding-bottom:310px;
    background:#fff;
}
.adjust-padding.thin-grey{
    background:#F7F7F7;
}
.tpworks-sec{
    position:relative;
    background:var(--deep-color);
}
.ul-tpworks{
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
    margin-left:auto;
    margin-right:auto;
}
.ul-tpworks li{
    margin-bottom:30px;
}
.ul-tpworks li .box{
    width:100%;
    background:var(--thin-color);
    padding:30px 10px;
    border-radius:5px;
}
.tpworks-hd{
    width:100%;
}
.tax_works_service{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content: flex-end;
}
.tax_works_area{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    justify-content: flex-start;
}
.tpworks-bd{
    width:100%;
}
.dl-tpworks{
    margin:0;
    width:100%;
    display:flex;
    flex-flow:row wrap;
}
.dl-tpworks>dt{
    width:100%;
    margin-bottom:20px;
}
.div-flexbox{
    width:100%;
    margin:0 0 10px 0;
    display:flex;
    flex-flow:row wrap;
    justify-content: space-between;
}
.tpworks-before{
    width:39%;
}
.tpworks-after{
    width:59%;
}
.dl-tpworks>dd{
    width:100%;
    margin-bottom:0;
}
.tpworks-before .pict{
    position:relative;
    border:solid 1px var(--focus-color);
}
.tpworks-before .pict:before{
    content:'Before';
    padding:5px 10px;
    background:#fff;
    color:var(--focus-color);
    font-weight:700;
    font-size:12px;
    line-height:1;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.tpworks-after .pict{
    position:relative;
    border:solid 2px var(--focus-color);
}
.tpworks-after .pict:before{
    content:'After';
    padding:5px 10px;
    background:var(--focus-color);
    color:#fff;
    font-weight:700;
    font-size:12px;
    line-height:1;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.tpworks-desc{
    width:100%;
}
.tpworks-option{
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    justify-content: space-between;
}
.dl-period, .dl-cost{
    display:flex;
    flex-flow:row nowrap;
    width:49%;
    margin:0;
}
.dl-period>dt, .dl-cost>dt{
    width:50%;
    font-weight:500;
    display:flex;
    height:30px;
    align-items: center;
    justify-content:center;
    background:var(--focus-color);
    font-size:12px;
    color:#fff;
    line-height:1;
}
.dl-period>dd, .dl-cost>dd{
    width:50%;
    font-weight:500;
    display:flex;
    height:30px;
    align-items: center;
    justify-content:flex-end;
    font-size:12px;
    border:solid var(--focus-color) 1px;
    line-height:1;
    margin:0;
    background:#fff;
}
h3.works_title{
    font-size:15px;
    font-weight:700;
    color:#fff;
}
p.works_content{
    font-size:14px;
    line-height:1.8;
    color:#fff;
}
.terms_list{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-flow:row wrap;
}
.terms_list li{
    margin-bottom:10px;
    margin-right:10px;
}
.terms_list li div{
    display:table;
    padding:5px 10px;
    background:var(--focus-color);
    color:#fff;
    font-size:12px;
    line-height:1;
    white-space:nowrap;
}
.ul-tpworks li .biz-btn{
    margin-top:20px;
}
.ul-tpworks li .biz-btn a{
    background:transparent;
    border:solid 1px #fff;
}
.btn_pc{
    display:none;
}
.tpworks-sec .hd-style h2{
    color:#fff;
    text-align:center;
}
.tpworks-sec .hd-style p{
    color:#fff;
}
.tpworks-sec .hd-style p:before{
    background:var(--focus-color);
}
.tpworks-sec .biz-btn.viewmore-btn a{
    background:transparent;
    border:solid 1px #fff;
    color:#fff;
}
@media(min-width:768px){
    .adjust-padding{
        padding-top:0;
        padding-bottom:300px;
    }
    .ul-tpworks li .box{
        padding:40px 20px;
    }
    .terms_list li div{
        font-size:14px;
    }
    .tpworks-before .pict:before{
        font-size:16px;
    }
    .tpworks-after .pict:before{
        font-size:18px;
    }
    .dl-period>dt, .dl-cost>dt, .dl-period>dd, .dl-cost>dd{
        font-size:16px;
    }
    h3.works_title{
        font-size:18px;
    }
    p.works_content{
        font-size:16px;
    }
    .btn_sp{
        display:none;
    }
    .btn_pc{
        display:block;
    }
    .dl-hd{
        width:100%;
        display:flex;
        flex-flow:row nowrap;
    }
    .dl-hd>dt{
        width:50%;
        display:flex;
        justify-content:flex-start;
    }
    .dl-hd>dd{
        width:50%;
        display:flex;
        align-items:center;
    }
    .dl-hd>dt .hd-style h2{
        margin-left:0;
    }
    .dl-hd>dt .hd-style p{
        margin-left:0;
        padding-left:30px;
    }
    .dl-hd>dt .hd-style p:before{
        left:0;
    }
}
@media(min-width:992px){
    .adjust-padding{
        padding-top:0;
        padding-bottom:320px;
    }
    .tpworks-sec{
        padding:80px 0;
    }
    .dl-tpworks{
        justify-content: space-between;
        margin-bottom:0;
    }
    .dl-tpworks>dt{
        width:49%;
        margin:0;
    }
    .dl-tpworks>dd{
        width:49%;
        margin:0;
    }
    .ul-tpworks li:nth-of-type(2n) .dl-tpworks>dt{
        order:2;
    }
    .ul-tpworks li:nth-of-type(2n) .dl-tpworks>dd{
        order:1;
    }
    .tpworks-sec .biz-btn.viewmore-btn a{
        max-width:250px;
        margin-right:0;
    }
}
/*==========================================================*/
/* tpstrength-sec       										*/
/*==========================================================*/
.tpstrength-sec{
    padding:0;
    position:relative;
}
.tpstrength-wrap{
    width:100%;
    padding:80px 0;
    position:absolute;
    top:0;
    left:0;
    z-index:10;
}
.tpstrength-wrap .hd-style h2{
    text-align:center;
}
.tpstrength-inner{
    width:80%;
    margin-left:auto;
    margin-right:auto;
}
.ul-tpstrength{
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
    display:flex;
    flex-flow:row wrap;
}
.ul-tpstrength li{
    margin-bottom:40px;
}
.ul-tpstrength li:last-of-type{
    margin-bottom:0;
}
.ul-tpstrength li .box{
    width:100%;
    position:relative;
}
.ul-tpstrength li .box .pict{
    width:100%;
    position:relative;
    overflow:hidden;
    border-radius:5px;
}
.ul-tpstrength li .box .pict>img{
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
    object-position:center center;
}
.ul-tpstrength li .box .pict:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.4);
    backdrop-filter: blur(1px);
    position:absolute;
    top:0;
    left:0;
    z-index:2;
}
.strength-desc{
    width:80%;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    z-index:5;
}
.strength-desc h3{
    font-size:16px;
    font-weight:700;
    text-align:center;
    color:#fff;
    white-space:nowrap;
}
.strength-desc p{
    font-weight:500;
    font-size:15px;
    color:#fff;
    text-align:justify;
}
@media(min-width:576px){
    .tpstrength-video{
        height:800px;
    }
    .tpstrength-inner{
        width:100%;
    }
    .ul-tpstrength{
        justify-content: space-evenly;
    }
    .ul-tpstrength li{
        width:48%;
    }
}
@media(min-width:768px){
    .tpstrength-video{
        height:850px;
    }
}
@media(min-width:992px){
    .tpstrength-video{
        height:550px;
    }
    .ul-tpstrength{
        justify-content: space-between;
    }
    .ul-tpstrength li{
        width:30%;
    }
    .tpstrength-wrap .hd-style h2 br{
        display:none;
    }
}
@media(min-width:1200px){
    .tpstrength-video{
        height:600px;
    }
    .strength-desc h3{
        font-size:18px;
    }
    .strength-desc p{
        font-size:16px;
    }
}
/*==========================================================*/
/* tpvoice-sec       										*/
/*==========================================================*/
.tpvoice-sec{
    background:#f7f7f7;
    position:relative;
    padding:250px 0 40px 0;
}
.ul-tpvoice{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
}
.ul-tpvoice>li{
    width:100%;
    margin-bottom:30px;
}
.ul-tpvoice>li .box{
    width:100%;
    padding:30px 10px;
    background:#fff;
    border-radius:5px;
}
.dl-voice_head{
    width:100%;
    display:flex;
    flex-flow:row nowrap;
    margin:0 0 10px 0;
}
.dl-voice_head>dt{
    width:80px;
    margin:0;
    font-weight:500;
}
.dl-voice_head>dd{
    width:calc(100% - 80px);
    margin:0;
    display:flex;
    padding-left:20px;
    align-items: center;
}
.dl-voice_head>dt .pict{
    width:100%;
}
.dl-voice_head>dt .pict>img{
    width:100%;
    aspect-ratio:1/1;
    object-fit:cover;
    border-radius:50%;
    background:#f7f7f7;
}
.v_sub_ttl{
    font-size:14px;
    font-weight:700;
    letter-spacing: 0.1em;
    color:var(--grey-color);
}
.voice_body{
    width:100%;
}
.voice_body .biz-btn{
    margin-top:20px;
}
.voice_body .biz-btn a{
    background:var(--main-color);
}
.eval_star{
    margin-bottom:10px;
}
.eval_star>i{
    font-size:18px;
    margin-right:3px;
}
.eval_star .fa-solid.fa-star{
    color:var(--yellow-deep);
}
.eval_star .fa-regular.fa-star{
    color:#ccc;
}
.voice_body .desc{
    font-size:14px;
    letter-spacing:0.1em;
    font-weight:500;
    line-height:1.8;
}
.voice_body .desc p{
    font-size:14px;
    letter-spacing:0.1em;
    font-weight:500;
    line-height:1.8;
}
.voice_body .desc .trmlist{
    width:100%;
    margin-top:10px;
}
@media(min-width:768px){
    .tpvoice-sec{
        padding:230px 0 40px 0;
    }
}
@media(min-width:992px){
    .tpvoice-sec{
        padding:230px 0 80px 0;
    }
    .ul-tpvoice{
        margin-bottom:30px;
    }
    .ul-tpvoice>li{
        width:33.333%;
        margin-bottom:0;
    }
    .ul-tpvoice>li:nth-of-type(3n + 1){
        padding-right:2%;
    }
    .ul-tpvoice>li:nth-of-type(3n + 2){
        padding:0 1%;
    }
    .ul-tpvoice>li:nth-of-type(3n){
        padding-left:2%;
    }
    .ul-tpvoice>li .box{
        padding:40px 20px;
    }
}
@media(min-width:1200px){
    .voice_body .desc{
        min-height:160px;
    }
}
/*==========================================================*/
/* tpfaq-sec           										*/
/*==========================================================*/
.tpfaq-sec{
    position:relative;
    padding:80px 0 0 0;
}
/*==========================================================*/
/* top-faq-sec         								        */
/*==========================================================*/
/* faq */
.dl_faq{
    margin: 0 auto 60px;
}
.dl_faq dt{
    margin-top:20px;
    position: relative;
    cursor: pointer;
    transition: all .3s;
    font-size: 14px;
    color:var(--font-color);
    font-weight:400;
    background:var(--faq-bk-color);
    min-height:80px;
    padding:0;
    display:flex;
    align-items:center;
    border-radius:5px;
}
.dl_faq dd{
    display: none;
    font-size:14px;
}
.dl_faq dd img{
    width:unset;
    height:unset;
    max-width:100%;
}
.dl_faq dt .wrap{
    width:100%;
    padding: 10px 5px;
    padding-right: 30px;
    padding-left:30px;
    position:relative;
}
.dl_faq dt .wrap:after{
    content:'Q';
    font-weight:700;
    font-size:24px;
    color:var(--q-mark-color);
    display:inline-block;
    position:absolute;
    top:0;
    left:10px;
}
.dl_faq dt .wrap:before{
    content:'';
    width:25px;
    height:25px;
    background:var(--q-mark-color);
    position:absolute;
    right:5.5px;
    top:50%;
    transform:translateY(-50%);
}
.dl_faq dt:before, .dl_faq dt:after{
    content:'';
    position: absolute;
    top: 50%;
    width: 15px;
    height: 2px;
    border-radius: 50px;
    background: #fff;
    transition: all .3s;
    z-index:5;
}
.dl_faq dt:before{
    right: 10px;
    transform: translateY(-50%);
}
.dl_faq dt:after{
    right: 11px;
    top: calc(50% - 1px);
    transform: rotate(90deg) translateY(-50%);
}
.dl_faq dt.open::before{
    opacity:0;
}
.dl_faq dt.open::after {
    transform: rotate(0deg) translateY(-50%);
}
.dl_faq dd .entry-body{
    padding: 10px 5px 30px;
}
.dl_faq dd .wrap{
    padding:10px;
    padding-left:30px;
    position:relative;
}
.dl_faq dd .wrap:after{
    content:'A';
    font-weight:700;
    font-size:24px;
    color:var(--q-mark-color);
    display:inline-block;
    position:absolute;
    top:3px;
    left:10px;
}
.dl_faq dd .wrap a{
    text-decoration: underline;
}
.dl_faq dd .wrap p{
    font-size:inherit;
}
@media(min-width:768px){
    .dl_faq dt .wrap{
        padding-left:35px;
    }
}
/*==========================================================*/
/* viewmore-btn        								        */
/*==========================================================*/
.biz-btn.viewmore-btn a{
    margin-left:auto;
    margin-right:auto;
}
@media(min-width:992px){
    .biz-btn.viewmore-btn a{
        max-width:500px;
    }
}
/*==========================================================*/
/* tprecruit-sec       								        */
/*==========================================================*/
.tprecruit-sec{
    padding:0;
}
.tprecruit-wrap{
    width:100%;
}
.dl-tprecruit{
    width:100%;
    margin:0;
    display:flex;
    flex-flow:row wrap;
}
.dl-tprecruit>dt{
    width:100%;
    margin:0;
    position:relative;
}
.dl-tprecruit>dd{
    width:100%;
    margin:0;
    position:relative;
}
.dl-tprecruit>dt a, .dl-tprecruit>dd a{
    display:block;
    overflow:hidden;
}
.dl-tprecruit>dt a .pict, .dl-tprecruit>dd a .pict{
    width:100%;
    position:relative;
}
.dl-tprecruit>dt a img, .dl-tprecruit>dd a img{
    width:100%;
    aspect-ratio: 5/3;
    object-fit:cover;
    transition:all 0.5s;
}
.dl-tprecruit>dt a:hover img, .dl-tprecruit>dd a:hover img{
    transform:scale(1.1);
}
.dl-tprecruit>dt a .pict:before, .dl-tprecruit>dd a .pict:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(255,255,255,0.2);
    position:absolute;
    top:0;
    left:0;
    z-index:1;
    backdrop-filter: blur(1px);
    transition:all 0.5s;
}
.dl-tprecruit>dt a:hover .pict:before, .dl-tprecruit>dd a:hover .pict:before{
    backdrop-filter: blur(0px);
}
.temp-btn{
    width:300px;
    height:55px;
    display:flex;
    justify-content: center;
    align-items:center;
    background:var(--main-color);
    color:#fff;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    font-weight:700;
    border-radius:5px;
    overflow:hidden;
    z-index:5;
}
@media(min-width:576px){
    .dl-tprecruit>dt a img, .dl-tprecruit>dd a img{
        width:100%;
        aspect-ratio: 16/9;
        object-fit:cover;
        position:relative;
        transition:all 0.5s;
    }
}
@media(min-width:768px){
    .dl-tprecruit>dt a img, .dl-tprecruit>dd a img{
        aspect-ratio: 4/3;
    }
    .dl-tprecruit>dt{
        width:50%;
    }
    .dl-tprecruit>dd{
        width:50%;
    }

}
@media(min-width:992px){
    .dl-tprecruit>dt a img, .dl-tprecruit>dd a img{
        height:300px;
        aspect-ratio: unset;
    }
}
/*==========================================================*/
/* tpinfo-sec       								        */
/*==========================================================*/
.tpinfo-sec{
    position:relative;
    padding:80px 0 0 0;
}
.h2simple{
    font-size:24px;
    letter-spacing:0.1em;
    margin-bottom:30px;
    font-weight:700;
}
.tpinfo-wrap{
    width:100%;
}
.ul-tpinfo{
    display:block;
    margin-bottom:30px;
}
.ul-tpinfo li{
    width:100%;
    margin:0;
    border-top: 1px solid #DDDDDD;
}
.ul-tpinfo li:last-of-type{
    border-bottom: 1px solid #DDDDDD;
}
.tpinfo-box{
    display:block;
    padding:20px 0;
    display:flex;
    flex-flow:row wrap;
    width:100%;
    transition:all 0.5s
}
.tpinfo-box:hover{
    opacity:0.6;
}
.tpinfo-date{
    width:30%;
}
.tpinfo-date time{
    font-size:15px;
    color: #747480;
    letter-spacing:0;
}
.tpinfo-cat{
    width:70%;
}
.tpinfo-cat div{
    display:table;
    padding:0 15px;
    background:#F7F7F7;
    color:var(--font-color);
    font-size:12px;
    line-height:1.9;
    letter-spacing:0.1em;
}
.tpinfo-desc{
    padding-top:5px;
    width:100%;
}
.tpinfo-ttl{
    display:inline;
    font-size:15px;
    color:var(--font-color);
    letter-spacing:0;
    font-weight:500;
}
.tpinfo-mark{
    display:inline;
    font-size:14px;
}
.tpinfo-ttl i{
    margin-left:5px;
}
.info-new{
   background: #3b3b41;
 }
/*
.info-new{
    position:static;
    display:inline-block;
    transform:transitionY(1px);
    background: #3b3b41;
    color:#fff;
    font-size:11px;
    padding:4px 15px;
    font-weight:700;
    font-family: "Helvetica Neue", "arial", sans-serif;
    border-radius:0;
    margin-left:15px;
    letter-spacing:0;
}
*/
.tpinfo-sec .biz-btn.viewmore-btn a{
    margin-left:0;
}
@media(min-width:768px){
    .h2simple{
        font-size:28px;
    }
    .ul-tpinfo{
        margin-bottom:40px;
    }
    .tpinfo-date{
        width:90px;
        display:flex;
        align-items:center;
    }
    .tpinfo-cat{
        width:120px;
        display:flex;
        align-items:center;
    }
    .tpinfo-desc{
        width:calc(100% - 210px);
        display:flex;
        flex-flow:row nowrap;
        align-items:center;
    }
    .tpinfo-ttl{
        width:calc(100% - 80px);
    }
    .tpinfo-mark{
        width:80px;
    }
}
@media(min-width:992px){
    .tpinfo-sec .biz-btn.viewmore-btn a{
        max-width:250px;
    }
}
/*==========================================================*/
/* footer              								        */
/*==========================================================*/
.site-footer{
    padding:0 0 100px 0;
    border-top:solid 3px #333;
}
.footer_widget{
    width:100%
}
.before-ft{
    width:100%;
}
.logo_img{
    display:table;
    width:100%;
    max-width:250px;
    margin:0 auto 10px auto;
    transition:all 0.5s;
}
.logo_img:hover{
    opacity:0.6;
}
.ul-snslist{
    display:flex;
    flex-flow:row wrap;
    width:100%;
    margin:0 0 10px 0;
    padding:0;
    list-style:none;
    justify-content:center;
}
.ul-snslist li{
    margin:0;
}
.ul-snslist li a{
    font-size:32px;
    margin:0 auto;
    transition:all 0.5s;
}
.ul-snslist li a:hover{
    opacity:0.6;
}
.ul-ftcompany{
    display:flex;
    flex-flow:row wrap;
    width:100%;
    margin:0 0 40px 0;
    padding:0;
    list-style:none;
    justify-content:space-evenly;
}
.ul-ftcompany li a{
    width:fit-content;
    white-space:nowrap;
    transition:all 0.5s;
    position:relative;
}
.ul-ftcompany li a:before{
    content:'';
    width:100%;
    height:1px;
    background:#fff;
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.ul-ftcompany li a:hover:before{
    transform-origin: left top;
    transform: scale(1, 1);
}
.footerwidget ul.menu{
    display:flex;
    margin:0;
    padding:0;
    list-style:none;
    width:100%;
    flex-flow:row wrap;
    margin-bottom:40px;
}
.footerwidget ul.menu li{
    width:50%;
    border-bottom:solid 1px #ddd;
    position:relative;
}
.footerwidget ul.menu li:nth-of-type(2n+1):before{
    content:'';
    width:1px;
    height:80%;
    background:#ddd;
    position:absolute;
    top:50%;
    right:0;
    translate:0 -50%;
}
.footerwidget ul.menu li a{
    position:relative;
    font-weight:400;
    width:100%;
    height:80px;
    display:flex;
    justify-content:center;
    align-items:center;
    transition:all 0.5s;
}
.footerwidget ul.menu li a .nav-label{
    display:block;
    text-align:center;
    font-size:15px;
}
.footerwidget ul.menu li.ftmenu_logn a .nav-label{
    letter-spacing:-1px;
}
.footerwidget ul.menu li a .attr-title{
    display:block;
    text-align:center;
    font-size:12px;
    color:#aaa;
}
.footerwidget ul.menu li a:hover{
    text-decoration:underline;
    opacity:0.6;
}
.footer-company-info{
    width:100%;
    display:flex;
    justify-content:center;
}
.company-name{
    color:var(--font-color);
    text-align:center;
}
.company-address{
    color:var(--font-color);
}
.company-tel{
    color:var(--font-color);
    text-align:center;
}
.company-tel a{
    color:var(--font-color);
    font-size:32px;
    font-family:var(--noto-serif);
    font-weight:400;
}
.company-tel a i{
    margin-right:5px;
}
.telnolink{
    position:relative;
    transition:all 0.5s;
    font-weight:700;
}
.telnolink:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--font-color);
    transform:scale(0, 1);
    transform-origin:right center;
    transition:transform 0.5s;
    position:absolute;
    bottom:0;
    left:0;
}
.telnolink:hover:before{
    transform:scale(1, 1);
    transform-origin:left center;
}
.telnolink:hover{
    opacity:0.6;
}
@media(min-width:768px){
    .footerwidget ul.menu li{
        width:33.333%;
    }
    .footerwidget ul.menu li:before{
        content:'';
        width:1px;
        height:80%;
        background:#ddd;
        position:absolute;
        top:50%;
        left:0;
        translate:0 -50%;
    }
    .footerwidget ul.menu li:nth-of-type(3n):after, .footerwidget ul.menu li:last-of-type:after{
        content:'';
        width:1px;
        height:80%;
        background:#ddd;
        position:absolute;
        top:50%;
        right:0;
        translate:0 -50%;
    }
    .telnolink{
        pointer-events:none;
        font-weight:500;
    }
    .br_add2{
        display:none;
    }
}
@media(min-width:992px){
    .footerwidget ul.menu li{
        width:25%;
    }
    .footerwidget ul.menu li:nth-of-type(3n):after{
        content:none;
    }
    .footerwidget ul.menu li:nth-of-type(4n):after{
        content:'';
        width:1px;
        height:80%;
        background:#ddd;
        position:absolute;
        top:50%;
        right:0;
        translate:0 -50%;
    }
    .br_zipcode{
        display:none;
    }
}
@media(min-width:1200px){
    .footerwidget ul.menu li{
        width:20%;
    }
    .footerwidget ul.menu li:nth-of-type(4n):after{
        content:none;
    }
    .footerwidget ul.menu li:nth-of-type(5n):after{
        content:'';
        width:1px;
        height:80%;
        background:#ddd;
        position:absolute;
        top:50%;
        right:0;
        translate:0 -50%;
    }
}
@media(min-width:1400px){
    .footerwidget ul.menu li{
        width:20%;
        padding-top:5px;
        padding-bottom:5px;
    }
}
/*==========================================================*/
/* tparea-sec          								        */
/*==========================================================*/
.tparea-sec{
    position:relative;
    background:#f0f0f0;
}
.tpstrength-video{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
    z-index:1;
}
.tpstrength-video video{
    width:100%;
    height:100%;
    object-fit:cover;
}
.tpstrength-video:before{
    content:'';
    width:100%;
    height:100%;
    background:rgba(0,0,0,0.3);
    position:absolute;
    top:0;
    left:0;
    z-index:5;
}
.tparea-wrap{
    width:100%;
    position:relative;
    z-index:10;
}
.tparea-wrap .hd-style h2{
    color:#fff;
}
.tparea-wrap .hd-style p{
    color:#fff;
}
.tparea-wrap .hd-style p:before{
    background:var(--focus-color);
}
.dl-tparea{
    margin:0;
    width:100%;
}
.dl-tparea>dd{
    margin:0;
    width:100%;
    padding:0 20px;
    margin-bottom:20px;
}
.dl-tparea>dt{
    margin:0;
    width:100%;
    padding:20px 0;
}
.dl-tparea>dd p{
    color:#fff;
}
@media(min-width:768px){
    .dl-tparea{
        display:flex;
        flex-flow:row nowrap;
    }
    .dl-tparea>dd{
        display:flex;
        width:50%;
        align-items:center;
        padding-left:calc((100vw - 700px) / 2);
    }
    .dl-tparea>dt{
        width:50%;
    }
}
@media(min-width:992px){
    .tparea-sec{
        padding:80px 0;
    }
    .dl-tparea>dd{
        padding-left:calc((100vw - 940px) / 2);
    }
}
@media(min-width:1200px){
    .dl-tparea>dd{
        padding-left:calc((100vw - 1120px) / 2);
    }
}
@media(min-width:1400px){
    .dl-tparea>dd{
        padding-left:calc((100vw - 1300px) / 2);
    }
}
/*==========================================================*/
/* top contact     											*/
/*==========================================================*/
.tpcontact-sec{
    position:relative;
    background:#fff;
}
/* contact form */
.div-contactfm{
    width:100%;
    margin-bottom:20px;
}
.div-contactfm label{
    width:100%;
    font-weight:500;
    margin-bottom:10px;
    position:relative;
}
input[type='text'], input[type='email'], input[type='tel']{
    width:100%;
    height:60px;
    padding:5px;
    background-color:#fff;
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #ccc;
}
input[type='text']:focus, input[type='email']:focus, input[type='tel']:focus{
    outline:solid 1px var(--focus-color);
}
textarea{
    width:100%;
    padding:5px;
    background-color:#fff;    
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #ccc;
}
textarea:focus{
    outline:solid 1px var(--focus-color);
}
input[type='submit']{
    width:100%;
    max-width:460px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--submit-btn);
    color:#fff;
    border:none;
    margin:0 auto;
    transition:all 0.3s;
}
input[type='submit']:hover{
    filter:brightness(1.1);
}
input[type='submit']:disabled{
    filter:brightness(0.8);
}
input[type='submit']:hover:disabled{
    filter:brightness(0.8);
}
.pripol-btn{
    padding:10px 0;
}
.pripol-btn>div{
    margin-bottom:30px;
}
.pripol-btn a{
    text-decoration:underline;
    margin-right:5px;
    transition:0.5s;
    width:fit-content;
    position:relative;
}
.pripol-btn a:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--require-color);
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.pripol-btn a:hover:before{
    transform-origin: left top;
    transform: scale(1, 1);
}
.pripol-btn a:hover{
    text-decoration:none;
    opacity:0.8;
}
.pripol-btn .square{
    display:inline-block;
    position:relative;
    padding:10px;
}
.pripol-btn .square:before{
    content:'';
    width:13px;
    height:13px;
    border:solid 1px #555;
    border-radius:2px;
    background:#fff;
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.checkbox-pripol{
    display:flex;
    justify-content:center;
    align-items:center;
}
.checkbox-pripol label{
    display:flex;
    align-items:center;
}
input[name='acceptance-privacypolicy']{
    width:18px;
    height:18px;
    margin-right:10px;
}
.pripol-desc{
    display:flex;
    justify-content:center;
}
.p-desc .require{
    color:var(--require-color);
}
.require{
    font-weight:400;
    display:flex;
    width:50px;
    height:26px;
    justify-content:center;
    align-items:center;
    background:var(--require-color);
    color:#fff;
    font-size:12px;
    border-radius:13px;
    position:absolute;
    top:50%;
    right:0;
    transform:translateY(-50%);
}
@media(min-width:992px){
    .tpcontact-sec{
        padding:80px 0;
    }
}
/*==========================================================*/
/* service page    											*/
/*==========================================================*/
.srv-sec{
    position:relative;
}
.h2org{
    font-size:24px;
    font-weight:700;
    margin-bottom:40px;
    text-align:center;
    color:var(--font-color);
}
.ul-srv{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    width:100%;
    flex-flow:row wrap;
}
.ul-srv li{
    width:100%;
    margin-bottom:40px;
}
.dl-srv{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    margin:0;
}
.dl-srv dt{
    width:100%;
    display:block;
    margin-bottom:10px;
    position:relative;
}
.dl-srv dt .pict{
    width:100%;
}
.dl-srv dt .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
.dl-srv dd{
    display:block;
    width:100%;
    margin:0;
}
.h3org{
    font-size:20px;
    font-weight:700;
    margin-bottom:10px;
    text-align:center;
    color:var(--font-color);
}
.dl-srv dd .fade-in.scroll-in{
    animation-delay: 0.5s;
}
/* strength */
.reform-strengh-sec{
    background:var(--deep-color);
}
.reform-strengh-sec .hd-style h2{
    color:#fff;
}
.reform-strengh-sec .hd-style p{
    color:#fff;
}
.reform-strengh-sec .hd-style p:before{
    background:var(--focus-color);
}
.ul-tpstrengths{
    list-style:none;
    display:flex;
    flex-flow:row wrap;
    width:100%;
    margin:0 0 40px 0;
    padding:0 20px;
}
.ul-tpstrengths>li{
    display:block;
    width:100%;
    margin-top:110px;
    counter-increment: title 1;
}
.ul-tpstrengths>li:first-of-type{
    margin-top:50px;
}
.ul-tpstrengths>li .box{
    background:#fff;
    width:100%;
    position:relative;
    padding-top:75px;
    border-radius:20px;
    box-shadow: rgba(0, 131, 179, 0.2) 0px 0px 50px;
}
.ul-tpstrengths>li .box:before{
    content:"0" counter(title);
    color:var(--thin-bk-color);
    position: absolute;
    right: 32px;
    bottom: 32px;
    line-height: 1;
    font-weight: 900;
    font-size: 450%;
    letter-spacing: 0px;    
}
.ul-tpstrengths>li .pict{
    width:150px;
    height:150px;
    border-radius:50%;
    overflow:hidden;
    position:absolute;
    top:-75px;
    left:50%;
    transform:translateX(-50%);
    background:#fff;
}
.ul-tpstrengths>li .pict>img{
    position:relative;
    top:5%;
    left:5%;
    width:90%;
    height:90%;
    border-radius:50%;
    object-fit:cover;
}
.ul-tpstrengths>li .desc{
    padding:20px;
    position:relative;
    z-index:5;
}
.ul-tpstrengths>li .desc h3{
    font-size:1.5em;
    color:var(--font-color1);
    text-align:center;
    font-weight:700;
    margin-bottom:20px;
    white-space:nowrap;
}
.ul-tpstrengths>li .desc h4{
    font-size:17px;
    color:var(--font-color2);
    font-weight:500;
    margin-bottom:20px;
}
.ul-tpstrengths>li .desc p{
    font-size:14px;
}
/* area */
.slug-renovation .tparea-sec,
.slug-electrical-work .tparea-sec,
.slug-air-conditioning-work .tparea-sec,
.slug-exteriors .tparea-sec,
.slug-painting .tparea-sec{
    background:#fff;
}
.slug-realestate .tparea-sec,
.slug-emergency-support .tparea-sec{
    background:var(--main-color);
}
.slug-renovation .tpstrength-video,
.slug-electrical-work .tpstrength-video,
.slug-air-conditioning-work .tpstrength-video,
.slug-exteriors .tpstrength-video,
.slug-painting .tpstrength-video,
.slug-realestate .tpstrength-video,
.slug-emergency-support .tpstrength-video{
    display:none;
}
.slug-renovation .tparea-sec .tparea-wrap .hd-style h2,
.slug-electrical-work .tparea-sec .tparea-wrap .hd-style h2,
.slug-air-conditioning-work .tparea-sec .tparea-wrap .hd-style h2,
.slug-exteriors .tparea-sec .tparea-wrap .hd-style h2,
.slug-painting .tparea-sec .tparea-wrap .hd-style h2{
    color:var(--font-color);
}
.slug-realestate .tparea-sec .tparea-wrap .hd-style h2,
.slug-emergency-support .tparea-sec .tparea-wrap .hd-style h2{
    color:#fff;
}
.slug-renovation .tparea-sec .tparea-wrap .hd-style p,
.slug-electrical-work .tparea-sec .tparea-wrap .hd-style p,
.slug-air-conditioning-work .tparea-sec .tparea-wrap .hd-style p,
.slug-exteriors .tparea-sec .tparea-wrap .hd-style p,
.slug-painting .tparea-sec .tparea-wrap .hd-style p{
    color:var(--font-color);
}
.slug-realestate .tparea-sec .tparea-wrap .hd-style p,
.slug-emergency-support .tparea-sec .tparea-wrap .hd-style p{
    color:#fff;
}
.slug-renovation .tparea-sec .tparea-wrap .hd-style p:before,
.slug-electrical-work .tparea-sec .tparea-wrap .hd-style p:before,
.slug-air-conditioning-work .tparea-sec .tparea-wrap .hd-style p:before,
.slug-exteriors .tparea-sec .tparea-wrap .hd-style p:before,
.slug-painting .tparea-sec .tparea-wrap .hd-style p:before{
    background:var(--main-color);
}
.slug-realestate .tparea-sec .tparea-wrap .hd-style p:before,
.slug-emergency-support .tparea-sec .tparea-wrap .hd-style p:before{
    background:var(--focus-color);
}
.slug-renovation .dl-tparea>dd p,
.slug-electrical-work .dl-tparea>dd p,
.slug-air-conditioning-work .dl-tparea>dd p,
.slug-exteriors .dl-tparea>dd p,
.slug-painting .dl-tparea>dd p{
    color:var(--font-color);
}
.slug-realestate .dl-tparea>dd p,
.slug-emergency-support .dl-tparea>dd p{
    color:#fff;
}
.cl_srv_ttl{
    font-size:50%;
    display:block;
    text-align:center;
    margin-bottom:10px;
}
.tpfaq-sec.srvpg_faq-sec{
    padding:40px 0;
}
/* pattern 2 */
.ul-srv2{
    width:100%;
    display:flex;
    margin:0;
    padding:0;
    list-style:none;
    flex-flow:row wrap;
    justify-content:center;
    align-items:flex-start;
}
.ul-srv2 li{
    margin-bottom:40px;
}
.dl-srv2{
    width:100%;
    margin:0;
    display:block;
}
.dl-srv2 dt{
    width:100%;
    margin:0 0 10px 0;
}
.dl-srv2 dt .pict{
    max-width:200px;
    margin-left:auto;
    margin-right:auto;
    border-radius:30px;
    overflow:hidden;
}
.dl-srv2 dd{
    padding:10px;
}
.dl-srv2 dd h3{
    text-align:center;
    font-size:20px;
    font-weight:700;
    margin-bottom:10px;
    color:var(--main-color);
}
.br_ele{
    display:none;
}
/* 空調 */
.slug-air-conditioning-work .page-header-wrap>img{
    object-position:top center;
}
.air-conditioning-sec .dl-srv2 dt .pict{
    background:var(--linear-gradient-icon2);
    max-width:250px;
}
/* エクステリア･外構 */
.exteriors-sec .dl-srv2 dt .pict{
    padding:0;
    max-width:300px;
    background:none;
}
/* 塗装 */
.painting-sec .dl-srv2 dt .pict{
    padding:0;
    max-width:300px;
    background:none;
}
.painting-strength-sec .ul-tpstrengths>li .desc h3 .br_pai{
    display:none;
}
.br_ele.br_pai{
    display:block;
}
.ul-srv2 .ul-painting{
    padding-left:20px;
    list-style-type: disc;
    margin:1em 0;
}
.ul-srv2 .ul-painting>li{
    margin-bottom:0;
    width:100%;
}
/* 不動産 */
.realestate-sec{
    position:relative;
}
.h2realestate{
    font-size:24px;
    font-weight:700;
    margin-bottom:30px;
}
.realestate-sec .dl-srv2 dt .pict{
    padding:0;
    max-width:300px;
    background:none;
}
.realestate-box{
    padding:20px;
    background:var(--thin-attention-bk-color);
    border-radius:10px;
}
.realestate-box h3{
    font-size:24px;
    margin-bottom:20px;
    font-weight:700;
    color:var(--main-color);
}
.realestate-box .ul-painting{
    margin-top:1rem;
}
/* 緊急対応サービス */
.emergency-sec{
    position:relative;
}
.h2realestate{
    font-size:24px;
    font-weight:700;
    margin-bottom:30px;
}
.emergency-sec .dl-srv2 dt .pict{
    padding:0;
    max-width:300px;
    background:none;
}
.emergency-box{
    padding:20px;
    background:var(--thin-attention-bk-color);
    border-radius:10px;
    width:100%;
}
.emergency-box h3{
    font-size:24px;
    margin-bottom:20px;
    font-weight:700;
    color:var(--main-color);
}
.emergency-box .ul-painting{
    margin-top:1rem;
}
.br_ele.br_emer{
    display:block;
}
@media(min-width:768px){
    .h2org{
        font-size:32px;
    }
    .h3org{
        font-size:24px;
    }
    .dl-srv dt{
        width:40%;
        margin-bottom:0;
        aspect-ratio:10/9;
    }
    .dl-srv dd{
        width:60%;
    }
    .h3org{
        text-align:left;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt{
        order:2;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt{
        order:1;
    }
    .dl-srv dt .pict{
        width:calc(680px * 0.6);
        position:absolute;
        left:calc(((100vw - 680px) / 2) * -1);
        z-index:-1;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt .pict{
        left:auto;
        right:calc(((100vw - 680px) / 2) * -1);
    }
    .dl-srv dd{
        display:flex;
        align-items:center;
    }
    .dl-srv dd .desc{
        background:rgba(245, 245, 245, 0.9);
        padding:10px;
    }
    .tpworks-sec .cl_srv_ttl{
        text-align:left;
    }
    /* pattern 2 */
    .ul-srv2 li{
        width:50%;
        padding:5px;
    }
    .br_ele{
        display:block;
    }
    .dl-srv2 dd h3{
        font-size:24px;
    }
    /* エクステリア･外構 */
    .exteriors-sec .h2org .br_ext{
        display:none;
    }
    /* 塗装 */
    .painting-sec .h2org .br_pai{
        display:none;
    }
    .painting-sec .ul-srv2 li{
        width:100%;
    }
}
@media(min-width:992px){
    .dl-srv dt .pict{
        width:calc(920px * 0.6);
        position:absolute;
        left:calc(((100vw - 920px) / 2) * -1);
        z-index:-1;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt .pict{
        left:auto;
        right:calc(((100vw - 920px) / 2) * -1);
    }
    .dl-srv dd .desc{
        padding:20px;
    }
    .h2org{
        margin-bottom:60px;
    }
    .ul-srv li{
        margin-bottom:60px;
    }
    .reform-strengh-sec{
        padding:80px 0;
    }
    .ul-tpstrengths{
        justify-content:space-between;
    }
    .ul-tpstrengths>li{
        width:32%;
        display:inline-block;
        margin-top:70px;
        margin-bottom:40px;
    }
    .ul-tpstrengths>li:first-of-type{
        margin-top:70px;
    }
    .ul-tpstrengths>li .desc{
        min-height:340px;
    }
    .tpfaq-sec.srvpg_faq-sec{
        padding:80px 0;
    }
    /* pattern 2 */
    .ul-srv2 li{
        width:33.333%;
    }
    .dl-srv2 dt .pict{
        max-width:150px;
    }
    .dl-srv2 dd h3{
        min-height:60px;
        display:flex;
        align-items:center;
        justify-content:center;
    }
    /* 空調 */
    .air-conditioning-sec .ul-srv2{
        justify-content: space-between;
    }
    .air-conditioning-sec .ul-srv2 li{
        width:48%;
        padding:0;
    }
    .air-conditioning-sec .dl-srv2 dd h3{
        min-height:90px;
    }
    .br_ele.br_air{
        display:none;
    }
    /* エクステリア･外構 */
    .exteriors-sec .ul-srv2{
        justify-content: space-between;
    }
    .exteriors-sec .ul-srv2 li{
        width:48%;
        padding:0;
    }
    .exteriors-sec .dl-srv2 dd h3{
        min-height:90px;
    }
    .br_ele.br_ext{
        display:none;
    }
    /* 塗装 */
    .painting-strength-sec .ul-tpstrengths>li .desc h3 .br_pai{
        display:block;
    }
    .painting-sec .ul-srv2{
        justify-content: space-between;
    }
    .painting-sec .ul-srv2>li{
        width:48%;
    }
    .painting-strength-sec .ul-tpstrengths{
        justify-content:space-around;
        padding:0;
    }
    .painting-strength-sec .ul-tpstrengths>li{
        width:30%;
    }
    /* 不動産管理 */
    .realestate-sec{
        padding-bottom:80px;
    }
    .h2realestate{
        text-align: center;
    }
    .realestate-sec .ul-srv2>li{
        width:48%;
    }
    .realestate-sec .ul-srv2 li{
        padding:0;
    }
    .br_ele.br_real{
        display:none;
    }
    .realestate-box{
        padding:40px;
    }
    .realestate-sec .dl-srv2 dt .pict>img{
        aspect-ratio:4/3;
        object-fit:cover;
    }
    /* 緊急対応サービス */
    .emergency-sec{
        padding-bottom:80px;
    }
    .h2realestate{
        text-align: center;
    }
    .emergency-sec .ul-srv2{
        justify-content: space-between;
    }
    .emergency-sec .ul-srv2>li{
        width:48%;
    }
    .emergency-sec .ul-srv2 li{
        padding:0;
    }
    .br_ele.br_emer{
        display:none;
    }
    .emergency-sec .dl-srv2 dd h3{
        letter-spacing:0;
    }
    .emergency-sec .dl-srv2 dt .pict>img{
        aspect-ratio:4/3;
        object-fit:cover;
    }
    .emergency-box{
        padding:40px;
    }
}
@media(min-width:1200px){
    .dl-srv dt .pict{
        width:calc(1100px * 0.6);
        position:absolute;
        left:calc(((100vw - 1100px) / 2) * -1);
        z-index:-1;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt .pict{
        left:auto;
        right:calc(((100vw - 1100px) / 2) * -1);
    }
    .dl-srv dd .desc{
        padding:40px;
    }
    /* pattern 2 */
    .dl-srv2 dd h3{
        min-height:40px;
    }
    .br_ele{
        display:none;
    }
    /* 不動産管理 */
    .realestate-sec .ul-srv2>li{
        width:33.333%;
        padding:0;
    }
    .realestate-sec .ul-srv2>li:nth-of-type(3n+1){
        padding-right:10px;
    }
    .realestate-sec .ul-srv2>li:nth-of-type(3n+2){
        padding:0 5px;
    }
    .realestate-sec .ul-srv2>li:nth-of-type(3n){
        padding-left:10px;
    }
    .realestate-sec .dl-srv2 dd h3{
        white-space:nowrap;
        letter-spacing: 0;
    }
    .realestate-sec .dl-srv2 dd{
        padding-left:0;
        padding-right:0;
    }
    /* 緊急対応サービス */
    .emergency-sec .dl-srv2 dt .pict{
        max-width:400px;
    }
}
@media(min-width:1400px){
    .dl-srv dt .pict{
        width:calc(1280px * 0.5);
        position:absolute;
        left:0;
        z-index:-1;
    }
    .ul-srv li:nth-of-type(2n) .dl-srv dt .pict{
        left:auto;
        right:0;
    }
}
/*==========================================================*/
/* archive works                                            */
/*==========================================================*/
.works-sec{
    position:relative;
}
.hd-style-cat{
    display:flex;
    justify-content:center;
    width:100%;
    margin-bottom:20px;
}
.hd-style-cat>h2{
    font-weight:700;
}
.hd-style-cat>h2 .en{
    font-size:24px;
}
.hd-style-cat>h2 .jp{
    font-size:16px;
    margin-left:10px;
    color:var(--main-color);
}
.case_study_catlist{
    width:100%;
    margin-bottom:40px;
}
.case_study_catlist .pc{
    display:none;
    width:100%;
}
.case_study_catlist .sp{
    display:block;
    width:100%;
}
select.cl_categoryselect{
    width:100%;
    height:50px;
    padding:5px;
    background-color:#fff;
    color:var(--font-color);
}
.case_study_catlist .wrap>div{
    display:none;
}
.case_study_catlist .wrap>div.active{
    display:block;
}
.case_study_catlist .wrap{
    width:100%;
    margin-top:20px;
}
.ul-works_cat{
    width:100%;
    display:flex;
    align-items:center;
    margin:0;
    padding:0;
    list-style:none;
    flex-flow:row wrap;
}
.ul-works_cat>li{
    width:50%;
    padding:0 5px;
    margin-bottom:10px;
}
.ul-works_cat>li>a{
    width:100%;
    height:50px;
    display:flex;
    justify-content:center;
    align-items:center;
    border:solid 1px var(--font-color);
    text-align:center;
    line-height:1.2;
    transition:all 0.5s;
}
.ul-works_cat>li>a:hover{
    background:var(--main-color);
    color:#fff;
}
.ul-works_cat>li.current{
    background:transparent;
}
.ul-works_cat>li.current a{
    background:var(--focus-color);
    color:#fff;
    border-color:#f0f0f0;
    pointer-events: none;
}
@media(min-width:768px){
    .hd-style-cat>h2 .en{
        font-size:32px;
    }
    .hd-style-cat>h2 .jp{
        font-size:24px;
    }
    .case_study_catlist .pc{
        display:block;
    }
    .case_study_catlist .sp{
        display:none;
    }
    .ul_case_study_catlist {
        width: 100%;
        display: flex;
        flex-flow: row;
        margin: 0px;
        padding: 0px;
        border-bottom: 1px solid rgb(204, 204, 204);
        list-style: none;
    }
    .ul_case_study_catlist > li > div {
        height: 45px;
        width: 120px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: 500;
        pointer-events: auto;
        cursor: pointer;
        background: var(--bk-category-btn);
        border-right: 1px solid rgb(255, 255, 255);
        transition: 0.3s;
    }
    .ul_case_study_catlist > li > a {
        height: 45px;
        width: 120px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-weight: 500;
        background: var(--bk-category-btn);
        border-right: 1px solid rgb(255, 255, 255);
        transition: 0.3s;
    }
    .ul_case_study_catlist > li.active div {
        color: rgb(255, 255, 255);
        pointer-events: none;
        background: var(--focus-color);
    }
    .ul_case_study_catlist > li > a:hover {
        filter: brightness(1.1);
    }
    .ul_case_study_catlist > li > div:hover {
        filter: brightness(1.1);
    }
    .ul_case_study_catlist>li.active a {
        background: var(--focus-color);
        color: #fff;
        pointer-events: none;
    }
}
@media(min-width:992px){
    .ul-works_cat>li{
        width:25%;
    }
}
/*==========================================================*/
/* signle works                                            */
/*==========================================================*/
.entry-body-hd{
    width:100%;
    padding-bottom:40px;
}
.entry-body-bd{
    width:100%;
    padding-top:40px;
}
.works-summary-wrap .box{
    width: 100%;
    background: var(--thin-color);
    padding: 30px 10px;
    border-radius: 5px;
}
.works-summary-wrap .box .tpworks-desc{
    color:#fff;
}
.works-summary-wrap .box .tpworks-desc p{
    color:#fff;
}
.entry-body .works-summary-wrap img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
@media(min-width:992px){
    .works-summary-wrap .dl-tpworks>dt{
        width:100%;
        margin-bottom:40px;
    }
    .works-summary-wrap .dl-tpworks>dd{
        width:100%;
    }
    .works-summary-wrap .tpworks-option{
        justify-content:flex-start;
    }
    .works-summary-wrap .dl-period, .works-summary-wrap .dl-cost{
        max-width:300px;
        margin-right:20px;
    }
}
/*==========================================================*/
/* signle voice                                            */
/*==========================================================*/
.column-wrap{
    width:100%;
}
.entry-body{
    width:100%;
}
.voice-sec .entry-body-hd{
    padding-bottom:20px;
}
.voice-sec .entry-body-bd{
    padding:0;
}
.voice-summary-wrap{
    width:100%;
}
.voice-summary-hd{
    width:100%;
}
.voice-summary-hd .v_sub_ttl{
    white-space:nowrap;
}
/*==========================================================*/
/* contact                                                  */
/*==========================================================*/
.contact-sec{
    position:relative;
}
.before-contact-wrap{
    width:100%;
    margin-bottom:40px;
}
.dl-contact{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    margin:0;
}
.dl-contact dt{
    width:100%;
    margin-bottom:20px;
}
.dl-contact dd{
    width:100%;
    margin-bottom:0;
}
.contact-box{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
    padding:40px 0;
    border-radius:5px;
}
.dl-contact dt .contact-box{
    background:var(--thin-bk-color);
}
.dl-contact dd .contact-box{
    background:var(--thin-line-color);
}
.contact-box h2{
    font-size:24px;
    font-weight:700;
    text-align:center;
    margin-bottom:10px;
}
.telno-wrap{
    width:100%;
    display:flex;
    justify-content:center;
    align-items: center;
    margin-bottom:10px;
}
.telno-wrap p{
    display:flex;
    font-size:24px;
    align-items:center;
}
.telno-wrap .telnolink{
    position:relative;
}
.telno-wrap .telnolink:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--font-color);
    transform:scale(0, 1);
    transform-origin:right center;
    transition:transform 0.5s;
    position:absolute;
    bottom:0;
    left:0;
}
.telno-wrap .telnolink:hover:before{
    transform:scale(1, 1);
    transform-origin:left center;
}
.telno-wrap i{
    margin-right:5px;
    color:var(--deep-color);
    font-size:32px;
}
.contact-box>div>p{
    text-align:center;
}
.line-wrap{
    width:100%;
    margin-bottom:10px;
}
.line-wrap a{
    width:100%;
    max-width:280px;
    height:50px;
    border-radius:25px;
    display:flex;
    justify-content: center;
    align-items:center;
    background:var(--line-btn-color);
    color:#fff;
    letter-spacing:0.1em;
    position:relative;
    margin-left:auto;
    margin-right:auto;
    transition:all 0.5s;
}
.line-wrap a i{
    font-size:32px;
    position:absolute;
    top:50%;
    left:50px;
    translate:0 -50%;
}
.line-wrap a:hover{
    filter:brightness(1.1);
}
.contact-wrap{
    margin-top:80px;
}
.contact-wrap .inner{
    margin-bottom:40px;
}
@media(min-width:768px){
    .telno-wrap .telnolink{
        font-weight:700;
    }
}
@media(min-width:992px){
    .before-contact-wrap>p{
        text-align:center;
    }
    .dl-contact{
        justify-content: space-between;
    }
    .dl-contact dt{
        width:49%;
        margin-bottom:0;
    }
    .dl-contact dd{
        width:49%;
    }
    .contact-box{
        height:210px;
    }
}
/*==========================================================*/
/* privacy policy                                           */
/*==========================================================*/
.pri_sec{
    position:relative;
}
.detail-wrap{
    margin-top:60px;
}
.detail-wrap .h2org{
    text-align:left;
    margin-bottom:30px;
}
.ul_pri{
    margin-top:20px;
    padding-left:20px;
    margin-bottom:0;
}
.ul_pri li{
    margin-top:10px;
    font-size:16px;
}
.detail-wrap a{
    color:var(--deep-color);
    font-weight:700;
    position:relative;
}
.detail-wrap a:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--deep-color);
    transform:scale(0, 1);
    transform-origin:right center;
    transition:transform 0.5s;
    position:absolute;
    bottom:0;
    left:0;
}
.detail-wrap a:hover:before{
    transform:scale(1, 1);
    transform-origin:left center;
}
@media(min-width:768px){
    .detail-wrap .h2org{
        font-size:24px;
    }
}
/*==========================================================*/
/* company page                                             */
/*==========================================================*/
.mission-sec{
    position:relative;
}
.mission-wrap{
    width:100%;
}
.dl-mission{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    justify-content:space-between;
    margin:0;
}
.dl-mission>dt{
    width:100%;
    margin-bottom:40px;
}
.dl-mission>dd{
    width:100%;
}
.dl-mission>dt .pict{
    width:100%;
    padding-top:56.25%;
    position:relative;
}
.dl-mission>dt .pict video{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
}
.dl-mission>dd{
    width:100%;
    margin:0;
}
.dl-mission>dd .box{
    width:100%;
}
.dl-mission>dd .box h3{
    font-size:24px;
    font-weight:700;
    margin-bottom:20px;
}
.dl-mission>dd .box .desc p{
    line-height:2;
    letter-spacing:0.1em;
}
.message-sec{
    position:relative;
    background:var(--bk-thin-color);
}
.message-wrap{
    width:100%;
}
.dl-message{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    justify-content:space-between;
    margin:0;
}
.dl-message>dt{
    width:100%;
    margin-bottom:40px;
}
.dl-message>dd{
    width:100%;
}
.dl-message>dt .pict{
    width:100%;
    position:relative;
}
.dl-message>dt .pict>img{
    width:100%;
    aspect-ratio:16/9;
    object-fit:cover;
}
.dl-message>dd{
    width:100%;
    margin:0;
}
.dl-message>dd .box{
    width:100%;
}
.dl-message>dd .box h3{
    font-size:24px;
    font-weight:700;
    margin-bottom:20px;
}
.dl-message>dd .box .desc p{
    line-height:2;
    letter-spacing:0.1em;
}
.representative{
    margin-top:20px;
}
.representative p{
    font-weight:700;
}
.company-sec{
    position:relative;
}
.company-wrap{
    width:100%;
}
.tbl-company{
    width:100%;
}
.tbl-company tr{
    display:block;
    width:100%;
    margin-bottom:20px;
}
.tbl-company th{
    display:block;
    width:100%;
    padding:1em;
    border:solid 1px var(--tbl-bd-color);
    background:var(--tbl-th-color);
    font-weight:500;
}
.tbl-company td{
    display:block;
    width:100%;
    padding:1em;
    border-left:solid 1px var(--tbl-bd-color);
    border-right:solid 1px var(--tbl-bd-color);
    border-bottom:solid 1px var(--tbl-bd-color);
    font-weight:500;
}
.tbl-company td p>span{
    display:inline-block;
}
.ul-companyprofile{
    width:100%;
    padding-left:20px;
    margin-bottom:0;
}
.access-sec{
    position:relative;
    background:var(--bk-thin-color);
}
.access-wrap{
    width:100%;
}
.access-wrap .map{
    position:relative;
    width:100%;
    padding-top:100%;
}
.access-wrap .map iframe{
    width:100%;
    height:100%;
    position:absolute;
    top:0;
    left:0;
}
@media(min-width:768px){
    .dl-mission>dd .box h3{
        font-size:32px;
    }
    .dl-message>dd .box h3{
        font-size:32px;
    }
    .access-wrap .map{
        position:relative;
        width:100%;
        padding-top:500px;
    }
    .br_add{
        display:none;
    }
}
@media(min-width:992px){
    .mission-sec{
        padding-bottom:80px;
    }
    .message-sec{
        padding:80px 0;
    }
    .message-wrap .forpc{
        display:block;
    }
    .message-wrap .forsp{
        display:none;
    }
    .message-wrap .h3org{
        font-size:32px;
        margin-bottom:40px;
        text-align:center;
    }
    .dl-message>dt{
        width:38%;
        margin-bottom:0;
        order:2;
    }
    .dl-message>dd{
        width:58%;
        order:1;
    }
    .dl-message>dt .pict>img{
        width:100%;
        height:692px;
        aspect-ratio:unset;
        object-fit:cover;
        object-position:right center;
    }
    .company-sec{
        padding:80px 0;
    }
    .tbl-company{
        border-top:solid 1px var(--tbl-bd-color);
    }
    .tbl-company tr{
        margin-bottom:0;
        display:table-row;
    }
    .tbl-company th{
        width:30%;
        display:table-cell;
        border-top:none;
        border-left:none;
        border-right:none;
        background:transparent;
        padding:2em 1em;
    }
    .tbl-company td{
        width:70%;
        display:table-cell;
        border-left:none;
        border-right:none;
        padding:2em 1em;
    }
    .access-sec{
        padding:80px 0;
    }
}
@media(min-width:1200px){
    .dl-message>dt .pict>img{
        height:628px;
    }
}
@media(min-width:1400px){
    .dl-message>dt .pict>img{
        height:596px;
    }
}
/*==========================================================*/
/* service fee page                                         */
/*==========================================================*/
.service-fee-sec{
    position:relative;
}
.price-intro{
    width:100%;
    margin-bottom:40px;
}
.price-intro p{
    line-height:2;
    letter-spacing: 0.1em;
}
.price-block{
    margin-bottom:80px;
}
.price-block h2, .price-notes h2{
    font-size:24px;
    font-weight:700;
    margin-bottom:20px;
    padding-bottom:10px;
    position:relative;
}
.price-block h2:before,  .price-notes h2:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--main-color);
    position:absolute;
    bottom:0;
    left:0;
}
.price-caption{
    width:100%;
    margin-bottom:20px;
}
.price-caption p{
    letter-spacing:0.1em;
    line-height: 2;
}
.tbl-scroll{
    width:100%;
}
.tbl-price{
    width:100%;
}
.tbl-price thead{
    display:none;
}
.tbl-price tbody tr{
    display:block;
    width:100%;
    margin-top:20px;
}
.tbl-price tbody th{
    display:block;
    width:100%;
    padding:1em 0.5em;
    border:solid 1px var(--tbl-bd-color);
    background:var(--tbl-th-color);
    text-align:center;
    font-weight:500;
}
.tbl-price tbody td{
    display:block;
    width:100%;
    padding:1em;
    border-left:solid 1px var(--tbl-bd-color);
    border-right:solid 1px var(--tbl-bd-color);
    border-bottom:solid 1px var(--tbl-bd-color);
    font-weight:500;
    text-align:center;
}
.price-notes{
    margin-top:20px;
    margin-bottom:40px;
}
.price-notes p{
    letter-spacing:0.1em;
    line-height:2;
}
.price-notes-box{
    width:100%;
    margin-bottom:40px;
    background:var(--thin-bk-color);
    border-radius:10px;
    padding:20px;
}
.price-notes-box h3{
    font-size:20px;
    margin-bottom:20px;
}
.ul-price-notes{
    margin:0;
    padding-left:20px;
}
.estimate-sec{
    position:relative;
    background:var(--deep-color);
}
.price-cta{
    width:100%;
}
.price-cta h4{
    font-size:24px;
    font-weight:700;
    text-align:center;
    position:relative;
    padding-bottom:20px;
    margin-bottom:40px;
    color:#fff;
}
.price-cta h4:before{
    content:'';
    width:120px;
    height:4px;
    background:var(--focus-color);
    position:absolute;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
}
.price-cta>p{
    line-height:2;
    letter-spacing:0.1em;
    color:#fff;
}
.btn-area{
    width:100%;
    margin-top:40px;
}
.btn-area a{
    width:300px;
    height:50px;
    border-radius:30px;
    background:var(--focus-color);
    display:flex;
    justify-content: center;
    align-items:center;
    margin:0 auto;
    color:#fff;
    font-weight:700;
    transition:all 0.5s;
}
.btn-area a:hover{
    color:#fff;
    filter:brightness(1.1);
}
@media(min-width:768px){
    .price-cta h4{
        font-size:32px;
    }
}
@media(min-width:992px){
    .tbl-price thead{
        display:table-header-group;
    }
    .tbl-price thead th{
        display:table-cell;
        width:33.333%;
        padding:1em;
        text-align:left;
        border-top:solid 1px var(--tbl-bd-color);
        border-left:solid 1px var(--tbl-bd-color);
        border-bottom:solid 1px var(--tbl-bd-color);
        background:var(--main-color);
        color:#fff;
    }
    .tbl-price thead th:first-of-type{
        width:40%;
    }
    .tbl-price thead th:nth-of-type(2){
        width:25%;
    }
    .tbl-price thead th:last-of-type{
        border-right:solid 1px var(--tbl-bd-color);
        width:35%;
    }
    .tbl-price tbody tr{
        display:table-row;
        width:100%;
        margin-top:0;
    }
    .tbl-price tbody th{
        display:table-cell;
        width:40%;
        padding:1em 0.5em;
        border-top:none;
        background:transparent;
        text-align:left;
    }
    .tbl-price tbody td{
        display:table-cell;
        padding:1em;
        border-left:none;
        width:30%;
    }
    .tbl-price tbody td:first-of-type{
        width:25%;
        text-align:right;
    }
    .tbl-price tbody td:last-of-type{
        width:35%;
        text-align:left;
    }
    .sp-tax{
        display:none;
    }
    .price-notes-wrap{
        display:flex;
        width:100%;
        flex-flow:row wrap;
        justify-content:space-between;
        margin-bottom:10px;
    }
    .price-notes-box{
        width:48%;
        margin-bottom:0;
    }
    .estimate-sec{
        padding:80px 0;
    }
    .price-cta>p{
        text-align:center;
    }
}
/*==========================================================*/
/* business partner page                                    */
/*==========================================================*/
.partners-sec{
    position:relative;
}
.partners-block{
    width:100%;
    margin-bottom:40px;
}
.partners-block h2{
    font-size:24px;
    font-weight:700;
    margin-bottom:20px;
    padding-bottom:10px;
    position:relative;
}
.partners-block h2:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--main-color);
    position:absolute;
    bottom:0;
    left:0;
}
.dl-flexbox{
    display:flex;
    width:100%;
    flex-flow:row wrap;
    justify-content:space-between;
    margin:0;
}
.dl-flexbox>dt{
    width:100%;
    margin-bottom:20px;
}
.dl-flexbox>dd{
    width:100%;
    margin:0;
}
.dl-flexbox>dt .pict{
    width:100%;
}
.dl-flexbox>dt .pict>img{
    width:100%;
    aspect-ratio:16/9;
    object-fit:cover;
}
.dl-flexbox>dd .box{
    width:100%;
    margin:0;
}
.dl-flexbox>dd .box p{
    line-height:2;
    letter-spacing: 0.1em;
}
.ul-parner{
    display:flex;
    flex-flow:row wrap;
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
    justify-content: space-between;
}
.ul-parner>li{
    width:100%;
    margin-top:40px;
    background:var(--thin-bk-color);
    border-radius:5px;
}
.ul-parner>li .box{
    width:100%;
    padding:20px;
}
.ul-parner>li .box h3{
    font-size:20px;
    margin-bottom:20px;
    font-weight:700;
    text-align:center;
    color:var(--deep-color);
}
.ul-pochi{
    width:100%;
    margin:20px 0;
    list-style-type:disc;
    padding-left:20px;
}
.partner-cta-sec .price-cta>div>p{
    color:#fff;
}
@media(min-width:768px){
    .ul-parner>li{
        width:49%;
    }
    .ul-parner>li:last-of-type{
        width:100%;
        margin-left:auto;
        margin-right:auto;
    }
}
@media(min-width:992px){
    .ul-parner{
        justify-content: space-between;
    }
    .ul-parner>li{
        width:48%;
    }
    .dl-flexbox>dt{
        width:49%;
        order:2;
    }
    .dl-flexbox>dd{
        width:49%;
        order:1;
    }
    .dl-flexbox>dt .pict>img{
        aspect-ratio: 5/3;
    }
}
/*==========================================================*/
/* business partner page                                    */
/*==========================================================*/
.recruit-pgheader{
    height:600px;
}
.recruit-pgheader:after{
    background:rgb(31, 75, 155,0.5);
    z-index:1;
}
.pg-hd-wrap{
    width:100%;
    height:600px;
    position:absolute;
    top:0;
    left:0;
    z-index:2;
    padding:20px;
}
.pg-hd-recruit-ttl{
    width:100%;
    display:flex;
    justify-content: flex-end;
    margin-bottom:20px;
}
.pg-hd-recruit-ttl p{
    font-size:12px;
    color:#fff;
    font-weight:700;
    text-align:center;
}
.pg-hd-recruit-ttl h1{
    font-size:16px;
    color:#fff;
    font-weight:700;
}
.pg-hd-recruit-desc{
    width:100%;
}
.pg-hd-recruit-desc h2{
    font-size:18px;
    color:#fff;
    margin-bottom:20px;
    font-weight:700;
}
.pg-hd-recruit-desc p{
    font-size:14px;
    font-weight:500;
    color:#fff;
}
.pg-hd-recruit-desc p br{
    display:none;
}
.ul-pg-hd-point{
    width:100%;
    padding-left:20px;
    margin-top:10px;
}
.ul-pg-hd-point>li{
    font-size:14px;
    color:#fff;
}
/*recruit list */
.ul-hd-rec{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    list-style:none;
    margin:0 0 40px 0;
    padding:0;
}
.ul-hd-rec>li{
    width:auto;
    padding-right:10px;
    margin-top:10px;
}
.ul-hd-rec>li button{
    border:0;
    background:#fff;
    border:solid 1px var(--main-color);
    padding:0.5em 1em;
    color:var(--main-color);
    transition:all 0.5s;
    font-size:14px;
}
.ul-hd-rec>li button:hover{
    background:var(--main-color);
    color:#fff;
}
.ul-hd-rec>li.active button{
    background:var(--main-color);
    color:#fff;
    pointer-events:none;
}
.ul-bd-rec{
    display:block;
    padding:0;
    margin:0;
    list-style:none;
}
.ul-bd-rec>li{
    width:100%;
    display:none;
}
.ul-bd-rec>li.active{
    display:block;
}
.tbl-rec{
    width:100%;
}
.tbl-rec tr{
    display:block;
    margin-bottom:20px;
}
.tbl-rec th{
    display:block;
    padding:1em 0.5em;
    border:solid 1px var(--tbl-bd-color2);
    background:var(--tbl-th-color2);
}
.tbl-rec td{
    display:block;
    padding:1em 0.5em;
    border-left:solid 1px var(--tbl-bd-color2);
    border-right:solid 1px var(--tbl-bd-color2);
    border-bottom:solid 1px var(--tbl-bd-color2);
}
.h3rec{
    font-size:18px;
    font-weight:700;
    padding-bottom:20px;
    margin-bottom:40px;
    position:relative;
    text-align:center;
}
.h3rec:before{
    content:'';
    width:80px;
    height:4px;
    background:var(--main-color);
    position:absolute;
    bottom:0;
    left:50%;
    translate:-50% 0;
}
@media(min-width:768px){
    .pg-hd-wrap{
        padding:40px;
    }
    .pg-hd-recruit-ttl p{
        font-size:14px;
    }
    .pg-hd-recruit-ttl h1{
        font-size:18px;
    }
    .pg-hd-recruit-desc h2{
        font-size:20px;
    }
    .pg-hd-recruit-desc h2 br{
        display:none;
    }
    .pg-hd-recruit-desc p{
        font-size:16px;
    }
    .ul-pg-hd-point>li{
        font-size:16px;
    }
    .h3rec{
        font-size:24px;
        padding:30px;
    }
}
@media(min-width:992px){
    .recruit-sec{
        padding-bottom:80px;
    }
    .pg-hd-recruit-ttl p{
        font-size:20px;
    }
    .pg-hd-recruit-ttl h1{
        font-size:26px;
    }
    .pg-hd-recruit-desc h2{
        font-size:32px;
    }
    .pg-hd-recruit-desc p{
        font-size:17px;
    }
    .ul-pg-hd-point>li{
        font-size:17px;
    }
    .tbl-rec{
        border-top:solid 1px var(--tbl-bd-color);
    }
    .tbl-rec tr{
        display: table-row;
        margin-bottom:0;
    }
    .tbl-rec th{
        width:35%;
        display: table-cell;
        border-top:none;
        padding-left:1em;
    }
    .tbl-rec td{
        width:65%;
        display: table-cell;
        border-left:none;
    }
    .h3rec{
        font-size:32px;
    }
}
@media(min-width:1200px){
    .pg-hd-wrap>div{
        max-width:1010px;
        margin-left:auto;
        margin-right:auto;
    }
}
/*==========================================================*/
/* side-fixed-btn                                           */
/*==========================================================*/
.side-fixed-btn{
    position:fixed;
    top:50%;
    right:0;
    translate:0 -50%;
    width:40px;
    z-index: 9999;
    background: var(--side-fixed-btn-color);
    color:#fff;
    border-radius: 8px 0 0 8px;
    padding:20px 0;
    display:none;
    box-shadow:0 0 10px rgba(0,0,0,0.1);
    transition:all 0.5s;
}
.side-fixed-btn:hover{
    filter:brightness(1.1);
}
.side-fixed-btn > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.side-fixed-btn img {
  width: 28px;
  height: auto;
  margin-bottom:5px;
}
.side-fixed-btn span {
  writing-mode: vertical-rl;   /* 縦書き */
  text-orientation: mixed;     /* 英数字を自然な向きに */
  letter-spacing: 0.2em;
  font-size: 14px;
}
.page-contact .side-fixed-btn{
    display:none!important;
}
@media(min-width:992px){
    .side-fixed-btn{
        width:50px;
    }
    .side-fixed-btn img {
        width:35px;
    }
    .side-fixed-btn span {
        font-size:16px;
    }
}
