/* mioお知らせ用 */

article#main-contents,
article#main-contents * {
    box-sizing: border-box;
}

.ta-r {
    text-align: right;
}
.ta-c {
    text-align: center;
}
.ta-l {
    text-align: left;
}
.mt_0 {
    margin-top: 0!important;
}
.mt_10 {
    margin-top: 10px!important;
}
.mt_20 {
    margin-top: 20px!important;
}
.mb_0 {
    margin-bottom: 0!important;
}
.mb_10 {
    margin-bottom: 10px!important;
}
.mb_20 {
    margin-bottom: 20px!important;
}
.ml_0 {
    margin-left: 0 !important;
}
.w-10 {
    width: 10%;
}
.w-20 {
    width: 20%;
}
.w-30 {
    width: 30%;
}
.w-40 {
    width: 40%;
}
.w-50 {
    width: 50%;
}
.w-60 {
    width: 60%;
}
.w-70 {
    width: 70%;
}
.w-80 {
    width: 80%;
}
.w-90 {
    width: 90%;
}
.w-100 {
    width: 100%;
}
article#main-contents small,
article#main-contents small li,
article#main-contents sub {
    font-size: 12px!important;
}

article#main-contents h2 {
    margin: 30px auto 40px;
    font-size: 24px;
    font-weight: bold;
    font-weight: normal;
    color: #333;
    text-align: center;
}
article#main-contents h3 {
    margin-bottom: 30px;
    text-align: center;
    color: #555;
    font-size: 18px;
    font-weight: bold;
}
article#main-contents h4 {
    margin-bottom: 20px;
    color: #e85299;
    font-weight: bold;
    font-size: 17px;
}

article#main-contents section.introduction {
    margin-bottom: 50px;
}
article#main-contents section:not(.introduction) {
    margin-bottom: 40px;
}
article#main-contents section + h4 {
    margin-top: 80px;
}

article#main-contents section p {
    margin-top: 0;
}
article#main-contents .midashi {
    margin-bottom: 7px;
    font-weight: bold;
}
article#main-contents .content-inner {
    padding-left: 50px;
}
article#main-contents dl {
    padding-left: 0!important;
}
article#main-contents dl.flex {
    display: flex;
}

table.default-table {
    width: 100%;
    table-layout: fixed;
}
table.default-table th {
    padding: 7px 10px;
    background-color: #eee;
    width: 25%;
    text-align: center;
}
table.default-table td {
    padding: 7px 10px;
    font-size: 14px;
    vertical-align: middle;
}
table.default-table td.w_25 {
    width: 25%;
}

table.default-table {
    width: 100%;
    table-layout: fixed;
    border: 1px solid #ccc;
    vertical-align: middle;
}
table.default-table th {
    border-top: none;
    border-left: none;
}
table.default-table th,
table.default-table td {
    border-right: 1px solid #CCC;
    border-bottom: 1px solid #CCC;
}

ol {
    margin-left: 20px;
}
ol li {
    list-style-type: decimal !important;
}

