/* ============================================
   GPS Iraq — Light Mode Professional Theme
   Green & White — Fresh & Modern
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Tajawal:wght@300;400;500;700;800&display=swap');

/* ============================================
   DESIGN TOKENS
   ============================================ */
:root {
  --gps-primary: #16a34a;
  --gps-primary-light: #22c55e;
  --gps-primary-lighter: #4ade80;
  --gps-primary-dark: #15803d;
  --gps-primary-darker: #166534;
  --gps-accent: #059669;
  --gps-accent-glow: rgba(22, 163, 74, 0.08);
  --gps-bg: #ffffff;
  --gps-bg-soft: #f0fdf4;
  --gps-bg-card: #ffffff;
  --gps-bg-sidebar: #f8faf9;
  --gps-bg-hover: #f0fdf4;
  --gps-text: #1a2e1a;
  --gps-text-secondary: #4a6a4a;
  --gps-text-muted: #7a9a7a;
  --gps-border: #d4e8d4;
  --gps-border-light: #e8f5e8;
  --gps-success: #16a34a;
  --gps-danger: #dc2626;
  --gps-warning: #d97706;
  --gps-info: #0284c7;
  --gps-radius: 12px;
  --gps-radius-sm: 8px;
  --gps-shadow: 0 4px 24px rgba(22, 163, 74, 0.08), 0 1px 4px rgba(0, 0, 0, 0.04);
  --gps-shadow-sm: 0 2px 8px rgba(22, 163, 74, 0.06), 0 1px 2px rgba(0, 0, 0, 0.03);
  --gps-shadow-lg: 0 8px 40px rgba(22, 163, 74, 0.1), 0 2px 8px rgba(0, 0, 0, 0.04);
  --gps-transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ============================================
   BASE & TYPOGRAPHY
   ============================================ */
html,
body {
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  font-family: 'Tajawal', -apple-system, BlinkMacSystemFont, sans-serif !important;
  background: var(--gps-bg-soft) !important;
  color: var(--gps-text) !important;
  -webkit-font-smoothing: antialiased;
}

.root {
  display: flex;
  flex-direction: column;
  height: 100%;
}

*,
*::before,
*::after {
  font-family: 'Tajawal', -apple-system, BlinkMacSystemFont, sans-serif !important;
}

/* ============================================
   APPBAR / TOP BAR
   ============================================ */
.MuiAppBar-root {
  background: var(--gps-bg) !important;
  border-bottom: 1px solid var(--gps-border) !important;
  box-shadow: 0 1px 8px rgba(0, 0, 0, 0.04) !important;
  color: var(--gps-text) !important;
}

.MuiToolbar-root {
  min-height: 56px !important;
  padding: 0 16px !important;
}

.MuiToolbar-root .MuiTypography-root {
  font-weight: 700 !important;
  letter-spacing: 0.3px !important;
  color: var(--gps-text) !important;
}

.MuiToolbar-root .MuiIconButton-root {
  color: var(--gps-text-secondary) !important;
  transition: var(--gps-transition) !important;
  border-radius: var(--gps-radius-sm) !important;
}

.MuiToolbar-root .MuiIconButton-root:hover {
  color: var(--gps-primary) !important;
  background: var(--gps-accent-glow) !important;
}

/* ============================================
   DRAWER / SIDEBAR
   ============================================ */
.MuiDrawer-paper {
  background: var(--gps-bg-sidebar) !important;
  border-right: 1px solid var(--gps-border) !important;
  border-left: 1px solid var(--gps-border) !important;
  color: var(--gps-text) !important;
  box-shadow: 2px 0 12px rgba(0, 0, 0, 0.03) !important;
}

.MuiDrawer-paper .MuiList-root {
  padding: 8px !important;
}

.MuiDrawer-paper .MuiListItemButton-root,
.MuiDrawer-paper .MuiListItem-root {
  border-radius: var(--gps-radius-sm) !important;
  margin: 2px 0 !important;
  padding: 10px 16px !important;
  transition: var(--gps-transition) !important;
  color: var(--gps-text-secondary) !important;
}

.MuiDrawer-paper .MuiListItemButton-root:hover,
.MuiDrawer-paper .MuiListItem-root:hover {
  background: var(--gps-bg-hover) !important;
  color: var(--gps-primary) !important;
}

.MuiDrawer-paper .MuiListItemButton-root.Mui-selected,
.MuiDrawer-paper .MuiListItem-root.Mui-selected {
  background: var(--gps-accent-glow) !important;
  color: var(--gps-primary) !important;
  border-right: 3px solid var(--gps-primary) !important;
  border-left: 3px solid var(--gps-primary) !important;
  font-weight: 700 !important;
}

.MuiDrawer-paper .MuiListItemIcon-root {
  color: inherit !important;
  min-width: 40px !important;
}

.MuiDrawer-paper .MuiListItemText-primary {
  font-weight: 500 !important;
  font-size: 14px !important;
}

.MuiDrawer-paper .MuiDivider-root {
  border-color: var(--gps-border-light) !important;
  margin: 8px 12px !important;
}

/* ============================================
   BOTTOM NAVIGATION (Mobile)
   ============================================ */
.MuiBottomNavigation-root {
  background: var(--gps-bg) !important;
  border-top: 1px solid var(--gps-border) !important;
  box-shadow: 0 -2px 12px rgba(0, 0, 0, 0.04) !important;
}

.MuiBottomNavigationAction-root {
  color: var(--gps-text-muted) !important;
  transition: var(--gps-transition) !important;
}

.MuiBottomNavigationAction-root.Mui-selected {
  color: var(--gps-primary) !important;
}

.MuiBottomNavigationAction-label {
  font-size: 11px !important;
  font-weight: 600 !important;
}

/* ============================================
   PAPER / CARDS
   ============================================ */
.MuiPaper-root {
  background: var(--gps-bg-card) !important;
  color: var(--gps-text) !important;
  border: 1px solid var(--gps-border-light) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: var(--gps-shadow-sm) !important;
}

.MuiPaper-elevation1 {
  box-shadow: var(--gps-shadow-sm) !important;
}

.MuiPaper-elevation4,
.MuiPaper-elevation8 {
  box-shadow: var(--gps-shadow) !important;
}

.MuiCard-root {
  background: var(--gps-bg-card) !important;
  border: 1px solid var(--gps-border-light) !important;
  border-radius: var(--gps-radius) !important;
  transition: var(--gps-transition) !important;
}

.MuiCard-root:hover {
  border-color: var(--gps-border) !important;
  box-shadow: var(--gps-shadow) !important;
}

/* ============================================
   BUTTONS
   ============================================ */
.MuiButton-root {
  text-transform: none !important;
  font-weight: 600 !important;
  border-radius: var(--gps-radius-sm) !important;
  transition: var(--gps-transition) !important;
  letter-spacing: 0.3px !important;
  padding: 8px 20px !important;
}

.MuiButton-contained,
.MuiButton-containedPrimary {
  background: linear-gradient(135deg, var(--gps-primary), var(--gps-primary-dark)) !important;
  color: #fff !important;
  box-shadow: 0 3px 12px rgba(22, 163, 74, 0.25) !important;
}

.MuiButton-contained:hover,
.MuiButton-containedPrimary:hover {
  background: linear-gradient(135deg, var(--gps-primary-light), var(--gps-primary)) !important;
  box-shadow: 0 5px 20px rgba(22, 163, 74, 0.35) !important;
  transform: translateY(-1px) !important;
}

.MuiButton-outlined,
.MuiButton-outlinedPrimary {
  border-color: var(--gps-border) !important;
  color: var(--gps-primary) !important;
}

.MuiButton-outlined:hover {
  background: var(--gps-accent-glow) !important;
  border-color: var(--gps-primary) !important;
}

.MuiButton-text,
.MuiButton-textPrimary {
  color: var(--gps-primary) !important;
}

.MuiButton-text:hover {
  background: var(--gps-accent-glow) !important;
}

.MuiFab-root,
.MuiFab-primary {
  background: linear-gradient(135deg, var(--gps-primary), var(--gps-primary-dark)) !important;
  box-shadow: 0 4px 20px rgba(22, 163, 74, 0.3) !important;
  transition: var(--gps-transition) !important;
  color: #fff !important;
}

.MuiFab-root:hover {
  transform: scale(1.05) !important;
  box-shadow: 0 6px 28px rgba(22, 163, 74, 0.4) !important;
}

/* ============================================
   ICON BUTTONS
   ============================================ */
.MuiIconButton-root {
  color: var(--gps-text-secondary) !important;
  transition: var(--gps-transition) !important;
  border-radius: var(--gps-radius-sm) !important;
}

.MuiIconButton-root:hover {
  background: var(--gps-accent-glow) !important;
  color: var(--gps-primary) !important;
}

/* ============================================
   TEXT FIELDS / INPUTS
   ============================================ */
.MuiTextField-root .MuiOutlinedInput-root {
  border-radius: var(--gps-radius-sm) !important;
  background: var(--gps-bg) !important;
  color: var(--gps-text) !important;
  transition: var(--gps-transition) !important;
}

.MuiOutlinedInput-notchedOutline {
  border-color: var(--gps-border) !important;
  transition: var(--gps-transition) !important;
}

.MuiOutlinedInput-root:hover .MuiOutlinedInput-notchedOutline {
  border-color: var(--gps-primary-lighter) !important;
}

.MuiOutlinedInput-root.Mui-focused .MuiOutlinedInput-notchedOutline {
  border-color: var(--gps-primary) !important;
  box-shadow: 0 0 0 3px var(--gps-accent-glow) !important;
}

.MuiInputLabel-root {
  color: var(--gps-text-muted) !important;
}

.MuiInputLabel-root.Mui-focused {
  color: var(--gps-primary) !important;
}

.MuiInputBase-input {
  color: var(--gps-text) !important;
}

.MuiInputBase-input::placeholder {
  color: var(--gps-text-muted) !important;
  opacity: 0.7 !important;
}

.MuiSelect-select {
  color: var(--gps-text) !important;
}

.MuiSelect-icon {
  color: var(--gps-text-muted) !important;
}

/* ============================================
   TABLES
   ============================================ */
.MuiTableHead-root .MuiTableCell-root {
  background: var(--gps-bg-soft) !important;
  color: var(--gps-primary-darker) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  border-bottom: 2px solid var(--gps-border) !important;
  letter-spacing: 0.3px !important;
  padding: 12px 16px !important;
  white-space: nowrap !important;
}

.MuiTableBody-root .MuiTableCell-root {
  color: var(--gps-text) !important;
  border-bottom: 1px solid var(--gps-border-light) !important;
  padding: 10px 16px !important;
  font-size: 13px !important;
  transition: var(--gps-transition) !important;
}

.MuiTableBody-root .MuiTableRow-root:hover .MuiTableCell-root {
  background: var(--gps-bg-hover) !important;
}

.MuiTableBody-root .MuiTableRow-root:nth-child(even) .MuiTableCell-root {
  background: rgba(240, 253, 244, 0.5) !important;
}

.MuiTableBody-root .MuiTableRow-root:nth-child(even):hover .MuiTableCell-root {
  background: var(--gps-bg-hover) !important;
}

.MuiTablePagination-root {
  color: var(--gps-text-secondary) !important;
  border-top: 1px solid var(--gps-border-light) !important;
}

/* ============================================
   DIALOGS / MODALS
   ============================================ */
.MuiDialog-paper {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12) !important;
  color: var(--gps-text) !important;
  animation: gps-fadeIn 0.2s ease-out !important;
}

