@charset "UTF-8";
html {
	overflow-y:scroll;
}
#wd-63d8a7e33ff08 {
display: none!important;
}
.gogosite {
	display: inline-block;
	font-size: 14px;
	color: #996600;
	padding-top: 5px;
}
.vc_custom_1627997469457 .info-btn-wrapper {
display: none!important;
}
/* タイトルのサイズ指定 (1.5em) */
.swal2-title.swal-custom-title {
    font-size: 1.5em !important;
    padding-top: 1em; /* 少し余白をあけると綺麗です */
}

/* ボタンの文字サイズ指定 */
.swal2-styled.swal-custom-button {
    font-size: 1.1em !important; /* 標準より少し大きく */
    padding: 10px 25px !important; /* 押しやすくサイズ調整 */
    font-weight: bold;
}
/*========root==============*/
:root{
--wd-text-color:#333333!important;
--color-gray-300: #333333!important;
--color-gray-400: #333333!important;
--color-gray-500: #333333!important;
--color-gray-600: #333333!important;
--color-gray-700: #333333!important;
--sub-menu-color: #555555!important;
--nav-icon-size: 1em!important; 
--wd-main-bgcolor: rgba(255,255,255,.0)!important;
}
.woocommerce-error .amount {
color: #003366!important;
}
.footer-container p{
    padding-bottom:0!important;
    margin-bottom:0!important;	
}
.copyrights-wrapper img{
opacity:1!important;
}
.wd-prefooter {
padding-bottom: 0!important;
}
.wd-pagination{
margin-left: 5%!important;
}
.wd-pagination li{
	border: 1px solid #CCCCCC;
}
h1.entry-title{
font-size: 30px!important;
}
.entry-header:before {
font-size: 60px!important;
}
.wd-empty-page {
font-size: 30px!important;
}

.site-content {
margin-bottom: 0!important;
}

@media only screen and (max-width: 1024px) {
.wd-empty-page {
font-size: 20px!important;
}
}

.single-product-page {
    padding-bottom: 50px!important;
}
@media only screen and (max-width: 700px) {
.acd_form .vc_tta-panel-body {
	padding-left:0!important;
	padding-right:0!important;
	border-top-style: none!important;
	border-right-style: none!important;
	border-bottom-style: none!important;
	border-left-style: none!important;
}
}
.acd_form .vc_tta-panel-heading h5{
display:block!important;
}
.acd_form .vc_tta-panel.vc_active .vc_tta-panel-heading{
	background-color: #CCCCFF!important;
}
/*======== placeholder ==============*/
.wd-search-full-screen .searchform input[type="text"] {
	font-size: 20px!important;
	letter-spacing: 1.6px!important;
}
input::-webkit-input-placeholder {
color: #999!important;
font-size:15px!important;
font-weight: normal!important;
}
input:-moz-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input::-moz-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:-ms-input-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input::placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:focus::-webkit-input-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:focus:-moz-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:focus::-moz-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:focus:-ms-input-placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
input:focus::placeholder {
color: #999!important;
font-size:14px!important;
font-weight: normal!important;
}
.wd-search-full-screen {
display: block!important;
z-index: 9999!important;
}
@media only screen and (max-width: 1024px)  {
.wd-search-full-screen {
display: block!important;
}
}




/**********************
page-title 
**********************/
.page-titleboi
{
/*	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	margin-top: -40px!important;
	margin-bottom: 40px;
**/	
	border-bottom-width: 2px;
	border-bottom-style: solid;
	background-color: rgba(255,255,255,0.00);
	border-bottom-color: #143A31;
	position: relative;
}		
.page-titleboi:after
{
}



.sub-head-all {
	text-align: center;
	position: relative;
}

.sub-head-title_h1 {
height:100px; /*高さ指定*/
}
.sub-head-title {
	position: absolute;
	margin-right: auto;
	margin-left: auto;
	width: 100%;
	text-align: center;
	bottom: 6px;
display: none!important;	
}
#next_h1 {
	padding-top: 22px;
}

#next_h1 h1{
	font-size: 20px;
	color: #143A31;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	letter-spacing: 3px;
	border-bottom: solid 2px #143A31;
	position: relative;
	display: inline-block;
	padding-right: 12px;
	padding-left: 12px;
	padding-top: 0px;
	padding-bottom: 0px;
	line-height: 1.3;
	margin-top: 8px;
	margin-bottom: 0;
font-weight: bold;	
}
#next_h1 h1:after {
    position: absolute;
    content: " ";
    display: block;
    border-bottom: solid 2px red;
    bottom: -2px;
    width: 20%;
}

#breadcrumb ol,
#breadcrumb li
{
	margin: 0!important;
	padding: 0!important;


}
#breadcrumb {
	text-align: left;
	font-size: 13px;
	display: inline-block!important;
	color: #444;
	position: absolute;
	z-index: 1;
	right: -14px;
	bottom: -23px;
	padding-right: 4px;
	padding-left: 5px;
	letter-spacing: normal;
}
#breadcrumb span,#breadcrumb li{
	display:inline-block;
}
#breadcrumb a {
	color: #444;
}
.br_arrow {
	padding-right: 1px;
	padding-left: 5px;
	color: #999;
}
a.br_last{
	color: #FFFFFF;
}
#breadcrumb ol li:last-child .br_arrow {
    display: none;
}
@media only screen and (max-width: 1024px) {
.sub-head-title_h1 {
width: 100%;
justify-content:center; /*横位置の指定*/
height:80px; /*高さ指定*/
}
#next_h1 {
padding-top:15px;
}
#next_h1 h1{
	font-size: 18px;
	padding-right: 10px;
	padding-left: 10px;
	line-height: 1.6;
	margin-left: 0;
	letter-spacing: 2px;	
}
.sub-head-title {
display:none!important;
width: 0%;
}
}

/*======== header menu plus ==============*/
.hd_top_p{
	font-size: 13px;
	text-align: center;
	color: #f6f6f6;
	line-height: 12px;
	font-weight: normal;
	padding: 0px;
	margin-top: 0px;
	margin-right: auto;
	margin-bottom: 0px;
	margin-left: auto;
	letter-spacing: 1px;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	display: inline-block;
}



@media only screen and (min-width: 1024px) {
.whb-sticked .whb-general-header
{
display:none!important;
}
}




.wd-toolbar {
display:none!important;
}


.scrollToTop{
	transform: translateX(130%)!important;
}
.scrollToTop.button-show{
    transform: translateX(0)!important;
}
@media only screen and (max-width: 1024px)  {
.scrollToTop{
	right: 6px!important;
}
}

/* #foot_suma footer styles =======================================*/
/* #foot_suma footer color back =======================================*/
#foot_pc,
#foot_suma{
	background: rgba(0,0,0,.76);

}

.foot_suma_curr a{
	background: rgba(0,0,0,1);
}
.foot_suma-element,
.foot_suma-element > a {
	color: #FFFFFF;
}
/* #foot_suma footer styles =======================================*/

#foot_suma{
	overflow: hidden;
	position: fixed;
	width: 100%;
	height:48px;
	bottom: 0;
	z-index: 350;
	text-align: center;
	padding-right: 0;
	padding-left: 0;
	padding-top: 3px;
	box-shadow: 0 0 9px rgb(0 0 0 / 42%);
}
#foot_pc{
	overflow: hidden;
	position: fixed;
	width: 100%;
	height:52px;
	bottom: 0;
	z-index: 350;
	text-align: center;
	padding-right: 5px;
	padding-left: 5px;
	padding-top: 5px;
	box-shadow: 0 0 9px rgb(0 0 0 / 42%);
}
#foot_input_menu,
#foot_input_menu_nopc
{
	overflow: hidden;
	position: fixed;
	bottom: 0;
	right:0;
	background: rgba(0,0,0,.8);
}
.foot_suma-element {
	position: relative;
}
.foot_suma-element a{
	height: 45px;
	position: relative;
	padding-bottom: 15px;
	border-radius: 5px
}
.foot_suma-element > a {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
	padding-right: 10px;
	padding-left: 10px;
	width: 80px;
}
#foot_suma .foot_suma-element > a {
	padding-right:1px;
	padding-left: 1px;
	width: 54px;
}
#foot_input_menu_nopc .foot_suma-element > a {
	padding-right:1px;
	padding-left: 1px;
	width: 50px;
}




.foot_infobox {
	display: flex;
	justify-content: space-between;
	width: 100%;
}



.ft-icon {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0;
}




