@charset "utf-8";

/*
Theme Name: towayakuhin-child Template
Template: towayakuhin
Author: towayakuhin-child テンプレート
Author URI: 
Description: 親テーマ "towayakuhin" の子テーマ
Version: 0.2
Author: 
*/



/*------------------------------------------------------------------------

◆目次

------------------------------------------------------------------------*/



/*------------------------------------------------------------------------
◆要素
------------------------------------------------------------------------*/
html, body{
	overflow-x: hidden;
    width: 100vw;
}

body *{
    font-weight: 500;
}

/*------------------------------------------------------------------------
◆共通（テーマカスタマイズ適用候補）
------------------------------------------------------------------------*/
iframe{ /* youtubeのベース横幅 */
	width: 100%;
}

table{
    font-size: 100%;
}

#main_wrap h2:not(.home #main_wrap h2){
    font-size: 144%;
    border-bottom: 2px solid #CCC;
    padding-bottom: 8px;
}

#main_wrap h2:not(.home #main_wrap h2):before {
    content: url(images/common/h2_catch.png);
    margin-right: 8px;
    padding: 4px 0;
    position: relative;
    top: -1px;
}

#main_wrap h2:not(.home #main_wrap h2):after {
    width: 24%;
    bottom: -2px;
    border-bottom-width: 2px !important;
}

#main_wrap h3:not(.home #main_wrap h3){
	font-size: 120%;
 /*   background: #f4f4f4;*/
	background: #eef4f6;
    border-radius: 4px;
    padding: 8px 16px;

}

#main_wrap h4 {
    font-size: 112%;
    line-height: 140%;
    margin-top: 0.81em;
    margin-bottom: 0.81em;
    /* margin: 0.8em; */
    font-weight: bold;
    color: #333 !important;
    background: #eff5f7 !important;
    padding: 5px 0 5px 8px !important;
}


.wp-block-button__link {
    background-color: #48a3a3;
}

body figure.wp-block-table,
body figure.wp-block-flexible-table-block-table{
    margin-bottom: 1.618em;
}

body #contents_wrap figure.wp-block-table table,
body #contents_wrap figure.wp-block-flexible-table-block-table table{
    margin-bottom: 0;
}

figure.wp-block-table table:not(table thead) tr > td:first-of-type{
    width: 24%;
	background: #f4f4f4;
}

#main_wrap .size-thumbnail.aligncenter,
#main_wrap .size-medium.aligncenter,
#main_wrap .size-full.aligncenter {
    text-align: center;
}

#main_wrap input[type="submit"].wpcf7-submit{
    padding: 12px;
    min-width: 240px;
    border-radius: 56px;
}

#main_wrap ul.arrow li{ /* リストに自動で▲ 1/2 */
	padding-left: 16px;
	position: relative;
}

#main_wrap ul.arrow li:before { /* リストに自動で▲ 2/2 */
    font-family: "fontello";
    content: '\e828';
    width: auto;
    font-size: 72%;
	color: #48a3a3;
    position: absolute;
	top: 0.4em;
    left: 0.4em;
}

body figure.wp-block-table thead th { /* テーブルヘッダー */
    background: #48a3a3;
}

body figure.wp-block-table tfoot { /* テーブルフッター */
    border-top: 2px solid #48a3a3;
}

#header_container.header_right_nav.header_fix,
body.nav_active #header_container.header_right_nav.header_fix{ /* ホーム以外はヘッダーを追従させない */
	/*position: static !important;*/
}

body.page #main_wrap:not(.page-template-page-no-sidebar #main_wrap, .page-template-page-no-sidebar-bottom #main_wrap){ /* 左側にサイドナビ 1/3 */
    float: right;
}

body.page #sub_wrap:not(.page-template-page-no-sidebar #sub_wrap, .page-template-page-no-sidebar-bottom #sub_wrap){ /* 左側にサイドナビ 2/3 */
    float: left;
}

body.page #contents_wrap:not(body.home #contents_wrap, .page-template-page-no-sidebar #contents_wrap, .page-template-page-no-sidebar-bottom #contents_wrap){ /* 左側にサイドナビ 3/3 ホーム以外のページメインイメージとサイドナビの幅 */
    padding: 40px 0;
}

#mainimage .section_wrap { /* ページメインイメージ中央寄せ */
    justify-content: center;
    min-height: 250px;
}

ul#contents_bottom_menu { /* ページ下部ナビの非表示 */
    background-color: #f4f4f4;
    display: none;
}

#sidenav li a:before { /* サイドナビ▲調整 */
    top: 1em;
}

#sidenav_wrap h2#sidenav_parent a { /* サイドナビ　親ページ背景色 */
    background-color: #48a3a3 !important;
}

#sidenav li.current_page_item > a { /* サイドナビ　子ページ現在地　背景色 */
    background-color: #ecf4f8 !important;
    color: #333 !important;
}

body #main_wrap h2:after {
    border-bottom: 1px solid #48a3a3;
}

body #main_wrap ul.term li.category a {
    background-color: #48a3a3;
}

.wp-block-details { /* 要約 1/2 */
    background: #f4f4f4;
}

.wp-block-details summary { /* 要約 2/2 */
    font-weight: bold;
}

@media screen and (min-width: 521px) and (max-width: 960px){

	#main_wrap h2:not(.home #main_wrap h2):before {
	    top: 0px;
	}
}

@media screen and (min-width: 521px) and (max-width: 600px){

	.wp-block-media-text .wp-block-media-text__content { /* メディアとテキスト */
	    padding: 12px 0;
	}
}

@media screen and (max-width: 520px) {

	div#contents_container{
		overflow: hidden;
	}

	.wp-block-media-text .wp-block-media-text__content { /* メディアとテキスト */
	    padding: 12px 0;
	}

	#main_wrap h2:not(.home #main_wrap h2) {
	    font-size: 132%;
	}

	#main_wrap h2:not(.home #main_wrap h2):before {
	    top: 1px;
	}

	#main_wrap h3:not(.home #main_wrap h3) {
	    font-size: 116%;
	}

}


/*------------------------------------------------------------------------
◆faq
------------------------------------------------------------------------*/
.schema-faq-section {
    margin-bottom: 24px;
    padding: 24px;
    padding-right: 64px;
    padding-left: 64px;
    border-radius: 8px;
    background: #f4f4f4;
    font-size: 120%;
    position: relative;
}

.schema-faq-section::before,
.schema-faq-section::after {
    content: "";
    position: absolute;
	top: 36px;
    left: auto;
    right: 36px;
    width: 1px;
    height: 16px;
    background: #2c61b1;
    border: none;
}

.schema-faq-section::before{
    transform: translate(-50%,-50%) rotate(90deg);
	transition: all 300ms;
}

.schema-faq-section::after{
    transform: translate(-50%,-50%) rotate(0deg);
    top: 36px;
}

.schema-faq-section .schema-faq-question {
    display: block;
    font-weight: bold;
    cursor: pointer;
}

.schema-faq-section .schema-faq-question:hover{
    color: #00a0e9;
}

.schema-faq-section .schema-faq-question::marker {
	content: "";
}

.schema-faq-section .schema-faq-question::before {
    content: "Q";
    display: inline-block;
    background: #48a3a3;
    padding: 4px;
    width: 24px;
    height: 24px;
    margin-right: 4px;
    border-radius: 40px;
    color: #fff;
    text-align: center;
    font-size: 100%;
    line-height: 1;
    position: absolute;
    top: 24px;
    left: 24px;
}

.schema-faq-section .schema-faq-answer {
	display: none;
    font-weight: bold;
    font-size: 88%;
    cursor: pointer;
    position: relative;
}

.schema-faq-section .schema-faq-answer::before {
    content: "A";
    display: inline-block;
    background: #6ab429;
    padding: 4px;
    width: 24px;
    height: 24px;
    margin-right: 4px;
    border-radius: 48px;
    color: #fff;
    text-align: center;
    font-size: 120%;
    line-height: 1;
    position: absolute;
    top: 0px;
    left: -40px;
}

.schema-faq-section.open:before{
    transform: translate(-50%,-50%) rotate(0deg);
}

.schema-faq-section.open:after{
	display: none;
}

.schema-faq-section.open .schema-faq-question {
    color: #00a0e9;
    margin-bottom: 40px;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
}

.schema-faq-section.open .schema-faq-answer {
	display: block;
    margin-bottom: 0 !important;
    animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}


/*------------------------------------------------------------------------
◆wordpress調整
------------------------------------------------------------------------*/
figure.wp-block-table thead th{
	background: #333;
	color: #fff;
}

.wp-block-file:not(.wp-element-button) {
    font-size: 1em;
}

#main_wrap .wp-block-media-text.is-image-fill .wp-block-media-text__media img{ /* レイアウト崩れの直し */
	width: 1px;
}

.wp-block-image .aligncenter>figcaption, .wp-block-image .alignleft>figcaption, .wp-block-image .alignright>figcaption, .wp-block-image.aligncenter>figcaption, .wp-block-image.alignleft>figcaption, .wp-block-image.alignright>figcaption{
    display: block;
}

/* テーブル
--------------------------------------------------------------------------*/
figure.wp-block-table{
	width: 100%;
	font-size: 100%;
	line-height: 160%;
	margin: 0 auto;
}

figure.wp-block-table thead {
    border-bottom: none;
}

figure.wp-block-table tfoot {
    border-top: 2px solid #333;
}

figure.wp-block-table th,
figure.wp-block-table td{
	border: 1px solid #E6E6E6;
	padding: 16px;
}

figure.wp-block-table thead th{
	background: #333;
	color: #fff;
	font-weight: bold;
}

figure.wp-block-table td{
	text-align: left;
	background: #FFFFFF;
}

figure.wp-block-table tbody th{
	text-align: left;
	background: #f4f4f4;
	color: #333333;
	font-weight: bold;
	width: 24%;
}

figure.wp-block-table td *{
	margin-bottom: 0em !important;
}

figure.wp-block-table td ul.catch{
	margin-bottom: 0em !important;
}

figure.wp-block-table td ul.catch li{
	margin-bottom: 0.4em !important;
}

figure.wp-block-table td ul.catch li:last-of-type{
	margin-bottom: 0em !important;
}

figure.wp-block-table td ul.catch br{
	display: none !important;
}

figure.wp-block-table td *:last-of-type{
	margin-bottom: 0 !important;
}

figure.wp-block-table tfoot td {
    background: #fff;
}


/* ファイルダウンロード
--------------------------------------------------------------------------*/
#content .wp-block-file {
    margin: 0;
    padding: 20px 20px 16px;
    background-color: #fcfaf7;
}

#content .wp-block-file + .wp-block-file{
    padding-top: 0;
}

#content .wp-block-file a.wp-block-file__button.wp-element-button{
	display: none;
}

#content .wp-block-file a::before{
    content: "";
    background: url(images/common/catch_blue.png) no-repeat center center;
    background-size: contain;
    display: inline-block;
    width: 9px;
    height: 9px;
    margin-right: 8px;
    vertical-align: middle;
    position: relative;
    top: -2px;
}

/* アイコンを表示する基本設定 */
#content .wp-block-file a::after{
    content: "";
    display: none;
    width: 16px;
    height: 16px;
    margin-left: 4px;
    vertical-align: middle;
    position: relative;
    top: -2px;
}

#content .wp-block-file a[href$=".pdf"]::after {
    display: inline-block;
    background: url(images/common/icon_pdf.svg) no-repeat center center;
    background-size: contain;
    top: -2px;
}

#content .wp-block-file a[href$=".word"]::after {
    display: inline-block;
    background: url(images/common/icon_word.svg) no-repeat center center;
    background-size: contain;
    top: -2px;
}

#content .wp-block-file a[href$=".excel"]::after {
    display: inline-block;
    background: url(images/common/icon_excel.svg) no-repeat center center;
    background-size: contain;
    top: -2px;
}



/*------------------------------------------------------------------------
◆テンプレート
------------------------------------------------------------------------*/
/* 1カラム　サイド&コンテンツ下部非表示 */
body.page-template-page-one-column-no-sidebar-bottom #contents_wrap{
	max-width: 100%;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap{
	float: none;
	width: 100%;
	font-size: 120%;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > *{
	max-width: 1200px;
    margin: 0 auto;
	padding: 40px 0;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2{
	font-size: 240% !important;
	color: #48a3a3;
	border-bottom: none !important;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2::before,
body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2::after{
	display: none;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap h3{
    background: none !important;
    border-bottom: 1px solid #48a3a3 !important;
    padding: 12px 0 !important;
    border-radius: 0 !important;
}

body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > section#contact_container{
	max-width: 100%;
	padding: 40px 0;
/*	background: #d4f2f2;*/
}

/*------------------------------------------------------------------------
◆ヘッダー
------------------------------------------------------------------------*/
body #header_container.header_right_nav {
    background-color: #fff;
}

body.home #header_container{
    position: absolute;
    background: none;
}

body #header_wrap{
    max-width: 100%;
    padding: 0 0 0 4%;
}

body.home #header_wrap{
    padding: 0 0 0 4%;
}

#header_wrap h1 {
    position: relative;
    z-index: 101;
}

body.home #header_wrap h1 {
    top: 32px;
}

#header_wrap h1 img {
    height: 56px;
}