.MuiDialogTitle-root {
  background: var(--gps-bg-soft) !important;
  border-bottom: 1px solid var(--gps-border-light) !important;
  padding: 16px 24px !important;
  font-weight: 700 !important;
  font-size: 17px !important;
  color: var(--gps-primary-darker) !important;
}

.MuiDialogContent-root {
  padding: 24px !important;
  color: var(--gps-text) !important;
}

.MuiDialogActions-root {
  padding: 12px 24px !important;
  border-top: 1px solid var(--gps-border-light) !important;
  background: var(--gps-bg-soft) !important;
}

.MuiBackdrop-root {
  background: rgba(22, 101, 52, 0.08) !important;
  backdrop-filter: blur(4px) !important;
}

/* ============================================
   TABS
   ============================================ */
.MuiTabs-root {
  min-height: 44px !important;
}

.MuiTab-root {
  color: var(--gps-text-muted) !important;
  text-transform: none !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  min-height: 44px !important;
  transition: var(--gps-transition) !important;
}

.MuiTab-root:hover {
  color: var(--gps-primary) !important;
  background: var(--gps-accent-glow) !important;
}

.MuiTab-root.Mui-selected {
  color: var(--gps-primary) !important;
  font-weight: 700 !important;
}

.MuiTabs-indicator {
  background: var(--gps-primary) !important;
  height: 3px !important;
  border-radius: 3px 3px 0 0 !important;
}

