:root	{
	--page-pad: 16px;
	--bg:#ffffff;
	--fg:#1f2937;
	--muted:#6b7280;
	--border:#e5e7eb;
	--shadow-sm:0 8px 26px rgba(2,6,23,.08);
}

*	{
	box-sizing:border-box;
}

img	{
	max-width:100%;
	height:auto;
	display:block;
}

.sep	{
	height:1px;
	background:var(--border);
}

header	{
	position:sticky;
	top:0;
	z-index:40;
	background: linear-gradient(180deg, #77889a 0%, #8899ab 85%, #b6c1d0 100%);
	-webkit-backdrop-filter:saturate(150%) blur(10px);
	backdrop-filter:saturate(150%) blur(10px);
	border-radius:0;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.65), 0 6px 18px rgba(2,6,23,.08);
}

.brand	{
	display:flex;
	align-items:center;
	gap:10px;
	font-weight:600;
}

.brand img	{
	height:45px;
	background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(255,255,255,.82));
	border-radius:15%;
	filter:drop-shadow(0 1px 2px rgba(0,0,0,.5));
	border-radius:8px;
	padding:1px;
	filter: saturate(1.2);
}

.brand a:hover img 	{
	filter: saturate(2.5);
}

.brand span	{
	font-size:1.8rem;
	font-weight:700;
	color:#fff;
	text-shadow:0 1px 2px rgba(5,5,5,.7);
}

nav	{
	display:flex;
	gap:14px;
}

nav a	{
	color:#fff;
	text-decoration:none;
	padding:8px 16px;
	border-radius:20px;
	transition:background .3s, border .3s;
	background:rgba(55,65,81,.3);
	border:1px solid rgba(255,255,255,.25);
}

nav a:hover	{
	background:rgba(255,255,255,.2);
	border-color:#fff;
}

.container	{
	min-width: 0;
	max-width: 100%;
	margin-inline: auto;
	box-sizing: border-box;
	background: transparent;
	padding : 10px;
}

.news	{
	margin:10px 0;
	padding:12px 16px 35px;
	background:rgba(255,255,255,.65);
	border-radius:18px;
	box-shadow:0 8px 28px rgba(2,6,23,.08);
	backdrop-filter:blur(6px);
	border:1px solid var(--border);
}

.news-list	{
	list-style:none;
	margin:12px 0 0;
	padding:0;
	display:flex;
	flex-direction:column;
	gap:8px;
}

.section-head	{
	display:flex;
	align-items:center;
	gap:8px;
	background:#e1e5e9;
	padding:4px 16px;
	border-radius:999px;
	border:1px solid rgba(15,23,42,.06);
	box-shadow:0 1px 2px rgba(2,6,23,.04);
	width:100%;
	margin:0 0 10px;
}

.company-head	{
	display:flex;
	align-items:center;
	gap:8px;
	background:#e1e5e9;
	padding:4px 16px;
	border-radius:999px;
	border:1px solid rgba(15,23,42,.06);
	box-shadow:0 1px 2px rgba(2,6,23,.04);
	width:100%;
	margin:0 0 10px;
}

.section-head .eyebrow	{
	font-size:.78rem;
	letter-spacing:.08em;
	color:#334155;
	background:rgba(255,255,255,.8);
	border-radius:999px;
	padding:4px 10px;
	white-space:nowrap;
}

.company-head .eyebrow	{
	font-size:.78rem;
	letter-spacing:.08em;
	color:#334155;
	background:rgba(255,255,255,.8);
	border-radius:999px;
	padding:4px 10px;
	white-space:nowrap;
}

.section-head h2	{
	margin:0;
	font-size:24px;
	line-height:1.3;
	font-weight:600;
	letter-spacing:.2px;
	color:#1e293b;
	padding-bottom:2px;
	position:relative;
	text-decoration:none;
}

.company-head .company-title	{
	margin:0;
	font-size:24px;
	line-height:1.3;
	font-weight:800;
	letter-spacing:.2px;
	color:#1e293b;
	padding-bottom:2px;
	position:relative;
	text-decoration:none;
}

.section-head h2::after	{
	content:"";
	position:absolute;
	left:0;
	bottom:0;
	width:100px;
	height:5px;
	border-radius:5px;
	background:#fff;
}

.company-head .company-title::after	{
	content:"";
	position:absolute;
	left:0;
	bottom:0;
	width:100px;
	height:5px;
	border-radius:5px;
	background:#fff;
}

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

.company-card	{
	width:95%;
	position:relative;
	display:flex;
	flex-direction:column;
	border:1px solid var(--border);
	border-radius:14px;
	background:#fff;
	box-shadow:var(--shadow-sm);
	overflow:hidden;
	transition:transform .25s ease,box-shadow .25s ease;
	text-decoration:none;
	color:inherit;
}

.company-card:hover	{
	transform:translateY(-2px);
	box-shadow:0 16px 36px rgba(2,6,23,.18);
}

.company-thumb 	{
	height: 250px;
	overflow: hidden;
}

.company-thumb img 	{
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center  35%;
	transform: scale(0.80);
	transition: transform .3s ease;
	margin:0;
}

.company-body	{
	display:flex;
	flex-direction:column;
	gap:6px;
	padding:0px 20px 20px;
	flex:1;
}

.company-label	{
	font-size:.8rem;
	color:var(--muted);
	line-height:.5;
	margin:0;
}

.company-card .company-title	{
	font-size:20px;
	margin:0px;
	font-weight:700;
	color:#1e293b;
	line-height:1.3;
	text-decoration:none;
}

.company-desc	{
	color:var(--muted);
	font-size:.95rem;
	line-height:1.5;
	margin:0;
}

.wide	{
	position:relative;
	display:block;
	border-radius:14px;
	overflow:hidden;
	border:1px solid var(--border);
	text-decoration:none;
	color:inherit;
	margin:10px 0;
	height:280px;
}

.wide .bg	{
	position:absolute;
	inset:0;
	background-size:cover;
	background-position:center;
	transform:scale(1.02);
	transition:transform .35s ease;
}

.wide .overlay	{
	position:absolute;
	inset:0;
	background:linear-gradient(0deg,rgba(2,6,23,.60),rgba(2,6,23,.22));
}

.wide .cap	{
	position:relative;
	z-index:1;
	width:100%;
	color:#fff;
	margin:0 auto;
	padding:24px 16px 22px;
}

.wide .cap h2	{
	margin:0 0 8px;
	font-size:clamp(26px,3.6vw,36px);
	font-weight:800;
	line-height:1.25;
	text-shadow:0 2px 10px rgba(0,0,0,.5);
}

.wide .cap p	{
	margin: 0 auto;
	font-size: 1.1rem;
	line-height: 1.5;
	color: #f1f5f9;
	text-shadow: 0 1px 6px rgba(0,0,0,.45);
}

.wide:hover .bg	{
	transform:scale(1.06);
}

.wide p	{
	margin:10px 16px 18px;
	color:#e8edf3;
	line-height:1.65;
	text-shadow:0 2px 8px rgba(0,0,0,.35);
}

.wide .section-head	{
	display:flex;
	align-items:center;
	gap:8px;
	width:100%;
	margin:0 0 12px;
	padding:4px 16px;
	border-radius:999px;
	background:rgba(255,255,255,.55);
	-webkit-backdrop-filter:blur(6px);
	backdrop-filter:blur(6px);
	border:1px solid rgba(255,255,255,.30);
	box-shadow:0 4px 16px rgba(0,0,0,.12);
	color:#1e293b;
}

.wide .section-head .eyebrow	{
	font-size:.78rem;
	letter-spacing:.08em;
	color:#334155;
	background:rgba(255,255,255,.8);
	border-radius:999px;
	padding:4px 10px;
	white-space:nowrap;
}

.wide .section-head h2	{
	margin:0;
	font-size:24px;
	line-height:1.3;
	font-weight:800;
	letter-spacing:.2px;
	color:#1e293b;
	width:66%;
	padding-bottom:2px;
	position:relative;
	text-decoration:none;
}

.wide .section-head h2::after	{
	content:"";
	position:absolute;
	left:0;
	bottom:0;
	width:100px;
	height:5px;
	border-radius:5px;
	background:#cbd5e1;
}

