/* ============================================================
   Webground — Components
   Buttons, Cards, Badges, Forms, FAQ, Process, Case Study
   ============================================================ */

/* ── Buttons ──────────────────────────────────────── */
.wg-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-button);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: var(--weight-medium);
  line-height: 1;
  padding: 0 var(--space-5);
  height: 40px;
  white-space: nowrap;
  transition:
    background var(--dur-base) var(--ease-out),
    color var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-fast) var(--ease-out);
  cursor: pointer;
  text-decoration: none;
  border: 1px solid transparent;
}

.wg-btn:active { transform: scale(0.98); }

.wg-btn--lg { height: 48px; padding: 0 var(--space-6); font-size: var(--fs-body-lg); }
.wg-btn--sm { height: 32px; padding: 0 var(--space-4); font-size: var(--fs-small); }

/* Primary */
.wg-btn--primary {
  background: var(--wg-teal);
  color: var(--fg-on-teal);
  border-color: var(--wg-teal);
}
.wg-btn--primary:hover {
  background: var(--wg-teal-700);
  border-color: var(--wg-teal-700);
  color: var(--fg-on-teal);
}

/* Secondary (ink outline) */
.wg-btn--secondary {
  background: var(--wg-white);
  color: var(--fg-1);
  border-color: var(--wg-ink);
}
.wg-btn--secondary:hover {
  background: var(--wg-ink-08);
  color: var(--fg-1);
}

/* White outline (hero-n) */
.wg-btn--outline-white {
  background: transparent;
  color: var(--wg-white);
  border-color: rgba(255, 255, 255, 0.7);
}
.wg-btn--outline-white:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--wg-white);
  color: var(--wg-white);
}

/* Accent — max 1x/oldal */
.wg-btn--accent {
  background: var(--wg-orange);
  color: var(--fg-on-orange);
  border-color: var(--wg-orange);
}
.wg-btn--accent:hover {
  background: var(--wg-orange-700);
  border-color: var(--wg-orange-700);
  color: var(--fg-on-orange);
}

/* Ghost */
.wg-btn--ghost {
  background: transparent;
  color: var(--wg-teal);
  border-color: transparent;
}
.wg-btn--ghost:hover { background: var(--wg-teal-50); }

/* ── Service Card ─────────────────────────────────── */
.wg-service-card {
  background: var(--bg-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: border-color var(--dur-base) var(--ease-out);
}
.wg-service-card:hover { border-color: var(--border-hover); }

.wg-service-card__icon {
  color: var(--wg-teal);
  width: 32px;
  height: 32px;
}

.wg-service-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
  letter-spacing: -0.015em;
}

.wg-service-card__body {
  font-size: 15px;
  color: var(--fg-2);
  line-height: var(--leading-normal);
}

.wg-service-card__bullets {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.wg-service-card__bullet {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--fs-small);
  color: var(--wg-ink-90);
  line-height: var(--leading-normal);
}
.wg-service-card__bullet svg {
  flex-shrink: 0;
  color: var(--wg-teal);
  margin-top: 2px;
}

.wg-service-card__link {
  margin-top: auto;
  font-size: var(--fs-small);
  font-weight: var(--weight-medium);
  color: var(--wg-teal);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  transition: gap var(--dur-base) var(--ease-out);
}
.wg-service-card__link:hover { gap: var(--space-2); }

.wg-services-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
@media (max-width: 1100px) {
  .wg-services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .wg-services-grid { grid-template-columns: 1fr; }
}

/* ── Value Props ──────────────────────────────────── */
.wg-value-props {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 768px) {
  .wg-value-props { grid-template-columns: 1fr; }
}

.wg-value-prop {
  background: var(--bg-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  transition: border-color var(--dur-base) var(--ease-out);
}
.wg-value-prop:hover { border-color: var(--border-hover); }

.wg-value-prop__icon {
  color: var(--wg-teal);
  margin-bottom: var(--space-4);
  width: 28px;
  height: 28px;
}
.wg-value-prop__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
  margin-bottom: var(--space-3);
}
.wg-value-prop__body { font-size: 15px; color: var(--fg-2); line-height: var(--leading-normal); }

