@charset "utf-8";
html {  scroll-behavior: smooth; scroll-padding-top: 0px; }
body { line-height: 1.5;}
.wrapper { width: 100% ; margin: 0;  }
img { max-width: 100%; height: auto; }

@media screen and (max-width: 768px) {
  html { font-size: .8735rem; }
}
/*----------------------------
layout
----------------------------*/
.l-container { width: 90%; max-width: 1100px; margin: 0 auto; }
.l-container-s { width: 90%; max-width: 930px; margin: 0 auto; }

.l-spacer-l { margin-top: 110px; }
.l-spacer { margin-top: 80px; }
.l-center { text-align: center; }
@media screen and (max-width: 768px) {
  .l-spacer-l { margin-top: 70px; }
  .l-spacer { margin-top: 50px; }
}

.u-sp-only { display: none; }
@media screen and (max-width: 768px) {
  .u-pc-only { display: none; }
  .u-sp-only { display: initial; }
}

/*logo*/
.c-logo { font-size: 1.375rem; text-align: center; display: flex; align-items: baseline; justify-content: center; width: fit-content; }
.c-logo__en { font-size: 1.09em; }
.c-logo__img { width: 1.7em; margin-right: .2em; align-self: center; }


/*----------------------------
header
----------------------------*/
.l-header { display: flex; padding: 1.25rem 2.5rem; display: flex; justify-content: space-between; align-items: center; z-index: 999; position: relative; }
.l-header__logo { font-weight: 500;  }
.l-header-menu { display: flex; }
.l-header-menu__item + .l-header-menu__item { margin-left: 2em; }

.l-header-tel__title { display: block; font-size: .6875rem; }
.l-header-tel__telnum { display: block; font-size: 1.5rem; line-height: 1.2; }
.l-header-tel__telnum img { width: 1.5em; vertical-align: middle; margin-right: .3em; }

@media screen and (max-width: 1250px) {
  .l-header { padding: 1.25rem; }
  .l-header__logo { font-size: 1.125rem; }
  .l-header-menu { font-size: .8735rem; }
  .l-header-menu__item + .l-header-menu__item { margin-left: 1.5em; }
  .l-header-tel__telnum { font-size: 1.3rem; }
}

