/* ═══════════════════════════════════════════
   PURCHASE REGISTER — Light Bubble Theme
═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&family=Poppins:wght@500;600;700&display=swap');

#pr-wrap, #pr-admin-wrap {
    font-family: 'Nunito', sans-serif;
    position: relative;
    min-height: 420px;
    padding: 10px 0 30px;
}

/* ── BUBBLES ── */
.pr-bubbles {
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}
.pr-bubble {
    position: absolute;
    border-radius: 50%;
    opacity: 0.18;
    animation: prFloat linear infinite;
}
@keyframes prFloat {
    0%   { transform: translateY(110vh) scale(0.8); opacity: 0; }
    10%  { opacity: 0.18; }
    90%  { opacity: 0.12; }
    100% { transform: translateY(-20vh) scale(1.1); opacity: 0; }
}

/* ── CARD ── */
.pr-card {
    background: #ffffffee;
    border-radius: 20px;
    box-shadow: 0 8px 40px rgba(72,126,255,0.13);
    max-width: 520px;
    margin: 0 auto;
    padding: 28px 32px 22px;
    position: relative;
    z-index: 2;
    border: 1.5px solid #e0eaff;
}

.pr-header {
    text-align: center;
    margin-bottom: 22px;
}
.pr-logo { font-size: 2.2rem; }
.pr-header h2 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.4rem;
    color: #2d3a8c;
    margin: 4px 0 0;
}

/* ── STEP ── */
.pr-step { display: none; animation: prFadeIn 0.35s ease; }
.pr-step.active { display: block; }
@keyframes prFadeIn {
    from { opacity: 0; transform: translateX(30px); }
    to   { opacity: 1; transform: translateX(0); }
}
.pr-step-title {
    font-size: 0.78rem;
    font-weight: 700;
    color: #7a8ab8;
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-bottom: 16px;
}

/* ── FIELDS ── */
.pr-field-row { margin-bottom: 14px; }
.pr-field-row label {
    display: block;
    font-weight: 700;
    font-size: 0.88rem;
    color: #3a4a8a;
    margin-bottom: 5px;
}
.pr-field-row input[type="text"],
.pr-field-row input[type="number"],
.pr-field-row textarea,
.pr-field-row select {
    width: 100%;
    padding: 9px 13px;
    border: 1.5px solid #c7d4f8;
    border-radius: 10px;
    font-family: 'Nunito', sans-serif;
    font-size: 0.95rem;
    background: #f5f8ff;
    color: #1a2350;
    box-sizing: border-box;
    transition: border 0.2s;
    outline: none;
}
.pr-field-row input:focus,
.pr-field-row textarea:focus,
.pr-field-row select:focus {
    border-color: #4876ff;
    background: #fff;
}
.pr-field-row input[readonly] {
    background: #edf1fd;
    color: #556;
}

/* ── RADIO GROUPS ── */
.pr-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 4px;
}
.pr-radio-opt {
    display: flex;
    align-items: center;
    gap: 6px;
    background: #f0f4ff;
    border: 1.5px solid #c7d4f8;
    border-radius: 30px;
    padding: 6px 15px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #2d3a8c;
    cursor: pointer;
    transition: all 0.18s;
}
.pr-radio-opt:has(input:checked),
.pr-radio-opt.selected {
    background: #4876ff;
    color: #fff;
    border-color: #4876ff;
}
.pr-radio-opt input { display: none; }

/* ── NAV BUTTONS ── */
.pr-nav-row {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 18px;
}
.pr-btn-next, .pr-btn-submit, .pr-btn-prev {
    padding: 9px 26px;
    border: none;
    border-radius: 30px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}
.pr-btn-next, .pr-btn-submit {
    background: linear-gradient(135deg, #4876ff, #2d3a8c);
    color: #fff;
    box-shadow: 0 4px 15px rgba(72,118,255,0.35);
}
.pr-btn-next:hover, .pr-btn-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(72,118,255,0.45);
}
.pr-btn-prev {
    background: #f0f4ff;
    color: #4876ff;
    border: 1.5px solid #c7d4f8;
}

