@charset "UTF-8";
/*--------------------------------
 index.html
---------------------------------*/
#oneid {
  margin-bottom: 0;
}
/*----- #main -----*/
#oneid #main {
  background: #041D41;
}

#oneid #main .main__inner {
  display: flex;
  align-items: center;
}

#oneid #main .main__login {
  margin: 10px 30px 10px 0px;
  text-align: center;
}

#oneid #main .main__ttl {
  color: #fff;
  font-size: 14px;
  line-height: 1;
  margin-bottom: 20px;
}

#oneid #main .main__ttl img {
/*max-width: 203px;
  max-height: 47px;*/
/*max-width: 100px;*/
  max-width: 120px;
}

#oneid #main .main__img img {
  width: 100%;
}

#oneid #main .caption {
  color: #fff;
  text-align: left;
}

#oneid .main__app {
  display: flex;
  column-gap: 3%;
  align-items: center;
  max-width: 400px;
  text-align: center;
  /*margin: 0 auto 10px;*/
  margin: -10px auto 10px;
}

#oneid .main__app div a:hover {
  opacity: .7;
}

#oneid .main__app .app_img_a {
  flex-basis: 43%;
}

#oneid .main__app .app_img_g {
  flex-basis: 53%;
}

/*----- #point -----*/
#oneid #point .point__inner {
  padding: 30px 0 20px;
}

#oneid .point__ttl_wrap {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 35px;
}

#oneid #point .point__ttl {
  font-size: 20px;
  line-height: 1.8;
  text-align: center;
  flex: 1;
}

#oneid #point .point__ttl p {
  display: inline;
  background: linear-gradient(transparent 65%, #fff 0%);
}

#oneid #point .point__ttl .caption {
  margin-top: 10px;
}

#oneid .point__ttl_img {
  flex-basis: calc(35% - 10px);
}

#oneid .point__ttl_img:hover {
  opacity: .8;
}

#oneid .point__ttl_img .item__img,
:is(#support, #process) .item__movie a {
  position: relative;
}

#oneid .point__ttl_img .item__img::before,
:is(#support, #process) .item__movie a::before {
  content: '';
  position: absolute;
  width: 55px;
  height: 55px;
  z-index: 10;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  background: url("../images/common/icon_play.svg") no-repeat center/cover;
}

:is(#support, #process) .item__movie a {
  display: block;
}

:is(#support, #process) .item__movie a::before {
  width: 40px;
  height: 40px;
}

#process .item__movie a img {
  /* processのみグレー */
  filter: brightness(70%);
  width: 100%;
}

#oneid .point__ttl_img .item__img img {
  -webkit-filter: brightness(90%);
  filter: brightness(90%); /* 70% */
}

#oneid .point__ttl_img .item__txt.point__ttl {
  font-weight: bold;
}

#oneid #point .point__cover {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  z-index: 0;
  margin-bottom: 40px;
}

#oneid #point .point__cover::after {
  position: absolute;
  content: '';
  top: 25px;
  left: 0;
  width: 97%;
  height: 87%;
  min-height: 280px;
  z-index: -1;
  background: #fff;
  border-radius: 4px;
}

#oneid #point .point__article {
  width: 47%;
  padding: 5px 0 0 50px;
}

#oneid #point .point__img {
  width: 50%;
  max-width: 480px;
  padding: 0 0;
}

#oneid #point .point__cover.reverse {
  flex-flow: row-reverse;
}

#oneid #point .point__cover.reverse::after {
  left: auto;
  right: 0;
}

#oneid #point .point__cover.reverse .point__article {
  padding: 5px 50px 0 0;
}

#oneid #point .point__cover.point1 .point__img {
  padding: 0 50px 0 0;
}

#oneid #point .point__cover.point1 .point__img.pc {
  display: flex;
  align-items: center;
}

#oneid #point .point__cover.point2 .point__img {
  padding: 0 0 0 0;
}

#oneid #point .point__cover.point3 .point__img {
  padding: 0 50px 0 0;
}

#oneid #point .point__cover.point4 .point__img {
  padding: 0 0 0 50px;
}

#oneid #point .point__number {
  font-size: 28px;
  line-height: 1.5;
  margin-bottom: 25px;
}

#oneid #point .point__number img {
  height: 40px;
  display: block;
  margin-bottom: 20px;
}

#oneid #point .point__txt {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 30px;
}

#oneid .txt-large {
  font-size: 18px;
  margin-bottom: 10px;
}

#oneid .col-red {
  color: #CC0000;
}

#oneid #point .point__cover.point1 .caption ul {
  margin-bottom: 60px;
}

/*----- #login -----*/
#oneid #login {
  background: #fff;
}

#oneid #login .login__inner {
  padding: 60px 0;
  text-align: center;
}

#oneid #login .login__ttl {
  font-size: 20px;
  line-height: 1.5;
  margin-bottom: 110px;
}

/*----- .bottom-bar -----*/
#oneid .bottom-bar {
  padding: 20px 20px 15px;
  text-align: center;
}

#oneid .bottom-bar .foot-login > div {
  margin: 0 10px;
}

#oneid .bottom-bar.p-abs {
  position: absolute;
  bottom: 47px;
  box-shadow: none;
}

#oneid .bottom-bar.p-fix {
  position: fixed;
  bottom: 0;
  box-shadow: 0px -3px 6px rgba(0, 0, 0, 0.16);
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #oneid #main .container {
    width: 100%;
  }

  #oneid #main .main__inner {
    display: block;
    position: relative;
  }

  #oneid #main .main__login {
    width: 95%;
    max-width: 100%;
    display: block;
    position: absolute;
    bottom: -260px;
    left: 0;
    right: 0;
    margin: auto;
    background: #041D41;
    border-radius: 8px;
    /*padding: 25px 20px 20px;*/
    padding: 20px 20px;
  }

  #oneid #main .main__ttl img {
    /*max-width: 90px;*/
    max-width: 110px;
  }

  #oneid #point .point__inner {
    padding: 290px 0 20px;
  }

  #oneid .point__ttl_wrap {
    flex-flow: column;
    gap: 0;
  }

  #oneid #point .point__ttl {
    font-size: 16px;
    line-height: 1.8;
  }

  #oneid .point__ttl_img .item__txt {
    margin-top: 5px;
  }
  /*#oneid #point .point__ttl p{
    padding: 0;
  }*/
  #oneid #point .point__cover {
    margin-bottom: 60px;
  }

  #oneid #point .point__cover::after {
    width: 100%;
    height: 98%;
    border-radius: 8px;
  }

  #oneid #point .point__cover.reverse {
    flex-flow: wrap;
  }

  #oneid #point .point__article {
    width: 100%;
    padding: 0 30px;
  }

  #oneid #point .point__img {
    margin: 0 auto;
  }

  #oneid #point .point__cover.reverse .point__article {
    padding: 0 30px;
  }

  #oneid #point .point__cover .point__img {
    padding: 0 !important;
  }

  #oneid #point .point__number {
    font-size: 22px;
    display: flex;
    align-items: center;
  }

  #oneid #point .point__number img {
    display: inline-block;
    margin-right: 20px;
    margin-bottom: 10px;
  }

  #oneid #point .point__img {
    max-width: 100%;
    width: 100%;
    margin: 0 auto 30px;
  }

  #oneid #point .point__cover.reverse .point__img {
    width: 100%;
  }

  #oneid #point .caption {
    margin-bottom: 30px;
  }

  #oneid #login .login__inner {
    padding: 30px 20px 55px;
  }

  #oneid #login .login__ttl {
    font-size: 16px;
    margin-bottom: 120px;
  }

  #oneid .bottom-bar {
    text-align: left;
  }

  #oneid .bottom-bar .bottom-bar__inner {
    justify-content: space-between;
  }

  #oneid .bottom-bar .foot-login > div {
    width: 100%;
    margin: 0 10px;
  }

  #oneid #point .point__cover.point1 .caption ul {
    margin-bottom: 0;
  }

  #oneid #point .point__cover.point1 .point__img.pc {
    display: none;
  }
}


/*--------------------------------
 entry/index.html, terms/index.html
---------------------------------*/
#entry :not(.terms).form {
  margin-top: 20px;
}

#entry .form .scroll-box_inner {
  font-size: 14px;
  line-height: 1.5;
}

#entry .form .scroll-box p + p,
#entry .form .scroll-box ol + p,
#entry .form .scroll-box ul + p,
#entry .form .scroll-box p + ol,
#entry .form .scroll-box ol + ol,
#entry .form .scroll-box ul + ol,
#entry .form .scroll-box p + ul,
#entry .form .scroll-box ol + ul,
#entry .form .scroll-box ul + ul {
  margin-top: 20px !important;
}

#entry .form .scroll-box ol li {
  text-indent: -3.3em;
  padding-left: 3.3em;
  word-wrap: break-word;
}

#entry .form .scroll-box ul li {
  text-indent: -1.5em;
  padding-left: 1.5em;
  word-wrap: break-word;
}

#entry .form .scroll-box ul ol li {
  text-indent: -3em;
  padding-left: 3em;
}
/* #entry .form .scroll-box a {
  text-decoration: underline;
}*/

#entry .form .scroll-box h2 {
  font-size: 20px;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 20px;

  @media screen and (max-width: 768px){
    font-size: 16px;
  }
}

#entry .form.terms .scroll-box {
  max-height: unset;
  border: unset;
  padding: 0;
  overflow: unset;
  margin-bottom: unset;
}

/*--------------------------------
 entry/personal-info.html
---------------------------------*/
#personal-info .form {
  margin-top: 30px;
}

#personal-info .form .h3-ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}

#personal-info .form .h3-ttl span {
  width: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 1.5px;
  font-weight: normal;
  background: #000;
  border-radius: 4px;
  padding: 3px 5px;
  margin-right: 10px;
}

#personal-info .form .q3.checkbox > label {
  height: 85px;
}

#personal-info .form .q3.checkbox label span {
  position: absolute;
  top: 0;
  right: 0;
  display: block;
  width: 110px;
  height: 100%;
}

#personal-info .form .q3.checkbox label span img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: .3s;
}

#personal-info .form .q3.checkbox label:hover span img {
  opacity: .7;
}

#personal-info .caption {
  margin-bottom: 25px;
}

#personal-info .skip {
  margin: -15px 0 15px;
}


/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {

  #personal-info .form .h3-ttl {
    font-size: 14px;
  }

  #personal-info .form .q3.checkbox > label {
    height: auto;
  }

  #personal-info .form .q3.checkbox label {
    padding: 115px 20px 18px 40px;
  }

  #personal-info .form .q3.checkbox label span {
    width: 100%;
    height: 100px;
  }

  #personal-info .form .q3.checkbox input[type=checkbox] + label::before {
    top: auto;
    transform: none;
    bottom: 14px;
  }

  #personal-info .form .column-harf > label {
    width: 49.33% !important;
  }
}


/*--------------------------------
 gated
---------------------------------*/
#gated {
  margin-bottom: 80px;
}

#gated #caution-area {
  padding-top: 15px;
}

#gated #caution-area .important__inner {
  border: 1px solid #d3d3d3;
  border-radius: 4px;
  background: #fff;
  padding: 15px 20px;
  color: #000;
  align-items: center;
  gap: 5px;
  font-size: 14px;
  line-height: 1.5;
  margin-bottom: -25px;
}

#gated #important {
  padding: 15px 0;
}

#gated #important .important__inner {
  border: 1px solid #F00000;
  border-radius: 4px;
  background: #fff;
  padding: 15px 20px;
  color: #F00000;
  display: flex;
  align-items: center;
  gap: 5px;
}

#gated #important .important__inner .tag {
  color: #F00000;
  font-size: 12px;
  line-height: 1;
  font-weight: 600;
  flex: 1;
}

#gated #important .important__inner .tag span {
  background: url("../images/common/icon-important.svg") left center no-repeat;
  background-size: 16px;
  padding-left: 20px;
}

#gated #important .important__inner dl {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  font-size: 14px;
  line-height: 1.8;
  flex: 8;
}

#gated #important .important__inner dt {
  font-size: 12px;
  font-weight: normal;
  width: 90px;
}

#gated #important .important__inner dd {
  width: calc(100% - 90px);
}

#gated #important .important__inner dd a {
  text-decoration: underline;
}

#gated #important .important__inner .more {
  flex: 1;
  text-align: right;
}

#gated #important .important__inner .more a {
  font-size: 12px;
  text-decoration: underline;
}

/*----- #main -----*/
#gated #main {
  background: #041D41;
}

#gated #main .main__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  padding: 24px 0;
  gap: 10px;
}

#gated #main .main__login {
  width: auto;
  flex: 1;
  text-align: center;
}

#gated #main .main__ttl {
  color: #fff;
  font-size: 14px;
  line-height: 1;
}

#gated #main .main__ttl img {
  /*max-height: 65px;*/
  /*max-width: 130px;*/
  max-width: 150px;
  width: 100%;
}

#gated #main .bottom-bar-txt {
  text-align: left;
}

/*----- slide -----*/
#gated #main .main__slide {
  width: 648px;
}

#main .slider {
  max-height: 200px;
}

#main .slider.slick-initialized {
  max-height: unset;
}

#gated #main .main__slide .list {
  /*display: flex;
  justify-content: space-between;
  flex-wrap: wrap;*/
}

#gated #main .main__slide .item {
  width: 40%;
  max-width: 316px;
  margin-bottom: 20px;
}

#gated #main .main__slide .item a {
  width: 100%;
  display: block;
  position: relative;
}

#gated #main .main__slide .item .item__thumb {
  width: 100%;
  border-radius: 4px 4px 0px 4px;
  overflow: hidden;
  position: relative;
  transition: 0.3s;
}

#gated #main .main__slide .item a:hover .item__thumb {
  opacity: 0.7;
}

#gated #main .main__slide .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#gated #main .main__slide .item .item__txt {
  width: 100%;
  color: #fff;
  padding: 25px 16px 10px;
  border-radius: 0px 0px 0px 4px;
  background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,1));
  position: absolute;
  bottom: 0;
  left: 0;
}

#gated #main .main__slide .item dt.ttl {
  min-height: 38px;
  font-size: 14px;
  font-weight: normal;
  line-height: 1.4;
  margin-bottom: auto;
}

#gated #main .main__slide .item dd.date {
  font-size: 10px;
  display: inline-block;
  margin-right: 25px;
}

#gated #main .main__slide .item dd.view {
  font-size: 10px;
  display: inline-block;
  background: url("../images/common/icon_view.svg") center left no-repeat;
  padding-left: 20px;
}

#gated #main .main__slide .item .tag {
  position: absolute;
  bottom: -20px;
  right: 0;
  font-size: 11px;
}

#gated #main .main__slide .item .tag span {
  display: inline-block;
  color: #fff;
  background: #000;
  border-radius: 0 0 4px 4px;
  padding: 2px 10px 6px 10px;
}

#gated #main .main__slide .item .tag::before {
  content: "";
  background: url("../images/common/corner_rt.svg");
  width: 5px;
  height: 5px;
  position: absolute;
  top: 0;
  left: -5px;
}

#gated #main .main__slide .item .new {
  position: absolute;
  top: -7px;
  left: -25px;
  background: #CC0305;
  color: #fff;
  font-size: 10px;
  padding: 20px 25px 2px;
  border-radius: 0 0 4px 0;
  transform: rotate(-45deg);
  z-index: 2;
}

