/* =============================================
   BookedUpmmerce — Front-end Styles
   ============================================= */

/* ---- Plan selector ---- */
.bum-plan-selector {
    margin: 16px 0 12px;
    border: 1px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    background: #fff;
    font-size: 14px;
}
.bum-plan-heading { padding: 10px 16px 6px; margin: 0; border-bottom: 1px solid #f0f0f0; }
.bum-plan-option {
    display: flex; align-items: center; gap: 10px;
    padding: 11px 16px; cursor: pointer;
    border-bottom: 1px solid #f5f5f5; transition: background .15s;
}
.bum-plan-option:last-of-type { border-bottom: none; }
.bum-plan-option:hover { background: #fafafa; }
.bum-plan-option.bum-selected { background: #fff7f7; }
.bum-plan-option input[type="radio"] { flex-shrink: 0; accent-color: #c0392b; }
.bum-plan-name { flex: 1; }
.bum-plan-name small { display: block; color: #888; font-size: 12px; font-weight: normal; margin-top: 2px; }
.bum-plan-price { font-weight: 700; color: #c0392b; text-align: right; }
.bum-plan-price small { display: block; font-weight: normal; font-size: 11px; color: #999; }
.bum-res-price { color: #888; }

/* Second option block */
.bum-second-option { border-top: 2px solid #c0392b; background: #fff5f5; }
.bum-second-label { padding: 8px 16px 0; margin: 0; font-size: 13px; }
.bum-plan-option.bum-sub { padding-left: 32px; background: transparent; }
.bum-plan-option.bum-sub:hover { background: #fff0f0; }

/* Deadlines */
.bum-deadlines { background: #fffde7; border-top: 1px solid #f0e58c; padding: 8px 16px; font-size: 13px; color: #7a6a00; }
.bum-deadlines p { margin: 2px 0; }

/* ---- Schedule box ---- */
.bum-schedule-box {
    border: 1px solid #ddd; border-radius: 6px;
    padding: 14px; margin: 14px 0; background: #fafafa;
}
.bum-schedule-box h4 { margin: 0 0 10px; }
.bum-schedule-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.bum-schedule-table th { background: #f5f5f5; font-weight: 600; }
.bum-schedule-table th, .bum-schedule-table td { padding: 7px 10px; border-bottom: 1px solid #eee; text-align: left; }
.bum-overdue td { background: #fff5f5; }

/* ---- Badges ---- */
.bum-badge {
    display: inline-block; padding: 2px 8px; border-radius: 3px;
    font-size: 11px; font-weight: 700; text-transform: uppercase;
}
.bum-badge-pending      { background: #fff3cd; color: #856404; }
.bum-badge-overdue      { background: #f8d7da; color: #721c24; font-weight: 700; letter-spacing:.02em; }
.bum-badge-paid         { background: #d4edda; color: #155724; }
.bum-badge-unpaid       { background: #f8d7da; color: #721c24; }
.bum-badge-cancelled    { background: #e2e3e5; color: #383d41; }
.bum-badge-refund_sent  { background: #cce5ff; color: #004085; }
.bum-badge-fifty_dp_paid{ background: #d1ecf1; color: #0c5460; }
.bum-badge-void         { background: #e2e3e5; color: #383d41; }
.bum-badge-expired      { background: #e2e3e5; color: #6c757d; }

/* ---- Courier / payment at checkout ---- */
.bum-courier-payment { margin: 20px 0; padding: 16px; border: 1px solid #ddd; border-radius: 6px; background: #f9f9f9; }
.bum-courier-payment h3 { margin: 0 0 12px; font-size: 16px; }
.bum-field label { font-weight: 600; font-size: 13px; }
#bum-qr-wrap { margin: 12px 0; text-align: center; }
.bum-qr { display: inline-block; margin: 0 12px; }
.bum-qr img { border: 2px solid #eee; border-radius: 6px; display: block; margin: 0 auto 6px; }
.bum-qr p { text-align: center; font-size: 13px; color: #555; margin: 0; }
.bum-qr-label { font-weight: 600; font-size: 14px; margin-bottom: 8px; }

/* ---- Proof of payment ---- */
.bum-proof-section { margin: 24px 0; padding: 16px; border: 1px solid #ddd; border-radius: 6px; background: #f9f9f9; }
.bum-proof-section h3 { margin: 0 0 10px; }
.bum-proof-upload-form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-top: 12px; }
.bum-proof-upload-form input[type="file"] { flex: 1 1 200px; }
.bum-proof-upload-form input[type="text"] { flex: 1 1 160px; padding: 6px 8px; border: 1px solid #ddd; border-radius: 4px; font-size: 13px; }
.bum-proof-list ul { margin: 4px 0 12px; padding-left: 16px; font-size: 13px; }
.bum-proof-msg { font-size: 13px; margin: 4px 0 0; width: 100%; }

.bum-proof-uploaded-link {
    display: block;
    font-size: 11px;
    color: #5a9a70;
    text-decoration: none;
    margin-bottom: 4px;
}
.bum-proof-uploaded-link:hover { text-decoration: underline; }
.bum-upcoming-dues { margin: 0; }
.bum-upcoming-dues h2 { margin-bottom: 16px; }
.bum-empty { background: #f0fff4; border: 1px solid #b7ebc2; border-radius: 6px; padding: 16px; font-size: 15px; }
.bum-overdue-row td { background: #fff8f8 !important; }
.bum-dues-filter { display:flex; align-items:center; gap:10px; margin:0 0 14px; flex-wrap:wrap; }
.bum-dues-filter select { padding:8px 12px; border:1.5px solid #e2d6cf; border-radius:8px; font-size:14px; background:#fff; }
.bum-dues-total-row td { border-top:2px solid #e2d6cf; padding-top:12px; font-size:15px; }
#bum-dues-total { color:#C2185B; font-size:17px; }
#bum-dues-total-label { color:#888; font-weight:500; font-size:13px; }
.bum-upload-trigger { font-size: 12px !important; padding: 4px 10px !important; }

/* ---- Upload modal ---- */
.bum-modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,.5);
    display: flex; align-items: center; justify-content: center; z-index: 9999;
}
.bum-modal {
    background: #fff; border-radius: 8px; padding: 24px;
    width: 90%; max-width: 440px; position: relative;
}
.bum-modal h3 { margin: 0 0 14px; }
.bum-modal label { display: block; margin-bottom: 10px; font-size: 13px; }
.bum-modal input[type="file"], .bum-modal textarea {
    display: block; width: 100%; margin-top: 4px;
    border: 1px solid #ddd; border-radius: 4px; padding: 6px; font-size: 13px;
}
.bum-modal-close {
    position: absolute; top: 12px; right: 14px;
    background: none; border: none; font-size: 18px; cursor: pointer; color: #888;
}
