/*
Theme Name: Eguchigumi SNS Theme
Author: 札幌ホームページ制作ラボ
Author URI: https://www.sapporo-homepage.com/
Original Author: STAFF Co.,Ltd.
Original Author URI: http://www.d-staff.jp
Description: 編集元テーマ (株)STAFF WPテンプレート
*/

@charset "utf-8";
/* CSS Document */
.noto-sans-jp-<uniquifier> {
  font-family: 'Noto Sans JP', 'Helvetica', sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

.swiper-pagination-bullet-active {
  background-color: #333; /* アクティブなドットの色 */
}

body {
	font-family: 'Noto Sans JP', 'Helvetica', sans-serif;
	background-color: #ffe700;
}

h2 span.text-primary {
  color: #007bff;
}

h3.shimaShadow {
	position:relative;
	color:#fff;
	background: url(./img/kage.png) ;
	display:inline-block;
	padding:0px 10px 30px 0px;
	border-radius:35px;
	margin-left:10px;
	margin-bottom:30px;
	font-weight:bold;
}
h3.shimaShadow span {
	background-color:#000000;
	padding:10px 60px 15px 60px;
	border-radius:35px;
	font-size:43px;
	margin-left:-10px;
}

h3.hIcon0 {
	color:#363538;
	font-size:50px;
	text-align:center;
	font-weight:bold;
	margin-top:10px;
}
h3.hIcon0 span:first-child {
	font-size:16px;
}
h3.hIcon0 span.main {
	position:relative;
	display:inline-block;
}

h3.hIcon1 {
	color:#ffe700;
	font-size:50px;
	text-align:center;
	font-weight:bold;
	margin-top:10px;
}
h3.hIcon1 span:first-child {
	font-size:16px;
}
h3.hIcon1 span.main {
	position:relative;
	display:inline-block;
}
h3.hIcon1 span.main::before {
	content:"";
	background: url(./img/h31.png);
	position:absolute;
	left:-158px;
	top:-46px;
	width:136px;
	height:104px;
}

h3.hIcon2 {
	color:#363538;
	font-size:50px;
	text-align:center;
	font-weight:bold;
	margin-top:0px;
}
h3.hIcon2 span:first-child {
	font-size:16px;
}
h3.hIcon2 span.main {
	position:relative;
	display:inline-block;
}
h3.hIcon2 span.main::after {
	content:"";
	background: url(./img/h32.png);
	position:absolute;
	right:-280px;
	top:-46px;
	width:268px;
	height:133px;
}

h3.hIcon3 {
	color:#ffe700;
	font-size:50px;
	text-align:center;
	font-weight:bold;
	margin-top:10px;
}
h3.hIcon3 span:first-child {
	font-size:16px;
}
h3.hIcon3 span.main {
	position:relative;
	display:inline-block;
}
h3.hIcon3 span.main::before {
	content:"";
	background: url(./img/h33.png);
	position:absolute;
	left:-188px;
	top:-54px;
	width:178px;
	height:131px;
}



a {
	text-decoration:none;
	color:#140508;
}
a:hover {
	font-weight:bold;
}

img {
	max-width:100%;
	height: auto;
}

.f18 {
	font-size:18px;
}


.baseColor {
	background-color: #ffe700;
}

div.none {clear: both;}
div.none hr {display: none;}

.btnSns a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha(opacity=80)";
}

section {
	padding: 2em 0;
}

/* ヘッダ */
#headerArea {
	width:100%;
	max-width:1594px;
	margin:0px auto;
	padding:6px 0 0 0;
}
#headerArea h1 {
	float:left;
	padding:0 0 0;
	margin-bottom:0;
}
#headerArea h1 img {
	width:200px;
}

#headerArea #headCont {
	float:right;
	display: flex;
	margin-top:4px;
}

#headerArea #headCont ul.btnSns {
	flex:2.3;
	display: flex;
	width:234px;
	margin-bottom:0;
}
ul.btnSns li {
	flex:1;
	list-style-type:none;
}
ul.btnSns li img.svg {
	border-radius: 100%;
	width: 34px;
}
ul.btnSns li img.youtube {
	margin-top:4px;
	width: 34px;
}

#headerArea #headCont p.tel {
	flex:2.5;
	margin-bottom:0;
}
#headerArea #headCont p.tel img {
	width: 224px;
}