@media screen and (max-width: 1000px) {
  .l-header-menu { display: none; position: fixed; top: 1rem; right: .5rem; margin: auto; border-radius: 30px; background: #FFF; padding: 4rem 1rem; width: fit-content; box-shadow: 10px 10px 30px rgba(197, 213, 183, .5);}
  .l-header-tel { margin: 0 4rem 0 auto; }
  
  .l-header.open .l-header-menu { display: block; }
  .l-header-menu__link { display: block; padding: .5em 2em; }
  .l-header-menu__item + .l-header-menu__item { margin: .5em 0 0;}
}
@media screen and (max-width: 768px) {
  .l-header__logo { font-size: 1rem; }
  .l-header-tel {margin-right: 3rem;  }
  .l-header-tel__telnum { font-size: 1.125rem; }
}


.c-btn-hamburger { display: none; }
@media screen and (max-width: 1000px) {
  .c-btn-hamburger { display: block; background: none; width: 3rem; height: 3rem;padding: 0; text-indent: 100%; overflow: hidden; white-space: nowrap; border: none; position: fixed; top: 1.25rem; right: 1.25rem; margin: auto; z-index: 999;  }
  .c-btn-hamburger::before,
  .c-btn-hamburger::after { content: '';  width: 1.5rem; height: 2px; background: #55A86C; display: block; position: absolute; inset: 0; margin: auto; }
  .c-btn-hamburger::before { transform: translateY(-5px); box-shadow: 0 5px 0 #55A86C; }
  .c-btn-hamburger::after { transform: translateY(5px); }
  
  .c-btn-hamburger.open::before { transform: rotate(45deg); box-shadow: none; }
  .c-btn-hamburger.open::after { transform: rotate(-45deg); }
}
@media screen and (max-width: 768px) {
  .c-btn-hamburger { right: .5rem; top: 1rem; }
}

.common_header {
  .bg-grad {
    padding: 21px 0 80px;
  }


  .c-title-section {
    font-weight: 500;
    font-size: 44px;
    text-align: center;
    color: #fff;
    margin-bottom: 0;
  }

  .c-title-section::before {
    margin-bottom: 0;
  }

  .c-title-section__en {
    margin-top: 3px;
    font-family: var(--font-en);
    font-weight: 600;
    font-size: 15px;
    text-align: center;
    color: #fff;
  }

  .w-box {
    border-radius: 50px;
    background: #fff;
    box-shadow: 10px 10px 30px rgba(197, 213, 183, 0.25);
    max-width: 1100px;
    width: 90%;
    margin: -86px auto 0;
    padding: 64px 0 73px;

    .text {
      margin-bottom: 38px;

      .desc {
        text-align: center;

        @media screen and (max-width: 767px) {
          text-align: left;
          width: calc(323 / 343 * 100%);
          margin-left: auto;
          margin-right: auto;
        }

        strong {
          font-weight: bold;
          font-size: 20px;
          line-height: 30px;
          text-align: center;
          color: #333;

          @media screen and (max-width: 767px) {
            font-size: 18px;

          }

        }
      }
    }

    .p_menu {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      grid-template-rows: auto;
      gap: 10px;

      @media screen and (max-width: 767px) {
        grid-template-columns: 1fr;
        width: 90%;
        margin: 0 auto;
      }

      .menuitem {
        border-radius: 5px;
        background: #fafcf4;

        border: 1px solid #d7ecbc;
        padding: 18px 13px;
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: center;
        text-decoration: underline;
        transition: all .4s ease;

        p {
          font-size: 16px;
          line-height: 20px;

          @media screen and (max-width: 767px) {
            font-size: 14px;
            width: calc(220 / 303 * 100%);
          }
        }



        a {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;

        }


      }

      .menuitem:hover {
        filter: opacity(60%);
        transition: all .4s ease;
      }
    }
  }
}

/*----------------------------
footer
----------------------------*/

.l-footer { padding: 100px 0; }
.l-footer-menu-primary { display: flex; flex-wrap: wrap; justify-content: center; font-size: .875rem; }
.l-footer-menu-primary__item { margin: 0 1em; }

.l-footer-menu-secondary { display: flex; justify-content: center; font-size: .75rem; opacity: .7; }
.l-footer-menu-secondary__item { margin: 0 1.5em; }

@media screen and (max-width: 768px) {
  .l-footer-menu-primary__item  { margin: .5em 1em; }
  
  .l-footer-menu-secondary { flex-wrap: wrap; }
  .l-footer-menu-secondary__item { margin: .5em 1em; }
  .l-footer-menu-secondary__item + .l-footer-menu-secondary__item { margin-left: 1em; }
}
.l-footer-logo { margin: 3rem auto; }

.c-copyright { text-align: center; font-size: .75rem; opacity: .35; display: block; margin-top: 2.5rem; }

/*----------------------------
common compornent
----------------------------*/

/*title*/
.c-title-section { text-align: center; font-size: 2rem; margin-bottom: 2em; }
.c-title-section__en { display: block; font-family: 'Montserrat',sans-serif; color: #55A86C; font-size: .46875em; font-weight: 600; margin-top: 1em;  }
.c-title-section::before { content: ''; width: 30px; height: 10px; display: block; background: url("../img/ttl.svg") no-repeat center center / 100% 100%; margin: 0 auto 1.2rem; }

.c-title-section.-white { color: #FFF; }
.c-title-section.-white::before { background-image: url(../img/ttl-white.svg); }
.c-title-section.-white .c-title-section__en{ color: #FFF; }

.c-title-section-s { text-align: center; font-size: 1.5rem; color: #55A86C; font-weight: bold; margin-bottom: 2em; }


@media screen and (max-width: 768px) {
  .c-title-section::before { margin-bottom: 1rem; width: 20px; height: 7px; }
  .c-title-section { font-size: 1.5rem; margin-bottom: 1.5em; }
  
  .c-title-section-s { font-size: 1.3rem; margin-bottom: 1.5em; }
}

/*text*/
.c-text-lead { text-align: center; margin-bottom: 4em; }
.c-text-en { font-family: 'Montserrat',sans-serif; }
.c-text-bold { font-weight: bold; }
.c-text-green { color: #55A86C; }
.c-text-ygreen { color: #A4C74E; }
.c-text-red { color: #E67C8D; }

@media screen and (max-width: 768px) {
  .c-text-lead { margin-bottom: 2em; }
}


/*button*/
.c-button-round { max-width: 300px; width: 90%; background: #55A86C url('../img/arrow-r.svg') no-repeat right 1.5em center / auto .8em; box-shadow: 10px 10px 30px rgba(197, 213, 183, .5); text-align: center; font-weight: bold; padding: .8em; border-radius: 2em; color: #FFF; display: inline-block; }
.c-button-round.-line { border: 2px solid #FFFFFF; }

/*list*/
.c-list-dot > li { padding-left: 1em; }
.c-list-dot > li::before { content: ''; width: 6px; height: 6px; border-radius: 50%; margin-left: -1em; margin-right: calc(1em - 6px); display: inline-block; background: #55A86C; }
.c-list-dot > li  + li { margin-top: 1em; }

.c-list-dot.-green > li::before { background: #55A86C; }
.c-list-dot.-yellow > li::before { background: #DDAB47; }
.c-list-dot.-red > li::before { background: #E67C8D; }


.c-fixed-menu { position: fixed; bottom: 0; left: 0; right: 0; margin: auto; z-index: 99; width: fit-content; display: flex; }
.c-fixed-menu__item { width: 12rem; text-align: center; padding: 1em; border-radius: .5em .5em 0 0 ; color: #FFF; display: block; margin: 0 5px; overflow: hidden;position: relative; }
.c-fixed-menu__item::before {
  content: ''; position: absolute; content: ''; display: inline-block; top: -180px; left: 0; width: 30px; height: 100%; background-color: #fbfbfb; }

.c-fixed-menu__item .icon { vertical-align: middle; margin-right: .5em; width: 1.5em; height: 1em; object-fit: contain; }
.c-fixed-menu__item.-mail {background: linear-gradient( #38BA5C, #37C981 65%, #37D397); }
.c-fixed-menu__item.-soudan {background: linear-gradient( #E4747F, #EBA3D5); }

@media (hover:hover) {
  .c-fixed-menu__item:hover::before {  animation: btn_animation 2s ease-out infinite; }
}

@-webkit-keyframes btn_animation {
    0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
    10% { -webkit-transform: scale(4) rotate(45deg); opacity: 0.5; }
    11% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
    50% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
    100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}

@media screen and (max-width: 900px) {
  .c-table-wrap { width: 100%;  overflow-x: scroll; }
}
@media screen and (max-width: 768px) {
  .c-fixed-menu__item::before { animation: btn_animation 2s ease-out infinite; }
}


/*----------------------------
FV
----------------------------*/
.p-home-mv { width: 100%; height: calc(100vh - 10rem); min-height: 650px; position: relative; display: flex; flex-direction: column; justify-content: center; margin-bottom: 8rem; }
.p-home-mv__img { width: calc((100vh - 10rem) * 0.7); height: calc(100% - 2rem);  position: absolute; top: 0; right: 0; margin: auto; z-index: -1;}
.p-home-mv__img img { width: 100%; height: 100%;  object-fit: cover; border-radius: 3rem;  }

.p-home-mv__text { padding-bottom: 3em; }
.p-main-copy { font-size: 3.125rem; line-height: 1.2; }
.p-main-subcopy { font-size: 1.25rem; margin: 1em 0 2em; }
.p-main-title { width: 73%; margin: 0 auto 1em -1em; }
.p-main-title img { width: 100%; }

@media screen and (max-width: 768px) {
  .p-home-mv { justify-content: flex-start; height: auto; margin: 0; min-height: 0; }
  .p-main-copy { font-size: 2.5rem; }
  .p-home-mv__img { width: 60vw; height: 80vw; }
  .p-home-mv__text { margin-top: 50vw; }
}

@media screen and (max-width: 600px) {
  .p-main-copy { font-size: 8vw; }
  .p-main-subcopy { font-size: 3vw; }
  .p-main-title { width: 100%;}
  
}

.p-main-feature { display: flex; font-size: .9375rem; color: #AD8B5B; line-height: 1.2; }
.p-main-feature .large { font-size: 2em; }
.p-main-feature .medium { font-size: 1.3em; }
.p-main-feature sup { vertical-align: text-top; font-size: .7em; }
.p-main-feature__item { text-align: center; background: url("../img/leaf.svg") no-repeat center center/ 100% auto; ; width:12em; height: 6em; display: flex; align-items: centere; justify-content: center; margin-right: 1em; flex-direction: column; }
.p-main-note { font-size: .75rem;color: #AD8B5B; }

@media screen and (max-width: 768px) {
  
  .p-main-feature { font-size: 2.5vw; white-space: nowrap; }
}

.c-button-scroll-down { position: absolute; left: 0; right: 0; bottom: -.5rem; margin: auto; width: fit-content; font-size: .625rem; }
.c-button-scroll-down img { display: block; margin: 0 auto .5em; }

@media screen and (max-width: 768px) {
  .c-button-scroll-down { display: none; }
}



.campaign-bnr { position: relative; width: fit-content; margin: 0 auto; }

.campaign-bnr:before,
.campaign-bnr:after {
  content: "";
  position: absolute;
  z-index: -10;
  top: 22.5%;
  left: 6.2%;
  margin: auto;
  border-radius: 15px;
  background: #38BA5C;
  transform: translate3d(0, 0, 0);
  width: 85%;
  height: 45%;
}
@media (hover:hover) {
  .campaign-bnr:hover:before {
    animation: ripple 1s ease-out infinite;
  }
  .campaign-bnr:hover:after {
    animation: ripple 1s ease-out 1s infinite;
  }
}

@media screen and (max-width: 768px) {
  .campaign-bnr::before {
    animation: ripple 1s ease-out infinite;
  }
  .campaign-bnr::after {
    animation: ripple 1s ease-out 1s infinite;
  }
}


@keyframes ripple{
0%{transform:scale(.95); opacity:1}
90%{opacity:.05}to{transform:scale(1.1,1.5); opacity:0; }
}

/*----------------------------
Service
----------------------------*/
.p-home-service-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 60px; max-width: 900px; margin: 0 auto; counter-reset: listnum;  }

.p-home-service-list__item { position: relative; counter-increment: listnum; }
.p-home-service-list__item::before { content: counter(listnum, decimal-leading-zero); position: absolute; color: #FFF; width: 2.5em; height: 2.5em; line-height: 2.5; text-align: center; border-radius: 50%; font-size: 1.25rem; top: 5%; left: 5%; margin: auto; background: #55A86C; z-index: 3; } 
.p-home-service-list__item:nth-child(2)::before { background: #7BBB69; }
.p-home-service-list__item:nth-child(3)::before { background: #9FCE66; }
.p-home-service-list__item:nth-child(-n + 2)::after { content: ''; width: 60px; height: 100%; display: block; position: absolute; left: 100%; top: 0; bottom: 0; margin: auto; background-size: 60%; auto; background-position: center center; background-repeat: no-repeat; }
.p-home-service-list__item:nth-child(1)::after { background-image: url("../img/arrow-green-r.svg"); } 
.p-home-service-list__item:nth-child(2)::after { background-image: url("../img/arrow-ygreen-r.svg"); }

.p-home-service-list__circle { text-align: center; display: flex; flex-direction: column; justify-content:center; align-items: center; aspect-ratio: 1 /1; border-radius: 50%; position: relative; background: #FAFCF4; font-size: 1.125rem; }
.p-home-service-list__circle::after { content: ''; width: calc(100% + 6px); height: calc(100% + 6px); background: linear-gradient(100deg, #55A86C, #B9DB64); position: absolute; top: -3px; left: -3px; margin: auto;border-radius: 50%; z-index: -1; }

.p-home-service-list__item img { margin: -1em 0 .5em; }
.p-home-service-list__item:first-child img { margin-left: 1em; }

@media screen and (max-width :768px) {
  .p-home-service-list { grid-template-columns: 1fr; max-width: 200px; }
  .p-home-service-list__circle{ font-size: 1rem; }
  .p-home-service-list__item:nth-child(-n + 2)::after { top: 100%; bottom: auto; left: 0; right: 0; transform: rotate(90deg); height: 60px; width: 60px; }
}


/*----------------------------
Why
----------------------------*/
.p-home-why { overflow-x: hidden; padding-bottom: 30px; }
.p-home-why-list { counter-reset: listnum; overflow: visible; } 
.p-home-why-list__item { background: #FFF; box-shadow: 10px 10px 30px rgba(197, 213, 183, .25); border-radius: 50px; counter-increment: listnum; padding: 2rem 2em 3em; } 
.p-home-why-list__num { text-align: center; color: #55A86C; font-size: 1.875rem; display: flex; align-items: center; justify-content: center; margin-bottom: .5em; line-height: 1;}
.p-home-why-list__num span { font-size: 1.8em; background: linear-gradient(100deg, #55A86C, #B9DB64); background-clip: text; color: transparent; margin-left: .2em; } 

.p-home-why-list__title { color: #55A86C; font-weight: bold; font-size: 1.25rem; line-height: 1.6; margin-bottom: 1em; height: 3em; text-align: center; display: flex; align-items: center; justify-content: center; } 
.p-home-why-list__img { margin-bottom: 2em; }
.p-home-why-list__img img { width: 100%; }
.p-home-why-list__desc { line-height: 1.625; }


.p-why-slider__prev,
.p-why-slider__next { display: none; }


@media screen and (max-width: 980px) {
  .p-why-slider { position: relative; }
  .p-why-slider__prev,
  .p-why-slider__next { width: 56px; height: 56px; position: absolute; top: calc(50% - 58px); margin: auto; z-index: 10; cursor: pointer; display: block; }
  .p-why-slider__prev { left: -30px; }
  .p-why-slider__next { right: -30px;}
}
@media screen and (max-width: 900px) {
  .p-home-why-list { gap: 30px; }
  .p-home-why-list__num { font-size: 1.5rem; }
  .p-home-why-list__title { font-size: 1.125rem; }
}
@media screen and (max-width: 768px) {
  .p-home-why-list__num { font-size: 1.3rem; }
  .p-home-why-list { grid-template-columns: 1fr ; }
  .p-home-why-list__item { border-radius: 25px; }
  .p-why-slider__prev,
  .p-why-slider__next { width: 30px; height: 30px; }
  .p-why-slider__prev { left: -15px; }
  .p-why-slider__next { right: -15px;}
  
}

/*----------------------------
Price
----------------------------*/
.p-home-price { background: #FFF; padding: 60px 0 80px; border-radius: 50px; box-shadow: 10px 10px 30px rgba(197, 213, 183, .25); }

.p-home-price-table__wrap { width: 900px; max-width: 90%; margin: 0 auto 60px; }
.p-home-price-table { width: 100%; min-width: 800px; table-layout: fixed;}
.p-home-price-table tr { border-bottom: 1px solid #CFD1C7; }
.p-home-price-table th { vertical-align: middle; }
.p-home-price-table th:first-child { width: 140px; background: #F2F7E4; font-weight: normal; text-align: center; padding: 1em; }
.p-home-price-table td { padding: 1em; }
.p-home-price-table td + td { border-left: 1px solid #CFD1C7; }

.p-home-price-plan { text-align: center; font-size: 1.25rem; font-weight: bold; color: #FFF; padding: 1em; }
.p-home-price-plan img { vertical-align: middle; margin-right: .3em; margin-top: -.2em; }

.p-home-price-plan.-time { background: #55A86C; }
.p-home-price-plan.-pack { background: #DDAB47; }
.p-home-price-plan.-success { background: #E67C8D; }


@media screen and (max-width: 768px) {
  .p-home-price { padding: 40px 0 50px; border-radius: 25px;  }
  .p-home-price-plan{ font-size: 1rem; }
}

/*----------------------------
Reason
----------------------------*/
.p-home-reason { background: linear-gradient( 135deg, #55A86C, #55A86C 30%, #B9DB64); padding: 100px 0; }
.p-home-reason-list { counter-reset: listnum; }
.p-home-reason-list__item { display: flex; align-items: center; counter-increment: listnum; } 
.p-home-reason-list__item + .p-home-reason-list__item { margin-top: 40px; }

.p-home-reason-list__item:nth-child(2n) { flex-direction: row-reverse; }
.p-home-reason-list__text { background: #FFF; border-radius: 20px; width: 50%; margin-right: -10%; position: relative; z-index: 2; padding: 3rem 4rem; }
.p-home-reason-list__text::after { content: counter(listnum, decimal-leading-zero); font-family: 'Montserrat', sans-serif; font-weight: 200; position: absolute; right: 3rem; top: 0; bottom: 0; line-height: 1; height: 1em; margin: auto; color: #A4C74E; opacity: .19; font-size: 7.5rem;}

.p-home-reason-list__img { width: 60%; border-radius: 43px; overflow: hidden; }
.p-home-reason-list__item:nth-child(2n) .p-home-reason-list__text { margin-left: -10%; margin-right: 0; }

.p-home-reason-list__title { font-size: 1.5rem; font-weight: bold; color: #55A86C; margin-bottom: 1em; }
.p-home-reason-list__desc { padding-right: 3rem; }


@media screen and (max-width: 900px) {
  .p-home-reason-list__item:nth-child(n) { flex-direction: column-reverse; align-items: flex-start; }
  .p-home-reason-list__item:nth-child(n) .p-home-reason-list__text { width: 85%; margin: 0; }
  .p-home-reason-list__item:nth-child(n) .p-home-reason-list__img { width: 85%; margin: 0 0 -2rem auto;  }
}

@media screen and (max-width: 768px) {
  .p-home-reason { padding: 60px 0; }
  .p-home-reason-list__text { padding: 1.5rem 2rem; border-radius: 25px; }
  .p-home-reason-list__img { border-radius: 25px; }
  .p-home-reason-list__title { font-size: 1.3rem; }
  .p-home-reason-list__text::after  { right: 2rem; bottom: auto; top: .5rem; font-size: 6rem; }
  .p-home-reason-list__desc  { padding: 0;}
}

/*----------------------------
voice
----------------------------*/
.p-home-voice { padding: 120px 0;}

.p-review-slider { position: relative; }
.p-review-slider .swiper-wrapper { align-items: center; }
.p-review-slider .swiper-slide { transform: scale(.8);  opacity: .2; transition: transform .5s .2s, opacity .5s; }
.p-review-slider .swiper-slide-active { transform: scale(1); opacity: 1;}
.p-review-slider__comment { background: #FFF; border-radius: 50px; padding: 3em; margin-bottom: 30px; position: relative;box-shadow: 10px 10px 30px rgba(197, 213, 183, .25); min-height: 15em; }
.p-review-slider__comment::after { content: ''; width: 37px; height: 28px; display: block; background: #FFF; clip-path: polygon(0 0 , 100% 0, 0 100%, 0 0); position: absolute; top: 100%; left: 60px; margin: auto; box-shadow: 10px 10px 30px rgba(197, 213, 183, .25);}

@media screen and (max-width: 768px) {
  .p-home-voice { padding: 60px 0;}
  
  .p-review-slider__comment { padding: 2rem; border-radius: 30px; }
}

.c-google-review { display: flex; font-weight: bold; font-size: .75rem; color: #B2B4AB; width: fit-content; align-items: center; margin-top: 2em; position: absolute; right: 3rem; bottom: 1rem; margin: auto; }

.p-review-slider__rating { display: grid; grid-template-columns: 60px minmax(0, 1fr); gap: 1rem;  align-items: center; }
.p-review-slider__star { font-size: 1.25rem; color: transparent; background-clip: text; width: fit-content;  }
.p-review-slider__star.-star1 { background-image: linear-gradient(to right, #F4CA1B 20%, #CCC 20%); }
.p-review-slider__star.-star2 { background-image: linear-gradient(to right, #F4CA1B 40%, #CCC 40%); }
.p-review-slider__star.-star3 { background-image: linear-gradient(to right, #F4CA1B 60%, #CCC 60%); }
.p-review-slider__star.-star4 { background-image: linear-gradient(to right, #F4CA1B 80%, #CCC 80%); }
.p-review-slider__star.-star5 { background-image: linear-gradient(to right, #F4CA1B 100%, #CCC 100%); }


@media screen and (max-width: 768px) {
  .p-review-slider__rating { grid-template-columns: 40px minmax(0, 1fr); }
}

.p-review-slider__prev,
.p-review-slider__next { width: 56px; height: 56px; position: absolute; top: calc(50% - 58px); margin: auto; z-index: 10; cursor: pointer; }
.p-review-slider__prev { right: 70%; }
.p-review-slider__next {  left: 70%;}
  
.p-review-slider__pagination { text-align: center; margin: 4rem 0; }
.swiper-pagination-bullet { background: #CFD1C7; width: 10px; height: 10px; }
.swiper-pagination-bullet-active { background: #55A86C; }

@media screen and (max-width: 768px) {
  .p-home-voice .l-container { width: 100%; }
  .p-review-slider__prev,
  .p-review-slider__next { width: 30px; height: 30px;  top: calc(50% - 30px);}
  .p-review-slider__prev { right: 90%; }
  .p-review-slider__next {  left: 90%;}
  .p-review-slider__pagination { margin: 2rem 0 4rem; }
  .c-google-review { right: 1.5rem; }
}

.p-letter-slider { position: relative; }
.p-letter-slider .swiper-slide { transform: scale(.8);  opacity: .2; transition: transform .5s .2s, opacity .5s; }
.p-letter-slider .swiper-slide-active { transform: scale(1); opacity: 1;}
.p-letter-slider__img { background: #FFF; padding: 3rem; border-radius: 50px; box-shadow: 10px 10px 30px rgba(197, 213, 183, .25);}

.p-letter-slider__title { color: #55A86C; font-weight: bold; margin: 1em 0 .5em; }

.p-letter-slider__prev,
.p-letter-slider__next { width: 56px; height: 56px; position: absolute; top: calc(50% - 58px); margin: auto; z-index: 10; cursor: pointer; }
.p-letter-slider__prev { right: 70%; }
.p-letter-slider__next {  left: 70%;}
.p-letter-slider__pagination { text-align: center; margin: 4rem 0; }

@media screen and (max-width: 768px) {
  .p-letter-slider__img { padding: 1.5rem; border-radius: 30px; }
  .p-letter-slider__prev,
  .p-letter-slider__next { width: 30px; height: 30px;  top: calc(50% - 30px);}
  .p-letter-slider__prev { right: 90%; }
  .p-letter-slider__next {  left: 90%;}
  .p-letter-slider__pagination { margin: 2rem 0; }
}

/*----------------------------
case
----------------------------*/
.p-home-case { padding: 100px 0 120px; background: #FFF; }

.p-home-case-head { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: center; max-width: 600px; margin: 0 auto; }
.p-home-case-info { border-top: 1px solid #CFD1C7; table-layout: fixed; width: 100%;}
.p-home-case-info tr { border-bottom: 1px solid #CFD1C7; }
.p-home-case-info th { background: #E5EFCB; padding: .5em 1em; }
.p-home-case-info td { padding: .5em 1em; }

@media screen and (max-width :768px) {
  .p-home-case { padding: 50px 0 60px; }
}
.p-case-calc { min-width: 850px; }
.p-case-calc__item { display: grid; grid-template-columns: 150px minmax(0, 1fr); gap: 1rem; padding: 2.5rem 0; align-items: center; }
.p-case-calc__item + .p-case-calc__item { border-top: 1px solid #DDDDDD;}

.p-case-calc__title { width: calc(100% - 10px); border-radius: 20px; display: flex; align-items: center; justify-content: center; color: #FFF; font-weight: bold; padding: 1em;text-align: center; position: relative; }
.p-case-calc__title::after { content: ''; width: 10px; height: 10px; background: inherit; position: absolute; left: 100%; top: 0; bottom: 0; margin: auto; clip-path: polygon(0 0, 100% 50%, 0 100%, 0 0); }
.p-case-calc__title.-green { background: #55A86C; }
.p-case-calc__title.-ygreen { background: #A4C74E; }
.p-case-calc__title.-red { background: #E67C8D; }


.p-case-calc__conts { font-size: 1.125rem; }
.p-case-timeplan { width: 100%; table-layout: fixed; }
.p-case-timeplan tr + tr { border-top: 1px dotted #DDDDDD; font-weight: bold; }
.p-case-timeplan th { text-align: center; padding-bottom: 1em; position: relative; padding-right: 1em; }
.p-case-timeplan th:first-child { width: 45%; }
.p-case-timeplan td { text-align: center; padding-top: 1em; position: relative; padding-right: 1em; }


.p-case-timeplan th:nth-child(-n +2)::after,
.p-case-timeplan td:nth-child(-n +2)::after { content: '×'; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; height: 1em; line-height: 1;  }
.p-case-timeplan th:nth-child(3)::after,
.p-case-timeplan td:nth-child(3)::after { content: '='; position: absolute; right: 0; top: 0; bottom: 0; margin: auto; height: 1em; line-height: 1; }
.p-case-timeplan th:nth-child(n)::after { bottom: 1em; }
.p-case-timeplan td:nth-child(n)::after { top: 1em; }

.p-case-calc__actual-cost { padding: 1em; font-size: 1rem; display: inline-block; }
 
.p-case-total { width: 100%; table-layout: fixed; }
.p-case-total tr + tr { border-top: 1px dotted #DDDDDD; font-weight: bold; }
.p-case-total th { text-align: center; padding-bottom: 1em; position: relative; padding-right: 1em; }
.p-case-total td { text-align: center; padding-top: 1em; position: relative; padding-right: 1em; }
.p-case-total th:first-child::after,
.p-case-total td:first-child::after { content: '+'; position: absolute; top: 0; right: 0; bottom: 0; margin: auto; height: 1em; line-height: 1; color: #333; }
.p-case-total th:nth-child(2)::after,
.p-case-total td:nth-child(2)::after { content: '='; position: absolute; top: 0; right: 0; bottom: 0; margin: auto; height: 1em; line-height: 1; color: #333; }
.p-case-total th:nth-child(n)::after { bottom: 1em; }
.p-case-total td:nth-child(n)::after { top: 1em; }

.p-case-timeline__title { text-align: center; color: #55A86C; font-weight: bold; font-size: 1.25rem; padding: 1em 0; border-top: 3px solid ; border-bottom: 3px solid ; position: relative; margin-top: 5rem; cursor: pointer; transition: background .3s; }
.p-case-timeline__title::after { content: ''; width: 1em; height: 1em; display: block; position: absolute; right: 1em;top: 0; bottom: 0; margin: auto; border-right: 3px solid; border-bottom: 3px solid; transform: rotate(45deg) translateY(-25%); transition: transform .3s;  }
.p-case-timeline__title.open { background: #55A86C; color: #FFF; }
.p-case-timeline__title.open::after { transform: rotate(225deg) translateY(-25%); }

.p-case-timeline__detail { display: none; }
.p-case-timeline { display: grid; grid-template-columns: 80px minmax(0, 1fr); gap: 20px 15px; max-width: 820px; margin: 0 auto; align-items: center; position: relative; z-index: 2; margin-top: 55px;  }
.p-case-timeline__time { background: #A4C74E; color: #FFF; text-align: center; border-radius: 8px; padding: .7em; }
.p-case-timeline::before { content: ''; width:1px; height: 100%; position: absolute; left: 40px; top: 0; margin: auto; z-index: -1; background: #55A86C; display: block; }

@media screen and (max-width :900px) {
  .p-case-calc { min-width: 750px; }
  .p-case-calc__conts { font-size: 1rem; }
  .p-case-timeline__title { font-size: 1rem; }
  .p-case-calc__item { grid-template-columns: 120px minmax(0, 1fr); }
  .p-case-calc__title { padding: 1em .5em; }
}

@media screen and (max-width :768px) {
  .p-home-case-head { grid-template-columns: 1fr; }
  .p-home-case-head__img { text-align: center; margin-bottom: 1em; }
}
/*----------------------------
flow
----------------------------*/
.p-home-flow-list { position: relative; max-width: 900px; margin: 0 auto; counter-reset: listnum; }
.p-home-flow-list::before { content: ''; width: 3px; height: 100%; background: #55A86C;  display: block; position: absolute; top: 0; left: 0; right: 0; margin: auto; z-index: -1; }
.p-home-flow-list__item { background: #FFF; border-radius:50px; padding: 2rem 3.5rem; box-shadow: 10px 10px 30px rgba(197, 213, 183, .25); position: relative; display: grid; grid-template-columns: minmax(0, 1fr) 90px; gap: 40px; align-items: center; counter-increment: listnum;}
.p-home-flow-list__item + .p-home-flow-list__item { margin-top: 20px;  }

.p-home-flow-list__title { font-weight: bold; margin-bottom: 1em; }
.p-home-flow-list__text { padding-left: 120px; position: relative; }
.p-home-flow-list__text::before { content: counter(listnum, decimal-leading-zero); font-family: 'Montserrat',sans-serif; font-weight: 200; font-size: 4rem; position: absolute; line-height: 1; height: 1em; position: absolute; left: 0; top: 0; bottom: 0; margin: auto; text-align: center; color: #55A86C; }
.p-home-flow-list__item:nth-child(2n) .p-home-flow-list__text::before { color: #A4C74E; }


@media screen and (max-width :768px) {
  .p-home-flow-list__item { border-radius: 25px; padding:2rem  1.5rem; gap: 1rem; align-items: flex-start; }
  .p-home-flow-list__text { padding-left: 0; }
  .p-home-flow-list__text::before { top: -.3em; bottom: auto; left: -.2em; opacity: .4; line-height: 1; height: 1em;  }
  .p-home-flow-list__title { padding-left: 2em; z-index: 2; position: relative; }  
}


.js-inview-conts { opacity: 0;transform: translateY(20px); transition: opacity .5s .2s, transform .5s .2s; }
.js-inview-conts.inview { opacity: 1; transform: translateY(0); }

/*----------------------------
company
----------------------------*/

/* 会社概要ページ用セクション */
/* .s_price .w900 {
  padding: 100px 0;
} */

/* 会社概要テーブル */
.company-table-wrapper table {
  width: 100%;
  border-collapse: collapse;
  margin: 2rem 0;
  background: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  overflow: hidden;
}

.company-table-wrapper table td {
  padding: 1.5rem 2rem;
  border-bottom: 1px solid #e5e5e5;
  vertical-align: middle;
}

.company-table-wrapper table tr:last-child td {
  border-bottom: none;
}

.company-table-wrapper table td:first-child {
  background: #f8f9fa;
  font-weight: bold;
  color: #333;
  width: 30%;
  min-width: 150px;
  text-align: center;
}

.company-table-wrapper table td:last-child {
  background: #fff;
  color: #555;
}

.company-table-wrapper table tr:hover {
  background: #f5f5f5;
}

.company-table-wrapper table tr:hover td:first-child {
  background: #eeeeee;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .company-table-wrapper table td {
    padding: 1rem;
    font-size: 0.9rem;
  }
  
  .company-table-wrapper table td:first-child {
    width: 35%;
    min-width: 120px;
  }
}

@media screen and (max-width: 480px) {
  .company-table-wrapper table {
    font-size: 0.85rem;
  }
  
  .company-table-wrapper table td {
    padding: 0.8rem;
  }
  
  .company-table-wrapper table td:first-child {
    width: 40%;
    min-width: 100px;
  }
}

/* Google Map */
.location-map-wrapper {
  text-align: center;
  margin: 2rem 0;
}

.location-map-wrapper iframe {
  max-width: 100%;
  height: 450px;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .location-map-wrapper iframe {
    width: 100%;
    height: 300px;
  }
}

@media screen and (max-width: 480px) {
  .location-map-wrapper iframe {
    height: 250px;
  }
}

/*----------------------------
representative-introduction
----------------------------*/

/* 代表紹介ページ用セクション */
.s_price .w900 {
  padding: 100px 0;
}

/* 代表紹介コンテンツ */
.representative-content {
  max-width: 800px;
  margin: 0 auto;
}

.representative-profile {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 3rem;
  align-items: flex-start;
  background: #fff;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.representative-image {
  text-align: center;
}

.representative-image img {
  width: 100%;
  max-width: 280px;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
}

.representative-text {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.representative-name {
  font-size: 1.5rem;
  font-weight: bold;
  color: #55A86C;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #55A86C;
}

.representative-story {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

.representative-story p {
  font-size: 1rem;
  line-height: 1.8;
  color: #333;
  text-align: justify;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .representative-profile {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 2rem 1.5rem;
  }
  
  .representative-image {
    order: -1;
  }
  
  .representative-image img {
    max-width: 200px;
  }
  
  .representative-name {
    font-size: 1.3rem;
    text-align: center;
  }
  
  .representative-story p {
    font-size: 0.95rem;
    line-height: 1.7;
  }
}

@media screen and (max-width: 480px) {
  .representative-content {
    margin: 0 1rem;
  }
  
  .representative-profile {
    padding: 1.5rem 1rem;
  }
  
  .representative-image img {
    max-width: 160px;
  }
  
  .representative-name {
    font-size: 1.2rem;
  }
  
  .representative-story p {
    font-size: 0.9rem;
    line-height: 1.6;
  }
}

/*----------------------------
access
----------------------------*/

/* アクセス情報リスト */
.access-location-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.access-location-item {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

.access-info {
  padding: 2rem;
  background: #f8f9fa;
}

.location-name {
  font-size: 1.5rem;
  font-weight: bold;
  color: #55A86C;
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #55A86C;
}

.location-details {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.detail-item {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 1rem;
  align-items: flex-start;
}

.detail-label {
  font-weight: bold;
  color: #fff;
  font-size: 0.9rem;
  background: #4CAF50;
  padding: 0.5rem;
  border-radius: 4px;
  text-align: center;
}

.detail-values {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.detail-value {
  font-size: 1rem;
  color: #333;
  line-height: 1.6;
  padding: 0.25rem 0;
}

.access-map {
  height: 300px;
  overflow: hidden;
}

.access-map iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .access-info {
    padding: 1.5rem;
  }
  
  .location-name {
    font-size: 1.3rem;
  }
  
  .detail-item {
    grid-template-columns: 70px 1fr;
    gap: 0.8rem;
  }
  
  .detail-label {
    font-size: 0.8rem;
  }
  
  .detail-value {
    font-size: 0.9rem;
  }
  
  .access-map {
    height: 250px;
  }
}

@media screen and (max-width: 480px) {
  .access-info {
    padding: 1rem;
  }
  
  .location-name {
    font-size: 1.2rem;
  }
  
  .detail-item {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
  
  .detail-label {
    justify-self: start;
    width: fit-content;
    margin-bottom: 0.5rem;
  }
  
  .detail-values {
    margin-left: 0;
  }
  
  .access-map {
    height: 200px;
  }
}

/*----------------------------
contact
----------------------------*/

/* お問い合わせコンテンツ */
.contact-content {
  max-width: 800px;
  margin: 0 auto;
}

.contact-intro {
  text-align: center;
  margin-bottom: 3rem;
}

.contact-intro .desc {
  font-size: 1rem;
  line-height: 1.8;
  color: #555;
  margin-bottom: 1rem;
}

/* セクション共通 */
.contact-line-section,
.contact-form-section {
  background: #fff;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  margin-bottom: 2rem;
}

.contact-section-title {
  font-size: 1.5rem;
  font-weight: bold;
  color: #55A86C;
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid #55A86C;
  text-align: center;
}

.contact-section-desc {
  font-size: 1rem;
  line-height: 1.6;
  color: #666;
  text-align: center;
  margin-bottom: 2rem;
}

/* LINEボタン */
.line-add-button {
  text-align: center;
}

.btn-line {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: #06C755;
  color: #fff;
  padding: 1rem 2rem;
  border-radius: 25px;
  text-decoration: none;
  font-weight: bold;
  font-size: 1.1rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(6, 199, 85, 0.3);
}

.btn-line:hover {
  background: #05B34A;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(6, 199, 85, 0.4);
}

.line-icon {
  width: 24px;
  height: 24px;
}

/* フォーム */
.contact-form {
  max-width: 600px;
  margin: 0 auto;
}

.form-row {
  margin-bottom: 1.5rem;
}

.form-label {
  display: block;
  font-weight: bold;
  color: #333;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.required {
  color: #e74c3c;
  font-weight: bold;
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid #e5e5e5;
  border-radius: 6px;
  font-size: 1rem;
  transition: border-color 0.3s ease;
  box-sizing: border-box;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: #55A86C;
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
}

.form-checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  cursor: pointer;
}

.form-checkbox {
  margin-top: 0.25rem;
}

.checkbox-text {
  font-size: 0.9rem;
  line-height: 1.5;
}

.checkbox-text a {
  color: #55A86C;
  text-decoration: underline;
}

.checkbox-text a:hover {
  color: #3d7a4f;
}

.form-submit {
  text-align: center;
  margin-top: 2rem;
}

.btn-submit {
  background: #55A86C;
  color: #fff;
  padding: 1rem 3rem;
  border: none;
  border-radius: 25px;
  font-size: 1.1rem;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(85, 168, 108, 0.3);
}

.btn-submit:hover {
  background: #3d7a4f;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(85, 168, 108, 0.4);
}

/* レスポンシブ対応 */
@media screen and (max-width: 768px) {
  .contact-line-section,
  .contact-form-section {
    padding: 2rem 1.5rem;
  }
  
  .contact-section-title {
    font-size: 1.3rem;
  }
  
  .btn-line {
    padding: 0.875rem 1.5rem;
    font-size: 1rem;
  }
  
  .form-input,
  .form-select,
  .form-textarea {
    padding: 0.625rem;
    font-size: 0.9rem;
  }
  
  .btn-submit {
    padding: 0.875rem 2.5rem;
    font-size: 1rem;
  }
}

@media screen and (max-width: 480px) {
  .contact-content {
    margin: 0 1rem;
  }
  
  .contact-line-section,
  .contact-form-section {
    padding: 1.5rem 1rem;
  }
  
  .contact-section-title {
    font-size: 1.2rem;
  }
  
  .contact-section-desc {
    font-size: 0.9rem;
  }
  
  .btn-line {
    padding: 0.75rem 1.25rem;
    font-size: 0.9rem;
  }
  
  .btn-submit {
    padding: 0.75rem 2rem;
    font-size: 0.9rem;
  }
}

/* ========================================
   Thanks Page
======================================== */
.thanks-content {
  max-width: 600px;
  margin: 0 auto;
  padding: 40px 20px;
  text-align: center;
}

.thanks-message {
  margin-bottom: 40px;
}

.thanks-text {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 15px;
  color: #333;
}

.thanks-text:last-child {
  margin-bottom: 0;
}

.contact-info-table {
  margin: 40px 0;
}

.thanks-table {
  width: 100%;
  border-collapse: collapse;
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  overflow: hidden;
}

.thanks-table tr {
  border-bottom: 1px solid #eee;
}

.thanks-table tr:last-child {
  border-bottom: none;
}

.thanks-table td {
  padding: 20px;
  vertical-align: middle;
}

.info-label {
  background-color: #55A86C;
  color: white;
  font-weight: bold;
  width: 140px;
  text-align: center;
  font-size: 14px;
}

.info-value {
  background-color: #fff;
  text-align: left;
  padding-left: 30px;
}

.info-value a {
  color: #55A86C;
  text-decoration: none;
  font-size: 16px;
  font-weight: bold;
}

.info-value a:hover {
  text-decoration: underline;
}

.thanks-back-link {
  margin-top: 40px;
}

.btn-back {
  display: inline-block;
  background-color: #55A86C;
  color: white;
  padding: 15px 30px;
  border-radius: 30px;
  text-decoration: none;
  font-weight: bold;
  font-size: 16px;
  transition: all 0.3s ease;
}

.btn-back:hover {
  background-color: #4a9460;
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(85, 168, 108, 0.3);
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .thanks-content {
    padding: 30px 15px;
  }
  
  .thanks-text {
    font-size: 14px;
  }
  
  .thanks-table td {
    padding: 15px 10px;
  }
  
  .info-label {
    width: 120px;
    font-size: 12px;
  }
  
  .info-value {
    padding-left: 15px;
  }
  
  .info-value a {
    font-size: 14px;
  }
  
  .btn-back {
    padding: 12px 25px;
    font-size: 14px;
  }
}

@media (max-width: 480px) {
  .thanks-table {
    font-size: 14px;
  }
  
  .info-label {
    width: 100px;
    font-size: 11px;
  }
  
  .info-value {
    padding-left: 10px;
  }
  
  .info-value a {
    font-size: 13px;
  }
}

/* 初回割引キャンペーンページ専用スタイル */

/* LINE公式アカウント追加セクション */
.line-account-section {
  text-align: center;
  padding: 40px 20px;
  background: #f8f9fa;
  border-radius: 10px;
  margin-top: 30px;
}

.line-account-description {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
  margin-bottom: 30px;
}

.line-button-container {
  margin-bottom: 20px;
}

.line-icon {
  width: 24px;
  height: 24px;
  margin-right: 10px;
  filter: brightness(0) invert(1);
}

.line-button-text {
  font-family: "Noto Sans JP", sans-serif;
}

.line-note {
  font-size: 14px;
  color: #666;
  margin-top: 15px;
}

/* キャンペーン内容セクション */
.campaign-header {
  background: linear-gradient(135deg, #2c5530, #3a6b3f);
  color: white;
  padding: 20px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

/* キャンペーン適用フローセクション */
.campaign-flow {
  margin-top: 30px;
}

.flow-steps {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 50px;
  flex-wrap: wrap;
  gap: 20px;
}

.flow-step {
  flex: 1;
  max-width: 280px;
  text-align: center;
  background: white;
  padding: 30px 20px;
  border-radius: 15px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
}

.flow-step:hover {
  transform: translateY(-5px);
}

.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, #2c5530, #3a6b3f);
  color: white;
  border-radius: 50%;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}

.step-image {
  margin-bottom: 20px;
}

.flow-img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 10px;
  border: 3px solid #e8f5e8;
}

.step-title {
  font-size: 16px;
  font-weight: bold;
  color: #2c5530;
  margin-bottom: 15px;
  line-height: 1.4;
}

.step-description {
  font-size: 14px;
  line-height: 1.6;
  color: #666;
}

.flow-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 10px;
}

.arrow-icon {
  width: 30px;
  height: 30px;
  filter: hue-rotate(90deg);
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .flow-steps {
    flex-direction: column;
    align-items: center;
  }
  
  .flow-step {
    max-width: 100%;
    margin-bottom: 30px;
  }
  
  .flow-arrow {
    transform: rotate(90deg);
    margin: 15px 0;
  }
  
  .arrow-icon {
    width: 25px;
    height: 25px;
  }
  
  .campaign-details-table {
    font-size: 14px;
  }
  
  .campaign-item {
    width: 30%;
    padding: 15px 10px;
  }
  
  .campaign-content {
    padding: 15px;
  }
}

@media (max-width: 480px) {
  .line-account-section {
    padding: 30px 15px;
  }
  
  .flow-step {
    padding: 25px 15px;
  }
  
  .campaign-item {
    display: block;
    width: 100%;
    text-align: left;
    background: #2c5530;
    color: white;
  }
  
  .campaign-content {
    display: block;
    width: 100%;
  }
  
  .campaign-details-table,
  .campaign-details-table tbody,
  .campaign-details-table tr,
  .campaign-details-table td {
    display: block;
  }
  
  .campaign-details-table tr {
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
  }
  
  .campaign-header {
    display: none;
  }
}

/* キャンペーン内容セクション */
.campaign-details {
  margin-top: 30px;
}

.campaign-table {
  background: white;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.campaign-details-table {
  width: 100%;
  border-collapse: collapse;
}

.campaign-header {
  background: linear-gradient(135deg, #2c5530, #3a6b3f);
  color: white;
  padding: 20px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
}

.campaign-details-table tr:nth-child(even) {
  background: #f8f9fa;
}

.campaign-item {
  background: #e8f5e8;
  padding: 20px;
  font-weight: bold;
  width: 25%;
  text-align: center;
  vertical-align: top;
  border-bottom: 1px solid #ddd;
}

.campaign-content {
  padding: 20px;
  line-height: 1.8;
  border-bottom: 1px solid #ddd;
}

.discount-highlight {
  color: #e74c3c;
  font-size: 1.2em;
  font-weight: bold;
  background: linear-gradient(135deg, #fff3cd, #ffeaa7);
  padding: 2px 8px;
  border-radius: 5px;
  border: 2px solid #e74c3c;
}

/* キャンペーン適用フローセクション - 縦長スマホスクリーンショット対応 */
.campaign-flow {
  margin-top: 30px;
}

.flow-steps {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 50px;
  flex-wrap: wrap;
  gap: 20px;
}

.flow-step {
  flex: 1;
  max-width: 300px;
  text-align: center;
  background: white;
  padding: 30px 20px;
  border-radius: 15px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  transition: transform 0.3s ease;
}

.flow-step:hover {
  transform: translateY(-5px);
}

.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, #2c5530, #3a6b3f);
  color: white;
  border-radius: 50%;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
}

.step-image {
  margin-bottom: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 縦長スマホスクリーンショット用のスタイル */
.flow-img {
  width: auto;
  height: 250px;
  max-width: 150px;
  object-fit: contain;
  border-radius: 15px;
  border: 3px solid #e8f5e8;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  background: #fafafa;
}

.step-title {
  font-size: 16px;
  font-weight: bold;
  color: #2c5530;
  margin-bottom: 15px;
  line-height: 1.4;
}

.step-description {
  font-size: 14px;
  line-height: 1.6;
  color: #666;
}

.flow-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 10px;
  align-self: center;
}

.arrow-icon {
  width: 30px;
  height: 30px;
  filter: hue-rotate(90deg);
}

/* レスポンシブ対応 */
@media (max-width: 1024px) {
  .flow-steps {
    gap: 15px;
  }
  
  .flow-step {
    max-width: 280px;
  }
  
  .flow-img {
    height: 220px;
    max-width: 130px;
  }
}

@media (max-width: 768px) {
  .flow-steps {
    flex-direction: column;
    align-items: center;
  }
  
  .flow-step {
    max-width: 100%;
    margin-bottom: 30px;
    padding: 25px 15px;
  }
  
  .flow-arrow {
    transform: rotate(90deg);
    margin: 15px 0;
    align-self: center;
  }
  
  .arrow-icon {
    width: 25px;
    height: 25px;
  }
  
  .flow-img {
    height: 280px;
    max-width: 170px;
    border-radius: 12px;
  }
  
  .campaign-details-table {
    font-size: 14px;
  }
  
  .campaign-item {
    width: 30%;
    padding: 15px 10px;
  }
  
  .campaign-content {
    padding: 15px;
  }
  
  .line-account-section {
    padding: 30px 15px;
  }
}

@media (max-width: 480px) {
  .flow-step {
    padding: 20px 15px;
  }
  
  .flow-img {
    height: 240px;
    max-width: 140px;
    border-radius: 10px;
  }
  
  .campaign-item {
    display: block;
    width: 100%;
    text-align: left;
    background: #2c5530;
    color: white;
  }
  
  .campaign-content {
    display: block;
    width: 100%;
  }
  
  .campaign-details-table,
  .campaign-details-table tbody,
  .campaign-details-table tr,
  .campaign-details-table tr td {
    display: block;
  }
  
  .campaign-details-table tr {
    margin-bottom: 15px;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
  }
  
  .campaign-header {
    display: none;
  }
}
