@charset "utf-8";

/*
Theme Name: Lightning Child
Template: lightning
Author: pc-suketto.net
Version: 1.0.0
*/


/* ------------------------------ 共通 start ------------------------------ */
body {
	font-size: 16px;
	font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
	font-feature-settings: "palt";
	letter-spacing: 0.1em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-size-adjust: 100%; /* safari用 */
	-webkit-text-size-adjust: 100%;
	overflow: clip; /* position:sticky用 */
}

/* 変数 */
:root {
	--color-main: var(--vk-color-primary);
	--color-main-light: #63ADD8;
	--color-main-dark: #205E82;
	--color-sub01: #DA2C38;
	--color-sub02: #363636;
	--color-base: #eee;
	--color-line: #ccc;
	--grad-main: linear-gradient(135deg, #00b6d9 0%, var(--color-main) 100%);
	--grad-recruit: linear-gradient(170deg, var(--color-main) 0%, #006799 100%);
	--font-en-cursive: "Mr Dafoe", cursive;
	--font-en: "Montserrat", sans-serif;
	--txt-shadow-sub01: 1px 1px 4px rgba(0, 0, 0, 0.3);
	/* 以下はLightningの変数 */
	--vk-width-col-2-main: calc(100% - 360px);
	--vk-width-col-2-sub: 300px;
}

/* タグ */
a { text-decoration: none !important; }
address { font-style: normal; }
p { margin: 0; line-height: 1.8; }
iframe { margin: 0; }
img { vertical-align: middle; }
input, textarea, input::placeholder, textarea::placeholder { font-family: "Noto Sans JP", sans-serif; }

/* コンテナ */
.container { padding-right: 0; padding-left: 0; }
.page .entry-body>div>div { position: relative; z-index: 1; }
.page .site-body-container { max-width: 100%; padding: 0; }
.con-base { width: 1200px; margin: 0 auto; padding: 90px 0; }
.site-body { padding: 90px 0; }

/* 見出し */
dl+h1, dl+h2, dl+h3, dl+h4, dl+h5, dl+h6, ol+h1, ol+h2, ol+h3, ol+h4, ol+h5, ol+h6, p+h1, p+h2, p+h3, p+h4, p+h5, p+h6, table+h1, table+h2, table+h3, table+h4, table+h5, table+h6, ul+h1, ul+h2, ul+h3, ul+h4, ul+h5, ul+h6 { margin-top: 0; }
h1,h2,h3,h4,h5,h6 { position: relative; z-index: 1; margin: 0; font-weight: 900; line-height: 1.6; }
h2 { font-size: 2rem; /* 32px */ }
h3 { font-size: 1.75rem; /* 28px */ }
h4 { font-size: 1.5rem; /* 24px */ }
h5 { font-size: 1.25rem; /* 20px */ }

h3.deco {
	margin-left: 0.75em;
	padding: 0.1em 1em;
}
h3.deco::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: -10px;
	transform: translateY(-50%) skewX(-15deg);
	content: "";
	width: 20px;
	height: 100%;
	background: var(--color-sub01);
}

/* セクションタイトル */
.sec-ttl {
	display: inline-block;
	position: relative;
	z-index: 1;
	padding-bottom: 1rem;
}
.sec-ttl h2 {
	font-size: 2rem;
	font-weight: 900;
}
.sec-ttl .en {
	width: 100%;
	margin: 0.1em 0 0;
	color: var(--color-main);
	font-size: 6rem;
}
.sec-ttl .en-cursive {
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 50%;
	width: 80%;
	color: var(--color-sub01);
	font-size: 4rem;
	text-align: center;
	white-space: nowrap;
	transform: rotate(-10deg);
}

/* セクションタイトル（サブページ） */
.sec-ttl.sub-page {
	display: flex;
	align-items: center;
	gap: 0 30px;
	padding: 0;
}
.sec-ttl.sub-page h2 {
	max-width: 70%;
	color: var(--color-sub02);
	font-size: 3rem;
}
.sec-ttl.sub-page h2 .fs-s {
	display: block;
	margin: 0;
	font-size: 0.5em;
}
.sec-ttl.sub-page .en {
	flex: 1;
	margin: 0.25em 0 0;
	font-size: 1.5rem;
	font-weight: 900;
}
.sec-ttl .bg-clip {
	background: var(--grad-main); 
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* セクションタイトル（日本語） */
.sec-ttl.jp .en {
	margin: 1em 0 0;
	font-size: 1.5rem;
}
.sec-ttl.jp h2 {
	font-size: 3rem;
}

/* セクションヘッド */
.sec-head-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 60px;
}
.sec-head-wrap .sec-ttl {
	min-width: 50%;
}
.sec-head-wrap .sec-txt-outer {
	flex: 1;
}

/* テキスト */
.lead { color: var(--color-main); font-size: 2.25rem; font-weight: 700;}
.txt { display: block; margin-bottom: 10px; }
.txt a { border-bottom: 1px solid var(--color-main); transition: all 0.3s; }
.txt a:hover { opacity: 0.5; }
.msg-txt { line-height: 2.5; margin-bottom: 30px; }
.link-txt { color: #666; text-decoration: underline !important; }
.link-txt:hover { opacity: 0.5; }
div>.txt:last-of-type, div>.msg-txt:last-of-type { margin-bottom: 0; }
.fs-b { margin: 0 0.25em; font-size: 1.25em; }
.fs-s { margin: 0 0.25em; font-size: 0.8em; }
.fw-b { font-weight: 700; }
.en { display: inline-block; font-weight: 700; font-family: var(--font-en); line-height: 1.25; }
.en-cursive { font-family: var(--font-en-cursive); line-height: 1; transform: rotate(-10deg); }
.num { display: inline-block; font-family: var(--font-en); line-height: 1; }
.color { color: var(--color-main); }
.color-sub01 { color: var(--color-sub01); }
.notes { color: #666; font-size: 0.9em; }
.notes-mark { margin: 0 0.25em; font-size: 0.5em; vertical-align: top; }
.sp-br { display: none; }

.amp-txt {
	display: inline-block;
	position: relative;
	z-index: 1;
	padding: 0 2.5em;
	color: var(--color-main);
	font-family: var(--font-maru);
}
.amp-txt::before, .amp-txt::after {
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 0;
	content: "";
	width: 1px;
	height: 80%;
	background: var(--color-main);
	transform: rotate(-35deg);
	transform-origin: top;
}
.amp-txt::after {
	left: auto;
	right: 0;
	transform: rotate(35deg);
}

/* リスト */
ol { margin: 0; }
ul { margin: 0; }
li, .widget li { margin: 0; }
:is(.ol-base, .ul-base) li:not(:last-child) { margin-bottom: 0.5em; }
li>:is(.ol-base, .ul-base) { margin-top: 0.5em; }
.nonstyle-list { list-style: none; padding: 0 !important; }

/* 注釈 */
.notes-ol, .notes-ul { list-style: none; padding-left: 2em !important; counter-reset: number 0; }
.notes-ul { padding-left: 1.5em !important; }
.notes-ol li, .notes-ul li { position: relative; font-size: 0.9em; }
.notes-ol li:not(:last-child), .notes-ul li:not(:last-child) { margin-bottom: 5px; }
.notes-ol li::before, .notes-ul li::before { display: block; position: absolute; left: -2.25em; font-size: 1em; counter-increment: number 1; content: "※" counter(number); }
.notes-ul li::before { left: -1.5em; content: "※"; }

/* 定義リスト */
dl { margin: 0; }
.dli:not(:last-child) { margin-bottom: 0.75em; }
dt { margin-bottom: 0.25em; font-weight: 700; line-height: 1.25; }
dd:not(:last-child) { margin-bottom: 0.25em; }
.about-dl .dli { display: flex; flex-wrap: wrap; gap: 10px; }
.about-dl .dli:not(:last-child) { margin-bottom: 20px; }
.about-dl .dli dt {
	margin: 0;
	padding: 2.5px 5px;
	border-bottom: 1px solid var(--color-main);
	color: var(--color-main);
	font-size: 0.9em;
}
.about-dl .dli dd { width: 100%; }

/* テーブル */
:where(:not(.wp-block-table))>table:is(thead,tbody,tfoot,th,td) { border-color: #ccc; }
:where(:not(.wp-block-table))>table :is(th,td) { font-size: 0.9em; }
:where(:not(.wp-block-table))>table.tb-base :is(th,td) { border-top: 1px solid #ccc; border-bottom: 1px solid #ccc; }
:where(:not(.wp-block-table))>table { border-right: none; border-left: none; }
table { table-layout: fixed; }
table td, table th { padding: 1.5em; }
.tb-base th {
	width: 30%;
	border-right: none;
	border-left: none;
	color: var(--color-main);
	text-align: left;
}
.tb-base td {
	width: 70%;
	border-right: none;
	border-left: none;
}
.tb-base td .notes-ul {
	margin-top: 10px;
}
.tb-base td a {
	text-decoration: underline !important;
}
.scroll-tb-wrap .txt.notes { display: none; }

/* ボタン */
.btn-base {
	position: relative;
	z-index: 1;
	display: inline-block;
	min-width: 280px;
	padding: 20px 60px;
	border: 1px solid var(--color-main);
	background: var(--color-main);
	color: #fff;
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
	transition: all 0.3s;
}
.line-arrow {
	display: inline-block;
	position: relative;
	z-index: 1;
	left: 0;
	width: 20px;
	height: 1px;
	margin-top: 0.5em;
	border-top: 1px solid var(--color-main);
	transition: all 0.3s;
}
.line-arrow::before {
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0;
	content: "";
	width: 45%;
	height: 1px;
	border-radius: 0 999px 999px 0;
	background: var(--color-main);
	transform: rotateZ(45deg);
	transform-origin: right bottom;
	transition: all 0.3s;
}
.btn-base .line-arrow {
	position: absolute;
	z-index: 1;
	left: auto;
	top: 42.5%;
	right: 20px;
	transform: translateY(-42.5%);
	border-top-color: #fff;
}
.btn-base .line-arrow::before {
	background: #fff;
}

@media (hover: hover) {
	.btn-base:hover {
		background: #fff;
		color: var(--color-main);
	}
	.btn-base:hover .line-arrow {
		right: 15px;
		border-top-color: var(--color-main);
	}
	.btn-base:hover .line-arrow::before {
		background: var(--color-main);
	}
}
.contact-btn-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 5px 15px;
}
.contact-btn .btn-icon span {
	margin: 0;
	font-size: 30px;
}
.contact-btn .btn-txt .txt {
	line-height: 1.5;
}

/* text-align */
.center { text-align: center; }
.left { text-align: left; }
.right { text-align: right; }

/* フェードアニメーション */
.fade-in, .fade-up, .fade-down, .fade-left, .fade-right { opacity: 0; }
/* フェードイン */
.fade-in.active { animation-name: fadeInAnime; animation-duration: 1.75s; animation-fill-mode: forwards; }
@keyframes fadeInAnime { from { opacity: 0; } to { opacity: 1; } }
/* フェードアップ */
.fade-up.active { animation-name: fadeUpAnime; animation-duration: 1s; animation-fill-mode: forwards; }
@keyframes fadeUpAnime { from { opacity: 0; transform: translateY(100px); } to { opacity: 1; transform: translateY(0); } }
/* フェードダウン */
.fade-down.active { animation-name: fadeDownAnime; animation-duration: 1s; animation-fill-mode: forwards; }
@keyframes fadeDownAnime { from { opacity: 0; transform: translateY(-100px); } to { opacity: 1; transform: translateY(0); } }
/* フェードレフト */
.fade-left.active { animation-name: fadeLeftAnime; animation-duration: 1s; animation-fill-mode: forwards; }
@keyframes fadeLeftAnime { from {opacity: 0; transform: translateX(-100px); } to { opacity: 1; transform: translateX(0); } }
/* フェードライト */
.fade-right.active { animation-name: fadeRightAnime; animation-duration: 1s; animation-fill-mode: forwards; }
@keyframes fadeRightAnime { from { opacity: 0; transform: translateX(100px); } to { opacity: 1; transform: translateX(0); } }
/* フェードのディレイ */
.delay-time02 { transition-delay: 0.2s; animation-delay: 0.2s; }
.delay-time04 { transition-delay: 0.4s; animation-delay: 0.4s; }
.delay-time06 { transition-delay: 0.6s; animation-delay: 0.6s; }
.delay-time08 { transition-delay: 0.8s; animation-delay: 0.8s; }
.delay-time10 { transition-delay: 1s; animation-delay: 1s; }

/* メニュー */
.widget_nav_menu>ul li { margin-top: 10px; }

/* Page Builder by SiteOrigin */
.row-reverse { flex-direction: row-reverse; } /* 2カラム時に左右のコンテンツ入れ替える */
.stretch-cell>div, .stretch-cell>div>div { height: 100%; } /* columnをストレッチさせる */

/* Contact Form 7 */
.txt-cf7 { display: inline-block; margin-bottom: 10px; font-size: 0.9em; }
.cf7-tb { overflow: hidden; table-layout: fixed; border-right: none; border-left: none; }
.cf7-tb input, .cf7-tb textarea { margin-bottom: 0; padding: 0.5em 1em; border: none; background-color: var(--color-base); line-height: 1.5; }
.cf7-tb textarea { border-radius: 5px; }
.cf7-tb select { width: 100%; margin: 0 0 1em 0; padding: 0.5em; }
.cf7-tb th, .cf7-tb td { font-size: 1rem; border-right: none; border-left: none; }
.cf7-tb th { width: 40%; text-align: left; vertical-align: top; }
.cf7-tb td { width: 60%; text-align: left; }
.cf7-tb .fs-s { margin: 0; }
.input-zip { display: inline-block; width: 150px !important; max-width: 100%; margin: 0 0 10px 5px !important; }
.wpcf7-list-item { margin: 0 1em 0 0 !important; }
.required {
	margin-right: 10px;
	padding: 2.5px 5px;
	background: var(--color-sub01);
	color: #fff;
	font-size: 0.7em;
	line-height: 1;
	vertical-align: middle;
}
.required.not-required {
	background: #ccc;
	color: #333;
}
.cf7-btn {
	margin-top: 60px;
	text-align: center;
}
.cf7-btn .btn-base {
	min-width: 30%;
	padding: 25px 45px;
	border: none;
	border-radius: 999px;
	background: var(--color-main);
	color: #fff;
	text-align: center;
}
.cf7-btn .btn-base:hover {
	background: var(--color-main-dark);
}
.wpcf7-spinner { display: block !important; margin: 0 auto !important; text-align: center; }

/* Lightbox */
.featherlight .featherlight-content { padding: 5px 5px 0; border-bottom: 5px solid transparent; }
.featherlight-next { top: 5px; right: 5px; }
.featherlight-previous { top: 5px; left: 5px; }
.rl-gallery-item img { transition: all 0.3s ease;}
.rl-gallery-item img:hover { opacity: 0.8; }
.rl-gallery-caption { display: block; font-size: 0.9em;}

/* Swiper */
.swiper-wrapper { transition-timing-function: linear !important; }

/* Material Symbols & Icons - Google Fonts */
.material-symbols-outlined { margin: 0 0.15em 0.1em; font-size: 1.3em; vertical-align: middle; }

/* Googleマップ */
.map iframe { width: 100%; height: auto !important; aspect-ratio: 3/1.25;}

/* モバイルナビ */
.vk-mobile-nav-menu-btn { display: none; } /* Lightning既存のナビは非表示 */

/* ページトップへ戻るボタン */
.page_top_btn {
	bottom: 20px;
	right: 20px;
	width: 50px;
	height: 50px;
	border: 1px solid #fff;
	border-radius: 50%;
	background-color: var(--color-main);
	box-shadow: none;
}

/* タブ */
.tab-list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 10px;
}
.tab-list li {
	margin: 0 !important;
}
.tab {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	z-index: 1;
	width: 100%;
	padding: 10px 30px;
	border-radius: 999px;
	background: #ccc;
	color: #666;
	font-size: 1.25rem;
	font-style: var(--font-maru);
	text-align: center;	
	cursor: pointer;
	transition: all 0.3s;
}
.tab:hover, .tab.active {
	background: var(--color-main);
	color: #fff;
}
.tab-panel {
	display: none !important;
}
.tab-panel.active {
	display: block !important;
	animation-name: tabFadeIn;
	animation-fill-mode: forwards;
	animation-duration: 0.3s;
}
.tab-panel-wrap .con-base {
	padding-top: 60px;
	padding-bottom: 0;
}
@keyframes tabFadeIn{ 0% { opacity: 0; } 100% { opacity: 1; } }

/* ループテキスト */
.loop-txt {
	display: flex;
	width: 100vw;
	margin-inline: calc(50% - 50vw);
	color: var(--color-base);
	font-size: min(10vw,10rem);
	line-height: 1;
	white-space: nowrap;
}
.loop-txt .en {
	flex-shrink: 0;
	padding-right: 0.5em;
}
.loop-txt:not(.no-tick) .en:nth-child(odd) {
	animation: MoveLeft var(--tick-duration, 24s) var(--tick-delay, -12s) infinite linear;
	animation-fill-mode: both;
}
.loop-txt:not(.no-tick) .en:nth-child(even) {
	animation: MoveLeft2 var(--tick-duration, 24s) infinite linear;
	animation-fill-mode: both;
}
.loop-txt-wrap-right .loop-txt:not(.no-tick) .en:nth-child(odd) {
	animation: MoveRight var(--tick-duration, 24s) var(--tick-delay, -12s) infinite linear;
	animation-fill-mode: both;
}
.loop-txt-wrap-right .loop-txt:not(.no-tick) .en:nth-child(even) {
	animation: MoveRight2 var(--tick-duration, 24s) infinite linear;
	animation-fill-mode: both;
}
@keyframes MoveLeft {
	from { transform: translateX(100%); }
	to { transform: translateX(-100%); }
}
@keyframes MoveLeft2 {
	from { transform: translateX(0); }
	to { transform: translateX(-200%); }
}
@keyframes MoveRight {
	from { transform: translateX(-100%); }
	to { transform: translateX(100%); }
}
@keyframes MoveRight2 {
	from { transform: translateX(-200%); }
	to { transform: translateX(0); }
}
/* ------------------------------ 共通 end ------------------------------ */


/* ------------------------------ ヘッダー start ------------------------------ */
.site-header {
	box-shadow: none;
	transition: all 0.3s;
	padding-right: clamp(240px, 10vw, 280px);
}
.site-header-container {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0 20px;
}
.site-header--layout--nav-float .site-header-container {
	align-items: center;
	gap: 20px;
}
.site-header--layout--nav-float .site-header-logo {
	width: auto;
	margin-right: 0;
}
.global-nav-list {
	padding: 0;
}
.device-mobile .global-nav-list>li {
	padding: 20px;
}
.global-nav-list>li .global-nav-name {
	font-size: 0.9rem;
}
.global-nav-list>li .global-nav-description {
	color: var(--color-main);
	font-family: var(--font-en);
	font-weight: 700;
	opacity: 1;
}
.device-mobile .global-nav-list .acc-btn {
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
.device-pc .global-nav-list>li>a {
	gap: 2.5px;
	padding: 15px;
}
.device-pc .global-nav-list>li>a:hover {
	transition: color .3s cubic-bezier(.23,1,.32,1);
}
.global-nav-list>li>a {
	color: #333;
	text-shadow: 0 0 10px #fff;
	transition: all 0.3s;
}
.global-nav-list>li>a:hover, .global-nav-list>li[class*=current]>a {
	color: var(--color-main) !important;
}
.global-nav-list>li::before { /* ヘッダーナビのアニメーション用 */
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	content: "";
	width: 0;
	border-bottom: 1px solid var(--color-sub01);
	transition: all .3s ease-out;
}
.global-nav-list>li:hover::before, .global-nav-list>li[class*=current]::before {
	width: 100%;
}


/* スクロール時ヘッダー */
.header_scrolled .site-header {
	position: fixed !important;
	top: 0;
	max-width: 100%;
	box-shadow: none;
}
.header_scrolled .site-header-container {
	margin: 0;
}
.header_scrolled .site-header-logo img {
	max-height: 40px !important;
}

/* ヘッダー上部 */
.header-top {
	margin: 0;
	padding-top: 5px;
	border-bottom: 0;
	background: transparent;
}
.header-top .container {
	max-width: 100%;
	padding: 0 20px;
	align-items: center;
}
.header-top .header-top-description {
	top: 0;
	padding: 0;
	font-size: min(0.9vw,0.9rem);
}
.header-top nav {
	top: 0;
}
.header-top ul {
	align-items: center;
	gap: 15px;
	margin: 0;
}
.header-top ul>li>a {
	padding: 0;
	text-decoration: underline !important;
}
.header-top ul>li>a:hover {
	opacity: 0.5;
}

/* ヘッダーお問い合わせボタン */
.header-contact {
	position: absolute;
	z-index: 1;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	height: 100%;
	text-align: center;
}
.header-contact .contact-btn {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: clamp(240px, 10vw, 280px);
	min-width: auto;
	height: 100%;
	padding: 20px 30px;
	font-size: 1rem;
	font-weight: 700;
}
.header-contact .contact-btn .btn-txt .en {
	display: block;
	font-size: 10px;
}

.header_scrolled .header-contact .contact-btn {
	padding: 10px 30px;
}
/* ------------------------------ ヘッダー end ------------------------------ */


/* ------------------------------ ページヘッダー start ------------------------------ */
.page-header-wrap {
	position: relative;
}
.page-header-wrap svg#symbol-mark {
	position: absolute;
	z-index: 1;
	top: -10vw;
	left: -10vw;
	width: 40%;
	aspect-ratio: 1;
}
.page-header-wrap .bg-en {
	position: absolute;
	z-index: 2;
	bottom: 0;
	left: 25%;
	width: 100%;
	color: var(--color-sub01);
	font-size: min(12vw,12rem);
	text-align: center;
	white-space: nowrap;
	/* 	text-shadow: var(--txt-shadow-sub01); */
}
.page-header-outer {
	padding: 0 0 0 20%;
}
.page-header {
	z-index: 1;
}
.page-header-inner {
	margin-left: -20%;
}
.page-header-title, h1.page-header-title {
	font-size: min(3.5vw,3.5rem);
	font-weight: 900;
	text-shadow: 0 0 30px #fff, 0 0 30px #fff;
}
.page-header-subtext {
	margin: 0.5em 0 0;
	color: var(--color-main);
	font-size: min(1.5vw,1.5rem);
	font-weight: 700;
	font-family: var(--font-en);
	line-height: 1.25;
	text-shadow: 0 0 30px #fff, 0 0 30px #fff;
}
/* ------------------------------ ページヘッダー end ------------------------------ */


/* ------------------------------ パンくずリスト start ------------------------------ */
.breadcrumb { position: relative; z-index: 3; padding: 0 20px; }
.breadcrumb .container { max-width: 100%; }
/* ------------------------------ パンくずリスト end ------------------------------ */


/* ------------------------------ フッター start ------------------------------ */
/* フッター上部 */
.cta-contact {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 45px;
	position: relative;
	z-index: 1;
	margin-bottom: 60px;
	padding: 45px 60px;
	border: 1px solid #fff;
}
.cta-tel {
	width: calc(50% - 22.5px);
}
.cta-tel h2 {
	margin-bottom: 20px;
	font-size: 1.25rem;
}
.cta-tel .tel-num {
	margin-bottom: 0.1em;
	color: #fff;
	font-size: 3rem;
}
.cta-tel .tel-num:hover {
	color: var(--color-main);
}
.cta-tel .tel-num .fs-s {
	color: #fff;
}
.cta-tel .contact-desc {
	color: #fff;
}
.cta-mail {
	width: calc(50% - 22.5px);
}
.cta-mail .contact-btn {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	max-width: 100%;
	height: 100%;
}

/* フッターウィジェット */
.site-footer {
	font-size: 0.9em;
}
.site-footer-content {
	padding: 90px 0;
}
.site-footer .col-lg-12 {
	padding: 0;
}
.site-footer .widget {
	margin-bottom: 60px;
}
.site-footer .widget:last-child {
	margin-bottom: 0;
}
.site-footer .site-description {
	margin-bottom: 1em;
	color: var(--vk-color-text-light);
	font-size: 1.125rem;
	font-family: var(--font-maru);
}
.ft-contents-wrap {
	display: flex;
	flex-direction: column;
	gap: 30px;
	padding: 60px 60px 0;
	border-top: 1px solid #666;
}
.ft-logo {
	text-align: center;
}
.ft-logo img {
	width: 100%;
	max-width: 400px;
}
.ft-banner {
	margin-top: 15px;
}
.ft-banner a {
	display: inline-block;
	width: 80px;
}
.ft-banner a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.info-dl {
	display: flex;
	flex-wrap: wrap;
}
.info-dl .dli {
	width: calc(100%/3);
	margin: 0;
	padding: 30px 30px 0;
}
.info-dl dt {
	margin: 0 0 1em;
}
#menu-footer-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 30px 0; 
}
#menu-footer-nav > li {
	width: calc(100%/4);
}
#menu-footer-nav > li > a {
	display: inline-block;
	padding: 15px 30px;
	border-bottom: none;
	font-size: 1.1rem;
	font-weight: 700;
	line-height: 1.5;
	transition: all 0.3s;
}
#menu-footer-nav > li > a:hover {
	background-color: transparent;
	color: var(--color-main);
}
#menu-footer-nav > li.current_page_item > a {
	background-color: transparent;
	color: var(--color-main);
}
#menu-footer-nav .sub-menu li a {
	position: relative;
	z-index: 1;
	padding: 10px 30px 10px 60px;
	border-bottom: none;
	font-size: 0.9rem;
}
#menu-footer-nav .sub-menu li a::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 30px;
	transform: translateY(-50%);
	content: "";
	width: 10px;
	height: 1px;
	background: #fff;
}
#menu-footer-nav li.current_page_ancestor .sub-menu li.current_page_item a {
	color: var(--color-main);
}
#menu-footer-nav li.current_page_ancestor .sub-menu li.current_page_item a::before {
	background-color: var(--color-main);
}
#menu-footer-nav .sub-menu .sub-menu li a {
	margin-left: 15px;
}
.site-footer .widget_nav_menu>div>ul#menu-header-top-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
}
.site-footer .widget_nav_menu>div>ul#menu-header-top-nav li a {
	display: inline-block;
	padding: 0;
	border-bottom: none;
	background-color: transparent;
	color: #ccc;
	font-size: 0.8rem;
	text-decoration: underline !important;
}
.site-footer .widget_nav_menu>div>ul#menu-header-top-nav li a:hover {
	opacity: 0.5;
}
.site-footer-copyright {
	max-width: 100%;
	padding: 0 20px 90px;
}
.site-footer-copyright p {
	margin: 0;
	color: #ccc;
	font-family: var(--font-en);
}
/* ------------------------------ フッター end ------------------------------ */


