/* 
Theme Name: Hello Elementor Child
Theme URI: https://github.com/elementor/hello-theme/
Description: Hello Elementor Child is a child theme of Hello Elementor, created by Elementor team
Author: Elementor Team
Author URI: https://elementor.com/
Template: hello-elementor
Version: 1.0.1
Text Domain: hello-elementor-child
License: GNU General Public License v3 or later.
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Tags: flexible-header, custom-colors, custom-menu, custom-logo, editor-style, featured-images, rtl-language-support, threaded-comments, translation-ready
*/

/*
    Add your custom styles here
*/


/*=================================================
共通
=================================================*/
/**********
全般
**********/
body,html {
    font-size: 16px;
    font-family: "Noto Sans JP", sans-serif;
    position: relative;
}

html {
    scroll-behavior: smooth;
}

p, h1, h2, h3, h4 {
    margin: 0;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
}

a {
    transition: 0.3s;
    font-family: "Noto Sans JP", sans-serif;
    color: #555555;
}
a:active, a:hover {
    color: #555555;
}
a:hover {
    opacity: 0.6;
}

ul,li,a {
    text-decoration: none;
    list-style: none;
}

img {
    vertical-align: middle;
    image-rendering: auto;
    /*width: 100%;*/
}

.flex {
    display: flex;
    flex-wrap: wrap;
}

.ib {
    display: inline-block;
}

.block {
    display: block;
}

.indent {
    padding-left: 1em;
    text-indent: -1em;
}

.indent span {
    padding-left: 1em;
}

.hankaku {
    margin-right: 0.5em;
}

.sans {
    font-family: "Noto Sans JP", sans-serif;
}

.meiryo {
    font-family:'Meiryo UI','游ゴシック体', 'Yu Gothic', YuGothic,sans-serif;
}

.gothic {
    font-family: a-otf-gothic-mb101-pr6n, sans-serif;
    font-weight: 300;
    font-style: normal;
}

.small {
    font-size: 14px;
}

.light {
    font-weight: 300;
}

.bold {
    font-weight: 500;
}

.red {
    color: #FF0707;
}

.elementor-column-gap-default>.elementor-column>.elementor-element-populated {
    padding: 0;
}

a[href^="tel:"] {
    cursor: default;
}

@media screen and (min-width: 1025px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}

/****************
font-size
*****************/
.fs42 {
    font-size: clamp(1.625rem, 1.425rem + 1vw, 2.625rem);
}

.fs40 {
    font-size: clamp(1.5rem, 1.3rem + 1vw, 2.5rem);
}

.fs36 {
    font-size: clamp(1.5rem, 1.35rem + 0.75vw, 2.25rem);
}

.fs34 {
    font-size: clamp(1.25rem, 1.075rem + 0.8750000000000001vw, 2.125rem);}

.fs32 {
    font-size: clamp(1.25rem, 1.1rem + 0.75vw, 2rem);}

.fs30 {
    font-size: clamp(1.125rem, 0.975rem + 0.75vw, 1.875rem);
}

.fs29 {
    font-size: clamp(1.25rem, 1.15rem + 0.5vw, 1.8125rem);
}

.fs28 {
    font-size: clamp(1.25rem, 1.15rem + 0.5vw, 1.75rem);
}

.fs24 {
    font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
}

.fs22 {
    font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
}

.fs20 {
    font-size: clamp(1rem, 0.95rem + 0.25vw, 1.25rem);
}

.fs18 {
    font-size: clamp(1rem, 0.975rem + 0.125vw, 1.125rem);
}

/****************
サイドバーメニュー
*****************/
.area-wrap {
    display: flex;
    flex-wrap: nowrap;
    position: relative;
}

.main-area {
    width: calc(100% - 283px);
}

.side-area {
    width: 283px;
    flex-shrink: 0;
    position: relative;
    z-index: 1;
    background-color: white;
}

@media screen and (min-width: 1201px) {
    .side-area.fix {
        height: 100%;
        position: fixed;
        top: 0;
        right: 0;
        overflow-y: scroll;
        -ms-overflow-style: none;
        scrollbar-width: none;
    }

    .side-area.fix::-webkit-scrollbar {
        display: none;
    }
    
    .side-area.stop {
        position: absolute;
    }
    
    .side-area.stop .side-menu {
        position: absolute;
        bottom: 0;
        width: 100%;
    }
}


@media screen and (max-width: 1200px) {
    .main-area {
        width: 100%;
    }
    
    .side-area {
        /*display: none;*/
        position: fixed;
        top: 0;
        right: -300px;
        transition: right 1s;
        overflow-y: scroll;
        -ms-overflow-style: none;
        scrollbar-width: none;
        height: 100vh;
    }
    
    .side-area::-webkit-scrollbar {
        display: none;
    }
    
    .side-area.open {
        right: 0;
    }
}

/****************
パーツ
*****************/
/* sec-tit */
.sec-tit-wrap {
    padding-bottom: 45px;
}

.sec-tit-lead {
    margin-bottom: 5px;
    color: #555555;
    opacity: 0;
    transition: 1s 1.3s;
}

.sec-tit {
    /*border-bottom: 1px solid #707070;*/
    display: inline-flex;
    align-items: center;
    font-size: clamp(1.125rem, 0.975rem + 0.75vw, 1.875rem);
    padding-bottom: 15px;
    color: #555555;
    position: relative;
}

.sec-tit span:first-child {
    opacity: 0;
    transition: 1s 0.8s;
}

.sec-tit::after {
    content: "";
    width: 0;
    height: 1px;
    background-color: #707070;
    left: 0;
    bottom: 0;
    position: absolute;
    transition: 1s ease-in;
}

.sec-tit-arrow {
    margin-left: 25px;
    height: 1px;
    width: 0;
    background-color: #555555;
    margin-top: 7px;
    position: relative;
    transition: 1s ease-in;
}

.sec-tit-arrow::after{
    content: "";
    display: block;
    position: absolute;
    top: -3px;
    /*right: 1px;*/
    left: 15px;
    width: 0;
    height: 5px;
    border-top: 1px solid #555555;
    transform: rotate(30deg);
    transition: 0.2s 0.8s ease-in;
}

.sec-text {
    font-size: clamp(1.125rem, 1.075rem + 0.25vw, 1.375rem);
    line-height: 1.8;
    color: #555555;
}

.sec-text-sub {
    margin-top: 25px;
    color: #555555;
    line-height: 2.25;
}

.sec-tit-wrap.on .sec-tit::after {
    width: 100%;
}

.sec-tit-wrap.on .sec-tit-arrow {
    width: 25px;
}

.sec-tit-wrap.on .sec-tit-arrow::after {
    width: 10px;
}

.sec-tit-wrap.on .sec-tit span:first-child,
.sec-tit-wrap.on .sec-tit-lead {
    opacity: 1;
}

@media screen and (max-width: 767px) {
    .sec-text {
        line-height: 1.5;
    }

    .sec-text-sub {
        line-height: 1.8;
    }
}


/* btn */
.btn-wrap {
    display: flex;
    justify-content: center;
}

.btn {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 60px;
    color: #ffffff;
    border: 1px solid #AAD2C3;
    border-radius: 30px;
    background-color: #B1DBCB;
}

.btn-inner {
    position: relative;
}

.btn-inner::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 0%;
    height: 1px;
    background-color: #ffffff;
    content: "";
    transition: 0.5s ease;
}

.btn:hover {
    opacity: 1 !important;
    color: #ffffff;
}

.btn:hover .btn-inner::after {
    width: 100%;
}

@media screen and (max-width: 1200px) {
    .btn {
        height: 50px;
    }
}

/* container */
.container {
    padding-top: 80px;
    padding-bottom: 80px;
}

@media screen and (max-width: 1024px) {
    .container {
        padding-top: 60px;
        padding-bottom: 60px;
    }
}

/* inner */
.sec-inner {
    width: 85%;
    max-width: 1150px;
    margin: 0 auto;
}

.main-inner {
    width: 85%;
    max-width: 1560px;
    margin: 0 auto;
}

@media screen and (max-width: 1024px) {
    .sec-inner,
    .main-inner {
        width: 92%;
    }
    
}


/* page-bottom-bg */
.page-bottom-bg img {
    width: 100%;
}

/*=================================================
    ヘッダー
=================================================*/
/* メニュー共通 */
.menu li a {
    /*color: #000;*/
}

li.menu-item {
    position: relative;
}

li.menu-item::after {
    font-size: 10px;
    color: #545353;
    display: block;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 27px;
    width: 100%;
    text-align: center;
}

