@import url("/css/1.0.0/base.css");

@media screen and (min-width: 834px) {
  header.top {
    position: relative;
    height: 12.6rem;
  }
  header.top .logo {
    width: 18.0rem;
    position: absolute;
    top: 6.8rem;
    left: 11.1rem;
  }
  header.top .menu {
    display: none;
  }
  header.top .media-menu {
    position: absolute;
    top: 6.6rem;
    right: 1.9rem;
    width: 29.9rem;
    height: 6.0rem;
    line-height: 6.0rem;
    text-align: center;
    font-size: 2.0rem;
    color: #fff;
    background: #222;
    border-radius: 1.5rem 1.5rem 1.5rem 0;
    cursor: pointer;
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
    user-select: none;
  }
  header.top .media-menu span {
    display: inline-block;
    transition: transform 0.3s ease;
  }
  header.top .media-menu:hover span {
    transform: scale(1.05);
  }
  header.top .media-menu::before {
    content: '';
    display: block;
    position: absolute;
    bottom: 0.7rem;
    left: 0.8rem;
    width: 0.8rem;
    height: 0.8rem;
    border-left: solid 2px #fff;
    border-bottom: solid 2px #fff;
  }
}
@media screen and (max-width: 833px) {
  header {
    width: 100%;
    height: 19.0rem;
    background: #fff;
  }
  header .logo {
    position: absolute;
    top: 9.0rem;
    left: 5.7rem;
    width: 23.7rem;
    margin: 0 auto;
  }
  header.top .media-menu {
    display: none;
  }
  header.top .menu {
    position: absolute;
    top: round(3.0rem, 1px);
    right: round(3.8rem, 1px);
    width: round(5.3rem, 1px);
    height: round(4.8rem, 1px);
    overflow: hidden;
  }
  header.top .menu span {
    display: block;
    text-indent: 100%;
    white-space: nowrap;
	  overflow:hidden;
  }
  header.top .menu::before,
  header.top .menu::after,
  header.top .menu span::before {
    content: '';
    display: block;
    height: round(0.7rem, 1px);
    width: 100%;
    background: #222;
    position: absolute;
    left: 0;
    border-radius: 10.0rem;
  }
  header.top .menu::before {
    top: 0;
  }
  header.top .menu::after {
    top: 50%;
    transform: translate(0%, -50%);
  }
  header.top .menu span::before {
    bottom: 0;
  }
}

@media screen and (min-width: 834px) {
  body.scrolltop .fixed-menu {
    display: block;
  }
  .fixed-menu.abs {
  }
  .fixed-menu.abs .inner {
    position: absolute;
    border-top: none;
    border-bottom: none;
    box-shadow: none;
    height: 10.0rem;
  }
  .fixed-menu.abs .logo {
    display: none;
    opacity: 0;
  }
  .fixed-menu.abs .media-menu {
    display: none;
    opacity: 0;
  }
  .fixed-menu.abs .gmenu {
    right: 5.0rem;
    top: 0.3rem;
    left: unset;
    justify-content: right;
  }
  .fixed-menu.abs .gmenu ul {
    flex-wrap: nowrap;
    width: fit-content;
  }
  .fixed-menu.abs .gmenu ul li {
    margin-right: 5.4rem;
    margin-left: 0rem;
    min-width: unset;
  }
  .fixed-menu.abs .gmenu ul li a {
    font-size: 1.6rem;
  }
  .fixed-menu.abs .search-block {
    position: relative;
    top: auto;
    right: auto;
    margin-left: 0rem;
  }
  .fixed-menu.abs .search-block .search-form {
    height: 5.3rem;
  }
  .fixed-menu.abs .search-block .button {
    width: 6.0rem;
  }
  .fixed-menu.abs .search-block .input {
    width: 34.0rem;
  }
  .fixed-menu.abs .search-block .input input {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 1920px) {
  .fixed-menu.abs .gmenu ul li {
    width: unset;
  }
}
@media screen and (max-width: 1500px) and (min-width: 1001px) {
}
@media screen and (max-width: 1000px) and (min-width: 834px) {
}
@media screen and (max-width: 833px) {
  .fixed-menu {
    top: 102.1rem;
  }
  .fixed-menu.abs .inner {
    position: absolute;
    height: 11.3rem;
  }
  .fixed-menu.abs .logo {
    display: none;
  }
  .fixed-menu.abs .menu {
    display: none;
  }

  .fixed-menu.abs .gmenu {
    position: absolute;
    width: 100%;
    height: 0;
    bottom: 0;
    z-index: 1;
  }
  .fixed-menu.abs .search-block {
    top: auto;
    bottom: 0;
    left: 0;
    width: 37.5rem;
    height: 0;
  }
  .fixed-menu.abs .search-block .toggle {
    position: absolute;
    top: -5.5rem;
    right: unset;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 5.0rem;
    text-align: center;
    width: 100%;
    height: 11.3rem;
    top: -11.3rem;
    left: 0;
    transform: none;
    padding-top: 3.5rem;
  }
  .fixed-menu.abs .search-block .toggle img {
    width: 5.0rem;
    height: auto;
  }
  .fixed-menu.abs .search-block .search-form {
    bottom: -17.0rem;
  }
  .fixed-menu.abs .search-block .search-form::before {
    left: 17.4rem;
  }
  .fixed-menu.abs .media-menu {
    top: 0;
    right: 0;
    width: 37.5rem;
    height: 11.0rem;
    line-height: 11.0rem;
    font-size: 2.9rem;
    font-weight: bold;
    font-family: TsukuGoPro-B-HelveticaNowTextMedium;
    color: #222;
    background: #fff;
    border-radius: 0;
    cursor: pointer;
    user-select: none;
    border-left: solid 1px #ccc;
  }
  .fixed-menu.abs .media-menu::before {
    content: '';
    display: block;
    position: absolute;
    bottom: auto;
    top: 2.0rem;
    left: 1.6rem;
    width: 1.2rem;
    height: 1.2rem;
    border-right: none;
    border-bottom: none;
    border-left: solid 3px #222;
    border-top: solid 3px #222;
  }

  body.hm-open .fixed-menu.abs .inner {
    position: fixed;
    height: 10.6rem;
  }
  body.hm-open .fixed-menu.abs .logo {
    display: block;
  }
  body.hm-open .fixed-menu.abs .menu {
    display: block;
  }

  body.hm-open .fixed-menu.abs .gmenu {
    position: relative;
    height: unset;
    bottom: unset;
    z-index: unset;
  }
  body.hm-open .fixed-menu.abs .search-block {
    top: 2.8rem;
    bottom: unset;
    left: unset;
    height: 5.0rem;
    width: 100%;
  }
  body.hm-open .fixed-menu.abs .search-block .toggle {
    position: absolute;
    top: 0rem;
    right: 46.4rem;
    left: unset;
    transform: none;
    width: 5.0rem;
    padding-top: 0rem;
  }
  body.hm-open .fixed-menu.abs .search-block .search-form {
    bottom: -19.5rem;
  }
  body.hm-open .fixed-menu.abs .search-block .search-form::before {
    left: 24.9rem;
  }
  body.hm-open .fixed-menu.abs .media-menu {
    position: absolute;
    top: 1.5rem;
    right: 15.9rem;
    width: 25.5rem;
    height: 7.1rem;
    line-height: 7.1rem;
    text-align: center;
    font-size: 2.4rem;
    color: #fff;
    background: #222;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    cursor: pointer;
    user-select: none;
    border-left: none;
    font-family: TsukuGoPr5-M;
    font-weight: normal;
  }
  body.hm-open .fixed-menu.abs .media-menu::before {
    content: '';
    display: block;
    position: absolute;
    top: unset;
    bottom: 0.9rem;
    left: unset;
    right: 0.9rem;
    width: 1.2rem;
    height: 1.2rem;
    border-left: none;
    border-top: none;
    border-right: solid 0.3rem #fff;
    border-bottom: solid 0.3rem #fff;
  }
}

section.home-mv {
  overflow: hidden;
}
@keyframes anim-maku-open {
  0% {
    transform: translate(0, -100%);
  }
  100% {
    transform: translate(0, 0);
  }
}
@keyframes anim-maku-close {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(0, -100%);
  }
}

