/*
 * FAQ Accordion 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 .faq-accordion — 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).
 */

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

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

/* Surface variants */

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

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

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

/* Layout variants */

.faq-accordion[data-layout="single-column"] .faq-accordion__inner {
    /* TODO: style single-column layout */
}

.faq-accordion[data-layout="two-column"] .faq-accordion__inner {
    /* Responsive grid applied at 48rem — see below */
}

.faq-accordion[data-layout="boxed"] .faq-accordion__inner {
    /* TODO: style boxed layout */
}

/* Responsive layout — structural only, single breakpoint */
@media (min-width: 48rem) {
    .faq-accordion[data-layout="two-column"] .faq-accordion__inner { grid-template-columns: repeat(2, 1fr); }
}


/* ------------------------------------------------------------------
 * 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 --- */
.faq-accordion { padding-block: var(--space-2xl); }
.faq-accordion[data-size="lg"] { padding-block: var(--space-3xl); }
.faq-accordion__inner > * + * { margin-top: var(--space-xl); }
.faq-accordion__header { text-align: center; display: flex; flex-direction: column; gap: var(--space-2xs); max-width: 48ch; margin-inline: auto; }
.faq-accordion__intro { color: var(--color-text-muted); font-size: var(--text-lg); }
.faq-accordion__items { display: grid; grid-template-columns: 1fr; gap: var(--space-2xs); }
.faq-accordion__item { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); transition: background-color 180ms ease, border-color 180ms ease; }
.faq-accordion__item[open] { border-color: color-mix(in srgb, var(--color-primary) 40%, var(--color-border)); background: var(--color-bg-alt); }
.faq-accordion__item-question { list-style: none; cursor: pointer; font-weight: 600; font-size: var(--text-base); display: flex; justify-content: space-between; align-items: center; gap: var(--space-sm); }
.faq-accordion__item-question::-webkit-details-marker { display: none; }
.faq-accordion__item-marker { display: inline-grid; place-items: center; width: 1.6em; height: 1.6em; border-radius: 50%; background: var(--color-accent, var(--brand-neutral-200)); color: var(--color-primary); flex: none; position: relative; }
.faq-accordion__item-marker::before, .faq-accordion__item-marker::after { content: ""; position: absolute; background: currentColor; border-radius: 999px; }
.faq-accordion__item-marker::before { width: 0.7em; height: 2px; }
.faq-accordion__item-marker::after  { width: 2px;   height: 0.7em; transition: transform 180ms ease; }
.faq-accordion__item[open] .faq-accordion__item-marker::after { transform: scaleY(0); }
.faq-accordion__item-answer { padding-top: var(--space-sm); color: var(--color-text-muted); font-size: var(--text-base); line-height: 1.6; }
.faq-accordion[data-layout="two-column"] .faq-accordion__items { grid-template-columns: 1fr; }
@media (min-width: 48rem) {
  .faq-accordion[data-layout="two-column"] .faq-accordion__items { grid-template-columns: 1fr 1fr; gap: var(--space-xs); }
}
.faq-accordion[data-layout="boxed"] .faq-accordion__items { background: var(--color-bg-alt); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-xs); gap: 0; }
.faq-accordion[data-layout="boxed"] .faq-accordion__item { background: transparent; border: 0; border-radius: var(--radius-sm); }
.faq-accordion[data-layout="boxed"] .faq-accordion__item + .faq-accordion__item { border-top: 1px solid var(--color-border); border-radius: 0; }
.faq-accordion[data-surface="dark"] { background: var(--color-bg-dark); color: var(--color-text-inverse, #fff); }
.faq-accordion[data-surface="dark"] .faq-accordion__item { background: color-mix(in srgb, #fff 5%, transparent); border-color: color-mix(in srgb, #fff 10%, transparent); }
.faq-accordion[data-surface="dark"] .faq-accordion__item[open] { background: color-mix(in srgb, #fff 8%, transparent); }
.faq-accordion[data-surface="dark"] .faq-accordion__item-answer { color: color-mix(in srgb, currentColor 75%, transparent); }

/* --- Components used — heading-h2 --- */
.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;
}

