@charset "utf-8";
/*------------------------------
     CurveX
    created: 2026.3.18
    update: 2026.3.24
--------------------------------*/

/*----------------------------------------
    title
-----------------------------------------*/
.title figure {
    display: flex;
    align-items: flex-end;
    column-gap: 20px;
}

.title figure img {
    max-height: 100px;
}

.title figure img:first-child {
    max-height: 120px;
}


/*----------------------------------------
    contents
-----------------------------------------*/
.pc { display: block; }
.mobile { display: none; }

.note::marker {  content: "※ ";}

.note { display: inline-block; }

.noteList {
    margin: 0.5rem 0 0 2em;
    counter-reset: count 0;
}

.noteList li { counter-increment: count 1; }

.noteList li:not(:last-child) { margin-bottom: 0.5em; }

.noteList li::marker {
    content: "※" counter(count) ": ";
}

.contents {
    max-width: 1530px;
    padding: 50px;
    margin: 0 auto;
    position: relative;
}

.info { 
    position: absolute;
    display: flex;
    align-items: center;
    column-gap: 10px;
    max-width: 45%;
    right: 30px;
    top: 50px;
}

.info figure { max-width: 120px; }

.info figure img { max-width: 100%; }

.info .box {
    border: 1px solid #039E1A;
    padding: 15px;
}

.info .box h2 {
    font-family: "DM Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    color: #039E1A;
    margin-bottom: 0.5rem;
}

.info .box p:last-child { margin-top: 0.5rem; }

.flow {
    font-size: 1rem;
    padding: 0 32px;
}

.flow a { text-decoration: none; }

.flow figure { flex-shrink: 0; }

.flow figure img { width: 100%; }

/* rb1 */
.flow .rb1 {
    display: flex;
    align-items: center;
    gap: 32px  52px;
}

.flow .rb1 figure { width: 230px; }

.flow .rb1 ul {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-bottom: 2rem;
}

.flow .rb1 ul li { line-height: 1.5; }

.flow .rb1 ul li a::after {
    content: "　▶▶▶";
    font-size: 14px;
}

.flow .rb1 ul li a:hover {  border-bottom: 1px solid ; }

.flow .rb1 p {
    max-width: 420px;
    margin-bottom: 0.5rem; }

.flow .rb1 dl:not(:last-child) { margin-bottom: 0.5rem; }

.flow .rb1 dl dt::before { content: "● "; }

.flow .rb1 dl dd::before { content: "・ "; }

.flow .rb1 dl dt,
.flow .rb1 dl dd {
    padding-left: 1.5em;
    text-indent: -1.5em;
}

.flow .rb1 dl dd { margin-left: 1.3em; }

/* rb2-3 */
.flow .rb2-3 {
    display: flex;
    align-items: flex-start;
    gap: 32px  52px;
    margin-top: 32px;
}

.flow .rb2-3 figure { width: 580px; }

.flow .rb2-3 .box {
    display: flex;
    column-gap: 22px;
}

.flow .rb2-3 .box figure { max-width: 130px;}
.flow .rb2-3 .box figure img { max-width: 100%; }

.flow .rb2-3 .box p.note { margin-top: 0.5rem; }


/* rb4-5 */
.flow .rb4-5 {
    display: flex;
    align-items: flex-start;
    gap: 32px  52px;
    margin-top: 32px;
}

.flow .rb4-5 figure { width: 580px; }

.flow .rb4-5 .box {
    display: flex;
    column-gap: 22px;
}

.flow .rb4-5 .box figure { max-width: 130px;}
.flow .rb4-5 .box figure img { max-width: 100%; }

/* rb6 */
.flow .rb6 {
    display: flex;
    align-items: center;
    gap: 32px  52px;
    margin-top: 22px;
}

.flow .rb6 figure { width: 232px; }

/* rb7-9 */
.flow .rb7-9  {
    display: flex;
    align-items: flex-start;
    gap: 32px  52px;
}

