/* FJMedia inquiry-form module — namespaced + token-driven so it drops into any
   client site without colliding. Brand tokens (--fj-*) are injected per client
   from form-config.brand; the values here are inert fallbacks. */

.fj-inquiry {
  /* brand tokens — overridden per client */
  --fj-paper: #fff;
  --fj-paper-2: #f4f4f5;
  --fj-ink: #1c1c22;
  --fj-muted: #6b6b76;
  --fj-accent: #d4467f;
  --fj-on-accent: #fff;
  --fj-rule: #e6e6ea;
  --fj-rule-2: #cfcfd6;
  --fj-error: oklch(55% 0.20 25);
  --fj-success: oklch(55% 0.13 150);
  --fj-font-display: inherit;
  --fj-font-body: inherit;
  /* fixed craft tokens */
  --fj-dur-fast: 120ms;
  --fj-dur-base: 240ms;
  --fj-ease-std: cubic-bezier(0.4, 0, 0.2, 1);
  --fj-r: 12px;
  --fj-h: 46px;

  font-family: var(--fj-font-body);
  color: var(--fj-ink);
  max-width: 640px;
  margin-inline: auto;
}
.fj-inquiry * { box-sizing: border-box; }

.fj-inquiry :focus { outline: none; }
.fj-inquiry :focus-visible { outline: 2px solid var(--fj-accent); outline-offset: 2px; border-radius: inherit; }
.fj-inquiry ::selection { background: var(--fj-accent); color: var(--fj-on-accent); }

.fj-head { margin-bottom: 2rem; }
.fj-head .fj-eyebrow { font: 700 12px/1 var(--fj-font-body); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fj-accent); margin: 0 0 0.6rem; }
.fj-head h1 { font: 400 clamp(2rem, 4vw + 1rem, 2.8rem)/1.05 var(--fj-font-display); text-wrap: balance; margin: 0 0 0.6rem; }
.fj-head p { color: var(--fj-muted); margin: 0; max-width: 52ch; }

.fj-inquiry fieldset {
  border: 1px solid var(--fj-rule); border-radius: var(--fj-r);
  padding: 2rem 1.5rem 1.5rem; margin: 0 0 1.5rem; position: relative; background: var(--fj-paper);
}
.fj-inquiry fieldset::before { content: ""; position: absolute; top: -1px; left: 1.5rem; right: 1.5rem; height: 3px; background: var(--fj-accent); border-radius: 0 0 3px 3px; }
.fj-inquiry legend { font: 700 13px/1 var(--fj-font-body); letter-spacing: 0.12em; text-transform: uppercase; color: var(--fj-muted); padding-inline: 0.5rem; margin-left: -0.5rem; }

.fj-field { margin-bottom: 1.5rem; }
.fj-field:last-child { margin-bottom: 0; }
.fj-lbl { display: block; font-weight: 600; margin-bottom: 0.5rem; }
.fj-lbl .fj-req { color: var(--fj-accent); margin-left: 2px; }

/* input recipe — 1px border every state, reserved outline slot, no layout shift */
.fj-input {
  display: block; width: 100%; height: var(--fj-h); padding: 0 0.85rem;
  font: 400 16px/1 var(--fj-font-body); color: var(--fj-ink); background: var(--fj-paper);
  border: 1px solid var(--fj-rule-2); border-radius: var(--fj-r);
  outline: 2px solid transparent; outline-offset: 1px;
  transition: background-color var(--fj-dur-fast) var(--fj-ease-std), border-color var(--fj-dur-fast) var(--fj-ease-std);
}
.fj-inquiry textarea.fj-input { height: auto; min-height: 6rem; padding: 0.85rem; resize: vertical; line-height: 1.6; }
.fj-input::placeholder { color: var(--fj-muted); }
@media (hover: hover) { .fj-input:hover { background: var(--fj-paper-2); } }
.fj-input:focus-visible { outline-color: var(--fj-accent); border-color: var(--fj-ink); }
.fj-input:disabled { opacity: 0.55; cursor: not-allowed; background: var(--fj-paper-2); }
.fj-input[aria-invalid="true"] { border-color: var(--fj-error); }

.fj-select-wrap { position: relative; }
.fj-select-wrap::after { content: ""; position: absolute; right: 0.85rem; top: 50%; width: 9px; height: 9px; margin-top: -6px; border-right: 2px solid var(--fj-muted); border-bottom: 2px solid var(--fj-muted); transform: rotate(45deg); pointer-events: none; }
select.fj-input { appearance: none; padding-right: 2rem; cursor: pointer; }

.fj-help { min-height: 1lh; margin-top: 0.5rem; font-size: 13px; color: var(--fj-muted); }
.fj-help.is-error { color: var(--fj-error); }