/*------------------------------------------------------------------------
◆フッター
------------------------------------------------------------------------*/
body #footer_container_top {
    padding: 0;
    background: #f1f7fa;
    border-top: none;
}

body #footer_wrap_top {
    padding: 0;
    font-size: 100%;
}

body #footer_wrap_top * {
    text-align: left;
}

body #footer_middle_menu{
	display: flex;
	gap: 32px;
}

#fnav_left > li > a, #fnav_center_left > li > a, #fnav_center > li > a, #fnav_center_right > li > a, #fnav_right > li > a {
    font-weight: bold;
}

div#fnav_right_container ul li{
	margin: 0 0 12px;
}

body #footer_middle_menu .sub-menu *{
    font-size: 92%;
}

body #footer_middle_menu .sub-menu li::before {
    content: "";
    display: block;
    position: absolute;
    border-right: 1px solid #333;
    border-top: 1px solid #333;
    width: 4px;
    height: 4px;
    left: 0;
    top: calc(1em - 4px);
    margin-top: 0;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
}

ul.fnav ul.sub-menu li {
    padding-left: 12px;
    position: relative;
}




body #footer_container_middle #footer_wrap_middle {
    display: flex;
    gap: 24px;
    max-width: 1200px;
	margin: 0 auto;
    padding: 64px 0 0;
    font-size: 88%;
}

body #footer_container_middle #footer_wrap_middle * {
    color: #333;
}

#footer_container_middle p.footer_text {
    margin-top: 16px;
}

#footer_container_middle p.footer_text br{
	display: none;
}

body #footer_middle_info{
	width: 50%;
    margin: 0;
}

#footer_middle_info ul{
    margin-top: 24px;
}

#footer_middle_info ul li {
    display: inline;
}

#footer_middle_info ul li.footer_company_zip,
#footer_middle_info ul li.footer_company_tel{
	margin-right: 1em;
}

#footer_middle_info ul li.footer_company_address1,
#footer_middle_info ul li.footer_company_address2{
	margin-right: auto;
}

#footer_middle_info ul li.footer_company_address1::after {
    content: "";
    display: block;
}

#menu_button_wrap {
    width: 50%;
}

#menu_button_wrap .button_wrap{
    text-align: right;
}

#menu_button_wrap .button_wrap a{
    display: inline-block;
    width: 276px;
    padding: 12px;
    background: #48a3a3;
    border-radius: 9999px;
    text-decoration: none;
    font-size: 120%;
    text-align: center;
    color: #fff !important;
}


#footer_middle_menu .fnav_container {
    padding-right: 0;
}

#fnav li:before {
    content: "";
    margin-right: 0px;
    margin-left: 24px;
}

#footer_middle_info {
    margin: 24px 0 48px;
}

#footer_middle_menu {
	width: 100% !important;
    max-width: 1200px;
    margin: 0 auto;
    float: none;
}

#footer_container_middle #fnav_container{
	margin-top: 40px;
}

#footer_container_middle #fnav_container a{
	font-size: 120%;
    font-weight: 400;
}

#footer_middle_menu_copyright {
    width: 50%;
    margin: 24px 0 48px;
    margin-top: 58px;
    float: right;
    text-align: right;
    color: #fff;
}

#footer_container_bottom{
    font-size: 88%;
}

#footer_container_bottom #footer_wrap_copyright {
    display: block;
    margin: 16px 0 16px auto;
    color: #000000;
    font-weight: 400;
}

#footer_wrap_bottom {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 0 0 24px;
    border-top: none;
}

#footer_container_bottom.menu_in #fnav_btm_container{
	float: none;
}

#footer_container_bottom.menu_in #footer_wrap_copyright {
    float: none;
    text-align: center;
}

/*------------------------------------------------------------------------
◆メインイメージ
------------------------------------------------------------------------*/
#keyvisual_container {
    aspect-ratio: 5 / 3;
    position: relative;
    overflow: hidden;
}

.keyvisual_wrap.slider_back,
.slider_back_wrap .slick-slide img {
    height: 100%;
    object-fit: cover;
    object-position: bottom;
    width: 100%;
}

#keyvisual_container .copy_wrap {
    position: relative;
}

#keyvisual_container .copy_wrap::before{
    content: "";
    display: block;
    background: #fff;
    width: 88vw;
    height: 88vw;
    border-radius: 50%;
    position: absolute;
    top: -22vw;
    left: -52vw;
    z-index: 1;
}

#keyvisual_container .copy_wrap ul{
    position: absolute;
    z-index: 2;
}

#keyvisual_container .copy_wrap li.maincopy{
    font-size: 276%;
    font-size: 2.28vw;
    font-weight: 600;
    color: #48a3a3;
    margin: 160px 0 0 160px;
}

#keyvisual_container .copy_wrap li.subcopy{
    font-size: 188%;
    font-size: 1.58vw;
    font-weight: 500;
    color: #999999;
    margin: 16px 0 0 160px;
}




#keyvisual_container .slides .wrap{
    display: flex;
    align-items: center;
    position: absolute;
    top: calc(23vw + 200px);
    left: 12vw;
}

#keyvisual_container .slick-dots {
    width: auto !important;
    text-align: left !important;
	position: relative;
    bottom: auto;
    top: -18px;
    z-index: 3;
}

#keyvisual_container button.slick-prev.slick-arrow,
#keyvisual_container button.slick-next.slick-arrow {
    display: block;
    width: 30px;
    height: 30px;
    border-radius: 50%;
	padding-top: 30px;
    background: #48a3a3;
	border: none;
	overflow: hidden;
	cursor: pointer;
    position: relative;
    top: auto;
    bottom: 0;
    left: auto;
    z-index: 2;
}



#keyvisual_container button.slick-prev.slick-arrow{
    left: -16px;
}

#keyvisual_container button.slick-next.slick-arrow {
    right: -16px;
}

#keyvisual_container button.slick-prev:hover,
#keyvisual_container button.slick-next:hover{
	opacity: 0.8;
}

#keyvisual_container button.slick-prev:before, #keyvisual_container button.slick-prev:after,
#keyvisual_container button.slick-next:before, #keyvisual_container button.slick-next:after{
    content: "";
    width: 10px;
    height: 2px;
    display: block;
    color: #fff;
    background: #fff;
    position: absolute;
	opacity: 1;
}

#keyvisual_container button.slick-prev:before{
	transform: translate(-7px , 22px) rotate(135deg);
	top: -11px;
	right: 3px;
}

#keyvisual_container button.slick-prev:after{
	transform: translate(7px , 22px) rotate(225deg);
	top: -5px;
	left: 3px;
}

#keyvisual_container button.slick-next:before{
	transform: translate(-7px , 22px) rotate(45deg);
	top: -11px;
	right: 3px;
}

#keyvisual_container button.slick-next:after{
	transform: translate(7px , 22px) rotate(135deg);
	top: -5px;
	left: 3px;
}

#keyvisual_container .slick-dots li {
    margin: 0 4px;
}

#keyvisual_container .slick-dots li button:before {
    font-size: 13px;
    color: #d4f2f2;
    opacity: 1;
}

#keyvisual_container .slick-dots li.slick-active button:before {
    color: #48a3a3;
    opacity: 1;
}


/*------------------------------------------------------------------------
◆グローバルナビ
------------------------------------------------------------------------*/
body #hnav_sub_container {
    height: 100%;
    max-height: 128px;
    top: 0;
    right: 4%;
}

body.home #hnav_sub_container {
	display: none;
}

body #hnav_sub_container ul#hnav_sub {
    display: flex;
    height: 100%;
	gap: 24px;
    align-items: end;
    border-left: none;
}

body #hnav_sub_container ul#hnav_sub > li {
    margin-left: 0px;
}

body #hnav_sub_container ul#hnav_sub > li a {
    display: block;
    padding: 24px 0;
    font-size: 100%;
    font-weight: 600;
}

body #hnav_sub_container ul#hnav_sub > li.current_page_item a::after,
body #hnav_sub_container ul#hnav_sub > li a:hover::after{
	content: "";
    display: block;
    width: 100%;
    height: 4px;
    background: #48a3a3;
    position: absolute;
    bottom: 0;
    left: 0;
}

body #hnav_sub_container ul#hnav_sub > li.contact{
    padding: 0;
    height: 100%;
}

body #hnav_sub_container ul#hnav_sub > li.contact a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
    background: #f4f4f4 !important;
    padding: 0 16px;
    font-size: 96%;
    text-align: center;
    line-height: 1.4;
}

body #hnav_sub_container ul#hnav_sub > li.contact a::before{
	content: "";
	background: url(images/common/icon_mail.png) no-repeat center top;
	display: block;
	width: 31px;
	height: 25px;
    margin: 12px auto;
}

body #gnav-switch {
    top: 8px;
    right: 32px;
	z-index: 100001;
}

body #gnav-switch.on{
    top: 0px;
    right: 32px;
}

body .menu-icon, .menu-icon span{
	border-radius: 8px;
	transition: none !important;
}

body #gnav-switch span.text {
    margin-top: -12px;
    font-size: 16px;
	color: #fff;
}

body #header_right.nav{
    display: none;
}

body.home #header_right.nav{
	display: block;
    height: 920px;
    width: 920px;
    top: 0;
    right: 0;
    overflow: hidden;
	pointer-events: none;
}

body.home #header_right.nav *{
	pointer-events: auto;
}

.burger #nav_wrap {
	gap: 40px;
	max-width: 100%;
    padding-right: 0px;
    position: relative !important;
	top: 0 !important;
}

.burger #nav_wrap > .gnav_container{
	width: 100%;
}

body #header_right #nav_container{
	background: none;
    margin: 0;
}

body.home #header_right #nav_container{
	content: "";
    height: 176px;
    width: 176px;
    border-radius: 50%;
    padding-top: 72px;
    background: #48a3a3;
    position: absolute;
    top: -56px;
    right: -32px;
    z-index: 100000;
	transition: all 300ms;
}

body.home.nav_active #header_right #nav_container{
	content: "";
    height: 920px;
    width: 920px;
    border-radius: 50%;
    top: -332px;
    right: -256px;
}

#header_right #nav_container.burger #nav_wrap{
	display: none;
	opacity: 0;
    width: 320px;
    margin: 0;
    top: 352px !important;
    left: 176px !important;
	transition: all 1200ms;
}

body.home.nav_active #header_right #nav_container.burger #nav_wrap{
	opacity: 1;
}

#header_right #nav_container.burger #nav_wrap ul li a {
	font-size: 100%;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li > a{ /* 親メニュー */
    padding: 20px 0;
    background: none;
    font-size: 156%;
    font-weight: 500;
    color: #fff;
    position: relative;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li > a:hover{
	opacity: 0.8;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::before,
#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::after{
    content: "";
    position: absolute;
    top: 50%;
    left: auto;
    right: 4%;
    display: block !important;
    width: 4px;
    height: 14px;
    background: #fff;
    border: none;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::before{
	transform: translate(-50%,-80%) rotate(135deg);
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::after{
	transform: translate(-50%,-20%) rotate(45deg);
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a::before, /* 子メニュー */
#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a::after{
    content: "";
    position: absolute;
    top: 50%;
    left: auto;
    right: 8px;
    display: block !important;
    width: 2px;
    height: 18px;
    background: #48a3a3;
    border: none;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a::before{
	transform: translate(-50%,-50%) rotate(90deg);
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a::after{
	transform: translate(-50%,-50%) rotate(0deg);
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a.toggleopen::before{
	display: none !important;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.menu-item-has-children > a.toggleopen::after{
	transform: translate(-50%,-50%) rotate(90deg);
	transition: all .4s;
}

body #nav_wrap .gnav > li > ul.sub-menu {
    position: static !important;
}

body #nav_wrap .gnav > li:hover > ul.sub-menu {
	display: none;
}

body #nav_wrap .gnav ul.sub-menu{
	margin: 8px 0;
}

body #nav_wrap .gnav ul.sub-menu li a {
    padding: 2px 16px !important;
    border-bottom: none;
    background-color: #fff;
    color: #333;
    font-weight: 600 !important;
}

body #nav_wrap .gnav ul.sub-menu li a::before{
    content: "";
	display: block;
    position: absolute;
    border-right: 1px solid #1e4fa8;
    border-top: 1px solid #1e4fa8;
    width: 6px;
    height: 6px;
    left: 0;
    top: calc(50% - 4px);
    margin-top: 0;
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
}

body #nav_wrap .gnav ul.sub-menu li a:hover{
	opacity: 0.8;
}

#nav_wrap ul li.button{
	display: inline-block;
    border-radius: 0px;
    box-shadow: none;
    min-width: 0;
    max-width: 100%;
	width: 342px;
    padding: 40px 0px !important;
    background: none;
    box-sizing: border-box;
    font-size: 72%;
    line-height: 140%;
    color: #fff;
    font-weight: bold;
    text-align: center;
    text-decoration: none;
}

#nav_wrap ul li.button a{
    display: block;
    width: 256px !important;
    max-width: 100%;
	padding: 8px 24px !important;
	margin: 0 auto;
    border-radius: 40px;
    border-bottom: none;
    background: #fff !important;
    color: #48a3a3 !important;
    font-family: "Noto Sans JP";
    font-size: 144% !important;
    font-weight: 600 !important;
    text-align: center;
}

