/* FV Styles ==============================================*/
.fv {
    position: relative;
    min-height: 100vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.fv-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}

.fv-background-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.fv-background::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.fv-container {
    position: relative;
    z-index: 1;
    margin: -5rem auto 0;
    padding: 0 8vw 0 12vw;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.fv-content {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 0.5rem;
    position: relative;
}
.fv-text {
    width: 50vw;
}

.fv-subtitle {
    color: var(--white);
    font-family: var(--font-noto-sans-cjk-jp);
    font-size: 2.125rem;
    font-style: normal;
    font-weight: 350;
    line-height: 2.8125rem;
    letter-spacing: 0.02125rem;
    margin-bottom: 2rem;
    text-shadow: 0 1.503px 8.018px rgba(9, 55, 149, 0.25);
    opacity: 0;
    animation: fadeInUp 0.8s ease-out 0.5s forwards;
}
.fv-title {
    color: var(--white);
    font-family: var(--font-noto-sans-cjk-jp);
    font-size: 5.47738rem;
    font-style: normal;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: -0.05475rem;
    margin: 0;
    text-shadow: 0 2.565px 13.683px rgba(9, 55, 149, 0.25);
    animation: fadeInUp 0.8s ease-out 0.9s forwards;
    opacity: 0;
}
@keyframes fadeInUp {
  from {
      opacity: 0;
      transform: translateY(30px);
  }
  to {
      opacity: 1;
      transform: translateY(0);
  }
}

/* .fv-title-main {
    background: linear-gradient(90deg, #08A7F5 0%, #0297E0 37.5%, #1672D6 73.08%, #0E46B5 100%);
    padding: 0 1.5rem;
    display: inline-block;
    margin-bottom: 0.85rem;
} */

.fv-image {
  width: 34vw;
  height: 60vh;
  object-fit: cover;
}

.fv-watermark {
    position: absolute;
    bottom: -6.5%;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10.67356rem;
    font-weight: 900;
    color: var(--white);
    letter-spacing: 0.1em;
    white-space: nowrap;
    pointer-events: none;
    font-family: var(--font-saira-condensed);
    font-style: italic;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: 0.32019rem;
    opacity: 0.2;
    mix-blend-mode: lighten;
}
@media screen and (min-width: 1900px) {
  .fv-text {
    margin-top: 5rem;
  }
}
@media screen and (max-width: 1800px) {
  .fv-container {
    padding: 0 5vw 0 10vw;
    margin: -5rem auto 0;
  }
  .fv-title {
    font-size: 4.52325rem;
  }
}
@media screen and (max-width: 1500px) {
  .fv-container {
    padding: 0 3vw 0 6vw;
    margin: 0rem auto 0;
  }
  .fv-title {
    font-size: 4rem;
  }
.fv-image {
  width: 30vw;
}
.fv-text {
  width: 60%;
}

.fv-subtitle {
  font-size: 1.8rem;
  line-height: 2.2rem;
}

.fv-watermark {
  font-size: 8rem;
  bottom: -6%;
}
}
@media screen and (max-width: 1200px) {
  .fv {
    padding-top: 3.43rem;
}
  .fv-content {
    flex-direction: column;
}
  .fv-title {
    font-size: 4.12325rem;
  }
}
@media (max-width: 1024px) {
  .fv-container {
    padding: 0 2.5rem;
    margin-top: 5rem;
  }
    .fv-text {
      width: 100%;
    }
    .fv-image {
      width: 65%;
    }
    .fv-watermark {
      font-size: 5.83088rem;
      bottom: -3%;
    }
    .fv-background-image.pc-tab-only {
      object-fit: cover;
      object-position: top;
    }
}

  @media (max-width: 768px) {
    .fv {
      padding: var(--section-padding-mobile);
    }
    .fv-container {
      padding: 0 2rem;
      margin-top: 54.88px;
    }

    .fv-content {
      margin-top: 3.81rem;
      flex-direction: column-reverse;
      gap: 0.5rem;
      text-align: center;
    }
    /* .fv-title-main {
      margin-bottom: 0.5rem;
    } */
    .fv-text {
      order: 1;
      text-align: left;
      max-width: 100%;
      flex: 1;
      margin-top: 0;
    }
    .fv-image {
      width: 100%;
    }

    .fv-title {
      font-size: 2.91569rem;
    }

  
    .fv-subtitle {
      font-size: 1.1875rem;
      font-weight: 350;
      line-height: 1.625rem;
      letter-spacing: 0.01313rem;
      margin-bottom: 1rem;
    }

    .fv-watermark {
      font-size: 5.83088rem;
      bottom: -4%;
    }
}

/* @media (max-width: 480px) {
    .fv-title-main {
        padding: 0.2rem 1rem;
    }
} */

/* Problem Section Styles ================================*/
.problem {
    position: relative;
    background-color: #f3f3f3;
    overflow: hidden;
}

.problem-container {
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2rem;
    z-index: 2;
}

.problem-content {
    position: relative;
    min-height: 500px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-top: 2rem;
}

.problem-bubbles {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.19rem;
    width: 100%;
    max-width: 1100px;
    position: relative;
    z-index: 3;
}

.bubble {
    position: relative;
    background: white;
    border-radius: 1.0625rem;
    padding: 2.2rem 2rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    width: 22.125rem;
}

.bubble::after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
}
.bubble-left {
    margin: 15% 0 10%;
}
.bubble-left::after {
    bottom: -20px;
    left: 70%;
    border-width: 1.5rem 0rem 0rem 2rem;
    border-color: white transparent transparent transparent;
}

