/*!
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=Libre+Baskerville:ital,wght@0,400..700;1,400..700&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
/************************************************************/
:root{
    --bk-body-color:#1F2E3C;
    --bk-body-color2:#111111;
    --bk-body-color3:#263f57;
    --font-color:#ccc;
    --font-color2:#BFC7CF;
    --font-color3:#f7f7f7;
    --btn-color:#BFC7CF;
    --bk-sec-color:#ccc;
    --btn-hover-color:#999;
    --h2-emphasis-color:#999;
    --h2pg-color:#999;
    --focus-color:#999;
    --bk-desc-color:#233b57;
    --bk-desc-color-pc:rgb(35, 59, 87, 0.8);
    --bk-desc-color2:rgb(170, 170, 170, 0.8);
    --bk-desc-color3:#ccc;
    --bk-beforeft-color:#233b57;
    --main-color:#f2f2f2;
    --bk-accent-color:transparent;
    --faq-bk-color:#1F2E3C;
    --q-mark-color:#ccc;
    --a-mark-color:#ccc;
    --require-color:#999;
    --submit-btn:#999;
    --noto-sans:"Noto Sans JP", sans-serif;
    --noto-serif:"Noto Serif JP", serif;
    --libre:"Libre Baskerville", serif;
    --burger-bkcolor:transparent;
    --ptnB-sp-header-height:60px;
    --ptnB-pc-header-height:60px;
    --sp-pgheader-height: 250px;
    --tb-pgheader-height: 300px;
    --pc-pgheader-height: 450px;
}
/*==========================================================*/
/* defalt define											*/
/*==========================================================*/
body, p{
    font-size:16px;
    letter-spacing:0.1em;
    font-family:var(--noto-serif);
    color:var(--font-color);
    text-align:justify;
    font-weight:400;
}
body a{
    color:#333;
}
body a:hover{
    color:#333;
}
.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;
    }
}
/*==========================================================*/
/* body         											*/
/*==========================================================*/
.wpcf7 form.sent .wpcf7-response-output{
    border-color:var(--font-color);
}
.error-sec{
    background:var(--bk-body-color);
    padding:80px 0;
}
/*==========================================================*/
/* body         											*/
/*==========================================================*/
.siteContent{
    background:var(--bk-body-color);
}
/*==========================================================*/
/* header         											*/
/*==========================================================*/
.site-header.ptnB{
    height:0;
}
.site-header-wrap{
    height:var(--ptnB-sp-header-height);
    position:fixed;
    top:0;
    left:0;
    box-shadow:none;
    z-index:1950;
    background:rgb(31, 46, 60, 0.7);
}
.front-page .site-header-wrap{
    background:transparent;
}
.scrolled .ptnB .site-header-wrap{
    background:rgb(31, 46, 60, 0.7);
    backdrop-filter: blur(2px);
}
.site-header-logo{
    height:100%;
}
.site-header-logo a{
    display:flex;
    width:100%;
    height:100%;
}
.dl-logo{
    height:100%;
    margin:0;
    display:flex;
}
.dl-logo>dt{
    width:60px;
    height:100%;
    margin:0;
}
.dl-logo>dd{
    display:flex;
    align-items:center;
    width:calc(100% - 60px);
    height:100%;
    margin:0;
}
.dl-logo>dd .desc{
    color:var(--logo-gradient2);
    line-height:1;
}
.dl-logo>dd .desc strong{
    display:block;
    font-size:30px;
    font-family:var(--libre);
    margin-bottom:4px;
}
.dl-logo>dd .desc small{
    display:block;
    font-size:10px;
    font-family:var(--libre);
    letter-spacing: 0;
}
@media(min-width:992px){
    .site-header-wrap{
        height:var(--ptnB-pc-header-height);
        position:fixed;
    }
}
.section.breadSection{
    background:var(--bk-body-color);
}
.breadSection .breadcrumb a, .breadSection .breadcrumb span{
    color:var(--font-color);
}
/*==========================================================*/
/* page header     											*/
/*==========================================================*/
.page-header{
    overflow:hidden;
}
.page-header-wrap{
    filter: blur(1px) grayscale(50%);
}
.page-header-wrap{
    transform-origin:center center;
    transform:scale(1.05);
}
.page-header-ttl{
    top:calc(50% + 30px);
}

/*==========================================================*/
/* mobile         											*/
/*==========================================================*/
.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:var(--font-color3);
    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     											*/
