@charset "utf-8";
/* ================================================================
   TARSKホールディングス トップページ スタイル
   デザイン: モックアップV02準拠 / 中身: 実装スペック確定版
   ================================================================ */

:root{
  --navy:#0c223b;
  --head:#03317B;
  --blue:#066FC8;
  --blue-d:#125a9c;
  --serif:YakuHanMP,"Noto Serif JP","Hiragino Mincho ProN","Yu Mincho",YuMincho,"MS PMincho",serif;
  --gold:#b58a3b;
  --ink:#17191d;
  --muted:#666b75;
  --line:#dfe3e8;
  --card-line:#C9E2F8;
  --soft:#f3f6fa;
  --water:#e9f4fd;
  --paper:#fff;
  --radius:4px;
  --shadow:0 14px 34px rgba(12,34,59,.10);
  --shadow-sm:0 6px 18px rgba(12,34,59,.08);
  --container:1180px;
  --header-h:74px;
}

*,*::before,*::after{box-sizing:border-box;}
/* font-size の基準: 1rem = 10px（px ÷ 10 = rem）。各所の font-size は rem で統一 */
html{font-size:62.5%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 12px);}
body{
  margin:0;color:var(--ink);background:var(--water);
  font-family:YakuHanJP,"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  font-size:1.6rem;line-height:1.8;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul,ol{list-style:none;margin:0;padding:0;}
h1,h2,h3,p{margin:0;}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 24px;}
.container--wide{max-width:1480px;}

/* 超広幅ディスプレイ対策：ヘッダー・各セクション・フッターの最大幅を1920pxに制限し中央寄せ */
.site-header,main,.site-footer{max-width:1920px;margin-inline:auto;}
/* キーナンバーをヒーロー下端へ絶対配置で重ねるための位置基準 */
main{position:relative;}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  font-size:1.4rem;font-weight:700;line-height:1;border-radius:4px;
  padding:16px 24px;transition:.18s;cursor:pointer;border:1.5px solid transparent;white-space:nowrap;
}
.btn .arr{transition:transform .18s;}
.btn:hover .arr{transform:translateX(3px);}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 18px rgba(23,105,180,.28);}
.btn-primary:hover{background:var(--blue-d);}
.btn-ghost{background:#fff;color:var(--blue);border-color:var(--blue);}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy);}
.btn-outline:hover{background:var(--navy);color:#fff;}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.6);}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff;}
/* 成長ビジョン用：白背景・青枠・青文字。ホバーで青塗り＋白文字（従来の色） */
.btn-vision{background:#fff;color:var(--blue);border-color:var(--blue);box-shadow:none;}
.btn-vision:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 8px 18px rgba(23,105,180,.28);}
.btn-contact{background:var(--blue);color:#fff;font-size:1.5rem;padding:13px 26px;border-radius:999px;box-shadow:0 8px 18px rgba(23,105,180,.25);}
.btn-contact:hover{background:var(--blue-d);}
.btn-lg{padding:16px 28px;font-size:1.5rem;}
/* メールアイコン（Unicode絵文字はサイズが不安定なためSVGマスクで精密に表示） */
.ico-mail{
  width:16px;height:16px;flex:0 0 auto;display:inline-block;
  background-color:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M20%204H4c-1.1%200-2%20.9-2%202v12c0%201.1.9%202%202%202h16c1.1%200%202-.9%202-2V6c0-1.1-.9-2-2-2zm0%204l-8%205-8-5V6l8%205%208-5v2z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M20%204H4c-1.1%200-2%20.9-2%202v12c0%201.1.9%202%202%202h16c1.1%200%202-.9%202-2V6c0-1.1-.9-2-2-2zm0%204l-8%205-8-5V6l8%205%208-5v2z'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* ---------- ブランドロゴ ---------- */
.brand{display:inline-flex;align-items:center;}
.brand img{height:48px;width:auto;display:block;}
.brand--footer img{height:40px;}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:1280px;margin:0 auto;height:var(--header-h);padding:0 24px;
  display:flex;align-items:center;gap:24px;
}
.gnav{margin-left:auto;display:flex;align-items:center;gap:32px;}
.gnav>ul{display:flex;align-items:center;gap:48px;}
.gnav>ul a{font-size:1.5rem;font-weight:700;color:var(--navy);position:relative;padding:6px 0;}
.gnav>ul a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:.2s;}
.gnav>ul a:hover::after{transform:scaleX(1);}
.gnav-contact{display:none;}
.header-contact{margin-left:auto;}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;align-items:center;justify-content:center;}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);transition:.25s;}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ---------- ファーストビュー ---------- */
/* ヒーローは画像をフル高さで表示（横は右端基準でトリミング）。キーナンバーは下にabsoluteで重ねる。
   絶対配置のキーナンバーが下のセクションに被らないよう margin-bottom でスペースを確保 */
