@charset "utf-8";

:root {
	--color-pink: #F48B90;
	--color-light-pink: #FFE6E8;
	--color-light-blue: #70B8CE;
}

/*===========================================================
voice01
===========================================================*/

.voice01 {
    max-width: 192rem;
    width: 100%;
    margin: 0 auto;
    padding: 11rem 1.5rem 5rem;
    background: url(../../../../uploads/voice01.jpg) center top / cover no-repeat;
}

.voice01-title-box {
    text-align: center;
    color: var(--color-pink);
}

.voice01-title {
    font-size: 4rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 1.75;
}

.voice01-title strong {
    padding: 0 1rem;
    color: var(--white);
    background: var(--color-pink);
}

.voice01-frame {
    margin: 3rem auto 0;
    padding: 3rem 4rem 3rem 3.5rem;
    max-width: 110.5rem;
    width: 100%;
    position: relative;
}

.voice01-illust01 {
    max-width: 41.1rem;
    width: 37.2%;
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
}

.voice01-illust02 {
    max-width: 17rem;
    width: 15.3%;
    position: absolute;
    bottom: 0;
    right: 0;
    margin: auto;
}

.voice01-container {
    padding: 2rem;
    background: var(--color-pink);
}

.voice01-area {
    padding: 4.6rem 1.5rem 5.5rem;
    background: var(--white);
}

.voice01-text-area {
    max-width: 80rem;
    width: 100%;
    margin: 0 auto;
}

.voice01-text-box {
    margin: 4rem 0 0;
    text-align: center;
    color: var(--color-pink);
}

.voice01-text-box:first-child {
    margin: 0;
}

.voice01-text-decoration {
    font-size: 2.3rem;
    line-height: 1.739130;
    background: linear-gradient(transparent 60%, #FFED61 60%);
}

/*===========================================================
voice02
===========================================================*/

.voice02 {
    margin: 0 auto;
    padding: 12rem 1.5rem 8rem;
    max-width: 192rem;
    width: 100%;
    background: var(--color-light-pink);
}

.voice02-frame {
    max-width: 132rem;
    width: 100%;
    margin: 0 auto;
}

.voice02-title-img-box {
    max-width: 41.3rem;
    width: 100%;
    margin: 0 auto;
}

.voice02-title-img-box img {
    width: 100%;
}

.voice02-container {
    max-width: 132rem;
    width: 100%;
    padding: 0 5rem 4rem;
	position: relative;
}

.voice02-illust-box {
    max-width: 15.8rem;
    width: 15%;
    position: absolute;
    right: 0;
    bottom: 0;
    margin: auto;
}

.voice02-area {
    max-width: 122rem;
    width: 100%;
    margin: 0 auto;
}

.voice02-block {
    margin: 7rem 0 0;
}

.voice02-point-text {
    font-size: 2.3rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    line-height: 2.60869;
}

.voice02-text-container {
    padding: 3rem 2rem 7rem;
    width: 100%;
    background: var(--white);
}

.voice02-text-area {
    max-width: 115rem;
    width: 100%;
    margin: 0 auto;
}

.voice02-text-block {
    margin: 8.5rem 0 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.voice02-text-block:first-child {
	margin: 0;
}

.voice02-text-box01 {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.voice02-text01 {
    font-size: 2.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    color: var(--color-light-blue);
}

.voice02-text01 strong {
    margin-left: 3rem;
    font-size: 4.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.voice02-text-box02 {
    padding: 2rem 0 0;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    border-top: 0.1rem solid var(--base-font-color);
}

.voice02-text02 {
	display: flex;
	align-items: center;
}

.voice02-text02::before {
	content: "";
	margin-right: 0.6rem;
	display: block;
	width: 2.8rem;
	height: 2.8rem;
    background: url(../../../../uploads/voice_illust03.svg) center top / cover no-repeat;
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (width <= 1920px) {


/*===========================================================

===========================================================*/



}


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (width <= 1024px) {


/*===========================================================
voice01
===========================================================*/

.voice01 {
    padding: 8rem 1.5rem 5rem;
}

/*===========================================================
voice02
===========================================================*/

.voice02 {
    padding: 10rem 1.5rem 8rem;
}

.voice02-text-box02 {
    grid-template-columns: repeat(3, 1fr);
}

} 


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (width <= 768px) {


/*===========================================================
voice01
===========================================================*/

.voice01-text-decoration {
    font-size: 2.3rem;
    line-height: 1.739130;
    background: linear-gradient(transparent 60%, #FFED61 60%);
}

.voice01-title {
    font-size: 3rem;
}

.voice01-text-decoration {
    font-size: 2.1rem;
}

/*===========================================================
voice02
===========================================================*/

.voice02 {
    padding: 8rem 1.5rem 8rem;
}

.voice02-text-box02 {
    grid-template-columns: repeat(2, 1fr);
}

} 


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (width <= 576px) {


/*===========================================================
voice01
===========================================================*/

.voice01 {
    padding: 6rem 1.5rem 5rem;
}

.voice01-title {
    font-size: 2.2rem;
}

.voice01-illust01 {
    width: 50%;
}

.voice01-illust02 {
    width: 27%;
}

.voice01-text-decoration {
    font-size: 2rem;
}

/*===========================================================
voice02
===========================================================*/

.voice02-container {
	padding: 0 3rem 4rem;
}

.voice02-point-text {
	font-size: 1.8rem;
}

.voice02-text-block {
	margin: 4.5rem 0 0;
}

.voice02-text-box02 {
    grid-template-columns: repeat(1, 1fr);
}

.voice02-text01 {
	font-size: 2rem;
}

.voice02-text01 strong {
	font-size: 2.5rem;
}

}


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (width <= 414px) {


/*===========================================================

===========================================================*/



}


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */