@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Dela+Gothic+One&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap");
/****** Elad Shechter's RESET *******/
/*** box sizing border-box for all elements ***/
*,
*::before,
*::after {
  box-sizing: border-box;
}

a {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

button {
  background-color: transparent;
  color: inherit;
  border-width: 0;
  padding: 0;
  cursor: pointer;
}

figure {
  margin: 0;
}

input::-moz-focus-inner {
  border: 0;
  padding: 0;
  margin: 0;
}

ul, ol, dl, dd {
  margin: 0;
  padding: 0;
  list-style: none;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
}

p {
  margin: 0;
}

cite {
  font-style: normal;
}

fieldset {
  border-width: 0;
  padding: 0;
  margin: 0;
}

/* ------------------------------------
// base
------------------------------------ */
html {
  font-size: 62.5%;
}
@media screen and (max-width: 767px) {
  html {
    font-size: 2.6666666667vw;
  }
}

body {
  background: #fff;
  color: #252723;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
  overflow-wrap: anywhere;
}

@media (max-width: 767px) {
  body {
    font-size: 1.6rem;
    min-width: 0;
  }
}
a {
  color: #252723;
  text-decoration: none;
  transition: 0.3s;
}
a img {
  transition: 0.3s;
}
a:hover img {
  opacity: 0.8;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media (min-width: 1025px) {
  a[href^="tel:"] {
    cursor: default;
    pointer-events: none;
  }
}
/* // screen
----------------------------------- */
.sp {
  display: none;
}

.md {
  display: none;
}

.pc {
  display: block;
}

.pconly {
  display: block;
}

@media (max-width: 1024px) {
  .sp {
    display: none;
  }
  .md {
    display: block;
  }
  .pc {
    display: block;
  }
  .pconly {
    display: none;
  }
}
@media (max-width: 767px) {
  .sp {
    display: block;
  }
  .md {
    display: block;
  }
  .pc {
    display: none;
  }
  .pconly {
    display: none;
  }
}
.fadein {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.7s, transform 0.7s;
}

.fadein.visible {
  opacity: 1;
  transform: translateY(0);
}

/* header
----------------------------------- */
header {
  background: #ff323c;
  color: #fff;
  padding: 0 clamp(12px, 9vw, 120px) clamp(10px, 7.5vw, 100px);
  position: relative;
}
header .header {
  max-width: 1080px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 40.7407407407% 53.7037037037%;
  grid-template-rows: max-content max-content 1fr;
  gap: 0 7.4074074074%;
  position: relative;
}
header .header .title {
  grid-column: 1/2;
  grid-row: 1/span 3;
  width: clamp(44px, 32.8vw, 440px);
  padding: clamp(4px, 2.6vw, 35px) 0 0 clamp(4px, 3vw, 40px);
}
header .header .logo {
  grid-column: 2/3;
  grid-row: 1/2;
  padding: clamp(4px, 2.6vw, 35px) 0 clamp(8px, 6vw, 80px);
  width: clamp(22px, 16.4vw, 220px);
  justify-self: end;
  margin-right: clamp(2px, 1.5vw, 20px);
}
header .header .text {
  grid-column: 2/3;
  grid-row: 2/3;
}
header .header .text .lead {
  font-size: clamp(0rem, 1.5vw, 2rem);
  line-height: 1.7;
}
header .header .text .lead span.tight:first-child {
  margin-left: -0.5em;
}
header .header .text .lead span.tight _::-webkit-full-page-media,
header .header .text .lead span.tight _:future, :root header .header .text .lead span.tight {
  margin-left: -0.5em;
}
@-moz-document url-prefix() {
  header .header .text .lead span.tight {
    margin-left: -0.5em;
  }
}
header .header .text .str {
  margin-top: 0.5em;
  font-size: clamp(0rem, 2.1vw, 2.8rem);
  color: #252723;
  line-height: 1.7;
}
header .header .text .str span {
  background: #fff;
  padding: 0 0 0 0.3em;
}
header .header .senkyo {
  grid-column: 2/3;
  grid-row: 3/4;
  align-self: end;
  display: flex;
  align-items: center;
  gap: 20px;
  font-size: clamp(0rem, 1.8vw, 2.4rem);
  line-height: 1;
}
header .header .senkyo .date {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(0rem, 3.1vw, 4.2rem);
}
header > .util {
  position: fixed;
  right: 0;
  top: 0;
  width: clamp(11px, 8.2vw, 110px);
  display: grid;
  gap: 2px 0;
  z-index: 10;
}
header > .util > * a {
  position: relative;
  display: grid;
  place-content: center;
  min-height: clamp(18px, 13.1vw, 176px);
  color: #fff;
  transition: 0.3s;
}
header > .util > * a:hover {
  opacity: 0.9;
}
header > .util .akahata a {
  background: #fff;
  padding-bottom: clamp(2px, 1.5vw, 20px);
}
header > .util .akahata a::after {
  content: "";
  width: clamp(2px, 1.3vw, 17px);
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_07.webp) no-repeat 0 0/100% auto;
  position: absolute;
  left: 50%;
  bottom: clamp(2px, 1.3vw, 17px);
  transform: translateX(-75%);
}
header > .util .akahata a img {
  width: clamp(6px, 4.5vw, 60px);
}
header > .util .oshikatu a,
header > .util .candidate a,
header > .util .bokin a {
  writing-mode: vertical-rl;
  gap: 2px;
  color: #fff;
  width: 100%;
  padding-left: clamp(1px, 0.9vw, 12px);
}
header > .util .oshikatu a p,
header > .util .candidate a p,
header > .util .bokin a p {
  position: relative;
}
header > .util .oshikatu a p:nth-child(1),
header > .util .candidate a p:nth-child(1),
header > .util .bokin a p:nth-child(1) {
  font-size: clamp(0rem, 1vw, 1.4rem);
  font-weight: 400;
}
header > .util .oshikatu a p:nth-child(2),
header > .util .candidate a p:nth-child(2),
header > .util .bokin a p:nth-child(2) {
  font-size: clamp(0rem, 1.9vw, 2.5rem);
  display: flex;
  align-items: center;
  gap: clamp(1px, 0.9vw, 12px);
}
header > .util .oshikatu a p:nth-child(2)::after,
header > .util .candidate a p:nth-child(2)::after,
header > .util .bokin a p:nth-child(2)::after {
  content: "";
  width: clamp(2px, 1.3vw, 17px);
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_01.webp) no-repeat 0 0/100% auto;
}
header > .util .oshikatu a {
  background: linear-gradient(to bottom left, #ff74d1 0%, #ff88e2 19%, #82a5ff 76%, #6085ff 100%);
}
header > .util .oshikatu a p:nth-child(2)::after {
  transform: translate(10%, 150%);
}
header > .util .candidate a,
header > .util .bokin a {
  background: linear-gradient(to bottom left, #3bcfff 14%, #0080d5 100%);
}
header > .util .candidate a p:nth-child(2)::after,
header > .util .bokin a p:nth-child(2)::after {
  transform: translate(10%, 180%);
}
header > .util .goodbad {
  z-index: 1;
}
header > .util .goodbad a {
  background: linear-gradient(to bottom left, #f4f6f8 42%, #c2cdd5 96%);
  border-radius: 0 0 0 10px;
}
header > .util .goodbad a img {
  width: clamp(7px, 5.1vw, 68px);
}
header > .util .policy {
  display: none;
}
header > nav {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 0 clamp(12px, 9vw, 120px);
}
header > nav ul {
  max-width: 800px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 0.86fr 1fr 0.86fr;
  background: #fff;
  margin-top: -25px;
  transform: translateY(50%);
  box-shadow: 0 5px 0 0 #929495;
}
header > nav ul > * a {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(2rem, 1.8vw, 2.4rem);
  position: relative;
  padding: 10px 20px 12px 0;
  background: #fff;
}
header > nav ul > * a::after {
  content: "";
  width: 14px;
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_08.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: clamp(2px, 1.6vw, 22px);
  top: 50%;
  transform: translateY(-50%);
}
header > nav ul > * + * a::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  bottom: 10px;
  width: 1px;
  background: #dadada;
}
header > nav ul > *.policy a, header > nav ul > *.bokin a {
  letter-spacing: 0.2em;
  text-indent: 0.2em;
}
header #menu {
  display: none;
}
@media (max-width: 767px) {
  header {
    padding: 0 0 12.5rem 0;
  }
  header .header {
    display: block;
  }
  header .header .title {
    width: 30.8rem;
    padding: 2.8rem 0 0 1.2rem;
  }
  header .header .logo {
    padding: 0.9rem 1rem 0;
    width: 14.3rem;
    margin: 0 0 0 auto;
  }
  header .header .text .lead {
    padding: 4.5rem 3rem 1.5rem;
    font-size: 1.8rem;
  }
  header .header .text .str {
    width: fit-content;
    margin: 0 auto;
    font-size: 2.4rem;
  }
  header .header .senkyo {
    gap: 2rem;
    font-size: 2.4rem;
    margin: 2.5rem 2.5rem 0;
  }
  header .header .senkyo .date {
    font-size: 4.2rem;
  }
  header > nav {
    display: none;
  }
  header > .util {
    position: absolute;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    width: calc(100% - 6rem);
    box-shadow: 0 0.4rem 0 0 #929495;
    top: auto;
    bottom: 0;
    left: 3rem;
    transform: translateY(50%);
  }
  header > .util > li a {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    aspect-ratio: 156/52;
    padding: 0 0 0 1.5rem;
    min-height: 0;
  }
  header > .util > li a::after {
    content: "";
    width: 0.8rem;
    aspect-ratio: 16/24;
    position: absolute;
    right: 1.4rem;
    top: 50%;
    transform: translateY(-50%);
    background-repeat: no-repeat;
    background-size: 100% auto;
  }
  header > .util > li.akahata a::after, header > .util > li.goodbad a::after {
    background-image: url(../img/icon_arrow_16.webp);
  }
  header > .util > li.oshikatu a, header > .util > li.candidate a, header > .util > li.bokin a {
    writing-mode: horizontal-tb;
    padding: 0 0 0 1.5rem;
  }
  header > .util > li.oshikatu a p:nth-child(1), header > .util > li.candidate a p:nth-child(1), header > .util > li.bokin a p:nth-child(1) {
    display: none;
  }
  header > .util > li.oshikatu a p:nth-child(2), header > .util > li.candidate a p:nth-child(2), header > .util > li.bokin a p:nth-child(2) {
    font-size: 1.8rem;
  }
  header > .util > li.oshikatu a p:nth-child(2)::after, header > .util > li.candidate a p:nth-child(2)::after, header > .util > li.bokin a p:nth-child(2)::after {
    display: none;
  }
  header > .util > li.oshikatu a::after, header > .util > li.candidate a::after, header > .util > li.bokin a::after {
    background-image: url(../img/icon_arrow_17.webp);
  }
  header > .util > li.akahata a {
    padding: 0 0 0 1.5rem;
  }
  header > .util > li.akahata a::after {
    width: 0.8rem;
    aspect-ratio: 16/24;
    right: 1.4rem;
    top: 50%;
    transform: translateY(-50%);
    left: auto;
    bottom: auto;
  }
  header > .util > li.akahata a img {
    width: 10.4rem;
  }
  header > .util > li.goodbad a {
    border-radius: 0;
    background: linear-gradient(to bottom left, #f4f6f8 50%, #c2cdd5 96%);
  }
  header > .util > li.goodbad a img {
    width: 8.2rem;
  }
  header > .util > li.policy, header > .util > li.volunteer {
    display: block;
    grid-column: 1/span 2;
  }
  header > .util > li.policy a, header > .util > li.volunteer a {
    background: #e71515;
    color: #fff;
    aspect-ratio: auto;
    text-indent: 1em;
    justify-content: center;
    padding: 0.8em 0;
    font-size: 1.8rem;
  }
  header > .util > li.policy a::after, header > .util > li.volunteer a::after {
    background-image: url(../img/icon_arrow_17.webp);
  }
  header > .util > li.policy {
    display: none;
  }
  header > .util > li.policy a {
    letter-spacing: 1em;
  }
  header #menu {
    display: grid;
    grid-template-rows: 1fr max-content max-content;
    padding-bottom: 1px;
    position: fixed;
    z-index: 10;
    top: 0;
    left: 0;
    right: 0;
    padding: 0 3rem 3.5rem 3rem;
    height: calc(100vh - (5.6rem + 2px));
    background: #f6f8fa;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    transform: translateX(-100%);
    transition: opacity 0.3s 0s, visibility 0.3s 0s, transform 0s 0.3s;
  }
  .js-menuOpen header #menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    transition: opacity 0.3s 0s, visibility 0.3s 0s, transform 0s 0s;
  }
  header #menu .logo {
    padding: 0.9rem 1rem 0;
    width: 14.3rem;
    margin: 0 -3rem 0 auto;
  }
  header #menu > .util {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem 0.7rem;
  }
  header #menu > .util > li a {
    display: block;
    aspect-ratio: 154/88;
    position: relative;
  }
  header #menu > .util > li a::after {
    content: "";
    width: 0.8rem;
    aspect-ratio: 16/24;
    position: absolute;
    right: 1.4rem;
    top: 50%;
    transform: translateY(-50%);
    background-repeat: no-repeat;
    background-size: 100% auto;
  }
  header #menu > .util > li.akahata a::after, header #menu > .util > li.goodbad a::after {
    background-image: url(../img/icon_arrow_16.webp);
  }
  header #menu > .util > li.oshikatu a, header #menu > .util > li.candidate a {
    color: #fff;
    padding: 1.8rem 0 0 1.5rem;
  }
  header #menu > .util > li.oshikatu a p:nth-child(1), header #menu > .util > li.candidate a p:nth-child(1) {
    font-size: 1.3rem;
    font-weight: 400;
  }
  header #menu > .util > li.oshikatu a p:nth-child(2), header #menu > .util > li.candidate a p:nth-child(2) {
    font-size: 2rem;
    margin-top: 0.2rem;
  }
  header #menu > .util > li.oshikatu a::after, header #menu > .util > li.candidate a::after {
    background-image: url(../img/icon_arrow_17.webp);
  }
  header #menu > .util > li.akahata a {
    border: solid 1px #adadad;
    background: #fff;
    display: grid;
    place-content: center;
    padding-right: 0.5rem;
  }
  header #menu > .util > li.akahata a img {
    width: 7.4rem;
  }
  header #menu > .util > li.oshikatu a {
    background: linear-gradient(to bottom left, #ff74d1 0%, #ff88e2 19%, #82a5ff 76%, #6085ff 100%);
  }
  header #menu > .util > li.candidate a {
    background: linear-gradient(to bottom left, #3bcfff 14%, #0080d5 100%);
  }
  header #menu > .util > li.goodbad a {
    border: solid 1px #adadad;
    background: linear-gradient(to bottom left, #f4f6f8 42%, #c2cdd5 96%);
    display: grid;
    place-content: center;
    padding-right: 2rem;
  }
  header #menu > .util > li.goodbad a img {
    width: 9.9rem;
  }
  header #menu > nav {
    margin-top: 2.3rem;
  }
  header #menu > nav li + * {
    margin-top: 0.4rem;
  }
  header #menu > nav li a {
    display: flex;
    align-items: center;
    font-size: 1.5rem;
    position: relative;
    height: 5rem;
    background: #fff;
    padding-left: 3rem;
    color: #333;
  }
  header #menu > nav li a::after {
    content: "";
    width: 0.8rem;
    aspect-ratio: 16/24;
    position: absolute;
    right: 3rem;
    top: 50%;
    transform: translateY(-50%);
    background: url(../img/icon_arrow_16.webp) no-repeat 0 0/100% auto;
  }
}

