main {
	position: relative;
}

main .title_area {
	background: #666;
	overflow: hidden;
	margin-bottom:0;
}

main .title_area .container {
	box-shadow: 0 36px 0px 0px #666, 0 -36px 0px 0px #666, 48px 0 60px -16px rgba(0,0,0,0.4), -48px 0 60px -16px rgba(0,0,0,0.4);
	padding:2em 0;
}

main .products_jp .title_area .container {
	padding:2em 0 5.5em;
}

main .title_area h1 {
	font-size:1.5em;
	font-weight:bold;
	color:#FFF;
	text-align: center;
	line-height: 1.4;
}

main .container {
	position: relative;
}

main .container a:hover,
main .container a:active,
main .container a:focus,
main .container a:visited {
	text-decoration:none;
}

.cate_wrapper {
	position: relative;
	box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.2);
}

.select_area {
	position: absolute;
	top:-3.3em;
	width:100%;
}

#taxo_list {
	width:96%;
	max-width: 1160px;
	margin:0 auto;
}

#tag_trigger_list {
	text-align: center;
	width:85%;
	margin:0 auto;
}

#tag_trigger_list li {
	display: inline-block;
	width:48%;
	margin:0 0.5%;
	font-size:1.1em;
	border-radius: 4px 4px 0 0 / 4px 4px 0 0;
	overflow: hidden;
}

#tag_trigger_list li a {
	display: block;
	height:3em;
	padding:0.8em 0 1em;
	box-sizing: border-box;
	background: var(--Yellow);
	font-weight: bold;
	text-align: center;
	text-decoration: none;
	color:var(--DarkGray);
	box-shadow:0 -8px 5px -5px rgba(0,0,0,0.1) inset
}

#tag_trigger_list li.active a {
	background: #FFF;
	box-shadow:none;
}

.product_menu {
	background: #FFF;
	padding:2em 2em 1em;
	display: none;
	margin-bottom:30px;
}

.product_menu.active {
	display: block;
}

.product_menu a {
	color:var(--DarkGray);
	display: block;
}

.product_menu a:hover {
	text-decoration: none;
	opacity: 0.7;
}

.product_menu ul li ul li {
	line-height: 1.6;
}

.product_menu ul li ul li:first-child a {
	border-bottom:solid 3px var(--Yellow);
	font-weight:bold;
	margin-bottom:6px;
}

.product_menu > ul > li {
	margin-bottom:1em;
}

.lead_en {
	padding:2em 1em;
	line-height: 1.7;
}

.to_naviplus {
	text-align: center;
	margin-bottom:2em;
}

.to_naviplus a {
	color: var(--DarkGray);
}

.to_naviplus a dl {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	gap: 1.5em;
	width: 100%;
	max-width: 850px;
	height:7em;
	overflow: hidden;
	border-radius: 8px;
	border: solid 3px var(--YellowGreen);
	box-sizing: border-box;
}

.to_naviplus a dl dt {
	background: var(--YellowGreen);
	color: #FFF;
	padding: 2em 0 2em 1.3em;
	position: relative;
	min-width: 8em;
	max-width: 13em;
}

.to_naviplus a dl dt:before {
	content:"";
	width:0;
	height:0;
	border: solid 4em transparent;
	position: absolute;
	top: calc(50% - 4em);
	right: -5em;
	border-left: solid 1em var(--YellowGreen);
}

.to_naviplus a dl dt span {
	font-weight:500;
	display: inline-block;
}

.to_naviplus a dl dd {
	display: flex;
	flex-wrap: wrap;
	gap: 0 10px;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	padding: 0.8em 1.3em 0 0;
	width: 100%;
}

.to_naviplus a dl dd span {
	display: flex;
	gap: 0 0.4em;
	width:13.4em;
	font-weight:500;
}

.to_naviplus a dl dd span i img {
	width:2em;
}

.to_naviplus a dl dd > img {
	width: 10.5em;
	margin-bottom: 0.8em;
}

.content_inner {
	display: none;
}

.content_inner.active {
	display: block;
}

.content_inner > section {
	background: #FFF;
	padding:1em;
}

.products_jp .content_inner > section {
	padding:0;
}

.content_inner > section h2 {
	font-weight:500;
	border-left:solid 4px var(--Yellow);
	padding:0.5em 0.6em;
	font-size:1.6em;
	margin-bottom:1em;
	line-height: 1.0;
	background: var(--PaleBlue);
}

.content_inner > section h3 {
	font-weight:500;
	font-size:1.3em;
}