/* ── DOTS ── */
.pr-dots { text-align: center; margin-top: 18px; }
.pr-dot {
    display: inline-block;
    width: 10px; height: 10px;
    background: #c7d4f8;
    border-radius: 50%;
    margin: 0 4px;
    transition: background 0.3s, transform 0.3s;
}
.pr-dot.active {
    background: #4876ff;
    transform: scale(1.3);
}

/* ── PUBLIC BUTTON ── */
.pr-btn-public {
    background: linear-gradient(135deg, #00b894, #00796b);
    color: #fff;
    border: none;
    border-radius: 30px;
    padding: 10px 28px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    box-shadow: 0 4px 15px rgba(0,185,148,0.3);
    transition: all 0.2s;
    position: relative;
    z-index: 2;
}
.pr-btn-public:hover { transform: translateY(-2px); }

/* ── PUBLIC LIST TABLE ── */
#pr-public-list {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}
.pr-pub-title {
    font-family: 'Poppins', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: #2d3a8c;
    margin-bottom: 10px;
    text-align: center;
}
.pr-table-wrap { overflow-x: auto; }
.pr-table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffffee;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(72,118,255,0.10);
}
.pr-table th {
    background: linear-gradient(135deg, #4876ff, #2d3a8c);
    color: #fff;
    padding: 10px 12px;
    font-size: 0.82rem;
    font-weight: 700;
    text-align: left;
    white-space: nowrap;
}
.pr-table td {
    padding: 9px 12px;
    font-size: 0.83rem;
    border-bottom: 1px solid #eef0f8;
    color: #1a2350;
    word-break: break-word;
}
.pr-table tr:last-child td { border-bottom: none; }
.pr-table tr:nth-child(even) td { background: #f5f8ff; }
.pr-badge {
    display: inline-block;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 700;
}
.badge-Pending  { background:#fff3cd; color:#856404; }
.badge-Approved { background:#d1e7dd; color:#0f5132; }
.badge-Rejected { background:#f8d7da; color:#842029; }

/* ══════════════════════════
   POPUP
══════════════════════════ */
#pr-popup-overlay {
    position: fixed;
    inset: 0;
    background: rgba(30,40,100,0.45);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pr-popup {
    background: #fff;
    border-radius: 20px;
    padding: 28px 32px;
    max-width: 420px;
    width: 92%;
    box-shadow: 0 20px 60px rgba(30,40,100,0.25);
    animation: prPopIn 0.3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes prPopIn {
    from { transform: scale(0.7); opacity: 0; }
    to   { transform: scale(1);   opacity: 1; }
}
.pr-popup h3 {
    font-family: 'Poppins', sans-serif;
    color: #2d3a8c;
    margin: 0 0 16px;
    font-size: 1.15rem;
}
.pr-popup-row {
    display: flex;
    justify-content: space-between;
    padding: 6px 0;
    border-bottom: 1px solid #eef0f8;
    font-size: 0.9rem;
    color: #334;
}
.pr-popup-row:last-of-type { border-bottom: none; }
.pr-popup-row strong { color: #2d3a8c; min-width: 130px; }
.pr-popup-btns {
    display: flex;
    gap: 10px;
    margin-top: 18px;
    justify-content: flex-end;
}
.pr-btn-confirm {
    background: linear-gradient(135deg,#4876ff,#2d3a8c);
    color: #fff;
    border: none;
    border-radius: 30px;
    padding: 9px 24px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
}
.pr-btn-cancel {
    background: #f0f4ff;
    color: #c0392b;
    border: 1.5px solid #f5c6cb;
    border-radius: 30px;
    padding: 9px 20px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    cursor: pointer;
}

/* ══════════════════════════
   ADMIN PANEL
══════════════════════════ */
.pr-admin-login-box {
    max-width: 340px;
    margin: 40px auto;
    background: #ffffffee;
    border-radius: 18px;
    padding: 32px 28px;
    box-shadow: 0 8px 40px rgba(72,126,255,0.13);
    text-align: center;
    border: 1.5px solid #e0eaff;
}
.pr-admin-login-box h2 {
    font-family: 'Poppins', sans-serif;
    color: #2d3a8c;
    margin-bottom: 18px;
}
.pr-admin-login-box input {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid #c7d4f8;
    border-radius: 10px;
    font-size: 1rem;
    margin-bottom: 12px;
    box-sizing: border-box;
    background: #f5f8ff;
    outline: none;
}
.pr-admin-login-box button {
    background: linear-gradient(135deg,#4876ff,#2d3a8c);
    color: #fff;
    border: none;
    border-radius: 30px;
    padding: 10px 30px;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    cursor: pointer;
    font-size: 1rem;
}

.pr-admin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
    flex-wrap: wrap;
    gap: 10px;
}
.pr-admin-header h2 {
    font-family: 'Poppins', sans-serif;
    color: #2d3a8c;
    font-size: 1.2rem;
    margin: 0;
}
.pr-btn-logout {
    background: #e74c3c;
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 7px 20px;
    font-weight: 700;
    cursor: pointer;
}

/* ── STATS ── */
.pr-stats { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 16px; }
.pr-stat-box {
    flex: 1; min-width: 90px;
    background: #f0f4ff;
    border-radius: 12px;
    padding: 12px 14px;
    text-align: center;
    border: 1.5px solid #e0eaff;
}
.pr-stat-box .pr-stat-num {
    font-family: 'Poppins', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: #4876ff;
}
.pr-stat-box .pr-stat-label { font-size: 0.75rem; color: #7a8ab8; font-weight: 600; }

/* ── FILTER BAR ── */
.pr-filter-bar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 12px;
    align-items: center;
}
.pr-filter-bar select,
.pr-filter-bar input {
    padding: 7px 11px;
    border: 1.5px solid #c7d4f8;
    border-radius: 8px;
    font-size: 0.85rem;
    background: #f5f8ff;
    color: #1a2350;
    outline: none;
}
.pr-filter-bar button {
    background: #4876ff;
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 7px 16px;
    font-weight: 700;
    cursor: pointer;
    font-size: 0.85rem;
}

/* ── BULK BAR ── */
.pr-bulk-bar {
    display: flex;
    gap: 8px;
    align-items: center;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.pr-bulk-bar button {
    padding: 6px 16px;
    border: none;
    border-radius: 20px;
    font-weight: 700;
    cursor: pointer;
    font-size: 0.83rem;
    background: #27ae60;
    color: #fff;
}
.pr-bulk-bar button:nth-child(3) { background: #c0392b; }

/* ── ADMIN TABLE ROW ACTIONS ── */
.pr-row-actions { display: flex; gap: 5px; flex-wrap: wrap; }
.pr-row-actions button {
    padding: 4px 11px;
    border: none;
    border-radius: 14px;
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
}
.btn-approve { background: #27ae60; color: #fff; }
.btn-reject  { background: #e67e22; color: #fff; }
.btn-edit    { background: #f39c12; color: #fff; }
.btn-delete  { background: #e74c3c; color: #fff; }

/* ── EDIT MODAL ── */
#pr-edit-modal {
    position: fixed; inset: 0;
    background: rgba(30,40,100,0.45);
    backdrop-filter: blur(4px);
    z-index: 9999;
    display: flex; align-items: center; justify-content: center;
}
.pr-edit-box {
    background: #fff;
    border-radius: 18px;
    padding: 26px 28px;
    max-width: 400px;
    width: 94%;
    box-shadow: 0 20px 60px rgba(30,40,100,0.22);
}
.pr-edit-box h3 {
    font-family: 'Poppins', sans-serif;
    color: #2d3a8c;
    margin: 0 0 16px;
}

/* ── SUCCESS TOAST ── */
.pr-toast {
    position: fixed;
    bottom: 30px; left: 50%;
    transform: translateX(-50%) translateY(80px);
    background: #27ae60;
    color: #fff;
    padding: 12px 28px;
    border-radius: 30px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 0.95rem;
    z-index: 99999;
    box-shadow: 0 6px 24px rgba(39,174,96,0.35);
    transition: transform 0.4s cubic-bezier(.34,1.56,.64,1), opacity 0.3s;
    opacity: 0;
}
.pr-toast.show { transform: translateX(-50%) translateY(0); opacity: 1; }

/* ── MOBILE ── */
@media (max-width: 540px) {
    .pr-card { padding: 18px 14px; }
    .pr-radio-group { gap: 6px; }
    .pr-radio-opt { padding: 5px 12px; font-size: 0.83rem; }
}
