/* numbers-cards-stylish.css
   モバイルファースト（ベース = モバイル）最小構成
   前提: variables.css があればそちらを優先、なければ下の変数を使用
*/

/* カラーパレット（必要最小限） */
:root{
  --nc-bg: #f1f1f1;
  --nc-card: rgb(255, 255, 255);
  --nc-accent-2: #e49364;
  --nc-muted: #6b6b6b;
  --nc-ink: #0f1720;
  --nc-shadow: rgba(16,24,40,0.06);
  --nc-radius-lg: 16px;
  --nc-radius: 12px;
  --nc-gap: 16px;
}
.section__en__num{
  font-size:2rem;
  letter-spacing:0em;
  color:#1a478b;
  margin-bottom:0px;
  font-weight: 700;
  text-align:center
}

.section__title__num{
  font-size:1.2rem;
  letter-spacing:0em;
  color:#999999;
  margin-top: 0px;
  margin-bottom:0px;
  font-weight:600;
  text-align:center
}

/* ページベース */
body.numbers-page {
  background: var(--nc-bg);
  color: var(--nc-ink);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* グリッド（モバイル = 1列） */
.data-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--nc-gap);
  margin-top: 16px;
  align-items: start;
  padding: 0;
}

/* カード（共通） */
.data-card {
  background: linear-gradient(180deg, var(--nc-card), rgb(255, 255, 255));
  border-radius: var(--nc-radius-lg);
  border: 1px solid rgba(16,24,40,0.03);
  box-shadow: 0 8px 20px var(--nc-shadow);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: auto; /* モバイルでは自動、高さはコンテンツに依存 */
}

/* テンプレで使う順序クラス（ベース） */
.data-card__text--top { order: 1; padding: 12px 14px 8px; display:flex; align-items:center; justify-content:center; }
.data-card__img       { order: 2; margin: 0 12px; display:flex; align-items:center; justify-content:center; }
.data-card__meta      { order: 3; padding: 8px 14px 12px; display:flex; flex-direction:column; align-items:center; gap:6px;height: 125px; }

/* 画像領域（モバイルは縦長寄り） */
.data-card__img {
  width: 100%;
  aspect-ratio: 1/1; /* モバイルはやや横長に見せるが狭い画面向け */
  background: linear-gradient(180deg,#f0fff4,#eefaf0);
  border-radius: 10px;
  overflow: hidden;
}
.data-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* テキスト（中央寄せ） */
.data-card__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--nc-accent-2);
  margin: 0;
  text-align: center;
  line-height: 2;
}

.data-card__value {
  font-size: 2.8rem;
  font-weight: 300;
  color: var(--nc-ink);
  margin: 0;
  min-height: 1.6rem; /* 空でもスペースを確保 */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}

.data-card__note {
  font-size: 0.88rem;
  color: var(--nc-muted);
  margin: 0;
  min-height: 1.2rem; /* 空でもスペースを確保 */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}


.data-card__note { min-height: 2rem; }


/* フォーカス（アクセシビリティ） */
.data-card:focus {
  outline: 3px solid rgba(42,160,90,0.12);
  outline-offset: 2px;
}

/* -------------------- ブレイクポイント（拡張） -------------------- */
/* タブレット以上（例: 700px 以上） */
@media (min-width: 700px) {
  .data-card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }

  .data-card {
    height: 550px; /* デスクトップ寄せの高さをここで指定 */
    border-radius: var(--nc-radius-lg);
  }

  .data-card__img {
    aspect-ratio: 1/1; /* より正方形寄りに */
    margin: 0 18px;
    border-radius: 12px;
  }

  /* サイズバリエーションを有効にする */
  .data-card--large { grid-column: span 2; }
  .data-card--tall  { grid-row: span 2; }
  .data-card--large-tall { grid-column: span 2;height: 700px;}
  .data-card--holidays .data-card__img { aspect-ratio: 1/1; }
}

/* デスクトップ以上（例: 1100px 以上） */
@media (min-width: 1100px) {
  .data-card-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
  }

  .data-card {
    min-height: 240px;
    box-shadow: 0 12px 30px var(--nc-shadow);
  }

  .data-card__title { font-size: 1.5rem; }
  .data-card__value { font-size: 1.2rem; }
}

/* 数値と単位を分けて装飾 */
.data-card__value {
  font-weight: 500;
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 6px;
  line-height: 1;
}

/* 数字部分 */
.data-card__value-num {
  font-size: clamp(3rem, 4vw, 5rem);
  font-weight: 700;
  color: var(--nc-accent-2);
  letter-spacing: -0.02em;
  line-height: 1;
}

/* 単位や補助テキスト */
.data-card__value-unit {
  font-size: 1rem;
  color: var(--nc-muted);
  font-weight: 600;
  line-height: 1;
}

/* パーセントや複合値のときは少し小さめに */


/* レスポンシブ調整 */
@media (min-width: 700px) {
  .data-card__value { font-size: 3rem; }
  .data-card__value-unit { font-size: 1.05rem; }
}

@media (min-width: 1100px) {
  .data-card__value { font-size: 2rem; }
  .data-card__value-unit { font-size: 1.1rem; }
}


/* コンテナで切り取り、背景を設定して透過部分の見え方を安定化 */
.data-card__img {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: 10px;
  margin: 0;
  position: relative;
  background: #ffffff; /* 透過部分の背景 */
}

.data-card__value-label {
  font-size: 0.95rem;
  color: var(--nc-muted);
  font-weight: 600;
  margin-right: 6px;
  white-space: nowrap;
}



/* 指定の比率だけを上書き（余計な追加なし） */
.data-card--large  .data-card__img { aspect-ratio: 2 / 1; }   /* large: width:height = 2:1 */
.data-card--tall   .data-card__img { aspect-ratio: 1 / 2; }   /* tall:  width:height = 1:2 */
.data-card--large-tall .data-card__img { aspect-ratio: 1 / 1; } /* large-tall: 1:1 */