@charset "UTF-8";
/*====== reset.css =====*/
abbr, address, article, aside, audio, b, blockquote, body, canvas, caption, cite, code, dd, del, details, dfn, div, dl, dt, em, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, p, pre, q, samp, section, small, span, strong, sub, summary, table, tbody, td, tfoot, th, thead, time, tr, ul, var, video { margin: 0; padding: 0; border: 0; outline: 0; font-size: 100%; vertical-align: baseline; background: 0 0; }

body { font-size: 14px; line-height: 1.4; font-family: Verdana,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ','ＭＳ Ｐゴシック','MS P Gothic',sans-serif; }

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

ul { list-style: none; }

blockquote, q { quotes: none; }

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

a { margin: 0; padding: 0; border: 0; font-size: 100%; vertical-align: baseline; background: 0 0; }

ins { background-color: #ff9; color: #000; text-decoration: none; }

mark { background-color: #ff9; color: #000; font-style: italic; font-weight: 700; }

del { text-decoration: line-through; }

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

table { border-collapse: collapse; border-spacing: 0; }

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

address { font-style: normal; }

/*====== clearfix =====*/
.clearfix:after { content: "."; display: block; clear: both; height: 0; visibility: hidden; }

.clearfix { min-height: 1px; }

* html .clearfix { height: 1px; /*¥*/      /*/
height: auto;
overflow: hidden;
/**/ }

/*====== box-sizing =====*/
html { -webkit-box-sizing: border-box; box-sizing: border-box; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }

*, *:before, *:after { -webkit-box-sizing: inherit; box-sizing: inherit; }

#wrapper { position: relative; overflow: hidden; }

/*====== font =====*/
@font-face {
    font-family: YuGothicM;
    src: local("Yu Gothic Medium");
}
body,
button, input, textarea {
    font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", HelveticaNeue, "游ゴシック Medium", YuGothic, "Yu Gothic Medium", "Yu Gothic", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
    font-weight: 500;
    letter-spacing: 0.065em;
    line-height: 1.75;
}

body {
    color: #333;
}

h1, h2, h3, h4, h5, h6 { margin-bottom: .8em; }

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

.font-en,
.page-title__en,
.svc-title__en,
.m-lb01__en,
.m-lb02__en,
.pager-list,
.error-404__en {
    font-family: "Montserrat", sans-serif;
}

.fw-n { font-weight: 400; }
.fw-m { font-weight: 500; }
.fw-sb { font-weight: 600; }
.fw-b { font-weight: 700; }

.fs-xs { font-size: .75em; }
.fs-s { font-size: .875em; }
.fs-l { font-size: 1.125em; }
.fs-xl { font-size: 1.25em; }

.font-ker { -webkit-font-feature-settings: "palt"; font-feature-settings: "palt"; }
.font-ker1 { letter-spacing: -0.4em; }
.font-ker2 { letter-spacing: -0.08em; }

.tleft { text-align: left; }
.tcenter { text-align: center; }
.tright { text-align: right; }

/*====== link =====*/
a { color: #333; -webkit-transition: opacity .7s; transition: opacity .7s; }

a:hover { opacity: 0.7; }

header a,
footer a,
.toggle-nav a {
    color: inherit;
    text-decoration: none;
}

.no-link { cursor: pointer; }

/*====== button =====*/
button, .js-tglBtn { outline: none; cursor: pointer; }

/*====== img =====*/
img { max-width: 100%; height: auto; vertical-align: top; }
iframe { max-width: 100%; vertical-align: top; }

/*====== wp style =====*/
/* Navigation */
.main-navigation { clear: both; display: block; float: left; width: 100%; }
.main-navigation ul { display: none; list-style: none; margin: 0; padding-left: 0; }
.main-navigation ul ul { -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2); box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2); float: left; position: absolute; top: 100%; left: -999em; z-index: 99999; }
.main-navigation ul ul ul { left: -999em; top: 0; }
.main-navigation ul ul li:hover > ul, .main-navigation ul ul li.focus > ul { left: 100%; }
.main-navigation ul ul a { width: 200px; }
.main-navigation ul li:hover > ul, .main-navigation ul li.focus > ul { left: auto; }
.main-navigation li { float: left; position: relative; }
.main-navigation a { display: block; text-decoration: none; }

/*** Small menu. ***/
.menu-toggle, .main-navigation.toggled ul { display: block; }

@media screen and (min-width: 37.5em) { .menu-toggle { display: none; }
.main-navigation ul { display: block; } }
.site-main .comment-navigation, .site-main .posts-navigation, .site-main .post-navigation { margin: 0 0 1.5em; overflow: hidden; }
.comment-navigation .nav-previous, .posts-navigation .nav-previous, .post-navigation .nav-previous { float: left; width: 50%; }
.comment-navigation .nav-next, .posts-navigation .nav-next, .post-navigation .nav-next { float: right; text-align: right; width: 50%; }

/* Accessibility */
/*** Text meant only for screen readers. ***/
.screen-reader-text { border: 0; clip: rect(1px, 1px, 1px, 1px); -webkit-clip-path: inset(50%); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute !important; width: 1px; word-wrap: normal !important; /* Many screen reader and browser combinations announce broken words as they would appear visually. */ }
.screen-reader-text:focus { background-color: #f1f1f1; border-radius: 3px; -webkit-box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6); box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6); clip: auto !important; -webkit-clip-path: none; clip-path: none; color: #21759b; display: block; font-size: 14px; font-size: 0.875rem; font-weight: bold; height: auto; left: 5px; line-height: normal; padding: 15px 23px 14px; text-decoration: none; top: 5px; width: auto; z-index: 100000; /* Above WP toolbar. */ }

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus { outline: 0; }

/* Alignments */
.alignleft { display: inline; float: left; margin-right: 1.5em; }

.alignright { display: inline; float: right; margin-left: 1.5em; }

.aligncenter { clear: both; display: block; margin-left: auto; margin-right: auto; }

/* Widgets */
.widget { margin: 0 0 1.5em; /* Make sure select elements fit in widgets. */ }
.widget select { max-width: 100%; }

/* Posts and pages */
.sticky { display: block; }

.updated:not(.published) { display: none; }

.page-content, .entry-content, .entry-summary { margin: 1.5em 0 0; }

.page-links { clear: both; margin: 0 0 1.5em; }

/* Comments */
.comment-content a { word-wrap: break-word; }

.bypostauthor { display: block; }

/* Infinite scroll */
/*** Globally hidden elements when Infinite Scroll is supported and in use. ***/
.infinite-scroll .posts-navigation, .infinite-scroll.neverending .site-footer { /* Theme Footer (when set to scrolling) */ display: none; }

/*** When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. ***/
.infinity-end.neverending .site-footer { display: block; }

/* Media */
.wp-smiley { border: none; margin-bottom: 0; margin-top: 0; padding: 0; }

/*** Make sure embeds and iframes fit their containers. ***/
embed, iframe, object { max-width: 100%; }

/*** Make sure logo link wraps around logo image. ***/
.custom-logo-link { display: inline-block; }

/* Captions */
.wp-caption { margin-bottom: 1.5em; max-width: 100%; }
.wp-caption img[class*="wp-image-"] { display: block; margin-left: auto; margin-right: auto; }
.wp-caption .wp-caption-text { margin: 0.8075em 0; }

.wp-caption-text { text-align: center; }

/* Galleries */
.gallery { margin-bottom: 1.5em; }

.gallery-item { display: inline-block; text-align: center; vertical-align: top; width: 100%; }
.gallery-columns-2 .gallery-item { max-width: 50%; }
.gallery-columns-3 .gallery-item { max-width: 33.33%; }
.gallery-columns-4 .gallery-item { max-width: 25%; }
.gallery-columns-5 .gallery-item { max-width: 20%; }
.gallery-columns-6 .gallery-item { max-width: 16.66%; }
.gallery-columns-7 .gallery-item { max-width: 14.28%; }
.gallery-columns-8 .gallery-item { max-width: 12.5%; }
.gallery-columns-9 .gallery-item { max-width: 11.11%; }

.gallery-caption { display: block; }

/*====== common style =====*/
.color-orange { color: #F38201; }
.color-green { color: #8CB806; }

.w100 { width: 100% !important; }

.mtp0 { margin-top: 0 !important; }
.mtp5 { margin-top: 5px !important; }
.mtp10 { margin-top: 10px !important; }
.mtp15 { margin-top: 15px !important; }
.mtp20 { margin-top: 20px !important; }
.mtp25 { margin-top: 25px !important; }
.mtp30 { margin-top: 30px !important; }
.mtp35 { margin-top: 35px !important; }
.mtp40 { margin-top: 40px !important; }
.mtp45 { margin-top: 45px !important; }
.mtp50 { margin-top: 50px !important; }
.mtp55 { margin-top: 55px !important; }
.mtp60 { margin-top: 60px !important; }
.mtp70 { margin-top: 70px !important; }
.mtp80 { margin-top: 80px !important; }

.mbt0 { margin-bottom: 0 !important; }
.mbt5 { margin-bottom: 5px !important; }
.mbt10 { margin-bottom: 10px !important; }
.mbt15 { margin-bottom: 15px !important; }
.mbt20 { margin-bottom: 20px !important; }
.mbt25 { margin-bottom: 25px !important; }
.mbt30 { margin-bottom: 30px !important; }
.mbt35 { margin-bottom: 35px !important; }
.mbt40 { margin-bottom: 40px !important; }
.mbt45 { margin-bottom: 45px !important; }
.mbt50 { margin-bottom: 50px !important; }
.mbt55 { margin-bottom: 55px !important; }
.mbt60 { margin-bottom: 60px !important; }
.mbt70 { margin-bottom: 70px !important; }
.mbt80 { margin-bottom: 80px !important; }

.fleft { float: left; }
.fright { float: right; }

.block { display: block; }
.iblock { display: inline-block; }
.hide { overflow: hidden; }

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.flex.is-wrap {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
}

/* box inner */
.m-inner {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-width: 1200px;
    width: 92.533%;
}

.m-inner_s {
    display: block;
    margin-left: auto;
    margin-right: auto;
    max-width: 1100px;
    width: 92.533%;
}

.m-inner .m-inner_s {
    width: 100%;
}

/* box inner margin ( paragraph ) */
.m-para * + * {
    margin-top: 1.75em;
}

/* icon */
.m-icon {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: .1em;
}

/* list */
.m-list-disc > li {
    position: relative;
    padding-left: 1.1em;
    text-indent: 0;
}

.m-list-disc > li::before {
    content: "・";
    position: absolute;
    left: 0;
}

/* blog thumbnail */
.thumb {
    position: relative;
    width: 100%;
    height: 0;
	overflow: hidden;
}

.thumb img {
    width: 100%; height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    position: absolute;
    top: 0; bottom: 0;
    left: 0; right: 0;
    margin: auto;
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}

/* Parallax */
.t--u {
	-webkit-transform: translate(0, -120px);
	        transform: translate(0, -120px);
}
.u--t {
	-webkit-transform: translate(0, 120px);
	        transform: translate(0, 120px);
}
.r--l {
	-webkit-transform: translate(120px, 0);
	        transform: translate(120px, 0);
}
.l--r {
	-webkit-transform: translate(-120px, 0);
	        transform: translate(-120px, 0);
}
.s--b {
    -webkit-transform: scale(0);
            transform: scale(0);
}
.u--t {
	opacity: 0;
	-webkit-transition: .8s;
	transition: .8s;
}
.t--u,
.r--l,
.l--r {
	opacity: 0;
	-webkit-transition: .8s;
	transition: .8s;
	-webkit-transition-delay: .2s;
	        transition-delay: .2s;
}
.t--u.active,
.u--t.active,
.r--l.active,
.l--r.active {
    opacity: 1;
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
}

.s--b {
	opacity: 0;
	-webkit-transition: .8s;
	transition: .8s;
	-webkit-transition-delay: .2s;
	        transition-delay: .2s;
}
.s--b.active {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
}