/* ==================================================================
   Components — مكونات UI قابلة لإعادة الاستعمال
   ================================================================== */

/* ---------- الأزرار ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 18px;
  border-radius: var(--radius);
  font-weight: 800;
  font-size: 14.5px;
  transition: var(--tr);
  font-family: var(--font-body);
  text-decoration: none;
}
.btn:active { transform: translateY(1px); }

.btn-pri {
  background: linear-gradient(135deg, var(--green-l), var(--green));
  color: #fff;
  box-shadow: 0 10px 22px -12px rgba(47,93,58,.9);
}
.btn-pri:hover { filter: brightness(1.07); }

.btn-amber {
  background: linear-gradient(135deg, var(--amber-l), var(--amber));
  color: #2a1708;
  box-shadow: 0 10px 22px -12px rgba(201,123,53,.9);
}
.btn-amber:hover { filter: brightness(1.05); }

.btn-ghost {
  background: var(--card);
  border: 1px solid var(--line);
  color: var(--ink);
}
.btn-ghost:hover {
  border-color: var(--green-l);
  color: var(--green);
}

.btn-sm {
  padding: 7px 12px;
  font-size: 13px;
  border-radius: var(--radius-sm);
}

.btn-danger {
  background: #fbeae7;
  color: var(--red);
}
.btn-danger:hover { background: #f7ddd8; }

/* ---------- البطاقات (Cards) ---------- */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: 20px;
}

.kpi { position: relative; overflow: hidden; }
.kpi .lbl {
  font-size: 13.5px;
  color: var(--ink-soft);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}
