/* ════════════════════════════════════════════════════════════════════
   COMPONENTS — buttons, eyebrows, spec lines, cards, pills, tags
   ──────────────────────────────────────────────────────────────────── */

/* ─── Buttons ─── */
.btn {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.005em;
  border: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  white-space: nowrap;
  padding: 12px 22px;
  font-size: 14px;
  border-radius: 6px;
  background: var(--accent);
  color: var(--accent-foreground);
  transition: background var(--dur-fast) var(--ease-forge),
              color var(--dur-fast) var(--ease-forge),
              border-color var(--dur-fast) var(--ease-forge),
              transform var(--dur-fast) var(--ease-forge);
}

.btn:hover { background: var(--accent-hover); }

.btn--sm { padding: 8px 14px; font-size: 13px; }
.btn--lg { padding: 16px 28px; font-size: 15px; }

.btn--navy   { background: var(--navy); color: var(--bone); }
.btn--navy:hover { background: var(--carbon); }
.btn--bone   { background: var(--bone); color: var(--navy); }
.btn--bone:hover { background: var(--bone-2); }
.btn--border {
  background: transparent;
  color: var(--navy);
  border: 1px solid var(--ink-5);
}
.btn--border:hover { border-color: var(--navy); background: transparent; }
.btn--border-dark {
  background: transparent;
  color: var(--bone);
  border: 1px solid rgba(250,250,248,0.24);
}
.btn--border-dark:hover { border-color: rgba(250,250,248,0.5); background: rgba(250,250,248,0.04); }
.btn--flat {
  background: var(--accent-soft);
  color: var(--accent);
}
.btn--ghost {
  background: transparent;
  color: var(--accent);
  padding: 0;
}
.btn--block { width: 100%; justify-content: center; }

.btn .icon { flex-shrink: 0; }

/* Magnetic wrapper — vanilla JS adds .is-pulled with transform */
.magnetic {
  display: inline-block;
  transition: transform 380ms var(--ease-forge);
}
.magnetic > * {
  transition: transform 120ms var(--ease-forge);
  display: inline-flex;
}

/* ─── Eyebrow / SpecLine ─── */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--ink-3);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.eyebrow::before {
  content: "";
  width: 24px; height: 1px;
  background: currentColor;
  opacity: 0.5;
}
.eyebrow--no-rule::before { display: none; }
.eyebrow--muted { color: var(--muted); letter-spacing: 0.14em; }

.spec-line {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.section--navy .spec-line { color: rgba(250,250,248,0.55); }

.section-number {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-3);
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}
.section-number::before {
  content: attr(data-n);
}
.section-number > span:first-child {
  flex: 1; height: 1px;
  background: var(--ink-5);
  max-width: 48px;
  display: inline-block;
}

/* ─── Forge Seal mark ─── */
.forge-seal {
  display: inline-block;
  flex-shrink: 0;
}

/* ─── Card primitives ─── */
.card {
  background: var(--bone);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 26px 28px 28px;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: border-color 200ms var(--ease-forge),
              transform 200ms var(--ease-forge),
              box-shadow 500ms var(--ease-forge);
}
.card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}
.card--cloud { background: var(--cloud); }
.card--lift:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-3);
}
.card--lift-lg:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-card-hover);
}

/* ─── Pill / chip ─── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-radius: 999px;
  background: var(--cloud);
  border: 1px solid var(--border);
}
.chip__dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--verdigris);
  flex-shrink: 0;
}
.chip__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
}
.chip__meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* ─── Bullet list with check ─── */
.bullet-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.bullet-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-2);
}
.bullet-list li::before {
  content: "";
  width: 14px; height: 14px;
  flex-shrink: 0;
  margin-top: 4px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 256 256' fill='%231E3454'%3E%3Cpath d='M229.66,77.66l-128,128a8,8,0,0,1-11.32,0l-56-56a8,8,0,0,1,11.32-11.32L96,188.69,218.34,66.34a8,8,0,0,1,11.32,11.32Z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
}

/* ─── Quote block ─── */
.quote {
  padding: 32px 36px;
  background: var(--cloud);
  border: 1px solid var(--border);
  border-radius: 8px;
}
.quote__text {
  font-size: 20px;
  font-family: var(--font-sans);
  font-weight: 500;
  color: var(--navy);
  line-height: 1.45;
  letter-spacing: -0.015em;
  margin-bottom: 12px;
  text-wrap: pretty;
}
.quote--accent {
  background: var(--cloud);
  border: 1px solid var(--accent);
}
.quote--display .quote__text {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 22px;
  letter-spacing: -0.015em;
}

