@charset "UTF-8";
/*
Theme Name: SANGO Child
Theme URI: https://saruwakakun.design
Author: SARUWAKA
Author URI: https://saruwakakun.com
Template: sango-theme
Version: 4.0
*/
/*こちらはSANGOの子テーマ用CSSです。以下にCSSを記入していきましょう。*/
*{
	margin: 0;
	padding: 0;
}
@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;400;500&family=Playfair+Display:wght@400;500;600&display=swap');
:root{
	--font-serif: 'Noto Serif JP', sans-serif;
	--font-sans-serif: 'Noto Sans JP', sans-serif;
	--color-btn-bg: #c0b5a6;
	--color-btn-txt: #333;
	--color-primary-black:#333;
	--color-primary-white:#fff;
	--colorAccent1: #c0b5a5;
}
/*レスポンシブ改行調整*/
.unbr{display:inline-block!important;}
@media screen and (min-width:768px){.sp_br br{display:none!important;}.sp_nobr br{display:block!important;}}
@media screen and (max-width:767px){.sp_br br{display:block!important;}.sp_nobr br{display:none!important;}}
.headerParts{
	width: 60%!important;
	justify-content: flex-end;
}

@media screen and (min-width:1024px){
	#inner-header{
		display:none;
	}
	/* header */
	.flexRow{
		display: flex;
		flex-direction: row;
		width: 100%;
	}

	#myHeader{
		background-color: transparent;
		position: relative;
		width: 100%;
		z-index:999;
		padding:0;
		height: 112px;
	}
	.headerContainer{
		display:block;
		width: 1024px;
      margin-top: -20px!important;
		padding: 7px 0;
		height: auto;
	}
	.headerContainer>section{
		align-items: center;
		justify-content:space-between;
	}
	.headerContainer a{
		color: #fff!important;
    font-size: 120%!important;
    letter-spacing: 2px!important;
    font-family: 'Playfair Display', serif!important;
    font-weight: normal!important;
	}

	.headerContainer a:hover{
		text-decoration:none;
		color:#fff!important;
		opacity:0.5;
		transition:0.5s;
	}
	.headerLogo{
		width: 60%;
		position: relative;
	}
	.headerLogo img{
		width: 250px;
	}
	#naviBar{
		width: 90px;
	}
	#naviBar > div:first-child{
		width:100%;
		text-align: start;
		margin-top: 10px;
	}
	.naviBar{
		margin: 0 2%;
		width:50px;
	}
	.material-symbols-outlined{
		color: #a4afb7;
      line-height: 0.6!important;
	}
	.material-symbols-outlined.naviBar{
		font-size: 80px;
      width: 50px!important;
       margin-left: 25px!important;
	}
	.entrybtn{
		width: 50%;
		max-width: 300px;
	}
	.entrybtn button{
		color: #fff!important;
		width: 100%; 
		padding:0.7em 3%;
		background-color: #C69C6D;
		border: 0px solid var(--color-btn-bg)!important;

	}
	.entrybtn button:hover{
		background-color:#555;
		border: 0px solid var(--color-btn-txt)!important;
		color: #fff;
		transition: 0.5s;
	}
	.entrybtn p:first-child{
		font-family:'Playfair Display', serif;
		 font-weight:normal;
		font-size: 30px;
		letter-spacing: 0.1em;
	}
	.entrybtn p{
		font-size: 14px;
	}
	.menuContents{
		background-color: #a89f91!important;
		width:100%;
		display:none;
		position:absolute;
		padding:4% ;
		left: 0;
		top:100%;
		color: #fff;
	}
	.menuContents section{
		display: flex;
		width: 1024px;
		margin: 0 auto;
		align-items: flex-start;
	}
	.menuContents > section > div{
		width: 25%;
		/*height: 100%;*/
		padding:0 20px;
	}
	.menuContents > section > div > h3{
		font-family: var(--font-serif);
		font-weight: 400;
		font-size: 25px;
		padding-bottom: 0.5rem;
      line-height: 1.2em!important;
	}
	.menuContents > section > div > ul{
		font-family: var(--font-sans-serif);
		font-weight: 400;
		font-size: 14px;
		letter-spacing: 0.1em;
		list-style: square;
		padding-bottom: 1em;
		margin-block-start: 0;
		margin-block-end: 0;
		margin-inline-start: 0;
		margin-inline-end: 0;
		padding-inline-start: 20px;
	}
	.menuContents > section > div:first-child{
		width: 25%;
		/*height: 380px;*/
      padding:0 20px;
	}
	.menuContents > section > div:first-child > img{
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}
@media screen and (min-width:1200px){
	.headerContainer{
		width: 100%;
		padding: 10px 1%;
	}
	.menuContents section{
		width: 1200px;
	}
	/* 	#naviBar{
	margin-left: -5%;
} */
}
@media screen and (max-width:1024px){
	.headerContainer{
		display:none;
	}
	#myHeader{
		background-color:#fff;
	}
}

/*ホームボタンを非表示*/
.footer-menu__btn {
	display: none !important;
}

