@charset "UTF-8";

/*!
Theme Name: Simplicity2 child
Template:   simplicity2
Version:    251224-robust-fix-center
*/

/* =========================================================
   基本設定
   ========================================================= */
body {
  font-family: 'Hiragino Kaku Gothic ProN', Meiryo, Helvetica, Arial, sans-serif;
  font-size: 15px;
  -webkit-text-size-adjust: 100%;
}

#breadcrumb {
  display: none;
}

/* 記事本文の行間設定 */
.article {
  margin-bottom: 1.4em;
}

/* =========================================================
   レイアウト
   ========================================================= */
#container {
  padding: 0;
  margin: 0 auto;
}

#header-in, #navi-in, #body-in, #footer-in {
  width: 1070px;
  margin: 30px auto;
  box-sizing: border-box;
  position: relative;
}

/* 本文側の基本余白（PC） */
#body-in {
  padding-top: 30px;
}

/* =========================================================
   本文開始位置（PC）
   fixedヘッダー分だけ下げる
   ========================================================= */
#content,
#content-in,
#main,
#main-content,
#main-in,
#main-inner {
  padding-top: 96px !important; /* 本文とキャッチの縦関係 */
}

/* =========================================================
   ヘッダー
   ========================================================= */
#header {
  margin-bottom: 0;
  position: relative;
  z-index: 1000;
}

#header .alignleft,
#header .alignright {
  margin-bottom: 0;
  max-width: 380px; /* ←拡張：ロゴ＋キャッチ幅拡張に合わせる */
}

/* 固定幅1070pxの左端 */
:root {
  --vit-container-left: calc(50% - 535px); /* コンテンツ左基準 */
  --vit-sidebar-top: 260px;               /* ←Chrome基準のカテゴリ開始位置 */
  --vit-leftcol-width: 340px;             /* ←追加：ロゴ＋キャッチ（＋サイドバー）幅 */

  /* ★修正：スマホ/タブレット縦の左右余白（統一） */
  --vit-pad-mobile: 0px;

  /* ★追加：PCのカテゴリ左だけ微調整したいとき用（±数px） */
  --vit-sidebar-left-offset: 0px;
}

/* ロゴ＋キャッチ */
#header .alignleft {
  position: fixed;
  margin: 0px;
  padding: 0;
  top: 35px;
  left: var(--vit-container-left);
  z-index: 1100;
  width: var(--vit-leftcol-width); /* ←拡張 */
}

.vit-brand {
  width: var(--vit-leftcol-width); /* ←拡張 */
  text-align: left;
}

.site-title-img {
  display: block;
  margin: 0;
}

#site-title {
  margin: 0;
  padding: 0;
}

/* キャッチ：行単位で太字にする */
#site-description .desc-strong {
  font-weight: 600; /* ※修正：700→600（滲み/ギザつきの抑制） */
}

/* キャッチ：語だけ通常に戻す */
#site-description .desc-normal {
  font-weight: 400; /* 通常の太さ */
}

/* キャッチ全体 */
#site-description {
  color: #000; /* ※修正：#777→#000（トップキャッチを黒） */

  /* ★修正：キャッチ左ズレの原因（padding-left:24px）を撤去 */
  padding: 0 0 0 24px; /* ←重要：これでロゴ/カテゴリと左端が揃う */

  /* ★修正：キャッチ上端の位置調整はここ（18px→好みの値へ） */
  margin: 18px 0 0 0;

  line-height: 140%;
  font-size: 14px;
  font-weight: 400; /* ※修正：normal→400（描画の揺れを減らす） */
  position: relative;
  z-index: 1200;

  max-width: var(--vit-leftcol-width); /* ←追加：キャッチ幅 */
  text-wrap: balance;                  /* ←追加：Chrome等で1文字だけの折返しを減らす */

  /* =====================================================
     ※追加：トップキャッチの文字レンダリング安定化
     ===================================================== */
  transform: none !important;
  backface-visibility: visible;
  will-change: auto;
  text-rendering: optimizeLegibility;
}

