/* ============================================================
   ECBC Compliance Portal — Builder / Building Owner Panel
   Emerald Green Theme — uses --ecp-* tokens from tokens.css
   ============================================================ */

/* ── Builder-specific custom properties ───────────────────── */
.panel-builder {
  --bl-topbar-accent: var(--ecp-primary);
  --bl-topbar-accent-bg: var(--ecp-primary-bg);
  --bl-avatar-bg: var(--ecp-primary);
  --bl-nav-active-bg: var(--ecp-primary-bg);
  --bl-nav-active-color: var(--ecp-primary);
  --bl-focus-ring: rgba(var(--ecp-primary-rgb), 0.15);
}


/* ========================================
   TOP NAVBAR
   ======================================== */
.au-topbar {
  background: var(--ecp-white);
  border-bottom: 1px solid var(--ecp-gray-200);
  padding: 10px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky;
  top: 0;
  z-index: var(--ecp-z-dropdown);
}

.au-topbar-left {
  display: flex;
  align-items: center;
  gap: var(--ecp-space-3);
}

.au-topbar-logo {
  width: 36px;
  height: 36px;
  border-radius: var(--ecp-radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 16px;
}

.au-topbar-brand {
  font-size: var(--ecp-font-small);
  font-weight: var(--ecp-weight-bold);
  color: var(--ecp-gray-900);
  line-height: var(--ecp-line-height-tight);
}

.au-topbar-brand small {
  display: block;
  font-size: 10px;
  font-weight: var(--ecp-weight-regular);
  color: var(--ecp-text-muted);
}

/* Nav links */
.au-topbar-nav {
  display: flex;
  align-items: center;
  gap: 2px;
}

.au-nav-link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--ecp-radius-md);
  font-size: var(--ecp-font-small);
  font-weight: var(--ecp-weight-medium);
  color: var(--ecp-text-light);
  transition: all var(--ecp-transition-base);
}

.au-nav-link i { font-size: 15px; }
.au-nav-link:hover {
  background: var(--ecp-gray-50);
  color: var(--ecp-text-body);
  text-decoration: none;
}

.au-nav-link.active {
  background: var(--bl-nav-active-bg);
  color: var(--bl-nav-active-color);
  font-weight: var(--ecp-weight-semibold);
}

/* Mobile toggle */
.au-mobile-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--ecp-gray-200);
  border-radius: var(--ecp-radius-md);
  background: none;
  font-size: 18px;
  color: var(--ecp-text-light);
  cursor: pointer;
}

.au-mobile-toggle:hover {
  background: var(--ecp-gray-50);
  color: var(--bl-topbar-accent);
}

.au-mobile-nav {
  display: none;
  background: var(--ecp-white);
  border-bottom: 1px solid var(--ecp-gray-200);
  box-shadow: var(--ecp-shadow-2);
  padding: var(--ecp-space-2);
}

.au-mobile-nav.show { display: flex; flex-direction: column; }

.au-mobile-nav .au-nav-link {
  display: flex;
  padding: 10px 14px;
  border-radius: var(--ecp-radius-md);
  font-size: var(--ecp-font-body);
}

@media (max-width: 767.98px) {
  .au-mobile-toggle { display: flex; }
}

/* Topbar right */
.au-topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.au-topbar-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--ecp-radius-md);
  border: 1px solid var(--ecp-gray-200);
  background: var(--ecp-white);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ecp-text-light);
  font-size: 16px;
  cursor: pointer;
  transition: all var(--ecp-transition-base);
  position: relative;
}

.au-topbar-icon:hover {
  background: var(--ecp-gray-50);
  color: var(--bl-topbar-accent);
}

.au-topbar-icon .dot {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 6px;
  height: 6px;
  background: var(--ecp-error);
  border-radius: var(--ecp-radius-full);
  border: 1.5px solid #fff;
}

/* Profile chip */
.au-topbar-profile {
  display: flex;
  align-items: center;
  gap: var(--ecp-space-2);
  cursor: pointer;
  padding: 4px 8px 4px 4px;
  border-radius: var(--ecp-radius-md);
  transition: background var(--ecp-transition-base);
}

.au-topbar-profile:hover { background: var(--ecp-gray-50); }

