@charset "UTF-8";
#topPage .topLink-wrapper {
  background: #dd042b;
  text-align: center;
  display: block;
  padding: 10px 0;
}

@media only screen and (max-width: 925px) {
  #topPage .topLink-wrapper {
    padding: 8px 15px;
  }
}

#topPage .topLink-wrapper img {
  width: 25%;
}

@media only screen and (max-width: 925px) {
  #topPage .topLink-wrapper img {
    width: 100%;
  }
}

@media only screen and (max-width: 925px) {
  #topPage #mainHeader .left #spNavTriger {
    top: initial;
  }
}

@media only screen and (max-width: 925px) {
  #topPage #mainHeader .right .ico-search {
    top: 60px;
  }
}

@media only screen and (max-width: 925px) {
  #topPage #mainHeader .sp-logo {
    top: 60px;
  }
}

#topPage .slideNav button {
  display: inline-block;
  width: 67px;
  height: 67px;
  font-size: 0;
}

#topPage .slideNav .slick-prev {
  background: url(../common/img/btn_slider_prev_off.png) center center no-repeat;
}

#topPage .slideNav .slick-prev:focus {
  background: url(../common/img/btn_slider_prev_on.png) center center no-repeat;
}

#topPage .slideNav .slick-next {
  margin-left: 1px;
  background: url(../common/img/btn_slider_next_off.png) center center no-repeat;
}

#topPage .slideNav .slick-next:focus {
  background: url(../common/img/btn_slider_next_on.png) center center no-repeat;
}

#topPage #mainVisual {
  position: relative;
  height: 100vh;
  min-height: 750px;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual {
    min-height: auto;
  }
}

#topPage #mainVisual #mainSlider {
  height: 65%;
  /*ステップ1プライマー*/
  /*.mainSlide02 {
        background: url(../img/main_201015.jpg) center center no-repeat;
        background-size: cover;
        .slideTxt {
          .slideCatch {
            color: #000;
            font-weight: 100;
            span {
              display: block;
              font-weight: 400;
            }
            &+p {
              color: #000;
            }
          }
          @media only screen and (max-width: 925px) {
            width: 210px;
          }
        }
      }*/
  /*リブートルミナイザー*/
  /*ルージュアーティスト*/
  /*アクアレジスト*/
  /*ベストセラー*/
}

#topPage #mainVisual #mainSlider div {
  height: 100%;
}

#topPage #mainVisual #mainSlider a {
  color: inherit;
  text-decoration: none;
}

#topPage #mainVisual #mainSlider [class^="mainSlide0"] {
  position: relative;
}

#topPage #mainVisual #mainSlider .mainSlide01 {
  background: url(../img/main_201225.jpg) center center no-repeat;
  background-size: cover;
}

#topPage #mainVisual #mainSlider .mainSlide01 .slideTxt .slideCatch {
  color: #000;
  font-weight: 100;
}

#topPage #mainVisual #mainSlider .mainSlide01 .slideTxt .slideCatch span {
  display: block;
  font-weight: 400;
}

#topPage #mainVisual #mainSlider .mainSlide01 .slideTxt .slideCatch + p {
  color: #000;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .mainSlide01 .slideTxt {
    width: 210px;
  }
}

#topPage #mainVisual #mainSlider .mainSlide02 {
  background: url(../img/main_200924.jpg) center center no-repeat;
  background-size: cover;
}

#topPage #mainVisual #mainSlider .mainSlide02 .slideTxt .slideCatch {
  color: #000;
  font-weight: 100;
}

#topPage #mainVisual #mainSlider .mainSlide02 .slideTxt .slideCatch span {
  display: block;
  font-weight: 400;
}

#topPage #mainVisual #mainSlider .mainSlide02 .slideTxt .slideCatch + p {
  color: #000;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .mainSlide02 .slideTxt {
    width: 210px;
  }
}

#topPage #mainVisual #mainSlider .mainSlide03 {
  background: url(../img/main_200813.jpg) center center no-repeat;
  background-size: cover;
}

#topPage #mainVisual #mainSlider .mainSlide03 .slideTxt .slideCatch {
  color: #000;
  font-weight: 100;
}

#topPage #mainVisual #mainSlider .mainSlide03 .slideTxt .slideCatch span {
  display: block;
  font-weight: 400;
}

#topPage #mainVisual #mainSlider .mainSlide03 .slideTxt .slideCatch + p {
  color: #000;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .mainSlide03 .slideTxt {
    width: 210px;
  }
}

