@charset "utf-8";

:root {
  --ex-border: #b34a2d;
  --ex-bg: #78818E;
}

/* Common
-------------------- */
.sell_cp a,
.sell_trade a,
.sell_faq dl a{
  color: var(--sub-text);
  text-decoration: underline;
}

.-sell_content {
  color: #202020;
  font-size: 15px;
  margin: 0 auto;
  max-width: 1200px;
  padding: 50px 9%;
  width: 100%;
}

.-sell_content.-jump_content {
  padding-top: calc(50px + var(--header-height));
  margin-top: calc(-1*var(--header-height));
}

.sell_subTitle {
  font-size: 27px;
  font-weight: bold;
  line-height: 34px;
  margin: 0 auto 25px;
}

.sell_subTitle::before {
  border: solid var(--sub-text);
  border-right-color: transparent;
  border-width: 17px 5px;
  content: '';
  display: inline-block;
  height: 0;
  margin: 0 10px -8px 0;
}

@media screen and (max-width: 768px) {
  main {
    background: #F7F7F7;
  }

  .-sell_content {
    font-size: calc(26*100vw/768);
    padding: calc(70*100vw/768) 0;
    width: calc(670*100vw/768);
  }

  .-sell_content.-jump_content {
    padding-top: calc((70*100vw/768) + var(--header-height));
    margin-top: calc(-1*var(--header-height));
  }

  .sell_subTitle {
    font-size: calc(40*100vw/768);
    line-height: calc(51*100vw/768);
    margin: 0 auto calc(50*100vw/768);
  }

  .sell_subTitle::before {
    border-width: calc(25*100vw/768) calc(7*100vw/768);
    margin: 0 calc(5*100vw/768) calc(-10*100vw/768) 0;
  }
}

.sell_brand,
.sell_pickup,
.sell_faq {
  background: var(--sub-bg01);
  overflow-y: hidden;
}


/* MV
-------------------- */
.sell_mv {
  margin: 0 auto;
  width: 100%;
}

.sell_mv img {
  margin: auto;
}

@media screen and (max-width: 768px) {
  .sell_mv {
    max-width: 100vw;
  }
  .sell_mv img {
    width: 100%;
  }
}


/* Campaign
-------------------- */
.sell_cp-lead {
  color: #000;
  margin: 0 auto 20px;
}

.sell_cp-detail {
  margin: 0 auto 25px;
}

.sell_cp-detail dt {
  color: var(--sub-text);
  float: left;
  font-weight: bold;
  margin: 0 10px 0 0;
}

.sell_cp-detail dd {
  margin: 0 0 5px;
}

.sell_cp-flow {
  display: flex;
  gap: 40px;
  justify-content: space-between;
}

.sell_cp-flow > li {
  background: var(--sub-bg01);
  border-radius: 7px;
  display: block;
  padding: 32px 15px 25px;
  position: relative;
  width: 30%;
}

.sell_cp-flow > li::after {
  border: solid transparent;
  border-left-color: var(--ex-bg);
  border-width: 18px 20px;
  content: '';
  display: block;
  position: absolute;
  right: -50px;
  top: 50%;
  transform: translateY(-50%);
}
.sell_cp-flow > li:last-child::after {
  content: none;
}

.sell_cp-flow > li img {
  display: block;
  margin: 0 auto 20px;
  width: 66px;
}

.sell_cp-flow-head {
  color: var(--sub-text);
  font-size: 18px;
  font-weight: bold;
  margin: 0 auto 10px;
  text-align: center;
}

.sell_cp-flow-detail {
  font-size: 13px;
}

@media screen and (max-width: 768px) {
  .sell_cp-lead {
    margin: 0 auto calc(50*100vw/768);
  }

  .sell_cp-detail {
    margin: 0 auto calc(50*100vw/768);
  }

  .sell_cp-detail dt {
    float: none;
    font-size: calc(30*100vw/768);
    margin: 0 0 calc(14*100vw/768);
  }

  .sell_cp-detail dd {
    margin: 0 0 calc(40*100vw/768);
  }

  .sell_cp-flow {
    flex-wrap: wrap;
    gap: calc(89*100vw/768);
  }

  .sell_cp-flow > li {
    border-radius: calc(15*100vw/768);
    padding: calc(40*100vw/768) calc(30*100vw/768) calc(30*100vw/768);
    width: 100%;
  }

  .sell_cp-flow > li::after {
    border-left-color: transparent;
    border-top-color: var(--ex-bg);
    border-width: calc(30*100vw/768);
    bottom: calc(-87*100vw/768);
    left: 50%;
    right: auto;
    top: auto;
    transform: translateX(-50%);
  }

  .sell_cp-flow > li img {
    margin: 0 auto calc(40*100vw/768);
    width: calc(131*100vw/768);
  }

  .sell_cp-flow-head {
    font-size: calc(30*100vw/768);
    margin: 0 auto calc(20*100vw/768);
  }

  .sell_cp-flow-detail {
    font-size: calc(26*100vw/768);
  }
}


