/* ============================================================
   Blue Atlas Owner Portal — Design System
   Bold & Professional | Inter font | Mobile-first
   ============================================================ */

/* ── Google Fonts: Inter ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* ── Design Tokens ───────────────────────────────────────── */
:root {
  /* Brand */
  --brand-900: #001f3f;
  --brand-800: #002952;
  --brand-700: #003366;
  --brand-600: #004080;
  --brand-500: #0055a5;
  --brand-400: #1a6bbf;
  --brand-100: #dbeafe;
  --brand-50:  #eff6ff;

  /* Accent */
  --accent-blue:   #3399ff;
  --accent-peach:  #ffcc99;
  --accent-orange: #ff9966;

  /* Semantic status */
  --status-active:  #16a34a;
  --status-pending: #d97706;
  --status-leased:  #0891b2;
  --status-danger:  #dc2626;
  --status-gray:    #6b7280;

  /* Surface */
  --surface-page:   #f4f6f9;
  --surface-card:   #ffffff;
  --surface-subtle: #f8fafc;
  --surface-border: rgba(0, 0, 0, 0.07);

  /* Text */
  --text-primary:   #0f172a;
  --text-secondary: #475569;
  --text-muted:     #94a3b8;
  --text-inverse:   #ffffff;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.07);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg: 0 8px 28px rgba(0,0,0,0.13);

  /* Radius */
  --radius-sm:  6px;
  --radius-md:  10px;
  --radius-lg:  14px;
  --radius-xl:  20px;
  --radius-pill: 999px;

  /* Spacing scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;

  /* Sidebar */
  --sidebar-width: 256px;
  --sidebar-bg: var(--brand-700);

  /* Transitions */
  --transition-fast: 0.15s ease;
  --transition-base: 0.25s ease;

  /* Legacy aliases (keep for any templates still using them) */
  --main-color:       var(--brand-700);
  --main-color-dark:  var(--brand-800);
  --main-color-light: var(--brand-500);
  --button-color:     var(--brand-700);
  --ui-background:    var(--surface-card);
  --ui-box-shadow:    rgba(0,0,0,0.08);
  --ui-border-radius: var(--radius-md);
  --badge-success:    var(--status-active);
  --badge-warning:    var(--status-pending);
  --badge-danger:     var(--status-danger);
  --badge-secondary:  var(--status-gray);
}

/* ── Reset & Base ────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  background: var(--surface-page);
  color: var(--text-primary);
  padding-left: var(--sidebar-width);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: var(--brand-500); text-decoration: none; }
a:hover { color: var(--brand-700); }

.container {
  width: 94%;
  max-width: 1200px;
}

/* ── Unit Images (Unit Detail) ─────────────────────────── */
.lp-strip-btn{
  width: 100%;
  border: 1px solid var(--surface-border);
  background: var(--surface-subtle);
  border-radius: var(--radius-lg);
  padding: 12px;
  text-align: left;
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
}
.lp-strip-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
  border-color: rgba(0, 51, 102, 0.22);
}
.lp-strip{
  display: flex;
  gap: 10px;
  align-items: center;
  overflow: hidden;
}
.lp-strip-thumb{
  width: 76px;
  height: 56px;
  object-fit: cover;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #eef2f7;
  flex-shrink: 0;
}
.lp-more-tile{
  width: 76px;
  height: 56px;
  border-radius: 10px;
  border: 1px dashed rgba(0,0,0,0.18);
  background: rgba(0, 51, 102, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  color: var(--brand-700);
  flex-shrink: 0;
}
.lp-strip-hint{
  margin-top: 10px;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--text-secondary);
}

