/* ResQRent — Admin & Pro portal */

body.admin, body.pro { background: #F5F6F8; }

.admin-nav, .pro-nav {
  background: #112142; color: #fff;
  padding: 0 32px;
}
.admin-nav .nav-inner, .pro-nav .nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px; max-width: 1400px; margin: 0 auto;
}
.admin-nav a, .pro-nav a {
  color: rgba(255,255,255,.85); font-family: 'Montserrat', sans-serif;
  font-weight: 500; font-size: 14px;
  padding: 8px 14px; border-radius: 6px;
}
.admin-nav a:hover, .pro-nav a:hover { background: rgba(255,255,255,.08); color: #fff; }
.admin-nav a.active, .pro-nav a.active { background: #E96B10; color: #fff; }
.admin-nav-brand, .pro-nav-brand {
  font-family: 'Montserrat', sans-serif; font-weight: 700; color: #fff;
  display: flex; align-items: center; gap: 8px;
}
.admin-nav-brand .logo, .pro-nav-brand .logo { height: 30px; width: auto; filter: brightness(0) invert(1); }
.admin-nav-brand .tag, .pro-nav-brand .tag {
  background: #E96B10; color: #fff;
  font-size: 10px; letter-spacing: .1em;
  padding: 3px 8px; border-radius: 4px; margin-left: 8px;
}
.admin-nav-menu, .pro-nav-menu {
  display: flex; gap: 4px; align-items: center;
}

.admin-main, .pro-main {
  max-width: 1400px; margin: 0 auto;
  padding: 32px;
}

.admin-head, .pro-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 32px; flex-wrap: wrap; gap: 16px;
}
.admin-head h1, .pro-head h1 { font-size: 1.75rem; margin: 0; }

/* KPI cards */
.kpi-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 16px; margin-bottom: 32px;
}
.kpi-card {
  background: #fff; border-radius: 12px; padding: 20px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.kpi-label {
  color: #888; font-size: .75rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase; margin-bottom: 6px;
}
.kpi-value {
  font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 1.875rem;
  color: #1A1A1A; line-height: 1;
}
.kpi-card.kpi-danger .kpi-value { color: #DC3545; }
.kpi-card.kpi-warning .kpi-value { color: #D68A00; }
.kpi-card.kpi-success .kpi-value { color: #28A745; }
.kpi-sub { font-size: .75rem; color: #888; margin-top: 4px; }

/* Panels */
.panel {
  background: #fff; border-radius: 12px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
  padding: 24px; margin-bottom: 24px;
}
.panel-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; gap: 12px; flex-wrap: wrap;
}
.panel-head h2 { margin: 0; font-size: 1.125rem; }

/* Filter bar */
.filter-bar {
  display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
  margin-bottom: 16px;
}
.filter-bar input, .filter-bar select {
  width: auto; min-width: 180px; padding: 8px 12px;
}

/* Alerts list */
.alerts-list {
  background: #fff; border-radius: 12px; overflow: hidden;
}
.alert-item {
  padding: 14px 20px; border-left: 4px solid;
  display: flex; align-items: center; gap: 12px;
  font-size: .95rem;
  border-bottom: 1px solid #EEE;
}
.alert-item:last-child { border-bottom: 0; }
.alert-item.alert-danger { border-left-color: #DC3545; }
.alert-item.alert-warning { border-left-color: #FFC107; }

/* Login pro / admin */
.auth-wrapper {
  min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: linear-gradient(135deg, #112142 0%, #1A2E5A 100%);
}
.auth-card {
  background: #fff; border-radius: 16px;
  padding: 40px 48px; width: 100%; max-width: 460px;
  box-shadow: 0 10px 40px rgba(0,0,0,.25);
}
.auth-card h1 { margin-bottom: 8px; font-size: 1.5rem; }
.auth-card .subtitle { color: #666; margin-bottom: 24px; font-size: .9rem; }
.auth-brand { display: flex; justify-content: center; margin-bottom: 24px; }
.auth-brand .logo { height: 44px; width: auto; }

/* Pro portal specifics */
.pro-search-big {
  max-width: 680px; margin: 48px auto; text-align: center;
}
.pro-search-big h1 { font-size: 2rem; margin-bottom: 32px; }
.pro-search-big form {
  display: flex; gap: 12px;
}
.pro-search-big input {
  font-size: 1.125rem; padding: 16px 20px;
}

/* Fiche locataire */
.fiche-section {
  background: #fff; border-radius: 12px; padding: 24px; margin-bottom: 16px;
  box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.fiche-section h3 {
  font-size: .75rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: #666; margin-bottom: 16px;
}
.fiche-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px 32px;
}
.fiche-item .label {
  font-size: .75rem; color: #888; font-weight: 600;
  letter-spacing: .04em; text-transform: uppercase; margin-bottom: 2px;
}
.fiche-item .value {
  font-family: 'Inter', sans-serif; font-weight: 500;
  color: #1A1A1A; font-size: 1rem;
}
.fiche-item .value.hex { font-family: 'JetBrains Mono', monospace; background: #F8F9FA; padding: 4px 10px; border-radius: 4px; display: inline-block; }

.status-banner {
  background: #D4EDDA; color: #155724;
  padding: 14px 20px; border-radius: 10px;
  font-family: 'Montserrat', sans-serif; font-weight: 600;
  margin-bottom: 16px;
}
.status-banner.expired { background: #F8D7DA; color: #721C24; }

@media (max-width: 860px) {
  .admin-main, .pro-main { padding: 16px; }
  .admin-nav, .pro-nav { padding: 0 16px; }
  .admin-nav-menu, .pro-nav-menu { display: none; }
  .fiche-grid { grid-template-columns: 1fr; }
  .pro-search-big form { flex-direction: column; }
}
