/*
 * sutekina-home.css
 * 「素敵な社員食堂」ホームページ専用スタイル
 *
 * sutekina-base.css の共通スタイルを前提としている。
 * ヒーロー・コンセプトセクション・記事カードグリッドを定義。
 */

/* ── ヒーローセクション ── */
/*
 * メインサイトとの見た目の断絶を作るため、
 * 暖色グラジエントで全画面を覆う独立したヒーローを設ける。
 */
.s-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: #3D1C08; /* 画像読み込み前のフォールバック色 */
  background-image:
    linear-gradient(rgba(44,16,8,0.52), rgba(44,16,8,0.38)),
    url('../img/homepage/hero.jpg');
  background-size: cover;
  background-repeat: no-repeat;
  /* ↓ バナー画像の表示位置。「左右 上下」の順。
     上下: top / center / bottom もしくは 0%(上)〜100%(下)。
     例) center top（上を見せる） / center 30% / center bottom */
  background-position: center;
}

/* 背景テクスチャ：視覚的な温かみを加えるドットパターン */
.s-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}

/* アンバーグロー：ヒーローに光源のような輝きを追加 */
.s-hero::after {
  content: '';
  position: absolute;
  bottom: -80px;
  right: -80px;
  width: 480px;
  height: 480px;
  background: radial-gradient(circle, rgba(232, 168, 85, 0.20) 0%, transparent 70%);
  pointer-events: none;
}

.s-hero__inner {
  position: relative;
  z-index: 1;
  padding: calc(var(--s-nav-height) + 3rem) 10% 4rem;
}

/* バッジ：コーナーが何であるかをユーザーに即座に伝える */
.s-hero__badge {
  display: inline-block;
  font-family: var(--s-font-sans);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--s-amber);
  background: rgba(232, 168, 85, 0.15);
  border: 1px solid rgba(232, 168, 85, 0.35);
  padding: 0.3rem 0.9rem;
  border-radius: 999px;
  margin-bottom: 1.25rem;
}

.s-hero__title {
  font-family: var(--s-font-serif);
  font-size: clamp(2rem, 5vw, 3.25rem);
  font-weight: 400;
  color: var(--s-white);
  line-height: 1.2;
  margin-bottom: 1rem;
  max-width: 20ch;
}

.s-hero__tagline {
  font-family: var(--s-font-sans);
  font-size: clamp(0.9375rem, 1.5vw, 1.0625rem);
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.75;
  max-width: 60ch;
  margin-bottom: 2rem;
}

/* アニメーション：コンテンツをフェードインで登場させる */
.s-hero__badge,
.s-hero__title,
.s-hero__tagline,
.s-hero .s-btn {
  animation: s-fadeUp 0.6s ease both;
}

.s-hero__badge  { animation-delay: 0.0s; }
.s-hero__title  { animation-delay: 0.1s; }
.s-hero__tagline{ animation-delay: 0.2s; }
.s-hero .s-btn  { animation-delay: 0.3s; }

@keyframes s-fadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── コンセプトセクション ── */
/*
 * このコーナーの目的（お客様の食堂を広く紹介すること）を
 * 2カラムレイアウトで見やすく伝える。
 */
.s-concept {
  padding: 5rem 0;
  background: var(--s-cream);
}

.s-concept__inner {
  padding: 0 10%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}

.s-concept__text {}

.s-concept__body {
  font-size: 0.9375rem;
  color: var(--s-ink-mid);
  line-height: 1.9;
  margin-top: 1rem;
}

/* コンセプト装飾パネル：記事カードのプレビューを示す */
.s-concept__visual {
  background: var(--s-sand);
  border-radius: var(--s-radius-lg);
  padding: 2rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border: 1px solid var(--s-border);
}

/* 装飾内のダミー行 */
.s-concept__visual-line {
  height: 12px;
  background: rgba(196, 92, 46, 0.15);
  border-radius: 6px;
}