#topPage #mainVisual #mainSlider .mainSlide04 {
  background: url(../img/main_200617.jpg) center center no-repeat;
  background-size: cover;
}

#topPage #mainVisual #mainSlider .mainSlide04 .slideTxt .slideCatch {
  color: #000;
  font-weight: 100;
}

#topPage #mainVisual #mainSlider .mainSlide04 .slideTxt .slideCatch span {
  display: block;
  font-weight: 400;
}

#topPage #mainVisual #mainSlider .mainSlide04 .slideTxt .slideCatch + p {
  color: #000;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .mainSlide04 .slideTxt {
    width: 210px;
  }
}

#topPage #mainVisual #mainSlider .mainSlide05 {
  background: url(../img/main_bestseller.jpg) center right no-repeat;
  background-size: cover;
}

#topPage #mainVisual #mainSlider .mainSlide05 .slideTxt .slideCatch {
  color: #000;
  font-weight: 100;
}

#topPage #mainVisual #mainSlider .mainSlide05 .slideTxt .slideCatch span {
  display: block;
  font-weight: 400;
}

#topPage #mainVisual #mainSlider .mainSlide05 .slideTxt .slideCatch + p {
  color: #000;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .mainSlide05 .slideTxt {
    width: 210px;
  }
}

#topPage #mainVisual #mainSlider .slideTxt {
  position: absolute;
  text-align: center;
  right: 25%;
  padding-right: 25px;
  padding-left: 25px;
  width: 675px;
  margin-right: -337.5px;
  top: 50%;
  height: auto;
  max-height: 100%;
  padding-top: 5.25em;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transform: translateZ(0) translateY(-50%);
  -moz-transform: translateZ(0) translateY(-50%);
  -ms-transform: translateZ(0) translateY(-50%);
  -o-transform: translateZ(0) translateY(-50%);
  transform: translateZ(0) translateY(-50%);
}

#topPage #mainVisual #mainSlider .slideTxt .slideCatch {
  color: #FFF;
  font-size: 6.0rem;
  line-height: 1;
}

#topPage #mainVisual #mainSlider .slideTxt .slideCatch + p {
  margin-top: 30px;
  color: #FFF;
  font-size: 1.4rem;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #mainSlider .slideTxt .slideCatch + p {
    font-size: 1.2rem;
  }
}

#topPage #mainVisual #mainSlider .slideTxt .slideLinkTxt {
  margin-top: 20px;
  background: url(../common/img/bg_lip_red.png) center center no-repeat;
  color: #FFF;
  line-height: 66px;
}

@media (max-width: 1349px) {
  #topPage #mainVisual #mainSlider .slideTxt {
    padding-top: 6.015625em;
    width: 463px;
    margin-right: -231.5px;
    font-size: 80%;
  }
}

#topPage #mainVisual #mainSlider .slideTxt .slideLinkTxt.black {
  margin-top: 20px;
  background: url(../common/img/bg_lip_black.png) center center no-repeat;
  color: #FFF;
  line-height: 66px;
}

@media (max-width: 1349px) {
  #topPage #mainVisual #mainSlider .slideTxt {
    padding-top: 6.015625em;
    width: 463px;
    margin-right: -231.5px;
    font-size: 80%;
  }
}

#topPage #mainVisual #mainSlider .slideTxt .slideLinkTxt.nude {
  margin-top: 20px;
  background: url(../common/img/bg_lip_nude.png) center center no-repeat;
  color: #FFF;
  line-height: 66px;
}

@media (max-width: 1349px) {
  #topPage #mainVisual #mainSlider .slideTxt {
    padding-top: 6.015625em;
    width: 463px;
    margin-right: -231.5px;
    font-size: 80%;
  }
}

#topPage #mainVisual #subSlider {
  height: 35%;
  font-size: 0;
}

#topPage #mainVisual #subSlider div {
  height: 100%;
}

#topPage #mainVisual #subSlider *:focus {
  outline: none;
}

#topPage #mainVisual #subSlider a {
  display: block;
  height: 100%;
}

#topPage #mainVisual #subSlider .slideWrap {
  width: 100%;
}

#topPage #mainVisual #subSlider .slideWrap > div {
  display: inline-block;
  width: 25%;
  vertical-align: top;
  text-align: center;
  border-right: 1px solid #E1E1E1;
  font-size: 1.4rem;
}

@media only screen and (min-width: 926px) {
  #topPage #mainVisual #subSlider .slideWrap > div {
    display: inline-block !important;
  }
}

