@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/************************************
** スマホ時画像100%拡大
************************************/
@media(max-width:480px) {
	.lum-lightbox-inner img{
		width:100%;
	}
}

/************************************
** TOPの入力
************************************/

#breadcrumb{
	display: none;
}

/************************************
** TOPの入力
************************************/

@media(min-width:960px) {
	.p-mainVisual{
	width: 900px;
	margin: 30px auto;
	box-shadow: 0 2px 8px rgb(0 0 0 / 10%), 0 4px 8px -4px rgb(0 0 0 / 20%);
	}
}

.l-header{
	box-shadow: none;
}

@media(min-width:960px) {
.l-header{
	max-width: 980px;
	margin: 30px auto 40px;
	}
}

@media(min-width:960px) {
.l-fixHeader__inner{
	max-width: 980px;
	}
}

.text_mi {
  display: flex;
  align-items: center;
}
.text_mi:before {
  border-top: 1px solid #3e6e92;
  content: "";
  width: 20px; 
}
.text_mi:before {
  margin-right: 10px; 
}

.post_content h2{
	letter-spacing: .2em;
	margin-bottom: 15px;
}

.post_content h2::before{
	position: static;
}

.has-text-align-left{
	line-height: 3em;
}

.textwidget.custom-html-widget p {
    letter-spacing: .15em;
    font-size: .8rem;
}

.pc_fo_h2{
	font-size: 1.2em;
	margin: 30px 0px 10px;
}

.sp_fo_h2{
	margin: 32px 0px 10px;
	font-size: 1.1em;
}

.fo_space{
	margin: 30px 0px 0px;
}

.fo_space li{
	margin-bottom: 15px;
}

.li_space{
	margin: 10px 0px;
}

.top_h2 {
  position: relative;
  padding: 1.5rem;
  text-align: center;
}

@media(min-width: 768px){
	.top_h2{
		font-size: 1.6em　!important;
	}
}

.top_h2:before {
  position: absolute !important;
  bottom: -10px;
  left: calc(50% - 30px);
  width: 60px;
  height: 1px;
  content: '';
  background: #0d1e5f;
}

.c-gnav a::after{
	height: 1px;
}

@media(min-width: 500px){
.page-id-25 .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image){
	padding: 10px;
	}
}

/************************************
** NEWSのCSS
************************************/

div.whatsnew a{
	padding: 10px 0px;
	color: #808080;
}

@media(min-width: 500px){
.page-id-25 .l-mainContent__inner>.post_content{
	padding: 0px;
	}
}

/************************************
** スマホメニュー
************************************/

.c-iconBtn{
	background: #000;
}

.icon-menu-thin:before{
	color: #fff;
}

.c-widget__title.-spmenu{
	letter-spacing: .1em;
  border-left: 5px double #a7a7a7;
	color: #333;
	background: none;
}

.p-spMenu__inner .is-style-more_btn a{
	min-width: 100% !important;
	padding: 0.75em 1em !important;
}

.p-spMenu__inner .swell-block-button .swell-block-button__link[data-has-icon]{
	justify-content: start;
}

/************************************
** button
************************************/

.textlink a {
	position: relative;
	color: #333;
	text-decoration: none;
}
.textlink a:hover {
	color: #b99b00;
}

.textlink07 {
    text-align: right;
    padding-top: 32px;
}

@media(max-width: 500px){
	.textlink07{
   padding-top: 16px;
	}
}

.textlink07 a {
	padding-right: 50px;
}

.textlink07 a::before {
	content: '';
	position: absolute;
	top: calc(50% - 4px);
	right: 0;
	transform: rotate(30deg);
	width: 12px;
	height: 1px;
	background-color: #333;
}

.textlink07 a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 40px;
	height: 1px;
	background-color: #333;
}

.textlink07 a:hover::before {
	background-color: #ceb849;
}

.textlink07 a:hover::after {
	background-color: #ceb849;
}



.textlink08 {
    padding-top: 32px;
}

@media(max-width: 500px){
	.textlink08{
   padding-top: 16px;
	padding-bottom: 32px;
	}
}

@media(max-width: 500px){
	.page-id-472 .textlink08{
		padding-bottom: 0px;
	}
}

.textlink08 a {
	padding-right: 50px;
}

.textlink08 a::before {
	content: '';
	position: absolute;
	top: calc(50% - 4px);
	right: 0;
	transform: rotate(30deg);
	width: 12px;
	height: 1px;
	background-color: #333;
}

