@charset "utf-8";
/*
Theme Name: aipricom
Author: aipricom
*/
/* ==================================================
reset
================================================== */
body {
	margin: 0;
	padding: 0;
	font-size: 100%;
	line-height: 1.5;
	background-color: #FFFFFF;
	color: #323232;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd,
blockquote,
form,
input {
	margin: 0;
	padding: 0;
}
img {
	border: none;
	vertical-align: top;
}
li,
dt,
dd {
	line-height: 1.5;
}
table {
	font-size: 100%;
	line-height: 1.5;
	border-collapse: collapse;
	border-spacing: 0;
}
form,
input,
select {
	font-size: 100%;
}
a {
	text-decoration: underline;
	transition-duration: 0.2s;
}
a:link,
a:visited {
	color: #105da0;
	background-color: transparent;
}
::placeholder {
	color: #b3b3b3;
}
.sp_only {
	display: none;
}
body,
#contents input[type="submit"],
#contents input[type="button"],
#contents input[type="text"],
#contents textarea,
#contents select,
body.mceContentBody {
	font-family: "Noto Sans JP", sans-serif;
}
/* ==================================================
layout
================================================== */
header,
main,
footer {
	width: 100%;
	min-width: 1200px;
	clear: both;
}
#title,
#pnavi,
#main,
#recruit_message,
#recruit_design,
#recruit_work,
#recruit_voice,
#top_news,
#footer {
	width: 1180px;
	margin: 0 auto;
}
/* ==================================================
header
================================================== */
#header {
	width: 100%;
	min-width: 1200px;
	padding: 0 2% 0 0;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
}
#hlogo {
	background-color: #ffffff;
	position: relative;
	z-index: 2;
}
#hlogo span {
	display: none;
}
#hlogo p {
	position: absolute;
	left: 0;
	top: 0;
}
#hlogo a {
	display: block;
	padding: 10px 17px;
	background-color: #ffffff;
}
#hlogo img {
	height: 110px;
	width: auto;
}
#sp_menu {
	display: none;
}
#header.toppage {
	padding: 0 2%;
}
#header.toppage #hlogo {
	background: none;
	position: static;
}
#header.toppage #hlogo img {
	height: 155px;
	width: auto;
}
/* ==================================================
gnavi
================================================== */
#gnavi {
	padding: 15px 0;
}
#gnavi ul {
	margin: 0;
	list-style: none;
	display: flex;
	justify-content: space-around;
	align-items: center;
}
#gnavi li {
	padding: 0 5px 0 7px;
	background: url("img/header/gnavi_line.png") no-repeat left center;
}
#header.toppage #gnavi li {
	background-image: url("img/header/gnavi_line_top.png");
}
#gnavi li a {
	display: block;
	padding: 8px 20px;
	line-height: 1.2;
	text-decoration: none;
	color: #323232;
	background: url("img/header/gnavi_on.png") no-repeat center bottom;
	background-size: auto 0;
}
#gnavi li.contact a {
	color: #ffffff;
	background-color: #105da0;
	padding: 8px 14px;
	border: 1px solid #105da0;
}
#gnavi li:first-of-type a {
	border: none;
}
#gnavi li:first-of-type {
	background: none;
}
#gnavi li:last-of-type {
	background: none;
	padding: 0 0 0 5px;
}
#header.toppage #gnavi li:first-of-type {
	background: none;
}
#header.toppage #gnavi li:last-of-type {
	background: none;
	padding: 0 0 0 5px;
}
#header.toppage #gnavi li a {
	color: #ffffff;
	background: none;
	border-color: #ffffff;
	text-shadow: 2px 2px 5px #000000;
}
#header.toppage #gnavi li.contact a {
	text-shadow: none;
	background-color: #105da0;
	border-color: #105da0;
}
/* ==================================================
main
================================================== */
#main {
	margin-bottom: 50px;
}
/* title
--------------------------- */
#wrap_title {
	background-color: #f2f2f2;
}
#title {
	padding: 70px 0;
	background: url("img/header/title_bg.png") no-repeat left top 10px;
}
#title h1,
#title p.ttl {
	margin: 0;
	font-size: 188%;
	font-weight: bold;
	line-height: 1.2;
}
#title p.eng {
	vertical-align: top;
	margin: 0 0 0.4em;
	font-size: 113%;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	color: #105da0;
	line-height: 1.2;
	text-transform: uppercase;
}
#wrap_title.titlebg {
	position: relative;
	background-size: cover;
	background-position: center;
}
#wrap_title.titlebg::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	background-color: rgba(0,0,0,0.2);
}
#wrap_title.titlebg #title {
	position: relative;
	z-index: 2;
	padding: 190px 0;
	background: none;
}
#wrap_title.titlebg #title h1 {
	color: #ffffff;
	text-align: center;
	text-shadow: 2px 2px 10px #000000;
}
#wrap_title.titlebg #title p.eng {
	color: #ffffff;
	text-align: center;
	text-shadow: 2px 2px 10px #000000;
}
/* pnavi
--------------------------- */
#pnavi {
	padding: 5px 0;
	text-align: right;
	color: #808080;
}
#pnavi span {
	margin: 0 0.5em;
}
/* ==================================================
footer
================================================== */
#wrap_footer {
	padding: 20px 0;
	background: url("img/footer/line.png") repeat-y center top;
	background-color: #f2f2f2;
	border-bottom: 10px solid #0f61a5;
}
#footer {
	display: flex;
}
#finfo {
	width: 50%;
}
#flogo {
	display: inline-block;
	text-align: center;
	margin: 0 0 15px;
}
#flogo img {
	width: 300px;
	height: auto;
}
#fadd {
	padding: 0 0 0 10px;
}
#fadd p {
	margin: 0 0 10px;
}
#fadd span {
	display: inline-block;
	color: #0f61a5;
	font-weight: bold;
	padding: 0;
}
/* fnavi
--------------------------- */
#fnavi {
	display: flex;
	justify-content: center;
	margin-top: 20px;
}
#fnavi ul {
	margin: 0 3em;
	list-style: none;
}
#fnavi li a {
	color: inherit;
	text-decoration: none;
	position: relative;
}
#fnavi li.child a {
	padding: 0 0 0 15px;
}
#fnavi li.child a::before {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 4px;
	height: 4px;
	margin: -3px 0 0 0;
	border-top: solid 2px #0f61a5;
	border-right: solid 2px #0f61a5;
	transform: rotate(45deg);
}
/* pagetop
--------------------------- */
#pagetop {
	position: fixed;
	bottom: 0;
	right: 0;
	z-index: 10;
}
#pagetop a {
	display: block;
	width: 50px;
	height: 50px;
	background-color: #0f61a5;
	opacity: 0.8;
	transition-duration: 0.3s;
	position: relative;
	border: 2px solid #ffffff;
}
#pagetop a::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 12px;
	height: 12px;
	border-top: #fff 2px solid;
	border-left: #fff 2px solid;
	transform: translate(-50%, -20%) rotate(45deg);
}
/* ==================================================
contents
================================================== */
#contents a[target="_blank"]::after {
	margin: 0 5px;
	content: url(img/admin/exlink.png);
	vertical-align: middle;
	line-height: 0.1;
}
#contents a.eximg::after {
	content: none;
}
#contents a.icon_link::after {
	margin: 0 5px;
	content: url(img/admin/link.png);
	vertical-align: middle;
	line-height: 0.1;
}
#contents a.icon_pdf::after,
#contents a[href$=".pdf"]::after {
	margin: 0 5px;
	content: url(img/admin/pdf.png);
	vertical-align: middle;
	line-height: 0.1;
}
#contents a[href$=".xlsx"]::after,
#contents a[href$=".xls"]::after {
	margin: 0 5px;
	content: url(img/admin/xls.png);
	vertical-align: middle;
	line-height: 0.1;
}
#contents a[href$=".docx"]::after,
#contents a[href$=".doc"]::after {
	margin: 0 5px;
	content: url(img/admin/doc.png);
	vertical-align: middle;
	line-height: 0.1;
}
#contents img {
	max-width: 100%;
}
#contents table img {
	max-width: inherit;
}
#contents iframe {
	border: none;
}
#contents #contents_top {
	margin-bottom: 50px;
}
#contents p {
	margin-bottom: 0.8em;
}
#contents p.update {
	margin: -1.6em 0 0.3em;
}
#contents h1 {
	clear: both;
	margin: 0 0 1.5em;
	padding: 10px 20px;
	border-top: 1px solid #000000;
	border-bottom: 1px solid #000000;
	line-height: 1.3;
	font-size: 157%;
	font-weight: bold;
}
#contents h2 {
	clear: both;
	margin: 1.6em 0 1.2em;
	padding: 5px 0 5px 20px;
	border-bottom: 2px solid #105da0;
	line-height: 1.3;
	font-size: 175%;
	font-weight: bold;
	position: relative;
}
#contents h2::before {
	content: "";
	position: absolute;
	left: 10px;
	top: 10px;
	bottom: -15px;
	width: 1px;
	background-color: #000000;
}
#contents h3 {
	padding: 0 0 0 25px;
	margin: 1.5em 0 0.8em;
	line-height: 1.3;
	font-size: 150%;
	font-weight: bold;
	position: relative;
}
#contents h3::before {
	content: "";
	position: absolute;
	left: 0;
	top: 15px;
	width: 15px;
	height: 3px;
	background-color: #0483c5;
}
#contents h4 {
	margin: 1.5em 0 0.8em;
	font-size: 113%;
	font-weight: bold;
	color: #105da0;
}
#contents ul {
	margin: 0 0 0.8em 1.5em;
	list-style: none;
}
#contents ul ul {
	margin: 0 0 0 1em;
}
#contents ul li {
	margin: 0.4em 0;
	position: relative;
}
#contents ul:not([class]) li::before {
	content: "";
	display: block;
	position: absolute;
	left: -1em;
	top: 0.5em;
	width: 0.6em;
	height: 0.6em;
	background-color: #666666;
	border-radius: 50%;
}
#contents ol {
	margin: 0 0 0.8em 2.2em;
	list-style: none;
	counter-reset: cnt;
}
#contents ol ol,
#contents ol ol ol {
	margin: 0 0 0 1em;
	counter-reset: cnt;
}
#contents ol > li,
#contents ol ol > li,
#contents ol ol ol > li {
	margin: 0.4em 0;
	counter-increment: cnt;
	position: relative;
}
#contents ol li:before {
	position: absolute;
	display: block;
	width: 2em;
	left: -2.5em;
	top: 0.2em;
	content: counter(cnt) ".";
	line-height: 1;
	text-align: right;
}
#contents ol ol li:before {
	position: absolute;
	display: block;
	width: 2em;
	left: -2.5em;
	top: 0.2em;
	content: "(" counter(cnt) ") ";
	line-height: 1;
	text-align: right;
}
#contents ol ol ol li:before {
	position: absolute;
	display: block;
	width: 1.2em;
	height: 1.2em;
	left: -2em;
	top: 0.4em;
	content: counter(cnt);
	border: #211613 1px solid;
	border-radius: 50%;
	font-size: 70%;
	line-height: 1.2;
	text-align: center;
}
#contents input[type="submit"],
#contents input[type="button"] {
	margin: 0 5px;
	padding: 12px 60px;
	border-style: none;
	background-color: #323232;
	color: #FFFFFF;
	font-weight: 500;
	cursor: pointer;
	-webkit-appearance: none;
	transition-duration: 0.2s;
}
#contents input[type="text"],
#contents textarea,
#contents select {
	font-size: 100%;
	border: #ddd 1px solid;
	padding: 5px;
	box-sizing: border-box;
	background-color: #fff;
	border-radius: 0;
	color: inherit;
}
/* table
--------------------------- */
#contents table {
	margin: 1.5em 0;
}
#contents table th,
#contents table td {
	padding: 15px 20px;
	border: none;
	border-bottom: 1px solid #999999;
	vertical-align: top;
}
#contents table th {
	text-align: left;
	font-weight: bold;
}
#contents table p,
#contents table ul,
#contents table ol,
#contents table ul li,
#contents table ol li {
	margin-top: 0;
	margin-bottom: 0;
}
/* form_table
--------------------------- */
#contents form.contact {
	padding: 10px 50px;
	background-color: #f8f8f8;
}
#contents table.form_table {
	width: 100%;
}
#contents table.form_table th,
#contents table.form_table td {
	padding: 10px 0;
	border: none;
}
#contents table.form_table th {
	width: 25%;
	padding-right: 1em;
	background: none;
	text-align: right;
	vertical-align: middle;
}
#contents table.form_table th span::before {
	content: "※";
	margin-right: 0.2em;
	color: #ff0000;
}
#contents table.form_table textarea {
	width: 100%;
}
#contents table.form_table input[type="checkbox"],
#contents table.form_table input[type="radio"] {
	margin-right: 5px;
}
#contents table.form_table label {
	margin-right: 30px;
}
/* form_btn
--------------------------- */
#contents .form_btn {
	margin: 30px 0;
	text-align: center;
}
/* backblog
--------------------------- */
#contents div.backblog {
	clear: both;
	padding: 50px 0 0;
}
#contents div.backblog p {
	margin: 0;
	padding: 20px 0 0;
	border-top: #000000 2px solid;
	text-align: center;
}
#contents div.backblog a {
	margin: 0 5px;
	padding: 5px 30px;
	border: 2px solid #000000;
	color: inherit;
	text-decoration: none;
	display: inline-block;
}
/* archive_list
--------------------------- */
#contents ul.archive_list {
	margin: 1.5em 0;
	list-style: none;
}
#contents ul.archive_list li {
	margin: 0;
	padding: 15px 20px;
	box-sizing: border-box;
	border-bottom: #CCCCCC 1px dotted;
	display: flex;
}
#contents ul.archive_list li p.date {
	width: 10em;
	margin: 0;
}
#contents ul.archive_list li p.ttl {
	margin: 0;
	flex: 1;
}
/* link_list
--------------------------- */
#contents ul.link_list {
	margin-left: 3em;
}
#contents ul.link_list li {
	position: relative;
}
#contents ul.link_list li.child {
	margin-left: 1em;
}
#contents ul.link_list li::before {
	content: "";
	width: 4px;
	height: 4px;
	border-top: solid 2px #aaa;
	border-right: solid 2px #aaa;
	display: block;
	position: absolute;
	top: 0.6em;
	left: -1em;
	transform: rotate(45deg);
}
/* child_list
--------------------------- */
#contents ul.child_list {
	margin: 1.5em 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 65px;
}
#contents ul.child_list li {
	width: calc((100% - 1 * 65px) / 2);
	margin: 0;
	box-sizing: border-box;
}
#contents ul.child_list li a {
	display: flex;
	align-items: center;
	background: url("img/contents/link_icon.png") no-repeat right 30px center;
	background-size: auto 11px;
	text-decoration: none;
	color: #323232;
	padding: 40px 90px 40px 20px;
	border-top: #000000 1px solid;
	border-bottom: #000000 1px solid;
}
#contents ul.child_list li p.ttl {
	margin: 0 1em 0 0;
	font-size: 125%;
	font-weight: bold;
}
#contents ul.child_list li p.eng {
	margin: 0;
	font-weight: bold;
	color: #105da0;
	text-transform: uppercase;
}
/* ==================================================
style class
================================================== */
/* layout_table
--------------------------- */
#contents table.layout_table {
	width: 100%;
	margin: 0;
}
#contents table.layout_table > tbody > tr > td {
	padding: 0 20px;
	background: none;
	border: none;
	vertical-align: top;
}
#contents table.layout_table > tbody > tr > td:first-child {
	padding-left: 0;
}
#contents table.layout_table > tbody > tr > td:last-child {
	padding-right: 0;
}
#contents table.layout_table td > h2:first-child,
#contents table.layout_table td > h3:first-child,
#contents table.layout_table td > h4:first-child,
#contents table.layout_table td > table:first-child {
	margin-top: 1em;
}
#contents table.layout_table > tbody > tr > td > p,
#contents table.layout_table > tbody > tr > td > ul,
#contents table.layout_table > tbody > tr > td > ol {
	margin-bottom: 0.8em;
}
#contents table.layout_table > tbody > tr > td > ul li,
#contents table.layout_table > tbody > tr > td > ol li {
	margin-top: 0.4em;
	margin-bottom: 0.4em;
}
/* layout_table2
--------------------------- */
#contents table.layout_table2 > tbody > tr > td {
	padding: 5px;
	border: none;
	vertical-align: top;
	line-height: 1.3;
}
#contents table.layout_table2 > tbody > tr > td:first-child {
	padding-left: 0;
}
#contents table.layout_table2 > tbody > tr > td:last-child {
	padding-right: 0;
}
/* border_box
--------------------------- */
#contents .border_box {
	clear: both;
	margin: 1.5em 0;
	padding: 20px 30px;
	border: #105da0 4px solid;
}
/* fill_box
--------------------------- */
#contents p.fill_box {
	clear: both;
	margin: 1.5em 0;
	padding: 20px 30px;
	background-color: #edf4f6;
}
#contents table.fill_box {
	clear: both;
	width: 100%;
	margin: 1.5em 0;
	border-collapse: separate;
	border-spacing: 20px;
}
#contents table.fill_box td {
	padding: 20px 30px;
	background-color: #edf4f6;
	border: none;
	vertical-align: top;
}
#contents table.fill_box td h2:first-child,
#contents table.fill_box td h3:first-child,
#contents table.fill_box td h4:first-child,
#contents table.fill_box td table:first-child {
	margin-top: 0;
}
#contents table.fill_box > tbody > tr > td > p,
#contents table.fill_box > tbody > tr > td > ul,
#contents table.fill_box > tbody > tr > td > ol {
	margin-bottom: 0.8em;
}
#contents table.fill_box > tbody > tr > td > ul li,
#contents table.fill_box > tbody > tr > td > ol li {
	margin-top: 0.4em;
	margin-bottom: 0.4em;
}
/* link_btn
--------------------------- */
#contents a.link_btn {
	display: inline-block;
	margin: 10px;
	padding: 10px 90px 10px 60px;
	border: 1px solid #888;
	color: inherit;
	font-weight: 500;
	text-decoration: none;
	background: url("img/contents/link_icon.png") no-repeat right 15px center;
	background-size: auto 10px;
}
#contents a.link_btn:first-of-type {
	margin-left: 0;
}
#contents a.link_btn:last-of-type {
	margin-right: 0;
}
/* h3_number
--------------------------- */
#contents h2 {
	counter-reset: h3num;
}
#contents h3.h3_number {
	counter-increment: h3num;
	position: relative;
	font-size: 163%;
	padding: 8px 0 8px 45px;
	margin: 1.3em 0 0.6em;
	border-bottom: 1px solid #808080;
}
#contents h3.h3_number::before {
	content: counter(h3num);
	display: block;
	width: 1.8em;
	top: 8px;
	bottom: auto;
	height: auto;
	line-height: 1;
	text-align: center;
	padding: 8px 2px;
	color: #ffffff;
	font-size: 67%;
}
/* ==================================================
top
================================================== */
#top_main {
	background: url("img/top/main_bg.png") no-repeat center top 730px;
}
/* header
--------------------------- */
#header.toppage {
	position: absolute;
	z-index: 10;
}
/* top_slide
--------------------------- */
#top_slide {
	background-color: #ffffff;
	overflow: hidden;
}
#top_slide li {
	position: relative;
}
#top_slide li a {
	text-decoration: none;
	color: #ffffff;
}
#top_slide p.image {
	width: 100%;
	aspect-ratio: 1920 / 940;
	min-height: 730px;
}
#top_slide p.image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#top_slide p.txt {
	position: absolute;
	z-index: 2;
	bottom: 4%;
	right: 5%;
	font-size: 125%;
	font-weight: 500;
	color: #ffffff;
	text-shadow: 3px 3px 6px rgba(0, 0, 0, 0.7);
	line-height: 1.2;
}
#top_slide p.catch {
	position: absolute;
	z-index: 2;
	top: 0;
	bottom: 0;
	left: 8%;
}
#top_slide p.catch span {
	display: none;
}
#top_slide p.link {
	position: absolute;
	z-index: 3;
	bottom: 7%;
	left: 8%;
}
#top_slide p.link a {
	display: block;
	font-size: 157%;
	font-weight: bold;
	text-shadow: 3px 3px 6px rgba(0, 0, 0, 0.7);
	line-height: 1.2;
	padding: 30px 200px 30px 30px;
	background: url("img/top/link_arrow.png") no-repeat right 40px center;
	background-size: 115px auto;
	border-bottom: 3px solid rgba(16, 93, 160, 0.0);
}
#top_slide .swiper-slide-active p.image img,
#top_slide .swiper-slide-prev p.image img {
	animation: zoom-in 8s linear;
}
@keyframes zoom-in {
	100% {
		transform: scale(1.2);
	}
}
/* top_news
--------------------------- */
#wrap_top_news {
	position: relative;
}
#top_news {
	padding: 50px 0;
	position: relative;
	z-index: 2;
}
#top_news div.title {
	text-align: center;
	line-height: 1.2;
	margin: 0 0 30px;
}
#top_news div.title p.eng {
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	line-height: 1.2;
	font-size: 113%;
	color: #0483c5;
	margin: 0 0 0.4em;
}
#top_news div.title h2 {
	font-size: 188%;
	font-weight: bold;
}
#top_news ul {
	margin: 0;
	list-style: none;
}
#top_news li {
	padding: 10px 20px;
	box-sizing: border-box;
	border-bottom: #000000 1px solid;
	display: flex;
}
#top_news li p.date {
	width: 10em;
}
#top_news li p.ttl {
	flex: 1;
}
#top_news p.more {
	position: absolute;
	z-index: 2;
	right: 0;
	top: 70px;
}
#top_news p.more a {
	display: block;
	line-height: 1.2;
	font-size: 113%;
	font-weight: 500;
	padding: 10px 115px 10px 0;
	color: #323232;
	background: url("img/top/link_arrow2.png") no-repeat right 15px center;
	background-size: 77px auto;
	text-decoration: none;
	border-bottom: 2px solid rgba(4, 131, 197, 0.00);
}
/* top_works
--------------------------- */
#top_works {
	padding: 0 0 70px;
}
#top_works div.title {
	text-align: center;
	line-height: 1.2;
	margin: 0 0 30px;
}
#top_works div.title p.eng {
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	line-height: 1.2;
	font-size: 113%;
	color: #0483c5;
	margin: 0 0 0.4em;
}
#top_works div.title h2 {
	font-size: 188%;
	font-weight: bold;
}
#top_works ul {
	position: relative;
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	gap: 0 0.5%;
	list-style: none;
	width: 100%;
	padding: 0 0 40px;
	background-color: #ffffff;
}
#top_works ul li {
	width: 33%;
}
#top_works ul li a {
	text-decoration: none;
}
#top_works ul li p.img {
	aspect-ratio: 5/3;
	overflow: hidden;
}
#top_works ul li p.img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition-duration: 0.4s;
}
#top_works ul li div.text {
	padding: 15px 10px;
	min-height: 125px;
	box-sizing: border-box;
}
#top_works ul li p.cat {
	display: inline-block;
	line-height: 1.2;
	color: #ffffff;
	background-color: #0f61a5;
	padding: 2px 10px;
}
#top_works ul li p.day {
	line-height: 1.2;
	text-align: right;
	margin: -1.5em 0 0.6em;
	color: #808080;
	transition-duration: 0.2s;
}
#top_works ul li p.ttl {
	color: #323232;
	font-weight: 500;
	line-height: 1.2;
	margin: 0 0 0.4em;
	transition-duration: 0.2s;
}
#top_works ul li p.location {
	color: #808080;
	line-height: 1.2;
	transition-duration: 0.2s;
}
#top_works p.more {
	text-align: center;
}
#top_works p.more a {
	display: inline-block;
	border: 1px solid #000000;
	line-height: 1.2;
	padding: 20px 235px;
	background: url("img/top/link_arrow2.png") no-repeat right 30px center #ffffff;
	background-size: 77px auto;
	box-sizing: border-box;
	text-decoration: none;
	color: #323232;
	font-size: 113%;
	font-weight: 500;
	box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.5);
}
/* top_company top_recruit
--------------------------- */
#wrap_top_company,
#wrap_top_recruit {
	max-width: 1920px;
	margin: 0 auto;
	margin-bottom: 2px;
	transition-duration: 0.4s;
}
#wrap_top_company {
	background: url("img/top/company_line.png") no-repeat center center / 1920px auto, url("img/top/combg.jpg") no-repeat center center / 1920px auto;
}
#wrap_top_recruit {
	background: url("img/top/recruit_line.png") no-repeat center center / 1920px auto, url("img/top/recbg.jpg") no-repeat center center / 1920px auto;
}
#top_company,
#top_recruit {
	height: 520px;
	padding: 90px 160px 150px;
	box-sizing: border-box;
	color: #ffffff;
	text-shadow: 2px 2px 5px rgba(0, 0, 0, 0.5);
	position: relative;
}
#top_company {
	background: url("img/top/company_ttl_line.png") no-repeat left top;
	padding: 90px 160px 170px;
}
#top_company div.title,
#top_recruit div.title {
	display: flex;
	align-items: baseline;
	margin: 0 0 40px;
}
#top_company div.title h2,
#top_recruit div.title h2 {
	order: 1;
	line-height: 1.2;
	font-size: 219%;
	margin-right: 1em;
}
#top_company div.title p.eng,
#top_recruit div.title p.eng {
	order: 2;
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	line-height: 1.2;
	font-size: 113%;
}
#top_company p.lead,
#top_recruit p.lead {
	line-height: 1.7;
	font-size: 113%;
}
#top_company p.more,
#top_recruit p.more {
	position: absolute;
	left: 130px;
	bottom: 112px;
	line-height: 1.2;
}
#top_recruit p.more {
	bottom: 86px;
}
#wrap_top_company a,
#wrap_top_recruit a {
	display: block;
	padding: 15px 195px 15px 30px;
	background: url("img/top/link_arrow.png") no-repeat right 30px center;
	background-size: 115px auto;
	text-decoration: none;
	color: #ffffff;
	font-size: 125%;
	font-weight: 500;
	border-bottom: 2px solid rgba(16, 93, 160, 0.0);
}
/* ==================================================
works
================================================== */
/* works_search
--------------------------- */
#contents div.works_search {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin: 0 0 30px;
}
#contents div.works_search p {
	margin: 0;
}
#contents div.works_search p.ttl {
	font-weight: bold;
	margin: 0 5px 0 0;
}
#contents div.works_search p.cat {
	margin: 0 20px 0 0;
}
#contents div.works_search p.cat select {
	width: 300px;
	padding: 10px;
	border-color: #000000;
}
#contents div.works_search p.text {
	margin: 0 20px 0 0;
}
#contents div.works_search p.text input {
	width: 450px;
	padding: 10px;
	border-color: #000000;
}
#contents div.works_search p.submit input {
	margin: 0;
	padding: 11px 60px;
}
/* works_list
--------------------------- */
#contents ul.works_list {
	display: flex;
	flex-wrap: wrap;
	gap: 0 0.5%;
	list-style: none;
	width: 100%;
	padding: 0 0 40px;
	margin: 1.5em 0;
	background-color: #ffffff;
}
#contents ul.works_list li {
	width: 33%;
	margin: 0;
}
#contents ul.works_list li a {
	text-decoration: none;
}
#contents ul.works_list li p.img {
	aspect-ratio: 5/3;
	overflow: hidden;
	margin: 0;
}
#contents ul.works_list li p.img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition-duration: 0.4s;
}
#contents ul.works_list li div.text {
	padding: 15px 10px;
	min-height: 125px;
	box-sizing: border-box;
}
#contents ul.works_list li p.cat {
	display: inline-block;
	line-height: 1.2;
	color: #ffffff;
	background-color: #0f61a5;
	padding: 2px 10px;
	margin: 0;
}
#contents ul.works_list li p.day {
	line-height: 1.2;
	text-align: right;
	margin: -1.5em 0 0.6em;
	color: #808080;
	transition-duration: 0.2s;
}
#contents ul.works_list li p.ttl {
	color: #323232;
	font-weight: 500;
	line-height: 1.2;
	margin: 0 0 0.4em;
	transition-duration: 0.2s;
}
#contents ul.works_list li p.location {
	color: #808080;
	line-height: 1.2;
	transition-duration: 0.2s;
}
/* works_ttl
--------------------------- */
#contents h1#works_ttl {
	border: none;
	background: url("img/contents/works_ttl.png") no-repeat center top;
	padding: 35px 0 0;
	margin-top: -35px;
	text-align: center;
}
/* image
--------------------------- */
#works_img {
	margin: 0 0 70px;
	position: relative;
}
#works_img div.main {
	width: 1100px;
	margin: 0 auto 10px;
	overflow: hidden;
}
#works_img div.main ul {
	margin: 0;
}
#works_img div.main ul li {
	margin: 0;
}
#works_img div.main ul li p.image {
	display: flex;
	justify-content: center;
	width: 100%;
	height: 733px;
	overflow: hidden;
	margin: 0;
}
#works_img div.main ul li img {
	width: auto;
	height: 100%;
	max-width: none;
}
#works_img #works_img_prev,
#works_img #works_img_next {
	position: absolute;
	z-index: 5;
	top: 336px;
	right: 0;
	width: 60px;
	height: 60px;
	background: #000000;
	opacity: 0.3;
	cursor: pointer;
	margin: 0;
	transition-duration: 0.2s;
}
#works_img #works_img_prev {
	left: 0;
}
#works_img #works_img_prev.swiper-button-disabled,
#works_img #works_img_next.swiper-button-disabled {
	display: none;
}
#works_img #works_img_prev::after,
#works_img #works_img_next::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	width: 15px;
	height: 15px;
	border-top: #fff 3px solid;
	border-left: #fff 3px solid;
	transform: translate(-70%, -50%) rotate(135deg);
}
#works_img #works_img_prev::after {
	transform: translate(-30%, -50%) rotate(315deg);
}
#works_img div.navi {
	text-align: center;
}
#works_img div.navi ul {
	display: inline-block;
	margin: 0;
	list-style: none;
	text-align: left;
}
#works_img div.navi ul li {
	position: relative;
	display: inline-block;
	cursor: pointer;
	margin: 3px;
}
#works_img div.navi ul li::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(255,255,255,0.6);
	transition-duration: 0.2s;
	border-radius: 0;
}
#works_img div.navi ul li.active::before,
#works_img div.navi ul li:hover::before {
	background: none;
}
#works_img div.navi ul li p.image {
	width: 130px;
	height: 85px;
	margin: 0;
}
#works_img div.navi ul li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
/* contents
--------------------------- */
#contents p.works_text {
	margin-bottom: 3em;
}
#contents table.works_table {
	width: 100%;
}
#contents table.works_table th {
	width: 20%;
}
/* ==================================================
recruit
================================================== */
div.recruit #wrap_title {
	position: relative;
	text-align: center;
	background-size: cover;
	background-position: center top;
	margin: 0 0 90px;
}
div.recruit #title {
	position: relative;
	background: none;
	padding: 60px 0 310px;
	height: 750px;
	box-sizing: border-box;
}
div.recruit #title p.eng {
	font-size: 125%;
}
div.recruit #title h1 {
	font-size: 250%;
}
div.recruit #text {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -25px;
	width: 810px;
	background-color: rgba(4,131,197,0.5);
	box-sizing: border-box;
	line-height: 1.7;
	padding: 35px 20px 20px;
}
div.recruit #text h2 {
	color: #ffffff;
	font-size: 188%;
	font-weight: 600;
	text-shadow: 2px 2px 5px #000000;
	margin: 0 0 0.7em;
}
div.recruit #text p {
	text-align: left;
	color: #ffffff;
	font-size: 125%;
	font-weight: 500;
	text-shadow: 2px 2px 5px #000000;
}
div.recruit div.title {
	background: url("img/contents/recruit_ttl_line.png") no-repeat center bottom;
	text-align: center;
	line-height: 1.2;
	margin: 0 0 30px;
	padding: 0 0 15px;
}
div.recruit div.title p.eng {
	font-family: "Noto Serif JP", serif;
	font-weight: 700;
	line-height: 1.2;
	font-size: 100%;
	color: #0483c5;
	margin: 0 0 5px;
}
div.recruit div.title h2 {
	font-size: 188%;
	font-weight: bold;
}
#recruit_message {
	display: flex;
	justify-content: space-between;
	margin-bottom: 65px;
}
#recruit_message div.title {
	display: inline-block;
	text-align: left;
	background-position: left bottom;
}
#recruit_message div.text {
	width: 610px;
}
#recruit_message p.txt {
	line-height: 1.7;
	font-weight: 500;
	margin: 0 0 1em;
}
#recruit_message p.image {
	width: 506px;
}
#wrap_recruit_design {
	background: url("img/contents/recruit_design_bg.jpg") no-repeat center bottom 30px #ebf9ff;
	padding: 60px 0 360px;
}
#recruit_design {
	text-align: center;
}
#recruit_design p.txt {
	display: inline-block;
	text-align: left;
	line-height: 1.7;
	font-weight: 500;
}
#recruit_work {
	padding: 60px 0;
}
#recruit_work div.work_box {
	display: flex;
	justify-content: space-between;
}
#recruit_work div.work_box > div {
	width: 380px;
}
#recruit_work div.work_box h3 {
	border-left: 6px solid #0483c5;
	padding-left: 8px;
	font-size: 138%;
	margin: 0 0 0.5em;
}
#recruit_work div.work_box p.img {
	margin: 0 0 10px;
}
#recruit_voice div.voice_box {
	position: relative;
	margin: 50px 0 75px;
}
#recruit_voice div.voice_box div.image {
	margin: 0 0 35px;
}
#recruit_voice div.voice_box div.image div.txt {
	position: absolute;
	left: 0;
	top: 40px;
	background: url("img/contents/recruit_voice_ttl_bg.png") no-repeat left top;
	padding: 85px 50px 50px 80px;
	min-width: 540px;
	box-sizing: border-box;
}
#recruit_voice div.voice_box div.image h3 {
	color: #ffffff;
	font-size: 175%;
	font-weight: 500;
	text-shadow: 2px 2px 5px #000000;
	margin: 0 0 1em;
}
#recruit_voice div.voice_box div.image p.ttl {
	color: #105da0;
	font-size: 113%;
	font-weight: bold;
}
#recruit_voice div.voice_box div.image p.img1 {
	text-align: right;
}
#recruit_voice div.voice_box div.faq {
	display: flex;
	justify-content: space-between;
	flex-flow: row-reverse;
}
#recruit_voice div.voice_box div.faq div.img {
	width: 400px;
}
#recruit_voice div.voice_box div.faq p.img2 {
	margin: 0 0 10px;
}
#recruit_voice div.voice_box div.faq div.txt {
	width: 725px;
}
#contents p.voice_q,
#recruit_voice p.voice_q {
	position: relative;
	font-size: 113%;
	font-weight: bold;
	padding: 3px 0 3px 35px;
	margin: 1.0em 0 0.5em;
}
#contents p.voice_q::before,
#recruit_voice p.voice_q::before {
	content: "Q";
	position: absolute;
	left: 0;
	top: 2px;
	width: 1.8em;
	bottom: auto;
	height: auto;
	line-height: 1;
	text-align: center;
	padding: 8px 2px;
	color: #ffffff;
	background-color: #0483c5;
	font-size: 67%;
}
/* ==================================================
align
================================================== */
.alignleft {
	float: left;
}
.alignright {
	float: right;
}
img.alignleft {
	margin: 0 30px 20px 0;
}
img.alignright {
	margin: 0 0 20px 30px;
}
img.aligncenter {
	display: block;
	margin: 0 auto;
}
.clear {
	clear: both;
}
/* ==================================================
wp-caption
================================================== */
#contents .wp-caption-dd,
#contents p.wp-caption-text {
	margin: 0.2em 0;
	font-size: 90%;
	line-height: 1.3;
}
/* ==================================================
wp-pagenavi
================================================== */
.wp-pagenavi {
	clear: both;
	margin: 50px 0 0;
	text-align: center;
}
.wp-pagenavi a,
.wp-pagenavi span {
	margin: 0 2px;
	padding: 5px 15px;
	border: 1px solid #105da0;
	color: inherit;
	display: inline-block;
	text-decoration: none;
}
.wp-pagenavi span.current {
	background-color: #105da0;
	color: #ffffff;
}
/* ==================================================
reCAPTCHA
================================================== */
.grecaptcha-badge {
	visibility: hidden;
}
/* ==================================================
mceContentBody
================================================== */
#contents.mceContentBody {
	width: 1180px !important;
	max-width: none !important;
}
body.mceContentBody {
	overflow: visible !important;
	background-image: none !important;
	background-color: #FFFFFF !important;
}
body.mceContentBody div {
	border: #80FF80 1px dashed;
}
body.mceContentBody p {
	border: #80FFFF 1px dashed;
}
body.mceContentBody th,
body.mceContentBody td {
	font-size: 100%;
}
body.mceContentBody table.layout_table > tbody > tr > th,
body.mceContentBody table.layout_table > tbody > tr > td {
	border: #C0C0C0 1px dashed !important;
}
body.mceContentBody .mce-resize-bar {
	display: none !important;
}
/* ==================================================
float_clear
================================================== */
#contents,
.float_clear {
	display: flow-root;
}
/* ==================================================
hover
================================================== */
@media screen and (min-width : 480px) {
	a:hover,
	a:active {
		color: #1493d5;
	}
	#gnavi li a:hover {
		color: #105da0;
		background-size: auto 2px;
	}
	#header.toppage #gnavi li a:hover {
		color: #105da0;
		background-color: #ffffff;
		text-shadow: none;
	}
	#gnavi li.contact a:hover {
		color: #105da0;
		border: 1px solid #105da0;
		background: none;
		background-color: #ffffff;
	}
	#header.toppage #gnavi li.contact a:hover {
		border-color: #ffffff;
		background-color: #ffffff;
	}
	#fnavi li a:hover {
		text-decoration: underline;
	}
	#top_news p.more a:hover {
		color: #323232;
		background: url("img/top/link_arrow2.png") no-repeat right center;
		background-size: 77px auto;
		border-bottom: 2px solid rgba(4, 131, 197, 1.00);
	}
	#contents ul.works_list li a:hover p.img img,
	#top_works ul li a:hover p.img img {
		transform: scale(1.05);
	}
	#contents ul.works_list li a:hover p.ttl,
	#top_works ul li a:hover p.ttl {
		color: #105da0;
	}
	#top_works p.more a:hover {
		padding: 20px 270px;
		color: #105da0;
		border-color: #105da0;
		background-image: url("img/top/link_arrow3.png");
		box-shadow: 0 0 0 1px inset #105da0;
	}
	#pagetop a:hover {
		opacity: 1;
	}
	#top_slide p.link a:hover {
		padding-right: 280px;
		border-bottom: 3px solid rgba(4, 131, 197, 1.00);
	}
	#wrap_top_company:has(#top_company p.more a:hover) {
		background: url("img/top/company_line.png") no-repeat center center / 1920px auto, url("img/top/combg.jpg") no-repeat center center / 1950px auto;
	}
	#wrap_top_recruit:has(#top_recruit p.more a:hover) {
		background: url("img/top/recruit_line.png") no-repeat center center / 1920px auto, url("img/top/recbg.jpg") no-repeat center center / 1950px auto;
	}
	#top_company p.more a:hover,
	#top_recruit p.more a:hover {
		padding-right: 225px;
		border-bottom: 2px solid rgba(4, 131, 197, 1.00);
	}
	#contents ul.child_list li a:hover {
		background-position: right 15px center;
		box-shadow: 0 -2px 0 0 inset #105da0;
		border-bottom-color: #105da0;
	}
	#contents input[type="submit"]:hover,
	#contents input[type="button"]:hover {
		background-color: #105da0;
	}
	#contents div.backblog a:hover,
	#contents a.link_btn:hover,
	.wp-pagenavi a:hover {
		background-color: #105da0;
		color: #ffffff;
		border-color: #105da0;
	}
	#contents a.link_btn:hover {
		background: url("img/contents/link_icon_on.png") no-repeat right 10px center #105da0;
		background-size: auto 10px;
		border-color: #105da0;
	}
	#works_img #works_img_prev:hover,
	#works_img #works_img_next:hover {
		background-color: #0f61a5;
		opacity: 0.5;
	}
}