.nav-home::after {
    content: "HOME";
}
.nav-service::after {
    content: "Medical Service";
}
.nav-doctor::after {
    content: "Doctor Introduction";
}
.nav-clinic::after {
    content: "Clinic Introduction";
}
.nav-reserve::after {
    content: "Medical Appointment";
}
.nav-news::after {
    content: "News";
}
.nav-access::after {
    content: "Access";
}
.nav-contact::after {
    content: "Contact";
}
.nav-faq::after {
    content: "Q&A";
}
.nav-recruit::after {
    content: "Staff Recruitment";
}


/* ヘッダーメニュー */
body:not(.home) .header-wrapL,
body:not(.home) .header-nav {
    display: none;
}

#site-header {
    opacity: 0;
}

#site-header {
    position: absolute;
    z-index: 2;
    width: 100%;
    max-width: none;
    padding: 1rem 0 !important;
}

.header-inner{
    max-width: 1700px !important;
    width: 92% !important;
    margin: 0 auto;
    padding-top: 50px;
}

.site-header:not(.header-stacked) .header-inner .site-branding {
    max-width: none;
}

.header-logo {
    max-width: 210px;
}

.header-wrap {
    justify-content: space-between;
    /* align-items: center; */
    width: 100%;
}

.header-logo2,
.header-yoyaku-sp,
.header-logo-sp {
    display: none;
}

#menu-main {
    display: flex;
}

#menu-main li {
    padding-left: 30px;
    padding-right: 30px;
}

#menu-main .nav-home,
#menu-main .nav-reserve,
#menu-main .nav-news,
#menu-main .nav-recruit {
    display: none;
}

@media screen and (min-width: 1201px) {
    body:not(.home) #site-header {
        pointer-events: none;
    }
}

@media screen and (max-width: 1200px) {
    #site-header {
        position: fixed;
        background-color: rgba(255, 255, 255, 0.9);
        padding: 10px 0 !important;

    }

    .header-wrap {
        align-items: center;
    }
    
    body:not(.home) .header-wrapL {
        display: block;
    }
    
    .header-logo {
        display: none !important;
    }
    
    .header-logo2 {
        display: flex;
        align-items: center;
    }
    
    .header-logo2 a {
        align-items: center;
    }
    
    .header-logo-tb {
        width: 170px;
        display: block;
    }
    
    .header-yoyaku {
        padding-left: 40px;
        width: 195px;
        display: block;
    }
    
    .header-inner {
        padding: 0 !important;
    }

    #menu-main {
        display: none;
    }
}

@media screen and (max-width: 767px) {
    #site-header {
        background-color: rgba(170, 220, 200, 1);
    }

    .header-wrap {
        justify-content: flex-end;
        position: relative;
    }

    .header-wrapL {
        display: none !important;
    }

    .header-logo-sp {
        display: block;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
        width: 185px;
    }
    
    .header-yoyaku-sp {
        display: block;
        position: absolute;
        bottom: -38px;
        height: 38px;
        background-image: url(img/header-yoyaku-bg.png);
        background-position: center;
        background-repeat: no-repeat;
        background-size: cover;
        background-color: #6C4F3F;
        text-align: center;
        line-height: 38px;
        width: 100%;
    }
    
    .header-yoyaku-sp a {
        color: #ffffff;
        font-weight: 300;
        display: block;
        width: 100%;
    }
}



/****************
サイドメニュー
*****************/
.mobmenu-wrap {
    padding-top: 25px;
    position: relative;
    min-height: 100vh;
}

.mobmenu {
    padding-bottom: 190px;
    
    padding: 0;
    position: absolute;
    left: 0;
    width: 100%;
    top: 50%;
    transform: translateY(-50%);
}

.mobmenu-heading {
    display: flex;
    flex-direction: column;
    align-items: center;
    
    position: absolute;
    left: 0;
    width: 100%;
    top: 4vh;
}

.mobmenu-logo {
    max-width: 136px;
    width: 80%;
    margin-bottom: 10px;
}

.mobmenu-logo:hover {
    opacity: 1;
}

.mobmenu-text {
    display: flex;
    margin-bottom: 25px;
    color: #513027;
}

.mobmenu-text span {
    margin-right: 5px;
    margin-left: 5px;
}

.mobmenu .menu-main-container > ul {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-left: 0;
}

.mobmenu .menu-main-container > ul li {
    margin-bottom: 40px;
    display: block;
    width: 100%;
    text-align: center;
}

.mobmenu-bottom {
    background-color: #B1DBCB;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    text-align: center;
    padding: 25px 10px 30px;
    /*color: black;*/
}

.mobmenu-map {
    margin-bottom: 10px;
}

.mobmenu-tel {
    margin-top: 10px;
}

.mobmenu-tel a {
    /*color: black;*/
}

.mobmenu-map img {
    transform: rotate(0);
    transform-origin: bottom;
    animation: map 4.5s linear infinite;
}

@keyframes map {
    0% { transform: rotate(0); }
    1.5% { transform: rotate(10deg); }
    3% { transform: rotate(0); }
    4.5% { transform: rotate(-10deg); }
    6% { transform: rotate(0); }
    7.5% { transform: rotate(10deg); }
    9% { transform: rotate(0); }
    10.5% { transform: rotate(-10deg); }
    12% { transform: rotate(0); }
    100% { transform: rotate(0); }
}

/*@media screen and (min-width: 1201px) {
    .mobmenu-heading {
        position: absolute;
        left: 0;
        width: 100%;
        top: 4vh;
    }
    
    .mobmenu {
        padding: 0;
        position: absolute;
        left: 0;
        width: 100%;
        top: 50%;
        transform: translateY(-50%);
    }
    
    .mobmenu .menu-main-container > ul li {
        margin-bottom: 40px;
    }
}*/

@media screen and (max-height: 1000px) /*and (min-width: 1201px)*/ {
    .mobmenu .menu-main-container > ul li {
        margin-bottom: 30px;
    }
    
    .mobmenu {
        margin: 20px 0 0;
    }
    
    .mobmenu-post, .mobmenu-address {
        text-align: left;
    }
    
    .mobmenu-map {
        position: absolute;
        width: 40px;
        right: 10px;
        top: 25px;
    }
    
    .mobmenu-tel {
        margin: 0;
    }    
}

@media screen and (max-height: 860px) /*and (min-width: 1201px)*/ {
    .mobmenu-text {
        margin-bottom: 15px;
    }
    
    .side-menu .menu li {
        margin-bottom: 22px !important;
    }
    
    .side-menu .menu li a {
        font-size: 14px;
    }
    
    .side-menu .menu li::after {
        top: 22px;
    }
    
    .mobmenu-bottom {
        padding: 20px 15px;
    }
    
    .mobmenu-address {
        font-size: 14px;
    }
    
    .mobmenu-tel a {
        font-size: 18px;
    }
}

@media screen and (max-height: 750px) /*and (min-width: 1201px)*/ {
    .mobmenu-heading {
        position: static;
    }
    
    .mobmenu {
        padding: 0 0 110px;
        position: static;
        transform: none;
        margin: 0;
    }
}

@media screen and (max-width: 1200px) {
    .mobmenu-wrap {
        padding-top: 50px;
    }
}

/****************
mobmenu
*****************/
.openbtn,
.mobmenu-fix,
header .side-area {
    display: none;
}

@media screen and (max-width: 1200px) {
    .openbtn,
    .mobmenu-fix,
    header .side-area {
        display: block;
    }
}

.openbtn{
	position: relative;
	cursor: pointer;
    width: 50px;
    height:50px;
	border-radius: 5px;
    z-index: 100;
}

.openbtn .openbtn-area{
    transition: all .4s;
}

.openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 2px;
    border-radius: 2px;
	background: #6C4F3F;
  	width: 45%;
}

.openbtn span:nth-of-type(1) {
	top:15px;	
}

.openbtn span:nth-of-type(2) {
	top:23px;
}

.openbtn span:nth-of-type(3) {
	top:31px;
}

.openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
}

.openbtn.active span:nth-of-type(2) {
	opacity: 0;
}

.openbtn.active span:nth-of-type(3){
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
}

/****************
画面左端の要素
*****************/
/* 予約 */
.yoyaku {
    position: fixed;
    z-index: 999;
    left: 0;
    bottom: 18%;
    opacity: 0;
}

.yoyaku a:hover {
    opacity: 1;
}

.yoyaku span {
    display: block;
    position: relative;
}

.yoyaku-img {
    z-index: 1;
}

.yoyaku-text {
    margin-top: -40px;
}

@media screen and (max-width: 1200px) {
    .yoyaku {
        display: none !important;
    }
}

/* 縦書き文字 */
.side-text {
    display: none;
    writing-mode: vertical-rl;
    font-size: 12px;
    color: #555555;
    position: absolute;
    z-index: 998;
    left: 15px;
    white-space: nowrap;
}