/* Brand
-------------------- */
.sell_brand-detail {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  text-align: center;
}

.sell_brand-detail > li {
  width: calc((100% - 40px) / 3);
}

.sell_brand-img {
  background: var(--main-bg);
  margin-bottom: 10px;
}

.sell_items-catch {
  color: var(--sub-text);
  font-size: 20px;
  font-weight: bold;
  line-height: 72px;
  margin: 0 auto 15px;
  position: relative;
  text-align: center;
}

.sell_items-catch::before,
.sell_items-catch::after {
  background: var(--sub-text);
  content: '';
  display: inline-block;
  height: 44px;
  position: absolute;
  top: 50%;
  width: 2px;
}
.sell_items-catch::before {
  margin: auto -20px;
  transform: translateY(-50%) rotate(-20deg);
}
.sell_items-catch::after {
  margin: auto 20px;
  transform: translateY(-50%) rotate(20deg);
}

.sell_items-list {
  align-items: stretch;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

.sell_items-list > li {
  border: 1px solid var(--ex-border);
  padding: 20px;
  position: relative;
  width: calc((100% - 60px) /4);
}

.sell_items-detail .-brand {
  font-size: 15px;
  font-weight: bold;
}

.sell_items-detail .-brand span {
  font-size: 13px;
  font-weight: normal;
}

.sell_items-detail .-text {
  display: block;
  font-size: 13px;
  margin: 3px 0 1.7em;
  min-height: 43px;
}

.sell_items-detail .-coupon {
  background: url('../img/pc/top/coupon.svg') center left / 21px auto no-repeat;
  bottom: 1em;
  font-weight: bold;
  padding: 0 0 0 26px;
  position: absolute;
}

.sell_items-caution,
.sell_pickup-caution {
  font-size: 13px;
  margin: 15px 0 0;
}

.sell_items-caution > li,
.sell_pickup-caution > li {
  padding-left: 1em;
  text-indent: -1em;
}

@media screen and (max-width: 768px) {
  .sell_brand-detail {
    gap: calc(20*100vw/768);
  }

  .sell_brand-detail > li {
    width: calc(325*100vw/768);
  }

  .sell_brand-img {
    margin-bottom: calc(5*100vw/375);
  }

  .sell_items-catch {
    font-size: calc(30*100vw/768);
    line-height: calc(46*100vw/768);
    margin: 0 auto calc(20*100vw/768);
  }

  .sell_items-catch::before,
  .sell_items-catch::after {
    height: calc(46*100vw/768);
    width: calc(4*100vw/768);
  }
  .sell_items-catch::before {
    margin: auto calc(-30*100vw/768);
  }
  .sell_items-catch::after {
    margin: auto calc(30*100vw/768);
  }

  .sell_items-acc {
    background: #fff;
    border: calc(1*100vw/768) solid var(--ex-border);
    margin: 0 auto calc(20*100vw/768);
    padding-bottom: calc(5*100vw/375);
  }

  .sell_items-genre {
    align-items: center;
    display: flex;
    position: relative;
  }

  .sell_items-genre::after {
    color: var(--ex-bg);
    content: '＋';
    display: block;
    font-size: calc(28*100vw/768);
    font-weight: bold;
    position: absolute;
    right: calc(64*100vw/768);
  }

  .sell_items-genre.-open::after {
    content: 'ー';
  }

  .sell_items-img {
    width: calc(303*100vw/768);
  }

  .sell_items-detail {
    font-size: calc(30*100vw/768);
    margin: 0 calc(37*100vw/768) 0 0;
  }

  .sell_items-list {
    display: none;
    align-items: start;
    padding-bottom: calc(5*100vw/375);
  }

  .sell_items-list > li {
    align-items: center;
    border: none;
    display: flex;
    padding: calc(10*100vw/375) 0 0;
    position: relative;
    width: 100%;
  }

  .sell_items-list > li::before {
    border: calc(4*100vw/768) dashed var(--sub-bg01);
    content: '';
    display: block;
    height: calc(1*100vw/768);
    left: 50%;
    position: absolute;
    top: calc(5*100vw/375);
    transform: translateX(-50%);
    width: calc(630*100vw/768)
  }

  .sell_items-detail .-brand {
    font-size: calc(30*100vw/768);
  }

  .sell_items-detail .-brand span {
    font-size: calc(23*100vw/768);
  }

  .sell_items-detail .-text {
    font-size: calc(23*100vw/768);
    min-height: auto;
    margin-bottom: auto;
  }

  .sell_items-detail .-coupon {
    background-size: calc(42*100vw/768) auto;
    bottom: auto;
    padding: 0 0 0 calc(50*100vw/768);
    position: relative;
  }

  .sell_items-caution,
  .sell_pickup-caution {
    font-size: calc(26*100vw/768);
    margin: calc(20*100vw/768) 0 0;
  }
}


/* Pickup
-------------------- */
.sell_pickup-brand {
  display: flex;
  gap: 20px;
  margin: 0 auto 25px;
}

.sell_pickup-brand > li {
  align-items: center;
  background: var(--main-bg);
  border: 1px solid var(--ex-border);
  border-radius: 10px;
  color: var(--sub-text);
  display: flex;
  font-weight: bold;
  justify-content: center;
  line-height: 1.3;
  text-align: center;
  min-height: 4em;
  width: 10em;
}

.sell_pickup-detail {
  display: none;
  flex-direction: column;
  flex-wrap: wrap;
  font-size: 13px;
  height: calc(1em * 1.4 * 14);
  margin: 0 auto 25px;
}

.sell_pickup-detail.-open {
  display: flex;
}

.sell_pickup-detail > li {
  padding-left: 1em;
  text-indent: -1em;
}

.sell_pickup-detail > li::before {
  content: '・';
}

.sell_pickup-btn {
  background: var(--sub-text);
  border-radius: 51px;
  color: var(--main-bg);
  cursor: pointer;
  display: block;
  font-weight: 600;
  height: 51px;
  line-height: 51px;
  margin: 0 auto;
  position: relative;
  text-align: center;
  width: 165px;
}

.sell_pickup-btn::before {
  content: 'もっと見る';
}
.sell_pickup-btn.-open::before {
  content: '閉じる';
}

.sell_pickup-btn::after {
  content: '＋';
  font-weight: normal;
  position: absolute;
  right: 15px;
}
.sell_pickup-btn.-open::after {
  content: 'ー';
}

@media screen and (max-width: 768px) {
  .sell_pickup-brand {
    gap: calc(20*100vw/768);
    margin: 0 auto calc(50*100vw/768);
    width: fit-content;
  }

  .sell_pickup-brand > li {
    font-size: calc(30*100vw/768);
  }

  .sell_pickup-detail {
    font-size: calc(26*100vw/768);
    height: auto;
    line-height: 1.6;
    margin: 0 auto calc(50*100vw/768);
  }

  .sell_pickup-detail.-open {
    display: block;
  }

  .sell_pickup-btn {
    font-size: calc(28*100vw/768);
    height: calc(99*100vw/768);
    line-height: calc(99*100vw/768);
    width: calc(316*100vw/768);
  }

  .sell_pickup-btn::after {
    right: calc(32*100vw/768);
  }
}


/* Trade
-------------------- */
.sell_trade-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 70px;
}

