@charset "UTF-8";
/*
Theme Name:roadsafety
Version:2.1.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: #000;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
	font-family: 'Zen Kaku Gothic New', sans-serif !important;
    font-size: calc(17 / 1920 * 100vw);
	overflow-wrap: break-word;
}

.l-main {
    margin-top: 123px;
}

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(17 / 1199 * 100vw);}
	}
	
	@media (min-width: 768px) and (max-width: 1000px){
	body {
		font-size: calc(17 / 1000 * 100vw);}
	}
	
	@media (min-width: 501px) and (max-width: 767px){
	body {
		font-size: calc(18 / 767 * 100vw);}
	}
	
	@media (min-width: 300px) and (max-width: 500px){
	body {
		font-size: calc(18 / 500 * 100vw);}
	}


/* 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: #fff !important; padding-top: 50px; }

.l-footer__inner {
    width: 30%;
    float: left;
    margin: 0 5% 0 0;
}
.address_txt {
    font-size: 90%;
    margin-bottom: 5px;
}
.address_txt a:hover {
    opacity: 0.8;
    text-decoration: unset;
}

.address_txt a {
    text-decoration: underline;
}
.l-footer__flex {
    width: 94%;
    max-width: 1400px;
    margin: 0 auto 40px;
    display: table;
}
.l-footer__flex_right {
    width: 65%;
    float: left;
    position: relative;
}

.l-footer__logo {
    width: 80%;
    margin: 0 auto 32px 0;
}
.l-footer__logo a {
    display: block;
    position: relative;
}
.l-footer__logo.footer_logo_retina img { width:50%; margin:auto; }


/* Header ----------------------------------------------------------------- */
.l-header { background: rgba(19, 30, 32, 0.8); height: 123px; line-height: 123px; width: 100%; position: relative; z-index: 999; }
.l-header.is-fixed { position: absolute; top: 0; }
.l-header.is-active { height: 123px; line-height: 123px; position: fixed; top: 0; left: 0; -webkit-animation: slideDown 0.5s ease; animation: slideDown 0.5s ease; }
.l-header.is-fixed.is-active {
    top: 0 !important;
    box-shadow: 0 0 10px #c1c1c1;
}
.l-header.is-fixed.is-active.is-mobile-fix {
    animation: none;
    position: relative;
}

.l-header--large { height: 123px; line-height: 123px; position: absolute; 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-left: auto;
    margin-right: auto;
    position: relative;
    width: 100%;
    height: 100%;
}

.l-header__logo {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    position: relative;
}

.l-header__logo a { line-height: 1; 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; overflow: hidden; word-wrap: break-word;position: relative;}
.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: #999; font-family: "design_plus"; margin-left: 12px; margin-right: 12px; }

