@charset "utf-8";
/*-------------------------------------------------------------------
    * site name : チャンスイットスマホ TOP
    * description : スマホサイトのTOPページ
    * LastUpdate : 2024/06/18 m-ido
-------------------------------------------------------------------*/

/* ----------------------------見出し */

h1 {
    border-bottom: 1px solid #bebebe;
    font-size: 17px;
    font-weight: bold;
    text-align: left;
    padding: 2px 0 2px 10px;
}
h2 {
    font-size: 17px;
    font-weight: bold;
    text-align: left;
    padding: 2px 0 5px 10px;
    background: #fff;
}
.sub_title {
    padding: 6px 10px;
    border-bottom: none;
    background: #F3F2F2;
    font-weight: bold;
    font-size: 14px;
    text-align: left;
}
a {
    color: #555;
    text-decoration: none;
}

/*コインアイコン表示*/
.point .ci-point,
.point del{
    background-image: url("../img/base/icon_point.png");
    background-repeat: no-repeat;
    background-position: 0 center;
    -webkit-background-size: 12px 12px;
    -moz-background-size: 12px 12px;
    background-size: 12px 12px;
    padding:0 0 0 13px;
}

/*アイコン表示*/
.tit_shop {
    background: url(../img/icon/title/ico_shop.png) no-repeat 0 -2px;
    background-size: 32px auto;
}
.tit_first_month {
    background: url(../img/icon/title/ico_free.png) no-repeat 0 -4px;
    background-size: 32px auto;
}
.tit_repeat_ok {
    background: url(../img/icon/title/ico_repeat.png) no-repeat 0 -4px;
    background-size: 32px auto;
}
.tit_pointnews {
    background: url(../img/icon/title/ico_point_news.png) no-repeat 0 -2px;
    background-size: 32px auto;
}
.tit_catnews,
.tit_dognews,
.tit_benessenews,
.tit_cinemanews {
    background: url(../img/icon/title/ico_cinema.png) no-repeat 0 -2px;
    background-size: 32px auto;
}

/* スワイプ */
.swipe {
    overflow-y: hidden;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    background: #fdf4e7;
}

/* ---------------------------------------未ログイン時 */
#top_image img {
    width:100%;
    height:auto;
    vertical-align:bottom;
}
#top_image h1 {
    border:0;
    padding:0;
}
.top_btn {
    padding: 5px 20px 0;
}
.top_btn a {
    padding: 10px 0;
    margin-bottom: 10px;
    display: block;
    border-radius: 10px;
    color: #fff;
    font-weight: bold;
    font-size: 18px;
    line-height: 1.5;
}
.top_btn a.regist {
    background: #3DBA8F;
    border-bottom: 3px solid #268262;
}
.top_btn a.beginner {
    background: #FFB21C;
    border-bottom: 3px solid #D17A0A;
}

/* ---------------------------------------1行お知らせ枠 */
.information {
    margin: 8px 10px;
    position: relative;
}
.information a {
    display: block;
    padding: 5px 8px;
    background: #f7f7f7;
    border-radius: 5px;
    border: 1px solid #bebebe;
    text-align: left;
    text-decoration: none;
    color: #555;
}
.information a:after {
    content: "";
    width: 7px;
    height: 7px;
    display: block;
    position: absolute;
    top: 13px;
    right: 10px;
    border-top: 1px solid #555555;
    border-right: 1px solid #555555;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.latest_info {
    margin-bottom: 20px;
    border-top: 1px solid #d4d4d4; 
    border-bottom: 1px solid #d4d4d4;
    text-align: left;
}
.latest_info a {
    display: block;
    padding: 10px;
    text-decoration: none;
    color: #555;
}

/* -----------------初心者ビンゴ */
div.bingo {
    margin: 10px 10px 0;
}
div.bingo img {
    width: 100%;
}

/* ---------------------おすすめポイント案件 */

section.point_info {
    margin: 20px 0 40px;
    background: #FDF4E7;
}
section.point_info ul {
    overflow: hidden;
    margin: 10px 5px 0;
}
section.point_info ul li {
    padding: 0 5px 10px;
    box-sizing: border-box;
    float: left;
    width: calc( 100% / 3);
}
section.point_info li a {
    display: block;
    padding: 10px 6px;
    background: #fff;
    border-radius: 5px;
    box-shadow: 0px 1px 3px #cec4b9;
    text-align: center;
}
section.point_info li .img {
    position: relative;
    height: 80px;
    margin-bottom: 10px;
}
section.point_info li .img img {
    max-width: 80px;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}
