@charset "UTF-8";
body {
  background: #fff;
}

ul {
  list-style: none;
}

#col1 #ph_main {
  margin: 0 !important;
  text-align: center !important;
}

body#sp,
#sp #ph_content_top,
#ph_content_bottom {
  background: #fff;
}

header.epoint_page_header {
  margin-bottom: 4rem;
}

header.epoint_page_header .epoint_page_header_inner {
  background: #ffb200;
}

header.epoint_page_header .epoint_page_header_inner h1 {
  max-width: 94rem;
  margin: 0 auto;
  font-size: 0;
  line-height: 1;
}

header.epoint_page_header .epoint_page_header_inner h1 img {
  width: 100%;
}

header.epoint_page_header nav {
  background: #ec641a;
}

header.epoint_page_header nav ul {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
}

header.epoint_page_header nav ul li {
  margin: 0;
  padding: 0;
}

header.epoint_page_header nav ul li {
  background: #ec641a !important;
}

header.epoint_page_header nav ul li a {
  color: #fff;
  padding: 1em 1.5em;
  display: block;
}

#sp header.epoint_page_header .epoint_page_header_inner h1 {
  width: 100%;
}

.epoint_information .epoint_information_inner {
  width: 94rem;
  margin: 0 auto 4rem;
  border: 1px solid #f8935c;
  background: #fffbf9;
  padding: 1em;
  box-sizing: border-box;
}

.epoint_information h2 {
  font-size: 1.7rem;
  color: #333;
  margin-bottom: 0.5em;
  padding: 0;
  text-shadow: none;
  background: none;
  text-align: center;
}

.epoint_information p {
  font-size: 1.4rem;
  color: #333;
}

#sp .epoint_information .epoint_information_inner {
  width: 90%;
}

section.epoint_section {
  margin: 4rem 0;
}

section.inner_section {
  padding: 1.5rem;
}

section.inner_section h3 {
  font-weight: bold;
}

.epoint_section_container {
  margin: 4rem 0;
}

section.epoint_section h2.title_main {
  font-size: 2.2rem;
  margin-bottom: 3rem;
  color: #333;
}

section.epoint_section p.text {
  font-size: 1.6rem;
  margin: 1.5em;
  color: #333;
  line-height: 1.6;
}

section.epoint_section p.text.small {
  font-size: 1.3rem;
}

section.epoint_section p.text a {
  color: #007dce;
  text-decoration: underline;
}

section.epoint_section p.text_m {
  font-size: 1.6rem;
  margin: 1.5em auto;
  color: #333;
  line-height: 1.6;
}

section.epoint_section figure {
  width: 30%;
  margin: 1.5em auto;
}

section.epoint_section figure img {
  width: 100%;
}

section.epoint_section figure.type_img {
  width: 50%;
}

section.epoint_section {
  width: 90%;
  margin-right: auto;
  margin-left: auto;
}

section.inner_section {
  text-align: left;
}

section.inner_section p.text {
  margin: 1.5rem 0;
}

h3 {
  font-size: 2rem;
  font-weight: normal;
  color: #333;
}

.h3_new {
  font-size: 2.2rem;
  font-weight: bold;
}

.epoint_section_container h3 {
  padding: 2.2rem 0;
  font-weight: bold;
}

.pc_none {
  display: none;
}

.sp_none {
  display: block;
}

.for_flex {
  display: flex;
}

.f_bw {
  justify-content: space-between;
}

.f_ev {
  justify-content: space-evenly;
}

.f_center {
  justify-content: center;
}

.f_mid {
  align-items: center;
}

.f_wrap {
  flex-wrap: wrap;
}

.comment {
  font-size: 1.3rem;
}

p.middle_w {
  max-width: 66%;
  text-align: left;
}

.bg_bg {
  background-color: #fff7f2;
  margin-bottom: 1.5rem;
}

.bg_lgrn {
  background-color: #f5fae7;
}

.p-wrap {
  width: 28%;
  border: 1px solid #f8935c;
  border-radius: 19px;
  padding: 2.2rem 1.7rem 1.6rem;
}

.p-wrap_g {
  width: 28%;
  border: 1px solid #eb6419;
  border-radius: 19px;
  padding: 2.2rem 1.7rem 1.6rem;
}