.s-concept__visual-line:nth-child(2) { width: 80%; }
.s-concept__visual-line:nth-child(3) { width: 65%; }

.s-concept__visual-img {
  width: 100%;
  aspect-ratio: 5 / 4;
  border-radius: var(--s-radius-md);
  object-fit: cover;
  display: block;
}

/* ── 企業ロゴカード（セクション3）── */
.s-co-card__logo {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, var(--s-terracotta) 0%, var(--s-amber) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}

.s-co-card__logo--muted {
  background: linear-gradient(135deg, #B0A090 0%, #C8B8A0 100%);
}

.s-co-card__initial {
  font-family: var(--s-font-serif);
  font-size: 2.5rem;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.90);
  letter-spacing: 0.05em;
}

.s-co-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.25rem;
}

/* セクションの交互背景 */
.s-articles--alt {
  background: var(--s-white);
}

.s-articles--alt .s-card__img {
  object-position: top;
}

/* ── 食堂訪問レポート ── */
.s-visits {
  padding: 5rem 0;
  background: var(--s-white);
}

.s-visits__inner {
  padding: 0 10%;
}

.s-visits__head {
  margin-bottom: 2.5rem;
}

.s-visits__list {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.s-vcard {
  display: flex;
  flex-direction: row;
  background: var(--s-white);
  border: 1px solid var(--s-border);
  border-radius: var(--s-radius-md);
  overflow: hidden;
  text-decoration: none;
  transition: box-shadow var(--s-transition), border-color var(--s-transition);
}

.s-vcard:not(.s-vcard--soon):hover {
  box-shadow: 0 6px 24px rgba(44, 24, 16, 0.10);
  border-color: rgba(196, 92, 46, 0.30);
}

.s-vcard__img-wrap {
  position: relative;
  width: 38%;
  flex-shrink: 0;
  min-height: 220px;
  overflow: hidden;
}

.s-vcard__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.s-vcard__vol-tag {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  background: rgba(44, 24, 16, 0.55);
  backdrop-filter: blur(4px);
  color: var(--s-white);
  font-size: 0.6875rem;
  font-weight: 500;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.25);
}

.s-vcard__body {
  flex: 1;
  padding: 1.75rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.s-vcard__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.s-vcard__company {
  font-family: var(--s-font-serif);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--s-ink);
  margin-top: 0.25rem;
}

.s-vcard__headline {
  font-family: var(--s-font-serif);
  font-size: 0.9375rem;
  font-style: italic;
  font-weight: 300;
  color: var(--s-ink-mid);
  line-height: 1.6;
}

.s-vcard__stats {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0 1.25rem;
  margin-top: 0.25rem;
}

.s-vcard__stats li {
  font-size: 0.8125rem;
  color: var(--s-ink-light);
}

.s-vcard__stats li + li::before {
  content: '／ ';
  color: var(--s-border-md);
}

.s-vcard__cta {
  margin-top: auto;
  padding-top: 1rem;
  font-size: 0.875rem;
  color: var(--s-terracotta);
  font-weight: 500;
}

.s-vcard--soon {
  opacity: 0.60;
  pointer-events: none;
}

.s-vcard__soon-label {
  display: inline-block;
  margin-top: auto;
  padding-top: 0.75rem;
  font-size: 0.75rem;
  color: var(--s-ink-light);
  border: 1px solid var(--s-border);
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  align-self: flex-start;
  margin-top: 0.5rem;
}

/* ── インタビュー特集 ── */
.s-interviews {
  padding: 5rem 0;
  background: var(--s-sand);
}

.s-interviews__inner {
  padding: 0 10%;
}

.s-interviews__head {
  margin-bottom: 2.5rem;
}

.s-interviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

.s-icard {
  background: var(--s-white);
  border: 1px solid var(--s-border);
  border-radius: var(--s-radius-md);
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  text-decoration: none;
  transition: box-shadow var(--s-transition), border-color var(--s-transition);
}