/* news_youtube
----------------------------------- */
.news_youtube {
  background: #f4f6f8;
  padding: 78px clamp(12px, 9vw, 120px) 65px;
}
.news_youtube > div {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 30px;
}
.news_youtube > div h2 {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.2rem, 2.1vw, 2.8rem);
  color: #ff323c;
  display: flex;
  align-items: center;
  gap: clamp(2px, 1.1vw, 15px);
  line-height: 1;
}
.news_youtube #news {
  flex-basis: 400px;
}
.news_youtube #news h2 {
  margin-bottom: 10px;
  text-transform: uppercase;
}
.news_youtube #news h2::before {
  content: "";
  width: clamp(24px, 2vw, 27px);
  aspect-ratio: 1/1;
  background: url(../img/icon_news.webp) no-repeat 0 0/100% auto;
  position: relative;
  top: -0.1em;
}
.news_youtube #news .entries li {
  border-bottom: solid 1px #d4d4d4;
}
.news_youtube #news .entries li a {
  display: flex;
  align-items: center;
  gap: 0 10px;
  padding: 0.7em 0;
  font-size: 1.5rem;
  position: relative;
}
.news_youtube #news .entries li a::before {
  content: "";
  width: 12px;
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_03.webp) no-repeat 0 0/100% auto;
  flex-shrink: 0;
}
.news_youtube #news .entries li a .date {
  width: 4.5em;
  flex-shrink: 0;
}
.news_youtube #news .entries li a .text {
  -webkit-line-clamp: 1;
  overflow: hidden;
  -webkit-box-orient: vertical;
  display: -webkit-box;
}
.news_youtube #news .others {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
  gap: 20px;
}
.news_youtube #news .others > * {
  display: flex;
  min-width: 120px;
}
.news_youtube #news .others > * a {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  font-size: 1.5rem;
  color: #ff323c;
  font-weight: 700;
  border-bottom: solid 1px #ccc;
  padding-bottom: 0.2em;
}
.news_youtube #news .others > * a::after {
  content: "";
  width: 12px;
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_14.webp) no-repeat 0 0/100% auto;
}
.news_youtube #youtube {
  width: 51%;
}
.news_youtube #youtube h2 {
  margin-bottom: 15px;
}
.news_youtube #youtube h2 a.logo {
  display: flex;
  align-items: center;
  gap: clamp(2px, 1.1vw, 15px);
  color: #ff323c;
}
.news_youtube #youtube h2 a.logo::before {
  content: "";
  width: clamp(28px, 2.4vw, 32px);
  aspect-ratio: 64/45;
  background: url(../img/icon_youtube.webp) no-repeat 0 0/100% auto;
  position: relative;
}
.news_youtube #youtube h2 span.text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(1.2rem, 1vw, 1.4rem);
  font-weight: 500;
  color: #252723;
}
.news_youtube #youtube .slides {
  position: relative;
}
.news_youtube #youtube .slides .slide_nav {
  position: absolute;
  top: 50%;
  width: clamp(2px, 1.8vw, 24px);
  aspect-ratio: 24/60;
  cursor: pointer;
  background: url(../img/icon_arrow_04.webp) no-repeat 0 0/100% auto;
}
.news_youtube #youtube .slides .slide_nav.right {
  right: 0;
  transform: translate(150%, -90%);
}
.news_youtube #youtube .slides .swiper-slide {
  width: calc((100% - clamp(3px, 2.2vw, 30px)) / 3);
  margin-right: clamp(2px, 1.1vw, 15px);
}
.news_youtube #youtube .slides .swiper-slide:last-child {
  margin-right: 0;
}
.news_youtube #youtube .slides .swiper-slide a .thumbnail {
  aspect-ratio: 16/9;
  background: #dddddd;
  border-radius: 10px;
  overflow: hidden;
}
.news_youtube #youtube .slides .swiper-slide a .thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.news_youtube #youtube .slides .swiper-slide a p {
  margin-top: 10px;
  font-size: 1.2rem;
}
.news_youtube #youtube .other_sns {
  margin-top: clamp(2px, 1.5vw, 20px);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: clamp(2px, 1.1vw, 15px) 0;
}
.news_youtube #youtube .other_sns > * a {
  display: flex;
  gap: 5px;
  font-size: clamp(1.2rem, 1vw, 1.4rem);
  font-weight: 500;
}
.news_youtube #youtube .other_sns > * a::before {
  content: "";
  width: clamp(18px, 1.9vw, 25px);
  aspect-ratio: 1/1;
  flex-shrink: 0;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
