@charset "UTF-8";
.pc {
  display: none !important;
}
@media only screen and (min-width: 768px) {
  .pc {
    display: initial !important;
  }
}

@media only screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

.btn_more_wrap .item_link {
  display: inline-flex !important;
}

.icon_feather {
  display: inline-block !important;
}

.heading_ff .jp, .wide_area_btn, .footer_grid, .footer_logo, .header_inner, .nav_menu, .nav_menu .nav_link {
  display: flex !important;
}

.nav_menu {
  flex-direction: column !important;
}

@media only screen and (min-width: 768px) {
  .nav_menu {
    flex-direction: row !important;
  }
}
.footer_copyright {
  letter-spacing: 0.06em;
}

.header, .nav, .nav_toggler {
  position: fixed !important;
}

.heading_ff .img, .totop_txt, .nav_toggler_box, .nav_toggler_bar, .nav_mask, .icon_feather::after {
  position: absolute !important;
}

.heading_ff, .wide_area_btn, .icon_feather {
  position: relative !important;
}

@media only screen and (min-width: 768px) {
  .nav {
    position: relative !important;
  }
}
.btn_more_wrap, .heading_pri, .wide_area, .totop {
  text-align: center !important;
}

@media only screen and (min-width: 768px) {
  .heading_ff .jp, .activities_lists .item_name, .activities_lists .item_txt {
    text-align: center !important;
  }
}
.totop_txt {
  font-family: "Oswald", sans-serif !important;
}

.l_pagination .item, .l_pagination .first,
.l_pagination .last,
.l_pagination .current,
.l_pagination .page {
  font-size: 1.4rem;
}

body {
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  body {
    font-size: 1.6rem;
  }
}

.activities_lists .item_youtube {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_youtube {
    font-size: 1.9rem;
  }
}

.wide_area_txt .txt, .activities_lists .item_cate {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .wide_area_txt .txt, .activities_lists .item_cate {
    font-size: 2rem;
  }
}

.wide_area_list li .spec {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .wide_area_list li .spec {
    font-size: clamp(18px, 18px + 3 / 832 * (100vw - 768px), 21px);
  }
}

.activities_lists .item_name {
  font-size: 1.6rem;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_name {
    font-size: 2.2rem;
  }
}

.btn_more_wrap .item_link {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_link {
    font-size: 2.3rem;
  }
}

.wide_area_list li {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .wide_area_list li {
    font-size: clamp(20px, 20px + 5 / 832 * (100vw - 768px), 25px);
  }
}

.footer_home_txt {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .footer_home_txt {
    font-size: clamp(23px, 23px + 3 / 832 * (100vw - 768px), 26px);
  }
}

.wide_area_txt .txt .lg {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .wide_area_txt .txt .lg {
    font-size: clamp(23px, 23px + 4 / 832 * (100vw - 768px), 27px);
  }
}

.btn_more_wrap .item_txt, .wide_area_sub {
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_txt, .wide_area_sub {
    font-size: clamp(23px, 23px + 5 / 832 * (100vw - 768px), 28px);
  }
}

.wide_area .item_leading, .wide_area_btn {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .wide_area .item_leading, .wide_area_btn {
    font-size: clamp(24px, 24px + 8 / 832 * (100vw - 768px), 32px);
  }
}

.activities_head .txt {
  font-size: 2rem;
}
@media only screen and (min-width: 768px) {
  .activities_head .txt {
    font-size: clamp(26px, 26px + 9 / 832 * (100vw - 768px), 35px);
  }
}

.activities_ttl {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .activities_ttl {
    font-size: clamp(28px, 28px + 12 / 832 * (100vw - 768px), 40px);
  }
}

.activities_head .icon {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .activities_head .icon {
    font-size: clamp(28px, 28px + 13 / 832 * (100vw - 768px), 41px);
  }
}

.activities_sub {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .activities_sub {
    font-size: clamp(28px, 28px + 14 / 832 * (100vw - 768px), 42px);
  }
}

.heading_pri .jp {
  font-size: 2.4rem;
}
@media only screen and (min-width: 768px) {
  .heading_pri .jp {
    font-size: clamp(28px, 28px + 20 / 832 * (100vw - 768px), 48px);
  }
}

.title_slash, .heading_ff .jp {
  font-size: 2.6rem;
}
@media only screen and (min-width: 768px) {
  .title_slash, .heading_ff .jp {
    font-size: clamp(30px, 30px + 22 / 832 * (100vw - 768px), 52px);
  }
}

.wide_area .item_heading {
  font-size: 3rem;
}
@media only screen and (min-width: 768px) {
  .wide_area .item_heading {
    font-size: clamp(30px, 30px + 28 / 832 * (100vw - 768px), 58px);
  }
}

.footer_copyright {
  font-weight: 300;
}

