@charset "UTF-8";
* {
  color: #1a1a1a;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: 500;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  text-align: justify;
  line-height: 1.6;
  letter-spacing: 0.025em;
}

html {
  font-size: 56.5%;
  line-height: 1.65;
  overflow-x: hidden;
  scroll-behavior: smooth;
}
@media print, screen and (min-width: 1024px) {
  html {
    font-size: 62.5%;
  }
}

body {
  font-size: 1.6rem;
  overflow-x: hidden;
}

li {
  list-style: none;
}

a {
  display: block;
  width: 100%;
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-decoration: none;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
a *, a::before, a::after {
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
@media print, screen and (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

address {
  font-style: normal;
}

span {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  text-align: inherit;
  line-height: inherit;
}

img,
iframe {
  display: block;
  width: 100%;
  max-width: -webkit-max-content;
  max-width: -moz-max-content;
  max-width: max-content;
  height: auto;
}

@media print, screen and (min-width: 480px) {
  br.under480 {
    display: none;
  }
}
@media print, screen and (min-width: 768px) {
  br.under768 {
    display: none;
  }
}
br.over768 {
  display: none;
}
@media print, screen and (min-width: 768px) {
  br.over768 {
    display: block;
  }
}
br.over1024 {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  br.over1024 {
    display: block;
  }
}

.container {
  width: 100%;
  max-width: 1920px;
  margin: auto;
  overflow-x: hidden;
  -webkit-animation: fade 0.5s forwards;
          animation: fade 0.5s forwards;
}

.inner {
  width: 90%;
  margin: auto;
}
.inner.max1024 {
  max-width: 1024px;
}
.inner.max1200 {
  max-width: 1200px;
}
.inner.max1250 {
  max-width: 1250px;
}
.inner.max1400 {
  max-width: 1400px;
}

.mg_top40 {
  margin-top: clamp(2rem, 2.5vw, 4rem) !important;
}
.mg_top64 {
  margin-top: clamp(4rem, 3.5vw, 6.4rem) !important;
}
.mg_top80 {
  margin-top: clamp(4rem, 4.5vw, 8rem) !important;
}
.mg_top120 {
  margin-top: clamp(6rem, 6.5vw, 12rem) !important;
}

.pd120 {
  padding: clamp(6rem, 6.5vw, 12rem) 0 !important;
}
.pd_top120 {
  padding-top: clamp(6rem, 6.5vw, 12rem) !important;
}
.pd_bottom40 {
  padding-bottom: clamp(2rem, 2.5vw, 4rem) !important;
}

@media print, screen and (min-width: 1024px) {
  .bold {
    font-weight: bold;
  }
}

header.section_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #1a1a1a;
}
header.section_title span {
  position: relative;
  font-size: 5.6rem;
  font-size: min(11.2vw, 5.6rem);
  font-weight: 100;
}
header.section_title h2 {
  color: inherit;
  font-size: 1.8rem;
  font-weight: bold;
}

section.page_top .inner {
  height: min(40vw, 29.5rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
section.page_top .title_area {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  section.page_top .title_area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: end;
  }
}
section.page_top header.page_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
section.page_top header.page_title h1 {
  color: #1a1a1a;
  font-size: 1.8rem;
  font-weight: bold;
}
section.page_top header.page_title span {
  position: relative;
  color: #ef271b;
  font-size: clamp(3.2rem, 6.4vw, 6.4rem);
  font-weight: bold;
}
section.page_top nav.breadcrumb {
  display: none;
}
@media print, screen and (min-width: 768px) {
  section.page_top nav.breadcrumb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}
section.page_top nav.breadcrumb ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.5rem;
}
section.page_top nav.breadcrumb ol li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.5rem;
  font-size: 1.4rem;
  font-weight: bold;
}
section.page_top nav.breadcrumb ol li:not(:last-of-type)::after {
  content: ">";
  display: block;
}
section.page_top nav.breadcrumb ol li a {
  display: inline-block;
  font-size: 1.4rem;
  font-weight: bold;
}
section.page_top nav.breadcrumb ol li a[href*="#"] {
  pointer-events: none;
}
section.page_top nav.breadcrumb ol li a:hover {
  color: #00af54;
}
section.page_top .page_img {
  width: 100%;
  height: min(40vw, 40rem);
  background: center/cover no-repeat;
}
section.page_top .page_img.company {
  background-image: url(../img/company/page_top.webp);
}
section.page_top .page_img.product {
  background-image: url(../img/product/page_top.webp);
}
section.page_top .page_img.flow {
  background-image: url(../img/flow/page_top.webp);
}
section.page_top .page_img.example {
  background-image: url(../img/example/page_top.webp);
}
section.page_top .page_img.news {
  background-image: url(../img/news/page_top.webp);
}
section.page_top .page_img.contact {
  background-image: url(../img/contact/page_top.webp);
}
section.page_top .page_img.privacy {
  background-image: url(../img/privacy/page_top.webp);
}
section.page_top .page_img.page404 {
  background-image: url(../img/page404/page_top.webp);
}

.anchor_list ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem 0;
}
.anchor_list ul li {
  border-left: 0.1rem solid #1a1a1a;
}
.anchor_list ul li:last-of-type {
  border-right: 0.1rem solid #1a1a1a !important;
}
.anchor_list ul li a {
  position: relative;
  color: #1a1a1a;
  font-weight: bold;
  text-align: center;
}
.anchor_list ul li a::after {
  content: "";
  width: 0.5em;
  aspect-ratio: 1/1;
  border-right: 2px solid #1a1a1a;
  border-bottom: 2px solid #1a1a1a;
  position: absolute;
  top: 50%;
  right: 8%;
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
@media print, screen and (min-width: 1024px) {
  .anchor_list ul li a::after {
    content: none;
  }
}
.anchor_list ul li a:hover {
  color: #fe654f;
}
.anchor_list.company ul li {
  width: 50%;
}
@media print, screen and (min-width: 768px) {
  .anchor_list.company ul li {
    width: 25%;
  }
}
.anchor_list.company ul li:nth-of-type(even) {
  border-right: 0.1rem solid #1a1a1a;
}
@media print, screen and (min-width: 768px) {
  .anchor_list.company ul li:nth-of-type(even) {
    border-right: none;
  }
}

header.page_section_title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header.page_section_title span {
  color: #fe654f;
  font-size: min(8vw, 4rem);
  font-weight: bold;
}
header.page_section_title h2 {
  font-size: 1.6rem;
  font-weight: bold;
}

.btn {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
.btn a {
  position: relative;
  width: 200px;
  color: #ef271b;
  text-align: center;
  border: 0.1rem solid #ef271b;
  border-radius: 9999px;
  padding: min(2vw, 0.8em) 0;
}
.btn a::before, .btn a::after {
  content: "";
  aspect-ratio: 1/1;
  position: absolute;
  top: 50%;
}
.btn a::before {
  width: 1em;
  border: 0.1rem solid #ef271b;
  border-radius: 50%;
  background-color: #fff;
  right: 20px;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.btn a::after {
  width: 0.35em;
  border-top: 1px solid #ef271b;
  border-right: 1px solid #ef271b;
  right: calc(20px + 0.35em);
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
.btn a:hover {
  color: #fff;
  background-color: #ef271b;
}

#header {
  position: fixed;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  z-index: 9999999999;
  width: 100%;
  max-width: 1920px;
  background-color: #fff;
}
#header .header_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: min(3vw, 1.5rem) min(2vw, 4rem);
}
@media print, screen and (min-width: 1024px) {
  #header .header_inner {
    padding: min(0.65vw, 1.2rem) min(2vw, 4rem);
  }
}
#header h1.logo,
#header p.logo {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#header h1.logo a,
#header p.logo a {
  display: grid;
  place-items: center;
}
#header h1.logo a:hover,
#header p.logo a:hover {
  opacity: 0.5;
}
#header h1.logo a img,
#header p.logo a img {
  width: 20rem;
  max-width: none;
}
#header .area_right {
  -ms-flex-item-align: stretch;
      align-self: stretch;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 1024px) {
  #header .area_menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 min(2vw, 4rem);
  }
}
#header nav.pc_menu {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  #header nav.pc_menu {
    display: block;
  }
}
#header nav.pc_menu ul.upper {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
}
#header nav.pc_menu ul.upper li.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#header nav.pc_menu ul.upper li.flex .link_company {
  padding-right: 1.5rem;
  border-right: 0.1rem solid #1a1a1a;
}
#header nav.pc_menu ul.upper li.flex .link_company a {
  font-size: 1.2rem;
  font-weight: bold;
}
#header nav.pc_menu ul.upper li.flex .link_company a:hover {
  color: #00af54;
}
#header nav.pc_menu ul.upper li.flex .link_tel {
  margin-left: 1.5rem;
}
#header nav.pc_menu ul.upper li.flex .link_tel a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
}
#header nav.pc_menu ul.upper li.flex .link_tel a .icon {
  width: 2rem;
  aspect-ratio: 1/1;
  background: url(../img/icon_tel.svg) center/contain no-repeat;
}
#header nav.pc_menu ul.upper li.flex .link_tel a p {
  font-size: 1.6rem;
  font-weight: bold;
}
#header nav.pc_menu ul.upper li.flex .link_tel a p small {
  display: block;
  font-size: 1rem;
  font-weight: bold;
  line-height: 1;
}
#header nav.pc_menu ul.upper li.flex .link_tel a p span {
  font-size: 1.2rem;
  font-weight: bold;
  margin-right: 0.5rem;
}
#header nav.pc_menu ul.main_link {
  margin-top: min(1vw, 2rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(2vw, 4rem);
}
@media print, screen and (min-width: 1024px) {
  #header nav.pc_menu ul.main_link > li > a {
    position: relative;
    height: 100%;
    display: grid;
    place-items: center;
    font-size: 1.5rem;
    font-weight: bold;
  }
  #header nav.pc_menu ul.main_link > li > a::after {
    content: "";
    width: 0;
    height: 0.2rem;
    background-color: #00af54;
    border-radius: 9999px;
    position: absolute;
    top: 90%;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
    opacity: 0;
  }
  #header nav.pc_menu ul.main_link > li > a:hover::after {
    opacity: 1;
    width: calc(100% + 1rem);
  }
}
#header nav.pc_menu ul.sub_link {
  position: absolute;
  top: 100%;
  background-color: #f1f1f1;
  padding: 1em 1.5em;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#header nav.pc_menu ul.sub_link li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#header nav.pc_menu ul.sub_link li::before {
  content: "-";
  margin-right: 0.5em;
}
#header nav.pc_menu ul.sub_link li a {
  font-size: 1.5rem;
  line-height: 2.2;
}
#header nav.pc_menu ul.sub_link li a:hover {
  color: #00af54;
}
#header nav.pc_menu ul.main_link > li > a:hover + ul.sub_link,
#header nav.pc_menu ul.sub_link:hover {
  opacity: 1;
  visibility: visible;
}
#header nav.pc_menu ul.main_link > li:hover > a::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#header nav.contact ul li a {
  width: 5rem;
  height: 5rem;
  background-color: #00af54;
  border: 0.1rem solid #00af54;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
