/* ── forms.css ────────────────────────────────────────────────────────────────
   Shared form field styles used by profile, itinerary edit, and auth templates.
   ────────────────────────────────────────────────────────────────────────── */

/* ── Form grid ───────────────────────────────────────────────────── */
.form-row { display: grid; gap: 1rem; margin-bottom: 1rem; }
.form-row.cols-2 { grid-template-columns: 1fr 1fr; }
.form-row.cols-3 { grid-template-columns: 1fr 1fr 1fr; }
.form-row.cols-4 { grid-template-columns: 1fr 1fr 1fr 1fr; }
@media (max-width: 600px) {
  .form-row.cols-2,
  .form-row.cols-3,
  .form-row.cols-4 { grid-template-columns: 1fr; }
}

/* ── Field ───────────────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: .3rem; }

.field label {
  font-size: .78rem;
  font-weight: 600;
  color: var(--c-text);
  letter-spacing: .01em;
}
.field label .req { color: var(--c-danger); margin-left: 2px; }

.field-help {
  font-size: .72rem;
  color: var(--c-text-muted);
  margin-top: .15rem;
}

.field-error { font-size: .75rem; color: var(--c-danger); margin-top: .2rem; }

/* ── Inputs ──────────────────────────────────────────────────────── */
input.form-input,
select.form-select,
textarea.form-input {
  font-family: var(--font-body);
  font-size: .875rem;
  color: var(--c-text);
  background: var(--c-white);
  border: 1.5px solid var(--c-grey-light);
  border-radius: var(--radius-sm);
  padding: .55rem .8rem;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  width: 100%;
}
input.form-input:focus,
select.form-select:focus,
textarea.form-input:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px rgba(43,76,126,.08);
}
select.form-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7A8D' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .75rem center;
  padding-right: 2rem;
}
textarea.form-input { resize: vertical; min-height: 70px; }

/* ── Checkbox row ────────────────────────────────────────────────── */
.check-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .85rem;
  color: var(--c-text);
  cursor: pointer;
}
.check-row input[type=checkbox] {
  width: 15px;
  height: 15px;
  accent-color: var(--c-primary);
  margin: 0;
  cursor: pointer;
}

/* ── Currency / money input group ────────────────────────────────── */
.money-input-group { display: flex; align-items: stretch; }

.currency-picker { position: relative; flex-shrink: 0; }

.currency-symbol-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3px;
  padding: .55rem .55rem .55rem .75rem;
  background: #eef1f8;
  border: 1.5px solid var(--c-grey-light);
  border-right: none;
  border-radius: var(--radius-sm) 0 0 var(--radius-sm);
  font-size: .82rem;
  font-weight: 700;
  color: var(--c-text);
  min-width: 4.5rem;
  pointer-events: none;
  user-select: none;
  white-space: nowrap;
  line-height: 1;
}
.currency-symbol-btn::after {
  content: '';
  display: inline-block;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 4px solid var(--c-text-muted);
  margin-left: 1px;
  flex-shrink: 0;
}

.currency-picker select {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: pointer;
  appearance: none;
  border: none;
  padding: 0;
  margin: 0;
}

.money-input-group input.form-input {
  border-left: 1px solid var(--c-grey-light) !important;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
  flex: 1;
  min-width: 0;
}

.currency-picker:focus-within .currency-symbol-btn {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px rgba(43,76,126,.08);
}

.money-input-group input.form-input:focus {
  border-left-color: var(--c-primary) !important;
}

/* ── Non-field errors ────────────────────────────────────────────── */
.non-field-errors {
  background: #fee2e2;
  border: 1px solid #fca5a5;
  border-radius: var(--radius-sm);
  padding: .7rem 1rem;
  margin-bottom: 1rem;
  font-size: .85rem;
  color: var(--c-danger);
}

/* ── Form-level error summary (create/edit forms) ────────────────── */
.form-error-summary {
  background: #fee2e2;
  border: 1px solid #fca5a5;
  border-radius: var(--radius-sm);
  padding: .7rem 1rem .7rem 1.1rem;
  margin-bottom: 1.25rem;
  font-size: .85rem;
  color: var(--c-danger);
}
.form-error-summary strong {
  display: block;
  margin-bottom: .35rem;
  font-weight: 600;
}
.form-error-summary ul {
  margin: 0;
  padding-left: 1.1rem;
}
.form-error-summary li {
  margin-bottom: .2rem;
}
.form-error-summary a {
  color: var(--c-danger);
  text-decoration: underline;
}

/* ── Form help text ─────────────────────────────────────────────── */
.form-help {
  margin-top: .5rem;
  font-size: .82rem;
  color: var(--c-text-muted);
}

/* ── Form submit/action bar ─────────────────────────────────────── */
.form-submit-bar {
  margin-top: 1.5rem;
  display: flex;
  gap: .75rem;
  align-items: center;
  flex-wrap: wrap;
}

/* ── Save / action buttons ───────────────────────────────────────── */
.btn-save {
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 600;
  padding: .65rem 1.5rem;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  transition: background .15s;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--c-primary);
  color: #fff;
}
.btn-save:hover { background: var(--c-primary-dark); }