.c-breadcrumb__item--home a { color: #b2b2b2; }
.c-breadcrumb__item--home a::before { content: "\e90c"; font-family: "design_plus"; }
.c-breadcrumb__item--home span { display: none; }


 /**
	* 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 {
    display: none;
}
.c-menu-button:before {content: ""; background: url(/wp-content/uploads/c-menu.png);display: inline-block;width: 100%;background-size: contain;background-position: center;background-repeat: no-repeat;vertical-align: baseline;height: 100%;}
.p-menu-button {
    width: 75px;
    height: 75px;
    text-align: center;
    margin: 0px;
}




.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 {
    border-bottom: 1px solid #ddd;
    box-sizing: border-box;
    padding: 30px 30px 20.2px;
}

.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: 110%; font-weight: bold; line-height: 2; margin-bottom: 6px; }

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

.p-article02__excerpt { font-size: 14px; line-height: 2.4; }

 /**
	* 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 { font-size: 12px; line-height: 1.7; margin-bottom: 55.8px; }
.p-breadcrumb a:hover { color: #e37100; }

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

 /**
	* 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 {
    background: #0c68ab;
    color: #fff;
    font-size: 80%;
    padding: 15px 0;
    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 { position:relative}

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

.p-entry__body {
    margin: 150px auto;
}
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: #000;
    font-size: 95%;
    display: table;
    width: 100%;
}
.p-footer-nav li:before {
    position: absolute;
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 10px;
    background: #454545;
    top: 41%;
    left: 0px;
}

.p-footer-nav li {
    width: 47%;
    float: left;
    margin: 0 0 15px;
    position: relative;
    padding-left: 14px;
}

.p-footer-nav a { color: #000; }
.p-footer-nav a:hover { color: #454545;text-decoration:underline }

/*
```
<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%; }


@media only screen and (min-width: 1201px) { 
	.p-global-nav { display:block !important; }
.p-global-nav a:hover {
    color: #ddd;
}
}

nav {
    margin: 55px 150px 0 auto;
    width: auto;
}
.contact_clock a span {
    background: url(/wp-content/uploads/m_ico.png)center no-repeat;
    display: block;
    width: 28px;
    height: 24px;
    background-size: contain;
    position: absolute;
    top: 32px;
}
.contact_clock a {
    position: relative;
    color: #fff;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    height: 100px;
    font-size: 95%;
    font-weight: 500;
    letter-spacing: 1px;
    padding-top: 23px;
}
.contact_clock:hover {opacity:0.7}
.contact_clock {
    transition: all 0.3s ease 0s;
    position: absolute;
    right: 0;
    background: #0c68ab;
    line-height: normal;
    height: 123px;
    width: 137px;
}
span.spa_space {
    font-weight: 600;
    margin: 0 10px;
    font-size: 110%;
}
span.telspan {
    font-size: 140%;
    font-weight: 600;
    margin-right: 10px;
}
.tel_block {
    position: absolute;
    line-height: 1.5;
    margin: 12px 150px 0 auto;
    right: 0;
    display: table;
    width: auto;
    padding: 5px 22px;
    background: #66a9bc;
    border-radius: 100px;
    letter-spacing: 1px;
    font-size: 90%;
    font-weight: 600;
	color: white;
}

.p-global-nav > li { float: left; line-height: 4; }
.p-global-nav > li.menu-item-has-children:hover > .sub-menu { top: 100%; }
.p-global-nav > li > a { padding-left: 22px; padding-right: 22px; }
.p-global-nav > li > .sub-menu { top: 75%; left: 0; }
.p-global-nav a {
    color: #000;
    display: block;
    font-weight: 600;
    letter-spacing: 1px;
}
.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; }
.p-global-nav .sub-menu a {
    background: #13307f;
    box-sizing: border-box;
    padding: 15px 19px;
    width: 220px;
    color: #fff;
}




/* nav-mobile時 */
@media only screen and (max-width: 1200px){
nav {
    margin: 0 auto;
}
	.p-global-nav .menu-item-has-children>a>span::before {border: none !important;color:#fff !important;width: 57px !important;font-size: 17px !important;right: 5px !important;text-align: left !important;content: "▼" !important;}
	.p-global-nav li .sub-menu li {border-bottom: solid 1px #fff;}
.p-global-nav li {
border-left: unset;
    width: 86% !important;
    margin: 0 auto;
    text-align: center;
    border-bottom: solid 1px #fff;
}
.p-global-nav a {
    height: 60px !important;
    line-height: 60px !important;
    color: #ffffff !important;
    font-size: 115%;
    letter-spacing: 2px;
    font-weight: 500;
}
	#menu-item-340{display:none}
	.p-global-nav span { font-size: 9px;text-align: center;  line-height: 0; letter-spacing: 0.11em;text-indent: 3em;}
	nav {height: 0px;line-height: 0px;}
	.p-global-nav > .current-menu-item > a{color:#fff !important}
.p-global-nav {
    margin-top: 0;
    position: fixed !important;
    background: rgb(102 169 188 / 95%) !important;
}
span.gl_spa {
    color: #fff !important;
    text-align: center;
    display: block !important;
    margin: 0 auto;
    text-indent: 0 !important;
    top: -10px;
    position: relative;
}
.p-global-nav li img {
    position: relative;
    top: -24px;
}
.p-global-nav .sub-menu a {
    font-size: 100%;
    border-top: solid 1px #fff;
    border-bottom: unset;
    text-align: center !important;
    padding: 0 !important;
}
.p-global-nav li .sub-menu li {
    border-bottom: unset;
    margin: 0 auto;
    padding: 0 !important;
}
span.gl_spa:before {
    display: none !important;
}
.p-global-nav {
    display: none;
    position: absolute;
    top: 0 !important;
    left: 0;
    z-index: 99;
    width: 100%;
    padding-top: 60px;
}
}




 /**
	* headline
	*/
.p-headline {
    background: #0c68ab;
    box-sizing: border-box;
    color: #fff;
    font-size: 110%;
    height: 55px;
    line-height: 55px;
    margin-bottom: 45px;
    padding-left: 24px;
    padding-right: 24px;
    text-align: center;
    font-family: 'Zen Kaku Gothic New', sans-serif !important;
    font-weight: 500;
    letter-spacing: 2px;
    border-radius: 5px;
}

 /**
	* 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;
    width: 100%;
    padding-top: 43%;
    width: 80%;
    margin: 0 0 0 auto;
    border-radius: 15px 0 0 15px;
}

.p-index-slider__item {
    background-position: center center;
    background-size: 101% auto;
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
background-repeat: no-repeat;
}
.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; }

 /**
	* latest news
	*/
.p-latest-news { margin-bottom: 150px; }

.p-latest-news__title { background: #131e20; color: #fff; font-size: 16px; height: 55px; line-height: 55px; padding-left: 26px; position: relative; }

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

.p-latest-news__item a { border: 1px solid #ddd; border-top: 0; box-sizing: border-box; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; line-height: 54px; height: 54px; padding-left: 23px; padding-right: 45px; overflow: hidden; position: relative; width: 100%; }
.p-latest-news__item a::after { color: #aaa; content: "\e910"; font-family: "design_plus"; position: absolute; top: 0; right: 12px; bottom: 0; }
.p-latest-news__item a:hover { background: #f8f8f8; }
.p-latest-news__item a:hover::after { color: #000; }

.p-latest-news__item-date { color: #999; font-size: 12px; margin-right: 22px; line-height: 54px; height: 54px; }

.p-latest-news__item-title { font-size: 14px; overflow: inherit; text-overflow: ellipsis; white-space: nowrap; }

 /**
	* 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 { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; margin-bottom: 122px; }

.p-news-list__item {
    box-sizing: border-box;
    margin-bottom: 28px;
    width: 100%;
}
.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 {
    display: block;
    position: relative;
    height: 300px;
    background-size: cover !important;
    width: 75%;
    margin: 0 0 30px auto;
}
.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 {
    z-index: 2;
    position: absolute;
    left: -10%;
    top: 50%;
}

.p-page-header__title {
    color: #000;
    font-size: 120%;
    line-height: 1.3;
    letter-spacing: 2px;
    font-family: 'Zen Kaku Gothic New', sans-serif !important;
    font-weight: 600;
}

.p-page-header__desc {
    position: relative;
    z-index: 1;
    color: #0c68ab;
    font-size: 330%;
    font-style: italic;
    font-family: 'Jost', sans-serif;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1;
    margin-bottom: 25px;
    text-shadow: unset;
}

.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: #666666;
    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;  }
	}

 /**
	* review
	*/
.p-review__image { border-radius: 50%; float: left; margin-top: 11.2px; margin-right: 30px; width: 150px; height: 150px; }

.p-review__name { font-size: 16px; font-weight: bold; line-height: 2.4; }

.p-review__desc { font-size: 14px; line-height: 2.4; overflow: hidden; }

.p-review__button { background: #131e20; color: #fff; display: block; font-size: 14px; line-height: 50px; margin-top: 14px; margin-bottom: 9.8px; text-align: center; width: 200px; height: 50px; }
.p-review__button::after { content: "\e910"; font-family: "design_plus"; margin-left: 10px; }

/** review footer */
.p-review-footer { border-bottom: 1px solid #ddd; margin-bottom: 150px; text-align: right; }
.p-review-footer + .p-cta { margin-bottom: 150px; }

.p-review-footer__portrait { border-radius: 50%; display: block; margin: 0 auto 15px; width: 150px; height: 150px; }

.p-review-footer__name { font-size: 16px; margin-bottom: 15px; text-align: center; }

.p-review-footer__link { background: #131e20; box-sizing: border-box; color: #fff; display: inline-block; font-size: 14px; margin-bottom: -1px; padding: 0 15px; min-width: 200px; height: 50px; line-height: 50px; text-align: center; }
.p-review-footer__link:hover { background: #ff7f00; }
.p-review-footer__link span::before { content: "\e90f"; display: inline-block; font-family: "design_plus"; margin-right: 10px; }

/** review header */
.p-review-header { border-top: 1px solid #ddd; position: relative; }

.p-review-header__name { background: #ccc; box-sizing: border-box; color: #fff; display: inline-block; font-size: 16px; min-width: 200px; height: 50px; line-height: 50px; margin-top: -1px; margin-bottom: 54px; padding: 0 15px; text-align: center; }

.p-review-header__title { font-size: 30px; line-height: 1.4; margin-bottom: 54px; }

 /**
	* review list
	*/
.p-review-list { margin-bottom: 50px; }

.p-review-list__row { border-bottom: 1px solid #ddd; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; padding-top: 39px; }
.p-review-list__row:first-child { padding-top: 0; }
.p-review-list__row:last-child { border-bottom: 0; }

.p-review-list__item { padding-bottom: 40.2px; width: 46.0177%; }

.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; padding: 10px 15px 7px; line-height: 2.2; background: #fff; font-size: 14px; }

.p-entry__body th { background: #fafafa; font-weight: normal; }

/* 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; } }

/** Cardlink style - カードリンクのスタイル */
.cardlink {
  word-wrap:break-word; margin:15px 0 2em; padding:20px 20px 15px; border:1px solid #ddd; background:#fff; box-sizing:border-box;
  display:flex; flex-wrap:wrap; align-items:center;
}
.cardlink .image { margin-right:25px; }
.cardlink .image img { width:130px; height:130px; -o-object-fit:cover; object-fit:cover; }
.cardlink .content { width:calc(100% - 155px); padding-top:5px; box-sizing:border-box; }
.cardlink .title_area { }
.cardlink .meta { display:flex; flex-wrap:wrap; margin:0 0 5px 0; }
.cardlink .meta > p { color:#222; font-size:12px; line-height:1; margin:0 10px 10px 0; position:relative; padding:0 0 0 18px; box-sizing:border-box; }
.cardlink .meta > p.date:before {
  font-family:'design_plus_new'; content:'\e91d'; font-size:14px; position:absolute; left:0; top:45%; transform: translateY(-50%);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
.cardlink .meta > p.modified_date { margin-right:0; }
.cardlink .meta > p.modified_date:before {
  font-family:'design_plus_new'; content:'\e943'; font-size:13px; position:absolute; left:0; top:40%; transform: translateY(-50%);
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
.cardlink .title { margin:-3px 0 5px 0 !important; font-size:16px; font-weight:bold; line-height:1.7; }
.cardlink .title a { text-decoration:none; display:block; }
.cardlink .title a:hover { color:#aaa !important; }
.cardlink .desc { font-size:14px; line-height:1.7; margin:0 0 0 0 !important; max-height:3.4em; overflow:hidden; visibility:visible; }
.cardlink .desc span { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; }
@media screen and (max-width: 800px) {
  .cardlink { display:block; padding:12px; margin:30px 0 35px !important; box-sizing:border-box; }
  .cardlink .image { float:left; margin-right:15px; }
  .cardlink .image img { width:120px; height:120px; }
  .cardlink .content { width:auto; }
  .cardlink .title_area { width:calc(100% - 135px); float:left; height:120px; display:flex; flex-direction:column; justify-content:center; }
  .cardlink .meta { width:100%; margin-bottom:0px; }
  .cardlink .title { margin:0 !important; max-height:5.1em; overflow:hidden; visibility:visible; }
  .cardlink .title a { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:3; }
  .cardlink .desc { clear:both; padding:10px 0 0 0; max-height:3.4em; }
  .cardlink .desc span { -webkit-line-clamp:2; }
}

/* デザインされた番号付きリスト */
.q_styled_ol { counter-reset: item; list-style-type: none; margin-left:0 !important; margin-bottom:2em; }
.q_styled_ol li { display:-webkit-box; display:-webkit-flex; display:flex; margin-bottom:0.4em; }
.q_styled_ol li:before {
  counter-increment: item; content: counter(item);
  display:-webkit-box; display:-webkit-flex; display:flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  width:1.5em; min-width: 1.5em; height: 1.5em; background:#000;
  color: #fff; border-radius: 50%; line-height: 1; margin-top: 0.3em; margin-right: 0.7em;
}
@media screen and (max-width: 800px) {
  .q_styled_ol li:before { margin-top: 0.1em; }
}

/** Contactform - お問い合わせフォーム */
.wpcf7 {
    font-size: 100%;
    padding: 0;
    width: 100%;
    box-sizing: border-box;
display: block;
    background: #f9f9f9;
    padding: 20px 3%;
    border-radius: 15px;
}
.wpcf7 p { margin-bottom: 1em; font-size: 100%; }
.wpcf7 input, .wpcf7 textarea {
    border: 1px solid #ccc;
    box-sizing: border-box;
    line-height: 1.5;
    padding: 10px;
    width: 100%;
    border-radius: 5px;
}
span.wpcf7-form-control.wpcf7-acceptance {
    float: left;
}
.s_pry a:hover {
    opacity: 0.7;
    text-decoration: unset;
}

.s_pry a {
    color: #1D44C5;
    text-decoration: underline;
    font-weight: 600;
}
span.neki {
    color: #fff;
    background: #a7a5a6;
    font-size: 85%;
    padding: 0 7px 1px;
    border-radius: 5px;
    margin-left: 10px;
}
span.required {
    color: #fff;
    background: #fa1e32;
    font-size: 85%;
    padding: 0 7px 1px;
    border-radius: 5px;
    margin-left: 10px;
}

.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: 100%;
    line-height: 1.2;
}
.wpcf7{ display: block; }
.wpcf7-list-item {
    display: inline-block;
    margin: 0 25px 0 0;
}
.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; }

table.rec_table02 th {
    text-align: left;
    font-weight: 500;
    width: 30%;
    font-size: 100%;
    border: unset;
    padding: 15px 0;
    vertical-align: middle;
}
span.short {
    font-size: 80%;
    font-weight: 500;
}
table.rec_table02 td {
    font-size: 100%;
    border: unset;
    padding: 15px 0;
}


input.wpcf7-form-control.wpcf7-submit.has-spinner {
    position: relative;
    display: block;
    width: 90%;
    max-width: 350px;
    padding: 15px 0;
    text-align: center;
    background: #00bddc;
    border-radius: 100px;
    font-size: 95%;
    letter-spacing: 0;
    font-weight: 600;
    color: #fff;
    margin-top: 70px;
    transition: all 0.3s ease 0s;
    height: auto;
}
.pr_txt {
    font-size: 90% !important;
}

.pr_ttl {
    font-weight: 500;
    font-size: 110% !important;
    border-bottom: solid 1px #ddd;
    padding-bottom: 5px;
}
.pry {
    position: relative;
    display: block;
    overflow-y: scroll;
    height: 200px;
    background: #fff;
    padding: 20px;
    margin: 20px auto;
    border-radius: 10px;
}




.b { font-weight: 700; }

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

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

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


/* ヘッダーメッセージ */
#header_message {
    position: absolute;
    z-index: 2000;
    width: auto;
    box-sizing: border-box;
    font-size: 80%;
}


#header_message .label {
    display: block;
    line-height: 1.4;
}

#header_message a.label:hover { text-decoration: underline; }
@media (max-width: 767px) {
  #header_message { min-height:40px; font-size:12px; }
}


/* レスポンシブテーブル */
@media (max-width: 767px) {
  .p-entry__body .wp-block-table { overflow: auto; white-space: nowrap; margin-bottom: 2em; }
  .p-entry__body .wp-block-table { margin-bottom: 0; }
}


/* クイックタグ追加分 */
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;
}






/**********
 main contents
*********************************************/
.logo_up_txt {
    font-size: 90%;
    margin-bottom: 5px;
}
.head_logo_contents {
    width: 40%;
    max-width: 290px;
    text-align: center;
    line-height: initial;
    padding-left: 35px;
    margin-top: 30px;
}
.logo_under_txt {
    font-size: 105%;
    font-weight: 600;
    margin-top: 2px;
}

.l-header.is-fixed.is-active .logo_up_txt {
    display: none;
}
.l-header.is-fixed.is-active .head_logo_contents {
    margin-top: 3px;
}


/*main_visual*/
#main_visual:before {
    background: #F7F7F7;
    position: absolute;
    content: "";
    width: 100%;
    height: 53%;
    top: -124px;
}
#main_visual {
    position: relative;
}
.main_catch_block {
    position: absolute;
    left: 3%;
    top: 44%;
}


.top_banner a {
    position: relative;
    display: block;
}
.top_banner:hover {
    opacity: 0.7;
}
.top_banner {
    position: absolute;
    bottom: -90px;
    right: 2%;
    transition: all 0.3s ease 0s;
    width: 40%;
    max-width: 450px;
}
.ca_ttl {
    font-size: 280%;
    font-weight: 600;
    letter-spacing: 0.05em;
    margin-bottom: 20px;
text-shadow: 0px 0px 5px #ffffff;
}
.ca_txt01 {
    font-size: 140%;
    letter-spacing: 1px;
    font-weight: 700;
    padding-bottom: 5px;
    border-bottom: solid 2px;
    margin-bottom: 25px;
	text-shadow: 0px 0px 5px #ffffff;
}
.ca_txt02 {
    font-size: 105%;
    line-height: 2;
    font-weight: 500;
    letter-spacing: 1px;
	text-shadow: 0px 0px 5px #ffffff;
}


/*sec_message*/
.inner {
    width: 94%;
    max-width: 1400px;
    margin: 0 auto;
    position: relative;
}
#sec_message {
    position: relative;
    margin: 150px 0;
    padding: 50px 0;
}
#sec_message:after {
    position: absolute;
    content: "";
    background: rgb(26 46 110 / 90%);
    width: 90%;
    height: 100%;
    top: 0;
    right: 0;
    border-radius: 15px 0 0 15px;
}

#sec_message:before {
    position: absolute;
    top: 0;
    width: 90%;
    height: 100%;
    background: url(/wp-content/uploads/haikei01.jpg)center no-repeat;
    background-size: cover;
    content: "";
    right: 0;
    border-radius: 15px 0 0 15px;
}
.sub_ttl {
    position: relative;
    z-index: 1;
    color: #000;
    font-size: 250%;
    font-style: italic;
    font-family: 'Jost', sans-serif;
    font-weight: 400;
    letter-spacing: 4px;
    line-height: 1;
    margin-bottom: 10px;
    text-align: center;
}
.sub_se_ttl {
    position: relative;
    z-index: 1;
    font-weight: 600;
    color: #13307f;
    text-align: center;
}

#sec_message .sub_ttl, #sec_message .sub_se_ttl{color:#fff;
text-align:left}




#sec_message ul {
    position: relative;
    z-index: 1;
    width: 100%;
    display: table;
    margin-top: 75px;
}
.me_li70 {
    width: 80%;
    float: left;
    position: relative;
    z-index: 1;
}

.me_li30 img {
    border-radius: 200px;
    width: 75%;
}

.me_li30 {
    width: 20%;
    float: left;
    position: relative;
    z-index: 1;
    text-align: center;
}
.me_ttl {
    font-size: 150%;
    font-weight: 600;
    color: #fff;
    line-height: 1.5;
    margin-bottom: 30px;
}
.me_txt {
    color: #fff;
    font-weight: 500;
}

.btn_01 {
	max-width:300px;
    width: 90%;
    position: relative;
    margin: 30px auto 20px;
}
.btn_01 a {
    position: relative;
    display: block;
    background: #13307f;
    color: #fff;
    font-size: 100%;
    padding: 15px 0 15px 23px;
    font-weight: 500;
    border-radius: 100px;
    transition: all 0.3s ease 0s;
    font-weight: 600;
    font-size: 100%;
    letter-spacing: 1px;
}
.btn_01 a:before {
    content: "";
    position: absolute;
    transform: translateY(calc(-50% - 2px)) rotate(46deg);
    width: 8px;
    height: 1px;
    background-color: #ffffff;
    transition: 0.3s;
    right: 18px;
    bottom: 23px;
    transition: all 0.2s ease 0s;
}
.btn_01 a:after {
    content: "";
    position: absolute;
    transform: translateY(-50%);
    width: 53px;
    height: 1px;
    background-color: #ffffff;
    transition: 0.3s;
    right: 19px;
    bottom: 22px;
    margin: 0 auto;
    transition: all 0.2s ease 0s;
}
.btn_01 a:hover {
    opacity: 0.8;
}
.btn_01 a:hover:before {
    right: 6px;
}
.btn_01 a:hover:after {
    right: 7px;
}
.whbtn {
    margin: 50px 0 0;
}
.whbtn a {
    background: #fff;
    color: #000000;
}
.whbtn a:before{ background-color: #000;}
.whbtn a:after{ background-color: #000;}



/*sec_service*/

#sec_service {
    padding: 50px 0 20px;
    background: #437ba5;
    position: relative;
    margin-top: 150px;
	color: white;
}
#sec_service .sub_ttl {
	color: white;
}
#sec_service li:last-child {
    margin: 0;
}

#sec_service li {
    width: 30%;
    float: left;
    position: relative;
    margin: 0 5% 0 0;
}
#sec_service ul {
    margin: 40px 0;
    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;
}
.ser_img img {
    border-radius: 10px;
}
.ser_ttl {
    position: absolute;
    background: #13307f;
    border-radius: 10px 0px 10px 0px;
    color: #fff;
    font-size: 120%;
    font-weight: 600;
    letter-spacing: 1px;
    padding: 7px 50px;
}
.ser_img {
    margin-bottom: 20px;
}

#sec_service li .txt01 {
    width: 90%;
    margin: 0 auto;
}
.txt01 {
    font-size: 100%;
    margin-bottom: 20px;
}



/* #sec_case */
#sec_case {
    position: relative;
    margin: 100px auto;
}
#sec_case::before {
	content: '';
	position: absolute;
	top: 0;
	left: 5%;
	width: clamp(78px, 10vw, 130px);
	height: clamp(79px, 10vw, 132px);
	background: url(/wp-content/uploads/bird-blue.png) center / contain no-repeat;
	transform: scale(-1, 1);
}
.c-inner {
    width: 94%;
    margin: 0 auto;
    max-width: 1600px;
    position: relative;
}

.thum_img {
    display: block;
    width: 100%;
    height: 230px;
    position: relative;
    z-index: 0;
    overflow: hidden;
}
.thum_img .image {
    height: 100% !important;
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
    border-radius: 10px;
}
#sec_case .sub_se_ttl {
    margin-bottom: 65px;
}

.blog_ttl {
    font-size: 105%;
    font-weight: 500;
    margin: 10px 0;
}
.blog_txt {
    font-size: 95%;
}





/* #sec_guid */

#sec_guid {
    position: relative;
}

.gu_ul {
    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;
}
.gu_li_left:before {
    position: absolute;
    content: "";
    background: linear-gradient(-41deg, rgba(255,255,255,0) 82%, rgba(255,255,255,0.1) 22%, rgba(255,255,255,0.1) 100%);
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}

.gu_li_left {
    width: 40%;
    float: left;
    position: relative;
    background: #1a2c78;
    padding: 60px 5%;
}

.gu_li_right {
    width: 50%;
    float: left;
    background: url(/wp-content/uploads/t_img01.jpg)center no-repeat;
    background-size: cover;
}


.guid_img_sp {
    width: 100%;
    height: 300px;
    position: relative;
    z-index: 0;
    overflow: hidden;
	display:none
}
.guid_img_sp .image {
    height: 100% !important;
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
}
.gu_sub_ttl {
    position: relative;
}
.gu_sub_ttl p:before {
    position: absolute;
    content: "";
    width: 80px;
    right: -80px;
    border-top: solid 1px #fff;
    top: 50%;
    z-index: 0;
}

.gu_sub_ttl p {
    font-size: 110%;
    font-weight: 500;
    letter-spacing: 1px;
    color: #fff;
    position: relative;
    display: inline-block;
    padding: 0 20px 0 0;
    margin-bottom: 25px;
    line-height: 1;
}
.gu_ttl {
    font-size: 200%;
    font-weight: 600;
    color: #fff;
    letter-spacing: 0.05em;
}
.gu_in_ul {
    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: 20px 0 40px;
}

.gu_li span {
    font-size: 105%;
    font-weight: 600;
    color: #0c68ab;
}

.gu_li:last-child {
    margin: 0;
}
.gu_li {
    text-align: center;
    background: #fff;
    padding: 8px 0;
    width: 31.3%;
    margin: 0 3% 0 0;
    border-radius: 5px;
}
.gudiv {
    border: solid 1px #fff;
    border-radius: 5px;
    padding: 20px 4% 10px;
}
.gu_ttl_sub {
    font-size: 105%;
    font-weight: 500;
    color: #fff;
    border-bottom: solid 1px #fff;
    padding-bottom: 5px;
    margin-bottom: 10px;
}
.gudiv li:before {
    position: absolute;
    content: "";
    width: 5px;
    height: 5px;
    border-radius: 100px;
    background: #fff;
    top: 12px;
    left: 0;
}

.gudiv li {
    position: relative;
    float: left;
    margin: 0 5% 10px 0;
    width: auto;
    padding-left: 10px;
    color: #fff;
}
.gudiv ul {
    width: 100%;
    display: table;
    position: relative;
}
.gu_li_left .whbtn {
    margin: 40px auto 0;
}



/* sec_rec */
#sec_rec {
    position: relative;
    margin: 150px auto 100px;
}
#sec_rec ul {
    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: 50px 0 0;
}
#sec_rec li {
    width: 50%;
    float: left;
    position: relative;
}
.rec_li_right div {
    background: #2e90c6;
    position: relative;
    padding: 30px 5%;
}