.news_youtube #youtube .other_sns > * a span {
  background: #eee;
  border-radius: 2em;
  padding: 0 0.8em 0.2em;
  display: flex;
  align-items: center;
  justify-content: center;
}
.news_youtube #youtube .other_sns > *.insta a::before {
  background-image: url(../img/sns_icon_04.png);
}
.news_youtube #youtube .other_sns > *.tiktok a::before {
  aspect-ratio: 46/52;
  width: auto;
  height: clamp(18px, 1.9vw, 25px);
  background-image: url(../img/sns_icon_05.png);
}
.news_youtube #youtube .other_sns > *.x a::before {
  background-image: url(../img/sns_icon_06.png);
}
.news_youtube #youtube .other_sns > *.fb a::before {
  background-image: url(../img/sns_icon_02.webp);
}
@media (max-width: 1300px) {
  .news_youtube {
    padding-right: clamp(16px, 11.9vw, 160px);
  }
}
@media (max-width: 767px) {
  .news_youtube {
    padding: 12.5rem 0 5.5rem;
  }
  .news_youtube > div {
    display: block;
  }
  .news_youtube > div h2 {
    font-size: 2.8rem;
    gap: 1.5rem;
  }
  .news_youtube #news {
    width: auto;
    margin: 0 3rem 4.5rem 3rem;
  }
  .news_youtube #news h2 {
    margin-bottom: 1rem;
  }
  .news_youtube #news h2::before {
    width: 2.7rem;
    top: -0.1em;
  }
  .news_youtube #news .entries li a {
    display: block;
    padding: 0.5em 0 0.5em 2.3rem;
    font-size: 1.5rem;
  }
  .news_youtube #news .entries li a::before {
    position: absolute;
    left: 0;
    top: 0.8em;
  }
  .news_youtube #news .entries li a .date {
    width: auto;
    display: block;
    margin-bottom: 0.2em;
  }
  .news_youtube #news .others {
    margin-top: 1.5rem;
    gap: 4rem;
  }
  .news_youtube #youtube {
    width: auto;
    margin-left: 3rem;
  }
  .news_youtube #youtube h2 {
    margin-bottom: 1.5rem;
  }
  .news_youtube #youtube h2::before {
    width: 3.2rem;
  }
  .news_youtube #youtube h2 span {
    font-size: 1.4rem;
  }
  .news_youtube #youtube .slides {
    position: relative;
  }
  .news_youtube #youtube .slides .slide_nav {
    display: block;
    width: 2.7rem;
    aspect-ratio: 24/90;
    background: url(../img/icon_arrow_04_sp.webp) no-repeat 0 0/100% auto;
    z-index: 2;
  }
  .news_youtube #youtube .slides .slide_nav.right {
    transform: translate(0, -70%);
  }
  .news_youtube #youtube .slides .swiper-slide {
    width: 23rem;
    margin-right: 3rem;
  }
  .news_youtube #youtube .slides .swiper-slide:last-child {
    margin-right: 0;
  }
  .news_youtube #youtube .slides .swiper-slide a p {
    margin-top: 1rem;
    font-size: 1.4rem;
  }
  .news_youtube #youtube .other_sns {
    margin: 3rem 3rem 0 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem 2rem;
  }
  .news_youtube #youtube .other_sns > * a {
    gap: 0.5rem;
    font-size: 1.4rem;
  }
  .news_youtube #youtube .other_sns > * a::before {
    width: 2.5rem;
  }
  .news_youtube #youtube .other_sns > * a span {
    min-width: 10.5rem;
  }
  .news_youtube #youtube .other_sns > *.tiktok a::before {
    height: 2.5rem;
  }
}

/* movie
----------------------------------- */
#movie {
  background: url(../img/bg_youtube.webp) no-repeat 0 0/cover;
  padding: 30px clamp(12px, 9vw, 120px);
}
#movie .movie {
  max-width: 768px;
  aspect-ratio: 16/9;
  margin-inline: auto;
}
#movie .movie iframe {
  width: 100%;
  height: 100%;
}
@media (max-width: 767px) {
  #movie {
    padding: 3rem;
  }
}

/* voice
----------------------------------- */
#voice {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
#voice .title {
  background: url(../img/voice_img.webp) no-repeat center center/cover;
  padding-left: 20px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  position: relative;
}
#voice .title h2 {
  position: relative;
  z-index: 3;
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  color: #407de9;
  font-size: clamp(1rem, 6.5vw, 8.7rem);
  padding-top: 0.8em;
  margin-right: 0.7em;
  line-height: 0.94;
  text-shadow: 2px 2px 0 #fff, -2px -2px 0 #fff, -2px 2px 0 #fff, 2px -2px 0 #fff, 0 2px 0 #fff, 0 -2px 0 #fff, -2px 0 0 #fff, 2px 0 0 #fff;
}
#voice .title h2 span.str {
  font-size: 125%;
}
#voice .title h2 span:nth-of-type(2) {
  line-height: 1.05;
}
#voice .title::before {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../img/voice_ov.webp) repeat 0 0/720px auto;
  position: absolute;
  top: 0;
  left: 0;
  mix-blend-mode: multiply;
}
#voice .detail {
  background: #ff323c;
  color: #fff;
  padding: clamp(9px, 6.7vw, 90px) clamp(12px, 9vw, 120px) clamp(5px, 3.4vw, 45px) 0;
  position: relative;
  z-index: 2;
}
#voice .detail > div {
  max-width: 500px;
}
#voice .detail .fukidashi {
  width: fit-content;
  background: #fff;
  border-radius: 10px;
  padding: 0.5em 0.5em 0.5em 0.5em;
  margin-left: clamp(3px, 1.9vw, 25px);
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  font-size: clamp(0rem, 2.8vw, 3.8rem);
  color: #ff323c;
  position: relative;
  z-index: 3;
}
#voice .detail .fukidashi span {
  font-size: 130%;
}
#voice .detail .fukidashi::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 25%;
  border-style: solid;
  border-width: clamp(7px, 5.2vw, 70px) clamp(2px, 1.5vw, 20px) 0 clamp(4px, 3vw, 40px);
  border-color: #fff transparent transparent;
  translate: -50% 100%;
  transform: skew(-45deg);
  transform-origin: top;
}
#voice .detail .graph,
#voice .detail .graph_shadow {
  width: clamp(52px, 38.7vw, 519px);
  aspect-ratio: 1038/858;
  position: absolute;
  top: clamp(25px, 18.5vw, 248px);
  left: 0;
  transform: translate(-44%, 0);
}
#voice .detail .graph {
  z-index: 1;
}
#voice .detail .graph img {
  width: 75.4335260116%;
}
#voice .detail .graph_shadow {
  mix-blend-mode: multiply;
  z-index: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
}
#voice .detail .graph_shadow::after {
  content: "";
  width: 94.6050096339%;
  aspect-ratio: 982/690;
  background: url(../img/voice_graph-shadow.webp) no-repeat 0 0/100% auto;
}
#voice .detail .text {
  margin: clamp(5px, 3.4vw, 45px) 0 0 clamp(19px, 14.2vw, 190px);
  line-height: 1.6;
  position: relative;
  z-index: 1;
}
#voice .detail .text .lead {
  font-size: clamp(0rem, 1.3vw, 1.8rem);
}
#voice .detail .text .str {
  margin-top: 0.5em;
  font-size: clamp(0rem, 2vw, 2.7rem);
  color: #252723;
  line-height: 1.7;
}
#voice .detail .text .str span {
  background: #fff;
  padding: 0 0.3em;
}
#voice .detail .text .str span:nth-of-type(2) {
  padding-right: 0;
}
#voice .detail .link {
  margin-top: clamp(4px, 3vw, 40px);
  text-align: right;
}
#voice .detail .link a {
  font-size: clamp(0rem, 1.2vw, 1.6rem);
  color: #fff;
  display: inline-flex;
  gap: 0 10px;
  align-items: center;
  border-bottom: solid 1px #fff;
  padding-bottom: 0.3em;
}
#voice .detail .link a::after {
  content: "";
  width: 13px;
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_05.webp) no-repeat 0 0/100% auto;
}
@media (max-width: 767px) {
  #voice {
    display: block;
  }
  #voice .title {
    background-image: url(../img/voice_img_sp.webp);
    padding-left: 2.5rem;
    align-items: flex-end;
    justify-content: flex-start;
    height: 31.2rem;
  }
  #voice .title h2 {
    font-size: 4.9rem;
    padding-top: 0;
    margin-right: 0;
    transform: translateY(0.5em);
  }
  #voice .detail {
    padding: 0 3rem 3.5rem 3rem;
  }
  #voice .detail > div {
    max-width: none;
  }
  #voice .detail .fukidashi {
    width: 100%;
    border-radius: 1rem;
    padding: 0.5em 0.5em 0.5em 0.5em;
    margin: -2.5rem 0 0 0;
    font-size: 3rem;
  }
  #voice .detail .fukidashi::before {
    top: 0;
    bottom: auto;
    left: 55%;
    border-width: 0 3.2rem 4.2rem 0;
    border-color: transparent transparent #fff;
    translate: calc(-50% - 0.3px) -100%;
    transform: skew(20deg);
    transform-origin: bottom;
  }
  #voice .detail .graph,
  #voice .detail .graph_shadow {
    top: 0;
    left: 0;
  }
  #voice .detail .graph {
    width: auto;
    aspect-ratio: auto;
    position: relative;
    padding-left: 1.9rem;
    transform: translate(0, -4.2rem);
  }
  #voice .detail .graph img {
    width: 28rem;
  }
  #voice .detail .graph_shadow {
    width: 100%;
    aspect-ratio: 375/260;
    transform: none;
    overflow: hidden;
  }
  #voice .detail .graph_shadow::after {
    content: "";
    width: 36.1rem;
    aspect-ratio: 722/518;
    transform: translate(15%, 5%);
  }
  #voice .detail .text {
    margin: 2.5rem 0 0 0;
  }
  #voice .detail .text .lead {
    font-size: 1.8rem;
    line-height: 1.7;
  }
  #voice .detail .text .str {
    font-size: 2.4rem;
  }
  #voice .detail .link {
    margin-top: 3.5rem;
    text-align: left;
  }
  #voice .detail .link a {
    font-size: 1.5rem;
    gap: 0 1rem;
  }
  #voice .detail .link a::after {
    width: 1.3rem;
  }
}

