/* ==========================================================================
   Shared components — Febus
   Layered on top of theme.css (base + tokens). Markup is generated by the
   Nunjucks macros in _includes/components/ui.njk. Class-based so source order
   relative to the base element styles doesn't matter.
   ========================================================================== */

/* --- Eyebrow ------------------------------------------------------------- */
.eyebrow {
  color: var(--accent-2);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 0 0 0.75rem;
}

/* --- Section header ------------------------------------------------------ */
.section-head { max-width: 60ch; margin-bottom: 2.5rem; }
.section-head__lead { font-size: 1.15rem; color: var(--ink-dim); margin: 0; }
.section-head--center { margin-inline: auto; text-align: center; }

/* --- Responsive grid ----------------------------------------------------- */
.grid {
  display: grid;
  gap: clamp(1rem, 2.5vw, 1.75rem);
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17rem), 1fr));
}
.grid--2 { grid-template-columns: repeat(auto-fit, minmax(min(100%, 22rem), 1fr)); }

/* --- Card ---------------------------------------------------------------- */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.card__icon { font-size: 1.75rem; line-height: 1; }
.card__title { margin: 0; }
.card__body { margin: 0; }
.card__link {
  margin-top: auto;
  padding-top: 0.4rem;
  color: var(--accent-2);
  font-family: var(--font-display);
  font-weight: 600;
}
.card--link { transition: transform 0.2s var(--ease), border-color 0.2s var(--ease); }
.card--link:hover { transform: translateY(-3px); border-color: var(--accent-2); }

/* --- Stat ---------------------------------------------------------------- */
.stat { display: flex; flex-direction: column; gap: 0.15rem; }
.stat__value {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(2rem, 4vw, 2.75rem);
  color: var(--ink);
  line-height: 1;
}
.stat__label { color: var(--ink-dim); font-size: 0.9rem; }

/* --- Pill ---------------------------------------------------------------- */
.pill {
  display: inline-block;
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--bg-soft);
  color: var(--ink-dim);
  font-size: 0.8rem;
  font-weight: 500;
}

/* --- Steps (numbered process) ------------------------------------------- */
.steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1.25rem;
}
.step { display: flex; gap: 1rem; align-items: flex-start; }
.step__n {
  flex: 0 0 auto;
  width: 2.5rem;
  height: 2.5rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  border: 1px solid var(--accent-2);
  color: var(--ink);
  font-family: var(--font-display);
  font-weight: 700;
}
.step__content { padding-top: 0.15rem; }
.step__title { margin: 0 0 0.25rem; }
.step__content p { margin: 0; }

/* --- Tick list (deliverables, plan features) ----------------------------- */
.ticklist {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.65rem;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 18rem), 1fr));
}
.ticklist li {
  position: relative;
  padding-left: 1.8rem;
  color: var(--ink-dim);
}
.ticklist li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--accent-2);
  font-weight: 700;
}

/* --- FAQ (native <details>) ---------------------------------------------- */
.faq { display: grid; gap: 0.75rem; max-width: 70ch; }
.faq__item {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--card);
  padding: 0 1.1rem;
}
.faq__item summary {
  cursor: pointer;
  padding: 1rem 0;
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--ink);
  list-style: none;
}
.faq__item summary::-webkit-details-marker { display: none; }
.faq__item[open] summary { color: var(--accent-2); }
.faq__item p { margin: 0 0 1rem; }

/* --- Service detail hero ------------------------------------------------- */
.service-hero__back { margin: 0 0 1.25rem; font-size: 0.9rem; }
.service-hero__back a { color: var(--ink-dim); }
.service-hero__back a:hover { color: var(--accent-2); }
.service-hero__tagline { font-size: 1.25rem; color: var(--ink-dim); max-width: 52ch; }
.service-hero__meta { display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 1.25rem 0; }