.ft-label {
    position: absolute;
    right: 10px;
    bottom: 3px;
    left: 10px;
    display: block;
    overflow: hidden;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-weight: 600;
    font-size: 11px;
    line-height: 1;
    padding: 1px 0;
}
#foot_suma .ft-label {
    right: 2px;
    left: 2px;
	bottom: 4px;
    font-weight: 400;
    font-size: 10px;
}
#foot_input_menu_nopc .ft-label {
    right: 2px;
    left: 2px;
	bottom: 4px;
    font-weight: 400;
    font-size: 10px;
}

.ft-hum .ft-icon:before {
    font-size: 24px;
    content: "\f15a";
    font-family: "woodmart-font";
}


.ft-home .ft-icon:before {
    font-size: 20px;
    content: "\f144";
    font-family: "woodmart-font";
}


.ft-mail .ft-icon:before {
    font-size: 20px;
    content: "\f157";
    font-family: "woodmart-font";
}

.ft-shop .ft-icon:before {
    font-size: 20px;
    content: "\f146";
    font-family: "woodmart-font";
}

.ft-cart .ft-icon:before {
    font-size: 20px;
    content: "\f126";
    font-family: "woodmart-font";
}
.ft-cart .wd-cart-number {
	position: absolute;
	top: -5px;
	right: -9px;
	z-index: 1;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	color: #fff;
	text-align: center;
	letter-spacing: 0;
	font-weight: 400;
	font-size: 9px;
	line-height: 15px;
	background-color: #FF3300;
}
.ft-cart .ft-icon.cart_emp .wd-cart-number{
	background-color: #252525;
}  
.ft-cart .wd-cart-number > span {
	display: none;
}

.ft-ken .ft-icon:before {
    font-size: 20px;
    content: "\f148";
    font-family: "woodmart-font";
}

.ft-staff .ft-icon:before {
    font-size: 20px;
    content: "\f124";
    font-family: "woodmart-font";
}

.ft-post .ft-icon:before {
    font-size: 20px;
    content: "\f145";
    font-family: "woodmart-font";
}
.ft-prev .fa{
    font-size: 20px;
}
@media only screen and (max-width: 345px) {
#foot_suma .ft-staff{
	display: none;
}
}




/* TITLE widget  =======================================*/

.boi_vc_left p,
.boi_vc_left h1,
.boi_vc_left h2,
.boi_vc_left h3,
.boi_vc_left h4,
.boi_vc_left h5
{
	text-align: left!important;
	margin-bottom: 0px!important;
}
.boi_vc_bk_wh {
	background-color: #FFFFFF!important;
}
.boi_vc_color_wh.vc_message_box-solid-icon {
    color:#014b8f;
    border-color: #014b8f;
}
.boi_vc_color_wh.vc_message_box-solid-icon .vc_message_box-icon{
	background-color: #014b8f;
	color: #FFFFFF;
}
h5.widget-title{
	border-top: 4px double #014b8f;
	border-bottom: 4px double #014b8f;
	padding-top: 8px;
	padding-right: 8px;
	padding-bottom: 8px;
	padding-left: 12px;
}
.link_link h1,
.link_link h2, 
.link_link h3,
.link_link h4,
.link_link h5 {
	font-size: 14px;
}
.link_link {
	padding-right: 10px;
	padding-left: 10px;
}
.link_link .cs-button {
	font-size: 16px;
	margin-top: 10px;
	margin-bottom: 10px;
}
.link_title {
	font-size: 15px;
	padding-left: 7px;
}
.link_title_s {
	font-size: 13px;
	display: block;
	padding-left: 10px;
}
/*MENNU   =======================================*/
.mobile-nav .current-menu-parent .wd-sub-menu {
    display: block !important;
}
.mobile-nav {
	padding-right: 3px;
	padding-left: 3px;
	padding-bottom: 35px;	
}
.wd-header-mobile-nav a {
	color: #252525;
}
.mobile-nav .wd-heading {
    padding: 18px !important;
}
@media only screen and (max-width: 1024px)  {
.wd-sidebar .wd-heading {
    padding: 18px !important;
}
}


.wd-header-mobile-nav.wd-style-text .wd-tools-text {
display: block !important;
}

.mobile-nav li a {
	color: #FFFFFF !important;
	font-size: 15px;
}
.mobile-nav .wd-sub-menu li a {
    margin-left: 18px;
}
.mobile-nav.wd-side-hidden {
	background-color: #000 !important;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #444;
}

.mobile-nav .close-side-widget a, 
.mobile-nav .close-side-widget a .wd-action-text,
.mobile-nav .close-side-widget a .wd-action-icon:before,
.mobile-nav .close-side-widget a .wd-action-icon:after
{
	color: #FFFFFF !important;
}



.mobile-nav .wd-nav-mobile li.current-menu-item>a {
    color: #1c4999;
}

.mobile-nav.wd-side-hidden .wd-heading,
.wd-nav-mobile li a {
	border-bottom-color: #444 !important;
}
.single-post .mobile-nav .wd-nav-mobile .menu-item-13193 a,
.mobile-nav .wd-nav-mobile li.current-menu-item>a,
.mobile-nav .wd-nav-mobile li.current-menu-parent>a,
.mobile-nav .wd-nav-mobile li.opener-page>a
{
color: #143A31 !important;
background-color: #eee;
}
.mobile-nav .wd-nav-mobile .wd-nav-opener {
	color: #FFF;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #444;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #444;	
}



.whb-main-header .wd-dropdown {
	background: #f1f3f8 !important;
}
.wd-dropdown-menu .wd-sub-menu>li  {
width:auto!important;
min-width:260px!important;
margin-right: 4px!important;
padding-left: 6px;
}

.wd-dropdown {
	border-width: 2px;
	border-style: solid;
	border-color: #143A31;
	border-radius:0px;
}
.wd-nav>li a{
color: #143A31;
}


.whb-main-header .headnav_none {
display:none!important;
}
.login_on {
display:none!important;
}
.logged-in .mobile-nav .login_on {
display:block!important;
}
.logged-in .login_none {
display:none!important;
}
.mobile-nav .mbnav_none {
display:none!important;
}

.whb-main-header .m_title_hidden .nav-link-text {
display:none!important;
}
.whb-main-header li.m_title_hidden > a .wd-nav-icon
{
    margin-right: 4px !important;
    margin-left: 4px !important;
	display:block !important;
}
.whb-main-header li.m_title_hidden > a .wd-nav-icon:before
{
	font-size: 24px;
}
.whb-main-header .wide_form_top img {
display:none!important;
}

.wd-header-html p {
	margin-bottom: 0!important;
}
.head-right-pup {
	height: 84px;
	width: 340px;
	text-align: right;
	background-image: url(images/go_map3.png);
	background-repeat: no-repeat;
	background-position: center center;
	padding: 0px;
	margin-top: 3px;
	margin-right: 0px;
	margin-bottom: 0;
	margin-left: 0px;
    display: flex;
	align-items: flex-end;
	justify-content: flex-end;
}
ul#menu-top-head-mini1-1{
	width: 260px;
}
.nav_toku > a {
	width: 260px;
}
.m_title_hidden > a:after,
.nav_toku > a:after {
display:none!important;
}


.head-right-pup .wd-dropdown{
margin-top:3px!important;
}

.lrm-switch-to--reset-password {
display:none!important;
}
.lrm-user-modal-container .lrm-switcher a {
	color: #014b8f!important;
	font-weight: bold;
}

@media only screen and (min-width: 600px) {
.lrm-user-modal-container .lrm-switcher a {
    height: 60px!important;
    line-height: 60px!important;
}
}
.acc_count {
	white-space: nowrap;
	display: inline-block;
	padding-left: 4px;
}
.acc_count_title {
display:none;
}

.home .acc_count_title {
	white-space: nowrap;
	display: inline-block;
	padding-left: 4px;
}
@media only screen and (min-width: 720px) {
.home .acc_count_title {
	display: block;
	padding-bottom:6px;	
}
}


.enkaku_title {
	display: block;
	font-size: 15px;
	font-weight: bold;
	color: #FFFFFF;
	background-color: #003366;
	line-height:36px;
	height:36px;
	text-align: center;
}