#headerArea #headCont p.mail {
	flex:2;
	width: 220px;
	margin:8px 0 0 6px;
	text-align:center;
}
#headerArea #headCont p.mail a {
    background-color: #0F0E0E;
    color: #fff;
	position:relative;
	border-radius: 6px;
	text-decoration: none;
	padding: 5px 17px 5px 44px;
	height: 40px;
}
#headerArea #headCont p.mail a::before {
	content:"　";
	background: url(./img/iconMailW.svg) no-repeat;
	position:absolute;
	left:15px;
	top:9px;
	width:24px;
}

/* sp */
#glNav {
	display:none;
}
.off {
	display:none;
}

.container {
	width:100%;
	max-width:1600px;
	margin:0px auto;
	padding: 0 15px;
}
.container11 {
	width:100%;
	max-width:1170px;
	margin:0px auto;
}
.container14 {
	width:100%;
	max-width:1430px;
	margin:0px auto;
	padding: 0 15px;
}

/* toppage:メインビジュアル */
section#topmain {
	padding: 0;
	height:900px;
}

#topbg {
	background: url(./img/top/hedbg.jpg) no-repeat #ffe700;
	height:670px;
	background-size:cover;
}


.hero-copy1{
	text-align: center;
	padding: 2rem 0;
}

.hero-movie{
	display: flex;
}
.hero-slider{
  order: 1;
  width: 50%;
  max-width:760px;
  position: relative;
}
.hero-rightbox{
  order: 2;
  margin-left:30px;
  width: 50%;
}

.hero-copy2{
	margin: 20px 0 30px;
}

.hero-youtube{
	display: flex;
}


#topmain > div #main_slider {
	border-radius:80px;
	border:8px solid #ffe700;
	/*overflow:hidden;
	max-width:760px;
	width: 100%;
	height:610px;
	padding-bottom: calc(610 / 760 * 100);*/
}
#topmain > div #main_slider img {
	padding:0;
}

#topmain > div .swiper-pagination{
	max-width:760px;
	bottom: -30px;
}


/* toppage:SNSを入れる理由 */
.reason {
	display: flex;
	flex-wrap: wrap;
}

.reason .reason-txt{
	width: 60%;
	padding: 15px;
}

.reason p {
	font-size:18px;
	line-height:32px;
}
.reason .imgbox {
	text-align:center;
	width: 40%;
}
.reason img {
	border-radius:50px;
	margin-top:-100px;
	width:auto;
	height:auto;
	width: 100%;
	padding: 15px;
}

/* toppage:サービスの概要 */
.bgBlack {
	background-color:#363538;
}
.serviceBoxs {
	padding-top:15px;
}
.serviceBoxs > div {
	padding-top:20px;
}
.serviceBoxs > div div {
	position:relative;
	top:-15px;
	background: url(./img/kage_y.png) ;
	padding:0px 5px 0px 0px;
	border-radius:68px;
	margin:0px 5px 30px 10px;
	z-index: 1;
}
.serviceBoxs > div div div {
	background: #fff;
	border-radius:68px;
	color:#363538;
	padding:40px 40px;
	margin:-15px 5px 0 -10px;
	z-index: 2;
}
.serviceBoxs > div p {
	text-align:left;
	min-height: 70px;
}


/* toppage:江口組の強み */
.strengthsBox {
	display: flex;
	background-color:#fff8b0;
	border-radius:70px;
	padding:50px;
	margin-bottom:34px;
}
.strengthsBoxR {
	flex-direction: row;
}
.strengthsBoxL {
	flex-direction: row-reverse;
}
.strengthsBox:last-child {
	margin-bottom:0;
}
.strengthsBox div h5 {
	font-size:36px;
	font-weight:bold;
}
.strengthsBox div p {
	font-size:18px;
	line-height:32px;
}
.strengthsBox > div:first-child {
	flex:2;
}
.strengthsBox > div:last-child {
	flex:1.5;
}


/* toppage:お知らせ */
.infoBox {
	background-color:#fff;
	border-radius:70px;
	padding:0 40px 40px 40px;
	font-size:18px;
	margin-bottom:20px;
}
.infoBox ul li {
	border-bottom:1px dashed #7e7e7e;
	padding-top:12px;
}
.infoBox ul li > span:first-child {
	border:2px solid #7e7e7e;
	padding:0 4px;
	margin-right:1em;
	width:7em;
	display:inline-block;
	text-align:center;
}
.infoBox  p.listLink {
	margin-top:30px;
	text-align:center;
}
.infoBox  p.listLink a {
	display:inline-block;
	background-color:#363538;
	color:#fff;
	border-radius:24.5px;
	font-size:18px;
	padding:9px 0;
	width:320px;
	max-width:100%;
}
.infoBox  p.listLink a img {
	margin-bottom:3px;
}


