 @charset "UTF-8";

@media print{body{display:none;}}

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,p,th,td,img,form,hr{margin:0;padding:0;border:0;font-style:normal;font-weight:normal;text-align:left;word-break:break-all;}
table{border-collapse:collapse;border-spacing:0;font-size:100%;}
th,td{border-collapse: collapse;}
ol,ul{list-style:none;}
h1,h2,h3,h4,h5,h6{font-size:100%;line-height:100%;font-weight:normal;word-wrap:break-word;}
sup{vertical-align:text-top;}
sub{vertical-align:text-bottom;}

/*------------------------------------------------------
 Base 
------------------------------------------------------*/
body{
    color: #fff;
    width: 100%;
    font-size: 1.7rem;
    line-height: 1.6;
    -webkit-text-size-adjust: 100%;
    font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif;
    background-color: #fff;
  }
  
  h1 {
    font-size: 2em;
  }
  
  h2 {
    font-size: 1.5em;
  }
  
  h3 {
    font-size: 1.17em;
  }
  
  h4 {
    font-size: 1.08em;
  }
  
  h5 {
    font-size: .83em;
  }
  
  h6 {
    font-size: .75em;
  }
  
  h1, h2, h3, h4, h5, h6 {
    font-weight: bold;
    line-height: 1.4;
  }
  
  img{
    width: 100%;
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }
 .photo__wrap{
  text-align: center;
 }

  /* link */
  a:link { text-decoration:none; color:#0066cc; }
  a:visited { text-decoration:none; color:#0066cc; }
  a:hover { text-decoration:none; color:#0066cc; }
  a:active { text-decoration:none; color:#0066cc; }
  
  /* clearfix */
  .clearfix:before,
  .clearfix:after {
    content: '';
    display: table;
  }
  
  .clearfix:after {
    clear: both;
  }
  
  /* For IE 6/7 only */
  .clearfix {
    *zoom: 1;
  }

  /*.pc{}*/
  .pc{ display:block;}
  .sp{ display:none;}
  .cx_smartphoneview .pc{ display:none;}
  .cx_smartphoneview .sp{ display:block;}
  
/*------------------------------------------------------------
  
　メインビジュアル

------------------------------------------------------------*/

#c-header .fv {
  background: repeat-y center top url(../image/fv_bg.jpg);
  background-size: 100%;
}
#c-header .ttl-logo{
  margin: 0 auto;
  width: 68%;
  max-width: 300px;
}
@media screen and (max-width: 768px) {
  #c-header .ttl-logo{
    max-width: 180px;
  }
}
#c-header .fv img{
  width: 100%;
  text-align: center;
}
#c-header h1 {
  display: none;
}

/*------------------------------------------------------------
  
　ナビゲージョンエリア

------------------------------------------------------------*/
#navi{
  padding: 0 24px;
  background: #000;
}
#navi ul{
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
#navi .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
#navi .navi-area-wrap {
  padding: 24px 0;
}
#navi .navi-area-wrap li {
  width: 16.35%;
  padding-right: 1rem;
}
#navi .navi-area-wrap li:last-of-type {
  padding-right: 0;
}
#navi .navi-area-wrap li a img:hover{
  position: relative; 
  top: 3px; 
  left: 3px; 
  transition: .6s;
  -webkit-transition: .6s;
  -ms-transition: .6s;
}
@media screen and (max-width: 1000px) {
  #navi .navi-area-wrap li  {
    width: 20.35%
  }
}
@media screen and (max-width: 768px) {
  #navi{
    padding: 0 4%;
  }
  #navi .navi-area-wrap {
    padding: 15px 0;
  }
  /*#navi .navi-area-wrap li {
    width: 30.35%;
  }
  #navi .navi-area-wrap li:last-child {
    padding-right: 0;
  }*/
  #navi .navi-area-wrap li {
    width: 48.35%;
  }
  #navi .navi-area-wrap li:nth-child(even) {
    padding-right: 0;
  }
  #navi .navi-area-wrap li:nth-child(-n + 2) {
    margin-bottom: 1rem;
  }
}

/*------------------------------------------------------------
  
　お知らせ

------------------------------------------------------------*/

/*-------------- 共通 -------------*/
.bg-image {
  background-size: 100%;
  background-repeat: repeat;
  background-position: center top;
  background: url(/the-second/image/bg.jpg),#1b018d;
}
.bg-color{
  background: #000;
}

