@charset "UTF-8";
@import "https://fonts.googleapis.com/earlyaccess/notosansjp.css";

/* トップ
--------------------------------------------------------------- */
/* メインビジュアル */
.ot-main-visual {
  position: relative;
  background: var(--color-blue-02);
}
.ot-main-visual::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 92%;
  clip-path: polygon(0 0, 100% 54%, 0 100%);
  background: var(--color-yellow-02);
}
.ot-main-visual__text {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  width: 100%;
  height: 100%;
  padding: 15px 15px 46px;
  pointer-events: none; /* スライダーを操作可能にする */
}
.ot-main-visual__slider {
  margin: 16px;
  overflow: hidden;
}
.ot-main-visual__slider__inner {
  width: 200%;
  transform: translateX(-50%);
  position: relative;
  left: 50%;
}
.ot-main-visual__slider__inner .n2-ss-slider-controls {
  transform: scale(50%);
}
.ot-main-visual {
  overflow: hidden;
}
.ot-main-visual__slider {
  position: relative;
}
.ot-main-visual__control {
  bottom: 15% !important;
}
.ot-main-visual__control .swiper-pagination-bullet {
  background-color: var(--color-white);
  opacity: 0.6 !important;
}
.ot-main-visual__control .swiper-pagination-bullet-active {
  background-color: var(--color-white);
  opacity: 1 !important;
}
.ot-main-visual__text {
  aspect-ratio: 663/750;
}
.ot-main-visual__text .ot-image-change {
  display: block;
  margin: 8% auto 0;
  text-align: center;
}
/* お知らせ */
.ot-news__heading {
  margin-block: 14px 10px;
}
.ot-news-heading__icon {
  display: inline-block;
  width: 34px;
  height: auto;
}
.ot-news__list {
  margin-block: 0 24px;
}
.ot-news-list__item {
  display: flex;
  flex-direction: column;
  margin: 0 auto 14px;
  font-size: 0.875rem;
  font-weight: bold;
}
.ot-news-item__date {
  width: 100%;
  color: var(--color-primary);
}
.ot-news-item__text {
  overflow: hidden;
  width: 100%;
  margin: 4px auto;
  display: -webkit-box;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.ot-news-item__text:has(.ot-news-item__link) {
  color: var(--color-blue-03);
}
.ot-news-item__link {
  color: var(--color-blue-03);
  text-decoration: none;
  border-bottom: 2px solid var(--color-blue-03);
}
/* はねぴょんギフトとは */
.ot-section-layout--about {
  padding-bottom: 86px;
  background-color: var(--color-blue-01);
}
.ot-about__heading {
  margin-block: 30px 0;
  text-align: center;
  font-size: 1.25rem;
}
.ot-about-heading__text {
  position: relative;
  display: inline-block;
  z-index: 1;
}
.ot-about-heading__text::before {
  content: "";
  display: block;
  position: absolute;
  left: -36px;
  top: -12px;
  z-index: -1;
  width: 100%;
  max-width: 99px;
  aspect-ratio: 99 / 55;
  background: url("../img/top/feature_cloud_01.png") left center no-repeat;
  background-size: contain;
}
.ot-about-heading__text::after {
  content: "";
  display: block;
  position: absolute;
  right: -36px;
  top: -16px;
  z-index: -1;
  width: 100%;
  max-width: 131px;
  aspect-ratio: 131 / 71;
  background: url("../img/top/feature_cloud_02.png") right center no-repeat;
  background-size: contain;
}
.ot-about-details {
  position: relative;
  margin-top: 26px;
  padding-block: 36px 34px;
  padding-inline: 14px;
  border-radius: 10px;
  border: 1px solid var(--color-primary);
  background-color: var(--color-white);
}
.ot-about-details__summary {
  margin-block: 0;
  font-size: 1rem;
  font-weight: bold;
  text-align: center;
}
.ot-about-details__description {
  margin-block: 16px 0;
  font-size: 0.875rem;
  line-height: 2;
}
.ot-about-details__feature {
  margin-top: 36px;
}
.ot-about-feature {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  max-width: 948px;
  margin-inline: auto;
  padding-inline: 14px;
}
.ot-about-feature__item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  row-gap: 12px;
  padding: 48px 38px 14px;
  border-radius: 8px;
  border: 1px solid var(--color-primary);
  background: var(--color-yellow-01);
}
.ot-about-feature__item+.ot-about-feature__item {
  margin-top: 35px;
}
.ot-about-feature__label {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  flex-shrink: 0;
  justify-content: center;
  padding-block: 1px;
  padding-inline: 16px calc(16px - .1em);
  font-weight: bold;
  font-size: 1rem;
  color: var(--color-white);
  text-align: center;
  word-break: keep-all;
  border-radius: 6px;
  background: var(--color-primary);
}
.ot-about-feature__text {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-block: auto;
  text-align: center;
  font-size: 0.875rem;
  font-weight: bold;
}
/* 選べる寄付額 */
.ot-select-donation__heading {
  margin-top: 68px;
}
.ot-select-donation__donation-list {
  max-width: 100%;
  margin-block: 24px 0;
  margin-inline: auto;
}
.ot-donation-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 10px;
  text-align: center;
}
.ot-donation-list::before {
  content: "";
  position: absolute;
  top: -29%;
  right: 12px;
  width: 20.2666666667vw;
  max-width: 76px;
  aspect-ratio: 76/93;
  background: url("../img/top/guide-balloon.svg") center right no-repeat;
  background-size: contain;
}
.ot-donation-list__item {
  display: flex;
  flex-direction: column;
  row-gap: 2px;
}
.ot-donation-list__heading {
  padding: 5px;
  margin-block: 0;
  font-size: 0.75rem;
  font-weight: bold;
  color: var(--color-white);
  background-color: var(--color-primary);
}
.ot-price-list {
  display: flex;
  flex-direction: column;
  row-gap: 9px;
  height: 100%;
  margin-top: 6px;
}
.ot-price-list__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding-block: 4px;
  font-size: 0.75rem;
  font-weight: bold;
}
.ot-price-list--donation>.ot-price-list__item {
  position: relative;
  border: 1px solid var(--color-gray-01);
}
.ot-price-list--gift>.ot-price-list__item {
  background: var(--color-yellow-01);
}
.ot-price-list--donation>.ot-price-list__item::before,
.ot-price-list--donation>.ot-price-list__item::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -20px;
  display: block;
  height: 1px;
  background: var(--color-primary);
  border-radius: 10px;
  transform: translateY(-50%);
}
.ot-price-list--donation>.ot-price-list__item::before {
  width: 30px;
}
.ot-price-list--donation>.ot-price-list__item::after {
  width: 8px;
  transform: rotate(50deg) translate(-1px, calc(-50% - 3px));
}
.ot-donation__icon {
  width: 15.25vw;
  margin: 10px 16px 0 auto;
}
/* ご利用方法 */
.ot-section-layout--steps {
  padding-block: 14px 120px;
  background-color: var(--color-blue-01);
}
.ot-steps-heading--accent {
  position: relative;
  display: block;
  font-size: 0.8rem;
  color: var(--color-red-01);
}
.ot-steps-heading--accent::before {
  content: "・・・・";
  display: block;
  line-height: 0.8;
}
.ot-guide__process--wrap {
  border-radius: 10px;
  border: 1px solid var(--color-primary);
  background: var(--color-white);
}
.ot-guide__process {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 70px;
  margin-block: 24px 0;
  padding: 60px 30px 40px;
}
.ot-process__item {
  display: flex;
  flex-direction: column;
  row-gap: 16px;
  position: relative;
  padding: 0px 20px 24px;
  border-radius: 10px;
  border: 1px solid var(--color-primary);
  background: var(--color-yellow-01);
}
.ot-process-item__image {
  margin-inline: auto;
}
.ot-process-item__text {
  font-weight: bold;
  width: fit-content;
  margin: 0 auto;
}
.ot-process-item__number {
  margin: -2.6rem auto 0;
}
.ot-process-number__image {
  flex-shrink: 0;
  max-width: 80px;
}
.ot-guide__button {
  margin-top: 26px;
  margin-inline: 20px;
}
/* 使える加盟店 */
.ot-section-layout--shops {
  padding-block: 46px 40px;
}
.ot-shops__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.ot-shops__button {
  max-width: 260px;
  margin-top: 16px;
  margin-inline: auto;
}
/* 加盟店募集 */
.ot-section-layout--recruit {
  padding: 40px 0 20px;
}
.ot-recruit__cta {
  margin-inline: auto;
  background: var(--color-blue-01);
}

