@charset "UTF-8";
.senryu {
  font-family: Hiragino Kaku Gothic Pro, "ヒラギノ角ゴ Pro W3", HiraKakuPro-W3, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, Arial, Helvetica, sans-serif;
  line-height: 1.75;
}

@media screen and (max-width: 767px) {
  .senryu-inner {
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}

.senryu-button-area, .senryu-button-area--direction-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-button-area, .senryu-button-area--direction-row {
    gap: 3.2vw;
  }
}

.senryu-button-area--direction-row {
  align-items: center;
  flex-direction: column;
}

.senryu-button-type01, .senryu-button-type01--color-type03, .senryu-button-type01--color-type02, .senryu-button-type01--color-type02-shadow, .senryu-button-type01--color-type01 {
  align-items: center;
  border-radius: 200px;
  border-style: solid;
  border-width: 2px;
  display: flex;
  font-size: 18px;
  font-weight: bold;
  justify-content: center;
  min-height: 70px;
  position: relative;
  width: 360px;
}
@media screen and (max-width: 767px) {
  .senryu-button-type01, .senryu-button-type01--color-type03, .senryu-button-type01--color-type02, .senryu-button-type01--color-type02-shadow, .senryu-button-type01--color-type01 {
    font-size: 4.8vw;
    max-width: 89.3333333333vw;
    min-height: 16vw;
    width: 100%;
  }
}
.senryu-button-type01::after, .senryu-button-type01--color-type03::after, .senryu-button-type01--color-type02::after, .senryu-button-type01--color-type02-shadow::after, .senryu-button-type01--color-type01::after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  background-image: url(../img/icon_arrow_02.svg);
  height: 14px;
  position: absolute;
  right: 20px;
  width: 9px;
}

.senryu-button-type01--color-type01 {
  border-color: #fff;
  color: #fff;
}
@media (hover: hover) {
  .senryu-button-type01--color-type01:hover {
    background-color: #fff;
    color: var(--primary-color);
  }
  .senryu-button-type01--color-type01:hover::after {
    background-image: url(../img/icon_arrow_01.svg);
  }
}

.senryu-button-type01--color-type02, .senryu-button-type01--color-type02-shadow {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}
@media (hover: hover) {
  .senryu-button-type01--color-type02:hover, .senryu-button-type01--color-type02-shadow:hover {
    background-color: #fff;
    color: var(--primary-color);
  }
  .senryu-button-type01--color-type02:hover::after, .senryu-button-type01--color-type02-shadow:hover::after {
    background-image: url(../img/icon_arrow_01.svg);
  }
}

.senryu-button-type01--color-type02-shadow {
  box-shadow: 0 4px 0 var(--primary-color-dark);
}
@media screen and (max-width: 767px) {
  .senryu-button-type01--color-type02-shadow {
    box-shadow: 0 1.0666666667vw 0 var(--primary-color-dark);
  }
}

.senryu-button-type01--color-type03 {
  border-color: var(--primary-color);
  color: var(--primary-color);
}
.senryu-button-type01--color-type03::after {
  background-image: url(../img/icon_arrow_01.svg);
}
@media (hover: hover) {
  .senryu-button-type01--color-type03:hover {
    background-color: var(--primary-color);
    color: #fff;
  }
  .senryu-button-type01--color-type03:hover::after {
    background-image: url(../img/icon_arrow_02.svg);
  }
}

.senryu-section, .senryu-section--gold {
  display: grid;
  gap: 40px;
  padding-bottom: 80px;
  padding-top: 60px;
}
@media screen and (max-width: 767px) {
  .senryu-section, .senryu-section--gold {
    gap: 7.4666666667vw;
    padding-bottom: 10.6666666667vw;
    padding-top: 10.6666666667vw;
  }
}

.senryu-section--gold {
  background-color: #faf2cd;
}

.senryu-section__title {
  font-family: Hiragino Kaku Gothic Pro, "ヒラギノ角ゴ Pro W3", HiraKakuPro-W3, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, Arial, Helvetica, sans-serif;
}

.senryu-text-wrapper {
  display: grid;
  gap: 2em;
}

.senryu-text, .senryu-text--center {
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-text, .senryu-text--center {
    font-size: 4.2666666667vw;
  }
}

.senryu-text--center {
  text-align: center;
}

.senryu-text-small {
  font-size: 13px;
}
@media screen and (max-width: 767px) {
  .senryu-text-small {
    font-size: 3.4666666667vw;
  }
}

