@charset "UTF-8";
/*Surprice用のcss*/
/* adタグ非表示 */
#sensy-cd-ww-launcher + div + img,
#sensy-cd-ww-launcher + img {
  display: none;
}

iframe[name="google_conversion_frame"] {
  display: none;
}

.kxhead + img {
  display: none;
}

/* general */
body {
  font-family: Arial, Helvetica, sans-serif;
}
body.is-fixed {
  overflow: hidden;
}

.displayNone {
  display: none !important;
}

.m20 {
  margin: 20px !important;
}

.m30 {
  margin: 30px !important;
}

/* 共通パーツ */
/* header */
#page-header {
  display: block;
  height: 60px;
  top: 0;
  width: 100%;
  z-index: 1;
}
#page-header.is-fixed {
  position: fixed;
  box-shadow: 0 0 4px #bbb;
}
#page-header h2 {
  display: none;
}
#page-header .logo {
  width: 60%;
}
#page-header .logo h1 {
  margin-top: 7px;
}
#page-header .head_signin a {
  width: 20%;
}

/* overlayメニュー */
#overlay {
  overflow: auto;
  left: 0;
  right: 0;
  bottom: 0;
}
#overlay.is-fixed {
  position: fixed;
}
#overlay.is-fixed .menu_top {
  position: fixed;
}
#overlay .menu_top {
  z-index: 1;
}
#overlay .head_title {
  font-size: 16px;
}
#overlay .menu_navi li a, #overlay .menu_navi2 li a {
  font-size: 13.6px;
}
#overlay h2 {
  font-weight: normal;
  font-size: 16px;
}
#overlay .toggle {
  font-size: 16px;
}
#overlay .support_list a {
  font-size: 12.8px;
}

.overlay-wrap {
  z-index: 1;
  position: relative;
  overflow: scroll;
}

.overlay-bg {
  z-index: 0;
  position: fixed;
  width: 100%;
  height: 100%;
  margin-top: -5px;
  background: #000;
  opacity: .5;
  cursor: pointer;
}

/* footer */
#page-footer .pagetop {
  display: none;
}

footer ul li a {
  font-size: 12.8px;
  color: #333;
}
footer ul li a:link, footer ul li a:visited {
  color: #333;
}

.footer-simple {
  position: fixed;
  bottom: 0;
  padding: 0;
  width: 100%;
}
.footer-simple .copy {
  padding: 10px;
}

/* ページTOPボタン */
.go-to-top {
  width: 40px;
  height: 40px;
  right: 10px;
  bottom: 10px;
  position: fixed;
  z-index: 1;
}
.go-to-top img {
  width: 100%;
  height: 100%;
}

/* 個人情報に関して、旅行保険に関して */
/* SSL暗号化通信にて～ */
.privacy a, .security a {
  color: #069;
  text-decoration: underline;
}

.privacy {
  padding: 15px;
  background: #eee;
  color: #333;
  font-size: 13px;
  border-top: 1px solid #e5e5e5;
}
.privacy strong {
  font-weight: bold;
  padding-bottom: 5px;
  display: block;
}

.security {
  padding: 12px 14px 18px 14px;
  font-size: 13px;
  line-height: 1.5;
}

#container .inner {
  position: relative;
  width: auto;
}
#container .form_list li.warning {
  border-bottom: none;
}

/* .member */
/* エラー表示 */
.err_log {
  background: #fff;
  padding: 5%;
  border: 1px solid #f00;
}

.forgot {
  line-height: 1.5;
}

/* mypage.aspx */
/* 商品ラベル */
.labelProduct {
  font-size: 10px;
  color: #fff;
  padding: 4px;
  border-radius: 4px;
  float: left;
  margin: 0 4px 4px 0;
}
.labelProduct-air {
  background: #005fa4;
}
.labelProduct-hotel, .labelProduct-pickup {
  background: #ff6200;
}
.labelProduct-dynamic, .labelProduct-tourpack {
  background: #fa5e72;
}
.labelProduct-optional {
  background: #008000;
}

/* フォームパーツ　*/
.nav_global {
  margin-bottom: 20px;
}