#gated #main .main__slide .slick-arrow {
  background: #041D41 !important;
}

#gated #main .main__slide .slick-arrow:hover,
#gated #main .main__slide .slick-arrow:focus {
  background: #041D41 !important;
}

#gated #main .main__slide .slick-prev {
  display: block !important;
}

#gated #main .main__slide .slick-prev:before {
  background: url("../images/common/btn-arrow-primary.svg") 0 center no-repeat !important;
  background-size: 35px !important;
}

#gated #main .main__slide .slick-next:before {
  background: url("../images/common/btn-arrow-primary.svg") 0 center no-repeat !important;
  background-size: 35px !important;
}

#gated #main .main__slide .slick-dots li.slick-active button:before {
  background: #fff;
}

/*----- #contents-area  -----*/
#gated .enjoy .item {
  margin-bottom: 15px;
}

#gated .enjoy .item a {
  display: flex;
  position: relative;
  background-color: #fff;
  border-radius: 4px;
  overflow: hidden;
  padding: 15px;
  border: 1px solid #fff;
}

#gated .enjoy .item a:hover {
  border: 1px solid #000;
}

#gated .enjoy .item .item__thumb {
  width: 76px;
  transition: 0.3s;
}

#gated .enjoy .item a:hover .item__thumb {
  opacity: 0.7;
}

#gated .enjoy .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#gated .enjoy .item .item__txt {
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0 0 0 40px;
  margin: 0;
  font-size: 14px;
  line-height: 1.4;
}

#gated .service__btn,
#gated .support__btn {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  position: relative;
  height: auto;
}

#gated .p-icon {
  min-width: 108px;
  height: 108px;
  display: block;
  text-align: center;
  font-size: 14px;
  padding: 75px 10px 0;
  background: #fff url("../images/gated/icon01.png") top 16px center no-repeat;
  background-size: 46px 46px;
  border-radius: 4px;
  border: 1px solid #fff;
  position: relative;
}

#gated .p-icon.ic1 {
  background-image: url("../images/gated/icon01.png");
}

#gated .p-icon.ic2 {
  background-image: url("../images/gated/icon02.png");
}

#gated .p-icon.ic3 {
  background-image: url("../images/gated/icon03.png");
}

#gated .p-icon.ic4 {
  background-image: url("../images/gated/icon04.png");
}

#gated .p-icon.ic5 {
  background-image: url("../images/gated/icon05.png");
}

#gated .p-icon.ic6 {
  background-image: url("../images/common/img-total-care.png");
  background-size: 110px;
  background-position: top 34px center;
}

#gated .p-icon.ic7 {
  background-image: url("../images/common/img-monthly-owner.png");
  padding: 62px 10px 0;
  background-position: top 10px center;
}

#gated .p-icon.ic8 {
  background-image: url("../images/common/img-ccard.png");
  background-size: 110px;
  background-position: top 28px center;
}

#gated .p-icon:hover {
  border: 1px solid #000;
}

#gated .check .p-icon {
  /*min-width: 148px;*/
  min-width: 230px;
}

#gated .check .p-icon::after {
  content: "";
  background: url("../images/common/check-off.svg") no-repeat;
  background-size: cover;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 8px;
  right: 8px;
}

#gated .check .p-icon:active::after,
#gated .check .p-icon.active::after {
  content: "";
  background: url("../images/common/check-on.svg") no-repeat;
  background-size: cover;
}

#gated .check .nocheck::after {
  display: none;
}

#gated .information__slide .item {
  position: relative;
  /*max-width: 360px;*/
}

#gated .information__slide .item img {
  max-height: 136px;
}

#gated .information__slide .item span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 14px;
}

#gated .process__box {
  min-height: 135px;
  font-size: 14px;
  padding: 20px 20px;
  border-radius: 4px;
  border: 1px solid #fff;
  background: #fff;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

#gated .process__box .b-icon {
  text-align: center;
  font-size: 14px;
  line-height: 1;
  width: 20%;
}

#gated .process__box .b-icon img {
  max-width: 64px;
}

#gated .process__box .b-icon span {
  display: block;
  margin-top: 10px;
}

#gated .process__box .b-btn {
  width: 55%;
  margin-left: auto;
  font-size: 14px;
  line-height: 1.4;
}

#gated .process__box .b-btn .txt {
  margin-bottom: 10px;
}

#gated .process__box .b-btn .btn {
  min-width: auto;
  height: 45px;
  font-size: 14px;
  line-height: 1;
  margin-bottom: 0;
}

#gated .txt-bottom {
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  margin: 35px 20px 20px;
}

/*----- #contents-area new -----*/
#gated .cont__cover {
  font-size: 14px;
}

#gated .cont__cover > div {
  display: block;
  background-color: #fff;
  padding: 12px 19px 7px;
  border-radius: 4px;
}

#gated .cont__cover + .cont__cover {
  margin-top: 10px;
}

#gated .h2-ttl {
  margin-bottom: 10px;
}

#gated .h2-ttl__ttl {
  font-size: 18px;
}

#gated .h2-ttl__ttl::before {
  content: none;
}
/*
#gated .icon-harf,
#gated .icon-third {
  display: flex;
}

  #gated .icon-harf > div {
    width: 50%;
  }

  #gated .icon-third > div {
    width: 33.3%;
  }*/

#gated .icon-wrap {
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 8px;
}

@media (hover: hover) {
  #gated .icon-wrap::-webkit-scrollbar {
    height: 8px;
    background: #fff;
    border-radius: 6px;
  }

  #gated .icon-wrap::-webkit-scrollbar-thumb {
    background-color: #a7a4a4;
    border-radius: 6px;
  }
}

#gated .icon-btn {
  display: flex;
  gap: 18px;

  @media not screen and (min-width: 768px) {
    gap: 5px
  }
}

#gated :is(.i-icon, .t-icon) {
  word-break: keep-all;
  overflow-wrap: break-word;
  width: 85px;
  height: 85px;
  flex-shrink: 0;
  background-color: #fff;
  border-radius: 4px;
  position: relative;
  overflow: visible;

  @media not screen and (min-width: 768px) {
    width: calc((100vw - 20px) / 5.2);
    height: calc((100vw - 20px) / 5.2);
    max-width: 85px;
    max-height: 85px;
  }

  &:last-child::before {
    position: absolute;
    content: '';
    top: 0;
    left: 100%;
    height: 1px;
    width: 4px;
    background-color: transparent;
  }
}

#gated :is(.i-icon, .t-icon) > * {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 5px 0;
  border-radius: 4px;
  height: 100%;
}

#gated :is(.i-icon, .t-icon) > a {
  border: solid 1px #ccc;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.12);
}

#gated .i-icon {
  text-align: center;
  position: relative;
  margin-bottom: 0 !important;
}

#gated .i-icon :is(a, p) {
  padding: 5px;
}

#gated .i-icon img {
  max-height: clamp(45px, 90%, 60px);
}

#gated .i-icon.check::after {
  content: "";
  background: url("../images/common/check-on.svg") no-repeat;
  background-size: cover;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 2px;
  right: 2px;
}

#gated .t-icon {
  text-align: center;
  font-size: 12px;
  line-height: 1;
  margin-bottom: 0 !important;
}

#gated .t-icon img {
  max-height: 46px;
}

#gated .t-icon span {
  display: block;
  margin-top: 5px;
}

#gated .icon-group a {
  display: flex;
  gap: 18px;
  border: solid 1px #ccc;
  border-radius: 4px;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.12);

  @media screen and (max-width: 768px) {
    gap: 5px;
  }
}

@media (hover: hover) {
  #gated :is(.i-icon, .t-icon) a:hover,
  #gated .icon-group a:hover {
    border: 1px solid #696969;
  }
}

#gated .s-txt {
  display: flex;
  align-items: center;
}

#gated .banner-area {
  margin-top: 20px;
}

#gated .banner-area .link-bnr {
  position: relative;
}

#gated .banner-area .link-bnr span {
  font-size: 14px;
  color: #333;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #gated #important {
    padding: 7px 0;
  }

  #gated #important .important__inner {
    padding: 10px 15px 15px;
    position: relative;
  }

  #gated #important .important__inner .tag {
    width: 60px;
    flex: unset;
  }

  #gated #important .important__inner dl {
    font-size: 12px;
    line-height: 1.6;
    width: calc(100% - 65px);
  }

  #gated #important .important__inner dt {
    width: 100%
  }

  #gated #important .important__inner dd {
    width: 100%;
    margin-bottom: 10px;
  }

  #gated #important .important__inner .more {
    position: absolute;
    bottom: 5px;
    right: 10px;
  }

  #gated #main .main__inner {
    padding: 6px 0 16px;
  }

  #gated #main .main__login {
    max-width: 100%;
    width: 100%;
  }

  #gated #main .main__ttl {
    font-size: 0;
    /*margin: 0 0 5px;*/
    text-align: left;
  }

  #gated #main .main__ttl img {
    /*max-height: 23px;
    margin-top: 0;*/
    /*max-width: 50px;*/
    max-width: 60px;
    margin-left: -5px;
    margin-bottom: -7px;
  }

  #gated #main .slick-dotted.slick-slider,
  #gated #main .main__slide {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }

  #gated #main .main__slide .item .tag {
    font-size: 10px;
  }

  #gated #main .main__slide {
    width: 100%;
  }

  #gated #main .main__slide .slick-dots {
    left: 50%;
    margin-left: -158px;
  }

  #gated .support {
    margin-bottom: 45px !important;
  }

  #gated .p-icon {
    min-width: 100%;
    height: 70px;
    padding: 44px 5px 0;
    font-size: 12px;
    background-size: 32px 32px;
    background-position: top 10px center;
  }

  #gated .check .p-icon {
    min-width: 100%;
    height: 87px;
    font-size: 12px;
    background-position: top 9px center;
  }

  #gated .p-icon.ic6 {
    padding: 60px 10px 0;
    background-size: 110px;
    background-position: top 25px center;
  }

  #gated .p-icon.ic7 {
    padding: 50px 10px 0;
    background-size: 40px;
    background-position: top 9px center;
  }

  #gated .p-icon.ic8 {
    padding: 60px 10px 0;
    background-size: 110px;
    background-position: top 18px center;
  }

  #gated .check .p-icon::after {
    width: 16px;
    height: 16px;
  }

  #gated .support__btn > div {
    width: 23.6%;
  }

  #gated .service__btn > div {
    /*width: 32%;*/
    width: 49%;
  }

  #gated .information__slide .item {
    max-width: 300px;
  }

  #gated .process {
    margin-bottom: 45px !important;
  }

  #gated .process__box .b-icon {
    font-size: 12px;
    margin-right: 4%;
  }

  #gated .process__box .b-btn {
    width: 50%;
  }

  #gated .process__box .b-btn .txt br {
    display: none;
  }

  #gated .txt-bottom {
    font-size: 14px;
  }

  #gated #contents .container__inner {
    padding: 10px 0 40px !important;
  }
  
  #gated #caution-area .important__inner {
    margin-bottom: 0px;
  }

  #gated .column-harf {
    margin-bottom: -12px;
  }

  #gated .h2-ttl {
    margin-bottom: 8px;
    align-items: baseline;
    column-gap: 3px
  }

  #gated .h2-ttl__ttl {
    font-size: 16px;
    flex: 1;
  }

  #gated .h2-ttl__more {
    margin-right: -10px;
    padding-right: 22px;
  }

  #gated .t-icon {
    font-size: 11px;
  }

  #gated .t-icon img {
    max-height: clamp(30px, 50%, 46px);
  }

  #gated .i-icon.check::after {
    width: 16px;
    height: 16px;
  }

  #gated .s-txt {
    display: none;
  }
}

/*media Queries 500
----------------------------------------------------*/
@media screen and (max-width: 500px) {
  #gated .t-icon {
    font-size: 10px;
  }
}

/*media Queries 350
----------------------------------------------------*/
@media screen and (max-width: 350px) {
  #gated .t-icon {
    font-size: 7px;
  }
}

/*--------------------------------
 gated/contents
---------------------------------*/
#enjoy-contents {
  margin-bottom: 80px;
}
/*----- #main -----*/ /* delete
  #enjoy-contents #main {
    background: #041D41;
  }

    #enjoy-contents #main .main__inner {
      padding: 0 0 16px 0;
    }

    /*----- main__slide -----*/ /* delete
    #enjoy-contents #main .slick-dotted.slick-slider,
    #enjoy-contents #main .main__slide {
      width: 100%;
      margin-bottom: 10px !important;
    }

      #enjoy-contents #main .main__slide .list {
      }

      #enjoy-contents #main .main__slide .item {
        width: 40%;
        max-width: 316px;
        margin-bottom: 20px;
      }

        #enjoy-contents #main .main__slide .item a {
          width: 100%;
          display: block;
          position: relative;
        }

        #enjoy-contents #main .main__slide .item .item__thumb {
          width: 100%;
          border-radius: 4px 4px 0px 4px;
          overflow: hidden;
          position: relative;
          transition: 0.3s;
        }

        #enjoy-contents #main .main__slide .item a:hover .item__thumb {
          opacity: 0.7;
        }

        #enjoy-contents #main .main__slide .item .item__thumb img {
          width: 100%;
          height: 100%;
          object-fit: cover;
        }

        #enjoy-contents #main .main__slide .item .item__txt {
          width: 100%;
          color: #fff;
          padding: 25px 16px 10px;
          border-radius: 0px 0px 0px 4px;
          background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,1));
          position: absolute;
          bottom: 0;
          left: 0;
        }

        #enjoy-contents #main .main__slide .item dt.ttl {
          min-height: 38px;
          font-size: 14px;
          font-weight: normal;
          line-height: 1.4;
          margin-bottom: auto;
        }

        #enjoy-contents #main .main__slide .item dd.date {
          font-size: 10px;
          display: inline-block;
          margin-right: 25px;
        }

        #enjoy-contents #main .main__slide .item dd.view {
          font-size: 10px;
          display: inline-block;
          background: url("../images/common/icon_view.svg") center left no-repeat;
          padding-left: 20px;
        }

        #enjoy-contents #main .main__slide .item .tag {
          position: absolute;
          bottom: -20px;
          right: 0;
          font-size: 11px;
        }

          #enjoy-contents #main .main__slide .item .tag span {
            display: inline-block;
            color: #fff;
            background: #000;
            border-radius: 0 0 4px 4px;
            padding: 2px 10px 6px 10px;
          }

          #enjoy-contents #main .main__slide .item .tag::before {
            content: "";
            background: url("../images/common/corner_rt.svg");
            width: 5px;
            height: 5px;
            position: absolute;
            top: 0;
            left: -5px;
          }

        #enjoy-contents #main .main__slide .item .new {
          position: absolute;
          top: -7px;
          left: -25px;
          background: #CC0305;
          color: #fff;
          font-size: 10px;
          padding: 20px 25px 2px;
          border-radius: 0 0 4px 0;
          transform: rotate(-45deg);
          z-index: 2;
        }

      #enjoy-contents #main .main__slide .slick-arrow {
        background: #041D41 !important;
      }

        #enjoy-contents #main .main__slide .slick-arrow:hover,
        #enjoy-contents #main .main__slide .slick-arrow:focus {
          background: #041D41 !important;
        }

      #enjoy-contents #main .main__slide .slick-prev {
        display: block !important;
      }

        #enjoy-contents #main .main__slide .slick-prev:before {
          background: url("../images/common/btn-arrow-primary.svg") 0 center no-repeat !important;
          background-size: 35px !important;
        }

      #enjoy-contents #main .main__slide .slick-next:before {
        background: url("../images/common/btn-arrow-primary.svg") 0 center no-repeat !important;
        background-size: 35px !important;
      }

      #enjoy-contents #main .main__slide .slick-dots {
        max-width: 316px;
        left: 0;
        right: 0;
        margin: auto;
      }

        #enjoy-contents #main .main__slide .slick-dots li.slick-active button:before {
          background: #fff;
        }

    #enjoy-contents #main .main__inner .txt-top {
      color: #fff;
      font-size: 16px;
      line-height: 1.5;
      text-align: center;
      margin-bottom: 20px;
    }

    #enjoy-contents #main .main__inner .main_btn {
      display: flex;
      justify-content: flex-end;
    }

      #enjoy-contents #main .main__inner .main_btn .btn {
        width: auto;
        min-width: 260px;
        height: 35px;
        font-size: 14px;
        line-height: 1;
        margin-bottom: 0;
      }*/

