@charset "UTF-8";
/* ------------------------------------------------
  index
------------------------------------------------ */
#topics {
  font-size: 10px;
}
#topics em {
  color: #8A6C73;
}
#topics .inner {
  font-weight: bold;
  padding: 19rem 0;
}
#topics .inner h1 {
  text-align: center;
  margin: 0 auto 11rem;
  width: 21.9rem;
}
#topics .inner ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  width: 180rem;
  margin: 0 auto;
}
#topics .inner ul li {
  width: 37.4rem;
  margin: 0 3.7rem;
}
@media screen and (min-width: 640.1px) {
  #topics .inner ul li:nth-child(n+5) {
    margin-top: 7rem;
  }
}
#topics .inner ul li a:hover {
  text-decoration: none;
}
#topics .inner ul li a:hover .img img {
  transform: scale(1.1);
}
#topics .inner ul li a .img {
  border-radius: 1rem;
  margin-bottom: 3rem;
  aspect-ratio: 3/2;
  overflow: hidden;
  align-content: center;
}
#topics .inner ul li a .img img {
  transition: transform 1.4s ease;
}
#topics .inner ul li a .date {
  font-size: 1.6rem;
  color: #AB8085;
  margin-bottom: 0.8rem;
  display: flex;
  justify-content: space-between;
}
#topics .inner ul li a .date em {
  font-style: normal;
  border: 1px solid #AB8085;
  border-radius: 100px;
  font-size: 80%;
  padding: 0.2em 0.5em;
}
#topics .inner ul li a .txt {
  font-size: 1.6rem;
  color: #8A6C73;
  line-height: 1.8;
}
#topics .inner ul + .link_more {
  text-align: center;
  padding-top: 27rem;
  margin-top: -13.5rem;
}
@media screen and (max-width: 640px) {
  #topics .inner {
    padding: 5.4rem 3.6rem;
  }
  #topics .inner h1 {
    width: auto;
    height: 2rem;
    margin: 0 auto 6.5rem;
  }
  #topics .inner h1 img,
  #topics .inner h1 svg {
    width: auto;
    height: 100%;
  }
  #topics .inner ul {
    display: block;
    padding: 0;
    width: auto;
  }
  #topics .inner ul li {
    width: 100%;
    margin: 0 auto 3.7rem;
  }
  #topics .inner ul li a .img {
    border-radius: 0.6rem;
    margin-bottom: 1.9rem;
  }
  #topics .inner ul li a .date {
    font-size: 1.3rem;
    margin-bottom: 0.5rem;
  }
  #topics .inner ul li a .txt {
    font-size: 1.3rem;
  }
  #topics .inner ul + .link_more {
    padding-top: 13rem;
    margin-top: -13rem;
  }
}

/* ------------------------------------------------
 記事
------------------------------------------------ */
#article .inner {
  padding: 19rem 0;
  width: 1000px;
  box-sizing: border-box;
  position: relative;
}
#article .inner .end {
  text-align: center;
  margin-top: -3rem;
  margin-bottom: 2rem;
}
#article .inner .end em {
  display: inline-block;
  font-size: 3rem;
  font-style: normal;
  border: 3px solid #AB8085;
  border-radius: 100px;
  line-height: 1;
  padding: 0.2em 1em 0.3em;
}
#article h1 {
  font-size: 5.5rem;
  font-weight: 600;
  color: #8A6C73;
  letter-spacing: 0.06em;
  margin-bottom: 7rem;
}
#article h1 strong {
  display: block;
  text-align: center;
  margin-bottom: 3rem;
}
#article h1 span.middle {
  display: block;
  font-size: 80%;
  text-align: left;
}
#article h1 span.small {
  display: block;
  font-size: 70%;
  text-align: left;
}
#article h1 .line {
  display: inline-block;
}
#article h1 sup {
  font-size: 40%;
}
#article .date {
  font-size: 2.5rem;
  font-weight: 600;
  color: #AB8085;
  letter-spacing: 0.1em;
  margin-bottom: 3rem;
  display: flex;
  justify-content: space-between;
}
#article .date em {
  font-style: normal;
  border: 1px solid #AB8085;
  border-radius: 100px;
  font-size: 80%;
  padding: 0.2em 0.5em 0.3em;
}
#article .body {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 1220px) {
  #article .inner {
    width: 100rem;
  }
  #article .body {
    width: 100rem;
  }
}
@media screen and (max-width: 640px) {
  #article .inner {
    padding: 5.4rem 3.6rem;
    width: auto;
  }
  #article .inner .end {
    margin-top: -1.5rem;
  }
  #article .inner .end em {
    font-size: 1.6rem;
  }
  #article h1 {
    font-size: 1.8rem;
    margin-bottom: 1.2rem;
  }
  #article h1 strong {
    margin-bottom: 1.5rem;
  }
  #article .date {
    font-size: 1.2rem;
    margin-bottom: 1rem;
  }
  #article .body {
    width: auto;
  }
}