.side-text.fix {
    position: fixed;
    top: 180px !important;
}

.side-text.stop {
    position: absolute;
    top: auto !important;
    height: 100%;
}

.side-text.stop .side-text-inner {
    position: absolute;
    left: 0;
    bottom: 0;
}

@media screen and (max-width: 1200px) {
    .side-text {
        left: 5px;
    }
}

@media screen and (max-width: 767px) {
    .side-text {
        display: none !important;
    }
}

/*=================================================
    フッター
=================================================*/
#site-footer {
    max-width: none !important;
    padding: 0;
}

.footer-inner {
    max-width: none !important;
    padding: 0 !important;
    position: relative;
}

.footer-L {
    width: 43.5%;
    background-color: #B1DBCB;
    padding: 80px 5%;
    justify-content: center;
    align-items: center;
}

.footer-info {
    color: #555555;
    font-size: 16px;
    font-weight: 300;
    margin-top: 5px;
}

.footer-info span {
    display: inline-block;
}

.footer-zip {
    font-size: 14px;
    padding-right: 0.8em;
}

.footer-address {
    padding-right: 0.8em;
}

.footer-telno {
    font-size: 20px;
    font-weight: 500;
    padding: 0 1.5em 0 5px;
}

.footer-R {
    width: 56.5%;
    background-color: #F2F0EC;
    padding: 80px 5%;
    justify-content: center;
    align-items: flex-start;
}

.footer-R-inner {
    width: 100%;
    max-width: 680px;
}

.footer-menu-title {
    font-size: 14px;
    color: black;
    margin-bottom: 30px;
}

.footer-menu-item {
    color: black;
    font-size: 14px;
}

.footer-menu1 {
    padding-bottom: 15px;
    margin-bottom: 15px;
    border-bottom: 1px solid #707070;
}

.footer-menu1 .footer-menu-item:not(:last-child) {
    margin-right: 50px;
}

.footer-menu2 .footer-menu-item:not(:last-child) {
    margin-right: 40px;
}

.footer-copyright {
    font-size: 12px;
    margin-top: 40px;
    color: black;
}

.totop {
    position: absolute;
    right: 300px;
    bottom: 50px;
    cursor: pointer;
}

@media screen and (max-width: 1280px) and (min-width: 1025px) {
    .footer-menu1 .footer-menu-item:not(:last-child) {
        margin-right: 30px;
    }
}

@media screen and (max-width: 1200px) {
    .totop {
        right: 2.5%;
    }
}

@media screen and (max-width: 1024px) {
    .footer-L {
        width: 100%;
        padding: 40px 5%;
    }
    
    .footer-R {
        width: 100%;
        padding: 40px 5% 25px;
    }
    
    .footer-copyright {
        text-align: center;
    }
}

@media screen and (max-width: 640px) {
    .footer-logo {
        max-width: 320px;
        margin: 0 auto;
    }

    .footer-menu-title {
        width: 240px;
        margin: 0 auto 20px;
    }
    
    .footer-menu {
        width: 240px;
        margin: 0 auto;
    }
    
    .footer-menu1 {
        padding: 0;
        border: 0;
    }
    
    .footer-menu-item {
        width: 50%;
        margin: 0 0 8px !important;
    }
    
    .footer-copyright {
        margin: 25px 0 0;
    }
}

@media screen and (max-width: 480px) {
    .footer-info {
        text-align: center;
    }
    
    .footer-address, .footer-telno {
        padding-right: 0;
    }
    
    .footer-parking, .footer-division {
        width: 100%;
    }
}

/*=================================================
    トップ
=================================================*/
/****************
top-slider
*****************/
.top-wrap {
    position: relative;
}

.top-slider {
    position: relative;
    overflow: hidden;
    min-height: 768px;
    max-height: 1080px;
}

.slide-img {
    background-position: top;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 110%;
    opacity: 0;
    transition: transform 0s 1s, opacity 1s linear;
    transform: translate3d(0,0,0);
}

.slide1 {
    background-image: url(img/slide1.webp);
    opacity: 1;
}
.slide2 {
    background-image: url(img/slide2.webp);
}

.slide-img.on {
    /*top: -50px;*/
    opacity: 1;
    transition: transform 10s linear, opacity 1s linear;
    transform: translate3d(0,-50px,0);
}

.slide-mask {
    position: relative;
    width: 100%;
}

.slide-mask img {
    object-fit: cover;
    object-position: left;
    width: 100%;
    height: 100%;
}

.top-content {
    position: absolute;
    top: 37%;
    left: 0;
    width: 100%;
    opacity: 0;
}

.top-text-lead {
    color: #AADCC8;
    text-shadow: 0 0 10px #ffffff,
     0 0 10px #ffffff,
      0 0 10px #ffffff,
       0 0 10px #ffffff,
        0 0 10px #ffffff,
         0 0 20px #ffffff,
          0 0 20px #ffffff,
           0 0 20px #ffffff,
            0 0 20px #ffffff;
    margin-bottom: 20px;
    font-weight: 300 !important;

}

.top-text-main {
    color: #6C4F3F;
    text-shadow: 0 0 10px #ffffff,
    0 0 10px #ffffff,
     0 0 10px #ffffff,
      0 0 10px #ffffff,
       0 0 10px #ffffff,
        0 0 20px #ffffff,
         0 0 20px #ffffff,
          0 0 20px #ffffff,
           0 0 20px #ffffff;
   margin-bottom: 20px;
   letter-spacing: 0.09em;
   line-height: 1.34;
   font-weight: 300 !important;
   font-size: clamp(1.25rem, 1.1rem + 0.5vw, 2rem);
}

.top-text-small {
    line-height: 1.625;
    font-weight: 300 !important;
}

.btn-wrap-top {
    justify-content: flex-start;
    margin-top: 24px;
}

.btn-top {
    width: 178px;
}

.btn-top--clinic {
    margin-right: 10px;
}

.top-content .btn {
    opacity: 0;
}

@media screen and (max-width: 1024px) {
    .top-slider {
        min-height: 780px;
        height: 100dvh;
    }

    @media (orientation: landscape){
        .top-content {
            top: 30%;
        }
    }
}

@media screen and (max-width: 600px) {
    .top-text-small .br {
        display: none;
    }

    .slide-mask img {
        object-position: 12%;
    }
}

@media screen and (max-width: 480px) {
    .top-text-main br.block {
        display: none;
    }

    .top-content {
        top: 40%;
    }

    .top-text-main,
    .top-text-small {
        width: 267px;
    }
}

@media screen and (max-width: 380px) {
    .top-content {
        top: 39%;
    }
}

/****************
slider-news
*****************/
.swiper {
    width: 100%;
    height: 100%;
}

.slider-news {
    height: 74px;
    margin-top: 5px;
    margin-bottom: 5px;
    display: inline-flex;
    align-items: center;
    padding-left: 60px;
    padding-right: 30px;
    /*background-color: #fff;
    border-radius: 0 10px 10px 0;
    transition: width 0.3s;*/
    position: relative;
}

.slider-news-bg {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    background-color: #fff;
    border-radius: 0 10px 10px 0;
    transition: width 0.4s 0.1s;
}

.slider-newsSwiper .swiper-slide {
    display: flex;
    align-items: center;
}

.slider-news-item {
    flex-wrap: nowrap;
}

.slider-news-title {
    color: #6C4F3F;
}

.slider-news-date {
    color: #74A793;
    margin-right: 24px;
    font-weight: 300;
    position: relative;
}

.swiper-button-next, .swiper-button-prev {
    z-index: 1;
}

.slider-news-date::before,
.slider-news-date::after {
    position: absolute;
    content: "";
    left: 0;
    bottom: -2px;
    height: 1px;
}

.slider-news-date::before {
    width: 100%;
    background-color: #cccccc;
}

.slider-news-date::after {
    width: 0;
    background-color: #6C4F3F;
    transition: width 6s linear;
}

.swiper-slide-active .slider-news-date::after {
    width: 100%;
}

@media screen and (max-width: 1024px) {
    .slider-news {
        padding-left: 4%;
        height: 60px;
    }

}


/****************
top-clinic
*****************/
@media screen and (min-width: 1025px) {
    .container-top-clinic {
        padding-bottom: 45px;
    }
}

#top-clinic.sec-tit-wrap {
    padding-top: 80px;
    margin-top: -80px;
}

.container-top-clinic {
    padding-top: 45px;
    position: relative;
    z-index: 1;
}

.top-clinic {
    position: relative;
    background-color: #F9F7F5;
    overflow: hidden;
}

