@charset "UTF-8";
/****************************************

目次 
1.ベース
2.ヘッダー
3.フッター
4.トップページ

*****************************************/
/*レスポンシブ*/
/*フォントサイズ*/
/*Webフォント*/
@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&display=swap");
/****************************************


1.ベース


*****************************************/
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, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figure {
  border: 0 none;
  font-style: normal;
  margin: 0;
  outline: 0 none;
  padding: 0;
  vertical-align: top;
  font-family: 'Noto Serif JP', '游明朝', 'Yu Mincho', 'ヒラギノ明朝 ProN', 'Hiragino Mincho ProN', 'MS P明朝', 'MS PMincho', serif;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: auto;
  font-size: clamp(16px, 1.6vw, 16px);
  color: #000;
  -webkit-text-size-adjust: none; }

body {
  overflow-x: hidden;
  background: #FFFDF7;
  padding-top: 0 !important; }

.inner {
  width: 85%;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .inner {
      width: 90%; } }
  @media all and (max-width: 768px) {
    .inner {
      width: 100%;
      padding-left: clamp(20px, 6vw, 32px);
      padding-right: clamp(20px, 6vw, 32px); } }

.innerS {
  width: 70%;
  max-width: 1000px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .innerS {
      width: 90%;
      max-width: 90%; } }
  @media all and (max-width: 768px) {
    .innerS {
      width: 100%;
      max-width: 100%;
      padding-left: clamp(20px, 6vw, 32px);
      padding-right: clamp(20px, 6vw, 32px); } }

.innerL {
  width: 100%;
  padding-left: 80px;
  padding-right: 80px;
  box-sizing: border-box; }
  @media all and (max-width: 1280px) {
    .innerL {
      padding-left: 50px;
      padding-right: 50px; } }
  @media all and (max-width: 768px) {
    .innerL {
      padding-left: clamp(20px, 5vw, 32px);
      padding-right: clamp(20px, 5vw, 32px); } }

/*ボタン速度関係*/
a,
input[type=submit],
button {
  transition: all .5s ease-in; }
  a:before, a:after,
  input[type=submit]:before,
  input[type=submit]:after,
  button:before,
  button:after {
    transition: inherit; }
  a *,
  input[type=submit] *,
  button * {
    transition: inherit; }
    a *:before, a *:after,
    input[type=submit] *:before,
    input[type=submit] *:after,
    button *:before,
    button *:after {
      transition: inherit; }

.pcDisplay {
  display: block; }
  @media all and (max-width: 1024px) {
    .pcDisplay {
      display: none !important; } }

.spDisplay {
  display: none !important; }
  @media all and (max-width: 1024px) {
    .spDisplay {
      display: block !important; } }

/*インビュー関連*/
.inview {
  opacity: 0;
  transition: all 3000ms cubic-bezier(0.165, 0.84, 0.44, 1);
  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
  transition-property: transform,opacity; }
  .inview.left {
    transform: translateX(-30px); }
  .inview.right {
    transform: translateX(30px); }
  .inview.bottom {
    transform: translateY(20px); }
  .inview.action {
    opacity: 1;
    transform: translate(0px); }

/*テキスト関連*/
.center {
  text-align: center; }

.under {
  text-decoration: underline; }

b, stlong, .bold {
  font-weight: bold; }

