@charset "utf-8";
/*
* This is CSS for smartphone top.
* 2020/10/28 s.sato
*/
a {
  text-decoration: none;
  color: #333;
}
/* ------------------------------------------
keywordSearch
------------------------------------------ */
#keywordSearch {
  position: relative;
  margin-bottom: 10px;
  padding: 5px 10px;
  background: -moz-linear-gradient(top, #f0f0f0, #e0e0e0);
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#f0f0f0),
    to(#e0e0e0)
  );
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.2);
}
#keywordSearch .field {
  width: 53%;
  height: 26px;
  margin: 0;
  padding: 5px 25% 5px 2%;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  border-right: none;
  border-left: 1px solid #ccc;
  border-radius: 4px;
  /*box-shadow: inset 0px 0px 1px 1px rgba(0, 0, 0, 0.1);*/
  font-size: 90%;
}
#keywordSearch .cancel {
  position: absolute;
  top: 16px;
  right: 26%;
  width: 16px;
  height: 16px;
}
#keywordSearch .cancel a {
  display: block;
  width: 16px;
  height: 18px;
  text-indent: -9999px;
  overflow: hidden;
  background-position: -15px -950px;
}
#keywordSearch .submit {
  position: absolute;
  top: 5px;
  right: 10px;
  width: 20%;
  height: 38px;
  margin: 0;
  padding: 0;
  border: 1px solid #4c4c4c;
  background: #4c4c4c top center;
  border-radius: 0 4px 4px 0;
  text-indent: -9999px;
  overflow: hidden;
}
/* ------------------------------------------
dateSearch
------------------------------------------ */
#dateSearch {
  margin-bottom: 2px;
  padding: 0 10px 5px;
  border: 1px solid #fff;
  /*background: #F5F5F5;*/
  background: -moz-linear-gradient(top, #ffffff, #f5f5f5);
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#ffffff),
    to(#f5f5f5)
  );
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.2);
}
/* ----- srcHisBox -----*/
.srcHisBox {
  position: relative;
  margin-bottom: 10px;
  padding: 5px 5px 3px 5px;
  background: #eaeaea;
  box-shadow: inset 0px 2px 3px rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  font-size: 82%;
  line-height: 2;
}

.srcHisBox .btnOpen,
.srcHisBox .btnClose {
  display: block;
  position: absolute;
  bottom: 0.9em;
  right: 10px;
  width: 10px;
  height: 10px;
  text-indent: -9999px;
  overflow: hidden;
  z-index: 1;
}
.srcHisBox .btnOpen {
  background-position: 0 -775px;
}
.srcHisBox .btnClose {
  background-position: 0 -800px;
}
.srcHisBox .btnOpen.openArrow {
  background-position: 0 -800px;
}

.srcHisBox .searchHistoryLink {
  padding-left: 12px;
  background-position: -28px -743px;
  margin-right: 20px;
}
.srcHisBox .delete a {
  background-position: 0 -1543px;
  position: absolute;
  top: 10px;
  right: 10px;
  width: 17px;
  height: 17px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
}
.inputWrap#du-input-num dd li {
  float: left;
  font-size: 65%;
  text-align: center;
  border-right: 1px solid #d3d3d3;
}
.searchWrap .submitWrap {
  margin: 10px;
  border: 1px none #fff;
}
.searchWrap .submitWrap .submit {
  padding-left: 1.5em;
}
/* ------------------------------------------
midnight
------------------------------------------ */

.midnight a {
  display: block;
  font-size: 95%;
  position: relative;
  text-indent: 15px;
}
.midnight a:before {
  content: "";
  position: absolute;
  background-position: 0px -1570px;
  height: 13px;
  width: 13px;
  display: block;
  position: absolute;
  top: 50%;
  margin-top: -5px;
  left: 0px;
  overflow: hidden;
  line-height: 1;
}

/*「＞」*/
.midnight a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 3px;
  width: 5px;
  height: 5px;
  margin-top: -4px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
  border-top-width: 3px;
  border-right-width: 3px;
  border-top-style: solid;
  border-right-style: solid;
  border-top-color: #888;
  border-right-color: #888;
}
/* ------------------------------------------
feature
------------------------------------------ */
#feature {
  position: relative;
  padding: 10px 0px 20px 0px;
  background: #eaeaea;
}

#feature #ichioshi {
  margin-bottom: 7px;
  text-align: center;
  overflow: hidden;
  padding-left: 10px;
  padding-right: 10px;
}
/*--↓バナーサイズの変更--*/
#feature #ichioshi .bnrGroup {
  width: 290px;
  margin: 0 auto 1px;
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.4);
}
#feature #ichioshi .bnrGroup img {
  width: 100%;
  max-width: 100%;
  height: auto;
}

#feature .controlBtn a {
  display: block;
  position: absolute;
  text-indent: -9999px;
}

#feature #controlBtnA,
#feature #controlBtnB {
  position: absolute;
  width: 100%;
  z-index: 1;
}

#feature .bnrPrev a {
  left: 0px;
}

#feature .bnrNext a {
  right: 0px;
}

#feature #controlBtnA .bnrPrev a {
  background-position: 3px 89px;
}

#feature #controlBtnA .bnrNext a {
  background-position: 25px -31px;
}

#feature #controlBtnB .bnrPrev a {
  background-position: 3px 75px;
}

#feature #controlBtnB .bnrNext a {
  background-position: 26px -45px;
}

#feature #ichioshi .controller {
  position: relative;
  overflow: hidden;
}

