/*
Theme Name: Shinokura
Theme URI: https://shinokura.co.jp/
Author: Shinokura Co., Ltd.
Author URI: https://shinokura.co.jp/
Description: WordPress Theme for Shinokura Corporation
Version: 1.0.0
License: GPL v2 or later
Text Domain: shinokura
*/
.grecaptcha-badge { 
   visibility: hidden; 
}
.sp-only{
  display: none;
}
.copy-text-sp{
  display: none;
}
@media (max-width: 1139px) {
  .copy-text-sp{
    display: block;
  }
}
/* ローディングアニメーション用スタイル */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    opacity: 1;
    transition: opacity 0.8s ease-in-out;
}

.loading-overlay.hide {
    opacity: 0;
    pointer-events: none;
}

.loading-logo {
    width: 150px;
    height: 150px;
    animation: rotate 5s linear infinite;
    margin-bottom: 30px;
    background-color: transparent;
    mix-blend-mode: normal;
}

@keyframes rotate {
    from {
        transform: rotate(0deg);
    }
    to {
        transform: rotate(360deg);
    }
}

.company-name {
    font-size: 48px;
    font-weight: bold;
    color: #2a3990;
    /* display: flex; */
    gap: 0.2em;
    font-family: "Noto Sans JP", sans-serif;
}

.company-name span {
    display: inline-block;
    color: #333;
}

@keyframes fadeInChar {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeOutChar {
    from {
        opacity: 1;
        transform: translateY(0);
    }
    to {
        opacity: 0;
        transform: translateY(-20px);
    }
}

/* 各文字のアニメーション遅延 */
.company-name span:nth-child(1) { animation-delay: 0s; }
.company-name span:nth-child(2) { animation-delay: 0.1s; }
.company-name span:nth-child(3) { animation-delay: 0.2s; }
.company-name span:nth-child(4) { animation-delay: 0.3s; }
.company-name span:nth-child(5) { animation-delay: 0.4s; }
.company-name span:nth-child(6) { animation-delay: 0.5s; }
.company-name span:nth-child(7) { animation-delay: 0.6s; }
@import url("https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css");
* {
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}
html,
body {
  margin: 0px;
  height: 100%;
  overflow-x: hidden;
}
/* スムーススクロール */
html {
  scroll-behavior: smooth;
}
/* a blue color as a generic focus style */
button:focus-visible {
  outline: 2px solid #4a90e2 !important;
  outline: -webkit-focus-ring-color auto 5px !important;
}
a {
  text-decoration: none;
}

/* 電話番号リンクのスタイル（iPhone Safari対策） */
a[href^="tel:"] {
  color: inherit;
  text-decoration: none;
}

/* KV Block Styles */
.kv-block {
  width: 100%;
  padding: 0 0 64px;
  background: linear-gradient(180deg, #ffffff 0%, #1813ab 100%);
  position: relative;
}

.kv-block .container {
  display: flex;
  flex-direction: row;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  position: relative;
}

.kv-block .left-section {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 48px 0 0 48px;
  gap: 64px;
  flex: 1;
}

.kv-block .image01 {
  width: 756px;
  height: 563px;
  border-radius: 0 40px 0 40px;
  position: relative;
  overflow: hidden;
}

/* Left Slider Styles */
.kv-block .slider-left {
  width: 100%;
  height: 100%;
  position: relative;
}

.kv-block .slider-left .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}

.kv-block .slider-left .slide.active {
  opacity: 1;
}

.kv-block .slider-left .slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 40px 0 40px;
}

.kv-block .navigationbar {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  padding-left: 48px;
}

.kv-block .bar {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
}

.kv-block .line {
  width: 120px;
  height: 3px;
  background-color: #a7b1ff;
  transition: all 0.3s ease;
}

.kv-block .line.active {
  background-color: #ffffff;
}

.kv-block .counter {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  gap: 8px;
  padding: 2px 0;
}

.kv-block .current {
  font-family: "Prompt", Helvetica, sans-serif;
  font-weight: 400;
  font-size: 20px;
  line-height: 1em;
  color: #ffffff;
  text-align: center;
}

.kv-block .separator {
  font-family: "Prompt", Helvetica, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1em;
  color: #ffffff;
  text-align: center;
}

.kv-block .total {
  font-family: "Prompt", Helvetica, sans-serif;
  font-weight: 400;
  font-size: 20px;
  line-height: 1em;
  color: #ced5ff;
  text-align: right;
}

.kv-block .right-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 96px;
  padding: 120px 80px 0 96px;
  flex: 1;
}

.kv-block .copy-text {
  display: flex;
  flex-direction: column;
  width: 100%;
}

.kv-block .text-line {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 84px;
  line-height: 1.3em;
  letter-spacing: 3px;
  color: #000000;
  text-align: left;
}

.kv-block .highlight-char {
  color: #0D05D2;
}

.kv-block .image02 {
  width: 400px;
  height: 286px;
  border-radius: 0px 40px 0px 40px;
  position: relative;
  overflow: hidden;
}

/* Right Slider Styles */
.kv-block .slider-right {
  width: 100%;
  height: 100%;
  position: relative;
}

.kv-block .slider-right .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}

.kv-block .slider-right .slide.active {
  opacity: 1;
}

.kv-block .slider-right .slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0px 40px 0px 40px;
}

.kv-block .teitan01 {
  position: absolute;
  right: 48px;
  bottom: 0;
  width: 238px;
  height: 210px;
  z-index: 10;
}

.kv-block .speech-bubble {
  position: absolute;
  top: 67px;
  left: 95px;
  width: 148px;
  height: 143px;
  background: #ffffff;
  border: 2px solid #3f42ff;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
}

.kv-block .bubble-text {
  font-family: "Noto Sans JP", Helvetica, sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.5em;
  color: #0d05d2;
  text-align: center;
  padding: 16px;
}

.kv-block .character-illustration {
  position: absolute;
  top: 0;
  left: 0;
  width: 131px;
  height: 156px;
  background: url('assets/character.svg') center center/contain no-repeat;
  z-index: 1;
}

/* Right Swiper Styles */
.kv-block .kv-swiper-right {
  width: 100%;
  height: 100%;
  border-radius: 0 40px 0 40px;
}

.kv-block .kv-swiper-right .swiper-slide {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kv-block .kv-swiper-right .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 40px 0 40px;
}

/* Responsive Design */
@media (max-width: 1024px) {
  .kv-block .container {
    flex-direction: column;
    padding: 0 24px;
  }
  
  .kv-block .left-section {
    padding: 24px 0 0 0;
    gap: 32px;
  }
  
  .kv-block .image01 {
    width: 100%;
    height: 400px;
  }
  
  .kv-block .right-section {
    padding: 48px 24px 0 24px;
    gap: 48px;
  }
  
  .kv-block .text-line {
    font-size: 48px;
    line-height: 1.2em;
  }
  
  .kv-block .image02 {
    width: 100%;
    height: 300px;
  }
  
  .kv-block .teitan01 {
    right: 24px;
    width: 120px;
    height: 105px;
  }
}