.rec_li_left div {
    position: relative;
    background: #184160;
    padding: 30px 5%;
}
#sec_rec .whbtn {
    position: absolute;
    top: 20px;
    right: 5%;
    margin: 0 auto;
}
.rec_ttl {
    font-size: 130%;
    font-weight: 600;
    letter-spacing: 2px;
    color: #fff;
}
.partner_li:hover, .cmpany_li:hover {
    opacity: 0.7;
}
.partner_li {
    width: 46% !important;
    margin: 0 4% 0 0;
    background: url(/wp-content/uploads/b_haikei01.jpg)center no-repeat;
    background-size: cover;
	    border-radius: 10px;
		    transition: all 0.3s ease 0s;
}
.partner_li:before {
    position: absolute;
    content: "";
    background: rgb(110 110 109 / 75%);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 10px;
}
.cmpany_li {
    width: 46% !important;
    transition: all 0.3s ease 0s;
    margin: 0 0 0 4%;
    background: url(/wp-content/uploads/b_haikei02.jpg)center no-repeat;
    background-size: cover;
    border-radius: 10px
}
.cmpany_li:before {
    position: absolute;
    content: "";
    background: rgb(26 46 110 / 85%);
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 10px;
}
.partner_li a, .cmpany_li a {
    position: relative;
    height: 180px;
    color: #fff;
    letter-spacing: 2px;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
span.spa_02 {
    font-size: 95%;
    font-style: italic;
    font-family: 'Jost', sans-serif;
}

span.spa_01 {
    font-weight: 500;
    letter-spacing: 2px;
    font-size: 160%;
}
span.spa_01, span.spa_02 {
    display: contents;
}
.ban_ul {
    margin-top: 140px !important;
}





/* sec_topic*/
#sec_topic {
    position: relative;
    margin: 150px 0;
}