/* ------------------------------------------------
 本文
------------------------------------------------ */
.pc-m_sp-s {
  font-size: 2rem;
}
@media screen and (max-width: 640px) {
  .pc-m_sp-s {
    font-size: 1rem;
  }
}

#article #kv,
#article .kv {
  margin: 0 auto 8rem;
}
#article #kv .inline_movie {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
#article #kv .annotation {
  font-size: 2rem;
  margin-top: 0.75em;
}
#article .txt + #kv,
#article .txt + .kv {
  margin-top: 8rem;
}
#article h2 {
  font-size: 3.8rem;
  font-weight: bold;
  line-height: 1.6;
  margin-top: 12rem;
  margin-bottom: 1.3em;
  text-align: center;
}
#article h2 .sub1 {
  display: block;
  font-size: 3rem;
  letter-spacing: 0.1em;
  margin-bottom: 7rem;
}
#article h2 .sub2 {
  display: block;
  font-size: 2rem;
}
#article h3 {
  font-size: 3.2rem;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 8rem;
  margin-bottom: 1.3em;
}
#article h4 {
  font-size: 2.6rem;
  font-weight: bold;
  margin-top: 4rem;
  margin-bottom: 0.8em;
}
#article em {
  font-weight: bold;
  font-style: normal;
}
#article .txt {
  font-size: 2.6rem;
  color: #8A6C73;
  line-height: 2;
}
#article .txt .annotation {
  font-size: 1.8rem;
  display: block;
}
#article .txt a {
  color: #B78791;
  text-decoration: underline;
  display: inline-block;
  line-height: 1.4;
  word-break: break-all;
}
#article .txt + .txt,
#article .txt p + p {
  margin-top: 5rem;
}
#article .txt + .media,
#article .media + .media {
  margin-top: 10rem;
}
#article .center {
  text-align: center;
}
#article .center > * {
  text-align: left;
  display: inline-block;
}
#article .center .margin {
  margin-top: 0;
}
#article .middle {
  font-size: 2rem;
}
#article .middle.block {
  display: block;
}
#article .small {
  font-size: 1.6rem;
}
#article .small.block {
  display: block;
}
#article .small .annotation {
  font-size: 1.6rem;
}
#article table caption {
  font-size: 1.1em;
  font-weight: bold;
}
#article .txt th {
  white-space: nowrap;
  font-weight: inherit;
  padding-right: 0.5em;
  text-align: right;
  vertical-align: top;
}
#article .btn_back {
  margin-top: 12rem;
  text-align: center;
}
#article .btn_back a {
  display: inline-block;
  font-size: 2.2rem;
  color: #8A6C73;
  position: relative;
  letter-spacing: 0.1em;
  padding: 1.8rem 7rem;
  border: 1px solid #8A6C73;
  border-radius: 100rem;
  transition: all 0.2s ease;
}
#article .btn_back a::after {
  content: "";
  background: url(/images/common/link_arrow3.svg) 0 0 no-repeat;
  background-size: contain;
  width: 1.3rem;
  height: 1.6rem;
  display: block;
  transform: scale(-1, 1);
  position: absolute;
  top: calc(50% - 0.8rem);
  left: 3rem;
  z-index: 100;
  margin: auto;
  transition: left 0.15s ease;
}
#article .btn_back a:hover {
  color: #FFF !important;
  text-decoration: none;
  background-color: #8a6d73 !important;
  border-color: #8a6d73 !important;
}
#article .btn_back a:hover::after {
  background-image: url(/images/common/link_arrow0.svg);
  left: 2rem;
}
@media screen and (max-width: 640px) {
  #article #kv,
  #article .kv {
    margin: 0 -3.6rem 4rem;
  }
  #article #kv .annotation {
    font-size: 1.1rem;
  }
  #article .txt {
    font-size: 1.2rem;
    line-height: 2.2;
  }
  #article .txt.small {
    font-size: 1rem;
  }
  #article .txt + #kv,
  #article .txt + .kv {
    margin-top: 4rem;
  }
  #article .txt + .txt,
  #article .txt p + p {
    margin-top: 3rem;
  }
  #article .txt + .media,
  #article .media + .media {
    margin-top: 3rem;
  }
  #article .media + .txt {
    margin-top: 4rem;
  }
  #article h2 {
    font-size: 1.8rem;
    margin-top: 6rem;
    margin-bottom: 1.3em;
  }
  #article h2 .sub1 {
    font-size: 1.4rem;
    margin-bottom: 2.5rem;
  }
  #article h2 .sub2 {
    font-size: 1rem;
  }
  #article h3 {
    font-size: 1.4rem;
    margin-top: 4rem;
    margin-bottom: 1.3em;
  }
  #article h4 {
    font-size: 1.2rem;
    margin-top: 4rem;
    margin-bottom: 1.3em;
  }
  #article .txt .annotation {
    font-size: 1rem;
  }
  #article .middle {
    font-size: 1.2rem;
  }
  #article .small {
    font-size: 1rem;
  }
  #article .small .annotation {
    font-size: 0.9rem;
  }
  #article .btn_back {
    margin-top: 6rem;
  }
  #article .btn_back a {
    font-size: 1.2rem;
    padding: 1rem 4rem;
  }
  #article .btn_back a::after {
    width: 0.7rem;
    height: 0.8rem;
    left: 2rem;
    top: calc(50% - 0.4rem);
  }
}