/* ------------------------------ フッター上部（ウィジェット） start ------------------------------ */
.site-body-bottom .widget {
	margin: 0;
}
.site-body-bottom .container {
	width: 100%;
	max-width: 100%;
}
/* ------------------------------ フッター上部（ウィジェット） end ------------------------------ */


/* ------------------------------ フロントページ start ------------------------------ */
/* メインビジュアル */
.main-visual {
	position: relative;
	z-index: 1;
}
.mv-ttl {
	position: absolute;
	z-index: 3;
	top: 5vw;
	left: 5vw;
}
.mv-ttl .ttl-en {
	position: relative;
	z-index: 1;
	margin-bottom: 50px;
	padding-bottom: min(1vw,1rem);
}
.mv-ttl h2 {
	font-size: min(7vw,7rem);
	text-shadow: 0 0 0.5em #fff, 0 0 0.5em #fff;
}
.mv-ttl .en-cursive {
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 50%;
	width: 80%;
	color: var(--color-sub01);
	font-size: min(5vw,5rem);
	text-align: center;
	white-space: nowrap;
	/* 	text-shadow: var(--txt-shadow-sub01); */
}
.mv-ttl .txt {
	color: #fff;
	font-size: min(1.5vw,1.5rem);
	font-weight: 700;
	line-height: 3;
}
.mv-ttl .txt span {
	padding: 0.5em 1em;
	background: var(--color-sub02);
}
.main-visual .swiper-wrapper {
	position: relative;
	z-index: 2;
	overflow: hidden;
}
.mv-swiper {
	width: 80%;
	height: clamp(720px, 90svh, 1080px);
	margin: 0 0 0 auto;
}
.mv-swiper :is(.swiper-slide, .swiper-slide-inner) {
	width: 100%;
	height: 100%;
}
.mv-swiper .swiper-slide-inner img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.scrolldown {
	position:absolute;
	z-index: 1;
	left: 7.5vw;
	bottom: 5vw;
	height: 60px;
}
.scrolldown span {
	position: absolute;
	z-index: 1;
	bottom: 105%;
	left: 50%;
	transform: translateX(-50%);
	color: var(--color-main);
	font-size: 0.8rem;
}
.scrolldown::after {
	content: "";
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: 30px;
	background: var(--color-main);
	animation: pathmove 1.4s ease-in-out infinite;
	opacity:0;
}
@keyframes pathmove {
	0% { height:0; top:0; opacity: 0; }
	30% { height:30px; opacity: 1; }
	100% { height:0; top:60px; opacity: 0; }
}
.main-visual svg#symbol-mark {
	position: absolute;
	z-index: 1;
	top: -10vw;
	left: -10vw;
	width: 40%;
	max-height: 90%;
	aspect-ratio: 1;
}
.loop-txt-wrap.mv-top {
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 0;
}
.loop-txt-wrap.mv-top .loop-txt {
	color: transparent;
	font-size: min(12vw,12rem);
	-webkit-text-stroke: 1.5px #fff;
	text-stroke: 1.5px #fff;
	opacity: 0.5;
}
.loop-txt-wrap-right.mv-bottom .loop-txt {
	font-size: min(12vw,12rem);
}