.top-clinic::after {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    content: "";
    background-image: url(img/top-bg.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    width: 100%;
    height: 250px;
    z-index: 0;
}

.top-clinic-img {
    justify-content: space-between;
    max-width: 1637px;
    margin: 0 auto 80px;
}

.top-clinic-imgL {
    position: relative;
    width: 60%;
    max-width: 985px;
    overflow: hidden;
    min-height: 200px;
    border-radius: 0 54px 54px 0;
}

.top-clinic-imgR {
    position: relative;
    width: 38%;
    max-width: 622px;
    overflow: hidden;
    min-height: 200px;
    border-radius: 54px 0 0  54px;
}

.top-clinic-imgL::before,
.top-clinic-imgR::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-size: 100% 100%;
    opacity: 0.8;
    transition: 0.6s linear;
}

.top-clinic-imgL::before {
    background-image: url(img/maskL.png);
}

.top-clinic-imgR::before {
    background-image: url(img/maskR.png);
}

.top-clinic-img.on .top-clinic-imgL::before,
.top-clinic-img.on .top-clinic-imgR::before {
    left: 100%;
}

.top-clinic-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top-clinic-flex {
    justify-content: space-between;
    flex-wrap: nowrap;
}

.top-clinic-L {
    width: 48%;
}

.top-clinic-sp-img {
    display: none;
}

.top-clinic-R {
    width: 48%;
    margin-top: -25px;
    /*min-width: 280px;*/
}

.sec-text-sub--top-clinic {
    padding-bottom: 20px;
}

@media screen and (max-width: 1024px) {
    .top-clinic::after {
        height: 200px;
    }

    .top-clinic-L {
        margin-right: 25px;
    }

    .top-clinic-R {
        margin-top: 0;
    }

    .top-clinic-img {
        margin: 0 auto 60px;
    }
    
}

@media screen and (max-width: 767px) {
    .top-clinic::after {
        height: 150px;
    }

    .top-clinic-flex {
        flex-wrap: wrap;
    }

    .top-clinic-L {
        width: 100%;
    }

    .top-clinic-sp-img {
        display: block;
        width: 100%;
        max-width: 378px;
        margin: 0 auto;
        padding-bottom: 10px;
    }

    .sec-text-sub--top-clinic {
        padding-bottom: 30px;
    }

    .top-clinic-R {
        display: none;
    }

    .top-clinic .btn-wrap-top {
        justify-content: center;
    }
}

@media screen and (max-width: 480px) {
    .top-clinic-imgL {
        border-radius: 0 30px 30px 0;
    }
    .top-clinic-imgR {
        border-radius: 30px 0 0 30px;
    }
}

/****************
top-feature
*****************/
.top-feature {
    background-color: #F2F0EC;
}

.top-feature-wrap {
    justify-content: space-between;
    margin-top: 50px;
}

.top-feature-item {
    position: relative;
    width: 31.3%;
    background-color: white;
    border-radius: 20px;
    padding: 50px max(3%, 35px);
}

.top-feature-no {
    position: absolute;
    left: -20px;
    top: -25px;
    opacity: 0;
    transform: translateY(30px);
    transition: 1.2s;
}

.top-feature-item.on .top-feature-no {
    opacity: 1;
    transform: translateY(0);
}

.top-feature-tate {
    position: absolute;
    right: 15px;
    bottom: 20px;
}

.top-feature-title {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 20px;
    min-height: 81px;
}

.top-feature-text {
    line-height: 1.8;
}

@media screen and (max-width: 1410px) and (min-width: 1025px) {
    .top-feature-title .ib {
        display: inline;
    }
}

@media screen and (max-width: 1024px) {
    .top-feature-item {
        width: 100%;
        margin-left: 30px;
        margin-right: 30px;
    }
    
    .top-feature-item:not(:last-child) {
        margin-bottom: 45px;
    }
    
    .top-feature-title {
        min-height: 0;
    }
}

@media screen and (max-width: 640px) {
    .top-feature-no {
        left: -7px;
    }
}

@media screen and (max-width: 350px) {
    .top-feature-title .ib {
        display: inline;
    }
}

/****************
top-news
*****************/
@media screen and (min-width: 1025px) {
    .container-top-news {
        padding-bottom: 117px;
    }
}

.top-news-position {
    position: relative;
}


.top-news {
    background-color: #F9F7F5;
}

.top-news-list {
    justify-content: space-between;
    flex-wrap: nowrap;
}

.top-news-item {
    width: 29.5%;
    opacity: 0;
    transform: translateY(30px);
    transition: 1.2s ease;
}

.top-news-item.on {
    opacity: 1;
    transform: translateY(0);
}

.top-news .single-img {
    max-height: 200px;
    margin-bottom: 20px;
    overflow: hidden;
    border-radius: 20px;
}

.top-news-date {
    margin-bottom: 5px;
}

.top-news-title {
    margin-bottom: 20px;
}

.top-news-content {
    line-height: 1.875;
}

@media screen and (max-width: 1200px) {
    .top-news-item {
        width: 31%;
    }

    .top-news-title {
        margin-bottom: 10px;
    }
    
    .top-news-content {
        line-height: 1.5;
    }
}

@media screen and (min-width: 768px) {
    .swiper-button-next,
    .swiper-button-prev {
        display: none;
    }

}

@media screen and (max-width: 767px) {
    .top-newsSwiper {
        width: 80%;
    }

    .top-news .single-img {
        max-height: none;
    }
    
    .swiper-button-next{
        background-color: #B1DBCB;
        background-image: none;
        border: 1px solid #ffffff;
        border-radius: 100%;
        width: 40px;
        height: 40px;
    }

    .swiper-button-next::after {
        display: block;
        color: #ffffff;
        font-size: 18px;
        padding-left: 3px;
        line-height: 38px;
    }

    .swiper-button-prev{
        background-image: none;
        background-color: #B1DBCB;
        border: 1px solid #ffffff;
        border-radius: 100%;
        width: 40px;
        height: 40px;
    }

    .swiper-button-prev::after {
        display: block;
        color: #ffffff;
        font-size: 18px;
        padding-right: 3px;
        line-height: 38px;
    }
}

@media screen and (max-width: 600px) {
    .top-news-position {
        padding-bottom: 60px;
    }

    .swiper-button-next {
        top: auto;
        bottom: 0px;
        left: 52%;
        right: auto;
    }
    .swiper-button-prev {
        top: auto;
        bottom: 0px;
        right: 52%;
        left: auto;
    }
}


/****************
top-access
*****************/
.top-access-inner {
    margin-left: calc(50% - 575px);
}

.top-access-logo {
    width: 96%;
    max-width: 379px;
    margin-bottom: 27px;
}

.top-access-flex {
    justify-content: space-between;
    flex-wrap: nowrap;
}

.top-access-L {
    width: 42%;
    min-width: 470px;
    flex-shrink: 0;
    margin-right: 47px;
    color: #513027;
}

.top-access-R {
    width: calc(58% - 30px);
}


.top-access {
    background-color: #F2F0EC;
}

.access-table {
    margin-bottom: 45px;
    max-width: 600px;
}

table , td, th {
    border-collapse: collapse;
    background-color: #fff !important;
}

table td, table th {
    /*border: 0.5px solid #513027;*/
    border: 1px solid #513027;
    vertical-align: middle;
    text-align: center;
    padding: 10px;
}

th {
    height: 37px;
    font-weight: 300 !important;
}

td {
    width: 68px;
	height: 83px;
    font-weight: 300 !important;
}

.access-table-time {
    width: 173px;
}

.access-table-time .block {
    display: none;
}

.access-table-time .ls {
    letter-spacing: 0.04em;
}

.maru {
    display: block;
    width: 30px;
    height: 30px;
    background-color: #B1DBCB;
    border-radius: 100%;
    margin: 0 auto;
    position: relative;
}

.maru-notice::after {
    position: absolute;
    bottom: -24px;
    left: 50%;
    transform: translateX(-50%);
    content: "17:00まで";
    font-size: 14px;
    font-weight: 300;
    letter-spacing: -0.04em;
    white-space: nowrap;
}

.top-access-list {
    align-items: center;
    flex-wrap: nowrap;
    margin-bottom: 24px;
}

.top-access-listL {
    width: 176px;
    height: 33px;
    margin-right: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #6C4F3F;
    background-color: #fff;
}

.top-access-post {
    padding-top: 5px;
    margin-bottom: 5px;
}

.top-access-map {
    position: relative;
    height: 482px;
    border-radius: 54px 0 0 54px;
    overflow: hidden;
    z-index: 1
}

.top-access-map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: calc(100% + 320px);
    margin-top: -160px;
}


@media screen and (max-width: 1650px) {
    .top-access-inner {
        margin-left: 7.5%;
    }
}

@media screen and (max-width: 1200px) {
    .maru-notice::after {
        font-size: 12px;
    }
    
}