/* ----------------------------
 movie
------------------------------*/
#article .movie {
  position: relative;
  width: 100%;
  margin: 0 auto;
  aspect-ratio: 16/9;
  overflow: hidden;
}
#article .movie a::before {
  content: "";
  display: block;
  width: 20.3rem;
  height: 25.9rem;
  position: absolute;
  top: 2rem;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 100;
  margin: auto;
  background-repeat: no-repeat;
  background-image: url(/images/concept/movie_attachment.png);
  background-size: contain;
  pointer-events: none;
  transition: transform 1.4s ease;
}
#article .movie a.ajust::before {
  top: 10rem;
}
#article .movie a:hover::before {
  transform: scale(0.95);
}
@media screen and (max-width: 640px) {
  #article .movie a::before {
    width: 6.1rem;
    height: 7.77rem;
  }
}

/* ----------------------------
 media
------------------------------*/
#article .media.m37 {
  max-width: 37rem;
  margin: 0 auto;
}
#article .media.m50 {
  max-width: 50rem;
  margin: 0 auto;
}
#article .media.m60 {
  max-width: 60rem;
  margin: 0 auto;
}
#article .media.mini {
  max-width: 40rem;
}
#article .media.mini.center {
  margin-left: auto;
  margin-right: auto;
}
#article .media.mini em {
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
  font-style: normal;
  text-align: center;
  margin-top: 0.8rem;
}
@media screen and (min-width: 640.1px) {
  #article .media img.small {
    width: auto;
    height: auto;
  }
}
@media screen and (max-width: 640px) {
  #article .media.mini {
    max-width: 70%;
  }
}