.exp,
.content_inner > section > div.exp {
	background: var(--PaleYellow);
	box-sizing: border-box;
	padding:2em;
	border-radius: 14px;
	margin-bottom:40px;
	position: relative;
}

.exp:after {
	content:"";
	width:0;
	height:0;
	display: block;
	position: absolute;
	bottom:-30px;
	left:50px;
	border-top:solid 15px var(--PaleYellow);
	border-right:solid 20px var(--PaleYellow);
	border-bottom:solid 15px transparent;
	border-left:solid 20px transparent;
}

.content_inner > section .exp h2,
.exp h2 {
	font-weight:500;
	font-size:1.3em;
	margin-bottom:0.7em;
	text-align: center;
	background: none;
	padding:0;
	line-height: 1.5;
	border-left: none;
}

.exp p {
	text-align: left;
	line-height: 1.8;
	margin:0 auto;
}

.products_jp .content_inner > section > div.exp > ul,
.exp ul {
	margin:1em auto 0;
	max-width: 300px;
	display: block;
}

.products_jp .content_inner > section > div.exp > ul li {
	width: auto;
	min-height: 0;
}

.products_jp .content_inner > section > div.exp > ul li a {
	border:none;
}

.products_jp .content_inner > section > div.exp > ul li a.btn,
.exp ul li a.btn {
	display: block;
	font-weight: 600;
	font-size:1.2em;
	border-radius: 3em;
	position: relative;
	text-align: center;
	padding:1em 3em 1em 2em;
	/*border:solid 1px #CCC;*/
	background: #FFF;
	margin-top:0.5em;
	line-height: 1em;
	box-sizing: border-box;
}

.exp ul li a.btn:before {
	content:"";
	width: 19px;
    height: 19px;
    background: var(--Orange);
    border-radius: 100%;
    display: block;
    margin: 0 auto;
    position: absolute;
    top: calc(50% - 10px);
    right: 19px;
}

.exp ul li a.btn.green:before {
	background: var(--Green);
}

.exp ul li a.btn.blue:before {
	background: var(--Blue);
}

.exp ul li a.btn:after {
	content: "";
    width: 4px;
    height: 4px;
    border-top: solid 1px #FFF;
    border-right: solid 1px #FFF;
    transform: rotate(45deg);
    position: absolute;
    top: calc(50% - 3px);
    right: 27px;
}

.h3_wrap {
	margin-bottom:0.6em;
}

.h3_wrap p {
	margin-top: 0.3em;
    line-height: 1.7;
}

.content_inner > section h2 + div.example {
	margin-bottom:1.5em;
}

.content_inner > section h2 + div.example ul {
	display: flex;
	gap:10px;
	margin-bottom:0.5em;
	align-items: flex-start;
}

.content_inner > section h2 + div.example ul li {
	width: 100%;
	max-width: 310px;
}

.content_inner > section h2 + div.example ul li img {
	aspect-ratio:3/2;
	object-fit: cover;
}

.content_inner > section > div {
	margin-bottom:2em;
	position: relative;
}

.products_jp .content_inner > section > div {
	margin-bottom:3em;
}

.products_jp .content_inner > section > div.exp {
	margin-bottom: 40px;
}

.content_inner > section > div a.btn_detail {
	position: absolute;
	top:1.2em;
	right:2em;
	background: var(--DarkGray);
	color:#FFF;
	border-radius: 3px;
	padding:0.2em 0.8em;
	font-weight:bold;
	font-size:0.9em;
}

.content_inner > section > div a.btn_detail:hover {
	text-decoration: none;
	opacity: 0.7;
}

.content_inner > section > div.active {
	height:auto;
}

.content_inner > section > div > ul {
	background: #DDD;
	padding:1.1em;
	padding-bottom:0.2em;
}

.products_jp .content_inner > section > div > ul,
.products_jp ul.grid_list {
	background: none;
	padding:0;
	padding-bottom:0;
	display: flex;
	gap:10px;
	flex-wrap: wrap;
	align-items: stretch;
}

.content_inner > section > div > ul li {
	display: inline-block;
	vertical-align: top;
	width:48%;
	margin:0 0.5% 1em;
	min-height:210px;
}

.products_jp .content_inner > section > div > ul li,
.products_jp ul.grid_list li {
	margin:0;
	min-height: 0;
	width:calc((100% - 10px) / 2);
}

