/* ── Voucher Manager Frontend Styles ─────────────────────────────────────── */
:root {
    --vm-primary:    #6c47ff;
    --vm-primary-d:  #5435d6;
    --vm-success:    #22c55e;
    --vm-danger:     #ef4444;
    --vm-border:     #e2e8f0;
    --vm-text:       #1e293b;
    --vm-text-light: #64748b;
    --vm-radius:     12px;
}

/* ── Badges ──────────────────────────────────────────────────────────────── */
.vm-badge { display:inline-block; padding:3px 10px; border-radius:999px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; }
.vm-badge--available { background:#eff6ff; color:#1d4ed8; }
.vm-badge--assigned  { background:#fef9c3; color:#854d0e; }
.vm-badge--redeemed  { background:#dcfce7; color:#15803d; }
.vm-badge--cancelled { background:#fee2e2; color:#991b1b; }

/* ── Code chip ───────────────────────────────────────────────────────────── */
.vm-code-chip {
    font-family:'Courier New',monospace;
    background:#f1f5f9; border:1px solid #cbd5e1;
    border-radius:4px; padding:4px 10px;
    font-size:13px; font-weight:700; letter-spacing:.08em; color:var(--vm-primary);
}

/* ── Notice ──────────────────────────────────────────────────────────────── */
.vm-notice { background:#fffbeb; border-left:4px solid #f59e0b; padding:12px 16px; border-radius:0 6px 6px 0; color:#78350f; }

/* ── My Vouchers — WooCommerce table ─────────────────────────────────────── */
.vm-myaccount-table .vm-code-chip { font-size:12px; }

/* Offer message row */
.vm-offer-row td,
.vm-offer-cell {
    padding: 0 0 14px !important;
    border-bottom: 1px solid var(--vm-border) !important;
    background: transparent !important;
    text-align: left !important;
}
.vm-offer-pill {
    display: flex !important;
    gap: 10px;
    align-items: flex-start;
    text-align: left !important;
    background: linear-gradient(135deg,#f5f0ff 0%,#fff7ed 100%);
    border: 1.5px dashed #c4b5fd;
    border-radius: 10px;
    padding: 12px 16px;
}
.vm-offer-icon { font-size:18px; flex-shrink:0; line-height:1.5; }
.vm-offer-text {
    display: flex;
    flex-direction: column;
    gap: 3px;
    text-align: left !important;
}
.vm-offer-label {
    display: block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: #7c3aed;
    margin-bottom: 2px;
    text-align: left !important;
}
.vm-offer-text span {
    display: block;
    font-size: 13px;
    color: #4c1d95;
    line-height: 1.65;
    text-align: left !important;
}

/* Partner contact row */
.vm-partner-row td,
.vm-partner-cell {
    padding: 0 0 14px !important;
    border-bottom: 1px solid var(--vm-border) !important;
    background: transparent !important;
    text-align: left !important;
}
.vm-partner-contact {
    display: block;
    background: #f8fafc;
    border: 1px solid var(--vm-border);
    border-left: 3px solid var(--vm-primary);
    border-radius: 8px;
    padding: 12px 16px;
    text-align: left !important;
}
.vm-partner-contact-label {
    display: block;
    font-size: 12px;
    color: var(--vm-text-light);
    margin-bottom: 8px;
    text-align: left;
}
.vm-partner-contact-links {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 20px;
    align-items: center;
    text-align: left;
}
.vm-contact-link {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--vm-primary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
    text-align: left;
}
.vm-contact-link:hover { text-decoration: underline; }
.vm-contact-note {
    display: block;
    margin: 4px 0 0;
    font-size: 13px;
    color: var(--vm-text);
    line-height: 1.5;
    white-space: pre-line;
    text-align: left !important;
}
.vm-how-to-redeem {
    display: block;
    width: 100%;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px dashed var(--vm-border);
    text-align: left !important;
}
.vm-how-to-redeem-label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--vm-primary);
    margin-bottom: 4px;
    text-align: left !important;
}
/* Remove any theme-injected p margin inside our containers */
.vm-partner-contact p,
.vm-how-to-redeem p { margin: 0 !important; padding: 0 !important; }

.vm-whatsapp-link { color: #16a34a !important; display: inline-flex !important; align-items: center; gap: 3px; }
.vm-whatsapp-link:hover { color: #15803d !important; }
.vm-whatsapp-link::before {
    content: '';
    display: inline-block; width: 15px; height: 15px; flex-shrink: 0;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%2325d366' d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413z'/%3E%3C/svg%3E") center/contain no-repeat;
    vertical-align: middle;
}

/* ── Redeem shortcode widget ─────────────────────────────────────────────── */
.vm-redeem-wrap { max-width:520px; margin:32px auto; font-family:inherit; }
.vm-redeem-form-box {
    background:#fff; border:1px solid var(--vm-border);
    border-radius:var(--vm-radius); padding:28px;
    box-shadow:0 4px 24px rgba(108,71,255,.08);
}
.vm-input-group { display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.vm-input-group label { font-size:13px; font-weight:600; color:var(--vm-text); }
.vm-input-group input {
    border:1.5px solid var(--vm-border); border-radius:8px;
    padding:12px 14px; font-size:15px;
    font-family:'Courier New',monospace; color:var(--vm-text);
    text-transform:uppercase; letter-spacing:.06em;
    transition:border-color .15s,box-shadow .15s; width:100%; box-sizing:border-box;
}
.vm-input-group input:focus { border-color:var(--vm-primary); outline:none; box-shadow:0 0 0 3px rgba(108,71,255,.12); }
.vm-btn {
    display:block; width:100%; background:var(--vm-primary); color:#fff;
    border:none; border-radius:8px; padding:13px 20px; font-size:15px; font-weight:700;
    cursor:pointer; letter-spacing:.02em; transition:background .15s,transform .1s,box-shadow .15s;
}
.vm-btn:hover { background:var(--vm-primary-d); box-shadow:0 4px 16px rgba(108,71,255,.35); transform:translateY(-1px); }
.vm-btn:active { transform:none; }
.vm-btn:disabled { opacity:.6; cursor:not-allowed; transform:none; }
#vm-redeem-result { margin-top:16px; border-radius:8px; font-size:14px; line-height:1.5; }
.vm-result-success { background:#f0fdf4; border:1px solid #bbf7d0; color:#15803d; padding:14px 16px; border-radius:8px; }
.vm-result-error   { background:#fff1f2; border:1px solid #fecdd3; color:#be123c; padding:14px 16px; border-radius:8px; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width:600px) {
    .vm-redeem-form-box { padding:20px; }
    .vm-partner-contact { flex-direction:column; gap:6px; }
}
