@charset "UTF-8";

@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP|Roboto:500');

@media screen and (min-width: 760px) {
	
	/* .anchor-link
------------------------------------------------------------------- */
	.anchor-link ul li::before {
		margin-right: 0.25em;
		content: "▼";
		color: #83cc0e;
	}
	
	.anchor-link .section-sub-title-section {
		text-align: center;
		margin-left: 0;
		margin-right: 0;
	}
	
	.anchor-link ul {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
		margin-bottom: 30px;
	}
	
	.anchor-link ul li {
		margin-right: 2em;
	}
	
	.anchor-link-top {
		text-align: right;
	}
	
	.anchor-link-top::before {
		margin-right: 0.25em;
		content: "▲";
		color: #83cc0e;
	}
	
	
	/* .business-usual
------------------------------------------------------------------- */
	.business-usual {
		margin-bottom: 13px;
		position: relative;
	}

	.business-usual dt {
		width: 101px;
		height: 24px;
		text-indent: -9999px;
		background: url(../img/common/icon-business.png) no-repeat;
		position: absolute;
		top: 4px;
		left: 0;
	}

	.business-usual dd {
		padding-left: 117px;
		font-size: 17px;
		font-weight: bold;
		line-height: 2;
		letter-spacing: 1.5px;
	}

	/* .list-dot
------------------------------------------------------------------- */
	.list-dot {
		padding-left: 1em;
	}

	.list-dot li {
		padding-left: 26px;
		margin-bottom: 14px;
		line-height: 2.2;
		position: relative;
	}

	.list-dot li:before {
		content: "";
		display: block;
		width: 10px;
		height: 10px;
		background: #88d60e;
		position: absolute;
		top: 10px;
		left: 2px;
	}

	.content {
		text-align: left;
	}

	/*category-header
------------------------------------------------------------------- */
	.category-header h1 .category-title--inner {
		align-items: center;
		color: #fff !important;
		display: flex;
		font-size: 26px;
		height: 80px;
		justify-content: space-between;
		letter-spacing: 0.275em;
		padding: 0 8px;
		overflow: hidden;
		width: 100%;
		max-width: 960px;
	}
	
	.category-nav {
		font-size: 12.5px;
		margin-bottom: 0;
	}

	.category-nav li {
		height: 13px;
	}

	.category-nav li a:hover {
		color: #83cc0e !important;
	}

	.category-nav li.is-active a {
		color: #83cc0e !important;
	}

	.category-nav li.is-active:after {
		z-index: 1;
	}

	.category-nav.category-nav_special {
		height: 50px;
		justify-content: flex-end;
		margin-bottom: 25px;
	}

	.category-nav.category-nav_special a {
		background: #6fad0c;
		border-radius: 2px;
		color: #fff !important;
		font-size: 13px;
		letter-spacing: .25em;
		line-height: 1.2;
		padding: 4px 10px 4px 18px;
	}

	.category-nav.category-nav_special a:hover {
		background: #83cc0e;
	}

	@media screen and (max-width: 820px) {

		.category-nav li {
			font-size: 12px;
		}

	}

	/* section-title
------------------------------------------------------------------- */
	.article-title {
		background: url(../img/common/bg_dot.gif);
		border-radius: 16px;
		margin-left: auto;
		margin-right: auto;
		background-repeat: repeat;
		width: 100%;
		max-width: 960px;
	}

	.section-title {
		max-width: 960px;
		margin: 0 auto 36px;
		padding: 0 20px 9px 20px;
		font-weight: bold;
		font-size: 20px;
		line-height: 30px;
		background: url(../img/common/section-title_bg.gif) no-repeat left bottom;
	}

	.section-title small {
		font-size: 14px;
		line-height: 21px;
		vertical-align: middle;
	}

	.float-img-left {
		float: left;
		padding-top: 9px;
		margin-right: 50px;
	}

	.float-img-right {
		float: right;
		padding-top: 9px;
		margin-left: 50px;
	}

	/* ==========================================================================
		engineer
============================================================================= */

	.category-top-title {
		letter-spacing: .375em;
		border-color: #83cc0e;
	}

	.category-top-title .sub-title {
		color: #83cc0e;
		font-size: 12.5px;
		letter-spacing: .225em;
	}

	.category-title .sub-title {
		color: #fff;
		font-size: 12.5px;
		letter-spacing: .225em;
	}

	.category-title--engineer {
		background-image: url(../img/common/bg_dot.gif);
	}

	.content-title--engineer {
		border-color: #83cc0e;
	}

	.content-title--engineer .sub-title {
		background: #83cc0e;
	}

	.content-title--engineer .sub-title::after {
		border-top: 10px solid #83cc0e;
	}

	.content-title--engineer .content-intro {
		border-color: #83cc0e;
	}
	
	#container .content-article .text-link,
	#container .content-article .text-link:visited,
	#container .content-article .text-link:active {
		text-decoration: underline;
	}
	
	.anchor-height {
		margin-top: -108px;
		padding-top: 108px;
	}

	/* .content-diagram
------------------------------------------------------------------- */
	.content-diagram-wrap {
		max-width: 960px;
		margin: 0 auto 34px;
	}
	.content-diagram {
		border-bottom: 6px solid #83cc0e;
	}
	.content-diagram img {
		margin-left: auto;
		margin-right: auto;
	}
	
	/* .keyword-engineer
------------------------------------------------------------------- */

	.keyword-engineer {
		background: #f2fae6;
		border-radius: 10px;
		padding: 30px 0 34px;
	}
	
	.keyword-engineer {
		margin-bottom: 20px;
		margin-top: 0;
	}
	
	.keyword-engineer .keyword_list {
		gap: 15px;
		width: 845px;
	}
	
	#container .keyword-engineer .section-title-keyword {
		color: #6fad0c;
		margin: 0 auto 26px;
		padding: 0;
		border-bottom: none;
		width: 845px;
		font-size: 20px;
		line-height: 30px;
	}
	
	.keyword-engineer .keyword_list li a {
		width: 200px;
		height: 200px;
	}
	
	@media screen and (max-width: 979px) {
		
		.keyword-engineer {
			padding: 20px 0;
		}
		
		#container .keyword-engineer .section-title-keyword {
			width: 100%;
			margin-bottom: 16px;
			padding: 0 20px;
		}
		
		.keyword_list {
			padding: 0 20px;
		}
		
		.keyword-engineer .keyword_list {
			width: 100%;
		}
		
		.keyword-engineer .keyword_list li a {
			width: 20vw;
			height: 20vw;
		}
		
	}

	

	/* ==========================================================================
		Top
============================================================================= */

	.top-scroll_btn {
		display: none;
		position: fixed;
		left: 50%;
		margin-left: -44px;
		width: 88px;
		height: 88px;
		z-index: 100;
	}

	.top-scroll_btn a {
		display: block;
		width: 88px;
		height: 88px;
		cursor: pointer;
		text-indent: -9999px;
		background-image: url(../img/top/btn_scroll.png);
		overflow: hidden;
	}

	.top-scroll_btn a:hover {
		background-position: -88px 0;
	}

	#top-lead {
		max-width: 960px;
		margin: 24px auto 44px;
		padding: 0 130px 322px;
		background: url(../img/top/lead-image.jpg) no-repeat center bottom;
	}

	#top-work {
		background-image: url(../img/common/bg_dot.gif);
	}

	#top-work {
		padding: 70px 8px 85px;
		background-image: url(../img/common/bg_dot.gif);
	}

	#top-work .top-sec-title {
		color: #fff;
		font-size: 28px;
		font-weight: bold;
		line-height: 1.2;
		letter-spacing: .35em;
		margin: 0 auto 24px;
		text-align: center;
	}

	#top-work .top-sec-summary {
		color: #fff;
		font-size: 18px;
		margin: 0 auto 65px;
		width: 500px;
		height: 62px;
	}

	#top-work .content-wrap {
		width: 100%;
		max-width: 1096px;
		margin: 0 auto;
	}
	
	#top-work .content-wrap .flexbox {
		display: flex;
		gap: 8px;
	}

	#top-work .content-wrap .block-soft,
	#top-work .content-wrap .block-net,
	#top-work .content-wrap .block-hard {
		background: #fff;
		width: 32.85%;
	}

	#top-work .content-wrap .block-soft,
	#top-work .content-wrap .block-net,
	#top-work .content-wrap .block-hard {
		margin-bottom: 8px;
	}

	#top-work .content-wrap .block-soft {

		border-radius: 20px 20px 0 0;
	}

	.content-wrap .block-hard {
		/*float: right;
		width: 49.475%;*/
		border-radius: 0 20px 0 0;
	}

	.content-wrap .block-ip {
		border-radius: 0 0 20px 20px;
	}

	#top-work .block-soft h3,
	#top-work .block-net h3,
	#top-work .block-hard h3,
	#top-work .block-ip a {
		background: #f2fae6;
		overflow: hidden;
	}

	#top-work .block-soft h3,
	#top-work .block-net h3,
	#top-work .block-hard h3 {
		align-items: center;
		color: #83cc0e;
		display: flex;
		font-size: 22px;
		height: 75px;
		padding-left: 49px;
	}

	#top-work .block-soft h3 {
		border-radius: 20px 0px 0 0;
	}

	#top-work .block-hard h3 {
		border-radius: 0 20px 0 0;
	}

	#top-work .block-soft h3 p,
	#top-work .block-net h3 p,
	#top-work .block-hard h3 p {
		letter-spacing: .25em;
		margin-bottom: -4px;
	}

	#top-work .block-soft h3 p span,
	#top-work .block-net h3 p span,
	#top-work .block-hard h3 p span {
		letter-spacing: .1em;
	}

	/* soft */
	#top-work .block-menu-inner {
		padding: 35px 50px;
		position: relative;
	}

	#top-work .wi-list li {
		align-items: center;
		display: flex;
		font-weight: bold;
		letter-spacing: .1em;
		min-width: 19.25vw;
		width: 45%;
		margin-left: 30px;
		gap: 15px;
	}

	#top-work .wi-list li:not(:last-child) {
		margin-bottom: 8px;
	}

	#top-work .wi-list li a {
		align-items: center;
		display: flex;
		flex-shrink: 0;
		position: relative;
	}

	#top-work .wi-list li a:before {
		position: absolute;
		display: block;
		content: '';
		width: 18px;
		height: 18px;
		left: -30px;
		top: 0;
		bottom: 0;
		margin: auto 0;
		background: url(../../common/img/arrow_gray.svg);
	}

	#top-work .wi-list li a:hover {
		color: #83cc0e;
	}

	/* hard */
	#top-work .block-hard .wi-list {
		text-align: left;
	}

	/* ip */
	#top-work .block-ip {
		border-radius: 0 0 20px 20px;
		padding: 35px 50px 25px;
		background: #f2fae6;
		position: relative;
	}
	#top-work .block-ip ul {
		display: flex;
		gap: 40px;
		justify-content: center;
	}
	#top-work .block-ip ul li {
		margin-left: 30px;
		/*width: 45%;*/
	}
	#top-work .block-ip ul li:not(:last-child) {
		margin-bottom: 10px;
	}
	#top-work .block-ip a h3 {
		color: #83cc0e;
		display: inline-block;
		font-size: 22px;
		letter-spacing: .25em;
		position: relative;
	}
	#top-work .block-ip a h3:before {
		background: url(../../common/img/arrow_white.svg);
		display: block;
		content: '';
		width: 18px;
		height: 18px;
		left: -20px;
		top: 50%;
		margin: auto 0;
		position: absolute;
		transform: translate(-50%, -50%);
	}
	#top-work .block-ip a:hover h3 {
		color: #67a505;
	}

	#top-work .block-ip a h3 img {
		margin-right: 12px;
		width: 26px;
	}
	#top-work  .block-ip-note {
		display: inline-block;
		position: absolute;
		font-size: 12px;
		right: 15px;
		bottom: 10px;
	}
	
	/*top-diagram*/
	#top-diagram {
		text-align: center;
		padding: 95px 0;
	}
	
	.top-diagram-title {
		font-size: 28px;
		font-weight: bold;
		line-height: 1.2;
		letter-spacing: .35em;
		margin: 0 auto 24px;
	}
	
	.top-diagram-lead {
		max-width: 960px;
		margin: 24px auto 24px;
		padding: 0 130px 0;
		text-align: left;
	}
	
	/*top-interview*/
	#top-interview {
		padding: 95px 0;
		background: #f2f2f2;
	}
	
	#top-interview .interview-banner {
		margin: 0 auto;
		max-width: 610px;
		color: #fff;
		font: "YakuHanJPs","Roboto","Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3",Arial,"nc3Jp",sans-serif !important;
	}
	
	#top-interview .interview-banner h3 {
		font-size: 32px;
		font-weight: normal;
		letter-spacing: 0.2em;
	}
	
	#top-interview .interview-banner-text {
		margin-top: 18px;
		line-height: 1.6;
	}
	
	#top-interview .interview-banner a {
		padding: 30px 40px;
		color: #fff;
		display: block;
		background: #e60012;
		border-radius: 16px;
	}
	
	#top-interview .interview-banner a:hover {
		opacity: 0.75;
	}
	
	#top-interview .interview-banner span {
		font-size: 16px;
		display: block;
		font-weight: bold;
		letter-spacing: 0.25em;
	}
	#top-interview .interview-banner-flex {
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
	}
	#top-interview .interview-banner-link {
		position: relative;
		padding-left: 20px;
		line-height: 1.6;
	}
	#top-interview .interview-banner-link::before {
		display: inline-block;
		content: "";
		width: 14px;
		height: 14px;
		background: url(../../../../common/v2/img/ncommon/_common/icon/right-fill-white.svg) 50% 50% no-repeat;
		border-radius: 7px;
		background-size: cover;
		margin-right: 5px;
		position: relative;
		top: 1px;
}

	/* top-special */
	#top-special {
		position: relative;
		height: 681px;
		padding-top: 15px;
		background: #eeeeee url(../img/top/special-image.jpg) no-repeat center bottom;
		text-align: center;
	}

	#top-special:hover .top-sec-menu,
	#top-special:hover .top-sec-menu-btn {
		color: #83cc0e !important;
	}

	#top-special .top-sec-title span {
		display: inline-block;
		font-size: 22px;
		font-weight: bold;
		position: relative;
		padding: 10px 0 10px 15px;
		background: #83cc0e;
		border-radius: 30px;
		color: #fff;
		letter-spacing: .75em;
		margin-top: 32px;
		text-align: center;
		width: 209px;
	}

	#top-special .top-sec-title span::after {
		content: "";
		position: absolute;
		margin: 0;
		bottom: -8px;
		right: 52%;
		width: 0;
		height: 0;
		border-top: 24px solid #83cc0e;
		border-left: 22px solid transparent;
		transform: translateX(50%);
	}

	#top-special .top-sec-menu {
		background-image: linear-gradient(to right, #3c3c3c, #3c3c3c 1px, transparent 1px, transparent 4px);
		background-size: 4px 1px;
		background-position: left bottom;
		background-repeat: repeat-x;
		display: inline-block;
		font-size: 30px;
		font-weight: bold;
		line-height: 1.2;
		letter-spacing: .25em;
		margin-top: 30px;
		padding: 0 4px 16px 56px;
		position: relative;
	}

	#top-special .top-sec-menu:before {
		background: url(../../common/img/arrow_white.svg);
		display: block;
		content: '';
		width: 30px;
		height: 30px;
		left: 20px;
		top: 34.5%;
		margin: auto 0;
		position: absolute;
		transform: translate(-50%, -50%);
	}

	#top-special .top-sec-menu img {
		margin-bottom: 6px;
		margin-right: 16px;
		width: 26px;
	}

	#top-special .top-sec-summary {
		font-size: 18px;
		letter-spacing: .055em;
		width: 685px;
		height: 60px;
		position: absolute;
		top: 211px;
		right: 0;
		left: 0;
		margin: auto;
		text-align: left;
	}

	#top-special .top-sec-menu-btn {
		position: absolute;
		bottom: 30px;
		right: 10%;
	}

	#top-special .top-sec-menu-btn span {
		align-items: center;
		background: #fff;
		border: #ccc solid 1px;
		border-radius: 4px;
		display: inline-block;
		font-size: 14px;
		font-weight: bold;
		line-height: 2;
		padding: 2px 56px 2px 12px;
		position: relative;
		width: 182px;
		height: 34px;
	}

	#top-special .top-sec-menu-btn span:before {
		position: absolute;
		display: block;
		content: '';
		width: 18px;
		height: 18px;
		right: 5%;
		top: 0;
		bottom: 0;
		margin: auto 0;
		background: url(../../common/img/arrow_gray.svg);
	}

	#top-special .top-sec-menu-btn img {
		margin-left: 36px;
		width: 20px;
	}

	/* ==========================================================================
		soft
============================================================================= */

	#soft-title {
		margin-bottom: 66px;
		margin-top: 50px;
	}
	
	#soft-title.mb30 {
		margin-bottom: 30px;
	}

	#soft-title #title-anchor {
		max-width: 960px;
		margin: 0 auto;
	}

	#soft-title #title-anchor>ul {
		padding-top: 30px;
		margin-bottom: 40px;
	}

	#soft-title #title-anchor>ul>li {
		float: left;
		text-indent: -9999px;
	}

	#soft-title #title-anchor>ul>li a {
		display: block;
		width: 230px;
		height: 35px;
	}

	#soft-title #title-anchor>ul>li.anchor-game a {
		background: url(../img/soft/anchor-soft-game_off.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-system a {
		background: url(../img/soft/anchor-soft-system_off.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-network a {
		background: url(../img/soft/anchor-soft-network_off.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-it a {
		background: url(../img/soft/anchor-soft-it_off.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-game a:hover {
		background: url(../img/soft/anchor-soft-game_on.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-system a:hover {
		background: url(../img/soft/anchor-soft-system_on.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-network a:hover {
		background: url(../img/soft/anchor-soft-network_on.png) no-repeat;
	}

	#soft-title #title-anchor>ul>li.anchor-it a:hover {
		background: url(../img/soft/anchor-soft-it_on.png) no-repeat;
	}

	#soft-game,
	#soft-system,
	#soft-network,
	#soft-it {
		margin-bottom: 39px;
	}

	/* ==========================================================================
		Soft-Title
============================================================================= */

	/* ==========================================================================
		Hard-Title
============================================================================= */

	/* ==========================================================================
		engineer layout
============================================================================= */

	.engineer {
		margin-bottom: 50px;
	}

	.engineer .section-left {
		margin-right: 5%;
		width: 55%;
	}

	.engineer .section-right {
		width: 40%;
		text-align: left;
	}

	.engineer .section-right img {
		margin-bottom: 10px;
	}

	.engineer .section-right a img {
		margin-bottom: 0;
	}

	.engineer .section-right a {
		display: block;
		margin-bottom: 10px;
	}

	.section-sub-title-section {
		max-width: 960px;
		margin: 0 auto 20px;
		font-size: 17px;
		font-weight: bold;
		color: #6fad0c;
	}

	figure.wrap {
		margin-bottom: 50px;
	}

	figure.wrap a {
		display: inline-block;
		margin-left: 15px;
	}

	.mb20_sp {
		margin-bottom: 20px;
	}

	.mb50 {
		margin-bottom: 50px;
	}

	.ml230 {
		margin-left: 230px;
	}

	.case-wrap {
		padding: 50px 25px 10px;
		margin-top: 30px;
		margin-bottom: 20px;
		border-radius: 10px;
		background: #f5f5f5;
		box-sizing: border-box;
	}
	
	.content .content-section .annotation {
		padding-left: 1em;
		text-indent: -1em;
	}
	

	/* ==========================================================================
		hard
============================================================================= */

	#hard-title {
		margin-bottom: 66px;
	}

	#hard-title h1 {
		height: 114px;
		background-image: url(../img/hard/title.gif);
	}

	#hard-title #title-anchor {
		max-width: 960px;
		margin: 0 auto;
	}

	#hard-title #title-anchor>ul {
		padding-top: 30px;
		margin-bottom: 40px;
	}

	#hard-title #title-anchor>ul>li {
		float: left;
		text-indent: -9999px;
	}

	#hard-title #title-anchor>ul>li a {
		display: block;
		height: 35px;
	}

	#hard-title #title-anchor>ul>li.anchor-circuit a {
		width: 307px;
		background: url(../img/hard/anchor-hard-circuit_off.png) no-repeat;
	}

	#hard-title #title-anchor>ul>li.anchor-mechanism a {
		width: 306px;
		background: url(../img/hard/anchor-hard-mechanism_off.png) no-repeat;
	}

	#hard-title #title-anchor>ul>li.anchor-production a {
		width: 307px;
		background: url(../img/hard/anchor-hard_off.png) no-repeat;
	}

	#hard-title #title-anchor>ul>li.anchor-circuit a:hover {
		background: url(../img/hard/anchor-hard-circuit_on.png) no-repeat;
	}

	#hard-title #title-anchor>ul>li.anchor-mechanism a:hover {
		background: url(../img/hard/anchor-hard-mechanism_on.png) no-repeat;
	}

	#hard-title #title-anchor>ul>li.anchor-production a:hover {
		background: url(../img/hard/anchor-hard_on.png) no-repeat;
	}

	#hard-circuit,
	#hard-mechanism,
	#hard-products {
		margin-bottom: 39px;
	}

	#hard-circuit .article-title,
	#hard-mechanism .article-title,
	#hard-products .article-title {
		height: 80px;
		margin-bottom: 26px;
	}

	/* ==========================================================================
		ip
============================================================================= */

	#ip-title {
		margin-top: 40px;
		margin-bottom: 40px;
	}

	#ip-patent {
		margin-bottom: 39px;
	}

	#ip-patent .article-title {
		height: 80px;
		margin-bottom: 26px;
	}

	/* ==========================================================================
		special
============================================================================= */

	.cg-pagenation {
		margin: 0 auto 40px;
		text-align: right;
		width: 100%;
		max-width: 960px;
	}

	.cg-pagenation:after {
		content: "";
		display: block;
		clear: both;
	}

	.cg-pagenation li.prev,
	.cg-pagenation li.next {
		display: inline-block;
	}

	.cg-pagenation li a {
		display: block;
		padding: 6px 40px 4px;
		font-weight: bold;
		position: relative;
	}

	.cg-pagenation li.prev a {
		padding-right: 20px;
	}

	.cg-pagenation li.next a {
		padding-left: 20px;
	}

	.cg-pagenation li.pager-num {
		display: inline-block;
		margin: 0px auto 4px;
		text-align: right;
		vertical-align: middle;
		border-left: 1px solid #ccc;
		border-right: 1px solid #ccc;
	}

	.cg-pagenation li.pager-num ul li {
		float: left;
	}

	.cg-pagenation li.pager-num a,
	.cg-pagenation li.pager-num span {
		display: block;
		padding: 0 10px;
		line-height: 1.3;
		vertical-align: middle;
	}

	.cg-pagenation li a:before {
		content: "";
		display: block;
		width: 28px;
		height: 28px;
		background: url(../img/common/icon-arrow.png) no-repeat;
		background-size: contain;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
	}

	.cg-pagenation li.prev a:before {
		left: 0;
		transform: rotate(180deg);
	}

	.cg-pagenation li.next a:before {
		right: 0;
	}

	.cg-pagenation li.pager-active span {
		color: #afafaf !important;
	}

	.cg-pagenation li.pager-num a:before {
		display: none;
	}

	#special-title {
		display: block;
		height: auto;
		margin-bottom: 52px;
	}

	#special-title h1 {
		height: 340px;
		background-image: url(../img/special/title.jpg);
		background-position: center;
		text-indent: -9999px;
	}

	#special-title .sub-title {
		display: none;
	}

	#special-title .title-lead {
		padding: 20px 60px 29px;
		font-size: 15px;
		border-top: 2px solid #83cc0e;
		line-height: 2.26;
		letter-spacing: 2px;
	}

	#special-planning .article-title,
	#special-design .article-title,
	#special-production .article-title {
		height: 80px;
		margin-bottom: 32px;
	}

	#special-planning {
		margin-bottom: 34px;
	}

	#special-design {
		margin-bottom: 67px;
	}

	#special-planning .content-section--2 {
		margin-bottom: 30px;
	}

	#special-planning .content-section--1,
	#special-design .content-section--3 {
		margin-bottom: 15px;
	}

	#special-design .content-section--1 {
		margin-bottom: 21px;
	}

	#special-design .content-section--2 {
		margin-bottom: 10px;
	}

	#special-design .content-section--3 {
		margin-bottom: 10px;
	}

	#special-design .content-section--4,
	#special-design .content-section--5 {
		margin-bottom: 50px;
	}

	#special-production .content-section--1 {
		padding-top: 5px;
		margin-bottom: 20px;
	}

	#special-production .content-section--2 {
		margin-bottom: 22px;
	}

	#special-production .content-section--2 figure {
		padding-top: 7px;
	}

	.content-section .special-notes {
		padding-left: 1em;
		margin-bottom: 20px;
		font-size: 13px;
		color: #666;
		text-indent: -1em;
		line-height: 2.3;
	}

	#special-planning .content-section--1 .section-left {
		margin-right: 5%;
		width: 47.5%;
	}

	#special-planning .content-section--1 .section-right {
		width: 47.5%;
	}

	#special-planning .content-section--1 .section-right figure,
	#special-design .content-section--1 .section-right figure,
	#special-design .content-section--2 .section-left figure {
		padding-top: 7px;
	}

	#special-planning .content-section--1 .section-right figure img,
	#special-design .content-section--1 .section-right figure img,
	#special-design .content-section--2 .section-left figure img {
		width: 100%;
	}

	.section-sub-title {
		padding-top: 3px;
		margin-bottom: 15px;
		font-size: 17px;
		font-weight: bold;
		color: #83cc0e;
	}

	#special-design .content-section--1 .section-left {
		margin-right: 5%;
		width: 57.5%;
	}

	#special-design .content-section--1 .section-right {
		width: 37.5%;
	}

	#special-design .content-section--2 .section-left {
		margin-right: 5%;
		width: 37.5%;
	}

	#special-design .content-section--2 .section-right {
		width: 57.5%;
	}

	#special-design .content-section--3 .section-left,
	#special-design .content-section--3 .section-right {
		width: 47.5%;
	}

	#special-design .content-section--4 .section-left {
		margin-right: 5%;
		width: 47.5%;
	}

	#special-design .content-section--4 .section-right {
		width: 47.5%;
	}

	#special-design .content-section--5 .section-left,
	#special-design .content-section--5 .section-right {
		width: 47.5%;
	}

	#special-design .content-section--6 figure {
		text-align: center;
	}

	#special-production .content-section--2 .section-right {
		width: 60%;
	}

	#special-production .content-section--2 .section-left {
		margin-right: 5%;
		width: 35%;
	}

	/* add */
	.soft_left {
		margin-left: -24px !important;
	}

	.hard_left {
		margin-left: -305px !important;
	}

	.ip_left {
		left: 21px;
	}

	.software-nav {
		margin-left: -143px;
	}

	.hardware-nav {
		margin-left: -305px;
	}

	.z-layer {
		z-index: 1;
	}

	.pointer {
		cursor: pointer;
	}

	.menu__item2 {
		padding-left: 220px;
	}

	.menu__item3 {
		margin-left: -480px;
	}

	ul.case {
		margin-bottom: 20px;
	}

	figure.performance {
		text-align: center;
	}

	figure.performance img {
		width: 40%;
		text-align: center;
		height: auto;
	}

	figcaption {
		margin-bottom: 40px;
		text-align: left;
	}

	figure.performance figcaption {
		margin-bottom: 30px;
	}

	.two {
		align-items: flex-start;
		display: flex;
		gap: 30px;
		margin-bottom: 20px;
	}

	.two li {
		list-style: none;
		width: calc(100% / 2);
	}

	.two li figure,
	.two li img {
		width: 100%;
		height: auto;
	}

	.two li iframe {
		aspect-ratio: 300/168;
		width: 100% !important;
	}

	.three {
		align-items: flex-start;
		display: flex;
		gap: 10px;
	}

	.three li {
		width: calc(100% / 3);
	}

	.three li iframe {
		aspect-ratio: 300/168;
		width: 100% !important;
	}

	.three li img {
		height: auto;
	}

	.two_mb30 {
		margin-bottom: 30px;
	}

	.two.mb50,
	.three.mb50 {
		margin-bottom: 50px;
	}

	.section-center {
		text-align: center;
	}

	.engineer h4 {
		max-width: 960px;
		margin: 0px auto 20px;
		padding: 0 20px;
		font-weight: bold;
		font-size: 16px;
		line-height: 30px;
	}

	.section-center-zoom {
		width: 630px;
		margin: 0 auto;
	}

	.section-center-zoom a {
		display: block;
	}

	.border_radius {
		width: 99%;
		border-radius: 6px;
		border: 1px solid #b5b5b5;
	}

	.border_radius_wn {
		border-radius: 6px;
		border: 1px solid #b5b5b5;
	}

	a:hover figcaption {
		text-decoration: none !important
	}

	.rights {
		font-size: 8px;
		float: right;
	}

	.rights li {
		line-height: 1.2em;
	}

	.ml76 {
		margin-left: 76px;
	}

	.mb8 {
		margin-bottom: 8px;
	}

	.pc_none {
		display: none !important;
	}
	.green_indent{
    justify-content: space-between;
	}
	.green_indent .section-left{
    width: 58%;
    margin-right:2%;
	}
	.green_indent ul{
    margin-top: -14px;
    margin-bottom: 28px;
    padding-left: 54px;
    font-size: 15.5px;
		font-feature-settings: 'palt';
	}
	.green_indent li::before{
    content: '●';
    color: #6fad0c;
    margin-left: -21px;
    margin-right: 3px;
	}
	/* ==========================================================================
		footer
============================================================================= */

	#footer {
		margin-top: 50px !important;
	}
	#footer.mt_0 {
		margin-top: 0px !important;
	}

	/* safari */
	::-webkit-full-page-media,
	:future,
	.two li figure,
	.three li figure {
		width: 100%;
	}

	::-webkit-full-page-media,
	:future,
	.two li .youtube_movie,
	.three li .youtube_movie {
		position: relative;
		width: 100%;
		height: 0;
		padding-top: 56.25%;
	}

	::-webkit-full-page-media,
	:future,
	.two li .youtube_movie iframe,
	.three li .youtube_movie iframe {
		aspect-ratio: auto;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
	}
}

