/*
 * Rich Text 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 .rich-text — 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).
 */

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

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

/* Surface variants */

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

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

.rich-text[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 --- */
.rich-text { padding-block: var(--space-2xl); }
.rich-text[data-size="lg"] { padding-block: var(--space-3xl); }
.rich-text__content { max-width: 62ch; margin-inline: 0; font-size: var(--text-base); line-height: 1.7; }
.rich-text[data-width="narrow"]   .rich-text__content { max-width: 50ch; }
.rich-text[data-width="standard"] .rich-text__content { max-width: 62ch; }
.rich-text[data-width="wide"]     .rich-text__content { max-width: 80ch; }
.rich-text[data-alignment="centred"] .rich-text__content { margin-inline: auto; text-align: center; }
.rich-text__content > * + * { margin-top: var(--space-sm); }
.rich-text__content > h2 + *, .rich-text__content > h3 + * { margin-top: var(--space-xs); }
.rich-text__content h2 { font-size: var(--text-3xl); margin-top: var(--space-lg); }
.rich-text__content h3 { font-size: var(--text-xl); margin-top: var(--space-md); }
.rich-text__content ul, .rich-text__content ol { padding-left: 1.25em; list-style: revert; }
.rich-text__content li { margin: 0.35em 0; }
.rich-text__content li::marker { color: var(--color-primary); }
.rich-text__content blockquote { margin: var(--space-md) 0; padding: var(--space-sm) var(--space-md); border-left: 3px solid var(--color-primary); font-size: var(--text-lg); font-style: italic; color: var(--color-text-muted); }
.rich-text__content a { color: var(--color-primary); text-underline-offset: 3px; }
.rich-text__content img { border-radius: var(--radius-md); margin-block: var(--space-md); }
.rich-text[data-surface="dark"] { background: var(--color-bg-dark); color: var(--color-text-inverse, #fff); }
.rich-text[data-surface="dark"] blockquote { color: color-mix(in srgb, currentColor 75%, transparent); }

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