#nav_wrap ul li.button a:hover{
    opacity: 0.8;
}

#header_right #nav_container.burger #nav_wrap ul.gnav > li.button > a::before,
#header_right #nav_container.burger #nav_wrap ul.gnav > li.button > a::after{
    display: none !important;
}



/*------------------------------------------------------------------------
◆トグル（モバイル）　オーバーライド
------------------------------------------------------------------------*/
@media screen and (min-width: 0px) {

	/* 開閉ボタン */
	#gnav-switch{
		display: block;
		float: right;
		height: 62px;
		width: 70px;
		padding-top: 20px;
		text-align: center;
		line-height: 60%;
		cursor: pointer;
		font-size: 120%;
		box-sizing: border-box;
	}

	#gnav-switch span.text{
		display: block;
	    font-size: 8px;
	    margin-top: 2px;
	}

	#gnav-switch span.text.close{
		display: none;
	}

	#gnav-switch.text.on span.text.menu{
		display: none;
	}

	#gnav-switch.text.on span.text.close{
		display: block;
	}

	/* アイコン */
	.menu-icon,
	.menu-icon span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
		position: relative;
		z-index: 1;
	}

	.menu-icon {
		position: relative;
        width: 48px;
        height: 52px;
	}

	body.nav_active .menu-icon {
        width: 52px;
        height: 52px;
	}

	body .menu-icon span {
		position: absolute;
		left: 0;
		width: 100%;
        height: 4px;
		background-color: #fff;
	}

	body.nav_active .menu-icon span {
        height: 6px;
		background-color: #fff;
	}

	.menu-icon span:nth-of-type(1) {
		top: 0;
	}
	.menu-icon span:nth-of-type(2) {
		top: 22px;
	}
/*
	.menu-icon span:nth-of-type(3) {
        width: 40px;
		bottom: 0;
	}
*/
	/* アイコン押下時 */
	.on .menu-icon span {
		/*background-color: #fff;*/
	}

	/* アイコン×ボタンに変更 */
	.on .menu-icon span:nth-of-type(1) {
		-webkit-transform: translateY(20px) rotate(-45deg);
		transform: translateY(20px) rotate(-45deg);
        top: 4px;
        bottom: auto;
	}
/*
	.on .menu-icon span:nth-of-type(2) {
		opacity: 0;
		top: 0;
	}
	.on .menu-icon span:nth-of-type(3) {
        width: 100%;
		-webkit-transform: translateY(-20px) rotate(45deg);
		transform: translateY(-20px) rotate(45deg);
		bottom: 2px;
	}
*/
	.on .menu-icon span:nth-of-type(2) {
        width: 100%;
		-webkit-transform: translateY(-20px) rotate(45deg);
		transform: translateY(-20px) rotate(45deg);
        top: 43px;
        bottom: auto;
	}



	/* 開閉ボタン　押下時 */
	#gnav-switch.on{
		/*background: #999 !important;*/
		color: #000;
	}

	#gnav-switch .toggle-label:after{
		content: "";
		display: block;
		clear: both;
	}


	#nav_wrap{
		position: relative;
		height: auto;
		z-index: 99999;
		margin: 0px auto;
		overflow: hidden;
		margin-bottom: 0px;
		width: 100%;
		-webkit-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-moz-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-ms-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-o-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
	}

	/* たたむ型 */
	nav#nav_container.bundle{
		position: absolute;
		width: 100%;
	}

	nav#nav_container.bundle + *{
		margin-top: 53px;
	}

	.bundle #nav_wrap{
		display: none;
	}

	.bundle #nav_wrap ul li a,
	.burger #nav_wrap ul li a{
		display: block;
	}

	.bundle #menu_bt{
		display: block;
	}

	/* フロー型 */
	nav#nav_container.flow #menu_bt{
		display: none;
	}

	nav#nav_container.flow #nav_wrap {
		overflow-x: scroll;
	}

	body #nav_wrap ul#gnav {
        border-top: none;
	    table-layout: auto;
	}

	nav#nav_container.flow #nav_wrap ul li{
		display: table-cell !important;
	}

	nav#nav_container.flow #nav_wrap ul li a{
		display: block;
		width: auto;
		border-bottom: none;
		padding: 12px 16px;
	}

	nav#nav_container.flow #nav_wrap ul li #gnav > li > ul.sub-menu{
		display: none !important;
	}
/*
	html{
	}

	body{
		left: 0%;
		position: relative;
		-webkit-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-moz-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-ms-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-o-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
	}

	body.nav_active{
		left: -256px;
		position: relative;
		-webkit-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-moz-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-ms-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		-o-transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
		transition: all 0.2s cubic-bezier(0.25, 0.1, 0.25, 1);
	}
*/

	#nav_wrap ul li{
		display: block !important;
		float: none;
		position: relative;
		width: 100%;
	}

	#nav_wrap ul li a{
		display: none;
		height: auto;
		width: 100%;
		padding: 12px 4%;
		border-top: 1px solid #fff;
		border-right: none;
		border-left: none;
		background: none;
		font-size: 90%;
		font-weight: bold;
		line-height: 200%;
		text-align: left;
		text-decoration: none;
		text-shadow: none;
		-webkit-tap-highlight-color: #333;
	}

	#nav_wrap ul li:nth-child(1) a{
		border-top: none;
	}

	/* バーガー型 */
	.burger #nav_wrap{
	    position: absolute;
	    width: 100%;
	    left: 0;
	    top: 90px;
		display: none;
	}

	#nav_container.burger header.header_fix #nav_wrap{
		height: 0;
		transition: none;
    	top: auto;
	}

	body.nav_active header.header_fix #nav_container.burger #nav_wrap{
		height: 100vh;
	}

	body.home.nav_active #header_container,
	body.home.nav_active #header_wrap,
	body.home.nav_active #header_right.nav{
		position: absolute !important;
	}

	.burger #nav_wrap ul li a{
		display: block;
	}

	#nav_wrap ul li a:hover{
		background: #fff;
		color: #333;
	}

	#nav_wrap ul li:first-child a {
		border-left: none;
	}

	#nav_wrap ul li a.tap{
		color: #FFFFFF !important;
		border: 1px solid #0763A4;
	}

	#nav_wrap ul li a.tap:after{
		border-top: 3px solid #FFFFFF;
		border-right: 3px solid #FFFFFF;
	}

	/* 現在の場所 */
	#nav_wrap ul li.current-menu-item > a,
	#nav_wrap ul li.current-menu-ancestor > a,
	#nav_wrap ul li.current-post-ancestor > a,
	#nav_wrap ul li.current-page-ancestor > a{
		color: #333;
	}

	#nav_wrap ul li.current-menu-item > a:after,
	#nav_wrap ul li.current-menu-ancestor > a:after,
	#nav_wrap ul li.current-post-ancestor > a:after,
	#nav_wrap ul li.current-page-ancestor > a:after,
	#nav_wrap ul li.current-page-ancestor > a:after{
		display: none;
	}

	/* 親ページ 閉じている時 */
	#gnav > li a.toggleclose{
		color: #ffffff !important;
	}

	/* 親ページ 閉じている時のアイコン状態 */
	#gnav > li.menu-parent-item > a.toggleclose:after,
	#gnav > li.menu-parent-item > a:after{
		font-family: "fontello";
	    content: '\f107';
	    color: #333;
	    display: block !important;
	    /* width: 13px !important; */
	    /* height: 2px !important; */
	    /* border-top: none !important; */
	    /* border-right: none; */
	    /* background: #333; */
	    position: absolute !important;
	    top: 0.8em !important;
	    right: 4% !important;
	}

	/* 親ページ 開けている時 */
	#gnav > li a.toggleopen{
		border-bottom: 1px solid #000000 !important;
		background: #000000 !important;
		color: #FFFFFF !important;
		text-shadow: none !important;
	}

	/* 親ページ 開けている時のアイコン状態 */
	#gnav > li.menu-parent-item > a.toggleopen:after {
	    -moz-transform: rotate(-180deg);
	    -webkit-transform: rotate(-180deg);
	    -o-transform: rotate(-180deg);
	    -ms-transform: rotate(-180deg);
	    transform: rotate(-180deg);
		color: #FFFFFF;
	}

	/* 親ページ 閉じている時のタップ時の状態　初回 */
	#gnav > li.menu-parent-item > a.tap{
		border: 1px solid #000000;
		background: #000000;
		color: #FFFFFF;
	}

	/* 親ページ 閉じている時のタップ時　2回目以降 */
	#gnav > li.menu-parent-item > a.toggleclose:active{
		border: 1px solid #000000 !important;
		background: #000000 !important;
		color:#FFFFFF !important;
	}

	/* 親ページ 閉じている時のアイコン状態　タップ時　初回 */
	#gnav > li.menu-parent-item > a.tap:after{
		border-top: none;
		border-right: none;
		background: #FFFFFF;
	}

	/* 親ページ 閉じている時のアイコン状態　タップ時　2回目以降 */
	#gnav > li.menu-parent-item > a.toggleclose.tap:after{
		background: #FFFFFF !important;
	}

	/* 子ページ */
	#gnav ul.sub-menu{
		-moz-box-shadow:none !important;
		-webkit-box-shadow:none !important;
		box-shadow:none !important;
	}

	#gnav ul.sub-menu li a{
		background: #fff;
		color: #333;
		width: 100%;
		font-size: 88%;
		padding: 16px 4%;
		border-top: none;
	    border-bottom: 1px solid #ccc;
		opacity: 1;
	}

	#gnav ul.sub-menu li a:before{
		content: "-";
		margin-right: 8px;
	}

	#gnav ul.sub-menu li a:hover{
	}

	#gnav ul.sub-menu li:first-child a {
	}

	#gnav ul.sub-menu li a.tap {
		color: #FFFFFF !important;
		border-top: 1px solid #0763A4;
		border-bottom: 1px solid #0763A4;
	}

	#gnav > li > ul.sub-menu li.current-menu-item > a, 
	#gnav > li > ul.sub-menu li.current-menu-ancestor > a, 
	#gnav > li > ul.sub-menu li.current-post-ancestor > a, 
	#gnav > li > ul.sub-menu li.current-page-ancestor > a, 
	#gnav > li > ul.sub-menu li a:hover{
		background: #fff;
		color: #333;
	}

	/* 孫ページ 表示非表示 */
	#gnav ul.sub-menu ul.sub-menu{
		display:none !important;
	}

	/* モバイル専用メニュー */
	#nav_wrap ul#rnav,
	#nav_wrap ul#mnav{
		display:block;
		overflow:hidden;
	}

	#nav_wrap ul#rnav li,
	#nav_wrap ul#mnav li{
		display: block;
		float: none;
		width: 100%;
	}

	#nav_wrap ul#rnav li a,
	#nav_wrap ul#mnav li a{
/*
		padding-left: 8%;
		padding-right: 8%;
*/
	}

	#nav_wrap ul#rnav li a:after,
	#nav_wrap ul#mnav li a:after{
		border: none !important;
	}

	#nav_wrap ul#rnav li:nth-child(even) a,
	#nav_wrap ul#mnav li:nth-child(even) a{
		/*border-left: 1px solid #ccc;*/
	}

	#nav_wrap #searchform{
		display: block;
		padding: 16px 4%;
		text-align: center;
		border-top: 1px solid #464646;
	}

	#nav_wrap #searchform input[type="text"] {
	    padding: 0px 16px;
	    box-sizing: border-box;
	    width: 100%;
		height: 26px;
		max-width: 183px;
	}

	#nav_wrap #searchform input[type="image"] {
	    padding: 4px 16px;
	    vertical-align: bottom;
	}

	.disable_filter{
		position: absolute;
		z-index: 9999;
		width: 100%;
		background: #333;
		opacity: 0.9;
	}

	#menu_bt > a{
		height: auto;
		width: 100%;
		padding: 12px 4%;
		border-top: 1px solid #ccc;
		border-bottom: 1px solid #ccc;
		border-right: none;
		border-left: none;
		font-size: 90%;
		font-weight: bold;
		line-height: 200%;
		text-align: left;
		text-decoration: none;
		text-shadow: none;
		-webkit-tap-highlight-color: #333;

		display: block;
		text-align: center;
		background: #fff;
		color: #333;
	}

	#menu_bt.active > a{
		background: #000;
		color: #fff;
	}

	#menu_bt > a.icon-menu:before{
		padding-right: 4px;
	}

	#menu_bt.active a.icon-menu:before{
		content: '\e80d';
		color: #fff;
	}
}



body.home.nav_active #header_container.header_right_nav {
	transition: all 0.3s ease;
}

.menu-icon span {
    background-color: #48a3a3;
}

#nav_wrap ul#gnav {
    display: flex;
    border-left: none;
    flex-direction: column;
}

#nav_wrap ul#gnav > li {
    margin-left: 0;
}

#header_right #nav_wrap ul li a {
    padding-top: 12px;
    padding-bottom: 12px;
    font-size: 80%;
    font-weight: bold;
}

body.nav_active header.header_fix #nav_container.burger #nav_wrap {
    background-color: #fff;
}

body.home.nav_active header.header_fix #nav_container.burger #nav_wrap {
    background-color: rgb(0 0 0 / 80%);
	transition: all 0.3s ease;
}