@media screen and (max-width: 1024px) {
    .top-access-inner {
        margin-left: 4%;
    }

    .top-access-flex {
        flex-wrap: wrap;
    }

    .top-access-L {
        width: 96%;
        margin-right: 0;
        margin-bottom: 20px;
    }

    .top-access-R {
        width: 100%;
    }
}

@media screen and (max-width: 600px) {
    .top-access-logo {
        max-width: 335px;
        margin: 0 auto 20px;
        padding-right: 15px;
    }

    .top-access-L {
        min-width: 0;
    }

    table td, table th {
        padding: 5px;
    }

    .access-table-time {
        width: 58px;
    }

    .access-table-time .block {
        display: block;
    }

    .access-table-time .hankaku {
        display: none;
    }

    .maru {
        height: 20px;
        width: 20px;
    }

    .maru-notice{
        top: -12px;
    }

    .maru-notice::after {
        bottom: -34px;
        white-space: normal;
        line-height: 1;
    }

    .top-access-listL{
        width: 100px;
        flex-shrink: 0;
    }

    .top-access-map {
        height: 350px;
    }
}


/****************
top-reserve
*****************/
@media screen and (min-width: 1025px) {
    .container-top-reserve {
        padding-bottom: 38px;
    }
}

.top-reserve {
    background-color: #F9F7F5;
}

.top-reserve-flex {
    justify-content: space-between;
    margin-top: 25px;
}

.top-reserve-L {
    margin-top: 12px;
    width: calc(100% - 363px);
}

.top-reserve-R {
    width: 300px;
    flex-shrink: 0;
}

.top-reserve-text {
    line-height: 2.25;
}

.btn-wrap-top-reserve {
    justify-content: flex-start;
    margin-top: 40px;
}

.btn-wrap-top-reserve a {
    margin: 0 10px 0 0;
}

.top-reserve-sp-img {
    display: none;
}

.btn-top-reserve {
    width: 303px;
}

.top-reserve-text .text-under {
    display: inline-block;
    text-decoration: underline;
    text-decoration-thickness: 0.5px;
    text-decoration-color: #555555;
    letter-spacing: -0.04em;
    margin-right: 5px;
    white-space: nowrap;
}

.qr-tel-desc {
    margin-top: 20px;
    text-align: center;
}

.qr-tel a:hover {
    opacity: 1;
}


@media screen and (max-width: 1550px) {
    .top-reserve-text .br {
        display: none;
    }
}

@media screen and (min-width: 1025px) {
    .qr-tel a {
        pointer-events: none;
    }
}

@media screen and (max-width: 1024px) {
    .top-reserve-L {
        margin-top: 0;
        width: calc(100% - 320px);
    }
}

@media screen and (max-width: 767px) {
    .top-reserve-L {
        width: 100%;
    }

    .top-reserve-R {
        width: 100%;
        margin: 30px auto 0;
        max-width: 300px;
    }

    .qr-tel {
        text-align: center;
    }

    .btn-wrap-top-reserve {
        justify-content: center;
    }
    
    .btn-wrap-top-reserve a {
        margin: 0 5px 0;
    }

    .top-reserve-text {
        line-height: 1.8;
    }
}

@media screen and (max-width: 600px) {
    .btn-wrap-top-reserve {
        flex-wrap: wrap;
    }
    
    .btn-wrap-top-reserve a {
        margin: 0 0 10px;
    }
}









/*=================================================
サブページ共通
=================================================*/
.subheader {
    opacity: 0;
}

.subheader-inner {
    width: 92%;
    max-width: 1440px;
    margin: 0 auto;
}

.subheader-bg {
    /* height: 100vh;
    max-height: 1080px;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover; */
    position: relative;
}


/* .subheader-news .subheader-bg {
    background-image: url(img/subheader-news.webp);
} */

@media screen and (max-width: 1200px) {
    .subheader-img img {
        height: 100vh;
        width: 100%;
        object-fit: cover;
        object-position: 70%;
    }
}

@media screen and (max-width: 767px) {
    .subheader-img img {
        height: calc(100vh + 65px);
    }
}

.subheader-tit-wrap {
    position: absolute;
    left: 0;
    bottom: 0;
    background-color: rgba(177,219,203,0.5);
    width: 100%;
}
.subheader-tit {
    color: #fff;
    padding-top: 34px;
    padding-bottom: 34px;
    font-size: 18px;
}

@media screen and (max-width: 767px) {
    .subheader-tit {
        padding-top: 20px;
        padding-bottom: 20px;
    }
}

/*=================================================
    診療案内　service
=================================================*/
/* .service-bg {
    background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 31%, #F2F0EC 31%, #F2F0EC 100%);
}

@media screen and (max-width: 767px) {
    .service-bg {
        background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 34%, #F2F0EC 34%, #F2F0EC 100%);
    }
} */

.service-bg {
    background-color: #F9F7F5;
}

/****************
service1
*****************/

/****************
service2
*****************/
.service2-list dl {
    margin-bottom: 50px;
    padding-left: 15px;
    border-left: 7px solid rgba(177,219,203,1);
}

.service2-list dl.sleep {
    margin-top: 90px;
}

.service2-list dt {
    margin-bottom: 20px;
    font-size: 22px;
    font-weight: 500;
}

.service2-list dd {
    font-size: 16px;
    margin-left: 0;
}

.service2-outline {
    margin-bottom: 20px !important;
    margin-left: 65px;
    margin-right: 65px;
    padding: 20px;
    border: 2px solid #B1DBCB;
    border-radius: 10px;
}

.service2-outline h3 {
    display: block;
    margin-bottom: 10px;
    font-size: 18px;
    font-weight: 500;
    line-height: 1.4;
}

.service2-outline p {
    font-size: 14px;
    line-height: 1.8;
}

@media screen and (max-width: 767px) {
    .service2-outline {
        margin-left: 20px;
        margin-right: 20px;
        padding: 10px;
    }
}

/****************
service3
*****************/
.service1-img {
    padding-top: 60px;
    padding-bottom: 34px;
}

@media screen and (max-width: 1024px) {
    .service1-img {
        padding-top: 0;
        padding-bottom: 0;
    }
}

/*=================================================
    医師紹介　doctor
=================================================*/
@media screen and (min-width: 1025px) {
    .sec-tit-wrap--doctor {
        padding-bottom: 70px !important;
    }
}

/****************
doctor1
*****************/
@media screen and (min-width: 1025px) {
    .container-doctor1.container {
        padding-bottom: 78px;
    }
}

.doctor1 {
    background-color: #F9F7F5;
}

.doctor-sign {
    margin-top: 30px;
    text-align: right;
}

.doctor-sign span {
    margin-right: 1em;
}

/****************
doctor2
*****************/
@media screen and (min-width: 1025px) {
    .container.container-doctor2 {
        padding-bottom: 115px;
    }
}

.doctor2 {
    background-color: #F2F0EC;
}

.doctor2-items {
    max-width: 800px;
}

.doctor2-item {
    align-items: center;
    padding-top: 17px;
    padding-bottom: 17px;
    border-bottom: 0.5px solid #707070;
}

.doctor2-itemL {
    width: 180px;
    padding-left: 45px;
    flex-shrink: 0;
}

.doctor2-itemR {
    width: calc(100% - 180px);
}

.doctor2-add .doctor2-item p {
    padding-left: 45px;
}

@media screen and (max-width: 767px) {
    .doctor2-itemL {
        width: 130px;
        padding-left: 20px;
        }
    
    .doctor2-itemR {
        width: calc(100% - 130px);
    }
    
    .doctor2-add .doctor2-item p {
        padding-left: 20px;
    }
}


@media screen and (max-width: 420px) {
    .doctor2-itemL {
        width: 100%;
        margin-bottom: 5px;
    }

    .doctor2-itemR {
        width: 100%;
        padding-left: 20px;
    }
}

/****************
doctor2-add
*****************/
.doctor2-add {
    justify-content: space-between;
}

.doctor2-addL {
    width: 48%;
}
.doctor2-addR {
    width: 48%;
}

.doctor2-add {
    margin-top: 80px;
}

.doctor2-add .sec-tit-wrap {
    padding-bottom: 30px !important;
}

.doctor2-add .doctor2-item p {
    padding-left: 20px;
}

@media screen and (max-width: 1024px) {
    .doctor2-add {
        margin-top: 60px;
    }
}

@media screen and (max-width: 767px) {
    .doctor2-addL {
        width: 100%;
        margin-bottom: 60px;
    }
    .doctor2-addR {
        width: 100%;
    }
    
}

/****************
doctor3
*****************/
.doctor3-img {
    height: 20vw;
    /* background-image: url(img/doctor3-img.webp);
    background-size: 100% auto;
    background-position: center;
    background-repeat: no-repeat; */
    overflow: hidden;
    background-color: #F2F0EC;
}