/* ============================================
   CHIPS & BADGES
   ============================================ */
.MuiChip-root {
  border-radius: 20px !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  border: 1px solid var(--gps-border) !important;
  background: var(--gps-bg-hover) !important;
  color: var(--gps-primary-dark) !important;
  transition: var(--gps-transition) !important;
}

.MuiChip-root:hover {
  background: rgba(22, 163, 74, 0.12) !important;
}

.MuiChip-deleteIcon {
  color: var(--gps-text-muted) !important;
}

.MuiBadge-badge {
  font-weight: 700 !important;
  font-size: 11px !important;
}

/* ============================================
   SWITCH / CHECKBOX / RADIO
   ============================================ */
.MuiSwitch-root .MuiSwitch-track {
  background: var(--gps-border) !important;
  border-radius: 14px !important;
}

.MuiSwitch-root .Mui-checked+.MuiSwitch-track {
  background: var(--gps-primary-lighter) !important;
  opacity: 0.7 !important;
}

.MuiSwitch-root .Mui-checked .MuiSwitch-thumb {
  background: var(--gps-primary) !important;
}

.MuiCheckbox-root {
  color: var(--gps-text-muted) !important;
}

.MuiCheckbox-root.Mui-checked {
  color: var(--gps-primary) !important;
}

.MuiRadio-root {
  color: var(--gps-text-muted) !important;
}

