@charset "utf-8";

/*--------------------------------------
CONTENTS
--------------------------------------*/
html{
  box-sizing: border-box;
}
img {
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
#tccp_narita_202512 {
  max-width:704px;
  margin:0 auto 50px;
  line-height:1.8em;
  box-sizing: border-box;
}
a img:hover{
  opacity: .7;
}
.pc_none,.pc_none320{
  display: none !important;
}
.sp_none{
  display: inline-block !important;
}
.ac_color{
  color: #FF2244;
}
.mainvisual img{
  width: 704px;
  height: auto;
}
.mainvisual .period{
  background-color: #AB5A96;
  padding: 10px 10px 6px 10px;
  text-align: center;
  color: #FFF;
  font-size: 24px;
  font-weight: bold;
}
.shopList dt{
  pointer-events: none;
}
a:hover{
	color:#333333;
}
#tccp_narita_202512 .hovernone a img:hover {
  opacity:1;
}

/* ---------------------------------------------
共通
--------------------------------------------- */
.fs15{
  font-size: 15px;
}
.red{
  color: #CD1219;
}
.yellow_line{
  border-bottom: solid 4px #FFD300;
  text-align: center;
  line-height: 1em;
}

/*----------------------------------
見出し
----------------------------------*/
h2{
  background-color: #F1DFEC;
  color: #AB5A96;
  font-size: 15px;
  padding: 10px 0 10px 20px;
  margin: 30px 0 20px;
  position: relative;
}
h2:before {
  position: absolute;
  content: "";
  top: 0.5em;
  left: 0.5em;
  width: 4px;
  height: calc(100% - 1em);
  background-color: #AB5A96;
}
h3{
    border-left: 4px solid #AB5A96;
    line-height: 1.3;
    padding-left: 5px;
    margin-left: 10px;
}
#attention h3{
    border-left: none;
    line-height: 1.5;
    padding-left: 0;
    margin-left: 0;
}

/* ---------------------------------------------
ポイントラリー
--------------------------------------------- */
.points_rally{
  display: flex;
  justify-content: center;
  text-align: center;
}
.points_rally .points_rally_wrap{
  display: block;
}
.points_rally .traiangle{
    width: 0;
    height: 0;
    margin: 54px 0 0 0;
    border-style: solid;
    border-width: 20px 15px 0 15px;
    border-color: #AB5A96 transparent transparent transparent;
    rotate: -90deg;
}
.points_rally .points_rally_wrap img{
    width: 50%;
}
.points_rally .points_rally_wrap p{
  font-size: 13px;
  line-height: 1.5;
}
.points_rally .points_rally_wrap.step1{
  margin-right: -40px;
}
.points_rally .points_rally_wrap.step2{
  margin-left: -35px;
}

/* ---------------------------------------------
抽選
--------------------------------------------- */
.lottery p{
  font-size: 14px;
  margin-left: 10px;
}
.lottery div{
  text-align: center;
}
.lottery div img{
  width: 45%;
  margin-top: 10px;
}