.totop_txt, .l_pagination .item, .l_pagination .first,
.l_pagination .last,
.l_pagination .current,
.l_pagination .page, .activities_lists .item_txt {
  font-weight: 500;
}

.nav_menu_item, .activities_lists .item_name {
  font-weight: 700;
}

.btn_more_wrap .item_txt, .btn_more_wrap .item_link, .title_slash, .heading_pri .jp, .heading_ff .jp, .wide_area .item_heading, .wide_area .item_leading, .wide_area_btn, .activities_lists .item_youtube {
  font-weight: 900;
}

html {
  min-height: 100vh;
  min-height: 100dvh;
  line-height: 1.6;
  scrollbar-width: thin;
}

body {
  width: 100%;
  top: 0;
  left: 0;
  position: relative;
  background-color: #fff6d6;
  color: #501c16;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  min-height: 100dvh;
}

img {
  width: 100%;
  height: auto;
}

.wrapper,
#wrapper {
  position: relative;
  overflow: hidden;
}

main {
  padding-top: 53px;
}
@media only screen and (min-width: 768px) {
  main {
    padding-top: 0;
  }
}

@media only screen and (min-width: 768px) {
  .nav_link_block:hover,
  .nav_link:hover {
    opacity: 0.6;
  }
}

.item_link,
.nav_link {
  display: inline-block;
  transition: 300ms ease-out;
}

.item_link_block,
.nav_link_block {
  display: block;
  transition: 300ms ease-out;
}

.container {
  width: 100%;
  padding-left: 20px;
  padding-right: 20px;
}
@media only screen and (min-width: 768px) {
  .container {
    max-width: 1240px;
    margin-right: auto;
    margin-left: auto;
  }
}
.container_fluid {
  padding-left: 20px;
  padding-right: 20px;
}

html.is_loading #loadding {
  opacity: 1;
  pointer-events: all;
}
html.is_loading body {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}

#loadding {
  position: fixed;
  z-index: 999999;
  top: 0;
  width: 100%;
  height: 100vh;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  background: linear-gradient(0deg, #fff6d6 0%, #fff 100%);
  opacity: 0;
  transition: opacity 1s ease-out 0.5s;
}

.three-body {
  position: relative;
  display: inline-block;
  height: 50px;
  width: 50px;
  animation: spin 2.75s infinite linear;
}
.three-body__dot {
  position: absolute;
  height: 100%;
  width: 30%;
}
.three-body__dot:after {
  content: "";
  position: absolute;
  height: 0%;
  width: 100%;
  padding-bottom: 100%;
  background-color: #fff;
  border-radius: 50%;
}
.three-body__dot:nth-child(1) {
  bottom: 5%;
  left: 0;
  transform: rotate(60deg);
  transform-origin: 50% 85%;
}
.three-body__dot:nth-child(1)::after {
  bottom: 0;
  left: 0;
  animation: wobble1 1.1s infinite ease-in-out;
  animation-delay: -0.33s;
}
.three-body__dot:nth-child(2) {
  bottom: 5%;
  right: 0;
  transform: rotate(-60deg);
  transform-origin: 50% 85%;
}
.three-body__dot:nth-child(2)::after {
  bottom: 0;
  left: 0;
  animation: wobble1 1.1s infinite -0.165s ease-in-out;
}
.three-body__dot:nth-child(3) {
  bottom: -5%;
  left: 0;
  transform: translateX(116.666%);
}
.three-body__dot:nth-child(3)::after {
  top: 0;
  left: 0;
  animation: wobble2 1.1s infinite ease-in-out;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes wobble1 {
  0%, 100% {
    transform: translateY(0%) scale(1);
    opacity: 1;
  }
  50% {
    transform: translateY(-66%) scale(0.65);
    opacity: 0.8;
  }
}
@keyframes wobble2 {
  0%, 100% {
    transform: translateY(0%) scale(1);
    opacity: 1;
  }
  50% {
    transform: translateY(66%) scale(0.65);
    opacity: 0.8;
  }
}
/*cookie*/
.cookie_wrap {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #3057ff;
  color: #000;
  z-index: 30;
  padding: 10px 0;
}
.cookie_container {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  max-width: 100%;
  width: 100%;
  padding: 0 25px;
}
@media only screen and (min-width: 768px) {
  .cookie_container {
    flex-wrap: nowrap;
  }
}
.cookie_txt {
  width: 100%;
  font-size: 1.4rem;
}
@media only screen and (min-width: 768px) {
  .cookie_txt {
    width: 75%;
    padding-right: 15px;
  }
}
.cookie_close {
  width: 90%;
  margin: 10px auto 0;
}
@media only screen and (min-width: 768px) {
  .cookie_close {
    margin-top: 0;
    flex-shrink: 0;
    width: 25%;
  }
}
.cookie_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 5px 10px 6px;
  text-decoration: none;
  border: solid 2px #000;
  background: #000;
  border-radius: 30px;
  color: #fff;
}
@media only screen and (min-width: 768px) {
  .cookie_btn {
    transition: all 0.5s;
    padding: 10px 10px 11px;
  }
  .cookie_btn:hover {
    opacity: 0.7;
  }
}

