@charset "utf-8";
/*変数の宣言*****************************/
:root {
    --duration    : 0.3s;
    --page_back   : #FFFFFF;
    --font_color  : #000000;
    --font_red    : #FF405C;
    --font_blue   : #0C63BD;
    --back_red    : #F7C3BF;
    --back_yellow : #FEF9DB;
    --table_border: 1px solid #CBCBCB;
}
/***************************************/
#web_campaign *,
#web_campaign *::before,
#web_campaign *::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-text-size-adjust: none;
}
#web_campaign img {
    margin: 0;
    padding: 0;
    border-style: none;
    width: 100%;
    height: auto;
    vertical-align: bottom;
    display: inline;
}
#web_campaign a.button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 48px;
    max-width: 400px;
    font-weight: 600;
    color: #FFFFFF;
    background-color: var(--font_red);
    border-radius: 48px;
    text-decoration: none;
    position: relative;
}
#web_campaign a.button::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 22px;
    transform: translateY(-50%);
    aspect-ratio: 8/14;
    width: 8px;
    background: url(../img/arrow.svg) center center/cover no-repeat;
}
@media only screen and (min-width:960px) {
    #web_campaign a {
        transition: var(--duration) all;
    }
    #web_campaign a:hover {
        opacity: 0.7;
    }
    #web_campaign a.button {
        width: 272px;
    }
}
@media only screen and (min-width:1366px) {
    #web_campaign a.button {
        width: 340px;
        height: 60px;
        font-size: 2rem;
    }
    #web_campaign a.button::after {
        width: 10px;
    }
}
#web_campaign sup {
    vertical-align: top;
}
#web_campaign sub {
    vertical-align: bottom;
}
#web_campaign .red {
    color: var(--font_red);
}
#web_campaign .blue {
    color: var(--font_blue);
}
#web_campaign ul.atte > li {
    display: flex;
    flex-flow: nowrap;
    align-items: flex-start;
}
#web_campaign ul.atte > li::before {
    content: "※";
}
#web_campaign ul.atte.number {
    counter-reset: number 0;
}
#web_campaign ul.atte.number > li {
    column-gap: 0.5em;
}
#web_campaign ul.atte.number > li:before {
    counter-increment: number 1;
    content: "※"counter(number);
}
#web_campaign ol.number {
    counter-reset: number 0;
}
#web_campaign ol.number > li {
    display: flex;
    flex-flow: nowrap;
    align-items: flex-start;
    column-gap: 0.5em;
}
#web_campaign ol.number > li::before {
    display: flex;
    justify-content: center;
    align-items: center;
    aspect-ratio: 1/1;
    width: 20px;
    line-height: 1;
    counter-increment: number 1;
    content: counter(number);
    border: 1px solid var(--font_color);
    border-radius: 100%;
    font-size: 80%;
    margin-top: 0.4em;
}
#web_campaign ol.number > li > * {
    width: calc(100% - 1em);
}
/*indent***************/
#web_campaign .indent {
    position: relative;
    overflow: hidden;
}
#web_campaign .indent .text {
    display: block;
    text-indent: 150%;
    white-space: nowrap;
    overflow: hidden;
    position: absolute;
    top: 0px;
    left: 0px;
}
/**********************/
/* main_img *****************/
#main_img {
    background-color: var(--back_yellow);
}
/****************************/
/* about ********************/
#about {
    padding: 30px 37px 50px 37px;
    background-color: var(--back_yellow);
}
#about .box {
    display: flex;
    flex-flow: column;
    row-gap: 20px;
    margin: 0 auto 0 auto;
    padding: 36px 17px 17px 17px;
    border-radius: 20px;
    max-width: 500px;
    background-color: #FFFFFF;
    font-weight: 700;
    text-align: center;
    position: relative;
}
#about .box p span {
    display: inline-block;
}
#about .box ul.atte {
    display: flex;
    justify-content: center;
}
#about .box ul.atte > li {
    text-align: left;
}
#about .box .icon.type1 {
    display: none;
    bottom: 5px;
    left: 0;
    width: 95px;
}
#about .box .icon.type2 {
    margin: -16px auto 0 auto;
    bottom: -4px;
    right: 8px;
    width: 51px;
}
@media only screen and (min-width:670px) {
    #about {
        padding: 30px 20px 50px 20px;
    }
    #about .box {
        padding-bottom: 30px;
        row-gap: 15px;
        max-width: 650px;
    }
    #about .box ul.atte > li {
        width: calc(100% - 120px - 70px);
        max-width: none;
    }
    #about .box .icon {
        position: absolute;
    }
    #about .box .icon.type1 {
        display: block;
        left: 15px;
        width: 120px;
    }
    #about .box .icon.type2 {
        margin-top: 0;
        right: 30px;
        width: 70px;
    }
}
@media only screen and (min-width:960px) {
    #about {
        padding: 44px 20px 64px 20px;
    }
    #about .box {
        max-width: 768px;
        padding: 46.4px 17px 48px 17px;
    }
    #about .box ul.atte > li {
        width: auto;
    }
    #about .box .icon.type1 {
        left: 28px;
        width: 140px;
    }
    #about .box .icon.type2 {
        bottom: -4.8px;
        right: 56px;
        width: 88px;
    }
}
@media only screen and (min-width:1366px) {
    #about .box {
        max-width: 960px;
        padding: 58px 17px 60px 17px;
        font-size: 2.0rem;
    }
    #about .box .icon.type1 {
        bottom: 0;
        left: 35px;
        width: 175px;
    }
    #about .box .icon.type2 {
        bottom: -6px;
        right: 70px;
        width: 110px;
    }
}
/****************************/
/* section.base *************/
#web_campaign section.base {
    padding: 50px 0 50px 0;
}
#web_campaign section.base .area {
    margin: 0 auto 0 auto;
    padding: 0 20px 0 20px;
}
#web_campaign section.base .area h2 {
    line-height: 1;
    margin: 0 auto 0 auto;
    max-width: 265px;
}
@media only screen and (min-width:670px) {
    #web_campaign section.base .area h2 {
        max-width: 375px;
    }
}
@media only screen and (min-width:960px) {
    #web_campaign section.base {
        padding: 56px 0 80px 0;
    }
    #web_campaign section.base .area {
        max-width: 768px;
        padding: 0;
    }
    #web_campaign section.base .area h2 {
        max-width: 542px;
    }
}
@media only screen and (min-width:1366px) {
    #web_campaign section.base {
        padding: 70px 0 100px 0;
    }
    #web_campaign section.base .area {
        max-width: 960px;
    }
}
/****************************/
/* campaign *****************/
#campaign {
    background-color: var(--back_red);
}
#campaign .period {
    text-align: center;
}
#campaign dl.overview {
    margin-top: 30px;
    display: flex;
    flex-flow: column;
    row-gap: 12px;
}
#campaign dl.overview > .block {
    border-radius: 8px;
    overflow: hidden;
}
#campaign dl.overview > .block > dt {
    background-color: var(--font_red);
    padding: 10px 0 10px 0;
    font-size: 2rem;
    font-weight: 700;
    text-align: center;
    line-height: 1.15;
    color: #FFFFFF;
}
#campaign dl.overview > .block > dd {
    background-color: #FFFFFF;
    padding: 12px 20px 15px 20px;
}
#campaign dl.overview .center {
    text-align: center;
}
#campaign dl.yonden {
    margin-top: 12px;
    display: flex;
    flex-flow: column;
    row-gap: 12px;
}
#campaign dl.yonden > .block {
    display: flex;
    flex-flow: column;
    border-radius: 8px;
    overflow: hidden;
    background-color: #FFFFFF;
}
#campaign dl.yonden > .block > dt {
    padding: calc(10px + 12px) 0 5px 0;
    text-align: center;
}
#campaign dl.yonden > .block > dt img {
    width: calc(90px * 1.2);
}
#campaign dl.yonden > .block > dd {
    padding: 12px 20px 20px 20px;
}
#campaign dl.yonden > .block > dd > .box {
    display: flex;
    flex-flow: column;
    row-gap: 20px;
}
#campaign dl.yonden > .block > dd > .box .img {
    text-align: center;
}
#campaign dl.yonden > .block > dd > .box .img img {
    width: 200px;
}
#campaign dl.point {
    font-weight: bold;
    display: table;
}
#campaign dl.point > .block {
    display: table-row;
}
#campaign dl.point > .block > * {
    display: table-cell;
    text-align: right;
}
#campaign dl.point > .block > dt::after {
    content: "：";
}
#campaign dl.important {
    margin-top: 20px;
}
#campaign dl.important > .block > dt {
    font-weight: bold;
}
#campaign dl.important > .block > dt::before {
    content: "【";
}
#campaign dl.important > .block > dt::after {
    content: "】";
}
#campaign dl.important > .block > dd {
    font-size: 1.4rem;
}
#campaign dl.important ul {
    padding-left: 1.5em;
}
#campaign dl.important ul > li {
    display: list-item;
    list-style: disc;
}
#campaign dl.important ul > li::marker {
    font-size: 1.0rem;
}

