@charset "Shift_JIS";

/* ---------------------------------------
 メッセージカード作成
---------------------------------------- */
#frmMessageCard h3.sub-ttl { padding: 0; margin: 0 0 10px 0; font-size: 14px; font-weight: 500;}
#frmMessageCard .block-messagecard-create--error { margin: 0 0 20px; font-size: 14px; text-align: center; color: #EC0000;}
#frmMessageCard .block-messagecard-message-length-error { padding: 0 0 0 1em; margin: 0 0 20px; font-size: 14px; text-indent: -1em; color: #EC0000; display: none;}
#frmMessageCard .block-messagecard-create .block-messagecard-create--error { text-align: left;}
#frmMessageCard .block-messagecard-create { padding: 40px; margin: 0 0 70px; background: #F2F2F2;}
#frmMessageCard .block-messagecard-head { margin: 0 0 60px 0;}
#frmMessageCard .block-messagecard-head h2 { padding: 0; margin: 0 0 20px 0; border: none; font-size: 20px; font-weight: 400;}
#frmMessageCard .block-messagecard-frame-inner { width: 100%; display: flex; flex-wrap: wrap; justify-content: space-between;}
#frmMessageCard .block-messagecard-frame--title { display: none;}
#frmMessageCard .block-messagecard-preview { width: calc(50% - 20px); padding: 40px; border-radius: 6px; background: #FFF;}
#frmMessageCard .block-messagecard-setting { width: calc(50% - 20px);}

/* 左フレーム
---------------------------------------- */
/* カードイラスト */
#frmMessageCard .block-messagecard-preview--img { max-width: 400px; margin: 0 auto 40px;}
#frmMessageCard .block-messagecard-preview--img img { width: 100%;}

/* メッセージ入力 */
#frmMessageCard .block-messagecard-preview--text-wrap { margin: 0 0 40px 0;}
#frmMessageCard .block-messagecard-preview--text { width: 100%; max-width: 100%; min-height: 230px; line-height: 2.0;}
#frmMessageCard .block-messagecard-preview--text.error { background: #FFE5E5;}
#frmMessageCard .block-messagecard-preview--note { margin: 7px 0 0 0; display: flex; align-items: center; justify-content: flex-end;}
#frmMessageCard .block-messagecard-preview--note-text { color: #CCC; font-size: 10px;}
#frmMessageCard .block-messagecard-preview--note-text.active { color: #F00;}
#frmMessageCard .block-messagecard-preview--counter { font-size: 12px; font-weight: 400; color: #626264;}
#frmMessageCard .block-messagecard-preview--counter span { font-size: 12px; font-weight: 400; color: #626264;}

/* 本名またはニックネーム */
#frmMessageCard .block-messagecard-preview--giver-name { padding: 20px 0; margin: 10px 0 0 0; border-top: #949497 1px dashed; border-bottom: #949497 1px dashed; display: flex; align-items: center;}
#frmMessageCard .block-messagecard-preview--giver-name input { width: calc(100% - 2em - 15px); margin: 0 15px 0 0; font-weight: 700; text-align: right;}
#frmMessageCard .block-messagecard-preview--giver-name input + span { color: #707070; font-size: 15px; font-weight: bold; word-break: keep-all; white-space: nowrap;}
#frmMessageCard .block-messagecard-preview--giver-name span.efo { width: 75%; display: flex; align-items: center;}
#frmMessageCard .block-messagecard-preview--giver-name span.efo + img { margin: 0 0 0 15px;}
#frmMessageCard .block-messagecard-preview--giver-name.error,
#frmMessageCard .block-messagecard-preview--giver-name.error input { background: #FFE5E5;}
#frmMessageCard .block-messagecard-preview--giver-note { margin: 7px 0 0 0; display: flex; justify-content: space-between;}
#frmMessageCard .block-messagecard-preview--giver-note p { font-size: 10px; font-weight: bold; text-align: right; color: #626264; flex: 1;}
#frmMessageCard .block-messagecard-preview--giver-note .block-messagecard-giver--note { display: none;}

