@charset "UTF-8";
/* =============================
   Works Section Custom Layout
============================= */

.block-works .works-groups {
  display: flex;
  flex-direction: column;
  gap: 60px;
  margin-top: 40px;
}

/* 見出し */
.works-group__head {
  text-align: center;
  margin-bottom: 30px;
}

.works-group__en {
  font-size: 13px;
  letter-spacing: 0.2em;
  color: #30b364;
  font-weight: 600;
  margin-bottom: 6px;
}

.works-group__jp {
  font-size: 20px;
  font-weight: 700;
  display: inline-block;
  position: relative;
  padding-bottom: 10px;
}

.works-group__jp::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 60px;
  height: 1px;
  background: #ccc;
}

/* グリッド */
.works-list--grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

@media (min-width: 768px) {
  .works-list--grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1200px) {
  .works-list--grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* カード */
.works-list-item__image img {
  width: 100%;
  height: auto;
  display: block;
}

.works-list-item__text {
  text-align: center;
  margin-top: 14px;
  min-height: 60px;
}

.works-list-item__company {
  font-weight: 700;
  line-height: 1.4;
}

.works-list-item__sitename {
  font-size: 14px;
  color: #666;
  margin-top: 6px;
  line-height: 1.6;
}

/* 横スクロール無効化 */
.block-works .works-list {
  animation: none !important;
  white-space: normal !important;
}
/* ===== works の“自動横スクロール/ループ”を停止 ===== */
.block-works .works-list,
.block-works .works-list * {
  animation: none !important;
  transition: none;
}

.block-works .works-list {
  transform: none !important;
  will-change: auto !important;
}

/* 横スクロール用の横並びをやめてグリッド表示にする */
.block-works .works-list--grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

/* SP */
@media (max-width: 768px) {
  .block-works .works-list--grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }
}

/* =========================================
   Works: stop old loop/rail behaviors (force)
   ========================================= */
.block-works .works-list{
  animation: none !important;
  transform: none !important;
  translate: none !important;
  will-change: auto !important;
}

.block-works .works-rail{
  overflow: visible !important;
}

/* flex/nowrap を潰す（旧レール対策） */
.block-works .works-list{
  display: block !important;
  white-space: normal !important;
}

/* grid を勝たせる */
.block-works .works-list--grid{
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 24px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 768px){
  .block-works .works-list--grid{
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 24px 20px;
  }
}
@media (min-width: 1200px){
  .block-works .works-list--grid{
    grid-template-columns: repeat(4, minmax(0,1fr));
  }
}

/* 旧レールの固定幅を無効化 */
.block-works .works-list--grid .works-list-item{
  width: auto !important;
  margin: 0 !important;
  flex: none !important;
}

/* =========================================
   Works grid (new classes to avoid loop JS)
   ========================================= */
.block-works .works-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

@media (min-width: 768px){
  .block-works .works-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px 20px;
  }
}

@media (min-width: 1200px){
  .block-works .works-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.block-works .works-card{
  width: auto;
  margin: 0;
}

/* =========================================
   Works grid responsive (A + B)
   - PCは3列固定で「3つだけ空き」問題を回避
   - 1件だけ中央寄せ（is-single）
   ========================================= */

/* default: SPは2列（今のままでOKなら省略可） */
.block-works .works-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

/* TB以上：3列 */
@media (min-width: 768px){
  .block-works .works-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px 20px;
  }
}

/* PC以上：3列固定（4列にしない） */
@media (min-width: 1200px){
  .block-works .works-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* 1件だけ中央寄せ（ulに is-single を付与） */
.block-works .works-grid.is-single{
  grid-template-columns: minmax(0, 1fr) !important;
  max-width: 360px; /* カード幅に合わせて調整OK */
  margin-left: auto !important;
  margin-right: auto !important;
}

/* =========================
   2件だけ中央寄せ
   ========================= */

@media (min-width: 768px){
  .block-works .works-grid.is-two{
    grid-template-columns: repeat(2, 360px); /* カード幅 */
    justify-content: center;                 /* ←中央寄せ */
  }
}

/* =========================================
   Works: card width + image size unify
   ========================================= */

/* すべてのカードを「一定幅」で中央寄せ（列が広くても伸びすぎない） */
.block-works .works-card{
  width: 100%;
  max-width: 360px;          /* ← 1枚表示と同じ基準 */
  margin-left: auto;
  margin-right: auto;
}

/* 画像を常にカード幅いっぱいに */
.block-works .works-list-item__image img{
  width: 100%;
  height: auto;
  display: block;
}

/* =========================================
   実績下文
   ========================================= */

.page-top .main .block-works .business-record__lead2 {
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .page-top .main .block-works .business-record__lead2 {
    margin-top: 1.2rem;
    margin-bottom: 1.2rem;
    font-size: 1.5rem;
  }
}
@media screen and (min-width: 768px) {
  .page-top .main .block-works .business-record__lead2 {
    margin-top: 3.6rem;
    margin-bottom: 3.6rem;
    font-size: 2.4rem;
  }
}