/* 横山運輸の強み（ホーム） */
#pg-19-1 {
	z-index: 1;
}
#pg-19-1::after {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 60%;
	content: "";
	width: auto;
	height: 60%;
	max-height: 900px;
	aspect-ratio: 1;
	background: url(/wp-content/uploads/2025/09/logo_color-base.png) no-repeat center / contain;
}
.sec-ttl.strength h2 {
	color: var(--color-main);
}
.sec-ttl.strength .en {
	color: var(--color-sub02);
}
.strengths-wrap {
	position: relative;
	z-index: 1;
}
.strengths-truck {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 45%;
	width: 100%;
	height: 95%;
}
.strengths-wrap::before, .strengths-wrap::after {
	position: absolute;
	z-index: -1;
	bottom: calc(-5% - 95px);
	left: 50%;
	transform: translateX(-50%);
	content: "";
	width: 100vw;
	height: 115%;
	background: url(/wp-content/uploads/2026/01/bg_strengths.jpg) center / cover;
	clip-path: polygon(0 0, 100% 20%, 100% 80%, 0 100%);
}
.strengths-wrap::after {
	background: linear-gradient(90deg, transparent 0%, var(--color-main-dark) 75%);
	opacity: 0.8;
}
.strengths-truck {
	overflow: visible;
}
.strengths-truck img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: top right;
	filter:drop-shadow(10px 10px 5px rgba(0, 0, 0, 0.75));
}
.strengths-contents {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	width: 65%;
	height: auto;
	min-height: 700px;
	margin: 0 0 auto 0;
}
.strengths-link-list {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	margin-bottom: 60px;
}
.strengths-link-item {
	width: 100%;
}
.strengths-link-item a {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 30px;
	padding: 30px;
	border: 1px solid var(--color-line);
	background: #fff;
	color: #333;
	transition: all 0.3s;
}
.strengths-link-item a:hover {
	border-color: var(--color-main);
	box-shadow: 4px 4px 0 var(--color-main);
}
.strengths-link-num {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	min-width: 100px;
	aspect-ratio: 1;
	background: var(--color-sub02);
}
.strengths-link-num .num {
	color: #fff;
	font-size: 2.5rem;
	font-weight: 700;
}
.strengths-link-ttl {
	flex: 1;
}
.strengths-link-ttl .en {
	color: var(--color-sub01);
	font-size: 1rem;
}
.strengths-link-ttl h3 {
	background: var(--grad-main);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	font-size: 2rem;
}
.strengths-link-item a:hover .line-arrow {
	left: 15px;
}

/* 事業内容（ホーム） */
#pg-19-2 {
	z-index: 1;
}
#pg-19-2::before, #pg-19-2::after {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 60%;
	background: url(/wp-content/uploads/2025/10/bg_service.jpg) no-repeat center / cover;
}
#pg-19-2::after {
	background: linear-gradient(0deg, transparent 0%, var(--color-main) 100%);
	opacity: 0.75;
}
.sec-ttl.service :is(h2, .en) {
	color: #fff;
}
.sec-ttl.service .en-cursive {
	z-index: -1;
	top: 35%;
	left: 50%;
	transform: translate(-50%,-35%) rotate(-10deg);
	color: #fff;
	width: 100vw;
	font-size: 10rem;
	opacity: 0.25;
}
.service-link-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 60px;
	margin: 0 60px;
}
.service-link-box {
	width: calc(50% - 30px);
}
.service-link-box a {
	display: block;
	color: #333;
}
.service-link-box-img {
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 3/2;
	overflow: hidden;
}
.service-link-box-img::before {
	position: absolute;
	z-index: 1;
	top: 41%;
	left: 0;
	content: "";
	width: 100%;
	height: 60%;
	background: linear-gradient(0deg, #fff 0%, transparent 100%);
}
.service-link-box-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all 0.3s;
}
.service-link-box .sec-ttl-outer {
	margin-top: -10%;
}
.service-link-box .sec-ttl {
	display: inline-block;
}
.service-link-box .sec-ttl h2{
	font-size: min(1.5vw,1.5rem);
}
.service-link-box .sec-ttl .en {
	font-size: min(4.5vw,4.5rem);
}
.service-link-box .sec-ttl .en-cursive {
	font-size: min(3vw,3rem);
}
@media (hover: hover) {
	.service-link-box a:hover .service-link-box-img img {
		transform: scale(1.1,1.1);
	}
	.service-link-box a:hover .line-arrow {
		left: 20px;
	}
}

/* 会社案内（ホーム） */
.sec-ttl.company {
	width: 100%;
	padding: 60px 0;
}
.sec-ttl.company .en-cursive {
	position: static;
	width: 100%;
	margin-bottom: 1em;
}
.sec-ttl.company .en {
	margin: 0.5em 0 0.1em;
}
.sec-ttl.company .logo img {
	width: 100%;
	max-width: 600px;
}
.sec-ttl.company .deco-logo-text {
	position: absolute;
	z-index: -1;
	top: -5%;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: calc(100% + 180px);
}
.sec-ttl.company .deco-logo-text img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	animation: rotateAnimation 60s linear infinite;
}
@keyframes rotateAnimation { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.history-top-img-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
	z-index: 1;
	gap: 20px;
	margin: 0 20px;
}
.history-top-img {
	width: calc(100%/3 - 40px/3);
}
.history-top-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.company-link-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 10px;
}
.company-link-item {
	position: relative;
	z-index: 1;
	width: calc(100%/3 - 20px/3);
	aspect-ratio: 3/1;
}
.company-link-item a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 30px 20px 60px 20px;
	color: #fff;
}
.company-link-ttl .txt {
	margin-bottom: 0.25em !important;
	font-size: min(1.5vw,1.5rem);
	font-weight: 900;
	line-height: 1.25;
}
.company-link-ttl .en {
	color: var(--color-sub01);
	font-size: min(0.9vw,0.9rem);
}
.company-link-img {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.company-link-img::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, var(--color-main) 0%, transparent 100%);
	transition: all 0.3s linear;
}
.company-link-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all 0.3s linear;
}
.company-link-item .line-arrow-outer {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0;
	width: 40px;
	height: 40px;
	background: #fff;
	text-align: center;
}
@media (hover: hover) {
	.company-link-item a:hover .company-link-img::before {
		width: 240%;
	}
	.company-link-item a:hover .company-link-img img {
		transform: scale(1.1,1.1);
	}
	.company-link-item a:hover .line-arrow-outer .line-arrow {
		left: 10px;
	}
}