#feature #ichioshi .controller:after {
  content: "";
  display: block;
  clear: both;
}
#feature #ichioshi .controller ul {
  position: relative;
  float: left;
  left: 50%;
}
#feature #ichioshi .controller li {
  position: relative;
  float: left;
  left: -50%;
  width: 8px;
  height: 8px;
  margin: 0 3px;
}
#feature #ichioshi .controller li a {
  display: block;
  width: 8px;
  height: 8px;
  background: #666;
  border-radius: 4px;
  text-indent: -9999px;
  overflow: hidden;
}
#feature #ichioshi .controller li.active a {
  background: #cc0000;
}

#feature #itemListB {
  padding-left: 10px;
  padding-right: 10px;
}
#feature #itemListB:after {
  content: "";
  display: block;
  clear: both;
}

#feature #itemListB .spBox {
  position: relative;
  float: left;
  /*width: 178px;*/
  width: 160px;
  border-radius: 4px;
  background: #fff;
  border: 1px solid #ccc; /*box-shadow: 0 2px 2px #999999;*/
  margin: 0 10px 0 0;
  height: 177px;
}

#feature #itemListB .spBox .area {
  position: absolute;
  top: 0;
  left: 0;
  padding: 4px;
  color: #fff;
  font-size: 90%;
  border-radius: 3px 0 0 0;
  background: #e97d2a;
}
.spBox .photo img {
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 3px 3px 0 0;
}
.spBox dl {
  margin: 5px 7px;
  line-height: 1.4;
}
/*CampaignM_title*/
.spBox dl dt {
  margin-bottom: 5px;
  font-weight: bold;
  font-size: 92%;
}
/*CampaignM_text*/
.spBox dl dd {
  font-size: 70%;
  color: #666;
}

/* ------------------------------------------
recent
------------------------------------------ */
#recent {
  position: relative;
  padding-bottom: 20px;
  background: #eaeaea;
  overflow: hidden;
}

#recent h1 {
  margin-bottom: 10px;
  padding: 7px 0 5px 0;
  background: #333;
  line-height: 1.1;
  color: #fff;
  text-align: center;
  font-size: 100%;
  font-weight: normal;
}
#recent #recTtlNum {
  margin: 10px 10px 5px 10px;
  font-size: 82%;
}
#recent #recTtlNum strong {
  color: #cc0000;
  font-size: 146%;
  font-weight: normal;
}

#recent .pagination {
  position: relative;
  float: left;
  left: 50%;
  margin-top: 9px;
}
#recent .pagination:after {
  content: "";
  display: block;
  clear: both;
}
#recent .pagination a {
  position: relative;
  float: left;
  left: -50%;
  width: 8px;
  height: 8px;
  margin: 0 3px;
  display: block;
  background: #666;
  border-radius: 4px;
  text-indent: -9999px;
  overflow: hidden;
}
#recent .pagination a.selected {
  background: #cc0000 !important;
}

#recent .recentList {
  margin-top: 5px;
  margin-bottom: 0px;
  padding: 0px;
}
#recent .recentList:after {
  content: "";
  display: block;
  clear: both;
}

#recent .recentList li {
  border: 1px solid #ccc;
  border-radius: 3px;
  float: left;
  margin-right: 4px;
  margin-left: 4px;
  padding: 8px;
  background: #fff;
  position: relative;
  height: 165px;
}

#recent .recentList li .photo {
  margin-bottom: 8px;
  text-align: center;
  height: 100px;
}
#recent .recentList li .pref {
  font-size: 65%;
}
#recent .recentList li h2 {
  font-size: 100%;
  font-weight: normal;
}

#recent .recentList li .delete {
  position: absolute;

  top: 5px;
  right: 5px;
  width: 16px;
  height: 18px;
}
#recent .recentList li .delete a {
  display: block;
  width: 16px;
  height: 18px;
  text-indent: -9999px;
  overflow: hidden;
  background-position: -15px -950px;
}

#recent .more {
  margin-top: 25px;
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 0;
  border: 1px solid #ccc;
  border-radius: 5px;
  background: #fff;
}
#recent .more a {
  display: block;
  position: relative;
  padding: 10px;
  text-align: center;
  font-size: 82%;
}
#recent .more a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

/* ------------------------------------------
purpose
------------------------------------------ */
#purpose {
  padding-bottom: 10px;
  background: #eaeaea;
}

#purpose h1 {
  margin-bottom: 1-px;
  margin-bottom: 10px;
  padding: 7px 0 5px 0;
  background: #333;
  line-height: 1.1;
  color: #fff;
  text-align: center;
  font-size: 100%;
  font-weight: normal;
}

#purpose ul.category {
  margin: 0 10px 10px 10px;
  padding-bottom: 5px;
  border-bottom: 1px dotted #ccc;
}
#purpose ul.category:after {
  content: "";
  display: block;
  clear: both;
}

#purpose ul.category li {
  float: left;
  width: 50%;
  margin-bottom: 8px;
}
#purpose ul.category li a {
  display: block;
  position: relative;
  height: 44px;
  border: 1px solid #ccc;
  border-radius: 5px;
  background: #fff;
  font-size: 90%;
  line-height: 1.3;
}
#purpose ul.category li:nth-child(2n-1) a {
  margin-right: 4px;
}
#purpose ul.category li:nth-child(2n) a {
  margin-left: 4px;
}

#purpose ul.category li.catUsj a {
  font-size: 82%;
  line-height: 1.1;
}

#purpose ul.category li a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

#purpose ul.category li a span {
  display: table-cell;
  height: 44px;
  padding: 0 10px 0 40px;
  vertical-align: middle;
}