.news_block {
    border-bottom: solid 1px #ddd;
    margin-bottom: 30px;
    padding-bottom: 10px;
    display: table;
    width: 100%;
}
.news_block a:hover{opacity:0.7}
.news_block a {
    display: block;
    position: relative;
    transition: all 0.3s ease 0s;
}
.blog_date {
    font-size: 90%;
    width: 15%;
    position: relative;
    float: left;
}
.news_inbl {
    width: 85%;
    float: left;
    position: relative;
}
.news_inbl .blog_ttl {
    margin: 0px 0 15px;
}
.topic_block {
    max-width: 1000px;
}
#sec_topic .sub_se_ttl {
    margin-bottom: 50px;
}
.insta_block {
    max-width: 1000px;
    margin: 100px auto 150px;
}


/* sec_contact*/
#sec_contact {
    position: relative;
    padding: 70px 0;
    background: #f4f4f4;
}
#sec_contact::before {
	content: '';
	position: absolute;
	top: 15%;
	right: 5%;
	width: clamp(78px, 10vw, 130px);
	height: clamp(79px, 10vw, 132px);
	background: url(/wp-content/uploads/bird-purple.png) center / contain no-repeat;
}
#sec_contact li:last-child {
    margin: 0;
}
#sec_contact li {
    width: 32%;
    margin: 0 2% 0 0;
    float: left;
    text-align: center;
}
#sec_contact ul {
    width: 100%;
    display: table;
    position: relative;
    margin: 50px 0 0;
}
.con_sub_txt {
    text-align: center;
    margin-bottom: 10px;
}


