.belpost-tariffs {
    width: 86%;
    max-width: 400px;
    margin: 20px auto 0;
    font-family: 'Open Sans', Arial, sans-serif;
}

.belpost-tariffs details {
    background: #ffffff;
    border: 2px solid #4f8023;
    border-radius: 18px;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.12);
    overflow: hidden;
}

.belpost-tariffs summary {
    list-style: none;
    cursor: pointer;
    padding: 16px 18px;
    background: linear-gradient(335deg, #4f8023, #98e83b);
    color: #ffffff;
    font-size: 19px;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
}

.belpost-tariffs summary::-webkit-details-marker {
    display: none;
}

.belpost-tariffs summary::after {
    content: " ▼";
    font-size: 14px;
}

.belpost-tariffs details[open] summary::after {
    content: " ▲";
}

.belpost-tariffs__content {
    padding: 16px;
    background: #fff;
}

.belpost-tariffs__text {
    margin: 0 0 14px;
    font-size: 15px;
    line-height: 1.45;
    color: #333;
    text-align: center;
}

.belpost-tariffs__table {
    width: 100%;
    border-collapse: collapse;
    margin: 10px 0 14px;
    font-size: 14px;
}

.belpost-tariffs__table th,
.belpost-tariffs__table td {
    border: 1px solid #d6d6d6;
    padding: 10px 8px;
    text-align: center;
}

.belpost-tariffs__table th {
    background: #eef8e7;
    color: #254011;
    font-weight: 700;
}

.belpost-tariffs__table td {
    color: #333;
}

.belpost-tariffs__note {
    margin: 0;
    font-size: 13px;
    line-height: 1.4;
    color: #666;
    text-align: center;
}

.belpost-tariffs sup {
    font-size: 12px;
    vertical-align: super;
}

.belpost-tariffs__ecommerce-note {
    margin: 8px 0 12px;
    font-size: 13px;
    line-height: 1.35;
    color: #4f8023;
    text-align: center;
    font-weight: 600;
}

.button-m,
button.button-m,
a.button-m {
    -webkit-appearance: none !important;
    appearance: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 400px !important;
    max-width: calc(100% - 40px) !important;
    height: 80px !important;
    min-height: 80px !important;
    padding: 0 18px !important;
    box-sizing: border-box !important;
    border: none !important;
    border-radius: 50px !important;
    box-shadow: -2px 12px 10px 0px rgb(0 0 0 / 43%) !important;
    color: #fff !important;
    text-decoration: none !important;
    text-align: center !important;
    font-family: Arial, "Open Sans", sans-serif !important;
    font-size: 26px !important;
    font-weight: 800 !important;
    line-height: 1.1 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    transform: none !important;
    zoom: 1 !important;
    -webkit-font-smoothing: antialiased !important;
    text-rendering: auto !important;
}

.button-m span {
    display: block !important;
    width: 100% !important;
    font-family: Arial, "Open Sans", sans-serif !important;
    font-size: inherit !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    letter-spacing: 0 !important;
    color: #fff !important;
    text-align: center !important;
    white-space: nowrap !important;
    transform: none !important;
}

@supports (-webkit-touch-callout: none) {
    .button-m,
    button.button-m,
    a.button-m {
        font-size: 24px !important;
        letter-spacing: 0 !important;
        line-height: 1.1 !important;
        font-family: Arial, "Open Sans", sans-serif !important;
    }
    .button-m span {
        font-size: inherit !important;
        letter-spacing: 0 !important;
        line-height: 1.1 !important;
        font-family: Arial, "Open Sans", sans-serif !important;
    }
}

.agree-check {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: fit-content !important;
    max-width: calc(100% - 40px) !important;
    margin: 12px auto 0 !important;
    padding: 0 !important;
    gap: 8px !important;
    box-sizing: border-box !important;
    font-family: Arial, Helvetica, sans-serif !important;
    cursor: pointer !important;
}

.agree-check input {
    position: absolute !important;
    opacity: 0 !important;
    width: 1px !important;
    height: 1px !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: none !important;
}

.agree-box {
    position: relative !important;
    display: block !important;
    width: 25px !important;
    height: 25px !important;
    min-width: 25px !important;
    flex: 0 0 25px !important;
    border: none !important;
    border-radius: 6px !important;
    background-color: #28aef0 !important;
    box-sizing: border-box !important;
    transform: none !important;
    zoom: 1 !important;
}

.agree-check input:checked + .agree-box::after {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-image: url("data:image/svg+xml,%3Csvg width='25' height='25' viewBox='0 0 25 25' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10.1 16.8L5.6 12.3L7.3 10.6L10.1 13.4L17.7 5.8L19.4 7.5L10.1 16.8Z' fill='white'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: 25px 25px !important;
    transform: none !important;
}

.agree-check input:not(:checked) + .agree-box {
    background-color: #ffffff !important;
    border: 2px solid #28aef0 !important;
}

.agree-check input:not(:checked) + .agree-box::after {
    display: none !important;
}

.agree-text {
    display: block !important;
    color: #444 !important;
    font-family: Arial, Helvetica, sans-serif !important;
    font-size: 11px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    text-align: left !important;
    padding: 0 !important;
    margin: 0 !important;
    transform: none !important;
}