.bubble-center {
    margin: -15% 0 30%;
}

.bubble-center::after {
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    border-width: 20px 15px 0 15px;
    border-color: white transparent transparent transparent;
}

.bubble-right {
    margin: 15% 0 10%;
}
.bubble-right::after {
    bottom: -20px;
    right: 70%;
    border-width: 1.5rem 2rem 0rem 0rem;
    border-color: white transparent transparent transparent;
}


.bubble-content {
    text-align: center;
}

.bubble-title {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--primary-blue);
    margin-bottom: 1rem;
    line-height: 130%;
    letter-spacing: 0.01375rem;
    text-align: center;
}

.bubble-text {
    color: var(--black);
    font-size: 1.0625rem;
    font-weight: 400;
    line-height: 150%;
    letter-spacing: 0.02125rem;
    padding: 0 1.12rem;
}

.bubble-highlight {
    font-weight: 600;
}

.problem-character {
    z-index: 2;
    width: 11.375rem;
    height: 13.25rem;
    aspect-ratio: 91/106;
    overflow: hidden;
    margin: -8.5rem auto 0;
    /* margin: -4.5rem auto 0; */
}

.problem-character img {
    width: 100%;
    height: 100%;
}
@media screen and (max-width: 1200px) {
  .problem-bubbles-bottom {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.88rem;
    margin-top: 1.88rem;
  }

.problem-bubbles {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.19rem;
}
.bubble-left {
  margin: 0% 0 0% 0%;
}
.bubble-center {
  margin: 0% 0 0%;
}
.bubble-right {
  margin: 0% 0 0% 0%;
}

.problem-character {
  margin: 3rem auto 0 ;
}
.problem-content {
  margin-top: 5rem;
}
}

@media (max-width: 768px) {
    .problem-title {
        font-size: 1.5rem;
    }

    .bubble::after {
        display: none;
    }

    .bubble-left::after,
    .bubble-right::after {
        display: none;
    }

    .problem-content {
      margin-top: 3rem;
  }
  .problem-character {
    width: 9.375rem;
    height: 10.875rem;
  }
}

/* Solution Section Styles =====================================*/
.solution {
    position: relative;
    min-height: 700px;
    overflow: hidden;
}

.solution-background {
    position: absolute;
    top: -10px;
    left: 0;
    width: 100%;
    height: 102%;
    z-index: 0;
}

.solution-bg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.triangle-wrapper {
    position: relative;
    width: 100%;
    height: 10rem;
}

.triangle {
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    background: #f3f3f3;
    width: 100%;
    height: 10rem;
    margin-top: -1px;
}

.solution-container {
    position: relative;
    max-width: 1400px;
    margin: 0 auto;
    padding: 3.75rem 2rem 9rem;
    z-index: 2;
}

.solution-header {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
}