@media (max-width: 768px) {
  .kv-block {
    padding: 0 0 32px;
  }
  
  .kv-block .container {
    padding: 0 16px;
  }
  
  .kv-block .left-section {
    padding: 16px 0 0 0;
    gap: 24px;
  }
  
  .kv-block .image01 {
    width: 100%;
    height: 280px;
  }
  
  .kv-block .right-section {
    padding: 32px 16px 0 16px;
    gap: 32px;
  }
  
  .kv-block .text-line {
    font-size: 32px;
    line-height: 1.2em;
  }
  
  .kv-block .image02 {
    width: 100%;
    height: 200px;
  }
  
  .kv-block .teitan01 {
    right: 16px;
    width: 80px;
    height: 70px;
  }
}

  .CTA-block {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-items: center;
    justify-content: center;
    gap: 32px;
    padding: 96px 24px;
    position: relative;
    background-color: #110cad;
  }
  
  .CTA-block::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url(assets/LogoPatternbg.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    background-position: -12px -76px;
    background-size: 29%;
    z-index: 0;
    pointer-events: none;
  }
  
  .CTA-block .title-contact {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1140px;
    align-items: center;
    gap: 24px;
    position: relative;
    flex: 0 0 auto;
    border-radius: 0px 28px 0px 28px;
    z-index: 1;
  }
  
  .CTA-block .title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .CTA-block .div {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .CTA-block .zap-icon {
    position: relative;
    width: 18px;
    height: 18px;
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(7500%) hue-rotate(0deg) brightness(100%) contrast(100%);
  }
  
  .CTA-block .advantage {
    position: relative;
    width: fit-content;
    font-family: "Kanit", Helvetica, sans-serif;
    font-weight: 400;
    color: #ced5ff;
    font-size: 20px;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .CTA-block .text-wrapper {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 40px;
    text-align: center;
    letter-spacing: 2%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .CTA-block .text-wrapper-2 {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    color: #ffffff;
    font-size: 14px;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.71em;
  }
  
  .CTA-block .contact-infomation {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 32px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
    background-color: #e5e8ff;
  }
  
  .CTA-block .text-wrapper-3 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 20px;
    letter-spacing: 2.5%;
    line-height: 1.6em;
    white-space: nowrap;
  }
  
  .CTA-block .frame {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    align-self: stretch;
    width: 100%;
    position: relative;
    flex: 0 0 auto;
  }
  
  .CTA-block .CTA-mainoffice {
    display: flex;
    flex-direction: column;
    width: 343px;
    height: 150px;
    align-items: flex-start;
    justify-content: space-between;
    padding: 32px 16px;
    position: relative;
    background-color: #ffffff;
    border: 1px solid #ffffff;
    cursor: pointer;
    transition: all 0.3s ease;
    border-radius: 0;
  }
  
  .CTA-block .CTA-mainoffice:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(13, 5, 210, 0.15);
  }
  
  .CTA-block .text-wrapper-4 {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .CTA-block .text-wrapper-5 {
    position: relative;
    width: fit-content;
    font-family: var(--typography-body-xs-font-family);
    font-weight: var(--typography-body-xs-font-weight);
    color: #1a1a1a;
    font-size: var(--typography-body-xs-font-size);
    letter-spacing: var(--typography-body-xs-letter-spacing);
    line-height: var(--typography-body-xs-line-height);
    white-space: nowrap;
    font-style: var(--typography-body-xs-font-style);
  }
  
  .CTA-block .text-wrapper-6 {
    position: relative;
    width: fit-content;
    font-family: var(--typography-body-lg-bold-font-family);
    font-weight: var(--typography-body-lg-bold-font-weight);
    color: #1a1a1a;
    font-size: var(--typography-body-lg-bold-font-size);
    letter-spacing: var(--typography-body-lg-bold-letter-spacing);
    line-height: var(--typography-body-lg-bold-line-height);
    white-space: nowrap;
    font-style: var(--typography-body-lg-bold-font-style);
  }
  
  .CTA-block .CTA-mainoffice-2 {
    display: flex;
    flex-direction: column;
    width: 343px;
    height: 150px;
    align-items: flex-start;
    justify-content: space-between;
    padding: 32px 24px;
    position: relative;
    background-color: #ffffff;
    border: 1px solid;
  }
  
  .CTA-block .frame-2 {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .CTA-block .img {
    position: relative;
    width: 24px;
    height: 24px;
  }
  
  .CTA-block .text-wrapper-7 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 24px;
    letter-spacing: 2.5%;
    line-height: 1.6em;
    white-space: nowrap;
  }
  
  .CTA-block .element {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 16px;
    letter-spacing: 2.5%;
    line-height: 1.6em;
  }
  
  .CTA-block .div-2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .CTA-block .CTA-office {
    display: flex;
    flex-direction: column;
    width: 280px;
    height: 150px;
    align-items: flex-start;
    justify-content: space-around;
    gap: 4px;
    padding: 32px 16px;
    position: relative;
    border: 1px solid #ffffff;
    cursor: pointer;
    transition: all 0.3s ease;
    border-radius: 0;
  }
  
  .CTA-block .CTA-office:hover {
    background-color: rgba(255, 255, 255, 0.1);
    transform: translateY(-1px);
  }
  
  .CTA-block .frame-3 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
    margin-top: -17.00px;
    margin-bottom: -17.00px;
  }
  
  .CTA-block .text-wrapper-8 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .CTA-block .phone {
    position: relative;
    width: 20px;
    height: 20px;
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(7500%) hue-rotate(0deg) brightness(100%) contrast(100%);
  }
  
  .CTA-block .text-wrapper-9 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 20px;
    letter-spacing: 2.5%;
    line-height: 1.6em;
    white-space: nowrap;
  }
  
  .CTA-block .element-2 {
    position: relative;
    align-self: stretch;
    font-family: var(--typography-body-md-font-family);
    font-weight: var(--typography-body-md-font-weight);
    color: #ffffff;
    font-size: var(--typography-body-md-font-size);
    letter-spacing: var(--typography-body-md-letter-spacing);
    line-height: var(--typography-body-md-line-height);
    font-style: var(--typography-body-md-font-style);
  }
  
  .CTA-block .text-wrapper-10 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.5em;
  }
  
  .CTA-block .file {
    position: relative;
    width: 32px;
    height: 32px;
  }

  /* CTA Block Responsive Design */
  @media (max-width: 768px) {
    .CTA-block {
      padding: 48px 24px;
    }
    
    .CTA-block .title-contact {
      width: 100%;
      max-width: none;
    }
    
    .CTA-block .frame {
      flex-direction: column;
      gap: 16px;
    }
    
    .CTA-block .CTA-mainoffice,
    .CTA-block .CTA-mainoffice-2 {
      width: 100%;
      max-width: 343px;
    }
    
    .CTA-block .div-2 {
      flex-direction: column;
      gap: 16px;
    }
    
    .CTA-block .CTA-office {
      width: 100%;
      max-width: 280px;
    }
  }
  :root {
    --typography-title-lg-font-family: "Noto Sans JP", Helvetica;
    --typography-title-lg-font-weight: 700;
    --typography-title-lg-font-size: 48px;
    --typography-title-lg-letter-spacing: 0.72px;
    --typography-title-lg-line-height: 150%;
    --typography-title-lg-font-style: normal;
    --typography-title-md-font-family: "Noto Sans JP", Helvetica;
    --typography-title-md-font-weight: 700;
    --typography-title-md-font-size: 40px;
    --typography-title-md-letter-spacing: 0.8px;
    --typography-title-md-line-height: 150%;
    --typography-title-md-font-style: normal;
    --typography-heading-xl-font-family: "Noto Sans JP", Helvetica;
    --typography-heading-xl-font-weight: 700;
    --typography-heading-xl-font-size: 34px;
    --typography-heading-xl-letter-spacing: 0.68px;
    --typography-heading-xl-line-height: 152.99999713897705%;
    --typography-heading-xl-font-style: normal;
    --typography-heading-lg-font-family: "Noto Sans JP", Helvetica;
    --typography-heading-lg-font-weight: 700;
    --typography-heading-lg-font-size: 28px;
    --typography-heading-lg-letter-spacing: 0.56px;
    --typography-heading-lg-line-height: 157.00000524520874%;
    --typography-heading-lg-font-style: normal;
    --typography-heading-md-font-family: "Noto Sans JP", Helvetica;
    --typography-heading-md-font-weight: 700;
    --typography-heading-md-font-size: 24px;
    --typography-heading-md-letter-spacing: 0.6px;
    --typography-heading-md-line-height: 166.99999570846558%;
    --typography-heading-md-font-style: normal;
    --typography-heading-sm-font-family: "Noto Sans JP", Helvetica;
    --typography-heading-sm-font-weight: 700;
    --typography-heading-sm-font-size: 20px;
    --typography-heading-sm-letter-spacing: 0.5px;
    --typography-heading-sm-line-height: 160.0000023841858%;
    --typography-heading-sm-font-style: normal;
    --typography-heading-xs-font-family: "Noto Sans JP", Helvetica;
    --typography-heading-xs-font-weight: 700;
    --typography-heading-xs-font-size: 16px;
    --typography-heading-xs-letter-spacing: 0.48px;
    --typography-heading-xs-line-height: 175%;
    --typography-heading-xs-font-style: normal;
    --typography-body-lg-font-family: "Noto Sans JP", Helvetica;
    --typography-body-lg-font-weight: 400;
    --typography-body-lg-font-size: 20px;
    --typography-body-lg-letter-spacing: 0.5px;
    --typography-body-lg-line-height: 160.0000023841858%;
    --typography-body-lg-font-style: normal;
    --typography-body-md-font-family: "Noto Sans JP", Helvetica;
    --typography-body-md-font-weight: 400;
    --typography-body-md-font-size: 16px;
    --typography-body-md-letter-spacing: 0.48px;
    --typography-body-md-line-height: 175%;
    --typography-body-md-font-style: normal;
    --typography-body-sm-font-family: "Noto Sans JP", Helvetica;
    --typography-body-sm-font-weight: 400;
    --typography-body-sm-font-size: 14px;
    --typography-body-sm-letter-spacing: 0.42px;
    --typography-body-sm-line-height: 171.00000381469727%;
    --typography-body-sm-font-style: normal;
    --typography-body-xs-font-family: "Noto Sans JP", Helvetica;
    --typography-body-xs-font-weight: 400;
    --typography-body-xs-font-size: 12px;
    --typography-body-xs-letter-spacing: 0.48px;
    --typography-body-xs-line-height: 166.99999570846558%;
    --typography-body-xs-font-style: normal;
    --typography-body-lg-bold-font-family: "Noto Sans JP", Helvetica;
    --typography-body-lg-bold-font-weight: 700;
    --typography-body-lg-bold-font-size: 20px;
    --typography-body-lg-bold-letter-spacing: 0.5px;
    --typography-body-lg-bold-line-height: 160.0000023841858%;
    --typography-body-lg-bold-font-style: normal;
    --typography-body-md-bold-font-family: "Noto Sans JP", Helvetica;
    --typography-body-md-bold-font-weight: 700;
    --typography-body-md-bold-font-size: 16px;
    --typography-body-md-bold-letter-spacing: 0.48px;
    --typography-body-md-bold-line-height: 175%;
    --typography-body-md-bold-font-style: normal;
    --typography-body-sm-bold-font-family: "Noto Sans JP", Helvetica;
    --typography-body-sm-bold-font-weight: 700;
    --typography-body-sm-bold-font-size: 14px;
    --typography-body-sm-bold-letter-spacing: 0.42px;
    --typography-body-sm-bold-line-height: 171.00000381469727%;
    --typography-body-sm-bold-font-style: normal;
    --typography-body-xs-bold-font-family: "Noto Sans JP", Helvetica;
    --typography-body-xs-bold-font-weight: 700;
    --typography-body-xs-bold-font-size: 12px;
    --typography-body-xs-bold-letter-spacing: 0.48px;
    --typography-body-xs-bold-line-height: 166.99999570846558%;
    --typography-body-xs-bold-font-style: normal;
    --typography-label-md-font-family: "Noto Sans JP", Helvetica;
    --typography-label-md-font-weight: 700;
    --typography-label-md-font-size: 16px;
    --typography-label-md-letter-spacing: 0px;
    --typography-label-md-line-height: 100%;
    --typography-label-md-font-style: normal;
    --typography-label-sm-font-family: "Noto Sans JP", Helvetica;
    --typography-label-sm-font-weight: 700;
    --typography-label-sm-font-size: 14px;
    --typography-label-sm-letter-spacing: 0px;
    --typography-label-sm-line-height: 100%;
    --typography-label-sm-font-style: normal;
    --typography-label-xs-font-family: "Noto Sans JP", Helvetica;
    --typography-label-xs-font-weight: 400;
    --typography-label-xs-font-size: 12px;
    --typography-label-xs-letter-spacing: 0.24px;
    --typography-label-xs-line-height: 100%;
    --typography-label-xs-font-style: normal;
  }
  /* Footer wrapper for background */
  .footer-wrapper {
    position: relative;
    width: 100%;
  }
  
  .footer-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: url('assets/logo-bg-Footer.png') no-repeat;
    background-size: 40%;
    background-position: 989px -15px;
    /* opacity: 0.3; */
    z-index: 0;
  }

  .footer {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    align-items: center;
    gap: 48px;
    padding: 96px 64px 24px;
    position: relative;
    z-index: 1;
  }
  
  .footer .frame {
    justify-content: space-between;
    display: flex;
    align-items: flex-start;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
    gap: 51px;
  }
  
  .footer .left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 16px;
    position: relative;
    flex: 1;
    flex-grow: 1;
  }
  
  .footer .logo {
    position: relative;
    width: 240px;
    height: 48px;
    background-image: url(./img/logo.png);
    background-size: cover;
    background-position: 50% 50%;
  }
  
  .footer .div {
    flex-direction: column;
    gap: 8px;
    display: flex;
    align-items: flex-start;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .footer .text-wrapper {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.75em;
    position: relative;
    align-self: stretch;
    color: #1a1a1a;
  }
  
  .footer .element {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    font-size: 14px;
    letter-spacing: 3%;
    line-height: 1.71em;
    position: relative;
    align-self: stretch;
    color: #1a1a1a;
  }
  
  .footer .text-wrapper-2 {
    position: relative;
    align-self: stretch;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    color: #1a1a1a;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.75em;
  }
  
  .footer .right {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 16px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .footer .menus {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .footer .dropdown-list {
    width: 180px;
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 0px 4px 8px;
    position: relative;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .footer .dropdown-list:hover {
    background-color: rgba(13, 5, 210, 0.05);
  }
  
  .footer .name {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.75em;
    white-space: nowrap;
  }
  
  .footer .menu-list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    flex: 0 0 auto;
  }
  
  .footer .dropdown-list-2 {
    display: flex;
    width: 180px;
    align-items: center;
    gap: 4px;
    padding: 4px 0px 4px 8px;
    position: relative;
    flex: 0 0 auto;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .footer .dropdown-list-2:hover {
    background-color: rgba(13, 5, 210, 0.05);
  }
  
  .footer .dropdown-list-3 {
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 0px 4px 8px;
    position: relative;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .footer .dropdown-list-3:hover {
    background-color: rgba(26, 26, 26, 0.05);
  }
  
  .footer .check-indeterminate {    
    position: relative;
    width: 10px;
    height: 12px;
    margin-right: 1px;
  }
  
  .footer .language-name {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 14px;
    letter-spacing: 3%;
    line-height: 1.71em;
    white-space: nowrap;
  }
  
  .footer .dropdown-list-4 {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 0px 4px 16px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .footer .dropdown-list-4:hover {
    background-color: rgba(26, 26, 26, 0.05);
  }
  
  .footer .button {
    all: unset;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px 8px 8px;
    position: relative;
    flex: 0 0 auto;
    background-color: #006ace;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
  }
  
  .footer .button:hover {
    background-color: #0056a3;
    transform: translateY(-1px);
  }
  
  .footer .icon {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px;
    position: relative;
    flex: 0 0 auto;
    background-color: rgba(255, 255, 255, 0.3);
    border-radius: 2px;
  }
  
  .footer .icon-search {
    position: relative;
    width: 18px;
    height: 18px;
  }
  
  .footer .label {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    position: relative;
    width: fit-content;
    white-space: nowrap;
  }
  
  .footer .copyright {
    display: flex;
    align-items: flex-start;
    justify-content: space-between; 
    gap: 64px;
    position: relative;
    flex: 0 0 auto;
    text-align: center;
  }
  
  .footer .p {
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 300;
    color: #67676f;
    font-size: 10px;
    letter-spacing: 3%;
    line-height: 1.71em;
    position: relative;
    width: fit-content;
    white-space: nowrap;
  }

  /* Responsive Design for Footer */
  @media (max-width: 1024px) {
    .footer {
      padding: 64px 32px 16px;
    }
    
    .footer .frame {
      gap: 32px;
    }
    
    .footer .logo {
      width: 200px;
      height: 40px;
    }
  }

  @media (max-width: 768px) {
    .footer {
      padding: 48px 24px 16px;
    }
    
    .footer .frame {
      flex-direction: column;
      gap: 40px;
    }
    
    .footer .right {
      width: 100%;
      flex-direction: column;
      gap: 24px;
    }
    
    .footer .menus {
      flex-direction: column;
      gap: 16px;
      width: 100%;
    }
    
    .footer .dropdown-list,
    .footer .dropdown-list-2 {
      width: 100%;
    }
    
    .footer .logo {
      width: 180px;
      height: 36px;
    }
    
    .footer .copyright {
      justify-content: center;
      text-align: center;
    }
  }
  .recruit-block {
    display: flex;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    align-items: flex-end;
    padding: 0px 0px 120px;
    position: relative;
  }
  
  .recruit-block .left {
    position: relative;
    width: 913px;
    height: 640px;
    border-radius: 0px 80px 0px 80px;
    background: 
      linear-gradient(0deg, rgba(221, 235, 248, 0.9) 0%, rgba(221, 235, 248, 0.9) 100%),
      url('assets/recruit-hero-image.png');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
  }
  
  .recruit-block .frame {
    display: flex;
    flex-direction: column;
    width: 535px;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 16px;
    padding: 64px 0px 0px;
    position: relative;
    left: 165px;
  }
  
  .recruit-block .div {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 48px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .recruit-block .title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .recruit-block .text-wrapper {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #006ace;
    font-size: 40px;
    text-align: center;
    letter-spacing: 2%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .recruit-block .title-eg {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .recruit-block .img {
    position: relative;
    width: 18px;
    height: 18px;
  }
  
  .recruit-block .title-eg .img {
    filter: brightness(0) saturate(100%) !important;
  }
  
  .recruit-block .advantage {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Kanit", Helvetica, sans-serif;
    font-weight: 500;
    color: #002956;
    font-size: 20px;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .recruit-block .text-wrapper-2 {
    position: relative;
    align-self: stretch;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    color: #004890;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.75em;
  }
  
  .recruit-block .button {
    all: unset;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px 8px 8px;
    position: relative;
    flex: 0 0 auto;
    background-color: #006ace;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.2s ease;
  }
  
  .recruit-block .button:hover {
    background-color: #0052a3;
    transform: translateY(-1px);
  }
  
  .recruit-block .icon {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px;
    position: relative;
    flex: 0 0 auto;
    background-color: #ffffff4c;
    border-radius: 2px;
  }
  
  .recruit-block .button .icon i {
    color: #ffffff;
  }
  
  .recruit-block .label {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .recruit-block .teitan {
    position: relative;
    width: 257px;
    height: 210px;
    transition: transform 0.3s ease;
  }
/*   
  .recruit-block .teitan:hover {
    transform: scale(1.02);
  } */
  
  .recruit-block .overlap {
    position: relative;
    width: 259px;
    height: 161px;
    top: 25px;
  }
  
  .recruit-block .group {
    position: absolute;
    width: 128px;
    height: 118px;
    top: 0;
    left: 131px;
  }
  
  .recruit-block .overlap-group {
    position: relative;
    width: 117px;
    height: 107px;
    top: 5px;
    left: 5px;
    background-image: url(./img/lt-gt.svg);
    background-size: 100% 100%;
  }
  
  .recruit-block .text-wrapper-3 {
    position: absolute;
    top: 39px;
    left: 21px;
    font-family: "Noto Sans JP-Bold", Helvetica;
    font-weight: 700;
    color: #004890;
    font-size: 12px;
    text-align: center;
    letter-spacing: 0;
    line-height: 18px;
  }
  
  .recruit-block .element {
    position: absolute;
    width: 131px;
    height: 156px;
    top: 5px;
    left: 0;
  }
  
  .recruit-block .overlap-2 {
    position: relative;
    height: 156px;
  }
  
  .recruit-block .overlap-wrapper {
    position: absolute;
    width: 125px;
    height: 156px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .overlap-3 {
    position: relative;
    width: 126px;
    height: 157px;
  }
  
  .recruit-block .element-2 {
    position: absolute;
    width: 44px;
    height: 27px;
    top: 81px;
    left: 82px;
  }
  
  .recruit-block .element-3 {
    position: absolute;
    width: 30px;
    height: 25px;
    top: 84px;
    left: 82px;
  }
  
  .recruit-block .element-4 {
    position: absolute;
    width: 30px;
    height: 36px;
    top: 89px;
    left: 23px;
  }
  
  .recruit-block .element-5 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 11px;
    left: 21px;
  }
  
  .recruit-block .element-6 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 11px;
    left: 93px;
  }
  
  .recruit-block .element-7 {
    position: absolute;
    width: 55px;
    height: 69px;
    top: 87px;
    left: 41px;
  }
  
  .recruit-block .element-wrapper {
    position: absolute;
    width: 51px;
    height: 15px;
    top: 135px;
    left: 43px;
  }
  
  .recruit-block .element-8 {
    position: absolute;
    width: 53px;
    height: 17px;
    top: -1px;
    left: -1px;
  }
  
  .recruit-block .element-9 {
    position: absolute;
    width: 55px;
    height: 48px;
    top: 89px;
    left: 41px;
  }
  
  .recruit-block .element-10 {
    position: absolute;
    width: 2px;
    height: 38px;
    top: 96px;
    left: 68px;
  }
  
  .recruit-block .element-11 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 110px;
    left: 50px;
  }
  
  .recruit-block .element-12 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 110px;
    left: 77px;
  }
  
  .recruit-block .element-13 {
    position: absolute;
    width: 96px;
    height: 78px;
    top: 17px;
    left: 20px;
  }
  
  .recruit-block .element-14 {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 56px;
    left: 86px;
  }
  
  .recruit-block .element-15 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 58px;
    left: 93px;
  }
  
  .recruit-block .element-16 {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 56px;
    left: 33px;
  }
  
  .recruit-block .element-17 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 59px;
    left: 40px;
  }
  
  .recruit-block .element-18 {
    position: absolute;
    width: 16px;
    height: 20px;
    top: 66px;
    left: 60px;
  }
  
  .recruit-block .element-19 {
    position: absolute;
    width: 45px;
    height: 25px;
    top: 91px;
    left: 45px;
  }
  
  .recruit-block .img-wrapper {
    position: absolute;
    width: 13px;
    height: 13px;
    top: 98px;
    left: 71px;
    background-image: url(./img/159.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-20 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 3px;
    left: 3px;
  }
  
  .recruit-block .element-21 {
    position: absolute;
    width: 20px;
    height: 18px;
    top: 101px;
    left: 21px;
  }
  
  .recruit-block .overlap-group-wrapper {
    position: absolute;
    width: 60px;
    height: 30px;
    top: 114px;
    left: 41px;
  }
  
  .recruit-block .overlap-4 {
    position: relative;
    height: 30px;
  }
  
  .recruit-block .div-wrapper {
    position: absolute;
    width: 60px;
    height: 28px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .overlap-5 {
    position: relative;
    width: 61px;
    height: 28px;
    left: -1px;
  }
  
  .recruit-block .element-22 {
    position: absolute;
    width: 52px;
    height: 11px;
    top: 13px;
    left: 0;
  }
  
  .recruit-block .element-23 {
    position: absolute;
    width: 16px;
    height: 28px;
    top: 0;
    left: 44px;
  }
  
  .recruit-block .overlap-6 {
    position: relative;
    height: 28px;
  }
  
  .recruit-block .element-24 {
    position: absolute;
    width: 16px;
    height: 28px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .overlap-7 {
    position: relative;
    height: 29px;
  }
  
  .recruit-block .element-25 {
    position: absolute;
    width: 14px;
    height: 20px;
    top: 9px;
    left: 0;
  }
  
  .recruit-block .element-26 {
    position: absolute;
    width: 14px;
    height: 5px;
    top: 9px;
    left: 0;
  }
  
  .recruit-block .element-27 {
    position: absolute;
    width: 8px;
    height: 18px;
    top: 1px;
    left: 8px;
  }
  
  .recruit-block .overlap-group-2 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/162.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-28 {
    position: absolute;
    width: 10px;
    height: 20px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-29 {
    position: absolute;
    width: 5px;
    height: 18px;
    top: 0;
    left: 5px;
  }
  
  .recruit-block .overlap-8 {
    position: relative;
    width: 7px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/166.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-30 {
    position: absolute;
    width: 7px;
    height: 20px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-31 {
    position: absolute;
    width: 9px;
    height: 18px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .overlap-9 {
    position: relative;
    height: 18px;
  }
  
  .recruit-block .overlap-group-3 {
    position: relative;
    width: 11px;
    height: 20px;
    top: -1px;
    left: -1px;
  }
  
  .recruit-block .element-32 {
    position: absolute;
    width: 7px;
    height: 12px;
    top: 8px;
    left: 4px;
  }
  
  .recruit-block .element-33 {
    position: absolute;
    width: 9px;
    height: 11px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-34 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 1px;
    left: 1px;
  }
  
  .recruit-block .element-35 {
    position: absolute;
    width: 11px;
    height: 19px;
    top: 10px;
    left: 4px;
  }
  
  .recruit-block .element-36 {
    position: absolute;
    width: 13px;
    height: 19px;
    top: 9px;
    left: 1px;
  }
  
  .recruit-block .element-37 {
    position: absolute;
    width: 13px;
    height: 4px;
    top: 9px;
    left: 1px;
  }
  
  .recruit-block .overlap-group-4 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/178.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-38 {
    position: absolute;
    width: 8px;
    height: 19px;
    top: 1px;
    left: 1px;
  }
  
  .recruit-block .overlap-10 {
    position: relative;
    width: 7px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/181.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-39 {
    position: absolute;
    width: 6px;
    height: 18px;
    top: 1px;
    left: 1px;
  }
  
  .recruit-block .overlap-group-5 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
  }
  
  .recruit-block .element-40 {
    position: absolute;
    width: 8px;
    height: 11px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-41 {
    position: absolute;
    width: 5px;
    height: 11px;
    top: 8px;
    left: 4px;
  }
  
  .recruit-block .element-42 {
    position: absolute;
    width: 7px;
    height: 10px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-43 {
    position: absolute;
    width: 4px;
    height: 6px;
    top: 1px;
    left: 1px;
  }
  
  .recruit-block .element-44 {
    position: absolute;
    width: 11px;
    height: 18px;
    top: 11px;
    left: 4px;
  }
  
  .recruit-block .element-45 {
    position: absolute;
    width: 7px;
    height: 16px;
    top: 14px;
    left: 50px;
  }
  
  .recruit-block .overlap-11 {
    position: relative;
    height: 16px;
  }
  
  .recruit-block .element-46 {
    position: absolute;
    width: 7px;
    height: 16px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .overlap-group-6 {
    position: relative;
    width: 9px;
    height: 17px;
    top: -1px;
    left: -1px;
  }
  
  .recruit-block .element-47 {
    position: absolute;
    width: 5px;
    height: 15px;
    top: 2px;
    left: 1px;
  }
  
  .recruit-block .element-48 {
    position: absolute;
    width: 9px;
    height: 5px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-49 {
    position: absolute;
    width: 2px;
    height: 4px;
    top: 0;
    left: 5px;
  }
  
  .recruit-block .overlap-12 {
    position: relative;
    width: 8px;
    height: 16px;
  }
  
  .recruit-block .element-50 {
    position: absolute;
    width: 4px;
    height: 14px;
    top: 2px;
    left: 1px;
  }
  
  .recruit-block .element-51 {
    position: absolute;
    width: 8px;
    height: 4px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-52 {
    position: absolute;
    width: 1px;
    height: 3px;
    top: 0;
    left: 5px;
  }
  
  .recruit-block .element-53 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 17px;
    left: 50px;
  }
  
  .recruit-block .element-54 {
    position: absolute;
    width: 105px;
    height: 84px;
    top: 0;
    left: 15px;
  }
  
  .recruit-block .overlap-group-7 {
    position: relative;
    height: 84px;
  }
  
  .recruit-block .element-55 {
    position: absolute;
    width: 105px;
    height: 84px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-56 {
    position: absolute;
    width: 92px;
    height: 32px;
    top: 52px;
    left: 7px;
  }
  
  .recruit-block .element-57 {
    position: absolute;
    width: 12px;
    height: 32px;
    top: 0;
    left: 80px;
  }
  
  .recruit-block .element-58 {
    position: absolute;
    width: 12px;
    height: 32px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-59 {
    position: absolute;
    width: 105px;
    height: 62px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-60 {
    position: absolute;
    width: 107px;
    height: 64px;
    top: -1px;
    left: -1px;
  }
  
  .recruit-block .element-61 {
    position: absolute;
    width: 73px;
    height: 9px;
    top: 41px;
    left: 16px;
  }
  
  .recruit-block .element-62 {
    position: absolute;
    width: 22px;
    height: 22px;
    top: 17px;
    left: 42px;
    background-image: url(./img/372.svg);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-63 {
    position: absolute;
    width: 8px;
    height: 21px;
    top: 0;
    left: 7px;
  }
  
  .recruit-block .element-64 {
    position: absolute;
    width: 48px;
    height: 45px;
    top: 71px;
    left: 0;
  }
  
  .recruit-block .overlap-13 {
    position: relative;
    width: 49px;
    height: 46px;
    background-image: url(./img/67.svg);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-65 {
    position: absolute;
    width: 39px;
    height: 37px;
    top: 5px;
    left: 5px;
  }
  
  .recruit-block .element-66 {
    position: absolute;
    width: 6px;
    height: 10px;
    top: 11px;
    left: 5px;
  }
  
  .recruit-block .element-67 {
    position: absolute;
    width: 23px;
    height: 23px;
    top: 12px;
    left: 13px;
  }
  
  .recruit-block .overlap-group-8 {
    position: relative;
    width: 24px;
    height: 24px;
    top: -1px;
  }
  
  .recruit-block .element-68 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-69 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 2px;
    left: 5px;
  }
  
  .recruit-block .element-70 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 4px;
    left: 10px;
  }
  
  .recruit-block .element-71 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 6px;
    left: 15px;
  }
  
  .recruit-block .element-72 {
    position: absolute;
    width: 11px;
    height: 16px;
    top: 9px;
    left: 5px;
  }
  
  .recruit-block .element-73 {
    position: absolute;
    width: 20px;
    height: 17px;
    top: 101px;
    left: 22px;
  }
  
  .recruit-block .element-74 {
    position: absolute;
    width: 20px;
    height: 34px;
    top: 61px;
    left: 111px;
  }
  
  .recruit-block .overlap-14 {
    position: relative;
    width: 21px;
    height: 36px;
    top: -1px;
    left: -1px;
    background-image: url(./img/215.png);
    background-size: 100% 100%;
  }
  
  .recruit-block .element-75 {
    position: absolute;
    width: 21px;
    height: 35px;
    top: 0;
    left: 0;
  }
  
  .recruit-block .element-76 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 83px;
    left: 110px;
  }
  
  .recruit-block .right {
    display: flex;
    width: 504px;
    align-items: flex-end;
    gap: 24px;
    position: relative;
    margin-left: -80px;
  }
  
  .recruit-block .image {
    position: relative;
    width: 480px;
    height: 534px;
    border-radius: 0px 40px 0px 40px;
    overflow: hidden;
    background: linear-gradient(135deg, #3D37DB 0%, rgba(61, 55, 219, 0) 100%);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .recruit-block .image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0px 40px 0px 40px;
  }
/*   
  .recruit-block .image:hover {
    transform: scale(1.01);
    box-shadow: 0 8px 24px rgba(0, 106, 206, 0.2);
  } */
  
  .recruit-block .navigationbar {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    width: 24px;
    height: 534px;
    margin-top: -1.00px;
    margin-bottom: -1.00px;
    margin-right: -1.75px;
  }
  
  .recruit-block .nav-bar {
    width: 2px;
    height: 120px;
    background-color: #94B5FF;
    border-radius: 1px;
    cursor: pointer;
    transition: all 0.3s ease;
  }
  
  .recruit-block .nav-bar.active,
  .recruit-block .nav-bar:hover {
    background-color: #3F8EFF;
    transform: scaleX(1.5);
  }

  @media (max-width: 1024px) {
    .recruit-block {
      padding: 0px 24px 80px;
    }
    
    .recruit-block .left {
      width: 100%;
      max-width: 800px;
      height: auto;
      min-height: 500px;
    }
    
    .recruit-block .frame {
      width: 100%;
      max-width: 480px;
      left: 120px;
      padding: 48px 0px 0px;
    }
    
    .recruit-block .right {
      width: 400px;
      margin-left: -60px;
    }
    
    .recruit-block .image {
      width: 380px;
      height: 420px;
    }
  }

  @media (max-width: 768px) {
    .recruit-block {
      flex-direction: column;
      align-items: center;
      padding: 0px 24px 60px;
      gap: 40px;
    }
    
    .recruit-block .left {
      width: 100%;
      max-width: 100%;
      height: auto;
      min-height: 400px;
      order: 2;
    }
    
    .recruit-block .frame {
      width: 100%;
      max-width: 100%;
      left: 0;
      padding: 32px 24px 0px;
    }
    
    .recruit-block .div {
      align-items: center;
      gap: 32px;
    }
    
    .recruit-block .title {
      align-items: center;
      text-align: center;
    }
    
    .recruit-block .text-wrapper {
      font-size: 32px;
    }
    
    .recruit-block .advantage {
      font-size: 18px;
    }
    
    .recruit-block .text-wrapper-2 {
      text-align: center;
      font-size: 14px;
      line-height: 1.7em;
    }
    
    .recruit-block .right {
      width: 100%;
      margin-left: 0;
      justify-content: center;
      order: 1;
    }
    
    .recruit-block .image {
      width: 100%;
      max-width: 350px;
      height: 300px;
    }
    
    .recruit-block .navigationbar {
      display: none;
    }
    
    .recruit-block .teitan {
      width: 200px;
      height: 160px;
    }
  }
  
  .news-company-block {
    display: flex;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    align-items: flex-start;
    justify-content: space-between;
    padding: 96px min(150px, 10%);
    position: relative;
  }
  
  .news-company-block .div {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 40px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .div-2 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .news-company-block .title {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #101010;
    font-size: 40px;
    text-align: center;
    letter-spacing: 2%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .news-company-block .text-wrapper {
    color: #0d05d2;
    letter-spacing: 2%;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    line-height: 1.5em;
    font-size: 40px;
  }
  
  .news-company-block .span {
    color: #0f0f0f;
    letter-spacing: 2%;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    line-height: 1.5em;
    font-size: 40px;
  }
  
  .news-company-block .title-eg {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .zap {
    position: relative;
    width: 18px;
    height: 18px;
  }
  
  .news-company-block .advantage {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 20px;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .news-company-block .frame {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 32px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .list {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .news-list {
    display: flex;
    flex-direction: row !important;
    width: 540px;
    align-items: center;
    gap: 16px;
    padding: 16px 8px 16px;
    position: relative;
    flex: 0 0 auto;
    background-color: #ffffff;
    border-bottom-width: 2px;
    border-bottom-style: solid;
    border-color: #a7b1ff;
    cursor: pointer;
    transition: background-color 0.2s ease;
    margin-bottom: 0 !important;
  }
  
  .news-company-block .news-list:hover {
    background-color: rgba(167, 177, 255, 0.05);
  }
  
  .news-company-block .thumbnail {
    position: relative;
    width: 163px;
    height: 100px;
    border-radius: 4px;
    background-image: url(./img/image.png);
    background-size: cover;
    background-position: 50% 50%;
  }
  
  .news-company-block .body {
    display: flex;
    flex-direction: column;
    height: 79px;
    align-items: flex-start;
    justify-content: center;
    gap: 16px;
    padding: 8px 0px;
    position: relative;
    flex: 1;
    flex-grow: 1;
  }
  
  .news-company-block .postdate-category {
    display: flex;
    align-items: center;
    gap: 8px;
    position: relative;
    flex: 0 0 auto;
    margin-top: -0.50px;
  }
  
  .news-company-block .postdate {
    display: flex;
    align-items: flex-end;
    padding: 2px 0px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .text-wrapper-2 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 400;
    color: #0d05d2;
    font-size: 12px;
    text-align: right;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .news-company-block .text-wrapper-3 {
    position: relative;
    width: fit-content;
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 400;
    color: #767fff;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .news-company-block .category-label {
    display: flex;
    height: 20px;
    align-items: center;
    justify-content: center;
    padding: 2px 6px;
    position: relative;
    flex: 0 0 auto;
    background-color: #1612c1;
  }
  
  .news-company-block .score {
    position: relative;
    width: fit-content;
    margin-top: -3.00px;
    margin-bottom: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #ffffff;
    font-size: 12px;
    text-align: right;
    letter-spacing: 4%;
    line-height: 1.67em;
    white-space: nowrap;
  }
  
  .news-company-block .headline {
    position: relative;
    align-self: stretch;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    color: #0d05d2;
    font-size: 16px;
    letter-spacing: 3%;
    line-height: 1.75em;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
  }
  
  .news-company-block .date {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Kanit", Helvetica, sans-serif;
    font-weight: 400;
    color: #0d05d2;
    font-size: 12px;
    text-align: right;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .news-company-block .thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 4px;
  }
  
  .news-company-block .button {
    all: unset;
    box-sizing: border-box;
    display: flex;
    height: 48px;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 24px;
    position: relative;
    background-color: #ffffff;
    border-radius: 4px;
    border: 1px solid;
    border-color: #767fff;
    cursor: pointer;
    transition: all 0.2s ease;
  }
  
  .news-company-block .button:hover {
    border-color: #0d05d2;
    background-color: rgba(13, 5, 210, 0.05);
    transform: translateY(-1px);
  }
  
  .news-company-block .label {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .news-company-block .chevrons-right {
    position: relative;
    width: 24px;
    height: 24px;
  }
  
  .news-company-block .list-2 {
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 40px;
    flex-direction: column;
    position: relative;
    flex: 0 0 auto;
  }
  
  .news-company-block .link {
    display: flex;
    width: 540px;
    height: 88px;
    align-items: center;
    gap: 8px;
    padding: 0px 16px 0px 32px;
    position: relative;
    background-color: rgba(255, 255, 255, 0.3);
    border: 2px solid;
    border-color: #d1ddff;
    cursor: pointer;
    transition: all 0.2s ease;
  }
  
  .news-company-block .link:hover {
    background-color: rgba(255, 255, 255, 0.8);
    border-color: #767fff;
    transform: translateY(-2px);
  }
  
  .news-company-block .body-2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    padding: 8px 4px;
    position: relative;
    flex: 1;
    flex-grow: 1;
  }
  
  .news-company-block .name {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0f0f0f;
    font-size: 18px;
    letter-spacing: 3%;
    line-height: 1.75em;
    white-space: nowrap;
  }
  
  .news-company-block .icon {
    display: flex;
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 4px;
    position: relative;
    background-color: #e5e8ff;
    border-radius: 999px;
    flex: 0 0 auto;
  }
  
  .news-company-block .img {
    position: relative;
    width: 20px;
    height: 20px;
  }

  .news-company-block .icon i {
    color: #0d05d2;
    font-size: 16px;
  }

  .news-company-block .icon img {
    width: 10px;
    height: 10px;
    filter: brightness(0) saturate(100%) invert(13%) sepia(86%) saturate(5471%) hue-rotate(251deg) brightness(92%) contrast(111%);
  }

  @media (max-width: 1024px) {
    .news-company-block {
      padding: 80px 100px;
      gap: 60px;
    }
    
    .news-company-block .title {
      font-size: 36px;
    }
    
    .news-company-block .text-wrapper,
    .news-company-block .span {
      font-size: 36px;
    }
    
    .news-company-block .advantage {
      font-size: 18px;
    }
    
    .news-company-block .news-list {
      width: 100%;
      max-width: 480px;
    }
    
    .news-company-block .link {
      width: 100%;
      max-width: 480px;
    }
  }

  @media (max-width: 768px) {
    .news-company-block {
      flex-direction: column;
      padding: 60px 24px;
      gap: 60px;
    }
    
    .news-company-block .title {
      font-size: 32px;
      text-align: center;
    }
    
    .news-company-block .text-wrapper,
    .news-company-block .span {
      font-size: 32px;
    }
    
    .news-company-block .advantage {
      font-size: 16px;
    }
    
    .news-company-block .div-2 {
      align-items: center;
    }
    
    .news-company-block .title-eg {
      justify-content: center;
    }
    
    .news-company-block .frame {
      align-items: center;
    }
    
    .news-company-block .list-2 {
      align-items: center;
    }
    
    .news-company-block .news-list {
      width: 100%;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 12px;
      padding: 20px 16px;
    }
    
    .news-company-block .thumbnail,
    .news-company-block .thumbnail-2,
    .news-company-block .thumbnail-3,
    .news-company-block .thumbnail-4 {
      width: 100%;
      max-width: 280px;
      height: 160px;
    }
    
    .news-company-block .body {
      height: auto;
      text-align: center;
    }
    
    .news-company-block .postdate-category {
      justify-content: center;
    }
    
    .news-company-block .link {
      width: 100%;
      height: auto;
      padding: 20px 16px;
    }
  }



  .business-block-index {
    width: 100%;
    position: relative;
    background: linear-gradient(176deg, #f1f4ff 88%, #ffffff 0%);
    padding: 80px 0 200px;
  }

  .business-block-index .container {
    display: flex;
    flex-direction: column;
    max-width: 1140px;
    margin: 0 auto;
    align-items: flex-start;
    gap: 40px;
  }
  
  .business-block-index .title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .business-block-index .div {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: transparent;
    font-size: 48px;
    text-align: center;
    letter-spacing: 1.5%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .business-block-index .text-wrapper {
    color: #0d05d2;
    letter-spacing: 1.5%;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    line-height: 1.5em;
    font-size: 48px;
  }
  
  .business-block-index .span {
    color: #0f0f0f;
    letter-spacing: 1.5%;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    line-height: 1.5em;
    font-size: 48px;
  }
  
  .business-block-index .title-eg {
    display: flex;
    align-items: center;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .business-block-index .zap {
    position: relative;
    width: 18px;
    height: 18px;
    transition: transform 0.3s ease;
  }
  
  .business-block-index .zap:hover {
    transform: rotate(15deg);
  }
  
  .business-block-index .advantage {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Kanit", Helvetica, sans-serif;
    font-weight: 500;
    color: #0d05d2;
    font-size: 20px;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .business-block-index .frame {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .business-block-index .left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 24px;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
  }
  
  .business-block-index .teitan {
    position: relative;
    width: 238px;
    height: 210px;
    transition: transform 0.3s ease;
  }
  
  
  .business-block-index .group {
    position: absolute;
    width: 128px;
    height: 118px;
    top: 26px;
    left: 116px;
  }
  
  .business-block-index .overlap-group {
    position: relative;
    width: 117px;
    height: 107px;
    top: 5px;
    left: 5px;
    background-image: url(./img/lt-gt.svg);
    background-size: 100% 100%;
  }
  
  .business-block-index .text-wrapper-2 {
    position: absolute;
    top: 39px;
    left: 21px;
    font-family: "Noto Sans JP-Bold", Helvetica;
    font-weight: 700;
    color: #0d05d2;
    font-size: 12px;
    text-align: center;
    letter-spacing: 0;
    line-height: 18px;
  }
  
  .business-block-index .element {
    position: absolute;
    width: 111px;
    height: 154px;
    top: 30px;
    left: 0;
  }
  
  .business-block-index .overlap {
    position: relative;
    height: 156px;
  }
  
  .business-block-index .img {
    position: absolute;
    width: 48px;
    height: 23px;
    top: 81px;
    left: 54px;
  }
  
  .business-block-index .element-2 {
    position: absolute;
    width: 33px;
    height: 19px;
    top: 85px;
    left: 54px;
  }
  
  .business-block-index .element-3 {
    position: absolute;
    width: 50px;
    height: 65px;
    top: 90px;
    left: 25px;
  }
  
  .business-block-index .element-4 {
    position: absolute;
    width: 48px;
    height: 16px;
    top: 133px;
    left: 26px;
  }
  
  .business-block-index .element-5 {
    position: absolute;
    width: 50px;
    height: 45px;
    top: 91px;
    left: 26px;
  }
  
  .business-block-index .element-6 {
    position: absolute;
    width: 6px;
    height: 28px;
    top: 106px;
    left: 57px;
  }
  
  .business-block-index .element-7 {
    position: absolute;
    width: 10px;
    height: 12px;
    top: 110px;
    left: 41px;
  }
  
  .business-block-index .element-8 {
    position: absolute;
    width: 8px;
    height: 12px;
    top: 108px;
    left: 64px;
  }
  
  .business-block-index .element-9 {
    position: absolute;
    width: 29px;
    height: 33px;
    top: 88px;
    left: 6px;
  }
  
  .business-block-index .element-10 {
    position: absolute;
    width: 9px;
    height: 8px;
    top: 110px;
    left: 17px;
  }
  
  .business-block-index .element-11 {
    position: absolute;
    width: 29px;
    height: 27px;
    top: 88px;
    left: 12px;
  }
  
  .business-block-index .element-wrapper {
    position: absolute;
    width: 7px;
    height: 9px;
    top: 95px;
    left: 59px;
    background-image: url(./img/82.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-12 {
    position: absolute;
    width: 5px;
    height: 5px;
    top: 2px;
    left: 1px;
  }
  
  .business-block-index .overlap-group-wrapper {
    position: absolute;
    width: 40px;
    height: 26px;
    top: 91px;
    left: 30px;
  }
  
  .business-block-index .div-wrapper {
    position: relative;
    width: 43px;
    height: 28px;
    top: -1px;
    left: -1px;
    background-image: url(./img/84.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .img-wrapper {
    position: relative;
    width: 9px;
    height: 13px;
    top: 9px;
    left: 29px;
    background-image: url(./img/85.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-13 {
    position: absolute;
    width: 4px;
    height: 7px;
    top: 3px;
    left: 2px;
  }
  
  .business-block-index .overlap-wrapper {
    position: absolute;
    width: 36px;
    height: 33px;
    top: 72px;
    left: 75px;
  }
  
  .business-block-index .overlap-2 {
    position: relative;
    width: 38px;
    height: 35px;
    top: -1px;
    left: -1px;
    background-image: url(./img/88.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-14 {
    position: absolute;
    width: 17px;
    height: 16px;
    top: 10px;
    left: 9px;
  }
  
  .business-block-index .element-15 {
    position: absolute;
    width: 8px;
    height: 9px;
    top: 85px;
    left: 85px;
  }
  
  .business-block-index .element-16 {
    position: absolute;
    width: 24px;
    height: 25px;
    top: 14px;
    left: 77px;
  }
  
  .business-block-index .element-17 {
    position: absolute;
    width: 95px;
    height: 80px;
    top: 16px;
    left: 4px;
  }
  
  .business-block-index .element-18 {
    position: absolute;
    width: 13px;
    height: 16px;
    top: 59px;
    left: 79px;
  }
  
  .business-block-index .element-19 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 61px;
    left: 85px;
  }
  
  .business-block-index .element-20 {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 56px;
    left: 32px;
  }
  
  .business-block-index .element-21 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 58px;
    left: 39px;
  }
  
  .business-block-index .element-22 {
    position: absolute;
    width: 15px;
    height: 19px;
    top: 68px;
    left: 58px;
  }
  
  .business-block-index .element-23 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 8px;
    left: 11px;
  }
  
  .business-block-index .element-24 {
    position: absolute;
    width: 105px;
    height: 83px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .overlap-group-2 {
    position: relative;
    height: 83px;
  }
  
  .business-block-index .element-25 {
    position: absolute;
    width: 10px;
    height: 30px;
    top: 53px;
    left: 8px;
  }
  
  .business-block-index .element-26 {
    position: absolute;
    width: 12px;
    height: 32px;
    top: -1px;
    left: -1px;
  }
  
  .business-block-index .element-27 {
    position: absolute;
    width: 105px;
    height: 62px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .element-28 {
    position: absolute;
    width: 107px;
    height: 64px;
    top: -1px;
    left: -1px;
  }
  
  .business-block-index .element-29 {
    position: absolute;
    width: 72px;
    height: 12px;
    top: 40px;
    left: 27px;
    background-image: url(./img/102.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-30 {
    position: absolute;
    width: 21px;
    height: 21px;
    top: 17px;
    left: 56px;
    background-image: url(./img/200.svg);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-31 {
    position: absolute;
    width: 8px;
    height: 21px;
    top: 0;
    left: 7px;
  }
  
  .business-block-index .element-32 {
    position: absolute;
    width: 50px;
    height: 9px;
    top: 129px;
    left: 25px;
  }
  
  .business-block-index .element-33 {
    position: absolute;
    width: 52px;
    height: 11px;
    top: -1px;
    left: -1px;
  }
  
  .business-block-index .element-34 {
    position: absolute;
    width: 16px;
    height: 29px;
    top: 113px;
    left: 26px;
  }
  
  .business-block-index .overlap-3 {
    position: relative;
    height: 29px;
  }
  
  .business-block-index .element-35 {
    position: absolute;
    width: 16px;
    height: 27px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .overlap-4 {
    position: relative;
    height: 27px;
  }
  
  .business-block-index .overlap-5 {
    position: relative;
    height: 28px;
  }
  
  .business-block-index .element-36 {
    position: absolute;
    width: 14px;
    height: 19px;
    top: 9px;
    left: 2px;
  }
  
  .business-block-index .element-37 {
    position: absolute;
    width: 14px;
    height: 5px;
    top: 9px;
    left: 2px;
  }
  
  .business-block-index .element-38 {
    position: absolute;
    width: 7px;
    height: 18px;
    top: 1px;
    left: 0;
  }
  
  .business-block-index .overlap-group-3 {
    position: relative;
    width: 9px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/109.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-39 {
    position: absolute;
    width: 9px;
    height: 20px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .element-40 {
    position: absolute;
    width: 5px;
    height: 17px;
    top: 0;
    left: 6px;
  }
  
  .business-block-index .overlap-6 {
    position: relative;
    width: 7px;
    height: 19px;
    top: -1px;
    left: -1px;
    background-image: url(./img/113.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-41 {
    position: absolute;
    width: 7px;
    height: 19px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .element-42 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 0;
    left: 7px;
  }
  
  .business-block-index .overlap-7 {
    position: relative;
    height: 17px;
  }
  
  .business-block-index .element-43 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .overlap-group-4 {
    position: relative;
    width: 10px;
    height: 19px;
    top: -1px;
    left: -1px;
  }
  
  .business-block-index .element-44 {
    position: absolute;
    width: 7px;
    height: 12px;
    top: 7px;
    left: 0;
  }
  
  .business-block-index .element-45 {
    position: absolute;
    width: 8px;
    height: 11px;
    top: 0;
    left: 2px;
  }
  
  .business-block-index .element-46 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 1px;
    left: 4px;
  }
  
  .business-block-index .element-47 {
    position: absolute;
    width: 11px;
    height: 18px;
    top: 10px;
    left: 1px;
  }
  
  .business-block-index .element-48 {
    position: absolute;
    width: 13px;
    height: 19px;
    top: 9px;
    left: 2px;
  }
  
  .business-block-index .element-49 {
    position: absolute;
    width: 13px;
    height: 4px;
    top: 9px;
    left: 2px;
  }
  
  .business-block-index .overlap-group-5 {
    position: relative;
    width: 9px;
    height: 19px;
    top: -1px;
    left: -1px;
    background-image: url(./img/125.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-50 {
    position: absolute;
    width: 8px;
    height: 18px;
    top: 1px;
    left: 1px;
  }
  
  .business-block-index .overlap-8 {
    position: relative;
    width: 7px;
    height: 19px;
    top: -1px;
    left: -1px;
    background-image: url(./img/128.png);
    background-size: 100% 100%;
  }
  
  .business-block-index .element-51 {
    position: absolute;
    width: 6px;
    height: 18px;
    top: 1px;
    left: 1px;
  }
  
  .business-block-index .element-52 {
    position: absolute;
    width: 6px;
    height: 12px;
    top: 7px;
    left: 0;
  }
  
  .business-block-index .overlap-9 {
    position: relative;
    height: 18px;
  }
  
  .business-block-index .element-53 {
    position: absolute;
    width: 5px;
    height: 10px;
    top: 7px;
    left: 0;
  }
  
  .business-block-index .element-54 {
    position: absolute;
    width: 7px;
    height: 10px;
    top: 0;
    left: 2px;
  }
  
  .business-block-index .element-55 {
    position: absolute;
    width: 4px;
    height: 5px;
    top: 1px;
    left: 4px;
  }
  
  .business-block-index .element-56 {
    position: absolute;
    width: 10px;
    height: 18px;
    top: 10px;
    left: 1px;
  }
  
  .business-block-index .element-57 {
    position: absolute;
    width: 7px;
    height: 15px;
    top: 14px;
    left: 2px;
  }
  
  .business-block-index .overlap-10 {
    position: relative;
    height: 15px;
  }
  
  .business-block-index .element-58 {
    position: absolute;
    width: 7px;
    height: 15px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .overlap-group-6 {
    position: relative;
    width: 9px;
    height: 17px;
    top: -1px;
    left: -1px;
  }
  
  .business-block-index .element-59 {
    position: absolute;
    width: 5px;
    height: 14px;
    top: 2px;
    left: 3px;
  }
  
  .business-block-index .element-60 {
    position: absolute;
    width: 9px;
    height: 5px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .element-61 {
    position: absolute;
    width: 2px;
    height: 4px;
    top: 0;
    left: 2px;
  }
  
  .business-block-index .overlap-11 {
    position: relative;
    width: 8px;
    height: 16px;
  }
  
  .business-block-index .element-62 {
    position: absolute;
    width: 4px;
    height: 13px;
    top: 2px;
    left: 3px;
  }
  
  .business-block-index .element-63 {
    position: absolute;
    width: 8px;
    height: 4px;
    top: 0;
    left: 0;
  }
  
  .business-block-index .element-64 {
    position: absolute;
    width: 1px;
    height: 3px;
    top: 0;
    left: 2px;
  }
  
  .business-block-index .element-65 {
    position: absolute;
    width: 6px;
    height: 6px;
    top: 16px;
    left: 3px;
  }
  
  .business-block-index .frame-2 {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 32px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .business-block-index .image {
    position: relative;
    width: 435px;
    height: 330px;
    border-radius: 0px 40px 0px 40px;
    box-shadow: inset -12px -12px 0px 8px #1813ab;
    background-image: url(./img/image-02.png);
    background-size: cover;
    background-position: 50% 50%;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .business-block-index .image:hover {
    transform: scale(1.01);
    box-shadow: inset -12px -12px 0px 8px #1813ab, 0 8px 24px rgba(24, 19, 171, 0.2);
  }
  
  .business-block-index .label {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 4px;
    position: relative;
    flex: 0 0 auto;
    background-color: #ffffff;
  }
  
  .business-block-index .name {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .business-block-index .right {
    display: flex;
    flex-direction: column;
    width: 600px;
    align-items: flex-end;
    justify-content: space-between;
    position: relative;
    align-self: stretch;
  }
  
  .business-block-index .frame-3 {
    display: flex;
    flex-direction: column;
    width: 600px;
    align-items: flex-start;
    position: relative;
    flex: 0 0 auto;
  }
  
  .business-block-index .business-list {
    display: flex;
    height: 88px;
    align-items: center;
    justify-content: space-between;
    padding: 0px 16px 0px 32px;
    position: relative;
    align-self: stretch;
    width: 100%;
    background-color: #ffffff;
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-color: #a7b1ff;
    transition: background-color 0.2s ease;
    cursor: pointer;
  }
  
  .business-block-index .business-list:hover {
    background-color: rgba(167, 177, 255, 0.05);
  }
  
  .business-block-index .frame-4 {
    display: flex;
    width: 336.5px;
    align-items: center;
    gap: 16px;
    position: relative;
  }
  
  .business-block-index .img-2 {
    position: relative;
    width: 30px;
    height: 30px;
  }
  
  .business-block-index .name-2 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 20px;
    letter-spacing: 2.5%;
    line-height: 1.6em;
    white-space: nowrap;
  }
  
  .business-block-index .chevrons-right {
    position: relative;
    width: 12px;
    height: 12px;
  }
  
  .business-block-index .button {
    all: unset;
    box-sizing: border-box;
    display: inline-flex;
    height: 48px;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 24px;
    position: relative;
    background-color: #ffffff;
    border-radius: 4px;
    border: 1px solid;
    border-color: #767fff;
    transition: all 0.2s ease;
    cursor: pointer;
    margin-top: 20px;
  }
  
  .business-block-index .button:hover {
    background-color: #d0d3ff;
    color: #ffffff;
    transform: translateY(-1px);
  }
  
  .business-block-index .label-2 {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .business-block-index .chevrons-right-2 {
    position: relative;
    width: 24px;
    height: 24px;
  }

  @media (max-width: 1024px) {
    .business-block-index {
      padding: 60px 80px 80px;
    }
    
    .business-block-index .image {
      width: 380px;
      height: 290px;
    }
    
    .business-block-index .right {
      width: 100%;
    }

    .business-block-index .frame-3 {
      width: 100%;
    }
  }

  @media (max-width: 768px) {
    .business-block-index {
      padding: 60px 24px;
    }
    
    .business-block-index .div,
    .business-block-index .text-wrapper,
    .business-block-index .span {
      font-size: 32px;
      text-align: center;
    }
    
    .business-block-index .frame {
      flex-direction: column;
      align-items: center;
      gap: 40px;
    }
    
    .business-block-index .left {
      order: 2;
      align-items: center;
      text-align: center;
    }
    
    .business-block-index .right {
      order: 1;
      width: 100%;
      align-items: stretch;
    }
    
    .business-block-index .frame-3 {
      width: 100%;
    }
    
    .business-block-index .image {
      width: 100%;
      max-width: 320px;
      height: 240px;
    }
    
    .business-block-index .frame-2 {
      align-items: center;
    }
    
    .business-block-index .teitan {
      align-self: center;
    }
  }
  .kv-advantage {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    align-items: flex-start;
    position: relative;
    background: linear-gradient(124.34deg, #FFFFFF 43.58%, #1813AB 50%);
    background-size: cover;
    background-position: 50% 50%;
    min-height: 100vh;
    padding: 0;
  }
  
  .kv-advantage .kv-block {
    display: flex;
    width: 100%;
    align-items: flex-start;
    padding: 0px 0px 64px;
    position: relative;
    flex: 0 0 auto;
    min-height: calc(100vh - 64px);
  }
  
  .kv-advantage .frame {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: space-between;
    padding: 48px 0px 0px 48px;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
    gap: 64px;
    width: 713px;
  }
  
  .kv-advantage .image {
    position: relative;
    width: 665px;
    height: 800px;
    border-radius: 0px 40px 0px 40px;
    background-image: url(./img/image-01.png);
    background-size: cover;
    background-position: 50% 50%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    flex: 0 0 auto;
  }
  
  .kv-advantage .image:hover {
    transform: scale(1.02);
    box-shadow: 0 8px 32px rgba(13, 5, 210, 0.2);
  }
  
  .kv-advantage .navigationbar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 0px 0px 0px 48px;
    position: relative;
    align-self: stretch;
    width: 665px;
    flex: 0 0 auto;
  }
  
  .kv-advantage .bar {
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
    flex: 0 0 auto;
    width: 392px;
    height: 0px;
  }
  
  .kv-advantage .counter {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    padding: 2px 0px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .kv-advantage .number {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 400;
    color: #ffffff;
    font-size: 1.25em;
    text-align: center;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .kv-advantage .text-wrapper {
    position: relative;
    width: fit-content;
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 400;
    color: #ffffff;
    font-size: 1em;
    text-align: center;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .kv-advantage .div {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Prompt", Helvetica, sans-serif;
    font-weight: 400;
    color: #ced5ff;
    font-size: 1.25em;
    text-align: right;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .kv-advantage .right {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 96px;
    padding: 120px 80px 0px 96px;
    position: relative;
    flex: 1;
    flex-grow: 1;
  }
  
  .kv-advantage .copy {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    position: relative;
    align-self: stretch;
    width: 100%;
    flex: 0 0 auto;
  }
  
  .kv-advantage .p {
    position: relative;
    align-self: stretch;
    margin-top: -1.12px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 500;
    color: #0d05d2;
    font-size: 5.25em;
    letter-spacing: 3%;
    line-height: 1.3em;
  }
  
  .kv-advantage .span {
    color: #0d05d2;
    letter-spacing: 3%;
  }
  
  .kv-advantage .text-wrapper-2 {
    color: #0d05d2;
    font-size: 5.125em;
    letter-spacing: 3%;
    line-height: 1.3em;
  }
  
  .kv-advantage .div-2 {
    position: relative;
    align-self: stretch;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 500;
    color: #0d05d2;
    font-size: 5.25em;
    text-align: right;
    letter-spacing: 3%;
    line-height: 1.3em;
  }
  
  .kv-advantage .text-wrapper-3 {
    color: #0d05d2;
    font-size: 5em;
    letter-spacing: 3%;
    line-height: 1.3em;
  }
  
  .kv-advantage .image-2 {
    border-radius: 0px 40px 0px 40px;
    position: relative;
    width: 448px;
    height: 529px;
    background-image: url(./img/image.png);
    background-size: cover;
    background-position: 50% 50%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .kv-advantage .image-2:hover {
    transform: scale(1.02);
    box-shadow: 0 8px 32px rgba(13, 5, 210, 0.2);
  }
  
  .kv-advantage .teitan {
    position: absolute;
    width: 238px;
    height: 210px;
    top: 665px;
    left: 601px;
    transition: transform 0.3s ease;
  }
  
  .kv-advantage .teitan:hover {
    transform: scale(1.05) rotate(2deg);
  }
  
  .kv-advantage .overlap {
    position: relative;
    width: 245px;
    height: 201px;
    top: 9px;
  }
  
  .kv-advantage .group {
    position: absolute;
    width: 150px;
    height: 143px;
    top: 58px;
    left: 95px;
  }
  
  .kv-advantage .overlap-group {
    position: relative;
    width: 112px;
    height: 107px;
    top: 20px;
    left: 20px;
    background-image: url(./img/image.svg);
    background-size: 100% 100%;
  }
  
  .kv-advantage .text-wrapper-4 {
    position: absolute;
    top: 28px;
    left: 24px;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 0.75em;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.5em;
  }
  
  .kv-advantage .element {
    position: absolute;
    width: 131px;
    height: 156px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-2 {
    position: relative;
    height: 156px;
  }
  
  .kv-advantage .overlap-wrapper {
    position: absolute;
    width: 125px;
    height: 156px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-3 {
    position: relative;
    width: 126px;
    height: 157px;
  }
  
  .kv-advantage .img {
    position: absolute;
    width: 44px;
    height: 27px;
    top: 81px;
    left: 82px;
  }
  
  .kv-advantage .element-2 {
    position: absolute;
    width: 30px;
    height: 25px;
    top: 84px;
    left: 82px;
  }
  
  .kv-advantage .element-3 {
    position: absolute;
    width: 30px;
    height: 36px;
    top: 89px;
    left: 23px;
  }
  
  .kv-advantage .element-4 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 11px;
    left: 21px;
  }
  
  .kv-advantage .element-5 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 11px;
    left: 93px;
  }
  
  .kv-advantage .element-6 {
    position: absolute;
    width: 55px;
    height: 69px;
    top: 87px;
    left: 41px;
  }
  
  .kv-advantage .element-wrapper {
    position: absolute;
    width: 51px;
    height: 15px;
    top: 135px;
    left: 43px;
  }
  
  .kv-advantage .element-7 {
    position: absolute;
    width: 53px;
    height: 17px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-8 {
    position: absolute;
    width: 55px;
    height: 48px;
    top: 89px;
    left: 41px;
  }
  
  .kv-advantage .element-9 {
    position: absolute;
    width: 2px;
    height: 38px;
    top: 96px;
    left: 68px;
  }
  
  .kv-advantage .element-10 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 110px;
    left: 50px;
  }
  
  .kv-advantage .element-11 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 110px;
    left: 77px;
  }
  
  .kv-advantage .element-12 {
    position: absolute;
    width: 96px;
    height: 78px;
    top: 17px;
    left: 20px;
  }
  
  .kv-advantage .element-13 {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 56px;
    left: 86px;
  }
  
  .kv-advantage .element-14 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 58px;
    left: 93px;
  }
  
  .kv-advantage .element-15 {
    position: absolute;
    width: 16px;
    height: 16px;
    top: 56px;
    left: 33px;
  }
  
  .kv-advantage .element-16 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 59px;
    left: 40px;
  }
  
  .kv-advantage .element-17 {
    position: absolute;
    width: 16px;
    height: 20px;
    top: 66px;
    left: 60px;
  }
  
  .kv-advantage .element-18 {
    position: absolute;
    width: 45px;
    height: 25px;
    top: 91px;
    left: 45px;
  }
  
  .kv-advantage .img-wrapper {
    position: absolute;
    width: 13px;
    height: 13px;
    top: 98px;
    left: 71px;
    background-image: url(./img/159.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-19 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 3px;
    left: 3px;
  }
  
  .kv-advantage .element-20 {
    position: absolute;
    width: 20px;
    height: 18px;
    top: 101px;
    left: 21px;
  }
  
  .kv-advantage .overlap-group-wrapper {
    position: absolute;
    width: 60px;
    height: 30px;
    top: 114px;
    left: 41px;
  }
  
  .kv-advantage .overlap-4 {
    position: relative;
    height: 30px;
  }
  
  .kv-advantage .div-wrapper {
    position: absolute;
    width: 60px;
    height: 28px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-5 {
    position: relative;
    width: 61px;
    height: 28px;
    left: -1px;
  }
  
  .kv-advantage .element-21 {
    position: absolute;
    width: 52px;
    height: 11px;
    top: 13px;
    left: 0;
  }
  
  .kv-advantage .element-22 {
    position: absolute;
    width: 16px;
    height: 28px;
    top: 0;
    left: 44px;
  }
  
  .kv-advantage .overlap-6 {
    position: relative;
    height: 28px;
  }
  
  .kv-advantage .element-23 {
    position: absolute;
    width: 16px;
    height: 28px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-7 {
    position: relative;
    height: 29px;
  }
  
  .kv-advantage .element-24 {
    position: absolute;
    width: 14px;
    height: 20px;
    top: 9px;
    left: 0;
  }
  
  .kv-advantage .element-25 {
    position: absolute;
    width: 14px;
    height: 5px;
    top: 9px;
    left: 0;
  }
  
  .kv-advantage .element-26 {
    position: absolute;
    width: 8px;
    height: 18px;
    top: 1px;
    left: 8px;
  }
  
  .kv-advantage .overlap-group-2 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/162.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-27 {
    position: absolute;
    width: 10px;
    height: 20px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-28 {
    position: absolute;
    width: 5px;
    height: 18px;
    top: 0;
    left: 5px;
  }
  
  .kv-advantage .overlap-8 {
    height: 20px;
    background-image: url(./img/166.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-29 {
    position: absolute;
    width: 7px;
    height: 20px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-30 {
    position: absolute;
    width: 9px;
    height: 18px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-9 {
    position: relative;
    height: 18px;
  }
  
  .kv-advantage .overlap-group-3 {
    position: relative;
    width: 11px;
    height: 20px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-31 {
    position: absolute;
    width: 7px;
    height: 12px;
    top: 8px;
    left: 4px;
  }
  
  .kv-advantage .element-32 {
    position: absolute;
    width: 9px;
    height: 11px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-33 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 1px;
    left: 1px;
  }
  
  .kv-advantage .element-34 {
    position: absolute;
    width: 11px;
    height: 19px;
    top: 10px;
    left: 4px;
  }
  
  .kv-advantage .element-35 {
    position: absolute;
    width: 13px;
    height: 19px;
    top: 9px;
    left: 1px;
  }
  
  .kv-advantage .element-36 {
    position: absolute;
    width: 13px;
    height: 4px;
    top: 9px;
    left: 1px;
  }
  
  .kv-advantage .overlap-group-4 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/178.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-37 {
    position: absolute;
    width: 8px;
    height: 19px;
    top: 1px;
    left: 1px;
  }
  
  .kv-advantage .overlap-10 {
    height: 20px;
    background-image: url(./img/181.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-38 {
    position: absolute;
    width: 6px;
    height: 18px;
    top: 1px;
    left: 1px;
  }
  
  .kv-advantage .overlap-group-5 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-39 {
    position: absolute;
    width: 8px;
    height: 11px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-40 {
    position: absolute;
    width: 5px;
    height: 11px;
    top: 8px;
    left: 4px;
  }
  
  .kv-advantage .element-41 {
    position: absolute;
    width: 7px;
    height: 10px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-42 {
    position: absolute;
    width: 4px;
    height: 6px;
    top: 1px;
    left: 1px;
  }
  
  .kv-advantage .element-43 {
    position: absolute;
    width: 11px;
    height: 18px;
    top: 11px;
    left: 4px;
  }
  
  .kv-advantage .element-44 {
    position: absolute;
    width: 7px;
    height: 16px;
    top: 14px;
    left: 50px;
  }
  
  .kv-advantage .overlap-11 {
    position: relative;
    height: 16px;
  }
  
  .kv-advantage .element-45 {
    position: absolute;
    width: 7px;
    height: 16px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-group-6 {
    position: relative;
    width: 9px;
    height: 17px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-46 {
    position: absolute;
    width: 5px;
    height: 15px;
    top: 2px;
    left: 1px;
  }
  
  .kv-advantage .element-47 {
    position: absolute;
    width: 9px;
    height: 5px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-48 {
    position: absolute;
    width: 2px;
    height: 4px;
    top: 0;
    left: 5px;
  }
  
  .kv-advantage .overlap-12 {
    position: relative;
    width: 8px;
    height: 16px;
  }
  
  .kv-advantage .element-49 {
    position: absolute;
    width: 4px;
    height: 14px;
    top: 2px;
    left: 1px;
  }
  
  .kv-advantage .element-50 {
    position: absolute;
    width: 8px;
    height: 4px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-51 {
    position: absolute;
    width: 1px;
    height: 3px;
    top: 0;
    left: 5px;
  }
  
  .kv-advantage .element-52 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 17px;
    left: 50px;
  }
  
  .kv-advantage .element-53 {
    position: absolute;
    width: 105px;
    height: 84px;
    top: 0;
    left: 15px;
  }
  
  .kv-advantage .overlap-group-7 {
    position: relative;
    height: 84px;
  }
  
  .kv-advantage .element-54 {
    position: absolute;
    width: 105px;
    height: 84px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-55 {
    position: absolute;
    width: 92px;
    height: 32px;
    top: 52px;
    left: 7px;
  }
  
  .kv-advantage .element-56 {
    position: absolute;
    width: 12px;
    height: 32px;
    top: 0;
    left: 80px;
  }
  
  .kv-advantage .element-57 {
    position: absolute;
    width: 12px;
    height: 32px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-58 {
    position: absolute;
    width: 105px;
    height: 62px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-59 {
    position: absolute;
    width: 107px;
    height: 64px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-60 {
    position: absolute;
    width: 73px;
    height: 9px;
    top: 41px;
    left: 16px;
  }
  
  .kv-advantage .element-61 {
    position: absolute;
    width: 22px;
    height: 22px;
    top: 17px;
    left: 42px;
    background-image: url(./img/372.svg);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-62 {
    position: absolute;
    width: 8px;
    height: 21px;
    top: 0;
    left: 7px;
  }
  
  .kv-advantage .element-63 {
    position: absolute;
    width: 48px;
    height: 45px;
    top: 71px;
    left: 0;
  }
  
  .kv-advantage .overlap-13 {
    position: relative;
    width: 49px;
    height: 46px;
    background-image: url(./img/67.svg);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-64 {
    position: absolute;
    width: 39px;
    height: 37px;
    top: 5px;
    left: 5px;
  }
  
  .kv-advantage .element-65 {
    position: absolute;
    width: 6px;
    height: 10px;
    top: 11px;
    left: 5px;
  }
  
  .kv-advantage .element-66 {
    position: absolute;
    width: 23px;
    height: 23px;
    top: 12px;
    left: 13px;
  }
  
  .kv-advantage .overlap-group-8 {
    position: relative;
    width: 24px;
    height: 24px;
    top: -1px;
  }
  
  .kv-advantage .element-67 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-68 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 2px;
    left: 5px;
  }
  
  .kv-advantage .element-69 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 4px;
    left: 10px;
  }
  
  .kv-advantage .element-70 {
    position: absolute;
    width: 9px;
    height: 17px;
    top: 6px;
    left: 15px;
  }
  
  .kv-advantage .element-71 {
    position: absolute;
    width: 11px;
    height: 16px;
    top: 9px;
    left: 5px;
  }
  
  .kv-advantage .element-72 {
    position: absolute;
    width: 20px;
    height: 17px;
    top: 101px;
    left: 22px;
  }
  
  .kv-advantage .element-73 {
    position: absolute;
    width: 20px;
    height: 34px;
    top: 61px;
    left: 111px;
  }
  
  .kv-advantage .overlap-14 {
    position: relative;
    width: 21px;
    height: 36px;
    top: -1px;
    left: -1px;
    background-image: url(./img/215.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-74 {
    position: absolute;
    width: 21px;
    height: 35px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-75 {
    position: absolute;
    width: 7px;
    height: 7px;
    top: 83px;
    left: 110px;
  }
  
  .kv-advantage .advantage-block {
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    align-items: center;
    gap: 40px;
    padding: 96px 120px 160px;
    position: relative;
    background-image: url(./img/advantage-block.svg);
    background-size: cover;
    background-position: 50% 50%;
    min-height: 782px;
  }
  
  .kv-advantage .frame-2 {
    width: 100%;
    max-width: 1140px;
    justify-content: center;
    gap: 160px;
    display: flex;
    align-items: stretch;
    position: relative;
    flex: 0 0 auto;
  }
  
  .kv-advantage .left {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: space-between;
    position: relative;
    flex: 1;
    align-self: stretch;
    border-radius: 16px;
    background-color: rgba(255, 255, 255, 0.86);
    padding: 40px;
    gap: 64px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .kv-advantage .left:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 64px rgba(13, 5, 210, 0.15);
  }
  
  .kv-advantage .frame-3 {
    flex-direction: column;
    gap: 64px;
    align-self: stretch;
    width: 100%;
    display: flex;
    align-items: flex-start;
    position: relative;
    flex: 0 0 auto;
  }
  
  .kv-advantage .title {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .kv-advantage .title-2 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: var(--typography-title-lg-font-family);
    font-weight: var(--typography-title-lg-font-weight);
    color: transparent;
    font-size: var(--typography-title-lg-font-size);
    text-align: center;
    letter-spacing: var(--typography-title-lg-letter-spacing);
    line-height: var(--typography-title-lg-line-height);
    white-space: nowrap;
    font-style: var(--typography-title-lg-font-style);
  }
  
  .kv-advantage .text-wrapper-5 {
    color: #ced5ff;
    letter-spacing: 10%;
    font-family: "Kanit", Helvetica, sans-serif;
    font-style: normal;
    font-weight: 600;
    line-height: 1.17em;
    font-size: 0.75em;
  }
  
  .kv-advantage .text-wrapper-6 {
    color: #ffffff;
    letter-spacing: 10%;
    font-family: "Kanit", Helvetica, sans-serif;
    font-style: normal;
    font-weight: 600;
    line-height: 1.17em;
    font-size: 0.75em;
  }
  
  .kv-advantage .title-eg {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .kv-advantage .zap {
    position: relative;
    width: 18px;
    height: 18px;
  }
  
  .kv-advantage .text-wrapper-7 {
    position: relative;
    width: fit-content;
    margin-top: -1.00px;
    font-family: "Kanit", Helvetica, sans-serif;
    font-weight: 400;
    color: #ffffff;
    font-size: 1.25em;
    text-align: center;
    letter-spacing: 3%;
    line-height: 1.5em;
    white-space: nowrap;
  }
  
  .kv-advantage .text-wrapper-8 {
    position: relative;
    align-self: stretch;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    color: #ffffff;
    font-size: 1em;
    letter-spacing: 3%;
    line-height: 1.75em;
  }
  
  .kv-advantage .button {
    all: unset;
    box-sizing: border-box;
    display: inline-flex;
    height: 48px;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 8px 24px;
    position: relative;
    background-color: #ffffff;
    border-radius: 4px;
    border: 1px solid;
    border-color: #767fff;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  
  .kv-advantage .button:hover {
    background-color: #767fff;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(118, 127, 255, 0.3);
  }
  
  .kv-advantage .button:hover .label {
    color: #ffffff;
  }
  
  .kv-advantage .label {
    position: relative;
    width: fit-content;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 0.875em;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
    transition: color 0.3s ease;
  }
  
  .kv-advantage .chevrons-right {
    position: relative;
    width: 24px;
    height: 24px;
  }
  
  .kv-advantage .image-3 {
    border-radius: 40px 0px 40px 0px;
    transform: rotate(180deg);
    position: relative;
    width: 448px;
    height: 529px;
    background-image: url(./img/image-01-2.png);
    background-size: cover;
    background-position: 50% 50%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }
  
  .kv-advantage .image-3:hover {
    transform: rotate(180deg) scale(1.02);
    box-shadow: 0 16px 64px rgba(13, 5, 210, 0.2);
  }
  
  .kv-advantage .teitan-2 {
    position: absolute;
    width: 364px;
    height: 160px;
    top: 465px;
    left: 695px;
    transition: transform 0.3s ease;
  }
  
  .kv-advantage .teitan-2:hover {
    transform: scale(1.05) rotate(-2deg);
  }
  
  .kv-advantage .overlap-15 {
    position: absolute;
    width: 243px;
    height: 175px;
    top: -17px;
    left: 0;
  }
  
  .kv-advantage .group-2 {
    position: absolute;
    width: 156px;
    height: 150px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-group-9 {
    position: relative;
    width: 106px;
    height: 105px;
    top: 20px;
    left: 20px;
    background-image: url(./img/lt-gt.svg);
    background-size: 100% 100%;
  }
  
  .kv-advantage .text-wrapper-9 {
    position: absolute;
    top: 39px;
    left: 10px;
    -webkit-text-stroke: 1px #006ace;
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    color: #0d05d2;
    font-size: 0.75em;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.5em;
  }
  
  .kv-advantage .element-76 {
    position: absolute;
    width: 106px;
    height: 153px;
    top: 22px;
    left: 137px;
  }
  
  .kv-advantage .overlap-16 {
    position: relative;
    height: 154px;
  }
  
  .kv-advantage .element-77 {
    position: absolute;
    width: 13px;
    height: 13px;
    top: 131px;
    left: 74px;
  }
  
  .kv-advantage .element-78 {
    position: absolute;
    width: 54px;
    height: 64px;
    top: 90px;
    left: 31px;
  }
  
  .kv-advantage .element-79 {
    position: absolute;
    width: 54px;
    height: 24px;
    top: 123px;
    left: 31px;
  }
  
  .kv-advantage .element-80 {
    position: absolute;
    width: 54px;
    height: 42px;
    top: 90px;
    left: 31px;
  }
  
  .kv-advantage .element-81 {
    position: absolute;
    width: 2px;
    height: 38px;
    top: 93px;
    left: 57px;
  }
  
  .kv-advantage .element-82 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 106px;
    left: 40px;
  }
  
  .kv-advantage .element-83 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 106px;
    left: 64px;
  }
  
  .kv-advantage .element-84 {
    position: absolute;
    width: 97px;
    height: 79px;
    top: 19px;
    left: 5px;
  }
  
  .kv-advantage .element-85 {
    position: absolute;
    width: 15px;
    height: 18px;
    top: 74px;
    left: 47px;
  }
  
  .kv-advantage .element-86 {
    position: absolute;
    width: 16px;
    height: 9px;
    top: 67px;
    left: 24px;
  }
  
  .kv-advantage .element-87 {
    position: absolute;
    width: 16px;
    height: 10px;
    top: 60px;
    left: 67px;
  }
  
  .kv-advantage .element-88 {
    position: absolute;
    width: 46px;
    height: 24px;
    top: 92px;
    left: 31px;
  }
  
  .kv-advantage .element-89 {
    position: absolute;
    width: 13px;
    height: 12px;
    top: 99px;
    left: 58px;
    background-image: url(./img/359.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-90 {
    position: absolute;
    width: 6px;
    height: 6px;
    top: 3px;
    left: 4px;
  }
  
  .kv-advantage .element-91 {
    position: absolute;
    width: 14px;
    height: 7px;
    top: 69px;
    left: 78px;
  }
  
  .kv-advantage .element-92 {
    position: absolute;
    width: 14px;
    height: 7px;
    top: 77px;
    left: 16px;
  }
  
  .kv-advantage .element-93 {
    position: absolute;
    width: 24px;
    height: 25px;
    top: 17px;
    left: 0;
  }
  
  .kv-advantage .element-94 {
    position: absolute;
    width: 23px;
    height: 25px;
    top: 10px;
    left: 72px;
  }
  
  .kv-advantage .element-95 {
    position: absolute;
    width: 60px;
    height: 30px;
    top: 112px;
    left: 26px;
  }
  
  .kv-advantage .overlap-17 {
    width: 61px;
    position: relative;
    height: 28px;
  }
  
  .kv-advantage .element-96 {
    position: absolute;
    width: 52px;
    height: 11px;
    top: 13px;
    left: 9px;
  }
  
  .kv-advantage .element-97 {
    position: absolute;
    width: 14px;
    height: 20px;
    top: 9px;
    left: 2px;
  }
  
  .kv-advantage .element-98 {
    position: absolute;
    width: 14px;
    height: 5px;
    top: 9px;
    left: 2px;
  }
  
  .kv-advantage .element-99 {
    position: absolute;
    width: 8px;
    height: 18px;
    top: 1px;
    left: 0;
  }
  
  .kv-advantage .overlap-group-10 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/364.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-100 {
    position: absolute;
    width: 5px;
    height: 18px;
    top: 0;
    left: 6px;
  }
  
  .kv-advantage .overlap-18 {
    height: 20px;
    background-image: url(./img/368.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-101 {
    position: absolute;
    width: 9px;
    height: 18px;
    top: 0;
    left: 8px;
  }
  
  .kv-advantage .element-102 {
    position: absolute;
    width: 7px;
    height: 12px;
    top: 8px;
    left: 0;
  }
  
  .kv-advantage .element-103 {
    position: absolute;
    width: 9px;
    height: 11px;
    top: 0;
    left: 2px;
  }
  
  .kv-advantage .element-104 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 1px;
    left: 4px;
  }
  
  .kv-advantage .element-105 {
    position: absolute;
    width: 11px;
    height: 19px;
    top: 10px;
    left: 1px;
  }
  
  .kv-advantage .element-106 {
    position: absolute;
    width: 13px;
    height: 19px;
    top: 9px;
    left: 2px;
  }
  
  .kv-advantage .element-107 {
    position: absolute;
    width: 13px;
    height: 4px;
    top: 9px;
    left: 2px;
  }
  
  .kv-advantage .overlap-group-11 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/380.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .overlap-19 {
    height: 20px;
    background-image: url(./img/383.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-108 {
    position: absolute;
    width: 8px;
    height: 11px;
    top: 0;
    left: 2px;
  }
  
  .kv-advantage .element-109 {
    position: absolute;
    width: 5px;
    height: 11px;
    top: 8px;
    left: 0;
  }
  
  .kv-advantage .element-110 {
    position: absolute;
    width: 7px;
    height: 10px;
    top: 0;
    left: 2px;
  }
  
  .kv-advantage .element-111 {
    position: absolute;
    width: 4px;
    height: 6px;
    top: 1px;
    left: 4px;
  }
  
  .kv-advantage .element-112 {
    position: absolute;
    width: 11px;
    height: 18px;
    top: 11px;
    left: 1px;
  }
  
  .kv-advantage .element-113 {
    position: absolute;
    width: 7px;
    height: 16px;
    top: 14px;
    left: 2px;
  }
  
  .kv-advantage .element-114 {
    position: absolute;
    width: 5px;
    height: 15px;
    top: 2px;
    left: 3px;
  }
  
  .kv-advantage .element-115 {
    position: absolute;
    width: 2px;
    height: 4px;
    top: 0;
    left: 2px;
  }
  
  .kv-advantage .element-116 {
    position: absolute;
    width: 4px;
    height: 14px;
    top: 2px;
    left: 3px;
  }
  
  .kv-advantage .element-117 {
    position: absolute;
    width: 1px;
    height: 3px;
    top: 0;
    left: 2px;
  }
  
  .kv-advantage .element-118 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 17px;
    left: 3px;
  }
  
  .kv-advantage .element-119 {
    position: absolute;
    width: 105px;
    height: 89px;
    top: 0;
    left: 1px;
  }
  
  .kv-advantage .overlap-group-12 {
    position: relative;
    height: 89px;
  }
  
  .kv-advantage .element-120 {
    position: absolute;
    width: 105px;
    height: 89px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-121 {
    position: absolute;
    width: 92px;
    height: 40px;
    top: 48px;
    left: 6px;
  }
  
  .kv-advantage .element-122 {
    position: absolute;
    width: 9px;
    height: 32px;
    top: 0;
    left: 83px;
  }
  
  .kv-advantage .element-123 {
    position: absolute;
    width: 16px;
    height: 31px;
    top: 9px;
    left: 0;
  }
  
  .kv-advantage .element-124 {
    position: absolute;
    width: 105px;
    height: 68px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-125 {
    position: absolute;
    width: 107px;
    height: 70px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-126 {
    position: absolute;
    width: 73px;
    height: 15px;
    top: 40px;
    left: 15px;
  }
  
  .kv-advantage .element-127 {
    position: absolute;
    width: 22px;
    height: 22px;
    top: 17px;
    left: 38px;
    background-image: url(./img/742.svg);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-128 {
    position: absolute;
    width: 6px;
    height: 21px;
    top: 0;
    left: 8px;
  }
  
  .kv-advantage .element-129 {
    position: absolute;
    width: 22px;
    height: 33px;
    top: 80px;
    left: 16px;
  }
  
  .kv-advantage .element-130 {
    position: absolute;
    width: 21px;
    height: 23px;
    top: 89px;
    left: 18px;
  }
  
  .kv-advantage .element-131 {
    position: absolute;
    width: 22px;
    height: 35px;
    top: 76px;
    left: 73px;
  }
  
  .kv-advantage .element-132 {
    position: absolute;
    width: 21px;
    height: 25px;
    top: 86px;
    left: 73px;
  }
  
  .kv-advantage .element-133 {
    position: absolute;
    width: 107px;
    height: 154px;
    top: 6px;
    left: 257px;
  }
  
  .kv-advantage .overlap-20 {
    position: relative;
    height: 155px;
  }
  
  .kv-advantage .element-134 {
    position: absolute;
    width: 18px;
    height: 42px;
    top: 95px;
    left: 55px;
  }
  
  .kv-advantage .element-135 {
    position: absolute;
    width: 16px;
    height: 29px;
    top: 95px;
    left: 55px;
  }
  
  .kv-advantage .element-136 {
    position: absolute;
    width: 28px;
    height: 29px;
    top: 78px;
    left: 2px;
  }
  
  .kv-advantage .element-137 {
    position: absolute;
    width: 26px;
    height: 20px;
    top: 87px;
    left: 3px;
  }
  
  .kv-advantage .element-138 {
    position: absolute;
    width: 41px;
    height: 28px;
    top: 75px;
    left: 2px;
  }
  
  .kv-advantage .element-139 {
    position: absolute;
    width: 49px;
    height: 66px;
    top: 88px;
    left: 14px;
  }
  
  .kv-advantage .element-140 {
    position: absolute;
    width: 49px;
    height: 23px;
    top: 126px;
    left: 14px;
  }
  
  .kv-advantage .element-141 {
    position: absolute;
    width: 49px;
    height: 44px;
    top: 89px;
    left: 14px;
  }
  
  .kv-advantage .element-142 {
    position: absolute;
    width: 2px;
    height: 38px;
    top: 95px;
    left: 37px;
  }
  
  .kv-advantage .element-143 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 108px;
    left: 21px;
  }
  
  .kv-advantage .element-144 {
    position: absolute;
    width: 11px;
    height: 13px;
    top: 108px;
    left: 45px;
  }
  
  .kv-advantage .element-145 {
    position: absolute;
    width: 6px;
    height: 7px;
    top: 123px;
    left: 62px;
  }
  
  .kv-advantage .element-146 {
    position: absolute;
    width: 44px;
    height: 34px;
    top: 90px;
    left: 20px;
  }
  
  .kv-advantage .element-147 {
    position: absolute;
    width: 13px;
    height: 13px;
    top: 105px;
    left: 41px;
    background-image: url(./img/293.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-148 {
    position: absolute;
    width: 23px;
    height: 24px;
    top: 11px;
    left: 15px;
  }
  
  .kv-advantage .element-149 {
    position: absolute;
    width: 23px;
    height: 24px;
    top: 29px;
    left: 84px;
  }
  
  .kv-advantage .element-150 {
    position: absolute;
    width: 95px;
    height: 80px;
    top: 23px;
    left: 1px;
  }
  
  .kv-advantage .element-151 {
    position: absolute;
    width: 17px;
    height: 20px;
    top: 68px;
    left: 37px;
  }
  
  .kv-advantage .element-152 {
    position: absolute;
    width: 16px;
    height: 10px;
    top: 55px;
    left: 19px;
  }
  
  .kv-advantage .element-153 {
    position: absolute;
    width: 16px;
    height: 10px;
    top: 64px;
    left: 61px;
  }
  
  .kv-advantage .element-154 {
    position: absolute;
    width: 14px;
    height: 7px;
    top: 75px;
    left: 70px;
  }
  
  .kv-advantage .element-155 {
    position: absolute;
    width: 14px;
    height: 7px;
    top: 62px;
    left: 10px;
  }
  
  .kv-advantage .element-156 {
    position: absolute;
    width: 22px;
    height: 2px;
    top: 58px;
    left: 63px;
  }
  
  .kv-advantage .element-157 {
    position: absolute;
    width: 19px;
    height: 13px;
    top: 40px;
    left: 22px;
  }
  
  .kv-advantage .element-158 {
    position: absolute;
    width: 59px;
    height: 29px;
    top: 114px;
    left: 5px;
  }
  
  .kv-advantage .element-159 {
    position: absolute;
    width: 59px;
    height: 28px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-21 {
    width: 60px;
    position: relative;
    height: 28px;
  }
  
  .kv-advantage .element-160 {
    position: absolute;
    width: 51px;
    height: 11px;
    top: 13px;
    left: 9px;
  }
  
  .kv-advantage .overlap-group-13 {
    position: relative;
    width: 10px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/302.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .overlap-22 {
    height: 20px;
    background-image: url(./img/306.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-161 {
    position: absolute;
    width: 7px;
    height: 12px;
    top: 7px;
    left: 0;
  }
  
  .kv-advantage .overlap-group-14 {
    position: relative;
    width: 9px;
    height: 20px;
    top: -1px;
    left: -1px;
    background-image: url(./img/318.png);
    background-size: 100% 100%;
  }
  
  .kv-advantage .element-162 {
    position: absolute;
    width: 8px;
    height: 18px;
    top: 1px;
    left: 1px;
  }
  
  .kv-advantage .overlap-23 {
    height: 19px;
    background-image: url(./img/321.png);
    position: relative;
    width: 7px;
    top: -1px;
    left: -1px;
    background-size: 100% 100%;
  }
  
  .kv-advantage .overlap-group-15 {
    position: relative;
    width: 10px;
    height: 19px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-163 {
    position: absolute;
    width: 6px;
    height: 12px;
    top: 7px;
    left: 0;
  }
  
  .kv-advantage .element-164 {
    position: absolute;
    width: 5px;
    height: 11px;
    top: 7px;
    left: 0;
  }
  
  .kv-advantage .element-165 {
    position: absolute;
    width: 7px;
    height: 15px;
    top: 14px;
    left: 2px;
  }
  
  .kv-advantage .overlap-24 {
    position: relative;
    height: 15px;
  }
  
  .kv-advantage .element-166 {
    position: absolute;
    width: 7px;
    height: 15px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-167 {
    position: absolute;
    width: 102px;
    height: 92px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .overlap-group-16 {
    position: relative;
    height: 92px;
  }
  
  .kv-advantage .element-168 {
    position: absolute;
    width: 92px;
    height: 47px;
    top: 45px;
    left: 5px;
  }
  
  .kv-advantage .element-169 {
    position: absolute;
    width: 17px;
    height: 31px;
    top: 17px;
    left: 76px;
  }
  
  .kv-advantage .element-170 {
    position: absolute;
    width: 9px;
    height: 33px;
    top: -1px;
    left: -1px;
  }

/* サブページメニューボタン */
.subpage-menu-button {
  margin-top: 16px;
  position: relative;
  width: 360px;
}

.menu-dropdown {
  position: relative;
  width: 100%;
  height: 56px;
  background-color: #ffffff;
  border: 1px solid #0d05d2;
  border-radius: 8px;
  padding: 0;
  cursor: pointer;
  transition: all 0.2s ease;
  overflow: visible;
}

.menu-dropdown:hover {
  background-color: #f5f5f5;
}

.menu-dropdown.open {
  background-color: #f5f5f5;
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.menu-dropdown-inner {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 16px;
  height: 100%;
}

.menu-dropdown .chevron-icon {
  width: 14px;
  height: 14px;
  margin-right: 10px;
  transition: transform 0.2s ease;
}

.menu-dropdown.open .chevron-icon {
  transform: rotate(180deg);
}

.menu-dropdown span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  color: #0d05d2;
}

/* ドロップダウンメニュー - position: fixedで対応 */
.menu-dropdown-list {
  background-color: #ffffff;
  border: 1px solid #0d05d2;
  border-top: none;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  display: none;
  overflow: hidden;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  z-index: 99999;
  opacity: 0;
  transform: translateY(-10px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.menu-dropdown-list.show {
  opacity: 1;
  transform: translateY(0);
}

.menu-dropdown-item {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 12px 16px;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-decoration: none;
}

.menu-dropdown-item:hover {
  background-color: #f5f5f5;
}

.menu-dropdown-item .menu-icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.menu-dropdown-item span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0.42px;
  color: #1a1a1a;
  white-space: nowrap;
}
  
  .kv-advantage .element-171 {
    position: absolute;
    width: 102px;
    height: 72px;
    top: 0;
    left: 0;
  }
  
  .kv-advantage .element-172 {
    position: absolute;
    width: 104px;
    height: 74px;
    top: -1px;
    left: -1px;
  }
  
  .kv-advantage .element-173 {
    position: absolute;
    width: 71px;
    height: 22px;
    top: 36px;
    left: 18px;
  }
  
  .kv-advantage .element-174 {
    position: absolute;
    width: 21px;
    height: 21px;
    top: 18px;
    left: 47px;
    background-image: url(./img/634.svg);
    background-size: 100% 100%;
  }

/* 会社概要ブロック */
.company-info-block {
  background-color: #ffffff;
  padding: 96px 0;
  padding-top: 0px;
}

.company-info-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 150px;
}

.company-info-block .section-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  margin-bottom: 48px;
}

.company-info-block .section-title .zap-icon {
  width: 20px;
  height: 20px;
}

.company-info-block .section-title h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.57;
  letter-spacing: 0.56px;
  color: #0d05d2;
  margin: 0;
}

/* テーブルスタイル */
.company-info-table {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.table-row {
  display: flex;
  min-height: 60px;
  border-bottom: 1px solid rgba(13, 5, 210, 0.6);
}

.table-row-multi {
  min-height: auto;
}

.table-header {
  width: 300px;
  background-color: #ffffff;
  padding: 16px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #0d05d2;
  display: flex;
  align-items: flex-start;
}

.table-content {
  flex: 1;
  padding: 16px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #000000;
  display: flex;
  align-items: center;
}

/* 資格セクション用スタイル */
.table-row-multi .table-content {
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  padding: 0;
}

.qualification-section {
  width: 100%;
  padding: 16px;
}

.qualification-section h4 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #000000;
  margin: 0 0 0 8px;
}

.qualification-section p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #000000;
  margin: 0;
}

.qualification-section p.indent {
  margin-left: 24px;
}

.qualification-note {
  width: 100%;
  padding: 16px;
  border-bottom: 1px solid rgba(13, 5, 210, 0.6);
}

.qualification-note p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #000000;
  margin: 0;
}

/* 沿革セクション */
.company-history-block {
  background: #fff;
  padding: 96px 150px;
}

.company-history-inner {
  max-width: 1140px;
  margin: 0 auto;
}

.company-history-block .section-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  margin-bottom: 48px;
}

.company-history-block .section-title .zap-icon {
  width: 20px;
  height: 20px;
}

.company-history-block .section-title h3 {
  font-size: 28px;
  font-weight: 700;
  color: #0d05d2;
  letter-spacing: 0.03em;
}

/* 履歴テーブルラッパー */
.history-table-wrapper {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

/* 履歴テーブルコンテナ */
.history-table-container {
  flex: 1;
  height: 568px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 8px;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none; /* IE and Edge */
}

.history-table-container::-webkit-scrollbar {
  display: none; /* Chrome, Safari, Opera */
}

/* 履歴テーブル */
.history-table {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.history-row {
  display: flex;
  gap: 4px;
  align-items: flex-start;
  min-height: 56px;
}

.history-date {
  width: 300px;
  padding: 16px;
  background: #f1f4ff;
  font-size: 16px;
  font-weight: 700;
  color: #0d05d2;
  letter-spacing: 0.03em;
  line-height: 150%;
  display: flex;
  align-items: center;
}

.history-content {
  flex: 1;
  padding: 16px;
  background: #fff;
  border-bottom: 1px solid rgba(13, 5, 210, 0.6);
  font-size: 16px;
  color: #000;
  letter-spacing: 0.03em;
  line-height: 145%;
  display: flex;
  align-items: center;
}

/* カスタムスクロールバー */
.history-scrollbar {
  width: 8px;
  height: 568px;
  position: relative;
}

.scrollbar-track {
  width: 100%;
  height: 100%;
  background: #eaeaea;
  border-radius: 100px;
  position: relative;
}

.scrollbar-thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 142px; /* 568px / 4 = 142px (表示領域の25%) */
  background: #0d05d2;
  border-radius: 100px;
  cursor: pointer;
  transition: opacity 0.2s;
}

.scrollbar-thumb:hover {
  opacity: 0.8;
}

/* 組織図セクション */
.company-organizational-block {
  background: #fff;
  padding: 96px 150px;
}

.company-organizational-inner {
  max-width: 1140px;
  margin: 0 auto;
}

.company-organizational-block .section-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  margin-bottom: 48px;
}

.company-organizational-block .section-title .zap-icon {
  width: 20px;
  height: 20px;
}

.company-organizational-block .section-title h3 {
  font-size: 28px;
  font-weight: 700;
  color: #0d05d2;
  letter-spacing: 0.03em;
}

.chart-container {
  width: 100%;
  background: #fff;
  border: 1px solid #0d05d2;
  padding: 0;
  overflow: hidden;
}

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

/* 事業所一覧セクション */
.offices-block {
  padding: 96px 150px 0;
  padding-top: 0px;
}

.offices-inner {
  max-width: 1140px;
  margin: 0 auto;
}

.offices-block .section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 48px;
}

.offices-block .section-title .zap-icon {
  width: 20px;
  height: 20px;
}

.offices-block .section-title h3 {
  font-size: 28px;
  font-weight: 700;
  color: #0d05d2;
  letter-spacing: 0.03em;
}

.offices-container {
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.offices-row {
  display: flex;
  gap: 48px;
  justify-content: space-between;
}

.branch-office {
  flex: 1;
  background: #fff;
  border: 1px solid #0d05d2;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  z-index: 101;
}

.office-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid #0d05d2;
}

.office-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px;
}

.office-icon {
  color: #0d05d2;
  font-size: 20px;
  line-height: 1;
}

.office-title h4 {
  font-size: 24px;
  font-weight: 700;
  color: #1a1a1a;
  letter-spacing: 0.03em;
  margin: 0;
}

.office-business {
  display: flex;
  align-items: center;
  gap: 16px;
}

.business-label {
  background: #0d05d2;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 8px;
  border-radius: 1000px;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.business-text {
  font-size: 14px;
  color: #1a1a1a;
  letter-spacing: 0.03em;
}

.office-description {
  font-size: 16px;
  line-height: 1.75;
  color: #1a1a1a;
  letter-spacing: 0.03em;
}

/* 事業所マップセクション */
.offices-map-section {
  background: #f1f4ff;
  padding: 96px 150px;
  padding-top: 150px;
  position: relative;
  top: -75px;
  z-index: 100;
}

.map-wrapper {
  max-width: 1140px;
  margin: 0 auto;
}

.map-image-container {
  background: #fff;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

/* イメージマップのクリッカブルエリア */
area {
  cursor: pointer;
  outline: none;
}

.area-map {
  max-width: 100%;
  height: auto;
  display: block;
}
  
  .kv-advantage .element-175 {
    position: absolute;
    width: 12px;
    height: 19px;
    top: 1px;
    left: 5px;
  }
  /* 通常のヘッダー */
  .header-normal {
    display: flex;
    width: 100%;
    align-items: flex-start;
    position: relative;
    background-color: #ffffff;
  }
  
  /* 固定ヘッダー */
  .header-fixed {
    display: flex;
    width: 100%;
    align-items: flex-start;
    position: fixed;
    top: -100px;
    left: 0;
    right: 0;
    background-color: #ffffff;
    z-index: 9999;
    transition: top 0.3s ease-in-out;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  }
  
  .header-fixed.show {
    top: 0;
  }
  
  /* 共通のヘッダースタイル */
  .header-normal,
  .header-fixed {
    display: flex;
    width: 100%;
    align-items: flex-start;
    background-color: #ffffff;
  }
  
  .header-normal .class,
  .header-fixed .class {
    display: flex;
    width: 100%;
    max-width: 1440px;
    align-items: center;
    justify-content: space-between;
    position: relative;
    background-color: transparent;
    margin: 0 auto;
  }
  
  .header-normal .left,
  .header-fixed .left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 8px;
    padding: 0px 48px;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
    background-color: #ffffff;
  }
  
  .header-normal .logo,
  .header-fixed .logo {
    position: relative;
    width: 240px;
    height: 48px;
    background-image: url(./img/logo.png);
    background-size: cover;
    background-position: 50% 50%;
  }

  .header-normal .logo a,
  .header-fixed .logo a {
    display: block;
    width: 100%;
    height: 100%;
  }

  .header-normal .logo img,
  .header-fixed .logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .header-normal .button .icon i,
  .header-normal .button-2 .icon i,
  .header-fixed .button .icon i,
  .header-fixed .button-2 .icon i {
    color: white;
  }
  
  .header-normal .right,
  .header-fixed .right {
    display: flex;
    align-items: center;
    gap: 32px;
    padding: 24px 48px 24px 0px;
    position: relative;
    flex: 0 0 auto;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
  
  .header-normal .menus,
  .header-fixed .menus {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
    gap: 0;
  }
  
  .header-normal .menu-button,
  .header-fixed .menu-button {
    display: flex;
    align-items: center;
    padding: 4px 16px;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .header-normal .menu-button:hover,
  .header-fixed .menu-button:hover {
    background-color: rgba(26, 26, 26, 0.05);
  }
  
  .header-normal .inner,
  .header-fixed .inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: 2px 0px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .header-normal .value,
  .header-fixed .value {
    width: fit-content;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    position: relative;
    font-family: "Zen Kaku Gothic New", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1.2em;
  }
  
  .header-normal .div,
  .header-fixed .div {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 16px;
    position: relative;
    align-self: stretch;
    flex: 0 0 auto;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .header-normal .div:hover,
  .header-fixed .div:hover {
    background-color: rgba(26, 26, 26, 0.05);
  }
  
  .header-normal .iconex-filled-down,
  .header-fixed .iconex-filled-down {
    position: relative;
    width: 20px;
    height: 20px;
  }
  
  .header-normal .text-wrapper,
  .header-fixed .text-wrapper {
    align-self: stretch;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    position: relative;
    font-family: "Zen Kaku Gothic New", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1em;
  }
  
  .header-normal .value-2,
  .header-fixed .value-2 {
    align-self: stretch;
    position: relative;
    font-family: "Zen Kaku Gothic New", Helvetica, sans-serif;
    font-weight: 700;
    color: #1a1a1a;
    font-size: 16px;
    letter-spacing: 0;
    line-height: 1em;
  }
  
  .header-normal .frame,
  .header-fixed .frame {
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
    flex: 0 0 auto;
  }
  
  .header-normal .button,
  .header-fixed .button {
    all: unset;
    box-sizing: border-box;
    background-color: #2118ff;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px 8px 8px;
    position: relative;
    flex: 0 0 auto;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .header-normal .button:hover,
  .header-fixed .button:hover {
    background-color: #1a0ee6;
  }
  
  .header-normal .icon,
  .header-fixed .icon {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px;
    position: relative;
    flex: 0 0 auto;
    background-color: #ffffff4c;
    border-radius: 2px;
  }
  .header-normal .img,
  .header-fixed .img {
    position: relative;
    width: 18px;
    height: 18px;
  }
  
  .header-normal .label,
  .header-fixed .label {
    font-family: "Zen Kaku Gothic New", Helvetica, sans-serif;
    position: relative;
    width: fit-content;
    font-weight: 700;
    color: #ffffff;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  .header-normal .button-2,
  .header-fixed .button-2 {
    all: unset;
    box-sizing: border-box;
    background-color: #006ace;
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px 8px 8px;
    position: relative;
    flex: 0 0 auto;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.2s ease;
  }
  
  .header-normal .button-2:hover,
  .header-fixed .button-2:hover {
    background-color: #0056b0;
  }
  
  .header-normal .label-2,
  .header-fixed .label-2 {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    position: relative;
    width: fit-content;
    font-weight: 700;
    color: #ffffff;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1em;
    white-space: nowrap;
  }
  
  @media (max-width: 1024px) {
    .kv-advantage {
      min-height: auto;
    }
    
    .kv-advantage .kv-block {
      width: 100%;
      padding: 0px 20px 64px;
    }
    
    .kv-advantage .frame {
      padding: 48px 20px 0px;
      width: 100%;
      max-width: 500px;
    }
    
    .kv-advantage .image {
      width: 100%;
      max-width: 500px;
      height: auto;
      aspect-ratio: 665/800;
    }
    
    .kv-advantage .navigationbar {
      width: 100%;
      max-width: 500px;
    }
    
    .kv-advantage .right {
      padding: 80px 40px 0px;
    }
    
    .kv-advantage .p,
    .kv-advantage .div-2 {
      font-size: 4em;
      line-height: 1.2em;
    }
    
    .kv-advantage .image-2 {
      width: 350px;
      height: 414px;
    }
    
    .kv-advantage .teitan {
      transform: scale(0.8);
    }
  }
  
  .header-normal .menus .div i,
  .header-fixed .menus .div i{
    font-size: 0.9em;
    position: relative;
    top: -3px;
    left: -1px;
    transition: transform 0.3s ease;
  }
  
  .header-normal .menus .div.active i,
  .header-fixed .menus .div.active i{
    transform: rotate(180deg);
  }

  /* KV Block Styles */
  .kv-block {
    width: 100%;
    background: linear-gradient(175deg, #FFFFFF 49.9%, #1813AB 50.1%);
    transform: translateZ(0);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    padding-bottom: 334px;
    margin-bottom: -240px;
    position: relative;
  }

  .kv-block .container {
    display: flex;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    position: relative;
  }

  .kv-block .left-section {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 64px;
    padding: 48px 0 0 48px;
    flex: 0 0 auto;
  }
  .kv-block .image01 {
    width: 756px;
    height: 563px;
    border-radius: 0px 40px 0px 40px;
    position: relative;
    overflow: hidden;
  }
  .kv-block .navigationbar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding-left: 48px;
  }

  .kv-block .bar {
    display: flex;
    align-items: center;
    gap: 16px;
  }

  .kv-block .line {
    width: 120px;
    height: 3px;
    background-color: #A7B1FF;
    cursor: pointer;
    transition: background-color 0.3s ease;
  }

  .kv-block .line.active {
    background-color: #FFFFFF;
  }

  .kv-block .counter {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    padding: 2px 0;
  }

  .kv-block .current {
    font-family: "Prompt", sans-serif;
    font-weight: 400;
    font-size: 20px;
    line-height: 1em;
    color: #FFFFFF;
    text-align: center;
  }

  .kv-block .separator {
    font-family: "Prompt", sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1em;
    color: #FFFFFF;
    text-align: center;
  }

  .kv-block .total {
    font-family: "Prompt", sans-serif;
    font-weight: 400;
    font-size: 20px;
    line-height: 1em;
    color: #CED5FF;
    text-align: right;
  }

  .kv-block .right-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 150px;
    padding: 82px 20px 0 30px;
    flex: 1;
  }

  .kv-block .copy-text {
    display: flex;
    flex-direction: column;
    width: 100%;
    align-self: stretch;
  }

  .kv-block .text-line {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 84px;
    line-height: 1.3em;
    letter-spacing: 3%;
    color: #000;
    text-align: left;
    width: 100%;
  }
.kv-block .image02 {
  width: 400px;
  height: 286px;
  border-radius: 0px 40px 0px 40px;
  position: relative;
  overflow: hidden;
}

  .kv-block .teitan01 {
    position: absolute;

    top: 474px;
    left: 578px;
    width: 238px;
    height: 210px;
    z-index: 10;
  }

  .kv-block .teitan01 img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  /* KV Block Responsive */
  @media (max-width: 1024px) {
    .kv-block .container {
      width: 100%;
      padding: 0 24px;
    }
    
    .kv-block .left-section {
      padding: 32px 0 0 24px;
    }
    
    .kv-block .image01 {
      width: 500px;
      height: 600px;
    }
    
    .kv-block .right-section {
      padding: 80px 40px 0 60px;
      gap: 60px;
    }
    
    .kv-block .text-line1,
    .kv-block .text-line2 {
      font-size: 64px;
    }
    
    .kv-block .image02 {
      width: 350px;
      height: 400px;
    }
    
    .kv-block .teitan01 {
      top: 500px;
      left: 450px;
      width: 180px;
      height: 160px;
    }
  }

  @media (max-width: 768px) {
    .kv-block {
      background: linear-gradient(180deg, #FFFFFF 60%, #1813AB 60%);
    }
    
    .kv-block .container {
      flex-direction: column;
      align-items: center;
      gap: 40px;
    }
    
    .kv-block .left-section {
      width: 100%;
      padding: 24px;
      gap: 32px;
    }
    
    .kv-block .image01 {
      width: 100%;
      max-width: 400px;
      height: 300px;
    }
    
    .kv-block .navigationbar {
      padding-left: 0;
      justify-content: center;
    }
    
    .kv-block .line {
      width: 80px;
      height: 2px;
    }
    
    .kv-block .right-section {
      width: 100%;
      padding: 32px 24px;
      gap: 40px;
      order: -1;
    }
    
    .kv-block .text-line1,
    .kv-block .text-line2 {
      font-size: 48px;
      text-align: center;
    }
    
    .kv-block .image02 {
      width: 100%;
      max-width: 300px;
      height: 250px;
    }
    
    .kv-block .teitan01 {
      position: relative;
      top: auto;
      left: auto;
      width: 150px;
      height: 130px;
      margin: 20px auto;
    }
  }

  @media (max-width: 768px) {
    .kv-advantage {
      flex-direction: column;
    }
    
    .kv-advantage .kv-block {
      flex-direction: column;
      padding: 0px 20px 40px;
    }
    
    .kv-advantage .frame {
      padding: 40px 20px 0px;
      order: 2;
      width: 100%;
      max-width: none;
    }
    
    .kv-advantage .image {
      order: 1;
      width: 100%;
      height: auto;
      aspect-ratio: 665/800;
    }
    
    .kv-advantage .navigationbar {
      width: 100%;
      padding: 0px 0px 0px 20px;
    }
    
    .kv-advantage .right {
      order: 1;
      align-items: center;
      text-align: center;
      padding: 60px 20px 0px;
    }
    
    .kv-advantage .p,
    .kv-advantage .div-2 {
      font-size: 2.5em;
      line-height: 1.2em;
      text-align: center;
    }
    
    .kv-advantage .image-2 {
      width: 280px;
      height: 331px;
      order: 1;
      margin-bottom: 20px;
    }
    
    .kv-advantage .teitan {
      position: relative;
      top: auto;
      left: auto;
      width: 200px;
      height: 176px;
      order: 3;
      align-self: center;
    }
  }
  
  /* Advantage Block Styles */
  .advantage-block {
    width: 100%;
    padding: 40px 0;
    background: linear-gradient(180deg, #1813ab 0%, #767fff 100%);
    position: relative;
  }
  
  .advantage-block .advantage-container {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 160px;
    width: 100%;
    max-width: 1140px;
    margin: 0 auto;
    position: relative;
  }
  
  .advantage-block .left-section {
    background: rgba(255, 255, 255, 0.86);
    border-radius: 16px;
    padding: 64px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 64px;
    flex: 1;
    max-width: 480px;
  }
  
  .advantage-block .content-frame {
    display: flex;
    flex-direction: column;
    gap: 64px;
  }
  
  .advantage-block .title-section {
    display: flex;
    flex-direction: column;
    gap: 4px;
  }
  
  .advantage-block .main-title {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    font-size: 48px;
    line-height: 1.5em;
    letter-spacing: 1.5%;
    color: #ffffff;
    text-align: center;
    margin: 0;
  }
  
  .advantage-block .title-eg {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 4px;
  }
  
  .advantage-block .zap-icon {
    width: 18px;
    height: 18px;
    color: #ffffff;
  }
  
  .advantage-block .zap-icon i {
    font-size: 14px;
  }
  
  .advantage-block .advantage-label {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.5em;
    letter-spacing: 3%;
    color: #ffffff;
    text-align: center;
  }
  
  .advantage-block .description {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.75em;
    letter-spacing: 3%;
    color: #ffffff;
    text-align: left;
    margin: 0;
  }
  
  .advantage-block .advantage-button {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 8px;
    padding: 8px 24px;
    height: 48px;
    background: #ffffff;
    border: 1px solid #767fff;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.3s ease;
  }
  
  .advantage-block .advantage-button:hover {
    background: #f0f0ff;
    border-color: #0d05d2;
  }
  
  .advantage-block .button-label {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    font-size: 14px;
    line-height: 1em;
    color: #0d05d2;
  }
  
  .advantage-block .advantage-button i {
    width: 24px;
    height: 24px;
    color: #0d05d2;
    font-size: 14px;
  }
  
  .advantage-block .image-section {
    flex: 1;
    max-width: 448px;
  }
  
  .advantage-block .advantage-image {
    width: 448px;
    height: 529px;
    background: url('assets/advantage-image.png') center center/cover no-repeat;
    border-radius: 0 40px 0 40px;
    background-color: #ddd;
  }
  
  .advantage-block .teitan02 {
    position: absolute;
    bottom: -40px;
    right: 0;
    width: 364px;
    height: 160px;
  }
  
  .advantage-block .teitan02 .speech-bubble {
    position: absolute;
    top: 0;
    left: 0;
    width: 153px;
    height: 150px;
    background: url('assets/speech-bubble.svg') center center/contain no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  .advantage-block .teitan02 .bubble-text {
    font-family: "Noto Sans JP", Helvetica, sans-serif;
    font-weight: 700;
    font-size: 12px;
    line-height: 1.5em;
    color: #0d05d2;
    text-align: center;
    padding: 16px;
    margin-top: 20px;
  }
  
  .advantage-block .teitan02 .character-illustration {
    position: absolute;
    top: 5px;
    right: 0;
    width: 200px;
    height: 150px;
    background: url('assets/character-advantage.svg') center center/contain no-repeat;
  }
  
  /* Responsive Design for Advantage Block */
  @media (max-width: 1024px) {
    .advantage-block .advantage-container {
      flex-direction: column;
      gap: 64px;
      padding: 0 24px;
    }
    
    .advantage-block .left-section {
      max-width: none;
      width: 100%;
    }
    
    .advantage-block .image-section {
      max-width: none;
      width: 100%;
    }
    
    .advantage-block .advantage-image {
      width: 100%;
      max-width: 448px;
      margin: 0 auto;
    }
    
    .advantage-block .teitan02 {
      position: relative;
      bottom: auto;
      right: auto;
      margin: 40px auto 0;
    }
  }
  
  @media (max-width: 768px) {
    .advantage-block {
      padding: 24px 0;
    }
    
    .advantage-block .advantage-container {
      gap: 32px;
      padding: 0 16px;
    }
    
    .advantage-block .left-section {
      padding: 32px 24px;
      gap: 32px;
    }
    
    .advantage-block .content-frame {
      gap: 32px;
    }
    
    .advantage-block .main-title {
      font-size: 32px;
    }
    
    .advantage-block .text-wrapper .company-name {
      font-size: 32px !important;
    }
    
    .advantage-block .advantage-label {
      font-size: 16px;
    }
    
    .advantage-block .description {
      font-size: 14px;
    }
    
    .advantage-block .advantage-image {
      height: 300px;
    }
    
    .advantage-block .teitan02 {
      width: 300px;
      height: 120px;
    }
    
    .advantage-block .teitan02 .speech-bubble {
      width: 120px;
      height: 110px;
    }
    
    .advantage-block .teitan02 .character-illustration {
      width: 150px;
      height: 110px;
    }
  }
  
  .zap-icon-white {
    filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(7500%) hue-rotate(0deg) brightness(100%) contrast(100%);
  }
  
  .zap-icon {
    width: 20px;
    height: 20px;
    filter: brightness(0) saturate(100%) invert(13%) sepia(86%) saturate(5471%) hue-rotate(251deg) brightness(92%) contrast(111%);
  }
  
  @media (max-width: 1024px) {
    .news-company-block .title {
      font-size: 36px;
    }
    
    .news-company-block .text-wrapper,
    .news-company-block .span {
      font-size: 36px;
    }
    
    .news-company-block .advantage {
      font-size: 18px;
    }
    
    .news-company-block .news-list {
      width: 100%;
      max-width: 480px;
    }
    
    .news-company-block .link {
      width: 100%;
      max-width: 480px;
    }
  }
  
  @media (max-width: 768px) {
    .news-company-block .title {
      font-size: 32px;
      text-align: center;
    }
    
    .news-company-block .text-wrapper,
    .news-company-block .span {
      font-size: 32px;
    }
    
    .news-company-block .advantage {
      font-size: 16px;
    }
    
    .news-company-block .div-2 {
      align-items: center;
    }
    
    .news-company-block .title-eg {
      justify-content: center;
    }
    
    .news-company-block .frame {
      align-items: center;
    }
    
    .news-company-block .list-2 {
      align-items: center;
    }
    
    .news-company-block .news-list {
      width: 100%;
      flex-direction: column;
      align-items: center;
      text-align: center;
      gap: 12px;
      padding: 20px 16px;
    }
    
    .news-company-block .thumbnail,
    .news-company-block .thumbnail-2,
    .news-company-block .thumbnail-3,
    .news-company-block .thumbnail-4 {
      width: 100%;
      max-width: 280px;
      height: 160px;
    }
    
    .news-company-block .body {
      height: auto;
      text-align: center;
    }
    
    .news-company-block .postdate-category {
      justify-content: center;
    }
    
    .news-company-block .link {
      width: 100%;
      height: auto;
      padding: 20px 16px;
    }
  }
  
  .business-block-index .image:hover {
    opacity: 0.8;
  }

  .business-block-index .image img {
    width: 97%;
    border-radius: 0px 20px 0px 20px;
  }

/* New Advantage Block Styles */
.advantage-block {
  width: 100%;
  padding: 96px 120px 160px;
  background: #1813AB ;
  /* background: #14189D url('assets/advantage-bg.png') center/cover; */
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
}

.advantage-block .container {
  display: flex;
  flex-direction: row;
  justify-content: center;
  gap: 160px;
  width: 100%;
  max-width: 1140px;
  position: relative;
}

.advantage-block .left {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 64px;
  flex: 1;
  max-width: 480px;
  height: 529px;
  padding: 0;
  position: relative;
}

.advantage-block .content {
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.advantage-block .title {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.advantage-block .text-wrapper {
  font-family: "Noto Sans JP", Helvetica, sans-serif;
  font-weight: 700;
  font-size: 48px;
  line-height: 1.5em;
  letter-spacing: 1.5%;
  color: #FFFFFF;
  text-align: left;
  margin: 0;
}

.advantage-block .title-eg {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 4px;
  justify-content: flex-start;
}

.advantage-block .zap-icon {
  width: 18px;
  height: 18px;
  filter: brightness(0) saturate(100%) invert(100%) sepia(0%) saturate(7500%) hue-rotate(0deg) brightness(100%) contrast(100%);
}

.advantage-block .advantage {
  font-family: "Noto Sans JP", Helvetica, sans-serif;
  font-weight: 700;
  font-size: 20px;
  line-height: 1.5em;
  letter-spacing: 3%;
  color: #FFFFFF;
  text-align: left;
}

.advantage-block .description {
  font-family: "Noto Sans JP", Helvetica, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75em;
  letter-spacing: 3%;
  color: #FFFFFF;
  text-align: left;
  margin: 0;
}

.advantage-block .company-name {
  color: #CED5FF;
}

.advantage-block .button {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 8px 24px;
  height: 48px;
  background: #ffffff;
  border: 1px solid #767fff;
  border-radius: 4px;
  cursor: pointer;
  transition: all 0.3s ease;
  width: fit-content;
  position: absolute;
  bottom: 0;
  right: 0;
}

.advantage-block .button:hover {
  background: #f0f0ff;
  border-color: #0d05d2;
}

.advantage-block .label {
  font-family: "Noto Sans JP", Helvetica, sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1em;
  color: #0d05d2;
}

.advantage-block .chevrons-right {
  width: 16px;
  height: 16px;
}

.advantage-block .right {
  flex: 1;
  max-width: 448px;
  position: relative;
  display: flex;
  justify-content: flex-end;
}

.advantage-block .image01 {
  width: 448px;
  height: 529px;
  background: url('assets/advantage-image.png') center/cover;
  border-radius: 0px 0px 0px 0px;
  /* transform: scaleX(-1); */
}

.advantage-block .teitan02 {
  position: absolute;
  top: 364px;
  left: 581px;
  width: 364px;
  height: 187px;
  z-index: 10;
}

.advantage-block .teitan02 img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Responsive Design for New Advantage Block */
@media (max-width: 1024px) {
  .advantage-block {
    padding: 60px 40px 120px;
  }
  
  .advantage-block .container {
    gap: 80px;
    max-width: 944px;
  }
  
  .advantage-block .left {
    max-width: 400px;
    height: 425px;
  }
  
  .advantage-block .text-wrapper {
    font-size: 36px;
  }
  
  .advantage-block .right {
    max-width: 360px;
  }
  
  .advantage-block .image01 {
    width: 360px;
    height: 425px;
  }
  
  .advantage-block .teitan02 {
    top: 385px;
    left: 384px;
    width: 291px;
    height: 128px;
  }
}

@media (max-width: 768px) {
  .advantage-block {
    padding: 40px 20px 80px;
  }
  
  .advantage-block .container {
    flex-direction: column;
    gap: 40px;
    align-items: center;
  }
  
  .advantage-block .left {
    max-width: 100%;
    height: auto;
    order: 2;
  }
  
  .advantage-block .text-wrapper {
    font-size: 28px;
    text-align: center;
  }
  
  .advantage-block .title-eg {
    justify-content: center;
  }
  
  .advantage-block .advantage {
    text-align: center;
  }
  
  .advantage-block .description {
    text-align: center;
  }
  
  .advantage-block .right {
    max-width: 100%;
    order: 1;
    display: flex;
    justify-content: center;
  }
  
  .advantage-block .image01 {
    width: 280px;
    height: 331px;
  }
  
  .advantage-block .teitan02 {
    position: relative;
    top: auto;
    left: auto;
    width: 200px;
    height: 88px;
    order: 3;
    align-self: center;
  }
}
  

  

/* subpage */
.subpage-kv-wrapper {
  position: relative;
  width: 100%;
  height: 480px;
  overflow: hidden;
  background-image: url(./assets/subpage-kv.png);
  background-size: cover;
  background-position: 50% 50%;
}
.subpage-kv-wrapper-mini {
  height: 120px;
}
.subpage-kv-wrapper .logo-bg-traced {
  position: absolute;
  top: 0;
  right: 0;
  object-fit: cover;
  z-index: 0;
}

.subpage-kv {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  height: 100%;
  align-items: flex-start;
  justify-content: space-between;
  padding: 64px 150px 96px;
  position: relative;
  z-index: 1;
}

.subpage-kv .breadcrumb {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: 100%;
  position: relative;
  z-index: 1;
}

.subpage-kv .breadcrumb-inner {
  display: inline-flex;
  height: 40px;
  align-items: center;
  padding: 0px 24px;
  position: relative;
  background-color: #ffffff;
  border-radius: 999px;
  border: 1px solid #0d05d2;
  gap: 8px;
}

.subpage-kv .breadcrumb-item {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: #0d05d2;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap;
  text-decoration: none;
}

.subpage-kv .breadcrumb-item:hover {
  text-decoration: underline;
}

.subpage-kv .breadcrumb-item.current {
  cursor: default;
}

.subpage-kv .breadcrumb-item.current:hover {
  text-decoration: none;
}

.subpage-kv .breadcrumb-separator {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

.subpage-kv .title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
  width: 100%;
  position: relative;
  z-index: 1;
}

.subpage-kv .p {
  position: relative;
  width: fit-content;
  margin: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 56px;
  text-align: center;
  letter-spacing: 0.84px;
  line-height: 84px;
  white-space: nowrap;
}

.subpage-kv .text-wrapper {
  color: #0d05d2;
  letter-spacing: 0.47px;
}

.subpage-kv .span {
  color: #1a1a1a;
  letter-spacing: 0.47px;
}

.subpage-kv .title-eg {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.subpage-kv .zap-icon {
  width: 28px;
  height: 28px;
}

.subpage-kv .text-wrapper-2 {
  position: relative;
  width: fit-content;
  font-family: "Prompt", sans-serif;
  font-weight: 400;
  color: #0d05d2;
  font-size: 30px;
  text-align: center;
  letter-spacing: 0.90px;
  line-height: 45px;
  white-space: nowrap;
}
/* ====================================
   ADVANTAGE PAGE STYLES
   ==================================== */

/* Advantage Link Section */
.advantage-link-section {
  width: 100%;
  background-image: url(./assets/advantage-link-bg.png);
  background-repeat: no-repeat;
  padding: 0px 0 80px;
  margin-bottom: -130px;
  position: relative;
  height: 587px;
  top: -130px;
}

.advantage-link-section .container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  position: relative;
  top: 275px;
}

.teitan-message {
  flex-shrink: 0;
  margin-right: 40px;
}

.teitan-message img {
  width: 238px;
  height: auto;
}

.link-cards-container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  z-index: 1;
  max-width: 840px;
}

.link-card {
  background-color: #ffffff;
  padding: 32px 40px;
  width: 386px;
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  overflow: hidden;
}

.link-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
}

.link-card-number {
  position: absolute;
  top: -4px;
  left: -4px;
  font-family: 'Prompt', sans-serif;
  font-weight: 300;
  font-style: italic;
  font-size: 80px;
  color: #ffffff;
  line-height: 1;
  -webkit-text-stroke: 1px #a7a4eb;
}

.link-card-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #1a1a1a;
  line-height: 1.4;
  letter-spacing: 0.5px;
  flex: 1;
  text-align: center;
  line-height: 2em;
}

.link-card-arrow {
  position: absolute;
  bottom: 3px;
  right: 50%;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Teitan Message */
.teitan-message {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    z-index: 1;
    top: -146px;
}

.teitan-message img {
  width: 200px;
  height: auto;
}



/* Advantage Detail Section */
.advantage-detail-section {
  padding: 16px;
}

.advantage-item {
  background-color: #ffffff;
  margin-bottom: 0;
}

.advantage-content {
  background-color: #f1f4ff;
  padding: 96px 134px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
  gap: 64px;
}

.advantage-item-reverse .advantage-content {
  flex-direction: row-reverse;
}

.logo-bg-pattern {
  position: absolute;
  width: 276px;
  height: 276px;
  opacity: 0.5;
  top: 80%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

/* Advantage Image */
.advantage-image {
  display: flex;
  flex-direction: column;
  gap: 16px;
  flex-shrink: 0;
}

.title-eg {
  display: flex;
  align-items: center;
  gap: 4px;
}

.title-eg img {
  width: 28px;
  height: 28px;
}

.title-eg span {
  font-family: 'Prompt', sans-serif;
  font-size: 30px;
  color: #0d05d2;
  line-height: 1;
}

.advantage-photo {
  width: 360px;
  height: 436px;
  position: relative;
}

.advantage-item-reverse .advantage-photo {
  /* 角丸は画像自体に含まれている */
}

.advantage-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Advantage Card */
.advantage-card {
  background-color: #ffffff;
  width: 600px;
  padding: 32px 48px 48px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  position: relative;
  box-shadow: 2px 2px 40px 0px rgba(24, 19, 171, 0.06);
  flex-shrink: 0;
}

.advantage-number {
  position: absolute;
  top: -10px;
  left: -10px;
  font-family: 'Prompt', sans-serif;
  font-weight: 300;
  font-style: italic;
  font-size: 112px;
  color: #ffffff;
  line-height: 1;
  -webkit-text-stroke: 2px #e7e6ff;
  text-stroke: 2px #e7e6ff;
}

.advantage-title {
  padding: 48px 0;
  border-bottom: 1px solid rgba(13, 5, 210, 0.4);
  text-align: center;
}

.advantage-title h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 24px;
  color: #0d05d2;
  line-height: 1.67;
  letter-spacing: 0.6px;
  margin: 0;
}

.advantage-description p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  color: #1a1a1a;
  line-height: 1.75;
  letter-spacing: 0.48px;
  margin: 0;
}

/* Suggest Page Link */
.suggest-page-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--size-space-1200);
  padding: 30px 0px;
  position: relative;
  background-color: #ffffff;
}

.suggest-page-link .page-link-item {
  display: flex;
  width: 318px;
  align-items: center;
  gap: var(--size-space-200);
  padding: var(--size-space-400);
  position: relative;
  border-bottom-width: 1px;
  border-bottom-style: solid;
  border-color: #1713ab;
  margin-right: 20px;
}

.suggest-page-link .image {
  position: relative;
  width: 150px;
  height: 150px;
  border-radius: var(--shape-corner-none) var(--shape-corner-large)
    var(--shape-corner-none) var(--shape-corner-large);
  background-image: url(./img/image-2.png);
  background-size: cover;
  background-position: 50% 50%;
  margin-bottom: 15px;
  gap: var(--size-space-200);
}

.suggest-page-link .link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--size-space-200);
  position: relative;
  flex: 1;
  flex-grow: 1;
}

.suggest-page-link .title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.suggest-page-link .zap {
  position: relative;
  width: 18px;
  height: 18px;
}

.suggest-page-link .name {
  position: relative;
  width: fit-content;
  font-family: var(--typography-label-md-font-family);
  font-weight: var(--typography-label-md-font-weight);
  color: #000000;
  font-size: var(--typography-label-md-font-size);
  letter-spacing: var(--typography-label-md-letter-spacing);
  line-height: var(--typography-label-md-line-height);
  white-space: nowrap;
  font-style: var(--typography-label-md-font-style);
}

.suggest-page-link .chevrons-right {
  position: relative;
  width: 20px;
  height: 20px;
}

.suggest-page-link .div {
  position: relative;
  width: 150px;
  height: 150px;
  border-radius: var(--shape-corner-none) var(--shape-corner-large)
    var(--shape-corner-none) var(--shape-corner-large);
  box-shadow: inset -6px -6px 0px 6px #0d05d2;
  background-image: url(./img/image-3.png);
  background-size: cover;
  background-position: 50% 50%;
  gap: var(--size-space-200);
}

.suggest-page-link .image-2 {
  position: relative;
  width: 150px;
  height: 150px;
  border-radius: var(--shape-corner-none) var(--shape-corner-large)
    var(--shape-corner-none) var(--shape-corner-large);
  box-shadow: inset -6px -6px 0px 6px #0d05d2;
  background-image: url(./img/image.png);
  background-size: cover;
  background-position: 50% 50%;
  gap: var(--size-space-200);
}

.suggest-page-link .title-2 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
  margin-left: -3.00px;
}

.suggest-page-link .img {
  position: relative;
  width: 20px;
  height: 20px;
  margin-right: -3.00px;
}


/* ====================================
   END OF ADVANTAGE PAGE STYLES
   ==================================== */


/* ====================================
   MESSAGE BLOCK STYLES
   ==================================== */

.message-block {
    background-color: #0d05d2;
    padding: 0px 150px 96px 150px;
    position: relative;
    overflow: visible;
    margin-top: 100px;
}

/* 斜めの上部エッジ */
.message-block::after {
    content: "";
    position: absolute;
    top: 0px;
    right: 0px;
    left: 0px;
    height: 117px;
    background-color: #0d05d2;
    transform: skewY(-4deg);
    transform-origin: bottom left;
    z-index: -1;
}

.message-block::before {
    content: "Message";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-family: 'Prompt', sans-serif;
    font-weight: 300;
    font-style: italic;
    font-size: 240px;
    letter-spacing: 0.03em;
    color: rgba(255, 255, 255, 0.05);
    z-index: 0;
    white-space: nowrap;
}

.message-inner {
    position: relative;
    z-index: 1;
    max-width: 1140px;
    margin: 0 auto;
}

.message-label {
    font-family: 'Prompt', sans-serif;
    font-weight: 300;
    font-style: italic;
    font-size: 96px;
    color: #000090;
    text-align: center;
    letter-spacing: 0.03em;
    -webkit-text-stroke: 1px #000051;
    position: relative;
    top: 186px;
}

.message-block .section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: center;
    position: relative;
    top: -45px;
}

.message-block .section-title h3 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 28px;
    color: white;
    margin: 0;
    letter-spacing: 0.03em;
}

.message-content-wrapper {
    background-color: #ffffff;
    padding: 64px;
    display: flex;
    gap: 48px;
    align-items: flex-end;
    position: relative;
    overflow: hidden;
}

.message-bg-logo {
    position: absolute;
    top: 70%;
    left: 36%;
    transform: translateY(-50%);
    width: 276px;
    height: 276px;
    z-index: 0;
}

.message-text-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 48px;
    align-items: center;
    position: relative;
    z-index: 1;
}

.rin-concept {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.rin-kana {
    font-family: 'Shippori Mincho', serif;
    font-weight: 400;
    font-size: 20px;
    color: #a7b1ff;
    letter-spacing: 8px;
}

.rin-kanji {
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: 64px;
    color: #0d05d2;
    line-height: 1;
}

.message-text {
    width: 504px;
    max-width: 504px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.message-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.75;
    color: #1a1a1a;
    letter-spacing: 0.03em;
    margin: 0;
    text-align: left;
}

.message-name {
    width: 504px;
    display: flex;
    align-items: baseline;
    gap: 16px;
    justify-content: flex-end;
}

.message-name .position {
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: 20px;
    color: #1a1a1a;
    letter-spacing: 0.03em;
}

.message-name .name {
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: 24px;
    color: #1a1a1a;
    letter-spacing: 0.025em;
}

.message-photo {
    flex-shrink: 0;
    width: 460px;
    height: 573px;
    border-top-right-radius: 48px;
    border-bottom-left-radius: 48px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

.message-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.block-content{
  width:1140px;
    margin: 0 auto;
}
.keiei-p-text{
  text-align: left;
}
.keiei-p-text span{
  display: block;
  margin-bottom: 10px;
  font-size: 24px;
}
/* ====================================
   END OF MESSAGE BLOCK STYLES
   ==================================== */

/* ====================================
   CONTACT DROPDOWN STYLES
   ==================================== */

.contact-dropdown {
    position: absolute;
    top: 100%;
    right: auto;
    left: 0;
    background-color: #ffffff;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.3s ease;
    z-index: 1000;
    margin-top: 10px;
    min-width: 200px;
}

.contact-dropdown.active {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.contact-dropdown-inner {
    padding: 16px 0;
}

.contact-dropdown-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.contact-dropdown-list li {
    margin: 0;
}

.contact-dropdown-list a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 24px;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 16px;
    font-weight: 500;
    color: #1a1a1a;
    text-decoration: none;
    transition: all 0.2s ease;
    white-space: nowrap;
    gap: 16px;
    min-width: 200px;
}

.contact-dropdown-list a:hover {
    background-color: #f5f7fa;
    color: #0d05d2;
}

.contact-dropdown-list a i {
    font-size: 12px;
    color: #737373;
    transition: all 0.2s ease;
}

.contact-dropdown-list a:hover i {
    color: #0d05d2;
    transform: translateX(4px);
}

/* ドロップダウンのラッパー */
.dropdown-wrapper {
    position: relative;
}

/* お問い合わせボタンのアクティブ状態 */
.button.has-dropdown.active .icon i {
    transform: rotate(180deg);
}

/* ====================================
   END OF CONTACT DROPDOWN STYLES
   ====================================*/


/* ====================================
   YOUTUBE SECTION STYLES
   ==================================== */

.youtube-section {
    background-color: #f1f4ff;
    padding: 120px 150px 96px 150px;
}

.youtube-inner {
    max-width: 1140px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 48px;
}

.youtube-section .section-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.youtube-section .section-title h3 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 28px;
    color: #0d05d2;
    margin: 0;
    letter-spacing: 0.03em;
}

.youtube-section .zap-icon {
    width: 20px;
    height: 20px;
}

.youtube-blocks {
    display: flex;
    flex-direction: column;
    gap: 48px;
    align-items: center;
}

.youtube-block {
    background-color: #ffffff;
    border-radius: 8px;
    padding: 24px;
    width: 768px;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
}

.youtube-block h4 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 20px;
    color: #1a1a1a;
    margin: 0;
    letter-spacing: 0.025em;
    text-decoration: underline;
    line-height: 1.6;
    text-align: left;
    width: 100%;
}

.youtube-video {
    width: 720px;
    height: auto;
    position: relative;
    cursor: pointer;
    overflow: hidden;
}

.youtube-video img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.youtube-video .play-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: transform 0.2s ease;
}

.youtube-video:hover .play-button {
    transform: translate(-50%, -50%) scale(1.1);
}

/* ====================================
   END OF YOUTUBE SECTION STYLES
   ==================================== */

/* ====================================
   SHAKUN (社訓) SECTION STYLES
   ==================================== */
.shakun-section {
    background-color: #f1f4ff;
    padding: 96px 150px;
    padding-top: 0px;
}

.shakun-inner {
    max-width: 1140px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 48px;
}

.shakun-header {
    display: flex;
    align-items: center;
    gap: 48px;
}

.shakun-section .section-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.shakun-section .section-title h3 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 28px;
    color: #0d05d2;
    margin: 0;
    letter-spacing: 0.02em;
}

.shakun-section .zap-icon {
    width: 20px;
    height: 20px;
}

.shakun-subtitle {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-size: 16px;
    color: #1a1a1a;
    margin: 0;
    letter-spacing: 0.03em;
}

.shakun-cards {
    display: flex;
    justify-content: space-between;
    gap: 30px;
}

.shakun-card {
    background-color: #0d05d2;
    width: 360px;
    height: 180px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 0 24px 16px 24px;
}

.shakun-number {
    position: relative;
    height: 55px;
    width: 57px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 8px;
}

.shakun-num {
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: 40px;
    color: #0d05d2;
    -webkit-text-stroke: 1px #ffffff;
    text-stroke: 1px #ffffff;
    letter-spacing: 0.03em;
}

.shakun-comma {
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    font-size: 23px;
    color: #0d05d2;
    -webkit-text-stroke: 1px #ffffff;
    text-stroke: 1px #ffffff;
    position: absolute;
    top: 8px;
    right: -8px;
}

.shakun-text {
    text-align: center;
}

.shakun-text p {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.6;
    color: #ffffff;
    margin: 0;
    letter-spacing: 0.025em;
}

/* ====================================
   END OF SHAKUN SECTION STYLES
   ==================================== */

/* ====================================
   SLOGAN SECTION STYLES
   ==================================== */
.slogan-list {
    background-color: #f1f4ff;
    padding: 24px 48px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.slogan-item {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px 0;
}

.slogan-number {
    font-family: 'Prompt', sans-serif;
    font-weight: 275;
    font-style: italic;
    font-size: 40px;
    color: #a7b1ff;
    letter-spacing: 0.025em;
    line-height: 1.6;
    flex-shrink: 0;
}

.slogan-text {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 20px;
    color: #1a1a1a;
    letter-spacing: 0.025em;
    line-height: 1.6;
}

/* ====================================
   END OF SLOGAN SECTION STYLES
   ==================================== */

/* ====================================
   QUALITY POLICY SECTION STYLES
   ==================================== */
.quality-policy-section {
    background-color: #f1f4ff;
    padding: 0;
    position: relative;
    overflow: hidden;
    min-height: 731px;
}

.management-policy-bg {
    position: absolute;
    bottom: -97px;
    right: 0px;
    font-family: 'Prompt', sans-serif;
    font-weight: 300;
    font-style: italic;
    font-size: 82px;
    color: #ffffff;
    letter-spacing: 0.03em;
    transform-origin: right bottom;
    white-space: nowrap;
    z-index: 1;
}

.quality-policy-inner {
    max-width: 1440px;
    margin: 0 auto;
    padding: 96px 150px;
    display: flex;
    gap: 48px;
    position: relative;
    z-index: 2;
}

.quality-policy-left {
    background-color: #ffffff;
    padding: 48px;
    width: 400px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.quality-policy-section .section-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

.quality-policy-section .section-title h3 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    font-size: 28px;
    color: #0d05d2;
    margin: 0;
    letter-spacing: 0.02em;
}

.quality-policy-section .zap-icon {
    width: 20px;
    height: 20px;
}

.quality-policy-text {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.75;
    color: #1a1a1a;
    letter-spacing: 0.03em;
    margin: 0;
}

.quality-policy-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    flex: 1;
}

.quality-policy-item {
    display: flex;
    gap: 16px;
    padding: 8px;
}

.policy-number {
    width: 32px;
    height: 32px;
    background-color: #ffffff;
    border: 1px solid #0d05d2;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Prompt', sans-serif;
    font-weight: 300;
    font-style: italic;
    font-size: 24px;
    color: #0d05d2;
    letter-spacing: 0.03em;
    flex-shrink: 0;
}

.policy-text {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    font-size: 16px;
    line-height: 1.75;
    color: #1a1a1a;
    letter-spacing: 0.03em;
    flex: 1;
}

.quality-policy-image {
  position: absolute;
  bottom: -133px;
  left: 333px;
  width: 257px;
  height: 320px;
  border-radius: 0 0px 16px 0;
  overflow: hidden;
}

.quality-policy-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ====================================
   END OF QUALITY POLICY SECTION STYLES
   ==================================== */

.bg-blue{
    background-color: #f1f4ff;
}

.bg-white{
  background-color: #ffffff;
}

.common-padding{
  padding: 120px 150px 96px 150px;
}
.block-title {
  display: flex;
  gap: 8px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  color: #0d05d2;
  margin: 0;
  letter-spacing: 0.03em;
}
.zap-icon-large{
  height: 32px;
  width: 32px;
}

.box-common{
  padding:20px;
}
.business-handshake{
  position: relative;
  left: 193px;
  top: 6px;
  z-index: 9999;
}


.compliance-section {
  padding: 160px 150px 64px;
  background-color: #ffffff;
  margin-bottom: 100px;
  margin-top: -30px;
}

.compliance-inner {
  display: flex;
  gap: 100px;
  align-items: flex-start;
  border-bottom: 1px solid #0d05d2;
  padding-bottom: 50px;
}

.compliance-title {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  width: 355px;
}

.compliance-title .zap-icon {
  width: 20px;
  height: 20px;
}

.compliance-title h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.67;
  letter-spacing: 0.6px;
  color: #0d05d2;
  margin: 0;
}

.compliance-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 640px;
}

.compliance-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 8px;
}

.compliance-number {
  width: 32px;
  height: 32px;
  background-color: #ffffff;
  border: 1px solid #0d05d2;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.compliance-number span {
  font-family: 'Prompt', sans-serif;
  font-style: italic;
  font-weight: 300;
  font-size: 24px;
  line-height: 1;
  letter-spacing: 0.72px;
  color: #0d05d2;
}

.compliance-text {
  flex: 1;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.48px;
  color: #1a1a1a;
}

/* 事業所情報セクション */
.office-info-section {
  position: relative;
  overflow: hidden;
}

/* offices.html専用の背景画像付きスタイル */
.office-info-section.with-bg {
  border-radius: 0 80px 0 0;
  background-image: url(assets/logo-bg-Business.png);
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: auto 55%;
}

.office-info-inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 150px;
}

.office-info-section .section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 48px;
}

.office-info-section .zap-icon {
  width: 20px;
  height: 20px;
}

.office-info-section h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.57;
  letter-spacing: 0.56px;
  color: #0d05d2;
  margin: 0;
}

.office-cards-container {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.office-cards-row {
  display: flex;
  gap: 2px;
}

.office-cards-row:first-child {
  justify-content: flex-start;
}

.office-cards-row:last-child {
  justify-content: flex-start;
}

.office-info-section .office-card {
  background-color: #0d05d2;
  width: 380px;
  min-height: 290px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  color: #ffffff;
  position: relative;
  text-decoration: none;
  transition: all 0.3s ease;
}

a.office-card {
  text-decoration: none;
  color: inherit;
}

a.office-card:hover {
  background-color: #0a04a5;
}

.office-card-header {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.office-card-title {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px;
}

.office-dot {
  width: 20px;
  height: 20px;
  color: #ffffff;
  font-size: 16px;
  line-height: 1;
}

.office-card-title h4 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.67;
  letter-spacing: 0.6px;
  color: #ffffff;
  margin: 0;
  white-space: nowrap;
}

.office-card-address {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.office-card-address p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.48px;
  color: #ffffff;
  margin: 0;
  white-space: nowrap;
}

.office-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  /*margin-top: 16px;*/
}

.office-tag {
  background-color: transparent;
  border: 1px solid #ffffff;
  border-radius: 1000px;
  padding: 6px 12px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.36px;
  color: #ffffff;
  white-space: nowrap;
}

.office-card-link {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid #ffffff;
  border-radius: 4px;
  padding: 8px 12px;
  justify-content: space-between;
  align-self: flex-end;
  cursor: pointer;
}

.office-card-link span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.48px;
  color: #ffffff;
  white-space: nowrap;
}

.office-card-link .chevron-right {
  width: 20px;
  height: 20px;
  filter: invert(1);
}

/* 東京支社詳細ページスタイル */
.office-detail-container {
  width: 100%;
  background: #ffffff;
}

.office-detail-wrapper {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 30px;
}

/* サブタイトル */
.office-subtitle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 4px;
  margin-bottom: 24px;
}

.subtitle-icon {
  width: 20px;
  height: 20px;
}

.subtitle-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 48px;
  font-weight: 700;
  color: #000000;
  line-height: 1.5;
  letter-spacing: 0.015em;
  margin: 0;
}

/* メインコンテンツ */
.office-detail-content {
  background: #ffffff;
  box-shadow: 2px 2px 40px rgba(24, 19, 171, 0.12);
  padding: 64px 24px;
}

/* 支社情報セクション */
.office-info-section {
  display: flex;
  gap: 32px;
  /*margin-bottom: 100px;*/
}

.office-thumbnail {
  width: 318px;
  height: 350px;
  border-radius: 3.16px;
  overflow: hidden;
  flex-shrink: 0;
}

.office-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.office-info-table {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 180px;
  justify-content: space-between;
}

.info-row {
  display: flex;
  height: 60px;
  border-bottom: 1px solid rgba(13, 5, 210, 0.4);
}

.info-label {
  width: 160px;
  padding: 16px 8px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0d05d2;
  display: flex;
  align-items: center;
}

.info-value {
  flex: 1;
  padding: 16px 8px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #000000;
  line-height: 1.75;
  letter-spacing: 0.03em;
  display: flex;
  align-items: center;
}

/* セクションタイトル */
.section-title {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 48px;
  justify-content: center;
}

.section-icon {
  width: 20px;
  height: 20px;
}

.section-title h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: #0d05d2;
  line-height: 1.57;
  letter-spacing: 0.02em;
  margin: 0;
}

/* 業務範囲セクション */
.business-scope-section {
  padding: 80px 0;
}

.business-scope-table {
  width: 100%;
}

.scope-row {
  display: flex;
  min-height: 92px;
}

.scope-label {
  width: 300px;
  padding: 24px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: #0d05d2;
  border-bottom: 1px solid #0d05d2;
  margin-right: 3px;
  border-right: none;
  display: flex;
  align-items: center;
}

.scope-content {
  flex: 1;
  padding: 16px;
  border-bottom: 1px solid #0d05d2;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.scope-content p {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #000000;
  line-height: 1.75;
  letter-spacing: 0.03em;
  margin: 0;
}

.scope-row:not(:first-child) .scope-label,
.scope-row:not(:first-child) .scope-content {
  border-top: none;
}

/* 青背景のスタイル */
.blue-bg {
  background-color: #f1f4ff;
}

/* スコープタグ */
.scope-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 4px 0;
}

.scope-tag {
  display: inline-flex;
  padding: 4px 8px;
  background: #ffffff;
  border: 1px solid #0d05d2;
  border-radius: 4px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #000000;
  line-height: 1.5;
  letter-spacing: 0.03em;
}

/* 管轄の作業所セクション */
.affiliated-offices-section {
  padding-top: 64px;
}

.affiliated-offices-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  width: 100%;
}

.office-card {
  width: 100%;
  background: #ffffff;
  border: 1px solid #0d05d2;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.office-card:nth-child(3n+1) {
  margin-left: 0;
}

.office-card:nth-child(-n+3) {
  margin-top: 0;
}

.office-card-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(13, 5, 210, 0.6);
}

.office-name {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.6;
  letter-spacing: 0.025em;
  margin: 0;
  text-align: left;
}

.office-address {
  display: flex;
  align-items: center;
  gap: 4px;
}

.office-address img {
  width: 24px;
  height: 24px;
}

.office-address span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-weight: 400;
  color: #1a1a1a;
  line-height: 1.71;
  letter-spacing: 0.03em;
}

.office-tel {
  display: flex;
  align-items: center;
  gap: 4px;
}

.office-tel img {
  width: 20px;
  height: 20px;
}

.office-tel span {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #0d05d2;
  line-height: 1.6;
  letter-spacing: 0.025em;
}

/* 主要取引先ページスタイル */
.client-section-container {
  width: 100%;
  background: #ffffff;
  padding: 96px 150px 48px;
}

.client-section-wrapper {
  max-width: 1441px;
  margin: 0 auto;
}

/* カテゴリータイトル */
.client-category-title {
  background: #0d05d2;
  border-radius: 4px;
  padding: 8px 24px;
  margin-bottom: 40px;
  position: sticky;
  top: 100px;
  z-index: 100;
  transition: all 0.3s ease;
}

/* スティッキー状態のスタイル */
.client-category-title.is-sticky {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.client-category-title h2 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin: 0;
  text-align: center;
}

/* クライアントリスト */
.client-list-container {
  display: flex;
  flex-direction: column;
}

.client-group {
  display: flex;
  padding: 16px 0;
}

.client-group:last-child {
  border-bottom: none;
}

.light-bg {
  background-color: #f1f4ff;
}

.client-group-title {
  width: 400px;
  padding: 8px 16px 4px;
  flex-shrink: 0;
}

.client-group-title h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: #121212;
  line-height: 1.5;
  letter-spacing: 0.03em;
  margin: 0;
  text-align: left;
}

.client-group-items {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.client-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 16px;
  min-height: 44px;
}

.client-bullet {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}

.client-name {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: #121212;
  line-height: 1.75;
  letter-spacing: 0.03em;
}

/* 建設業タイトル */
.client-category-title.construction {
  background-color: #0d05d2;
}

.client-category-title.construction h2 {
  color: #ffffff;
}

/* Business Block Styles */
.business-block {
  position: relative;
  padding: 0;
  background: #ffffff;
}

.business-item {
  width: 100%;
  padding: 80px 150px;
  position: relative;
}

.business-content {
  display: flex;
  align-items: center;
  background: #0d05d2;
  padding-right: 0;
  position: relative;
}

.business-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 64px 80px;
  gap: 24px;
}

.business-header {
  display: flex;
  align-items: center;
  gap: 24px;
  padding-bottom: 24px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.business-number {
  display: flex;
  align-items: center;
  gap: 8px;
}

.number-text {
  font-family: "Prompt", sans-serif;
  font-style: italic;
  font-weight: 200;
  font-size: 56px;
  line-height: 1;
  letter-spacing: 0.03em;
  color: transparent;
  -webkit-text-stroke: 1px #ffffff;
  text-stroke: 1px #ffffff;
}

.zap-small.zap-icon-white {
  width: 20px;
  height: 20px;
  filter: invert(1);
}

.business-title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.57;
  letter-spacing: 0.02em;
  color: #ffffff;
  margin: 0;
}

.business-details {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.business-features {
  background: #ffffff;
  border-radius: 0;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.feature-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px;
}

.feature-icon {
  width: 10px;
  height: 10px;
  flex-shrink: 0;
}

.feature-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.03em;
  color: #0d05d2;
}

.business-description {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75;
  letter-spacing: 0.03em;
  color: #ffffff;
  margin: 0;
}

.business-image {
  width: 252px;
  height: 350.25px;
  flex-shrink: 0;
  overflow: hidden;
  border-radius: 0 30px 0 30px;    
  margin-right: 60px;
}

.business-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Qualified Tab Styles */
.qualified-tabs-container {
  width: 100%;
  background-color: #ffffff;
  padding: 64px 0 0;
  position: relative;
}

.qualified-tabs-container::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #0d05d2;
  z-index: 1;
}

.qualified-tabs-wrapper {
  display: flex;
  align-items: flex-end;
  max-width: 1141px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.qualified-tab {
  flex: 1;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background-color: #e4e8f4;
  border: 1px solid #767fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  color: #767fff;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}

.qualified-tab:hover {
  background-color: #d0d7ec;
}

.qualified-tab.active {
  background-color: #ffffff;
  border: 1px solid #0d05d2;
  border-bottom: none;
  color: #121212;
}

.qualified-tab.active::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: #ffffff;
  z-index: 3;
}

.tab-circle-icon {
  width: 8px;
  height: 8px;
}

/* Qualified Block Styles */
.qualified-block-container {
  width: 100%;
  background-color: #ffffff;
  padding: 0 150px 96px;
}

.qualified-block-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 50px;
  max-width: 1141px;
  margin: 0 auto;
}

.qualified-label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 40px;
}

.qualified-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 34px;
  line-height: 1.53;
  letter-spacing: 0.02em;
  color: #0d05d2;
  margin: 0;
}

.qualified-cards-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  width: 100%;
}

.qualified-card {
  width: 380px;
  min-width: 380px;
  background-color: #f1f4ff;
  border-bottom: 1px solid rgba(13, 5, 210, 0.4);
  border-right: 1px solid rgba(13, 5, 210, 0.4);
}

/* 1100px-1454pxで3列レイアウトを維持 */
@media (max-width: 1454px) and (min-width: 1100px) {
  .qualified-card {
    width: calc(33.333% - 1px);
    min-width: 0;
  }
  
  .qualified-name {
    font-size: 14px;
  }
  
  .qualified-card-body {
    padding: 12px;
  }
  
  .count-number {
    font-size: 14px;
  }
}

/* 1100px未満で2列レイアウト */
@media (max-width: 1099px) {
  .qualified-card {
    width: calc(50% - 0.5px);
    min-width: 0;
  }
  
  .qualified-card:nth-child(3n) {
    border-right: 1px solid rgba(13, 5, 210, 0.4);
  }
  
  .qualified-card:nth-child(2n) {
    border-right: none;
  }
}

.qualified-card:nth-child(3n) {
  border-right: none;
}

.qualified-card-body {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px;
  gap: 8px;
}

.qualified-name {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  color: #121212;
  flex: 1;
}

.qualified-count {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

.user-icon {
  width: 20px;
  height: 20px;
}

.count-number {
  font-family: 'Inter', sans-serif;
  font-weight: 400;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.03em;
  color: #1f1f1f;
}

.count-unit {
  font-family: 'BIZ UDPGothic', sans-serif;
  font-weight: 700;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.03em;
  color: #1f1f1f;
}

/* Single Post Styles */
/* KVエリアのスタイル */
.single-post-kv-title {
    padding: 20px 30px;
    background-color: #e8eaf6;
    margin-top: 20px;    
    width: 100%;
}

.single-post-kv-meta {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 10px;
}

.single-post-kv-meta .news-badge.new {
    /* color: #6e78ff; */
    font-weight: 700;
    font-size: 16px;
}

.single-post-kv-date {
    font-size: 18px;
    color: #1612c1;
    font-weight: 700;
}

.single-post-kv-category {
    display: inline-block;
    padding: 6px 16px;
    background-color: #1612c1;
    color: white;
    font-size: 14px;
    border-radius: 4px;
    font-weight: 500;
}

.single-post-title-text {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.5;
    color: #333333;
    margin: 0;
}

.single-post-section {
  margin-bottom: 100px;
}

.single-post-container {
    max-width: 800px;
    width: 100%;
    margin: 0 auto;
    padding: 0 30px;
}

.single-post {
    background: white;
    border-radius: 8px;
}
.single-button{
  text-align: center;
}
.single-post-header {
    margin-bottom: 30px;
}

.single-post-meta {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-bottom: 20px;
}

.single-post-date {
    font-size: 14px;
    color: #666;
}

.single-post-category {
    display: inline-block;
    padding: 4px 12px;
    background-color: #e3f2fd;
    color: #1976d2;
    font-size: 12px;
    border-radius: 4px;
    font-weight: 500;
}

.single-post-title {
    font-size: 32px;
    font-weight: 700;
    line-height: 1.4;
    color: #333;
    margin: 0;
}

.single-post-thumbnail {
    margin-bottom: 40px;
}

.single-post-thumbnail img {
    width: 100%;
    height: auto;
    border-radius: 8px;
}

.single-post-content {
    font-size: 16px;
    line-height: 1.8;
    color: #333;
    margin-bottom: 60px;
}

.single-post-content h2 {
    font-size: 24px;
    font-weight: 700;
    margin: 40px 0 20px;
    color: #333;
}

.single-post-content h3 {
    font-size: 20px;
    font-weight: 700;
    margin: 30px 0 15px;
    color: #333;
}

.single-post-content p {
    margin-bottom: 20px;
}

.single-post-content ul,
.single-post-content ol {
    margin: 20px 0;
    padding-left: 30px;
}

.single-post-content li {
    margin-bottom: 10px;
}

.single-post-footer {
    border-top: 1px solid #e0e0e0;
    padding-top: 30px;
}

.single-post-nav {
    display: flex;
    justify-content: space-around;
    align-items: center;
    flex-wrap: wrap;
    gap: 20px;
    margin-top: 60px;
}

.post-nav-link {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    color: #333;
    text-decoration: none;
    transition: all 0.3s ease;
}

.post-nav-link:hover {
    color: #5e35b1;
}

.post-nav-link.prev {
    margin-right: auto;
}

.post-nav-link.next {
    margin-left: auto;
}

.post-nav-link.list {
    padding: 15px 40px;
    background-color: transparent;
    color: #3949ab;
    border: 2px solid #3949ab;
    border-radius: 4px;
    font-weight: 500;
    font-size: 16px;
    transition: all 0.3s ease;
}

.post-nav-link.list:hover {
    background-color: #3949ab;
    color: white;
}

/* ニュースアーカイブセクション */
.news-archive-section {
  background-color: #ffffff;
  padding: 0px 30px;
}

.news-archive-container {
  max-width: 1140px;
  margin: 0 auto;
}

.news-archive-header {
  margin-bottom: 48px;
}

.news-archive-header .section-title {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  margin-bottom: 24px;
}

.news-archive-header .zap-icon {
  width: 20px;
  height: 20px;
}

.news-archive-header .title-text {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.57;
  color: #0d05d2;
  margin: 0;
}

.category-labels {
  display: flex;
  gap: 16px;
}

.category-label {
  display: inline-block;
  padding: 6px 12px;
  background-color: #0d05d2;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 500;
  font-size: 14px;
  color: white;
  cursor: pointer;
  transition: all 0.2s ease;
}

.category-label:hover {
  background-color: #e5e8ff;
  border-color: #0d05d2;
  color: #0d05d2;

}

/* ニュースリスト */
.news-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 48px;
}

.news-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 8px;
  border-bottom: 2px solid #a7b1ff;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.news-item:hover {
  background-color: rgba(167, 177, 255, 0.05);
}

.news-thumbnail {
  width: 163px;
  height: 100px;
  background-color: #f1f4ff;
  border-radius: 4px;
  flex-shrink: 0;
  overflow: hidden;
}

.news-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.news-meta {
  display: flex;
  align-items: center;
  gap: 8px;
}

.news-date {
  font-family: 'Prompt', sans-serif;
  font-weight: 400;
  font-size: 12px;
  color: #0d05d2;
  line-height: 1;
}

.news-badge {
  padding: 2px 8px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.67;
  letter-spacing: 0.04em;
  background: #971919;
}

.news-badge.new {
  color: #ffffff;
}

.news-category {
  background-color: #1612c1;
  color: #ffffff;
  padding: 2px 6px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 12px;
  line-height: 1.67;
  letter-spacing: 0.04em;
}

.news-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.75;
  color: #0d05d2;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}

.news-item .chevron-right {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

/* ページネーション */
.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.pagination-arrow {
  width: 32px;
  height: 32px;
  background-color: #ffffff;
  border: 1px solid #f1f4ff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.pagination-arrow:hover:not(:disabled) {
  background-color: #f1f4ff;
  border-color: #0d05d2;
}

.pagination-arrow:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.pagination-arrow img {
  width: 16px;
  height: 16px;
}

.pagination-page {
  width: 32px;
  height: 32px;
  background-color: #ffffff;
  border: 1px solid #f1f4ff;
  font-family: 'Prompt', sans-serif;
  font-style: italic;
  font-weight: 400;
  font-size: 14px;
  color: #0d05d2;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
}

.pagination-page:hover {
  background-color: #f1f4ff;
  border-color: #0d05d2;
}

.pagination-page.active {
  background-color: #0d05d2;
  color: #ffffff;
  border-color: #0d05d2;
}

.pagination-dots {
  font-family: 'Prompt', sans-serif;
  font-weight: 400;
  font-size: 14px;
  color: #a7b1ff;
  padding: 0 4px;
}

/* レスポンシブ対応 */
@media (max-width: 1024px) {
  .news-archive-container {
    padding: 0 100px;
  }
}

@media (max-width: 768px) {
  .news-archive-container {
    padding: 0 24px;
  }
  
  .news-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    padding: 20px 16px;
  }
  
  .news-thumbnail {
    width: 100%;
    max-width: 280px;
    height: 160px;
  }
  
  .news-meta {
    flex-wrap: wrap;
  }
  
  .news-title {
    -webkit-line-clamp: 2;
  }
  
  .news-item .chevron-right {
    display: none;
  }
}

/* ダウンロードブロック */
.download-block {
  width: 100%;
  padding: 96px 0;
  background-image: url('assets/download-block-bg.png');
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  position: relative;
}

.download-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 150px;
  position: relative;
  z-index: 2;
}

.download-inner {
  display: flex;
  gap: 24px;
  align-items: center;
}

.download-left {
  flex: 0 0 464px;
}

.slide-image-placeholder {
  width: 464px;
  height: 516px;
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

.slide-image-placeholder p {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 20px;
  color: #999999;
  margin: 0;
}

.download-right {
  flex: 1;
  padding-left: 40px;
}

.download-content {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.download-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.57;
  color: #0d05d2;
  margin: 0;
}

.download-description {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1.75;
  color: #0d05d2;
  margin: 0;
}

.download-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  background-color: #0d05d2;
  color: #ffffff;
  border: none;
  border-radius: 4px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  cursor: pointer;
  transition: all 0.2s ease;
  width: fit-content;
}

.download-button:hover {
  background-color: #0a04a8;
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(13, 5, 210, 0.2);
}

.download-button i {
  font-size: 18px;
}

/* レスポンシブ対応 */
@media (max-width: 1024px) {
  .download-container {
    padding: 0 100px;
  }
  
  .download-inner {
    flex-direction: column;
    align-items: center;
  }
  
  .download-left {
    flex: 0 0 auto;
  }
  
  .slide-image-placeholder {
    width: 400px;
    height: 445px;
  }
  
  .download-right {
    padding-left: 0;
    text-align: center;
  }
  
  .download-content {
    align-items: center;
  }
}

@media (max-width: 768px) {
  .download-block {
    padding: 60px 0;
  }
  
  .download-container {
    padding: 0 24px;
  }
  
  .slide-image-placeholder {
    width: 100%;
    max-width: 350px;
    height: 390px;
  }
  
  .download-title {
    font-size: 24px;
  }
  
  .download-description {
    font-size: 14px;
  }
  
  .download-button {
    padding: 10px 20px;
    font-size: 14px;
  }
}

/* FAQ セクションのスタイル */
.faq-tabs-container {
  width: 100%;
  background-color: #ffffff;
  padding: 64px 0 0;
  position: relative;
}

.faq-tabs-container::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background-color: #0d05d2;
  z-index: 1;
}

.faq-tabs-wrapper {
  display: flex;
  align-items: flex-end;
  max-width: 1141px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.faq-tab {
  flex: 1;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  background-color: #e4e8f4;
  border: 1px solid #767fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  color: #767fff;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
}

.faq-tab:hover {
  background-color: #d0d7ec;
}

.faq-tab.active {
  background-color: #ffffff;
  border: 1px solid #0d05d2;
  border-bottom: none;
  color: #121212;
}

.faq-tab.active::after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background-color: #ffffff;
}

.faq-tab .tab-circle-icon {
  width: 10px;
  height: 10px;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.faq-tab.active .tab-circle-icon {
  opacity: 1;
}

.faq-content-section {
  max-width: 1440px;
  margin: 0 auto;
  padding: 96px 150px;
}

.faq-content-container {
  position: relative;
}

.faq-content {
  display: none;
}

.faq-content.active {
  display: block;
}

.faq-section-title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 34px;
  font-weight: 700;
  color: #0d05d2;
  margin-bottom: 64px;
  letter-spacing: 2%;
  line-height: 1.53;
}

.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.faq-item {
  background: #fff;
  border: none;
  overflow: hidden;
}

.faq-question-item {
  width: 100%;
  height: 88px;
  border: none;
  background: #ffffff;
  padding: 28px 40px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: #1813ab;
  transition: background-color 0.3s ease;
  border: 1px solid #e9ecef;
  border-bottom: none;
}

.faq-item:last-child .faq-question-item {
  border-bottom: 1px solid #e9ecef;
}

.faq-question-item:hover {
  background: #f8f9fa;
}

.faq-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 4px;
  flex-shrink: 0;
}

.faq-icon-q {
  background: #1813ab;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 700;
  font-style: italic;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
}

.faq-icon-a {
  background: #1813ab;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 700;
  font-style: italic;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
}

.faq-question-text {
  flex: 1;
  line-height: 1.6;
  color: #1813ab;
}

.faq-toggle-icon {
  width: 20px;
  height: 20px;
  position: relative;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.icon-horizontal,
.icon-vertical {
  position: absolute;
  background-color: #1813ab;
  transition: all 0.3s ease;
}

.icon-horizontal {
  width: 16px;
  height: 2px;
}

.icon-vertical {
  width: 2px;
  height: 16px;
  transform: rotate(0deg);
}

.faq-item.open .icon-vertical {
  transform: rotate(90deg);
  opacity: 0;
}

.faq-answer-item {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
  background: #f1f4ff;
  border: 1px solid #e9ecef;
  border-top: none;
}

.faq-item.open .faq-answer-item {
  max-height: 500px;
  padding: 28px 40px;
}

.faq-answer-content {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.faq-answer-text {
  flex: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.8;
  color: #333;
}

.faq-answer-text p {
  margin: 0 0 16px 0;
}

.faq-answer-text ul {
  margin: 0;
  padding-left: 20px;
}

.faq-answer-text li {
  margin-bottom: 8px;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
  .faq-tabs-container {
    padding: 32px 0 0;
  }
  
  .faq-tabs-wrapper {
    padding: 0 24px;
    flex-wrap: wrap;
    gap: 8px;
  }
  
  .faq-tab {
    flex: 0 0 calc(50% - 4px);
    height: 48px;
    font-size: 14px;
  }
  
  .faq-content-section {
    padding: 32px 24px 48px;
  }
  
  .faq-section-title {
    font-size: 20px;
    margin-bottom: 24px;
  }
  
  .faq-question {
    padding: 20px;
    font-size: 14px;
  }
  
  .faq-icon {
    font-size: 18px;
  }
  
  .faq-answer p {
    font-size: 13px;
  }
}

/* 事業所一覧へ戻るボタン */
.back-to-list-button {
  display: flex;
  justify-content: center;
  margin-top: 80px;
  margin-bottom: 80px;
}

.btn-back-to-list {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: transparent;
  border: 1px solid #0d05d2;
  border-radius: 4px;
  padding: 12px 24px;
  text-decoration: none;
  transition: all 0.3s ease;
}

.btn-back-to-list:hover {
  background-color: #0d05d2;
  color: #ffffff;
}

.btn-back-to-list .chevron-left {
  width: 20px;
  height: 20px;
  transition: all 0.3s ease;
}

.btn-back-to-list:hover .chevron-left {
  filter: invert(1);
}

.btn-back-to-list span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.48px;
  color: #0d05d2;
  transition: all 0.3s ease;
}

.btn-back-to-list:hover span {
  color: #ffffff;
}

/* 協力会社殿の募集セクション */
.partner-recruitment-section {
  background-color: #0d05d2;
  padding: 64px 0;
  position: relative;
  background-image: url(assets/logo-bg-traced.svg);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: auto 150%;
}

.partner-recruitment-wrapper {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 150px;
}

.partner-recruitment-content {
  background-color: #ffffff;
  border-radius: 0 16px 16px 0;
  padding: 48px 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 48px;
  width: 100%;
}

.partner-text-content {
  flex: 1;
}

.partner-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 28px;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #0d05d2;
  margin: 0 0 16px 0;
  text-align: left;
}

.partner-description {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.71;
  letter-spacing: 0.03em;
  color: #1a1a1a;
  margin: 0;
  text-align: left;
}

.btn-contact-partner {
  all: unset;
  box-sizing: border-box;
  background-color: #ffffff;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 8px;
  position: relative;
  flex: 0 0 auto;
  border: 1px solid #0d05d2;
  border-radius: 4px;
  cursor: pointer;
  transition: background-color 0.2s ease;
  text-decoration: none;
}

.btn-contact-partner:hover {
  background-color: #f5f5f5;
}

.btn-contact-partner .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  background-color: transparent;
  border-radius: 4px;
}

.btn-contact-partner .icon i {
  color: #0d05d2;
  font-size: 16px;
}

.btn-contact-partner .label {
  font-family: "Zen Kaku Gothic New", Helvetica, sans-serif;
  position: relative;
  width: fit-content;
  font-weight: 700;
  color: #0d05d2;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1em;
  white-space: nowrap;
}

/* メガメニュー */
.megamenu-container {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;

  background-color: rgb(231 231 231 / 50%);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  z-index: 1000;
}

/* 通常ヘッダー用のメガメニュー位置調整 */
.header-normal + .megamenu-for-normal {
  position: fixed;
  top: 80px; /* ヘッダーの高さに合わせて調整 */
}

.megamenu-container.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.megamenu-inner {
  max-width: 1132px;
  margin: 0 auto;
  padding: 24px;
}

.megamenu-header .zap-icon {
  width: 20px;
  height: 20px;
}

.megamenu-header h3 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 20px;
  color: #0d05d2;
  margin: 0;
}

.megamenu-content {
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
  border-radius: 4px;
  box-shadow: 0 8px 32px 0 rgba(13, 5, 210, 0.1);
  padding: 0;
  display: flex;
  flex-direction: column;
}

.megamenu-header {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 24px;
  margin: 0;
  margin-top: 16px;
  border-radius: 4px 4px 0 0;
}

.megamenu-columns-wrapper {
  display: flex;
  gap: 12px;
  padding: 24px;
}

.megamenu-column {
  flex: 1;
}

.megamenu-column:last-child {
  /*
   * max-width: 260px;
   */
}

.megamenu-group-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px;
  color: #1a1a1a;
  margin-bottom: 12px;
}

.megamenu-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.megamenu-list li {
  padding: 4px 0;
}

.megamenu-list li a {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px 16px;
  color: #1a1a1a;
  text-decoration: none;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 14px;
  transition: background-color 0.2s ease;
}

.megamenu-list li a:hover {
  background-color: #f5f5f5;
}

.megamenu-list li a::before {
  content: '－';
  color: #666;
}

.megamenu-thumbnail img {
  width: 100%;
  height: 127px;
  object-fit: cover;
  border-radius: 4px;
  margin-bottom: 4px;
}

.megamenu-thumb-link {
  display: flex;
  align-items: center;
  padding: 6px 16px;
  border-radius: 4px;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.megamenu-thumb-link:hover {
  background-color: #e8e8e8;
}

.megamenu-thumb-link span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #1a1a1a;
  letter-spacing: 0.03em;
  line-height: 1.71;
}

.megamenu-thumb-link img {
  width: 16px;
  height: 16px;
}

.megamenu-buttons {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.megamenu-btn {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 4px;
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.megamenu-btn:hover {
  background-color: #e8e8e8;
}

.megamenu-btn span {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #1a1a1a;
  letter-spacing: 0.03em;
}

.megamenu-btn img {
  width: 16px;
  height: 16px;
}

/* 事業内容メガメニュー（1カラム専用） */
.megamenu-single-column .megamenu-inner {
  max-width: 356px;
  margin: 0 auto;
}

.megamenu-single-column .megamenu-content {
  width: 100%;
}

.megamenu-single-column .megamenu-columns-wrapper {
  grid-template-columns: 1fr;
  gap: 0;
}

.megamenu-single-column .megamenu-column {
  width: 100%;
}

/* 事業内容メガメニューのボタンスタイル調整 */
.megamenu-single-column .megamenu-buttons {
  margin-top: 16px;
}

.megamenu-single-column .megamenu-btn {
  width: 100%;
  margin-bottom: 8px;
}

.megamenu-single-column .megamenu-btn:last-child {
  margin-bottom: 0;
}

/* ====================================
   RESPONSIVE FIXES FOR HORIZONTAL SCROLL
   ==================================== */
@media (max-width: 1574px) {
  /* 150pxのパディングを持つ要素を調整 */
  /*
  .news-company-block,
  .company-info-inner,
  .company-history-block,
  .company-organizational-block,
  .offices-block,
  .offices-map-section,
  .subpage-kv,
  .message-block,
  .youtube-section,
  .shakun-section,
  .quality-policy-inner,
  .common-padding,
  .compliance-section,
  .office-info-inner,
  .client-section-container,
  .qualified-inner,
  .faq-content-section,
  .partner-recruitment-wrapper {
    padding-left: 48px !important;
    padding-right: 48px !important;
  }
  */  
  /* kv-blockの右セクションも調整 */
  .kv-block .right-section {
    padding-right: 48px;
  }
}

/* ====================================
   END OF RESPONSIVE FIXES
   ==================================== */

/* ====================================
   CTA BLOCK LINK STYLES
   ==================================== */
.CTA-mainoffice-link {
    text-decoration: none;
    color: inherit;
    display: block;
    transition: all 0.3s ease;
}

.CTA-mainoffice-link:hover .CTA-mainoffice {
    background-color: #f5f5f5;
    transform: translateY(-2px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.CTA-mainoffice {
    transition: all 0.3s ease;
}

/* ====================================
   NEWS DYNAMIC STYLES
   ==================================== */
.news-item {
    text-decoration: none;
    color: inherit;
    display: flex;
    transition: background-color 0.3s ease;
}

.news-item:hover {
    background-color: #f5f5f5;
}

.no-image-placeholder {
    width: 100%;
    height: 100%;
    background-color: #f0f0f0;
}

.no-news {
    padding: 60px 20px;
    text-align: center;
    color: #666;
    font-size: 16px;
}

.category-label {
    text-decoration: none;
    /* color: inherit; */
    cursor: pointer;
    transition: all 0.3s ease;
}

.category-label:hover {
    background-color: #e0e0e0;
}

.category-label.active {
    background-color: #0d05d2;
    color: #ffffff;
}

.pagination-arrow.disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.pagination-page {
    text-decoration: none;
    color: inherit;
}

/* ====================================
   FAQ DYNAMIC STYLES
   ==================================== */
.no-faq-message,
.no-faq-categories {
    padding: 40px 20px;
    text-align: center;
    color: #666;
    font-size: 16px;
}

.no-faq-categories {
    margin: 60px 0;
}

/* ====================================
   BACK TO TOP BUTTON
   ==================================== */
.back-to-top {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 60px;
  height: 60px;
  background-color: #0d05d2;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  z-index: 999999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(13, 5, 210, 0.3);
  gap: 2px;
}

.back-to-top:hover {
  background-color: #0a04a5;
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(13, 5, 210, 0.4);
}

.back-to-top.show {
  opacity: 1 !important;
  visibility: visible !important;
}

.back-to-top svg {
  width: 16px;
  height: 16px;
}

.back-to-top-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-weight: 700;
  color: #ffffff;
  line-height: 1;
  letter-spacing: 0.05em;
}

.youtube-blocks {
  display: flex !important;
  flex-direction: row !important;
  gap: 20px;
  flex-wrap: wrap;
}
.youtube-block {
  flex: 1;
  min-width: 300px; 
}
.youtube-video {
  width: 100%;
  max-width: 720px;
  height: auto;
}
.youtube-section {
  padding: 120px 50px 96px 50px;
}
.youtube-inner {
  max-width: 100%;
}
@media (min-width: 769px){
  .sp {
    display: none !important;
  }
}
/* タブレット・モバイル対応 */
@media (max-width: 1139px) {
  /* 固定ヘッダーを非表示 */
  .header-fixed {
    display: none !important;
  }
}

@media (max-width: 768px) {
  
  .back-to-top {
    bottom: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
  }
  
  .back-to-top svg {
    width: 14px;
    height: 14px;
  }
  
  .back-to-top-text {
    font-size: 11px;
  }
}


@media (min-width: 769px) {
  .sp{
    display: none !important;
  }
  .sp-br {
    display: none;
  }
  
  .pc-br {
    display: block;
  }
}


.news-thumbnail img{
    width: 100% !important;
    object-fit: cover;
}