.activities::after {
  content: "";
  width: 100%;
  height: 60px;
  background-image: url("../images/specialsettinglp/img_decorate_01.png");
  background-repeat: repeat-x;
  background-size: 640px;
  opacity: 0.5;
  position: absolute;
  left: 0;
  bottom: 0;
}
@media only screen and (min-width: 768px) {
  .activities::after {
    height: 143px;
    background-size: 1600px;
  }
}
.activities_lists {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px 10px;
}
@media only screen and (min-width: 768px) {
  .activities_lists {
    grid-template-columns: repeat(auto-fill, minmax(198px, 1fr));
    gap: 52px clamp(2rem, 16.6666666667vw + -15.0666666667rem, 5.6rem);
  }
}
@media only screen and (min-width: 768px) {
  .activities_lists.is_archive {
    gap: 113px clamp(2rem, 16.6666666667vw + -15.0666666667rem, 5.6rem);
  }
}
.activities_lists .item {
  display: flex;
  flex-direction: column;
}
.activities_lists .item_thumb {
  position: relative;
  aspect-ratio: 0.5620915033;
  overflow: hidden;
  border-radius: 9px;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_thumb {
    cursor: pointer;
  }
  .activities_lists .item_thumb:hover img {
    scale: 1.05;
  }
}
.activities_lists .item_thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: scale 300ms ease;
}
.activities_lists .item_cate {
  margin-top: 10px;
  padding: 8px 10px 5px;
  background-color: #501c16;
  color: #fff;
  font-weight: 700;
  text-align: center;
  line-height: 1.2;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_cate {
    margin-bottom: -5px;
    margin-top: 20px;
  }
}
.activities_lists .item_cate.region {
  background-color: #006a1d;
}
.activities_lists .item_cate.wide {
  background-color: #0d0074;
}
.activities_lists .item_name {
  line-height: 1.5454545455;
  min-height: 50px;
  margin-top: 17px;
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_name {
    min-height: 67px;
    margin: 17px -5px 14px;
  }
}
.activities_lists .item_txt {
  line-height: 1.5625;
  margin-top: 6px;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_txt {
    margin-left: -8px;
    margin-right: -8px;
  }
}
.activities_lists .item_youtube {
  line-height: 1.1052631579;
  color: #d51100;
  max-width: 180px;
  width: 100%;
  background-color: #fff;
  display: flex;
  gap: 10px;
  align-items: center;
  position: relative;
  margin-top: 14px;
  margin-left: auto;
  margin-right: auto;
  padding: 10px 16px;
  border-radius: 99px;
  border: 2px solid #d51100;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_youtube {
    max-width: 202px;
    min-height: 46px;
    margin-top: auto;
    padding: 10px 30px 10px 37px;
    transition: 300ms ease;
  }
  .activities_lists .item_youtube:hover {
    background-color: #d51100;
    color: #fff;
  }
  .activities_lists .item_youtube:hover::after {
    border-color: #fff;
  }
  .activities_lists .item_youtube:hover .icon {
    background-image: url("./../images/specialsettinglp/icon_youtube_w.svg");
  }
}
.activities_lists .item_youtube::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 10px;
  rotate: -45deg;
  translate: 0 -50%;
  width: 8px;
  height: 8px;
  border: 0;
  border-right: 2px solid #d51100;
  border-bottom: 2px solid #d51100;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_youtube::after {
    width: 13px;
    height: 13px;
    right: 18px;
    transition: 300ms ease;
  }
}
.activities_lists .item_youtube .icon {
  width: 16px;
  aspect-ratio: 1.2857142857;
  display: inline-block;
  background-image: url("./../images/specialsettinglp/icon_youtube.svg");
  background-size: 100%;
  background-repeat: no-repeat;
}
@media only screen and (min-width: 768px) {
  .activities_lists .item_youtube .icon {
    width: 27px;
    transition: 300ms ease;
  }
}
.activities .btn_more_wrap {
  margin-top: 30px;
}
@media only screen and (min-width: 768px) {
  .activities .btn_more_wrap {
    margin-top: 65px;
  }
}
.activities_inner {
  position: relative;
  width: calc(100% - 40px);
  padding-bottom: 40px;
  margin: 70px auto 0;
  padding: 0 20px 40px;
  background-color: #fff;
  border-radius: 20px;
}
@media only screen and (min-width: 768px) {
  .activities_inner {
    max-width: 1294px;
    margin-top: 65px;
    padding-right: 47px;
    padding-left: 47px;
    padding-bottom: 95px;
    border-radius: 39px;
  }
}
@media only screen and (min-width: 768px) {
  .activities_heading {
    margin-bottom: -1px;
  }
}
.activities_ttl {
  position: relative;
  top: -28px;
  width: calc(100% - 40px);
  margin: 0 auto;
  padding: 10px 20px 0;
  background-color: #fff;
  border-radius: 20px;
  color: #d51100;
  text-align: center;
  font-weight: 800;
}
@media only screen and (min-width: 768px) {
  .activities_ttl {
    top: -42px;
    max-width: 784px;
    padding: 13px 110px 0;
    border-radius: 30px;
  }
}
.activities_ttl span {
  display: block;
}
.activities_head {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  margin-bottom: 30px;
}
@media only screen and (min-width: 768px) {
  .activities_head {
    gap: 18px;
    margin-bottom: 74px;
  }
}
.activities_head .icon {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 70px;
  height: 70px;
  background-color: #d51100;
  border-radius: 100%;
  color: #fff;
  text-align: center;
  font-weight: 800;
  line-height: 1;
}
@media only screen and (min-width: 768px) {
  .activities_head .icon {
    width: 117px;
    height: 117px;
    padding-bottom: 5px;
  }
}
.activities_head .txt {
  padding: 10px 5px;
  border-top: 1px dotted #501c16;
  border-bottom: 1px dotted #501c16;
  color: #501c16;
  font-weight: 700;
  line-height: 1.8285714286;
}
@media only screen and (min-width: 768px) {
  .activities_head .txt {
    padding: 10px 10px 10px 26px;
    text-align: center;
  }
}
.activities_sub {
  margin-bottom: 30px;
  font-weight: 900;
  text-align: center;
  line-height: 1.2380952381;
}
@media only screen and (min-width: 768px) {
  .activities_sub {
    margin-bottom: 45px;
  }
}
.activities_group {
  margin-bottom: 50px;
}
.activities_group:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .activities_group.group01 {
    margin-bottom: 137px;
  }
}
@media only screen and (min-width: 768px) {
  .activities_group.group02 {
    margin-bottom: 98px;
  }
}
@media only screen and (min-width: 768px) {
  .activities_group.group02 .activities_head {
    margin-bottom: 45px;
  }
}
.activities_group.group02 .activities_head .txt {
  text-align: center;
}
@media only screen and (min-width: 768px) {
  .activities_group.group02 .activities_head .txt {
    padding: 10px 10px 12px;
  }
}
.activities_group.group02 .activities_sub {
  color: #006a1d;
}
.activities_group.group02 .btn_more_wrap .item_txt {
  color: #006a1d;
}
.activities_group.group02 .btn_more_wrap .item_txt::before, .activities_group.group02 .btn_more_wrap .item_txt::after {
  background-color: #006a1d;
}
.activities_group.group02 .btn_more_wrap .item_link {
  background-color: #006a1d;
  border-color: #006a1d;
}
.activities_group.group02 .activities_lists .item_cate {
  background-color: #006a1d;
}
.activities_group.group03 .activities_sub {
  color: #0d0074;
}
.activities_group.group03 .btn_more_wrap .item_txt {
  color: #0d0074;
}
.activities_group.group03 .btn_more_wrap .item_txt::before, .activities_group.group03 .btn_more_wrap .item_txt::after {
  background-color: #0d0074;
}
.activities_group.group03 .btn_more_wrap .item_link {
  background-color: #0d0074;
  border-color: #0d0074;
}
.activities_group.group03 .activities_lists .item_cate {
  background-color: #0d0074;
}

