@charset "utf-8";
/* ============================================================
   株式会社キャリアバランス コーポレートサイト クリーンCSS（cb-site.css）
   方針: BiND(bind.css/cssskin/css_list)を排し、現デザインの根幹を忠実再現。
   基調: 濃灰 #333 ＋ 白文字 ＋ 差し色 #728ff0 ＋ 補助灰 #777b80。
   ヘッダ/フッタは全幅、本文は約960px。意味不明なCMS文字列なし。h1/h2/h3 正常化。
   ============================================================ */
:root{
  --bg:#333333; --ink:#ffffff; --accent:#728ff0; --accent-deep:#5b78dc;
  --muted:#9aa0a8; --muted-dark:#777b80; --panel:#f1f1f1;
  --link:#9fb4f5;                  /* 暗地で読みやすい明るめの青（文書内リンク用） */
  --line:rgba(255,255,255,.18);
  --content:1120px;                /* 表・カードも窮屈に見えないHP本文幅 */
  --read:840px;                    /* 長文本文の読みやすい最大幅 */
  --pad:clamp(18px,3.4vw,48px);    /* PCは画面を広く使い、スマホは本文幅を確保 */
  --t:.2s ease;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg) url(_dress/pp023c/images/bg_body_c.png) center top/contain repeat;
  color:var(--ink);
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic UI",Meiryo,system-ui,sans-serif;
  font-size:16px;line-height:1.9;letter-spacing:.012em;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
iframe{max-width:100%}
a{color:var(--ink);text-decoration:none;transition:color var(--t)}
a:hover{color:var(--accent)}

/* 全幅バー（ヘッダ/フッタ/ビルボード）。左右余白のみ、最大幅なし＝現行の全幅に合わせる */
.cb-bar{width:100%;padding-inline:var(--pad)}
/* 本文コンテナ（中央・約960px） */
.cb-wrap{max-width:var(--content);margin-inline:auto;padding-inline:var(--pad);width:100%}

/* ---- ヘッダ（上部4px青ライン・白ロゴ・横ナビ・全幅） ---- */
.cb-header{background:var(--bg);border-top:4px solid var(--accent);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.cb-header .cb-bar{display:flex;align-items:center;gap:1.2em;min-height:84px}
.cb-logo{margin-right:auto;display:inline-flex;align-items:center}
.cb-logo img{height:48px;width:auto}
.cb-nav{display:flex;gap:0}
.cb-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:88px;padding:.4em .7em;line-height:1.35;border-left:1px solid var(--line);
  font-size:13px;font-weight:700;color:var(--ink)}
.cb-nav a:last-child{border-right:1px solid var(--line)}
.cb-nav a .en{font-size:10px;font-weight:400;letter-spacing:.12em;color:var(--muted-dark)}
.cb-nav a:hover{color:var(--accent)}
.cb-nav a[aria-current="page"]{color:var(--accent)}
.cb-navtoggle{display:none}

/* ---- ビルボード（全幅・白文字・中央タイトル・キッカー） ---- */
.cb-billboard{position:relative;min-height:320px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding-block:clamp(32px,6vw,64px);
  border-bottom:1px solid var(--line);text-shadow:1px 1px 12px rgba(0,0,0,.5);
  background-position:center;background-size:cover;background-repeat:no-repeat}
/* 背景画像に負けないよう暗幕を敷き、白文字の可読性を確保 */
.cb-billboard::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.42);pointer-events:none}
.cb-billboard .cb-bar{position:relative;z-index:1}
.cb-kicker{font-size:12px;font-weight:700;letter-spacing:.22em;color:var(--accent);
  text-transform:uppercase;margin-bottom:.9em}
.cb-billboard h1{font-size:clamp(22px,4.4vw,32px);font-weight:700;letter-spacing:.04em;
  line-height:1.5;margin:0}

/* ---- パンくず（全幅） ---- */
.cb-breadcrumb{font-size:12px;color:var(--muted);padding-block:.9em;border-bottom:1px solid var(--line)}
.cb-breadcrumb a{color:var(--muted)}.cb-breadcrumb a:hover{color:var(--accent)}
.cb-breadcrumb .sep{margin:0 .5em;opacity:.6}