/*----- magazine -----*/
#enjoy-contents .magazine {
  max-height: 420px;
  margin-bottom: 30px;
  padding: 20px 30px 10px;
  border-radius: 8px;
  background: url(../images/gated/contents/magazine/bg_wood_w.jpg);
  border: solid 1px #d9cfc7;
}

#enjoy-contents .magazine .h3-ttl {
  text-align: center;
  margin-bottom: 15px;
}

/* magazine__slide */
#enjoy-contents .magazine__slide .slick-track {
  display: block;
}

#enjoy-contents .magazine__slide .slick-arrow {
  display: block !important;
  background: #e7dad0 !important;
}

#enjoy-contents .magazine__slide .slick-prev {
  left: -30px;
  box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.2);
}

#enjoy-contents .magazine__slide .slick-next {
  right: -30px;
  box-shadow: -2px 2px 4px 0px rgba(0, 0, 0, 0.2);
}

#enjoy-contents .magazine__slide .slick-dots {
  padding-left: calc(100% / 2.5 + 12px);
}

#enjoy-contents .magazine__slide .slide-item a {
  display: block;
  position: relative;
  margin: 25px 0 5px
}

#enjoy-contents .magazine__slide .item__thumb {
  border-bottom: 7px solid #a78369a1;
}

#enjoy-contents .magazine__slide .item__thumb div {
  padding: 0 10px;
}

#enjoy-contents .magazine__slide .item__thumb img {
  background: white;
  box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.4);
  margin-bottom: -7px;
}

#enjoy-contents .magazine__slide .item__txt {
  background: linear-gradient(to bottom, rgb(239 231 228 / 90%) 70%, rgba(0, 0, 0, 0));
  padding: 10px 12px 15px;
  border-top: 8px solid saddlebrown;
}

#enjoy-contents .magazine__slide .item__txt .ttl {
  font-size: 12px;
  font-weight: bold;
  line-height: 1.4;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: 34px;  /* failsafe */
}

#enjoy-contents .magazine__slide .tag {
  display: flex;
  flex-flow: row-reverse;
  justify-content: space-between;
  gap: 8px;
  position: absolute;
  top: -24px;
  right: 10px;
  width: calc(100% - 20px);
  height: 24px;
  font-size: 11px;
  color: #fff;
}

#enjoy-contents .magazine__slide .tag dt {
  background: #041d41;
  border-radius: 4px 4px 0 0;
  padding: 4px 8px;
}

#enjoy-contents .magazine__slide .tag .latest {
  background: #cc0000;
  padding: 4px 0;
  text-align: center;
  flex-grow: 1;
}

/*----- .enjoy -----*/
/*----- navi -----*/
#enjoy-contents .enjoy__navi {
  background: #fff;
  border-bottom: 1px solid #ccc;
  margin: 0 calc(50% - 50vw) 30px;
  width: 100vw;
}

#enjoy-contents .enjoy__navi ul {
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  justify-content: space-around;
}

#enjoy-contents .enjoy__navi li {
  display: flex;
  padding: 10px 10px 8px;
  align-items: center;
  border-bottom: solid 3px #fff;
}

#enjoy-contents .enjoy__navi li.active {
  border-bottom: solid 3px #000;
}

#enjoy-contents .enjoy__navi li a {
  color: #7C7C7C;
  font-size: 14px;
  font-weight: 600;
  transition: 0.3s;
  white-space: nowrap;
  text-align: center;
}

#enjoy-contents .enjoy__navi li.active a,
#enjoy-contents .enjoy__navi li a:hover {
  color: #000;
}

#enjoy-contents .contents-list {
  margin-bottom: 0 !important;
}

#enjoy-contents .contents-list .item {
  display: flex;
}

#enjoy-contents .contents-list .item + .item {
  margin-top: 10px;
}

#enjoy-contents .contents-list .item a {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  border-radius: 4px;
  overflow: hidden;
  background-color: #fff;
}

#enjoy-contents .contents-list .item .item__thumb {
  width: 100%;
  height: auto;
  transition: 0.3s;
}

#enjoy-contents .contents-list .item a:hover .item__thumb {
  opacity: 0.7;
}

#enjoy-contents .contents-list .item .item__thumb img {
  width: 100%;
  max-height: 254px;
  object-fit: cover;
}

#enjoy-contents .contents-list .item .item__txt {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 10px 16px 10px;
  margin: 0;
  position: relative;
}

#enjoy-contents .contents-list .item dt.ttl {
  min-height: 40px;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: auto;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#enjoy-contents .contents-list .item dd.tag {
  color: #7C7C7C;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 5px;
}

#enjoy-contents .contents-list.landscape .item dd.tag:empty {
  margin-top: 1.2em;
}

#enjoy-contents .contents-list .item dd.date {
  font-size: 12px;
  line-height: 1.2;
  margin-top: 8px;
}

#enjoy-contents .contents-list.landscape .item .item__thumb {
  /*width: 120px;
  height: 90px;*/
  width: 150px;
  height: auto;
}

#enjoy-contents .contents-list.landscape .item .item__thumb img {
  max-height: 80px;
}

#enjoy-contents .contents-list.landscape .item dd.date {
  position: absolute;
  top: 10px;
  right: 14px;
  margin-top: 0;
}

/*----- .present -----*/
#enjoy-contents .present {
  margin-bottom: 0 !important;
}

#enjoy-contents .present__btn .item a {
  width: 100%;
  display: block;
  position: relative;
}

#enjoy-contents .present__btn .item .item__thumb {
  width: 100%;
  min-height: 130px;
  border-radius: 4px 4px 0px 4px;
  overflow: hidden;
  position: relative;
  transition: 0.3s;
}

#enjoy-contents .present__btn .item a:hover .item__thumb {
  opacity: 0.7;
}

#enjoy-contents .present__btn .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#enjoy-contents .present__btn .item .item__txt {
  width: 100%;
  color: #fff;
  padding: 25px 16px 10px;
  border-radius: 4px;
  background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,1));
  position: absolute;
  bottom: 0;
  left: 0;
  text-align: center;
}

#enjoy-contents .present__btn .item .item__txt span {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: auto;
}

/*----- slide -----*/
/* delete
#enjoy-contents .information__slide .item {
  position: relative;
}

  #enjoy-contents .information__slide .item img {
    max-height: 136px;
  }

  #enjoy-contents .information__slide .item span {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    font-size: 14px;
    display: block;
    width: 100%;
    text-align: center;
  } */

#enjoy-contents .element__slide .item {
  max-width: 400px;
}

#enjoy-contents .element__slide .item a {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  border-radius: 4px;
  overflow: hidden;
  background-color: #fff;
}

#enjoy-contents .element__slide .item .item__thumb {
  width: 35%;
  height: 100px;
  transition: 0.3s;
}

#enjoy-contents .element__slide .item a:hover .item__thumb {
  opacity: 0.7;
}

#enjoy-contents .element__slide .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#enjoy-contents .element__slide .item .item__txt {
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 14px 16px;
  margin: 0;
}

#enjoy-contents .element__slide .item dt.ttl {
  font-size: 14px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 5px;
}

#enjoy-contents .element__slide .item dd.txt {
  font-size: 12px;
  line-height: 1.4;
}

#enjoy-contents .mail-magazine .txt-middle {
  margin-bottom: 20px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  /* delete
  #enjoy-contents #main .main__inner {
    padding: 0 0 10px 0;
  }

  #enjoy-contents #main .slick-dotted.slick-slider,
  #enjoy-contents #main .main__slide {
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }

    #enjoy-contents #main .main__slide .item .tag {
      font-size: 10px;
    }

  #enjoy-contents #main .main__slide {
    width: 100%;
  }

  #enjoy-contents #main .main__inner .txt-top {
    font-size: 14px;
    margin-bottom: 15px;
  }*/

  #enjoy-contents .magazine {
    max-height: 480px;
    margin-bottom: 20px;
    padding-top: 15px;
  }

  #enjoy-contents .magazine__slide .tag {
    height: 22px;
    top: -22px;
    font-size: 10px;
  }

  #enjoy-contents .magazine__slide .slick-dots {
    padding-left: calc(100% / 3 + 12px);
  }

  #enjoy-contents .enjoy__navi {
    overflow: auto;
    white-space: nowrap;
  }

  #enjoy-contents .enjoy__navi::-webkit-scrollbar {
    width: 4px;
    height: 4px;
  }

  #enjoy-contents .enjoy__navi::-webkit-scrollbar-track {
    background-color: #fff;
  }

  #enjoy-contents .enjoy__navi::-webkit-scrollbar-thumb {
    background-color: #ccc;
    border-radius: 5px;
  }

  #enjoy-contents .enjoy__navi li {
    padding: 10px 5px 8px;
  }

  #enjoy-contents .enjoy__navi li a {
    font-size: 12px;
  }

  #enjoy-contents .contents-list .item .item__thumb img {
    max-height: 380px;
  }

  #enjoy-contents .contents-list.landscape {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }

  #enjoy-contents .contents-list.landscape .item {
    width: 48.4%;
  }

  #enjoy-contents .contents-list.landscape .item:first-child {
    margin-top: 10px;
  }

  #enjoy-contents .contents-list.landscape .item .item__thumb {
    width: 100%;
    height: auto;
  }

  #enjoy-contents .contents-list.landscape .item .item__thumb img {
    max-height: 185px;
  }

  #enjoy-contents .contents-list.landscape .item dd.date {
    position: relative;
    top: auto;
    right: auto;
  }

  #enjoy-contents .contents-list .item dt.ttl {
    min-height: 35px;
    font-size: 12px;
  }

  #enjoy-contents .contents-list .item dd.tag {
    font-size: 10px;
  }

  #enjoy-contents .contents-list.landscape .item dd.tag:empty {
    margin: 0;
  }

  #enjoy-contents .contents-list .item dd.date {
    font-size: 10px;
  }

  #enjoy-contents .present__btn.column-harf > div {
    width: 48.4% !important;
  }

  #enjoy-contents .present__btn .item .item__txt span {
    font-size: 14px;
  }

  /* delete
  #enjoy-contents .information__slide .item {
    max-width: 300px;
  } */

  #enjoy-contents .learn__slide .item a {
    display: block;
  }

  #enjoy-contents .element__slide .item {
    width: 215px;
  }

  #enjoy-contents .element__slide .item .item__thumb {
    width: 100%;
    height: 120px;
  }

  #enjoy-contents .element__slide .item dt.ttl {
    font-size: 12px;
  }

  #enjoy-contents .event {
    margin-bottom: 40px !important;
  }
}
/*media Queries 450
----------------------------------------------------*/
@media screen and (max-width: 450px) {
  #enjoy-contents .magazine__slide .slick-dots {
    padding-left: 0;
  }

  #enjoy-contents .contents-list .item .item__thumb img {
    max-height: 222px;
  }

  #enjoy-contents .contents-list.landscape .item .item__thumb img {
    max-height: 110px;
  }
}

/*--------------------------------
 gated/support/index.html
---------------------------------*/
#support {
  margin-bottom: 80px;
}

#support .scene1__bnr {
  margin-bottom: 40px;
}

#support #bottom-link {
  margin-top: 45px;
}

#support #self-assessment .bnr-icon::before {
  background-image: url("../images/gated/support/icon-self.png");
}

#support #self-assessment .bnr-icon.icon-qrcode::before {
  background-image: url("../images/gated/support/icon-qrcode.png");
}

#support #self-assessment .bnr-icon + .bnr-icon {
  margin-top: 15px;
}

#support #self-assessment .bnr-icon.disabled {
  background: #E9E9E9;
  border: 1px solid #ccc;
  pointer-events: none;
}

#support #self-assessment .bnr-icon.disabled::before {
  filter: brightness(92%);
}

#support #self-assessment .assessment {
  align-items: center;
  padding: 30px 35px 5px;
  background: #fff;
  border-radius: 4px;
  margin-bottom: 15px;
}

#support #self-assessment .assessment > div:first-child {
  border-right: 1px solid #ccc;
}

#support #self-assessment .assessment__ttl {
  font-size: 14px;
  line-height: 1.2;
}

#support #self-assessment .assessment__ttl .ttl {
  font-size: 20px;
  font-weight: 600;
}

#support #self-assessment .assessment__ttl .date {
  color: #aaa;
  margin-top: 10px;
}

#support #self-assessment .assessment__info {
  display: flex;
  flex-wrap: wrap;
  column-gap: 10px;
}

#support #self-assessment .assessment__info dl {
  width: calc((100% - 20px) / 3);
  font-size: 14px;
  line-height: 1.5;
  margin-top: 15px;
}

#support #self-assessment .assessment__info dt {
  font-weight: normal;
}

#support #self-assessment .assessment__info dd {
  font-weight: 600;
}

#support #self-assessment .assessment__price {
  margin-bottom: 20px;
}

#support #self-assessment .assessment__price .ttl,
#support #self-assessment .assessment__future .ttl {
  font-size: 14px;
  line-height: 1.2;
  font-weight: 600;
}

#support #self-assessment .assessment__future .ttl {
  margin-bottom: 5px;
}

#support #self-assessment .assessment__price dl,
#support #self-assessment .assessment__future dl {
  font-size: 12px;
  line-height: 1.4;
  display: flex;
  align-items: baseline;
}

#support #self-assessment .assessment__price dt,
#support #self-assessment .assessment__future dt {
  color: #aaa;
  font-weight: normal;
}

#support #self-assessment .assessment__price .txt,
#support #self-assessment .assessment__future .txt {
  min-width: 100px;
}

#support #self-assessment .assessment__price .price,
#support #self-assessment .assessment__future .price {
  font-weight: 600;
  margin-left: auto;
}

#support #self-assessment .assessment__price .price span {
  font-size: 24px;
}

#support #self-assessment .assessment__future .price span {
  font-size: 18px;
}

#support #self-assessment .assessment__btn {
  width: 100% !important;
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0;
}