.gr_btn a {
    background: #66a9bc;
}

.bl_btn a {
    background: #772e84;
}
.re_btn a {
    background: #1a2c78;
}
.con_btn a {
    position: relative;
    height: 110px;
    letter-spacing: 2px;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-radius: 7px;
    font-size: 130%;
    font-weight: 500;
    color: #fff;
transition: all 0.3s ease 0s;
}
.con_btn a:hover {
    opacity: 0.7;
}
.con_btn a span {
    font-family: 'Jost', sans-serif;
    font-size: 130%;
    letter-spacing: 0.04em;
}





/***respon***********************/

@media screen and (max-width: 1800px) {
	#sec_message .inner {
    max-width: 1200px;
}
#sec_message:before, #sec_message:after {
    width: 96%;
}
}

@media screen and (max-width: 1500px) {
.head_logo_contents {
    padding-left: 13px;
    margin-top: 16px;
}
.l-header__logo {
    width: 90%;
    margin: 0 auto;
}
}


@media screen and (max-width: 1200px) {
	.l-header, .l-header--large.is-active {
    background: unset !important;
}
#sec_message .inner {
    margin: 0 3% 0 auto;
    width: 91%;
}
.p-index-slider {
    padding-top: 53%;
}
.c-menu-button {
    position: fixed;
    top: 0;
    right: 0;
z-index: 999;
}
.contact_clock {
    display: none;
}
.logo_under_txt {
	font-size: 85%;}