@media screen and (max-width: 767px) {
    .doctor3-img {
        height: 25vw;
    }
}

/*=================================================
    院内紹介　clinic
=================================================*/
.container-clinic {
    padding-bottom: 0 !important;
}

.sec-inner--clinic {
    max-width: 1230px !important;
}

.sec-tit-wrap--clinic {
    padding-bottom: 7px !important;
}

.clinic-bg {
    background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 660px, #F2F0EC 660px, #F2F0EC 1195px, #F9F7F5 1195px, #F9F7F5 1725px, #F9F7F5 100%);
}

.clinic-items {
    justify-content: space-between;
}

.clinic-item {
    width: calc(33.333% - 60px * 2/3);
    height: 415px;
    margin-top: 60px;
    margin-bottom: 60px;
}

.clinic-img {
    margin-bottom: 20px;
    cursor: pointer;
    transition: 1s;
    border-radius: 20px;
    display: block;
    position: relative;
    z-index: 1;
    overflow: hidden;
}

.clinic-img:hover {
    opacity: 1 !important;
}

.clinic-img img {
    border-radius: 20px !important;
}

.clinic-img::before {
    position: absolute;
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 50%;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    margin: auto;
    background-color: rgba(177,219,203,0.8);
    transform: scale(0);
    transition: 1s cubic-bezier(.77,0,.18,1);
    transition-property: opacity, transform;
    z-index: 2;
    opacity: 0;
}

.clinic-img:hover::before {
    transform: scale(100);
    opacity: 1;
    transition-duration: 1.3s;
    transition-timing-function: cubic-bezier(.19,1,.22,1);
}

.clinic-tit {
    margin-bottom: 25px;
}

.clinic-text {
    line-height: 1.875;
}

@media screen and (max-width: 1200px) {
    .clinic-bg {
        background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 640px, #F2F0EC 640px, #F2F0EC 1180px, #F9F7F5 1180px, #F9F7F5 1725px, #F9F7F5 100%);
    }
}

@media screen and (max-width: 1024px) {
    .clinic-item {
        width: calc(33.333% - 25px * 2/3);
    }
}

@media screen and (max-width: 767px) {
    .clinic-item {
        width: calc(50% - 15px * 1/2);
        height: 350px;
        margin-top: 45px;
        margin-bottom: 45px;
    }

    .clinic-tit {
        margin-bottom: 15px;
    }
    
    .clinic-text {
        line-height: 1.3;
    }
    
    
    .clinic-bg {
        background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 570px, #F2F0EC 570px, #F2F0EC 1010px, #F9F7F5 1010px, #F9F7F5 1450px, #F2F0EC 1450px, #F2F0EC 1890px, #F9F7F5 1890px,#F9F7F5 100%);
    }
}

@media screen and (max-width: 600px) {
    .clinic-item {
        height: 285px;
    }
    
    .clinic-bg {
        background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 510px, #F2F0EC 510px, #F2F0EC 885px, #F9F7F5 885px, #F9F7F5 1260px, #F2F0EC 1260px, #F2F0EC 1640px, #F9F7F5 1640px,#F9F7F5 100%);
    }
}

