@charset "UTF-8";
html {
  font-size: 62.5%;
  height: 100%; }

body {
  font-family: "Noto Sans JP",'Meiryo','Helvetica Neue','Helvetica','Arial','Geneva,sans-serif','メイリオ','Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','ＭＳ Ｐゴシック','Osaka',sans-serif;
  color: #000000;
  background-color: #ffffff;
  box-sizing: border-box;
  line-height: 1;
  margin: 0;
  padding: 0; }

a {
  text-decoration: none; }

#splash {
  position: fixed;
  z-index: 99999;
  width: 100%;
  height: 100%;
  background: #333;
  text-align: center;
  color: #fff;
  top: 0; }

#splash_text {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 999999;
  width: 100%;
  transform: translate(-50%, -50%);
  color: #fff; }

#splash_text svg {
  height: 2px; }

nav ul {
  display: block; }
  @media screen and (min-width: 960px) {
    nav ul {
      list-style: none;
      display: flex;
      justify-content: center; } }

nav ul li {
  position: relative;
  text-align: center;
  font-size: 16px;
  font-weight: 300;
  /*padding: 0 10px;*/ }
  @media screen and (min-width: 960px) {
    nav ul li {
      /*text-align: left;*/
      font-size: 18px;
      border-left: 1px solid #000000;
      border-right: none;
      padding: 0 10px; } }
  @media screen and (min-width: 1050px) {
    nav ul li {
      font-size: 20px; } }
  @media screen and (min-width: 960px) {
    nav ul li:nth-last-child(2) {
      border-right: 1px solid #000000; } }

nav ul li a {
  display: block;
  text-decoration: none;
  color: #000000;
  border-left: 1px solid #fff;
  border-right: 1px solid #fff;
  /*padding:20px 35px;*/
  /*transition:all .3s;*/ }
  nav ul li a:hover {
    color: #92242a;
    transition: all 0.4s ease-out; }

/*@media screen and (max-width:1200px) {
    nav ul li a{
        padding:20px;
    }
}*/
/*==960px以下の形状*/
@media screen and (max-width: 960px) {
  nav {
    padding: 0; } }
@media screen and (max-width: 960px) {
  #g-nav {
    position: fixed;
    z-index: 999;
    top: -250%;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.9);
    /*動き*/
    transition: all 0.6s; }

  #g-nav.panelactive {
    top: 0; }

  #g-nav.panelactive #g-nav-list {
    position: fixed;
    z-index: 999;
    width: 100%;
    height: 100vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch; }

  /*ナビゲーション*/
  #g-nav ul {
    /*ナビゲーション天地中央揃え*/
    /*width: 90%;*/
    margin: 100px auto 0 auto; }

  /*リストのレイアウト設定*/
  #g-nav li {
    list-style: none;
    text-align: center; }

  #g-nav li a {
    color: #fff;
    text-decoration: none;
    padding: 0 10px;
    margin-bottom: 40px;
    display: inline-block;
    /*text-transform: uppercase;*/
    letter-spacing: 0.1em;
    font-weight: 300; } }
.g-nav-openbtn {
  display: none; }

@media screen and (max-width: 960px) {
  .g-nav-openbtn {
    display: block;
    position: fixed;
    z-index: 9999;
    top: 10px;
    right: 10px;
    cursor: pointer;
    width: 50px;
    height: 50px; }

  /*ボタン内側*/
  .g-nav-openbtn .openbtn-area {
    transition: all .4s; }

  .g-nav-openbtn span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
    background: #92242a;
    width: 45%; }

  .g-nav-openbtn span:nth-of-type(1) {
    top: 10px; }

  .g-nav-openbtn span:nth-of-type(2) {
    top: 18px; }

  .g-nav-openbtn span:nth-of-type(3) {
    top: 26px; }

  .g-nav-openbtn span:nth-of-type(3)::after {
    content: "Menu";
    position: absolute;
    top: 6px;
    left: -2px;
    color: #92242a;
    font-size: 1rem;
    text-transform: uppercase; } }
  @media screen and (max-width: 960px) and (min-width: 768px) {
    .g-nav-openbtn span:nth-of-type(3)::after {
      font-size: 0.6rem; } }

