/* ==========================================================================
   Base & General Styles
   ========================================================================== */
.brp-portal, .brp-submit, .brp-dash, .brp-account { 
    border: 1px solid #e2e8f0; 
    padding: 20px; 
    border-radius: 12px; 
    background: #ffffff; 
    margin-bottom: 24px; 
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}
.brp-notice { 
    background: #f0fdf4; 
    border: 1px solid #bbf7d0; 
    color: #15803d;
    padding: 12px; 
    border-radius: 8px; 
    margin-bottom: 16px;
}
.brp-notice-error {
    background-color: #fef2f2;
    border-color: #fecaca;
    color: #b91c1c;
}
.brp-meta { margin: 12px 0; font-size: 14px; color: #475569; }
.brp-meta a { color: #4f46e5; text-decoration: none; }
.brp-meta a:hover { text-decoration: underline; }
.brp-disclaimer { 
    margin-top: 24px; 
    font-size: 13px; 
    color: #475569; 
    background: #f8fafc; 
    padding: 12px; 
    border-radius: 8px; 
    border-left: 4px solid #64748b;
}
.brp-featured-media { margin-bottom: 24px; }
.brp-featured-media img,
.brp-featured-media video { max-width: 100%; height: auto; border-radius: 12px; }

/* Form Messages (Success / Error) */
#brp-register-msg, #brp-submit-msg, #brp-account-msg {
    padding: 12px; margin-top: 10px; border-radius: 8px; font-weight: 500;
}
.brp-msg-success { background-color: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.brp-msg-error { background-color: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }

/* Phone Number Field Styling */
.brp-phone-field { display: flex; align-items: center; }
.brp-phone-prefix {
    padding: 8px 12px; background-color: #f3f4f6; border: 1px solid #d1d5db;
    border-right: none; border-radius: 6px 0 0 6px; font-weight: 500;
}
.brp-phone-field input { border-radius: 0 6px 6px 0 !important; }

/* ==========================================================================
   Tabs & Panels (Login/Register)
   ========================================================================== */
.brp-tabs { display: flex; gap: 4px; margin-bottom: 16px; border-bottom: 1px solid #e2e8f0; }
.brp-tab { 
    border: 1px solid transparent; background: transparent; color: #475569;
    padding: 10px 16px; cursor: pointer; border-radius: 6px 6px 0 0; 
    margin-bottom: -1px; font-weight: 600;
}
.brp-tab:hover { background: #f8fafc; color: #1e293b; }
.brp-panel { padding: 16px; }

/* ==========================================================================
   Buttons & CTAs
   ========================================================================== */
.brp-cta { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin: 20px 0; }
.brp-like-btn, .brp-enq-btn { 
    border: 1px solid #d1d5db; background: #ffffff; padding: 8px 16px; border-radius: 30px; 
    text-decoration: none; cursor: pointer; font-size: 14px; font-weight: 600;
    color: #374151; display: inline-flex; align-items: center; gap: 8px;
    transition: all 0.2s ease-in-out;
}
.brp-like-btn:hover, .brp-enq-btn:hover { background-color: #f9fafb; border-color: #9ca3af; }
.brp-like-btn.brp-disabled, .brp-like-btn[disabled] { 
    opacity: 1; cursor: default; background-color: #f0fdf4;
    border-color: #16a34a; color: #15803d;
}
.brp-like-count, .brp-enq-count { 
    background: #e0e7ff; color: #4338ca; padding: 2px 10px; border-radius: 12px; 
    font-weight: 700; font-size: 12px;
}
.brp-icon { vertical-align: middle; }

/* Share Buttons */
.brp-share { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 20px 0; }
.brp-sh, .brp-copy { 
    padding: 6px 12px; border: 1px solid #e2e8f0; border-radius: 20px; 
    background: #f8fafc; font-size: 13px; text-decoration: none; 
    cursor: pointer; color: #334155; transition: background-color 0.2s;
}
.brp-sh:hover, .brp-copy:hover { background-color: #e2e8f0; }

/* ==========================================================================
   Dashboard & Admin
   ========================================================================== */
.brp-dash-controls { display: flex; gap: 8px; margin-bottom: 16px; }
.brp-dash-table { width: 100%; border-collapse: collapse; background: #fff; }
.brp-dash-table th, .brp-dash-table td { border: 1px solid #e5e7eb; padding: 10px 12px; font-size: 14px; text-align: left; }
.brp-dash-table th { background-color: #f9fafb; font-weight: 600; }
.brp-dash-table tbody tr:nth-child(even) { background-color: #f9fafb; }
.brp-filter-form { display: flex; gap: 10px; margin-bottom: 15px; align-items: center; flex-wrap: wrap; }
.brp-pagination { margin-top: 20px; padding-bottom: 10px; }
.brp-pagination .page-numbers { padding: 6px 12px; border: 1px solid #cbd5e1; text-decoration: none; margin: 0 2px; border-radius: 4px; color: #334155; }
.brp-pagination .page-numbers:hover { background-color: #f1f5f9; }
.brp-pagination .page-numbers.current { background-color: #e2e8f0; font-weight: bold; color: #1e293b; }

/* User Dashboard Subscription Box */
.brp-sub-status-box {
    padding: 20px; border-radius: 12px; margin-bottom: 24px;
    border: 1px solid; display: flex; justify-content: space-between; align-items: center;
}
.brp-sub-status-active { background-color: #f0fdf4; border-color: #bbf7d0; color: #14532d; }
.brp-sub-status-paused { background-color: #fffbeb; border-color: #fde68a; color: #78350f; }
.brp-sub-status-stopped { background-color: #fef2f2; border-color: #fecaca; color: #991b1b; }
.brp-sub-status-box strong { font-size: 1.1em; }
.brp-sub-status-box .button {
    background-color: #4f46e5; color: white; text-decoration: none;
    padding: 10px 20px; border-radius: 8px; font-weight: 600;
}

/* Admin Status Badges */
.brp-status-badge {
    display: inline-block; padding: 3px 10px; border-radius: 15px;
    font-size: 12px; font-weight: 600; text-transform: capitalize;
}
.brp-status-active { background-color: #dcfce7; color: #166534; }
.brp-status-paused { background-color: #fef9c3; color: #854d0e; }
.brp-status-stopped { background-color: #fee2e2; color: #991b1b; }
.button.brp-grant-button { background-color: #16a34a; border-color: #15803d; }
.button.brp-grant-button:hover { background-color: #15803d; }


/* ==========================================================================
   Homepage Filters & Card Grid
   ========================================================================== */
.brpt-latest, .brpt-featured { padding-top: 24px; }
.brpt-sec-h h2 { font-size: 2em; text-align: center; margin-bottom: 24px; color: #1e293b; }
.brpt-filterbar {
    display: flex; gap: 12px; margin: 0 auto 32px auto; padding: 16px;
    background-color: #fff; border-radius: 12px;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    max-width: 800px; flex-wrap: wrap;
}
.brpt-filterbar input, .brpt-filterbar select {
    flex-grow: 1; padding: 10px; border: 1px solid #d1d5db; border-radius: 8px;
}
.brpt-filterbar button {
    padding: 10px 20px; background-color: #4f46e5; color: white;
    border: none; border-radius: 8px; cursor: pointer; font-weight: 600;
}
.brpt-cards-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 24px;
}
.brpt-card {
    background-color: #fff; border-radius: 12px;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
    display: flex; flex-direction: column; transition: transform 0.2s, box-shadow 0.2s;
    overflow: hidden; position: relative;
}
.brpt-card:hover { transform: translateY(-5px); box-shadow: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1); }

/* Card Image Styles */
.brpt-card-image-link {
    display: block; height: 180px; background-color: #f3f4f6; overflow: hidden;
}
.brpt-card-image-link img {
    width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s ease;
}
.brpt-card:hover .brpt-card-image-link img { transform: scale(1.05); }
.brpt-card-image-placeholder { display: flex; align-items: center; justify-content: center; color: #9ca3af; }

.brpt-card-content { display: flex; flex-direction: column; flex-grow: 1; padding: 16px; }
.brpt-card-header { display: flex; justify-content: space-between; font-size: 12px; color: #64748b; margin-bottom: 8px; }
.brpt-card-type {
    background-color: #eef2ff; color: #4338ca; padding: 2px 8px;
    border-radius: 12px; font-weight: 600;
}
.brpt-card-title { margin: 0; font-size: 1.15em; }
.brpt-card-title a { color: #1e293b; text-decoration: none; }
.brpt-card-excerpt { font-size: 14px; color: #475569; flex-grow: 1; line-height: 1.6; margin-top: 8px; }
.brpt-card-footer {
    display: flex; justify-content: space-between; align-items: center;
    margin-top: 16px; border-top: 1px solid #f1f5f9; padding-top: 16px;
}
.brpt-card-date { font-size: 13px; color: #64748b; }
.brpt-card-link { font-size: 14px; font-weight: 600; color: #4f46e5; text-decoration: none; }
.brpt-no-results, .brpt-load-more-wrap {
    text-align: center; grid-column: 1 / -1; padding: 40px 20px;
}
.brpt-load-more-wrap button {
    padding: 12px 24px; background-color: #fff; color: #4f46e5;
    border: 1px solid #d1d5db; border-radius: 8px; cursor: pointer; font-weight: 600;
}

/* Ticker Styles */
.brp-ticker-wrap { width: 100%; overflow: hidden; background: #1e293b; color: white; padding: 10px 0; margin-bottom: 24px; }
.brp-ticker {
    display: flex; list-style: none; margin: 0; padding: 0;
    animation: ticker-scroll 60s linear infinite;
}
.brp-ticker:hover { animation-play-state: paused; }
.brp-ticker-item { flex-shrink: 0; margin-right: 40px; }
.brp-ticker-item a { color: white; text-decoration: none; display: flex; align-items: center; gap: 10px; }
.brp-ticker-img { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; }
.brp-ticker-type { font-weight: 600; color: #93c5fd; }
@keyframes ticker-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* Homepage CTA & Community Section */
.brpt-cta-section, .brp-community-section { text-align: center; padding: 40px 20px; background-color: #f8fafc; border-radius: 12px; margin: 32px 0; }
.brpt-cta-section h2, .brp-community-section h2 { font-size: 1.8em; margin-top: 0; }
.brpt-cta-section p, .brp-community-section p { color: #475569; }
.brp-community-links { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; margin-top: 20px;}
.brp-community-links .button { text-decoration: none; padding: 12px 24px; border-radius: 8px; font-weight: 600; border: none;}
.brp-community-links .whatsapp-btn { background-color: #25d366; color: white; }
.brp-community-links .telegram-btn { background-color: #0088cc; color: white; }
.brp-community-links .admin-contact-btn { background-color: #64748b; color: white; }


/* Featured Section Styles */
.brpt-featured { background-color: #f0f9ff; padding: 32px 0; }
.brpt-card-featured { border: 2px solid #fbbf24; }
.brpt-card-badge {
    position: absolute; top: 10px; right: 10px; background-color: #fbbf24; color: #78350f;
    padding: 4px 10px; border-radius: 15px; font-size: 12px; font-weight: 700;
}

/* AJAX Loader Spinner */
.brpt-spinner {
    width: 50px; height: 50px; border: 5px solid #f3f3f3;
    border-top: 5px solid #4f46e5; border-radius: 50%;
    animation: spin 1s linear infinite; margin: 0 auto;
}
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }


/* My Account Page Styles */
.brp-account-wrap {
    max-width: 600px; margin: 20px auto; padding: 24px;
    background-color: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}
.brp-account-wrap h3, .brp-account-wrap h4 {
    color: #1e293b; border-bottom: 1px solid #f1f5f9; padding-bottom: 8px;
    margin-top: 20px; margin-bottom: 16px;
}
.brp-account-wrap h3:first-child { margin-top: 0; }
.brp-account-wrap p { margin-bottom: 16px; }
.brp-account-wrap label { display: block; font-weight: 600; margin-bottom: 6px; color: #334155; }
.brp-account-wrap input[type="email"],
.brp-account-wrap input[type="tel"],
.brp-account-wrap input[type="password"] {
    width: 100%; padding: 10px; border: 1px solid #d1d5db;
    border-radius: 8px; box-sizing: border-box; 
}
.brp-account-wrap input:disabled { background-color: #f3f4f6; cursor: not-allowed; }
.brp-account-wrap small { display: block; margin-top: 4px; font-size: 12px; color: #64748b; }
#brp-account-msg { margin-top: 16px; }

/* Pricing Page & Payment Options */
.brp-pricing-page-wrap { max-width: 700px; margin: 20px auto; }
.brp-payment-option-box {
    padding: 24px; border: 1px solid #e2e8f0; border-radius: 12px;
    background: #ffffff; margin-bottom: 24px;
    box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
}
.brp-payment-option-box h3 { margin-top: 0; color: #1e293b; }
.brp-payment-option-box p { color: #475569; }
.brp-price-display { font-size: 1.2em; margin: 16px 0; }
.brp-offline-details {
    background-color: #f8fafc; border: 1px solid #e2e8f0;
    padding: 16px; border-radius: 8px; margin-bottom: 16px;
}
.brp-offline-details h4 { margin-top: 0; margin-bottom: 8px; }
.brp-offline-note { font-size: 13px; font-style: italic; color: #64748b; margin-top: 16px; }