.au-topbar-avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--ecp-radius-full);
  background: var(--bl-avatar-bg);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: var(--ecp-weight-bold);
}

.au-topbar-profile-name {
  font-size: 12.5px;
  font-weight: var(--ecp-weight-semibold);
  color: var(--ecp-gray-900);
}

.au-topbar-profile-role {
  font-size: 10px;
  color: var(--ecp-text-muted);
}


/* ========================================
   DASHBOARD LAYOUT
   ======================================== */
.au-dashboard {
  padding: var(--ecp-space-6);
  max-width: 1200px;
  margin: 0 auto;
}

.au-page-title {
  font-size: 22px;
  font-weight: var(--ecp-weight-extrabold);
  color: var(--ecp-gray-900);
  margin-bottom: var(--ecp-space-1);
}

.au-page-subtitle {
  font-size: var(--ecp-font-small);
  color: var(--ecp-text-muted);
  margin-bottom: var(--ecp-space-6);
}


/* ========================================
   STAT CARDS
   ======================================== */
.au-stat-card {
  background: var(--ecp-white);
  border: 1px solid var(--ecp-gray-100);
  border-radius: var(--ecp-radius-lg);
  padding: 18px;
  box-shadow: var(--ecp-shadow-1);
  transition: box-shadow var(--ecp-transition-base);
}

.au-stat-card:hover {
  box-shadow: var(--ecp-shadow-2);
}

.au-stat-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--ecp-radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.au-stat-value {
  font-size: var(--ecp-font-h1);
  font-weight: var(--ecp-weight-extrabold);
  color: var(--ecp-gray-900);
  margin-top: 10px;
  line-height: 1;
}

.au-stat-label {
  font-size: 12px;
  color: var(--ecp-text-light);
  margin-top: 3px;
}


/* ========================================
   CARDS
   ======================================== */
.au-card {
  background: var(--ecp-white);
  border: 1px solid var(--ecp-gray-100);
  border-radius: var(--ecp-radius-lg);
  box-shadow: var(--ecp-shadow-1);
  overflow: hidden;
}

.au-card-header {
  padding: 14px 18px;
  border-bottom: 1px solid var(--ecp-gray-100);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.au-card-title {
  font-size: var(--ecp-font-body);
  font-weight: var(--ecp-weight-bold);
  color: var(--ecp-gray-900);
  margin: 0;
}

.au-card-body {
  padding: 18px;
}


/* ========================================
   TABLE
   ======================================== */
.au-table {
  font-size: var(--ecp-font-small);
  width: 100%;
}

.au-table thead th {
  background: var(--ecp-gray-50);
  font-size: 10.5px;
  font-weight: var(--ecp-weight-semibold);
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--ecp-text-light);
  padding: 10px 14px;
  border-bottom: 1px solid var(--ecp-gray-200);
}

.au-table tbody td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--ecp-gray-100);
  vertical-align: middle;
}

.au-table tbody tr:hover { background: #FAFBFC; }
.au-table tbody tr:last-child td { border-bottom: none; }


/* ========================================
   BADGES
   ======================================== */
.au-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: var(--ecp-font-caption);
  font-weight: var(--ecp-weight-semibold);
}