/* ── Process Steps ────────────────────────────────── */
.wg-process-steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}

.wg-process-step {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
}

.wg-process-step__num {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-pill);
  background: var(--wg-teal-50);
  color: var(--wg-teal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-weight: var(--weight-medium);
  font-size: var(--fs-body);
}

.wg-process-step__title {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
  letter-spacing: -0.01em;
  margin-bottom: var(--space-2);
}

.wg-process-step__body {
  font-size: 15px;
  color: var(--fg-2);
  line-height: var(--leading-normal);
}

/* ── FAQ ──────────────────────────────────────────── */
.wg-faq { display: flex; flex-direction: column; gap: var(--space-2); }

.wg-faq__item {
  border: 1px solid var(--border-1);
  border-radius: var(--radius-card);
  overflow: hidden;
  transition: border-color var(--dur-base) var(--ease-out);
}
.wg-faq__item[open] { border-color: var(--wg-teal); }

.wg-faq__summary {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-5) var(--space-6);
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
  gap: var(--space-4);
  user-select: none;
}
.wg-faq__summary::-webkit-details-marker { display: none; }
.wg-faq__summary:hover { color: var(--wg-teal); }

.wg-faq__chevron {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  color: var(--wg-ink-50);
  transition: transform var(--dur-base) var(--ease-out);
}
.wg-faq__item[open] .wg-faq__chevron { transform: rotate(180deg); }

.wg-faq__body {
  padding: 0 var(--space-6) var(--space-5);
  font-size: var(--fs-body);
  color: var(--fg-2);
  line-height: var(--leading-normal);
}

/* ── Case Study Card ──────────────────────────────── */
.wg-cs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
@media (max-width: 768px) { .wg-cs-grid { grid-template-columns: 1fr; } }

.wg-cs-card {
  background: var(--bg-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: border-color var(--dur-base) var(--ease-out);
}
.wg-cs-card:hover { border-color: var(--border-hover); }
.wg-cs-card--featured { border-color: var(--wg-teal-50); }

.wg-cs-card__meta {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.wg-badge {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  font-size: var(--fs-caption);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.wg-badge--teal { background: var(--wg-teal-50); color: var(--wg-teal); }
.wg-badge--soft { background: var(--wg-ink-08); color: var(--fg-2); }

.wg-cs-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
  margin-top: var(--space-4);
}

.wg-cs-card__metrics {
  display: flex;
  gap: var(--space-6);
}

.wg-cs-metric__value {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--weight-semibold);
  color: var(--wg-teal);
  line-height: 1;
}
.wg-cs-metric__label {
  font-size: var(--fs-caption);
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  margin-top: var(--space-1);
}

.wg-cs-card__timeframe {
  font-size: var(--fs-small);
  color: var(--fg-3);
}

.wg-cs-card__link {
  font-size: var(--fs-small);
  font-weight: var(--weight-medium);
  color: var(--wg-teal);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  margin-top: auto;
  transition: gap var(--dur-base) var(--ease-out);
}
.wg-cs-card__link:hover { gap: var(--space-2); }

/* ── Lead Magnet Strip ────────────────────────────── */
.wg-lead-strip {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
@media (max-width: 768px) { .wg-lead-strip { grid-template-columns: 1fr; } }

.wg-lead-card {
  background: var(--bg-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-card);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  transition: border-color var(--dur-base) var(--ease-out);
}
.wg-lead-card:hover { border-color: var(--border-hover); }

.wg-lead-card__icon {
  color: var(--wg-teal);
  width: 28px;
  height: 28px;
}
.wg-lead-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-h4);
  font-weight: var(--weight-semibold);
  color: var(--fg-1);
}
.wg-lead-card__body {
  font-size: 15px;
  color: var(--fg-2);
  line-height: var(--leading-normal);
  flex-grow: 1;
}