/*simple=======================================*/
.suma_box {
	padding-bottom: 60px;
}
.suma_h3 {
	font-size: 16px;
	color: #006699;
	font-weight: bold;
	margin-top: 35px;
	margin-bottom: 10px;
	line-height: 1.5;
	padding-left: 8px;
	border-left-width: 4px;
	border-left-style: double;
	border-left-color: #006699;	
}
.suma_p {
	padding-right: 6px;
	padding-left: 6px;
	margin-bottom: 12px;
}
.aka {
	color: #CC0000;
}
.cha {
	color: #993300;
}
.suma_sp1 {
	text-indent: -1em;
	margin-left: 1em;
	display: inline-block;
}
.suma_center {
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
	display: block;
}
@media only screen and (max-width: 600px) {
#p5454.wd-popup {
padding: 10px;
}
}
@media only screen and (max-width: 600px) {
#p13997.wd-popup {
padding: 10px;
}
}


#p13997 ol  {
	padding-right: 10px;
	padding-left: 10px;
}
#p13997 ol li  {
  list-style: none;
  padding-left: 1.3em;
  text-indent: -1.3em;
}
.img_nform {
	margin-bottom: 40px;
}
.calendar-caption {
	font-size: 18px!important;
	color: #006699!important;
	font-weight: bold!important;
  padding-top: 6px!important;
}
.into-slide-bk {

}

.main-slider {
	background-color: rgba(21, 54, 46,0.9);
	margin-right: auto;
	margin-left: auto;
	text-align: center;
	border: 20px solid #143A31;
}
@media only screen and (max-width: 767px) {
.main-slider {
border: 3px solid #143A31;
}
}
/*tt_title=======================================*/
.tt_title_block {
	text-align: center;
	line-height: 1.2;
	max-width: 96%;
	overflow: hidden;
	margin-right: auto;
	margin-left: auto;
}
.tt_title_block span{
}
h1 .tt_title_h1 {
}	
.tt_title1 {
	font-size: 12px;
	color: #143A31;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 3px;
	padding-bottom: 2px;
	display:inline-block;
}
.tt_title2 {
	font-size: 18px;
	/*	color: #865A03;*/
	color: #D51010;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 2px;
	padding-bottom: 2px;
	font-weight: bold;
	display:block;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
}
.tt_title2{
    text-shadow: 1px 1px #fff, 1px -1px #fff, -1px 1px #fff, -1px -1px #fff;
    border-bottom: 2px solid #D51010;
    line-height: .82;
}
.tt_title2{
	position: relative;
}
.tt_title2:before {
	left: -110px;
	top: 50%;
}
.tt_title2:after {
	right: -110px;
	top: 50%;	
}
.tt_title2:before, .tt_title2:after {
	content: "";
	display: block;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: rgba(18,70,58,.6);
	position: absolute;
	width: 100px;	
}
.tt_title3 {
	font-size: 13px;
	color: #143A31;
	font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 4px;
	display:inline-block;
}
.tt_title_main {
	display: flex;
	align-items: center;
	flex-direction: row;
	text-align: center;
}
.tt_title_ch{
	color: #252525;
}

@media only screen and (max-width: 720px) {
.tt_title_mb_dele {
display:none;
}
}

