@charset "UTF-8";
/* line 3, common.scss */
html,
body,
div,
span,
applet,
object,
iframe,
h1, h2, h3, h4, h5, h6,
p,
blockquote,
pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q,
s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside,
canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  vertical-align: baseline; }

/* line 23, common.scss */
*,
*::before,
*::after {
  box-sizing: border-box; }

/* line 28, common.scss */
html,
body {
  overflow-x: clip; }

/* line 32, common.scss */
html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth; }

/* line 37, common.scss */
body {
  font-size: 15px;
  color: #1D1D1D;
  line-height: 1;
  background-color: #FCF6ED;
  -webkit-font-smoothing: antialiased; }
  /* line 43, common.scss */
  body.fixed {
    width: 100%;
    height: 100%;
    position: fixed; }

/* line 49, common.scss */
:target {
  scroll-margin-top: 90px; }
  @media screen and (max-width: 800px) {
    /* line 49, common.scss */
    :target {
      scroll-margin-top: 78px; } }

/* line 55, common.scss */
body,
input,
textarea {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400; }

/* line 61, common.scss */
.en {
  font-family: "Poppins", sans-serif;
  font-weight: 400; }

/* line 67, common.scss */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/* line 71, common.scss */
caption,
th,
td {
  font-weight: normal;
  text-align: left; }

/* line 77, common.scss */
h1,
h2,
h3,
h4,
h5,
h6 {
  position: relative;
  color: #1D1D1D;
  clear: both;
  line-height: 1;
  letter-spacing: 0.05em;
  margin: 0;
  padding: 0; }

/* line 91, common.scss */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
  display: block; }

/* line 103, common.scss */
p {
  color: #1D1D1D;
  margin-bottom: 15px;
  letter-spacing: 0.05em;
  line-height: 1.8; }

/* line 109, common.scss */
ol,
ul {
  list-style: none; }

/* line 113, common.scss */
ul li,
ol li {
  line-height: 1.6;
  letter-spacing: 0.05em;
  margin: 0 0 5px; }

/* line 120, common.scss */
ol {
  list-style: decimal;
  margin: 0 0 20px 1.5em; }

/* line 124, common.scss */
ul ul,
ol ol,
ul ol,
ol ul {
  margin-bottom: 0; }

/* line 130, common.scss */
dl {
  margin: 0 0 24px 0; }

/* line 133, common.scss */
dt,
dd {
  line-height: 1.6; }

/* line 137, common.scss */
dt {
  font-weight: bold; }

/* line 140, common.scss */
dd {
  margin: 0; }

/* line 143, common.scss */
strong {
  font-weight: bold; }

/* line 146, common.scss */
cite,
i {
  font-style: normal; }

/* line 150, common.scss */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

/* line 157, common.scss */
sup {
  top: -0.5em; }

/* line 160, common.scss */
sub {
  bottom: -0.25em; }

/* line 163, common.scss */
small {
  font-size: smaller; }

/* line 166, common.scss */
img {
  border: none;
  vertical-align: top;
  max-width: 100%;
  height: auto; }
  /* line 171, common.scss */
  img.nosave {
    pointer-events: none;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-touch-callout: none;
    -moz-user-select: none;
    user-select: none; }

/* line 180, common.scss */
video {
  width: 100%; }

/* line 183, common.scss */
address {
  font-style: normal; }

/* line 188, common.scss */
.alignleft {
  float: left; }

/* line 191, common.scss */
.alignright {
  float: right; }

/* line 194, common.scss */
.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto; }

/* line 199, common.scss */
a {
  color: #1D1D1D;
  text-decoration: underline; }
  @media screen and (min-width: 800px) {
    /* line 203, common.scss */
    a:hover {
      text-decoration: none; }
      /* line 206, common.scss */
      a:hover .btn_arrow::before {
        translate: 350% -50%; }
      /* line 209, common.scss */
      a:hover .btn_arrow::after {
        translate: -50% -50%; }
      /* line 213, common.scss */
      a:hover .btn_viewmore {
        text-decoration: underline; } }

/* line 220, common.scss */
a:focus, *:focus {
  outline: none; }

/* line 223, common.scss */
.pc {
  display: block; }
  @media screen and (max-width: 800px) {
    /* line 223, common.scss */
    .pc {
      display: none; } }

/* line 229, common.scss */
.sp {
  display: none; }
  @media screen and (max-width: 800px) {
    /* line 229, common.scss */
    .sp {
      display: block; } }

/* line 235, common.scss */
.komelist {
  margin: 0 0 30px; }

/* line 238, common.scss */
.komelist li {
  color: #E7380D;
  list-style: none;
  margin-left: 1em; }
  /* line 242, common.scss */
  .komelist li:last-child {
    margin-bottom: 0; }

/* line 246, common.scss */
.komelist li::before {
  content: "※";
  margin-left: -1em; }

/* line 251, common.scss */
.cbox {
  position: relative;
  width: calc(100% - 40px);
  max-width: 1000px;
  margin: 0 auto; }
  /* line 256, common.scss */
  .cbox.cbox740 {
    max-width: 740px; }
  /* line 259, common.scss */
  .cbox.cbox800 {
    max-width: 800px; }
  /* line 262, common.scss */
  .cbox.cbox860 {
    max-width: 860px; }
  /* line 265, common.scss */
  .cbox.cbox1120 {
    max-width: 1120px; }
  /* line 268, common.scss */
  .cbox.cbox1320 {
    max-width: 1320px; }

/* line 272, common.scss */
.content {
  padding-bottom: 0; }

/* line 275, common.scss */
.txtright {
  display: block;
  text-align: right; }

/* line 279, common.scss */
.txtcenter {
  text-align: center; }

/* line 282, common.scss */
[data-aos="fadein"] {
  opacity: 0;
  transition-property: transform, opacity; }
  /* line 285, common.scss */
  [data-aos="fadein"].aos-animate {
    opacity: 1; }

/* line 289, common.scss */
[data-aos="fadeup"] {
  opacity: 0;
  transition-property: transform, opacity;
  transform: translate(0px, 20px); }
  /* line 293, common.scss */
  [data-aos="fadeup"].aos-animate {
    opacity: 1;
    transform: translate(0); }

/* line 298, common.scss */
.bg_lightorange {
  background-color: #F5EDE1;
  border-radius: 20px; }
  @media screen and (max-width: 800px) {
    /* line 298, common.scss */
    .bg_lightorange {
      border-radius: 15px; } }

/* line 308, common.scss */
.site-header {
  display: flex;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 80px;
  z-index: 3;
  background-color: #FFFFFF;
  border-bottom: 1px solid #E1E2E6;
  transition: all 0.3s ease-out; }
  @media screen and (max-width: 800px) {
    /* line 308, common.scss */
    .site-header {
      height: 68px; } }
  /* line 323, common.scss */
  .site-header.hide {
    translate: 0 -100%; }
  /* line 326, common.scss */
  .site-header.white {
    background: none;
    border: none; }
    /* line 330, common.scss */
    .site-header.white .site-title a {
      background-image: url("../img/logo_white.svg");
      background-repeat: no-repeat;
      background-position: left top;
      background-size: 192px 44px; }
      @media screen and (max-width: 800px) {
        /* line 330, common.scss */
        .site-header.white .site-title a {
          background-size: 157px 36px; } }
      /* line 338, common.scss */
      .site-header.white .site-title a img {
        opacity: 0; }
    /* line 346, common.scss */
    .site-header.white .mainmenu ul li a {
      color: #FFFFFF; }
  /* line 353, common.scss */
  .site-header.open-header {
    background-color: #FFFFFF;
    border-bottom: 1px solid #E1E2E6;
    translate: 0 0; }
    /* line 358, common.scss */
    .site-header.open-header .site-title a {
      background: none; }
      /* line 360, common.scss */
      .site-header.open-header .site-title a img {
        opacity: 1; }
    /* line 368, common.scss */
    .site-header.open-header .mainmenu ul li a {
      color: #1D1D1D; }
  /* line 375, common.scss */
  .site-header .site-title {
    display: inline-block;
    position: absolute;
    top: 50%;
    left: 20px;
    translate: 0 -50%;
    width: 192px;
    height: 44px; }
    @media screen and (max-width: 800px) {
      /* line 375, common.scss */
      .site-header .site-title {
        width: 157px;
        height: 36px;
        left: 15px; } }
    /* line 388, common.scss */
    .site-header .site-title a {
      display: block;
      width: 100%;
      height: 100%; }
      /* line 392, common.scss */
      .site-header .site-title a img {
        opacity: 1;
        transition: opacity 0.3s ease-out; }

/* line 404, common.scss */
#toggle {
  display: none; }
  @media screen and (max-width: 800px) {
    /* line 404, common.scss */
    #toggle {
      display: block;
      position: absolute;
      top: 11px;
      right: 64px;
      width: 46px;
      height: 46px;
      background-color: #FFFFFF;
      border: 1px solid #DDDDDD;
      border-radius: 50%;
      padding: 0;
      cursor: pointer;
      z-index: 10; } }

@media screen and (max-width: 800px) {
  /* line 421, common.scss */
  .menu-trigger,
  .menu-trigger span {
    display: inline-block;
    transition: all 0.4s; } }

@media screen and (max-width: 800px) {
  /* line 428, common.scss */
  .menu-trigger {
    display: block;
    position: relative;
    width: 100%;
    height: 100%;
    outline: none; }
    /* line 435, common.scss */
    .menu-trigger span {
      display: block;
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      background-color: #1D1D1D;
      width: 14px;
      height: 1px; }
      /* line 443, common.scss */
      .menu-trigger span:nth-of-type(1) {
        top: 18px; }
      /* line 446, common.scss */
      .menu-trigger span:nth-of-type(2) {
        top: 22px; }
      /* line 449, common.scss */
      .menu-trigger span:nth-of-type(3) {
        top: 26px; }
    /* line 454, common.scss */
    .menu-trigger.active :nth-of-type(1) {
      -webkit-transform: translate(-50%, 4px) rotate(30deg);
      transform: translate(-50%, 4px) rotate(30deg); }
    /* line 458, common.scss */
    .menu-trigger.active :nth-of-type(2) {
      opacity: 0; }
    /* line 461, common.scss */
    .menu-trigger.active :nth-of-type(3) {
      -webkit-transform: translate(-50%, -4px) rotate(-30deg);
      transform: translate(-50%, -4px) rotate(-30deg); } }