@media print, screen and (min-width: 480px) {
  #header nav.contact ul li a {
    width: 16.5rem;
    border-radius: 0;
  }
}
#header nav.contact ul li a .icon {
  width: 60%;
  aspect-ratio: 3/2;
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  background-color: #fff;
}
@media print, screen and (min-width: 480px) {
  #header nav.contact ul li a .icon {
    width: 2rem;
  }
}
#header nav.contact ul li a p {
  display: none;
}
@media print, screen and (min-width: 480px) {
  #header nav.contact ul li a p {
    display: block;
    color: #fff;
    font-size: 1.5rem;
    position: relative;
    top: -0.1em;
  }
}
#header nav.contact ul li a:hover {
  background-color: #fff;
}
#header nav.contact ul li a:hover .icon {
  background-color: #00af54;
}
#header nav.contact ul li a:hover p {
  color: #00af54;
}
#header .menu_toggle {
  position: relative;
  margin-left: min(4vw, 2rem);
  width: 4rem;
  height: 100%;
  padding: 0 min(3vw, 2rem);
}
@media print, screen and (min-width: 1024px) {
  #header .menu_toggle {
    display: none;
  }
}
#header .menu_toggle span {
  display: inline-block;
  width: 4rem;
  height: 0.3rem;
  background-color: #00af54;
  border-radius: 9999px;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#header .menu_toggle span:nth-of-type(1) {
  top: 50%;
}
#header .menu_toggle span:nth-of-type(2) {
  top: calc(50% - 1rem);
}
#header .menu_toggle span:nth-of-type(3) {
  top: calc(50% + 1rem);
}
#header .menu_toggle.active span:nth-of-type(1) {
  opacity: 0;
}
#header .menu_toggle.active span:nth-of-type(2) {
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
#header .menu_toggle.active span:nth-of-type(3) {
  top: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
#header .overlay {
  position: absolute;
  left: 0;
  width: 100%;
  background-color: #fff;
  -webkit-transform: translateX(100vw);
          transform: translateX(100vw);
  opacity: 0;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  overflow-y: scroll;
}
#header .overlay.active {
  -webkit-transform: translateX(0);
          transform: translateX(0);
  opacity: 1;
}
#header nav.sp_menu {
  padding: clamp(4rem, 8vw, 8rem);
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
#header nav.sp_menu ul.main_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem;
}
#header nav.sp_menu ul.main_link > li > a {
  display: inline-block;
  font-size: 2rem;
  font-weight: bold;
}
#header nav.sp_menu ul.main_link > li > a.recruit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
#header nav.sp_menu ul.main_link > li > a.recruit::after {
  content: "";
  width: 1em;
  height: 1em;
  -webkit-mask: url(../img/icon_roundarrow.svg) center/contain no-repeat;
          mask: url(../img/icon_roundarrow.svg) center/contain no-repeat;
  background-color: #1a1a1a;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
#header nav.sp_menu ul.sub_link li {
  margin-top: 0.5rem;
}
#header nav.sp_menu ul.sub_link li a {
  display: inline-block;
  font-size: 1.8rem;
}
#header nav.sp_menu ul.sub_link li a::before {
  content: "-";
  margin-right: 1rem;
}

#footer .fixed_menu {
  display: none;
}
@media print, screen and (min-width: 1024px) {
  #footer .fixed_menu {
    display: block;
    position: fixed;
    right: 0;
    bottom: 0;
    z-index: 10;
  }
}
#footer .fixed_menu ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem 0;
  width: 13rem;
  height: clamp(7rem, 6vw, 10.5rem);
}
#footer .fixed_menu ul li a .icon {
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  background-color: #fff;
}
#footer .fixed_menu ul li a p {
  color: #fff;
  font-size: 1.4rem;
  font-weight: bold;
}
#footer .fixed_menu ul li a.contact {
  border: 0.1rem solid #00af54;
  background-color: #00af54;
}
#footer .fixed_menu ul li a.contact .icon {
  width: 3rem;
  aspect-ratio: 30/23;
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
}
#footer .fixed_menu ul li a.product {
  border: 0.1rem solid #ef271b;
  background-color: #ef271b;
}
#footer .fixed_menu ul li a.product .icon {
  width: 4.2rem;
  aspect-ratio: 42/23;
  -webkit-mask-image: url(../img/icon_container.svg);
          mask-image: url(../img/icon_container.svg);
}
#footer .fixed_menu ul li a:hover {
  background-color: #fff;
}
#footer .fixed_menu ul li a:hover.contact .icon {
  background-color: #00af54;
}
#footer .fixed_menu ul li a:hover.contact p {
  color: #00af54;
}
#footer .fixed_menu ul li a:hover.product .icon {
  background-color: #ef271b;
}
#footer .fixed_menu ul li a:hover.product p {
  color: #ef271b;
}
#footer section.contact {
  background: url(../img/footer_contact_bg.webp) center/cover no-repeat;
}
#footer section.contact * {
  color: #fff;
}
#footer section.contact .contact_way {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4rem 0;
}
@media print, screen and (min-width: 768px) {
  #footer section.contact .contact_way {
    position: relative;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 min(8vw, 16rem);
  }
  #footer section.contact .contact_way::before {
    content: "";
    width: 0.1rem;
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
#footer section.contact .contact_way * {
  color: #fff;
}
#footer section.contact .contact_way dl {
  width: 100%;
  max-width: 38.5rem;
}
@media print, screen and (min-width: 768px) {
  #footer section.contact .contact_way dl {
    padding: min(2vw, 4rem) 0;
  }
}
#footer section.contact .contact_way dl dt {
  font-size: 2rem;
  font-weight: bold;
  border-left: 0.5rem solid #fff;
  padding-left: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  #footer section.contact .contact_way dl dt {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}
