/* =====================================================================
 * components.css — central shared UI component library
 * ---------------------------------------------------------------------
 * The single source of truth for the APP/ADMIN UI layer (buttons, cards,
 * form fields, pills, tables, modals, icons). Built entirely on the design
 * tokens in style.css (:root). Use these `ui-*` classes instead of
 * re-inventing per-file styles or inline styles.
 *
 * NOTE: the large marketing CTA `.btn-primary` (style.css) is intentionally
 * kept separate — it's the hero/landing button. `.ui-btn` is the compact,
 * consistent button for application & admin surfaces.
 * ===================================================================== */

/* ── Buttons ───────────────────────────────────────────────────────── */
.ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 10px 18px;
  border-radius: var(--radius-btn);
  font-family: var(--font);
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.2;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: var(--transition);
}
.ui-btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}
.ui-btn:disabled,
.ui-btn[disabled] {
  opacity: 0.55;
  cursor: not-allowed;
}
.ui-btn--primary {
  background: var(--blue);
  color: #fff;
}
.ui-btn--primary:hover {
  background: var(--blue-dark);
}
.ui-btn--secondary {
  background: #fff;
  color: var(--dark);
  border-color: var(--border);
}
.ui-btn--secondary:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.ui-btn--ghost {
  background: transparent;
  color: var(--dark);
  border-color: var(--border);
}
.ui-btn--ghost:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.ui-btn--danger {
  background: var(--red-light);
  color: #991b1b;
  border-color: #fecaca;
}
.ui-btn--danger:hover {
  background: #fee2e2;
}
.ui-btn--sm {
  padding: 6px 12px;
  font-size: 0.82rem;
  gap: var(--space-1);
}
.ui-btn--pill {
  border-radius: var(--radius-pill);
}
.ui-btn--block {
  width: 100%;
}

/* Round icon action button (table row actions etc.) */
.ui-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-btn);
  border: 1px solid var(--border);
  background: #fff;
  color: var(--gray);
  cursor: pointer;
  transition: var(--transition);
}
.ui-icon-btn:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.ui-icon-btn.is-danger:hover {
  border-color: var(--red);
  color: var(--red);
}

/* ── Cards ─────────────────────────────────────────────────────────── */
.ui-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: var(--transition);
}
.ui-card--pad {
  padding: var(--space-5) var(--space-6);
}
.ui-card--muted {
  background: var(--bg-light);
}
.ui-card--hover:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow);
  border-color: var(--blue);
}

/* ── Form fields ───────────────────────────────────────────────────── */
.ui-field {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--dark);
}
.ui-field > input,
.ui-field > select,
.ui-field > textarea,
.ui-input,
.ui-select,
.ui-textarea {
  width: 100%;
  box-sizing: border-box;
  margin-top: var(--space-2);
  padding: 11px 14px;
  border: 2px solid var(--border);
  border-radius: var(--radius-btn);
  font-family: var(--font);
  font-size: 0.95rem;
  color: var(--dark);
  background: #fff;
}
.ui-field > textarea,
.ui-textarea {
  resize: vertical;
  line-height: 1.7;
}
.ui-field > select,
.ui-select {
  cursor: pointer;
}
.ui-field > input:focus-visible,
.ui-field > select:focus-visible,
.ui-field > textarea:focus-visible,
.ui-input:focus-visible,
.ui-select:focus-visible,
.ui-textarea:focus-visible {
  outline: none;
  border-color: var(--blue);
  box-shadow: var(--focus-ring);
}
.ui-checkline {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: 0.9rem;
  font-weight: 600;
  min-height: 44px;
}
.ui-checkline input {
  width: 17px;
  height: 17px;
  flex: none;
  accent-color: var(--blue);
}
.ui-hint {
  display: block;
  color: var(--gray-light);
  font-size: 0.75rem;
  font-weight: 400;
  margin-top: var(--space-1);
}
.ui-req {
  color: var(--red);
}
.ui-form-error {
  background: var(--red-light);
  color: #a82a2f;
  border: 1px solid #ffd6d8;
  border-right: 4px solid var(--red);
  border-radius: var(--radius-btn);
  padding: var(--space-3) var(--space-4);
  font-size: 0.9rem;
}
.ui-form-success {
  background: var(--green-light);
  color: #0a7d4f;
  border: 1px solid #b6ecd3;
  border-right: 4px solid var(--green);
  border-radius: var(--radius-btn);
  padding: var(--space-3) var(--space-4);
  font-size: 0.9rem;
}