.head_logo_contents {
    max-width: 230px;
    padding-left: 0;
    padding-top: 3px;
}
.logo_up_txt {
    display: none;
}
.head_logo_contents {
    margin-top: 0;
}
.tel_block {
    margin: 0 70px 0 0;
    top: 11px;
    font-size: 80%;
}
	.l-header.is-fixed.is-active{box-shadow: unset;}
#main_visual:before {
    top: -70px;
}
}



@media screen and (max-width: 767px) {
	.tel_block {
    display: none;
}
.l-footer__flex_right {
    width: 100%;
	float: unset;}
.l-footer__logo {
    width: 65%;
    margin: 0 auto 33px;
}
.l-footer__inner {
    width: 100%;
    float: unset;
    margin: 0 auto;
	text-align:center;
}
#sec_contact li {
    width: 100%;
    margin: 0 auto 30px;
	float: unset;}
.partner_li, .cmpany_li {
    width: 100% !important;
    margin: 0 auto 40px;
}
#sec_rec li {
    width: 100%;
	float: unset;}
#sec_rec {
    margin: 100px auto 70px;
}
.gu_li_right {
    display: none;
}
.gu_li_left {
    width: 100%;
    float: unset;
    padding: 60px 6%;
}
.guid_img_sp {
    display: block;
}
#sec_service li {
    width: 100%;
    float: unset;
    margin: 0 auto 30px;
}
.me_ttl {
    text-align: center;
}
.me_li70 {
    width: 100%;
    float: unset;
    margin-top: 26px;
}
.me_li30 img {
    width: 45%;
}
.me_li30 {
    width: 100%;
	float: unset;}
.p-index-slider {
    padding-top: 89%;
}
.p-index-slider__item {
	background-size: cover;}
}




@media screen and (max-width: 500px) {
.main_catch_block {
    width: 77%;
    left: 0;
    top: unset;
    bottom: -19%;
    background: rgb(255 255 255 / 75%);
    padding: 10px 15px 0px 12px;
    border-radius: 0 11px 0 0;
	}
.l-header__logo a {
    line-height: unset !important;
    height: auto !important;
}
.l-header.is-fixed.is-active .head_logo_contents {
    margin-top: 0;
    padding-top: 0;
    width: 35%;
}
.logo_under_txt {
    font-size: 10px;
    margin: 0px auto;
    font-weight: 500;
}
.l-header__logo {
    width: 100%;
    margin: 0;
    height: auto !important;
    padding: 6px 0 0 10px !important;
    display: block;
}
#sec_message {
    margin: 64% 0 0px;
}
.sub_ttl {
    font-size: 210%;
}
#sec_case {
    margin: 70px auto;
}
#sec_case .sub_se_ttl {
    margin-bottom: 30px;
}
.thum_img {
    height: 107px;
}
#sec_message .sub_ttl, #sec_message .sub_se_ttl {
    text-align: center;
}
#main_visual:before {
    height: 71%;
	}
.top_banner {
    bottom: -64%;
    width: 86%;
    margin: 0 auto;
    right: 0;
    left: 0;
}
.p-footer-nav li {
	width: 44%;}
.ca_txt02 {
    font-size: 80%;
	line-height: 1.7;}
.ca_ttl {
    font-size: 210%;
    margin-bottom: 6px;
    line-height: 1.5;
}
.ca_txt01 {
    font-size: 85%;
    padding-bottom: 5px;
    border-bottom: solid 1px;
    margin-bottom: 10px;
}
.whbtn {
    margin: 50px auto 0;
}
#sec_message:before, #sec_message:after {
    width: 100%;
    border-radius: 0;
}
.rec_li_left div, .rec_li_right div {
    padding: 10px 3% 18px;
}
#sec_message ul {
    margin-top: 40px;
}
.gudiv li:before {
    top: 10px;
	}
.topic_block {
    width: 86%;
}
.con_btn a {
    height: 74px;
    border-radius: 100px;
}
#sec_contact li {
    width: 88%;
}
#sec_contact li:last-child {
    margin: 0 auto;
}
.insta_block {
    max-width: 1000px;
    margin: 70px auto 100px;
}
.rec_ttl {
    font-size: 120%;
    text-align: center;
}
.news_inbl .blog_ttl {
    margin: 0px;
}
.blog_ttl {
	font-size: 100%;}
#sec_topic {
    margin: 70px 0;
}
span.spa_01 {
    font-size: 130%;
}
.partner_li a, .cmpany_li a {
    height: 130px;
}
.ban_ul {
    margin-top: 90px !important;
}
#sec_rec .whbtn {
    position: relative;
    margin: 13px auto 0px;
    right: 0;
    top: 0;
}
#sec_rec ul {
    margin: 20px 0 0;
}
#sec_rec {
    margin: 70px auto;
}
.gu_ttl {
	font-size: 170%;}
.guid_img_sp {
    height: 250px;
}
.gu_in_ul {
    margin: 20px auto;
}
.gu_li {
    padding: 2px 0;
}
.gu_li_left {
    float: unset;
    padding: 35px 7%;
}
}
	

/***下層ページ***********************/
.k_inner {
    width: 94%;
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
}
.k_ttl01 {
    font-size: 220%;
    margin: 100px auto 15px;
    text-align: center;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #0c68ab;
}
.k_ttl_sub {
    position: relative;
    z-index: 1;
    color: #66a9bc;
    font-size: 120%;
    font-style: italic;
    font-family: 'Jost', sans-serif;
    line-height: 1;
    margin-bottom: 25px;
    text-align: center;
    letter-spacing: 0.05em;
}
table.table01 th {
    width: 25%;
    font-size: 100%;
    font-weight: 500;
    border: unset;
    border-bottom: solid 1px #5a699f;
    vertical-align: middle;
    padding: 20px 0;
    background: unset;
letter-spacing: 1px;
}
table.table01 td {
    font-size: 100%;
    border: unset;
    border-bottom: solid 1px #c7c7c7;
    vertical-align: middle;
    padding: 20px 5%;
	line-height: 1.7;
letter-spacing: 1px;
}
table.table01 {
    margin: 50px auto;
}

table.history_table {
    margin: 50px auto;
}
table.history_table th {
    background: unset;
    border: unset;
    font-size: 110%;
    font-family: 'Jost', sans-serif;
    font-style: italic;
    vertical-align: baseline;
    padding: 0;
    width: 15%;
    text-align: left;
}
table.history_table td {
    border: unset;
    border-left: solid 1px #020202;
    border-bottom: solid 2px #fff;
    font-size: 105%;
    font-weight: 500;
    letter-spacing: 1px;
    position: relative;
    padding: 20px 5%;
}
table.history_table td:before {
    content: '';
    position: absolute;
    left: -6px;
    border-right: 6px solid transparent;
    border-top: 9px solid #ebb85b;
    border-bottom: 6px solid transparent;
    border-left: 6px solid transparent;
    bottom: -5px;
}

