@charset "utf-8";

#relief h1 {
        font-family: 'Kiwi Maru', serif;
        position: absolute;
        top: 3.5vw;
        left: 10%;
        z-index: 1;
        color: #ffffff;
	font-size: 7vw;
	font-weight: normal;
}

.relief-header {
        max-width: 1200px;
	width: 94%;
        margin: 3% auto;
        padding-bottom: 5px;   
}

.relief-header .header-inner {
        height: 23vw;
	position: relative;
        background-color: #20aee5;
        border-radius: 5px;
}

.relief-header .relief-img-ico {
        position: absolute;
        bottom: 0;
        right: 10%;
        width: 25%;
        height: auto;
        object-fit: cover;
}

/* main */
.relief-main .main-inner{
        max-width: 1200px;
	width: 94%;
        margin: 0 auto;
        padding-bottom: 4rem;
        text-align: justify;
}
.relief-main .top-title {
        margin-bottom: 20px;
}

.relief-main .top-title-box {
        font-family: 'Kiwi Maru', serif;
        padding: 0.5rem;
        border-top: solid 1px #20aee5;
        border-bottom: solid 1px #20aee5;
        color: #20aee5;
        text-align: center;
        margin: 1rem auto;
}

.relief-main .top-title-text {
        margin-bottom: 10px;
}

.relief-main h3 {
        font-family: 'Kiwi Maru', serif;
        font-size: 18.5px;
        padding-left: 5px;
        margin: 20px auto;
        border-left: 4px solid #20aee5;
}

/* step */

#relief .mb30 {
        margin-bottom: 30px;
}

.relief-main .relief-step-box {
        padding: 0;
        list-style-type: none;
}

.relief-main .relief-step-list {
        position: relative;
}

.relief-main .flow > li:not(:last-child) {
        margin-bottom: 40px;
}

.relief-main .relief-step-box .relief-list-style {
        position: relative;
        margin: 20px auto;
        width: 100%;
        padding: 10px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        border: 2px solid #e85298;
        border-radius: 10px;
}

.relief-main .flow > li:not(:last-child) dl::before,
.relief-main .flow > li:not(:last-child) dl::after { 
        content: "";
        border: solid transparent;
        position: absolute;
        top: 100%;
        left: 50%;
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
}

.relief-main .flow > li:not(:last-child) dl::before {
        border-width: 22px;
        border-top-color: #e85298;
}

.relief-main .flow > li:not(:last-child) dl::after {
        border-width: 20px;
        border-top-color: #fff;
}

.relief-main .flow > li dl dt {
        font-size: 1.5rem;
        font-weight: 600;
        color: #e85298;
        -ms-flex-preferred-size: 20%;
        margin-right: 2vw;
        text-align: center;
}

.relief-main .flow > li dl dt .icon {
        width: 8rem;
        font-size: 12px;
        color: #fff;
        background: #e85298;
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6b90db', endColorstr='#66d5e9',GradientType=1 );
        padding: 5px;
        margin-bottom: 10px;
        display: block;
        border-radius: 20px;
        position: relative;
        z-index: 100;
        font-family: 'Kiwi Maru', serif;
}

.relief-main .step-title {
        font-family: 'Kiwi Maru', serif;
}

.relief-main .anshin-point {
        position: relative;
        width: 100%;
        height: 55vw;
        border-radius: 5px;
        background-image: url(../images/anshin_point01.png),url(../images/anshin_point_text01.png);
        background-position: bottom left 3%,top 10% right 4%;
        background-repeat: no-repeat,no-repeat;
        background-size: 45% auto,60% auto;
        background-color: #e85298;
}

.relief-main .anshin-01 p{
        position: absolute;
        top: 30%;
        right: 4%;
        width: 48%;
        height: auto;
        font-family: 'Yomogi', cursive;
        font-weight: bold;
        color: #ffffff;
        text-align: justify;
}

.relief-main .anshin-point,
.relief-main .anshin-point02,
.relief-main .anshin-point03 {
        margin-bottom: 20px;
}

.relief-main .top-title .relief-img {
        width: 100%;
        height: 60vw;
        object-fit: cover;
}

.relief-main .relief-step-box {
        list-style-type: none;
}

.relief-main .relief-step-text {
        margin: 5px auto;
}

.relief-main .relief-list-arrow {
        text-align: center;
}

.relief-main .relief-arrow {
        width: 30px;
        height: 30px;
}

.relief-main .relief-step-point {
        width: 100%;
        height: 60vw;
        object-fit: cover;
        object-position: top center;
        margin: 10px auto 0px;
}

.relief-main .anshin-point02 {
        position: relative;
        width: 100%;
        height: 55vw;
        border-radius: 5px;
        background-image: url(../images/anshin_point02.png),url(../images/anshin_point_text02.png);
        background-position: bottom left 3%,top 10% right 4%;
        background-repeat: no-repeat,no-repeat;
        background-size: 45% auto,60% auto;
        background-color: #e85298;
}

.relief-main .anshin-02 p{
        position: absolute;
        top: 30%;
        right: 4%;
        width: 48%;
        height: auto;
        font-family: 'Yomogi', cursive;
        font-weight: bold;
        color: #ffffff;
        text-align: justify;
}

.relief-main .anshin-point03 {
        position: relative;
        width: 100%;
        height: 60vw;
        border-radius: 5px;
        background-image: url(../images/anshin_point03.png),url(../images/anshin_point_text03.png);
        background-position: bottom left 3%,top 10% right 4%;
        background-repeat: no-repeat,no-repeat;
        background-size: 40% auto,60% auto;
        background-color: #e85298;
}

