/*
 * Contact form block — scoped styles
 *
 * Whyso Design System — auto-generated from the Whyso hub.
 * Project: Marcus & Marcus
 * Generated: 2026-06-04T22:25:13+00:00
 *
 * Scoped to .contact-form — relies on tokens.css being loaded.
 * One breakpoint maximum (structural layout shifts only — never size or
 * colour, those come from the fluid scales in tokens.css).
 */

.contact-form {
    padding-block: var(--space-2xl);
    /* Surface default — overridden by [data-surface] variants below */
    background: var(--color-bg);
    color: var(--color-text);
}

.contact-form__inner {
    display: flex;
    flex-direction: column;
    gap: var(--space-md);
}

/* Surface variants */

.contact-form[data-bg="light"] {
    background: var(--color-bg);
    color: var(--color-text);
}

.contact-form[data-bg="alt"] {
    background: var(--color-bg-alt);
    color: var(--color-text);
}

.contact-form[data-bg="dark"] {
    background: var(--color-bg-dark);
    color: var(--color-text-inverse);
}






/* ------------------------------------------------------------------
 * Block polish — from preview_sample.extra_css
 * Plus CSS for every component + animation the block references.
 * Matches byte-for-byte what /library preview inlines, so the
 * deployed block renders the same on a real WordPress site.
 * ------------------------------------------------------------------ */

/* --- preview_sample.extra_css --- */
.contact-form__inner { display: grid; grid-template-columns: 1fr; gap: var(--space-xl); align-items: start; }
.contact-form__eyebrow { text-transform: uppercase; letter-spacing: 0.12em; font-size: var(--text-sm); font-weight: 600; color: var(--color-accent); margin: 0 0 var(--space-xs); }
.contact-form__heading { font-size: var(--text-3xl); margin: 0 0 var(--space-sm); }
.contact-form__intro { color: var(--color-text-muted); margin: 0 0 var(--space-md); }
.contact-form__details { list-style: none; margin: 0 0 var(--space-md); padding: 0; display: flex; flex-direction: column; gap: var(--space-sm); }
.contact-form__detail { display: flex; flex-direction: column; gap: 2px; }
.contact-form__detail-label { font-weight: 700; color: var(--color-primary); }
.contact-form__detail-value { color: var(--color-text-muted); }
.contact-form__map { border-radius: var(--radius-md); overflow: hidden; aspect-ratio: 16 / 9; background: var(--color-bg-alt); }
.contact-form__map iframe { width: 100%; height: 100%; border: 0; display: block; }
.contact-form__form { background: var(--color-bg, #fff); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-lg); box-shadow: 0 30px 70px -52px rgba(0,0,0,0.5); }
.contact-form__form-heading { font-size: var(--text-xl); margin: 0 0 var(--space-md); }
.contact-form__field { margin-bottom: var(--space-sm); }
.contact-form__field label { display: block; font-size: var(--text-sm); font-weight: 600; color: var(--color-primary); margin-bottom: var(--space-2xs, 6px); }
.contact-form__field input, .contact-form__field textarea { width: 100%; padding: 0.8em 1em; border: 1.5px solid var(--color-border); border-radius: var(--radius-sm); font-family: inherit; font-size: var(--text-base); color: var(--color-text); background: var(--color-bg-alt); }
.contact-form__field input:focus, .contact-form__field textarea:focus { outline: 0; border-color: var(--color-accent); }
.contact-form__field textarea { resize: vertical; min-height: 110px; }
.contact-form__submit { width: 100%; }
.contact-form__note { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-xs); }
@media (min-width: 56rem) {
  .contact-form__inner { grid-template-columns: 1fr 1fr; gap: var(--space-2xl, var(--space-xl)); }
}
.contact-form[data-surface="dark"] { background: var(--color-bg-dark); color: var(--color-text-inverse, #fff); }

/* --- Animations used — fade-up --- */
@keyframes wy-fade-up {
  from { opacity: 0; transform: translateY(var(--anim-distance, 20px)); }
  to   { opacity: 1; transform: translateY(0); }
}

.fade-up {
    animation: wy-fade-up var(--anim-duration, 400ms) var(--anim-easing, cubic-bezier(.16, 1, .3, 1)) both;
}

