@charset "utf-8";
.company-spec dd img {
	width: 200px !important;
	height: auto;
	margin: 0 0 1em;
	display: block;
}
@media print, screen and (min-width:768px) {
	.introduction .flame_orange_3 {
		width: 100%;
		display: flex;
		flex-wrap: wrap;
		margin: 0;
		padding: 0;
		gap: 0;
	}
	.introduction .flame_orange_3>ul {
		max-width: 960px;
		width: 100%;
	}
	.introduction .flame_orange_3>li {
		width: calc(100%/3 - 2em);
		max-width: calc(100%/3 - 2em);
		margin: 1em;
		padding: 1em 1em 4em;
		box-sizing: border-box;
		border: 1px solid #ccc;
		border-radius: 10px;
		text-align: left;
		position: relative;
		line-height: 1.6;
	}
	.introduction .flame_orange_3>li>a {
		margin: 0;
		padding: 1em;
		display: block;
		font-size: 12px;
	}
	.introduction .flame_orange_3>li:hover {
		background: #eee;
	}
	.introduction .flame_orange_3>li>a>h3 {
		margin: 0;
		padding: 0;
		font-size: 20px;
		text-align: left;
	}
	.introduction .flame_orange_3>li>a>p:not(.btn_cv) {
		margin: 0 auto;
		padding: 10px 0;
		line-height: 1.6;
		font-size: 16px;
	}
	.introduction .flame_orange_3 li img.img100 {
		margin: 0 0 1em;
		padding: 0;
		width: 100% !important;
		max-width: 500px;
		height: 150px !important;
		object-fit: cover;
	}
	.introduction li.empty {
		border: none;
	}
	.state {
		margin: 5px 5px 0 0;
		background: #ccc;
		padding: 0 .5em;
		font-size: 12px;
		display: block;
		float: left;
	}
	.enter {
		display: block;
		clear: both;
		text-align: center;
		margin: 0;
		padding: 0;
	}
	a.disabled {
		pointer-events: auto;
	}
	a.disabled .state {
		pointer-events: auto;
		cursor: pointer;
	}
	.clear {
		display: block !important;
		clear: both !important;
		content: "" !important;
	}
	.btn_achievement {
		display: block;
		text-align: center;
		vertical-align: middle;
		text-decoration: none;
		width: 50%;
		margin: 1em auto 0;
		padding: 1em 0 0;
		font-size: 16px !important;
		color: #19192b;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 1em;
	}
	.btn_achievement::after {
		position: absolute;
		top: 50%;
		right: 1.3em;
		width: .4em;
		height: .4em;
		transform: translateY(-50%) rotate(45deg);
		border-right: 3px solid #19192b;
		border-top: 3px solid #19192b;
		content: "";
		z-index: 2;
	}
	#caseFilterMenu fieldset {
		border: 1px solid #ddd;
		padding: 10px;
		margin: 0 0 12px;
	}
	#caseFilterMenu label {
		margin-right: 12px;
		display: inline-flex;
		gap: 6px;
		align-items: center;
	}
	#caseFilterClear {
		display: block;
		margin: 1em;
		padding: 5px;
		border: 1px solid #333;
		background: #fff;
		color: #333;
		border-radius: 6px;
		font-size: 14px;
		line-height: 1;
		cursor: pointer;
	}
	#caseFilterClear:hover {
		background: #f5f5f5;
	}
	#caseFilterClear:active {
		transform: translateY(1px);
	}
	.achievement_main {
		width: 100%;
		max-width: 960px;
		margin: auto;
		padding: 0;
		text-align: left;
	}
	.achievement_main h3,
	.achievement_main h4 {
		text-align: left;
		padding: 0;
		margin: 1em 0;
	}
	.achievement_main h3 {
		font-size: 30px;
		display: inline-block;
		vertical-align: middle;
	}
	.achievement_main img {
		width: 60px;
		height: auto;
		padding-right: .5em;
		display: inline-block;
		vertical-align: middle;
	}
	.achievement_main h4 {
		font-size: 20px;
	}
	.achievement_main h3+p {
		margin-top: 1em;
	}
	.achievement_main ul,
	.achievement_main dl {
		margin: 0;
	}
	.achievement_main ul {
		background: #eee;
		border-radius: 10px;
		padding: 1em;
		list-style: none;
	}
	.achievement_main ul li {
		position: relative;
		padding-left: 1.2em;
		line-height: 1.8;
	}
	.achievement_main ul li::before {
		content: '';
		position: absolute;
		left: 0;
		top: .55em;
		width: .6em;
		height: .6em;
		background: #ff8c00;
		border-radius: 50%;
	}
	.company-spec {
		display: grid;
		grid-template-columns: 120px 1fr;
		row-gap: .6em;
		column-gap: 1.2em;
		margin: 1.5em 0;
		padding: 1em 1.2em;
		background: #eee;
		border-radius: 10px;
		font-size: .95rem;
	}
	.company-spec dt {
		font-weight: 600;
		text-align: left;
	}
	.company-spec dd {
		margin: 0;
	}
	.company-comment {
		padding: 1em 1.2em;
		background: #eee;
		border-radius: 10px;
	}
	.achievement_menu ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
		list-style: none;
		margin: 0;
		padding: 0;
	}
	.achievement_menu li {
		display: flex;
		align-items: center;
	}
	.achievement_menu li:not(:last-child)::after {
		content: "／";
		margin-left: 1em;
	}
	.achievement_menu li a {
		display: block;
		padding: .5em 0 .5em 1em;
		font-size: 12px;
		color: #005387;
		text-decoration: none;
		border-radius: 10px;
		transition: .2s;
	}
	.achievement_menu li a::after {
		content: "\25BC";
		font-size: .7em;
		margin-left: .4em;
		color: #005387;
	}
	.achievement_menu li a:hover {
		color: #aaa;
	}
	.achievement_point ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
		list-style: none;
		margin: 0;
		padding: 0;
	}
	.achievement_point li {
		display: flex;
		align-items: center;
		padding: 0 .5em;
		margin: 0;
		background: #005387;
		border-radius: 10px;
		font-size: 12px;
		color: #fff;
	}
	.achievement_wrap {
		background: #eee;
		padding: 1em 2em;
		margin: 2em 0;
		border-radius: 10px;
		line-height: 1.8;
	}
	.achievement_wrap p {
		line-height: 1.6;
	}
}
/* SP */
@media only screen and (max-width:767px) {
	.introduction .flame_orange_3>li {
		width: 100%;
		margin: 1em 0;
		padding: 1em 1em 4em;
		box-sizing: border-box;
		border: 1px solid #ccc;
		border-radius: 10px;
		text-align: left;
		position: relative;
		line-height: 1.6;
	}
	.btn_achievement {
		display: block;
		text-align: center;
		vertical-align: middle;
		text-decoration: none;
		width: 50%;
		margin: 1em auto 0;
		padding: 1em 0 0;
		font-size: 16px !important;
		color: #19192b;
		position: absolute;
		left: 0;
		right: 0;
		bottom: 1em;
	}
	.btn_achievement::after {
		position: absolute;
		top: 74%;
		right: 1.3em;
		width: .4em;
		height: .4em;
		transform: translateY(-50%) rotate(45deg);
		border-right: 3px solid #19192b;
		border-top: 3px solid #19192b;
		content: "";
		z-index: 2;
	}
	.achievement_main {
		width: 100%;
		max-width: 960px;
		margin: auto;
		padding: 0;
		text-align: center;
	}
	.achievement_main h3,
	.achievement_main h4 {
		text-align: left;
		padding: 0;
		margin: 0;
	}
	.achievement_main h3 {
		font-size: 20px;
	}
	.achievement_main img {
		width: 60px;
		height: auto;
		margin: auto;
		padding-right: .5em;
	}
	.achievement_main h4 {
		font-size: 20px;
	}
	.achievement_main h3+p {
		margin-top: 1em;
	}
	.achievement_main ul,
	.achievement_main dl {
		margin: 0;
	}
	.achievement_main ul {
		background: #eee;
		border-radius: 10px;
		padding: 1em;
		list-style: none;
	}
	.achievement_main ul li {
		position: relative;
		padding-left: 1.2em;
		line-height: 1.2;
		text-align: left;
		margin-bottom: 1em;
	}
	.achievement_main ul li::before {
		content: '';
		position: absolute;
		left: 0;
		top: .55em;
		width: .6em;
		height: .6em;
		background: #ff8c00;
		border-radius: 50%;
	}
	.company-spec {
		margin: .5em 0;
		padding: 1em 1.2em;
		background: #eee;
		border-radius: 10px;
		text-align: left;
	}
	.company-spec dt {
		font-weight: 600;
		text-align: left;
	}
	.company-spec dd {
		margin: 0 0 2em;
	}
	.company-comment {
		padding: 1em 1.2em;
		background: #eee;
		border-radius: 10px;
	}
	.achievement_menu ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
		list-style: none;
		margin: 1em 0 0;
		padding: 0;
	}
	.achievement_menu li {
		display: flex;
		align-items: center;
	}
	.achievement_menu li:not(:last-child)::after {
		content: "／";
		margin-left: 1em;
	}
	.achievement_menu li a {
		display: block;
		padding: 0 0 0 1em;
		font-size: 12px;
		color: #005387;
		text-decoration: none;
		border-radius: 10px;
		transition: .2s;
	}
	.achievement_menu li a::after {
		content: "\25BC";
		font-size: .7em;
		margin-left: .4em;
		color: #005387;
	}
	.achievement_menu li a:hover {
		color: #aaa;
	}
	.achievement_point ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		gap: 8px;
		list-style: none;
		margin: 0;
		padding: 0;
	}
	.achievement_point li {
		display: flex;
		align-items: center;
		padding: 0 .5em;
		margin: 0;
		background: #005387;
		border-radius: 10px;
		font-size: 12px;
		color: #fff;
		text-align: left;
	}
	.achievement_wrap {
		background: #eee;
		padding: 1em 2em;
		margin: 2em 0;
		border-radius: 10px;
		line-height: 1.8;
	}
	.achievement_wrap p {
		line-height: 1.6;
		text-align: left;
		margin-bottom: 1em;
	}
}