.lp-thumb-grid{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.lp-thumb-btn{
  border: 0;
  padding: 0;
  background: transparent;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.lp-thumb-btn:hover{
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.lp-thumb-img{
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  background: #eef2f7;
}

.lp-carousel-stage{
  background: #0b1220;
  border-radius: 16px;
  padding: 10px;
}
.lp-carousel-img{
  max-height: 70vh;
  object-fit: contain;
  border-radius: 12px;
  background: #0b1220;
}
.lp-carousel-caption{
  background: rgba(0,0,0,0.45);
  border-radius: 12px;
  padding: 10px 12px;
}

/* ── Typography ──────────────────────────────────────────── */
.page-title {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin: 0;
  line-height: 1.2;
}

.page-subtitle {
  color: var(--text-secondary);
  font-size: 0.875rem;
  margin: 4px 0 0 0;
}

.section-heading {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
}

/* ── Sidebar ─────────────────────────────────────────────── */
.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--sidebar-width);
  height: 100vh;
  background: var(--sidebar-bg);
  z-index: 1000;
  box-shadow: 2px 0 12px rgba(0,0,0,0.15);
  overflow-y: auto;
  overflow-x: hidden;
  transition: transform var(--transition-base);
  display: flex;
  flex-direction: column;
}

/* Sidebar scrollbar */
.sidebar::-webkit-scrollbar { width: 4px; }
.sidebar::-webkit-scrollbar-track { background: transparent; }
.sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }

.sidebar-header {
  padding: var(--space-5) var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  flex-shrink: 0;
}

.logo-link {
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.logo {
  height: 44px;
  width: 44px;
  object-fit: contain;
  flex-shrink: 0;
}

.white-logo {
  filter: brightness(0) invert(1);
}

.sidebar-brand {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.sidebar-brand-name {
  font-size: 0.9rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.sidebar-brand-sub {
  font-size: 0.7rem;
  color: rgba(255,255,255,0.55);
  font-weight: 400;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Legacy sidebar-title alias */
.sidebar-title {
  font-size: 0.9rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.3;
}

.sidebar-nav {
  padding: var(--space-3) 0;
  flex: 1;
}

.nav-section {
  margin: 2px 0;
}

.nav-section-label {
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255,255,255,0.35);
  padding: var(--space-4) var(--space-4) var(--space-1);
  display: block;
}

.nav-section-link,
.nav-section-toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: none;
  background: transparent;
  color: rgba(255,255,255,0.82);
  text-decoration: none;
  padding: 9px var(--space-4);
  margin: 0;
  border-radius: 0;
  font-size: 0.875rem;
  font-weight: 500;
  transition: background var(--transition-fast), color var(--transition-fast);
  gap: var(--space-3);
}

.nav-section-link .nav-icon,
.nav-section-toggle .nav-icon {
  width: 18px;
  text-align: center;
  font-size: 0.875rem;
  flex-shrink: 0;
  opacity: 0.7;
  transition: opacity var(--transition-fast);
}

.nav-section-link .nav-label,
.nav-section-toggle .nav-label {
  flex: 1;
  text-align: left;
}

.nav-section-link:hover,
.nav-section-toggle:hover {
  background: rgba(255,255,255,0.1);
  color: #ffffff;
}

.nav-section-link:hover .nav-icon,
.nav-section-toggle:hover .nav-icon {
  opacity: 1;
}

.nav-section-link.nav-active {
  background: rgba(255,255,255,0.15);
  color: #ffffff;
  font-weight: 600;
}

.nav-section-link.nav-active .nav-icon {
  opacity: 1;
}

.nav-section-link.nav-disabled,
.nav-sub-link.nav-disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

.nav-section-toggle .toggle-icon {
  transition: transform var(--transition-fast);
  font-size: 0.7rem;
  opacity: 0.5;
}

.nav-section-toggle.expanded .toggle-icon {
  transform: rotate(180deg);
}

.nav-subsection {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-base);
}

.nav-subsection.expanded {
  max-height: 300px;
}

.nav-sub-link {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  padding: 7px var(--space-4) 7px 44px;
  font-size: 0.8125rem;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.nav-sub-link:hover {
  background: rgba(255,255,255,0.08);
  color: #ffffff;
}

.nav-divider {
  height: 1px;
  background: rgba(255,255,255,0.1);
  margin: var(--space-3) var(--space-4);
}

/* Nav badge (Soon, etc.) */
.nav-badge {
  font-size: 0.6rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background: rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.5);
  padding: 2px 6px;
  border-radius: var(--radius-pill);
  flex-shrink: 0;
}

.nav-alert-badge {
  min-width: 18px;
  height: 18px;
  padding: 0 6px;
  border-radius: var(--radius-pill);
  background: #ef4444;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 0 0 3px rgba(239,68,68,0.14);
  flex-shrink: 0;
}

/* ── Mobile Menu Toggle ───────────────────────────────────── */
.mobile-menu-toggle {
  display: none;
  position: fixed;
  top: 14px;
  left: 14px;
  z-index: 1100;
  background: var(--brand-700);
  border: none;
  color: #fff;
  padding: 10px 13px;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  cursor: pointer;
}

/* ── Main Content ─────────────────────────────────────────── */
.main-content {
  padding: var(--space-6) 0 80px 0;
  min-height: 100vh;
}

/* ── Page Header ─────────────────────────────────────────── */
.owner-page-header {
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--surface-border);
}

