/* ============================================================
   PG Finder — Owner Dashboard  (owner-dashboard.css)
   Page-specific styles only. Extends ../styles.css tokens.
   Do NOT modify styles.css.
   ============================================================ */


/* ── Page shell ──────────────────────────────────────────────────────────── */
.owner-dashboard-page {
  background-color: var(--color-surface);
  min-height: 100vh;
}


/* ════════════════════════════════════════════════════════════════════════════
   NAVBAR
════════════════════════════════════════════════════════════════════════════ */

.dash-navbar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--navbar-h);
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--color-border);
  z-index: 100;
  box-shadow: var(--shadow-xs);
}

.dash-navbar__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  height: 100%;
  padding: 0 var(--space-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}

/* Logo */
.dash-navbar__logo {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  text-decoration: none;
  flex-shrink: 0;
}

.dash-navbar__logo-icon {
  width: 34px;
  height: 34px;
  background-color: var(--color-primary);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.dash-navbar__brand {
  font-size: var(--font-size-lg);
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.025em;
}

/* Centre badge */
.dash-navbar__badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  background: var(--color-primary-light);
  border: 1px solid var(--color-primary-border);
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
}

/* Right actions */
.dash-navbar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-shrink: 0;
}


/* ════════════════════════════════════════════════════════════════════════════
   MAIN CONTENT SHELL
════════════════════════════════════════════════════════════════════════════ */

.dash-main {
  padding-top: calc(var(--navbar-h) + var(--space-8));
  padding-bottom: var(--space-16);
}

.dash-container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-8);
}


/* ════════════════════════════════════════════════════════════════════════════
   DASHBOARD HEADER — Owner profile summary
════════════════════════════════════════════════════════════════════════════ */

.dash-header {
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--color-border);
}

.dash-header__profile {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.dash-header__avatar {
  width: 60px;
  height: 60px;
  background: var(--color-primary-light);
  border: 2px solid var(--color-primary-border);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--color-primary);
}

.dash-header__greeting {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}

.dash-header__name {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem) !important;
  font-weight: 800 !important;
  color: var(--color-text-primary);
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin-bottom: var(--space-2);
}

.dash-header__meta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.dash-header__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  font-weight: 500;
}

.dash-header__meta-item svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
}


/* ════════════════════════════════════════════════════════════════════════════
   STATISTICS CARDS
   id="totalProperties", id="activeProperties", id="newMessages" — locked
════════════════════════════════════════════════════════════════════════════ */

.dashboard-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-bottom: var(--space-8);
}

.stat-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-6);
  display: flex;
  align-items: center;
  gap: var(--space-5);
  transition: var(--transition-base);
}

.stat-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.stat-card__icon {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.stat-card__icon--blue {
  background: var(--color-primary-light);
  color: var(--color-primary);
}

.stat-card__icon--green {
  background: var(--color-success-light);
  color: var(--color-success);
}

.stat-card__icon--amber {
  background: #FFFBEB;
  color: #D97706;
}

.stat-card__body {
  min-width: 0;
}

/* JS sets .textContent on these — keep the IDs, only style the element */
.stat-card__label {
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  margin-bottom: 4px;
  display: block;
}

.stat-card__value {
  font-size: var(--font-size-3xl);
  font-weight: 800;
  color: var(--color-text-primary);
  letter-spacing: -0.04em;
  line-height: 1;
  display: block;
}


/* ════════════════════════════════════════════════════════════════════════════
   TAB NAVIGATION
   switchTab() in inline script toggles .dash-tab-btn--active
   and .dash-tab-panel--active
════════════════════════════════════════════════════════════════════════════ */

.dash-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--color-border);
  margin-bottom: var(--space-6);
}

.dash-tab-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 11px var(--space-5);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px; /* overlap the container border */
  font-size: var(--font-size-sm);
  font-weight: 600;
  font-family: var(--font-family);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: var(--transition-base);
  white-space: nowrap;
}