.flow .rb7-9 figure { width: 230px; }

.flow .rb7-9 div { padding-top: 22px; }

.flow .rb7-9 dl {
    margin: 22px 0;
    display: flex;
    column-gap: 10px;
}

.flow .rb7-9 dl dt { white-space: nowrap;}

.flow .rb7-9 dl address { font-style: normal; }

.flow .rb7-9 h3 {
    font-family: "DM Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    color: red;
    margin-bottom: 0.5rem;
}

/* rb10-14 */
.flow .rb10-14 { margin-top: 32px; }

.flow .rb10-14 figure { width: 730px; }

.flow .rb10-14 ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.flow .rb10-14 ul li:not(:first-child) { max-width: 230px; }

.flow .rb10-14 ul li:first-child { 
    margin: -410px 0 0 135px;
    max-width: 320px;
}
.flow .rb10-14 ul li:nth-child(2) { margin: 365px 0 0 495px; }
.flow .rb10-14 ul li:nth-child(n+3) { margin-left: 495px; } 

/* rb15-18 */
.flow .rb15-18 { margin: -130px 0 0 0;}

.flow .rb15-18 figure { width: 730px; }

.flow .rb15-18 ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.flow .rb15-18 ul li:first-child {
    display: flex;
    align-items: center;
    column-gap: 22px;
    margin: -500px 0 0 450px;
}

.flow .rb15-18 ul li:first-child img { width: 130px; }
.flow .rb15-18 ul li:nth-child(2) { margin: 115px 0 0 630px; }
.flow .rb15-18 ul li:nth-child(3) { 
    display: flex;
    align-items: flex-end;
    column-gap: 70px;
    margin: 95px 0 0 500px;
}

.flow .rb15-18 ul li:nth-child(3) img { width: 130px; }

/* rb19-22 */
.flow .rb19-22 { margin: 32px 0 200px 0;}

.flow .rb19-22 figure { width: 495px; }

.flow .rb19-22 ul li:first-child {
    display: flex;
    align-items: center;
    column-gap: 22px;
    margin: -420px 0 0 200px;
}

.flow .rb19-22 ul li:first-child img { width: 130px; }

.flow .rb19-22 ul li:nth-child(2) { margin: 100px 0 0 400px; }
.flow .rb19-22 ul li:nth-child(3) {
    display: flex;
    align-items: center;
    column-gap: 150px;
    margin: 110px 0 0 260px;
}

.flow .rb19-22 ul li:nth-child(3) img { width: 130px; }
.flow .rb19-22 ul li:nth-child(4) { margin: -85px 0 10px 0; }
.flow .rb19-22 ul li:nth-child(5) { max-width: 230px; } 


.price,
.option { 
    margin-top: 52px;
    padding: 0 32px;
    font-family: "Noto Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}

.price h2,
.option h2 { margin-bottom: 12px; }

.price .basicTable,
.option .basicTable {
    font-size: 1rem;
    border: solid 1px dimgray;
    background-color: snow;
}

.price .basicTable caption { text-align: right; }

.price .basicTable thead,
.option .basicTable thead { border-bottom: 3px double dimgray; }
.price .basicTable thead th:nth-child(3),
.option .basicTable thead th:nth-child(3) { white-space: pre-line; }

.price .basicTable tbody td:first-child,
.option .basicTable tbody td:first-child { white-space: nowrap; }
.price .basicTable tbody tr td:nth-child(3),
.option .basicTable tbody tr td:nth-child(3) { text-align: right; }
.price .basicTable tbody tr:last-child td:nth-child(3),
.option .basicTable tbody tr:nth-child(2) td:nth-child(3) { text-align: center !important; }

.price .basicTable span.spaceCut { letter-spacing:  -0.8em; }

.request { 
    margin-top: 102px;
    font-family: "Noto Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
}

.request h2 {
    font-family: "Noto Sans", sans-serif;
    font-optical-sizing: auto;
    font-style: normal;
    font-weight: 700;
    background-color: deeppink;
    color: whitesmoke;
    position: relative;
    padding: 5px 62px;
    margin: 0 0 62px 30px;
}

.request h2 img {
    position: absolute;
    top: -20px;
    left: -30px;
    width: 100px;
}


#approval {
    font-size: 1rem;
    text-align: center;
}