.l-main {
  padding: 50px 30px;
}
@media screen and (max-width: 1000px) {
  .l-main {
      padding: 50px 5%;
  }
}
.l-content-wrap{
  max-width: 1000px;
  margin: 0 auto;
}

/*------------------------------------------  
　　キャンペーン 
-----------------------------------------  */
.campaign_cantainer{
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  box-sizing: border-box;
}
/*-------------- メンバー -------------*/
.member_contents{
  padding: 60px 30px 80px;
  background: url(../image/bg_1.jpg);
  background-size: 100%;
  background-repeat: repeat-y;
}
.member_catch{
  font-size: 2.8rem;
  font-weight: bold;
  text-align: center;
  margin-bottom: 40px;
  line-height: 1.5;
  padding: 15px 10px;
  background: rgb(28 3 142 / 75%);
}
.member_wrap{
  padding: 0 40px;
  margin-bottom: 30px;
}
.member_wrap:last-child{
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .member_contents{
    padding: 20px 3% 40px;
  }
  .member_catch{
    font-size: 2rem;
    margin-bottom: 20px;
    padding: 10px 3%;
  }
  .member_wrap {
    padding: 0 3%;
    margin-bottom: 20px;
  }
}
/*-------------- プレゼント -------------*/
.present_contents{
  padding: 60px 30px 80px;
  background: url(../image/bg_2.jpg);
  background-size: 100%;
  background-repeat: repeat-y;
}
.present_title{
  margin-bottom: 40px;
}
.present_item{
  text-align: center;
  margin-bottom: 60px;
}
.present_item:last-child{
  margin-bottom: 30px;
}
.present_btn{
  display: flex;
  justify-content: center;
  align-items: center;
  background: #03708e;
  padding: 10px 10px;
  border-radius: 30px;
}
.present_btn:hover{
  background-color: #004152;
}
.present_btn p{
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  padding-right: 6px;
}
.present_btn .icon{
  width: 32px;
}
@media screen and (max-width: 768px) {
  .present_contents {
    padding: 20px 3% 40px;
  }
  .present_title {
    margin-bottom: 20px;
  }
  .present_wrap{
    padding: 0 3%;
  }
  .present_item {
    margin-bottom: 25px;
  }
  .present_btn {
    margin: 0 3%;
    padding: 5px;
  }
  .present_btn p {
    font-size: 14px;
    text-align: center;
  }
  .present_btn .icon {
    width: 10%;
  }
}
/*-------------- 応募方法 -------------*/
.apply_contents{
  background: #000;
  padding: 60px 30px 40px;
}
.apply_title{
  font-size: 72px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 30px;
}
.apply_wrap{
  color: #000;
  background: #fff;
  padding: 30px 30px 60px;
}
.apply_block{
  margin-bottom: 60px;
}
.apply_block:nth-child(3){
  margin-bottom: 30px;
}
.apply_block:last-child{
  margin-bottom: 0;
}
.apply_word{
  font-weight: bold;
  font-size: 25px;
}
.apply_note{
  font-size: 18px;
  text-indent: -0.5em;
  padding-left: 0.5em;
  margin: 1% 0 1% 0;
}
.twitter_btn,
.apply_btn{
  background: #000;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 30px 60px 0;
  border-radius: 10px;
}
.twitter_btn:hover,
.apply_btn:hover{
  opacity: 0.5;
}
.twitter_btn p,
.apply_btn p {
  width: 100%;
  text-align: center;
  color: #fff;
  font-size: 32px;
  padding: 6px;
  position: relative;
  display: inline-block;
}

.twitter_btn p::before,
.twitter_btn p::after ,
.apply_btn p::after {
  display: inline-block;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  position: absolute;
  vertical-align: middle;
}

.twitter_btn p::before {
  background-image: url('../image/left-icon.png'); /* 左側アイコンの画像パス */
  margin-right: 8px;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 54px;
    height: 54px;
}