.page-header {
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
}

/* ── Footer ──────────────────────────────────────────────── */
.main-footer {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding-left: var(--sidebar-width);
  background: var(--surface-card);
  border-top: 1px solid var(--surface-border);
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
  z-index: 900;
}

.main-footer p {
  font-size: 12px;
  color: var(--text-muted);
  margin: 0;
}

.main-footer a {
  color: var(--text-secondary);
}

.main-footer a:hover {
  color: var(--brand-700);
}

/* ── Cards ───────────────────────────────────────────────── */
.card {
  background: var(--surface-card);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--surface-border);
}

.card-with-accent {
  border-left: 3px solid var(--accent-blue);
}

.card:hover {
  box-shadow: var(--shadow-md);
  transition: box-shadow var(--transition-fast);
}

.card-disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

/* ── Stats Grid ──────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

.stats-card {
  background: var(--surface-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--surface-border);
  box-shadow: var(--shadow-xs);
  padding: var(--space-4) var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
  border-left: 3px solid transparent;
  transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.stats-card[role="button"]{
  cursor: pointer;
}

.stats-card[role="button"]:focus-visible{
  outline: 3px solid rgba(0, 85, 165, 0.35);
  outline-offset: 2px;
}

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

.stats-card--blue  { border-left-color: var(--brand-700); }
.stats-card--teal  { border-left-color: var(--status-leased); }
.stats-card--green { border-left-color: var(--status-active); }
.stats-card--amber { border-left-color: var(--status-pending); }
.stats-card--gray  { border-left-color: var(--status-gray); }
.stats-card--red   { border-left-color: var(--status-danger); }

.stats-card-icon {
  width: 38px;
  height: 38px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
  background: rgba(0,51,102,0.07);
  color: var(--brand-700);
}

.stats-card--teal  .stats-card-icon { background: rgba(8,145,178,0.10);  color: var(--status-leased); }
.stats-card--green .stats-card-icon { background: rgba(22,163,74,0.10);   color: var(--status-active); }
.stats-card--amber .stats-card-icon { background: rgba(217,119,6,0.12);   color: var(--status-pending); }
.stats-card--gray  .stats-card-icon { background: rgba(107,114,128,0.10); color: var(--status-gray); }
.stats-card--red   .stats-card-icon { background: rgba(220,38,38,0.10);   color: var(--status-danger); }

.stats-card-body { flex: 1; min-width: 0; }

.stats-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  line-height: 1;
  margin-bottom: 4px;
}

.stats-value {
  font-size: 1.375rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  letter-spacing: -0.02em;
}

.stats-value--sm {
  font-size: 1rem;
  font-weight: 700;
  margin-top: 2px;
}

/* ── Financials: quick ranges ─────────────────────────────── */
.fin-date-presets .btn{
  font-weight: 700;
  font-size: 0.8125rem;
}