#purpose ul.category li.catGrp a span {
  background-position: 0 -1040px;
}
#purpose ul.category li.catSta a span {
  background-position: 0 -1600px;
}
#purpose ul.category li.catHdy a span {
  background-position: 0 -1648px;
}
#purpose ul.category li.catTdr a span {
  background-position: 0 -1090px;
}
#purpose ul.category li.catUsj a span {
  background-position: 0 -1140px;
}
#purpose ul.category li.catKnk a span {
  background-position: 0 -1190px;
}
#purpose ul.category li.catOns a span {
  background-position: 0 -1238px;
}
#purpose ul.category li.catDay a span {
  background-position: 0 -2160px;
}
#purpose ul.category li.catFmy a span {
  background-position: 0 -2264px;
}

#purpose .category .catOns a:before {
  content: "";
  display: block;
  width: 52px;
  height: 26px;
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/icon_5percent_off.png)
    no-repeat;
  background-size: 100%;
  position: absolute;
  top: 10px;
  left: 93px;
}
@media screen and (max-width: 374px) {
  #purpose .category .catOns a:before {
    width: 45px;
    height: 23px;
    left: 84px;
  }
}

#purpose ul.service {
  margin: 0 10px;
  border: 1px solid #ccc;
  border-radius: 5px;
  background: #fff;
}
#purpose ul.service li a {
  display: block;
  position: relative;
  height: 44px;
  border-bottom: 1px solid #ccc;
  font-size: 90%;
  line-height: 1.3;
}
#purpose ul.service li:last-child a {
  border-bottom: none;
}
#purpose ul.service li a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

#purpose ul.service li a span {
  display: table-cell;
  height: 44px;
  padding: 0 0 0 50px;
  vertical-align: middle;
}
#purpose ul.service li.srvOdp a span {
  background-position: 5px -290px;
}
#purpose ul.service li.srvOair a span {
  background-position: 5px -590px;
}
#purpose ul.service li.srvOhtl a span {
  background-position: 5px -90px;
}
#purpose ul.service li.srvCS a span {
  background-position: 5px -690px;
}
#purpose ul.service li.srvRac a span {
  background-position: 5px -2210px;
}
/* ------------------------------------------
utility
------------------------------------------ */
#utility {
  margin: 0;
}
#utility ul {
  width: 100%;
  border-top: 1px solid #ccc;
}
#utility ul:after {
  content: "";
  display: block;
  clear: both;
}
#utility ul li {
  float: left;
  width: 50%;
}
#utility ul li a {
  display: block;
  position: relative;
  height: 44px;
  border-bottom: 1px solid #ccc;
  font-size: 90%;
  color: #666;
  line-height: 1.3;
}
#utility ul li:nth-child(2n-1) a {
  border-right: 1px solid #ccc;
}
#utility ul li a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

#utility ul li a span {
  display: table-cell;
  height: 44px;
  padding: 0 10px 0 40px;
  vertical-align: middle;
}
#utility ul li.linkPsnl a span {
  background-position: 0 -1290px;
}
#utility ul li.linkHelp a span {
  background-position: 0 -1340px;
}
#utility ul li.linkRule a span {
  background-position: 0 -1390px;
}
#utility ul li.linkInfo a span {
  background-position: 0 -1440px;
}

#utility .btn,
#utility .appPR {
  margin: 10px;
}
#utility .btn a {
  display: block;
  border-radius: 5px;
  background: -moz-linear-gradient(top, #83ba38, #71a230);
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#83ba38),
    to(#71a230)
  );
  color: #fff;
  line-height: 1.3;
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.4);
}
#utility .btn a span {
  display: block;
  padding: 10px 0 10px 40px;
  font-size: 90%;
  background-position: 0 -1494px;
}
#utility .appPR a {
  display: block;
}
#utility .appPR a img {
  width: 100%;
  height: auto;
}

/* ------------------------------------------
generalLink
------------------------------------------ */
.generalLink {
  margin-top: 10px;
}
.generalLink ul {
  display: block;
  border: 1px solid #ccc;
  border-radius: 5px;
  background-color: #fff;
}
.generalLink ul li {
  display: block;
}
.generalLink ul li a {
  display: block;
  position: relative;
  font-size: 90%;
  line-height: 1.3;
  padding: 14px 30px 12px 12px;
}
/*「＞」*/
.generalLink ul li a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -5px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

/* ------------------------------------------
Texts common
------------------------------------------ */
.subTtl001 {
  font-size: 90%;
  font-weight: bold;
  color: #8a8a8a;
  border-bottom-color: #b5b5b5;
  border-bottom-width: 1px;
  border-bottom-style: dotted;
  line-height: 0.9;
  padding: 3px 0 12px; /*上 左右 下*/
  margin: 6px 0 6px; /*上 左右 下*/
}