.solution-logo {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.solution-logo-icon {
    color: white;
    font-size: 1.5rem;
}

.solution-logo-image {
    height: 5.52175rem;
    width: auto;
    display: block;
}

.solution-title {
    font-size: 2rem;
    font-weight: 700;
    color: var(--black);
    line-height: 150%;
    letter-spacing: 0.04rem;
}

.solution-features {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
}

.solution-features-box {
    background: var(--blue-gradation);
    padding: 0rem 1.5rem;
    display: inline-block;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.3);
    clip-path: polygon(2.5% 0%, 100% 0%, 97.5% 100%, 0% 100%);
    width: fit-content;
    margin: 0 auto;
}

.solution-features-box-container {
  display: none;
  align-items: center;
  justify-content: center;
}
.solution-features-title {
    color: var(--white);
    text-align: center;
    text-shadow: 0 1.377px 7.349px rgba(9, 55, 149, 0.25);
    font-family: var(--font-noto-sans-cjk-jp);
    font-size: 2.37994rem;
    font-weight: 500;
    letter-spacing: -0.02381rem;
    padding-bottom: 0.25rem;
}

.solution-features-text {
    font-size: 1.0625rem;
    color: var(--black);
    line-height: 1.5;
    font-weight: 400;
    letter-spacing: 0.02125rem; 
    margin-top: 0.7rem;
}

.solution-chart {
    max-width: 768px;
    margin: 0 auto;
}

.solution-chart-content {
    margin-top: 2.5rem;
}

.solution-chart-image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
}

@media (max-width: 1024px) {
    .solution-features-text {
      font-weight: 600;
      }
}

@media (max-width: 768px) {
    .solution-container {
            padding: 3.16rem 25px 3.5rem;
    }
    .solution-logo-image {
        height: 3.8235rem;
    }

    .solution-title {
        font-size: 1.25rem;
    }
    .solution-features-box-container {
        display: flex;
        flex-direction: column;
    }
    .solution-features-box {
      width: fit-content;
      margin: 0 auto;
      padding: 0rem 1.3rem;
    }

    .solution-features-title {
      letter-spacing: 0.01rem;
        font-size: 1.875rem;
    }

    .solution-features-text {
        font-size: 1.0625rem;
        margin-top: 1.52rem;
    }

    .solution-chart-content {
        padding: 0;
        margin-top: 3.13rem;
    }
    .triangle-wrapper {
      height: 5rem;
    }
    .triangle {
      height: 5rem;
  }
}
@media screen and (max-width: 400px) {
.solution-title {
    font-size: 1rem;
}
}
/* Feature Section Styles =====================================*/
.feature {
    background: var(--pale-blue);
  }

  .feature-container {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    padding-bottom: 8.25rem;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

.feature-items {
    display: flex;
    flex-direction: column;
    gap: 5.5rem;
    margin-top: 5.5rem;
}

  .feature-item {
    display: flex;
    align-items: center;
    gap: 2.5rem;
  }

  .feature-item-02 {
    flex-direction: row-reverse;
    margin-left: 1rem;
  }
  
  .feature-content {
    position: relative;
    width: 41%;
}

.feature-number {
    font-family: var(--font-onest);
    font-size: 4.55013rem;
    font-style: italic;
    font-weight: 700;
    color: rgba(6, 71, 169, 0.40);
    line-height: 1.4;
    display: block;
}

/* .feature-heading {
    font-size: 2.125rem;
    font-weight: 700;
    line-height: 1.45;
    color: var(--primary-blue);
    background: white;
    padding: 0.48rem 0.63rem;
    display: inline;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
} */
/* .feature-items .feature-heading:nth-of-type(2) {
  padding-right: 0;
} */

/* .highlight-blue {
  font-size: 2.125rem;
  font-weight: 700;
  line-height: 1.45;
  background: var(--blue-gradation);
  color: var(--white);
  padding: 0.48rem 0.63rem;
  display: inline-block;
  position: relative;
  z-index: 1;
  display: inline;
} */

/* .feature-item-01 .feature-heading .highlight-blue {
  margin-right: 0;
} */
.feature-heading {
  font-size: 2.125rem;
  font-weight: 700;
  line-height: 1.1;
  color: var(--primary-blue);
  margin: 0;
}
.marker-align {
  display: inline-flex;
}

.feature-text {
    color: var(--black);
    font-family: var(--font-noto-sans);
    font-size: 1.0625rem;
    font-weight: 400;
    line-height: 150%;
    letter-spacing: 0.02125rem;
    margin-top: 2rem;
}

.feature-image {
    position: relative;
    width: 33.75rem;
    height: 21.875rem;
    overflow: hidden;
}

/* 背景色が敷かれるアニメーション用 */
.feature-image::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
    background-color: var(--primary-blue, #0647A9);
    transform-origin: left;
    transition: width 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.3s ease 0.3s;
    z-index: 3;
    pointer-events: none;
    transform: translateX(0);
}

/* 画面内に入った時のアニメーション状態 */
.feature-image.is-show::after {
    width: 100%;
    transform: translateX(100%);
}
.feature-item-01 .feature-image img {
    transform: scale(1.2) translate(20px, -10px);
}
.feature-item-02 .feature-image img {
    transform: scale(1.3) translate(0, 10px);
}
.feature-item-03 .feature-image img {
    transform: scale(1.5) translate(-35px, -7px);
}

.feature-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: relative;
    z-index: 1;
    opacity: 0;
    transition: opacity 0.1s ease;
    transition-delay: 0.3s;
}