.fin-date-presets .btn:focus-visible{
  outline: 3px solid rgba(0, 85, 165, 0.35);
  outline-offset: 2px;
}

/* ── Financials: current period banner ───────────────────── */
.financials-period-banner{
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 14px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(0, 51, 102, 0.12);
  background: linear-gradient(180deg, rgba(0, 85, 165, 0.06), rgba(0, 51, 102, 0.03));
  box-shadow: var(--shadow-xs);
}

.financials-period-banner__label{
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}

.financials-period-banner__value{
  font-size: 0.98rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--brand-800);
  line-height: 1.2;
}

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  border-radius: var(--radius-sm);
  font-weight: 600;
  font-size: 0.875rem;
  transition: transform var(--transition-fast), background var(--transition-fast),
              border-color var(--transition-fast), box-shadow var(--transition-fast);
  letter-spacing: -0.01em;
}

.btn-primary {
  background: var(--brand-700);
  border-color: var(--brand-700);
  color: #fff;
}

.btn-primary:hover,
.btn-primary:focus {
  background: var(--brand-800);
  border-color: var(--brand-800);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,51,102,0.25);
}

.btn-outline-primary {
  border-color: var(--brand-700);
  color: var(--brand-700);
  background: transparent;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus {
  background: var(--brand-700);
  border-color: var(--brand-700);
  color: #fff;
  transform: translateY(-1px);
}

.btn-outline-secondary:hover {
  transform: translateY(-1px);
}

/* ── Badges ──────────────────────────────────────────────── */
.badge {
  border-radius: var(--radius-pill);
  padding: 4px 10px;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.01em;
}

.badge-active {
  background: rgba(22,163,74,0.12);
  color: #15803d;
  border: 1px solid rgba(22,163,74,0.2);
}

.badge-pending {
  background: rgba(217,119,6,0.12);
  color: #b45309;
  border: 1px solid rgba(217,119,6,0.2);
}

.badge-inactive {
  background: rgba(220,38,38,0.10);
  color: #b91c1c;
  border: 1px solid rgba(220,38,38,0.15);
}

.badge-secondary {
  background: rgba(107,114,128,0.10);
  color: #4b5563;
  border: 1px solid rgba(107,114,128,0.15);
}

/* ── Tables ──────────────────────────────────────────────── */
table thead th {
  background: var(--brand-700);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  border-color: rgba(255,255,255,0.1) !important;
  padding: 10px 14px;
}

table tbody td {
  padding: 11px 14px;
  vertical-align: middle;
  border-color: rgba(0,0,0,0.05);
}

table tbody tr:hover {
  background: rgba(0,51,102,0.03);
}

/* Clickable table rows (Maintenance Center, etc.) */
.table-row-link {
  cursor: pointer;
}

.table-row-link:focus {
  outline: 2px solid rgba(0, 85, 165, 0.35);
  outline-offset: -2px;
}

/* Maintenance Center table refinements */
.mc-table thead th {
  background: transparent;
  color: var(--text-muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--surface-border) !important;
}

.mc-table tbody td {
  padding-top: 14px;
  padding-bottom: 14px;
}

.mc-table tbody tr {
  position: relative;
}

.mc-table tbody tr.table-row-link:hover td {
  background: rgba(0, 51, 102, 0.025);
}

.mc-id {
  font-weight: 700;
  color: var(--text-secondary);
}

.mc-title {
  font-weight: 800;
  letter-spacing: -0.01em;
  font-size: 0.95rem;
  color: var(--text-primary);
  line-height: 1.25;
}

.mc-sub {
  font-size: 0.84rem;
  color: var(--text-secondary);
  line-height: 1.45;
  margin-top: 4px;
}

.mc-unit {
  font-weight: 700;
  color: var(--text-secondary);
}

.mc-chip {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--surface-border);
  background: var(--surface-subtle);
  color: var(--text-muted);
  border-radius: var(--radius-pill);
  padding: 2px 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.mc-status {
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 800;
}

/* ── Empty State ─────────────────────────────────────────── */
.empty-state {
  padding: var(--space-10) var(--space-6);
  text-align: center;
  color: var(--text-muted);
}

.empty-state i {
  font-size: 2rem;
  color: var(--brand-100);
  margin-bottom: var(--space-3);
  display: block;
}

.empty-state div {
  font-size: 0.9rem;
  font-weight: 500;
}

/* ── Key/Value block ─────────────────────────────────────── */
.kv { }

.kv .kv-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-bottom: 3px;
}