.content_inner > section > div > ul li a,
.content_inner > section > div > ul li > span,
.products_jp ul.grid_list li > a,
.products_jp ul.grid_list li > span {
	display: block;
	background: #FFF;
	border:solid 1px #CCC;
	padding:1em;
	color:var(--DarkGray);
	height: 100%;
	box-sizing: border-box;
}

.content_inner > section > div#automation_machines > ul li > span {
	background: var(--PaleYellow);
	border-radius: 8px;
	border:none;
	display: flex;
	align-items: center;
	justify-content: center;
	gap:16px;
}

.content_inner > section > div#automation_machines > ul li > span p.product_name {
	text-align: center;
    color: var(--Orange);
    font-size: 1.7em;
    letter-spacing: 0.1em;
}

.content_inner > section > div#automation_machines > ul li > span img {
	width:3em;
	margin-top:3px;
}

.content_inner > section > div > ul li a:hover {
	text-decoration: none;
	opacity: 0.7;
}

.content_inner > section > div > ul li .img_wrapper,
.products_jp ul.grid_list li .img_wrapper {
	/*width:80%;*/
	max-width:160px;
	display: block;
	margin:0 auto 1em;
	text-align: center;
}

#products_en .content_inner > section > div > ul li .img_wrapper {
	width:100%;
	max-width: none;
}

#products_en .content_inner > section#inspection > div ul li .img_wrapper,
#products_en .content_inner > section#transport > div ul li .img_wrapper {
	max-width:160px;
}

.content_inner > section > div > ul li .img_wrapper img,
.products_jp ul.grid_list li .img_wrapper img {
	width:auto;
	height:96px;
}

#products_en .content_inner > section > div > ul li .img_wrapper img {
	width:100%;
	height:auto;
}

.content_inner > section > div > ul li p.spec,
.products_jp ul.grid_list li p.spec {
	color:#888;
	line-height: 1.3;
	font-size:0.74em;
	word-break: break-all;
}

.products_jp ul.grid_list li p.spec {
	font-size:0.9em;
}

.content_inner > section > div > ul li p.product_name,
.products_jp ul.grid_list li p.product_name {
	font-size:1.1em;
	font-weight:600;
	word-break: break-all;
}

#products_en .content_inner > section > div > ul li p.product_name,
#products_en .content_inner > section > div > ul li p.spec {
	word-break: break-word;
}

.content_inner > section > div > ul li p.product_name span {
	font-size:0.9em;
}

.content_inner > section > div#pad_printing > ul li p.product_name {
	background: var(--Blue);
	color:#FFF;
	padding:0.3em 0.5em;
	margin-bottom:0.3em;
}

.content_inner > section > div#hot_stamp > ul li p.product_name,
.content_inner > section > div#roll_transfer > ul li p.product_name {
	background: var(--Green);
	color:#FFF;
	padding:0.3em 0.5em;
	margin-bottom:0.3em;
}

#products_en .content_inner > section#inspection > div > ul li p.product_name {
	background: #65aadd;
	color:#FFF;
	padding:0.3em 0.5em;
	margin-bottom:0.3em;
}

.content_inner > section > div > ul li#screen p.product_name {
	background: var(--DarkGray);
	color:#FFF;
	padding:0.3em 0.5em;
	margin-bottom:0.3em;
}

.bnr_process_area {
	display: block;
	text-align: center;
	margin:3em 0 1em;
}

.bnr_process_area > p {
	font-size: 1.1em;
	font-weight: 500;
	line-height: 1.7;
}

.bnr_process_area > p span {
	display: inline-block;
	font-weight: 500;
}

.bnr_process_area a {
	display: inline-block;
	position: relative;
	background: #FFF;
	border: solid 4px var(--Orange);
	border-radius: 21px;
	overflow: visible;
	padding: 1.6em 0;
	box-sizing: border-box;
	width: 100%;
	max-width: 850px;
	margin:3em auto 0;
	min-width: 324px;
}

.bnr_process_area a > i {
	font-size: 20px;
	line-height: 68px;
	padding: 0;
	text-align: center;
	width: 68px;
	height: 68px;
	box-sizing: border-box;
	color: #FFF;
	font-weight: 500;
	background: var(--Orange);
	border-radius: 100%;
	position: absolute;
	left: 6%;
	top: -36px;
}

.bnr_process_area a > img {
	position: absolute;
	width: 21%;
	max-width: 156px;
	left: 4%;
	bottom: 0;
}

