/* ============================================================
   دليل الخدمات الأساسية — غزة
   style.css
   ============================================================ */

/* ── Variables ── */
:root {
  --clr-primary:       #2563a8;
  --clr-primary-light: #e8f0fb;
  --clr-primary-dark:  #1a4a80;
  --clr-water:         #2a7bbf;
  --clr-charge:        #d97706;
  --clr-food:          #16a34a;
  --clr-bg:            #f8f9fb;
  --clr-card:          #ffffff;
  --clr-border:        #e4e7ee;
  --clr-text:          #1e293b;
  --clr-muted:         #64748b;
  --clr-active:        #15803d;
  --clr-closed:        #dc2626;
  --clr-unknown:       #92400e;
  --radius:            12px;
  --radius-sm:         8px;
  --shadow:            0 1px 4px rgba(0,0,0,.07);
  --shadow-md:         0 4px 16px rgba(0,0,0,.10);
}

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

body {
  font-family: 'Cairo', sans-serif;
  background: var(--clr-bg);
  color: var(--clr-text);
  font-size: 15px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main { flex: 1; }

a { text-decoration: none; color: inherit; }

/* ── Navbar ── */
.navbar {
  background: #fff;
  border-bottom: 1px solid var(--clr-border);
  padding: 12px 0;
}
.navbar-brand {
  font-weight: 700;
  font-size: 18px;
  color: var(--clr-primary) !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.brand-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--clr-primary);
  display: inline-block;
  flex-shrink: 0;
}
.nav-link {
  color: var(--clr-muted) !important;
  font-weight: 500;
  font-size: 14px;
  padding: 6px 14px !important;
  border-radius: var(--radius-sm);
  transition: background .15s, color .15s;
}
.nav-link:hover,
.nav-link.active {
  background: var(--clr-primary-light);
  color: var(--clr-primary) !important;
}
.btn-nav-submit {
  background: var(--clr-primary);
  color: #fff !important;
  font-weight: 600;
  font-size: 14px;
  padding: 7px 18px !important;
  border-radius: var(--radius-sm);
  transition: opacity .15s;
}
.btn-nav-submit:hover { opacity: .88; }

/* ── Hero ── */
.hero {
  background: #fff;
  border-bottom: 1px solid var(--clr-border);
  padding: 48px 0 36px;
}
.hero h1 {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 6px;
}
.hero p.lead {
  color: var(--clr-muted);
  font-size: 15px;
  margin-bottom: 24px;
}