/* ----------------------------
 #article .group
------------------------------*/
#article .group {
  display: flex;
  justify-content: space-between;
}
#article .group.center {
  justify-content: center;
}
#article .group.award + .award {
  margin-top: 2rem;
}
#article .group .txt {
  flex: 1;
  padding-right: 2rem;
}
#article .group .txt h4 {
  margin-top: 0;
}
#article .group .ph {
  margin-top: 1.5rem;
}
#article .group .ph.c2 {
  display: flex;
  justify-content: space-between;
  width: 39rem;
}
#article .group .ph span {
  display: block;
  width: 19rem;
}
#article .group .ph em {
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
  font-style: normal;
  text-align: center;
  margin-top: 0.8rem;
}
@media screen and (max-width: 640px) {
  #article .group {
    display: block;
  }
  #article .group .ph {
    margin-top: 1.5rem;
  }
  #article .group .ph.c2 {
    width: 100%;
  }
  #article .group .ph span {
    width: 49%;
  }
}

/* ------------------------------------------------
 award
------------------------------------------------ */
#awards {
  width: 100rem;
  margin: 12rem auto 0;
}
#awards ul.list + .txt {
  margin-top: 8rem;
  text-align: center;
}
#awards ul.list li.frame .group .head {
  width: 46rem;
  display: flex;
  flex-direction: column;
}
#awards ul.list li.frame .group .head .name_en img {
  width: auto;
}
#awards ul.list li.frame .group .head .name_jp {
  font-size: 1.6rem;
  font-weight: 600;
  color: #916c73;
  letter-spacing: 0.01em;
  margin-top: 1.5em;
  margin-bottom: 3rem;
  margin-right: -2em;
}
#awards ul.list li.frame .group .head .ph {
  text-align: center;
}
#awards ul.list li.frame .group .head .ph img {
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  display: inline-block;
}
#awards ul.list li.frame.f1 .group .head .name_en img, #awards ul.list li.frame.f3 .group .head .name_en img {
  height: 3.15rem;
}
#awards ul.list li.frame.f2 .group .head .name_en img {
  height: 2.43rem;
}
#awards ul.list li.frame.f4 .group .head .name_en img {
  height: 6.48rem;
}
#awards ul.list li.frame.f5 .group .head .name_en img {
  height: 3.15rem;
}
#awards ul.list li.frame.f25_1 .group .head .name_en img {
  height: 6.48rem;
}
#awards ul.list li.frame + li.frame {
  margin-top: 16rem;
}
#awards ul.list .product_all {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 5rem;
}
#awards ul.list .product_all .logo {
  width: 19rem;
}
#awards ul.list .product_all .txt {
  font-size: 2rem;
  font-weight: 600;
  text-align: center;
  margin-top: 0.5rem;
}
@media screen and (min-width: 640.1px) {
  #awards ul.list li.frame .group.large {
    display: block;
    margin-bottom: 5rem;
  }
  #awards ul.list li.frame .group.large .head {
    width: auto;
    flex-direction: row;
    justify-content: center;
    align-items: center;
  }
  #awards ul.list li.frame .group.large .head > * {
    margin: 0 3rem;
  }
  #awards ul.list li.frame .group.large .head .ph.no_award {
    width: 27rem;
  }
}

/* ----------------------------
 award
------------------------------*/
#awards ul.list li.frame .group .award {
  width: 49rem;
  align-self: center;
}
#awards ul.list li.frame .group .award .logo {
  margin-bottom: 8.3rem;
  margin-bottom: 4rem;
}
#awards ul.list li.frame .group .award ul {
  display: flex;
  flex-direction: column;
}
#awards ul.list li.frame .group .award li {
  font-size: 1.7rem;
  font-weight: bold;
  color: #806b70;
  letter-spacing: 0.06em;
  text-align: center;
  position: relative;
  height: 9.1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
#awards ul.list li.frame .group .award li a {
  font-size: 1.5rem;
  font-weight: 600;
  color: #B78791;
  text-decoration: underline;
  display: inline-block;
  line-height: 1.4;
  word-break: break-all;
  display: block;
  margin-top: 0.7rem;
}
#awards ul.list li.frame .group .award.single_column {
  width: 107rem;
  width: 100%;
}
#awards ul.list li.frame .group .award.single_column ul {
  justify-content: center;
  flex-direction: row;
}
#awards ul.list li.frame .group .award.single_column li {
  width: 49rem;
}
#awards ul.list li.frame .group .award.single_column li.short {
  width: 40rem;
}
#awards ul.list li.frame .group .award.twin_column {
  width: 107rem;
}
#awards ul.list li.frame .group .award.twin_column ul {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: space-between;
}
#awards ul.list li.frame .group .award.twin_column li {
  width: 49rem;
  margin-top: 0;
  margin-bottom: 20px;
}
#awards ul.list li.frame .group .award.twin_column li .annotation {
  font-size: 1.4rem;
  color: #8A6C73;
  line-height: 1.8;
  margin-top: 0.5rem;
}

