/* ============================================================
   locations.css — Locations admin page
   Depends on: main.css + dashboard.css
   ============================================================ */

.loc-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.loc-header__title { font-family: var(--gx-font-heading); font-size: clamp(1.4rem, 2vw, 1.75rem); font-weight: 700; letter-spacing: -0.02em; color: var(--gx-dark); }
.loc-header__sub { font-size: 0.875rem; color: var(--gx-gray-mid); }
.loc-header__actions { display: flex; align-items: center; gap: 0.5rem; }

.loc-btn { display: flex; align-items: center; gap: 0.5rem; padding: 0.6rem 1rem; border-radius: var(--gx-r-full); font-size: 0.85rem; font-weight: 500; cursor: pointer; border: 1px solid transparent; transition: all var(--gx-t); white-space: nowrap; }
.loc-btn--outline { background: transparent; border-color: var(--gx-gray-light); color: var(--gx-g300); }
.loc-btn--outline:hover { background: var(--gx-off-white); border-color: var(--gx-gray); }
.loc-btn--primary { background: var(--gx-dark); border-color: var(--gx-dark); color: var(--gx-lime); }
.loc-btn--primary:hover { background: var(--gx-gray-dark); }
.loc-btn__icon { width: 1.5rem; height: 1.5rem; background: var(--gx-lime); color: var(--gx-dark); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* Stats */
.loc-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem; }

/* Location cards grid */
.loc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.loc-card {
  background: var(--gx-white);
  border: 1px solid var(--gx-gray-light);
  border-radius: var(--gx-r-xl);
  overflow: hidden;
  transition: box-shadow var(--gx-t), border-color var(--gx-t);
}
.loc-card:hover { box-shadow: var(--gx-sh); border-color: var(--gx-gray); }

.loc-card__map {
  height: 9rem;
  background: linear-gradient(135deg, #e8f0fe 0%, #d2e3fc 100%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.loc-card__map-pin {
  width: 2.75rem;
  height: 2.75rem;
  background: var(--gx-dark);
  border-radius: 50% 50% 50% 0;
  transform: rotate(-45deg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.loc-card__map-pin svg { transform: rotate(45deg); color: var(--gx-lime); }
.loc-card__map-label {
  position: absolute;
  bottom: 0.75rem;
  left: 0.75rem;
  font-family: var(--gx-font-mono);
  font-size: 0.58rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(0,0,0,0.5);
  background: rgba(255,255,255,0.8);
  padding: 0.2rem 0.5rem;
  border-radius: var(--gx-r-full);
  backdrop-filter: blur(4px);
}
.loc-card__status-dot {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.35rem;
  background: rgba(255,255,255,0.9);
  padding: 0.25rem 0.6rem;
  border-radius: var(--gx-r-full);
  backdrop-filter: blur(4px);
  font-size: 0.68rem;
  font-weight: 600;
}
.loc-card__status-dot span { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

.loc-card__body { padding: 1.25rem; }

.loc-card__name {
  font-family: var(--gx-font-heading);
  font-size: 1rem;
  font-weight: 700;
  color: var(--gx-dark);
  margin-bottom: 0.15rem;
}
.loc-card__address { font-size: 0.78rem; color: var(--gx-gray-mid); margin-bottom: 1rem; display: flex; align-items: center; gap: 0.25rem; }
.loc-card__address svg { flex-shrink: 0; color: var(--gx-gray-mid); }

.loc-card__stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.5rem; margin-bottom: 1rem; }
.loc-card__stat { text-align: center; }
.loc-card__stat-val { font-family: var(--gx-font-heading); font-size: 1.35rem; font-weight: 800; letter-spacing: -0.03em; color: var(--gx-dark); line-height: 1; }
.loc-card__stat-label { font-size: 0.65rem; color: var(--gx-gray-mid); margin-top: 0.15rem; }

.loc-card__utilization {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.loc-card__util-header { display: flex; justify-content: space-between; align-items: center; }
.loc-card__util-label { font-size: 0.72rem; color: var(--gx-gray-mid); }
.loc-card__util-pct { font-family: var(--gx-font-mono); font-size: 0.72rem; font-weight: 600; color: var(--gx-dark); }
.loc-card__util-bar { height: 4px; background: var(--gx-gray-light); border-radius: 2px; overflow: hidden; }
.loc-card__util-fill { height: 100%; border-radius: 2px; background: var(--gx-lime); transition: width 0.6s var(--gx-ease); }

.loc-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.85rem 1.25rem;
  border-top: 1px solid var(--gx-gray-light);
  background: var(--gx-off-white);
}
.loc-card__manager { font-size: 0.78rem; color: var(--gx-gray-mid); }
.loc-card__manager span { color: var(--gx-dark); font-weight: 500; }

.loc-card__actions { display: flex; gap: 0.3rem; }
.loc-card__btn { width: 1.75rem; height: 1.75rem; border-radius: var(--gx-r-sm); background: var(--gx-white); border: 1px solid var(--gx-gray-light); color: var(--gx-g300); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all var(--gx-t); }
.loc-card__btn:hover { background: var(--gx-dark); color: var(--gx-lime); border-color: var(--gx-dark); }

/* ============================================================
   Dark theme
   ============================================================ */
[data-theme="dark"] .loc-header__title { color: #dde4f2; }
[data-theme="dark"] .loc-header__sub { color: #5c6880; }
[data-theme="dark"] .loc-btn--outline { background: transparent; border-color: rgba(255,255,255,0.1); color: #8090b0; }
[data-theme="dark"] .loc-btn--outline:hover { background: rgba(255,255,255,0.05); }

[data-theme="dark"] .loc-card { background: #0f1420; border-color: rgba(255,255,255,0.07); }
[data-theme="dark"] .loc-card:hover { border-color: rgba(255,255,255,0.15); box-shadow: 0 4px 24px rgba(0,0,0,0.5); }
[data-theme="dark"] .loc-card__map { background: linear-gradient(135deg, #0d1828 0%, #111e38 100%); }
[data-theme="dark"] .loc-card__map-label { color: rgba(255,255,255,0.5); background: rgba(0,0,0,0.5); }
[data-theme="dark"] .loc-card__status-dot { background: rgba(15,20,32,0.9); color: #dde4f2; }
[data-theme="dark"] .loc-card__name { color: #dde4f2; }
[data-theme="dark"] .loc-card__address { color: #5c6880; }
[data-theme="dark"] .loc-card__address svg { color: #5c6880; }
[data-theme="dark"] .loc-card__stat-val { color: #dde4f2; }
[data-theme="dark"] .loc-card__stat-label { color: #5c6880; }
[data-theme="dark"] .loc-card__util-label { color: #5c6880; }
[data-theme="dark"] .loc-card__util-pct { color: #dde4f2; }
[data-theme="dark"] .loc-card__util-bar { background: rgba(255,255,255,0.08); }
[data-theme="dark"] .loc-card__footer { background: rgba(255,255,255,0.03); border-top-color: rgba(255,255,255,0.07); }
[data-theme="dark"] .loc-card__manager { color: #5c6880; }
[data-theme="dark"] .loc-card__manager span { color: #dde4f2; }
[data-theme="dark"] .loc-card__btn { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.08); color: #7080a0; }
[data-theme="dark"] .loc-card__btn:hover { background: var(--gx-lime); color: var(--gx-dark); border-color: var(--gx-lime); }

@media (max-width: 1200px) { .loc-grid { grid-template-columns: repeat(2, 1fr); } .loc-stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 768px) { .loc-grid { grid-template-columns: 1fr; } .loc-stats { grid-template-columns: repeat(2, 1fr); } }