.MuiRadio-root.Mui-checked {
  color: var(--gps-primary) !important;
}

/* ============================================
   MENUS / POPOVERS
   ============================================ */
.MuiMenu-paper,
.MuiPopover-paper {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: var(--gps-shadow-lg) !important;
  color: var(--gps-text) !important;
  animation: gps-fadeIn 0.15s ease-out !important;
}

.MuiMenuItem-root {
  font-size: 14px !important;
  padding: 10px 16px !important;
  transition: var(--gps-transition) !important;
  color: var(--gps-text) !important;
  border-radius: var(--gps-radius-sm) !important;
  margin: 2px 4px !important;
}

.MuiMenuItem-root:hover {
  background: var(--gps-bg-hover) !important;
  color: var(--gps-primary) !important;
}

.MuiMenuItem-root.Mui-selected {
  background: var(--gps-accent-glow) !important;
  color: var(--gps-primary) !important;
}

/* ============================================
   TOOLTIP
   ============================================ */
.MuiTooltip-tooltip {
  background: var(--gps-primary-darker) !important;
  color: #fff !important;
  border-radius: var(--gps-radius-sm) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  padding: 6px 12px !important;
}

.MuiTooltip-arrow::before {
  background: var(--gps-primary-darker) !important;
}

/* ============================================
   SNACKBAR / ALERTS
   ============================================ */
.MuiSnackbarContent-root {
  background: var(--gps-bg) !important;
  color: var(--gps-text) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: var(--gps-shadow-lg) !important;
}

.MuiAlert-root {
  border-radius: var(--gps-radius-sm) !important;
  font-weight: 500 !important;
}

.MuiAlert-standardSuccess {
  background: #f0fdf4 !important;
  color: var(--gps-success) !important;
  border: 1px solid #bbf7d0 !important;
}

.MuiAlert-standardError {
  background: #fef2f2 !important;
  color: var(--gps-danger) !important;
  border: 1px solid #fecaca !important;
}

.MuiAlert-standardWarning {
  background: #fffbeb !important;
  color: var(--gps-warning) !important;
  border: 1px solid #fde68a !important;
}