.case-spec {
	border: 1px solid #005bac;
	color: #005bac;
	border-radius: 10px;
	padding: 0 1em;
	margin: 0 1em 0 0;
}
.case-section {
	padding: 32px 16px;
}
.case-section h2 {
	font-size: 1.5rem;
	margin-bottom: 20px;
}
.case-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.case-grid-list {
	display: flex;
	flex-wrap: nowrap;
	gap: 16px;
	overflow-x: auto;
	overflow-y: hidden;
	padding-bottom: 8px;
}
.case-grid-list .case-card {
	width: 350px;
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
}
.case-grid-list .case-card > a:first-child {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
}
.case-grid-list .case-card .btn_cv {
	margin:1em auto 0;
}
.case-grid-list .achievement_point{
	margin-top: 1em;
}

.case-card {
	background: #fff;
	border: 1px solid #d7dde5;
	border-radius: 4px;
	padding: 14px 16px;
	transition: box-shadow .2s ease, transform .2s ease;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.case-card a.btn_cv {
	margin-top: auto;
}
.case-card:hover {
	box-shadow: 0 2px 8px rgba(0, 0, 0, .06);
	transform: translateY(-1px);
}
.case-title {
	font-size: 1rem;
	margin-bottom: 10px;
	font-weight: 600;
	color: #222;
	text-align: left;
	border-bottom: 1px solid #aaa;
	padding-bottom: 0.5em;
}
.case-card dl {
	margin: 0;
}
.case-card dt {
	font-size: 16px;
	color: #666;
	font-weight: 600;
}
p.case-p {
	font-size: 16px;
	margin-top: 2em;
	color: #666;
	font-weight: 600;
}
img.case-p {
	max-width: 400px;
	width: 100%;
	height: auto;
	margin: auto;
}
.case-card dd {
    margin: 0 0 6px;
    font-size: .85rem;
    padding: 1em;
    background: #eee;
    border-radius: 10px;
    /* display: flex; ←これを消す */
    /* align-items: flex-start; ←これも不要なら消す */
    gap: 16px;
}
.case-card dd p + p{
	margin-bottom: 1em;
}
.case-card dd p + p:last-child{
	margin-bottom: 0em;
}
.case-card dd img {
	max-width: 150px;
	height: auto;
}
@media (max-width:1024px) {
	.case-grid,.case-grid-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}
@media (max-width:640px) {
	.case-grid,.case-grid-list {
		grid-template-columns: 1fr;
	}
}
.inner800 {
	max-width: 800px;
	margin: auto;
}
.img100par {
	width: 100% !important;
	height: auto;
}
.fontx2 h2 {
	font-size: 40px !important;
}
.fontx2 h3 {
	font-size: 30px !important;
}
.fontx2 dt {
	margin-top: 2em;
}
.fontx2 dt,
.fontx2 dd {
	font-size: 16px !important;
}