@charset "utf-8";

/* =========================
   Onime LP (PC)
   Scope: .contentsOnime only
   ========================= */

.contentsOnime{
  width: 830px;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;

  /* 使い回す値（見た目を変えずに整理） */
  --gap: 16px;
  --gap-lg: 18px;
  --bd: 1px solid #ddd;
  --bg: #fff;
}

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

.contentsOnime img{
  vertical-align: bottom;
}

h1::after {
    content: "ONIME NUT";
}

/* breadcrumb を nav で囲った時に右寄りになるのを防ぐ */
.contentsOnime nav.breadcrumb,
.contentsOnime #breadcrumb{
  width: 100%;
  max-width: 830px;      /* 830基準なら */
  margin: 0 auto 12px;   /* 中央寄せラッパー内で左寄せ表示 */
  text-align: left;
  float: none;
  clear: both;
}

.contentsOnime nav.breadcrumb ul{
  margin: 0;
  padding: 0;
  text-align: left;
}

/* -------------------------
   見出し
------------------------- */
.contentsOnime .on-h2{
  font-size: 22px;
  line-height: 1.4;
  margin: 0 0 18px;
  padding: 0;
  text-align: center;
  position: relative;
  padding-bottom: 14px; /* 線との距離 */
}

.contentsOnime .on-h2::after{
  content: "";
  display: block;
  width: 100px;              /* ← ここで長さ調整（100〜200px） */
  height: 3px;               /* 太さ */
  background-color: #00973D;
  margin: 12px auto 0;       /* 中央寄せ */
  border-radius: 2px;
}

/* -------------------------
   セクション共通
------------------------- */
.contentsOnime .on-sec{
  margin: 64px 0 0;
}

/* -------------------------
   ヒーロー
------------------------- */
.contentsOnime .on-hero{
  margin: 12px 0 0;
}
.contentsOnime .on-hero img{
  width: 100%;
  height: auto;
  display: block;
}

/* メインビジュアル下の受賞帯 */
.contentsOnime .on-award{
  background: #4a4a4a;
  color: #fff;
  font-size: 18px;
  line-height: 1.6;
  padding: 12px 16px;
  text-align: center;
}

/* 商標注記（画像直下用：右寄せ） */
.contentsOnime .on-award-note{
  font-size: 12px;
  color: #666;
  line-height: 1.6;
  margin: 8px 0 26px;
  text-align: right;
}

/* -------------------------
   “箱”系の共通（重複整理）
   ※既存の見た目を変えずにまとめる
------------------------- */
.contentsOnime .on-card,
.contentsOnime .on-types__box,
.contentsOnime .on-flange,
.contentsOnime .on-step,
.contentsOnime .on-usage__item{
  border: var(--bd);
  background: var(--bg);
  box-sizing: border-box;
}

/* -------------------------
   ラインナップ（ON-04）
------------------------- */
/* ON-04 / ON-11 共通：カード行を4列グリッドにする */
.on-lineupGrid .on-lineup__row{
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: 16px; /* 横スペース */
  row-gap: 24px;    /* 縦スペース */
  justify-content: start;
  justify-items: stretch;
}

.on-lineupGrid .on-lineup__row > .on-card{
  flex: none !important;
  width: 100%;
  max-width: none !important;
  min-width: 0;
  margin: 0;
}

.on-lineupGrid .on-lineup__row + .on-lineup__row{
  margin-top: var(--gap);
}

/* バッジ共通：サイズと位置 */
.contentsOnime .on-card__badge{
  position: absolute;
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;

  display: inline-block;
  opacity: 1 !important;
  visibility: visible !important;

  padding: 2px 6px;
  font-size: 10px;
  line-height: 1.2;
  font-weight: 500;
  border-radius: 2px;

  color: #fff;
  white-space: nowrap;
  box-sizing: border-box;
}