/* ------------------------------------------
background
------------------------------------------ */
#keywordSearch .cancel a,
#keywordSearch .submit,
.srcHisBox .btnOpen,
.srcHisBox .btnClose,
.srcHisBox .searchHistoryLink,
.srcHisBox .delete a,
.midnight a:before,
#dateSearch .searchNav li a span,
#dateSearch .searchNav li em span,
#recent .recentList li .delete a,
#recent .controller li a,
#purpose ul li a span,
#utility ul li a span,
#utility .btn a span {
  background-image: url(//trvimg.r10s.jp/share/smart/images/sprite_sptop-b.png?_=20201020);
  background-repeat: no-repeat;
  background-size: 40px 2298px;
}
#feature .controlBtn a {
  background-image: url(//trvimg.r10s.jp/share/smart/images/sprite_campaign.png);
  background-repeat: no-repeat;
  background-size: 250px 500px;
}
.two-lines-truncate {
  text-overflow: ellipsis;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
body {
  -webkit-text-size-adjust: none;
}
.truncate {
  text-overflow: ellipsis;
  white-space: nowrap;
  overflow: hidden;
}
#itemListA {
  width: 300px;
}
#itemListA ul.bnrGroup {
  height: 217px;
  overflow: hidden;
  box-shadow: none !important;
}
#itemListA ul.bnrGroup li {
  float: left;
  display: inline-block;
  width: 290px;
  margin: 0px 5px;
  box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.4);
}
#itemListB div.contentView {
  height: 179px;
  overflow: hidden;
}
/* ------------------------------------------
recommendation
------------------------------------------ */
#o_recommendation {
  padding: 0px 10px 10px 10px;
  background-color: #eaeaea;
}
/* ------------------------------------------------------------------------------------
各サービスへのボタン+Search部分のオーバーライド
------------------------------------------------------------------------------------ */
body.top-smart .tab-dmstc-ovs {
  margin-top: 10px;
  border-bottom: 3px solid #72a427;
}
body.top-smart .tab-dmstc-ovs:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
body.top-smart .tab-dmstc-ovs {
  min-height: 1px;
}
* html body.top-smart .tab-dmstc-ovs {
  height: 1px;
  /*¥*/ /*/
  height: auto;
  overflow: hidden;
  /**/
}
body.top-smart .tab-dmstc-ovs li {
  width: 50%;
  float: left;
}
body.top-smart .tab-dmstc-ovs > .tab-dmstc {
  padding-left: 10px;
  padding-right: 2px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
body.top-smart .tab-dmstc-ovs > .tab-ovs {
  padding-left: 2px;
  padding-right: 10px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
body.top-smart .tab-dmstc-ovs span,
body.top-smart .tab-dmstc-ovs a {
  display: block;
  padding-top: 9px;
  padding-bottom: 7px;
  text-align: center;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  font-size: 1.6rem;
  font-weight: bold;
}
body.top-smart .tab-dmstc-ovs span {
  background-color: #72a427;
  border: solid 1px #72a427;
  color: #fff;
}
body.top-smart .tab-dmstc-ovs a {
  border: 1px solid #ccc;
  border-bottom: 1px solid #e2e2e2;
  background: -moz-linear-gradient(top, #fdfdfd, #e2e2e2);
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#fdfdfd),
    to(#e2e2e2)
  );
}
body.top-smart .tab-dmstc-ovs a,
body.top-smart .tab-dmstc-ovs a:hover,
body.top-smart .tab-dmstc-ovs a:active,
body.top-smart .tab-dmstc-ovs a:visited {
  color: #333;
  font-weight: normal;
}
/* ------------------------------------------
dateSearch
------------------------------------------ */
body.top-smart #dateSearch {
  padding-left: 0;
  padding-right: 0;
  margin-bottom: 2px;
  border: none;
  background: none;
}
body.top-smart #dateSearch .searchNav {
  padding: 10px 10px 10px 4px;
  margin-bottom: 0px;
  border: none;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  background-color: #e5e5e5;
}
body.top-smart #dateSearch .searchNav:after {
  content: "";
  display: block;
  clear: both;
}
body.top-smart #dateSearch .searchNav li {
  float: left;
  width: 20%;
  margin: 0;
  padding-left: 6px;
  height: 52px;
  line-height: 2;
  font-size: 1rem;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
body.top-smart #dateSearch .searchNav li a {
  display: block;
  height: 48px;
  padding: 0;
  border: 1px solid #ccc;
  border-radius: 3px;
  text-align: center;
  background: -moz-linear-gradient(top, #fdfdfd, #e2e2e2);
  background: -webkit-gradient(
    linear,
    left top,
    left bottom,
    from(#fdfdfd),
    to(#e2e2e2)
  );
}
body.top-smart #dateSearch .searchNav li a span {
  display: block;
  width: 53px;
  height: 18px;
  margin: 0 auto;
  padding-top: 30px;
}
body.top-smart #dateSearch .searchNav li em {
  display: block;
  position: relative;
  height: 48px;
  padding: 0;
  border: 1px solid #fff;
  border-radius: 3px;
  text-align: center;
  background-color: #444;
  color: #fff;
  box-shadow: none;
}
body.top-smart #dateSearch .searchNav li em:before {
  content: "";
  position: absolute;
  margin-left: -8px;
  border-top: 10px solid #fff;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  bottom: -10px;
  left: 50%;
}
body.top-smart #dateSearch .searchNav li em:after {
  content: "";
  position: absolute;
  margin-left: -6px;
  border-top: 8px solid #444;
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
  bottom: -8px;
  left: 50%;
}
body.top-smart #dateSearch .searchNav li em span {
  display: block;
  width: 50px;
  height: 18px;
  margin: 0 auto;
  padding-top: 30px;
}
/* ------------------------------------------
keywordSearch
------------------------------------------ */
body.top-smart #keywordSearch {
  position: relative;
  margin-bottom: 10px;
  padding: 0px 10px 10px 10px;
  background: none;
  background-color: #e5e5e5;
  box-shadow: none;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