#footer section.contact .contact_way dl dd .mail_link a {
  position: relative;
  height: min(17vw, 8.5rem);
  border: 0.1rem solid #fff;
  padding: 0 min(4vw, 4rem);
  display: grid;
  place-items: center;
}
#footer section.contact .contact_way dl dd .mail_link a:hover {
  background-color: rgba(255, 255, 255, 0.2);
}
#footer section.contact .contact_way dl dd .mail_link a .icon {
  width: 3rem;
  height: 2.5rem;
  -webkit-mask: url(../img/icon_mail.svg) center/contain no-repeat;
          mask: url(../img/icon_mail.svg) center/contain no-repeat;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: min(4vw, 4rem);
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
#footer section.contact .contact_way dl dd .mail_link a p {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #footer section.contact .contact_way dl dd .tel_link a {
    height: 8.5rem;
  }
}
#footer section.contact .contact_way dl dd .tel_link a p {
  font-size: min(8vw, 4rem);
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #footer section.contact .contact_way dl dd .tel_link a p {
    font-size: min(4vw, 4rem);
  }
}
#footer section.contact .contact_way dl dd .tel_link a p small {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #footer section.footer_bottom .inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media print, screen and (min-width: 768px) {
  #footer section.footer_bottom .area_left {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#footer section.footer_bottom p.logo {
  width: 18.5rem;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  #footer section.footer_bottom p.logo {
    margin: 0;
  }
}
#footer section.footer_bottom p.logo a:hover {
  opacity: 0.5;
}
#footer section.footer_bottom p.logo a img {
  width: 20rem;
  max-width: none;
}
#footer section.footer_bottom address {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 2rem auto 0;
}
#footer section.footer_bottom address p {
  font-weight: bold;
}
#footer section.footer_bottom address p + p {
  margin-top: 2rem;
}
#footer section.footer_bottom address p a {
  display: inline;
}
#footer section.footer_bottom nav.footer_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 min(4vw, 8rem);
}
#footer section.footer_bottom nav.footer_nav ul.main_link.left {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #footer section.footer_bottom nav.footer_nav ul.main_link.left {
    display: block;
  }
}
#footer section.footer_bottom nav.footer_nav ul.main_link.left li + li {
  margin-top: min(4vw, 4rem);
}
#footer section.footer_bottom nav.footer_nav ul.main_link.left li a {
  font-weight: bold;
  border-left: 0.1rem solid #1a1a1a;
  padding-left: 2rem;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.left li a:hover {
  color: #00af54;
  border-color: #00af54;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right {
  margin: 0 auto;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li + li {
  margin-top: 2rem;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li:not(.sp_visible) {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #footer section.footer_bottom nav.footer_nav ul.main_link.right li:not(.sp_visible) {
    display: block;
  }
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a {
  width: clamp(18rem, 23vw, 23rem);
  height: 5.5rem;
  border: 0.1rem solid;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 2rem;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a .icon {
  width: 3rem;
  -webkit-mask: center/contain no-repeat;
          mask: center/contain no-repeat;
  background-color: #fff;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a .icon.company {
  height: 2.2rem;
  -webkit-mask-image: url(../img/icon_company.svg);
          mask-image: url(../img/icon_company.svg);
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a .icon.mail {
  height: 2rem;
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a .icon.instagram {
  height: 3rem;
  background: url(../img/icon_instagram.webp) center/contain no-repeat;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a p {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  color: #fff;
  font-weight: bold;
  text-align: center;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a.company {
  background-color: #ef271b;
  border-color: #ef271b;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a.contact {
  background-color: #00af54;
  border-color: #00af54;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a.instagram p {
  color: #1a1a1a;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a.qr_code {
  width: 15rem;
  height: auto;
  border: none;
  padding: 0;
  margin: 0 auto;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.company {
  background-color: #fff;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.company .icon {
  background-color: #ef271b;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.company p {
  color: #ef271b;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.contact {
  background-color: #fff;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.contact .icon {
  background-color: #00af54;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.contact p {
  color: #00af54;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.instagram {
  background-color: #1a1a1a;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.instagram p {
  color: #fff;
}
#footer section.footer_bottom nav.footer_nav ul.main_link.right li a:hover.qr_code {
  opacity: 0.5;
}
#footer .to_top {
  position: fixed;
  right: min(4vw, 2.5rem);
  bottom: min(4vw, 2.5rem);
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(20rem);
          transform: translateY(20rem);
  -webkit-transition: 1s;
  transition: 1s;
}
@media print, screen and (min-width: 1024px) {
  #footer .to_top {
    right: 14rem;
  }
}
#footer .to_top.active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
#footer .to_top a {
  position: relative;
  width: 6rem;
  aspect-ratio: 1/1;
  border: 0.1rem solid #fff;
  background-color: #00af54;
  border-radius: 50%;
}
#footer .to_top a::before {
  content: "";
  width: 0.8em;
  aspect-ratio: 1/1;
  border-top: 0.2rem solid #fff;
  border-right: 0.2rem solid #fff;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
  -webkit-animation: float 1.5s infinite linear;
          animation: float 1.5s infinite linear;
  opacity: 0;
}
#footer .to_top a:hover {
  border-radius: 0;
}
#footer .to_top a:hover::before {
  opacity: 1;
  top: 55%;
  -webkit-animation: none;
          animation: none;
}
#footer p.copyright {
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
  padding: 1.75em 0;
  background-color: #ef271b;
}
@media print, screen and (min-width: 400px) {
  #footer p.copyright {
    padding-bottom: 1.75em;
  }
}

@-webkit-keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fade {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes float {
  0% {
    opacity: 0;
    top: 80%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 40%;
  }
}
@keyframes float {
  0% {
    opacity: 0;
    top: 80%;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    top: 40%;
  }
}
#top header nav.pc_menu ul li a.nav_top::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#top header nav.sp_menu ul li a.nav_top {
  color: #00af54;
}
#top footer section.contact {
  display: none;
}
#top main {
  padding-top: 0 !important;
}
@media print, screen and (min-width: 768px) {
  #top .title_area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#top header.top_section_title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem 0;
}
@media print, screen and (min-width: 768px) {
  #top header.top_section_title {
    margin: 0;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    gap: 0 2rem;
  }
}
#top header.top_section_title h2,
#top header.top_section_title span {
  color: #ef271b;
  font-weight: bold;
  line-height: 1;
}
#top header.top_section_title h2 {
  font-size: min(3.6vw, 1.8rem);
}
@media print, screen and (min-width: 1024px) {
  #top header.top_section_title h2 {
    font-size: min(2.5vw, 2rem);
  }
}
#top header.top_section_title span {
  font-size: min(9.6vw, 4.8rem);
  text-box: trim-both cap alphabetic;
}
@media print, screen and (min-width: 768px) {
  #top header.top_section_title span::before {
    content: "・";
  }
}
@media print, screen and (min-width: 1024px) {
  #top header.top_section_title span {
    font-size: min(3.5vw, 5.6rem);
  }
}
#top .detail_link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#top .detail_link.visible_under768 {
  margin: clamp(4rem, 3.5vw, 6.4rem) auto 0;
}
@media print, screen and (min-width: 768px) {
  #top .detail_link.visible_under768 {
    display: none;
  }
}
#top .detail_link.visible_over768 {
  display: none;
}
@media print, screen and (min-width: 768px) {
  #top .detail_link.visible_over768 {
    display: block;
  }
}
#top .detail_link a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1.5rem;
}
#top .detail_link a p {
  color: #ef271b;
  font-size: 1.8rem;
  font-weight: bold;
  border-bottom: 0.1rem solid #ef271b;
}
#top .detail_link a .icon {
  position: relative;
  width: 3.5rem;
  aspect-ratio: 1/1;
  border: 0.4rem solid #ef271b;
  border-radius: 50%;
}
#top .detail_link a .icon::before {
  content: "";
  width: 35%;
  aspect-ratio: 1/1;
  border-top: 2px solid #ef271b;
  border-right: 2px solid #ef271b;
  position: absolute;
  top: 51%;
  left: 45%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#top .detail_link a:hover .icon {
  background-color: #ef271b;
}
#top .detail_link a:hover .icon::before {
  border-color: #fff;
}
#top section.top_fv {
  position: relative;
  width: 100%;
  height: 100vh;
  background: url(../img/top/fv.webp) 60%/cover no-repeat;
  overflow: hidden;
  -webkit-animation: bg-zoom 5s forwards;
          animation: bg-zoom 5s forwards;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_fv {
    max-height: 92rem;
  }
}
#top section.top_fv .inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -40%);
          transform: translate(-50%, -40%);
}
#top section.top_fv header * {
  color: #fff;
  text-shadow: 0 0 0.3rem #333;
}
@media print, screen and (min-width: 768px) {
  #top section.top_fv header * {
    text-shadow: none;
  }
}
#top section.top_fv header h2 {
  font-size: 1.5rem;
  opacity: 0;
  -webkit-animation: fade 1s 0.5s forwards;
          animation: fade 1s 0.5s forwards;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_fv header h2 {
    font-size: min(1.045vw, 2rem);
  }
}
#top section.top_fv header h3 {
  font-size: min(7.5vw, 4.8rem);
  line-height: 1.4;
  opacity: 0;
  -webkit-animation: fade 1s 1.5s forwards;
          animation: fade 1s 1.5s forwards;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_fv header h3 {
    font-size: min(3.35vw, 6.4rem);
  }
}
#top section.top_fv header h4 {
  margin-top: min(2vw, 2rem);
  font-size: min(3.6vw, 1.8rem);
  opacity: 0;
  -webkit-animation: fade 1s 2.5s forwards;
          animation: fade 1s 2.5s forwards;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_fv header h4 {
    font-size: min(1.25vw, 2.4rem);
  }
}
@media print, screen and (min-width: 768px) {
  #top section.top_products p.note {
    text-align: center;
  }
}
#top section.top_products ul.product_list {
  margin-top: 4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: min(4vw, 4rem);
}
#top section.top_products ul.product_list li {
  width: calc((100% - min(4vw, 4rem)) / 2);
}
@media print, screen and (min-width: 1024px) {
  #top section.top_products ul.product_list li {
    width: calc((100% - min(4vw, 4rem) * 3) / 4);
  }
}
#top section.top_products ul.product_list li a {
  border-radius: 0.8rem;
  overflow: hidden;
  -webkit-box-shadow: 0 1rem 1.5rem rgba(0, 0, 0, 0.1);
          box-shadow: 0 1rem 1.5rem rgba(0, 0, 0, 0.1);
}
#top section.top_products ul.product_list li a figure {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#top section.top_products ul.product_list li a figure .container_img {
  overflow: hidden;
}
#top section.top_products ul.product_list li a figure .container_img img {
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#top section.top_products ul.product_list li a figure figcaption {
  padding: min(5vw, 2.5rem) 0;
}
#top section.top_products ul.product_list li a figure figcaption::after {
  content: "";
  display: block;
  width: 0.8em;
  aspect-ratio: 1/0.75;
  background-color: #ef271b;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  margin: min(4vw, 2rem) auto 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#top section.top_products ul.product_list li a:hover figure .container_img img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
#top section.top_example {
  position: relative;
}
#top section.top_example::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: #f1efe7;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -99999;
}
#top section.top_example .swiper_container {
  padding-bottom: clamp(6rem, 5vw, 9.5rem);
  position: relative;
}
#top section.top_example .swiper_container figure.swiper-slide a .img {
  overflow: hidden;
}
#top section.top_example .swiper_container figure.swiper-slide a .img img {
  aspect-ratio: 445/280;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#top section.top_example .swiper_container figure.swiper-slide a:hover .img img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
#top section.top_example .swiper_container figure.swiper-slide figcaption {
  margin-top: 2rem;
}
#top section.top_example .swiper_container figure.swiper-slide figcaption p.prefecture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
  font-size: 1.4rem;
}
#top section.top_example .swiper_container figure.swiper-slide figcaption p.prefecture::before {
  content: "";
  display: block;
  width: 1.7rem;
  aspect-ratio: 17/25;
  background: url(../img/top/icon_pin.svg) center/contain no-repeat;
}
#top section.top_example .swiper_container figure.swiper-slide figcaption p.usage {
  font-size: 2.4rem;
}
#top section.top_example .swiper_container figure.swiper-slide figcaption ul.tag_list {
  margin-top: min(4vw, 4rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}