.MuiAlert-standardInfo {
  background: #f0f9ff !important;
  color: var(--gps-info) !important;
  border: 1px solid #bae6fd !important;
}

/* ============================================
   ACCORDION
   ============================================ */
.MuiAccordion-root {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border-light) !important;
  border-radius: var(--gps-radius-sm) !important;
  margin-bottom: 8px !important;
  color: var(--gps-text) !important;
}

.MuiAccordion-root::before {
  display: none !important;
}

.MuiAccordionSummary-root:hover {
  background: var(--gps-bg-hover) !important;
}

.MuiAccordionSummary-expandIconWrapper {
  color: var(--gps-text-muted) !important;
}

.MuiAccordionDetails-root {
  padding: 16px !important;
  border-top: 1px solid var(--gps-border-light) !important;
}

/* ============================================
   SCROLLBAR
   ============================================ */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(22, 163, 74, 0.15);
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(22, 163, 74, 0.3);
}

/* ============================================
   DEVICE LIST
   ============================================ */
.MuiList-root .MuiListItemButton-root {
  border-radius: var(--gps-radius-sm) !important;
  margin: 2px 4px !important;
  transition: var(--gps-transition) !important;
}

.MuiList-root .MuiListItemButton-root:hover {
  background: var(--gps-bg-hover) !important;
}

.MuiListItemAvatar-root .MuiAvatar-root {
  background: linear-gradient(135deg, var(--gps-primary), var(--gps-primary-dark)) !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 14px !important;
}

.MuiListItemText-secondary {
  color: var(--gps-text-muted) !important;
  font-size: 12px !important;
}

/* ============================================
   MAP MARKERS & DEVICE ICONS — PROTECTION
   أيقونات الخريطة يجب أن تحتفظ بألوانها الأصلية
   ============================================ */

/* حماية أيقونات الأجهزة على الخريطة */
.maplibregl-marker,
.mapboxgl-marker {
  color: initial !important;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3)) !important;
  transition: transform 0.2s ease !important;
  cursor: pointer !important;
  z-index: 1 !important;
}

.maplibregl-marker:hover,
.mapboxgl-marker:hover {
  transform: scale(1.2) !important;
  z-index: 10 !important;
  filter: drop-shadow(0 3px 8px rgba(0, 0, 0, 0.4)) !important;
}

/* حماية SVG داخل الماركرات */
.maplibregl-marker svg,
.mapboxgl-marker svg {
  overflow: visible !important;
}

.maplibregl-marker svg *,
.mapboxgl-marker svg * {
  color: inherit !important;
}

/* ضمان أيقونات الأجهزة تحتفظ بألوانها الأصلية */
.maplibregl-marker img,
.mapboxgl-marker img {
  max-width: none !important;
  max-height: none !important;
}

/* أزرار التحكم على الخريطة */
.maplibregl-ctrl-group,
.mapboxgl-ctrl-group {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius-sm) !important;
  box-shadow: var(--gps-shadow-sm) !important;
  overflow: hidden !important;
}

.maplibregl-ctrl-group button,
.mapboxgl-ctrl-group button {
  background: var(--gps-bg) !important;
  border-bottom: 1px solid var(--gps-border-light) !important;
  width: 36px !important;
  height: 36px !important;
}

.maplibregl-ctrl-group button:hover,
.mapboxgl-ctrl-group button:hover {
  background: var(--gps-bg-hover) !important;
}

.maplibregl-ctrl-group button .maplibregl-ctrl-icon,
.mapboxgl-ctrl-group button .mapboxgl-ctrl-icon {
  filter: none !important;
}

/* ============================================
   MAPBOX-GL-DRAW — أزرار رسم الحدود الجغرافية
   ============================================ */
.mapbox-gl-draw_ctrl-draw-btn {
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: 20px 20px !important;
  border: none !important;
  border-bottom: 1px solid var(--gps-border-light) !important;
  cursor: pointer !important;
  transition: var(--gps-transition) !important;
}

/* ضمان ظهور الأيقونات بلون داكن */
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_line,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_polygon,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_point,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_trash,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_combine,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_uncombine {
  filter: brightness(0) saturate(100%) !important;
  opacity: 0.6 !important;
}