/*------------------------------------------------------------------------
◆ヘッダー上部ナビ
------------------------------------------------------------------------*/
#hnav_sub_container {
    top: 36px;
}

#hnav_sub_container li a {
    padding: 4px 0 4px 48px;
    background: none !important;
    color: #000;
}

/*------------------------------------------------------------------------
◆ホーム
------------------------------------------------------------------------*/
body.home #header_container.header_right_nav {
    border-bottom: none;
}

body.home #contents_container {
    padding-top: 64px;
}

body.home #contents_wrap {
    padding-bottom: 0;
}

body.home #header_container.header_right_nav.header_fix,
body.home.nav_active #header_container.header_right_nav.header_fix{
	position: fixed !important;
}

.home #contents_container.sidebar_off #main_wrap h2{
    font-weight: 500;
    font-size: 424%;
	color: #48a3a3;
	position: relative;
}

.home #contents_container.sidebar_off #main_wrap section header h2 + p.en{
    font-size: 424%;
    color: #b4e6e6;
    font-weight: 600;
    position: absolute;
    transform: rotate(90deg);
}






.home #main_wrap #message_container{
	position: relative;
    overflow: visible;
    padding-top: 80px;
    padding-bottom: 0;
}

.home #main_wrap #message_container::after{
    content: "";
    background: url(/wp-content/themes/towayakuhin-child/images/home/circles.png) no-repeat 40% bottom;
    display: block;
    height: 197px;
    width: 100%;
    margin-top: 72px;
}

.home #main_wrap #message_container > *{
	max-width: 100%;
}

.home #main_wrap #message_container header h2{
	text-align: left;
}

.home #main_wrap #message_container .wp-block-columns{
	gap: 56px;
}

.home #main_wrap #message_container .wp-block-columns > *:nth-child(1){

}

.home #main_wrap #message_container .wp-block-columns > *:nth-child(2){
	position: relative;
}

.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before{
	content: "";
	background: url(/wp-content/themes/towayakuhin-child/images/home/circle02.png) no-repeat center center;
	height: 538px;
	width: 538px;
	position: absolute;
    top: 64px;
    right: auto;
    left: 420px;
}

.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en{
    top: 52px;
    right: auto;
    left: 500px;
    white-space: nowrap;
}

.home #main_wrap #message_container .wp-block-columns > *:nth-child(2) p{
	position: relative;
	z-index: 1;
}

.home #main_wrap #message_container .wp-block-image{
	position: relative;
    top: 144px;
}

.home #main_wrap #message_container .wp-block-image::before{
	content: "";
	background: url(/wp-content/themes/towayakuhin-child/images/home/circle01.png) no-repeat center center;
	height: 531px;
	width: 531px;
	position: absolute;
    top: -172px;
    right: 24px;
    z-index: 0;
}

.home #main_wrap #message_container .wp-block-image figure.alignright{
    float: right;
    margin: 0 !important;
    max-width: 100%;
}

.home #main_wrap #message_container .wp-block-image img{
	position: relative;
}

.home #main_wrap #message_container .wp-block-button a{
	width: 276px;
    padding: 12px;
	background: #48a3a3;
}

.home #main_wrap #message_container .wp-block-button a { /* WP bug 20251211*/
    display: flex;
    justify-content: center;
}

.home #main_wrap #message_container .wp-block-button a:hover{
	opacity: 0.8;
}








.home #main_wrap #guide_container{
    background: none !important;
    position: absolute;
    width: 100%;
    margin-top: -80px;
	overflow: visible;
}

.home #main_wrap #guide_container .wp-block-columns{
    justify-content: space-around;
    /*gap: 144px;*/
	display: flex;
}

.home #main_wrap #guide_container .wp-block-columns > *{
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
	border-radius: 264px;
	background-color: transparent;
    width: 264px;
    height: 264px;
    flex: 0 0 auto;
	position: relative;
}



/* WP bug 20251211 */
.home #main_wrap .wp-block-columns {
    display: flex;
    justify-content: space-between;
	gap: 4%;
}
.home .wp-block-gallery {
    justify-content: center;
}



.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1){
	top: 80px;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2){

}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3){
	top: 80px;
}

.home #main_wrap #guide_container .wp-block-columns > *::before{
	content: "";
	border: 2px solid #cce198;
    width: 264px;
    height: 264px;
	border-radius: 264px;
	position: absolute;
	z-index: 2;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1)::before{
	border-color: #cce198;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2)::before{
	border-color: #b9ddec;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3)::before{
	border-color: #fff799;
}

.home #main_wrap #guide_container .wp-block-columns > *::after{
	content: "";
    display: flex;
    width: 264px;
    height: 264px;
	border-radius: 264px;
    background: #fff;
	 box-shadow: 0px 0px 24px rgba(0, 0, 0, 0.10);
	position: absolute;
    top: auto;
    right: auto;
	bottom: -16px;
    left: -16px;
	z-index: 1;
	pointer-events: none;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1)::after{
    top: auto;
    right: -16px;
	bottom: -16px;
    left: auto;
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2)::after{
}

.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3)::after{
}

.home #main_wrap #guide_container .wp-block-columns > * *{
	position: relative;
    z-index: 2;
}








.home #main_wrap #business_container{
    margin: 160px 0;
    margin-top: 300px;
    padding: 0;
	background: #d4f2f2;
    overflow: visible;
    position: relative;
}

.home #main_wrap #business_container > * {
    margin-top: -80px;
    margin-bottom: -80px;
}

.home #main_wrap #business_container::before,
.home #main_wrap #business_container::after{
	content: "";
    display: block;
    width: 100%;
    height: 160px;
	background: url(/wp-content/themes/towayakuhin-child/images/home/business_back.png) no-repeat center top;
	background-size: cover;
    position: relative;

}

.home #main_wrap #business_container::before{
	background-position: center top;
    top: -160px;
}

.home #main_wrap #business_container::after{
	background-position: center bottom;
    bottom: -160px;
}

.home #main_wrap #business_container > *{
    margin-top: -80px;
    margin-bottom: -160px;
}

.home #contents_container.sidebar_off #main_wrap section#business_container h2 + p.en{
    font-size: 500%;
	top: -40px;
    right: auto;
    left: 4%;
}

.home #main_wrap #business_container .wp-block-columns{
    flex-wrap: wrap !important;
}

.home #main_wrap #business_container .wp-block-columns .wp-block-column{
    display: flex;
	flex-basis: auto;
	flex-grow: inherit !important;
    margin: 0 auto;
}

.home #main_wrap #business_container .wp-block-columns header{
    display: flex;
    align-items: center;
    justify-content: center;
    height: 246px;
    width: 246px;
    border-radius: 50%;
	background: #fff;
    position: relative;
	z-index: 2;
}

.home #main_wrap #business_container .wp-block-columns header h3{
    margin-bottom: 0;
    font-weight: 500;
    font-size: 136%;
}

.home #main_wrap #business_container .wp-block-columns header h3::before{
	content: "";
    display: block;
    margin: 0 auto 16px;
    position: relative;
}

.home #main_wrap #business_container .wp-block-columns .wp-block-column:nth-child(1) header h3::before{
    width: 94px;
    height: 73px;
	background: url(/wp-content/uploads/2025/05/icon_kenkosyokuhin.png) no-repeat center center;
/*	width: 78px;*/
/*   height: 90px;*/
/*	background: url(/wp-content/themes/towayakuhin-child/images/home/icon_kenkosyokuhin.png) no-repeat center center;*/
}

.home #main_wrap #business_container .wp-block-columns .wp-block-column:nth-child(2) header h3::before{
    width: 77px;
    height: 68px;
	background: url(/wp-content/themes/towayakuhin-child/images/home/icon_healthcare.png) no-repeat center center;
}

.home #main_wrap #business_container .wp-block-columns header h3 + p{
	color :#48a3a3;
}

.home #main_wrap #business_container .wp-block-columns header + p{
    display: flex;
    align-items: center;
    justify-content: center;
	background :#48a3a3;
    width: 312px;
    height: 312px;
    border-radius: 50%;
    padding: 64px;
    color: #fff;
    position: relative;
	top: 8px;
	left: -24px;
	z-index: 1;
}











.home #main_wrap #product_container{
    background: #fff;
    padding: 120px 0 0px;
}

.home #main_wrap #product_container > *{
	max-width: 100%;
}

.home #main_wrap #product_container > * > .wp-block-gallery{
    max-width: 100%;
    margin-bottom: 56px;
}

.home #main_wrap #product_container .wp-block-gallery {
    display: flex; /* 子要素を横並びにする */
    flex-wrap: nowrap; /* 改行を防ぐ */
    overflow: visible;
    position: relative; /* 相対位置指定 */
}

.home #main_wrap #product_container .wp-block-gallery .wp-block-image {
    flex: none; /* 横並びを維持 */
    margin-right: 10px; /* 各画像間の余白 */
    min-width: 282px;
	min-width: 0;
    overflow: visible;
}

.home #main_wrap #product_container .wp-block-gallery.has-nested-images figure.wp-block-image:has(figcaption):before{
    backdrop-filter: none;
}

.home #main_wrap #product_container .wp-block-gallery .wp-block-image figcaption{
	position: relative !important;
	bottom: 0px !important;
	color: #333 !important;
    text-shadow: none;
    background: none;
    font-size: 100%;
    line-height: 1.6;
}

.home #main_wrap #product_container .slick-prev,
.home #main_wrap #product_container .slick-next{
    z-index: 1;
}

.home #main_wrap #product_container .slick-prev:before{
	content: "";
	background: url(/wp-content/themes/towayakuhin-child/images/common/arrow_left.png) no-repeat;
	background-size: contain;
    width: 60px;
    height: 60px;
	position: absolute;
    top: -44px;
    left: 16px;
}

.home #main_wrap #product_container .slick-next:before {
	content: "";
	background: url(/wp-content/themes/towayakuhin-child/images/common/arrow_right.png) no-repeat;
	background-size: contain;
    width: 60px;
    height: 60px;
	position: absolute;
    top: -44px;
    right: 16px;
}

@media screen and (min-width: 600px) {
    .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image) {
        width: calc(20% - var(--wp--style--unstable-gallery-gap, 16px)* .66667);
    }
}

.notable_figures_gallery ul.slick-dots {
    bottom: -64px;
    z-index: 9999;
}

.notable_figures_gallery .slick-dots li button:before {
    color: #ccc;
    font-size: 8px;
    opacity: 0.8;
}

.notable_figures_gallery .slick-dots li.slick-active button:before {
    color: #b3a563;
}

@media screen and (min-width: 521px) and (max-width: 960px){

	.home #main_wrap #product_container .wp-block-gallery .wp-block-image {
	    min-width: 0;
	}
}

@media screen and (max-width: 520px) {

	.home #main_wrap #product_container .wp-block-gallery .wp-block-image {
	    min-width: 0;
	}

	.notable_figures_gallery .slick-dots li {
	    margin: 0 4px;
	}
}



.home #contents_container.sidebar_off #main_wrap #banner_container {
    margin-bottom: 40px;
}









#news_container {
    display: flex;
    gap: 40px;
    align-items: center;
    max-width: 1200px;
    width: 100%;
    margin: -240px auto 104px;
    background: rgb(212 242 242 / 50%);
    border-radius: 16px;
    padding: 40px;
    position: absolute;
    bottom: auto;
    left: calc(50% - 600px);
    z-index: 3;
}

#news_container h2 {
	align-self: flex-start;
    font-size: 200%;
    font-weight: 700;
    color: #48a3a3;
}

#news_container ul {
	flex: 1
}

#news.show_all li {
	display: list-item;
    padding-top: 8px;
}

#news.show_all li:nth-child(1){
    padding-top: 0;
}

#news.show_all li a .wrap {
    align-items: baseline;
}

#news li a{
	text-decoration: none;
}

#news li a:hover{
	opacity: 0.6;
}

#news li a .wrap{
	display: flex;
    gap: 24px;
    align-items: center;
}

#news li a .wrap .time,
#news li a .wrap .title{
	color: #333;
}

#news li a .wrap .time{
	flex: 0 0 auto;
}

#news li a .wrap .newmark {
    padding: 4px;
    font-family: Verdana, Geneva, Arial, Helvetica, sans-serif !important;
    background-color: #f39800;
    color: #fff !important;
    border-radius: 4px;
    width: 72px;
    font-size: 88%;
    text-align: center;
    font-weight: normal;
    line-height: 1;
    white-space: nowrap;
}

#news.show_all li a .wrap .newmark{
    align-items: baseline;
}

#news ul.categories {
    display: none;
}

#news li:nth-child(n+2) {
	max-height: 0;
	opacity: 0;
	overflow: hidden;
	transition: max-height 0.4s ease, opacity 0.4s ease;
}

#news.show_all li:nth-child(n+2) {
	max-height: 100px; /* 適切な高さに調整（行数により調整要） */
	opacity: 1;
}

#toggle_news_btn {
    display: block;
    width: 40px;
    height: 40px;
    border-radius: 50%;
	padding-top: 40px;
    background: #48a3a3;
	border: none;
	overflow: hidden;
	cursor: pointer;
    position: relative;
}

#toggle_news_btn:hover{
	opacity: 0.8;
}