/* 採用情報（ホーム） */
#pg-19-4 {
	background: var(--grad-recruit);
}
.sec-ttl.recruit {
	padding: 0;
}
.sec-ttl.recruit h2 {
	margin: 0 0 0.5em;
	color: #fff;
}
.sec-ttl.recruit .en {
	color: #fff;
}
.sec-ttl.recruit .en .color {
	color: var(--color-sub01);
	/* 	text-shadow: var(--txt-shadow-sub01); */
}
.sec-head-wrap.recruit .sec-txt-outer {
	color: #fff;
}
.recruit-link-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px 0;
}
.recruit-link-item {
	width: calc(50% - 15px);
}
.recruit-link-item a {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 20px;
	border-bottom: 1px solid #fff;
	color: #fff;
}
.recruit-link-ttl {
	flex: 1;
	display: flex;
	align-items: center;
	gap: 20px;
}
.recruit-link-ttl .txt {
	margin-bottom: 0 !important;
	font-size: 1.25rem;
	font-weight: 700;
}
.recruit-link-ttl .en-cursive {
	color: var(--color-sub01);
	font-size: 2rem;
	/* 	text-shadow: var(--txt-shadow-sub01); */
}
.recruit-link-item .line-arrow-outer {
	width: 40px;
}
.recruit-link-item .line-arrow-outer .line-arrow {
	border-top-color: #fff;
}
.recruit-link-item .line-arrow-outer .line-arrow::before {
	background: #fff;
}
@media (hover: hover) {
	.recruit-link-item a:hover .line-arrow-outer .line-arrow {
		left: 20px;
	}
}
#recruit-top-swiper {
	position: relative;
	z-index: 1;
	margin: 0 2.5vw;
	padding-top: 5%;
}
#recruit-top-swiper .swiper-slide {
	position: relative;
	z-index: 1;
	aspect-ratio: 2/3;
	overflow: hidden;
}
#recruit-top-swiper .swiper-slide::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	background: linear-gradient(0deg, var(--color-main) 0%, transparent 100%);
	mix-blend-mode: hard-light;
	opacity: 0.5;
}
#recruit-top-swiper .swiper-slide-inner {
	width: 100%;
	height: 100%;
}
#recruit-top-swiper .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#recruit-top-swiper .en-cursive {
	position: absolute;
	z-index: 1;
	top: 10%;
	left: 50%;
	transform: translate(-50%,-10%) rotate(-10deg);
	color: #fff;
	font-size: min(6vw,6rem);
	white-space: nowrap;
	text-shadow: 0 0 30px var(--color-main);
}
#recruit-top-swiper .loop-txt-wrap {
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
#recruit-top-swiper .loop-txt-wrap .loop-txt {
	color: transparent;
	font-size: min(8vw,8rem);
	-webkit-text-stroke: 1px #fff;
	text-stroke: 1px #fff;
	opacity: 0.5;
}
/* ------------------------------ フロントページ end ------------------------------ */


/* ------------------------------ サブページ共通 start ------------------------------ */
/* セクションライン */
body:not(.home, .post-name-strengths) .entry-body>div>div .con-base {
	position: relative;
	z-index: 1;
}
body:not(.home, .post-name-strengths, .post-name-recruit, .post-name-privacy-policy) .entry-body>div>div .con-base::before {
	position: absolute;
	z-index: -1;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	width: 100%;
	height: 2px;
	background: var(--color-base);
}

/* サブページ内リンク */
.anchor-links {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	align-items: center;
}
.anchor-links li {
	display: flex;
	flex-direction: column;
	height: 100%;
	margin: 0 !important;
}
.anchor-links li a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	padding: 10px 30px 10px 60px;
	color: #333;
	font-size: 0.8em;
	font-weight: 700;
	transition: all 0.3s;
}
.anchor-links li a::before {
	position: absolute;
	z-index: -1;
	top: 50%;
	left: 22.5px;
	transform: translateY(-50%);
	content: "\e313";
	color: var(--color-main);
	font-size: 17.5px;
	font-family: "Material Symbols Outlined";
	transition: all 0.3s;
}
.anchor-links li a:hover {
	color: var(--color-main);
}
.anchor-links li a:hover::before {
	top: 70%;
	transform: translateY(-70%);
}
/* ------------------------------ サブページ共通 end ------------------------------ */


/* ------------------------------ 横山運輸の強み start ------------------------------ */
/* 親ページ */
#pg-23-0::before {
	position: absolute;
	z-index: -1;
	bottom: 0;
	left: 0;
	content: "";
	width: 100%;
	height: clamp(180px,40svh,360px);
	background: #00a9c4;
	clip-path: polygon(0 50%, 100% 0%, 100% 100%, 0% 100%);
}
#pg-23-1 {
	background: linear-gradient(180deg, #00a9c4 0%, var(--color-main) 100%);
}
.con-base#strengths-lead {
	padding-bottom: clamp(180px,40svh,360px) !important;
}
.strengths-lead-contents {
	position: relative;
	z-index: 2;
	width: 50%;
	margin: 90px 0 60px;
}
.strengths-lead-contents .sec-ttl {
	margin-bottom: 60px;
}
.strengths-lead-contents .txt {
	font-size: 1.25rem;
	font-weight: 700;
}
.strengths-lead-img {
	position: absolute;
	z-index: 1;
	top: 90px;
	left: 45%;
	width: 60%;
	height: calc(100% - 180px);
	max-height: 900px;
	aspect-ratio: 1;
}
.strengths-lead-img img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
	filter:drop-shadow(0 20px 5px rgba(0, 0, 0, 0.75));
}
.strength-list {
	display: flex;
	flex-wrap: wrap;
	gap: 120px;
	counter-reset: number 0;
}
.strength-item {
	display: flex;
	flex-wrap: wrap;
	align-items:flex-start;
	gap: 60px;
	position: relative;
	z-index: 1;
	width: 100%;
	margin: 0 60px 60px 0 !important;
}
.strength-item::before {
	position: absolute;
	z-index: -1;
	top: 60px;
	left: 60px;
	content: "";
	width: 100vw;
	height: 100%;
	border: 1px solid var(--color-line);
	background: #fff;
}
.strength-item:nth-child(even) {
	flex-direction: row-reverse;
	margin: 0 0 60px 60px !important;
}
.strength-item:nth-child(even)::before {
	left: auto;
	right: 60px;
}
.strength-img {
	position: relative;
	z-index: 1;
	width: 40%;
	aspect-ratio: 3/4;
}
.strength-img::before {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: absolute;
	z-index: 2;
	top: -10px;
	left: -10px;
	counter-increment: number 1;
	content: "" counter(number, decimal-leading-zero);
	width: 120px;
	height: 120px;
	background: var(--color-sub02);
	color: #fff;
	font-size: 3.5rem;
	font-family: var(--font-en);
	font-weight: 700;
	line-height: 1;
}
.strength-item:nth-child(even) .strength-img::before {
	left: auto;
	right: -10px;
}
.strength-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.strength-contents {
	flex: 1;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	gap: 60px;
	margin-top: 120px;
}
.sec-ttl.jp.strength .en {
	margin: 0 0 0.5em;
	color: var(--color-sub01);
}

/* 子ページ共通 */
.parent-pageid-23 .entry-body > div > div:first-child {
	color: #fff;
}
.parent-pageid-23 .entry-body > div > div:first-child::before {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: calc(100% - min(20%,270px));
	background: linear-gradient(180deg, #00a9c4 0%, var(--color-main) 100%);
}
.parent-pageid-23 .entry-body > div > div:first-child::after {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 60%;
	content: "";
	width: auto;
	height: 60%;
	max-height: 900px;
	aspect-ratio: 1;
	background: url(/wp-content/uploads/2025/10/logo_color-white.png) no-repeat center / contain;
	opacity: 0.1;
}
.parent-pageid-23 .entry-body > div > div:first-child .con-base::before {
	display: none;
}
.parent-pageid-23 .link-con {
	padding-top: 0 !important;
}
.strength-lead-wrap {
	display: flex;
	flex-direction: column;
	gap: 60px;
}
.strength-lead-contents .sec-ttl {
	margin-bottom: 60px;
}
.strength-lead-contents .sec-ttl .num {
	margin: 0 0 0.5em;
	font-size: min(6vw,6rem);
	font-weight: 700;
}
.strength-lead-contents .sec-ttl h2 {
	font-size: min(3.5vw,3.5rem);
}
.strength-lead-contents .sec-ttl .en {
	color: #fff;
}
.strength-lead-contents .txt {
	font-size: 1.125rem;
	font-weight: 700;
}
.strength-lead-img {
	width: 100%;
	height: 100%;
	aspect-ratio: 3/1;
}
.strength-lead-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.strength-detail-img {
	width: 100%;
	aspect-ratio: 3/2;
}
.strength-detail-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.strength-detail-img.contain img {
	object-fit: contain;
}
.strength-detail-img.strength-g-mark {
}
.strength-detail-img.strength-g-mark figure {
	width: 100%;
	margin: 0;
}
.strength-detail-img.strength-g-mark img {
	object-fit: contain;
}
.strength-detail-img.strength-g-mark figcaption {
	margin-top: 1em;
	font-size: 0.8rem;
	text-align: left;
}

/* 安心安全への取り組み */
.post-name-safety {
	counter-reset: number 0;
}
.post-name-safety .btn-con {
	padding-top: 0 !important;
}
.post-name-safety .btn-con::before {
	display: none;
}
.post-name-safety .contact-btn {
	width: 100%;
	min-width: auto;
	max-width: 100%;
}
.safety-con::after {
	position: absolute;
	z-index: -1;
	top: 0;
	right: 0;
	counter-increment: number 1;
	content: "" counter(number, decimal-leading-zero);
	color: var(--color-base);
	font-size: 15rem;
	font-family: var(--font-en);
	font-weight: 700;
	line-height: 1;
}
/* ------------------------------ 横山運輸の強み end ------------------------------ */


/* ------------------------------ 事業内容 start ------------------------------ */
/* 親ページ */
.service-lead-outer {
	text-align: center;
}
.service-lead-outer .lead {
	background: var(--grad-main);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	font-size: 3rem;
	font-weight: 900;
}
.service-txt-outer {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
}

/* 共通 */
.service-lead-img {
	position: relative;
	z-index: 1;
	height: 60svh;
	max-height: 900px;
}
.service-lead-img::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	background: linear-gradient(180deg, transparent 0%, var(--color-main) 100%);
	opacity: 0.75;
}
.service-lead-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.post-name-shipping .service-lead-img img {
	object-position: bottom 20% left 50%;
}
.service-lead-txt-outer {
	position: relative;
	z-index: 2;
	margin-top: -90px;
	padding: 60px 60px 0 60px;
	background: #fff;
}
.service-lead-txt-outer .msg-txt {
	font-size: 1.1rem;
	font-weight: 600;
}
.desc-list {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}
.desc-list li {
	position: relative;
	z-index: 1;
	margin-left: 0.75em;
	padding: 0.5em 1em 0.5em 30px;
	background: var(--color-base);
	font-size: 1.25rem;
	font-weight: 700;
}
.desc-list li::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: -10px;
	transform: translateY(-50%) skewX(-15deg);
	content: "";
	width: 20px;
	height: 10px;
	background: var(--color-sub01);
}
/* ------------------------------ 事業内容 end ------------------------------ */