/*==========================================================*/
.site-mobile-nav{
    padding:20px 0;
}
.site-mobile-nav>div{
    padding:0;
}
.site-mobile-menu>li{
    margin:0;
    padding:0;
    border:none;
}
.site-mobile-menu>li>a{
    color:var(--font-color);
    padding:0;
    margin:0;
    width:100%;
    height:50px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    padding-left:30px;
    transition:all 0.5s;
}
.site-mobile-menu>li>a:hover{
    background:var(--btn-hover-color);
    color:var(--bk-body-color);
}
/*==========================================================*/
/* global menu     											*/
/*==========================================================*/
@media(min-width:992px){
    .site-header-menu>li>a{
        font-family:var(--libre);
        letter-spacing:0.1em;
        font-weight:400;
        transition:all 0.5s;
    }
    .site-header-menu>li>a:hover{
        color:var(--menu-gradient2);
    }
}
/*==========================================================*/
/* loading      											*/
/*==========================================================*/
.intro-layers{
    width:100vw;
    height:100vh;
    position:fixed;
    top:0;
    left:0;
    z-index:3000;
}
.intro-layers .wrap{
    width:100%;
    height:100%;
    background:var(--bk-body-color);
    display:flex;
    justify-content:center;
    align-items:center;
}
.logo_title{
    width:300px;
    opacity:0;
}
.intro-layers .dl-logo{
    align-items:center;
}
.intro-layers .dl-logo>dd{
    padding-left:10px;
}
.intro-layers .dl-logo>dd .desc strong{
    font-size:45px;
}
.intro-layers .dl-logo>dd .desc small{
    font-size:12px;
}
@media(min-width:768px){
    .logo_title{
        width:auto;
        opacity:0;
    }
    .intro-layers.dl-logo>dt{
        width:75px;
    }
    .intro-layers .dl-logo>dd .desc strong{
        font-size:55px;
    }
    .intro-layers .dl-logo>dd .desc small{
        font-size:12px;
    }
    .intro-layers .dl-logo>dd{
        width:fit-content;
    }
}
/*==========================================================*/
/* 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-right.scroll-in{
    transform:translateX(0);
    opacity:1;
}
*/
/* addition */
.fade-right{
    opacity:1;
    position:relative;
}
.fade-right>div{
    opacity:0;
    transition:opacity 0.3s linear 1s;
    overflow:hidden;
}
.fade-right:before{
    content:'';
    position:absolute;
    top:0;
    left:0;
    width:0%;
    height:100%;
    background:var(--bk-desc-color3);
    transform:translateX(0);
    transition: width 1s cubic-bezier(0.55, 0.055, 0.675, 0.19),
    transform 0.8s ease 1.1s;
    z-index:1;
}
.fade-right.scroll-in:before{
    width:100%;
    transform: translateX(100%);
}
.fade-right.scroll-in>div{
    opacity:1;
}
.fade-right2{
  position: relative;
  overflow: hidden;
  opacity: 1;
}
.fade-right2:before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  height:100%;
  width:0%;
  background:var(--bk-sec-color);
  transition: width 1s cubic-bezier(0.55, 0.055, 0.675, 0.19);
  z-index:1;
}
.fade-right2.scroll-in:before{
    width:100%;
}
.fade-right2 > *{
  opacity:0;
  transform: translateY(6px);
  transition: opacity .6s ease 1s, transform .6s ease 1s;
  position:relative;
  z-index:5;
}
.fade-right2.scroll-in > *{
  opacity:1;
  transform: translateY(0);
}
/**/
.fade-left{
    transform:translateX(100%);
    opacity:0;
    transition:all 1s cubic-bezier(0.77, 0, 0.175, 1);
}
.fade-left.scroll-in{
    transform:translateX(0);
    opacity:1;
}
/* ribbon */
.anime-slide{
    position: relative;
    display: table;
    overflow: hidden;
}
.anime-slide>.anime-word{
    opacity: 0;
    transform: translateY(6px); /* a little move */
    transition: opacity .2s linear, transform .2s ease;
    transition-delay: 0s;
}
.anime-slide::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--btn-hover-color);
  z-index: 5;
  transform: scaleX(0);
  transform-origin: left center;
}
.anime-slide::after{
  content:"";
  position:absolute;
  inset:0;
  background: var(--btn-hover-color);
  z-index: 5;
  transform: scaleX(1);
  transform-origin: right center;
  opacity: 0;
}
/* active */
.anime-slide.active>.anime-word{
    opacity: 1;
    transform: translateY(0);
    transition-delay: 0.6s;
}
.anime-slide.active::before{
    animation: ribbon-in 0.6s cubic-bezier(0.77,0,0.175,1) forwards;
}
.anime-slide.active::after{
  animation: ribbon-out 0.6s cubic-bezier(0.77,0,0.175,1) forwards;
  animation-delay: 0.6s;
}
@keyframes ribbon-in{
    0%   { transform: scaleX(0); opacity: 1; }
    99.9999% { transform: scaleX(1); opacity: 1; }
    100% { transform: scaleX(1); opacity: 0; }
}
@keyframes ribbon-out{
    0%   { transform: scaleX(1); opacity: 1; }
    100% { transform: scaleX(0); opacity: 1; }
}
@keyframes passing-bar{
	0% {
		left: 0;
		width: 0;
	}
	50% {
		left: 0;
		width: 100%;
	}
	51% {
		left: 0;
		width: 100%;
	}
	100% {
		left: 100%;
		width: 0;
	}
}
@keyframes passing-txt{
	0% { opacity:0; }
	70% { opacity:0; }
	100% { opacity:1; }
}
@keyframes fade-in{
	0% {
         opacity:0;
         transform:translateY(20px);
    }
	100% {
        opacity:1;
        transform:translateY(0);
    }
}
/*==========================================================*/
/* top slide      											*/
/*==========================================================*/
.tpslide-sec{
    position:relative;
    padding:0;
}
.tpslide-sec.page-section{
    padding:0;
}
.slider-wrapper{
    width:100%;
    position:relative;
    height:100vh;
}
.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:100vh;
    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:var(--font-color);
    font-size:26px;
    font-weight:700;
    letter-spacing:0;
    line-height:1.4;
    margin-bottom:20px;
    font-family:var(--libre);
    letter-spacing:0.1em;
}
.catchcopy p{
    color:var(--font-color);
    font-size:14px;
    font-weight:700;
    letter-spacing:0;
}
/* scroll arrow */
.scroll-arrow {
    display: flex;
    writing-mode: vertical-rl;
    position: absolute;
    left: 50%;
    bottom: 1%;
    transform:translateX(-50%);
    z-index:15;
}
.scroll-arrow a{
    letter-spacing: 5px;
    font-size: 12px;
    position: relative;
    padding-top: 10px;
    text-decoration: none;
    transition:all 0.3s;
    color:#fff;
}
.scroll-arrow a:hover{
    color:#fff;
    opacity:0.8;
}
.scroll-arrow a:before{
    content: '';
    width: 1px;
    height: 5px;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    animation: extend-anime 2s ease-out infinite;
    z-index: 2;
}
.scroll-arrow a:after{
    content: '';
    width: 1px;
    height: 10px;
    background: #fff;
    transform: rotate(-45deg);
    position: absolute;
    top: -3px;
    left: -4px;
    animation: move-anime 2s ease-out infinite;
}
@keyframes extend-anime{
    0% {
        height:5px;
    }
    100%{
        height:100%;
    }
}
@keyframes move-anime{
    0% {
        top:-3px;
    }
    100%{
        top:calc(100% - 10px);
    }
}
@media(min-width:768px){
    .catchcopy{
        padding-left:calc((100vw - 700px) / 2);
    }
    .catchcopy h2{
        font-size:40px;
        letter-spacing: 0;
    }
    .catchcopy p{
        font-size:20px;
    }
    .scroll-arrow a{
        letter-spacing: 10px;
        font-size:14px;
    }
}
@media(min-width:992px){
    .catchcopy{
        padding-left:calc((100vw - 940px) / 2);
    }
    .catchcopy h2{
        font-size:60px;
    }
    .catchcopy p{
        font-size:24px;
    }
    .slider-wrapper{
        height:100vh;
        max-height:1100px;
    }
    .slider-wrapper .slide img{
        height:100vh;
        max-height:1100px;
    }
}
@media(min-width:1200px){
    .catchcopy{
        padding-left:calc((100vw - 1120px) / 2);
    }
    .catchcopy h2{
        letter-spacing:0.1em;
    }
    .catchcopy p{
        letter-spacing:0.1em;
    }
}
@media(min-width:1400px){
    .catchcopy{
        padding-left:calc((100vw - 1300px) / 2);
    }
}
/*==========================================================*/
/* tpconcept-sec   											*/
/*==========================================================*/
.tpconcept-sec{
    position:relative;
}
.tpconcept-sec .pict{
    width:100%;
    position:absolute;
    top:50%;
    left:0;
    translate:0 -50%;
    z-index:1;
}
.tpconcept-sec .pict img{
    display:table;
    width:200px;
    height:auto;
    margin-left:auto;
    margin-right:auto;
    opacity:0.5;
    filter:blur(1px);
}
.tpconcept-wrap{
    position:relative;
    z-index:10;
    width:100%;
    height:400px;
    display:flex;
    align-items:center;
    justify-content:center;
}
.tpconcept-wrap h2{
    text-align:center;
    font-size:24px;
    margin-bottom:40px;
}
.tpconcept-desc{
    text-align:center;
}
.tpconcept-desc{
    line-height:2;
}
.viewmore-btn{
    position:relative;
    z-index:10;
}
.viewmore-btn a{
    width:280px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--btn-color);
    margin-left:auto;
    margin-right:auto;
    transition:all 0.5s;
}
.viewmore-btn a:hover{
    background:var(--btn-hover-color);
    color:#fff;
}
@media(min-width:768px){
    .tpconcept-wrap{
        height:500px;
    }
    .tpconcept-wrap h2{
        font-size:28px;
    }
    .tpconcept-desc p{
        font-size:18px;
    }
    .sp_br{
        display:none;
    }
    .con_br2{
        display:none;
    }
}
@media(min-width:992px){
    .page-section{
        padding:80px 0;
    }
    .tpconcept-wrap{
        height:600px;
    }
    .tpconcept-wrap h2{
        font-size:32px;
        margin-bottom:60px;
    }
    .tpconcept-desc p{
        font-size:18px;
    }
}
/*==========================================================*/
/* top service     											*/
/*==========================================================*/
.tpsrv-sec{
    position:relative;
}
.dl-tpsrv{
    width:100%;
    margin:0;
}
.dl-tpsrv>dt{
    width:100%;
    margin:0;
}
.dl-tpsrv>dd{
    width:100%;
    margin:0;
    position:relative;
    padding:0 20px;
}
.dl-tpsrv>dt .pict{
    width:100%;
}
.dl-tpsrv>dt .pict>img{
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
}
.dl-tpsrv>dd .desc{
    width:100%;
    position:relative;
    top:-20px;
}
.dl-tpsrv>dd .desc>div{
    padding:20px;
}
.dl-tpsrv>dd .desc>div>div>p{
    color:var(--bk-body-color);
}
.hd-style{
    padding-bottom:10px;
    margin-bottom:30px;
    position:relative;
}
.hd-style:before{
    content:'';
    width:60px;
    height:3px;
    background:var(--bk-body-color);
    position:absolute;
    bottom:0;
    left:50%;
    translate:-50% 0;
}
.hd-style p{
    text-align:center;
    color: var(--bk-body-color);
    margin-bottom:10px;
}
.hd-style h2{
    text-align:center;
    color:var(--bk-body-color);
}
.dl-tpsrv>dd .desc .viewmore-btn{
    margin-top:40px;
}
@media(min-width:768px){
    .dl-tpsrv>dt .pict>img{
        aspect-ratio:5/3;
    }
    .dl-tpsrv>dd{
        padding:0 40px;
    }
    .dl-tpsrv>dd .desc{
        top:-40px;
    }
}
@media(min-width:992px){
    .dl-tpsrv{
        display:flex;
        flex-flow:row nowrap;
    }
    .dl-tpsrv>dt{
        width:80%;
        order:2;
        overflow:hidden;
    }
    .dl-tpsrv>dd{
        width:20%;
        position:relative;
        padding:0;
        order:1;
    }
    .dl-tpsrv>dt .pict>img{
        aspect-ratio:unset;
        width:100%;
        height:800px;
    }
    .dl-tpsrv>dd .desc{
        position:absolute;
        top:auto;
        left:0;
        bottom:0;
        z-index:10;
        width:500px;
    }
    .dl-tpsrv>dd .desc>div{
        padding:40px;
    }
}
@media(min-width:1200px){
    .dl-tpsrv>dd .desc{
        width:700px;
    }
    .dl-tpsrv>dd .desc>div{
        padding:40px 80px;
    }
    .dl-tpsrv>dt{
        width:70%;
    }
    .dl-tpsrv>dd{
        width:30%;
    }
}
/*==========================================================*/
/* top profile     											*/
/*==========================================================*/
@media(min-width:992px){
    .tpprofile-sec .dl-tpsrv>dt{
        order:1;
    }
    .tpprofile-sec .dl-tpsrv>dd{
        order:2;
    }
    .tpprofile-sec .dl-tpsrv>dd .desc{
        width:500px;
        position:absolute;
        top:auto;
        right:0;
        left:auto;
        bottom:0;
    }
    .tpprofile-sec .dl-tpsrv>dd .desc>div{
        padding:40px;
    }
}
@media(min-width:1200px){
    .tpprofile-sec .dl-tpsrv>dd .desc{
        width: 700px;
    }
    .tpprofile-sec .dl-tpsrv>dd .desc{
        padding: 40px 80px;
    }
}
/*==========================================================*/
/* top scene     											*/
/*==========================================================*/
.tpscene-sec{
    position:relative;
}
.tpscene-wrap{
    width:100%;
    position:relative;
}
.ul-paslider{
    margin:0;
    padding:0;
    width:100%;
    list-style:none;
}
.ul-paslider li{
    width:100%;
    margin:0;
}
.ul-paslider li img{
    width:100%;
    aspect-ratio:4/3;
    object-fit:cover;
    filter: grayscale(50%);
}
/* slick */
.slick-prev, .slick-next{
    z-index:30;
    width:30px;
    height:40px;
    top:150%;
}
.slick-prev:before, .slick-next:before{
    display:flex;
    width:30px;
    height:40px;
    justify-content:center;
    align-items:center;
    background:var(--bk-desc-color2);
    opacity:1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-family: "Font Awesome 7 Free";
    font-feature-settings: normal;
    font-style: normal;
    font-synthesis: none;
    font-variant: normal;
    font-weight: 900;
    line-height: 1;
    text-align: center;
    text-rendering: auto;
    color:var(--font-color);
    font-size:16px;
}
.slick-prev:before{
    content:"\f104";
}
.slick-next:before{
    content:"\f105";
}
.slick-prev{
    left:0;
}
.slick-next{
    right:0;
}
.slick-dots{
    position:absolute;
    bottom:-20px;
    left:50%;
    translate:-50% 0;
    display:flex;
    flex-flow:row nowrap;
    width:fit-content;
    justify-content: center;
    z-index:10;
}
.ul-paslider .slick-dots>li{
    width:30px;
    height:3px;
}
.slick-dots>li button{
    width:30px;
    height:3px;
}
.slick-dots>li button:before{
    content:'';
    width:30px;
    height:3px;
    background:rgba(255,255,255,0.5);
    opacity:1;
}
.slick-dots li.slick-active button:before{
    background:#fff;
    opacity:1;
}
.slick-dotted.slick-slider{
    margin:0;
}
/* new */
.ul-scene-desc{
  display:none;
}
.tpscene-fixedbox{
  width:100%;
  aspect-ratio:4/3;
  padding:30px 10px 10px 10px;
  background:var(--bk-desc-color);
}
/* fade */
.tpscene-fixedbox__inner{
  opacity:0;
  transform: translateY(10px);
  transition: opacity 1s ease, transform 1s ease;
}
.tpscene-fixedbox__inner.is-show{
  opacity:1;
  transform: translateY(0);
}
.box.tpscene-fixedbox .scene{
    color:var(--font-color);
    text-align:center;
    font-size:14px;
    padding-bottom:10px;
    margin-bottom:30px;
    position:relative;
}
.box.tpscene-fixedbox .scene:before{
    content:'';
    width:60px;
    height:1px;
    background:var(--font-color);
    position:absolute;
    bottom:0;
    left:50%;
    translate:-50% 0;
}
.box.tpscene-fixedbox h2{
    display:flex;
    width:100%;
    height:45px;
    justify-content:center;
    color:var(--font-color);
    font-size:18px;
    text-align:center;
    font-weight:500;
}
.box.tpscene-fixedbox .desc{
    display:table;
    max-width:300px;
    margin:0 auto;
}
.box.tpscene-fixedbox .desc p{
    color:var(--font-color);
    font-size:14px;
}
@media(min-width:768px){
    .ul-paslider li img{
        width:100%;
        aspect-ratio:5/3;
        object-fit:cover;
    }
    .tpscene-fixedbox{
        aspect-ratio:5/3;
        padding:50px 10px 10px 10px;
    }
    .box.tpscene-fixedbox .scene{
        font-size:17px;
    }
    .box.tpscene-fixedbox h2{
        font-size:24px;
        height:60px;
    }
    .box.tpscene-fixedbox .desc{
        max-width:500px;
    }
    .box.tpscene-fixedbox .desc p{
        font-size:17px;
    }
    .slick-dots{
        bottom:-30px;
    }
}
@media(min-width:992px){
    .tpscene-fixedbox{
        width:60%;
        position:absolute;
        left:0;
        top:50%;
        aspect-ratio:unset;
        width:700px;
        height:500px;
        translate:0 -50%;
        padding:100px 20px 20px 20px;
        z-index:5;
        background:var(--bk-desc-color-pc);
    }
    .box.tpscene-fixedbox .desc{
        max-width:400px;
    }
    .box.tpscene-fixedbox h2{
        height:80px;
    }
    .slick-prev, .slick-next{
        width:70px;
        height:70px;
        top:50%;
    }
    .slick-prev:before, .slick-next:before{
        width:70px;
        height:70px;
    }
    .slick-prev{
        left:8px;
    }
    .slick-next{
        right:auto;
        left:calc(700px - 70px);
    }
    .ul-paslider li img{
        aspect-ratio:unset;
        height:800px;
    }
    .slick-dots{
        width:700px;
        bottom:auto;
        top:calc(50% - 180px);
        left:0;
        translate:0 -50%;
    }
}
/*==========================================================*/
/* before footer  											*/
/*==========================================================*/
.beforeft-sec{
    padding:40px 0;
    background:var(--bk-beforeft-color);
}
.beforeft-wrap{
    width:100%;
}
.beforeft-wrap p{
    text-align:center;
    font-size:14px;
    margin-bottom:20px;
}
.beforeft-btn{
    display:flex;
    width:100%;
    justify-content:center;
    margin-bottom:20px;
}
.beforeft-btn h2{
    display:flex;
    font-weight:600;
    align-items:center;
    font-size:18px;
}
.beforeft-btn h2>span{
    width:fit-content;
    display:inline-block;
}
.beforeft-btn h2>a{
    width:fit-content;
    display:flex;
    width:32px;
    height:32px;
    justify-content: center;
    align-items: center;
    background:var(--btn-hover-color);
    color:#fff;
    border-radius:10px;
    margin-left:1em;
    transition:all 0.5s;
    font-size:14px;
}
.beforeft-btn h2>a i{
    transition:all 0.5s;
}
.beforeft-btn h2>a:hover{
    filter:grayscale(50%);
}
.beforeft-btn h2>a:hover i{
    transform:translateX(5px);
}
.beforeft-wrap .pict{
    width:100%;
    margin-left:auto;
    margin-right:auto;
}
.beforeft-wrap .pict>img{
    width:100%;
    height:331px;
    object-fit:cover;
    object-position:center center;
}
.beforeft-wrap .pict>img{
    filter:grayscale(50%);
}
@media(min-width:768px){
    .spbr{
        display:none;
    }
    .beforeft-wrap p{
        font-size:16px;
    }
}
/*==========================================================*/
/* footer         											*/
/*==========================================================*/
.footer_widget{
    width:100%;
    margin-bottom:40px;
}
.ft-logo{
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
}
.ft-logo a{
    transition:all 0.5s;
}
.ft-logo a:hover{
    opacity:0.8;
}
.ft-logo .dl-logo{
    align-items:center;
}
.menu-footermenu-container ul.menu{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    list-style:none;
}
.menu-footermenu-container ul.menu>li{
    width:50%;
}
.footerwidget ul>li a{
    display:table;
    position:relative;
    transition:all 0.5s;
}
.footerwidget ul>li a:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--footer-font-color);
    transform:scale(0, 1);
    position:absolute;
    left:0;
    bottom:0;
    transform-origin: right center;
    transition:transform 0.5s;
}
.footerwidget ul>li a:hover::before{
    transform:scale(1, 1);
    transform-origin:left center;
}
.footerwidget ul>li a:hover{
    opacity:0.8;
}
.privacy-wrap{
    display:flex;
    justify-content:center;
    width:100%;
    margin-bottom:20px;
}
.privacy-wrap>a{
    color:var(--footer-font-color);
    display:table;
    position:relative;
    transition:all 0.5s;
}
.privacy-wrap>a::before{
    content:'';
    width:100%;
    height:1px;
    background:var(--footer-font-color);
    transform:scale(0, 1);
    position:absolute;
    left:0;
    bottom:0;
    transform-origin: right center;
    transition:transform 0.5s;
}
.privacy-wrap>a:hover::before{
    transform:scale(1, 1);
    transform-origin:left center;
}
.privacy-wrap>a:hover{
    opacity:0.8;
    color:var(--footer-font-color);
}
@media(min-width:768px){
    .menu-footermenu-container ul.menu>li{
        width:20%;
        display:flex;
        justify-content: center;
    }
}
@media(min-width:992px){
    .footerwidget>.footer_widget{
        margin:0;
    }
    .footerwidget>.footer_widget:first-of-type{
        width:250px;
    }
    .footerwidget>.footer_widget:last-of-type{
        width:calc(100% - 250px);        
    }
    .menu-footermenu-container{
        height:100%;
        display:flex;
        align-items:center;
    }
    .menu-footermenu-container ul.menu{
        margin:0;
    }
}
/*==========================================================*/
/* concept         											*/
/*==========================================================*/
.page-concept .siteContent{
    background:transparent;
}
.page-concept .page-section{
    padding:80px 0;
}
.page-concept .beforeft-sec.page-section{
    padding:40px 0;
}
.page-concept .ourservice-sec.page-section{
    padding-top:0;
    padding-bottom:80px;
}
.concept-sec, .reason-sec, .core-sec, .everyday-sec, .performance-sec, .important-sec, .ourservice-sec{
    position:relative;
    background:var(--bk-body-color);
}
.pg-style{
    width:100%;
    margin-bottom:40px;
}
.pg-style p{
    font-size:18px;
    color:var(--h2pg-color);
    font-family:var(--libre);
    white-space:nowrap;
    font-weight:700;
}
.pg-style h2{
    font-size:24px;
    line-height:1.4;
    font-weight:700;
}
.page-concept .fixed-bk-sec.page-section{
    padding:0;
}
.fix-bk-frm{
    width:100%;
    height:200px;
    background:rgb(31, 46, 60, 0.4);
}
.fixed-bk-wrap{
    position:fixed;
    width:100%;
    height:100vh;
    top:0;
    left:0;
    z-index:-1;
    opacity:0;
    transition:all 0.5s;
}
.fixed-bk-wrap>img{
    width:100%;
    height:100%;
    object-fit:cover;
    filter:blur(1px), grayscale(50%);
}
.fixed-bk-sec.active .fixed-bk-wrap{
    opacity:1;
}
/* reason-sec */
.reason-wrap{
    width:100%;
}
.dl-reason{
    width:100%;
    display:flex;
    flex-flow:row wrap;
    margin:0;
}
.dl-reason>dt{
    width:100%;
    font-weight:400;
}
.dl-reason>dd{
    padding-top:3em;
    width:100%;
}
.dl-reason>dt .pict{
    width:100%;
}
.dl-reason>dt .pict>img{
    width:100%;
    aspect-ratio:5/3;
    object-fit:cover;
}
.dl-reason>dd>.desc p{
    line-height: 2;
}
.dl-reason>dd>.desc p br{
    display:none;
}
.reason-wrap .desc p{
    line-height:2;
}
/* core-sec */
.core-wrap{
    width:100%;
}
.h3pg{
    font-size:20px;
    color:var(--h2pg-color);
    margin-bottom:3em;
}
.anime-slide .h3pg{
    margin-bottom:0;
}
.core-wrap>.desc>p, .performance-wrap>.desc>p{
    line-height:2;
}
.core-wrap>.desc>p br, .performance-wrap>.desc>p br{
    display:none;
}
.core-wrap .desc p{
    line-height:2;
}
/* everyday-sec */
.everyday-wrap{
    width:100%;
}
.everyday-wrap .desc p{
    line-height:2;
}
/* important-sec */
.ul-pochi{
    padding-left:20px;
}
.dl-view_srv{
    width:100%;
    display:flex;
    justify-content:center;
    flex-flow:row wrap;
}
.dl-view_srv>dt{
    font-weight:400;
    width:100%;
}
.dl-view_srv>dd{
    width:100%;
    padding-top:3em;
}
.dl-view_srv>dt .box>p{
    line-height:2;
}
.dl-view_srv>dt .box>p br{
    display:none;
}
.dl-view_srv>dd .desc a{
    width:280px;
    height:60px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--btn-color);
    margin-left:auto;
    margin-right:auto;
    transition:all 0.5s;
}
.dl-view_srv>dd .desc a:hover{
    background:var(--btn-hover-color);
}
@media(min-width:768px){
    .page-concept .page-section{
        padding:160px 0;
    }
    .page-concept .ourservice-sec.page-section{
        padding-top:0;
        padding-bottom:80px;
    }
    .pg-style{
        margin-bottom:80px;
    }
    .pg-style p{
        font-size:24px;
    }
    .pg-style p br{
        display:none;
    }
    .pg-style h2{
        font-size:32px;
    }
    .br_sp{
        display:none;
    }
}
@media(min-width:992px){
    .concept-sec .contains-wrap{
        display:flex;
        justify-content:center;
    }
    .concept-sec .contains-wrap .pg-style{
        width:fit-content;
    }
    .fix-bk-frm{
        height:400px;
    }
    .dl-reason{
        gap:20px;
    }
    .dl-reason>dt{
        width:calc(50% - 10px);
    }
    .dl-reason>dd{
        padding-top:0;
        width:calc(50% - 10px);
    }
    .dl-reason>dt .pict>img{
        aspect-ratio:4/3;
    }
    .dl-reason>dd>.desc p br{
        display:block;
    }
}
/*==========================================================*/
/* concept         											*/
/*==========================================================*/
.service-sec{
    position:relative;
}
.srv1-sec{
    padding-top:80px;
}
.srv_catch{
    margin-bottom:80px;
}
.h2srv{
    font-size:24px;
    margin-bottom:40px;
    font-weight:700;
    line-height:1.4;
}
.h2srv br{
    display:none;
}
.anime-slide .h2srv{
    margin-bottom:0;
}
.srv-style{
    margin-bottom:40px;
}
.srv-style p{
    color:var(--h2pg-color);
    font-weight:700;
    font-family:var(--libre);
}
.srv-style .h3srv{
    margin:0;
    text-align:center;
    font-size:24px;
    font-weight:500;
}
.h4srv{
    margin:0;
    text-align:center;
    font-size:24px;
}
.margin-center{
    margin-left:auto;
    margin-right:auto;
}
.service-sec .desc p{
    line-height:2;
}
.service-sec .desc p br{
    display:none;
}
.srv3-wrap{
    width:100%;
    display:flex;
    justify-content: center;
}
.ul-service{
    margin:0;
    padding:0;
    list-style:none;
    display:flex;
    flex-flow:row wrap;
    width:100%;
}
.ul-service .anime-slide::before,.ul-service .anime-slide::after{
    background:var(--btn-hover-color);
}
.ul-service>li{
    width:100%;
    margin-bottom:30px;
}
.ul-service>li .box{
    width:100%;
    border:solid 2px var(--h2pg-color);
    padding:40px 20px;
}
.ul-service>li .box .srv_mark{
    text-align:center;
    color:var(--h2pg-color);
    margin-bottom:10px;
    font-size:20px;
}
.ul-service>li .box .h4srv{
    margin-bottom:30px;
    font-weight:700;
    font-size:22px;
}
.ul-service>li .box .desc{
    width:100%;
    display:flex;
}
.vertical_parts1{
    min-height:110px;
}
.vertical_parts2{
    min-height:290px;
}
.ul-poci{
    padding-left:20px;
}
.ul-poci>li{
    font-size:16px;
}
.srv2-sec, .srv4-sec{
    background:var(--bk-body-color3);
}
/* price */
.price-sec .h2srv{
    font-size:20px;
}
.price-h{
    margin-bottom:40px;
}
.price-before{
    margin-bottom:40px;
}
.price-before p{
    font-size:14px;
    line-height:2;
}
.price-wrap{
    width:100%;
}
.ul-price{
    width:100%;
    margin:0;
    padding:0;
    list-style:none;
}
.ul-price>li{
    width:100%;
    margin-bottom:80px;
}
.ul-price>li:last-of-type{
    margin-bottom:0;
}
.ul-price>li .box h3{
    font-size:16px;
    font-weight:400;
    margin-bottom:10px;
    padding-bottom:10px;
    position:relative;
    border-bottom:solid 1px var(--font-color);
}
.ul-price>li .box h3.letter_set{
    letter-spacing: 1px;
}
.time_min{
    margin-left:10px;
}
.ul-price>li .box .price{
    font-size:14px;
    font-family:var(--libre);
    margin-bottom:10px;
    font-weight:400;
}
.ul-price>li .box .price>span{
    margin-left:5px;
    font-size:0.8em;
}
.dl-price{
    width:100%;
    margin-bottom:10px;
    display:flex;
    flex-flow:row wrap;
    padding-bottom:10px;
    border-bottom:solid 1px rgba(255,255,255,0.2);
}
.dl-price>dt{
    margin:0;
    width:45%;
    font-weight:400;
    font-size:14px;
}
.dl-price>dd{
    margin:0;
    width:55%;
    display:flex;
    justify-content:flex-end;
    align-items:center;
}
.ul-price>li .box .dl-price>dd .price{
    margin-bottom:0;
    font-size:14px;
}
.ul-price>li .box .desc{
    margin-bottom:40px;
    font-size:14px;
}
.price-after{
    width:100%;
}
.price-after>p{
    font-size:14px;
}
.ul-srv_four .anime-slide>.anime-word{
    opacity:1;
    transform: translateY(0);
}
.ul-srv_four .anime-slide:before{
    content:none;
}
.ul-srv_four .anime-slide:after{
    content:none;
}
.ul-srv_three .anime-slide>.anime-word{
    opacity:1;
    transform: translateY(0);
}
.ul-srv_three .anime-slide:before{
    content:none;
}
.ul-srv_three .anime-slide:after{
    content:none;
}
.ol-sessionflow{
    margin-bottom:20px;
    padding-left:22px;
}
@media(min-width:768px){
    .srv1-sec{
        padding-top:160px;
    }
    .srv_catch{
        margin-bottom:160px;
    }
    .h2srv{
        font-size:32px;
    }
    .h2srv br{
        display:block;
    }
    .srv-style p{
        font-size:24px;
    }
    .srv-style .h3srv{
        font-size:32px;
    }
    .h4srv{
        font-size:32px;
    }
    .ul-srv_four{
        gap:40px;
    }
    .ul-srv_four>li{
        width:calc(50% - 20px);
    }
    .ul-srv_three{
        justify-content:space-between;
    }
    .ul-srv_three>li{
        width:33%;
        margin-bottom:0;
    }
    .ul-srv_three>li .box{
        padding:40px 10px;
    }
    .vertical_parts2{
        min-height:390px;
    }
    .price-sec .h2srv{
        font-size:24px;
    }
    .ul-price>li .box h3{
        font-size:16px;
        margin-bottom:20px;
    }
    .price-after{
        margin-top:60px;
    }
}
@media(min-width:992px){
    .ul-srv_four{
        gap:0;
        justify-content:space-between;
    }
    .ul-srv_four .anime-slide>.anime-word{
        opacity:0;
        transform: translateY(6px);
    }
    .ul-srv_four .anime-slide.active>.anime-word{
        opacity:1;
        transform: translateY(0);
    }
    .ul-srv_four .anime-slide:before{
        content:'';
    }
    .ul-srv_four .anime-slide:after{
        content:'';
    }
    .ul-srv_four>li{
        width:24%;
        margin-bottom:0;
    }
    .ul-service.ul-srv_four>li .box .h4srv{
        font-size:18px;
    }
    .vertical_parts1{
        min-height:160px;
    }
    .srv-style{
        margin-bottom:80px;
    }
    .ul-srv_three .anime-slide>.anime-word{
        opacity:0;
        transform: translateY(6px);
    }
    .ul-srv_three .anime-slide.active>.anime-word{
        opacity:1;
        transform: translateY(0);
    }
    .ul-srv_three .anime-slide:before{
        content:'';
    }
    .ul-srv_three .anime-slide:after{
        content:'';
    }
    .ul-srv_three>li{
        width:32%;
    }
    .vertical_parts2{
        min-height:290px;
    }
}
@media(min-width:1200px){
    .ul-srv_three>li .box{
        padding:40px 40px;
    }
    .vertical_parts2{
        min-height:290px;
    }
}
/*==========================================================*/
/* faq list        											*/
/*==========================================================*/
.faq-sec{
    position:relative;
    background:var(--bk-body-color3);
}
.faq-wrap{
    width:100%;
}
.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;
    border:solid 1px var(--main-color);
}
.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: 40px;
    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:5px;
}
.dl_faq dt .wrap:before{
    content:'';
    width:25px;
    height:25px;
    background:transparent;
    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;
    background:var(--bk-accent-color);
}
.dl_faq dd .wrap:after{
    content:'A';
    font-weight:700;
    font-size:24px;
    color:var(--a-mark-color);
    display:inline-block;
    position:absolute;
    top:3px;
    left:5px;
}
.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;
    }
    .dl_faq dt .wrap:after{
        left:10px;
    }
    .dl_faq dd .wrap:after{
        left:10px;
    }
}
@media(min-width:992px){
    .dl_faq dt, .dl_faq dd{
        font-size:16px;
    }
}
/*==========================================================*/
/* profile        											*/
/*==========================================================*/
.profile-sec{
    position:relative;
}
.dl-profile{
    display:block;
    width:100%;
    margin:0;
}
.dl-profile>dt{
    width:100%;
    margin-bottom:30px;
}
.dl-profile>dd{
    width:100%;
    margin-bottom:0;
}
.dl-profile>dt .pict{
    width:100%;
}
.dl-profile>dt .pict>img{
    width:100%;
    aspect-ratio:3/4;
    object-fit:cover;
}
.dl-profile>dd .desc{
    width:100%;
}
.hd-profile{
    width:100%;
    margin-bottom:30px;
}
.hd-profile p{
    font-size:14px;
    text-align:left;
    letter-spacing:0;
    color:var(--h2pg-color);
    margin-bottom:10px;
    font-family:var(--libre);
}
.h2profile{
    font-size:24px;
    font-weight:700;
    margin-bottom:0;
}
.h2profile span{
    font-size:14px;
    margin-left:10px;
}
.bd-profile{
    width:100%;
}
.bd-profile>p{
    line-height:2;
}
.profile_ttl{
    margin-bottom:10px;
    font-weight:100;
    font-size:14px;
}
.profile_ttl2{
    letter-spacing: 0;
    font-family:var(--libre);
    margin-bottom:4px;
    font-weight:100;
    font-size:14px;
}
.ul-license{
    margin:0;
    padding:0;
    list-style:none;
    margin-bottom:30px;
}
.ul-license>li{
    letter-spacing: 0;
    font-family:var(--libre);
    position:relative;
    padding-left:20px;
    font-weight:100;
    font-size:14px;
}
.ul-license>li:before{
    content:'-';
    position:absolute;
    top:0;
    left:5px;
}
.notelink{
    width:100%;
}
.notelink a{
    display:block;
    max-width:120px;
    transition:all 0.5s;
}
.notelink a:hover{
    opacity:0.6;
}
.msg-sec{
    padding-top:0;
}
.msg-wrap{
    width:100%;
}
.msg-wrap p{
    line-height:2;
    font-weight:100;
    font-size:14px;
}
@media(min-width:768px){
    .profile_ttl{
        font-size:16px;
    }
    .profile_ttl2{
        font-size:16px;
    }
    .ul-license>li{
        font-size:16px;
    }
    .msg-wrap p{
        font-size:16px;
    }
}
@media(min-width:992px){
    .dl-profile{
        display:flex;
        flex-flow:row wrap;
        justify-content:space-between;
    }
    .dl-profile>dt{
        width:49%;
    }
    .dl-profile>dd{
        width:49%;
        display:flex;
        align-items:center;
    }
}
/*==========================================================*/
/* contact        											*/
/*==========================================================*/
.page-contact .beforeft-sec{
    display:none;
}
.contact-sec{
    position:relative;
}
.contact-wrap{
    width:100%;
    max-width:960px;
    margin-left:auto;
    margin-right:auto;
}
.before-contact{
    width:100%;
    margin-bottom:40px;
}
.before-contact p{
    line-height:2;
}
.attention-contact{
    width:100%;
    margin-bottom:40px;
}
.attention-contact>p{
    margin-bottom:10px;
}
.ul-attention{
    padding-left:20px;
    margin-bottom:0;
}
.ul-attention>li{
    margin-top:8px;
}
.contact-type-btn{
    display:flex;
    flex-flow:row wrap;
}
.contact-type-btn a{
    color:var(--font-color);
    display:flex;
    width:280px;
    height:60px;
    justify-content:center;
    align-items:center;
    border:solid 1px var(--font-color);
    margin-top:20px;
    margin-left:auto;
    margin-right:auto;
    position:relative;
    letter-spacing: 0;
    padding-right:20px;
    transition:all 0.5s;
}
.contact-type-btn a i{
    position:absolute;
    top:50%;
    right:10px;
    translate:0 -50%;
    font-size:32px;
}
.contact-type-btn a:hover{
    background:var(--bk-body-color3);
    color:var(--font-color);
}
.contactfrm-sec{
    position:relative;
}
.hd-contact{
    width:100%;
    margin-bottom:40px;
}
.hd-contact p{
    display:table;
    position:relative;
    color:var(--h2pg-color);
    padding-left:20px;
    font-family:var(--libre);
    margin-left:auto;
    margin-bottom:10px;
    margin-right:auto;
}
.hd-contact h2{
    display:table;
    font-size:24px;
    margin-left:auto;
    margin-right:auto;
}
/* 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;
    padding-left:20px;
    background-color:var(--bk-body-color);
    color:var(--font-color);
    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{
    border:0;
    outline:solid 1px var(--focus-color);
}
textarea{
    width:100%;
    padding:5px;
    padding-left:20px;
    padding-right:20px;
    background-color:var(--bk-body-color);
    box-shadow: none !important;
    line-height: 1.5em;
    appearance: none;
    border: 1px solid #ccc;
    color:var(--font-color);
}
textarea:focus{
    border:0;
    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:var(--bk-body-color);
    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;
    color:var(--font-color);
}
.pripol-btn a:before{
    content:'';
    width:100%;
    height:1px;
    background:var(--font-color);
    position:absolute;
    display:block;
    bottom:0;
    left:0;
    transform: scale(0, 1);
    transform-origin: right top;
    transition:transform 0.5s;
}
.pripol-btn a:hover:before{
    transform-origin: left top;
    transform: scale(1, 1);
}
.pripol-btn a:hover{
    color:var(--font-color);
    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:var(--bk-body-color);
    font-size:12px;
    position:absolute;
    top:50%;
    right:0;
    transform:translateY(-50%);
}
.wpcf7-not-valid-tip{
    color:var(--btn-hover-color);
}
@media(min-width:992px){
    .hd-contact h2{
        font-size:17px;
    }
    .hd-contact h2{
        font-size:32px;
    }
}
@media(min-width:992px){
    .tpcontact-sec{
        padding:80px 0;
    }
    .contactfrm-wrap{
        max-width:920px;
        margin-left:auto;
        margin-right:auto;
        background:rgba(255,255,255,0.05);
        padding:60px 80px 40px 80px;
        border-radius:10px;
    }
}
/*==========================================================*/
/* 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(--font-color);
    font-weight:700;
    position:relative;
}
.detail-wrap a: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;
}
.detail-wrap a:hover{
    color:var(--font-color);
}
.detail-wrap a:hover:before{
    transform:scale(1, 1);
    transform-origin:left center;
}
@media(min-width:768px){
    .detail-wrap .h2org{
        font-size:24px;
    }
}
/*==========================================================*/
/* membership terms       									*/
/*==========================================================*/
.page-header.membership-terms-pgheader{
    height:150px;
}
.membership-rules-block, .service-agreement-block{
    margin-bottom:80px;
}
.block-h2{
    font-size:18px;
    margin-bottom:20px;
}
.article-h3{
    font-size:18px;
    margin-bottom:20px;
    letter-spacing:1px;
}
.rules-article, .agreement-item{
    width:100%;
    margin-top:40px;
}
.article-h3{
    font-size:16px;
    margin-bottom:10px;
}
.article-p{
    font-size:14px;
    line-height:2;
}
.ol-basic, .ul-basic{
    padding-left:20;
    margin-bottom:0;
    margin-top:10px;
}
.ol-basic>li, .ul-basic>li{
    font-size:14px;
    line-height:1.4;
    margin-top:8px;
}
#agree-program .ol-basic{
    margin:20px 0;
}
.consent-item{
    margin-top:20px;
}
.consent-item .ul-basic{
    margin-bottom:20px;
}
.signature-block{
    margin-top:40px;
}
.signature-block,
.signature-block *{
  -webkit-user-select: none;   /* iOS Safari */
  user-select: none;           /* 標準 */
  -webkit-touch-callout: none; /* iOSのコピー/保存メニュー抑止 */
}
.signature-row{
    margin-bottom:40px;
}
.signature-date-wrap{
    max-width:400px;
}
.signature-date-field {
  display: flex;
  align-items: center;
  gap: 8px;
}
/* 行全体はレイアウト用（サイズは持たせない） */
.signature-line.signature-date{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
/* ★サイズは wrap に持たせる（これが重要） */
.signature-line.signature-date .signature-canvas-wrap{
  width:80px;
  height:60px;
  display:inline-block;
}
.signature-line.signature-full .signature-canvas-wrap{
  width:100%;   /* 署名欄は任意 */
  height:80px;
  display:inline-block;
}
/* ★canvasは必ず親にフィットさせる */
.signature-canvas{
  width:100%;
  height:100%;
  display:block;
  /* 枠線をcanvasに付けるならこれ必須（ズレ防止） */
  box-sizing:border-box;
  border:1px solid #ccc;
  background:transparent;
  touch-action: none;
}
.signature-canvas{
  background:var(--bk-body-color);
}
.signature-date-unit {
  white-space: nowrap;
}
.signature-clear-btn{
    font-size:14px;
    font-family:var(--noto-serif);
    margin-top:5px;
    width:70px;
    height:30px;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--btn-color);
    border:none;
    outline:none;
    transition:all 0.5s;
    color:var(--bk-desc-color);
}
.signature-clear-btn:hover{
    background:var(--btn-hover-color);
}
.note-p{
    font-size:14px;
}
/* select YYYY MM DD*/
.signature-block .signature-select-wrap select{
    background:var(--bk-body-color);
    color:var(--font-color);
    width:70px;
    height:40px;
    display:flex;
    align-items:center;
    border:1px solid #ccc;
    padding-left:5px;
    font-weight:400;
    border-radius:0;
}
.signature-block .signature-select-wrap select.sign-year{
    width:90px;
}
.signature-block .signature-select-wrap select:focus{
    border:1px solid #ccc;
    outline:none;
}
@media(min-width:768px){
    .page-header.membership-terms-pgheader{
        height:200px;
    }
    .signature-line.signature-date .signature-canvas-wrap{
        width:190px;
        height:150px;
    }
    .signature-line.signature-full .signature-canvas-wrap{
        height:150px;
        max-width:680px;
    }
}