/* 強調文 */
#site-description .desc-bold {
  font-weight: 700 !important;
}

/* 事務所名 */
#site-description .desc-sub {
  display: block;
  margin-top: 5px;
  font-size: 13px;
  font-weight: 600;
  color: #000; /* ※修正：#666→#000（事務所名も黒） */
  letter-spacing: 0.08em;
  line-height: 1.4;
}

/* 右側 */
#header .alignright {
  height: 52px;
  text-align: right;
  margin-right: 30px;
  right: 0;
  top: 0;
  position: absolute;
  z-index: 1100;
}

#h-top {
  min-height: 0;
  overflow: visible;
  background-repeat: no-repeat;
  background-position: top left;
  position: relative;
  z-index: 1050;
}

/* =========================================================
   本文
   ========================================================= */
#body {
  margin-top: 0;
  position: relative;
  z-index: 1;
}

#main, #sidebar {
  border: none !important;
}

/* =========================================================
   ※追加：一覧（カテゴリ/アーカイブ）での崩れ対策（Chrome優先）
   ========================================================= */
#list {
  display: flow-root;
}

#list .entry,
#list .entry-card,
#list .entry-card-large,
#list .entry-body {
  display: flow-root;
}

#list .entry-thumb {
  max-width: 100%;
}

/* =========================================================
   サイドバー
   ========================================================= */
#sidebar {
  position: fixed;
  margin: 0px;
  padding-top: 10px;
  top: var(--vit-sidebar-top); /* ←カテゴリ開始位置（Chrome基準） */
  left: calc(var(--vit-container-left) + var(--vit-sidebar-left-offset)); /* ★修正：微調整可能に */
  width: var(--vit-leftcol-width); /* ←拡張：キャッチ幅と揃える */
  z-index: 900;
}

#sidebar .widget {
  padding: 0 0 15px 0;
  margin: 0;
}

/* =========================================================
   Firefoxのみ：キャッチが高くなった分だけカテゴリを下げる
   ========================================================= */
@supports (-moz-appearance: none) {
  :root {
    --vit-sidebar-top: 260px; /* ←Firefox用調整値 */
  }
}

/* =========================================================
   メニュー設定
   ========================================================= */
#menu-global_menu,
#menu-global_menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

#menu-global_menu li {
  padding-top: 3px;
  padding-bottom: 3px;
  margin: 0;
  line-height: 18px;
}

#menu-global_menu a {
  display: inline-block;
  text-decoration: none;
  color: #444;
  font-size: 15px;
  font-weight: bold;
}

#menu-global_menu ul.sub-menu {
  margin: 0 !important;
  padding: 0 0 0 18px !important;
  list-style: none !important;
}

#menu-global_menu ul.sub-menu li {
  margin: 0 !important;
  padding: 3px 0 !important;
}

#menu-global_menu ul.sub-menu li a {
  color: #444 !important;
  font-size: 12px !important;
  font-weight: bold !important;
}

#menu-global_menu a:hover,
#menu-global_menu a:active {
  color: #000099;
  border-left: solid 4px #000099;
  padding: 0 1px;
}

/* =========================================================
   互換（旧IE向け）
   ========================================================= */
*:first-child+html #header > div {
  clear: both;
  zoom: 1;
}

#header-image {
  margin: 0 0 20px 0;
}

/* =========================================================
   ※追加：記事末尾ロゴ＋キャッチはデフォルト非表示（PC）
   ========================================================= */
.vit-branding-bottom {
  display: none;
}

/* =========================================================
   ★追加：小さめPC幅 / タブレット横（重なり回避）
   1100px以下は「スマホ同等」に落とす（固定配置を解除）
   ========================================================= */