.mapbox-gl-draw_ctrl-draw-btn:hover {
  background-color: var(--gps-bg-hover) !important;
  opacity: 1 !important;
}

/* الزر النشط — حالة الرسم */
.mapbox-gl-draw_ctrl-draw-btn.active,
.mapbox-gl-draw_ctrl-draw-btn.mapbox-gl-draw_ctrl-draw-btn--active {
  background-color: var(--gps-accent-glow) !important;
  opacity: 1 !important;
  filter: brightness(0) saturate(100%) invert(39%) sepia(90%) saturate(600%) hue-rotate(100deg) !important;
}

/* Popup على الخريطة */
.maplibregl-popup-content,
.mapboxgl-popup-content {
  background: var(--gps-bg) !important;
  color: var(--gps-text) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: var(--gps-shadow) !important;
  padding: 12px 16px !important;
  font-family: 'Tajawal', sans-serif !important;
  font-size: 13px !important;
}

.maplibregl-popup-close-button,
.mapboxgl-popup-close-button {
  color: var(--gps-text-muted) !important;
  font-size: 18px !important;
  padding: 4px 8px !important;
}

.maplibregl-popup-close-button:hover,
.mapboxgl-popup-close-button:hover {
  color: var(--gps-text) !important;
  background: var(--gps-bg-hover) !important;
}

/* Popup tip (arrow) */
.maplibregl-popup-anchor-bottom .maplibregl-popup-tip,
.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip {
  border-top-color: var(--gps-bg) !important;
}

.maplibregl-popup-anchor-top .maplibregl-popup-tip,
.mapboxgl-popup-anchor-top .mapboxgl-popup-tip {
  border-bottom-color: var(--gps-bg) !important;
}

.maplibregl-popup-anchor-left .maplibregl-popup-tip,
.mapboxgl-popup-anchor-left .mapboxgl-popup-tip {
  border-right-color: var(--gps-bg) !important;
}

.maplibregl-popup-anchor-right .maplibregl-popup-tip,
.mapboxgl-popup-anchor-right .mapboxgl-popup-tip {
  border-left-color: var(--gps-bg) !important;
}

/* Attribution */
.maplibregl-ctrl-attrib,
.mapboxgl-ctrl-attrib {
  background: rgba(255, 255, 255, 0.8) !important;
  font-size: 10px !important;
  border-radius: 4px !important;
}

/* Canvas — حماية حاسوب الخريطة */
.maplibregl-canvas-container,
.mapboxgl-canvas-container {
  position: absolute !important;
}

.maplibregl-canvas,
.mapboxgl-canvas {
  outline: none !important;
}

/* ============================================
   TYPOGRAPHY
   ============================================ */
.MuiTypography-root {
  color: var(--gps-text) !important;
}

.MuiTypography-h1,
.MuiTypography-h2,
.MuiTypography-h3,
.MuiTypography-h4,
.MuiTypography-h5,
.MuiTypography-h6 {
  font-weight: 700 !important;
}

.MuiTypography-body2,
.MuiTypography-caption {
  color: var(--gps-text-muted) !important;
}

/* ============================================
   DIVIDER / SLIDER / PROGRESS
   ============================================ */
.MuiDivider-root {
  border-color: var(--gps-border-light) !important;
}

.MuiSlider-root {
  color: var(--gps-primary) !important;
}

.MuiSlider-track {
  background: linear-gradient(90deg, var(--gps-primary), var(--gps-primary-light)) !important;
  border: none !important;
}

.MuiSlider-thumb {
  background: var(--gps-primary) !important;
  box-shadow: 0 2px 6px rgba(22, 163, 74, 0.3) !important;
}

.MuiSlider-rail {
  background: var(--gps-border) !important;
}

.MuiLinearProgress-root {
  background: rgba(22, 163, 74, 0.1) !important;
  border-radius: 4px !important;
}

.MuiLinearProgress-bar {
  background: linear-gradient(90deg, var(--gps-primary), var(--gps-primary-light)) !important;
  border-radius: 4px !important;
}

.MuiCircularProgress-root {
  color: var(--gps-primary) !important;
}