/* 画面内に入った時の画像表示 */
.feature-image.is-show img {
    opacity: 1;
}

@media screen and (max-width: 1200px) {

  .feature-item {
    flex-direction: column;
    gap: 2.31rem;
  }
  .feature-content {
    width: 80%;
  }
  .feature-image {
    width: 35.125rem;
    height: 22.125rem;
  }
/* 
  .feature-number {
    font-size: 3.8rem;
  }

  .feature-heading {
    font-size: 24px;
  } */
}
@media screen and (max-width: 1024px) {
  .feature-container {
    padding: 0rem 0 8.75rem;
  }
  .feature-heading .highlight-blue {
    padding: 0.2rem 0.63rem;
  }
  .feature-text {
    margin-top: 1.25rem;
  }
}
@media screen and (max-width: 768px) {
  .feature-container {
    padding: 4.31rem 1.56rem 5rem;
  }

  .feature-title {
    font-size: 1.75rem;
  }

  .feature-items {
    margin-top: 3.5rem;
    gap: 3.5rem;
  }
  .feature-item-02 {
    margin-left: 0;
  }

  .feature-content {
    width: 100%;
  }

  .feature-image {
    width: 100%;
    height: 13.8125rem;
  }

  .feature-number {
    font-size: 3.5rem;
  }

  .feature-heading {
    font-size: 1.625rem;
  }
  .highlight-blue {
    font-size: 1.625rem;
  }
  .feature-text {
    font-size: 1.0625rem;
    margin-top: 1.25rem;
    line-height: 170%;
  }
}
/* Contact Section Styles =====================================*/

.contact {
    position: relative;
    padding: 6rem 4.69rem 4.5rem;
    text-align: center;
    overflow: hidden;
}

.contact::before,
.contact::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    width: 50%;
    background-image: url('https://www.e-value.jp/environmental-consulting/mega-solar-support/wordpress/wp-content/themes/mega-solar/src/assets/contact-bg.webp');
    background-size: cover;
    background-position: center;
    z-index: 0;
}

.contact::before {
    left: 0;
    background-position: left center;
}

.contact::after {
    right: 0;
    background-position: right 15% center;
}
  
  .contact-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 25, 56, 0.75);
    z-index: 1;
  }
  
  .contact-container {
    position: relative;
    z-index: 2;
  }
  
  .contact-content {
    max-width: 800px;
    margin: 0 auto;
  }

  .contact-button {
    display: inline-block;
    color: var(--white);
    font-size: 18px;
    font-weight: 500;
    padding: 18px 48px;
    border-radius: 50px;
    text-decoration: none;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    margin-top: 3.19rem;
  }

/* Responsive Styles */
@media screen and (max-width: 1400px) {
  .contact {
    padding: 5rem 2.69rem 3rem;
  }

.contact-title {
    font-size: 1.5rem;
  }

#contact .contact-button {
    margin-top: 2rem;
}

