/*
Theme Name: Procell Works
Theme URI: https://prosell-traction.com/works/
Author: Procell Traction
Description: 事例ページ /works/ 専用テーマ。クライアント提供モックに準拠した card grid + filter デザイン。
Version: 0.1.0
Requires at least: 6.0
Requires PHP: 7.4
Tested up to: 6.5
License: Proprietary
Text Domain: procell-works
*/

/* ============================================================
 * Design Tokens  (Procell Traction Brand Aligned)
 *
 *   primary navy  : #1B224C  (p-navy)   ヘッダー・H1
 *   action blue   : #1C93D2  (p-blue)   CTAボタン
 *   accent teal   : #71BFBA  (p-green-2) アクセント・進行表示
 *   sub teal      : #4EA9CA  (p-green)  サブ装飾
 *   body text     : #555555  (p-base)
 * ============================================================ */
:root{
  --ink:#1B224C;            /* p-navy : メイン色 */
  --ink-2:#2A325E;          /* 同系ライト */
  --bg:#FFFFFF;
  --paper:#FFFFFF;
  --paper-2:#F4F8FB;
  --panel-soft:#DFF1FB;     /* 水色パネル背景（VISION枠と同じ） */
  --panel-soft-2:#EAF6FC;   /* もう少し薄い水色 */
  --signal:#71BFBA;         /* p-green-2 : アクセントティール */
  --signal-dim:#4EA9CA;     /* p-green : サブ装飾 */
  --action:#1C93D2;         /* p-blue : CTAボタン */
  --action-2:#157AB0;       /* hover時の深ブルー */
  --mute:#6B7A8D;
  --mute-2:#A7B3C0;
  --text-body:#555555;      /* p-base */
  --line:#E5E7EB;
  --line-dk:rgba(255,255,255,.18);
  --card:#FFFFFF;
  --maxw:1200px;
  --mono:"IBM Plex Mono",monospace;
  --sans:"Inter","Noto Sans JP",system-ui,sans-serif;
  --jp:"Noto Sans JP","Inter",sans-serif;
}

/* ============================================================
 * Reset
 * ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--jp);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ============================================================
 * SITE HEADER  (プロセル様サイト本番に準拠)
 * ============================================================ */
.pw-header{
  background:#fff;
  border-bottom:1px solid #9ca3af;
  position:relative;z-index:50;
}
.pw-header__inner{
  max-width:1400px;
  margin:0 auto;
  padding:0 32px;
  height:112px;            /* 本家サイトの h-28 */
  display:flex;
  align-items:center;
  gap:24px;
}

/* === ロゴ === */
.pw-logo{
  margin:0;display:inline-flex;align-items:center;
  width:200px;flex-shrink:0;
}
.pw-logo a{display:block;text-decoration:none;transition:opacity .2s}
.pw-logo a:hover{opacity:.75}
.pw-logo svg{width:100%;height:auto;display:block}

/* === 右側ラップ：タグライン＋ナビ＋CTA === */
.pw-header__right{
  flex:1;
  display:flex;flex-direction:column;justify-content:space-between;
  height:100%;
  padding:14px 0;
}
.pw-header__top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
  margin-bottom:6px;
}
.pw-header__tagline{
  font-family:var(--jp);font-size:10.5px;
  color:var(--text-body);letter-spacing:.04em;
  line-height:1.5;
}
.pw-header__ctas{
  display:flex;gap:8px;flex-shrink:0;
}
.pw-cta{
  display:inline-flex;align-items:center;justify-content:center;
  width:176px;height:36px;
  background:var(--action);color:#fff;
  font-family:var(--jp);font-weight:500;font-size:12.5px;letter-spacing:.04em;
  border-radius:4px;
  text-decoration:none;
  transition:background-color .2s;
}
.pw-cta:hover{background:var(--action-2);color:#fff}
.pw-cta--blue{background:var(--action)}
.pw-cta--blue:hover{background:var(--action-2)}

/* === グローバルナビ（PC） === */
.pw-gnav{flex:1;display:flex;align-items:flex-end}
.pw-gnav__list{
  list-style:none;display:flex;
  gap:36px;
  font-family:var(--jp);font-size:13px;
  letter-spacing:.06em;
}
.pw-gnav__list > li{position:relative}
.pw-gnav__list > li > a,
.pw-gnav__label{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--ink);text-decoration:none;
  padding:6px 0 8px;
  font-weight:500;font-size:13px;
  cursor:pointer;
  transition:color .15s;
  white-space:nowrap;
}
.pw-gnav__list > li > a:hover,
.pw-gnav__label:hover{color:var(--action)}
.pw-gnav__caret{
  display:inline-block;width:6px;height:6px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:translateY(-2px) rotate(45deg);
  transition:transform .2s;
}
.pw-gnav__has-dropdown:hover .pw-gnav__caret{transform:translateY(0) rotate(225deg)}