/* ------------------------------ 会社案内 start ------------------------------ */
/* 親ページ */
.post-name-company .company-link-list {
	margin: 0;
}
.post-name-company .company-link-item {
	width: 100%;
}
.post-name-company .company-link-ttl .txt {
	font-size: clamp(1.25rem,2vw,2rem);
}
.post-name-company .company-link-ttl .en {
	font-size: clamp(0.8rem,0.9vw,1rem);
}

/* 共通 */
.parent-pageid-20 .company-link-list {
	margin-top: 90px;
	margin-bottom: 10px;
}

/* 代表挨拶 */
.top-message-img {
	position: relative;
	z-index: 1;
	width: 100&;
	height: 100%;
	max-height: 600px;
	aspect-ratio: 3/1;
}
.top-message-img::before {
	position: absolute;
	z-index: 2;
	top: 60%;
	right: -10%;
	content: "";
	width: 40%;
	max-width: 400px;
	height: auto;
	aspect-ratio: 1;
	background: url(/wp-content/uploads/2025/09/logo_color-base.png) no-repeat center / contain;
}
.top-message-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-message-ttl {
	position: relative;
	z-index: 2;
}
.top-message-ttl h2 {
	color: #fff;
	line-height: 3;
}
.top-message-ttl h2 span {
	padding: 0.5em 1em;
	background: var(--color-sub02);
}
.top-message-txt-outer {
	position: relative;
	z-index: 1;
}
.top-message-name {
	display: flex;
	flex-direction: column;
	gap: 20px;
}
.top-msg-name-img {
	max-width: 150px;
	margin: 0 0 0 auto;
}
.top-msg-name-sign {
	text-align: right;
}
.top-msg-name-sign .txt {
	font-size: 1.25rem;
	font-weight: 700;
}
.top-msg-name-sign .txt .fs-s {
	display: block;
}
.top-msg-name-sign .en-cursive {
	color: var(--color-main);
	font-size: 3rem;
	transform: none;
}

/* 企業理念 */
.philo-wrap .lead {
	color: var(--color-sub02);
	font-weight: 900;
	line-height: 2;
}
.philo-img {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}

/* スローガン */
.slogan-wrap .en {
	margin-bottom: 0.25em;
	color: var(--color-sub02);
	font-size: 7rem;
}
.slogan-wrap .txt {
	font-size: 1.25rem;
	font-weight: 700;
}
.guidelines-ol {
	display: inline-block;
}
.guidelines-ol li {
	color: var(--color-sub02);
	font-size: 1.5rem;
	font-weight: 700;
	text-align: left;
}
.guidelines-ol li:not(:last-child) {
	margin-bottom: 1em;
}
.guidelines-ol li::marker {
	color: var(--color-main);
}

/* 会社概要 */
.overview-tb th {
	vertical-align: top;
}

/* 沿革 */
.history-dl .dli {
	display: flex;
	flex-wrap: wrap;
	gap: 90px;
	margin: 0;
	padding: 45px 0;
}
.history-dl dt {
	position: relative;
	z-index: 1;
	width: 20%;
	margin: 0;
	color: var(--color-sub01);
}
.history-dl dt::before {
	position: absolute;
	z-index: 1;
	top: -45px;
	left: calc(100% + 44px);
	content: "";
	width: 2px;
	height: calc(100% + 90px);
	background: var(--color-line);
}
.history-dl dt .num {
	display: block;
	margin: 0 0 0.1em;
	color: var(--color-main);
	font-size: 4rem;
}
.history-dl dd {
	flex: 1;
}
.history-month-list li {
	position: relative;
	z-index: 1;
	padding: 25px 0 0;
}
.history-month-list li::before {
	position: absolute;
	z-index: 1;
	top: 37.5px;
	right: calc(100% + 37.5px);
	content: "";
	width: 15px;
	height: 15px;
	border-radius: 999px;
	background: var(--color-sub01);
}
.history-month-list li {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 30px;
}
.history-month-list li .history-month-ttl .month {
	margin-right: 30px;
	color: var(--color-main);
	font-size: 1.5em;
	font-weight: 700;
}
.history-month-list li .history-month-contents {
	width: 100%;
}
.history-month-list li .history-month-contents .history-top-img-wrap {
	margin: 0;
}

/* 保有車両 */
.fleet-img-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.fleet-img {
	border: 1px solid var(--color-line);
}
/* .fleet-img {
width: calc(50% - 5px);
} */

/* 拠点一覧 */
.overview-dl {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 10px;
}
.overview-dl .dli {
	width: calc(100%/3 - 20px/3);
	margin: 0;
}
.overview-dl dt {
	margin-bottom: 0.75em;
	padding: 7.5px 10px;
	background: var(--color-sub02);
	color: #fff;
	font-size: 1rem;
}
.overview-dl dd {
	padding: 0 10px;
}

/* CSR */
.post-name-csr .page-header-wrap .bg-en {
	text-transform: uppercase;
}
.sr-list {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 45px;
}
.sr-list li {
	position: relative;
	z-index: 1;
	padding: 0 0 0 50px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.8;
}
.sr-list li::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	content: "";
	width: 20px;
	height: 20px;
	border-radius: 999px;
	background: var(--color-main);
}
.csr-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px;
}
.csr-item {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: 30px;
	width: 100%;
	padding: 60px;
	border: 1px solid var(--color-line);
}
.csr-ttl {
	width: 40%;
}
.csr-ttl .num {
	margin-bottom: 0.25em;
	padding-bottom: 0.25em;
	border-bottom: 2px solid var(--color-sub01);
	color: var(--color-main);
	font-size: 4rem;
	font-weight: 700;
}
.csr-contents {
	flex: 1;
}
.activity-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}
.activity-list li {
	width: 100%;
	padding: 0.5em 1em 0.5em 20px;
	background: var(--color-base);
}
/* ------------------------------ 会社案内 end ------------------------------ */


/* ------------------------------ 採用情報 start ------------------------------ */
/* 親ページ */
#pg-5508-0 {
	background: var(--grad-recruit);
}

/* 横山運輸を知る */
#pg-7260-0 {
	background: linear-gradient(0deg, var(--color-main) 0%, transparent 30%, transparent 100%);
}
#pg-7260-1 {
	background: var(--color-main);
	color: #fff;
}
.con-base:is(#lead, #numbers)::before {
	display: none;
}
.con-base#lead .sec-ttl h2 {
	color: var(--color-sub02);
}
.con-base#lead .sec-ttl .en {
	color: var(--color-main);
}
.recruit-msg-txt-outer {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}
.con-base#numbers .sec-ttl :is(h2,.en) {
	color: #fff;
}
.numbers-list {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}
.numbers-item {
	width: calc(50% - 15px);
	padding: 30px;
	border-radius: 10px;
	background: #fff;
	color: #333;
}
.numbers-ttl {
	margin-bottom: 30px;
}
.numbers-ttl h3 {
	padding-left: 1em;
	color: var(--color-sub01);
	font-size: 1.25rem;
}
.numbers-ttl h3::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 0;
	content: "";
	transform: translateY(-50%);
	width: 0.5em;
	height: 0.5em;
	margin-top: 0.1em;
	border-radius: 999px;
	background: var(--color-sub01);
}
.numbers-contents {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	align-items: flex-end;
	gap: 30px;
}
.numbers-icon span {
	margin: 0;
	color: #a6abbd;
	font-size: 10rem;
}
.numbers-num {
	position: relative;
	z-index: 1;
	flex: 1;
}
.numbers-num .txt {
	width: 150%;
	color: var(--color-sub02);
	font-size: 2rem;
	font-weight: 700;
}
.numbers-num .txt .sub-txt {
	display: block;
	color: #666;
	font-size: 1.25rem;
}
.numbers-num .txt .num {
	margin: 0 0.125em;
	color: var(--color-main);
	font-size: 3em;
}
.post-name-know .company-link-list {
	margin: 10px;
}

/* 社員インタビュー（親） */
.interview-link-list {
	display: flex;
	flex-wrap: wrap;
	gap: 60px;
}
.interview-link-item {
	width: 100%;
}
.interview-link-item a {
	display: block;
	position: relative;
	z-index: 1;
	width: 100%;
	aspect-ratio: 3/1.25;
}
.interview-link-lead {
	display: inline-block;
	max-width: 50%;
	margin-top: 60px;
	color: #333;
}
.interview-link-lead .lead {
	font-size: 2rem;
	line-height: 3;
}
.interview-link-lead .lead span {
	padding: 0.5em 1em;
	background: #fff;
}
.interview-link-name {
	margin: 60px;
	color: #fff;
}
.interview-link-name .txt {
	font-size: 1.75rem;
	font-weight: 700;
}
.interview-link-name .desc {
	margin-top: 1em;
}
.interview-link-item .en-cursive {
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0.25em;
	color: var(--color-sub01);
	font-size: min(10vw,10rem);
}
.interview-link-img {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.interview-link-img::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	content: "";
	width: 40%;
	height: 100%;
	background: var(--grad-recruit);
	clip-path: polygon(0 0, 50% 0, 100% 100%, 0% 100%);
}
.interview-link-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all 0.3s;
}
@media (hover: hover) {
	.interview-link-item a:hover .interview-link-img img {
		transform: scale(1.1,1.1);
	}
}

/* 社員インタビュー（子） */
.interview-lead-wrap {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column-reverse;
	gap: 60px;
}
.interview-lead-img {
	position: relative;
	z-index: 1;
	width: 100%;
	height: 100%;
	aspect-ratio: 3/1.75;
}
.interview-lead-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.interview-lead-img .en-cursive {
	position: absolute;
	z-index: 1;
	left: 50%;
	top: 0;
	width: 80%;
	color: var(--color-sub01);
	font-size: 6rem;
	text-align: center;
	white-space: nowrap;

}
.interview-lead-contents {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	gap: 60px;
	width: 100%;
}
.interview-lead-ttl {
	width: 50%;
}
.interview-lead-name {
	flex: 1;
}
.interview-lead-name .txt {
	font-size: 2rem;
	font-weight: 700;
}
.interview-lead-name .en {
	color: #666;
	font-size: 1.25rem;
}
.interview-lead-name .desc {
	margin-top: 1em;
}
.interview-wrap {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 60px;
}
.interview-wrap-inner {
	display: flex;
	flex-wrap: wrap;
	gap: 60px;
	width: 100%;
}
.interview-wrap-inner:nth-child(even) {
	flex-direction: row-reverse;
}
.interview-img {
	flex: 0 0 50%;
	height: 100%;
	aspect-ratio: 4/3;
}
.interview-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.interview-contents {
	flex: 1;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 60px;
}
.interview-qa h3 {
	margin-bottom: 1em;
}
.interview-qa h3::before {
	content: "";
	display: inline-block;
	width: 3rem;
	height: 1px;
	margin: 0.7em 0.5em 0.3em 0;
	background: var(--color-sub02);
}

/* キャリアビジョン */
#step01 { --color-main: #7587bb; }
#step02 { --color-main: #7d7cb5; }
#step03 { --color-main: #8670ac; }
#step04 { --color-main: #90639f; }
.c-vision-list {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 60px;
}
.c-vision-item {
	position: relative;
	width: 100%;
	padding: 60px 0;
}
.c-vision-item::before {
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	content: "";
	width: 2.5%;
	height: 100%;
	background: var(--color-main);
}
.c-vision-item::after {
	position: absolute;
	z-index: 1;
	top: 100%;
	left: 0;
	content: "";
	width: 2.5%;
	height: auto;
	aspect-ratio: 1;
	background: var(--color-main);
	clip-path: polygon(50% 100%, 0 0, 100% 0);
}
.c-vision-ttl {
	margin-bottom: 60px;
	padding: 1em 1em 1em calc(2.5% + 60px);
	border-bottom: 4px solid var(--color-main);
}
.c-vision-ttl .txt {
	display: inline-block;
	margin: 0 0 0.75em !important;
	padding: 0.5em 1em;
	background: var(--color-main);
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1;
}
.c-vision-ttl .txt .num {
	margin-right: 0.25em;
	font-size: 1.5em;
}
.c-vision-contents {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px;
	padding: 0 60px 0 calc(2.5% + 60px);
}
:is(.c-vision-task, .c-vision-seek) {
	width: calc(50% - 30px);
}
:is(.c-vision-task, .c-vision-seek) h4 {
	display: inline-block;
	margin-bottom: 1em;
	border-bottom: 2px solid var(--color-main);
}
.task-list {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	gap: 5px;
}
.task-list li {
	padding: 0.5em 1em;
	background: var(--color-base);
	color: var(--color-main);
	font-size: 0.9rem;
	font-weight: 700;
}
.c-vision-task .task-list li {
	border: 2px solid var(--color-main);
	background: #fff;
	font-size: 1rem;
}