#approval p { padding-top: 22px; }


@media only screen and (max-width: 1501px) {
        .flow .rb1 p { max-width: 48%; }
}

@media only screen and (max-width: 1371px) {
        .flow .rb1 p { max-width: 43%; }
}

@media only screen and (max-width: 1321px) {
    
    .info { 
        position: static;
        max-width: 100%;
        column-gap: 32px;
        right: 0;
        top: 0;
        margin-bottom: 32px;
    }
        
    .flow .rb1 p { max-width: 100%; }
    
    .flow .rb2-3,
    .flow .rb4-5 { flex-wrap: wrap; }
    
    .flow .rb2-3 div.box,
    .flow .rb4-5 div.box { margin: -170px 0 0 300px;  }
}

@media only screen and (max-width: 1107px) {
    .flow .rb15-18 ul li:nth-child(2) {
        margin: 130px 0 0 500px;
        padding: 5px;
        background-color: rgba(255,255,255,0.5);
    }
    .flow .rb15-18 ul li:nth-child(3) { margin: 50px 0 0 500px;}
}

@media only screen and (max-width: 986px) {
    .flow .rb15-18 ul li:nth-child(2) { margin: 100px 0 0 500px;  }
    .flow .rb15-18 ul li:nth-child(3) {
        column-gap: 10px;
        align-items: flex-start;
        margin: 100px 0 0 500px;
    }
}

@media only screen and (max-width: 850px) {
    
    .flow { padding: 0; }
    
    .flow .rb2-3 .box figure,
    .flow .rb4-5 .box figure { max-width: 90px;}
    
    .flow .rb15-18 ul li:first-child { margin: -520px 0 0 430px; }
    .flow .rb15-18 ul li:nth-child(2) { margin: 60px 0 0 500px;  }
    
    .flow .rb19-22 ul li:nth-child(3) { margin: 90px 0 0 260px; }
}