/* ============================================
   AUTOCOMPLETE
   ============================================ */
.MuiAutocomplete-paper {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border) !important;
  color: var(--gps-text) !important;
}

.MuiAutocomplete-option:hover,
.MuiAutocomplete-option[aria-selected="true"] {
  background: var(--gps-bg-hover) !important;
}

/* ============================================
   MAP CONTROLS
   ============================================ */
.maplibregl-ctrl-group,
.mapboxgl-ctrl-group {
  background: var(--gps-bg) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius-sm) !important;
  box-shadow: var(--gps-shadow-sm) !important;
}

.maplibregl-ctrl-group button,
.mapboxgl-ctrl-group button {
  background: transparent !important;
  border-color: var(--gps-border-light) !important;
}

.maplibregl-ctrl-group button:hover,
.mapboxgl-ctrl-group button:hover {
  background: var(--gps-bg-hover) !important;
}

.maplibregl-popup-content,
.mapboxgl-popup-content {
  background: var(--gps-bg) !important;
  color: var(--gps-text) !important;
  border: 1px solid var(--gps-border) !important;
  border-radius: var(--gps-radius) !important;
  box-shadow: var(--gps-shadow) !important;
  padding: 12px !important;
}

/* ============================================
   SETTINGS / FORMS
   ============================================ */
.MuiContainer-root {
  color: var(--gps-text) !important;
}

.MuiFormControl-root .MuiFormLabel-root {
  color: var(--gps-text-muted) !important;
}

.MuiFormHelperText-root {
  color: var(--gps-text-muted) !important;
  font-size: 11px !important;
}

/* ============================================
   PAGINATION
   ============================================ */
.MuiPaginationItem-root {
  color: var(--gps-text-secondary) !important;
  border-color: var(--gps-border) !important;
}

.MuiPaginationItem-root.Mui-selected {
  background: var(--gps-primary) !important;
  color: #fff !important;
  border-color: var(--gps-primary) !important;
}

/* ============================================
   SKELETON
   ============================================ */
.MuiSkeleton-root {
  background: rgba(22, 163, 74, 0.06) !important;
}

/* ============================================
   LINKS & SELECTION
   ============================================ */
a {
  color: var(--gps-primary) !important;
  text-decoration: none !important;
}

a:hover {
  color: var(--gps-primary-dark) !important;
}

::selection {
  background: rgba(22, 163, 74, 0.15);
  color: var(--gps-text);
}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes gps-fadeIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.MuiMenu-paper {
  animation: gps-fadeIn 0.15s ease-out !important;
}

/* ==========================================================================
   LOGIN PAGE — Custom Overlay (Light Green)
   ========================================================================== */

#gps-iraq-login-overlay {
  position: fixed;
  inset: 0;
  z-index: 99999;
  display: flex;
  font-family: 'Tajawal', sans-serif;
  direction: rtl;
}

#gps-iraq-login-overlay.hidden {
  display: none;
}

/* الجانب الأيمن — البراند */
.gps-brand-side {
  flex: 1;
  background: linear-gradient(135deg, #166534 0%, #15803d 30%, #16a34a 60%, #22c55e 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  min-height: 100vh;
}

.gps-brand-side::before {
  content: '';
  position: absolute;
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: gps-pulse 6s ease-in-out infinite;
}

.gps-brand-side::after {
  content: '';
  position: absolute;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.08);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: gps-ring 8s linear infinite;
}

@keyframes gps-pulse {

  0%,
  100% {
    transform: translate(-50%, -50%) scale(1);
    opacity: 0.6;
  }

  50% {
    transform: translate(-50%, -50%) scale(1.15);
    opacity: 1;
  }
}

@keyframes gps-ring {
  0% {
    transform: translate(-50%, -50%) scale(0.8);
    opacity: 0;
  }

  50% {
    opacity: 0.3;
  }

  100% {
    transform: translate(-50%, -50%) scale(1.5);
    opacity: 0;
  }
}

.gps-brand-logo {
  position: relative;
  z-index: 2;
  text-align: center;
}

.gps-brand-logo svg {
  width: 100px;
  height: 100px;
  color: #ffffff;
  filter: drop-shadow(0 4px 20px rgba(0, 0, 0, 0.15));
  margin-bottom: 24px;
}