.senryu-text-bold {
  font-weight: bold;
}

.senryu-link-text {
  color: #00e;
}
@media (hover: hover) {
  .senryu-link-text:hover {
    text-decoration: underline;
  }
}

.senryu-title, .senryu-title--type04, .senryu-title--type04-center, .senryu-title--type03, .senryu-title--type03-center, .senryu-title--type02, .senryu-title--type02-center, .senryu-title--type01, .senryu-title--type01-center {
  line-height: 1.5;
}

.senryu-title--type01, .senryu-title--type01-center {
  font-size: 28px;
}
@media screen and (max-width: 767px) {
  .senryu-title--type01, .senryu-title--type01-center {
    font-size: 6.4vw;
  }
}

.senryu-title--type01-center {
  text-align: center;
}

.senryu-title--type02, .senryu-title--type02-center {
  font-size: 28px;
}
@media screen and (max-width: 767px) {
  .senryu-title--type02, .senryu-title--type02-center {
    font-size: 5.8666666667vw;
  }
}

.senryu-title--type02-center {
  text-align: center;
}

.senryu-title--type03, .senryu-title--type03-center {
  font-size: 32px;
}
@media screen and (max-width: 767px) {
  .senryu-title--type03, .senryu-title--type03-center {
    font-size: 6.4vw;
  }
}

.senryu-title--type03-center {
  text-align: center;
}