#contact .phone-number {
  margin-top: 1.25rem;
}
}
@media screen and (max-width: 1200px) {
  .contact {
    padding: 4.75rem 2.69rem 3rem;
  }
}

  @media screen and (max-width: 768px) {
    .contact {
      width: 100%;
      height: auto;
      background-image: url('https://www.e-value.jp/environmental-consulting/mega-solar-support/wordpress/wp-content/themes/mega-solar/src/assets/contact-bg-tabSp.webp');
      padding: 5.3rem 2rem 3.75rem;
    }
    .contact::before,
    .contact::after {
  background-image: url('https://www.e-value.jp/environmental-consulting/mega-solar-support/wordpress/wp-content/themes/mega-solar/src/assets/contact-bg-tabSp.webp');
}
    .contact::before {
      background-position: 0% center;
    }
    .contact::after {
      background-position: 90% center;
    }
    #contact .contact-button {
      width:17.0625rem
  }  
    #contact .phone-text {
      font-size: 2.0325rem;
      text-decoration: none;
    }
    #contact .phone-hours {
      font-size: 0.88925rem;
    }
  }

  /* Forecast Section =====================================*/
.forecast {
    position: relative;
    background: #f3f3f3;
    overflow: hidden;
  }
  .forecast-container {
    padding: 0 10vw;
  }

  .forecast-header {
    text-align: center;
  }
  
  .forecast-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--black);    
  }
  
  .forecast-subtitle {
    font-size: 1.0625rem;
    color: var(--black);
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.02125rem;
    margin-top: 4.88rem;
}

.forecast-highlight-container {
    display: block;
    background: var(--white);
    padding: 0rem 0.62rem;
    width: 100%;
    width: fit-content;
    margin: .87rem auto 0;
    text-align: center;
}

.forecast-highlight {
    font-size: 1.75rem;
    font-style: normal;
    font-weight: 700;
    line-height: 140%; /* 2.45rem */
    vertical-align: middle;
    border-radius: 8px;
    display: inline-block;
    background-image: var(--blue-gradation);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
    position: relative;
    padding-bottom: 0.15rem;
  }

.solution-card .forecast-highlight-container:nth-of-type(3),
.solution-card .forecast-highlight-container:nth-of-type(4),
.solution-card .forecast-highlight-container:nth-of-type(5) {
    margin: 0 auto 0 !important;
}
.solution-card .forecast-highlight-container:nth-of-type(2) {
    margin: 1 auto 0 !important;
}

.forecast-content {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  
  .forecast-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  
  .forecast-tab {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: 0.75rem;
    font-size: 1.375rem;
    font-family: var(--font-noto-sans);
    font-weight: 700;
    color: var(--black);
    margin: 5rem auto 0;
    width: 100%;
}

.forecast-chart-container {
    margin-top: 1.25rem;
}

.forecast-chart-image-01 {
    width: 47.875rem;
}

.forecast-chart-image-02 {
    width: 68.6875rem;
}

.tab-label {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--blue-gradation);
    color: white;
    padding: 0.25rem 0.62rem 0.2rem;
    border-radius: 25px;
    font-size: 1rem;
    font-weight: 700;
    letter-spacing: 0.5px;
    /* text-transform: uppercase; */
    font-family: var(--font-saira-condensed);
    line-height: 140%;
}

.forecast-chart-image {
    width: 100%;
    height: auto;
    display: block;
}


.forecast-description {
    font-size: 1.0625rem;
    line-height: 1.5;
    font-weight: 400;
    letter-spacing: 0.02125rem;
    color: var(--black);
    text-align: center;
    margin-top: 1.87rem;
}

.forecast-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-bottom: 30px;
}

.forecast-card {
    background: white;
    border-radius: 12px;
    padding: 30px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    position: relative;
    overflow: hidden;
  }
  
  
  .forecast-warning {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.44rem;
    margin-top: 3.12rem;
    }
  
  .warning-icon {
    width: 4.43781rem;
    height: 4.43781rem;
  }

  .warning-text {
    text-align: center;
    font-size: 1.0625rem;
    font-weight: 700;
    line-height: 150%;
    letter-spacing: 0.02125rem;
    color: var(--black);
  }

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

.forecast-wave {
    position: relative;
    width: 100%;
    height: 10rem;
    background: #DCE6F4;
}
.forecast-wave-inner {
    position: relative;
    width: 100%;
    height: 10rem;
    background: var(--gray);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
}