.bnr_process_area a p {
	font-weight: 500;
	font-size: 3.25vw;
	color: var(--DarkGray);
	line-height: 1.6;
	text-align: left;
	width: 19.5em;
	float: right;
}

.bnr_process_area a p span {
	display: inline-block;
	font-weight: 500;
}

.bnr_process_area a p strong {
	display: block;
	width: 13em;
	color:var(--Orange);
	font-size: 1.45em;
	font-weight:500;
	margin-top:0.2em;
	position: relative;
}

.bnr_process_area a p strong:before {
	content:"";
	width: 19px;
	height: 19px;
	background: var(--Orange);
	border-radius: 100%;
	display: block;
	margin: 0 auto;
	position: absolute;
	top: calc(50% - 8px);
	right: 10px;
}

.bnr_process_area a p strong:after {
	content: "";
	width: 4px;
	height: 4px;
	border-top: solid 1px #FFF;
	border-right: solid 1px #FFF;
	transform: rotate(45deg);
	position: absolute;
	top: calc(50% - 1px);
	right: 18px;
}

.to_cases {
	text-align: center;
	margin-top:3em;
}

.to_cases a {
	display: inline-block;
	font-weight: 500;
	color:var(--DarkGray);
	text-decoration: none;
	background: #FFF;
	border:solid 1px #CCC;
	border-radius:3em;
	padding:1.4em 3.5em 1.4em 1.8em;
	line-height: 1em;
	box-sizing: border-box;
	position: relative;
}

.to_cases a:hover {
	text-decoration: none;
}

.to_cases a:before {
	content:"";
	width: 19px;
	height: 19px;
	background: var(--Orange);
	border-radius: 100%;
	display: block;
	margin: 0 auto;
	position: absolute;
	top: calc(50% - 10px);
	right: 19px;
}

.to_cases a:after {
	content: "";
	width: 4px;
	height: 4px;
	border-top: solid 1px #FFF;
	border-right: solid 1px #FFF;
	transform: rotate(45deg);
	position: absolute;
	top: calc(50% - 3px);
	right: 27px;
}


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

.to_naviplus a dl dt {
	padding: 2em 0.5em 2em 1.8em;
}

.to_naviplus a dl dd {
	font-size:1.0em;
	padding: 0.8em 1.5em 0 0.5em;
}

}


@media screen and (min-width: 560px) {

.content_inner > section > div a.btn_detail {
	font-size:1.0em;
}

.content_inner > section > div > ul li .img_wrapper img,
.products_jp ul.grid_list li .img_wrapper img {
	height:140px;
}

#products_en .content_inner > section > div > ul li .img_wrapper img {
	height:auto;
}

.content_inner > section > div > ul li p.spec {
	font-size:0.9em;
}

.bnr_process_area a {
	padding: 2em 0;
}

.bnr_process_area a > i {
	left: 3%;
}

.bnr_process_area a > img {
	width: 15%;
    left: 4.5%;
}

.bnr_process_area a p {
	font-size: 2.45vw;
	line-height: 1.7;
	width: 28em;
}

.bnr_process_area a p strong {
	font-size: 1.7em;
	margin:0;
}

}


@media screen and (min-width: 768px) {

main .title_area h1 {
	font-size:1.8em;
	margin:0 auto;
	box-sizing: border-box;
}

.select_area {
	top:-3.6em;
}

#tag_trigger_list {
	width:80%;
	max-width:600px;
	display: block;
}

#tag_trigger_list li {
	font-size:1.2em;
}

.product_menu {
	padding:2em 1em 1em;
}

.product_menu > ul > li {
	display: inline-block;
	width: 35%;
	vertical-align: top;
	padding:0 0.5em;
	box-sizing: border-box;
}

.product_menu > ul > li:nth-of-type(3n) {
	width: 29%;
}

.to_naviplus a dl {
	border-radius: 14px;
}

.to_naviplus a dl dt {
	padding: 3em 0.3em 3em 1.7em;
}

.to_naviplus a dl dd {
	padding: 0.8em 2em 0 1em;
}

.content_inner > section .exp h2,
.exp h2 {
	font-size:1.5em;
}

#results .exp p br.pc {
	display:none;
}

.exp ul {
	display: flex;
	gap: 6px;
	max-width: 840px;
	justify-content: center;
}

.exp ul li {
	width: 100%;
}

.exp ul li a.btn {
	font-size:15px;
	padding:1em 2em 1em 1em;
}

.content_inner > section {
	background: #FFF;
	padding:20px 30px;
}

.products_jp .content_inner > section > div {
	margin-bottom:4em;
}

