/* ============================================================
   tools.css — ガジェッター 便利ツールズ
   2カラム（左サイドバー＋右メイン）。CLAUDE.md のデザイン標準に従い
   角丸ゼロ・影なし、区切りは border と背景色の差で表現する。
   ============================================================ */

/* ── 見出しの帯（ヘッダー下のダークグレー。list-page-head と同系統） ── */
.tl-head {
  background: #191c22;
  border-bottom: 1.5px solid #252930;
  padding: 22px 0;
}
.tl-head-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 28px;
  display: flex;
  align-items: baseline;
  gap: 14px;
  flex-wrap: wrap;
}
.tl-head h1 {
  font-size: var(--fs-xl);
  font-weight: 900;
  letter-spacing: -.5px;
  display: flex;
  align-items: center;
  gap: 10px;
  color: #e4e6ed;
  margin: 0;
}
.tl-head h1 .bi { color: var(--accent); }
.tl-head-sub { color: #aeb4c0; font-size: var(--fs-sm); font-weight: 600; }
@media (min-width: 901px) { .tl-head h1 { font-size: var(--fs-2xl); } }

/* ── 2カラムラッパ ── */
.tl-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 24px 28px 90px;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  box-sizing: border-box;
}

/* ── 左サイドバー：ランキングページ（rk-sidebar）と同じデザイン ── */
.tl-side {
  position: sticky;
  top: 76px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
/* ブロック見出し（TAG + タイトル + 横線）＝ ranking の .rk-block-head と同型 */
.tl-block-head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.tl-block-head:not(:first-of-type) { margin-top: 26px; }
.tl-block-tag {
  font-size: var(--fs-xs); font-weight: 900; letter-spacing: .14em;
  color: var(--accent); border: 1.5px solid var(--accent); padding: 3px 8px;
  background: transparent; white-space: nowrap;
}
.tl-block-title { font-size: var(--fs-base); font-weight: 900; letter-spacing: .04em; margin: 0; color: var(--text); white-space: nowrap; }
.tl-block-line { flex: 1; height: 1.5px; background: var(--text); opacity: .85; }

/* リンク（枠線を共有・アクティブ赤）＝ ranking の .rk-side-link と同型 */
.tl-side-link {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--bg2);
  border: 1.5px solid var(--text); border-top: none;
  font-size: var(--fs-sm); font-weight: 700; color: var(--text);
  text-decoration: none; line-height: 1.3;
}
.tl-block-head + .tl-side-link { border-top: 1.5px solid var(--text); } /* 見出し直後の最初の項目に上枠 */
.tl-side-link .bi { font-size: 1.1em; color: var(--text2); flex: 0 0 auto; }
.tl-side-link span { min-width: 0; }
.tl-side-link:hover { background: var(--bg); color: var(--accent); border-color: var(--accent); }
.tl-side-link.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.tl-side-link.on .bi { color: #fff; }
.tl-side-link.is-soon { color: var(--text4); cursor: default; }
.tl-side-link.is-soon .bi { color: var(--text4); }
.tl-side-link.is-soon:hover { background: var(--bg2); color: var(--text4); border-color: var(--text); }

/* ── 右メイン ── */
.tl-intro {
  border: 1.5px solid var(--border2);
  background: var(--bg2);
  padding: 18px 20px;
  margin-bottom: 20px;
}
.tl-intro-title { font-size: var(--fs-lg); font-weight: 900; margin: 0 0 6px; color: var(--text); }
.tl-intro-text { font-size: var(--fs-sm); line-height: 1.8; color: var(--text2); margin: 0; }

.tl-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.tl-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  border: 1.5px solid var(--border2);
  background: var(--bg2);
  padding: 16px;
  text-decoration: none;
  color: inherit;
  transition: border-color .15s, background .15s;
}
a.tl-card:hover { border-color: var(--text); background: var(--bg3); }
.tl-card-ico {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--text);
  background: var(--bg);
  font-size: 1.5rem;
  color: var(--accent);
}
.tl-card-body { min-width: 0; }
.tl-card-title {
  font-size: var(--fs-base);
  font-weight: 800;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.tl-card-desc { font-size: var(--fs-sm); line-height: 1.7; color: var(--text2); margin-top: 5px; }
.tl-card.is-soon { opacity: .75; }
.tl-card.is-soon .tl-card-ico { color: var(--text4); border-color: var(--border2); }

/* カテゴリ（Windowsソフト / ブラウザツール）間の余白 */
.tl-cat + .tl-cat { margin-top: 30px; }
/* ツール独自の画像アイコン（縮小革命など）。bi アイコンと同じ位置に収める。 */
.tl-card-ico .tl-ico-img { width: 32px; height: 32px; object-fit: contain; display: block; }
.tl-side-link .tl-ico-img { width: 1.25em; height: 1.25em; object-fit: contain; flex: 0 0 auto; display: block; }

/* ── モバイル：1カラム。サイドバーは横スクロールの行に変換 ── */
@media (max-width: 900px) {
  .tl-wrap { grid-template-columns: 1fr; gap: 16px; padding: 16px 14px 70px; }
  .tl-side {
    flex-direction: row;
    overflow-x: auto;
    gap: 8px;
    padding-bottom: 6px;
    position: static;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .tl-side::-webkit-scrollbar { display: none; }
  .tl-block-head { display: none; }   /* モバイルは見出しを省略し、項目を横スクロールのチップに */
  .tl-side-link {
    border: 1.5px solid var(--text);
    white-space: nowrap;
    flex: 0 0 auto;
    padding: 9px 12px;
  }
  .tl-block-head + .tl-side-link { border-top: 1.5px solid var(--text); }
  .tl-grid { grid-template-columns: 1fr; }
  .tl-head-inner { padding: 0 14px; }
}

/* ============================================================
   配布ページ（縮小革命など）専用 .dl-*
   ============================================================ */
.dl-hero {
  border: 1.5px solid var(--border2);
  background: var(--bg2);
  padding: 26px;
  margin-bottom: 24px;
}
/* 上段：左＝情報／右＝スクリーンショット */
.dl-hero-top { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.08fr); gap: 26px; align-items: center; }
.dl-hero-info { min-width: 0; }
.dl-title { font-size: var(--fs-2xl); font-weight: 900; letter-spacing: -.5px; margin: 0; color: var(--text); }
.dl-tagline { font-size: var(--fs-base); font-weight: 700; color: var(--accent); margin: 6px 0 12px; }
.dl-hero-shot { margin: 0; padding: 12px; background: var(--bg3); border: 1.5px solid var(--border2); box-sizing: border-box; }
.dl-hero-shot img { display: block; width: 100%; height: auto; border: 1.5px solid var(--border); background: var(--bg); }
.dl-lead { font-size: var(--fs-base); line-height: 1.85; color: var(--text2); margin: 0 0 16px; }
.dl-meta { display: flex; align-items: center; gap: 10px 14px; flex-wrap: wrap; margin: 0; }
/* 下段：全幅のダウンロード行（上に区切り線） */
.dl-hero-actions { margin-top: 22px; padding-top: 22px; border-top: 1px solid var(--border); }
.dl-ver-badge {
  font-size: var(--fs-xs); font-weight: 900; letter-spacing: .04em;
  color: #fff; background: var(--accent); padding: 5px 11px;
}
.dl-meta-date, .dl-meta-free { font-size: var(--fs-xs); font-weight: 700; color: var(--text3); }
.dl-meta-free { color: #15803d; }

.dl-dl-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.dl-btn {
  display: grid; grid-template-columns: auto 1fr; column-gap: 14px; align-items: center;
  border: 1.5px solid var(--accent); background: var(--accent); color: #fff;
  padding: 16px 20px; text-decoration: none;
  transition: background .15s, border-color .15s;
}
.dl-btn:hover { background: var(--accent-dark); border-color: var(--accent-dark); }
.dl-btn .bi { grid-column: 1; grid-row: 1 / 3; font-size: 1.8rem; align-self: center; }
.dl-btn-main { grid-column: 2; grid-row: 1; font-size: var(--fs-base); font-weight: 800; }
.dl-btn-size { grid-column: 2; grid-row: 2; font-size: var(--fs-xs); font-weight: 600; opacity: .9; margin-top: 2px; }
.dl-btn-sub { background: var(--bg2); color: var(--accent); }
.dl-btn-sub:hover { background: var(--bg3); border-color: var(--accent); }
.dl-dl-note { font-size: var(--fs-xs); line-height: 1.7; color: var(--text3); margin: 12px 0 0; }

/* セクション共通 */
.dl-section { margin-bottom: 28px; }
.dl-section-title {
  font-size: var(--fs-lg); font-weight: 900; color: var(--text); margin: 0 0 14px;
  padding-bottom: 8px; border-bottom: 1.5px solid var(--border2);
  display: flex; align-items: center; gap: 9px;
}
.dl-section-title .bi { color: var(--accent); }
.dl-section-lead { font-size: var(--fs-sm); color: var(--text2); line-height: 1.8; margin: 0 0 12px; }

/* 特長グリッド */
.dl-feat { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.dl-feat-item { display: flex; gap: 12px; align-items: flex-start; border: 1.5px solid var(--border2); background: var(--bg2); padding: 14px; }
.dl-feat-ico {
  flex: 0 0 auto; width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--text); background: var(--bg); font-size: 1.3rem; color: var(--accent);
}
.dl-feat-body { min-width: 0; }
.dl-feat-title { font-size: var(--fs-base); font-weight: 800; color: var(--text); }
.dl-feat-desc { font-size: var(--fs-sm); line-height: 1.7; color: var(--text2); margin-top: 4px; }

/* スクリーンショット */
.dl-gallery { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.dl-shot { margin: 0; }
.dl-shot img { width: 100%; height: auto; display: block; border: 1.5px solid var(--border2); background: var(--bg); }
.dl-shot figcaption { font-size: var(--fs-xs); line-height: 1.6; color: var(--text3); margin-top: 6px; }

/* 使い方 */
.dl-steps { margin: 0; padding-left: 1.4em; }
.dl-steps li { font-size: var(--fs-sm); line-height: 1.9; color: var(--text2); margin-bottom: 6px; }
.dl-steps b { color: var(--text); }
.dl-subhead { font-size: var(--fs-base); font-weight: 800; color: var(--text); margin: 18px 0 8px; }
.dl-uses { margin: 0; padding-left: 1.2em; }
.dl-uses li { font-size: var(--fs-sm); line-height: 1.9; color: var(--text2); margin-bottom: 8px; }
.dl-uses b { color: var(--text); }
.dl-tip {
  font-size: var(--fs-sm); line-height: 1.75; color: var(--text2);
  border: 1.5px solid var(--border2); border-left: 5px solid var(--star);
  background: var(--bg2); padding: 12px 14px; margin: 14px 0 0;
}
.dl-tip .bi { color: var(--star); margin-right: 4px; }
.dl-tip b { color: var(--text); }

/* 仕様 */
.dl-spec { margin: 0; border: 1.5px solid var(--border2); }
.dl-spec > div { display: grid; grid-template-columns: 140px minmax(0, 1fr); border-bottom: 1px solid var(--border); }
.dl-spec > div:last-child { border-bottom: none; }
.dl-spec dt { font-size: var(--fs-sm); font-weight: 800; color: var(--text); background: var(--bg3); padding: 12px 14px; }
.dl-spec dd { font-size: var(--fs-sm); line-height: 1.8; color: var(--text2); padding: 12px 14px; margin: 0; }

/* 過去バージョン */
.dl-oldver { margin: 0; padding-left: 1.3em; }
.dl-oldver li { font-size: var(--fs-sm); line-height: 1.9; color: var(--text2); }
.dl-oldver a { color: var(--accent); font-weight: 700; }

/* ライセンス */
.dl-license { border: 1.5px solid var(--border2); background: var(--bg2); padding: 16px 18px; }
.dl-license ul { margin: 0; padding-left: 1.2em; }
.dl-license li { font-size: var(--fs-sm); line-height: 1.85; color: var(--text2); margin-bottom: 6px; }
.dl-license b { color: var(--text); }
.dl-credit { font-size: var(--fs-xs); color: var(--text3); margin: 12px 0 0; }
.dl-credit a { color: var(--accent); font-weight: 700; }

@media (max-width: 900px) {
  .dl-hero { padding: 16px; }
  .dl-hero-top { grid-template-columns: 1fr; gap: 18px; }
  .dl-dl-row { grid-template-columns: 1fr; }
  .dl-feat { grid-template-columns: 1fr; }
  .dl-gallery { grid-template-columns: 1fr; }
  .dl-spec > div { grid-template-columns: 1fr; }
  .dl-spec dt { border-bottom: 1px solid var(--border); }
}