.forecast-solution {
    position: relative;
    background: #DCE6F4;;
    padding: 3rem 10vw 12.25rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

.solution-cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    max-width: 1080px;
    gap: 30px;
    margin-top: 1.25rem;
}
  
  .solution-card {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0;
    overflow: visible;
  }
  
  .solution-number {
    position: absolute;
    top: 1.25rem;
    left: 0.75rem;
    width: 100%;
    font-size: 3.3rem;
    font-family: var(--font-onest);
    font-style: italic;
    font-weight: 700;
    line-height: 1;
    z-index: 2;
    opacity: 0.5;
background: var(--blue-gradation);
background-clip: text;
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
mix-blend-mode: multiply;
  }
  
  .solution-image-wrapper {
    position: relative;
    width: 28.125rem;
    height: 16.3125rem;
    overflow: hidden;
  }
  
  .solution-bg-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

.solution-text {
    padding: 20px 24px;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.6;
    color: #2C3E50;
    text-align: center;
    background: white;
    border-radius: 8px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    position: relative;
    z-index: 2;
  }
  
  .solution-text .text-blue {
    color: #0647A9;
  }
  
  .solution-text .text-orange {
    color: #FF8A00;
  }
  
  .solution-arrow {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 30px 0;
  }
  
  .solution-arrow svg {
    opacity: 0.6;
  }
  
  .solution-description {
    text-align: center;
    color: var(--black);
    max-width: 800px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
    font-size: 1.0625rem;
font-style: normal;
font-weight: 700;
line-height: 150%;
letter-spacing: 0.02125rem;
}