.content_inner > section > div > ul li {
	width:31%;
	margin:0 0.5% 1em;
}

.products_jp .content_inner > section > div > ul li,
.products_jp ul.grid_list li {
	width:calc((100% - 20px) / 3);
}

.content_inner > section > div > ul li p.spec,
.products_jp ul.grid_list li p.spec {
	font-size:13px;
}

.bnr_process_area a {
	padding: 2em 0;
	max-width: 850px;
}

.bnr_process_area a > i {
  line-height: 73px;
  width: 73px;
  height:73px;
  top:-24px;
  left: auto;
  right: calc(50% + 296px);
}

.bnr_process_area a > img {
	width: 120px;
  left: auto;
  right: calc(50% + 190px);
}

.bnr_process_area a p {
	font-size: 17px;
	line-height: 1.8;
	float: none;
  padding-left: calc(50% - 170px);
}

.bnr_process_area a p strong {
	font-size: 30px;
	margin:0;
	width: 12.5em;
}

}


@media screen and (min-width: 800px) {

.to_naviplus a dl dt {
	min-width: 19em;
	max-width: none;
	width: 43%;
}

.to_naviplus a dl dt:before {
	right: -4.9em;
}

.to_naviplus a dl dd {
	width: 57%;
}

}


@media screen and (min-width: 1000px) {

.product_menu {
	height:11em;
	margin-bottom:50px;
	padding:2em 0 1em;
}

.product_menu > ul {
	display: flex;
	width: auto;
	gap: 10px;
	margin: 0 auto;
	justify-content: center;
}

.product_menu > ul > li,
.product_menu > ul > li:nth-of-type(3n) {
	display: block;
	width:auto;
}

.product_menu:nth-of-type(2) > ul {
	margin:0 auto;
	padding-top:4.2em;
	gap:36px;
}

.product_menu ul li ul li {
	padding-right: 1em;
	width: 100%;
}

.exp p {
	text-align: center;
	max-width: none;
}

#results .exp p br.pc {
	display:block;
}

.exp ul li a.btn {
	font-size:17px;
}

.to_naviplus {
	margin-bottom:3em;
}

.to_naviplus a {
	font-size:1.1em;
}

.h3_wrap h3 {
	margin-right:1.5em;
}

.h3_wrap h3,
.h3_wrap p {
	display: inline-block;
	vertical-align: bottom;
}

.content_inner > section h2 + div.example {
	display: flex;
	width: 100%;
	gap:24px;
	align-items: center;
}

.content_inner > section h2 + div.example p {
	font-size: 14px;
	line-height: 1.7;
	width: 33em;
	text-align: justify;
}

.products_jp .content_inner > section > div {
	margin-bottom:5em;
}

.content_inner > section > div > ul li {
	width:23%;
	margin:0 0.5% 1em;
}

.products_jp .content_inner > section > div > ul li,
.products_jp ul.grid_list li {
	width: calc((100% - 30px) / 4);
}

.to_cases a,
.to_cases a:before,
.to_cases a:after,
.bnr_process_area a,
.bnr_process_area a p strong:before,
.bnr_process_area a p strong:after {
	transition-duration: .2s;
}

.bnr_process_area a:hover {
	background: var(--PaleYellow);
	border: solid 4px var(--Yellow);
}

.to_cases a:hover:before,
.bnr_process_area a:hover p strong:before {
	transform: translateX(10px);
}

.to_cases a:hover:after,
.bnr_process_area a:hover p strong:after {
	transform: translateX(10px) rotate(45deg);
}

.bnr_process_area a p {
	padding-left: calc(50% - 156px);
}

.to_cases a:before {
	right: 29px;
}

.to_cases a:after {
	right: 37px;
}

.to_cases a:hover {
	color:#AAA;
	outline:solid 2px #CCC;
	outline-offset: -2px;
}

}


@media screen and (min-width: 1200px) {

.product_menu > ul {
	gap: 20px;
}

.exp ul li a.btn {
	font-size:18px;
}

.content_inner > section h2 + div.example p {
	font-size:15px;
}

.content_inner > section > div > ul li .img_wrapper {
	width:100%;
	max-width:none;
}
.content_inner > section > div > ul li .img_wrapper img,
.products_jp ul.grid_list li .img_wrapper img {
	height:160px;
}

#products_en .content_inner > section > div > ul li .img_wrapper img {
	height:auto;
}

.bnr_process_area > p {
	font-size: 1.2em;
}

}