/*tt_title　特別対応　=======================================*/
.tt_title_top {
	width: 420px;
	margin-right: auto;
	margin-left: auto;
	max-width: 100%;
	overflow: hidden;
}
@media only screen and (max-width: 1220px) {
.tt_title_top {
	width: 380px;
}
.tt_title_top .tt_title2{
	font-size: 16px;
}
.tt_title_top .tt_title3{
	font-size: 12px;
}
}
.tt_title_def {
	background-color: #FFFFFF;
	border-radius: 5px;
	border: 2px solid #006633;
	padding-top: 4px;
	padding-right: 6px;
	padding-bottom: 8px;
	padding-left: 6px;
	margin-bottom: 15px;
}
.tt_title_def.none3 {
	padding-bottom: 18px;
	margin-bottom: 24px
}
.tt_title_cmenu_tp1 {
	text-align: center;
	padding-top: 10px;
	padding-bottom: 25px;
}
.tt_title_cmenu_tp1 .icon_free_fw:before
{
	text-align: center;
	padding-right: 0px;
	font-size: 4.0em;
	color: #003366;	
}
.tt_title_cmenu_tp1 .tt_title_block
{
	margin-bottom: 16px;
}
/*tleft_title=======================================*/
.tleft_title_block {
	text-align: left;
	line-height: 1.2;
	width: 100%;
	max-width: 100%;	
}
.tleft_title1 {
	font-size: 12px;
	color: #143A31;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 6px;
	padding-bottom: 1px;
	display:inline-block;
}
.tleft_title2 {
	font-size: 18px;
	/*	color: #865A03;*/
	color: #D51010;
font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 2px;
	padding-bottom: 2px;
	font-weight: bold;
	display:block;
	text-align: left;
}
.tleft_title2{
    text-shadow: 1px 1px #fff, 1px -1px #fff, -1px 1px #fff, -1px -1px #fff;
border-bottom: 2px solid #D51010;
    line-height: .82;
}
.pdf_mnettop_one {
	padding-top: 15px;
}
#pdf_pdf_mnet .tleft_title2{
	line-height: 1.3;
	border-bottom: 1px solid #666;
	margin-left: 1em;
	text-indent: -1em;
}
.tleft_title2{
	position: relative;
}
.tleft_title2:after {
	right: -1010px;
	top: 50%;	
}
.tleft_title2:after {
	content: "";
	display: block;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: rgba(18,70,58,.6);
	position: absolute;
	width: 1000px;	
}
.tleft_title3 {
	font-size: 14px;
	color: #143A31;
	font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	padding-top: 3px;
	display:inline-block;
	padding-bottom: 3px;	
}
.tleft_title_main {
	display: flex;
	align-items: center;
	flex-direction: row;
	text-align: left;
}
.tleft_title_ch{
	color: #252525;
}
.title_s{
	color: #252525;
	font-size: 13px;
}
/*tleft_title　特別対応　=======================================*/
.tleft_title.tpt1 {

}
.tp_title_def {
	background-color: #FFFFFF;
	border-radius: 3px;
	border: 2px solid #006633;
	padding-top: 4px;
	padding-right: 10px;
	padding-bottom: 3px;
	padding-left: 6px;
	margin-bottom: 15px;
}
.tleft_title2.ahv1 a{
	color: #333333;
}
.tleft_title2.ahv1{
	color: #252525;
line-height: 1.3;	
}
/*.icon_text=======================================*/
.icon_text {
	max-width: 100%;
	overflow: hidden;
}
.icon_text:before {
    display: table;
    content: ' ';
}
.icon_text-icons {
display: table-cell;
vertical-align: middle;
}
.icon_text_3 {
	text-align: left;
line-height: 0;	
}
.icon_text_4 {
text-align: left;
max-width: 100% ;
text-align: center;
display: inline-block;
box-sizing: content-box;
position: relative;
line-height:1.0;
font-size:34px ;
width: 44px;
height: 44px;
}
.icon_text_5 {
    font-style: normal;
    font-size-adjust: none;
    font-stretch: normal;
    -webkit-font-feature-settings: normal;
    font-feature-settings: normal;
    -webkit-font-language-override: normal;
    font-language-override: normal;
    -webkit-font-kerning: auto;
    font-kerning: auto;
    font-synthesis: weight style;
    font-variant: normal;
    text-rendering: auto;
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
.icon_text_5:before {
    font-style: normal;
    display: inline-block;
    text-decoration: inherit;
    width: inherit;
    height: inherit;
    font-size: 1em;
    text-align: center;
    text-rendering: optimizelegibility
}
.icon_go_link {
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    box-sizing: content-box;
    border: none
}
.icon_text_content {
	display: table-cell;
	padding-left: 10px;
	line-height: 1.0;
	color:#252525;
	vertical-align: middle;
}
/*.icon_text_into=======================================*/
.icon_text_into {
	margin-right: auto;
	margin-left: auto;
	max-width: 100%;
}
.icon_text_into:before {
    display: table;
    content: ' ';
}
.icon_text_into-icons {
display: table-cell;
vertical-align: middle;
}
.icon_text_into_3 {
text-align: left;
line-height: 0;	
}
.icon_text_into_4 {
text-align: left;
max-width: 100%;
text-align: center;
display: inline-block;
box-sizing: content-box;
position: relative;
line-height:1.0;
font-size:14px ;
width: 20px;
height: 20px;
}
.icon_text_into_5 {
    font-style: normal;
    font-size-adjust: none;
    font-stretch: normal;
    -webkit-font-feature-settings: normal;
    font-feature-settings: normal;
    -webkit-font-language-override: normal;
    font-language-override: normal;
    -webkit-font-kerning: auto;
    font-kerning: auto;
    font-synthesis: weight style;
    font-variant: normal;
    text-rendering: auto;
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
.icon_text_into_5:before {
    font-style: normal;
    display: inline-block;
    text-decoration: inherit;
    width: inherit;
    height: inherit;
    font-size: 1em;
    text-align: center;
    text-rendering: optimizelegibility
}
.icon_text_into_content {
	display: table-cell;
	padding-left: 5px;
	line-height: 1.0;
	color:#252525;
	vertical-align: middle;
}
/*.icon_text共通=======================================*/
.icon-fw:before {
content: var(--fa);
font-family: "Font Awesome 6 Free";
}
.icon_color1 {
color:#3B6E15;
}
.icon_color2 {
color:#D51010;
}
/*.icon_特別対応=======================================*/
.icon_header{
	margin-top: 3px;
}
.icon_header .icon_text_into_content {
	font-size: 13px;
	letter-spacing: normal;
}
.icon_header .icon_text_5{
top:32%;
}
.icon_header .icon_text-icons {
	background-image: url(images/go_mail.png);
	background-repeat: no-repeat;
	background-position: 0 40px;
}
@media only screen and (max-width: 1220px) {
.icon_header .icon_text_into_content {
	font-size: 12px;
	letter-spacing: normal;
padding-left: 2px;	
}
.icon_header .icon_text-icons {
display:none ;
}
.icon_header .icon_text_content {
padding-left: 0;	
}

}
.icon_header .icon_text_into_content a,
{
	color:#252525;
} 
.icon_header .icon_text_4 {
font-size:34px ;
width: 44px;
height: 44px;
}
.icon_header .icon_text_into_4 {
font-size:14px ;
width: 20px;
height: 20px;
}
/*.icon_text_into=======================================*/
/*.icon_text_into=======================================*/
/*.icon_free=======================================*/
.icon_free {
text-align: left;
max-width: 100%;
display: inline-block;
box-sizing: content-box;
position: relative;
line-height:1.0;
}
.icon_free,
.icon_free a {
font-size: 1em;
}
.icon_free_fw {
}
.icon_free_fw:before {
font-style:  inherit;
display: inline-block;
text-decoration: inherit;
width: inherit;
height: inherit;
font-size: 1.2em;
padding-right: 2px;
text-align: center;
text-rendering: optimizelegibility;
content: var(--fa);
font-family: "Font Awesome 6 Free";
}
.icon-fw:before {
content: var(--fa);
font-family: "Font Awesome 6 Free";
}
.boi-icon-txt {
	font-size: 14px;
}
/*.icon_free size colorなど=======================================*/
.icon_free_size_m {
	font-size: 14px;
}
.pop_kojin_area .icon_free,
.pop_kojin_area .icon_free a,
.pop_login_area .icon_free,
.pop_login_area .icon_free a
{
	font-size: 13px;
	color: #FFFFFF;
}
.pop_kojin_area .icon_free,
.pop_login_area .icon_free
{
	padding-right: 10px;
	padding-left: 10px;
}
.pop_login_area_pt2 .if1
{
	padding-right: 14px;
}
.page-id-13431 .pop_login_area_pt2 .icon_free.if1 a
{
	color: #D51010;
	
}
.pop_login_area_pt2 .icon_free,
.pop_login_area_pt2 .icon_free a
{
	font-size: 14px;
	color: #143A31;
}

.pop_login_mb .icon_free,
.pop_login_mb .icon_free a
{
	font-size: 16px;
	color: #143A31;
}
.pop_login_mb .icon_free
{
	padding-right: 20px;
}


.widgetarea-mobile {
	position: absolute;
	top: 0px;
	z-index: 999;
}

.mb_menu_icon {
	height: 60px;
}
@media only screen and (max-width: 1120px) {
.pop_login_area_pt2 .boi-login-txt
{
display: none;
}
}
.stck-menu .icon_free {
	color: #FFFFFF;
	margin-top: 12px;
	margin-bottom: 10px;
	margin-left: 10px;
	display: block;
}
.stck-menu .icon_free .boi-icon-txt{
	font-family: "Main_Serif", "Noto Serif JP","メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	font-size: 15px;
	font-weight: bold;
	letter-spacing: 1px;
}

.pop_login_mbmenu .icon_free {
	color: #FFFFFF;
	margin-top: 8px;
	margin-left: 20px;
	display: inline-block;
}
.pop_login_mbmenu .icon_free a{
	font-size: 1.4em;
	color: #FFFFFF;
}


/*.icon_free=======================================*/


.page-title .nav-link-summary:before,
.page-title h1.entry-title:before,
h1.tokuh1:before,
#next_h1 h1:before{
	position: absolute;
	content: " ";
	display: block;
	width: calc(100% + 12px);
	height: calc(100% + 8px);
	z-index: -1;
	margin-left: -7px;
	left: 0px;
	top: -2px;
}





.wd-btn-show-cat.wd-action-btn a,
.wd-nav-product-cat .wd-action-btn.wd-style-text>a,
.page-title .nav-link-summary:before,
.page-title h1.entry-title:before,
h1.tokuh1:before,
#next_h1 h1:before,
.wd-nav-product-cat .shop-all-link a:before
{
background-color: rgba(255,255,255,.76);
box-shadow: 0 2px 8px rgba(0,0,0,.32);
}

.main_loop_back.type_post_view {
background-color: rgba(255,255,255,.98);
}
.page-template-page-contact-top-php .main_loop_back {
background-color: rgba(255,255,255,1);
}
.postid-19142 .website-wrapper,
.page-id-19105 .main_loop_back,
.page-id-13431 .main_loop_back,
.page-id-17996 .main_loop_back,
.search .main_loop_back,
.page-id-17350 .main_loop_back,
.page-id-7565 .main_loop_back,
.page-id-8792 .main_loop_back,
.page-id-16245 .main_loop_back,
.page-id-16045 .main_loop_back,
.page-id-16081 .main_loop_back,
.page-id-16076 .main_loop_back,
.page-id-13243 .main_loop_back,
.parent-pageid-13477 .main_loop_back,
.page-id-13477 .main_loop_back {
background-color: rgba(255,255,255,1);
}
.admin_news-template-default .main_loop_back,
.page-template-page-option-form .main_loop_back,
.page-template-page-post-form .main_loop_back {
background-color: rgba(255,255,255,1);
}


.sp_list {
	text-align: left;
	background-color: #FFFFFF;
	padding: 3px;
}
.mfp-content .sp_list {
padding: 25px;
}

.kojin_kojin {
	font-size: 16px;
	font-weight: bold;
	color: #003333;
	display: inline-block;
	padding-top: 3px;
	padding-bottom: 3px;
}


.subm_sticky_area .whb-sticky-prepared{
	padding: 0px;
}
.sticky-sticky {
	width: 100%;
	background-color: #990000;
}
.subm_sticky_area {
	position: absolute;
	width: 100%;
	top:110px;
	z-index:100;
}
.main-page-wrapper:has(.page-titleboi) .subm_sticky_area {
top: 250px;
}
.wd-sidebar-opener {
	top: 120px!important;
}


.pdf-wrap iframe{
  width:100%;
  height:1100px;
  border:0;
}

/* タブレット */
@media only screen and (max-width: 1024px) {
  .pdf-wrap iframe{
    height:900px;
  }
}

/* スマホ */
@media only screen and (max-width: 768px) {
  .pdf-wrap iframe{
    height:700px;
  }
}




.boi-pdf-viewer{
max-width:900px;
margin:auto;
}

.boi-pdf-page{
width:100%;
height:auto;
margin-bottom:20px;
box-shadow:0 2px 6px rgba(0,0,0,0.15);
}
.boi-pdf-thumb{
    width:200px;
    height:auto;
    margin:5px;
    border:1px solid #ddd;
    box-shadow:0 2px 4px rgba(0,0,0,0.1);
}


.list_m-net {
	padding-right: 15px;
	padding-left: 20px;
	padding-top: 15px;
	padding-bottom: 60px;
	font-size: 15px;
}
@media only screen and (max-width: 1024px) {
.list_m-net {
	padding-right: 5px;
	padding-left: 5px;
}
}
@media only screen and (max-width: 768px) {
.list_m-net {
	padding-right: 0;
	padding-left: 0;
}
}



.list_m-net dl {
	background-color: #F8F8F8;
	margin-bottom: 65px;
	margin-top: 8px;
	margin-left: 25px;
  display: flex;        /* 横並びにする */
  flex-wrap: wrap;      /* 複数行に対応させる */
  border-top: 1px solid #ccc;	
}
@media only screen and (max-width: 1320px){
.list_m-net dl {
	margin-left: 0;
	margin-right: 0;	
}
}





.list_m-net dt {
	width: 26%;           /* 見出しの幅 */
	box-sizing: border-box;
	color: #252525;
	font-weight: normal;
	margin: 0px;
	line-height: 1.3;
	padding-top: 5px;
	padding-right: 5px;
	padding-bottom: 5px;
	padding-left: 15px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	border-bottom-style: solid;
	border-left-style: solid;
	border-bottom-color: #ccc;
	border-left-color: #CCCCCC;
}
.list_title_date,
.list_title_mnet {
	display: inline-block;
}
.list_title_date {
	color: #003333;
	font-weight: bold;	
}
.list_title_mnet {
	padding-left: 1em;
}
.list_m-net dd {
	color: #252525;
	width: 74%;           /* 内容の幅 */
	margin: 0;            /* デフォルトの余白を消す */
	box-sizing: border-box;
	/* 前の質問の「リンク全画面」を合わせる場合 */
display: flex;        /* aタグを高さ一杯にするため */
	align-items: stretch;
	padding-left: 18px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	border-bottom-style: solid;
	border-left-style: solid;
	border-bottom-color: #ccc;
	border-left-color: #CCCCCC;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #CCCCCC;
	background-image: url(images/pdf30.png);
	background-size: 25px auto ;
	background-repeat: no-repeat;
	background-position: right 15px center;
	line-height: 1.3;	
}
.list_m-net dd:nth-of-type(odd) {
	background-color: #FEF9F7;
}
.list_m-net dd:nth-of-type(even) {
	background-color: #fdfdfd;
}

.list_desc_mnet {
	display: block;
	margin-right: 60px;
}
.list_m-net dd a {
	display: flex;
	align-items: center;  /* 文字を上下中央に */
	width: 100%;
	text-decoration: none;
}
/* スマホ */
@media only screen and (max-width: 768px) {

.list_m-net dt {
	width: 100%;           /* 見出しの幅 */
	padding-top: 15px;
	padding-right: 5px;
	padding-bottom: 15px;
	padding-left: 8px;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #CCCCCC;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #CCCCCC;
}
.list_m-net dd {
	width: 95%;
	background-position: right 3px center;
	margin-left: 5%;
	background-size: 20px auto;
	padding-left: 6px;
	margin-bottom: 3px;	
}
.list_m-net dd a{
}
.list_desc_mnet {
	margin-right: 20px;
	padding-top: 15px;
	padding-bottom: 15px;	
}
}

.mobile-nav-sp {
	height: 60px;
	display: block;
}
/* MAIN ハンバーガー */
.mbar-box {
	display: block;
	height: 32px;
	width: 32px;
	position: relative;
	vertical-align: middle;
	margin-bottom: 22px;
	color: #000000;
}
.sub-hum .mbar-box{
	height: 22px;
	width: 22px;
	margin-bottom: 22px;	
} 
.mbar-box:before {
    -webkit-transform: translate3d(0, 0, 0);
    -webkit-transition: all .35s ease-in-out;
	color: #000000;
    content: "";
    display: block;
    font-size: 14px;
    line-height: 32px;
    opacity: 0;
    text-align: center;
    width: 100px;
}
.sub-hum .mbar-box:before{
} 

.mbar-top {
    height: 4px;
    border-radius: 1px;
    left: 0;
    position: absolute;
    display: block;
    width: 100%;
    -webkit-transition: all .35s ease-in-out;
    top: 5px;	
    background-color: #000000;
	vertical-align: middle;
}
.sub-hum .mbar-top{
height: 4px;
top: 2px;
} 



.mbar-middle {
    height: 4px;
    border-radius: 1px;
    left: 0;
    position: absolute;
    display: block;
    width: 100%;
    -webkit-transition: all .35s ease-in-out;
    top: 50%;
	margin-top: -2px;	
    background-color: #000000;	
	vertical-align: middle;
}
.sub-hum .mbar-middle{
height: 4px;
top: 50%;
margin-top: -2px;
}
.mbar-bottom {
    height: 4px;
    border-radius: 1px;
    left: 0;
    position: absolute;
    display: block;
    width: 100%;
    -webkit-transition: all .35s ease-in-out;
    bottom: 5px;	
    background-color: #000000;	
	vertical-align: middle;
}
.sub-hum .mbar-bottom{
    height: 4px;
    bottom: 2px;
}
.wd-header-mobile-nav a:after {
   position: absolute;
    content: "MAIN\Aメニュー";
	white-space: pre; 	
    display: block;
    color: #000000;
    text-align: center;
    overflow: hidden;
    font-size: 13px;
    font-weight: bold;
    bottom: -1px;
    margin-right: auto;
    margin-left: auto;
    letter-spacing: normal;
    font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
	line-height: 1;	
}
.wd-header-mobile-nav a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 54px;
	color: #fff;
	border-radius: 6px;
	text-decoration: none;
	font-size: 18px;
	opacity: 0.80;
	transition: all 0.25s ease;
	background-color: #FFFFFF;
}
.wd-header-mobile-nav a{
    -webkit-transition: transform .4s cubic-bezier(0.215, 0.61, 0.355, 1);
    -moz-transition: transform .4s cubic-bezier(0.215, 0.61, 0.355, 1);
    -ms-transition: transform .4s cubic-bezier(0.215, 0.61, 0.355, 1);
    -o-transition: transform .4s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform .4s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.wd-header-mobile-nav {
	position: absolute;
	right: 0px;
	top: 3px;
}


.mobile-sticky-menus {
	position: absolute;
	right: 0px;
	top: 78px;
}
.sub-nonehref:after {
width:100%;
   position: absolute;
    content: "サイド";
	white-space: pre; 
    display: block;
    color: #000000;
    text-align: center;
    overflow: hidden;
    font-size: 13px;
    font-weight: normal;
    bottom: 10px;
    margin-right: auto;
    margin-left: auto;
    letter-spacing: normal;
    font-family: "Main_Gothic", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif!important;
}
.sub-nonehref.icon-fw:before {
    color: #333;
    font-size: 26px;
	top:7px;
    position: absolute;
	left:50%;
    margin-left:-12px;
}
.sub-nonehref {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 54px;
	color: #fff;
	border-radius: 10px 0 0 10px;
	text-decoration: none;
	font-size: 18px;
	opacity: 0.80;
	transition: all 0.25s ease;
	background-color: #FFFFFF;
	cursor: pointer;
	line-height: 1;
}

/* SUBボタン */
.sticky-sub-btn .sp-label {
    font-size: 10px;
    margin-top: 2px;
    line-height: 1;
}

/* SUB用サイドバー */
.sp-sidebar-overlay {
    position: fixed;
    top:0; left:0; width:100%; height:100%;
    background: rgba(0,0,0,0.7);
    opacity:0; visibility:hidden;
    transition: .3s;
    z-index: 9997;
}
.sp-sidebar-overlay.active {
    opacity:1;
    visibility: visible;
}
.sp-sidebar-panel {
    position: fixed;
    top:0; right:-320px;
    width: 300px;
    height: 100%;
    background: #fff;
    overflow-y: auto;
    transition: .3s;
    z-index: 9999998;
    box-shadow: -4px 0 10px rgba(0,0,0,.1);
}
.sp-sidebar-panel.active {
    right: 0;
}
.sp-sidebar-heading {
padding: 16px;
text-align: right;
}
.sp-sidebar-heading .wd-action-btn.wd-style-text>a {
    height: 25px;
}






.mobile-nav .searchform {
	margin-top: 3px;
	margin-right: 4px;
	margin-bottom: 20px;
	margin-left: 4px;
}
.mobile-nav .searchform input[type="text"] {
	height: 46px!important;
	border: 1px solid #000000!important;
	border-radius: 4px!important;
}
.mobile-nav .widgetarea-mobile {
	padding-top: 10px;
	padding-right: 5px;
	padding-bottom: 5px;
	padding-left: 5px;
}

/* ===========================================================================
   1. 変数定義（一括管理）
   =========================================================================== */
.und_mg_l {
	margin-bottom: 50px;
	padding-right: 5px;
}   
   
 :root {
  /* ヘッダーの高さを変数にしておくと管理が楽です */
  --header-h: 40px; /* 実際のヘッダーの高さに合わせて調整 */
}  
   
   
:root {
  --w-side: 220px;            /* サイドバーの幅 */
  --w-side-large: 300px;            /* サイドバーの幅 */  
  --w-container: 1320px;       /* 全体の最大幅 */
  --ingap: 30px;               /* サイドバーとメインの間隔 */
  --main-pd: 0 0 40px 0;       /* メインコンテンツの余白 */
  --bg-color:rgba(255, 255, 255, 0.7);         /* 背景色（白） */
  --fade-height: 30px;         /* サイドバー下部の消える演出の高さ */
}

/* ===========================================================================
   2. レイアウト土台
   =========================================================================== */
.l-container {
  display: flex;
  align-items: flex-start;    /* ★重要：高さを揃えず、上揃えにする（Stickyに必須） */
  max-width: var(--w-container);
  margin: 0 auto;
  gap: var(--ingap);
  width: 100%;
}

/* ===========================================================================
   3. 左サイドバー（画面固定・独立スクロール）
   =========================================================================== */
.l-sidebar {
  flex: 0 0 var(--w-side);
  width: var(--w-side);
  background: var(--bg-color);
  
  /* --- 画面内固定（Sticky）設定 --- */
  position: sticky;
  overflow-y: auto;           /* はみ出したらスクロール */
  /* --- スクロールバーを隠すマジックコード --- */
 /*  -ms-overflow-style: none;   /* IE, Edge */
  /* scrollbar-width: none;      /* Firefox */
    /* Firefox用：細くする */
  scrollbar-width: thin;
  /* バーの色を調整（つまみの色 / 背景の色） */
  scrollbar-color: #ccc transparent; 
}
.l-sidebar.is-large {
  flex: 0 0 var(--w-side-large);
  width: var(--w-side-large);
}

/* 通常時（アドミンバーなし）のサイドバー位置 */
.l-sidebar {
  top: calc(var(--header-h) + 20px); /* ヘッダー + 余白 */
  max-height: calc(100vh - var(--header-h) - 40px);
   padding: 0; /* 余白をゼロにして上端を詰める */ 
  /* ...その他の設定... */
}

/* ログイン時（アドミンバーがある時）の自動調整 */
/* WordPressはログイン中 body に .admin-bar クラスを付与します */
.admin-bar .l-sidebar {
  /* アドミンバーの高さ（--wd-admin-bar-h または 32px）をプラスする */
  top: calc(var(--header-h) + var(--wd-admin-bar-h, 32px) + 20px);
  max-height: calc(100vh - var(--header-h) - var(--wd-admin-bar-h, 32px) - 40px);
}




/* Chrome, Safari, Edge 用のスクロールバー非表示 */
/* .l-sidebar::-webkit-scrollbar {
  display: none;
} */
/* Chrome, Safari用：細くしてデザインを整える */
.l-sidebar::-webkit-scrollbar {
  width: 6px; /* バーの幅を細く */
}
.l-sidebar::-webkit-scrollbar-thumb {
  background-color: #ccc; /* つまみの色 */
  border-radius: 10px;    /* 角を丸く */
}
.l-sidebar::-webkit-scrollbar-track {
  background: transparent; /* バーの背景を透明に */
}

/* --- ふわっと消える演出（疑似要素） --- */
/* 注意：コンテンツの最後に配置されるため、スクロール末尾の演出になります */
/* --- 上端：ふわっと消える演出（新規追加） --- */
/* --- 上下共通：浮かせた配置の設定 --- */
/* --- 上下グラデーション共通（浮かせる設定） --- */
/* --- 上下グラデーション共通（張り付き設定） --- */
.l-sidebar::before,
.l-sidebar::after {
  content: "";
  position: sticky; /* ★ absoluteではなくstickyで「枠」に固定 */
  left: 0;
  width: 100%;
  height: var(--fade-height);
  display: block;   /* stickyを効かせるためにblockに */
  z-index: 10;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

/* 上端：サイドバーのトップに張り付く */
.l-sidebar::before {
  top: 0; 
  margin-bottom: calc(var(--fade-height) * -1); /* ★重要：自身の高さ分、中身を上に引き戻して余白を消す */
  background: linear-gradient(to bottom, var(--bg-color), rgba(255, 255, 255, 0));
}

/* 下端：サイドバーのボトムに張り付く */
.l-sidebar::after {
  bottom: 0;
  margin-top: calc(var(--fade-height) * -1);    /* ★重要：自身の高さ分、中身を下に引き戻して余白を消す */
  background: linear-gradient(to top, var(--bg-color), rgba(255, 255, 255, 0));
}
/* --- 表示制御 --- */
.l-sidebar.is-scrolled::before { opacity: 1; }
.l-sidebar:not(.is-bottom)::after { opacity: 1; }

/* ===========================================================================
   4. メインコンテンツ
   =========================================================================== */
.l-main {
  flex: 1;
  min-width: 0;               /* フレックスアイテムの突き抜け防止 */
  padding: var(--main-pd);
}

/* ===========================================================================
   5. 自動判別・特殊レイアウト（bodyクラス連動）
   =========================================================================== */

/* フルワイド時：サイドバーがない場合、メインを中央寄せにするなど */
body.is-full .l-main {
  max-width: 1320px;          /* 読みやすい幅に制限（任意） */
  margin: 0 auto;
}

/* サイドバーの中身が空、または非表示の時の保険 */
.l-sidebar:empty {
  display: none;
}

/* ===========================================================================
   6. スマホ対応 (1024px以下)
   =========================================================================== */
@media (max-width: 1024px) {
  .l-container {
    display: block;           /* Flexを解除して縦並び（または通常の流れ）に */
    padding: 0;
    gap: 0;
  }

  .l-sidebar {
    position: static;         /* 固定を解除 */
    width: 100%;
    max-height: none;
    overflow-y: visible;
    display: none;            /* PHP側で消しきれなかった場合も考慮して非表示 */
  }

  .l-main {
    width: 100%;
    padding: 0 !important;
    order: -1;                /* メインを優先的に上に（display: flex時のみ有効） */
  }
}
.staff_side {
	padding-top: 10px;
}



/* --- 基本設定 --- */
.fl-container {
  display: flex;
  width: 100%;
  box-sizing: border-box; /* パディングを含めて100%にする */
  padding: 0;        /* 【両端】5pxの余白 */
  gap: 26px;             /* 【中央】10pxの隙間 */
}

/* --- 比率のパターン定義 --- */
/* 中央の隙間(10px)を引いた残りを比率で分けます */
.ratio-40-60 .left-block  { width: calc(40% - 6px); } /* 10pxの40%分(4px)を引く計算に近い数値 */
.ratio-40-60 .right-block { width: calc(60% - 4px); }

.ratio-50-50 .left-block  { width: calc(50% - 5px); }
.ratio-50-50 .right-block { width: calc(50% - 5px); }

.ratio-60-40 .left-block  { width: calc(60% - 5px); }
.ratio-60-40 .right-block { width: calc(40% - 5px); }

/* --- レスポンシブ (1024px以下) --- */
@media (max-width: 1024px) {
  .fl-container {
  /*flex-direction: column-reverse; /* 縦並び・下を上に */
    flex-direction: column;　　　　 /* 縦並び・上から下に */
    padding: 0;                     /* 【ブレーク後】左右マージン(パディング)なし */
    gap: 20px;                      /* 【上下のあいだ】15pxあける */
  }

  .fl-item {
    width: 100% !important;         /* 横幅いっぱい */
    margin: 0;                      /* マージンなし */
  }
}


.postlist_first {
width: 100%;
padding-top: 0px;
}
.postlist_first .new_hover_into_img img {
    max-height: 840px;
}

 
.postlist_first .block_bpdf_thum{
    justify-content: center;
    align-items: center;
}
.postlist_other {
    width: calc(100% / 3);
    float: left;
    padding-top: 30px;
    padding-right: 5px;
    padding-bottom: 30px;
    padding-left: 5px;
}
.postlist_other .block_bpdf_thum{
    min-height: 340px;
    max-height: 340px;	
    display: flex;
    justify-content: center;
    align-items: center;	
}
@media (max-width: 1024px) {
.postlist_other {
    width: calc(100% / 2);
}
}
@media (max-width: 768px) {
.postlist_other {
    width: calc(100% / 1);
}
}



.semi_first_left,
.semi_first_right
{
	padding-top: 15px;
}




.user-lg-edit {
	text-align: right;
}

.type_admin_view .media-modal-close
{
    position: absolute;
    top: 0;
    right: 0;
    width: 50px;
    height: 50px;
    margin: 0;
    padding: 0;
    border: 1px solid transparent;
    background: 0 0;
    color: #646970;
    z-index: 1000;
    cursor: pointer;
    outline: 0;
    transition: color .1s ease-in-out,background .1s ease-in-out
}

.type_admin_view .media-router {
    position: relative;
    padding: 0 6px;
    margin: 0;
    clear: both
}
.type_admin_view .media-router .media-menu-item:last-child {
    border-right: 0
}
.type_admin_view .media-router .media-menu-item:active,
.type_admin_view .media-router .media-menu-item:hover {
    color: #2271b1
}

.page-template-page-paget-form .media-router .active,
.type_admin_view .media-router .active:hover {
    color: #1d2327
}
.type_admin_view .media-router .media-menu-item:focus {
    box-shadow: 0 0 0 2px #2271b1;
    color: #043959;
    outline: 2px solid transparent;
    z-index: 1
}
.type_admin_view .media-router .active,
.type_admin_view .media-router .media-menu-item.active:last-child {
    margin: -1px -1px 0;
    background: #fff;
    border: 1px solid #dcdcde;
    border-bottom: none
}
.type_admin_view .media-router .active:after {
    display: none
}
.type_admin_view .media-router button {
    min-height:inherit!important;
}
.type_admin_view .media-modal-content h1 {
	min-height:inherit!important;
	background-color: #FFFFFF!important;
	border: none!important;
}



.sidebar-content .side-std {
	padding-right: 10px;
	padding-left: 10px;
}


:root {
    --main-green: #007b43;
    --dark-green: #005a32;
    --light-green: #f0f9f4;
    --light-gray: #f8f9fa;
    --accent-gold: #d4af37;
}

  .table-responsive-container {
    width: 100%;
    margin: 30px 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  }

  .premium-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    min-width: 850px;
    background: #fff;
  }

  /* ヘッダー全体 */
  .premium-table th {
    background: linear-gradient(135deg, var(--dark-green), var(--main-green));
    color: #fff;
    padding: 18px 15px;
    font-weight: 600;
    border: 0.5px solid rgba(255,255,255,0.1);
    letter-spacing: 0.05em;
  }

  /* 区分ラベル列（一番左） */
  .label-column {
    background-color: var(--dark-green) !important;
    color: #fff !important;
    text-align: center;
    font-weight: bold;
    width: 130px;
  }

  /* セル共通 */
  .premium-table td {
    padding: 20px 15px;
    border-bottom: 1px solid #eee;
    border-right: 1px solid #eee;
    font-size: 15px;
    line-height: 1.7;
    color: #333;
    vertical-align: middle;
  }

  /* 列の背景色分け */
  .col-regular { background-color: var(--light-green); } /* 正会員エリア */
  .col-general { background-color: var(--light-gray); }  /* 一般会員エリア */

  /* 要件テキスト（左寄せ） */
  .req-text {
    text-align: left;
    font-size: 15px;
  }

  /* 金額・表決権（中央寄せ） */
  .center-align { text-align: center; }

  .price-tag {
    font-size: 18px;
    font-weight: 800;
    color: var(--dark-green);
    display: block;
  }

  .price-sub {
    font-size: 14px;
    color: #444;
    display: block;
    margin-top: 5px;
  }

  /* 有・無のバッジ風 */
  .badge {
    display: inline-block;
    padding: 6px 16px;
    border-radius: 50px;
    font-weight: bold;
    font-size: 14px;
  }
  .badge-yes {
    background: var(--main-green);
    color: #fff;
    box-shadow: 0 3px 6px rgba(0,123,67,0.2);
  }
  .badge-no {
    background: #bbb;
    color: #fff;
  }

  /* ホバー時の挙動 */
  .premium-table tbody tr:hover td {
    filter: brightness(0.98);
  }

  /* スマホ用のスクロールバー表示（任意） */
  .table-responsive-container::-webkit-scrollbar { height: 6px; }
  .table-responsive-container::-webkit-scrollbar-thumb { background: #ccc; border-radius: 10px; }


  /* 全体のレイアウト */
  .org-container {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    justify-content: center;
    align-items: flex-start;
    margin: 20px auto;
    max-width: 1000px;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  }

  /* 画像のレスポンシブ設定 */
  .org-image {
    flex: 1;
    min-width: 300px;
    max-width: 500px;
  }
  .org-image img {
    width: 100%;
    height: auto;
    display: block;
  }

  /* テーブルのスタイル */
  .org-table-wrapper {
    flex: 1;
    min-width: 320px;
  }
  .business-table {
    width: 100%;
    border-collapse: collapse;
    border-top: 2px solid #333;
    border-bottom: 2px solid #333;
    font-size: 0.95rem;
  }
  .business-table th {
    background-color: #f2f2f2;
    color: #333;
    font-weight: bold;
    padding: 12px 10px;
    border-bottom: 1px solid #ccc;
    text-align: center;
    white-space: nowrap;
  }
  .business-table td {
    padding: 10px;
    border-bottom: 1px solid #eee;
    color: #444;
  }
  /* 空白行の調整 */
  .spacer-row td {
    padding: 5px;
    border: none;
  }
  /* 列ごとの調整 */
  .col-pos { text-align: left; background-color: #fafafa; font-weight: 500; }
  .col-name { text-align: left; }
  .col-pay { text-align: center; color: #666; }

  /* スマホ表示での調整 */
  @media (max-width: 768px) {
    .org-container { flex-direction: column; align-items: center; }
    .org-table-wrapper { width: 100%; }
    .business-table { font-size: 0.85rem; }
  }

  /* 共通のコンテナ設定（前のコードと共存可能） */
  .info-table-wrapper {
    width: 90%; /* 横幅を広めに使用 */
    max-width: 1200px;
    margin: 40px auto;
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  }

  /* テーブルのスタイル（ビジネスライク） */
  .modern-business-table {
    width: 100%;
    border-collapse: collapse;
    border-top: 3px solid #333; /* 上部は少し太めに */
    border-bottom: 2px solid #333;
    line-height: 1.6;
  }

  .modern-business-table th {
    background-color: #f2f2f2; /* 薄いグレーで統一感 */
    color: #333;
    padding: 15px;
    border-bottom: 1px solid #ccc;
    text-align: left;
    font-weight: bold;
    font-size: 1rem;
  }

  .modern-business-table td {
    padding: 15px;
    border-bottom: 1px solid #eee;
    vertical-align: middle;
    color: #444;
  }

  /* 「役員・職員」列の強調 */
  .col-title {
    width: 25%; /* 横幅に余裕を持たせる */
    background-color: #fafafa;
    font-weight: bold;
    color: #222;
    border-right: 1px solid #eee;
  }

  /* 「職務」列 */
  .col-desc {
    width: 75%;
    text-align: left;
  }

  /* スマホ表示での調整 */
  @media (max-width: 600px) {
    .info-table-wrapper { width: 100%; }
    .modern-business-table th, .modern-business-table td {
      padding: 10px;
      font-size: 0.9rem;
    }
    .col-title { width: 35%; }
  }

/*========catemix swiper==============*/



.catemix {
width: 100%;
margin-right: auto;
margin-left: auto;
}
.catemix .swiper-container.sw_vert {
height:218px;
position:inherit;
margin-bottom:36px!important;
text-align:left ;
overflow: hidden;
}
.into-slide-img {
    height: 94px;
    overflow: hidden;
}
/* ===== コンテナ高さ（ここだけ管理） ===== */

.swiper-container-vertical > .swiper-wrapper {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
}
/* ===== スライド高さは書かない！ ===== */
.sw_vert .swiper-slide {
    box-sizing: border-box;
}

/* ===== 中身 ===== */
.into-slide {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.into-slide {
    margin: 2px;
    border: 1px solid #DDD;
    height: 98px;
    position: relative;
}
.catemix .swiper-container.sw_vert .swiper-wrapper{
	position:inherit;
}
.swiper-container.sw_vert .swiper-slide{
	overflow: hidden;
	border: 1px solid #CCC;
	background-color: #FFFFFF;
	border-radius:3px;
}
.swiper-slide .catemix_box img  {
	box-shadow :none;
	opacity:1!important;
}
.cm_img_into  {
	border: 1px solid #ddd;
	padding: 2px;
	margin-top: 2px;
	margin-right: 2px;
	margin-bottom: 0px;
	margin-left: 2px;
}
.cm_date{
	font-size: 12px;
	letter-spacing: normal;
	line-height: 1.2;
	display: inline-block;
}
.cm_desc{
	float: right;
	width: calc(100% - 102px);
	margin-top: 2px;
	margin-right: 2px;
}
.cm_blog_cate span[class^="blog_cate_"] {
	font-size: 10px;
	letter-spacing: normal;	
	display: block;
	padding-top: 1px;
	padding-right: 2px;
	padding-bottom: 1px;
	padding-left: 2px;
	text-align:center;
}
.cm_desc_title{
	overflow: hidden;
	font-size: 12px;
	line-height: 1.4;
	text-align: left;
	padding-top: 2px;
	padding-right: 2px;
	padding-bottom: 2px;
	padding-left: 4px;
}
.catemix img {
	max-width: 92px;
	background-color: #FFFFFF;
	margin: 2px;
	padding: 2px;
	border: 1px solid #CCC;
	opacity:1!important;	
}
.catemix .date_info {
	display: block;
	position: absolute;
	right: 3px;
	top: 0px;
}
.catemix .cate_tbox {
	display: inline-block;
	position: absolute;
	left: 98px;
	top: 0;
}
.into-desc{
	display: inline-block;

}
.into-desc{
	color: #333;
}

.into-desc-tate {
	display: inline-block;
	position: absolute;
	left: 104px;
	top: 49px;
	font-size: 12px;
	line-height: 1.2;
	padding-right: 2px;
}
.into-desc-tate a{
	color: #333;
}
.into-wrap-price {
	display: block;
	position: absolute;
	right: 2px;
	bottom: 1px;
	font-size: 13px;
}
.into--price {
display: flex;
align-items: center;
flex-wrap: wrap;
justify-content: flex-end;
}
.into--price .cs-price .amount{
	font-size: 13px!important;
}

.into--price .shops2{
	font-size: 12px
}
.sw-gogo {
	position: absolute;
	z-index: 22;
	margin-top: 6px;
}
/*========catemix swiper==============*/
.tokub h4.banner-title {
	margin-left: 20px!important;
}
div#n2-ss-68 .n2-ss-slider-2 {
box-shadow: 0 1px 8px rgba(0,0,0,.1)!important;
}
@media only screen and (max-width: 1200px){
.whb-6nk5k6r8rdjvgaatz6fz {
	display: none!important;
}
}
#pdf_catch {
height: 80vh;
}
.top_event_dark {
color:#fff!important;
}
.top_event_dark .ad_ad_area a,
.top_event_dark .ad_ad_area {
	color: #FFFFFF;
} 
.ttt_list {
	position: relative;
	background-color: rgba(255,255,255,1);
	margin-right: auto;
	margin-left: auto;
	padding-top: 6px;
	padding-right: 8px;
	padding-bottom: 5px;
	padding-left: 10px;
	box-shadow: 0 1px 8px rgba(0,0,0,.12);
	border-radius:5px;
	width: 560px;
	max-width:98%;
	text-align: left;
}
.top_event_into{
	text-align: left;
	vertical-align: top;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #CCCCCC;
	border-right-color: #CCCCCC;
	border-bottom-color: #CCCCCC;
	border-left-color: #CCCCCC;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	padding-top: 4px;
	padding-bottom: 4px;
	padding-right: 5px;
	position: relative;
}
.top_event_into span{
	vertical-align: top	;
	line-height: 1.2;
}
.top_event_into .cate_tbox{
	position: absolute;
	left: 40%;
	top: 2px;	
}
.top_event_into .date_info{
	position: absolute;
	top: -2px;
	right: 2px;
	color: #666666;
}
.top_event_into .nc_title a{
	color: #006699;
	display: block;
	font-size: 14px;
	line-height: 1.3;
}
.top_event_title {
    background-color: #669966;
    color: #ffffff;
    display: inline-block!important;
    margin-left: 4px;
    margin-right: 2px;
    border-radius: 5px;
    font-size: 13px!important;
    line-height: 12px!important;
    padding-top: 5px;
    padding-right: 8px;
    padding-bottom: 5px;
    padding-left: 8px;	
}
.top_event_title.t_semi {
    background-color: #0099CC;
}
.flex2 {
  display: flex;                /* Flexboxを有効化 */
  justify-content: center;      /* 左右の中央に配置 */
  align-items: center;          /* 上下（縦）の中央に配置 */
  gap: 5px;                    /* 左右のボックスの間を空ける（20pxの例） */
  padding: 5px;
}

.flex2.evt {
  display: flex;                /* Flexboxを有効化 */
  justify-content: center;      /* 左右の中央に配置 */
  align-items: flex-start;      /* 上下（縦）の中央に配置 */
  gap: 5px;                    /* 左右のボックスの間を空ける（20pxの例） */
  padding: 5px;
}







.fl_fst {
  width: 120px;
  flex-shrink: 0;
  /* 中央寄せの設定を追加 */
  display: flex;
  justify-content: center; /* 水平方向の中央 */
  align-items: center;     /* 垂直方向の中央 */
  background: #f0f0f0;    /* 背景色（確認用） */
}
.fl_fst img {
	background-color: #FFFFFF;
	padding: 2px;
	border: 1px solid #CCCCCC;
	max-height: 100px;
	margin-right: auto;
	margin-left: auto;
	max-height: 100px;
  max-width: 100%;         /* 画像が枠からはみ出ないように */
  height: auto;            /* アスペクト比を維持 */	
}
.fl_2st {
	width: 100%;
}


.tt_sd {
	background-image: url(images/paste_20.png);
	background-repeat: no-repeat;
	background-position: left top;
	padding-left: 24px;
}
.into-desc{
	padding-left: 2px;
}
.into-desc a {
	font-size: 14px;
	display: block;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #CCCCCC;
	margin-top: 4px;
	padding-top: 3px;
	line-height: 1.4;
}
@media only screen and (max-width: 750px){
.top_event_into{
	letter-spacing:normal;
}
.fl_fst {
  width: 90px;
}
}


@media only screen and (max-width: 650px){
.top_event_title {
    font-size: 12px;
    padding-top: 6px;
    padding-bottom: 6px;
    padding-left: 8px;
	padding-right: 8px;
}
.top_event_into .nc_title a{
    font-size: 13px;
	line-height: 1.2;	
}
.into-desc a {
	font-size: 12px;
}
.top_event_into .cate_tbox {
display:none;
}
.top_event_into{
	letter-spacing:
}
.ttt_list {
    padding-left: 2px;
	padding-right: 2px;
}
.tt_sd {
padding-left:21px;
}
}


.box_yotei_list {
	margin-left: 8px;
	margin-top: 5px;
}
.box_yotei_list_title a{
	font-size: 15px;
	color: #003366;
	font-weight: bold;
}
.box_yotei_tpright {
	display: block;
	text-align: right;
}
.yotei-label,
.yotei-data {
	font-size: 15px;
}
.top_event {
	padding-bottom: 20px;
}
.box_yotei_list_title{
	display: block;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #0099CC;
}
.box_yotei_list_title a{
	font-size: 15px;
	color: #003366;
	font-weight: bold;
	display: block;
	padding-top: 2px;
	padding-bottom: 2px;
	padding-left: 4px;
}
.box_yotei_list_title .fa{
	color: #CC0000;
}
.flex2.evt .tt_sd {
	background-image: none;
	padding-left: 0;	
}
.box_yotei_tm{
background-image: url(images/16.png);
	background-repeat: no-repeat;
	background-position: left top;
	padding-left: 24px;
    margin-top: 2px;
    margin-bottom: 4px;
	display: block;	
	font-size: 14px;		
}
.box_yotei_date {
	background-image: url(images/clock_16.png);
	background-repeat: no-repeat;
	background-position: 2px 1px;
	padding-left: 24px;
    margin-top: 2px;
    margin-bottom: 4px;
	display: block;	
	font-size: 14px;
}
.yotei_kai{
background-image: url(images/180.png);
	background-repeat: no-repeat;
	background-position: 1px top;
	padding-left: 24px;
    margin-top: 2px;
    margin-bottom: 4px;
	display: block;
	font-size: 14px;
}
.link-go {
	position: absolute;
	z-index: 10;
	right: 2px;
	bottom: 3px;
}
.top_int {
	text-align: right;
	line-height: 2.0;
	padding-right: 5px;
	font-size: 14px;
}
.top_int .icon_free{
	text-align: right;
}
.top_int .icon_free_fw {
	color: #006633;
}
@media only screen and (max-width: 500px){
.top_int {
	padding-right: 0;
	font-size: 13px;	
}
}