/* ---- 本文 ---- */
main{display:block}
.cb-article{padding-block:clamp(36px,6vw,60px)}
.cb-lead{font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--accent);
  text-align:center;text-transform:uppercase;margin:0 0 .4em}
.cb-article h2{font-size:clamp(23px,2.8vw,27px);font-weight:700;letter-spacing:.02em;line-height:1.55;
  text-align:center;margin:0}
.cb-rule{width:50px;height:0;border:none;border-top:2px solid var(--accent);margin:14px auto 30px}
.cb-article h3{font-size:18.5px;font-weight:700;color:var(--ink);line-height:1.65;
  position:relative;text-align:center;margin:2em 0 1em;padding:0 0 .5em}
.cb-article h3::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:34px;height:2px;background:var(--accent)}
.cb-article p{font-size:16px;line-height:2;margin:0 0 1.35em}
.cb-article a{color:var(--accent)}
.cb-article a:hover{color:var(--accent-deep);text-decoration:underline}
.cb-article ul{margin:1em 0 1.5em;padding-left:1.4em}
.cb-article li{font-size:15.5px;line-height:1.95;margin:.35em 0}
.cb-article strong{font-weight:700}
.cb-source{font-size:13px;color:var(--muted)}
.cb-source a{color:var(--accent);font-weight:700;white-space:nowrap}
.cb-faq p{margin:0 0 1.1em}.cb-faq strong{color:#cdd6ff}
.cb-article > p:not(.cb-lead):not(.cb-dateline),
.cb-article > ul,
.cb-article > ol{max-width:var(--read);margin-left:auto;margin-right:auto}

/* ---- コラム本文内：メタ情報 / 目次 / 関連記事 ---- */
.cb-article-meta{display:flex;flex-wrap:wrap;justify-content:center;gap:.55em .7em;
  margin:-10px auto 1.8em;max-width:760px}
.cb-meta-pill{display:inline-flex;align-items:center;border:1px solid var(--line);
  background:rgba(255,255,255,.045);color:var(--muted);font-size:11.5px;line-height:1.5;
  border-radius:999px;padding:.28em .75em}
.cb-meta-pill strong{color:var(--link);font-weight:700}
.cb-article-index{max-width:760px;margin:1.7em auto 2em;padding:1.1em 1.25em;
  background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:10px;text-align:left}
.cb-index-title{font-size:13.5px;font-weight:700;color:var(--ink);margin:0 0 .55em}
.cb-index-title::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--accent);margin-right:.65em;vertical-align:.08em}
.cb-article-index ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.3em 1em}
.cb-article-index li{margin:0;line-height:1.7}
.cb-article-index a{display:block;color:var(--link);font-size:13px;padding:.2em 0}
.cb-article-index a::before{content:"\203A";margin-right:.45em;color:var(--accent);font-weight:700}
.cb-related{margin:2.5em auto 0;max-width:860px;text-align:left}
.cb-related-head{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--link);margin:0 0 .35em}
.cb-related-title{font-size:17px;font-weight:700;line-height:1.6;margin:0 0 .9em;color:var(--ink)}
.cb-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.cb-related-card{display:block;min-height:100%;padding:1em 1.05em;border:1px solid var(--line);
  background:rgba(255,255,255,.035);border-radius:9px;color:var(--ink);text-decoration:none;
  transition:border-color var(--t),background var(--t),transform var(--t)}
.cb-related-card:hover{border-color:var(--accent);background:rgba(114,143,240,.09);
  transform:translateY(-2px);text-decoration:none}
.cb-related-card span{display:block;font-size:11.5px;color:var(--muted);margin-bottom:.45em}
.cb-related-card strong{display:block;font-size:14px;line-height:1.65;color:var(--ink)}
@media(max-width:760px){
  .cb-article-index ul,.cb-related-grid{grid-template-columns:1fr}
}
.cb-column-shell{max-width:1480px;display:grid;grid-template-columns:minmax(0,920px) minmax(340px,360px);
  gap:clamp(68px,5.6vw,96px);align-items:start;justify-content:end;
  padding-inline:clamp(18px,2.2vw,32px);padding-block:clamp(36px,6vw,60px)}