@media screen and (max-width: 1130px) {
	#top-work .content-wrap {
		max-width: 600px;
		margin: 0 auto;
	}
	#top-work .content-wrap .flexbox {
		display: block;
	}
	#top-work .content-wrap .block-soft,
	#top-work .content-wrap .block-net,
	#top-work .content-wrap .block-hard,
	#top-work .block-ip {
		width: 100%;
		border-radius: 8px;
	}
	#top-work .block-hard {
		margin-bottom: 15px;
		border-radius: 8px;
	}
	
	#top-work .block-soft,
	#top-work .block-net,
	#top-work .block-hard {
		background: #fff;
		margin-bottom: 10px;
	}
	
	#top-work .block-soft {
		border-radius: 8px 8px 0 0;
	}
	
	#top-work .block-ip {
		background: #f2fae6;
		/*border-radius: 0 0 8px 8px;*/	
	}
	
	#top-work .block-ip ul {
		padding: 2px 20px 0;
	}
	
	#top-work .block-ip ul li {
		margin: 15px auto;
	}
	
	#top-work  .block-ip-note {
		display: inline-block;
		position: absolute;
		font-size: 12px;
		right: 15px;
		bottom: 2px;
	}

	#top-work h3 {
		border-radius: 8px 8px 0 0;
		background: #f2fae6;
		color: #83cc0e;
		font-size: 20px;
		line-height: 1.6;
		position: relative;
		text-align: center;
	}
	
	#top-work .block-soft h3,
	#top-work .block-hard h3 {
		border-radius: 8px 8px 0 0;
	}
	
	#top-work .block-soft h3,
	#top-work .block-net h3,
	#top-work .block-hard h3 {
		padding-left: 0;
		height: auto;
	}

	#top-work .block-ip h3 {
		border-radius: 8px;
		text-align: left;
	}

	#top-work h3 p {
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		padding: 13px 13px 15px;
		position: relative;
		box-sizing: border-box;
	}

	#top-work a h3 {
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		position: relative;
		box-sizing: border-box;
		padding-left: 30px;
	}
	
	#top-work .block-ip a h3:before {
		background: url(../../common/img/arrow_white.svg);
		display: block;
		content: '';
		width: 16px;
		height: 16px;
		left: 10px;
		top: 50%;
		margin: auto 0;
		position: absolute;
		transform: translate(-50%, -50%);
	}

	#top-work .block-menu-inner {
		padding: 0 164px 20px;
	}

	#top-work .wi-list li {
		margin: 15px 0 0;
	}

	#top-work .wi-list li a {
		padding-left: 30px;
		background: #FFF;
		display: block;
		font-weight: bold;
		position: relative;
	}

	#top-work .wi-list li a:before {
		position: absolute;
		display: block;
		content: '';
		width: 16px;
		height: 16px;
		left: 0;
		top: 0;
		bottom: 0;
		margin: auto 0;
		background: url(../../common/img/arrow_gray.svg);
	}
	#top-work .block-ip {
		padding-top: 25px;
	}
	#top-work .block-ip ul li {
		margin:0 auto;
	}
	#top-work .block-ip ul li:not(:last-child) {
		margin-bottom: 0;
	}
	
}