footer	{
	margin-top:10px;
	border-top:none;
	background: linear-gradient(180deg, #9fb0c1 0%, #8899ab 20%, #77889a 100%);
	color:#f9fafb;
	-webkit-backdrop-filter:saturate(150%) blur(10px);
	backdrop-filter:saturate(150%) blur(10px);
	border-radius:0;
}

.footer-inner	{
	width:100%;
	padding:20px 16px;
	display:flex;
	justify-content:space-between;
	align-items:center;
	margin:0 auto;
}

.footer-inner a	{
	color:#f9fafb;
	text-decoration:none;
}

.footer-inner a:hover	{
	text-decoration:underline;
}

.about-head 	{
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 12px;
	background: #f3f6f9;
	border: 1px solid #e5e7eb;
	margin: 10px 0 12px;
}

.about-tag 	{
	display: inline-block;
	font-size: 12px;
	letter-spacing: .12em;
	color: #475569;
	background: #eef2f7;
	border: 1px solid #d7dee6;
	border-radius: 999px;
	padding: 4px 10px;
	white-space: nowrap;
}

.about-title 	{
	margin: 0;
	font-size: 18px;
	font-weight: 700;
	color: #0f172a;
}

.about-info	{
	display:block;
	border: 2px solid #94a3b8;
	border-radius:12px;
	overflow:hidden;
	margin:10px;
	background:#fff;
}

.about-info > div	{
	display:grid;
	grid-template-columns: 230px 1fr;
	border-top: 2px solid #cbd5e1;
}

.about-info > div:first-child	{
	border-top:none;
}

.about-info dt	{
	padding:6px 20px;
	font-size:18px;
	line-height:1.7;
}

.about-info dt	{
  padding: 4px 14px;   /* 上下余白を軽く */
  font-size: 16px;     /* 少し小さめに */
  line-height: 1.5;    /* 行間も適度に */
	background: #f1f5f9;
	font-weight: 800;
	color:#1f2937;
	white-space:nowrap;
	border-right:1px solid #e2e8f0;
}

.about-info dd	{
  padding: 4px 14px;   /* 上下余白を軽く */
  font-size: 16px;     /* 少し小さめに */
  line-height: 1.5;    /* 行間も適度に */
	color:#0f172a;
	margin:0;
}

.about-links 	{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
	margin: 8px 0 16px;
}

.about-link 	{
	display: block;
	text-align: center;
	text-decoration: none;
	color: #0f172a;
	background: #ffffff;
	border: 1px solid #dfe3ea;
	border-radius: 10px;
	padding: 10px 8px;
	transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
}

.about-link:hover 	{
	border-color: #c6ccd7;
	box-shadow: 0 6px 20px rgba(2,6,23,.08);
	transform: translateY(-1px);
}

.about-philosophy 	{
	margin: 8px 0 18px;
}

.about-philosophy	{
	margin-inline: auto;
}

.about-philosophy img 	{
	display: block;
	width: 70%;
	height: auto;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	margin: 20px auto;
}

.group-head 	{
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px 16px;
	border-radius: 12px;
	background: linear-gradient(to bottom, #f3f6f9, #e0e4e8, #cfd4da);
	border: 1px solid #e5e7eb;
	margin: 18px auto 12px;
	width: auto;
	box-sizing: border-box;
}

.group-tag 	{
	display: inline-block;
	font-size: 12px;
	letter-spacing: .12em;
	color: #475569;
	background: #eef2f7;
	border: 1px solid #d7dee6;
	border-radius: 999px;
	padding: 4px 10px;
	white-space: nowrap;
}

.group-title 	{
	margin: 0;
	font-size: 26px;
	font-weight: 700;
	color: #0f172a;
}

.group-list 	{
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 20px;
	margin: 10px 0px;
}

.group-item 	{
	display: block;
	text-decoration: none;
	text-align: center;
	color: inherit;
	background: #fff;
	border: 1px solid #dfe3ea;
	border-radius: 12px;
	padding: 20px;
	transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
	margin: 10px 10px;
}

.group-item:hover 	{
	border-color: #c6ccd7;
	box-shadow: 0 10px 26px rgba(2,6,23,.08);
	transform: translateY(-1px);
}

.group-name 	{
	margin: 0 0 6px;
	font-size: 18px;
	font-weight: 700;
	color: #0f172a;
}

.group-text 	{
	margin: 0;
	margin-bottom: 8px;
	font-size: 15px;
	color: #374151;
	line-height: 1.7;
}

.group-img 	{
	width: 150px;
	height: auto;
	display: block;
	margin: 0 auto 12px;
	border-radius: 8px;
	object-fit: contain;
}

.page-recruit 	{
	--c-accent: #0ea5e9;
	--c-line: #e5e7eb;
	--c-card: #f9fafb;
	--c-sub: #6b7280;
	--c-txt: #111827;
}

.page-recruit .btn 	{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 16px;
	border: 1px solid var(--c-accent);
	border-radius: 999px;
	background: #e0f2fe;
	color: #075985;
	text-decoration: none;
	font-weight: 600;
	transition: transform .05s ease, background .2s ease;
}

.page-recruit .btn:hover 	{
	background: #bae6fd;
}

.page-recruit .btn:active 	{
	transform: translateY(1px);
}

.page-recruit .img4 	{
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

.page-recruit .img4 figure 	{
	margin: 0;
	border-radius: 12px;
	overflow: hidden;
	background: #f3f4f6;
	border: 1px solid var(--c-line);
	aspect-ratio: 4 / 3;
	max-height: 200px;
}

.page-recruit .img4 img 	{
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.page-recruit .jobs 	{
	display: grid;
	grid-template-columns:repeat(2, minmax(0,1fr));
	gap:20px;
}

.page-recruit .benefit-grid 	{
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
}

.page-recruit .benefit 	{
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: 12px;
	align-items: start;
	padding: 16px;
	border: 1px solid var(--c-line);
	border-radius: 16px;
	background: var(--c-card);
}

.page-recruit .benefit h3 	{
	margin: 0 0 6px;
	font-size: 16px;
}

.page-recruit .benefit p 	{
	margin: 0;
	font-size: 14px;
	color: var(--c-sub);
	line-height: 1.8;
}

.page-recruit .ico 	{
	width: 36px;
	height: 36px;
	display: grid;
	place-items: center;
	border-radius: 10px;
	background: #5fccdd;
	border: 1px solid #bfdbfe;
}

.page-recruit .ico svg 	{
	width: 20px;
	height: 20px;
	color: #fff;
}

.page-recruit .data-grid 	{
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
}

.page-recruit .data-card 	{
	text-align: center;
	border: 1px solid var(--c-line);
	border-radius: 16px;
	background: linear-gradient(180deg, #fff, #f8fafc 70%);
	padding: 16px;
}

.page-recruit .data-ttl 	{
	font-size: 13px;
	color: var(--c-sub);
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 6px;
}

.page-recruit .data-num 	{
	font-size: 28px;
	font-weight: 700;
	letter-spacing: .02em;
	color:#555555;
}

.page-recruit .voice-block 	{
	margin-top: 32px;
}

.page-recruit .voice-block .sec-ttl 	{
	font-size: 22px;
	margin-bottom: 14px;
	display: flex;
	align-items: center;
	gap: 10px;
}

.page-recruit .voice-block .sec-ttl span	{
	display:inline-block;
	width:6px;
	height:18px;
	border-radius:3px;
	background:#0ea5e9;
}

.page-recruit .voice-bubble	{
	display:flex;
	align-items:flex-start;
	gap:16px;
}

.page-recruit .voice-avatar	{
	position: relative;
	flex:0 0 72px;
	height:72px;
	border-radius:50%;
	overflow:hidden;
	background:#fff;
	box-shadow:0 2px 8px rgba(2,6,23,.08);
}

.page-recruit .voice-avatar img	{
	width:100%;
	height:100%;
	object-fit:cover;
	display:block;
}

.page-recruit .voice-avatar .avatar-fallback	{
	position:absolute;
	inset:0;
	display:grid;
	place-items:center;
	background: radial-gradient(circle at 30% 25%, #e6f1ff, #cfe3ff);
	color:#1e3a8a;
	font-weight:800;
	font-size:20px;
}

.page-recruit .voice-avatar .avatar-fallback::after	{
	content: attr(data-initial);
}

.page-recruit .voice-balloon	{
	position:relative;
	flex:1;
	background: linear-gradient(#f4faff,#eef7ff);
	border:1px solid #cfe3ff;
	color:#0f172a;
	border-radius:14px;
	padding:16px 18px;
	box-shadow: 0 2px 10px rgba(2,6,23,.06) inset;
}

.page-recruit .voice-balloon::before	{
	content:"";
	position:absolute;
	left:-10px;
	top:20px;
	width:0;
	height:0;
	border:10px solid transparent;
	border-right-color:#cfe3ff;
}

.page-recruit .voice-balloon::after	{
	content:"";
	position:absolute;
	left:-8px;
	top:21px;
	width:0;
	height:0;
	border:9px solid transparent;
	border-right-color:#f4faff;
}

.page-recruit .voice-balloon p	{
	margin:0 0 10px;
	line-height:1.85;
	letter-spacing:.01em;
}

.page-recruit .voice-meta	{
	color:#475569;
	font-size:12px;
	margin-bottom:8px;
}

.page-recruit .voice-link	{
	display:inline-block;
	padding:8px 14px;
	font-weight:700;
	border:1px solid #3b82f6;
	color:#1e40af;
	border-radius:999px;
	background:#eef6ff;
	text-decoration:none;
	transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
}

.page-recruit .voice-link:hover	{
	transform: translateY(-1px);
	background:#e0efff;
	border-color:#2563eb;
}

.page-recruit .section 	{
	padding: 36px 0;
	border-top: 1px solid #e5e7eb;
}

.page-recruit .section:first-of-type 	{
	border-top: none;
	padding-top: 0;
}

.page-recruit h2.sec-ttl 	{
	margin: 0 0 35px 5px;
	font-size: 24px;
	letter-spacing: .08em;
	display: flex;
	align-items: center;
	gap: 10px;
}

.page-recruit h2.sec-ttl .bar 	{
	width: 6px;
	height: 20px;
	border-radius: 6px;
	background: #0ea5e9;
}

.page-recruit .lead 	{
	color: #6b7280;
	margin: 6px 0 0;
	font-size: 14px;
}

.about-info	{
	margin-inline: auto;
}

.company-grid	{
	margin-inline: auto;
}

.group-list 	{
	margin-inline: auto;
}

.sec-ttl-img 	{
	display: block;
	max-width: 100%;
	height: auto;
	margin: 0 auto;
}

.page-recruit .job-card--compact	{
	position: relative;
	display: flex;
	align-items: center;
	gap: 15px;
	padding: 5px 5px;
	border: 2px solid #5b6b84;
	border-radius: 16px;
	background: linear-gradient(180deg,#fff,#fffbff);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.8), inset 0 -1px 0 rgba(2,6,23,.04), 0 2px 8px rgba(2,6,23,.07);
	text-decoration: none;
	transition: transform .2s, box-shadow .2s, border-color .2s;
}

.page-recruit .job-card--compact:hover	{
	transform: translateY(-2px);
	border-color: #2e5ae1;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.9), inset 0 -1px 0 rgba(2,6,23,.05), 0 6px 16px rgba(2,6,23,.12);
}

.page-recruit .job-thumb	{
	position: relative;
	flex: 0 0 100px;
	height: 100px;
	border-radius: 50%;
	overflow: hidden;
	background:#fff;
	box-shadow: 0 2px 6px rgba(2,6,23,.08);
}

.page-recruit .job-thumb::after	{
	content:"";
	position:absolute;
	inset:-10%;
	border-radius:50%;
	background: radial-gradient(ellipse at 50% 40%, rgba(96,165,250,.35) 0%, rgba(59,130,246,.18) 45%, rgba(59,130,246,0) 65%);
	z-index:0;
	pointer-events:none;
}

.page-recruit .job-thumb img	{
	position: relative;
	z-index:1;
	width:100%;
	height:100%;
	object-fit:cover;
	filter: drop-shadow(0 1px 1px rgba(2,6,23,.06));
	transition: transform .25s ease;
}

.page-recruit .job-card--compact:hover .job-thumb img	{
	transform: scale(1.02);
}

.page-recruit .job-info	{
	flex:1;
	display:flex;
	align-items:center;
}

.page-recruit .job-title	{
	font-size: clamp(24px, 2.2vw, 26px);
	font-weight: 600;
	line-height: 1.35;
	letter-spacing: .3px;
	font-feature-settings: "palt" 1;
	color:#0f172a;
	text-decoration: none;
	font-feature-settings: "palt" 0;
	letter-spacing: 0.1em;
	padding-left:30px;
}

.page-recruit .job-card--compact:hover .job-title	{
	text-decoration:none;
}

.page-recruit .data-card:nth-child(1) .data-num::after 	{
	content: "人";
}

.page-recruit .data-card:nth-child(2) .data-num::after 	{
	content: "歳";
}

.page-recruit .data-card:nth-child(3) .data-num::after 	{
	content: "日";
}

.page-recruit .data-card:nth-child(4) .data-num::after 	{
	content: "時間";
}

.page-recruit .license dl	{
	display:grid;
	grid-template-columns: 1fr auto;
	column-gap: 6px;
	row-gap: 12px;
	align-items:center;
}

.page-recruit .license dl div 	{
	display: flex;
	align-items: center;
	gap: 6px;
}

.page-recruit .license dt	{
	padding: 8px 6px 8px 12px;
	font-size: 15px;
	font-weight: 700;
	color: #0f172a;
	border: 1px solid #cbd5e1;
	border-radius: 10px;
	background: linear-gradient(90deg, #dbeafe calc(var(--p,0) * 1%), transparent 0), #fff;
	background-clip: padding-box;
	position: relative;
}

.page-recruit .license dt::before	{
	content: none;
}

.page-recruit .license dd 	{
	flex: none;
	width: 58px;
	height: 58px;
	border-radius: 50%;
	background: #eff6ff;
	border: 1px solid #bfdbfe;
	color: #1e3a8a;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2px;
	font-weight: 800;
}

.page-recruit .license dd .num 	{
	font-size: 24px;
	line-height: 1;
}

.page-recruit .license dd .unit 	{
	position: relative;
	top: 2px;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.2;
}

.page-recruit .badge-new 	{
	display: inline-block;
	margin-left: 12px;
	padding: 4px 10px;
	font-size: 15px;
	font-weight: 700;
	color: #dc2626;
	border: 2px solid #dc2626;
	border-radius: 6px;
	background: #fff;
	line-height: 1.4;
	vertical-align: middle;
	transform: rotate(-10deg);
}

.page-recruit .job-info 	{
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 10px;
}

.page-recruit .voice-mosaic	{
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.page-recruit .voice-mosaic figure	{
	overflow: hidden;
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 1px 4px rgba(2,6,23,.06);
	aspect-ratio: 4/3;
}

.page-recruit .voice-mosaic img	{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .25s ease;
}

.page-recruit .voice-mosaic img:hover	{
	transform: scale(1.035);
}

.page-recruit .sec-voice h2	{
	display:flex;
	align-items:center;
	gap:8px;
	font-size:22px;
	font-weight:700;
	color:#111;
	margin: 0 0 16px;
}

.page-recruit .sec-voice h2::before	{
	content:"";
	width:4px;
	height:20px;
	border-radius:2px;
	background:#3b82f6;
}

.page-recruit .voice-grid	{
	--g: 24px;
	display:grid;
	grid-template-columns: repeat(4, minmax(0,1fr));
	gap: var(--g);
}

.page-recruit .voice-shot	{
	width:100%;
	display:block;
	border-radius:12px;
	box-shadow: 0 2px 6px rgba(0,0,0,.04);
}

.page-recruit .voice-box	{
	grid-column: 1 / -1;
	display:grid;
	grid-template-columns: 1fr auto;
	align-items:center;
	gap:16px;
	padding: clamp(16px, 2vw, 24px);
	border-radius:12px;
	background:#f9fbff;
	border:1px solid #e0e7ff;
	box-shadow: 0 2px 6px rgba(0,0,0,.04);
	width:100%;
}

.page-recruit .voice-box p	{
	margin:0;
	font-size: clamp(16px, 1.8vw, 17.5px);
	line-height:1.85;
	word-break: normal;
	overflow-wrap: anywhere;
}

.page-recruit .voice-box .voice-link	{
	justify-self: end;
	display: inline-block;
	padding: 14px 28px;
	font-size:16px;
	font-weight:500;
	color:#fff;
	text-decoration:none;
	background:#0ea5e9;
	border-radius: 45px;
	box-shadow: 0 2px 6px rgba(14,165,233,.25);
	transition: background .2s, transform .15s, box-shadow .2s;
}

.page-recruit .voice-box .voice-link:hover	{
	background:#0284c7;
	transform: translateY(-2px);
	box-shadow: 0 4px 10px rgba(2,132,199,.3);
}

.page-recruit .voice-box .voice-link:active	{
	transform: translateY(0);
	box-shadow: 0 2px 6px rgba(0,0,0,.15);
}

.page-works .works-intro	{
	margin: 22px auto 0;
	padding: 0 16px;
}

.page-works .works-intro p	{
	font-size: clamp(16.5px, 1.85vw, 19px);
	line-height: 1.95;
	letter-spacing: .01em;
	color: #111827;
	margin: 0;
	text-align: left;
	margin: 0 0 20px;
}

.page-works .works-list	{
	background: #f6f8fb;
	padding: 24px 0 40px;
}

.page-works .works-grid	{
	margin: 12px auto 0;
	padding: 0 16px;
	display: grid;
	grid-template-columns: repeat(6, minmax(0, 1fr));
	gap: 18px;
}

.page-works .works-item	{
	aspect-ratio: 4 / 3;
	display: grid;
	grid-template-rows: 1fr auto;
	overflow: hidden;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 1px 2px rgba(2,6,23,.04);
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.page-works .works-item:hover	{
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(2,6,23,.10);
	border-color: #dbe1ea;
}

.page-works .works-item > img	{
	grid-row: 1;
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
	margin: 0;
	padding: 0;
}

#about .about-info	{
	max-width: 100%;
	margin-inline: 0;
}

#about .about-philosophy	{
	max-width: 100%;
	margin-inline: 0;
}

#about .company-grid	{
	max-width: 100%;
	margin-inline: 0;
}

#group .group-list	{
	max-width: 100%;
	margin-inline: 0;
}

.ph-duo__wrap	{
	display:grid;
	grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
	gap: clamp(24px, 4vw, 56px);
	max-width: min(1320px, 96vw);
	margin-inline:auto;
}

.page-works .works-item	{
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: #fff;
	overflow: hidden;
	padding-top: 16px;
	padding-bottom: 48px;
	box-shadow: 0 1px 2px rgba(2,6,23,.04);
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

.page-works .works-item	{
	position: relative;
	overflow: visible;
	padding: 62px;
}

.page-works .works-caption	{
	position: absolute;
	left: 8px;
	right: 8px;
	bottom: 8px;
	height: 40px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 12px;
	margin: 0;
	background: linear-gradient( 90deg, rgba(0, 149, 255, 0.28) 0%, rgba(0, 191, 255, 0.22) 100% );
	box-shadow: none;
	border: none;
	border-radius: 0 0 8px 8px;
	-webkit-backdrop-filter: saturate(120%) blur(2px);
	backdrop-filter: saturate(120%) blur(2px);
	font-size: clamp(16px, 1.8vw, 18px);
	font-weight: 600;
	letter-spacing: .05em;
	color: #1f2937;
	line-height: 1.2;
	transition: transform .15s ease, box-shadow .2s ease, border-color .2s ease;
}

.page-works .works-item:hover 	{
	transform: translateY(-2px);
	box-shadow: inset 0 1px 0 rgba(255,255,255,.95), inset 0 -1px 0 rgba(0,0,0,.05), 0 8px 18px rgba(0,0,0,.12);
}

.page-works .works-item > img	{
	filter: grayscale(100%) contrast(118%) brightness(1.02);
}

.ph-duo 	{
	--ink: #0f172a;
	--blue: #3b82f6;
	--amber: #f59e0b;
	--green: #22c55e;
	--ring: #e5e7eb;
	--circle: 230px;
	--overlap: 32px;
	padding: 24px 16px;
}

.ph-duo__wrap 	{
	max-width: 1240px;
	margin-inline: auto;
	display: grid;
	grid-template-columns: minmax(0,1.5fr) minmax(0,1fr);
	gap: 44px;
	align-items: start;
}

.ph-duo__head 	{
	margin: 0 0 12px;
	text-align: center;
	line-height: 1.14;
}

.ph-duo__en 	{
	display: block;
	font-size: 11px;
	letter-spacing: .18em;
	color: #64748b;
	font-weight: 600;
	margin: 0 0 2px;
}

.ph-duo__ja 	{
	display: block;
	font-size: 26px;
	font-weight: 800;
	color: var(--ink);
}

.ph-head--stack 	{
	display: block;
	gap: 0;
}

.ph-duo__left 	{
	display: flex;
	flex-direction: column;
	align-items: center;
}

.ph-duo__trio 	{
	width: 100%;
	margin: 6px 0 16px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.ph-duo__pill 	{
	width: var(--circle);
	height: var(--circle);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font: 800 22px/1 system-ui, -apple-system, "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	letter-spacing: .04em;
	text-align: center;
}

.ph-duo__pill + .ph-duo__pill 	{
	margin-left: calc(var(--overlap) * -1);
}

.ph-duo--outline .pill--blue 	{
	color: var(--blue);
	border: 6px solid var(--blue);
	font-size:26px;
}

.ph-duo--outline .pill--amber 	{
	color: var(--amber);
	border: 6px solid var(--amber);
	font-size:26px;
}

.ph-duo--outline .pill--green 	{
	color: var(--green);
	border: 6px solid var(--green);
	font-size:26px;
}

.ph-duo__messagebox	{
	width: 100%;
	margin-top: 20px;
	background: #fff;
	border: 1px solid var(--ring);
	border-radius: 10px;
	padding: 26px 40px 26px 48px;
	font-size: 17px;
	line-height: 1.9;
	color: #374151;
}

.ph-duo__messagebox br	{
	display:block;
	content:"";
	margin-bottom:.5em;
}

.ph-duo__right	{
	align-self: start;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.ph-duo__creed	{
	list-style: none;
	padding: 0;
	margin: 16px auto 12px;
	max-width: 600px;
	width: 100%;
}

.ph-duo__creed li	{
	display:flex;
	align-items:center;
	gap:.6em;
	margin: 10px 0;
	padding: 18px 55px 16px 55px;
	min-height: 96px;
	font-size: 24px;
	font-weight: 800;
	letter-spacing:.02em;
	color:#0f172a;
	background: linear-gradient(145deg,#ffffff 0%,#f8fafc 100%);
	border: 1px solid rgba(255,255,255,.6);
	border-top-color: rgba(255,255,255,.9);
	border-left-color: rgba(255,255,255,.9);
	border-radius: 16px;
	box-shadow: inset 0 2px 4px rgba(255,255,255,.7), 0 6px 12px rgba(0,0,0,.08), 0 12px 28px rgba(0,0,0,.08);
	text-shadow: 0 1px 1px rgba(255,255,255,.8), 1px 2px 2px rgba(0,0,0,.20);
}

.ph-duo__mark	{
	flex-shrink:0;
	font-size:26px;
	font-weight:900;
	color:inherit;
	line-height:1;
	margin-right:.6em;
}

.ph-duo__trio	{
	width: 96%;
	margin-inline:auto;
	box-sizing:border-box;
}

.ph-duo__messagebox	{
	width: 96%;
	margin-inline:auto;
	box-sizing:border-box;
}

.ph-duo	{
	--circle: clamp(140px, 26vw, 260px);
	--overlap: clamp(16px, 6vw, 48px);
}

.ph-duo__pill	{
	width: var(--circle);
	aspect-ratio: 1 / 1;
	height: auto;
	border-radius: 50%;
	box-sizing: border-box;
	display:grid;
	place-items:center;
	font-weight: 800;
	font-size: clamp(16px, 3.2vw, 22px);
	border: .35rem solid currentColor;
}

.ph-duo__pill + .ph-duo__pill	{
	margin-left: calc(var(--overlap) * -1);
}

.page-history .history-timeline	{
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5px 20px;
}

.page-history .history-timeline > li	{
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	gap: 5px;
	padding: 3px 0;
}

.page-history .history-timeline .point	{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	height: 36px;
	padding: 0 12px;
	border-radius: 999px;
	background: #f1f5f9;
	border: 1px solid #e2e8f0;
	line-height: 1;
	white-space: nowrap;
	font-variant-numeric: tabular-nums;
}

.page-history .history-timeline .point .era 	{
	display:block;
	font-weight:700;
	font-size:14px;
	color:#334155;
}

.page-history .history-timeline .point .year 	{
	display:block;
	font-weight:700;
	font-size:14px;
	color:#0f172a;
}

.page-history .history-timeline .point .month	{
	display:block;
	font-weight:600;
	font-size:12px;
	color:#475569;
}

.page-history .history-timeline .desc	{
	padding: 8px 12px;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: #fff;
	box-shadow: 0 1px 2px rgba(2,6,23,.04);
	line-height: 1.6;
}

.page-history .history-timeline > li.hr 	{
	list-style: none;
	grid-column: 1 / -1;
	border-top: 1px solid #e5e7eb;
	margin: 5px 0;
	padding: 0;
}

.page-history .history-timeline > li.era-hr	{
	grid-column: 1 / -1;
	list-style: none;
	margin: 24px 0 10px;
	padding: 0;
	position: relative;
	height: 0;
}

.page-history .history-timeline > li.era-hr::before	{
	content:"";
	position:absolute;
	left:0;
	right:0;
	top:0;
	height:1px;
	background:#e5e7eb;
}

.page-history .history-timeline > li.era-hr .label	{
	position:absolute;
	top:0;
	left:0;
	transform: translateY(-50%);
	padding: 2px 8px;
	font-weight: 700;
	font-size: 12px;
	line-height: 1;
	border-radius: 999px;
	background:#fff;
	color:#334155;
	border:1px solid #e5e7eb;
}

.page-history .history-timeline > li.era-hr[data-era="M"] .label	{
	background:#fff5f6;
	border-color:#fde2e7;
	color:#a11234;
}

.page-history .history-timeline > li.era-hr[data-era="S"] .label	{
	background:#f7f8fb;
	border-color:#e5e7eb;
	color:#334155;
}

.page-history .history-timeline > li.era-hr[data-era="H"] .label	{
	background:#f0fbfd;
	border-color:#cfeff6;
	color:#0e7490;
}

.page-history .history-timeline > li.era-hr[data-era="R"] .label	{
	background:#eef4ff;
	border-color:#dbe7ff;
	color:#1d4ed8;
}

.page-message	{
	color:#1a1a1a;
}

.page-message .message-block .container	{
	max-width:1400px;
	margin:40px auto;
	padding:0 16px;
}

.page-message .message-layout	{
	display:grid;
	grid-template-columns:2fr 1fr;
	gap:40px;
	align-items:start;
}

.page-message .message-inner p	{
	font-family:"游明朝","Yu Mincho","MS PMincho",serif;
	line-height:1.9;
	margin:0 0 1.4em;
	font-size:17px;
	letter-spacing:.02em;
	text-align:justify;
	text-indent:1em;
}

.page-message .ceo-profile img	{
	display:block;
	width:100%;
	max-width:280px;
	height:auto;
	margin:0 auto 16px;
}

.page-message .ceo-sign	{
	text-align:center;
}

.page-message .ceo-sign p	{
	margin:0;
	font-family:"游明朝","Yu Mincho","MS PMincho",serif;
}

.page-message .ceo-sign .name	{
	font-size:18px;
	font-weight:700;
	letter-spacing:.1em;
}

.company-card	{
	box-shadow: 0 1px 2px rgba(2,6,23,.04), 0 6px 20px rgba(2,6,23,.04);
}

.page-initiatives .section p 	{
	font-size: 18px;
	line-height: 1.9;
	color: #374151;
	margin-bottom: 1.2em;
}

.page-initiatives .icon-row 	{
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 10px 0 20px;
	align-items: center;
}

.page-initiatives .icon-row img 	{
	height: 100px;
	width: auto;
	object-fit: contain;
}

.page-works .initiatives-fuji p 	{
	font-size: 18px;
	line-height: 1.85;
	margin: 0 0 1.2em;
	color: #374151;
}

.page-works .initiatives-fuji .btn-wrap 	{
	margin-top: 16px;
}

.page-works .initiatives-fuji .btn-link 	{
	display: inline-block;
	padding: 12px 22px;
	font-size: 18px;
	font-weight: 600;
	color: #fff;
	background: #0ea5e9;
	border-radius: 9999px;
	text-decoration: none;
	transition: background .2s, transform .15s;
}

.page-works .initiatives-fuji .btn-link:hover 	{
	background: #0284c7;
	transform: translateY(-2px);
}

.page-works .initiatives-fuji .btn-link:active 	{
	transform: translateY(0);
}

.page-initiatives p 	{
	font-size: clamp(18px, 1.1vw, 20px);
	line-height: 1.9;
}

.page-works .fuji-ttl	{
	margin: 0 0 6px;
	font-size: clamp(22px, 2.8vw, 30px);
	font-weight: 800;
	letter-spacing: .06em;
	color: #0f172a;
}

.page-works .fuji-lead	{
	margin: 4px 0 6px;
	color: #334155;
	font-weight: 600;
}

.page-works .fuji-text	{
	margin: 0 0 12px;
	color: #374151;
}

.page-initiatives .btn-link--lg	{
	display: inline-block;
	padding: 14px 26px;
	font-size: 16px;
	font-weight: 700;
	color: #fff;
	background: #0ea5e9;
	border-radius: 9999px;
	text-decoration: none;
	box-shadow: 0 3px 10px rgba(14,165,233,.3);
	transition: background .2s, transform .15s, box-shadow .2s;
}

.page-initiatives .btn-link--lg:hover	{
	background:#0284c7;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(2,132,199,.35);
}

.page-initiatives .icon-row--lg img	{
	height: 72px;
}

.page-initiatives .sdgs-grid 	{
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 28px 32px;
	margin-top: 20px;
}

.page-initiatives .sdgs-block h3 	{
	margin-bottom: 10px;
	font-size: 18px;
	font-weight: 700;
	color: #0f172a;
}

.page-voice 	{
	font: 15px/1.6 system-ui, -apple-system, "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	color:#0f172a;
}

.page-voice .voice-cards	{
	background: linear-gradient(180deg,#f5f7fb 0,#fff 60%), #fff;
	padding: clamp(28px,6vw,72px) 0;
}

.page-voice .voice-card	{
	display: grid;
	grid-template-columns: 1fr;
	gap: 18px;
	padding: clamp(16px,3vw,22px);
	margin: 0 auto clamp(22px,3.8vw,36px);
	background:#fff;
	border:1px solid #e5e7eb;
	border-radius:16px;
	box-shadow: 0 6px 18px rgba(0,0,0,.04);
}

.page-voice .voice-card__media	{
	border-radius:12px;
	overflow:hidden;
	background:#f3f4f6;
	aspect-ratio: 4 / 3;
}

.page-voice .voice-card__media img	{
	width:100%;
	height:100%;
	object-fit:cover;
	display:block;
	transform: scale(1.01);
}

.page-voice .voice-card__body	{
	display: grid;
	gap: 8px;
}

.page-voice .voice-card__name	{
	font-size: clamp(18px,2.5vw,22px);
	font-weight:700;
	margin:0;
}

.page-voice .voice-card__dept	{
	color:#1d4ed8;
	font-weight:800;
	margin-right:.4em;
}

.page-voice .voice-card__year	{
	color:#64748b;
	font-weight:600;
}

.page-voice .voice-card__subtitle	{
	font-size: clamp(15px,2.1vw,18px);
	font-weight:700;
	margin:4px 0 2px;
}

.page-voice .voice-card__text	{
	margin:0;
	text-align:justify;
	text-justify: inter-ideograph;
}

.page-voice .voice-card:last-child	{
	margin-bottom:0;
}

.page-voice .voice-cards .container 	{
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-areas: "card1 card2" "card3 card3";
	gap: 32px;
}

.page-voice .voice-cards .voice-card 	{
	margin: 0;
	width: 100%;
}

.page-voice .voice-card:nth-child(1) 	{
	grid-area: card1;
}

.page-voice .voice-card:nth-child(2) 	{
	grid-area: card2;
}

.page-voice .voice-card:nth-child(3) 	{
	grid-area: card3;
}

.page-voice .voice-card__body p 	{
	margin: 0 0 1em;
	line-height: 1.8;
}

.page-voice .voice-card__body p:last-child 	{
	margin-bottom: 0;
}

.page-voice .voice-cards 	{
	padding: 40px 0 60px;
}

.page-voice .voice-card__body h2 	{
	margin: 0 0 4px;
}

.page-voice .voice-card__body h3 	{
	margin: 0 0 8px;
	font-size: 16px;
	font-weight: 600;
	color: #333;
}

.page-voice .voice-card__body p 	{
	margin: 0 0 1em;
	line-height: 1.7;
}

.page-voice .voice-card__body p:first-of-type 	{
	margin-top: 0;
}

.voice-card__body h2 	{
	display: inline-block;
	background: linear-gradient(transparent 60%, #fef08a 60%);
	padding: 0 4px;
}

.page-patrol .patrol-intro p 	{
	margin-top: .8em;
	font-size:18px;
}

.page-patrol .title-band 	{
	margin: 28px 0 16px;
	padding: 10px 14px;
	background: #fff;
	border: 1px solid #e5e7eb;
	border-left: 6px solid #60a5fa;
	border-radius: 8px;
}

.page-patrol .title-band h2 	{
	margin: 0;
	font-weight: 700;
}

.page-patrol .title-band .year 	{
	color: #1e40af;
}

.page-patrol .patrol-grid 	{
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 18px;
}

.page-patrol .patrol-item 	{
	border: 1px solid #e5e7eb;
	border-radius: 14px;
	background: #fff;
	overflow: clip;
	transition: transform .15s ease, box-shadow .15s ease;
}

.page-patrol .patrol-item:has(.patrol-link:hover) 	{
	transform: translateY(-1px);
	box-shadow: 0 6px 18px rgba(2,6,23,.08);
}

.page-patrol .patrol-link 	{
	display: block;
	color: inherit;
	text-decoration: none;
}

.page-patrol .thumb 	{
	aspect-ratio: 1/1;
	background: #f8fafc;
	overflow: hidden;
}

.page-patrol .thumb img 	{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform: scale(1.02);
	transition: transform .25s ease;
}

.page-patrol .patrol-link:hover .thumb img 	{
	transform: scale(1.06);
}

.page-patrol .caption 	{
	padding: 10px 12px 12px;
}

.page-patrol .caption .date 	{
	font-size: 13px;
	color: #334155;
	margin-bottom: 4px;
}

.page-patrol .caption .title 	{
	font-weight: 700;
	text-align:center;
}

.page-policy details 	{
	border: 1px solid #e5e7eb;
	border-radius: 8px;
	margin-bottom: 14px;
	background: #fff;
	overflow: hidden;
}

.page-policy summary 	{
	cursor: pointer;
	padding: 12px 16px;
	font-weight: 600;
	font-size: 16px;
	list-style: none;
	position: relative;
}

.page-policy summary::marker 	{
	display: none;
}

.page-policy summary::after 	{
	content: "＋";
	position: absolute;
	right: 16px;
	transition: transform .2s;
}

.page-policy details[open] summary::after 	{
	content: "－";
}

.page-policy .content 	{
	padding: 0 16px 16px;
	border-top: 1px solid #e5e7eb;
	background: #f9fafb;
	font-size: 14px;
}

.page-policy .contact-box 	{
	border: 2px solid #60a5fa;
	border-radius: 8px;
	padding: 16px;
	background: #f0f9ff;
}

.page-policy .contact-box h2 	{
	font-size: 16px;
	margin: 0 0 8px;
	color: #1e40af;
}

.page-job 	{
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	line-height: 1.6;
	font-size: 15px;
	color: #0f172a;
}

.page-job .breadcrumb 	{
	background: #f8fafc;
	border-top: 1px solid #e5e7eb;
	border-bottom: 1px solid #e5e7eb;
}

.page-job .breadcrumb ol 	{
	margin: 0 auto;
	padding: 8px 16px;
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	list-style: none;
}

.page-job .breadcrumb a 	{
	color: #2563eb;
	text-decoration: none;
}

.page-job .breadcrumb li::after 	{
	content: "›";
	margin: 0 .4rem;
	color: #94a3b8;
}

.page-job .breadcrumb li:last-child::after 	{
	content: "";
}

.page-job .job-container 	{
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: 32px;
	align-items: start;
}

.page-job .job-table-wrap 	{
	background: #fff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	overflow-x: hidden;
	box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.page-job .job-table 	{
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	table-layout: fixed;
}

.page-job .job-table th	{
	padding: 14px 16px;
	vertical-align: top;
	border-bottom: 1px solid #e5e7eb;
	white-space: normal !important;
	word-break: break-word;
	overflow-wrap: anywhere;
	hyphens: auto;
}

.page-job .job-table td	{
	padding: 14px 16px;
	vertical-align: top;
	border-bottom: 1px solid #e5e7eb;
	white-space: normal !important;
	word-break: break-word;
	overflow-wrap: anywhere;
	hyphens: auto;
}

.page-job .job-table th 	{
	background: #f8fafc;
	color: #0f172a;
	text-align: left;
	font-weight: 500;
	width: 30%;
}

.page-job .job-table tr:first-child th 	{
	border-top-left-radius: 12px;
}

.page-job .job-table tr:first-child td 	{
	border-top-right-radius: 12px;
}

.page-job .job-table tr:last-child th	{
	border-bottom: none;
}

.page-job .job-table tr:last-child td	{
	border-bottom: none;
}

.page-job .job-table small 	{
	color: #64748b;
}

.page-job .job-note 	{
	margin: 14px 0 0;
	font-weight: 600;
	color: #0f172a;
	background: #fff7ed;
	border: 1px solid #fed7aa;
	padding: 10px 12px;
	border-radius: 10px;
}

.page-job .job-actions 	{
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 18px;
}

.page-job .btn 	{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 16px;
	border-radius: 10px;
	border: 1px solid #cbd5e1;
	text-decoration: none;
	color: #0f172a;
	background: #fff;
	transition: transform .06s ease, box-shadow .2s ease, background .2s ease;
	box-shadow: 0 1px 1px rgba(0,0,0,.04);
}

.page-job .btn:hover 	{
	transform: translateY(-1px);
}

.page-job .btn:active 	{
	transform: translateY(0);
}

.page-job .btn-primary 	{
	background: #2563eb;
	border-color: #2563eb;
	color: #fff;
}

.page-job .btn-primary:hover 	{
	filter: brightness(1.04);
}

.page-job .btn-primary:active 	{
	filter: brightness(.98);
}

.page-job .btn-outline 	{
	background: #fff;
	color: #2563eb;
	border-color: #2563eb;
}

.page-job .btn-block 	{
	width: 100%;
}

.page-job .job-aside 	{
	position: sticky;
	top: 16px;
}

.page-job .aside-card 	{
	background: #ffffff;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	padding: 16px;
	box-shadow: 0 1px 2px rgba(0,0,0,.04);
}

.page-job .aside-card + .aside-card 	{
	margin-top: 16px;
}

.page-job .aside-card h3	{
	margin: 0 0 8px;
	font-weight: 700;
}

.page-job .aside-card h4	{
	margin: 0 0 8px;
	font-weight: 700;
}

.page-job .aside-card .tel a 	{
	font-size: 20px;
	font-weight: 800;
	letter-spacing: .02em;
	text-decoration: none;
	color: #0f172a;
}

.page-job .aside-tips ul 	{
	margin: 0 0 8px;
	padding-left: 1.1em;
}

.page-job .aside-tips .small 	{
	color: #64748b;
	font-size: 13px;
}

.page-job .badge-pending 	{
	display: inline-block;
	margin-left: 8px;
	padding: 2px 8px;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.6;
	color: #b45309;
	background: #fef3c7;
	border: 1px solid #fcd34d;
	border-radius: 999px;
	vertical-align: middle;
}

.page-job .job-placeholder 	{
	margin: 14px 0 0;
	padding: 14px 16px;
	border: 1px dashed #94a3b8;
	background: #f8fafc;
	border-radius: 10px;
	color: #0f172a;
}

.page-job .job-head 	{
	display: flex;
	align-items: center;
	gap: 10px;
	background: #f1f5f9;
	border: 1px solid #e5e7eb;
	border-radius: 999px;
	padding: 6px 14px;
	margin: 0 0 18px;
	box-shadow: 0 2px 6px rgba(2,6,23,.05);
}

.page-job .job-head .eyebrow 	{
	font-size: 0.75rem;
	letter-spacing: .1em;
	font-weight: 600;
	color: #2563eb;
	background: #fff;
	border-radius: 999px;
	padding: 3px 8px;
}

.page-job .job-head .job-title 	{
	margin: 0;
	font-size: 22px;
	font-weight: 500;
	color: #0f172a;
}

.brand-name 	{
	font-size: 28px;
	font-weight: 700;
	color: #fff;
	text-shadow: 0 1px 2px rgba(5,5,5,.7);
	text-decoration: none;
	transition: color .25s ease, transform .25s ease;
}

.brand-name:hover 	{
	filter: grayscale(90%) brightness(0.9);
}

.page-patrol .breadcrumb 	{
	font-size: 14px;
	color: #475569;
	margin: 16px auto 0;
}

.page-patrol .breadcrumb a 	{
	color: inherit;
	text-decoration: none;
}

.page-patrol .breadcrumb .sep 	{
	margin: 0 6px;
	color: #94a3b8;
}

.page-patrol .patrol-detail 	{
	margin-top: 14px;
}

.page-patrol .detail-head	{
	display:flex;
	align-items:center;
	gap:12px;
	background: linear-gradient(90deg,#eef6ff 0%,#ffffff 46%);
	border:1px solid #e6effe;
	border-left:6px solid #60a5fa;
	border-radius:12px;
	padding:10px 16px;
	margin:0 0 12px;
	box-shadow:none;
}

.page-patrol .detail-head .eyebrow	{
	font-size:16px;
	letter-spacing:.08em;
	font-weight:700;
	color:#475569;
	background:#f8fafc;
	border:1px solid #e2e8f0;
	border-radius:999px;
	padding:4px 10px 3px;
	line-height:1;
	white-space:nowrap;
}

.page-patrol .detail-head .date	{
	margin:0;
	font-size:clamp(18px,2.8vw,22px);
	font-weight:800;
	color:#0f172a;
	line-height:1.4;
}

.page-patrol .detail-meta	{
	display:block;
	margin:10px 0 0;
}

.page-patrol .detail-meta > div	{
	display:block;
}

.page-patrol .detail-meta dt	{
	display:none;
}

.page-patrol .detail-meta dd	{
	margin:0;
}

.page-patrol .detail-desc	{
	font-size:16.5px;
	line-height:1.9;
	max-width:60ch;
	color:#334155;
}

.page-patrol .patrol-photos 	{
	margin-top: 28px;
}

.page-patrol .sr-only 	{
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	border: 0;
}

.page-patrol .gallery 	{
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

.page-patrol .gallery .item a 	{
	display: block;
	text-decoration: none;
	color: inherit;
}

.page-patrol .gallery .thumb 	{
	aspect-ratio: 4/3;
	background: #f8fafc;
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 2px 8px rgba(2,6,23,.04);
}

.page-patrol .gallery .thumb img 	{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform: scale(1.02);
	transition: transform .25s ease;
}

.page-patrol .gallery .item a:hover .thumb img 	{
	transform: scale(1.06);
}

.page-patrol .gallery .item a:hover .thumb	{
	outline:2px solid #93c5fd;
	outline-offset:-2px;
	box-shadow:0 10px 24px rgba(2,6,23,.08);
}

.page-patrol .gallery figcaption 	{
	font-size: 13px;
	color: #64748b;
	margin-top: 6px;
	text-align: center;
}

.page-patrol .photo-note 	{
	margin-top: 12px;
	font-size: 13px;
	color: #64748b;
}

.page-patrol .back 	{
	margin: 28px auto 40px;
	text-align: center;
}

.page-patrol .btn-back 	{
	display: inline-block;
	padding: 10px 18px;
	border: 1px solid #cbd5e1;
	border-radius: 999px;
	text-decoration: none;
	color: #0f172a;
	transition: background .2s ease, border-color .2s ease;
}

.page-patrol .btn-back:hover 	{
	background:#eef6ff;
	border-color:#93c5fd;
}

.page-works .fuji-lead	{
	margin: 0;
	font-size: clamp(16px, 1.2vw, 18px);
	line-height: 1.85;
	color: #374151;
}

.page-works .fuji-divider	{
	height: 1px;
	background: #e5e7eb;
	margin: clamp(10px, 1.6vw, 14px) 0;
}

.page-works .fuji-cta	{
	display: flex;
	justify-content: flex-end;
}

.page-works .fuji-cta .btn-link--lg	{
	padding: 14px 28px;
	font-size: 16px;
	font-weight: 700;
	border-radius: 9999px;
	background: #0ea5e9;
	color: #fff;
	text-decoration: none;
	box-shadow: 0 3px 10px rgba(14,165,233,.28);
	transition: background .2s, transform .15s, box-shadow .2s;
}

.page-works .fuji-cta .btn-link--lg:hover	{
	background:#0284c7;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(2,132,199,.34);
}

.page-initiatives .sdgs-grid	{
	display: grid;
	grid-template-columns: repeat(2, minmax(0,1fr));
	gap: 20px 22px;
	margin-top: 16px;
}

.page-initiatives .sdgs-block	{
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 16px;
	border: 1px solid #e5e7eb;
	border-radius: 14px;
	background: #fff;
	box-shadow: 0 2px 6px rgba(2,6,23,.04);
}

.page-initiatives .sdgs-block h3	{
	margin: 2px 0 6px;
	font-size: 18px;
	font-weight: 800;
	color: #0f172a;
}

.page-initiatives .sdgs-block .icon-row	{
	gap: 8px;
	margin: 0 0 6px;
}

.page-initiatives .sdgs-block .icon-row img	{
	height: 56px;
	width: auto;
	object-fit: contain;
}

.page-initiatives .sdgs-block ul	{
	margin: 0;
	padding-left: 1.1em;
	line-height: 1.8;
	color: #374151;
}

.page-initiatives .sdgs-block li	{
	margin: .14em 0;
	font-size: 14px;
}

.page-policy .policy-item 	{
	margin: 18px 0;
}

.page-policy .policy-item h3 	{
	font-size: 15px;
	font-weight: 700;
	color: #1e3a8a;
	margin: 0 0 6px;
	padding-left: 6px;
	border-left: 4px solid #3b82f6;
}

.page-policy .policy-item p 	{
	margin: 0;
	line-height: 1.8;
	font-size: 14px;
	color: #374151;
}

.page-policy .policy-table-wrap 	{
	margin: 12px 0 18px 12px;
	overflow-x: auto;
}

.page-policy .policy-table 	{
	width: 100%;
	border-collapse: collapse;
	background: #fff;
	font-size: 14px;
	line-height: 1.6;
}

.page-policy .policy-table th	{
	border: 1px solid #e5e7eb;
	padding: 8px 12px;
	text-align: left;
}

.page-policy .policy-table td 	{
	border: 1px solid #e5e7eb;
	padding: 8px 12px;
	text-align: left;
}

.page-policy .policy-table th 	{
	background: #f3f4f6;
	font-weight: 700;
	color: #1f2937;
}

.page-patrol .section-actions	{
	display: flex;
	justify-content: center;
	grid-column: 1 / -1;
	margin: 20px 0;
	text-align: center;
}

.page-voice .section-actions	{
	display: flex;
	justify-content: center;
	grid-column: 1 / -1;
	margin: 20px 0;
	text-align: center;
}

.page-patrol .section-actions .btn	{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 9999px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background .2s, transform .1s, color .2s, border-color .2s;
}

.page-voice .section-actions .btn	{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 18px;
	border-radius: 9999px;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background .2s, transform .1s, color .2s, border-color .2s;
}

.page-patrol .section-actions .btn.btn-outline	{
	border: 1px solid #2563eb;
	color: #2563eb;
	background: #fff;
}

.page-voice .section-actions .btn.btn-outline	{
	border: 1px solid #2563eb;
	color: #2563eb;
	background: #fff;
}

.page-patrol .section-actions .btn.btn-outline:hover	{
	background: #eff6ff;
	transform: translateY(-1px);
}

.page-voice .section-actions .btn.btn-outline:hover	{
	background: #eff6ff;
	transform: translateY(-1px);
}

h1 	{
	margin: 0 0 .4em;
	font-weight: 700;
	line-height: 1.25;
}

h2 	{
	margin: 0 0 .4em;
	font-weight: 700;
	line-height: 1.25;
}

h3 	{
	margin: 0 0 .4em;
	font-weight: 700;
	line-height: 1.25;
}

h1 	{
	font-size: clamp(28px, 4vw, 40px);
}

h2 	{
	font-size: clamp(22px, 3vw, 26px);
}

h3 	{
	font-size: clamp(18px, 2.4vw, 20px);
}

small	{
	font-size: 13px;
}

.eyebrow	{
	font-size: 13px;
}

.company-desc	{
	font-size: 15px;
}

p	{
	font-size: 15px;
}

header .brand span 	{
	font-size: 1.5rem;
	text-shadow: 0 1px 1px rgba(0,0,0,.35);
}

nav a	{
	font-weight: 550;
}

.section-head h2	{
	font-weight: 550;
}

.company-head .company-title	{
	font-weight: 550;
}

.wide .section-head h2	{
	font-weight: 550;
}

.page-works .works-caption	{
	font-weight: 550;
}

:root 	{
	--muted: #4b5563;
}

.news-tag 	{
	font-size: 13px;
	font-weight: 500;
	padding: 2px 5px;
	border-radius: 999px;
	border: 1px solid #d7dee6;
	background: #eef2f7;
	color: #475569;
	white-space: nowrap;
	text-align: center;
}

.stage .section-wrap > .container 	{
	padding-left: 0;
	padding-right: 0;
}

/* === header/footer 背景グリッドを背面に固定 === */
header {
  position: sticky;
  top: 0;
  z-index: 0; /* ← これがポイント：40 → 0 に変更 */
  background: linear-gradient(180deg, #77889a 0%, #8899ab 85%, #b6c1d0 100%);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
  backdrop-filter: saturate(150%) blur(10px);
  border-radius: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.65), 0 6px 18px rgba(2,6,23,.08);
  overflow: hidden;
}

header::before,
footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(#ccc 1px, transparent 1px),
    linear-gradient(90deg, #ccc 1px, transparent 1px);
  background-size: 14px 14px;
  opacity: 0.2;
  pointer-events: none;
  z-index: -1; /* 背面へ固定 */
}


:root	{
	--site-width: 1300px;
	--page-gutter: 16px;
	--header-h: 68px;
	--footer-h: 72px;
}

.container	{
	max-width: min(100%, var(--site-width));
	margin-inline: auto;
	padding-left: var(--page-gutter);
	padding-right: var(--page-gutter);
}

header .brand img	{
	height: 44px;
}

.footer-inner	{
	max-width: min(100%, var(--site-width));
	margin-inline: auto;
	padding-left: var(--page-gutter);
	padding-right: var(--page-gutter);
	min-height: var(--footer-h);
	align-items: center;
}

footer	{
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

footer .footer-inner	{
	max-width: 100%;
	padding-left: max(16px,3.5vw);
	padding-right: max(16px,3.5vw);
}


.page-top .news	{
	padding: 14px clamp(12px,2.4vw,18px) 18px;
}

.page-top .news	{
	border: 1px solid var(--border, #e5e7eb);
	box-shadow: 0 6px 20px rgba(2,6,23,.06);
	background: #fff;
}

.page-top .panel--top	{
	margin:10px 0;
	padding:12px 16px 35px;
	border-radius:18px;
	backdrop-filter:blur(6px);
	border: 1px solid var(--border, #e5e7eb);
	box-shadow: 0 6px 20px rgba(2,6,23,.06);
	background: #fff;
}

.page-top .wide	{
	border: 1px solid var(--border, #e5e7eb);
	box-shadow: 0 6px 20px rgba(2,6,23,.06);
	background: #fff;
}

.page-top .company-grid	{
	gap: 14px;
}

.page-top .company-card	{
	width: 100%;
	border-color: var(--border, #e5e7eb);
	box-shadow: 0 4px 14px rgba(2,6,23,.06);
}

.page-top .company-thumb	{
	height: 210px;
}

.page-top .company-thumb img	{
	transform: scale(0.96);
}

.page-top .wide	{
	height: 240px;
	border-color: var(--border, #e5e7eb);
}

.page-top .wide .cap	{
	padding: 18px clamp(14px,2.6vw,22px);
}



html	{
	font:16px/1.7 "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	background: #ffffff;
	margin:0;
	padding:0;
	max-width: 100%;
	color:var(--fg);
	overflow-x: clip;
}

html	{
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	font-size: 18px;
	line-height: 1.4;
	letter-spacing: 0.01em;
	color: #1f2937;
}

html 	{
	font-size: 16px;
}


body	{
	font:16px/1.7 "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	background: #ffffff;
	margin:0;
	padding:0;
	max-width: 100%;
	color:var(--fg);
	overflow-x: clip;
}

body	{
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	font-size: 18px;
	line-height: 1.4;
	letter-spacing: 0.01em;
	color: #1f2937;
}

body 	{
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	line-height: 1.7;
	letter-spacing: 0.01em;
	color: #111827;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

body::before	{
	content:"";
	position: fixed;
	top:0;
	bottom:0;
	width:1px;
	background: var(--border);
	pointer-events:none;
	z-index: 50;
	left: 0;
}

body::after	{
	content:"";
	position: fixed;
	top:0;
	bottom:0;
	width:1px;
	background: var(--border);
	pointer-events:none;
	z-index: 50;
	right: 0;
}


.page-works-detail 	{
	--works-card-max: 360px;
	--works-grid-gap: 26px;
	--works-section-space: 22px;
	--works-cap-fz: 15px;
	--works-cap-color: #0f172a;
	--works-muted: #64748b;
	--works-muted2: #94a3b8;
}

.page-works-detail .breadcrumb 	{
	font-size: 14px;
	color: #475569;
	margin: 16px auto 0;
}

.page-works-detail .breadcrumb a 	{
	color: inherit;
	text-decoration: none;
}

.page-works-detail .breadcrumb .sep 	{
	margin: 0 6px;
	color: var(--works-muted2);
}

.page-works-detail .works-detail-head 	{
	display: grid;
	grid-template-columns: 72px 1fr;
	gap: 16px;
	align-items: center;
	margin-top: var(--works-section-space);
	margin-bottom: 8px;
}

.page-works-detail .works-detail-head .cat-icon 	{
	width: 72px;
	height: 72px;
	object-fit: contain;
	border-radius: 12px;
	background: #fff;
	border: 1px solid #e5e7eb;
}

.page-works-detail .works-detail-head .title 	{
	margin: 0 0 4px;
	font-size: 22px;
}

.page-works-detail .works-detail-head .lead 	{
	margin: 0;
	color: var(--works-muted);
	font-size: 14px;
}



.page-works-detail .work-link 	{
	display: block;
	text-decoration: none;
	color: inherit;
}


.page-works-detail .back 	{
	margin: 34px auto 52px;
	text-align: center;
}

.page-works-detail .btn-back 	{
	display: inline-block;
	padding: 10px 18px;
	border: 1px solid #cbd5e1;
	border-radius: 999px;
	text-decoration: none;
	color: #0f172a;
	transition: background .2s ease, border-color .2s ease;
}

.page-works-detail .btn-back:hover 	{
	background: #f8fafc;
	border-color: var(--works-muted2);
}

.page-works-detail .works-detail-head 	{
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 10px 16px;
	border: 1px solid #e5e7eb;
	border-radius: 12px;
	background: linear-gradient(180deg, #f3f6f9, #e0e4e8);
	margin: 24px auto 18px;
	box-shadow: 0 2px 6px rgba(2,6,23,.05);
}

.page-works-detail .works-detail-head .title 	{
	font-size: 22px;
	font-weight: 800;
	margin: 0 0 4px;
	color: #0f172a;
}

.page-works-detail .works-detail-head .lead 	{
	font-size: 14px;
	color: #475569;
	margin: 0;
}



.page-works-detail .btn-back 	{
	display: inline-block;
	padding: 10px 22px;
	border: 1px solid #2563eb;
	border-radius: 999px;
	color: #2563eb;
	text-decoration: none;
	font-weight: 600;
	transition: background .2s, transform .15s;
}

.page-works-detail .btn-back:hover 	{
	background: #eff6ff;
	transform: translateY(-1px);
}

.page-works-detail .hero-title--icon 	{
	display: inline-flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}

.page-works-detail .hero-title--icon .hero-icon 	{
	width: 72px;
	height: 72px;
	flex: 0 0 72px;
	object-fit: contain;
	max-width: none;
	border-radius: 12px;
	background: #fff;
	padding: 4px;
	box-shadow: 0 3px 12px rgba(0,0,0,.25);
}




.page-works-detail .back	{
	margin: 16px 0 8px;
}



.page-works-detail .work-cap 	{
	margin-top: 10px;
	font-size: var(--works-cap-fz);
	line-height: 1.65;
	color: var(--works-cap-color);
}

.page-works-detail .work-cap 	{
	font-size: 15px;
	font-weight: 600;
	text-align: center;
	padding: 8px;
	color: #0f172a;
}

.page-works-detail .work-cap	{
	padding: 10px 12px;
	font-size: 16px;
	font-weight: 400;
	color: #0f172a;
	text-align: center;
	min-height: 3em;
	display: flex;
	align-items: center;
	justify-content: center;
}

.page-works-detail .work-cap 	{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	background: #fff;
	border-radius: 14px;
	box-shadow: 0 3px 10px rgba(0,0,0,0.08);
	padding: 16px 12px;
	margin-top: 10px;
	line-height: 1.5;
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
}

.page-works-detail .work-cap	{
	background:#f4f7ff;
	border-top:1px solid #e6ecfb;
	padding:14px 16px;
	min-height:84px;
	display:flex;
	align-items:center;
	justify-content:center;
	text-align:center;
	line-height:1.65;
	color:#1f2937;
}

.page-works-detail .work-cap	{
	word-break: break-word;
}

.page-works-detail .work-cap .title 	{
	font-weight: 600;
	font-size: 16px;
	color: #1e293b;
	margin-bottom: 6px;
}

.page-works-detail .work-cap .client 	{
	font-size: 13px;
	color: #64748b;
	letter-spacing: 0.05em;
}


header nav a 	{
	font-size: 18px;
	font-weight: 500;
	color: #fff;
	text-decoration: none;
	padding: 5px 12px;
	border-radius: 5px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.3);
	transition: background 0.25s ease, transform 0.15s ease;
}

header nav a 	{
	padding-top: 4px;
	padding-bottom: 4px;
}

header nav a	{
	padding-top: 8px;
	padding-bottom: 8px;
	line-height: 1.2;
}

header nav a:hover 	{
	background: rgba(255, 255, 255, 0.25);
	transform: translateY(-1px);
}


.news-link	{
	color:#111827;
	text-decoration:none;
	flex:1;
}

.news-link	{
	font-size: 15px;
}

.news-link 	{
	flex: 1 1 100%;
	min-width: 0;
	overflow-wrap: anywhere;
}

.news-link 	{
	font-size: 15px;
	font-weight: 400;
	color: #0f172a;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.news-date	{
	white-space:nowrap;
	font-variant-numeric:tabular-nums;
	color: #6b7280;
	font-weight: 400;
	font-size: 14px;
}

.news-item	{
	display:flex;
	align-items:center;
	gap:8px;
	background:#fff;
	padding:3px 16px;
	border:1px solid rgba(15,23,42,.1);
	border-radius:12px;
	box-shadow:0 1px 0 #e5e7eb,0 4px 12px rgba(2,6,23,.04);
}

.news-item 	{
	flex-wrap: wrap;
	align-items: flex-start;
}

.news-item 	{
	display: grid;
	grid-template-columns: 75px 80px minmax(0,1fr);
	align-items: baseline;
	column-gap: 10px;
	font-family: "Noto Sans", "Noto Sans JP", "Yu Gothic UI", sans-serif;
	font-size: 15px;
	line-height: 1.6;
	letter-spacing: 0.01em;
	color: #111827;
}


.header-inner	{
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap:12px;
	padding:8px 16px;
	height:auto;
	flex-wrap:nowrap;
}

.header-inner	{
	max-width: min(100%, var(--site-width));
	margin-inline: auto;
	padding-left: var(--page-gutter);
	padding-right: var(--page-gutter);
	min-height: var(--header-h);
}

header .header-inner	{
	max-width: 100%;
	padding-left: max(16px,3.5vw);
	padding-right: max(16px,3.5vw);
}



@media (max-width:560px)	{
	.company-grid{
	grid-template-columns:1fr;
}

}

@media (max-width:760px)	{
	.about-info > div{
	grid-template-columns: 1fr;
}
.about-info dt{
	border-right:none;
@media (max-width: 768px)	{
	.header-inner{
	flex-wrap:wrap;
	gap:6px;
	padding:8px 12px;
}
.brand{
	order:1;
	width:100%;
	justify-content:center;
}
.brand img{
	height:42px;
}
.brand span{
	font-size:1.2rem;
}
nav{
	order:2;
	width:100%;
	justify-content:center;
	flex-wrap:wrap;
	gap:8px;
}
nav a{
	font-size:.9rem;
	padding:6px 10px;
	border-radius:999px;
}

}

@media (max-width:1024px)	{
	.company-grid{
	grid-template-columns:repeat(2,1fr);
}

}
border-bottom:1px solid #e2e8f0;
}

}

@media (max-width: 760px) 	{
	.about-links {
	grid-template-columns: 1fr;
}

}

@media (max-width: 480px) 	{
	.group-img {
	width: 100%;
}

}

@media (max-width: 960px) 	{
	.group-list {
	grid-template-columns: 1fr;
}

}

@media (max-width: 768px)	{
	.page-recruit .voice-bubble{
	flex-direction:column;
}
.page-recruit .voice-avatar{
	width:64px;
	height:64px;
}
.page-recruit .voice-balloon{
	padding:14px 16px;
}

}

@media (max-width: 1024px) 	{
	.page-recruit .benefit-grid {
	grid-template-columns: repeat(2,1fr);
}
.page-recruit .data-grid {
	grid-template-columns: repeat(2,1fr);
}

}

@media (max-width: 640px) 	{
	.page-recruit .img4 {
	grid-template-columns: repeat(2,1fr);
}
.page-recruit .benefit-grid {
	grid-template-columns: 1fr;
}
.page-recruit .data-grid {
	grid-template-columns: 1fr;
}

}

@media (max-width: 640px) 	{
	.page-recruit h2.sec-ttl {
	font-size: 20px;
}

}

@media (prefers-reduced-motion: reduce)	{
	.page-recruit .job-card--compact, .page-recruit .job-thumb img{
	transition:none;
}

}

@media (min-width: 1000px)	{
	.page-recruit .license dl{
	grid-template-columns: 1fr auto minmax(48px, 8vw) 1fr auto;
	column-gap: 6px;
}
.page-recruit .license dl dt:nth-of-type(odd) {
	grid-column: 1;
}
.page-recruit .license dl dd:nth-of-type(odd) {
	grid-column: 2;
}
.page-recruit .license dl dt:nth-of-type(even){
	grid-column: 4;
}
.page-recruit .license dl dd:nth-of-type(even){
	grid-column: 5;
}

}

@media (max-width: 768px) 	{
	.page-recruit .job-info {
	flex-direction: column;
	align-items: center;
}
.page-recruit .badge-new {
	margin-left: 0;
	margin-top: 6px;
	transform: none;
}

}

@media (max-width: 1024px)	{
	.page-recruit .voice-grid{
	grid-template-columns: repeat(2, 1fr);
}

}

@media (max-width: 560px)	{
	.page-recruit .voice-grid{
	grid-template-columns: 1fr;
}

}

@media (max-width: 1024px)	{
	.page-recruit .voice-box{
	grid-template-columns: 1fr;
}
.page-recruit .voice-box .voice-link{
	justify-self: end;
	margin-top: 10px;
}

}

@media (max-width: 560px)	{
	.page-recruit .voice-box .voice-link{
	justify-self: stretch;
	display:block;
	text-align:center;
	padding: 14px 18px;
	border-radius: 9999px;
}

}

@media (max-width:1024px)	{
	.page-works .works-grid{
	grid-template-columns: repeat(3,1fr);
}

}

@media (max-width: 720px)	{
	.page-works .works-grid{
	grid-template-columns: repeat(2,1fr);
}

}

@media (max-width: 420px)	{
	.page-works .works-grid{
	grid-template-columns: 1fr;
}

}

@media (max-width: 768px)	{
	.page-recruit .jobs{
	grid-template-columns: 1fr;
	gap: 14px;
}

}

@media (max-width: 560px)	{
	.page-recruit .job-thumb{
	flex: 0 0 80px;
	height: 80px;
}
.page-recruit .job-title{
	font-size: clamp(18px, 5.2vw, 22px);
	padding-left: 14px;
}

}

@media (max-width: 960px)	{
	.ph-duo__wrap{
	grid-template-columns: 1fr;
	gap: 28px;
}
.ph-duo__pill{
	--circle: 170px;
	font-size: 20px;
}
.ph-duo__messagebox, .ph-duo__creed{
	width: 100%;
	max-width: 560px;
	margin-left:auto;
	margin-right:auto;
}
.ph-duo__creed li{
	font-size:21px;
	min-height:78px;
	padding:18px 28px;
}

}

@media (max-width: 430px)	{
	.header-inner nav{
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
	width: 100%;
	justify-content: center;
}
.header-inner nav a{
	width: 100%;
	text-align: center;
	padding: 12px 10px;
	font-size: 15px;
}

}

@media (max-width: 960px)	{
	.ph-duo__wrap{
	grid-template-columns: 1fr;
}

}

@media (max-width: 420px)	{
	.ph-duo{
	--overlap: clamp(10px, 4vw, 28px);
}

}


@media (max-width: 560px)	{
	body.company-about::before, body.company-about::after{
	display: none;
}

}

@media (max-width: 560px)	{
	.ph-duo{
	padding: 16px 10px;
	overflow-x: hidden;
	--circle: clamp(96px, 28vw, 140px);
	--overlap: clamp(8px, 5vw, 16px);
}
.ph-duo__trio{
	max-width: 100%;
	overflow: hidden;
}
.ph-duo__messagebox{
	width: 100%;
	padding: 18px 14px;
	font-size: 15.5px;
}
.ph-duo__creed li{
	font-size: 20px;
	min-height: auto;
	padding: 14px 20px;
}

}

@media (max-width: 400px)	{
	.ph-duo__trio{
	flex-wrap: wrap;
	justify-content: center;
	row-gap: 8px;
}
.ph-duo__pill + .ph-duo__pill{
	margin-left: 8px;
}

}

@media (max-width:1024px)	{
	.page-history .history-timeline{
	grid-template-columns: 1fr;
}

}


@media (max-width:768px)	{
	.page-message .message-layout{
	grid-template-columns:1fr;
}

}


@media (max-width: 560px) 	{
	.page-initiatives .icon-row img {
	height: 48px;
}

}

@media (max-width: 560px)	{
	.page-initiatives .icon-row--lg img{
	height: 56px;
}

}

@media (max-width: 768px) 	{
	.page-initiatives .sdgs-grid {
	grid-template-columns: 1fr;
	gap: 24px;
}

}

@media (min-width: 860px)	{
	.page-voice .voice-card{
	grid-template-columns: minmax(260px,35%) 1fr;
	align-items: start;
	gap: 24px;
}

}


@media (max-width: 960px) 	{
	.page-job .job-container {
	grid-template-columns: 1fr;
}

}

@media (min-width: 641px) 	{
	.page-job .job-table {
	min-width: 680px;
}

}

@media (max-width: 640px) 	{
	.page-job .job-table th {
	width: 36%;
}
.page-job .job-table th, .page-job .job-table td {
	padding: 10px 12px;
	font-size: 0.95rem;
}

}

@media (max-width: 960px) 	{
	.page-job .job-aside {
	position: static;
}

}

@media (max-width: 960px) 	{
	.page-patrol .gallery {
	grid-template-columns: repeat(2, 1fr);
}

}

@media (max-width: 560px) 	{
	.page-patrol .gallery {
	grid-template-columns: 1fr;
}

}



@media (max-width: 560px)	{
	.page-works .fuji-cta {
	justify-content: stretch;
}
.page-works .fuji-cta .btn-link--lg{
	display:block;
	text-align:center;
}

}

@media (max-width: 768px)	{
	.page-initiatives .sdgs-grid{
	grid-template-columns: 1fr;
}

}




@media (max-width: 640px)	{
	.page-works-detail .work-cap{
	min-height:72px;
	padding:12px 14px;
}

}

@media (max-width: 768px)	{
	.header-inner{
	display: block;
}
.header-inner nav{
	display: grid;
	grid-template-columns: repeat(4, minmax(0,1fr));
	gap: 8px;
	width: 100%;
}
.header-inner nav a{
	text-align: center;
	padding: 10px 0;
	white-space: nowrap;
}

}

@media (max-width: 430px)	{
	.header-inner nav{
	grid-template-columns: repeat(4, minmax(0,1fr));
	gap: 6px;
}

}

@media (min-width: 769px)	{
	header nav a{
	font-size: clamp(16px, 0.95vw, 18px);
	font-weight: 500;
	letter-spacing: .02em;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	text-shadow: none;
	transform: none;
	transition: background .25s ease, border-color .25s ease;
	padding: 8px 14px;
}
header nav a:hover{
	background: rgba(255,255,255,.22);
	border-color: rgba(255,255,255,.45);
}

}

@media (max-width: 768px)	{
	header nav a{
	font-size: 14px;
	font-weight: 600;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	text-shadow: none;
	transform: none;
}

}

@media (max-width: 768px)	{
	header .brand-name{
	font-size: 1.6rem;
	line-height: 1.2;
}
header nav{
	gap: 6px;
}
header nav a{
	padding: 5px 0;
	font-size: 13.5px;
	letter-spacing: .01em;
}

.news-item{
	row-gap: 3px;
	padding: 6px 10px;
}
.news-link{
	font-size: 14.5px;
	line-height: 1.7;
	white-space: normal;
}

}

@media (max-width: 768px)	{
	.header-inner{
	padding-left:12px;
	padding-right:12px;
}
header .brand{
	margin-bottom:8px;
}
header nav{
	gap:6px;
}
header nav a{
	padding:4px 0;
	font-size:13.5px;
	line-height:1.2;
}


@media (max-width: 768px) 	{
	header nav a {
	padding-top: 5px;
	padding-bottom: 5px;
}

}

@media (max-width: 768px) 	{
	.page-works .title-band h2, .page-recruit .title-band h2, .page-company .title-band h2, .page-patrol .title-band h2, .page-initiatives .title-band h2, .page-message .title-band h2 {
	font-size: clamp(16px, 4.2vw, 22px);
}
.page-works .title-band p, .page-recruit .title-band p, .page-company .title-band p, .page-patrol .title-band p, .page-initiatives .title-band p, .page-message .title-band p {
	font-size: clamp(13px, 3.4vw, 16px);
}

}

@media (max-width: 768px)	{
	.news-title {
	font-size: 20px;
	line-height: 1.4;
}
.section-head h2, .company-head .company-title, .wide .section-head h2 {
	font-size: 20px;
	line-height: 1.4;
}
.wide .cap p {
	font-size: 13.5px;
	line-height: 1.7;
}

}

@media (max-width: 768px)	{
	.page-voice .voice-cards > .container{
	display: block !important;
	grid-template-columns: none !important;
	grid-template-areas: none !important;
}
.page-voice .voice-cards > .container > .voice-card{
	display: block;
	grid-area: auto !important;
	margin: 0 0 14px;
}
.page-voice .voice-card__media{
	width: 100%;
	margin: 0 0 8px;
}
.page-voice .section-actions{
	display:flex;
	justify-content:center;
	margin: 14px 0 0;
}

}

@media (max-width: 768px)	{
	:root{
	--site-width: 100%;
	--header-h: 60px;
	--footer-h: 64px;
}
header .brand img{
	height: 40px;
}
header nav a{
	padding-top: 6px;
	padding-bottom: 6px;
	
}

}


.page-top .company-thumb{
	height: 180px;
}
.page-top .wide{
	height: 200px;
}

}


@keyframes text-swipe 	{
	to {
	opacity: 1;
	transform: translateX(0);
}

}

@keyframes works-title-reveal	{
	0% {
	opacity:0;
	transform: translate(-10px,8px) scale(1.02);
	filter: blur(6px);
}
60% {
	opacity:1;
	transform: translate(0,0) scale(1.00);
	filter: blur(0);
}
100% {
	opacity:1;
	transform: none;
	filter: none;
}

}

@keyframes works-sub-reveal	{
	from {
	opacity:0;
	transform: translateY(12px);
}
to {
	opacity:1;
	transform: translateY(0);
}

}

@keyframes company-title-wipe	{
	0% {
	opacity:0;
	clip-path: inset(100% 0 0 0);
	transform: translateY(8px);
}
60% {
	opacity:1;
	clip-path: inset(0 0 0 0);
	transform: translateY(0);
}
100% {
	opacity:1;
	clip-path: inset(0 0 0 0);
	transform: none;
}

}

@keyframes company-title-underline	{
	from {
	width:0;
}
to {
	width:48%;
}

}

@keyframes company-sub-rise	{
	from {
	opacity:0;
	transform: translateY(12px);
}
to {
	opacity:1;
	transform: translateY(0);
}

}

@keyframes message-kenburns	{
	0% {
	opacity:0;
	transform:scale(1.06) translateY(6px);
	filter:brightness(.9) saturate(.96);
}
60% {
	opacity:1;
	transform:scale(1.02) translateY(2px);
	filter:brightness(1) saturate(1);
}
100% {
	opacity:1;
	transform:scale(1.00) translateY(0);
	filter:brightness(1) saturate(1);
}

}

@keyframes message-cap-fade	{
	0%{
	opacity:0;
	transform:translateY(8px)
}
100%{
	opacity:1;
	transform:translateY(0)
}

}

@keyframes message-title-fade	{
	0%{
	opacity:0;
	transform:translateY(6px)
}
100%{
	opacity:1;
	transform:translateY(0)
}

}

@keyframes vh-zoom	{
	from{
	transform: scale(1.08);
	opacity:.2;
}
to {
	transform: scale(1.02);
	opacity:1;
}

}

@keyframes patrol-text-fade 	{
	to {
	opacity: 1;
}

}

/* === HISTORY：フォーマル年表（落ち着いた2カラム）=== */
.page-history .history-timeline li{
  display: grid;
  grid-template-columns: 8.5rem 1fr;  /* 左：年月 / 右：内容 */
  align-items: start;                  /* 上寄せ */
  column-gap: 16px;
  padding: 10px 0;
  border-top: 1px solid #e6e9ee;       /* 行区切りのみ */
}
.page-history .history-timeline li:first-child{ border-top: none; }

/* 年月：プレーン表示（バッジや角丸・背景は無し） */
.page-history .history-timeline .point{
  min-width: 0;
  text-align: right;
  padding: 0;
  margin: 0;
  font-weight: 600;
  padding-left: 0.8em;
  font-size: 0.95rem;
  color: rgba(51, 65, 85, 0.75);  /* ← 不透明グレー#334155を75%透過に */
  line-height: 1.4;
}
.page-history .history-timeline .point .era,
.page-history .history-timeline .point .year,
.page-history .history-timeline .point .month{
  display: inline;
  padding: 0;
  margin: 0 .1em 0 0;
  border: 0;
  background: none;
  border-radius: 0;
}

/* 内容：装飾は排除しテキストのみ（行間だけ整える） */
.page-history .history-timeline .desc{
  padding: 0;
  margin: 0;
  border: 0;
  background: none;
  box-shadow: none;
  color: #1f2937;
  line-height: 1.65;
}
.page-history .history-timeline .desc:hover{ box-shadow: none; }

/* スマホ時は読みやすさ優先で1カラム化 */
@media (max-width: 768px){
  .page-history .history-timeline li{
    grid-template-columns: 6.5rem 1fr;
    column-gap: 12px;
    padding: 8px 0;
  }
  .page-history .history-timeline .point{ text-align: left; }
}

/* グリッド内要素が縮められるように（デフォは min-width:auto で溢れやすい） */
.page-history .history-timeline .point,
.page-history .history-timeline .desc {
  min-width: 0;                 /* ←超重要 */
  overflow-wrap: anywhere;      /* 長い単語/数字も折り返す */
  word-break: break-word;
  hyphens: auto;
}

/* 小さめ画面の列幅と文字サイズを少し調整 */
@media (max-width: 560px){
  .page-history .history-timeline li{
    grid-template-columns: 5.8rem 1fr;  /* 年月列をやや細く */
    column-gap: 12px;
  }
  .page-history .history-timeline .point{ font-size:.88rem; padding-left:.5em; }
  .page-history .history-timeline .desc { font-size:.92rem; }
}

/* さらに狭い端末は1カラムにフォールバック */
@media (max-width: 400px){
  .page-history .history-timeline li{
    grid-template-columns: 1fr;
    row-gap: 4px;
  }
  .page-history .history-timeline .point{ padding-left:.25em; }
}


/* 共通ヘッダー帯 */
.head-band {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #e1e5e9;
  padding: 4px 16px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.06);
  box-shadow: 0 1px 2px rgba(2,6,23,.04);
  width: 100%;
  margin: 0 0 10px;
}

.head-band .eyebrow {
  font-size: .78rem;
  letter-spacing: .08em;
  color: #334155;
  background: rgba(255,255,255,.8);
  border-radius: 999px;
  padding: 4px 10px;
  white-space: nowrap;
}

.head-band .title {
  margin: 0;
  font-size: 24px;
  line-height: 1.3;
  font-weight: 800;
  letter-spacing: .2px;
  color: #1e293b;
  position: relative;
}

.head-band .title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100px;
  height: 5px;
  border-radius: 5px;
  background: #fff;
}

/* ========================================
   全ページ共通：ヘッダ／フッタ全幅＋左右64px余白
   ======================================== */
header,
footer {
  width: 100vw; /* 背景は画面幅いっぱい */
}

header > .header-inner,
footer > .footer-inner {
  max-width: 100%;
  margin: 0 auto;
  padding-left: 48px;
  padding-right: 48px;
  box-sizing: border-box;
}



@media (max-width: 768px) {
  header > .header-inner,
  footer > .footer-inner {
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* ==========================================
   worksページ：パネル3×3固定レイアウト
   ========================================== */
.page-works .works-grid {
  grid-template-columns: repeat(3, 1fr);
}

/* スマホ時は従来通りの段組みに自動移行 */
@media (max-width: 720px) {
  .page-works .works-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 420px) {
  .page-works .works-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================
   富士山パトロール：カードデザイン改善
   ========================================== */
.page-patrol .patrol-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  margin-top: 24px;
}

.page-patrol .patrol-item {
  position: relative;
  border: none;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(2,6,23,.06);
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
}

.page-patrol .patrol-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(2,6,23,.12);
}

.page-patrol .patrol-item .thumb {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f3f4f6;
}

.page-patrol .patrol-item .thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1);
  transition: transform .4s ease;
}

.page-patrol .patrol-item:hover .thumb img {
  transform: scale(1.06);
}

.page-patrol .patrol-item .caption {
  padding: 14px 16px 18px;
  text-align: center;
  background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
}

.page-patrol .patrol-item .title {
  font-weight: 700;
  font-size: 1rem;
  color: #1f2937;
  margin: 0 0 4px;
}

.page-patrol .patrol-item::before {
  content: "PATROL";
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(37,99,235,0.9);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .05em;
  padding: 4px 8px;
  border-radius: 6px;
}

/* === パネル画像の角丸を追加 === */
.page-patrol .patrol-item .thumb img {
  border-top-left-radius: 36px;
  border-top-right-radius: 36px;
}

/* PATROLラベルが角に沿うよう微調整 */
.page-patrol .patrol-item::before {
  top: 10px;
  left: 10px;
  border-top-left-radius: 8px;
  border-bottom-right-radius: 6px;
}

/* ラベル(PATROL)の外周に白いリングを付けて、角の段差をごまかす */
.page-patrol .patrol-item::before{
  z-index: 2;
  box-shadow: 0 0 0 6px #fff;   /* ← 白い縁を描く（カード背景色に合わせる） */
  border-radius: 8px;           /* 角をやや丸めて自然に */
  top: 10px; left: 10px;        /* お好みで微調整 */
}


/* === 富士山パトロール：カード横幅をやや拡大 === */
.page-patrol .patrol-grid {
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); /* ← 260→320に拡大 */
  gap: 24px;
  margin-top: 24px;
}

/* === 富士山パトロール：ホバー時も角丸を維持＋灰色背景を隠す === */
.page-patrol .patrol-item {
  border-radius: 20px;               /* 丸みを少し強める */
  overflow: visible;                 /* transform時の切れを防ぐ */
  clip-path: inset(0 round 20px);    /* 常に角丸を強制 */
  background: #fff;
}

.page-patrol .patrol-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(2,6,23,.12);
  clip-path: inset(0 round 20px);    /* ホバー中も維持 */
}

.page-patrol .patrol-item .thumb {
  overflow: hidden;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  background: #fff; /* ← 背景を白に変更して灰色を消す */
}

.page-patrol .patrol-item .thumb img {
  border-radius: 0; /* 外枠に任せる */
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}

/* === 施工実績トップ：カテゴリーカードの見栄えを統一 === */
/* カード本体：1枚板化（画像＋キャプションの2行グリッド） */
.page-works .works-list .works-item{
  position: relative;
  display: grid;
  grid-template-rows: minmax(0, 1fr) 46px;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 4px 16px rgba(2,6,23,.06);
  overflow: hidden;
  padding: 0;             /* 既存の上下パディングを打ち消し */
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.page-works .works-list .works-item:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(2,6,23,.10);
  border-color: #dbe1ea;
}

/* 画像：比率維持＋アイコンが映える余白 */
.page-works .works-list .works-item > img{
  grid-row: 1;
  width: 100%;
  height: 100%;
  aspect-ratio: 4/3;
  object-fit: contain;         /* アイコンを潰さない */
  background: #f6f8fb;
  padding: 18px;               /* 余白を一定に */
  margin: 0;
}

/* キャプション：帯で一体感を出す（細い仕切り線のみ） */
.page-works .works-list .works-caption{
  grid-row: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  background: linear-gradient(90deg, #dbeafe 0%, #cff0ff 100%);
  border-top: 1px solid #e5e7eb;
  color: #0f172a;
  font-weight: 700;
  letter-spacing: .03em;
  border-radius: 0 0 14px 14px; /* 下だけ角丸（上は画像に揃える） */
}

/* グリッドの間隔を少しだけ広げて呼吸感を確保 */
.page-works .works-grid{
  gap: 20px;
}

/* ==============================
   TOP：会社カードのリファイン
   ============================== */

/* カードを“1枚の板”に／高さを揃える */
.page-top .company-card{
  display:flex;
  flex-direction:column;
  border-radius:16px;
  overflow:hidden;                           /* 角丸を確実に適用 */
  border:1px solid #e5e7eb;
  background:#fff;
  box-shadow:0 6px 18px rgba(2,6,23,.06);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.page-top .company-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px rgba(2,6,23,.12);
  border-color:#dbe1ea;
}

/* サムネイル：比率固定でブレさせない */
.page-top .company-thumb{
  height:auto;                 /* 既存の固定高さを解除 */
  aspect-ratio:16 / 9;         /* 画像の縦横比を統一 */
  background:#f6f8fb;
  overflow:hidden;
}
.page-top .company-thumb img{
  width:100%; height:100%;
  object-fit:cover;            /* 画像は切り抜きでフィット */
  transform:none;              /* 既存の縮小をリセット */
  transition:transform .25s ease;
}
.page-top .company-card:hover .company-thumb img{
  transform:scale(1.02);       /* ほんのりズームで訴求 */
}

/* 本文：余白・文字階層を整理 */
.page-top .company-body{
  flex:1;
  display:flex;
  gap:8px;
  padding:14px 18px 18px;
}
.page-top .company-label{
  display:inline-block;
  font-size:12px;
  letter-spacing:.08em;
  color:#1e40af;
  background:#eff6ff;
  border:1px solid #bfdbfe;
  border-radius:999px;
  padding:3px 10px;
  line-height:1;
  width:max-content;
}
.page-top .company-card .company-title{
  font-size:18px;
  font-weight:600;
  color:#0f172a;
  margin:2px 0 0;
}
.page-top .company-desc{
  margin-top:auto;             /* 下辺で止めて高さを揃える */
  color:#475569;
  font-size:14.5px;
  line-height:1.75;
}

/* グリッド間の“呼吸感”を少しだけアップ */
.page-top .company-grid{
  gap:18px;
}

/* ==========================================
   他ページの会社パネルをTOP準拠にリファイン
   対象スコープ：.page-company / body.company-about / #about
   （HTML変更なし・追記のみ）
   ========================================== */

/* カード本体：1枚板＆角丸・影を統一 */
:where(.page-company, body.company-about, #about) .company-card{
  display: flex;
  flex-direction: column;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 6px 18px rgba(2,6,23,.06);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
:where(.page-company, body.company-about, #about) .company-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(2,6,23,.12);
  border-color: #dbe1ea;
}

/* サムネイル：比率固定16:9＋微ズーム */
:where(.page-company, body.company-about, #about) .company-thumb{
  height: auto;            /* 既存の固定高さを解除 */
  aspect-ratio: 16 / 9;    /* TOPと同じ比率に統一 */
  background: #f6f8fb;
  overflow: hidden;
}
:where(.page-company, body.company-about, #about) .company-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;       /* 画像の切り抜きで整形 */
  transform: none;         /* 既存の縮小をリセット */
  transition: transform .25s ease;
}
:where(.page-company, body.company-about, #about) .company-card:hover .company-thumb img{
  transform: scale(1.03);
}

/* 本文：ラベル／タイトル／本文の階層を整理 */
:where(.page-company, body.company-about, #about) .company-body{
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 18px 18px;
}
:where(.page-company, body.company-about, #about) .company-label{
  display: inline-block;
  font-size: 12px;
  letter-spacing: .08em;
  color: #1e40af;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 999px;
  padding: 3px 10px;
  line-height: 1;
  width: max-content;
}
:where(.page-company, body.company-about, #about) .company-card .company-title{
  font-size: 18px;
  font-weight: 600;
  color: #0f172a;
  margin: 2px 0 0;
}
:where(.page-company, body.company-about, #about) .company-desc{
  color: #475569;
  font-size: 14.5px;
  line-height: 1.75;
  margin-top: auto;        /* 下端で揃えて高さを合わせる */
}

/* グリッドの呼吸感（他ページ用） */
:where(.page-company, body.company-about, #about) .company-grid{
  gap: 18px;               /* TOPと同じ間隔に */
}



/* =========================================================
   company.html 専用（body.company-about）— シンプル&静的
   既存と混ぜない：このスコープ内だけで完結。!important 不使用。
========================================================= */
body.company-about{

  /* 見出し帯（1パターン化） */
  .section-head{ display:flex; align-items:center; gap:8px; background:#f3f6f9; border:1px solid #e5e7eb; border-radius:12px; padding:8px 12px; box-shadow:0 1px 2px rgba(2,6,23,.04); margin:10px 0; }
  .section-tag{ background:#eef7fb; border:1px solid #d7dee6; border-radius:999px; padding:8px 5px; font-size:12px; font-weight:500; letter-spacing:.12em; color:#475569; line-height:1;}
  .section-title{ margin:0; font-size:18px; font-weight:600; line-height:1.3; color:#0f172a; }

  /* 会社概要テーブル（安定2カラム） */
  .about-info{ width:100%; box-sizing:border-box; margin-bottom:40px; }
  .about-info > div{ display:grid; grid-template-columns: 200px minmax(0,1fr); }
  .about-info dt{ padding:6px 10px; background:#f7f9fc; border:1px solid #e5e7eb; border-right:none; font-weight:700; white-space:nowrap; }
  .about-info dd{ padding:6px 12px; border:1px solid #e5e7eb; border-left:none; min-width:0; overflow-wrap:anywhere; line-height:1.6; }
  .about-info > div:first-child dt{ border-top-left-radius:8px; }
  .about-info > div:first-child dd{ border-top-right-radius:8px; }
  .about-info > div:last-child  dt{ border-bottom-left-radius:8px; }
  .about-info > div:last-child  dd{ border-bottom-right-radius:8px; }

  /* コンテンツカード */
  .company-grid{ display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:16px; }
  @media (max-width:1024px){ .company-grid{ grid-template-columns: repeat(2,1fr);} }
  @media (max-width:560px){ .company-grid{ grid-template-columns: 1fr;} }
  .company-card{ display:flex; flex-direction:column; border:1px solid #e5e7eb; border-radius:14px; box-shadow:0 6px 20px rgba(2,6,23,.06); background:#fff; text-decoration:none; color:inherit; overflow:hidden; transition:transform .2s, box-shadow .2s; }
  .company-card:hover{ transform:translateY(-2px); box-shadow:0 14px 32px rgba(2,6,23,.12); }
  .company-thumb{ aspect-ratio:16/9; background:#f6f8fb; }
  .company-thumb img{ width:100%; height:100%; object-fit:cover; }
  .company-body{ padding:12px 14px 14px; display:flex; flex-direction:column; gap:6px; }
  .company-label{ display:inline-block; font-size:12px; letter-spacing:.08em; background:#eff6ff; border:1px solid #cfe0ff; border-radius:999px; padding:3px 8px; color:#1e3a8a; }
  .company-title{ font-size:17px; font-weight:600; }
  .company-desc{ font-size:14.5px; color:#475569; line-height:1.7; }

  /* 経営理念 2カラム（簡素） */
  .ph-two-col{ display:grid; grid-template-columns: minmax(0,1.2fr) minmax(0,1fr); gap:24px;}
  @media (max-width:900px){ .ph-two-col{ grid-template-columns:1fr; gap:16px; } }
  .ph-head{ margin:0 0 8px; font-weight:700; }
  .ph-pills{ display:flex; gap:14px; justify-content:center; margin:8px 0 12px; }
  .pill{ display:grid; place-items:center; width:120px; aspect-ratio:1/1; border-radius:50%; border:4px solid currentColor; font-weight:800; background:#fff; }
  .ph-message{ border:1px solid #e5e7eb; border-radius:10px; padding:16px; background:#fff; line-height:1.8; }
  .creed{ list-style:none; padding:0; }
  .creed li{ display:flex; gap:.6em; align-items:center; padding:10px 12px; margin:8px 0; border:1px solid #e5e7eb; border-radius:10px; font-weight:700; background:#fff; }

  /* グループ会社 */
  .group-list{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px;}
  @media (max-width:960px){ .group-list{ grid-template-columns: 1fr; } }
  .group-item{ display:flex; flex-direction:column; align-items:center; text-decoration:none; color:inherit; border:1px solid #e5e7eb; border-radius:14px; padding:16px; box-shadow:0 6px 20px rgba(2,6,23,.06); background:#fff; transition:transform .2s, box-shadow .2s; }
  .group-item:hover{ transform:translateY(-2px); box-shadow:0 14px 32px rgba(2,6,23,.12); }
  .group-img{ width:150px; height:auto; object-fit:contain; }
  .group-name{ font-size:18px; font-weight:700;}
  .group-text{ font-size:15px; color:#374151; line-height:1.7; text-align:center; }
}

/* --- 会社タイトル帯 日本語サイズ調整 --- */
body.company-about .section-title {
  font-size: 24px;       /* 現在よりやや大きめに */
  letter-spacing: 0.03em;
}

/* 1) タイトル帯：日本語を主役に少し大きく */
body.company-about .section-title{
  font-size:25px; font-weight:500; letter-spacing:.02em; color:#0f172a;
}

/* 2) 経営理念・社是：企業サイト向けに落ち着いたデザインへ */
body.company-about .ph-two-col{
  display:grid; grid-template-columns:1.3fr 1fr; gap:32px; margin:28px 0 40px;
}
@media (max-width:900px){ body.company-about .ph-two-col{ grid-template-columns:1fr; gap:20px; }}

/* 見出し */
body.company-about .ph-head{ font-size:18px; font-weight:700; color:#0f172a; margin:0 0 12px; }

/* 背景カード（両カラム共通） */
body.company-about .philosophy-block,
body.company-about .creed-block{
  background:#f9fafb; border:1px solid #e2e8f0; border-radius:12px;
  padding:24px; box-shadow:0 3px 10px rgba(0,0,0,.04);
}

/* シンボル（円⇄角丸□ 切替可） */
body.company-about .ph-pills{
}
body.company-about .pill{
  width:var(--pill-size); height:var(--pill-size); border-radius:var(--pill-radius);
  display:grid; place-items:center; border:3px solid currentColor; background:#fff;
  font-weight:700; font-size:18px; line-height:1;
}
body.company-about .pill.pill-contribution{ color:#2563eb; border-color:#60a5fa; }
body.company-about .pill.pill-growth      { color:#ca8a04; border-color:#facc15; }
body.company-about .pill.pill-harmony     { color:#16a34a; border-color:#4ade80; }

/* 理念本文 */
body.company-about .ph-message{
  background:#fff; border:1px solid #e5e7eb; border-radius:10px;
  padding:16px 18px; line-height:1.9; color:#334155;
}

/* 社是（整然としたカード列） */
body.company-about .creed{ list-style:none; padding:0; margin:0; }
body.company-about .creed li{
  display:flex; align-items:center; gap:.6em;
  background:#fff; border:1px solid #e2e8f0; border-radius:10px;
  padding:12px 14px; margin:10px 0; font-weight:700; color:#1e293b;
  box-shadow:0 1px 2px rgba(0,0,0,.05);
}
/* 「一、二、三、」の字下げを安定させる */
body.company-about .creed li > b{ min-width:2.4em; display:inline-block; color:#475569; font-weight:700; }

body.company-about .pill{
  position: relative;
  width: 130px; height: 130px;
  border-radius: 50%;
  border: 5px solid transparent;
  background-clip: padding-box;
  opacity: 0.9;
}

body.company-about .ph-pills{ display:flex; align-items:center; gap:0; margin:12px 0 20px; }
body.company-about .ph-pill{
  flex:0 0 auto; width:120px; height:120px; border-radius:20px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:700; font-size:18px; position:relative; z-index:1;
}
body.company-about .ph-pill + .ph-pill{ margin-left:-20px; }
body.company-about .ph-pill--contribution{ background:rgba(37,99,235,.88); z-index:1; }
body.company-about .ph-pill--growth      { background:rgba(234,179,8,.88);  z-index:2; }
body.company-about .ph-pill--harmony     { background:rgba(16,185,129,.88); z-index:3; }

/* ========== 社是 / CREED：横長カプセル & 淡色トーン ========== */
body.company-about .creed{
  display: flex;
  flex-direction: column;
  gap: 12px;                 /* 行間 */
  margin: 8px 0 0;
}

body.company-about .creed li{
  display: flex;
  align-items: center;
  gap: .75em;                /* 番号と本文の間隔 */
  padding: 12px 16px;
  border-radius: 999px;      /* 横長の丸（カプセル） */
  border: 1px solid transparent;
  background: #f6f8fb;
  color: #0f172a;
  font-weight: 700;
  line-height: 1.6;
  box-shadow: 0 1px 0 rgba(255,255,255,.6) inset,
              0 6px 18px rgba(2,6,23,.06);
}

/* 左側に小さなカラードット（視線誘導） */
body.company-about .creed li::before{
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  flex: 0 0 10px;
  box-shadow: 0 0 0 3px rgba(255,255,255,.9) inset;
}

/* 1行目（青） */
body.company-about .creed li:nth-child(1){
  background: rgba(59,130,246,.10);
  border-color: rgba(59,130,246,.28);
}
body.company-about .creed li:nth-child(1)::before{ background:#3b82f6; }

/* 2行目（橙） */
body.company-about .creed li:nth-child(2){
  background: rgba(245,158,11,.10);
  border-color: rgba(245,158,11,.30);
}
body.company-about .creed li:nth-child(2)::before{ background:#f59e0b; }

/* 3行目（緑） */
body.company-about .creed li:nth-child(3){
  background: rgba(16,185,129,.12);
  border-color: rgba(16,185,129,.28);
}
body.company-about .creed li:nth-child(3)::before{ background:#10b981; }

/* ホバー時：うっすら濃く */
@media (hover:hover){
  body.company-about .creed li:hover{

  }
}

/* モバイルでのはみ出し防止（カプセルは常に親幅内） */
body.company-about .creed li{ max-width: 100%; }

/* ===============================
   works.html 施工実績カード（中間サイズ）
=============================== */
body.page-works .works-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); /* ← 220〜可変 */
  gap: 28px; /* 少し余裕をもたせて間延び防止 */
  justify-items: center;
  margin-top: 24px;
}

body.page-works .works-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  padding: 18px 14px;
  box-shadow: 0 5px 14px rgba(2,6,23,.08);
  text-decoration: none;
  color: inherit;
  transition: transform .25s ease, box-shadow .25s ease;
  justify-self: center; /* ← カードを中央揃え */

}

body.page-works .works-item img {
  width: 100%;
  border-radius: 10px;
  margin: 10px;
}

body.page-works .works-caption {
  display: block;
  font-weight: 600;
  font-size: 15px;
  text-align: center;
  color: #334155;
  background: linear-gradient(to right, #e2e8f0, #f1f5f9);
  border-radius: 8px;
  padding: 6px 10px;
}


/* ====================================
   HERO（全ページ同一の“形”）＋ ページ別“動作”は変数で
   ※ このブロックを style.css の一番後ろに配置
==================================== */

/* 器：高さ・クリッピング */
.top-img {
  position: relative;
  overflow: hidden;
    min-height: clamp(310px, 40vh, 620px);
  padding: 0;
  background: transparent;
}
/* トップページだけ従来の高さに戻す */
body.page-top .top-img {
  min-height: clamp(360px, 52vh, 720px);
}

/* 画像：中央基準。位置は変数で微調整可 */
.top-img > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--hero-pos-x, 50%) var(--hero-pos-y, 50%);
  transform-origin: var(--hero-pos-x, 50%) var(--hero-pos-y, 50%);
  opacity: var(--hero-opacity-start, 0);
  transform:
    scale(var(--hero-scale-start, 1.06))
    translate(var(--hero-tx-start, 0), var(--hero-ty-start, 0));
  filter:
    grayscale(var(--hero-gray-start, 100%))
    brightness(var(--hero-bright-start, 1.1));
  animation:
    var(--hero-anim, hero-zoomfade)
    var(--hero-duration, 2s)
    var(--hero-ease, ease-out)
    var(--hero-delay, 0s)
    forwards;
}


/* タイトル群の配置（左下寄せ） */
.top-img .cap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  text-align: left;
  padding: clamp(12px, 2.2vw, 20px) clamp(16px, 3vw, 28px);
  opacity: 0;
  transform: translateY(12px);
  animation:
    var(--cap-anim, cap-rise)
    var(--cap-duration, 1.2s)
    ease-out
    var(--cap-delay, 1s)
    forwards;
}

/* cap 内に .container があるケースの余白調整（任意） */
.top-img .cap .container { padding-left: 0; padding-right: 0; }

/* 背景ボックス（採用情報準拠） */
.top-img .cap-bg {
  display: inline-block;
  padding: clamp(12px, 2vw, 20px) clamp(16px, 3vw, 28px);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.25);
}

/* タイトル／サブ（共通） */
.top-img .hero-title {
  margin: 0 0 clamp(6px, 0.8vw, 10px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.02em;
  font-size: clamp(28px, 4.6vw, 40px);
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,.55);
}
.top-img .sub {
  margin: 0;
  font-weight: 500;
  line-height: 1.5;
  font-size: clamp(16px, 2vw, 20px);
  color: #f1f5f9;
  text-shadow: 0 1px 6px rgba(0,0,0,.45);
}

/* タイトル画像（あるページのみ） */
.top-img .sec-ttl-img {
  display: block;
  max-width: min(72vw, 520px);
  height: auto;
  margin: 0 0 clamp(8px, 1.2vw, 14px);
}

/* ============ 共通キーフレーム ============ */
@keyframes hero-zoomfade {
  to { opacity: 1; transform: scale(1) translate(0,0); filter: grayscale(0%) brightness(1); }
}
@keyframes hero-fade {
  to { opacity: 1; transform: none; filter: none; }
}
@keyframes hero-pan-up {
  to { opacity: 1; transform: scale(1.02) translate(0, -2%); filter: grayscale(0%) brightness(1); }
}
@keyframes hero-pan-left {
  to { opacity: 1; transform: scale(1.02) translate(-2%, 0); filter: grayscale(0%) brightness(1); }
}
@keyframes hero-none { to { opacity: 1; } }
@keyframes cap-rise { to { opacity: 1; transform: translateY(0); } }

/* ============ ページ別“動作だけ”指定（必要に応じて調整） ============ */

/* トップ */
body.page-top {
  --hero-anim: hero-zoomfade;
  --hero-duration: 2.4s;
  --hero-scale-start: 1.08;
  --hero-gray-start: 100%;
  --hero-bright-start: 1.2;
  --cap-delay: 1.1s;
}

/* 会社概要 */
body.company-about {
  --hero-anim: hero-pan-up;
  --hero-duration: 1.6s;
  --hero-scale-start: 1.03;
  --hero-gray-start: 60%;
  --hero-bright-start: 1.05;
  --cap-delay: 0.8s;
}

/* 施工実績（一覧） */
body.page-works {
  --hero-anim: hero-fade;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.04;
  --hero-gray-start: 100%;
  --hero-bright-start: 1.1;
  --cap-delay: 1s;
}

/* 採用情報 */
body.page-recruit {
  --hero-anim: hero-pan-left;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.02;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.08;
  --cap-delay: 1s;
}

/* 社員メッセージ */
body.page-voice {
  --hero-anim: hero-none;
  --hero-duration: 1.0s;
  --hero-scale-start: 1;
  --hero-gray-start: 0%;
  --hero-bright-start: 1;
  --cap-delay: 0.6s;
}

/* 取り組み */
body.page-initiatives {
  --hero-anim: hero-pan-up;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.05;
  --hero-gray-start: 100%;
  --hero-bright-start: 1.1;
  --cap-delay: 0.9s;
}

/* 沿革 */
body.page-history {
  --hero-anim: hero-zoomfade;
  --hero-duration: 2.0s;
  --hero-scale-start: 1.06;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.15;
  --cap-delay: 1.2s;
}

/* パトロール */
body.page-patrol {
  --hero-anim: hero-zoomfade;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.05;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.08;
  --cap-delay: 0.9s;
}

/* ポリシー */
body.page-policy {
  --hero-anim: hero-fade;
  --hero-duration: 1.2s;
  --hero-scale-start: 1;
  --hero-gray-start: 0%;
  --hero-bright-start: 1;
  --cap-delay: 0.8s;
}

/* お問い合わせ */
body.page-contact {
  --hero-anim: hero-fade;
  --hero-duration: 1.2s;
  --hero-scale-start: 1;
  --hero-gray-start: 0%;
  --hero-bright-start: 1;
  --cap-delay: 0.8s;
}

/* ---------- 採用詳細（募集要項など） ---------- */
body.page-job {
  --hero-anim: hero-fade;
  --hero-duration: 1.2s;
  --hero-scale-start: 1;
  --hero-gray-start: 0%;
  --hero-bright-start: 1;
  --cap-delay: 0.8s;
}

/* ---------- 施工実績 詳細ページ ---------- */
body.page-works-detail {
  --hero-anim: hero-fade;
  --hero-duration: 1.6s;
  --hero-scale-start: 1.02;
  --hero-gray-start: 90%;
  --hero-bright-start: 1.1;
  --cap-delay: 1.0s;
}

/* ---------- パトロール 詳細ページ ---------- */
body.page-patrol-detail {
  --hero-anim: hero-zoomfade;
  --hero-duration: 1.8s;
  --hero-scale-start: 1.04;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.08;
  --cap-delay: 0.9s;
}

/* パトロール：共通cap構造のまま旧見た目を再現 */
body.page-patrol .top-img .cap { bottom: 8%; } /* 旧 inset: auto 0 8% を同義に */
body.page-patrol .top-img .cap-bg{
  padding: clamp(10px, 1.4vw, 14px) clamp(14px, 2vw, 20px);
  border-radius: 12px;
  background: rgba(17,24,39,.58);            /* 旧の濃さに寄せる */
  backdrop-filter: saturate(140%) blur(2px);  /* 旧と同等の質感 */
}
/* 画像の動作はページ変数で：例（任意） */
body.page-patrol{
  --hero-anim: hero-zoomfade;
  --hero-duration: 2.4s;  /* 旧 2.4s に合わせたいなら */
  --hero-scale-start: 1.06;
  --hero-gray-start: 100%;
  --hero-bright-start: 0.92;
  --cap-delay: 0.9s;
}


/* アイコン付き見出し：旧の絶対配置レイアウトを汎用化 */
.top-img .hero-title--icon{
  position: relative;
  display: block;
  padding-left: clamp(68px, 6vw, 88px); /* 旧: 88px を可変化 */
  line-height: 1.2;
  margin: 0 0 6px;
}
.top-img .hero-title--icon .hero-icon{
  position: absolute;
  left: 0;
  top: 20%;
  transform: translateY(-10%);          /* 旧: top:20% + translateY(-30%) を中央寄せに最適化 */
  width: clamp(48px, 6vw, 72px);
  height: clamp(48px, 6vw, 72px);
  object-fit: contain;
  border-radius: 12px;
  background: #fff;
  padding: 4px;
  box-shadow: 0 3px 12px rgba(0,0,0,.25);
}
.top-img .hero-title--icon + .sub{
  margin-left: clamp(72px, 6.4vw, 95px); /* 旧: 95px 相当 */
}

/* history専用：最終状態に blur を含める */
@keyframes hero-zoomfade-history {
  to {
    opacity: 1;
    transform: scale(1) translate(0,0);
    filter: grayscale(0%) brightness(1) blur(2px); /* ← ここがポイント */
  }
}

/* historyページ用の変数上書き（後勝ちの場所に） */
body.page-history {
  --hero-anim: hero-zoomfade-history; /* ← これでblur入りの最終フレームを使う */
  --hero-duration: 2.0s;
  --hero-scale-start: 1.06;
  --hero-gray-start: 80%;
  --hero-bright-start: 1.15;
  /* 位置は必要なら：--hero-pos-x:50%; --hero-pos-y:50%; */
}


/* -----------------------------------
   位置の初期化・微調整（後勝ち）
   全ページ50%で中央表示を基準化
----------------------------------- */
body.page-top           { --hero-pos-x: 50%; --hero-pos-y: 50%; }
body.company-about      { --hero-pos-x: 50%; --hero-pos-y: 50%; }
body.page-works         { --hero-pos-x: 50%; --hero-pos-y: 35%; }
body.page-works-detail  { --hero-pos-x: 50%; --hero-pos-y: 35%; }
body.page-recruit       { --hero-pos-x: 50%; --hero-pos-y: 45%; }
body.page-job           { --hero-pos-x: 50%; --hero-pos-y: 45%; }
body.page-voice         { --hero-pos-x: 50%; --hero-pos-y: 40%; }
body.page-initiatives   { --hero-pos-x: 50%; --hero-pos-y: 30%; }
body.page-history       { --hero-pos-x: 50%; --hero-pos-y: 70%; }
body.page-patrol        { --hero-pos-x: 50%; --hero-pos-y: 50%; }
body.page-patrol-detail { --hero-pos-x: 50%; --hero-pos-y: 50%; }
body.page-policy        { --hero-pos-x: 50%; --hero-pos-y: 35%; }
body.page-contact       { --hero-pos-x: 50%; --hero-pos-y: 50%; }
body.page-message       { --hero-pos-x: 50%; --hero-pos-y: 40%; }


.page-works .initiatives-fuji p 	{
	font-size: 18px;
	line-height: 1.85;
	margin: 0 0 1.2em;
	color: #374151;
}

.page-works .initiatives-fuji .btn-wrap 	{
	margin-top: 16px;
}

.page-works .initiatives-fuji .btn-link 	{
	display: inline-block;
	padding: 12px 22px;
	font-size: 18px;
	font-weight: 600;
	color: #fff;
	background: #0ea5e9;
	border-radius: 9999px;
	text-decoration: none;
	transition: background .2s, transform .15s;
}

.page-works .initiatives-fuji .btn-link:hover 	{
	background: #0284c7;
	transform: translateY(-2px);
}

.page-works .initiatives-fuji .btn-link:active 	{
	transform: translateY(0);
}



/* =====================================================
   富士山パトロールブロック（initiatives ページ専用）
===================================================== */
.fuji-hero {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  background-size: cover;
  background-position: center 50%;
  background-repeat: no-repeat;
  min-height: 260px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

/* 背景の暗幕（上に透明グラデーションを重ねる） */
.fuji-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom right, rgba(0,0,0,0.2), rgba(0,0,0,0.05));
  z-index: 0;
}

/* テキストエリア（白半透明＋角丸＋シャドウ） */
.fuji-hero__cap {
  position: relative;
  z-index: 1;
  background: rgba(255,255,255,0.85);
  color: #111;
  border-radius: 12px;
  padding: clamp(16px, 3vw, 24px) clamp(20px, 4vw, 32px);
  margin: clamp(16px, 4vw, 32px);
  max-width: 640px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
}

/* テキスト */
.fuji-lead {
  font-weight: 600;
  line-height: 1.6;
  margin: 0;
}

/* 区切り線 */
.fuji-divider {
  width: 100%;
  height: 1px;
  background: rgba(0,0,0,0.08);
  margin: clamp(12px, 2vw, 16px) 0;
}

/* CTAボタンの配置 */
.fuji-cta {
  display: flex;
  justify-content: flex-end;
}

/* CTAボタン */
.btn-link.btn-link--lg {
  display: inline-block;
  background: linear-gradient(to right, #00AEEF, #0095D9);
  color: #fff;
  font-weight: 600;
  padding: 12px 28px;
  border-radius: 24px;
  text-decoration: none;
  transition: 0.2s ease;
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.25);
}
.btn-link.btn-link--lg:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

/* トップページのヒーロータイトルを1行固定 */
body.page-top .hero-title {
  white-space: nowrap;
}

/* HEROタイトルの黒枠：光学的に下を厚めにしてバランス調整 */
.top-img .cap-bg{
  padding-top:  clamp(10px, 1.6vw, 14px);
  padding-bottom: clamp(16px, 2.4vw, 22px);
}

/* -------------------------------------
   WORKS / RECRUIT：黒枠の内側上余白を狭くする
------------------------------------- */
body.page-works   .top-img .cap-bg,
body.page-recruit .top-img .cap-bg {
  padding-top:  clamp(10px, 1.6vw, 14px);
  padding-bottom: clamp(18px, 2.5vw, 24px);
}


/* PCだけ1行固定、SPは折り返し */
@media (min-width: 768px){
  body.page-top .hero-title { white-space: nowrap; }
}
@media (max-width: 767.98px){
  body.page-top .hero-title {
    white-space: normal;      /* ← SPで改行可 */
    overflow-wrap: anywhere;  /* 英字/長い語の強制折り */
  }
  /* 念のため枠も画面内に収める保険 */
  body.page-top .top-img .cap{
    max-width: calc(100% - 24px);
    margin-inline: 12px;
  }
}



/* =========================================================
   initiatives（取り組み）= recruit のレイアウト流用（1:1複製）
   ※ 後勝ちで適用／将来の差分調整もしやすいよう別ブロック化
========================================================= */

.page-initiatives {
  --c-accent: #0ea5e9;
  --c-line: #e5e7eb;
  --c-card: #f9fafb;
  --c-sub: #6b7280;
  --c-txt: #111827;
}

/* recruit系の見栄え・グリッド・カード等をそのまま複製 */
.page-initiatives .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border: 1px solid var(--c-accent);
  border-radius: 999px;
  background: #e0f2fe;
  color: #075985;
  text-decoration: none;
  font-weight: 600;
  transition: transform .05s ease, background .2s ease;
}
.page-initiatives .btn:hover { background: #bae6fd; }
.page-initiatives .btn:active { transform: translateY(1px); }

.page-initiatives .img4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.page-initiatives .img4 figure {
  margin: 0;
  border-radius: 12px;
  overflow: hidden;
  background: #f3f4f6;
  border: 1px solid var(--c-line);
  aspect-ratio: 4 / 3;
  max-height: 200px;
}
.page-initiatives .img4 img { width: 100%; height: 100%; object-fit: cover; }

.page-initiatives .jobs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
}

.page-initiatives .benefit-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.page-initiatives .benefit {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 12px;
  align-items: start;
  padding: 16px;
  border: 1px solid var(--c-line);
  border-radius: 16px;
  background: var(--c-card);
}
.page-initiatives .benefit h3 { margin: 0 0 6px; font-size: 16px; }
.page-initiatives .benefit p  { margin: 0; font-size: 14px; color: var(--c-sub); line-height: 1.8; }
.page-initiatives .ico {
  width: 36px; height: 36px; display: grid; place-items: center;
  border-radius: 10px; background: #dbeafe; border: 1px solid #bfdbfe;
}
.page-initiatives .ico svg { width: 20px; height: 20px; color: #1d4ed8; }

.page-initiatives .data-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}
.page-initiatives .data-card {
  text-align: center;
  border: 1px solid var(--c-line);
  border-radius: 16px;
  background: linear-gradient(180deg, #fff, #f8fafc 70%);
  padding: 16px;
}
.page-initiatives .data-ttl {
  font-size: 13px; color: var(--c-sub);
  display: flex; justify-content: center; align-items: center; gap: 6px;
}
.page-initiatives .data-num { font-size: 28px; font-weight: 800; letter-spacing: .02em; }

.page-initiatives .voice-block { margin-top: 32px; }
.page-initiatives .voice-block .sec-ttl {
  font-size: 22px; margin-bottom: 14px; display: flex; align-items: center; gap: 10px;
}
.page-initiatives .voice-block .sec-ttl span {
  display:inline-block; width:6px; height:18px; border-radius:3px; background:#0ea5e9;
}
.page-initiatives .voice-bubble { display:flex; align-items:flex-start; gap:16px; }
.page-initiatives .voice-avatar {
  position: relative; flex:0 0 72px; height:72px; border-radius:50%; overflow:hidden;
  background:#fff; box-shadow:0 2px 8px rgba(2,6,23,.08);
}
.page-initiatives .voice-avatar img { width:100%; height:100%; object-fit:cover; display:block; }
.page-initiatives .voice-avatar .avatar-fallback {
  position:absolute; inset:0; display:grid; place-items:center;
  background: radial-gradient(circle at 30% 25%, #e6f1ff, #cfe3ff);
  color:#1e3a8a; font-weight:800; font-size:20px;
}
.page-initiatives .voice-avatar .avatar-fallback::after { content: attr(data-initial); }
.page-initiatives .voice-balloon {
  position:relative; flex:1; background: linear-gradient(#f4faff,#eef7ff);
  border:1px solid #cfe3ff; color:#0f172a; border-radius:14px;
  padding:16px 18px; box-shadow: 0 2px 10px rgba(2,6,23,.06) inset;
}
.page-initiatives .voice-balloon::before{
  content:""; position:absolute; left:-10px; top:20px; width:0; height:0;
  border:10px solid transparent; border-right-color:#cfe3ff;
}
.page-initiatives .voice-balloon::after{
  content:""; position:absolute; left:-8px; top:21px; width:0; height:0;
  border:9px solid transparent; border-right-color:#f4faff;
}
.page-initiatives .voice-balloon p { margin:0 0 10px; line-height:1.85; letter-spacing:.01em; }
.page-initiatives .voice-meta { color:#475569; font-size:12px; margin-bottom:8px; }
.page-initiatives .voice-link{
  display:inline-block; padding:8px 14px; font-weight:700; border:1px solid #3b82f6;
  color:#1e40af; border-radius:999px; background:#eef6ff; text-decoration:none;
  transition: transform .15s, box-shadow .15s, background .15s, border-color .15s;
}
.page-initiatives .voice-link:hover{
  transform: translateY(-1px); background:#e0efff; border-color:#2563eb;
}

.page-initiatives .section { padding: 36px 0; border-top: 1px solid #e5e7eb; }
.page-initiatives .section:first-of-type { border-top: none; padding-top: 0; }

.page-initiatives h2.sec-ttl {
  margin: 0 0 16px; font-size: 24px; letter-spacing: .08em; display:flex; align-items:center; gap:10px;
}
.page-initiatives h2.sec-ttl .bar { width:6px; height:20px; border-radius:6px; background:#0ea5e9; }
.page-initiatives .lead { color:#6b7280; margin:6px 0 0; font-size:14px; }

.page-initiatives .license dl {
  display:grid; grid-template-columns: 1fr auto; column-gap: 6px; row-gap: 12px; align-items:center;
}
.page-initiatives .license dl div { display:flex; align-items:center; gap:6px; }
.page-initiatives .license dt {
  padding: 8px 6px 8px 12px; font-size: 15px; font-weight: 700; color: #0f172a;
  border: 1px solid #cbd5e1; border-radius: 10px;
  background: linear-gradient(90deg, #dbeafe calc(var(--p,0) * 1%), transparent 0), #fff;
  background-clip: padding-box; position: relative;
}
.page-initiatives .license dt::before { content: none; }
.page-initiatives .license dd {
  flex: none; width:58px; height:58px; border-radius:50%; background:#eff6ff; border:1px solid #bfdbfe;
  color:#1e3a8a; display:flex; align-items:center; justify-content:center; gap:2px; font-weight:800;
}
.page-initiatives .license dd .num { font-size:24px; line-height:1; }
.page-initiatives .license dd .unit { position:relative; top:2px; font-size:13px; font-weight:600; line-height:1.2; }

.page-initiatives .badge-new {
  display:inline-block; margin-left:12px; padding:4px 10px; font-size:15px; font-weight:700;
  color:#dc2626; border:2px solid #dc2626; border-radius:6px; background:#fff; line-height:1.4; vertical-align:middle; transform: rotate(-10deg);
}

.page-initiatives .job-info { display:flex; align-items:center; justify-content:flex-start; gap:10px; }

/* recruitの「声」モザイク系 */
.page-initiatives .voice-mosaic {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px;
}
.page-initiatives .voice-mosaic figure {
  overflow: hidden; border-radius: 12px; background: #fff; box-shadow: 0 1px 4px rgba(2,6,23,.06); aspect-ratio: 4/3;
}
.page-initiatives .voice-mosaic img {
  width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .25s ease;
}
.page-initiatives .voice-mosaic img:hover { transform: scale(1.035); }

.page-initiatives .sec-voice h2 {
  display:flex; align-items:center; gap:8px; font-size:22px; font-weight:700; color:#111; margin: 0 0 16px;
}
.page-initiatives .sec-voice h2::before { content:""; width:4px; height:20px; border-radius:2px; background:#3b82f6; }

.page-initiatives .voice-grid {
  --g: 24px;
  display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: var(--g);
}
.page-initiatives .voice-shot {
  width:100%; display:block; border-radius:12px; box-shadow: 0 2px 6px rgba(0,0,0,.04);
}
.page-initiatives .voice-box {
  grid-column: 1 / -1; display:grid; grid-template-columns: 1fr auto; align-items:center; gap:16px;
  padding: clamp(16px, 2vw, 24px); border-radius:12px; background:#f9fbff; border:1px solid #e0e7ff; box-shadow: 0 2px 6px rgba(0,0,0,.04); width:100%;
}
.page-initiatives .voice-box p { margin:0; font-size: clamp(14px, 1.6vw, 15.5px); line-height:1.85; word-break: normal; overflow-wrap: anywhere; }
.page-initiatives .voice-box .voice-link {
  justify-self: end; display:inline-block; padding:14px 28px; font-size:16px; font-weight:500; color:#fff;
  text-decoration:none; background:#0ea5e9; border-radius:45px; box-shadow:0 2px 6px rgba(14,165,233,.25);
  transition: background .2s, transform .15s, box-shadow .2s;
}
.page-initiatives .voice-box .voice-link:hover { background:#0284c7; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(2,132,199,.3); }
.page-initiatives .voice-box .voice-link:active { transform: translateY(0); box-shadow: 0 2px 6px rgba(0,0,0,.15); }

/* 見出しなど */
.page-initiatives h2.sec-ttl .bar { background:#0ea5e9; }


/* ---------- responsive（recruitと同値を複製） ---------- */
@media (max-width: 1024px) {
  .page-initiatives .benefit-grid { grid-template-columns: repeat(2,1fr); }
  .page-initiatives .data-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 640px) {
  .page-initiatives .img4 { grid-template-columns: repeat(2,1fr); }
  .page-initiatives .benefit-grid { grid-template-columns: 1fr; }
  .page-initiatives .data-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) {
  .page-initiatives .voice-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .page-initiatives .voice-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) {
  .page-initiatives .voice-box { grid-template-columns: 1fr; }
  .page-initiatives .voice-box .voice-link { justify-self: end; margin-top: 10px; }
}
@media (max-width: 560px) {
  .page-initiatives .voice-box .voice-link {
    justify-self: stretch; display:block; text-align:center; padding: 14px 18px; border-radius: 9999px;
  }
}
@media (max-width: 768px) {
  .page-initiatives .jobs { grid-template-columns: 1fr; gap: 14px; }
}
@media (max-width: 768px) {
  .page-initiatives .voice-bubble { flex-direction: column; }
  .page-initiatives .voice-avatar { width: 64px; height: 64px; }
  .page-initiatives .voice-balloon { padding: 14px 16px; }
}

/* ======================================================
   HERO：採用＝右パン ／ 取り組み＝左パン（安全マージン入り最終版）
   ====================================================== */

/* 共通：オーバーフロー隠し＋中央アンカー設定 */
body.page-recruit .top-img,
body.page-initiatives .top-img {
  position: relative;
  overflow: hidden;
}

/* 基本画像スタイル（色は触らない） */
body.page-recruit .top-img > img,
body.page-initiatives .top-img > img {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 100%;
  max-width: none;
  min-width: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: var(--hero-pos-x, 50%) var(--hero-pos-y, 50%);
  transform-origin: center center;
  filter: none;
  opacity: 0;
  backface-visibility: hidden;   /* サブピクセル誤差防止 */
  will-change: transform, opacity;
}

/* ===== 採用情報：右パン（右端スキマ防止・2%余裕） ===== */
@keyframes hero-pan-right-safe {
  0%   { opacity: 0; transform: translate(-52%, -50%) scale(1.08); }
  100% { opacity: 1; transform: translate(-50%, -50%) scale(1.02); }
}

body.page-recruit .top-img > img {
  transform: translate(-50%, -50%) scale(1.06);
  animation: hero-pan-right-safe 1.8s ease-out 0s 1 forwards;
}

/* ===== 取り組み：左パン（左端スキマ防止・2%余裕） ===== */
@keyframes hero-pan-left-safe {
  0%   { opacity: 0; transform: translate(-48%, -50%) scale(1.08); }
  100% { opacity: 1; transform: translate(-50%, -50%) scale(1.02); }
}

body.page-initiatives .top-img > img {
  transform: translate(-50%, -50%) scale(1.06);
  animation: hero-pan-left-safe 2.0s ease-out 0s 1 forwards;
}

/* ===== iOS/Safari丸め誤差対策（SPのみ1.5%拡大） ===== */
@media (max-width: 768px) {
  body.page-recruit .top-img > img,
  body.page-initiatives .top-img > img {
    width: 101.5%;
    height: 101.5%;
  }
}

/* ===== works / works-detail：器はクリップ＋中央アンカー ===== */
body.page-works .top-img,
body.page-works-detail .top-img { position: relative; overflow: hidden; }

body.page-works .top-img > img,
body.page-works-detail .top-img > img {
  position: absolute; left:50%; top:50%;
  width:100%; height:100%; max-width:none; min-width:100%; min-height:100%;
  object-fit: cover; object-position: var(--hero-pos-x,50%) var(--hero-pos-y,35%);
  transform-origin: center center; filter:none; opacity:0;
  backface-visibility: hidden; will-change: transform, opacity;
}

/* === A) works：Snap Zoom（弾みあり・はっきり差別化） === */
@keyframes hero-zoom-snap-safe {
  0%   { opacity:0; transform: translate(-50%,-50%) scale(1.12); }
  70%  { opacity:1; transform: translate(-50%,-50%) scale(0.995); }
  100% { opacity:1; transform: translate(-50%,-50%) scale(1.00); }
}
body.page-works .top-img > img {
  transform: translate(-50%,-50%) scale(1.08);
  animation: hero-zoom-snap-safe 1.2s ease-out 0s 1 forwards;
}

/* === B) works-detail：Tilt＋Diagonal（右下→中央へ微パン） === */
@keyframes hero-tilt-diagonal-safe {
  /* 右下側から入れてカバーを確保（端の白帯防止） */
  from { opacity:0; transform: translate(-49.0%,-51.0%) scale(1.08) rotate(-1.1deg); }
  to   { opacity:1; transform: translate(-50%,-50%)  scale(1.00) rotate(0deg); }
}
body.page-works-detail .top-img > img {
  transform: translate(-50%,-50%) scale(1.06);
  animation: hero-tilt-diagonal-safe 1.6s ease-out 0s 1 forwards;
}

/* SPのサブピクセル誤差保険 */
@media (max-width: 768px) {
  body.page-works .top-img > img,
  body.page-works-detail .top-img > img { width:101.5%; height:101.5%; }
}

/* ===== works-detail：酔いにくいフォーカスプル（微ズームのみ） ===== */
@keyframes hero-focus-pull-safe {
  0%   { opacity: 0; transform: translate(-50%, -50%) scale(1.04); }
  100% { opacity: 1; transform: translate(-50%, -50%) scale(1.00); }
}
body.page-works-detail .top-img > img{
  /* 既存より後でこの2行が上書きされればOK */
  transform: translate(-50%, -50%) scale(1.04);
  animation: hero-focus-pull-safe 1.2s ease-out 0s 1 forwards;
}

/* 動きを極力抑えたい環境への配慮（任意） */
@media (prefers-reduced-motion: reduce){
  body.page-works-detail .top-img > img{
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
  }
}

/* HERO文字装飾のみ（下線をやや暗く調整） */
body.page-top .top-img .cap h1 {
  color: #fff;
  text-shadow:
    0 1px 0 rgba(0,0,0,.45),
    0 2px 6px rgba(0,0,0,.35),
    0 0 24px rgba(0,0,0,.15);
  background-image:
    linear-gradient(transparent calc(100% - 6px), rgba(255,255,255,0.55) 0); /* ← 明度を下げたライン色 */
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: 100% 100%;
}

body.page-top .top-img .cap p {
  color: rgba(255,255,255,.92);
  text-shadow:
    0 1px 0 rgba(0,0,0,.35),
    0 2px 10px rgba(0,0,0,.25);
}


header .brand img {
  transition: transform 0.6s ease;
}
header .brand img:hover {
  transform: rotate(360deg);
}

/* 見出し帯：会社情報/NEWSで共通利用 */
.band {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: .6rem 1rem;
  border-radius: 24px;
  background: #d9dfe7;            /* 会社情報の帯と同色 */
  box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
  position: relative;
  overflow: hidden;
}
.band__chip {
  display: inline-block;
  padding: .25rem .7rem;
  border-radius: 9999px;
  font-size: .8rem;
  line-height: 1;
  color: #5a6472;
  background: #eef2f6;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.band__title {
  font-size: 1.35rem;
  font-weight: 700;
  color: #2a3440;
  letter-spacing: .02em;
}

/* ヘッダー／フッターのグリッドはそのまま維持（他には出さない） */
header, footer { position: relative; z-index: 0; overflow: hidden; }
header::before, footer::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(#ccc 1px, transparent 1px),
    linear-gradient(90deg, #ccc 1px, transparent 1px);
  background-size: 14px 14px;
  opacity: .2; pointer-events: none; z-index: -1;
}

/* topページ余白調整 */
.section--news,
.section--company,
.section--works {
  margin-bottom: 25px;
}


.page-history .history-timeline .desc {
  font-size: 0.94rem; /* 約15px相当に */
  line-height: 1.65;  /* 行間はそのまま維持 */
}

.page-history .history-timeline .point {
  font-size: 0.9rem;
}

.page-history .history-timeline .point .era,
.page-history .history-timeline .point .year,
.page-history .history-timeline .point .month {
  font-weight: 400;
}

.page-history .history-timeline .point .era {
  padding-left:7px;
}

.page-recruit .hero-message {
  font-size: 1.1rem; /* 現在より少し大きめ。必要に応じて1.2rem程度まで調整可 */
  line-height: 1.8;
}

/* TOP：会社カードのホバーを強める */
.page-top .company-card{
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease, filter .22s ease;
}
.page-top .company-card:hover{
  transform: translateY(-4px);                 /* -2px → -4px相当 */
  box-shadow: 0 18px 40px rgba(2,6,23,.16);     /* 影を一段強く */
  border-color: #cfd6e2;
  filter: saturate(1.03);                       /* 色をほんの少しだけ艶やかに */
}

/* ワイド帯：ホバーで暗幕が少し薄くなり、奥行きを強調 */
.wide .overlay{
  transition: background .25s ease;
}
.wide:hover .overlay{
  background: linear-gradient(0deg, rgba(2,6,23,.46), rgba(2,6,23,.16));
}


/* NEWS：リンクの下線スライド */
.news-link{
  background:
    linear-gradient(currentColor, currentColor) left 100%/0 1.5px no-repeat;
  transition: background-size .25s ease, color .2s ease;
}
.news-item:hover .news-link{
  background-size: 100% 1.5px; /* 左→右に伸びる */
  color: #0b1f4a;              /* 文字もわずかに濃く */
}

/* ヘッダー：hoverで下線バー */
header nav a{
  position: relative;
}
header nav a::after{
  content:"";
  position: absolute;
  left: 12px; right: 12px; bottom: 4px;
  height: 2px;
  background: rgba(255,255,255,.9);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .18s ease;
  border-radius: 2px;
}
header nav a:hover::after{
  transform: scaleX(1);
}

@media (prefers-reduced-motion: reduce){
  .page-top .company-card,
  .page-top .company-card * ,
  .wide .bg, .wide .overlay,
  .news-link, header nav a::after {
    transition: none !important; /* ← ここだけ配慮で使用 */
  }
}

/* 施工実績パネル：画像サイズを安定させる */
.page-works .works-item img{
  display:block;
  height: 140px;     /* デスクトップの見栄え基準 */
  width: auto;       /* 横は自動。これで小さくならない */
  transform-origin: center;
  transition: transform .28s ease;
}

/* スマホは少しだけ小さめに */
@media (max-width: 640px){
  .page-works .works-item img{ height: 120px; }
}

/* ホバー時の拡大（そのまま活かす） */
.page-works .works-item:hover img{
  transform: scale(1.08);
  filter:none;
  filter: brightness(1.15); /* ★ 少し明るくする（1.10〜1.20で微調整可） */
}
}

/* スマホで長い場合はフォントサイズを少しだけ下げる */
@media (max-width: 480px) {
  .cap .sub {
    font-size: 0.85rem;
    letter-spacing: 0.02em;
  }
}

/* NEWS：下線アニメの安定版（整数pxでスナップ） */
.news-link{
  text-decoration: none;
  background: linear-gradient(currentColor, currentColor) 0 100% / 0 1px no-repeat;
  transition: background-size .24s ease, color .16s ease;
}
.news-item:hover .news-link{
  background-size: 100% 1px;  /* 横方向だけ伸ばす */
}


/* works：正方形パネル */
body.page-works .works-item {
  aspect-ratio: 1 / 1;           /* ★ 正方形固定 */
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform .18s ease, box-shadow .18s ease;
}

/* === works：画像と水色帯の間の白い隙間を完全に除去 === */
body.page-works .works-item img {
  display: block;      /* ★ インライン要素→ブロック化で行間ギャップを消す */
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: bottom; /* 保険として下揃え */
}

/* 採用ページの文字色トーン調整：黒→青みのある濃グレー */
body.page-recruit {
  --text-main: #1e293b;   /* 濃い青灰（見出しや強調に） */
  --text-sub:  #334155;   /* 本文などに */
}

body.page-recruit h1,
body.page-recruit h2,
body.page-recruit h3,
body.page-recruit .job-title {
  color: var(--text-main);
}

body.page-recruit p,
body.page-recruit li,
body.page-recruit .hero-message {
  color: var(--text-sub);
}

/* === 採用ページ：罫線ありデザインに統一 === */
body.page-recruit .job-card,
body.page-recruit .benefit,
body.page-recruit .data-card {
  border: 1px solid #c3cad4;   /* 統一線色：やや淡いブルーグレー */
  border-radius: 10px;
  background: #fff;
  box-shadow: none;             /* ベースはフラットに */
  transition: box-shadow .2s ease, transform .2s ease;
}

body.page-recruit .job-card:hover,
body.page-recruit .benefit:hover,
body.page-recruit .data-card:hover {
  box-shadow: 0 6px 14px rgba(0,0,0,0.06);
  transform: translateY(-2px);
}

/* === 採用ページ：社員メッセージにも罫線を追加して統一 === */
body.page-recruit .section-voice {
  border: 1px solid #d4dbe5;   /* 他カードと同じ色の線 */
  border-radius: 10px;
  background: #fff;
  padding: 24px;               /* 内側の余白を確保（既存より少し広め） */
  box-shadow: none;
  margin-top: 40px;            /* 上のセクションとの間にゆとり */
}

body.page-recruit .section {
  padding-bottom: 40px; /* 各セクション内の下余白 */
}

/* 共通：福利厚生・資格情報どちらにも */
body.page-recruit .benefit h3,
body.page-recruit .license dt {
  font-size: 1.1rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #0F2E86;
  padding-left:20px;
}

/* 福利厚生タイトル専用 */
body.page-recruit #welfare .benefit h3 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.5;
  color: #1E9cbb;
  padding-left:0;
}

/* 左の画像（形：丸または角丸） */
body.page-recruit .job-thumb img {
  width: 140px;
  height: 140px;
  object-fit: cover;
  border-radius: 50%;          /* 丸くする。四角に戻すなら0に */
}

/* 右側の職種情報 */
body.page-recruit .job-info {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* 「募集中」バッジ：大きめ押印スタイル */
body.page-recruit .job-card--compact .badge-new {
  position: absolute;
  top: -14px;                /* バナー上にもう少しせり出す */
  right: 18px;
  font-size: 1.25rem;        /* ★ 大きめフォント */
  font-weight: 400;          /* 細字 */
  letter-spacing: 0.06em;
  color: #d94b00;            /* 朱色寄りオレンジ */
  border: 2px solid #d94b00;
  border-radius: 8px;
  background: rgba(255, 245, 235, 0.92); /* 半透明の下地 */
  padding: 6px 14px;         /* ★ 面積を広げて押印感アップ */
  transform: rotate(-8deg);
  box-shadow: 0 3px 6px rgba(0,0,0,0.18);
  z-index: 2;
}

/* バッジがカードの上に乗るための位置基準 */
body.page-recruit .job-card--compact {
  position: relative;
}

/* 募集要項：バナー領域の左右余白を整理 */
body.page-recruit .job-card--compact {
  max-width: 620px;          /* ★ 余計な横幅を抑える */
  margin: 0 auto;
  padding: 16px 24px;
  position: relative;
  border: 1px solid #d4dbe5;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 3px 10px rgba(0,0,0,0.05);
  display: flex;
  align-items: center;
  gap: 24px;
}

/* 左のアイコンの左に約1cmの余白を付加 */
body.page-recruit .job-thumb {
  margin-left: 38px;          /* ★ 約1cm（37.8px） */
}

/* 職種名の右側に約2cmの余白 */
body.page-recruit .job-title {
  margin-right: 76px;         /* ★ 約2cm（75.6px） */
}

/* レイアウト調整：左右の間隔を保ちながらバランス良く */
body.page-recruit .job-info {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* カード自体をパネルっぽく（薄いグラ・枠・柔らかい影） */
body.page-recruit .job-card--compact{
  border: 1px solid #dfe6f1;
  background: linear-gradient(180deg,#ffffff 0%,#f8fbff 100%);
  box-shadow: 0 6px 18px rgba(9,30,66,.06), 0 1px 0 rgba(9,30,66,.04);
  border-radius: 12px;
}
/* パネルの面を少し立たせる・上面のハイライト */
body.page-recruit .job-card--compact::before{
  content:"";
  position:absolute; inset:0;
  border-radius: inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
  pointer-events:none;
}

@media (max-width: 768px){
  /* カードは1列で見やすく、余白を軽く */
  body.page-recruit .job-card--compact{
    flex: 1 1 100%;
    padding: 12px 14px;
    border-radius: 10px;
  }
  /* サムネは少し小さく */
  body.page-recruit .job-thumb img{
    width: 96px;
    height: 96px;
    border-radius: 50%;
  }
  /* 文字ブロックの詰めを最適化 */
  body.page-recruit .job-info{
    gap: 8px;
    flex: 1;
  }
  /* タイトルはやや控えめに */
  body.page-recruit .job-title{
    font-size: 1rem;
  }
  /* スタンプ位置をスマホ用に微調整（大きさは前回のまま） */
  body.page-recruit .job-card--compact .badge-new{
    top: -10px;
    right: 12px;
    padding: 4px 10px;
  }
  /* ご指定の左右スペースもスマホではほどよく短縮 */
  body.page-recruit .job-thumb{ margin-left: 16px; }
  body.page-recruit .job-title{ margin-right: 42px; }
}

/* パネル（募集要項/福利厚生/数字/VOICE）を白ベースに統一 */
body.page-recruit .job-card--compact,
body.page-recruit .benefit,
body.page-recruit .data-card,
body.page-recruit .section-voice{
  border: 1px solid #e6ebf2;
  background: #fff;
  box-shadow: 0 4px 12px rgba(9,30,66,.05);
  border-radius: 12px;
}

/* 上面のハイライトで面を整える（募集要項のみ軽く） */
body.page-recruit .job-card--compact::before{
  content:"";
  position:absolute; inset:0; border-radius:inherit;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
  pointer-events:none;
}

/* PCレイアウトのままでは .voice-mosaic が display:grid で上書きされない場合があるため */
@media (max-width: 768px) {
  body.page-recruit .section-voice .voice-mosaic {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 16px;
  }

  /* 各写真を小さく整列 */
  body.page-recruit .section-voice .voice-mosaic figure {
    margin: 0;
  }

  body.page-recruit .section-voice .voice-mosaic img {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    border-radius: 8px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  }

  /* テキスト・ボタンブロックの余白を縮小して画像とバランスを取る */
  body.page-recruit .section-voice .voice-box {
    padding: 10px 12px;
    margin-bottom: 12px;
  }

  /* さらに狭い端末は2列 */
  @media (max-width: 420px) {
    body.page-recruit .section-voice .voice-mosaic {
      grid-template-columns: repeat(2, 1fr);
    }
  }
}

/* ====== モバイルの募集要項カード修正 ====== */
@media (max-width: 768px){

  /* カードは1列・フル幅に、余白だけ軽く */
  body.page-recruit .job-card--compact{
    display:flex;
    align-items:center;
    gap:12px;
    flex:1 1 100%;
    padding:12px 14px;
    border-radius:10px;
  }

  /* 左のサムネを小さめに・左余白はゼロ（以前の1cm指定は解除） */
  body.page-recruit .job-thumb{ margin-left:0; }
  body.page-recruit .job-thumb img{
    width:88px; height:88px; border-radius:50%;
    object-fit:cover;
  }

  /* 右側のテキストブロックは伸縮可／改行で崩れないように */
  body.page-recruit .job-info{
    flex:1; min-width:0; gap:6px; flex-wrap:wrap;
  }

  /* 職種名のサイズ・行間・余白を調整（右2cm指定は解除） */
  body.page-recruit .job-title{
    font-size:1.05rem; line-height:1.35;
    margin:0;                /* ← 右マージンを無効化 */
    overflow-wrap:anywhere;  /* 長い語でもはみ出さない */
  }

  /* スタンプは小さめ・右上固定で干渉しない位置に */
  body.page-recruit .job-card--compact .badge-new{
    top:-8px; right:10px;
    font-size:1.1rem; padding:4px 8px;
    transform:rotate(-8deg);
    pointer-events:none;
  }
}

@media (max-width: 768px){

  /* 職業名を強調（サイズ・字間・行間調整） */
  body.page-recruit .job-title {
    font-size: 1.2rem;        /* ★ 文字サイズをやや拡大 */
    font-weight: 600;         /* やや太字に */
    letter-spacing: 0.03em;   /* 少しゆとりを持たせる */
    line-height: 1.4;
    color: #1e293b;           /* 落ち着いた濃紺で視認性アップ */
  }

  /* スタンプと干渉しないようわずかに下げる */
  body.page-recruit .job-info {
    align-items: flex-start;
  }

  /* 必要ならスタンプもほんの少し上へ */
  body.page-recruit .job-card--compact .badge-new {
    top: -10px;
  }
}


/* 採用ページ内だけ、カード系の共通ボーダー/影を太めに上書き */
body.page-recruit{
  --border: 2px solid #cfd8e6;         /* ★ 太さと色を上書き */
  --shadow-sm: 0 4px 12px rgba(9,30,66,.06);
}

/* 念のため、募集要項カードに明示適用（既存が var(--border) でない場合に備え） */
body.page-recruit #jobs .jobs a.job-card.job-card--compact{
  border: var(--border);
  box-shadow: var(--shadow-sm);
  border-radius: 12px;
}

/* モバイル時のヒーローサブ文言（.sub）調整 */
@media (max-width: 768px) {
  body.page-top .top-img .sub {
    white-space: nowrap;          /* 改行禁止 */
    font-size: clamp(14px, 3.6vw, 17px);  /* 画面幅に応じて縮小 */
    line-height: 1.4;             /* 行間をやや詰める */
    letter-spacing: 0.02em;       /* 読みやすい字間 */
    text-align: left;             /* 左揃え維持 */
  }
}

/* =============================
   hero-eyebrow（英字ラベル）
   ============================= */
.hero-eyebrow {
  display: block;
  font-family: "Playfair Display", "Noto Sans", "Yu Mincho", serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(14px, 2.4vw, 17px);
  color: rgba(255, 255, 255, 0.82);   /* 白すぎを抑え自然に */
  letter-spacing: 0.05em;
  margin: 0 0 0.15em 0;               /* 下余白を少し詰める（0.35em→0.15em） */
  line-height: 1.05;                  /* タイトルと一体感を出す */
  text-align: left;
}

/* hero-titleとの距離・階層感 */
.hero-title {
  line-height: 1.18;
  margin: 0;
  text-align: left;
}

/* 背景が明るめのページ用 */
.top-img--company .hero-eyebrow,
.top-img--recruit .hero-eyebrow {
  text-shadow: 0 1px 2px rgba(0,0,0,0.25);
}

/* モバイル最適化 */
@media (max-width: 768px) {
  .hero-eyebrow {
    font-size: clamp(13px, 3.5vw, 15px);
    margin-bottom: 0.2em;
  }
}

/* ===== Policy page tune-up ===================================== */

/* 本文幅を適度に絞る */
.page-policy .container{
  max-width: min(1040px, 92vw);
  padding: clamp(10px, 2vw, 20px);
  margin-inline: auto;
}

/* ヒーローキャプションを“読めるカード”に */
.page-policy .top-img .cap{
  position: absolute;
  left: 0;
  bottom: clamp(14px, 4vw, 26px);
  width: 100%;
  display: grid;
  place-items: start;
  padding: 0 16px;
}
.page-policy .top-img .cap .cap-bg{
  padding: 14px 18px;
  border-radius: 14px;
  background: rgba(15,23,42,.52);
  -webkit-backdrop-filter: blur(4px) saturate(140%);
  backdrop-filter: blur(4px) saturate(140%);
  color: #fff;
  box-shadow: 0 8px 26px rgba(2,6,23,.22);
  max-width: min(1040px, 92vw);
}

.page-policy .top-img .sub{
  font-size: clamp(13px, 2.4vw, 16px);
  opacity: .92;
}

/* アコーディオン（押しやすく読みやすく） */
.page-policy details{
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(2,6,23,.04);
}
.page-policy summary{
  cursor: pointer;
  padding: 16px 18px;
  font-weight: 500;
  font-size: 18px;
  list-style: none;
  position: relative;
}
.page-policy summary::-webkit-details-marker{ display:none; }
.page-policy summary::after{
  content: "＋";
  position: absolute;
  right: 16px;
  transition: transform .2s;
}
.page-policy details[open] summary::after{ content: "－"; }
.page-policy .content{
  padding: 0 18px 18px;
}
.page-policy .policy-item{
  margin: 14px 0 8px;
}
.page-policy .policy-item h3{
  margin: .6em 0 .2em;
  font-size: 18px;
  font-weight: 500;
  color: #0f172a;
}
.page-policy .policy-item p{
  line-height: 1.9;
  color: #334155;
  margin: 0;
}

/* 表（CIO/CISO）を読みやすく */
.page-policy .policy-table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 15px;
}
.page-policy .policy-table th,
.page-policy .policy-table td{
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
}
.page-policy .policy-table thead th{
  background: #f1f5f9;
  font-weight: 500;
}
.page-policy .policy-table tbody tr:nth-child(even){
  background: #fcfdff;
}

/* お問合せ窓口カード */
.page-policy .contact-box{
  margin: 18px 0;
  padding: 14px 16px;
  border: 2px solid #cfe3ff;
  border-radius: 12px;
  background: linear-gradient(180deg,#fff,#f8fbff 80%);
  box-shadow: 0 6px 18px rgba(2,6,23,.05) inset;
}
.page-policy .contact-box h2{
  margin: 0 0 8px;
  font-size: 18px;
}
.page-policy .contact-box p{
  margin: 0;
  line-height: 1.8;
  color: #0f172a;
}

/* モバイル最適化 */
@media (max-width: 768px){
  .page-policy summary{ font-size: 16px; padding: 14px 16px; }
  .page-policy .content{ padding: 0 14px 14px; }
  .page-policy .policy-item h3{ font-size: 17px; }
}

/* === モバイル専用：新着情報を縦並びに改行表示 ==================== */
@media (max-width: 768px) {
  .section--news .news-item {
    display: block;                /* 横並びを解除して縦積みに */
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
    background: #fff;
    margin-bottom: 8px;
  }

  .section--news .news-date,
  .section--news .news-tag {
    display: inline-block;
    vertical-align: middle;
    margin-right: 4px;
    font-size: 13px; /* ラベルや日付は少し小さめに */
  }

  .section--news .news-link {
    display: block;
    margin-top: 4px;
    line-height: 1.6;
    font-size: 14px; /* 本文（タイトル部分）を少し小さく */
    color: #1e293b;
  }

  /* 全体の余白を調整してコンパクトに */
  .section--news .news-list {
    padding: 0 10px;
    margin: 0;
  }
}

/* === トップページ専用：タイトル帯（eyebrow）の幅統一 ================== */
body.page-top .section-head .eyebrow {
  width: 80px;          /* 任意の統一幅（例：96px） */
  text-align: center;   /* 中央揃え */
  white-space: nowrap;  /* 折り返し防止 */
  padding:3px; 0px;
}

body.page-recruit .job-card--compact:hover .badge-new {
  animation: swingBadgeStrong 1s ease-in-out;
}

/* ゆらゆら＋わずかな上下動も追加して遊び感を強化 */
@keyframes swingBadgeStrong {
  0%   { transform: rotate(-8deg) translateY(0); }
  15%  { transform: rotate(-2deg) translateY(-2px); }
  35%  { transform: rotate(-12deg) translateY(1px); }
  55%  { transform: rotate(-4deg) translateY(-2px); }
  75%  { transform: rotate(-10deg) translateY(1px); }
  100% { transform: rotate(-8deg) translateY(0); }
}

/* === 募集要項：丸い画像（左側）をホバーでふわっと拡大＋光エフェクト === */
body.page-recruit .job-card--compact .job-thumb img {
  transition: transform 0.6s ease, box-shadow 0.6s ease;
  transform-origin: center center;
}

/* カード全体 hover で画像だけが反応 */
body.page-recruit .job-card--compact:hover .job-thumb img {
  transform: scale(1.08); /* ふわっと拡大 */
  box-shadow: 0 0 24px rgba(255, 215, 150, 0.55); /* 柔らかい光 */
}

/* ===== Contact page (ダミー表示) =========================== */
body.page-contact .contact-wrap{
  max-width: min(1040px, 92vw);
  margin-inline: auto;
  padding: clamp(12px, 2vw, 20px);
  box-sizing: border-box;
}

body.page-contact .contact-card{
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: clamp(12px, 2vw, 16px);
  box-shadow: 0 2px 8px rgba(2,6,23,.04);
}
body.page-contact .contact-card h2{
  margin: 0 0 6px;
  font-size: 18px;
  font-weight: 800;
  color: #0f172a;
}
body.page-contact .contact-lead{
  margin: 0 0 2px;
  font-size: 16px;
  font-weight: 700;
  color: #1f2937;
}
body.page-contact .contact-note{
  margin: 0;
  color: #475569;
  font-size: 14px;
  line-height: 1.7;
}

/* ダミーフォーム（送信無効の見た目） */
body.page-contact .contact-form-sample{
  margin-top: 8px;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: clamp(12px, 2vw, 18px);
  box-shadow: 0 2px 8px rgba(2,6,23,.04);
}
body.page-contact .contact-form-sample .sec-ttl{
  margin: 0 0 10px;
}
body.page-contact .contact-form-sample .form-row{
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 10px;
  align-items: start;
  margin: 10px 0;
}
@media (max-width: 640px){
  body.page-contact .contact-form-sample .form-row{
    grid-template-columns: 1fr;
  }
}
body.page-contact .contact-form-sample label{
  font-weight: 700;
  color: #0f172a;
  padding-top: 8px;
}
body.page-contact .contact-form-sample input,
body.page-contact .contact-form-sample select,
body.page-contact .contact-form-sample textarea{
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  background: #f9fafb;
  color: #334155;
}
body.page-contact .contact-form-sample input[disabled],
body.page-contact .contact-form-sample select[disabled],
body.page-contact .contact-form-sample textarea[disabled]{
  opacity: .7;
  cursor: not-allowed;
}
body.page-contact .contact-form-sample .form-actions{
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 10px;
}
body.page-contact .contact-form-sample button{
  border: 1px solid #2563eb;
  background: #eff6ff;
  color: #1e40af;
  padding: 10px 16px;
  border-radius: 9999px;
  font-weight: 700;
}
body.page-contact .contact-form-sample small{
  color: #64748b;
}

.about-info {
  display: grid;
  grid-template-columns: 8em 1fr;
}

.about-info dt {
  font-weight: 600;
  color: #333;
}

.about-info dd {
  margin: 0;
}

@media (max-width: 768px) {
  .about-info {
    grid-template-columns: 1fr;
  }
  .about-info dt {
    margin-top: 0.8em;
  }
}

/* ===== PC限定：ヒーロー見出しの「ハイライトスワイプ」 ===== */
@media (min-width: 769px){
  /* 既存のh1背景ラインは無効化（残像防止） */
  body.page-top .top-img .cap h1{
    position: relative;
    background: none;
    background-image: none;
    z-index: 0;
  }

  /* 見出しの背後に色帯が左→右へスッと伸びる */
  body.page-top .top-img .cap h1::before{
    content: "";
    position: absolute;
    left: -10px; right: -10px;
    bottom: -8px;                 /* 文字の少し下を走らせる */
    height: 14px;                 /* 帯の太さ（お好みで） */
    border-radius: 8px;
    background: linear-gradient(90deg, #3b82f6, #60a5fa);
    opacity: .92;
    transform-origin: left center;
    transform: scaleX(0);
    animation: hero-highlight 1.3s cubic-bezier(.2,.8,.2,1) calc(var(--cap-delay, 1s) + .10s) forwards;
    z-index: -1;                  /* 文字の“背面”で走る */
  }

  /* 文字自体もわずかにフェードアップ（確実に分かる程度） */
  body.page-top .top-img .cap h1{
    opacity: 0; transform: translateY(6px);
    animation: hero-title-in 1.10s ease-out calc(var(--cap-delay, 1s) + .05s) forwards;
    text-shadow: 0 2px 8px rgba(0,0,0,.55), 0 0 1px rgba(0,0,0,.8);
    color: #fff;
  }

  /* サブは控えめに後追い */
  body.page-top .top-img .cap .sub{
    opacity: 0; transform: translateY(4px);
    animation: hero-sub-in .90s ease-out calc(var(--cap-delay, 1s) + .35s) forwards;
  }

  @keyframes hero-highlight{
    from { transform: scaleX(0); }
    to   { transform: scaleX(1); }
  }
  @keyframes hero-title-in{
    from { opacity: 0; transform: translateY(6px); filter: blur(1px); }
    to   { opacity: 1; transform: translateY(0);   filter: blur(0); }
  }
  @keyframes hero-sub-in{
    from { opacity: 0; transform: translateY(4px); filter: blur(0.5px); }
    to   { opacity: 1; transform: translateY(0);   filter: blur(0); }
  }
}

/* motion配慮 */
@media (prefers-reduced-motion: reduce){
  body.page-top .top-img .cap h1::before,
  body.page-top .top-img .cap h1,
  body.page-top .top-img .cap .sub { animation: none !important; opacity: 1; transform: none; }
}

/* ===== PC限定：サブ文字＋波線を連動フェードイン ===== */
@media (min-width: 769px){
  body.page-top .top-img .cap .sub{
    position: relative;
    display: inline-block;
    margin-top: 10px;
    opacity: 0;
    transform: translateY(8px);
    animation: sub-fade-in 0.8s ease-out calc(var(--cap-delay,1s) + 1.3s) forwards;
  }

  /* 左から右へ波が文字幅いっぱいに伸びる */
  body.page-top .top-img .cap .sub::after{
    content: "";
    position: absolute;
    left: 0; bottom: -12px;
    width: 100%;
    height: 14px;
    background: url("data:image/svg+xml;utf8,\
      <svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 14' preserveAspectRatio='none'>\
        <path d='M0 7 \
                 Q10 0,20 7 T40 7 T60 7 T80 7 T100 7 \
                 T120 7 T140 7 T160 7 T180 7 T200 7 T220 7 T240 7' \
              fill='none' stroke='%2360a5fa' stroke-width='3' stroke-linecap='round'/>\
      </svg>") no-repeat left center;
    background-size: 100% 100%;
    transform-origin: left center;
    transform: scaleX(0);
    opacity: 0;
    animation: sub-wave-grow 1.8s ease-out calc(var(--cap-delay,1s) + 1.7s) forwards;
  }

  /* フェードアップ */
  @keyframes sub-fade-in{
    0% { opacity: 0; transform: translateY(8px); }
    100%{ opacity: 1; transform: translateY(0); }
  }

  /* 波線伸長 */
  @keyframes sub-wave-grow{
    0%   { transform: scaleX(0); opacity: 0; }
    30%  { opacity: 1; }
    100% { transform: scaleX(1); opacity: 1; }
  }
}

/* ===== 富士山パトロールCTA：上側ギザギザ白（HTML改修なし） ===== */
.page-works .fuji-cta .btn-link.btn-link--lg{
  position: relative;
  isolation: isolate;   /* 疑似要素の重なりを安定化 */
  overflow: hidden;
}

/* 上側に“雪”をギザギザで重ねる（テキストの上に出す） */
.page-works .fuji-cta .btn-link.btn-link--lg::after{
  content: "";
  position: absolute;
  left: 0; top: 0;
  width: 100%;
  height: 40%;                 /* 白の高さ（好みで 40〜70% に） */
  background: #fff;
  z-index: 1;                  /* テキストより上 */
  /* ギザギザの下辺（中央が少し高く見える山並み） */
  clip-path: polygon(
    0% 0%, 100% 0%,
    100% 72%, 95% 62%, 90% 72%, 85% 62%, 80% 72%, 75% 62%,
    70% 72%, 65% 62%, 60% 72%, 55% 62%, 50% 72%,
    45% 62%, 40% 72%, 35% 62%, 30% 72%, 25% 62%,
    20% 72%, 15% 62%, 10% 72%, 5% 62%, 0% 72%
  );
  transform: translateY(-100%);               /* 初期は上に隠す */
  transition: transform .45s ease;
  pointer-events: none;
}

/* ホバー/フォーカスで“雪”がスッと降りてくる */
.page-works .fuji-cta .btn-link.btn-link--lg:is(:hover, :focus-visible)::after{
  transform: translateY(0);
}

/* 白がかぶった時に文字を読める色へ */
.page-works .fuji-cta .btn-link.btn-link--lg:is(:hover, :focus-visible){
  color: #111;
}

/* ===== 経営理念：pill 3つを左右＋下から“ミックス”で収束 ===== */
body.company-about .ph-pills{ display:flex; gap:16px; justify-content:center; }

body.company-about .ph-pill{
  opacity: 0;
  transform: translateY(28px);
  transition: transform .6s ease, opacity .6s ease;
  will-change: transform, opacity;
}
/* 左右に散らし＋下げておく（中央は下げのみ） */
body.company-about .ph-pill:nth-child(1){ transform: translate(-64px, 28px); }
body.company-about .ph-pill:nth-child(2){ transform: translate(   0px, 28px); }
body.company-about .ph-pill:nth-child(3){ transform: translate( 64px, 28px); }

/* 収束（所定位置に戻す）＋段階的に */
body.company-about .ph-pills.in-view .ph-pill{
  opacity: 1;
  transform: translate(0,0);
}
body.company-about .ph-pills.in-view .ph-pill:nth-child(1){ transition-delay: .05s; }
body.company-about .ph-pills.in-view .ph-pill:nth-child(2){ transition-delay: .18s; }
body.company-about .ph-pills.in-view .ph-pill:nth-child(3){ transition-delay: .31s; }

/* ===== 社是：左右交互＋下からの“ミックス”で収束 ===== */
body.company-about .creed li{
  opacity: 0;
  transform: translateY(24px);
  transition: transform .6s ease, opacity .6s ease;
  will-change: transform, opacity;
}
/* 初期は左右に散らしておく */
body.company-about .creed li:nth-child(odd) { transform: translate(-56px, 24px); }
body.company-about .creed li:nth-child(even){ transform: translate( 56px, 24px); }

/* ビューポートに入ったら所定位置へ */
body.company-about .creed.in-view li{
  opacity: 1;
  transform: translate(0,0);
}
/* 段階的に（1→2→3） */
body.company-about .creed.in-view li:nth-child(1){ transition-delay: .05s; }
body.company-about .creed.in-view li:nth-child(2){ transition-delay: .18s; }
body.company-about .creed.in-view li:nth-child(3){ transition-delay: .31s; }

/* 配慮：モーションを減らす設定の環境 */
@media (prefers-reduced-motion: reduce){
  body.company-about .ph-pill,
  body.company-about .creed li{
    transition: none; transform:none; opacity:1;
  }
}

/* === 経営理念のメッセージ：右余白を少し詰め、枠線を太く、フェードin === */
body.company-about .ph-message{
  /* 右を気持ち詰める（左は読みやすさ維持） */
  padding: 16px 14px 16px 18px;   /* 既存 16px 18px → 右だけ -4px */

  /* 枠の存在感を上げる */
  border-width: 2px;              /* 既存 1px → 2px */
  border-color: #e5e7eb;          /* 既存色を踏襲 */

  /* フェードの初期状態 */
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .45s ease, transform .45s ease;
}

/* ビューポートに入ったら表示 */
body.company-about .ph-message.in-view{
  opacity: 1;
  transform: translateY(0);
}

/* 見出し帯（最終調整版） */
.sec-ttl {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 1.8rem;
}

.sec-ttl .bar {
  width: 4px;
  height: 2.6rem;               /* ← 少し短く（縦長感を軽減） */
  background-color: #2b6cb0;    /* ブランドカラー */
  border-radius: 999px;
  margin-top: 0.1rem;
}

.sec-ttl-label {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.sec-ttl .eyebrow {
  font-size: 0.85rem;           /* ← 少し小さく */
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #7d8a9a;               /* ← 少し淡いグレー寄り */
  margin-bottom: 0.2em;
}

.sec-ttl .sec-ttl-main {
  font-size: 1.45rem;
  font-weight: 650;
  color: #223;
}

/* 富士山パトロール 背景内タイトル */
.fuji-hero__title {
  position: absolute;
  top: 50px; /* 背景内の上からの位置 */
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-shadow: 0 3px 10px rgba(0,0,0,0.6);
}

/* タイトル位置を左上に変更 */
.fuji-hero__title {
  position: absolute;
  top: 20px;     /* 画像の上端からの距離 */
  left: 180px;    /* 左端からの距離 */
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-shadow: 0 3px 10px rgba(0,0,0,0.6);
}

.fuji-hero {
  min-height: 300px; /* 背景をやや縦に広げる */
}

/* 背景位置とボックス下げ */
.fuji-hero {
  min-height: 300px; /* ← 高さを少し広げる（320→360） */
  background-position: center 40%; /* ← 背景の見える範囲をやや下方向にシフト */
}

/* 白いボックスを下にずらす */
.fuji-hero__cap {
  margin-top: 5rem; /* ← 現在より下方向に余白を追加 */
}

@media (max-width: 767px) {
  .fuji-hero {
    min-height: 420px;
    background-position: center 35%;
  }

  .fuji-hero__title {
    top: 30px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    font-size: 1.8rem;      /* 少しだけ縮小して1行に収める */
    line-height: 1.2;
    white-space: nowrap;    /* ← 折り返し防止 */
    color: #fff;
    text-shadow: 0 3px 8px rgba(0, 0, 0, 0.6);
    letter-spacing: 0.03em;
  }

  .fuji-hero__cap {
    margin-top: 60px;       /* タイトルとの間に余白 */
    padding: 1.4rem 1rem 2rem;
    max-width: calc(100% - 32px);
  }

  .fuji-lead {
    font-size: 0.9rem;
    line-height: 1.8;
  }

  .fuji-cta .btn-fuji-zigzag {
    width: 100%;
    text-align: center;
    font-size: 0.95rem !important;  /* ← 優先度を上げて確実に反映 */

  }
}

/* 共通：タップ時の挙動改善（ダブルタップ防止） */
a,
button {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

/* ボタン風リンク類：テキスト選択防止＋ポインタ表示 */
.btn-link,
.btn-fuji-zigzag,
.header-logo a,
.header-nav a,
.gnav a {
  -webkit-user-select: none;
  user-select: none;
  cursor: pointer;
}

/* =========================================
   施工実績トップ：カテゴリーパネル統一
   （既存の .page-works .works-item を後ろから上書き）
========================================= */

/* グリッド列数を画面幅で素直に切り替え */
.page-works .works-grid {
  display: grid;
  gap: 18px;
  margin: 12px auto 32px;
  padding: 0 16px;
  justify-items: center;
}

@media (min-width: 1025px) {
  .page-works .works-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .page-works .works-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .page-works .works-grid {
    grid-template-columns: 1fr; /* スマホは常に1列＝全パネル同幅 */
  }
}

/* パネル本体：全カード同じ高さになるよう統一 */
.page-works .works-item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 260px;
  margin: 0 auto;
  padding: 18px 12px 44px; /* 上：アイコン / 下：キャプション分 */
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15,23,42,.06);
  overflow: hidden;
}

/* アイコンサイズを固定して高さを揃える */
.page-works .works-item > img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  display: block;
}

/* 下部キャプションも固定位置に */
.page-works .works-caption {
  position: absolute;
  left: 8px;
  right: 8px;
  bottom: 8px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  margin: 0;
  border-radius: 0 0 8px 8px;
}

/* 施工実績ページ：パネルブロックの上下余白を統一 */
.page-works .works-list {
  padding-top: 12px;
  padding-bottom: 12px;
}



/* =========================
   FINAL OVERRIDES（共通）
   ※このブロックが常に後勝ち
========================= */

/* タップ挙動と選択制御（共通） */
a, button { touch-action: manipulation; -webkit-tap-highlight-color: transparent; }
.btn-link, .btn-fuji-zigzag { -webkit-user-select: none; user-select: none; cursor: pointer; }

/* HERO：黒帯内の上下余白を共通化（WORKS / DETAIL / RECRUIT） */
body.page-works .top-img .cap-bg,
body.page-works-detail .top-img .cap-bg,
body.page-recruit .top-img .cap-bg {
  padding-top:  clamp(10px, 1.6vw, 14px);
  padding-bottom: clamp(18px, 2.5vw, 24px);
}

/* 施工実績トップ（一覧）：グリッドとパネル幅を統一 */
body.page-works .works-grid {
  display: grid; gap: 18px; margin: 12px auto 40px; padding: 0 16px; justify-items: center;
}
@media (min-width:1025px){ body.page-works .works-grid { grid-template-columns: repeat(6, minmax(0,1fr)); } }
@media (min-width:768px) and (max-width:1024px){ body.page-works .works-grid { grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media (max-width:767px){ body.page-works .works-grid { grid-template-columns: 1fr; } }

body.page-works .works-item {
  width: 100%; max-width: 220px; margin: 0 auto; padding: 16px 12px 44px;
  display: flex; flex-direction: column; align-items: center; justify-content: space-between; position: relative;
}
body.page-works .works-item > img { width: 80px; height: 80px; object-fit: contain; }
body.page-works .works-caption {
  position: absolute; left: 8px; right: 8px; bottom: 8px; height: 34px;
  display: flex; align-items: center; justify-content: center; padding: 0 10px; margin: 0; border-radius: 0 0 8px 8px;
}

/* 施工実績詳細：グリッド統一（PC/タブレット=2列、スマホ=1列） */
.page-works-detail .works-detail-grid{
  display: grid;
  gap: 24px;
  justify-items: center;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 24px auto 24px;      /* 任意：既存の見た目に合わせたい時は維持 */
  padding-block: 4px 10px;     /* 任意：不要なら削ってOK */
}

@media (max-width: 767px){
  .page-works-detail .works-detail-grid{
    grid-template-columns: 1fr;  /* スマホは必ず1列＝横幅が統一される */
    gap: 18px;
  }
}


/* 富士山パトロール：モバイル時はタイトルを中央固定 */
@media (max-width: 767px) {
  .fuji-hero { position: relative; } /* 念のため基準化 */

  .fuji-hero__title {
    top: 20px;
    left: 50%;                /* PC用の left:180px を上書き */
    transform: translateX(-50%);
    right: auto;              /* 念のためリセット */
    width: auto;              /* 影響排除 */
    text-align: center;
    font-size: 1.6rem;        /* 折り返し防止のため少し控えめ */
    line-height: 1.2;
    white-space: nowrap;      /* 1行で表示 */
    z-index: 2;               /* 白カードより上に出したい場合 */
  }

  /* タイトルと白カードが重ならないように少し下げる */
  .fuji-hero__cap {
    margin-top: 80px;
  }
}


/* ===============================
   施工実績 詳細ページ（共通修正）
   モバイル崩れ・幅ブレ解消（後勝ち）
================================ */

/* グリッド：モバイルは常に1列、768px以上は2列 */
body.page-works-detail .works-detail-grid{
  display: grid;
  grid-template-columns: 1fr;     /* ← スマホは必ず1列 */
  gap: 20px;
  justify-items: stretch;
  margin: 24px auto 40px;
  padding: 0 16px;
}
@media (min-width: 768px){
  body.page-works-detail .works-detail-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 各カードの実幅を統一（画像ははみ出さない） */
body.page-works-detail .work{ margin: 0; }
body.page-works-detail .work-figure{
  width: 100%;
  max-width: 520px;               /* 端末幅に馴染む実幅 */
  border-radius: 18px;
  overflow: hidden;               /* 角丸を画像にも適用 */
  background: #fff;
  box-shadow: 0 6px 18px rgba(15,23,42,.08);
  display: flex;
  flex-direction: column;
}

/* サムネイルは16:9固定・はみ出し防止 */
body.page-works-detail .work-thumb{
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #eef2f7;
}
body.page-works-detail .work-thumb img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* キャプション部も幅を揃えて中央寄せ */
body.page-works-detail .work-cap{
  padding: 14px 16px;
  text-align: center;
  background: #f4f7ff;
  width: 100%;
  line-height: 1.6;
}
body.page-works-detail .work-cap .title{ font-weight: 700; font-size: 1rem; margin-bottom: 4px; }
body.page-works-detail .work-cap .client{ font-size: .85rem; color: #64748b; }

/* 施工実績詳細ページだけリセット */
body.page-works-detail figure {
  margin: 0;
  padding: 0;
}

body.page-works-detail .work-figure{
  width: 100% !important;
  max-width: 100% !important;
}

/* お問合せフォーム準備中：ボタンを非アクティブ風に */
.page-contact .contact-form-sample button[disabled] {
  opacity: 0.35;
  cursor: not-allowed;
  background: #ccc;
  color: #777;
  border: 1px solid #bbb;
  box-shadow: none;
  transform: none;
}

.page-contact .contact-form-sample button[disabled]:hover {
  opacity: 0.35;
  background: #ccc;
}

.page-contact .contact-form-sample form {
  position: relative;
  opacity: 0.5;
  pointer-events: none;
}

.page-contact .contact-form-sample form::after {
  content: "準備中";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 1.8rem;
  font-weight: bold;
  color: #888;
  background: rgba(255, 255, 255, 0.6);
  padding: 0.5em 1em;
  border-radius: 6px;
}

/* お問合せページ：パネルを1:2に変更 */
.page-contact .contact-cards {
  display: grid;
  grid-template-columns: 1fr;  /* 左1：右2 の比率 */
  gap: 0.5rem;  /* パネル間余白 */
}

/* スマホでは縦並びに戻す */
@media (max-width: 768px) {
  .page-contact .contact-cards {
    grid-template-columns: 1fr; /* 一列表示 */
  }
}

/* ==========================================================
   CONTACT PAGE — PANEL DESIGN / A TYPE（白パネル・影・角丸）
========================================================== */

/* 全体レイアウト */
.contact-wrap {
    max-width: 900px;
    margin: 0 auto;
    padding: 40px 20px;
    font-size: 16px;
}

/* パネル全体（白・影） */
.panel {
    background: #ffffff;
    border-radius: 10px;
    padding: 24px 28px;
    margin-bottom: 28px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}

/* 説明文（読みやすく） */
.contact-lead {
    font-size: 17px;
    line-height: 1.8;
    color: #333;
}

/* 見出し */
.contact-block-title,
.contact-form-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 12px;
    color: #222;
}

/* 電話の強調 */
.contact-tel {
    font-size: 22px;
    font-weight: 700;
    color: #0066cc;
    margin-bottom: 4px;
}

/* 補足 */
.contact-note,
.contact-form-desc {
    font-size: 14px;
    color: #666;
    margin-top: 4px;
}

/* ボタン */
.form-btn {
    display: inline-block;
    padding: 14px 40px;
    background: #0066cc;
    color: #ffffff;
    font-size: 17px;
    font-weight: 700;
    border-radius: 8px;
    text-decoration: none;
    transition: background 0.25s;
}

.form-btn:hover {
    background: #0052a3;
}

.contact-form-link {
    margin-top: 20px;
    text-align: left;
}

/* ----------------------------------------------------------
   スマホ最適化
---------------------------------------------------------- */
@media (max-width: 768px) {

    .contact-wrap {
        padding: 20px 16px;
        font-size: 16px;
    }

    .panel {
        padding: 20px;
        margin-bottom: 20px;
    }

    .contact-block-title,
    .contact-form-title {
        font-size: 18px;
    }

    .contact-lead {
        font-size: 16px;
        line-height: 1.7;
    }

    .contact-tel {
        font-size: 20px;
    }

    .form-btn {
        width: 100%;
        padding: 16px 0;
        font-size: 18px;
        text-align: center;
    }

    .contact-form-link {
        text-align: center;
    }
}

/* ==========================================================
   CONTACT PAGE — PANEL DESIGN（余白統一）
========================================================== */

/* パネル本体の余白統一 */
.panel {
    background: #ffffff;
    border-radius: 10px;
    padding: 28px 32px;  /* 内側余白：上下左右すべて統一 */
    margin: 32px 0;      /* パネル間：上下 32px に統一 */
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}

/* テキストの段落余白も統一 */
.panel p {
    margin: 6px 0 0;  /* 各段落の上を少し詰めると美しい */
}

/* パネルの最初の要素（h3）は上に余白不要 */
.panel h3 {
    margin-top: 0;
    margin-bottom: 14px;
    font-size: 20px;
    font-weight: 700;
    color: #222;
}

/* パネルの最後の要素は下余白を削除 */
.panel > *:last-child {
    margin-bottom: 0 !important;
}

/* ボタンブロック */
.contact-form-link {
    margin-top: 20px;
}

/* ----------------------------------------------------------
   CONTACT — TITLE ACCENT (採用ページと同デザイン)
---------------------------------------------------------- */

/* h3 の装飾（パネルタイトル） */
.contact-block-title,
.contact-form-title {
    position: relative;
    padding-left: 18px;   /* バー分の余白 */
    font-size: 22px;
    font-weight: 700;
    color: #222;
}

/* 左アクセントバー */
.contact-block-title::before,
.contact-form-title::before {
    content: "";
    position: absolute;
    left: 0;
    top: 4px;
    width: 4px;
    height: 20px;
    background-color: #0066cc; /* 青アクセント */
    border-radius: 2px;
}

.page-contact .sub {
    font-size: 18px;
    line-height: 1.8;
}

/* お問い合わせページ：住所部分を読みやすく */
.page-contact .contact-block p {
    font-size: 17px !important;
    line-height: 1.8 !important;
    font-weight: 400 !important;
}

/* ▼募集要項：スマホ時にカードを縦並び＆幅100%に統一 */
@media (max-width: 768px) {
  body.page-recruit #jobs .jobs {
    display: block;
  }

  body.page-recruit #jobs a.job-card.job-card--compact {
    width: 100%;
    max-width: 100%;
    flex: none;

    /* ★上下の余白を追加して「くっつき問題」を解決 */
    margin-bottom: 20px;
  }
}

.panel {
  background: #fff;
  padding: 24px;
  margin-bottom: 24px;
  border-radius: 12px;

  /* 影をやめて境界線でくっきり見せる */
  box-shadow: none;
  border: 1px solid rgba(0, 0, 0, 0.12);
}