#top section.top_example .swiper_container figure.swiper-slide figcaption ul.tag_list li {
  color: #4d4d4d;
  font-size: 1.2rem;
  border: 0.1rem solid #969799;
  border-radius: 0.4rem;
  padding: 0.3em 1em;
}
#top section.top_example .swiper_container .swiper-pagination {
  position: absolute;
  bottom: 0;
}
#top section.top_example .swiper_container .swiper-pagination-bullet {
  width: 1.5rem;
  height: 1.5rem;
  margin: 0 1.5rem;
}
#top section.top_example .swiper_container .swiper-pagination-bullet-active {
  background-color: #ef271b;
}
#top section.top_example .swiper_container .swiper-pagination-bullet.hidden {
  display: none;
}
#top section.top_example .swiper_container .swiper-button-prev, #top section.top_example .swiper_container .swiper-button-next {
  top: 25vw;
  width: 5.5rem;
  height: 5.5rem;
  background-color: #1a1a1a;
  border-radius: 50%;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
@media print, screen and (min-width: 768px) {
  #top section.top_example .swiper_container .swiper-button-prev, #top section.top_example .swiper_container .swiper-button-next {
    top: 12.5vw;
  }
}
@media print, screen and (min-width: 1280px) {
  #top section.top_example .swiper_container .swiper-button-prev, #top section.top_example .swiper_container .swiper-button-next {
    top: 6.5vw;
  }
}
#top section.top_example .swiper_container .swiper-button-prev::after, #top section.top_example .swiper_container .swiper-button-next::after {
  content: "";
  width: 30%;
  aspect-ratio: 1/1;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
}
#top section.top_example .swiper_container .swiper-button-prev:hover, #top section.top_example .swiper_container .swiper-button-next:hover {
  background-color: #ef271b;
}
#top section.top_example .swiper_container .swiper-button-prev {
  left: 2.5vw;
}
@media print, screen and (min-width: 1280px) {
  #top section.top_example .swiper_container .swiper-button-prev {
    left: 8vw;
  }
}
#top section.top_example .swiper_container .swiper-button-prev::after {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
  position: relative;
  left: 0.2rem;
}
#top section.top_example .swiper_container .swiper-button-next {
  right: 2.5vw;
}
@media print, screen and (min-width: 1280px) {
  #top section.top_example .swiper_container .swiper-button-next {
    right: 8vw;
  }
}
#top section.top_example .swiper_container .swiper-button-next::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: relative;
  right: 0.2rem;
}
#top section.top_flow .inner {
  position: relative;
  overflow: visible;
}
#top section.top_flow ul.flow_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_flow ul.flow_list {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: min(4.5vw, 8rem) min(5.5vw, 10rem);
  }
}
#top section.top_flow ul.flow_list li {
  padding: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_flow ul.flow_list li {
    width: calc((100% - min(5.5vw, 10rem)) / 2);
    border-left: 0.1rem solid #ef271b;
    padding-left: 2.5rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
#top section.top_flow ul.flow_list li dl dt {
  font-size: 2rem;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 2rem;
}
#top section.top_flow ul.flow_list li dl dt .icon {
  width: min(10vw, 4.3rem);
  aspect-ratio: 43/36;
  background: center/contain no-repeat;
}
#top section.top_flow ul.flow_list li dl dt .icon.attention {
  background-image: url(../img/top/icon_attention.svg);
}
#top section.top_flow ul.flow_list li dl dt .icon.cart {
  background-image: url(../img/icon_cart.svg);
}
#top section.top_flow ul.flow_list li dl dt .icon.map {
  background-image: url(../img/top/icon_map.svg);
}
#top section.top_flow ul.flow_list li dl dd {
  margin-top: 2rem;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_flow ul.flow_list li dl dd {
    padding-left: 6.3rem;
  }
}
#top section.top_flow ul.flow_list li .detail_link {
  margin: 2rem auto 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_flow ul.flow_list li .detail_link {
    margin: 4rem 0 0 auto;
  }
}
#top section.top_flow ul.flow_list li .detail_link a {
  margin: 0 auto;
}
#top section.top_contact {
  background: url(../img/footer_contact_bg.webp) center/cover no-repeat;
}
#top section.top_contact * {
  color: #fff;
}
#top section.top_contact .contact_way {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4rem 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_contact .contact_way {
    position: relative;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 min(8vw, 16rem);
  }
  #top section.top_contact .contact_way::before {
    content: "";
    width: 0.1rem;
    height: 100%;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
#top section.top_contact .contact_way * {
  color: #fff;
}
#top section.top_contact .contact_way dl {
  width: 100%;
  max-width: 38.5rem;
}
@media print, screen and (min-width: 768px) {
  #top section.top_contact .contact_way dl {
    padding: min(2vw, 4rem) 0;
  }
}
#top section.top_contact .contact_way dl dt {
  font-size: 2rem;
  font-weight: bold;
  border-left: 0.5rem solid #fff;
  padding-left: 1.5rem;
}
@media print, screen and (min-width: 768px) {
  #top section.top_contact .contact_way dl dt {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
  }
}
#top section.top_contact .contact_way dl dd .mail_link a {
  position: relative;
  height: min(17vw, 8.5rem);
  border: 0.1rem solid #fff;
  padding: 0 min(4vw, 4rem);
  display: grid;
  place-items: center;
}
#top section.top_contact .contact_way dl dd .mail_link a:hover {
  background-color: rgba(255, 255, 255, 0.2);
}
#top section.top_contact .contact_way dl dd .mail_link a .icon {
  width: 3rem;
  height: 2.5rem;
  -webkit-mask: url(../img/icon_mail.svg) center/contain no-repeat;
          mask: url(../img/icon_mail.svg) center/contain no-repeat;
  background-color: #fff;
  position: absolute;
  top: 50%;
  left: min(4vw, 4rem);
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
#top section.top_contact .contact_way dl dd .mail_link a p {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #top section.top_contact .contact_way dl dd .tel_link a {
    height: 8.5rem;
  }
}
#top section.top_contact .contact_way dl dd .tel_link a p {
  font-size: min(8vw, 4rem);
  font-weight: bold;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #top section.top_contact .contact_way dl dd .tel_link a p {
    font-size: min(4vw, 4rem);
  }
}
#top section.top_contact .contact_way dl dd .tel_link a p small {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
}
#top section.top_news ul.latest_news {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(8vw, 4rem) 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_news ul.latest_news {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 4rem;
  }
}
#top section.top_news ul.latest_news li {
  width: 100%;
  max-width: 56rem;
}
@media print, screen and (min-width: 768px) {
  #top section.top_news ul.latest_news li {
    width: calc((100% - 4rem) / 2);
    max-width: none;
  }
}
#top section.top_news ul.latest_news li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: min(4vw, 2rem) 0;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_news ul.latest_news li a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 min(2.4vw, 4rem);
  }
}
#top section.top_news ul.latest_news li a .image_area {
  aspect-ratio: 18/12;
  border: 0.1rem solid #cecece;
  overflow: hidden;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_news ul.latest_news li a .image_area {
    width: 18rem;
  }
}
#top section.top_news ul.latest_news li a .text_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(2vw, 2rem) 2rem;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_news ul.latest_news li a .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#top section.top_news ul.latest_news li a .text_area p.date {
  color: #4d4d4d;
  font-size: 1.4rem;
}
#top section.top_news ul.latest_news li a .text_area p.category {
  color: #4d4d4d;
  font-size: 1.2rem;
  text-align: center;
  width: 9rem;
  border: 0.1rem solid #4d4d4d;
  padding: 0.2em 0;
}
#top section.top_news ul.latest_news li a .text_area h3.title {
  width: 100%;
}
#top section.top_news ul.latest_news li a:hover .text_area p {
  color: #00af54;
  border-color: #00af54;
}
#top section.top_news ul.latest_news li a:hover .text_area h3.title {
  color: #00af54;
}
#top section.top_company {
  position: relative;
  padding: clamp(6rem, 6.5vw, 12rem) 0;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company {
    padding: min(13.5vw, 25rem) 0;
  }
}
#top section.top_company::before {
  content: "";
  width: 95%;
  max-width: 1800px;
  height: 100%;
  background: url(../img/top/company_bg.webp) center/cover;
  border-radius: 2rem;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  z-index: -99999;
}
#top section.top_company header.top_section_title h2,
#top section.top_company header.top_section_title span {
  color: #fff;
}
#top section.top_company .introduction {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: min(4vw, 4rem) 0;
}
@media print, screen and (min-width: 768px) {
  #top section.top_company .introduction {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
#top section.top_company .introduction * {
  color: #fff;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction .area_left {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding-right: min(10vw, 18rem);
  }
}
#top section.top_company .introduction h3 {
  font-size: min(6.4vw, 3.2rem);
  font-weight: bold;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction h3 {
    font-size: min(2.4vw, 3.2rem);
  }
}
#top section.top_company .introduction p {
  margin-top: 2rem;
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction .area_right {
    width: 40.5rem;
  }
}
#top section.top_company .introduction ul.link_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(4vw, 4rem);
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction ul.link_list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
#top section.top_company .introduction ul.link_list li {
  width: 100%;
  max-width: 25rem;
  border-bottom: 0.1rem solid #fff;
}
@media print, screen and (min-width: 480px) {
  #top section.top_company .introduction ul.link_list li {
    width: calc((100% - 2 * min(4vw, 4rem)) / 3);
  }
}
@media print, screen and (min-width: 1024px) {
  #top section.top_company .introduction ul.link_list li {
    width: 100%;
  }
}
#top section.top_company .introduction ul.link_list li a {
  position: relative;
  font-size: 1.8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1em 0;
}
#top section.top_company .introduction ul.link_list li a::before {
  content: "";
  width: 1.5em;
  aspect-ratio: 1/1;
  background-color: #fff;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
  opacity: 0;
}
#top section.top_company .introduction ul.link_list li a::after {
  content: "";
  width: 0.5em;
  aspect-ratio: 1/1;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
  top: 50%;
  right: 0.55em;
  -webkit-transform: translate(0, -50%) rotate(45deg);
          transform: translate(0, -50%) rotate(45deg);
}
#top section.top_company .introduction ul.link_list li a:hover::before {
  opacity: 1;
}
#top section.top_company .introduction ul.link_list li a:hover::after {
  border-color: #1a1a1a;
}
#top section.top_company .detail_link a p {
  color: #fff;
  border-color: #fff;
}
#top section.top_company .detail_link a .icon {
  border-color: #fff;
}
#top section.top_company .detail_link a .icon::before {
  border-color: #fff;
}
#top section.top_company .detail_link a:hover .icon {
  background-color: #fff;
}
#top section.top_company .detail_link a:hover .icon::before {
  border-color: #1a1a1a;
}

