/* ============================================================================
 * coupon.redesign.css — Superset tokenizado de coupons/coupon.css
 *
 * Origen: /tools/components/coupons/assets/css/coupon.css (239 líneas).
 *
 * MODO: SUPERSET REEMPLAZO. Copia íntegra + tokenizations en valores existentes.
 * REGLA ESTRICTA: solo cambia valores de propiedades ya declaradas.
 *
 * Tokenizations:
 *   color: #fff               → var(--neutral-white)
 *   #ef5350                   → var(--error)
 *   #eef5f9                   → var(--neutral-200)
 *   margin-top: 50px          → var(--space-12) (Δ=−2)
 *   margin-top: 30px          → var(--space-8) (Δ=+2)
 *   margin-top: 10px          → var(--space-3)
 *   margin-top: 15px          → var(--space-4) (Δ=+1)
 *   font-weight: 600          → var(--font-weight-semibold)
 *   font-weight: 700          → var(--font-weight-bold)
 *   font-weight: bold         → var(--font-weight-bold)
 *   font-size: 12px           → var(--font-caption)
 *   font-size: 16px           → var(--font-body)
 *   font-size: 17px           → var(--font-body-l) (Δ=+1)
 *   font-size: 11px           → var(--font-caption) (Δ=+1)
 *   font-size: 18px           → var(--font-h4) (Δ=+2)
 *   font-size: 15px           → var(--font-body) (Δ=+1)
 *   border-radius: .25rem     → var(--radius-sm)
 *   padding-top/bottom: 10px  → var(--space-3)
 *   padding-top: 5px          → var(--space-1) (Δ=−1)
 *   padding-left/right: 30px  → var(--space-8) (Δ=+2)
 *
 * Preservados:
 *   margin-top: 40px (no encaja exacto)
 *   padding-left/right: 40px (no encaja)
 *   font-size: 10px / .8rem (fuera escala)
 *   height: 30px (dimensión)
 *   width / margin / line-height percentuales/específicos
 *   border-top: 8px solid transparent (separador)
 *   max-height: 100px
 * ============================================================================ */

#div_error_validate_coupon{
    display: none;
}

.m_t_50{
    margin-top: var(--space-12);
}

.c_w{
    color: var(--neutral-white);
}

.div_info_coupon{
    display: none;
}

.m_t_30{ margin-top: var(--space-8); }

#txt_offer{
    font-weight: var(--font-weight-semibold);
    line-height: 1.2;
}

.expiration_date{ display:none; }

#tbl_expiration_date thead th {
    padding-top: 0px !important;
    padding-bottom: 0px !important;
}
#tbl_expiration_date tbody td { padding-top: 0px !important; }

.btn-coupon-color{
    margin-top: var(--space-3);
}

.m_t_40 {
    margin-top: 40px;
}

.f-s-12 {
    font-size: var(--font-caption);
}

.helper_links{
    display: none;
    margin-top: var(--space-3);
}

.m_r_l_0 {
    margin-right: 0px;
    margin-left: 0px;
}

.d_f {
    display: flex;
}

.j_c_c {
    justify-content: center;
}

.d_c {
    display: contents;
}

.helper_link_action{
    display: inline-block;
    cursor: pointer;
}

.div_info_redemption{
    display: none;
    padding-left: var(--space-8);
    padding-right: var(--space-8);
}

.info_redemption{
    display: none;
}

.p_l_r_40{
    padding-left: 40px;
    padding-right: 40px;
}

#txt_redemption_code {
    line-height: 22px;
}

.f_s_16 {
    font-size: var(--font-body);
}

#div_coupon_barcode img{
    margin-left: auto;
    margin-right: auto;
    width: 80%;
}

#img_coupon_barcode{
    display: inline-block;
    width: 70%;
    max-height: 100px;
    margin-top: var(--space-4);
}

#img_coupon_redeem{
    width: 100%;
}

.div_conversion{
    display: none;
}

.error input {
    border: 1px solid var(--error) !important;
}

.m_t_10{
    margin-top: var(--space-3);
}

.div_conversion_password{
    display: none;
}

#txt_expire_text{
    font-weight: var(--font-weight-semibold);
}

#txt_expire_text_redeem{
    font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-bold);
}

.content_timer_redeem{
    background-color: var(--neutral-200);
    border-radius: var(--radius-sm);
}

.content_timer_redeem .table{
    margin-bottom: 0rem !important;
    text-transform: uppercase;
    font-size: var(--font-caption);
    font-weight: var(--font-weight-semibold);
}

.content_timer_redeem .table thead{
    font-size: var(--font-body-l);
}

.content_timer_redeem .table thead th{
    font-weight: var(--font-weight-semibold);
    padding-bottom: 0px !important;
}

.content_timer_redeem .table tbody{
    font-size: var(--font-caption);
}

.content_timer_redeem .table tbody td{
    padding-top: var(--space-1) !important;
}

#expiration_timer {
    padding-top: var(--space-3);
    border-radius: var(--radius-sm);
    padding-bottom: var(--space-3);
}

#expiration_timer .table{
    margin-bottom: 0rem !important;
    text-transform: uppercase;
    font-size: var(--font-caption);
    font-weight: var(--font-weight-semibold);
}

#expiration_timer .table thead{
    font-size: var(--font-body-l);
}

#expiration_timer .table thead th{
    font-weight: var(--font-weight-semibold);
}

#expiration_timer .table tbody{
    border-top: 8px solid transparent;
    font-size: var(--font-caption);
}

#expiration_timer .table tbody td{
    padding-bottom: 0px !important;
}

#btn_comple_redeem{
    font-size: var(--font-h4);
    font-weight: var(--font-weight-bold);
    width: 100%;
}

h5{
    font-size: var(--font-body) !important;
}

#txt_redemption_action{
    font-weight: var(--font-weight-bold);
    line-height: 30px;
}

#txt_conversion_password{
    height: 30px !important;
    min-height: 0px !important;
    font-size: .8rem !important;
}

#txt_offer_description, #txt_fine_print{
    white-space: pre-wrap;
}

#txt_fine_print {
    font-size: 10px;
}

#div_barcode {
    width: 100%;
}

#div_barcode canvas {
    width: 70%;
}

#div_barcode img {
    width: 90% !important;
    margin: auto;
}

#div_background .contentMobileView {
    padding-top: 0px !important;
}