body.top-smart #keywordSearch .field {
  width: 80%;
  height: 38px;
  margin: 0;
  padding: 5px 28px 5px 5px;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
  border-radius: 4px 0px 0px 4px;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  border-right: none;
  border-left: 1px solid #ccc;
  font-size: 1.4rem;
  box-shadow: none;
  -webkit-appearance: none;
}
body.top-smart #keywordSearch .cancel {
  position: absolute;
  top: 11px;
  right: 20%;
  margin-right: 16px;
  width: 16px;
  height: 16px;
}
body.top-smart #keywordSearch .cancel a {
  display: block;
  width: 16px;
  height: 18px;
  text-indent: -9999px;
  overflow: hidden;
  background-position: -15px -950px;
}
body.top-smart #keywordSearch .submit {
  width: 20%;
  height: 38px;
  margin: 0;
  padding: 0;
  position: absolute;
  top: 0px;
  right: 10px;
  border: 1px solid #4c4c4c;
  background: #4c4c4c top center;
  border-radius: 0 4px 4px 0;
  text-indent: -9999px;
  overflow: hidden;
  /*↓UP後、これを消して大丈夫かテスト予定*/
  background-image: url(//trvimg.r10s.jp/share/smart/images/sprite_sptop-b.png);
  background-repeat: no-repeat;
  background-size: 40px 2298px;
}
/* ------------------------------------------
#midnight
------------------------------------------ */
body.top-smart #midnight,
body.top-smart #tonight {
  width: auto;
  margin-left: 10px;
  margin-right: 10px;
  background-color: #4c4c4c;
}
/* ------------------------------------------
#dh-input-area
------------------------------------------ */
body.top-smart #dh-search-history,
body.top-smart #dh-input-area,
body.top-smart #dh-input-date,
body.top-smart #dh-input-num,
body.top-smart #dh-input-amt {
  width: auto;
  margin-left: 10px;
  margin-right: 10px;
}
body.top-smart .Searchnotes {
  font-size: 70%;
  text-align: right;
  padding-right: 15px;
}
body.top-smart .searchWrap .submitWrap {
  padding-top: 0px;
}
/* ------------------------------------------------------------------------------------
/各サービスへのボタン+Search部分のオーバーライドここで終了
------------------------------------------------------------------------------------ */
/* ------------------------------------------
#oshirase
------------------------------------------ */
body.top-smart #oshirase {
  padding-bottom: 10px;
  background: #eaeaea;
}
body.top-smart #oshirase h1 {
  margin-bottom: 1-px;
  margin-bottom: 10px;
  padding: 7px 0 5px 0;
  background: #333;
  line-height: 1.1;
  color: #fff;
  text-align: center;
  font-size: 100%;
  font-weight: normal;
}
body.top-smart #oshirase ul > li > a > p.rtprts__one-column-btn {
  padding-top: 5px;
  padding-bottom: 5px;
}

/* 20190614 s-sato */
/*=============================================
COMMON
=============================================*/
.module-history-domsp {
  padding-top: 18px;
}
.module-history-domsp .History__title h2 {
  font-size: 15px;
  color: #333;
  text-align: left;
  margin: 0 10px 5px;
  padding: 0;
  background: none;
}

/*=============================================
#purpose
=============================================*/
#purpose {
  padding: 5px 0 0;
}
#purpose h2 {
  font-size: 15px;
  font-weight: normal;
  margin: 0 10px 5px;
}

#purpose ul.category {
  border: none;
  margin-bottom: 0px;
}

#purpose ul.category:nth-of-type(3) {
  padding-bottom: 15px;
}

#purpose li {
}

#purpose .catYad span,
#purpose .catDea span,
#purpose .catGui span,
#purpose .catLoc span {
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/sprite_sptop-c.png)
    no-repeat;
  background-size: 35px 210px;
}
#purpose .catPre span {
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/sprite_sptop-d.png)
    no-repeat;
  background-size: contain;
  background-position: 3px 3px;
  width: 8em;
}
#purpose .catYad span {
  background-position: 3px 4px;
}

#purpose .catDea span {
  background-position: 2px -31px;
}

#purpose .catGui span {
  background-position: 2px -65px;
}

#purpose .catLoc span {
  background-position: 2px -101px;
}

#purpose .service-outer {
  background: #fff;
  padding: 20px 0;
}

#purpose ul.service-list {
  display: flex;
  flex-flow: wrap;
  justify-content: left;
  margin: 0;
  border: none;
  border-top: 1px solid #ccc;
  border-radius: initial;
  background: #eaeaea;
  padding: 0 0 20px;
}

#purpose .service-list li {
  width: 33.3333%;
  border-right: 1px solid #ccc;
}

#purpose .service-list li:first-child {
  border-left: none;
}

#purpose ul.service-list li a:after {
  display: none;
}

#purpose ul.service-list li a {
  height: 56px;
}

#purpose ul.service-list li:last-child a {
  border-bottom: 1px solid #ccc;
}

#purpose ul.service-list li a span {
  height: 56px;
}

#purpose ul.service li.srvOdp a span {
  background-position: 5px -284px;
}

#purpose ul.service li.srvOair a span {
  background-position: 5px -584px;
  padding: 0 0 0 45px;
}

#purpose ul.service li.srvOhtl a span {
  background-position: 5px -84px;
  padding: 0 0 0 45px;
}

#purpose ul.service li.srvJrHtl a span {
  background-position: 5px -1972px;
  padding: 0 0 0 50px;
}

/*=============================================
#oshirase
=============================================*/
body.top-smart #oshirase {
  padding-bottom: 10px;
}

/*=============================================
#mente
=============================================*/
#mente {
  background: #eaeaea;
  padding: 0 0 20px;
}

#mente h2 {
  font-size: 15px;
  font-weight: normal;
  margin: 0 10px 5px;
}

