@charset "utf-8";
/*
Theme Name:GAIA
Theme URI:https://tcd-theme.com/tcd102/
Description: "GAIA" is a theme that allows event information to be managed through a unique calendar UI, and is optimized for sites such as complex and live music club. The custom post type designed to introduce facilities and equipment can also be used as floor maps.
Author:TCD
Author URI:https://tcd-theme.com/
Version:1.11
Text Domain:tcd-gaia
*/

/* ------------------------------------------------------------------------------------
 web fonts　ウェブフォントファイルを変更した場合はv=1.0の数字を変更（キャッシュ対策）
------------------------------------------------------------------------------------ */

@font-face {
  font-family: 'design_plus';
  src: url('fonts/design_plus.eot?v=1.2');
  src: url('fonts/design_plus.eot?v=1.2#iefix') format('embedded-opentype'),
       url('fonts/design_plus.woff?v=1.2') format('woff'),
       url('fonts/design_plus.ttf?v=1.2') format('truetype'),
       url('fonts/design_plus.svg?v=1.2#design_plus') format('svg');
  font-weight: normal;
  font-style: normal;
}


/* ----------------------------------------------------------------------
 reset css
---------------------------------------------------------------------- */

* { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box; }
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%; vertical-align:baseline; }

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display:block; }
html { overflow-y: scroll; -webkit-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; box-sizing:border-box; font-size:100%; }
input, textarea { background-image: -webkit-linear-gradient(hsla(0,0%,100%,0), hsla(0,0%,100%,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; }
iframe { max-width:100%; }

/* input */
.visually-hidden { position: fixed !important; top: 0px !important; left: 0px !important; width: 4px !important; height: 4px !important; opacity: 0 !important; overflow: hidden !important; border: none !important; margin: 0 !important; padding: 0 !important; display: block !important; visibility: visible !important; }
img { max-width:100%; height:auto; vertical-align: bottom; }
button { color:#000; }

strong, h1, h2, h3, h4, h5, h6 { font-weight:600; }
body {
  font-family:Arial,sans-serif; font-size:16px; line-height:1; width:100%; position:relative; -webkit-font-smoothing:antialiased;
  overflow-wrap: break-word;
}

/* splide */
.splide.is-initialized > .splide__arrows:not(.splide__arrows--custom) { display:none; }

/* ----------------------------------------------------------------------
  CSS変数
---------------------------------------------------------------------- */

:root {

  /* 基本カラー */
  --tcd-accent-color:0,133,178;
  --tcd-sub-color:21,168,226;
  --tcd-hover-color:0,133,178;
  --tcd-bg-color:245, 245, 245;
  --tcd-link-color:21,120,214;

  /* Meiryo */
  --tcd-font-type1: Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  /* YuGothic */
  --tcd-font-type2: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
  /* YuMincho */
  --tcd-font-type3: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;

}

body, input, textarea, button { font-family: var(--tcd-font-type2); }

.post_content a:not(.q_custom_button) { color:rgba(var(--tcd-link-color, 21,120,214),1); }
.post_content a:hover:not(.q_custom_button) { text-decoration: underline; }

.post_content strong{font-weight: bold;}/** Androidの太字対策**/

body.is-fixed { position:fixed; top:0; left:0; }

/* ----------------------------------------------------------------------
 基本設定
---------------------------------------------------------------------- */

a { color:#000; text-decoration:none; }
a, a:before, a:after, input {
  transition-property:background-color, color, border-color; transition-duration:0.2s; transition-timing-function:ease;
}
.clear { clear:both; }
.hide { display:none; }
.post_content { word-wrap: break-word; }
a[href^="tel:"] { pointer-events:none; text-decoration:none; }
.mobile_device a[href^="tel:"] { pointer-events:auto; text-decoration:underline; }

/* ----------------------------------------------------------------------
 上付き文字、下付き文字
---------------------------------------------------------------------- */

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


/* ----------------------------------------------------------------------
  Layout
---------------------------------------------------------------------- */

.l-inner { max-width:1050px; width:calc(100% - 60px); margin:0 auto; }
@media (max-width: 767px) {
  .l-inner { width:calc(100% - 40px); }
}

.l-container { position:relative; height:100%; }
.l-container__inner { padding:100px 0 150px; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
.home .l-container__inner { max-width:100%; width:100%; padding:0; }

@media (max-width: 1200px) {
  .l-container__inner { -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
}
@media (max-width: 767px) {
  .l-container__inner { padding:40px 0; }
}

.l-main { max-width:100%; width:700px; }
.l-main:only-child { width:100%; }
@media (max-width: 767px) {
  .l-main { width:100%; }
}

.l-sidebar { max-width:100%; width:300px; }
@media (max-width: 1200px) {
  .l-sidebar { width:700px; margin-top:50px; }
  .l-sidebar__inner { margin:-50px 0 0 -40px; }
}
@media (max-width: 767px) {
  .l-sidebar { width:100%; margin-top:40px; }
  .l-sidebar__inner { margin:-40px 0 0 -20px; }
}
@media (max-width: 599px) {
  .l-sidebar__inner { margin-left:0; }
}


/* ----------------------------------------------------------------------
  Header
---------------------------------------------------------------------- */

.l-header { color:#fff; position: sticky; top:0; z-index:100; width:100%; background: rgba(var(--tcd-accent-color, 0,0,0),1); }
.l-header--sp { display:none; }
.l-header__inner { height:80px; }
@media (max-width: 1200px) {
  .p-fp-slider ~ .l-header { display: none; }
  .l-header--sp { display: block; position: fixed; top:0; left:0; }
  html:not(.show-drawer) .l-header--sp { transition: transform 0.4s cubic-bezier(0.22,0.61,0.36,1), visibility 0.4s ease; }
  .l-header--sp:not(.is-fix) {
    pointer-events: none; visibility: hidden;
    transform: translateY(-80px);
  }
}
@media (max-width: 767px) {
  .l-header__inner { height:60px; }
  .l-header--sp:not(.is-fix) { transform: translateY(-60px); }
}

/* ロゴエリア */
.l-header__logo { position: relative; width:300px; height:100%; padding:0 30px; }
.l-header__logo-image { height:100%; flex-shrink: 0; }
@media (max-width: 1200px) {
  .l-header__logo { width:calc(100% - 80px); }
}
@media (max-width: 767px) {
  .l-header__logo { width:calc(100% - 60px); padding:0 20px; }
}

/* ナビゲーション */
.l-header__nav { width:calc(100% - 300px); }
.l-header__nav-inner { position: relative; }
@media not all and (max-width: 1200px) {
  .l-header__nav--sp { display:none!important; }
}
@media (max-width: 1200px) {
  .l-header__nav { display: none; }
  .l-header__nav--sp { width:80px; height:100%; }
}
@media (max-width: 767px) {
  .l-header__nav--sp { width:60px; }
}

/* ハンバーガーメニュー */
button.p-menu-button { padding:10px; transition: opacity 0.2s ease; }
@media (hover: hover) and (pointer: fine) {
  button.p-menu-button:hover { opacity:0.5; }
}
.p-menu-button span { display:block; height:1px; width:22px; overflow:hidden; background:rgba(0,0,0,.3); }
.p-menu-button span:before {
  content:''; display:block; width:100%; height:100%; background:rgba(255,255,255,1);
  transform:translateX(0); transition:transform 0.2s ease;
}
.p-menu-button span:not(:first-of-type) { margin-top:7px; }
.p-menu-button span:nth-of-type(1):before { transition-delay: 0s; }
.p-menu-button span:nth-of-type(2):before { transition-delay: 0.1s; }
.p-menu-button span:nth-of-type(3):before { transition-delay: 0.2s; }

@media (max-width: 767px) {
  button.p-menu-button { height:60px; top:0; transform: none; }
}


/* ----------------------------------------------------------------------
  Footer
---------------------------------------------------------------------- */

.l-footer { overflow: hidden; background:rgba(var(--tcd-accent-color, 0,0,0),1); }

/* menu */
.l-footer__nav { padding:50px 0; border-bottom:1px solid rgba(255,255,255,0.2); }
.l-footer__nav-list li { font-size:14px; line-height:1.6; margin:-0.3em 0 -0.3em; }
.l-footer__nav-list a { color:#fff; }
@media (hover: hover) and (pointer: fine) {
  .l-footer__nav-list a:hover { color:rgba(var(--tcd-hover-color, 0,0,0),1); }
}

/* 縦並び */
.l-footer--type1 .l-footer__nav-list { width:25%; }
.l-footer--type1 .l-footer__nav-list:not(:last-of-type) { padding-right:20px; }
.l-footer--type1 .l-footer__nav-list li + li { margin-top:calc(30px - 0.3em); }
.l-footer--type1 .l-footer__nav-list li:first-of-type { font-size:16px; pointer-events: none; }
.l-footer--type1 .l-footer__nav-list li:first-of-type a { color:rgba(var(--tcd-sub-color, 0,0,0),1); }
@media (max-width: 1024px) {
  .l-footer--type1 .l-footer__nav-border { width:calc(100% + 60px); height:1px; margin:50px -30px; background:rgba(255,255,255,0.2); }
  .l-footer--type1 .l-footer__nav-list { width:50%; }
  .l-footer--type1 .l-footer__nav-list:nth-of-type(2),
  .l-footer--type1 .l-footer__nav-border + .l-footer__nav-list + .l-footer__nav-list { padding-right:0; }
}
@media (max-width: 767px) {
  .l-footer--type1 .l-footer__nav { display:none; padding:40px 0; }
  .l-footer--type1 .l-footer__nav-border { width:calc(100% + 40px); margin:40px -20px; }
}

/* 横並び */
.l-footer--type2 .l-footer__nav-list { width:100%; }
.l-footer--type2 * + .l-footer__nav-list { margin-top:50px; }
.l-footer--type2 .l-footer__nav-list ul { width:100%; display:flex; flex-wrap:wrap; gap:20px; justify-content: center; }
.l-footer--type2 .l-footer__nav-list li { font-size:16px; }
@media (max-width: 767px) {
  .l-footer--type2 .l-footer__nav { display:none; padding:40px 0; }
  .l-footer--type2 * + .l-footer__nav-list { margin-top:40px; }
}

/* banner */
.l-footer__banners { padding:50px 0; border-bottom:1px solid rgba(255,255,255,0.2); }
.l-footer__banners-list { margin:-30px 0 0 -30px; justify-content: center; }
.l-footer__banners-item { width:calc(100% / 3 - 30px ); margin:30px 0 0 30px; }
.l-footer__banners-item__link { position: relative; display:block; height:120px; }
.l-footer__banners-item__headline {
  position: absolute; left:0; bottom:0; z-index:3; background:rgba(0,0,0,0.3);
  width:100%; padding:calc(20px - 0.1em) 20px; font-size:14px; line-height:1.2; color:#fff;
  font-weight: 600;
}
.l-footer__ad-code { color:#fff; line-height:1.4; }
.l-footer__ad-code a { color:rgba(var(--tcd-sub-color, 0,0,0),1); }
@media (hover: hover) and (pointer: fine) {
  .l-footer__ad-code a:hover { text-decoration: underline; }
}
@media (max-width: 767px) {
  .l-footer__banners { padding:40px 0; }
  .l-footer__banners-list { margin:-20px 0 0 -20px; }
  .l-footer__banners-item { width:100%; margin:20px 0 0 20px; }
  .l-footer__banners-item__headline { padding:calc(20px - 0.1em) 30px; }
}

/* コピーライト、SNS */
.l-footer__bottom { position: relative; height:60px; }
.l-footer__sns-icons { height:100%; }
.l-footer__sns-icons.c-sns-icons--type1 .c-sns-icons__link { color:#fff; }
.l-footer__copyright { position: absolute; top:0; left:30px; line-height:60px; font-size:14px; color:#fff; }
@media (hover: hover) and (pointer: fine) {
  .l-footer__sns-icons.c-sns-icons--type1 .c-sns-icons__link:hover { color:rgba(var(--tcd-hover-color, 0,0,0),1); opacity:1; }
}
@media (max-width: 767px) {
  .l-footer__bottom { height:auto; }
  .l-footer__sns-icons { height:50px; border-bottom:1px solid rgba(255,255,255,0.2); }
  .l-footer__copyright { position: static; text-align: center; height:50px; line-height:50px; }
}


/* ----------------------------------------------------------------------
  component
---------------------------------------------------------------------- */


/* アイコン */
.c-icon--dp {
  font-family: 'design_plus';
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
  font-size:16px;
}
.c-icon {
  font-family: 'Material Symbols Rounded'; font-weight: 200; font-style: normal;
  font-size: 24px; line-height: 1; letter-spacing: normal; text-transform: none; display: inline-block;
  white-space: nowrap; word-wrap: normal; direction: ltr; -webkit-font-feature-settings: 'liga'; -webkit-font-smoothing: antialiased;
  font-variation-settings: 'FILL' 0, 'GRAD' 0, 'opsz' 48;
}

/* フォントタイプ */
.c-font-type { font-weight:600; }
.c-font--type1 { font-family: Arial, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif; font-weight:600; }
.c-font--type2 { font-family: Arial, "Hiragino Sans", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif; font-weight:600; }
.c-font--type3 { font-family: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif; font-weight:600; }

/* 行間 */
.c-line1, .c-line2, .c-line3, .c-line4 { overflow:hidden; visibility:visible; word-break: break-all; }
.c-line1 > span, .c-line1 > a { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:1; }
.c-line2 > span, .c-line2 > a { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; }
.c-line3 > span, .c-line3 > a { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:3; }
.c-line4 > span, .c-line4 > a { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:4; }

/* ホバー時のアクセントカラー */
.c-hover-color { transition:color 0.3s ease; }
@media (hover: hover) and (pointer: fine) {
  a:hover .c-hover-color { color:rgba(var(--tcd-hover-color, 0,0,0),1); }
}

/* SNSアイコン */
.c-sns-icons { display:-webkit-box; display:-ms-flexbox; display:-webkit-flex; display:flex; -ms-flex-wrap:wrap; -webkit-flex-wrap:wrap; flex-wrap:wrap; -ms-align-items:center; -webkit-align-items:center; align-items:center; }
.c-sns-icons__item {}
.c-sns-icons__item:not(:last-of-type) { margin-right:15px; }
.c-sns-icons__link { display:block; transition:opacity 0.2s ease; }
.c-sns-icons__link:before { font-family:'design_plus'; display:block; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.c-sns-icons__link--user-url:before { content:'\e942'; }
.c-sns-icons__link--facebook:before { content:'\e944'; font-size:1.1em; }
.c-sns-icons__link--twitter:before { content: "\e904"; font-size:0.85em; padding-top:0.05em; }
.c-sns-icons__link--instagram:before { content:'\ea92'; font-size:0.95em; padding-top:0.05em; }
.c-sns-icons__link--tiktok:before { content:'\e954'; font-size:0.9em; }
.c-sns-icons__link--pinterest:before { content:'\e905'; }
.c-sns-icons__link--youtube:before { content:'\ea9d'; }
.c-sns-icons__link--contact:before { content:'\f0e0'; font-size:0.95em; }
.c-sns-icons__link--rss:before { content:'\e90b'; font-size:0.9em; padding-top:0.05em; }
@media (hover: hover) and (pointer: fine) {
  .c-sns-icons__link:hover { opacity:0.5; }
}

/* モノクロ */
.c-sns-icons--type1 { font-size:18px; }
.c-sns-icons--type1 .c-sns-icons__link { color:#000; }

/* カラー */
.c-sns-icons--type2 { font-size:22px; }
.c-sns-icons--type2 .c-sns-icons__link--user-url:before { color:#00729f; }
.c-sns-icons--type2 .c-sns-icons__link--facebook:before { color:#1877f2; }
.c-sns-icons--type2 .c-sns-icons__link--tiktok:before { color:#000; }
.c-sns-icons--type2 .c-sns-icons__link--twitter:before { color:#000; }
.c-sns-icons--type2 .c-sns-icons__link--instagram:before { color:#e4405f; }
.c-sns-icons--type2 .c-sns-icons__link--pinterest:before {color:#bd081c; }
.c-sns-icons--type2 .c-sns-icons__link--youtube:before { color:#f00; }
.c-sns-icons--type2 .c-sns-icons__link--contact:before { color:#00729f; }
.c-sns-icons--type2 .c-sns-icons__link--rss:before { color:orange; }
.c-sns-icons--type2.is-dark .c-sns-icons__link--tiktok:before { color:#fff; }
.c-sns-icons--type2.is-dark .c-sns-icons__link--twitter:before { color:#fff; }


/* ロゴ */
.c-logo {
  color:inherit; transition: opacity 0.3s ease;
  display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
}
.c-logo__image { max-width:100%; width:auto; max-height:100%; }
.c-logo__text { display:block; line-height:1.6; margin:-0.3em 0; }
@media (hover: hover) and (pointer: fine) {
  .c-logo:hover { opacity:0.5; }
}
@media not all and (max-width: 767px) {
  .c-logo__image { max-height:70px; }
  .c-logo__image + .c-logo__image { display:none; }
}
@media (max-width: 767px) {
  .c-logo__image { display:none; max-height:50px; }
  .c-logo__image + .c-logo__image { display:block; }
  .c-logo__image:only-child { display: block; }
}

/* 日付 */
.c-date, .c-date--updated {
  display:-webkit-box; display:-ms-flexbox; display:-webkit-flex; display:flex;
  font-family:'Arial'; font-size:14px; color:#999; line-height:1;
}
.c-date:before, .c-date--updated:before {
  font-family: 'Material Symbols Rounded'; font-weight: normal; font-style: normal;
  line-height: 1; white-space: nowrap; word-wrap: normal; direction: ltr;
  -webkit-font-feature-settings: 'liga'; -webkit-font-smoothing: antialiased; font-weight:400;
  font-size:1.2em; margin-right:4px; margin-top: -0.08em;
}
.c-date:before { content: '\e8b5'; }
.c-date--updated:before { content:'\e923'; }


/* カテゴリー */
.c-post-category {
  font-size:14px; text-align: center; line-height:1.2;
  min-width:110px; height:40px;
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:-webkit-inline-flex; display:inline-flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); padding:0 15px; transition: color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .c-post-category:hover { color:rgba(255,255,255,0.5); }
}
@media (max-width: 767px) {
  .c-post-category { font-size:12px; min-width:100px; height:35px; }
}
.c-post-categories {
  font-size:14px; line-height:1.4;
  display:inline-block; padding:calc(13px - 0.2em) 15px;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); 
}
.c-post-categories__sep { color:inherit; margin-right:5px; }
.c-post-categories__link { color:inherit; transition: color 0.3s ease; }
@media (hover: hover) and (pointer: fine) {
  .c-post-categories__link:hover {
    color:rgba(255,255,255,0.5);
  }
}
@media (max-width: 767px) {
  .c-post-categories { font-size:12px; padding:calc(12px - 0.2em) 15px; }
}

/* お知らせカテゴリー */
.c-news-category {
  font-size:14px; text-align: center; line-height:1.2;
  min-width:100px; height:35px; border-radius:35px;
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:-webkit-inline-flex; display:inline-flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); padding:0 15px; transition: color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .c-news-category:hover { color:rgba(255,255,255,0.5); }
}
@media (max-width: 767px) {
  .c-news-category { font-size:12px; }
}
.c-news-categories {
  display:inline-block; font-size:14px; line-height:1.4; text-align: center;
  border-radius:35px; min-width:100px; padding:calc(11px - 0.2em) 15px;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1);
}
.c-news-categories__sep { color:inherit; margin-right:5px; }
.c-news-categories__link { color:inherit; transition: color 0.3s ease; }
@media (hover: hover) and (pointer: fine) {
  .c-news-categories__link:hover { color:rgba(255,255,255,0.5); }
}
@media (max-width: 767px) {
  .c-news-categories { font-size:12px; }
}


/* パンくずリスト */
.c-breadcrumb { position: relative; z-index:5; overflow:hidden; margin-bottom:-60px; background:rgba(0, 0, 0, 0.3); }
.c-breadcrumb__list { height:60px; overflow: initial; }
.c-breadcrumb__item { font-size:14px; white-space: nowrap; }
.c-breadcrumb * { color:#fff; }
.c-breadcrumb a > span { color:inherit; transition: color 0.2s ease; }
.c-breadcrumb a > span.c-icon { font-size:22px; }
.c-breadcrumb__item:last-of-type > span[itemprop="name"] { color:rgba(var(--tcd-sub-color, 0,0,0),1); }
@media (hover: hover) and (pointer: fine) {
  .c-breadcrumb a:hover span { color:rgba(var(--tcd-hover-color, 0,0,0),1); }
}
@media not all and (max-width: 767px) {
  .c-breadcrumb__item > span { overflow:hidden; white-space: nowrap; text-overflow: ellipsis; visibility:visible; }
  .c-breadcrumb__item:last-of-type { overflow: hidden; }
}
@media (max-width: 767px) {
  .c-breadcrumb { margin-bottom:-45px; }
  .c-breadcrumb__list { width:100%; height:45px; padding: 1px 20px 0; }
  .c-breadcrumb__item { font-size:14px; }
}


/* ページャー */
.c-pagination { width:100%; margin-top:50px; text-align: center; font-family: Arial; }
.c-pagination__item { display:block; }
* + .c-pagination__item { margin-left:7px; }
.c-pagination a, .c-pagination span {
  display:-webkit-box; display:-ms-flexbox; 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: 50px; height: 50px; font-size: 14px; color: #000; border-radius:50%; background:#eee;
}
.c-pagination a { color:#000!important; transition:all 0.2s ease; }
.c-pagination .dots { background:none; width:25px; }
.p-archive--news .c-pagination .dots { color:#fff; }
.c-pagination .current { position: relative; color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); }
.post_content .c-pagination > * + * { margin-left:7px; }
@media (hover: hover) and (pointer: fine) {
  .c-pagination a:hover { color:#fff!important; text-decoration: none!important; background:rgba(var(--tcd-sub-color, 0,0,0),1); }
}
@media (max-width: 767px) {
  .c-pagination { margin-top:40px; }
}

/* 検索フォーム */
.c-search-form {
  max-width:550px; width:100%; border-radius:50px; overflow: hidden; background:#fff;
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:-webkit-inline-flex; display:inline-flex;
}
.c-search-form__text { width: calc(100% - 60px); }
.c-search-form__text input {
  display: block; width: 100%; height: 50px; padding-left: 25px;
  border: none; background: transparent; font-size: 16px;
}
.c-search-form__button label {
  font-size: 24px; cursor: pointer; color:#000;
  width:60px; height:100%; transition:color 0.3s ease;
}

@media (hover: hover) and (pointer: fine) {
  .c-search-form__button label:hover { color:rgba(var(--tcd-hover-color, 0,0,0),1); }
}
@media (max-width: 767px) {
  .c-search-form__text { width:calc(100% - 50px); }
  .c-search-form__text input { height:45px; padding-left:20px; }
  .c-search-form__text input::-webkit-input-placeholder { font-size:14px; }
  .c-search-form__text input:-ms-input-placeholderm { font-size:14px; }
  .c-search-form__text input::placeholder { font-size:14px; }
  .c-search-form__button label { width:50px; }
}
@media (max-width: 599px) {
  .c-search-form { max-width:280px; }
}

/* 個別ページのセクション用タイトル */
.c-single-section-title, .post_content .c-single-section-title {
  font-size:22px; line-height:1.4; padding:calc(24px - 0.2em) 20px; text-align: center; font-weight: 600;
  color:#fff; background:rgba(var(--tcd-accent-color, 0,0,0),1); margin:0;
}
@media (max-width: 767px) {
  .c-single-section-title, .post_content .c-single-section-title { font-size:16px; padding:calc(20px - 0.2em) 20px; }
}

/* 背景画像 */
.c-bg-image {
  position: absolute; top:0; left:0; z-index:1; background-size:cover!important; width:100%; height:100%;
}
.c-overlay {
  position: absolute; top:0; left:0; z-index:2; width:100%; height:100%; background:rgba(0,0,0,0.3);
}

/* スライダーアロー */
.c-arrow {
  cursor: pointer; position: absolute; top:50%; transform:translateY(-50%);
  width:50px; height:50px; line-height:50px; font-size:48px;
  color:#000; background: transparent; border:none;
  text-align: center; transition:opacity 0.3s ease; z-index:1;
}
.c-arrow--prev { left:-65px; }
.c-arrow--next { right:-56px; }
@media (hover: hover) and (pointer: fine) {
  .c-arrow:hover { opacity:0.5; }
}

/* サイドバーのレイアウト */
.c-row-reverse { -webkit-box-orient: horizontal; -webkit-box-direction: reverse; -ms-flex-direction: row-reverse; flex-direction: row-reverse; }
.is-sidebar--left .l-container__inner { -webkit-box-orient: horizontal; -webkit-box-direction: reverse; -ms-flex-direction: row-reverse; flex-direction: row-reverse; }
.is-sidebar--none .l-container__inner { max-width:700px; }


/* 基本ボタン */
.c-button, .post_content .c-button {
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:-webkit-inline-flex; display:inline-flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  min-width: 300px; min-height: 70px; border-radius: 70px; overflow: hidden; cursor: pointer;
  font-size: 16px; padding: .5em 1.5em; background:transparent; text-align: center;line-height: 1.5;
  color: #fff!important; background:rgba(var(--tcd-accent-color, 0,0,0),1);
  transition:color 0.3s ease, background-color 0.3s ease;
  position: relative; border:none;
}
.c-button--grey { border:none; }
.c-button--grey:not(:hover) { color: #fff; background: #ccc; }
@media (hover: hover) and (pointer: fine) {
  .c-button:hover, .post_content .c-button:hover { background: rgba(var(--tcd-sub-color, 0,0,0),1); text-decoration: none!important; }
}
@media (max-width: 767px) {
  .c-button, .post_content .c-button { font-size: 14px; min-width: 240px; min-height: 50px; border-radius: 50px; }
}

/* 横スクロール対応 */
.c-h-scroll {
  overflow: auto hidden; -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none; scrollbar-width: none;
}
.c-h-scroll::-webkit-scrollbar { display:none; }
.c-h-scroll > * { overflow:visible; position:relative; }
.c-h-scroll > *:last-child:after {
  position: absolute; content: ''; top: 0; left: 100%; height: 1px; width: 20px; background-color: transparent;
}

/* 投稿が無いときのメッセージ */
.c-no-post { line-height:1.8; margin:-0.4em 0; }

/* 画像読み込み時 */
.c-image-loading {
	position: absolute; top:0; left:0; z-index:1; width:100%; height:100%; background:#eee; overflow: hidden;
}
.c-image-loading:before {
	content: ""; width:100%; height:100%; position:absolute; top:0; left:0;
	background: linear-gradient(90deg,#eee 0,#f3f3f3 15%,#eee 30%);
	animation-duration: 1.5s;
	animation-fill-mode: forwards;
	animation-iteration-count: infinite;
	animation-name: imageLoadingBackground;
	animation-timing-function: linear;
}
@keyframes imageLoadingBackground {
	0% { transform: translateZ(0) }
	to { transform: translate3d(100%,0,0) }
}
body.is-watermark-loaded .c-image-loading { display:none; }

/* フリースペースのリンク文字色 */
.c-link-color a { color:rgba(var(--tcd-link-color, 21,120,214),1); }
@media (hover: hover) and (pointer: fine) {
  .c-link-color a:hover { text-decoration: underline; }
}

/* アニメーション用 */
body:not(.use_loading_screen) .c-animation--header, .close_loading_screen .c-animation--header
{ opacity:0; animation: FadeIn 0.5s ease 0.3s forwards; }

body:not(.use_loading_screen) .c-animation--text, .close_loading_screen .c-animation--text
{ opacity:0; animation: FadeIn 1s ease 1s forwards; }
body:not(.use_loading_screen) .c-animation--text + .c-animation--text, .close_loading_screen .c-animation--text + .c-animation--text
{ animation-delay: 1.5s; }
body:not(.use_loading_screen) .c-animation--text + .c-animation--text + .c-animation--text, .close_loading_screen .c-animation--text + .c-animation--text + .c-animation--text
{ animation-delay: 2s; }

@keyframes FadeIn {
  0% { opacity:0; }
  100% { opacity:1; }
}

/* ----------------------------------------------------------------------
  Project - wave
---------------------------------------------------------------------- */

.p-wave { position:relative; height:50px; z-index:5; }
.p-wave--header { width:100%; position: absolute; left:0; bottom:-2px; }
.p-wave--footer { margin-bottom:-1px; }
.p-wave-canvas { position: absolute; bottom: 0; left:0; width: 100%; }
@media (max-width: 767px) {
  .p-wave--header { bottom:-30px; }
  .p-wave--footer { margin-top:20px; }
}

/* ----------------------------------------------------------------------
  Project - side button
---------------------------------------------------------------------- */

.p-side-button { position: fixed; top:50%; transform:translateY(-50%); z-index:100; }
.p-side-button--left { left:0; }
.p-side-button--right { right:0; }
.p-side-button__list {}
.p-side-button__item { background: rgba(var(--tcd-sub-color, 0,0,0),1); }
.p-side-button__item-link {
  color:#fff; width:80px; height:80px;
  -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column;
}
.p-side-button__item-icon {  }
.p-side-button__item-label { display:block; font-size:12px; line-height:1.3; text-align: center; margin:-0.15em 0; }
* + .p-side-button__item-label { margin-top:calc(10px - 0.15em); }
@media (hover: hover) and (pointer: fine) {
  .p-side-button__item-link:hover { background:rgba(0, 0, 0, 0.2); }
}
@media (max-width: 767px) {
  .p-side-button { display:none; }
}


/* ----------------------------------------------------------------------
  Project - navigation
---------------------------------------------------------------------- */

/* ナビゲーション */
.p-global__nav-wrapper { position: relative; }
.p-global__nav { font-size: 16px; line-height:1.2; }
.p-global__nav li { width:100%; position: relative; }
.p-global__nav a { color:#fff; position: relative; }

/* 親メニュー */
.p-global__nav > li { border-left:1px solid rgba(255, 255, 255, 0.2); }
.p-global__nav > li > a { text-align: center; width:100%; height:80px; line-height:1.2; padding:0 20px; overflow: hidden; }
.p-global__nav > li > a:before {
  content:''; background:rgba(var(--tcd-sub-color, 0,0,0),0.3); transition: transform 0.4s cubic-bezier(0.22,0.61,0.36,1);
  position: absolute; top:0; left:0; z-index:-1; width:100%; height:100%; transform:translateY(100%);
}
.p-global__nav > li.current-menu-item > a:before { transform:translateY(0); }
.p-global__nav-icon { color:inherit; margin-right:10px; will-change: transform; backface-visibility: hidden; }
.p-global__nav-image { color:inherit; margin-right:10px; will-change: transform; backface-visibility: hidden; }
.p-global__nav-icon.c-icon--dp { font-size:18px; width:24px; text-align: center; }
.p-global__nav-image img { width:auto; max-height:24px; }
@media (hover: hover) and (pointer: fine) {
  .p-global__nav > li.is-active > a:before, .p-global__nav > li:hover > a:before { transform:translateY(0); }
  .p-global__nav > li.is-active a .p-global__nav-icon,
  .p-global__nav > li:hover > a .p-global__nav-icon,
  .p-global__nav > li.is-active a .p-global__nav-image,
  .p-global__nav > li:hover > a .p-global__nav-image
  { animation: navIconPopUp 1s cubic-bezier(0.17,0.84,0.44,1) 0s forwards; }
}
@keyframes navIconPopUp {
	0% { transform: scale(1); }
	25% { transform: scale(1.6); }
	100% { transform: scale(1.3); }
}

/* サブメニュー */
.p-global__nav .sub-menu {
  position: absolute; left: 100%; top: 0; font-size:14px; line-height:1.7;
  visibility: hidden; opacity: 0; transition: opacity 0.3s ease, visibility 0.3s ease;
  background:rgba(var(--tcd-sub-color, 0,0,0),1);
}
.p-global__nav > li.menu-item-has-children > .sub-menu { top:100%; left: 0; z-index: 200; }
.p-global__nav > li:last-child.menu-item-has-children > .sub-menu { left:auto; right:0; }

.p-global__nav .sub-menu a { color: inherit; line-height:1.4; padding:0 20px; min-width: 240px; z-index: 2; height:50px; transition:color 0.2s ease, background 0.2s ease; }
.p-global__nav a[data-megamenu] + .sub-menu { display:none; }
@media (hover: hover) and (pointer: fine) {
  .p-global__nav a:hover + .sub-menu, .p-global__nav .sub-menu:hover { visibility: visible; opacity: 1; }
  .p-global__nav .sub-menu a:hover { background: rgba(var(--tcd-accent-color, 0,0,0),1); }
}

/* メガメニュー */
.p-megamenu {
  position: absolute; top:100%; width:100%; overflow: hidden;
  opacity:0; visibility: hidden; pointer-events: none;
  background: #000;
  transition: opacity 0.3s ease, visibility 0s ease;
}
.p-megamenu.is-active, .p-megamenu:hover {
  opacity:1; visibility: visible; pointer-events: auto;
}
.p-megamenu .c-arrow { color:#fff; }

@media (max-width: 1024px) {
  .p-megamenu { display: none; }
}

/* トップページ用対策 */
.p-fp-slider ~ .l-header.is-top .p-global__nav > li.menu-item-has-children > .sub-menu,
.p-fp-slider ~ .l-header.is-top .p-megamenu { top:initial; bottom:100%; }

/* メガメニュー01（イベントスライダー） */
.p-megamenu01 {}
.p-megamenu01__inner { position: relative; }
.p-megamenu01__list { }
.p-megamenu01__item { width:calc( 100% / 3 - 30px ); margin-right:30px; }
.p-megamenu01__link { padding:20px 0; }
.p-megamenu01__image { width:140px; height:140px; }
.p-megamenu01__image-bg { width:100%; height:100%; }
.p-megamenu01__content { width:calc(100% - 140px); padding-left:20px; color:#fff; }
.p-megamenu01__date { margin-bottom:20px; margin-left:-1px; }
.p-megamenu01__date-time {
  font-size:14px; text-align: center; white-space: nowrap; overflow: hidden;
  display:inline-block; padding:0 20px; max-width: 100%; height:35px; line-height:35px; border-radius: 35px;
  background:rgba(var(--tcd-sub-color, 0,0,0),1);
}
.p-megamenu01__title { font-size:16px; line-height:1.7; height:5.1em; margin:-0.35em 0; font-weight:600; }

/* メガメニュー02（ブログスライダー） */
.p-megamenu02 {}
.p-megamenu02__inner { position: relative; }
.p-megamenu02__list { }
.p-megamenu02__item { width:calc( 100% / 2 - 40px ); margin-right:40px; }
.p-megamenu02__link { padding:20px 0; }
.p-megamenu02__catgeory { padding: calc(11px - 0.2em) 15px; margin-bottom:20px; }
.p-megamenu02__image { width:205px; height:140px; }
.p-megamenu02__image-bg { width:100%; height:100%; }
.p-megamenu02__content { width:calc(100% - 205px); padding-left:20px; color:#fff; }
.p-megamenu02__title { font-size:16px; line-height:1.7; height:3.4em; margin:-0.35em 0; font-weight:600; }
.p-megamenu02__date { margin-top:20px; color:inherit; }


/* ----------------------------------------------------------------------
  Project - Drawer menu
---------------------------------------------------------------------- */

/* 閉じるボタン */
.p-menu-button--close { width:50px; height:50px; position: absolute; top:0; right:0; z-index:1; transition:opacity 0.3s ease; }
.p-menu-button--close span {
  display:block; width:1px; height:17px; overflow: hidden; background:#fff;
  position:absolute; top:0; left:0; right:0; bottom:0; margin:auto;
}
.p-menu-button--close span:first-of-type { transform: rotate(-45deg); z-index:2; }
.p-menu-button--close span:last-of-type { transform: rotate(45deg); }
.p-menu-button--close span:before {
  content:''; display:block; width:100%; height:100%; transition: transform 0.3s ease;
}
.p-menu-button--close span:first-of-type:before { transform: translateY(-100%); transition-delay: 0.2s; }
.p-menu-button--close span:last-of-type:before { transform: translateY(-100%); transition-delay: 0.5s; }
html.show-drawer .p-menu-button--close span:before { transform: translateY(0); }
@media (hover: hover) and (pointer: fine) {
  .p-menu-button--close:hover { opacity:0.5; }
}

/* ドロワーメニュー */
.p-drawer-menu {
  position: fixed; top:0; right:-400px; z-index:201; padding:50px 0; background: rgba(var(--tcd-accent-color, 0,0,0),1);
  width:400px; height:100%; overflow: hidden auto; transition:transform 0.4s cubic-bezier(0.65,0.05,0.36,1);
}
html.show-drawer .p-drawer-menu { transform:translateX(-400px); }
html.show-drawer .p-drawer-menu__overlay { position: fixed; top:0; left:0; z-index:200; width:100%; height:100%; background:rgba(0, 0, 0, 0.4) }
@media (max-width: 599px) {
  .p-drawer-menu { width:100%; right:-100%; }
  html.show-drawer .p-drawer-menu { transform:translateX(-100%); }
  .p-drawer-animation { transition:transform 0.4s cubic-bezier(0.65,0.05,0.36,1); }
  html.show-drawer .p-drawer-animation { transform:translateX(-100%); }
  .p-drawer-menu__overlay { display:none; }
}

/* ナビゲーション */
.p-drawer-menu__nav a {
  font-size:16px; line-height:1.2; padding:0 20px; height:50px; color:#fff;
  border-top:1px solid rgba(255, 255, 255, 0.2);
  -webkit-box-pack: start; -ms-flex-pack: start; justify-content: flex-start;
}
.p-drawer-menu__nav .p-global__nav-name { flex:1 1 0; }
.p-drawer-menu__nav .p-global__nav-icon { margin-right:15px; }
.p-drawer-menu__nav .p-global__nav-image { margin-right:15px; transition: opacity 0.3s ease; }
.p-drawer-menu__nav ul { background:rgba(var(--tcd-sub-color, 0,0,0),1); }
.p-drawer-menu__nav ul a { color:#fff; border-top:none; height: auto; padding: calc(12.5px - 0.1em) 20px; }
.p-drawer-menu__nav ul li:first-of-type a { padding-top:calc(25px - 0.1em); }
.p-drawer-menu__nav ul li:last-of-type a { padding-bottom:calc(25px - 0.1em); }
.p-drawer-menu__nav ul { height:0; overflow: hidden; transition:height 0.3s ease; }
.p-drawer-menu__nav li.is-active > a { color:#fff!important; }
@media (hover: hover) and (pointer: fine) {
  .p-drawer-menu__nav > li a:hover { color:rgba(255,255,255,0.5); }
  .p-drawer-menu__nav ul li a:hover { color:rgba(255, 255, 255, 0.5)!important; }
  .p-drawer-menu__nav a:hover .p-global__nav-image { opacity:0.5; }
}

/* サブメニュー開閉ボタン */
.p-drawer-menu-toggle-button { min-width:50px; width:50px; height:100%; margin-right:-20px; position:relative; transition:opacity 0.2s ease; }
.p-drawer-menu-toggle-button__icon { display:block; width:14px; height:14px; position:relative; }
.p-drawer-menu-toggle-button__icon:before, .p-drawer-menu-toggle-button__icon:after {
  content:''; display:block; background:#fff; position: absolute; top:0; left:0; right:0; bottom:0; margin:auto;
}
.p-drawer-menu-toggle-button__icon:before { width:1px; height:100%; transition: transform 0.2s ease; }
.p-drawer-menu-toggle-button__icon:after { width:100%; height:1px; }
.p-drawer-menu__nav li.is-active .p-drawer-menu-toggle-button__icon:before { transform: rotate(90deg); }
@media (hover: hover) and (pointer: fine) {
  .p-drawer-menu-toggle-button:hover { opacity:0.5; }
}

/* SNS */
.p-drawer-menu__sns { padding:20px; border-top:1px solid rgba(255, 255, 255, 0.2); }
.p-drawer-menu .c-sns-icons--type1 .c-sns-icons__link { color:#fff; }


/* ----------------------------------------------------------------------
  Project - header message
---------------------------------------------------------------------- */

.p-header-message {
  display:-webkit-box; display:-ms-flexbox; display:flex;
  -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  min-height:50px; text-align: center; font-size:14px; font-weight:600; padding:1em 20px;
  position: relative; z-index:100;
}
.p-header-message__label { display:block; color:inherit; line-height:1.4; margin:-0.2em 0; padding-top:1px; }
a.p-header-message__label:hover { text-decoration: underline; }
@media (max-width: 767px) {
  .p-header-message { min-height:40px; font-size:12px; }
}

/* ----------------------------------------------------------------------
  Project - return top button
---------------------------------------------------------------------- */

/* ページ上部へ戻るボタン */
.p-return-top-button-wrapper { position: fixed; right:30px; bottom: 30px; z-index:101; }
.p-return-top-button {
  display:block; width:65px; height:65px; padding:0; margin-left:auto; color:#fff;
  background:rgba(var(--tcd-sub-color, 0,0,0),1); border:none; border-radius:50%;
  cursor: pointer; pointer-events: auto; opacity:0; transition: opacity 0.3s ease, color 0.3s ease;
}
.p-return-top-button .c-icon { color:inherit; font-size:32px; padding-top:3px; }
.p-return-top-button.is-active { opacity:1; }
@media (hover: hover) and (pointer: fine) {
  .p-return-top-button:hover { color:rgba(255, 255, 255, 0.4); }
}
@media (max-width:767px) {
  .p-return-top-button-wrapper { right:20px; bottom: 25px; }
  .p-return-top-button { width:50px; height:50px; }
  .p-return-top-button .c-icon { color:inherit; font-size:24px; }
  .p-footer-bar ~ .p-return-top-button-wrapper { bottom:75px; }

  /* ドロワー対策 */
  html.show-drawer .p-return-top-button-wrapper .p-return-top-button,
  .p-calender-modal.is-active ~ .p-return-top-button-wrapper { opacity:0; transition:none; }
}

/* ----------------------------------------------------------------------
  Project - front page
---------------------------------------------------------------------- */

.p-fp-slider { position: relative; height:calc(100vh - 80px); }

/* ショルダーコピー */
.p-fp-slider_copy { width:100%; height:80px; position: absolute; top:0; left:0; z-index:5; }
.p-fp-slider_copy-text { width:calc(100% - 60px); color:#fff; font-size:18px; line-height:1.6; font-weight:600; padding:0 30px; }
@media not all and (max-width:1200px) {
  .p-fp-slider_copy-menu { display:none; }
}
@media (max-width:767px) {
  .p-fp-slider_copy { height:60px; }
  .p-fp-slider_copy-text { font-size:14px; padding:0 20px; }
  .p-fp-slider_copy-menu { width:60px; text-align: center; margin-left:auto; }
}

/* コンテンツ */
.p-fp-slider__content {
  position: absolute; top:0; left:0; bottom:0; right:0; z-index:3; text-align: center;
}
.p-fp-slider__headline { font-size:26px; line-height:1.6; margin:-0.3em 0; color:#fff; text-align: center; }
* + .p-fp-slider__logo { margin-top:40px; }
@media (max-width:767px) {
  .p-fp-slider__headline { font-size:20px; }
  * + .p-fp-slider__logo { margin-top:30px; }
}
.p-fp-slider__content .c-animation--text { animation-duration: 1.4s!important; }

.p-fp-slider__bg { width:100%; height:100%; }
/* 背景画像 */
.p-fp-slider__images {}
.p-fp-slider__images-track { width:100%; height:100%; }
.p-fp-slider__images-list {}
.p-fp-slider__images-item { width:100%; height:100%; }
.p-fp-slider__images-item__bg { width:100%; height:100%; }

/* 背景動画 */
.p-fp-slider__video {}
.p-fp-slider__video-bg { width:100%; height:100%; object-fit: cover; }

/* youtube */
.p-fp-slider__youtube { position: relative; overflow:hidden; background: #000; }
.p-fp-slider__youtube-bg:not(.is-ready) { opacity:0; }
.p-fp-slider__youtube-bg {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); opacity:1; transition: opacity 0.3s ease;
  width: calc(100vh * 16 / 9); height: calc(100vw * 9 / 16); min-width: 100%; min-height: 100%;
}
.p-fp-slider__youtube iframe {}

/* 代替画像 */
.p-fp-slider__alternate {}
.p-fp-slider__alternate-bg { width:100%; height:100%; }


/* ----------------------------------------------------------------------
  Project - Page Header
---------------------------------------------------------------------- */

.p-page-header { background:#333; overflow:hidden; position: relative; }
.p-page-header__inner { position:relative; height:100%; color:#fff; text-align: center; }
.p-page-header__content { width:100%; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index:3; }
.p-page-header__headline { font-size:36px; line-height:1.6; margin:-0.3em 0; }
.p-page-header__description { font-size:18px; line-height:2.4; margin:-0.7em 0; }
.p-page-header__headline + .p-page-header__description { margin-top:calc(40px - 0.7em); }
.p-page-header__overlay { position:absolute; top:0; left:0; z-index:2; width:100%; height:100%; background:#000; }
.p-page-header__image { position:absolute; top:0; left:0; z-index:1; width:100%; height:100%; }
* + .p-page-header__search { margin-top:40px; }
@media not all and (max-width: 767px) {
  .p-page-header--normal { height:600px; }
  .l-header ~ .l-container .p-page-header--normal { height:400px; }
  .p-page-header--simple { height:200px; }
}
@media (max-width: 767px) {
  .p-page-header--normal { height:300px; }
  .l-header ~ .l-container .p-page-header--normal { height:250px; }
  .p-page-header--simple { height:130px; }
  .p-page-header__headline { font-size:20px; }
  .p-page-header__description { font-size:14px; line-height:2; margin:-0.5em; }
  .p-page-header__headline + .p-page-header__description { margin-top:calc(25px - 0.5em); }
}

/* ----------------------------------------------------------------------
  Project - Post
---------------------------------------------------------------------- */

/* 投稿アーカイブ */
.p-archive--post { margin:1px 0 0 1px; }
.p-archive--post-item { width:calc(100% / 3 + 1px); margin:-1px 0 0 -1px; position: relative; }
.p-archive--post-item__image { position: relative; }
.p-archive--post-item__image-bg { width:100%; height:240px; }
.p-archive--post-item__content { position: relative; padding:30px; border:1px solid #ddd; border-top:none; }
.p-archive--post-item__category { position: absolute; left:0; bottom:0; z-index:1; margin:0 30px; }
.p-archive--post-item__title { font-size:18px; line-height:1.6; height:3.2em; margin:-0.3em 0; }
.p-archive--post-item__date { margin-top:20px; }
@media (max-width:992px) {
  .p-archive--post-item { width:calc(100% / 2 + 1px); }
}
@media (max-width:767px) {
  .p-archive--post-item__image-bg { height:220px; }
  .p-archive--post-item__content { padding:20px; }
  .p-archive--post-item__category { margin:0 20px; }
  .p-archive--post-item__title { font-size:16px; }
  .p-archive--post-item__date { margin-top:15px; }
}
@media (max-width:599px) {
  .p-archive--post-item { width:100%; }
}


/* カテゴリー一覧のスタイル */
#blog_category_sort_wrap { width:100%; margin:0px auto 80px; position:relative; text-align:center; }
#archive_headline + #archive_blog #blog_category_sort_wrap { margin-top:100px; }
.splide__track.category-splide__track:after { content:''; display:block; width:1px; height:70px; background:#ddd; position:absolute; right:0; top:0; z-index:2; }
.splide__track.category-splide__track:before { content:''; display:block; width:1px; height:70px; background:#ddd; position:absolute; left:0; top:0; z-index:2; }
.splide__slide.category-splide__slide { margin:0; width:25%; }
.splide.small_size .splide__slide.category-splide__slide { flex: 1 1 0%; width:auto; }
.splide__slide.category-splide__slide a { font-size:16px; height:70px; display:flex; flex-wrap:wrap; justify-content:center; align-items:center; border-top:1px solid #ddd; border-bottom:1px solid #ddd; padding:0 20px; position:relative; }
.splide__slide.category-splide__slide a p { line-height:1.4; max-height:2.8em; overflow:hidden; visibility:visible; transition: opacity 0.3s ease; }
.splide__slide.category-splide__slide a span { display:-webkit-inline-box; -webkit-box-orient:vertical; -webkit-line-clamp:2; }
.splide__slide.category-splide__slide a:after { content:''; display:block; width:1px; height:100%; position:absolute; right:0; top:0; background:#ddd; }
.splide__slide.category-splide__slide.active_menu { position:relative; z-index:5; }
.splide__slide.category-splide__slide.active_menu a { background:rgba(var(--tcd-accent-color, 0, 0, 0), 1); border-color:rgba(var(--tcd-accent-color, 0, 0, 0), 1) !important; color:#fff; position:relative; pointer-events:none; }
/* 選択されたカテゴリーの背景色を変更 */
.splide__slide.category-splide__slide.active_category a{ background-color: rgba(var(--tcd-accent-color, 0, 0, 0), 1); border-color:rgba(var(--tcd-accent-color, 0, 0, 0), 1) !important;color: #fff;  }
.splide__slide.category-splide__slide.active_menu a:after { background:#eee; }
.splide__arrow.category-splide__arrow::after, .splide__arrow.category-splide__arrow::after { color:#000; font-size: 20px; }
.splide__arrow--prev.category-splide__arrow--prev { left:-60px; right:auto; top:50%; z-index:10; color: #000; font-size: 35px;width: unset;height: unset;line-height: 35px; cursor: pointer;}
.splide__arrow--next.category-splide__arrow--next {left:auto; right: -60px;top: 50%; z-index:10; color: #000;font-size: 35px;width: unset;height: unset;line-height: 35px; cursor: pointer;}
/* カテゴリー数が4つ未満の場合、擬似要素を非表示にする */
.few-categories .splide__track.category-splide__track:before { display:none; }
.few-categories .splide__track.category-splide__track:after { display:none }
/* 最初のスライドに左側のボーダーを追加 */
.few-categories .splide__slide.category-splide__slide:first-child a { border-left: 1px solid #ddd; }
/* 最後のスライドに右側のボーダーを追加 */
.few-categories .splide__slide.category-splide__slide:last-child a { border-right: 1px solid #ddd; }

@media(hover: hover) {
  .splide__arrow--next.category-splide__arrow--next:hover:before, .splide__arrow--prev.category-splide__arrow--prev:hover:before { color:#aaa; }
  .splide__slide.category-splide__slide a:hover p {
    opacity: 0.5;
  }
}

.splide__list.category-splide__list.category_center { justify-content: center; }
.splide__slide.category-splide__slide.item_width { flex: none !important; width: calc(100% / 4) !important; }
.splide.small_size::before { display: none; }
.splide.small_size::after { display: none; }
.splide__list.category-splide__list.category_center .splide__slide.category-splide__slide:first-child { border-left: 1px solid #ddd; }
.splide__list.category-splide__list.mobile_button_width { justify-content: center; }

#blog_category_sort_wrap .splide__arrows.category-splide__arrows button:disabled { opacity:0; display:none; }

@media screen and (max-width:1200px) {
  #blog_category_sort_wrap {  width: 95%; }
}
@media screen and (max-width:1130px) {
  #archive_blog { width:100vw; margin:0 0 150px; overflow:hidden; }
  #blog_category_sort_wrap {  width: calc(100% + 60px); margin: 10px -30px 100px -30px; }
  .splide.category-splide { overflow:hidden; }
  .splide__track.category-splide__track:after, .splide__track.category-splide__track:before { display:none !important; }
  .splide__arrow.category-splide__arrow { display:none; }
  .splide__slide.category-splide__slide { width:233px ; }
  .splide__slide.category-splide__slide:first-child { padding-left: 30px; width: calc(233px + 30px)!important; }
  .splide__slide.category-splide__slide:last-child { padding-right: 30px; width: calc(233px + 30px)!important; }
  .splide.small_size .splide__slide.category-splide__slide { flex: 0 0 auto; width:auto; }
  .splide__slide.category-splide__slide a { border-right:1px solid #ddd; }
  .splide__slide.category-splide__slide:first-of-type a { border-left:1px solid #ddd!important; }
  .splide__slide.category-splide__slide:last-of-type a { border-right:1px solid #ddd!important; }
  .splide__slide.category-splide__slide a:after { display:none; }
}

@media screen and (max-width:767px) {
  #blog_category_sort_wrap { width: calc(100% + 40px); margin:0 -20px 40px -20px; }
  #archive_headline + #archive_style #blog_category_sort_wrap { margin-top:35px; }
  .splide__slide.category-splide__slide.mobile_item_width { width: calc( 100% / 2) !important; }
  .splide__slide.category-splide__slide { width:200px !important; }
  .splide__slide.category-splide__slide:first-child { padding-left: 20px; width: calc(200px + 20px) !important; }
  .splide__slide.category-splide__slide:last-child { padding-right: 20px; width: calc(200px + 20px) !important; }
  .splide__slide.category-splide__slide a { height:50px; line-height:50px; font-size:14px; }

  /* スマホ画角時に最初と最後のスライドにボーダーを追加 */
  .few-categories .splide__slide.category-splide__slide:first-child a { border-left: 1px solid #ddd !important; }
  .few-categories .splide__slide.category-splide__slide:last-child a { border-right: 1px solid #ddd !important; }
}

@media screen and (max-width:600px) {
  .splide__slide.category-splide__slide.mobile_item_width { width: calc( 100% / 2) !important; }
  .splide__slide.category-splide__slide { width:160px !important; }
  .splide__slide.category-splide__slide:first-child { padding-left: 20px; width: calc(160px + 20px) !important;}
  .splide__slide.category-splide__slide:last-child { padding-right: 20px; width: calc(160px + 20px) !important; }

  /* スマホ画角時に最初と最後のスライドにボーダーを追加 */
  .few-categories .splide__slide.category-splide__slide:first-child a { border-left: 1px solid #ddd !important; }
  .few-categories .splide__slide.category-splide__slide:last-child a { border-right: 1px solid #ddd !important; }
}




/* 著者アーカイブ */
.p-author-profile--archive { background:#f6f6f6; padding:100px 100px 100px 90px; }
.p-author-profile--archive__image { width:140px; text-align: center; }
.p-author-profile--archive__image-bg { width:120px; border-radius:50%; }
.p-author-profile--archive__title { font-size:18px; font-weight: 600; line-height:1.8; margin:calc(30px - 0.4em) -30px -0.4em; }
.p-author-profile--archive__content { width:calc(100% - 140px); padding-left:90px; }
.p-author-profile--archive__desc { font-size:16px; line-height:2.4; margin:-0.7em 0; }
.p-author-profile--archive__icons { margin-top:40px; }

#author_headline{ text-align: center; margin: 100px auto 60px; font-size: 28px; }

@media (max-width:767px) {
  .p-author-profile--archive { padding:40px; }
  .p-author-profile--archive__image { width:100%; }
  .p-author-profile--archive__image-bg { width:110px; }
  .p-author-profile--archive__title { font-size:16px; margin:calc(30px - 0.4em) 0 -0.4em; }
  .p-author-profile--archive__content { width:100%; padding:0; }
  .p-author-profile--archive__desc { font-size:14px; line-height:2.2; margin:calc(30px - 0.6em) 0 -0.6em; }
  .p-author-profile--archive__icons { margin-top:30px; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }

  #author_headline{ margin: 40px auto; font-size: 20px; }
}

/* ----------------------------------------------------------------------
  Project - single post
---------------------------------------------------------------------- */

/* 全体 */
.p-single {}

/* ヘッダー */
.p-single__header { position: relative; }
.p-single__header-content { padding:0 40px 40px 40px; border:1px solid #ddd; }
.p-single__header-category { margin-top:-1px; }
.p-single__header-title { font-size:28px; line-height:1.5; margin:calc(40px - 0.25em) 0 -0.25em; }
.p-single__header-meta { margin-top:20px; }
* + .p-single__header-meta__item { margin-left:20px; }
.p-single__header-image { margin-top:-1px; }
.p-single__header-image img { width:100%; }
.p-single__header-caption { font-size:16px; line-height :1.8; margin:calc( 20px - 0.4em ) 0 -0.4em; }
@media not all and (max-width:767px) {
  .p-single__header-image .p-single__header-category { display:none; }
}
@media (max-width:767px) {
  .p-single__header { }
  .p-single__header-content { padding:0; border:none; }
  .p-single__header-content .p-single__header-category { display:none; }
  .p-single__header-title { font-size:20px; margin-top:-0.4em; }
  * + .p-single__header-meta__item { margin-left:10px; }
  .p-single__header-image { position: relative; margin:20px -20px 0; }
  .p-single__header-image .p-single__header-category { position: absolute; top:0; left:0; margin:0 20px; z-index:1; }
}

/* 各コンテンツの余白 */
* + .p-single__margin { margin-top:50px; }
@media (max-width: 767px) {
  * + .p-single__margin { margin-top:40px; }
}

/* 本文 */


/* コピーボタン */
.p-copy-title-url { text-align: center; }
.p-copy-title-url__button {
  font-size:14px; background:#fff; border:3px solid #ccc; cursor:pointer; line-height:54px; min-width:300px; padding: 0 15px;
  transition-property:background-color, color; transition-duration:0.3s; transition-timing-function:ease;
}
.p-copy-title-url__button.copied { background:#ccc; color:#fff; pointer-events:none; }
@media (hover: hover) and (pointer: fine) {
  .p-copy-title-url__button:hover { color:rgba(0,0,0,0.5) !important; }
}
@media (max-width:767px) {
  * + .p-copy-title-url { margin-top:40px; }
  .p-copy-title-url__button { border-width:2px; font-size:12px; line-height:46px; min-width:250px; }
}

/* 記事下タグクラウド */
.p-single-tagcloud {}
.p-single-tagcloud__list { margin:-6px 0 0 -6px; }
.p-single-tagcloud__item { margin:6px 0 0 6px; }
.p-single-tagcloud__link {
  display:block; line-height: 35px; height: 35px; padding: 0px 12px;
  font-size:12px; background:#eeeeee; border-radius: 5px;
}
@media (hover: hover) and (pointer: fine) {
  .p-single-tagcloud__link:hover { background: rgba(var(--tcd-accent-color, 0,0,0),1); color: #fff; }
}
@media (max-width: 767px) {
  .p-single-tagcloud { margin-top:40px; }
}

/* プロフィール */
.p-author-profile {
  position:relative; padding:40px; background:rgba(var(--tcd-bg-color, 245, 245, 245),1);
  display:-webkit-box; display:-ms-flexbox; display:-webkit-flex; display:flex;
  -ms-align-items:center; -webkit-align-items:center; align-items:center;
}
.p-author-profile__image { display:block; width:110px; height:110px; border-radius:100%; overflow:hidden; }
.p-author-profile__image img { width:100%; height:100%; object-fit: cover; }
.p-author-profile__content { width:calc(100% - 110px); padding-left:40px; }
.p-author-profile__title {
  font-weight: 600;
  font-size:18px; line-height:1.6; margin:-0.3em 0 calc(15px - 0.3em);
  overflow: hidden; white-space: nowrap; text-overflow: ellipsis; visibility: visible;
}
.p-author-profile__desc { font-size:14px; line-height:1.8; margin:-0.4em 0; max-height:3.6em; }
.p-author-profile__icons { margin-top:15px; }
.p-author-profile__icons li:not(:last-of-type) { margin-right:0.5em; }

@media (hover: hover) and (pointer: fine) {
  .p-author-profile__title a:hover { color:rgba(0, 0, 0, 0.5); }
  .p-author-profile__title a:hover span { border-color:rgba(0, 0, 0, 0.5); }
}
@media (max-width:767px) {
  .p-author-profile { padding:20px; }
  .p-author-profile__image { width:90px; height:90px; }
  .p-author-profile__content { width:calc(100% - 90px); padding-left:20px; }
  .p-author-profile__title { font-size:14px; }
  .p-author-profile__desc { font-size: 12px; }
  .p-author-profile .c-sns-icons--type1 { font-size:16px; }
}

/* 次の記事・前の記事 */
.p-page-nav { font-size:16px; }
.p-page-nav__inner { display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; }
.p-page-nav__item {
  display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;
  -webkit-box-align: center; -ms-flex-align: center; -webkit-align-items: center; align-items: center;
  width:50%; height:120px; padding:0 30px; color:#000; border:1px solid #ddd;
}
.p-page-nav__item--prev { padding-left:30px; }
.p-page-nav__item--next { padding-right:30px; }
.p-page-nav__arrow { font-size:30px; color:inherit; }
.p-page-nav__arrow--prev { margin-right:30px; }
.p-page-nav__arrow--next { margin-left:30px; }
.p-page-nav__item--next:only-child { margin-left:auto; border-left:1px solid #ddd; }
.p-page-nav__item--prev + .p-page-nav__item--next { border-left:none; }
.p-page-nav__title {
  display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex;
  -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center;
  line-height:1.7; max-height: 3.4em; width:100%;
}
.p-page-nav__title-sp { display:none; }

@media (hover: hover) and (pointer: fine) {
  .p-page-nav__item:hover { color:rgba(0,0,0,0.5); }
}
@media (max-width: 767px) {
  .p-page-nav { font-size:14px; }
  .p-page-nav__item { height:60px; padding:0; border:1px solid #ddd; }
  .p-page-nav__item--prev { padding-right:0; }
  .p-page-nav__item--next { padding-left:0; }
  .p-page-nav__title-pc { display:none; }
  .p-page-nav__title-sp { display:block; width:100%; text-align: center; }
  .p-page-nav__arrow--prev { margin-right:-1em; padding-left:5px; }
  .p-page-nav__arrow--next { margin-left:-1em; padding-right:5px; }
}

/* 追加コンテンツ */


/* 関連記事 */
.p-related-post {}
.p-related-post__item-image { width:235px; height:160px; }
.p-related-post__item-image__bg { width:100%; height:100%; }
.p-related-post__item-content { width:100%; padding:30px; border:1px solid #ddd; border-top:none; }
* + .p-related-post__item-content { width:calc(100% - 235px); padding:0 30px; border-left:none; }
.p-related-post__item-content__title { font-size:18px; line-height:1.6; max-height:3.2em; margin:-0.3em 0; }
.p-related-post__item-content__date { margin-top:15px; }
@media (max-width: 767px) {
  .p-related-post { margin-left:-20px; margin-right:-20px; }
  .p-related-post__item-image { width:170px; height:120px; }
  .p-related-post__item-content { padding:20px; border-left:none; border-right:none; }
  * + .p-related-post__item-content { width:calc(100% - 170px);  padding:0 20px; }
  .p-related-post__item-content__title { font-size:14px; max-height:4.8em; }
  .p-related-post__item-content__title > span { -webkit-line-clamp: 3; }
  .p-related-post__item-content__date { margin-top:10px; }
  * + .p-related-post__item-content .p-related-post__item-content__date { display:none; }
}

/* コメント */
.p-single-comment {}
@media (max-width: 767px) {
  .p-single-comment {}
}


/* ----------------------------------------------------------------------
  Project - NEWS
---------------------------------------------------------------------- */

.p-archive--news { }
.p-archive--news .c-pagination { margin-bottom:25px; }
.p-archive--news-category {}
.p-archive--news-category__item { width:100%; }
.p-archive--news-category__item-link {
  cursor: pointer; width:100%; height:70px; padding:0 10px; line-height:1.4; border:1px solid #ddd; background:#fff;
  transition:color 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}
.p-archive--news-category__item:not(:last-of-type) .p-archive--news-category__item-link { border-right:none; }
.p-archive--news-category__item.is-active { pointer-events: none; }
.p-archive--news-category__item.is-active .p-archive--news-category__item-link
{ color:#fff; background:rgba(var(--tcd-accent-color, 0,0,0),1); border-color:rgba(var(--tcd-accent-color, 0,0,0),1); }
.p-archive--news-category__item.is-active + .p-archive--news-category__item .p-archive--news-category__item-link
{ border-left:none; }
@media (hover: hover) and (pointer: fine) {
  .p-archive--news-category__item:hover .p-archive--news-category__item-link {
    color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); border-color:rgba(var(--tcd-sub-color, 0,0,0),1);
  }
  .p-archive--news-category__item:hover + .p-archive--news-category__item .p-archive--news-category__item-link {
    border-left-color:transparent;
  }
}

@media not all and (max-width: 767px) {
  .p-archive--news-category { overflow: initial; }
}
@media (max-width: 767px) {
  .p-archive--news { margin:0 -20px; }
  .p-archive--news .c-pagination { margin-bottom:20px; }
  .p-archive--news-category {}
  .p-archive--news-category > *:last-child:after { content:none; }
  .p-archive--news-category__item { width:auto; white-space: nowrap; }
  .p-archive--news-category__item-link { min-width:110px; width:auto; height:50px; padding:0 20px; font-size:14px; }
  .p-archive--news-no-post { margin:15px 0 0 15px; }
}

/* loop */
.p-archive--news-wrapper { padding:10px 25px 25px 10px; background:rgba(var(--tcd-accent-color, 0,0,0),1); }
.p-archive--news-wrapper:not(.is-show) { display:none!important; }
.p-archive--news-loop { position: relative; margin-top:-1px; }
.p-archive--news-item { position: relative; width:calc(100% / 3 - 15px); margin:15px 0 0 15px; }
.p-archive--news-item__link { width:100%; }
.p-archive--news-item__category { margin:0 20px; position: absolute; top:20px; left:0; z-index:1; }
.p-archive--news-item__image { width:100%; height:220px; }
.p-archive--news-item__image-bg { width:100%; height:100%; }
.p-archive--news-item__content { width:100%; padding:30px; background:#fff; }
.p-archive--news-item__title { font-size:18px; line-height:1.6; margin:-0.3em 0; height:3.2em; }
.p-archive--news-item__date { margin-top:15px; }
/* no image */
.p-archive--news-item.is-no-image { width: calc(100% / 2 - 15px); background: #fff; }
.p-archive--news-item.is-no-image .p-archive--news-item__category { position:initial; margin:30px 29px -10px; }
.p-archive--news-no-post { margin:15px 0 0 15px; color:#fff; }

@media (max-width: 992px) {
  .p-archive--news-item { width: calc(100% / 2 - 15px); }
}
@media (max-width: 767px) {
  .p-archive--news-wrapper { padding:0 20px 20px 0; }
  .p-archive--news-loop {}
  .p-archive--news-item { width: calc(100% / 2 - 20px); margin:20px 0 0 20px; }
  .p-archive--news-item__content { padding:20px; }
  .p-archive--news-item__title { font-size:16px; }
  /* no image */
  .p-archive--news-item.is-no-image { width:100%; }
  .p-archive--news-item.is-no-image .p-archive--news-item__category { margin:20px 19px 0px; }
  .p-archive--news-no-post { margin:20px 0 0 20px; }
}
@media (max-width: 599px) {
  .p-archive--news-item { width: 100%; }
}


/* ロードアイコン */
.p-archive--news-item--ajax { opacity:0; transition: opacity 0.3s ease; }
.p-archive--news-item--ajax.is-show { opacity:1; }
.p-news-ajax-loading { height:70px; }
.p-news-ajax-loading.is-loading {
  animation: ajaxButtonAnimation 2s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
}
.p-archive--news-button:not(.is-loading) .p-news-ajax-loading { display:none; }
.p-archive--news-button.is-loading .p-archive--news-button__link { display:none; }

/* アイコンアニメーション */
.p-news-ajax-loading-icon, .p-news-ajax-loading-icon:before, .p-news-ajax-loading-icon:after {
  display:block; width: 1.5em; height: 1.5em; border-radius: 50%;
  -webkit-animation-fill-mode: both; animation-fill-mode: both;
  -webkit-animation: ajaxLoadAnimation 1.8s infinite ease-in-out;
  animation: ajaxLoadAnimation 1.8s infinite ease-in-out;
}
.p-news-ajax-loading-icon {
  display:block; color: rgba(255, 255, 255 ,0.7); position: relative; top:-1.5em; text-indent: -9999em; font-size: 10px;
  -webkit-transform: translateZ(0); -ms-transform: translateZ(0); transform: translateZ(0);
  -webkit-animation-delay: -0.16s; animation-delay: -0.16s;
}
.p-news-ajax-loading-icon:before, .p-news-ajax-loading-icon:after { content: ''; position: absolute; top: 0; }
.p-news-ajax-loading-icon:before { left: -2.5em; -webkit-animation-delay: -0.32s; animation-delay: -0.32s; }
.p-news-ajax-loading-icon:after { left: 2.5em; }
@keyframes ajaxLoadAnimation {
  0%,80%,100% { box-shadow: 0 1.5em 0 -1.3em; }
  40% { box-shadow: 0 1.5em 0 0; }
}
@media (max-width: 767px) {
  .p-news-ajax-loading { height:50px; }
}
.p-archive--news-button { width:100%; text-align: center; margin: 50px 0 25px 15px; }
.p-archive--news-button__link { border:1px solid #fff; transition-property: background, border; }
@media (hover: hover) and (pointer: fine) {
  .p-archive--news-button__link:hover { background:rgba(var(--tcd-sub-color, 0,0,0),1); border-color:rgba(var(--tcd-sub-color, 0,0,0),1); }
}
@media (max-width: 767px) {
  .p-archive--news-button { margin: 40px 0 20px 20px; }
}


/* ----------------------------------------------------------------------
  Project - single news
---------------------------------------------------------------------- */

/* 新着記事 */
.p-single--news__header {}
.p-single--news__header-content {}
.p-single--news__header-category { margin-left:-1px; margin-bottom:20px; }
.p-single--news__header-title { margin-top:-0.25em; }
.p-single--news__header-image { margin-top:47px; }
@media not all and (max-width: 767px) {
  .p-single--news__header-category { padding: calc(13px - 0.2em) 15px; }
  .p-single--news__header-image .p-single--news__header-category { display:none; }
}
@media (max-width: 767px) {
  .p-single--news:not(.is-no-image) .p-single--news__header-content .p-single--news__header-category { display:none; }
  .p-single--news.is-no-image .p-single--news__header-category {}
  .p-single--news__header-image { margin-top:20px; }
  .p-single--news__header-image .p-single--news__header-category { position: absolute; top:20px; margin:0 19px; margin-bottom:0px; }
}

.p-recent-news {}
@media (max-width: 767px) {
  .p-recent-news { margin-left:-20px; margin-right:-20px; }
}

/* ----------------------------------------------------------------------
  Project - facilty archive
---------------------------------------------------------------------- */

/* main loop */
.p-archive--facility {}
.p-archive--facility-loop { margin:-50px 0 0 -50px; }
.p-archive--facility-item { width:calc(100% / 2 - 50px); margin:50px 0 0 50px; }
.p-archive--facility-item__link {}
.p-archive--facility-item__image { width:100%; height:250px; }
.p-archive--facility-item__image-bg { width:100%; height:100%; }
.p-archive--facility-item__title {
  width:100%; height:70px; line-height:70px; padding: 0 40px;
  color:#fff; background:rgba(var(--tcd-accent-color, 0,0,0),1);
  font-size:20px; text-align: center; transition: color 0.3s ease;
}
.p-archive--facility-item__desc { background:#f6f6f6; padding:40px; }
.p-archive--facility-item__desc-text { font-size:16px; line-height:2.4; margin:-0.7em 0; height:7.2em; }
@media (hover: hover) and (pointer: fine) {
  .p-archive--facility-item__link:hover .p-archive--facility-item__image-title { color:rgba(255, 255, 255, 0.5); }
}

@media (max-width: 767px) {
  .p-archive--facility-loop { margin:-20px 0 0 -20px; }
  .p-archive--facility-item { width:calc(100% / 2 - 20px); margin:20px 0 0 20px; }
  .p-archive--facility-item__image { height:160px; }
  .p-archive--facility-item__title { font-size:16px; height:60px; line-height:60px; padding:0 20px; }
  .p-archive--facility-item__desc { padding:20px; }
  .p-archive--facility-item__desc-text { font-size:14px; line-height:2.2; margin:-0.6em 0; height:8.8em; }
  .p-archive--facility-item__desc-text span { -webkit-line-clamp: 4; }
}
@media (max-width: 599px) {
  .p-archive--facility-item { width:calc(100% - 20px); }
}

/* bottom */
.p-facility-info {}
* + .p-facility-info { padding-top:120px; }
.p-facility-info__header { text-align: center; }
.p-facility-info__header-headline { font-size:36px; line-height:1.6; margin:-0.3em 0; }
.p-facility-info__header-desc { font-size:18px; line-height:2.4; margin:-0.7em 0; }
* + .p-facility-info__header-desc { margin-top:calc(40px - 0.7em); }
.p-facility-info__list { margin:-50px 0 0 -50px; }
* + .p-facility-info__list { padding-top:120px; }
.p-facility-info__item { margin:50px 0 0 50px; }
.p-facility-info__item--type1 { width:calc(100% / 2 - 50px); }
.p-facility-info__item--type2 { width:100%; }
.p-facility-info__item--type1-box {}
.p-facility-info__item--type1-box__image { width:170px; height:170px; }
.p-facility-info__item--type1-box__image-bg { width:100%; height:100%; }
.p-facility-info__item--type1-box__content { width:100%; }
* + .p-facility-info__item--type1-box__content { width:calc(100% - 170px); padding-left:30px; }
.p-facility-info__item--type1-box__title { font-size:20px; line-height:1.6; margin:-0.3em 0; }
.p-facility-info__item--type1-box__desc { font-size:16px; line-height:2.4; margin:-0.7em 0; }
* + .p-facility-info__item--type1-box__desc { margin-top:calc(30px - 0.7em); }
.p-facility-info__item--type2 { width:100%; }

@media not all and (max-width: 767px) {
  .p-facility-info__item--type1-box__desc--sp { display:none; }
}
@media (max-width: 767px) {
  * + .p-facility-info { padding-top:40px; }
  .p-facility-info__header {}
  .p-facility-info__header-headline { font-size:20px; }
  .p-facility-info__header-desc { font-size:14px; line-height:2; margin:-0.5em 0; }
  * + .p-facility-info__header-desc { margin-top:calc(30px - 0.5em); }
  .p-facility-info__list { margin:-20px 0 0 -20px; }
  * + .p-facility-info__list { padding-top:40px; }
  .p-facility-info__item { margin:20px 0 0 20px; }
  .p-facility-info__item--type1 { width:calc(100% - 20px); margin:20px 0 0 20px; }
  .p-facility-info__item--type1 +.p-facility-info__item--type1 {
    padding-top:20px; border-top:1px solid #ddd;
  }
  * + .p-facility-info__item--type2 { margin-top:40px; }
  .p-facility-info__item--type1-box__image { width:120px; height:120px; }
  * + .p-facility-info__item--type1-box__content {
    width:calc(100% - 120px); padding-left:20px;
    display:-webkit-box; display:-ms-flexbox; display:flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center;
  }
  .p-facility-info__item--type1-box__title { font-size:16px; }
  .p-facility-info__item--type1-box__desc { font-size:14px; line-height:2.2; margin:-0.6em 0; }
  * + .p-facility-info__item--type1-box__desc { margin-top:calc(20px - 0.6em); }
  .p-facility-info__item--type1-box__desc--pc { display:none; }
}



/* ----------------------------------------------------------------------
  Project - facilty single
---------------------------------------------------------------------- */

.p-single--facility {}
.p-single--facility__title {}
.p-single--facility__wrapper { padding:80px; background:#f6f6f6; }
.p-single--facility__image img { width:100%; }
.p-single--facility__caption { background:#fff; padding:calc(30px - 0.3em) 30px; font-size:20px; line-height:1.6; text-align: center; font-weight:600; }
.p-single--facility__pager { background:#f6f6f6; height:120px; padding:0 80px; margin-top:2px; }
.p-single--facility__pager-link { font-size:16px; flex:1 1 0; }
.p-single--facility__pager-prev { margin-right:35px; }
.p-single--facility__pager-prev .p-single--facility__pager-arrow { -webkit-box-pack: end; -ms-flex-pack: end; justify-content: flex-end; }
.p-single--facility__pager-next { margin-left:35px; }
.p-single--facility__pager-prev .p-single--facility__pager-arrow { -webkit-box-pack: end; -ms-flex-pack: end; justify-content: flex-end; }
.p-single--facility__pager-arrow {  }
.p-single--facility__pager-icon { color:inherit; font-size:30px; margin:0 5px; }
@media (hover: hover) and (pointer: fine) {
  .p-single--facility__pager-arrow:hover { color:rgba(0, 0, 0, 0.5); }
}
@media (max-width: 767px) {
  .p-single--facility { margin:0 -20px; }
  .p-single--facility__wrapper { padding:0 20px 40px; }
  .p-single--facility__image { margin:0 -20px; }
  .p-single--facility__caption { font-size:14px; padding:calc(20px - 0.3em) 20px; margin:0 -20px; }
  .p-single--facility__pager { height:100px; padding:0; }
  .p-single--facility__pager-label { display:none; }
  .p-single--facility__pager-prev { margin-right:5px; }
  .p-single--facility__pager-next { margin-left:5px; }
}

/* ----------------------------------------------------------------------
  Project - events
---------------------------------------------------------------------- */

/* time */
.p-events-times { white-space: nowrap; }
.p-events-times__item {
  min-width:80px; min-height:35px; line-height:35px; border-radius: 35px;
  font-size:14px; text-align: center; padding:0 15px; margin-right: 10px;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1);
}
.p-events-times__item:last-child{ margin-right:0; }
@media (max-width: 767px) {
  .p-events-times__item {
    min-width:70px; min-height:30px; line-height:30px; border-radius:30px; padding:0 15px;
  }
}

/* loop */
.p-events-loop {}
.p-events-loop__item {}
.p-events-loop__item-link { position: relative; }
.p-events-loop__item-date { height:60px; }
.p-events-loop__item-image { position: relative; }
.p-events-loop__item-image__bg { width:350px; height:240px; }
.p-events-loop__item-content { width:calc(100% - 350px); padding:0 40px; border-right:1px solid #ddd; border-bottom:1px solid #ddd; }
.p-events-loop__item-content-inner { width:100%; }
.p-events-loop__item-times { margin-bottom:25px; display: flex;flex-wrap: wrap; gap: 10px;}
.p-events-loop__item-title { font-size:20px; line-height:1.6; height:1.6em; margin:-0.3em 0; }
.p-events-loop__item-desc { font-size:16px; line-height:2; max-height:4em; margin:calc(25px - 0.5em) 0 -0.5em; }
@media (max-width: 767px) {
  .p-events-loop__item { border-bottom:1px solid #ddd; }
  .p-events-loop__item-link { padding:30px 20px; }
  .p-events-loop__item-image { width:100%; }
  .p-events-loop__item-image__bg { width:100%; height:220px; }
  .p-events-loop__item-content { width:100%; padding:20px 0 0; border:none; }
  .p-events-loop__item-times { margin-bottom:20px; }
  .p-events-loop__item-title { font-size:16px; height:auto; max-height:3.2em; }
  .p-events-loop__item-title span { -webkit-line-clamp: 2; }
  .p-events-loop__item-desc { font-size:14px; margin-top:calc(20px - 0.5em); }
}

.event_dates{ border:1px solid #ddd; border-top:none; display:flex; flex-wrap:wrap; }
.event_dates li{ display: block; width:50%; border-right: 1px solid #ddd; border-bottom: 1px solid #ddd; margin-bottom:-1px; }
.event_dates li:nth-child(2n){ border-right:none; }
.event_dates li a{ display: flex; height:70px; align-items:center; justify-content: center; transition: opacity 0.3s ease; font-size:20px; }
.event_dates li a:hover{ opacity: 0.5; }
.event_dates li a span{ display:block; }
@media screen and (max-width: 768px) {
  .event_dates li a{ height:56px; }
  .event_dates{ border-right:none; border-left:none; }
  .event_dates li a::before{ content: attr(data-date); font-size: 16px; }
  .event_dates li a span{ display: none; }
}



/* ----------------------------------------------------------------------
  Project - event archive
---------------------------------------------------------------------- */

.p-calender {}
.p-archive--events {}
@media not all and (max-width: 767px) {
  .p-calender--sp { display:none; }
}
@media (max-width: 767px) {
  .p-calender--pc { display:none; }
  .p-archive--events { margin:0 -20px; }
}

/* ナビゲーション */
.p-calender__nav { height:70px; }
.p-calender__nav-headline { font-size:22px; width:calc(100% - 460px); height:100%; border:1px solid #ddd; border-bottom:none; }
.p-calender__nav-link { width:230px; height:100%; border-top:1px solid #ddd; transition: background 0.3s ease; }
.p-calender__nav-link--prev { border-left:1px solid #ddd; }
.p-calender__nav-link--next { border-right:1px solid #ddd; }
.p-calender__nav-icon { font-size:18px; }
.p-calender__nav-icon--prev { margin-right:5px; }
.p-calender__nav-icon--next { margin-left:5px; }
@media (hover: hover) and (pointer: fine) {
  .p-calender__nav-link:hover { background-color: #f6f6f6; }
}
@media (max-width: 767px) {
  .p-calender__nav { height:60px; }
  .p-calender__nav-headline { font-size:18px; width:calc(100% - 160px); border-left:none; border-right:none; }
  .p-calender__nav-link { width:80px; }
  .p-calender__nav-link--prev { border-left:none; }
  .p-calender__nav-link--next { border-right:none; }
  .p-calender__nav-icon--prev { margin:0; }
  .p-calender__nav-icon--next { margin-left:2px; }
}

/* カレンダーPC */
.p-calender__header {}
.p-calender__header-row { font-size:16px; font-weight:600; color:#fff; background:rgba(var(--tcd-accent-color, 0,0,0),1); }
.p-calender__header-item { height:50px; line-height:50px; border:1px solid rgba(var(--tcd-accent-color, 0,0,0),1); }
.p-calender__header-item:not(:last-of-type) { border-right-color:rgba(255,255,255,0.3); }
.p-calender__body {}
.p-calender__body-row {}
.p-calender__body-item { position: relative; font-size:14px; width: calc(100% / 7); height: 150px; border:1px solid #ddd; }
.p-calender__body-item--pad { background:#f6f6f6; }
.p-calender__body-item-week--0 .p-calender__body-item__day { color:#d90000; }
.p-calender__body-item__modal {
  color:rgba(var(--tcd-sub-color, 0,0,0),1); font-size: 30px; font-weight:400; margin: -0.2em; transition: filter 0.3s ease;
}
.p-calender__body-item__day {
  display:block; font-size:20px; margin:15px 15px 0;
  position: relative; z-index:2; font-weight:600; justify-content: space-between;
}
.p-calender__body-item__comment { padding:20px 15px 15px; }
.p-calender__body-item__comment-text { font-size:14px; line-height:1.6; height:3.2em; margin:-0.3em 0; }
.p-calender__body-item__link { display:block; width:100%; height:45px; color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); }
.p-calender__body-item.is-past .p-calender__body-item__link { background: #bbbbbb; }
.p-calender__body-item__link-button { width:100%; height:100%; font-weight:600; transition: background 0.3s ease; padding: 10px; line-height: 1.4;}
@media (hover: hover) and (pointer: fine) {
  .p-calender__body-item__link:hover .p-calender__body-item__link-button { background: rgba(0, 0, 0, 0.2); }
  .p-calender__body-item__modal:hover { filter: brightness(0.8); }
}
.p-calender__body-item__holiday {
  position: absolute; top:0; left:0; width:100%; height:100%;
  line-height:1.6; padding: 40px 15px;
  background:rgba(var(--tcd-sub-color, 0,0,0),0.2);
}

/* ----------------------------------------------------------------------
  Project - event archive sp
---------------------------------------------------------------------- */
.p-calender--sp {}
.p-calender--sp__body {}
.p-calender--sp__body-row {}
.p-calender--sp__body-item { border:1px solid #ddd; width:60px; height:80px; vertical-align: middle; }
.p-calender--sp__body-item--day {}
.p-calender--sp__body-item--day-wrapper { width:100%; height:100%; flex-direction: column; }
.p-calender--sp__body-item--day-number { font-size:20px; font-weight:600; line-height:1; }
.p-calender--sp__body-item--day-week { font-size:14px; margin-top:5px; }
.p-calender--sp__body-item--week-0 { color:#d80000; }
.p-calender--sp__body-item--caption { width:calc(100% - 180px); }
.p-calender--sp__body-item--caption-wrapper { width:100%; height:100%; padding:0 15px; }
.p-calender--sp__body-item--caption-text { font-size:14px; line-height:1.6; max-height:3.2em; }
.p-calender--sp__body-item--modal {}
.p-calender--sp__body-item--modal-icon { width:100%; height:100%; margin:0; }
.p-calender--sp__body-item--events {}
.p-calender--sp__body-item--events-link { width:100%; height:100%; color:rgba(var(--tcd-sub-color, 0,0,0),1); }
.p-calender--sp__body-item--holiday { font-size:14px; background: rgba(var(--tcd-sub-color, 0,0,0),0.2); }
.p-calender--sp__body-item--holiday-label { padding:0 15px; line-height:1.6; }
/* アーカイブ下 */
* + .p-archive--events-bottom { margin-top:120px; }
@media (max-width: 767px) {
  * + .p-archive--events-bottom { margin-top:0; }
}


/* ----------------------------------------------------------------------
  Project - event archive modal
---------------------------------------------------------------------- */

.p-calender-modal { position: fixed; top:0; left:0; z-index:100; width:100%; height:100%; }
.p-calender-modal:not(.is-active) { visibility: hidden; pointer-events: none; }
.p-calender-modal__inner { position: absolute; top:0; left:0; width:100%; height:100%; pointer-events: none; }
.p-calender-modal__content {
  width:420px; max-width:calc(100% - 40px); border-radius:10px; overflow: hidden; background:#fff;
  filter: drop-shadow(0 0px 10px rgba(0,0,0, 0.2)); pointer-events: auto;
  overflow: hidden auto; max-height: calc(100% - 100px);
  transform:translateY(20px); opacity:0;
  transition:opacity 0.3s ease, transform 0.4s cubic-bezier(0.22,0.61,0.36,1);
}
.p-calender-modal.is-active .p-calender-modal__content { opacity:1; transform:translateY(0); }
.p-calender-modal__content-close {
  display: block; color:#fff; transition:color 0.3s ease;
  position: absolute; top:0; right:0; width:60px; height:60px; font-weight:400;
}
.p-calender-modal__headline {
  font-size:18px; text-align: center; line-height:60px; height:60px;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1);
}
@media (hover: hover) and (pointer: fine) {
  .p-calender-modal__content-close:hover {
    color:rgba(255, 255, 255, 0.5);
  }
}
@media (max-width: 767px) {
  .p-calender-modal__content { max-height: calc(100% - 80px); }
  .p-calender-modal__content-close { width:50px; height:50px; }
  .p-calender-modal__headline { font-size:16px; line-height:50px; height:50px; }
}

.p-calender-modal__content-wrap { padding:30px; }
.p-calender-modal__content-headline { font-size:18px; line-height:1.6; margin:-0.3em 0; }
.p-calender-modal__content-desc { font-size:16px; line-height:2.2; margin:-0.6em 0; }
* + .p-calender-modal__content-desc { margin-top:calc(20px - 0.6em); }
.p-calender-modal__content-button { text-align: center; margin-top:30px; }
.p-calender-modal__content-button__link { font-size:14px; min-width:170px; min-height:50px; }
.p-calender-modal__content-events {}
* + .p-calender-modal__content-events { margin-top:30px; }
.p-calender-modal__content-events__headline {
  font-size:16px; text-align: center; line-height:50px; height:50px;
  color:#fff; background:rgba(var(--tcd-sub-color, 0,0,0),1); position: relative;
}
.p-calender-modal__content-events__item { margin-top:-1px; }
.p-calender-modal__content-events__item-link {
  display: block; font-size:16px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  height:50px; line-height:50px; padding:0 20px; border:1px solid #ddd;
}
.p-calender-modal__overlay { width:100%; height:100%; background:rgba(0, 0, 0, 0.3); }
@media (hover: hover) and (pointer: fine) {
  .p-calender-modal__content-events__item-link:hover {
    color:rgba(var(--tcd-sub-color, 0,0,0),1);
  }
}
@media (max-width: 767px) {
  .p-calender-modal__content-wrap { padding:30px 20px; }
  .p-calender-modal__content-headline { font-size:16px; }
  .p-calender-modal__content-desc { font-size:14px; }
  .p-calender-modal__content-events__headline { font-size:14px; }
  .p-calender-modal__content-events__item-link { font-size:14px; }
}


/* ----------------------------------------------------------------------
  Project - event archive day
---------------------------------------------------------------------- */

.p-archive--events-day {}
.p-single--events__wapper + .p-single--events__list { margin-top:120px; }
.p-archive--events-day__nav { padding:25px 0; border:1px solid #ddd; border-top:none; }
@media (max-width: 767px) {
  .p-single--events__wapper + .p-single--events__list { margin-top:-1px; }
  .p-archive--events-day__nav { border-left:none; border-right:none; }
}

/* ----------------------------------------------------------------------
  Project - events single
---------------------------------------------------------------------- */

.p-single--events {}
.p-single--events__wapper { border:1px solid #ddd; border-top:none; }
.p-single--events__title { position: relative; }
.p-single--events__title-date {
  position: absolute; top:0; left:0; z-index:5;
  width:70px; height:70px;
  color:#fff; background: rgba(var(--tcd-sub-color, 0,0,0),1);
}
.p-archive--events-day .p-single--events__title-date { display: none!important; }
.p-single--events__title-inner { text-align: center; }
.p-single--events__title-date--y { display:block; font-size:12px; }
.p-single--events__title-date--md { display:block; font-size:20px; margin-top:8px; font-weight:600; }
.p-single--events__title-date--md-unit { font-size:16px; }
@media not all and (max-width: 767px) {
  .p-single--events__title-date + .p-single--events__title-text { padding-left:90px; padding-right:90px; }
}
@media (max-width: 767px) {
  .p-single--events { width:calc(100% + 40px); margin:0 -20px; }
  .p-single--events__wapper { border-left: none; border-right:none; }
  .p-single--events .p-single--events__title-date { display:none; }
  .p-single--events__title-text { text-align: left; }
}

/* ヘッダー */
.p-single--events__header { background:#f6f6f6; }
.p-single--events__header-content { width:calc(100% + 2px); margin:0 -1px; }
.p-single--events__header-content:not(:only-child) { width:calc(50% + 1px); margin-right:0; min-height:360px; }
.p-single--events__header-image img { width:100%; height:100%; object-fit: cover; }
.p-single--events__header-excerpt { font-size:18px; font-weight:600; line-height:2.4; padding:calc(50px - 0.7em) 50px; }
@media (max-width: 767px) {
  .p-single--events__header-content:not(:only-child) { width:100%; min-height:auto; }
  .p-single--events__header-image { width:100%; height:250px; margin:0; }
  .p-single--events__header-excerpt { font-size:16px; line-height:2.2; padding:calc(40px - 0.6em) 40px; }
}

/* テーブル */
.p-single--events__table { margin-top:-1px; }
.p-single--events__table-wrapper {}
.p-single--events__table-body {}
.p-single--events__table-row {  }
.p-single--events__table-cell { font-size:16px; line-height:1.6; padding:calc(27px - 0.3em) 30px; border:1px solid #ddd; }
.p-single--events__table-cell--headline { width:24%; text-align: center; border-left:none; background: #f6f6f6; vertical-align: middle; font-weight:normal; }
.p-single--events__table-cell--data { width:76%; border-right:none; }
@media (max-width: 767px) {
  .p-single--events__table { overflow: auto hidden; white-space: nowrap; }
  .p-single--events__table-cell { font-size:14px; padding:calc(20px - 0.3em) 20px; }
  .p-single--events__table-cell--headline { background: #fff; }
}

.p-single--events__content { padding:80px; }
@media (max-width: 767px) {
  .p-single--events__content { padding:40px 20px; }
}
.p-single--events__pager { background:#fff; border-top:1px solid #ddd; }


/* ----------------------------------------------------------------------
  Project - news ticker
---------------------------------------------------------------------- */

.p-news-ticker { position: relative; width:100%; border-top:1px solid rgba(255, 255, 255, 0.2); margin-top:-61px; z-index:5; }
.p-news-ticker__inner { max-width:800px; height:60px; }
.p-news-ticker__list { height:100%; }
.p-news-ticker__wrapper { height:100%; }
.p-news-ticker__item { height:100%; font-size:16px; opacity:0; transition: opacity 1s ease; }
.p-news-ticker__date { line-height:60px; font-weight:600; color:rgba(var(--tcd-sub-color, 0,0,0),1); }
.p-news-ticker__title { line-height:60px; margin-left:15px; }
.p-news-ticker__link { color:#fff; }
.p-news-ticker__item.is-active { opacity:1; }
@media (hover: hover) and (pointer: fine) {
  .p-news-ticker__link:hover { color: rgba(255, 255, 255, 0.5); }
}
@media (max-width: 767px) {
  .p-news-ticker { margin-top:-51px; }
  .p-news-ticker__inner { height:50px; }
  article.p-news-ticker__item { font-size:14px; -webkit-box-pack: start; -ms-flex-pack: start; justify-content: flex-start; }
  .p-news-ticker__date { line-height:50px; }
  .p-news-ticker__title { font-size:14px; line-height:50px; margin-left:10px; }
}
.p-news-ticker--ad-code { font-size:16px; padding:20px 0; text-align: center; color:#fff; line-height:1.8; }
.p-news-ticker--ad-code p { margin:-0.4em 0; }
.p-news-ticker--ad-code a { color:rgba(var(--tcd-link-color, 21,120,214),1); }
@media (hover: hover) and (pointer: fine) {
  .p-news-ticker--ad-code a:hover { text-decoration: underline; }
}
@media (max-width: 767px) {
  .p-news-ticker--ad-code { font-size:14px; }
}


/* ----------------------------------------------------------------------
  Project - front page section
---------------------------------------------------------------------- */

.p-fp-section { padding:120px 0; }
.p-fp-section:not(.p-fp-banner) + .p-fp-section:not(.p-fp-banner) { margin-top:-120px; }
@media (max-width: 767px) {
  .p-fp-section { padding:40px 0; }
  .p-fp-section:not(.p-fp-banner) + .p-fp-section:not(.p-fp-banner) { margin-top:-40px; }
}
.p-fp-section__header { text-align: center; padding-bottom:50px; }
.p-fp-section__headline { font-size:38px; line-height:1.6; margin:-0.3em 0; }
.p-fp-section__desc { font-size:18px; line-height:1.6; margin:-0.3em 0; }
.p-fp-section__headline + .p-fp-section__desc { margin-top:calc(20px - 0.3em); }
@media (max-width: 767px) {
  .p-fp-section__header { padding-bottom:40px; }
  .p-fp-section__headline { font-size:28px; }
  .p-fp-section__desc { font-size:14px; }
  .p-fp-section__headline + .p-fp-section__desc { margin-top:calc(15px - 0.5em); }
}
.p-fp-section__button { margin-top:50px; text-align: center; position: relative; z-index:1; }
@media (max-width: 767px) {
  .p-fp-section__button { margin-top:40px; }
}


/* ----------------------------------------------------------------------
  Project - front page - page type
---------------------------------------------------------------------- */

.p-fp-main-page { padding:100px 0 150px; }
@media (max-width: 767px) {
  .p-fp-main-page { padding:40px 0; }
}

/* ----------------------------------------------------------------------
  Project - front page banner
---------------------------------------------------------------------- */

.p-fp-banner { position: relative; height:560px; overflow: hidden; background:#333; }
.p-fp-banner__content { position: absolute; top:0; left:0; width:100%; height:100%; z-index:3; }
.p-fp-banner__inner { color:#fff; text-align: center; }
.p-fp-banner__title { font-size:36px; line-height:1.6; margin:-0.3em 0; }
.p-fp-banner__desc { font-size:18px; line-height:2.4; margin:-0.7em 0; }
* + .p-fp-banner__desc { margin-top:calc(40px - 0.7em); }
.p-fp-banner__button { border:1px solid rgba(var(--tcd-sub-color, 0,0,0),1); transition-property: background, border; }
.p-fp-banner__button:not(:hover) { background: transparent; border-color:#fff; }
* + .p-fp-banner__button { margin-top:40px; }
.p-fp-banner__image { width:100%; }
.p-fp-banner__image {  }
.p-fp-banner__image-bg { width:100%; height:560px; }
.p-fp-banner__image-bg[data-orientation="up"],
.p-fp-banner__image-bg[data-orientation="down"] { width:88%; margin:0 6%; }

@media (max-width: 767px) {
  .p-fp-banner { height:450px; }
  .p-fp-banner__title { font-size:20px; }
  .p-fp-banner__desc { font-size:14px; line-height:2; margin:-0.5em 0; }
  * + .p-fp-banner__desc { margin-top: calc(30px - 0.5em); }
  * + .p-fp-banner__button { margin-top:30px; }
  .p-fp-banner__image-bg { height:450px; }
}


/* ----------------------------------------------------------------------
  Project - front page posts
---------------------------------------------------------------------- */

.p-fp-posts { overflow: hidden; }
.p-fp-posts__splide { position: relative; visibility: visible; }

/* slider */
.p-fp-posts.is-slider .p-fp-posts__splide:before {
  content:''; position: absolute; left:0; bottom:0; z-index:1;
  width:1px; height:143.25px; background:#ddd;
}
.p-fp-posts.is-slider .p-fp-posts__splide:after {
  content:''; position: absolute; right:0; bottom:0; z-index:1;
  width:1px; height:143.25px; background:#ddd;
}
.p-fp-posts.is-slider .p-archive--post-item { width:calc(100% / 3); margin:0; }
.p-fp-posts.is-slider .p-archive--post-item__content { border-right:none }
.p-fp-posts:not(.is-slider) .p-fp-posts__list {
  overflow: initial; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 1px 0 0 1px!important;
}
.p-fp-posts:not(.is-slider) .splide__arrows { display: none; }
@media (max-width: 1150px) {
  .p-fp-posts.is-slider .p-fp-posts__inner { padding: 0 30px; }
}
@media not all and (max-width: 767px) {
  .p-fp-posts.is-slider .p-fp-posts__list { overflow: initial; }
}
@media (max-width: 767px) {
  .p-fp-posts.is-slider .p-fp-posts__inner { padding: 0; }
  .p-fp-posts.is-slider .p-fp-posts__splide { margin:0 -20px; }
  .p-fp-posts__splide:after, .p-fp-posts__splide:before { content:none; }
  .p-fp-posts.is-slider .p-fp-posts__list { display:flex!important; padding: 0 20px!important; }
  .p-fp-posts.is-slider .splide__slide:last-child .p-archive--post-item__content { border-right:1px solid #ddd; }
  .p-fp-posts.is-slider .p-archive--post-item { width:260px; min-width:260px; }
  .p-fp-posts.is-slider .p-archive--post-item__image-bg { height:180px; }
}

/* ----------------------------------------------------------------------
  Project - front page news slider
---------------------------------------------------------------------- */

.p-fp-news { overflow: hidden; }
.p-fp-news__tab {}
.p-fp-news__tab-labels {}
.p-fp-news__tab-labels-item { cursor: pointer; }
.p-fp-news__tab-labels-link { transition:background 0.3s ease; }
.p-fp-news__tab-area { background: rgba(var(--tcd-accent-color, 0,0,0),1); padding:25px; margin-top:-1px; position: relative; }
.p-fp-news__tab-area__item.splide { visibility: visible; }
.p-fp-news__tab-area__item:not(.is-show) { display:none; }

.splide.is-initialized:not(.is-active) .p-fp-news__tab-area__item-list { display: -webkit-box; display: -ms-flexbox; display: flex; }
.p-fp-news__arrow.c-arrow--prev { left:-90px; }
.p-fp-news__arrow.c-arrow--next { right:-81px; }

.p-fp-news:not(.is-slider) .p-fp-news__tab-area {}
.p-fp-news:not(.is-slider) .p-fp-news__tab-area__item-track { margin:-15px 0 0 -15px; }
.p-fp-news:not(.is-slider) .p-fp-news__tab-area__item-list {
  display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap;
  overflow: initial;
}
.p-fp-news:not(.is-slider) .splide__arrows { display:none; }

@media (max-width: 1150px) {
  .p-fp-news.is-slider .p-fp-news__inner { padding: 0 30px; }
}
@media not all and (max-width: 767px) {
  /* slider */
  .p-fp-news.is-slider .p-fp-news__tab-area__item-list { overflow: initial; }
  .p-fp-news.is-slider .p-fp-news__tab-area__item-slide.splide__slide { width: calc(((100% + 15px) / 3) - 15px); margin: 0 15px 0 0; }
  .p-fp-news.is-slider .p-fp-news__tab-area__item-slide.is-no-image { width: calc(((100% + 15px) / 2) - 15px); }
}
@media (max-width: 767px) {
  .p-fp-news__inner { padding:0; width:100%; }
  .p-fp-news__tab {  }
  .p-fp-news__tab-area { padding:20px; }
  .p-fp-news:not(.is-slider) .p-fp-news__tab-area__item-track { margin:-20px 0 0 -20px; }

  /* slider */
  .p-fp-news.is-slider .p-fp-news__inner { padding: 0; }
  .p-fp-news.is-slider .p-fp-news__tab-area { padding:20px 0; }
  .p-fp-news.is-slider .p-fp-news__tab-area__item-slide:first-child { margin-left:20px; }
  .p-fp-news.is-slider .p-fp-news__tab-area__item-slide { width:260px; margin:0 0 0 20px; }
  .p-fp-news.is-slider .p-archive--news-item__image { height:180px; }
}


/* ----------------------------------------------------------------------
  Project - front page events slider
---------------------------------------------------------------------- */

.p-fp-events { overflow: hidden; }
.p-fp-events__slider { position: relative; visibility: visible; }
.p-fp-events__track {}
.p-fp-events__list {  }
.p-fp-events__item { width:calc(100% / 3); }
.p-fp-events__item-link { display: block; }
.p-fp-events__item-image { width:100%; }
.p-fp-events__item-image__bg { width:100%; height:240px; }
.p-fp-events__item-date { color:#fff; background: rgba(var(--tcd-sub-color, 0,0,0),1); font-size:14px; }
.p-fp-events__item-date__month { width:60px; height:60px; background: rgba(0, 0, 0, 0.3); }
.p-fp-events__item-date__ymd { flex:1 1 0; height:60px; line-height:1.8; padding:0 20px; overflow: hidden; }
.p-fp-events__item-content { position: relative; padding:30px; color:#fff; background: rgba(var(--tcd-accent-color, 0,0,0),1); }
.p-fp-events__item-content:before {
  content:''; width:1px; height:100%; background:rgba(255,255,255,0.3);
  position: absolute; top:0; left:-1px;
}
.p-fp-events__item-headline { font-size:18px; line-height:1.6; height:3.2em; margin:-0.3em 0; transition: color 0.3s ease; }
.p-fp-events:not(.is-slider) .p-fp-events__list { overflow: initial; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.p-fp-events:not(.is-slider) .splide__arrows { display: none; }

@media (hover: hover) and (pointer: fine) {
  .p-fp-events__item-link:hover .p-fp-events__item-headline { color:rgba(255, 255, 255, 0.5); }
}
@media not all and (max-width: 767px) {
  /* slider */
  .p-fp-events.is-slider .p-fp-events__list { overflow: initial; }
}
@media (max-width: 992px) {
  .p-fp-events__item { width:calc(100% / 2); }
}
@media (max-width: 767px) {
  .p-fp-events__list { display: flex!important; }
  .p-fp-events__item-image__bg { height:200px; }
  .p-fp-events__item-date__month { height:50px; }
  .p-fp-events__item-date__ymd { height:50px; }
  .p-fp-events__item-content { padding:20px; }
  .p-fp-events__item-headline { font-size:16px; }
  
  .p-fp-events.is-slider .p-fp-events__track { margin:0 -20px; }
  .p-fp-events.is-slider .p-fp-events__list { padding-left:20px!important; }
  .p-fp-events.is-slider .p-fp-events__item { width:300px; min-width:300px; }
}
@media (max-width: 599px) {
  .p-fp-events__item { width:100%; }
}

/*** イベントが登録されていないときのテキスト ***/
.p-fp-event__desc{
  text-align: center;
  line-height: 1.8;
}

/*** 追加コンテンツのスタイル調整 ***/
.p-single-banner { line-height:2.4; }
.p-single-banner a img { -webkit-transition: filter 0.3s ease; transition: filter 0.3s ease; }
@media(hover: hover) {
  .p-single-banner a:hover img { filter: brightness(80%); }
}

@media (max-width: 767px) {
  .p-single-banner { line-height:2; }
}

/* ----------------------------------------------------------------------
  Project - Page
---------------------------------------------------------------------- */

/* LP */
.p-single--lp--narrow { max-width:700px; }
.p-single--lp--normal { max-width:900px; }
.p-single--lp--wide {}

@media not all and (max-width: 767px) {
  .p-single--lp { margin:0 auto; }
}
@media (max-width: 767px) {
  .p-single--lp {}
}

/* デザインコンテンツ */
.post_content * + .p-dc { margin-top:100px; }
.post_content .p-dc__image-top img { width:100%; }
.post_content .p-dc__content { padding:100px; color:#fff; text-align: center; background: rgba(var(--tcd-accent-color, 0,0,0),1); }
.post_content .p-dc__image-top + .p-dc__content { margin-top:-1px; }
.post_content .p-dc__content-catch { font-size:36px; line-height:1.6; margin:-0.3em 0; }
.post_content .p-dc__content-desc { font-size:16px; line-height:2.4; margin:-0.7em 0!important; }
.post_content .p-dc__content-catch + .p-dc__content-desc { margin-top:calc(40px - 0.7em)!important; }
.post_content .p-dc__image-bottom img { width:100%; }
.post_content .p-dc__content + .p-dc__image-bottom { margin-top:-1px; }
.post_content .p-dc__desc { padding:100px; background: #f6f6f6; }
.post_content .p-dc__desc-text { font-size:16px; line-height:2.4; margin:-0.7em 0!important; }
@media (max-width: 991px) {
  .post_content .p-dc__content, .post_content .p-dc__desc { padding:100px 30px; }
}
@media (max-width: 767px) {
  .post_content .p-dc { margin:0 -20px; }
  .post_content * + .p-dc { margin-top:40px; }
  .post_content .p-dc__content { padding:40px; }
  .post_content .p-dc__content-catch { font-size:20px; }
  .post_content .p-dc__content-desc { font-size:14px; line-height:2; margin:-0.5em 0!important; }
  .post_content .p-dc__content-catch + .p-dc__content-desc { margin-top:calc(30px - 0.5em)!important; }
  .post_content .p-dc__desc { padding:40px; }
  .post_content .p-dc__desc-text { line-height:2; margin:-0.5em 0!important; }
}

/* 2カラムコンテンツ */
.post_content * + .p-2col { margin-top:100px; }
.post_content .p-2col__catch { font-size:36px; line-height:1.6; margin:-0.3em 0; }
.post_content .p-2col__desc { font-size:16px; line-height:2.4; text-align: center; margin:-0.7em 0!important; }
.post_content .p-2col__catch + .p-2col__desc { margin-top:calc(40px - 0.7em)!important; }
.post_content .p-2col__list { margin-top:calc(100px - 50px); }
.post_content .p-2col__item { background:#f6f6f6; }
.post_content .p-2col__item-content {}
.post_content .p-2col__item-title { font-size:20px; line-height:1.6; height:auto; padding:calc(25px - 0.3em) 40px; margin:0; }
.post_content .p-2col__item-desc {}
.post_content .p-2col__item-desc__text { font-size:16px; line-height:2.4; height:auto; margin:-0.7em 0!important; }
@media (max-width: 767px) {
  .post_content * + .p-2col { margin-top:40px; }
  .post_content .p-2col__catch { font-size:20px; }
  .post_content .p-2col__desc { font-size:14px; line-height:2; margin:-0.5em 0!important; }
  .post_content .p-2col__catch + .p-2col__desc { margin-top:calc(30px - 0.5em)!important; }
  .post_content .p-2col__list { margin-top:calc(40px - 20px); }
  .post_content .p-2col__item-title { font-size:16px; line-height:1.6; padding:calc(20px - 0.3em) 20px; }
  .post_content .p-2col__item-desc__text { font-size:14px; line-height:2.2; margin:-0.6em 0!important; }
}

/* アクセス */
.post_content * + .p-map { margin-top:100px; }
.post_content .p-map {  }
.post_content .p-map__gmap { height:500px; overflow: hidden; }
.post_content .p-map__gmap .qt_google_map { height:100%; }
.post_content .p-map__desc { font-size:16px; line-height:2.4; padding:calc(25px - 0.7em) 40px; text-align: center; background: #f6f6f6; }
.post_content * + .p-map__list { margin-top:50px; }
.post_content .p-map__item { width:100%; }
.post_content * + .p-map__item { margin-left:50px; }
.post_content .p-map__item:not(:only-child) { width:calc(50% - 25px); }
.post_content .p-map__item-desc { font-size:16px; line-height:2.4; padding:calc(40px - 0.7em) 40px; background: #f6f6f6; }
@media (max-width: 767px) {
  .post_content * + .p-map { margin-top:40px; }
  .post_content .p-map__gmap { height:320px; }
  .post_content .p-map__desc { font-size:14px; line-height:1.8; padding:calc(20px - 0.4em) 20px; }
  .post_content * + .p-map__list { margin-top:40px; }
  .post_content * + .p-map__item { margin:40px 0 0; }
  .post_content .p-map__item:not(:only-child) { width:100%; }
  .post_content .p-map__item-desc { font-size:14px; line-height:1.7; padding:calc(20px - 0.35em) 20px; }
}

/* テーブル */
.post_content * + .p-tc { margin-top:100px; }
.post_content .p-tc__wrapper { padding:50px; background: #f6f6f6; }
.post_content .p-tc__content { padding:100px 50px; margin-top:-50px; text-align: center; }
.post_content .p-tc__content-headline { font-size:36px; line-height:1.6; margin:-0.3em 0!important; }
.post_content .p-tc__content-desc { font-size:16px; line-height:2.4; margin:-0.7em 0!important; }
.post_content * + .p-tc__content-desc { margin-top:calc(40px - 0.7em)!important; }
.post_content .p-tc__image img { width:100%; }
.post_content * + .p-tc__table { margin-top:50px; }
.post_content .p-tc__table-wrapper { margin:0; text-align: center; }
.post_content .p-tc__table-head { color:#fff; }
.post_content .p-tc__table-head__item {}
.post_content .p-tc__table-head__item-cell {
  position: relative; font-size:20px; line-height:1.6; font-weight:600; padding:calc(25px - 0.3em) 25px;
  border-color:rgba(var(--tcd-sub-color, 0,0,0),1); background: rgba(var(--tcd-sub-color, 0,0,0),1);
}
.post_content * + .p-tc__table-head__item-cell:before {
  content:''; display: block; width:1px; height:calc(100% + 2px); background:#ddd;
  position: absolute; top:-1px; left:-1px; z-index:1;
}

.post_content .p-tc__table-body {}
.post_content .p-tc__table-body__item {}
.post_content .p-tc__table-body__item-label { width:200px; white-space: nowrap; position: relative; background: rgba(var(--tcd-sub-color, 0,0,0),0.2); }
.post_content .p-tc__table-body__item-label__bg { position: absolute; left:0; bottom:-1px; width:100%; height:1px; z-index:1; background: rgba(var(--tcd-sub-color, 0,0,0),0.2); }
.post_content tr:last-child .p-tc__table-body__item-label__bg { display:none; }
.post_content .p-tc__table-body__item-cell { font-size:16px; line-height:2.4; padding:calc(27px - 0.7em) 25px; }
.post_content .is-row--1 .p-tc__table-body__item-label { width:250px; }
.post_content .is-row--1 .p-tc__table-body__item-desc { text-align: left; }
.post_content .p-tc__bottom { padding:50px 0; margin-bottom:-50px; }
.post_content .p-tc__bottom-desc { font-size:16px; line-height:2.4; margin:-0.7em 0; }
.post_content .p-tc__bottom-button { text-align: center; }
.post_content * + .p-tc__bottom-button { margin-top:50px; }

@media (max-width: 767px) {
  .post_content * + .p-tc { margin-top:40px; }
  .post_content .p-tc__wrapper { padding:20px; }
  .post_content .p-tc__content { padding:40px 0; margin-top:-20px; }
  .post_content .p-tc__content-headline { font-size:20px; }
  .post_content .p-tc__content-desc { font-size:14px; line-height:2; margin:-0.5em 0!important; }
  .post_content * + .p-tc__content-desc { margin-top:calc(30px - 0.5em)!important; }

  .post_content .p-tc__table-wrapper { margin-top:20px; }
  .post_content .p-tc__table { overflow: auto hidden; white-space: nowrap; }
  .post_content * + .p-tc__table { margin-top:40px; }
  .post_content .p-tc__table-head__item-cell { font-size:16px; padding:calc(17px - 0.3em) 20px; }
  .post_content .p-tc__table-body__item-cell { font-size:14px; padding:calc(18px - 0.7em) 20px; }

  .post_content .p-tc__bottom { padding:40px 0px; margin-bottom:-20px; }
  .post_content .p-tc__bottom-desc { font-size:14px; line-height:2.2; margin:-0.6em 0; }
  .post_content * + .p-tc__bottom-button { margin-top:30px; }

}

/* FAQ */
.post_content .p-faq-list { margin-bottom:2em; background: #fff; }
.post_content .p-faq-list__item { border:1px solid #ddd; }
.post_content * + .p-faq-list__item { margin-top:-1px; }
.post_content .p-faq-list__title {
  font-size:16px; font-weight:500; line-height:1.6; padding:25px 70px 25px 30px; margin:0!important;
  cursor: pointer; position:relative; transition:color 0.4s ease;
}
.post_content .p-faq-list__title-label { display:block; margin:-0.7em 0; }
.post_content .p-faq-list__title-icon {
  position:absolute; right:30px; top:50%; transform:translateY(-50%); width:10px; height:10px; overflow: hidden;
}
.post_content .p-faq-list__title-icon:before, .post_content .p-faq-list__title-icon:after {
  content:''; display:block; width:1px; height:10px; background:#000;
  position:absolute; top:0; left:0; right:0; bottom:0; margin:auto;
}
.post_content .p-faq-list__title-icon:before { transition: height 0.3s ease; }
.post_content .p-faq-list__title-icon:after { transform:rotate(90deg); }
.post_content .p-faq-list__content {
  height:0; overflow:hidden; transition:height 0.5s cubic-bezier(0.54, 0.07, 0.38, 0.9);
}
.post_content .p-faq-list__desc {
  font-size:16px; line-height:2.4; border-top:1px solid #ddd; padding:30px;
}
.post_content .p-faq-list__desc span {
  display:block; margin:-0.7em 0;
  transition:opacity 0.7s ease; opacity:0;
}
.post_content .p-faq-list__title.is-active {
  color:rgba(var(--tcd-accent-color, 0,0,0),1);
}
.post_content .p-faq-list__title.is-active .p-faq-list__title-icon:before { height:0; }
.post_content .p-faq-list__title.is-active + .p-faq-list__content span { opacity:1; transition:opacity 1s ease; }
@media (max-width: 767px) {
  .post_content .p-faq-list__title { font-size:14px; padding:17px 45px 17px 20px; }
  .post_content .p-faq-list__title-label { line-height:1.6; margin:-0.3em 0; }
  .post_content .p-faq-list__title-icon { right:20px; }
  .post_content .p-faq-list__desc { font-size:14px; padding:20px; }
}


/* ----------------------------------------------------------------------
  Project - Front cover
---------------------------------------------------------------------- */

.p-front-cover { height:550px; background:#333; position:relative; }
.p-front-cover__inner { position: absolute; top: 0; left: 50%; transform: translateX(-50%); height:100%; z-index:3; }
.p-front-cover__content { width:100%; text-align: center; }
.p-front-cover__headline { font-size:38px; line-height:1.6; margin:-0.3em 0; color:#fff; }
.p-front-cover__search { background:#f5f5f5; }
* + .p-front-cover__search { margin-top:40px; }
.p-front-cover__images { width:100%; height:100%; }
.p-front-cover__images-wrapper {}
.p-front-cover__images-item { background-size: cover!important;}
@media not all and (max-width: 599px) {
  .p-front-cover { max-height:550px; }
}
@media (max-width: 767px) {
  .p-front-cover { height:470px; }
  .p-front-cover__content { padding:0 20px; }
  .p-front-cover__headline { font-size:24px; line-height:1.4; margin:-0.2em 0; }
  * + .p-front-cover__search { margin-top:20px; }
}
@media (max-width: 599px) {
  .p-header-message ~ .l-container .p-front-cover {  }
}

/* ----------------------------------------------------------------------
  Project - Post slider
---------------------------------------------------------------------- */

.p-header-post-slider { width:100%; height:550px; background: #333; position:relative; overflow: hidden; }
.p-header-post-slider__inner { width:calc(100% + 2px); margin-left:-1px; height:100%; }
.p-header-post-slider__item { width:calc(100% / 4); }
.p-header-post-slider__item-link { position: relative; height:100%; display:block; }
.p-header-post-slider__item-category { position: absolute; top:0; left:0; z-index:4; }
.p-header-post-slider__item-content { position: absolute; left:0; bottom:0; z-index:3; width:100%; padding:40px; }
.p-header-post-slider__item-date { margin-top: 15px; color: #fff; }
.p-header-post-slider__item-title { color:#fff; font-size:20px; line-height:1.6; margin:-0.3em 0; height:3.2em; }
.p-header-post-slider__item-overlay {
  position: absolute; left:0; bottom:0; z-index:2; width:100%; height:100%;
  background-image: linear-gradient(180deg, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.8));
}
.p-header-slider__arrow .c-arrow { font-size:16px; width:60px; height:60px; background: #fff; border-radius:50%; }
.p-header-slider__arrow .c-arrow--prev { left:30px; }
.p-header-slider__arrow .c-arrow--next { right:30px; }

@media (max-width: 1024px) {
  .p-header-post-slider { height:470px; }
  .p-header-post-slider__item { width:calc(100% / 3); }
}
@media (max-width: 767px) {
  .p-header-slider__arrow { display:none; }
  .p-header-post-slider__item { width:calc(100% / 2); }
  .p-header-post-slider__item-content { padding:30px; }
  .p-header-post-slider__item-title { font-size:18px; line-height:1.5; margin:-0.25em 0; height:3em; }
}
@media (max-width: 599px) {
  .p-header-post-slider__item { width:calc(100% / 1); }
}


/* ----------------------------------------------------------------------
  Project - 404
---------------------------------------------------------------------- */

.p-404-container .l-container__inner { padding:0; max-width:initial; width:100%; }
.p-404-container .l-main { width:100%; }
.p-404-page { width:100%; height:calc(100vh - 140px); position:relative; }
.p-404-page__contents { text-align:center; position: relative; z-index:3; }
.p-404-page__headline { font-size:42px; line-height:1.5; margin:-0.25em 0; }
.p-404-page__desc { font-size:16px; line-height:2.2; margin:-0.6em 0; }
* + .p-404-page__desc { margin-top:calc(35px - 0.6em); }
.p-404-page__desc a { color:rgba(var(--tcd-link-color, 21,120,214),1); }
.p-404-page__desc a:hover { text-decoration: underline; }
.p-404-page__overlay { position:absolute; top:0; left:0; width:100%; height:100%; z-index:2; }
.p-404-page__image { position:absolute; top:0; left:0; width:100%; height:100%; z-index:1; }
.p-404-page__arrow { position: absolute; }
.p-404-page--light { color:#000; background:rgba(var(--tcd-bg-color, 246, 246, 246),1); }
.p-404-page--dark { color:#fff; background:#333; }
.p-404-page__search {
  max-width:500px; width:100%; border-radius:50px; overflow: hidden; background:#fff;
  display:-webkit-inline-box; display:-ms-inline-flexbox; display:-webkit-inline-flex; display:inline-flex;
}
* + .p-404-page__search { margin-top:40px; }
@media (max-width: 767px) {
  .p-404-page { height: calc(100vh - 160px); }
  .p-404-page__headline { font-size:24px; }
  .p-404-page__desc { font-size:14px; }
  * + .p-404-page__desc { margin-top:calc( 25px - 0.6em ); }
  * + .p-404-page__search { margin-top:25px; }
  * + .p-404-page__post-tags { margin-top:20px; }
}


/* ----------------------------------------------------------------------
  Utility
---------------------------------------------------------------------- */

@media not all and (max-width: 767px) {
  .is-device-sp { display:none!important; }
}
@media (max-width: 767px) {
  .is-device-pc { display:none!important; }
}

/* flex */
.u-flex { display:-webkit-box; display:-ms-flexbox; display:flex; }
.u-flex-wrap { display:-webkit-box; display:-ms-flexbox; display:flex; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.u-flex-center { display:-webkit-box; display:-ms-flexbox; display:flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
.u-flex-align-center { display:-webkit-box; display:-ms-flexbox; display:flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.u-flex-justify-center { display:-webkit-box; display:-ms-flexbox; display:flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }

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

/* visually hidden */
.u-visually-hidden { position: fixed !important; top: 0px !important; left: 0px !important; width: 4px !important; height: 4px !important; opacity: 0 !important; overflow: hidden !important; border: none !important; margin: 0 !important; padding: 0 !important; display: block !important; visibility: visible !important; }

/* button reset */
.u-button-reset { background-color: transparent; border: none; cursor: pointer; outline: none; padding: 0; appearance: none; }

/* no scroll bar */
.u-hidden-scroll-bar { -ms-overflow-style: none; scrollbar-width: none; }
.u-hidden-scroll-bar::-webkit-scrollbar { display:none; }


/* ----------------------------------------------------------------------
 WordPress プリセットスタイル
---------------------------------------------------------------------- */
/* alignment */
.post_content .alignright { float:right; }
.post_content .alignleft { float:left; }
.post_content .aligncenter { display:block; margin-left:auto; margin-right:auto; margin-bottom:7px; }
.post_content blockquote.alignleft, .post_content img.alignleft { margin:7px 24px 7px 0; }
.post_content .wp-caption.alignleft { margin:7px 14px 7px 0; }
.post_content blockquote.alignright, .post_content img.alignright { margin:7px 0 7px 24px; }
.post_content .wp-caption.alignright { margin:7px 0 7px 14px; }
.post_content blockquote.aligncenter, .post_content img.aligncenter, .post_content .wp-caption.aligncenter { margin-top:7px; margin-bottom:7px; }


/* text and headline */
.post_content p { line-height:2.4; margin:0 0 2em 0; }
/* .post_content p:first-child { margin-top:-0.7em; } */
.post_content p:last-child { margin-bottom:0; }
.post_content h1,
.post_content h2,
.post_content h3,
.post_content h4,
.post_content h5,
.post_content h6 { clear:both; line-height:1.4; padding:0; font-weight:600; }

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

/* list */
.post_content li, .post_content dt, .post_content dd { line-height:2.2; }
.post_content ul, .post_content ol, .post_content dl { margin-bottom:24px; }
.post_content ol { list-style:decimal outside none; margin-left:1.5em; }
.post_content ul { list-style:circle outside none; margin-left:1.3em; }
.post_content li > ul, .post_content li > ol { margin-bottom:0; }
.post_content dt { font-weight:bold; }
.post_content dd { margin-bottom:1em; }


/* table */
.post_content table { margin:0 0 24px 0; width:100% !important; }
.post_content td, .post_content th { border:1px solid #ddd; padding:17px 30px; line-height:2.2; background:#fff; -webkit-box-sizing:border-box; box-sizing:border-box; }
.post_content th { background:#f7f7f7; font-weight:normal; }
/* table style */
.post_content table.table_no_border th, .post_content table.table_no_border td { border:none; padding-left:0; }
.post_content table.table_border_horizontal th, .post_content table.table_border_horizontal td { border-left:none; border-right:none; padding-left:0; }

/* new block quote */
.post_content blockquote {
  position:relative; color:rgba(0, 0, 0, 0.6); margin-bottom:2em; padding:2em 2.4em;
  box-shadow:none; background:rgba(0, 0, 0, 2%); border:none; border-left:3px solid #000;
}
.post_content blockquote:before {  line-height:40px;   top:5px; left:10px; }
.post_content blockquote:after {  text-align:left; line-height:60px;   bottom:10px; right:-2px; }
.post_content blockquote:before, .post_content blockquote:after {
  content: '"'; font-style:italic; font-size:30px; font-weight:normal; color:#000;
  width:30px; height:30px; position:absolute;
}
.post_content blockquote p { line-height:1.8; }

/* captions */
.post_content .wp-caption { margin-bottom:2em; background:#fff; border:1px solid #ddd; padding:10px; max-width:100%; }
.post_content .wp-caption-text { text-align:center; line-height:1.5; margin:0 auto; padding:10px 0 0; font-size:14px; }
.post_content .wp-caption img[class*="wp-image-"] { display:block; margin:0 auto 0; }



/* gallery */
.gallery { margin-bottom:20px; }
.gallery img { border: 0 !important; display:block; margin:0; }
.gallery-item { float:left; margin:0 4px 4px 0; overflow:hidden; position:relative; }
.gallery-columns-1, .gallery-columns-2, .gallery-columns-3, .gallery-columns-4, .gallery-columns-5,
  .gallery-columns-6, .gallery-columns-7, .gallery-columns-8, .gallery-columns-9, .gallery-columns-10 { margin:0 -4px -4px 0 !important; }
.gallery-columns-1 .gallery-item { max-width:100%; }
.gallery-columns-2 .gallery-item { max-width:calc(50% - 4px); }
.gallery-columns-3 .gallery-item { max-width:calc(100% / 3 - 4px); }
.gallery-columns-4 .gallery-item { max-width:calc(25% - 4px); }
.gallery-columns-5 .gallery-item { max-width:calc(20% - 4px); }
.gallery-columns-6 .gallery-item { max-width:calc(100% / 6 - 4px); }
.gallery-columns-7 .gallery-item { max-width:calc(100% / 7 - 4px); }
.gallery-columns-8 .gallery-item { max-width:calc(100% / 8 - 4px); }
.gallery-columns-9 .gallery-item { max-width:calc(100% / 9 - 4px); }
.gallery-columns-10 .gallery-item { max-width:calc(10% - 4px); }
.gallery-caption {
  background-color:rgba(0, 0, 0, 0.7); color:#fff; font-size:12px; line-height:1.5; margin:0; pointer-events:none;
  padding:6px 8px; position:absolute; bottom:0; left:0; text-align:left; width:100%;
  -webkit-box-sizing:border-box; box-sizing:border-box;
	transform: translate3d(0, 100%, 0);
	transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0s;
}
.gallery-item:hover .gallery-caption { transform: translate3d(0, 0, 0); }
.gallery-columns-7 .gallery-caption, .gallery-columns-8 .gallery-caption, .gallery-columns-9 .gallery-caption, .gallery-columns-10 .gallery-caption { display: none; }
@media screen and (max-width:767px) {
  .gallery-caption { display:none; }
}


/* etc */
.post_content .wp-smiley { border:0; margin-bottom:0; margin-top:0; padding:0; }
.post_content address { margin:0 0 24px 0; line-height:2.2; }
.post_content pre { border-left:3px solid #ccc; background:#f8f8f8; font-size:12px; margin:0 0 27px 0; line-height:1.7; padding:20px; overflow:auto; }
.post_content .sticky { }
.post_content .mejs-container { margin: 12px 0 25px; }


/* パスワード保護 */
.c-pw { background: #fff; margin-top:50px; }
.c-pw__box { font-size:16px; padding:40px; border:1px solid #ddd; }
.c-pw__box-inner { width:100%; height:50px; display:-webkit-box; display:-ms-flexbox; display:flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
.c-pw__box-desc { line-height:1.8!important; margin:-0.4em 0 2em!important; }
.c-pw__box-input { display:block; flex:1; border:none; background:#eee; height:100%; padding: 0 20px; }
.c-pw__btn--submit { display:block; min-width:150px; height:100%; padding:0 1em; background:#111; color:#fff!important; border:0; cursor:pointer; }
.c-pw__btn--submit:hover { background:#333; }
@media (max-width:767px) {
  .c-pw { margin-top:40px; }
  .c-pw__box { font-size:14px; padding:20px; }
  .c-pw__box-inner { height:40px; }
  .c-pw__box-desc { margin-bottom:1em!important; }
  .c-pw__box-input { width:calc(100% - 100px); padding:0 10px; }
  .c-pw__btn--submit { min-width:auto; width:100px; }
}


/* Cardlink style - カードリンクのスタイル */

/* Google Mapの設定 */
.p-btn {
  -webkit-box-sizing: border-box; box-sizing: border-box;
  display: inline-block; min-width: 180px; height: 50px; padding: 0 15px; border-radius: 0;
  color: #fff; font-size: 14px; line-height: 50px; text-align: center;
}
@media screen and (max-width: 767px) {
  .p-btn { height: 45px; font-size: 12px; line-height: 45px; }
}


/* ブロックエディタ */
.wp-block-social-links a { color:#fff !important; }
.has-small-font-size { font-size:.8125em !important; }
.has-normal-font-size,
.has-regular-font-size { font-size:1em !important; }
.has-medium-font-size { font-size:1.25em !important; }
.has-large-font-size { font-size:2.25em !important; }
.has-huge-font-size, .has-larger-font-size { font-size:2.625em !important; }
.has-text-align-left { text-align:left !important; }
.has-text-align-right { text-align:right !important; }
.wp-block-embed { margin:0 0 2em 0; }


/* QUADRAから追加分 */
.post_content .underline, .post_content .underline:hover { text-decoration:underline; }
.post_content .e_link {
  display: inline-block; position: relative; padding-right:1em;
}
.post_content .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%);
}
.post_content 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;
}
@media (max-width: 767px) {
  .post_content .s_table,
  .post_content .wp-block-table { overflow: auto; white-space: nowrap; margin-bottom: 2em; }
  .post_content .s_table table,
  .post_content .wp-block-table { margin-bottom: 0; }
  .post_content table.c_fix tbody td:first-child { position: sticky; top:0; left:0; z-index:1; }
}
.post_content .a_break { display: inline-block; }
@media (max-width: 767px) {
  .post_content .is-pc { display:none!important; }
}
@media not all and (max-width: 767px) {
  .post_content .is-sp { display:none!important; }
}

/*  WordPress プリセットスタイル */
@media screen and (max-width:767px) {
  .post_content h1, .post_content h2, .post_content h3, .post_content h4, .post_content h5, .post_content h6 { }
  .post_content p { line-height:2; }
  .post_content li, .post_content dt, .post_content dd { line-height:1.8; }
  .post_content td, .post_content th { line-height:1.8; padding:14px 20px; }
}


/* admin bar利用時 */
body.admin-bar { padding-top:32px; }
body.admin-bar #header_top { top:32px; }
body.admin-bar .drawer_contents, body.admin-bar .drawer_overlay { top: 32px; }


@media screen and (max-width:782px) {
  body.admin-bar #header_top { top:0px; }
  body.admin-bar { padding-top:46px; }
  body.admin-bar .drawer_contents, body.admin-bar .drawer_overlay { top: 46px; }
}


/** ブロックエディターのテーブルブロックの調整 **/
.wp-block-table.is-style-stripes td,
.wp-block-table .has-background td{
  background-color: transparent;
}