/* 
▼ basic.cssにて宣言
:root{
	--main-color:#1e2900;
	--main-color-2:#3b4f0040;
}
*/

/*---------------------------------------------------------------------------
  TITLE
---------------------------------------------------------------------------*/
.page_title {
	padding: 70px 0 70px 4.5%;
	max-width: calc(100% - ((100% - 1220px) / 2));
}
.page_title h2 { color:#929c86; font-family: "Noto Serif JP", sans-serif; }
.page_title h2 b {
	display: block;
	font-size: 400%;
	font-weight: 600;
	line-height: 100%;
}
.page_title h2 small {
	display: block;
	font-size: 250%;
	font-weight: 600;
	line-height: 100%;
	margin-top: 30px;
	position: relative;
}
.page_title h2 small span { display: inline-block; background: #FFF; padding-right: 12px; }
.page_title h2 small::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	z-index: -1;
	width: 100%;
	height: 4px;
	background:#e7f3d7;
	transform: translateY(-50%);
}




/*====================================================================================================

  SUBPAGE: COMMON

====================================================================================================*/
.subpage img { width: 100%; }
.subpage .come { font-size: 125%; line-height: 190%; }

/* SUB MAIN INFO */
.sb_main {
	display: flex;
	column-gap: 40px;
	flex-direction: row-reverse;
}
.sb_main .photo { max-width:50%; }

/* TABLE */
.list_box { margin-top: 50px; }
.list_box table {
	width: 100%;
	border-top: 1px solid #A5A5A5;
	border-right: 1px solid #A5A5A5;
}
.list_box table tr th {
	width: 24.6%;
	text-align: left;
	font-size: 112.5%;
	padding: 25px 20px;
	vertical-align: text-top;
	border-left: 1px solid #A5A5A5;
	border-bottom: 1px solid #A5A5A5;
	background: rgba(67, 131, 196, 0.15);
}
.list_box table tr td {
	width: 75.4%;
	font-size: 112.5%;
	padding: 25px 0 25px 20px;
	border-left: 1px solid #A5A5A5;
	border-bottom: 1px solid #A5A5A5;
}

/*====================================================================================================

  SUBPAGE: ABOUT

====================================================================================================*/
.about {}

.profile { margin-block: 160px 110px; }

.access { margin-block: 110px 135px; }
.access .map { margin-top: 60px; }
.access .map iframe { width: 100%; height: 595px; }


/*====================================================================================================

  SUBPAGE: SERVICE

====================================================================================================*/
.service {}
.service .come { margin-block: 50px 170px; }


/*====================================================================================================

  SUBPAGE: WORKS

====================================================================================================*/
.works {}
.works .come { margin-block: 60px 85px; }

.work_list {
	display: flex;
	row-gap: 65px;
	flex-wrap: wrap;
	margin-bottom: 135px;
	justify-content: space-between;
}
.work_list ul { max-width: 391px; }
.work_list .caption { font-size: 125%; margin-top: 15px; }



/*====================================================================================================

  SUBPAGE: RECRUIT

====================================================================================================*/
.recruit {}
.type { margin-block: 160px 180px; }
.type .catch { font-size: 187.5%; text-align: center; margin-block: 60px 15px; }
.type .come { text-align: center; }
.type .list_box { margin-top: 160px; }






/*====================================================================================================

  SUBPAGE

====================================================================================================*/

.subpage { margin: auto; padding: 40px 0 80px; max-width: 1000px;}
.subpage:after { /*float_clear*/ display:block; clear:both; content:"";}

/*---------------------------------------------------------------------------
  KAIGYOU
---------------------------------------------------------------------------*/

.subpage p.indention {
	clear:both;
	margin: 0 2%;
	height:40px;
	text-indent: -9999px;
	background:none;
}


/*---------------------------------------------------------------------------
  MIDASHI
---------------------------------------------------------------------------*/

.subpage h3 {
	clear:both;
	margin:150px auto 45px;
	font-family:"Noto Serif JP";
	font-size:275%;
	font-weight:600;
	line-height:100%;
	color:var(--main-color);
	text-align:center;
	position:relative;
}
.subpage h4 {
	clear:both;
	margin:0 auto 16px;
	font-size:187.5%;
	font-weight:500;
	line-height:1.4;
	text-align:center;
}
.subpage h4.mid {
	font-size:225%;
}
.subpage > :is(h3,h4):first-child { margin-top:0!important;}

/*---------------------------------------------------------------------------
  CATCH COPY
---------------------------------------------------------------------------*/

.subpage .catch {
	clear:both;
	margin:20px 2%;
	font-weight:bold;
	font-size: 180%;
	line-height:120%;
}


/*---------------------------------------------------------------------------
  COMMENT
---------------------------------------------------------------------------*/

.subpage .comment1 {
	font-size:112.5%;
	clear:both;
	margin:0 2% 20px;
	text-align:justify;
}
.subpage .comment2 {
	clear:both;
	font-size:112.5%;
	margin:0 2% 20px;
	padding: 2%;
	border: 1px solid #aaa;
	background:#F4F4F4;
	text-align:justify;
}
.subpage .comment3 {
	clear:both;
	font-size:112.5%;
	margin:0 2% 20px;
	padding: 2%;
	color: #FF4646;
	border: 1px solid #FF7575;
	background:#FFEAEA;
	text-align:justify;
}


/*---------------------------------------------------------------------------
  HYOU
---------------------------------------------------------------------------*/

.subpage table.hyou {
	clear:both;
	margin:10px auto;
	max-width:960px;
	font-size:112.5%;
	width:100%;
	border-collapse:collapse;
	border-top:solid 1px #A5A5A5;
	border-left:solid 1px #A5A5A5;
}
.subpage table.hyou + table.hyou { border-top:none;}
.subpage table.hyou th,
.subpage table.hyou td { border-bottom:solid 1px #A5A5A5; border-right:solid 1px #A5A5A5; padding:28px 22px;}
.subpage table.hyou th {
	background:var(--main-color-2);
	font-weight:bold;
	vertical-align:top;
	text-align:left;
}
.subpage table.hyou td { padding:20px; }
.subpage table.hyou td.sm_mid {
	display:none;
	color:var(--main-color-deep);
	font-weight:bold;
}

/* 2RETU */
.subpage table.hyou2 { margin:0 auto; }
.subpage table.hyou2 th { width:25%; }
.subpage table.hyou2 td { width:75%; }
.subpage table.hyou2 td table {
	border-collapse:collapse;
	display:block;
	max-height:300px;
	overflow:auto;
}
.subpage table.hyou2 td table th,
.subpage table.hyou2 td table td { width:auto;}

/* 3RETU */
.subpage table.hyou3 { margin:0 2%;}
.subpage table.hyou3 th,
.subpage table.hyou3 td { width:33%; }

/* 4RETU */
.subpage table.hyou4 { margin:0 2%;}
.subpage table.hyou4 th,
.subpage table.hyou4 td { width:25%; }

/* 5RETU */
.subpage table.hyou5 { margin:0 2%;}
.subpage table.hyou5 th,
.subpage table.hyou5 td { width:20%;}

/* FREE */
.subpage .pc_table { display:block;}
.subpage .sm_table { display:none;}
.subpage .pc_table table,
.subpage .sm_table table {
	clear:both;
	margin:10px 2%;
	width:96%;
	border-collapse:collapse;
}
.subpage .pc_table table td,
.subpage .sm_table table td {
	padding:5px 10px;
	background:#FFF;
}
.subpage .pc_table thead td,
.subpage .sm_table thead td { background:#EEE;}

/* FIX */
.subpage .fix_table {}
.subpage .fix_table table {
	clear:both;
	margin:10px 2%;
	width:96%;
	border-collapse:collapse;
}
.subpage .fix_table table th,
.subpage .fix_table table td {
	padding:5px 10px;
}
.subpage .fix_table table th {
	background:#EEE;
	font-weight:bold;
	text-align:center;
}
.subpage .fix_table table td { background:#FFF;}

/*---------------------------------------------------------------------------
  LIST
---------------------------------------------------------------------------*/

.subpage ul.list-ul {
	clear:both;
	margin:0 2%;
	padding:5px 0;
}
.subpage ul.list-ul li {
	padding: 0 0 0 20px;
	position:relative;
}
.subpage ul.list-ul li:before{
	content: "";
    display: block;
    position: absolute;
    width: 0.5rem;
    aspect-ratio:1/1;
    background:var(--main-color);
    border-radius: 50%;
    top: 50%;
    left: 5px;
    translate: 0 -50%;
}


/*---------------------------------------------------------------------------
  LINK
---------------------------------------------------------------------------*/

.subpage .link {
	clear:both;
	margin:0 2%;
	padding: 0 0 10px;
	text-indent: 25px;
	/* background:url(../image/link_arrow.png) no-repeat left 5px; */
	position:relative;
}
.subpage .link:before{
	content:">";
	position:absolute;
	display:block;
	font-weight:700;
	color:var(--main-color);
	left:-1rem;
}
.subpage .file {
	clear:both;
	margin:0 2%;
	padding: 0 0 10px;
}
.subpage .file img { padding-right:10px;}

/* LINK PLURALï¿½@*************************/
/* LINK BOX2 */ .subpage .link2 { clear:none; float:left; width:46%;}
/* LINK BOX3 */ .subpage .link3 { clear:none; float:left; width:29.3%;}
/* LINK BOX4 */ .subpage .link4 { clear:none; float:left; width:21%;}

/* FILE PLURALï¿½@*************************/
/* FILE BOX2 */ .subpage .file2 { clear:none; float:left; width:46%;}
/* FILE BOX3 */ .subpage .file3 { clear:none; float:left; width:29.3%;}
/* FILE BOX4 */ .subpage .file4 { clear:none; float:left; width:21%;}


/*---------------------------------------------------------------------------
  EMBEDDED
---------------------------------------------------------------------------*/

.subpage .embedded {
  position:relative;
	clear:both;
	margin: 0 2%;
	padding:0 0 20px;
}
.subpage .embedded iframe { width: 100%;}


/*---------------------------------------------------------------------------
  PHOTO
---------------------------------------------------------------------------*/

.subpage .photo-l {	float:left;}
.subpage .photo-r {	float:right;}
.subpage .photo-c { clear:both; text-align:center;}
.subpage .photo-l img { padding:0 20px 0 0;}
.subpage .photo-r img { padding:0 0 0 20px;}
.subpage .photo-c img { padding:0 0 10px;}
.subpage .photo-l p,
.subpage .photo-r p,
.subpage .photo-c p { padding: 0 0 5px;}
.subpage .caption { font-size:80%; text-align:center;}

/* PHOTO BOXï¿½@*************************/
.subpage ul.photo_box { float:left; margin:2%;}
.subpage ul.photo_box li {}
.subpage ul.photo_box li.photo { margin:0 0 5px;}
.subpage ul.photo_box li.cap {}
.subpage ul.photo_box li.youtube { position: relative;}
.subpage ul.photo_box li.youtube iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}
/* PHOTO BOX1 */ .subpage ul.g1 {width:96%x; float:none; }
/* PHOTO BOX2 */ .subpage ul.g2 {width:46%;}
/* PHOTO BOX3 */ .subpage ul.g3 {width:29.3%;}
/* PHOTO BOX4 */ .subpage ul.g4 {width:21%;}
/* PHOTO BOX5 */ .subpage ul.g5 {width:16%;}
.subpage ul.g1 img { max-width:960px; height:auto;}
.subpage ul.g2 img { max-width:460px; height:auto;}
.subpage ul.g3 img { max-width:293px; height:auto;}
.subpage ul.g4 img { max-width:210px; height:auto;}
.subpage ul.g5 img { max-width:160px; height:auto;}


/*---------------------------------------------------------------------------
  BOX
---------------------------------------------------------------------------*/

.subpage .box1 h4, .subpage .box2 h4 {
	clear:none;
	border:none;
	padding:0;
}

/* BOX1 */
.subpage .box1 {
	clear:both;
	margin:20px 2%;
	width:96%;
}
.subpage .box1 .photo-c img {max-width:960px; height:auto;}
.subpage .box1 .photo-l img {max-width:460px; height:auto;}
.subpage .box1 .photo-r img {max-width:460px; height:auto;}
.subpage .box1:after { /*float_clear*/ display:block; clear:both;	content:"";}
.subpage .box1 h4 {}
.subpage .box1 .come {/*overflow:hidden; ï¿½Ü‚ï¿½Ô‚ï¿½ï¿½ï¿½*/}

/* BOX2 */
.subpage .box2 {
	float:left;
	margin:20px 2%;
	width:46%;
}
.subpage .box2 h4 {}
.subpage .box2 .come {/*overflow:hidden; ï¿½Ü‚ï¿½Ô‚ï¿½ï¿½ï¿½*/}
.subpage .box2 .photo-l img {max-width:210px; height:auto;}
.subpage .box2 .photo-r img {max-width:210px; height:auto;}


/*---------------------------------------------------------------------------
  LINE
---------------------------------------------------------------------------*/

.subpage .line {
	clear:both;
	margin:0 2%;
	padding:20px 0;
	width:96%;
}
.subpage .line hr {
	height: 1px;
	border: none;
	border-top: 1px #AAA dotted;
}


/*---------------------------------------------------------------------------
  BUTTON
---------------------------------------------------------------------------*/

.subpage .btn {
	float:left;
	margin:1% 2%;
	padding:10px 25px;
	color:#FFF;
	border-radius: 30px; /* CSS3 */
	-webkit-border-radius: 30px; /* Safari,Google Chrome */
	-moz-border-radius: 30px;/* Firefox */
	background:var(--main-color);
}
.subpage .btn a {
	display:block;
	padding:10px 25px;
	font-size:112.5%;
	color:#FFF;
	text-decoration:none;
	position:relative;
}
.subpage .btn a:before,
.subpage .btn a:after { content:""; display:block; position:absolute;}
.subpage .btn a:before{
	width:2rem;
	aspect-ratio:1/1;
	background:#fff;
	border-radius:50%;
	top:50%;
	right:0.5rem;
	translate:0 -50%;
}
.subpage .btn a:after {
	content: "";
    position: absolute;
    display: block;
    width: 2rem;
    aspect-ratio: 1/1;
    border-top: solid 5px var(--main-color);
    border-right: solid 5px var(--main-color);
    right: 0.5rem;
    top: 50%;
    translate: -2px -50%;
    rotate: 45deg;
    scale: 0.4;
}
.subpage .btn a:hover {
	background:var(--main-color);
	border-radius: 30px; /* CSS3 */
	-webkit-border-radius: 30px; /* Safari,Google Chrome */
	-moz-border-radius: 30px;/* Firefox */
}
.subpage .btn a:hover:after { opacity:0.7;}
.subpage .btn.about_btn a:hover { background:var(--main-color); }
.subpage .btn.recruit_btn a:hover { background:#48AA4F; }
/* BUTTON BOX1 */ .subpage .b1 { width:60%; clear: both; float:none; margin:0 auto;}
/* BUTTON BOX2 */ .subpage .b2 { width:46%;}
/* BUTTON BOX3 */ .subpage .b3 { width:29.3%;}

/*---------------------------------------------------------------------------
  COLUMNBOX
---------------------------------------------------------------------------*/
.subpage .column {}
.subpage .column:after { /*float_clear*/ display:block; clear:both; content:"";}
.subpage .column .col2 { float: left; margin: 2%; width: 46%;}
.subpage .column .col3 { float: left; margin: 2%; width: 29.3%;}
.subpage .column .col2:nth-child(2+1),
.subpage .column .col3:nth-child(3+1) { clear:both;}

/*---------------------------------------------------------------------------
  FLOW
---------------------------------------------------------------------------*/

.subpage ul.flow_box {}
.subpage ul.flow_box:after { /*float_clear*/ display:block; clear:both; content:"";}
.subpage ul.flow_box li {
	position:relative;
	float:left;
	margin:1% 2%;
	padding:15px;
	color:#FFF;
	text-align:center;
	background:#222;
	border-radius: 5px; /* CSS3 */
	-webkit-border-radius: 5px; /* Safari,Google Chrome */
	-moz-border-radius: 5px;/* Firefox */
	box-sizing:border-box;
}
.subpage ul.flow_box li a:hover {
	background:#999;
	border-radius: 5px; /* CSS3 */
	-webkit-border-radius: 5px; /* Safari,Google Chrome */
	-moz-border-radius: 5px;/* Firefox */
}
.subpage ul.flow_box li+li:before {
	position:absolute;
	top:0;
	left:-22px;
	display:block;
	clear:both;
	content:"";
	width:15px;
	height:100%;
	background:url(../image/flow_bg_pc.png) no-repeat center center;
}
.subpage .flow1 { position:relative;}
.subpage .flow1 li { float: none; width:96%;}
.subpage .flow1+.flow1:before {
	position:absolute;
	top:-15px;
	left:0;
	display:block;
	clear:both;
	content:"";
	width:100%;
	height:30px;
	background:url(../image/flow_bg_sm.png) no-repeat center center;
}
.subpage .flow2 li { width:46%;}
.subpage .flow3 li { width:29.3%;}
.subpage .flow4 li { width:21%;}

.subpage .flow1a { position:relative;}
.subpage .flow1a+.flow1a {margin-top:3%;}
.subpage .flow1a li+li:before { display:none !important;}
.subpage .flow1a li:nth-child(1) { width:32%; background:#222;}
.subpage .flow1a li:nth-child(2) { width:60%; padding:0; text-align: left; color: #343434; background: none;}
.subpage .flow1a+.flow1a:before {
	position:absolute;
	top:-25px;
	left:0;
	display:block;
	clear:both;
	content:"";
	width:36%;
	height:30px;
	background:url(../image/flow_bg_sm.png) no-repeat center center;
}

/*---------------------------------------------------------------------------
  FAQ
---------------------------------------------------------------------------*/

.subpage dl.faq { clear: both; margin:0 2%; padding: 3%; background: #F6F6F6;}
.subpage dl.faq+dl.faq { margin-top: 10px;}
.subpage dl.faq dt { position: relative; padding-left: 30px; font-weight: bold; color:#1D2085;}
.subpage dl.faq dd { position: relative; padding-left: 30px;}
.subpage dl.faq dt:after,
.subpage dl.faq dd:after { 
	display:block;
	clear:both;
	position: absolute;
	top: 0;
	left: 0;
	font-weight: bold;
	font-family: "Arial Black", Gadget, "sans-serif";
	font-size:18px;
}
.subpage dl.faq dt:after { content:"Q"; color:#1D2085;}
.subpage dl.faq dd:after { content:"A"; color:#FF0004;}