/* BizDirectory Pro v2 - Frontend Styles */
:root {
  --bdp-brand: #4f46e5;
  --bdp-accent: #7c3aed;
  --bdp-brand-50: #eef2ff;
  --bdp-brand-100: #e0e7ff;
  --bdp-bg: #f8fafc;
  --bdp-card-bg: #ffffff;
  --bdp-text: #1e293b;
  --bdp-muted: #64748b;
  --bdp-border: #e2e8f0;
  --bdp-success: #059669;
  --bdp-warn: #d97706;
  --bdp-danger: #dc2626;
  --bdp-radius: 10px;
  --bdp-radius-sm: 6px;
  --bdp-shadow: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.03);
  --bdp-shadow-hover: 0 4px 12px rgba(79,70,229,.12);
}

.bdp-wrap { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; color: var(--bdp-text); }
.bdp-wrap * { box-sizing: border-box; }

.bdp-form { background: var(--bdp-card-bg); border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius); padding: 24px; margin-bottom: 24px; box-shadow: var(--bdp-shadow); }
.bdp-form-title { margin: 0 0 16px; color: var(--bdp-brand); font-size: 20px; font-weight: 700; }
.bdp-field { margin-bottom: 16px; }
.bdp-field label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 14px; color: var(--bdp-text); }
.bdp-input { width: 100%; padding: 10px 12px; border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius-sm); font-size: 14px; transition: border-color .15s, box-shadow .15s; background: #fff; }
.bdp-input:focus { outline: none; border-color: var(--bdp-brand); box-shadow: 0 0 0 3px var(--bdp-brand-100); }
.bdp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.bdp-grid-2 .bdp-field { margin-bottom: 0; }
.bdp-field-hint { font-size: 12px; color: var(--bdp-muted); margin-top: 4px; }