#page-company header nav.pc_menu ul li .link_company a {
  color: #00af54;
}
#page-company header nav.pc_menu ul li a.nav_access::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#page-company header nav.sp_menu ul li a.nav_company {
  color: #00af54;
}
#page-company .anchor_list ul {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 768px) {
  #page-company .anchor_list ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
#page-company .anchor_list ul li {
  width: 100%;
  max-width: 30rem;
  border-right: 0.1rem solid #1a1a1a;
}
@media print, screen and (min-width: 768px) {
  #page-company .anchor_list ul li {
    width: 25%;
  }
  #page-company .anchor_list ul li:not(:last-of-type) {
    border-right: none;
  }
}
@media print, screen and (min-width: 768px) {
  #page-company .anchor_list ul li a {
    padding: 0 4rem;
  }
}
#page-company section.greeting .inner {
  max-width: 72rem;
}
#page-company section.greeting .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 2rem 4rem;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greeting .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
#page-company section.greeting .message {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greeting .message {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.greeting .message p + p {
  margin-top: 1em;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greeting .message p + p {
    margin-top: 4rem;
  }
}
#page-company section.greeting .message p strong {
  font-size: min(6vw, 2.4rem);
  font-weight: bold;
}
#page-company section.greeting .ceo_img {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  width: 100%;
  max-width: 40rem;
  margin: 0 auto;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greeting .ceo_img {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    width: 45%;
    max-width: 52rem;
    margin: 0;
  }
}
#page-company section.greeting .ceo_name {
  -webkit-box-ordinal-group: 4;
      -ms-flex-order: 3;
          order: 3;
}
@media print, screen and (min-width: 1024px) {
  #page-company section.greeting .ceo_name {
    width: 100%;
  }
}
#page-company section.greeting .ceo_name p {
  width: 23rem;
  margin-left: auto;
}
#page-company section.greeting .ceo_name p img {
  max-width: none;
}
#page-company section.profile {
  background-color: #f0f0f0;
}
#page-company section.profile dl.profile_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.profile dl.profile_list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
#page-company section.profile dl.profile_list dt {
  background-color: #fff;
  padding: 1em min(4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.profile dl.profile_list dt {
    width: calc(30% - 1rem);
    display: grid;
    place-items: center;
  }
}
#page-company section.profile dl.profile_list dt span {
  display: inline-block;
  width: 5em;
  font-weight: bold;
  -moz-text-align-last: justify;
       text-align-last: justify;
}
#page-company section.profile dl.profile_list dd {
  background-color: #fff;
  padding: 1em min(4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-company section.profile dl.profile_list dd {
    width: 70%;
  }
}
#page-company section.profile dl.profile_list dd a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-item-align: center;
      align-self: center;
  gap: 0 0.5rem;
  color: #3fa7f3;
  text-decoration: underline;
}
#page-company section.profile dl.profile_list dd a::after {
  content: "";
  width: 1em;
  aspect-ratio: 1/1;
  -webkit-mask: url(../img/company/icon_window.svg) center/contain no-repeat;
          mask: url(../img/company/icon_window.svg) center/contain no-repeat;
  background-color: #3fa7f3;
}
#page-company section.profile dl.profile_list dd a:hover {
  color: #fff;
  background-color: #3fa7f3;
}
#page-company section.profile dl.profile_list dd a:hover::after {
  background-color: #fff;
}
#page-company section.access .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem 4rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.access .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
#page-company section.access dl.office_info dt {
  text-align: center;
  background-color: #ef271b;
  padding: 0.3em 0;
}
#page-company section.access dl.office_info dt span {
  display: inline-block;
  width: 3em;
  color: #fff;
  font-size: 2rem;
  font-weight: bold;
  -moz-text-align-last: justify;
       text-align-last: justify;
}
#page-company section.access dl.office_info dd {
  margin-top: min(4vw, 4rem);
}
#page-company section.access dl.office_info dd address p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0 1em;
}
#page-company section.access dl.office_info dd address p span {
  display: inline-block;
}
#page-company section.access .office_img {
  max-width: 64rem;
}
@media print, screen and (min-width: 768px) {
  #page-company section.access .office_img {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-company section.history {
  background-color: #f0f0f0;
}
#page-company section.history dl.history_flow {
  border-top: 0.1rem solid #b1b1b1;
}
@media print, screen and (min-width: 768px) {
  #page-company section.history dl.history_flow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
#page-company section.history dl.history_flow dt {
  font-weight: bold;
  padding-top: 1em;
}
@media print, screen and (min-width: 768px) {
  #page-company section.history dl.history_flow dt {
    width: 20%;
    text-align: right;
    border-bottom: 0.1rem solid #b1b1b1;
    padding: 1.5em 0;
  }
}
#page-company section.history dl.history_flow dd {
  margin-top: 0.5rem;
  padding: 0 0 1em 1em;
  border-bottom: 0.1rem solid #b1b1b1;
}
@media print, screen and (min-width: 768px) {
  #page-company section.history dl.history_flow dd {
    margin-top: 0;
    width: 80%;
    padding: 1.5em min(5.5vw, 10rem) 1.5em min(7.5vw, 14rem);
  }
}

#page-product header nav.pc_menu ul li a.nav_product::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#page-product header nav.sp_menu ul li a.nav_product {
  color: #00af54;
}
#page-product footer nav.footer_nav ul li a.nav_product {
  color: #00af54;
  border-color: #00af54 !important;
}
#page-product .anchor_list ul li a {
  font-size: min(3.5vw, 1.6rem);
}
@media print, screen and (min-width: 768px) {
  #page-product .anchor_list ul li a {
    font-size: min(1.75vw, 1.6rem);
  }
}
#page-product section.container h2 {
  color: #fff;
  font-size: min(5vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background-color: #ef271b;
  padding: 0.8em 0;
}
#page-product section.container ul.container_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(4rem, 4.5vw, 8rem) 2rem;
}
#page-product section.container ul.container_list li {
  width: calc((100% - 2rem) / 2);
}
@media print, screen and (min-width: 768px) {
  #page-product section.container ul.container_list li {
    width: calc((100% - 4rem) / 3);
  }
}
#page-product section.container ul.container_list li a figure .img {
  width: 100%;
  max-width: 38.5rem;
  aspect-ratio: 386/309;
  overflow: hidden;
}
#page-product section.container ul.container_list li a figure .img img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
#page-product section.container ul.container_list li a figure figcaption {
  margin-top: 1rem;
}
#page-product section.container ul.container_list li a figure figcaption p.color {
  width: 8.5rem;
  height: 2.2rem;
  display: grid;
  place-items: center;
  color: #b1b1b1;
  font-size: 1.2rem;
  border: 0.1rem solid #b1b1b1;
}
#page-product section.container ul.container_list li a figure figcaption h3.name {
  margin-top: 2rem;
  text-align: center;
  text-decoration: underline;
}
@media print, screen and (min-width: 1024px) {
  #page-product section.container ul.container_list li a figure figcaption h3.name {
    text-decoration: none;
  }
}
#page-product section.container ul.container_list li a:hover figure .img img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
#page-product section.container_detail .type {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 2rem;
}
#page-product section.container_detail .type p {
  width: 12rem;
  height: 2.8rem;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 1.4rem;
}
#page-product section.container_detail .type p.condition {
  background-color: #00af54;
}
#page-product section.container_detail .type p.color {
  background-color: #b1b1b1;
}
#page-product section.container_detail h2.name {
  margin: 2rem auto 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(6.4vw, 3.2rem);
}
#page-product section.container_detail .image_area {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: min(4vw, 4rem);
}
#page-product section.container_detail .image_area .main {
  width: 100%;
}
#page-product section.container_detail .image_area .main img {
  max-width: none;
  aspect-ratio: 1024/500;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
#page-product section.container_detail .image_area .sub {
  width: calc((100% - min(4vw, 4rem)) / 2);
}
#page-product section.container_detail .image_area .sub img {
  max-width: none;
  aspect-ratio: 492/320;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