.sell_trade-flow > li {
  align-items: center;
  background: var(--sub-bg01);
  border-radius: 10px;
  display: flex;
  gap: 50px;
  padding: 30px 30px 0 40px;
  position: relative;
  width: 100%;
}

.sell_trade-flow > li img {
  width: 200px;
}

.sell_trade-flow-block {
  padding: 0 0 30px;
}

.sell_trade-flow-step {
  background: var(--sub-text);
  color: var(--main-bg);
  display: inline-block;
  font-size: 14px;
  font-weight: 600;
  line-height: 26px;
  margin: 0 15px 0 0; 17px 0;
  position: relative;
  text-align: center;
  width: 87px;
}

.sell_trade-flow-step::after {
  border: solid transparent;
  border-width: 8px 15px;
  border-left-color: var(--sub-text);
  content: '';
  display: block;
  height: 0;
  position: absolute;
  right: -24px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
}

.sell_trade-flow-head {
  color: var(--sub-text);
  display: inline-block;
  font-size: 18px;
  font-weight: 600;
  line-height: 26px;
}

.sell_trade-flow-text {
  margin: 17px auto 25px;
}

.sell_trade-flow-detail {
  border-top: 1px solid var(--ex-bg);
  font-size: 13px;
  padding: 20px 0 0;
}