.kv .kv-value {
  font-weight: 700;
  color: var(--text-primary);
  font-size: 0.9375rem;
}

/* ── Unit cards ──────────────────────────────────────────── */
.unit-card-inner {
  height: 100%;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.unit-card:hover .unit-card-inner {
  border-color: rgba(0,51,102,0.2);
  box-shadow: var(--shadow-md);
}

/* ── Portal Section Cards (Home page) ────────────────────── */
.portal-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 22px 24px 20px;
  min-height: 120px;
  border-radius: var(--radius-md);
  border: 1px solid var(--surface-border);
  border-left: 3px solid var(--brand-700);
  box-shadow: none;
  background: var(--surface-card);
  position: relative;
  transition: background var(--transition-fast), border-color var(--transition-fast),
              box-shadow var(--transition-fast), transform var(--transition-fast);
  color: inherit;
  text-decoration: none;
}

.portal-card--active {
  cursor: pointer;
}

.portal-card--active:hover {
  background: var(--surface-subtle);
  border-left-color: var(--brand-500);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
  color: inherit;
  text-decoration: none;
}

.portal-card--action {
  border-left-color: var(--status-pending);
  cursor: pointer;
}

.portal-card--action:hover {
  background: var(--surface-subtle);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
  color: inherit;
  text-decoration: none;
}

.portal-card--pending {
  border-left-color: var(--status-gray);
}

.portal-card--disabled {
  background: var(--surface-subtle);
  border-left-color: var(--surface-border);
  opacity: 0.55;
  cursor: default;
}

.portal-card--disabled:hover {
  transform: none;
  box-shadow: none;
  background: var(--surface-subtle);
}

/* No icon — hide icon elements if still present in markup */
.portal-card-icon { display: none; }

.portal-card-body {
  flex: 1;
  min-width: 0;
}

.portal-card-title {
  font-size: 0.9375rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 6px 0;
  letter-spacing: -0.015em;
  line-height: 1.2;
}

.portal-card--disabled .portal-card-title {
  color: var(--text-secondary);
}

.portal-card-sub {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.45;
}

.portal-card-arrow {
  display: inline-block;
  margin-top: 14px;
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--text-muted);
  font-style: normal;
  transition: color var(--transition-fast), transform var(--transition-fast);
  letter-spacing: 0.02em;
}

.portal-card--active:hover .portal-card-arrow,
.portal-card--action:hover .portal-card-arrow {
  color: var(--brand-700);
  transform: translateX(3px);
}

.portal-card-lock {
  position: absolute;
  top: 14px;
  right: 16px;
  font-size: 10px;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Suppress generic .card hover bleed */
.portal-card:hover {
  transform: none;
  box-shadow: none;
}
.portal-card--active:hover,
.portal-card--action:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* ── Home: Inbox tiles (Requests + Messages) ──────────────── */
.inbox-tiles{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
}

.inbox-tile{
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 18px 18px;
  background: var(--surface-card);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-lg);
  border-left: 4px solid var(--brand-700);
  box-shadow: var(--shadow-xs);
  color: inherit;
  text-decoration: none;
  transition: background var(--transition-fast), border-color var(--transition-fast),
              box-shadow var(--transition-fast), transform var(--transition-fast);
  position: relative;
  overflow: hidden;
}