/*=============================================
#houjin
=============================================*/
#houjin {
  background: #eaeaea;
}

#houjin h1 {
  margin-bottom: 10px;
  padding: 7px 0 5px 0;
  background: #333;
  line-height: 1.1;
  color: #fff;
  text-align: center;
  font-size: 100%;
  font-weight: normal;
}

#houjin ul {
  overflow: hidden;
  margin: 0 10px 0px 10px;
  padding-bottom: 12px;
}

#houjin li {
  float: left;
  width: 50%;
  margin-bottom: 8px;
}

#houjin li:nth-child(2n) a {
  margin-left: 4px;
}

#houjin li:nth-child(2n-1) a {
  margin-right: 4px;
}

#houjin li a:after {
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 5px;
  height: 5px;
  margin-top: -3px;
  border-top: 3px solid #999;
  border-right: 3px solid #999;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: "";
}

#houjin li a {
  display: block;
  position: relative;
  height: 44px;
  border: 1px solid #ccc;
  border-radius: 5px;
  background: #fff;
  font-size: 84%;
  line-height: 1.3;
}

#houjin li span {
  display: table-cell;
  height: 44px;
  padding: 0 10px 0 40px;
  vertical-align: middle;
}

#houjin .houRac a {
  font-size: 82%;
  line-height: 1.1;
}

#houjin .houRac span {
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/sprite_sptop-c.png)
    no-repeat;
  background-size: 35px 210px;
  background-position: 2px -172px;
}

#houjin .houNew span {
  background: url(https://trvimg.r10s.jp/share/smart/images/sprite_sptop-b.png)
    no-repeat;
  background-size: 40px 2298px;
  background-position: 0 -1440px;
}

#utility ul li.linkInfo a span {
  background-position: 0 -1440px;
}

/*=============================================
#sns-area
=============================================*/
.sns-list {
  display: flex;
  justify-content: space-around;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.sns-list li {
  width: 20%;
  height: 80px;
  box-sizing: border-box;
  line-height: 1;
  text-align: center;
  position: relative;
  border-left: 1px solid #ccc;
}

.sns-list li:first-child {
  border-left: none;
}

.sns-list li:before {
  content: "";
  width: 35px;
  height: 36px;
  position: absolute;
  top: 15px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url(https://img.travel.rakuten.co.jp/share/smart/images/sprite_sns.png);
  background-size: 35px auto;
  pointer-events: none;
}

.sns-list .btn-facebook:before {
  background-position: 0 0;
}

.sns-list .btn-twitter:before {
  background-position: 0px -39px;
}

.sns-list .btn-instagram:before {
  background-position: 0px -78px;
}

.sns-list .btn-line:before {
  background-position: 0 75px;
}

.sns-list .btn-youtube:before {
  background-position: 0 -156px;
}

.sns-list li a {
  font-size: 10px;
  display: block;
  height: 100%;
  box-sizing: border-box;
  padding: 60px 0 0;
}

/*=============================================
#downloads
=============================================*/
.downloads-in {
  display: flex;
  justify-content: space-around;
  padding: 0 1%;
  max-width: 400px;
  margin: 0 auto;
}

.downloads p {
  width: 46%;
  padding: 20px 0;
}

.downloads p a {
  font-size: 0;
  display: block;
}

.downloads p img {
  max-width: 180px;
  width: 100%;
  height: auto;
}

/*20200525*/
/*=============================================
Accordion
=============================================*/
.acc {
  margin: 10px 10px 0 10px;
  background-color: #ffffff;
  /* border: 1px solid #cccccc; */
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  border-radius: 5px;
  margin: 0 10px;
}
.acc > dd,
.acc-pref {
  display: none;
}
.acc > dt,
.acc > dd li a {
  position: relative;
  display: block;
  padding: 6px 0px 6px 0px;
  border-top: 1px dotted #cccccc;
  cursor: pointer;
}
.acc > dt:first-child {
  border-top: none;
}
.acc > dt:after,
.acc-area > li:not(.no-pref) > a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 8px;
  transform: translateY(-50%);
  width: 14px;
  height: 13px;
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/expand-arrow-open.svg)
    center center no-repeat;
  background-size: contain;
}
.acc dt.on:after,
.acc-area > li:not(.no-pref) > a.on:after {
  background-image: url(https://img.travel.rakuten.co.jp/share/smart/images/expand-arrow-close.svg);
}
.acc-area > li > a,
.acc-airport a,
.acc-station {
  position: relative;

  text-indent: 1em;
}
.acc-pref a {
  text-indent: 2em;
}
.acc-pref > li,
.acc-airport li,
.acc-station li {
  position: relative;
}
.acc-pref > li > a:after,
.no-pref a:after,
.acc-airport a:after,
.acc-station a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 7px;
  width: 14px;
  height: 14px;
  transform: translateY(-50%);
  background: url(https://img.travel.rakuten.co.jp/share/smart/images/arrow-right.svg)
    center center no-repeat;
}

/*=============================================
keywordSuggest
=============================================*/
#keywordSuggest {
  position: absolute;
  z-index: 5;
  left: 8px;
  width: 226px;
}
#tabimado {
  display: none !important;
}
#tabimado,
#station {
  display: none;
  position: absolute;
  z-index: 5;
  left: 8px;
  width: 226px;
  width: 300px;
}
#keywordSuggest,
#tabimado,
#station {
  top: 60px;
  top: 40px;
}
* html #keywordSuggest,
* html #tabimado,
* html #station {
  top: 67px;
  top: 40px;
}
#keywordSuggest ul,
#tabimado ul,
#station ul {
  border: 2px solid #76ae25;
  background: #fff;
  box-shadow: 0px 3px 3px #666;
}
#keywordSuggest ul li,
#tabimado ul li,
#station ul li {
  border-bottom: 1px dotted #76ae25;
  font-size: 82%;
}
#keywordSuggest ul li:last-child,
#tabimado ul li:last-child,
#station ul li:last-child {
  border-bottom: none;
}
#keywordSuggest ul li a,
#tabimado ul li a,
#station ul li a {
  display: block;
  padding: 7px 5px 7px 12px;
  background-image: url(https://trvimg.r10s.jp/share/common/images/sprite_common_pc.png);
  background-repeat: no-repeat;
}
#keywordSuggest ul li a:link,
#tabimado ul li a:link,
#station ul li a:link,
#keywordSuggest ul li a:visited,
#tabimado ul li a:visited,
#station ul li a:visited {
  background-position: -142px -890px;
}
#keywordSuggest ul li a:hover,
#tabimado ul li a:hover,
#station ul li a:hover,
#keywordSuggest ul li a:active,
#tabimado ul li a:active,
#station ul li a:active {
  background-position: -142px -990px;
  background-color: #ebf2d8;
}