.twitter_btn p::after,
.apply_btn p::after {
  width: 24px;
  height: 24px;
  background-image: url('../image/right-icon.png'); /* 右側アイコンの画像パス */
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 768px) {
  .apply_contents {
    padding: 20px 6% 20px;
  }
  .apply_title {
    font-size: 32px;
    margin-bottom: 20px;
  }
  .apply_wrap {
    padding: 20px 6% 40px;
  }
  .apply_word {
    font-size: 18px;
  }
  .apply_note {
    font-size: 14px;
  }
  .twitter_btn, .apply_btn {
    margin: 20px 0 0;
  }
  .twitter_btn p, .apply_btn p {
    font-size: 18px;
    padding: 6% 3%;
  }
  .apply_block {
    margin-bottom: 40px;
  }
  .apply_block:nth-child(3) {
    margin-bottom: 20px;
  }
}

/*-------------- 現在の大予想ランキング -------------*/
.prediction_contents{
  padding: 60px 30px 80px;
  background: url(../image/bg_1.jpg);
  background-size: 100%;
  background-repeat: repeat-y;
}
.prediction_subtitle{
  margin-top: 30px;
  margin-bottom: 40px;
}
.p-member_wrap{
  display: grid;
  grid-template-columns: 1fr 2fr;
  padding: 0 40px 0 0;
  margin: 30px 0 40px;
}
.member_box_inner{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
}
.member_box_inner .icon-wrap{
  margin-bottom: 5px;
}
.member_box_1 .photo-wrap{
  border: 5px solid;
    border-image: linear-gradient(to bottom, #c4a600 0%, #fff5b4 40%, #fff5b4 60%, #c4a600 100%);
    border-image-slice: 1;
}
.member_box_2 .photo-wrap{
  border: 5px solid;
    border-image: linear-gradient(to bottom, #6a7a85 0%, #d4cfc9 40%, #d4cfc9 60%, #6a7a85 100%);
    border-image-slice: 1;
}
.r-container{
  position: relative;
  width: 100%;
  max-width: 540px;
  margin: 40px auto 40px;
  padding-top: 80px;
}
.r-container .background-img{
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: auto;
  display: block;
}
.r-container .fixed-img{
  position: absolute;
  top: 20%;
  left: 30%;
  z-index: 10;
  width: 100%;
  max-width: 65%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .prediction_contents {
    padding: 20px 6% 40px;
  }
  .prediction_subtitle {
    padding: 0;
    margin-top: 30px;
    margin-bottom: 0;
  }
  .p-member_wrap {
    padding: 0;
    margin: 15px 0;
  }
  .member_box_inner {
    gap: 10px;
  }
  .r-container {
    margin: 20px auto 20px;
    padding-top: 45px;
}
  .r-container .fixed-img {
    top: 20%;
    left: 30%;
    max-width: 65%;
  }
}
/*------------------------------

   バナー 

------------------------------*/
.archive h5{
  font-size: 4.2rem;
  font-weight: 900;
  border-bottom: 1px solid #fff;
  margin-bottom: 20px;
}
.archive .list{
  display: flex;
  gap: 15px;
  /* gap: 5px; */
  flex-wrap: wrap;
  justify-content: center;
}
.archive .item{
  /* width: 16%; */
  width: 46%;
  display: block;
}
.archive .item a{
  position: relative;
  display: block;
  /* padding: 15px 0; */
  padding: 25px 0;
  /* font-size: 15px; */
  font-size: 22px;
  text-align: center;
  letter-spacing: .1em;
  border: 1px solid #cacaca;
  color: #cacaca;
}
.archive .item a:hover{
  background: rgba(255, 255, 255, 0.25);
}
.archive .item a::after {
  position: absolute;
  right: -1px;
  bottom: -11px;
  content: "";
  border-top: 20px solid rgba(0, 0, 0, 0);
  border-bottom: 20px solid rgba(0, 0, 0, 0);
  border-left: 20px solid #cacaca;
  transform: rotate(45deg);
}
.article-container a{
  color: #fff !important;
  text-decoration: underline !important;
}
@media screen and (max-width: 768px) {
  .archive h5{
    font-size: 3.2rem;
  }
  .archive .list{
    gap: 10px;
    justify-content: center;
  }
  .archive .item{
    width: 48%;
  }
  .archive .item a{
    padding: 15px 0;
    font-size: 15px;
    font-size: 16px;
  }
  .archive .item a::after {
    right: 0px;
    bottom: -5px;
    border-top: 10px solid rgba(0, 0, 0, 0);
    border-bottom: 10px solid rgba(0, 0, 0, 0);
    border-left: 10px solid #cacaca;
  }
}