/* 福利厚生 */
.support-tb thead th {
	width: 25%;
	background: var(--color-main);
	color: #fff;
	text-align: center;
}
.support-tb thead th:nth-child(2) {
	width: 50%;
}
.support-tb tbody th {
	background: var(--color-base);
	text-align: center;
}
.club-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 30px;
}
.club-item {
	width: calc(50% - 15px);
}
.club-img {
	margin-bottom: 10px;
}
.club-ttl .txt {
	position: relative;
	z-index: 1;
	padding-left: 1.5em;
	font-size: 1.25rem;
	font-weight: 700;
}
.club-ttl .txt::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	content: "";
	width: 1em;
	height: 4px;
	background: var(--color-sub01);
}

/* 募集要項 */
.posting-tb th {
	background: var(--color-base);
	vertical-align: top;
}
.con-base#entry .contact-btn {
	min-width: 100%;
	padding: 60px;
}
/* ------------------------------ 採用情報 end ------------------------------ */


/* ------------------------------ よくある質問 start ------------------------------ */
.accordion-list {
	display: flex;
	flex-direction: column;
	gap: 30px;
}
.accordion-item {
	width: 100%;
}
.accordion-ttl {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 20px;
	position: relative;
	z-index: 1;
	padding: 20px 60px 20px 20px;
	border-radius: 1em;
	background: var(--color-base-main);
	cursor: pointer;
	transition: all 0.3s;
}
.accordion-icon {
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 40px;
	aspect-ratio: 1/1;
	border: 1px solid var(--color-main);
	border-radius: 50%;
	background: var(--color-main);
	color: #fff;
	text-align: center;
}
.accordion-icon.faq-a {
	background: #fff;
	color: var(--color-main);
}
.accordion-icon .en {
	font-weight: 700;
	line-height: 1;
}
.accordion-ttl::before, .accordion-ttl::after {
	position: absolute;
	content:'';
	width: 20px;
	height: 2px;
	background-color: var(--color-main);
	transition: all 0.3s;
}
.accordion-ttl::before {
	top: 49%;
	right: 20px;
	transform: rotate(0deg);
}
.accordion-ttl::after {
	top: 49%;
	right: 20px;
	transform: rotate(90deg);
}
.accordion-ttl.close::before {
	transform: rotate(45deg);
}
.accordion-ttl.close::after {
	transform: rotate(-45deg);
}
.accordion-ttl .txt {
	flex: 1;
	font-size: 1.1rem;
	font-weight: 700;
}
.accordion-contents {
	display: none;
}
.accordion-contents-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	gap: 20px;
	padding: 20px 0;
}
.accordion-txt-outer {
	flex: 1;
	margin-top: 0.4em;
}
/* ------------------------------ よくある質問 end ------------------------------ */


/* ------------------------------ 投稿 start ------------------------------ */
/* サイドバー */
.widget-title.sub-section-title {
	padding: 0 10px 10px 10px;
	color: var(--color-main);
	font-size: 1rem;
	line-height: 1.25;
}