span.war_txt {
  display: inline-block;
  width: auto;
  margin-top: 2px;
  margin-left: 0;
  background: url(/mypage/image/ico-warrning.png) no-repeat 7px 49% #ff6067;
  background-size: 14px 13px;
  padding: 3px 10px 3px 26px;
  color: #fff;
  font-size: 11px;
  font-weight: bold;
}

.field-validation-error + .note_ {
  margin-top: 5px;
}

.form_list .heading-item {
  font-size: .8rem;
}
.form_list dl {
  margin-bottom: 10px;
}
.form_list li:last-child {
  border-bottom: none;
}
.form_list span.field-validation-error {
  display: block;
  width: auto;
}
.form_list span.war_txt {
  display: inline-block;
  width: auto;
}
.form_list .passport_name {
  margin-bottom: 5px;
}
.form_list .three_ip input[type="tel"] {
  width: auto;
}
.form_list .one_line.radio {
  margin-bottom: 10px;
}
.form_list .mail-magAdress {
  width: auto;
  margin-right: 0;
}

/* 電話番号フィールド　1列 */
.req .heading {
  margin-bottom: 5px;
}

.confirm .form_list {
  margin: 0 0 30px;
  padding-top: 5px;
}

.oversea_address {
  font-size: .9rem;
  line-height: 1;
  margin: 15px 0;
}
.oversea_address input {
  margin-right: .5rem;
}
.oversea_address + dl dt {
  font-weight: normal;
}

.list_check dd {
  margin-bottom: 5px;
}
.list_check label {
  width: auto;
  margin-right: 20px;
}

.radio {
  margin-bottom: 4px;
}

#container .form_list .oversea_address + dl dt {
  font-weight: normal;
}
#container .form_list #address1Tr dt, #container .form_list #address2Tr dt, #container .form_list #address3Tr dt, #container .form_list #address4Tr dt {
  font-weight: normal;
}

.warning_box {
  margin: 10px 0;
}
.warning_box li {
  margin-bottom: .3rem;
  border-bottom: none;
  text-indent: -.5rem;
  padding: 0 0 0 .5rem;
}

/* リスト */
.listNote li {
  text-indent: -.5rem;
  padding-left: .5rem;
  margin-bottom: .5rem;
}
.listNote li::before {
  content: '●';
  color: #666;
}

/* コンテンツ */
#itemName {
  background: #d4d4d4;
  padding: 10px 65px;
  font-size: 13px;
  text-align: center;
  display: none;
}

/* 会員情報　air_mytravel.aspx */
/* ヘッダ */
.description,
.c_etc3_,
#t-header .common_heading_ {
  color: #555;
  background: #ffd960;
  padding: 10px;
  font-size: 15px;
  line-height: 1.3;
}

/*　会員No.、氏名 */
.customer {
  border-bottom: none;
}

.customer_bot,
.box_.welcome_ {
  background: #ffebad;
  border-bottom: none;
}
.customer_bot .inner_box_,
.box_.welcome_ .inner_box_ {
  padding-left: 18px;
  border-bottom: none;
}
.customer_bot .inner_box_ .text_,
.box_.welcome_ .inner_box_ .text_ {
  font-size: 11px;
}

.customer .customer_name span,
.member_no_ {
  font-size: 14px;
  line-height: 1.3;
}

.customer .name,
.box_.welcome_ .member_name_ {
  margin: 4px 0;
  font-size: 19px;
}

/* 見出し */
.heading2_ {
  color: #333;
  border-top-color: #999;
  border-bottom-color: #999;
}

.common_heading_ {
  font-weight: bold;
}

div.section_.booking_.detail_ .ptn1_ {
  border-color: #ccc;
}

.c_flight_ {
  color: #333;
  background-color: #ffebad;
}

div.section_.flight_ .toggle_,
.heading4_,
div.contents_.cancel_ .section_ .heading4_,
.heading_lb_ {
  border-left-color: #f9be00;
  font-size: 14px;
}

.main_contents .inner:last-of-type {
  border-bottom: 1px solid #ccc;
  margin-bottom: 30px;
}
.main_contents .inner .md_login_sns {
  border-top: none;
  padding: 20px 0;
}

.content h1.headline {
  border-left-color: #f9be00;
}