@media only screen and (min-width:960px) {
    #campaign .period {
        text-align: left;
    }
    #campaign dl.overview {
        margin-top: 32px;
    }
    #campaign dl.overview > .block {
        display: flex;
        flex-flow: nowrap;
    }
    #campaign dl.overview > .block > dt {
        width: 196px;
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        font-size: 1.84rem;
    }
    #campaign dl.overview > .block > dd {
        width: calc(100% - 196px);
        padding: 16px;
    }
    #campaign dl.yonden > .block {
        flex-flow: nowrap;
        align-items: center;
    }
    #campaign dl.yonden > .block > dt {
        width: 196px;
        padding: 0;
    }
    #campaign dl.yonden > .block > dt img {
        width: 120px;
    }
    #campaign dl.yonden > .block > dd {
        width: calc(100% - 196px);
        padding: 16px;
    }
    #campaign dl.yonden > .block > dd > .box {
        flex-flow: nowrap;
        align-items: center;
        justify-content: space-between;
    }
    #campaign dl.yonden > .block > dd > .box p {
        width: 349px;
    }
    #campaign dl.yonden > .block > dd > .box .img {
        width: 147px;
    }
    #campaign dl.yonden > .block > dd > .box .img img {
        width: 100%;
    }
}
@media only screen and (min-width:1366px) {
    #campaign dl.overview {
        margin-top: 40px;
        row-gap: 15px;
    }
    #campaign dl.overview > .block {
        border-radius: 10px;
    }
    #campaign dl.overview > .block > dt {
        width: 245px;
        font-size: 2.3rem;
    }
    #campaign dl.overview > .block > dd {
        padding: 20px;
        width: calc(100% - 245px);
    }
    #campaign dl.yonden > .block > dt {
        width: 245px;
    }
    #campaign dl.yonden > .block > dd {
        width: calc(100% - 245px);
        padding-right: 32px;
    }
    #campaign dl.yonden > .block > dd > .box p {
        width: 436px;
    }
    #campaign dl.yonden > .block > dd > .box .img {
        width: 184px;
    }
    #campaign dl.important {
        margin-top: 25px;
    }
}
/****************************/
/* process ******************/
#process {
    background-color: var(--back_yellow);
}
#process ol.step {
    max-width: 500px;
    margin: 44px auto 0 auto;
    display: flex;
    flex-flow: column;
    row-gap: 44px;
}
#process ol.step > li {
    display: flex;
    flex-flow: column;
    row-gap: 15px;
    background-color: #FFFFFF;
    padding: 45px 25px 55px 25px;
    border: 3px solid #999999;
    border-radius: 20px;
    position: relative;
}
#process ol.step .icon {
    text-align: center;
}
#process ol.step .icon img {
    width: 120px;
}
#process dl.setp_content > .block {
    display: flex;
    flex-flow: column;
    row-gap: 15px;
}
#process dl.setp_content > .block > dd {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
}
#process dl.setp_content .title {
    text-align: center;
    height: 26px;
}
#process ol.step > li:nth-child(3) dl.setp_content .title {
    height: 60px;
}
#process dl.setp_content .title img {
    width: auto;
    height: 100%;
}
#process dl.setp_content .img {
    width: 60px;
    aspect-ratio: 1/1;
    position: absolute;
    top: calc(0px - 3px/2 - 30px);
    left: calc(50% - 30px);
}
#process dl.info > .block {
    display: flex;
    flex-flow: column;
    row-gap: 8px;
}
#process dl.info > .block > dt {
    text-align: center;
    font-size: 1.8rem;
    font-weight: bold;
}
#process dl.info > .block > dt::before {
    content: "〈";
}
#process dl.info > .block > dt::after {
    content: "〉";
}
#process ul.orange > li {
    display: flex;
    flex-flow: wrap;
    column-gap: 0.3em;
    align-items: flex-start;
}
#process ul.orange > li::before {
    content: "";
    display: block;
    aspect-ratio: 1/1;
    width: 10px;
    background-color: var(--font_red);
    border-radius: 100%;
    margin-top: calc(1em * 1.625/2 - 5px);
}
#process ul.orange > li p {
    width: calc(100% - 10px - 0.3em);
}
#process ul.atte {
    margin-top: 15px;
    font-size: 1.4rem;
}