#topPage #mainVisual #subSlider .slideWrap > div.new {
  position: relative;
}

#topPage #mainVisual #subSlider .slideWrap > div.new .iconNew {
  display: inline-block;
  background: #000;
  padding: 8px 12px;
  text-transform: uppercase;
  font-size: 1.3rem;
  margin: 20px 0 20px;
  color: #fff;
  letter-spacing: .2em;
  line-height: 1;
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual #subSlider .slideWrap > div.new .iconNew {
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
  }
}

#topPage #mainVisual #subSlider .slideWrap > div:nth-child(5) {
  border-right: 0;
}

#topPage #mainVisual #subSlider .slideWrap > div figure {
  position: relative;
  margin-top: -webkit-calc(56px + 0.9625em);
  margin-top: calc(56px + 0.9625em);
  height: -webkit-calc(100% - 86px - 4.5625em);
  height: calc(100% - 86px - 4.5625em);
}

#topPage #mainVisual #subSlider .slideWrap > div figure img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  display: inline-block;
  vertical-align: middle;
}

#topPage #mainVisual #subSlider .slideWrap > div .iconNew + figure {
  margin-top: 0;
}

#topPage #mainVisual #subSlider .slideWrap h2 {
  padding: 0 20px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #000;
  font-size: 1.4rem;
}

#topPage #mainVisual #subSlider .slideWrap .price {
  margin: 5px 0;
  color: #999;
  font-size: 1.3rem;
}

#topPage #mainVisual #mainSliderBtn {
  position: absolute;
  left: 0;
  bottom: 35%;
  font-size: 0;
}

#topPage #mainVisual #mainSliderBtn .txtArea,
#topPage #mainVisual #mainSliderBtn .buttonArea {
  display: inline-block;
  vertical-align: top;
  line-height: 67px;
}

#topPage #mainVisual #mainSliderBtn .txtArea {
  padding: 0 30px 0 75px;
  background: #FFF url(../common/img/ico_arrow_under_gray.png) 33px center no-repeat;
  font-size: 1.3rem;
  letter-spacing: .2em;
}

@media (max-width: 1349px) {
  #topPage #mainVisual #mainSliderBtn .txtArea,
  #topPage #mainVisual #mainSliderBtn .buttonArea {
    line-height: 53px;
    line-height: 53px;
  }
  #topPage #mainVisual #mainSliderBtn .txtArea {
    padding: 0 20px 0 50px;
    background: #FFF url(../common/img/ico_arrow_under_gray.png) 15px center no-repeat;
    line-height: 53px;
  }
  #topPage #mainVisual #mainSliderBtn .buttonArea button {
    width: 53px;
    height: 53px;
  }
}

@media only screen and (max-width: 925px) {
  #topPage #mainVisual {
    height: auto;
  }
  #topPage #mainVisual div {
    height: auto;
    min-height: auto;
  }
  #topPage #mainVisual #mainSlider [class^="mainSlide"] {
    position: relative;
  }
  #topPage #mainVisual #mainSlider [class^="mainSlide"]:before {
    display: block;
    padding-bottom: 58%;
    content: '';
  }
  #topPage #mainVisual #mainSlider .slideTxt {
    padding-top: 0;
    width: 150px;
    margin-right: -105px;
    font-size: 40%;
  }
  #topPage #mainVisual #mainSlider .slideTxt .slideCatch {
    font-size: 2.2rem;
    line-height: 1;
  }
  #topPage #mainVisual #mainSlider .slideTxt .slideCatch + p {
    /*display: none;*/
    margin-top: 15px;
    line-height: 1.3;
  }
  #topPage #mainVisual #mainSlider .slideTxt .slideLinkTxt {
    display: none;
  }
  #topPage #mainVisual #subSlider .slideWrap {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
    height: auto;
  }
  #topPage #mainVisual #subSlider .slideWrap > div {
    flex-basis: 50%;
    height: 250px;
    display: block;
    padding-top: 65px;
    border-right: 0;
  }
  #topPage #mainVisual #subSlider .slideWrap > div figure {
    height: 110px;
    margin-top: 0;
  }
  #topPage #mainVisual #subSlider .slideWrap > div figure img {
    max-width: 65%;
  }
  #topPage #mainVisual #subSlider .slideWrap > div:nth-child(n + 3) {
    display: none;
  }
  #topPage #mainVisual #subSlider .moreShow {
    display: block;
    flex-basis: 100%;
    padding: 10px;
    border-top: 1px solid #e1e1e1;
    border-bottom: 1px solid #e1e1e1;
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
  }
  #topPage #mainVisual #subSlider .moreShow .txtLess {
    display: none;
  }
  #topPage #mainVisual #subSlider .moreShow.active .txtLess {
    display: block;
  }
  #topPage #mainVisual #subSlider .moreShow.active .txtMore {
    display: none;
  }
  #topPage #mainVisual #mainSliderBtn {
    top: 58vw;
    width: 100%;
    bottom: auto;
    text-align: center;
  }
  #topPage #mainVisual #mainSliderBtn .txtArea {
    background-color: #FFF;
    margin-top: -26px;
    display: inline-block;
  }
  #topPage #mainVisual #mainSliderBtn .buttonArea {
    display: none;
  }
}