@media screen and (min-width: 834px) {
  section.home-mv {
    margin-bottom: 10.0rem;
    padding-top: 2.0rem;
    padding-bottom: 2.5rem;
  }
  section.home-mv .container {
    width: 100%;
    max-width: 100%;
    position: relative;
    padding: 0;
    height: 80.0rem;
    overflow: hidden;
  }
  section.home-mv .maku {
    width: 100%;
    height: 80.0rem;
    position: absolute;
    background: #008000;
    z-index: 3;
  }
  section.home-mv.anim01 .maku {
    transform: translate(0, calc(-100% - 1px));
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-close;
  }
  section.home-mv.anim02 .maku {
    transform: translate(0, 0);
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-open;
  }
  section.home-mv.anim03 .maku {
    transform: translate(0, calc(-100% - 1px));
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-close;
  }

  section.home-mv .animation-wrap {
    width: 100%;
    height: 84.5rem;
    position: absolute;
    background: #fff;
    z-index: 2;
  }
  section.home-mv.anim03 .animation-wrap {
    display: none;
  }
  section.home-mv .animation {
    width: 100%;
    height: 100%;
    position: relative;
  }
  section.home-mv .animation .image {
    position: absolute;
    width: 191.5rem;
    top: 3.3rem;
    left: calc(50% - 125.3rem);
  }
  section.home-mv .animation .message01 {
    position: absolute;
    top: 28.8rem;
    left: calc(50% + -6.0rem);
    width: 43.6rem;
    aspect-ratio: 426 / 107;
    opacity: 0;
    transform: translate(0, 4.0rem);
    transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity linear 0.7s;
    transition-delay: 0.25s;
  }
  section.home-mv.anim01 .animation .message01 {
    transform: translate(0, 0);
    opacity: 1;
  }
  section.home-mv .animation .message02 {
    position: absolute;
    top: 43.1rem;
    left: calc(50% + -1.4rem);
    width: 33.1rem;
    aspect-ratio: 331 / 108;
    opacity: 0;
    transform: translate(0, 4.0rem);
    transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity linear 0.7s;
    transition-delay: 0.45s;
  }
  section.home-mv.anim01 .animation .message02 {
    transform: translate(0, 0);
    opacity: 1;
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - 29.7rem) 3.3rem/191.5rem auto no-repeat;
    width: 100%;
    height: 84.5rem;
    position: absolute;
    z-index: 1;
  }
  section.home-mv .home-mv-swiper {
    max-width: calc(60.0rem + 3.0rem);
    padding-top: 11.0rem;
    margin: 0 auto;
    overflow: visible;
    position: relative;
  }
  section.home-mv .home-mv-swiper .swiper-slide {
    padding: 0 1.5rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    cursor: pointer;
    user-select: none;
    display: block;
    width: 60.0rem;
    aspect-ratio: 1/1;
    text-decoration: none;
    border-radius: 1.8rem 1.8rem 0rem 1.8rem;
    overflow: hidden;
    position: relative;
    border: solid 1px #999;
    background: #999;
    transition: box-shadow 200ms 0s ease;
  }
  section.home-mv .home-mv-swiper .swiper-slide a:hover,
  section.home-mv .home-mv-swiper .swiper-slide span:hover {
    box-shadow: -0.4rem -0.3rem 0 0 #999;
  }
  section.home-mv .home-mv-swiper .swiper-slide a::before,
  section.home-mv .home-mv-swiper .swiper-slide span::before {
    content: "";
    display: block;
    width: 2.0rem;
    height: 2.0rem;
    border-right: solid 0.5rem #000;
    border-bottom: solid 0.5rem #000;
    position: absolute;
    bottom: 2.2rem;
    right: 1.8rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide img {
    width: 100%;
    height: auto;
  }
  section.home-mv .home-mv-swiper .swiper-pagination {
    position: absolute;
    bottom: -6.4rem;
    left: 2.7rem;
    width: 100%;
  }
  section.home-mv .home-mv-swiper .swiper-button {
    bottom: -4.3rem;
  }
  section.home-mv .c-swiper-block .swiper-button-prev {
    right: 13.6rem;
  }
  section.home-mv .c-swiper-block .swiper-button-next {
    right: 0rem;
  }
}
@media screen and (min-width: 1441px) and (min-height: 1051px) {
  .fixed-menu {
    top: 97.1rem;
  }
  section.home-mv .container {
    height: 80.0rem;
  }
  section.home-mv .maku {
    height: 80.0rem;
  }
  section.home-mv .animation .image {
    width: 191.5rem;
    top: 3.3rem;
    left: calc(50% - 125.3rem);
  }
  section.home-mv .animation .message01 {
    top: 28.8rem;
    left: calc(50% + -6.0rem);
    width: 43.6rem;
  }
  section.home-mv .animation .message02 {
    top: 43.1rem;
    left: calc(50% + -1.4rem);
    width: 33.1rem;
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - 29.7rem) 3.3rem/191.5rem auto no-repeat;
  }
  section.home-mv .home-mv-swiper {
    max-width: calc(60.0rem + 3.0rem);
    padding-top: 11.0rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    width: 60.0rem;
  }
  section.home-mv .home-mv-swiper .swiper-pagination {
    bottom: -6.4rem;
    left: 2.7rem;
  }
  section.home-mv .home-mv-swiper .swiper-button {
    bottom: -4.3rem;
  }
  section.home-mv .c-swiper-block .swiper-button-prev {
    right: 13.6rem;
  }
  section.home-mv .c-swiper-block .swiper-button-next {
    right: 0rem;
  }
}
@media screen and (min-width: 1441px) and (max-height: 1050px) and (min-height: 921px) {
  .fixed-menu {
    top: calc(72.1rem * 1.17);
  }
  section.home-mv .container {
    height: calc(55.0rem * 1.17);
  }
  section.home-mv .maku {
    height: calc(55.0rem * 1.17);
  }
  section.home-mv .animation .image {
    top: calc(2.6rem * 1.17);
    left: calc(50% - (88.5rem * 1.17));
    width: calc(131.0rem * 1.17);
  }
  section.home-mv .animation .message01 {
    top: calc(20.1rem * 1.17);
    left: calc(50% - (6.9rem * 1.17));
    width: calc(29.8rem * 1.17);
  }
  section.home-mv .animation .message02 {
    width: calc(22.6rem * 1.17);
    top: calc(29.8rem * 1.17);
    left: calc(50% - (3.7rem * 1.17));
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - (23.6rem * 1.17)) calc(2.8rem * 1.17)/calc(130.2rem * 1.17) auto no-repeat;
  }
  section.home-mv .home-mv-swiper {
    max-width: calc((42.0rem * 1.17) + 3.0rem);
    padding-top: calc(4.1rem * 1.17);
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    width: calc(42.0rem * 1.17);
  }
  section.home-mv .home-mv-swiper .swiper-pagination {
    bottom: calc(-7.0rem * 1.17);
    left: calc(-16.5rem * 1.17);
  }
  section.home-mv .home-mv-swiper .swiper-button {
    bottom: calc(-5.0rem * 1.17);
  }
  section.home-mv .c-swiper-block .swiper-button-prev {
    right: calc(11.2rem * 1.17);
  }
  section.home-mv .c-swiper-block .swiper-button-next {
    right: calc(3.6rem * 1.17);
  }
}
@media screen and (min-width: 1441px) and (max-height: 920px) {
  .fixed-menu {
    top: 72.1rem;
  }
  section.home-mv .container {
    height: 55.0rem;
  }
  section.home-mv .maku {
    height: 55.0rem;
  }
  section.home-mv .animation .image {
    top: 2.6rem;
    left: calc(50% - 88.5rem);
    width: 131.0rem;
  }
  section.home-mv .animation .message01 {
    top: 20.1rem;
    left: calc(50% + -6.9rem);
    width: 29.8rem;
  }
  section.home-mv .animation .message02 {
    width: 22.6rem;
    top: 29.8rem;
    left: calc(50% + -3.7rem);
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - 23.6rem) 2.8rem/130.2rem auto no-repeat;
  }
  section.home-mv .home-mv-swiper {
    max-width: calc(42.0rem + 3.0rem);
    padding-top: 4.1rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    width: 42.0rem;
  }
  section.home-mv .home-mv-swiper .swiper-pagination {
    bottom: -7.0rem;
    left: -16.5rem;
  }
  section.home-mv .home-mv-swiper .swiper-button {
    bottom: -5.0rem;
  }
  section.home-mv .c-swiper-block .swiper-button-prev {
    right: 11.2rem;
  }
  section.home-mv .c-swiper-block .swiper-button-next {
    right: 3.6rem;
  }
}
@media screen and (max-width: 1440px) and (min-width: 834px) {
  .fixed-menu {
    top: 72.1rem;
  }
  section.home-mv .container {
    height: 55.0rem;
  }
  section.home-mv .maku {
    height: 55.0rem;
  }
  section.home-mv .animation .image {
    top: 2.6rem;
    left: calc(50% - 88.5rem);
    width: 131.0rem;
  }
  section.home-mv .animation .message01 {
    top: 20.1rem;
    left: calc(50% + -6.9rem);
    width: 29.8rem;
  }
  section.home-mv .animation .message02 {
    width: 22.6rem;
    top: 29.8rem;
    left: calc(50% + -3.7rem);
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - 23.6rem) 2.8rem/130.2rem auto no-repeat;
  }
  section.home-mv .home-mv-swiper {
    max-width: calc(42.0rem + 3.0rem);
    padding-top: 4.1rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    width: 42.0rem;
  }
  section.home-mv .home-mv-swiper .swiper-pagination {
    bottom: -7.0rem;
    left: -16.5rem;
  }
  section.home-mv .home-mv-swiper .swiper-button {
    bottom: -5.0rem;
  }
  section.home-mv .c-swiper-block .swiper-button-prev {
    right: 11.2rem;
  }
  section.home-mv .c-swiper-block .swiper-button-next {
    right: 3.6rem;
  }
}
@media screen and (max-width: 833px) {
  section.home-mv {
    height: 87.0rem;
    overflow: hidden;
    margin-bottom: 10.0rem;
  }
  section.home-mv .container {
    width: 100%;
    max-width: 100%;
    position: relative;
    padding: 0;
    height: 87.0rem;
    overflow: hidden;
    margin-top: -1px;
  }
  section.home-mv .maku {
    width: 100%;
    height: 87.0rem;
    position: absolute;
    background: #008000;
    z-index: 3;
  }
  section.home-mv.anim01 .maku {
    transform: translate(0, -100%);
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-close;
  }
  section.home-mv.anim02 .maku {
    transform: translate(0, 0);
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-open;
  }
  section.home-mv.anim03 .maku {
    transform: translate(0, -100%);
    animation: 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0s anim-maku-close;
  }
  section.home-mv .animation-wrap {
    width: 100%;
    height: 87.0rem;
    position: absolute;
    background: #fff;
    z-index: 2;
  }
  section.home-mv.anim03 .animation-wrap {
    display: none;
  }
  section.home-mv .animation {
    width: 100%;
    height: 100%;
    position: relative;
  }
  section.home-mv .animation .image {
    width: 109.9rem;
    height: 117.0rem;
    aspect-ratio: 1925 / 725;
    position: absolute;
    top: 35.2rem;
    left: calc(50% - 67.8rem);
  }
  section.home-mv .animation .message01 {
    width: 47.5rem;
    aspect-ratio: 436 / 107;
    position: absolute;
    top: 11.9rem;
    left: calc(50% + -32.4rem);
    opacity: 0;
    transform: translate(0, 4.0rem);
    transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity linear 0.7s;
    transition-delay: 0.25s;
  }
  section.home-mv.anim01 .animation .message01 {
    transform: translate(0, 0);
    opacity: 1;
  }
  section.home-mv .animation .message02 {
    width: 47.6rem;
    aspect-ratio: 331 / 108;
    position: absolute;
    top: 24.2rem;
    left: calc(50% + -32.5rem);
    opacity: 0;
    transform: translate(0, 4.0rem);
    transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 1s, opacity linear 0.7s;
    transition-delay: 0.45s;
  }
  section.home-mv.anim01 .animation .message02 {
    transform: translate(0, 0);
    opacity: 1;
  }
  section.home-mv .home-mv-swiper-wrap {
    background: #fff url(/img/home_mv_slider_bg.webp) calc(50% - 12.7rem) 35.2rem/109.9rem auto no-repeat;
    width: 100%;
    height: 84.5rem;
    position: absolute;
    z-index: 1;
  }
  section.home-mv .home-mv-swiper {
    max-width: 90%;
    margin: 0 auto;
    overflow: visible;
    padding-top: 5.0rem;
    position: relative;
  }
  section.home-mv .home-mv-swiper .swiper-slide {
    padding: 0 1.0rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide a,
  section.home-mv .home-mv-swiper .swiper-slide span {
    display: block;
    text-decoration: none;
    border-radius: 1.8rem 1.8rem 0rem 1.8rem;
    overflow: hidden;
    position: relative;
    border: solid 1px #999;
    background: #999;
  }
  section.home-mv .home-mv-swiper .swiper-slide a::before,
  section.home-mv .home-mv-swiper .swiper-slide span::before {
    content: "";
    display: block;
    width: 2.0rem;
    height: 2.0rem;
    border-right: solid 0.5rem #000;
    border-bottom: solid 0.5rem #000;
    position: absolute;
    bottom: 2.2rem;
    right: 1.8rem;
  }
  section.home-mv .home-mv-swiper .swiper-slide img {
    width: 100%;
    height: auto;
  }
  section.home-mv .c-swiper-block .swiper-pagination {
    left: 1.0rem;
    bottom: -6.3rem;
    text-align: center;
    margin-left: -1.1rem;
  }
  section .c-swiper-block .swiper-pagination .swiper-pagination-bullet {
    width: 1.8rem;
    height: 1.8rem;
    margin: 0 1.1rem;
  }
  section.home-mv .c-swiper-block .swiper-button {
    display: none;
  }
}

section.home-navi {
}
@keyframes anim-item01 {
   0% {
     opacity: 0;
     transform: translateY(2.0rem);
   }
   100% {
     opacity: 1;
     transform: translateY(0);
   }
}
@keyframes anim-item02 {
   0% {
     opacity: 0;
     transform: translateY(2.0rem);
   }
   100% {
     opacity: 1;
     transform: translateY(0);
   }
}
@keyframes anim-item03 {
   0% {
     opacity: 0;
     transform: translateY(-2.0rem);
   }
   100% {
     opacity: 1;
     transform: translateY(0);
   }
}
@keyframes anim-item04 {
   0% {
     opacity: 0;
     transform: translateY(2.0rem);
   }
   100% {
     opacity: 1;
     transform: translateY(0);
   }
}
@keyframes anim-item05 {
   0% {
     opacity: 0;
     transform: translateY(-2.0rem);
   }
   100% {
     opacity: 1;
     transform: translateY(0);
   }
}
section.home-navi.anim .item01 a {
  animation-name: anim-item01;
  animation-delay: 0;
  animation-duration: 0.33s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
section.home-navi.anim .item02 a {
  animation-name: anim-item02;
  animation-delay: 0.33s;
  animation-duration: 0.33s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
section.home-navi.anim .item03 a {
  animation-name: anim-item03;
  animation-delay: 0.66s;
  animation-duration: 0.33s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
section.home-navi.anim .item04 a {
  animation-name: anim-item04;
  animation-delay: 0.66s;
  animation-duration: 0.33s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}
section.home-navi.anim .item05 a {
  animation-name: anim-item05;
  animation-delay: 0.33s;
  animation-duration: 0.33s;
  animation-timing-function: ease-out;
  animation-fill-mode: forwards;
}

@media screen and (min-width: 834px) {
  section.home-navi .container {
    padding: 0;
    position: relative;
    height: 150.0rem;
  }
  section.home-navi .wrap {
    position: relative;
    max-width: 155.0rem;
    margin: 0 auto;
  }
  section.home-navi .wrap::before {
    content: '';
    width: 110.4rem;
    height: 42.0rem;
    background: url(/img/home_navi_bg_00.webp) 0 0/100% auto no-repeat;
    position: absolute;
    top: 62.5rem;
    right: -23.2rem;
    z-index: 0;
  }
  section.home-navi .head {
    position: absolute;
    top: 41.1rem;
    left: calc(50% - 60.1rem);
  }
  section.home-navi .head h2 {
    font-size: 2.8rem;
    font-weight: bold;
    font-family: TsukuGoPro-B-HelveticaNowTextMedium;
    letter-spacing: -0.02em;
    margin-bottom: 5.1rem;
  }
  section.home-navi .head h2 b {
    font-size: 3.4rem;
  }
  section.home-navi .head .lead {
    font-size: 1.8rem;
    line-height: 1.7;
  }
  section.home-navi ul {
    width: 100%;
    height: 100%;
    padding-top: 20.0rem;
  }
  section.home-navi ul li {
    display: block;
    position: absolute;
    width: 100%;
    z-index: 0;
  }
  section.home-navi ul li a {
    position: absolute;
    opacity: 0;
    aspect-ratio: 1/1;
    border-radius: 1.5rem 1.5rem 0rem 1.5rem;
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
    color: #fff;
    z-index: 1;
    overflow: hidden;
    display: block;
    text-decoration: none;
    display: flex;
    justify-content: left;
    align-items: center;
    transition: box-shadow 200ms 0s ease,
                background 200ms 0s ease;
  }
  section.home-navi ul li a::before {
    content: "";
    display: block;
    width: 1.0rem;
    height: 1.0rem;
    border-right: solid 0.2rem #fff;
    border-bottom: solid 0.2rem #fff;
    position: absolute;
    bottom: 1.1rem;
    right: 1.1rem;
  }
  section.home-navi ul li.item04 a::before {
    border-color: #000;
  }
  section.home-navi ul li a:hover {
    box-shadow: -0.9rem -0.8rem 0 0 #999;
  }

  section.home-navi .inner {
    padding: 0 2.7rem;
    padding-bottom: 0.7rem;
    color: #fff;
  }
  section.home-navi .title {
    font-size: 2.9rem;
    margin-top: 0.6rem;
    margin-bottom: 1.5rem;
  }
  section.home-navi .text {
    line-height: 1.7;
  }
  section.home-navi .item01 .inner {
    padding: 0 4.2rem;
    padding-bottom: 2.0rem;
  }
  section.home-navi .item01 .icon {
    margin-left: 1.0rem;
    width: 3.5rem;
  }
  section.home-navi .item01 .title {
    font-size: 3.5rem;
  }
  section.home-navi .item02 .inner {
    padding-right: 1.0rem;
  }
  section.home-navi .item02 .icon {
    width: 5.1rem;
  }
  section.home-navi .item03 .inner {
    padding: 0 4.0rem;
    padding-top: 0.3rem;
  }
  section.home-navi .item03 .icon {
    width: 5.6rem;
  }
  section.home-navi .item03 .title {
    font-size: 3.2rem;
    margin-top: 1.3rem;
    margin-bottom: 2.1rem;
  }
  section.home-navi .item04 .inner {
    padding-top: 0.5rem;
    color: #222;
  }
  section.home-navi .item04 .icon {
    width: 4.2rem;
  }
  section.home-navi .item04 .title {
    margin-bottom: 1.7rem;
  }
  section.home-navi .item04 .text {
    letter-spacing: -0.1em;
  }
  section.home-navi .item05 .inner {
    padding-right: 4.0rem;
    padding-bottom: 1.1rem;
  }
  section.home-navi .item05 .icon {
    width: 2.6rem;
    margin-left: 0.5rem;
  }
  section.home-navi .item05 .title {
    margin-top: 0.3rem;
    margin-bottom: 1.3rem;
  }
  section.home-navi .item05 .text {
    letter-spacing: -0.05em;
  }

  section.home-navi li a::after {
    background: url(/img/home_navi_bg_white.webp) 0 0/100% auto no-repeat;
    display: block;
    position: absolute;
    z-index: 0;
    opacity: 0.07;
    width: 110.4rem;
    height: 42.0rem;
  }

  section.home-navi .item01 a {
    background: #008000;
    width: 60.0rem;
    top: 0.5rem;
    right: 7.0rem;
  }
  section.home-navi ul li.item01 a:hover {
    background-color: #076906;
  }
  section.home-navi .item01 a::after {
    content: '';
    top: 42.0rem;
    left: -20.2rem;
  }
  section.home-navi .item02 a {
    background: #222;
    width: 30.6rem;
    top: 55.5rem;
    right: 117.9rem;
  }
  section.home-navi ul li.item02 a:hover {
    background-color: #000;
  }
  section.home-navi .item03 a {
    background: #008000;
    width: 40.8rem;
    top: 65.5rem;
    right: 72.2rem;
  }
  section.home-navi ul li.item03 a:hover {
    background-color: #076906;
  }
  section.home-navi .item03 a::after {
    content: '';
    top: -23.0rem;
    left: 25.5rem;
  }
  section.home-navi .item04 a {
    background: #d5d5d5;
    width: 30.5rem;
    top: 80.9rem;
    right: 36.5rem;
    border: solid 0.1rem #d5d5d5;
  }
  section.home-navi ul li.item04 a:hover {
    background-color: #fff;
  }
  section.home-navi .item04 a::after {
    content: '';
    background: url(/img/home_navi_bg_black.webp) 0 0/100% auto no-repeat;
    top: -38.3rem;
    left: -20.5rem;
  }
  section.home-navi .item05 a {
    background: #606060;
    width: 30.6rem;
    top: 65.5rem;
    right: 0.6rem;
  }
  section.home-navi ul li.item05 a:hover {
    background-color: #454545;
  }
  section.home-navi .item05 a::after {
    content: '';
    background: url(/img/home_navi_bg_black.webp) 0 0/100% auto no-repeat;
    top: -23.2rem;
    left: -56.3rem;
  }
}
@media screen and (max-width: 1550px) and (min-width: 834px) {
  section.home-navi .container {
    height: calc((100vw / 155) * 150.0);
  }
  section.home-navi {
    background-position: calc(50% + (((100vw / 155) * 45.3))) calc((100vw / 155) * 62.5);
    background-size: calc((100vw / 155) * 110.4) auto;
  }
  section.home-navi .wrap::before {
    width: calc((100vw / 155) * 110.4);
    height: calc((100vw / 155) * 42.0);
    top: calc((100vw / 155) * 62.5);
    right: calc((100vw / 155) * -23.2);
  }
  section.home-navi ul {
    padding-top: calc((100vw / 155) * 20.0);
  }
  section.home-navi li a::after {
    width: calc((100vw / 155) * 110.4);
    height: calc((100vw / 155) * 42.0);
  }
  section.home-navi .head {
    top: calc((100vw / 155) * 41.1);
  }
  section.home-navi .item01 a {
    width: calc((100vw / 155) * 60.0);
    top: calc((100vw / 155) * 0.5);
    right: calc((100vw / 155) * 7.0);
  }
  section.home-navi .item01 a::after {
    top: calc((100vw / 155) * 42.0);
    left: calc((100vw / 155) * -20.2);
  }
  section.home-navi .item02 a {
    width: calc((100vw / 155) * 30.6);
    top: calc((100vw / 155) * 55.5);
    right: calc((100vw / 155) * 117.9);
  }
  section.home-navi .item03 a {
    width: calc((100vw / 155) * 40.8);
    top: calc((100vw / 155) * 65.5);
    right: calc((100vw / 155) * 72.2);
  }
  section.home-navi .item03 a::after {
    top: calc((100vw / 155) * -23.0);
    left: calc((100vw / 155) * 25.5);
  }
  section.home-navi .item04 a {
    width: calc((100vw / 155) * 30.5);
    top: calc((100vw / 155) * 80.9);
    right: calc((100vw / 155) * 36.5);
  }
  section.home-navi .item04 a::after {
    top: calc((100vw / 155) * -38.3);
    left: calc((100vw / 155) * -20.5);
  }
  section.home-navi .item05 a {
    width: calc((100vw / 155) * 30.6);
    top: calc((100vw / 155) * 65.5);
    right: calc((100vw / 155) * 0.6);
  }
  section.home-navi .item05 a::after {
    top: calc((100vw / 155) * -23.2);
    left: calc((100vw / 155) * -56.3);
  }
}
@media screen and (max-width: 833px) {
  section.home-navi .container {
    padding: 0;
    padding-top: 15.6rem;
    height: auto;
  }
  section.home-navi .wrap {
    position: relative;
  }
  section.home-navi .wrap::before {
    content: '';
    width: 90.0rem;
    aspect-ratio: 1104 / 420;
    background: url(/img/home_navi_bg_00.webp) 0 0/100% auto no-repeat;
    position: absolute;
    top: 107.1rem;
    right: -22.5rem;
    z-index: 0;
  }
  section.home-navi .head {
    padding: 0 2.9rem;
  }
  section.home-navi .head h2 {
    font-size: 5.2rem;
    font-weight: bold;
    font-family: TsukuGoPro-B-HelveticaNowTextMedium;
    line-height: 1.5;
    margin-bottom: 7.7rem;
  }
  section.home-navi .head .lead {
    font-size: 3.3rem;
    line-height: 1.6;
    margin-bottom: 9.7rem;
  }

  section.home-navi ul {
  }
  section.home-navi ul li {
    display: block;
    width: 100%;
  }
  section.home-navi ul li a {
    opacity: 0;
    aspect-ratio: 1/1;
    border-radius: 1.5rem 1.5rem 0rem 1.5rem;
    box-shadow: -0.8rem -0.6rem 0 0 #ccc;
    color: #fff;
    z-index: 1;
    overflow: hidden;
    display: block;
    text-decoration: none;
    display: flex;
    justify-content: left;
    align-items: center;
    position: relative;
  }
  section.home-navi ul li a::before {
    content: "";
    display: block;
    width: 1.3rem;
    height: 1.3rem;
    border-right: solid 0.3rem #fff;
    border-bottom: solid 0.3rem #fff;
    position: absolute;
    bottom: 2.2rem;
    right: 2.0rem;
  }
  section.home-navi .icon {
    width: 10.0rem;
  }
  section.home-navi .item01 a::after {
    content: '';
    background: url(/img/home_navi_bg_white.webp) 0 0/100% auto no-repeat;
    display: block;
    position: absolute;
    opacity: 0.07;
    width: 90.0rem;
    aspect-ratio: 1104 / 420;
    top: 48.7rem;
    right: -23.8rem;
    z-index: 0;
  }
  section.home-navi .item01 a {
    background: #008000;
    width: 60.0rem;
    margin-right: 1.3rem;
    margin-left: auto;
    margin-bottom: 4.1rem;
  }
  section.home-navi .item02 a {
    background: #222;
    width: 44.0rem;
    margin-right: auto;
    margin-left: 3.1rem;
    margin-bottom: 4.3rem;
  }
  section.home-navi .item03 a {
    background: #008000;
    width: 50.8rem;
    margin-right: auto;
    margin-left: 8.0rem;
    margin-bottom: 5.0rem;
  }
  section.home-navi .item04 a {
    background: #d5d5d5;
    width: 42.0rem;
    margin-right: 5.7rem;
    margin-left: auto;
    margin-bottom: 4.5rem;
  }
  section.home-navi .item05 a {
    background: #606060;
    width: 44.0rem;
    margin-right: auto;
    margin-left: 9.3rem;
  }


  section.home-navi .inner {
    padding: 0 4.2rem;
    padding-bottom: 1.8rem;
    color: #fff;
  }
  section.home-navi .title {
    font-size: 4.0rem;
    margin-top: 0.9rem;
    margin-bottom: 1.9rem;
  }
  section.home-navi .text {
    line-height: 1.7;
    font-size: 3.0rem;
  }
  section.home-navi .item01 .inner {
  }
  section.home-navi .item01 .icon {
    margin-left: 0.4rem;
    width: 5.9rem;
  }
  section.home-navi .item01 .title {
    font-size: 5.0rem;
  }
  section.home-navi .item02 .inner {
    padding-top: 2.0rem;
  }
  section.home-navi .item02 .icon {
    width: 9.5rem;
  }
  section.home-navi .item02 .title {
    padding-top: 0.5rem;
  }
  section.home-navi .item03 .inner {
    padding: 0 4.6rem;
  }
  section.home-navi .item03 .icon {
    width: 8.5rem;
    margin-left: 0.2rem;
  }
  section.home-navi .item03 .title {
    margin-top: 1.3rem;
    margin-bottom: 2.1rem;
  }
  section.home-navi .item04 .inner {
    padding: 0 3.5rem;
    color: #222;
  }
  section.home-navi .item04 .icon {
    width: 7.2rem;
  }
  section.home-navi .item04 .title {
    margin-bottom: 1.7rem;
  }
  section.home-navi .item05 .inner {
    padding: 0 3.6rem;
    padding-top: 0.2rem;
  }
  section.home-navi .item05 .icon {
    width: 4.4rem;
  }
  section.home-navi .item05 .title {
    margin-top: 1.3rem;
    margin-bottom: 1.0rem;
  }
  section.home-navi .item05 .text {
    letter-spacing: -0.05em;
  }
}

section.home-update {
  overflow: hidden;
}
@media screen and (min-width: 834px) {
  section.home-update .container {
    padding-top: 5.7rem;
    position: relative;
  }
  section.home-update .container {
    padding-bottom: 0rem;
  }
  section.home-update .home-update-swiper-wrap {
    overflow: visible;
    max-width: 176.8rem;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    position: relative;
    margin-top: 8.1rem;
  }
  section.home-update .home-update-swiper {
    overflow: visible;
    max-width: 43.6rem;
    margin: 0 auto 0 0;
    width: 100%;
    height: 100%;
    padding-left: 0.4rem;
    padding-right: 5.1rem;
    padding-bottom: 6.5rem;
  }
  section.home-update .home-update-swiper .swiper-slide {
    padding: 0 5.0rem 5.0rem 0;
    width: 33.0rem;
    aspect-ratio: 1/1;
  }
  section.home-update .home-update-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    overflow: hidden;
    border: solid 1px #fff;
    position: relative;
    background: #f3f3f3;
    transition: box-shadow 200ms 0s ease,
                border 200ms 0s ease;
  }
  section.home-update .home-update-swiper .swiper-slide a::before {
    content: "";
    display: block;
    border-right: solid 0.2rem #666;
    border-bottom: solid 0.2rem #666;
    width: 0.9rem;
    height: 0.9rem;
    position: absolute;
    bottom: 1.0rem;
    right: 1.0rem;
  }
  section.home-update .home-update-swiper .swiper-slide.black a::before {
    border-right: solid 0.2rem #fff;
    border-bottom: solid 0.2rem #fff;
  }
  section.home-update .home-update-swiper .swiper-slide.black a {
    color: #fff;
    background: #222;
  }
  section.home-update .home-update-swiper a:hover {
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
    border: solid 1px #666;
  }
  section.home-update .home-update-swiper .image {
    width: 100%;
    aspect-ratio: 330 / 185;
  }
  section.home-update .home-update-swiper .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  section.home-update .home-update-swiper .text {
    padding: 0 1.6rem;
    margin-top: 1.0rem;
    line-height: 1.7;
    font-size: 1.7rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }
  section.home-update .home-update-swiper .tags {
    position: absolute;
    bottom: 1.0rem;
    left: 1.8rem;
    font-size: 1.4rem;
  }
  section.home-update h2.c-section-title {
    margin-bottom: 4.7rem;
  }
}
@media screen and (max-width: 833px) {
  section.home-update .container {
    padding-top: 32.8rem;
    padding-bottom: 22.1rem;
    position: relative;
  }
  section.home-update .c-button-more {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0%);
  }
  section.home-update .c-section-lead {
    margin-bottom: 9.5rem;
  }
  section.home-update .home-update-swiper-wrap {
    overflow: visible;
    width: 59.0rem;
    margin: 0 auto;
  }
  section.home-update .home-update-swiper .swiper-slide {
    width: 100%;
    height: 55.1rem;
    padding: 0 2.0rem;
    margin-bottom: 1.8rem;
  }
  section.home-update .home-update-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    overflow: hidden;
    border: solid 1px #fff;
    position: relative;
  }
  section.home-update .home-update-swiper .swiper-slide a::before {
    content: "";
    display: block;
    border-right: solid 0.4rem #666;
    border-bottom: solid 0.4rem #666;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
  }
  section.home-update .home-update-swiper .swiper-slide.black a::before {
    border-right: solid 0.4rem #fff;
    border-bottom: solid 0.4rem #fff;
  }
  section.home-update .home-update-swiper .image {
    width: 100%;
    aspect-ratio: 330 / 185;
  }
  section.home-update .home-update-swiper .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  section.home-update .home-update-swiper .text {
    padding: 1.0rem 3.0rem;
    line-height: 1.7;
    height: 100%;
    background: #f3f3f3;
  }
  section.home-update .home-update-swiper .swiper-slide.black .text {
    background: #222;
    color: #fff;
  }
}


section.home-book {
  overflow: hidden;
}
@media screen and (min-width: 834px) {
  section.home-book .container {
    padding-top: 23.9rem;
    position: relative;
  }
  section.home-book .container {
    padding-bottom: 0rem;
  }
  section.home-book .home-book-swiper-wrap {
    overflow: visible;
    max-width: 176.8rem;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    position: relative;
    margin-top: 6.8rem;
  }
  section.home-book .home-book-swiper {
    overflow: visible;
    max-width: 43.6rem;
    margin: 0 auto 0 0;
    width: 100%;
    height: 100%;
    padding-left: 0.4rem;
    padding-right: 5.1rem;
    padding-bottom: 5.7rem;
  }
  section.home-book .home-book-swiper .swiper-slide {
    padding: 0 5.0rem 5.0rem 0;
  }
  section.home-book .home-book-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    overflow: visible;
  }
  section.home-book .home-book-swiper .book {
    background: #f3f3f3;
    overflow: hidden;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    position: relative;
    border: solid 1px #fff;
    transition: box-shadow 200ms 0s ease,
                border 200ms 0s ease;
  }
  section.home-book .home-book-swiper .book::before {
    content: "";
    display: block;
    border-right: solid 0.2rem #666;
    border-bottom: solid 0.2rem #666;
    width: 0.9rem;
    height: 0.9rem;
    position: absolute;
    bottom: 1.0rem;
    right: 1.0rem;
  }
  section.home-book .home-book-swiper a:hover .book {
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
    border: solid 1px #666;
  }
  section.home-book .home-book-swiper .book .num {
    position: absolute;
    top: 0;
    right: 1.5rem;
    width: 3.4rem;
  }
  section.home-book .home-book-swiper .book .num img {
    width: 100%;
    height: auto;
  }
  section.home-book .home-book-swiper .book .image {
    height: 33.0rem;
    padding-top: 1.9rem;
    padding-bottom: 1.2rem;
  }
  section.home-book .home-book-swiper .book .image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  section.home-book .home-book-swiper .title {
    padding-top: 1.2rem;
    line-height: 1.7;
  }
  section.home-book .home-book-swiper .author {
    line-height: 1.7;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 833px) {
  section.home-book .container {
    padding-top: 38.9rem;
    padding-bottom: 22.1rem;
    position: relative;
  }
  section.home-book .c-button-more {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0%);
  }
  section.home-book .c-section-title {
    margin-bottom: 8.7rem;
  }
  section.home-book .home-book-swiper-wrap {
    overflow: visible;
    width: 59.0rem;
    margin: 0 auto;
  }
  section.home-book .home-book-swiper .swiper-slide {
    width: 100%;
    padding: 0 2.0rem;
    margin-bottom: 0.5rem;
  }
  section.home-book .home-book-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    overflow: hidden;
    border: solid 1px #fff;
    position: relative;
  }

  section.home-book .home-book-swiper .book {
    background: #f3f3f3;
    overflow: hidden;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    position: relative;
    border: solid 1px #fff;
  }
  section.home-book .home-book-swiper .book::before {
    content: "";
    display: block;
    border-right: solid 0.4rem #666;
    border-bottom: solid 0.4rem #666;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
  }
  section.home-book .home-book-swiper .book .num {
    position: absolute;
    top: 0;
    right: 2.5rem;
    width: 5.7rem;
  }
  section.home-book .home-book-swiper .book .image {
    height: 54.8rem;
    padding-top: 2.7rem;
    padding-bottom: 2.7rem;
  }
  section.home-book .home-book-swiper .book .image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  section.home-book .home-book-swiper .title {
    padding-top: 1.4rem;
    line-height: 1.7;
    font-size: 3.2rem;
  }
  section.home-book .home-book-swiper .author {
    line-height: 1.7;
    font-size: 2.7rem;
  }
}