div.f_center .p-wrap_g:nth-child(n+1) {
  margin-left: 16px;
}

.p-wrap h3,
.p-wrap_g h3 {
  font-weight: bold;
}

.for_check {
  font-weight: bold;
}

.textin_img {
  display: inline-block;
  vertical-align: middle;
  padding: 0 1.2rem;
}

.for_check::before {
  content: "";
  background-image: url("/~/media/Images/service/epoint/home/check");
  background-repeat: no-repeat;
  display: inline-block;
  width: 1.2rem;
  height: 2.2rem;
  vertical-align: text-bottom;
  margin-right: 0.6rem;
}

section.epoint_section .epoint_section_container .img_wrap figure {
  width: 33%;
  margin: 0;
}

section.epoint_section .epoint_section_container .img_wrap figure img {
  width: 62%;
}

.text_calc {
  color: #ec641a;
  font-size: 2rem;
  font-weight: bold;
  margin: 3.7rem 0;
}

.text_pur {
  color: #e20097;
}

.discountObi {
  display: inline-block;
  position: relative;
  text-align: center;
  background: #de002e;
  height: 2em;
  margin: 0;
  font-size: 1.8rem;
  line-height: 2em;
  color: #fff;
  padding: 0 1em;
}

.discountObi:before {
  position: absolute;
  top: 0;
  right: -0.5em;
  content: "";
  display: block;
  border-top: 1em solid #de002e;
  border-right: 0.5em solid transparent;
  border-bottom: 1em solid #de002e;
  border-left: 0.5em solid transparent;
}

.discountObi:after {
  position: absolute;
  top: 0;
  left: -0.5em;
  content: "";
  display: block;
  border-top: 1em solid #de002e;
  border-right: 0.5em solid transparent;
  border-bottom: 1em solid #de002e;
  border-left: 0.5em solid transparent;
}

.point_q {
  color: #0055d4;
}

.point_q:before {
  content: "Q.";
}

.point_a {
  color: #ce0000;
}

.point_a::before {
  content: "A.";
}

.epoint_section ul {
  padding: 0;
}

.epoint_section ul li {
  border-top: 1px solid #c9c9c9;
  padding: 2rem 0;
  text-align: left;
}

.epoint_section ul li p {
  margin: 0;
  font-size: 1.6rem;
}

section.epoint_section h2.border_l::before,
section.epoint_section h2.border_l::after {
  content: "";
  width: 38%;
  border-top: 1px solid #707070;
}

section.epoint_section h2.border_m::before,
section.epoint_section h2.border_m::after {
  content: "";
  width: 34%;
  border-top: 1px solid #707070;
}

section.epoint_section h2.border_s::before,
section.epoint_section h2.border_s::after {
  content: "";
  width: 26%;
  border-top: 1px solid #707070;
}

.epoint_section_container .border_sub::before,
.epoint_section_container .border_sub::after {
  content: "";
  width: 25%;
  border-top: 1px solid #b1b1b1;
  margin: 0 1em;
}

.box_attention01 {
  border: 1px solid #f8935c;
}

.epoint_page_header_inner nav ul li a:hover {
  text-decoration: none;
  background-color: #f59f71;
  transition: 0.3s;
}

section.epoint_section .for_c {
  width: 100%;
  text-align: center;
}

.epoint_section_container.mailnews h3 {
  width: 28%;
  margin: 0 auto;
}

.epoint_section_container.mailnews h3 img {
  width: 100%;
}

.bt_area {
  margin-bottom: 42px;
}

.bt {
  text-align: center;
}

.bt::before {
  font-size: 1.4rem;
  display: block;
  margin-bottom: 1.1rem;
}

.bt a {
  color: #ffffff;
  background-color: #007dce;
  padding: 1.4rem;
  display: inline-block;
  border-radius: 10px;
  font-size: 1.4rem;
}

#pc .bt a {
  min-width: 24rem;
}

.com1::before {
  content: "ソースネクスト・アカウントをお持ちの方";
}

.com2::before {
  content: "ソースネクスト・アカウントをお持ちでない方";
}

