@charset "UTF-8";
/* ============================================================================
   CONTACT-FORM.SCSS – formularz kontaktowy Snuggly Plush
   Używa klas z shortcode’u:
     .cf-form
     .cf-field
     .cf-consent
     .cf-button
     .cf-notice
   + opcjonalny wrapper .contact-section / .contact-section__inner
============================================================================ */
/* --------------------------------------
   1. Wrapper sekcji kontaktowej (opcjonalny)
   Użyj np. w edytorze:
     <div class="contact-section">
       [simple_contact_form]
     </div>
--------------------------------------- */
.contact-section {
  width: 100%;
  padding-block: var(--space-3xl);
  background: var(--color-soft-cream);
}
.contact-section__inner {
  max-width: 820px;
  margin: 0 auto;
  padding-inline: 24px;
}
.contact-section__heading {
  text-align: center;
  margin: 0 0 var(--space-md);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: clamp(1.8rem, 1.5rem + 1vw, 2.2rem);
  color: var(--color-text-dark);
}
.contact-section__subheading {
  text-align: center;
  max-width: 520px;
  margin: 0 auto var(--space-2xl);
  font-size: 0.98rem;
  color: var(--color-text-muted);
  line-height: 1.6;
}

/* --------------------------------------
   2. Karta formularza
--------------------------------------- */
.cf-form {
  max-width: 760px;
  margin: 0 auto;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  padding: var(--space-xl);
  display: grid;
  gap: var(--space-md);
}
@media (max-width: 640px) {
  .cf-form {
    padding: var(--space-lg);
    gap: var(--space-sm);
  }
}

/* --------------------------------------
   3. Pola formularza
--------------------------------------- */
.cf-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0;
}
.cf-field label {
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--color-text-dark);
}
.cf-field input[type=text],
.cf-field input[type=email],
.cf-field textarea {
  background: #fff;
}
.cf-field textarea {
  min-height: 140px;
  resize: vertical;
}

/* Dwie kolumny – jeśli kiedyś zechcesz użyć cf-row--2 */
.cf-row--2 {
  display: grid;
  gap: var(--space-md);
}
@media (min-width: 640px) {
  .cf-row--2 {
    grid-template-columns: 1fr 1fr;
  }
}

/* --------------------------------------
   4. Zgody / RODO
--------------------------------------- */
.cf-consent {
  margin-top: var(--space-xs);
  font-size: 0.86rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}
.cf-consent label {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
}
.cf-consent input[type=checkbox] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 4px;
  border: 1.5px solid var(--color-border);
  background: #fff;
  margin-top: 2px;
  position: relative;
  flex-shrink: 0;
  transition: background-color 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.cf-consent input[type=checkbox]:hover {
  border-color: var(--color-warm-beige);
  box-shadow: 0 0 0 3px rgba(216, 193, 170, 0.35);
}
.cf-consent input[type=checkbox]:checked {
  background: var(--color-cozy-brown);
  border-color: var(--color-cozy-brown);
  box-shadow: 0 0 0 3px rgba(176, 140, 102, 0.25);
}
.cf-consent input[type=checkbox]:checked::after {
  content: "✓";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -52%);
  font-size: 13px;
  color: #fff;
  font-weight: 700;
}
.cf-consent .cf-consent__text {
  color: var(--color-text);
  font-size: 0.9rem;
}
.cf-consent .cf-error-message {
  display: none;
  margin-top: 4px;
  font-size: 0.8rem;
  color: #b91c1c;
}

/* --------------------------------------
   5. Przycisk wysyłki
--------------------------------------- */
.cf-button {
  margin-top: var(--space-sm);
  justify-self: flex-start;
}
@media (max-width: 640px) {
  .cf-button {
    width: 100%;
  }
}

/* --------------------------------------
   6. Powiadomienia (sukces / błąd)
--------------------------------------- */
.cf-notice {
  max-width: 760px;
  margin: 0 auto var(--space-md);
  padding: 0.75rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  line-height: 1.5;
}

.cf-notice--success {
  background: #ecfdf3;
  border: 1px solid #bbf7d0;
  color: #065f46;
}

.cf-notice--error {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #991b1b;
}

/* --------------------------------------
   7. Stany błędów przy polach (na później)
   Możesz dodać .cf-field--error w PHP jeśli walidacja padnie
--------------------------------------- */
.cf-field--error label {
  color: #b91c1c;
}
.cf-field--error input,
.cf-field--error textarea {
  border-color: #f97373 !important;
  box-shadow: 0 0 0 3px rgba(248, 113, 113, 0.25);
}
.cf-field--error .cf-error-message {
  margin-top: 4px;
  font-size: 0.8rem;
  color: #b91c1c;
}

/* --------------------------------------
   8. Meta kontaktu (opcjonalny blok)
   Użyteczne, jeśli dodasz np. e-mail / IG obok formularza
--------------------------------------- */
.contact-meta {
  max-width: 760px;
  margin: 0 auto var(--space-xl);
  display: grid;
  gap: var(--space-sm);
  font-size: 0.95rem;
  color: var(--color-text);
}
.contact-meta__item {
  display: flex;
  align-items: center;
  gap: 8px;
}
.contact-meta__icon {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--color-light-sand);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
}
.contact-meta a {
  color: var(--link);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.contact-meta a:hover {
  color: var(--link-hover);
}

input.cf-error {
  border-color: #d82c0d !important;
  box-shadow: 0 0 0 3px rgba(216, 44, 13, 0.15) !important;
}

.cf-error-message {
  color: #d82c0d;
  margin-top: 4px;
  font-size: 0.82rem;
  display: none;
}

.cf-notice--success {
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 16px;
  padding: 28px 32px;
  max-width: 720px;
  margin: 0 auto 40px auto;
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.06);
}
.cf-notice--success h3 {
  margin: 0 0 6px;
  font-size: 1.45rem;
  font-weight: 700;
  color: #1a1a1a;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cf-notice--success h3::before {
  content: "✔";
  display: inline-block;
  font-size: 1.2rem;
  color: #2c7a4b;
  background: #e8f5ec;
  padding: 6px 9px;
  border-radius: 50%;
  line-height: 1;
}
.cf-notice--success p {
  margin: 0;
  color: #333;
  font-size: 1rem;
  line-height: 1.55;
}

.footer-snuggly__contact-link,
.footer-snuggly__contact-mail {
  display: block;
}

.footer-snuggly__contact-link {
  font-weight: 600;
  margin-bottom: 4px;
}

.contact-section__subheading a:hover {
  text-decoration: underline;
}

/*# sourceMappingURL=contact-form.css.map */
