/* ═══════════════════════════════════════════════════════════════════════
   Mimirio Section Blocks – Frontend Styles
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Hero backgrounds ──────────────────────────────────────────────── */
.mimirio-hero--dark {
    background-color: var(--color-teal-blue);
    color: #fff;
}

.mimirio-hero--iceberg {
    background-color: var(--color-iceberg);
    color: var(--color-teal-blue);
}

.mimirio-hero--image {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff;
}

/* ── Hero Heading ──────────────────────────────────────────────────── */
.mimirio-hero__heading {
    /* XS / S / M  (< 1024 px) */
    font-size: 2.75rem;
    line-height: 1.2;
    /* Reduce gap after <h1> to half of the container's space-y-6 (1.5 rem).
       Adding a negative margin-bottom of 0.75 rem achieves 0.75 rem effective gap. */
    margin-bottom: -0.75rem;
    /* Note: filter: drop-shadow() on the same element as background-clip:text
       prevents the gradient from rendering in Chrome/Safari. Not used here. */
}

@media (min-width: 1024px) {
    /* L / XL (≥ 1024 px) */
    .mimirio-hero__heading {
        font-size: 3.25rem;
        line-height: 4.25rem;
    }
}

/* Background-specific heading colour ─────────────────────────────────────────────
 * WordPress theme.json outputs `h1 { color: var(--wp--preset--color--teal-blue) }`
 * which overrides the colour inherited from the section background.  Set the
 * colour explicitly on the heading so it is always readable.
 */
.mimirio-hero--dark .mimirio-hero__heading,
.mimirio-hero--image .mimirio-hero__heading {
    color: #fff;
}
.mimirio-hero--iceberg .mimirio-hero__heading {
    color: var(--color-teal-blue);
}