/* toppage:SNSブログ */
.snsBox {
	margin-bottom:22px;
}
.snsBox > div {
}
.snsBox > div a.imgLink {
	height:300px;
	overflow:hidden;
	display:inline-block;
	border-radius:27px;
	margin-bottom:20px;
}
.snsBox > div p {
	border-radius:19px;
	font-size:18px;
	color:#363538;
	padding:5px 0;
	background-color:#fff;
}
.snsBox  p.listLink {
	margin-top:30px;
	text-align:center;
}
.snsBox  p.listLink a {
	display:inline-block;
	background-color:#fff;
	border-radius:24.5px;
	font-size:18px;
	padding:9px 0;
	width:320px;
	max-width:100%;
}
.snsBox  p.listLink a img {
	margin-bottom:3px;
}

/* toppage:お問い合わせ・お申込み */
.formSection {
	padding:62px 0 60px;
}
.mailForm {
	border:5px solid #363538;
	max-width:838px;
	margin:10px auto;
	padding:30px 40px 20px;
	background-color:#fff;
	font-size:18px;
}
.mailForm table {
	width:100%;
	border-collapse:collapse;
	margin-bottom:20px;
}
.mailForm table tr th {
	background-color:#f7f7f7;
}
.mailForm table tr th,
.mailForm table tr td {
	border:1px solid #e2e5e8;
	padding:4px 8px;
}
.mailForm button[type="submit"] {
	padding-left:2em;
	padding-right:2em;
}

/* フッター */
footer {
	margin-top:30px;
	font-size:18px;
	padding:40px 0 30px;
	background-color:#0e0e0e;
}

footer h3 {
	font-size:30px;
}

.footerSns {
	display: flex;
	width:360px;
	margin:38px auto 32px;
}
.footerSns div {
	flex:1;
}
.footerSns a {
	background-color:#fff;
/*	display:inline-block;*/
	width:63px;
	height:63px;
	border-radius:63px;
	display: grid;
	justify-items: start;
	align-content: center;
	margin:0 auto;
	filter: invert(0%);
	transition: filter 0.5s ease;
}
.footerSns a img {
	margin:0 auto;
}
/*
.footerSns a:hover {
	animation: snsInvert -0.5s ease-in 1s 1 normal forwards;
}

.footerSns a:not(:hover) {
	animation: snsInvert -0.5s ease-in 1s 1 reverse forwards;
}

@keyframes snsInvert {
	from {
		filter:invert(0%);
	}
	to {
		filter:invert(100%);
	}
}
*/
.footerSns a.invert {
	animation: snsInvert 0.5s ease forwards;
}

.footerSns a.uninvert {
	animation: snsUninvert 0.5s ease forwards;
}
@keyframes snsInvert {
	from { filter: invert(0%); }
	to   { filter: invert(100%); }
}

@keyframes snsUninvert {
	from { filter: invert(100%); }
	to   { filter: invert(0%); }
}




.SDGsLogo {
	width:300px;
	margin:30px auto 35px;
	text-align:left;
	font-size:14px;
}
.SDGsLogo a img {
	margin-bottom:10px;
}




.nopc{
	display: none;
}

.nosp{
	display: block;
}

.pc{
	display: inline;
}


.clearfix:after{
  content: ".";
  display: block;
  height: 0;
  font-size:0;
  clear: both;
  visibility:hidden;
}

/* contactform7 カスタマイズ */
.wpcf7 p {
display: inline;
}

.wpcf7-form input[type="text"],.wpcf7-form input[type="email"],.wpcf7-form textarea{
    display: block;
    width: 100%;
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    background-color: var(--bs-body-bg);
    background-clip: padding-box;
    border: var(--bs-border-width) solid var(--bs-border-color);
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: var(--bs-border-radius);
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

/* 送信ボタンのスタイル */
.wpcf7-form input[type="submit"] {
	  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
cursor: pointer;
transition: background-color 0.3s ease;
border: none;
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	margin: auto;
	margin-bottom: 1rem;
	padding: 0.5rem 2rem;
	font-weight: normal;
	border-radius: 0.5rem;
	background: #dc3545; /* 赤 */;
	color: #fff;
}
.wpcf7-form input[type="submit"]:hover{ 
	background: #E15160; /* 赤 */;
	color: #fff;
	font-weight: bold;
}
span.wpcf7-spinner {
  display: none;
}

@media screen and (max-width: 1594px) {
	#headerArea {
		padding-left: 10px;
	}
	.reason div {
		text-align:center;
	}
	.reason div p {
		text-align:left;
	}
	.reason img {
		max-width:100%;
	}
	#topmain > div {
		text-align:center;
	}
	#topmain > div #main_slider {
		display:inline-block;
		max-width:100%;
	}
	#topmain > div #main_slider img {
		margin:0;
	}
	#topmain > div img:nth-child(2) {
		right:10px;
	}
	#topmain > div img:nth-child(3) {
		right:10px;
	}
	.serviceBoxs > div div {
		/*min-height:518px;*/
	}
	.serviceBoxs > div div div {
		background: #fff;
		border-radius:68px;
		color:#363538;
		padding:40px 25px;
		margin:-15px 5px 0 -10px;
		z-index: 2;
	}
	.container11 {
		padding-right: 12px;
		padding-left: 12px;
	}
}

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