.inbox-tile:hover{
  background: var(--surface-subtle);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
  color: inherit;
  text-decoration: none;
}

.inbox-tile__icon{
  width: 40px;
  height: 40px;
  border-radius: 12px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  background: rgba(0,51,102,0.08);
  color: var(--brand-700);
  margin-top: 1px;
}

.inbox-tile__body{ flex: 1; min-width: 0; }

.inbox-tile__title-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.inbox-tile__title{
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 0;
  color: var(--text-primary);
}

.inbox-alert-badge{
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: var(--radius-pill);
  background: #ef4444;
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 0 0 4px rgba(239,68,68,0.12);
  flex-shrink: 0;
}

.inbox-tile__sub{
  margin-top: 6px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.45;
}

.inbox-tile__cta{
  margin-top: 12px;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: var(--text-muted);
  transition: color var(--transition-fast), transform var(--transition-fast);
}

.inbox-tile:hover .inbox-tile__cta{
  color: var(--brand-700);
  transform: translateX(3px);
}

.inbox-tile--requests{ border-left-color: var(--status-pending); }
.inbox-tile--requests .inbox-tile__icon{
  background: rgba(217,119,6,0.12);
  color: var(--status-pending);
}

.inbox-tile--messages{ border-left-color: var(--status-leased); }
.inbox-tile--messages .inbox-tile__icon{
  background: rgba(8,145,178,0.10);
  color: var(--status-leased);
}

/* ── Welcome Banner (Home page) ──────────────────────────── */
.welcome-banner {
  background: linear-gradient(135deg, var(--brand-800) 0%, var(--brand-600) 100%);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-8);
  color: #fff;
  margin-bottom: var(--space-6);
  position: relative;
  overflow: hidden;
}

.welcome-banner::after {
  content: '';
  position: absolute;
  top: -40px;
  right: -40px;
  width: 200px;
  height: 200px;
  background: rgba(255,255,255,0.04);
  border-radius: 50%;
  pointer-events: none;
}

.welcome-banner::before {
  content: '';
  position: absolute;
  bottom: -60px;
  right: 60px;
  width: 280px;
  height: 280px;
  background: rgba(255,255,255,0.03);
  border-radius: 50%;
  pointer-events: none;
}

.welcome-name {
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 4px 0;
  line-height: 1.1;
}

.welcome-meta {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.7);
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
}

.welcome-meta i {
  opacity: 0.7;
}

/* ── Home analytics (dashboard) ───────────────────────────── */
.home-analytics { }

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

/* Base card — label top, value pinned bottom-left */
.kpi-card {
  background: var(--surface-card);
  border-radius: var(--radius-sm);
  border: 1px solid var(--surface-border);
  border-left: 3px solid var(--brand-700);
  box-shadow: none;
  padding: 12px 14px 12px;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
  transition: background var(--transition-fast), border-color var(--transition-fast);
  color: inherit;
}

.kpi-card:hover {
  background: var(--surface-subtle);
}

/* All cards share the same brand left border */
.kpi-card--blue,
.kpi-card--green,
.kpi-card--amber,
.kpi-card--teal,
.kpi-card--slate,
.kpi-card--red,
.kpi-card--purple,
.kpi-card--gray   { border-left-color: var(--brand-700); }

/* Clickable variant */
.kpi-card--link { cursor: pointer; text-decoration: none; }

.kpi-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  line-height: 1;
  /* anchored to top via space-between */
}

.kpi-value {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--text-primary);
  line-height: 1;
  /* anchored to bottom via space-between */
}

.kpi-value--money {
  font-size: 1.15rem;
}

/* Arrow on link cards — bottom-right corner */
.kpi-link-arrow {
  position: absolute;
  bottom: 10px;
  right: 11px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text-muted);
  transition: color var(--transition-fast), transform var(--transition-fast);
}
.kpi-card--link:hover .kpi-link-arrow {
  color: var(--brand-700);
  transform: translateX(3px);
}