@media only screen and (min-width: 926px) {
  #topPage #mainVisual .moreShow {
    display: none;
  }
}

#topPage main {
  padding-bottom: 110px;
  background: #000;
  color: #FFF;
}

#topPage main a {
  color: #FFF;
}

#topPage main a:hover {
  text-decoration: underline;
}

#topPage main .toggleTrigger {
  display: none;
}

@media only screen and (max-width: 925px) {
  #topPage main {
    padding-bottom: 30px;
  }
  #topPage main .toggleTrigger {
    display: block;
    width: 100%;
    padding: 17px;
    color: #FFF;
    font-size: 1.7rem;
    font-weight: bold;
  }
  #topPage main .toggleTrigger:before, #topPage main .toggleTrigger:after {
    background: #FFF;
  }
  #topPage main .toggleTrigger.active {
    color: #dd042b;
  }
  #topPage main .toggleTrigger.active:before, #topPage main .toggleTrigger.active:after {
    background: #dd042b;
  }
}

#topPage main #secNews {
  max-width: 980px;
  margin: 0 auto;
  padding: 60px 20px 0;
}

#topPage main #secNews .eventInfo {
  margin-top: 40px;
  padding: 20px;
  background: #282828;
  text-align: center;
}

#topPage main #secNews .eventInfo a {
  text-decoration: none;
  display: block;
}

#topPage main #secNews .eventInfo:hover {
  background: #dd042b !important;
  border-color: #dd042b !important;
  color: #FFF !important;
}

#topPage main #secNews .BestSeller .sp {
  display: none;
}

#topPage main #secNews .bnrArea {
  margin-top: 25px;
  font-size: 0;
}

#topPage main #secNews .bnrArea div {
  display: inline-block;
  width: 49%;
  margin-top: 20px;
  vertical-align: middle;
}

#topPage main #secNews .bnrArea div:nth-child(2n) {
  margin-left: 2%;
}

@media only screen and (max-width: 925px) {
  #topPage main #secNews {
    padding-top: 30px;
  }
  #topPage main #secNews .toggleTrigger {
    border-bottom: 1px solid #FFF;
    margin-bottom: 30px;
  }
  #topPage main #secNews .eventInfo {
    width: 87.5%;
    margin: 20px auto 0;
  }
  #topPage main #secNews .BestSeller {
    width: 100%;
    text-align: center;
  }
  #topPage main #secNews .BestSeller .pc {
    display: none;
  }
  #topPage main #secNews .BestSeller .sp {
    display: block;
    width: 87.5%;
    margin: 0 auto;
  }
  #topPage main #secNews .bnrArea {
    width: 87.5%;
    margin: 15px auto 0;
  }
  #topPage main #secNews .bnrArea div {
    width: 100%;
    margin-top: 10px;
    text-align: center;
  }
  #topPage main #secNews .bnrArea div:nth-child(2n) {
    margin-left: 0;
  }
}

#topPage main #middleMenu {
  max-width: 1390px;
  margin: 100px auto 0;
  text-align: center;
  padding: 0 20px;
  font-size: 0;
}

#topPage main #middleMenu > div {
  display: inline-block;
  width: 33.33%;
  vertical-align: top;
}

#topPage main #middleMenu > div .menuDetail,
#topPage main #middleMenu > div figure {
  width: 50%;
  vertical-align: top;
}

#topPage main #middleMenu > div .menuDetail {
  float: left;
  padding-top: 40px;
}

#topPage main #middleMenu > div figure {
  float: right;
}

#topPage main #middleMenu > div h4 {
  font-size: 2.8rem;
  line-height: 1.1;
}

#topPage main #middleMenu > div h4 span {
  display: block;
}

#topPage main #middleMenu > div p {
  margin-top: 20px;
  font-size: 1.2rem;
  line-height: 1.5;
}