/* ご利用方法
--------------------------------------------------------------- */
.ot-section-layout--howto {
  margin-top: 30px;
  padding-bottom: 30px;
}
.ot-howto__process {
  padding: 60px 0px 40px;
}
.ot-howto__item {
  min-height: 300px;
  background: var(--color-white);
}
.ot-howto__button {
  margin-top: 26px;
  margin-inline: 20px;
}
.ot-howto__number-item {
  width: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 16px;
}

/* 加盟店一覧
--------------------------------------------------------------- */
.ot-section-layout--shoplist {
  padding-bottom: 20px;
}
.ot-shoplist-search__tabs {
  margin-top: 24px;
}
.ot-search-tabs__switcher {
  display: flex;
  justify-content: center;
  padding-inline: 10px;
  border-bottom: 1px solid var(--color-primary);
}
.ot-search-tabs__button {
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: center;
  justify-content: center;
  width: 25%;
  margin-left:-1px;
  padding-block: 6px;
  font-size: 1rem;
  font-weight: bold;
  color: var(--color-primary);
  background-color: var(--color-white);
  border: 1px solid var(--color-primary);
  border-bottom: none;
}
.ot-search-tabs__button[aria-selected=true] {
  background-color: var(--color-blue-01);
}
.ot-search-tabs__button--eat::before,
.ot-search-tabs__button--stay::before,
.ot-search-tabs__button--shopping::before,
.ot-search-tabs__button--other::before {
  content: "";
  display: block;
  height: 30px;
  aspect-ratio: 2;
  background: center center no-repeat;
  background-size: contain;
}
.ot-search-tabs__button--eat::before {
  background-image: url("../img/shoplist/eat.png");
}
.ot-search-tabs__button--stay::before {
  background-image: url("../img/shoplist/stay.png");
}
.ot-search-tabs__button--shopping::before {
  background-image: url("../img/shoplist/shopping.png");
}
.ot-search-tabs__button--other::before {
  background-image: url("../img/shoplist/other.png");
}
.ot-search-tabs__content {
  margin-top: 50px;
}
.ot-search-tabs__content .ot-tab-content__item {
  padding: 0;
}
.ot-shop-cards {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 12px;
}
.ot-shop-cards__items {
  display: flex;
  flex-direction: column-reverse;
  row-gap: 0;
}
.ot-shop-detail-card {
  background-color: var(--color-white);
  border-radius: 16px;
}
.ot-shop-detail-card__head {
  position: relative;
  height: -moz-fit-content;
  height: fit-content;
}
.ot-shop-detail-card__link {
  opacity: 1;
}
.ot-shop-detail-card__link:hover {
  opacity: 0.6;
}
.ot-shop-detail-card__image {
  width: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  aspect-ratio: 3 / 2;
  background: var(--color-blue-01);
}
.ot-shop-detail-card__body {
  height: 100%;
}
.ot-shop-details {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 10px;
  padding: 16px 14px 20px;
}
.ot-shop-details__heading {
  overflow: hidden;
  margin: 0;
  font-size: 1.125rem;
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.ot-shop-details__summary {
  overflow: hidden;
  display: -webkit-box;
  line-clamp: 3;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.ot-shop-details__label {
  margin-top: 2px;
  padding: 4px 8px;
  font-size: 0.875rem;
  border-radius: 8px;
  background: var(--color-gray-01);
}
/* もっと見るボタン */
.ot-shop-cards__button{
  margin-top: 20px;
}

/* よくある質問
--------------------------------------------------------------- */
.ot-faq__inner {
  padding-top: 30px;
}
.ot-faq-category {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 10px;
  margin: 0 auto 50px;
}
.ot-faq-category__item {
  display: flex;
  flex-direction: column;
  gap: 10px;
  aspect-ratio: 1.8;
  border: 2px solid var(--color-primary);
  border-radius: 6px;
}
.ot-faq-category__anchor {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding-block: 25% 10px;
  font-size: 0.8125rem;
  font-weight: bold;
  text-align: center;
  color: var(--color-primary);
  text-decoration: none;
  letter-spacing: 0.08em;
  line-height: 1.2;
  transform: translateY(-2px);
}
.ot-faq-category__anchor::before {
  content: "";
  position: absolute;
  top: 8%;
  width: 100%;
  height: 38%;
  margin: auto;
  background: no-repeat center;
  background-size: contain;
}
.ot-faq-category__anchor--about::before  {
  background-image: url("../img/faq/icon-hanepyon.png");
}
.ot-faq-category__anchor--smartphone {
  word-break: keep-all;
}
.ot-faq-category__anchor--smartphone::before  {
  background-image: url("../img/faq/icon-smartphone.png");
}
.ot-faq-category__anchor--login::before  {
  background-image: url("../img/faq/icon-login.png");
}
.ot-faq-category__anchor--furusato::before  {
  background-image: url("../img/faq/icon-furusato.png");
}
.ot-faq-category__anchor--other::before  {
  background-image: url("../img/faq/icon-other.png");
}
.ot-faq-category__anchor::after {
  content: "";
  position: absolute;
  bottom: -6px;
  display: block;
  width: 100%;
  height: 24px;
  background-color: var(--color-primary);
  -webkit-mask-image: url("../common/img/svg-icons/caret-down.svg");
  mask-image: url("../common/img/svg-icons/caret-down.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
}
.ot-faq__title {
  margin-bottom: 20px;
  font-size: 1.25rem;
  text-align: center;
}
.ot-faq__group {
  margin-top: 50px;
  margin-bottom: 20px;
}
.ot-faq__item {
  border:2px solid var(--color-blue-01);
}
.ot-faq__item + .ot-faq__item {
  margin-top: 24px;
}
.ot-faq__content {
  margin: 0;
  padding: 10px;
  display: flex;
  gap: 12px;
  align-items: baseline;
  font-size: 0.875rem;
  font-weight: bold;
}
.ot-faq__question {
  position: relative;
  padding-right: 34px;
  font-size: 1rem;
  background: var(--color-blue-01);
}
.ot-faq__question::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 6px;
  transform: translateY(-50%);
  display: block;
  width: 26px;
  height: 10px;
  background-color: var(--color-primary);
  -webkit-mask-image: url("../common/img/svg-icons/caret-down.svg");
  mask-image: url("../common/img/svg-icons/caret-down.svg");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center right;
  mask-position: center right;
}
/* 質問開いた状態 */
.ot-faq__question.is-faq-open::after {
  -webkit-mask-image: url("../common/img/svg-icons/caret-up.svg");
  mask-image: url("../common/img/svg-icons/caret-up.svg");
}
.ot-faq__answer {
  display: flex;
  overflow: hidden;
  padding-top: 0;
  padding-bottom: 0;
  transition-duration: 0.2s;
  transition-property: max-height, padding-top, padding-bottom;
  max-height: 0;
}
.ot-faq__question.is-faq-open+.ot-faq__answer {
  display: flex;
  padding-top: 10px;
  padding-bottom: 10px;
}
.ot-faq-content__text {
  word-break: break-all;
}
.ot-faq-content__text p + p {
  margin-top: 1.75em;
}
.ot-faq-content__q,
.ot-faq-content__a {
  font-size: 1.25rem;
}
.ot-faq-content__text a {
  color: var(--color-primary);
}

@media (min-width: 480px) {
  /* よくある質問
  --------------------------------------------------------------- */
  .ot-faq-category {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px 6px;
  }
  .ot-faq-category__item {
    aspect-ratio: 1.6;
  }
  .ot-faq-category__anchor--smartphone{
    font-size: 0.75rem;
  }
}

@media (min-width: 768px) {
  /* トップ
  --------------------------------------------------------------- */
  /* メインビジュアル */
  .ot-main-visual {
    padding: 30px 0 54px;
  }
  .ot-main-visual::before {
    clip-path: polygon(0% 3%, 68% 50%, 0% 84%);
  }
  .ot-main-visual__slider {
    aspect-ratio: 2880/1289;
  }
  .ot-main-visual__control {
    bottom: 20% !important;
  }
  .ot-main-visual__text {
    aspect-ratio: 1388/655;
    padding: 0;
  }
  .ot-main-visual__text .ot-image-change {
    width: 60.5%;
    margin-top: 8.5%;
  }
  .ot-main-visual__slider {
    padding: 0 40px;
  }
  .ot-main-visual__slider {
    margin: 0;
    overflow: hidden;
  }
  .ot-main-visual__slider__inner {
    width: auto;
    transform: none;
    position: static;
    left: auto;
  }
  .ot-main-visual__slider__inner .n2-ss-slider-controls {
    transform: none;
  }
  .ot-main-visual__slider img {
    clip-path: polygon(28% 0, 100% 0, 100% 100%, 0 100%);
  }
  /* お知らせ */
  .ot-section-layout--news{
    padding-bottom: 120px;
  }
  .ot-news__heading {
    margin-block: 86px 40px;
  }
  .ot-news-heading__icon {
    width: auto;
  }
  .ot-news__list {
    margin-bottom: 36px;
  }
  .ot-news-list__item {
    flex-direction: row;
    gap: 70px;
    margin-bottom: 30px;
    font-size: 1.25rem;
  }
  .ot-news-item__date {
    width: auto;
  }
  .ot-news-item__text {
    margin: 0;
    line-clamp: 2;
    -webkit-line-clamp: 2;
  }
  /* はねぴょんギフトとは */
  .ot-section-layout--about {
    padding-bottom: 240px;
  }
  .ot-about__heading {
    margin-block: 50px 0;
    font-size: 2.375rem;
  }
  .ot-about-heading__text::before {
    left: -138px;
    top: -2px;
  }
  .ot-about-heading__text::after {
    right: -148px;
    top: -2px;
  }
  .ot-about__details {
    margin-top: 64px;
  }
  .ot-about-details {
    padding-block: 36px 80px;
  }
  .ot-about-details__summary {
    font-size: 1.5rem;
  }
  .ot-about-details__description {
    margin-block: 32px 0;
    font-size: 1rem;
    text-align: center;
  }
  .ot-about-feature {
    margin-top: 52px;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 30px;
  }
  .ot-about-feature__item {
    padding: 58px 10px 22px;
    row-gap: 20px;
  }
  .ot-about-feature__item+.ot-about-feature__item {
    margin-top: 0;
  }
  .ot-about-feature__label {
    top: -16px;
    padding-block: 0;
    font-size: 1.25rem;
  }
  .ot-about-feature__text {
  font-size: 1.125rem;
  }
  /* 選べる寄付額 */
  .ot-section-layout--donation {
    padding-bottom: 120px;
  }
  .ot-select-donation__heading {
    margin-top: 115px;
  }
  .ot-select-donation__donation-list {
    margin-block: 40px 0;
  }
  .ot-donation__icon {
    position: relative;
    width: 128px;
    margin-top: -68px;
    margin-right: 0;
  }
  .ot-donation-list {
    column-gap: 30px;
  }
  .ot-donation-list::before {
    top: -12vw;
    right: 0;
    width: 11.1111111111vw;
    max-width: 183px;
    aspect-ratio: 183 / 183;
    background-image: url("../img/top/guide-balloon.svg")
  }
  .ot-donation-list__item {
    row-gap: 5px;
  }
  .ot-donation-list__heading {
    padding: 8px;
    font-size: 1.125rem;
  }
  .ot-price-list {
    margin-top: 14px;
    row-gap: 6px;
  }
  .ot-price-list__item {
    font-size: 1.125rem;
    padding-block: 12px;
  }
  .ot-price-list--donation>.ot-price-list__item::before {
    width: 60px;
  }
  .ot-price-list--donation>.ot-price-list__item::before,
  .ot-price-list--donation>.ot-price-list__item::after {
    right: -46px;
  }
  .ot-price-list--donation>.ot-price-list__item::after {
    width: 14px;
    transform: rotate(50deg) translate(-1px, calc(-50% - 6px));
  }
  /* ご利用方法 */
  .ot-section-layout--steps {
    padding-block: 66px 150px;
  }
  .ot-steps-heading--accent {
    font-size: 1.5rem;
  }
  .ot-guide__process--wrap {
    border-radius: 10px;
    border: 1px solid var(--color-primary);
    background-color: var(--color-white);
  }
  .ot-guide__process {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    max-width: 980px;
    margin: auto;
    padding: 100px 30px 40px;
  }
  .ot-process__item {
    padding: 24px 20px;
    row-gap: 20px;
  }
  .ot-process-item__number {
    margin-top: -5.4rem;
    text-align: center;
  }
  .ot-process-number__image {
    max-width: 97px;
  }
  .ot-process-item__text {
    margin: 0;
    width: auto;
  }
  .ot-guide__button {
    max-width: 300px;
    margin-inline: auto;
    margin-top: 40px;
  }
  /* 使える加盟店 */
  .ot-section-layout--shops {
    padding-block: 80px 120px;
  }
  .ot-shops__heading {
    flex-direction: row;
    gap: 20px;
  }
  .ot-shops__button {
    margin-top: 70px;
  }
  /* 加盟店募集 */
  .ot-section-layout--recruit {
    padding: 80px 0 60px;
  }

  /* ご利用方法
  --------------------------------------------------------------- */
  .ot-section-layout--howto {
    padding-bottom: 80px;
  }
  .ot-howto__process {
    grid-template-columns: repeat(1, 1fr);
    gap: 120px;
    max-width: 100%;
    padding-top: 0px;
  }
  .ot-howto__item {
    position: relative;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 38px 10px;
  }
  .ot-howto__item::after {
    content: "";
    position: absolute;
    bottom: -90px;
    left: 50%;
    transform: translateX(-50%);
    --r:8px; /* border radius */
    height: 60px;
    aspect-ratio: 2;
    --_g:calc(var(--r)/tan(22.5deg)) top var(--r),#000 98%,#0000 101%;
    -webkit-mask:
      conic-gradient(from 157.5deg at 50% calc(var(--r)/(3*sqrt(2) - 4) - 100%/tan(22.5deg)),#000 45deg,#0000 0)
      0 0/100% calc(100% - var(--r)/sqrt(2)) no-repeat,
      radial-gradient(var(--r) at 50% calc(100% - var(--r)*sqrt(2)),#000 98%,#0000 101%),
      radial-gradient(var(--r) at left  var(--_g)),
      radial-gradient(var(--r) at right var(--_g));
    mask:
      conic-gradient(from 157.5deg at 50% calc(var(--r)/(3*sqrt(2) - 4) - 100%/tan(22.5deg)),#000 45deg,#0000 0)
      0 0/100% calc(100% - var(--r)/sqrt(2)) no-repeat,
      radial-gradient(var(--r) at 50% calc(100% - var(--r)*sqrt(2)),#000 98%,#0000 101%),
      radial-gradient(var(--r) at left  var(--_g)),
      radial-gradient(var(--r) at right var(--_g));
    clip-path: polygon(50% 100%,100% 0,0 0);
    background: var(--color-yellow-02);
  }
  .ot-howto__item:last-child:after {
    display: none;
  }
  .ot-howto-item__number {
    margin: 0;
  }
  .ot-howto__number-item {
    flex-direction: row;
    justify-content: space-around;
    width: 40%;
    min-width: 300px;
  }
  .ot-howto-item__image {
    margin-inline: 0;
  }
  .ot-howto-item__text {
    font-weight: bold;
    width: 55%;
    display: flex;
    flex-direction: column;
  }
  .ot-howto__button {
    margin-top: 36px;
    margin-inline: 0px;
    max-width: 260px;
  }

  /* 加盟店一覧
  --------------------------------------------------------------- */
  .ot-section-layout--shoplist {
    padding-bottom: 80px;
  }
  .ot-search-tabs__switcher {
    border-width: 2px;
    padding-inline: 16px;
  }
  .ot-search-tabs__button {
    flex-direction: row;
    gap: 16px;
    margin-left: -2px;
    padding-block: 10px;
    font-size: 1.125rem;
    border-width: 2px;
    cursor: pointer;
  }
  .ot-search-tabs__button--eat::before,
  .ot-search-tabs__button--stay::before,
  .ot-search-tabs__button--shopping::before,
  .ot-search-tabs__button--other::before {
    display: block;
    height: 50px;
  }
  .ot-search-tabs__button--eat::before {
    width: 36%;
  }
  .ot-search-tabs__button--stay::before {
    width: 22%;
  }
  .ot-search-tabs__button--shopping::before {
    width: 22%;
  }
  .ot-search-tabs__button--other::before {
    width: 16%;
  }
  .ot-search-tabs__content {
    margin-top: 70px;
  }
  .ot-shop-cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 30px 30px;
    margin: 0;
    margin-bottom: 16px;
  }
  .ot-shop-cards__items {
    display: grid;
    grid-template-rows: auto 1fr 5.25em 36.5px;
    gap: 10px 0;
  }
  .ot-shop-details {
    display: contents;
  }
  .ot-shop-detail-card__head {
    grid-row-start: 1;
    display: grid;
    margin-bottom: 6px;
  }
  .ot-shop-details__heading,
  .ot-shop-details__summary {
    margin: 0;
  }
  .ot-shop-details__heading {
    font-size: 1.5rem;
    line-height: 1.4;
    max-height: 2.8em;
  }
  .ot-shop-details__summary {
    max-height: 5.25em; /* line-height x 3 */
  }
  .ot-shop-details{
    padding: 0;
  }
  .ot-shop-details__label {
    margin-top: 8px;
    width: fit-content;
  }
  .ot-shop-cards__button{
    margin-top: 70px;
  }

  /* よくある質問
  --------------------------------------------------------------- */
  .ot-faq__inner {
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .ot-faq-category {
    flex-wrap: nowrap;
    gap: 14px;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    width: 100%;
  }
  .ot-faq-category__item {
    width: 100%;
    aspect-ratio: 1.8;
    cursor: pointer;
  }
  .ot-faq-category__anchor {
    font-size: 0.875rem;
  }
  .ot-faq-category__anchor::after {
    bottom: -4px;
  }
  .ot-faq__group {
    padding-top: 50px;
  }
  .ot-faq__title {
    font-size: 1.5rem;
  }
  .ot-faq__content {
    gap: 20px;
  }
  .ot-faq__content {
    padding: 20px 30px;
    font-size: 1rem;
  }
  .ot-faq__answer {
    padding-top: 0;
    padding-bottom: 0;
  }
  .ot-faq__question.is-faq-open+.ot-faq__answer {
    padding-top: 20px;
    padding-bottom: 20px;
  }
  .ot-faq__question {
    padding-right: 50px;
    font-size: 1.125rem;
  }
  .ot-faq__question::after {
    right: 16px;
  }
  .ot-faq-content__q,
  .ot-faq-content__a {
    font-size: 1.5rem;
  }
}

@media (min-width: 1024px) {
  /* よくある質問
  --------------------------------------------------------------- */
  .ot-faq-category {
    display: flex;
    flex-wrap: nowrap;
    gap: 14px;
    justify-content: space-between;
    width: 100%;
  }
  .ot-faq-category__item {
    aspect-ratio: 1.6;
  }
}

@media (min-width: 1280px) {
  /* よくある質問
  --------------------------------------------------------------- */
  .ot-faq-category__anchor {
    font-size: 1rem;
  }
}
@media (min-width: 1600px) {
  /* トップ
  --------------------------------------------------------------- */
  /* 選べる寄付額 */
  .ot-donation-list::before {
    top: -194px;
  }
}

@media (min-width: 1280px) and (max-width: 1600px) {
  /* トップ
  --------------------------------------------------------------- */
  /* メインビジュアル */
  .ot-main-visual__slider__inner {
    margin-top: -30px;
  }
}