/* agreement */
.agree {
  text-align: center;
  font-size: 13px;
}
.agree a {
  color: #069;
  text-decoration: underline;
}

#a-02 .inner {
  margin-bottom: 30px;
}
#a-02 .form_list {
  padding: 0;
}
#a-02 .form_list dd {
  padding-bottom: 0;
}
#a-02 .list_check label {
  width: auto;
  margin-right: 20px;
}

/* メールアドレスを保存する */
#b-01 .err_log {
  margin-bottom: 30px;
}
#b-01 .password.form-onlyPasswd {
  border: 1px solid #ccc;
  border-radius: 7px;
}
#b-01 .form_list li:last-child {
  margin-top: 20px;
  font-size: 13px;
  text-align: center;
}
#b-01 .btn_orange {
  height: 100%;
}

/* マイページ */
.sub_box:last-of-type {
  border-bottom: 1px solid #ccc;
  margin-bottom: 30px;
}

#e-01 .color01, #e-01 .color02 {
  color: #333;
}
#e-01 .color01 {
  background: #ffebad;
  border-top: none;
}
#e-01 .color02 {
  background: #ffd960;
  border-top: none;
}
#e-01 .list_history .color01, #e-01 .list_history .color02 {
  color: #000;
}
#e-01 .list_history .color01 {
  background: #ffebad;
}
#e-01 .list_history .color02 {
  background: #ffd960;
}
#e-01 .sub_box .text-importantInfo {
  margin-top: 5px;
  padding: 0;
  text-align: right;
  display: block;
}
#e-01 .sub_box .text-importantInfo.important span {
  padding-right: 0;
}

/* ボタン */
.submit {
  background: none;
}

.btn,
.btn_wrap_ {
  margin: 20px auto;
  width: 270px;
  position: relative;
}
.btn::before,
.btn_wrap_::before {
  content: '';
  display: block;
  position: absolute;
  border-top: 3px solid #444;
  border-right: 3px solid #444;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  width: 6px;
  height: 6px;
  top: 19px;
  left: 28%;
}
.btn input,
.btn_wrap_ input {
  font-weight: bold;
  width: 100%;
  height: 100%;
  display: block;
  border: none;
}

.btn_wrap_ {
  display: block;
  padding: 10px 15px 10px 5px;
}
.btn_wrap_::before {
  top: 15px;
  right: 11%;
  left: inherit;
  border-top-color: #fff;
  border-right-color: #fff;
}

.section_ .btn_wrap_::before {
  display: none;
}

/* Surpriceに新規メッセージを送る */
.booking_.section_ .btn_wrap_::before {
  top: 35px;
  right: 9%;
  border-top-color: #333;
  border-right-color: #333;
}

.btn_wrap_ {
  display: block;
}
.btn_wrap_ .button_ {
  background-color: #f9be00;
}

/* historydetail.aspx */
/* 航空運送規約のページ ボタン　*/
.common_table_ .btn_wrap_ {
  margin: 0 auto;
}

/* 予約の取り消しを行う ボタン　*/
.flight_.section_ {
  margin-bottom: 0;
}
.flight_.section_ + .section_ .btn_wrap_ {
  margin: 30px auto;
  padding: 0;
}
.flight_.section_ + .section_ .btn_wrap_ .button_ {
  margin-top: 0;
}

/* 旅行条件書　condition.aspx */
#SECTION01 {
  padding: 0 10px;
}
#SECTION01 table {
  width: 100%;
}

/* 旅のワンコインクーポン */
#option_service .button_::before {
  top: 23px;
  right: 4%;
}

/* クレジットカード */
.ico_caution_ {
  line-height: 1.5;
  margin-bottom: 15px;
}
.ico_caution_.ico_l_ {
  background-position: left top;
}

.arrow_w_ {
  padding-right: 0;
  font-weight: bold;
  background: none;
}

.arrow_w_ {
  color: #333;
}

a.button_.c_etc3_ {
  color: #333;
  background: #f9be00;
}

.btn-yellow {
  color: #444;
  font-weight: bold;
  background: #f9be00;
  border-radius: 6px;
  height: 48px;
}
.btn-yellow input {
  background: transparent;
}