@media print, screen and (min-width: 768px) {
  #page-product section.container_detail .spec_area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0 min(4vw, 4rem);
  }
}
#page-product section.container_detail .spec_area dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 0.1rem solid #b1b1b1;
  padding: min(4vw, 2rem) clamp(1rem, 2.5vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-product section.container_detail .spec_area dl {
    width: calc((100% - min(4vw, 4rem)) / 2);
  }
}
#page-product section.container_detail .spec_area dl dt {
  width: clamp(6rem, 5.5vw, 10rem);
  font-weight: bold;
  text-align: left;
  border-right: 0.1rem solid #b1b1b1;
}
#page-product section.container_detail .spec_area dl dd {
  padding-left: clamp(2rem, 2.5vw, 4rem);
}
#page-product section.container_detail .option_area p {
  font-weight: bold;
  text-align: center;
}
#page-product section.container_detail .option_area ul {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: min(2vw, 2rem);
}
#page-product section.container_detail .option_area ul li {
  width: calc((100% - min(2vw, 2rem)) / 2);
  max-width: 15.5rem;
  aspect-ratio: 155/35;
  display: grid;
  place-items: center;
  font-size: 1.4rem;
  border: 0.1rem solid #b1b1b1;
}
@media print, screen and (min-width: 480px) {
  #page-product section.container_detail .option_area ul li {
    width: calc((100% - min(2vw, 2rem) * 2) / 3);
  }
}
@media print, screen and (min-width: 1024px) {
  #page-product section.container_detail .option_area ul li {
    width: calc((100% - min(2vw, 2rem) * 5) / 6);
  }
}
#page-product section.container_detail .link_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-product section.container_detail .link_area {
    gap: 0 min(4vw, 4rem);
  }
}
#page-product section.container_detail .link_area .link {
  width: 100%;
  max-width: 49.5rem;
}
@media print, screen and (min-width: 768px) {
  #page-product section.container_detail .link_area .link {
    width: calc((100% - min(4vw, 4rem)) / 2);
  }
}
#page-product section.container_detail .link_area .link a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border: 0.1rem solid #666;
  border-radius: 0.4rem;
  padding: 1em min(4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-product section.container_detail .link_area .link a {
    display: grid;
    grid-auto-flow: column;
    place-items: center;
    gap: 0 min(4vw, 4rem);
    padding: 1em 0;
  }
}
#page-product section.container_detail .link_area .link a .icon {
  width: min(9vw, 4.5rem);
  aspect-ratio: 45/34;
  -webkit-mask: center/contain no-repeat;
          mask: center/contain no-repeat;
}
#page-product section.container_detail .link_area .link a p {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: min(5vw, 2rem);
  text-align: center;
}
#page-product section.container_detail .link_area .link a p small {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
  color: inherit;
  font-size: 1.4rem;
}
#page-product section.container_detail .link_area .link a p small::after {
  content: "";
  width: 5rem;
  aspect-ratio: 5/1;
  -webkit-mask: url(../img/product/longarrow.svg) center/contain no-repeat;
          mask: url(../img/product/longarrow.svg) center/contain no-repeat;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-product section.container_detail .link_area .link a.flow {
  background-color: #666;
}
#page-product section.container_detail .link_area .link a.flow .icon {
  -webkit-mask-image: url(../img/icon_cart.svg);
          mask-image: url(../img/icon_cart.svg);
  background-color: #fff;
}
#page-product section.container_detail .link_area .link a.flow p {
  color: #fff;
}
#page-product section.container_detail .link_area .link a.flow p small::after {
  background-color: #fff;
}
#page-product section.container_detail .link_area .link a.contact .icon {
  -webkit-mask-image: url(../img/icon_mail.svg);
          mask-image: url(../img/icon_mail.svg);
  background-color: #666;
}
#page-product section.container_detail .link_area .link a.contact p {
  color: #666;
}
#page-product section.container_detail .link_area .link a.contact p small::after {
  background-color: #666;
}
#page-product section.container_detail .link_area .link a:hover.flow {
  background-color: #fff;
}
#page-product section.container_detail .link_area .link a:hover.flow .icon {
  background-color: #666;
}
#page-product section.container_detail .link_area .link a:hover.flow p {
  color: #666;
}
#page-product section.container_detail .link_area .link a:hover.flow p small::after {
  background-color: #666;
}
#page-product section.container_detail .link_area .link a:hover.contact {
  background-color: #666;
}
#page-product section.container_detail .link_area .link a:hover.contact .icon {
  background-color: #fff;
}
#page-product section.container_detail .link_area .link a:hover.contact p {
  color: #fff;
}
#page-product section.container_detail .link_area .link a:hover.contact p small::after {
  background-color: #fff;
}

#page-flow header nav.pc_menu ul li a.nav_flow::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#page-flow header nav.sp_menu ul li a.nav_flow {
  color: #00af54;
}
#page-flow footer nav.footer_nav ul li a.nav_flow {
  color: #00af54;
  border-color: #00af54 !important;
}
#page-flow .anchor_list ul {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media print, screen and (min-width: 768px) {
  #page-flow .anchor_list ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
#page-flow .anchor_list ul li {
  width: 100%;
  max-width: 30rem;
  border-right: 0.1rem solid #1a1a1a;
}
@media print, screen and (min-width: 768px) {
  #page-flow .anchor_list ul li {
    width: auto;
  }
  #page-flow .anchor_list ul li:not(:last-of-type) {
    border-right: none;
  }
}
@media print, screen and (min-width: 768px) {
  #page-flow .anchor_list ul li a {
    padding: 0 4rem;
  }
}
@media print, screen and (min-width: 768px) {
  #page-flow section.notice p.note {
    text-align: center;
  }
}
#page-flow section.notice .notice_detail h3 {
  color: #fff;
  font-size: min(4.8vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background-color: #ef271b;
  padding: 0.5em 0;
}
#page-flow section.notice .notice_detail p {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.notice .notice_detail p {
    text-align: center;
  }
}
#page-flow section.notice .notice_detail .truck_img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 clamp(2vw, 4.5vw, 8rem);
}
#page-flow section.notice .notice_detail .truck_img figure {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(4vw, 2rem) 0;
}
#page-flow section.notice .border_area {
  border: 0.1rem solid #1a1a1a;
  padding: min(4vw, 4rem) 2rem;
}
#page-flow section.notice .border_area dl dt {
  color: #ef271b;
  font-size: min(4.8vw, 2rem);
  font-weight: bold;
  text-align: center;
}
#page-flow section.notice .border_area dl dd {
  margin-top: min(4vw, 4rem);
}
#page-flow section.notice .border_area dl dd ul {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.notice .border_area dl dd ul {
    max-width: 78rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0 min(4.5vw, 8rem);
  }
}
#page-flow section.notice .border_area dl dd ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-font-feature-settings: normal;
          font-feature-settings: normal;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.notice .border_area dl dd ul li {
    width: calc((100% - min(4.5vw, 8rem)) / 2);
  }
}
#page-flow section.notice .border_area dl dd ul li::before {
  content: "・";
}
#page-flow section.notice .border_area dl dd ul li.note::before {
  content: "※";
}
#page-flow section.notice .border_area dl dd small {
  margin-top: 2rem;
  display: block;
  font-size: min(4vw, 1.6rem);
  text-align: center;
}
#page-flow section.notice .border_area dl dd small::before {
  content: "※";
}
#page-flow section.flow .flow_list ol {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: clamp(2rem, 4vw, 4rem);
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .flow_list ol {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
#page-flow section.flow .flow_list ol li {
  width: 100%;
}
@media print, screen and (min-width: 480px) {
  #page-flow section.flow .flow_list ol li {
    width: calc((100% - clamp(2rem, 4vw, 4rem)) / 2);
  }
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .flow_list ol li {
    width: calc((100% - clamp(2rem, 4vw, 4rem) * 2) / 3);
  }
}
#page-flow section.flow .flow_list ol li span {
  color: #ef271b;
  font-size: clamp(3rem, 3.5vw, 6.2rem);
  font-weight: bold;
  line-height: 1;
}
#page-flow section.flow .flow_list ol li .radius_block {
  margin-top: 1rem;
  border-radius: 1rem;
  overflow: hidden;
}
#page-flow section.flow .flow_list ol li .radius_block h3 {
  position: relative;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  background-color: #ef271b;
  padding: 0.3em 0;
}
#page-flow section.flow .flow_list ol li .radius_block h3::after {
  content: "";
  width: 1.7rem;
  height: 1.5rem;
  background-color: #ef271b;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  position: absolute;
  top: calc(100% - 0.1rem);
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
#page-flow section.flow .flow_list ol li p {
  margin-top: 1rem;
}
#page-flow section.flow .place_deliverable {
  position: relative;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable {
    padding-bottom: min(10vw, 10rem);
  }
}
#page-flow section.flow .place_deliverable::before {
  content: "";
  width: 100%;
  max-width: 60rem;
  aspect-ratio: 603/580;
  background: url(../img/flow/map.webp) center/contain no-repeat;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: -1;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable::before {
    width: 60%;
    top: auto;
    bottom: 0;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
#page-flow section.flow .place_deliverable h3 {
  color: #fff;
  font-size: min(4.8vw, 2.4rem);
  font-weight: bold;
  text-align: center;
  background-color: #ef271b;
  padding: 0.5em 0;
}
#page-flow section.flow .place_deliverable p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable p {
    text-align: center;
  }
}
#page-flow section.flow .place_deliverable p strong {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: clamp(2rem, 4vw, 4rem) auto;
  color: #ef271b;
  font-size: min(4.8vw, 3.2rem);
}
#page-flow section.flow .place_deliverable .prefectures {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable .prefectures {
    width: auto;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    -ms-flex-pack: distribute;
        justify-content: space-around;
  }
}
#page-flow section.flow .place_deliverable .prefectures dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable .prefectures dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#page-flow section.flow .place_deliverable .prefectures dl dt {
  width: 10rem;
  color: #fe654f;
  font-size: 1.6rem;
  font-weight: bold;
  -moz-text-align-last: justify;
       text-align-last: justify;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable .prefectures dl dt {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}
#page-flow section.flow .place_deliverable .prefectures dl dt::before {
  content: "【";
}
#page-flow section.flow .place_deliverable .prefectures dl dt::after {
  content: "】";
}
#page-flow section.flow .place_deliverable .prefectures dl dd {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
#page-flow section.flow .place_deliverable .prefectures dl dd ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-flow section.flow .place_deliverable .prefectures dl dd ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
}
#page-flow section.flow .place_deliverable .prefectures dl dd ul li {
  color: #fe654f;
}