#support #self-assessment .assessment__btn .btn {
  min-width: 220px;
  width: 220px;
  height: 35px;
  font-size: 14px;
  padding: 11px 14px;
}

#support #self-assessment .assessment-about {
  width: 100%;
  min-height: 150px;
  padding: 14px 14px 14px 190px;
  padding-left: 190px;
  border-radius: 4px;
  position: relative;
  overflow: hidden;
  outline: none;
  vertical-align: bottom;
  background: #fff;
  color: #000;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

#support #self-assessment .assessment-about .txt {
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
}

#support #self-assessment .assessment-about::before {
  content: "";
  width: 150px;
  height: 100px;
  position: absolute;
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  background-image: url("../images/gated/support/icon-about.png");
  background-repeat: no-repeat;
  background-position: left center;
  background-size: contain;
}

#support #self-assessment .assessment-about span {
  display: block;
  width: 100%;
  font-size: 14px;
  line-height: 1.4;
  font-weight: normal;
  margin: 10px 0 0;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #support #self-assessment .assessment {
    padding: 18px 18px 0;
  }

  #support #self-assessment .assessment > div:first-child {
    border-right: none;
    border-bottom: 1px solid #ccc;
    padding-bottom: 15px;
    margin-bottom: 15px;
  }

  #support #self-assessment .assessment__ttl {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 5px;
  }

  #support #self-assessment .assessment__info {
    display: block;
  }

  #support #self-assessment .assessment__info dl {
    width: 100%;
    font-size: 14px;
    line-height: 1.2;
    display: flex;
  }

  #support #self-assessment .assessment__info dt {
    width: 30%;
  }

  #support #self-assessment .assessment__info dd {
    width: 70%;
  }

  #support #self-assessment .assessment__btn .btn {
    width: 100%;
  }

  #support #self-assessment .assessment__future {
    display: flex;
    flex-wrap: wrap;
  }

  #support #self-assessment .assessment__future .ttl {
    width: 100%;
    margin-bottom: 15px;
  }

  #support #self-assessment .assessment__future dl {
    width: 50%;
    flex-wrap: wrap;
    text-align: center;
  }

  #support #self-assessment .assessment__future dl.dash {
    border-right: 1px dashed #ccc;
  }

  #support #self-assessment .assessment__future dt,
  #support #self-assessment .assessment__future dd {
    width: 100%;
  }

  #support #self-assessment .assessment-about {
    padding: 130px 14px 14px 14px;
  }

  #support #self-assessment .assessment-about .txt {
    font-size: 14px;
  }

  #support #self-assessment .assessment-about::before {
    top: 14px;
    left: 50%;
    transform: translateY(0);
    transform: translateX(-50%);
  }

  #support #self-assessment .assessment-about span {
    font-size: 12px;
  }

  #support .connect .column-fourth > div {
    width: 100% !important;
  }
}

/*--------------------------------
 gated/support/self-estimate
---------------------------------*/
#support #self-estimate .bnr-icon::before {
  background-image: url("../images/gated/support/icon-self-ev.svg");
}

#support #self-estimate .estimate-info .item {
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
  font-size: 14px;
  line-height: 1.2;
  padding: 20px 20px 10px;
  margin-bottom: 15px;
}

#support #self-estimate .estimate-info .item {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative;
  column-gap: 40px;
  row-gap: 15px;
}

#support #self-estimate .estimate-info .item .estimate-info__car {
  width: 320px;
}

#support #self-estimate .estimate-info .item .thumb {
  height: 160px;
  padding: 0;
}

#support #self-estimate .estimate-info .item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#support #self-estimate .estimate-info .item .estimate-info__price {
  flex: 1;
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
}

#support #self-estimate .estimate-info .item .estimate-info__price .name {
  font-size: 20px;
  line-height: 1;
  font-weight: 600;
  margin-top: 15px;
  margin-bottom: 15px;
}

#support #self-estimate .estimate-info .item .estimate-info__price .type {
  font-size: 16px;
  line-height: 1.5;
  border-bottom: 1px solid #ccc;
  padding: 0 0 12px;
  margin-bottom: 12px;
}

#support #self-estimate .estimate-info .item .estimate-info__price .type .type-ttl {
  color: #7C7C7C;
  font-size: 14px;
  font-weight: normal;
}

#support #self-estimate .estimate-info .item .estimate-info__price .price {
  font-size: 14px;
  margin-bottom: auto;
  display: flex;
  align-items: flex-end;
}

#support #self-estimate .estimate-info .item .estimate-info__price .price .pri-ttl {
  color: #7C7C7C;
  font-weight: normal;
  margin-right: 30px;
}

#support #self-estimate .estimate-info .item .estimate-info__price .price .pri-num span {
  font-size: 20px;
  font-weight: 600;
  margin-right: 10px;
}

#support #self-estimate .estimate-info .item .date {
  position: absolute;
  top: 20px;
  right: 20px;
  color: #7C7C7C;
  font-size: 12px;
  line-height: 1;
}

#support .estimate-info__btn {
  width: 100%;
  display: grid;
  grid-template-columns: 320px 1fr;
  column-gap: 40px;
}

#support .estimate-info__btn .btn {
  min-width: unset !important;
}

#support .estimate-info__btn .btn-test {
  grid-row: 2;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #support #self-estimate .estimate-info .item {
    padding: 20px 20px 10px;
    row-gap: 0;
  }

  #support #self-estimate .estimate-info .item .estimate-info__car {
    width: 100%;
    margin: 0 0 10px 0;
  }

  #support #self-estimate .estimate-info .item .estimate-info__car .btn-test {
    position: absolute;
    bottom: 10px;
    left: 20px;
    width: calc(100% - 40px);
  }

  #support #self-estimate .estimate-info .item .thumb {
    padding: 20px 0 0;
  }

  #support #self-estimate .estimate-info .item .estimate-info__price .name {
    font-size: 18px;
    margin-top: 0;
  }

  #support #self-estimate .estimate-info .item .estimate-info__price .type {
    font-size: 14px;
  }

  #support #self-estimate .estimate-info .item .estimate-info__price .type .type-ttl {
    font-size: 12px;
  }

  #support #self-estimate .estimate-info .item .estimate-info__price .price {
    font-size: 12px;
    margin-bottom: 20px;
  }

  #support #self-estimate .estimate-info .item .estimate-info__price .price .pri-num span {
    font-size: 18px;
  }

  #support .estimate-info__btn {
    grid-template-columns: initial;
    column-gap: 0;
    row-gap: 0;
  }

  #support .estimate-info__btn .btn-catalog {
    grid-row: 2;
  }

  #support .estimate-info__btn .btn-test {
    grid-row: 3;
  }
}


/*--------------------------------
 gated/support/search.html
---------------------------------*/
#search {
  margin-bottom: 80px;
}

#search .form .form__name {
  display: block;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 5px;
}

/*----- .result -----*/
#search .result {
  margin-top: 30px;
  border-top: 1px solid #ccc;

  &:has(.item) {
    padding-top: 45px;
  }
}

#search .result .item {
  width: 100%;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
  font-size: 14px;
  line-height: 1.4;
  padding: 20px 30px;
  margin-bottom: 15px;
}

#search .result .item {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}

#search .result .item .shop-info__add {
  flex: 1;
  padding: 0 20px 0 0;
  border-right: 1px solid #ccc;
  margin-right: 20px;
}

#search .result .item .shop-info__add .ttl {
  font-size: 16px;
  line-height: 1.4;
  margin-bottom: 10px;
}

#search .result .item .shop-info__add .add {
  /*background: url("../../../images/common/icon-map.png") left top 2px no-repeat;
  background-size: 16px;
  padding-left: 25px;*/
}

#search .result .item .shop-info__add .add a {
  text-decoration: underline;
}

#search .result .item .shop-info__add .add span {
  margin-right: 10px;
}

#search .result .item .shop-info__btn {
  text-align: center;
}

#search .result .item .shop-info__btn .btn {
  min-width: 220px;
  font-size: 14px;
  margin-bottom: 0;
}

#search .btn-map {
  min-width: 220px;
  width: 100%;
  height: 35px;
  font-weight: normal;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 14px;
  line-height: 1;
  border-radius: 100px;
  position: relative;
  overflow: hidden;
  outline: none;
  vertical-align: bottom;
  border: 1px solid #7C7C7C;
  color: #7C7C7C;
  background-color: #F0F0F0;
  transition: 0.3s;
}

#search .btn-map:hover {
  background-color: #E9E9E9;
}

#search .form .h2-ttl {
  margin-bottom: 5px;
}

#search .form .h2-ttl .btn-secondary {  /* #search-with-location */
  margin-bottom: 0;
  max-width: 298px;
  min-width: 180px;
  width: 40% !important;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #search .result .item {
    min-width: 200px;
    font-size: 12px;
  }

  #search .result .item > div {
    width: 100%;
    display: block;
  }

  #search .result .item .shop-info__add {
    padding: 0 0 20px 0;
    border-right: none;
    margin-right: 0;
  }

  #search .result .item .shop-info__add .ttl {
    font-size: 14px;
    padding-bottom: 10px;
    margin: 0 0 10px 0;
    border-bottom: 1px solid #ccc;
  }

  #search .result .item .shop-info__add .add span {
    display: block;
  }

  #search .result .item .shop-info__btn {
    margin: 0 auto;
  }

  #search .btn-map {
    min-width: 160px;
  }
}


/*--------------------------------
 gated/service/
---------------------------------*/
#service {
  margin-bottom: 80px;
}
/*----- .status -----*/
#service .status {
  margin-bottom: 40px;
}

#service .status-info {
  margin-bottom: 40px;
}

#service .status-info .item {
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
  font-size: 14px;
  line-height: 1.2;
  padding: 20px 30px;
}

#service .status-info .item {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}

#service .status-info .item .status-info__car {
  display: flex;
  justify-content: space-between;
  gap: 20px 30px;
  align-items: center;
}

#service .status__slide .item .status-info__car dl {
  padding: 0 0 0 30px;
  border-left: 1px solid #ccc;
}

#service .status__slide .item .status-info__car dl > div {
  display: flex;
  column-gap: 1em;
  align-items: center;
  margin-bottom: 5px;

  dd:not(.edit-area) {
    font-weight: bold;
    word-break: break-word;
  }
}

#service .status__slide .item .status-info__car dl > div.mileage {
  align-items: start; 

  .data {
    margin-top: 15px;
  }

  .update {
    font-size: 12px;
    padding-left: 3px;
  }
}


#service .status-info .item dd.edit-area .textbox {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
  margin-bottom: 6px;

  input {
    width: 100px;
    padding: 10px;
    text-align: right;
    font-weight: unset;
    outline-color: #cccccc;
    outline-style: solid;
    outline-width: 1px;
    
    &::placeholder {
      font-size: 10px;
    }
    &:focus {
      outline-color: #000;
    }
    &:disabled {
      outline: none;
    }
  }

  span {
    min-width: unset;
  }
}

#service .status-info .item .toggle-edit {
  border: 1px solid #000;
  border-radius: 4px;
  background-color: #fff;
  transition: 0.3s;
  font-size: 14px;
  line-height: 1.2;
  padding: 2px;
  width: 35px;
  height: 35px;
  text-align: center;

  img {
    width: 25px;
    margin: auto;
  }

  span {
    display: none;
  }

  &.is-edit {
    img {
      display: none;
    }
    span {
      display: block;
      color: #000;
    }
  }

  @media (hover: hover) {
    &:hover {
      background-color: #E9E9E9;
    }
  }
}
#service .status-info .item .thumb {
  width: 55%;
  height: 100px;
}

#service .status .item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#service .status-info .item dl {
  flex: 1;
  text-align: left;
}

#service .status-info .item .ttl {
  font-size: 18px;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 15px;
}

#service .status-info .item .data {
  line-height: 1;
  font-weight: 600;
}

#service .status-info .item .shop {
  font-size: 14px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 6px;
  display: flex;
}

#service .status-info .item .distance {
  font-size: 12px;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 6px;
}

#service .status-info .item .distance strong {
  font-size: 20px;
  margin-right: 8px;
}

#service .status-info .item dl span {
  color: #7C7C7C;
  font-size: 12px;
  font-weight: normal;
  min-width: 80px;
  display: inline-block;
}

#service .status-info .item .status-info__point {
  flex: 1;
  padding: 0 20px 0 0;
  border-right: 1px solid #ccc;
  margin-right: 20px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

#service .status-info .item .status-info__point .point {
  width: 50%;
  padding: 0 20px 0 0;
  border-right: 1px solid #ccc;
  margin-right: 20px;
}

#service .status-info .item .status-info__point .point,
#service .status-info .item .status-info__point .total {
  min-height: 48px;
  font-size: 18px;
  font-weight: 600;
  padding-top: 7px;
}

#service .status-info .item .status-info__point span {
  color: #7C7C7C;
  font-size: 14px;
  font-weight: normal;
  margin-right: 20px;
}

#service .status-info .item .status-info__point strong {
  font-size: 28px;
  margin-right: 10px;
}

#service .status-info .item .status-info__btn {
  text-align: center;
  width: 34.4%;
}

#service .status-info .item .status-info__btn .btn {
  min-width: 100%;
  font-size: 14px;
  margin-bottom: 0;
}

/*----- .status__slide -----*/
#service .status__slide {
  margin-bottom: 15px;
}

#service .status__slide .item {
  width: 40%;
  min-width: 700px;
}

#service .status__slide .item .h3-ttl {
  margin-top: 15px;
}

#service .status__slide .item .shop-info {
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

#service .status__slide .item .shop-info .shop-info__add {
  flex-grow: 1;
}


/*----- .service #service #process共有  -----*/
#service .service_inner .item {
  margin-bottom: 15px;
}

:is(#service, #process) .service_inner .item a {
  display: flex;
  position: relative;
  background-color: #fff;
  border-radius: 4px;
  overflow: hidden;
  align-items: center;
}

#service .service_inner .item a[href=""] {
  pointer-events: none;
}

:is(#service, #process) .service_inner .item .item__thumb {
  width: 30%;
  height: 110px;
  transition: 0.3s;
  position: relative;
}

:is(#service, #process) .service_inner .item a:hover .item__thumb {
  opacity: 0.7;
}

:is(#service, #process) .service_inner .item .item__thumb img {
  width: 100%;
  height: 100%;
/*  object-fit: cover;*/
  object-fit: contain;
}

:is(#service, #process) .service_inner .item .item__txt {
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 14px;
  margin: 0;
}