.btn-gray {
  width: 210px;
  height: 100%;
  padding: 0 0 0 10px;
  line-height: 2.9;
  color: #fff;
  font-weight: bold;
  background: #999;
  border-radius: 9px;
  height: 48px;
}
.btn-gray::before {
  display: none;
}
.btn-gray input {
  background-position: 21px 50%;
  padding: inherit;
}

.arrow-downward::before {
  top: 17px;
  left: 15%;
  -webkit-transform: rotate(135deg);
      -ms-transform: rotate(135deg);
          transform: rotate(135deg);
}

/* SNSログイン */
.md_login_sns {
  width: 270px;
  padding: 30px 0;
  margin: 0 auto;
  display: block;
  border-left: none;
  border-top: 1px dotted #ccc;
}
.md_login_sns_headline {
  text-align: center;
  font-size: .8rem;
  margin-bottom: 15px;
  font-weight: normal;
}
.md_login_sns_headline.btn {
  display: block;
  color: #333;
  font-weight: bold;
  height: auto;
  padding: 10px;
}
.md_login_sns_headline.btn::before {
  top: 19px;
}
.md_login_sns_list {
  max-width: 100%;
}
.md_login_sns_list li {
  margin-bottom: 20px;
}
.md_login_snsBtn {
  border-radius: 5px;
  height: 40px;
}
.md_login_snsBtn .md_login_snsicon {
  width: 29%;
}
.md_login_snsBtn .md_login_snsicon::before {
  background-size: 80%;
  margin: 0 auto;
}
.md_login_snsBtn span, .md_login_snsBtn.is_fb, .md_login_snsBtn.is_tw, .md_login_snsBtn.is_gp, .md_login_snsBtn.is_yh {
  box-shadow: none;
}
.md_login_sns_link {
  font-size: .8rem;
  text-decoration: underline;
}
.md_login_sns_link a {
  color: #2361ad;
}

/* 会員メニュー */
.wrap_box {
  background: #f3bb06;
}

/* アコーディオンのアイコン */
.menu_member .caption.open .txt, .menu_member .caption.open .headline, .menu_member .caption.close .txt, .menu_member .caption.close .headline, .caption_reg.open .txt, .caption_reg.open .headline, .caption_reg.close .txt, .caption_reg.close .headline {
  position: relative;
  background: none;
}
.menu_member .caption.open .txt::before, .menu_member .caption.open .txt::after, .menu_member .caption.open .headline::before, .menu_member .caption.open .headline::after, .menu_member .caption.close .txt::before, .menu_member .caption.close .txt::after, .menu_member .caption.close .headline::before, .menu_member .caption.close .headline::after, .caption_reg.open .txt::before, .caption_reg.open .txt::after, .caption_reg.open .headline::before, .caption_reg.open .headline::after, .caption_reg.close .txt::before, .caption_reg.close .txt::after, .caption_reg.close .headline::before, .caption_reg.close .headline::after {
  content: '';
  display: block;
  position: absolute;
  right: 0;
}
.menu_member .caption.open .txt::before, .menu_member .caption.open .headline::before, .menu_member .caption.close .txt::before, .menu_member .caption.close .headline::before, .caption_reg.open .txt::before, .caption_reg.open .headline::before, .caption_reg.close .txt::before, .caption_reg.close .headline::before {
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 8px;
}
.menu_member .caption.open .txt::after, .menu_member .caption.open .headline::after, .menu_member .caption.close .txt::after, .menu_member .caption.close .headline::after, .caption_reg.open .txt::after, .caption_reg.open .headline::after, .caption_reg.close .txt::after, .caption_reg.close .headline::after {
  color: #f9be00;
  font-weight: bold;
  font-size: 15px;
  top: 11px;
}
.menu_member .caption.open .txt::after, .menu_member .caption.open .headline::after, .caption_reg.open .txt::after, .caption_reg.open .headline::after {
  content: '－';
}
.menu_member .caption.close .txt::after, .menu_member .caption.close .headline::after, .caption_reg.close .txt::after, .caption_reg.close .headline::after {
  content: '＋';
}