.fj-choices { display: flex; flex-wrap: wrap; gap: 0.5rem 1.5rem; }
.fj-choice { display: flex; align-items: center; gap: 0.5rem; cursor: pointer; min-height: 32px; }
.fj-choice input { accent-color: var(--fj-accent); width: 18px; height: 18px; cursor: pointer; }
.fj-check-grid { display: grid; grid-template-columns: minmax(0, 1fr); gap: 0.75rem; }
@media (min-width: 30rem) { .fj-check-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.fj-check-card { display: flex; align-items: flex-start; gap: 0.75rem; padding: 0.75rem; border: 1px solid var(--fj-rule); border-radius: var(--fj-r); cursor: pointer; transition: border-color var(--fj-dur-fast) var(--fj-ease-std), background-color var(--fj-dur-fast) var(--fj-ease-std); }
@media (hover: hover) { .fj-check-card:hover { background: var(--fj-paper-2); } }
.fj-check-card:has(input:checked) { border-color: var(--fj-accent); }
.fj-check-card:has(input:focus-visible) { outline: 2px solid var(--fj-accent); outline-offset: 2px; }
.fj-check-card input { accent-color: var(--fj-accent); width: 18px; height: 18px; margin-top: 2px; flex: none; }
.fj-check-card span { font-size: 14px; line-height: 1.45; }
.fj-check-card.fj-disabled { opacity: 0.5; cursor: not-allowed; }
.fj-check-card.fj-disabled input { cursor: not-allowed; }
.fj-hint { margin: -2px 0 12px; font-size: 13px; color: var(--fj-muted); }

.fj-file-field input[type="file"] { position: absolute; width: 1px; height: 1px; opacity: 0; }
.fj-file-label { display: flex; align-items: center; justify-content: center; gap: 0.5rem; min-height: var(--fj-h); padding: 0.85rem 1rem; border: 1px dashed var(--fj-rule-2); border-radius: var(--fj-r); color: var(--fj-muted); cursor: pointer; text-align: center; transition: border-color var(--fj-dur-fast) var(--fj-ease-std), background-color var(--fj-dur-fast) var(--fj-ease-std); }
@media (hover: hover) { .fj-file-label:hover { background: var(--fj-paper-2); border-color: var(--fj-accent); color: var(--fj-ink); } }
.fj-file-field input:focus-visible + .fj-file-label { outline: 2px solid var(--fj-accent); outline-offset: 2px; }
.fj-file-field.fj-dragging .fj-file-label { background: var(--fj-paper-2); border-color: var(--fj-accent); border-style: solid; color: var(--fj-ink); }
.fj-help.is-ok { color: var(--fj-success); font-weight: 600; }

/* photo previews — confirms each image was added, with remove */
.fj-file-previews { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 0.85rem; }
.fj-file-previews:empty { margin-top: 0; }
.fj-photo { position: relative; width: 88px; }
.fj-photo img { width: 88px; height: 88px; object-fit: cover; border-radius: var(--fj-r); border: 1px solid var(--fj-rule); display: block; }
.fj-photo-name { display: block; margin-top: 0.3rem; max-width: 88px; font-size: 11px; color: var(--fj-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fj-photo-rm { position: absolute; top: -7px; right: -7px; width: 22px; height: 22px; display: flex; align-items: center; justify-content: center; padding: 0; border: 2px solid var(--fj-paper); border-radius: 50%; background: var(--fj-ink); color: var(--fj-on-accent); font-size: 11px; line-height: 1; cursor: pointer; box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25); transition: background-color var(--fj-dur-fast) var(--fj-ease-std), transform var(--fj-dur-fast) var(--fj-ease-std); }
@media (hover: hover) { .fj-photo-rm:hover { background: var(--fj-accent); transform: scale(1.1); } }

/* button — all 8 states, single-line, press tick, loading spinner */
.fj-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
  min-height: var(--fj-h); padding: 0 2rem; font: 700 15px/1 var(--fj-font-body); white-space: nowrap;
  color: var(--fj-on-accent); background: var(--fj-accent); border: 1px solid var(--fj-accent);
  border-radius: var(--fj-r); cursor: pointer; width: 100%;
  transition: filter var(--fj-dur-fast) var(--fj-ease-std), transform var(--fj-dur-fast) var(--fj-ease-std);
}
@media (hover: hover) { .fj-btn:hover { filter: brightness(0.93); } }
.fj-btn:active { transform: translateY(1px); }
.fj-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.fj-btn .fj-spinner { width: 16px; height: 16px; border: 2px solid color-mix(in srgb, var(--fj-on-accent) 40%, transparent); border-top-color: var(--fj-on-accent); border-radius: 50%; display: none; }
.fj-btn .fj-l-loading, .fj-btn .fj-l-success, .fj-btn .fj-l-error { display: none; }
.fj-btn[data-state="loading"] .fj-spinner { display: inline-block; animation: fj-spin 0.7s linear infinite; }
.fj-btn[data-state="loading"] .fj-l-default { display: none; } .fj-btn[data-state="loading"] .fj-l-loading { display: inline; }
.fj-btn[data-state="success"] { background: var(--fj-success); border-color: var(--fj-success); }
.fj-btn[data-state="success"] .fj-l-default { display: none; } .fj-btn[data-state="success"] .fj-l-success { display: inline; }
.fj-btn[data-state="error"] { background: var(--fj-error); border-color: var(--fj-error); }
.fj-btn[data-state="error"] .fj-l-default { display: none; } .fj-btn[data-state="error"] .fj-l-error { display: inline; }
@keyframes fj-spin { to { transform: rotate(360deg); } }

@media (prefers-reduced-motion: reduce) {
  .fj-inquiry * { transition-duration: 0.01ms !important; }
  .fj-btn .fj-spinner { animation-duration: 1.2s; }
}