.bdp-btn { display: inline-block; padding: 10px 18px; border-radius: var(--bdp-radius-sm); font-size: 14px; font-weight: 600; cursor: pointer; border: none; transition: all .15s; text-decoration: none; color: #fff; line-height: 1.4; }
.bdp-btn-primary { background: var(--bdp-brand); }
.bdp-btn-primary:hover { background: #4338ca; transform: translateY(-1px); }
.bdp-btn-secondary { background: var(--bdp-accent); }
.bdp-btn-secondary:hover { background: #6d28d9; }
.bdp-btn-danger { background: var(--bdp-danger); }
.bdp-btn-danger:hover { background: #b91c1c; }
.bdp-btn-sm { padding: 5px 10px; font-size: 12px; }
.bdp-fetch-btn { margin-top: 8px; }

.bdp-fetch-status { display: inline-block; margin-left: 8px; font-size: 13px; color: var(--bdp-muted); }
.bdp-thumb-preview { width: 100%; min-height: 120px; border: 1px dashed var(--bdp-border); border-radius: var(--bdp-radius-sm); display: flex; align-items: center; justify-content: center; background: var(--bdp-bg); }
.bdp-thumb-preview img { max-width: 100%; max-height: 120px; border-radius: var(--bdp-radius-sm); }
.bdp-thumb-placeholder { color: var(--bdp-muted); font-size: 12px; padding: 8px; text-align: center; }

.bdp-form-message { margin-top: 12px; padding: 10px 14px; border-radius: var(--bdp-radius-sm); font-size: 14px; }
.bdp-form-message:empty { display: none; }
.bdp-form-message.success { background: #ecfdf5; color: var(--bdp-success); border-left: 4px solid var(--bdp-success); }
.bdp-form-message.error { background: #fef2f2; color: var(--bdp-danger); border-left: 4px solid var(--bdp-danger); }
.bdp-notice { padding: 14px 18px; background: var(--bdp-brand-50); color: var(--bdp-brand); border-radius: var(--bdp-radius-sm); margin-bottom: 16px; }
.bdp-notice-warn { background: #fffbeb; color: var(--bdp-warn); }
.bdp-empty { text-align: center; padding: 40px; color: var(--bdp-muted); }

.bdp-spinner { display: inline-block; width: 12px; height: 12px; border: 2px solid var(--bdp-border); border-top-color: var(--bdp-brand); border-radius: 50%; animation: bdp-spin .6s linear infinite; }
@keyframes bdp-spin { to { transform: rotate(360deg); } }

/* Listing toolbar */
.bdp-listing-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; padding: 8px 0; }
.bdp-result-count { color: var(--bdp-muted); font-size: 13px; font-weight: 600; }
.bdp-view-toggle { display: inline-flex; gap: 4px; background: var(--bdp-bg); border-radius: var(--bdp-radius-sm); padding: 3px; }
.bdp-view-toggle button { background: transparent; border: none; padding: 6px 10px; cursor: pointer; border-radius: 4px; color: var(--bdp-muted); display: flex; align-items: center; }
.bdp-view-toggle button.active { background: var(--bdp-card-bg); color: var(--bdp-brand); box-shadow: 0 1px 2px rgba(0,0,0,.05); }

/* Grid view */
.bdp-listing.bdp-view-grid .bdp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.bdp-listing.bdp-view-grid .bdp-card { flex-direction: column; }

/* List view */
.bdp-listing.bdp-view-list .bdp-grid { display: flex; flex-direction: column; gap: 12px; }
.bdp-listing.bdp-view-list .bdp-card { display: grid; grid-template-columns: 140px 1fr; gap: 0; }
.bdp-listing.bdp-view-list .bdp-card-thumb { aspect-ratio: auto; height: 100%; min-height: 110px; }

.bdp-card { background: var(--bdp-card-bg); border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius); overflow: hidden; transition: all .2s; box-shadow: var(--bdp-shadow); display: flex; }
.bdp-card:hover { box-shadow: var(--bdp-shadow-hover); border-color: var(--bdp-brand-100); transform: translateY(-2px); }
.bdp-card-thumb { width: 100%; aspect-ratio: 4/3; overflow: hidden; background: var(--bdp-bg); }
.bdp-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.bdp-card:hover .bdp-card-thumb img { transform: scale(1.05); }
.bdp-card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.bdp-card-title { margin: 0 0 8px; font-size: 16px; font-weight: 700; line-height: 1.3; }
.bdp-card-title a { color: var(--bdp-text); text-decoration: none; }
.bdp-card-title a:hover { color: var(--bdp-brand); }
.bdp-card-desc { color: var(--bdp-muted); font-size: 13px; margin: 0 0 12px; flex: 1; line-height: 1.5; }
.bdp-card-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.bdp-tag { background: var(--bdp-brand-50); color: var(--bdp-brand); padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; }
.bdp-tag-soft { background: #f1f5f9; color: var(--bdp-muted); }
.bdp-card-stats { display: flex; align-items: center; gap: 12px; padding-top: 10px; border-top: 1px solid var(--bdp-border); font-size: 12px; color: var(--bdp-muted); }
.bdp-stat { display: flex; align-items: center; gap: 4px; }
.bdp-report-btn { margin-left: auto; background: transparent; border: 1px solid var(--bdp-border); color: var(--bdp-danger); padding: 3px 10px; border-radius: 4px; font-size: 11px; cursor: pointer; font-weight: 600; }
.bdp-report-btn:hover { background: #fef2f2; }
.bdp-report-btn:disabled { cursor: not-allowed; opacity: .6; }

.bdp-pagination { margin: 24px 0; text-align: center; }
.bdp-pagination .page-numbers { display: inline-block; padding: 8px 12px; margin: 0 2px; border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius-sm); color: var(--bdp-text); text-decoration: none; font-size: 13px; background: #fff; }
.bdp-pagination .page-numbers.current { background: var(--bdp-brand); color: #fff; border-color: var(--bdp-brand); }
.bdp-pagination .page-numbers:hover:not(.current) { border-color: var(--bdp-brand); color: var(--bdp-brand); }

.bdp-badge { display: inline-block; padding: 3px 8px; border-radius: 4px; font-size: 11px; font-weight: 700; }
.bdp-badge-active { background: #ecfdf5; color: var(--bdp-success); }
.bdp-badge-inactive { background: #f1f5f9; color: var(--bdp-muted); }
.bdp-badge-warn { background: #fffbeb; color: var(--bdp-warn); }
.bdp-badge-featured { background: var(--bdp-accent); color: #fff; }

.bdp-table { width: 100%; border-collapse: collapse; margin: 16px 0; background: #fff; }
.bdp-table th, .bdp-table td { padding: 10px 12px; border: 1px solid var(--bdp-border); text-align: left; font-size: 13px; }
.bdp-table th { background: var(--bdp-bg); font-weight: 700; }

.bdp-login-required { background: var(--bdp-card-bg); padding: 32px; border-radius: var(--bdp-radius); text-align: center; border: 1px solid var(--bdp-border); }
.bdp-login-required p { margin-bottom: 12px; color: var(--bdp-muted); }
.bdp-login-required .bdp-btn { margin: 0 4px; }

.bdp-ad { display: block; margin: 16px 0; text-align: center; }
.bdp-ad-image { max-width: 100%; height: auto; border-radius: var(--bdp-radius-sm); }
.bdp-ad-link { display: inline-block; }

.bdp-website-directory .bdp-website-card { background: #fff; border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius); padding: 16px; text-decoration: none; color: inherit; display: flex; flex-direction: column; align-items: center; gap: 8px; transition: all .15s; }
.bdp-website-directory .bdp-website-card:hover { box-shadow: var(--bdp-shadow-hover); transform: translateY(-2px); }
.bdp-website-logo { width: 60px; height: 60px; border-radius: 50%; object-fit: cover; }
.bdp-website-card-body h3 { margin: 0; font-size: 15px; color: var(--bdp-brand); }
.bdp-website-card-body p { margin: 4px 0 0; font-size: 12px; color: var(--bdp-muted); text-align: center; }

/* Toast notifications */
.bdp-toast { position: fixed; bottom: 24px; right: 24px; padding: 12px 20px; background: #1e293b; color: #fff; border-radius: var(--bdp-radius-sm); box-shadow: 0 8px 24px rgba(0,0,0,.2); opacity: 0; transform: translateY(20px); transition: all .25s; z-index: 99999; font-size: 14px; max-width: 320px; }
.bdp-toast.show { opacity: 1; transform: translateY(0); }
.bdp-toast-success { background: var(--bdp-success); }
.bdp-toast-error { background: var(--bdp-danger); }

.bdp-premium-banner { background: linear-gradient(135deg, #fef3c7, #fde68a); padding: 12px 18px; border-radius: var(--bdp-radius); margin-bottom: 18px; display: flex; align-items: center; gap: 12px; }
.bdp-premium-badge { background: var(--bdp-accent); color: #fff; padding: 4px 12px; border-radius: 12px; font-size: 11px; font-weight: 700; letter-spacing: .5px; }
.bdp-premium-until { font-size: 13px; color: #78350f; font-weight: 600; }

@media (max-width: 640px) {
  .bdp-grid-2 { grid-template-columns: 1fr; }
  .bdp-listing.bdp-view-grid .bdp-grid { grid-template-columns: 1fr; }
  .bdp-listing.bdp-view-list .bdp-card { grid-template-columns: 1fr; }
  .bdp-form { padding: 16px; }
  .bdp-toast { left: 12px; right: 12px; bottom: 12px; max-width: none; }
}

.bdp-image-only, .bdp-code-only { transition: opacity .2s; }

/* ============ v2.1 ENHANCEMENTS ============ */

/* Report modal */
.bdp-report-modal-content { max-width: 480px; }
.bdp-report-modal-content h3 { margin: 0 0 8px; color: var(--bdp-danger); font-size: 18px; }
.bdp-modal-desc { color: var(--bdp-muted); font-size: 13px; margin: 0 0 16px; }
.bdp-report-options { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.bdp-report-option { background: #f1f5f9; border: 1px solid var(--bdp-border); color: var(--bdp-text); padding: 8px 14px; border-radius: 20px; font-size: 12px; cursor: pointer; transition: all .15s; font-weight: 600; }
.bdp-report-option:hover { border-color: var(--bdp-danger); color: var(--bdp-danger); }
.bdp-report-option.selected { background: var(--bdp-danger); color: #fff; border-color: var(--bdp-danger); }
#bdp-report-reason { width: 100%; padding: 10px 12px; border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius-sm); font-size: 14px; resize: vertical; font-family: inherit; }
#bdp-report-reason:focus { outline: none; border-color: var(--bdp-brand); box-shadow: 0 0 0 3px var(--bdp-brand-100); }
.bdp-modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 16px; }

/* Fetch status icon */
.bdp-fetch-icon { display: inline-flex; width: 16px; height: 16px; align-items: center; justify-content: center; border-radius: 50%; font-size: 11px; font-weight: 700; margin-right: 2px; }
.bdp-notice-icon { font-weight: 700; margin-right: 4px; }

/* Multi-step form */
.bdp-step-indicator { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 24px; padding: 16px; background: var(--bdp-bg); border-radius: var(--bdp-radius); }
.bdp-step { display: flex; align-items: center; gap: 6px; padding: 8px 14px; border-radius: 20px; font-size: 13px; font-weight: 600; color: var(--bdp-muted); background: #fff; border: 1px solid var(--bdp-border); transition: all .15s; }
.bdp-step.active { background: var(--bdp-brand); color: #fff; border-color: var(--bdp-brand); }
.bdp-step.completed { background: var(--bdp-success); color: #fff; border-color: var(--bdp-success); }
.bdp-step-num { display: inline-flex; width: 20px; height: 20px; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,.3); font-size: 11px; }
.bdp-form-step { display: none; }
.bdp-form-step.active { display: block; }
.bdp-form-step h4 { color: var(--bdp-brand); margin: 0 0 16px; padding-bottom: 8px; border-bottom: 2px solid var(--bdp-brand-50); font-size: 16px; }
.bdp-step-actions { display: flex; justify-content: space-between; margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--bdp-border); }

/* Repeatable rows */
.bdp-row { padding: 12px; border: 1px solid var(--bdp-border); border-radius: var(--bdp-radius-sm); margin-bottom: 10px; background: #fff; position: relative; }
.bdp-row:hover { border-color: var(--bdp-brand-100); }
.bdp-row .bdp-remove-row { position: absolute; top: 8px; right: 8px; }

/* Gallery preview */
.bdp-gallery-preview { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.bdp-gallery-preview img { width: 60px; height: 60px; object-fit: cover; border-radius: 4px; }

/* Section divider */
.bdp-section-divider { margin: 24px 0 16px; padding-bottom: 8px; border-bottom: 2px solid var(--bdp-brand); color: var(--bdp-brand); font-size: 18px; font-weight: 700; }

/* Star rating */
.bdp-star-rating { display: inline-flex; gap: 2px; }
.bdp-star-rating input { display: none; }
.bdp-star-rating label { cursor: pointer; font-size: 20px; color: #d1d5db; }
.bdp-star-rating input:checked ~ label { color: #fbbf24; }
.bdp-star-rating label:hover, .bdp-star-rating label:hover ~ label { color: #fbbf24; }

/* Template preview cards */
.bdp-template-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; margin: 12px 0; }
.bdp-template-card { border: 2px solid var(--bdp-border); border-radius: var(--bdp-radius); padding: 12px; cursor: pointer; transition: all .15s; background: #fff; }
.bdp-template-card:hover { border-color: var(--bdp-brand); }
.bdp-template-card.selected { border-color: var(--bdp-brand); background: var(--bdp-brand-50); }
.bdp-template-card .bdp-template-preview { height: 100px; background: linear-gradient(135deg, #e0e7ff, #c7d2fe); border-radius: 6px; margin-bottom: 8px; display: flex; align-items: center; justify-content: center; color: var(--bdp-brand); font-weight: 700; font-size: 12px; }
.bdp-template-card .bdp-template-name { font-size: 13px; font-weight: 700; color: var(--bdp-text); }
.bdp-template-card .bdp-template-badge { font-size: 10px; padding: 2px 6px; border-radius: 3px; margin-left: 4px; }
.bdp-template-badge-free { background: #ecfdf5; color: #059669; }
.bdp-template-badge-premium { background: #fef3c7; color: #d97706; }

/* Profile link style options */
.bdp-link-style-options { display: flex; gap: 8px; flex-wrap: wrap; }
.bdp-link-style-option { padding: 10px 16px; border: 2px solid var(--bdp-border); border-radius: var(--bdp-radius-sm); cursor: pointer; font-size: 12px; font-weight: 600; transition: all .15s; }
.bdp-link-style-option.selected { border-color: var(--bdp-brand); background: var(--bdp-brand-50); color: var(--bdp-brand); }

/* Responsive improvements */
@media (max-width: 768px) {
  .bdp-grid-2 { grid-template-columns: 1fr; }
  .bdp-template-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
  .bdp-form { padding: 16px; }
  .bdp-step-indicator { overflow-x: auto; flex-wrap: nowrap; padding: 12px; }
  .bdp-step { white-space: nowrap; flex-shrink: 0; }
  .bdp-modal-content { padding: 16px; margin: 10px; }
  .bdp-report-options { gap: 6px; }
  .bdp-report-option { padding: 6px 10px; font-size: 11px; }
}

@media (max-width: 480px) {
  .bdp-card-stats { flex-wrap: wrap; gap: 8px; }
  .bdp-report-btn { width: 100%; text-align: center; }
  .bdp-toast { left: 12px; right: 12px; bottom: 12px; max-width: none; }
  .bdp-step-actions { flex-direction: column-reverse; gap: 8px; }
  .bdp-step-actions .bdp-btn { width: 100%; }
}

/* ============ v2.2 AUTH FORMS ============ */
.bdp-auth-wrap { max-width: 480px; margin: 0 auto; background: #fff; border-radius: 12px; box-shadow: 0 4px 24px rgba(15,23,42,.08); overflow: hidden; }
.bdp-auth-tabs { display: flex; border-bottom: 1px solid #e2e8f0; }
.bdp-auth-tab { flex: 1; text-align: center; padding: 16px 12px; text-decoration: none; font-weight: 600; color: #64748b; border-bottom: 2px solid transparent; transition: all .15s; font-size: 14px; }
.bdp-auth-tab.active { color: var(--bdp-brand); border-bottom-color: var(--bdp-brand); background: var(--bdp-brand-50); }
.bdp-auth-tab:hover:not(.active) { color: var(--bdp-brand); background: #f8fafc; }
.bdp-auth-form { padding: 24px; }
.bdp-auth-error { background: #fef2f2; color: #dc2626; padding: 12px 16px; border-radius: 6px; margin: 16px; font-size: 13px; border-left: 4px solid #dc2626; }
.bdp-auth-success { background: #ecfdf5; color: #059669; padding: 12px 16px; border-radius: 6px; margin: 16px; font-size: 13px; border-left: 4px solid #059669; }
.bdp-auth-row { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; margin-top: 16px; }
.bdp-remember { font-size: 13px; color: #64748b; display: flex; align-items: center; gap: 6px; }
.bdp-auth-link { text-align: center; margin-top: 16px; font-size: 13px; color: #64748b; }
.bdp-auth-link a { color: var(--bdp-brand); font-weight: 600; text-decoration: none; }
.bdp-auth-link a:hover { text-decoration: underline; }
.bdp-auth-logged-in { text-align: center; padding: 40px 20px; background: #fff; border-radius: 12px; }
.bdp-auth-logged-in p { margin-bottom: 16px; color: #64748b; }
.bdp-dashboard-guest { padding: 20px 0; }