/* toppage:SNSを入れる理由 */
	.reason {
		display: flex;
		flex-direction: column;
	}
	.reason .reason-txt{
		width: 100%;
		padding: 15px;
	}
	.reason p {
		font-size:18px;
		line-height:32px;
	}
	.reason .imgbox {
		text-align:center;
		width: 100%;
	}
	.reason img {
		border-radius:40px;
		margin-top:0px;
		width:auto;
		height:auto;
		max-width: 100%;
		padding: 15px;
	}
}
/* sp menu */
@media screen and (max-width: 959px) {

	.off {
		display:inline;
	}
	#pcNavi {
		display:none !important;
	}
	#headerArea {
		position:sticky;
		z-index:97;
	}
	#headerArea #headCont {
		display:none;
	}
	button {
		border:none;
		background-color:transparent;
	}
	button img {
		width: 46px;
	}
	#headerArea #btnMenu {
		float:right;
	}

	#glNav {
		position: fixed;
		top:0;
		background-color:#FFE700;
		width:100%;
	}
	#glNav.open {
		z-index: 999;
	}

	#glNav ul#btnNav {
        display: grid;
        grid-template-columns: auto auto;
        column-gap: 20px;
        padding: 10px 0;
    }

	#glNav #btnNav li {
		list-style-type: none;
	}
	#glNav #btnNav li.tel {
		text-align:center;
	}
	#glNav #btnNav li.tel a {
	    background-color: #fff;
	    color: #000c15;
		position:relative;
		border-radius: 6px;
		text-decoration: none;
		padding: 5px 17px 5px 44px;
		height: 40px;
		border:1px solid #0F0E0E;
	}
	#glNav #btnNav li.tel a::before {
		content:"　";
		background: url(./img/iconTelG.svg) no-repeat;
		position:absolute;
		left:15px;
		top:9px;
		width:24px;
	}

	#glNav #btnNav li.mail {
		text-align:center;
	}
	#glNav #btnNav li.mail a {
	    background-color: #0F0E0E;
	    color: #fff;
		position:relative;
		border-radius: 6px;
		text-decoration: none;
		padding: 5px 17px 5px 44px;
		height: 40px;
		border:1px solid #0F0E0E;
	}
	#glNav #btnNav li.mail a::before {
		content:"　";
		background: url(./img/iconMailW.svg) no-repeat;
		position:absolute;
		left:15px;
		top:9px;
		width:24px;
	}
	#btnMenuClose {
		margin: 0 -6px 0 auto;
		display:block;
		padding-right:0;
	}

	#glNavArea {
		padding: 0 10px;
	}

    #glNavArea ul#TxtNav {
    	padding-left:0;
    }
    #glNavArea ul#TxtNav > li {
        border-bottom: 1px solid #0F0E0E;
		list-style-type: none;
    }
    #glNavArea ul#TxtNav > li:first-child {
        border-top: 1px solid #0F0E0E;
    }
    #glNavArea ul#TxtNav > li > a, #glNavArea ul#TxtNav > li.parent .tbspAcc button {
		position: relative;
		display:block;
		padding: 10px 10px 10px 15px;
	}
    #glNavArea ul#TxtNav > li > a::before, #glNavArea ul#TxtNav > li.parent .tbspAcc button::before {
        content: '';
        border-radius: 100%;
        width: 10px;
        height: 10px;
        position: absolute;
        left: 0;
        top:18px;
		background-color: #666;
    }
	#glNavArea ul#TxtNav > li > a:hover, #glNavArea ul#TxtNav > li.current > a {
	    font-weight: bold;
	}

    #glNavArea ul.btnSns {
    	padding-left:0;
    	display:flex;
    	text-align:center;
    	max-width:300px;
    }

	section#topmain {
		height:530px;
	}

	#topbg {
		height:400px;
	}

	.serviceBoxs > div div {
		min-height:400px;
	}

	h3.hIcon2 {
		margin-top:110px;
	}
	h3.hIcon2 span.main::after {
		position:absolute;
		left:calc(50% - 134px);
		top:-166px;
	}

	h3.hIcon3 {
		margin-top:110px;
	}
	h3.hIcon3 span.main::before {
		position:absolute;
		left:calc(50% - 89px);
		top:-166px;
	}
	h3.shimaShadow {
		display:block;
	}
	h3.shimaShadow span {
		display:block;
	}