#page-example header nav.pc_menu ul li a.nav_example::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#page-example header nav.sp_menu ul li a.nav_example {
  color: #00af54;
}
#page-example footer nav.footer_nav ul li a.nav_example {
  color: #00af54;
  border-color: #00af54 !important;
}
#page-example section.example ul.example_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: min(8vw, 8rem) min(3vw, 3rem);
}
#page-example section.example ul.example_list > li {
  width: calc((100% - min(3vw, 3rem)) / 2);
}
@media print, screen and (min-width: 768px) {
  #page-example section.example ul.example_list > li {
    width: calc((100% - min(3vw, 3rem) * 2) / 3);
  }
}
#page-example section.example ul.example_list > li figure a .img {
  overflow: hidden;
}
#page-example section.example ul.example_list > li figure a .img img {
  aspect-ratio: 445/280;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-example section.example ul.example_list > li figure a:hover .img img {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
#page-example section.example ul.example_list > li figure figcaption {
  margin-top: 2rem;
}
#page-example section.example ul.example_list > li figure figcaption p.prefecture {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
  font-size: 1.4rem;
}
#page-example section.example ul.example_list > li figure figcaption p.prefecture::before {
  content: "";
  display: block;
  width: 1.7rem;
  aspect-ratio: 17/25;
  background: url(../img/top/icon_pin.svg) center/contain no-repeat;
}
#page-example section.example ul.example_list > li figure figcaption p.usage {
  font-size: min(4.8vw, 2.4rem);
}
#page-example section.example ul.example_list > li figure figcaption ul.tag_list {
  margin-top: min(4vw, 4rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}
#page-example section.example ul.example_list > li figure figcaption ul.tag_list li {
  color: #4d4d4d;
  font-size: 1.2rem;
  border: 0.1rem solid #969799;
  border-radius: 0.4rem;
  padding: 0.3em 1em;
}
#page-example section.example_detail h2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem 0;
  color: #ef271b;
  font-size: 3.2rem;
  font-size: min(6.4vw, 3.2rem);
  font-weight: bold;
  line-height: 1;
}
#page-example section.example_detail h2 span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
  color: #1a1a1a;
  font-size: 1.6rem;
  font-weight: bold;
}
#page-example section.example_detail h2 span::before {
  content: "";
  width: 1.7rem;
  aspect-ratio: 17/25;
  background: url(../img/top/icon_pin.svg) center/contain no-repeat;
}
#page-example section.example_detail .example_img {
  margin-top: 2rem;
}
#page-example section.example_detail .example_img #example-slider .swiper-slide {
  width: 100%;
  aspect-ratio: 1024/560;
}
#page-example section.example_detail .example_img #example-slider .swiper-slide img {
  margin: auto;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  -o-object-position: center;
     object-position: center;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-prev, #page-example section.example_detail .example_img #example-slider .swiper-button-next {
  width: 5.5rem;
  height: 5.5rem;
  border-radius: 50%;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-prev::after, #page-example section.example_detail .example_img #example-slider .swiper-button-next::after {
  content: "";
  width: 30%;
  aspect-ratio: 1/1;
  border-top: 3px solid #0059cb;
  border-right: 3px solid #0059cb;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-prev:hover, #page-example section.example_detail .example_img #example-slider .swiper-button-next:hover {
  background-color: #0059cb;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-prev:hover::after, #page-example section.example_detail .example_img #example-slider .swiper-button-next:hover::after {
  border-color: #fff;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-prev::after {
  -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
  position: relative;
  left: 0.2rem;
}
#page-example section.example_detail .example_img #example-slider .swiper-button-next::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: relative;
  right: 0.2rem;
}
#page-example section.example_detail .example_img #slider-thumbnail {
  margin-top: 1rem;
}
#page-example section.example_detail .example_img #slider-thumbnail .swiper-wrapper {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.5rem;
}
@media print, screen and (min-width: 1024px) {
  #page-example section.example_detail .example_img #slider-thumbnail .swiper-wrapper {
    margin-top: 2rem;
    gap: 2rem;
  }
}
#page-example section.example_detail .example_img #slider-thumbnail .swiper-slide {
  width: calc((100% - 2.5rem) / 5) !important;
  aspect-ratio: 19/14;
  opacity: 0.5;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  cursor: pointer;
}
@media print, screen and (min-width: 1024px) {
  #page-example section.example_detail .example_img #slider-thumbnail .swiper-slide {
    width: calc((100% - 8rem) / 5) !important;
  }
}
#page-example section.example_detail .example_img #slider-thumbnail .swiper-slide.swiper-slide-thumb-active {
  opacity: 1;
}
#page-example section.example_detail .example_img #slider-thumbnail .swiper-slide img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media print, screen and (min-width: 768px) {
  #page-example section.example_detail .example_info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 0 4rem;
  }
}
#page-example section.example_detail .example_info dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 4rem;
  border-top: 0.1rem solid #edf0f4;
  padding: 1em 0;
}
@media print, screen and (min-width: 768px) {
  #page-example section.example_detail .example_info dl {
    width: calc((100% - 4rem) / 2);
  }
}
#page-example section.example_detail .example_info dl:last-of-type {
  border-bottom: 0.1rem solid #edf0f4;
}
#page-example section.example_detail .example_info dl dt {
  width: 6rem;
  color: #ef271b;
  font-size: 1.8rem;
  font-weight: bold;
}
#page-example section.example_detail .example_info dl dd {
  font-size: 1.4rem;
}
#page-example section.example_detail .example_desc h3 {
  color: #fe654f;
  font-size: 2.4rem;
  font-size: 2.4rem;
  font-weight: bold;
}
#page-example section.example_detail .example_desc p {
  margin-top: 3rem;
}

#page-news header nav.pc_menu ul li a.nav_news::after {
  opacity: 1;
  width: calc(100% + 1rem);
}
#page-news header nav.sp_menu ul li a.nav_news {
  color: #00af54;
}
#page-news footer nav.footer_nav ul li a.nav_news {
  color: #00af54;
  border-color: #00af54 !important;
}
#page-news section.news .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4rem 0;
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 min(12.5vw, 25rem);
  }
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .category_list {
    width: 10rem;
  }
}
#page-news section.news .category_list h3 {
  color: #ef271b;
  font-weight: 1.8rem;
  font-weight: bold;
  text-align: center;
}
#page-news section.news .category_list ul {
  margin-top: min(2vw, 2rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: min(2vw, 2rem);
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .category_list ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
#page-news section.news .category_list ul li {
  width: calc((100% - min(2vw, 2rem) * 3) / 4);
  max-width: 90px;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news .category_list ul li {
    width: 100%;
  }
}
#page-news section.news .category_list ul li button {
  display: block;
  width: 100%;
  color: #4d4d4d;
  font-size: 1.2rem;
  text-align: center;
  white-space: nowrap;
  border: 0.1rem solid #4d4d4d;
  padding: 0.2em 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-news section.news .category_list ul li button:hover, #page-news section.news .category_list ul li button.active {
  color: #fff;
  background-color: #0059cb;
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-news section.news .title_list > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(8vw, 4rem) 0;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news .title_list > ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 4rem;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list > ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: min(3.5vw, 6rem);
  }
}
#page-news section.news .title_list > ul li {
  width: 100%;
  max-width: 56rem;
}
@media print, screen and (min-width: 768px) {
  #page-news section.news .title_list > ul li {
    width: calc((100% - 4rem) / 2);
    max-width: none;
  }
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list > ul li {
    width: 100%;
  }
}
#page-news section.news .title_list > ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: min(4vw, 2rem) 0;
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list > ul li a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0 min(2.4vw, 4rem);
  }
}
#page-news section.news .title_list > ul li a .image_area {
  border: 0.1rem solid #cecece;
  aspect-ratio: 54/36;
  overflow: hidden;
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list > ul li a .image_area {
    width: 18rem;
  }
}
#page-news section.news .title_list > ul li a .text_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(2vw, 2rem) 2rem;
}
@media print, screen and (min-width: 1024px) {
  #page-news section.news .title_list > ul li a .text_area {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-news section.news .title_list > ul li a .text_area p.date {
  color: #4d4d4d;
  font-size: 1.4rem;
}
#page-news section.news .title_list > ul li a .text_area p.category {
  color: #4d4d4d;
  font-size: 1.2rem;
  text-align: center;
  width: 9rem;
  border: 0.1rem solid #4d4d4d;
  padding: 0.2em 0;
}
#page-news section.news .title_list > ul li a .text_area h3.title {
  width: 100%;
}
#page-news section.news .title_list > ul li a:hover .text_area p {
  color: #00af54;
  border-color: #00af54;
}
#page-news section.news .title_list > ul li a:hover .text_area h3.title {
  color: #00af54;
}
#page-news section.news .pagination ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 1.5rem;
}
#page-news section.news .pagination ul li a {
  width: 2em;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  color: #4d4d4d;
  font-weight: bold;
  border: 0.1rem solid #4d4d4d;
}
#page-news section.news .pagination ul li a:hover, #page-news section.news .pagination ul li a.pagination_on {
  color: #fff;
  background-color: #00af54;
  border-color: #00af54;
}
#page-news section.news_detail .flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: min(4vw, 4rem) 2rem;
}
#page-news section.news_detail p.date {
  color: #4d4d4d;
  font-size: 1.4rem;
}
#page-news section.news_detail p.category {
  color: #4d4d4d;
  font-size: 1.2rem;
  text-align: center;
  width: 9rem;
  border: 0.1rem solid #4d4d4d;
  padding: 0.2em 0;
}
#page-news section.news_detail .title_area {
  width: 100%;
  padding-bottom: min(4vw, 4rem);
  border-bottom: 0.1rem solid #edf0f4;
}
#page-news section.news_detail .title_area h2 {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  color: #ef271b;
  font-size: min(6vw, 2.8rem);
  line-height: 1;
}
#page-news section.news_detail .image_area {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 5%;
}
#page-news section.news_detail .image_area .image {
  width: 47.5%;
  aspect-ratio: 492/328;
  border: 0.1rem solid #cecece;
  overflow: hidden;
}
#page-news section.news_detail .image_area .image a {
  position: relative;
  width: 100%;
  height: 100%;
}
#page-news section.news_detail .image_area .image a::before {
  content: "";
  width: 5rem;
  aspect-ratio: 1/1;
  background: url(../img/news/icon_glass.svg) center/60% no-repeat;
  background-color: #ef271b;
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 1;
}
#page-news section.news_detail .image_area .image a:hover::before {
  background-color: #00af54;
}
#page-news section.news_detail .image_area .image a img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
#page-news section.news_detail .text_area {
  width: 100%;
}
#page-news section.news_detail .link_area {
  width: 100%;
}
#page-news section.news_detail .link_area p.link {
  text-align: left;
}
#page-news section.news_detail .link_area p.link a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  color: #0059cb;
  text-decoration: underline;
  padding: 0 0.2em;
}
#page-news section.news_detail .link_area p.link a::after {
  content: "";
  width: 1em;
  aspect-ratio: 1/1;
  -webkit-mask: url(../img/news/icon_window.svg) center/contain no-repeat;
          mask: url(../img/news/icon_window.svg) center/contain no-repeat;
  background-color: #0059cb;
}
#page-news section.news_detail .link_area p.link a:hover {
  color: #fff;
  background-color: #0059cb;
}
#page-news section.news_detail .link_area p.link a:hover::after {
  background-color: #fff;
}
#page-news section.news_detail .pdf_area {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 0.5rem;
}
#page-news section.news_detail .pdf_area::before {
  content: "";
  height: 2em;
  aspect-ratio: 28/31;
  background: url(../img/news/icon_pdf.svg) center/contain no-repeat;
}
#page-news section.news_detail .pdf_area p.pdf a {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  color: #0059cb;
  text-decoration: underline;
  padding: 0 0.2em;
}
#page-news section.news_detail .pdf_area p.pdf a:hover {
  color: #fff;
  background-color: #0059cb;
}