section.point_info li .title {
    padding: 0;
    font-size: 12px;
    text-decoration:none;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}
section.point_info li p {
    font-size: 12px;
    color: #333;
}
section.point_info li .point_wrap {
    position: relative;
    height: 35px;
}
section.point_info li .point {
}
section.point_info li .point .ci-point {
    font-size: 14px;
    font-weight: bold;
    color: #f55;
}
.point_info .more {
    position: relative;
    display: block;
    padding: 10px 20px;
    text-align: right;
    border-bottom: 1px solid #d4d4d4;
    background: #fff;
}
.point_info .more::after {
     position: absolute;
     content: '';
     width: 6px;
     height: 6px;
     border-top: solid 2px #ffb359;
     border-right: solid 2px #ffb359;
     -webkit-transform: rotate(45deg);
     transform: rotate(45deg);
     top: 50%;
     right: 10px;
     margin-top: -3px;
}

/* -----------最新セール＆キャンペーン情報 */
section.sale_info {
    margin: 20px 0;
}
section.sale_info h2 {
    border-bottom: 1px solid #d4d4d4;
}
section.sale_info ul a {
    position: relative;
    display: block;
    padding: 10px 20px;
    text-align: left;
    border-bottom: 1px solid #d4d4d4;
}
section.sale_info ul a {
    padding: 10px 0 10px 30px;
    background-image: url(../img/top/ico_star.gif);
    background-repeat: no-repeat;
    background-position: 10px center;
    background-size: 12px auto;
    text-decoration: underline;
    color: #0c90ff;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}
section.sale_info .teiban {
    display: block;
    margin: 20px 0;
}
section.sale_info .teiban img {
    width: 100%;
}

/* ----------------------------毎日タップ枠 */
section.everyday_tap {
    margin-bottom: 20px;
}
section.everyday_tap ul {
    padding: 20px 10px 0;
    overflow: hidden;
    background: #fdf4e7;
}
section.everyday_tap li {
    float: left;
    width: 49%;
    position: relative;
    margin-bottom: 20px;
    background: #fff;
    border-radius: 5px;
    box-sizing: border-box;
    box-shadow: 0px 1px 3px #cec4b9;
    text-align: center;
}
section.everyday_tap li:nth-child(2n) {
    float: right;
}
section.everyday_tap li a {
    display: block;
    text-decoration: none;
}
section.everyday_tap li .img {
    height: 90px;
    position: relative;
    line-height: 0;
    padding-top: 10px;
}
section.everyday_tap li .img img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}
section.everyday_tap li .txt-box p.title {
    padding: 0 10px;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    background: none;
    font-size: 13px;
    font-weight: bold;
    color: #04c;
}
section.everyday_tap li .txt-box .summary-txt {
    margin: 7px 0 0;
    color: #555;
}
section.everyday_tap li .txt-box p {
    font-size: 12px;
    color: #333;
}
section.everyday_tap .txt-box .point {
    min-height: 40px;
    margin: 3px 0 0;
    line-height: 1.3;
}

section.everyday_tap li .txt-box .point .ci-point {
    font-size: 16px;
    font-weight: bold;
    color: #f55;
}
section.everyday_tap li .txt-box .point del {
    margin: 0 2px 0 0;
    text-decoration: line-through;
    color: #333;
    font-size: 11px;
}
section.everyday_tap li .txt-box .point ins {
    display: block;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
    color: #f55;
}
section.everyday_tap li a.detail_link {
    padding: 7px 0;
    position: relative;
    background: #eee;
    color: #555;
    font-size: 11px;
}

/* アイコン */
.everyday_tap .icon_tap {
    width: 46px;
    height: 46px;
    vertical-align: middle;
    display: inline-block;
    position: absolute;
    top: -4px;
    left: -4px;
    background-color: #FF695E;
    -webkit-border-radius: 50%;
    border-radius: 50%;
    cursor: pointer;
    font-size: 13px;
    font-weight: bold;
    line-height: 1.0;
    text-align: center;
    color: #fff;
}
.everyday_tap .icon_tap p {
    width: 100%;
    position:absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    -moz-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
}
.tada {
    -webkit-animation-name: tada;
    animation-name: tada;
    -webkit-animation-duration: 2s;
    animation-duration: 2s;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-animation-delay: 1s;
    animation-delay: 1s;
}