/* トップページ */
.fontSerif{
	font-family:--font-serif;
}
.accentCharacter{
	color: var(--colorAccent1);
}
.txtVertical{
	writing-mode: vertical-rl;
}
.cornerBracket {
	padding: ;
	position: relative;
}
.cornerBracket:before, .cornerBracket:after {
	content: '';
	width: 100px;
	height: 100px;
	position: absolute;
}
.cornerBracket::before {
	border-left: solid 1px #000000;
	border-top: solid 1px #000000;
	top: 0;
	left: 0;
}
.cornerBracket::after {
	border-right: solid 1px #000000;
	border-bottom: solid 1px #000000;
	bottom: 0;
	right: 0;
}
.multiplicationMark{
	position: relative;
}
.multiplicationMark::after{
	position: absolute;
	content: "×";
	font-weight: 100;
	font-size: 27px;
	right: -9px;
	bottom: 64px;
}
.width100butonn > div > div > a{
	width: 100%!important;
	height: 100%;
}
.borderDotted1{
	border-style: dotted;
	border-width: 5px;
	border-color:  var(--colorAccent1);
}
@media screen and (max-width:767px){
    .conceptTxt-emphasize1{
        background-color: var(--colorAccent1);
        padding: 0.5em 0.3em;
        line-height: 2.5em;
    }
    .multiplicationMark::after{
        position: absolute;
        content: "×";
        font-weight: 100;
        font-size: 20px;
        right: -7px;
        bottom: 25px;
    }
}
/* popup */
.jobDescripton h5, .companyInfo h5{
	font-size: 1.5rem;
	padding-bottom: 1.5rem;
}
.jobDescripton dl, .companyInfo dl{
	display: flex;
	margin: 0;
}
.jobDescripton dl, .companyInfo dl{
	border:solid #333;
	border-width:1px 1px 0 ;
}
.jobDescripton dl:last-of-type, .companyInfo dl:last-of-type{
	border-bottom:solid #333 1px;
}

.jobDescripton dl *, .companyInfo dl *{
	line-height: 1.5em;
	letter-spacing: 0.1em;
}
.jobDescripton dl dt, .companyInfo dl dt{
	width:30%;
	text-align:right;
	background-color:#ddd;
	padding: 1.5rem 1rem 1.5rem;
	font-weight: bold;
	font-family: sans-serif;
	font-size: 0.9rem;
	color: #333;
	border-right:solid #333 1px;
}
.jobDescripton dl dd, .companyInfo dl dd{
	width:70%;
	margin-bottom:0;
	padding: 1.5rem 1rem 1.5rem;
	font-size: 0.9rem;
	color: #666;
}
@media screen and (max-width:768px) {
	.jobDescripton h5, .companyInfo h5{
		font-size: 1.3rem;
	}
	.jobDescripton dl, .companyInfo dl{
		flex-direction: column;
		border:solid #ddd 2px;
		margin-top:0.8rem;
	}
	.jobDescripton dl:first-of-type, .companyInfo dl:first-of-type{
		border-top:solid #ddd 2px;
	}
	.jobDescripton dl:last-of-type, .companyInfo dl:last-of-type{
		border-bottom:solid #ddd 2px;
	}
	.jobDescripton dl dt, .jobDescriptone dl dd, .companyInfo dl dt, .companyInfo dl dd{
		width: 100%;
		font-size: 0.8rem;
		text-align:left;
		border:none;
	}
	.jobDescripton dl dt, .companyInfo dl dt{
		padding: 1rem;
	}
	.jobDescripton dl dd, .companyInfo dl dd{
		padding: 1.5rem 1rem;
	}
}
@media screen and (max-width:767px){
	.conceptTxt-emphasize1{
		background-color: var(--colorAccent1);
		padding: 0.5em 0.3em;
		line-height: 2.5em;
	}
	.multiplicationMark::after{
		position: absolute;
		content: "×";
		font-weight: 100;
		font-size: 20px;
		right: -7px;
		bottom: 25px;
	}
}

/* 下からふわっと表示 */
.effect-fade {
	opacity : 0;
	transform : translate(0, 150px);
	transition : all 1000ms;
}


.effect-fade.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}

/* ueからふわっと表示 
.effect-fade-ue {
opacity : 0;
transform :translateY(-150px);
transition : all 1000ms;
}


.effect-fade-ue.effect-scroll {
opacity : 1;
transform : translate(0, 0);
}


/*右からふわっと表示 


.effect-fade-migi {
opacity : 0;
transform : translateX(150px);
transition : all 1000ms;
}

.effect-fade-migi.effect-scroll {
opacity : 1;
transform : translate(0, 0);
}


/*左からふわっと表示 

.effect-fade-migi2 {
opacity : 0;
transform : translateX(-150px);
transition : all 1000ms;
}

.effect-fade-migi2.effect-scroll {
opacity : 1;
transform : translate(0, 0);
}




/*下から0秒遅れてふわっと表示 */
.effect-fade-delay0 {
	opacity : 0;
	transform : translate(0, 150px);
	transition : all 1000ms;
	transition-delay :0s;
}

