@charset "utf-8";
/*------------------------------
     positestAT-Series
    created: 2025.12.25
    update: 2026.1.5
--------------------------------*/

/*----------------------------------------
    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::before {
    content: "※ ";
}

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

.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%; }

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

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

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

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

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

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

.flow .cb1 p { margin-bottom: 0.5rem; }

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

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

.flow .cb1 dl dd::before { content: "□ "; }

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

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

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

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

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

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

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


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

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

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

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

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

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

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

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

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

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

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

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

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

/* cb10-13 */
.flow .cb10-13 { position: relative; }

.flow .cb10-13 figure { width: 700px; }

.flow .cb10-13 ul {
    max-width: 230px;
    margin-top: -32px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* cb14-17 */
.flow .cb14-17 {
    margin: -120px 0 0 250px;
}

.flow .cb14-17 figure { width: 474px; }

.flow .cb14-17 ul {
    display: flex;
    column-gap: 22px;
    margin-top: 10px;
}

.flow .cb14-17 ul li {
    flex-shrink: 0;
    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 tr:not(:last-child) td:nth-child(3) { text-align: right; }
.price .basicTable tbody tr:last-child td:nth-child(3) { text-align: center; }

.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: 1321px) {
    
    .info { 
        position: static;
        max-width: 100%;
        column-gap: 32px;
        right: 0;
        top: 0;
        margin-bottom: 32px;
    }
    
    .flow .cb2-3,
    .flow .cb4-5 { flex-wrap: wrap; }
    
    .flow .cb2-3 div.box,
    .flow .cb4-5 div.box { margin: -170px 0 0 300px;  }
}

@media only screen and (max-width: 850px) {
    
    .flow .cb2-3 .box figure,
    .flow .cb4-5 .box figure { max-width: 90px;}
    
}

@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; }
    
    /* cb1 */
    .flow .cb1 {
        align-items: flex-start;
        gap: 32px  32px;
    }
    
    .flow .cb1 > div { padding-top: 100px; }
    
    .flow .cb1 dl dt,
    .flow .cb1 dl dd {
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    /* cb2-3 */
    .flow .cb2-3 { gap: 32px  32px; }
    
    .flow .cb2-3 figure { width: 495px; }
    
     .flow .cb2-3 div.box { margin:  -350px  0 0 195px;}
    
    /* cb4-5 */
    .flow .cb4-5 { 
        gap: 32px  32px;
        margin-top: 0;
    }
    
    .flow .cb4-5 figure { width: 495px; }
    
     .flow .cb4-5 div.box { margin:  -350px  0 0 195px;}
    
    /* cb6 */
    .flow .cb6 { 
        gap: 32px  32px;
        margin-top: 0;
    }
    
    /* cb7-9 */
    .flow .cb7-9 { gap: 32px  32px; }
    
    .flow .cb7-9 div { padding-top: 0; }
    
    .flow .cb7-9 div div { padding-top:  270px; }
    
    /* cb10-12 */
    .flow .cb10-12  {  margin-top: 12px; }
    
    .flow .cb10-12 figure { width: 495px; }
    
    .flow .cb10-12 ul {
        max-width: 230px;
        margin: -160px 0 0 0;
    }
    
    /* cb13-17 */
    .flow .cb13-17 { 
        margin-top: 22px;
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .flow .cb13-17 figure { width:  500px; }
    
    .flow .cb13-17 ul {
        display: flex;
        flex-direction: column;
        max-width: auto;
    }
    
    .flow .cb13-17 ul li { max-width: 260px; }
    
    .flow .cb13-17 ul li:first-child { margin: -190px 0 0 150px; }
    .flow .cb13-17 ul li:last-child { margin: 155px 0 0 260px; }
    
    
    
    .price {  padding: 0; }
    
    .price .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; }
    
    .note { 
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    .info {
        flex-direction: column-reverse;
        gap: 10px;
        align-items: flex-start;
    }
    
    .info figure { max-width: 80px; }
    
    /* cb1 */
    .flow .cb1 {  gap: 0; }
    
    .flow .cb1 figure { width: 140px; }
    
     .flow .cb1 > div {
         padding-top: 0;
        margin: 55px 0 0 -50px;
    }
    
    .flow .cb1 dl dt,
    .flow .cb1 dl dd {
        padding-left: 1.2em;
        text-indent: -1.2em;
    }
    
    /* cb2-3 */
    .flow .cb2-3 { gap: 0; }
    
    .flow .cb2-3 figure { width: 300px; }
    
    .flow .cb2-3 div.box { 
        flex-direction: column-reverse;
        gap: 12px;
        margin:  -200px  0 0 120px;
    }
    
    .flow .cb2-3 div.box figure { max-width: 85px; }
    
    /* cb4-5 */
    .flow .cb4-5 { 
        gap: 0;
        margin-top: 32px;
    }
    
    .flow .cb4-5 figure { width: 300px; }
    
    .flow .cb4-5 div.box { 
        flex-direction: column-reverse;
        gap: 12px;
        margin:  -200px  0 0 120px;
    }
    
    .flow .cb4-5 div.box figure { max-width: 85px; }
    
    /* cb6 */
    .flow .cb6 { 
        gap: 22px;
        margin-top: 32px;
    }
    
    .flow .cb6  figure { width: 140px; }
    
     /* cb7-9 */
    .flow .cb7-9 { gap: 22px; }
    
    .flow .cb7-9  figure { width: 140px; }
    
    .flow .cb7-9 dl {
        flex-direction: column;
        gap: 0;
    }
    
   .flow .cb7-9 div div { padding-top:  0; }
    
   .flow .cb7-9 h3 { margin-bottom: 0; }
    
    /* cb10-12 */
    .flow .cb10-12 figure { width: 300px; }
    
    .flow .cb10-12 ul {
        max-width: 140px;
        margin: -100px 0 0 0;
    }
    
    /* cb13-17 */
    .flow .cb13-17 { margin-top: 0;  }

    .flow .cb13-17 figure { width:  300px; }

    .flow .cb13-17 ul li { max-width: 140px; }
    
    .flow .cb13-17 ul li:first-child { margin: -110px 0 0 90px; }
    .flow .cb13-17 ul li:last-child { margin: 55px 0 0 155px; }
    
    .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;
    }
}