.textlink08 a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 40px;
	height: 1px;
	background-color: #333;
}

.textlink08 a:hover::before {
	background-color: #ceb849;
}

.textlink08 a:hover::after {
	background-color: #ceb849;
}

/************************************
**profileの入力
************************************/

.page-id-628 .name{
	color: #333 !important;
	letter-spacing: .12em;
}

@media(min-width: 600px){
.page-id-628 .name{
	font-size: 1.5em !important;
	}
}

.page-id-628 .post_content h2{
	margin-bottom: 1.2em;
	margin-left: 0px;
	color: #3e6e92;
}

@media(min-width: 600px){
.page-id-628 .post_content h2{
	font-size: 1.8em;
	}
}

.page-id-628 .post_content td, .post_content th{
	border: none !important;
}

.page-id-628 .post_content h3{
	margin: 1em 0 1em !important;
	border-left: 0px !important;
	padding-left: 32px;
}

.name_space{
	margin-bottom: 240px;
}

@media(max-width: 600px){
.name_space{
	margin-bottom: 120px;
	}
}

.name_span{
	font-size: 1.3rem;
	font-weight: 300 !important;
	color: #333 !important;
	margin-top: 0px !important;
}

.fl_right{
	max-width: 400px;
}

.fl_img{
	width: 40%;
}

@media(max-width: 600px){
.fl_img{
	padding-top: 24px;
	}
}

/************************************
** aboutの入力
************************************/

@media(min-width: 960px){
.c-pageTitle__inner{
	padding: 0px 16px;
	}
}

.page-id-18 .post_content h2{
	margin-bottom: 1.2em;
	margin-left: 0px;
	color: #3e6e92;
}

@media(min-width: 600px){
.page-id-18 .post_content h2{
	font-size: 1.8em;
}
}

.page-id-18 .post_content td, .post_content th{
	border: none !important;
}

.post_content tbody th::before {
    background-color: rgb(255 255 255 / 5%);
    pointer-events: none;
}

@media(min-width: 900px){
.page-id-18 .wp-block-media-text{
	--swl-mediatext--space: 3rem;
}
}

.page-id-18 .post_content h3{
	margin: 1em 0 1em !important;
	border-left: 0px !important;
	padding-left: 32px;
}

.flex{
	display: flex;
	align-items: center;
	justify-content: space-evenly;
}

@media(max-width: 600px){
	.flex{
		flex-direction: column;
		align-items: initial;
	}
}

@media(min-width: 900px){
	.flex{
		margin-left: -85px;
	}
}

.img_size{
	max-width: 300px;
}

@media(max-width: 600px){
	.img_size{
		max-width: 50%;
	}
}

.flex_left{
	width: 50%;
	padding-right: 15px;
}

.flex_right{
	width: 50%;
	padding-left: 15px;
}

/************************************
** companyの入力
************************************/
.page-id-16 .post_content td, .post_content th{
	border: none !important;
}

.square {
    position: relative;
    display: block;
    padding: 0.2em 0 0.2em 1.2em;
}

.square::before {
    position: absolute;
    top: 12px;
    left: 0;
    display: block;
    width: 0.8em;
    height: 0.8em;
    background: #606060;
    content: "";
}

@media(max-width: 600px){
	.square::before {
      top: 9px;
	}
}

/* table01 */
#table01 tr {
  border-bottom: 1px solid #ececec;
}

#table01 th,
#table01 td {
  padding: 20px 0;
  border: none;
}

@media(max-width: 600px){
	#table01 th,
#table01 td {
  padding: 20px 0 12px;
	}
}

#table01 th {
  width: 30%;
}

/* sp */
@media only screen and (max-width: 480px) {
  #table01 th,
  #table01 td {
    width: 100%;
    display: block;
  }

  #table01 th {
    width: 100%;
  }

  #table01 td {
    padding-top: 0;
  }
}

.space{
	margin-top: 5em;
}

/************************************
** WORKSのCSS
************************************/
@media (min-width: 600px){
.wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:last-child{
	width: 284px;
	}
}

@media (min-width: 600px){
.wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2), .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2)~figure.wp-block-image:not(#individual-image) {
    width: 284px;
	}
}

@media (min-width: 782px){
.page-id-472  .wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
    padding: 0px 20px 0px 0px;
	}
}

.wp-block-gallery.has-nested-images figure.wp-block-image figcaption{
	background: none;
	overflow: initial;
	position: unset;
	color: #333;
}