:is(#service, #process) .service_inner .item dt.ttl {
  font-size: 14px;
  font-weight: normal;
  line-height: 1.4;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #service .status-info .item {
    padding: 16px 16px;
  }

  #service .status-info .item .status-info__car {
    margin-bottom: 10px;
    flex-direction: column;
  }

  #service .status-info .item .status-info__car .ttl {
    font-size: 16px;
    margin-bottom: 12px;
  }

  #service .status-info .item .status-info__car .data {
    font-size: 12px;
  }

  #service .status-info .item .status-info__car .shop {
    font-size: 12px;
  }

  #service .status-info .item .status-info__car .distance strong {
    font-size: 16px;
  }

  #service .status-info .item .status-info__car .thumb {
    width: 100%;
  }

  #service .status .item .thumb img {
    object-fit: contain;
  }

  #service .status__slide .item .status-info__car .dl1 {
    position: absolute;
    top: 16px;
    left: 16px;
  }

  #service .status__slide .item .status-info__car dl {
    padding: 0;
    border-left: none;
  }

  #service .status-info .item .status-info__point {
    padding: 0;
    border-right: none;
    margin-right: 0;
    margin-bottom: 10px;
  }

  #service .status-info .item .status-info__point .point,
  #service .status-info .item .status-info__point .total {
    font-size: 16px;
    padding: 0 20px;
  }

  #service .status-info .item .status-info__point span {
    font-size: 12px;
    display: block;
    margin-bottom: 5px;
  }

  #service .status-info .item .status-info__point strong {
    font-size: 22px;
  }

  #service .status-info .item .status-info__btn {
    width: 100%;
  }

  #service .status__slide .item {
    width: 100%;
    min-width: auto;
  }

  :is(#service, #process) .service_inner .item .item__thumb {
    height: 100px;
  }

  :is(#service, #process) .service_inner .item dt.ttl {
    font-size: 12px;
  }

  #service .service  + .service .service_inner .item .icon-doc {
    font-size: 14px;
    padding-right: 28px;
  }
}

/*--------------------------------
 gated/process/
---------------------------------*/
#process {
  margin-bottom: 80px;
}

#process .h2-read:has(a.underline) {
  margin: 0 0 35px;
}

#process .select {
  margin-bottom: 40px;
  width: 100%;
}

/*----- .movie -----*/
/*
#process .movie_inner .item {
	margin-bottom: 15px;
}
#process .movie_inner .item a{
	display: flex;
	position: relative;
	border-radius: 4px;
	overflow: hidden;
	background-color: #fff;
}
#process .movie_inner .item .item__thumb {
	width: 50%;
	height: 135px;
	transition: 0.3s;
	position: relative;
}
#process .movie_inner .item a:hover .item__thumb{
	opacity: 0.7;
}
#process .movie_inner .item .item__thumb::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 44px;
	height: 44px;
	background: url("../images/common/icon-movie.png") no-repeat;
	background-size: contain;
	transition: 0.3s;
}
#process .movie_inner .item .item__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#process .movie_inner .item .item__txt {
	flex: 1;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	padding: 14px;
	margin: 0;
}
#process .movie_inner .item dt.ttl {
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
	margin-bottom: auto;
}
#process .movie_inner .item dd.date {
	font-size: 11px;
	line-height: 1.4;
}
*/
#process .movie_inner .item {
  position: relative;
}

#process .movie_inner .item span {
  display: none;
/*	position: absolute;
	top: 50%;
	left: 50%;
	transform:translate(-50%,-50%);
	font-size: 14px;*/
}

#process .enjoy .item {
  margin-bottom: 15px;
}

#process .enjoy .item a {
  display: flex;
  position: relative;
  background-color: #fff;
  border-radius: 4px;
  overflow: hidden;
  padding: 15px;
  border: 1px solid #fff;
}

#process .enjoy .item a[href=""] {
  pointer-events: none;
}

#process .enjoy .item a:hover {
  border: 1px solid #000;
}

#process .enjoy .item .item__thumb {
  width: 76px;
  transition: 0.3s;
}

#process .enjoy .item a:hover .item__thumb {
  opacity: 0.7;
}

#process .enjoy .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#process .enjoy .item .item__txt {
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 0 0 0 40px;
  margin: 0;
  font-size: 14px;
  line-height: 1.4;
}

#process .fov-shop {
  padding-bottom: 15px;
}

#process .blank {
  min-height: 59px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #process .movie_inner .item .item__thumb {
    width: 35%;
    height: 100px;
  }

  #process .select select {
    font-size: 12px !important;
  }
}

/*--------------------------------
 gated/process/contract.html
 gated/pos/pos-receipt.html
---------------------------------*/
:where(#contract, #pos-receipt) .container__inner {
  margin: 0 auto;
  max-width: 480px;
}

:where(#contract, #pos-receipt) .preview {
  border-radius: 4px;
  border: 1px solid #ccc;
  background: #fff;
  padding: 0px;
  margin-bottom: 20px;
  overflow: hidden;
  display: block;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  /*color: #7C7C7C;*/
}

:where(#contract, #pos-receipt) .canvas_container {
  height: 100%;
  overflow: auto;
  margin: 0 auto;
  max-width: 600px;
  overflow: auto;
  text-align: center;
}

:where(#contract, #pos-receipt) #pdf_renderer {
  width: 100%;
}
/*#contract .preview embed{
	width: 100%;
	height: 705px;
}*/
#contract .navigation_controls {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  margin: 10px;
}

#contract .navigation_controls .page_count {
  display: inline-flex;
  width: 80px;
  height: 35px;
  align-items: center;
  justify-content: center;
}

#contract .navigation_controls .page_count span {
  margin: 0 10px;
}

#contract .navigation_controls button {
  position: relative;
  width: 35px;
  height: 35px;
  background: #f0f0f0 !important;
  border: solid 1px #ccc;
  border-radius: 50% !important;
}

#contract .navigation_controls button::before {
  content: "";
  position: absolute;
  top: 11px;
  left: 13px;
  width: 12px;
  height: 12px;
  border-top: 3px solid #000000;
  border-right: 3px solid #000000;
}

#contract #go_previous::before {
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

#contract #go_next::before {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  left: 9px;
}

#contract #zoom_in, #contract #zoom_out {
  display: none;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  :where(#contract, #pos-receipt) .container__inner {
    max-width: 100%;
  }

  :where(#contract, #pos-receipt) .preview {
    font-size: 14px;
  }

  #contract .canvas_container {
    max-width: 100%;
  }
}

/*--------------------------------
 gated/information/
---------------------------------*/
#information {
  margin-bottom: 80px;
}

#information .select {
  width: 100%;
  margin-bottom: 40px;
}

#information .info-list li {
  border-bottom: 1px solid #ccc;
}

#information .info-list li:last-child {
  border-bottom: none;
}

#information .info-list li a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex-wrap: nowrap;
  padding: 14px;
  background: #fff;
  transition: 0.3s;
  position: relative;
}

#information .info-list .item .item__thumb {
  max-width: 80px;
  height: 80px;
  border-radius: 4px;
  border: 1px solid #ccc;
  overflow: hidden;
  transition: 0.3s;
}

#information .info-list li a:hover .item__thumb {
  opacity: .7;
}

#information .info-list .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#information .info-list .item .item__txt {
  padding: 5px 140px 5px 20px;
  flex: 1;
}

#information .info-list .item .item__txt .tag {
  color: #7C7C7C;
  font-size: 14px;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 12px;
  position: relative;
}

#information .info-list .item .item__txt .ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
}

#information .info-list .item .item__date {
  position: absolute;
  top: 20px;
  right: 14px;
  color: #7C7C7C;
  font-size: 14px;
  line-height: 1;
}

#information .info-list .item .item__txt .tag span {
  margin-right: 5px;
}

#information .info-list .item .item__txt .tag span.new {
  background: #F00000;
  color: #fff;
  font-size: 11px;
  font-weight: normal;
  padding: 1px 6px;
  border-radius: 4px;
}

#information .info-list .item .item__txt .tag span.imp {
  background: url("../images/common/icon-important.svg") left center no-repeat;
  background-size: 16px;
  padding-left: 20px;
  color: #F00000;
}

#information .info-list .item .item__txt .tag span.cate {
  margin-right: 0;
}

#information .info-list .item .item__txt .ttl.imp {
  font-weight: 600;
}

/*media Queries 767
----------------------------------------------------*/
@media screen and (max-width: 764px) {
  #information .info-list li a {
    display: grid;
    padding: 12px 14px;
    grid-template-columns: 70px 1fr;
    grid-template-rows: auto 1fr 12px;
    grid-template-areas: "date  date"
      "img   content"
      "blank blank";
    column-gap: 14px;
  }

  #information .info-list .item .item__thumb {
    max-width: 70px;
    height: 70px;
    grid-area: img;
  }

  #information .info-list .item .item__txt {
    /*padding: 5px 0px 0 20px;
		flex: 1;*/
    padding: 0;
    grid-area: content;
  }

  #information .info-list .item .item__txt .tag {
    font-size: 12px;
    line-height: 1.4;
  }

  #information .info-list .item .item__txt .tag span.new {
    font-size: 10px;
  }

  #information .info-list .item .item__txt .ttl {
    font-size: 14px;
  }

  #information .info-list .item .item__date {
    font-size: 12px;
    position: unset;
    grid-area: date;
    text-align: right;
    padding-bottom: 3px;
  }
}


/*--------------------------------
 gated/information/detail/
---------------------------------*/
#detail {
  margin-bottom: 80px;
}

#detail #main .datail-ttl {
  padding: 15px 0 20px;
  display: grid;
  grid-template-areas:
    "nav     page     page"
    "cate    cate     date"
    "content content content";
  grid-template-columns: 1fr 1fr auto;
  column-gap: 5px;
}

#detail #main .page-nav {
  grid-area: nav;
}

#detail #main .page-nav.page-prevnext {
  grid-area: page;
  text-align: right;
}

#detail #main .page-nav .prev {
  margin-left: 20px;
}

#detail #main .datail-ttl__tag {
  color: #7C7C7C;
  font-size: 14px;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 12px;
  position: relative;
  grid-area: cate;
}

#detail #main .datail-ttl__ttl {
  font-size: 16px;
  line-height: 1.4;
  grid-area: content;
}

#detail #main .datail-ttl__ttl.imp {
  font-weight: 600;
}

#detail #main .datail-ttl__date {
  color: #7C7C7C;
  font-size: 14px;
  line-height: 1;
  text-align: right;
  grid-area: date;
}

#detail #main .datail-ttl__tag span {
  margin: 0 5px 0 0;
}

#detail #main .datail-ttl__tag span.new {
  background: #F00000;
  color: #fff;
  font-size: 11px;
  font-weight: normal;
  padding: 1px 6px;
  border-radius: 4px;
}

#detail #main .datail-ttl__tag span.imp {
  background: url("../images/common/icon-important.svg") left center no-repeat;
  background-size: 16px;
  padding-left: 20px;
  color: #F00000;
}

#detail #main .datail-ttl__tag span.cate {
  margin-right: 0;
}

#detail .column-submenu {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

#detail .column-submenu .article {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 20px;
  flex: 1;
}

#detail .column-submenu .article p + p,
#detail .column-submenu .article ol + p,
#detail .column-submenu .article ul + p,
#detail .column-submenu .article p + ol,
#detail .column-submenu .article ol + ol,
#detail .column-submenu .article ul + ol,
#detail .column-submenu .article p + ul,
#detail .column-submenu .article ol + ul,
#detail .column-submenu .article ul + ul {
  margin-top: 20px;
}

#detail .column-submenu .article ol {
  list-style-type: decimal;
  padding-left: 1.5em;
}

#detail .column-submenu .article ul {
  list-style-type: disc;
  padding-left: 1.5em;
}

#detail .column-submenu .article img {
  height: auto !important;
}

#detail .column-submenu .submenu {
  width: 35%;
  margin-left: 40px;
  margin-bottom: 25px;
}

#detail .column-submenu .submenu p + p {
  margin-top: 15px;
}

#detail .detail-link {
  width: 100%;
  min-height: 65px;
  padding: 25px;
  font-size: 16px;
  line-height: 1;
  border-radius: 4px;
  background-color: #fff;
  margin-bottom: 25px;
}

#detail .detail-link p {
  margin-bottom: 15px;
}

#detail .detail-link a {
  font-size: 14px;
  line-height: 1;
  background: url("../images/common/btn-arrow-next.svg") left 2px center no-repeat;
  background-size: 7.4px;
  padding-left: 20px;
}

#detail .detail-link a:hover {
  text-decoration: underline;
}

#detail .detail-link .item__link + .item__link {
  margin-top: 15px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #detail #main .datail-ttl {
    padding: 10px 0 15px;
  }

  #detail #main .datail-ttl__tag {
    font-size: 12px;
  }

  #detail #main .datail-ttl__tag span.new {
    font-size: 10px;
  }

  #detail #main .datail-ttl__date {
    top: 15px;
    font-size: 12px;
  }

  #detail .column-submenu .article {
    font-size: 14px;
  }

  #detail .column-submenu .submenu {
    width: 100%;
    margin-left: 0;
  }

  #detail .column-submenu .detail-link {
    font-size: 14px;
    padding: 16px;
  }

  #detail .column-submenu .detail-link a {
    font-size: 12px;
  }
}


/*--------------------------------
 gated/mypage/
---------------------------------*/
#mypage {
  margin-bottom: 80px;
}

#mypage .account-id.element {
  margin-bottom: 45px;
}

#mypage .account-info__bnr span {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #CC0000;
  color: #fff;
  font-size: 10px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  padding: 3px 3px;
  margin-left: 10px;
}

/*----- .status -----*/
#mypage .estimate__slide .item {
  min-width: 342px;
}

#mypage .estimate__slide .item a,
#mypage .estimate__slide .item p {
  min-height: 135px;
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
  font-size: 14px;
  line-height: 1.2;
  padding: 16px 16px;
  border: 1px solid #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
}

#mypage .estimate__slide .item p {
  justify-content: center;
}

#mypage .estimate__slide .item a:hover {
  border: 1px solid #000;
}

#mypage .estimate__slide .item .thumb {
  width: 48%;
  max-width: 160px;
  height: 100px;
  margin-right: 15px;
}

#mypage .estimate__slide .item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

#mypage .estimate__slide .item dl {
  flex: 1;
  text-align: left;
}

#mypage .estimate__slide .item .ttl {
  font-size: 16px;
  line-height: 1;
  font-weight: 600;
  margin-bottom: 15px;
}

#mypage .estimate__slide .item .total {
  font-size: 14px;
  line-height: 1.5;
  font-weight: 600;
  margin-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
}

#mypage .estimate__slide .item .total span {
  color: #7C7C7C;
  font-size: 12px;
  font-weight: normal;
  margin-right: 10px;
}

#mypage .estimate__slide .item .total strong {
  font-size: 18px;
  margin-right: 10px;
}

#mypage .estimate__slide .item .date {
  color: #7C7C7C;
  font-size: 12px;
  line-height: 1;
}

#mypage .assessment {
  align-items: center;
  padding: 30px 35px 5px;
  background: #fff;
  border-radius: 4px;
  margin-bottom: 15px;
}

#mypage .assessment > div:first-child {
  border-right: 1px solid #ccc;
}

#mypage .assessment__ttl {
  font-size: 14px;
  line-height: 1.2;
}

#mypage .assessment__ttl .ttl {
  font-size: 20px;
  font-weight: 600;
}

#mypage .assessment__ttl .date {
  color: #aaa;
  margin-top: 10px;
}

#mypage .assessment__price .ttl {
  font-size: 14px;
  line-height: 1.2;
  font-weight: 600;
}

#mypage .assessment__price dl {
  font-size: 12px;
  line-height: 1.4;
  display: flex;
  align-items: baseline;
}

#mypage .assessment__price dt {
  color: #aaa;
  font-weight: normal;
}

#mypage .assessment__price .txt {
  min-width: 100px;
}