/* アーカイブページ */
.archive-header-title { margin-bottom: 60px; }
:is(.post-type-post, .archive, .single) .sub-section .widget_nav_menu>div>ul li a, :is(.post-type-post, .archive, .single) .widget_nav_menu>ul li a { padding: 0.85em 1.5em; border: 1px solid var(--color-line); background-color: #fff; color: #333; transition: all 0.3s; }
:is(.post-type-post, .archive, .single) .sub-section .widget_nav_menu>div>ul li a, :is(.post-type-post, .archive, .single) .widget_nav_menu>ul li a:hover { color: var(--color-main); }
:is(.post-type-post, .archive, .single) .sub-section .widget_nav_menu>ul li>ul.children { margin-left: 1.5em; }
:is(.post-type-post, .archive, .single) .sub-section .widget_nav_menu>ul li.current-cat>a { border-color: var(--color-main); background: var(--color-main); color: #fff; }
.card-noborder .vk_post_imgOuter { aspect-ratio: 3/2; border-color: var(--color-line); background-color: var(--color-base); background-size: contain; background-repeat: no-repeat; transition: all 0.3s; }
.card-noborder .vk_post:hover .vk_post_imgOuter { opacity: 0.5; }
.next-prev-prev .vk_post_imgOuter_singleTermLabel { right: auto; left: 5px; }
.vk_post_imgOuter_singleTermLabel { top: 5px; right: 5px; }
.vk_post .vk_post_title { margin: 0; font-size: 1.25rem; }

/* シングルページ */
.single .entry-header {
	margin-bottom: 60px;
}
.single .entry-header h1 {
	margin: 0 0 0.5em;
}
.single .entry-body h2 {
	padding-bottom: 0.25em;
	border-bottom: 2px dashed var(--color-main);
}
.single　.entry-body h3:not(.contact-method-ttl h3) {
	padding-left: 30px;
}
.single .entry-body h3:not(.contact-method-ttl h3)::before {
	position: absolute;
	z-index: 1;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	content: "";
	width: 20px;
	height: 2px;
	background: var(--color-main);
}
.single .entry-body :is(ul,ol) li:not(:last-child) {
	margin-bottom: 0.5em;
}
.single .entry-body table td:first-child {
	width: 30% !important;
	border-right: none;
	border-left: none;
	background: var(--color-base);
	color: var(--color-main);
	font-weight: 700;
	text-align: left;
}
.single .entry-body table td {
	border-right: none;
	border-left: none;
}
.single .entry-body table td a {
	text-decoration: underline !important;
}
.single .entry-body .contact-method-list {
	gap: 30px;
}
.single .entry-body .contact-method-list .contact-method-item {
	width: 100%;
}
.entry-meta-data-list:first-child {
	margin: 60px 0 5px;
}
.single .main-section--margin-bottom--on {
	margin-bottom: 60px;
}
.single .site-body .entry-footer {
	margin-bottom: 90px;
}
/* ------------------------------ 投稿 end ------------------------------ */


/* ------------------------------ お問い合わせ start ------------------------------ */
.post-name-contact .site-body-bottom {
	display: none;
}

/* お電話 */
.tel-num {
	color: var(--color-main);
	font-size: 4rem;
	font-weight: 700;
	transition: all 0.3s;
}
.tel-num .fs-s {
	margin-left: 0;
	color: var(--color-sub01);
	font-size: 0.5em;
}
.contact-desc-wrap .contact-desc:not(:last-child) {
	margin-bottom: 10px;
}
.contact-desc .desc-ttl {
	margin-right: 15px;
	padding: 5px 10px;
	border-bottom: 1px solid var(--color-line);
	color: var(--color-main);
	font-size: 0.9rem;
	font-weight: 700;
}
/* ------------------------------ お問い合わせ end ------------------------------ */


/* ------------------------------ プライバシーポリシー start ------------------------------ */
.post-name-privacy-policy .entry-body > div > div:not(:last-child) > .con-base {
	padding-bottom: 0 !important;
}
.post-name-privacy-policy .sec-ttl {
	padding: 0;
}
/* ------------------------------ プライバシーポリシー end ------------------------------ */


/* ------------------------------ 404ページ start ------------------------------ */
/* ------------------------------ 404ページ end ------------------------------ */


/* ------------------------------ レスポンシブ対応（1260px以下） start ------------------------------ */
@media (max-width: 1260px) {
	/* コンテナ */
	.con-base, :is(.page-header, footer, body:not(.page) .site-body) .container:not(.site-footer-copyright) { width: 931px; max-width: 931px; }

	/* 共通 */
	h2 { font-size: 1.75rem; }
	h3 { font-size: 1.5rem; }
	h4 { font-size: 1.25rem; }
	h5 { font-size: 1.125rem; }
	.lead {
		font-size: 2rem;
	}
	.sec-ttl h2 {
		font-size: 1.75rem;
	}
	.sec-ttl .en {
		font-size: 5.25rem;
	}
	.sec-ttl .en-cursive {
		font-size: 3.5rem;
	}
	.sec-ttl.jp .en {
		font-size: 1.3125rem;
	}
	.sec-ttl.jp h2 {
		font-size: 2.625rem;
	}
	.sec-ttl.sub-page h2 {
		font-size: 2.625rem;
	}
	.sec-ttl.sub-page .en {
		font-size: 1.3125rem;
	}

	/* ヘッダー */
	.device-mobile .global-nav-list>li {
		padding: 20px 10px;
	}

	/* ヘッダー上部 */
	.header-top .header-top-description {
		font-size: 12px;
	}

	/* フッター */
	.cta-tel .tel-num {
		font-size: 2.75rem;
	}

	/* ページヘッダー */
	.page-header {
		min-height: 22.5rem;
	}
	.page-header-inner {
		padding: 0;
	}
	.page-header-title, h1.page-header-title {
		font-size: 5vw;
	}
	.page-header-subtext {
		font-size: 2.25vw;
	}
	.breadcrumb .container {
		padding: 0;
	}

	/* フロントページ */
	.strengths-truck {
		left: 70%;
	}
	.strengths-link-num {
		min-width: 90px;
	}
	.strengths-link-ttl h3 {
		font-size: 1.75rem;
	}
	.sec-ttl.service .en-cursive {
		font-size: 8.75rem;
	}
	.company-link-item {
		width: calc(50% - 5px)
	}
	.company-link-ttl .txt {
		font-size: 2.5vw;
	}
	.company-link-ttl .en {
		font-size: 1.25vw;
	}

	/* サブページ */

	/* 安心安全への取り組み */
	.safety-con::after {
		font-size: 13.125rem;
	}
	.desc-list {
		gap: 20px;
	}
	.desc-list li {
		font-size: 1rem;
	}

	/* 事業内容 */
	.service-lead-outer .lead {
		font-size: 2.625rem;
	}

	/* 会社案内 */
	.slogan-wrap .en {
		font-size: 6rem;
	}
	.csr-ttl .num {
		font-size: 3rem;
	}

	/* 採用情報 */
	.numbers-num .txt {
		font-size: 1.5rem;
	}
	.interview-link-lead .lead {
		font-size: 1.5rem;
	}
	.interview-link-name {
		margin: 30px 60px 0;
		padding-bottom: 60px;
	}
	.interview-link-name .txt {
		font-size: 1.25rem;
	}
	.interview-link-name .desc {
		font-size: 0.9rem;
	}
	.interview-lead-img .en-cursive {
		font-size: 5rem;
	}
	.c-vision-ttl .txt {
		font-size: 1rem;
	}

	/* お問い合わせ */
	.tel-num {
		font-size: 3rem;
	}
}
/* ------------------------------ レスポンシブ対応（1260px以下） end ------------------------------ */


/* ------------------------------ レスポンシブ対応（991px以下） start ------------------------------ */
@media (max-width: 991px) {
	/* コンテナ */
	.con-base, :is(.page-header, footer, body:not(.page) .site-body) .container:not(.site-body-bottom .container, .site-footer-copyright) { width: 100%; max-width: 100%; padding-right: 30px; padding-left: 30px; }

	/* 共通 */
	.map iframe { aspect-ratio: 3/2; }
	.scroll-tb-wrap { overflow: scroll; }
	.scroll-tb-wrap .txt.notes { display: block; }
	.scroll-tb-wrap table { width: 990px; }

	/* モバイルナビ */
	.vk-mobile-nav {
		padding: 120px 20px 180px;
		text-align: center;
		background: #fff;
	}
	.vk-mobile-nav.vk-mobile-nav-open {
		display: block;
		transition: all 0.3s;
	}
	.vk-mobile-nav-widget:first-child {
		margin-bottom: 45px;
	}
	.vk-mobile-nav-menu-outer { opacity: 0; transition: all 0.3s;}
	.vk-mobile-nav-open .vk-mobile-nav-menu-outer { animation-name: opacityAnime; animation-duration: 1s; animation-delay: 0s; animation-fill-mode: forwards; }
	@keyframes opacityAnime { 0% { opacity: 0; } 100% { opacity: 1; } }
	.vk-mobile-nav.vk-mobile-nav-open .btn-base { animation-name: opacityAnime; animation-duration: 1s; animation-delay: .3s; animation-fill-mode: forwards; }
	.vk-mobile-nav nav>ul { border-top: none; }
	.vk-mobile-nav-menu-outer>ul>li a {
		position: relative;
		z-index: 1;
		padding: 15px 45px !important;
		color: #333 !important;
		font-size: 1.25rem;
		font-weight: 700;
		text-align: center !important;
		border-bottom: none !important;
	}
	.vk-menu-acc .acc-btn {
		top: 26px;
		border-color: #fff;
		border-radius: 50%;
		background: var(--vk-menu-acc-icon-open-white-bg-src) center 50% no-repeat;
		background-color: var(--color-main);
	}
	.vk-menu-acc .acc-btn.acc-btn-close {
		background: var(--vk-menu-acc-icon-close-white-bg-src) center 50% no-repeat;
		background-color: var(--color-main);
	}
	.vk-menu-acc ul.sub-menu li {
		margin-bottom: 5px;
	}
	.vk-menu-acc ul.sub-menu li a {
		background: var(--color-main);
		color: #fff !important;
		font-size: 0.9em;
		font-weight: 400;
	}
	.vk-menu-acc ul.sub-menu li .acc-btn {
		top: 12.5px;
	}
	.vk-menu-acc ul.sub-menu li .sub-menu li {
		margin-bottom: 0;
	}
	.vk-menu-acc ul.sub-menu li .sub-menu li a {
		background: transparent;
		color: #333 !important;
	}
	.vk-mobile-nav-menu-outer>ul>li a .fs-s {
		display: block;
		margin:  0.25em 0 0;
		color: var(--color-main);
		font-size: 0.65em;
		font-family: var(--font-en);
		font-weight: 700;
	}
	#menu-header-top-nav-1 {
		margin-top: 60px;
	}
	.openbtn {
		position: fixed;
		top: 5px;
		right: 15px;
		transition: all 0.5s ease-out;
		cursor: pointer;
		width:  35px;
		height: 45px;
		z-index: 9999;
	}
	.openbtn span {
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 0;
		width: 100%;
		height: 3px;
		background: var(--color-main);
		box-sizing: content-box;
		transition: all 0.3s;
	}
	.openbtn span:nth-of-type(1) { top:13px; }
	.openbtn span:nth-of-type(2) { top:21px; }
	.openbtn span:nth-of-type(3) { top:29px; }
	.openbtn.active span:nth-of-type(1) { top: 16px; transform: translateY(6px) rotate(-45deg); }
	.openbtn.active span:nth-of-type(2) { opacity: 0; }
	.openbtn.active span:nth-of-type(3) { top: 28px; transform: translateY(-6px) rotate(45deg); }

	/* ヘッダー */
	.site-header {
		min-height: 55px;
		padding-right: 0;
	}
	.site-header-container {
		min-height: 55px;
		padding: 0 10px;
		overflow: visible;
	}
	.site-header--layout--nav-float .site-header-container {
		display: flex;
		gap: 10px;
		padding-right: 140px;
	}
	.site-header-logo {
		text-align: left;
	}
	.site-header-logo a {
		display: block;
	}
	.site-header-logo img {
		max-height: 40px;
	}

	/* スクロール時ヘッダー */
	.header_scrolled .site-header {
		max-width: 100%;
		margin: 0 auto;
		padding: 0;
	}
	.header_scrolled .site-header-container {
		padding: 0 65px 0 10px;
	}
	.header_scrolled .site-header-logo {
		display: block;
		max-height: 40px;
		margin: 7.5px 0;
		padding-top: 0;
		background-image: var(--vk-header-logo-url);
		background-repeat: no-repeat;
		background-size: contain;
		background-position: left;
	}
	.header_scrolled .site-header-logo img {
		max-height: 40px !important;
		opacity: 0;
	}

	/* ヘッダーお問い合わせボタン */
	.header-contact {
		position: fixed;
		top: 0;
		right: 65px;
		transform: none;
		width: auto;
		height: 55px;
	}
	.header-contact .contact-btn {
		width: 65px;
		padding: 10px;
	}
	.header-contact .contact-btn .btn-icon span {
		font-size: 26px;
	}
	.header-contact .contact-btn .btn-txt {
		display: none;
	}
	.header_scrolled .header-contact .contact-btn {
		padding: 10px;
	}

	/* フッター */
	.cta-contact {
		gap: 30px;
		text-align: center;
	}
	.cta-tel, .cta-mail {
		width: 100%;
	}
	.ft-contents-wrap {
		padding: 60px 0 0;
	}
	.ft-logo img {
		max-width: 300px;
	}
	.site-footer-copyright {
		padding: 0 20px 120px;
	}

	/* ページヘッダー */
	.page-header-outer {
		padding: 0 0 0 10%;
	}
	.page-header-inner {
		margin-left: -10%;
	}
	.page-header-title, h1.page-header-title {
		font-size: 5vw;
	}
	.page-header-subtext {
		font-size: 2.75vw;
	}

	/* フロントページ */
	.mv-swiper {
		width: 90%;
		height: clamp(480px,70svh,720px);
	}
	.mv-ttl {
		left: 2.5vw;
	}
	.mv-ttl h2 {
		font-size: 8.75vw;
	}
	.mv-ttl .en-cursive {
		font-size: 6.25vw;
	}
	.mv-ttl .txt {
		font-size: 1.875vw;
	}
	.scrolldown {
		left: 5vw;
	}
	#pg-19-1::after {
		left: 30%;
		width: 80%;
		height: auto;
	}
	.sec-head-wrap .sec-txt-outer {
		width: 100%;
		min-width: 100%;
	}
	.strengths-wrap {
		display: flex;
		flex-direction: column-reverse;
		gap: 30px;
	}
	.strengths-wrap::before, .strengths-wrap::after {
		height: 65%;
	}
	.strengths-contents {
		justify-content: flex-start;
		width: 100%;
		min-height: auto;
	}
	.strengths-contents .btn-outer {
		text-align: center;
	}
	.strengths-truck {
		position: relative;
		right: -30%;
		left: auto;
		width: 80%;
	}
	.service-link-wrap {
		gap: 30px;
		margin: 0 30px;
	}
	.service-link-box {
		width: calc(50% - 15px);
	}
	.recruit-link-item {
		width: 100%;
	}

	/* サブページ共通 */
	.anchor-links {
		grid-template-columns: 1fr 1fr;
	}

	/* 横山運輸の強み */
	.con-base#strengths-lead {
		padding-bottom: 90px !important;
	}
	.strengths-lead-contents {
		margin: 0;
	}
	.strengths-lead-img {
		top: auto;
		bottom: 30px;
		height: auto;
	}
	.strength-item::before {
		left: 0;
		width: calc(100% + 60px);
	}
	.strength-item:nth-child(even)::before {
		left: -60px;
		right: auto;
	}
	.strength-img {
		left: -10px;
		width: 100%;
		aspect-ratio: 3/2;
	}
	.strength-item:nth-child(even) .strength-img {
		left: auto;
		right: -10px;
	}
	.strength-contents {
		margin: 0 0 0 60px;
	}
	.strength-item:nth-child(even) .strength-contents {
		margin: 0 60px 0 0;
	}
	.parent-pageid-23 .entry-body > div > div:first-child::after {
		left: 30%;
		width: 80%;
		height: auto;
	}
	.strength-lead-contents .sec-ttl .num {
		font-size: 5rem;
	}
	.desc-list li {
		padding: 0.5em 1em 0.5em 20px;
	}

	/* 会社案内 */
	.slogan-wrap .en {
		font-size: 5rem;
	}
	.guidelines-ol li {
		font-size: 1.25rem;
	}
	.csr-ttl {
		width: 100%;
	}

	/* 採用情報 */
	.numbers-contents {
		text-align: center;
	}
	.numbers-icon {
		width: 100%;
	}
	.numbers-icon span {
		font-size: 6rem;
	}
	.numbers-num .txt {
		width: 100%;
	}

	/* お問い合わせ */
	.cf7-btn .btn-base {
		min-width: 50%;
	}
}
/* ------------------------------ レスポンシブ対応（991px以下） end ------------------------------ */