#awards ul.list li.frame .group .award li + li {
  margin-top: 20px;
}

#awards ul.list li.frame .group .award li em {
  font-style: normal;
  background-color: #ffe7b2;
  background-color: #fff4f0;
  padding: 3px 5px;
}

#awards ul.list li.frame .group .award li::before,
#awards ul.list li.frame .group .award li::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  width: 2.7rem;
  height: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: 50% 50%;
}

#awards ul.list li.frame .group .award li::before {
  left: 0;
  background-image: url(/images/top/leaf_l.svg);
}

#awards ul.list li.frame .group .award li::after {
  right: 0;
  background-image: url(/images/top/leaf_r.svg);
}

#awards .link_more {
  text-align: center;
  margin-top: 7rem;
  display: flex;
  justify-content: center;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
}

@media screen and (max-width: 640px) {
  #awards,
  #awards.large {
    width: 100%;
    margin: 4.2rem auto 0;
  }
  #awards.large ul.list {
    padding: 0;
  }
  #awards ul.list + .txt {
    margin-top: 4rem;
  }
  #awards ul.list .product_all {
    margin-bottom: 0;
  }
  #awards ul.list .product_all .logo {
    width: 15rem;
  }
  #awards ul.list .product_all .txt {
    font-size: 1.8rem;
    font-weight: 600;
    text-align: center;
    margin-top: 0.5rem;
  }
  #awards ul.list li.frame .group .head {
    width: 100%;
    display: flex;
    flex-direction: column;
    text-align: center;
  }
  #awards ul.list li.frame + li.frame {
    margin-top: 6.5rem;
  }
  #awards ul.list li.frame .group .head .name_en img {
    width: auto;
  }
  #awards ul.list li.frame.f1 .group .head .name_en img,
  #awards ul.list li.frame.f3 .group .head .name_en img,
  #awards ul.list li.frame.f4 .group .head .name_en img,
  #awards ul.list li.frame.f5 .group .head .name_en img {
    height: 1.75rem;
  }
  #awards ul.list li.frame.f25_1 .group .head .name_en img {
    height: 1.75rem;
  }
  #awards ul.list li.frame.f2 .group .head .name_en img {
    height: 1.35rem;
  }
  #awards ul.list li.frame .group .head .name_jp {
    font-size: 1.3rem;
    margin-top: 0.3em;
    margin-bottom: 2rem;
    margin-right: 0;
  }
  #awards ul.list li.frame .group .head .ph {
    text-align: center;
    margin-top: 0;
  }
  #awards ul.list li.frame .group .head .ph img {
    width: auto;
    height: auto;
    /* max-width: initial; */
    display: inline-block;
  }
  #awards ul.list li.frame .group .award {
    width: 100%;
    margin-top: 3rem;
  }
  #awards ul.list li.frame .group .award + .award {
    margin-top: 1.2rem;
  }
  #awards ul.list li.frame .group .award .logo {
    margin-bottom: 1.5rem;
  }
  #awards ul.list li.frame .group.center .award .logo {
    margin-bottom: 0;
  }
  #awards ul.list li.frame .group .award ul {
    display: flex;
    flex-direction: column;
  }
  #awards ul.list li.frame .group .award li {
    height: 4.75rem;
    font-size: 1rem;
  }
  #awards ul.list li.frame .group .award li a {
    font-size: 0.9rem;
    margin-top: 0.3rem;
    /* 		margin-bottom: -1rem; */
  }
  #awards ul.list li.frame .group .award.single_column {
    width: 100%;
  }
  #awards ul.list li.frame .group .award.twin_column {
    width: 100%;
  }
  #awards ul.list li.frame .group .award.twin_column ul {
    display: block;
  }
  #awards ul.list li.frame .group .award.twin_column li {
    width: 100%;
    margin-top: 0;
    margin-bottom: 1.2rem;
  }
  #awards ul.list li.frame .group .award li + li {
    margin-top: 1.2rem;
  }
  #awards ul.list li.frame .group .award li em {
    padding: 1.5px 3px;
  }
  #awards ul.list li.frame .group .award li::before,
  #awards ul.list li.frame .group .award li::after {
    width: 2.7rem;
    height: 100%;
  }
  #awards ul.list li.frame .group .award li::before {
    left: 0;
    background-image: url(/images/top/leaf_l.svg);
  }
  #awards ul.list li.frame .group .award li::after {
    right: 0;
    background-image: url(/images/top/leaf_r.svg);
  }
  #awards .link_more {
    text-align: center;
    margin-top: 3.5rem;
    flex-direction: column;
    row-gap: 2rem;
  }
}
/* ------------------------------------------------
 mustbuycampaign @2025-10-06
------------------------------------------------ */
#article.mustbuycampaign .btn_buy {
  text-align: center;
  margin-top: 7rem;
  width: auto;
}
#article.mustbuycampaign .btn_buy a {
  color: #f9e6df;
  font-size: 2.6rem;
  text-decoration: none;
  padding-left: 5rem;
  padding-right: 5rem;
  width: auto;
}
#article.mustbuycampaign .step {
  display: flex;
  flex-direction: column;
  row-gap: 6rem;
}
#article.mustbuycampaign .step li {
  display: flex;
}
#article.mustbuycampaign .step li p {
  margin: 0;
}
#article.mustbuycampaign .step li .img {
  width: 175px;
}
#article.mustbuycampaign .step li .txt {
  flex-grow: 1;
  flex-basis: 0;
  margin-left: 1.5em;
  line-height: 1.6;
}
#article.mustbuycampaign .step li .num {
  color: #bc989a;
  font-weight: bold;
  margin-bottom: 0.5em;
}
#article.mustbuycampaign .howto {
  display: flex;
  -moz-column-gap: 4rem;
       column-gap: 4rem;
}
#article.mustbuycampaign .howto .img {
  width: 200px;
}
#article.mustbuycampaign .howto .txt {
  flex-grow: 1;
  flex-basis: 0;
}
#article.mustbuycampaign .howto .txt ol {
  margin-top: 0.75em;
}
#article.mustbuycampaign .howto .txt ol li i {
  color: #f9e6df;
  font-style: normal;
  line-height: 1.3;
  text-align: center;
  border-radius: 1.4em;
  background-color: #bc989a;
  margin-right: 0.4em;
  width: 1.4em;
  height: 1.4em;
  display: inline-block;
}
#article.mustbuycampaign .howto + .annotation {
  margin-top: 4rem;
}
@media screen and (min-width: 640.1px) {
  #article.mustbuycampaign .txt .heading {
    font-size: 2.8rem;
    margin-bottom: 1rem;
  }
  #article.mustbuycampaign .items {
    text-align: center;
  }
  #article.mustbuycampaign .items img {
    width: auto !important;
  }
  #article.mustbuycampaign .items + .annotation {
    margin-left: 55px;
  }
  #article.mustbuycampaign .step {
    margin: 0 auto;
    width: 750px;
  }
  #article.mustbuycampaign .step li {
    flex-grow: 1;
    flex-basis: 0;
  }
  #article.mustbuycampaign .howto {
    margin: 0 auto;
    width: 750px;
  }
  #article.mustbuycampaign .howto .txt {
    font-size: min(2.6rem, 18px);
  }
  #article.mustbuycampaign .howto + .annotation {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 640px) {
  #article.mustbuycampaign .txt .heading {
    margin-bottom: 1rem;
  }
  #article.mustbuycampaign .btn_buy {
    margin-top: 4rem;
  }
  #article.mustbuycampaign .btn_buy a {
    font-size: 1.4rem;
    padding: 1.4rem 4rem 1.4rem 3.5rem;
  }
  #article.mustbuycampaign .step {
    row-gap: 3rem;
  }
  #article.mustbuycampaign .step li .num {
    font-size: 1.5rem;
    margin-bottom: 0;
  }
  #article.mustbuycampaign .step li .img {
    width: 8.75rem;
  }
  #article.mustbuycampaign .step + .btn_buy {
    margin-top: 3rem;
  }
  #article.mustbuycampaign .howto {
    -moz-column-gap: 2rem;
         column-gap: 2rem;
  }
  #article.mustbuycampaign .howto .img {
    margin-left: -1.2rem;
    width: 16rem;
  }
  #article.mustbuycampaign .howto + .annotation {
    margin-top: 1.5rem;
  }
}