ul.asterisk,
ul.hyphen,
ul.square_list {
    padding-left: 1.3em;
    margin-left: 0;
}
ul.asterisk li {
    list-style-type: none;
    text-indent: -1.3em;
}
ul.asterisk_number {
    counter-reset: number;
    padding-left: 2em;
    margin-left: 0;
}
ul.asterisk li:before {
    display: inline;
    content: "※ ";
}
.asterisk_number li {
    text-indent: -2em;
    list-style: none;
}
.asterisk_number li:before {
    counter-increment: number;
    content: "※" counter(number) " ";
}
ul.hyphen li {
    list-style-type: none;
    text-indent: -1em;
}
ul.hyphen li:before {
    display: inline;
    content: "- ";
}
ul.square_list li {
    list-style-type: none;
    text-indent: -1em;
}
ul.square_list li:before {
    display: inline;
    content: "■";
}
ul.no_disc li {
    list-style-type: none;
}
.diagonal_line {
    position: relative;
}
.diagonal_line:after {
    position: absolute;
    content: "";
    width: 100%;
    height: 1px;
    top: 50%;
    left: 0;
    background-color: #ccc;
    transform: rotate(8deg);
}
.ar_link,
.tcl_link2 {
    color: #e7198c !important;
}
.box_inner {
    padding: 0 10px 10px;
}
.brackets {
    position: relative;
}
.brackets:before {
    position: absolute;
    content: "";
    width: 102%;
    left: -10px;
    top: -3px;
    height: 100%;
    border: 2px solid #777;
    border-image: linear-gradient(to right, #777 0%, #777 1%, #fff 1%, #fff 99%, #777 99%, #777 100%);
    border-image-slice: 1;
}

@media screen and (min-width: 641px) {
    .smp,
    .pc_off {
        display: none !important;
    }
}

@media screen and (max-width: 640px) {
    article#main-contents h2 {
        font-size: clamp(16px, 5vw, 22px);
    }
    article#main-contents h3 {
        font-size: clamp(14px, 4.5vw, 20px);
    }
    article#main-contents h4 {
        font-size: clamp(14px, 4.5vw, 20px);
    }
    article#main-contents section p,
    article#main-contents section dt,
    article#main-contents section dd,
    article#main-contents section li {
        font-size: clamp(13px, 4vw, 16px);
    }
    article#main-contents .midashi {
        font-size: clamp(14px, 4.2vw, 19px);
    }

    article#main-contents section:not(.introduction) {
        margin-bottom: 15px;
    }

    article#main-contents .content-inner {
        padding-left: 0;
    }

    table.default-table th,
    table.default-table td {
        font-size: 12px;
    }
    .diagonal_line:after {
        position: absolute;
        content: "";
        width: 0;
        height: 0;
        top: 0;
        left: 0;
        background-color: transparent;
        transform: none;
    }
    .pc,
    .sp_off {
        display: none !important;
    }
    .box_inner {
        padding: 0 4%;
    }
    .brackets:before {
        width: 106%;
        left: -4%;
        border-image: linear-gradient(to right, #777 0%, #777 2%, #fff 2%, #fff 98%, #777 98%, #777 100%);
        border-image-slice: 1;
    }

    .bgColor-eee {
        background-color: #eee;
    }
    .bgColor-ccc {
        background-color: #ccc;
    }
    .bgColor-ddd {
        background-color: #ddd;
    }
    .text-align-center {
        text-align: center;
    }
    .font-weight-bold {
        font-weight: bold;
    }
    .border-top-double {
        border-top: 3px double #CCC !important;
    }
    .border-bottom-double {
        border-bottom: 3px double #CCC !important;
    }
    table.device_list {
        display: block;
        border-right: none;
        border-bottom: none;
    }
    table.device_list th {
        display: none;
    }
    table.device_list tr {
        display: flex;
        flex-wrap: wrap;
    }
    table.device_list td {
        display: flex;
        width: 100%;
        padding: 0;
    }
    table.device_list td span {
        display: flex;
        align-items: center;
        width: 100%;
        padding: 7px;
    }
    table.device_list td::before {
        display: flex;
        align-items: center;
        width: 105px;
        min-width: 105px;
        content: attr(data-label);
        white-space: break-spaces;
        background-color: #eee;
        border-right: 1px solid #CCC;
        padding: 7px;
    }
    table.device_list td.bgColor-ddd::before {
        background-color: #ddd;
    }
    table.device_list td.label-none::before {
        content: none;
    }

    .device_list th {
        font-size: 14px;
    }
    .device_list td {
        font-size: 12px;
    }
    .diagonal_line:after {
        position: absolute;
        content: "";
        width: 0;
        height: 0;
        top: 0;
        left: 0;
        background-color: transparent;
        transform: none;
    }

    .box_inner {
        padding: 0 4%;
    }

    .brackets:before {
        width: 106%;
        left: -4%;
        border-image: linear-gradient(to right, #777 0%, #777 2%, #fff 2%, #fff 98%, #777 98%, #777 100%);
        border-image-slice: 1;
    }
}