/*.kw-link*/
.kw-link {
  overflow: hidden;
  margin: 2px 0 0 -6px;
}
.kw-link li {
  float: left;
  display: inline-block;
  margin: 8px 6px 0px;
}
.kw-link a {
  font-size: 12px;
  padding: 8px;
  background: #fff;
  border-radius: 5px;
  display: block;
}

/*#areaSearch*/
/* #areaSearch { */
/* padding-bottom: 10px; */
/* background: #eaeaea; */
/* } */
#areaSearch h2 {
  font-size: 15px;
  font-weight: normal;
  margin: 0 10px 5px;
}

/*#purpose*/
#purpose .service-list li {
  width: 50%;
  background: #fff;
  box-sizing: border-box;
}
#purpose .service-list li:nth-of-type(even) {
  border-right: none;
}
#purpose ul.category:nth-of-type(3) {
  padding-bottom: 5px;
}

/*#o_recommendation*/
#o_recommendation {
  padding: 0px 10px 15px 10px;
}

/*#utility*/
#utility {
  padding-bottom: 10px;
  background: #eaeaea;
}
#utility ul li a {
  background: #fff;
}
#utility ul.list1 li {
  width: 100%;
  float: none;
}
#utility ul.list1 li a {
  border-right: none;
}
#utility .btn,
#utility .appPR {
  margin: 10px 10px 20px;
}

/* icon background  */
#purpose .catHtb a span,
#purpose .catSanrio a span,
#purpose .catBiz a span,
#purpose .catCpl a span,
#purpose .catPet a span,
#purpose .srvHtb a span,
#utility .linkMail a span,
#utility .linkSite a span,
#utility .linkImprove a span,
#utility ul li.linkPsnl a span {
  background-image: url(https://img.travel.rakuten.co.jp//share/smart/images/sprite_sptop-e.png);
  background-repeat: no-repeat;
  background-size: 40px auto;
}
#purpose .catHtb a span {
  background-position: 0 -182px;
}
#purpose .catSanrio a span {
  background-position: 0 -29px;
}
#purpose .catBiz a span {
  background-position: 0 -64px;
}
#purpose .catCpl a span {
  background-position: 0 -139px;
}
#purpose .catPet a span {
  background-position: 0 -223px;
}
#purpose .srvHtb a span {
  background-position: 5px 18px;
}
#utility .linkMail a span {
  background-position: 0 -310px;
}
#utility .linkSite a span {
  background-position: 0 -100px;
}
#utility .linkImprove a span {
  background-position: 0 -350px;
}
#utility ul li.linkPsnl a span {
  background-position: 0 -266px;
}

/* gnav swipe style */
body.top-smart #dateSearch .searchNav {
  display: flex;
  flex-flow: row nowrap;
  overflow-x: auto;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  background: #fff;
  border-bottom: 1px solid #cfcfcf;
  padding: 6px 0 0 0;
  margin: 0 5px 0;
}
body.top-smart #dateSearch .searchNav::-webkit-scrollbar,
body.top-smart .tab-dmstc-ovs {
  display: none;
}
.dateSearch .searchNav li.srvOdp a span,
#dateSearch .searchNav li.srvOdp a span {
  background-position: 5px -295px;
  white-space: nowrap;
}
.dateSearch .searchNav li.srvOair a span,
#dateSearch .searchNav li.srvOair a span {
  background-position: 5px -595px;
  white-space: nowrap;
}
.dateSearch .searchNav li.srvOhtl a span,
#dateSearch .searchNav li.srvOhtl a span {
  background-position: 5px -95px;
  white-space: nowrap;
}
body.top-smart #dateSearch .searchNav li {
  padding: 0;
  height: 60px;
  min-width: 22%;
  line-height: 1.3;
}
body.top-smart #dateSearch .searchNav li em {
  background-color: transparent;
  color: #333;
  border: none;
  height: 100%;
  box-sizing: border-box;
}
body.top-smart #dateSearch .searchNav li em span {
  background-position: 5px -95px;
  padding-top: 33px;
}
body.top-smart #dateSearch .searchNav li em:after,
body.top-smart #dateSearch .searchNav li em:before {
  display: none;
}
body.top-smart #dateSearch .searchNav li em:after {
  display: block;
  width: 100%;
  height: 4px;
  margin: 0;
  bottom: 0;
  left: 0;
  border: 0;
  background: #72a427;
}
body.top-smart #dateSearch .searchNav li a {
  background: none !important;
  border: none;
}
body.top-smart #dateSearch .searchNav li a span {
  padding-top: 33px;
}
.srvOdp a span {
  line-height: 1.3 !important;
}
body.top-smart #keywordSearch {
  margin-top: 10px;
}
#keyword_form {
  padding-top: 10px;
}
body.top-smart #keywordSearch .cancel {
  top: 20px;
}
body.top-smart #keywordSearch .submit {
  top: 10px;
}
/* /gnav swipe style */