#mypage .assessment__price .price {
  font-weight: 600;
  margin-left: auto;
}

#mypage .assessment__price .price span {
  font-size: 24px;
}

#mypage .assessment__btn {
  width: 100% !important;
  margin-top: 5px;
}

/*----- .service -----*/
/* pre
.service_inner .item {
	margin-bottom: 15px;
}
.service_inner .item a{
	display: flex;
	position: relative;
	background-color: #fff;
	border-radius: 4px;
	overflow: hidden;
}
.service_inner .item .item__thumb {
	width: 30%;
	height: 120px;
	transition: 0.3s;
	position: relative;
}
.service_inner .item a:hover .item__thumb{
	opacity: 0.7;
}
.service_inner .item .item__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.service_inner .item .item__txt {
	flex: 1;
	overflow: hidden;
	display: flex;
	align-items: center;
	padding: 14px;
	margin: 0;
}
.service_inner .item dt.ttl {
	font-size: 18px;
	font-weight: normal;
	line-height: 1.4;
}
*/
#mypage .p-icon {
  height: 108px;
  display: block;
  text-align: center;
  font-size: 14px;
  padding: 75px 10px 0;
  background: #fff url("../gated/mypage/images/index/icon01.png") top 16px center no-repeat;
  background-size: 46px 46px;
  border-radius: 4px;
  border: 1px solid #fff;
  position: relative;
}

#mypage .p-icon.ic6 {
  background-image: url("../images/common/img-total-care.png");
  background-size: 120px;
  background-position: top 28px center;
}

#mypage .p-icon.ic7 {
  background-image: url("../images/common/img-monthly-owner.png");
  background-position: top 20px center;
}

#mypage .p-icon.ic8 {
  background-image: url("../images/common/img-ccard.png");
  background-size: 62px;
  background-position: center center;
}

#mypage .p-icon:hover {
  border: 1px solid #000;
}

#mypage .check .p-icon {
  min-width: 148px;
}

#mypage .check .p-icon::after {
  content: "";
  background: url("../images/common/check-off.svg") no-repeat;
  background-size: cover;
  width: 20px;
  height: 20px;
  position: absolute;
  top: 8px;
  right: 8px;
}
/*#mypage .check .p-icon:active::after,*/
#mypage .check .p-icon.active::after {
  content: "";
  background: url("../images/common/check-on.svg") no-repeat;
  background-size: cover;
}

#mypage .check .nocheck::after {
  display: none;
}

/*----- .favorite .slide -----*/
#mypage .recommend__slide .item {
  width: 215px;
  margin-bottom: 15px;
}

#mypage .contents-list .item {
  display: flex;
}

#mypage .contents-list .item a {
  display: flex;
  flex-wrap: wrap;
  border-radius: 4px;
  overflow: hidden;
  background-color: #fff;
}

#mypage .contents-list .item .item__thumb {
  width: 100%;
  height: 135px;
  transition: 0.3s;
}

#mypage .contents-list .item a:hover .item__thumb {
  opacity: 0.7;
}

#mypage .contents-list .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#mypage .contents-list .item .item__txt {
  display: flex;
  flex-direction: column;
  padding: 14px 16px 16px;
  margin: 0;
}

#mypage .contents-list .item dt.ttl {
  min-height: 40px;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: auto;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

#mypage .contents-list .item dd.tag {
  color: #7C7C7C;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: 5px;
}

#mypage .contents-list .item dd.date {
  font-size: 12px;
  line-height: 1.2;
  margin-top: 8px;
}

#mypage .other__bnr a {
  font-size: 14px;
  font-weight: normal;
  padding: 18px 20px 18px 20px;
  min-height: auto;
}

.modal-window__inner .qrcode {
  max-width: 300px;
  margin: 0 auto 20px;
}

.modal-window__inner .qrcode img {
  width: 100%;
  padding: 30px;
}


/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #mypage .estimate__slide .item {
    min-width: 300px;
  }

  #mypage .estimate__slide .item .thumb {
    width: 100%;
    max-width: 100%;
    margin: 0 auto 5px;
  }

  #mypage .estimate__slide .item .ttl {
    font-size: 14px;
    margin-bottom: 5px;
  }

  #mypage .estimate__slide .item .total {
    font-size: 10px;
    margin-bottom: 5px;
  }

  #mypage .estimate__slide .item .total span {
    font-size: 12px;
  }

  #mypage .estimate__slide .item .total strong {
    font-size: 14px;
    margin-right: 10px;
  }

  #mypage .estimate__slide .item a,
  #mypage .estimate__slide .item p {
    font-size: 14px;
    min-height: 207px;
  }

  #mypage .assessment {
    padding: 18px 18px 0;
  }

  #mypage .assessment > div:first-child {
    border-right: none;
    border-bottom: 1px solid #ccc;
    padding-bottom: 15px;
    margin-bottom: 15px;
  }

  #mypage .assessment__ttl {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }

  #mypage .contents-list .item .item__thumb {
    height: 120px;
  }

  #mypage .contents-list .item dt.ttl {
    min-height: 35px;
    font-size: 12px;
  }

  #mypage .contents-list .item dd.tag {
    font-size: 10px;
  }

  #mypage .contents-list .item dd.date {
    font-size: 10px;
  }

  /*
	.service_inner .item .item__thumb {
		height: 100px;
	}
	.service_inner .item dt.ttl {
		font-size: 12px;
	}
	*/
  #mypage .service__inner.column-harf > div {
    /*width: 32.4% !important;*/
    width: 49.33% !important;
  }

  #mypage .p-icon {
    min-width: 100%;
    height: 70px;
    padding: 44px 10px 0;
    font-size: 12px;
    background-size: 32px 32px;
    background-position: top 10px center;
  }

  #mypage .check .p-icon {
    min-width: 100%;
    height: 87px;
    font-size: 12px;
    background-position: top 9px center;
  }

  #mypage .p-icon.ic6 {
    padding: 60px 10px 0;
    background-size: 110px;
    background-position: top 25px center;
  }

  #mypage .p-icon.ic7 {
    padding: 60px 10px 0;
    background-size: 40px;
    background-position: top 20px center;
  }

  #mypage .p-icon.ic8 {
    padding: 60px 10px 0;
    background-size: 62px;
    background-position: center center;
  }

  #mypage .check .p-icon::after {
    width: 16px;
    height: 16px;
  }

  #mypage .other__inner.column-third > div {
    width: 100% !important;
  }
}


/*--------------------------------
 gated/mypage/account-info.html
---------------------------------*/
#account-info {
  margin-bottom: 80px;
}

#account-info :is(.login-info, .account-info) {
  margin-bottom: 0 !important; /* 打消し */
}

#account-info .login-info__inner {
  background: #fff;
  border-radius: 4px;
  padding: 18px 20px 8px 20px;
  margin-bottom: 15px;
  display: flex;
  align-items: center;
  height: 355px;
}

#account-info .login-info__inner > div {
  width: 100%;
}

#account-info .login-info__inner .ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#account-info .login-info__inner .add,
#account-info .login-info__inner .pass {
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 20px;
}

#account-info .login-info__inner .add {
  margin-bottom: 40px;
}

#account-info .account-info__inner {
  background: #fff;
  border-radius: 4px;
  padding: 18px 20px 20px 20px;
  margin-bottom: 15px;
}

#account-info .account-info__inner .table {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  font-size: 16px;
  line-height: 1;
  margin-top: -15px;
}

#account-info .account-info__inner .table dt,
#account-info .account-info__inner .table dd {
  border-bottom: 1px solid #ccc;
  box-sizing: border-box;
  padding: 20px 5px 10px;
}

#account-info .account-info__inner .table dt:last-child {
  border-bottom: none;
}

#account-info .account-info__inner .table dt {
  width: 40%;
  font-weight: 600;
}

#account-info .account-info__inner .table dd {
  text-align: right;
  width: 60%;
}

#account-info  .h2-ttl__more.disabled {
  opacity: .4;
  pointer-events: none;
}

/*----- .detail__slide スライダー 共通（mydealer-info , car-profile） -----*/
#account-info .detail__slide .item {
  display: flex;
  flex-direction: column;
  min-width: clamp(300px, 70vw, 700px);
  border-radius: 4px;
  background: #fff;
  font-size: 16px;
  line-height: 1.4;
  padding: 10px 20px 20px;
}

#account-info .detail__slide .h2-ttl__more {
  margin-right: -10px;

  &.disabled {
    opacity: .4;
    pointer-events: none;
  }
}

#account-info .detail__slide .underline-list {
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

#account-info .detail__slide .underline-list div {
  display: flex;
  gap: 10px;
  border-bottom: 1px solid #ccc;
  padding: 10px 5px 10px;

  &:last-child {
    flex-grow: 1;
    flex-direction: column;
  }

  dt {
    width: min(40%,140px);
    flex-shrink: 0;
  }

  dd {
    word-break: break-word;
  }
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #account-info .login-info__inner {
    height: auto
  }

  #account-info .login-info__inner .ttl {
    font-size: 14px;
  }

  #account-info .login-info__inner .add,
  #account-info .login-info__inner .pass {
    font-size: 14px;
  }

  #account-info .account-info {
    margin-top: 30px;
  }

  #account-info .account-info__inner .table {
    font-size: 14px;
  }

  /*----- .detail__slide スライダー 共通（mydealer-info , car-profile） -----*/
  #account-info .detail__slide .underline-list div {
    flex-direction: column;
    gap: 5px;
    font-size: 14px;

    dt {
      width: 100%
    }
  }

}

/*--------------------------------
 gated/mypage/update-account-info.html
 gated/signup_regist/index.html(#update-account-info)
 gated/mypage/update-profile-info.html
 gated/mypage/update-mydealer-info.html
 ccard/ccard-edit.html 
 pos/index.htmlと共有化
---------------------------------*/
#update-account-info ,#update-profile-info, #update-mydealer-info {
  margin-bottom: 0;
}

#ccard-edit {
  margin-bottom: 80px;
}

:is(#update-account-info,#pos) .topinfo-red {
  border: 1px solid #7C7C7C;
  border-radius: 4px;
  background: #fff;
  padding: 20px 25px;
  margin-bottom: 40px;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
}

:is(#update-account-info,#pos) .topinfo-red p + p,
.topinfo p + p {
  margin-top: 10px;
}

/* ccard */
.topinfo {
  border: 1px solid #000;
  border-radius: 4px;
  background: #fff;
  padding: 20px 25px;
  margin-bottom: 40px;
  font-size: 16px;
  line-height: 1.4;
  text-align: center;
}

.topinfo .h3-ttl {
  text-align: center;
}

.topinfo .item__txt.underline {
  text-decoration: underline;
}

.topinfo .item__img {
  display: flex;
  justify-content: center;
  max-width: 500px;
  text-align: center;
  margin: 20px auto 0;
}

.topinfo .item__img img {
  width: 50%;
}

#contents .txt_center {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 20px;
  text-align: center;
}

#contents .txt_center a {
  text-decoration: underline;
}

#contents .txt_center p + p {
  margin-top: 1rem;
}

#contents .txt_alert {
  color: #F00000;
}

/* ------ form ------ */
#update-account-info .form,
#ccard-edit .form {
  margin-top: 30px;
}
/*#update-account-info .form .form__ttl{*/
.form .form__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}
/*#update-account-info .form .form__ttl-sub{*/
.form .form__ttl-sub {
  display: block;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-top: 10px;
}
/*#update-account-info .form .form__name {*/
.form .form__name {
  display: block;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 5px;
}

#update-account-info .form .p-country-name {
  display: none;
}

#update-account-info .form .p-postal-code {
  width: 130px;
}

#update-account-info .caption {
  margin-bottom: 25px;
}

#update-account-info .skip {
  margin-bottom: 10px;
}

#contents .btn_wrap {
  display: flex;
  gap: 20px;
  margin-top: 40px;
  justify-content: center;
}

#contents button:disabled, #contents [type="button"]:disabled {
  background: #E9E9E9 url(../images/common/btn-arrow-secondary.svg) right 12px center no-repeat;
}

.form .form__value {
  font-size: 16px;
  line-height: 1.4;
  border-radius: 4px;
  background: #fff;
  padding: 18px 20px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  position: relative;
  word-break: break-word;

  &.disabled {
    background: #e9e9e9;
  }
}

#ccard-edit .radiobtn.column-single {
  justify-content: center;
}

#ccard-edit .radiobtn.column-single label {
  width: 100%;
  max-width: 400px;
}

#submit-ccard-point {
  margin-top: 30vh !important;
}

#update-profile-info .form div:has(#yearMileage) {
    align-items: center;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  :is(#update-account-info,#pos) .topinfo-red,
  .topinfo {
    padding: 16px;
    font-size: 14px;
  }

  .topinfo .item__txt br {
    display: none;
  }

  /*#update-account-info .form .form__ttl{*/
  .form .form__ttl {
    font-size: 14px;
  }
  /*#update-account-info .form .form__ttl-sub{*/
  .form .form__ttl-sub {
    font-size: 14px;
  }
  /*#update-account-info .form .form__name{*/
  .form .form__name {
    font-size: 14px;
  }

  #update-account-info .form .q3.column-third > label {
    width: 100% !important;
  }

  #update-account-info .form .q4.column-third > div {
    width: 32.4% !important;
  }

  #update-account-info .form .q8.column-third > div {
    width: 100% !important;
  }
  /* ccard */
  #contents .txt_center, .topinfo {
    text-align: unset;
  }

  #contents .txt_center {
    font-size: 14px;
  }

  #ccard-edit .column-third > div, #ccard-edit .column-third > label {
    width: 32.4% !important;
  }

  #contents .btn_wrap .btn {
    min-width: unset;
  }

  #contents .btn_wrap.btn-single {
    flex-flow: column;
    gap: unset;
  }
}


/*--------------------------------
 gated/mypage/update-mail-code.html
---------------------------------*/
#update-mail-code {
  margin-bottom: 80px;
}

#update-mail-code .element {
  text-align: center;
  margin-bottom: 40px;
}

#update-mail-code .txt-large {
  margin-bottom: 20px;
  font-weight: 600;
}

#update-mail-code .txt-middle {
  margin-bottom: 30px;
}

#update-mail-code .line-bottom {
  padding-bottom: 20px;
  margin-bottom: 30px;
}

/* ------ form ------ */
#update-mail-code .form .form__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#update-mail-code .form .form__ttl-sub {
  display: block;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-top: 10px;
}

#update-mail-code .form .form__name {
  display: block;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 5px;
}

#update-mail-code .form .mail {
  background: #fff;
  border-radius: 4px;
  padding: 18px 20px;
  margin-bottom: 15px;
}

#update-mail-code .form .mail__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#update-mail-code .form .mail__add {
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
}

#update-mail-code .caption {
  margin-bottom: 5px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #update-mail-code .txt-middle {
    text-align: left;
  }

  #update-mail-code .form .form__ttl {
    font-size: 14px;
  }

  #update-mail-code .form .form__ttl-sub {
    font-size: 14px;
  }

  #update-mail-code .form .form__name {
    font-size: 14px;
  }

  #update-mail-code .form .mail {
    margin-bottom: 0;
  }

  #update-mail-code .form .mail__ttl {
    font-size: 14px;
  }

  #update-mail-code .form .mail__add {
    font-size: 14px;
  }
}