.dash-tab-btn:hover {
  color: var(--color-text-primary);
  background: var(--color-surface);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.dash-tab-btn--active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

.dash-tab-btn--active:hover {
  background: none;
}

/* Tab panels — hidden by default */
.dash-tab-panel {
  display: none;
}

.dash-tab-panel--active {
  display: block;
}


/* ════════════════════════════════════════════════════════════════════════════
   PROPERTY CARDS
   Class names generated by createPropertyCard() in owner-dashboard.js.
   id="propertiesContainer" locked — JS sets .innerHTML
════════════════════════════════════════════════════════════════════════════ */

/* Container grid — wraps all property cards */
#propertiesContainer {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--space-5);
}

.property-card {
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  transition: var(--transition-base);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  text-decoration: none;
}

.property-card:hover {
  border-color: var(--color-primary-border);
  box-shadow: 0 8px 24px rgba(37, 99, 235, 0.1);
  transform: translateY(-3px);
}

/* Property card image section */
.property-card__image {
  width: 100%;
  height: 180px;
  overflow: hidden;
  border-radius: var(--radius-md);
  margin-bottom: var(--space-2);
  background: var(--color-surface-alt);
}

.property-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.property-card:hover .property-card__image img {
  transform: scale(1.05);
}

/* Placeholder for properties without images */
.property-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  color: var(--color-text-muted);
  background: var(--color-surface);
  border: 2px dashed var(--color-border);
  border-radius: var(--radius-md);
}

.property-card__placeholder svg {
  opacity: 0.6;
}

.property-card__placeholder span {
  font-size: var(--font-size-xs);
  font-weight: 500;
  text-align: center;
}

/* Card header row: icon + name + status badge */
.property-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

/* Kept as .property-header for any legacy CSS hit — also add .property-card__head */
.property-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}

.property-card__title-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}

.property-card__icon {
  width: 36px;
  height: 36px;
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

/* JS template: <h3>${property.PRT}</h3> — keep .property-card__name as alias */
.property-card__name,
.property-header h3 {
  font-size: var(--font-size-base) !important;
  font-weight: 700 !important;
  color: var(--color-text-primary);
  text-transform: capitalize;
  line-height: 1.3;
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Status badges — generated by JS */
.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: capitalize;
  white-space: nowrap;
  flex-shrink: 0;
}

.status-active {
  background: var(--color-success-light);
  color: #065F46;
  border: 1px solid var(--color-success-border);
}

.status-pending {
  background: #FFFBEB;
  color: #92400E;
  border: 1px solid #FCD34D;
}

/* Property info rows */
.property-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.property-info__row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.property-info__icon {
  color: var(--color-text-muted);
  flex-shrink: 0;
}

/* Keep legacy .property-info p for any unmodified path */
.property-info p {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.property-info strong {
  color: var(--color-text-primary);
  font-weight: 600;
}

/* Card footer — "View Details →" */
.property-card__footer {
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
  margin-top: auto;
}

.property-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-primary);
  transition: gap 0.15s ease;
}

.property-card:hover .property-card__cta {
  gap: 8px;
}


/* ── Empty / Error states for properties ─────────────────────────────────── */
.no-properties {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-20) var(--space-6);
  color: var(--color-text-secondary);
  font-size: var(--font-size-base);
}

.no-properties a {
  color: var(--color-primary);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.error-message {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--space-6) var(--space-8);
  color: #B91C1C;
  background: var(--color-error-light);
  border: 1px solid var(--color-error-border);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-base);
  font-weight: 500;
}


/* ════════════════════════════════════════════════════════════════════════════
   MESSAGE CARDS
   Class names generated by createMessageCard() in owner-dashboard.js.
   id="messagesList" locked — JS sets .innerHTML
════════════════════════════════════════════════════════════════════════════ */

#messagesList {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.message-card {
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5) var(--space-6);
  transition: var(--transition-base);
}

.message-card:hover {
  border-color: var(--color-primary-border);
  box-shadow: var(--shadow-md);
}