.hero{position:relative;min-height:clamp(540px,53vw,610px);display:flex;align-items:center;overflow:hidden;background:#dceaf6;margin-bottom:152px;}
.hero-media{position:absolute;inset:0;z-index:0;}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:right bottom;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(100deg,rgba(255,255,255,.92) 0%,rgba(255,255,255,.78) 34%,rgba(255,255,255,.25) 56%,rgba(255,255,255,0) 75%);}
.hero-body{position:relative;z-index:3;max-width:var(--container);width:100%;margin:0 auto;padding:0 24px;}
.hero-title{font-family:var(--serif);font-size:clamp(3rem,4.4vw,5rem);font-weight:700;line-height:1.36;color:var(--head);letter-spacing:.03em;}
.hero-lead{margin-top:22px;font-size:clamp(1.5rem,1.45vw,1.7rem);color:#1f2d3a;font-weight:600;line-height:1.9;}
.hero-sub{margin-top:10px;font-size:clamp(1.5rem,1.45vw,1.7rem);color:#1f2d3a;font-weight:600;max-width:560px;line-height:1.9;}
/* 2つのボタンを横並びで2等分し、合計幅をタイトル2行目「人と社会の未来をつくる。」に合わせる
   （タイトルは clamp(30px,4.4vw,50px)。同文字数12字×約1.03の実幅 ≒ 54.4vw を上限618pxで追従）。
   画面が狭くなったら縦積みにせず、ボタン自体を縮小して横並びを維持する（キーナンバーとの重なり防止） */
.hero-actions{margin-top:32px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:clamp(10px,1.2vw,16px);width:clamp(340px,54.4vw,618px);max-width:100%;}
.hero-actions .btn{font-size:clamp(1.05rem,1.45vw,1.6rem);padding:clamp(11px,1.5vw,24px) clamp(6px,1.3vw,22px);border-radius:4px;min-width:0;}

/* ---------- キーナンバー（1枚パネルに横一列／現在｜未来を区切り線で分離） ---------- */
/* キーナンバー：ヒーロー下端へ絶対配置で重ねる（top はヒーロー高さに追従）。背景は透過しパネルだけを浮かせる */
.numbers{position:absolute;left:0;right:0;top:calc(clamp(540px,53vw,610px) - 84px);z-index:5;padding:0;background:transparent;}
.num-panel{
  display:flex;align-items:stretch;
  background:rgba(255,255,255,.96);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  border:2px solid var(--card-line);border-radius:8px;box-shadow:var(--shadow);
  padding:16px 6px;
}
.num-set{display:flex;flex-direction:column;gap:10px;min-width:0;}
.num-set--current{flex:3 1 0;}
.num-set--vision{flex:3 1 0;border-left:2px solid #cfdded;} /* 来期｜2033 の区切り線（3枚なので現在ブロックと同じ flex:3） */
.num-set-cap{display:inline-flex;align-items:center;gap:8px;margin:0;padding:0 14px;font-size:1.55rem;font-weight:800;color:var(--navy);letter-spacing:.04em;}
.num-set-cap::before{content:"";width:5px;height:17px;border-radius:2px;background:#27B3A2;}
.num-set--vision .num-set-cap{color:var(--head);}
.num-set--vision .num-set-cap::before{background:#3E7DE4;}
.num-row{display:flex;align-items:stretch;}
.num-card{
  flex:1 1 0;min-width:0;display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;
  padding:6px 12px;border-left:2px solid var(--card-line); /* カード間の区切り線 */
}
.num-row .num-card:first-child{border-left:none;}
/* アイコン→見出し→数字 を中央寄せで縦並び */
.num-card-head{display:flex;flex-direction:column;align-items:center;gap:7px;}
.num-ico-img{width:64px;height:64px;object-fit:contain;flex:0 0 auto;}
.num-label{font-size:1.3rem;font-weight:700;color:var(--muted);line-height:1.3;}
/* 数字は細長い英字フォント（Oswald）でモックアップに寄せる。単位（億円/名/校）は日本語フォントへ自動フォールバック */
.num-value{margin:0;font-family:"Roboto Condensed","Roboto","Helvetica Neue",Arial,sans-serif;font-weight:600;color:var(--navy);font-size:3.7rem;line-height:1;letter-spacing:.01em;white-space:nowrap;}
.num-value .unit{font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;font-size:1.5rem;font-weight:700;color:var(--navy);margin-left:5px;}
/* 未来（目標）は数字を青で強調。見出しもモックアップに合わせて数値と同じ青に */
.num-set--vision .num-value,.num-set--vision .num-value .unit{color:var(--blue);}
.num-set--vision .num-label{color:var(--blue);}
/* 現在は「未来の青」に黒味を足した、やや濃いめのくすんだ青（現状値は控えめ、目標を引き立てる） */
.num-set--current .num-value,.num-set--current .num-value .unit{color:#6a87a8;}
.num-set--current .num-label{color:#496f96;}
/* ── 来期の目標売上高（オレンジで分離）。トップ（.numbers）・vision（#numbers）とも
   現在 → 来期 → 2033年ビジョン の3ブロック構成。来期は1枚（flex:1）、現在/2033は各3枚（flex:3）で
   カード幅を揃える（2033は上の .num-set--vision を flex:3 に統一済みなのでスコープ限定は不要） ── */
.num-set--next{flex:1 1 0;border-left:2px solid #cfdded;} /* 現在｜来期 の区切り線 */
.num-set--next .num-set-cap{color:#A8530A;} /* 見出しは濃いオレンジ（青系と区別） */
.num-set--next .num-set-cap::before{background:#EE8A1E;} /* 見出しの色帯もオレンジ */
.num-set--next .num-value,.num-set--next .num-value .unit{color:#E07A12;} /* 数値はビビッドなオレンジ */
.num-set--next .num-label{color:#A8530A;}
.num-set--next .num-row{justify-content:center;} /* カード1枚のため中央寄せ */
/* 数字の接頭辞（例：約）は単位と同じ小さいサイズに */
.num-prefix{font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;font-size:1.5rem;font-weight:700;margin-right:2px;}

/* ---------- セクション共通 ---------- */
.section{padding:72px 0;}
.sec-head{text-align:center;margin-bottom:40px;}
.sec-title{font-size:clamp(2.3rem,2.6vw,3rem);font-weight:800;color:var(--head);letter-spacing:.04em;}
.sec-subtitle{margin:12px 0 0;font-size:clamp(1.5rem,1.8vw,1.8rem);font-weight:700;color:var(--navy);}
.sec-lead{margin:12px auto 0;max-width:760px;color:var(--muted);font-size:1.5rem;line-height:1.9;}
.sec-lead-wrap{display:flex;justify-content:center;margin-top:12px;}
.sec-lead-wrap .sec-lead{margin:0;text-align:left;}
.sec-head--left .sec-subtitle{text-align:left;}
.sec-action{text-align:center;margin-top:36px;}

/* ---------- 事業紹介（6列1行・色付きタイトルを上に・アイコンなし） ---------- */
.business{background:#F1F8FE;padding-bottom:34px;}
.biz-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;}
.biz-card{
  --biz:var(--blue);
  position:relative;background:#fff;border:2px solid var(--card-line);border-radius:4px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:.2s;
}
.biz-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#c4d2e2;}
.biz-name{display:flex;align-items:center;gap:8px;font-size:1.35rem;font-weight:800;color:var(--biz);line-height:1.35;padding:13px 13px 10px;min-height:3.9em;}
.biz-icon{width:30px;height:30px;flex:0 0 auto;object-fit:contain;}
.biz-thumb{display:block;aspect-ratio:4/3;background:#eef2f7;}
.biz-thumb img{width:100%;height:100%;object-fit:cover;}
.biz-text{font-size:1.3rem;color:#56606c;line-height:1.65;padding:12px 14px 8px;flex:1;}
.biz-more{display:flex;justify-content:center;align-items:center;gap:5px;font-size:1.25rem;font-weight:700;color:var(--blue);padding:0 14px 16px;}
.biz-card:hover .biz-more .arr{transform:translateX(3px);}
.biz-more .arr{transition:transform .18s;}
.biz-badge-new{position:absolute;top:10px;right:10px;z-index:2;background:var(--gold);color:#fff;font-size:1rem;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:.04em;}
.biz-driving{--biz:#1769b4;}
.biz-realestate{--biz:#2e8b57;}
.biz-construction{--biz:#bf7d2a;}
.biz-stayfood{--biz:#e0892a;}
.biz-insurance{--biz:#0e8a82;}
.biz-dx{--biz:#5b6fd0;}

/* ---------- グループ企業（マーキー） ---------- */
.companies{background:#F1F8FE;padding-top:24px;}
/* マーキーのラッパー：両端に＜＞ボタン用のスペース（padding）を確保し、カードはその内側だけでループ */
.marquee-wrap{position:relative;padding:0 60px;}
/* 連続した1枚の帯（角丸の白パネル）。カードはこの中をスクロール */
.marquee{margin-top:8px;overflow:hidden;cursor:grab;background:#fff;border:2px solid var(--card-line);border-radius:4px;box-shadow:var(--shadow-sm);touch-action:pan-y;}
.marquee.dragging{cursor:grabbing;}
.marquee-track{display:flex;gap:0;width:max-content;will-change:transform;padding:0;}
/* モックアップ準拠：背景画像なしのコンパクトな白カードを、間隔ゼロ＋縦の区切り線で連続表示 */
.co-card{
  flex:0 0 auto;width:250px;background:#fff;border:0;border-right:2px solid var(--card-line);border-radius:0;
  padding:22px 24px;display:grid;grid-template-columns:auto 1fr;grid-template-areas:"logo name" "text text";
  column-gap:12px;row-gap:13px;align-items:center;text-align:left;
  box-shadow:none;transition:background .2s;position:relative;
}
.co-card:hover{background:var(--water);}
.co-logo-img{grid-area:logo;width:44px;height:44px;border-radius:10px;display:block;box-shadow:0 3px 9px rgba(12,34,59,.14);}
.co-name{grid-area:name;font-size:1.4rem;font-weight:800;color:var(--navy);line-height:1.3;}
.co-text{grid-area:text;font-size:1.3rem;color:var(--muted);line-height:1.6;}
/* リンク先の公式横長ロゴに差し替えたカード（社名テキストは省略） */
.co-card--logo{grid-template-areas:"logo logo" "text text";}
/* ロゴ直下に名称を併記するカード（#77）：logo→name→text の縦並び */
.co-card--logo:has(.co-logoname){grid-template-areas:"logo logo" "name name" "text text";}
.co-logoname{grid-area:name;justify-self:start;font-size:1.25rem;font-weight:700;color:var(--navy);line-height:1.3;}
.co-logo-full{grid-area:logo;justify-self:start;width:auto;height:auto;max-width:100%;max-height:46px;display:block;}
/* 左右の送りボタン（＜ ＞） */
.marquee-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:42px;height:42px;border-radius:999px;border:1px solid var(--line);
  background:rgba(255,255,255,.96);color:var(--navy);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(12,34,59,.14);transition:.18s;
}
.marquee-nav:hover{background:#fff;border-color:var(--blue);color:var(--blue);}
.marquee-nav:active{transform:translateY(-50%) scale(.94);}
.marquee-nav svg{width:18px;height:18px;display:block;}
.marquee-prev{left:9px;}
.marquee-next{right:9px;}

/* ---------- 代表メッセージ（バナー型） ---------- */
.ceomsg{
  position:relative;overflow:hidden;
  background:linear-gradient(100deg,#ffffff 0%,#eef5fb 46%,#dbe9f6 100%);
}
/* 右側：代表写真エリア（左端を斜めにカット）。画像を斜めエリア全体にシームレスに敷く */
.ceomsg-photo{
  position:absolute;top:0;right:0;bottom:0;width:46%;z-index:1;
  background:linear-gradient(155deg,#d3e4f5 0%,#aecbe6 58%,#8fb4d8 100%);
  clip-path:polygon(16% 0,100% 0,100% 100%,2% 100%);
  overflow:hidden;
}
/* 代表写真：斜めエリアいっぱいに cover で配置（枠なし・継ぎ目なし） */
.ceomsg-photo-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center 30%;
}
/* 左側：テキスト（左の白ゾーン=左カラムの中で中央寄せにして左隅寄りを解消） */
.ceomsg-inner{position:relative;z-index:2;display:grid;grid-template-columns:54% 46%;align-items:center;min-height:430px;padding-top:52px;padding-bottom:52px;}
.ceomsg-text{grid-column:1;justify-self:center;max-width:600px;}
.ceomsg-title{
  font-family:var(--serif);font-weight:700;color:var(--head);
  font-size:clamp(2.4rem,2.8vw,3.2rem);letter-spacing:.1em;margin:0 0 26px;
}
.ceomsg-lead{color:#33414f;font-size:1.6rem;line-height:2.1;margin:0 0 28px;}
.ceomsg-sign{font-family:var(--serif);color:var(--navy);font-size:1.4rem;margin:0 0 26px;}
.ceomsg-sign strong{font-size:2.1rem;font-weight:700;letter-spacing:.05em;margin-left:2px;}

/* ---------- 成長ビジョン ---------- */
/* ---------- 成長ビジョン（画像にテキストをオーバーレイ） ---------- */
.vision{background:#eaf3fb;}
.vision-figure{position:relative;}
.vision-pic{display:block;}
/* 高さを抑える：画像を全幅で敷くと高くなりすぎるため、高さを上限付きで固定し
   上部の空・下部の反射を object-fit:cover で軽くトリミング（グラフ本体は維持） */
.vision-img{width:100%;height:clamp(300px,28vw,440px);object-fit:cover;object-position:center 48%;display:block;}
.vision-textbox{position:absolute;inset:0;display:flex;align-items:center;}
.vision-textbox-inner{max-width:var(--container);width:100%;margin:0 auto;padding:0 24px;}
.vision-textbox-inner > *{max-width:46%;}
/* 見出しは全体同サイズ＋字間を少し広げ、行ごとの余白を詰める（モックアップ準拠） */
.vision-headline{font-size:clamp(2.2rem,3.2vw,3.6rem);font-weight:800;color:var(--head);margin:6px 0 8px;line-height:1.28;letter-spacing:.06em;white-space:nowrap;max-width:none;}
.vision-lead{color:#33414f;font-size:1.5rem;line-height:1.65;margin:0 0 18px;}

/* ---------- 沿革（左）＋ 採用（右）横並び ---------- */
/* 成長ビジョンに近づけるため上余白を詰め、背景は右=うっすい水色→左=薄くなる右→左グラデーション */
.history-recruit{background:linear-gradient(to left,#e4f1fb 0%,#eef7fd 50%,#f9fcff 100%);padding:26px 0 26px;}
.hr-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:36px;align-items:stretch;max-width:1920px;}
.sec-head--left{text-align:left;margin-bottom:22px;}
.sec-head--left .sec-lead{margin-left:0;margin-right:0;max-width:760px;}
.sec-note{margin-top:14px;color:var(--muted);font-size:1.3rem;}

/* 沿革・ニュース カード（添付準拠） */
.news-card{background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:18px 26px 8px;height:100%;}
.news-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:2px solid var(--navy);}
.news-card-title{font-size:2rem;font-weight:800;color:var(--head);}
.news-card-more{font-size:1.3rem;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:6px;transition:.15s;}
.news-card-more:hover{color:var(--blue);}
.news-card-more .arr{transition:transform .18s;}
.news-card-more:hover .arr{transform:translateX(3px);}
.news-list li{display:flex;align-items:baseline;gap:18px;padding:8px 2px;border-bottom:1px solid var(--line);}
.news-list li:last-child{border-bottom:0;}
.news-date{flex:0 0 auto;font-size:1.3rem;font-weight:700;color:#44546a;font-variant-numeric:tabular-nums;}
.news-title{font-size:1.5rem;font-weight:600;color:var(--ink);line-height:1.5;}
.sec-action--left{text-align:left;margin-top:24px;}
.dummy-note{display:inline-block;margin-left:8px;font-size:1.1rem;color:#c0392b;font-weight:700;}

.timeline{position:relative;}
.timeline::before{content:"";position:absolute;top:6px;bottom:6px;left:84px;width:2px;background:#cdd9e6;}
.tl-item{position:relative;display:grid;grid-template-columns:68px 1fr;gap:30px;align-items:center;padding:13px 0;}
.tl-dot{position:absolute;left:78px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--blue);z-index:1;}
.tl-date{text-align:right;line-height:1.12;}
.tl-date b{display:block;font-size:2.2rem;font-weight:800;color:var(--blue);}
.tl-date small{font-size:1.2rem;color:var(--muted);font-weight:700;}
.tl-title{font-size:1.45rem;font-weight:700;color:var(--navy);}

/* 採用情報（画像にテキストをオーバーレイ・添付準拠） */
.hr-recruit{display:flex;align-items:stretch;}
/* カード全体はリンクではなく単なる枠。ホバーで動かさない（リンク遷移はボタンのみ） */
.recruit-card{position:relative;display:block;width:100%;min-height:200px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.recruit-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:right center;}
.recruit-card::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(95deg,rgba(223,239,252,.97) 6%,rgba(223,239,252,.72) 36%,rgba(223,239,252,.12) 60%,transparent 76%);}
.recruit-overlay{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:14px;padding:32px 34px;max-width:66%;}
.recruit-label{font-size:clamp(1.6rem,1.9vw,2.1rem);font-weight:800;color:var(--head);letter-spacing:.05em;}
.recruit-h{font-family:var(--serif);font-size:clamp(1.9rem,2.3vw,2.6rem);font-weight:700;color:var(--head);line-height:1.4;}
.recruit-btn{margin-top:4px;display:inline-flex;align-items:center;gap:8px;background:var(--head);color:#fff;font-weight:700;font-size:1.4rem;padding:12px 22px;border-radius:4px;transition:.18s;}
.recruit-card:hover .recruit-btn{background:#16406e;}
.recruit-btn .arr{transition:transform .18s;}
.recruit-card:hover .recruit-btn .arr{transform:translateX(3px);}

/* ---------- お問い合わせ ---------- */
.contact-cta{background:linear-gradient(120deg,#0c223b,#143a64);color:#fff;padding:56px 0;}
.contact-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.contact-title{font-size:2.6rem;font-weight:800;}
.contact-lead{margin-top:10px;font-size:1.5rem;color:#c8d6e6;max-width:520px;}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;}

/* ---------- フッター（白基調・モックアップ準拠） ---------- */
.site-footer{position:relative;overflow:hidden;padding-top:12px;background:#fff;color:var(--ink);}
/* 装飾：右下に「地平線へ続く道」を薄く透かす（文字の可読性を保つため左側はマスクで消す） */
.footer-bg{
  position:absolute;right:0;bottom:0;z-index:0;
  width:min(900px,68%);height:auto;
  opacity:.5;pointer-events:none;user-select:none;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 42%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 42%);
}
/* フッターの中身は装飾画像より前面に置く */
.site-footer>.container{position:relative;z-index:1;}
.footer-top{display:grid;grid-template-columns:1.1fr 2fr;gap:40px;padding:36px 0 24px;}
.brand--footer{display:inline-flex;}
.footer-addr{margin-top:16px;font-size:1.3rem;line-height:1.9;color:#3c3f44;}
.footer-nav{display:grid;grid-template-columns:repeat(4,max-content);gap:34px;justify-content:start;}
.footer-col-h{font-size:1.4rem;font-weight:800;color:var(--head);margin-bottom:12px;}
.footer-col-h a:hover{color:var(--blue);}
.footer-col ul li{margin-bottom:4px;}
.footer-col ul a{font-size:1.25rem;font-weight:600;color:#33363c;transition:.15s;}
.footer-col ul a:hover{color:var(--blue);}
/* 規約バー：全幅のグレー帯をやめ、フッターのコンテナ内に取り込む */
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 0;flex-wrap:wrap;border-top:1px solid var(--line);}
.footer-legal{display:flex;flex-wrap:wrap;gap:18px;}
.footer-legal a{font-size:1.2rem;color:var(--muted);}
.footer-legal a:hover{color:var(--blue);}
.copyright{font-size:1.15rem;color:#9aa3ad;}

/* ================= レスポンシブ ================= */
@media (max-width:1200px){
  .biz-grid{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:480px){
  /* スマホ幅では横並びだと文字が小さくなりすぎるため、ここで初めて縦積みにする */
  .hero-actions{grid-template-columns:1fr;width:100%;max-width:340px;}
  .hero-actions .btn{font-size:1.5rem;padding:15px 20px;}
}
@media (max-width:920px){
  .gnav>ul,.gnav-contact{display:none;}
  /* 右寄せの押し出しは gnav ではなくトグル自身に持たせ、開閉（メニュー固定配置）で位置がずれないようにする */
  .gnav{margin-left:0;}
  .nav-toggle{display:flex;margin-left:auto;}
  .header-contact{display:none;}
  /* backdrop-filter があると position:fixed の基準枠がヘッダーになり、開いたメニューが潰れるため無効化 */
  .site-header{-webkit-backdrop-filter:none;backdrop-filter:none;}
  /* モバイルメニュー展開 */
  .gnav.open{display:flex;position:fixed;top:var(--header-h);left:0;right:0;bottom:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:10px 0;overflow:auto;border-top:1px solid var(--line);}
  .gnav.open>ul{display:flex;flex-direction:column;gap:0;width:100%;}
  .gnav.open>ul li{border-bottom:1px solid var(--line);}
  .gnav.open>ul a{display:block;padding:16px 24px;font-size:1.5rem;}
  .gnav.open>ul a::after{display:none;}
  .gnav.open .gnav-contact{display:inline-flex;margin:18px 24px;}
  /* スマホでは絶対配置の重ねを解除し、通常フローに戻す（重なり崩れ防止） */
  main{position:static;}
  .hero{margin-bottom:0;}
  .numbers{position:static;top:auto;margin-top:-40px;padding:0 0 6px;background:#F1F8FE;}
  /* キーナンバー: パネルを縦積みにし、現在｜未来の区切りは上下線に。カードは折り返し */
  .num-panel{flex-direction:column;padding:14px 14px 16px;gap:12px;}
  .num-set--vision{border-left:none;border-top:2px solid #cfdded;padding-top:12px;}
  .num-set--next{border-left:none;border-top:2px solid #cfdded;padding-top:12px;} /* 縦積み時は上に区切り線 */
  .num-set--next .num-card{flex:1 1 100%;} /* カード1枚なので横幅いっぱい */
  .num-row{flex-wrap:wrap;}
  .num-card{flex:1 1 33.33%;border-left:none;padding:8px 10px;}


  /* 成長ビジョン: オーバーレイを解除し縦積み（テキスト→グラフ） */
  .vision-figure{display:flex;flex-direction:column;}
  .vision-textbox{position:static;order:-1;background:#eaf3fb;}
  .vision-pic{order:2;}
  /* モバイルはSP用グラフを全体表示（高さ固定・トリミングを解除） */
  .vision-img{height:auto;object-fit:fill;}
  .vision-textbox-inner{padding:30px 24px 30px;}
  .vision-textbox-inner > *{max-width:none;}
  .hr-grid{grid-template-columns:1fr;gap:28px;align-items:stretch;}
  .recruit-card{min-height:230px;}
  /* 代表メッセージ: 斜めカットを解除し、写真→テキストの縦積み */
  .ceomsg-photo{position:relative;width:100%;height:260px;clip-path:none;}
  .ceomsg-photo-img{width:100%;height:100%;object-position:center top;}
  .ceomsg-inner{display:block;min-height:0;padding-top:34px;padding-bottom:38px;}
  .ceomsg-text{max-width:none;justify-self:stretch;}
  .footer-top{grid-template-columns:1fr;gap:30px;}
  .footer-nav{grid-template-columns:repeat(2,1fr);}
  /* モバイル：道画像が右下の小片になって不自然なので、下端いっぱいに自然比率で敷き、
     フッター背景を画像の空の色に合わせ、上端をフェードで溶け込ませる（シームレス）。
     新画像は上空が濃い青(#77a5c8付近)なので、下半分はその色を保持して継ぎ目を消す */
  .site-footer{background:linear-gradient(180deg,#eaf3fb 0%,#eaf3fb 14%,#7ba7ca 52%,#7ba7ca 100%);}
  .footer-bg{
    left:0;right:0;width:100%;height:auto;opacity:.9;
    -webkit-mask-image:linear-gradient(180deg,transparent 0%,#000 22%);
    mask-image:linear-gradient(180deg,transparent 0%,#000 22%);
  }
}
@media (max-width:620px){
  .section{padding:52px 0;}
  .hero-overlay{background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(255,255,255,.55));}
  .biz-grid{grid-template-columns:repeat(2,1fr);}
  .timeline::before{left:74px;}
  .tl-item{grid-template-columns:60px 1fr;gap:24px;}
  .tl-dot{left:68px;}
  .tl-date b{font-size:2rem;}
  .contact-inner{flex-direction:column;align-items:flex-start;}
  .footer-bottom-inner{flex-direction:column;align-items:flex-start;}
  /* キーナンバー: スマホでは現在も2列にして、拡大した文字が窮屈にならないようにする */

  /* Issue #115: グループネットワークのマーキー。スマホでは左右の送り矢印を隠し、
     ラッパーの左右パディング（矢印用の60px）を詰めてカード表示幅を広げる。
     ※ 矢印は display:none でCSS非表示のみ。DOMからは消さない（自動スクロール/
        ドラッグのJSが #marqueePrev/#marqueeNext を参照するため要素は残す）。 */
  .marquee-nav{display:none;}
  .marquee-wrap{padding:0;}
}

@media (max-width:480px){
  /* Issue #110: トップのスマホ表示細部修正（採用情報・キーナンバー）。
     既存の 920px ルールより後に置き、スマホ幅でのみ上書きする。 */

  /* Issue #117: 採用カードの::beforeを、青フィルターではなく「ごく薄い白」のオーバーレイに変更。
     写真は透けさせつつ、濃紺テキストが乗る左側だけ少し白を濃くして視認性を確保する。 */
  .recruit-card::before{display:block;background:linear-gradient(95deg,rgba(255,255,255,.42) 0%,rgba(255,255,255,.22) 38%,rgba(255,255,255,.06) 62%,transparent 80%);}
  /* 採用: フィルターを外しても濃色テキストが写真上で読めるよう、明るいにじみを最小限付与 */
  .recruit-label,.recruit-h{text-shadow:0 1px 6px rgba(255,255,255,.85);}
  /* 採用テキスト域を広げ、見出しが窮屈に折り返さないようにする */
  .recruit-overlay{max-width:92%;}
  /* 採用見出し: 「地域と社会の未来を、」の行末で「を、」だけが孤立しないよう、
     日本語の途中改行を禁止。収まる字サイズに調整（<br>の2行構成・文言は維持） */
  .recruit-h{word-break:keep-all;font-size:1.7rem;}
  /* 採用ボタン: 「採用サイトを見る →」を途中で折り返さず1行に収める */
  .recruit-btn{white-space:nowrap;}

  /* キーナンバー: ボタン群と数値ブロックが詰まるため、負マージンをやめて余白を確保 */
  .numbers{margin-top:16px;}
  /* キーナンバー: 「売上高（2027年）」等が「2027」「年）」で割れるため、（年）部分を別行に表示 */
  .num-label-sub{display:block;}
}

/* ================================================================
   下層ページ：TARSKについて（about.html）
   トップと同じパレット・トークンを流用。固有要素のみ追加。
   ================================================================ */

/* 下層ページの本文幅をヘッダー（max-width:1280px）に合わせて左端を揃える。
   トップの container--wide（1480px）はそのまま。下層だけ内側に寄せ、
   見出し・パンくず・本文が左に張り出して「詰まって」見えるのを防ぐ。
   body.subpage を付けたページ（about.html / history.html）のみ適用。 */
body.subpage .container--wide{max-width:1280px;}

/* ---------- 下層ページ共通：ページヘッダー（タイトル帯） ---------- */
.page-hero{
  position:relative;background:linear-gradient(105deg,#f4f9fe 0%,#e6f1fd 58%,#d6e8fb 100%);
  color:var(--ink);padding:96px 0 84px;overflow:hidden;
}
/* シティスケープ画像を右側に敷く（モックアップ準拠）。絶対配置のためCLSは発生しない */
.page-hero-media{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center 55%;}
/* 左のテキスト域を明るい背景色で覆い、右へ向けて透明にして画像を見せる。暗いスクリムは廃止し、濃色テキストの可読性を確保する */
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,#f4f9fe 0%,#f1f8fe 30%,rgba(238,245,251,.9) 46%,rgba(230,242,252,.5) 60%,rgba(224,238,251,.12) 80%,rgba(224,238,251,0) 100%);
}
.page-hero-inner{position:relative;z-index:2;}
/* スマホ幅：画像が文字に重なっても濃色テキストが読めるよう明るい被せを強める */
@media (max-width:620px){
  .page-hero{padding:60px 0 48px;}
  .page-hero::before{background:linear-gradient(160deg,#f4f9fe 0%,rgba(241,248,254,.94) 55%,rgba(230,242,252,.72) 100%);}
  .page-hero-media{object-position:center center;}
}
.page-hero-en{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:.22em;color:var(--blue);text-transform:uppercase;margin-bottom:10px;}
.page-hero-title{font-family:var(--serif);font-size:clamp(2.6rem,3.4vw,4rem);font-weight:700;letter-spacing:.06em;line-height:1.3;color:var(--head);}
.page-hero-lead{margin-top:16px;font-size:1.5rem;line-height:1.9;color:#4a5663;max-width:680px;}

/* パンくず */
.breadcrumb{background:#eef5fb;border-bottom:1px solid var(--line);}
.breadcrumb ol{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:11px 0;font-size:1.25rem;color:var(--muted);}
.breadcrumb li{display:inline-flex;align-items:center;gap:8px;}
.breadcrumb li:not(:last-child)::after{content:"›";color:#b3bdc8;}
.breadcrumb a{color:var(--blue);font-weight:700;}
.breadcrumb a:hover{text-decoration:underline;}
.breadcrumb [aria-current="page"]{color:var(--ink);font-weight:700;}

/* 下層セクション共通：左寄せの見出し＋英字ラベル */
.about-sec{padding:64px 0;}
.about-sec:nth-of-type(even){background:#F1F8FE;}
.about-head{margin-bottom:30px;}
.about-en{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:.2em;color:var(--blue);text-transform:uppercase;margin-bottom:8px;}
.about-title{font-size:clamp(2.2rem,2.6vw,3rem);font-weight:800;color:var(--head);letter-spacing:.04em;}
.about-title .ja-sub{display:block;margin-top:10px;font-family:var(--serif);font-size:clamp(1.6rem,1.9vw,2rem);font-weight:700;color:var(--navy);letter-spacing:.04em;}
.about-body{color:#33414f;font-size:1.6rem;line-height:2.05;max-width:860px;}
.about-body p+p{margin-top:18px;}

/* 仮テキスト注記（受領待ち）：トップの .dummy-note を踏襲しつつ、ブロック用も用意 */
.todo-note{display:inline-block;margin-left:8px;padding:2px 8px;font-size:1.1rem;font-weight:700;color:#fff;background:#c0392b;border-radius:3px;letter-spacing:.02em;vertical-align:middle;}
.todo-block{margin-top:18px;padding:14px 16px;background:#fff5f4;border:1px dashed #e2a39c;border-radius:4px;color:#9c3027;font-size:1.25rem;line-height:1.7;}
.todo-block b{color:#7d231c;}

/* ---------- 代表メッセージ（写真＋本文・フル版） ---------- */
.about-message{padding:64px 0;background:linear-gradient(100deg,#ffffff 0%,#eef5fb 52%,#dbe9f6 100%);}
.about-message-grid{display:grid;grid-template-columns:38% 1fr;gap:0;align-items:stretch;}
.about-message-photo{position:relative;min-height:520px;background:linear-gradient(155deg,#d3e4f5,#8fb4d8);}
.about-message-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;}
.about-message-photo .todo-tag{position:absolute;left:12px;top:12px;z-index:2;}
.about-message-text{padding:60px clamp(24px,4vw,64px);}
.about-message-catch{font-family:var(--serif);font-size:clamp(2rem,2.4vw,2.8rem);font-weight:700;color:var(--head);letter-spacing:.05em;line-height:1.5;margin:6px 0 26px;}
.about-message-body{color:#33414f;font-size:1.6rem;line-height:2.1;}
.about-message-body p+p{margin-top:20px;}
.about-message-sign{font-family:var(--serif);color:var(--navy);font-size:1.4rem;margin-top:30px;}
.about-message-sign strong{display:inline-block;font-size:2.2rem;font-weight:700;letter-spacing:.06em;margin-left:6px;}
/* 成長ビジョン：写真なし・本文のみの1カラム版（#message・#134） */
.about-message--text{padding:clamp(48px,7vw,72px) 0;}
.about-message--text .about-message-body{max-width:860px;margin:0 auto;}

/* ---------- 2カラム共通レイアウト（本文＋サイド） ---------- */
.about-split{display:grid;grid-template-columns:1fr .82fr;gap:clamp(28px,4vw,52px);align-items:start;}
.about-split .about-body{max-width:none;}

/* ---------- 私たちの原点：サイドの引用カード（ネイビー・大きめ） ---------- */
.origin-aside{position:relative;align-self:start;color:#fff;border-radius:6px;padding:80px 34px;box-shadow:var(--shadow);overflow:hidden;background:url("../../img/origin-spirit-bg.webp") top center/cover no-repeat;}
.origin-aside .label{display:block;position:relative;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.2em;color:#9cc6f0;margin-bottom:16px;text-transform:uppercase;text-shadow:0 1px 10px rgba(0,0,0,.45);}
.origin-aside p{position:relative;font-family:var(--serif);font-size:clamp(1.6rem,1.7vw,1.9rem);font-weight:900;line-height:1.95;letter-spacing:.02em;text-shadow:0 1px 14px rgba(0,0,0,.55);}
.origin-aside cite{display:block;position:relative;margin-top:16px;font-style:normal;font-size:1.45rem;color:#bcd6ef;font-weight:700;text-shadow:0 1px 10px rgba(0,0,0,.5);}

/* ---------- 私たちの原点：変化の年表（4ステップ） ---------- */
.evolution{margin-top:clamp(40px,5vw,60px);}
.evolution-head{font-size:1.5rem;font-weight:800;color:var(--navy);letter-spacing:.04em;margin-bottom:26px;display:flex;align-items:center;gap:10px;}
.evolution-head::before{content:"";width:5px;height:18px;border-radius:2px;background:var(--blue);}
.evo-steps{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:8px;}
/* 全ステップを貫く1本の連続コネクター線（最初のドットから右端まで） */
.evo-steps::before{content:"";position:absolute;top:5.5px;left:14px;right:6px;height:2px;background:var(--blue);z-index:0;}
/* 04の先へ突き抜ける矢印（→）。未来へ続く発展の含み */
.evo-steps::after{content:"";position:absolute;top:2.5px;right:-2px;width:0;height:0;border-left:8px solid var(--blue);border-top:4px solid transparent;border-bottom:4px solid transparent;z-index:0;}
.evo-step{position:relative;padding:30px 14px 0;text-align:left;}
/* ステップ位置を示すドット（番号の位置＝左基準でコネクター上に並ぶ） */
.evo-step::before{content:"";position:absolute;top:0;left:14px;width:13px;height:13px;border-radius:50%;background:#fff;border:2px solid var(--blue);z-index:1;}
.evo-num{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:3.2rem;line-height:1;letter-spacing:.02em;color:#9ec5ec;margin-bottom:12px;}
.evo-title{font-size:1.5rem;font-weight:800;color:var(--navy);margin-bottom:9px;line-height:1.4;}
.evo-text{font-size:1.35rem;color:var(--muted);line-height:1.7;}

/* ---------- 企業理念：大きな言い切り ---------- */
.philosophy-grid{display:flex;flex-direction:column;align-items:flex-start;gap:clamp(20px,2.4vw,30px);max-width:600px;}
.philosophy-statement .label{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:.2em;color:var(--blue);margin-bottom:20px;text-transform:uppercase;}
.philosophy-statement h3{font-family:var(--serif);font-size:clamp(2.5rem,3.3vw,4rem);font-weight:700;color:var(--head);line-height:1.55;letter-spacing:.04em;}
.philosophy-statement h3 em{font-style:normal;color:var(--blue);}
.philosophy-support{background:rgba(255,255,255,.9);border:2px solid var(--card-line);border-radius:6px;padding:26px 30px;box-shadow:var(--shadow-sm);backdrop-filter:blur(2px);}
.philosophy-support p{color:#26333f;font-size:1.5rem;line-height:1.95;}

/* 企業理念：背景一枚絵＋重ねテキスト（安全な交通社会・子どもの笑顔 / #86・#97） */
/* テキストは上部の空、子どもたちは下部に完全表示されるよう高さを確保し上揃え */
#philosophy{position:relative;display:flex;align-items:flex-start;padding:clamp(52px,7vw,92px) 0 clamp(280px,30vw,360px);min-height:clamp(560px,52vw,820px);background:#cfe3f4 url("../../img/about-philosophy-bg.webp") center top/cover no-repeat;}
/* ライトスクリム：上部のテキスト帯だけ白を薄く重ね、画像の明るさは保ちつつ可読性を底上げ（#97 ダークグラデ廃止） */
#philosophy::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.82) 0%,rgba(255,255,255,.56) 22%,rgba(255,255,255,.14) 42%,rgba(255,255,255,0) 58%);pointer-events:none;}
#philosophy>.container{position:relative;z-index:1;width:100%;}
/* 明るい背景に合わせ、重ねテキストは濃色へ（#97：視認性確保） */
#philosophy .about-en{color:var(--blue);}
#philosophy .about-title{color:var(--head);}
#philosophy .philosophy-statement .label{color:var(--blue);}
#philosophy .philosophy-statement h3{color:var(--head);}
#philosophy .philosophy-statement h3 em{color:var(--blue);}

/* ---------- 行動指針（円形アイコン＋説明の横レイアウト） ---------- */
.creed-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px;}
.creed-card{display:flex;align-items:center;gap:22px;background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm);}
.creed-icon{flex:0 0 auto;width:84px;height:84px;display:block;}
.creed-body{min-width:0;}
.creed-card h3{font-family:var(--serif);font-size:1.9rem;font-weight:700;color:var(--head);letter-spacing:.05em;margin-bottom:8px;}
.creed-card p{font-size:1.45rem;color:#56606c;line-height:1.8;}

/* ---------- 会社情報（定義テーブル） ---------- */
.company-table{width:100%;max-width:860px;border-collapse:collapse;background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);overflow:hidden;}
.company-table th,.company-table td{text-align:left;padding:16px 22px;border-bottom:1px solid var(--line);font-size:1.5rem;line-height:1.8;vertical-align:top;}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:0;}
.company-table th{width:200px;background:#eef5fb;color:var(--navy);font-weight:800;white-space:nowrap;}
.company-table td{color:#33414f;}
.company-map{margin-top:18px;font-size:1.3rem;}
.company-map a{color:var(--blue);font-weight:700;}
.company-map a:hover{text-decoration:underline;}

/* ---------- about：セクション補強画像（帯＋キャプション） ---------- */
.about-figure{position:relative;margin:clamp(36px,5vw,56px) 0 0;border-radius:6px;overflow:hidden;box-shadow:var(--shadow);}
.about-figure img{display:block;width:100%;height:auto;}
.about-figure figcaption{position:absolute;left:0;right:0;bottom:0;padding:22px clamp(20px,3vw,34px);font-family:var(--serif);font-size:clamp(1.5rem,1.9vw,2rem);font-weight:700;color:#fff;letter-spacing:.04em;background:linear-gradient(0deg,rgba(8,24,44,.72),rgba(8,24,44,0));}

/* ---------- about：会社情報のグループ事業領域ストリップ ---------- */
.biz-strip{margin-top:clamp(28px,4vw,40px);max-width:860px;}
.biz-strip-head{font-size:1.5rem;font-weight:800;color:var(--navy);letter-spacing:.04em;margin-bottom:18px;display:flex;align-items:center;gap:10px;}
.biz-strip-head::before{content:"";width:5px;height:18px;border-radius:2px;background:var(--blue);}
.biz-strip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;list-style:none;margin:0;padding:0;}
.biz-strip-item{position:relative;border-radius:6px;overflow:hidden;box-shadow:var(--shadow-sm);aspect-ratio:3/2;}
.biz-strip-item img{width:100%;height:100%;object-fit:cover;display:block;}
.biz-strip-item span{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:.03em;line-height:1.4;background:linear-gradient(0deg,rgba(8,24,44,.78),rgba(8,24,44,0));}

/* ---------- 下層ページのレスポンシブ ---------- */
@media (max-width:920px){
  .about-message-grid{grid-template-columns:1fr;}
  .about-message-photo{min-height:300px;}
  .about-message-text{padding:40px 24px 48px;}
  .creed-grid{grid-template-columns:1fr;}
  .company-table th{width:130px;padding:14px 14px;}
  .company-table td{padding:14px 14px;}
  /* 2カラム→縦積み */
  .about-split{grid-template-columns:1fr;gap:28px;}
  /* 企業理念：スマホは横幅いっぱいに縦積み。子どもが下に収まるよう余白を確保 */
  .philosophy-grid{max-width:none;}
  #philosophy{padding:clamp(40px,8vw,64px) 0 clamp(320px,86vw,430px);min-height:auto;}
  /* 企業理念：スマホは上部スクリムをやや強め、明るさは保ちつつ可読性を確保（#97） */
  #philosophy::before{background:linear-gradient(180deg,rgba(255,255,255,.9) 0%,rgba(255,255,255,.64) 30%,rgba(255,255,255,.18) 52%,rgba(255,255,255,0) 72%);}
  /* 年表：4列→2列。横一直線が成立しないのでコネクターとドットは隠す */
  .evo-steps{grid-template-columns:repeat(2,1fr);gap:28px 8px;}
  .evo-step{padding-top:0;}
  .evo-step::before,.evo-steps::before,.evo-steps::after{display:none;}
  /* 事業領域ストリップ：3列→2列 */
  .biz-strip-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:560px){
  .evo-steps{grid-template-columns:1fr;}
  .about-figure figcaption{padding:14px 16px;}
}

/* ================================================================
   下層ページ：沿革（history.html）
   driver.co.jp/history 風：左にリード（スクロール追従）＋右に年グルーピングの
   タイムライン。WordPress化時は archive-history.php の出力へ同じクラスを当てる。
   トップの news-list / 旧 .tl-* とは別系統の「年大字＋ノード」スタイル。
   ================================================================ */
.history-page{background:#fff;padding:clamp(48px,6vw,76px) 0;}
/* 2カラム：左リード（追従）＋右タイムライン */
.hist-layout{display:grid;grid-template-columns:minmax(220px,300px) 1fr;gap:clamp(32px,5vw,68px);align-items:start;}

/* ---------- 左：リード（スクロール追従） ---------- */
.hist-lead{position:sticky;top:calc(var(--header-h) + 28px);}
.hist-lead-en{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:.2em;color:var(--blue);text-transform:uppercase;margin-bottom:14px;}
.hist-lead-title{font-family:var(--serif);font-size:clamp(2.2rem,2.6vw,2.5rem);font-weight:700;color:var(--head);line-height:1.5;letter-spacing:.04em;margin-bottom:22px;word-break:keep-all;}
.hist-lead-body p{color:#44525f;font-size:1.5rem;line-height:2.0;}
.hist-lead-body p+p{margin-top:16px;}

/* ---------- 右：タイムライン本体（縦ライン） ---------- */
.hist-timeline{position:relative;}
/* 年ノードの中心に合わせた縦ライン */
.hist-timeline::before{content:"";position:absolute;top:10px;bottom:10px;left:7px;width:2px;background:#cdd9e6;}

/* 年グループ（＝同じ年の出来事のまとまり / WordPress: 年メタでグルーピング） */
.hist-year{position:relative;padding:0 0 clamp(34px,4vw,48px) 34px;}
.hist-year:last-child{padding-bottom:0;}
/* 年ノード（○） */
.hist-year::before{content:"";position:absolute;left:0;top:9px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--blue);box-shadow:0 0 0 4px #fff;z-index:1;}
/* 年見出し（西暦・大きく青字＋【和暦】） */
.hist-year-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:18px;}
.hist-year-num{font-family:"Roboto Condensed","Roboto","Helvetica Neue",Arial,sans-serif;font-size:clamp(3rem,4vw,4.2rem);font-weight:800;color:var(--head);line-height:1;letter-spacing:.02em;font-variant-numeric:tabular-nums;}
.hist-wareki{font-size:1.6rem;font-weight:700;color:var(--muted);}

/* ---------- 出来事リスト（1出来事＝1投稿） ---------- */
.hist-events{display:flex;flex-direction:column;gap:22px;}
.hist-event-head{display:flex;align-items:baseline;gap:14px;}
.hist-month{flex:0 0 auto;min-width:42px;font-weight:800;color:var(--blue);font-size:1.6rem;font-variant-numeric:tabular-nums;}
.hist-event-title{font-size:1.8rem;font-weight:700;color:var(--navy);line-height:1.6;}
/* 任意：画像（見出しの下） */
.hist-img{margin-top:12px;border-radius:6px;overflow:hidden;border:1px solid var(--card-line);max-width:520px;}
.hist-img img{width:100%;height:auto;}
/* 画像プレースホルダ（静的版・実画像が来るまでの仮枠。実画像が入れば .hist-img に差し替え） */
.hist-img-ph{margin-top:12px;max-width:520px;aspect-ratio:16/9;border-radius:6px;border:1px dashed #b9c9da;background:repeating-linear-gradient(135deg,#eef5fb,#eef5fb 12px,#e4eef8 12px,#e4eef8 24px);display:flex;align-items:center;justify-content:center;color:#6f8094;font-size:1.25rem;font-weight:700;text-align:center;padding:10px;}
/* 任意：本文（画像の下にインライン。無ければ何も出さない） */
.hist-body{margin-top:12px;color:#44525f;font-size:1.45rem;line-height:1.95;max-width:600px;}
.hist-body p+p{margin-top:10px;}

/* ---------- プライバシーポリシー本文 ---------- */
.privacy-doc{color:#33414f;font-size:1.5rem;line-height:1.95;}
.privacy-doc>p{margin-top:0;}
.privacy-doc h3{margin:32px 0 10px;font-family:var(--serif);font-size:1.8rem;font-weight:700;color:var(--navy);letter-spacing:.03em;}
.privacy-doc h3:first-of-type{margin-top:28px;}
.privacy-list{margin:8px 0 0;padding-left:1.4em;list-style:disc;}
.privacy-list li{margin-top:6px;}
.privacy-contact{margin-top:10px;font-weight:700;color:var(--navy);line-height:1.9;}
.privacy-contact a{color:var(--blue);text-decoration:underline;}
.privacy-contact a:hover{color:var(--blue-d);}

/* ---------- 沿革のレスポンシブ：リード→タイムラインの縦積み（sticky解除） ---------- */
@media (max-width:900px){
  .hist-layout{grid-template-columns:1fr;gap:30px;}
  .hist-lead{position:static;top:auto;}
}
@media (max-width:560px){
  .hist-year{padding-left:28px;}
  .hist-year-num{font-size:3rem;}
  .hist-event-head{flex-direction:column;gap:2px;}
}

/* ================================================================
   下層ページ：お問い合わせ（contact.html）
   トップ／about と同じパレット・トークンを流用。フォーム固有要素のみ追加。
   WordPress では Contact Form 7 が同じクラス構造のマークアップを出力する想定。
   ================================================================ */
/* セクション背景（淡いブルー）。会社情報の再掲を削除したため明示指定する */
.contact-sec{background:#F1F8FE;}

/* 必須／任意バッジ（モックアップ03準拠：白地＋枠線。必須＝赤オレンジ、任意＝グレー） */
.req,.opt{display:inline-block;margin-left:10px;padding:2px 10px;font-size:1.1rem;font-weight:700;line-height:1.5;border-radius:3px;vertical-align:middle;letter-spacing:.02em;background:#fff;}
.req{color:#d8403c;border:1px solid #e6938f;}
.opt{color:var(--muted);border:1px solid var(--line);}

/* フォーム全体（白いカード。左：淡青パネルのラベル＋バッジ／右：白い入力欄） */
.contact-form{background:#fff;border:1px solid var(--card-line);border-radius:10px;box-shadow:var(--shadow-sm);padding:clamp(20px,2.4vw,32px);}
.form-row{display:grid;grid-template-columns:clamp(200px,26%,300px) 1fr;gap:0 28px;align-items:stretch;border-top:1px solid var(--line);}
.form-row:first-child{border-top:0;}
/* ラベル列＝淡青の連続パネル。行をまたいで一続きに見せる */
.form-label{display:flex;align-items:center;flex-wrap:wrap;font-size:1.5rem;font-weight:800;color:var(--navy);line-height:1.6;background:#F2F7FD;padding:18px 18px;}
.form-row:first-child .form-label{border-radius:6px 6px 0 0;}
.form-row:last-of-type .form-label{border-radius:0 0 6px 6px;}
.form-row--privacy .form-label{align-items:flex-start;}
.form-field{min-width:0;display:flex;flex-direction:column;justify-content:center;padding:14px 0;}
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea{
  width:100%;font-family:inherit;font-size:1.5rem;line-height:1.7;color:var(--ink);
  background:#fff;border:1.5px solid var(--line);border-radius:var(--radius);
  padding:12px 14px;transition:border-color .15s,box-shadow .15s;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(6,111,200,.14);}
.contact-form textarea{resize:vertical;min-height:160px;}
.contact-form input::placeholder,
.contact-form textarea::placeholder{color:#a6adb6;}

/* CF7 のラッパー対応：入力欄を form-field いっぱいに広げる
   （CF7 は各入力を span.wpcf7-form-control-wrap で包む。既定では inline のため幅が出ない） */
.contact-form .form-field>.wpcf7-form-control-wrap{display:block;}

/* 個人情報保護方針：約8行・内部スクロールのボックス＋同意チェック */
.privacy-box{
  height:18.4em;overflow-y:auto;background:var(--soft);border:1.5px solid var(--line);
  border-radius:var(--radius);padding:16px 18px;font-size:1.3rem;line-height:1.85;color:#44525f;
}
.privacy-box:focus{outline:2px solid var(--blue);outline-offset:2px;}
.privacy-box h3{font-size:1.45rem;font-weight:800;color:var(--head);margin-bottom:10px;}
.privacy-box h4{font-size:1.3rem;font-weight:800;color:var(--navy);margin:14px 0 4px;}
.privacy-box p{margin:0;}
.privacy-box ul{list-style:disc;margin:4px 0;padding-left:1.4em;}
.privacy-box li{margin-bottom:2px;}
.privacy-consent{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:1.45rem;font-weight:700;color:var(--navy);cursor:pointer;}
.privacy-consent label{display:flex;align-items:center;gap:10px;margin:0;cursor:pointer;}
/* CF7 の acceptance（同意チェック）出力に合わせる
   （CF7 は input をネストした span/label で出力するため、内側の label を整える） */
.privacy-consent .wpcf7-form-control-wrap,
.privacy-consent .wpcf7-acceptance,
.privacy-consent .wpcf7-list-item{display:inline-flex;margin:0;}
.privacy-consent input[type="checkbox"]{width:20px;height:20px;flex:0 0 auto;accent-color:var(--blue);cursor:pointer;}

/* 送信ボタン（モックアップ準拠：濃い青・幅広・右側にシェブロン矢印） */
.form-submit{margin-top:32px;text-align:center;}
.form-submit .btn{min-width:min(460px,100%);padding:16px 54px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='9 6 15 12 9 18'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 24px center;background-size:16px 16px;}

/* Contact Form 7 のバリデーション表示（WordPress 稼働時に CF7 が付与するクラス） */
.contact-form .wpcf7-not-valid-tip{display:block;margin-top:6px;color:#c0392b;font-size:1.25rem;font-weight:700;}
.contact-form .wpcf7-not-valid{border-color:#c0392b !important;}
.wpcf7-response-output{margin:24px auto 0;max-width:860px;padding:14px 18px;border-radius:var(--radius);font-size:1.4rem;line-height:1.7;}

/* お問い合わせページのレスポンシブ（スマホ：縦積み。ラベルは淡青の帯） */
@media (max-width:680px){
  .form-row{grid-template-columns:1fr;gap:8px 0;padding:14px 0;}
  .form-label{padding:8px 12px;border-radius:6px;}
  .form-row:first-child .form-label,
  .form-row:last-of-type .form-label{border-radius:6px;}
  .form-field{padding:0;}
  .form-submit .btn{min-width:0;width:100%;padding:15px 20px;background-position:right 18px center;}
}

/* ================================================================
   下層ページ：成長ビジョン（vision.html / page-vision.php）
   about の共通トークン（.about-sec / .about-head / .num-panel 等）を流用し、
   ビジョン固有要素（グラフ・マイルストーン・4本柱・CTA）のみ追加。
   ================================================================ */

/* 成長グラフ */
.vision-graph{margin:0 0 clamp(24px,3vw,36px);border-radius:6px;overflow:hidden;box-shadow:var(--shadow);}
.vision-graph img{display:block;width:100%;height:auto;}

/* マイルストーン（現在＝実績 → 目標 を3枚で表現） */
.vision-milestones{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.vm-card{background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);padding:24px 20px;text-align:center;box-shadow:var(--shadow-sm);}
.vm-year{display:block;font-size:1.35rem;font-weight:700;color:var(--muted);letter-spacing:.03em;margin-bottom:10px;}
.vm-value{display:block;font-family:"Roboto Condensed","Roboto","Helvetica Neue",Arial,sans-serif;font-weight:600;color:#6a87a8;font-size:clamp(3rem,4vw,4.4rem);line-height:1;letter-spacing:.01em;}
.vm-value .unit{font-family:"Helvetica Neue",Arial,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;font-size:1.5rem;font-weight:700;margin-left:4px;}
.vm-card--target .vm-value,.vm-card--target .vm-value .unit{color:var(--blue);}
.vm-tag{display:inline-block;margin-top:14px;padding:3px 14px;font-size:1.2rem;font-weight:700;border-radius:999px;letter-spacing:.04em;}
.vm-tag--actual{background:#e7f3ee;color:#1f7a5c;}
.vm-tag--target{background:#e8f1fc;color:var(--blue);}

/* 成長を支える4本柱 */
.pillar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px;}
.pillar-card{position:relative;background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow-sm);}
.pillar-num{display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.6rem;letter-spacing:.14em;color:var(--blue);margin-bottom:12px;}
.pillar-title{font-family:var(--serif);font-size:1.8rem;font-weight:700;color:var(--head);letter-spacing:.03em;line-height:1.45;margin-bottom:12px;}
.pillar-text{font-size:1.35rem;color:#56606c;line-height:1.85;}

/* お問い合わせ誘導バンド */
.vision-cta{background:linear-gradient(100deg,#0c223b 0%,#143a64 100%);color:#fff;padding:clamp(40px,5vw,64px) 0;}
.vision-cta-inner{text-align:center;}
.vision-cta-title{font-family:var(--serif);font-size:clamp(2rem,2.6vw,2.8rem);font-weight:700;letter-spacing:.05em;line-height:1.6;}
.vision-cta-lead{margin-top:14px;font-size:1.5rem;line-height:1.9;color:#cddcec;}
.vision-cta .btn{margin-top:26px;}

/* 売上高の推移：部門別 積み上げ棒グラフ（100億宣言 P2 準拠） */
.rev-chart-fig{margin:0 0 clamp(24px,3vw,36px);}
.rev-chart-img{display:block;width:100%;height:auto;}
.rev-caption{margin-top:14px;font-size:1.25rem;color:var(--muted);line-height:1.7;}

/* 目標と課題／具体的措置：左右2カラム */
.vision-2col{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2vw,24px);}
.v2-card{background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);padding:clamp(24px,3vw,34px);box-shadow:var(--shadow-sm);background-size:cover;background-position:center;background-repeat:no-repeat;}
/* 4カード：内容に即したうっすら背景画像。白オーバーレイで文字の可読性を最優先（#134） */
.v2-card--goal{background-image:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.4)),url("../../img/vision-cards/vision-card-goal.webp");}
.v2-card--issue{border-color:#e2e7ee;background-image:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.4)),url("../../img/vision-cards/vision-card-issue.webp");}
.v2-card--means{background-image:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.4)),url("../../img/vision-cards/vision-card-means.webp");}
.v2-card--system{background-image:linear-gradient(rgba(255,255,255,.6),rgba(255,255,255,.4)),url("../../img/vision-cards/vision-card-system.webp");}
.v2-head{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:clamp(1.8rem,2.1vw,2.2rem);font-weight:700;color:var(--head);letter-spacing:.03em;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line);}
.v2-ico-img{width:40px;height:40px;flex:0 0 auto;object-fit:contain;}
.v2-list{display:flex;flex-direction:column;gap:8px;}
.v2-list li{position:relative;padding-left:26px;font-size:1.45rem;line-height:1.6;color:#3a4654;}
.v2-list li::before{content:"";position:absolute;left:4px;top:.7em;width:8px;height:8px;border-radius:50%;background:var(--blue);}
.v2-card--issue .v2-list li::before{background:var(--gold);}
.v2-card--system .v2-list li::before{background:var(--head);}

/* グループ構成図：ラベルを上辺に乗せた囲み枠線（カード増減・モバイル幅に自動追従・#134） */
.group-chart{position:relative;}
.group-holder{position:absolute;top:0;left:50%;transform:translate(-50%,-50%);z-index:2;width:max-content;max-width:calc(100% - 32px);background:linear-gradient(135deg,#03317B,#066FC8);color:#fff;border-radius:6px;padding:13px 30px;text-align:center;box-shadow:var(--shadow-sm);}
.group-holder-name{display:block;font-weight:800;font-size:clamp(1.6rem,2vw,2rem);letter-spacing:.03em;line-height:1.4;}
.group-holder-role{display:block;margin-top:4px;font-size:1.2rem;color:#cfe2f6;letter-spacing:.06em;}
.group-subs{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%;border:2px solid var(--card-line);border-radius:10px;padding:clamp(40px,5vw,52px) clamp(16px,2.5vw,26px) clamp(22px,3vw,30px);}
.group-node{background:#fff;border:2px solid var(--card-line);border-radius:var(--radius);padding:18px 16px;text-align:center;box-shadow:var(--shadow-sm);}
.group-node-name{display:block;font-weight:700;font-size:1.45rem;color:var(--navy);letter-spacing:.02em;line-height:1.5;}
.group-node-role{display:block;margin-top:6px;font-size:1.2rem;color:var(--muted);}
.group-link{text-align:center;margin-top:26px;}

/* 成長ビジョン：レスポンシブ（スマホ幅で縦積み） */
@media (max-width:920px){
  .vision-milestones{grid-template-columns:1fr;}
  .pillar-grid{grid-template-columns:1fr;}
  .vision-cta-title br{display:none;}
  .vision-2col{grid-template-columns:1fr;}
  .group-subs{grid-template-columns:1fr 1fr;}
}

/* アクセシビリティ: モーション抑制 */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .marquee-track{transform:none !important;}
}

/* ================================================================
   下層ページ：事業紹介（business.html / page-business.php）
   about/vision の共通トークン（.page-hero / .breadcrumb / .section 等）を流用し、
   事業セクション固有要素（事業概要・担う会社カード）のみ追加。
   事業ごとのテーマ色は --biz（トップ #business と完全一致）で切り替える。
   ================================================================ */

/* イントロ（グループ事業の全体像） */
.biz-intro{background:#fff;padding:clamp(40px,5vw,60px) 0;}
.biz-intro .sec-lead{max-width:840px;}

/* 6事業のクイックナビ（アンカー行・モックアップ準拠／各事業の縦セクションへページ内ジャンプ） */
.biz-anchors{background:#fff;border-top:1px solid var(--card-line);border-bottom:1px solid var(--card-line);padding:18px 0 22px;}
.biz-anchor-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;}
.biz-anchor{--biz:var(--blue);display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:16px 8px;border:1px solid var(--card-line);border-radius:6px;background:#fff;box-shadow:var(--shadow-sm);transition:.18s;}
.biz-anchor:hover{border-color:var(--biz);transform:translateY(-3px);box-shadow:var(--shadow);}
.biz-anchor-ico{width:48px;height:48px;object-fit:contain;}
.biz-anchor-num{font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.1rem;letter-spacing:.14em;color:var(--biz);}
.biz-anchor-label{font-size:1.25rem;font-weight:800;color:var(--navy);line-height:1.35;}
.biz-anchor--driving{--biz:#1769b4;}
.biz-anchor--realestate{--biz:#2e8b57;}
.biz-anchor--construction{--biz:#bf7d2a;}
.biz-anchor--stayfood{--biz:#e0892a;}
.biz-anchor--insurance{--biz:#0e8a82;}
.biz-anchor--dx{--biz:#5b6fd0;}

/* 事業セクション（交互背景・--biz でアクセント色を切替） */
.biz-sec{padding:clamp(48px,6vw,72px) 0;--biz:var(--blue);scroll-margin-top:calc(var(--header-h) + 12px);}
.biz-sec:nth-of-type(even){background:#F1F8FE;}
.biz-sec--driving{--biz:#1769b4;}
.biz-sec--realestate{--biz:#2e8b57;}
.biz-sec--construction{--biz:#bf7d2a;}
.biz-sec--stayfood{--biz:#e0892a;}
.biz-sec--insurance{--biz:#0e8a82;}
.biz-sec--dx{--biz:#5b6fd0;}

/* 見出し：大きな番号（01〜06）＋英字ラベル＋日本語タイトル（モックアップ準拠） */
.biz-sec-head{display:grid;grid-template-columns:auto 1fr;align-items:center;column-gap:clamp(14px,2vw,24px);margin-bottom:26px;}
.biz-sec-num{grid-row:1 / span 2;font-family:"Roboto Condensed","Roboto","Helvetica Neue",Arial,sans-serif;font-weight:800;font-size:clamp(4.6rem,6.4vw,6.8rem);line-height:.86;color:var(--biz);opacity:.2;letter-spacing:.01em;}
.biz-sec-en{grid-column:2;display:block;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.2rem;letter-spacing:.2em;color:var(--biz);text-transform:uppercase;margin-bottom:8px;}
.biz-sec-title{grid-column:2;display:flex;align-items:center;gap:12px;font-size:clamp(2.2rem,2.6vw,3rem);font-weight:800;color:var(--head);letter-spacing:.04em;line-height:1.3;}
.biz-sec-title::before{content:"";flex:0 0 auto;width:6px;height:1.1em;border-radius:3px;background:var(--biz);}

/* 概要＋写真（2カラム→スマホ1カラム） */
.biz-overview{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(20px,3vw,40px);align-items:center;}
.biz-overview-text p{font-size:1.5rem;line-height:1.95;color:#3a444f;}
.biz-overview-fig{margin:0;border-radius:8px;overflow:hidden;box-shadow:var(--shadow);}
.biz-overview-fig img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:3/2;}

/* 担うグループ企業・サービス */
.biz-companies{margin-top:clamp(28px,4vw,40px);}
.biz-companies-head{font-size:1.5rem;font-weight:800;color:var(--navy);letter-spacing:.03em;margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.biz-companies-head::before{content:"";width:5px;height:18px;border-radius:2px;background:var(--biz);}
.bizco-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
/* ロゴ＋正式名称カード（カード全体がクリック可。外部の公式サイトへ遷移） */
.bizco-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:118px;text-align:center;background:#fff;border:1px solid var(--card-line);border-radius:6px;padding:22px 16px;box-shadow:var(--shadow-sm);transition:.18s;}
a.bizco-card:hover{transform:translateY(-3px);border-color:var(--biz);box-shadow:var(--shadow);}
.bizco-logo{width:auto;height:auto;max-width:78%;max-height:42px;object-fit:contain;display:block;}
.bizco-name{font-size:1.3rem;font-weight:800;color:var(--navy);line-height:1.4;}
/* リンクのあるカード（a.bizco-card）だけ、名称の右に控えめな「＞」を付ける。placeholder には付かない */
a.bizco-card .bizco-name::after{content:"＞";margin-left:.25em;font-size:.85em;font-weight:700;color:var(--biz);opacity:.7;}

/* 提供サービス（GINGUN が開発・提供する SignDS／SignHR。社名カードに従属する詳細カード。控えめ・上質に） */
.biz-services{margin-top:clamp(18px,2.4vw,24px);}
.biz-services-label{display:flex;align-items:center;gap:10px;font-size:1.35rem;font-weight:800;color:var(--navy);letter-spacing:.03em;margin-bottom:14px;}
.biz-services-label::before{content:"";width:5px;height:18px;border-radius:2px;background:var(--biz);}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.svc-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--card-line);border-radius:6px;box-shadow:var(--shadow-sm);padding:20px 20px 22px;}
.svc-card-head{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 12px;}
.svc-name{font-size:1.7rem;font-weight:800;color:var(--navy);letter-spacing:.02em;}
.svc-cat{font-size:1.2rem;font-weight:700;color:var(--biz);}
.svc-desc{margin-top:10px;font-size:1.3rem;line-height:1.85;color:var(--ink);}
.svc-shot{margin:14px 0 0;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:#f4f7fb;}
.svc-shot img{width:100%;height:auto;display:block;}
.svc-links{margin-top:auto;padding-top:16px;display:flex;flex-wrap:wrap;gap:10px;}
.svc-link{display:inline-flex;align-items:center;gap:6px;font-size:1.2rem;font-weight:700;color:#fff;background:var(--biz);padding:8px 16px;border-radius:999px;transition:.18s;}
.svc-link:hover{opacity:.9;transform:translateY(-1px);}
.svc-link--sub{color:var(--biz);background:transparent;border:1px solid var(--biz);}
.svc-link--sub:hover{background:rgba(91,111,208,.08);opacity:1;transform:translateY(-1px);}
/* 末尾のリンク表現「＞」はbizco-cardに合わせ控えめサイズ。色はボタン文字色（白/サブはbiz色）を継承 */
.svc-link span{font-size:.85em;}

/* 今後グループ加入予定の placeholder カード（建設事業など担当会社が未確定・外部リンク無し） */
.bizco-card--placeholder{flex-direction:row;align-items:center;justify-content:flex-start;gap:16px;text-align:left;grid-column:1 / -1;max-width:640px;border-style:dashed;border-color:var(--biz);cursor:default;padding:20px 22px;}
.bizco-ph-ico{flex:0 0 auto;width:54px;height:54px;color:var(--biz);opacity:.85;}
.bizco-ph-body{display:flex;flex-direction:column;gap:4px;}
.bizco-card--placeholder .bizco-name{font-size:1.45rem;}
.bizco-ph-text{font-size:1.3rem;color:#56606c;line-height:1.8;}

/* 事業紹介：レスポンシブ */
@media (max-width:880px){
  .biz-overview{grid-template-columns:1fr;}
  .bizco-grid{grid-template-columns:repeat(2,1fr);}
  .biz-anchor-grid{grid-template-columns:repeat(3,1fr);}
  .svc-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .bizco-grid{grid-template-columns:1fr;}
  .biz-anchor-grid{grid-template-columns:repeat(2,1fr);gap:8px;}
  .biz-sec-num{font-size:4.2rem;}
}

/* ================================================================
   ページ先頭へ戻る フローティングボタン（全ページ共通・#111）
   現在表示中ページの先頭(#top)へスムーズスクロール。別ページへは遷移しない。
   ヘッダー(z-index:50)より下に置き、モバイルメニュー展開時は隠れるようにする。
   ================================================================ */
.pagetop{
  position:fixed;right:24px;bottom:24px;z-index:40;
  display:flex;align-items:center;justify-content:center;
  width:52px;height:52px;border-radius:50%;
  background:var(--head);color:#fff;text-decoration:none;
  box-shadow:var(--shadow);
  transition:background .2s ease,transform .2s ease,box-shadow .2s ease;
}
.pagetop:hover{background:var(--navy);transform:translateY(-3px);box-shadow:0 18px 40px rgba(12,34,59,.18);}
.pagetop:focus-visible{outline:3px solid var(--blue);outline-offset:3px;}
.pagetop-ico{font-size:2.2rem;line-height:1;font-weight:700;}
@media (max-width:560px){
  .pagetop{right:16px;bottom:16px;width:46px;height:46px;}
  .pagetop-ico{font-size:2rem;}
}

/* ================================================================
   404 ページ（Not Found・#118）
   静的404.html とテーマ404.php で共通利用。白基調＋青アクセントの
   クリーンな中央寄せ構成。共通ヘッダー/フッターはそのまま踏襲する。
   ================================================================ */
.error-sec{background:#fff;padding:96px 0 104px;}
.error-inner{max-width:720px;text-align:center;}
/* 大きな「404」：数字フォント Roboto Condensed、ネイビー〜ブルーのグラデーション */
.error-code{
  font-family:"Roboto Condensed","Roboto","Helvetica Neue",Arial,sans-serif;
  font-weight:800;font-size:clamp(9rem,18vw,16rem);line-height:.9;letter-spacing:.02em;
  color:var(--head);
  background:linear-gradient(180deg,var(--blue) 0%,var(--head) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.error-en{display:block;margin-top:6px;font-family:"Roboto","Helvetica Neue",Arial,sans-serif;font-weight:700;font-size:1.3rem;letter-spacing:.22em;color:var(--blue);text-transform:uppercase;}
.error-title{margin-top:18px;font-family:var(--serif);font-size:clamp(2.2rem,3.4vw,3.2rem);font-weight:700;letter-spacing:.06em;line-height:1.4;color:var(--head);}
.error-lead{margin:18px auto 0;max-width:560px;font-size:1.5rem;line-height:1.95;color:#4a5663;}
.error-actions{margin-top:36px;}
.error-actions .arr{margin-left:2px;}
.error-links{margin:30px auto 0;display:flex;flex-wrap:wrap;justify-content:center;gap:14px 32px;}
.error-links a{display:inline-flex;align-items:center;gap:6px;font-size:1.4rem;font-weight:700;color:var(--blue);transition:.15s;}
.error-links a:hover{color:var(--blue-d);}
.error-links .arr{transition:transform .18s;}
.error-links a:hover .arr{transform:translateX(3px);}
@media (max-width:560px){
  .error-sec{padding:64px 0 76px;}
  .error-links{flex-direction:column;gap:12px;}
}

/* ================================================================
   下層ページ：採用情報（recruit.html / page-recruit.php・#132）
   about/vision の共通トークン（.page-hero / .breadcrumb / .about-sec /
   .about-head / .vision-cta 等）を流用し、採用ページ固有要素
   （大切に思っていること／募集職種カード／採用窓口）のみ追加。
   ================================================================ */

/* 見出しの中央寄せ（採用メッセージ用） */
.about-head--center{text-align:center;}

/* 1. 大切に思っていること（採用メッセージ・落ち着いた中央寄せ） */
.recruit-belief{max-width:780px;margin:0 auto;text-align:center;}
.recruit-belief-line{margin:0;text-align:center;font-family:var(--serif);font-size:clamp(1.9rem,2.3vw,2.4rem);font-weight:700;line-height:2.1;color:var(--head);letter-spacing:.04em;word-break:auto-phrase;}
.recruit-belief-line + .recruit-belief-line{margin-top:clamp(24px,3.4vw,38px);}

/* 2. 募集職種（トップ事業紹介に準拠・表示のみ／リンクなし） */
/* リード文は文節単位で折り返し、「職種」等が語の途中で割れないようにする（word-break:auto-phrase） */
.recruit-jobs-lead{margin-bottom:clamp(28px,3.6vw,38px);font-size:1.6rem;line-height:2;color:#3a444f;word-break:auto-phrase;}
.job-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.job-card{display:flex;flex-direction:column;align-items:stretch;gap:10px;background:#fff;border:1px solid var(--card-line);border-radius:8px;padding:clamp(28px,3vw,34px) 22px;box-shadow:var(--shadow-sm);background-size:cover;background-position:center;background-repeat:no-repeat;}
.job-name{display:block;width:100%;text-align:center;font-size:1.65rem;font-weight:800;color:var(--navy);line-height:1.5;}
.job-icon{display:block;margin:0 auto 14px;width:60px;height:60px;object-fit:contain;}
.job-roles{display:block;width:100%;text-align:center;font-size:1.4rem;font-weight:700;color:#5a6470;line-height:1.75;}
/* 各カードに対応する事業画像をうっすら背景に（白オーバーレイで文字の可読性を最優先・#137） */
.job-driving{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-driving.webp");}
.job-realestate{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-realestate.webp");}
.job-construction{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-construction.webp");}
.job-stayfood{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-stay-food.webp");}
.job-insurance{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-maintenance.webp");}
.job-dx{background-image:linear-gradient(rgba(255,255,255,.86),rgba(255,255,255,.8)),url("../../img/business-dx.webp");}

/* 3. 採用窓口（区切り線飾り＋採用ページリンク） */
.recruit-gate-lead{margin-bottom:clamp(22px,3vw,30px);font-size:1.6rem;line-height:2;color:#3a444f;}
.recruit-gate-list{border-top:1px solid var(--card-line);}
.recruit-gate-row{border-bottom:1px solid var(--card-line);}
.recruit-gate-link{display:flex;align-items:center;gap:clamp(18px,3vw,34px);padding:clamp(22px,2.5vw,28px) 10px;transition:.18s;}
.recruit-gate-link:hover{background:#fff;}
.recruit-gate-logo{flex:0 0 auto;width:auto;height:auto;max-width:190px;max-height:48px;object-fit:contain;}
.recruit-gate-name{flex:1 1 auto;font-size:1.75rem;font-weight:800;color:var(--navy);letter-spacing:.02em;line-height:1.45;}
.recruit-gate-cta{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-size:1.45rem;font-weight:700;color:var(--blue);white-space:nowrap;}
.recruit-gate-cta .arr{transition:transform .18s;}
.recruit-gate-link:hover .recruit-gate-cta{color:var(--blue-d);}
.recruit-gate-link:hover .recruit-gate-cta .arr{transform:translateX(3px);}

/* 4. 採用に関するお問い合わせ */
.recruit-contact-body{max-width:760px;margin:0 auto;text-align:center;}
.recruit-contact-lead{margin-bottom:clamp(20px,2.5vw,28px);font-size:1.6rem;line-height:2.2;color:#3a444f;word-break:auto-phrase;}
.recruit-contact-bridge{margin-bottom:clamp(28px,3.5vw,38px);font-size:1.65rem;line-height:2;color:var(--navy);font-weight:600;}
/* 採用お問い合わせフォーム：contactと同じテイスト（.contact-form を流用）。中央寄せの body 内で左寄せに戻す */
.recruit-contact-body .contact-form{text-align:left;}

/* 採用情報：レスポンシブ */
@media (max-width:880px){
  .job-grid{grid-template-columns:repeat(2,1fr);}
  /* モバイルではPC用<br>を非表示にして文節折り返し（word-break:auto-phrase）に委ねる（#169） */
  .recruit-belief-line br{display:none;}
}
@media (max-width:560px){
  /* スマホでは縦積み・中央寄せにして、左詰まりを解消（タップ領域も確保・#137） */
  .recruit-gate-link{flex-direction:column;align-items:center;text-align:center;gap:12px;padding:24px 10px;}
  .recruit-gate-logo{max-width:170px;max-height:44px;}
  .recruit-gate-name{flex:0 0 auto;width:100%;text-align:center;font-size:1.7rem;}
  .recruit-gate-cta{flex:0 0 auto;justify-content:center;font-size:1.5rem;}
}
