@charset "UTF-8";
/*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css */
*,
::before,
::after {
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
  min-width: 0;
}

html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth;
}

body {
  margin: 0;
}

main {
  display: block;
}

p,
table,
blockquote,
address,
pre,
iframe,
form,
figure,
dl {
  margin: 0;
}

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

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

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border-top-width: 1px;
  margin: 0;
  clear: both;
  color: inherit;
}

pre {
  font-family: monospace, monospace;
  font-size: inherit;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}

abbr[title] {
  text-decoration: underline dotted;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: inherit;
}

small {
  font-size: 80%;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

svg,
img,
embed,
object,
iframe {
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  outline: 0;
  border-radius: 0;
  text-align: inherit;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

button[disabled],
[type=button][disabled],
[type=reset][disabled],
[type=submit][disabled] {
  cursor: default;
}

:-moz-focusring {
  outline: auto;
}

select:disabled {
  opacity: inherit;
}

option {
  padding: 0;
}

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

legend {
  padding: 0;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

[type=number] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

[contenteditable]:focus {
  outline: auto;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

caption {
  text-align: left;
}

td,
th {
  vertical-align: top;
  padding: 0;
}

th {
  text-align: left;
}

img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  vertical-align: bottom;
}

a {
  user-select: none;
}

@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

html {
  font-size: 2.5641025641vw;
  scroll-behavior: smooth;
}
@media (min-width: 540px) {
  html {
    font-size: 10px;
  }
}

body {
  font-family: "YakuHanJP", "Noto Sans JP", "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
  font-weight: 400;
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  color: #231815;
  line-height: 1.6;
  letter-spacing: 0.03em;
  font-feature-settings: "palt" 1;
  vertical-align: baseline;
  word-break: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
  line-break: strict;
  text-align: justify;
  -webkit-text-size-adjust: 100%;
}

dl, dt, th, dd, label {
  font-weight: 400;
}

@media (min-width: 1024px) {
  .under-pc {
    display: none;
  }
}

@media (min-width: 768px) {
  .under-tab_over-pc {
    display: none;
  }
}
@media (min-width: 1024px) {
  .under-tab_over-pc {
    display: block;
  }
}

@media (min-width: 768px) {
  .under-tab {
    display: none;
  }
}

@media (min-width: 540px) {
  .under-sp_over-tab {
    display: none;
  }
}
@media (min-width: 768px) {
  .under-sp_over-tab {
    display: block;
  }
}

@media (min-width: 540px) {
  .under-sp_in-tab {
    display: none;
  }
}
@media (min-width: 768px) {
  .under-sp_in-tab {
    display: block;
  }
}
@media (min-width: 1024px) {
  .under-sp_in-tab {
    display: none;
  }
}

@media (min-width: 540px) {
  .under-sp_over-pc {
    display: none;
  }
}
@media (min-width: 1024px) {
  .under-sp_over-pc {
    display: block;
  }
}

@media (min-width: 540px) {
  .under-sp {
    display: none;
  }
}

@media (min-width: 600px) {
  .under-Lsp {
    display: none;
  }
}

.over-sp {
  display: none;
}
@media (min-width: 540px) {
  .over-sp {
    display: block;
  }
}

.in-sp_in-tab {
  display: none;
}
@media (min-width: 540px) {
  .in-sp_in-tab {
    display: block;
  }
}
@media (min-width: 1024px) {
  .in-sp_in-tab {
    display: none;
  }
}

.in-sp_over-pc {
  display: none;
}
@media (min-width: 540px) {
  .in-sp_over-pc {
    display: block;
  }
}
@media (min-width: 768px) {
  .in-sp_over-pc {
    display: none;
  }
}
@media (min-width: 1024px) {
  .in-sp_over-pc {
    display: block;
  }
}

.in-sp {
  display: none;
}
@media (min-width: 540px) {
  .in-sp {
    display: block;
  }
}
@media (min-width: 768px) {
  .in-sp {
    display: none;
  }
}

.over-tab {
  display: none;
}
@media (min-width: 768px) {
  .over-tab {
    display: block;
  }
}

.in-tab {
  display: none;
}
@media (min-width: 768px) {
  .in-tab {
    display: block;
  }
}
@media (min-width: 1024px) {
  .in-tab {
    display: none;
  }
}

.over-pc {
  display: none;
}
@media (min-width: 1024px) {
  .over-pc {
    display: block;
  }
}

.button {
  display: block;
  margin-inline: auto;
  border: 1px solid #231815;
  border-radius: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  width: fit-content;
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  background: #FAFAFA;
  transition: all 0.3s ease-in-out;
}
.button:hover {
  background: #6FBA2C;
  color: #FAFAFA;
  border: 1px solid #6FBA2C;
}
.button:disabled {
  background: #ECECEC;
  color: #FAFAFA;
}

.arrowbutton {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #231815;
  border-radius: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  width: fit-content;
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  background: #FAFAFA;
  position: relative;
  transition: all 0.3s ease-in-out;
}
.arrowbutton::after {
  content: "→";
  display: block;
  position: absolute;
  right: 1.25em;
  transition: all 0.3s ease-in-out;
}
.arrowbutton:hover {
  background: #6FBA2C;
  color: #FAFAFA;
  border: 1px solid #6FBA2C;
}
.arrowbutton:hover::after {
  right: 0.5em;
}
.arrowbutton:disabled {
  background: #ECECEC;
  color: #FAFAFA;
}

.heading {
  width: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem) clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.heading .page-title {
  color: #727171;
  font-size: clamp(3.395rem, 6.4153439153vw, 9.7rem);
  font-weight: 700;
  line-height: 1;
  opacity: 0;
  animation: titleLower 0.3s 0.1s ease-out forwards;
}

@keyframes titleUpper {
  0% {
    transform: rotateX(180deg);
    background-position: 0% 0%;
    opacity: 0;
  }
  20% {
    opacity: 1;
  }
  50% {
    transform: rotateX(0);
    background-position: 0% 0%;
    opacity: 1;
  }
  100% {
    transform: rotateX(0);
    background-position: 100% 0%;
    opacity: 1;
  }
}
@keyframes titleLower {
  0% {
    transform: translateY(100%);
    opacity: 0;
    filter: blur(3px);
  }
  100% {
    transform: translateY(0);
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes logo {
  0% {
    opacity: 0;
    filter: blur(10px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes disAppear {
  0% {
    opacity: 1;
    height: 100dvh;
  }
  99% {
    opacity: 0;
    height: 100dvh;
  }
  100% {
    opacity: 0;
    height: 0;
  }
}
.single-pagenavigation {
  margin-top: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(3.92rem, 2.6455026455vw, 4rem);
}
.single-pagenavigation a {
  display: block;
  padding: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  color: #231815;
  font-size: clamp(1.372rem, 0.9259259259vw, 1.4rem);
  font-weight: 700;
  line-height: 1;
}

.pagination { /*スクリーンリーダー用のテキスト*/ }
.pagination .screen-reader-text {
  transform: scale(0, 0);
}
.pagination .nav-links {
  margin-top: clamp(3.92rem, 2.6455026455vw, 4rem);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5873015873vw;
}
.pagination .nav-links .page-numbers {
  width: clamp(5.292rem, 3.5714285714vw, 5.4rem);
  height: clamp(5.292rem, 3.5714285714vw, 5.4rem);
  flex-shrink: 0;
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: clamp(1.372rem, 0.9259259259vw, 1.4rem);
  font-weight: 700;
  line-height: 1;
  color: #000000;
  border-radius: 50%;
  transition: all 0.3s ease-in-out;
}
.pagination .nav-links .page-numbers:hover {
  background: #D8ECC5;
}
.pagination .nav-links .current {
  background: #D8ECC5;
}
.pagination .nav-links .prev,
.pagination .nav-links .next {
  border-radius: 50%;
}

.wrapper {
  min-height: 100vh;
  scroll-behavior: smooth;
  background: #FAFAFA;
}

main.ly_main {
  min-height: 100%;
  width: 100%;
  padding-top: clamp(5.676rem, 4.3650793651vw, 6.6rem);
}
@media (orientation: landscape) {
  main.ly_main.top_main {
    padding-top: 0;
  }
}

.paddingInline {
  margin-inline: auto;
  padding-inline: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  max-width: calc(clamp(123.186rem, 83.1349206349vw, 125.7rem) + clamp(7.808rem, 8.4656084656vw, 12.8rem) * 2);
}
@media (min-width: 540px) {
  .paddingInline {
    padding-inline: clamp(2.44rem, 2.6455026455vw, 4rem);
  }
}
@media (min-width: 600px) {
  .paddingInline {
    padding-inline: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  }
}
@media (min-width: 768px) {
  .paddingInline {
    padding-inline: clamp(7.808rem, 8.4656084656vw, 12.8rem);
  }
}

.paddingInline16 {
  margin-inline: auto;
  padding-inline: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  max-width: calc(clamp(123.186rem, 83.1349206349vw, 125.7rem) + clamp(7.808rem, 8.4656084656vw, 12.8rem) * 2);
}
@media (min-width: 540px) {
  .paddingInline16 {
    padding-inline: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  }
}
@media (min-width: 600px) {
  .paddingInline16 {
    padding-inline: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  }
}
@media (min-width: 768px) {
  .paddingInline16 {
    padding-inline: clamp(7.808rem, 8.4656084656vw, 12.8rem);
  }
}

footer.ly_footer {
  position: sticky;
  top: 100svh;
  padding-block: clamp(3.904rem, 4.2328042328vw, 6.4rem) clamp(6.344rem, 6.8783068783vw, 10.4rem);
  display: grid;
  justify-items: center;
  text-align: center;
}
@media (min-width: 768px) {
  footer.ly_footer {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    justify-items: start;
    text-align: justify;
  }
}

@media (min-width: 768px) {
  .footer_company {
    grid-area: 1/1/2/2;
  }
}
.footer_company .imgWrap {
  width: clamp(29.4rem, 19.8412698413vw, 30rem);
}
.footer_company .imgWrap img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.footer_info {
  margin-top: clamp(2.058rem, 1.3888888889vw, 2.1rem);
}
@media (min-width: 768px) {
  .footer_info {
    margin-top: 0;
    grid-area: 1/2/2/3;
  }
}
@media (min-width: 1024px) {
  .footer_info {
    grid-area: 1/2/3/3;
  }
}
.footer_info .footer_companyname {
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 700;
  line-height: 1.3;
}
.footer_info .footer_address {
  margin-top: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.032rem, 0.7936507937vw, 1.2rem);
  line-height: 1.4;
}
.footer_info .footer_sns {
  margin-top: clamp(0.784rem, 0.5291005291vw, 0.8rem);
}
.footer_info .footer_sns ul {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 768px) {
  .footer_info .footer_sns ul {
    justify-content: flex-start;
  }
}
.footer_info .footer_sns ul a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  padding: clamp(0.294rem, 0.1984126984vw, 0.3rem);
}
.footer_info .footer_sns ul img {
  width: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  height: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  object-fit: contain;
}
.footer_info .footer_contact {
  margin-top: clamp(2.058rem, 1.3888888889vw, 2.1rem);
  margin-inline: auto;
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(4.816rem, 3.7037037037vw, 5.6rem);
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 768px) {
  .footer_info .footer_contact {
    margin-inline: 0;
  }
}
.footer_info .footer_navi {
  margin-top: clamp(2.058rem, 1.3888888889vw, 2.1rem);
}
.footer_info .footer_navi ul {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(1.032rem, 0.7936507937vw, 1.2rem);
  gap: clamp(2.064rem, 1.5873015873vw, 2.4rem) clamp(4.128rem, 3.1746031746vw, 4.8rem);
  flex-direction: column;
}
@media (min-width: 768px) {
  .footer_info .footer_navi ul {
    align-items: flex-start;
  }
}
@media (min-width: 1024px) {
  .footer_info .footer_navi ul {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
  }
}
.footer_info .footer_navi a {
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer_info .blanklink a::after {
  display: block;
  width: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  height: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  margin-left: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  padding-bottom: clamp(0.196rem, 0.1322751323vw, 0.2rem);
  content: "↗";
  background-size: cover;
}

.footer_copyright {
  padding-top: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
@media (min-width: 768px) {
  .footer_copyright {
    grid-area: 2/1/3/3;
    justify-self: center;
  }
}
@media (min-width: 1024px) {
  .footer_copyright {
    padding-top: 0;
    grid-area: 2/1/3/2;
    align-self: end;
    justify-self: start;
  }
}
.footer_copyright small {
  display: block;
  font-weight: 300;
  font-size: clamp(1rem, 0.6613756614vw, 1rem);
}

header.ly_header {
  position: fixed;
  z-index: 7002;
  display: flex;
  align-items: center;
  justify-content: space-between;
  top: 0;
  width: 100%;
  height: clamp(5.676rem, 4.3650793651vw, 6.6rem);
  transition: all 0.3s ease-in-out;
  background: #FAFAFA;
}
@media (min-width: 850px) {
  header.ly_header {
    background: rgba(250, 250, 250, 0.8);
  }
}
header.ly_header.transparent {
  background: transparent;
}
header.ly_header .headerLogolink {
  position: relative;
}
header.ly_header .headerLogowrap {
  height: calc(clamp(5.676rem, 4.3650793651vw, 6.6rem) - clamp(1.568rem, 1.0582010582vw, 1.6rem));
  width: auto;
  margin-left: clamp(1.464rem, 1.5873015873vw, 2.4rem);
}
header.ly_header .headerLogowrap img {
  object-fit: contain;
}

.headermenuwrap {
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  color: #231815;
}

.menuMask {
  position: fixed;
  z-index: 7000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #231815;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease-in-out;
}
.menuMask.activeNavi {
  opacity: 0.8;
  visibility: visible;
}
@media (min-width: 850px) {
  .menuMask {
    display: none;
  }
}

.menuButtonWrap {
  position: absolute;
  z-index: 7005;
  height: 100%;
  top: 0;
  right: clamp(0.882rem, 0.5952380952vw, 0.9rem);
  display: flex;
  flex-direction: column;
  text-align: center;
  justify-content: center;
}
@media (min-width: 850px) {
  .menuButtonWrap {
    display: none;
  }
}

.menuButton {
  display: grid;
  grid-template-rows: auto min-content;
  text-align: center;
  width: clamp(4.8rem, 3.1746031746vw, 4.8rem);
  height: clamp(4.8rem, 3.1746031746vw, 4.8rem);
  aspect-ratio: 1/1;
}
.menuButton .rectangles {
  height: 100%;
  width: auto;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding-block: clamp(0.8rem, 0.5291005291vw, 0.8rem);
  padding-block: clamp(1.25rem, 0.8267195767vw, 1.25rem) clamp(0.45rem, 0.2976190476vw, 0.45rem);
}
.menuButton .rectangles div {
  border-radius: clamp(0.2rem, 0.1322751323vw, 0.2rem);
  width: clamp(2.3rem, 1.5211640212vw, 2.3rem);
  height: clamp(0.1rem, 0.0661375661vw, 0.1rem);
  background: #231815;
  transition: all 0.3s ease-in-out;
}
.menuButton .menuText {
  font-size: clamp(1rem, 0.6613756614vw, 1rem);
  line-height: 1;
  padding-bottom: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  font-family: "Roboto";
}
.menuButton.activeNavi .rectangles {
  justify-content: center;
  position: relative;
}
.menuButton.activeNavi .rectangles div {
  position: absolute;
  background: #FAFAFA;
}
.menuButton.activeNavi .rectangles div:nth-of-type(1) {
  transform: rotate(315deg);
}
.menuButton.activeNavi .rectangles div:nth-of-type(2) {
  transform: rotateY(90deg);
}
.menuButton.activeNavi .rectangles div:nth-of-type(3) {
  transform: rotate(-315deg);
}
.menuButton.activeNavi .menuText {
  color: #FAFAFA;
}

.headermenu {
  width: 60vw;
  height: clamp(44.884rem, 30.291005291vw, 45.8rem);
  min-width: 234px;
  max-height: calc(100svh - clamp(4.704rem, 3.1746031746vw, 4.8rem));
  overflow-y: auto;
  overscroll-behavior: none;
  position: fixed;
  inset: 0;
  margin: auto;
  z-index: 7004;
  transition: all 0.3s ease-in-out;
  opacity: 0;
  pointer-events: none;
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  padding-inline: clamp(2.92rem, 2.6455026455vw, 4rem);
  background: #6FBA2C;
  color: #FAFAFA;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
.headermenu.activeNavi {
  opacity: 1;
  pointer-events: all;
}
@media (min-width: 850px) {
  .headermenu {
    position: static;
    width: 100%;
    height: auto;
    padding-block: clamp(1.464rem, 1.5873015873vw, 2.4rem);
    opacity: 1;
    pointer-events: all;
    background: transparent;
    color: #231815;
    flex-direction: row;
    justify-content: flex-end;
    gap: clamp(6.272rem, 4.2328042328vw, 6.4rem);
    overflow: hidden;
  }
}
.headermenu .navi ul {
  display: flex;
  flex-direction: column;
  gap: clamp(3.92rem, 2.6455026455vw, 4rem) clamp(2.352rem, 1.5873015873vw, 2.4rem);
}
@media (min-width: 850px) {
  .headermenu .navi ul {
    width: 100%;
    flex-direction: row;
    justify-content: flex-end;
    padding: 0;
    border: 0;
  }
}
.headermenu .navi ul li {
  width: 100%;
  text-align: center;
  font-family: "Roboto";
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 400;
  line-height: 1;
}
@media (min-width: 850px) {
  .headermenu .navi ul li {
    width: auto;
    border: 0;
    padding: 0;
  }
}
.headermenu .navilistContact {
  width: fit-content;
}
.headermenu a {
  color: #FAFAFA;
  transition: all 0.3s ease-in-out;
}
.headermenu a:hover {
  opacity: 0.6;
}
.headermenu .langageButton span {
  color: #BDBBBB;
}
@media (min-width: 850px) {
  .headermenu a {
    color: #231815;
    transition: all 0.3s ease-in-out;
  }
  .headermenu a:hover {
    color: #6FBA2C;
  }
  .headermenu .langageButton span {
    color: #231815;
    opacity: 0.6;
  }
}

.page-contact {
  max-width: clamp(123.088rem, 83.0687830688vw, 125.6rem);
}
.page-contact form.snow-monkey-form {
  padding-bottom: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  margin-bottom: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item {
  min-height: clamp(4.9rem, 3.3068783069vw, 5rem);
  display: flex;
  flex-direction: column;
  gap: clamp(0.584rem, 0.5291005291vw, 0.8rem) clamp(1.168rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 768px) {
  .page-contact form.snow-monkey-form .smf-form .smf-item {
    flex-direction: row;
  }
}
.page-contact form.snow-monkey-form .smf-form .smf-item:nth-of-type(n+2) {
  margin-top: clamp(2.92rem, 2.6455026455vw, 4rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__col--label {
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__col--label {
    height: clamp(4.9rem, 3.3068783069vw, 5rem);
    width: clamp(17.64rem, 11.9047619048vw, 18rem);
  }
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__col--label .smf-item__label__text {
  display: flex;
  align-items: center;
  gap: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  color: #231815;
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  font-weight: 500;
  line-height: 1.1;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__col--label .required {
  padding: 2px 4px;
  font-size: clamp(1.032rem, 0.7936507937vw, 1.2rem);
  font-weight: 700;
  line-height: 1;
  border-radius: 4px;
  color: #ffffff;
  background: #EA5532;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__col--controls {
  flex-grow: 1;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input,
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls textarea {
  padding-right: clamp(1.032rem, 0.7936507937vw, 1.2rem);
  padding-left: clamp(1.032rem, 0.7936507937vw, 1.2rem);
  width: 100%;
  display: inline-block;
  background: #F2F1F1;
  caret-color: #6FBA2C;
  border-radius: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  overflow: hidden;
  border: 2px solid #F2F1F1;
  resize: vertical;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input {
  height: clamp(4.9rem, 3.3068783069vw, 5rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls textarea {
  height: clamp(21.9rem, 19.8412698413vw, 30rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls select {
  width: 100%;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input[type=checkbox] {
  display: inline-block;
  padding: 0;
  height: clamp(1.978rem, 1.5211640212vw, 2.3rem);
  width: clamp(1.978rem, 1.5211640212vw, 2.3rem);
  aspect-ratio: 1/1;
  border: clamp(0.172rem, 0.1322751323vw, 0.2rem) solid #595757;
  border-radius: clamp(0.344rem, 0.2645502646vw, 0.4rem);
  transition: all 0.3s ease-in-out;
  position: relative;
  resize: none;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input[type=checkbox]:checked {
  background: #FAFAFA;
  border: clamp(0.172rem, 0.1322751323vw, 0.2rem) solid #595757;
  aspect-ratio: 1/1;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input[type=checkbox]:checked::before {
  display: none;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input[type=checkbox]:checked::after {
  display: block;
  content: "";
  position: absolute;
  bottom: clamp(0.258rem, 0.1984126984vw, 0.3rem);
  left: calc(50% - clamp(0.344rem, 0.2645502646vw, 0.4rem));
  height: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  width: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  transform: rotate(45deg);
  border-bottom: clamp(0.344rem, 0.2645502646vw, 0.4rem) solid #6FBA2C;
  border-right: clamp(0.344rem, 0.2645502646vw, 0.4rem) solid #6FBA2C;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input::placeholder,
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls textarea::placeholder {
  letter-spacing: 0.03em;
  color: #A5A4A4;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls input:focus,
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls textarea:focus {
  border: solid 2px #6FBA2C;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls .smf-select-control {
  width: 100%;
  background: #fff;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls .smf-select-control__toggle {
  display: none;
}
.page-contact form.snow-monkey-form .smf-form .smf-item .smf-item__controls .smf-checkbox-control {
  align-items: center;
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy {
  text-align: center;
  color: #231815;
  font-weight: 400;
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  margin-top: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy a {
  color: #1A0DAB;
  text-decoration: underline;
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy a:hover {
  opacity: 0.7;
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy .smf-placeholder {
  margin-top: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  font-weight: 800;
  line-height: 1.8;
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy .smf-placeholder .smf-checkbox-control {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.392rem, 0.2645502646vw, 0.4rem);
}
.page-contact form.snow-monkey-form .smf-form .smf-item.smf-privacypolicy .smf-placeholder .smf-checkbox-control__label {
  font-weight: 800;
}
.page-contact .formNotes {
  color: #231815;
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 500;
  line-height: 1.8;
}
.page-contact form[data-screen=input] .formNotes .confirmmsg,
.page-contact form[data-screen=invalid] .formNotes .confirmmsg,
.page-contact form[data-screen=back] .formNotes .confirmmsg {
  display: none;
}
.page-contact form[data-screen=confirm] .smf-form .smf-item.smf-privacypolicy {
  display: none;
  height: 0;
  overflow: hidden;
}
.page-contact form[data-screen=confirm] .formNotes .inputmsg {
  display: none;
}
.page-contact form[data-screen=confirm] .smf-item__controls {
  height: 100%;
  display: flex;
  align-items: center;
}
.page-contact form[data-screen=confirm] .smf-placeholder {
  font-size: 1.8rem;
}
.page-contact form[data-screen=complete] .smf-action {
  margin-top: 0;
}
.page-contact form[data-screen=invalid] .smf-item__col--controls .smf-placeholder:has(.smf-error-messages) input,
.page-contact form[data-screen=invalid] .smf-item__col--controls .smf-placeholder:has(.smf-error-messages) textarea {
  border: solid 2px #D5272F;
}
.page-contact form[data-screen=invalid] .smf-item__col--controls .smf-placeholder:has(.smf-error-messages) input:focus,
.page-contact form[data-screen=invalid] .smf-item__col--controls .smf-placeholder:has(.smf-error-messages) textarea:focus {
  border: solid 2px #6FBA2C;
  caret-color: #6FBA2C;
  line-height: 1;
  font-weight: 700;
  color: #D5272F;
}
.page-contact .snow-monkey-form .smf-action {
  margin-top: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: clamp(2.928rem, 3.1746031746vw, 4.8rem);
}
@media (min-width: 540px) {
  .page-contact .snow-monkey-form .smf-action {
    flex-direction: row;
  }
}
.page-contact .snow-monkey-form .smf-action button {
  min-width: clamp(15.738rem, 17.0634920635vw, 25.8rem);
  padding: clamp(0.976rem, 1.0582010582vw, 1.6rem) clamp(2.928rem, 3.1746031746vw, 4.8rem);
  border-radius: clamp(0.244rem, 0.2645502646vw, 0.4rem);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease-in-out;
  font-weight: 700;
}
.page-contact .snow-monkey-form .smf-action button[data-action=confirm] {
  pointer-events: none;
  background: #ECECEC;
  color: #ffffff;
  border: clamp(0.3rem, 0.1984126984vw, 0.3rem) solid #ECECEC;
}
.page-contact .snow-monkey-form .smf-action button[data-action=back] {
  color: #686767;
  border: clamp(0.3rem, 0.1984126984vw, 0.3rem) solid #ECECEC;
}
.page-contact .snow-monkey-form .smf-action button[data-action=back]:hover {
  color: #ffffff;
  background: #A5A4A4;
  border: clamp(0.3rem, 0.1984126984vw, 0.3rem) solid #A5A4A4;
}
.page-contact .snow-monkey-form .smf-action button[data-action=complete] {
  color: #6FBA2C;
  border-radius: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  border: clamp(0.196rem, 0.1322751323vw, 0.2rem) solid #6FBA2C;
  background: #FAFAFA;
  pointer-events: auto;
}
.page-contact .snow-monkey-form .smf-action button[data-action=complete]:hover {
  background: #6FBA2C;
  color: #ffffff;
  border: clamp(0.196rem, 0.1322751323vw, 0.2rem) solid #6FBA2C;
}
.page-contact .snow-monkey-form:has(input[name="check-privacypolicy[]"]:checked) .smf-action button[data-action=confirm] {
  color: #231815;
  border-radius: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  border: clamp(0.3rem, 0.1984126984vw, 0.3rem) solid #231815;
  background: #FAFAFA;
  pointer-events: auto;
}
.page-contact .snow-monkey-form:has(input[name="check-privacypolicy[]"]:checked) .smf-action button[data-action=confirm]:hover {
  background: #6FBA2C;
  color: #ffffff;
  border: clamp(0.3rem, 0.1984126984vw, 0.3rem) solid #6FBA2C;
}

.smf-complete-content {
  color: #231815;
}
.smf-complete-content h2 {
  font-family: "Noto Sans JP";
  color: #231815;
  text-align: center;
  font-size: clamp(2.562rem, 2.7777777778vw, 4.2rem);
  line-height: 1.4;
  font-weight: 600;
}
.smf-complete-content p {
  margin-top: clamp(2.92rem, 2.6455026455vw, 4rem);
  font-size: clamp(1.533rem, 1.3888888889vw, 2.1rem);
  text-align: center;
  line-height: 1.8;
}
.smf-complete-content .backToTop {
  display: block;
  margin-top: clamp(2.92rem, 2.6455026455vw, 4rem);
  margin-inline: auto;
  border: 1px solid #231815;
  border-radius: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  width: fit-content;
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(4.816rem, 3.7037037037vw, 5.6rem);
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}

.page-privacy-policy {
  color: #231815;
  padding-bottom: clamp(8.784rem, 9.5238095238vw, 14.4rem);
}
.page-privacy-policy .page {
  margin-inline: auto;
  padding-inline: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  padding-bottom: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  max-width: calc(clamp(123.186rem, 83.1349206349vw, 125.7rem) + clamp(15.616rem, 16.9312169312vw, 25.6rem));
}
@media (min-width: 540px) {
  .page-privacy-policy .page {
    padding-inline: clamp(2.44rem, 2.6455026455vw, 4rem);
  }
}
@media (min-width: 600px) {
  .page-privacy-policy .page {
    padding-inline: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  }
}
@media (min-width: 768px) {
  .page-privacy-policy .page {
    padding-inline: clamp(7.808rem, 8.4656084656vw, 12.8rem);
  }
}
.page-privacy-policy h2 {
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 700;
  line-height: 1.2;
  padding-bottom: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  letter-spacing: 0;
}
.page-privacy-policy h3 {
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 700;
  line-height: 1.2;
  padding-bottom: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  letter-spacing: 0;
}
.page-privacy-policy .privacy-policy_container {
  font-weight: 500;
}
.page-privacy-policy .privacy-policy_container + div {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.page-privacy-policy .privacy-policy_container p {
  margin-top: clamp(0.488rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
}
.page-privacy-policy .privacy-policy_container .privacy-policy_Wrap p {
  color: #231815;
  margin-top: clamp(0.488rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  font-weight: 420;
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer + div {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer p {
  color: #231815;
  margin-top: clamp(0.488rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 420;
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer ul {
  margin-top: clamp(0.488rem, 0.5291005291vw, 0.8rem);
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer ul li {
  display: flex;
  align-items: baseline;
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  font-weight: 420;
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer ul li span {
  white-space: nowrap;
  flex-shrink: 0;
}
.page-privacy-policy .privacy-policy_container .privacy-policy_subcontainer ul li + li {
  margin-top: clamp(1.176rem, 0.7936507937vw, 1.2rem);
}
.page-privacy-policy .privacy-policy_enactment {
  color: #231815;
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 500;
  line-height: 1.8;
}
.page-privacy-policy a {
  color: #1A0DAB;
  text-decoration: underline;
}
.page-privacy-policy .button {
  margin-top: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  padding: clamp(1.548rem, 1.1904761905vw, 1.8rem) clamp(2.752rem, 2.1164021164vw, 3.2rem);
  color: #231815;
  text-decoration: none;
}
.page-privacy-policy .button:hover {
  color: #FAFAFA;
}

/* wordpress post markup setting */
.docment h5,
.page_docment h5 {
  font-weight: bold;
  color: #6FBA2C;
}
.docment h6,
.page_docment h6 {
  color: #6FBA2C;
}
.docment em,
.page_docment em {
  font-weight: bold;
}
.docment blockquote,
.page_docment blockquote {
  padding-left: 1em;
  border-left: 1px solid #BDBBBB;
  margin: 1em;
}
.docment cite,
.page_docment cite {
  display: block;
  width: fit-content;
  margin: 0 0 0 auto;
  font-style: italic;
}
.docment code,
.page_docment code {
  display: inline-block;
  padding: 0 0.25em;
  color: #686767;
  background-color: #ECECEC;
  border-radius: 3px;
  border: solid 1px #A5A4A4;
}
.docment pre,
.page_docment pre {
  margin-block: 1em;
  width: 100%;
  overflow-x: scroll;
  border: 1px solid #ECECEC;
}
.docment address,
.page_docment address {
  padding-block: 1em;
}
.docment table,
.page_docment table {
  width: 100%;
  border: 1px solid #ECECEC;
  text-align: left;
}
.docment table thead td, .docment table thead th,
.page_docment table thead td,
.page_docment table thead th {
  border-bottom: 1px solid #ECECEC;
}
.docment table th,
.page_docment table th {
  font-weight: bold;
  padding: 0.25em;
  white-space: nowrap;
}
.docment table td,
.page_docment table td {
  padding: 0.25em;
}
.docment dt,
.page_docment dt {
  font-weight: bold;
  margin-top: 1em;
}
.docment dd,
.page_docment dd {
  margin-bottom: 1em;
}
.docment ul,
.page_docment ul {
  list-style: inside;
}
.docment ul li,
.page_docment ul li {
  margin-bottom: 0.25em;
}
.docment ul ul, .docment ul ol,
.page_docment ul ul,
.page_docment ul ol {
  padding-left: 1em;
}
.docment ol,
.page_docment ol {
  list-style: decimal;
}
.docment ol li,
.page_docment ol li {
  margin-bottom: 0.25em;
}
.docment ol ul, .docment ol ol,
.page_docment ol ul,
.page_docment ol ol {
  padding-left: 1em;
}

.error404 {
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
.error404 .backTop {
  margin-top: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.error404 .backTop .button {
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(4.816rem, 3.7037037037vw, 5.6rem);
}

.heading404 .title404 {
  text-align: center;
  font-family: "Roboto";
  color: #231815;
  font-size: clamp(3.552rem, 4.8941798942vw, 7.4rem);
  font-weight: 700;
  line-height: 1;
}
.heading404 h2 {
  text-align: center;
  font-size: clamp(1.464rem, 1.5873015873vw, 2.4rem);
  font-weight: 700;
  line-height: 1.8;
}

.page_404 {
  padding-top: clamp(2.352rem, 1.5873015873vw, 2.4rem);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
}
.page_404 img {
  display: none;
}
@media (min-width: 600px) {
  .page_404 img {
    display: block;
  }
}
.page_404 .img_light {
  justify-self: end;
  align-self: end;
  margin-right: clamp(4.672rem, 4.2328042328vw, 6.4rem);
  margin-bottom: -3%;
}
.page_404 .img_light img {
  width: clamp(4.526rem, 4.1005291005vw, 6.2rem);
  height: clamp(17.082rem, 15.4761904762vw, 23.4rem);
}
.page_404 .text {
  align-self: center;
  justify-self: center;
  padding-block: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.page_404 .text p {
  color: #231815;
  font-size: max(1.281rem, 1.3888888889vw);
  text-align: center;
  line-height: 1.8;
}
.page_404 .img_leaves {
  justify-self: start;
  align-self: start;
  margin-left: clamp(2.92rem, 2.6455026455vw, 4rem);
}
.page_404 .img_leaves img {
  width: clamp(21.827rem, 19.7751322751vw, 29.9rem);
  height: clamp(15.549rem, 14.0873015873vw, 21.3rem);
}

.loading {
  position: fixed;
  z-index: 8000;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
}

.loading.active {
  height: 100vh;
  background: #ffffff;
  opacity: 1;
}
.loading.active .logoWrap {
  animation: logo 1s forwards;
}

.loading.loaded {
  animation: disAppear 0.3s forwards;
}

.logoWrap {
  width: clamp(20.659rem, 18.7169312169vw, 28.3rem);
  height: clamp(6.278rem, 5.6878306878vw, 8.6rem);
  opacity: 0;
}

.single {
  padding: clamp(6.344rem, 6.8783068783vw, 10.4rem) clamp(1.568rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 768px) {
  .single {
    padding: clamp(6.344rem, 6.8783068783vw, 10.4rem) clamp(3.904rem, 4.2328042328vw, 6.4rem);
  }
}
@media (min-width: 1024px) {
  .single {
    padding: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  }
}

.post_info {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  gap: clamp(0.488rem, 0.5291005291vw, 0.8rem);
}
.post_info .post_date {
  font-size: clamp(1.204rem, 0.9259259259vw, 1.4rem);
  letter-spacing: 0;
  line-height: 1;
}
.post_info .post_categories {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  gap: clamp(0.488rem, 0.5291005291vw, 0.8rem);
}
.post_info .post_category {
  font-weight: 500;
  font-size: clamp(1.176rem, 0.7936507937vw, 1.2rem);
  line-height: 1;
  letter-spacing: 0;
  background: #BDBBBB;
  padding: clamp(0.392rem, 0.2645502646vw, 0.4rem) clamp(1.568rem, 1.0582010582vw, 1.6rem);
  color: #FAFAFA;
}

.ariticle_title {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  font-weight: 700;
  font-size: clamp(3.066rem, 2.7777777778vw, 4.2rem);
  line-height: 1.2;
}

figure.single-eyecatch {
  width: 100%;
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
}
figure.single-eyecatch img {
  width: auto;
  height: auto;
  object-fit: scale-down;
  max-width: 100%;
  max-height: 65svh;
  margin-inline: auto;
  margin-block: 0;
}
figure.single-eyecatch figcaption {
  width: fit-content;
  margin-inline: auto;
  margin-top: clamp(0.488rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  color: #231815;
  font-weight: 500;
  line-height: 1.2;
}

.single-content {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.single-content img {
  display: block;
  object-fit: scale-down;
  max-height: 65svh;
  max-width: 100%;
  margin-inline: auto;
  margin-block: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.single-content p {
  margin-top: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  font-weight: 400;
  line-height: 1.6;
  color: #231815;
}
.single-content p:has(a) {
  text-align: left;
}
.single-content h1 {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  color: #231815;
  font-size: clamp(2.336rem, 2.1164021164vw, 3.2rem);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0;
}
.single-content h2 {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  color: #231815;
  font-size: clamp(2.336rem, 2.1164021164vw, 3.2rem);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: 0;
}
.single-content h3 {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  color: #231815;
  font-size: clamp(2.044rem, 1.8518518519vw, 2.8rem);
  font-weight: 700;
  line-height: 1.3;
}
.single-content h4 {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  color: #231815;
  font-size: clamp(1.752rem, 1.5873015873vw, 2.4rem);
  font-weight: 700;
  line-height: 1.3;
}
.single-content figure {
  width: 100%;
}
.single-content figure img {
  width: auto;
  height: auto;
  object-fit: scale-down;
  max-width: 100%;
  max-height: 95svh;
}
.single-content figure figcaption {
  width: fit-content;
  margin-inline: auto;
  margin-top: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  font-size: clamp(1.204rem, 0.9259259259vw, 1.4rem);
  color: #EA5532;
  font-weight: 500;
}
.single-content a {
  color: #6FBA2C;
  text-decoration: underline;
  display: inline-block;
}

.post_tags {
  margin-top: clamp(2.44rem, 2.6455026455vw, 4rem);
  display: flex;
  gap: clamp(0.976rem, 1.0582010582vw, 1.6rem);
}
.post_tags > a {
  display: block;
  padding: clamp(0.183rem, 0.1984126984vw, 0.3rem) clamp(0.976rem, 1.0582010582vw, 1.6rem) 0 clamp(0.976rem, 1.0582010582vw, 1.6rem);
  border-bottom: clamp(0.098rem, 0.0661375661vw, 0.1rem) solid #231815;
}

.is-provider-youtube {
  width: 100%;
  height: auto;
}

.wp-embed-aspect-16-9 {
  aspect-ratio: 16/9;
}

.wp-block-embed__wrapper {
  width: 100%;
  height: 100%;
}
.wp-block-embed__wrapper iframe {
  width: 100%;
  height: 100%;
}

.page_docment {
  padding-block: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.page_docment a {
  color: #1A0DAB;
}
.page_docment a:hover {
  color: #6FBA2C;
}

.page_modified_date {
  display: none;
}

.sectionheading {
  text-align: center;
  font-size: clamp(3.416rem, 3.7037037037vw, 5.6rem);
  font-family: "Roboto";
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.sectionheading::after {
  content: "";
  display: block;
  background: #6FBA2C;
  height: clamp(0.392rem, 0.2645502646vw, 0.4rem);
  width: 0;
  margin-top: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  margin-inline: auto;
  transform: all 0.3s ease-in-out;
}
.sectionheading.active::after {
  animation: underbar 0.3s ease-in forwards;
}
@keyframes underbar {
  0% {
    width: 0;
  }
  100% {
    width: 84px;
  }
}

.firstview_inner {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
}
.firstview_inner .night {
  position: absolute;
  z-index: 1;
  background: #231815;
  width: 100%;
  color: #FAFAFA;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
}
@media (orientation: landscape) {
  .firstview_inner .night {
    height: 100dvh;
  }
}
@media (orientation: portrait) {
  .firstview_inner .night {
    height: auto;
    width: 100%;
    aspect-ratio: 384/425;
  }
}
.firstview_inner .night .message {
  position: absolute;
  font-weight: 700;
  font-size: clamp(1.952rem, 2.1164021164vw, 3.2rem);
  white-space: nowrap;
  will-change: auto;
  letter-spacing: 1.25em;
  transform: translateY(-5px);
  opacity: 0;
}
@keyframes night {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes message {
  0% {
    opacity: 0;
    letter-spacing: 1.25em;
    transform: translateY(-5px);
  }
  25% {
    opacity: 1;
    letter-spacing: 0;
    transform: translateY(0px);
  }
  100% {
    opacity: 0;
    letter-spacing: 0;
    transform: translateY(0px);
  }
}
.firstview_inner .light {
  position: absolute;
  z-index: 2;
  background: #FAFAFA;
  will-change: auto;
  transform: scale(1);
  filter: blur(0);
  opacity: 1;
}
@media (orientation: landscape) {
  .firstview_inner .light {
    flex-shrink: 0;
    height: 100dvh;
    width: auto;
    aspect-ratio: 63/47;
    clip-path: circle(0% at 24% 29%);
  }
}
@media (orientation: portrait) {
  .firstview_inner .light {
    height: auto;
    width: 100%;
    aspect-ratio: 384/425;
    clip-path: circle(0% at 20% 29%);
  }
}
@keyframes lightingL {
  0% {
    clip-path: circle(0% at 24% 29%);
    transform: scale(1);
    filter: blur(10vw);
    opacity: 0;
  }
  2.5% {
    clip-path: circle(5% at 24% 29%);
    transform: scale(1);
    filter: blur(10vw);
    opacity: 0;
  }
  7.5% {
    clip-path: circle(5% at 24% 29%);
    transform: scale(1);
    filter: blur(10vw);
    opacity: 0;
  }
  10% {
    clip-path: circle(2% at 24% 29%);
    transform: scale(1);
    filter: blur(20vw);
    opacity: 1;
  }
  50% {
    clip-path: circle(105% at 24% 29%);
    transform: scale(2);
    filter: blur(2vw);
    opacity: 1;
  }
  100% {
    clip-path: circle(105% at 24% 29%);
    transform: scale(2);
    filter: blur(0);
    opacity: 1;
  }
}
@keyframes lightingP {
  0% {
    clip-path: circle(0% at 20% 29%);
    transform: scale(1);
    filter: blur(100px);
    opacity: 0;
  }
  2.5% {
    clip-path: circle(5% at 20% 29%);
    transform: scale(1);
    filter: blur(100px);
    opacity: 0;
  }
  7.5% {
    clip-path: circle(5% at 20% 29%);
    transform: scale(1);
    filter: blur(100px);
    opacity: 0;
  }
  10% {
    clip-path: circle(2% at 20% 29%);
    transform: scale(1);
    filter: blur(100px);
    opacity: 1;
  }
  50% {
    clip-path: circle(105% at 20% 29%);
    transform: scale(2);
    filter: blur(10px);
    opacity: 1;
  }
  100% {
    clip-path: circle(105% at 20% 29%);
    transform: scale(2);
    filter: blur(0);
    opacity: 1;
  }
}
.firstview_inner .illustration {
  margin-inline: auto;
  position: relative;
  z-index: 3;
}
.firstview_inner .illustration video {
  display: flex;
  justify-content: center;
}
@media (orientation: landscape) {
  .firstview_inner .illustration {
    height: 100dvh;
    width: auto;
    aspect-ratio: 63/47;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .firstview_inner .illustration video {
    flex-shrink: 0;
    height: 100dvh;
    width: auto;
    aspect-ratio: 63/47;
    object-fit: contain;
    clip-path: circle(0% at 24% 29%);
  }
}
@media (orientation: portrait) {
  .firstview_inner .illustration {
    height: auto;
    width: 100%;
    aspect-ratio: 384/425;
  }
  .firstview_inner .illustration video {
    height: auto;
    width: 100%;
    aspect-ratio: 384/425;
    flex-shrink: 0;
    clip-path: circle(0% at 20% 29%);
  }
}
@keyframes illustrationL {
  0% {
    clip-path: circle(0% at 24% 29%);
  }
  5% {
    clip-path: circle(5% at 24% 29%);
    opacity: 1;
  }
  10% {
    clip-path: circle(5% at 24% 29%);
    opacity: 0.2;
  }
  15% {
    clip-path: circle(5% at 24% 29%);
    opacity: 1;
  }
  20% {
    clip-path: circle(3% at 24% 29%);
    opacity: 0.2;
  }
  90% {
    clip-path: circle(105% at 24% 29%);
  }
  100% {
    clip-path: circle(105% at 24% 29%);
  }
}
@keyframes illustrationP {
  0% {
    clip-path: circle(0% at 20% 29%);
  }
  5% {
    clip-path: circle(5% at 20% 29%);
    opacity: 1;
  }
  10% {
    clip-path: circle(5% at 20% 29%);
    opacity: 0.2;
  }
  15% {
    clip-path: circle(5% at 20% 29%);
    opacity: 1;
  }
  20% {
    clip-path: circle(3% at 20% 29%);
    opacity: 0.2;
  }
  90% {
    clip-path: circle(110% at 20% 29%);
  }
  100% {
    clip-path: circle(110% at 20% 29%);
  }
}

.firstview.show .night {
  animation: night 1s ease-out 4s forwards;
}
.firstview.show .message {
  animation: message 4s cubic-bezier(0.8, 0.01, 0.58, 1.25) forwards;
}
@media (orientation: landscape) {
  .firstview.show .light {
    animation: lightingL 4s cubic-bezier(0.42, -0.61, 0.02, 1) 2.5s forwards;
  }
}
@media (orientation: portrait) {
  .firstview.show .light {
    animation: lightingP 4s cubic-bezier(0.42, -0.61, 0.02, 1) 2.5s forwards;
  }
}
@media (orientation: landscape) {
  .firstview.show .illustration video {
    animation: illustrationL 2s cubic-bezier(0.42, -0.61, 0.02, 1) 2.5s forwards;
  }
}
@media (orientation: portrait) {
  .firstview.show .illustration video {
    animation: illustrationP 2s cubic-bezier(0.42, -0.61, 0.02, 1) 2.5s forwards;
  }
}

.firstview_text {
  padding-top: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
}
@media (min-width: 600px) {
  .firstview_text {
    grid-template-columns: 1fr auto 1fr;
  }
}
.firstview_text .img_light {
  justify-self: end;
  align-self: end;
  margin-right: clamp(4.672rem, 4.2328042328vw, 6.4rem);
  margin-bottom: -3%;
  grid-area: 2/1/3/2;
}
@media (min-width: 600px) {
  .firstview_text .img_light {
    grid-area: 1/1/2/2;
  }
}
.firstview_text .img_light img {
  width: clamp(4.526rem, 4.1005291005vw, 6.2rem);
  height: clamp(17.082rem, 15.4761904762vw, 23.4rem);
}
.firstview_text .text {
  align-self: center;
  justify-self: center;
  padding-block: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  text-align: center;
  grid-area: 1/1/2/3;
}
@media (min-width: 600px) {
  .firstview_text .text {
    grid-area: 1/2/2/3;
  }
}
.firstview_text .text .catch {
  font-size: clamp(2.336rem, 2.1164021164vw, 3.2rem);
  font-weight: 700;
  line-height: 1.2;
}
.firstview_text .text .paragraphs {
  margin-top: clamp(3.612rem, 2.7777777778vw, 4.2rem);
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  line-height: 1.6;
}
.firstview_text .img_leaves {
  justify-self: start;
  align-self: start;
  margin-left: clamp(2.92rem, 2.6455026455vw, 4rem);
  grid-area: 2/2/3/3;
}
@media (min-width: 600px) {
  .firstview_text .img_leaves {
    grid-area: 1/3/2/4;
  }
}
.firstview_text .img_leaves img {
  width: clamp(21.827rem, 19.7751322751vw, 29.9rem);
  height: clamp(15.549rem, 14.0873015873vw, 21.3rem);
}

.projectbg {
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem);
  position: relative;
  z-index: 1;
  background: rgba(111, 186, 44, 0.5019607843);
  max-width: 100%;
}
.projectbg .background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.5;
}
.projectbg h1 {
  color: #FAFAFA;
  text-align: center;
}
.projectbg h1 .catch {
  font-size: clamp(2.336rem, 2.1164021164vw, 3.2rem);
  font-weight: 700;
  line-height: 1.2;
}
.projectbg h1 .subtitle {
  margin-top: clamp(0.292rem, 0.2645502646vw, 0.4rem);
  font-size: clamp(1.752rem, 1.5873015873vw, 2.4rem);
  font-weight: 700;
  line-height: 1.2;
}
.projectbg h1 .title {
  margin-top: clamp(0.292rem, 0.2645502646vw, 0.4rem);
  font-size: clamp(4.656rem, 6.4153439153vw, 9.7rem);
  font-weight: 400;
  line-height: 1.2;
}
.projectbg h1 .jp {
  font-size: clamp(1.168rem, 1.0582010582vw, 1.6rem);
  line-height: 1.2;
  letter-spacing: 0.1em;
  background: #FAFAFA;
  color: #231815;
  width: fit-content;
  padding: clamp(0.344rem, 0.2645502646vw, 0.4rem) clamp(1.376rem, 1.0582010582vw, 1.6rem) clamp(0.43rem, 0.3306878307vw, 0.5rem) clamp(1.376rem, 1.0582010582vw, 1.6rem);
  margin-inline: auto;
  border-radius: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}

.project {
  padding-block: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  margin-inline: auto;
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  max-width: clamp(83.398rem, 56.2830687831vw, 85.1rem);
  background: #FAFAFA;
}
.project .sectionheading {
  color: #BDBBBB;
}
.project .ecostandalone01 {
  margin-top: clamp(3.904rem, 4.2328042328vw, 6.4rem);
  position: relative;
  container: ecostandalone01/inline-size;
}
.project .ecostandalone01 img.logo {
  position: absolute;
  left: 4.9353701528cqw;
  top: 2.8202115159cqw;
  width: 34.312573443cqw;
  height: 10.4582843713cqw;
}
.project .paragraphs {
  margin-top: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  text-align: center;
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  line-height: 1.8;
}
.project .paragraphs p + p {
  margin-top: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
.project .paragraphs .bold {
  font-weight: 700;
}
.project .paragraphs.ecostandalone {
  padding-bottom: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.project .system {
  padding-top: clamp(5.504rem, 4.2328042328vw, 6.4rem);
}
.project .system .ecostandalone02 {
  position: relative;
  container: ecostandalone02/inline-size;
}
.project .system .ecostandalone02 .balloon {
  position: absolute;
  top: calc(clamp(7.84rem, 5.291005291vw, 8rem) * -1);
  left: 4.7003525264cqw;
  width: clamp(16.954rem, 11.4417989418vw, 17.3rem);
  height: clamp(10.682rem, 7.208994709vw, 10.9rem);
  padding-top: clamp(1.47rem, 0.9920634921vw, 1.5rem);
  background: no-repeat url(../img/project/balloon.svg) center center/contain;
  text-align: center;
}
@media (min-width: 768px) {
  .project .system .ecostandalone02 .balloon {
    top: -9.1656874266cqw;
    left: 4.7003525264cqw;
    width: 29.1421856639cqw;
    height: 18.3313748531cqw;
    padding-top: 2.4676850764cqw;
  }
}
.project .system .ecostandalone02 .balloon .large {
  font-size: clamp(1.47rem, 0.9920634921vw, 1.5rem);
  font-weight: 700;
  line-height: 1.2;
}
@media (min-width: 768px) {
  .project .system .ecostandalone02 .balloon .large {
    font-size: 2.4676850764cqw;
  }
}
.project .system .ecostandalone02 .balloon .small {
  margin-top: 0.4700352526cqw;
  font-size: clamp(1.078rem, 0.7275132275vw, 1.1rem);
  font-weight: 500;
  line-height: 1.2;
}
@media (min-width: 768px) {
  .project .system .ecostandalone02 .balloon .small {
    font-size: 1.8801410106cqw;
  }
}
.project .system .ecostandalone02 .tank figcaption {
  bottom: 13.160987074cqw;
  left: 35.017626322cqw;
}
.project .system .ecostandalone02 .cow {
  position: absolute;
  bottom: calc(clamp(1.078rem, 0.7275132275vw, 1.1rem) * -1);
  left: 4.7003525264cqw;
  width: clamp(9.898rem, 6.6798941799vw, 10.1rem);
  height: clamp(7.938rem, 5.3571428571vw, 8.1rem);
}
@media (min-width: 540px) {
  .project .system .ecostandalone02 .cow {
    bottom: -2.8202115159cqw;
    width: 23.6192714454cqw;
    height: 19.1539365452cqw;
  }
}
.project .system .workings {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
}
.project .system .workings p {
  margin-inline: auto;
  width: fit-content;
  padding: clamp(1.376rem, 1.0582010582vw, 1.6rem) clamp(2.752rem, 2.1164021164vw, 3.2rem);
  background: #EA5532;
  border-radius: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  color: #FAFAFA;
  text-align: center;
  font-weight: 700;
  font-size: clamp(2.044rem, 1.8518518519vw, 2.8rem);
  line-height: 1.2;
}
.project .system .workings img {
  display: block;
  margin-inline: auto;
  width: clamp(5.16rem, 3.9682539683vw, 6rem);
  height: clamp(6.192rem, 4.7619047619vw, 7.2rem);
}
.project .system .produced {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  max-width: clamp(48.608rem, 32.8042328042vw, 49.6rem);
  margin-inline: auto;
  padding-inline: clamp(2.44rem, 2.6455026455vw, 4rem);
  display: grid;
  grid-template-columns: auto auto;
  grid-template-rows: clamp(19.6rem, 13.2275132275vw, 20rem) clamp(14.406rem, 9.7222222222vw, 14.7rem);
  gap: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 540px) {
  .project .system .produced {
    grid-template-rows: auto auto;
  }
}
@media (min-width: 1024px) {
  .project .system .produced {
    max-width: 100%;
    grid-template-columns: 17fr 10fr 10fr;
    grid-template-rows: auto;
  }
}
.project .system .produced figure {
  display: block;
  position: relative;
  width: 100%;
}
.project .system .produced figure figcaption {
  bottom: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  right: clamp(0.784rem, 0.5291005291vw, 0.8rem);
}
.project .system .produced .electric {
  grid-column: span 2;
  height: 100%;
}
@media (min-width: 1024px) {
  .project .system .produced .electric {
    grid-column: span 1;
  }
}
.project .system .produced .gas {
  height: auto;
  aspect-ratio: 1/1;
}
.project .system .produced .fertilizer {
  position: relative;
  height: auto;
  aspect-ratio: 1/1;
}
.project .system .produced .fertilizer .field {
  width: 100%;
  height: 100%;
}
.project .system .produced .fertilizer .bottle {
  position: absolute;
  top: 0;
  left: 0;
  width: clamp(7.84rem, 5.291005291vw, 8rem);
  height: clamp(7.84rem, 5.291005291vw, 8rem);
}
.project .system figcaption {
  position: absolute;
  width: fit-content;
  height: fit-content;
  padding: 1px clamp(1.376rem, 1.0582010582vw, 1.6rem) 3px clamp(1.376rem, 1.0582010582vw, 1.6rem);
  font-size: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  font-weight: 700;
  line-height: 1;
  color: #FAFAFA;
  white-space: nowrap;
  border-radius: clamp(1.548rem, 1.1904761905vw, 1.8rem);
  border: clamp(0.2rem, 0.1322751323vw, 0.2rem) solid #FAFAFA;
  background: #6FBA2C;
}
.project .project_figure {
  margin-top: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.project .project_figure .figure_text {
  font-size: clamp(1.752rem, 1.5873015873vw, 2.4rem);
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
.project .project_figure .figure_text .underline {
  font-size: clamp(1.168rem, 1.0582010582vw, 1.6rem);
  display: block;
  width: fit-content;
  margin-inline: auto;
  margin-bottom: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  padding: clamp(0.344rem, 0.2645502646vw, 0.4rem) clamp(0.688rem, 0.5291005291vw, 0.8rem);
  border-bottom: 1px solid #231815;
}
.project .project_figure .figureWrap {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
}
.project .project_figure .figureWrap img {
  width: 100%;
  height: auto;
  object-fit: contain;
}
.project .more {
  margin-top: clamp(3.904rem, 4.2328042328vw, 6.4rem);
}
.project .more .moreButtons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(3.612rem, 2.7777777778vw, 4.2rem);
  margin-bottom: clamp(3.612rem, 2.7777777778vw, 4.2rem);
  flex-direction: column;
}
@media (min-width: 850px) {
  .project .more .moreButtons {
    flex-direction: row;
  }
}
.project .more .arrowbutton {
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(2.752rem, 2.1164021164vw, 3.2rem) clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
.project .more .arrowbutton::after {
  right: 0.5em;
}
.project .more .sublink {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(2.064rem, 1.5873015873vw, 2.4rem) clamp(3.612rem, 2.7777777778vw, 4.2rem);
  flex-direction: column;
}
@media (min-width: 850px) {
  .project .more .sublink {
    flex-direction: row;
  }
}
.project .more .sublink .arrowbutton {
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(3.612rem, 2.7777777778vw, 4.2rem) clamp(1.032rem, 0.7936507937vw, 1.2rem) 0;
  border: 0;
  width: clamp(21.756rem, 14.6825396825vw, 22.2rem);
  justify-content: flex-start;
}
.project .more .sublink .arrowbutton::after {
  right: 1.25em;
}
.project .more .sublink .arrowbutton:hover {
  background: transparent;
  color: #231815;
}
.project .more .sublink .arrowbutton:hover::after {
  right: 0.5em;
}
@media (min-width: 850px) {
  .project .more .sublink .arrowbutton {
    width: fit-content;
    justify-content: center;
  }
}

.topics {
  background: #F2F1F1;
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
.topics .sectionheading {
  color: #BDBBBB;
}

.topicslists {
  margin-inline: auto;
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  max-width: clamp(83.398rem, 56.2830687831vw, 85.1rem);
}

.topics-top {
  max-width: clamp(80.262rem, 54.1666666667vw, 81.9rem);
  margin-inline: auto;
  padding: clamp(2.44rem, 2.6455026455vw, 4rem);
}
.topics-top li a {
  padding-block: clamp(1.568rem, 1.0582010582vw, 1.6rem);
}
@media (min-width: 540px) {
  .topics-top li a {
    padding-block: 0;
  }
}
.topics-top li:nth-of-type(n+2) {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
}

.pickups {
  border: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #595757;
  border-radius: clamp(0.488rem, 0.5291005291vw, 0.8rem);
}

.topicsbutton a {
  margin-inline: auto;
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(2.752rem, 2.1164021164vw, 3.2rem) clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(1.376rem, 1.0582010582vw, 1.6rem);
  height: clamp(3.92rem, 2.6455026455vw, 4rem);
}
.topicsbutton a::after {
  right: 0.5em;
}

.about_inner.pre {
  padding-block: clamp(6.344rem, 6.8783068783vw, 10.4rem);
}
.about_inner.pre .companyinfo_heading {
  color: #FAFAFA;
  background: #727171;
  padding: clamp(0.688rem, 0.5291005291vw, 0.8rem) clamp(1.376rem, 1.0582010582vw, 1.6rem);
  font-size: clamp(1.806rem, 1.3888888889vw, 2.1rem);
  font-weight: 700;
  line-height: 1.2;
}
.about_inner.pre .companyinfo {
  max-width: clamp(63.112rem, 42.5925925926vw, 64.4rem);
  margin-inline: auto;
}
.about_inner.pre .companyinfo dl {
  margin-top: clamp(3.612rem, 2.7777777778vw, 4.2rem);
  font-size: clamp(1.372rem, 0.9259259259vw, 1.4rem);
  border-top: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
}
.about_inner.pre .companyinfo dl > div {
  display: grid;
  grid-template-columns: clamp(6.272rem, 4.2328042328vw, 6.4rem) auto;
  padding-block: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  border-bottom: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
  gap: clamp(1.376rem, 1.0582010582vw, 1.6rem);
}
.about_inner.pre .companyinfo dl .logolist {
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: clamp(4.214rem, 2.8439153439vw, 4.3rem) auto;
  align-items: center;
  justify-items: start;
  gap: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(2.064rem, 1.5873015873vw, 2.4rem);
}
@media (min-width: 768px) {
  .about_inner.pre .companyinfo dl .logolist {
    grid-template-columns: clamp(14.7rem, 9.9206349206vw, 15rem) clamp(14.7rem, 9.9206349206vw, 15rem) clamp(17.64rem, 11.9047619048vw, 18rem);
    justify-items: center;
  }
}
.about_inner.pre .companyinfo dl .logolist .logo {
  display: grid;
  grid-row: span 2;
  grid-template-rows: subgrid;
  gap: 0;
  align-items: center;
  justify-items: center;
  text-align: center;
  font-size: clamp(1.032rem, 0.7936507937vw, 1.2rem);
}
.about_inner.pre .companyinfo dl .logolist .logo > div {
  align-self: start;
  white-space: nowrap;
}
.about_inner.pre .companyinfo dl img {
  width: auto;
  max-width: clamp(13.76rem, 10.582010582vw, 16rem);
  max-height: clamp(4.214rem, 2.8439153439vw, 4.3rem);
  object-fit: contain;
}

.contact {
  background: no-repeat url(../img/top/contact/contact.webp) center center/cover;
}

.contact_inner {
  padding-block: clamp(2.92rem, 2.6455026455vw, 4rem);
  position: relative;
  background: rgba(111, 186, 44, 0.5019607843);
  transition: all 0.3s ease-in-out;
}
.contact_inner:hover {
  background: rgba(111, 186, 44, 0);
}
.contact_inner:hover .arrowbutton {
  background: #6FBA2C;
  color: #FAFAFA;
  border: 1px solid #6FBA2C;
}
.contact_inner:hover .arrowbutton::after {
  right: 0.5em;
}
.contact_inner .sectionheading {
  color: #FAFAFA;
}
.contact_inner .text {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  font-size: clamp(1.806rem, 1.3888888889vw, 2.1rem);
  font-weight: 700;
  line-height: 1.6;
  text-align: center;
  color: #FAFAFA;
}
.contact_inner .arrowbutton {
  margin-top: clamp(2.064rem, 1.5873015873vw, 2.4rem);
  margin-inline: auto;
  padding: clamp(1.032rem, 0.7936507937vw, 1.2rem) clamp(4.816rem, 3.7037037037vw, 5.6rem);
}
.contact_inner a.largeblock {
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
}

.topics-cardlist {
  max-width: clamp(80.262rem, 54.1666666667vw, 81.9rem);
  margin-inline: auto;
}
.topics-cardlist li {
  padding: clamp(2.352rem, 1.5873015873vw, 2.4rem) clamp(1.464rem, 1.5873015873vw, 2.4rem);
}
.topics-cardlist li.sticky {
  background: #F2F1F1;
  padding: clamp(2.352rem, 1.5873015873vw, 2.4rem) clamp(1.464rem, 1.5873015873vw, 2.4rem);
}

.topics-card {
  display: grid;
  grid-template-columns: auto;
  align-items: center;
  background: #FAFAFA;
  transition: all 0.3s ease-in-out;
}
@media (min-width: 540px) {
  .topics-card {
    grid-template-columns: auto clamp(17.2rem, 13.2275132275vw, 20rem);
  }
}
@media (min-width: 768px) {
  .topics-card {
    grid-template-columns: auto min-content;
  }
}
.topics-card:hover {
  background: #D8ECC5;
}

.card-textWrap {
  padding: clamp(1.568rem, 1.0582010582vw, 1.6rem) clamp(1.568rem, 1.0582010582vw, 1.6rem) clamp(1.568rem, 1.0582010582vw, 1.6rem) clamp(2.352rem, 1.5873015873vw, 2.4rem);
}

.card-header {
  align-self: self-end;
  display: flex;
  justify-content: flex-start;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  height: auto;
}
.card-header .sticky-label img {
  display: block;
}
.card-header .date {
  font-size: clamp(1.372rem, 0.9259259259vw, 1.4rem);
  font-weight: 400;
  line-height: 1;
}
.card-header .category {
  color: #FAFAFA;
  background: #BDBBBB;
  min-width: clamp(8.6rem, 6.6137566138vw, 10rem);
  padding: clamp(0.294rem, 0.1984126984vw, 0.3rem) clamp(0.392rem, 0.2645502646vw, 0.4rem) clamp(0.392rem, 0.2645502646vw, 0.4rem) clamp(0.392rem, 0.2645502646vw, 0.4rem);
  font-size: clamp(1.204rem, 0.9259259259vw, 1.4rem);
  text-align: center;
  line-height: 1;
}

.card-title {
  margin-top: clamp(1.568rem, 1.0582010582vw, 1.6rem);
}
.card-title .articletitle {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  line-clamp: 1;
  text-overflow: ellipsis;
  height: 1.3em;
  overflow: hidden;
  font-size: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  font-weight: 700;
  line-height: 1.3;
  hyphens: auto;
}

.card-text {
  margin-top: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  text-overflow: ellipsis;
  height: 4.8em;
  overflow: hidden;
  font-size: clamp(1.372rem, 0.9259259259vw, 1.4rem);
  font-weight: 400;
  line-height: 1.6;
}
.card-text p {
  hyphens: auto;
  overflow-wrap: break-word;
  word-break: break-all;
}

.card-imgWrap {
  background: #FAFAFA;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-eyecatch {
  width: auto;
  height: 100%;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width: 540px) {
  .card-eyecatch {
    aspect-ratio: 4/3;
  }
}
.card-eyecatch img {
  width: 100%;
  height: 100%;
}
.card-eyecatch img.logoimg {
  padding: clamp(1.568rem, 1.0582010582vw, 1.6rem);
  height: auto;
  object-fit: contain;
}
.card-eyecatch img.noimg {
  height: auto;
  object-fit: contain;
}

.archivelist {
  display: grid;
  grid-template-columns: auto;
  gap: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  padding-bottom: clamp(3.92rem, 2.6455026455vw, 4rem);
}
@media (min-width: 540px) {
  .archivelist {
    padding-bottom: 4.2328042328vw;
    grid-template-columns: auto clamp(15.48rem, 11.9047619048vw, 18rem);
  }
}
@media (min-width: 768px) {
  .archivelist {
    grid-template-columns: auto clamp(25.8rem, 19.8412698413vw, 30rem);
  }
}
.archivelist p {
  margin-bottom: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  color: #ffffff;
}
.archivelist .archivelist-category .archivelist-categorylist {
  display: grid;
  gap: clamp(0.784rem, 0.5291005291vw, 0.8rem);
  grid-template-columns: repeat(3, 1fr);
}
@media (min-width: 540px) {
  .archivelist .archivelist-category .archivelist-categorylist {
    grid-template-columns: repeat(auto-fill, minmax(127px, 10.582010582vw));
  }
}
.archivelist .archivelist-category .archivelist-categorylist li {
  overflow: hidden;
}
.archivelist .archivelist-category .archivelist-categorylist a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: clamp(4.644rem, 3.5714285714vw, 5.4rem);
  font-size: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  font-weight: 700;
  line-height: 1;
  text-align: center;
  overflow: hidden;
  color: #ffffff;
  background: #BDBBBB;
}
@media (min-width: 540px) {
  .archivelist .archivelist-category .archivelist-categorylist a {
    padding: clamp(1.376rem, 1.0582010582vw, 1.6rem);
    white-space: nowrap;
  }
}
.archivelist .archivelist-category .archivelist-categorylist a:hover {
  opacity: 0.7;
}
.archivelist .archivelist-category .archivelist-categorylist .cat-item a:hover {
  opacity: 0.7;
}
.archivelist .archivelist-date {
  width: 100%;
  flex-shrink: 0;
  position: relative;
}
@media (min-width: 540px) {
  .archivelist .archivelist-date {
    width: clamp(15.48rem, 11.9047619048vw, 18rem);
  }
}
@media (min-width: 768px) {
  .archivelist .archivelist-date {
    width: clamp(25.8rem, 19.8412698413vw, 30rem);
  }
}
.archivelist .archivelist-date input[type=checkbox] {
  display: none;
}
.archivelist .archivelist-date label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: clamp(4.644rem, 3.5714285714vw, 5.4rem);
  padding-left: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  border-bottom: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
  border-left: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
}
.archivelist .archivelist-date label img {
  width: clamp(1.376rem, 1.0582010582vw, 1.6rem);
  transition: all 0.3s ease-in-out;
}
.archivelist .archivelist-date .archivelist-yearlist {
  height: 0;
  width: 100%;
  overflow: hidden;
  border-bottom: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
  border-left: clamp(0.1rem, 0.0661375661vw, 0.1rem) solid #231815;
  background: #FAFAFA;
  position: absolute;
  transition: all 0.3s ease-in-out;
  opacity: 0;
}
.archivelist .archivelist-date .archivelist-yearlist a {
  width: 100%;
  height: clamp(4.644rem, 3.5714285714vw, 5.4rem);
  padding-left: clamp(0.688rem, 0.5291005291vw, 0.8rem);
  display: flex;
  align-items: center;
}
.archivelist .archivelist-date .archivelist-yearlist a:hover {
  background: #B9B6B3;
}
.archivelist .archivelist-date label:has(input[type=checkbox]:checked) {
  border-bottom: 0;
}
.archivelist .archivelist-date label:has(input[type=checkbox]:checked) img {
  transform: rotate(180deg);
}
.archivelist .archivelist-date label:has(input[type=checkbox]:checked) + ul.archivelist-yearlist {
  height: auto;
  z-index: 1;
  opacity: 1;
}
.archivelist .archivelist-date .archivelist-yearlistItem .count {
  font-size: clamp(1.176rem, 0.7936507937vw, 1.2rem);
  margin-left: 0.25em;
}

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