@media screen and (max-width: 420px) {
    .clinic-item {
        height: 270px;
    }
    
    .clinic-bg {
        background: linear-gradient(to bottom, #F9F7F5, #F9F7F5 485px, #F2F0EC 485px, #F2F0EC 850px, #F9F7F5 850px, #F9F7F5 1220px, #F2F0EC 1220px, #F2F0EC 1570px, #F9F7F5 1570px,#F9F7F5 100%);
    }
}

/****************
ライトボックス
*****************/
.lb-dataContainer {
    padding-top: 20px !important;
}

.lb-data .lb-caption {
    font-size: 22px !important;
    font-weight: 400 !important;
    color: #ffffff;
}

.lb-data .lb-close {
    opacity: 1 !important;
}

.lb-nav a.lb-prev,
.lb-nav a.lb-next {
    opacity: 1 !important;
}


@media screen and (min-width: 1401px) {
    .lb-nav a.lb-prev {
        transform: translateX(-60px);
    }
    .lb-nav a.lb-next {
        transform: translateX(60px);
    }
}
@media screen and (max-width: 1400px) {
    .lb-nav a.lb-prev {
        transform: translateX(10px);
    }
    .lb-nav a.lb-next {
        transform: translateX(-10px);
    }
}

@media screen and (max-width: 767px) {
    .lb-data .lb-caption {
        font-size: 18px !important;
    }
    }



/*=================================================
    お問い合せ
=================================================*/
/****************
contact1
*****************/
@media screen and (min-width: 1025px) {
    .container.container-contact1 {
        padding-bottom: 113px;
    }
}

.contact1 {
    background-color: #F9F7F5;
}

.sec-text-sub--contact1 {
    margin-bottom: 50px;
}

.contact1-flex {
    justify-content: space-between;
    margin-top: 45px;
}

.contact1L {
    width: 48.7%;
    border: 1px solid #555555;
    padding-top: 35px;
    padding-bottom: 37px;
    padding-left: 73px;
    padding-right: 73px;
    background-color: #ffffff;
}

.contact1R {
    width: 48.7%;
    border: 1px solid #555555;
    padding-top: 35px;
    padding-bottom: 37px;
    padding-left: 42px;
    padding-right: 42px;
    background-color: #ffffff;
}

.contact1-tit {
    margin-bottom: 5px;
    color: #000000;
    text-align: center;
}

.contact1-lead {
    color: #000000;
    margin-bottom: 15px;
    text-align: center;
}

.contact1-number-wrap {
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
}

.contact1-icon {
    width: 49px;
    margin-right: 15px;
}

.contact1L .contact1-icon {
    width: 31px;
    margin-right: 8px;
}

.contact1-number {
    color: #3A3A3A;
}

.contact1-time {
    padding-left: 20px;
    padding-right: 20px;
    min-width: 250px;
    max-width: 300px;
    height: auto;
    min-height: 30px;
    border-radius: 21px;
    background-color: #B8AD8B;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.03em;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 15px;
}

.contact1-time.flex {
    flex-wrap: nowrap;
}

.contact1-time.flex span:first-child {
    width: 78px;
    flex-shrink: 0;
}

.contact1-time.flex span:last-child {
    line-height: 1.2;
    padding-top: 5px;
    padding-bottom: 5px;
}

@media screen and (max-width: 1400px) {
    .contact1L,
    .contact1R {
        padding: 30px 20px;
    }
}

@media screen and (max-width: 767px) {
    .contact1L {
        width: 100%;
        margin-bottom: 30px;
    }

    .contact1R {
        width: 100%;
    }

    .contact1-time {
        padding-left: 15px;
        padding-right: 15px;
    }
}

@media screen and (max-width: 600px) {
    .contact1L, .contact1R {
        padding: 30px 10px;
    }
}

/****************
contact2
*****************/
@media screen and (min-width: 1025px) {
    .container.container-contact2 {
        padding-bottom: 94px;
    }
}

.contact2 {
    background-color: #F2F0EC;
}

.contact-tit {
    color: #000000;
    text-align: center;
    margin-bottom: 3px;
}

.contact-tit-lead {
    color: #000000;
    text-align: center;
    margin-bottom: 45px;
}

.contact-notice {
    max-width: 958px;
    margin: 0 auto 45px;
}

/* form */
.form-wrap {
    border-top: 1px solid #555555;
    padding: 16px 0 16px 20px;
    align-items: center;
}

.form-wrap.last {
    border-bottom: 1px solid #555555;
}

.form-wrapL {
    width: 234px;
    flex-shrink: 0;
    color: #333333 !important;
}

.form-wrapR {
    width: calc(100% - 234px);
}

input[type=date],
input[type=email],
input[type=number],
input[type=password],
input[type=search],
input[type=tel],
input[type=text],
input[type=url],
select,
textarea {
    border-radius: 25px !important;
    border: none !important;
}

input[type=tel],
input[type=text],
input[type=email] {
    padding: 5px 25px !important;
    height: 35px !important;
}

.iphone input[type=tel],
.iphone input[type=text],
.iphone input[type=email] {
    padding: 5px 25px 12px!important;
}



textarea {
    padding: 8px 25px !important;
}

::placeholder {
    color: #666666;
    font-weight: 300;
    font-family:'メイリオ','Meiryo UI','游ゴシック体', 'Yu Gothic', YuGothic,sans-serif;
    -webkit-appearance: none;
}



.wpcf7-acceptance .wpcf7-list-item {
    display: flex;
}

.form-acceptance {
    padding-top: 40px;
    padding-bottom: 40px;
    padding-right: 10px;
    margin-bottom: 36px;
    border-bottom: 1px dotted #95989A;
}

.form-acceptance p {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
}

.your-ok {
    width: 25px;
    height: 25px;
    margin-right: 7px;
}

.form-acceptance .form-text {
    padding-left: 1em;
    text-indent: -1em;
}

.form-btn-wrap {
    width: 250px;
    margin: 0 auto;
}

.form-btn-wrap .btn-maru {
    width: 300px;
}

input[type=submit] {
    border: 1px solid #AAD2C3;
    border-radius: 25px;
    color: #FFFFFF;
    background-color: #B1DBCB;
    font-size: clamp(1.25rem, 1.2rem + 0.25vw, 1.5rem);
    width: 100%;
    height: 50px;
    line-height: 50px;
    padding: 0 1rem !important;
    z-index: 1;
    font-family:'メイリオ','Meiryo UI','游ゴシック体', 'Yu Gothic', YuGothic,sans-serif;
}

[type=submit]:hover,
[type=submit]:focus {
    background-color: #B1DBCB !important;
    opacity: 0.6;
    color: #FFFFFF;
}

.wpcf7-spinner {
    display: none;
}

@media screen and (max-width: 1024px) {
    .form-btn-wrap {
        width: 230px;
    }
}

@media screen and (max-width: 767px) {
    .form-wrap {
        padding: 12px 10px;
    }

    .form-wrapL {
        width: 100%;
        margin-bottom: 10px;
    }

    .form-wrapR {
        width: 100%;
    }
}

@media screen and (max-width: 500px) {
    .form-wrap {
        padding: 10px 0;
    }

    .wpcf7-acceptance .wpcf7-list-item {
        margin-left: 0;
    }
}





/****************
contact3
*****************/
@media screen and (min-width: 1025px) {
    .container.container-contact3 {
        padding-bottom: 70px;
    }
}

.contact3 {
    /* background-color: #F9F7F5; */
    background-color: #F2F0EC;

}

.container-contact3 {
    position: relative;
    z-index: 1;
}

/* .page-bottom-bg--contact {
    position: absolute;
    bottom: 0;
} */

/****************
privacy-policy
*****************/
.privacy-policy p,
.privacy-policy a {
    color: #555555;
}

.privacy-policy-content {
    margin-top: 50px;
}

.privacy-policy-wrap {
    margin-bottom: 30px;
}

.privacy-policy-wrap .pp__text:first-child {
    margin-bottom: 1em;
}

.pp__text.day {
    text-align: right;
}

/* .pp__text--indent {
    padding-left: 1em;
} */

.pp__text--indent-mark {
    padding-left: 3em;
    text-indent: -2.5em;
}

.pp__text--mark {
    padding-left: 1em;
    text-indent: -1em;
}

.pp__text--mark a {
    color: #555555;
}

.pp__text--mark a:hover {
    color: #555555;
    opacity: 0.7;
}

/* .pp-google {
    padding-left: 1em;
} */

.pp-google__lead {
    width: 270px;
    display: inline-block;
}

/* .pp-google__br {
    display: none;
} */

.pp-google__link {
    color: #3B4043;
    word-break: break-all;
    display: block;
    padding-left: 1em;
}

.pp-google__link:hover {
    color: #3B4043;
    opacity: 0.7;
}

/* @media screen and (max-width: 1024px) {
    .pp-google__br {
        display: block;
    }
    
    .pp-google__link {
        display: block;
        padding-left: 1em;
    }
}
 */


/*=================================================
    アクセス　access
=================================================*/
/* access */
.subheader-access .subheader-img img {
    object-position: 50%;
}

.access-bg {
    background-color: #F9F7F5;
}

.access-zip {
    font-weight: 300;
    font-size: 14px;
    padding-left: 2.5em;
}

.access-address {
    font-weight: 300;
    font-size: 16px;
    padding-left: 0.5em;
}

.access-main {
    margin: 15px 0 50px;
}

.access-item {
    padding: 25px 0;
    align-items: center;
}

.access-item:not(:last-child) {
    border-bottom: 1px solid rgba(112,112,112,0.5);
}

.accessL {
    align-items: center;
    width: 310px;
    opacity: 0;
    transform: translateY(30px);
    transition: 0.8s;
}

.access-title {
    font-size: 22px;
    font-weight: 700;
    padding-left: 15px;
}

.accessR {
    width: calc(100% - 310px);
    font-size: 16px;
    line-height: 2.2;
    padding: 0 5%;
    opacity: 0;
    transform: translateY(30px);
    transition: 0.8s;
}

.access-bus-list {
    padding-left: 1em;
    position: relative;
}

.access-bus-list::before {
    content: "・";
    position: absolute;
    left: 0;
}

.access-item.on .accessL,
.access-item.on .accessR {
    opacity: 1;
    transform: translateY(0);
}

.map-inner {
    position: relative;
    padding-top: 54%;
}

.map-inner iframe {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
}

@media screen and (max-width: 1024px) {
    .accessL {
        width: 170px;
        justify-content: center;
    }
    
    .access-title  {
        padding: 10px 0 0;
        font-size: 20px;
    }
    
    .accessR {
        width: calc(100% - 170px);
        padding: 0 3%;
    }
}

@media screen and (max-width: 767px) {
    .accessL {
        width: 100%;
    }
    
    .access-title {
        padding: 0 0 0 10px;
    }
    
    .accessR {
        width: 100%;
        padding: 20px 0 0;
        line-height: 1.5;
    }
    
    .map-inner {
        padding-top: 300px;
    }
}

@media screen and (min-width: 481px) {
    .access .sec-text .br480 {
        display: none;
    }
}

@media screen and (max-width: 480px) {
    .access-zip {
        padding: 0;
    }
}

/* Q&A */
.qa-bg {
    background-color: #F2F0EC;
}

.qa-item {
    border-bottom: 1px solid rgba(112,112,112,0.5);
    transition: 0.2s;
    background-color: transparent;
}

.qa-item:first-child {
    border-top: 1px solid rgba(112,112,112,0.5);
}



.qa-q {
    align-items: center;
    cursor: pointer;
    padding: 25px 0;
}

.qa-title {
    width: calc(100% - 50px);
    position: relative;
    transition: 0.2s;
    left: 0;
}

.qa-icon {
    position: relative;
    width: 50px;
    transition: 0.2s;
    left: 0;
}

.qa-icon img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: 0.3s;
}

.qa-item.open {
    background-color: rgba(177,219,203,0.5);
}

.qa-icon.open .qa-open {
    opacity: 0;
}

.qa-a {
    line-height: 2.2;
    padding: 0 65px 20px;
    display: none;
}

.qa-item:hover {
    background-color: rgba(177,219,203,0.5);
}

.qa-item:hover .qa-title,
.qa-item:hover .qa-icon {
    left: 8px;
}

@media screen and (max-width: 1024px) {
    .qa-a {
        padding: 0 30px 20px;
    }
}

@media screen and (max-width: 767px) {
    .qa-q {
        padding: 15px 0;
    }
    
    .qa-a {
        padding: 0 15px 15px;
        line-height: 1.5;
    }
}

/*=================================================
    スタッフ募集　recruit
=================================================*/
.recruit-bg {
    background-color: #F9F7F5;
    min-height: 600px;
}

@media screen and (max-width: 767px) {
    .recruit-bg {
        min-height: 350px;
    }
}


/*=================================================
    新着情報　news
=================================================*/
/*=================================================
  新着情報
=================================================*/
/****************
news-body
*****************/
.news-top-bg {
    background-color: #F9F7F5;
    padding-bottom: 55px;
}

.news-wrapper-bg {
    background-color: #F2F0EC;
    padding-bottom: 40px;
}

.news-wrapper {
    padding-top: 65px;
    justify-content: space-between;
}

.news-main {
    width: 78.8%;
}

.news-body .sec-tit-wrap {
    padding-top: 80px;
    padding-bottom: 45px;
}


.news-item {
    max-width: 907px;
    width: 100%;
    display: flex;
    padding-bottom: 30px;
    align-items: flex-start;
}

.news-item:last-child {
    padding-bottom: 0;
}

.news-item:hover .news-itemL img {
    transform: scale(1.1);
}

.news-itemL img {
    transition: .5s ease;
}

.news-itemL {
    width: 40.5%;
    margin-right: 45px;
    border-radius: 20px;
    overflow: hidden;
}

.news-itemR {
width: calc(100% - (40.5% + 35px));
}

.news-date-cat {
margin-bottom: 15px;
}

.news-title {
margin-bottom: 15px;
}

.news-content {
font-size: 16px;
line-height: 1.875;
font-weight: 300;
}

