.terme_appointment .terme_panel_footer .terme_add_coupon {
    position: static;
    left: auto;
    right: auto;
    bottom: auto;
    width: 100%;
    margin: 0.75rem 0 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.5rem;
    align-items: center;
    box-sizing: border-box;
}

.terme_appointment .terme_panel_footer .terme_add_coupon::after {
    content: none;
}

.terme_appointment .terme_panel_footer .terme_add_coupon input {
    width: auto;
    min-width: 0;
    height: 2rem;
    padding: 0 0.625rem;
    border: 0.0625rem solid var(--bk-border, #e3eaf3);
    border-radius: 0.625rem;
    background: var(--bk-base-100, #ffffff);
    color: var(--bk-text-primary, #1f2937);
    font-size: 0.8125rem;
    line-height: 1.2;
    box-sizing: border-box;
}

.terme_appointment .terme_panel_footer .terme_add_coupon input::placeholder {
    color: var(--bk-text-muted, #8b98a7);
}

.terme_appointment .terme_panel_footer .terme_add_coupon input:focus {
    outline: none;
    border-color: var(--bk-accent, #ff6b00);
    box-shadow: 0 0 0 0.1875rem rgba(255, 107, 0, 0.14);
}

.terme_appointment .terme_panel_footer .terme_add_coupon .terme_coupon_actions {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: nowrap;
}

.terme_appointment .terme_panel_footer .terme_add_coupon .terme_coupon_ok_btn,
.terme_appointment .terme_panel_footer .terme_add_coupon .terme_coupon_cancel_btn {
    width: auto;
    min-width: 2.25rem;
    height: 2rem;
    padding: 0 0.625rem;
    margin: 0;
    white-space: nowrap;
    border-radius: 0.5rem;
    line-height: 1;
}

.terme_appointment .terme_panel_footer .terme_add_coupon.terme_coupon_ok {
    padding: 0.25rem;
    border: 0.0625rem solid rgba(79, 191, 101, 0.28);
    border-radius: 0.625rem;
    background: rgba(79, 191, 101, 0.08);
}

.terme_appointment .terme_panel_footer .terme_add_coupon.terme_coupon_ok input {
    border-color: rgba(79, 191, 101, 0.32);
    background: transparent;
}

@media (max-width: 24rem) {
    .terme_appointment .terme_panel_footer .terme_add_coupon {
        grid-template-columns: minmax(0, 1fr);
    }

    .terme_appointment .terme_panel_footer .terme_add_coupon .terme_coupon_actions {
        justify-self: end;
    }
}

/* Landing page/theme styles can apply a large global min-height to text inputs. */
#booking .terme_appointment .terme_panel_footer .terme_add_coupon input {
    height: 2rem;
    min-height: 2rem;
}

body.terme_td_landing_page .terme-td-sidebar #booking .terme_panel_footer .terme_add_coupon {
    gap: 0.375rem;
    padding: 0.25rem 0.375rem;
}

body.terme_td_landing_page .terme-td-sidebar #booking .terme_panel_footer .terme_add_coupon .terme_coupon_ok_btn,
body.terme_td_landing_page .terme-td-sidebar #booking .terme_panel_footer .terme_add_coupon .terme_coupon_cancel_btn {
    height: 2rem;
    min-height: 2rem;
}