.l_pagination .item {
  width: 30px;
  height: 30px;
  background-color: #fff;
  color: #707070;
  border: 1px solid #acacac;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 300ms ease-out;
}
.l_pagination .item.active {
  background-color: #d6000d;
  border-color: #d6000d;
  color: #fffae8;
  pointer-events: none;
}
@media only screen and (min-width: 768px) {
  .l_pagination .item:hover {
    background-color: #d6000d;
    border-color: #d6000d;
    color: #fffae8;
  }
}
.l_pagination .item_group {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
}
.l_pagination .item_arrow {
  width: 15px;
  height: 15px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .l_pagination .item_arrow:hover::after {
    border-left-color: #d6000d;
  }
}
.l_pagination .item_arrow::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border: 0;
  border-top: 8px solid rgba(62, 58, 57, 0);
  border-left: 15px solid #3e3a39;
  border-bottom: 8px solid rgba(62, 58, 57, 0);
  transition: 300ms ease-out;
}
.l_pagination .item_prev::after {
  scale: -1 1;
}
.l_pagination .first {
  color: #000;
}
.l_pagination .last {
  color: #3e3a39;
}
.l_pagination .wp-pagenavi {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: center;
}
.l_pagination .extend {
  display: none !important;
}
.l_pagination .first,
.l_pagination .last,
.l_pagination .current,
.l_pagination .page {
  width: 24px;
  height: 24px;
  background-color: #fff;
  color: #707070;
  border: 1px solid #acacac;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 300ms ease-out;
}
@media only screen and (min-width: 768px) {
  .l_pagination .first,
  .l_pagination .last,
  .l_pagination .current,
  .l_pagination .page {
    width: 30px;
    height: 30px;
  }
  .l_pagination .first:hover,
  .l_pagination .last:hover,
  .l_pagination .current:hover,
  .l_pagination .page:hover {
    background-color: #d6000d;
    border-color: #d6000d;
    color: #fffae8;
  }
}
.l_pagination .current {
  background-color: #d6000d;
  border-color: #d6000d;
  color: #fffae8;
  pointer-events: none;
}
.l_pagination .first {
  color: #000;
}
.l_pagination .last {
  color: #3e3a39;
}
.l_pagination .previouspostslink,
.l_pagination .nextpostslink {
  width: 15px;
  height: 15px;
  position: relative;
  font-size: 0;
}
@media only screen and (min-width: 768px) {
  .l_pagination .previouspostslink:hover::after,
  .l_pagination .nextpostslink:hover::after {
    border-left-color: #d6000d;
  }
}
.l_pagination .previouspostslink::after,
.l_pagination .nextpostslink::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border: 0;
  border-top: 8px solid rgba(62, 58, 57, 0);
  border-left: 15px solid #3e3a39;
  border-bottom: 8px solid rgba(62, 58, 57, 0);
  transition: 300ms ease-out;
}
.l_pagination .previouspostslink::after {
  scale: -1 1;
}
.icon_feather {
  width: 26px;
  aspect-ratio: 0.7428571429;
}
.icon_feather::after {
  content: "";
  inset: 0;
  width: 100%;
  aspect-ratio: 0.7428571429;
  background-image: url("../images/specialsettinglp/icon_feather.svg");
  background-repeat: no-repeat;
  background-size: 100%;
}
.icon_feather__w::after {
  background-image: url("../images/specialsettinglp/icon_feather_w.svg");
}