/* manufest
----------------------------------- */
*[id^=manufest] {
  background: #f4f6f8;
  padding: clamp(6px, 4.5vw, 60px) clamp(12px, 9vw, 120px) clamp(7px, 4.9vw, 65px) calc((100% - 1000px) / 2);
}
*[id^=manufest] .manufest {
  max-width: 1000px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: max-content 1fr;
  gap: 40px 0;
}
*[id^=manufest] .manufest .title {
  grid-column: 1/2;
  grid-row: 1/2;
  padding-right: 20px;
}
*[id^=manufest] .manufest .title hgroup {
  position: relative;
}
*[id^=manufest] .manufest .title hgroup .num {
  position: absolute;
  left: 0;
  top: 0;
}
*[id^=manufest] .manufest .title hgroup .num span {
  display: none;
}
*[id^=manufest] .manufest .title hgroup .fukidashi {
  margin-bottom: 7px;
  position: relative;
  display: flex;
  align-items: flex-start;
  width: fit-content;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > * {
  position: relative;
  width: fit-content;
  min-width: clamp(18px, 13.4vw, 180px);
  text-align: center;
  font-size: clamp(0rem, 1.1vw, 1.5rem);
  padding: 0.3em 0.7em 0.5em;
  border-radius: 7px;
  border: solid 2px #fff;
  color: #fff;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 15px 0 0 20px;
  border-color: #fff transparent transparent;
  translate: -50% 100%;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: 11px 0 0 14.7px;
  translate: calc(-50% + 0.7px) 100%;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(1) {
  position: relative;
  z-index: 1;
  background: #407de9;
  margin-top: 15px;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(1)::after {
  border-color: #407de9 transparent transparent;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(2) {
  background: #1052cf;
  margin-left: -0.8em;
  padding-left: 1.3em;
  padding-right: 1.3em;
}
*[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(2)::after {
  border-color: #1052cf transparent transparent;
}
*[id^=manufest] .manufest .title hgroup h2 {
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  line-height: 1;
  color: #ff323c;
  font-size: clamp(1rem, 6vw, 8rem);
}
*[id^=manufest] .manufest .text {
  grid-column: 2/3;
  grid-row: 1/2;
  padding-top: clamp(9px, 6.7vw, 90px);
  line-height: 1.6;
}
*[id^=manufest] .manufest .text p {
  color: #ff323c;
}
*[id^=manufest] .manufest .text p.str {
  margin-bottom: 0.3em;
  font-size: clamp(0rem, 2vw, 2.7rem);
  color: #252723;
  line-height: 1.8;
}
*[id^=manufest] .manufest .text p.str span {
  background: #fff;
  padding: 0.1em 0.5em;
}
*[id^=manufest] .manufest .text p.str span:nth-of-type(1) {
  padding-right: 0;
}
*[id^=manufest] .manufest .text p.str span:nth-of-type(2) {
  padding-left: 0;
}
*[id^=manufest] .manufest .pop_detail {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-column: 1/span 2;
  grid-row: 2/3;
  gap: clamp(1px, 1vw, 14px);
}
*[id^=manufest] .manufest .pop_detail > * a {
  display: grid;
  align-content: center;
  gap: clamp(2px, 1.1vw, 15px) 0;
  background: #ff323c;
  color: #fff;
  min-height: clamp(16px, 11.8vw, 158px);
  box-shadow: 0 5px 0 0 #929495;
  transition: 0.3s;
  position: relative;
  padding: 0 0 clamp(1px, 0.4vw, 5px) clamp(10px, 7.1vw, 95px);
}
*[id^=manufest] .manufest .pop_detail > * a:hover {
  opacity: 0.8;
}
*[id^=manufest] .manufest .pop_detail > * a::before {
  content: "";
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: clamp(8px, 6vw, 80px) clamp(8px, 6vw, 80px) 0 0;
  border-color: #e71515 transparent transparent transparent;
  position: absolute;
  top: 0;
  left: 0;
}
*[id^=manufest] .manufest .pop_detail > * a::after {
  content: "";
  width: clamp(2px, 1.5vw, 20px);
  aspect-ratio: 1/1;
  background: url(../img/icon_plus.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: clamp(3px, 1.9vw, 25px);
  bottom: clamp(2px, 1.6vw, 22px);
}
*[id^=manufest] .manufest .pop_detail > * a .icon {
  position: absolute;
  left: 0;
  top: 0;
  background-repeat: no-repeat;
  background-size: 100% auto;
}
*[id^=manufest] .manufest .pop_detail > * a .point {
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  font-size: clamp(1rem, 3.7vw, 5rem);
  letter-spacing: 0.04em;
  line-height: 1.1;
}
*[id^=manufest] .manufest .pop_detail > * a .point .str {
  font-size: clamp(7px, 5.2vw, 70px);
}
*[id^=manufest] .manufest .pop_detail > * a .mean {
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(0rem, 1.5vw, 2rem);
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0 1.5em;
  margin-right: 3.5em;
}
*[id^=manufest]#manufest_01 .manufest .title {
  grid-row: 1/span 2;
}
*[id^=manufest]#manufest_01 .manufest .title hgroup .num {
  width: clamp(9px, 6.3vw, 85px);
  transform: translate(-150%, 50%);
}
*[id^=manufest]#manufest_01 .manufest .title .image {
  margin-top: clamp(3px, 1.9vw, 25px);
  width: clamp(47px, 35.1vw, 471px);
}
*[id^=manufest]#manufest_01 .manufest .text {
  grid-column: 2/3;
  grid-row: 1/2;
}
*[id^=manufest]#manufest_01 .manufest .pop_detail {
  grid-column: 2/3;
  grid-row: 2/3;
  grid-template-columns: auto;
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > * a {
  padding: clamp(1px, 0.7vw, 10px) 0 0 0;
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > * a .point {
  font-size: clamp(0rem, 3.6vw, 4.8rem);
  text-align: center;
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a {
  padding: clamp(2px, 1.1vw, 15px) 0 0 0;
  gap: clamp(1px, 0.7vw, 10px);
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a .icon {
  width: clamp(4px, 2.8vw, 38px);
  aspect-ratio: 76/77;
  background-image: url(../img/manufest_01_icon_01.webp);
  transform: translate(50%, 50%);
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a .point {
  line-height: 0.97;
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > *.zaigen a .icon {
  width: clamp(3px, 2.4vw, 32px);
  aspect-ratio: 64/81;
  background-image: url(../img/manufest_01_icon_02.webp);
  transform: translate(70%, 30%);
}
*[id^=manufest]#manufest_01 .manufest .pop_detail > *.zaigen a .point {
  transform: translate(-1%, -10%);
}
*[id^=manufest]#manufest_02 .manufest .title hgroup .num {
  width: clamp(15px, 11.5vw, 154px);
  transform: translate(-102%, 48%);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > * a .mean {
  position: absolute;
  margin: 0;
  right: clamp(6px, 4.5vw, 60px);
  bottom: clamp(2px, 1.5vw, 20px);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo {
  grid-column: 1/span 2;
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a {
  display: flex;
  align-items: center;
  gap: 0 clamp(4px, 3vw, 40px);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .icon {
  width: clamp(5px, 3.6vw, 48px);
  aspect-ratio: 96/98;
  background-image: url(../img/manufest_02_icon_01.webp);
  transform: translate(30%, 28%);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .point {
  font-size: clamp(8px, 6vw, 80px);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .mean {
  position: static;
  font-size: clamp(0rem, 2.4vw, 3.2rem);
  padding-top: clamp(1px, 0.7vw, 10px);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyoiku a .icon {
  width: clamp(4px, 3vw, 40px);
  aspect-ratio: 80/55;
  background-image: url(../img/manufest_02_icon_02.webp);
  transform: translate(40%, 80%);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.kome a .icon {
  width: clamp(4px, 2.6vw, 35px);
  aspect-ratio: 70/65;
  background-image: url(../img/manufest_02_icon_03.webp);
  transform: translate(55%, 55%);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.iryo a .icon {
  width: clamp(4px, 2.7vw, 36px);
  aspect-ratio: 72/60;
  background-image: url(../img/manufest_02_icon_04.webp);
  transform: translate(50%, 80%);
}
*[id^=manufest]#manufest_02 .manufest .pop_detail > *.jutaku a .icon {
  width: clamp(4px, 2.8vw, 38px);
  aspect-ratio: 76/67;
  background-image: url(../img/manufest_02_icon_05.webp);
  transform: translate(50%, 55%);
}
*[id^=manufest]#manufest_03 .manufest .title hgroup .num {
  width: clamp(16px, 12.2vw, 163px);
  transform: translate(-102%, 48%);
}
*[id^=manufest]#manufest_03 .manufest .pop_detail > * a {
  padding-top: 0;
}
*[id^=manufest]#manufest_03 .manufest .pop_detail > *.trump a .icon {
  width: clamp(4px, 3.1vw, 41px);
  aspect-ratio: 82/50;
  background-image: url(../img/manufest_03_icon_01.webp);
  transform: translate(50%, 90%);
}
*[id^=manufest]#manufest_03 .manufest .pop_detail > *.heiwa a .icon {
  width: clamp(3px, 2.5vw, 33px);
  aspect-ratio: 66/66;
  background-image: url(../img/manufest_03_icon_02.webp);
  transform: translate(60%, 60%);
}
*[id^=manufest]#manufest_04 {
  padding-bottom: clamp(11px, 8.2vw, 110px);
}
*[id^=manufest]#manufest_04 .manufest .title hgroup .num {
  width: clamp(17px, 13vw, 174px);
  transform: translate(-93%, 50%);
}
*[id^=manufest]#manufest_04 .manufest .pop_detail > *.kikou a .icon {
  width: clamp(4px, 3.1vw, 41px);
  aspect-ratio: 1/1;
  background-image: url(../img/manufest_04_icon_01.webp);
  transform: translate(45%, 40%);
}
*[id^=manufest]#manufest_04 .manufest .pop_detail > *.gender a .icon {
  width: clamp(4px, 3.2vw, 43px);
  aspect-ratio: 86/60;
  background-image: url(../img/manufest_04_icon_02.webp);
  transform: translate(45%, 70%);
}
*[id^=manufest]#manufest_04 .manufest .pop_detail > *.uragane a .icon {
  width: clamp(4px, 2.7vw, 36px);
  aspect-ratio: 72/92;
  background-image: url(../img/manufest_04_icon_03.webp);
  transform: translate(38%, 28%);
}
*[id^=manufest]#manufest_04 .manufest .pop_detail > *.hate a .icon {
  width: clamp(4px, 2.9vw, 39px);
  aspect-ratio: 78/74;
  background-image: url(../img/manufest_04_icon_04.webp);
  transform: translate(60%, 55%);
}
*[id^=manufest]#manufest_05 {
  background: #fff;
}
*[id^=manufest]#manufest_05 .manufest .title {
  grid-row: 1/span 2;
}
*[id^=manufest]#manufest_05 .manufest .title hgroup h2 {
  color: #ff6800;
}
*[id^=manufest]#manufest_05 .manufest .title p {
  margin-top: 0.8em;
}
*[id^=manufest]#manufest_05 .manufest .title p.str {
  font-size: clamp(0rem, 2.2vw, 3rem);
  color: #ff6800;
  line-height: 1.8;
}
*[id^=manufest]#manufest_05 .manufest .title p.str span {
  background: #fff800;
  padding: 0.1em 0.5em;
}
*[id^=manufest]#manufest_05 .manufest .title p.str span:nth-of-type(1) {
  padding-right: 0;
}
*[id^=manufest]#manufest_05 .manufest .title p.str span:nth-of-type(2) {
  padding-left: 0;
}
*[id^=manufest]#manufest_05 .manufest .text {
  grid-row: 1/2;
  padding-top: 0.5em;
}
*[id^=manufest]#manufest_05 .manufest .text > p:first-child {
  color: #ff6800;
  font-size: clamp(0rem, 1.5vw, 2rem);
  line-height: 1.7;
}
*[id^=manufest]#manufest_05 .manufest .more {
  grid-column: 2/3;
  grid-row: 2/3;
  align-self: end;
  padding: 0 clamp(3px, 2.2vw, 30px) clamp(3px, 1.9vw, 25px) 0;
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: clamp(2px, 1.5vw, 20px);
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn p {
  background: #ff323c;
  color: #fff;
  font-size: clamp(0rem, 1.3vw, 1.8rem);
  padding: 0.7em 1.4em 0.7em 0.9em;
  position: relative;
  border-radius: 0.3em;
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn p span {
  margin-right: 0.3em;
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn p::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #ff323c;
  translate: 100% -50%;
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn .btn a {
  display: block;
  font-size: clamp(0rem, 1.1vw, 1.5rem);
  padding: 0.5em 2.5em 0.5em 0.8em;
  border: solid 1px #ff323c;
  background: #fff;
  color: #ff323c;
  position: relative;
}
*[id^=manufest]#manufest_05 .manufest .more .more_btn .btn a::after {
  content: "";
  width: clamp(1px, 1vw, 13px);
  aspect-ratio: 1/1;
  background: url(../img/icon_plus_red.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 1350px) {
  *[id^=manufest] {
    padding-left: clamp(18px, 13.1vw, 175px);
  }
}
@media (max-width: 767px) {
  *[id^=manufest] {
    padding: 2.7rem 3rem 6.5rem !important;
  }
  *[id^=manufest] .manufest {
    display: block;
  }
  *[id^=manufest] .manufest .title {
    padding-right: 0;
  }
  *[id^=manufest] .manufest .title hgroup .num {
    width: auto !important;
  }
  *[id^=manufest] .manufest .title hgroup .num img {
    display: none;
  }
  *[id^=manufest] .manufest .title hgroup .num span {
    display: block;
    font-family: "Montserrat", sans-serif;
    color: #fff;
    font-size: 20rem;
    font-style: italic;
    line-height: 1;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi {
    margin-bottom: 1rem;
    width: auto;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > * {
    min-width: 16.2rem;
    font-size: 1.4rem;
    padding: 0.3em 0 0.5em;
    border-radius: 0.7rem;
    letter-spacing: -0.03em;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > * .tight {
    margin-left: -0.5em;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *::before {
    border-width: 1.5rem 0 0 2rem;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *::after {
    border-width: 1.1rem 0 0 1.47rem;
    translate: calc(-50% + 0.07rem) 100%;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(1) {
    margin-top: 1.5rem;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(2) {
    margin-left: -0.9rem;
    padding-left: 0;
    padding-right: 0;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(2)::before {
    border-width: 1.5rem 2rem 0 0;
  }
  *[id^=manufest] .manufest .title hgroup .fukidashi > *:nth-of-type(2)::after {
    border-width: 1.1rem 1.47rem 0 0;
    translate: calc(-50% - 0.07rem) 100%;
  }
  *[id^=manufest] .manufest .title hgroup h2 {
    position: relative;
    font-size: 6.2rem;
  }
  *[id^=manufest] .manufest .text {
    padding-top: 3rem;
    line-height: 1.7;
  }
  *[id^=manufest] .manufest .text p.str {
    margin-bottom: 0.5em;
    font-size: 2.4rem;
  }
  *[id^=manufest] .manufest .text p.str span:nth-of-type(1) {
    padding-right: 0.5em;
  }
  *[id^=manufest] .manufest .text p.str span:nth-of-type(2) {
    padding-left: 0.5em;
  }
  *[id^=manufest] .manufest .pop_detail {
    margin-top: 2.2rem;
    display: block;
  }
  *[id^=manufest] .manufest .pop_detail > * + * {
    margin-top: 1.1rem;
  }
  *[id^=manufest] .manufest .pop_detail > * a {
    gap: 0;
    min-height: 12.5rem;
    box-shadow: 0 0.5rem 0 0 #929495;
    padding: 0 0 0.5rem 5.5rem;
  }
  *[id^=manufest] .manufest .pop_detail > * a::before {
    border-width: 5.5rem 5.5rem 0 0;
  }
  *[id^=manufest] .manufest .pop_detail > * a::after {
    width: 1.8rem;
    right: 1.5rem;
    bottom: 1.3rem;
  }
  *[id^=manufest] .manufest .pop_detail > * a .point {
    font-size: 3.5rem;
  }
  *[id^=manufest] .manufest .pop_detail > * a .point .str {
    font-size: 4.4rem;
  }
  *[id^=manufest] .manufest .pop_detail > * a .mean {
    font-size: 1.7rem;
    margin-right: 5rem;
  }
  *[id^=manufest]#manufest_01 .manufest .title hgroup .num {
    transform: translate(-11%, -28%);
  }
  *[id^=manufest]#manufest_01 .manufest .title .image {
    margin: -2.2rem 0 0 auto;
    width: 29.1rem;
  }
  *[id^=manufest]#manufest_01 .manufest .text p.str span:nth-of-type(1) {
    padding-right: 0;
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > * a {
    padding: 0;
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > * a .point {
    font-size: 3.5rem;
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a {
    padding: 0;
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a .icon {
    width: 2.8rem;
    transform: translate(38%, 35%);
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > *.shouhizei a .mean {
    position: absolute;
    margin: 0;
    right: 4.6rem;
    bottom: 1.1rem;
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > *.zaigen a .icon {
    width: 2.6rem;
    transform: translate(40%, 25%);
  }
  *[id^=manufest]#manufest_01 .manufest .pop_detail > *.zaigen a .point {
    transform: none;
  }
  *[id^=manufest]#manufest_02 .manufest .title hgroup .num {
    transform: translate(-24%, -28%);
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > * a {
    padding-bottom: 1.5rem;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > * a .point {
    line-height: 1;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > * a .mean {
    right: 4.6rem;
    bottom: 1.1rem;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a {
    display: grid;
    align-items: center;
    gap: 0;
    padding-left: 0;
    padding-bottom: 0.5rem;
    text-align: center;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .icon {
    width: 3.2rem;
    transform: translate(30%, 25%);
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .point {
    font-size: 4.5rem;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyuryo a .mean {
    position: absolute;
    font-size: 1.7rem;
    padding-top: 0;
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kyoiku a .icon {
    width: 3.2rem;
    transform: translate(25%, 60%);
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.kome a .icon {
    width: 2.8rem;
    transform: translate(35%, 35%);
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.iryo a .icon {
    width: 2.8rem;
    transform: translate(30%, 60%);
  }
  *[id^=manufest]#manufest_02 .manufest .pop_detail > *.jutaku a .icon {
    width: 3rem;
    transform: translate(30%, 60%);
  }
  *[id^=manufest]#manufest_03 .manufest .title hgroup .num {
    transform: translate(-24%, -28%);
  }
  *[id^=manufest]#manufest_03 .manufest .pop_detail > *.trump a .icon {
    width: 3.2rem;
    transform: translate(25%, 90%);
  }
  *[id^=manufest]#manufest_03 .manufest .pop_detail > *.heiwa a .icon {
    width: 2.6rem;
    transform: translate(35%, 60%);
  }
  *[id^=manufest]#manufest_04 {
    padding-bottom: 10.5rem;
  }
  *[id^=manufest]#manufest_04 .manufest .title hgroup .num {
    transform: translate(-25%, -32%);
  }
  *[id^=manufest]#manufest_04 .manufest .pop_detail > *.kikou a .icon {
    width: 3.2rem;
    transform: translate(30%, 35%);
  }
  *[id^=manufest]#manufest_04 .manufest .pop_detail > *.gender a .icon {
    width: 3.3rem;
    transform: translate(30%, 65%);
  }
  *[id^=manufest]#manufest_04 .manufest .pop_detail > *.uragane a .icon {
    width: 2.8rem;
    transform: translate(20%, 23%);
  }
  *[id^=manufest]#manufest_04 .manufest .pop_detail > *.hate a .icon {
    width: 3rem;
    transform: translate(30%, 40%);
  }
  *[id^=manufest]#manufest_04 .manufest .pop_detail > *.hate a .point span {
    letter-spacing: -0.01em;
  }
  *[id^=manufest]#manufest_05 {
    padding-bottom: 4rem !important;
  }
  *[id^=manufest]#manufest_05 .manufest .title p {
    margin-top: 0.8em;
  }
  *[id^=manufest]#manufest_05 .manufest .title p.str {
    font-size: 2.4rem;
  }
  *[id^=manufest]#manufest_05 .manufest .title p.str span:nth-of-type(1) {
    padding-right: 0.5em;
  }
  *[id^=manufest]#manufest_05 .manufest .title p.str span:nth-of-type(2) {
    padding-left: 0.5em;
    padding-right: 0;
  }
  *[id^=manufest]#manufest_05 .manufest .title p.str span:nth-of-type(3) {
    padding-left: 0;
  }
  *[id^=manufest]#manufest_05 .manufest .text {
    margin-top: 1em;
  }
  *[id^=manufest]#manufest_05 .manufest .text > p:first-child {
    font-size: 1.8rem;
  }
  *[id^=manufest]#manufest_05 .manufest .more {
    margin-top: 4rem;
    padding: 0;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn {
    display: block;
    text-align: center;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn p {
    display: inline-block;
    font-size: 2rem;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn p::after {
    top: auto;
    right: auto;
    bottom: 0;
    left: 50%;
    border-width: 1rem 0.75rem 0 0.75rem;
    border-color: #ff323c transparent transparent;
    translate: -50% 100%;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn .btn {
    margin-top: 1.5rem;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn .btn a {
    display: inline-block;
    font-size: 1.5rem;
  }
  *[id^=manufest]#manufest_05 .manufest .more .more_btn .btn a::after {
    width: 1.3rem;
  }
}
@media (max-width: 767px) and (max-width: 1350px) {
  *[id^=manufest] {
    padding-left: clamp(18px, 13.1vw, 175px);
  }
}

/* goodbad
----------------------------------- */
#goodbad {
  padding: clamp(7px, 5.2vw, 70px) clamp(12px, 9vw, 120px) clamp(5px, 3.7vw, 50px);
}
#goodbad .goodbad {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 0 0 clamp(3px, 2.4vw, 32px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
#goodbad .goodbad .image {
  flex-basis: 412px;
}
#goodbad .goodbad .detail {
  width: 510px;
}
#goodbad .goodbad .detail h2 {
  max-width: 410px;
  margin: 0 auto clamp(3px, 2.2vw, 30px);
}
#goodbad .goodbad .detail p {
  max-width: 185px;
  margin: 0 auto clamp(2px, 1.1vw, 15px);
}
#goodbad .goodbad .detail ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1px, 0.7vw, 10px) clamp(1px, 0.4vw, 5px);
}
#goodbad .goodbad .detail ul li a {
  display: block;
  border-radius: 2em;
  font-size: clamp(0rem, 1.5vw, 2rem);
  padding: 0.6em 1.6em 0.6em 1em;
  position: relative;
  background: linear-gradient(to right, #54c837 19%, #ff6db6 81%);
}
#goodbad .goodbad .detail ul li a span {
  position: relative;
  z-index: 1;
}
#goodbad .goodbad .detail ul li a:hover::before {
  opacity: 0.8;
}
#goodbad .goodbad .detail ul li a::before {
  content: "";
  position: absolute;
  top: 3px;
  bottom: 3px;
  left: 3px;
  right: 3px;
  border-radius: 2em;
  background: #fff;
  transition: 0.3s;
}
#goodbad .goodbad .detail ul li a::after {
  content: "";
  width: 11px;
  aspect-ratio: 22/12;
  background: url(../img/icon_arrow_06.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: 0.8em;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  #goodbad {
    padding: 3.5rem 3rem 4.2rem;
  }
  #goodbad .goodbad {
    padding: 0;
    display: block;
  }
  #goodbad .goodbad .image {
    margin-bottom: 2.5rem;
  }
  #goodbad .goodbad .detail {
    width: auto;
  }
  #goodbad .goodbad .detail h2 {
    max-width: 24rem;
    margin-bottom: 2.8rem;
  }
  #goodbad .goodbad .detail p {
    max-width: 17.3rem;
    margin-bottom: 1.6rem;
  }
  #goodbad .goodbad .detail ul {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.3rem 1rem;
  }
  #goodbad .goodbad .detail ul li a {
    font-size: 1.8rem;
    padding: 0.6em 1.4em 0.7em 1.2em;
  }
  #goodbad .goodbad .detail ul li a::after {
    width: 1.2rem;
    right: 0.8em;
  }
}