table.history_table td {
    border: unset;
    border-left: solid 1px #8d8989;
    font-size: 105%;
    font-weight: 500;
    letter-spacing: 1px;
    position: relative;
    padding: 20px 5%;
}
.ggmap {
    position: relative;
    padding-bottom: 43%;
    padding-top: 0px;
    height: 0;
    overflow: hidden;
}
.ggmap iframe, .ggmap object, .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.k_ul01 {
    width: 100%;
    position: relative;
    display: table;
    margin: 70px auto;
}
.k_imgenn img {
    border-radius: 500px;
    border: solid 4px #1a3d7d;
}
.k_txt01 {
    font-size: 100%;
    margin-bottom: 25px;
    letter-spacing: 1px;
}
.gree_name span {
    font-size: 140%;
    font-weight: 500;
    margin-left: 10px;
}

.gree_name {
    font-size: 110%;
    margin: 20px auto 0;
    text-align: center;
    font-weight: 500;
    letter-spacing: 1px;
}
.k_imgenn {
    width: 60%;
    margin: 0 auto;
}
.li_img {
    width: 50%;
    float: right;
    position: relative;
}
.li01_img {
    float: right;
    height: 450px;
    width: 50%;
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 10px;
}
.images {
    height: 100% !important;
    display: block;
    overflow: hidden;
    position: relative;
    width: 100%;
}
.li01_txt {
    float: left;
    width: 45%;
    position: relative;
	margin:0 5% 0 0;
}
.gree_ttl {
    font-size: 150%;
    font-weight: 600;
    margin-bottom: 30px;
    letter-spacing: 1px;
    margin-top: 20px;
}
.gree_txt {
    font-size: 100%;
}

.k_haikei_left:before {
    background: #d2e1e5;
    position: absolute;
    height: 60%;
    width: 70%;
    bottom: 0;
    content: "";
    max-height: 400px;
}
.k_haikei_left {
    position: relative;
    padding: 1px 0;
}
.k_ttl02 {
    font-size: 150%;
    font-weight: 500;
    letter-spacing: 2px;
    margin: 60px 0 20px;
}


.k_haikei_wide {
    position: relative;
    padding: 1px 0;
}
.k_haikei_wide:before {
    background: #F2F6FF;
    position: absolute;
    height: 60%;
    width: 100%;
    bottom: 0;
    content: "";
    max-height: 400px;
}
.k_ttl03:after {
    position: absolute;
    content: "";
    width: 20px;
    height: 20px;
    background: #66a9bc;
    top: 42%;
    left: 6px;
}

.k_ttl03:before {
    position: absolute;
    content: "";
    width: 20px;
    height: 20px;
    background: #1a2c78;
    top: 26%;
    left: 0;
}
.k_ttl03 {
    font-size: 180%;
    font-weight: 600;
    margin-bottom: 30px;
    letter-spacing: 0.05em;
    color: #0c68ab;
    padding-left: 49px;
    position: relative;
}



.k_haikei_right:before {
    background: #d2e1e5;
    position: absolute;
    height: 60%;
    width: 70%;
    bottom: 0;
    content: "";
    max-height: 400px;
    right: 0;
}
.k_haikei_right {
    position: relative;
    padding: 1px 0;
}
.k_ul02 {
    width: 100%;
    position: relative;
    display: table;
    margin: 70px auto;
}
.li02_img {
    float: left;
    height: 450px;
    width: 50%;
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 10px;
}
.li02_txt {
    float: left;
    width: 45%;
    position: relative;
    margin: 0 0 0 5%;
}


.gry_inner {
    padding: 1px 0 30px;
    position: relative;
    background: #f4f4f4;
    margin: 100px auto;
}
.flow_ttl {
    font-size: 130%;
    font-weight: 600;
    color: #0c68ab;
    border-bottom: solid 1px;
    padding: 0 0 10px 9px;
    margin-bottom: 20px;
}
.flow_txt {
    width: 94%;
    margin: 0 auto 20px;
    font-size: 100%;
}
.flow_txt a span {
    color: #fff;
}

.flow_txt a {
    background: #fa1e32;
    padding: 0 12px;
    margin-left: 11px;
    border-radius: 6px;
	color: white;
}
.flow_ttl span {
    background: #0c68ab;
    color: #fff;
    font-family: 'Jost', sans-serif;
    font-style: italic;
    font-size: 123%;
    padding: 2px 8px 0px 7px;
    margin-right: 22px;
}
.wh_box {
    background: #fff;
    text-align: center;
    padding: 30px 0;
    margin: 40px auto;
}
.triangle {
    margin: 30px auto;
    width: 0;
    height: 0;
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-top: 23px solid #9bcef1;
}
.whtxt {
    font-size: 110%;
    font-weight: 500;
    text-align: center;
}

.st_ttl{font-size:200%}
.k_ttl04 {
    font-size: 160%;
    margin: 100px auto 15px;
    text-align: center;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: #000;
    margin-bottom: 45px;
}
.k_ttl04 span {
    font-size: 80%;
    font-weight: 600;
    color: #5a73af;
}

.k_ttl04_sub {
    font-size: 100%;
    text-align: center;
    line-height: 2;
}
.li03_left img, .li03_left_right img {
    border-radius: 10px;
}
.li03_left_right {
    width: 35%;
    margin: 0 0 0 5%;
    float: right;
}
.li03_left {
    width: 35%;
    margin: 0 5% 0 0;
    float: left;
}
.li03_right {
    width: 60%;
    float: left;
}
.k_ttl06 {
    font-size: 150%;
    letter-spacing: 0.08em;
    font-weight: 600;
    color: #13307f;
    margin-bottom: 15px;
}
.k_ttl05 {
    font-size: 180%;
    letter-spacing: 0.05em;
    background: #0c68ab;
    text-align: center;
    padding: 15px 0;
    margin: 100px auto 70px;
    color: #fff;
    font-weight: 500;
}

.li04_right {
    width: 25%;
    float: left;
    position: relative;
}

.li04_left {
    width: 69%;
    margin: 0 6% 0 0;
    float: left;
    position: relative;
}
table.time_table td {
    border: unset;
    background: #ecf5f9;
    border-bottom: solid 20px #FFF;
    font-size: 95%;
    line-height: 1.5;
    padding: 20px;
}

table.time_table th:before {
    position: absolute;
    content: "";
    width: 15px;
    height: 15px;
    background: #0c68ab;
    border-radius: 20px;
    top: 0;
    left: -9px;
}
table.time_table th {
    background: unset;
    border: unset;
    border-left: solid 2px #0c68ab;
    position: relative;
    vertical-align: top;
    padding: 0 0 0 20px;
    line-height: 1;
    font-size: 95%;
    font-weight: 500;
    width: 25%;
}