#page-contact header nav.sp_menu ul li a.nav_contact {
  color: #00af54;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact p.section_info {
    text-align: center;
    line-height: 2;
  }
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact .anchor_list ul li {
    width: 28.5rem;
  }
}
#page-contact section.contact .tel_contact {
  position: relative;
  margin-top: clamp(4rem, 5.5vw, 10rem);
  border: 0.1rem solid #bfbfbf;
  padding: min(4vw, 4rem);
}
#page-contact section.contact .tel_contact::before {
  content: "";
  width: min(13vw, 6.5rem);
  aspect-ratio: 1/1;
  background-color: #ef271b;
  clip-path: polygon(0 0, 100% 0, 100% 100%);
  position: absolute;
  top: 0;
  right: 0;
}
#page-contact section.contact .tel_contact h2 {
  color: #ef271b;
  font-size: min(5.5vw, 2.4rem);
  font-weight: bold;
  text-align: center;
}
#page-contact section.contact .tel_contact p {
  margin-top: 2rem;
}
@media print, screen and (min-width: 480px) {
  #page-contact section.contact .tel_contact p {
    text-align: center;
  }
}
#page-contact section.contact .tel_contact .number {
  background-color: #f0f0f0;
  padding: min(4vw, 4rem) 0;
}
#page-contact section.contact .tel_contact .number a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#page-contact section.contact .tel_contact .number a p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(2vw, 2rem);
  font-size: min(8vw, 4rem);
  font-weight: bold;
  line-height: 1;
}
#page-contact section.contact .tel_contact .number a p span.icon {
  width: 1em;
  aspect-ratio: 1/1;
  background: url(../img/contact/icon_tel.svg) center/contain no-repeat;
}
#page-contact section.contact .tel_contact .number a small {
  font-size: 1.6rem;
}
#page-contact section.contact form p.form_info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form p.form_info {
    text-align: center;
  }
}
#page-contact section.contact form p.form_info span {
  color: #fff;
  font-size: 1.2rem;
  background-color: #00af54;
  padding: 0.2em 0.5em;
}
#page-contact section.contact form .input_list dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem 0;
  padding: min(3vw, 3rem) 0;
  border-bottom: 0.1rem solid #b1b1b1;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .input_list dl {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0 2rem;
  }
}
#page-contact section.contact form .input_list dl dt {
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .input_list dl dt {
    width: 23.5rem;
  }
}
#page-contact section.contact form .input_list dl dt.required {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .input_list dl dt.required {
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
#page-contact section.contact form .input_list dl dt.required::after {
  content: "必須";
  color: #fff;
  font-size: 1.2rem;
  background-color: #00af54;
  padding: 0.2em 0.5em;
}
#page-contact section.contact form .input_list dl dd {
  border: 0.1rem solid #b1b1b1;
  border-radius: 0.4rem;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .input_list dl dd {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
#page-contact section.contact form .input_list dl dd input {
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-contact section.contact form .input_list dl dd input:not([type=radio]) {
  width: 100%;
  font-size: 1.8rem;
  background-color: #f0f0f0;
  padding: 0.5em 1em;
  cursor: pointer;
}
#page-contact section.contact form .input_list dl dd input:not([type=radio]):hover {
  background-color: rgba(1, 172, 66, 0.2);
}
#page-contact section.contact form .input_list dl dd input[type=radio] {
  width: 1.2em;
  aspect-ratio: 1/1;
  accent-color: #0059cb;
}
#page-contact section.contact form .input_list dl dd.flex {
  border: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem 0;
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .input_list dl dd.flex {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 0 4rem;
  }
}
#page-contact section.contact form .input_list dl dd.flex label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  cursor: pointer;
}
#page-contact section.contact form .input_list dl dd.flex label:hover {
  color: #00af54;
}
#page-contact section.contact form .input_list dl dd textarea {
  display: block;
  width: 100%;
  min-height: 20rem;
  field-sizing: content;
  font-size: 1.8rem;
  background-color: #f0f0f0;
  padding: 0.5em 1em;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  cursor: pointer;
}
#page-contact section.contact form .input_list dl dd textarea:hover {
  background-color: rgba(1, 172, 66, 0.2);
}
#page-contact section.contact form .privacy_check {
  background-color: #f0f0f0;
  padding: min(4vw, 4rem) clamp(2rem, 5.5vw, 10rem);
}
@media print, screen and (min-width: 768px) {
  #page-contact section.contact form .privacy_check p {
    text-align: center;
  }
}
#page-contact section.contact form .privacy_check p a {
  display: inline;
  color: #3fa7f3;
  text-decoration: underline;
  padding: 0 0.1em;
}
#page-contact section.contact form .privacy_check p a:hover {
  color: #fff;
  background-color: #3fa7f3;
}
#page-contact section.contact form .privacy_check label {
  margin-top: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 1rem;
  line-height: 1;
  background-color: #fff;
  padding: min(4vw, 2rem) 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
  cursor: pointer;
}
#page-contact section.contact form .privacy_check label:hover {
  background-color: rgba(1, 172, 66, 0.2);
}
#page-contact section.contact form .privacy_check label input {
  width: 1.2em;
  aspect-ratio: 1/1;
  accent-color: #0059cb;
  position: relative;
  top: 0.05em;
}
#page-contact section.contact form .btn_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 min(4vw, 4rem);
}
#page-contact section.contact form .btn_area button {
  width: calc((100% - min(4vw, 4rem)) / 2);
  color: #fff;
  font-weight: bold;
  text-align: center;
  border: 0.1rem solid;
  padding: 1em 0;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
#page-contact section.contact form .btn_area button[type=reset], #page-contact section.contact form .btn_area button[type=button] {
  background-color: #333;
  border-color: #333;
}
#page-contact section.contact form .btn_area button[type=reset]:hover, #page-contact section.contact form .btn_area button[type=button]:hover {
  color: #333;
  background-color: #fff;
}
#page-contact section.contact form .btn_area button[type=submit] {
  background-color: #fe654f;
  border-color: #fe654f;
}
#page-contact section.contact form .btn_area button[type=submit]:hover {
  color: #fe654f;
  background-color: #fff;
}
#page-contact section.contact form.confirm label,
#page-contact section.contact form.confirm input,
#page-contact section.contact form.confirm textarea {
  pointer-events: none;
}

#page-privacy header nav.sp_menu ul li a.nav_privacy {
  color: #00af54;
}
#page-privacy footer nav.footer_nav ul li a.nav_privacy {
  color: #00af54;
  border-color: #00af54 !important;
}
#page-privacy p.note {
  border-bottom: 0.1rem solid #1a1a1a;
}
#page-privacy dl.policy_list dt {
  font-size: 1.8rem;
  font-weight: bold;
}
#page-privacy dl.policy_list dt:not(:first-of-type) {
  margin-top: clamp(4rem, 3.5vw, 6.4rem);
}
#page-privacy dl.policy_list dd {
  margin-top: 1rem;
}
#page-privacy dl.policy_list dd ul {
  margin-top: 1rem;
  padding-left: 1em;
}
#page-privacy dl.policy_list dd ul li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#page-privacy dl.policy_list dd ul li::before {
  content: "・";
}
#page-privacy dl.policy_list dd .contact {
  margin-top: 1rem;
}

#page-404 section.page404 p {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}
#page-404 section.page404 .btn_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2rem 4rem;
}
#page-404 section.page404 .btn_area .btn {
  margin: 0;
}/*# sourceMappingURL=style.css.map */