@media only screen and (min-width:670px) {
    #process ol.step {
        max-width: 650px;
    }
    #process ol.step > li:nth-child(3) dl.setp_content .title {
        height: 26px;
    }
}
@media only screen and (min-width:960px) {
    #process ol.step {
        max-width: none;
        margin-top: 64px;
        row-gap: 45.6px;
    }
    #process ol.step > li {
        padding: calc(40px + 16px) 0 40px 0;
        flex-flow: wrap;
        justify-content: center;
        align-items: center;
        column-gap: 32px;
    }
    #process ol.step .icon {
        display: flex;
        align-items: center;
        width: 128px;
    }
    #process ol.step .icon img {
        width: 100%;
    }
    #process dl.setp_content {
        width: 452px;
    }
    #process dl.setp_content > .block > dd {
        justify-content: flex-start;
    }
    #process dl.setp_content .title {
        text-align: left;
    }
    #process dl.setp_content .img {
        width: 68.8px;
        top: calc(0px - 3px/2 - 34.4px);
        left: calc(50% - 34.4px);
    }
    #process dl.info > .block > dt {
        text-align: left;
    }
}
@media only screen and (min-width:1366px) {
    #process ol.step {
        margin-top: 80px;
        row-gap: 57px;
    }
    #process ol.step > li {
        padding: calc(50px + 20px) 0 50px 0;
        column-gap: 40px;
    }
    #process ol.step .icon {
        width: 160px;
    }
    #process dl.setp_content {
        width: 600px;
    }
    #process dl.setp_content > .block {
        row-gap: 20px;
    }
    #process dl.setp_content .img {
        width: 86px;
        top: calc(0px - 3px/2 - 43px);
        left: calc(50% - 43px);
    }
    #process dl.setp_content .title {
        height: 28px;
    }
    #process ul.atte {
        margin-top: 20px;
    }
}