/*----------------------------------
対象店舗
----------------------------------*/
dl {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.narita_shop-dd::after {
  content: "";
  display: block;
  width: 345px;
}
.narita_shop-dd::after {
  content: "";
  display: block;
  width: 345px;
}
.narita_shop-dd {
  width: 49%;
    margin-bottom: 15px;
    background-color: #F8ECF5;
}
.narita_shop-dd .store_wrap {
  padding: 10px;
  text-decoration: none;
  background-color: #F8ECF5;
  display: flex;
}
.narita_shop-dd .store_wrap:hover {
  opacity: 0.7;
}

.narita_shop-dd .store_wrap .icon-right{
width: 18px;
}

.narita_shop-dd div .store_wrap .store_detail{
  display: flex;
  color: #333;
  text-align: left !important;
}
.narita_shop-dd div .store_wrap .store_detail .detail{
  width: 220px;
}
.narita_shop-dd div .store_wrap .store_detail {
  font-size: 12px;
}
.narita_shop-dd div .store_wrap .store_detail .points{
    font-size: 11px;
    background-color: #C185B2;
    color: #FFF;
    border-radius: 2px;
    padding: 2px 4px;
}
.narita_shop-dd div .store_wrap .store_detail h4{
  font-size: 12px;
  color: #AB5A96;
  line-height: 1.2;
  text-decoration: none !important;
  padding: 4px 0 4px 0;
  position: relative;
}
.narita_shop-dd div .store_wrap .store_detail p{
  font-size: 10px;
  font-weight: normal;
}
.narita_shop-dd div .store_wrap div img{
  width: 90%;
}
.narita_shop-dd.multiple01 {
  width: 100%;
}
.narita_shop-dd.multiple01 .colums1{
text-align: center;
    margin: 10px 0 10px;
}
.narita_shop-dd.multiple01 .spot{
  margin-right: 10px;
      font-size: 12px;
      font-weight: bold;
}
.narita_shop-dd.multiple01 .points{
    font-size: 11px;
    font-weight: bold;
    background-color: #C185B2;
    color: #FFF;
    border-radius: 2px;
    padding: 2px 4px;
}
.narita_shop-dd.multiple01 .colums2{
  display: flex;
  padding-bottom: 15px;
}
.narita_shop-dd.multiple01 .colums2 .store_wrap{
    padding: 0 10px 10px 10px;
}
.narita_shop-dd.multiple01 .colums2 .store_wrap:nth-of-type(1){
    border-right: dotted 1px #B56FA3;
    height: 95px;
    padding-right: 15px;
}
.narita_shop-dd.multiple01 .colums2 .store_wrap:nth-of-type(2){
    padding-left: 15px;
}
.narita_shop-dd.multiple01 .store_wrap {
  width: 48%;
}
.narita_shop-dd .store_wrap {
  padding: 10px;
  text-decoration: none;
  background-color: #F8ECF5;
  display: flex;
}
.narita_shop-dd.multiple02 .store_wrap {
    display: block;
}
.narita_shop-dd.multiple02 .store_wrap .icon-right{
position: relative;
    top: 18px;
}
.narita_shop-dd.multiple02 .cautions{
    font-size: 10px;
    font-weight: normal;
    line-height: 1.5;
}
#tccp_narita_202512 .target_stores .map:hover{
  opacity: 0.7;
}
#tccp_narita_202512 .target_stores .title02{
  margin-top: 70px;
}
#tccp_narita_202512 .target_stores .storeAre{
  margin-bottom: 25px;
  padding: 10px 0 5px;
  margin-top: -52px;
}
.store_wrap{
  font-size: 11px;
  color: #333333;
  font-weight: bold;
}
.pointer_none{
  pointer-events: none;
}

/*----------------------------------
注意事項
----------------------------------*/
.campList01{
  margin-bottom: 80px;
}
.campList01 h4{
  margin-top: 12px;
}
.campList01 h4:first-child{
  margin-top: 0px;
}
.campList01 li{
  text-indent: 0!important;
  margin-left: 0 !important;
}
.campList01 li p{
  text-indent: 0!important;
  margin-left: 1em;
  padding-right: 10px;
}
.campList01 li:before{
  display: none!important;
}

/*----------------------------------
バナー
----------------------------------*/
.bannerArea {
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  .pc_none{
    display: inline-block !important;
  }
  .sp_none{
    display: none !important;
  }

  /*----------------------------------
  コンテンツ
  ----------------------------------*/
  #tccp_narita_202512 {
  max-width:600px;
  }
  .mainvisual .period{
    padding: 10px 0;
    font-size: 14px;
  }
  .title02{
  width: auto;
  }
  .mainvisual,.mainvisual img{
    width: 100%;
  }
  .narita_shop-dd {
    width: 100%;
  }
}

@media screen and (max-width: 430px) {
  /* ---------------------------------------------
  ポイントラリー
  --------------------------------------------- */
  .points_rally{
    display: block;
  }
  .points_rally .points_rally_wrap{
    display: block;
  }
  .points_rally .traiangle{
      margin: 34px auto 20px;
      rotate: 0deg;
  }
  .points_rally .points_rally_wrap.step1{
    margin-right: 0;
  }
  .points_rally .points_rally_wrap.step2{
    margin-left: 0;
  }

  /* ---------------------------------------------
  抽選
  --------------------------------------------- */
  .lottery div img{
    width: 80%;
  }
  .narita_shop-dd.multiple01 .colums2{
    display: block;
    padding-bottom: 0;
  }
  .narita_shop-dd.multiple01 .colums2 .store_wrap{
    padding: 0 10px 10px 10px;
  }
  .narita_shop-dd.multiple01 .colums2 .store_wrap:nth-of-type(1){
    border-bottom: dotted 1px #B56FA3;
    width: auto;
    border-right: none;
    padding-right: 0;
    height: auto;
    padding: 0 10px 10px 10px;
    margin: 0 10px;
    padding-left: 0;
    padding-right: 0;
  }
  .narita_shop-dd.multiple01 .colums2 .store_wrap:nth-of-type(2){
    padding-top: 15px;
    padding-left: 10px;
  }
  .narita_shop-dd.multiple01 .store_wrap {
    width: auto;
  }

  /*----------------------------------
  バナー
  ----------------------------------*/
  .bannerArea {
    margin-bottom: 50px;
    margin-top: 20px;
  }
}