#toggle_news_btn:before, #toggle_news_btn:after {
    content: "";
    width: 12px;
    height: 2px;
    display: block;
    color: #fff;
    background: #fff;
    position: absolute;
}

#toggle_news_btn:before{
	transform: translate(-7px , 22px) rotate(135deg);
	top: -2px;
	right: 3px;
}

#toggle_news_btn:after {
	transform: translate(7px , 22px) rotate(225deg);
	top: -2px;
	left: 3px;
}

#news.show_all + #toggle_news_btn:before{
	transform: translate(-7px , 22px) rotate(45deg);
	top: -2px;
	right: 3px;
}

#news.show_all + #toggle_news_btn:after {
	transform: translate(7px , 22px) rotate(-45deg);
	top: -2px;
	left: 3px;
}



#news_container .wp-block-button__link {
    min-width: 160px;
    padding: 4px;
    font-size: 100%;
    border: none;
    background: #48a3a3;
    color: #fff;
    font-weight: bold;
    font-family: 'Noto Sans JP';
}

#news_container .wp-block-button__link.wp-element-button:hover{
	opacity: 0.8;
}

#news_container header p:before,
#news_container header p:after{
    display: none;
}

.home #main_wrap .news{
	width: 100%;
}

.home #main_wrap .news li a {
    border-bottom: none;
    position: relative;
}

.home #main_wrap .news li:first-child a {
    border-top: none;
}

.home #main_wrap .news li a .wrap{
    display: flex;
    gap: 120px;
}

.home #main_wrap .news li a .categories {
    display: block;
    position: absolute;
    top: 16px;
    left: 88px;
}

.home #main_wrap .news li a .category {
    display: inline-block;
    padding: 6px;
    min-width: 112px;
    text-align: center;
    border-radius: 4px;
    background: #333;
    color: #fff;
    font-size: 88%;
    line-height: 1;
    margin-right: 0;
}

.home #main_wrap .news li a .category{
    background-color: #48a3a3 !important;
}

.home #main_wrap .news li a .category-9{
    background-color: #00a0e9 !important;
}

.home #main_wrap .news li a .category-10{
    background-color: #358ab6 !important;
}

.home #main_wrap .news li a .category-11{
    background-color: #6ab429 !important;
}

.home #main_wrap .news li a .title {
    font-weight: normal;
    display: block;
    overflow: hidden;
    width: calc(100% - 200px - 8em);
}








/*------------------------------------------------------------------------
◆ページメインイメージ
------------------------------------------------------------------------*/
body #mainimage h1 {
    text-shadow: 0 0 2px black;
    font-size: 320%;
}



/*------------------------------------------------------------------------
◆ページトップ
------------------------------------------------------------------------*/
#pagenav a{
	background: #67A139;
}

#pagenav a:before ,
#pagenav a:after{
	content: "";
	width: 16px;
	height: 3px;
	display: block;
	color: #fff;
	background: #fff;
	position: absolute;
}

#pagenav a:before{
	transform: translate(-7px , 22px) rotate(45deg);
	top: 3px;
	right: 6px;
}

#pagenav a:after {
	transform: translate(7px , 22px) rotate(-45deg);
	top: 3px;
	left: 6px;

}



/*------------------------------------------------------------------------
◆フィルター
------------------------------------------------------------------------*/
body.home .black_filter{
	display: none;
}

/*------------------------------------------------------------------------
◆single
------------------------------------------------------------------------*/
body.single #main_wrap {
    float: none;
    width: 68%;
}

body.single #sub_wrap {
    display: none;
}

/*------------------------------------------------------------------------
◆archive
------------------------------------------------------------------------*/
body.archive #main_wrap {
    float: none;
    width: 68%;
}

body.archive #sub_wrap {
    display: none;
}


/*------------------------------------------------------------------------
◆レスポンシブ
------------------------------------------------------------------------*/
@media screen and (min-width: 1297px) and (max-width: 1600px){

	body #hnav_sub_container {
	    right: 4%;
	}

	.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before {
	    top: 82px;
        right: auto;
        left: 420px;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en {
		top: 64px;
        right: auto;
        left: 500px;
        white-space: nowrap;
	}


}

@media screen and (min-width: 1024px) and (max-width: 1480px){

	body #hnav_sub_container {
	    right: 4%;
	}

	/* キービジュアル */
	#keyvisual_container {
		height: 800px !important;
    	width: 100vw;
	    position: relative;
	    overflow: hidden;
	}

	.keyvisual_wrap.slider_back,
	.slider_back_wrap .slick-slide img {
		height: 800px !important;
	    object-fit: cover;
	    object-position: 72%;
	    width: 100vw;
	}

	#keyvisual_container .copy_wrap {
	    position: relative;
	}

	#keyvisual_container .copy_wrap::before{
        content: "";
        display: block;
        background: #fff;
        width: 1078px;
        height: 1078px;
        border-radius: 50%;
        position: absolute;
        top: -268px;
        left: -528px;
        z-index: 1;
	}

	#keyvisual_container .copy_wrap ul{
	    position: absolute;
	    z-index: 2;
	}

	#keyvisual_container .copy_wrap li.maincopy{
        font-size: 232%;
        font-weight: 600;
        color: #48a3a3;
        margin: 160px 0 0 80px;
	}

	#keyvisual_container .copy_wrap li.subcopy{
        font-size: 174%;
        font-weight: 500;
        color: #999999;
        margin: 16px 0 0 80px;
	}

	#keyvisual_container .slides .wrap{
		top: 587px;
        left: 144px;
	}

	#news_container {
	    margin: -104px auto 104px;
		z-index: 9;
	}




}

@media screen and (min-width: 1024px) and (max-width: 1296px){

	body #gnav-switch.on {
	    right: 64px;
	}

	body #hnav_sub_container {
	    right: 4%;
	}

	body #header_container{
        padding-right: 0;
    }

	body #header_wrap {
	    padding: 0;
	}

	body.home.nav_active #header_wrap{
    	position: static !important;
	}

	body #header_wrap h1 img {
	}

	/* キービジュアル */
	#keyvisual_container {
		height: 800px !important;
    	width: 100vw;
	    position: relative;
	    overflow: hidden;
	}

	.keyvisual_wrap.slider_back,
	.slider_back_wrap .slick-slide img {
		height: 800px !important;
	    object-fit: cover;
	    object-position: 72%;
	    width: 100vw;
	}

	#keyvisual_container .copy_wrap {
	    position: relative;
	}

	#keyvisual_container .copy_wrap::before{
        content: "";
        display: block;
        background: #fff;
        width: 1078px;
        height: 1078px;
        border-radius: 50%;
        position: absolute;
        top: -268px;
        left: -528px;
        z-index: 1;
	}

	#keyvisual_container .copy_wrap ul{
	    position: absolute;
	    z-index: 2;
	}

	#keyvisual_container .copy_wrap li.maincopy{
        font-size: 232%;
        font-weight: 600;
        color: #48a3a3;
        margin: 160px 0 0 80px;
	}

	#keyvisual_container .copy_wrap li.subcopy{
        font-size: 174%;
        font-weight: 500;
        color: #999999;
        margin: 16px 0 0 80px;
	}




	#keyvisual_container .slides .wrap{
		top: 587px;
        left: 144px;
	}

	#news_container {
        width: calc(100% - 160px);
        margin: 0 auto;
        bottom: 100px;
        position: relative;
        left: calc(50% - 50vw);
	}

    #news_container h2 {
        font-size: 186% !important;
        font-weight: 500;
    }

	#news_container ul {
	    flex: 1;
	    width: 100%;
	}

	#news li a{
		display: block;
	    width: calc(100% - 32px);
	}

	#news li a .wrap {
	    display: flex;
	    gap: 4px;
	    align-items: baseline;
        font-size: 88%;
	}

	#toggle_news_btn {
	    width: 24px;
	    height: 24px;
	    padding-top: 24px;
	    position: absolute;
	    top: calc(50% - 12px);
	    right: 16px;
	}

	#news li a .wrap .newmark {
        width: 44px;
        margin: 0 8px;
        font-size: 80%;
	}

	#toggle_news_btn:before, #toggle_news_btn:after {
		width: 8px;
	}

	#toggle_news_btn:before {
	    top: -10px;
	    right: -1px;
	}

	#toggle_news_btn:after {
	    top: -10px;
	    left: -1px;
	}

	#news.show_all + #toggle_news_btn:before {
	    top: -10px;
	    right: -1px;
	}

	#news.show_all + #toggle_news_btn:after {
	    top: -10px;
	    left: -1px;
	}





	/* ホーム */
	body.home #contents_container {
	    padding-top: 0;
	}

	.home #contents_container.sidebar_off #main_wrap h2 {
	    font-size: 300%;
	}

	.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before{
        background-size: contain;
        height: 400px;
        width: 400px;
        display: block;
        position: absolute;
        top: 24px;
        right: -220px;
        left: auto;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en {
	    white-space: nowrap;
        font-size: 300%;
        position: absolute;
        margin-top: -104px;
        top: auto;
        right: -56px;
        left: auto;
	}

	.home #contents_container.sidebar_off #main_wrap section#business_container h2 + p.en {
        font-size: 300%;
        top: -120px;
        right: auto;
        left: -56px;
	}


}

@media screen and (max-width: 1023px) {

	body.nav_active .black_filter{
		display: block;
		width: 100%;
		height: 100vh;
        margin-top: 51px;
        background: rgb(51 51 51 / 80%);
        position: fixed;
        top: 0;
        right: 0;
        z-index: 4;
	}

	body.home.nav_active .black_filter{
        top: -10px;
	}

	body #header_right.nav{
		display: none;
	    height: 144px;
		top: 0;
	    right: 0;
		overflow: hidden;
	}

	body.home #header_right.nav{
		display: block;
	}

	body.home #header_right #nav_container{

	}

	body.nav_active #header_right.nav {
		height: auto;
	    padding: 0;
	    background: none !important;
		box-shadow: 0px 1px 2px #cccccc;
		overflow: visible;
	    position: absolute !important;
	    top: 0;
	    right: 0;
	    z-index: 1;
	}

	body.home.nav_active #header_right.nav {
	    top: 108px;
	}

	/* メニュー */
	body #gnav-switch {
	    display: block;
	    position: absolute;
	    top: 0px;
	    right: 0;
	    z-index: 99999;
	}

	body #gnav-switch.on {
		background: none;
		position: absolute;
        top: -44px;
        right: 16px;
        z-index: 100000;
	}

	body #gnav-switch span.text {
	    margin-top: -8px;
	    font-size: 10px;
	    color: #fff;
	}



	body .menu-icon,
	body.nav_active .menu-icon {
        width: 28px;
        height: 26px;
	}

	body .menu-icon span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 3px;
        background-color: #fff;
    }

	body.nav_active .menu-icon span {
        height: 3px;
        background-color: #48a3a3;
    }

	body .menu-icon span:nth-of-type(1) {
		top: 0;
	}

	body .menu-icon span:nth-of-type(2) {
		top: 11px;
	}
/*
	body .menu-icon span:nth-of-type(3) {
        width: 20px;
		bottom: 0;
	}
*/
    body .on .menu-icon span:nth-of-type(1) {
        top: -8px;
    }

	body .on .menu-icon span:nth-of-type(2){
		top: 32px;
		opacity: 1;
	}
/*
	body .on .menu-icon span:nth-of-type(3) {
        bottom: -9px;
    }
*/

	/* グローバルナビ */
	body.nav_active {
		position: fixed;
		width: 100%;
		height: 100vh;
		overflow: hidden;
	}

	body #header_right.nav {
		display: block;
        width: 100%;
	}

	body.nav_active #header_right.nav {
		height: auto;
        width: 94%;
        margin-left: auto;
    	box-shadow: none;
		position: fixed !important;
		z-index: 999;
	}

	body #header_right #nav_container{
		overflow-y: auto;
	}

	body .burger #nav_wrap {
	    flex-direction: column;
    	gap: 0;
    	padding-right: 0;
	}

	body .burger #nav_wrap > .gnav_container {
	    width: 100%;
	}

	body #nav_wrap ul li:not(.button) a {
        border-top: 1px solid #75c7c7 !important;
        border-bottom: none !important;
	}

	body #header_right #nav_container.burger #nav_wrap ul.gnav > li > a {
	    padding: 16px 4%;
	    font-size: 80%;
        font-weight: 500;
	}

	#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::before,
	#header_right #nav_container.burger #nav_wrap ul.gnav > li > a::after {
	    width: 2px;
	    height: 8px;
	}

	#nav_wrap ul li.button{
        margin-right: auto;
        margin-left: auto;
    	padding: 32px 0px !important;
        background: #fff;
	}

	#nav_wrap ul li.button a {
        max-width: 200px;
	    background: #48a3a3 !important;
	    color: #fff !important;
	}

}