.cb-column-shell .cb-article{padding-block:0}
.cb-column{max-width:920px}
.cb-column h2{font-size:clamp(24px,3.2vw,30px)}
.cb-column h3{font-size:20px;margin-top:2.2em}
.cb-column p{font-size:17px;line-height:2.05}
.cb-column li{font-size:16.2px;line-height:2}
.cb-column .cb-def{font-size:16.5px}
.cb-column .cb-source{font-size:13.2px;line-height:1.9}
.cb-column .cb-faq p{font-size:16px}
.cb-column .cb-table{font-size:15.5px}
.cb-eyecatch{margin:1.9em auto 2em;max-width:860px;border:1px solid var(--line);
  border-radius:12px;overflow:hidden;background:rgba(255,255,255,.04);
  box-shadow:0 14px 34px rgba(0,0,0,.22)}
.cb-eyecatch img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.cb-inline-photo{margin:2.2em auto;border:1px solid var(--line);border-radius:12px;
  overflow:hidden;background:rgba(255,255,255,.04);box-shadow:0 12px 28px rgba(0,0,0,.18)}
.cb-inline-photo img{width:100%;aspect-ratio:16/9;object-fit:cover}
.cb-inline-photo figcaption{font-size:12.5px;line-height:1.7;color:var(--muted);
  padding:.75em 1em;text-align:left}
.cb-column-side{position:sticky;top:112px;align-self:start;width:100%;min-width:0}
.cb-sidebox{border-top:2px solid rgba(255,255,255,.32);padding-top:1.1em;margin:0 0 2em;text-align:left}
.cb-sidebox-plain{border-color:rgba(255,255,255,.18)}
.cb-side-kicker{font-size:11px!important;line-height:1.4!important;letter-spacing:.12em;
  font-weight:700;color:var(--link);margin:0 0 .35em!important;text-transform:uppercase}
.cb-side-heading{font-size:16px!important;line-height:1.55!important;text-align:left!important;
  margin:0 0 .9em!important;padding:0!important;color:var(--ink)}
.cb-side-heading::after{display:none!important}
.cb-side-list{display:grid;gap:14px}
.cb-side-card{display:grid;grid-template-columns:96px 1fr;gap:13px;align-items:start;
  padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.12);color:var(--ink);
  text-decoration:none}
.cb-side-card:hover{text-decoration:none}
.cb-side-card img{width:96px;height:68px;object-fit:cover;border-radius:6px;border:1px solid rgba(255,255,255,.14)}
.cb-side-card em{display:block;font-style:normal;font-size:11px;line-height:1.4;color:var(--muted);
  margin-bottom:.25em}
.cb-side-card strong{display:block;font-size:13.2px;line-height:1.58;color:var(--ink);font-weight:700}
.cb-side-card:hover strong{color:var(--link)}
.cb-side-links{list-style:none;margin:.2em 0 0!important;padding:0!important}
.cb-side-links li{margin:0!important;line-height:1.6!important;border-bottom:1px solid rgba(255,255,255,.1)}
.cb-side-links a{display:block;padding:.68em 0;color:var(--ink);font-size:12.5px;text-decoration:none}
.cb-side-links a::before{content:"\203A";margin-right:.45em;color:var(--accent);font-weight:700}
.cb-side-links a:hover{color:var(--link);text-decoration:none}
.cb-provider-card{margin:2.8em 0 2.2em;padding:1.45em 1.55em;border:1px solid rgba(114,143,240,.38);
  border-radius:12px;background:linear-gradient(135deg,rgba(114,143,240,.11),rgba(255,255,255,.04));text-align:left}
.cb-provider-kicker{font-size:11.5px!important;line-height:1.5!important;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--link);margin:0 0 .45em!important}
.cb-provider-title{font-size:18px!important;line-height:1.55!important;font-weight:700;color:var(--ink);margin:0 0 .65em!important}
.cb-provider-card p{font-size:15.5px;line-height:1.95;max-width:none}
.cb-provider-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35em 1.1em;
  margin:.9em 0 1.1em!important;padding-left:1.2em!important}