/* --- Hero ---------------------------------------------------------------- */
.hero {
  padding-block: clamp(3.5rem, 9vw, 7rem);
  background: radial-gradient(60% 80% at 50% -10%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 70%);
}
.hero h1 { max-width: 18ch; }
.hero__lead { max-width: 56ch; font-size: clamp(1.1rem, 2vw, 1.35rem); color: var(--ink-dim); }
.hero__cta { display: flex; flex-wrap: wrap; gap: 0.75rem; margin-top: 1.75rem; }

/* --- Section variants ---------------------------------------------------- */
.section--alt { background: var(--bg-soft); }
section[id] { scroll-margin-top: 84px; }

/* --- Method steps as columns -------------------------------------------- */
.steps--cols { grid-template-columns: repeat(auto-fit, minmax(min(100%, 16rem), 1fr)); }

/* --- Contact form ------------------------------------------------------- */
.form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem 1.25rem;
  max-width: 720px;
  margin-top: 1rem;
}
.field { display: flex; flex-direction: column; gap: 0.4rem; }
.field--full { grid-column: 1 / -1; }
.field label { font-size: 0.9rem; color: var(--ink-dim); }
.form input,
.form textarea {
  width: 100%;
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  color: var(--ink);
  font: inherit;
  padding: 0.7rem 0.85rem;
}
.form input:focus,
.form textarea:focus {
  outline: none;
  border-color: var(--accent-2);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 30%, transparent);
}
.form textarea { resize: vertical; }
/* Honeypot — kept far off-screen, never shown to humans. */
.form__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form__check {
  grid-column: 1 / -1;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  color: var(--ink-dim);
  font-size: 0.9rem;
}
.form__check input { width: auto; margin-top: 0.2rem; }
.form__status { grid-column: 1 / -1; margin: 0; min-height: 1.3em; font-weight: 600; }
.form__status.is-success { color: #7cd29a; }
.form__status.is-error { color: #ef9a9a; }
.form__fallback { margin-top: 1.25rem; color: var(--ink-dim); }
@media (max-width: 560px) { .form { grid-template-columns: 1fr; } }

/* --- Footer layout ------------------------------------------------------- */
.footer__top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 1.25rem;
}
.footer__logo { height: 26px; width: auto; margin-bottom: 0.6rem; }
.footer__email { margin: 0; color: var(--ink-dim); }
.footer__nav { display: flex; flex-wrap: wrap; gap: 0.4rem 1.1rem; align-items: center; }

/* --- Prose (whitepaper body, long-form copy) ----------------------------- */
.prose { max-width: 68ch; }
.prose p { margin: 0 0 1rem; }
.whitepaper__h { margin-top: 2.5rem; }

/* --- Back-to-top --------------------------------------------------------- */
.to-top {
  position: fixed;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  border: 1px solid var(--accent-2);
  background: color-mix(in srgb, var(--accent) 32%, transparent);
  backdrop-filter: blur(8px);
  color: var(--ink);
  font-size: 1.1rem;
  cursor: pointer;
  opacity: 0;
  transform: translateY(8px);
  pointer-events: none;
  transition: opacity 0.25s var(--ease), transform 0.25s var(--ease), background 0.2s var(--ease);
  z-index: 90;
}
.to-top.is-visible { opacity: 1; transform: none; pointer-events: auto; }
.to-top:hover { background: var(--accent); color: var(--accent-ink); }
@media (prefers-reduced-motion: reduce) {
  .to-top { transition: opacity 0.2s linear; transform: none; }
}

/* --- CTA band ------------------------------------------------------------ */
.cta-band {
  margin-block: var(--section-y);
}
.cta-band__inner {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 28%, var(--bg-soft)), var(--bg-soft));
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: clamp(1.75rem, 4vw, 2.75rem);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}
.cta-band__text { max-width: 48ch; }
.cta-band__text h2 { margin: 0 0 0.4rem; }
.cta-band__text p { margin: 0; }