/* comparison
----------------------------------- */
#comparison {
  padding: clamp(4px, 2.6vw, 35px) clamp(12px, 9vw, 120px);
}
#comparison .comparison {
  max-width: 1000px;
  margin: 0 auto;
}
#comparison .comparison h2 {
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  font-size: clamp(1rem, 4.5vw, 6rem);
  color: #5452cf;
  margin-bottom: clamp(1px, 0.7vw, 10px);
  text-align: center;
}
#comparison .comparison .genzei p {
  font-size: clamp(0rem, 3vw, 4rem);
  margin-bottom: 5px;
  color: #5452cf;
}
#comparison .comparison .genzei .scr_wrap {
  position: relative;
}
#comparison .comparison .genzei .scr_wrap .scroll-btn {
  display: none;
}
#comparison .comparison .zaigen {
  margin-top: calc(clamp(2px, 1.1vw, 15px) * -1);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1em;
  color: #ff323c;
}
#comparison .comparison .zaigen p {
  font-size: clamp(0rem, 3vw, 4rem);
  transform: translateY(-8%);
}
#comparison .comparison .zaigen .btn a {
  display: block;
  font-size: clamp(0rem, 1.1vw, 1.5rem);
  padding: 0.5em 2.5em 0.5em 0.8em;
  border: solid 1px #ff323c;
  background: #fff;
  color: #ff323c;
  position: relative;
}
#comparison .comparison .zaigen .btn a::after {
  content: "";
  width: clamp(1px, 1vw, 13px);
  aspect-ratio: 1/1;
  background: url(../img/icon_plus_red.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  #comparison {
    padding: 4rem 3rem;
  }
  #comparison .comparison h2 {
    font-size: 6rem;
    margin-bottom: 2rem;
  }
  #comparison .comparison .genzei {
    margin-right: -1.7rem;
  }
  #comparison .comparison .genzei p {
    font-size: 3.4rem;
    text-align: center;
    margin-bottom: 1.8rem;
  }
  #comparison .comparison .genzei .scr_wrap {
    position: relative;
  }
  #comparison .comparison .genzei .scr_wrap .scroll-btn {
    display: block;
    position: absolute;
    width: 2.7rem;
    aspect-ratio: 54/180;
    background: url(../img/icon_arrow_04_sp.webp) no-repeat 0 0/100% auto;
    top: 0;
    cursor: pointer;
    transition: 0.3s;
    pointer-events: auto;
  }
  #comparison .comparison .genzei .scr_wrap .scroll-btn.hidden {
    opacity: 0;
    pointer-events: none;
  }
  #comparison .comparison .genzei .scr_wrap .scroll-btn.left {
    left: -3rem;
    transform: scale(-1, 1);
  }
  #comparison .comparison .genzei .scr_wrap .scroll-btn.right {
    right: -3rem;
  }
  #comparison .comparison .genzei .scr_wrap .table {
    overflow-x: auto;
    margin: 0 -1rem;
  }
  #comparison .comparison .genzei .scr_wrap .table img {
    width: 79rem;
    max-width: none;
  }
  #comparison .comparison .zaigen {
    margin-top: 2.6rem;
    justify-content: space-between;
    gap: 0;
  }
  #comparison .comparison .zaigen p {
    font-size: 2.2rem;
    line-height: 1.6;
  }
  #comparison .comparison .zaigen .btn a {
    font-size: 1.5rem;
    padding: 0.5em 2.5em 0.5em 0.8em;
  }
  #comparison .comparison .zaigen .btn a::after {
    width: 1.5rem;
  }
}