.s-icard:not(.s-icard--soon):hover {
  box-shadow: 0 6px 20px rgba(44, 24, 16, 0.10);
  border-color: rgba(196, 92, 46, 0.30);
}

.s-icard__portrait {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--s-terracotta), var(--s-amber));
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--s-font-serif);
  font-size: 1.25rem;
  color: var(--s-white);
  flex-shrink: 0;
}

.s-icard__portrait--muted {
  background: linear-gradient(135deg, #C8B8A8, #A89888);
}

.s-icard__role {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--s-terracotta);
  text-transform: uppercase;
}

.s-icard--soon .s-icard__role {
  color: var(--s-ink-light);
}

.s-icard__name {
  font-family: var(--s-font-serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--s-ink);
}

.s-icard__org {
  display: block;
  font-size: 0.8125rem;
  color: var(--s-ink-light);
  font-style: normal;
  margin-top: 0.1rem;
}

.s-icard__quote {
  font-family: var(--s-font-serif);
  font-size: 0.9375rem;
  font-style: italic;
  font-weight: 300;
  color: var(--s-ink-mid);
  line-height: 1.75;
  border-left: 2px solid var(--s-amber);
  padding-left: 0.75rem;
  margin: 0;
  flex: 1;
}

.s-icard--soon .s-icard__quote {
  border-left-color: var(--s-border-md);
  color: var(--s-ink-light);
}

.s-icard__cta {
  font-size: 0.875rem;
  color: var(--s-terracotta);
  font-weight: 500;
  margin-top: auto;
}

.s-icard__soon-label {
  display: inline-block;
  font-size: 0.75rem;
  color: var(--s-ink-light);
  border: 1px solid var(--s-border);
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  align-self: flex-start;
}

/* ── 最新記事セクション ── */
/*
 * shashoku.com を参考に、記事をカードグリッドで一覧表示する。
 * 将来的に記事が増えてもグリッドが自動で対応できるよう
 * auto-fill を使用。
 */
.s-articles {
  padding: 5rem 0;
  background: var(--s-sand);
}

.s-articles__header {
  padding: 0 10%;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
  gap: 1rem;
}

.s-articles__heading-group {}

.s-articles__see-all {
  font-size: 0.875rem;
  color: var(--s-terracotta);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  transition: gap var(--s-transition);
}

.s-articles__see-all:hover {
  gap: 0.6rem;
}

/* カードグリッド：3カラム → タブレット2カラム → モバイル1カラム */
.s-articles__grid {
  padding: 0 10%;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

/* ── 記事カード ── */
.s-card {
  background: var(--s-white);
  border-radius: var(--s-radius-md);
  overflow: hidden;
  border: 1px solid var(--s-border);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform var(--s-transition), box-shadow var(--s-transition), border-color var(--s-transition);
}

.s-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(44, 24, 16, 0.12);
  border-color: rgba(196, 92, 46, 0.30);
}

/* カード画像エリア */
.s-card__img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
  background: linear-gradient(135deg, var(--s-sand), rgba(196,92,46,0.10));
}

.s-co-card .s-card__img {
  height: auto;
  aspect-ratio: 1 / 1;
}