/****************************/
/* qanda *****************/
#qanda {
    background-color: var(--back_red);
}
#qanda .accordion {
    margin-top: 30px;
    display: flex;
    flex-flow: column;
    row-gap: 20px;
}
#qanda .accordion details {
    display: flex;
    flex-flow: column;
}
#qanda .accordion details summary {
    display: flex;
    flex-flow: nowrap;
    align-items: flex-start;
    column-gap: 10px;
    padding: 15px;
    background-color: var(--font_red);
    color: #FFFFFF;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.5;
    letter-spacing: 0.05em;
    position: relative;
    overflow: hidden;
    cursor: pointer;
}
#qanda .accordion details summary::before {
    content: "Q";
    font-size: 2.0rem;
    line-height: 1;
    width: 20px;
}
#qanda .accordion details summary > span {
    width: calc(100% - 20px - 20px - 14px);
}
#qanda .accordion details summary > span.open {
    aspect-ratio: 1/1;
    width: 14px;
    position: absolute;
    right: 15px;
    top: calc(50% - 15px/2);
}
#qanda .accordion details summary > span.open::before,
#qanda .accordion details summary > span.open::after {
    content: "";
    display: block;
    height: 2px;
    width: 100%;
    background-color: #FFFFFF;
    position: absolute;
    left: 0;
    top: calc(50% - 1px);
    transition: var(--duration) all;
}
#qanda .accordion details .answer {
    background-color: #FFFFFF;
    padding: 16.5px 18px 20px 18px;
}
#qanda .accordion details .answer::before {
    display: none;
    content: "A";
    font-size: 2.0rem;
    font-weight: 600;
    line-height: 1;
    width: 20px;
    color: var(--font_red);
}
#qanda .accordion details .answer .body {
    width: 100%;
}
#qanda .accordion details summary > span.open::after {
    transform: rotate(90deg);
}
#qanda .accordion details[open] summary > span.open::after {
    transform: rotate(0deg);
}
#qanda .accordion details .answer ul.atte {
    font-size: 1.4rem;
    margin-top: 10px;
}
#qanda .table_data {
    margin-top: 25px;
}
#qanda .table_data ul.caption > li {
    font-size: 1.4rem;
    display: flex;
    flex-flow: nowrap;
}
#qanda .table_data ul.caption > li span.icon {
    width: 2.3em;
}
#qanda .table_data ul.caption > li span.icon::after {
    content: "：";
}
#qanda .table_data .star {
    color: var(--font_red);
    font-size: 120%;
    line-height: 0;
}
#qanda .table_data .circle {
    color: #FED602;
    font-size: 120%;
    line-height: 0;
}
#qanda .table_data .yellow {
    background-color: #fff9d9;
}
#qanda .scroll_atte {
    margin-top: 10px;
    font-size: 1.3rem;
}
#qanda .scroll {
    margin: 10px 0 15px 0;
    overflow-x: auto;
    border: 1px solid #cbcbcb;
    border-bottom: none;
}
#qanda .scroll table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}
#qanda .scroll table thead {
    position: sticky;
    top: 0;
    left: 0;
    z-index: 2;
}
#qanda .scroll table thead tr > * {
    position: relative;
}
#qanda .scroll table thead tr > *::before {
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: #CBCBCB;
    position: absolute;
    left: 0;
    bottom: 0px;
    z-index: 2;
}
#qanda .scroll table tr > th {
    background-color: #efefef !important;
}
#qanda .scroll table tbody tr > th {
    font-weight: normal;
}
#qanda .scroll table tr > * {
    text-align: center;
    padding: 5px;
    border: var(--table_border);
    border-top: none;
    border-left: none;
    white-space: nowrap;
    font-size: 1.4rem;
    line-height: 1.6;
}
#qanda .scroll table thead tr > * {
    border-bottom: none;
}
#qanda .scroll table thead tr:nth-last-child(n+2) > *:first-child::before {
    display: none;
}
#qanda .scroll table tr > *:nth-child(1) {
    border-right: none;
    background-color: #FFFFFF;
    position: sticky;
    top: 0;
    left: 0;
    z-index: 3;
}
#qanda .scroll table tr > *:nth-child(1)::after {
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    border-right: var(--table_border);
}
#qanda .scroll table tr > *:last-child {
    border-right: none;
}
#qanda .link {
    margin-top: 30px;
    display: flex;
    justify-content: center;
}