/* 右フレーム
---------------------------------------- */
#frmMessageCard .block-messagecard-setting .swiper-button-prev:after,
#frmMessageCard .block-messagecard-setting .swiper-button-next:after { font-size: 20px; font-weight: bold; color: #707070;}
#frmMessageCard .block-messagecard-setting .swiper-button-prev:after { position: relative; left: -2px;}
#frmMessageCard .block-messagecard-setting .swiper-button-prev,
#frmMessageCard .block-messagecard-setting .swiper-button-next {
  width: 50px;
  height: 50px;
	border: #DDD 1px solid;
	border-radius: 50px;
	line-height: 1.0;
  display: flex;
	justify-content: center;
	align-items: center;
  background: #FFF;
}
#frmMessageCard .block-messagecard-setting .swiper-button-prev { left: 25px;}
#frmMessageCard .block-messagecard-setting .swiper-button-next { right: 25px;}
#frmMessageCard .block-messagecard-setting .swiper-button-disabled { display: none !important;}

/* カードのカテゴリー選択 */
#frmMessageCard .block-messagecard-message { padding: 35px 45px; margin: 0 0 40px 0; border-radius: 8px; background: #FFF; position: relative;}
#frmMessageCard .block-messagecard-message .swiper-container { position: static;}
#frmMessageCard .block-messagecard-message .swiper-slide { border: #FFF 2px solid; text-align: center; position: relative;}
#frmMessageCard .block-messagecard-message .swiper-slide label { padding: 0; margin: 0;}
#frmMessageCard .block-messagecard-message .swiper-slide label:hover { opacity: .8;}
#frmMessageCard .block-messagecard-message .swiper-slide figure { width: 100%; height: 128px; margin: 0 0 10px 0;}
#frmMessageCard .block-messagecard-message .swiper-slide img { max-width: 100%; vertical-align: top;}
#frmMessageCard .block-messagecard-message .swiper-slide span { padding: 0 0 10px; font-size: 14px; font-weight: 400; line-height: 1.4; word-break: break-all; display: block;}
#frmMessageCard .block-messagecard-message .swiper-slide input { display: none;}
#frmMessageCard .block-messagecard-message .swiper-slide input:checked + figure:before {
  content: '';
  width: 100%;
  height: 100%;
  border: #BA1A1A 2px solid;
	box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
	right: 0;
	bottom: 0;
  opacity: 1;
}

/* カードのイラストを選択 */
#frmMessageCard .block-messagecard-card { padding: 35px 35px 35px 45px; margin: 0 0 40px; border-radius: 6px; position: relative; background: #FFF;}
#frmMessageCard .block-messagecard-card .swiper-container { display: none !important;}
#frmMessageCard .block-messagecard-card .swiper-container.show { display: block !important;}
#frmMessageCard .block-messagecard-card .swiper-wrapper { 
	width: 100% !important;
	height: auto !important;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row !important;
	justify-content: flex-start;
	transform: unset !important;
	transition-property: unset !important;
}
#frmMessageCard .block-messagecard-card .swiper-slide {
	width: calc((100% - 40px)/4) !important;
	height: auto !important;
	padding: 0;
	margin: 0 10px 10px 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #F2F2F2;
	position: relative;
}
#frmMessageCard .block-messagecard-card .swiper-slide label { padding: 100% 0 0 0; margin: 0;}
#frmMessageCard .block-messagecard-card .swiper-slide label figure { padding: 0; margin: 0; position: absolute; top: 0; left: 0; right: 0; bottom: 0;}
#frmMessageCard .block-messagecard-card .swiper-slide input { display: none;}
#frmMessageCard .block-messagecard-card .swiper-slide input:checked + figure:before {
	content: '';
	width: 100%;
	height: 100%;
	border: #BA1A1A 2px solid;
	box-sizing: border-box;
	position: absolute;
	top: 0;
	left: 0;
}
#frmMessageCard .block-messagecard-card .swiper-slide figure { width: 100%; height: 100%; padding: 0; margin: 0; display: flex;}
#frmMessageCard .block-messagecard-card .swiper-slide img { max-width: 100%; max-height: 100%; vertical-align: top;}
#frmMessageCard .block-messagecard-card .swiper-button-prev,
#frmMessageCard .block-messagecard-card .swiper-button-next { display: none !important;}