.kpi .val {
  font-size: 27px;
  font-weight: 900;
  font-family: var(--font-display);
  margin-top: 8px;
  letter-spacing: -.5px;
}
.kpi .sub {
  font-size: 12px;
  color: var(--ink-soft);
  margin-top: 4px;
}
.kpi .badge {
  position: absolute;
  left: 16px; top: 16px;
  width: 40px; height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  font-size: 20px;
}
.kpi.k-green .val { color: var(--green); } .kpi.k-green .badge { background: #e4efe2; }
.kpi.k-amber .val { color: var(--amber); } .kpi.k-amber .badge { background: #fbedda; }
.kpi.k-red   .val { color: var(--red);   } .kpi.k-red   .badge { background: #fbe7e3; }
.kpi.k-blue  .val { color: var(--blue);  } .kpi.k-blue  .badge { background: #e3eef4; }

/* ---------- الجدول ---------- */
.tbl-wrap {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  overflow: hidden;
}
table { width: 100%; border-collapse: collapse; }
th {
  background: var(--bg2);
  text-align: right;
  padding: 13px 16px;
  font-size: 12.5px;
  font-weight: 800;
  color: var(--ink-soft);
  font-family: var(--font-display);
  white-space: nowrap;
}
td {
  padding: 13px 16px;
  border-top: 1px solid var(--line);
  font-size: 14px;
  font-weight: 500;
  vertical-align: middle;
}
tr:hover td { background: #faf6ec; }

/* ---------- الـ Tags ---------- */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
}
.tag-green { background: #e4efe2; color: var(--green); }
.tag-amber { background: #fbedda; color: var(--amber); }
.tag-red   { background: #fbe7e3; color: var(--red);   }
.tag-blue  { background: #e3eef4; color: var(--blue);  }
.tag-gray  { background: #eee8da; color: var(--ink-soft); }
.dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  display: inline-block;
}

/* ---------- Empty State ---------- */
.empty {
  text-align: center;
  padding: 46px 20px;
  color: var(--ink-soft);
}
.empty .em { font-size: 46px; opacity: .6; }
.empty h4 {
  font-size: 17px;
  color: var(--ink);
  margin: 12px 0 6px;
  font-weight: 800;
}
.empty p {
  font-size: 14px;
  margin-bottom: 16px;
}

/* ---------- الـ Modal ---------- */
.overlay {
  position: fixed;
  inset: 0;
  background: rgba(33,44,28,.55);
  backdrop-filter: blur(3px);
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 50;
  padding: 34px 16px;
  overflow: auto;
}
.overlay.show { display: flex; }

.modal {
  background: var(--card);
  border-radius: var(--radius-xl);
  width: 100%;
  max-width: 620px;
  box-shadow: var(--shadow-lg);
  animation: pop .22s ease;
  overflow: hidden;
}
.modal.wide { max-width: 760px; }
@keyframes pop {
  from { opacity: 0; transform: translateY(14px) scale(.98); }
  to   { opacity: 1; transform: none; }
}

.modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fff, var(--bg));
}
.modal-head h3 { font-size: 19px; font-weight: 800; }
.modal-head .x {
  width: 34px; height: 34px;
  border-radius: var(--radius-sm);
  font-size: 20px;
  color: var(--ink-soft);
  display: grid;
  place-items: center;
}
.modal-head .x:hover { background: var(--bg2); color: var(--ink); }

.modal-body {
  padding: 22px 24px;
  max-height: 64vh;
  overflow: auto;
}

.modal-foot {
  padding: 16px 24px;
  border-top: 1px solid var(--line);
  display: flex;
  gap: 10px;
  justify-content: flex-start;
  background: var(--bg);
}

/* ---------- الفورم ---------- */
.fgrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 2px;
}
.field.full { grid-column: 1/-1; }
.field label {
  font-size: 13px;
  font-weight: 800;
  color: var(--ink);
}
.field .req { color: var(--red); }
.field input,
.field select,
.field textarea {
  padding: 11px 13px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  color: var(--ink);
  outline: none;
  transition: .15s;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--green-l);
  box-shadow: 0 0 0 3px rgba(74,130,89,.15);
}
.field textarea { resize: vertical; min-height: 64px; }
.field .help { font-size: 11.5px; color: var(--ink-soft); }

/* ---------- Switch (تشغيل/إيقاف) ---------- */
.switch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
}
.switch-row .t { font-weight: 800; font-size: 14px; }
.switch {
  position: relative;
  width: 48px; height: 27px;
  flex-shrink: 0;
}
.switch input { display: none; }
.switch .sl {
  position: absolute;
  inset: 0;
  background: #d6cab2;
  border-radius: 999px;
  transition: .2s;
}
.switch .sl:before {
  content: '';
  position: absolute;
  width: 21px; height: 21px;
  border-radius: 50%;
  background: #fff;
  top: 3px; right: 3px;
  transition: .2s;
  box-shadow: 0 2px 4px rgba(0,0,0,.25);
}
.switch input:checked + .sl { background: var(--green-l); }
.switch input:checked + .sl:before { transform: translateX(-21px); }

/* ---------- Pill ---------- */
.pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}
.pill {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  border-radius: 999px;
  background: var(--bg2);
  font-size: 13px;
  font-weight: 700;
  border: 1px solid var(--line);
}
.pill button { color: var(--red); font-size: 15px; line-height: 1; font-weight: 800; }

/* ---------- شريط الأدوات ---------- */
.toolbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 16px;
}
.toolbar input,
.toolbar select {
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--card);
  outline: none;
}
.toolbar input:focus,
.toolbar select:focus { border-color: var(--green-l); }
.spacer { flex: 1; }

/* ---------- شريط بياني ---------- */
.barlist {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.barrow .bl {
  display: flex;
  justify-content: space-between;
  font-size: 13.5px;
  font-weight: 700;
  margin-bottom: 5px;
}
.bartrack {
  height: 11px;
  background: var(--bg2);
  border-radius: 999px;
  overflow: hidden;
}
.barfill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--green-l), var(--green));
}
.barfill.exp {
  background: linear-gradient(90deg, var(--amber-l), var(--amber));
}

/* ---------- مساعدات شبكة ---------- */
.grid { display: grid; gap: 18px; }
.cards-4 { grid-template-columns: repeat(4, 1fr); }
.cards-3 { grid-template-columns: repeat(3, 1fr); }
.cards-2 { grid-template-columns: repeat(2, 1fr); }

.sec-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 26px 0 14px;
  flex-wrap: wrap;
  gap: 12px;
}
.sec-head h3 { font-size: 18px; font-weight: 800; }
.sec-head .hint { font-size: 13px; color: var(--ink-soft); }

.scrollx { overflow-x: auto; }

/* ========== Pagination ========== */
.pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 16px;
  padding: 12px 16px;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  font-size: 13.5px;
}
.pg-info { color: var(--ink); font-weight: 600; }
.pg-info strong { color: var(--green); font-weight: 800; }
.pg-controls {
  display: flex;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}
