@charset "UTF-8";
/* foundation/Reset
   
html5doctor.com Reset Stylesheet
v1.4.1
2010-03-01
Author: Richard Clark - http://richclarkdesign.com

   ----------------------------------------------------------------- */
@import url("https://fonts.googleapis.com/css2?family=Caprasimo&family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900&display=swap");
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font-weight: normal;
  vertical-align: baseline;
  background: transparent; }

body {
  line-height: 1.7em; }

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

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

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

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

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

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

del {
  text-decoration: line-through; }

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

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

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

li {
  list-style: none; }

address {
  font-style: normal; }

input, select {
  vertical-align: middle; }

img {
  vertical-align: bottom; }

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box; }

input:focus, select:focus, textarea:focus {
  outline: 0; }

.cf:after {
  content: "";
  display: block;
  clear: both; }

input[type="submit"] {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none; }

/* Base
   ----------------------------------------------------------------- */
@media screen and (min-width: 897px) {
  .pc_none {
    display: none !important; } }

@media screen and (max-width: 896px) {
  .sp_none {
    display: none !important; }
  img {
    max-width: 100%; } }

.hover, #header .inner .sp_inner, #header .global_navi .wrap .target, #header .global_navi .wrap .target:after, #eye .btn_wrap .btn, .more_btn_wrap .btn,
.wrap .btn, .contents05 .wrap .details .btns .btn {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out; }

html {
  height: 100%; }

body {
  height: 100%;
  color: #000;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 15px;
  line-height: 1.5;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%; }

.serif, #header .global_navi .wrap .target, #eye > .wrap .news_wrap, .contents_title, .contents04 .wrap .head time {
  font-family: 'Noto Serif JP', serif; }

a {
  color: #000;
  text-decoration: none; }

body {
  background-color: #040510; }

#header {
  position: fixed;
  top: 0;
  z-index: 2;
  width: 100%;
  padding: 30px 0 25px;
  background-color: #000; }
  @media screen and (max-width: 896px) {
    #header {
      padding: 0;
      height: 66px; } }
  #header .inner {
    position: relative;
    max-width: 1100px;
    width: 90%;
    margin: 0 auto; }
    @media screen and (max-width: 896px) {
      #header .inner {
        height: 100%; }
        #header .inner .sp_inner {
          visibility: hidden;
          opacity: 0;
          display: flex;
          justify-content: center;
          align-items: center;
          flex-wrap: wrap;
          background: rgba(0, 0, 0, 0.8);
          position: fixed;
          left: 0;
          top: 0;
          width: 100%;
          height: 100%; }
          #header .inner .sp_inner.active {
            visibility: visible;
            opacity: 1; } }
  #header .global_navi {
    text-align: center; }
    #header .global_navi .wrap {
      display: inline-block;
      margin: 0 15px; }
      @media screen and (max-width: 896px) {
        #header .global_navi .wrap {
          display: block;
          width: 100%;
          margin: 20px 0; } }
      #header .global_navi .wrap .target {
        font-size: 16px;
        padding: 2px;
        color: #C3C3C3;
        position: relative; }
        @media screen and (max-width: 896px) {
          #header .global_navi .wrap .target {
            font-size: 18px; } }
        #header .global_navi .wrap .target:after {
          position: absolute;
          left: 0;
          bottom: -3px;
          content: "";
          height: 5px;
          width: 100%;
          background-color: #000; }
        #header .global_navi .wrap .target.active {
          color: #FFFFFF; }
          #header .global_navi .wrap .target.active:after {
            background-color: #FFAD3E; }
        #header .global_navi .wrap .target:hover {
          color: #FFFFFF; }
          #header .global_navi .wrap .target:hover:after {
            background-color: #FFAD3E; }
  #header .sns {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    display: flex; }
    #header .sns a {
      transition: all 0.4s;
      padding: 5px;
      margin-left: 10px; }
      #header .sns a img {
        height: 24px; }
      #header .sns a.x img {
        height: 22px; }
      @media screen and (min-width: 897px) {
        #header .sns a:hover {
          opacity: 0.6; } }
  #header .menu-trigger {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 20px;
    display: inline-block;
    transition: all 0.4s;
    box-sizing: border-box;
    width: 30px;
    height: 20px;
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    appearance: none; }
    @media screen and (min-width: 897px) {
      #header .menu-trigger {
        display: none; } }
    #header .menu-trigger span {
      display: inline-block;
      transition: all 0.4s;
      box-sizing: border-box;
      position: absolute;
      left: 0;
      width: 100%;
      height: 2px;
      background-color: #C3C3C3; }
      #header .menu-trigger span:nth-of-type(1) {
        top: 0; }
      #header .menu-trigger span:nth-of-type(2) {
        top: 9px; }
      #header .menu-trigger span:nth-of-type(3) {
        bottom: 0; }
    #header .menu-trigger.active span:nth-of-type(1) {
      transform: translateY(9px) rotate(-45deg); }
    #header .menu-trigger.active span:nth-of-type(2) {
      opacity: 0; }
    #header .menu-trigger.active span:nth-of-type(3) {
      transform: translateY(-9px) rotate(45deg); }