/* 定型文 */
#frmMessageCard .block-messagecard-setting .block-messagecard-fixed-message { margin: 0 0 35px 0;}
#frmMessageCard .block-messagecard-setting .block-messagecard-fixed-message select { width: 100%; max-width: 100%; background-color: #FFF;}

#frmMessageCard .block-messagecard-giver--note { margin: 35px 0 0 0; font-size: 14px; font-weight: 400; text-align: right; text-decoration: underline; color: #1D3994; cursor: pointer;}
#frmMessageCard .block-messagecard-giver--note:hover { text-decoration: none;}

/* TOPへ戻る リンク */
#frmMessageCard div.shopping_link_ { margin-top: 40px;}

/* メッセージカードと個人情報のお取り扱いについて（モーダル）*/
#frmMessageCard .block-messagecard-privacy-modal { width: 100vw; height: 100vh; display: none; position: fixed; top: 0; left: 0; z-index: 111;}
#frmMessageCard .block-messagecard-privacy-modal--bg { width: 100%; height: 100%; position: absolute; top: 0; left: 0; background: rgba(0,0,0,0.5);}
#frmMessageCard .block-messagecard-privacy-modal--contents { width: 600px; padding: 40px 56px; border-radius: 12px; margin: auto; position: absolute; top: 30%; left: 0; right: 0; background: #FFF;}
#frmMessageCard .block-messagecard-privacy-modal--close { margin: 0 0 25px 0;}
#frmMessageCard .block-messagecard-privacy-modal--close span {
  width: 163px;
  height: 40px;
  padding: 0;
  margin: 0;
  border: #333 1px solid;
  border-radius: 20px;
  outline: none;
  font-size: 16px;
  font-weight: bold;
	text-decoration: none;
  color: #333;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #FFF;
	cursor: pointer;
	transition: 0.2s;
}
#frmMessageCard .block-messagecard-privacy-modal--close span::before {
  content: '';
  width: 8px;
  height: 8px;
	margin: 0 6px 0 0;
  border-right: #333 1px solid;
  border-top: #333 1px solid;
  display: block;
  transform: rotate(-135deg);
}
#frmMessageCard .block-messagecard-privacy-modal--close span:hover { opacity: 0.7;}
#frmMessageCard .block-messagecard-privacy-modal--contents-title { margin: 0 0 25px 0; font-size: 24px; font-weight: 500; line-height: 1.4; text-align: center;}
#frmMessageCard .block-messagecard-privacy-modal--contents ul { margin: 0 0 20px;}
#frmMessageCard .block-messagecard-privacy-modal--contents li { padding: 0 0 0 1em; font-size: 16px; text-indent: -1em; line-height: 1.7;}
#frmMessageCard .block-messagecard-privacy-modal--contents li + li { margin-top: 10px;}