section.home-magazine {
}
@media screen and (min-width: 834px) {
  section.home-magazine .container {
    padding-top: 24.5rem;
    padding-bottom: 4.9rem;
  }
  section.home-magazine .c-button-more-area {
    margin-top: -4.9rem;
  }
  section.home-magazine .c-button-more-area li {
    margin-left: 2.5rem;
  }
  section.home-magazine ul.list {
    max-width: 120.0rem;
    margin: 0 auto;
    margin-top: 8.2rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
  }
  section.home-magazine ul.list li {
    margin-bottom: 5.0rem;
  }
  section.home-magazine ul.list li a {
    display: block;
    position: relative;
    width: 20.1rem;
    height: 20.1rem;
    border: solid 1px #222;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 1.0rem;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    transition: box-shadow 200ms 0s ease;
  }
  section.home-magazine ul.list li a img {
    width: 100%;
    height: auto;
  }
  section.home-magazine ul.list li a:before {
    content: "";
    display: block;
    width: 0.8rem;
    height: 0.8rem;
    border-right: solid 0.2rem #222;
    border-bottom: solid 0.2rem #222;
    position: absolute;
    bottom: 0.8rem;
    right: 0.8rem;
  }
  section.home-magazine ul.list li a:hover {
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
  }
}
@media screen and (max-width: 833px) {
  section.home-magazine .container {
    padding-top: 27.7rem;
    padding-bottom: 34.5rem;
    position: relative;
  }
  section.home-magazine .c-button-more-area {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 0%);
  }
  section.home-magazine ul.list {
    max-width: 63.9rem;
    margin: 0 auto;
    margin-top: 9.6rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
  }
  section.home-magazine ul.list li {
    margin-bottom: 3.4rem;
  }
  section.home-magazine ul.list li a {
    display: block;
    position: relative;
    width: 30.0rem;
    height: 30.0rem;
    border: solid 1px #222;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 0 1.0rem;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    transition: box-shadow 200ms 0s ease;
  }
  section.home-magazine ul.list li a img {
    width: 100%;
    height: auto;
  }
  section.home-magazine ul.list li a:before {
    content: "";
    display: block;
    width: 1.0rem;
    height: 1.0rem;
    border-right: solid 0.3rem #222;
    border-bottom: solid 0.3rem #222;
    position: absolute;
    bottom: 1.0rem;
    right: 1.0rem;
  }
  section.home-magazine ul.list li a:hover {
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
  }
}