@media screen and (min-width: 961px) and (max-width: 1023px){

			/* フォントサイズ */
		    #contents_wrap {
			    font-size: 100%;
			}

			/* レイアウト */
			#contents_wrap:not(body.home #contents_wrap) {
			    padding: 24px 0;
			}

			/* フィルター */
			body.nav_active .black_filter {
		        margin-top: 76px;
			}

			/* テンプレート */
			body.page-template-page-one-column-no-sidebar-bottom #main_wrap {
			    font-size: 100%;
			}

			body.page-template-page-one-column-no-sidebar-bottom #main_wrap > * {
		        padding-left: 0 !important;
		        padding-right: 0 !important;
		    }

			body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > * {
			    padding: 24px 4% !important;
			}

			body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > section#contact_container {
			    padding: 40px 0 !important;
			}

			body.page #contents_wrap:not(body.home #contents_wrap, .page-template-page-no-sidebar #contents_wrap, .page-template-page-no-sidebar-bottom #contents_wrap) {
			    padding: 0;
			}

			body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2 {
			    font-size: 186% !important;
			}

			/* ヘッダー */
			body.nav_active #header_wrap{
				background: #fff;
			}

			body.home #header_wrap h1{
				top: auto;
			}

		    body #header_wrap h1 {
			    margin: 24px 0;
		        position: relative;
		        z-index: 2;
		    }

			body #header_wrap h1 img {
		        max-width: 100%;
		        width: auto;
		    	height: 22px;
			}

			/* メニュー */
			body.nav_active #header_right.nav {
		        top: 76px !important;
		    }

			body #header_right #nav_container {
		        height: 120px !important;
		        width: 120px !important;
				border-radius: 50%;
		    	background: #48a3a3;
			    position: absolute;
		        top: -36px;
		        right: -28px;
		        z-index: 10000;
		        transition: none;
		    }

			body.home #header_right #nav_container {
			    height: 96px;
			    width: 96px;
		        top: -36px;
		        right: -28px;
			    z-index: 10000;
			    transition: none;
			}

			body.nav_active #header_right #nav_container {
		        display: contents;
			}

			body.home.nav_active #header_right #nav_container {
		        display: contents;
			}

			#header_right #nav_container.burger #nav_wrap {
				width: 100%;
			    top: 0 !important;
			    left: 0 !important;
			    transition: none;
		    	opacity: 1;
			}

			body #gnav-switch {
		        display: block;
		        height: 120px !important;
		        width: 120px !important;
		        border-radius: 50%;
		        padding-top: 62px !important;
		        padding-right: 24px;
		        top: -36px;
		        right: -30px;
		        position: absolute;
		        z-index: 99999;
			}

			body #gnav-switch.on {
		        position: absolute;
		        top: -112px;
		        right: -28px;
		        z-index: 100000;
			}

			body #gnav-switch span.text {
			    margin-top: -8px;
			    font-size: 10px;
			    color: #fff;
			}

			/* キービジュアル */
			#keyvisual_container {
				height: 600px !important;
	        	width: 100vw;
			    position: relative;
			    overflow: hidden;
			}

			.keyvisual_wrap.slider_back,
			.slider_back_wrap .slick-slide img {
				height: 600px !important;
			    object-fit: cover;
			    object-position: 72%;
			    width: 100vw;
			}

			#keyvisual_container .copy_wrap {
			    position: relative;
			}

			#keyvisual_container .copy_wrap::before{
		        content: "";
		        display: block;
		        background: #fff;
		        width: 800px;
		        height: 800px;
		        border-radius: 50%;
		        position: absolute;
		        top: -240px;
		        left: -480px;
		        z-index: 1;
			}

			#keyvisual_container .copy_wrap ul{
			    position: absolute;
			    z-index: 2;
			}

			#keyvisual_container .copy_wrap li.maincopy{
		        font-size: 136%;
		        font-weight: 600;
		        color: #48a3a3;
				margin: 96px 0 0 40px;
			}

			#keyvisual_container .copy_wrap li.subcopy{
		        font-size: 100%;
		        font-weight: 500;
		        color: #999999;
				margin: 24px 0 0 40px;
			}

			#keyvisual_container .slides .wrap{
		        top: 368px;
		        left: 44px;
			}

			#keyvisual_container button.slick-prev.slick-arrow,
			#keyvisual_container button.slick-next.slick-arrow {
			    width: 18px;
			    height: 18px;
				padding-top: 18px;
			}



			#keyvisual_container button.slick-prev.slick-arrow{
			    left: -2px;
			}

			#keyvisual_container button.slick-next.slick-arrow {
			    right: -6px;
			}

			#keyvisual_container button.slick-prev:hover,
			#keyvisual_container button.slick-next:hover{
				opacity: 0.8;
			}

			#keyvisual_container button.slick-prev:before, #keyvisual_container button.slick-prev:after,
			#keyvisual_container button.slick-next:before, #keyvisual_container button.slick-next:after{
			    content: "";
			    width: 6px;
			    height: 2px;
			    display: block;
			    color: #fff;
			    background: #fff;
			    position: absolute;
				opacity: 1;
			}

			#keyvisual_container button.slick-prev:before{
				transform: translate(-7px , 22px) rotate(135deg);
		        top: -15px;
		        right: 0px;
			}

			#keyvisual_container button.slick-prev:after{
				transform: translate(7px , 22px) rotate(225deg);
		        top: -12px;
		        left: -2px;
			}

			#keyvisual_container button.slick-next:before{
				transform: translate(-7px , 22px) rotate(45deg);
				top: -16px;
				right: -1px;
			}

			#keyvisual_container button.slick-next:after{
				transform: translate(7px , 22px) rotate(135deg);
		        top: -13px;
		        left: -1px;
			}

			#keyvisual_container .slick-dots {
			    top: -13px;
			}

			#keyvisual_container .slick-dots li {
			    width: 16px;
			    height: 16px;
			}

			#keyvisual_container .slick-dots li {
			    margin: 0;
			}

			#keyvisual_container .slick-dots li button:before {
			    font-size: 7px;
			}

			#news_container {
				gap: 24px;
		        padding: 16px;
			    width: 92%;
		        margin: -64px auto 0px;
				position: relative;
		        left: auto;
			}

		    #news_container h2 {
		        font-size: 186% !important;
		        font-weight: 500;
		    }

			#news_container ul {
			    flex: 1;
			    width: 100%;
			}

			#news li a{
				display: block;
			    width: calc(100% - 32px);
			}

			#news li a .wrap {
			    display: flex;
			    gap: 22px;
			    align-items: baseline;
		        font-size: 88%;
			}

			#toggle_news_btn {
			    width: 24px;
			    height: 24px;
			    padding-top: 24px;
			    position: absolute;
			    top: calc(50% - 12px);
			    right: 16px;
			}

			#news li a .wrap .newmark {
		        width: 44px;
		        margin: 0 8px;
		        font-size: 80%;
			}

			#toggle_news_btn:before, #toggle_news_btn:after {
				width: 8px;
			}

			#toggle_news_btn:before {
			    top: -10px;
			    right: -1px;
			}

			#toggle_news_btn:after {
			    top: -10px;
			    left: -1px;
			}

			#news.show_all + #toggle_news_btn:before {
			    top: -10px;
			    right: -1px;
			}

			#news.show_all + #toggle_news_btn:after {
			    top: -10px;
			    left: -1px;
			}


			/* ホーム */
			body.home #contents_container {
			    padding-top: 0px;
			}

			.home #contents_container.sidebar_off #main_wrap h2 {
			    font-size: 172%;
			}

			.home #main_wrap #message_container .wp-block-columns{
				gap: 4%;
			}

			.home #main_wrap #message_container .wp-block-columns .wp-block-column:nth-child(1){
				flex-basis: 40% !important;
		    }

			.home #main_wrap #message_container .wp-block-columns .wp-block-column:nth-child(2){
				flex-basis: 56% !important;
		    }

			.home #main_wrap #message_container .wp-block-image {
			    top: auto;
			}

			.home #main_wrap #message_container .wp-block-image::before {
			    background-size: contain;
			    height: 274px;
			    width: 274px;
			    top: -80px;
		        right: auto;
		        left: -96px;
			}

			.home #main_wrap #message_container .wp-block-image figure.alignright {
			    float: none;
			    max-width: 100%;
			}

			.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before{
		        background-size: contain;
		        height: 240px;
		        width: 240px;
		        display: block;
		        position: absolute;
		        top: -80px;
		        right: -134px;
        		left: auto;
			}

			.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en {
			    white-space: nowrap;
			    font-size: 220%;
		        position: absolute;
		        margin-top: -120px;
		        top: auto;
		        right: -56px;
		        left: auto;
			}

			.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p{
				position: relative;
			}

			.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column header + p{
		    	width: 88%;
			}

			.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p br{
		    	display: none;
			}



			.home #main_wrap #message_container::after {
			    margin-top: 40px;
			}



			.home #main_wrap #guide_container {
			    margin-top: -80px;
				position: static;
			}

			.home #main_wrap #guide_container .wp-block-columns{
		    	gap: 40px;
			}

			.home #main_wrap #guide_container .wp-block-columns > *{
	        	flex-basis: 46% !important;
			}

			.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1){
				top: auto;
			}

			.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3){
				top: auto;
			}

			.home #main_wrap #guide_container .wp-block-columns > *::after {
				right: auto;
			    left: calc(50% - 132px - 16px);
			}

			.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1)::after {
			    right: calc(50% - 132px - 16px);
		        left: auto;
			}

			.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2)::after {
		        right: auto;
			    left: calc(50% - 132px - 8px);
			}



			.home #main_wrap #business_container {
			    margin-top: 80px;
			    margin-bottom: 80px;
			}

			.home #main_wrap #business_container::before {
			    top: -80px;
			}

			.home #main_wrap #business_container::before, .home #main_wrap #business_container::after {
			    height: 80px;
			}

			.home #main_wrap #business_container::after {
			    bottom: -80px;
			}

			.home #main_wrap #business_container > * {
			    margin-top: -80px;
			    margin-bottom: -80px;
			}

			.home #contents_container.sidebar_off #main_wrap section#business_container h2 + p.en {
			    font-size: 256%;
			    top: -64px;
			    right: auto;
			    left: -20px;
			}

			.home #main_wrap #business_container .wp-block-columns .wp-block-column {
				flex-basis: auto !important;
			}

			.home #main_wrap #product_container .slick-prev:before,
			.home #main_wrap #product_container .slick-next:before{
			    width: 40px;
			    height: 40px;
			}

			.home #main_wrap #product_container .slick-prev:before{
			    top: -30px;
			    left: 8px;
			}

			.home #main_wrap #product_container .slick-next:before{
			    top: -30px;
			    right: 8px;
			}

			.home #contents_container.sidebar_off #main_wrap #banner_container .wp-block-columns{
		    	text-align: center;
			}


			/* フッター */
		    #footer_container > * {
		        padding-right: 4%;
		        padding-left: 4%;
		    }

			body #footer_middle_info {
			    text-align: left;
			}

			#footer_container_middle p.footer_text br {
			    display: block;
			}

			/* ページメインイメージ */
			body #mainimage .section_wrap {
			    min-height: 160px;
	        	font-size: 120%;
			}

		    body #mainimage h1 {
		        font-size: 128%;
		    }

			/* フォーム */
			#main_wrap form.wpcf7-form table th {
			    padding-right: 8px;
			}

			/* single */
			body.single #main_wrap {
			    width: 100%;
			    max-width: 100%;
			}

			.single #main_wrap ul.term {
			    width: 64%;
			}

			/* archive */
			body.archive #main_wrap {
			    width: 100%;
			    max-width: 100%;
			}

		    body.category.archive #main_wrap .section a:after {
		        top: calc(50% - (12.73px / 2));
		        margin-top: 0;
		    }




}