@media only screen and (min-width:960px) {
    #qanda .accordion {
        margin-top: 36px;
    }
    #qanda .accordion details summary {
        font-size: 1.7rem;
    }
    #qanda .accordion details .answer {
        display: flex;
        flex-flow: nowrap;
        align-items: flex-start;
        column-gap: 8px;
    }
    #qanda .accordion details .answer::before {
        display: block;
    }
    #qanda .accordion details .answer .body {
        width: calc(100% - 20px - 8px - 8px - 20px);
    }
    #qanda .table_data ul.caption {
        display: flex;
        flex-flow: wrap;
        justify-content: center;
        column-gap: 28.8px;
    }
    #qanda .scroll_atte {
        display: none;
    }
    #qanda .link {
        margin-top: 38.4px;
    }
}

@media only screen and (min-width:1366px) {
    #qanda .accordion {
        margin-top: 45px;
    }
    #qanda .accordion details summary {
        font-size: 2.0rem;
    }
    #qanda .accordion details summary::before,
    #qanda .accordion details .answer::before {
        font-size: 2.4rem;
    }
    #qanda .accordion details summary > span {
        width: calc(100% - 20px - 20px - 17px);
    }
    #qanda .accordion details summary > span.open {
        width: 17px;
        top: calc(50% - 17px/2);
    }
    #qanda .link {
        margin-top: 48px;
    }
}
/****************************/
/* caution ******************/
/****************************/
/* application **************/
.application {
    padding-top: 50px;
}
.application .area {
    margin: 0 auto 0 auto;
    padding: 0 20px 0 20px;
}
.application .title {
    margin: 0 auto 0 auto;
    max-width: 450px;
}
.application ul.link {
    display: flex;
    flex-flow: column;
    row-gap: 15px;
    margin: 20px auto 0;
    max-width: 380px;
}
.application ul.link a img {
    width: 100%;
}
.application .other {
    margin-top: 25px;
    text-align: center;
}
@media only screen and (min-width:670px) {
    .application ul.link {
        max-width: 720px;
    }
}
@media only screen and (min-width:960px) {
    .application {
        padding-top: 72px;
    }
    .application .area {
        max-width: 768px;
        padding: 0;
    }
    .application ul.link {
        max-width: none;
    }
}
@media only screen and (min-width:1366px) {
    .application .area {
        max-width: 960px;
    }
}
/****************************/
/* return *******************/
#return {
    margin-top: 50px;
    border-top: 1px solid #D0D0D0;
}
#return .area {
    display: flex;
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
    height: calc(50px + 48px + 50px);
    margin: 0 auto 0 auto;
    padding: 0 20px 0 20px;
}
#return .area a.button::after {
    left: 22px;
    transform: rotate(180deg) translateY(50%);
}
@media only screen and (min-width:960px) {
    #return .area {
        height: 170px;
        max-width: 768px;
        padding: 0;
    }
    #return .area a.button {
        width: 400px;
    }
}
@media only screen and (min-width:1366px) {
    #return .area {
        height: 220px;
        max-width: 960px;
    }
    #return .area a.button {
        width:  600px;
        max-width:  none;
    }
}
/****************************/
/* procedure ****************/
#procedure {
    line-height: 0;
    display: flex;
    justify-content: center;
    width: 100%;
    padding: 0 20px 0 20px;
    z-index: 10;
    position: sticky;
    left: 0;
    bottom: 10px;
    pointer-events: none;
    transition: var(--duration) opacity;
}
#procedure a {
    width: 100%;
    pointer-events: visible;
    transition: var(--duration) opacity;
}
#procedure a img {
    width: 100%;
}
@media only screen and (min-width:750px) {
    #procedure {
        margin-top: calc(0px - (50px + 48px + 50px) + ((50px + 48px + 50px) - 140px)/2);
        padding: 0 30px calc(((50px + 48px + 50px) - 140px)/2) 0;
        justify-content: flex-end;
    }
    #procedure a {
        width: 140px;
    }
    #procedure.end a {
        pointer-events: none;
        opacity: 0;
    }
}
@media only screen and (min-width:960px) {
    #procedure {
        margin-top: calc(0px - 170px + (170px - 160px)/2);
        padding-bottom: calc((170px - 160px)/2);
    }
    #procedure a {
        width: 160px;
    }
}
@media only screen and (min-width:1366px) {
    #procedure {
        margin-top: calc(0px - 220px + (220px - 200px)/2);
        padding-bottom: calc((220px - 200px)/2);
    }
    #procedure a {
        width: 200px;
    }
}
/****************************/
/* 共通設定の無効化 **********/
html:has(#web_campaign) {
    scroll-behavior: smooth;
}
body:has(#procedure) {
    overflow-x: visible !important;
}
body:has(#procedure) main#a-main-content + .l-footer {
    padding-top: 50px;
}
@media only screen and (min-width:750px) {
    body:has(#procedure) main#a-main-content + .l-footer {
        padding-top: 0;
    }
}
body:has(#procedure) main#a-main-content + .l-footer footer {
    padding-top: 0;
}
/****************************/