/* toppage:SNSを入れる理由 */
	.reason .reason-txt{
		padding: 0px;
	}
	.reason img {
		border-radius:30px;
		padding: 0;
	}

}

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

	h3.hIcon0 {
		margin-top:10px;
		font-size:36px;
	}
	h3.hIcon0 span:first-child {
		font-size:14px;
	}

	h3.hIcon1 {
		margin-top:100px;
		font-size:36px;
	}
	h3.hIcon1 span.main::before {
		position:absolute;
		left:calc(50% - 68px);
		top:-146px;
	}
	h3.hIcon1 span:first-child {
		font-size:14px;
	}

	h3.hIcon2 {
		margin-top:120px;
		font-size:36px;
	}
	h3.hIcon2 span:first-child {
		font-size:14px;
	}

	h3.hIcon3 {
		margin-top:100px;
		font-size:36px;
	}
	h3.hIcon3 span:first-child {
		font-size:14px;
	}

	#topmain > div img:nth-child(2) {
		position:relative;
		max-width:calc(100% - 20px);
		top:0;
		margin-top:20px;
	}
	#topmain > div img:nth-child(3) {
		position:relative;
		max-width:calc(100% - 20px);
		top:0;
		margin-top:20px;
	}

	.hero-copy1{
		text-align: center;
		padding: 1rem 0;
	}

	.hero-copy2{
		text-align: center;
		margin: 0 0 30px;
	}

	.hero-movie{
		display: flex;
		flex-flow: column;
	}
	.hero-slider{
	  width: 100%;
	  position: relative;
	  margin-bottom: 30px;
	}
	.hero-rightbox{
	  margin-left:0;
	  width: 100%;
	}

	#topmain > div #main_slider {
		border-radius:30px;
		border:8px solid #ffe700;
	}
	#topmain > div #main_slider img {
		padding:0;
	}
	#topmain > div .swiper-pagination{
		max-width:760px;
		bottom: -20px;
	}


	h3.shimaShadow {
		position:relative;
		color:#fff;
		background: url(./img/kage.png) ;
		display:inline-block;
		padding:0px 10px 15px 0px;
		border-radius:20px;
		margin-left:10px;
		margin-bottom:30px;
		font-weight:bold;
		width: calc(100% - 15px);
	}
	h3.shimaShadow span {
	/*	width:calc(100% - 20px);
		height:calc(100% - 10px);*/
		background-color:#000000;
		padding:10px 15px 15px 15px;
		border-radius:20px;
		font-size:30px;
		margin-left:-10px;
	}
	.strengthsBoxR {
		flex-direction: column;
	}
	.strengthsBoxL {
		flex-direction: column;
	}

	.serviceBoxs > div div {
		border-radius:40px;
	}
	.serviceBoxs > div div div {
		border-radius:40px;
		padding:40px 20px;
	}
	
	.strengthsBox {
		border-radius:40px;
		padding:30px;
	}

	.infoBox {
		border-radius:40px;
		padding:0 20px 40px 20px;
	}

	.mailForm {
		padding:20px 20px 15px;
	}
	.mailForm table tr th ,
	.mailForm table tr td {
		display:block;
		width:100%;
	}

	.strengthsBox div h5 {
		font-size:24px;
	}

  .nopc {
    display: block;
  }

  .nosp {
    display: none !important;
  }
	.pc{
		display: none;
	}

	section#topmain {
		height:100vh;
	}

}

@media screen and (max-width: 480px) {
	section#topmain {
		height:80vh;
	}

	#topbg {
		height:80vh;
	}
    #glNavArea ul.btnSns {
/*    	max-width:100%;*/
    }
}
@media screen and (max-width: 380px) {
	section#topmain {
		height:90vh;
	}

}
@media screen and (max-width: 359px) {
	.footerSns {
		width:100%;
	}

}