/* oshikatu
----------------------------------- */
#oshikatu {
  background: #fff;
  padding: clamp(4px, 2.6vw, 35px) clamp(12px, 9vw, 120px) 0;
}
#oshikatu .oshikatu {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
}
#oshikatu .oshikatu .image {
  width: 38%;
}
#oshikatu .oshikatu .btn {
  width: 62%;
}
#oshikatu .oshikatu .btn a {
  margin-left: -0.1em;
  display: flex;
  align-items: center;
  aspect-ratio: 620/180;
  padding: 0 clamp(7px, 4.9vw, 65px) clamp(1px, 0.7vw, 10px);
  background: #6382ff;
  position: relative;
  color: #fff;
  font-size: clamp(1rem, 3.7vw, 5rem);
  line-height: 1.5;
  box-shadow: 0 5px 0 0 #929495;
  transition: 0.3s;
  transform: translateY(calc(clamp(2px, 1.3vw, 17px) * -1));
}
#oshikatu .oshikatu .btn a span {
  font-size: clamp(0rem, 1.8vw, 2.4rem);
  display: block;
}
#oshikatu .oshikatu .btn a:hover {
  opacity: 0.8;
}
#oshikatu .oshikatu .btn a::after {
  content: "";
  width: clamp(3px, 2.5vw, 33px);
  aspect-ratio: 1/1;
  background: url(../img/icon_arrow_09.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: clamp(7px, 4.9vw, 65px);
  top: 50%;
  transform: translateY(-50%);
}
@media (max-width: 767px) {
  #oshikatu {
    padding: 8rem 3rem;
  }
  #oshikatu .oshikatu {
    display: block;
  }
  #oshikatu .oshikatu .image {
    width: 88vw;
    margin: -2.2rem 0 0 -2.5rem;
    position: relative;
  }
  #oshikatu .oshikatu .btn {
    width: auto;
  }
  #oshikatu .oshikatu .btn a {
    margin-left: 0;
    aspect-ratio: 315/140;
    padding: 0 4.8rem 1rem 2.1rem;
    font-size: 2.9rem;
    line-height: 1.5;
    box-shadow: 0 0.5rem 0 0 #929495;
    transform: none;
  }
  #oshikatu .oshikatu .btn a span {
    font-size: 1.8rem;
  }
  #oshikatu .oshikatu .btn a::after {
    background-image: url(../img/icon_arrow_13.webp);
    width: 1.8rem;
    right: 2.3rem;
  }
}

/* policy_candidate
----------------------------------- */
.policy_candidate {
  position: relative;
  height: clamp(42px, 31.3vw, 420px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0 clamp(12px, 9vw, 120px);
}
.policy_candidate .gallery {
  display: flex;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
.policy_candidate .gallery > * {
  flex: 1;
  overflow: hidden;
}
.policy_candidate .gallery > * img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.policy_candidate .gallery > *:nth-child(2) img, .policy_candidate .gallery > *:nth-child(3) img {
  height: auto;
}
.policy_candidate .gallery::after {
  content: "";
  width: 100%;
  height: 100%;
  background: url(../img/gallery_ov.webp) repeat 0 0/1440px auto;
  position: absolute;
  top: 0;
  left: 0;
  mix-blend-mode: multiply;
}
.policy_candidate .link {
  display: flex;
  max-width: 1000px;
  width: 100%;
  box-shadow: 0 5px 0 0 #929495;
  transform: translateY(50%);
}
.policy_candidate .link > * {
  flex: 1;
}
.policy_candidate .link > * a {
  height: 100%;
  position: relative;
  display: flex;
  align-items: center;
}
.policy_candidate .link > * a p {
  font-size: clamp(0rem, 2.2vw, 3rem);
}
.policy_candidate .link > * a::after {
  content: "";
  width: clamp(2px, 1.6vw, 22px);
  aspect-ratio: 1/1;
  position: absolute;
  right: clamp(4px, 3vw, 40px);
  bottom: clamp(3px, 1.9vw, 25px);
}
.policy_candidate .link > *#policy a {
  background: #ff323c;
  color: #fff;
  padding: clamp(3px, 1.9vw, 25px) 0 clamp(3px, 1.9vw, 25px) clamp(4px, 3vw, 40px);
  gap: clamp(5px, 3.7vw, 50px);
}
.policy_candidate .link > *#policy a .image {
  width: clamp(16px, 12.1vw, 162px);
}
.policy_candidate .link > *#policy a .arrow_text {
  font-size: clamp(0rem, 1.2vw, 1.6rem);
  font-weight: 500;
  position: absolute;
  right: clamp(8px, 6vw, 80px);
  bottom: clamp(3px, 1.9vw, 25px);
}
.policy_candidate .link > *#policy a::after {
  background: url(../img/icon_arrow_10.webp) no-repeat 0 0/100%;
}
.policy_candidate .link > *#candidate a {
  background: #fff;
  color: #ff323c;
  padding-top: clamp(1px, 0.6vw, 8px);
  gap: clamp(5px, 3.4vw, 45px);
}
.policy_candidate .link > *#candidate a .image {
  width: clamp(25px, 18.6vw, 249px);
}
.policy_candidate .link > *#candidate a::after {
  background: url(../img/icon_arrow_11.webp) no-repeat 0 0/100%;
}
@media (max-width: 767px) {
  .policy_candidate {
    background: #f6f8fa;
    height: auto;
    display: block;
    padding: 0;
  }
  .policy_candidate .gallery {
    position: relative;
    width: auto;
    height: auto;
  }
  .policy_candidate .gallery > *:nth-child(2), .policy_candidate .gallery > *:nth-child(3) {
    aspect-ratio: 720/615;
  }
  .policy_candidate .gallery > *:nth-child(2) img, .policy_candidate .gallery > *:nth-child(3) img {
    height: 100%;
  }
  .policy_candidate .gallery > *:nth-child(1), .policy_candidate .gallery > *:nth-child(4) {
    display: none;
  }
  .policy_candidate .link {
    display: block;
    width: auto;
    box-shadow: 0 0.5rem 0 0 #929495;
    transform: none;
    margin: -3.5rem 3rem 0 3rem;
  }
  .policy_candidate .link > * a {
    height: auto;
  }
  .policy_candidate .link > * a p {
    font-size: 2.2rem;
  }
  .policy_candidate .link > * a::after {
    width: 1.5rem;
    right: 2rem;
    bottom: 2rem;
  }
  .policy_candidate .link > *#policy a {
    padding: 1.1rem 0 0.9rem 1.5rem;
    gap: 2.2rem;
  }
  .policy_candidate .link > *#policy a .image {
    width: 9.2rem;
  }
  .policy_candidate .link > *#policy a p:nth-of-type(1) {
    margin-bottom: 0.5em;
  }
  .policy_candidate .link > *#policy a .arrow_text {
    font-size: 1.4rem;
    right: 4.5rem;
    bottom: 2rem;
  }
  .policy_candidate .link > *#policy a::after {
    background-image: url(../img/icon_arrow_15.webp);
  }
  .policy_candidate .link > *#candidate a {
    padding-top: 0.4rem;
    gap: 2rem;
  }
  .policy_candidate .link > *#candidate a .image {
    width: 13.2rem;
  }
  .policy_candidate .link > *#candidate a::after {
    background-image: url(../img/icon_arrow_14.webp);
  }
}