@media screen and (max-width: 1024px) {
    .news-body .sec-tit-wrap {
        padding-top: 60px;
    }
    
.news-main {
    width: 100%;
}

.news-item {
    padding-top: 20px;
    padding-bottom: 20px;
}

.news-itemL {
    width: 250px;
}

.news-itemR {
    width: calc(100% - 310px);
}

}

@media screen and (max-width: 767px) {
.news-itemL {
    width: 200px;
    margin-right: 30px;
}

.news-itemR {
    width: calc(100% - 230px);
}
}

@media screen and (max-width: 600px) {
.news-item {
    flex-wrap: wrap;
    justify-content: center;
}

.news-itemL {
    width: 100%;
    max-width: 300px;
    margin: 0 auto 20px;
}

.news-itemR {
    width: 100%;
    padding-left: 15px;
    padding-right: 15px;
}

}


/****************
sidebar
*****************/

.sidebar {
    margin-bottom: 80px;
    }
    
    .news-sidebar {
        width: 157px;
        flex-shrink: 0;
    }
    
    .widgettitle {
        font-size: clamp(1rem, 0.975rem + 0.125vw, 1.125rem);
        padding-left: 14px;
        border-bottom: 0.5px solid #707070;
        padding-bottom: 8px;
        margin-bottom: 30px;
        color: #555555;
    }
    
    .sidebar li {
        text-decoration: none;
        list-style: none;
        font-size: clamp(1rem, 0.975rem + 0.125vw, 1.125rem);
        margin-bottom: 35px;
        padding-left: 17px;
    }
    
    .sidebar li a {
        display: block;
        position: relative;
        color: #555555;
        transform: translateX(-20px);
        transition: 0.6s;
    }
    
    .sidebar li a:hover {
        color: #333333;
        transform: translateX(0);
        opacity: 1;
    }
    
    .sidebar li a::before {
        content: ">";
        display: inline-block;
        margin-right: 3px;
        opacity: 0;
        transition: 0.6s;
    }

    .sidebar li a:hover::before {
        opacity: 1;
    }
    
    .sidebar ul {
        padding-left: 0 !important;
    }
    
    @media screen and (max-width: 1024px) {
    .news-sidebar {
        width: 100%;
        order: 2;
        display: flex;
        flex-wrap: wrap;
    }
    
    .news-sidebar .sidebar {
        margin-bottom: 0;
        margin-top: 30px;
        width: 50%;
        max-width: 157px;
    }
    
    .news-sidebar .sidebar:first-child {
        margin-right: 30px;
    }
    
    .sidebar li {
        margin-bottom: 15px;
    }
    
    .sidebar li a {
        display: inline-block;
    }
    }

/****************
pagination
*****************/
.pagination {
    text-align: center;
    width: 100%;
    margin: 80px auto 0!important;
}

.page-numbers {
    width: 40px;
    height: 40px;
    font-size: clamp(1rem, 0.95rem + 0.25vw, 1.25rem);
    line-height: 38px;
    color: #AAD2C3;
    border-radius: 100%;
    transition: .5s;
    display: inline-block;
    margin-right: 5px;
    margin-left: 5px;
    border: 1px solid #AAD2C3;
    overflow: hidden;
    position: relative;
    background-color: #ffffff;
}

.current {
    background-color: #B1DBCB;
    border: 1px solid #B1DBCB;
    color: #fff;
}

.page-numbers:hover {
    background-color: #B1DBCB;
    border: 1px solid #B1DBCB;
    color: #fff;
}

.prev.page-numbers,
.next.page-numbers {
    display: none;
}

@media screen and (max-width: 1024px) {
.pagination {
    order: 1;
    margin: 60px auto 30px!important;
}
}

/****************
single
*****************/
.single .news-item {
flex-direction: column;
justify-content: flex-start;
padding-bottom: 0;
}

.single .news-item:last-child {
border-bottom: none;
}

.single .news-title {
line-height: 1.625;
margin-bottom: 30px;
}

.single .news-content p {
margin-bottom: 1em;
}

.single .news-content p:last-child {
margin-bottom: 0;
}

.single-img {
margin-bottom: 40px;
}

.btn-wrap-news {
    margin-top: 70px;
    width: 100%;
}

.btn-news {
    width: 250px;
    font-size: clamp(1rem, 0.95rem + 0.25vw, 1.25rem);
}



@media screen and (max-width: 1024px) {
.single .news-item {
    margin-bottom: 40px;
}

}

@media screen and (max-width: 767px) {
.single .news-item {
    padding-bottom: 60px;
}

.single .news-item {
    max-width: 700px;
}

}




/****************
404
*****************/
.notfound-body {
    padding: 120px 0;
}

.news-header .page-title {
    padding-bottom: 30px;
    letter-spacing: 0.2em;
    text-align: center;
    font-size: 30px;
    font-weight: 600;
    font-family: "Noto sans JP", serif !important;
    color: #555555;
}

.text404 p {
    width: 90%;
    margin: 0 auto;
    text-align: center;
    font-size: 26px;
    font-family: "Noto sans JP", serif !important;
    color: #555555;
}

@media screen and (max-width: 1024px) {
    .news-header .page-title {
        font-size: 26px;
    }
    
    .text404 p {
        font-size: 22px;
    }
}

@media screen and (max-width: 767px) {
    .notfound-body {
        padding: 60px 0;
    }
    
    .news-header .page-title {
        font-size: 22px;
    }
    
    .text404 p {
        font-size: 18px;
    }
}


/****************
loading
*****************/
.loading {
    position: fixed;
    width: 100%;
    height: 100dvh;
    left: 0;
    top: 0;
    background-color: white;
    justify-content: center;
    align-items: center;
    z-index: 99999;
}
/***************************************************
 * Generated by SVG Artista on 1/27/2023, 9:58:37 AM
 * MIT license (https://opensource.org/licenses/MIT)
 * W. https://svgartista.net
 **************************************************/

svg .svg-elem-1 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.8s;
}

svg.active .svg-elem-1 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-2 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 0.9s;
}

svg.active .svg-elem-2 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-3 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1s;
}

svg.active .svg-elem-3 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-4 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.1s;
}

svg.active .svg-elem-4 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-5 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.2000000000000002s;
}

svg.active .svg-elem-5 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-6 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.3s;
}

svg.active .svg-elem-6 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-7 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.4000000000000001s;
}

svg.active .svg-elem-7 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-8 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.5s;
}

svg.active .svg-elem-8 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-9 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.6s;
}

svg.active .svg-elem-9 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-10 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.7000000000000002s;
}

svg.active .svg-elem-10 {
  fill: rgb(170, 220, 200);
}

svg .svg-elem-11 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.8s;
}

svg.active .svg-elem-11 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-12 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 1.9000000000000001s;
}

svg.active .svg-elem-12 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-13 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2s;
}

svg.active .svg-elem-13 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-14 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.1s;
}

svg.active .svg-elem-14 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-15 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.2s;
}

svg.active .svg-elem-15 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-16 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.3s;
}

svg.active .svg-elem-16 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-17 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.4000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.4000000000000004s;
}

svg.active .svg-elem-17 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-18 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.5s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.5s;
}

svg.active .svg-elem-18 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-19 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.6s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.6s;
}

svg.active .svg-elem-19 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-20 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.7s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.7s;
}

svg.active .svg-elem-20 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-21 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.8s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.8s;
}

svg.active .svg-elem-21 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-22 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.9000000000000004s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 2.9000000000000004s;
}

svg.active .svg-elem-22 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-23 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3s;
}

svg.active .svg-elem-23 {
  fill: rgb(108, 79, 63);
}

svg .svg-elem-24 {
  fill: transparent;
  -webkit-transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.1000000000000005s;
          transition: fill 0.7s cubic-bezier(0.47, 0, 0.745, 0.715) 3.1000000000000005s;
}

svg.active .svg-elem-24 {
  fill: rgb(108, 79, 63);
}

@media screen and (max-width: 1024px) {
    .loading svg {
        width: 150px;
        height: 150px;
    }
}


/*=================================================
    アニメーション
=================================================*/
/****************
fadein-up
*****************/
.fadein-up {
    opacity: 0;
    transform: translateY(30px);
    transform: translate3d(0.1deg);
    transition: 1.2s ease;
    will-change:transform;
}

@media screen and (min-width: 768px) {
    .fadein-up-delay {
        transition-delay: 0.3s;
    }
    .fadein-up-delay2 {
        transition-delay: 0.7s;
    }
}

@media screen and (max-width: 767px) {
    .fadein-up-delay3 {
        transition-delay: 0.3s;
    }
}

.fadein-up.on {
    opacity: 1;
    transform: translateY(0px);
}

/*20250203*/
.news-content{
font-weight:400 !important;
}
.news-content ol li{
list-style: decimal !important;
}
.news-content ol{
padding-inline-start:20px !important;
}