/* ============================================================
   FLOATING CONTACT WIDGET · v1
   Bottom-right persistent FAB that opens a modal with:
     • click-to-call link
     • short lead-capture form (wired to Wix Headless via
       wix-headless.js — uses data-wix-form="lead").
   Visual DNA matches the rest of the site: dark, hairlined,
   gold accent (#d4a04a), Inter / JetBrains Mono.
   ============================================================ */

/* ─── FAB (collapsed state) ─── */
.fc-fab {
  position: fixed;
  right: clamp(16px, 2.4vw, 28px);
  bottom: clamp(16px, 2.4vw, 28px);
  z-index: 50;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 20px;
  border: 1px solid rgba(212, 160, 74, 0.45);
  background: #141412;
  color: #f2ede4;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 4px;
  box-shadow:
    0 18px 40px -20px rgb(0 0 0 / 0.85),
    0 2px 6px rgb(0 0 0 / 0.45);
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease;
  appearance: none;
  font-weight: 500;
}
.fc-fab:hover,
.fc-fab:focus-visible {
  border-color: rgba(212, 160, 74, 0.85);
  background: #1a1916;
  transform: translateY(-1px);
  outline: none;
}
.fc-fab:focus-visible {
  box-shadow:
    0 0 0 2px rgba(212, 160, 74, 0.55),
    0 18px 40px -20px rgb(0 0 0 / 0.85);
}
.fc-fab-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #d4a04a;
  color: #141412;
  font-size: 12px;
  font-family: var(--font-sans, system-ui);
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  line-height: 1;
}
.fc-fab-label--short { display: none; }

@media (max-width: 540px) {
  .fc-fab {
    padding: 12px 16px;
    font-size: 11px;
    letter-spacing: 0.14em;
  }
  .fc-fab-label--long { display: none; }
  .fc-fab-label--short { display: inline; }
}

/* ─── SCRIM (modal backdrop) ─── */
.fc-scrim {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: rgb(5 5 4 / 0.78);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(16px, 4vw, 32px);
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease;
}
.fc-scrim.is-open {
  opacity: 1;
  pointer-events: auto;
}

/* ─── MODAL CARD ─── */
.fc-modal {
  position: relative;
  width: min(520px, 100%);
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  background: #0e0e0c;
  border: 1px solid rgba(242, 237, 228, 0.12);
  border-radius: 4px;
  padding: clamp(24px, 3vw, 36px);
  color: #f2ede4;
  font-family: var(--font-sans, "Inter", system-ui);
  box-shadow: 0 40px 120px -40px rgb(0 0 0 / 0.9);
  transform: translateY(8px);
  transition: transform .22s ease;
}
.fc-scrim.is-open .fc-modal {
  transform: translateY(0);
}

.fc-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 4px;
  color: #f2ede4;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  transition: border-color .15s ease, color .15s ease;
}
.fc-close:hover,
.fc-close:focus-visible {
  border-color: rgba(242, 237, 228, 0.22);
  color: #d4a04a;
  outline: none;
}

.fc-eyebrow {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 10.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: #d4a04a;
  margin-bottom: 8px;
}
.fc-h {
  font-family: var(--font-display, "Fraunces", "Anton", serif);
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.1;
  letter-spacing: -0.005em;
  margin: 0 0 6px;
  font-weight: 600;
}
.fc-sub {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(242, 237, 228, 0.66);
  margin: 0 0 22px;
}

.fc-call {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  margin-bottom: 22px;
  border: 1px solid rgba(242, 237, 228, 0.12);
  border-radius: 4px;
  color: #f2ede4;
  text-decoration: none;
  transition: border-color .15s ease, background .15s ease;
}
.fc-call:hover,
.fc-call:focus-visible {
  border-color: rgba(212, 160, 74, 0.55);
  background: rgba(212, 160, 74, 0.04);
  outline: none;
}
.fc-call-l {
  display: flex;
  align-items: center;
  gap: 12px;
}
.fc-call-icon {
  font-size: 22px;
  line-height: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(212, 160, 74, 0.12);
  color: #d4a04a;
}
.fc-call-icon .icon-phone {
  width: 22px;
  height: 22px;
}
.fc-call-k {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(242, 237, 228, 0.55);
  display: block;
  margin-bottom: 2px;
}
.fc-call-v {
  font-size: 15px;
  letter-spacing: 0.01em;
  color: #f2ede4;
}
.fc-call-arrow {
  color: #d4a04a;
  font-size: 16px;
}

.fc-or {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 18px;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(242, 237, 228, 0.5);
}
.fc-or::before,
.fc-or::after {
  content: "";
  flex: 1;
  height: 1px;
  background: rgba(242, 237, 228, 0.12);
}

/* ─── FORM ─── */
.fc-form { display: grid; gap: 14px; }
.fc-form label {
  display: block;
  font-size: 13px;
}
.fc-k {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(242, 237, 228, 0.55);
  margin-bottom: 6px;
  display: block;
}
.fc-form input,
.fc-form textarea {
  width: 100%;
  padding: 10px 12px;
  background: #141412;
  border: 1px solid rgba(242, 237, 228, 0.14);
  border-radius: 3px;
  color: #f2ede4;
  font-family: var(--font-sans, "Inter", system-ui);
  font-size: 14.5px;
  line-height: 1.4;
  transition: border-color .15s ease, background .15s ease;
}
.fc-form input:focus,
.fc-form textarea:focus {
  outline: none;
  border-color: rgba(212, 160, 74, 0.65);
  background: #17170f;
}
.fc-form textarea {
  resize: vertical;
  min-height: 84px;
}
.fc-row {
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 440px) {
  .fc-row { grid-template-columns: 1fr; }
}

.fc-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: 6px;
}
.fc-submit {
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: #d4a04a;
  color: #141412;
  border: 1px solid #d4a04a;
  border-radius: 3px;
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.fc-submit:hover,
.fc-submit:focus-visible {
  background: #e6b160;
  outline: none;
}
.fc-form.is-loading .fc-submit { opacity: 0.6; pointer-events: none; }

.fc-status {
  font-family: var(--font-mono, "JetBrains Mono", monospace);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: rgba(242, 237, 228, 0.6);
  min-height: 1.2em;
}
.fc-form.is-success .fc-status { color: #9dd29d; }
.fc-form.is-error .fc-status { color: #e67c7c; }
.fc-form.is-success .fc-fields,
.fc-form.is-success .fc-actions .fc-submit { display: none; }

/* ─── REDUCED MOTION ─── */
@media (prefers-reduced-motion: reduce) {
  .fc-scrim,
  .fc-modal,
  .fc-fab { transition: none; }
}

/* ─── PRINT — never print the FAB ─── */
@media print {
  .fc-fab,
  .fc-scrim { display: none !important; }
}