.cb-provider-list li{font-size:14.5px!important;line-height:1.75!important;margin:0!important}
.cb-provider-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:1.1em}
@media(max-width:560px){
  .cb-column p{font-size:16px;line-height:2}
  .cb-column li{font-size:15.5px}
  .cb-column h3{font-size:18px}
  .cb-eyecatch{margin:1.45em auto 1.7em;border-radius:9px}
  .cb-provider-list{grid-template-columns:1fr}
  .cb-column .cb-table,.cb-column .cb-table tbody,.cb-column .cb-table tr,
  .cb-column .cb-table th,.cb-column .cb-table td{display:block;width:100%}
  .cb-column .cb-table tr{border-bottom:1px solid var(--line)}
  .cb-column .cb-table tr:last-child{border-bottom:none}
  .cb-column .cb-table th{white-space:normal;border-right:none;border-bottom:1px solid rgba(255,255,255,.08);
    padding:.9em 1em .45em}
  .cb-column .cb-table td{padding:.55em 1em 1em}
}
@media(max-width:1060px){
  .cb-column-shell{display:block;max-width:920px}
  .cb-column-side{position:static;margin-top:2.6em}
  .cb-side-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px}
}
@media(max-width:640px){
  .cb-side-list{grid-template-columns:1fr}
}
@media(max-width:640px){
  .cb-provider-actions{display:grid;grid-template-columns:1fr}
  .cb-provider-actions .cb-btn{justify-content:center}
}

/* ---- コラム本文内：関連サービス / 問い合わせ導線 ---- */
.cb-article-cta{margin:2.4em auto 2.8em;padding:1.35em 1.5em 1.5em;
  border:1px solid rgba(114,143,240,.38);border-left:4px solid var(--accent);
  background:linear-gradient(135deg,rgba(114,143,240,.13),rgba(255,255,255,.045));
  border-radius:10px;text-align:left;box-shadow:0 12px 30px rgba(0,0,0,.18)}
.cb-article-cta .cb-cta-kicker{font-size:11.5px;font-weight:700;letter-spacing:.12em;
  color:var(--link);margin:0 0 .45em;text-transform:uppercase}
.cb-article-cta .cb-cta-title{font-size:17px;line-height:1.55;font-weight:700;
  color:var(--ink);margin:0 0 .6em;text-wrap:balance;word-break:auto-phrase}
.cb-article-cta .cb-cta-text{font-size:14px;line-height:1.9;color:var(--muted);
  margin:0 0 1.15em;text-wrap:pretty;word-break:auto-phrase}