/* === ドロップダウン === */
.pw-gnav__dropdown{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);
  opacity:0;visibility:hidden;
  background:#fff;border:1px solid #d1d5db;
  padding:18px 24px;
  min-width:520px;
  box-shadow:0 14px 32px -10px rgba(27,34,76,.18);
  transition:opacity .2s, transform .2s, visibility .2s;
  z-index:60;
}
.pw-gnav__dropdown--narrow{min-width:240px}
.pw-gnav__has-dropdown:hover .pw-gnav__dropdown,
.pw-gnav__has-dropdown:focus-within .pw-gnav__dropdown{
  opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);
}
.pw-gnav__dropdown-inner{display:flex;gap:28px}
.pw-gnav__col{display:flex;flex-direction:column;gap:6px;min-width:180px}
.pw-gnav__col-sublabel{
  font-family:var(--mono);font-size:9.5px;
  color:var(--mute);letter-spacing:.1em;font-weight:600;
  text-transform:uppercase;margin:12px 0 4px;
  border-bottom:1px solid var(--line);padding-bottom:6px;
}
.pw-gnav__col-label{
  font-family:var(--mono);font-size:9.5px;
  color:var(--mute);letter-spacing:.1em;font-weight:600;
  margin-bottom:6px;
  border-bottom:1px solid var(--line);padding-bottom:6px;
}
.pw-gnav__col a{
  color:var(--ink);text-decoration:none;font-size:12px;
  padding:4px 0;
  transition:color .15s;
}
.pw-gnav__col a:hover{color:var(--action)}