/*--------------------------------
 gated/mypage/update-mail-comp.html
---------------------------------*/
#update-mail-comp {
  margin-bottom: 80px;
}

#update-mail-comp .element {
  text-align: center;
  margin-bottom: 30px;
}

#update-mail-comp .txt-large {
  margin-bottom: 20px;
  font-weight: 600;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #update-mail-comp .txt-middle {
    text-align: left;
  }
}


/*--------------------------------
 gated/mypage/update-mail.html
---------------------------------*/
#update-mail {
  margin-bottom: 80px;
}

#update-mail .form .form__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#update-mail .form .form__ttl-sub {
  display: block;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-top: 10px;
}

#update-mail .form .form__name {
  display: block;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 5px;
}

#update-mail .form .mail {
  background: #fff;
  border-radius: 4px;
  padding: 18px 20px;
  margin-bottom: 15px;
}

#update-mail .form .mail__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#update-mail .form .mail__add {
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
}

#update-mail .caption {
  margin-bottom: 5px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #update-mail .form .form__ttl {
    font-size: 14px;
  }

  #update-mail .form .form__ttl-sub {
    font-size: 14px;
  }

  #update-mail .form .form__name {
    font-size: 14px;
  }

  #update-mail .form .mail {
    margin-bottom: 40px;
  }

  #update-mail .form .mail__ttl {
    font-size: 14px;
  }

  #update-mail .form .mail__add {
    font-size: 14px;
  }
}


/*--------------------------------
 gated/mypage/update-password.html
---------------------------------*/
#update-password {
  margin-bottom: 80px;
}

#update-password .form .form__ttl {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 15px;
}

#update-password .form .form__ttl-sub {
  display: block;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-top: 10px;
}

#update-password .form .form__name {
  display: block;
  color: #7C7C7C;
  font-size: 16px;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 5px;
}

#update-password .caption {
  margin-bottom: 25px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #update-password .form .form__ttl {
    font-size: 14px;
  }

  #update-password .form .form__ttl-sub {
    font-size: 14px;
  }

  #update-password .form .form__name {
    font-size: 14px;
  }
}


/*--------------------------------
 gated/mypage/delete-account.html
---------------------------------*/
#delete-account {
  margin-bottom: 80px;
}

#delete-account .service_inner .item {
  margin-bottom: 15px;
}

#delete-account .service_inner .item a {
  display: flex;
  position: relative;
  background-color: #fff;
  border-radius: 4px;
  overflow: hidden;
}

#delete-account .service_inner .item .item__thumb {
  width: 30%;
  height: 110px;
  transition: 0.3s;
  position: relative;
}

#delete-account .service_inner .item a:hover .item__thumb {
  opacity: 0.7;
}

#delete-account .service_inner .item .item__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#delete-account .service_inner .item .item__txt {
  flex: 1;
  overflow: hidden;
  display: flex;
  align-items: center;
  padding: 16px;
  margin: 0;
}

#delete-account .service_inner .item dt.ttl {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.4;
}

#delete-account .txt-bottom {
  font-size: 16px;
  line-height: 1.5;
  text-align: center;
  margin: 20px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #delete-account .service_inner .item .item__thumb {
    height: 100px;
  }

  #delete-account .service_inner .item .item__thumb img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  #delete-account .service_inner .item dt.ttl {
    font-size: 12px;
  }

  #delete-account .txt-bottom {
    font-size: 14px;
  }
}

/*--------------------------------
 faq_a, faq_b
---------------------------------*/
#faq {
  margin-bottom: 80px;
}

/*--------------------------------
 withdrawal.html
---------------------------------*/
#withdrawal {
  margin-bottom: 80px;
}

#withdrawal .withdrawal__btn {
  display: flex;
  justify-content: center;
  column-gap: 20px;
}

#withdrawal .withdrawal__btn .btn-secondary {
  max-width: 298px;
  width: 50%;
}
/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #withdrawal .withdrawal__btn {
    flex-flow: column;
  }
}
/*--------------------------------
 error.html
---------------------------------*/
#error {
  /*background: #041D41;*/
}

#error .error {
  /*color: #fff;*/
  text-align: center;
  padding: 50px 0;
}

#error .error .ttl {
  font-size: 25px;
  font-weight: 600;
  line-height: 1;
  margin-bottom: 45px;
}

#error .error .txt {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 30px;
}

#error .error p + p,
#error .error ol + p,
#error .error ul + p,
#error .error p + ol,
#error .error ol + ol,
#error .error ul + ol,
#error .error p + ul,
#error .error ol + ul,
#error .error ul + ul {
  margin-top: 20px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #error .error .ttl {
    font-size: 20px;
  }

  #error .error .txt {
    font-size: 14px;
    text-align: left;
  }
}

/*--------------------------------
 maintenance
---------------------------------*/
#maintenance .element {
  padding: 50px 0;
  text-align: center;
}

#maintenance .element div + div {
  margin-top: 40px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #maintenance .element {
    padding: 0;
    text-align: unset;
  }
}

/*--------------------------------
 ccard-info
---------------------------------*/
#contents .ccard-info, #contents .ccard-widhdrawal, #contents .ccard-err {
  width: 100%;
  min-height: 96px;
  border-radius: 4px;
  background: #fff;
  font-size: 14px;
  line-height: 1.4;
  padding: 20px 20px;
  font-size: 16px;
  line-height: 1.4;
}

#contents .ccard-widhdrawal {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: center;
}

#contents .ccard-widhdrawal .btn {
  margin-bottom: 0;
}

#contents .ccard-info {
  line-height: 1.4;
  display: grid;
  gap: 20px;
}

.ccard-info__link {
  grid-column: 1 / 3;
}

.ccard-info__link a {
  text-decoration: underline !important;
}

.ccard-info__img {
  display: flex;
  gap: 20px;
  align-items: center;
}

.ccard-info__img .thumb {
  width: 100px;
}

.ccard-info__amount {
  display: flex;
  flex-flow: column;
  row-gap: 20px;
  font-size: 16px;
  line-height: 1.4;
  padding-left: 20px;
  border-left: 1px solid #ccc;
}

.amount_point, .amount_price {
  display: flex;
  justify-content: space-between;
  font-weight: bold;
}

.amount_point {
  margin-top: 20px;
}

.ccard-info__amount .amount_txt .item__txt {
  background-color: #f0f0f0;
  padding: 10px;
  margin-top: 20px;
  font-size: 14px;
}

.element-sub .sub-ttl {
  font-weight: 600;
  font-size: 16px;
  line-height: 1.4;
  margin: 20px 0 10px;
  display: inline-block;
}

.modal-cluboff:hover {
  cursor: pointer;
}

.modal-cluboff span {
  position: relative;
}

.modal-cluboff span:after {
  content: " ?";
  position: absolute;
  background: #ccc;
  border-radius: 50%;
  color: white;
  width: 20px;
  height: 20px;
  right: -25px;
  text-align: center;
}

.modal-cluboff span:hover:after {
  background: #000;
}

.cluboff-info {
  width: 100%;
  border-radius: 4px;
  background: #fff;
  padding: 20px;
  font-size: 16px;
  line-height: 1.4;
}

.cluboff-info .ttl {
  text-align: center;
  margin-bottom: 20px;
}

.cluboff-info .ttl img {
  width: 400px;
}

.cluboff-info .item__img {
  width: 100%;
  display: flex;
  gap: 20px;
}

.cluboff-info .item__img img {
  width: calc((100% - 40px) / 3);
  border-radius: 4px;
}

.element-sub + .banner-area {
  margin-top: 20px;
}

.ccard-err {
  display: grid;
  gap: 20px;
}

.ccard-err div {
  grid-column: auto;
}

.ccard-err .item {
  text-align: center;
}

#contents .ccard-err .btn {
  margin: auto;
  max-width: 298px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #contents .ccard-widhdrawal {
    flex-flow: column;
  }

  #contents .ccard-widhdrawal .item__btn {
    width: 100%;
  }

  #contents .ccard-info {
    gap: 10px;
  }

  .ccard-info__card {
    padding: 0;
  }

  .ccard-info__amount {
    border: 0;
    border-top: 1px solid #ccc;
    padding-left: 0;
    padding-top: 10px;
  }

  .amount_point, .amount_price {
    padding: 0 5px;
  }

  .ccard-info__link {
    grid-column: unset;
    padding-top: 10px;
  }

  .element-sub .sub-ttl {
    font-size: 14px;
  }

  .cluboff-info .item__img {
    gap: 10px;
  }

  .cluboff-info .item__img img {
    width: calc((100% - 20px) / 3);
  }

  .ccard-err div {
    font-size: 14px;
  }
}

/*--------------------------------
 pos
---------------------------------*/
/* pos(pos-complete) / pos-address / pos-recipt / pos-receiptlist/ pos-confirm */
#pos, #pos-address, #pos-receipt, #pos-receiptlist, #pos-confirm {
  margin-bottom: 80px;
}

/* pos */
#pos .element {
  margin-bottom: 40px;
}

#pos .billing-list .item {
  display: flex;
  column-gap: 20px;
  width: 100%;
  border-radius: 4px;
  background: #fff;
  padding: 20px 30px;
  margin-bottom: 15px;
  position: relative;
  font-size: 16px;
}

#pos .billing-list dt {
  font-weight: unset;
}

#pos .billing-list .shop {
  flex: 1;
}

#pos .billing-list .shop .ttl span:first-child {
  margin-right: 12px;
}

#pos .billing-list .shop .deadline {
  display: flex;
  flex-wrap: wrap;
  margin: 5px 0 20px;
  font-size: 18px;
  font-weight: bold;
}

#pos .billing-list .date {
  display: flex;
  flex-wrap: wrap;
  position: absolute;
  bottom: 18px;
  font-size: 14px;
  color: #7C7C7C;
}

#pos .billing-list .price {
  width: 220px;
}

#pos .billing-list .price .pri-num {
  font-size: 12px;
  font-weight: bold;
  text-align: right;
  margin-bottom: 20px;
}

#pos .billing-list .price .pri-num span {
  font-size: 24px;
  margin-right: 5px;
}

#pos .billing-list .price .btn {
  font-size: 14px;
  min-width: 100%;
  margin-bottom: 0;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #pos .billing-list .item {
    flex-direction: column;
    row-gap: 15px;
    font-size: 14px;
  }

  #pos .billing-list .shop .ttl,
  #pos .billing-list .shop .deadline {
    margin-bottom: 0;
    font-size: 16px;
  }

  #pos .billing-list .shop .ttl span {
    display: inline-block;
  }

  #pos .billing-list .price {
    width: unset;
  }

  #pos .billing-list .date {
    position: unset;
  }
}

/*--------------------------------
 pos/pos-address,  pos/pos-recipt
---------------------------------*/
/* pos-adress */
#pos-address .column-variable {
  display: flex;
  justify-content: space-between;
}

#pos-address .column-variable .address_name {
  flex: 1;
}

#pos-address .column-variable:nth-child(2) .address_name {
  margin-right: clamp(100px, 20%, 150px);
}

#pos-address .column-variable .address_name input {
  max-height: 58px;
}

#pos-address .column-variable .select {
  width: clamp(100px, 20%, 150px);
  padding-left: 1.34%;
}

#pos-address .column-variable .select select {
  min-height: 58px;
}

/* pos-adress / pos-complete */
#pos .form, #pos-address .form {
  margin-top: 50px;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  /* pos-adress / pos-complete */
  #pos .form, #pos-address .form {
    margin-top: 40px;
  }

  /* pos-address */
  #pos-address .column-variable:nth-child(2) .address_name {
    margin-right: 0;
  }

  #pos-address .address_name input::placeholder {
    font-size: 14px;
  }

  #pos-address .column-variable .address_name input {
    max-height: 54px;
  }

  #pos-address .column-variable .select select {
    line-height: 1.4;
    min-height: 54px;
  }

}

/*--------------------------------
 pos/pos-confirm , #pos-receiptlistと一部共有
---------------------------------*/
:where(#pos-confirm, #pos-receiptlist) .detail-list {
  border-radius: 4px;
  background: #fff;
  padding: 20px 30px;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list dt {
  font-weight: unset !important;
}

/*#pos-confirm .detail-list dd {
    text-align: right;
    flex-shrink: 0;
}*/

:where(#pos-confirm, #pos-receiptlist) .detail-list .price {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  font-size: 18px;
  font-weight: bold;
}

#pos-confirm .detail-list .price {
  border-bottom: 1px solid #a9a9a9;
  padding-bottom: 15px;
  margin-bottom: 20px !important;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list .price .pri-num {
  font-size: 14px;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list .price .pri-num span {
  font-size: 20px;
  padding-right: 5px;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list .underline-list div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid #ccc;
  box-sizing: border-box;
  padding: 10px 5px 10px;
  width: 100%;
  font-size: 16px;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list .underline-list dd {
  font-size: 12px;
  flex-shrink: 0;
}

:where(#pos-confirm, #pos-receiptlist) .detail-list .underline-list dd span {
  font-size: 16px;
  padding-right: 5px;
}

#pos-confirm .h2-read {
  text-align: right;
  margin: -15px 5px 15px;
}

#pos-confirm .h2-read span {
  padding-right: 3px;
}

#pos-confirm .preview .item {
  border-radius: 4px;
  border: 1px solid #ccc;
  background: #fff;
  margin-bottom: 20px;
  overflow: hidden;
}

#pos-confirm .preview .item a {
  text-align: center;
  display: block;
  width: 100%;
}

#pos-confirm .preview .item img {
  max-height: 60svh;
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  :where(#pos-confirm, #pos-receiptlist) .detail-list .price {
    font-size: 16px;
  }

  :where(#pos-confirm, #pos-receiptlist) .detail-list .price .pri-num span {
    font-size: 18px;
  }

  :where(#pos-confirm, #pos-receiptlist) .detail-list .underline-list dt,
  :where(#pos-confirm, #pos-receiptlist) .detail-list .underline-list dd span {
    font-size: 14px;
  }
}

/*--------------------------------
 pos/pos-receiptlist
---------------------------------*/
/* form */
#pos-receiptlist .form .select {
  display: flex;
  column-gap: 20px;
}

#pos-receiptlist .form .form__column {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}

#pos-receiptlist .form .form__ttl {
  flex-shrink: 0;
  width: 15%;
  padding-top: 2px;
}

#pos-receiptlist .form .form__select {
  display: flex;
  gap: 10px;
  align-items: center;
  width: 100%;
}

#pos-receiptlist .form .form__select > div {
  width: 100%;
}

#pos-receiptlist .form .form__select > div.form__txt {
  width: 10%;
  flex-shrink: 0;
}

#pos-receiptlist .form #select-pay {
  width: calc(40% - 15px);
}

#pos-receiptlist .form .form__from {
  width: 5%;
  text-align: center;
}

#pos-receiptlist .form .form__name.from {
  text-align: center;
  width: 100%;
}

/* btn */
#pos-receiptlist .form .btn_wrap .btn {
  max-width: 298px;
}

/* sort */
#pos-receiptlist .sort-ttl {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
}

#pos-receiptlist .sort-navi {
  background: #fff;
  border-bottom: 1px solid #ccc;
  margin: 0 calc(50% - 50vw) 30px;
  width: 100vw;
}