.gps-brand-title {
  font-size: 42px;
  font-weight: 800;
  color: #ffffff;
  letter-spacing: 3px;
  margin: 0;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.1);
}

.gps-brand-subtitle {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.75);
  margin-top: 8px;
  letter-spacing: 4px;
  text-transform: uppercase;
}

.gps-brand-dots {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
}

.gps-dot {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.15);
  animation: gps-float 20s linear infinite;
}

@keyframes gps-float {
  0% {
    transform: translateY(100vh) scale(0);
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  90% {
    opacity: 1;
  }

  100% {
    transform: translateY(-10vh) scale(1);
    opacity: 0;
  }
}

/* الجانب الأيسر — فورم الدخول */
.gps-form-side {
  width: 480px;
  min-width: 400px;
  background: #ffffff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px;
  position: relative;
}

.gps-form-container {
  width: 100%;
  max-width: 360px;
}

.gps-form-header {
  text-align: center;
  margin-bottom: 40px;
}

.gps-form-header h2 {
  font-size: 26px;
  font-weight: 800;
  color: #166534;
  margin: 0 0 6px;
}

.gps-form-header p {
  font-size: 14px;
  color: #6b7a6b;
  margin: 0;
}

.gps-form-group {
  margin-bottom: 20px;
}

.gps-form-group label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: #374137;
  margin-bottom: 6px;
}

.gps-form-group input {
  width: 100%;
  padding: 13px 16px;
  border: 2px solid #d4e8d4;
  border-radius: 12px;
  font-size: 15px;
  font-family: 'Tajawal', sans-serif;
  color: #1a2e1a;
  background: #f8faf8;
  transition: var(--gps-transition);
  box-sizing: border-box;
  direction: ltr;
  text-align: right;
}

.gps-form-group input:focus {
  outline: none;
  border-color: #16a34a;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.08);
}

.gps-form-group input::placeholder {
  color: #9caa9c;
  direction: rtl;
}

.gps-login-btn {
  width: 100%;
  padding: 14px;
  background: linear-gradient(135deg, #16a34a, #15803d);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 16px;
  font-weight: 700;
  font-family: 'Tajawal', sans-serif;
  cursor: pointer;
  transition: var(--gps-transition);
  box-shadow: 0 4px 16px rgba(22, 163, 74, 0.25);
  margin-top: 8px;
  position: relative;
  overflow: hidden;
}

.gps-login-btn:hover {
  background: linear-gradient(135deg, #22c55e, #16a34a);
  box-shadow: 0 6px 24px rgba(22, 163, 74, 0.35);
  transform: translateY(-2px);
}

.gps-login-btn:active {
  transform: translateY(0);
}

.gps-login-btn:disabled {
  opacity: 0.7;
  cursor: not-allowed;
  transform: none;
}

.gps-login-btn .gps-spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2.5px solid rgba(255, 255, 255, 0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: gps-spin 0.7s linear infinite;
  vertical-align: middle;
  margin-left: 8px;
}

@keyframes gps-spin {
  to {
    transform: rotate(360deg);
  }
}

.gps-error-msg {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #dc2626;
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
  margin-bottom: 16px;
  text-align: center;
}

.gps-form-footer {
  text-align: center;
  margin-top: 32px;
  font-size: 12px;
  color: #9caa9c;
}

.gps-form-footer span {
  color: #16a34a;
  font-weight: 600;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 900px) {
  #gps-iraq-login-overlay {
    flex-direction: column-reverse;
  }

  .gps-brand-side {
    min-height: 200px;
    flex: none;
    padding: 40px 20px;
  }

  .gps-brand-title {
    font-size: 28px;
  }

  .gps-brand-logo svg {
    width: 60px;
    height: 60px;
    margin-bottom: 12px;
  }

  .gps-form-side {
    width: 100%;
    min-width: unset;
    flex: 1;
    padding: 30px 20px;
  }
}

/* ============================================
   DARK MODE OVERRIDE — DISABLED
   ============================================ */
@media (prefers-color-scheme: dark) {
  body {
    background: var(--gps-bg-soft) !important;
  }
}