@media only screen and (max-width: 769px) {
    .pc { display: none; }
    .mobile { display: block; }
    
    .title figure {
        flex-wrap: wrap;
        gap: 15px;
    }
    
    .title figure img { max-height: 80px; }
    .title figure img:first-child { max-height: 100px; }
    
    .contents {
        max-width: 100%;
        padding: 50px 22px;
    }
    
    .flow { padding: 0; }
    
    /* rb1 */
    .flow .rb1 {
        align-items: flex-start;
        gap: 32px  32px;
    }
    
    .flow .rb1 > div { padding-top: 100px; }
    
    .flow .rb1 dl dt,
    .flow .rb1 dl dd {
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    .flow .rb1 dl:not(:last-child) { margin: 50px 0; }
    
    /* rb2-3 */
    .flow .rb2-3 { gap: 32px  32px; }
    
    .flow .rb2-3 figure { width: 495px; }
    
     .flow .rb2-3 div.box { margin:  -350px  0 0 195px;}
    
    /* rb4-5 */
    .flow .rb4-5 { 
        gap: 32px  32px;
        margin-top: 0;
    }
    
    .flow .rb4-5 figure { width: 495px; }
    
     .flow .rb4-5 div.box { margin:  -350px  0 0 195px;}
    
    /* rb6 */
    .flow .rb6 { 
        gap: 32px  32px;
        margin-top: 0;
    }
    
    /* rb7-9 */
    .flow .rb7-9 { gap: 32px  32px; }
    
    .flow .rb7-9 div { padding-top: 22px; }
    
    .flow .rb7-9 div div { padding-top:  238px; }
    
    /* rb10-14 */
    .flow .rb10-14  {  margin-top: 32px; }
    
    .flow .rb10-14 figure { width: 480px; }
    
    .flow .rb10-14 ul li:not(:first-child) { max-width: 230px; }
    
    .flow .rb10-14 ul li:first-child { 
        margin: -710px 0 0 125px;
        max-width: 220px;
    }
    .flow .rb10-14 ul li:nth-child(2) { margin: 425px 0 0 250px; }
    .flow .rb10-14 ul li:nth-child(n+3) { margin-left: 250px; } 
    
    /* rb15-18 */
    .flow .rb15-18 { margin-top: 32px;}

    .flow .rb15-18 figure { width: 500px; }
    
    .flow .rb15-18 ul li:first-child {
        align-items: flex-start;
        margin: -800px 0 0 350px;
    }
    .flow .rb15-18 ul li:first-child img { width: 90px; }
    
    .flow .rb15-18 ul li:nth-child(2) { 
        background-color: rgba(0,0,0,0);
        margin: 250px 0 0 400px;
    }
    
    .flow .rb15-18 ul li:nth-child(3) { 
        align-items: flex-end;
        column-gap: 70px;
        margin: 290px 0 0 270px;
    }
    .flow .rb15-18 ul li:nth-child(3) img { width: 90px; }
    
    /* rb19-22 */
    .flow .rb19-22 { margin: 0 0 200px 0; }
    
    .flow .rb19-22 figure { width: 495px; }
    
    .flow .rb19-22 ul li:first-child { margin: -760px 0 0 220px; }
    .flow .rb19-22 ul li:first-child img { width: 90px; }
    
    .flow .rb19-22 ul li:nth-child(2) { margin: 200px 0 0 400px; }
    
    .flow .rb19-22 ul li:nth-child(3) {
        column-gap: 150px;
        margin: 200px 0 0 260px;
    }
    .flow .rb19-22 ul li:nth-child(3) img { width: 90px; }
    
    .flow .rb19-22 ul li:nth-child(4) { margin: 130px 0 10px 0; }
    
    
    
    .price,
    .option {  padding: 0; }
    
    .price .basicTable,
    .option .basicTable { width: 100%; }
}

@media screen and (max-width: 546px){
    .title figure img { max-height: 55px; }
    .title figure img:first-child { max-height: 70px; }
}

/* -SP- -599px */
@media screen and (max-width: 599px){
    
    .flow { font-size: 14px; }
    
    .info {
        flex-direction: column-reverse;
        gap: 10px;
        align-items: flex-start;
    }
    
    .info figure { max-width: 80px; }
    
    /* rb1 */
    .flow .rb1 {  gap: 0; }
    
    .flow .rb1 figure { width: 140px; }
    
     .flow .rb1 > div {
         padding-top: 0;
        margin: 55px 0 0 -50px;
    }
    
    .flow .rb1 dl dt,
    .flow .rb1 dl dd {
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    .flow .rb1 dl:not(:last-child) { margin: 20px 0; }
    
    /* rb2-3 */
    .flow .rb2-3 { gap: 0; }
    
    .flow .rb2-3 figure { width: 300px; }
    
    .flow .rb2-3 div.box { 
        flex-direction: column-reverse;
        gap: 12px;
        margin:  -200px  0 0 120px;
    }
    
    .flow .rb2-3 div.box figure { max-width: 85px; }
    
    /* rb4-5 */
    .flow .rb4-5 { 
        gap: 0;
        margin-top: 32px;
    }
    
    .flow .rb4-5 figure { width: 300px; }
    
    .flow .rb4-5 div.box { 
        flex-direction: column-reverse;
        gap: 12px;
        margin:  -200px  0 0 120px;
    }
    
    .flow .rb4-5 div.box figure { max-width: 85px; }
    
    /* rb6 */
    .flow .rb6 { 
        gap: 22px;
        margin-top: 32px;
    }
    
    .flow .rb6  figure { width: 140px; }
    
     /* rb7-9 */
    .flow .rb7-9 { gap: 22px; }
    
    .flow .rb7-9  figure { width: 140px; }
    
    .flow .rb7-9 dl {
        flex-direction: column;
        gap: 0;
    }
    
   .flow .rb7-9 div { padding-top: 0; }
    
   .flow .rb7-9 div div { padding-top:  0; }
    
   .flow .rb7-9 h3 { margin-bottom: 0; }
    
    /* rb10-14 */
    .flow .rb10-14 figure { width: 310px; }
    
    .flow .rb10-14 ul li:not(:first-child) { max-width: 140px; }
    
    .flow .rb10-14 ul li:first-child { 
        margin: -460px 0 0 85px;
        max-width: 140px;
    }
    .flow .rb10-14 ul li:nth-child(2) { margin: 240px 0 0 165px; }
    .flow .rb10-14 ul li:nth-child(n+3) { margin-left: 165px; } 
    
    /* rb15-18 */
    .flow .rb15-18 { margin-top: 22px;  }

    .flow .rb15-18 figure { width:  325px; }
    
    .flow .rb15-18 ul li:first-child { 
        flex-direction: column;
        align-items: center;
        gap: 10px;
        margin: -570px 0 0 195px;
    }
    .flow .rb15-18 ul li:nth-child(2) { 
        margin: 105px 0 0 155px;
        padding: 5px;
        background-color: rgba(255,255,255,0.5);
    }
    .flow .rb15-18 ul li:nth-child(3) { 
        column-gap: 10px;
        margin: 80px 0 0 170px;
    }
    
     /* rb19-22 */
     .flow .rb19-22 { margin: 0 0 100px 0; }
    
    .flow .rb19-22 figure { width: 320px; }
    
    .flow .rb19-22 ul li:first-child { margin: -500px 0 0 120px; }
    .flow .rb19-22 ul li:nth-child(2) { 
        padding: 5px;
        background-color: rgba(255,255,255,0.5);
        margin: 130px 0 0 150px; }
    .flow .rb19-22 ul li:nth-child(3) {
        column-gap: 80px;
        margin: 50px 0 0 160px;
    }
    .flow .rb19-22 ul li:nth-child(4) { margin: 60px 0 0 0; } 
    .flow .rb19-22 ul li:nth-child(5) { max-width: 140px; }
    
    
    .price .basicTable thead th:nth-child(3),
    .option .basicTable thead th:nth-child(3) { white-space: nowrap; }
    
    .overflow {
            white-space: nowrap;
            overflow-x: auto;
            padding-bottom: 10px;
    }
    
    #approval { 
        padding-top:  22px; 
        text-align: left;
    }
}

@media screen and (max-width: 391px){
    
    .flow .rb15-18 ul li:first-child { margin: -550px 0 0 195px; }
    .flow .rb15-18 ul li:first-child img { width: 60px; }
    .flow .rb15-18 ul li:nth-child(3) { margin: 85px 0 0 170px; }
    .flow .rb15-18 ul li:nth-child(3) img { width: 60px; }
    
    .flow .rb19-22 ul li:first-child { margin: -500px 0 0 130px; }
    .flow .rb19-22 ul li:first-child img { width: 60px; }
    .flow .rb19-22 ul li:nth-child(2) { margin: 150px 0 0 150px; }
    .flow .rb19-22 ul li:nth-child(3) { 
        align-items: flex-start; 
        column-gap: 40px;
        margin: 80px 0 0 165px;
    }
    .flow .rb19-22 ul li:nth-child(3) img { width: 60px; }
    .flow .rb19-22 ul li:nth-child(4) { margin: 55px 0 10px 0; }
}


