/* ============================================================
   kg-forms.css — KillerGrowth Form Component v1.0
   
   Standalone, scoped form stylesheet for all KillerGrowth
   static site builds. Drop this stylesheet on any site and
   wrap your form in: <div class="kg-form-wrapper">...</div>
   
   All rules are scoped under .kg-form-wrapper with !important
   guards so they win over any parent or sibling CSS regardless
   of specificity or load order.
   
   Brand colors are pulled from the site's CSS custom properties
   (--kg-primary, --kg-border, etc.) with safe fallbacks.
   ============================================================ */

/* ── Variables (inherit from site brand or use defaults) ──── */
.kg-form-wrapper {
  --kgf-primary:      var(--kg-primary, #1b3a2d);
  --kgf-secondary:    var(--kg-secondary, #f5a623);
  --kgf-border:       var(--kg-border, #d1d5db);
  --kgf-border-focus: var(--kg-primary, #1b3a2d);
  --kgf-radius:       var(--kg-radius, 8px);
  --kgf-text:         var(--kg-text, #1f2937);
  --kgf-muted:        var(--kg-text-muted, #6b7280);
  --kgf-bg:           #ffffff;
  --kgf-font:         var(--kg-font-body, system-ui, 'Segoe UI', sans-serif);
  --kgf-transition:   0.2s ease;
  --kgf-label-color:  var(--kg-primary, #1b3a2d);
  --kgf-shadow-focus: rgba(27, 58, 45, 0.15);
}

/* ── 2-column row ─────────────────────────────────────────── */
.kg-form-wrapper .kg-form-row {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
  margin-bottom: 0;
}

@media (max-width: 640px) {
  .kg-form-wrapper .kg-form-row {
    grid-template-columns: 1fr !important;
  }
}

/* ── Form group (label + field, stacked vertically) ──────── */
.kg-form-wrapper .kg-form-group {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
  margin-bottom: 20px !important;
}

/* ── Label ───────────────────────────────────────────────── */
.kg-form-wrapper .kg-form-group label {
  display: block !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  line-height: 1.4 !important;
  color: var(--kgf-label-color) !important;
  letter-spacing: 0.01em !important;
  margin: 0 !important;
}

/* ── All inputs, selects, textareas ─────────────────────── */
.kg-form-wrapper .kg-form-group input,
.kg-form-wrapper .kg-form-group select,
.kg-form-wrapper .kg-form-group textarea {
  display: block !important;
  width: 100% !important;
  padding: 12px 16px !important;
  border: 1.5px solid var(--kgf-border) !important;
  border-radius: var(--kgf-radius) !important;
  font-size: 1rem !important;
  font-family: var(--kgf-font) !important;
  color: var(--kgf-text) !important;
  background: var(--kgf-bg) !important;
  box-sizing: border-box !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  transition: border-color var(--kgf-transition), box-shadow var(--kgf-transition) !important;
  margin: 0 !important;
  line-height: 1.5 !important;
}

/* ── Select: custom chevron ─────────────────────────────── */
.kg-form-wrapper .kg-form-group select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 42px !important;
  cursor: pointer !important;
}

/* ── Focus ring ─────────────────────────────────────────── */
.kg-form-wrapper .kg-form-group input:focus,
.kg-form-wrapper .kg-form-group select:focus,
.kg-form-wrapper .kg-form-group textarea:focus {
  border-color: var(--kgf-border-focus) !important;
  box-shadow: 0 0 0 3px var(--kgf-shadow-focus) !important;
}

/* ── Textarea ───────────────────────────────────────────── */
.kg-form-wrapper .kg-form-group textarea {
  min-height: 130px !important;
  resize: vertical !important;
}

/* ── Placeholder ────────────────────────────────────────── */
.kg-form-wrapper .kg-form-group input::placeholder,
.kg-form-wrapper .kg-form-group textarea::placeholder {
  color: var(--kgf-muted) !important;
  opacity: 1 !important;
}

/* ── Submit button ──────────────────────────────────────── */
.kg-form-wrapper .kg-form-submit {
  display: block !important;
  width: 100% !important;
  padding: 14px 24px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  font-family: var(--kgf-font) !important;
  background: var(--kgf-primary) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: var(--kgf-radius) !important;
  cursor: pointer !important;
  letter-spacing: 0.02em !important;
  transition: background var(--kgf-transition), transform var(--kgf-transition) !important;
  text-align: center !important;
}

.kg-form-wrapper .kg-form-submit:hover {
  filter: brightness(0.88) !important;
  transform: translateY(-1px) !important;
}

.kg-form-wrapper .kg-form-submit:active {
  transform: translateY(0) !important;
}

/* ── Form note (below submit button) ────────────────────── */
.kg-form-wrapper .kg-form-note {
  display: block !important;
  font-size: 0.82rem !important;
  color: var(--kgf-muted) !important;
  margin-top: 10px !important;
  text-align: center !important;
}