@media screen and (min-width: 834px) {
  section.home-development .container {
    padding-top: 21.2rem;
    padding-bottom: 21.8rem;
  }
  section.home-development .home-development-swiper-wrap {
    overflow: visible;
    max-width: 176.8rem;
    margin: 0 auto;
    width: 100%;
    height: 100%;
    position: relative;
  }
  section.home-development .home-development-swiper {
    overflow: visible;
    max-width: 43.6rem;
    margin: 0 auto 0 0;
    width: 100%;
    height: 100%;
    margin-top: 4.9rem;
    padding-left: 0.4rem;
    padding-right: 5.1rem;
    padding-bottom: 8.0rem;
  }
  section.home-development .home-development-swiper .swiper-slide {
    padding: 0 5.0rem 5.0rem 0;
    width: 33.0rem;
    aspect-ratio: 1/1;
  }
  section.home-development .home-development-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    text-decoration: none;
    border-radius: 1.5rem 1.5rem 0 1.5rem;
    overflow: hidden;
    border: solid 1px #999;
    position: relative;
    transition: box-shadow 200ms 0s ease;
  }
  section.home-development .home-development-swiper .swiper-slide a::after {
    content: "";
    display: block;
    border-right: solid 0.2rem #666;
    border-bottom: solid 0.2rem #666;
    width: 0.9rem;
    height: 0.9rem;
    position: absolute;
    bottom: 1.0rem;
    right: 1.0rem;
  }
  section.home-development .home-development-swiper a:before {
    content: '';
    width: 100%;
    height: 1.2rem;
    background: #008000;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.home-development .home-development-swiper a:hover {
    border: solid 1px #222;
    box-shadow: -0.4rem -0.3rem 0 0 #ccc;
  }
  section.home-development .home-development-swiper .title {
    padding: 2.5rem 1.0rem 1.0rem 2.0rem;
    font-size: 2.0rem;
    font-weight: bold;
    font-family: TsukuGoPro-B-HelveticaNowTextMedium;
  }
  section.home-development .home-development-swiper .image {
    width: 100%;
    aspect-ratio: 328 / 160;
  }
  section.home-development .home-development-swiper .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  section.home-development .home-development-swiper .text {
    padding: 1.0rem 1.6rem;
    font-size: 1.7rem;
    line-height: 1.7;
  }
}
@media screen and (max-width: 833px) {
  section.home-development .container {
    padding-top: 35.0rem;
    padding-bottom: 29.6rem;
  }
  section.home-development .c-section-label {
    margin-bottom: 10.6rem;
  }
  section.home-development .c-section-title {
    margin-bottom: 8.1rem;
  }
  section.home-development .home-development-swiper-wrap {
    overflow: visible;
    width: 59.0rem;
    margin: 0 auto;
  }
  section.home-development .home-development-swiper .swiper-slide {
    width: 100%;
    padding: 0 2.0rem;
    margin-bottom: 2.5rem;
  }
  section.home-development .home-development-swiper .swiper-slide a {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 55.0rem;
    text-decoration: none;
    border-radius: 1.0rem 1.0rem 0 1.0rem;
    overflow: hidden;
    border: solid 1px #666;
    position: relative;
  }
  section.home-development .home-development-swiper .swiper-slide a::after {
    content: "";
    display: block;
    border-right: solid 0.4rem #666;
    border-bottom: solid 0.4rem #666;
    width: 1.2rem;
    height: 1.2rem;
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
  }
  section.home-development .home-development-swiper a:before {
    content: '';
    width: 100%;
    height: 2.1rem;
    background: #008000;
    position: absolute;
    top: 0;
    left: 0;
  }
  section.home-development .home-development-swiper a:after {
    content: "";
    display: block;
    width: 1.5rem;
    height: 1.7rem;
    border-right: solid 0.4rem #222;
    border-bottom: solid 0.4rem #222;
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
  }
  section.home-development .home-development-swiper .title {
    padding: 5.3rem 1.0rem 2.4rem 3.0rem;
    font-weight: bold;
    font-family: TsukuGoPro-B-HelveticaNowTextMedium;
    font-size: 3.1rem;
  }
  section.home-development .home-development-swiper .image {
    width: 100%;
    aspect-ratio: 328 / 160;
  }
  section.home-development .home-development-swiper .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  section.home-development .home-development-swiper .text {
    padding: 2.0rem 2.8rem;
    line-height: 1.6;
    font-size: 3.1rem;
  }
}

@media screen and (min-width: 834px) {
  section.supporters .container {
    padding-top: 11.6rem;
    padding-bottom: 9.2rem;
  }
}
@media screen and (max-width: 833px) {
}

section.section-media-links {
}
@media screen and (min-width: 834px) {
  section.section-media-links .container {
    padding-top: 7.5rem;
    padding-bottom: 9.2rem;
  }
}
@media screen and (max-width: 833px) {
  section.section-media-links .container {
    padding: 0 2.1rem;
    padding-top: 0.0rem;
    padding-bottom: 17.4rem;
  }
}