.pg-size {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--ink-soft);
  font-weight: 600;
  font-size: 12.5px;
}
.pg-size select {
  padding: 5px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  font-family: inherit;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  color: var(--ink);
}
.pg-size select:focus { outline: 2px solid var(--green-l); }
.pg-nav { display: flex; gap: 4px; align-items: center; }
.pg-nav button {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: var(--bg);
  border: 1px solid var(--line);
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
  transition: var(--tr);
  color: var(--ink);
  font-family: inherit;
}
.pg-nav button:hover:not(:disabled) {
  background: var(--green);
  color: #fff;
  border-color: var(--green);
  transform: translateY(-1px);
}
.pg-nav button:disabled {
  opacity: .35;
  cursor: not-allowed;
}
.pg-page {
  font-weight: 800;
  color: var(--green-d);
  padding: 0 12px;
  font-size: 13.5px;
  min-width: 56px;
  text-align: center;
}

@media (max-width: 640px) {
  .pagination { padding: 10px 12px; gap: 10px; }
  .pg-info { width: 100%; text-align: center; }
  .pg-controls { width: 100%; justify-content: space-between; }
  .pg-nav button { width: 32px; height: 32px; }
}

/* ========== Lightbox (عرض الصور بحجم كبير) ========== */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(15, 25, 18, 0.92);
  backdrop-filter: blur(8px);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  animation: lbfade .2s ease;
}
.lightbox.show { display: flex; }
@keyframes lbfade { from { opacity: 0; } to { opacity: 1; } }

.lightbox img {
  max-width: 92vw;
  max-height: 85vh;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
  background: #fff;
  user-select: none;
}

.lightbox .lb-close,
.lightbox .lb-prev,
.lightbox .lb-next {
  position: fixed;
  background: rgba(255,255,255,.18);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.3);
  cursor: pointer;
  display: grid;
  place-items: center;
  font-family: inherit;
  font-weight: 800;
  transition: all .15s;
  backdrop-filter: blur(8px);
}
.lightbox .lb-close:hover,
.lightbox .lb-prev:hover,
.lightbox .lb-next:hover {
  background: rgba(255,255,255,.35);
  transform: scale(1.06);
}

.lightbox .lb-close {
  top: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  font-size: 20px;
}
.lightbox .lb-prev,
.lightbox .lb-next {
  top: 50%;
  transform: translateY(-50%);
  width: 50px;
  height: 50px;
  border-radius: 50%;
  font-size: 28px;
  line-height: 1;
}
.lightbox .lb-prev { right: 24px; }
.lightbox .lb-next { left: 24px; }
.lightbox .lb-prev:hover, .lightbox .lb-next:hover {
  transform: translateY(-50%) scale(1.06);
}