.wp-block-gallery.has-nested-images figure.wp-block-image {
    flex-grow: 0;
}

.wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image) {
    height: 112px;
	}

@media (min-width: 500px){
.wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image) {
    height: 213px;
	}
}

.wp-block-gallery.has-nested-images.columns-3 figure.wp-block-image:not(#individual-image){
    height: 112px;
	}

@media (min-width: 500px){
	.wp-block-gallery.has-nested-images.columns-3 figure.wp-block-image:not(#individual-image){
    height: 213px;
	}
}


@media (min-width: 782px){
.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column:not(:first-child) {
    margin-left: var( --wp--style--gallery-gap-default, var( --gallery-block--gutter-size, var( --wp--style--block-gap, 0.5em ) ) );
	}
}

@media (min-width: 600px){
.page-id-20 .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2), .wp-block-gallery.has-nested-images.columns-default figure.wp-block-image:not(#individual-image):first-child:nth-last-child(2)~figure.wp-block-image:not(#individual-image) {
    width: 284px;
	}
}

.img_2019{
	width: 100%;
}

a.btn_02 {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 1px solid #6e6e6e;
  box-sizing: border-box;
  width: 100%;
  height: 50px;
  padding: 0 6% 0 12%;
  color: #228bc8;
  font-size: 16px;
  text-align: left;
  text-decoration: none;
  position: relative;
  transition-duration: 0.2s;
}
a.btn_02:hover {
  background: #228bc8;
  color: #fff;
}
a.btn_02:before {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 7px 0 7px 8px;
  border-color: transparent transparent transparent #228bc8;
  position: absolute;
  top: 50%;
  left: 6%;
  margin-top: -7px;
}
a.btn_02:hover:before {
  border-color: transparent transparent transparent #fff;
}

/************************************
** お問い合わせフォームの入力
************************************/
dl dd{
	margin-bottom: 32px;
}

.must{
	color: #fff;
	font-size: .8rem;
	background: #E58B30;
    padding: 7px;
    border-radius: 10px;
    margin-left: 8px;
}

#cf-tbl{
width: 800px;
}

#cf-tbl table{
width: 100%;
border-collapse: collapse;
border: solid #ededed;
color: #444;
}
#cf-tbl table tr th,
#cf-tbl table tr td{
padding: 0.5em;
text-align: left;
vertical-align: top;
border: solid #CCC;
border-width: 1px;
vertical-align: middle;
}
#cf-tbl table tr th{
width: 35%;
background: #fafafa;
}
@media screen and (max-width:768px){
#cf-tbl{
width: 100%;
}

#cf-tbl table,
#cf-tbl table tbody,
#cf-tbl table tr,
#cf-tbl table tr th,
#cf-tbl table tr td{
display: block;
}

#cf-tbl table{
width: 100%;
border-width: 0 0 1px 0;
}

#cf-tbl table tr th,
#cf-tbl table tr td{
width: 100%;
padding: 3% 5%;
}

#cf-tbl table tr td{
border-width: 0px 1px 0px 1px;
}
}
/*「必須」文字デザイン*/
.required{
font-size:.8em;
padding: 5px;
background: #F57500;
color: #fff;
border-radius: 3px;
margin-right: 5px;
}

/*「任意」文字デザイン*/
.optional{
font-size:.8em;
padding: 5px;
background: #000080;
color: #fff;
border-radius: 3px;
margin-right: 5px;
}

/* 入力項目を見やすく */
input.wpcf7-form-control.wpcf7-text,
textarea.wpcf7-form-control.wpcf7-textarea {
	width: 100%;
	padding: 8px 15px;
	margin-right: 10px;
	margin-top: 10px;
	border: 1px solid #d0d5d8;
	border-radius: 3px;
	background-color: #eff1f5;
}
textarea.wpcf7-form-control.wpcf7-textarea {
	height: 200px;
}

/* 「送信する」ボタン */
#cf7-btn {
    display: initial;
    padding: 15px;
    width: 400px;
    background: #3D6E92;
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    border-radius: 2px;
    margin: 30px auto 0
}
@media screen and (max-width:768px){
}#cf7-btn {
width: 250px;
}
}

#cf7-btn:hover {
    background: #fff280;
    color: #ffaa56;
    border: 2px solid #ffaa56
}
.c-gnav{
	letter-spacing: .1em;
}
/* エラーメッセージを見やすく */
span.wpcf7-not-valid-tip,
.wpcf7-response-output.wpcf7-validation-errors {
	color: red;
	font-weight: 600;
}