/* Global design system: colors, typography, components (Hebrew RTL) */

:root {
  /* Brand colors */
  --color-action-green: #198754; /* primary */
  --color-action-orange: #ffc107; /* secondary/edit */
  --color-action-blue: #0d6efd; /* tertiary/view */
  --color-action-red: #dc3545; /* danger */
  --color-bg: #ffffff; /* background */

  /* Shadows and radius */
  --radius-lg: 8px; /* rounded-lg */
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);

  /* Spacing tokens */
  --space-4: 1rem;   /* 16px */
  --space-6: 1.5rem; /* 24px */

  /* Sizes */
  --btn-height: 40px; /* h-10 */
}

html[dir="rtl"] body {
  background-color: #f8fafc; /* light gray background */
  color: #111827; /* gray-900 */
  font-family: 'Heebo', Arial, sans-serif;
}

/* Cards */
.card {
  background: var(--color-bg);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
}
.card--p {
  padding: var(--space-4);
}

/* Buttons */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; padding: .5rem 1rem; height: var(--btn-height); border-radius: var(--radius-lg); color: #fff; font-weight: 600; }
.btn--primary { background-color: var(--color-action-green); }
.btn--success { background-color: var(--color-action-green); }
.btn--secondary { background-color: var(--color-action-orange); color: #1f2937; }
.btn--warning { background-color: var(--color-action-orange); color: #1f2937; }
.btn--tertiary { background-color: var(--color-action-blue); }
.btn--info { background-color: var(--color-action-blue); }
.btn--danger { background-color: var(--color-action-red); }
.btn:disabled { opacity: .6; cursor: not-allowed; }

/* Table header */
.table-head { background-color: #f8f9fa; font-weight: 700; }

/* Inputs */
.input { width: 100%; border: 1px solid #ced4da; padding: 0.5rem 0.75rem; border-radius: 6px; }
.input--error { border-color: var(--color-action-red); background: #fff5f6; }
.help-error { color: var(--color-action-red); font-size: .8125rem; margin-top: .25rem; }
.label-required::after { content: " *"; color: var(--color-action-red); font-weight: 700; }

/* Django errorlist */
.errorlist { list-style: none; padding: 0; margin: .25rem 0 0; color: var(--color-action-red); font-size: .8125rem; }
.errorlist li { margin: 0; }

/* Badges */
.badge { display: inline-block; padding: .125rem .5rem; border-radius: 9999px; font-size: .75rem; font-weight: 600; }
.badge--success { background: rgba(25, 135, 84, 0.12); color: var(--color-action-green); }
.badge--danger { background: rgba(220, 53, 69, 0.12); color: var(--color-action-red); }
.badge--muted { background: #f1f5f9; color: #475569; }

/* Warning flash (orange pulse) */
.flash { color: var(--color-action-orange); }

/* Layout helpers */
.container { max-width: 80rem; margin-inline: auto; padding-inline: 1rem; }
.section { margin-bottom: var(--space-6); }

/* Vertical stack helper */
.stack-lg > * + * { margin-top: var(--space-6); }

/* Add gap between adjacent sections */
.section + .section { margin-top: var(--space-6); }

/* Responsive helpers for card list in mobile */
@media (max-width: 768px) {
  .list--cards > * { margin-bottom: 1rem; }
}

/* Radio as pills */
.radio-pills { display: flex; flex-wrap: wrap; gap: .5rem; }
.radio-pills label { position: relative; display: inline-flex; align-items: center; gap: .5rem; padding: .375rem .875rem; border-radius: 9999px; border: 1px solid #ced4da; cursor: pointer; user-select: none; }
.radio-pills label input[type="radio"] { position: absolute; inset: 0; opacity: 0; width: 100%; height: 100%; cursor: pointer; }
.radio-pills label:has(input[type="radio"]:checked) { background: var(--color-action-green); border-color: var(--color-action-green); color: #fff; }
.radio-pills label:hover { border-color: #94a3b8; }

/* Calendar holiday background (FullCalendar) */
.holiday-bg { background-color: #fff7e6 !important; color: #7c4a00 !important; font-size: 10px; }