@-webkit-keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%, 20% {
    -webkit-transform: scale3d(.8, .8, .8) rotate3d(0, 0, 1, -10deg);
    transform: scale3d(.8, .8, .8) rotate3d(0, 0, 1, -10deg);
  }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 10deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 10deg);
  }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.2, 1.1) rotate3d(0, 0, 1, -10deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -10deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

@keyframes tada {
  from {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }

  10%, 20% {
    -webkit-transform: scale3d(.8, .8, .8) rotate3d(0, 0, 1, -10deg);
    transform: scale3d(.8, .8, .8) rotate3d(0, 0, 1, -10deg);
  }

  30%, 50%, 70%, 90% {
    -webkit-transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 10deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 10deg);
  }

  40%, 60%, 80% {
    -webkit-transform: scale3d(1.1, 1.2, 1.1) rotate3d(0, 0, 1, -10deg);
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -10deg);
  }

  to {
    -webkit-transform: scale3d(1, 1, 1);
    transform: scale3d(1, 1, 1);
  }
}

/* リピートアイコン */
.everyday_tap .icon_repeat,
.ad-list .icon_repeat{
    position:absolute;
    -webkit-transform: rotate( -45deg );
    transform: rotate( -45deg );
}
.everyday_tap .icon_repeat p,
.ad-list .icon_repeat p{
    font-size:10px;
    width:42px;
    position:absolute;
    line-height:11px;
    font-weight:bold;
    color:#fff;
    right:-21px;
}
.everyday_tap .icon_repeat{
    bottom:-30px;
    right:-30px;
    border: 30px solid transparent;
    border-top: 30px solid #ffab47;

}
.everyday_tap .icon_repeat p{
    bottom:7px;
}
.ad-list .icon_repeat{
    bottom:-36px;
    right:-36px;
    text-align:center;
    border: 36px solid transparent;
    border-top: 36px solid #ffab47;
}
.ad-list .icon_repeat p{
    bottom:10px;
    font-weight:bold;
}

/* ショップアイコン */
.point_info .shop_point{
    text-align:center;
    background:#f4f4f4;
    border:#bfbfbf solid 1px;
    border-radius:2px;
    font-size:10px;
    color:#5d5d5d;
    padding:3px 0 2px;
    margin:2px 0 0;
}
.point_info .t_point{
    padding:3px 0 2px 10px;
    background-image:url(../img/base/icon_t.gif);
    background-repeat:no-repeat;
    background-size:9px 9px;
    background-position:10px 3px;
}