/* メッセージカードなしの場合 */
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-frame-inner { padding: 40px; border-radius: 6px; background: #FFF; display: block;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-frame--title { display: block;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview { width: 450px; padding: 0; border: 0; border-radius: 0; background: none;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--img,
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--text-wrap,
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver .sub-ttl,
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver .supplement_,
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-setting { display: none !important;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver-name { border: none; background: #FFF; padding: 0; position: relative;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver-name span.efo { min-width: 630px;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver-note { margin: 20px 0 0 0;}
#frmMessageCard .block-messagecard-frame.not-create .block-messagecard-preview--giver-note .block-messagecard-giver--note { margin: 0; display: block;}
#frmMessageCard .block-messagecard-giver--count { font-size: 10px; font-weight: bold; color: #CCC;}

/* ---------------------------------------
 ソーシャルギフト 各STEP共通パーツ
---------------------------------------- */
/* フロー・タイトル */
div.giftlist_header_ .giftlist_flow_ { text-align: center;}
div.giftlist_header_ .giftlist_flow_ img { width: 671px;}
div.giftlist_header_ .giftlist_flow_ + .giftlist_header_inner_ { margin-top: 40px;}
div.giftlist_header_ + .giftlist_header_inner_ { margin-top: 40px;}
div.giftlist_header_ .giftlist_header_inner_ { max-width: 1440px; min-width: 1040px; margin: 0 auto 20px;}
div.giftlist_header_ .giftlist_header_inner_ .gift_text2_ { font-size: 16px; font-weight: 400;}

div.giftlist_ h1.gift_headline_ { padding: 0; margin: 0 0 16px 0; font-size: 32px; font-weight: 400; line-height: 1.4;}
div.giftlist_ h2.gift_headline_ { padding: 12px 16px; margin: 0 0 40px 0; font-size: 20px; font-weight: 400; line-height: 1.4; letter-spacing: 0.5px; background: #F2F2F2;}
div.giftlist_ h2.gift_area_headline_ { padding: 12px 16px; margin: 0 0 40px 0; font-size: 20px; font-weight: 400; line-height: 1.4; letter-spacing: 0.5px; background: #F2F2F2;}

div.giftlist_ .submit_ { margin: 40px 0 60px; display: flex; flex-direction: column; justify-content: center; align-items: center;}
div.giftlist_ .submit_ .page_back_ { padding: 0; margin: 20px 0 0 0; border: none; font-size: 16px; text-decoration: underline; color: #1D3994; background: none;}

/* ---------------------------------------
 ソーシャルギフト STEP01
---------------------------------------- */
/* ギフトお届け状況はこちら */
div.page_giftinfo_ .gift_status_ { padding: 24px 0; border-top: #DDD 1px solid; border-bottom: #DDD 1px solid; font-size: 18px; font-weight: 500; display: flex; justify-content: center;}
div.page_giftinfo_ .gift_status_ dd { color: #EC0000;}
div.page_giftinfo_ .gift_status_ a { font-size: 18px; font-weight: 500; padding: 0 0 17px; position: relative;}
div.page_giftinfo_ .gift_status_ a:after { 
	content: '';
	width: 10px;
	height: 10px;
	margin: auto;
	border-right: #333 2px solid;
	border-bottom: #333 2px solid;
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0;
	transform: rotate(45deg);
}
div.page_giftinfo_ .gift_status_ a:hover { text-decoration: none; opacity: .8;}

/* メッセージカード */
div.page_giftinfo_ .gift_messagecard_frame_ { padding: 40px 0; margin: 0 0 60px 0; position: relative; z-index: 1; background: #F2F2F2;}
div.page_giftinfo_ .gift_messagecard_frame_::before { content: ''; background: #F2F2F2; display: block; position: absolute; top: 0; left: -50vw; right: -50vw; bottom: 0; z-index: 1;}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_ {
  width: 670px;
  margin: 0 auto 20px;
  padding: 40px;
  border: #DDD 1px solid;
  border-radius: 8px;
  background: #FFF;
  box-shadow: 0 9px 6px rgba(0, 0, 0, 0.05);
	position: relative;
	z-index: 2;
}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_img_ { margin: 0 0 25px; text-align: center;}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_img_ img { width: 100%;}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_text_ { font-size: 16px; line-height: 2.3; word-break: break-all;}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_giver_ {
	padding: 18px 10px;
	margin: 20px 0 0;
	border-top: #949497 1px dashed;
	border-bottom: #949497 1px dashed;
	font-size: 18px;
	font-weight: 500;
	text-align: right;
}
div.page_giftinfo_ .gift_messagecard_frame_ .gift_messagecard_giver_.no_message_ { margin: 0; text-align: center;}

/* ギフト商品 */
div.page_giftinfo_ .gift_item_list_ { width: 1050px; margin: 0 auto 30px;}
div.page_giftinfo_ .gift_item_list_ li { padding: 30px 60px; border: #D2D2D2 1px solid; background: #FFF; display: flex; justify-content: flex-start; align-items: center;}
div.page_giftinfo_ .gift_item_list_ li + li { margin-top: 10px;}
div.page_giftinfo_ .gift_item_list_ .gift_item_img_ { width: 160px; text-align: center;}
div.page_giftinfo_ .gift_item_list_ .gift_item_img_ img { width: 160px; vertical-align: top;}
div.page_giftinfo_ .gift_item_list_ .gift_item_name_ { width: 620px; padding: 0 40px; font-size: 16px; font-weight: 400; line-height: 1.6;}
div.page_giftinfo_ .gift_item_list_ .gift_item_qty_  { margin: 0 0 0 auto; font-size: 16px; font-weight: 400; display: flex; justify-content: flex-end;}
div.page_giftinfo_ .gift_item_list_ .gift_item_qty_ dt { font-size: 16px; font-weight: 400;}
div.page_giftinfo_ .gift_item_list_ .gift_item_qty_ dd { font-size: 16px; font-weight: 400;}
div.page_giftinfo_ .gift_item_list_ .gift_item_status_ { min-width: 170px; font-size: 14px; font-weight: 500; line-height: 1.7;}
div.page_giftinfo_ .gift_item_list_ .gift_item_status_ dd { color: #EC0000;}

div.page_giftinfo_ .gift_item_list_.status_ .gift_item_qty_ { 
	min-height: 62px;
	padding: 0 20px;
	margin: 0 20px 0 0;
	border-left: #DDD 1px solid;
	border-right: #DDD 1px solid;
	display: flex;
	align-items: center;
}
div.page_giftinfo_ .gift_item_list_.status_ li { padding: 30px;}

/* ギフト受取有効期限 */
div.page_giftinfo_ .gift_item_limit_ { width: 1050px; padding: 35px 60px; margin: 0 auto 40px; border: #D2D2D2 1px solid; background: #FFF;}
div.page_giftinfo_ .gift_item_limit_ dt { margin: 0 0 10px; font-size: 16px; font-weight: 400; text-align: center; line-height: 1.0;}
div.page_giftinfo_ .gift_item_limit_ dd { font-size: 20px; font-weight: 400; text-align: center; color: #EC0000;}

/* 登録完了済み or 期限切れ */
div.page_giftinfo_ .gift_completed_ { margin: 50px auto; text-align: center;}
div.page_giftinfo_ .gift_completed_ span {
  width: 256px;
  height: 56px;
	margin: 0 auto;
  border: none;
  border-radius: 56px;
  font-size: 16px;
	font-weight: 700;
	text-decoration: none;
  color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
  background: #D2D2D2;
  transition: 0.2s;
}

/* サブミット */
div.page_giftinfo_ .gift_btn_container_ { display: flex; justify-content: center; column-gap: 30px;}
div.page_giftinfo_ .gift_btn_container_ .gift_btn_ .yellow_button_ { 
	width: 256px;
	height: 56px;
	margin: 0 auto;
	border: #CC0000 1px solid;
	border-radius: 56px;
	font-size: 16px;
	font-weight: 700;
	text-decoration: none;
	color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
	background: #CC0000;
}
div.page_giftinfo_ .gift_btn_container_ .gift_btn_ p { margin: 10px 0 0 0; font-size: 12px; text-align: left;}
div.page_giftinfo_ .gift_btn_container_ .gift_btn_ .yellow_button_:disabled { border: #D2D2D2 1px solid; color: #FFF; background: #D2D2D2;}
div.page_giftinfo_ .gift_btn_container_ .gift_btn_ .yellow_button_:not(:disabled):hover { opacity: 0.7; text-decoration: none;}

/* ---------------------------------------
 ソーシャルギフト STEP02 - 入力
---------------------------------------- */
div.page_giftdest_input_.giftlist_ h2.gift_headline_ { padding: 0; margin: 40px 0 0 0; background: #FFF;}
div.page_giftdest_input_.giftlist_ h2.gift_area_headline_ { padding: 0; margin: 0 0 24px 0; background: #FFF;}

/* 配送情報入力 */
div.page_giftdest_input_ table.formdetail_.customer_ { margin: 0 0 60px 0;}
div.page_giftdest_input_ table.formdetail_.customer_ tbody tr.email_confirm_ td p.supplement_:not(.indent_) { margin-bottom: 0;}

/* 配送オプションの設定 */
div.giftlist_ div.order_delivery_ { border: none; margin: 0 0 60px 0;}
div.giftlist_ div.order_delivery_ .order_delivery_dest_goods_inner_ { padding: 0 60px; margin: 0 0 10px 0; border: #D2D2D2 1px solid;}
div.giftlist_ div.order_delivery_ p.block_title_ { margin: 0 0 10px 0; font-size: 20px; font-weight: 400;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ { padding: 30px 0; display: flex; justify-content: space-between; align-items: center;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_box_img_ { width: 160px;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_box_img_ img { max-width: 100%; vertical-align: top;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_box_detail_ { width: calc(100% - 200px);}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_detail_ { display: flex; justify-content: space-between; align-items: center;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_detail_ .gift_goods_name_ { font-size: 16px; font-weight: 400;}
div.giftlist_ div.order_delivery_ .goodsinfo_box_ .goodsinfo_detail_ .qty_ { min-width: 120px; font-size: 16px; font-weight: 400; text-align: right;}

/* 配送方法（佐川） */
div.giftlist_ div.order_delivery_ .goods_delivery_method_ { padding: 20px 0; border-top: #D2D2D2 1px solid;}
div.giftlist_ div.order_delivery_ .goods_delivery_method_ div .sagawa_message_ { font-size: 16px; font-weight: 400; color: #EC0000;}

/* お届け日時 */
div.giftlist_ div.order_delivery_ .goods_delivery_date_ { padding: 20px 0; border-top: #D2D2D2 1px solid;}
div.giftlist_ div.order_delivery_ .goods_delivery_spec_ { display: flex;}
div.giftlist_ div.order_delivery_ .goods_delivery_spec_ .consignor_ { width: calc(100% - 700px); padding: 10px 0 0 0; font-size: 16px; font-weight: 400;}
div.giftlist_ div.order_delivery_ .goods_delivery_spec_ .goods_delivery_ { max-width: 670px; margin: 0 0 0 auto;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ { display: flex; justify-content: flex-end; column-gap: 30px;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ .date_  { width: 320px;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ .time_  { width: 320px;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ .ttl_   { margin: 0 0 7px 0; font-size: 14px; font-weight: 500;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ .child_ { min-height: 56px; font-size: 16px; font-weight: 400;	text-decoration: none; display: flex; align-items: center;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ select  { width: 100%; max-width: 100%; font-size: 16px; font-weight: 400;}
div.giftlist_ div.order_delivery_ .date_time_wrap_.unselectables_ .child_ { min-height: 36px;}
div.giftlist_ div.order_delivery_ .date_time_wrap_ + p.efo-error_ { text-align: right;}
div.giftlist_ div.order_delivery_ p.delivery_notice_ { margin-top: 30px; font-size: 12px; font-weight: 400; text-align: right;}
div.giftlist_ div.order_delivery_ p.delivery_notice_ + p.delivery_notice_ { margin: 0;}

/* ---------------------------------------
 ソーシャルギフト STEP03 - 確認
---------------------------------------- */
div.giftlist_ table.formdetail_.delivery_address_ { padding: 0; margin: 0 0 30px 0; border: none; display: block;}
div.giftlist_ table.formdetail_.delivery_address_ tbody,
div.giftlist_ table.formdetail_.delivery_address_ tr { padding: 0; margin: 0; border: none; display: block;}
div.giftlist_ table.formdetail_.delivery_address_ th { padding: 10px 16px; margin: 0 0 10px 0; border: none; font-size: 14px; font-weight: 400; line-height: 1.0; display: block; background: #F2F2F2;}
div.giftlist_ table.formdetail_.delivery_address_ td { 
	padding: 10px 16px;
	margin: 0 0 20px 0;
	border: none;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.7;
	display: flex;
	justify-content: space-between;
	background: #FFF;
}
div.giftlist_ .address_edit_button_,
div.giftlist_ .customer_edit_button_ { min-width: 100px; padding: 0 0 0 60px;}
div.giftlist_ .address_edit_button_ a,
div.giftlist_ .customer_edit_button_ a {
	width: 40px;
	padding: 26px 0 0 0;
	margin: 0;
	border: none;
	font-size: 16px;
	text-align: center;
	text-decoration: none;
	display: block;
	background: url("../../img/usr/icon/edit.png") center top no-repeat;
	-webkit-background-size: 24px auto;
	background-size: 24px auto;
}
div.giftlist_ .address_edit_button_ a:hover,
div.giftlist_ .customer_edit_button_ a:hover { opacity: 0.7;}

/* ---------------------------------------
 ソーシャルギフト STEP04 - 登録完了
---------------------------------------- */
div.page_giftdest_complete_ div.giftlist_header_inner_ { margin-bottom: 40px; }
div.page_giftdest_complete_ div.giftlist_header_inner_ p.gift_text_ { font-size: 16px; font-weight: 400; line-height: 1.7;}
div.page_giftdest_complete_ div.giftlist_header_inner_ p.gift_text_.annot { margin: 0 0 20px 0; color: #EC0000;}
div.page_giftdest_complete_ h2.gift_headline_ { margin-bottom: 20px;}
div.page_giftdest_complete_ table.formdetail_.delivery_address_ { margin-top: 0;}

/* 会員登録はこちら */
div.page_giftdest_complete_ .gift_text3_ { margin: 30px 0 10px 0; font-size: 16px; font-weight: 400; text-align: center;}
div.page_giftdest_complete_ div.inputimage_ { margin: 0 0 60px 0; text-align: center;}
div.page_giftdest_complete_ div.inputimage_ input[type="submit"] {
  width: 310px;
  height: 56px;
	margin: 0 auto;
  border: none;
  border-radius: 56px;
  font-size: 16px;
	font-weight: 700;
	text-decoration: none;
  color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
  background: #CC0000;
  transition: 0.2s;
}
div.page_giftdest_complete_ div.inputimage_ input[type="submit"]:hover { opacity: 0.7;}

/* 続けてお買物される方はこちら */
div.page_giftdest_complete_ .gift_btn_list_ { margin: 80px 0; font-size: 16px; font-weight: 400; text-align: center;}
div.page_giftdest_complete_ .gift_btn_list_ li + li { margin-top: 40px;}
div.page_giftdest_complete_ .gift_btn_list_ li a {
  width: 310px;
  height: 56px;
	padding: 0;
	margin: 10px auto 0;
  border: none;
  border-radius: 56px;
  font-size: 16px;
	font-weight: 700;
	text-decoration: none;
  color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
  background: #CC0000;
  transition: 0.2s;
}
div.page_giftdest_complete_ .gift_btn_list_ li a:hover { opacity: 0.7;}
div.page_giftdest_complete_ .gift_btn_list_ li .gift_btn2_ a { border-color: #333; color: #333; background: #FFF;}

/* ---------------------------------------
 ソーシャルギフト
---------------------------------------- */
.social_gift_bg_ { width: 100%; height: 100%; display: none; background: rgba(112, 112, 112, 0.94); position: fixed; top: 0; left: 0; z-index: 101;}
.social_gift_ {
  width: 770px;
  max-height: calc(90% - 115px);
  padding: 70px 45px 45px;
  display: flex;
  flex-direction: column;
  background: #FFF;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.social_gift_inner_ { overflow-y: auto;}
.social_gift_ h4 { margin: 0 0 30px; font-size: 18px; font-weight: bold; text-align: center; color: #222;}
.social_gift_ p { font-size: 15px; line-height: 1.6;}
.social_gift_ p span { font-weight: bold; color: #FF0000;}
.social_gift_close_ {
  width: 320px;
  padding: 15px 0;
  margin: 0 0 10px;
  border: #CCC 1px solid;
  border-radius: 4px;
  font-size: 15px;
  text-align: center;
  color: #222;
  background: #EDEDED;
  display: block;
  cursor: pointer;
  transition: .2s;
}
.social_gift_close_:hover { opacity: 0.7;}
.social_gift_img_ { margin: 20px 0 40px;}
.social_gift_link_ { margin: 10px 0 0;}
.social_gift_link_ a { font-size: 10px; text-decoration: underline; color: #404040;}
.social_gift_link_ a:hover { text-decoration: none;}

/* ---------------------------------------
 のし設定
---------------------------------------- */
#noshisettingfrm dl.formdetail_ dd input[name="wrapping_name_text"],
#noshisettingfrm dl.formdetail_ dt#wrapping_name,
#noshisettingfrm dl.formdetail_ dt#wrapping_name + dd { display: none;}