/* Gradient variant — only used when enableGradientHeading is true and bg is Teal Blue */
.mimirio-hero__heading--gradient {
    background: linear-gradient(to right, var(--color-mango), var(--color-mango-shade-20));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

/* ── Hero Buttons ──────────────────────────────────────────────────── */

/* Base: no text decoration for all hero CTA buttons */
.mimirio-hero__btn {
    text-decoration: none !important;
    border-width: 1px;
    border-style: solid;
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.mimirio-hero__btn:hover,
.mimirio-hero__btn:focus-visible {
    text-decoration: none !important;
}

/* ── Teal Blue (dark) background button variants ───────────────────── */

/* CTA 1 – Primary: Mango bg + border, Teal Blue label */
.mimirio-hero--dark .mimirio-hero__btn-primary {
    background-color: var(--color-mango);
    color: var(--color-teal-blue) !important;
    border-color: var(--color-mango);
}

.mimirio-hero--dark .mimirio-hero__btn-primary:hover {
    background-color: var(--color-teal-blue);
    border-color: var(--color-mango);
    color: var(--color-mango) !important;
}

/* CTA 2 – Secondary: Iceberg bg, Teal Blue border & label */
.mimirio-hero--dark .mimirio-hero__btn-secondary {
    background-color: var(--color-iceberg);
    color: var(--color-teal-blue) !important;
    border-color: var(--color-iceberg);
}

.mimirio-hero--dark .mimirio-hero__btn-secondary:hover {
    background-color: var(--color-teal-blue);
    border-color: var(--color-iceberg);
    color: var(--color-iceberg) !important;
}

/* ── Iceberg background button variants ────────────────────────────── */

/* CTA 1 – Primary: Teal Blue bg & border, Iceberg label */
.mimirio-hero--iceberg .mimirio-hero__btn-primary {
    background-color: var(--color-teal-blue);
    color: var(--color-iceberg) !important;
    border-color: var(--color-teal-blue);
}

.mimirio-hero--iceberg .mimirio-hero__btn-primary:hover {
    background-color: var(--color-iceberg);
    color: var(--color-teal-blue) !important;
    border-color: var(--color-teal-blue);
}

/* CTA 2 – Secondary: Inverse of primary (Iceberg bg, Teal Blue border & label) */
.mimirio-hero--iceberg .mimirio-hero__btn-secondary {
    background-color: var(--color-iceberg);
    color: var(--color-teal-blue) !important;
    border-color: var(--color-teal-blue);
}

.mimirio-hero--iceberg .mimirio-hero__btn-secondary:hover {
    background-color: var(--color-teal-blue);
    color: var(--color-iceberg) !important;
    border-color: var(--color-teal-blue);
}

/* ── Hero Subtitle ─────────────────────────────────────────────────── */

/* On Iceberg background the subtitle must be 100% Teal Blue */
.mimirio-hero--iceberg .mimirio-hero__subtitle {
    color: var(--color-teal-blue);
}

/* ── Content with Image ────────────────────────────────────────────── */
.mimirio-content-image__text p {
    margin-bottom: 1em;
    line-height: 1.7;
}

.mimirio-content-image__text strong {
    color: var(--color-teal-blue);
    font-weight: 600;
}

.mimirio-content-image__text ul {
    list-style: disc;
    padding-left: 1.5em;
    margin-bottom: 1em;
}

.mimirio-content-image__text li {
    margin-bottom: 0.25em;
}

/* ── Testimonial Slider ────────────────────────────────────────────── */
.mimirio-testimonial-slider {
    position: relative;
    /* Full viewport width breakout so the background spans edge-to-edge
       even when the block lives inside a constrained page template. */
    left: 50%;
    margin-left: -50vw;
    width: 100vw;
    max-width: 100vw;
}

/* Slides stack on top of each other via CSS grid so height is content-driven */
.mimirio-testimonial-slider > div {
    display: grid;
}

.mimirio-tslide {
    grid-row: 1;
    grid-column: 1;
    transition: opacity 0.6s ease-in-out;
    opacity: 0;
    pointer-events: none;
    position: relative;
}

.mimirio-tslide.active {
    opacity: 1;
    pointer-events: auto;
}

.mimirio-tslide-prev,
.mimirio-tslide-next {
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
    opacity: 0.7;
}

.mimirio-tslide-prev:hover,
.mimirio-tslide-next:hover {
    opacity: 1;
}

/* Hide arrows when the slider has only one slide */
.mimirio-testimonial-slider.single-slide .mimirio-tslide-prev,
.mimirio-testimonial-slider.single-slide .mimirio-tslide-next {
    display: none;
}

/* Title/Role element – no opacity, no prose padding */
.quote-role {
    opacity: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Strip any drop-shadow / box-shadow from images inside slides */
.mimirio-tslide img {
    box-shadow: none !important;
    filter: none !important;
}

/* ── Step Process tabs ─────────────────────────────────────────────── */
.mimirio-stepper-tabs {
    gap: 0;
}

.mimirio-stepper-tab {
    position: relative;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    padding: 0 12px;
    background: none;
    border: none;
    text-align: center;
    min-width: 120px;
}

.mimirio-stepper-tab.active {
    opacity: 1;
}

.mimirio-stepper-tab .step-dot {
    width: 60px;
    height: 60px;
    border-radius: var(--wp--custom--border-radius--base, 0.5rem); /* 8px */
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    font-weight: 700;
    transition: all 0.3s;
}

.mimirio-stepper-tab .step-dot {
    background: var(--color-teal-10);
    color: var(--color-teal-50);
}

.mimirio-stepper-tab.active .step-dot {
    background: var(--color-mango);
    color: var(--color-teal-blue);
    box-shadow: 0 4px 14px rgba(253, 184, 19, 0.4);
}

.mimirio-stepper-tab .step-label {
    font-size: 13px;
    font-weight: 600;
    color: var(--color-teal-blue);
    opacity: 0.5;
}

.mimirio-stepper-tab.active .step-label {
    opacity: 1;
}

.mimirio-stepper-tab .step-sublabel {
    font-size: 11px;
    color: var(--color-teal-50);
    opacity: 0.5;
}

.mimirio-stepper-tab.active .step-sublabel {
    opacity: 1;
}

.mimirio-stepper-panel {
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.mimirio-stepper-panel.hidden {
    display: none;
}

.mimirio-stepper-prev,
.mimirio-stepper-next {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Step Process prev button: secondary styling (white bg, teal border/text) */
.mimirio-stepper-prev.button {
    background-color: white;
    border-color: var(--color-teal-blue);
    color: var(--color-teal-blue);
}

.mimirio-stepper-prev.button:hover {
    background-color: var(--color-teal-blue);
    border-color: var(--color-teal-blue);
    color: white;
}

/* hiw image wrapper — match original */
.hiw-image-wrapper {
    max-height: 480px;
}

.hiw-image-wrapper img {
    object-fit: cover;
}

/* ── Step Process content list styles ──────────────────────────────── */
.mimirio-stepper-content ul {
    list-style: disc;
    padding-left: 1.25em;
    margin-top: 0.5em;
}

.mimirio-stepper-content li {
    margin-bottom: 0.25em;
}

/* ── Use Case Cards: base (white bg for all section backgrounds) ─────── */
.mimirio-use-case-card {
    background-color: #ffffff;
    border: 1px solid var(--color-teal-20, #d5dade);
}

/* ── Use Case Cards: dark bg variant – solid white card ─────────────── */
.mimirio-use-case-grid[data-bg="dark"] .mimirio-use-case-card {
    background: #ffffff;
    border: none;
}

/* ── Use Case Cards: clickable card (anchor wrapper) ───────────────── */
a.mimirio-use-case-card {
    cursor: pointer;
    color: inherit;
    display: block;
}

a.mimirio-use-case-card:hover {
    text-decoration: none; /* global a {text-decoration:none} already handles this; kept for defence in depth */
}

/* ── Dots canvas (hero optional) ───────────────────────────────────── */
.mimirio-dots-canvas {
    display: block;
    width: 100%;
    height: 100%;
}

/* ── Animations ────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {

    .mimirio-hero,
    .mimirio-testimonial-slider,
    .mimirio-cta,
    .mimirio-stats,
    .mimirio-use-case-grid,
    .mimirio-stepper,
    .mimirio-content-image,
    .mimirio-tabs-section {
        animation: mimirio-fade-in 0.6s ease-out;
    }

    @keyframes mimirio-fade-in {
        from {
            opacity: 0;
            transform: translateY(16px);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }
}

/* ── Tabs Section ──────────────────────────────────────────────────── */
.mimirio-tabs-eyebrow {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    font-weight: 500;
    color: var(--color-link-blue, #5190C8);
    margin-bottom: 0.75rem;
}

.mimirio-tabs-nav {
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    border: 1px solid var(--color-teal-20, #d5dade);
    border-radius: var(--wp--custom--border-radius--base, 0.5rem); /* 8px */
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.mimirio-tab-btn {
    flex: 1;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    padding: 10px 20px;
    border: none;
    border-right: 1px solid var(--color-teal-20, #d5dade);
    background: transparent;
    cursor: pointer;
    transition: background-color 0.2s ease, color 0.2s ease;
    text-align: left;
    min-width: 0;
    font-family: inherit;
}

.mimirio-tab-btn:last-child {
    border-right: none;
}

.mimirio-tab-btn .tab-small-title {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    color: var(--color-link-blue, #5190C8);
    font-weight: 400;
    display: block;
}

.mimirio-tab-btn .tab-main-title {
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.02rem;
    color: var(--color-teal-blue, #2F4858);
    display: block;
}

.mimirio-tab-btn.active {
    background-color: var(--color-teal-blue, #2F4858);
    border-right-color: var(--color-teal-blue, #2F4858);
}

.mimirio-tab-btn.active .tab-small-title,
.mimirio-tab-btn.active .tab-main-title {
    color: #fff;
}

.mimirio-tab-btn:hover:not(.active) {
    background-color: rgba(47, 72, 88, 0.07);
}

/* ── Tabs Section: Teal Blue background overrides ───────────────── */
.bg-dark-blue .mimirio-tabs-nav {
    border-color: rgba(255, 255, 255, 0.3);
}

.bg-dark-blue .mimirio-tab-btn {
    border-right-color: rgba(255, 255, 255, 0.3);
}

.bg-dark-blue .mimirio-tab-btn .tab-small-title {
    color: rgba(255, 255, 255, 0.7);
}

.bg-dark-blue .mimirio-tab-btn .tab-main-title {
    color: #fff;
}

.bg-dark-blue .mimirio-tab-btn:hover:not(.active) {
    background-color: rgba(255, 255, 255, 0.15);
}

.bg-dark-blue .mimirio-tab-btn.active {
    background-color: #fff;
    border-right-color: #fff;
}

.bg-dark-blue .mimirio-tab-btn.active .tab-small-title {
    color: var(--color-link-blue, #5190C8);
}

.bg-dark-blue .mimirio-tab-btn.active .tab-main-title {
    color: var(--color-teal-blue, #2F4858);
}

@media (max-width: 600px) {
    .mimirio-tabs-nav {
        flex-direction: column;
        border-radius: 8px;
    }

    .mimirio-tab-btn {
        border-right: none;
        border-bottom: 1px solid var(--color-teal-20, #d5dade);
    }

    .mimirio-tab-btn:last-child {
        border-bottom: none;
    }

    .bg-dark-blue .mimirio-tab-btn {
        border-bottom-color: rgba(255, 255, 255, 0.3);
    }
}

.mimirio-tab-panel {
    display: none;
}

.mimirio-tab-panel.active {
    display: block;
}

.mimirio-tabs-panels {
    border: 1px solid var(--color-teal-20, #d5dade);
    border-radius: 8px;
    padding: 24px 28px;
    background-color: var(--color-teal-5, #f5f6f7);
}

/* ── Tab body: content prose styles ───────────────────────────────── */
.mimirio-tab-content p {
    margin-bottom: 1em;
    line-height: 1.7;
}

.mimirio-tab-content h2,
.mimirio-tab-content h3,
.mimirio-tab-content h4 {
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-teal-blue, #2F4858);
    margin-top: 1.25em;
    margin-bottom: 0.5em;
}

.mimirio-tab-content h2 { font-size: 1.375rem; }
.mimirio-tab-content h3 { font-size: 1.125rem; }
.mimirio-tab-content h4 { font-size: 1rem; }

.mimirio-tab-content ul,
.mimirio-tab-content ol {
    padding-left: 1.5em;
    margin-bottom: 1em;
}

.mimirio-tab-content ul { list-style-type: disc; }
.mimirio-tab-content ol { list-style-type: decimal; }

.mimirio-tab-content li {
    margin-bottom: 0.25em;
    line-height: 1.6;
}

/* ── Tab content: teal blue background body text fix ──────────────── */
.bg-dark-blue .mimirio-tab-content p,
.bg-dark-blue .mimirio-tab-content li {
    color: var(--color-teal-blue, #2F4858);
}

/* ── Meta Line ─────────────────────────────────────────────────────── */
.mimirio-meta-line {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.05rem;
    font-weight: 500;
    color: var(--meta-line-color, var(--color-teal-blue, #2f4858));
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.mimirio-meta-line::before {
    content: '';
    display: inline-block;
    width: 2rem;
    height: 1px;
    background-color: var(--meta-line-color, var(--color-teal-blue, #2f4858));
    flex-shrink: 0;
}

/* ── Tag cloud ────────────────────────────────────────────────────── */
.mimirio-tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1.5rem;
}

.mimirio-tag {
    display: inline-block;
    padding: 4px 14px;
    border-radius: 100px;
    border: 1px solid var(--color-sky, #86BBF0);
    color: var(--color-color-sky, #86BBF0);
    font-size: 0.75rem;
    font-weight: 500;
    background-color: var(--color-iceberg, #e3effc);
    white-space: nowrap;
    transition: background-color 0.15s ease, border-color 0.15s ease;
}

.mimirio-tag:hover {
    background-color: var(--color-sky, #86BBF0);
    border-color: var(--color-sky, #86BBF0);
    color: #fff;
}

/* ── Apps Grid ──────────────────────────────────────────────────────── */
.mimirio-apps-grid__grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 2.5rem;
}

/* Wide layout – 3 cols sm, 4 cols md, 7 cols lg+ */
@media (min-width: 640px) {
    .mimirio-apps-grid__grid--wide {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (min-width: 768px) {
    .mimirio-apps-grid__grid--wide {
        grid-template-columns: repeat(4, 1fr);
    }
}
@media (min-width: 1024px) {
    .mimirio-apps-grid__grid--wide {
        grid-template-columns: repeat(7, 1fr);
    }
}

/* Narrow layout – 1 col default, 2 cols sm, 3 cols md+ */
@media (max-width: 639px) {
    .mimirio-apps-grid__grid--narrow {
        grid-template-columns: 1fr;
    }
}
@media (min-width: 640px) {
    .mimirio-apps-grid__grid--narrow {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (min-width: 768px) {
    .mimirio-apps-grid__grid--narrow {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ── App Card ────────────────────────────────────────────────────────── */
.mimirio-app-card {
    background: #fff;
    border: 1px solid var(--color-teal-20, #d5dade);
    border-radius: var(--wp--custom--border-radius--base, 0.5rem); /* 8px */
    padding: 1.25rem 1rem;
    text-align: center;
    box-shadow: 0 1px 4px rgba(47, 72, 88, 0.07), 0 2px 8px rgba(47, 72, 88, 0.04);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
}

.mimirio-app-card__icon {
    width: 3.5rem;
    height: 3.5rem;
    margin-bottom: 0.75rem;
    color: var(--color-link-blue, #5190c8);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.mimirio-app-card__icon i {
    width: 3.5rem;
    height: 3.5rem;
}

.mimirio-app-card__icon img {
    width: 3.5rem;
    height: 3.5rem;
    object-fit: contain;
}

.mimirio-app-card__heading {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-teal-blue, #2f4858);
    line-height: 1.3;
    margin-bottom: 0.25rem;
}

.mimirio-app-card__subline {
    font-size: 0.75rem; /* 12px */
    color: var(--color-teal-50, #97A3AB);
    line-height: 1.4;
}

/* ── Section block h2 line-height fix ───────────────────────────────────── *
 * Tailwind's md:text-4xl sets line-height: 2.5rem, which clips descenders  *
 * (g, p, y…) at the bottom of h2 headings. Override to 2.75rem for all     *
 * section-block h2 headings at the md breakpoint and above.                *
 */
@media (min-width: 768px) {
    .mimirio-content-section h2,
    .mimirio-content-image h2,
    .mimirio-use-case-grid h2,
    .mimirio-stepper h2,
    .mimirio-tabs-section h2,
    .mimirio-apps-grid h2,
    .mimirio-cta h2,
    .mimirio-stats h2 {
        line-height: 2.75rem;
    }
}

/* ── Stat Item: responsive value font-size ─────────────────────────── */
/* At md breakpoint (768 – 1023 px) the grid switches from 2 to 4 cols.
   Reduce the large number to avoid overflow in narrower card columns.  */
@media (min-width: 768px) and (max-width: 1023px) {
    .mimirio-stats[data-maxwidth="7xl"] .mimirio-stat-value,
    .mimirio-stats[data-maxwidth="4xl"] .mimirio-stat-value {
        font-size: 55px;
    }
}

/* ═══════════════════════════════════════════════════════════════════════
   Feature Grid + Feature Item
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Grid section header ──────────────────────────────────────────────── */
.mimirio-feature-grid__header {
    margin-bottom: 2.5rem;
}

@media (min-width: 768px) {
    .mimirio-feature-grid__header {
        margin-bottom: 3.5rem;
    }
    .mimirio-feature-grid h2 {
        line-height: 2.75rem;
    }
}

/* ── Seamless grid inner wrapper ──────────────────────────────────────── */
.mimirio-feature-grid__inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5px;
    /* Separator colour shown through the gaps and as a border */
    background: rgba(0, 0, 0, 0.10);
    border: 1.5px solid rgba(0, 0, 0, 0.10);
    border-radius: 12px;
    overflow: hidden;
    align-items: stretch;
}

/* Lighter separator on dark (teal-blue) background */
.mimirio-feature-grid[data-bg="teal-blue"] .mimirio-feature-grid__inner {
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.18);
}

/* Slightly stronger separator on sky background */
.mimirio-feature-grid[data-bg="sky"] .mimirio-feature-grid__inner {
    background: rgba(47, 72, 88, 0.18);
    border-color: rgba(47, 72, 88, 0.18);
}

/* M (768 px – 1023 px): 2 columns for both layout modes */
@media (min-width: 768px) {
    .mimirio-feature-grid__inner {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* L+ (≥ 1024 px): layout-specific column counts */
@media (min-width: 1024px) {
    /* Single Row: up to 4 columns */
    .mimirio-feature-grid--single-row .mimirio-feature-grid__inner {
        grid-template-columns: repeat(4, 1fr);
    }
    /* Grid (3 × 2): 3 columns */
    .mimirio-feature-grid--grid .mimirio-feature-grid__inner {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ── Feature Item cell ────────────────────────────────────────────────── */
.mimirio-feature-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem 1.5rem;
    transition: filter 0.2s ease;
}

a.mimirio-feature-item {
    cursor: pointer;
}

a.mimirio-feature-item:hover {
    filter: brightness(0.95);
}

/* ── Item text colour variants ────────────────────────────────────────── */
.mimirio-feature-item--dark {
    color: #ffffff;
}

.mimirio-feature-item--light {
    color: #2f4858;
}

/* ── Meta label ───────────────────────────────────────────────────────── */
.mimirio-feature-item__meta {
    display: inline-block;
    font-size: 0.6875rem;   /* 11 px */
    font-weight: 500;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 3px 12px;
    border-radius: 20px;
    margin-bottom: 1.25rem;
    background: rgba(81, 144, 200, 0.12);
    color: #5190c8;
}

.mimirio-feature-item--dark .mimirio-feature-item__meta {
    background: rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.85);
}

/* ── Icon / logo ──────────────────────────────────────────────────────── */
.mimirio-feature-item__icon {
    width: 2.5rem;   /* 40 px */
    height: 2.5rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.mimirio-feature-item__icon i {
    width: 2.5rem;
    height: 2.5rem;
}

.mimirio-feature-item__icon img {
    max-width: 100%;
    max-height: 2.5rem;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

/* ── Heading ──────────────────────────────────────────────────────────── */
.mimirio-feature-item__heading {
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.3;
    margin-bottom: 0.5rem;
    color: inherit;
}

/* ── Description ─────────────────────────────────────────────────────── */
.mimirio-feature-item__description {
    font-size: 0.875rem;
    line-height: 1.65;
    margin-bottom: 1rem;
    color: inherit;
    opacity: 0.75;
}

.mimirio-feature-item--dark .mimirio-feature-item__description {
    opacity: 0.65;
}

/* ── Tags ─────────────────────────────────────────────────────────────── */
.mimirio-feature-item__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.375rem;
    justify-content: center;
    margin-top: auto;
    padding-top: 0.875rem;
}

.mimirio-feature-item__tag {
    font-size: 0.6875rem;
    padding: 3px 10px;
    border-radius: 20px;
    border: 1px solid rgba(47, 72, 88, 0.25);
    color: rgba(47, 72, 88, 0.7);
}

.mimirio-feature-item--dark .mimirio-feature-item__tag {
    border-color: rgba(255, 255, 255, 0.3);
    color: rgba(255, 255, 255, 0.7);
}

/* ── CTA text link ────────────────────────────────────────────────────── */
.mimirio-feature-item__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: #5190c8;
    text-decoration: none;
    margin-top: auto;
    padding-top: 0.875rem;
    transition: color 0.2s ease;
}

.mimirio-feature-item--dark .mimirio-feature-item__cta {
    color: #86bbf0;
}

.mimirio-feature-item__cta:hover {
    color: #2f4858;
    text-decoration: none;
}

.mimirio-feature-item--dark .mimirio-feature-item__cta:hover {
    color: #ffffff;
}

.mimirio-feature-item__cta i {
    width: 1rem;
    height: 1rem;
    flex-shrink: 0;
}

.mimirio-feature-item__cta-text {
    display: inline-block;
    font-size: 0.875rem;
    font-weight: 500;
    margin-top: auto;
    padding-top: 0.875rem;
    color: inherit;
    opacity: 0.8;
}

/* ── Logos Grid ────────────────────────────────────────────────────────
 * Parent section: mimirio/logos-grid
 * Child items:    mimirio/logo-item
 *
 * Layout (flex, gap, responsive widths) is applied via Tailwind utility
 * classes directly in the PHP render callbacks.  Only the rules that
 * cannot be expressed as a single utility class remain here:
 *   – height/width constraint on the image (needs two-class specificity
 *     to beat Tailwind preflight's img{height:auto} without !important)
 *   – text-decoration / color reset on the link wrapper
 *   – colour-filter modifier classes (.mimirio-logos-row--*-filter)
 *   – .white-logo-filter helper
 * ───────────────────────────────────────────────────────────────────── */

/* Logo image
 * Explicit height (not max-height) so flex computes width:auto from the
 * image's intrinsic aspect ratio.  Two-class specificity (0,2,0) beats
 * Tailwind preflight's img{height:auto} (0,0,1) without !important.
 */
.mimirio-logo-item .mimirio-logo-item__img {
    height: 3rem;
    width: auto;
    transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Logo link wrapper – reset any global link styles */
.mimirio-logo-item .mimirio-logo-item__link {
    text-decoration: none;
    color: inherit;
}
.mimirio-logo-item .mimirio-logo-item__link:hover,
.mimirio-logo-item .mimirio-logo-item__link:focus-visible {
    text-decoration: none;
    color: inherit;
}

/* ── White filter: logos become white (for Teal Blue backgrounds) ──── */
.mimirio-logos-row--white-filter .mimirio-logo-item__img {
    filter: brightness(0) invert(1);
    opacity: 0.9;
    transition: filter 0.3s ease, opacity 0.3s ease;
}

/* ── Greyscale filter: logos desaturated, colour revealed on hover ─── */
.mimirio-logos-row--grayscale-filter .mimirio-logo-item__img {
    filter: grayscale(1);
    opacity: 0.6;
    transition: filter 0.3s ease, opacity 0.3s ease;
}

.mimirio-logos-row--grayscale-filter .mimirio-logo-item:hover .mimirio-logo-item__img,
.mimirio-logos-row--grayscale-filter .mimirio-logo-item:focus-within .mimirio-logo-item__img {
    filter: grayscale(0);
    opacity: 1;
}

/* ── Helper utility class (usable as "Additional CSS Class") ────────── */
/* Applies a white filter to all images inside the container.           */
.white-logo-filter img {
    filter: brightness(0) invert(1) !important;
    transition: filter 0.3s ease;
}