@media screen and (max-width: 759px) {

	a.zoom_img,
	img.fluid-img,
	figure.has-caption {
		max-width: min(430px, 100%);
		height: auto;
	}

	figure.has-caption {
		width: 100%;
	}

	.mechanism_margin_bottom .mb10{
		margin-bottom:10px;
	}
	
	.content .content-section .annotation {
		padding-left: 1em;
		text-indent: -1em;
	}
	
	.anchor-height {
		margin-top: 0;
		padding-top: 0;
	}
	
	.category-title .category-title--inner {
		display: block;
		box-sizing: border-box;
		height: 70px;
		font-size: 18px;
		line-height: 36px;
		color: #FFF !important;
		text-decoration: none;
		overflow: hidden;
	}
	
		/* .anchor-link
------------------------------------------------------------------- */
	.anchor-link {
		margin-right: 15px;
		margin-left: 15px;
	}
	
	.anchor-link .section-sub-title-section {
		margin-left: 0;
		margin-right: 0;
	}
	
	.anchor-link ul li::before {
		margin-right: 0.25em;
		content: "▼";
		color: #83cc0e;
	}
	
	.anchor-link ul {
		margin-bottom: 30px;
	}
	
	.anchor-link-top {
		text-align: right;
	}
	.anchor-link-top::before {
		margin-right: 0.25em;
		content: "▲";
		color: #83cc0e;
	}
	
	/* .list-dot
------------------------------------------------------------------- */
	.list-dot {
		padding-left: 1em;
	}

	.list-dot li {
		padding-left: 1em;
		margin-bottom: 10px;
		position: relative;
	}

	.list-dot li:before {
		content: "";
		display: block;
		width: 10px;
		height: 10px;
		background: #88d60e;
		position: absolute;
		top: 5px;
		left: 0;
	}

	.menu {
		display: block !important;
	}

	.sp_none {
		display: none !important;
	}

	.keyword_list li a {
		width: 100% !important;
	}

	/* .title-anchor
------------------------------------------------------------------- */
	#title-anchor img {
		display: block;
		width: 100%;
		height: auto;
		margin: 0 auto;
	}

	#title-anchor>ul {
		padding-top: 15px;
		margin-bottom: 10px;
	}

	#title-anchor>ul li {
		margin: 0 0 10px;
	}

	#title-anchor>ul li a {
		display: block;
		padding: 15px;
		text-decoration: none;
		border: solid 1px #dddddd;
		border-radius: 3px;
		background: #FFF;
		position: relative;
	}

	#title-anchor>ul li a:after {
		position: absolute;
		display: block;
		content: '';
		width: 27px;
		height: 27px;
		right: 15px;
		top: 0;
		bottom: 0;
		margin: auto 0;
		background: url(../../common/img/arrow_gray.svg);
		transform: rotate(90deg);
	}

	/* .business-usual
------------------------------------------------------------------- */
	.business-usual {
		margin-bottom: 15px;
		position: relative;
	}

	.business-usual dt {
		display: inline-block;
		padding: 2px 5px 0;
		margin-bottom: 8px;
		color: #fff;
		text-align: center;
		vertical-align: middle;
		background: #88d60e;
	}

	.business-usual dd {
		font-weight: bold;
	}

	/* .content-section
------------------------------------------------------------------- */
	.content-section p {
		text-indent: 1em;
		margin-bottom: 22px;
	}
	.content-section p.mb10 {
		margin-bottom: 10px;
	}

	.sp-word-brake {
		margin-left: 0 !important;
	}

	/* section-title
------------------------------------------------------------------- */
	.article-title {
		padding: 15px 0;
		margin: 0 10px 20px;
		border-radius: 10px;
		color: #FFF;
		font-size: 18px;
		line-height: 23px;
		text-align: center;
		overflow: hidden;
		background: url(../img/common/bg_dot.gif) center top;
	}

	.section-title {
		margin: 0 10px 20px;
		border-bottom: solid 2px #e6f5cf;
	}

	.section-title strong {
		position: relative;
		display: inline-block;
		font-size: 16px;
		line-height: 24px;
		padding: 0 5px 5px;
	}

	.section-title strong:after {
		position: absolute;
		display: block;
		content: '';
		bottom: -2px;
		left: 0;
		width: 100%;
		height: 2px;
		background: #83cc0e;
	}

	.section-sub-title {
		margin-bottom: 6px;
		font-size: 15px;
		font-weight: bold;
		color: #83cc0e;
	}

	.section-title small {
		display: inline-block;
		font-weight: normal;
		line-height: 18px;
		font-size: 12px;
		vertical-align: middle;
	}

	.float-img-left,
	.float-img-right {
		display: block;
		float: none;
		margin: 0 auto 22px;
		max-width: 100%;
		height: auto;
	}

	figure {
		text-align: center;
	}
	
	/* .content-diagram
------------------------------------------------------------------- */
	.content-diagram-wrap {
		margin: auto auto 30px;
	}
	.content-diagram {
		border-bottom: 5px solid #83cc0e;
	}
	.content-diagram img {
		margin-left: auto;
		margin-right: auto;
	}
	
	/* .keyword-engineer
------------------------------------------------------------------- */
	.keyword-engineer {
		background: #f2fae6;
		border-radius: 20px;
		padding: 20px 0;
		margin: auto 0;
	}
	
	#container .keyword-engineer .section-title-keyword {
		color: #6fad0c;
		margin: 0 auto 20px;
		padding: 0 24px;
		border-bottom: none;
	}
	
	#container .keyword-engineer .content-section--flex {
		padding: 0 24px;
	}
	
	#container .keyword-engineer .keyword_list li {
		margin-bottom: 3%;
	}
	.green_indent ul{
		margin-bottom: 28px;
		padding-left: 3.5em;
	}
	.green_indent li::before{
		content: '●';
		color: #6fad0c;
		margin-left: -1.2em;
		margin-right: 0.2em;
	}
	@media screen and (max-width:580px) {
		#container .keyword-engineer .keyword_list li p.ttl {
			font-size: max(3.25vw, 12px);
		}
	}
	

	/* ==========================================================================
		soft
============================================================================= */

	.category-title--engineer {
		background-image: url(../img/common/bg_dot.gif);
	}

	.content-title--engineer {
		border-color: #83cc0e;
	}

	.content-title--engineer .content-intro {
		border-color: #83cc0e;
	}

	.content-title--engineer h1 .sub-title {
		color: #83cc0e;
	}

	.cf-ctop-btn a {
		background-image: url(../img/common/bg_dot.gif);
	}

	/* ==========================================================================
		Top
============================================================================= */

	.top-scroll_btn {
		display: none;
		position: fixed;
		left: 50%;
		margin-left: -30px;
		width: 60px;
		height: 60px;
		z-index: 100;
	}

	.top-scroll_btn a {
		display: block;
		width: 60px;
		height: 60px;
		cursor: pointer;
		text-indent: -9999px;
		background-image: url(../img/top/btn_scroll.png);
		background-size: 120px 60px;
		overflow: hidden;
	}

	.category-top-title {
		margin-bottom: 20px;
		padding: 20px 0 13px;
		text-align: center;
		border-style: solid;
		border-color: #83cc0e;
		border-width: 5px 0 2px;
		font-size: 25px;
		line-height: 30px;
	}

	.category-top-title .sub-title {
		margin-top: 8px;
		display: block;
		color: #83cc0e;
		font-size: 13px;
		line-height: 20px;
	}

	#top-lead {
		margin: 25px 20px;
	}
	
	#top-lead:after {
		margin-top: 1em;
		display: block;
		content: '';
		height: 0;
		padding-top: 30%;
		background: url(../img/top/lead-image.jpg) no-repeat center bottom;
		background-size: contain;
	}

	#top-work {
		padding: 20px 10px;
		background-image: url(../img/common/bg_dot.gif);
	}

	#top-work .top-sec-title,
	#top-work .top-sec-summary {
		color: #fff;
	}

	#top-work .top-sec-title {
		margin-bottom: 4px;
		font-size: 22px;
		font-weight: bold;
		text-align: center;
	}

	#top-work .top-sec-summary {
		margin: 0 auto 20px;
		max-width: min(364.5px, 100%);
	}
	
	#top-work .block-menu-inner {
		padding: 0 20px 20px;
	}
	
	#top-work .block-ip {
		padding-top: 0;
	}
	#top-work .block-ip ul li {
		margin: 15px auto;
	}
	
	#top-work .block-ip-note {
		position: static;
		display: block;
		text-align: right;
		margin-top: -15px;
		margin-right: 10px;
		margin-bottom: 4px;
	}
	
	#top-diagram {
		text-align: center;
		padding: 30px 10px;
	}
	
	.top-diagram-lead {
		text-align: left;
	}

	#top-special {
		padding: 40px 0 40vw;
		position: relative;
		background: #eee;
		background-size: contain;
	}

	#top-special:after {
		position: absolute;
		content: '';
		display: block;
		left: 0;
		bottom: 0;
		background: url(../img/top/special-image_sp.jpg) no-repeat center top;
		background-size: cover;
		width: 100%;
		height: 40vw;
	}