/** -- ▷ header -- */
.header {
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff;
}
.header_inner {
  align-items: center;
  height: 56px;
  padding: 10px;
}
@media only screen and (min-width: 768px) {
  .header_inner {
    height: 104px;
    height: clamp(74px, 74px + 30 / 832 * (100vw - 768px), 104px);
    padding-left: 71px;
    padding-left: clamp(20px, 20px + 51 / 832 * (100vw - 768px), 71px);
    padding-right: 103px;
    padding-right: clamp(20px, 20px + 83 / 832 * (100vw - 768px), 103px);
  }
}
.header_logo {
  width: 140px;
  max-width: 37.3333333333%;
  flex-shrink: 0;
}
@media only screen and (min-width: 768px) {
  .header_logo {
    width: clamp(150px, 150px + 168 / 832 * (100vw - 768px), 318px);
  }
}
.header_logo_2 {
  width: 140px;
  max-width: 37.3333333333%;
  flex-shrink: 0;
  margin-left: 10px;
}
@media only screen and (min-width: 768px) {
  .header_logo_2 {
    width: clamp(150px, 150px + 144 / 832 * (100vw - 768px), 294px);
    margin-left: 12px;
  }
}
@media only screen and (min-width: 768px) {
  .header_menu {
    margin-left: auto;
  }
}

.nav {
  z-index: 1;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: 300ms linear;
  padding: 80px 20px 20px;
}
.nav.is_open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.nav_toggler {
  z-index: 1;
  top: 0;
  right: 0;
  width: 56px;
  height: 56px;
}
@media only screen and (min-width: 768px) {
  .nav_toggler {
    display: none;
  }
}
.nav_toggler.is_open .nav_toggler_bar:nth-child(4), .nav_toggler.is_open .nav_toggler_bar:nth-child(1) {
  opacity: 0;
}
.nav_toggler.is_open .nav_toggler_bar:nth-child(2) {
  opacity: 1;
  rotate: 45deg;
}
.nav_toggler.is_open .nav_toggler_bar:nth-child(3) {
  rotate: -45deg;
}
.nav_toggler_box {
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: 30px;
  height: 20px;
}
.nav_toggler_bar {
  width: 100%;
  height: 2px;
  border-radius: 1px;
  background-color: #501c16;
  transition: rotate 300ms ease-out, opacity 150ms linear;
}
.nav_toggler_bar:nth-child(1) {
  top: 0;
}
.nav_toggler_bar:nth-child(2) {
  opacity: 0;
  top: calc(50% - 1px);
}
.nav_toggler_bar:nth-child(3) {
  top: calc(50% - 1px);
}
.nav_toggler_bar:nth-child(4) {
  top: calc(100% - 1px);
}
.nav_mask {
  inset: 0;
  z-index: -1;
  background-color: #fff6d6;
}
.nav_inner {
  max-width: 375px;
  background-color: #fff;
  border-radius: 20px;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
}
.nav_inner .overflow {
  width: 100%;
  max-height: calc(100vh - 140px);
  overflow: auto;
}
.nav_menu {
  gap: 16px;
}
@media only screen and (min-width: 768px) {
  .nav_menu {
    gap: 51px;
    gap: clamp(20px, 20px + 31 / 832 * (100vw - 768px), 51px);
  }
}
.nav_menu_item {
  line-height: 1.7727272727;
  font-size: 1.8rem;
}
@media only screen and (min-width: 768px) {
  .nav_menu_item {
    font-size: clamp(12px, 12px + 10 / 832 * (100vw - 768px), 22px);
  }
}
.nav_menu .nav_link {
  align-items: center;
}
.nav_menu .nav_link .icon_feather {
  width: 20px;
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .nav_menu .nav_link .icon_feather {
    width: clamp(16px, 16px + 10 / 832 * (100vw - 768px), 26px);
    margin-right: 6px;
  }
}

