/*
 * Newsletter (Inline) block — scoped styles
 *
 * Whyso Design System — auto-generated from the Whyso hub.
 * Project: Contenze Test
 * Generated: 2026-05-10T14:58:03+00:00
 *
 * Scoped to .newsletter-inline — 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).
 */

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

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

/* Surface variants */

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

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

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

.newsletter-inline[data-bg="primary"] {
    /* TODO: style primary variant */
}

/* Layout variants */

.newsletter-inline[data-layout="centred"] .newsletter-inline__inner {
    align-items: center;
    text-align: center;
    max-inline-size: 60ch;
    margin-inline: auto;
}

.newsletter-inline[data-layout="split"] .newsletter-inline__inner {
    /* TODO: style split layout */
}




/* ------------------------------------------------------------------
 * 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 --- */
.newsletter-inline { padding-block: var(--space-2xl); }
.newsletter-inline[data-size="sm"] { padding-block: var(--space-xl); }
.newsletter-inline[data-size="lg"] { padding-block: var(--space-3xl); }
.newsletter-inline__inner { display: flex; flex-direction: column; gap: var(--space-md); align-items: center; text-align: center; }
.newsletter-inline__body { display: flex; flex-direction: column; gap: var(--space-2xs); align-items: inherit; }
.newsletter-inline__text { color: var(--color-text-muted); font-size: var(--text-lg); max-width: 48ch; }
.newsletter-inline__form { display: flex; gap: var(--space-3xs); width: 100%; max-width: 32rem; background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-pill); padding: 4px; box-shadow: 0 1px 2px rgba(0,0,0,0.04); }
.newsletter-inline__form-field { flex: 1 1 auto; display: flex; align-items: center; }
.newsletter-inline__form input { flex: 1 1 auto; width: 100%; padding: 0.7em 1.1em; border: 0; background: transparent; font: inherit; color: inherit; outline: none; }
.newsletter-inline__form input::placeholder { color: var(--color-text-muted); }
.newsletter-inline__form-button { flex: none; padding: 0.7em 1.4em; border: 0; border-radius: var(--radius-pill); background: var(--color-primary); color: var(--color-on-primary, #fff); font: inherit; font-weight: 600; cursor: pointer; transition: filter 180ms ease; }
.newsletter-inline__form-button:hover { filter: brightness(1.08); }
.newsletter-inline__privacy { font-size: var(--text-xs); color: var(--color-text-muted); max-width: 40ch; }
.newsletter-inline[data-layout="split"] .newsletter-inline__inner { flex-direction: row; align-items: center; text-align: left; justify-content: space-between; flex-wrap: wrap; gap: var(--space-lg); }
.newsletter-inline[data-layout="split"] .newsletter-inline__body { align-items: flex-start; flex: 1 1 280px; }
.newsletter-inline[data-layout="split"] .newsletter-inline__form { flex: 1 1 320px; max-width: none; }
.newsletter-inline[data-surface="dark"], .newsletter-inline[data-surface="primary"] { color: var(--color-text-inverse, #fff); }
.newsletter-inline[data-surface="dark"] { background: var(--color-bg-dark); }
.newsletter-inline[data-surface="primary"] { background: var(--color-primary); }
.newsletter-inline[data-surface="dark"] .newsletter-inline__form,
.newsletter-inline[data-surface="primary"] .newsletter-inline__form { background: color-mix(in srgb, #fff 12%, transparent); border-color: color-mix(in srgb, #fff 18%, transparent); }
.newsletter-inline[data-surface="dark"] .newsletter-inline__form input::placeholder,
.newsletter-inline[data-surface="primary"] .newsletter-inline__form input::placeholder { color: color-mix(in srgb, currentColor 70%, transparent); }
.newsletter-inline[data-surface="primary"] .newsletter-inline__form-button { background: var(--color-text-inverse, #fff); color: var(--color-primary); }
.newsletter-inline[data-surface="dark"] .newsletter-inline__text,
.newsletter-inline[data-surface="primary"] .newsletter-inline__text,
.newsletter-inline[data-surface="dark"] .newsletter-inline__privacy,
.newsletter-inline[data-surface="primary"] .newsletter-inline__privacy { color: color-mix(in srgb, currentColor 75%, transparent); }
.visually-hidden { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); }
@media (max-width: 40rem) {
  .newsletter-inline__form { flex-direction: column; border-radius: var(--radius-lg); padding: var(--space-xs); gap: var(--space-xs); }
  .newsletter-inline__form-button { width: 100%; }
}

/* --- Components used — eyebrow, heading-h2 --- */
.eyebrow {
    font-family: var(--brand-font-mono, var(--brand-font-body, inherit));
    font-size: 0.72rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent, currentColor);
    margin: 0;
}

.heading-h2 {
    font-family: var(--brand-font-heading, inherit);
    font-weight: 700;
    font-size: var(--text-3xl);
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin: 0;
}


/* --- 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;
}