/* line 468, common.scss */
.mcontact {
  position: absolute;
  top: 17px;
  right: 18px;
  display: inline-flex;
  align-items: center;
  width: 180px;
  height: 46px;
  color: #FFFFFF;
  font-weight: 700;
  text-decoration: none;
  background-color: #1D1D1D;
  border-radius: 9999px;
  z-index: 3;
  overflow: hidden; }
  @media screen and (min-width: 800px) {
    /* line 485, common.scss */
    .mcontact:hover span {
      translate: 0 0; }
    /* line 488, common.scss */
    .mcontact:hover::before {
      top: 0; } }
  @media screen and (max-width: 1000px) {
    /* line 468, common.scss */
    .mcontact {
      right: 20px;
      width: 160px; } }
  @media screen and (max-width: 800px) {
    /* line 468, common.scss */
    .mcontact {
      justify-content: center;
      top: 11px;
      right: 10px;
      width: 46px;
      height: 46px;
      border-radius: 50%; } }
  /* line 505, common.scss */
  .mcontact::before {
    position: absolute;
    left: 0;
    top: 100%;
    width: 100%;
    height: 100%;
    background-color: #06CB43;
    content: "";
    transition: all 0.3s ease-out;
    z-index: 0; }
    @media screen and (max-width: 800px) {
      /* line 505, common.scss */
      .mcontact::before {
        display: none; } }
  /* line 519, common.scss */
  .mcontact span {
    background-image: url("../img/icon_contact.svg");
    background-repeat: no-repeat;
    background-position: 30px calc(50% + 1px);
    background-size: 18px 22px;
    padding-left: 60px; }
    @media screen and (max-width: 1000px) {
      /* line 519, common.scss */
      .mcontact span {
        background-position: 20px calc(50% + 1px);
        padding-left: 50px; } }
    @media screen and (max-width: 800px) {
      /* line 519, common.scss */
      .mcontact span {
        display: inline-block;
        width: 18px;
        height: 22px;
        font-size: 0;
        padding-left: 0;
        background-position: center center; } }

/* line 542, common.scss */
.mainmenu {
  position: fixed;
  top: 0;
  right: 240px;
  width: auto;
  height: 80px;
  display: flex;
  align-content: center;
  align-items: center;
  z-index: 3; }
  @media screen and (max-width: 1000px) {
    /* line 542, common.scss */
    .mainmenu {
      right: 200px; } }
  @media screen and (max-width: 800px) {
    /* line 542, common.scss */
    .mainmenu {
      display: none; } }
  /* line 558, common.scss */
  .mainmenu ul {
    display: flex;
    align-items: center;
    gap: 0 43px;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0; }
    @media screen and (max-width: 1000px) {
      /* line 558, common.scss */
      .mainmenu ul {
        gap: 0 15px; } }
    /* line 569, common.scss */
    .mainmenu ul li {
      position: relative;
      line-height: 1;
      margin: 0;
      padding: 0; }
      /* line 576, common.scss */
      .mainmenu ul li.active a span {
        translate: 0 -200%; }
      /* line 579, common.scss */
      .mainmenu ul li.active a::after {
        translate: 0 0; }
      /* line 584, common.scss */
      .mainmenu ul li a {
        position: relative;
        display: inline-flex;
        align-items: center;
        font-size: 15px;
        font-weight: 500;
        text-decoration: none;
        overflow: hidden; }
        @media screen and (max-width: 1000px) {
          /* line 584, common.scss */
          .mainmenu ul li a {
            font-size: 13px; } }
        /* line 595, common.scss */
        .mainmenu ul li a span {
          position: relative;
          display: inline-block;
          translate: 0 0;
          transition: all 0.3s ease-out;
          z-index: 1; }
        /* line 602, common.scss */
        .mainmenu ul li a::after {
          position: absolute;
          left: 0;
          top: 0;
          translate: 0 200%;
          color: #06CB43;
          content: attr(data-text);
          transition: all 0.3s ease-out; }
        @media screen and (min-width: 800px) {
          /* line 613, common.scss */
          .mainmenu ul li a:hover span {
            translate: 0 -200%; }
          /* line 616, common.scss */
          .mainmenu ul li a:hover::after {
            translate: 0 0; } }