/* Card header: property name + status badge */
.message-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}

.message-property-info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  min-width: 0;
}

.message-prop-icon {
  width: 30px;
  height: 30px;
  background: var(--color-primary-light);
  color: var(--color-primary);
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.message-property {
  font-weight: 700;
  color: var(--color-text-primary);
  font-size: var(--font-size-base);
  text-transform: capitalize;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Message status chips */
.message-status {
  display: inline-flex;
  align-items: center;
  padding: 3px 11px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
  flex-shrink: 0;
  text-transform: capitalize;
}

.status-waiting_for_reply {
  background: #FFFBEB;
  color: #92400E;
  border: 1px solid #FCD34D;
}

.status-requested_callback {
  background: var(--color-primary-light);
  color: var(--color-primary);
  border: 1px solid var(--color-primary-border);
}

.status-Contacted {
  background: var(--color-success-light);
  color: #065F46;
  border: 1px solid var(--color-success-border);
}

/* Message body */
.message-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

/* User / phone / message rows — SVG + text */
.message-user,
.message-phone {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-primary);
}

.message-user svg,
.message-phone svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.message-phone {
  color: var(--color-primary);
  font-weight: 600;
}

.message-phone svg {
  color: var(--color-primary);
}

/* Message text bubble */
.message-text {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  font-style: italic;
  line-height: 1.6;
}

.message-text svg {
  color: var(--color-text-muted);
  flex-shrink: 0;
  margin-top: 2px;
}

/* Timestamp */
.message-time {
  font-size: var(--font-size-xs) !important;
  color: var(--color-text-muted) !important;
  font-weight: 500;
  margin: 0;
}

/* Action row */
.message-actions {
  display: flex;
  gap: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}

/* No messages placeholder */
.no-messages {
  text-align: center;
  padding: var(--space-20) var(--space-6);
  color: var(--color-text-secondary);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  font-size: var(--font-size-base);
}


/* ════════════════════════════════════════════════════════════════════════════
   NOTIFICATION TOAST
   showNotification() in owner-dashboard.js sets inline styles + references
   these animation names by string — must keep exact keyframe names.
════════════════════════════════════════════════════════════════════════════ */

@keyframes slideIn {
  from { transform: translateX(420px); opacity: 0; }
  to   { transform: translateX(0);     opacity: 1; }
}

@keyframes slideOut {
  from { transform: translateX(0);     opacity: 1; }
  to   { transform: translateX(420px); opacity: 0; }
}


/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Tablet (≤ 900px)
════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {

  .dash-container {
    padding: 0 var(--space-6);
  }

  .dashboard-stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-4);
  }

  .stat-card {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
    padding: var(--space-5);
  }

  .stat-card__value {
    font-size: var(--font-size-2xl);
  }

  #propertiesContainer {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Adjust property card image height for tablet */
  .property-card__image {
    height: 160px;
  }
}


/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (≤ 640px)
════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {

  .dash-navbar__inner {
    padding: 0 var(--space-4);
  }

  .dash-navbar__badge {
    display: none;
  }

  .dash-navbar__brand {
    display: none;
  }

  .dash-container {
    padding: 0 var(--space-4);
  }

  .dash-main {
    padding-top: calc(var(--navbar-h) + var(--space-6));
  }

  .dashboard-stats {
    grid-template-columns: 1fr;
  }

  .stat-card {
    flex-direction: row;
    align-items: center;
  }

  .stat-card__value {
    font-size: var(--font-size-2xl);
  }

  #propertiesContainer {
    grid-template-columns: 1fr;
  }

  /* Adjust property card image height for mobile */
  .property-card__image {
    height: 200px;
  }

  .dash-header__profile {
    gap: var(--space-4);
  }

  .dash-header__avatar {
    width: 48px;
    height: 48px;
  }

  .message-header {
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  .dash-navbar__actions .btn--outline {
    display: none; /* collapse logout into a smaller pattern on tiny screens */
  }
}