/* ------------------------------ レスポンシブ対応（780px以下） start ------------------------------ */
@media (max-width: 780px) {
	/* 共通 */
	.sec-ttl h2 {
		font-size: 1.5rem;
	}
	.sec-ttl .en {
		font-size: 4.515rem;
	}
	.sec-ttl .en-cursive {
		left: 45%;
		font-size: 3rem;
	}
	.sec-ttl.jp .en {
		font-size: 1.3125rem;
	}
	.sec-ttl.jp h2 {
		font-size: 2.625rem;
	}
	.sec-ttl.sub-page h2 {
		font-size: 2.625rem;
	}
	.sec-ttl.sub-page .en {
		font-size: 1.3125rem;
	}
	.lead { font-size: 1.5rem; }
	.msg-txt { line-height: 2.25; }
	.cf7-tb th, .cf7-tb td { display: block; width: 100%; text-align: left; }
	.cf7-tb th { padding-bottom: 0; border-bottom: none; }
	.cf7-tb td { border-top: none; }

	/* コンテナ */
	.con-base, :is(.page-header, footer, body:not(.page) .site-body) .container:not(.site-body-bottom .container, .site-footer-copyright) { padding-right: 20px; padding-left: 20px; }
	:is(footer, .page-header, body:not(.page) .site-body) .container { width: 100%; max-width: 100% !important; }
	.con-base { padding-top: 60px; padding-bottom: 60px; }
	.site-body { padding: 60px 0; }
	.box { padding: 45px; }

	/* ページヘッダー */
	.page-header-outer {
		padding: 0;
	}
	.page-header {
		min-height: 20rem;
	}
	.page-header-inner {
		margin-left: 0;
	}
	.page-header-title, h1.page-header-title {
		color: #fff;
		font-size: 6vw;
		text-shadow: 0 0 0.75em #666, 0 0 0.75em #666;
	}
	.page-header-subtext {
		color: #fff;
		font-size: 3.25vw;
		text-shadow: 0 0 0.75em #666, 0 0 0.75em #666;
	}
	.page-header-wrap svg#symbol-mark {
		display: none;
	}

	/* フッター */
	.site-footer .row {
		margin: 0;
	}
	.site-footer .widget {
		margin-bottom: 45px;
	}
	.site-footer-content {
		padding: 60px 20px;
	}
	.ft-contents-wrap {
		margin-bottom: 45px;
	}
	#menu-footer-nav > li {
		width: 50%;
	}
	.info-dl {
		gap: 0;
	}
	.info-dl .dli {
		width: 100%;
		text-align: center;
	}

	/* フロントページ */
	.mv-ttl {
		top: 7.5vw;
	}
	.mv-ttl .ttl-en {
		margin-bottom: 25px;
	}
	.mv-ttl h2 {
		font-size: 12.25vw;
	}
	.mv-ttl .en-cursive {
		font-size: 8.75vw;
	}
	.mv-ttl .txt {
		font-size: 2.625vw;
	}
	.strengths-link-list {
		margin-bottom: 45px;
	}
	.strengths-link-num {
		min-width: 60px;
	}
	.strengths-link-num .num {
		font-size: 2rem;
	}
	.strengths-link-ttl h3 {
		font-size: 1.5rem;
	}
	#pg-19-2::before, #pg-19-2::after {
		height: 30%;
	}
	.sec-ttl.service .en-cursive {
		font-size: 6.25rem;
	}
	.service-link-box {
		width: 100%;
	}
	.service-link-box .sec-ttl h2 {
		font-size: 3vw;
	}
	.service-link-box .sec-ttl .en {
		font-size: 9vw;
	}
	.service-link-box .sec-ttl .en-cursive {
		font-size: 6vw;
	}
	.company-link-item {
		width: 100%;
	}
	.company-link-ttl .txt {
		font-size: 3.75vw;
	}
	.company-link-ttl .en {
		font-size: 1.875vw;
	}
	.sec-head-wrap {
		gap: 45px;
	}
	#recruit-top-swiper .en-cursive {
		font-size: 4rem;
	}
	#recruit-top-swiper .loop-txt-wrap .loop-txt {
		font-size: 6rem;
	}

	/* サブページ共通 */

	/* 横山運輸の強み */
	.con-base#strengths-lead {
		padding-bottom: 60px !important;
	}
	.strengths-lead-contents {
		width: 100%;
	}
	.strengths-lead-img {
		position: static;
		width: 80%;
		margin: 60px auto 0;
	}
	.strength-lead-contents .sec-ttl .num {
		font-size: 4rem;
	}
	.post-name-workplace .sec-ttl.jp h2 br {
		display: none;
	}

	/* 事業内容 */
	.service-lead-outer .lead {
		font-size: 2rem;
	}

	/* 会社案内 */
	.top-message-img {
		aspect-ratio: 3/1.5;
	}
	.top-msg-name-sign .en-cursive {
		font-size: 2rem;
	}
	.top-message-ttl h2 span {
		padding: 0.25em 0.5em;
	}
	.slogan-wrap .en {
		font-size: 4rem;
	}
	.slogan-wrap .txt {
		font-size: 1.1rem;
	}
	.history-dl .dli {
		position: relative;
		z-index: 1;
		gap: 0;
		margin-left: 40px;
	}
	.history-dl .dli::before {
		position: absolute;
		z-index: 1;
		top: 0;
		left: -30px;
		content: "";
		width: 2px;
		height: 100%;
		background: var(--color-line);
	}
	.history-dl dt {
		width: 100%;
	}
	.history-dl dt::before {
		display: none;
	}
	.history-dl dd {
		width: 100%;
	}
	.history-month-list li::before {
		right: auto;
		left: -36px;
	}
	.history-month-list li .history-month-ttl .month {
		display: block;
		margin: 0 0 0.25em;
	}
	.overview-dl {
		gap: 20px;
	}
	.overview-dl .dli {
		width: 100%;
	}
	.sr-list li {
		padding: 0 0 0 40px;
		font-size: 1.25rem;
	}
	.sr-list li br {
		display: none;
	}
	.csr-item {
		padding: 45px 30px;
	}
	.csr-ttl .num {
		font-size: 2rem;
	}
	.numbers-item {
		width: 100%;
	}

	/* 採用情報 */
	.interview-link-item a {
		display: flex;
		flex-direction: column;
		gap: 20px;
		aspect-ratio: auto;
		background: var(--grad-recruit);
	}
	.interview-link-img {
		position: relative;
		top: auto;
		left: auto;
	}
	.interview-link-img::before {
		display: none;
	}
	.interview-link-lead {
		max-width: 100%;
		margin: 0;
	}
	.interview-link-name {
		margin: 0 30px;
		padding-bottom: 45px;
	}
	.interview-lead-contents {
		gap: 45px;
	}
	.interview-lead-ttl {
		width: 100%;
	}
	.interview-lead-ttl .lead {
		font-size: 1.75rem;
	}
	.interview-lead-name .txt {
		font-size: 1.5rem;
	}
	.interview-lead-name .en {
		font-size: 1.1rem;
	}
	.interview-lead-img .en-cursive {
		left: 40%;
		font-size: 4rem;
	}
	.interview-img {
		flex: 0 0 100%;
	}
	.interview-qa h3::before {
		width: 2rem;
	}
	.c-vision-item {
		padding: 45px 0;
	}
	.c-vision-ttl {
		margin-bottom: 45px;
		padding: 1em 1em 1em calc(2.5% + 45px);
	}
	.c-vision-item {
		width: 100%;
	}
	.c-vision-contents {
		padding: 0 45px 0 calc(2.5% + 45px);
	}
	:is(.c-vision-task, .c-vision-seek) {
		width: 100%;
	}

	/* 投稿（お知らせ） */
	.single .entry-header {
		margin-bottom: 45px;
	}
	.single .entry-header h1 {
		font-size: 1.5rem;
	}

	/* お問い合わせ */
	.tel-num {
		font-size: 3rem;
	}
}
/* ------------------------------ レスポンシブ対応（780px以下） end ------------------------------ */


/* ------------------------------ レスポンシブ対応（576px以下） start ------------------------------ */
@media (max-width: 576px) {
	/* 共通 */
	.sec-ttl .en {
		font-size: 3rem;
	}
	.sec-ttl .en-cursive {
		width: 40%;
		font-size: 2.75rem;
	}
	.sec-ttl.jp .en {
		font-size: 1.25rem;
	}
	.sec-ttl.jp h2 {
		font-size: 2rem;
	}
	.sec-ttl.sub-page {
		flex-wrap: wrap;
		gap: 7.5px 20px;
	}
	.sec-ttl.sub-page h2 {
		width: 100%;
		max-width: 100%;
		font-size: 2rem;
	}
	.sec-ttl.sub-page .en {
		width: 100%;
		font-size: 1.125rem;
	}
	.rl-gallery-caption { font-size: 0.8em; }
	.pc-br { display: none; }
	.sp-br { display: block; }
	table td, table th { padding: 1.5em 1em; }
	.btn-base {
		min-width: 260px;
		padding: 15px 30px;
		font-size: 0.9em;
	}
	.msg-txt { line-height: 2; }

	/* ページヘッダー */
	.page-header {
		min-height: 15rem;
	}
	.page-header-title, h1.page-header-title {
		font-size: 6.5vw;
	}
	.page-header-subtext {
		font-size: 3.75vw;
	}

	/* フッター */
	.cta-contact {
		padding: 45px 20px;
	}
	.cta-mail .contact-btn {
		min-width: auto;
	}
	#menu-footer-nav {
		gap: 10px 0;
	}
	#menu-footer-nav > li {
		width: 100%;
	}
	#menu-footer-nav li a {
		padding: 10px 5px;
	}
	.ft-banner a {
		width: 50px;
	}

	/* フロントページ */
	.mv-swiper .swiper-slide.first-slide .swiper-slide-inner img {
		object-position: top 50% left 35%;
	}
	.mv-ttl h2 {
		font-size: 13vw;
	}
	.mv-ttl .en-cursive {
		left: 45%;
		font-size: 9.275vw;
	}
	.mv-ttl .txt {
		font-size: 3vw;
	}
	.scrolldown span {
		font-size: 0.6em;
	}
	#pg-19-1::after {
		left: 40%;
		width: 70%;
	}
	.strengths-link-list {
		gap: 10px;
	}
	.strengths-link-item a {
		gap: 10px;
		padding: 10px;
	}
	.strengths-link-num {
		min-width: 40px;
	}
	.strengths-link-num .num {
		font-size: 1.5rem;
	}
	.strengths-link-ttl h3 {
		font-size: 1.25rem;
	}
	.sec-ttl.service .en-cursive {
		font-size: 5.5rem;
	}
	.sec-ttl.company {
		padding: 0;
	}
	.sec-ttl.company .logo img {
		margin-top: 10px;
		max-width: 240px;
	}
	.sec-ttl.company .deco-logo-text {
		width: 150%;
		height: calc(100% + 120px);
	}
	.history-top-img-wrap {
		flex-direction: column;
		gap: 10px;
		margin: 0;
	}
	.history-top-img {
		width: 100%;
	}
	.company-link-item a {
		padding: 25px 0 0 20px;
	}
	.company-link-ttl .txt {
		font-size: 5vw;
	}
	.company-link-ttl .en {
		font-size: 2.5vw;
	}
	.recruit-link-item a {
		gap: 10px;
		padding: 10px;
	}
	#recruit-top-swiper .en-cursive {
		font-size: 3rem;
	}
	#recruit-top-swiper .loop-txt-wrap .loop-txt {
		font-size: 5rem;
	}

	/* サブページ共通 */
	.anchor-links li a {
		padding: 7.5px 0 7.5px 30px;
	}
	.anchor-links li a::before {
		left: 5px;
	}

	/* 横山運輸の強み */
	.con-base#strengths-lead {
		padding-bottom: 45px !important;
	}
	.strength-lead-img {
		aspect-ratio: 3/1.5;
	}
	.strengths-lead-contents .txt {
		font-size: 1.1rem;
	}
	.strength-item {
		gap: 45px;
		margin: 0 0 45px 0 !important;
	}
	.strength-item:nth-child(even) {
		margin: 0 0 45px 0 !important;
	}
	.strength-img::before {
		width: 90px;
		height: 90px;
	}
	.strength-contents {
		gap: 30px;
		margin: 0 0 0 20px;
	}
	.strength-item:nth-child(even) .strength-contents {
		margin: 0 20px 0 0;
	}
	.parent-pageid-23 .entry-body > div > div:first-child::after {
		left: 40%;
		width: 70%;
	}
	.strength-lead-contents .sec-ttl .num {
		font-size: 3rem;
	}
	.parent-pageid-23 .sec-ttl.jp h2 br {
		display: none;
	}
	.strength-lead-contents .txt {
		font-size: 1.1rem;
	}

	/* 事業内容 */
	.service-lead-outer .lead {
		font-size: 1.75rem;
		text-align: left;
	}
	.service-txt-outer {
		text-align: left;
	}
	.service-txt-outer .txt br:nth-of-type(2) {
		display: none;
	}
	.parent-pageid-2 .sec-ttl.jp h2 br {
		display: none;
	}
	.service-lead-img {
		height: 40svh;
	}
	.service-lead-txt-outer {
		margin-top: -45px;
		padding: 30px 20px 0 20px;
	}

	/* 会社案内 */
	.top-message-ttl h2 {
		font-size: 1.35rem;
		line-height: 1.8;
	}
	.top-msg-name-img {
		max-width: 100px;
	}
	.philo-wrap .lead br:first-of-type {
		display: none;
	}
	.slogan-wrap .en {
		font-size: 3rem;
	}
	.slogan-wrap .txt {
		font-size: 1rem;
	}
	.guidelines-ol li {
		font-size: 1.1rem;
	}
	.post-name-history .history-top-img {
		width: 100%;
	}
	.fleet-img {
		width: 100%;
	}
	.csr-item {
		padding: 45px 20px;
	}

	/* 採用情報 */
	.recruit-msg-txt-outer {
		text-align: left;
	}
	.recruit-msg-txt-outer .msg-txt br {
		display: none;
	}
	.numbers-ttl {
		margin-bottom: 15px;
	}
	.numbers-contents {
		gap: 15px;
	}
	.interview-link-lead .lead {
		font-size: 1.25rem;
	}
	.interview-lead-img .en-cursive {
		left: 35%;
		font-size: 3rem;
	}
	.club-item {
		width: 100%;
	}
	.con-base#entry .contact-btn {
		padding: 40px 30px;
	}

	/* 投稿（お知らせ） */
	.entry-title {
		font-size: 1.5rem;
	}

	/* お問い合わせ */
	.tel-num {
		font-size: 2.5rem;
	}
	.tel-num .fs-s {
		display: block;
		margin: 0 0 0.5em 0;
	}
	.contact-desc {
		font-size: 0.9em;
	}
	.cf7-btn .btn-base {
		min-width: 75%;
	}
}
/* ------------------------------ レスポンシブ対応（576px以下） end ------------------------------ */