.k_img_time {
    margin: 30px auto 60px;
}
.gry_inner .k_ttl05 {
    margin: 70px auto 70px;
}
.k_ttl06.bllt {
    font-size: 140%;
    color: #000;
    border-bottom: solid 1px;
    padding-bottom: 11px;
}
table.table03 th {
    width: 25%;
    background: #f3f9ff;
	border: solid 1px #ddd;
    font-size: 100%;
    font-weight: 500;
    letter-spacing: 1px;
    padding: 14px 0;
}

table.table03 td {
    border: solid 1px #ddd;
    font-size: 100%;
    letter-spacing: 1px;
    padding: 20px;
    line-height: 1.5;
}
table.table03 {
    margin: 50px auto;
}


.flex_ttl {
    text-align: center;
    font-size: 110%;
    font-weight: 600;
    margin-bottom: 10px;
    color: #0c68ab;
}
.flex_txt {
    font-size: 95%;
}
.flex_contents {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin: 70px auto;
}
.flex_box {
    flex: 1;
    padding: 20px;
    background: #e1f3fd;
    margin: 0 10px;
}


.k_box {
    background: #f4f4f4;
    padding: 1px 0 50px;
	text-align:center
}
.k_box .k_ttl04_sub {
    width: 90%;
    margin: 0 auto;
    background: #fff;
    padding: 10px 0;
}
.k_box .k_ttl01 {
    margin: 40px auto 15px;
    font-size: 146%;
    text-align: center;
    font-weight: 600;
    letter-spacing: 0.05em;
    background: #0c68ab;
    color: #fff;
    display: inline-block;
    padding: 0 25px;
}
.k_ul06 a {
    max-height: 82px;
}

.k_ul06 li {
    width: 44%;
    margin: 0 3%;
    float: left;
}
.k_ul06 {
    width: 100%;
    max-width: 800px;
    margin: 20px auto;
    display: table;
}


.p-page-header_cus:before {
    background: rgba(255, 255, 255, 0.2);
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    content: "";
}

.p-page-header_cus {
    height: 500px;
    width: 100%;
    margin: 0 auto 30px;
    position: relative;
    background-size: cover;
}
.p-page-header__desc span {
    font-size: 44%;
    font-weight: 600;
    position: absolute;
    bottom: -30px;
    right: 0;
}

/* 下層respon**/
@media screen and (max-width: 767px) {
.p-page-header {
    height: 230px;
    width: 85%;
}
table.table01 {
    margin: 20px auto;
}
.p-entry__body {
    margin: 50px auto;
}
.k_ttl01 {
    font-size: 180%;
    margin: 70px auto 15px;
}
.p-page-header__title {
    font-size: 100%;
}
.li_img {
    width: 100%;
    float: unset;
    margin: 0 auto 30px;
}
.k_ul06 li a {
    border-radius: 100px;
    max-height: 60px;
}
.k_ul06 li {
    width: 100%;
    margin: 0 auto 20px;
    float: unset;
    max-width: 300px;
    border-radius: 100px;
}
table.history_table th {
    width: 25%;
}
.li01_txt {
    float: unset;
    width: 100%;
    margin: 0 auto;
}
.k_ul01 {
    margin: 40px auto;
	}
.li01_txt {
    float: unset;
    width: 100%;
    margin: 0 auto;
}
.li01_img {
    height: 250px;
    width: 100%;
    margin: 0 auto 25px;
    float: unset;
}
.k_ttl03:after {
    width: 15px;
    height: 15px;
    top: 40%;
}
.li02_txt {
    float: unset;
    width: 100%;
    margin: 0 auto;
}
#sec_contact {
    padding: 50px 0;
}
.triangle {
    margin: 20px auto;
    width: 0;
    height: 0;
    border-left: 16px solid transparent;
    border-right: 16px solid transparent;
    border-top: 15px solid #9bcef1;
}
.flow_ttl span {
    margin-right: 11px;
    padding: 2px 6px 0px 3px;
}
.flow_ttl {
    font-size: 120%;
}
.wh_box {
    padding: 20px 0;
    margin: 25px auto;
}
.k_ul02 {
    margin: 40px auto;
}
.li02_img {
    float: unset;
    height: 250px;
    width: 100%;
    margin: 0 auto 25px;
}
.k_ttl03:before {
    width: 15px;
    height: 15px;
    top: 23%;
}
.k_haikei_left:before {
    width: 85%;
    bottom: 0;
    max-height: unset;
}
.k_haikei_right:before {
    width: 85%;
    max-height: unset;
}
.k_ttl03 {
    font-size: 150%;
    margin-bottom: 20px;
    padding-left: 34px;
}
.k_ttl03 {
    font-size: 150%;
}
.k_ttl05 {
    font-size: 150%;
    margin: 70px auto 15px;
    padding: 10px 0;
}
.k_haikei_wide:before {
    max-height: unset;
}
.p-page-header__desc {
    font-size: 200%;
    margin-bottom: 15px;
}
table.table01 th {
    padding: 10px 3px;
}
.k_ttl06.bllt {
	font-size: 130%;}
table.table01 td {
    padding: 10px;
	}
table.table03 th {
    padding: 10px 0;
    font-size: 95%;
}

table.table03 td {
    padding: 10px 15px;
    font-size: 95%;
}
.k_img_time {
    text-align: center;
    margin: 0px auto 32px;
}
.flow_txt a {
    display: block;
    position: relative;
    max-width: 80px;
    text-align: center;
    margin: 0 auto;
}
.k_img_time img {
    width: 66%;
}
table.time_table td {
    font-size: 90%;
    padding: 15px;
}
.li04_right {
    width: 100%;
    float: unset;
}
.li04_left {
    width: 100%;
    margin: 0 auto 25px;
    float: unset;
    position: relative;
}
.li03_right {
    width: 100%;
    float: unset;
}
.k_ttl06 {
    font-size: 130%;}
.li03_left_right {
    width: 100%;
    margin: 0 auto 25px;
    float: unset;
}

.li03_left {
    width: 100%;
    margin: 0 auto 25px;
    float: unset;
}
.k_ttl04 {
    font-size: 115%;
    margin: 50px auto 15px;
}
.p-page-header__inner {
    top: 45%;
    left: -8%;
}
}

.l-header.is-fixed.is-active .head_logo_contents {
    margin-top: 3px;
    display: flex;
    align-items: center;
}
@media screen and (max-width: 500px){
	.l-header.is-fixed.is-active .head_logo_contents,
	.l-header .head_logo_contents {
    width: 50%;
}
	.l-header.is-fixed.is-mobile-fix~.l-main {
    margin-top: 60px!important;
}
}

.logo_img {
	text-align: center
}
.logo_img img {
	max-width: 500px;
	margin: 0 auto;
}
.p-page-header {
	background-position: center right 40% !important;
}


.swiper {
    padding: 5% 3%!important;
}