/* line 628, common.scss */
.submenubox {
  display: none;
  position: fixed;
  left: 50%;
  top: 90px;
  translate: -50% 0;
  overflow: hidden;
  width: calc(100% - 80px);
  height: auto;
  margin: 0 auto;
  padding: 60px 20px;
  background-color: #FFFFFF;
  border-radius: 30px; }
  /* line 641, common.scss */
  .submenubox .menubox {
    display: block;
    position: relative;
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
    height: 100%; }
    /* line 648, common.scss */
    .submenubox .menubox nav {
      width: 100%; }
      /* line 650, common.scss */
      .submenubox .menubox nav ul {
        width: 100%;
        margin: 0;
        padding: 0; }
        /* line 654, common.scss */
        .submenubox .menubox nav ul li {
          width: 100%;
          line-height: 1.1;
          margin: 0;
          padding: 0; }
          /* line 659, common.scss */
          .submenubox .menubox nav ul li a {
            position: relative;
            font-size: 22px;
            font-weight: 700;
            text-decoration: none;
            padding-left: 37px;
            transition: color 0.3s ease-out; }
            @media screen and (min-width: 800px) {
              /* line 667, common.scss */
              .submenubox .menubox nav ul li a:hover {
                color: #06CB43; } }
            /* line 671, common.scss */
            .submenubox .menubox nav ul li a .btn_arrow {
              left: 0;
              right: auto;
              background-color: #06CB43; }
              /* line 675, common.scss */
              .submenubox .menubox nav ul li a .btn_arrow::before, .submenubox .menubox nav ul li a .btn_arrow::after {
                background-color: #FFFFFF; }
          /* line 681, common.scss */
          .submenubox .menubox nav ul li ul {
            display: flex;
            flex-wrap: wrap;
            gap: 30px 5%;
            margin-top: 45px; }
            /* line 686, common.scss */
            .submenubox .menubox nav ul li ul li {
              width: 30%; }
              /* line 688, common.scss */
              .submenubox .menubox nav ul li ul li a {
                display: inline-block;
                width: 100%;
                height: auto;
                font-size: 16px;
                font-weight: 400;
                border-bottom: 1px solid #DDDDDD;
                padding: 0 0 15px 35px; }
                @media screen and (min-width: 800px) {
                  /* line 697, common.scss */
                  .submenubox .menubox nav ul li ul li a:hover {
                    text-decoration: underline; } }
                /* line 701, common.scss */
                .submenubox .menubox nav ul li ul li a::before {
                  position: absolute;
                  left: 18px;
                  top: 4px;
                  width: 8px;
                  height: 10px;
                  mask-image: url("../img/arrow_r.svg");
                  mask-size: cover;
                  background-color: #06CB43;
                  content: ""; }

/* line 723, common.scss */
.spmainmenubox {
  display: none; }
  @media screen and (max-width: 800px) {
    /* line 723, common.scss */
    .spmainmenubox {
      display: block;
      position: fixed;
      top: 68px;
      left: 0;
      width: 100%;
      height: calc(100dvh - 68px);
      background-color: #FCF6ED;
      padding-top: 15px;
      z-index: 3;
      transition: all 0.3s ease-out;
      opacity: 0;
      pointer-events: none; }
      /* line 738, common.scss */
      .spmainmenubox.open {
        opacity: 1;
        pointer-events: auto; } }
  @media screen and (max-width: 800px) {
    /* line 743, common.scss */
    .spmainmenubox .spmenubox {
      position: relative;
      width: 100%;
      height: 100%;
      padding: 0 40px;
      overflow-y: auto;
      z-index: 2; } }
  @media screen and (max-width: 800px) {
    /* line 752, common.scss */
    .spmainmenubox .spmenubox .spmainmenu {
      padding: 0 0 25px; }
      /* line 755, common.scss */
      .spmainmenubox .spmenubox .spmainmenu ul {
        width: 100%;
        margin: 0;
        padding: 0; }
        /* line 759, common.scss */
        .spmainmenubox .spmenubox .spmainmenu ul li {
          width: 100%;
          margin: 0;
          padding: 0;
          line-height: 1.4;
          border-bottom: 1px solid #DDDDDD; }
          /* line 765, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li a {
            position: relative;
            display: block;
            font-size: 18px;
            font-weight: 700;
            text-decoration: none;
            padding: 25px 40px 25px 0px; }
            /* line 772, common.scss */
            .spmainmenubox .spmenubox .spmainmenu ul li a .btn_arrow {
              right: 0;
              background-color: #06CB43; }
              /* line 775, common.scss */
              .spmainmenubox .spmenubox .spmainmenu ul li a .btn_arrow::before, .spmainmenubox .spmenubox .spmainmenu ul li a .btn_arrow::after {
                background-color: #FFFFFF; }
          /* line 782, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li.en a {
            font-size: 20px; }
          /* line 789, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li.spmsub a .btn_arrow::before, .spmainmenubox .spmenubox .spmainmenu ul li.spmsub a .btn_arrow::after {
            display: block;
            top: 50%;
            left: 50%;
            translate: -50% -50%;
            width: 10px;
            height: 2px;
            mask: none;
            background-color: #FFFFFF;
            transition: all 0.3s ease-out; }
          /* line 801, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li.spmsub a .btn_arrow::after {
            rotate: -90deg; }
          /* line 805, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li.spmsub a.open {
            color: #06CB43; }
            /* line 808, common.scss */
            .spmainmenubox .spmenubox .spmainmenu ul li.spmsub a.open .btn_arrow::after {
              rotate: 0deg;
              opacity: 0; }
          /* line 816, common.scss */
          .spmainmenubox .spmenubox .spmainmenu ul li ul {
            display: none;
            padding: 0 0 0 30px; }
            /* line 819, common.scss */
            .spmainmenubox .spmenubox .spmainmenu ul li ul li {
              width: 100%;
              margin-bottom: 20px;
              border-bottom: none; }
              /* line 823, common.scss */
              .spmainmenubox .spmenubox .spmainmenu ul li ul li a {
                font-size: 14px;
                font-weight: 400;
                padding: 0 25px 0 0; }
                /* line 827, common.scss */
                .spmainmenubox .spmenubox .spmainmenu ul li ul li a::before {
                  position: absolute;
                  right: 8px;
                  top: 3px;
                  width: 8px;
                  height: 10px;
                  mask-image: url("../img/arrow_r.svg");
                  mask-size: cover;
                  background-color: #06CB43;
                  content: ""; } }
  /* line 845, common.scss */
  .spmainmenubox .spmenubox .spsubmenu {
    padding-bottom: 15px; }
    /* line 847, common.scss */
    .spmainmenubox .spmenubox .spsubmenu ul {
      margin: 0;
      padding: 0; }
      /* line 850, common.scss */
      .spmainmenubox .spmenubox .spsubmenu ul li {
        padding: 0;
        margin-bottom: 15px; }
        /* line 853, common.scss */
        .spmainmenubox .spmenubox .spsubmenu ul li a {
          font-size: 14px;
          text-decoration: none; }

/* line 866, common.scss */
.overlay {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(29, 29, 29, 0.4);
  opacity: 0;
  transition: opacity 0.2s ease-out;
  pointer-events: none;
  z-index: 0; }
  /* line 877, common.scss */
  .overlay.active {
    opacity: 1;
    z-index: 2;
    pointer-events: auto; }

/* line 887, common.scss */
.page-title {
  position: relative;
  width: 100%;
  margin-bottom: 100px; }
  @media screen and (max-width: 800px) {
    /* line 887, common.scss */
    .page-title {
      margin-bottom: 80px; } }
  /* line 894, common.scss */
  .page-title .breadcrumb {
    position: relative;
    display: flex;
    justify-content: flex-end;
    width: 100%;
    padding: 40px 0 0; }
    @media screen and (max-width: 800px) {
      /* line 894, common.scss */
      .page-title .breadcrumb {
        padding: 20px 0 10px;
        overflow-x: auto;
        word-break: keep-all;
        white-space: nowrap; } }
    /* line 906, common.scss */
    .page-title .breadcrumb p {
      display: inline-block;
      color: #8D8D8D;
      font-size: 13px;
      margin: 0; }
      @media screen and (max-width: 800px) {
        /* line 906, common.scss */
        .page-title .breadcrumb p {
          font-size: 11px; } }
      /* line 914, common.scss */
      .page-title .breadcrumb p br {
        display: none; }
      /* line 917, common.scss */
      .page-title .breadcrumb p a {
        text-decoration: none; }
      /* line 920, common.scss */
      .page-title .breadcrumb p span {
        margin: 0 5px; }
        /* line 922, common.scss */
        .page-title .breadcrumb p span.bhome {
          font-family: "Poppins", sans-serif;
          font-size: 15px;
          margin-left: 0; }
          @media screen and (max-width: 800px) {
            /* line 922, common.scss */
            .page-title .breadcrumb p span.bhome {
              font-size: 13px; } }
        /* line 930, common.scss */
        .page-title .breadcrumb p span.kugiri {
          color: #06CB43;
          margin: 0; }
        /* line 934, common.scss */
        .page-title .breadcrumb p span span {
          margin: 0; }
  /* line 940, common.scss */
  .page-title .greenline-head {
    position: relative;
    max-width: 365px;
    margin: -25px 0 20px -182px;
    z-index: 0;
    pointer-events: none; }
    @media screen and (max-width: 800px) {
      /* line 940, common.scss */
      .page-title .greenline-head {
        left: -10px;
        max-width: 260px;
        margin: 0 0 25px; } }
    /* line 951, common.scss */
    .page-title .greenline-head.noleaf {
      opacity: 0; }
      @media screen and (max-width: 800px) {
        /* line 951, common.scss */
        .page-title .greenline-head.noleaf {
          margin-bottom: 0; } }
  /* line 958, common.scss */
  .page-title h1 {
    position: relative;
    font-weight: 700;
    margin: 0; }
    @media screen and (max-width: 800px) {
      /* line 958, common.scss */
      .page-title h1 {
        position: relative; } }
    /* line 965, common.scss */
    .page-title h1.no-leaf {
      margin-top: 60px; }
    /* line 968, common.scss */
    .page-title h1 .parent-title {
      position: relative;
      display: block;
      font-family: "Poppins", sans-serif;
      font-size: 20px;
      padding-left: 28px;
      margin-bottom: 20px; }
      @media screen and (max-width: 800px) {
        /* line 968, common.scss */
        .page-title h1 .parent-title {
          margin-bottom: 15px; } }
      /* line 978, common.scss */
      .page-title h1 .parent-title::before {
        position: absolute;
        left: 0;
        top: 50%;
        translate: 0 -50%;
        width: 20px;
        height: 6px;
        background-color: #06CB43;
        content: ""; }
    /* line 989, common.scss */
    .page-title h1 .en {
      display: block;
      font-size: 74px;
      font-weight: 700;
      text-transform: uppercase;
      line-height: 1;
      margin-bottom: 20px; }
      @media screen and (max-width: 800px) {
        /* line 989, common.scss */
        .page-title h1 .en {
          font-size: 42px;
          margin-bottom: 10px; } }
    /* line 1001, common.scss */
    .page-title h1 .jp {
      display: block;
      font-size: 28px;
      letter-spacing: 0.1em; }
      @media screen and (max-width: 800px) {
        /* line 1001, common.scss */
        .page-title h1 .jp {
          font-size: 18px; } }
  /* line 1010, common.scss */
  .page-title.page-topimage {
    height: 428px;
    margin-bottom: 85px; }
    @media screen and (max-width: 800px) {
      /* line 1010, common.scss */
      .page-title.page-topimage {
        height: 271px;
        margin-bottom: 65px; } }
    /* line 1017, common.scss */
    .page-title.page-topimage::before {
      position: absolute;
      left: 0;
      top: 0;
      width: calc(100% - 40px);
      height: 428px;
      content: "";
      background-repeat: no-repeat;
      background-position: center center;
      background-size: cover;
      z-index: 0;
      pointer-events: none;
      border-radius: 0 0 30px 0; }
      @media screen and (max-width: 800px) {
        /* line 1017, common.scss */
        .page-title.page-topimage::before {
          width: calc(100% - 20px);
          height: 271px;
          border-radius: 0 0 15px 0; } }

/* line 1039, common.scss */
.single .page-title {
  margin-bottom: 45px; }
  /* line 1042, common.scss */
  .single .page-title h1 .jp {
    font-size: 28px;
    line-height: 1.6; }
    @media screen and (max-width: 800px) {
      /* line 1042, common.scss */
      .single .page-title h1 .jp {
        font-size: 24px; } }
  /* line 1050, common.scss */
  .single .page-title .cat-head {
    margin: 20px 0 0; }
    /* line 1052, common.scss */
    .single .page-title .cat-head .news-detail {
      display: block; }
      /* line 1054, common.scss */
      .single .page-title .cat-head .news-detail .entrydate {
        display: block;
        margin-top: 10px; }

/* line 1064, common.scss */
h2 {
  font-weight: 700;
  margin-bottom: 24px; }

/* line 1069, common.scss */
.wrapper h2 {
  font-size: 24px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  padding-left: 24px;
  margin-bottom: 20px; }
  @media screen and (max-width: 800px) {
    /* line 1069, common.scss */
    .wrapper h2 {
      font-size: 20px;
      margin-bottom: 15px; } }
  /* line 1079, common.scss */
  .wrapper h2::before {
    position: absolute;
    left: 0;
    top: 12px;
    width: 16px;
    height: 16px;
    background-color: #06CB43;
    content: "";
    border-radius: 50%; }
    @media screen and (max-width: 800px) {
      /* line 1079, common.scss */
      .wrapper h2::before {
        top: 9px;
        width: 14px;
        height: 14px; } }
/* line 1095, common.scss */
.wrapper h3 {
  line-height: 1.56;
  border-top: 1px solid #DDDDDD;
  border-bottom: 1px solid #DDDDDD;
  padding: 15px 0; }

/* line 1102, common.scss */
h3 {
  font-size: 18px;
  font-weight: 700;
  padding: 0;
  margin-bottom: 20px; }

/* line 1108, common.scss */
h4 {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: 10px; }

/* line 1114, common.scss */
h5 {
  font-size: 16px;
  font-weight: 700; }

/* line 1118, common.scss */
img.alignleft {
  margin: 0 24px 12px 0; }

/* line 1121, common.scss */
img.alignright {
  margin: 0 0 12px 24px; }

/* line 1124, common.scss */
img.aligncenter {
  margin-bottom: 12px; }

/* line 1127, common.scss */
.wp-caption {
  max-width: 100%;
  height: auto; }
  /* line 1130, common.scss */
  .wp-caption img {
    width: 100%; }
  /* line 1133, common.scss */
  .wp-caption .wp-caption-text {
    width: auto;
    text-align: left;
    font-size: 13px;
    line-height: 1.6;
    margin-top: 10px; }

/* line 1143, common.scss */
.column2 {
  display: flex; }

/* line 1146, common.scss */
.t_green {
  color: #06CB43; }

/* line 1153, common.scss */
main {
  position: relative;
  width: 100%;
  z-index: 1;
  overflow: hidden;
  padding: 80px 0 155px; }
  @media screen and (max-width: 800px) {
    /* line 1153, common.scss */
    main {
      padding: 68px 0 90px; } }

/* line 1167, common.scss */
.wrapper.column2 {
  flex-wrap: wrap;
  justify-content: space-between; }
  /* line 1170, common.scss */
  .wrapper.column2 .content {
    width: calc(100% - 260px); }
    @media screen and (max-width: 800px) {
      /* line 1170, common.scss */
      .wrapper.column2 .content {
        width: 100%;
        order: 1; } }
    /* line 1176, common.scss */
    .wrapper.column2 .content .newslist {
      border-top: 1px solid #DDDDDD; }
  /* line 1180, common.scss */
  .wrapper.column2 .sidebar {
    width: 200px;
    margin-left: 60px; }
    @media screen and (max-width: 800px) {
      /* line 1180, common.scss */
      .wrapper.column2 .sidebar {
        width: 100%;
        margin-left: 0;
        order: 3; } }
    /* line 1188, common.scss */
    .wrapper.column2 .sidebar h2 {
      font-size: 18px;
      font-weight: 700;
      letter-spacing: 0;
      padding: 0;
      margin-bottom: 8px; }
      /* line 1194, common.scss */
      .wrapper.column2 .sidebar h2::before {
        display: none; }
    /* line 1198, common.scss */
    .wrapper.column2 .sidebar .side-pickup {
      margin-bottom: 40px; }
      @media screen and (min-width: 800px) {
        /* line 1205, common.scss */
        .wrapper.column2 .sidebar .side-pickup .workslist li a:hover .cat-works {
          color: #1D1D1D;
          border: none; } }
      /* line 1211, common.scss */
      .wrapper.column2 .sidebar .side-pickup .workslist li a .works-img {
        margin-bottom: 8px; }
        /* line 1213, common.scss */
        .wrapper.column2 .sidebar .side-pickup .workslist li a .works-img img {
          width: 200px;
          height: 150px;
          object-fit: cover;
          border-radius: 14px; }
          @media screen and (max-width: 800px) {
            /* line 1213, common.scss */
            .wrapper.column2 .sidebar .side-pickup .workslist li a .works-img img {
              width: 100%;
              height: 100%; } }
      /* line 1224, common.scss */
      .wrapper.column2 .sidebar .side-pickup .workslist li a .cat-works {
        background-color: #DDDDDD;
        border: none; }
      /* line 1228, common.scss */
      .wrapper.column2 .sidebar .side-pickup .workslist li a .works-title {
        font-size: 13px;
        font-weight: 400;
        overflow: hidden;
        display: -webkit-box;
        text-overflow: ellipsis;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2; }
    /* line 1242, common.scss */
    .wrapper.column2 .sidebar .side-category .categorylist {
      background-color: #FFFFFF;
      border-radius: 15px;
      padding: 30px;
      margin: 0; }
      @media screen and (max-width: 800px) {
        /* line 1242, common.scss */
        .wrapper.column2 .sidebar .side-category .categorylist {
          display: flex;
          flex-wrap: wrap;
          gap: 16px;
          padding: 20px; } }
      /* line 1253, common.scss */
      .wrapper.column2 .sidebar .side-category .categorylist li {
        margin: 0 0 16px;
        padding: 0; }
        @media screen and (max-width: 800px) {
          /* line 1253, common.scss */
          .wrapper.column2 .sidebar .side-category .categorylist li {
            margin: 0; } }
        /* line 1259, common.scss */
        .wrapper.column2 .sidebar .side-category .categorylist li:last-child {
          margin-bottom: 0; }
        /* line 1264, common.scss */
        .wrapper.column2 .sidebar .side-category .categorylist li.current a, .wrapper.column2 .sidebar .side-category .categorylist li.current-cat a {
          color: #06CB43; }
        /* line 1268, common.scss */
        .wrapper.column2 .sidebar .side-category .categorylist li a {
          display: inline-block;
          font-size: 13px;
          font-weight: 700;
          text-decoration: none;
          transition: color 0.3s ease-out; }
          @media screen and (min-width: 800px) {
            /* line 1275, common.scss */
            .wrapper.column2 .sidebar .side-category .categorylist li a:hover {
              color: #06CB43; } }
  @media screen and (max-width: 800px) {
    /* line 1284, common.scss */
    .wrapper.column2 .wp-pagenavi {
      order: 2; } }

/* line 1293, common.scss */
table {
  width: 100%;
  margin: 0 0 64px; }
  @media screen and (max-width: 800px) {
    /* line 1293, common.scss */
    table {
      margin-bottom: 24px; } }
  /* line 1299, common.scss */
  table th,
  table td {
    text-align: left;
    line-height: 1.8;
    vertical-align: top; }
    @media screen and (max-width: 800px) {
      /* line 1299, common.scss */
      table th,
      table td {
        display: block;
        font-size: 14px;
        line-height: 1.875; } }
  /* line 1310, common.scss */
  table th {
    color: #1D1D1D;
    width: 240px;
    font-size: 16px;
    font-weight: 700;
    padding: 25px 20px 25px 0; }
    @media screen and (max-width: 800px) {
      /* line 1310, common.scss */
      table th {
        width: 100%;
        padding: 20px 0; } }
  /* line 1321, common.scss */
  table td {
    width: calc(100% - 240px);
    font-size: 15px;
    letter-spacing: 0.05em;
    padding: 25px 0; }
    @media screen and (max-width: 800px) {
      /* line 1321, common.scss */
      table td {
        width: 100%;
        padding: 20px 0; } }
  /* line 1332, common.scss */
  table.t_border th {
    width: 150px;
    border-bottom: 1px solid #06CB43; }
    @media screen and (max-width: 800px) {
      /* line 1332, common.scss */
      table.t_border th {
        display: table-cell;
        width: 120px; } }
  /* line 1340, common.scss */
  table.t_border td {
    width: calc(100% - 150px);
    padding-left: 40px;
    border-bottom: 1px solid #DDDDDD; }
    @media screen and (max-width: 800px) {
      /* line 1340, common.scss */
      table.t_border td {
        display: table-cell;
        width: calc(100% - 120px);
        padding-left: 20px; } }
    /* line 1349, common.scss */
    table.t_border td dl {
      display: flex;
      flex-wrap: wrap;
      margin: 0;
      padding: 0; }
      @media screen and (max-width: 800px) {
        /* line 1349, common.scss */
        table.t_border td dl {
          display: block; } }
      /* line 1357, common.scss */
      table.t_border td dl dt {
        width: 125px;
        line-height: 1.8;
        margin: 0 0 25px;
        padding: 0; }
        @media screen and (max-width: 800px) {
          /* line 1357, common.scss */
          table.t_border td dl dt {
            width: 100%;
            margin-bottom: 5px; } }
        /* line 1366, common.scss */
        table.t_border td dl dt:last-of-type {
          margin-bottom: 0; }
          @media screen and (max-width: 800px) {
            /* line 1366, common.scss */
            table.t_border td dl dt:last-of-type {
              margin-bottom: 5px; } }
      /* line 1373, common.scss */
      table.t_border td dl dd {
        width: calc(100% - 125px);
        line-height: 1.8;
        margin: 0 0 25px;
        padding: 0; }
        @media screen and (max-width: 800px) {
          /* line 1373, common.scss */
          table.t_border td dl dd {
            width: 100%;
            margin-bottom: 20px; } }
        /* line 1382, common.scss */
        table.t_border td dl dd:last-of-type {
          margin-bottom: 0; }
        /* line 1385, common.scss */
        table.t_border td dl dd .accessmap {
          margin-top: 20px; }

/* line 1394, common.scss */
.attention,
.attention a {
  color: #E7380D; }

/* line 1398, common.scss */
section {
  position: relative;
  clear: both; }

/* line 1402, common.scss */
.thumbnail {
  margin: 0 auto 15px; }

/* line 1405, common.scss */
p.photo_r {
  float: right;
  margin: 0 0 15px 15px; }

/* line 1409, common.scss */
p.photo_l {
  float: left;
  margin: 0 15px 15px 0; }

/* line 1413, common.scss */
p.photo_l {
  float: left;
  margin: 0 15px 15px 0; }

/* line 1417, common.scss */
.aligncenter {
  text-align: center; }

/* line 1422, common.scss */
.scroll-wrapper {
  width: 100%;
  overflow: scroll; }

/* line 1426, common.scss */
.youtube-content {
  display: flex;
  justify-content: center; }

/* line 1430, common.scss */
.youtube,
.accessmap {
  width: 100%;
  aspect-ratio: 16 / 9; }

/* line 1435, common.scss */
.accessmap {
  max-height: 356px; }

/* line 1438, common.scss */
iframe {
  width: 100%;
  height: 100%; }

/* line 1443, common.scss */
.btn {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 296px;
  height: 60px;
  letter-spacing: 0.05em;
  text-decoration: none;
  background-color: #FFFFFF;
  border: 1px solid #06CB43;
  border-radius: 9999px;
  transition: color 0.3s ease-out,background-color 0.3s ease-out;
  padding-left: 40px; }
  /* line 1457, common.scss */
  .btn.center {
    margin: 0 auto; }
  /* line 1460, common.scss */
  .btn.back {
    margin-top: 100px; }
    @media screen and (max-width: 800px) {
      /* line 1460, common.scss */
      .btn.back {
        margin-top: 30px; } }
  @media screen and (min-width: 800px) {
    /* line 1467, common.scss */
    .btn:hover {
      color: #FFFFFF;
      background-color: #06CB43; } }

/* line 1473, common.scss */
.btn_arrow {
  position: absolute;
  right: 14px;
  top: 50%;
  translate: 0 -50%;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background-color: #FFFFFF;
  overflow: hidden;
  z-index: 1; }
  @media screen and (max-width: 800px) {
    /* line 1473, common.scss */
    .btn_arrow {
      background-color: #06CB43; } }
  /* line 1487, common.scss */
  .btn_arrow::before, .btn_arrow::after {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 8px;
    height: 10px;
    mask-image: url("../img/arrow_r.svg");
    mask-size: cover;
    background-color: #06CB43;
    content: "";
    transition: translate 0.3s ease-out; }
    @media screen and (max-width: 800px) {
      /* line 1487, common.scss */
      .btn_arrow::before, .btn_arrow::after {
        background-color: #FFFFFF; } }
  /* line 1503, common.scss */
  .btn_arrow::before {
    translate: -50% -50%; }
  /* line 1506, common.scss */
  .btn_arrow::after {
    translate: -350% -50%; }
    @media screen and (max-width: 800px) {
      /* line 1506, common.scss */
      .btn_arrow::after {
        display: none; } }

/* line 1513, common.scss */
.btn_viewmore {
  position: absolute;
  right: 33px;
  bottom: 33px;
  display: inline-block;
  color: #06CB43;
  font-family: "Poppins", sans-serif;
  font-size: 18px;
  font-weight: 700;
  padding-right: 42px; }
  @media screen and (max-width: 800px) {
    /* line 1513, common.scss */
    .btn_viewmore {
      right: 20px;
      bottom: 20px; } }
  /* line 1527, common.scss */
  .btn_viewmore .btn_arrow {
    right: 0; }
    @media screen and (max-width: 800px) {
      /* line 1527, common.scss */
      .btn_viewmore .btn_arrow {
        background-color: #FFFFFF; }
        /* line 1531, common.scss */
        .btn_viewmore .btn_arrow::before {
          background-color: #06CB43; } }

/* line 1539, common.scss */
.detail-content {
  background-color: #F5EDE1;
  border-radius: 20px;
  padding: 30px 40px;
  margin-bottom: 40px; }
  @media screen and (max-width: 800px) {
    /* line 1539, common.scss */
    .detail-content {
      border-radius: 15px;
      padding: 25px 20px; } }
  /* line 1548, common.scss */
  .detail-content .dc-title {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8;
    letter-spacing: 0.05em;
    margin-bottom: 16px; }
    @media screen and (max-width: 800px) {
      /* line 1548, common.scss */
      .detail-content .dc-title {
        font-size: 17px;
        margin-bottom: 10px; } }
  /* line 1559, common.scss */
  .detail-content p {
    margin: 0; }

/* line 1566, common.scss */
.text-content .text-detail {
  margin-bottom: 70px; }
  @media screen and (max-width: 800px) {
    /* line 1566, common.scss */
    .text-content .text-detail {
      margin-bottom: 45px; } }
  /* line 1571, common.scss */
  .text-content .text-detail:last-of-type {
    margin-bottom: 0; }
/* line 1575, common.scss */
.text-content h2 {
  border-bottom: 2px solid #DDDDDD;
  padding: 0 0 8px;
  margin-bottom: 24px; }
  @media screen and (max-width: 800px) {
    /* line 1575, common.scss */
    .text-content h2 {
      border-bottom: 1px solid #DDDDDD; } }
  /* line 1582, common.scss */
  .text-content h2::before {
    width: 156px;
    height: 2px;
    border-radius: 0;
    top: auto;
    bottom: -2px; }
    @media screen and (max-width: 800px) {
      /* line 1582, common.scss */
      .text-content h2::before {
        width: 120px;
        height: 1px;
        bottom: -1px; } }
/* line 1595, common.scss */
.text-content h3 {
  border: none;
  padding: 0;
  margin-bottom: 12px; }
/* line 1600, common.scss */
.text-content p {
  margin-bottom: 30px; }
  /* line 1602, common.scss */
  .text-content p:last-child {
    margin-bottom: 0; }
  /* line 1605, common.scss */
  .text-content p.read-textcontent {
    margin-bottom: 70px; }
    @media screen and (max-width: 800px) {
      /* line 1605, common.scss */
      .text-content p.read-textcontent {
        margin-bottom: 60px; } }
/* line 1612, common.scss */
.text-content ol {
  counter-reset: my-counter;
  list-style-type: none;
  padding: 0;
  margin: 0; }
  /* line 1617, common.scss */
  .text-content ol li {
    position: relative;
    margin: 0 0 5px;
    padding: 0 0 0 22px; }
    /* line 1621, common.scss */
    .text-content ol li:last-child {
      margin-bottom: 0; }
    /* line 1624, common.scss */
    .text-content ol li::before {
      position: absolute;
      top: 5px;
      left: 0;
      display: flex;
      justify-content: center;
      align-items: center;
      height: 15px;
      width: 15px;
      font-size: 12px;
      line-height: 1;
      border: 1px solid #1D1D1D;
      border-radius: 50%;
      padding: 0 0 1px 1px;
      content: counter(my-counter);
      counter-increment: my-counter; }

/* line 1647, common.scss */
.page-top {
  margin-bottom: 100px; }
  /* line 1649, common.scss */
  .page-top .read-page {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.64;
    margin-bottom: 25px; }
    @media screen and (max-width: 800px) {
      /* line 1649, common.scss */
      .page-top .read-page {
        font-size: 22px;
        letter-spacing: 0; } }
  /* line 1659, common.scss */
  .page-top .cap-page {
    position: relative;
    font-size: 18px;
    line-height: 1.78;
    padding-left: 80px;
    margin-bottom: 0; }
    @media screen and (max-width: 800px) {
      /* line 1659, common.scss */
      .page-top .cap-page {
        font-size: 16px;
        padding-left: 50px; } }
    /* line 1669, common.scss */
    .page-top .cap-page::before {
      position: absolute;
      left: 0;
      top: 15px;
      width: 60px;
      height: 3px;
      content: "";
      background-color: #06CB43; }
      @media screen and (max-width: 800px) {
        /* line 1669, common.scss */
        .page-top .cap-page::before {
          width: 30px; } }

/* line 1686, common.scss */
.category-detail {
  display: flex;
  background-color: #FFFFFF;
  border-radius: 30px;
  padding: 40px 5px 40px 40px;
  margin-bottom: 40px; }
  @media screen and (max-width: 800px) {
    /* line 1686, common.scss */
    .category-detail {
      flex-wrap: wrap;
      border-radius: 15px;
      padding: 35px 20px;
      margin-bottom: 65px; } }
  /* line 1698, common.scss */
  .category-detail .l-category {
    width: 136px;
    border-right: 1px solid #8D8D8D; }
    @media screen and (max-width: 800px) {
      /* line 1698, common.scss */
      .category-detail .l-category {
        width: 100%;
        border: none;
        border-bottom: 1px solid #8D8D8D;
        padding-bottom: 14px; } }
    /* line 1707, common.scss */
    .category-detail .l-category h2 {
      color: #8D8D8D;
      font-size: 18px;
      font-weight: 700;
      padding: 0;
      margin: 0 0 15px; }
      @media screen and (max-width: 800px) {
        /* line 1707, common.scss */
        .category-detail .l-category h2 {
          margin-bottom: 5px; } }
      /* line 1716, common.scss */
      .category-detail .l-category h2::before {
        display: none; }
  /* line 1721, common.scss */
  .category-detail .r-category {
    width: calc(100% - 136px);
    padding-left: 40px; }
    @media screen and (max-width: 800px) {
      /* line 1721, common.scss */
      .category-detail .r-category {
        width: 100%;
        padding-left: 0; } }
    /* line 1728, common.scss */
    .category-detail .r-category h3 {
      font-size: 15px;
      border: none;
      padding: 0 0 0 30px;
      margin: 45px 0 15px; }
      @media screen and (max-width: 800px) {
        /* line 1728, common.scss */
        .category-detail .r-category h3 {
          font-size: 13px;
          padding-left: 20px;
          margin: 25px 0 10px; } }
      /* line 1738, common.scss */
      .category-detail .r-category h3:first-child {
        margin-top: 0; }
        @media screen and (max-width: 800px) {
          /* line 1738, common.scss */
          .category-detail .r-category h3:first-child {
            margin-top: 25px; } }
      /* line 1744, common.scss */
      .category-detail .r-category h3::before {
        position: absolute;
        left: 0;
        top: 50%;
        translate: 0 -50%;
        width: 20px;
        height: 6px;
        content: "";
        background-color: #06CB43; }
        @media screen and (max-width: 800px) {
          /* line 1744, common.scss */
          .category-detail .r-category h3::before {
            width: 14px;
            height: 4px; } }
  /* line 1760, common.scss */
  .category-detail .catlist {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin: 0;
    padding: 0; }
    @media screen and (max-width: 800px) {
      /* line 1760, common.scss */
      .category-detail .catlist {
        gap: 8px; } }
    /* line 1769, common.scss */
    .category-detail .catlist li {
      margin: 0;
      padding: 0; }
      /* line 1772, common.scss */
      .category-detail .catlist li a {
        display: inline-block;
        font-size: 16px;
        line-height: 1.4;
        text-decoration: none;
        border-radius: 9999px;
        border: 1px solid #1D1D1D;
        padding: 3px 10px;
        transition: color 0.3s ease-out,background-color 0.3s ease-out; }
        @media screen and (min-width: 800px) {
          /* line 1782, common.scss */
          .category-detail .catlist li a:hover {
            color: #FFFFFF;
            background-color: #1D1D1D; } }
        @media screen and (max-width: 800px) {
          /* line 1772, common.scss */
          .category-detail .catlist li a {
            font-size: 14px; } }
        /* line 1790, common.scss */
        .category-detail .catlist li a.current {
          color: #FFFFFF;
          background-color: #1D1D1D; }

/* line 1798, common.scss */
.category-title {
  font-size: 14px;
  letter-spacing: 0.05em;
  margin-bottom: 16px; }
  /* line 1802, common.scss */
  .category-title .now {
    font-weight: 700;
    font-size: 18px; }

/* line 1807, common.scss */
.workslist {
  margin: 0;
  padding: 0; }
  /* line 1810, common.scss */
  .workslist li {
    margin: 0;
    padding: 0; }
    /* line 1813, common.scss */
    .workslist li a {
      display: block;
      text-decoration: none; }
      @media screen and (min-width: 800px) {
        /* line 1819, common.scss */
        .workslist li a:hover .works-img img {
          scale: 1.1; }
        /* line 1823, common.scss */
        .workslist li a:hover .cat-works {
          color: #06CB43;
          border: 1px solid #06CB43; }
        /* line 1827, common.scss */
        .workslist li a:hover .works-title {
          color: #06CB43; }
        /* line 1830, common.scss */
        .workslist li a:hover .works-detail {
          color: #06CB43; }
          /* line 1832, common.scss */
          .workslist li a:hover .works-detail .works-detail-text {
            border-left: 1px solid #06CB43; } }
      /* line 1838, common.scss */
      .workslist li a .works-img {
        display: block;
        width: 100%;
        margin-bottom: 16px;
        overflow: hidden;
        border-radius: 20px; }
        @media screen and (max-width: 800px) {
          /* line 1838, common.scss */
          .workslist li a .works-img {
            border-radius: 15px; } }
        /* line 1847, common.scss */
        .workslist li a .works-img img {
          width: 100%;
          height: 100%;
          object-fit: cover;
          aspect-ratio: 310 / 232;
          border-radius: 20px;
          transition: scale 0.3s ease-out; }
          @media screen and (max-width: 800px) {
            /* line 1847, common.scss */
            .workslist li a .works-img img {
              border-radius: 15px; } }
      /* line 1859, common.scss */
      .workslist li a .works-title {
        display: block;
        font-weight: 500;
        transition: color 0.3s ease-out; }
      /* line 1864, common.scss */
      .workslist li a .works-detail {
        display: block;
        color: #8D8D8D;
        margin-top: 4px;
        transition: all 0.3s ease-out; }
        /* line 1869, common.scss */
        .workslist li a .works-detail .works-detail-text {
          display: inline-block;
          font-size: 13px;
          line-height: 1.2;
          margin-left: 10px;
          padding-left: 15px;
          border-left: 1px solid #8D8D8D;
          transition: all 0.3s ease-out; }
          /* line 1877, common.scss */
          .workslist li a .works-detail .works-detail-text:first-child {
            margin-left: 0;
            padding-left: 0;
            border-left: none; }
  /* line 1886, common.scss */
  .workslist.workslist2 {
    display: flex;
    flex-wrap: wrap;
    gap: 50px 3.5%; }
    @media screen and (max-width: 800px) {
      /* line 1886, common.scss */
      .workslist.workslist2 {
        gap: 25px 0; } }
    /* line 1893, common.scss */
    .workslist.workslist2 li {
      width: 31%; }
      @media screen and (max-width: 800px) {
        /* line 1893, common.scss */
        .workslist.workslist2 li {
          width: 100%; } }
  /* line 1900, common.scss */
  .workslist.workslist_s {
    display: flex;
    flex-wrap: wrap;
    gap: 0 2.3%; }
    @media screen and (max-width: 800px) {
      /* line 1900, common.scss */
      .workslist.workslist_s {
        gap: 25px 0; } }
    /* line 1907, common.scss */
    .workslist.workslist_s li {
      width: 23.3%; }
      @media screen and (max-width: 800px) {
        /* line 1907, common.scss */
        .workslist.workslist_s li {
          width: 100%; } }

/* line 1915, common.scss */
.cat-works {
  display: inline-block;
  font-size: 12px;
  border: 1px solid #1D1D1D;
  border-radius: 9999px;
  padding: 2px 10px;
  margin-bottom: 6px;
  transition: color 0.3s ease-out,border 0.3s ease-out; }

/* line 1924, common.scss */
.works-content {
  width: 100%;
  max-width: 740px;
  margin: 0 auto 100px; }
  /* line 1928, common.scss */
  .works-content h2 {
    border-bottom: 1px solid #DDDDDD;
    padding: 0 0 5px 20px;
    margin-bottom: 40px; }
    @media screen and (max-width: 800px) {
      /* line 1928, common.scss */
      .works-content h2 {
        margin-bottom: 30px; } }
    /* line 1935, common.scss */
    .works-content h2::before {
      top: 0;
      translate: 0 0;
      width: 10px;
      height: calc(100% - 8px);
      border-radius: 0; }
  /* line 1943, common.scss */
  .works-content h3 {
    border: none;
    padding: 0;
    margin-bottom: 25px; }
  /* line 1948, common.scss */
  .works-content p {
    margin-bottom: 40px; }
    /* line 1950, common.scss */
    .works-content p.catchcopy {
      color: #06CB43;
      font-size: 28px;
      font-weight: 700; }
      @media screen and (max-width: 800px) {
        /* line 1950, common.scss */
        .works-content p.catchcopy {
          font-size: 24px;
          line-height: 1.6;
          margin-bottom: 30px; } }

/* line 1963, common.scss */
.splide__arrow {
  width: 50px !important;
  height: 50px !important;
  background-color: #1D1D1D !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  opacity: 1 !important;
  border: 1px solid #1D1D1D !important; }
  /* line 1971, common.scss */
  .splide__arrow.splide__arrow--prev {
    left: 7.8% !important;
    background-image: url("../img/arrow_l.svg"); }
  /* line 1975, common.scss */
  .splide__arrow.splide__arrow--next {
    right: 7.8% !important;
    background-image: url("../img/arrow_r.svg"); }
  /* line 1979, common.scss */
  .splide__arrow svg {
    display: none; }

/* line 1986, common.scss */
.newslist {
  margin: 0;
  padding: 0; }
  /* line 1989, common.scss */
  .newslist li {
    width: 100%;
    margin: 0;
    padding: 0; }
    /* line 1993, common.scss */
    .newslist li a {
      display: flex;
      text-decoration: none;
      padding: 25px 0;
      border-bottom: 1px solid #DDDDDD; }
      @media screen and (min-width: 800px) {
        /* line 2000, common.scss */
        .newslist li a:hover .entrytitle {
          text-decoration: underline; } }
      @media screen and (max-width: 800px) {
        /* line 1993, common.scss */
        .newslist li a {
          display: block;
          padding: 15px 0; } }
      /* line 2009, common.scss */
      .newslist li a .news-detail {
        width: 200px;
        gap: 0 30px; }
        @media screen and (max-width: 800px) {
          /* line 2009, common.scss */
          .newslist li a .news-detail {
            width: 100%;
            margin-bottom: 10px;
            gap: 0 20px; } }
      /* line 2018, common.scss */
      .newslist li a .entrytitle {
        overflow: hidden;
        display: -webkit-box;
        text-overflow: ellipsis;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 2;
        width: calc(100% - 200px); }
        @media screen and (max-width: 800px) {
          /* line 2018, common.scss */
          .newslist li a .entrytitle {
            width: 100%; } }

/* line 2032, common.scss */
.news-detail {
  display: flex;
  align-items: center;
  gap: 0 20px; }
  /* line 2036, common.scss */
  .news-detail .entrydate {
    display: inline-block;
    font-family: "Poppins", sans-serif;
    font-size: 13px; }
  /* line 2041, common.scss */
  .news-detail .entrycat {
    display: inline-block;
    font-size: 12px;
    background-color: #DDDDDD;
    border-radius: 9999px;
    padding: 0px 12px;
    margin-bottom: 2px; }

/* line 2051, common.scss */
.news-content h2 {
  border-bottom: 2px solid #DDDDDD;
  padding: 0 0 8px;
  margin-bottom: 24px; }
  @media screen and (max-width: 800px) {
    /* line 2051, common.scss */
    .news-content h2 {
      border-bottom: 1px solid #DDDDDD; } }
  /* line 2058, common.scss */
  .news-content h2::before {
    width: 156px;
    height: 2px;
    border-radius: 0;
    top: auto;
    bottom: -2px; }
    @media screen and (max-width: 800px) {
      /* line 2058, common.scss */
      .news-content h2::before {
        width: 120px;
        height: 1px;
        bottom: -1px; } }
/* line 2071, common.scss */
.news-content h3 {
  color: #06CB43;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
  border: none;
  padding: 0;
  margin-bottom: 25px; }
/* line 2080, common.scss */
.news-content h4 {
  font-size: 15px;
  line-height: 1.8;
  margin-bottom: 20px; }
/* line 2085, common.scss */
.news-content p {
  margin-bottom: 40px; }

/* line 2092, common.scss */
.notfound-content p {
  font-size: 18px;
  margin-bottom: 60px; }
  @media screen and (max-width: 800px) {
    /* line 2092, common.scss */
    .notfound-content p {
      font-size: 15px;
      margin-bottom: 30px; } }
/* line 2100, common.scss */
.notfound-content .back404 {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 35px; }
  @media screen and (max-width: 800px) {
    /* line 2100, common.scss */
    .notfound-content .back404 {
      justify-content: center;
      gap: 20px 0; } }

/* line 2113, common.scss */
.wp-pagenavi {
  position: relative;
  width: 100%;
  margin: 80px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px; }
  @media screen and (max-width: 800px) {
    /* line 2113, common.scss */
    .wp-pagenavi {
      margin: 60px auto;
      gap: 6px; } }
  /* line 2125, common.scss */
  .wp-pagenavi a,
  .wp-pagenavi span {
    position: relative;
    display: grid;
    place-items: center;
    font-family: "Poppins", sans-serif;
    font-size: 16px;
    font-weight: 400;
    width: 40px;
    height: 40px;
    line-height: 1;
    background-color: #FFFFFF;
    border-radius: 50%;
    text-decoration: none;
    transition: all 0.3s ease-out; }
    @media screen and (max-width: 800px) {
      /* line 2125, common.scss */
      .wp-pagenavi a,
      .wp-pagenavi span {
        width: 28px;
        height: 28px;
        font-size: 11px; } }
    /* line 2145, common.scss */
    .wp-pagenavi a.nextpostslink, .wp-pagenavi a.previouspostslink,
    .wp-pagenavi span.nextpostslink,
    .wp-pagenavi span.previouspostslink {
      width: auto;
      height: auto;
      background: none; }
    /* line 2151, common.scss */
    .wp-pagenavi a.nextpostslink,
    .wp-pagenavi span.nextpostslink {
      margin-left: 10px; }
    /* line 2154, common.scss */
    .wp-pagenavi a.previouspostslink,
    .wp-pagenavi span.previouspostslink {
      margin-right: 10px; }
    /* line 2157, common.scss */
    .wp-pagenavi a.current,
    .wp-pagenavi span.current {
      color: #FFFFFF;
      background-color: #1D1D1D; }
    @media screen and (min-width: 800px) {
      /* line 2162, common.scss */
      .wp-pagenavi a:hover,
      .wp-pagenavi span:hover {
        color: #FFFFFF;
        background-color: #1D1D1D; }
        /* line 2165, common.scss */
        .wp-pagenavi a:hover.nextpostslink, .wp-pagenavi a:hover.previouspostslink,
        .wp-pagenavi span:hover.nextpostslink,
        .wp-pagenavi span:hover.previouspostslink {
          color: #1D1D1D;
          background: none;
          text-decoration: underline; } }
  /* line 2174, common.scss */
  .wp-pagenavi .pages {
    display: none; }

/* line 2182, common.scss */
.page-bottom {
  width: calc(100% - 80px);
  background-color: #FFFFFF;
  border-radius: 30px;
  padding: 65px 0;
  margin: 120px auto 0; }
  @media screen and (max-width: 800px) {
    /* line 2182, common.scss */
    .page-bottom {
      width: calc(100% - 40px);
      border-radius: 15px;
      padding: 45px 0;
      margin-top: 90px; } }
  /* line 2194, common.scss */
  .page-bottom h2 {
    margin-bottom: 30px; }
    /* line 2196, common.scss */
    .page-bottom h2 .en {
      display: block;
      font-size: 67px;
      font-weight: 700;
      text-transform: uppercase;
      line-height: 1;
      margin-bottom: 15px; }
      @media screen and (max-width: 800px) {
        /* line 2196, common.scss */
        .page-bottom h2 .en {
          font-size: 32px;
          margin-bottom: 10px; } }
    /* line 2208, common.scss */
    .page-bottom h2 .jp {
      display: block;
      font-size: 20px;
      letter-spacing: 0.1em; }
      @media screen and (max-width: 800px) {
        /* line 2208, common.scss */
        .page-bottom h2 .jp {
          font-size: 14px; } }
  /* line 2217, common.scss */
  .page-bottom ul {
    display: flex;
    flex-wrap: wrap;
    gap: 15px 1.4%;
    margin: 0;
    padding: 0; }
    @media screen and (max-width: 800px) {
      /* line 2217, common.scss */
      .page-bottom ul {
        display: block; } }
    /* line 2226, common.scss */
    .page-bottom ul li {
      width: 32.4%;
      margin: 0;
      padding: 0; }
      @media screen and (max-width: 800px) {
        /* line 2226, common.scss */
        .page-bottom ul li {
          width: 100%; } }
      /* line 2233, common.scss */
      .page-bottom ul li a {
        position: relative;
        display: block;
        font-size: 16px;
        font-weight: 500;
        border-bottom: 1px solid #DDDDDD;
        text-decoration: none;
        padding: 25px 60px 25px 42px; }
        @media screen and (min-width: 800px) {
          /* line 2243, common.scss */
          .page-bottom ul li a:hover .pbtitle {
            color: #FFFFFF; }
          /* line 2246, common.scss */
          .page-bottom ul li a:hover::after {
            opacity: 1; } }
        @media screen and (max-width: 800px) {
          /* line 2233, common.scss */
          .page-bottom ul li a {
            padding: 20px 60px 20px 20px; } }
        /* line 2254, common.scss */
        .page-bottom ul li a .pbtitle {
          position: relative;
          transition: color 0.3s ease-out;
          z-index: 1; }
        /* line 2259, common.scss */
        .page-bottom ul li a::after {
          position: absolute;
          left: 0;
          top: 50%;
          translate: 0 -50%;
          width: 100%;
          height: 52px;
          background-color: #06CB43;
          border-radius: 9999px;
          content: "";
          opacity: 0;
          transition: opacity 0.3s ease-out;
          z-index: 0; }
          @media screen and (max-width: 800px) {
            /* line 2259, common.scss */
            .page-bottom ul li a::after {
              display: none; } }

/* line 2284, common.scss */
input,
select,
textarea {
  padding: 20px;
  font-size: 16px;
  border: 1px solid #DDDDDD;
  background-color: #FFFFFF;
  border-radius: 14px;
  transition: border 0.3s ease-out, color 0.3s ease-out; }

/* line 2296, common.scss */
select {
  padding: 24px 20px 20px; }
  @media screen and (max-width: 800px) {
    /* line 2296, common.scss */
    select {
      padding: 10px; } }

/* line 2302, common.scss */
button,
input {
  line-height: normal; }

/* line 2306, common.scss */
textarea {
  vertical-align: top; }

/* line 2309, common.scss */
input[type="checkbox"],
input[type="radio"],
input[type="file"],
input[type="hidden"],
input[type="image"],
input[type="color"] {
  padding: 0; }

/* line 2318, common.scss */
input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
select,
textarea {
  width: 100%; }

/* line 2326, common.scss */
input#your-zip1,
input#your-zip2 {
  width: 20%; }
  @media screen and (max-width: 800px) {
    /* line 2326, common.scss */
    input#your-zip1,
    input#your-zip2 {
      width: 40%; } }

/* line 2334, common.scss */
.wpcf7-form-control-wrap .wpcf7-radio,
.wpcf7-form-control-wrap .wpcf7-checkbox {
  display: block;
  margin-top: 20px; }
  @media screen and (max-width: 800px) {
    /* line 2334, common.scss */
    .wpcf7-form-control-wrap .wpcf7-radio,
    .wpcf7-form-control-wrap .wpcf7-checkbox {
      margin-top: 0px; } }

/* line 2343, common.scss */
::placeholder {
  color: #8D8D8D; }

/* line 2346, common.scss */
select,
input[type="submit"],
input[type="button"] {
  appearance: none;
  -webkit-text-fill-color: #1D1D1D;
  opacity: 1; }

/* line 2354, common.scss */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
  appearance: none; }

/* line 2359, common.scss */
input[type="number"] {
  appearance: textfield; }

/* line 2364, common.scss */
.wpcf7-checkbox .wpcf7-list-item {
  margin-bottom: 15px; }

/* line 2368, common.scss */
input[type="checkbox"] {
  position: relative;
  cursor: pointer;
  width: 32px;
  height: 32px;
  margin-top: -1px;
  border-radius: 0px;
  border: 1px solid #DDDDDD;
  border-radius: 6px;
  background-color: #FFFFFF;
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  transition: .3s; }
  /* line 2383, common.scss */
  input[type="checkbox"]:checked::before {
    position: absolute;
    left: 50%;
    top: 50%;
    rotate: 45deg;
    translate: -50% -65%;
    width: 12px;
    height: 23px;
    border-right: 3px solid #aaa;
    border-bottom: 3px solid #aaa;
    content: ''; }

/* line 2397, common.scss */
.wpcf7-list-item {
  display: block;
  margin: 0 0 5px; }
  /* line 2400, common.scss */
  .wpcf7-list-item label {
    cursor: pointer;
    font-size: 16px; }
  /* line 2404, common.scss */
  .wpcf7-list-item input[type="radio"] {
    display: none;
    visibility: hidden;
    width: 0; }
    /* line 2410, common.scss */
    .wpcf7-list-item input[type="radio"]:checked + .wpcf7-list-item-label::after {
      background: #aaa; }
    /* line 2415, common.scss */
    .wpcf7-list-item input[type="radio"] + .wpcf7-list-item-label {
      display: inline-block;
      font-size: 16px;
      letter-spacing: 0.03em;
      padding: 0 0 0 30px;
      position: relative; }
      /* line 2421, common.scss */
      .wpcf7-list-item input[type="radio"] + .wpcf7-list-item-label::before {
        content: "";
        width: 20px;
        height: 20px;
        border-radius: 50%;
        background: #FFFFFF;
        position: absolute;
        top: 5px;
        left: 0;
        border: 1px solid #DDDDDD;
        transition: border .3s; }
      /* line 2433, common.scss */
      .wpcf7-list-item input[type="radio"] + .wpcf7-list-item-label::after {
        content: "";
        width: 12px;
        height: 12px;
        border-radius: 50%;
        position: absolute;
        top: 9px;
        left: 4px;
        transition: background .3s; }

/* line 2447, common.scss */
#your-sei .wpcf7-list-item {
  width: auto;
  margin-right: 30px; }
/* line 2451, common.scss */
#your-sei input[type="checkbox"] {
  display: none;
  visibility: hidden;
  width: 0; }
  /* line 2457, common.scss */
  #your-sei input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
    background: #aaa; }
  /* line 2462, common.scss */
  #your-sei input[type="checkbox"] + .wpcf7-list-item-label {
    display: inline-block;
    font-size: 16px;
    letter-spacing: 0.03em;
    padding: 0 0 0 30px;
    position: relative; }
    /* line 2468, common.scss */
    #your-sei input[type="checkbox"] + .wpcf7-list-item-label::before {
      content: "";
      width: 20px;
      height: 20px;
      border-radius: 50%;
      background: #FFFFFF;
      position: absolute;
      top: 5px;
      left: 0;
      border: 1px solid #DDDDDD;
      transition: border .3s; }
    /* line 2480, common.scss */
    #your-sei input[type="checkbox"] + .wpcf7-list-item-label::after {
      content: "";
      width: 12px;
      height: 12px;
      border-radius: 50%;
      position: absolute;
      top: 9px;
      left: 4px;
      transition: background .3s; }

/* line 2497, common.scss */
.contact-privacy {
  text-align: center;
  margin-bottom: 80px; }
  @media screen and (max-width: 800px) {
    /* line 2497, common.scss */
    .contact-privacy {
      text-align: left;
      margin-bottom: 60px; } }
  /* line 2504, common.scss */
  .contact-privacy .wpcf7-acceptance {
    display: block; }
    @media screen and (max-width: 800px) {
      /* line 2506, common.scss */
      .contact-privacy .wpcf7-acceptance label {
        display: flex; } }
    @media screen and (max-width: 800px) {
      /* line 2510, common.scss */
      .contact-privacy .wpcf7-acceptance label .wpcf7-list-item-label {
        width: calc(100% - 55px);
        line-height: 1.9;
        padding-left: 28px; } }
    /* line 2516, common.scss */
    .contact-privacy .wpcf7-acceptance label .wpcf7-list-item-label::before {
      display: inline-block;
      color: #E7380D;
      font-size: 13px;
      content: "※";
      padding: 0 5px; }
      @media screen and (max-width: 800px) {
        /* line 2516, common.scss */
        .contact-privacy .wpcf7-acceptance label .wpcf7-list-item-label::before {
          position: absolute;
          left: 46px;
          top: 3px;
          padding: 0; } }

/* line 2534, common.scss */
.wrapper input[type="submit"],
.wrapper input[type="button"] {
  position: relative;
  width: 100%;
  max-width: 296px;
  height: 60px;
  display: flex;
  align-items: center;
  font-size: 16px;
  text-align: left;
  letter-spacing: 0.03em;
  line-height: 1;
  background-color: #FFFFFF;
  background-image: url("../img/bg_button02.svg"), url("../img/bg_button01.svg");
  background-position: right 24px center,right 16px center;
  background-repeat: no-repeat, no-repeat;
  border: 2px solid #06CB43;
  border-radius: 9999px;
  transition: all .3s;
  cursor: pointer;
  margin: 0 auto 20px;
  padding: 0 0 0 40px; }
  /* line 2556, common.scss */
  .wrapper input[type="submit"]:disabled,
  .wrapper input[type="button"]:disabled {
    opacity: 0.3;
    cursor: inherit; }
  @media screen and (min-width: 800px) {
    /* line 2560, common.scss */
    .wrapper input[type="submit"]:hover:not(:disabled),
    .wrapper input[type="button"]:hover:not(:disabled) {
      color: #FFFFFF;
      background-color: #06CB43;
      -webkit-text-fill-color: #FFFFFF; } }

/* line 2570, common.scss */
.cfm-confirm .wpcf7-form-control-wrap {
  display: block;
  margin-top: 20px; }
  /* line 2573, common.scss */
  .cfm-confirm .wpcf7-form-control-wrap[data-name="your-zip1"], .cfm-confirm .wpcf7-form-control-wrap[data-name="your-zip2"] {
    display: inline-block;
    width: auto; }

/* line 2582, common.scss */
.required::after {
  position: relative;
  content: "※";
  color: #E7380D;
  font-size: 60%;
  vertical-align: baseline;
  top: -0.5em;
  display: inline-block;
  margin: 0 3px; }

/* line 2596, common.scss */
#topBtn {
  display: block;
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 68px;
  height: 68px;
  background-color: #FFFFFF;
  border: 1px solid #E1E2E6;
  border-radius: 50%;
  z-index: 5; }
  /* line 2607, common.scss */
  #topBtn::after {
    position: absolute;
    left: 50%;
    top: 50%;
    translate: -50% -50%;
    width: 10px;
    height: 12px;
    mask-image: url(../img/arrow_r.svg);
    mask-size: cover;
    background-color: #1D1D1D;
    rotate: -90deg;
    content: ""; }

/* line 2624, common.scss */
.footer {
  position: relative;
  width: 100%;
  padding: 60px 0 0px;
  background-color: #434343;
  z-index: 0; }
  @media screen and (max-width: 800px) {
    /* line 2624, common.scss */
    .footer {
      padding-top: 40px; } }
  /* line 2633, common.scss */
  .footer .siteinfo {
    width: 100%;
    margin-bottom: 70px; }
    @media screen and (max-width: 800px) {
      /* line 2633, common.scss */
      .footer .siteinfo {
        margin-bottom: 45px; } }
    /* line 2639, common.scss */
    .footer .siteinfo .logo-footer {
      max-width: 192px;
      margin-bottom: 45px; }
      @media screen and (max-width: 800px) {
        /* line 2639, common.scss */
        .footer .siteinfo .logo-footer {
          margin: 0 auto 40px; } }
    /* line 2646, common.scss */
    .footer .siteinfo .footermenu {
      display: flex;
      justify-content: space-between;
      width: 100%; }
      @media screen and (max-width: 800px) {
        /* line 2646, common.scss */
        .footer .siteinfo .footermenu {
          width: calc(100% + 15px);
          flex-wrap: wrap;
          gap: 20px 0; } }
      /* line 2655, common.scss */
      .footer .siteinfo .footermenu nav {
        width: auto; }
        @media screen and (max-width: 800px) {
          /* line 2655, common.scss */
          .footer .siteinfo .footermenu nav {
            width: 50%; } }
        /* line 2660, common.scss */
        .footer .siteinfo .footermenu nav ul {
          width: 100%;
          margin: 0;
          padding: 0; }
          @media screen and (max-width: 800px) {
            /* line 2660, common.scss */
            .footer .siteinfo .footermenu nav ul {
              display: flex;
              flex-wrap: wrap;
              gap: 20px 0; } }
          /* line 2669, common.scss */
          .footer .siteinfo .footermenu nav ul li {
            line-height: 1.4;
            margin: 0 0 20px;
            padding: 0; }
            @media screen and (max-width: 800px) {
              /* line 2669, common.scss */
              .footer .siteinfo .footermenu nav ul li {
                margin-bottom: 0; } }
            /* line 2676, common.scss */
            .footer .siteinfo .footermenu nav ul li:last-child {
              margin-bottom: 0; }
            /* line 2679, common.scss */
            .footer .siteinfo .footermenu nav ul li a {
              position: relative;
              color: #FFFFFF;
              font-size: 18px;
              font-weight: 700;
              text-decoration: none; }
              @media screen and (max-width: 800px) {
                /* line 2679, common.scss */
                .footer .siteinfo .footermenu nav ul li a {
                  font-size: 16px; } }
            /* line 2689, common.scss */
            .footer .siteinfo .footermenu nav ul li ul {
              margin-top: 20px; }
              @media screen and (max-width: 800px) {
                /* line 2689, common.scss */
                .footer .siteinfo .footermenu nav ul li ul {
                  display: block;
                  margin-top: 10px;
                  padding-left: 10px; } }
              /* line 2696, common.scss */
              .footer .siteinfo .footermenu nav ul li ul li {
                margin-bottom: 12px; }
                @media screen and (max-width: 800px) {
                  /* line 2696, common.scss */
                  .footer .siteinfo .footermenu nav ul li ul li {
                    margin-bottom: 6px; } }
                /* line 2701, common.scss */
                .footer .siteinfo .footermenu nav ul li ul li a {
                  font-size: 15px;
                  font-weight: 400; }
                  @media screen and (max-width: 800px) {
                    /* line 2701, common.scss */
                    .footer .siteinfo .footermenu nav ul li ul li a {
                      font-size: 13px; } }
        @media screen and (max-width: 800px) {
          /* line 2712, common.scss */
          .footer .siteinfo .footermenu nav.footermenu01 {
            width: 100%; } }
        @media screen and (max-width: 800px) {
          /* line 2717, common.scss */
          .footer .siteinfo .footermenu nav.footermenu02 {
            width: 100%; }
            /* line 2720, common.scss */
            .footer .siteinfo .footermenu nav.footermenu02 ul {
              width: 100%; }
              /* line 2722, common.scss */
              .footer .siteinfo .footermenu nav.footermenu02 ul li {
                width: 50%; } }
        /* line 2728, common.scss */
        .footer .siteinfo .footermenu nav.footermenu05 {
          width: 220px; }
          @media screen and (max-width: 800px) {
            /* line 2728, common.scss */
            .footer .siteinfo .footermenu nav.footermenu05 {
              width: 100%;
              margin-top: 20px; } }
          @media screen and (max-width: 800px) {
            /* line 2734, common.scss */
            .footer .siteinfo .footermenu nav.footermenu05 ul {
              display: flex;
              flex-wrap: wrap;
              gap: 6px 0; } }
          /* line 2740, common.scss */
          .footer .siteinfo .footermenu nav.footermenu05 ul li {
            margin-bottom: 12px; }
            @media screen and (max-width: 800px) {
              /* line 2740, common.scss */
              .footer .siteinfo .footermenu nav.footermenu05 ul li {
                width: 50%;
                margin-bottom: 0; } }
            /* line 2746, common.scss */
            .footer .siteinfo .footermenu nav.footermenu05 ul li a {
              font-size: 15px;
              font-weight: 400; }
              @media screen and (max-width: 800px) {
                /* line 2746, common.scss */
                .footer .siteinfo .footermenu nav.footermenu05 ul li a {
                  font-size: 13px; } }
            @media screen and (max-width: 800px) {
              /* line 2754, common.scss */
              .footer .siteinfo .footermenu nav.footermenu05 ul li:nth-child(even) a {
                padding-left: 10px; } }
            /* line 2760, common.scss */
            .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners {
              position: absolute;
              right: 0;
              bottom: 0;
              width: 100%;
              max-width: 220px;
              margin: 0; }
              @media screen and (max-width: 800px) {
                /* line 2760, common.scss */
                .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners {
                  position: relative;
                  right: auto;
                  bottom: auto;
                  margin: 30px auto 0;
                  padding: 0; } }
              /* line 2774, common.scss */
              .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners a {
                display: flex;
                align-items: center;
                height: 50px;
                border: 1px solid #FFFFFF;
                border-radius: 9999px;
                padding-left: 30px; }
                @media screen and (max-width: 800px) {
                  /* line 2774, common.scss */
                  .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners a {
                    font-size: 15px; } }
                @media screen and (max-width: 800px) {
                  /* line 2784, common.scss */
                  .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners a .btn_arrow {
                    background-color: #FFFFFF; }
                    /* line 2787, common.scss */
                    .footer .siteinfo .footermenu nav.footermenu05 ul li.fmpartners a .btn_arrow::before {
                      background-color: #06CB43; } }
  /* line 2800, common.scss */
  .footer .copyright {
    background-color: #06CB43;
    padding: 32px 0; }
    @media screen and (max-width: 800px) {
      /* line 2800, common.scss */
      .footer .copyright {
        text-align: center; } }
    /* line 2806, common.scss */
    .footer .copyright p {
      font-family: "Poppins", sans-serif;
      font-size: 12px;
      color: #FFFFFF;
      margin: 0; }

/* line 2817, common.scss */
#wpadminbar {
  position: fixed; }

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