.solution-description strong {
    font-weight: 700;
    color: #0647A9;
}
/* レスポンシブ対応: タブレット以下で横スクロール可能にする */
@media (max-width: 1200px) {
  /* forecast-sectionが子要素の幅を制限しないように */
  .forecast-section {
    align-items: stretch;
    width: 100%;
  }

  /* scroll-hint-shadow-wrap: 右側だけ画面いっぱいにする */
  .scroll-hint-shadow-wrap {
    margin-right: calc(-50vw + 50%);
  }

  /* スクロールコンテナ: 固定幅を解除し、親の幅に合わせる */
  .forecast-chart-container.js-scrollable,
  .forecast-chart-image-01.js-scrollable,
  .forecast-chart-image-02.js-scrollable {
    width: 100% !important;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    position: relative;
    display: block;
    /* スクロール開始位置の左側に余白を追加 */
    padding-left: 1.56rem;
    /* スクロールバーを表示 */
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 0, 0, 0.3) transparent;
  }

  /* スクロールバーのスタイル（Webkit系ブラウザ用） */
  .forecast-chart-container.js-scrollable::-webkit-scrollbar {
    height: 8px;
  }

  .forecast-chart-container.js-scrollable::-webkit-scrollbar-track {
    background: transparent;
  }

  .forecast-chart-container.js-scrollable::-webkit-scrollbar-thumb {
    background-color: rgba(0, 0, 0, 0.3);
    border-radius: 4px;
  }

  /* 画像は縮めず、元のサイズを維持 */
  .forecast-chart-container.js-scrollable .forecast-chart-image {
    width: auto;
    max-width: none;
    height: auto;
    display: block;
    /* flex-shrinkを防ぐ */
    flex-shrink: 0;
  }

  /* 画像ごとに必要な横幅をmin-widthで確保 */
  .forecast-chart-image-01.js-scrollable .forecast-chart-image {
    min-width: 47.875rem;
  }
  
  .forecast-chart-image-02.js-scrollable .forecast-chart-image {
    min-width: 68.6875rem;
  }
}
@media screen and (max-width: 1024px) {
  .solution-cards {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .forecast-solution {
    padding: 3rem 10vw 10.25rem;
  }
}
@media screen and (max-width: 768px) {
  .forecast-container {
    padding: 0 1.56rem;
  }
  .forecast-subtitle {
    margin-top: 3.44rem;
}
  .forecast-highlight {
    font-size: 1.375rem;
  }
  .forecast-tab {
    font-size: 1.125rem;
  }
  .tab-label {
    padding: 0.1rem 0.65rem;
  }
  .forecast-chart-container {
    margin-top: 1.25rem;
  }
  .forecast-description {
    padding: 0rem;
  }
  .forecast-warning {
    padding: 0 1.25rem;
  }
  .forecast-wave {
    height: 5rem;
  }
  .forecast-wave-inner {
    height: 5rem;
  }
  .solution-image-wrapper {
    width: auto;
    height: auto;
  }
  .forecast-solution {
    padding: 1rem 1.5rem 8rem;
  }
  .forecast-solution .fv-watermark {
    bottom: -3%;
  }
  /* scroll-hint-shadow-wrap: 右側だけ画面いっぱいにする */
  .scroll-hint-shadow-wrap {
    margin-right: calc(-50vw + 50%);
  }
    /* スクロールコンテナ: 固定幅を解除し、親の幅に合わせる */
    .forecast-chart-container.js-scrollable,
    .forecast-chart-image-01.js-scrollable,
    .forecast-chart-image-02.js-scrollable {
      /* スクロール開始位置の左側に余白を追加 */
      padding-left: 0;
    }
    .solution-arrow {
      margin: 1.25rem 0 0.9375rem;
    }
}

/* Flow Section Styles =====================================*/

/* Flow Section */
.flow {
    background: #FFFFFF;
    padding-bottom: 10.12rem;
  }
  
  .flow-grid {
    display: flex;
    align-items: center;
    gap: 0.9375rem;
    align-self: stretch;
    justify-content: center;
    width: 100%;
    flex-wrap: wrap;
    margin-top: 7.68rem;
  }
  .flow-grid-bottom {
    margin-top: 2.5rem;
  }
  .flow-step {
    background: #E8F1FB;
    display: flex;
    width: 16.25rem;
    height: 24.5625rem;
    padding: 1.5rem 1.625rem;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  
  .flow-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 5.625rem;
  }

  .flow .tab-label {
    margin-top: 1.88rem;
  }

  .flow-heading {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--black);
    line-height: 1.3;
    margin-top: 0.8rem;
    letter-spacing: 0.0125rem;
  }
  
  .flow-text {
    font-size: 1.0625rem;
    font-weight: 400;
    color: var(--black);
    line-height: 1.5;
    text-align: left;
    margin-top: 1rem;
    letter-spacing: 0.02125rem;
  }
  
  .flow-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  /* レスポンシブ対応 - タブレット (1024px以下) */
  @media (max-width: 1024px) {
    .flow {
      padding: 0rem 0 5.5rem;
    }

    .flow-grid {
      display: grid;
      grid-template-rows: auto auto;
      row-gap: 3.5rem;
      column-gap: 5.5rem;
      justify-items: center;
      align-items: start;
    }

    .flow-grid .flow-arrow {
      display: none;
    }

    .flow-grid .flow-step:nth-child(1) {
      grid-column: 1;
      grid-row: 1;
    }

    .flow-grid .flow-step:nth-child(3) {
      grid-column: 2;
      grid-row: 1;
    }

    .flow-grid .flow-step:nth-child(5) {
      grid-column: 1 / 3;
      grid-row: 2;
      justify-self: center;
      max-width: 18.25rem;
    }

    .flow-step {
      position: relative;
      padding: 30px 20px;
      width: 100%;
      max-width: 16.25rem;
      height: 24.125rem;
    }

    .flow-step::after {
      content: "";
      position: absolute;
      right: -3.75rem;
      top: 50%;
      transform: translateY(-50%);
      width: 36px;
      height: 36px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36' fill='none'%3E%3Cpath d='M9 33V3L27 18L9 33Z' fill='%23FDA000' fill-opacity='0.45'/%3E%3C/svg%3E");
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center;
      z-index: 1;
    }

    .flow-grid.flow-grid-bottom .flow-step:last-child::after {
      display: none;
    }
  
    .flow-heading {
      font-size: 18px;
    }
  
    .flow-text {
      font-size: 1.0625rem;
    }

    .flow-grid-bottom {
      margin-top: 3.5rem;
    }
  }

  @media (max-width: 768px) {
    .flow {
      padding: 0 0 5rem;
    }

    .flow-arrow {
        display: none;
    }

    .flow-grid {
      display: grid;
      grid-template-columns: 1fr;
      grid-template-rows: auto;
      gap: 2.5rem;
      justify-items: center;
      margin-top: 3.88rem;
    }
    .flow-grid:last-child {
      margin-top: 2.5rem;
    }

    .flow-grid .flow-step:nth-child(1),
    .flow-grid .flow-step:nth-child(3),
    .flow-grid .flow-step:nth-child(5) {
      grid-column: 1;
      grid-row: auto;
    }
    .flow-grid .flow-step:nth-child(5) {
      max-width: 17.5rem;
    }

    .flow-step {
      position: relative;
      padding: 1.5rem 1.625rem 2.25rem 1.625rem;
      width: 100%;
      max-width: 17.5rem;
      height: auto;
    }

    .flow-step::after {
      content: "";
      position: absolute;
      top: calc(100% + 0.25rem);
      left: 50%;
      transform: translateX(-50%) rotate(90deg);
      width: 36px;
      height: 36px;
      background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='36' height='36' viewBox='0 0 36 36' fill='none'%3E%3Cpath d='M9 33V3L27 18L9 33Z' fill='%23FDA000' fill-opacity='0.45'/%3E%3C/svg%3E");
      background-size: contain;
      background-repeat: no-repeat;
      background-position: center;
      z-index: 1;
      display: block;
    }

    .flow-grid.flow-grid-bottom .flow-step:last-child::after {
      display: none;
    }
  }

