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

.barlow {
    font-family: "Barlow", sans-serif;
    font-weight: 600;
    font-style: normal;
}
.barlow700 {
    font-family: "Barlow", sans-serif;
    font-weight: 700;
    font-style: normal;
}
.h2img {
	width: 154px;
	margin-left: auto;
}
@media screen and (max-width: 768px) {

}
.h3Wrap {
	background: url("../img/welfare/main.jpg") no-repeat center center;
	background-size: cover;
	min-height: 520px;
	padding-top: 245px;
}
.h3 {
	font-size: 48px;
	text-shadow: 0 0 5px rgba(0,0,0,.75);
	color: #fff;
	line-height: 1.25;
}
.h3 small {
	display: block;
	font-size: 33.333%;
	line-height: 3.5;
}
@media screen and (max-width: 768px) {
    .h3Wrap {
        background-size: 152%;
		background-position: 50% 0;
		aspect-ratio: 400 / 225;
		min-height: auto;
		padding-top: 27.5vw;
    }
    .h3 {
        font-size: calc(100vw * 48 / 768);
    }
}
@media screen and (max-width: 480px) {
    .h3Wrap {
        background-size: 152%;
		background-position: 50% 0;
		aspect-ratio: 400 / 225;
		min-height: auto;
		padding-top: 27.5vw;
    }
    .h3 {
        font-size: calc(100vw * 24 / 400);
    }
    .h3 small {
        font-size: 47.5%;
        line-height: 2.5;
    }
}
.txt01 {
	padding-top: 100px;
	font-size: 18px;
	line-height: 2.2;
}
@media screen and (max-width: 768px) {
    .txt01 {
        padding-top: 75px;
    }
    .txt01.tac {
        text-align: left;
    }
}
@media screen and (max-width: 480px) {
    .txt01 {
        padding-top: 8vw;
        font-size: calc(100vw * 14 / 400);
    }
}
.section {
	padding: 100px 0;
}
.h4 {
	font-size: 34px;
	border-bottom: 1px solid #000;
	padding-bottom: 0.75rem;
}
.h4 small {
	display: block;
	font-size: 47%;
	color: #c8c8c8;
}
.br900 {
	display: none;
}
.h5 {
	font-size: 24px;
}
.sectionFlex {
	display: flex;
	justify-content: space-between;
	flex-flow: wrap;
	gap: 2.5rem 0;
}
.sectionWrap {
	width: 48%;
	border-radius: 20px;
	background-color: #faf3c5;
	padding: 30px;
}
.headFlex {
	display: flex;
	align-items: center;
	/*gap: 30px;*/
	border-bottom: 1px dashed #000;
	margin-bottom: 1rem;
	padding-bottom: 1rem;
	flex-direction: column;
	gap: 15px;
}
.headFlex span {
	display: block;
}
.s1ico {
	width: 96px;
	flex-shrink: 0;
}
.h6 {
	font-size: 21px;
	line-height: 1.5;
}
.txt02 {
	font-size: 16px;
	line-height: 2.0;
}
@media screen and (max-width: 900px) {
	.br900 {
        display: block;
    }
    .h4 {
        line-height: 1.4;
    }
    .h4 small {
		padding-bottom: 0.75rem;
    }
    /*.headFlex {
        gap: 10px;
    }*/
}
@media screen and (max-width: 768px) {
    /*.h4 {
		font-size: calc(100vw * 34 / 768);
    }
    .h5 {
		font-size: calc(100vw * 24 / 768);
    }
    .h6 {
		font-size: calc(100vw * 21 / 768);
    }*/
    .sectionFlex {
        gap: 25px;
    }
    .sectionWrap {
        width: 100%;
    }
    .headFlex {
        flex-direction: row;
        gap: 2.5vw;
    }
    .headFlex span {
        display: none;
    }
}
@media screen and (max-width: 480px) {
    .section {
        padding: 15vw 0;
    }
    .h4 {
		font-size: calc(100vw * 24 / 400);
    }
    .h5 {
		font-size: calc(100vw * 18 / 400);
    }
    .h6 {
		font-size: calc(100vw * 18 / 400);
    }
    .txt02 {
        font-size: 14px;
    }
    .sectionFlex {
        gap: 5vw;
    }
    .sectionWrap {
        padding: 5vw;
    }
    .s1ico {
        width: 20vw;
    }
}
.bgSection {
	background-color: #fdfbee;
}
.section2 .sectionFlex {
}
/*.section2 .sectionWrap {
	width: 30.6%;
}*/
.section2 .headFlex {
	/*flex-direction: column;*/
	gap: 15px;
}
.section2 .s1ico {
	width: 92px;
}
.section2 .s1ico.adjust {
	padding: 10px 0;
}
.section2 .h6 {
	line-height: 1.4;
	text-align: center;
}
.section2 .h6.h6kurumin {
	padding-bottom: 10px;
}
.section2 .h6 small {
	font-size: 66.666%;
	display: block;
}
@media screen and (max-width: 768px) {
    .section2 .sectionWrap {
        width: 100%;
    }
    .section2 .headFlex {
        flex-direction: row;
        gap: 5vw;
    }
    .section2 .s1ico.adjust {
        padding: 0;
    }
    .section2 .h6 {
        line-height: 1.6;
        text-align: left;
    }
    .section2 .h6.h6kurumin {
        padding-bottom: 0;
    }
}
@media screen and (max-width: 480px) {
    .section2 .s1ico {
        width: 15vw;
	}
}
.section3 .s1ico {
	width: 116px;
}
.section3 .sectionWrap.col3 {
	width: 30.6%;
}
@media screen and (max-width: 768px) {
    .section3 .sectionWrap.col3 {
        width: 100%;
    }
    /*.section3 .headFlex {
        gap: 2vw;
    }*/
}
@media screen and (max-width: 480px) {
    .section3 .s1ico {
        width: 21.5vw;
	}

}
.bgSection2 {
	background-color: #f2e06e;
}
.txt03 {
	font-size: 18px;
	width: fit-content;
	margin: auto;
	border-bottom: 1px dashed #000;
}
.h4data {
	font-size: 34px;
}
.section4 .sectionWrap {
	width: 30.6%;
	background-color: #fff;
}
.h5data {
	font-size: 21px;
	border-bottom: 1px dashed #000;
	padding-bottom: 0.75rem;
	margin-bottom: 1.25rem;
}
.h5data small {
	font-size: 66.666%;
}
@media screen and (max-width: 768px) {
    .section4 .sectionFlex {
        gap: 5vw 0;
    }
    .section4 .sectionWrap {
        width: 47.222%;
    }
    .h5data {
        padding-bottom: 0.25rem;
        margin-bottom: 0.5rem;
    }
}
@media screen and (max-width: 480px) {
    .txt03 {
        font-size: calc(100vw * 14 / 400);
    }
    .h4data {
        font-size: calc(100vw * 24 / 400);
    }
    .h5data {
        font-size: calc(100vw * 16 / 400);
    }
}
.txt04 {
	font-size: 24px;
	line-height: 1.5;
	width: fit-content;
	margin: auto;
	border-bottom: 1px solid #000;
	padding-top: 100px;
}
.txt05 {
	font-size: 16px;
	line-height: 2.6;
}
@media screen and (max-width: 480px) {
    .txt04 {
        font-size: 21px;
        padding-top: 8vw;
    }
    .txt05 {
        font-size: 14px;
    }
}





