.menu_member .caption .txt {
  padding: 13px 10px 13px 13px;
  color: #fff;
  font-weight: bold;
  font-size: 14px;
  margin-right: 10px;
}

.caption_reg.close .headline, .caption_reg.open .headline {
  background: #f1f1f1;
}
.caption_reg.close .headline::before, .caption_reg.open .headline::before {
  top: 5px;
  right: 5px;
}
.caption_reg.close .headline::after, .caption_reg.open .headline::after {
  top: -2px;
  right: 5px;
}

/* ciao_contact2 */
.box_, .box_ .inner_box_ {
  padding-top: 15px;
}

/* 予約商品　枠 */
.booking_ {
  padding-top: 10px;
  margin-bottom: 10px;
}

/* 表組み */
.common_table_ {
  margin-bottom: 15px;
}

/* エラー系 */
body div .error_box_ {
  color: #fff;
  background: #ff6067 url(/mypage/image/ico-warrning.png) 7px 49% no-repeat;
  background-size: 14px;
  border: none;
  font-size: 11px;
  font-weight: bold;
}
body div.wrapper_ div.error_box_ > .error_msg_ {
  background: none;
}

/* ローディングアニメーション */
.loadingImg {
  width: 20%;
  position: absolute;
  top: 25%;
  left: 0;
  right: 0;
  margin: auto;
}

/* フッターの共通マイページ、トピック一覧リンク */
#mypageLink {
  margin-top: 60px;
}
#mypageLink .rwl {
  border-bottom: none;
  border-top: 1px solid #cecece;
  background: #f5f5f5;
}
#mypageLink .rwl:last-child {
  border-bottom: 1px solid #cecece;
}
#mypageLink .di-link {
  padding: 14px 0;
  width: 100%;
  overflow: hidden;
}
#mypageLink .aor {
  padding: 0 0 0 10px;
  display: block;
  float: left;
  font-size: 14px;
  color: #333;
}

/* 会員メニュー */
.di-link, .mlink-text {
  position: relative;
}
.di-link::after, .mlink-text::after {
  content: '';
  display: block;
  position: absolute;
  border-top: 3px solid #f9be00;
  border-right: 3px solid #f9be00;
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
  right: 5%;
  top: 15px;
  width: 7px;
  height: 7px;
}

.mod-link-boxs {
  width: 100%;
  overflow: hidden;
}

.member_content {
  padding: 15px 10px;
  border-top: 1px solid #e0ab00;
}

.mod-link-ta {
  display: table;
  width: 100%;
}

.mlink-only {
  background-color: #fff;
  height: auto;
  float: left;
  width: 100%;
  display: table-cell;
  vertical-align: middle;
  box-sizing: border-box;
  border: 1px solid #ddd;
  border-top: none;
}
.mlink-only.first_link {
  border-radius: 10px 10px 0 0;
}
.mlink-only.edge {
  border-radius: 0 0 10px 10px;
}

.mlink-text {
  padding: 12px 0 12px 10px;
  font-weight: normal;
  color: #333;
  font-size: 14px;
}

/* SSL証明書 */
#div_trendmicro_site_seal {
  border: none;
  margin: 7px auto;
}

/* historydetail.aspx */
#announcement {
  margin-top: 10px;
}

/* 予約取り消し reservecancel.aspx */
.box_ .link_, .box_ .fc_red_ {
  padding: 0 10px;
}

#modal-content {
  width: 70%;
  border-radius: 4px;
  border: none;
  box-shadow: 0 0 5px #000;
}
#modal-content a {
  color: #069;
  display: block;
  text-align: right;
  font-size: 12px;
}

#confirmation {
  padding-top: 0;
}

/* キャンセルポリシー */
#cxlpolicy div.headchui, #cxlpolicy div.cxlfee, #cxlpolicy div.cxlfeebox, #cxlpolicy div.footchui {
  padding: 10px;
}
#cxlpolicy .cxlfeebox div {
  padding: 0;
}
#cxlpolicy .list, #cxlpolicy .headchui_com {
  padding: 0;
}
#cxlpolicy .headchui_com dt {
  width: 3.5%;
}
#cxlpolicy .headchui_com dd {
  width: 95%;
}