/* ── Pills / chips / status badges ─────────────────────────────────── */
.ui-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 12px;
  border-radius: var(--radius-pill);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.6;
}
.ui-pill--blue {
  background: var(--blue-light);
  color: var(--blue);
}
.ui-pill--green {
  background: var(--green-light);
  color: #166534;
}
.ui-pill--red {
  background: var(--red-light);
  color: #991b1b;
}
.ui-pill--gray {
  background: #f3f4f6;
  color: #374151;
}
.ui-pill--gold {
  background: #fef9c3;
  color: #854d0e;
}
.ui-pill--purple {
  background: #ede9fe;
  color: #5b21b6;
}

/* ── Data table ────────────────────────────────────────────────────── */
.ui-table-wrap {
  overflow-x: auto;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 4px;
}
.ui-table {
  width: 100%;
  border-collapse: collapse;
}
.ui-table th {
  font-size: 0.78rem;
  color: var(--gray);
  font-weight: 600;
  text-align: right;
  padding: 12px 14px;
  border-bottom: 2px solid var(--border);
  white-space: nowrap;
}
.ui-table td {
  padding: 12px 14px;
  border-bottom: 1px solid #f0f0f0;
  font-size: 0.875rem;
  vertical-align: middle;
}
.ui-table tbody tr:last-child td {
  border-bottom: none;
}
.ui-table tbody tr:hover td {
  background: var(--bg-light);
}

/* ── Modal ─────────────────────────────────────────────────────────── */
.ui-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.ui-modal {
  background: #fff;
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-lg);
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
  padding: var(--space-6);
}

/* ── Section heading with icon tile ────────────────────────────────── */
.ui-section-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.ui-section-head h2 {
  font-size: 1.25rem;
  font-weight: 800;
  margin: 0;
  color: var(--dark);
}
.ui-icon-tile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: var(--radius-md);
  background: var(--blue-light);
  color: var(--blue);
  flex: none;
}

/* ── Icon sizing (SVGs use stroke=currentColor) ────────────────────── */
.ui-icon {
  width: 22px;
  height: 22px;
  flex: none;
}
.ui-icon-sm {
  width: 15px;
  height: 15px;
  flex: none;
  vertical-align: -2px;
}
.ui-icon-lg {
  width: 32px;
  height: 32px;
  flex: none;
}

/* ── Toast ─────────────────────────────────────────────────────────── */
.ui-toast-host {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10000;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  pointer-events: none;
}
.ui-toast {
  background: var(--green);
  color: #fff;
  padding: 12px 20px;
  border-radius: var(--radius-btn);
  font-weight: 600;
  font-size: 0.95rem;
  box-shadow: var(--shadow);
  pointer-events: auto;
}
.ui-toast.is-error {
  background: #c0392b;
}

/* ── Form layout (shared by admin forms) ───────────────────────────── */
.ui-form {
  max-width: 880px;
}
.ui-form input[type='text'],
.ui-form input[type='url'],
.ui-form input[type='date'],
.ui-form input[type='datetime-local'],
.ui-form input[type='number'],
.ui-form input[type='password'],
.ui-form input[type='file'],
.ui-form select,
.ui-form textarea {
  width: 100%;
  box-sizing: border-box;
  margin-top: var(--space-2);
  padding: 11px 14px;
  border: 2px solid var(--border);
  border-radius: var(--radius-btn);
  font-family: var(--font);
  font-size: 0.95rem;
  color: var(--dark);
  background: #fff;
}
.ui-form select {
  cursor: pointer;
}
.ui-form textarea {
  resize: vertical;
  line-height: 1.7;
}
.ui-form input:focus-visible,
.ui-form select:focus-visible,
.ui-form textarea:focus-visible {
  outline: none;
  border-color: var(--blue);
  box-shadow: var(--focus-ring);
}
.ui-form label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--dark);
}
.ui-fieldset {
  border: 1px solid var(--border);
  background: #fff;
  border-radius: var(--radius-sm);
  padding: var(--space-5) var(--space-6) var(--space-6);
  margin: 0 0 var(--space-5);
}
.ui-fieldset legend {
  font-weight: 700;
  padding: 0 var(--space-3);
  color: var(--blue);
  font-size: 1rem;
}
.ui-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--space-4) 18px;
  align-items: start;
}
.ui-block {
  margin-top: var(--space-4);
}
.ui-form-actions {
  display: flex;
  gap: var(--space-3);
  margin-top: var(--space-5);
  align-items: center;
}