@media screen and (min-width: 521px) and (max-width: 960px){

		/* フォントサイズ */
	    #contents_wrap {
		    font-size: 92%;
		}

		/* レイアウト */
		#contents_wrap:not(body.home #contents_wrap) {
		    padding: 24px 0;
		}

		/* フィルター */
		body.nav_active .black_filter {
	        margin-top: 60px;
		}

		/* テンプレート */
		body.page-template-page-one-column-no-sidebar-bottom #main_wrap {
		    font-size: 100%;
		}

		body.page-template-page-one-column-no-sidebar-bottom #main_wrap > * {
	        padding-left: 0 !important;
	        padding-right: 0 !important;
	    }

		body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > * {
		    padding: 24px 4% !important;
		}

		body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > section#contact_container {
		    padding: 40px 0 !important;
		}

		body.page #contents_wrap:not(body.home #contents_wrap, .page-template-page-no-sidebar #contents_wrap, .page-template-page-no-sidebar-bottom #contents_wrap) {
		    padding: 0;
		}

		body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2 {
		    font-size: 186% !important;
		}

		/* ヘッダー */
		body.nav_active #header_wrap{
			background: #fff;
		}

		body.home #header_wrap h1{
			top: auto;
		}

	    #header_wrap h1 {
		    margin: 24px 0;
	        position: relative;
	        z-index: 2;
	    }

		body #header_wrap h1 img {
	        max-width: 100%;
	        width: auto;
	    	height: 16px;
		}

		/* メニュー */
		body.nav_active #header_right.nav {
	        top: 60px !important;
	    }

		body #header_right #nav_container {
	        height: 120px !important;
	        width: 120px !important;
			border-radius: 50%;
	    	background: #48a3a3;
		    position: absolute;
	        top: -36px;
	        right: -28px;
	        z-index: 10000;
	        transition: none;
	    }

		body.home #header_right #nav_container {
		    height: 96px;
		    width: 96px;
	        top: -36px;
	        right: -28px;
		    z-index: 10000;
		    transition: none;
		}

		body.nav_active #header_right #nav_container {
	        display: contents;
		}

		body.home.nav_active #header_right #nav_container {
	        display: contents;
		}

		#header_right #nav_container.burger #nav_wrap {
			width: 100%;
		    top: 0 !important;
		    left: 0 !important;
		    transition: none;
	    	opacity: 1;
		}

		body #gnav-switch {
	        display: block;
	        height: 120px !important;
	        width: 120px !important;
	        border-radius: 50%;
	        padding-top: 62px !important;
	        padding-right: 24px;
	        top: -30px;
	        right: -24px;
	        position: absolute;
	        top: -44px;
	        right: -32px;
	        z-index: 99999;
		}

		body #gnav-switch.on {
	        position: absolute;
	        top: -104px;
	        right: -32px;
	        z-index: 100000;
		}

		body #gnav-switch span.text {
		    margin-top: -8px;
		    font-size: 10px;
		    color: #fff;
		}

		/* キービジュアル */
		#keyvisual_container {
			height: 600px !important;
        	width: 100vw;
		    position: relative;
		    overflow: hidden;
		}

		.keyvisual_wrap.slider_back,
		.slider_back_wrap .slick-slide img {
			height: 600px !important;
		    object-fit: cover;
		    object-position: 72%;
		    width: 100vw;
		}

		#keyvisual_container .copy_wrap {
		    position: relative;
		}

		#keyvisual_container .copy_wrap::before{
	        content: "";
	        display: block;
	        background: #fff;
	        width: 800px;
	        height: 800px;
	        border-radius: 50%;
	        position: absolute;
	        top: -240px;
	        left: -480px;
	        z-index: 1;
		}

		#keyvisual_container .copy_wrap ul{
		    position: absolute;
		    z-index: 2;
		}

		#keyvisual_container .copy_wrap li.maincopy{
	        font-size: 136%;
	        font-weight: 600;
	        color: #48a3a3;
	        margin: 80px 0 0 40px;
		}

		#keyvisual_container .copy_wrap li.subcopy{
	        font-size: 100%;
	        font-weight: 500;
	        color: #999999;
	        margin: 8px 0 0 40px;
		}




		#keyvisual_container .slides .wrap{
	        top: 316px;
	        left: 44px;
		}

		#keyvisual_container button.slick-prev.slick-arrow,
		#keyvisual_container button.slick-next.slick-arrow {
		    width: 18px;
		    height: 18px;
			padding-top: 18px;
		}



		#keyvisual_container button.slick-prev.slick-arrow{
		    left: -2px;
		}

		#keyvisual_container button.slick-next.slick-arrow {
		    right: -6px;
		}

		#keyvisual_container button.slick-prev:hover,
		#keyvisual_container button.slick-next:hover{
			opacity: 0.8;
		}

		#keyvisual_container button.slick-prev:before, #keyvisual_container button.slick-prev:after,
		#keyvisual_container button.slick-next:before, #keyvisual_container button.slick-next:after{
		    content: "";
		    width: 6px;
		    height: 2px;
		    display: block;
		    color: #fff;
		    background: #fff;
		    position: absolute;
			opacity: 1;
		}

		#keyvisual_container button.slick-prev:before{
			transform: translate(-7px , 22px) rotate(135deg);
	        top: -15px;
	        right: 0px;
		}

		#keyvisual_container button.slick-prev:after{
			transform: translate(7px , 22px) rotate(225deg);
	        top: -12px;
	        left: -2px;
		}

		#keyvisual_container button.slick-next:before{
			transform: translate(-7px , 22px) rotate(45deg);
			top: -16px;
			right: -1px;
		}

		#keyvisual_container button.slick-next:after{
			transform: translate(7px , 22px) rotate(135deg);
	        top: -13px;
	        left: -1px;
		}

		#keyvisual_container .slick-dots {
		    top: -13px;
		}

		#keyvisual_container .slick-dots li {
		    width: 16px;
		    height: 16px;
		}

		#keyvisual_container .slick-dots li {
		    margin: 0;
		}

		#keyvisual_container .slick-dots li button:before {
		    font-size: 7px;
		}

		#news_container {
	    	flex-direction: column;
			gap: 8px;
	        padding: 16px;
		    width: 92%;
	        margin: -64px auto 0px;
			position: relative;
	        left: auto;
		}

	    #news_container h2 {
	        font-size: 120% !important;
	        font-weight: 500;
	    }

		#news_container ul {
		    flex: 1;
	        width: 100%;
		}

		#news li a{
			display: block;
		    width: calc(100% - 32px);
		}

		#news li a .wrap {
		    display: flex;
		    flex-direction: column;
		    gap: 4px;
		    align-items: baseline;
	        font-size: 88%;
		}

		#toggle_news_btn {
		    width: 24px;
		    height: 24px;
		    padding-top: 24px;
		    position: absolute;
		    top: calc(50% - 8px);
		    right: 16px;
		}

		#news li a .wrap .newmark {
			padding: 2px;
		    width: 44px;
	        margin-top: 4px;
		    font-size: 80%;
		    position: absolute;
		    left: 104px;
		}

		#toggle_news_btn:before, #toggle_news_btn:after {
			width: 8px;
		}

		#toggle_news_btn:before {
		    top: -10px;
		    right: -1px;
		}

		#toggle_news_btn:after {
		    top: -10px;
		    left: -1px;
		}

		#news.show_all + #toggle_news_btn:before {
		    top: -10px;
		    right: -1px;
		}

		#news.show_all + #toggle_news_btn:after {
		    top: -10px;
		    left: -1px;
		}

		/* ホーム */
		.home #contents_container.sidebar_off #main_wrap h2 {
		    font-size: 172%;
		}

		body.home #contents_container {
		    padding-top: 0px;
		}

		.home #contents_container.sidebar_off #main_wrap h2 {
		    font-size: 172%;
		}

		.home #main_wrap #message_container .wp-block-columns{
			gap: 4%;
		}

		.home #main_wrap #message_container .wp-block-columns .wp-block-column:nth-child(1){
			flex-basis: 40% !important;
	    }

		.home #main_wrap #message_container .wp-block-columns .wp-block-column:nth-child(2){
			flex-basis: 56% !important;
	    }

		.home #main_wrap #message_container .wp-block-image {
		    top: auto;
		}

		.home #main_wrap #message_container .wp-block-image::before {
		    background-size: contain;
	        height: 50vw;
	        width: 50vw;
	        max-height: 400px;
	        max-width: 400px;
		    top: -80px;
	        right: auto;
	        left: -96px;
		}

		.home #main_wrap #message_container .wp-block-image figure.alignright {
		    float: none;
		    max-width: 100%;
		}

		.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before{
	        background-size: contain;
	        height: 240px;
	        width: 240px;
	        display: block;
	        position: absolute;
	        top: -80px;
	        right: -134px;
        	left: auto;
		}

		.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en {
		    white-space: nowrap;
		    font-size: 220%;
	        position: absolute;
	        margin-top: -120px;
	        top: auto;
	        right: -56px;
	        left: auto;
		}

		.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p{
			position: relative;
		}

		.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column header + p{
	    	width: 88%;
		}

		.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p br{
	    	display: none;
		}



		.home #main_wrap #message_container::after {
		    margin-top: 40px;
		}



		.home #main_wrap #guide_container {
		    margin-top: -80px;
			position: static;
		}

		.home #main_wrap #guide_container .wp-block-columns{
	    	gap: 40px;
			flex-wrap: wrap !important;
		}

		.home #main_wrap #guide_container .wp-block-columns > *{
        	flex-basis: 46% !important;
		}

		.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1){
			top: auto;
		}

		.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3){
			top: auto;
		}

		.home #main_wrap #guide_container .wp-block-columns > *::after {
			right: auto;
		    left: calc(50% - 132px - 16px);
		}

		.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1)::after {
		    right: calc(50% - 132px - 16px);
	        left: auto;
		}

		.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2)::after {
	        right: auto;
		    left: calc(50% - 132px - 8px);
		}



		.home #main_wrap #business_container {
		    margin-top: 80px;
		    margin-bottom: 80px;
		}

		.home #main_wrap #business_container::before {
		    top: -80px;
		}

		.home #main_wrap #business_container::before, .home #main_wrap #business_container::after {
		    height: 80px;
		}

		.home #main_wrap #business_container::after {
		    bottom: -80px;
		}

		.home #main_wrap #business_container > * {
		    margin-top: -80px;
		    margin-bottom: -80px;
		}

		.home #contents_container.sidebar_off #main_wrap section#business_container h2 + p.en {
		    font-size: 256%;
		    top: -64px;
		    right: auto;
		    left: -20px;
		}

		.home #main_wrap #business_container .wp-block-columns .wp-block-column {
			flex-basis: auto !important;
		}

		.home #main_wrap #product_container .slick-prev:before,
		.home #main_wrap #product_container .slick-next:before{
		    width: 32px;
		    height: 32px;
		}

		.home #main_wrap #product_container .slick-prev:before{
		    top: -30px;
		    left: 8px;
		}

		.home #main_wrap #product_container .slick-next:before{
		    top: -30px;
		    right: 8px;
		}

		.home #contents_container.sidebar_off #main_wrap #banner_container .wp-block-columns{
	    	text-align: center;
		}

		/* フッター */
		body #footer_container_top {
			padding: 0;
		}

		body #footer_middle_menu {
		    display: flex;
		    gap: 16px;
		    flex-wrap: wrap;
		}

		body #footer_middle_menu .fnav_container {
	        display: block;
	        width: calc(50% - 8px);
	        float: none;
	    }

		body #fnav_left, body #fnav_center_right {
	        width: 100%;
	    }

	    body #fnav_center_left, body #fnav_right {
	        float: none;
	        display: block;
	        width: 100%;
	    }

		body #footer_container_middle #footer_wrap_middle {
		    flex-direction: column;
		    padding: 32px 0 0;
		}



		#footer_container_middle p.footer_text {
		    margin: 16px auto;
		}

		#footer_container_middle p.footer_text br{
			display: block;
		}

		#menu_button_wrap {
		    width: 100%;
		}

		#menu_button_wrap .button_wrap {
		    text-align: center;
		}

		#footer_container_middle #fnav_container a {
		    font-size: 88%;
		    font-weight: 400;
		}

		#footer_container_bottom #footer_wrap_copyright {
		    margin: 16px auto;
		}



		body #footer_middle_info {
		    width: 100%;
		    margin: 0;
		}

		#footer_map {
		    width: 100%;
		}

		#footer_middle_info .name img {
	        width: 244px;
	    }

	    #footer_middle_info {
		    margin: 24px 0 8px;
	        font-size: 88%;
	    }

		#footer_middle_menu_copyright {
		    width: 100%;
		    margin: 0px 0 48px;
		    margin-top: 0;
		    float: none;
		    text-align: center;
		    font-size: 88%;
		}

		#footer_wrap_bottom{
	        font-size: 80%;
		}

		/* ページメインイメージ */
		body #mainimage .section_wrap {
		    min-height: 160px;
        	font-size: 120%;
		}

	    body #mainimage h1 {
	        font-size: 128%;
	    }

		/* ページトップ */
		#pagenav a:before, #pagenav a:after {
		    width: 12px;
		    height: 3px;
		}

		#pagenav a:before {
		    top: -6px;
		    right: 0px;
		}

		#pagenav a:after {
		    top: -6px;
		    left: 1px;
		}

		/* フォーム */
		#main_wrap form.wpcf7-form table th {
		    padding-right: 8px;
		}

		/* single */
		body.single #main_wrap {
		    width: 100%;
		    max-width: 100%;
		}

		.single #main_wrap ul.term {
		    width: 64%;
		}

		/* archive */
		body.archive #main_wrap {
		    width: 100%;
		    max-width: 100%;
		}

	    body.category.archive #main_wrap .section a:after {
	        top: calc(50% - (12.73px / 2));
	        margin-top: 0;
	    }



}



@media screen and (min-width: 521px) and (max-width: 640px){

	.home #main_wrap #business_container .wp-block-columns .wp-block-column {
        flex-basis: 520px !important;
    }

	.home #main_wrap #business_container .wp-block-columns header + p {
		top: -144px;
        left: 0px;
        right: auto;
        margin-left: auto;
        margin-bottom: -186px;
	}

	.home #main_wrap #business_container .wp-block-columns .wp-block-column {
	    display: block;
	}

}