/*
	#top-special a {
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		z-index: 100;
	}
*/
	#top-special .top-sec-title {
		display: block;
		position: relative;
		width: 7em;
		line-height: 1.2;
		margin: 0 auto 12px;
		text-align: center;
		background-color: #83cc0e;
		padding: 10.5px 5px;
		font-size: 16px;
		letter-spacing: 1px;
		color: #FFF;
		border-radius: 9999px;
	}

	#top-special .top-sec-title:after {
		bottom: -5px;
		display: block;
		content: '';
		position: absolute;
		left: 0;
		right: 0;
		margin: 0 auto;
		width: 10px;
		height: 10px;
		background-color: #83cc0e;
		-moz-transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
	}

	#top-special .top-sec-menu {
		margin-bottom: 12px;
		text-align: center;
		font-size: 20px;
		font-weight: bold;
		letter-spacing: .1em;
	}

	#top-special .top-sec-summary {
		margin-bottom: 20px;
		position: relative;
		padding: 0 20px 10px;
	}

	#top-special:hover .top-sec-summary {
		text-decoration: underline;
	}

	#top-special .top-sec-menu-btn {
		margin: 0 20px;
	}

	#top-special .top-sec-menu-btn span {
		background: #FFF;
		border: solid 1px #dddddd;
		border-radius: 3px;
		display: block;
		font-weight: bold;
		padding: 15px;
		position: relative;
		text-decoration: none;
	}

	#top-special .top-sec-menu-btn span:after {
		position: absolute;
		display: block;
		content: '';
		width: 27px;
		height: 27px;
		right: 15px;
		top: 0;
		bottom: 0;
		margin: auto 0;
		background: url(../../common/img/arrow_gray.svg);
	}

	#top-special .top-sec-menu-item1 {
		margin-bottom: 10px;
	}
	
	
	/*top-interview*/
	#top-interview {
		padding: 35px 10px;
		background: #f2f2f2;
	}
	
	#top-interview .interview-banner {
		margin: 0 auto;
		max-width: 610px;
		color: #fff;
		font: "YakuHanJPs","Roboto","Hiragino Kaku Gothic ProN","ヒラギノ角ゴ ProN W3",Arial,"nc3Jp",sans-serif !important;
		text-align: center;
	}
	
	#top-interview .interview-banner h3 {
		font-size: 24px;
		font-weight: normal;
		letter-spacing: 0.2em;
	}
	
	#top-interview .interview-banner-text {
		margin-top: 10px;
		line-height: 1.6;
	}
	
	#top-interview .interview-banner a {
		padding: 15px 20px;
		color: #fff;
		display: block;
		background: #e60012;
		border-radius: 16px;
	}
	
	#top-interview .interview-banner a:hover {
		opacity: 0.75;
		color: #fff;
	}
	
	#top-interview .interview-banner span {
		font-size: 12px;
		display: block;
		font-weight: bold;
		letter-spacing: 0.25em;
	}
	#top-interview .interview-banner-flex {
		display: block;
	}
	#top-interview .interview-banner-link {
		margin: 14px 0 8px;
		position: relative;
	}
	#top-interview .interview-banner-link::before {
		display: inline-block;
		content: "";
		width: 12px;
		height: 12px;
		background: url(../../../../common/v2/img/ncommon/_common/icon/right-fill-white.svg) 50% 50% no-repeat;
		border-radius: 7px;
		background-size: cover;
		margin-right: 5px;
		position: relative;
		top: 1px;
}

	/* ==========================================================================
		soft
============================================================================= */

	#soft-title {
		margin-bottom: 30px;
	}

	#soft-game,
	#soft-system,
	#soft-network {
		margin-bottom: 20px;
	}

	#soft-it {
		margin-bottom: 50px;
	}


	/* ==========================================================================
		hard
============================================================================= */

	#hard-title {
		margin-bottom: 30px;
	}

	#hard-circuit,
	#hard-mechanism {
		margin-bottom: 20px;
	}

	#hard-production {
		margin-bottom: 50px;
	}

	.i-block img {
		width: 100%;
	}

	/* ==========================================================================
		ip
============================================================================= */

	#ip-title {
		margin-bottom: 30px;
	}

	#ip-patent {
		margin-bottom: 50px;
	}

	#ip-patent figure img {
		width: 100%;
	}
	

	/* ==========================================================================
		special
============================================================================= */

	.cg-pagenation {
		margin: 0 20px 30px;
		text-align: right;
	}

	.cg-pagenation:after {
		content: "";
		display: block;
		clear: both;
	}

	.cg-pagenation>li {
		display: inline-block;
	}

	.cg-pagenation li.prev {
		display: inline-block;
		padding-right: 10px;
	}

	.cg-pagenation li.next {
		display: inline-block;
		padding-left: 10px;
	}

	.cg-pagenation li a {
		display: block;
		padding: 6px 40px 4px;
		vertical-align: 14px;
		font-weight: bold;
		position: relative;
	}

	.cg-pagenation li.prev a {
		padding-right: 5px;
	}

	.cg-pagenation li.next a {
		padding-left: 5px;
	}

	.cg-pagenation li a:before {
		content: "";
		display: block;
		width: 28px;
		height: 28px;
		background: url(../img/common/icon-arrow.png) no-repeat;
		background-size: contain;
		position: absolute;
		top: 0;
		bottom: 0;
		margin: auto;
	}

	.cg-pagenation li.prev a:before {
		left: 0;
		transform: rotate(180deg);
	}

	.cg-pagenation li.next a:before {
		right: 0;
	}

	.cg-pagenation li.pager-num {
		display: inline-block;
		margin: 0 auto 4px;
		padding-top: 2px;
		text-align: center;
		vertical-align: middle;
	}

	.cg-pagenation li.pager-num ul li {
		float: left;
	}

	.cg-pagenation li.pager-num ul li:first-child {
		border-left: 1px solid #ccc;
	}

	.cg-pagenation li.pager-num ul li:last-child {
		border-right: 1px solid #ccc;
	}

	.cg-pagenation li.pager-num a,
	.cg-pagenation li.pager-num span {
		display: block;
		padding: 0 10px;
		line-height: 1.3;
		vertical-align: middle;
	}

	.cg-pagenation li.pager-active span {
		color: #afafaf !important;
	}

	.cg-pagenation li.pager-num a:before {
		display: none;
	}

	#special-title {
		margin-bottom: 30px;
	}

	#special-patent {
		margin-bottom: 50px;
	}

	.content-section .special-notes {
		font-size: 13px;
		color: #666;
		text-indent: -1em;
		padding-left: 1em;
	}

	#special-title h1 {
		padding-bottom: 0;
		background: #eee;
		position: relative;
	}

	#special-title h1:after {
		content: "";
		display: block;
		width: 100%;
		height: 0;
		padding-top: 35.416%;
		background: url(../img/special/title_bg_sp.jpg) no-repeat top center;
		background-size: contain;
		box-sizing: border-box;
	}

	#special-title .title-lead {
		padding: 15px 10px 19px;
		border-top: 2px solid #83cc0e;
		line-height: 2.26;
	}

	#special-planning .content-section--1,
	#special-planning .content-section--2,
	#special-planning .content-section--3,
	#special-design .content-section--1,
	#special-design .content-section--2,
	#special-design .content-section--3,
	#special-design .content-section--4,
	#special-design .content-section--5,
	#special-design .content-section--6,
	#special-production .content-section--1,
	#special-production .content-section--2,
	#special-production .content-section--3 {
		margin-bottom: 20px;
	}

	#special-planning .content-section--1 .section-right figure,
	#special-design .content-section--1 .section-right figure,
	#special-design .content-section--2 .section-left figure,
	#special-design .content-section--3 .section-left figure,
	#special-design .content-section--3 .section-right figure,
	#special-design .content-section--4 .section-left figure,
	#special-design .content-section--4 .section-right figure,
	#special-design .content-section--5 .section-left figure,
	#special-design .content-section--5 .section-right figure,
	#special-design .content-section--6 figure,
	#special-production .content-section--2 .section-left figure {
		margin-bottom: 15px;
	}

	#special-planning figure img,
	#special-design figure img {
		width: 100%;
	}
	.mb10 {
		margin-bottom: 10px;
	}
	.mb20 {
		margin-bottom: 20px;
	}

	.section-sub-title-section {
		margin: 0 10px 10px 13px;
		color: #6fad0c;
	}

	.wrap {
		margin-bottom: 20px;
	}

	.case-wrap {
		padding: 25px 20px 10px;
		margin: 0 0 0;
		background: #f5f5f5;
		box-sizing: border-box;
	}

	.case-wrap .content-wrap--indent {
		margin: 0 auto;
	}

	.case-wrap img {
		width: 100%;
	}

	.zoom_img {
		margin-bottom: 10px;
	}

	.mgb-sm {
		margin-bottom: 30px;
	}

	figure.performance figcaption {
		margin-bottom: 20px;
	}

	.two {
		align-items: center;
		display: flex;
		flex-direction: column;
		justify-content: center;
		gap: 20px;
	}

	.two li {
		list-style: none;
		width: 100%;
		text-align: center;
	}

	.two li video,
	.two li img {
		width: 100%;
	}

	.mb20_sp {
		margin-bottom: 0px;
	}

	.three figure a {
		margin-bottom: 0px;
	}

	.three figure figcaption {
		margin-bottom: 30px;
	}

	figcaption {
		margin-top: 0em;
	}

	figcaption,
	.two figcaption,
	.three figcaption {
		margin-bottom: 20px;
	}

	a.color-black {
		color: #464646;
	}

	.sp_none {
		display: none;
	}

	.engineer h4 {
		font-weight: bold;
		margin: 0 10px 15px;
		padding: 0 5px;
	}

	.mb50 {
		margin-bottom: 20px;
	}

	.img_mb10 {
		margin-bottom: 10px;
	}

	.border_radius {
		width: 99%;
		border-radius: 6px;
		border: 1px solid #b5b5b5;
	}

	.border_radius_wn {
		border-radius: 6px;
		border: 1px solid #b5b5b5;
	}

	.rights {
		font-size: 8px;
		margin-bottom: 20px;
	}

	.rights li {
		line-height: 1.2em;
	}

	figcaption {
		text-align: left;
	}

	.w100 {
		width: 100%;
	}

	.w100 img.fluid-img {
		width: 100%;
	}

	.margin_sp {
		margin-bottom: 20px;
	}
	.content-wrap--indent.sp_mb0{
		margin-bottom: 0px;
	}

	.sp_none {
		display: none;
	}

	.category-nav_special {
		border-top: solid 1px #cdcdcd;
	}

	.category-nav_special a {
		position: relative;
		padding: 9px 20px;
		display: block;
		text-decoration: none;
		background: #f2f2f2;
	}

	.category-nav_special a:after {
		position: absolute;
		display: block;
		content: '';
		right: 20px;
		top: 0;
		bottom: 0;
		margin: auto 0;
		height: 8px;
		width: 5px;
		text-decoration: none;
		background-image: url(../../common/img/sp-sprite.png);
		background-size: 300px 300px;
		overflow: hidden;
		background-position: -150px -100px;
	}

	/* safari */
	::-webkit-full-page-media,
	:future,
	.two li .youtube_movie figure,
	.three li .youtube_movie figure {
		position: relative;
		width: 100%;
		height: 0;
		padding-top: 56.25%;
	}

	::-webkit-full-page-media,
	:future,
	.two li .youtube_movie figure iframe,
	.three li .youtube_movie figure iframe {
		aspect-ratio: auto;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
	}
	
		/* ==========================================================================
		footer
============================================================================= */
	#footer.mt_0 {
		margin-top: 0px !important;
	}

}

@media screen and (max-width:480px) {

	.article-title {
		font-size: 16px;
	}

}