/* ─── Photo wrapper ─── */
.photo {
  position: relative;
  overflow: hidden;
  background: var(--navy);
  border-radius: inherit;
}
.photo svg, .photo img { width: 100%; height: 100%; display: block; object-fit: cover; }
.photo--rounded { border-radius: 16px; }
.photo--rounded-sm { border-radius: 8px; }

/* ─── Arrow circle (used in card CTAs) ─── */
.arrow-circle {
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 1px solid var(--accent);
  display: grid;
  place-items: center;
  color: var(--accent);
  transition: transform 380ms var(--ease-forge);
}
.card-link:hover .arrow-circle,
.card:hover .arrow-circle { transform: translateX(4px) rotate(-45deg); }

/* ─── Arrow nav buttons (gallery/carousel) ─── */
.arrow-btn {
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid var(--navy);
  background: var(--bone);
  color: var(--navy);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 240ms var(--ease-forge);
}
.arrow-btn:hover { background: var(--navy); color: var(--bone); }

/* ─── Inline icon ─── */
.icon {
  display: inline-block;
  vertical-align: -0.125em;
  flex-shrink: 0;
}

/* Inline-flex utility for "label + arrow" link patterns */
.inline-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  transition: transform 380ms var(--ease-forge);
}
.inline-link:hover { transform: translateX(4px); }
.inline-link--mono {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  font-weight: 500;
}

/* ─── Tag (small pill, "Featured" / "New" / etc.) ─── */
.tag {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 3px 10px;
  border-radius: 2px;
  background: var(--accent);
  color: var(--bone);
}
.tag--ghost-light {
  background: rgba(250,250,248,0.1);
  color: var(--bone);
}
.tag--sand {
  background: rgba(255, 190, 11, 0.18);
  color: var(--ink-1);
  border: 1px solid rgba(255, 190, 11, 0.45);
}

/* ─── Form field component ─── */
.form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.form-field__label {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--ink-1);
  letter-spacing: -0.005em;
  display: flex;
  align-items: center;
  gap: 6px;
}
.form-field__required {
  color: var(--accent);
  font-weight: 400;
}
.form-field__hint {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 400;
  color: var(--ink-3);
  margin-top: -4px;
}
.form-field__input,
.form-field__textarea,
.form-field__select {
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 400;
  color: var(--ink-1);
  padding: 12px 14px;
  background: var(--bone-2);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  width: 100%;
  transition: border-color 180ms var(--ease-forge);
}
.form-field__input::placeholder,
.form-field__textarea::placeholder { color: var(--ink-4); }
.form-field__input:focus-visible,
.form-field__textarea:focus-visible,
.form-field__select:focus-visible {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
  border-color: var(--ink-1);
}
.form-field__textarea { min-height: 120px; resize: vertical; line-height: 1.5; }

.form-field--invalid .form-field__input,
.form-field--invalid .form-field__textarea,
.form-field--invalid .form-field__select { border-color: var(--signal); }
.form-field__error {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--signal);
  display: none;
}
.form-field--invalid .form-field__error { display: block; }

.form-field__input:disabled,
.form-field__textarea:disabled,
.form-field__select:disabled { opacity: 0.5; cursor: not-allowed; }

/* Form status — driven by Pageclip's .pageclip-form--success / --error classes added to the parent <form> on submit response. */
.form-status {
  font-family: var(--font-sans);
  font-size: 14px;
  padding: 12px 14px;
  border-radius: var(--r-md);
  margin-top: 12px;
  display: none;
}
.pageclip-form--success .form-status {
  display: block;
  background: rgba(39, 174, 96, 0.08);
  color: var(--verdigris);
  border: 1px solid var(--verdigris);
}
.pageclip-form--error .form-status {
  display: block;
  background: rgba(229, 62, 62, 0.08);
  color: var(--signal);
  border: 1px solid var(--signal);
}
.form-status__msg { display: none; }
.pageclip-form--success .form-status__msg--success { display: block; }
.pageclip-form--error .form-status__msg--error { display: block; }

/* Pageclip submit-button spinner — match our .btn sizing so the loader doesn't cause height jump */
.pageclip-form__submit { position: relative; }
.pageclip-form__submit > span { display: inline-flex; align-items: center; gap: 8px; }

/* Form companions used by contact / newsletter / pricing-calculator pages */
.cr-comp__form {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 14px;
}
.cr-comp__submit { align-self: flex-start; margin-top: 8px; }
.cr-comp__legal { margin: 0; }
.cr-comp__legal-link { color: var(--accent); }

.newsletter-form {
  max-width: 560px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 24px;
  background: var(--bone);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.newsletter-form__hint {
  font-size: 12px;
  color: var(--ink-3);
  line-height: 1.5;
  margin: 4px 0 0;
}