/* === モバイル：ハンバーガー === */
.pw-menu-btn{
  appearance:none;border:0;background:transparent;cursor:pointer;
  width:36px;height:36px;
  display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;
  flex-shrink:0;
}
.pw-menu-btn span{
  display:block;width:22px;height:2px;background:var(--ink);
  transition:transform .25s ease, opacity .15s ease;
}
.pw-menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.pw-menu-btn[aria-expanded="true"] span:nth-child(2){opacity:0}
.pw-menu-btn[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* === レスポンシブ === */
@media(max-width:1100px){
  .pw-header__inner{height:auto;padding:14px 24px;align-items:center}
  .pw-header__right{display:none}
  .pw-menu-btn{display:inline-flex;margin-left:auto}
}

/* Drawer */
.pw-drawer{
  position:fixed;top:60px;right:0;
  width:288px;max-width:90vw;
  background:#fff;
  border:1px solid #d1d5db;
  padding:24px 10px 24px 30px;
  z-index:40;
  transform:translateX(100%);
  transition:transform .3s cubic-bezier(.2,.7,.2,1);
  box-shadow:-8px 0 24px -8px rgba(27,34,76,.12);
  max-height:calc(100vh - 60px);
  overflow-y:auto;
}
.pw-drawer.open{transform:translateX(0)}
.pw-drawer__list{list-style:none;display:flex;flex-direction:column;gap:14px;font-size:14px}
.pw-drawer__list a{
  color:var(--ink);text-decoration:none;
  font-weight:500;display:block;padding:2px 0;
  transition:color .2s;
}
.pw-drawer__list a:hover{color:var(--action)}
.pw-drawer__group{
  display:block;font-size:11px;font-weight:700;
  color:var(--mute);letter-spacing:.06em;
  margin:6px 0 6px;
}
.pw-drawer__sub{list-style:none;display:flex;flex-direction:column;gap:8px;padding-left:0}
.pw-drawer__sub li{position:relative;padding-left:14px}
.pw-drawer__sub li::before{
  content:"›";position:absolute;left:0;top:0;color:var(--signal);font-weight:700;
}
.pw-drawer__sub a{font-size:13px;color:var(--text-body)}
.pw-drawer__cta{margin-top:14px}
.pw-drawer__cta a{
  display:block;background:var(--action);color:#fff;
  padding:10px 14px;border-radius:6px;text-align:center;font-weight:700;
  transition:background .2s;
}
.pw-drawer__cta a:hover{color:#fff;background:var(--action-2)}

/* ============================================================
 * SITE FOOTER  (プロセル様共通フッターに準拠)
 * ============================================================ */
.pw-footer{
  border-top:2px solid var(--ink);
  padding:36px 28px;
  background:#fff;
}
.pw-footer__nav{
  max-width:var(--maxw);margin:0 auto 24px;
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:18px 28px;
  font-size:13px;
}
.pw-footer__nav a{
  color:var(--ink);text-decoration:none;
  transition:color .2s;
}
.pw-footer__nav a:hover{color:var(--action)}
.pw-footer__copy{
  text-align:center;font-size:11px;color:var(--mute);font-family:var(--mono);
}

/* ============================================================
 * PAGE TITLE BAND  (プロセル様サイトの各ページ共通の上部帯)
 *   p-blue → p-green → p-green-2 のグラデーション
 *   斜めの装飾シェイプ
 *   センター配置・白文字
 * ============================================================ */
.hero-prev{
  position:relative;overflow:hidden;
  background:linear-gradient(90deg, #1C93D2 0%, #4EA9CA 55%, #71BFBA 100%);
  color:#fff;
  padding:54px 0 56px;
  text-align:center;
}
/* 斜めの装飾（三角形オーバーレイ） */
.hero-prev::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(115deg, rgba(255,255,255,.10) 0 18%, transparent 18% 36%, rgba(255,255,255,.06) 36% 54%, transparent 54% 100%);
  pointer-events:none;
}
.hero-prev::after{
  content:"";position:absolute;right:-8%;top:-30%;
  width:60%;height:160%;
  background:linear-gradient(120deg, rgba(255,255,255,.08), transparent 60%);
  transform:skewX(-18deg);
  pointer-events:none;
}
.hero-prev .wrap{position:relative;z-index:1}
.hero-prev .crumbs{
  font-size:11px;color:rgba(255,255,255,.75);
  margin-bottom:18px;letter-spacing:.04em;
}
.hero-prev .crumbs span{color:#fff}
.hero-prev .eyebrow{display:none}  /* 旧eyebrowは非表示（必要なら個別に有効化） */

.hero-prev h1{
  font-family:var(--jp);
  font-size:clamp(22px,2.6vw,28px);
  font-weight:700;letter-spacing:.04em;line-height:1.5;
  color:#fff;
  margin:0 0 12px;
}
.hero-prev h1 mark{
  background:rgba(255,255,255,.18);
  color:#fff;
  padding:0 4px;border-radius:3px;
}
.hero-prev .sub{
  font-family:var(--jp);font-size:14px;
  color:rgba(255,255,255,.88);letter-spacing:.04em;
  margin:0 auto;
}
.hero-prev p{
  max-width:720px;margin:14px auto 0;
  color:rgba(255,255,255,.92);font-size:14px;line-height:1.95;
}

/* 詳細ページ向け（小さめのタイトル帯） */
.case-single .hero-prev{padding:42px 0 44px}
.case-single .hero-prev h1{font-size:clamp(20px,2.4vw,24px)}

/* ============================================================
 * TRACK RECORD（実績）
 * 水色パネルで囲む（プロセル様サイトのVISIONブロックスタイルに準拠）
 * ============================================================ */
.track{
  background:#fff;
  padding:64px 0 64px;
}
.track-head{text-align:center;max-width:760px;margin:0 auto 36px}
.track-head .eb{
  font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  color:var(--action);font-weight:600;display:block;margin-bottom:10px;
  position:relative;padding-bottom:14px;
}
.track-head .eb::after{
  content:"";display:block;width:36px;height:2px;background:var(--action);
  margin:8px auto 0;
}
.track-head .eb-img{
  display:block;margin:0 auto 18px;
  height:48px;width:auto;
}
.track-head h2{
  font-family:var(--jp);font-weight:900;
  font-size:clamp(20px,2.6vw,26px);
  line-height:1.55;letter-spacing:.01em;color:var(--ink);
}
.track-head h2 mark{
  background:linear-gradient(transparent 62%,rgba(28,147,210,.18) 62%);
  color:inherit;padding:0 4px;
}
.track-head p{font-size:13.5px;color:var(--text-body);margin-top:14px;line-height:1.95}

/* 水色パネル：実績を包む箱 */
.track .panel{
  max-width:1000px;margin:0 auto;
  background:var(--panel-soft);
  border-radius:6px;
  padding:36px 40px 32px;
}

.rec-block{margin:0 auto 18px}
.rec-block:last-child{margin-bottom:0}
.rec-label{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.rec-label .ja{
  font-family:var(--jp);font-weight:700;font-size:12.5px;color:var(--ink);
  letter-spacing:.04em;white-space:nowrap;
}
.rec-label .en{font-family:var(--mono);font-size:9.5px;color:var(--action);letter-spacing:.12em;font-weight:600}
.rec-label .rule{flex:1;height:1px;background:rgba(28,147,210,.25)}
.rec-items{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:6px 0}
.rec-item{
  font-family:var(--jp);font-size:12.5px;font-weight:500;color:var(--ink-2);
  padding:2px 14px;position:relative;
}
.rec-item:not(:last-child)::after{
  content:"";position:absolute;right:0;top:50%;
  transform:translateY(-50%);width:1px;height:11px;background:rgba(27,34,76,.18);
}
.rec-item.biz{color:#0F766E}

/* ============================================================
 * FILTER BAR
 * ============================================================ */
.filterbar{
  background:linear-gradient(90deg, #1C93D2 0%, #4EA9CA 55%, #71BFBA 100%);
  position:sticky;top:0;z-index:30;
  box-shadow:0 4px 14px -6px rgba(27,34,76,.25);
  margin:0;       /* sticky直前の余白を確実にゼロ */
}
/* 上下のセクション間で見栄えを良くする */
.filterbar + .stage{padding-top:48px}
.filter-inner{display:flex;align-items:center;gap:18px;padding:14px 0;flex-wrap:wrap}
.filter-tag{
  font-family:var(--mono);font-size:11px;color:#fff;
  letter-spacing:.1em;display:flex;align-items:center;gap:8px;white-space:nowrap;font-weight:700;
}
.filter-tag svg{width:14px;height:14px;stroke:#fff}
.selects{display:flex;gap:8px;flex-wrap:wrap;flex:1}
.sel{position:relative}
.sel select{
  appearance:none;background:rgba(255,255,255,.92);color:var(--ink);
  border:1px solid rgba(255,255,255,.6);border-radius:6px;
  padding:8px 32px 8px 12px;
  font-family:var(--jp);font-size:12.5px;cursor:pointer;min-width:152px;
  transition:background-color .15s,border-color .15s;
}
.sel select:hover{background:#fff}
.sel select:focus{outline:none;background:#fff;border-color:var(--ink)}
.sel select option{background:#fff;color:var(--ink)}
.sel::after{
  content:"";position:absolute;right:12px;top:50%;
  width:6px;height:6px;
  border-right:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);
  transform:translateY(-70%) rotate(45deg);pointer-events:none;
}
.sel input{
  background:rgba(255,255,255,.92);color:var(--ink);
  border:1px solid rgba(255,255,255,.6);border-radius:6px;
  padding:8px 12px;font-family:var(--jp);font-size:12.5px;min-width:200px;
  transition:background-color .15s,border-color .15s;
}
.sel input::placeholder{color:var(--mute-2)}
.sel input:hover{background:#fff}
.sel input:focus{outline:none;background:#fff;border-color:var(--ink)}
.filter-right{display:flex;align-items:center;gap:16px}
.clearbtn{
  font-family:var(--mono);font-size:11px;color:#fff;background:none;
  border:none;cursor:pointer;letter-spacing:.04em;
  text-decoration:underline;text-underline-offset:3px;opacity:.85;
}
.clearbtn:hover{opacity:1}
.count{font-family:var(--mono);font-size:12px;color:#fff;white-space:nowrap;opacity:.92}
.count b{color:#fff;font-size:18px;font-weight:700}

/* ============================================================
 * GRID SECTIONS
 * ============================================================ */
.stage{padding:60px 0 30px}
.stage:last-of-type{padding-bottom:90px}
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:30px;gap:20px;flex-wrap:wrap;
}
.sec-head .l{display:flex;align-items:baseline;gap:16px}
.sec-head .idx{font-family:var(--mono);font-size:13px;color:var(--signal-dim);font-weight:600}
.sec-head h2{
  font-family:var(--jp);font-weight:900;font-size:26px;
  letter-spacing:-.01em;color:var(--ink);
}
.sec-head .en{
  font-family:var(--mono);font-size:11px;color:var(--mute);
  letter-spacing:.14em;display:block;margin-top:3px;
}
.sec-head .cnt{font-family:var(--mono);font-size:12px;color:var(--mute)}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}

/* ============================================================
 * CARD
 * ============================================================ */
.card{
  position:relative;background:var(--card);border:1px solid var(--line);
  border-radius:14px;overflow:hidden;display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:transform .22s cubic-bezier(.2,.7,.2,1),box-shadow .22s,border-color .22s;
}
.card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px -12px rgba(10,22,34,.22);
  border-color:#c9cabf;
}
.card:focus-visible{outline:2px solid var(--signal);outline-offset:2px}

/* Phase indicators — タグ風コンパクト1行表示 */
.phasebar{
  display:flex;align-items:center;gap:4px;padding:7px 12px;
  background:var(--ink);font-family:var(--mono);flex-wrap:nowrap;overflow:hidden;
}
.phasebar .ph-tag{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.01em;
  padding:2px 6px;border-radius:3px;
  background:rgba(255,255,255,.10);color:rgba(255,255,255,.45);
  white-space:nowrap;transition:background-color .2s,color .2s;
  flex-shrink:0;
}
.phasebar .ph-tag.on{
  background:var(--signal);color:var(--ink);font-weight:700;
}
.phasebar .ph-type{
  margin-left:auto;font-size:8px;letter-spacing:.14em;
  color:var(--signal);font-weight:600;white-space:nowrap;
  padding-left:8px;flex-shrink:0;
}

/* Thumbnail */
.thumb{
  position:relative;aspect-ratio:40/21;
  background-color:var(--paper-2);
  display:flex;align-items:center;justify-content:center;
  border-bottom:1px solid var(--line);overflow:hidden;
}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
/* ロゴ/文字主体のサムネはトリミングせずフィット＋白背景＋余白（スラッグ指定） */
.card[data-slug="saito"] .thumb,
.card[data-slug="aiesg"] .thumb,
.card[data-slug="cmc"] .thumb,
.card[data-slug="chukaio"] .thumb{
  background:#fff;
}
.card[data-slug="saito"] .thumb img,
.card[data-slug="aiesg"] .thumb img,
.card[data-slug="cmc"] .thumb img,
.card[data-slug="chukaio"] .thumb img{
  object-fit:contain;
  background:#fff;
  padding:24px;
  box-sizing:border-box;
}
.thumb-ph,
.thumb--placeholder{
  position:relative;aspect-ratio:40/21;
  background:repeating-linear-gradient(135deg,#f4f6f9,#f4f6f9 9px,#e8edf3 9px,#e8edf3 18px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  border-bottom:1px solid var(--line);
}
.thumb-ph .ic,
.thumb--placeholder .ic{width:26px;height:26px;stroke:#9aa7b5}
.thumb-ph .t1,
.thumb--placeholder .t1{
  font-family:var(--jp);font-size:11px;color:#6b7a8d;
  letter-spacing:.08em;font-weight:500;
}
.thumb-ph .t2{
  font-family:var(--mono);font-size:9.5px;color:#a7ac9d;
  background:#fff;border:1px solid var(--line);border-radius:4px;padding:2px 8px;
}

.cbody{padding:14px 16px 0;flex:1;display:flex;flex-direction:column}
.tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.tg{
  font-family:var(--mono);font-size:9.5px;font-weight:500;
  padding:2px 7px;border-radius:4px;
  background:var(--paper-2);color:var(--ink-2);letter-spacing:.02em;
}
/* 会社名 / サービス名の明示ブロック */
.ccorp{
  display:flex;flex-direction:column;gap:4px;
  padding:8px 12px;background:var(--paper-2);
  border-left:3px solid var(--signal);
  border-radius:6px;margin-bottom:10px;
}
.ccorp__row{
  display:flex;align-items:baseline;gap:8px;line-height:1.45;
}
.ccorp__key{
  font-family:var(--jp);font-size:10.5px;font-weight:700;
  color:var(--mute);letter-spacing:.04em;flex-shrink:0;
  min-width:56px;
}
.ccorp__val{
  font-family:var(--jp);font-size:12px;font-weight:700;color:var(--ink);
  word-break:break-word;
}

.ctitle{
  font-family:var(--jp);font-weight:700;font-size:15px;line-height:1.55;
  letter-spacing:.005em;margin-bottom:10px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;text-overflow:ellipsis;
}
.cclient{
  font-family:var(--mono);font-size:10.5px;color:var(--mute);
  margin-bottom:12px;letter-spacing:.02em;
}

.result{
  position:relative;margin:0 -16px;padding:11px 16px 12px;
  background:linear-gradient(180deg,#f5fbfb,#eef7f6);
  border-top:1px solid #dceae8;
}
.result .rl{
  font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;
  color:var(--signal-dim);margin-bottom:4px;
}
.result .rm{
  font-family:var(--jp);font-weight:700;font-size:12px;
  line-height:1.45;color:var(--ink);
}
.result .rm .big{
  font-family:var(--mono);font-weight:600;font-size:18px;
  color:var(--action);letter-spacing:-.02em;padding:0 1px;
}

.meta{padding:11px 0 4px}
.mrow{display:flex;font-family:var(--mono);font-size:10px;line-height:1.75}
.mrow .k{width:50px;font-size:9px;color:var(--mute);flex-shrink:0}
.mrow .v{color:var(--ink-2);font-weight:500;font-family:var(--jp)}

.cfoot{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 16px;border-top:1px solid var(--line);
}
.cfoot .more{font-family:var(--jp);font-weight:700;font-size:11.5px;color:var(--ink)}
.cfoot .ar{
  width:26px;height:26px;border-radius:50%;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;
}
.card:hover .cfoot .ar{background:var(--signal);transform:translateX(2px)}
.cfoot .ar svg{width:11px;height:11px;stroke:#fff;transition:stroke .2s}
.card:hover .cfoot .ar svg{stroke:var(--ink)}

.empty{text-align:center;padding:64px 20px;color:var(--mute)}
.empty h3{font-family:var(--jp);font-weight:700;font-size:17px;color:var(--ink);margin-bottom:8px}

/* ============================================================
 * Cases (事例解説) - 事例解説セクション固有の差分
 *   ・thumb-ph はインタビューと同じ大きさで表示
 *   ・client_name（匿名化済み）も表示する
 * ============================================================ */
/* （かつての縮小指定は撤廃。インタビューと同じカード見た目に統一） */

/* ============================================================
 * Case TOC（記事ページ自動目次）
 * ============================================================ */
.case-toc{
  background:#F0F8FC;
  border:1px solid #CFE4F3;
  border-radius:8px;
  padding:18px 24px 14px;
  margin:24px 0;
}
.case-toc__label{
  font-family:var(--jp);
  font-weight:700;
  font-size:16px;
  color:var(--ink);
  margin-bottom:10px;
}
.case-toc__list{
  list-style:none;        /* H2 のテキスト側に既に「１．」が入っているので自動番号は付けない */
  margin:0;
  padding-left:0;
}
.case-toc__list li{
  margin:6px 0;
  line-height:1.5;
}
.case-toc__list a{
  color:var(--blue);
  text-decoration:none;
  border-bottom:1px solid transparent;
  transition:border-color .15s, color .15s;
}
.case-toc__list a:hover{
  color:var(--ink);
  border-bottom-color:var(--blue);
}
/* h2 アンカーへのジャンプ余白（固定ヘッダーで隠れないよう） */
.case-single h2[id^="sec-"]{
  scroll-margin-top:120px;
}

/* ============================================================
 * Case body images (本文中の画像を統一サイズに)
 * ============================================================ */
.case-single .case-img,
.case-single figure.wp-block-image{
  margin:28px auto;
  max-width:720px;
  width:100%;
  text-align:center;
}
.case-single .case-img img,
.case-single figure.wp-block-image img{
  display:block;
  width:100%;
  height:auto;
  max-height:480px;
  object-fit:cover;
  object-position:center;
  border-radius:6px;
}

/* ============================================================
 * CTA  (導入事例ページタイトル帯と同じ青グラデーション)
 * ============================================================ */
.cta{
  background:linear-gradient(90deg, #1C93D2 0%, #4EA9CA 55%, #71BFBA 100%);
  color:#fff;position:relative;overflow:hidden;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(115deg, rgba(255,255,255,.10) 0 18%, transparent 18% 36%, rgba(255,255,255,.06) 36% 54%, transparent 54% 100%);
  pointer-events:none;
}
.cta::after{
  content:"";position:absolute;right:-8%;top:-30%;
  width:60%;height:160%;
  background:linear-gradient(120deg, rgba(255,255,255,.08), transparent 60%);
  transform:skewX(-18deg);
  pointer-events:none;
}
.cta .grid-bg{display:none}  /* 旧グリッド背景は不要 */
.cta .wrap{position:relative;z-index:1;padding:64px 28px;text-align:center}
.cta h2{
  font-family:var(--jp);font-weight:900;
  font-size:clamp(22px,3vw,30px);
  line-height:1.5;margin-bottom:14px;letter-spacing:.005em;
  color:#fff;
}
.cta h2 .lime{
  background:rgba(255,255,255,.18);color:#fff;
  padding:0 4px;border-radius:3px;
}
.cta p{color:rgba(255,255,255,.92);font-size:14px;margin-bottom:30px}
.cta a{
  display:inline-flex;align-items:center;gap:12px;
  background:#fff;color:var(--action);
  font-family:var(--jp);font-weight:700;font-size:15px;
  padding:14px 34px;border-radius:100px;text-decoration:none;
  transition:transform .2s,box-shadow .2s,background-color .2s;
  box-shadow:0 6px 18px -4px rgba(27,34,76,.18);
}
.cta a:hover{
  transform:translateY(-2px);
  background:var(--ink);color:#fff;
  box-shadow:0 12px 30px -8px rgba(27,34,76,.35);
}
.cta a svg{width:16px;height:16px;stroke:currentColor}

.note{
  background:#060e17;color:var(--mute);
  font-family:var(--mono);font-size:10px;line-height:1.8;
  text-align:center;padding:22px 28px;letter-spacing:.02em;
}
.note .impl{color:var(--signal-dim)}

/* ============================================================
 * Responsive
 * ============================================================ */
@media(max-width:980px){
  .grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  /* カードは1列レイアウト（PC同等サイズ） */
  .grid{grid-template-columns:1fr}

  /* TRACK RECORD パネルをスリム化 */
  .track{padding:44px 0 44px}
  .track-head{margin-bottom:24px}
  .track-head .eb-img{height:38px;margin-bottom:12px}
  .track .panel{padding:22px 18px}
  .rec-block{margin-bottom:14px}
  .rec-label{margin-bottom:10px;gap:8px}
  .rec-label .ja{font-size:11.5px}
  .rec-label .en{font-size:9px}
  .rec-items{column-gap:0;row-gap:4px}
  .rec-item{font-size:11.5px;padding:1px 10px}

  /* フィルタ：4プルダウンを2×2、検索ボックスは下に全幅 */
  .filter-inner{gap:10px;padding:12px 0}
  .selects{
    width:100%;
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:6px;
  }
  .sel{width:auto}
  .sel select,.sel input{
    width:100%;min-width:0;
    padding:7px 28px 7px 10px;font-size:12px;
  }
  /* キーワード検索（最後の.sel）は全幅 */
  .selects > .sel:last-child{grid-column:1 / -1}

  .filter-right{width:100%;justify-content:space-between}
}

/* ============================================================
 * Single Case Study (個別事例ページ用・初期ドラフト)
 * ============================================================ */
.case-single{padding:60px 0 90px}
.case-single .crumbs{
  font-family:var(--mono);font-size:11px;color:var(--mute);
  letter-spacing:.04em;margin-bottom:24px;
}
.case-single .crumbs a{color:var(--mute);text-decoration:none}
.case-single .crumbs a:hover{color:var(--ink)}
.case-single .case-hero{margin-bottom:48px}
.case-single .case-hero .tags{margin-bottom:18px}
.case-single .case-hero h1{
  font-family:var(--jp);font-weight:900;
  font-size:clamp(26px,3.6vw,36px);line-height:1.5;letter-spacing:-.005em;
  margin-bottom:18px;
}
.case-single .case-hero .client-line{
  font-family:var(--mono);font-size:12px;color:var(--mute);letter-spacing:.04em;
}
.case-single .summary-table{
  background:var(--card);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;margin-bottom:48px;
}
.case-single .summary-table table{width:100%;border-collapse:collapse}
.case-single .summary-table th,
.case-single .summary-table td{
  padding:14px 20px;border-bottom:1px solid var(--line);
  font-size:13px;line-height:1.7;text-align:left;vertical-align:top;
}
.case-single .summary-table th{
  width:200px;background:var(--paper);color:var(--ink-2);
  font-family:var(--jp);font-weight:700;font-size:12px;
}
.case-single .summary-table tr:last-child th,
.case-single .summary-table tr:last-child td{border-bottom:0}
.case-single h2{
  font-family:var(--jp);font-weight:900;
  font-size:22px;line-height:1.5;margin:48px 0 18px;color:var(--ink);
}
.case-single h3{
  font-family:var(--jp);font-weight:700;
  font-size:17px;line-height:1.6;margin:32px 0 12px;color:var(--ink);
}
.case-single p{margin-bottom:14px;font-size:14.5px;line-height:1.95;color:var(--ink-2)}
.case-single strong{font-weight:700;color:var(--ink)}
.case-single .is-table{
  width:100%;border-collapse:collapse;margin:18px 0 28px;
  border:1px solid var(--line);border-radius:8px;overflow:hidden;
}
.case-single .is-table th,
.case-single .is-table td{
  padding:11px 14px;border-bottom:1px solid var(--line);
  font-size:13px;line-height:1.7;text-align:left;vertical-align:top;
}
.case-single .is-table th{background:var(--paper-2);font-weight:700;color:var(--ink-2)}
.case-single .is-table tr:last-child th,
.case-single .is-table tr:last-child td{border-bottom:0}
.case-single .faq-item{
  border-top:1px solid var(--line);padding:24px 0;
}
.case-single .faq-item h3{margin:0 0 12px;font-size:16px}
.case-single .faq-item .q-label{color:var(--signal-dim);font-family:var(--mono);font-size:11px;letter-spacing:.06em;margin-right:8px}