.exp-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  margin-bottom: 4px;
}

.exp-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--surface-border);
  color: inherit;
  text-decoration: none;
  transition: background var(--transition-fast);
}

.exp-item:last-child { border-bottom: none; }

.exp-item:hover { background: transparent; }
.exp-item:hover .exp-title { color: var(--brand-700); }

.exp-left { flex: 1; min-width: 0; }

.exp-title {
  font-weight: 700;
  font-size: 0.875rem;
  letter-spacing: -0.01em;
  color: var(--text-primary);
  transition: color var(--transition-fast);
}

.exp-sub {
  margin-top: 2px;
  font-size: 0.78rem;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.exp-rent {
  font-weight: 700;
  color: var(--status-active);
}

.exp-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

.exp-date {
  font-weight: 700;
  font-size: 0.8rem;
  color: var(--text-primary);
  white-space: nowrap;
}

.exp-pill {
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: rgba(217,119,6,0.10);
  border: 1px solid rgba(217,119,6,0.16);
  color: #b45309;
  white-space: nowrap;
}

/* ── Kanban Board ─────────────────────────────────────────── */
.kanban-board {
  overflow-x: auto;
  padding-bottom: var(--space-2);
}

.kanban-column {
  background: var(--surface-subtle);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-md);
  margin-right: var(--space-3);
  min-width: 320px;
  max-width: 320px;
  height: calc(100vh - 280px);
  display: flex;
  flex-direction: column;
}

.kanban-header {
  background: var(--brand-800);
  color: #fff;
  padding: 12px 14px;
  border-top-left-radius: var(--radius-md);
  border-top-right-radius: var(--radius-md);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.kanban-title {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.card-count {
  background: rgba(255,255,255,0.18);
  color: #fff;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-pill);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
}

.kanban-cards {
  padding: var(--space-2);
  overflow-y: auto;
  flex: 1;
}

.kanban-card {
  background: var(--surface-card);
  border: 1px solid var(--surface-border);
  border-radius: var(--radius-md);
  padding: 12px;
  box-shadow: var(--shadow-xs);
  margin-bottom: var(--space-2);
  cursor: grab;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast),
              border-color var(--transition-fast);
}

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

.kanban-card.dragging {
  transform: rotate(1deg) scale(1.02);
  box-shadow: var(--shadow-lg);
  border-color: var(--accent-blue);
}

.kanban-column.drag-over,
.kanban-cards.drag-over {
  border: 2px dashed var(--accent-blue);
  background: rgba(51,153,255,0.06);
}

.card-property-name {
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
  font-size: 0.875rem;
}

.card-footer-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  color: var(--text-muted);
  font-size: 12px;
}

.days-remaining {
  background: rgba(0,0,0,0.04);
  padding: 3px 8px;
  border-radius: var(--radius-pill);
  white-space: nowrap;
  font-size: 11px;
  font-weight: 600;
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .stats-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .kpi-grid   { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

@media (max-width: 768px) {
  body {
    padding-left: 0;
    background: var(--surface-page);
  }

  .sidebar {
    transform: translateX(-100%);
  }

  .sidebar.mobile-open {
    transform: translateX(0);
  }

  .mobile-menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .main-footer {
    padding-left: 0;
  }

  .kanban-column {
    min-width: 290px;
    max-width: 290px;
  }

  .stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .welcome-banner {
    padding: var(--space-5) var(--space-5);
  }

  .welcome-name {
    font-size: 1.375rem;
  }

  .kpi-grid  { grid-template-columns: repeat(4, minmax(0, 1fr)); }

  .main-content {
    padding-top: 60px;
  }

  .inbox-tiles{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .portal-card {
    padding: 18px 20px 16px;
    min-height: 110px;
  }
}

/* ── Sidebar overlay (mobile) ────────────────────────────── */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.45);
  z-index: 999;
}

.sidebar-overlay.active {
  display: block;
}