.effect-fade-delay0.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}

/*下から0.5秒遅れてふわっと表示*/
.effect-fade-delay {
	opacity : 0;
	transform : translate(0, 150px);
	transition : all 1000ms;
	transition-delay :0.5s;
}

.effect-fade-delay.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}


/*下から1秒遅れてふわっと表示*/


.effect-fade-delay2 {
	opacity : 0;
	transform : translate(0, 150px);
	transition : all 1000ms;
	transition-delay :1s;
}

.effect-fade-delay2.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}

/*下から２.5秒遅れてふわっと表示 */


.effect-fade-delay3 {
	opacity : 0;
	transform : translate(0, 150px);
	transition : all 1000ms;
	transition-delay :1.5s;
}

.effect-fade-delay3.effect-scroll {
	opacity : 1;
	transform : translate(0, 0);
}

@media only screen and (max-width: 750px) {
	/*下から1秒遅れてふわっと表示 */
	.effect-fade-delay {
		opacity : 0;
		transform : translate(0, 150px);
		transition : all 1000ms;
		transition-delay :0s!important;
	}
	/*下から２秒遅れてふわっと表示 */
	.effect-fade-delay2 {
		opacity : 0;
		transform : translate(0, 150px);
		transition : all 1000ms;
		transition-delay :0s!important;
	}


	/*下から２.5秒遅れてふわっと表示  */


	.effect-fade-delay3 {
		opacity : 0;
		transform : translate(0, 150px);
		transition : all 1000ms;
		transition-delay :0s!important;
	}

}


/*画像ワイプ 黒 */
.img-wrap2 {
	opacity: 1;
}

.img-animation {
	animation: img-opacity 1s cubic-bezier(.4, 0, .2, 1);
	overflow: hidden;
	position: relative;
}

.img-animation:before {
	animation: img-animation 1s cubic-bezier(.4, 0, .2, 1) forwards;
	background: #fff;
	bottom: 0;
	content: '';
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}

@keyframes img-opacity {
	100% {
		opacity: 1;
	}
}

@keyframes img-animation {
	100% {
		transform: translateX(-100%);
	}
}

/*ヘッダーシャドウを非表示*/
.header {
	box-shadow: 0 3px 6px rgb(0 0 0 / 0%)!important;
}

.mw_wp_form p{
	font-family: --font-sans-serif;
	font-weight: 500;
	padding-bottom: 1.5rem;
}

.mw_wp_form input{
	margin-top: 0.7rem;
}
.mw_wp_form .inputBox {
	box-shadow: inset 0 0 0.2em #0005!important;
}
.inputSubmit{
	padding:0.2em 2em;
	background-color: var(--color-primary-black);
	border-color: var(--color-primary-black);
	color: var(--color-primary-white);
	font-weight:600;
}
.inputSubmit:hover{
	background-color: var(--color-primary-white);
	color: var(--color-primary-black);
	transition:0.2s;
}
.resume p{
	display:inline-block;
	background-color: var(--color-primary-black);
	border:2px solid var(--color-primary-black);
	color: var(--color-primary-white);
	padding:0.1em 0.7em;
	font-weight:600;
	font-size: 1rem;
}
.resume a{
	color:var(--color-primary-white);   
}
.resume p a:visited{
	color: var(--color-primary-white)f;
}
.resume p:hover {
	background-color:var(--color-primary-white);
	color:var(--color-primary-black);
	transition:0.2s;
}
.resume p:hover a{
	color:var(--color-primary-black);
}





.footer #footer-menu {
    background-color: #BFAF7F;
}
.footer #footer-menu a, .footer .copyright {
    color: #FFF; 
}


/* コメント非表示 */
.comment-respond {
    display: none!important;
}
/* 投稿記事調整 */
.sns-btn {
    display: none!important;
}

/*コンタクトフォーム */
button, html input[type="button"], input[type=reset], input[type=submit] {
	-webkit-appearance: button;
	cursor: pointer;
	background: #444;
	color: #fff;
	padding: 3px 20px;
}
.mw_wp_form p,.mw_wp_form div{
	line-height: 2em !important;
	font-size:14px;
	font-weight:bold !important;
	clear:both;
}
.mw_wp_form h5 {
	margin-top:5%;
}


.mw_wp_form input [type="text"] .field{
    margin-top: 0.7rem;
    background-color: #efefef!important;
}

/*スマホドロワータイトル非表示 */
.drawer__title {
    color: #FFF;
    display: none!important;}

#drawer__content {
    padding-left: 20px !important;}

/*スマホロゴ調整 */
@media only screen and (max-width: 750px) {
#logo img{
height:150px!important;
}

#inner-header {
    max-width: 96%;
    display: flex;
    justify-content: space-between;
    margin-top: -8%;
}}

/*メニュー固定 */
@media screen and (min-width: 1200px){
.headerContainer {
    width: 100%;
    padding: 10px 1%;
    position: fixed;
}}

/*トップページのみロゴ非表示 */
.page-id-4075 .headerLogo img {
    display:none!important;
}

 .headerLogo img {
    width: 150px!important;
}