@charset "UTF-8";
html, body, h1, h2, h3, h4, h5, h6, ul, ol, dl, li, dt, dd, p { margin: 0; padding: 0; font-size: 100%; }
body { line-height: 1; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; font-family: -apple-system, BlinkMacSystemFont, 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', '游ゴシック  Medium', meiryo, sans-serif; }
img { width: 100%; border: 0; virtical-align: bottom; }
ul, ol { list-style: none; }
.clearfix:after { content: "."; display: block; clear: both; height: 0; visibility: hidden; }
.clearfix { min-height: 1px; }
* html .clearfix { height: 1px; }

.bg { background: url(../images/0.png?debug)no-repeat; background-size: 100%; height: 100%; position: fixed; top:0; left: 0; right: 0; bottom:0; z-index: -1; }
.pc {display: none;}
.cont { width: 100%; margin: 0 auto; }
.entry {position: relative; width: 95%; margin: auto;}
.btn { position: absolute; z-index: 999; width: 90%; bottom:8%; left: 5%; }
.ad { background: #FFF; border:2px solid #465493; box-sizing: border-box; width: 95%; margin: 5% auto; }
.ad_title { padding: 3% 0 3% 12%; font-size: 2rem; color: #FFF; background: #465493; position: relative; }
.ad_title .icon { position: absolute; top:10%; left: 1%; width: 10%; z-index: 999; }
.ad_cont { padding: 2%; }
.ad_thum { float: left; width: 30%; border: 2px solid #EEE; box-sizing: border-box; }
.ad_txt { font-size: 14px; width: 70%; padding:0 0 0 2%; color:#333; float: left; line-height: 1.7; box-sizing: border-box; }
.ad_txt h2 { padding: 10px 0; }
.eva { padding: 0 0 0 5%; color: #FFC300; }
.point_color { font-size: 1.2em; color: #465493; }
.chart {}
.chart_in { padding: 1%;  
  width: 50%; float: left; box-sizing: border-box; }
.chart_t { padding: 5% 0; background: #465493; color: #FFF; text-align: center; }
.chart_note { padding: 5%; color: #465493; font-weight: 600; background: #FFF; text-align: center; border:5px solid #465493; }
.ad_entry a { width: 90%; margin: 5% auto 0;  box-shadow: inset 0px 1px 0px 0px #fff6af; background: linear-gradient(to bottom, #ffec64 5%, #ffab23 100%); background-color: #ffec64; border-radius: 6px; border: 1px solid #ffaa22; display: block; cursor: pointer; color: #333333; font-size: 16px; font-weight: bold; padding: 15px 0; text-align: center; text-decoration: none; text-shadow: 0px 1px 0px #ffee66; }
.ad_entry a:hover { background: linear-gradient(to bottom, #ffab23 5%, #ffec64 100%); background-color: #ffab23; }
.ad_entry a:active { position: relative; top: 1px; }
.r_area { line-height: 1.5; padding: 5%; background: #FFF; color: #000; }
.r_area h3 { font-size: 1.3em; margin:0 0 3% 0; text-align: center; border-bottom: 1px dotted #CCC; }
.r_area { padding: 3%;}
.r_area_in { padding: 3%; margin-bottom: 3%; background: rgba(244,244,244,1.00); display: table; }
.r_thum { padding: 5px 0; }
.r_thum_img { width: 20%; padding: 0 2%; float: left; }
.r_thum_name { width: 80%; float: left; padding: 2% 0 0 0; position: relative; }
.r_txt { font-size: 13px; padding: 5px 0; width: 100%; position: relative; }
.r_txt h4 { font-weight: normal; }
.marker { background-color: #ff9; color: #f00; font-weight: bold;}
.r_txt h4 > span { font-weight: normal; padding: 0 0 0 3%; }
.r_txt h4 > span.female { color: #465493; }
.sub_txt { color: #000; font-weight: 600; }
.r_date { position: absolute; top: 2%; right: 0; color: #999; }
.r_txt_title { font-size: 1.2rem; font-weight: bold; color: #465493; }
.r_contents { padding: 1% 0 0 0; }
footer { border-top:2px solid #eee; padding: 2% 0; position:relative; z-index: 9999; background: #FFF; color:#999; }
.link a { text-align: center; display: block; color: #465493; } 
.copy { text-align: center; padding: 10px 0; font-size: 11px; }
.p_c { background: #FFF; padding: 10%; }
.p_c h2 { font-size: 20px; text-align: center; margin: 5% 0; font-weight: normal; }
.policy { font-size: 12px; line-height: 1.8; }
.policy h1 { text-align: center; font-size: 20px; padding: 10px 0; margin-bottom: 20px; border-bottom: 5px solid #F1F1F1; }
.p_in {padding: 7px;}
.policy ul {padding:10px;}
.policy dl {padding:0 0 0 40px;}
.date_txt { padding: 15px 0;  }
#table .table_in .table { overflow: scroll; }
span.txt_scroll { float: right; font-size: 11px; padding-right: 10px; }  
#table .table_in table { table-layout: fixed; width: 180%; background: #fff }
table { border-collapse: collapse; border-spacing: 0; }
#table .table_in th:first-child { background: #F0F8FF; width: 15%; position: relative; }
.triangle { position: absolute; top:0; left:0; border-bottom: 40px solid transparent; border-left: 40px solid #465493; }
.label_txt { position: absolute; top: 8px; left: 2px; font-size: 12px; font-weight: bold; color: #fff; transform: rotate(-45deg); }
#table .table_in th:nth-child(2) { width: 12%; }
#table .table_in th:nth-child(3) { width: 18%; }
#table .table_in th:nth-child(4) { width: 28%; }
#table .table_in th:last-child { width: 10%; }
span.txt_scroll { float: right; font-size: 11px; padding-right: 10px; }
#table .table_in { display: inline-block; margin-left: 0; overflow: unset; width: 100%; padding-top: 5px; padding-bottom: 1px; margin-bottom: 10px; margin-top: 0; padding-left: 5px; padding-right: 5px; }
#table .table_in th { background: #F0F8FF;  font-size: 12px; }
#table .table_in td, #table .table_in th { border: solid 1px #465493; text-align: center; padding: 10px 0; }
#table .table_in tr td:not(.column-1) a { background: #465493; padding: 10px; font-size: 12px; text-align: center; border-radius: 3px; color: #fff; display: inline-block; width: 100%; line-height: 17px; border-bottom: 3px solid #126a35; }
#table .table_in td:nth-child(4) { text-align: left; }
#table .table_in td { border: 1px solid #465493; vertical-align: middle; padding: 0.5em; font-size: 11px; line-height: 16px; }  
.site_name { display: block; padding: 10px 0 0 0; }
.add_table_style_1 { border-collapse: collapse; margin: .6rem; }
.add_table_style_1 thead tr th { text-align: center; font-size: 20px; background: #465493; padding: 15px 0; color: white; border: 0; }
.add_table_style_1 tbody tr td { font-size: 14px; border: 1px solid #465493; background: #F2F2F2; padding: .8rem; text-align: center; width: 33.33%; }
.add_table_style_1__rank__no { position: relative; display: block; margin: auto; }
.add_table_style_2 { text-align: center; }
.add_table_style_2__icon { margin: 0 auto 1.5rem; overflow: hidden; border-radius: 2rem; border: 1px solid #CCC; }
.add_table_style_2 a { display: block; text-decoration: none; color: inherit; }
.add_table_style_2__icon img { max-width: inherit; width: 100%; object-fit: cover; }
.add_table_style_2__name { font-weight: 700; color: #465493; display: block; flex-direction: column; margin-top: 10px; align-items: center; }
.add_table_style_1 tbody tr th { border: 1px solid #465493; background: #465493; color:#FFF; text-align: center; padding: 0.8rem; padding: .8rem; font-weight: bold; }
.add_table_style_1__point.--doublecircle { background: url(../img/state-doublecircle.png) center center / 6.4rem no-repeat; }
.add_table_style_1__point { min-height: 6.4rem; height: 100%; display: flex; justify-content: center; align-items: center; flex-flow: column; list-style: none; margin: 0; padding: 0; }
.add_table_style_1__change { display: flex; list-style: none; justify-content: center; align-items: center; flex-wrap: wrap; margin: 0; padding: 0; }
.add_table_style_1__change { display: flex; list-style: none; justify-content: center; align-items: center; flex-wrap: wrap; margin: 0; padding: 0; }
.add_table_style_1__change > * { width: 33%; text-align: center; }
.c-button--flash::before { position: absolute; content: ""; display: inline-block; top: -180px; left: 0; width: 30px; height: 100%; background-color: #fff; animation: flash 3s ease-in-out infinite; }
.c-button--slim.c-button--blank::after { width: 1.2rem; height: 1.2rem; }
.c-button--blank::after { display: inline-block; content: ""; margin-left: 1rem; background-image: url(../img/icon-blank.png); background-repeat: no-repeat; background-position: center center; background-size: 100%; }
.add_table_style_1 tbody tr td .c-button { line-height: 1.3; }
.sub_note { padding: 10px; line-height: 1.7; }
.sub_note h3 { font-size: 16px; padding: 10px 10px 10px 20px; margin:10px 0; font-weight: bold; background: #EFFAFF; border-radius: 5px; position: relative; }
.sub_note h3::before { content:""; display:block; position: absolute; top:0; left: 0;  background: #BAE0FF; width: 5px; height: 100%; border-radius: 5px; } 
.sub_note p { font-size: 14px; padding:10px; }
.cta { width: 90%; margin: 5% auto; background: #FFFDF3; padding: 2%; border:1px solid #CCC; }
.cta_btn { width: 90%; margin: 5% auto; box-shadow:inset 0px 1px 0px 0px #d9fbbe; background:linear-gradient(to bottom, #b8e356 5%, #a5cc52 100%); background-color:#b8e356; border-radius:6px; border:1px solid #83c41a; display:block; cursor:pointer; color:#ffffff; font-family:Arial; font-size:15px; font-weight:bold; padding:15px 0; text-decoration:none; text-shadow:0px 1px 0px #86ae47; text-align: center; font-size: 20px; position: relative;  overflow: hidden; }
.cta_btn:hover { background:linear-gradient(to bottom, #a5cc52 5%, #b8e356 100%); background-color:#a5cc52; }
.cta_btn:active { position:relative; top:1px; }  
.entry_wrap { background: #FEF5FF; border:1px solid #F93CFF; padding: 5% !important; margin: 5% 0; }
.shop_table_data { color: #4c4c4c; font-size: .8rem; padding: 2% 0; }
.shop_table_data table { border:1px solid #CCC; width: 100%; }
.shop_table_data tr { border:1px solid #CCC !important; }
.shop_table_data th,.shop_table_data td { padding: 10px; background: #FFF; border:1px solid #CCC; }
.shop_table_data th { font-weight: bold; background: #F1F8FF; vertical-align: middle; }
.shop_table_data th i {padding: 0 10px 0 0;}
.shop_table_data td { background: #FFF; }
  @keyframes shiny { 
    0% {   transform: scale(0) rotate(25deg);   opacity: 0; }
    50% {   transform: scale(1) rotate(25deg);   opacity: 1; }
    100% {   transform: scale(50) rotate(25deg);   opacity: 0; }
  }
.cta_btn::after { content: ''; position: absolute; top: -100px; left: -100px; width: 50px; height: 50px; background-image: linear-gradient(100deg, rgba(255, 255, 255, 0) 10%, rgba(255, 255, 255, 1) 100%, rgba(255, 255, 255, 0) 0%);
  animation-name: shiny; animation-duration: 3s; animation-timing-function: ease-in-out; animation-iteration-count: infinite; }  
.shop_category span { font-size: .8rem; padding: 5px 15px; margin: 10px 5px 5px 0; text-align: center; border:1px solid #00bcb5; border-radius: 60px; background: #FFF; }
.shop_category span { float: left;}
.shop_category::after { content:""; display: block; clear: both; }
.fv_txt_wrap { background: #FBFFF0; padding: 3%; line-height: 1.5; }
.fv_txt_wrap2 { text-align: center; position: relative; margin-top: 5%; background: linear-gradient(0deg, rgba(25,64,112,1) 0%, rgba(72,126,164,1) 100%); padding: 15px 0; color: #FFF; }
.fv_txt_wrap2 span { display: block; width: 90%; background: #FFF; color: #465493; border:1px solid #CCC; padding: 2%; border-radius: 5px; font-weight: bold; position: absolute; top:-20%; left: 5%; }
.fv_txt_wrap2 h2 { padding: 4% 0 0 0; }
.fv_txt_wrap2 h2 b { display: block; font-size: 2rem; }
.fv_txt_wrap2 p { padding: 2% 0 0 0; }
/* ///////////////////////////////////////////////////////////////////// */
@media screen and (min-width: 480px) { 
	#wrap { width: 650px; overflow: hidden; 	margin: 0 auto; }    
  .sp {display: none;}
  .pc {display: block;}
  .bg { width: 375px; left: inherit; right: inherit; }
}
@media (max-width: 480px) { 
  #table .table_in {; display: inline-block; margin-left: 10px; overflow: scroll; width: calc(100% - 20px); -webkit-overflow-scrolling: touch; }
}  
/* 追加2025/01/28 */
.cont_sub { margin: 15px; border: 1px solid #EEE; }
.cont_sub h1 div { padding: 10px 20px; }
.marker_txt { background: #FFF7BA; font-weight: bold; }
.main_title { font-size: 30px; padding: 10px 0; font-weight: bold; line-height: 1.5; color: #010079; border-left: 5px solid #010079; text-shadow: 0 0 5px white;  padding: 0.3em 0.5em;  background: -webkit-repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px,#e9f4ff 3px, #e9f4ff 7px); background: repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px,#e9f4ff 3px, #e9f4ff 7px); margin-bottom: 10px; }
.main_txt { font-size: 18px; padding:10px 0; line-height: 1.5; }
@media (max-width: 480px) { 
  .main_title { font-size: 18px;}
}
/* 追加2025/01/28 */
.cont_sub { margin: 15px; border: 1px solid #EEE; }
.cont_sub h1 div { padding: 10px 20px; }
.marker_txt { background: #FFF7BA; font-weight: bold; }
.main_title { font-size: 30px; padding: 10px 0; font-weight: bold; line-height: 1.5; color: #010079; border-left: 5px solid #010079; text-shadow: 0 0 5px white;  padding: 0.3em 0.5em;  background: -webkit-repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px,#e9f4ff 3px, #e9f4ff 7px); background: repeating-linear-gradient(-45deg, #cce7ff, #cce7ff 3px,#e9f4ff 3px, #e9f4ff 7px); margin-bottom: 10px; }
.main_txt { font-size: 18px; padding:10px 0; line-height: 1.5; }
.ad p { padding: 10px; }
@media (max-width: 480px) { 
  .main_title { font-size: 18px;}
  .add_table_style_2__icon { border-radius: 10px; margin: 10px auto; }
  .add_table_style_1 tbody tr:last-child td { padding: 10px; }
  .ad_entry a { font-size: 12px; }
  .ad_txt::after { content:""; display: block; clear: both; }
  .ad .cta_btn { width: 95%; margin: 5px auto; } 
  .ad_thum { width: 100%; margin: auto; float: none;  }
  .ad_txt { width: 100%; }
  .point_color { font-size: 14px; line-height: 1.6; }
  .ad_title { font-size: 16px; }
  .r_txt_title { font-size: 14px; }
  .r_thum_name { font-size: 12px; }
  
}  