.postCn {
  font-size: clamp(16px, 1.6vw, 16px);
  line-height: 2; }
  .postCn * {
    font-size: clamp(16px, 1.6vw, 16px);
    line-height: 2; }
  .postCn h1 {
    font-size: 2em;
    line-height: 1.2;
    font-weight: bold;
    margin: 0 0 .75rem; }
  .postCn h2 {
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1.6;
    margin: 0 0 .66rem 0; }
  .postCn h3 {
    font-size: 1.17em;
    line-height: 1.8;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h4 {
    font-size: 0.83em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h5 {
    font-size: 0.83em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn h6 {
    font-size: 0.67em;
    line-height: 2;
    font-weight: bold;
    margin: 0 0 .66rem 0; }
  .postCn p {
    margin-bottom: 20px; }
  .postCn strong {
    font-weight: bold; }
    .postCn strong * {
      font-weight: bold; }
  .postCn em {
    font-style: italic; }
    .postCn em * {
      font-style: italic; }
  .postCn a {
    color: #e94b4b;
    display: inline;
    transition: 0.5s; }
    .postCn a * {
      color: #e94b4b; }
    .postCn a:hover {
      color: #e94b4b;
      text-decoration: underline; }
  .postCn img {
    margin-bottom: 20px; }
  .postCn iframe {
    margin-bottom: 20px; }
  .postCn ul {
    margin-bottom: 20px; }
    .postCn ul li {
      list-style: circle;
      list-style-position: inside; }
  .postCn ol {
    margin-bottom: 20px; }
    .postCn ol li {
      list-style-type: decimal;
      list-style-position: inside; }
  .postCn table {
    margin-bottom: 20px; }

/*フォント*/
.en1 {
  font-family: "times-new-roman", sans-serif;
  font-weight: 400;
  font-style: normal; }

/*タイトル*/
.sectionTit {
  background: url("img/titleBg.webp") no-repeat center center/cover;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 15px 30px;
  box-sizing: border-box;
  margin-bottom: 40px;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1); }
  @media all and (max-width: 1024px) {
    .sectionTit {
      background: url("img/titleBgSp.webp") no-repeat center center/cover;
      padding: 10px 15px;
      margin-bottom: 15px; } }
  .sectionTit .tit {
    font-size: clamp(18px, 3vw, 30px);
    font-weight: bold;
    letter-spacing: 0.1em;
    line-height: 1.4;
    display: flex;
    align-items: center;
    gap: 30px; }
    @media all and (max-width: 1024px) {
      .sectionTit .tit {
        gap: 15px; } }
    .sectionTit .tit span {
      font-size: clamp(12px, 1.6vw, 16px);
      font-weight: bold;
      letter-spacing: 0em;
      line-height: 1.1;
      display: inline-block; }
  .sectionTit .link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    font-size: clamp(12px, 1.8vw, 18px);
    font-weight: bold;
    color: #fff;
    position: relative;
    transition: 0.8s; }
    .sectionTit .link:hover {
      transition: 0.8s;
      color: #000; }
  @media all and (max-width: 1024px) {
    .sectionTit .iconArrow::before {
      width: 16px;
      height: 16px; } }
  @media all and (max-width: 1024px) {
    .sectionTit .iconArrow::after {
      left: 6px;
      width: 3px;
      height: 3px; } }
  .sectionTit .iconArrow:hover {
    transition: 0.8s; }
    .sectionTit .iconArrow:hover::before {
      background: #0c7b5c; }
    .sectionTit .iconArrow:hover::after {
      border-top: 1px solid #FFF;
      border-right: 1px solid #FFF; }

.iconArrow {
  transition: 0.8s; }
  .iconArrow::before {
    content: "";
    background: #FFF;
    width: 20px;
    height: 20px;
    border: 1px solid #0c7b5c;
    border-radius: 50%;
    flex-shrink: 0;
    position: relative; }
  .iconArrow::after {
    content: "";
    position: absolute;
    left: 7px;
    top: 50%;
    width: 5px;
    height: 5px;
    border-top: 1px solid #0c7b5c;
    border-right: 1px solid #0c7b5c;
    transform: translateY(-50%) rotate(45deg); }
  .iconArrow:hover {
    transition: 0.8s; }
    .iconArrow:hover::before {
      background: #0c7b5c; }
    .iconArrow:hover::after {
      border-top: 1px solid #FFF;
      border-right: 1px solid #FFF; }

/****************************************


2.ヘッダー


*****************************************/
header {
  background: rgba(255, 255, 255, 0.9);
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 999;
  display: flex;
  gap: 60px;
  height: 100px; }
  @media all and (max-width: 1280px) {
    header {
      height: 68px; } }
  header .innerL {
    padding: 20px 35px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px; }
    @media all and (max-width: 1280px) {
      header .innerL {
        display: block;
        padding: 15px 20px; } }
  header .navBtn {
    position: absolute;
    right: 20px;
    top: 15px;
    z-index: 1001;
    width: 35px;
    height: 35px;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    display: none; }
    @media all and (max-width: 1280px) {
      header .navBtn {
        display: inline-flex; } }
    header .navBtn span {
      position: absolute;
      left: 0;
      right: 0;
      height: 2px;
      background: #147251;
      transition: transform .6s, opacity .6s;
      transform-origin: center; }
      header .navBtn span:nth-child(1) {
        transform: translateY(-10px); }
      header .navBtn span:nth-child(2) {
        transform: translateY(0); }
      header .navBtn span:nth-child(3) {
        transform: translateY(10px); }
    header .navBtn.open {
      background: rgba(0, 0, 0, 0);
      border: none; }
      header .navBtn.open span {
        background: #147251;
        left: 0;
        right: 0;
        height: 2px; }
        header .navBtn.open span:nth-child(1) {
          transform: translateY(0) rotate(32deg); }
        header .navBtn.open span:nth-child(2) {
          opacity: 0; }
        header .navBtn.open span:nth-child(3) {
          transform: translateY(0) rotate(-32deg); }
  header .logo {
    flex-shrink: 0;
    width: 208px; }
    @media all and (max-width: 1280px) {
      header .logo {
        width: 150px; } }
    header .logo a {
      display: block; }
    header .logo img {
      width: 100%;
      height: auto;
      display: block; }
  header nav {
    display: flex;
    gap: 25px; }
    @media all and (max-width: 1280px) {
      header nav {
        opacity: 0;
        height: 0;
        visibility: hidden;
        pointer-events: none;
        transition: opacity .25s, visibility .25s;
        flex-direction: column; } }
    header nav .headNav {
      display: flex;
      align-items: center;
      justify-content: flex-end;
      gap: 40px;
      flex-wrap: wrap; }
      @media all and (max-width: 1580px) {
        header nav .headNav {
          display: grid;
          grid-template-columns: repeat(2, auto);
          justify-content: end;
          gap: 10px 40px; } }
      @media all and (max-width: 1280px) {
        header nav .headNav {
          display: flex;
          align-items: flex-start;
          flex-direction: column;
          gap: 0;
          padding-top: 50px;
          box-sizing: border-box;
          width: 300px;
          margin: 0 auto; } }
      @media all and (max-width: 1280px) {
        header nav .headNav li {
          margin-bottom: 40px; } }
      header nav .headNav a {
        display: flex;
        align-items: center;
        gap: 10px;
        position: relative;
        text-decoration: none;
        font-size: clamp(15px, 1.5vw, 15px);
        font-weight: bold;
        line-height: 1.6;
        white-space: nowrap;
        transition: opacity 0.8s ease-in-out; }
        @media all and (max-width: 1280px) {
          header nav .headNav a {
            font-size: clamp(21px, 2.1vw, 21px);
            letter-spacing: 0.02em;
            line-height: 1.4;
            display: flex;
            align-items: center; } }
      header nav .headNav a:hover {
        opacity: 0.7; }
    header nav .headInfo {
      display: flex;
      align-items: center;
      gap: 15px;
      margin-left: 20px; }
      @media all and (max-width: 1280px) {
        header nav .headInfo {
          flex-direction: column;
          margin-left: 0; } }
      header nav .headInfo li {
        list-style: none; }
      header nav .headInfo .telIcon {
        display: block;
        text-decoration: none;
        line-height: 1.4; }
        header nav .headInfo .telIcon span {
          display: block; }
        header nav .headInfo .telIcon span:nth-child(1) {
          font-size: 12px;
          font-weight: 500; }
          @media all and (max-width: 1280px) {
            header nav .headInfo .telIcon span:nth-child(1) {
              font-size: 15px; } }
        header nav .headInfo .telIcon span:nth-child(2) {
          font-size: 26px;
          font-weight: bold;
          letter-spacing: 0.025em;
          line-height: 1.1;
          padding-left: 35px;
          position: relative;
          letter-spacing: 0.05em; }
          @media all and (max-width: 1280px) {
            header nav .headInfo .telIcon span:nth-child(2) {
              font-size: 36px; } }
        header nav .headInfo .telIcon span:nth-child(2)::before {
          content: "";
          position: absolute;
          top: 50%;
          left: 0;
          transform: translateY(-50%);
          width: 25px;
          height: 20px;
          background: url("img/iconFreePhone.svg") no-repeat center center/contain; }
        header nav .headInfo .telIcon span:nth-child(3) {
          font-size: 12px;
          white-space: nowrap; }
          @media all and (max-width: 1280px) {
            header nav .headInfo .telIcon span:nth-child(3) {
              font-size: 15px; } }
      header nav .headInfo .contactForm {
        padding: 18px 60px;
        box-sizing: border-box;
        border: 3px solid #FF0000;
        border-radius: 999px;
        display: flex;
        align-items: center;
        justify-content: center;
        text-decoration: none;
        color: #FF0000;
        font-size: clamp(18px, 1.8vw, 18px);
        font-weight: bold;
        line-height: 1;
        background: #fff;
        transition: background 0.8s ease-in-out, color 0.8s ease-in-out; }
        header nav .headInfo .contactForm:hover {
          background: #ff1a12;
          color: #fff; }
  @media all and (max-width: 1280px) {
    header.open {
      width: 100%;
      height: 100vh; } }
  @media all and (max-width: 1280px) {
    header.open nav {
      opacity: 1;
      height: auto;
      visibility: visible;
      pointer-events: auto; } }
  @media all and (max-width: 1280px) {
    header.open .headSns {
      opacity: 1; } }

/****************************************


トップページ


*****************************************/
.home .mainImg {
  position: relative;
  height: 720px;
  overflow: hidden; }
  @media all and (max-width: 1024px) {
    .home .mainImg {
      height: 100vh; } }
  .home .mainImg .mainImgSlide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1; }
    .home .mainImg .mainImgSlide::before {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background: rgba(0, 0, 0, 0.2);
      z-index: 2; }
    .home .mainImg .mainImgSlide .item {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      opacity: 0;
      animation: topMainImgFade 18s infinite; }
    .home .mainImg .mainImgSlide .item1 {
      background-image: url("img/topMainImg1.webp");
      animation-delay: 0s; }
      @media all and (max-width: 1024px) {
        .home .mainImg .mainImgSlide .item1 {
          background-image: url("img/topMainImg1Sp.webp"); } }
    .home .mainImg .mainImgSlide .item2 {
      background-image: url("img/topMainImg2.webp");
      animation-delay: 6s; }
      @media all and (max-width: 1024px) {
        .home .mainImg .mainImgSlide .item2 {
          background-image: url("img/topMainImg2Sp.webp"); } }
    .home .mainImg .mainImgSlide .item3 {
      background-image: url("img/topMainImg3.webp");
      animation-delay: 12s; }
      @media all and (max-width: 1024px) {
        .home .mainImg .mainImgSlide .item3 {
          background-image: url("img/topMainImg3Sp.webp"); } }
  .home .mainImg .mainImgTxt {
    position: absolute;
    top: calc( 50% + 40px );
    left: 70px;
    transform: translateY(-50%);
    z-index: 5;
    color: #fff;
    width: calc(100% - 140px);
    max-width: 900px; }
    @media all and (max-width: 1024px) {
      .home .mainImg .mainImgTxt {
        left: 20px;
        width: calc(100% - 40px); } }
    .home .mainImg .mainImgTxt .txtWrap {
      margin-bottom: 40px; }
      @media all and (max-width: 1024px) {
        .home .mainImg .mainImgTxt .txtWrap {
          padding-top: 100px;
          margin-bottom: 40px;
          box-sizing: border-box; } }
      .home .mainImg .mainImgTxt .txtWrap h2 {
        font-size: clamp(36px, 5.2vw, 48px);
        font-weight: bold;
        color: #FFF;
        letter-spacing: 0.1em;
        line-height: 1.3;
        margin-bottom: 25px; }
      .home .mainImg .mainImgTxt .txtWrap p {
        font-size: clamp(16px, 2.4vw, 20px);
        color: #FFF;
        letter-spacing: 0.05em;
        line-height: 1.4; }
    .home .mainImg .mainImgTxt .btnWrap {
      display: flex;
      gap: 15px; }
      @media all and (max-width: 1024px) {
        .home .mainImg .mainImgTxt .btnWrap {
          flex-direction: column;
          gap: 10px; } }
      .home .mainImg .mainImgTxt .btnWrap .btn {
        width: 300px;
        padding: 20px;
        font-size: clamp(14px, 1.4vw, 14px);
        font-weight: bold;
        letter-spacing: 0.05em;
        line-height: 1;
        text-align: center;
        transition: 0.8s;
        box-sizing: border-box;
        display: flex;
        justify-content: center;
        align-items: center; }
        @media all and (max-width: 1024px) {
          .home .mainImg .mainImgTxt .btnWrap .btn {
            width: 250px;
            border-radius: 5px; } }
        @media all and (max-width: 1024px) {
          .home .mainImg .mainImgTxt .btnWrap .btn {
            width: 215px; } }
      .home .mainImg .mainImgTxt .btnWrap a.contactBtn {
        background: #147251;
        color: #FFF;
        border-radius: 5px; }
        .home .mainImg .mainImgTxt .btnWrap a.contactBtn:hover {
          background: #FFF;
          color: #147251; }
      .home .mainImg .mainImgTxt .btnWrap .productsBtn {
        background: #FFF;
        color: #147251;
        border: solid 2px #147251;
        box-sizing: border-box;
        border-radius: 5px; }
        .home .mainImg .mainImgTxt .btnWrap .productsBtn:hover {
          background: #E5F9F2; }
@keyframes topMainImgFade {
  0% {
    opacity: 0;
    transform: scale(1.03); }
  8% {
    opacity: 1;
    transform: scale(1); }
  28% {
    opacity: 1;
    transform: scale(1); }
  36% {
    opacity: 0;
    transform: scale(1.02); }
  100% {
    opacity: 0;
    transform: scale(1.02); } }
.home .mainImgNews {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 5;
  display: flex;
  width: 520px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 5px 0 0 5px; }
  @media all and (max-width: 1024px) {
    .home .mainImgNews {
      position: static;
      width: 100%;
      padding: 30px 5%;
      box-sizing: border-box;
      flex-direction: column; } }
  .home .mainImgNews .newsHead {
    width: 120px;
    background: #147251;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
    border-radius: 5px 0 0 5px;
    letter-spacing: 0.1em; }
    @media all and (max-width: 1024px) {
      .home .mainImgNews .newsHead {
        width: 100%;
        height: 40px;
        border-radius: 5px; } }
  .home .mainImgNews .newsList {
    flex: 1; }
    .home .mainImgNews .newsList li:first-child {
      padding: 16px 25px 0 25px; }
      @media all and (max-width: 1024px) {
        .home .mainImgNews .newsList li:first-child {
          padding: 16px 0 0 0; } }
    .home .mainImgNews .newsList li:nth-child(2) {
      padding: 10px 25px 16px 25px; }
      @media all and (max-width: 1024px) {
        .home .mainImgNews .newsList li:nth-child(2) {
          padding: 14px 0 0 0; } }
    .home .mainImgNews .newsList a {
      display: flex;
      align-items: center;
      gap: 20px;
      border-bottom: 1px solid #D3D3D3;
      text-decoration: none;
      color: #000;
      transition: background 0.8s ease-in-out;
      position: relative; }
      .home .mainImgNews .newsList a::after {
        content: "";
        position: absolute;
        right: 5px;
        top: 50%;
        width: 5px;
        height: 5px;
        border-top: 1.5px solid #0c7b5c;
        border-right: 1.5px solid #0c7b5c;
        transform: translateY(-50%) rotate(45deg); }
    .home .mainImgNews .newsList a:hover {
      background: #f5f5f5; }
    .home .mainImgNews .newsList time {
      font-size: clamp(14px, 1.4vw, 14px);
      font-family: "times-new-roman", sans-serif;
      font-weight: 500;
      width: 65px; }
    .home .mainImgNews .newsList .title {
      font-size: clamp(14px, 1.4vw, 14px);
      font-weight: 500;
      letter-spacing: 0.05em;
      line-height: 1.4;
      overflow: hidden;
      white-space: nowrap;
      text-overflow: ellipsis;
      width: calc( 100% - 85px ); }
.home .cn1 {
  padding-bottom: 50px; }
  @media all and (max-width: 1024px) {
    .home .cn1 {
      padding-bottom: 40px; } }
  .home .cn1 .wrap {
    background: url("img/productsImgBg.webp") no-repeat center top/cover;
    padding-top: 50px;
    padding-bottom: 70px; }
    @media all and (max-width: 1024px) {
      .home .cn1 .wrap {
        padding-top: 25px;
        padding-bottom: 25px; } }
  .home .cn1 .cn1List {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px 15px; }
    @media all and (max-width: 1270px) {
      .home .cn1 .cn1List {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px; } }
    @media all and (max-width: 768px) {
      .home .cn1 .cn1List {
        grid-template-columns: 1fr; } }
    .home .cn1 .cn1List li {
      list-style: none; }
    .home .cn1 .cn1List a {
      height: 100%;
      position: relative;
      min-height: 70px;
      display: flex;
      align-items: center;
      gap: 20px;
      padding: 4% 5%;
      box-sizing: border-box;
      background: #FFF;
      border-radius: 10px;
      box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
      text-decoration: none;
      transition: opacity 0.8s ease-in-out; }
      @media all and (max-width: 1580px) {
        .home .cn1 .cn1List a {
          gap: 10px; } }
      .home .cn1 .cn1List a::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 7px;
        height: 100%;
        background: #118065;
        border-radius: 6px 0 0 6px; }
      .home .cn1 .cn1List a:hover {
        background: #fffdf7;
        transition: 0.8s; }
    .home .cn1 .cn1List .icon {
      flex-shrink: 0;
      width: calc( 30% - 20px );
      max-width: 82px;
      height: auto; }
      @media all and (max-width: 1024px) {
        .home .cn1 .cn1List .icon {
          max-width: 52px; } }
      .home .cn1 .cn1List .icon img {
        width: 100%;
        height: auto;
        object-fit: cover; }
    .home .cn1 .cn1List .txt {
      color: #1f2a56;
      line-height: 1.4;
      width: 70%; }
    .home .cn1 .cn1List .name {
      font-size: clamp(18px, 3vw, 20px);
      font-weight: bold;
      letter-spacing: 0.05em;
      line-height: 1.4;
      color: #906B17; }
      @media all and (max-width: 1580px) {
        .home .cn1 .cn1List .name {
          font-size: clamp(16px, 1.6vw, 16px); } }
    .home .cn1 .cn1List .price {
      display: flex;
      align-items: flex-end; }
      .home .cn1 .cn1List .price span:nth-child(1) {
        font-size: clamp(28px, 3.2vw, 38px);
        font-weight: 600;
        line-height: 1; }
        @media all and (max-width: 1700px) {
          .home .cn1 .cn1List .price span:nth-child(1) {
            font-size: clamp(28px, 3.2vw, 32px); } }
        @media all and (max-width: 1580px) {
          .home .cn1 .cn1List .price span:nth-child(1) {
            font-size: clamp(28px, 3.2vw, 28px); } }
      .home .cn1 .cn1List .price span:nth-child(2) {
        font-size: clamp(10px, 1.4vw, 14px);
        font-weight: bold;
        margin-left: 4px; }
        @media all and (max-width: 1580px) {
          .home .cn1 .cn1List .price span:nth-child(2) {
            font-size: clamp(12px, 1.4vw, 12px); } }
    .home .cn1 .cn1List .note, .home .cn1 .cn1List .desc {
      margin-top: 5px;
      font-size: clamp(10px, 1.4vw, 14px);
      font-weight: bold;
      line-height: 1.4; }
      @media all and (max-width: 1580px) {
        .home .cn1 .cn1List .note, .home .cn1 .cn1List .desc {
          font-size: clamp(12px, 1.4vw, 12px); } }
  .home .cn1 .img {
    max-width: 825px;
    padding-top: 60px;
    margin-left: auto;
    margin-right: auto; }
    @media all and (max-width: 1024px) {
      .home .cn1 .img {
        padding-top: 40px;
        padding: 40px 5% 0 5%; } }
    .home .cn1 .img img {
      width: 100%;
      height: auto; }
@media all and (max-width: 768px) {
  .home .cn2 .sectionTit {
    gap: 0; } }
@media all and (max-width: 768px) {
  .home .cn2 .sectionTit .tit {
    gap: 0; } }
.home .cn2 .swiper-wrapper {
  align-items: stretch; }
.home .cn2 .swiper-slide {
  height: auto; }
.home .cn2 .swiper-slide > * {
  height: 100%; }
.home .cn2 .cn2Slide {
  padding-left: 5%;
  padding-right: 5%; }
  .home .cn2 .cn2Slide .swiper-slide .box {
    max-width: 520px;
    border-radius: 20px;
    background: #F7F6F4;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1); }
    .home .cn2 .cn2Slide .swiper-slide .box .point {
      background: #147251;
      font-size: clamp(16px, 3.6vw, 36px);
      font-weight: bold;
      color: #FFF;
      border-radius: 20px 20px 0 0;
      padding: 5px 20px; }
    .home .cn2 .cn2Slide .swiper-slide .box .txt {
      min-height: 230px;
      padding: 20px;
      box-sizing: border-box;
      display: flex;
      flex-direction: column;
      gap: 15px;
      justify-content: flex-start; }
      @media all and (max-width: 1024px) {
        .home .cn2 .cn2Slide .swiper-slide .box .txt {
          padding: 20px;
          min-height: 172px; } }
      .home .cn2 .cn2Slide .swiper-slide .box .txt h3 {
        font-size: clamp(16px, 1.8vw, 26px);
        letter-spacing: 0.05em;
        line-height: 1.3; }
      .home .cn2 .cn2Slide .swiper-slide .box .txt p {
        font-size: clamp(12px, 1.6vw, 16px);
        letter-spacing: 0.05em;
        line-height: 1.6; }
    .home .cn2 .cn2Slide .swiper-slide .box .img {
      width: 100%;
      height: auto; }
      .home .cn2 .cn2Slide .swiper-slide .box .img img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 0 0 20px 20px;
        pointer-events: none; }
.home .cn2 .swiper-button-prev,
.home .cn2 .swiper-button-next {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid #147251;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10; }
  @media all and (max-width: 1024px) {
    .home .cn2 .swiper-button-prev,
    .home .cn2 .swiper-button-next {
      width: 32px;
      height: 32px; } }
  .home .cn2 .swiper-button-prev::after,
  .home .cn2 .swiper-button-next::after {
    display: none; }
.home .cn2 .swiper-button-prev {
  left: 65px; }
  @media all and (max-width: 1024px) {
    .home .cn2 .swiper-button-prev {
      left: 10px; } }
.home .cn2 .swiper-button-next {
  right: 65px; }
  @media all and (max-width: 1024px) {
    .home .cn2 .swiper-button-next {
      right: 10px; } }
.home .cn2 .swiper-button-prev span,
.home .cn2 .swiper-button-next span {
  display: block;
  width: 10px;
  height: 10px;
  border-top: 2px solid #147251;
  border-right: 2px solid #147251;
  position: relative; }
  @media all and (max-width: 1024px) {
    .home .cn2 .swiper-button-prev span,
    .home .cn2 .swiper-button-next span {
      width: 7px;
      height: 7px; } }
.home .cn2 .swiper-button-prev span {
  transform: rotate(-135deg);
  left: 2px; }
.home .cn2 .swiper-button-next span {
  transform: rotate(45deg);
  right: 2px; }
.home .cn3 {
  padding-top: 130px; }
  @media all and (max-width: 1024px) {
    .home .cn3 {
      padding-top: 30px; } }
  .home .cn3 .sectionTit {
    margin-bottom: 70px; }
    @media all and (max-width: 1024px) {
      .home .cn3 .sectionTit {
        margin-bottom: 40px; } }
  .home .cn3 .txt {
    text-align: center; }
    .home .cn3 .txt p {
      font-size: clamp(30px, 5vw, 50px);
      font-weight: bold;
      letter-spacing: 0.1em;
      line-height: 1.4;
      margin-bottom: 70px; }
      @media all and (max-width: 1024px) {
        .home .cn3 .txt p {
          margin-bottom: 40px; } }
    .home .cn3 .txt .img {
      width: 90%;
      margin: 0 auto 20px auto; }
      @media all and (max-width: 1024px) {
        .home .cn3 .txt .img {
          width: 60%; } }
      @media all and (max-width: 768px) {
        .home .cn3 .txt .img {
          width: 90%; } }
      .home .cn3 .txt .img img {
        width: 100%; }
.home .cn4 {
  padding-top: 130px;
  padding-bottom: 130px; }
  @media all and (max-width: 1024px) {
    .home .cn4 {
      padding-top: 30px;
      padding-bottom: 80px; } }
  .home .cn4 .cmList {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 40px; }
    .home .cn4 .cmList .cmItem {
      width: calc( ( 100% - 80px ) / 3 ); }
      @media all and (max-width: 1024px) {
        .home .cn4 .cmList .cmItem {
          width: calc( ( 100% - 80px ) / 2 ); } }
      @media all and (max-width: 768px) {
        .home .cn4 .cmList .cmItem {
          width: 100%; } }
      .home .cn4 .cmList .cmItem .cmImg {
        margin-bottom: 20px;
        box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
        border-radius: 10px;
        overflow: hidden; }
        @media all and (max-width: 1024px) {
          .home .cn4 .cmList .cmItem .cmImg {
            margin-bottom: 10px; } }
        .home .cn4 .cmList .cmItem .cmImg img {
          width: 100%;
          height: auto;
          object-fit: cover;
          transform: scale(1); }
      .home .cn4 .cmList .cmItem .cmMeta {
        margin-bottom: 13px; }
        @media all and (max-width: 1024px) {
          .home .cn4 .cmList .cmItem .cmMeta {
            margin-bottom: 8px; } }
        .home .cn4 .cmList .cmItem .cmMeta .cmNew {
          display: inline-flex;
          justify-content: center;
          align-items: center;
          width: 68px;
          height: 33px;
          background: #F44848;
          font-family: "times-new-roman", sans-serif;
          font-weight: bold;
          font-size: clamp(15px, 1.5vw, 15px);
          letter-spacing: 0.05em;
          line-height: 1.1;
          color: #FFF;
          border-radius: 5px;
          margin-right: 10px; }
        .home .cn4 .cmList .cmItem .cmMeta .cmCat {
          display: inline-flex;
          justify-content: center;
          align-items: center;
          padding: 3px 10px;
          background: #FFF;
          font-size: clamp(14px, 1.6vw, 16px);
          font-weight: bold;
          letter-spacing: 0.05em;
          line-height: 1.4;
          color: #147251;
          border-radius: 5px;
          border: 2px solid #147251;
          box-sizing: border-box; }
      .home .cn4 .cmList .cmItem .cmTtl {
        font-weight: bold;
        font-size: clamp(18px, 3vw, 26px);
        letter-spacing: 0.05em;
        line-height: 1.3;
        color: #906B17;
        margin-bottom: 15px; }
        @media all and (max-width: 1024px) {
          .home .cn4 .cmList .cmItem .cmTtl {
            margin-bottom: 8px; } }
      .home .cn4 .cmList .cmItem .cmTxt {
        font-size: clamp(14px, 1.6vw, 16px);
        letter-spacing: 0.05em;
        line-height: 1.5; }
      .home .cn4 .cmList .cmItem:hover .cmImg img {
        transform: scale(1.1); }

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