/** -- ▷ footer -- */
.wide_area {
  background-color: #0d0074;
  color: #fff;
  margin-top: -1px;
  padding: 50px 0;
}
@media only screen and (min-width: 768px) {
  .wide_area {
    padding: 80px 0 112px;
  }
}
.wide_area .item_heading {
  line-height: 1.2222222222;
}
.wide_area .item_leading {
  line-height: 1.21875;
  margin-top: 16px;
}
@media only screen and (min-width: 768px) {
  .wide_area .item_leading {
    margin-top: 21px;
  }
}
.wide_area_head {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid #fff;
}
@media only screen and (min-width: 768px) {
  .wide_area_head {
    margin-bottom: 36px;
    padding-bottom: 53px;
  }
}
.wide_area_txt {
  margin-bottom: 30px;
}
@media only screen and (min-width: 768px) {
  .wide_area_txt {
    margin-bottom: 72px;
  }
}
.wide_area_txt .txt {
  font-weight: 600;
  text-align: left;
  line-height: 2;
}
@media only screen and (min-width: 768px) {
  .wide_area_txt .txt {
    margin-bottom: 30px;
    text-align: center;
    font-size: clamp(1.6rem, 0.4807692308vw + 1.2307692308rem, 2rem);
  }
}
.wide_area_txt .txt:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 768px) {
  .wide_area_txt .txt .lg {
    font-size: clamp(2rem, 0.8413461538vw + 1.3538461538rem, 2.7rem);
  }
}
.wide_area_main {
  width: 100%;
  max-width: 760px;
  margin-bottom: 50px;
}
@media only screen and (min-width: 768px) {
  .wide_area_main {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 90px;
  }
}
.wide_area_sub {
  display: inline-block;
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid #fff;
  text-align: center;
  font-weight: 500;
  line-height: 1.2142857143;
}
@media only screen and (min-width: 768px) {
  .wide_area_sub {
    margin-bottom: 32px;
    padding-bottom: 15px;
  }
}
.wide_area_sub .spec {
  font-weight: 900;
}
@media only screen and (min-width: 768px) {
  .wide_area_list {
    padding-left: 10px;
  }
}
.wide_area_list li {
  font-weight: 700;
  line-height: 1.36;
  text-align: left;
}
.wide_area_list li:not(:last-child) {
  margin-bottom: 15px;
}
@media only screen and (min-width: 768px) {
  .wide_area_list li:not(:last-child) {
    margin-bottom: 25px;
  }
}
.wide_area_list li .spec {
  margin-left: 20px;
  font-weight: 500;
}
@media only screen and (min-width: 768px) {
  .wide_area_list li .spec {
    position: relative;
    top: 2px;
    margin-left: 40px;
  }
}
.wide_area_more {
  max-width: 440px;
  background-color: #7c0d03;
  border-radius: 999px;
  margin-bottom: 40px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .wide_area_more {
    max-width: 1066px;
    margin-bottom: 52px;
  }
}
.wide_area_btn {
  line-height: 1.2432432432;
  color: #fff;
  min-height: 81px;
  background-color: #d51100;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 10px 40px 10px 10px;
  translate: 0 -10px;
}
@media only screen and (min-width: 768px) {
  .wide_area_btn {
    transition: translate 300ms ease-out;
    padding-left: 50px;
    padding-right: 50px;
    font-size: clamp(2rem, 2.7777777778vw + -0.1333333333rem, 3.2rem);
  }
  .wide_area_btn:hover {
    translate: none;
  }
}
.wide_area_btn::after {
  content: "";
  width: 16px;
  height: 16px;
  position: absolute;
  top: 53%;
  right: 20px;
  translate: 0 -50%;
  rotate: 45deg;
  border: 0;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}