@media screen and (max-width: 520px) {

	/* フォントサイズ */
    #contents_wrap {
	    font-size: 88%;
	}

	/* レイアウト */
	#contents_wrap:not(body.home #contents_wrap) {
	    padding: 24px 0;
	}

	/* テンプレート */
	body.page-template-page-one-column-no-sidebar-bottom #main_wrap {
	    font-size: 100%;
	}

	body.page-template-page-one-column-no-sidebar-bottom #main_wrap > * {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

	body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > * {
	    padding: 24px 4% !important;
	}

	body.page-template-page-one-column-no-sidebar-bottom #main_wrap #content > section#contact_container {
	    padding: 40px 0 !important;
	}

	body.page #contents_wrap:not(body.home #contents_wrap, .page-template-page-no-sidebar #contents_wrap, .page-template-page-no-sidebar-bottom #contents_wrap) {
	    padding: 0;
	}

	body.page-template-page-one-column-no-sidebar-bottom #main_wrap h2 {
	    font-size: 144% !important;
	}

	/* フレキシブルテーブル */
	.wp-block-flexible-table-block-table table{
	    border-spacing: 0 !important;
	}

	/* ヘッダー */
	body.nav_active #header_wrap{
		background: #fff;
	}

	body.home #header_wrap h1{
		top: auto;
	}

    #header_wrap h1 {
        position: relative;
        z-index: 2;
    }

	body #header_wrap h1 img {
    	height: 12px;
	}

	/* メニュー */
	body.nav_active #header_right.nav {
	    top: 51px !important;
	}

	body #header_right #nav_container {
        height: 96px;
        width: 96px;
		border-radius: 50%;
    	background: #48a3a3;
	    position: absolute;
        top: -27px;
        right: -22px;
        z-index: 10000;
        transition: none;
    }

	body.home #header_right #nav_container {
	    height: 96px;
	    width: 96px;
	    top: -27px;
	    right: -22px;
	    z-index: 10000;
	    transition: none;
	}

	body.nav_active #header_right #nav_container {
        display: contents;
	}

	body.home.nav_active #header_right #nav_container {
        display: contents;
	}

	#header_right #nav_container.burger #nav_wrap {
	    top: 0 !important;
	    left: 0 !important;
	    transition: none;
    	opacity: 1;
	}

	body #gnav-switch {
	    display: block;
	    height: 96px;
	    width: 96px;
	    border-radius: 50%;
    	padding-top: 46px;
    	padding-right: 20px;
        top: -30px;
        right: -24px;
	    position: absolute;
	    z-index: 99999;"
	}

	body #gnav-switch.on {
		position: absolute;
        top: -84px;
        right: -24px;
        z-index: 100000;
	}

	body #gnav-switch span.text {
	    margin-top: -8px;
	    font-size: 10px;
	    color: #fff;
	}

	/* キービジュアル */
	#keyvisual_container {
        /* aspect-ratio: 75 / 107; */
		height: 600px !important;
        width: 100%;
	    position: relative;
	    overflow: hidden;
	}

	.keyvisual_wrap.slider_back,
	.slider_back_wrap .slick-slide img {
		height: 600px !important;
	    object-fit: cover;
	    object-position: center;
	    width: 100vw;
	}

	#keyvisual_container .copy_wrap {
	    position: relative;
	}

	#keyvisual_container .copy_wrap::before{
        content: "";
        display: block;
        background: #fff;
        width: 560px;
        height: 560px;
        border-radius: 50%;
        position: absolute;
        top: -160px;
        left: -332px;
        z-index: 1;
	}

	#keyvisual_container .copy_wrap ul{
	    position: absolute;
	    z-index: 2;
	}

	#keyvisual_container .copy_wrap li.maincopy{
		font-size: 88%;
        font-size: 5.4vw;
        font-size: 20px;
        font-weight: 600;
        color: #48a3a3;
        margin: 64px 0 0 16px;
	}

	#keyvisual_container .copy_wrap li.subcopy{
        font-size: 60%;
        font-size: 4.0vw;
        font-size: 14px;
        font-weight: 500;
        color: #999999;
        margin: 8px 0 0 16px;
	}




	#keyvisual_container .slides .wrap{
	    top: 276px;
	    left: 19px;
	}

	#keyvisual_container button.slick-prev.slick-arrow,
	#keyvisual_container button.slick-next.slick-arrow {
	    width: 13px;
	    height: 13px;
		padding-top: 13px;
	}



	#keyvisual_container button.slick-prev.slick-arrow{
	    left: -2px;
	}

	#keyvisual_container button.slick-next.slick-arrow {
	    right: -6px;
	}

	#keyvisual_container button.slick-prev:hover,
	#keyvisual_container button.slick-next:hover{
		opacity: 0.8;
	}

	#keyvisual_container button.slick-prev:before, #keyvisual_container button.slick-prev:after,
	#keyvisual_container button.slick-next:before, #keyvisual_container button.slick-next:after{
	    content: "";
	    width: 4px;
	    height: 1px;
	    display: block;
	    color: #fff;
	    background: #fff;
	    position: absolute;
		opacity: 1;
	}

	#keyvisual_container button.slick-prev:before{
		transform: translate(-7px , 22px) rotate(135deg);
        top: -17px;
        right: -2px;
	}

	#keyvisual_container button.slick-prev:after{
		transform: translate(7px , 22px) rotate(225deg);
        top: -15px;
        left: -3px;
	}

	#keyvisual_container button.slick-next:before{
		transform: translate(-7px , 22px) rotate(45deg);
        top: -17px;
		right: -3px;
	}

	#keyvisual_container button.slick-next:after{
		transform: translate(7px , 22px) rotate(135deg);
        top: -15px;
		left: -2px;
	}

	#keyvisual_container .slick-dots {
	    top: -11px;
	}

	#keyvisual_container .slick-dots li {
	    width: 16px;
	    height: 16px;
	}

	#keyvisual_container .slick-dots li {
	    margin: 0;
	}

	#keyvisual_container .slick-dots li button:before {
	    font-size: 7px;
	}

	#news_container {
    	flex-direction: column;
		gap: 8px;
        padding: 16px;
	    width: 92%;
        margin: -64px auto 0px;
		position: relative;
        left: auto;
	}

    #news_container h2 {
        font-size: 120% !important;
        font-weight: 500;
    }

	#news_container ul {
	    flex: 1;
        width: 100%;
	}

	#news li a{
		display: block;
	    width: calc(100% - 32px);
	}

	#news li a .wrap {
	    display: flex;
	    flex-direction: column;
	    gap: 4px;
	    align-items: baseline;
        font-size: 88%;
	}

	#toggle_news_btn {
	    width: 24px;
	    height: 24px;
	    padding-top: 24px;
	    position: absolute;
	    top: calc(50% - 12px);
	    right: 16px;
	}

	#news li a .wrap .newmark {
		padding: 2px;
	    width: 44px;
        margin-top: 4px;
	    font-size: 80%;
	    position: absolute;
	    left: 104px;
	}

	#toggle_news_btn:before, #toggle_news_btn:after {
		width: 8px;
	}

	#toggle_news_btn:before {
	    top: -10px;
	    right: -1px;
	}

	#toggle_news_btn:after {
	    top: -10px;
	    left: -1px;
	}

	#news.show_all + #toggle_news_btn:before {
	    top: -10px;
	    right: -1px;
	}

	#news.show_all + #toggle_news_btn:after {
	    top: -10px;
	    left: -1px;
	}

	/* ホーム */
	body.home #contents_container {
	    padding-top: 0px;
	}

	.home #contents_container.sidebar_off #main_wrap h2 {
	    font-size: 172%;
	}

	.home #main_wrap #message_container .wp-block-button a {/* WP bug 20251211 */
		display: flex;
		justify-content: center;
		margin: 0 auto;
	}
	
	.home #main_wrap #message_container .wp-block-columns{
		gap: 24px;
	}

	.home #main_wrap #message_container .wp-block-columns {/* WP bug 20251211 */
        gap: 24px;
        flex-direction: column;
    }
	
	.home #main_wrap #message_container .wp-block-image {
	    top: auto;
	}

	.home #main_wrap #message_container .wp-block-image::before {
	    background-size: contain;
	    height: 274px;
	    width: 274px;
        top: -64px;
        right: auto;
        left: -72px;
	}

	.home #main_wrap #message_container .wp-block-image figure.alignright {
	    float: left;
	    max-width: 220px;
	}

	.home #main_wrap #message_container .wp-block-columns > *:nth-child(2)::before {
        background-size: contain;
        height: 240px;
        width: 240px;
        display: block;
        position: absolute;
        top: -80px;
        right: -134px;
        left: auto;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container h2 + p.en {
	    white-space: nowrap;
	    font-size: 220%;
        position: absolute;
        margin-top: -120px;
        top: auto;
        right: -56px;
        left: auto;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p{
		position: relative;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column header + p{
    	width: 88%;
	}

	.home #contents_container.sidebar_off #main_wrap section#message_container .wp-block-column p br{
    	display: none;
	}



	.home #main_wrap #message_container::after {
	    margin-top: 40px;
	}



	.home #main_wrap #guide_container {
	    margin-top: -80px;
		position: static;
	}

	.home #main_wrap #guide_container .wp-block-columns{
    	gap: 40px;
	}

	.home #main_wrap #guide_container .wp-block-columns { /* WP bug 20251211 */
        flex-direction: column;
        align-items: center;
    }
	
	.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1){
		top: auto;
	}

	.home #main_wrap #guide_container .wp-block-columns > *:nth-child(3){
		top: auto;
	}

	.home #main_wrap #guide_container .wp-block-columns > *::after {
		right: auto;
	    left: calc(50% - 132px - 16px);
	}

	.home #main_wrap #guide_container .wp-block-columns > *:nth-child(1)::after {
	    right: calc(50% - 132px - 16px);
        left: auto;
	}

	.home #main_wrap #guide_container .wp-block-columns > *:nth-child(2)::after {
        right: auto;
	    left: calc(50% - 132px - 8px);
	}



	.home #main_wrap #business_container {
	    margin-top: 80px;
	    margin-bottom: 80px;
	}

	.home #main_wrap #business_container::before {
	    top: -80px;
	}

	.home #main_wrap #business_container::before, .home #main_wrap #business_container::after {
	    height: 80px;
	}

	.home #main_wrap #business_container > * {
	    margin-top: -80px;
	    margin-bottom: -80px;
	}

	.home #contents_container.sidebar_off #main_wrap section#business_container h2 + p.en {
	    font-size: 256%;
	    top: -64px;
	    right: auto;
	    left: -20px;
	}

	.home #main_wrap #business_container .wp-block-columns .wp-block-column {
	    display: block;
	}

	.home #main_wrap #business_container .wp-block-columns header + p {
	    top: -80px;
	    left: 0px;
	    right: auto;
        margin-left: auto;
    	margin-bottom: -80px;
	}

	.home #main_wrap #business_container::after {
	    bottom: -80px;
	    z-index: 0;
	}

	.home #main_wrap #product_container .slick-prev:before,
	.home #main_wrap #product_container .slick-next:before{
	    width: 32px;
	    height: 32px;
	}

	.home #main_wrap #product_container .slick-prev:before{
	    top: -30px;
	    left: 8px;
	}

	.home #main_wrap #product_container .slick-next:before{
	    top: -30px;
	    right: 8px;
	}

	.home #contents_container.sidebar_off #main_wrap #banner_container .wp-block-columns{
    	text-align: center;
	}

	.home #contents_container.sidebar_off #main_wrap #banner_container .wp-block-columns { /* WP bug 20251211 */
		flex-direction: column;
		gap: 8px;
	}




	/* フッター */
	body #footer_container_top {
		padding: 0;
	}

	body #footer_middle_menu {
	    display: flex;
	    gap: 16px;
	    flex-wrap: wrap;
	}

	body #footer_middle_menu .fnav_container {
        display: block;
        width: calc(50% - 8px);
        float: none;
    }

	body #fnav_left, body #fnav_center_right {
        width: 100%;
    }

    body #fnav_center_left, body #fnav_right {
        float: none;
        display: block;
        width: 100%;
    }

	body #footer_container_middle #footer_wrap_middle {
	    flex-direction: column;
	    padding: 32px 0 0;
	}



	#footer_container_middle p.footer_text {
	    margin: 16px auto;
	}

	#footer_container_middle p.footer_text br{
		display: block;
	}

	#menu_button_wrap {
	    width: 100%;
	}

	#menu_button_wrap .button_wrap {
	    text-align: center;
	}

	#footer_container_middle #fnav_container a {
	    font-size: 88%;
	    font-weight: 400;
	}

	#footer_container_bottom #footer_wrap_copyright {
	    margin: 16px auto;
	}



	body #footer_middle_info {
	    width: 100%;
	    margin: 0;
	}

	#footer_map {
	    width: 100%;
	}

	#footer_middle_info .name img {
        width: 244px;
    }

    #footer_middle_info {
	    margin: 24px 0 8px;
        font-size: 88%;
    }

	#footer_middle_menu_copyright {
	    width: 100%;
	    margin: 0px 0 48px;
	    margin-top: 0;
	    float: none;
	    text-align: center;
	    font-size: 88%;
	}

	#footer_wrap_bottom{
        font-size: 80%;
	}



	/* ページトップ */
	#pagenav a:before, #pagenav a:after {
	    width: 12px;
	}

	#pagenav a:before {
	    top: -6px;
	    right: 0px;
	}

	#pagenav a:after {
	    top: -6px;
	    left: 0px;
	}




	/* ページメインイメージ */
	body #mainimage .section_wrap {
	    min-height: 0;
	}

    body #mainimage h1 {
        font-size: 108%;
    }

	/* サイドナビ */
	#sidenav li a:before {
	    top: 1.2em;
	}

	/* フォーム */
	#main_wrap form table td input[type="text"]{
		width: 100%;
	}

	/* single */
	body.single #main_wrap {
	    width: 100%;
	}

	/* archive */
	body.archive #main_wrap {
	    width: 100%;
	}

    body.category.archive #main_wrap .section a:after {
        top: calc(50% - (12.73px / 2));
        margin-top: 0;
    }

}