.like-button,
.dislike-button {
  cursor: pointer;
  transition: color 0.3s;
}

.like-button,
.dislike-button {
  cursor: pointer;
  transition: color 0.3s;
}

.like-button.selected {
  color: #28a745; /* Bootstrapのsuccess色 */
}

.like-button.selected:hover {
  color: #28a745 !important; /* ホバー時もselectedの色を保持 */
}

.like-button:hover {
  color: #7fa488 !important; /* ホバー時の色 */
}
.like-button-pop {
  color: #7fa488 !important;
  padding-right: 10px;
}

.dislike-button.selected {
  color: #dc3545; /* Bootstrapのdanger色 */
}

.dislike-button.selected:hover {
  color: #dc3545 !important; /* ホバー時もselectedの色を保持 */
}

.dislike-button:hover {
  color: #d58a91 !important; /* ホバー時の色 */
}
.dislike-button-pop {
  color: #d58a91 !important;
}

@keyframes buttonClick {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}

#commentTable {
  overflow: hidden;
  transition: max-height 0.5s ease-in-out;
  max-height: 0;
  margin-top: 10px !important;
  margin-bottom: 10px !important;
}

#commentTable.show {
  max-height: 500px; /* 適当な最大高さ */
}

.rank-title {
  padding-bottom: 1px !important;
}
.top-navi {
  padding-bottom: 0px !important;
}

.btn-light {
  /* font-weight: 400; */
  /* color: #000000 ; */
  /* text-decoration: none !important; */
  background-color: #f3f3f3 !important;
  border-color: #f3f3f3 !important;
}
.btn:focus {
  outline: none !important;
  box-shadow: none !important; /* フォーカス時の影も取り除く */
}
.form-group.text-right-custom {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.text-right-custom {
  margin-right: 10px;
  min-width: 200px;
  text-align: right;
}
.text-left-custom {
  margin-right: 10px;
  min-width: 200px;
  text-align: left;
}
.help-link,
.comment-link {
  color: #54822b !important;
}
.comment-link:hover {
  cursor: pointer;
}
#closeCommentForm {
  color: #888;
}
.send-custom-button {
  padding-left: 8% !important;
  padding-right: 8% !important;
}
/* ご意見・要望を書く */
.search-text {
  font-size: 1rem;
  padding-top: 5px;
  padding-bottom: 5px;
  text-align: left;
}
.text-muted {
  font-size: 1rem;
  margin: 2%;
}
.breadcrumbTop {
  margin-bottom: 1% !important;
}
.wrap .loading {
  width: 110%;
}
.hotel-box .review-best .jds_couponPopUp {
  color: #54822b;
  cursor: pointer;
}

/* ポップアップのスタイル */
.popup {
  position: absolute;
  top: -50px;
  left: 60%;
  transform: translateX(-50%);
  background-color: white;
  border: 1px solid #ddd;
  border-radius: 5px;
  padding: 10px;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, top 0.3s ease;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ポップアップ表示時のスタイル */
.popup.show {
  top: 0;
  opacity: 1;
  visibility: visible;
}

/* ポップアップ内のボタン */
.popup button {
  background-color: #fff;
  border: none;
  border-radius: 3px;
  padding: 5px 20px;
  cursor: pointer;
  margin: 5px 0;
  width: 100%;
  transition: background-color 0.2s ease;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.popup button i {
  margin-right: 8px; /* アイコンとテキストの間隔 */
}

.popup button:hover {
  background-color: #f0f0f0;
}

.form-group-like {
  display: flex;
  align-items: flex-start;
  justify-content: flex-end; /* form-groupを右寄せ */
  gap: 10px; /* ラベルとボタンボックスの間の余白を調整 */
}

.like-button-box {
  display: flex;
  align-items: center;
  background-color: white;
  border-radius: 30px;
  padding: 0px 10px; /* ボタンボックスの横幅を広げるために左右のパディングを増加 */
  box-shadow: 0 0 5px rgba(0, 0, 0, 0.1);
}

.like-button,
.dislike-button {
  background-color: transparent;
  border: none;
  padding: 5px;
  cursor: pointer;
}
.review-button-ico {
  width: 24px; /* アイコンのサイズ */
  height: 24px;
}

.separator {
  width: 1px;
  height: 24px;
  background-color: #ccc;
  margin: 0 10px; /* 線の左右にスペースを追加 */
}

.form-group-like-sp {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.search-text-sp {
  font-size: 1.2rem;
  padding-top: 5px;
  padding-bottom: 5px;
  text-align: left;
}
.commentFieldSP {
  font-size: 1.2rem;
}
#cancelLike,
#cancelDislike {
  color: inherit; /* 親要素の色を継承 */
  text-decoration: none; /* リンクの下線を消す */
}
.send-review-button {
  color: inherit;
}
.review-ico-pop {
  padding-right: 10px;
}
.sp-button-custom {
  font-size: 1.4rem;
}

#feedback-form {
  padding-bottom: 10px;
  padding-top: 10px;
}
dt {
  font-weight: 100 !important;
}
