@charset "utf-8";
/* CSS Document */



/*メインビジュアル*/

.conA{
	padding-top: 84px;
}

.conA .container{
	display: flex;
	justify-content: space-around;
	margin-bottom: 20px;
	background: #C4E9CF;
	height: 150px;
	background-image: linear-gradient(rgba(255,255,255,0.7), rgba(255,255,255,0.7)), url(../img/hakajimai/main.jpg);
	background-position: center 50%;
	position: relative;
	background-size: cover;
}

.conA .text{
	text-align: center;
			flex: 1;
		display: flex;
		justify-content: center;
		align-items: center;
}

.conA h1{
	font-size: 24px;
	letter-spacing: 0.1em;
	font-family: "Noto Serif JP", serif;
	font-weight:600;
	text-shadow: 0px 0px 2px #fff;
	
}

@media print, screen and (min-width: 768px){
	
.conA{
	padding-top:150px;
}	
	
.conA .container{
	
	display: flex;
	justify-content: space-around;
	height: 300px;
	margin-bottom: 30px;
	
}
	
	.conA .text{

	}
	
.conA h1{
	font-size: 34px;
}	
	
	
}


h2.flow{
	margin-bottom: 1em;
	color: #3675bb;
}




.post .container{
	width: 90%;
	max-width: 800px;
	margin: 0 auto 20px;
}


@media print, screen and (min-width: 768px){
	
	
.post .container{
	margin-bottom: 60px;
}	
	
	
	
	.post .container p{
		font-size: 18px;
		line-height: 1.6em;
		margin-bottom: 2em;
	}	

}




/*２カラム*/


.conB .container{
	max-width: 800px;
	margin: 0 auto;
	padding: 1em;
	box-sizing: border-box;
}

.conB h2{
	font-family: "Noto Serif JP", serif;
	margin-bottom: 1em;
}

.conB h3{
	text-align: center;
	margin-bottom: 0.5em;
	font-weight: 500;
	font-size: 20px;
}

.conB .text{
	/*margin-bottom: 20px;*/
}

.conB.service .text{
	margin-bottom: 40px;
}

.conB img{
	display: block;
	width: 90%;
	margin: 0 auto 10px;
}


.conB p{
	margin-bottom: 1em;
}

@media print, screen and (min-width: 768px){
	
.conB .container{
	display: flex;
	gap:10px;
	margin-bottom: 30px;
}	
	
	
	.conB .text{
		flex: 1;
		margin-bottom: 0;
	}
	
	.conB h2{
		font-size: 32px;
	}
	
	.conB h3{
		font-size: 20px;
	}
	
	.conB p{
		font-size: 18px;
	}
	

}
	.conB.soudan{
		margin-bottom: 50px;
}	

.conB.soudan .container{
	max-width: 1000px;
}


.conB.pr .container{
	display: flex;
	justify-content: space-around;
}

@media print, screen and (min-width: 768px){
	
	.conB.soudan{
		margin-bottom: 80px;
}	
}


/*料金について*/


.price .container{
	width: 90%;
	max-width: 860px;
	margin: 0 auto 50px;
	border-radius: 20px;
	box-shadow: 0px 0px 5px #a39e9f;
	padding: 20px;
	box-sizing: border-box;
	background: #fff;
}

.price01{
	font-weight: 500;
	line-height: 1.6em;
	text-align: center;
	/*margin-bottom: 20px;*/
	font-size: 18px;
	margin-bottom: 1em;
}




.price02{
	font-weight: 500;
	line-height: 1.6em;
	text-align: center;
	margin-bottom: 20px;
	font-size: 18px;
}

@media print, screen and (min-width: 768px){
	
	
.price .container{
	/*display: flex;
	justify-content: space-around;
	align-items: center;*/
	padding:40px 80px;
	margin-bottom: 100px;
}	
	.price ul{
		margin-bottom: 50px;
	}	
	
	.price01{
		font-size: 24px;
		padding:0.5em 1em;
		box-sizing: border-box;
		text-align: left;
		border-bottom: 1px dashed #2B79C2;
	}
	
	.price02{
		font-size: 24px;
		box-sizing: border-box;
		text-align: left;
	}
	
	.price01 span.blue{
	float: right;
}
	
	
}