/* bnr
----------------------------------- */
#bnr {
  background: #f6f8fa;
  padding: clamp(19px, 14.2vw, 190px) clamp(12px, 9vw, 120px) clamp(5px, 3.4vw, 45px);
}
#bnr ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
}
#bnr ul li img {
  max-height: 87px;
}
@media (max-width: 767px) {
  #bnr {
    padding: 4rem 0 5.8rem;
  }
  #bnr ul {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: auto;
    margin: 0 3rem;
    gap: 0.4rem;
  }
  #bnr ul li:nth-child(3) {
    grid-column: 1/span 2;
  }
  #bnr ul li img {
    max-height: none;
  }
}

/* footer
----------------------------------- */
footer {
  background: #ff323c;
  color: #fff;
  padding: clamp(6px, 4.5vw, 60px) clamp(12px, 9vw, 120px) 0;
}
footer .seido {
  max-width: 1000px;
  margin: 0 auto clamp(9px, 6.5vw, 87px);
  display: grid;
  grid-template-columns: max-content auto 67.6%;
}
footer .seido h2 {
  grid-column: 1/2;
  grid-row: 1/2;
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  font-size: clamp(0rem, 2.5vw, 3.4rem);
}
footer .seido h2 span {
  display: block;
  font-size: clamp(1rem, 4.9vw, 6.5rem);
}
footer .seido .vote {
  grid-column: 3/4;
  grid-row: 1/span 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
footer .seido .vote > * {
  padding: clamp(2px, 1.3vw, 17px) clamp(3px, 1.9vw, 25px) clamp(3px, 2.2vw, 30px);
  aspect-ratio: 1/1;
  border-radius: 10px;
  background: #e71515;
  display: grid;
  grid-template-columns: max-content auto max-content;
}
footer .seido .vote > * .step {
  grid-column: 1/2;
}
footer .seido .vote > * .step h3 {
  font-size: clamp(0rem, 3vw, 4rem);
  line-height: 1;
  text-align: center;
  transform: translate(-5%, -10%);
}
footer .seido .vote > * .step h3 .num {
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2rem, 11.9vw, 16rem);
  font-style: italic;
  display: block;
}
footer .seido .vote > * .step h3 span:last-child {
  display: block;
  margin-top: -0.4em;
}
footer .seido .vote > * .note {
  grid-column: 1/span 2;
  grid-row: 2/3;
  font-size: clamp(0rem, 1.3vw, 1.8rem);
  font-weight: 500;
  align-self: end;
  text-align: right;
  padding-right: 0.5em;
}
footer .seido .vote > * .detail {
  grid-column: 3/4;
  grid-row: 1/span 2;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
footer .seido .vote > * .detail p {
  font-size: clamp(0rem, 2.2vw, 2.9rem);
}
footer .seido .vote > * .detail .box {
  width: clamp(16px, 12.2vw, 163px);
  margin-left: auto;
}
footer .seido .vote > *:nth-child(1) .detail .box {
  margin-left: clamp(3px, 1.9vw, 25px);
}
footer .seido .vote > *:nth-child(2) .step h3 span:last-child {
  padding-right: 0.5em;
}
footer .seido .date {
  grid-column: 1/2;
  grid-row: 2/3;
  align-self: end;
}
footer .seido .date p {
  width: fit-content;
  font-size: clamp(0rem, 2.1vw, 2.8rem);
}
footer .seido .date p.advance {
  border-top: solid 1px #fff;
  border-bottom: solid 1px #fff;
  margin-top: 0.7em;
  padding: 0.5em 0;
}
footer .hirei {
  font-family: "Dela Gothic One", sans-serif;
  font-weight: normal;
  line-height: 0.97;
  font-size: clamp(1rem, 7.5vw, 10rem);
  margin: 0 calc(clamp(12px, 9vw, 120px) * -1);
  padding: 0.05em 0 0.2em;
  border-top: solid 20px #f6f8fa;
  border-bottom: solid 1px #f6f8fa;
  text-align: center;
  line-height: 1;
}
footer .footer {
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: max-content 1fr;
}
footer .footer .logo {
  grid-column: 1/2;
  grid-row: 1/2;
  padding: clamp(2px, 1.7vw, 23px) clamp(4px, 3vw, 40px) clamp(1px, 1vw, 13px) 0;
  border-right: solid 1px #f6f8fa;
}
footer .footer .logo img {
  width: clamp(21px, 15.8vw, 212px);
}
footer .footer .logo p {
  font-size: 1rem;
  line-height: 1;
  margin-top: 1em;
  letter-spacing: 0.1em;
}
footer .footer .util {
  grid-column: 2/3;
  grid-row: 1/2;
  padding-left: clamp(4px, 3vw, 40px);
  margin-top: calc(clamp(1px, 0.4vw, 5px) * -1);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
footer .footer .util a {
  transition: 0.3s;
}
footer .footer .util a:hover {
  opacity: 0.9;
}
footer .footer .util .share {
  display: flex;
  align-items: center;
  gap: clamp(2px, 1.3vw, 18px);
}
footer .footer .util .share p {
  font-size: clamp(0rem, 1.8vw, 2.4rem);
  line-height: 1.2;
}
footer .footer .util .share ul {
  display: flex;
  gap: clamp(1px, 0.4vw, 6px);
}
footer .footer .util .share ul li a {
  display: grid;
  place-content: center;
  width: clamp(6px, 4.2vw, 56px);
  aspect-ratio: 1/1;
  background: #fff;
  border-radius: clamp(1px, 0.4vw, 5px);
  box-shadow: 0 clamp(1px, 0.4vw, 5px) 0 0 #991e24;
}
footer .footer .util .share ul li.x img {
  width: clamp(3px, 1.9vw, 26px);
}
footer .footer .util .share ul li.fb img {
  width: clamp(3px, 2.3vw, 31px);
}
footer .footer .util .share ul li.line img {
  width: clamp(3px, 2.5vw, 33px);
}
footer .footer .util .btn_usual {
  justify-self: end;
}
footer .footer .util .btn_usual a {
  background: #fff;
  border-radius: clamp(1px, 0.4vw, 5px);
  box-shadow: 0 clamp(1px, 0.4vw, 5px) 0 0 #991e24;
  width: clamp(28px, 20.9vw, 280px);
  height: clamp(6px, 4.2vw, 56px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(3px, 2vw, 27px) clamp(0px, 0.2vw, 3px) clamp(2px, 1.6vw, 22px);
  color: #ff323c;
  font-size: clamp(0rem, 1.8vw, 2.4rem);
}
footer .footer .util .btn_usual a::after {
  content: "";
  width: clamp(2px, 1.8vw, 24px);
  aspect-ratio: 48/46;
  background: url(../img/icon_arrow_12.webp) no-repeat 0 0/100% auto;
}
footer .pagetop {
  position: fixed;
  width: clamp(6px, 4.2vw, 56px);
  aspect-ratio: 1/1;
  right: clamp(3px, 2vw, 27px);
  bottom: clamp(3px, 1.9vw, 25px);
  cursor: pointer;
  z-index: 2;
  opacity: 0;
  transition: 0.3s;
  pointer-events: none;
}
footer .pagetop.show {
  opacity: 1;
  pointer-events: auto;
}
footer .footer_fixed {
  display: none;
}
@media (max-width: 767px) {
  footer {
    padding: 5.6rem 3.75rem 10.5rem;
  }
  footer .seido {
    margin: 0 auto 10rem;
    display: block;
  }
  footer .seido h2 {
    font-size: 3.2rem;
    text-align: center;
    margin-bottom: 2rem;
  }
  footer .seido h2 span {
    font-size: 5.5rem;
  }
  footer .seido .vote {
    display: block;
  }
  footer .seido .vote > * {
    padding: 1.5rem 2.3rem 2.5rem;
    border-radius: 1rem;
  }
  footer .seido .vote > * + * {
    margin-top: 1.6rem;
  }
  footer .seido .vote > * .step h3 {
    font-size: 3.6rem;
  }
  footer .seido .vote > * .step h3 .num {
    font-size: 16rem;
  }
  footer .seido .vote > * .note {
    font-size: 1.6rem;
    padding-right: 0.3em;
  }
  footer .seido .vote > * .detail p {
    font-size: 2.7rem;
  }
  footer .seido .vote > * .detail .box {
    width: 14.7rem;
  }
  footer .seido .vote > *:nth-child(1) .detail .box {
    margin-left: 2rem;
  }
  footer .seido .vote > *:nth-child(2) .step h3 span:last-child {
    padding-right: 0.7em;
  }
  footer .seido .date {
    width: fit-content;
    margin: 2.6rem auto 0;
    text-align: center;
  }
  footer .seido .date p {
    font-size: 3rem;
    width: auto;
  }
  footer .seido .date p:first-child {
    padding-top: 0.5em;
    border-top: solid 2px #fff;
    position: relative;
    letter-spacing: 0.05em;
  }
  footer .seido .date p:first-child::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    border-style: solid;
    border-width: 0 1.2rem 1.8rem 1.2rem;
    border-color: transparent transparent #ffffff;
    translate: -50% -100%;
  }
  footer .seido .date p:first-child::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    border-style: solid;
    border-width: 0 0.96rem 1.44rem 0.96rem;
    border-color: transparent transparent #ff323c;
    translate: -50% -100%;
  }
  footer .seido .date p.advance {
    border-width: 2px;
    margin-top: 0.5em;
    padding: 0.5em 0;
  }
  footer .hirei {
    font-size: 5rem;
    margin: 0 -3.75rem;
    padding: 1.5rem 0 2rem;
    border-top-width: 2rem;
    border-bottom-width: 2px;
  }
  footer .footer {
    display: block;
  }
  footer .footer .logo {
    margin-top: 3.8rem;
    padding: 0;
    border-right: none;
    text-align: center;
  }
  footer .footer .logo img {
    width: 21.2rem;
  }
  footer .footer .logo p {
    margin-top: 1.2em;
  }
  footer .footer .util {
    padding-left: 0;
    margin-top: 3rem;
    display: block;
  }
  footer .footer .util .share {
    display: block;
    text-align: center;
  }
  footer .footer .util .share p {
    font-size: 2.4rem;
    margin-bottom: 2rem;
  }
  footer .footer .util .share ul {
    justify-content: center;
    gap: 2rem;
  }
  footer .footer .util .share ul li a {
    width: 5.6rem;
    border-radius: 0.5rem;
    box-shadow: 0 0.5rem 0 0 #991e24;
  }
  footer .footer .util .share ul li.x img {
    width: 2.5rem;
  }
  footer .footer .util .share ul li.fb img {
    width: 3rem;
  }
  footer .footer .util .share ul li.line img {
    width: 3.2rem;
  }
  footer .footer .util .btn_usual {
    justify-self: auto;
    margin-top: 5.7rem;
  }
  footer .footer .util .btn_usual a {
    border-radius: 0.5rem;
    box-shadow: 0 0.5rem 0 0 #991e24;
    width: 28rem;
    height: 5.6rem;
    padding: 0 2.7rem 0 1.8rem;
    font-size: 2.4rem;
    margin: 0 auto;
  }
  footer .footer .util .btn_usual a::after {
    width: 2rem;
  }
  footer .pagetop {
    width: 4.8rem;
    right: 0.4rem;
    bottom: 7rem;
  }
  footer .footer_fixed {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    display: grid;
    grid-template-columns: 1fr 1fr 5.6rem;
    z-index: 10;
    border-top: solid 2px #ff323c;
  }
  footer .footer_fixed .bokin a,
  footer .footer_fixed .volunteer a,
  footer .footer_fixed .candidate a,
  footer .footer_fixed .policy a {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    height: 5.6rem;
    font-size: 1.5rem;
  }
  footer .footer_fixed .bokin a::before,
  footer .footer_fixed .volunteer a::before,
  footer .footer_fixed .candidate a::before,
  footer .footer_fixed .policy a::before {
    content: "";
    width: 2.4rem;
    aspect-ratio: 1/1;
    background-repeat: no-repeat;
    background-size: 100% auto;
  }
  footer .footer_fixed .bokin a {
    gap: 2rem;
    letter-spacing: 1em;
  }
  footer .footer_fixed .bokin a::before {
    background-image: url(../img/icon_bokin.webp);
  }
  footer .footer_fixed .volunteer {
    border-left: solid 1px #ff323c;
  }
  footer .footer_fixed .volunteer a {
    gap: 1.2rem;
  }
  footer .footer_fixed .volunteer a::before {
    background-image: url(../img/icon_volunteer.webp);
  }
  footer .footer_fixed .candidate a {
    gap: 1.9rem;
  }
  footer .footer_fixed .candidate a::before {
    background-image: url(../img/icon_volunteer.webp);
  }
  footer .footer_fixed .policy {
    border-left: solid 1px #ff323c;
  }
  footer .footer_fixed .policy a {
    gap: 2rem;
    letter-spacing: 1em;
  }
  footer .footer_fixed .policy a::before {
    background-image: url(../img/icon_policy.webp);
  }
  footer .footer_fixed .btn_menu {
    cursor: pointer;
    background: #ff323c;
    color: #fff;
    display: grid;
    place-content: center;
    place-items: center;
    gap: 0.3rem;
  }
  footer .footer_fixed .btn_menu .lines {
    width: 2.4rem;
    height: 1.9rem;
    position: relative;
  }
  footer .footer_fixed .btn_menu .lines span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 0.3rem;
    background: #fff;
    transition: 0.3s;
  }
  footer .footer_fixed .btn_menu .lines span:nth-child(1) {
    top: 0;
  }
  footer .footer_fixed .btn_menu .lines span:nth-child(2) {
    top: 50%;
    margin-top: -1px;
  }
  footer .footer_fixed .btn_menu .lines span:nth-child(3) {
    bottom: 0;
  }
  .js-menuOpen footer .footer_fixed .btn_menu .lines span:nth-child(1) {
    top: 50%;
    transform: rotate(135deg);
  }
  .js-menuOpen footer .footer_fixed .btn_menu .lines span:nth-child(2) {
    opacity: 0;
  }
  .js-menuOpen footer .footer_fixed .btn_menu .lines span:nth-child(3) {
    bottom: auto;
    top: 50%;
    transform: rotate(-135deg);
  }
  footer .footer_fixed .btn_menu p {
    font-size: 0.8rem;
    font-weight: 500;
    text-align: center;
  }
  footer .footer_fixed .btn_menu p span:nth-child(2) {
    display: none;
  }
  .js-menuOpen footer .footer_fixed .btn_menu p span:nth-child(1) {
    display: none;
  }
  .js-menuOpen footer .footer_fixed .btn_menu p span:nth-child(2) {
    display: inline-block;
  }
}

