/* HVB Gift Cards — Frontend */
.hvb-gc-form-container { display: flex; gap: 2em; margin: 1em 0; }
.hvb-gc-form-left { flex: 1; }
.hvb-gc-form-right { width: 340px; flex-shrink: 0; }
.hvb-gc-label { font-weight: 600; display: block; margin-bottom: 0.5em; }
.hvb-gc-denominations { display: flex; flex-wrap: wrap; gap: 0.5em; margin-bottom: 1em; }
.hvb-gc-denom {
    padding: 0.6em 1.2em; border: 2px solid #ddd; border-radius: 8px;
    background: #fff; cursor: pointer; font-size: 1em; font-weight: 600;
    transition: all 0.2s;
}
.hvb-gc-denom:hover { border-color: #2e7d32; color: #2e7d32; }
.hvb-gc-denom.active { border-color: #2e7d32; background: #2e7d32; color: #fff; }
.hvb-gc-custom-amount {
    display: flex; align-items: center; gap: 0.3em; margin-bottom: 1em;
}
.hvb-gc-currency { font-size: 1.2em; font-weight: 600; color: #666; }
.hvb-gc-custom-input { width: 120px; padding: 0.5em; border: 2px solid #ddd; border-radius: 6px; font-size: 1em; }
.hvb-gc-custom-input:focus { border-color: #2e7d32; outline: none; }
.hvb-gc-fields { display: flex; flex-direction: column; gap: 0.8em; }
.hvb-gc-field label { display: block; font-weight: 500; margin-bottom: 0.2em; font-size: 0.9em; }
.hvb-gc-field input, .hvb-gc-field textarea {
    width: 100%; padding: 0.5em 0.7em; border: 1px solid #ccc; border-radius: 6px; font-size: 0.9em;
}
.hvb-gc-field input:focus, .hvb-gc-field textarea:focus { border-color: #2e7d32; outline: none; box-shadow: 0 0 0 2px rgba(46,125,50,0.12); }
.hvb-gc-hint { font-size: 0.8em; color: #999; margin: 0.2em 0 0; }
.required { color: #c00; }

/* Balance Checker */
.hvb-gc-balance-checker { max-width: 500px; margin: 1em 0; }
.hvb-gc-balance-form { display: flex; flex-wrap: wrap; gap: 0.5em; align-items: flex-start; }
.hvb-gc-code-input { flex: 1; min-width: 220px; padding: 0.5em; border: 1px solid #ccc; border-radius: 6px; font-family: monospace; font-size: 1em; letter-spacing: 1px; }
.hvb-gc-balance-result { width: 100%; margin-top: 0.5em; padding: 0.8em; border-radius: 6px; font-size: 0.95em; }
.hvb-gc-balance-result.success { background: #e8f5e9; color: #2e7d32; border: 1px solid #a5d6a7; }
.hvb-gc-balance-result.error { background: #fce4ec; color: #c62828; border: 1px solid #ef9a9a; }

/* Checkout Apply */
.hvb-gc-checkout-apply { margin: 1em 0; padding: 1em; background: #f9f9f9; border: 1px solid #e0e0e0; border-radius: 8px; }
.hvb-gc-apply-form label { font-weight: 500; display: block; margin-bottom: 0.4em; }
.hvb-gc-apply-row { display: flex; gap: 0.5em; }
.hvb-gc-apply-code { flex: 1; padding: 0.4em 0.6em; border: 1px solid #ccc; border-radius: 6px; font-family: monospace; }
.hvb-gc-apply-message { margin-top: 0.5em; font-size: 0.85em; }
.hvb-gc-applied { display: flex; align-items: center; justify-content: space-between; }
.hvb-gc-applied code { background: #e8f5e9; padding: 2px 6px; border-radius: 4px; }
.hvb-gc-remove-applied { background: none; border: none; color: #c00; cursor: pointer; font-size: 0.85em; text-decoration: underline; }

/* My Account */
.hvb-gc-myaccount h3 { margin-top: 1.5em; }
.hvb-gc-status { padding: 2px 8px; border-radius: 12px; font-size: 0.8em; font-weight: 600; }
.hvb-gc-status-active { background: #e8f5e9; color: #2e7d32; }
.hvb-gc-status-used { background: #e0e0e0; color: #666; }
.hvb-gc-status-void { background: #fce4ec; color: #c62828; }
.hvb-gc-status-pending { background: #fff3e0; color: #e65100; }
.hvb-gc-received-card { margin-bottom: 1.5em; border: 1px solid #e0e0e0; border-radius: 8px; padding: 1em; }
.hvb-gc-received-header { display: flex; align-items: center; gap: 1em; flex-wrap: wrap; margin-bottom: 0.8em; }
.hvb-gc-txn-table { width: 100%; font-size: 0.85em; }
.hvb-gc-txn-table th { text-align: left; padding: 4px 8px; border-bottom: 1px solid #ddd; }
.hvb-gc-txn-table td { padding: 4px 8px; }

@media (max-width: 768px) {
    .hvb-gc-form-container { flex-direction: column; }
    .hvb-gc-form-right { width: 100%; }
}