@media screen and (max-width: 599px) {
  .pc_none {
    display: block;
  }
  .sp_none {
    display: none;
  }
  .for_sp {
    width: 90%;
  }
  .for_sp img {
    width: 100%;
  }
  .sp_left {
    text-align: left;
  }
  .textin_img {
    padding: 0;
  }
  .p-wrap,
.p-wrap_g {
    width: initial;
    margin-top: 1.4rem;
  }
  .p-wrap:first-child,
.p-wrap_g:first-child {
    margin-top: 0;
  }
  section.epoint_section h2.title_main {
    font-size: 1.8rem;
  }
  h3 {
    font-size: 1.6rem;
  }
  section.epoint_section p.text {
    font-size: 1.4rem;
  }
  .epoint_section ul li p {
    font-size: 1.4rem;
  }
  section.epoint_section h2.border_l::before,
section.epoint_section h2.border_l::after {
    width: 22%;
  }
  section.epoint_section h2.border_m::before,
section.epoint_section h2.border_m::after {
    width: 16%;
  }
  section.epoint_section h2.border_s::before,
section.epoint_section h2.border_s::after {
    width: 18%;
  }
  .epoint_section_container .border_sub::before,
.epoint_section_container .border_sub::after {
    width: 28%;
  }
  .epoint_section_container.mailnews h3 {
    width: 50%;
  }
  .bt {
    width: 48%;
  }
  .bt:before {
    font-size: 1.2rem;
  }
  .h3_new {
    font-size: 1.6rem;
  }
  section.epoint_section figure .sp_max {
    width: 100%;
  }
  section.epoint_section figure.img {
    width: 50%;
  }
  section.epoint_section figure.type_img {
    width: 90%;
  }
  p.middle_w {
    max-width: 100%;
  }
  .about_p {
    display: block;
  }
}
@media screen and (max-width: 599px) and (max-width: 320px) {
  .bt a {
    font-size: 1.2rem;
  }
  section.epoint_section h2.border_l::before,
section.epoint_section h2.border_l::after {
    width: 18%;
  }
  section.epoint_section h2.border_m::before,
section.epoint_section h2.border_m::after {
    width: 10%;
  }
}
section.epoint_section .about_p figure {
  width: 100%;
  height: auto;
  margin: 0;
}

section.epoint_section .about_p figure img {
  height: 14rem;
  width: auto !important;
}

span.f_bg_logo {
  background: url("/~/media/Images/service/epoint/home/e-logo");
  background-repeat: no-repeat;
  background-size: contain;
  width: 3rem;
  height: 3rem;
}

span.f_bg_logo02 {
  background: url("/~/media/Images/service/epoint/home/e-logo02");
  background-repeat: no-repeat;
  background-size: contain;
  width: 3rem;
  height: 3rem;
}

.epoint_section_container {
  text-align: center;
}

/*--▼ 2024.07 現在地下線の調整
  -------------------------------------------------------------*/
.epoint_page_header_inner nav ul li a {
  text-decoration: none;
  position: relative;
}

.epoint_page_header_inner nav ul li a:hover {
  background-color: #f57732 !important;
}

.epoint_page_header_inner nav ul li a::before {
  content: "";
  border-bottom: 0.3rem solid transparent;
  display: block;
  position: absolute;
  bottom: 1rem;
  transition: 0.3s;
  width: 0;
  left: 50%;
  transform: translateX(-50%);
}

.epoint_page_header_inner nav ul li.current a::before {
  border-bottom: 0.3rem solid rgba(255, 255, 255, 0.8);
  width: 80%;
}

@media screen and (max-width: 599px) {
  header.epoint_page_header nav ul {
    flex-direction: column;
    padding: 0;
  }
}
/*-------------------------------------------------------------
  ポイントを交換
-------------------------------------------------------------*/
.epoint__exchange .epoint__exchange--index {
  font-size: 2.1rem;
  font-weight: bold;
  text-align: center;
}
.epoint__exchange .epoint__exchange--img-epoint {
  width: 27rem;
}
.epoint__exchange .epoint__exchange--img-gpoint {
  width: 15rem;
}
.epoint__exchange .epoint__exchange span strong {
  color: #df0000;
}
.epoint__exchange .epoint__exchange--note-text {
  font-size: 1.3rem;
  margin: 1.5em;
  color: #333;
  line-height: 1.6;
  text-align: left;
  max-width: 70rem;
  margin: auto;
}

