@charset "UTF-8";
/*
Theme Name:hayashi-cl
Version:2.2.2
*/
/* ========================================================================== Foundation ========================================================================== */
/* Reset  ----------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; font-weight: normal; vertical-align: baseline; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }

audio, canvas, video { display: inline-block; max-width: 100%; }

html { overflow-y: scroll; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

ul, ol { list-style: none; }

blockquote, q { quotes: none; }

blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }

a:focus { outline: none; }

ins { text-decoration: none; }

mark { font-style: italic; font-weight: bold; }

del { text-decoration: line-through; }

abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; }

table { border-collapse: collapse; border-spacing: 0; width: 100%; }

hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; }

button, input, select, textarea { outline: 0; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; font-size: 100%; }

input, textarea { background-image: -webkit-linear-gradient(rgba(255, 255, 255, 0), rgba(255, 255, 255, 0)); -webkit-appearance: none; border-radius: 0; /* Removing the inner shadow, rounded corners on iOS inputs */ }

input[type="checkbox"] { -webkit-appearance: checkbox; }

input[type="radio"] { -webkit-appearance: radio; }

button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; }

img { -ms-interpolation-mode: bicubic; }

/* clearfix */
.clearfix:after { content: "."; display: block; clear: both; height: 0; font-size: 0.1em; line-height: 0; visibility: hidden; overflow: hidden; }

.clearfix { display: inline-block; }

/* exlude MacIE5 \*/
* html .clearfix { height: 1%; }

.clearfix { display: block; }

/* end MacIE5 */
/* Base ----------------------------------------------------------------- */
body {
    background: #fff;
    color: #333;
    line-height: 1.8;
    letter-spacing: 0.05em;
    -webkit-font-smoothing: antialiased;
    font-size: calc(17 / 1920* 100vw);
    font-family: dnp-shuei-gothic-gin-std, sans-serif;
}

a { color: #000; text-decoration: none; }

b, strong { font-weight: 700; }

big { font-size: larger; }

small { font-size: 80%; }

sub { vertical-align: sub; font-size: smaller; }

sup { vertical-align: super; font-size: smaller; }

i, cite, em, var, address, dfn { font-style: italic; }

tt, code, kbd, samp { font-family: monospace; }

u, ins { text-decoration: underline; }

img {
    vertical-align: bottom;
    width: 100%;
    height: auto;
}

input { border: 0; margin: 0; padding: 0; }

select { background: none transparent; border: 0; border-radius: 0; margin: 0; padding: 0; -moz-appearance: none; -webkit-appearance: none; appearance: none; }



/**************************
フォント調整
**********************************************************************************/

@media (min-width: 1401px) and (max-width: 1599px){
	body {
		font-size: calc(17 / 1599 * 100vw);}
	}
	
	@media (min-width: 1200px) and (max-width: 1400px){
	body {
		font-size: calc(17 / 1400 * 100vw);}
	}
	
	@media (min-width: 1001px) and (max-width: 1199px){
	body {
		font-size: calc(16 / 1199 * 100vw);}
	}
	
	@media (min-width: 768px) and (max-width: 1000px){
	body {
		font-size: calc(16 / 1000 * 100vw);}
	}
	
	@media only screen and (max-width: 767px) {
		body {
			font-size: 4vw}
	}



/* for IE */
select::-ms-expand { display: none; }

a, a:before, a:after, input { -moz-transition-property: background-color, color; -moz-transition-duration: 0.2s; -moz-transition-timing-function: ease; -o-transition-property: background-color, color; -o-transition-duration: 0.2s; -o-transition-timing-function: ease; -webkit-transition-property: background-color, color; -webkit-transition-duration: 0.2s; -webkit-transition-timing-function: ease; transition-property: background-color, color; transition-duration: 0.2s; transition-timing-function: ease; }

/* infinite scroll */
#infscr-loading { color: #525252; font-size: 14px; text-align: center; width: 100%; }
#infscr-loading img { margin-right: 8px; vertical-align: middle; }
#infscr-loading div { display: inline; }

/* -------------------------------------------------------------------------------- web fonts　ウェブフォントファイルを変更した場合はv=1.0の数字を変更（キャッシュ対策）
-------------------------------------------------------------------------------- */
@font-face { font-family: "design_plus"; src: url("fonts/design_plus.eot?v=1.0"); src: url("fonts/design_plus.eot?v=1.0#iefix") format("embedded-opentype"), url("fonts/design_plus.woff?v=1.0") format("woff"), url("fonts/design_plus.ttf?v=1.0") format("truetype"), url("fonts/design_plus.svg?v=1.0#design_plus") format("svg"); font-weight: normal; font-style: normal; }
@font-face {
  font-family: 'design_plus_new';
  font-weight: normal;
  font-style: normal;
  font-display:swap;
  src: url('fonts/design_plus_new.woff?v=1.0') format('woff');
}

@font-face {
	font-family: 'tiktok_x_icon';
	src: url('fonts/tiktok_x_icon.eot?v=1.0');
	src: url('fonts/tiktok_x_icon.eot?v=1.0#iefix') format('embedded-opentype'),
		 url('fonts/tiktok_x_icon.woff?v=1.0') format('woff'),
		 url('fonts/tiktok_x_icon.ttf?v=1.0') format('truetype'),
		 url('fonts/tiktok_x_icon.svg?v=1.0#tiktok_x_icon') format('svg');
	font-weight: normal;
	font-style: normal;
  }
/* -------------------------------------------------------------------------------- keyframes
-------------------------------------------------------------------------------- */
/* fadeIn */
@-webkit-keyframes fadeIn { from { opacity: 0; }
  to { opacity: 1; } }
@keyframes fadeIn { from { opacity: 0; }
  to { opacity: 1; } }
/* loading-anime */
@-webkit-keyframes loading-anime { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@keyframes loading-anime { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
/* slideDown */
@-webkit-keyframes slideDown {
  0% { /*top: -70px;*/ transform: translate3d(0,-100%,0); }
  100% { /*top: 0;*/ transform: translate3d(0,0,0); }
}
@keyframes slideDown {
  0% { /*top: -70px;*/ transform: translate3d(0,-100%,0); }
  100% { /*top: 0;*/ transform: translate3d(0,0,0); }
}
/* ========================================================================== Layout ========================================================================== */
/* Footer ----------------------------------------------------------------- */
.l-footer {
    background: url(/wp-content/uploads/haikei_05.jpg) center no-repeat;
    padding-top: 32px;
    background-size: cover;
    position: relative;
}
.l-footer:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    background: rgb(30 143 127 / 90%);
    top: 0;
    left: 0;
}
.l-footer__inner { padding: 50px 0 100px; }
.w-inner {
    width: 90%;
    margin: 0 auto;
}
.l-footer__logo { margin-bottom: 32px; text-align: center; }
.l-footer__logo a { display:inline-flex; }
.l-footer__logo.footer_logo_retina img { width:50%; margin:auto; }

.sec_footer {
    background: #F1F8F2;
    padding: 80px 0;
    position: relative;
}
.info_ul {
    width: 100%;
    position: relative;
    display: table;
    margin: 0 auto 50px;
}
.infoli_left {
    width: 45%;
    float: left;
    position: relative;
}
.infoli_right {
    float: left;
    position: relative;
    width: 50%;
    margin: 0 0 0 5%;
}
.f_logo {
    width: 70%;
    margin: 0 0 20px;
}

.access_txt {
    margin-bottom: 5px;
}
span.boi_spa {
    font-size: 120%;
    font-weight: 600;
    line-height: 1;
    margin: 0 1px;
    color: #8a1616;
}
.inf_txt {
    margin-bottom: 10px;
}
.sec_footer .time_txt, .sec_footer .time_txt01{
	    text-align: left;
}

.info_flexbll {
    display: table;
    position: relative;
    width: 100%;
    margin: 30px auto 0;
}
.info_flexcon {
    width: 50%;
    float: left;
    position: relative;
}
.btn_02 a {
    position: relative;
    display: block;
    text-align: center;
    background: #46baaa;
    color: #fff;
    border-radius: 100px;
    padding: 12px 0;
    font-size: 100%;
    font-weight: 600;
    transition: all 0.3s ease 0s;
}

.btn_02 a:hover{
	opacity:0.7
}

.btn_02 {
    width: 90%;
    margin: 0 auto;
    position: relative;
    max-width: 280px;
}
.btn_02 a:before {
    position: absolute;
    content: "";
    background: url(/wp-content/uploads/arrow_01.svg) center no-repeat;
width: 11%;
    height: 100%;
    top: 0;
    right: 5%;
    background-size: contain;
}
.fc_ttl:before {
    position: absolute;
    content: "";
    width: 100%;
    border-top: solid 1px #c3c3c3;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 50%;
}

.fc_ttl span {
    background: #f1f8f2;
    padding: 0 37px;
    z-index: 1;
    position: relative;
}
.fc_ttl {
    font-size: 130%;
    font-family: 'Shippori Mincho B1', serif !important;
    text-align: center;
    position: relative;
    line-height: 1;
    margin-bottom: 30px;
}
.f_contact_flex {
    display: table;
    position: relative;
    width: 100%;
    margin: 50px auto 0;
}
.f_contact_inner {
    position: relative;
    margin: 0 auto;
    width: 90%;
    max-width: 1100px;
}
.f_contact_flex_con {
    width: 50%;
    float: left;
    position: relative;
}
.hsr_tel a img, .hsr_web a img {
    max-height: 30px;
}
.hsr_web a {
    position: relative;
    display: block;
    text-align: center;
    background: #6d4747;
    padding: 20px 0;
    transition: all 0.3s ease 0s;
    border-radius: 100px;
}
.hsr_web {
    width: 90%;
    margin: auto;
    max-width: 360px;
    position: relative;
}
.hsr_tel a {
    position: relative;
    display: block;
    text-align: center;
    background: #46baaa;
    padding: 20px 0;
    transition: all 0.3s ease 0s;
    border-radius: 100px;
}
.hsr_tel {
    width: 90%;
    margin: auto;
    max-width: 360px;
    position: relative;
}

.hsr_tel a:hover, .hsr_web a:hover{
	opacity:0.7;
}




/* custom_footer_bar*/
#custom_footer_bar {
    width: calc(100% - 55px);
    margin: 0 auto 0 0;
    left: 0;
    position: fixed;
    bottom: 0;
    background: #0077c9;
    z-index: 9999;
}
#custom_footer_bar li img {
    height: 34px;
}

#custom_footer_bar li {
    float: left;
}
.cfb_left {
    width: 45%;
}
.cfb_right_r {
    width: 55%;
}

#custom_footer_bar ul {
    width: 100%;
    position: relative;
    display: table;
}
.cfb_left a {
    padding: 16px 0px 17px;
    background: #4aa48c;
}
#custom_footer_bar li a {
    display: block;
    position: relative;
    line-height: 1;
}
.cfb_right_r a {
    background: #6d4747;
    padding: 12px 0px 9px;
}
.cfb_left img { height: 22px !important;}

.cfb_center a {
    padding: 14px 0px 13px;
    background: #c3527c;
}

@media only screen and (min-width:768px) {
	#custom_footer_bar{display:none}
}