@media screen and (max-width: 1100px) {

  /* 内枠をフル幅にする */
  #header-in,
  #navi-in,
  #body-in,
  #footer-in {
    width: 100%;
    margin: 0 auto;
    padding-left: var(--vit-pad-mobile);
    padding-right: var(--vit-pad-mobile);
  }

  /* 本文の上余白をリセット */
  #body-in {
    padding-top: 0;
  }

  /* ★修正：alignleft 内の「テーマ側 float / text-align / margin」を丸ごと安定化 */
  #header .alignleft {
    display: block !important;
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
    text-align: center !important;
    left: auto !important;
    top: auto !important;
    float: none !important;
    clear: both !important;
  }

  /* ★修正：.vit-brand だけではなく「中の a / img / p」まで中央寄せを固定 */
  .vit-brand {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: 0 !important;
    text-align: center !important;
    float: none !important;
    clear: both !important;
  }

  #site-title,
  #site-title a {
    display: block !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    text-align: center !important;
    float: none !important;
  }

  .site-title-img {
    display: block !important;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 140px !important;
    max-width: 80% !important;
    height: auto !important;
  }

  /* ★修正：キャッチは「padding-left:24px」が1pxでも残ると左に寄るので完全に殺す */
  #site-description {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    text-align: center !important;
  }

  #site-description .desc-sub {
    text-align: center !important;
  }

  /* カテゴリ（サイドバー）：fixed解除→記事一覧の下へ */
  #sidebar {
    position: static !important;
    margin-top: 20px !important;
    width: auto !important;
    left: auto !important;
    top: auto !important;
    float: none !important;
  }

  /* 念のためメインも下回り事故を防ぐ */
  #main {
    float: none !important;
    width: auto !important;
  }

  /* 本文開始位置を詰める */
  #content,
  #content-in,
  #main,
  #main-content,
  #main-in,
  #main-inner {
    padding-top: 20px !important;
  }
}

/* =========================================================
   レスポンシブ（スマホ）
   ※1100px以下で既に中央化しているため、ここでは「スマホ固有」だけに限定
   ========================================================= */
@media screen and (max-width: 767px) {

  #header-in,
  #navi-in,
  #body-in,
  #footer-in {
    padding-left: var(--vit-pad-mobile) !important;
    padding-right: var(--vit-pad-mobile) !important;
  }

  /* =====================================================
     スマホの個別記事ではヘッダーのロゴ/キャッチを非表示
     ===================================================== */
  .single #header .alignleft {
    display: none !important;
  }

  .single #content,
  .single #content-in,
  .single #main,
  .single #main-content,
  .single #main-in,
  .single #main-inner {
    padding-top: 0 !important;
  }

  /* =====================================================
     記事末尾（カテゴリの上）にロゴ＋キャッチを表示（スマホのみ）
     ===================================================== */
  .vit-branding-bottom {
    display: block !important;
    text-align: center !important;
    margin: 60px auto 12px auto !important;
    padding: 0 12px !important;
  }

  .single .vit-branding-bottom {
    margin: 120px auto 12px auto !important;
  }

  .vit-branding-bottom .site-title-img {
    display: block !important;
    margin: 12px auto 0 auto !important;
    width: 140px !important;
    max-width: 80% !important;
    height: auto !important;
  }

  .vit-branding-bottom .vit-branding-catch {
    margin: 14px 0 0 0 !important;
    font-size: 18px !important;
    line-height: 1.6 !important;
    color: #777 !important;
    white-space: normal !important;
    overflow: visible !important;
    word-break: break-word !important;
    text-wrap: balance;
    text-align: center !important;
  }

  .vit-branding-bottom .desc-sub {
    text-align: center !important;
  }

  /* =========================================================
     ※追加：ABOUT配下だけ内部ブログカードの文字サイズを指定
     ========================================================= */
  .page-id-4045 .blog-card-title a,
  .parent-pageid-4045 .blog-card-title a {
    font-size: 16px !important;
    line-height: 1.6 !important;
  }

  .page-id-4045 .blog-card-excerpt,
  .parent-pageid-4045 .blog-card-excerpt {
    font-size: 16px !important;
    line-height: 1.8 !important;
  }

} /* スマホ @media 終了 */