.senryu-title--type04, .senryu-title--type04-center {
  display: flex;
  font-size: 28px;
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .senryu-title--type04, .senryu-title--type04-center {
    font-size: 5.8666666667vw;
    gap: 1.8666666667vw;
  }
}
.senryu-title--type04::before, .senryu-title--type04-center::before, .senryu-title--type04::after, .senryu-title--type04-center::after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  background-image: url(../img/s-senryu/icon_nami.svg);
  height: 49px;
  width: 159px;
}
@media screen and (max-width: 767px) {
  .senryu-title--type04::before, .senryu-title--type04-center::before, .senryu-title--type04::after, .senryu-title--type04-center::after {
    height: 8.2666666667vw;
    width: 27.4666666667vw;
  }
}
.senryu-title--type04::after, .senryu-title--type04-center::after {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.senryu-title--type04-center {
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-title--type04-center {
    margin-left: -5.3333333333vw;
    margin-right: -5.3333333333vw;
  }
}

.senryu-list-type01 {
  display: grid;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-list-type01 {
    gap: 4.2666666667vw;
  }
}
.senryu-list-type01 > li {
  display: flex;
}
.senryu-list-type01 > li::before {
  content: "";
  display: block;
  background-color: #ffb66e;
  border-radius: 50%;
  flex-shrink: 0;
  gap: 4px;
  height: 20px;
  margin-top: 4px;
  width: 20px;
}

.senryu-list-note > li {
  font-size: 13px;
  margin-left: 1em;
  text-indent: -1em;
}

.senryu-list-description-type01 {
  display: grid;
  font-size: 14px;
  gap: 2em;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type01 {
    font-size: 3.2vw;
    gap: 0;
    grid-template-columns: repeat(2, 1fr);
    text-align: center;
  }
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type01 .senryu-list-description__inner:not(:first-child) {
    position: relative;
  }
  .senryu-list-description-type01 .senryu-list-description__inner:not(:first-child)::before {
    background-color: #ccc;
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 1px;
  }
}
.senryu-list-description-type01 .senryu-list-description__term {
  font-weight: bold;
}

.senryu-list-description-type02 {
  display: grid;
  font-size: 16px;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type02 {
    font-size: 4.2666666667vw;
    justify-content: inherit;
  }
}
.senryu-list-description-type02 > .senryu-list-description__inner {
  border-bottom: 1px solid #ccc;
  display: grid;
  grid-template-columns: 160px 1fr;
  padding-bottom: 20px;
  padding-top: 20px;
  width: 700px;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type02 > .senryu-list-description__inner {
    grid-auto-flow: row;
    grid-template-columns: 1fr;
    padding-bottom: 4.2666666667vw;
    padding-top: 4.2666666667vw;
    width: 100%;
  }
}
.senryu-list-description-type02 .senryu-list-description__term {
  font-weight: bold;
}

.senryu-list-description-type03, .senryu-list-description-type03--center {
  border-bottom: 1px solid #bfb78f;
  border-top: 1px solid #bfb78f;
  display: grid;
  font-size: 16px;
  justify-content: center;
  text-align: center;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type03, .senryu-list-description-type03--center {
    font-size: 4.2666666667vw;
    justify-content: inherit;
  }
}
.senryu-list-description-type03 > .senryu-list-description__inner, .senryu-list-description-type03--center > .senryu-list-description__inner {
  display: grid;
  gap: 8px;
  justify-content: center;
  padding-bottom: 20px;
  padding-top: 20px;
  width: 700px;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type03 > .senryu-list-description__inner, .senryu-list-description-type03--center > .senryu-list-description__inner {
    gap: 1.0666666667vw;
    padding-bottom: 5.3333333333vw;
    padding-top: 5.3333333333vw;
    width: 100%;
  }
}
.senryu-list-description-type03 .senryu-list-description__term, .senryu-list-description-type03--center .senryu-list-description__term {
  font-size: 20px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .senryu-list-description-type03 .senryu-list-description__term, .senryu-list-description-type03--center .senryu-list-description__term {
    font-size: 5.3333333333vw;
  }
}

.senryu-list-description-type03--center {
  margin-left: auto;
  margin-right: auto;
}

.senryu-prize-list {
  display: grid;
}
.senryu-prize-list .senryu-amazon-logo {
  margin-bottom: -6px;
  width: 72px;
}

.senryu-prize-list__inner {
  align-items: center;
  display: grid;
  gap: 20px;
  grid-template-columns: 100px auto;
  padding-bottom: 12px;
  padding-top: 12px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .senryu-prize-list__inner {
    gap: 2.1333333333vw;
    grid-template-columns: 26.6666666667vw auto;
    padding-bottom: 3.2vw;
    padding-left: 3.2vw;
    padding-right: 3.2vw;
    padding-top: 3.2vw;
  }
}
.senryu-prize-list__inner:not(:first-child)::before {
  content: "";
  display: block;
  background-color: #e1d8b6;
  height: 2px;
  left: 0;
  margin-left: auto;
  margin-right: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 320px;
}
@media screen and (max-width: 767px) {
  .senryu-prize-list__inner:not(:first-child)::before {
    width: 72vw;
  }
}

.senryu-prize-list__term {
  color: #c1153a;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.35;
  text-align: right;
}

.senryu-prize-list__description {
  align-items: center;
  display: flex;
  font-weight: bold;
  gap: 12px;
  line-height: 1.5;
}

.senryu-prize-list__text {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .senryu-prize-list__text {
    font-size: 3.7333333333vw;
  }
}

.senryu-prize-list__text-small {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .senryu-prize-list__text-small {
    font-size: 3.7333333333vw;
  }
}

.senryu-card-list {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-card-list {
    gap: 8.5333333333vw;
  }
}

.senryu-card-type01 {
  background-color: #fff;
  border-radius: 5px;
  padding: 24px 30px 30px;
  width: 360px;
}
@media screen and (max-width: 767px) {
  .senryu-card-type01 {
    border-radius: 1.3333333333vw;
    padding: 5.3333333333vw 3.2vw;
    width: 100%;
  }
}
.senryu-card-type01 .senryu-card__title {
  font-size: 20px;
  line-height: 1.5;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .senryu-card-type01 .senryu-card__title {
    font-size: 4.5333333333vw;
  }
}
.senryu-card-type01 .senryu-card__title-small {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .senryu-card-type01 .senryu-card__title-small {
    font-size: 4vw;
  }
}
.senryu-card-type01 .senryu-card__list {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-card-type01 .senryu-card__list {
    margin-top: 3.2vw;
  }
}
.senryu-card-type01 .senryu-card__button {
  font-size: 16px;
  min-height: 60px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .senryu-card-type01 .senryu-card__button {
    font-size: 4.2666666667vw;
    min-height: 12.8vw;
    width: 64vw;
  }
}

.senryu-block, .senryu-block--gap-medium {
  display: grid;
}

.senryu-block--gap-medium {
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-block--gap-medium {
    gap: 5.3333333333vw;
  }
}

.senryu-block-type01, .senryu-block-type01--small, .senryu-block-type01--small-align-center {
  background: url(../img/s-senryu/img_checkered-pattern_02.png) repeat top center/8px;
  padding: 48px 52px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .senryu-block-type01, .senryu-block-type01--small, .senryu-block-type01--small-align-center {
    padding: 40px 32px;
  }
}
.senryu-block-type01::before, .senryu-block-type01--small::before, .senryu-block-type01--small-align-center::before {
  content: "";
  display: block;
  background-color: #fff;
  bottom: 0;
  height: calc(100% - 60px);
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: calc(100% - 60px);
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .senryu-block-type01::before, .senryu-block-type01--small::before, .senryu-block-type01--small-align-center::before {
    height: calc(100% - 40px);
    width: calc(100% - 40px);
  }
}

.senryu-block-type01--small, .senryu-block-type01--small-align-center {
  width: 660px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type01--small, .senryu-block-type01--small-align-center {
    width: 100vw;
  }
}

.senryu-block-type01--small-align-center {
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 767px) {
  .senryu-block-type01--small-align-center {
    margin-left: -5.3333333333vw;
    margin-right: -5.3333333333vw;
  }
}

.senryu-block-type02, .senryu-block-type02--center {
  border: 2px solid var(--primary-color);
  border-radius: 5px;
  height: 280px;
  overflow-y: scroll;
  padding: 16px 20px;
  width: 660px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type02, .senryu-block-type02--center {
    height: 74.6666666667vw;
    max-height: 100vh;
    padding: 3.2vw 4.2666666667vw;
    width: 100%;
  }
}

.senryu-block-type02--center {
  margin-left: auto;
  margin-right: auto;
}

.senryu-block-type03, .senryu-block-type03--center {
  background-color: #f6f0d4;
  background-image: url(../img/s-senryu/icon_wagara_01.png), url(../img/s-senryu/icon_wagara_02.png), url(../img/s-senryu/icon_wagara_03.png), url(../img/s-senryu/icon_wagara_04.png), url(../img/s-senryu/icon_wagara_05.png), url(../img/s-senryu/icon_wagara_06.png);
  background-position: top 10px left 10px, top 68px left 2px, top 30px right 26px, bottom 84px right 10px, bottom 14px right 10px, bottom 16px left 17px;
  background-repeat: no-repeat;
  background-size: 168px, 55px, 26px, 64px, 168px, 65px;
  border: 3px solid #bfb78f;
  padding: 32px 35px 20px;
  width: 700px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type03, .senryu-block-type03--center {
    padding: 8.5333333333vw 4.2666666667vw 4.2666666667vw;
    width: 100%;
  }
}
.senryu-block-type03 .senryu-block-type03__text-large, .senryu-block-type03--center .senryu-block-type03__text-large {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .senryu-block-type03 .senryu-block-type03__text-large, .senryu-block-type03--center .senryu-block-type03__text-large {
    font-size: 5.8666666667vw;
  }
}
.senryu-block-type03 .senryu-block-type03__text-medium, .senryu-block-type03--center .senryu-block-type03__text-medium {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 4px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .senryu-block-type03 .senryu-block-type03__text-medium, .senryu-block-type03--center .senryu-block-type03__text-medium {
    font-size: 4.2666666667vw;
    margin-top: 1.0666666667vw;
  }
}
.senryu-block-type03 .senryu-block-type03__comment, .senryu-block-type03--center .senryu-block-type03__comment {
  font-size: 14px;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type03 .senryu-block-type03__comment, .senryu-block-type03--center .senryu-block-type03__comment {
    font-size: 3.7333333333vw;
    margin-top: 5.3333333333vw;
  }
}

.senryu-block-type03--center {
  margin-left: auto;
  margin-right: auto;
}

.senryu-block-type04, .senryu-block-type04--small {
  background-color: #f6f0d4;
  border: 3px solid #bfb78f;
  line-height: 1.5;
  padding: 20px 16px 16px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04, .senryu-block-type04--small {
    padding: 4.2666666667vw 4.2666666667vw 4.2666666667vw;
  }
}
.senryu-block-type04 .senryu-block-type04__text-large, .senryu-block-type04--small .senryu-block-type04__text-large {
  font-size: 20px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04 .senryu-block-type04__text-large, .senryu-block-type04--small .senryu-block-type04__text-large {
    font-size: 5.3333333333vw;
  }
}
.senryu-block-type04 .senryu-block-type04__text-medium, .senryu-block-type04--small .senryu-block-type04__text-medium {
  font-size: 16px;
  font-weight: bold;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04 .senryu-block-type04__text-medium, .senryu-block-type04--small .senryu-block-type04__text-medium {
    font-size: 4.2666666667vw;
    margin-top: 1.0666666667vw;
  }
}

.senryu-block-type04--small {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  padding: 16px 16px 12px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04--small {
    padding: 2.1333333333vw 2.1333333333vw 2.1333333333vw;
  }
}
.senryu-block-type04--small .senryu-block-type04__text-large {
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04--small .senryu-block-type04__text-large {
    font-size: 3.7333333333vw;
  }
}
.senryu-block-type04--small .senryu-block-type04__text-medium {
  font-size: 14px;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .senryu-block-type04--small .senryu-block-type04__text-medium {
    font-size: 3.2vw;
    margin-top: 1.0666666667vw;
  }
}

.senryu-block-full, .senryu-block-full--gray, .senryu-block-full--gray--wrap, .senryu-block-full--skyblue {
  margin: 0 calc(50% - 50vw);
  padding: 48px calc(50vw - 50%);
  width: 100vw;
}
@media screen and (max-width: 767px) {
  .senryu-block-full, .senryu-block-full--gray, .senryu-block-full--gray--wrap, .senryu-block-full--skyblue {
    margin-left: -5.3333333333vw;
    margin-right: -5.3333333333vw;
    padding: 10.6666666667vw 5.3333333333vw;
  }
}

.senryu-block-full--skyblue {
  background-color: var(--secondary-color);
}

.senryu-block-full--gray, .senryu-block-full--gray--wrap {
  background-color: #f5f5f5;
}

@media screen and (max-width: 767px) {
  .senryu-block-full--gray--wrap {
    margin-left: 0;
    margin-right: 0;
  }
}

.senryu-iframe-wrapper {
  height: auto;
  width: 100%;
}
.senryu-iframe-wrapper > iframe {
  max-height: inherit !important;
  overflow-y: auto;
  width: 100%;
}

.senryu-grid, .senryu-grid--type02, .senryu-grid--type01 {
  display: grid;
}

.senryu-grid--type01 {
  gap: 32px;
  grid-auto-flow: column;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-grid--type01 {
    gap: 6.4vw;
    grid-auto-flow: row;
  }
}
.senryu-grid--type01 > li {
  width: 280px;
}
@media screen and (max-width: 767px) {
  .senryu-grid--type01 > li {
    width: 74.6666666667vw;
  }
}

.senryu-grid--type02 {
  gap: 32px;
  grid-template-columns: repeat(2, 360px);
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .senryu-grid--type02 {
    gap: 3.2vw;
    grid-template-columns: repeat(2, 1fr);
  }
}

.senryu-margin-top-small {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-small {
    margin-top: 4.2666666667vw;
  }
}

.senryu-margin-top-medium {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-medium {
    margin-top: 4.8vw;
  }
}

.senryu-margin-top-medium-with-text {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-medium-with-text {
    margin-top: 4.2666666667vw;
  }
}

.senryu-margin-top-large {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-large {
    margin-top: 12.8vw;
  }
}

.senryu-margin-top-large-with-text {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-large-with-text {
    margin-top: 6.4vw;
  }
}

.senryu-margin-top-xlarge {
  margin-top: 80px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-xlarge {
    margin-top: 21.3333333333vw;
  }
}

.senryu-margin-top-xlarge-with-text {
  margin-top: 72px;
}
@media screen and (max-width: 767px) {
  .senryu-margin-top-xlarge-with-text {
    margin-top: 19.2vw;
  }
}

.senryu-mainvisual, .senryu-mainvisual--result, .senryu-mainvisual--application, .senryu-mainvisual--top {
  align-items: center;
  background: url(../img/s-senryu/img_checkered-pattern_01.png) repeat top center/50px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  position: relative;
}
.senryu-mainvisual::before, .senryu-mainvisual--result::before, .senryu-mainvisual--application::before, .senryu-mainvisual--top::before {
  background-color: #fff;
  border-radius: 50%;
  content: "";
  height: 570px;
  position: absolute;
  top: 37px;
  width: 570px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual::before, .senryu-mainvisual--result::before, .senryu-mainvisual--application::before, .senryu-mainvisual--top::before {
    height: 74.6666666667vw;
    top: 5.3333333333vw;
    width: 74.6666666667vw;
  }
}

.senryu-mainvisual--top .senryu-mainvisual__inner {
  height: 355px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--top .senryu-mainvisual__inner {
    height: 85.3333333333vw;
  }
}
.senryu-mainvisual--top .senryu-mainvisual__button-area {
  background-color: var(--primary-color);
  margin-top: auto;
  padding-bottom: 60px;
  padding-top: 40px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--top .senryu-mainvisual__button-area {
    padding-bottom: 4.2666666667vw;
    padding-top: 4.2666666667vw;
  }
}
.senryu-mainvisual--top .senryu-mainvisual__decoration-02,
.senryu-mainvisual--top .senryu-mainvisual__inner::after {
  display: none;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--top .senryu-mainvisual__decoration-02,
.senryu-mainvisual--top .senryu-mainvisual__inner::after {
    display: block;
  }
}

.senryu-mainvisual--application {
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application {
    overflow: inherit;
    width: 100vw;
  }
}
.senryu-mainvisual--application::after {
  content: "";
  display: block;
  background-color: var(--primary-color);
  bottom: 0;
  height: 60px;
  position: absolute;
  width: 100%;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application::after {
    height: 16vw;
  }
}
.senryu-mainvisual--application .senryu-mainvisual__inner {
  height: 525px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application .senryu-mainvisual__inner {
    height: 129.3333333333vw;
  }
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application .senryu-mainvisual__title {
    top: 33.0666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application .senryu-mainvisual__title-03 {
    margin-top: 1.6vw;
    width: 25.0666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--application .senryu-mainvisual__decoration-02 {
    z-index: 1;
  }
}

.senryu-mainvisual--result {
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result {
    overflow: inherit;
    width: 100vw;
  }
}
.senryu-mainvisual--result::after {
  content: "";
  display: block;
  background-color: var(--secondary-color);
  bottom: 0;
  height: 60px;
  position: absolute;
  width: 100%;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result::after {
    height: 5.3333333333vw;
  }
}
.senryu-mainvisual--result .senryu-mainvisual__inner {
  height: 425px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__inner {
    height: 90.6666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__title {
    top: 35.4666666667vw;
    width: 89.8666666667vw;
  }
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__title-03 {
    margin-top: 1.6vw;
    width: 25.0666666667vw;
  }
}
.senryu-mainvisual--result .senryu-mainvisual__decoration-02 {
  display: none;
}
.senryu-mainvisual--result .senryu-mainvisual__inner::after {
  display: none;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__inner::after {
    display: block;
    top: 69.3333333333vw;
  }
}
.senryu-mainvisual--result .senryu-mainvisual__result-text {
  align-items: center;
  display: flex;
  flex-direction: column;
  font-family: var(--serif-family);
  font-size: 46px;
  gap: 16px;
  line-height: 1;
  position: absolute;
  top: 328px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__result-text {
    font-size: 7.4666666667vw;
    gap: 3.2vw;
    top: 56vw;
  }
}
.senryu-mainvisual--result .senryu-mainvisual__result-text::before {
  content: "";
  display: block;
  background-color: #e1d8b6;
  height: 2px;
  width: 300px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual--result .senryu-mainvisual__result-text::before {
    width: 53.3333333333vw;
  }
}

.senryu-mainvisual__inner {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-left: auto;
  margin-right: auto;
  max-width: 980px;
  position: relative;
  width: 100%;
}
.senryu-mainvisual__inner::before, .senryu-mainvisual__inner::after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  background-image: url(../img/s-senryu/icon_main-visual_02.svg);
  height: 52px;
  position: absolute;
  width: 209px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__inner::before, .senryu-mainvisual__inner::after {
    height: 6.6666666667vw;
    width: 26.4vw;
  }
}
.senryu-mainvisual__inner::before {
  right: 46px;
  top: 86px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__inner::before {
    right: 2.9333333333vw;
    top: 13.6vw;
  }
}
.senryu-mainvisual__inner::after {
  left: 30px;
  top: 389px;
  -webkit-transform: scale(1, -1);
          transform: scale(1, -1);
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__inner::after {
    left: 4.8vw;
    top: 59.2vw;
  }
}

.senryu-mainvisual__kitayo,
.senryu-mainvisual__lead,
.senryu-mainvisual__title,
.senryu-mainvisual__decoration-01,
.senryu-mainvisual__decoration-02 {
  display: block;
  position: absolute;
}

.senryu-mainvisual__kitayo {
  top: 51px;
  width: 154px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__kitayo {
    top: 10.9333333333vw;
    width: 25.8666666667vw;
  }
}

.senryu-mainvisual__lead {
  top: 98px;
  width: 272px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__lead {
    top: 20.2666666667vw;
    width: 40.8vw;
  }
}

.senryu-mainvisual__title {
  top: 188px;
  width: 674px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__title {
    top: 34.6666666667vw;
    width: 61.3333333333vw;
  }
}

@media screen and (max-width: 767px) {
  .senryu-mainvisual__title-02 {
    display: block;
    width: 61.3333333333vw;
  }
}

@media screen and (max-width: 767px) {
  .senryu-mainvisual__title-03 {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: 3.4666666667vw;
    width: 28.8vw;
  }
}

.senryu-mainvisual__decoration-01 {
  left: 224px;
  top: 57px;
  width: 92px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__decoration-01 {
    left: 10.1333333333vw;
    top: 6.4vw;
    width: 16vw;
  }
}

.senryu-mainvisual__decoration-02 {
  right: 187px;
  top: 327px;
  width: 115px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__decoration-02 {
    right: 13.3333333333vw;
    top: 48vw;
    -webkit-transform: rotate(18deg);
            transform: rotate(18deg);
    width: 17.8666666667vw;
  }
}

.senryu-mainvisual__prize-list {
  position: relative;
  top: 320px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual__prize-list {
    background-color: #fff;
    border: 12px solid var(--primary-color);
    bottom: 3.2vw;
    margin-top: auto;
    top: inherit;
    width: 89.3333333333vw;
  }
}

.senryu-mainvisual__button-area {
  width: 100%;
}

.senryu-mainvisual-after-button-area {
  padding-top: 40px;
}
@media screen and (max-width: 767px) {
  .senryu-mainvisual-after-button-area {
    padding-top: 6.4vw;
  }
}

.senryu-image-wrapper-organizer {
  margin-left: auto;
  margin-right: auto;
  max-width: 600px;
}
@media screen and (max-width: 767px) {
  .senryu-image-wrapper-organizer {
    margin-left: -35.3333333333vw;
    margin-right: -35.3333333333vw;
    width: 160vw;
  }
}

/* ============================================================
   川柳 応募フォーム（サイト内）
============================================================ */
.senryu-form-wrap {
  margin-top: 2.4rem;
}
.senryu-form {
  max-width: 600px;
  margin: 0 auto;
  text-align: left;
}
.senryu-form__row {
  margin-bottom: 2rem;
}
.senryu-form__label {
  display: block;
  font-weight: 700;
  font-size: 1.6rem;
  margin-bottom: 0.8rem;
}
.senryu-form__input {
  width: 100%;
  padding: 1.2rem 1.4rem;
  font-size: 1.6rem;
  border: 1px solid #ccc;
  border-radius: 6px;
  background: #fff;
  box-sizing: border-box;
  line-height: 1.6;
}
.senryu-form__input:focus {
  outline: none;
  border-color: #f48414;
  box-shadow: 0 0 0 3px rgba(244, 132, 20, 0.15);
}
textarea.senryu-form__input {
  resize: vertical;
}
.senryu-form__req {
  display: inline-block;
  background: #e8462e;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.4rem 0.7rem;
  border-radius: 4px;
  margin-left: 0.8rem;
  vertical-align: middle;
}
.senryu-form__agree {
  text-align: center;
  margin: 2.4rem 0 0.8rem;
  font-size: 1.5rem;
}
.senryu-form__agree label {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
  justify-content: center;
}
.senryu-form__agree input[type="checkbox"] {
  width: 1.8rem;
  height: 1.8rem;
}
.senryu-form__agree a {
  color: #f48414;
  text-decoration: underline;
}
.senryu-form button[type="submit"] {
  font-family: inherit;
  cursor: pointer;
  border: none;
}
/* キャンペーン概要のリード文（強制改行をやめ、自然に折り返す） */
.senryu-lead {
  display: grid;
  gap: 1.8em;
  text-align: center;            /* PCは中央寄せ */
}
.senryu-lead p {
  font-size: 20px;               /* 文字サイズは従来どおり */
  line-height: 1.95;
  text-wrap: pretty;             /* 対応ブラウザでは折り返しを最適化 */
}
@media screen and (max-width: 767px) {
  .senryu-lead {
    gap: 1.5em;
    text-align: left;            /* スマホは左寄せで読みやすく */
  }
  .senryu-lead p {
    font-size: 4.2666666667vw;   /* 従来のSPサイズを維持（小さくしない） */
    line-height: 1.9;
  }
}

/* 日付など、途中で改行させたくない範囲（募集期間の各日付） */
.senryu-nowrap {
  display: inline-block;
  white-space: nowrap;
}

/* ラジオ・チェックボックスの選択肢 */
.senryu-form__choices {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem 2rem;
  padding-top: 0.4rem;
}
.senryu-form__choice {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.5rem;
}
.senryu-form__choice input {
  width: 1.7rem;
  height: 1.7rem;
}
/* ハニーポット（人間には非表示） */
.senryu-form__hp {
  position: absolute !important;
  left: -9999px !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
/* 送信結果・募集終了の通知 */
.senryu-form__notice {
  max-width: 600px;
  margin: 2.4rem auto 0;
  padding: 2rem;
  border-radius: 8px;
  text-align: center;
  font-size: 1.6rem;
  line-height: 1.8;
}
.senryu-form__notice--ok {
  background: #eef8f0;
  border: 1px solid #2e9e4f;
  color: #1f7a3c;
}
.senryu-form__notice--ng {
  background: #fdecea;
  border: 1px solid #e8462e;
  color: #b3301d;
}
.senryu-form__notice--closed {
  background: #f4f4f4;
  border: 1px solid #ccc;
  color: #555;
}
.senryu-form__notice--prep {
  background: #eef4fc;
  border: 1px solid #3a7bd5;
  color: #235aa6;
}
.senryu-form__notice--prep strong {
  color: #1c4e8f;
}
.senryu-form__notice a {
  color: #f48414;
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .senryu-form__label { font-size: 1.5rem; }
  .senryu-form__input { font-size: 1.6rem; }
}

/* ============================================================
   川柳 主催（きたよ。紹介）リデザイン
============================================================ */
.senryu-org {
  max-width: 760px;
  margin: 0 auto;
  background: #fff;
  border: 1px solid #f1e3d2;
  border-radius: 14px;
  padding: 4rem 4rem 3.6rem;
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.05);
  text-align: center;
}
.senryu-org__brand {
  font-size: 1.4rem;
  letter-spacing: 0.04em;
  color: #8a7a66;
  margin-bottom: 1.2rem;
}
.senryu-org__logo {
  margin-bottom: 2rem;
}
.senryu-org__logo img {
  width: 220px;
  max-width: 70%;
  height: auto;
}
.senryu-org__badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2.8rem;
}
.senryu-org__badges li {
  background: #fff7ef;
  border: 1px solid #f48414;
  color: #d96f0a;
  font-size: 1.3rem;
  font-weight: 700;
  padding: 0.6rem 1.4rem;
  border-radius: 999px;
}
.senryu-org__lead {
  text-align: left;
  font-size: 1.55rem;
  line-height: 2;
  color: #4a4035;
}
.senryu-org__lead p {
  margin-bottom: 1.6rem;
}
.senryu-org__lead p:last-child {
  margin-bottom: 0;
}
.senryu-org__lead strong {
  color: #d96f0a;
  font-weight: 700;
}
.senryu-org__features {
  display: flex;
  gap: 1.6rem;
  margin: 3.2rem 0 0;
}
.senryu-org__feature {
  flex: 1 1 0;
  background: #faf6f0;
  border-radius: 10px;
  padding: 1.4rem 1rem 1.6rem;
  text-align: center;
}
.senryu-org__feature-img img {
  width: 100%;
  height: auto;
  border-radius: 6px;
  display: block;
}
.senryu-org__feature-label {
  display: block;
  margin-top: 1rem;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.5;
  color: #4a4035;
}
@media screen and (max-width: 767px) {
  .senryu-org {
    padding: 3rem 1.8rem 2.8rem;
    border-radius: 10px;
  }
  .senryu-org__lead {
    font-size: 1.5rem;
    line-height: 1.9;
  }
  .senryu-org__features {
    flex-direction: column;
    gap: 1.2rem;
  }
  .senryu-org__feature {
    display: flex;
    align-items: center;
    gap: 1.4rem;
    text-align: left;
    padding: 1.2rem;
  }
  .senryu-org__feature-img {
    flex: 0 0 40%;
  }
  .senryu-org__feature-label {
    margin-top: 0;
    flex: 1;
  }
}
