.booth-header-img {
	position: relative;
}

.booth-header-img-title {
	position: absolute;
	top: 2.9rem;
	left: 50%;
	transform: translateX(-50%);
	color: #1052a5;
	font-size: 3.1rem;
	font-weight: bold;
	text-shadow:
    -2px -2px 0 #fff,
     0   -2px 0 #fff,
     2px -2px 0 #fff,
    -2px  0   0 #fff,
     2px  0   0 #fff,
    -2px  2px 0 #fff,
     0    2px 0 #fff,
     2px  2px 0 #fff,
     2px  3px 6px rgba(0, 0, 0, 0.45);
	   /* （Chrome/Safariで綺麗な縁取り） */
	   -webkit-text-stroke: 2px #fff;
	   paint-order: stroke fill;
	line-height: 1.25;
	white-space: nowrap;
	letter-spacing: .2rem;
}

.booth-header-img-subtitle {
	position: absolute;
	top: 7.3rem;
	left: 50%;
	transform: translateX(-50%);
	color: #000000;
	font-size: 2.25rem;
	font-weight: bold;
	line-height: 1.25;
	text-shadow:
    /* --- シロフチ（アウトライン） --- */
    -2px -2px 0 #fff,
     0   -2px 0 #fff,
     2px -2px 0 #fff,
    -2px  0   0 #fff,
     2px  0   0 #fff,
    -2px  2px 0 #fff,
     0    2px 0 #fff,
     2px  2px 0 #fff,
    /* --- 白ぼかし（内側：密度UP） --- */
     0    0   6px #fff,
     0    0   6px #fff,
    /* --- 白ぼかし（中距離：同半径3回） --- */
     0    0   20px rgba(255,255,255,1),
     0    0   20px rgba(255,255,255,1),
     0    0   20px rgba(255,255,255,1),
    /* --- 白ぼかし（遠距離） --- */
     0    0   40px rgba(255,255,255,0.95),
     0    0   60px rgba(255,255,255,0.9);
	white-space: nowrap;
	letter-spacing: .1rem;
}

.booth-header-img-description {
	position: absolute;
	bottom: 3rem;
	color: #000000;
	font-size: 1.25rem;
	line-height: 1.5;
	text-align: center;
	white-space: pre-line;
	font-weight: bold;
	width: 100%;
	letter-spacing: .1rem;
  
	text-shadow:
	  /* --- シロフチ（細め：±1px） --- */
	  -1px -1px 0 #fff,
	   0   -1px 0 #fff,
	   1px -1px 0 #fff,
	  -1px  0   0 #fff,
	   1px  0   0 #fff,
	  -1px  1px 0 #fff,
	   0    1px 0 #fff,
	   1px  1px 0 #fff,
  
	  /* --- 白ぼかし（近距離：密度UP、広がり抑え） --- */
	   0    0   4px rgba(255,255,255,1),
	   0    0   8px rgba(255,255,255,0.95),
	   0    0   12px rgba(255,255,255,0.85);
  }

.construction-booth-catch {
	display: block;
	text-align: center;
	font-size: 1.25rem;
	font-weight: bold;
	margin-bottom: .875rem;
	margin-top: 2.5rem;
	line-height: 1.25;
}

.construction-booth-risk-list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: .75rem;
}

.construction-booth-risk-list figure {
	display: flex;
	flex-direction: column;
	margin: 0;
}

.construction-booth-risk-list figure img {
	width: 100%;
	height: auto;
	max-width: 100%;
}

.construction-booth-risk-list figcaption {
	display: block;
	background-color: #30353B;
	color: #fff;
	text-align: center;
	font-weight: bold;
	font-size: 1.25rem;
	line-height: 2;
}

.construction-booth-risk-list p {
	margin-bottom: 0;
	padding: .5rem;
	font-size: .875rem;
}

.connavi-sub-ttl {
	font-size: 26px;
	padding: .5rem .875rem;
    line-height: 1.25;
}

.connavi-sub-ttl + h3 {
	margin-top: .75rem !important;
}

.construction-booth-column {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1rem;
}

.construction-booth-column div > p:not(:last-child) {
	margin-bottom: 1.5rem;
}

.construction-booth-column div strong {
	font-size: 1.25rem;
	font-weight: bold;
	display: block;
	margin-bottom: .5rem;
	line-height: 1.25;
}


@media (max-width: 768px) {
	.construction-booth-catch {
		font-size: 1rem;
	}

	.booth-header-img-title {
		font-size: 1.375rem;
		top: 1.25rem;
		text-shadow:
		1px 1px 0 #fff,
		-1px 1px 0 #fff,
		1px -1px 0 #fff,
		-1px -1px 0 #fff,
		2px 2px 4px rgba(0, 0, 0, 0.6);
	}

	.booth-header-img-subtitle {
		font-size: 1.125rem;
		top: 3.25rem;
		text-shadow:
		1px 1px 0 #fff,
		-1px 1px 0 #fff,
		1px -1px 0 #fff,
		-1px -1px 0 #fff,
		2px 2px 4px rgba(0, 0, 0, 0.6);
	}

	.booth-header-img-description {
		font-size: .5rem;
		bottom: 1rem;
		line-height: 1.25;
		text-shadow:
		1px 1px 0 #fff,
		-1px 1px 0 #fff,
		1px -1px 0 #fff,
		-1px -1px 0 #fff,
		2px 2px 3px rgba(0, 0, 0, 0.3);
	}

	.construction-booth-risk-list {
		grid-template-columns: repeat(2, 1fr);
	}

	.construction-booth-risk-list figcaption {
		font-size: 1rem;
	}

	.connavi-sub-ttl {
		font-size: 1.25rem;
	}

	.construction-booth-column {
		grid-template-columns: 1fr;
	}

	.construction-booth-column-features {
		grid-template-columns: 1fr;
	}

	.construction-booth-column-features span {
		padding: .875rem .5rem;
		font-size: 1rem;
	}

	.construction-booth-column-features img {
		width: 100%;
	}
}