@media only screen and (min-width: 768px) {
  .wide_area_btn::after {
    right: 39px;
  }
}
.wide_area .btn_more_wrap .item_txt {
  color: #fff;
}
.wide_area .btn_more_wrap .item_txt::before, .wide_area .btn_more_wrap .item_txt::after {
  background-color: #fff;
}
@media only screen and (min-width: 768px) {
  .wide_area .btn_more_wrap .item_txt::before {
    margin-right: 28px;
  }
}
@media only screen and (min-width: 768px) {
  .wide_area .btn_more_wrap .item_txt::after {
    margin-left: 28px;
  }
}
.wide_area .btn_more_wrap .item_link {
  background-color: #ff9d00;
  border-color: #ff9d00;
}
@media only screen and (min-width: 768px) {
  .wide_area .btn_more_wrap .item_link {
    width: 280px;
    height: 57px;
    margin-top: 14px;
  }
}

.footer {
  padding: 0.1px;
  background-color: #fff;
}
.footer_context {
  position: relative;
  margin-top: 50px;
}
@media only screen and (min-width: 768px) {
  .footer_context {
    margin-top: 75px;
  }
}
.footer_grid {
  align-items: flex-end;
  padding-top: 28px;
}
@media only screen and (min-width: 768px) {
  .footer_grid {
    padding-top: 22px;
    padding-left: 28px;
  }
}
.footer_ff {
  width: 100px;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .footer_ff {
    width: 25.5972696246%;
    aspect-ratio: 0.8695652174;
  }
}
.footer_ff_image {
  width: 100px;
  position: absolute;
  left: 50%;
  bottom: 0;
  translate: -56.6% 0;
}
@media only screen and (min-width: 768px) {
  .footer_ff_image {
    width: 30vw;
    max-width: 410px;
  }
}
.footer_content {
  width: calc(100% - 100px);
  padding-top: 16px;
  padding-bottom: 16px;
}
@media only screen and (min-width: 768px) {
  .footer_content {
    width: 74.4027303754%;
    padding-top: 30px;
    padding-left: 26px;
  }
}
.footer_heading {
  width: 100%;
}
@media only screen and (min-width: 768px) {
  .footer_heading {
    width: 797px;
    max-width: 100%;
  }
}
.footer_logo {
  gap: 10px;
  margin-top: 20px;
}
@media only screen and (min-width: 768px) {
  .footer_logo {
    gap: 12px;
    margin-top: 37px;
    padding-left: 9px;
  }
}
.footer_logo .item:nth-child(1) {
  width: calc(50% - 5px);
}
@media only screen and (min-width: 768px) {
  .footer_logo .item:nth-child(1) {
    width: 318px;
    max-width: 40%;
  }
}
.footer_logo .item:nth-child(2) {
  width: calc(50% - 5px);
}
@media only screen and (min-width: 768px) {
  .footer_logo .item:nth-child(2) {
    width: 294px;
    max-width: calc(40% - 10px);
  }
}
.footer_copyright {
  font-size: 1rem;
  color: #000;
  margin-top: 36px;
}
@media only screen and (min-width: 768px) {
  .footer_copyright {
    font-size: 1.1rem;
    padding-left: 34px;
  }
}
.footer_home {
  width: 800px;
  max-width: 100%;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (min-width: 768px) {
  .footer_home {
    margin-top: 78px;
  }
}
.footer_home_txt {
  position: relative;
  margin-top: 16px;
  color: #d51100;
  font-weight: 900;
  text-align: center;
  line-height: 1.6538461538;
}
.footer_home_txt span {
  position: relative;
  display: inline-block;
  padding: 0 18px;
  background-color: #fff;
}
.footer_home_txt::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  height: 1px;
  background-color: #d51100;
}

.totop {
  width: 60px;
  height: 60px;
  background-color: #d51100;
  position: fixed;
  z-index: 10;
  right: 20px;
  bottom: 20px;
  border-radius: 99px;
  padding-top: 11px;
  transition: translate 300ms ease, opacity 150ms linear;
  translate: 0 100px;
}
@media only screen and (min-width: 768px) {
  .totop {
    width: 70px;
    height: 70px;
    right: 38px;
    padding-top: 11px;
    cursor: pointer;
  }
  .totop:hover {
    opacity: 0.44;
  }
}
.totop.is_show {
  translate: none;
}
.totop_txt {
  font-size: 1.2rem;
  color: #fff;
  line-height: 1.4166666667;
  left: 0;
  right: 0;
  bottom: 5px;
}
@media only screen and (min-width: 768px) {
  .totop .icon_feather {
    width: 28px;
  }
}