#topPage main #middleMenu > div p.linkDetail {
  text-decoration: underline;
}

#topPage main #middleMenu > div p .red {
  color: #DD042B;
}

#topPage main #middleMenu > div:before, #topPage main #middleMenu > div:after {
  display: block;
  clear: both;
  content: '';
}

#topPage main #middleMenu > div a:hover .linkDetail {
  text-decoration: none;
}

@media only screen and (max-width: 1300px) {
  #topPage main #middleMenu > div {
    display: block;
    max-width: 480px;
    width: 100%;
    margin: 0 auto;
  }
  #topPage main #middleMenu > div + div {
    margin-top: 40px;
  }
}

@media only screen and (max-width: 925px) {
  #topPage main #middleMenu {
    margin-top: 55px;
    padding-top: 35px;
    border-top: 1px solid #666;
  }
  #topPage main #middleMenu > div {
    display: block;
  }
  #topPage main #middleMenu > div figure,
  #topPage main #middleMenu > div .menuDetail {
    display: block;
    width: 100%;
  }
  #topPage main #middleMenu > div.online h4 span {
    display: inline-block;
    margin-left: 10px;
  }
}

#topPage main #spContents {
  margin-top: 120px;
}

#topPage main #spContents .btnArea {
  margin-top: 50px;
  text-align: center;
}

#topPage main #spContents .btnArea a {
  color: #FFF;
  font-size: 3.9rem;
  font-weight: 100;
}

#topPage main #spContents .btnArea a:hover {
  color: #dd042b;
  text-decoration: none;
}

#topPage main #spContents h1 {
  position: relative;
  padding-bottom: 30px;
  font-size: 2.5rem;
  letter-spacing: 10px;
  text-align: center;
}

#topPage main #spContents h1:after {
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 34px;
  height: 1px;
  margin: 0 0 0 -17px;
  background: #FFF;
  content: '';
}

#topPage main #spContents .contentWrap {
  position: relative;
}

#topPage main #spContents .contentWrap h2 {
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
  font-size: 3.3rem;
  font-weight: bold;
  text-align: center;
  transform: translateZ(0) translateX(0) translateY(-50%);
  transition: ease .3s;
  line-height: 1.3;
  z-index: 5;
}

#topPage main #spContents .contentWrap a:after {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  content: '';
  transition: ease .3s;
}

#topPage main #spContents .contentWrap figure {
  overflow: hidden;
}

#topPage main #spContents .contentWrap img {
  transform: scale(1.1);
  transition: ease .25s;
}

#topPage main #spContents .contentWrap:hover a:after,
#topPage main #spContents .contentWrap:hover h2 {
  opacity: 0;
}

#topPage main #spContents .contentWrap:hover img {
  transform: scale(1);
}

#topPage main #spContents .pc {
  display: block;
}

#topPage main #spContents .sp {
  display: none;
}

@media only screen and (max-width: 925px) {
  #topPage main #spContents .pc {
    display: none;
  }
  #topPage main #spContents .sp {
    display: block;
  }
}

#topPage main #spContents #spSlider {
  margin-top: 25px;
}

#topPage main #spContents #spSliderBtn {
  margin-top: 40px;
  text-align: center;
}

#topPage main #spContents #spSliderBtn button {
  display: inline-block;
}

@media only screen and (max-width: 925px) {
  #topPage main #spContents {
    margin-top: 55px;
    /*padding-top: 35px;
        border-top: 1px solid #666;*/
  }
  #topPage main #spContents h1 {
    font-size: 2.2rem;
    letter-spacing: 5px;
  }
  #topPage main #spContents .sp {
    max-width: 528px;
    margin: 40px auto 0;
  }
  #topPage main #spContents .sp .contentsList .contentWrap + .contentWrap {
    margin-top: 15px;
  }
  #topPage main #spContents .sp .contentsList .contentWrap:nth-child(n + 3) {
    display: none;
  }
  #topPage main #spContents .sp .contentsList .contentWrap img {
    width: 100%;
  }
}

.service-menu {
  padding: 30px 0 20px;
  background: #CF0433;
}

@media only screen and (max-width: 925px) {
  .service-menu {
    padding: 15px 0;
  }
}

.service-menu-list {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  justify-content: center;
}

@media only screen and (max-width: 925px) {
  .service-menu-list {
    flex-wrap: wrap;
    align-items: center;
  }
}

.service-menu-list__item {
  flex-basis: 270px;
  max-width: 270px;
  text-align: center;
}