/* Header ----------------------------------------------------------------- */
.l-header { background:#fff !important ; height: 103px; line-height: 103px; width: 100%; position: relative; z-index: 999; }
.l-header.is-fixed { position: relative; top: 0; }
.l-header.is-active { height: 70px; line-height: 70px; position: fixed; top: 0; left: 0; -webkit-animation: slideDown 0.5s ease; animation: slideDown 0.5s ease; box-shadow: 0px 0px 10px #ddd;}
.l-header.is-fixed.is-active { top:0 !important; }
.l-header.is-fixed.is-active.is-mobile-fix { animation:none; position:sticky; }

.l-header--large { height: 103px; line-height: 103px; position: relative; top: 0; left: 0; z-index: 999; }

.l-header__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: 0 0 0 auto;
    position: relative;
    height: 100%;
    width: 100%;
}

.l-header__logo {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    top: 0;
    left: 0;
    width: 20%;
    background: #46BAAA;
}
.l-header__logo a {
    line-height: 1;
    align-items: center;
    overflow: hidden;
    word-wrap: break-word;
    padding: 40px 6% 41px;
    margin: 0 auto;
    width: 100%;
    text-align: center;
}
.l-header__logo a span {
    color: #fff;
    font-size: 0.8vw;
    border-top: solid 1px #fff;
    border-bottom: solid 1px #fff;
    position: relative;
    display: block;
    padding: 10px;
    margin-top: 25px;
    letter-spacing: 0.1em;
}
.l-header__logo img { vertical-align: middle; }

.l-header__logo--text a { width: 200px; }

.l-header__logo--retina img { width: 50%; }




/* Inner ----------------------------------------------------------------- */
.l-inner { margin-left: auto; margin-right: auto; position: relative; width: 88.28125%; max-width: 1130px; }

.l-inner--narrow { width: 79.64602%; max-width: 900px; }

/* Main ----------------------------------------------------------------- */
/* Sidebar ----------------------------------------------------------------- */
/* ========================================================================== Object ========================================================================== */
/* Component ----------------------------------------------------------------- */
.c-breadcrumb__item { display: inline; }
.c-breadcrumb__item + .c-breadcrumb__item::before { content: "\e910"; color: #6b5252; font-family: "design_plus"; margin-left: 12px; margin-right: 12px; }

.c-breadcrumb__item--home a { color: #6b5252; }


 /**
	* header video
	*/
.c-header-video { background: #000; background-position: center center; background-repeat: no-repeat; background-size: cover; position: relative; width: 100%; }

.c-header-video__overlay { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; z-index: 2; }
#js-header-video video { width:100%; height:100%; position:absolute; top:0; left:0; object-fit:cover; }

 /**
	* header youtube
	*/
.c-header-youtube { background: #000; background-position: center center; background-repeat: no-repeat; background-size: cover; position: relative; width: 100%; }

.c-header-youtube__overlay { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; z-index: 2; }

/* ヘッダー動画時キャッチコピー */
.p-header-video, .p-header-video .vegas-wrapper, .p-header-youtube { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; justify-content: center; }

.p-header-video .caption, .p-header-youtube .caption { text-align: center; width: calc(100% * 1150 / 1280); max-width: 1150px; z-index: 3; }

.p-header-video .caption .title, .p-header-youtube .caption .title { font-size: 40px; line-height: 1.4; margin-bottom: 12.4px; }

.p-header-video .caption .desc, .p-header-youtube .caption .desc { font-size: 16px; line-height: 2.2; margin-bottom: 20.4px; }

/* ヘッダー動画時キャッチコピーのアニメーション */
#js-header-video .caption .title, #js-header-youtube .caption .title, #js-header-video .caption .button, #js-header-youtube .caption .button { opacity: 0; }

#js-header-youtube .caption.first_active .title, #js-header-video .caption.first_active .title { -webkit-animation: opacityAnimation 0.5 ease forwards 0.75s; animation: opacityAnimation 0.5s ease forwards 0.75s; }

#js-header-youtube .caption.first_active .button, #js-header-video .caption.first_active .button { -webkit-animation: opacityAnimation 0.25s ease forwards 1.25s; animation: opacityAnimation 0.25s ease forwards 1.25s; }

@-webkit-keyframes opacityAnimation { 100% { opacity: 1; } }
@keyframes opacityAnimation { 100% { opacity: 1; } }
 /**
	* Load
	*/
@-webkit-keyframes loading-circle { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@keyframes loading-circle { 0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
  100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@-webkit-keyframes loading-square-base { 0% { bottom: 10px; opacity: 0; }
  5%, 50% { bottom: 0; opacity: 1; }
  55%, 100% { bottom: -10px; opacity: 0; } }
@keyframes loading-square-base { 0% { bottom: 10px; opacity: 0; }
  5%, 50% { bottom: 0; opacity: 1; }
  55%, 100% { bottom: -10px; opacity: 0; } }
@-webkit-keyframes loading-dots-fadein { 100% { opacity: 1; } }
@keyframes loading-dots-fadein { 100% { opacity: 1; } }
@-webkit-keyframes loading-dots-first-dot { 100% { -webkit-transform: translate(1em); transform: translate(1em); opacity: 1; } }
@keyframes loading-dots-first-dot { 100% { -webkit-transform: translate(1em); transform: translate(1em); opacity: 1; } }
@-webkit-keyframes loading-dots-middle-dots { 100% { -webkit-transform: translate(1em); transform: translate(1em); } }
@keyframes loading-dots-middle-dots { 100% { -webkit-transform: translate(1em); transform: translate(1em); } }
@-webkit-keyframes loading-dots-last-dot { 100% { -webkit-transform: translate(2em); transform: translate(2em); opacity: 0; } }
@keyframes loading-dots-last-dot { 100% { -webkit-transform: translate(2em); transform: translate(2em); opacity: 0; } }
#site-wrap { display: none; }

#site_loader_overlay { background: #fff; opacity: 1; position: fixed; top: 0px; left: 0px; width: 100%; height: 100%; width: 100vw; height: 100vh; z-index: 99999; }

/* type1 */
.c-load--type1 { width: 48px; height: 48px; font-size: 10px; text-indent: -9999em; position: fixed; top: 0; left: 0; right: 0; bottom: 0; margin: auto; border-radius: 50%; -webkit-animation: loading-circle 1.1s infinite linear; animation: loading-circle 1.1s infinite linear; }

/* type2 */
.c-load--type2 { width: 44px; height: 44px; position: fixed; top: 0; left: 0; bottom: 0; right: 0; margin: auto; }
.c-load--type2::before { position: absolute; bottom: 0; left: 0; display: block; width: 12px; height: 12px; content: ''; animation: loading-square-loader 5.4s linear forwards infinite; }
.c-load--type2::after { position: absolute; bottom: 10px; left: 0; display: block; width: 12px; height: 12px; opacity: 0; content: ''; animation: loading-square-base 5.4s linear forwards infinite; }

/* type3 */
.c-load--type3 { width: 100%; min-width: 160px; font-size: 16px; text-align: center; position: fixed; top: 50%; left: 0; opacity: 0; -webkit-animation: loading-dots-fadein .5s linear forwards; animation: loading-dots-fadein .5s linear forwards; }

#site_loader_animation i { width: .5em; height: .5em; display: inline-block; vertical-align: middle; background: #e0e0e0; border-radius: 50%; margin: 0 .25em; -webkit-animation: loading-dots-middle-dots .5s linear infinite; animation: loading-dots-middle-dots .5s linear infinite; }

#site_loader_animation i:first-child { -webkit-animation: loading-dots-first-dot .5s infinite; animation: loading-dots-first-dot .5s linear infinite; opacity: 0; -webkit-transform: translate(-1em); transform: translate(-1em); }

#site_loader_animation i:last-child { -webkit-animation: loading-dots-last-dot .5s linear infinite; animation: loading-dots-last-dot .5s linear infinite; }

.c-meta-box { background: #fafafa; box-sizing: border-box; font-size: 12px; padding: 22px 20px; }

.c-meta-box__item { border-right: 1px solid #ddd; float: left; margin-right: 15px; padding-left: 20px; padding-right: 15px; position: relative; }
.c-meta-box__item:last-child { border-right: none; }
.c-meta-box__item::before { color: #aaa; font-family: "design_plus"; position: absolute; left: 0; }

.c-meta-box__item--author::before { content: "\e90d"; }

.c-meta-box__item--category::before { content: "\e92f"; }

.c-meta-box__item--tag::before { content: "\e935"; }

.c-meta-box__item--comment::before { content: "\e916"; }

/***** c-menu ************************/
.c-menu-button::before { content: "\f0c9"; font-family: "design_plus"; font-size: 18px; }


.c-menu-button {
	display: none;
    top: 0;
    right: 0;
    position: absolute;
    text-align: center;
    background: url(/wp-content/uploads/c-menu.svg)center no-repeat;
    background-size: cover;
    z-index: 999;
}
.p-menu-button.is-active {
    background: url(/wp-content/uploads/c-menuclose.svg)center no-repeat !important;
    background-size: cover !important;
}
.c-menu-button::before {
	display:none
}



.c-nav01 { border-collapse: collapse; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; }

.c-nav01__item { border: 1px solid #ddd; box-sizing: border-box; font-size: 14px; line-height: 1.7; position: relative; width: 50%; height: 120px; flex: 1; margin-left: -1px; }
.c-nav01__item a { box-sizing: border-box; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; -ms-grid-row-align: center; align-items: center; height: 100%; padding: 36px 70px; }
.c-nav01__item a:hover { background: #f8f8f8; }

.c-nav01__item--prev::before { content: "\e90f"; font-family: "design_plus"; font-size: 18px; line-height: 100%; margin: auto; position: absolute; top: 0; bottom: 0; left: 25px; width: 18px; height: 18px; }

.c-nav01__item--next::after { content: "\e910"; font-family: "design_plus"; font-size: 18px; line-height: 100%; margin: auto; margin: auto; position: absolute; top: 0; bottom: 0; right: 25px; width: 18px; height: 18px; }

.c-pw__desc { line-height: 2.5; }
.c-pw__desc p { line-height: 2.5; margin-bottom: 16px; }

.c-pw__btn { box-sizing: border-box; color: #fff; display: inline-block; padding: 13px 20px; font-size: 14px; text-align: center; line-height: 1; }
.c-pw__btn:hover { background: #333; color: #fff; }

.c-pw__btn--register { min-width: 160px; margin-bottom: 32px; }

.c-pw__btn--submit { min-width: 100px; border: 0; cursor: pointer; }

.c-pw .c-pw__btn:hover { text-decoration: none; }

.c-pw__box { border: 1px solid #ddd; background: #f5f5f5; padding: 25px 36px; margin-bottom: 40px; box-sizing: border-box; }
.c-pw__box .c-pw__box-desc { line-height: 1.2; margin-bottom: 20px; }

.c-pw__box-inner { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; -ms-grid-row-align: center; align-items: center; }

.c-pw__box-label { margin-right: 14px; }

.c-pw__box-input { border: 1px solid #ddd; box-shadow: none; height: 40px; width: 250px; margin-right: 14px; flex: 1; box-sizing: border-box; padding: 0 10px; }

/** Share */
.c-share__icn { /* use !important to prevent issues with browser extensions that change fonts */ font-family: "design_plus" !important; font-style: normal; font-variant: normal; font-weight: normal; line-height: 1; speak: none; text-transform: none; /* Better Font Rendering */ -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; }

.c-share__icn--facebook::before { content: "\e902"; }

.c-share__icn--facebook2::before { content: "\e903"; }

.c-share__icn--feedly::before { content: "\e907"; }

.c-share__icn--google-plus::before { content: "\e900"; }

.c-share__icn--google-plus2::before { content: "\e901"; }

.c-share__icn--hatebu::before { content: "\e908"; }

.c-share__icn--line::before { content: "\e909"; }

.c-share__icn--pinterest::before { content: "\e905"; }

.c-share__icn--pocket::before { content: "\e90a"; }

.c-share__icn--rss::before { content: "\e90b"; }

.c-share__icn--rss2::before { content: "\e906"; }

.c-share__icn--twitter::before { content: "\e904"; }

.c-share--sm { line-height: 25px; min-width: 27px; }
.c-share--sm .c-share__btn { margin-right: 5px; }
.c-share--sm a { padding: 1px 5px 0; }
.c-share--sm .c-share__icn { font-size: 1.3em; position: relative; top: 3px; text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.1); }
.c-share--sm .c-share__title { line-height: 20px; margin: 0 3px 0 2px; }

.c-share--lg .c-share__btn { margin-right: 1%; margin-bottom: 2px; width: 24%; }
@media only screen and (max-width: 767px) { .c-share--lg .c-share__btn { margin-right: 3%; margin-bottom: 3%; width: 47%; } }
.c-share--lg .c-share__btn:nth-child(4n) { margin-right: 0; }
.c-share--lg .c-share__btn a { padding: 10px 2px; }
.c-share--lg .c-share__icn { font-size: 140%; position: relative; top: 3px; }
.c-share--lg .c-share__title { margin: 0 3px 0 4px; }

.c-share--color a { color: #fff; }
.c-share--color a:hover { -webkit-transform: translate3d(0, 1px, 0); transform: translate3d(0, 1px, 0); }
.c-share--color .c-share__btn--twitter a { background-color: #55acee; }
.c-share--color .c-share__btn--twitter a:hover { background-color: #468ec5; }
.c-share--color .c-share__btn--facebook a { background-color: #35629a; }
.c-share--color .c-share__btn--facebook a:hover { background-color: #1f3669; }
.c-share--color .c-share__btn--google-plus a { background-color: #dd4b39; }
.c-share--color .c-share__btn--google-plus a:hover { background-color: #b94031; }
.c-share--color .c-share__btn--hatebu a { background-color: #3c7dd1; }
.c-share--color .c-share__btn--hatebu a:hover { background-color: #0270ac; }
.c-share--color .c-share__btn--pocket a { background-color: #ee4056; }
.c-share--color .c-share__btn--pocket a:hover { background-color: #c53648; }
.c-share--color .c-share__btn--rss a { background-color: #ffb53c; }
.c-share--color .c-share__btn--rss a:hover { background-color: #e09900; }
.c-share--color .c-share__btn--feedly a { background-color: #6cc655; }
.c-share--color .c-share__btn--feedly a:hover { background-color: #5ca449; }
.c-share--color .c-share__btn--pinterest a { background-color: #d4121c; }
.c-share--color .c-share__btn--pinterest a:hover { background-color: #a42f35; }

.c-share--mono a { background: #fafafa; border: 1px solid rgba(0, 0, 0, 0.1); color: #222; }
.c-share--mono a:hover { border-color: rgba(255, 255, 255, 0.1); color: #fff; }
.c-share--mono .c-share__btn--twitter a:hover { background-color: #55acee; }
.c-share--mono .c-share__btn--facebook a:hover { background-color: #35629a; }
.c-share--mono .c-share__btn--google-plus a:hover { background-color: #dd4b39; }
.c-share--mono .c-share__btn--hatebu a:hover { background-color: #3c7dd1; }
.c-share--mono .c-share__btn--pocket a:hover { background-color: #ee4056; }
.c-share--mono .c-share__btn--rss a:hover { background-color: #ff8c00; }
.c-share--mono .c-share__btn--feedly a:hover { background-color: #6cc655; }
.c-share--mono .c-share__btn--pinterest a:hover { background-color: #d4121c; }

.c-share__btn { box-sizing: border-box; float: left; font-size: 12px; text-align: center; }
.c-share__btn a { border-radius: 2px; box-shadow: 0 1px 0 rgba(0, 0, 0, 0.03); display: block; }

@media screen and (max-width: 767px) { .c-share--sm .c-share__icn { left: 1px; }
  .c-share--sm .c-share__title { display: none; } }
.c-share--official .c-share__btn { line-height: 1; margin-right: 5px; }
.c-share--official .c-share__btn--twitter { width: 89px; }
.c-share--official .c-share__btn--facebook:hover { text-decoration: none; }
.c-share--official .c-share__btn--google-plus { width: 58px; }
.c-share--official .c-share__btn--pocket { width: 88px; }

/* Project ----------------------------------------------------------------- */
 /**
	* address
	*/
.p-address { color: #fff; display: none; font-size: 12px; line-height: 1.8; margin-bottom: 13.2px; text-align: center; }

 /**
	* article01
	*/
.p-article01__thumbnail { display: block; margin-bottom: 14px; }
.p-article01__thumbnail img { width: 100%; height: auto; }

.p-article01__title { font-size: 14px; line-height: 2; margin-bottom: 7px; }
.p-article01__title a { font-weight: 700; }
.p-article01__title a:hover { color: #e37100; }

.p-article01__meta { font-size: 12px; line-height: 1.9; }

.p-article01__date { color: #999; }
.p-article01__date + .p-article01__category::before { color: #999; content: "|"; display: inline-block; margin-left: 8px; margin-right: 8px; }

.p-article01__category a { color: #999; }

 /**
	* article02
	*/
.p-article02 {
    box-sizing: border-box;
    padding: 30px 30px 20.2px;
    border-bottom: solid 1px #bdbdbd;
}

.p-article02__header { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; -ms-grid-row-align: center; align-items: center; }

.p-article02__thumbnail { margin-right: 30px; width: 160px; }
.p-article02__thumbnail img { width: 100%; height: auto; }

.p-article02__content { flex: 1; }

.p-article02__title { font-size: 120%; font-weight: bold; line-height: 2; margin-bottom: 6px; }

.p-article02__date { color: #999; font-size: 12px; }

.p-article02__excerpt { font-size: 95%; line-height: 1.8; }

 /**
	* blog list
	*/
.p-blog-list { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; margin-bottom: 110px; width: 102.21239%; }

.p-blog-list__item { margin-right: 2.21239%; margin-bottom: 35.8px; width: 31.85841%; }
.p-blog-list__item:nth-of-type(3n) { margin-right: 0; }
.p-blog-list__item.is-active { -webkit-animation: fadeIn 0.65s ease forwards; animation: fadeIn 0.65s ease forwards; }

 /**
	* breadcrumb
	*/
.p-breadcrumb {
    line-height: 1.7;
    font-size: 90%;
    width: 90%;
    margin: 0 auto;
    color: #6b5252;
}
.p-breadcrumb a {
	color: #6b5252;
}
.p-breadcrumb a:hover {opacity:0.7; text-decoration:underline }

.p-breadcrumb__item + .p-breadcrumb__item::before { font-size: 10px; }

.bread_inner {
    background: #e8e8ab;
    padding: 10px 0;
}


 /**
	* button
	*/
.p-button { background: #ff7f00; border-radius: 4px; box-sizing: border-box; display: inline-block; font-size: 14px; line-height: 50px; text-align: center; min-width: 220px; height: 50px; padding: 0 15px; }
.p-button:hover { background: #e37100; color: #fff; }

 /**
	* copyright
	*/
	.p-copyright {
		color: #fff;
		font-size: 95%;
		height: 55px;
		line-height: 55px;
		overflow: hidden;
		text-align: center;
	}

 /**
	* CTA
	*/
.p-cta { overflow: hidden; background-position: center center; background-size: cover; height: 400px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; align-items: center; justify-content: center; text-align: center; margin-bottom: 70px; position: relative; }
.p-cta::before { content: ""; width: 100%; height: 100%; position: absolute; top: 0; left: 0; }

.p-cta--type2 .p-cta__inner { border: 1px solid #ddd; border-left: 0; box-sizing: border-box; color: #000; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -ms-flex-item-align: stretch; align-self: stretch; -webkit-box-orient: vertical; -webkit-box-direction: normal; -webkit-flex-direction: column; -ms-flex-direction: column; flex-direction: column; justify-content: center; flex: initial; width: 50%; padding: 0 4.44444%; }
.p-cta--type2 .p-cta__catch { text-align: left; margin-bottom: 16px; }
.p-cta--type2 .p-cta__desc { text-align: left; }
.p-cta--type2 .p-cta__desc p { margin-bottom: 21px; }

.p-cta--type2-rev { flex-flow: row-reverse nowrap; }
.p-cta--type2-rev .p-cta__inner { border: 1px solid #ddd; border-right: 0; }

.p-cta__inner { color: #fff; padding: 0 20px; position: relative; z-index: 1; flex: 1; }

.p-cta__catch { line-height: 1.5; margin-bottom: 14px; }

.p-cta__desc { line-height: 2; }
.p-cta__desc p { font-size: inherit; line-height: inherit; margin-bottom: 23px; }

.p-cta__btn { align-self: center; box-sizing: border-box; display: inline-block; font-size: 16px; min-width: 300px; height: 55px; line-height: 55px; padding: 0 10px; position: relative; color: #fff; }
.p-cta__btn:after { content: "\e910"; font-family: "design_plus"; position: absolute; top: 0; bottom: 0; right: 11px; margin: auto; }

.p-cta__img { flex: 1; position: relative; width: 50%; height: 100%; overflow: hidden; }
.p-cta__img img { position: absolute; top: 0; left: 50%; transform: translateX(-50%); }

 /**
	* entry
	*/
.p-entry__inner { width: 88.28125%; max-width: 1130px; }

.p-entry__inner--narrow { width: 79.64602%; max-width: 900px; }

body.home .p-entry__body { margin-top: 60.2px; }
.p-entry__body .p-entry__ad img { max-width: none; width: auto; }

.p-entry__share { margin-bottom: 27px; }

.p-entry__meta { margin-bottom: 70px; }

.p-entry__nav { margin-bottom: 70px; }

.p-entry__related { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; margin-bottom: 144.6px; }

.p-entry__related-item { margin-right: 2.65487%; width: 23.00885%; }
.p-entry__related-item:last-child { margin-right: 0; }

.p-entry__ad { margin-bottom: 70px; text-align: center; }

.p-entry__ad-item { display: inline-block; }
.p-entry__ad-item + .p-entry__ad-item { margin-left: 50px; }

 /**
	* footer blog
	*/
.p-footer-blog { border-bottom: 1px solid #333; margin-bottom: 50px; overflow: hidden; position: relative; }
.p-footer-blog .slick-dots { bottom: 0; width: 97.41379%; }
.p-footer-blog .slick-dots li { background: #fff; }

.p-footer-blog__catch { color: #fff; font-size: 30px; line-height: 2.2; margin-bottom: 32px; }

.p-footer-blog__archive-link { color: #fff; font-size: 14px; position: absolute; top: 18px; right: 0; }
.p-footer-blog__archive-link::after { content: "\e910"; font-family: "design_plus"; margin-left: 14px; transition-property: none; }
.p-footer-blog__archive-link:hover { color: #e37100; }

.p-footer-blog__list { color: #646767; padding-bottom: 58px; width: 102.65487%; }
.p-footer-blog__list.slick-dotted.slick-slider { margin-bottom: 50px; }

.p-footer-blog__item { float: left; margin-right: 2.58621%; width: 22.41379%; }

.p-footer-blog__item-title a { color: #fff; }

.p-footer-cta { position: fixed; bottom: 0; width: 100%; z-index: 9999; -webkit-transform: translate3d(0, 100%, 0); transform: translate3d(0, 100%, 0); -webkit-transition: -webkit-transform 0.35s; transition: transform 0.35s; }
.p-footer-cta.is-active { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); }

.p-footer-cta__inner { background: #000; box-sizing: border-box; border-top: 1px solid #333; height: 120px; padding: 0 60px 0 40px; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -ms-flex-align: center; -ms-grid-row-align: center; align-items: center; position: relative; }

.p-footer-cta__catch { color: #fff; font-size: 21px; line-height: 1.5; margin-bottom: 5px; }

.p-footer-cta__desc { color: #999; font-size: 14px; line-height: 2; }

.p-footer-cta__btn { color: #fff; font-size: 16px; display: inline-block; min-width: 300px; height: 55px; line-height: 55px; padding: 0 40px 0 10px; text-align: center; position: relative; /*
position: absolute;
top: 0;
bottom: 0;
margin: auto;
right: 60px;
*/ box-sizing: border-box; }
.p-footer-cta__btn:after { content: "\e910"; font-family: "design_plus"; position: absolute; right: 11px; }

.p-footer-cta__close { cursor: pointer; border-radius: 50%; position: absolute; top: 0; bottom: 0; right: 10px; width: 40px; height: 40px; margin: auto; text-align: center; transition: background 0.5s; }
.p-footer-cta__close:hover { background: #444; }
.p-footer-cta__close::before { color: #fff; content: "\e91a"; font-family: "design_plus"; line-height: 40px; height: 40px; }

 /**
	* footer nav
	*/
	.p-footer-nav {
		color: #fff;
		display: table;
		width: 100%;
	}
	.p-footer-nav li {
		width: 20%;
		float: left;
		position: relative;
	}
	.p-footer-nav li a {
		font-weight: 500;
		font-size: 120%;
    font-family: 'Shippori Mincho B1', serif !important;
	}
	.p-footer-nav .sub-menu li:before {
		position: absolute;
		content: "";
		width: 6px;
		height: 6px;
		border: 0px;
		border-top: solid 1px #ffffff;
		border-right: solid 1px #ffffff;
		-ms-transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		left: 0px;
		top: 11px;
	}
	.p-footer-nav .sub-menu li {
		width: auto;
		float: unset;
		padding-left: 18px;
		position: relative;
		margin-bottom: 3px;
	}
	.p-footer-nav .sub-menu {
		margin-top: 10px;
	}
.p-footer-nav .sub-menu li a {
    font-weight: 400;
    font-size: 90%;
    font-family: dnp-shuei-gothic-gin-std, sans-serif !important;
}
	.p-footer-nav a { color: #fff; }
	
	
	.p-footer-nav .sub-menu li a:hover {opacity:0.7;text-decoration:underline }
	
@media only screen and (max-width: 1000px) {
	.p-footer-nav li {
    width: 33%;
    float: left;
}
}

@media only screen and (max-width: 767px) {
	.p-footer-nav li {
        width: 100%;
        float: unset;
}
.p-footer-nav li a {
    font-size: 100%;
}
    .p-footer-nav .sub-menu li {
        padding-left: 14px;
        float: left;
        margin: 0 15px 5px 0;
    }
.p-footer-nav .sub-menu {
        margin: 5px 0 10px;
        display: table;
        width: 100%;
}
.l-footer__inner {
    padding: 50px 0 0;
}
    .l-footer {
        padding-top: 0px;
        padding-bottom: 50px;
    }
}

/*
```
<header id="js-header" class="l-header">
	<div class="l-header__inner">
		<a href="#" id="js-menu-button" class="p-menu-button c-menu-button"></a>
		<nav>
			<ul id="js-global-nav" class="p-global-nav u-clearfix">
				<li class="current-menu-item"><a href="#">HOME</a></li>
				<li class="menu-item-has-children">
					<a href="#js-news-ticker">ABOUT<span></span></a>
					<ul class="sub-menu">
						<li class="menu-item-has-children">
							<a href="#">サブメニューA<span></span></a>
							<ul class="sub-menu">
								<li><a href="#">サブメニューA-1</a></li>
								<li><a href="#">サブメニューA-2</a></li>
								<li><a href="#">サブメニューA-3</a></li>
							</ul>
						</li>
						<li><a href="#">サブメニューB</a></li>
						<li><a href="#">サブメニューC</a></li>
					</ul>
				</li>
				<li><a href="#index-content01">FEATURES</a></li>
				<li><a href="#js-index-content04__carousel">SERVICE</a></li>
				<li><a href="#">REVIEWS</a></li>
				<li><a href="#">DOWNLOAD</a></li>
				<li><a href="#">BLOG</a></li>
			</ul>
		</nav>
	</div>
</header>
```
*/
 /**
	* global nav
	*/
	
.p-global-nav {
    font-size: 100%;
    font-family: 'Shippori Mincho B1', serif !important;
    float: right;
    margin-top: 15px;
}
nav {
    margin: 0 30px 0 auto;
    position: relative;
}

@media only screen and (min-width: 1201px) {
	.p-global-nav { display:block !important; } 
}
.p-global-nav li {
    float: left;
    line-height: 3;
    position: relative;
}
.p-global-nav > li.menu-item-has-children:hover > .sub-menu { top: 100%; }
.p-global-nav li a {
	padding: 10px 22px;
    position: relative;
color: #222 !important; 
	display: block;
}
.p-global-nav > li > .sub-menu { top: 75%; left: 0; }

/*
.p-global-nav .menu-item-has-children { position: relative; }
.p-global-nav .menu-item-has-children:hover > .sub-menu { opacity: 1; top: 0; visibility: visible; }
.p-global-nav .sub-menu { line-height: 1.2; opacity: 0; position: absolute; top: -25%; left: 100%; transition: 0.3s; visibility: hidden; z-index: 99; }
.p-global-nav .sub-menu .menu-item-has-children > a { position: relative; }
.p-global-nav .sub-menu .menu-item-has-children > a::after { content: "\e910"; font-family: "design_plus"; position: absolute; right: 16px; }
*/

/* global sub装飾*/
/*
.p-global-nav .sub-menu a {
    background: #379d97;
    box-sizing: border-box;
    padding: 10px;
    width: 220px;
    border-bottom: solid 1px rgb(255 255 255 / 50%);
	font-size:95%;
}
.p-global-nav .sub-menu a:hover{background:#1a7570}
.p-global-nav > li > .sub-menu a {
    color: #fff !important;
}
.p-global-nav .sub-menu li {
    line-height: 1.5;
}
*/
.p-global-nav li a:before {
    border: 0;
    border-top: 1px solid #757575;
    content: "";
    position: absolute;
    transform: rotate( -65deg);
    width: 23px;
    height: 1px;
    top: 52%;
    right: -12px;
}

.p-global-nav .sub-menu li:before {
	display:none;
}


/* メガメニュー*/
@media only screen and (min-width: 1201px) {
.header-nav-child {
    height: 0;
    position: fixed;
    left: 0;
    transition: .2s;
	display: none;
	visibility: hidden;
}
.p-global-nav li:hover .header-nav-child {
    display: block;
    width: 100%;
    margin: 0px auto 0;
    z-index: 4;
    overflow: hidden;
    height: auto;
    visibility: visible;
    max-width: 1200px;
    left: 0;
    right: 0;
    padding-top: 5px;
}

/*li親要素をはみ出すのに必要*/
#menu-item-300, #menu-item-301 {
    position: inherit;
}
.header-nav-child .container {
    width: 96%;
    margin: 0 auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
	background: #e5eef9;
    padding: 0 2%;
}
.container .sub-menu {
    position: relative;
    background: none;
    margin-left: 0;
    text-align: left;
    box-sizing: border-box;
    padding: 37px 0 30px !important;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
	width:100%;
}
.container .sub-menu li {
    width: 22%;
    float: left;
    margin: 0 3% 8px 0;
}
.p-global-nav > li:hover .sub-menu::before{display:none}

.p-global-nav > li .header-nav-child .sub-menu li {
    background: unset !important;
    border: unset;
    border-bottom: solid 1px #c2cadf;
}
.p-global-nav > li .header-nav-child .sub-menu li a {
    font-size: 100%;
    padding: 0 0 0 20px !important;
    position: relative;
    display: block;
    line-height: 3;
    border-left: unset;
    border-right: unset;
}
.p-global-nav > li .header-nav-child .sub-menu li a:before {
    content: "";
    position: absolute;
    transition: 0.3s;
    border-right: 0 solid transparent;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 7px solid #4d67b1;
    top: 40%;
    z-index: 1;
    left: 4px !important;
	transform: rotate(0deg);
}
.p-global-nav > li .header-nav-child .sub-menu li a:hover {
        background: #cadcf2;
}
	.p-global-nav > li .header-nav-child .sub-menu li a:hover:after{
	display:none;	
}
.p-global-nav > li:hover .children>li:not( :first-child ), .p-global-nav > li:hover .sub-menu>li:not( :first-child ) {
    border-top: unset !important;
	box-shadow:unset !important;}
.p-global-nav > li .menu-item-has-children>a::before {
	right: 5px;}
.gmenu_wide {
    width: 100% !important;
}
.gmenu_wide a:hover {
    background: unset !important;
    color: #333 !important;
}
	.gmenu_wide a {font-weight:600}
	.gmenu_wide a:before {display:none}
.gmenu_wide a:hover {
    text-decoration: unset !important;
    opacity: 1 !important;
}
/*一部のメニューは標準*/
#menu-item-305:hover .header-nav-child, #menu-item-127:hover .header-nav-child, #menu-item-299:hover .header-nav-child {
    width: 250px;
    background: unset;
        left: unset;
        right: unset;
}
#menu-item-305 .header-nav-child .container, #menu-item-127 .header-nav-child .container, #menu-item-299 .header-nav-child .container {
    width: auto;
    max-width: unset;
    display: block;
    -webkit-box-pack: unset;
    -ms-flex-pack: unset;
    justify-content: unset;
	padding:0;
}
#menu-item-305 .container .sub-menu li a, #menu-item-127 .container .sub-menu li a, #menu-item-299 .container .sub-menu li a {
    padding: 2px 5px 2px 15px !important;
    border-left: unset;
    border-right: unset;
}
#menu-item-305 .container .sub-menu li a:before, #menu-item-127 .container .sub-menu li a:before, #menu-item-299 .container .sub-menu li a:before{display:none}

#menu-item-305 .container .sub-menu li, #menu-item-127 .container .sub-menu li, #menu-item-299 .container .sub-menu li {
    width: 100%;
    border-bottom: solid 1px #c2cadf;
    display: block;
    background: #e5eef9 !important;
    margin: 0;
}
#menu-item-305 .header-nav-child .sub-menu li a:hover, #menu-item-127 .header-nav-child .sub-menu li a:hover, #menu-item-299 .header-nav-child .sub-menu li a:hover {
text-decoration: unset;
        background: #cadcf2;
}
#menu-item-305 .container .sub-menu, #menu-item-127 .container .sub-menu, #menu-item-299 .container .sub-menu{
    padding: 0px !important;
    display: block !important;
}
}







/* global hover時・スクロール時*/
@media only screen and (min-width: 1201px) { 
.p-global-nav li a:after {
    position: absolute;
    content: '';
    bottom: 5px;
    left: 0;
    width: 0;
    height: 2px;
	background: #99c8c6;
    transition: all 0.3s ease 0s;
    right: 0;
    margin: 0 auto;
}
.p-global-nav li a:hover:after {
    width: 50%;
}
.p-global-nav li a:hover {
	cursor: pointer;}
.l-header.is-fixed.is-active .l-header__logo {
        max-width: 280px;
    }
.l-header.is-fixed.is-active .l-header__logo a {
    line-height: 70px;
    height: 70px;
    padding: 0 3%;
}
.l-header.is-fixed.is-active .l-header__logo a span {
    display: none;
}
.l-header.is-fixed.is-active .p-global-nav {
    margin-top: 0;
}
.l-header.is-fixed.is-active .g_con_block {
    max-width: 331px;
}
.l-header.is-fixed.is-active .l-header__inner {
    width: 100%;
}
}

.p-global-nav > li > .sub-menu a:after {display:none}




/* nav-mobile時 */
/*
@media screen and (max-width: 1200px) {
nav {
    margin: 0 auto;
}
.p-global-nav {
    margin-top: 0;
    height: 100vh;
    top: 0 !important;
    padding: 50px 10%;
    text-align: center;
    background: rgb(117 85 44 / 95%) !important;
	position: fixed !important;
}
.p-global-nav li a {
    color: #fff !important;
    height: 60px !important;
    line-height: 60px !important;
    font-size: 100%;
	padding:0
}
.p-global-nav li {
border-left: unset;
        width: 46% !important;
        margin: 0;
        text-align: left;
        float: left !important;
}
.p-global-nav > li > .sub-menu a {
    width: 90%;
    margin: 0 auto;
    border-bottom: solid 1px #fff;
}
.p-global-nav .sub-menu li {
    border-bottom: unset;
}
.p-global-nav li a:before{display:none}
.p-global-nav .sub-menu {
	display: block !important;
	}
}　
*/



/* nav-mobile時 */
@media only screen and (max-width: 1200px){
nav {
    margin: 0 auto;
}
.p-global-nav li a:before{display:none}
.p-global-nav .sub-menu a {
    width: 100%;
}
.l-header--large.is-active .p-global-nav, .l-header.is-fixed.is-active .p-global-nav {
    font-size: 100%;
}
.l-header--large.is-active .p-global-nav > li, .l-header.is-fixed.is-active .p-global-nav > li {
    line-height: 2;
border-bottom: solid 1px #b9aeae;
    margin-bottom: 10px;
}
.l-header--large.is-active .p-global-nav > li > a, .l-header.is-fixed.is-active .p-global-nav > li > a {
    padding: 5px 0 5px 13px;
	color: #4d4242 !important;
}
.p-global-nav .menu-item-has-children>a>span::before{display:none !important}
.p-global-nav li .sub-menu li {
    margin: 0 4% 0 0;
    position: relative;
}
.p-global-nav li .sub-menu li:after {    
	position: absolute;
	content: "";
	border: 0px;
	border-top: solid 1px #7f7e7e;
	border-right: solid 1px #7f7e7e;
	-ms-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	left: 0px;
	width: 5px;
	height: 5px;
	top: 16px;
}
.p-global-nav li {
    border-left: unset;
    width: 46% !important;
    margin: 0;
    text-align: left;
    float: left !important;
        line-height: inherit;
}
.p-global-nav a {
    font-weight: 500;
}
	nav {height: 0px;line-height: 0px;}
.p-global-nav li img {
    position: relative;
    top: -4px;
}
span.gl_spa:before {
    display: none !important;
}
.p-global-nav {
    top: 0 !important;
    left: 0;
    z-index: 99;
    width: 100%;
	padding: 60px 0 150px 3%;
    margin-top: 0;
	position:fixed !important;
    background: #f5f4f1 !important;
    font-family: dnp-shuei-gothic-gin-std, sans-serif !important;
}
	.p-global-nav .sub-menu{display: block !important;}
	.l-header.is-fixed.is-active .p-global-nav .sub-menu a {
    color: #4d4242 !important;
    font-size: 95%;
}
#menu-item-127, #menu-item-300, #menu-item-299, #menu-item-301, #menu-item-305 {
    width: 100% !important;
    border-bottom: unset;
    margin-bottom: 25px;
}
#menu-item-127 a, #menu-item-300 a, #menu-item-299 a, #menu-item-301 a, #menu-item-305 a {
    background: #635454dd;
    color: #fff !important;
    padding: 0 10px;
    display: inline-block;
}
#menu-item-127 .sub-menu a, #menu-item-300 .sub-menu a, #menu-item-299 .sub-menu a, #menu-item-301 .sub-menu a, #menu-item-305 .sub-menu a{
    background: unset;
    color: #4d4242 !important;
    padding: 5px 0 5px 13px;
    display: inline-block;
    border-bottom: solid 1px #b9aeae;
}
#menu-item-17:after {
    position: absolute;
    content: "";
    border: 0px;
    border-top: solid 1px #7f7e7e;
    border-right: solid 1px #7f7e7e;
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    left: 0px;
    width: 5px;
    height: 5px;
    top: 15px;
}
}


@media only screen and (max-width: 767px){
	.l-header--large.is-active .p-global-nav, .l-header.is-fixed.is-active .p-global-nav {
    font-size: 15px;
    letter-spacing: 0;
}
}






/*mobile時　logo変更*/
.is-mobile-fix .l-header__logo {
    background: unset;
    max-width: 250px;
    width: 40%;
}
.is-mobile-fix .l-header__logo a {
    padding: 0 0 0 10px;
    height: 60px;
	line-height:60px;
}

@media screen and (max-width: 767px) {
	.l-header__logo a span{display:none}
}


/* nav tel */
.g_con_block {
    width: 23%;
    max-width: 430px;
    display: table;
    position: relative;
}
.gc_resev img {
    vertical-align: middle;
}
.gc_tel img {
    vertical-align: middle;
}
.gc_resev a {
    position: relative;
    display: block;
    background: #5d3b36;
    padding: 0 8px;
    transition: all 0.3s ease 0s;
}
.gc_resev a:hover {opacity:0.8}

.gc_resev {
	width: 33%;
    float: left;
    position: relative;
}
.gc_tel {
    width: 64%;
    float: left;
    position: relative;
    padding: 0 3% 0 0;
}


@media screen and (max-width: 1400px) {
.g_con_block {
	width: 24%;}
}

@media screen and (max-width: 1200px) {
.g_con_block {
    position: absolute;
    top: 0;
    right: 60px;
    width: 26%;
}
	.l-header__logo a span {
    padding: 10px 0;
	}	
	.l-header__logo a {
    padding: 25px 5% 22px;
}
}


@media screen and (max-width: 767px) {
	.g_con_block {
    display: none;
}
.l-header__logo {
        width: 55%;
    }
.is-mobile-fix .l-header__logo {
    width: 60%;
}
}



 /**
	* headline
	*/
.p-headline { background: #131e20; box-sizing: border-box; color: #fff; font-size: 16px; height: 55px; line-height: 55px; margin-bottom: 27px; padding-left: 24px; padding-right: 24px; }

 /**
	* header video
	*/
.p-header-video { height: 780px; }

 /**
	* header youtube
	*/
.p-header-youtube { height: 780px; }



@media screen and (min-width: 768px) {
    .p-header-video{ height:calc(100vw * 9 / 16); max-height:780px; }
    .p-header-youtube{ height:calc(100vw * 9 / 16); }
    .p-header-youtube iframe { width:100% !important; margin-left: 0 !important; height: 100% !important; margin-top: 0 !important; }
}
@media screen and (max-width: 767px) {
    .p-header-youtube iframe { height:100% !important; margin-top: 0 !important; }
}



 /**
	* hover effect
	*/
.p-hover-effect--type1 { overflow: hidden; }
.p-hover-effect--type1 img { transform: scale(1); transition-duration: 0.75s; vertical-align: middle; }

/*
<a class="p-index-content02__item-image p-hover-effect--02" href="#">
	<img src="http://placehold.jp/340x220.png" alt="">
</a>
*/
.p-hover-effect--type2 { overflow: hidden; }
.p-hover-effect--type2:hover img { -webkit-transform: scale(1.2) translate3d(0, 0, 0); transform: scale(1.2) translate3d(0, 0, 0); }
.p-hover-effect--type2 img { transition-property: opacity, translate3d; transition: 0.5s; }

/*
<a class="p-index-content02__item-image p-hover-effect--03" href="#">
	<img src="http://placehold.jp/340x220.png" alt="">
</a>
*/
.p-hover-effect--type3:hover img { opacity: 0.5; }
.p-hover-effect--type3 img { transition-property: opacity; transition: 0.5s; background: #fff; }



 /**
	* index slider
	*/
.p-index-slider {
    overflow: hidden;
    position: relative;
    padding-top: 42%;
    width: calc(100% - 60px);
    margin: 0 0 0 auto;
}

.p-index-slider__item { background-position: center center; background-size: cover; display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.p-index-slider__item:first-child { display: block; }
.p-index-slider__item.is-active .p-index-slider__item-catch, .p-index-slider__item.is-active .p-index-slider__item-desc, .p-index-slider__item.is-active .p-index-slider__item-image { opacity: 1; transition: 0.5s; }
.p-index-slider__item.is-active .p-index-slider__item-button { opacity: 1; transition: background-color 0.2s, color 0.2s, opacity 0.25s linear 1.25s; }
.p-index-slider__item.is-active .p-index-slider__item-catch, .p-index-slider__item.is-active .p-index-slider__item-desc { transition-delay: 0.75s; }
.p-index-slider__item.is-active .p-index-slider__item-image { transition-delay: 1.75s; }

.p-index-slider__item--type2 .p-index-slider__item-content { order: 1; }
.p-index-slider__item--type2 .p-index-slider__item-catch, .p-index-slider__item--type2 .p-index-slider__item-desc { -webkit-transform: translateY(-50%); transform: translateY(-50%); }
.p-index-slider__item--type2 .p-index-slider__item-image { -webkit-transform: translateX(-50%); transform: translateX(-50%); order: 0; }
.p-index-slider__item--type2.is-active .p-index-slider__item-catch, .p-index-slider__item--type2.is-active .p-index-slider__item-desc, .p-index-slider__item--type2.is-active .p-index-slider__item-image { -webkit-transform: translate(0, 0); transform: translate(0, 0); }

.p-index-slider__item--type3 .p-index-slider__item-catch, .p-index-slider__item--type3 .p-index-slider__item-desc { -webkit-transform: translateX(-50%); transform: translateX(-50%); }
.p-index-slider__item--type3 .p-index-slider__item-image { -webkit-transform: translateX(50%); transform: translateX(50%); }
.p-index-slider__item--type3.is-active .p-index-slider__item-catch, .p-index-slider__item--type3.is-active .p-index-slider__item-desc, .p-index-slider__item--type3.is-active .p-index-slider__item-image { -webkit-transform: translate(0, 0); transform: translate(0, 0); }

.p-index-slider__item-inner { color: #fff; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; -ms-grid-row-align: center; align-items: center; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; height: 445px; margin: auto; position: absolute; top: 0; right: 0; bottom: 0; left: 0; }

.p-index-slider__item-content { width: 46.54867%; }

.p-index-slider__item-catch { font-size: 40px; line-height: 1.4; margin-bottom: 12.4px; opacity: 0; }

.p-index-slider__item-desc { font-size: 16px; line-height: 2.2; margin-bottom: 20.4px; opacity: 0; }

.p-index-slider__item-image { opacity: 0; width: 49.55752%; }
.p-index-slider__item-image img { width: 100%; height: auto; }

.p-index-slider__item-button { opacity: 0; }


 /**
	* lightbox
	*/
.lb-nav { background: #222; top: -webkit-calc(100% + 50px); top: calc(100% + 50px); height: 50px; }
.lb-nav a.lb-prev, .lb-nav a.lb-next { background: #333; opacity: 1; line-height: 50px; position: absolute; width: 50px; height: 50px; z-index: 9999; }
.lb-nav a.lb-prev { left: -webkit-calc(50% - 51px); left: calc(50% - 51px); }
.lb-nav a.lb-prev::before { color: #fff; content: "\e90f"; font-family: "design_plus"; }
.lb-nav a.lb-next { left: -webkit-calc(50% + 1px); left: calc(50% + 1px); }
.lb-nav a.lb-next::after { color: #fff; content: "\e910"; font-family: "design_plus"; }

.lb-dataContainer { height: 100px; padding-top: 0; }

.lb-data { background: #000; height: 50px; line-height: 50px; padding: 0; }
.lb-data .lb-details { box-sizing: border-box; float: none; padding: 0 10px; text-align: center; width: 100%; }
.lb-data .lb-caption { display: block !important; height: 50px; line-height: 50px; }
.lb-data .lb-number { padding-bottom: 0; }
.lb-data .lb-close { float: right; line-height: 50px; opacity: 1; position: relative; width: 50px; height: 50px; z-index: 999; }
.lb-data .lb-close::before { color: #aaa; content: "\e91a"; font-size: 18px; font-family: "design_plus"; position: absolute; right: 18px; }

.lightbox .lb-image { border: 0; border-radius: 0; }

 /**
	* load post
	*/
.p-load-post { margin-bottom: 150px; text-align: center; }
.p-load-post a { background: #131e20; color: #fff; display: inline-block; font-size: 14px; text-align: center; line-height: 50px; width: 200px; height: 50px; }

.p-logo a { color: #fff; }

 /**
	* menu button
	*/
.p-menu-button { line-height: 60px; width: 60px; height: 60px; }

 /**
	* news list
	*/
.p-news-list {
    width: 90%;
    max-width: 1000px;
    position: relative;
    margin: 60px auto 150px;
}

.p-latest-news {
    display: none;
}
.p-news-list__item { box-sizing: border-box; margin-bottom: 28px; width: auto; }
.p-news-list__item:nth-child(even) { margin-right: 0; }
.p-news-list__item.is-active { -webkit-animation: fadeIn 0.65s ease forwards; animation: fadeIn 0.65s ease forwards; }

 

 /**
	* page-links
	*/
.p-page-links { font-size: 14px; }
.p-page-links a, .p-page-links span { color: #fff; display: inline-block; line-height: 40px; text-align: center; width: 40px; height: 40px; }
.p-page-links span, .p-page-links a span:hover { background: #ff7f00; }
.p-page-links a span { background: #131e20; }
.p-page-links .p-page-links__title { background: transparent; color: #000; text-align: left; width: auto; height: auto; }

 /** pagebuilder extend
	*/
 /**
	* pager
	*/
.p-pager { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; justify-content: center; margin-bottom: 150px; }

.p-pager__item { font-size: 14px; margin-right: 5px; }
.p-pager__item a, .p-pager__item span { color: #fff; display: block; line-height: 40px; text-align: center; width: 40px; height: 40px; }
.p-pager__item a, .p-pager__item .dots { background: #131e20; }
.p-pager__item span { background: #ff7f00; }

 /**
	* page header
	*/
.p-page-header {
    align-items: center;
    margin-bottom: 0;
    position: relative;
    width: 100%;
    height: 350px;
}
.p-page-header::before { background: rgba(0, 0, 0, 0.5); content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }

.p-page-header__inner {
    text-align: center;
    position: relative;
    z-index: 2;
    -webkit-animation: fadeIn 1s ease 1s;
    animation: fadeIn 1s ease 1s;
    animation-fill-mode: both;
    height: 100%;
    max-width: unset;
}

.p-page-header__title {
    color: #fff;
    font-size: 220%;
    line-height: 1.3;
    font-family: 'Shippori Mincho B1', serif !important;
}

.p-page-header__desc { color: #fff; font-size: 16px; line-height: 2.2; }

.p-page-header__meta { color: #fff; font-size: 14px; line-height: 1.9; }
.p-page-header__meta a { color: #fff; }
.p-page-header__meta a:hover { color: #e37100; }

.p-page-header__date + .p-page-header__category::before { content: "|"; margin-left: 10px; margin-right: 10px; }

/**
	* pagetop カスタマイズ
	*/
	.p-pagetop {
		line-height: 65px;
		position: fixed;
		bottom: 0px;
		right: 0px;
		z-index: 9999;
		display: block !important;
		opacity: 1 !important;
	}
.p-pagetop a {
    background: #c19e53;
    color: #fff;
    display: block;
    position: relative;
    width: 60px;
    height: 60px;
    text-align: center;
}
	
	.p-pagetop a:hover { background:#f17888; }
	.p-pagetop a::after { content: "\e911"; font-family: "design_plus"; font-size: 18px; margin: auto; position: absolute; top: -40px; right: 0; bottom: 0; left: 0; width: 18px; height: 18px; }
	
	@media only screen and (max-width: 500px){
		.p-pagetop { line-height: 70px; position: fixed; bottom: 30px ; right: 10px ; z-index: 9999;  }
	}


.slick-dots li { border-radius: 50%; margin: 0 14px 0 0; width: 12px; height: 12px; transition-property: background-color; transition-duration: 0.2s; transition-timing-function: ease; }
.slick-dots li:last-child { margin-right: 0; }
.slick-dots li.slick-active, .slick-dots li:hover { background: #ff7f00; }
.slick-dots li button { width: 12px; height: 12px; }
.slick-dots li button::before { content: ""; }

.slick-prev:before
{
    content: '';
}
[dir='rtl'] .slick-prev:before
{
    content: '';
}
.slick-next:before
{
    content: '';
}
[dir='rtl'] .slick-next:before
{
    content: '';
}



 /**
	* social nav
	*/
.p-social-nav { margin-bottom: 30px; text-align: center; }

.p-social-nav__item { display: inline-block; margin-right: 20px; }
.p-social-nav__item:last-child { margin-right: 0; }
.p-social-nav__item a { color: #fff; }
.p-social-nav__item a::before { font-family: "design_plus"; transition-property: none; }
.p-social-nav__item a:hover { color: #e37100; }

.p-social-nav__item--facebook a::before { content: "\e902"; }

.p-social-nav__item--twitter a::before {font-family: 'tiktok_x_icon'; content: "\e901"; }

.p-social-nav__item--instagram a::before { content: "\ea92"; }

.p-social-nav__item--rss a::before { content: "\e90b"; }

 /**
	* widget area
	*/
.p-widget-area { background: #eeefef; }

.p-widget-area__inner { padding-top: 80px; padding-bottom: 80px; }

.p-widget-area__column { float: left; margin-right: 55px; width: -webkit-calc((100% - 110px) / 3); width: calc((100% - 110px) / 3); }
.p-widget-area__column:last-child { margin-right: 0; }

 /**
	* widget dropdown
	*/
.p-widget-dropdown { background: #131e20; font-size: 14px; height: 45px; line-height: 45px; position: relative; }
.p-widget-dropdown::after { color: #a9a9a9; content: "\e90e"; font-family: "design_plus"; position: absolute; top: 0; right: 17px; }
.p-widget-dropdown select { color: #fff; font-family: inherit; width: 100%; height: 100%; padding-left: 19px; padding-right: 17px; }

 /**
	* widget list
	*/
.p-widget-list li { font-size: 14px; }

.p-widget-list__item { background: #fff; font-size: 14px; line-height: 1.7; margin-bottom: 2px; }
.p-widget-list__item:last-child { margin-bottom: 0; }
.p-widget-list__item a { display: block; padding: 12px 52px 12px 22px; position: relative; }
.p-widget-list__item a::after { color: #aaa; content: "\e910"; font-family: "design_plus"; font-size: 16px; margin: auto; position: absolute; top: 50%; right: 12px; -webkit-transform: translateY(-50%); transform: translateY(-50%); }
.p-widget-list__item a:hover::after { color: #000; transition: none; }

.p-widget-list__item-date { color: #999; display: block; font-size: 12px; }

 /**
	* widget search
	*/
.p-widget-search { position: relative; }

.p-widget-search__input { height: 45px; line-height: 45px; padding: 0 10px; width: -webkit-calc(100% - 45px); width: calc(100% - 45px); }

.p-widget-search__submit { background: #131e20; color: #fff; cursor: pointer; font-family: "design_plus"; font-size: 20px; position: absolute; right: 0; width: 45px; height: 45px; }

 /**
	* widget
	*/
.p-widget { margin-bottom: 60px; }
.p-widget:last-child { margin-bottom: 0; }

.p-widget__title { font-size: 16px; margin-bottom: 20px; }

/* default widget */
.p-widget li { line-height: 1.7; }
.p-widget .calendar_wrap caption { margin-bottom: 20px; }
.p-widget .calendar_wrap tbody { line-height: 1.7; margin-bottom: 20px; }
.p-widget .calendar_wrap tfoot { line-height: 1.7; }
.p-widget .searchform { position: relative; }
.p-widget .searchform #s { height: 45px; line-height: 45px; padding: 0 55px 0 10px; width: -webkit-calc(100% - 45px); width: calc(100% - 45px); }
.p-widget .searchform #searchsubmit { background: #131e20; color: #fff; cursor: pointer; position: absolute; top: 0; right: 0; width: 45px; height: 45px; }

 /**
	* wordpress preset style
	*/
/* alignment */
.p-entry__body .alignright { float: right; }

.p-entry__body .alignleft { float: left; }

.p-entry__body .aligncenter { display: table; margin-left: auto; margin-right: auto; margin-bottom: 7px; }

.p-entry__body blockquote.alignleft, .p-entry__body img.alignleft { margin: 7px 24px 7px 0; }

.p-entry__body .wp-caption.alignleft { margin: 7px 14px 7px 0; }

.p-entry__body blockquote.alignright, .p-entry__body img.alignright { margin: 7px 0 7px 24px; }

.p-entry__body .wp-caption.alignright { margin: 7px 0 7px 14px; }

.p-entry__body blockquote.aligncenter, .p-entry__body img.aligncenter, .p-entry__body .wp-caption.aligncenter { margin-top: 7px; margin-bottom: 7px; }



/* image */
.p-entry__body img[class*="align"], .p-entry__body img[class*="wp-image-"], .p-entry__body img[class*="attachment-"], .p-entry__body .size-full, .p-entry__body .size-large, .p-entry__body .wp-post-image, .p-entry__body img { max-width: 100%; height: auto; }


/* table */
.p-entry__body table { margin: 0 0 24px 0; }

.p-entry__body td, .p-entry__body th { border: 1px solid #ddd;}

/* table style */
.table_no_border th, .table_no_border td { border: none; padding-left: 0; }

.table_border_horizontal th, .table_border_horizontal td { border-left: none; border-right: none; padding-left: 0; }

/* block quote */
.p-entry__body blockquote { margin: 0 0 25px 0; padding: 27px 30px 0; border: 1px solid #ccc; box-shadow: 0px 4px 0px 0px #f2f2f2; position: relative; }

.p-entry__body blockquote:before { content: '"'; font-style: italic; font-size: 30px; font-weight: normal; line-height: 40px; width: 30px; height: 30px; position: absolute; top: 5px; left: 10px; color: #5cbcd7; }

.p-entry__body blockquote:after { content: '"'; font-style: italic; font-size: 30px; font-weight: normal; text-align: left; line-height: 60px; width: 30px; height: 30px; position: absolute; bottom: 7px; right: -2px; color: #5cbcd7; }

.p-entry__body blockquote cite { border-top: 1px dotted #aaa; display: block; padding: 20px 0 0 0; font-style: italic; text-align: right; font-size: 90%; }

/* captions */
.p-entry__body .wp-caption { margin-bottom: 24px; background: #fff; border: 1px solid #ccc; padding: 5px; max-width: 100%; -webkit-border-radius: 5px; -moz-border-radius: 5px; border-radius: 5px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

.p-entry__body .wp-caption-text { text-align: center; font-size: 12px; font-style: italic; line-height: 1.5; margin: 9px auto; }

.p-entry__body .wp-caption img[class*="wp-image-"] { display: block; margin: 0 auto; }


/* etc */
.p-entry__body .wp-smiley { border: 0; margin-bottom: 0; margin-top: 0; padding: 0; }

.p-entry__body address { margin: 0 0 24px 0; line-height: 2.2; }

.p-entry__body pre { border-left: 5px solid #7fc120; font-size: 12px; margin: 0 0 27px 0; line-height: 25px; background: url(img/common/pre.gif) repeat left top; padding: 0 17px; overflow: auto; }

.p-entry__body .mejs-container { margin: 12px 0 25px; }

/* Utility ----------------------------------------------------------------- */
/** clearfix */
.u-clearfix::after { clear: both; content: " "; display: table; }

/** float */
.u-left { float: left; }

.u-right { float: right; }

/** hidden */
.u-hidden { display: none; }

@media only screen and (max-width: 991px) { .u-hidden-sm { display: none; } }
/** overflow */
.u-overflow-hidden { overflow: hidden; }

/**  Column layout - カラムレイアウト  */
.post_row { line-height: 2; margin-left: -15px; margin-right: -15px; }
.post_row:before, .post_row:after { content: " "; display: table; }
.post_row:after { clear: both; }

.post_col, .post_col-2, .post_col-3 { float: left; margin-bottom: 2em; min-height: 1px; padding-left: 15px; padding-right: 15px; position: relative; width: 100%; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }

@media screen and (min-width: 768px) { .post_col-2 { width: 50%; /* 2カラム */ }
  .post_col-3 { width: 33.33333%; } }
@media screen and (min-width: 1024px) { .post_col-2 { width: 50%; /* 2カラム */ }
  .post_col-3 { width: 33.33333%; } }
/** headline - 見出しのスタイル */
.style3a, .style3b, .style4a, .style4b, .style5a, .style5b, .style6 { line-height: 1.6; }

/* h3 */
.style3a { border-top: 1px solid #222; border-bottom: 1px solid #222; font-size: 22px; font-weight: 400; margin: 3em 0 1.5em; padding: 1.1em .2em 1em; }

.style3b { background: #fafafa; border-top: 2px solid #222; border-bottom: 1px solid #ddd; box-shadow: 0px 1px 2px #f7f7f7; font-size: 22px; font-weight: 400; margin: 3em 0 1.5em; padding: 1.1em .9em 1em; }

/* h4 */
.style4a { border-bottom: none; border-left: 2px solid #222; font-size: 18px; font-weight: 400; margin: 2.5em 2px 1.2em; padding: .3em 0 .3em .8em; }

.style4b { border-bottom: 1px dotted #aaa; font-size: 18px; font-weight: 400; margin: 2.5em 0 1.2em; padding: .9em 0 .8em; }

/* h5 */
.style5a { background: #f5f5f5; box-shadow: 0px 2px 0px 0px #f2f2f2; font-size: 18px; font-weight: 700; margin: 2em 0 1em; padding: .5em .8em .3em 1em; }

.style5b { background: #222; border-radius: 4px; box-shadow: 0px 2px 0px 0px #f2f2f2; color: #fff; font-size: 18px; font-weight: 400; margin: 2em 0 1em; padding: .5em .8em .4em 1em; }

/* h6 */
.style6 { color: #222; font-size: 16px; font-weight: bold; margin: 2em 0 1em; padding: .5em .8em .8em 1.3em; position: relative; }
.style6:before { background: #222; content: ""; position: absolute; top: .5em; left: .2em; width: 12px; height: 12px; }

.news_headline1 { border-left: 8px solid #444; font-size: 1.2em; line-height: 1.2; margin: 80px 0 25px 0; padding: .5em; position: relative; }
.news_headline1:after { border-bottom: 1px dotted #ddd; content: ""; position: absolute; bottom: 0px; left: 0; width: 100%; height: 0; }

.news_headline2 { border-left: 6px solid #545454; font-size: 1.1em; line-height: 26px; margin: 40px 0 20px 0; padding: 0 .5em; }

.balloon { background: #222; border-bottom: 0; clear: both; color: #fff; display: block; font-size: 20px; font-weight: 400; margin: 50px 0 22px; min-width: 115px; padding: .5em 18px .5em; position: relative; text-align: left; width: auto; z-index: 0; }
.balloon:after { border-color: #222 transparent transparent transparent; border-style: solid; border-width: 10px 10px 0 10px; bottom: -10px; content: ""; display: block; margin-left: -10px; position: absolute; left: 30px; width: 0px; height: 0px; }

/** flame - 囲み枠  */
.well { background-color: #f5f5f5; line-height: 2; border: 1px solid #e3e3e3; border-radius: 4px; margin-bottom: 20px; min-height: 20px; padding: 19px; -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05); box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.05); }

.well2 { margin: 1em 0 30px; padding: 1em 1.5em; line-height: 2; border: 1px solid #cdcdcd; background: #fcfcfc; box-shadow: 0 1px 3px 0 rgba(195, 195, 195, 0.3); }

.well3 { margin: 2em 0 2.5em; padding: 1em 1.5em; line-height: 2; border: 1px dashed #cdcdcd; background: #fcfcfc; box-shadow: 0 1px 3px 0 rgba(195, 195, 195, 0.3); }

.wl_red { background-color: #f2dede; border-color: #ebccd1; color: #a94442; }

.wl_yellow { background-color: #fcf8e3; border-color: #faebcc; color: #8a6d3b; }

.wl_blue { background-color: #d9edf7; border-color: #bce8f1; color: #31708f; }

.wl_green { background-color: #dff0d8; border-color: #d6e9c6; color: #3c763d; }

/** button - CSSボタンのスタイル  */
.q_button { background-color: #535353; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15); box-sizing: border-box; color: #fff !important; display: inline-block; font-size: 100%; font-weight: 400; min-width: 200px; margin: 0; max-width: 90%; padding: .6em 1.3em .5em; transition: all 0.3s ease-in-out 0s; text-decoration: none; text-align: center; vertical-align: middle; }
.q_button:hover, .q_button:focus { background-color: #7d7d7d; box-shadow: 0 2px 2px rgba(0, 0, 0, 0.15) inset; color: #fff; text-decoration: none; }
.q_button_wrap{ text-align:center; margin: 2em auto; }

/* Button option */
.rounded { border-radius: 6px; }

.pill { border-radius: 50px; }

.sz_full { display: block; font-size: 110%; max-width: 100%; min-width: 100px; padding: 1em 1.5em .9em; }

.sz_l { font-size: 110%; max-width: 90%; min-width: 350px; padding: .8em 1.5em .7em; }

@media screen and (max-width: 767px) { .sz_l { box-sizing: border-box; max-width: 100%; min-width: 0; width: 100%; } }
.sz_s { min-width: 100px; max-width: 90%; font-size: 85%; padding: .4em 1em .3em; }

.bt_red { background: #c01f0e; color: #fff; }
.bt_red:hover, .bt_red:focus { background-color: #d33929; color: #fff; }

.bt_yellow { background: #f1c40f; color: #fff; }
.bt_yellow:hover, .bt_yellow:focus { background-color: #f9d441; color: #fff; }

.bt_blue { background: #2980b9; color: #fff; }
.bt_blue:hover, .bt_blue:focus { background-color: #3a91c9; color: #fff; }

.bt_green { background: #27ae60; color: #fff; }
.bt_green:hover, .bt_green:focus { background-color: #39c574; color: #fff; }

/** Youtube responsive - Youtube動画のレスポンシブ表示 */
.ytube { position: relative; height: 0; margin-top: 20px; margin-bottom: 20px; padding-bottom: 56.25%; padding-top: 30px; overflow: hidden; }
.ytube iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important; }

/** Table responsive - テーブルのレスポンシブ表示 */
.rps_table { line-height: 2.0; }

@media only screen and (max-width: 480px) { .rps_table tr { display: block; margin-bottom: 1.5em; }
  .rps_table th, .rps_table td { display: list-item; list-style-type: none; border: none; } }




/** Contactform - お問い合わせフォーム */
.wpcf7 { background: #fafafa; border: 1px solid #ddd; font-size: 14px; margin: 0 0 2.5em !important; padding: 0; width: 100%; box-sizing: border-box; }
.wpcf7 form { margin: 1.5em 1.5em 0; }
.wpcf7 p { margin-bottom: 1em; font-size: 12px; }
.wpcf7 input, .wpcf7 textarea { border: 1px solid #ccc; box-sizing: border-box; line-height: 1.2; padding: 8px; width: 100%; }
.wpcf7 select, .wpcf7 input[type=checkbox], .wpcf7 input[type=radio] { border: 1px solid #ccc; max-width: 97%; padding: 8px; width: auto; }
.wpcf7 select, .wpcf7 .wpcf7-list-item-label { font-size: 14px; line-height: 1.2; }
.wpcf7 .wpcf7-list-item { display: block; }
.wpcf7 textarea { height: 300px; }
.wpcf7 input:focus, .wpcf7 textarea:focus { border: 1px solid #bbb; box-shadow: inner 0 0 5px rgba(0, 0, 0, 0.5); outline: none; }
.wpcf7 .wpcf7-submit, .wpcf7 .wpcf7-previous { box-sizing: border-box; position: relative; display: block; width: 225px; height: 48px; margin: 30px auto 0; background-color: #333333; cursor: pointer; border: none !important; color: #fff; text-align: center; text-decoration: none; font-size: 14px; line-height: 1.5; outline: none; -webkit-transition: all .3s; transition: all .3s; }
.wpcf7 .wpcf7-submit:before, .wpcf7 .wpcf7-submit:after { box-sizing: border-box; }
.wpcf7 .wpcf7-submit:hover, .wpcf7 .wpcf7-previous:hover { background-color: #666666; }
.wpcf7 .wpcf7-submit .wpcf7-not-valid { background: pink; }
.wpcf7 .wpcf7-submit .wpcf7-response-output { margin: 10px 0 0; padding: 8px 35px 8px 14px; -webkit-border-radius: 4px; -moz-border-radius: 4px; border-radius: 4px; }
.wpcf7 .wpcf7-submit .wpcf7-validation-errors { color: #B94A48; background-color: #F2DEDE; border: 1px solid #EED3D7; }
.wpcf7 .wpcf7-submit .wpcf7-mail-sent-ok { color: #3A87AD; background-color: #D9EDF7; border: 1px solid #BCE8F1; }
.wpcf7 .wpcf7-previous + br { display: none; }
.wpcf7 form .wpcf7-response-output{ margin: 2em 0.5em 2em; padding:0; border: none; text-align:center; }
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output{ color:#dc3232; font-size: 1em; }



.b { font-weight: 700; }

/* 太字 */
.u { text-decoration: underline; }

/* 下線 */
.del { text-decoration: line-through; }

/* 打ち消し線 */
/** font-color - フォントカラー */
.red { color: red; }



/* クイックタグ追加分 */
h2.style_h2 { font-size:26px; font-weight:600; line-height:1.4; margin: 3em 0 1.3em 0; text-align:center; }
h3.style_h3 { font-size:22px; font-weight:600; line-height:1.6; margin: 3em 0 1.3em 0; }
h4.style_h4 { font-size:20px; font-weight:600; line-height:1.6; margin: 2.3em 0 1em 0; }
h5.style_h5 { font-size:18px; font-weight:600; line-height:1.6; margin: 2.3em 0 1em 0; }
h6.style_h6 { font-size:16px; font-weight:600; line-height:1.6; margin: 2.3em 0 1em 0; }
@media screen and (max-width: 800px) {
  h2.style_h2 { font-size:20px; margin: 2.5em 0 1em 0; }
  h3.style_h3 { font-size:18px; margin: 2.3em 0 1em 0; }
  h4.style_h4 { font-size:16px; margin: 2.2em 0 1em 0; }
  h5.style_h5 { font-size:16px; margin: 2.2em 0 1em 0; }
  h6.style_h6 { font-size:14px; margin: 2.2em 0 1em 0; }
}
@media screen and (max-width: 600px) {
  h2.style_h2 { margin: 2.3em 0 1em 0; }
  h3.style_h3 { margin: 2em 0 1em 0; }
  h4.style_h4 { margin: 2em 0 1em 0; }
  h5.style_h5 { margin: 2em 0 1em 0; }
  h6.style_h6 { margin: 2em 0 1em 0; }
}

/* ----------------------------------------------------------------------
 汎用スタイルの追加
 https://tcd-theme.com/2023/09/utility-classes.html
---------------------------------------------------------------------- */
.p-entry__body .a_break { display: inline-block; }
@media (max-width: 767px) {
  .p-entry__body .is-pc { display:none!important; }
}
@media not all and (max-width: 767px) {
  .p-entry__body .is-sp { display:none!important; }
}
.p-entry__body .e_link {
  display: inline-block; position: relative; padding-right:1em;
}
.p-entry__body .e_link:after {
  font-family: 'design_plus'; content: '\e92a'; font-size: 100%; display: block;
  position: absolute; transition:none; margin-top:-0.1em;
  right:0; top:50%; -ms-transform: translateY(-50%); -webkit-transform: translateY(-50%); transform: translateY(-50%);
}
.p-entry__body img.frame {
  border: 1px solid #d2d2d2;
  -webkit-box-shadow: 0 6px 6px -6px #cccccc;
  -moz-box-shadow: 0 6px 6px -6px #cccccc;
  box-shadow: 0 6px 6px -6px #cccccc;
}




/********* fadeUp *************************************/
.delay-time{
	opacity: 0;
}
.delay-time02{
animation-delay: 0.2s;
}

.delay-time04{
animation-delay: 0.4s;
}

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:2s;
animation-fill-mode:forwards;
opacity:0;
	z-index:1;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(50px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeUpTrigger{
    opacity: 0;
}

/*main contents*/

.ggmap {
    position: relative;
    padding-bottom: 52%;
    padding-top: 0px;
    height: 0;
    overflow: hidden;
}
.gbad {
    padding-bottom: 32%;
}
.ggmap iframe, .ggmap object, .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.inner {
    width: 94%;
    max-width: 1300px;
    margin: 0 auto;
    position: relative;
}


/* scrolldown */
.scrolldown2 {
    position: absolute;
    left: 50%;
    z-index: 2;
    bottom: -150px;
}
.scrolldown2 span{
	position: absolute;
	left:10px;
	bottom:25px;
	color: #222;
	font-size: 95%;
	letter-spacing: 0.05em;
	-ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
	line-height:1;
font-family: josefin-sans, sans-serif;
}
.scrolldown2:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: -4px;
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #222;
    animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;
}
@keyframes circlemove{
      0%{bottom:95px;}
     100%{bottom:-5px;}
 }
@keyframes cirlemovehide{
      0%{opacity:0}
     50%{opacity:1;}
    80%{opacity:0.9;}
	100%{opacity:0;}
 }
.scrolldown2:after{
	content:"";
	position: absolute;
	bottom:0;
	left:0;
	width:1px;
	height: 100px;
	background:#222;
}

/********* fadeUp *************************************/
.delay-time{
	opacity: 0;
}
.delay-time02{
animation-delay: 0.2s;
}

.delay-time04{
animation-delay: 0.4s;
}

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:2s;
animation-fill-mode:forwards;
opacity:0;
	z-index:1;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(50px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeUpTrigger{
    opacity: 0;
}

/*font**/

.t_ttl01, .fea_ttl, .fea_num, .gree_ttl, .rec_ttl, .mv_catch{font-family: 'Shippori Mincho B1', serif !important;}


/*sec_mv**/
.mv_c01 {
    font-size: 310%;
    letter-spacing: 0.1em;
    color: #fff;
    margin-bottom: 15px;
    text-shadow: 0 0 20px #515151, 0 0 20px #515151, 0 0 20px #515151, 0 0 20px #515153, 0 0 20px #515151;
}
.mv_c02 {
    font-size: 160%;
    letter-spacing: 0.1em;
    color: #fff;
    text-shadow: 0 0 10px #515151, 0 0 10px #515151, 0 0 10px #515151, 0 0 10px #515151, 0 0 10px #515151;
}
.mv_catch {
    position: absolute;
    z-index: 1;
    top: 45%;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 80%;
    text-align: center;
}
.mv_left_contents {
    position: absolute;
    width: 60px;
    left: 0;
    top: 260px;
}
.ml_txt {
    writing-mode: vertical-lr;
    font-size: 16px;
    letter-spacing: 0.15rem;
    line-height: 60px;
}


/*news_sec**/
.pos_ul {
    width: 100%;
    position: relative;
    display: table;
}
.news_sec:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 150%;
    bottom: 0;
    z-index: -1;
    background: rgb(228, 255, 232);
    background: -moz-linear-gradient(133deg, rgba(228, 255, 232, 1) 0%, rgba(235, 245, 238, 1) 50%, rgba(215, 255, 234, 1) 100%);
    background: -webkit-linear-gradient(133deg, rgba(228, 255, 232, 1) 0%, rgba(235, 245, 238, 1) 50%, rgba(215, 255, 234, 1) 100%);
    background: linear-gradient(133deg, rgba(228, 255, 232, 1) 0%, rgba(235, 245, 238, 1) 50%, rgba(215, 255, 234, 1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#e4ffe8",endColorstr="#d7ffea",GradientType=1);
}
.news_sec {
    position: relative;
    padding: 70px 0 50px;
}
.post_m_block {
    position: relative;
    overflow-y: scroll;
    height: 310px;
}
.pos_li {
    width: 42%;
    float: left;
    position: relative;
}
.post_m_ttl {
    font-size: 180%;
    color: #CEB386;
    margin-bottom: 4px;
    line-height: 1;
    font-family: josefin-sans, sans-serif;
}
.post_m_ttl_sub {
    position: relative;
    border-bottom: solid 1px #9c9c9c;
    font-size: 80%;
    color: #6b5656;
    margin-bottom: 15px;
    padding-bottom: 8px;
}
.post_m_block a {
    display: block;
    position: relative;
    margin-bottom: 10px;
    padding: 10px 25px 16px;
    border-bottom: solid 1px #c9c9c9;
    color: #333333;
    transition: all 0.3s ease 0s;
}
.news_date {
    font-size: 85%;
    font-weight: 300;
    letter-spacing: 0;
    color: #6e6262;
}

.news_ttl {
    font-size: 110%;
    font-weight: 600;
    margin-bottom: 5px;
}
.news_txt {
    font-size: 90%;
}
.pos_left {
    width: 50%;
    float: left;
    margin-left: 8%;
    position: relative;
}
table.table01 tbody th {
    width: 25%;
    text-align: center;
    background: #fff;
   padding: 12px 0 22px;
    vertical-align: middle;
    font-size: 100%;
    font-weight: 600;
}
span.spa01 {
    color: #ff974b;
}
table.table01 tbody td {
    background: #fff;
    text-align: center;
    vertical-align: middle;
    padding: 12px 0 22px;
    color: #46BAAA;
}
th.mt_tr, td.mt_tr {
    padding: 22px 0 12px !important;
}
table.table01 thead td {
    font-size: 100%;
    font-weight: 600;
    padding: 12px 0;
    text-align: center;
}
table.table01 thead th {
    width: 25%;
    text-align: center;
    font-weight: 600;
    padding: 12px 0;
}
span.time_space {
    position: relative;
    margin: 0 10px 0 6px;
}
span.time_space:before {
    position: absolute;
    content: "";
    display: block;
    border-left: 7px solid #9f9f9f;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-right: 5px solid transparent;
    right: 0;
    left: 0;
    margin: 0 auto;
    top: 7px;
}
table.table01 {
    margin-bottom: 20px;
}
.time_txt span {
    background: #6D4747;
    border-radius: 100px;
    padding: 2px 9px 3px;
    font-size: 90%;
    color: #fff;
    font-weight: 500;
    margin-right: 10px;
}
.time_txt01 {
    font-size: 100%;
    text-align: center;
    margin-bottom: 5px;
}
.adress_txt01 {
    text-align: center;
    font-size: 105%;
}
.adress_txt01 span {
    margin-right: 15px;
}
.time_txt {
    font-size: 100%;
    text-align: center;
}
.btn_01 a:hover {
	opacity:0.7;
}
.btn_01 a {
    position: relative;
    display: block;
    background: #46BAAA;
    text-align: center;
    font-size: 110%;
    font-weight: 600;
    color: #fff;
    padding: 15px 0;
    border-radius: 100px;
    transition: all 0.3s ease 0s;
}

.btn_01 {
    width: 90%;
    max-width: 360px;
    margin: 30px auto 10px;
}
.btn_01 a:before {
    position: absolute;
    content: "";
    background: url(/wp-content/uploads/arrow_01.svg) center no-repeat;
    width: 8%;
    height: 100%;
    top: 0;
    right: 5%;
    background-size: contain;
}
.post_m_block::-webkit-scrollbar{
   width: 4px;
}
.post_m_block::-webkit-scrollbar-track{
   background-color: #fff;
}
.post_m_block::-webkit-scrollbar-thumb{
	background-color: #ddd;
}

.btn_news {
    position: absolute;
    display: inline-block;
    top: 15px;
    right: 0;
    font-size: 95%;
}
.btn_news a:hover{opacity:0.7}
.btn_news a {
    font-weight: 600;
    color: #454545;
    display: block;
    position: relative;
    padding: 5px 50px 5px 5px;
    transition: all 0.3s ease 0s;
}
.btn_news a:before {
    position: absolute;
    content: "";
    width: 40px;
    height: 40px;
    background: url(/wp-content/uploads/arrow_02.svg) center no-repeat;
    background-size: contain;
    right: 0;
    top: 0%;
}




/*sec_01**/

.sec_01 {
    padding: 70px 0;
    position: relative;
}
.t_ttl_sub {
    font-size: 180%;
    color: #CEB386;
    margin-bottom: 4px;
    font-family: josefin-sans, sans-serif;
    text-align: center;
}
.t_ttl01 span {
    color: #46BAAA;
    font-weight: 500;
}

.t_ttl01 {
    font-size: 220%;
    text-align: center;
    letter-spacing: 0.1em;
    font-weight: 500;
    margin-bottom: 30px;
}
.txtcen {
    text-align: center;
}

.t_txt01 {
    line-height: 2;
    margin-bottom: 20px;
}
.sec_01:before {
    position: absolute;
    width: 100%;
    height: 100%;
    content: "";
    top: 0;
    left: 0;
    background: rgb(255 255 255 / 75%);
}

.sec_01 {
    padding: 70px 0;
    position: relative;
    background: url(/wp-content/uploads/haikei_01.jpg) left no-repeat;
    background-size: 50% auto;
}


/*sec_02**/
.sec_02 {
    position: relative;
    padding: 70px 0 20px;
}


/* sec_medical */
.sec_medical .sub_ttl {
    color: #cfbc74;
    margin-bottom: 5px;
    font-size: 140%;
}
.sec_medical h3 {
    font-size: 220%;
    text-align: center;
    letter-spacing: 0.1em;
    line-height: 1.5;
    font-weight:500;
    color: #76869b;
}
.sec_medical {
    position: relative;
    padding: 50px 0 70px;
    background: #f9f9f9;
}

#m_menu li {
    width: 17%;
    margin: 0 1.5% 4%;
    float: left;
    transition: all 0.3s ease 0s;
    position: relative;
}
#m_menu li p {
    background: #58c1b2;
    border-radius: 50%;
    width: 68%;
    aspect-ratio: 1 / 1;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
}
@supports not (aspect-ratio: 1 / 1) {
    #m_menu li p {
        position: relative;
        padding-top: 80%;
        height: 0;
        display: block;
    }

    #m_menu li p > * {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    }
}

#m_menu li img {
    width: 60%;
    height: auto;
}
#m_symptom li {
    width: 30.33%;
    margin: 0 1.5% 3%;
    float: left;
    text-align: center;
    transition: all 0.3s ease 0s;
}
span.menu_ispa {
    position: relative;
    display: inline-block;
    width: 6%;
    padding: 3%;
    border: solid 1px #fff;
    margin: 4%;
    vertical-align: middle;
    height: auto;
    max-width: 30px;
    border-radius: 100px;
}
span.menu_spa {
    font-size: 115%;
    color: #46baaa;
    letter-spacing: 0.1em;
    bottom: 0;
    display: block;
    text-align: center;
    font-weight: 600;
    margin-top: 13px;
}
span.short_spa {
    font-size: 80%;
    font-weight: 600;
    position: relative;
    top: 5px;
    left: -9px;
}



#m_symptom li a span {
    font-size: 110%;
    color: #fff;
    font-weight: 500;
}
#m_symptom li a:before {
    position: absolute;
    content: "";
    background: url(/wp-content/uploads/arrow_01.svg) center no-repeat;
    width: 9%;
    height: 100%;
    right: 12px;
    background-size: contain;
    top: 0;
}
#m_symptom li a {
    text-align: center;
    padding: 25px 0;
    position: relative;
    overflow: hidden;
    background: #48b5a5;
    width: auto;
    height: auto;
}





#m_disease li {
    width: 23%;
    margin: 0 1% 2%;
    float: left;
    transition: all 0.3s ease 0s;
}
#m_disease li a span {
    font-size: 110%;
    color: #fff;
    font-weight: 500;
}
span.reng_short {
    font-size: 90% !important;
    letter-spacing: 0;
}
#m_disease li a:before {
    position: absolute;
    content: "";
    background: url(/wp-content/uploads/arrow_01.svg) center no-repeat;
    width: 9%;
    height: 100%;
    right: 12px;
    background-size: contain;
    top: 0;
}
#m_disease li a {
    padding: 20px 0 20px 5%;
    background: #69b1b6;
    position: relative;
    overflow: hidden;
    height: auto;
    width: auto;
}
.m_menu_ttl {
    font-size: 110%;
    font-weight: 600;
    text-align: center;
}
.m_sym_tl {
    font-size: 120%;
    padding: 0 0 5px;
    border-bottom: solid 1px #acb0cb;
    margin: 5px auto 15px;
    text-align: center;
    color: #876a48;
}

/*==================================================
tab
===================================*/

.tab {
    flex-wrap: wrap;
    margin: 45px auto 0;
    width: 90%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.tab li a span {
    font-size: 13px;
    letter-spacing: 2px;
}
.tabli {
    width: 33%;
    text-align: center;
    position: relative;
}
.tab li a:before {
    position: absolute;
    content: "";
    display: block;
    right: 19px;
    top: 43%;
    border-right: 1px solid #5e5f73;
    border-bottom: 1px solid #5e5f73;
    width: 9px;
    height: 9px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.tab li.active a:before {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}
.tab li a {
    display: block;
    background: #E7E8D9;
    margin: 0 5%;
    padding: 27px 0 20px;
    font-size: 110%;
    letter-spacing: 0.1em;
    color: #614848;
    font-weight: 600;
    position: relative;
    line-height: 1.6;
}
.tab li.active a:after {
    position: absolute;
    content: "";
    background: linear-gradient(125deg, rgba(255, 255, 255, 0) 22%, rgba(255, 255, 255, 0.1) 22%, rgba(255, 255, 255, 0.1) 100%);
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}
.tab li.active a {
    background: #47bcab;
    position: relative;
    color: #fff;
    font-size: 115%;
}


.area {
    display: none;
    opacity: 0;
    background: #fff;
    padding: 55px 2% 25px;
    box-shadow: 2px 2px 10px #ddd;
}
.area ul {
    position: relative;
    width: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.area.is-active {
    display: block;
    animation-name: displayAnime;
    animation-duration: 2s;
    animation-fill-mode: forwards;
}
.area li a {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
}


.area li:hover {
    opacity: 0.7;
}


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


@media only screen and (max-width: 767px) {
	.tab {
    margin: 15px auto 0;
    width: 100%;
}
.tab li.active a {
    font-size: 85%;
}
.tab li a:before {
    width: 5px;
    height: 5px;
    right: 8px;
    top: 49%;
}
#m_disease li a:before, #m_symptom li a:before {
    width: 12%;
    right: 3%;
}
#m_symptom li a {
    padding: 18px 21px 18px 8px;
    text-align: left;
    line-height: 1.2;
}
#m_symptom li a span {
	font-size: 90%;}
#m_symptom li {
    width: 47%;
    margin: 0 1.5% 3%;
}
.area.is-active {
    padding: 35px 2% 25px;
}
span.menu_spa {
    font-size: 100%;
    margin-top: 2px;
        letter-spacing: 0.05em;
}
#m_menu li {
width: 30%;
        margin: 0 1.5% 5%;
}
.tab li a {
    font-size: 80%;
    line-height: 1.4;
        padding: 11px 0 7px;
}
}


/* END */




/**sec_03*/
.sec_03 {
    position: relative;
    padding: 70px 0 100px;
}
.fea_block01 {
    position: relative;
    margin: 50px auto 110px;
    padding-top: 50px;
}
.fea_block01:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 110%;
    top: 0;
    left: 0;
    background: rgb(255, 255, 255);
    background: -moz-linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.7008053221288515) 100%);
    background: -webkit-linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.7008053221288515) 100%);
    background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.7008053221288515) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#ffffff",endColorstr="#ffffff",GradientType=1);
}
.fea_block01:before {
    position: absolute;
    content: "";
    background: url(/wp-content/uploads/haikei_02.jpg) center no-repeat;
    width: 100%;
    height: 110%;
    background-size: cover;
    top: 0;
}

.fea_ul {
    position: relative;
    width: 100%;
    display: table;
    z-index: 1;
}
.fea_img_right {
    width: 45%;
    margin: 0 5% 0 0;
    float: left;
    position: relative;
}
.fea_img {
    width: 45%;
    margin: 0 0 0 5%;
    float: right;
    position: relative;
}
.image {
    height: 100% !important;
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
}
.fea_mm {
    display: block;
    width: 100%;
    position: relative;
    z-index: 1;
    overflow: hidden;
    height: 350px;
}
.fea_txt_li {
    width: 50%;
    float: left;
    position: relative;
}
.fea_bl {
    width: 100%;
    position: relative;
    display: table;
    margin-bottom: 12px;
}
.fea_num {
    font-size: 650%;
    line-height: 1;
    color: #E2C985;
    position: relative;
}
.fea_bl_left {
    width: 22%;
    float: left;
}
.fea_bl_right {
    float: left;
    position: relative;
    top: 15px;
}
.fea_sub_ttl {
    font-size: 140%;
    color: #897132;
    font-weight: 600;
}
.fea_sub_en {
    font-family: josefin-sans, sans-serif;
    color: #8C8C8C;
    font-size: 160%;
    line-height: 1;
    margin: 15px 0 5px;
}
.fea_ttl {
    font-size: 220%;
    color: #A18538;
    margin-bottom: 15px;
}
.greexd .fea_num {
    color: #46BAAA;
}
.greexd .fea_sub_en {
    color: #A3D5D4;
}
.greexd .fea_sub_ttl {
    color: #46BAAA;
}

.greecd {
    color: #46BAAA;
}
.fea_img02 {
    display: block;
    width: 100%;
    position: relative;
    z-index: 1;
    overflow: hidden;
    height: 330px;
}

.fea_li:last-child {
    margin: 0;
}

.fea_li {
    width: 45%;
    float: left;
    margin: 0 10% 0 0;
    position: relative;
}
.fea_block03:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 60%;
    background: #F4F5F0;
    top: 0;
    left: 0;
}

.fea_block03 {
    position: relative;
    padding: 75px 0 0;
    margin: 75px auto 0;
}

.fea_bl_left {
    width: 8vw;
    float: left;
    position: relative;
}

.deexd .fea_num {
    color: #9B8A5C;
}
.deexd .fea_sub_en {
    color: #7c6464;
}
.deexd .fea_sub_ttl {
    color: #735353;
}
.deexdttl{
    color: #8C632D;
}



/**sec_04*/
.sec_04:before {
    position: absolute;
    content: "";
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: rgb(255 255 255 / 50%);
}
.sec_04 {
    position: relative;
    background: url(/wp-content/uploads/haikei_04.jpg) center no-repeat;
    background-size: cover;
    padding: 70px 0;
}
.wh_block {
    background: rgb(255 255 255 / 80%);
    padding: 50px 5% 40px;
    position: relative;
}

.gree_ul {
    width: 100%;
    display: table;
    position: relative;
    margin: 0 auto;
}
.gree_sub_ttl {
    font-size: 210%;
    text-align: center;
    font-family: josefin-sans, sans-serif;
    color: #46BAAA;
    margin-bottom: 15px;
}
.gree_liimg .image {
    background-position: top center !important;
}

.gree_liimg {
    width: 35%;
    float: right;
    margin: 0 0 0 5%;
    position: relative;
    z-index: 1;
    overflow: hidden;
    height: 370px;
}
.gree_li {
    width: 60%;
    float: left;
    position: relative;
}
.gree_ttl {
    font-size: 180%;
    margin-bottom: 30px;
    text-align: center;
}




/**sec_recruit**/
.rec_contents {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    width: 90%;
}

.sec_recruit {
    position: relative;
    padding: 120px 0 100px;
}

.rec_inner {
    border-top: solid 1px #d2d2d2;
    border-bottom: solid 1px #d2d2d2;
    padding: 40px 3% 30px;
    position: relative;
}
.rec_ul {
    width: 100%;
    position: relative;
    display: table;
}
.rec_li_right {
    width: 70%;
    float: left;
    position: relative;
}

.rec_li_left img {
    border-radius: 500px;
    width: 90%;
}
.rec_li_left {
    width: 25%;
    float: left;
    position: relative;
    margin: 0 5% 0 0;
    text-align: center;
}

.rec_ttl {
    font-size: 170%;
    margin-bottom: 20px;
    color: #634949;
}
.rec_sub_ttl span {
    font-size: 210%;
    font-family: josefin-sans, sans-serif;
    color: #f09b9b;
    background: #fff;
    padding: 0 32px;
}
.rec_sub_ttl {
    position: absolute;
    top: -28px;
    left: 5%;
}

.kai_sp{display:none}


/*****top respon***************/

@media only screen and (max-width: 1400px) {
.news_sec .inner {max-width: 1200px;}.p-index-slider {padding-top: 46%;}
.mv_catch {
    top: 38%;
}
}

@media only screen and (max-width: 1200px) {
.mv_left_contents {top: 23%;}.sec_01 {background-size: 70% auto;}
.mv_catch {
    top: 30%;
}
}

@media only screen and (max-width: 1000px) {    
.p-index-slider {padding-top: 50%;}.ml_txt {font-size: 90%;}.scrolldown2 {bottom: -64%;}table.table01 tbody th {width: 30%;}.fea_mm {height: 300px;}.fea_img02 {height: 270px;}.pos_left {width: 54%;margin-left: 4%;}.mv_left_contents {top: 19%;}.fea_bl_left {width: 12vw;}.btn_news a:before {width: 30px;height: 30px;}
}

@media only screen and (max-width: 767px) {
.sp_kai {display: none;}.p-index-slider__item:first-child {background: unset;background-image: url(/wp-content/uploads/n_top01_sp.jpg) !important;background-position: center center !important;background-size: cover !important;}.p-index-slider {padding-top: 110%;width: 100%;}.kai_sp{display:block}.ml_txt {writing-mode: unset;line-height: 1;}.news_sec {padding: 50px 0 50px;}.pos_left {width: 100%;margin: 30px auto 0px;}.news_txt {font-size: 85%;}.post_m_block a {padding: 10px 10px 8px;background: rgb(255 255 255 / 60%);border-bottom: unset;}.post_m_block {height: 200px;}.fea_bl {display: block;}.fea_img02 {height: 180px;margin-bottom: 10px;}.fea_num {font-size: 570%;}.fea_li {width: 100%;float: unset;margin: 0 auto 70px;}.fea_block03 {padding: 50px 0 0;margin: 50px auto 0;}.fea_img_right {width: 100%;margin: 0 auto 10px;float: unset;}.fea_ttl {font-size: 180%;line-height: 1.6;}.wh_block {padding: 30px 3% 40px;}.f_logo {width: 80%;margin: 0 auto 20px;}.sec_footer {padding: 50px 0 20px;}.rec_inner {padding: 40px 0 0px;border-bottom: unset;}.infoli_right {float: unset;width: 100%;margin: 0 auto;}.hsr_tel a img, .hsr_web a img {max-height: 22px;vertical-align: middle;}.f_contact_flex_con {width: 100%;float: unset;margin: 0px auto 30px;}.f_contact_flex {margin: 20px auto 0;}.fc_ttl {font-size: 120%;}.fc_ttl span {padding: 0;}.f_contact_inner {width: 100%;}.fc_ttl:before{display:none}.btn_02 a {padding: 8px 0 8px 15px;text-align: left;font-size: 14px;}.infoli_left {width: 100%;float: unset;margin-bottom: 20px;}.rec_ttl {font-size: 140%;text-align: center;margin-bottom: 15px;}.rec_li_right {width: 100%;float: unset;}.rec_li_left {width: 50%;float: unset;margin: 0 auto 20px;}.rec_sub_ttl span {padding: 0 15px;}.rec_sub_ttl {left: 0;right: 0;margin: 0 auto;text-align: center;}.sec_recruit {padding: 90px 0 60px;}.sec_04 {padding: 50px 0;}.wh_block .btn_01 {margin: 40px auto 0;}.gree_ttl {font-size: 170%;line-height: 1.5;margin-bottom: 25px;}.gree_li {width: 100%;float: unset;}.gree_liimg .image {background-position: 100% 17% !important;}.gree_liimg {width: 100%;float: unset;margin: 0 auto 20px;height: 250px;}.gree_sub_ttl {font-size: 160%;}.fea_bl_left {width: auto;float: unset;position: absolute;top: -99%;z-index: 1;}.fea_bl_right {float: unset;top: 0;text-align: right;}.fea_txt_li {width: 100%;float: unset;}.fea_mm {height: 180px;}.fea_img {width: 100%;margin: 0 auto 15px;float: unset;}.fea_sub_ttl {font-size: 110%;}.fea_block01 {margin: 30px auto 70px;}.news_ttl {font-size: 100%;margin-bottom: 0;}span.time_space {margin: 0 7px 0 4px;}span.time_space:before {border-left: 5px solid #9f9f9f;border-top: 3px solid transparent;border-bottom: 3px solid transparent;border-right: 3px solid transparent;top: 5px;}table.table01 thead th, table.table01 thead td {font-size: 90%;padding: 8px 0;}table.table01 tbody th {font-size: 80%;padding: 10px 0 15px;}table.table01 tbody td {font-size: 80%;padding: 10px 0 15px;}th.mt_tr, td.mt_tr {padding: 15px 0 10px !important;}.t_ttl_sub {font-size: 130%;}.t_ttl01 {font-size: 170%;line-height: 1.6;}.btn_01 a {padding: 12px 0;}.adress_txt01 {font-size: 100%;}.time_txt, .time_txt01 {font-size: 95%;}.mv_left_contents {position: relative;width: 100%;text-align: center;padding: 15px 0;background: #fff;}.pos_li {width: 100%;float: unset;}.scrolldown2 {display: none;}.sec_01 {background-size: cover;background-position: center;padding: 70px 0 50px;}.sec_02 {padding: 70px 0 5px;}.sec_01:before {background: rgb(255 255 255 / 90%);}.sec_footer .time_txt, .sec_footer .time_txt01 {text-align: center;}.txtcen {text-align: left;}.inf_txt {text-align: center;}.access_txt {text-align: center;}
.fea_sub_en {
        font-size: 90%;
        margin: 0px;
        font-weight: 300;
    }
.m_sym_tl {
    font-size: 100%;
    padding: 0px 0 3px;
    margin: 5px auto 12px;
}
span.reng_short {
	font-size: 70% !important;}
#m_disease li a span {
    font-size: 90%;
white-space: nowrap;
}
#m_disease li {
    width: 47%;
    margin: 0 1.5% 3%;
}
#m_disease li a {
    padding: 18px 21px 18px 8px;
    text-align: left;
    line-height: 1.2;
}
#m_disease {
    padding: 10px 2% 25px;
}
.mv_c01 {
    font-size: 7vw;
}
.mv_c02 {
    font-size: 4vw;
    letter-spacing: 0.05em;
}
.mv_catch {
    top: 28%;
    width: 96%;
}
}


/*****下層ページ***************/

.k_ttl01, .txt02{font-family: 'Shippori Mincho B1', serif !important;}

.p-page-header__inner_in {
    position: absolute;
    top: 45%;
    left: 0;
    right: 0;
    margin: 0 auto;
}
.p-page-header_h1 {
    position: absolute;
    bottom: 10px;
    right: 0;
    color: #fff;
    font-size: 90%;
    letter-spacing: 0.05em;
}
.k_inner {
    position: relative;
    width: 90%;
    max-width: 1200px;
    margin: 100px auto;
}
.k_con {
    position: relative;
    margin: 0 auto;
    width: 94%;
}


.k_ttl01 {
    font-size: 200%;
    background: #69b3a9;
    padding: 15px 5px;
    color: #fff;
    text-align: center;
    position: relative;
    margin: 100px auto 70px;
}
.k_ttl01:before {
    position: absolute;
    content: "";
    background: linear-gradient(50deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.1) 10%, rgba(255, 255, 255, 0.1) 100%);
    width: 100%;
    height: 100%;
    right: 0;
    top: 0;
}
.k_ttl01:after {
    position: absolute;
    content: "";
    background: linear-gradient(-130deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 0.1) 10%, rgba(255, 255, 255, 0.1) 100%);
    width: 100%;
    height: 100%;
    right: 0;
    top: 0;
}

.k_ttl02 {
    font-size: 160%;
    font-weight: 600;
    border-top: solid 1px #614c4c;
    border-bottom: solid 1px #614c4c;
    text-align: center;
    padding: 18px 0;
    letter-spacing: 0.1em;
    margin: 50px auto;
    color: #614c4c;
}
.k_ttl02 span {
    font-weight: 600;
    font-size: 80%;
}
.k_ul {
    width: 100%;
    position: relative;
    display: table;
    margin: 0 auto 70px;
}
.mar_bo{
    margin: 0 auto;
}
.li_30 {
    width: 30.333%;
	margin: 0 1.5% 3%;
    float: left;
    position: relative;
}
.road_img {
    margin: 0 auto 10px;
}
.road_txt span {
    background: #6a5656;
    padding: 1px 5px;
    color: #fff;
    margin-right: 7px;
}
.space_line {
    margin: 30px auto;
    border-top: solid 1px #d1d1d1;
}
.road_txt {
    line-height: 1.7;
}
.road_txt02 {
    text-align: center;
    font-weight: 600;
    color: #495755;
    line-height: 1.5;
}
.txt01 {
    margin-bottom: 20px;
    line-height: 2;
}
.k_ttl03:before {
    position: absolute;
    content: "";
    width: 25px;
    border-top: solid 1px #82b8b2;
    top: 50%;
    left: 0;
}

.k_ttl03 {
    font-size: 140%;
    color: #46baaa;
    font-weight: 700;
    letter-spacing: 0.1em;
    margin: 0 0 10px;
    padding-left: 40px;
    position: relative;
}
.li_img_right {
    width: 37%;
    margin: 0 0 0 3%;
    float: right;
    position: relative;
}
span.spa02 {
    color: #c73b3b;
}
.li_img {
    width: 37%;
    margin: 0 3% 0 0;
    float: left;
    position: relative;
}
.li_txt {
    width: 60%;
    float: left;
    position: relative;
}

.space {
    height: 30px;
}

table.table03 td {
    border: unset;
    border-bottom: solid 1px #c8c8c8;
    padding: 20px 5px;
}

table.table03 th {
    width: 30%;
    border: unset;
border-bottom: solid 1px #24786c;
    text-align: center;
    padding: 20px 0;
    font-weight: 500;
}
table.table02 tbody td {
    text-align: center;
    vertical-align: middle;
    padding: 20px 0;
    border: unset;
    border-bottom: solid 1px #ddd;
    color: #7d6547;
}

table.table02 tbody th {
    text-align: center;
    vertical-align: middle;
    border: unset;
    border-bottom: solid 1px #ddd;
    padding: 20px 0;
}
table.table02 thead th {
    width: 25%;
}
table.table02 thead th, table.table02 thead td {
    background: #b59d7f;
    text-align: center;
    padding: 10px 0;
    color: #fff;
    font-weight: 600;
    border: unset;
}
.k_ul02 li:last-child {
    margin: 0;
}
table.reki_table td {
    border: unset;
    font-size: 95%;
    line-height: 1.5;
}
.reki_txt {
    font-weight: 600;
    border-bottom: solid 1px #656565;
    padding: 0 0 0 5px;
    margin-bottom: 10px;
}
table.reki_table {
    margin: 0 auto;
    width: 96%;
}
table.reki_table th {
    border: unset;
    width: 22%;
    padding: 5px 0;
    font-size: 95%;
}
.k_ul02 li {
    width: 48%;
    margin: 0 4% 0 0;
    float: left;
    position: relative;
}
.list_ul {
    width: 96%;
    display: table;
    position: relative;
    margin: 0 auto;
}
.list_ul li:before {
    position: absolute;
    content: "";
    width: 6px;
    height: 6px;
    background: #444;
    left: 0;
    top: 11px;
    border-radius: 10px;
}
.list_ul li {
    margin: 0 0 5px !important;
    width: 93%;
    padding-left: 13px;
    position: relative;
}
.box_01 {
    background: #f4f8f2;
    padding: 15px 4% 15px;
    position: relative;
}
.k_ul02 {
    width: 100%;
    display: table;
    position: relative;
}

.txt02 {
    font-size: 110%;
    line-height: 2.4;
}
.box_ri {
    background: #f5f6e3;
    padding: 20px;
    position: relative;
    box-shadow: 0px 0px 0px 10px #f5f6e3;
    border: solid 1px #c5cab2;
    margin: 0 auto;
}
.box_02 .k_ttl02 {
    margin: 0 auto 50px;
}
.box_02 {
    background: #f3fae9;
    padding: 50px 4%;
    box-shadow: 0px 80px 80px -80px rgb(0 0 0 / 20%);
    position: relative;
    margin-bottom: 100px;
}
.light_heigh {
    padding: 30px 4% 10px;
}
.box_02 .btn_01 {
    margin: 35px auto 0px;
}
.box_02 .k_ul {
    margin: 0 auto;
}
.k_ttl04 {
    font-size: 140%;
    font-weight: 600;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
    line-height: 1.6;
    color: #512f2f;
}

.list_ul01 {
    width: 100%;
    display: table;
    position: relative;
	margin: 0 auto 15px;
}
.list_ul01 li:before {
    position: absolute;
    content: "";
    width: 10px;
    height: 10px;
    background: #c6b999;
    left: 0;
    top: 10px;
    border-radius: 10px;
}
.list_ul01 li {
    margin: 0 0 5px !important;
    width: 93%;
    font-weight: 600;
	font-size:105%;
    padding-left: 20px;
    position: relative;
color: #5c5647;
}
table.table04 thead td {
    padding: 15px 0;
    text-align: center;
    background: #46baaa;
    border: solid 1px #fff;
    color: #fff;
    font-weight: 600;
}

table.table04 tbody td {
    padding: 15px 3%;
}
table.table04 th {
    width: 30%;
    padding: 15px 0;
    font-weight: 600;
    background: #e6fdfa;
    color: #29746a;
}
table.table06 td {
    vertical-align: middle;
    text-align: center;
    font-weight: 600;
    background: #fff7e2;
    border: solid 2px #707969;
}

table.table06 th {
    width: 80%;
    padding: 20px 2%;
    text-align: left;
    line-height: 1.5;
    font-weight: 500;
    background: #ecffdd;
    border: solid 2px #707969;
}
.li_50 {
    width: 50%;
    float: left;
    position: relative;
}
.list_box {
    padding: 20px 4%;
	background: #f7f6f0;
    margin-bottom: 30px;
    position: relative;
}
.list_ttl:before {
    position: absolute;
    content: "";
    width: 8px;
    height: 8px;
    background: #96b8c1;
    border-radius: 10px;
    top: 17px;
    left: 0;
}

.list_ttl {
    font-size: 110%;
    font-weight: 600;
    border-bottom: solid 1px #c1c1c1;
    padding: 5px 0 5px 20px;
    margin: 0 0 10px;
    position: relative;
    color: #34424d;
}

.list_box li:before {
    width: 10px;
    height: 10px;
    border: 2px solid #9a8669;
    display: block;
    content: '';
    position: absolute;
    top: 6px;
    left: 0px;
}
.list_box li:after {
    border-left: 2px solid #7a5d5d;
    border-bottom: 2px solid #7a5d5d;
    width: 12px;
    height: 5px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    position: absolute;
    top: 6px;
    left: 3px;
    content: '';
}

.list_box li {
    width: auto;
    float: left;
    position: relative;
    margin: 0 40px 15px 0;
    padding-left: 23px;
    line-height: 1.5;
    font-weight: 600;
}
.list_box ul {
    display: table;
    position: relative;
    width: 100%;
    margin-top: 20px;
}
.flow_ttl span {
    background: #fff;
    color: #4eaa9e;
    padding: 1px 7px;
    margin-right: 13px;
}

.flow_ttl {
    font-size: 115%;
    font-weight: 600;
    background: #dfefed;
    padding: 8px 15px 6px;
    margin-bottom: 10px;
}
.box_03 {
    border: solid 1px #a1a1a1;
    padding: 30px 4% 20px;
    position: relative;
}
.triangle {
    margin: 15px auto;
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 23px solid #86c2ba;
}
span.kakk_spa {
    background: #502d2d;
    color: #fff;
    letter-spacing: 0;
    padding: 2px 5px 2px 6px;
    margin-right: 15px;
}

.kai_sp{display:none}

.box_04 {
    background: #f1f5fa;
    padding: 25px 3% 5px;
    position: relative;
}
.txt03 {
    font-size: 105%;
    font-weight: 600;
    position: relative;
    padding-left: 9px;
    border-left: solid 5px #6d7e9a;
    line-height: 1.5;
    margin-bottom: 5px;
}
.bage_col {
    border-left: solid 5px #8b7067;
}

.box_05 {
    padding: 20px 4% 10px;
    background: #f4faf9;
    margin-bottom: 30px;
    position: relative;
}
.k_ttl05 {
    margin: 40px auto 20px;
    text-align: center;
    font-size: 160%;
    font-weight: 600;
    letter-spacing: 0.1em;
    color: #3f736c;
}

.k_ul03 {
    position: relative;
    width: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 0 auto 50px;
}
.k_li30:last-child {
    margin: 0;
}

.k_li30 {
    width: 31.333%;
    margin: 0 3% 0 0;
    float: left;
    position: relative;
    background: #f1f8f2;
    box-shadow: 0px 30px 30px -30px rgb(0 0 0 / 20%);
    padding: 0 0 30px;
}
.sac_txt {
    width: 80%;
    margin: 0 auto;
}
.sac_ttl {
    font-size: 120%;
    text-align: center;
    font-weight: 600;
    background: #cbe4e3;
    padding: 15px 0;
    margin: 0 auto 20px;
}

.k_ttl06:before {
    position: absolute;
    content: "";
    background: #512f2f;
    width: 12px;
    height: 12px;
    top: 11px;
    left: 0;
}
.k_ttl06 {
    font-size: 130%;
    font-weight: 600;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    line-height: 1.5;
    color: #512f2f;
    position: relative;
    padding-left: 20px;
}

.anchor_high {
    display: block;
	padding-top: 30px;
    margin-top: -30px;
}


/**下層respon***/

@media only screen and (max-width: 767px) {
	.p-page-header {
    height: 190px;
	}
.p-article02__title {
    font-size: 105%;
}
.p-article02__excerpt {
	font-size: 90%;}
.li_50 {
    width: 100%;
    float: unset;
}
.p-news-list__item {
    padding: 0px 5px 15px;
    margin-bottom: 20px;
}
.p-news-list {
    width: 100%;
    margin: 50px auto 100px;
}
.sac_txt {
    width: 90%;
}
.sac_ttl {
        margin: 0 auto 15px;
    padding: 10px 0;
    font-size: 110%;
}
.k_ul03 {
    display: block;
}
.k_li30 {
    width: 100%;
    margin: 0 auto 30px;
    float: unset;
    padding: 0 0 20px;
}
span.kakk_spa {
    margin-right: 9px;
}
.k_ttl01 {
    font-size: 150%;
    padding: 15px 10px;
    margin: 60px auto 35px;
    line-height: 1.5;
}
.k_ttl05 {
    font-size: 130%;
    margin: 30px auto 12px;
}
.txt03 {
    border-left: solid 3px #6d7e9a;
}
.k_inner {
    margin: 50px auto;
}
.p-breadcrumb {
    font-size: 80%;
}
.bread_inner {
    padding: 5px 0;
}
.p-page-header__title {
    font-size: 170%;
}
.li_txt {
    width: 100%;
    float: unset;
}
.box_02 .space_line {
    margin: 20px auto;
}
.box_02 .k_ttl04 {
    margin-bottom: 5px;
}
.k_ttl02 {
        font-size: 130%;
        padding: 18px 10px;
        margin: 30px auto;
        line-height: 1.5;
    }
.kai_sp{display:block}
.li_img_right {
    width: 100%;
    margin: 0 auto 20px;
    float: unset;
}
table.table02 tbody td {
    font-size: 90%;
}
.road_txt {
    font-size: 90%;
}
table.table02 thead th, table.table02 thead td {
    font-size: 90%;
}
table.table06 td {
    font-size: 85%;
    padding: 5px 2px;
}
table.table06 th {
    width: 73%;
    padding: 15px 3%;
    font-size: 90%;
}
.li_30 {
    width: 47%;
    margin: 0 1.5% 25px;
}
.txt01 {
    line-height: 1.8;
}
.list_ttl {
    font-size: 105%;
    line-height: 1.5;
padding: 5px 0 5px 12px;
}
.list_ttl:before {
    top: 14px;
    width: 6px;
    height: 6px;
}
.gbad {
    padding-bottom: 82%;
}
table.table02 tbody th {
    width: 30%;
    font-size: 90%;
}
.p-page-header_h1 {    
	font-size: 11px;
	left: 0;
	margin: 0 auto;}
table.table03 th, table.table03 td {
    font-size: 90%;
    padding: 14px 2px;
    text-align: left;
}
.k_ttl04 {
    font-size: 120%;
}
.triangle {
    border-left: 16px solid transparent;
    border-right: 16px solid transparent;
    border-top: 16px solid #86c2ba;
}
.flow_ttl span {
    padding: 1px 4px;
    margin-right: 7px;
}
.flow_ttl {
    font-size: 105%;
}
.k_con {
    width: 100%;
}
.box_03 {
    padding: 15px 15px 1px;
}
.k_ttl03 {
        font-size: 120%;
        padding-left: 35px;
	margin: 0 0 5px;
}
.list_ul01 li {
    font-size: 100%;
    line-height: 1.3;
    margin: 0 0 10px !important;
}
.list_ul01 li:before {
    top: 5px;
}
table.table04 tbody td {
    padding: 10px 3%;
    line-height: 1.4;
}
table.table04 th {
    padding: 10px 5px;
    line-height: 1.4;
    text-align: left;
    font-size: 95%;
    width: 35%;
}
table.table04 thead td {
    font-size: 95%;
    padding: 10px 0;
}
.k_ul {
    width: 100%;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.box_ri {
    padding: 15px;
    width: 80%;
    margin: 0 auto;
}
.txt02 {
    font-size: 105%;
    line-height: 2;
}
.k_ul02 li {
    width: 100%;
    margin: 0 auto 30px;
    float: unset;
}
.box_02 .k_ttl02 {
    margin: 0 auto 30px;
    padding: 10px 0;
}
.box_02 .btn_01 {
    margin: 20px auto;
}
.box_02 {
        padding: 35px 5% 10px;
        margin-bottom: 50px;
    }
.box_02 .k_ttl02 {
    margin: 0 auto 30px;
}
.list_box li {
        margin: 0 40px 10px 0;
    padding-left: 18px;
}
.list_box li:after {
    width: 10px;
    height: 4px;
    top: 5px;
}
.list_box li:before {
    width: 8px;
    height: 8px;
    top: 5px;
}
.li_img {
    width: 100%;
    margin: 0 auto 20px;
    float: unset;
}
.space_line {
    margin: 20px auto;
}
.p-entry__inner--narrow {
    width: 100% !important;
}
.light_heigh {
    padding: 20px 4% 5px;
}
}