.heading_pri .jp {
  line-height: 2;
}
.heading_pri .jp::before, .heading_pri .jp::after {
  content: "";
  width: 30px;
  display: inline-block;
  vertical-align: middle;
  aspect-ratio: 0.7391304348;
  background-image: url("../images/specialsettinglp/icon_feather.svg");
  background-size: 100%;
  background-repeat: no-repeat;
  position: relative;
  top: -3px;
}
@media only screen and (min-width: 768px) {
  .heading_pri .jp::before, .heading_pri .jp::after {
    width: 4.5vw;
    max-width: 62px;
  }
}
.heading_pri .jp::before {
  margin-right: 10px;
}
@media only screen and (min-width: 768px) {
  .heading_pri .jp::before {
    margin-right: 27px;
  }
}
.heading_pri .jp::after {
  margin-left: 10px;
}
@media only screen and (min-width: 768px) {
  .heading_pri .jp::after {
    margin-left: 27px;
  }
}
.heading_ff {
  padding-top: 10px;
  padding-bottom: 10px;
}
@media only screen and (min-width: 768px) {
  .heading_ff {
    padding-top: 40px;
    padding-bottom: 40px;
  }
}
.heading_ff .jp {
  line-height: 1.2307692308;
  color: #fff;
  width: 90%;
  background-color: #d51100;
  border-radius: 10px;
  margin-left: auto;
  padding: 10px;
  padding-left: 80px;
  align-items: center;
}
@media only screen and (min-width: 768px) {
  .heading_ff .jp {
    max-width: 1040px;
    min-height: 196px;
    justify-content: center;
    border-radius: 22px;
    padding: 34px 10px;
    padding-left: 122px;
  }
}
.heading_ff .img {
  top: calc(50% - 4px);
  left: 0;
  right: 0;
  translate: 0 -50%;
  width: 100px;
}
@media only screen and (min-width: 768px) {
  .heading_ff .img {
    width: 26%;
    max-width: 279px;
  }
}
.heading_ff__right .jp {
  margin-left: 0;
  padding-left: 20px;
  padding-right: 70px;
}
@media only screen and (min-width: 768px) {
  .heading_ff__right .jp {
    padding-left: 36px;
    padding-right: 140px;
  }
}
.heading_ff__right .img {
  margin-left: auto;
}
.heading__red {
  color: #d51100;
}

.title_slash {
  line-height: 1.2307692308;
  color: #d51100;
}
.title_slash::before, .title_slash::after {
  content: "";
  width: 3px;
  height: 30px;
  background-color: #d51100;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  top: -2px;
  border-radius: 99px;
}
@media only screen and (min-width: 768px) {
  .title_slash::before, .title_slash::after {
    width: 6px;
    height: 57px;
    top: -7px;
  }
}
.title_slash::before {
  margin-right: 20px;
  rotate: -40deg;
}
@media only screen and (min-width: 768px) {
  .title_slash::before {
    margin-right: 33px;
  }
}
.title_slash::after {
  margin-left: 20px;
  rotate: 40deg;
}
@media only screen and (min-width: 768px) {
  .title_slash::after {
    margin-left: 33px;
  }
}

.btn_more_wrap .item_txt {
  line-height: 1.6785714286;
  color: #d51100;
}
.btn_more_wrap .item_txt::before, .btn_more_wrap .item_txt::after {
  content: "";
  width: 3px;
  height: 30px;
  background-color: #d51100;
  display: inline-block;
  vertical-align: middle;
  position: relative;
  top: -1px;
  border-radius: 99px;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_txt::before, .btn_more_wrap .item_txt::after {
    height: 44px;
  }
}
.btn_more_wrap .item_txt::before {
  margin-right: 16px;
  rotate: -47deg;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_txt::before {
    margin-right: 35px;
  }
}
.btn_more_wrap .item_txt::after {
  margin-left: 16px;
  rotate: 47deg;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_txt::after {
    margin-left: 35px;
  }
}
.btn_more_wrap .item_link {
  width: 280px;
  height: 50px;
  background-color: #501c16;
  line-height: 1;
  align-items: center;
  justify-content: center;
  color: #fff;
  position: relative;
  padding: 4px 16px 7px 5px;
  margin-top: 5px;
  border-radius: 99px;
  border: 1px solid #501c16;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_link {
    width: 341px;
    height: 60px;
    padding-right: 28px;
  }
  .btn_more_wrap .item_link:hover {
    opacity: 0.6;
  }
}
.btn_more_wrap .item_link::after {
  content: "";
  position: absolute;
  top: 47%;
  right: 20px;
  width: 9px;
  height: 9px;
  translate: 0 -50%;
  rotate: 45deg;
  border: 0;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_link::after {
    width: 12px;
    height: 12px;
    right: 26px;
  }
}
@media only screen and (min-width: 768px) {
  .btn_more_wrap .item_link.width2 {
    width: 372px;
  }
}

/*# sourceMappingURL=specialsettinglp_common.css.map */