.cb-cta-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.cb-article .cb-cta-actions a{text-decoration:none}
.cb-article .cb-btn{color:#fff;text-decoration:none}
.cb-article .cb-btn:hover{color:var(--accent);text-decoration:none}
.cb-btn-secondary{background:transparent;color:var(--link);border-color:rgba(255,255,255,.35)}
.cb-article .cb-btn-secondary{color:var(--link)}
.cb-btn-secondary:hover{background:rgba(255,255,255,.08);color:#fff;border-color:var(--accent)}
@media(max-width:560px){
  .cb-article-cta{padding:1.15em 1.1em 1.25em;border-radius:8px}
  .cb-cta-actions{display:grid;grid-template-columns:1fr}
  .cb-cta-actions .cb-btn{justify-content:center;width:100%;padding-inline:1.2em}
}

/* ---- ボタン ---- */
.cb-btn{display:inline-flex;align-items:center;gap:.5em;background:var(--accent);color:#fff;
  font-weight:700;font-size:14px;letter-spacing:.04em;padding:.85em 2em;border:1px solid var(--accent);
  transition:background var(--t),color var(--t)}
.cb-btn::before{content:"\203A";font-weight:700}
.cb-btn:hover{background:#fff;color:var(--accent)}
.cb-article .cb-btn-secondary{background:transparent;color:var(--link);border-color:rgba(255,255,255,.35)}
.cb-article .cb-btn-secondary:hover{background:rgba(255,255,255,.08);color:#fff;border-color:var(--accent)}

/* ---- 問い合わせ誘導 ---- */
.cb-contact{border-top:1px solid var(--line);padding-block:clamp(36px,6vw,56px);text-align:center}
.cb-contact .note{font-size:13px;color:var(--muted);line-height:1.9;max-width:42em;margin:1.2em auto 1.8em;text-align:left}
.cb-contact .fine{font-size:11.5px;color:var(--muted-dark);max-width:48em;margin-inline:auto;text-align:left}

/* ---- フッタ（全幅・濃灰・リンク列・クレジットロゴ） ---- */
.cb-footer{background:var(--bg);border-top:1px solid var(--line);padding-block:clamp(32px,5vw,52px) 1.4em}
.cb-foot-logo img{height:44px;width:auto;margin-bottom:22px}
.cb-foot-rule{border:none;border-top:1px solid rgba(241,241,241,.5);margin:34px 0 16px}
.cb-foot-grid{display:grid;grid-template-columns:1.05fr 1.5fr 1.25fr;gap:26px 48px;text-align:left;align-items:start}
.cb-foot-grid > div{min-width:0}
.cb-foot-nav-heading{font-size:15px;font-weight:700;letter-spacing:.04em;margin:0 0 .9em;color:var(--ink)}
.cb-foot-grid ul{list-style:none;margin:0;padding:0}
.cb-foot-grid li{margin:.3em 0;line-height:1.65}
.cb-foot-grid a{font-size:12px;color:var(--muted-dark)}
.cb-foot-grid a:hover{color:var(--accent)}
/* 1列タイトル除いて最大4行：超える分は2列に折り返す */
.cb-foot-cols{columns:2;column-gap:34px}
.cb-foot-cols li{break-inside:avoid}
.cb-foot-brand{max-width:30em}
.cb-foot-brandlogo{height:38px;width:auto;margin:0 0 14px;display:block}
.cb-foot-desc{font-size:12.5px;line-height:1.85;color:var(--muted-dark);margin:0 0 1em}
.cb-foot-addr{font-size:12px;line-height:1.7;color:var(--muted-dark);margin:0}
.cb-foot-credit{text-align:center;margin-top:18px}
.cb-foot-credit img{max-width:180px;height:auto;margin:0 auto 14px;display:inline-block}
.cb-copy{font-size:11.5px;color:var(--muted-dark);text-align:center}
.cb-foot-credit a{color:var(--muted);text-decoration:none}
.cb-foot-credit a:hover{color:var(--accent)}
.cb-foot-sep{margin:0 .7em;opacity:.45}
.cb-pagetop{text-align:right;margin-top:.6em}
.cb-pagetop a{font-size:12px;color:var(--muted)}

/* ---- レスポンシブ ---- */
@media (max-width:768px){
  .cb-header .cb-bar{flex-wrap:wrap;min-height:60px;gap:.5em}
  .cb-nav{order:3;width:100%;flex-wrap:wrap;display:none}
  .cb-nav.open{display:flex}
  .cb-nav a{width:50%;min-width:0;border:1px solid var(--line);border-top:none}
  .cb-navtoggle{display:inline-flex;align-items:center;justify-content:center;margin-left:auto;
    background:none;border:1px solid var(--line);color:#fff;font-size:12px;padding:.55em .9em;cursor:pointer;letter-spacing:.1em}
  .cb-foot-grid{grid-template-columns:1fr 1fr;gap:22px 40px}
  .cb-foot-brand{grid-column:1 / -1;max-width:none;margin-bottom:6px}
}
@media (max-width:480px){:root{--pad:18px}.cb-foot-grid{grid-template-columns:1fr}.cb-foot-cols{columns:1}}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}

/* ============================================================
   コーポレート系の文書/一覧レイアウト（.cb-doc）
   課題ページ用 .cb-article（中央寄せの編集体裁）に対し、
   会社概要/サービス/実績/メディア/専門家 等は左揃え＋表＋カード前提。
   .cb-article に後置で重ねて上書きする。
   ============================================================ */
.cb-doc h2{text-align:center;font-size:clamp(23px,2.6vw,27px);line-height:1.55;letter-spacing:.02em;margin:2em 0 0}
.cb-doc > h2:first-child,.cb-doc > *:first-child > h2{margin-top:0}
.cb-doc .cb-lead{text-align:center}
/* プライバシーポリシー等の文書系：条項見出しは左寄せ・下罫（中央寄せにしない） */
.cb-policy h2{text-align:left;font-size:17px;line-height:1.6;margin:2.2em 0 .7em;
  padding-bottom:.45em;border-bottom:1px solid var(--line)}
.cb-policy p,.cb-policy ul{text-align:left}
/* ナレッジ記事リンク一覧 */
.cb-knowledge-list{list-style:none;margin:1.1em auto 0;padding:0;max-width:42em;text-align:left}
.cb-knowledge-list li{margin:0;border-bottom:1px solid var(--line)}
.cb-knowledge-list a{display:block;padding:.95em .2em;color:var(--link);font-size:15.5px;font-weight:700;text-decoration:none;transition:color var(--t),padding-left var(--t)}
.cb-knowledge-list a::before{content:"\203A";color:var(--accent);font-weight:700;margin-right:.6em}
.cb-knowledge-list a:hover{color:#fff;padding-left:.6em}
.cb-doc a:link,.cb-doc a:visited{color:var(--link)}   /* 文書内リンクは明るい青で可読性UP（詳細度0,2,1で.cb-article aに勝つ） */
.cb-doc a:hover{color:#fff;text-decoration:underline}

/* ===== コラム / ナレッジ カードグリッド ===== */
.cb-cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:1.3em 0 2.6em;text-align:left}
@media(max-width:860px){.cb-cardgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cb-cardgrid{grid-template-columns:1fr}}
.cb-card{display:flex;flex-direction:column;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:transform var(--t),border-color var(--t),box-shadow var(--t)}
a.cb-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 10px 26px rgba(0,0,0,.32);text-decoration:none}
.cb-card-thumb{aspect-ratio:16/9;background-size:cover;background-position:center;display:flex;align-items:flex-end;padding:12px}
.cb-card-cat{font-size:11.5px;font-weight:700;letter-spacing:.05em;color:#fff;background:rgba(0,0,0,.36);padding:.28em .72em;border-radius:5px}
.cb-card-body{display:flex;flex-direction:column;gap:.55em;padding:15px 17px 18px;flex:1}
.cb-card-title{font-size:16px;font-weight:700;line-height:1.58;color:var(--ink);margin:0}
a.cb-card:hover .cb-card-title{color:var(--accent)}
.cb-card-desc{font-size:13.5px;line-height:1.82;color:var(--muted);flex:1;margin:0}
.cb-card-more{font-size:12.5px;font-weight:700;color:var(--link)}
a.cb-card:hover .cb-card-more{color:#fff}
.cb-card.is-soon{opacity:.72;cursor:default}
.cb-card.is-soon .cb-card-thumb{filter:grayscale(.4)}
.cb-card .cb-soon-badge{font-size:11px;font-weight:700;letter-spacing:.06em;color:#fff;background:rgba(0,0,0,.36);padding:.28em .72em;border-radius:5px}
.cb-topicnav{display:flex;flex-wrap:wrap;justify-content:center;gap:9px 10px;margin:1.2em auto 2em;max-width:820px}
.cb-topicnav a{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;
  padding:.42em .9em;font-size:12.5px;color:var(--link);background:rgba(255,255,255,.035);text-decoration:none}
.cb-topicnav a::before{content:"#";color:var(--accent);font-weight:700;margin-right:.25em}
.cb-topicnav a:hover{border-color:var(--accent);background:rgba(114,143,240,.08);color:#fff;text-decoration:none}

/* ===== AIO/LLMO: 結論先出し(TL;DR)ブロック・最終更新表示 ===== */
.cb-tldr{text-align:left;background:rgba(114,143,240,.08);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;padding:1em 1.3em;margin:0 0 1.65em;font-size:15.8px;line-height:2}
.cb-tldr strong{color:var(--accent)}
.cb-doc .cb-tldr,.cb-article .cb-tldr{max-width:760px;margin-left:auto;margin-right:auto}
.cb-def{text-align:left;font-size:15.2px;line-height:2;margin:.2em 0 1.45em;padding-left:1em;border-left:2px solid var(--line)}
.cb-def strong{color:var(--ink)}
.cb-dateline{font-size:12px;color:var(--muted-dark);margin:2.4em 0 0;text-align:right}

/* 日本語改行最適化（HP：見出し=balance / 本文=pretty / 文節改行 auto-phrase） */
.cb-billboard h1,.cb-doc h2,.cb-doc h3,.cb-article h2,.cb-article h3,.cb-card-title,.cb-service-body h2,.cb-related-title,.cb-related-card strong{text-wrap:balance}
.cb-doc p,.cb-article p,.cb-lead,.cb-tldr,.cb-def,.cb-card-desc,.cb-article-index a{text-wrap:pretty}
.cb-billboard h1,.cb-doc h2,.cb-doc h3,.cb-article h2,.cb-article h3,.cb-lead,.cb-tldr,.cb-def,.cb-card-title,.cb-index-title,.cb-related-title,.cb-related-card strong{word-break:auto-phrase}

/* ---- 表（cb-table / cb-history-table 共通・ハイラインの清潔な表） ---- */
.cb-table,.cb-history-table{width:100%;border-collapse:collapse;margin:.6em 0 2.1em;
  font-size:15px;border:1px solid var(--line)}
.cb-table th,.cb-history-table th{text-align:left;vertical-align:top;
  background:rgba(255,255,255,.05);color:var(--ink);font-weight:700;
  padding:.85em 1em;border:1px solid var(--line);line-height:1.65}
.cb-table td,.cb-history-table td{vertical-align:top;color:var(--ink-soft);
  padding:.9em 1.05em;border:1px solid var(--line);line-height:1.9}
/* 行見出し型テーブル（experts等）の左列を全表で同一幅に・「1級キャリアコンサルティング技能士」が改行なしで収まる */
.cb-table tbody th{width:272px;white-space:nowrap}
@media(max-width:560px){.cb-table tbody th{width:auto;white-space:normal}}
.cb-history-table th{width:30%;min-width:11em}
.cb-history-table td ul{margin:0;padding-left:1.2em}
.cb-history-table td li{margin:.4em 0}
.cb-table td a,.cb-history-table td a{color:var(--link)}
.cb-experts .cb-table{max-width:var(--read);margin-left:auto;margin-right:auto}
@media(max-width:680px){
  .cb-history-table,.cb-history-table tbody,.cb-history-table tr,
  .cb-history-table th,.cb-history-table td{display:block;width:100%}
  .cb-history-table th{min-width:0;border-bottom:none}
}
.cb-founder-figure{max-width:720px;margin:0 auto 1.6em}
.cb-founder-figure img{width:100%;aspect-ratio:16/9;object-fit:cover;
  object-position:center;border:1px solid var(--line);display:block}
.cb-founder-figure figcaption{font-size:12.5px;line-height:1.7;color:var(--muted);
  text-align:center;margin-top:.65em}

/* ---- サービス一覧：画像左・本文右のカード（画像の特大化を抑止） ---- */
.cb-doc.cb-article[id^="service"]{padding-block:clamp(26px,4vw,40px);
  border-bottom:1px solid var(--line)}
.cb-service-row{display:grid;grid-template-columns:280px 1fr;gap:26px;align-items:start}
.cb-service-img img{width:100%;height:185px;object-fit:cover;
  border:1px solid var(--line);display:block}
.cb-service-body h2{text-align:left;margin-top:0;margin-bottom:.55em}
.cb-service-body p{margin:0;font-size:15px;line-height:2;max-width:none}
.cb-service-detail{margin-top:1.4em}
.c-enclosure{background:rgba(255,255,255,.04);border:1px solid var(--line);
  border-left:4px solid var(--accent);padding:1.05em 1.25em;font-size:14.2px;
  line-height:1.95;color:var(--ink-soft);margin:0}
.cb-service-detail a{color:var(--link)}
@media(max-width:680px){
  .cb-service-row{grid-template-columns:1fr;gap:14px}
  .cb-service-img img{height:200px}
}

/* ---- 文書内の汎用リスト（実績ジャンプnav・参考リンク等） ---- */
.cb-doc nav ul,.cb-doc > ul{margin:.6em 0 1.6em;padding-left:1.2em}
.cb-doc li{margin:.35em 0;line-height:1.7}

/* ---- 目次ナビ（サービス一覧の冒頭TOC等）＝現行に倣い中央寄せ・インライン折返し ---- */
.cb-toc{padding-block:clamp(24px,4vw,44px)}
.cb-toc ul{list-style:none;margin:0 auto;padding:0;max-width:1040px;
  display:flex;flex-wrap:wrap;justify-content:center;column-gap:0;row-gap:.7em}
.cb-toc li{margin:0;display:inline-flex;align-items:center}
.cb-toc li:not(:last-child)::after{content:"｜";color:var(--muted-dark);opacity:.55;margin:0 1em}
.cb-toc a{color:var(--link);font-size:14px;line-height:1.75;text-decoration:none}
.cb-toc a:hover{color:#fff;text-decoration:underline}

/* ---- サイト調の問い合わせフォーム（送信先=Googleフォーム） ---- */
.cb-form{max-width:600px;margin:1.6em auto 0;text-align:left}
.cb-form .row{margin-bottom:1.25em}
.cb-form label{display:block;font-size:13.5px;font-weight:700;margin-bottom:.5em;color:var(--ink)}
.cb-form label .req{display:inline-block;font-size:11px;font-weight:700;color:#ffb4b4;
  border:1px solid rgba(255,180,180,.5);border-radius:3px;padding:.05em .5em;margin-left:.6em;vertical-align:1px}
.cb-form label .hint{font-weight:400;font-size:12px;color:var(--muted);margin-left:.6em}
.cb-form input,.cb-form textarea{width:100%;background:rgba(255,255,255,.06);
  border:1px solid var(--line);color:var(--ink);font-family:inherit;font-size:15px;line-height:1.6;
  padding:.72em .9em;border-radius:4px;transition:border-color var(--t),background var(--t)}
.cb-form input::placeholder,.cb-form textarea::placeholder{color:var(--muted-dark)}
.cb-form input:focus,.cb-form textarea:focus{outline:none;border-color:var(--accent);
  background:rgba(255,255,255,.10)}
.cb-form textarea{min-height:150px;resize:vertical}
.cb-form .cb-btn{border:none;cursor:pointer;font-family:inherit;margin-top:.4em}
.cb-form .cb-btn::before{content:none}
.cb-form-done{display:none;background:rgba(114,143,240,.12);border:1px solid var(--accent);
  border-radius:6px;padding:1.5em 1.7em;color:var(--ink);line-height:1.95;max-width:600px;margin:1.4em auto 0;text-align:left}
.cb-form-done.show{display:block}
.cb-form-done strong{color:var(--accent)}
/* よくあるご相談などのチェックリスト（青チェック＋区切り罫） */
.cb-checklist{list-style:none;margin:.9em auto 0;padding:0;max-width:30em;text-align:left;display:inline-block}
.cb-checklist li{position:relative;margin:0;padding:.62em 0 .62em 1.9em;
  border-bottom:1px solid var(--line);font-size:15px;line-height:1.7;color:var(--ink)}
.cb-checklist li:last-child{border-bottom:none}
.cb-checklist li::before{content:"";position:absolute;left:.15em;top:.92em;width:12px;height:6px;
  border-left:2px solid var(--accent);border-bottom:2px solid var(--accent);transform:rotate(-45deg)}

/* ---- スクロールで“ふわっと浮かび上がる”演出（cb-anim.jsがJSで付与） ---- */
.cb-fade{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.6,.2,1)}
.cb-fade.cb-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.cb-fade,.cb-fade.cb-in{opacity:1!important;transform:none!important;transition:none!important}}