/*-------------------------------------------------------------
  ポイントご利用履歴
-------------------------------------------------------------*/
.epoint__history {
  /*-------------------------------------------------------------*/
  /*# sourceMappingURL=main.cd521941.css.map*/
}
.epoint__history .point-history {
  margin-bottom: 8rem;
}
.epoint__history .point-history-information__total_label {
  justify-content: center;
}
.epoint__history .point-history-information__total_label img {
  width: 3.2rem !important;
}
.epoint__history .point-history-information__total_link a {
  font-size: 1.4rem;
  color: var(--color_link);
}
.epoint__history .point-history-information__total_point {
  margin-bottom: 1rem;
}
.epoint__history section.contents-pt-link {
  display: flex;
  justify-content: center;
}
.epoint__history section.contents-pt-link a {
  font-size: 1.8rem;
  font-weight: bold;
  background-color: #fff;
  padding-left: 6rem;
  box-shadow: 0 0.2rem 0.8rem rgba(0, 0, 0, 0.2);
}
.epoint__history section.contents-pt-link a::before {
  content: "";
  display: inline-block;
  background-image: url(/~/media/img/epoint/icon_cart_epoint.svg);
  background-size: cover;
  width: 3rem;
  height: 3.2rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 2rem;
}
.epoint__history .point_fix {
  text-align: center;
}
.epoint__history .point-histories {
  text-align: center;
}
.epoint__history .point-histories__subject {
  font-size: var(--size_h_m);
  font-weight: var(--font_weight_bold);
}
.epoint__history .point-histories__select-date_month, .epoint__history .point-histories__select-date_year {
  border: 1px solid var(--color_border_light);
  border-radius: var(--radius_m);
  padding: 0 1rem;
}
.epoint__history .point-histories__select-date_month {
  margin-left: 1rem;
}
.epoint__history .point-histories__select-date_view-all {
  background: #16a085;
  border: 0;
  border-radius: var(--radius_max);
  color: #fff;
  margin-left: 1rem;
  padding: 0.2rem 2rem;
}
.epoint__history .point-histories__list {
  font-size: var(--size_txt_s);
  margin: auto;
  text-align: left;
  width: 80rem;
}
.epoint__history .point-histories__list th {
  padding: 1rem 0;
}
.epoint__history .point-histories__list th,
.epoint__history .point-histories__list tr {
  border-bottom: 1px solid #bfbfbf;
}
.epoint__history .point-histories__list tr td {
  padding: 2rem 0;
}
.epoint__history .point-histories__list_date {
  width: 15%;
}
.epoint__history .point-histories__list_purpose {
  width: 40%;
}
.epoint__history .point-histories__list_order {
  width: 20%;
}
.epoint__history .point-histories__list_point {
  width: 15%;
}
.epoint__history .point-histories__list_minus {
  color: #e50000;
}
.epoint__history .point-history-information {
  border: 1px solid var(--color_border_light);
  border-radius: var(--radius_l);
  display: flex;
  margin: 4rem auto;
  width: 100%;
  max-width: 80rem;
  justify-content: center;
  padding: 2rem;
}
.epoint__history .point-history-information__total {
  border-right: 1px solid var(--color_border_light);
  color: #333;
  font-size: var(--size_txt_l);
  padding: 2rem 4rem;
}
@media screen and (min-width: 600px) {
  .epoint__history .point-history-information__total {
    width: 40%;
  }
}
.epoint__history .point-history-information__total_label {
  align-items: center;
  display: flex;
}
.epoint__history .point-history-information__total_label span {
  margin-left: 1rem;
}
.epoint__history .point-history-information__total_point {
  font-size: var(--size_h_xl);
  font-weight: var(--font_weight_bold);
  margin-top: 0.5rem;
  text-align: center;
}
.epoint__history .point-history-information__total_point span {
  font-size: var(--size_txt_l);
  font-weight: var(--font_weight_regular);
  margin-left: 0.5rem;
}
.epoint__history .point-history-information__details {
  padding: 2rem 4rem;
}
@media screen and (min-width: 600px) {
  .epoint__history .point-history-information__details {
    width: 60%;
  }
}
.epoint__history .point-history-information__details .point-history-information__detail {
  align-items: flex-start;
  display: flex;
  margin: 0 auto 1rem;
  width: 90%;
  justify-content: space-between;
}
.epoint__history .point-history-information__details .point-history-information__detail_points {
  /*align-items: flex-start;
  display: flex;
  margin-bottom: .3rem*/
  display: grid;
  margin-bottom: 0.3rem;
  /* height: 100%; */
  grid-template-columns: 12rem 2fr 1fr;
  align-items: center;
  order: 2;
  -webkit-order: 2;
}
.epoint__history .point-history-information__details .point-history-information__detail_label {
  font-size: var(--size_txt_s);
  margin-right: 6rem;
}
.epoint__history .point-history-information__details .point-history-information__detail_expired {
  font-size: var(--size_txt_xs);
  /*margin-right: 6rem*/
}
.epoint__history .point-history-information__details .point-history-information__detail_point {
  font-size: var(--size_txt_l);
  font-weight: var(--font_weight_bold);
  /*margin-top: -.4rem*/
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.epoint__history .point-history-information__details .point-history-information__detail span:last-child {
  font-size: var(--size_txt_s);
  margin-left: 0.5rem;
}
@media screen and (max-width: 599px) {
  .epoint__history .point-history-information {
    flex-direction: column;
    width: calc(100% - 2rem) !important;
    box-sizing: border-box;
    padding: 2rem 2rem 5rem !important;
  }
  .epoint__history .point-history-information__total {
    border-right: none !important;
    padding: 2rem 3rem !important;
  }
  .epoint__history .point-history-information__details {
    padding: 0.5rem !important;
  }
  .epoint__history .point-history-information__details .point-history-information__detail {
    justify-content: space-between;
  }
  .epoint__history .point-history-information__details .point-history-information__detail_label {
    margin-right: 0rem;
  }
}
@media screen and (max-width: 599px) {
  .epoint__history .point-histories__list {
    width: calc(100% - 2rem) !important;
  }
}
.epoint__history .loginContainer {
  margin: 9rem auto;
  text-align: center;
  width: 100%;
}
.epoint__history .loginContainer .login_form .form_item_btn {
  background: #007dce;
  border-radius: 1rem;
  margin: 3rem auto;
  padding: 1rem;
  width: 16rem;
}
.epoint__history .loginContainer .login_form .form_item_btn a {
  color: #fff;
  display: block;
  text-decoration: none;
}
.epoint__history section.contents-footer {
  margin: 50px auto;
  text-align: left;
  font-size: 1.4rem;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.epoint__history details {
  position: relative;
  /* width: 70%; */
  margin: auto;
  /*閉じる時*/
}
.epoint__history details summary {
  display: flex;
  order: 1;
  -webkit-order: 1;
  justify-content: center;
  align-items: center;
}
.epoint__history details summary::-webkit-details-marker {
  display: none;
}
.epoint__history details summary.point_summary {
  position: absolute;
  bottom: -2.75rem;
  left: 0;
  right: 0;
  text-align: center;
  font-size: var(--size_txt_xs);
  margin: 0rem auto;
  /* border: 1px solid #eee; */
  box-shadow: 0 0.1rem 0.2rem rgba(0, 0, 0, 0.16);
  border-radius: var(--radius_max);
  width: 100%;
  padding: 0.25rem 0rem 0.25rem 0.5rem;
  transition: all 0.3s;
  background-color: #fff;
  cursor: pointer;
  color: var(--color_link);
  gap: 0.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 70%;
}
@media screen and (min-width: 600px) {
  .epoint__history details summary.point_summary:hover {
    background-color: #f5f5f5;
  }
}
.epoint__history details summary.point_summary::before {
  content: "すべて表示";
}
.epoint__history details summary.point_summary::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  line-height: 1;
  width: 0.6em;
  height: 0.6em;
  border: 0.2rem solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
  margin: 0.5em 0 0 0;
  transform: translateY(-50%) rotate(135deg);
}
.epoint__history details[open] summary.point_summary::before {
  content: "閉じる";
}
.epoint__history details[open] summary.point_summary::after {
  transform: translateY(-10%) rotate(-45deg);
}