#eye {
  background-image: url(../img/eye_bg.jpg);
  background-size: cover;
  background-position: center center;
  padding-bottom: 80px;
  max-width: 100%;
  width: 100%; }
  @media screen and (max-width: 896px) {
    #eye {
      padding-bottom: 40px; } }
  #eye .btn_wrap {
    max-width: 1100px;
    width: 90%;
    margin: 0 auto;
    position: relative; }
    #eye .btn_wrap .btn {
      position: absolute;
      top: 30px;
      right: 0;
      width: 200px; }
      @media screen and (min-width: 897px) {
        #eye .btn_wrap .btn:hover {
          opacity: .6; } }
      @media screen and (max-width: 896px) {
        #eye .btn_wrap .btn {
          width: 30%;
          min-width: 140px; } }
      #eye .btn_wrap .btn img {
        width: 100%; }
  #eye > .wrap {
    max-width: 824px;
    margin: 0 auto;
    padding-top: 200px; }
    @media screen and (max-width: 896px) {
      #eye > .wrap {
        padding: 100px 20px 20px; } }
    #eye > .wrap > .title {
      display: block;
      margin-bottom: 80px; }
      @media screen and (max-width: 896px) {
        #eye > .wrap > .title {
          margin-bottom: 40px; } }
      #eye > .wrap > .title img {
        width: 100%; }
    #eye > .wrap .news img {
      width: 100%; }
    #eye > .wrap .news_wrap .news .title {
      background-color: #DA233A;
      font-size: 20px;
      font-weight: bold;
      color: #fff; }