@media only screen and (max-width: 925px) {
  .service-menu-list__item {
    flex-basis: 50%;
    max-width: 50%;
  }
}

.service-menu-list__item + .service-menu-list__item {
  border-left: 1px solid #FFF;
}

@media only screen and (max-width: 925px) {
  .service-menu-list__item:nth-child(3) {
    border-left: none;
  }
}

@media only screen and (max-width: 925px) {
  .service-menu-list__item:nth-child(odd) {
    border-left: none;
  }
}

@media only screen and (max-width: 925px) {
  .service-menu-list__item:nth-child(n+3) {
    margin-top: 20px;
  }
}

.service-menu-list__inner {
  position: relative;
  display: block;
  padding: 10px;
  color: #FFF;
}

.service-menu-list__img-on {
  position: absolute;
  top: 10px;
  left: 0;
  display: block;
  width: 100%;
  opacity: 0;
  transition: .15s;
  visibility: hidden;
}

.service-menu-list__link:hover {
  color: #000 !important;
  text-decoration: none !important;
}

.service-menu-list__link:hover .service-menu-list__img-off {
  opacity: 0;
}

.service-menu-list__link:hover .service-menu-list__img-on {
  opacity: 1;
  visibility: visible;
}

.service-menu-list__txt {
  display: block;
  margin-top: 5px;
  font-size: 1.4rem;
}

@media only screen and (max-width: 925px) {
  .service-menu-list__txt {
    font-size: 1.2rem;
  }
}

.top-news {
  max-width: 980px;
  margin: 0 auto;
  padding: 80px 20px 0;
}

@media only screen and (max-width: 925px) {
  .top-news {
    padding: 50px 0 0;
  }
}

.top-news__ttl {
  font-size: 5.4rem;
  text-align: center;
}

@media only screen and (max-width: 925px) {
  .top-news__ttl {
    font-size: 2.7rem;
  }
}

.top-news table {
  width: 100%;
  margin: 35px 0 0 0;
}

@media only screen and (max-width: 925px) {
  .top-news table {
    margin-top: 10px;
  }
}

.top-news table tr {
  border-bottom: 1px solid #CCC;
}

.top-news table tr th,
.top-news table tr td {
  padding: 25px 10px;
}

@media only screen and (max-width: 925px) {
  .top-news table tr th,
  .top-news table tr td {
    display: block;
    width: 100%;
    padding: 15px;
  }
}

.top-news table tr th {
  width: 190px;
  font-size: 1.2rem;
  font-weight: normal;
}

@media only screen and (max-width: 925px) {
  .top-news table tr th {
    padding-bottom: 0;
  }
}

.top-news table tr th .category {
  display: inline-block;
  width: 70px;
  margin-right: 20px;
  line-height: 23px;
  text-align: center;
}

.top-news table tr th .category.media {
  border: 1px solid #CCC;
}

.top-news table tr th .category.news {
  background: #FFF;
  color: #000;
}

.top-news table tr th .category.present {
  background: #DD042B;
  color: #FFF;
}

.top-news table tr th .category.info {
  background: #666;
  color: #FFF;
}

.top-news table tr td {
  font-size: 1.4rem;
}

@media only screen and (max-width: 925px) {
  .top-news table tr td {
    padding-top: 10px;
  }
}

@media only screen and (max-width: 925px) {
  .top-news table tr:nth-child(n + 4) {
    display: none;
  }
}

.discover {
  padding: 80px 0;
}

@media only screen and (max-width: 925px) {
  .discover {
    padding: 0;
  }
}

.discover-list {
  display: flex;
  max-width: 935px;
  margin: 0 auto;
}

@media only screen and (max-width: 925px) {
  .discover-list {
    flex-wrap: wrap;
    max-width: 100%;
  }
}

.discover-list__items {
  flex-basis: 235px;
  max-width: 235px;
}

@media only screen and (max-width: 925px) {
  .discover-list__items {
    flex-basis: 50%;
  }
}

.discover-list__link {
  position: relative;
}

.discover-list__link figcaption {
  position: absolute;
  /*top: 42%;*/
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  font-size: 3.0rem;
  font-weight: bold;
  text-align: center;
}

.discover-list__txt {
  position: absolute;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  width: 100%;
  padding: 10px 0;
  text-align: center;
  font-size: 1.6rem;
  font-weight: bold;
  color: #ffffff;
}

@media only screen and (max-width: 925px) {
  .discover-list__txt {
    bottom: -1px;
    padding: 2vw 0;
  }
}