/* FAQ Section Styles =====================================*/

.faq {
    background: #E8F1FB;
    padding-bottom: 10rem;
  }
  
  .faq-list {
    max-width: 1100px;
    margin: 7.63rem auto 0;
    background: var(--white);
    overflow: hidden;
    padding: 1.25rem 1.88rem;
  }
  
  .faq-item {
    border-bottom: 1px solid #E0E0E0;
    transition: background 0.2s ease;
  }
  
  .faq-item:last-child {
    border-bottom: none;
  }
  
  .faq-question {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 24px 28px;
    cursor: pointer;
    user-select: none;
    transition: background 0.2s ease;
  }
  
  .faq-item:hover {
    background: #F8FAFB;
  }
  
  .faq-q-label {
    font-size: 1.375rem;
    font-weight: 700;
    color: var(--primary-blue);
    flex-shrink: 0;
  }
  
  .faq-q-text {
    flex: 1;
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--black);
    line-height: 1.6;
    letter-spacing: 0.04rem;
    font-family: var(--font-noto-sans);
  }
  
  .faq-icon {
    width: 24px;
    height: 24px;
    position: relative;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .faq-icon-horizontal,
  .faq-icon-vertical {
    position: absolute;
    background-color: var(--primary-blue);
    transition: transform 0.3s ease;
  }
  
  .faq-icon-horizontal {
    width: 16px;
    height: 2px;
  }
  
  .faq-icon-vertical {
    width: 2px;
    height: 16px;
    transform: rotate(0deg);
  }
  
  .faq-item.active .faq-icon-vertical {
    transform: rotate(90deg);
  }
  
  .faq-answer {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease, padding 0.3s ease;
    padding: 0 28px;
  }
  
  .faq-item.active .faq-answer {
    max-height: 500px;
    padding: 0 28px 24px;
  }
  
  .faq-a-label {
    font-size: 1.375rem;
    font-weight: 700;
    color: #FFA726;
    display: inline-block;
    flex-shrink: 0;
    margin-bottom: 8px;
  }
  
  .faq-a-text {
    flex: 1;
    min-width: 0;
    font-size: 1.063rem;
    line-height: 1.6;
    color: var(--feature-text);
    margin: 0;
    font-weight: 400;
  }

  /* タブレット (max-width: 1024px) */
@media (max-width: 1024px) {
    .faq {
      padding: 0rem 0 5.5rem;
    }
    .faq-list {
      max-width: 100%;
      margin: 5rem 2rem 0;
    }
  }
  
  /* モバイル (max-width: 768px) */
  @media (max-width: 768px) {
    .faq {
      padding: 0 1.5rem 5rem;
    }
  .faq-container {
    padding-top: 4.69rem;
  }
    .faq-list {
      gap: 12px;
      margin: 3.87rem 0 0;
      width: 100%;
      max-width: 100%;
      padding: 1.25rem;
    }
  
    .faq-question {
      padding: 18px 0.31rem;
    }
  
    .faq-q-label {
      font-size: 1.375rem;
    }
  
    .faq-q-text {
      font-size: 1.0625rem;
      letter-spacing: 0.03rem;
    }
  
    .faq-icon {
      font-size: 20px;
    }
  
    .faq-a-label {
      font-size: 1.375rem;
    }
  
    .faq-a-text {
      font-size: 1.0625rem;
      letter-spacing: 0.02rem;
    }
  
    .faq-answer {
      padding: 0 0.31rem;
    }
  
    .faq-item.active .faq-answer {
      max-height: none;
      padding: 0 0.31rem 18px;
    }
  }