/* =========================================================
   ※追加：レスポンシブ（タブレット縦）
   ★重要：ここは「配置ルールを増やさない」ため、余白だけに限定（中央化は1100px側で統一）
   ========================================================= */
@media screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {

  #header-in,
  #navi-in,
  #body-in,
  #footer-in {
    padding-left: var(--vit-pad-mobile) !important;
    padding-right: var(--vit-pad-mobile) !important;
  }
}

/* =========================================================
   一覧ページでは投稿日を表示しない
   HOME / カテゴリ / アーカイブ / 検索結果
   ========================================================= */
body:is(.home, .archive, .search) #list :is(
  .post-meta,
  p.post-meta,
  .entry-meta,
  .post-date,
  .entry-date,
  .date,
  time,
  .fa-clock-o,
  .fa-calendar,
  .fa-calendar-o,
  .fa-history
) {
  display: none !important;
}

body:is(.home, .archive, .search) :is(
  .post-meta,
  p.post-meta,
  .entry-meta,
  .post-date,
  .entry-date,
  .date,
  time
) {
  display: none !important;
}

/* =========================================================
   ※修正：ABOUT関連だけ内部ブログカードの枠線を消す
   ========================================================= */
.page-id-4045 .blog-card.internal-blog-card,
.parent-pageid-4045 .blog-card.internal-blog-card {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}

.page-id-4045 .blog-card.internal-blog-card .blog-card-thumbnail,
.page-id-4045 .blog-card.internal-blog-card .blog-card-content,
.page-id-4045 .blog-card.internal-blog-card .blog-card-footer,
.parent-pageid-4045 .blog-card.internal-blog-card .blog-card-thumbnail,
.parent-pageid-4045 .blog-card.internal-blog-card .blog-card-content,
.parent-pageid-4045 .blog-card.internal-blog-card .blog-card-footer {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
  background: transparent !important;
}

.page-id-4045 .blog-card.internal-blog-card::before,
.page-id-4045 .blog-card.internal-blog-card::after,
.page-id-4045 .blog-card.internal-blog-card .blog-card-content::before,
.page-id-4045 .blog-card.internal-blog-card .blog-card-content::after,
.parent-pageid-4045 .blog-card.internal-blog-card::before,
.parent-pageid-4045 .blog-card.internal-blog-card::after,
.parent-pageid-4045 .blog-card.internal-blog-card .blog-card-content::before,
.parent-pageid-4045 .blog-card.internal-blog-card .blog-card-content::after {
  border: none !important;
  box-shadow: none !important;
}

.page-id-4045 .blog-card.internal-blog-card,
.parent-pageid-4045 .blog-card.internal-blog-card {
  border-radius: 0 !important;
}

/* =========================================================
   ABOUT配下：PC文字サイズ設定
   ========================================================= */
.page-id-4045 .blog-card-title a,
.parent-pageid-4045 .blog-card-title a {
  font-size: 18px !important;
  line-height: 1.6 !important;
}

.page-id-4045 .blog-card-excerpt,
.parent-pageid-4045 .blog-card-excerpt {
  font-size: 16px !important;
  line-height: 1.8 !important;
}

/* =========================================================
   ★追加：スマホの文字サイズが14pxに落ちる/表の中でさらに小さくなる対策
   （既存の #site-description 18px を確実に維持）
   ========================================================= */

/* スマホ時：本文テキストの基準を維持（テーマ側の上書きを打ち消す） */
@media screen and (max-width: 767px) {
  html, body {
    -webkit-text-size-adjust: 100% !important;
    text-size-adjust: 100% !important;
  }

  /* キャッチが14pxに落ちる場合の保険（#site-description が別ルールに負けるケース潰し） */
  #site-description {
    font-size: 18px !important;
  }

  /* テーブル内だけ小さくなる問題を止める（テーマの table {font-size:xx;} を無効化） */
  #main table,
  #main table th,
  #main table td,
  .article table,
  .article table th,
  .article table td,
  .entry-content table,
  .entry-content table th,
  .entry-content table td {
    font-size: inherit !important;
  }
}