/* modal
------------------------------------------------------*/
.modal_box {
  position: fixed;
  z-index: 8888;
  display: none;
  width: 100%;
  max-width: 628px;
  max-height: 100vh;
  padding: 24px 14px 14px 14px;
}
.modal_box::before {
  content: "";
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 110px 110px 0 0;
  border-color: #e71515 transparent transparent transparent;
  position: absolute;
  left: 0;
  top: 10px;
  z-index: 0;
}
.modal_box .box {
  background: #fff;
  max-width: 600px;
  max-height: 600px;
  height: calc(100vh - 100px);
  margin: 0 auto;
  padding: 55px 65px 70px 65px;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
}
.modal_box .box h3 {
  font-size: 3rem;
  color: #ff323c;
  margin-bottom: 0.7em;
}
.modal_box .box .text {
  flex: 1;
  overflow-y: auto;
  font-weight: 500;
  line-height: 1.8;
}
.modal_box .box .text p + * {
  margin-top: 1em;
}
.modal_box .box .text p.red {
  color: #ff323c;
}
.modal_box .box .text ul.list + *:not(.btn_more) {
  margin-top: 1em;
}
.modal_box .box .text ul.list li {
  padding-left: 15px;
  position: relative;
  font-weight: 700;
  line-height: 1.5;
}
.modal_box .box .text ul.list li + * {
  margin-top: 0.2em;
}
.modal_box .box .text ul.list li::before {
  content: "●";
  font-size: 1.2rem;
  color: #ff323c;
  position: absolute;
  left: 0;
  top: 0.4em;
}
.modal_box .box .text .tbl_party {
  border-top: solid 1px #252723;
  border-collapse: collapse;
  width: 100%;
}
.modal_box .box .text .tbl_party + * {
  margin-top: 1em;
}
.modal_box .box .text .tbl_party th,
.modal_box .box .text .tbl_party td {
  padding: 0.2em;
  border-bottom: solid 1px #252723;
}
.modal_box .box .text .tbl_party th {
  letter-spacing: 1em;
  text-indent: 1em;
  width: 6em;
}
.modal_box .box .text .tbl_party tr.reiwa th {
  letter-spacing: normal;
  text-indent: 0;
}
.modal_box .box .text .box_note {
  border: solid 2px #ff323c;
  padding: 0.8em 1.5em;
}
.modal_box .box .text h4 {
  font-size: 2.2rem;
  font-weight: 700;
  color: #ff323c;
  margin-bottom: 0.7em;
  line-height: 1.3;
}
.modal_box .box .text .btn_more {
  margin-top: 50px;
  text-align: center;
}
.modal_box .box .text .btn_more + .btn_more {
  margin-top: 15px;
}
.modal_box .box .text .btn_more a {
  display: inline-block;
  font-size: 1.5rem;
  padding: 0.3em 2.5em 0.3em 0.8em;
  border: solid 1px #ff323c;
  background: #fff;
  color: #ff323c;
  position: relative;
}
.modal_box .box .text .btn_more a::after {
  content: "";
  width: 13px;
  aspect-ratio: 1/1;
  background: url(../img/icon_plus_red.webp) no-repeat 0 0/100% auto;
  position: absolute;
  right: 0.5em;
  top: 50%;
  transform: translateY(-50%);
}
.modal_box .box::after {
  content: "";
  width: 0px;
  height: 0px;
  border-style: solid;
  border-width: 0 0 110px 110px;
  border-color: transparent transparent #e71515 transparent;
  position: absolute;
  right: -14px;
  bottom: -14px;
}
.modal_box .modal_close {
  width: 160px;
  height: 40px;
  cursor: pointer;
  background: #dcdcdc;
  margin: 25px auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1em;
  font-size: 1.5rem;
  padding-right: 1em;
  transition: 0.3s;
}
.modal_box .modal_close:hover {
  opacity: 0.9;
}
.modal_box .modal_close::before {
  content: "";
  width: 16px;
  aspect-ratio: 1/1;
  background: url(../img/icon_close.webp) no-repeat 0 0/100% auto;
}

.modal_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 7777;
  display: none;
  width: 100%;
  height: 100vh;
  background: #949494;
  mix-blend-mode: multiply;
}

@media (max-width: 767px) {
  .modal_box {
    width: 90vw;
    padding: 2rem 1rem 1rem 1rem;
  }
  .modal_box::before {
    border-width: 8rem 8rem 0 0;
    top: 1rem;
  }
  .modal_box .box {
    max-width: 84vw;
    max-height: 54rem;
    height: calc(100vh - 9.5rem);
    padding: 4rem 2.1rem 5.5rem 2.1rem;
  }
  .modal_box .box h3 {
    font-size: 2.6rem;
    margin-bottom: 0.7em;
  }
  .modal_box .box .text {
    line-height: 1.8;
  }
  .modal_box .box .text ul.list li {
    padding-left: 1.5rem;
  }
  .modal_box .box .text ul.list li::before {
    top: 0.2em;
  }
  .modal_box .box .text .box_note {
    padding: 0.8em 0.8em;
  }
  .modal_box .box .text h4 {
    font-size: 1.8rem;
  }
  .modal_box .box .text .btn_more {
    margin-top: 2.5rem;
  }
  .modal_box .box .text .btn_more + .btn_more {
    margin-top: 1rem;
  }
  .modal_box .box::after {
    border-width: 0 0 8rem 8rem;
    right: -1rem;
    bottom: -1rem;
  }
  .modal_box .modal_close {
    width: 14rem;
    height: 3.6rem;
    margin-top: 2rem;
    font-size: 1.5rem;
  }
  .modal_box .modal_close::before {
    width: 1.4rem;
  }
}