/* 画像がない場合のプレースホルダー */
.s-card__img-placeholder {
  width: 100%;
  height: 180px;
  background: linear-gradient(135deg, #F0E8DC 0%, #E8D5C0 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--s-font-serif);
  font-size: 0.875rem;
  color: var(--s-brown);
  font-style: italic;
}

.s-card__body {
  padding: 1.25rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* 会社名タグ */
.s-card__company {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--s-terracotta);
  letter-spacing: 0.05em;
}

.s-card__title {
  font-family: var(--s-font-serif);
  font-size: 1rem;
  font-weight: 400;
  color: var(--s-ink);
  line-height: 1.4;
}

.s-card__excerpt {
  font-size: 0.8125rem;
  color: var(--s-ink-mid);
  line-height: 1.7;
  flex: 1;
  /* 2行に切り詰める */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.s-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.5rem;
}

.s-card__date {
  font-size: 0.75rem;
  color: var(--s-ink-light);
}

.s-card__link {
  font-size: 0.8125rem;
  color: var(--s-terracotta);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
}

/* カムアップカード（準備中） */
.s-card--coming {
  opacity: 0.6;
  pointer-events: none;
}

.s-card--coming .s-card__img-placeholder {
  opacity: 0.7;
}

/* 近日公開プレースホルダー（? タイル） */
.s-card--soon {
  pointer-events: none;
}

.s-card__img-placeholder--q {
  font-family: var(--s-font-serif);
  font-size: 3.25rem;
  font-weight: 700;
  font-style: normal;
  color: var(--s-terracotta);
  opacity: 0.6;
}

.s-co-card .s-card__img-placeholder {
  height: auto;
  aspect-ratio: 1 / 1;
}

.s-hero__soon {
  margin-top: 1.25rem;
  font-family: var(--s-font-serif);
  font-size: 1.05rem;
  letter-spacing: 0.12em;
  color: var(--s-white);
  opacity: 0.92;
}

/* ── 記事一覧ページ ヒーロー ── */
.s-list-hero {
  background: var(--s-sand);
  padding: calc(var(--s-nav-height) + 2.5rem) 10% 2.5rem;
  border-bottom: 1px solid var(--s-border);
}

.s-list-hero__count {
  font-size: 0.875rem;
  color: var(--s-ink-light);
  margin-top: 0.5rem;
}

/* ── 記事カルーセル ── */
.s-carousel-wrap {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 10%;
}

.s-carousel {
  flex: 1;
  min-width: 0;
  display: flex;
  gap: 1.5rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  scroll-behavior: smooth;
  padding-bottom: 0.5rem;
}

.s-carousel::-webkit-scrollbar {
  display: none;
}

.s-carousel .s-card {
  flex: 0 0 calc((100% - 3rem) / 3);
  scroll-snap-align: start;
  min-width: 0;
}

#s-companies .s-carousel .s-card {
  flex: 0 0 calc((100% - 7.5rem) / 6);
}

.s-carousel-arrow {
  flex-shrink: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--s-white);
  border: 1px solid var(--s-border-md);
  color: var(--s-terracotta);
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(44, 24, 16, 0.10);
  transition: background var(--s-transition), opacity var(--s-transition);
}

.s-carousel-arrow:hover:not(:disabled) {
  background: var(--s-sand);
}

.s-carousel-arrow:disabled {
  opacity: 0.3;
  cursor: default;
}

/* ── レスポンシブ ── */
@media (max-width: 860px) {
  .s-concept__inner {
    grid-template-columns: 1fr;
  }

  .s-concept__visual {
    display: none;
  }

  .s-articles__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .s-carousel .s-card {
    flex: 0 0 calc((100% - 1.5rem) / 2);
  }

  #s-companies .s-carousel .s-card {
    flex: 0 0 calc((100% - 3rem) / 3);
  }

  .s-vcard {
    flex-direction: column;
  }

  .s-vcard__img-wrap {
    width: 100%;
    min-height: 0;
    aspect-ratio: 16 / 9;
  }

  .s-interviews__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .s-vcard__body {
    padding: 1.25rem;
  }
}

@media (max-width: 520px) {
  .s-articles__grid {
    grid-template-columns: 1fr;
  }

  .s-carousel .s-card {
    flex: 0 0 85%;
  }

  #s-companies .s-carousel .s-card {
    flex: 0 0 85%;
  }

}

/* ── 掲載企業一覧ページ：カードをホームの企業カードと同じサイズに ── */
.s-articles__grid--companies {
  grid-template-columns: repeat(6, 1fr);
}

@media (max-width: 860px) {
  .s-articles__grid--companies {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 520px) {
  .s-articles__grid--companies {
    grid-template-columns: repeat(2, 1fr);
  }
}