.au-badge.pending      { background: var(--ecp-warning-light); color: #92400E; }
.au-badge.in-progress  { background: var(--ecp-primary-bg); color: var(--ecp-primary); }
.au-badge.completed    { background: var(--ecp-success-light); color: var(--ecp-success-dark); }
.au-badge.review       { background: #FFF7ED; color: #C2410C; }


/* ========================================
   BUTTONS
   ======================================== */
.au-btn {
  font-size: var(--ecp-font-small);
  font-weight: var(--ecp-weight-semibold);
  padding: 8px 18px;
  border-radius: var(--ecp-radius-md);
  border: none;
  cursor: pointer;
  transition: all var(--ecp-transition-base);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.au-btn-blue {
  background: var(--ecp-primary);
  color: #fff;
}
.au-btn-blue:hover {
  background: var(--ecp-primary-dark);
  color: #fff;
}

.au-btn-green {
  background: var(--ecp-success);
  color: #fff;
}
.au-btn-green:hover {
  background: var(--ecp-success-dark);
  color: #fff;
}

.au-btn-outline {
  background: transparent;
  border: 1.5px solid var(--ecp-gray-200);
  color: var(--ecp-text-body);
}
.au-btn-outline:hover {
  border-color: var(--ecp-primary);
  color: var(--ecp-primary);
}

.au-btn-red {
  background: transparent;
  color: var(--ecp-error);
  border: none;
  font-weight: var(--ecp-weight-semibold);
}
.au-btn-red:hover { color: var(--ecp-error-dark); }


/* ========================================
   DETAIL GRID
   ======================================== */
.au-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ecp-space-3);
}

.au-detail-label {
  font-size: var(--ecp-font-caption);
  color: var(--ecp-text-muted);
  margin-bottom: 2px;
}

.au-detail-value {
  font-size: var(--ecp-font-small);
  font-weight: var(--ecp-weight-semibold);
  color: var(--ecp-gray-900);
}


/* ========================================
   BACK LINK
   ======================================== */
.au-back-link {
  font-size: 12px;
  color: var(--ecp-text-muted);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-bottom: var(--ecp-space-3);
}

.au-back-link:hover { color: var(--ecp-primary); }


/* ========================================
   FORM SECTIONS (builder registration)
   ======================================== */
.au-form-section {
  margin-bottom: 28px;
}

.au-form-section-title {
  font-size: 15px;
  font-weight: var(--ecp-weight-bold);
  color: var(--ecp-gray-900);
  margin-bottom: var(--ecp-space-4);
  padding-left: var(--ecp-space-3);
  border-left: 3px solid var(--ecp-primary);
}

.au-form-section .form-label {
  font-size: 12.5px;
  font-weight: var(--ecp-weight-semibold);
  color: var(--ecp-text-light);
  margin-bottom: 4px;
}

.au-form-section .form-control,
.au-form-section .form-select {
  border-radius: var(--ecp-radius-md);
  padding: 9px 14px;
  font-size: 13.5px;
  border: 1.5px solid var(--ecp-gray-200);
}

.au-form-section .form-control:focus,
.au-form-section .form-select:focus {
  border-color: var(--ecp-primary);
  box-shadow: 0 0 0 3px var(--bl-focus-ring);
}


/* ========================================
   INFO / WARNING / SUCCESS / ERROR BOXES
   ======================================== */
.au-info-box {
  background: var(--ecp-primary-bg);
  border: 1px solid var(--ecp-primary-100);
  border-radius: var(--ecp-radius-lg);
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.au-info-box-icon {
  width: 40px;
  height: 40px;
  min-width: 40px;
  border-radius: var(--ecp-radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.au-info-box-icon.blue   { background: var(--ecp-primary); color: #fff; }
.au-info-box-icon.orange { background: var(--ecp-warning); color: #fff; }
.au-info-box-icon.green  { background: var(--ecp-success); color: #fff; }
.au-info-box-icon.red    { background: var(--ecp-error); color: #fff; }

.au-info-box h6 {
  font-size: var(--ecp-font-body);
  font-weight: var(--ecp-weight-bold);
  color: var(--ecp-gray-900);
  margin-bottom: 4px;
}

.au-info-box p {
  font-size: 12.5px;
  color: var(--ecp-text-light);
  margin: 0;
  line-height: var(--ecp-line-height-normal);
}

.au-warning-box {
  background: var(--ecp-warning-light);
  border: 1px solid #FDE68A;
  border-radius: var(--ecp-radius-lg);
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.au-success-box {
  background: var(--ecp-success-light);
  border: 1px solid #BBF7D0;
  border-radius: var(--ecp-radius-lg);
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.au-error-box {
  background: var(--ecp-error-light);
  border: 1px solid #FECACA;
  border-radius: var(--ecp-radius-lg);
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
}


/* ========================================
   FILTER BAR
   ======================================== */
.au-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--ecp-space-5);
}

.au-filter-bar p {
  font-size: var(--ecp-font-small);
  color: var(--ecp-text-light);
  margin: 0;
}


/* ========================================
   RESPONSIVE
   ======================================== */
@media (max-width: 991.98px) {
  .au-detail-grid { grid-template-columns: 1fr; }
}

@media (max-width: 575.98px) {
  .au-dashboard { padding: var(--ecp-space-4); }
  .au-page-title { font-size: 18px; }
}