/* ── Misc shared bits ──────────────────────────────────────────────── */
.ui-note {
  color: var(--gray);
  font-size: 0.875rem;
  margin: 0 0 18px;
  line-height: 1.7;
}
.ui-state-box {
  padding: var(--space-7) var(--space-5);
  text-align: center;
  color: var(--gray);
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.ui-link-btn {
  background: none;
  border: none;
  color: var(--blue);
  cursor: pointer;
  font-weight: 600;
  text-decoration: underline;
  font-size: 0.8rem;
  font-family: var(--font);
  padding: 0;
}

/* Quill rich-text editor, RTL — shared by admin forms (Quill ships LTR) */
.ui-form .ql-toolbar.ql-snow {
  direction: ltr;
  border-radius: var(--radius-btn) var(--radius-btn) 0 0;
  border: 2px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--bg-light);
  margin-top: var(--space-2);
}
.ui-form .ql-container.ql-snow {
  direction: rtl;
  border: 2px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--radius-btn) var(--radius-btn);
  font-family: var(--font);
  font-size: 0.9rem;
  background: #fff;
}
.ui-form .ql-editor {
  direction: rtl;
  text-align: right;
  min-height: 150px;
  line-height: 1.8;
  padding: 14px 16px;
}
.ui-form .ql-editor.ql-blank::before {
  right: 16px;
  left: auto;
  font-style: normal;
  color: var(--gray-light);
}

/* ── File upload / picker (single source of truth) ─────────────────────
 * Legacy class names (.admin-file-upload, .jp-cv-drop) are grouped here so
 * existing markup adopts the unified look without per-file CSS. New code
 * should use .ui-upload. */
.ui-upload,
.admin-file-upload,
.jp-cv-drop {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 14px 16px;
  border: 2px dashed var(--border);
  border-radius: var(--radius-md);
  background: var(--bg-light);
  cursor: pointer;
  transition: var(--transition);
  font-size: 0.88rem;
  color: var(--gray);
}
.ui-upload:hover,
.admin-file-upload:hover,
.jp-cv-drop:hover {
  border-color: var(--blue);
  background: var(--blue-light);
  color: var(--blue);
}
.ui-upload:focus-within,
.admin-file-upload:focus-within,
.jp-cv-drop:focus-within {
  outline: none;
  border-color: var(--blue);
  box-shadow: var(--focus-ring);
}
.ui-upload input[type='file'],
.admin-file-upload input[type='file'],
.jp-cv-drop input[type='file'] {
  display: none;
}
.ui-upload-ic {
  display: inline-flex;
  color: var(--blue);
  flex: none;
}
.ui-upload-text,
.admin-file-upload .file-name {
  font-weight: 500;
  color: var(--dark);
}
.ui-upload-text b {
  color: var(--blue);
}
.ui-upload.has-file {
  border-style: solid;
  border-color: var(--green);
  background: var(--green-light);
}
.ui-upload-file {
  margin-inline-start: auto;
  font-size: 0.8rem;
  color: var(--green);
  font-weight: 600;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ui-upload-hint {
  display: block;
  color: var(--gray-light);
  font-size: 0.75rem;
  margin-top: var(--space-1);
}

/* ── Spinner ───────────────────────────────────────────────────────── */
.ui-spinner {
  width: 34px;
  height: 34px;
  border: 3px solid var(--border);
  border-top-color: var(--blue);
  border-radius: 50%;
  animation: uiSpin 0.8s linear infinite;
}
@keyframes uiSpin {
  to {
    transform: rotate(360deg);
  }
}