/* ── Search ── */
.search-wrap {
  background: var(--clr-bg);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  padding: 8px 14px;
  gap: 8px;
  max-width: 560px;
  transition: border-color .15s;
}
.search-wrap:focus-within { border-color: var(--clr-primary); }
.search-wrap i { color: var(--clr-muted); font-size: 17px; flex-shrink: 0; }
.search-wrap input {
  border: none;
  background: transparent;
  outline: none;
  font-family: 'Cairo', sans-serif;
  font-size: 14px;
  color: var(--clr-text);
  flex: 1;
  min-width: 0;
}
.search-wrap input::placeholder { color: #aab; }

/* ── Filter Pills ── */
.filter-pill {
  border: 1.5px solid var(--clr-border);
  background: #fff;
  color: var(--clr-muted);
  font-family: 'Cairo', sans-serif;
  font-size: 13px;
  font-weight: 600;
  padding: 6px 16px;
  border-radius: 20px;
  cursor: pointer;
  transition: all .15s;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.filter-pill:hover { border-color: var(--clr-primary); color: var(--clr-primary); }
.filter-pill.active       { background: var(--clr-primary); border-color: var(--clr-primary); color: #fff; }
.filter-pill.water.active { background: var(--clr-water);   border-color: var(--clr-water); }
.filter-pill.charge.active{ background: var(--clr-charge);  border-color: var(--clr-charge); }
.filter-pill.food.active  { background: var(--clr-food);    border-color: var(--clr-food); }

/* ── Stats Bar ── */
.stats-bar {
  background: var(--clr-primary-light);
  border-radius: var(--radius);
  padding: 14px 20px;
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  align-items: center;
}
.stat-num { font-size: 20px; font-weight: 700; color: var(--clr-primary); line-height: 1.2; }
.stat-lbl { font-size: 12px; color: var(--clr-muted); font-weight: 500; }

/* ── Section Label ── */
.section-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--clr-muted);
  letter-spacing: .03em;
  margin-bottom: 14px;
}

/* ── Service Card ── */
.service-card {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 18px 20px;
  box-shadow: var(--shadow);
  transition: box-shadow .18s, transform .18s;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
}
.service-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  color: inherit;
}
.card-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  margin-bottom: 10px;
  align-self: flex-start;
}
.badge-water  { background: #e0f0fc; color: var(--clr-water); }
.badge-charge { background: #fef3c7; color: #b45309; }
.badge-food   { background: #dcfce7; color: #15803d; }

.card-title {
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 4px;
}
.card-area {
  font-size: 13px;
  color: var(--clr-muted);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.card-desc {
  font-size: 13px;
  color: var(--clr-muted);
  line-height: 1.65;
  margin-bottom: 14px;
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.card-footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--clr-border);
  padding-top: 12px;
}
.card-link-arrow {
  font-size: 13px;
  color: var(--clr-primary);
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── Operational Status ── */
.op-status {
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.op-status .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  display: inline-block;
}
.status-active  { color: var(--clr-active); }
.status-closed  { color: var(--clr-closed); }
.status-unknown { color: var(--clr-unknown); }
.status-active  .dot { background: var(--clr-active); }
.status-closed  .dot { background: var(--clr-closed); }
.status-unknown .dot { background: #d97706; }

/* ── Request Status Badges ── */
.req-badge {
  font-size: 12px;
  font-weight: 600;
  padding: 3px 12px;
  border-radius: 20px;
  display: inline-block;
}
.req-badge.pending   { background: #fef3c7; color: #92400e; }
.req-badge.published { background: #dcfce7; color: #15803d; }
.req-badge.rejected  { background: #fee2e2; color: #991b1b; }

/* ── Empty State ── */
.empty-state {
  text-align: center;
  padding: 60px 20px;
  color: var(--clr-muted);
}
.empty-state i { font-size: 40px; margin-bottom: 12px; opacity: .35; display: block; }
.empty-state p { font-size: 14px; margin: 0; }

/* ── CTA Strip ── */
.cta-strip {
  text-align: center;
  padding: 36px 20px;
  border-top: 1px solid var(--clr-border);
  margin-top: 32px;
}
.cta-strip p { font-size: 14px; color: var(--clr-muted); margin-bottom: 14px; }

/* ── Buttons ── */
.btn-primary-main {
  background: var(--clr-primary);
  color: #fff;
  font-family: 'Cairo', sans-serif;
  font-weight: 600;
  font-size: 14px;
  border: none;
  padding: 10px 28px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: opacity .15s;
}
.btn-primary-main:hover { opacity: .88; color: #fff; }

.btn-outline-main {
  background: transparent;
  color: var(--clr-primary);
  font-family: 'Cairo', sans-serif;
  font-weight: 600;
  font-size: 14px;
  border: 1.5px solid var(--clr-primary);
  padding: 9px 24px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  transition: background .15s, color .15s;
}
.btn-outline-main:hover { background: var(--clr-primary-light); }

/* ── Page Header (inner pages) ── */
.page-header {
  background: #fff;
  border-bottom: 1px solid var(--clr-border);
  padding: 28px 0;
}
.page-header h1 { font-size: 22px; font-weight: 700; margin: 0; }
.page-header p  { font-size: 14px; color: var(--clr-muted); margin: 4px 0 0; }

/* ── Detail Page ── */
.detail-card {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 28px;
  box-shadow: var(--shadow);
}
.detail-meta-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 0;
  border-bottom: 1px solid var(--clr-border);
  font-size: 14px;
}
.detail-meta-item:last-child { border-bottom: none; }
.detail-meta-item i { color: var(--clr-primary); font-size: 17px; margin-top: 1px; flex-shrink: 0; }
.detail-meta-label { font-weight: 600; margin-bottom: 2px; }
.detail-meta-value { color: var(--clr-muted); }

.map-placeholder {
  background: #e8eff7;
  border-radius: var(--radius);
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-muted);
  font-size: 14px;
  gap: 8px;
  border: 1px solid var(--clr-border);
}

/* ── Flag Form ── */
.flag-form-wrap {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow);
}
.flag-form-wrap h2 { font-size: 16px; font-weight: 700; margin-bottom: 16px; }

/* ── Forms (general) ── */
.form-card {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 32px;
  box-shadow: var(--shadow);
  max-width: 520px;
  margin: 0 auto;
}
.form-card h1 { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.form-card .subtitle { font-size: 13px; color: var(--clr-muted); margin-bottom: 24px; }

.form-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--clr-text);
  margin-bottom: 5px;
}
.form-control, .form-select {
  font-family: 'Cairo', sans-serif;
  font-size: 14px;
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-sm);
  padding: 9px 12px;
  color: var(--clr-text);
  background: var(--clr-bg);
  transition: border-color .15s;
}
.form-control:focus, .form-select:focus {
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 3px rgba(37,99,168,.12);
  background: #fff;
  outline: none;
}
textarea.form-control { resize: vertical; min-height: 100px; }

.form-divider {
  text-align: center;
  position: relative;
  margin: 20px 0;
  font-size: 13px;
  color: var(--clr-muted);
}
.form-divider::before, .form-divider::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 42%;
  height: 1px;
  background: var(--clr-border);
}
.form-divider::before { right: 0; }
.form-divider::after  { left: 0; }

/* ── My Requests ── */
.request-row {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: var(--shadow);
  transition: box-shadow .15s;
}
.request-row:hover { box-shadow: var(--shadow-md); }
.request-icon {
  width: 42px; height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
.icon-water  { background: #e0f0fc; color: var(--clr-water); }
.icon-charge { background: #fef3c7; color: #b45309; }
.icon-food   { background: #dcfce7; color: #15803d; }

.request-info { flex: 1; min-width: 0; }
.request-name { font-size: 14px; font-weight: 700; margin-bottom: 2px; }
.request-meta { font-size: 12px; color: var(--clr-muted); }
.request-rejection {
  background: #fef2f2;
  border: 1px solid #fecaca;
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 13px;
  color: #991b1b;
  margin-top: 10px;
}

/* ── Admin Sidebar ── */
.admin-layout { display: flex; min-height: 100vh; }
.admin-sidebar {
  width: 240px;
  background: #fff;
  border-left: 1px solid var(--clr-border);
  padding: 24px 0;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
}
.admin-sidebar .sidebar-brand {
  font-size: 15px;
  font-weight: 700;
  color: var(--clr-primary);
  padding: 0 20px 20px;
  border-bottom: 1px solid var(--clr-border);
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--clr-muted);
  border-radius: 0;
  transition: background .15s, color .15s;
  border-right: 3px solid transparent;
}
.sidebar-link:hover { background: var(--clr-primary-light); color: var(--clr-primary); }
.sidebar-link.active { background: var(--clr-primary-light); color: var(--clr-primary); border-right-color: var(--clr-primary); font-weight: 600; }
.sidebar-link i { font-size: 17px; }
.sidebar-badge {
  margin-right: auto;
  background: var(--clr-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 1px 7px;
  border-radius: 10px;
}

.admin-main { flex: 1; padding: 28px; overflow-y: auto; }
.admin-main h1 { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.admin-main .page-sub { font-size: 13px; color: var(--clr-muted); margin-bottom: 24px; }

/* ── Admin Stats Cards ── */
.stat-card {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  gap: 16px;
}
.stat-card-icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.stat-card-num  { font-size: 26px; font-weight: 700; line-height: 1.1; }
.stat-card-lbl  { font-size: 12px; color: var(--clr-muted); font-weight: 500; }

/* ── Admin Table ── */
.admin-table-wrap {
  background: var(--clr-card);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.admin-table-head {
  padding: 16px 20px;
  border-bottom: 1px solid var(--clr-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.admin-table-head h2 { font-size: 15px; font-weight: 700; margin: 0; }

.table {
  font-size: 14px;
  margin: 0;
}
.table th {
  font-size: 12px;
  font-weight: 600;
  color: var(--clr-muted);
  background: var(--clr-bg);
  padding: 10px 16px;
  white-space: nowrap;
  border-bottom: 1px solid var(--clr-border);
}
.table td {
  padding: 12px 16px;
  vertical-align: middle;
  border-color: var(--clr-border);
}
.table tbody tr:hover { background: #fafbfd; }

.action-btn {
  font-family: 'Cairo', sans-serif;
  font-size: 12px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 6px;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: opacity .15s;
}
.action-btn:hover { opacity: .82; }
.btn-approve { background: #dcfce7; color: #15803d; }
.btn-reject  { background: #fee2e2; color: #991b1b; }
.btn-view    { background: var(--clr-primary-light); color: var(--clr-primary); }
.btn-delete  { background: #fee2e2; color: #991b1b; }

/* ── Footer ── */
footer {
  border-top: 1px solid var(--clr-border);
  background: #fff;
  padding: 20px 0;
  font-size: 13px;
  color: var(--clr-muted);
  text-align: center;
  margin-top: auto;
}

/* ── Alerts ── */
.alert-success-custom {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #15803d;
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.alert-error-custom {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
  border-radius: var(--radius-sm);
  padding: 12px 16px;
  font-size: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .hero  { padding: 28px 0 22px; }
  .hero h1 { font-size: 20px; }
  .stats-bar { gap: 16px; }
  .admin-sidebar { display: none; }
  .admin-main { padding: 16px; }
  .form-card { padding: 20px; }
  .detail-card { padding: 18px; }
}