.backgroundText {
  position: absolute;
  width: 100%;
  padding: 20px 0;
  display: flex;
  overflow: hidden;
  position: absolute;
  background-color: #DA233A; }
  .backgroundText .backgroundText__content {
    margin-right: .3em;
    line-height: 1;
    flex-shrink: 0;
    display: inline-block;
    text-wrap: nowrap;
    white-space: nowrap;
    font-size: 100px;
    color: #521A1A;
    text-shadow: 0 3px 3px rgba(0, 0, 0, 0.16);
    font-family: "Caprasimo", serif;
    animation-name: tickerAnimation;
    animation-timing-function: linear;
    animation-iteration-count: infinite; }
    @media screen and (max-width: 896px) {
      .backgroundText .backgroundText__content {
        font-size: 30px; } }

@keyframes tickerAnimation {
  0% {
    transform: translateX(0%); }
  100% {
    transform: translateX(-100%); } }

.ticker {
  position: relative;
  display: block;
  white-space: nowrap;
  overflow: hidden; }
  .ticker .ticker__text {
    display: inline-block;
    animation-name: tickerAnimation;
    animation-timing-function: linear;
    animation-iteration-count: infinite; }

.contents_title {
  text-align: center;
  font-size: 37px;
  font-weight: bold;
  color: #fff;
  margin-bottom: 80px; }
  @media screen and (max-width: 896px) {
    .contents_title {
      font-size: 28px;
      margin-bottom: 15px; } }

.contents {
  width: 100%;
  /*
	.contents_inner{
		max-width: 1400px;
		margin: 0 auto;
	}
*/ }

.line {
  width: 100%;
  margin-bottom: -100px; }
  @media screen and (max-width: 896px) {
    .line {
      margin-bottom: -8vw; } }

.bg {
  background-image: url(../img/bg.jpg);
  background-size: 240px auto; }

.contents01 {
  padding-top: 220px; }
  @media screen and (max-width: 896px) {
    .contents01 {
      margin-top: 0;
      padding-top: 120px; } }
  .contents01 .contents_title {
    margin-bottom: 40px; }
    @media screen and (max-width: 896px) {
      .contents01 .contents_title {
        margin-bottom: 15px; } }
  .contents01 .wrap {
    max-width: 824px;
    margin: 0 auto; }
    @media screen and (max-width: 896px) {
      .contents01 .wrap {
        padding: 0 20px; } }
    .contents01 .wrap .block .block_title {
      text-align: center;
      margin-bottom: 30px; }
      @media screen and (max-width: 896px) {
        .contents01 .wrap .block .block_title {
          margin-bottom: 20px; } }
    .contents01 .wrap .block .sub_title {
      font-size: 24px;
      font-weight: bold;
      color: #fff;
      text-align: center;
      margin-bottom: 20px; }
      @media screen and (max-width: 896px) {
        .contents01 .wrap .block .sub_title {
          font-size: 20px; } }
    .contents01 .wrap .block .text {
      color: #FFFFFF;
      margin-bottom: 50px;
      font-size: 20px;
      line-height: 1.8; }
      .contents01 .wrap .block .text strong {
        font-weight: bold;
        color: #FFAD3E; }
      @media screen and (max-width: 896px) {
        .contents01 .wrap .block .text {
          margin-bottom: 40px;
          font-size: 16px; } }

.contents02 {
  padding: 100px 0 0;
  margin-top: 100px; }
  @media screen and (max-width: 896px) {
    .contents02 {
      margin-top: 0;
      padding: calc(8vw + 40px) 0 0; } }
  .contents02 .contents_title {
    color: #FFFFFF; }
  .contents02 .staff {
    color: #fff;
    text-align: center;
    margin-bottom: 120px; }
    @media screen and (max-width: 896px) {
      .contents02 .staff {
        margin-bottom: 60px;
        padding: 0 20px; } }
    .contents02 .staff dt {
      color: #B9B9B9;
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 12px; }
      @media screen and (max-width: 896px) {
        .contents02 .staff dt {
          font-size: 14px; } }
    .contents02 .staff dd {
      font-size: 20px;
      font-weight: 700;
      margin-bottom: 60px; }
      @media screen and (max-width: 896px) {
        .contents02 .staff dd {
          font-size: 16px;
          margin-bottom: 40px; } }
  .contents02 .wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    max-width: 730px;
    margin: 0 auto; }
    @media screen and (max-width: 896px) {
      .contents02 .wrap {
        display: block;
        padding: 0 20px; } }
    .contents02 .wrap .character {
      width: 46%;
      color: #fff;
      margin-bottom: 80px; }
      @media screen and (max-width: 896px) {
        .contents02 .wrap .character {
          width: 100%;
          margin-bottom: 40px; } }
      .contents02 .wrap .character .img {
        text-align: center;
        margin-bottom: 15px; }
        @media screen and (max-width: 896px) {
          .contents02 .wrap .character .img {
            max-width: 40%;
            margin: 0 auto 10px; }
            .contents02 .wrap .character .img img {
              width: 100%; } }
      .contents02 .wrap .character .name {
        display: flex;
        justify-content: center;
        align-items: flex-end;
        margin-bottom: 35px; }
        @media screen and (max-width: 896px) {
          .contents02 .wrap .character .name {
            margin-bottom: 10px; } }
        .contents02 .wrap .character .name ruby rb {
          font-size: 28px;
          font-weight: bold; }
          @media screen and (max-width: 896px) {
            .contents02 .wrap .character .name ruby rb {
              font-size: 20px; } }
        .contents02 .wrap .character .name ruby rt {
          font-size: 12px;
          ruby-align: center;
          margin-bottom: 6px; }
          @media screen and (max-width: 896px) {
            .contents02 .wrap .character .name ruby rt {
              font-size: 10px; } }
        .contents02 .wrap .character .name .age {
          font-size: 28px;
          font-weight: bold; }
          @media screen and (max-width: 896px) {
            .contents02 .wrap .character .name .age {
              font-size: 20px; } }
      .contents02 .wrap .character .value p {
        font-size: 16px; }
        @media screen and (max-width: 896px) {
          .contents02 .wrap .character .value p {
            font-size: 14px; } }

.contents03 {
  margin-top: 80px;
  padding: 100px 0 0; }
  @media screen and (max-width: 896px) {
    .contents03 {
      margin-top: 0;
      padding: 60px 0 0; } }
  .contents03 .contents_title {
    color: #FFFFFF; }
  .contents03 .wrap {
    max-width: 900px;
    margin: 0 auto 30px; }
    @media screen and (max-width: 896px) {
      .contents03 .wrap {
        padding: 0 20px; } }
    .contents03 .wrap p {
      color: #fff;
      font-size: 20px;
      margin-bottom: 30px; }
      .contents03 .wrap p span {
        font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif; }
      @media screen and (max-width: 896px) {
        .contents03 .wrap p {
          font-size: 16px;
          margin-bottom: 20px; } }
    .contents03 .wrap .img {
      margin: 100px 0 150px; }
      @media screen and (max-width: 896px) {
        .contents03 .wrap .img {
          margin: 60px 0 80px; } }
      .contents03 .wrap .img img {
        width: 100%; }

.more_btn_wrap .btn,
.wrap .btn {
  background-color: #FFD93B;
  padding: 14px 20px 14px 30px;
  border-radius: 26px;
  font-size: 17px;
  font-weight: bold; }
  @media screen and (min-width: 897px) {
    .more_btn_wrap .btn:hover,
    .wrap .btn:hover {
      opacity: .6; } }
  @media screen and (max-width: 896px) {
    .more_btn_wrap .btn,
    .wrap .btn {
      padding: 10px 15px 10px 20px;
      font-size: 14px; } }
  .more_btn_wrap .btn img,
  .wrap .btn img {
    vertical-align: middle; }
    @media screen and (max-width: 896px) {
      .more_btn_wrap .btn img,
      .wrap .btn img {
        width: 6px; } }

.contents04 {
  padding: 180px 0 0; }
  @media screen and (max-width: 896px) {
    .contents04 {
      padding: calc(8vw + 40px) 0 0; } }
  .contents04 .wrap {
    max-width: 900px;
    margin: 0 auto 70px; }
    @media screen and (max-width: 896px) {
      .contents04 .wrap {
        margin: 0 auto 40px;
        padding: 0 20px; } }
    .contents04 .wrap .head {
      text-align: center;
      position: relative;
      border-top: 2px solid #fff;
      padding-top: 22px;
      margin-bottom: 24px; }
      @media screen and (max-width: 896px) {
        .contents04 .wrap .head {
          padding-bottom: 15px;
          margin-bottom: 20px; } }
      .contents04 .wrap .head time {
        color: #fff;
        font-size: 28px;
        font-weight: bold; }
        @media screen and (max-width: 896px) {
          .contents04 .wrap .head time {
            display: block;
            font-size: 20px;
            margin-bottom: 10px; } }
      .contents04 .wrap .head .btn_wrap {
        display: flex;
        justify-content: center; }
        @media screen and (max-width: 896px) {
          .contents04 .wrap .head .btn_wrap {
            justify-content: space-between; 
            gap: 12px;} }
        .contents04 .wrap .head .btn_wrap.ended {
          justify-content: center; }
      .contents04 .wrap .head .btn {
        position: relative;
        margin: 25px 8px 8px;
        padding: 15px 45px 15px 30px;
        margin-bottom: 15px;
        line-height: 1.2;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        text-indent: -0px; }
        @media screen and (max-width: 896px) {
          .contents04 .wrap .head .btn {
            width: 200px;
            height: 40px;
            margin: 0 auto;
            padding: 0 5px 0 0; } }
        .contents04 .wrap .head .btn div {
          font-weight: bold; }
          @media screen and (max-width: 896px) {
            .contents04 .wrap .head .btn div {
              font-size: 10px; } }
        .contents04 .wrap .head .btn span {
          font-weight: bold;
          line-height: 1.2;
          font-size: 17px;
          display: block;
          width: 100%; }
          @media screen and (max-width: 896px) {
            .contents04 .wrap .head .btn span {
              font-size: 10px; } }
        .contents04 .wrap .head .btn img {
          position: absolute;
          right: 21px;
          top: 50%;
          transform: translateY(-50%); }
          @media screen and (max-width: 896px) {
            .contents04 .wrap .head .btn img {
              right: 20px; } }
    .contents04 .wrap .items {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: 28px;
      margin: 0 auto;
      padding: 0 200px; }
      @media screen and (max-width: 896px) {
        .contents04 .wrap .items {
          justify-content: space-between;
          padding: 0 0;
          gap: 18px; } }
      .contents04 .wrap .items .item {
        margin-bottom: 25px;
        width: calc(100% / 3 - 28px);
        position: relative; }
        @media screen and (max-width: 896px) {
          .contents04 .wrap .items .item {
            width: calc(100% / 2 - 18px);
            text-align: center; } }
        .contents04 .wrap .items .item .strong_bg {
          text-align: center;
          background-image: url(../img/cast_title.svg);
          background-repeat: no-repeat;
          background-size: 100%;
          display: block;
          width: 70%;
          padding: 10px 0;
          position: absolute;
          z-index: 1;
          left: 15%; }
          @media screen and (max-width: 896px) {
            .contents04 .wrap .items .item .strong_bg {
              width: 90%;
              left: 5%; } }
          .contents04 .wrap .items .item .strong_bg strong {
            font-size: 12px;
            font-weight: 500;
            color: #fff;
            transform: rotate(-2deg);
            display: block;
            margin-top: -6px; }
            @media screen and (max-width: 896px) {
              .contents04 .wrap .items .item .strong_bg strong {
                margin-top: -4px; } }
        .contents04 .wrap .items .item .img {
          margin-bottom: 20px;
          text-align: center; }
          .contents04 .wrap .items .item .img img {
            object-fit: cover;
            width: 100%;
            border: 1px solid #FFD93B; }
        .contents04 .wrap .items .item .name {
          font-size: 16px;
          font-weight: 900;
          color: #fff;
          text-align: center; }
          @media screen and (max-width: 896px) {
            .contents04 .wrap .items .item .name {
              font-size: 16px; } }
          .contents04 .wrap .items .item .name img {
            height: 16px;
            position: relative;
            top: -3px; }

.contents05 {
  padding: 100px 0 75px; }
  @media screen and (max-width: 896px) {
    .contents05 {
      padding: 40px 0 75px; } }
  .contents05 .text_wrap {
    text-align: center;
    width: 100%;
    margin-bottom: 30px; }
    .contents05 .text_wrap strong {
      font-size: 20px;
      font-weight: 700;
      margin-bottom: 10px;
      display: block; }
  .contents05 .wrap {
    max-width: 900px;
    margin: 0 auto; }
    @media screen and (max-width: 896px) {
      .contents05 .wrap {
        padding: 0 20px; } }
    .contents05 .wrap .value {
      margin-bottom: 80px; }
      @media screen and (max-width: 896px) {
        .contents05 .wrap .value {
          margin-bottom: 60px; } }
      .contents05 .wrap .value p {
        font-size: 20px;
        color: #fff; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .value p {
            font-size: 16px; } }
    .contents05 .wrap .details {
      display: flex;
      justify-content: space-between;
      flex-wrap: wrap;
      color: #fff;
      margin-bottom: 60px; }
      @media screen and (max-width: 896px) {
        .contents05 .wrap .details {
          margin-bottom: 40px;
          display: block; } }
      .contents05 .wrap .details dt {
        font-size: 19px;
        margin-bottom: 18px;
        font-weight: bold; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .details dt {
            font-size: 12px;
            margin-bottom: 10px; } }
      .contents05 .wrap .details dd, .contents05 .wrap .details p {
        font-size: 19px;
        margin-bottom: 20px; }
        .contents05 .wrap .details dd .sub, .contents05 .wrap .details p .sub {
          margin: 2px 0 16px; }
          @media screen and (max-width: 896px) {
            .contents05 .wrap .details dd .sub, .contents05 .wrap .details p .sub {
              margin: 2px 0 10px; } }
          .contents05 .wrap .details dd .sub strong, .contents05 .wrap .details p .sub strong {
            font-size: 18px;
            font-weight: bold;
            border: 1px solid #fff;
            padding: 4px 8px; }
            @media screen and (max-width: 896px) {
              .contents05 .wrap .details dd .sub strong, .contents05 .wrap .details p .sub strong {
                font-size: 12px; } }
          .contents05 .wrap .details dd .sub p, .contents05 .wrap .details p .sub p {
            margin-top: 10px; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .details dd, .contents05 .wrap .details p {
            font-size: 12px;
            margin-bottom: 10px; } }
      .contents05 .wrap .details .text a {
        color: #0099FF;
        text-decoration: underline; }
      .contents05 .wrap .details .text.width {
        width: 100%; }
      @media screen and (max-width: 896px) {
        .contents05 .wrap .details .text {
          width: 100%; } }
      .contents05 .wrap .details .btns {
        width: 30%; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .details .btns {
            width: 100%;
            margin: 20px 0 40px; } }
        .contents05 .wrap .details .btns .btn {
          color: #fff;
          background-color: #000;
          font-size: 17px;
          font-weight: bold;
          display: block;
          border-radius: 26px;
          padding: 0 0 0 40px;
          margin-bottom: 15px;
          position: relative;
          height: 55px;
          line-height: 1.2;
          display: flex;
          align-items: center; }
          @media screen and (min-width: 897px) {
            .contents05 .wrap .details .btns .btn:hover {
              opacity: .6; } }
          @media screen and (max-width: 896px) {
            .contents05 .wrap .details .btns .btn {
              font-size: 15px;
              padding: 10px 15px 10px 20px;
              margin-bottom: 15px; } }
          .contents05 .wrap .details .btns .btn img {
            position: absolute;
            right: 20px;
            top: 20px;
            margin: 0 0 0 16px; }
            @media screen and (max-width: 896px) {
              .contents05 .wrap .details .btns .btn img {
                right: 20px;
                top: 20px;
                width: 6px; } }
    .contents05 .wrap .btn_wrap {
      margin: 20px auto 60px; }
    .contents05 .wrap .attention {
      color: #fff;
      background-color: rgba(0, 0, 0, 0.54);
      border: 1px solid #fff;
      padding: 32px 28px 0; }
      @media screen and (max-width: 896px) {
        .contents05 .wrap .attention {
          padding: 15px 20px; } }
      .contents05 .wrap .attention .title {
        font-size: 17px;
        text-align: center;
        margin-bottom: 30px; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .attention .title {
            font-size: 15px;
            margin-bottom: 20px; } }
      .contents05 .wrap .attention .text {
        font-size: 15px;
        margin-bottom: 35px; }
        @media screen and (max-width: 896px) {
          .contents05 .wrap .attention .text {
            font-size: 14px;
            margin-bottom: 20px; } }
        .contents05 .wrap .attention .text strong {
          color: #FF4B4B; }

.contents06 {
  padding: 100px 0 200px;
  max-width: 900px;
  margin: 0 auto; }
  @media screen and (max-width: 896px) {
    .contents06 {
      padding: 40px 20px 120px; } }
  .contents06 .contents_title {
    color: #FFFFFF;
    margin-bottom: 60px; }
    @media screen and (max-width: 896px) {
      .contents06 .contents_title {
        margin-bottom: 50px; } }
  .contents06 .names {
    text-align: center;
    margin-top: 120px; }
    @media screen and (max-width: 896px) {
      .contents06 .names {
        margin-top: 100px; } }
    .contents06 .names dt {
      color: #B9B9B9;
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 10px; }
      @media screen and (max-width: 896px) {
        .contents06 .names dt {
          font-size: 16px; } }
    .contents06 .names dd {
      color: #FFFFFF;
      font-size: 20px;
      font-weight: 700;
      margin-bottom: 90px; }
      @media screen and (max-width: 896px) {
        .contents06 .names dd {
          font-size: 16px;
          margin-bottom: 0; } }
      .contents06 .names dd p {
        text-align: left;
        border: 1px solid;
        padding: 20px; }
      .contents06 .names dd p {
        margin-top: 10px;
        font-size: 0.6em; }
      .contents06 .text strong {
          font-weight: bold;
          color: #FFFFFF}
      .contents06 .text em {
          font-weight: bold;
          color: #b9b9b9}
  .contents06 .text {
    color: #b9b9b9;
    font-size: 20px;
    margin-bottom: 1em; }
    @media screen and (max-width: 896px) {
      .contents06 .text {
        font-size: 16px; } }

        .contents06 {
  padding: 100px 0 100px;
  max-width: 900px;
  margin: 0 auto; }
  @media screen and (max-width: 896px) {
    .contents06 {
      padding: 40px 20px 120px; } }
  .contents06 .contents_title {
    color: #FFFFFF;
    margin-bottom: 60px; }
    @media screen and (max-width: 896px) {
      .contents06 .contents_title {
        margin-bottom: 50px; } }
  .contents06 .names {
    text-align: center;
    margin-top: 120px; }
    @media screen and (max-width: 896px) {
      .contents06 .names {
        margin-top: 100px; } }
    .contents06 .names dt {
      color: #B9B9B9;
      font-size: 16px;
      font-weight: 700;
      margin-bottom: 10px; }
      @media screen and (max-width: 896px) {
        .contents06 .names dt {
          font-size: 16px; } }
    .contents06 .names dd {
      color: #FFFFFF;
      font-size: 20px;
      font-weight: 700;
      margin-bottom: 90px; }
      @media screen and (max-width: 896px) {
        .contents06 .names dd {
          font-size: 16px;
          margin-bottom: 0; } }
      .contents06 .names dd p {
        text-align: left;
        border: 1px solid;
        padding: 20px; }
      .contents06 .names dd p {
        margin-top: 10px;
        font-size: 0.6em; }
      .contents06 .text strong {
          font-weight: bold;
          color: #FFFFFF}
      .contents06 .text em {
          font-weight: bold;
          color: #b9b9b9}
  .contents06 .text {
    color: #b9b9b9;
    font-size: 20px;
    margin-bottom: 1em; }
    @media screen and (max-width: 896px) {
      .contents06 .text {
        font-size: 16px; } }

 .contents07 {
          padding: 100px 0 100px;
          max-width: 900px;
          margin: 0 auto;
        }
        @media screen and (max-width: 896px) {
          .contents07 {
            padding: 40px 20px 120px;
          }
        }
        
        /* セクションタイトル */
        .contents07 .contents_title {
          color: #FFFFFF;
          margin-bottom: 60px;
          text-align: center;
        }
        @media screen and (max-width: 896px) {
          .contents07 .contents_title {
            margin-bottom: 50px;
          }
        }
        
        /* wrap部分 */
        .contents07 .wrap {
          max-width: 900px;
          margin: 0 auto;
        }
        @media screen and (max-width: 896px) {
          .contents07 .wrap {
            padding: 0px;
          }
        }
        
        /* テキスト部分 */
        .contents07 .wrap .text {
          color: #b9b9b9;
          font-size: 20px;
          line-height: 1.8;
          margin-bottom: 1em;
        }
        @media screen and (max-width: 896px) {
          .contents07 .wrap .text {
            font-size: 16px;
          }
        }
        .contents07 .wrap .text p {
          margin-bottom: 1em;
        }
        
        .contents07 .wrap .text strong {
          font-weight: bold;
          color: #FFFFFF}
        /* 見出し（応募方法、キャンペーンハッシュタグ等）のスタイル */
        .contents07 .wrap .text h3 {
          color: #FFFFFF;
          font-size: 24px;
          font-weight: bold;
          margin: 1em 0 0.5em;
        }
        
        /* リストの余白調整 */
        .contents07 .wrap .text ol,
        .contents07 .wrap .text ul {
          margin-left: 20px;
          margin-bottom: 1em;
        }
        .contents07 .wrap .text li {
          margin-bottom: 0.5em;
        }

#footer {
  text-align: center; }
  @media screen and (max-width: 896px) {
    #footer {
      padding: 20px 0 0; } }
  #footer small {
    padding: 10px;
    background-color: #FFD93B;
    color: #000;
    font-size: 16px;
    font-weight: 700;
    display: block;
    width: 100%;
    text-shadow: 0 3px 3px rgba(0, 0, 0, 0.16); }
    @media screen and (max-width: 896px) {
      #footer small {
        font-size: 14px; } }

#loader {
  background-color: #000;
  width: 100%;
  height: 100%;
  position: fixed;
  left: 0;
  top: 0;
  z-index: 999; }