/*沿革用　年表*/

.dlBlock {
  position: relative;
}
 
.dlBlock:before {
  position: absolute;
  display: block;
  content: "";
  background: #ccc;
  width: 1px;
  height: 100%;
  z-index: -1;
	left: 59px;
	top:10px;
}
 
.dlBlock .dlInner {
  display: flex;
  align-items: flex-start;/*なくても問題ない？？*/
	margin-bottom: 1em;
}
 
.dlBlock dt {
  position: relative;
  color: #1b2680;
 /* line-height: 1;*/
  box-sizing: border-box;
  word-break: break-all;
	padding-right: 1em;
	font-weight: bold;
}
 
.dlBlock dt:before {
  position: absolute;
  display: block;
  content: "";
  top: .7em;
  right: 0;
  width: 7px;
  height: 7px;
  background: #1b2680;
  border-radius: 50%;
  transform: translateY(-50%);
}
 
.dlBlock dd {
  line-height: 1.5;
  flex: 1;
	padding-left: 1em;
	box-sizing: border-box;
}
 
@media only screen and (min-width: 769px), print {
  .dlBlock:before {
    top: 12px;
    left: 96px;
  }
  .dlBlock .dlInner {
    padding-bottom: 10px;
  }
  .dlBlock dt {
    width: 100px;
    padding-right: 15px;
    font-size: 18px;
  }
  .dlBlock dd {
    margin-left: 20px;
    font-size: 16px;
  }
}



/*工事前工事後*/

.mihon{
	text-align: center;
}


.mihon img{
	width: 80%;
}

.post .mihon p{
	margin-bottom: 0.2em;
}

.allow{
	text-align: center;
	margin: 20px auto;
}

@media print, screen and (min-width: 768px){
	
.post .mihon p{
	font-size: 20px;
}
	
	
}



/*dt {
  counter-increment: my-awesome-counter;
  margin: 0.25rem 0.25rem 0.5rem;
	font-size: 16px;
	font-weight: bold;
}
dt::before {
  content: counter(my-awesome-counter);
  background: #3675bb;
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 50%;
  display: inline-block;
  line-height: 1.4rem;
  color: white;
  text-align: center;
  margin-right: 0.5rem;
}*/


dl{
	margin-bottom: 50px;
}

dt{
	display: flex;
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 0.2em;
	/*align-items: center;*/
}

dd{
	margin-bottom: 2em;
	padding-left: 2em;
}


@media print, screen and (min-width: 768px){

	dt{
		font-size: 20px;
		margin-bottom: 0.5em;
	}
	
	dt::before{
		width: 2rem;
  height: 2rem;
  line-height: 2rem;
	}
	
	dd{
		margin-bottom: 3em;
		padding-left: 3em;
		font-size: 16px;
	}
	
	
}


.allow{
	text-align: center;
	margin: 20px auto;
	width: 20%;
}

@media print, screen and (min-width: 768px){
	
.allow{
	width: auto;
}
}


/*.circle01 {
	display: block;
  background: #3675bb;
  border-radius: 50%;
	border:1px solid #3675bb;
  padding: 0.5em;
	width: 14px;
	height: 14px;
  color: #fff;
  font-size: 16px;
  text-align: center;
  line-height: 14px;
	margin-right: 0.5em;
}
*/


.circle01 {
    /* 重要な変更点：flexを使って中央配置にする */
    display: flex;
    align-items: center;
    justify-content: center;
    background: #3675bb;
    border-radius: 50%;
    border: 1px solid #3675bb;
    color: #fff;
    margin-right: 0.3em;
    /* サイズ固定：paddingではなくwidth/heightで円の大きさを決める */
    width: 24px;   /* Qの文字に対して14pxは小さすぎるため調整 */
    height: 24px;
    flex-shrink: 0; /* 親がflexの時に潰れないようにする */
    
    /* Snow Monkeyの変数をこの要素内で上書き */
    --_font-size-level: 0 !important;
    font-size: 16px !important;
    line-height: 1 !important;
}


@media print, screen and (min-width: 768px){
	
.circle01 {
	width: 36px;
	height: 36px;
  font-size: 20px !important;
  line-height: 30px;
}}
