@charset "utf-8";
/*------------------------------
     flowCup
    created: 2026.3.11
    update: 2026.3.12
--------------------------------*/

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

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


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

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

.note {
    display: inline-block;
    padding-left: 1.3rem;
    text-indent: -1.3rem;
}

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

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

.flow a { text-decoration: none; }

.flow figure { flex-shrink: 0; }

.flow figure img { width: 100%; }

/* cb1 */
.flow .cb1 {
    display: flex;
    gap: 32px  52px;
}

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

.flow .cb1 ul {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

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

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

.flow .cb1 ul li:last-child a,
.flow .cb1 ul li a:hover {
    border-bottom: 1px solid ;
}

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

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

/* cb3-4 */
.flow .cb3-4 {
    display: flex;
    align-items: flex-end;
    gap: 32px  52px;
}

.flow .cb3-4 figure { width: 230px; }

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

.flow .cb3-4 dl address { font-style: normal; }

/* cb5 */
.flow .cb5 {
    display: flex;
    align-items: center;
    gap: 32px  12px;
    margin-top: 32px;
}

.flow .cb5 figure { width: 620px; }

/* cb6-9 */
.flow .cb6-9 figure { width: 725px; }

.flow .cb6-9 ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.flow .cb6-9 ul li:first-child {
    display: flex;
    column-gap: 20px;
    margin: -42px 0 0 500px;
}

.flow .cb6-9 ul li:first-child img {
    max-width: 100px;
}

.flow .cb6-9 ul li:last-child {
    max-width: 250px;
    margin: -330px 0 0 160px;
}

/* cb10-14 */
.flow .cb10-14 { margin-top: 62px; }

.flow .cb10-14 figure { width: 720px; }

.flow .cb10-14 ul {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: -230px;
}

.flow .cb10-14 ul li:last-child {
    display: flex;
    column-gap: 20px;
    margin: 72px 0 0 250px;
}

.flow .cb10-14 ul li:last-child img { max-width: 100px; }

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


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

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

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

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

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

.price .basicTable tbody td:first-child { white-space: nowrap; }
.price .basicTable tbody td:nth-child(3) { text-align: right; }


.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: 1025px) {

}

@media only screen and (max-width: 769px) {
    .pc { display: none !important; }
    .mobile { display: block; }
    
    .title figure {
        flex-wrap: wrap;
        gap: 10px;
    }
    
    .title figure img { max-height: 80px; }
    
    .contents {
        max-width: 100%;
        padding: 50px 22px;
    }
    
    .flow { padding: 0; }
    
    /* cb1 */
    .flow .cb1 { 
        gap: 32px  32px;
        align-items: center;
    }
    
    /* cb2 */
    .flow .cb2 { gap: 32px  32px; }
    
    /* cb3-4 */
    .flow .cb3-4 {
        align-items: center;
        gap: 32px  32px;
    }
    
    .flow .cb3-4 dl { 
        margin: 32px 0;
        flex-direction: column;
    }
    
    /* cb5-8 */
    .flow .cb5-8 { margin-top: 32px; }
    
    .flow .cb5-8 figure { width: 370px; }
    
    .flow .cb5-8 ul {
        display: flex;
        flex-direction: column;
    }
    
    .flow .cb5-8 ul li:first-child { margin: -500px 0 0 290px; }
    
    .flow .cb5-8 ul li:last-child { 
        display: flex;
        column-gap: 50px;
        margin: 355px 0 0 145px;
    }
    
    .flow .cb5-8 ul li:last-child img { max-width: 80px; }
    
    /* cb9 */
    .flow .cb9 { 
        display: flex;
        align-items: center;
        gap: 32px  32px;
    }
    
    .flow .cb9 figure { width: 230px; }

    /* cb10-14 */
    .flow .cb10-14 { margin-top: 32px; }
    
    .flow .cb10-14 figure { width:  490px; }
    
    .flow .cb10-14 ul { margin: 20px 0 340px 0; }
    
    .flow .cb10-14 ul li:last-child { 
        margin: -360px 0 0 140px;
        display: flex;
        column-gap: 50px;
    }
    
    .flow .cb10-14 ul li:last-child img { width: 80px; }

    
    
    .price {  padding: 0; }
    
    .price .basicTable { width: 100%; }
}

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

/* -SP- -599px */
@media screen and (max-width: 599px){
    
    .flow { font-size: 14px; }
    
    .note { 
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    /* cb1 */
    .flow .cb1 {
        align-items: flex-start;
        gap: 22px;
    }
    
    .flow .cb1 figure { width: 140px; }
    
    /* cb2 */
    .flow .cb2 { 
        margin-top: 22px;
        gap: 22px;
    }
    
    .flow .cb2 figure { width: 140px; }
    
    /* cb3-4 */
    .flow .cb3-4 {
        align-items: flex-start;
        gap: 22px;
    }
    
    .flow .cb3-4 figure { width: 140px; }
    
    .flow .cb3-4 dl { margin: 17px 0; }
    
    /* cb5-8 */
    .flow .cb5-8 {  margin-top: 12px; }
    
    .flow .cb5-8 figure { width: 230px; }
    
    .flow .cb5-8 ul li:first-child { margin: -330px 0 0 175px; }
    .flow .cb5-8 ul li:last-child { 
        margin: 210px 0 0 90px;
        column-gap: 20px;
    }

     /* cb9 */
    .flow .cb9 { 
        margin-top: 22px;
        gap: 22px;
    }
    
    .flow .cb9 figure { width: 140px; }
    
     /* cb10-14 */
    .flow .cb10-14 figure { width:  300px; }
    
     .flow .cb10-14 ul { margin: 10px 0 255px 0; }
    
    .flow .cb10-14 ul li:last-child { 
        margin: -265px 0 0 85px;
        column-gap: 20px;
    }
    
    .flow .cb10-14 ul li:not(:last-child) { width: 140px; }
    
    
    
    .price .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){
    
     /* cb5-8 */
    .flow .cb5-8 { margin-top: 32px; }
    .flow .cb5-8 ul li:first-child { margin: -355px 0 0 175px; }
    .flow .cb5-8 ul li:last-child { margin: 190px 0 0 90px; }
    .flow .cb5-8 ul li:last-child img { width: 60px; }
    
     /* cb10-14 */
    .flow .cb10-14 ul li:last-child img { width: 60px; }
}