/* --------------------最新の懸賞情報 */
.latest_present {
    margin-bottom: 20px;
    padding-bottom: 20px;
    background: #fdf4e7;
}
.latest_present h2 {
    background: #fff;
}
.latest_present > ul {
    margin: 10px 5px 0;
    overflow: hidden;
}
.latest_present > ul li {
    padding: 0 5px 10px;
    box-sizing: border-box;
    float: left;
    width: calc( 100% / 3);
}
.latest_present > ul li a {
    display: block;
    padding: 10px;
    background: #fff;
    border-radius: 5px;
    box-shadow: 0px 1px 3px #cec4b9;
    text-align: center;
}
.latest_present li img {
    width: 100%;
}
.latest_present li h3 {
    font-size: 14px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.latest_present .winner {
    color: #f55;
    font-weight: bold;
}
.latest_present .more {
    position: relative;
    display: block;
    padding: 10px 20px;
    text-align: right;
    border-bottom: 1px solid #d4d4d4;
    background: #fff;
}
.latest_present .more::after {
     position: absolute;
     content: '';
     width: 6px;
     height: 6px;
     border-top: solid 2px #ffb359;
     border-right: solid 2px #ffb359;
     -webkit-transform: rotate(45deg);
     transform: rotate(45deg);
     top: 50%;
     right: 10px;
     margin-top: -3px;
}

/* -----------------読むだけでポイント貯まる */
section.pointnews {
    margin: 30px 0;
    background: #fdf4e7;
}
.pointnews h2{
    padding: 0;
}
.pointnews h2 img{
    width: 100%;
}
.pointnews ul {
    overflow: hidden;
    padding: 0 10px 10px;
}
.pointnews ul li {
    width: calc(100%/3);
    float: left;
}
.pointnews ul li a {
    display: block;
    padding: 10px;
    text-decoration: none;
    position: relative;
}
.pointnews img {
    width: 100%;
}
.pointnews .point {
    line-height: 1.3;
}
.pointnews span {
    color: #f55;
    font-weight: bold;
    font-size: 18px;
}

/* ポイントGET */
.pointnews ul li .point_get {
    background: url(../img/pointnews/stamp_get.png) no-repeat;
    background-size: 33px;
    width: 33px;
    height: 33px;
    position: absolute;
    top: 4px;
    left: 4px;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
}

/* もっと見る */
section.pointnews .loading {
    background: #fff;
    color: #555;
    display: block;
    box-shadow: 0px 1px 3px #cec4b9;
    border-radius: 5px;
    padding: 8px 0;
    margin: 0 50px 10px;
}

/* ----------特集＆キャンペーン */
.special ul {
    padding: 10px 5px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}
.special li {
    width: calc(100%/3);
    display: inline-block;
}
.special li a {
    display: block;
    padding: 0 5px 5px;
    text-decoration: none;
    position: relative;
}
.special li img{
    width: 100%;
}


/* -----------------SNSアイコン */
.sns_link {
    margin: 20px 0 30px;
}
.sns_link ul {
    padding: 10px 5% 0;
    display: flex;
    justify-content: center;
}
.sns_link li img {
    margin: 0 10px;
    width: 60px;
}

/* -----------------ご意見 */
.opinion{
    margin-bottom: 20px;
}
.opinion p {
    margin-bottom: 5px;
}
.opinion a {
    display: block;
    padding: 10px 0;
    margin: 0 20px;
    border-radius: 5px;
    background: #e5e5e5;
    color: #555;
    font-weight: bold;
    font-size: 17px;
}


/* ----------------------------スペシャルタイムセール */
.special_timesale a {
    display:block;
    text-decoration:none;
    margin:10px;
    padding:8px 0 7px 0;
    color:#ffffff;
    background-color:#de0c1a;
    border-radius: 8px;
    box-shadow: 0px 1px 3px #cec4b9;
}
.special_timesale h1 {
    border-bottom: none;
font-size: 17px;
font-weight: bold;
text-align: center;
padding: 0;
}
.special_timesale h1 img {display:block;}
.special_timesale .bnr_area {
    background: url(../img/top/bg_specilal_timesale_coin.png) no-repeat 0 20px;
    background-size: 100% auto;
    padding:8px 0;
}
.special_timesale .bnr_area img {
    display:block;
    margin:0 auto;
    width:55%;
    height:auto;
    border:2px solid #de0817;
}
.special_timesale .detail { padding:10px 10px 0 10px;}
.special_timesale .detail h2 {
    line-height: 1.3;
    font-size: 14px;
    font-weight:bold;
    margin-bottom: 3px;
    border-bottom: none;
    text-align: center;
    padding:0;
    background: transparent;
}
.special_timesale .detail ins {
    display: block;
    font-weight: bold;
    font-size: 40px;
    text-decoration: none;
    text-align: center;
    color: #fff959;
    text-shadow:0px 1px 2px #9e0000;
    line-height: 1.2;
}
.special_timesale .detail del {
    margin-bottom: 5px;
    background: url(../img/top/ico_coin_s.png) no-repeat 0px 2px;
    background-size: 12px 12px;
    padding: 0 0 0 18px;
}
.special_timesale .countdown {
    margin:10px 10px 7px 10px;
    padding:6px 5px 6px 5px;
    background-color:#ffffff;
    text-align:center;
    color:#de0c1a;
    border-radius:3px;
    line-height: 1;
}
.special_timesale .countdown span {
    font-size:20px;
    margin: 0 3px 0 5px;
    display:inline-block;
}
.special_timesale p.text { font-size:10px;}


/* ------------------モーダル広告枠 */
.modal_ad_inner {
    padding: 10px 20px 20px;
    margin: 30px 20px 0;
    text-align: center;
    position: relative;
    background: #f3edb7;
    border-radius: 5px;
}
.modal_ad .titile img {
    width: 90%;
}
.modal_ad .name {
    font-size: 15px;
    font-weight: bold;
    margin: 10px 0;
}
.modal_ad .detail_box {
    display: flex;
    width: 100%;
    gap: 0 10px;
}
.modal_ad .detail_box .bnr {
    width: 40%;
}
.modal_ad .detail_box .bnr img {
    width: 100%;
}
.modal_ad .detail_box .bnr_txt {
    text-align: left;
    width: 60%;
}
.modal_ad .point {
    font-size: 30px;
    font-weight: bold;
    color: #ff5555;
}
.modal_ad .btn {
    width: 100%;
    padding: 10px 0;
    font-size: 15px;
    background: #ff5555;
    color: #fff;
    border-radius: 5px;
}