/* ── CTA Banner ───────────────────────────────────── */
.wg-cta-banner {
  background: var(--wg-teal);
  border-radius: var(--radius-card);
  padding: var(--space-8) var(--space-7);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
}
@media (max-width: 768px) {
  .wg-cta-banner { flex-direction: column; text-align: center; }
}

.wg-cta-banner__heading {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  font-weight: var(--weight-semibold);
  color: var(--wg-white);
  letter-spacing: var(--tracking-tight);
}
.wg-cta-banner__body {
  font-size: var(--fs-body-lg);
  color: rgba(255, 255, 255, 0.82);
  margin-top: var(--space-3);
}

/* ── Pricing Box ──────────────────────────────────── */
.wg-pricing-box {
  background: var(--wg-teal-50);
  border: 1px solid var(--wg-teal);
  border-radius: var(--radius-card);
  padding: var(--space-6);
}
.wg-pricing-box__amount {
  font-family: var(--font-display);
  font-size: var(--fs-h1);
  font-weight: var(--weight-semibold);
  color: var(--wg-teal);
  line-height: 1;
}
.wg-pricing-box__note {
  font-size: var(--fs-small);
  color: var(--fg-2);
  margin-top: var(--space-3);
  line-height: var(--leading-normal);
}

/* ── Forms (FluentForms override) ─────────────────── */
.wg-form-wrap .ff-el-group { margin-bottom: var(--space-5); }
.wg-form-wrap label,
.wg-form-wrap .ff-el-input--label {
  display: block;
  font-size: var(--fs-small);
  font-weight: var(--weight-medium);
  color: var(--fg-1);
  margin-bottom: var(--space-2);
}

.wg-form-wrap input[type="text"],
.wg-form-wrap input[type="email"],
.wg-form-wrap input[type="tel"],
.wg-form-wrap input[type="url"],
.wg-form-wrap select,
.wg-form-wrap textarea,
.wg-form-wrap .ff-el-form-control {
  width: 100%;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  color: var(--fg-1);
  background: var(--bg-1);
  border: 1px solid var(--border-1);
  border-radius: var(--radius-input);
  padding: 10px var(--space-4);
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  outline: none;
}

.wg-form-wrap input:focus,
.wg-form-wrap select:focus,
.wg-form-wrap textarea:focus,
.wg-form-wrap .ff-el-form-control:focus {
  border-color: var(--border-focus);
  box-shadow: 0 0 0 3px var(--wg-teal-50);
}

.wg-form-wrap textarea,
.wg-form-wrap textarea.ff-el-form-control { min-height: 120px; resize: vertical; }

.wg-form-wrap .ff-btn-submit,
.wg-form-wrap button[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-button);
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: var(--weight-medium);
  height: 48px;
  padding: 0 var(--space-6);
  background: var(--wg-teal);
  color: var(--fg-on-teal);
  border: 1px solid var(--wg-teal);
  cursor: pointer;
  transition: background var(--dur-base) var(--ease-out);
}
.wg-form-wrap .ff-btn-submit:hover,
.wg-form-wrap button[type="submit"]:hover {
  background: var(--wg-teal-700);
  border-color: var(--wg-teal-700);
}

.wg-form-wrap .ff-errors,
.wg-form-wrap .error {
  font-size: var(--fs-small);
  color: var(--danger);
  margin-top: var(--space-1);
}

/* ── Trust Badges ─────────────────────────────────── */
.wg-trust-badges {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}
.wg-trust-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-small);
  color: var(--wg-ink-30);
}
.wg-trust-badge svg { color: var(--wg-teal); width: 16px; height: 16px; }

/* ── Google Partner Badge ─────────────────────────── */
.wg-partner-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
}
.wg-partner-badge img { height: 48px; width: auto; }