/* ------------------------------------------------
 profile @2026-02-20
------------------------------------------------ */
#article .creator_block,
#article .profile_block {
  margin-top: 11rem !important;
}
@media screen and (max-width: 640px) {
  #article .creator_block,
  #article .profile_block {
    margin-top: 3.5rem !important;
  }
}

#article .creator_block {
  border: 1px solid #BC989A;
  padding: 6.5rem;
}
#article .creator_block h3 {
  margin-top: 0;
}
@media screen and (max-width: 640px) {
  #article .creator_block {
    padding: 2rem;
  }
}

#article .profile_block {
  color: #806B70;
  background-color: #e8dddc;
  padding: 6.5rem;
}
#article .profile_block ul li {
  line-height: 1.75;
}
#article .profile_block ul li + li {
  margin-top: 0.25em;
}
#article .profile_block > .title {
  text-align: center;
  line-height: 1;
  margin: 0;
}
#article .profile_block > .heading .name {
  font-size: 3rem;
  font-weight: bold;
  margin-top: 0.75em;
  margin-right: -2em;
}
#article .profile_block > .heading .profile {
  font-size: 1.3rem;
  font-weight: bold;
  margin-top: 1em;
  margin-right: -1em;
}
#article .profile_block > .body {
  font-size: 1.3rem;
  width: 100%;
}
#article .profile_block > .body table tr + tr th, #article .profile_block > .body table tr + tr td {
  padding-top: 1em;
}
#article .profile_block > .body table th {
  font-weight: bold;
  padding-right: 1em;
}
#article .profile_block > .body .list li {
  text-indent: -1em;
  padding-left: 1em;
}
#article .profile_block > .body .list li ul {
  margin-left: 1.5em;
}
#article .profile_block > .body .list li ul li {
  text-indent: initial;
  padding-left: 0;
}
@media screen and (max-width: 1599px) and (min-width: 640.1px) {
  #article .profile_block > .heading .name {
    font-size: 3.2rem;
  }
  #article .profile_block > .heading .profile {
    font-size: 1.625rem;
  }
  #article .profile_block > .body {
    font-size: 1.625rem;
  }
}
@media screen and (max-width: 1220px) and (min-width: 640.1px) {
  #article .profile_block > .heading .profile br {
    display: none;
  }
}
@media screen and (min-width: 640.1px) {
  #article .profile_block {
    display: grid;
    grid-template-columns: 40% 1fr;
    gap: 2em;
  }
  #article .profile_block > .title {
    grid-row: 1/span 1;
    grid-column: 1/span 2;
  }
  #article .profile_block > .heading {
    grid-row: 2/span 1;
    grid-column: 1/span 1;
  }
  #article .profile_block > .body {
    width: auto;
    grid-row: 2/span 1;
    grid-column: 2/span 1;
  }
}
@media screen and (max-width: 640px) {
  #article .profile_block {
    padding: 3rem 3.6rem;
    padding: 2.5rem 3rem;
  }
  #article .profile_block > .heading {
    margin-top: 1.5em;
  }
  #article .profile_block > .heading .name {
    font-size: 1.4rem;
  }
  #article .profile_block > .heading .profile {
    font-size: 1rem;
    margin-top: 0.5em;
  }
  #article .profile_block > .body {
    font-size: 1rem;
    margin-top: 1.5em;
  }
  #article .profile_block > .body table tr {
    display: flex;
    flex-direction: column;
  }
  #article .profile_block > .body table tr th {
    text-align: left;
  }
  #article .profile_block > .body table tr + tr td {
    padding-top: 0;
  }
  #article .profile_block > .body .list li ul {
    margin-left: 1em;
  }
}