@media screen and (max-width: 960px) {
  /*activeクラスが付与されると
  線と周りのエリアが回転して×になる*/
  .g-nav-openbtn.active .openbtn-area {
    transform: rotateY(-360deg); }

  .g-nav-openbtn.active span:nth-of-type(1) {
    top: 16px;
    left: 16px;
    transform: translateY(6px) rotate(-45deg);
    width: 40%;
    background: #fff; }

  .g-nav-openbtn.active span:nth-of-type(2) {
    opacity: 0; }

  .g-nav-openbtn.active span:nth-of-type(3) {
    top: 28px;
    left: 16px;
    transform: translateY(-6px) rotate(45deg);
    width: 40%;
    background: #fff; }

  .g-nav-openbtn.active span:nth-of-type(3)::after {
    content: "Close";
    transform: translateY(0) rotate(-45deg);
    top: 10px;
    left: 8px;
    color: #fff; } }
/*topics*/
.topic__wrapper {
  position: relative;
  color: #666;
  letter-spacing: 0.1em;
  margin-top: 50px; }
  @media screen and (min-width: 960px) {
    .topic__wrapper {
      width: 900px;
      margin: 0 auto;
      margin-top: 50px; } }
  @media screen and (min-width: 1110px) {
    .topic__wrapper {
      display: flex;
      justify-content: space-between;
      width: 1016px;
      margin: 0 auto;
      margin-top: 50px; } }

.c-content-block__title {
  text-align: center; }

h2.c-headline-3 {
  color: #92242a;
  font-size: 19px;
  line-height: 1.5;
  text-align: center;
  border: 1px solid #92242a;
  padding: 11px 0 10px;
  width: 120px;
  margin: 0 auto; }
  @media screen and (min-width: 960px) {
    h2.c-headline-3 {
      font-size: 18px;
      width: 120px; } }

.c-headline-3__en {
  font-size: 25px; }
  @media screen and (min-width: 960px) {
    .c-headline-3__en {
      font-size: 24px; } }
.p-article-list__content {
  display: flex;
  flex-diretion: row;
  align-items: flex-start;
}
.p-article-list__category {
  white-space: nowrap;
}
@media only screen and (max-width: 640px) {
.p-article-list__content {
  flex-wrap:wrap;
}
.p-article-list__title {
  margin-top: 8px;
}
}
.p-article-list {
  font-size: 14px;
  line-height: 1.5;
  margin-top: 5px; }
  @media screen and (min-width: 960px) {
    .p-article-list {
      font-size: 16px;
      margin-top: 0; } }

.p-article-list__item {
  padding: 16px 0 16px 0;
  margin: 0 16px 0; }

.p-article-list__item:first-child {
  padding: 10px 0 16px 0;
  margin: 0 16px 0; }

.p-article-list__item:not(:last-child) {
  border-bottom: dotted 2px #666666; }

.p-article-list--type_home {
  width: 90%;
  margin: 0 auto;
  margin-top: 30px; }
  @media screen and (min-width: 960px) {
    .p-article-list--type_home {
      width: 90%;
      margin-top: 30px; } }
  @media screen and (min-width: 1110px) {
    .p-article-list--type_home {
      width: 85%;
      margin-top: 0; } }

.p-article-list__date,
.p-article-list__category,
.p-article-list__title {
  /*display: inline-block;*/
  letter-spacing: normal;
  vertical-align: top; }

.p-article-list__date,
.p-article-list__category {
  margin-right: 10px; }

.p-article-list__category {
  color: #666;
  font-weight: bold;
  background-color: #f2f2f2;
  padding: 1px 16px;
  border-radius: 30px;
  moz-border-radius: 30px;
  -webkit-border-radius: 30px;
  font-size: .8333em;
  vertical-align: baseline;
  text-align: center;
  width: 9em; }
  
.p-article-list__item a,
.p-article-list__item a:hover {
  text-decoration: none;
}

.p-article-list__title {
  color: #666; }

.p-article-list__title:hover,
.p-article-list__title > a:hover {
  text-decoration: underline;
  transition: all 0.4s ease-out; }

.p-article-list__title > a {
  color: #666;
  text-decoration: none; }

.p-article-list__title > a:hover {
  color: #666;
  text-decoration: underline;
  transition: all 0.4s ease-out; }

.p-article-list__date {
  margin-right: 8px;
  color: #999; }

.topics-button {
  text-align: center;
  margin: 20px 0 50px; }
  @media screen and (min-width: 769px) {
    .topics-button {
      margin: 20px 0 100px; } }

.topics-button a {
  position: relative;
  display: block;
  background-color: #92242a;
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  width: 120px;
  padding: 12px 5px;
  margin: auto; }

.topics-button a:hover {
  background-color: #333;
  color: #fff;
  text-decoration: none;
  transition: all 0.4s ease-out; }

.hover {
  display: none; }

/* ホバー時は通常時の文字を非表示にする */
a:hover .nomal {
  display: none; }

/* ホバー時に、ホバー時の文字を表示する */
a:hover .hover {
  display: inline; }

@media screen and (min-width: 1200px) {
  .topics-button {
    margin-bottom: 100px; } }
@media screen and (min-width: 640px) {
  .p-headline-3--type__home,
  .p-home-pickup__list,
  .p-article-list--type_home {
    display: block;
    vertical-align: top; } }
.hide-area {
  display: none; }

.modaal-close:after,
.modaal-close:before {
  background: #fff; }

.modaal-close:focus, .modaal-close:hover {
  outline: none;
  background: #000; }

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
  background: #fff; }

.modaal-video .modaal-inner-wrapper {
  padding: 0; }
