/*****/
/* グリッドシステム */
/*****/
.grid-container-fluid { width: 100%; margin-right: auto; margin-left: auto; }
.grid-container { width: 100%; margin-right: auto; margin-left: auto; }
.grid-row { display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.no-gutters { margin-right: 0; margin-left: 0; }
.no-gutters > .col,
.no-gutters > [class*="col-"] { padding-right: 0; padding-left: 0; }
.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col,
.col-auto, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm,
.col-sm-auto, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md,
.col-md-auto, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg,
.col-lg-auto, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl,
.col-xl-auto { position: relative; width: 100%; min-height: 1px; }

.col { -ms-flex-preferred-size: 0; flex-basis: 0; -ms-flex-positive: 1; flex-grow: 1; max-width: 100%; }
.col-auto { -ms-flex: 0 0 auto; flex: 0 0 auto; width: auto; max-width: none; }
.col-1 { -ms-flex: 0 0 8.333333%; flex: 0 0 8.333333%; max-width: 8.333333%; }
.col-2 { -ms-flex: 0 0 16.666667%; flex: 0 0 16.666667%; max-width: 16.666667%; }
.col-3 { -ms-flex: 0 0 25%; flex: 0 0 25%; max-width: 25%; }
.col-4 { -ms-flex: 0 0 33.333333%; flex: 0 0 33.333333%; max-width: 33.333333%; }
.col-5 { -ms-flex: 0 0 41.666667%; flex: 0 0 41.666667%; max-width: 41.666667%; }
.col-6 { -ms-flex: 0 0 50%; flex: 0 0 50%; max-width: 50%; }
.col-7 { -ms-flex: 0 0 58.333333%; flex: 0 0 58.333333%; max-width: 58.333333%; }
.col-8 { -ms-flex: 0 0 66.666667%; flex: 0 0 66.666667%; max-width: 66.666667%; }
.col-9 { -ms-flex: 0 0 75%; flex: 0 0 75%; max-width: 75%; }
.col-10 { -ms-flex: 0 0 83.333333%; flex: 0 0 83.333333%; max-width: 83.333333%; }
.col-11 { -ms-flex: 0 0 91.666667%; flex: 0 0 91.666667%; max-width: 91.666667%; }
.col-12 { -ms-flex: 0 0 100%; flex: 0 0 100%; max-width: 100%; }

.order-first { -ms-flex-order: -1; order: -1; }
.order-last { -ms-flex-order: 13; order: 13; }
.order-0 { -ms-flex-order: 0; order: 0; }
.order-1 { -ms-flex-order: 1; order: 1; }
.order-2 { -ms-flex-order: 2; order: 2; }
.order-3 { -ms-flex-order: 3; order: 3; }
.order-4 { -ms-flex-order: 4; order: 4; }
.order-5 { -ms-flex-order: 5; order: 5; }
.order-6 { -ms-flex-order: 6; order: 6; }
.order-7 { -ms-flex-order: 7; order: 7; }
.order-8 { -ms-flex-order: 8; order: 8; }
.order-9 { -ms-flex-order: 9; order: 9; }
.order-10 { -ms-flex-order: 10; order: 10; }
.order-11 { -ms-flex-order: 11; order: 11; }
.order-12 { -ms-flex-order: 12; order: 12; }

.offset-1 { margin-left: 8.333333%; }
.offset-2 { margin-left: 16.666667%; }
.offset-3 { margin-left: 25%; }
.offset-4 { margin-left: 33.333333%; }
.offset-5 { margin-left: 41.666667%; }
.offset-6 { margin-left: 50%; }
.offset-7 { margin-left: 58.333333%; }
.offset-8 { margin-left: 66.666667%; }
.offset-9 { margin-left: 75%; }
.offset-10 { margin-left: 83.333333%; }
.offset-11 { margin-left: 91.666667%; }

.d-none { display: none !important; }
.d-inline { display: inline !important; }
.d-inline-block { display: inline-block !important; }
.d-block { display: block !important; }
.d-table { display: table !important; }
.d-table-row { display: table-row !important; }
.d-table-cell { display: table-cell !important; }
.d-flex { display: -ms-flexbox !important; display: flex !important; }
.d-inline-flex { display: -ms-inline-flexbox !important; display: inline-flex !important; }

.flex-row { -ms-flex-direction: row !important; flex-direction: row !important; }
.flex-column { -ms-flex-direction: column !important; flex-direction: column !important; }
.flex-row-reverse { -ms-flex-direction: row-reverse !important; flex-direction: row-reverse !important; }
.flex-column-reverse { -ms-flex-direction: column-reverse !important; flex-direction: column-reverse !important; }
.flex-wrap { -ms-flex-wrap: wrap !important; flex-wrap: wrap !important; }
.flex-nowrap { -ms-flex-wrap: nowrap !important; flex-wrap: nowrap !important; }
.flex-wrap-reverse { -ms-flex-wrap: wrap-reverse !important; flex-wrap: wrap-reverse !important; }
.flex-fill { -ms-flex: 1 1 auto !important; flex: 1 1 auto !important; }
.flex-grow-0 { -ms-flex-positive: 0 !important; flex-grow: 0 !important; }
.flex-grow-1 { -ms-flex-positive: 1 !important; flex-grow: 1 !important; }
.flex-shrink-0 { -ms-flex-negative: 0 !important; flex-shrink: 0 !important; }
.flex-shrink-1 { -ms-flex-negative: 1 !important; flex-shrink: 1 !important; }

.justify-content-start { -ms-flex-pack: start !important; justify-content: flex-start !important; }
.justify-content-end { -ms-flex-pack: end !important; justify-content: flex-end !important; }
.justify-content-center { -ms-flex-pack: center !important; justify-content: center !important; }
.justify-content-between { -ms-flex-pack: justify !important; justify-content: space-between !important; }
.justify-content-around { -ms-flex-pack: distribute !important; justify-content: space-around !important; }

.align-items-start { -ms-flex-align: start !important; align-items: flex-start !important; }
.align-items-end { -ms-flex-align: end !important; align-items: flex-end !important; }
.align-items-center { -ms-flex-align: center !important; align-items: center !important; }
.align-items-baseline { -ms-flex-align: baseline !important; align-items: baseline !important; }
.align-items-stretch { -ms-flex-align: stretch !important; align-items: stretch !important; }

.align-content-start { -ms-flex-line-pack: start !important; align-content: flex-start !important; }
.align-content-end { -ms-flex-line-pack: end !important; align-content: flex-end !important; }
.align-content-center { -ms-flex-line-pack: center !important; align-content: center !important; }
.align-content-between { -ms-flex-line-pack: justify !important; align-content: space-between !important; }
.align-content-around { -ms-flex-line-pack: distribute !important; align-content: space-around !important; }
.align-content-stretch { -ms-flex-line-pack: stretch !important; align-content: stretch !important; }

.align-self-auto { -ms-flex-item-align: auto !important; align-self: auto !important; }
.align-self-start { -ms-flex-item-align: start !important; align-self: flex-start !important; }
.align-self-end { -ms-flex-item-align: end !important; align-self: flex-end !important; }
.align-self-center { -ms-flex-item-align: center !important; align-self: center !important; }
.align-self-baseline { -ms-flex-item-align: baseline !important; align-self: baseline !important; }
.align-self-stretch { -ms-flex-item-align: stretch !important; align-self: stretch !important; }

@media (min-width: 769px) {
  .grid-container-fluid { padding-right: 15px; padding-left: 15px; }
  .grid-container { max-width: 1200px; }

  .col-md { -ms-flex-preferred-size: 0;flex-basis: 0; -ms-flex-positive: 1;   flex-grow: 1; max-width: 100%; }
  .col-md-auto { -ms-flex: 0 0 auto;flex: 0 0 auto; width: auto; max-width: none; }
  .col-md-1 { -ms-flex: 0 0 8.333333%;flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-md-2 { -ms-flex: 0 0 16.666667%;flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-md-3 { -ms-flex: 0 0 25%;flex: 0 0 25%; max-width: 25%; }
  .col-md-4 { -ms-flex: 0 0 33.333333%;flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-md-5 { -ms-flex: 0 0 41.666667%;flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-md-6 { -ms-flex: 0 0 50%;flex: 0 0 50%; max-width: 50%; }
  .col-md-7 { -ms-flex: 0 0 58.333333%;flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-md-8 { -ms-flex: 0 0 66.666667%;flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-md-9 { -ms-flex: 0 0 75%;flex: 0 0 75%; max-width: 75%; }
  .col-md-10 { -ms-flex: 0 0 83.333333%;flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-md-11 { -ms-flex: 0 0 91.666667%;flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-md-12 { -ms-flex: 0 0 100%;flex: 0 0 100%; max-width: 100%; }

  .order-md-first { -ms-flex-order: -1; order: -1; }
  .order-md-last { -ms-flex-order: 13; order: 13; }
  .order-md-0 { -ms-flex-order: 0; order: 0; }
  .order-md-1 { -ms-flex-order: 1; order: 1; }
  .order-md-2 { -ms-flex-order: 2; order: 2; }
  .order-md-3 { -ms-flex-order: 3; order: 3; }
  .order-md-4 { -ms-flex-order: 4; order: 4; }
  .order-md-5 { -ms-flex-order: 5; order: 5; }
  .order-md-6 { -ms-flex-order: 6; order: 6; }
  .order-md-7 { -ms-flex-order: 7; order: 7; }
  .order-md-8 { -ms-flex-order: 8; order: 8; }
  .order-md-9 { -ms-flex-order: 9; order: 9; }
  .order-md-10 { -ms-flex-order: 10; order: 10; }
  .order-md-11 { -ms-flex-order: 11; order: 11; }
  .order-md-12 { -ms-flex-order: 12; order: 12; }

  .offset-md-0 { margin-left: 0; }
  .offset-md-1 { margin-left: 8.333333%; }
  .offset-md-2 { margin-left: 16.666667%; }
  .offset-md-3 { margin-left: 25%; }
  .offset-md-4 { margin-left: 33.333333%; }
  .offset-md-5 { margin-left: 41.666667%; }
  .offset-md-6 { margin-left: 50%; }
  .offset-md-7 { margin-left: 58.333333%; }
  .offset-md-8 { margin-left: 66.666667%; }
  .offset-md-9 { margin-left: 75%; }
  .offset-md-10 { margin-left: 83.333333%; }
  .offset-md-11 { margin-left: 91.666667%; }

  .d-md-none { display: none !important; }
  .d-md-inline { display: inline !important; }
  .d-md-inline-block { display: inline-block !important; }
  .d-md-block { display: block !important; }
  .d-md-table { display: table !important; }
  .d-md-table-row { display: table-row !important; }
  .d-md-table-cell { display: table-cell !important; }
  .d-md-flex { display: -ms-flexbox !important; display: flex !important; }
  .d-md-inline-flex { display: -ms-inline-flexbox !important; display: inline-flex !important; }

  .flex-md-row { -ms-flex-direction: row !important; flex-direction: row !important; }
  .flex-md-column { -ms-flex-direction: column !important; flex-direction: column !important; }
  .flex-md-row-reverse { -ms-flex-direction: row-reverse !important; flex-direction: row-reverse !important; }
  .flex-md-column-reverse { -ms-flex-direction: column-reverse !important; flex-direction: column-reverse !important; }
  .flex-md-wrap { -ms-flex-wrap: wrap !important; flex-wrap: wrap !important; }
  .flex-md-nowrap { -ms-flex-wrap: nowrap !important; flex-wrap: nowrap !important; }
  .flex-md-wrap-reverse { -ms-flex-wrap: wrap-reverse !important; flex-wrap: wrap-reverse !important; }
  .flex-md-fill { -ms-flex: 1 1 auto !important; flex: 1 1 auto !important; }
  .flex-md-grow-0 { -ms-flex-positive: 0 !important; flex-grow: 0 !important; }
  .flex-md-grow-1 { -ms-flex-positive: 1 !important; flex-grow: 1 !important; }
  .flex-md-shrink-0 { -ms-flex-negative: 0 !important; flex-shrink: 0 !important; }
  .flex-md-shrink-1 { -ms-flex-negative: 1 !important; flex-shrink: 1 !important; }

  .justify-content-md-start { -ms-flex-pack: start !important; justify-content: flex-start !important; }
  .justify-content-md-end { -ms-flex-pack: end !important; justify-content: flex-end !important; }
  .justify-content-md-center { -ms-flex-pack: center !important; justify-content: center !important; }
  .justify-content-md-between { -ms-flex-pack: justify !important; justify-content: space-between !important; }
  .justify-content-md-around { -ms-flex-pack: distribute !important; justify-content: space-around !important; }

  .align-items-md-start { -ms-flex-align: start !important; align-items: flex-start !important; }
  .align-items-md-end { -ms-flex-align: end !important; align-items: flex-end !important; }
  .align-items-md-center { -ms-flex-align: center !important; align-items: center !important; }
  .align-items-md-baseline { -ms-flex-align: baseline !important; align-items: baseline !important; }
  .align-items-md-stretch { -ms-flex-align: stretch !important; align-items: stretch !important; }

  .align-content-md-start { -ms-flex-line-pack: start !important; align-content: flex-start !important; }
  .align-content-md-end { -ms-flex-line-pack: end !important; align-content: flex-end !important; }
  .align-content-md-center { -ms-flex-line-pack: center !important; align-content: center !important; }
  .align-content-md-between { -ms-flex-line-pack: justify !important; align-content: space-between !important; }
  .align-content-md-around { -ms-flex-line-pack: distribute !important; align-content: space-around !important; }
  .align-content-md-stretch { -ms-flex-line-pack: stretch !important; align-content: stretch !important; }

  .align-self-md-auto { -ms-flex-item-align: auto !important; align-self: auto !important; }
  .align-self-md-start { -ms-flex-item-align: start !important; align-self: flex-start !important; }
  .align-self-md-end { -ms-flex-item-align: end !important; align-self: flex-end !important; }
  .align-self-md-center { -ms-flex-item-align: center !important; align-self: center !important; }
  .align-self-md-baseline { -ms-flex-item-align: baseline !important; align-self: baseline !important; }
  .align-self-md-stretch { -ms-flex-item-align: stretch !important; align-self: stretch !important; }
}

/*****/
/* 打消し */
/*****/
#main { background: #fff; -webkit-text-size-adjust: 100%; }
#main #contents { width: auto; }
#main #contents-body { padding: 0; }
#main #contents-body .section { background-color: #fff; margin: 0; }

h1, h2, h3, h4, h5, h6,
p, ul, li, dl, dt, dd { margin: 0; }

/*****/
/* ベースCSS */
/*****/
body { font-family: "akkurat-mono", YuGothic, '游ゴシック', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴシック ProN', Meiryo, 'メイリオ', sans-serif }
body,
p {
  font-size: 13px;
  font-size: 3.4666vw;
  line-height: 1.7;
  color: #000;
}
img { max-width: 100%; vertical-align: middle; image-rendering: -webkit-optimize-contrast; }
a { color: #000; transition-duration: .3s; }
a:hover { opacity: .7; }
a:focus { outline: 0; }
p { letter-spacing: .05em; }

/*****/
/* assets */
/*****/
.textL { text-align: left; }
.textC { text-align: center; }
.textR { text-align: right; }
.fc-white { color: #fff; }
.fc-black { color: #000; }

.sp_prl-4 { padding-right: 4%; padding-left: 4%; }
.sp_prl-5 { padding-right: 5%; padding-left: 5%; }
.sp_prl-8 { padding-right: 8%; padding-left: 8%; }
.negative-5 { margin-right: -5px; margin-left: -5px; }
.negative-10 { margin-right: -10px; margin-left: -10px; }
.negative-15 { margin-right: -15px; margin-left: -15px; }
.negative-20 { margin-right: -20px; margin-left: -20px; }

.bg_image { position: absolute; top: 0; left: 0%; width: 100%; height: 100%; background-repeat: no-repeat; background-position: center; background-size: cover; }

/* 大見出し */
.kv_tmp_heading { background-color: #000; border-bottom: 15px solid #f2f2f2; }
.kv_tmp_heading .kv { position: relative; }
.kv_tmp_heading .kv_title { position: relative; text-align: left; padding: 93.5% 8% 5%; }
.kv_tmp_heading .kv_title h1 { position: relative; padding-top: 8vw; padding-left: 22px; margin-bottom: 20px; }
.kv_tmp_heading .kv_title h1:before { content: ""; display: block; width: 0; border-left: 3px solid #e60010;
  position: absolute; top: 0; left: 0; bottom: 0; transform: skew(-15deg); transform-origin: bottom; }
.kv_tmp_heading .kv_title h1 .svg_ttl { position: absolute; top: 0; left: 25px; height: 100%; display: block; }
.kv_tmp_heading .kv_title h1 + p { font-size: 12px; font-size: 3.2vw; color: #fff; }
.kv_tmp_heading .bg_image { height: 100%; }

.kv_tmp_heading.kv_none { background-color: #fff; border-bottom: none; margin-bottom: 40px; }
.kv_tmp_heading.kv_none .bg_image { display: none; }
.kv_tmp_heading.kv_none .kv_title { padding-top: 13.335%; padding-bottom: 0; }

.kv_tmp_heading.kv_none .kv_title h1 {padding-top: 6.8vw; margin-bottom: 15px; }
.kv_tmp_heading.kv_none .kv_title h1 + p { color: #000; font-weight: bold; }


/* ボタン */
.btn { display: inline-block; transform: skew(-15deg); transition: all .3s; overflow: hidden; position: relative; vertical-align: middle; }
.btn:before { content: ""; width: 0; height: 100%; background-color: #e60010;
  position: absolute; top: 0; left: 0; transition: width .3s; }
.btn > a { font-family: 'DecimaMonoPro', sans-serif; font-style: italic; font-size: 4.8vw; font-weight: normal; line-height: 1; letter-spacing: -0.08em;
  min-width: 130px; display: block; padding: 14px 40px 14px 20px; transform: skew(15deg); position: relative;
  /*background-image: url(/pages/contents/jp/tgr-asset/image/common/btn_arrow.png); background-repeat: no-repeat; background-position: center right 15px;*/
}
.btn svg { fill: #e60010; position: absolute; top: 50%; right: 10px; transition-duration: .3s; transform: translateY(-50%) scale(0.5); }

.btn.normal a { font-family: inherit; font-size: 15px; font-size: 4vw; font-style: normal; letter-spacing: normal; padding-top: 16px; padding-bottom: 16px; }

.btn.bg-white { background-color: #fff; }
.btn.bg-white > a { color: #000; }
.btn.bg-black { background-color: #000; }
.btn.bg-black > a { color: #fff; }
.btn.btn-more { display: block; float: right; }
.btn.btn-more:before { content: none; }
.btn.btn-more > a { color: #000; font-size: 14px; font-size: 3.7333vw; display: inline-block; min-width: auto; min-width: initial; padding: 10px 35px 10px 15px; }

.btn2 { display: inline-block; transform: skew(-15deg); margin-top: 15px; transition: all .3s; position: relative; vertical-align: middle; background-color: #fff; }
.btn2 > a { font-family: 'DecimaMonoPro', sans-serif; color: #000; font-style: italic; font-size: 18px; font-weight: normal; line-height: 1; letter-spacing: -0.05em; min-width: 150px; display: block; padding: 14px 40px 14px 20px; transform: skew(15deg); position: relative; }
.btn2 > a:after { content: ""; width: 6px; height: 6px; transform:rotate(45deg) translate3d(-100%,30%,1px); border-top: 2px solid #e60010; border-right: 2px solid #e60010; position: absolute; top: 50%; right: 10px; transition-duration: .3s; }

.t-origin_top { transform-origin: top; }
.t-origin_center { transform-origin: center; }
.t-origin_bottom { transform-origin: bottom; }

.anim_btn { max-width: 0; overflow-x: hidden; display: inline-block; transform-origin: bottom; transform: skew(-15deg); background-color: #fff; margin-top: 15px; }
.anim_btn > .btn,
.anim_btn > .btn2 { transform: skew(0); display: block; margin-top: 0; }
.anim_btn > .btn > a,
.anim_btn > .btn2 > a { transform: skew(15deg); }
.view .anim_btn { animation: btn_in .6s both; }
@-webkit-keyframes btn_in {
  from { max-width: 0; }
  to { max-width: 20em; }
}
@keyframes btn_in {
  from { max-width: 0; }
  to { max-width: 20em; }
}

/* カード */
.card-box .card_info { border-bottom: 15px solid #f2f2f2; }
.card-box .card_inr { position: relative; display: block; height: 100%; }
.card-box .card_image { position: relative; }
.card-box .card_image img { width: 100%; }
.card-box .card_category { font-family: 'DecimaMonoPro', sans-serif; color: #fff; font-size: 15px; text-align: center; line-height: 22px; background-color: #e60010; position: absolute; left: 5%; bottom: -11px; transform: skew(-15deg); transform-origin: bottom; min-width: 100px; max-width: 90%; padding: 0 15px; }
.card-box .card_category.lang-en { font-family: 'DecimaMonoPro', sans-serif; }
.card-box .card_category.lang-jp { font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴシック ProN', YuGothic, '游ゴシック', Meiryo, 'メイリオ', sans-serif; }
.card-box .card_category.font_small { font-size: 12px; }
.card-box .card_text { padding-top: 20px; padding-bottom: 75px; }
.card-box .card_catch { color: #e60010; font-size: 12px; font-size: 3.2vw; font-weight: bold; margin-bottom: 10px; }
.card-box .card_ttl { font-size: 16px; font-size: 4.2666vw; font-weight: bold; margin-bottom: 15px; }
.card-box .card_caption { font-size: 12px; font-size: 3.2vw; }
.card-box .card_foot { position: absolute; right: 5%; bottom: 0; left: 5%; border-top: 1px solid #e5e5e5; padding: 5px 0; }
.card-box .card_date { font-family: 'DecimaMonoPro', sans-serif; color: #7f7f7f; display: inline-block; }
.card-box .card_more { font-family: 'DecimaMonoPro', sans-serif; color: #000; font-size: 14px; font-size: 3.7333vw; font-style: italic; position: relative; padding: 10px 25px 10px 15px;}
.card-box .card_more svg { fill: #e60010; position: absolute; top: 50%; right: 0; transition-duration: .3s; transform: translateY(-50%) scale(0.4); }
.card-box .card_tbl { font-size: 12px; font-size: 3.2vw; width: auto; border-left: 2px solid #e60010; text-align: left; margin-top: 15px; }
.card-box .card_tbl th { color: #999; padding-right: .5em; padding-left: .5em; }
.card-box .card_tbl td { color: #000; font-weight: bold; }

.card-box .go_list { padding: 0 4% 40px; background-color: #f2f2f2; }
.card-box .go_list a { color: #000; font-size: 12px;  font-size: 3.2vw; font-weight: bold; text-align: center; display: block; padding: 20px 0; background-color: #fff; position: relative; }
.card-box .go_list svg { transform: translateY(-50%) scale(.5); fill: #e60010; position: absolute; top: 50%; right: 15px; transition-duration: .3s; }

/* 200615 tc改修 */
@media (max-width: 768px) {
  .card-box .news-menu .card_info { border-bottom: none; }
  .card-box .news-menu .card_info .card_inr { display: flex; justify-content: space-between; height: auto; margin: 5% 5% 0 5%; padding: 0 0 5%; border-bottom: 1px solid #f2f2f2; }
  .card-box .news-menu .card_info:nth-child(1) .card_inr { margin-top: 0; }
  .card-box .news-menu .card_info:last-child .card_inr { border-bottom: none; }
  .card-box .news-menu .card_info .card_image { width: 34.5%; position: static; }
  .card-box .news-menu .card_info .card_category { font-size: 10px; font-size: 2.6666vw; line-height: 1; position: absolute; top: 0; right: 0; bottom: auto; left: auto; padding: 0.2em 0.5em; }
  .card-box .news-menu .card_info .card_text { display: flex; flex-direction: column; width: 65.5%; padding: 0; padding-left: 3%; }
  .card-box .news-menu .card_info .card_ttl { font-size: 12px; font-size: 3.2vw; font-weight: bold; margin-bottom: 0; order: 2; }
  .card-box .news-menu .card_info .card_caption { display: none; }
  .card-box .news-menu .card_info .card_foot { position: relative; right: 0; left: 0; padding: 0; border-top: none; order: 1; }
  .card-box .news-menu .card_info .card_date { font-size: 2.7vw; }
  .card-box .news-menu .card_info .card_more { display: none; }
  .card-box .go_list { padding: 40px 4%; }
}
/* end */

/* アコーディオン */
.acordion-box .ac_btn { font-size: 14px; font-size: 3.7333vw; font-weight: bold; border-top: 1px solid #e5e5e5; padding-left: 10px; padding-top: 1em; padding-bottom: 1em; position: relative; cursor: pointer; }
.acordion-box .ac_btn:before { content: ""; position: absolute; top: 50%; right: 10px; transform: translateY(-50%); width: 14px; height: 2px; background-color: #e60010; }
.acordion-box .ac_btn:after { content: ""; position: absolute; top: 50%; right: 16px; transform: translateY(-50%); width: 2px; height: 14px; background-color: #e60010; }
.acordion-box .ac_box { display: none; padding-bottom: 15px; }
.acordion-box .ac_btn.active:after { /*right: 10px; width: 14px; height: 2px;*/ opacity: 0; }

/* ページ内ナビ */
.local-nav { background-color: #f2f2f2; padding: 5px 5% 20px; }
.local-nav .local-nav_inr { padding: 0 5px; }
.local-nav .local-nav_inr a { font-family: 'DecimaMonoPro', sans-serif; color: #000; font-size: 15px; font-size: 4vw; font-style: italic; line-height: 1; display: block; background-color: #fff; padding: 15px; position: relative; }
.local-nav .local-nav_inr svg { transform: rotate(90deg) translate(-70%,0) scale(.5); fill: #e60010; position: absolute; top: 50%; right: 10px; transition-duration: .3s; }

/* アニメーション */
.anim_fadein,
.anim_fadeup { opacity: 0; }

.view .anim_fadein { animation: fadeIn .6s both; }
@-webkit-keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
.view .anim_fadeup { animation: fadeInUp .6s both; }
@-webkit-keyframes fadeInUp {
  from { opacity: 0; -webkit-transform: translate3d(0, 30px, 0); transform: translate3d(0, 30px, 0); }
  to { opacity: 1; -webkit-transform: none; transform: none; }
}
@keyframes fadeInUp {
  from { opacity: 0; -webkit-transform: translate3d(0, 30px, 0); transform: translate3d(0, 30px, 0); }
  to { opacity: 1; -webkit-transform: none; transform: none; }
}

.view .no_delay { animation-delay: 0s; }
.view .anim_delay-02 { animation-delay: .2s; }
.view .anim_delay-04 { animation-delay: .4s; }
.view .anim_delay-06 { animation-delay: .6s; }
.view .anim_delay-08 { animation-delay: .8s; }
.view .anim_delay-10 { animation-delay: 1s; }

/* 見出し */
h2.heading { position: relative; padding-left: 25px; padding-top: 8vw; }
h2.heading:before { content: ""; display: block; width: 0; border-left: 3px solid #e60010; position: absolute; top: 0; left: 0; bottom: 0; transform: skew(-15deg); transform-origin: bottom; }
h2.heading .svg_ttl { position: absolute; top: 0; left: 25px; height: 100%; display: block; }
h2.heading + p { margin-top: 15px; margin-bottom: 15px; position: relative; }
h2.heading + .tmp_article_image { margin-top: 15px; }

/* 共通エリア */
.content_bottom { background-color: #fff; border-top: 15px solid #f2f2f2; border-bottom: 15px solid #f2f2f2; padding-top: 30px; padding-bottom: 30px; }
.content_bottom h2.heading { padding-top: 6.934vw; min-width: 268px; }
.content_bottom h2.heading .svg_ttl { }
.content-garage { background-color: #fff; border-top: 15px solid #f2f2f2; padding-bottom: 10px; }
.content-garage .image { margin-bottom: 20px; }
.content-garage .garage-ttl { padding: 0 18%; margin-bottom: 15px; }
.content-garage .garage-ttl + p { border-bottom: 1px solid #e5e5e5; padding-bottom: 15px; }
.content-garage .btn-more { margin-top: 5px; }
.content-sns { background-color: #fff; padding: 30px 0; }
.content-sns .sns_menus { margin-top: 30px; }
/*.content-sns .sns_menu { position: relative; }*/
/*.content-sns .sns_menu + .sns_menu:before { content: ""; width: 1px; height: 28px; background-color: #e5e5e5; position: absolute; top: 50%; left: 0; transform: skew(-15deg) translateY(-50%); }*/
.content-sns .sns_menu a { display: block; }
.content-sns .sns_menu .sns_image { padding: 0 16px; margin-bottom: 10px; }
.content-sns .sns_menu span { font-family: 'DecimaMonoPro', sans-serif; font-style: italic; color: #000; display: block; text-align: center; }
.content-magazine { padding: 50px 0; border-top: 15px solid #f2f2f2; }
.content-magazine h2.heading + p { font-size: 12px; font-size: 3.2vw; margin-bottom: 15px; }
.content-magazine .btn_magazine > a { color: #fff; font-size: 12px; font-size: 3.2vw; font-weight: bold; display: block; text-align: center; padding: 20px 0; background-color: #000; position: relative; }
.content-magazine .btn_magazine svg { transform: translateY(-50%) scale(.5); position: absolute; top: 50%; right: 10px; transition-duration: .3s; fill: #e60010; }
.content-magazine .btn_magazinestop { text-align: center; margin-top: 20px; }
.content-magazine .btn_magazinestop > a { font-size: 12px; font-size: 3.2vw; display: inline-block; position: relative; padding-right: 25px; }
.content-magazine .btn_magazinestop svg { transform: translateY(-50%) scale(.5); position: absolute; top: 50%; right: 0; transition-duration: .3s; fill: #e60010; }

.content-box { padding-top: 40px; padding-bottom: 40px; }
.content-box h2.heading { margin-bottom: 30px; }


@media (min-width: 769px) {
  body,
  p { font-size: 14px; }
  .sp_prl-4,
  .sp_prl-5,
  .sp_prl-8 { padding-right: 0; padding-left: 0; }
  .pc_negative-5 { margin-right: -5px; margin-left: -5px; }
  .pc_negative-10 { margin-right: -10px; margin-left: -10px; }
  .pc_negative-15 { margin-right: -15px; margin-left: -15px; }
  .pc_negative-20 { margin-right: -20px; margin-left: -20px; }

  /* 大見出し */
  .kv_tmp_heading { border-bottom: none; }
  .kv_tmp_heading .bg_image { height: 100%; }
  .kv_tmp_heading .kv { padding-top: 215px; padding-bottom: 215px; }
  .kv_tmp_heading .kv_title { padding: 0; text-align: center; }
  .kv_tmp_heading .kv_title h1 { display: inline-block; padding-top: 0; padding-left: 50px; margin-bottom: 35px; }
  .kv_tmp_heading .kv_title h1:before { border-left-width: 4px; }
  .kv_tmp_heading .kv_title h1 .svg_ttl { position: static; height: 58px; filter: drop-shadow(0 0 50px rgba(0,0,0,0.3)); }
  .kv_tmp_heading .kv_title h1 + p { font-size: 14px; line-height: 1.85; }

  .kv_tmp_heading.kv_none { margin-bottom: 60px; }
  .kv_tmp_heading.kv_none .kv { padding: 80px 0 0; }
  .kv_tmp_heading.kv_none .kv_title { max-width: 1200px; text-align: left; padding: 0 15px; margin-right: auto; margin-left: auto; }
  .kv_tmp_heading.kv_none .kv_title h1 { padding-top: 0; padding-left: 35px; margin-bottom: 5px; }
  .kv_tmp_heading.kv_none .kv_title h1 .svg_ttl { height: 40px; }
  .kv_tmp_heading.kv_none .kv_title h1 + p { font-size: 14px; padding-left: 35px; }

  /* ボタン */
  .btn > a { font-size: 18px; }
  .btn.normal a { font-size: 15px; }
  .btn.btn-more > a { font-size: 14px; }

  .btn:hover a { color: #fff; }
  .btn:hover svg { fill: #fff; }
  .btn:hover:before { width: 100%; opacity: 1; transition: .1s; }
  .btn.ov-black:hover { background-color: #000; }
  .btn.ov-black:hover a { color: #fff; }
  .btn.btn-more:hover { background-color: transparent; }
  .btn.btn-more:hover a { color: #e60010; }
  .btn.btn-more:hover svg { fill: #e60010; }

  .btn2:hover { background-color: #e60010; }
  .btn2:hover a { color: #fff; }
  .btn2:hover > a:after { border-color: #fff; }

  /* 見出し */
  h2.heading { padding-left: 30px; padding-top: 0px; }
  h2.heading:before { border-left-width: 4px; }
  h2.heading .svg_ttl { position: static; height: 44px; }
  h2.heading + p { font-size: 14px; margin-top: 25px; margin-bottom: 25px; }
  h2.heading + .tmp_article_image { margin-top: 25px; }

  /* カード */
  .card-box .card_info { padding: 0 15px; margin-bottom: 0; border-bottom: none; margin-bottom: 30px; }
  .card-box .card_info a:hover,
  .card-box .card_inr:hover { opacity: .7; }
  .card-box .card_image { border: 1px solid #ddd; }
  .card-box .card_catch { font-size: 12px; }
  .card-box .card_ttl { font-size: 16px; }
  .card-box .card_caption { font-size: 12px; }
  .card-box .card_tbl { font-size: 12px; }
  .card-box .card_foot { right: 0; left: 0; }
  .card-box .card_more { font-size: 14px; }
  .card-box .go_list { background-color: #fff; padding: 0 10px; }
  .card-box .go_list a { font-size: 14px; background-color: #f2f2f2; }
  .card-box .go_list:hover a { color: #fff; background-color: #000; }
  .card-box .go_list:hover svg { fill: #fff; }

  /* アコーディオン */
  .acordion-box .ac_btn { font-size: 20px; padding-top: 30px; padding-left: 0; padding-bottom: 30px; border-top-width: 3px; border-top-color: #ccc; }
  .acordion-box .ac_btn:before { content: ""; position: absolute; top: -3px; left: 0; width: 20%; height: 3px; background-color: #e60012; transform: translateY(0); }
  .acordion-box .ac_btn:after { content: none; }
  .acordion-box .ac_box { padding-bottom: 30px; }
  .acordion-box .ac_box:last-of-type { padding-bottom: 0; }
  .acordion-box .ac_box .card_image { border: none; }

  /* ページ内ナビ */
  .local-nav { padding-top: 20px; }
  .local-nav .local-nav_inr a { font-size: 16px; text-align: center; }
  .local-nav .local-nav_inr:hover a { color: #fff; background-color: #000; }
  .local-nav .local-nav_inr:hover svg { fill: #fff; }

  /* 共通エリア */
  .content_bottom { overflow: hidden; border-width: 10px; padding-top: 50px; padding-bottom: 50px; }
  .content_bottom h2.heading { height: 27px; padding-top: 0; }
  .content_bottom h2.heading .svg_ttl { height: 27px; }
  .content-garage { padding-top: 60px; padding-bottom: 60px; border-top-width: 10px; }
  .content-garage .image { padding-right: 20px; }
  .content-garage .text { padding-left: 20px; }
  .content-garage .image { margin-bottom: 0; }
  .content-garage .garage-ttl { padding-right: 50%; padding-left: 0; }
  .content-sns { padding-bottom: 0; }
  .content-sns .sns_menus { width: 80%; padding: 0; }
  .content-sns .sns_menu { min-width: 68px; }
  .content-sns .sns_menu .sns_image { padding: 0 20%; }
  .content-sns .sns_menu span { transition-duration: .3s; font-size: 12px; }
  .content-sns .sns_menu a:hover span { opacity: .7; }
  .content-magazine { padding: 50px 0 50px 60px; border-top: none; border-left: 5px solid #f2f2f2; }
  .content-magazine h2.heading + p { font-size: 14px; }
  .content-magazine .btn_magazine > a { font-size: 14px; }
  .content-magazine .btn_magazine svg { transform: translateY(-50%) scale(.6); }
  .content-magazine .btn_magazinestop > a { font-size: 12px; }
  .content-magazine .btn_magazine:hover > a { opacity: .7; }

  .content-box { padding-top: 80px; padding-bottom: 80px; }
  .content-box h2.heading { font-size: 48px; padding-top: 0; margin-bottom: 40px; }
  .content-box h2.heading .svg_ttl { height: 35px; }
}