/* Family tree admin — Arabic RTL + El Messiri + brand palette */
:root,
[data-bs-theme='light'] {
  --background: #ffffff;
  --foreground: #1a1a1a;
  --primary: #7a1e2c;
  --primary-hover: #5e1722;
  --muted: #f8ecee;
  --surface: #f5f5f7;
  --link: #059669;

  --bs-font-sans-serif: 'El Messiri', -apple-system, blinkmacsystemfont, 'Segoe UI', sans-serif;
  --bs-body-font-family: 'El Messiri', -apple-system, blinkmacsystemfont, 'Segoe UI', sans-serif;
  --bs-body-bg: var(--background);
  --bs-body-color: var(--foreground);
  --bs-primary: var(--primary);
  --bs-primary-rgb: 122, 30, 44;
  --bs-link-color: var(--link);
  --bs-link-hover-color: #047857;
}

[data-bs-theme='light'] .btn-primary {
  --bs-btn-bg: var(--primary);
  --bs-btn-border-color: var(--primary);
  --bs-btn-hover-bg: var(--primary-hover);
  --bs-btn-hover-border-color: var(--primary-hover);
  --bs-btn-active-bg: var(--primary-hover);
  --bs-btn-active-border-color: var(--primary-hover);
}

[data-bs-theme='light'] .menu-item.active > .menu-link {
  color: var(--primary);
}

[data-bs-theme='light'] .menu-item.active::before {
  background: var(--primary);
}

[data-bs-theme='light'] .form-check-input:checked {
  background-color: var(--primary);
  border-color: var(--primary);
}

[data-bs-theme='light'] .card {
  border-color: rgba(122, 30, 44, 0.08);
}

[data-bs-theme='light'] .layout-navbar {
  background-color: var(--background) !important;
}

html[dir='rtl'] body {
  font-family: 'El Messiri', sans-serif;
}

.dz-message.needsclick {
  text-align: center;
}

.family-admin-page-title {
  margin-bottom: 1.5rem;
}

/* Brand logos — primary on light surfaces, white on primary bg */
.family-admin-logo {
  display: block;
  height: auto;
  max-width: 100%;
  object-fit: contain;
}

.family-admin-logo--on-light,
.family-admin-logo--sidebar {
  max-height: 4.25rem;
  width: auto;
  max-width: 220px;
}

.family-admin-logo--on-primary,
.family-admin-logo--auth {
  max-height: 6.5rem;
  width: auto;
  max-width: 320px;
  margin-inline: auto;
}

.family-admin-auth-banner {
  background-color: var(--primary);
  padding: 2.25rem 1.5rem;
  text-align: center;
}

.family-admin-auth-card .card-body {
  background-color: var(--background);
}

.layout-menu .app-brand {
  padding-block: 1.25rem 1rem;
}

.layout-menu .app-brand-link {
  min-height: 4.5rem;
  padding-inline: 0.5rem;
}

[data-bs-theme='light'] .btn-primary .family-admin-logo--on-light {
  display: none;
}

/* Select2 inside Bootstrap offcanvas — dropdown was clipped / behind panel */
.offcanvas .select2-container {
  display: block;
  width: 100% !important;
  z-index: 1;
}

.offcanvas .select2-container .select2-selection--single {
  min-height: calc(2.25rem + 2px);
  align-items: center;
}

.offcanvas .select2-container .select2-selection__rendered {
  line-height: 2.25rem;
  padding-inline: 0.875rem;
}

.offcanvas .select2-container--open {
  z-index: 1100;
}

.offcanvas .select2-dropdown {
  z-index: 1100 !important;
}

.select2-container--open .select2-dropdown {
  z-index: 1100;
}

.offcanvas .select2-search__field {
  width: 100% !important;
}

/* Hide BrowserSync connected badge if notify is re-enabled */

/* Media dropzones — always interactive */
.dropzone {
  min-height: 11rem;
  cursor: pointer !important;
  opacity: 1 !important;
}

.dropzone .dz-message {
  pointer-events: none;
}

.dropzone .dz-preview {
  cursor: default;
}

/* Select2 multi-select — React-style chips */

.family-admin-multi-select + .select2-container {
  width: 100% !important;
}

/* Album comments expand */
.album-comments-row td {
  background: var(--surface);
  padding: 1rem 1.25rem !important;
}

.album-comments-panel .table {
  margin-bottom: 0;
  background: var(--background);
}

#nav-notifications-badge {
  font-size: 0.65rem;
  min-width: 1.1rem;
  padding: 0.2em 0.45em;
}

.inbox-row {
  cursor: pointer;
}

.inbox-row--unread td {
  background-color: rgba(122, 30, 44, 0.04);
}

.inbox-unread-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--primary);
}

.inbox-row:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: -2px;
}

/* Banner settings — current image preview */
.family-admin-banner-preview__label {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--foreground);
  margin-bottom: 0.5rem;
}

.family-admin-banner-preview__frame {
  border: 1px solid rgba(122, 30, 44, 0.15);
  border-radius: 0.5rem;
  overflow: hidden;
  background: var(--surface);
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.family-admin-banner-preview__frame img {
  display: block;
  width: 100%;
  max-height: 220px;
  object-fit: contain;
}

.family-admin-banner-preview__empty {
  border: 2px dashed rgba(122, 30, 44, 0.2);
  border-radius: 0.5rem;
  padding: 2.5rem 1rem;
  text-align: center;
  color: #6c757d;
  background: var(--muted);
  min-height: 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.family-admin-banner-preview__empty .bx {
  font-size: 2rem;
  opacity: 0.6;
}