/* 色 */
.contentsOnime .on-card__badge--online{ background: #00973D; }
.contentsOnime .on-card__badge--offline{ background: #666; }

/* もし hover で消したり薄くする指定がどこかにある場合の保険 */
.contentsOnime .on-card:hover .on-card__badge{
  opacity: 1 !important;
  visibility: visible !important;
}

/* 非掲載カードは“押せない”見た目に */
.contentsOnime .on-card--offline{
  cursor: default;
  opacity: 0.92;
}

.contentsOnime .on-card--offline .on-card__img img{
  filter: grayscale(10%);
}

.contentsOnime .on-lineup__row + .on-lineup__row{
  margin-top: var(--gap);
}


/* クリック可能なカードだけ hover を出す */
.on-card[href]:hover{
  box-shadow: 0 0 0 1px #2aa44f;
}

/* -------------------------
   カード
------------------------- */
.contentsOnime .on-card{
  display: block;
  transition: box-shadow .15s ease, transform .15s ease;
  position: relative;
  padding-top: 18px;     /* バッジ分のスペース */
  box-sizing: border-box;
}
.contentsOnime .on-card[href]:hover{
  box-shadow: 0 3px 12px rgba(0,0,0,.08);
  transform: translateY(-1px);
}

/* カード画像 */
.contentsOnime .on-card__img img{
  width: 100%;
  height: auto;
  display: block;
  position: relative;
}

/* 製品名（センター＋矢印） */
.contentsOnime .on-card__name{
  padding: 0px 8px 5px;
  font-size: 12px;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
}
.contentsOnime .on-card__name::after{
  content: " ›";
  font-weight: normal;
  opacity: .6;
}

/* 強調カード */
.contentsOnime .on-card--main .on-card__name{
  font-size: 13px;
}

/* 製品ラインナップ：カード名エリアの下に余白 */
.contentsOnime .on-lineup .on-card__name{
  display: block;
}

/* -------------------------
   テキスト
------------------------- */
.contentsOnime .on-text{
  font-size: 15px;
  line-height: 1.9;
  margin: 0;
}

/* =========================
   ON-05: about（画像20%＋本文80%）
========================= */
.contentsOnime .on-about__wrap{
  display: flex;
  gap: var(--gap-lg);
  align-items: flex-start;
}
.contentsOnime .on-about__img{
  flex: 0 0 20%;
}
.contentsOnime .on-about__img img{
  width: 100%;
  height: auto;
  display: block;
}
.contentsOnime .on-about__body{
  flex: 1 1 80%;
}
/* ON-05：about 段落間の余白を明示 */
.contentsOnime .on-about__body .on-text{
  margin: 0 0 1.4em;
}

/* =========================
   ON-06: types
========================= */
.contentsOnime .on-types__lead{
  margin: 0 0 14px;
  font-size: 14px;
  line-height: 1.8;
}

.contentsOnime .on-types__wrap{
  display: flex;
  gap: var(--gap-lg);
  align-items: stretch;
}

/* 主な種類：左右でgrid2位置を揃える（文章量が違ってもOK） */
.contentsOnime .on-types__box{
  flex: 1 1 0;
  padding: 14px 14px 12px;
  display: flex;
  flex-direction: column;
}

.contentsOnime .on-types__head{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  margin-bottom: 10px;
  justify-content: initial;
  gap: 0;
  position: static;
  min-height: 60px;
}

.contentsOnime .on-types__title{
  grid-column: 2;
  text-align: center;
  font-size: 22px;
  line-height: 1.3;
}

/* アイコンは右側に固定しつつ、はみ出さないサイズに */
.contentsOnime .on-types__icon{
  grid-column: 3;
  justify-self: end;

  width: 60px;
  max-height: 60px;
  height: auto;

  /* 元のabsolute配置を完全に無効化 */
  position: static;
  right: auto;
  top: auto;
  transform: none;
}

.contentsOnime .on-types__desc{
  margin: 0 0 12px;
  font-size: 13px;
  line-height: 1.8;
  color: #333;
  flex: 1; /* ここが伸び縮みして、下のgrid2位置を揃える */
}

.contentsOnime .on-types__grid2{
  display: flex;
  gap: 12px;
  margin-top: 12px;
}

.contentsOnime .on-types__grid2 .on-types__col:nth-child(2) .on-types__cap{
  background: #00973D;
  color: #fff;
}

.contentsOnime .on-types__col{
  flex: 1 1 0;
  border: 1px solid #e3e3e3; /* typesだけ別枠線なので維持 */
}

.contentsOnime .on-types__cap{
  background: #4a4a4a;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  text-align: center;
  padding: 8px 8px;
  border-bottom: 1px solid #e3e3e3;
}

.contentsOnime .on-types__prod{
  display: block;
  padding: 10px 10px 10px;
  text-align: center;
}

.contentsOnime .on-types__prod img{
  width: 100%;
  height: auto;
  display: block;
}

.contentsOnime .on-types__prodname{
  display: block;
  margin-top: 5px;
  font-size: 13px;
  font-weight: bold;
}

/* hover（カードと統一感） */
.contentsOnime .on-types__prod:hover{
  background: #fafafa;
}

/* ON-06: flange description */
.contentsOnime .on-flange{
  margin-top: 18px;
  padding: 14px 14px 6px;
}
.contentsOnime .on-flange__box + .on-flange__box{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px dashed #ddd;
}
.contentsOnime .on-flange__ttl{
  font-size: 14px;
  font-weight: bold;
  margin: 0 0 6px;
}
.contentsOnime .on-flange__txt{
  margin: 0 0 10px;
  font-size: 13px;
  line-height: 1.8;
}

/* =========================
   ON-07: install steps (3)
========================= */
.contentsOnime .on-install__grid3{
  display: flex;
  gap: var(--gap);
}

.contentsOnime .on-step{
  flex: 1 1 0;
  padding: 10px 10px 12px;
}

.contentsOnime .on-step__img img{
  width: 100%;
  height: auto;
  display: block;
}

.contentsOnime .on-step__txt{
  margin: 10px 0 0;
  font-size: 13px;
  line-height: 1.8;
}

/* ON-07: install movie */
.contentsOnime .on-install__video{
  margin: 15px auto 0;
  width: 480px; 
}

.contentsOnime .on-install__video iframe{
  display: block;
  width: 100%;
  height: 360px;
  border: 1px solid #b4b4b4;
}

/* ON-07：背景色ブロック内の左右余白を確保 */
.contentsOnime .on-install{
  background: #f7f7f7;
  padding: 40px 16px;
}

/* ON-07：動画小見出し */
.contentsOnime .on-install__video-wrap{
  margin-top: 40px;
  text-align: center;
}

.contentsOnime .on-install__video-ttl{
  margin: 0 0 0px;
  font-size: 15px;
  font-weight: 600;
  color: #333;
  letter-spacing: 0.04em;
}


/* =========================
   ON-08: usage grid (6)
========================= */
.contentsOnime .on-usage__grid6{
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap);
}

.contentsOnime .on-usage__item{
  width: calc((100% - (var(--gap) * 2)) / 3); /* 3列、gap×2 */
}

.contentsOnime .on-usage__item img{
  width: 100%;
  height: auto;
  display: block;
}
/* 主な用途：キャプション */
.contentsOnime .on-usage__cap{
  margin: 8px 6px 10px;
  font-size: 13px;
  line-height: 1.5;
  text-align: center;
  color: #333;
}

/* =========================
   ON-09: history
========================= */
.contentsOnime .on-history__body{
  font-size: 14px;
  line-height: 1.9;
}

.contentsOnime .on-history__body p{
  margin: 0 0 14px;
}
/* ON-09：ブランドヒストリーも背景色＋左右余白 */
.contentsOnime .on-history{
  background: #f7f7f7;
  padding: 40px 16px;
}

/* =========================
   ON-10: factory
   ========================= */

.contentsOnime .on-factory__grid4{
  display: flex;
  gap: 16px;
}

.contentsOnime .on-factory__item{
  width: calc((100% - (16px * 3)) / 4); /* 4列、gap×3 */
  border: 1px solid #ddd;
  background: #fff;
  box-sizing: border-box;
}

.contentsOnime .on-factory__item img{
  width: 100%;
  height: auto;
  display: block;
}

.contentsOnime .on-factory__text{
  margin: 14px 0 0;
  font-size: 14px;
  line-height: 1.9;
}

.contentsOnime .on-factory__cap{
  margin: 8px 8px 12px;
  font-size: 13px;
  line-height: 1.6;
  text-align: center;
  color: #333;
}

.contentsOnime .on-install,
.contentsOnime .on-history{
  border-radius: 8px;
}

/* 最下部：ラインナップ再掲の下に余白 */
.contentsOnime .on-lineup--bottom{
  margin-bottom: 80px;
}

.contentsOnime .on-lineup--bottom__text{
  margin: 14px 0 0;
  font-size: 14px;
  line-height: 1.9;
}