.lightbox .lb-info {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  background: rgba(0,0,0,.5);
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13.5px;
  font-weight: 600;
  backdrop-filter: blur(8px);
  max-width: 80vw;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.lightbox .lb-info span { margin: 0 6px; }

@media (max-width: 640px) {
  .lightbox .lb-close { top: 12px; right: 12px; width: 38px; height: 38px; font-size: 17px; }
  .lightbox .lb-prev, .lightbox .lb-next { width: 42px; height: 42px; font-size: 24px; }
  .lightbox .lb-prev { right: 10px; }
  .lightbox .lb-next { left: 10px; }
  .lightbox .lb-info { bottom: 14px; font-size: 12px; padding: 6px 12px; }
  .lightbox img { max-width: 96vw; max-height: 75vh; }
}

/* ================================================================
   PRINT STYLES — تنسيق الطباعة الاحترافي
   ================================================================ */
@media print {

  /* —— إعداد الصفحة —— */
  @page {
    size: A4;
    margin: 1.5cm 1cm;
  }

  /* —— الأساس —— */
  *, *::before, *::after {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    box-shadow: none !important;
  }

  html, body {
    background: #fff !important;
    color: #000 !important;
    font-size: 11pt !important;
    direction: rtl !important;
  }

  body { margin: 0 !important; padding: 0 !important; }

  /* —— إخفاء كل العناصر التفاعلية والتنقل —— */
  .side,
  .side-backdrop,
  .side-close,
  .mobile-top,
  .topbar,
  .toolbar,
  .filters,
  .user-area,
  .user-pop,
  .topbar-btn,
  .farm-pick,
  .btn,
  .pageNav,
  .page-nav,
  .pagination,
  button,
  .modal-overlay,
  .modal,
  .toast,
  #toast,
  .lightbox,
  .empty .btn,
  select,
  input[type="search"],
  input[type="date"],
  input[type="text"]:not(.print-show),
  .hint:empty,
  .req,
  .foot,
  .nav,
  .brand .logo {
    display: none !important;
    visibility: hidden !important;
  }

  /* —— Layout: نلغي الـ flex/grid التطبيقي —— */
  .app {
    display: block !important;
  }
  .main {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    flex: none !important;
  }
  .content {
    padding: 0 !important;
    margin: 0 !important;
  }

  /* —— Header مخصّص للطباعة —— */
  body::before {
    content: "🌿  نظام مزرعتي — إدارة حجوزات المزارع";
    display: block;
    text-align: center;
    font-size: 14pt;
    font-weight: 800;
    color: #2b3d2a !important;
    border-bottom: 2px solid #2b3d2a;
    padding-bottom: 8pt;
    margin-bottom: 18pt;
  }

  /* —— عناوين الصفحة —— */
  .ttl, h1, h2, h3 {
    color: #2b3d2a !important;
    page-break-after: avoid;
  }
  .ttl { font-size: 16pt !important; margin: 0 0 4pt !important; }
  .ttl + .sub { font-size: 10pt !important; color: #555 !important; margin-bottom: 12pt !important; }
  .sec-head h3 { font-size: 13pt !important; margin: 14pt 0 8pt !important; }

  /* —— KPI cards: نوع 3 أعمدة عرضي للطباعة —— */
  .grid.cards-4,
  .grid.cards-3,
  .grid.cards-2 {
    display: grid !important;
    gap: 8pt !important;
    margin-bottom: 14pt !important;
    page-break-inside: avoid;
  }
  .grid.cards-4 { grid-template-columns: repeat(4, 1fr) !important; }
  .grid.cards-3 { grid-template-columns: repeat(3, 1fr) !important; }
  .grid.cards-2 { grid-template-columns: repeat(2, 1fr) !important; }

  .card.kpi {
    padding: 8pt !important;
    border: 1pt solid #ddd !important;
    background: #fafafa !important;
    border-radius: 4pt !important;
  }
  .card.kpi .badge {
    width: 24pt !important; height: 24pt !important;
    font-size: 12pt !important;
  }
  .card.kpi .lbl { font-size: 9pt !important; }
  .card.kpi .val {
    font-size: 14pt !important;
    color: #2b3d2a !important;
    margin: 2pt 0 !important;
  }
  .card.kpi .sub { font-size: 8pt !important; }

  /* —— Cards عامة —— */
  .card {
    border: 1pt solid #ddd !important;
    background: #fff !important;
    page-break-inside: avoid;
    margin-bottom: 10pt !important;
    padding: 10pt !important;
  }

  /* —— الجداول —— */
  table {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 10pt !important;
    page-break-inside: auto;
  }
  table tr { page-break-inside: avoid; page-break-after: auto; }
  table thead { display: table-header-group; }  /* يتكرر الـ header كل صفحة */

  table tr th, table tr td {
    border: 0.5pt solid #999 !important;
    padding: 5pt 6pt !important;
    text-align: right !important;
  }
  table tr th {
    background: #efece2 !important;
    color: #2b3d2a !important;
    font-weight: 700 !important;
  }
  table tr:nth-child(even) td {
    background: #fafaf6 !important;
  }

  /* —— Tags & badges —— */
  .tag {
    border: 0.5pt solid #999 !important;
    padding: 1pt 4pt !important;
    font-size: 9pt !important;
    display: inline-block !important;
  }
  .tag-green { background: #e8f3e8 !important; color: #1d5d1d !important; }
  .tag-amber { background: #fef3e0 !important; color: #8a5800 !important; }
  .tag-red   { background: #fbe5e0 !important; color: #8a2515 !important; }
  .tag-blue  { background: #e5edf8 !important; color: #1c3d80 !important; }
  .tag-gray  { background: #f0f0f0 !important; color: #555 !important; }

  /* —— Footer مخصّص —— */
  .scrollx { overflow: visible !important; }
  .tbl-wrap { overflow: visible !important; }

  /* —— Links: نخفي الـ URL underneath links —— */
  a { color: #000 !important; text-decoration: none !important; }
  a[href]:after { content: "" !important; }

  /* —— لمنع break داخل العناصر المهمة —— */
  .sec-head, .empty { page-break-inside: avoid; }
}