#pos-receiptlist .sort-navi ul {
  max-width: 980px;
  margin: 0 auto;
  display: flex;
  justify-content: space-evenly;
  gap: 10px;
}

#pos-receiptlist .sort-navi li {
  display: flex;
  padding: 10px 10px 8px;
  align-items: center;
  border-bottom: solid 3px #fff;
  text-align: center;
  font-size: 16px;
}

@media (hover: hover) {
  #pos-receiptlist .sort-navi li span:hover {
    cursor: pointer;
    color: black;
    font-weight: bold;
  }
}

#pos-receiptlist .sort-navi .reset {
  flex-grow: 1;
}

#pos-receiptlist .sort-navi .reset span {
  border-right: 1px solid #ccc;
  padding-right: 10px;
}

#pos-receiptlist .sort-navi .sort {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 20%;
}

#pos-receiptlist .sort-navi .sort .ttl {
  width: 100%;
}

#pos-receiptlist .sort-navi .sort .order {
  display: flex;
  color: #aaa;
}

#pos-receiptlist .sort-navi .sort .order div {
  padding: 0 8px;
}

#pos-receiptlist .sort-navi .sort .order div:first-child {
  border-right: 1px solid #ccc;
}

#pos-receiptlist .sort-navi .sort .order div.is-active {
  color: black;
  font-weight: bold;
}

#pos-receiptlist .sort-navi .custom-reset-original-sort span.is-active {
  color: black;
  font-weight: bold;
}

/* page navi */
#pos-receiptlist .page-navi {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 20px;
}

#pos-receiptlist .page-navi .count {
  font-size: 18px;
  font-weight: 600;
}

#pos-receiptlist .pagenation {
  flex-grow: 1;
  justify-content: end;
  flex-shrink: 0;
  margin: 0;
}

#pos-receiptlist .pagenation ul,
#pos-receiptlist .pagenation li {
  margin: 0;
}

#pos-receiptlist .pagenation li a.active {
  color: black;
  font-weight: bold;
}

@media (hover: hover) {
  #pos-receiptlist .pagenation a:hover {
    background-color: white;
  }
}

/* relust-list */
#pos-receiptlist .detail-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "total total"
    "detail  shop"
    "detail  btn";
  row-gap: 20px;
  margin-bottom: 20px;
}

#pos-receiptlist .detail-list .total {
  grid-area: total;
  width: 50%;
  padding-right: 25px;
}

#pos-receiptlist .detail-list .meisai {
  grid-area: detail;
  padding-right: 20px;
  border-right: 1px solid #a9a9a9;
}

#pos-receiptlist .detail-list .shop {
  grid-area: shop;
  padding-left: 20px;
}

#pos-receiptlist .detail-list .shop dl {
  display: flex;
  flex-direction: column;
  row-gap: 5px;
}

#pos-receiptlist .detail-list .shop dl div {
  display: flex;
  gap: 20px;
  align-items: baseline;
}

#pos-receiptlist .detail-list .shop dl dt {
  flex-shrink: 0;
  font-size: 14px;
  color: #aaa;
}

#pos-receiptlist .detail-list .shop .ttl span {
  display: inline-block;
}

#pos-receiptlist .detail-list .shop .ttl span:first-child {
  margin-right: 12px;
}

#pos-receiptlist .detail-list .btn-right {
  grid-area: btn;
  align-items: end;
}

#pos-receiptlist .detail-list .btn-right .btn {
  height: 48px;
  margin-bottom: 0;
}

/*media Queries 1000
----------------------------------------------------*/
@media screen and (max-width: 1000px) {
  #pos-receiptlist .sort-navi ul {
    width: 95%;
  }
}

/*media Queries 768
----------------------------------------------------*/
@media screen and (max-width: 768px) {
  #pos-receiptlist .form .select {
    flex-direction: column;
    row-gap: 0;
  }

  #pos-receiptlist .form .form__select {
    gap: 5px;
  }

  #pos-receiptlist .form .form__ttl {
    width: 100%;
  }

  #pos-receiptlist .form div.pay {
    flex-direction: column;
  }

  #pos-receiptlist .form #select-pay {
    width: 100%;
  }

  #pos-receiptlist .form .caption {
    display: inline-flex;
    width: 100%;
  }

  #pos-receiptlist .form div.pc {
    display: none;
  }

  #pos-receiptlist .form .btn_wrap {
    flex-direction: column-reverse;
    gap: 0;
  }

  #pos-receiptlist .form .btn_wrap .btn {
    max-width: unset;
  }

  /* sort */
  #pos-receiptlist .sort-ttl {
    font-size: 16px;
  }

  #pos-receiptlist .sort-navi li {
    font-size: 14px;
  }

  #pos-receiptlist .sort-navi .sort {
    width: auto;
  }

  /* page navi */
  #pos-receiptlist .page-navi .count {
    font-size: 14px;
  }

  #pos-receiptlist .pagenation a {
    width: 20px;
    height: 20px;
  }

  /* relust-list */
  #pos-receiptlist .relust-list .detail-list {
    grid-template-areas: unset;
    grid-template-columns: 1fr;
  }

  #pos-receiptlist .relust-list .detail-list > div {
    grid-area: unset;
  }

  #pos-receiptlist .detail-list .total {
    width: 100%;
    padding: 0 5px 0 0;
  }

  #pos-receiptlist .detail-list .shop {
    padding: 0 0 20px 0;
    border-bottom: 1px solid #ccc;
    font-size: 14px;
  }

  #pos-receiptlist .detail-list .shop dt {
    font-size: 12px;
  }

  #pos-receiptlist .detail-list .meisai {
    padding: 0;
    border: none;
    font-size: 14px;
  }

  #pos-receiptlist .btn-right .btn {
    max-width: unset;
  }
}

/*--------------------------------
 ucar 中古車マイページ
---------------------------------*/
#ucar {
  margin-bottom: 80px;
}

@media not screen and (max-width: 768px) {
  #ucar .h2-ttl {
    justify-content: flex-start;
    gap: 12px;
  }
}

/* item */
#ucar .item {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  margin-bottom: 15px;
  background: #fff;
  border-radius: 4px;
  font-size: 14px;
  line-height: 1.2;
}

#ucar .item > a {
  height: 100%;
  padding: 20px 20px;

  &:has(+.conditions) {
    padding-bottom: 0;
  }

  &:hover {
    opacity: .8;
  }
}

/* card */
#ucar .card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 10px;
  height: 100%;
}

#ucar .card dt {
  font-weight: unset;
}

#ucar .card .info__name {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-grow: 1;
}

#ucar .card .name {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 5px;

  h3 {
    font-size: var(--fs-20);
    font-weight: 600;
  }

  .new {
    background: #cc0000;
    color: white;
    font-size: var(--fs-16);
    font-weight: bold;
    padding: 2px 5px;
    border-radius: 4px;
  }
}

#ucar .card .line2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  line-height: normal;
}

#ucar .card ul.tag {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  max-height: 67px;
  overflow: hidden;

  li img {
    width: auto;
    max-height: 31px;
  }

  li.label {
    padding: 4px 12px 5px;
    border-radius: 20px;
    color: white;
    background-color: #7d878b;
    font-size: var(--fs-12);
  }

  li.online {
    background-color: #007f96;
  }

  @media screen and (max-width: 768px) {
    li img {
      max-height: 24px;
    }
  }
}

#ucar .card .info__car {
  display: flex;
  gap: 10px;

  .thumb {
    width: 45%;

    img {
      width: auto !important;
      height: auto !important;
    }
  }

  .price {
    flex-grow: 1;
    width: calc((100% - 10px) / 2);
    display: flex;
    gap: 10px;
    flex-direction: column;

    > div:not(.caption) {
      width: 100%;
      display: flex;
      flex-wrap: wrap;
      gap: 15px;
    }
  }
}

#ucar .card .price dl {
  flex-basis: auto;
  display: flex;
  justify-content: space-between;
  flex-direction: column;

  /* 価格変動車両 */
  &.total dd.pri-num {
    position: relative;
    padding-right: 18px;

    &::after {
      position: absolute;
      bottom: 0;
      right: 0;
    }

    &.down::after {
      content: "▼";
      color: #2E98E6;
    }

    &.up::after {
      content: "▲";
      color: #cc0000;
    }
  }
}

#ucar .card .price dd.pri-num {
  font-size: 12px;
  word-break: keep-all;

  span {
    font-size: 18px;
    padding-right: 5px;
    font-weight: bold;
  }

  span.red {
    font-size: 22px;
    color: #cc0000;
  }

  /* 価格なし */
  &:has(> span[data-price="---"]) {
    visibility: hidden;
  }

  span[data-price="---"] {
    visibility: visible;
    text-decoration: unset !important;
  }
}

#ucar .card .price .beforechange dd.pri-num {
  color: #7d878b;
  font-size: 10px;

  span {
    font-size: 16px;
    font-weight: unset;
    text-decoration: line-through;
  }
}

#ucar .card .price .option dd.pri-num {
  span {
    font-size: 16px;
    font-weight: unset;
  }
}

#ucar .card .caption {
  color: #000;
  font-size: var(--fs-12);
}

#ucar .card .info__table {
  display: flex;
  padding: 5px 2px;
  border: solid 1px #ccc;
  text-align: center;
  font-size: 12px;

  dl {
    flex: 1;
  }

  dl + dl {
    border-left: solid 1px #ccc;
  }
}

/* conditions */
#ucar .item .conditions {
  display: flex;
  justify-content: end;
  align-items: center;
  gap: 10px;
  padding: 10px 20px 10px;

  a {
    text-decoration: underline;
    padding-right: 25px;
    background: url(../images/common/icon-document.svg) center right no-repeat;
    background-size: 20px;
  }
}

/* tooltip */
#ucar .tooltip {
  position: relative;
  display: inline-block;

  img {
    width: 30px;
    cursor: pointer;
  }

  &.info img {
    width: 27px;
    margin-right: 2px;
  }
}

#ucar .tooltip .description {
  display: none;
  position: absolute;
  font-size: 12px;
  line-height: 1.6em;
  width: 215px;
  border: solid 1px gray;
  border-radius: 5px;
  padding: 10px;
  background: #fbfbfb;
  z-index: 100;

  &::before {
    content: "";
    position: absolute;
    border: 8px solid transparent;
    border-top: 10px solid #000;
    margin-left: -15px;
    bottom: -18px;
    right: 18px;
  }

  dt {
    font-weight: bold;
  }
}

#ucar .tooltip.info .description {

  &.is-active dd {
    padding-top: 18px;
  }

  &::before {
    top: -18px;
    bottom: unset;
    right: unset;
    left: 65px;
    transform: rotateZ(180deg);
  }
}

#ucar .tooltip.tip .description dd {
/* 4行 */
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}


#ucar .tooltip .description .close {
  text-align: right;
  position: absolute;
  top: 10px;
  right: 10px;
  width: 50px;
  height: 22px;

  &::before {
    display: block;
    content: "閉じる";
    width: 50px;
    height: 22px;
    font-size: 11px;
    font-weight: bold;
    background-image: url(../images/common/icon-cross-bk.svg);
    background-size: 15px;
    background-repeat: no-repeat;
    background-position: left center;
  }
}

/* tooltip hover */
@media (hover: hover) {
  /* pc */
  #ucar .tooltip:hover .description {
    display: block;

    .close {
      display: none;
    }
  }

  #ucar .tooltip.tip:hover .description {
    bottom: 45px;
    right: -12px;
  }

  #ucar .tooltip.info:hover .description {
    top: 45px;
    left: -45px;

    ::before {
      right: unset;
      left: 65px;
    }
  }

  @media screen and (max-width: 768px) {
  /* sp */
    #ucar .tooltip.tip:hover .description {
      bottom: 45px;
      right: -12px;
    }

    #ucar .tooltip.info:hover .description {
      right: -5%;
      left: unset;
    }

    #ucar .tooltip.info:hover .description::before {
      right: 8px;
      left: unset;
    }
  }
}

/* tooltip touch */
@media (hover: none) {
  /* pc */
  #ucar .tooltip .description.is-active {
    display: block;
  }

  #ucar .tooltip.tip .description.is-active {
    bottom: 45px;
    right: -12px;
  }

  #ucar .tooltip.info .description.is-active {
    top: 45px;
    left: -45px;

    ::before {
      left: 65px;
    }
  }

  @media screen and (max-width: 768px) {
  /* sp */
    #ucar .tooltip.info .description.is-active {
      top: 50px;
      right: -5%;
      left: unset;
    }

    #ucar .tooltip.info .description.is-active::before {
      top: -18px;
      right: 8px;
      left: unset;
    }
  }
}

/* .open-box 開閉エリア */
#ucar .open-box .open {
  overflow: hidden;
  transition: .5s;
  position: relative;

  /* ぼかし */
  &::before {
    content: "";
    background: linear-gradient(to bottom, transparent, rgb(241 241 241) 100%);
    position: absolute;
    width: 100%;
    top: calc(100% - 150px);
    bottom: -10px;
    z-index: 3;
  }

  /* 全表示で消す */
  &:not(:has(.ucar-info > .half))::before {
    background: none;
    z-index: -1;
  }
}

/* 読み込みボタン */
#ucar .open-box .open-btn {
  font-size: 18px;
  font-weight: bold;
  text-align: right;
  padding: 20px 30px 20px 20px;
  background: #f0f0f0 url(../images/common/select-arrow-primary.svg) right center no-repeat;
  background-size: 35px;
  cursor: pointer;
  display: none;

  &:hover {
    text-decoration: underline;
  }

  @media screen and (max-width: 768px) {
    font-size: 16px;
    padding-right: 25px;
    background-size: 30px;
  }
}

#ucar .open-box .open:has(.ucar-info > .half) + .open-btn {
  display: block;
}

/* item 初期非表示css → 動的変化はjsで制御*/
@media screen and (max-width: 768px) {
  #ucar .open-box .item:nth-child(n+3) {
    /* 初期表示 box内の3個目以降は非表示*/
    display: none;
  }

  #ucar .open-box .item:nth-child(2) {
    display: flex;
    height: 200px;
  }
}

@media not screen and (max-width: 768px) {
  #ucar .open-box .item:nth-child(n+5) {
    /* 初期表示 box内の5個目以降は非表示*/
    display: none;
  }

  #ucar .open-box :is(.item:nth-child(3), .item:nth-child(4)) {
    display: flex;
    height: 200px;
  }
}

/* 半分表示*/
#ucar .open-box {
  position: relative;

  .item.is-visible {
    display: flex;
    height: unset;
  }

  .item.half {
    height: 200px;
    overflow: hidden;
    display: flex;
  }
}

/* 回転時の表示変更 */
@media not screen and (max-width: 768px) {
  /* pc表示：偶数 */
  #ucar .open-box .item:not(.half) + .item.half:nth-child(2n) {
    display: flex;
    height: auto;

    + .item, + .item + .item {
      display: flex;
      height: 200px;
    }
  }

  /* pc表示：奇数 */
  #ucar .open-box .item.half:nth-child(2n+1) {
    + .item {
      display: flex;
      height: 200px;
    }
  }
}

@media screen and (max-width: 768px) {
  /* sp */
  #ucar .open-box .item.half + .half {
    display: none;
  }
}