.relief-main .anshin-03 p{
        position: absolute;
        top: 25%;
        right: 4%;
        width: 50%;
        height: auto;
        font-family: 'Yomogi', cursive;
        font-weight: bold;
        color: #ffffff;
        text-align: justify;
}

/* 24support-link */
.relief-contents-support .relief-support-btn {
        width: 60%;
        margin: 15px auto;
        border: 2px solid #20aee5;
        text-align: center;
        font-family: 'Kiwi Maru', serif;
        font-size: 1.5rem;
        border-bottom: 4px solid #20aee5;
        box-shadow: 0 1px 4px rgba(0, 0, 0, .3);
        border-radius: 100vh;
}

.relief-contents-support .relief-btn {
        display: block;
        padding: 16px;
        text-decoration: none;
}

@media screen and (min-width:768px) {

#relief h1 {
	position: absolute;
	left: 27%;
	top: 12rem;
        z-index: 1;
        color: #036eb8;
        font-family: 'Kiwi Maru', serif;
	font-weight: bold;
        font-size: 1.3rem;
}

#relief .relief-header .header-inner {
        margin-top: 8rem;
        height: 7rem;
        background-color: #bae3f9;
	background-image:
	radial-gradient(#d3edfb 20%, transparent 20%),
        radial-gradient(#d3edfb 20%, transparent 20%);
	background-size: 40px 40px;
	background-position: 0 0, 20px 20px;
}

#relief .pc-relief-title {
        position: absolute;
        left: 10%;
        bottom: 0;
        color: #036eb8;
        font-family: 'Kiwi Maru', serif;
	font-size: 4rem;
}

#relief .relief-header .relief-img-ico {
        position: absolute;
        right: 10%;
        width: auto;
        height: 150%;
	object-fit: contain;
}

#relief .relief-img {
	height: 10vw;
	object-fit: cover;
	object-position: center center;
}

#relief .relief-step-list{
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 3rem 0;
        margin-bottom: 0;
}

#relief .relief-step-box li {
        border-bottom: 1px dotted #e85298;
}

.relief-main .relief-step-box .relief-list-style {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        width: 70%;
        padding: 2rem;
        margin: 0 auto;
        border: none;
}

.relief-main .flow > li:not(:last-child) dl::before {
        border: none;
}

.circle {
        display: flex;
        flex-direction: column;
        justify-content: center;
        width: 11.5rem;
        height: 11.5rem;
        background-color: #e85298;
        border: 1px solid #e85298;
        border-radius: 50%;
        text-align: center;
}

.relief-main .flow > li dl dt .icon {
        width: auto;
        margin-bottom: 0;
        font-size: 1.5rem;
        color: #ffffff;
        background: none;
}

.relief-main .relief-step-text {
        margin: 0;
}

.relief-list-style dd {
        padding: 0 2rem;

}

.step-title {
        font-size: 1.8rem;
        color: #ffffff;
        font-weight: normal;
}

#relief .photo-wrap {
        width: 50%;
        margin: 0 auto
}

#relief .relief-step-point {
        width: 100%;
        height: auto;
        object-fit: contain;
}

.relief-main .anshin-point,
.relief-main .anshin-point02,
.relief-main .anshin-point03 {
        width: 50%;
        margin: 0 auto 20px;
        height: 30rem;
}

.raiten-text {
        margin-bottom: 20px;
}

.relief-main .anshin-point {
        display: flex;
        justify-content: flex-end;
        height: 20rem;
        background-image: url(../images/anshin_point01.png),url(../images/anshin_point_text01_pc.png);
        background-position: bottom left 3%,top 0 left 0;
        background-size: 30% auto,40% auto; 
        background-color: #ffffff;
}


#relief .anshin-point02 {
        display: flex;
        justify-content: flex-end;
        height: 18rem;
        background-image: url(../images/anshin_point02.png),url(../images/anshin_point_text02_pc.png);
        background-position: bottom left 3%,top 0 left 0;
        background-size: 25% auto,40% auto;
        margin-right: 2rem;
        background-color: #ffffff;
}

#relief .anshin-point03 {
        display: flex;
        justify-content: flex-end;
        height: 18rem;
        background-image: url(../images/anshin_point03.png),url(../images/anshin_point_text03_pc.png);
        background-position: bottom left 20%,top 0 left 10%;
        background-size: 20% auto,40% auto;
        background-color: #ffffff;
}

.box {
        position: relative;
        width: 50%;
        padding: 0.5rem;
        background-color: #fbfad3;
        box-shadow: 0 0 0 0.5rem #fbfad3;
        border-left: 10px dotted white;
}

.box::before {
        position: absolute;
        top: 2.5rem;
        left: 0.5rem;
        width: calc(100% - 1rem);
        height: calc(100% - 3.5rem);
        background-image: repeating-linear-gradient(#e0e0e0 0 0.5px, transparent 0.8px 26px);
        content: '';
}

.box::after {
        position: absolute;
        bottom: 0.5rem;
        right: 0;
        width: 50%;
        height: 20%;
        box-shadow: 0 10px 15px #999;
        transform: rotate(4deg);
        content: '';
        z-index: -1;
}

.relief-main .anshin-point p,
.relief-main .anshin-02 p,
.relief-main .anshin-03 p {
        top: 3%;
        z-index: 1;
        width: auto;
        padding: 5px;
        font-size: 1.6rem;
        color: #e85298;
} 

.relief-main .flow > li:not(:last-child) {
        margin-bottom: 0;
}

.supplement {
        padding-bottom: 1rem;
}


}