.sell_trade-flow > li::after {
  border: solid transparent;
  border-top-color: var(--ex-bg);
  border-width: 18px 20px;
  bottom: -62px;
  content: '';
  display: block;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
}
.sell_trade-flow > li:last-child::after {
  content: none;
}

@media screen and (max-width: 768px) {
  .sell_trade {
    padding: 0 0 calc(30*100vw/768);
  }

  .sell_trade-flow {
    gap: calc(90*100vw/768);
  }

  .sell_trade-flow > li {
    border-radius: calc(20*100vw/768);
    flex-wrap: wrap;
    gap: calc(30*100vw/768);
    padding: calc(60*100vw/768) calc(46*100vw/768);
  }

  .sell_trade-flow > li img {
    margin: 0 auto;
    width: calc(358*100vw/768);
  }

  .sell_trade-flow-block {
    padding: 0;
  }

  .sell_trade-flow-step {
    display: block;
    font-size: calc(26*100vw/768);
    line-height: calc(48*100vw/768);
    margin: 0 auto calc(20*100vw/768);
    width: calc(162*100vw/768);
  }

  .sell_trade-flow-step::after {
    border-width: calc(17*100vw/768) calc(15*100vw/768);
    border-left-color: transparent;
    border-top-color: var(--sub-text);
    bottom: calc(-30*100vw/768);
    left: 50%;
    right: auto;
    top: auto;
    transform: translateX(-50%);
  }

  .sell_trade-flow-head {
    display: block;
    font-size: calc(35*100vw/768);
    line-height: inherit;
    text-align: center;
  }

  .sell_trade-flow-text {
    font-size: calc(30*100vw/768);
    margin: calc(30*100vw/768) auto calc(50*100vw/768);
  }

  .sell_trade-flow-detail {
    font-size: calc(26*100vw/768);
    padding: calc(50*100vw/768) 0 0;
  }

  .sell_trade-flow > li::after {
    border-width: calc(30*100vw/768);
    bottom: calc(-87*100vw/768);
  }
}


/* FAQ
-------------------- */
.faq-list {
  border-bottom: 1px solid var(--ex-bg);
  margin: 0 auto 25px;
}

.faq-list dt {
  border-top: 1px solid var(--ex-bg);
  cursor: pointer;
  font-weight: 600;
  padding: 20px 50px 20px 15px;
  position: relative;
}
.faq-list dt:first-child {
  border-top: none;
}

.faq-list dt.-open {
  padding-top: 30px;
}

.faq-list dt::after {
  content: '＋';
  position: absolute;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}

.faq-list dt.-open::after {
  content: 'ー';
  margin-top: 10px;
}

.faq-list dd {
  display: none;
  font-size: 13px;
  padding: 0 50px 30px 15px;
}
.faq-list dd.-open {
  display: block;
}

.faq-note {
  margin: 12px 0 0;
  font-weight: 300;
}

.faq-btn {
  background: var(--sub-text);
  border-radius: 51px;
  color: var(--main-bg);
  display: block;
  font-weight: 600;
  height: 51px;
  line-height: 51px;
  margin: 0 auto;
  position: relative;
  text-align: center;
  width: 165px;
}

.faq-btn::after {
  content: '→';
  font-weight: normal;
  position: absolute;
  right: 15px;
}

@media screen and (max-width: 768px) {
  .faq-list {
    border-width: calc(1*100vw/768);
    margin: 0 auto calc(50*100vw/768);
  }

  .faq-list dt {
    border-width: calc(1*100vw/768);
    padding: calc(45*100vw/768) calc(60*100vw/768) calc(45*100vw/768) calc(10*100vw/768);
  }

  .faq-list dt.-open {
    padding-top: calc(45*100vw/768);
  }

  .faq-list dt::after {
    right: calc(10*100vw/768);
  }

  .faq-list dt.-open::after {
    margin-top: 0;
  }

  .faq-list dd {
    font-size: calc(26*100vw/768);
    padding: calc(30*100vw/768) calc(10*100vw/768) calc(45*100vw/768);
  }

  .faq-btn {
    border-radius: calc(99*100vw/768);
    font-size: calc(28*100vw/768);
    height: calc(99*100vw/768);
    line-height: calc(99*100vw/768);
    width: calc(316*100vw/768);
  }

  .faq-btn::after {
    right: calc(33*100vw/768);
  }
}


/* Footer
-------------------- */
.footer {
  background: #3C3C3C;
  min-height: 100px;
}

@media screen and (max-width: 768px) {
  .footer {
    min-height: fit-content;
      padding-bottom:  calc(100*100vw/768);
  }
}
