.ifhub-home .ifhub-section,
body.home .ifhub-section,
body.front-page .ifhub-section {
    position: relative;
    padding: 5rem 0;
}

.ifhub-section-heading-centered {
    margin-left: 0;
    margin-right: 0;
    text-align: left;
}

.ifhub-section-heading-centered h2 {
    max-width: 24ch;
    margin-left: 0;
    margin-right: 0;
}

.ifhub-section-heading-centered h2::after {
    margin-left: 0;
    margin-right: 0;
}

.ifhub-hero {
    position: relative;
    overflow: hidden;
    background: var(--color-surface-warm);
    padding: 3.4rem 0 4.8rem;
}

.ifhub-hero-media {
    position: absolute;
    inset: 0 0 0 auto;
    width: min(52%, 50rem);
    overflow: hidden;
}

.ifhub-hero-media::before {
    content: '';
    position: absolute;
    top: -6%;
    bottom: -6%;
    left: -14%;
    width: 35%;
    z-index: 2;
    pointer-events: none;
    background: linear-gradient(90deg, rgba(250, 248, 252, 1) 0%, rgba(250, 248, 252, 0.78) 48%, rgba(250, 248, 252, 0) 100%);
}

.ifhub-hero-media-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 48% center;
}

.ifhub-hero-media-fade {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(90deg, rgba(250, 248, 252, 0.92) 0%, rgba(250, 248, 252, 0.64) 14%, rgba(250, 248, 252, 0.18) 32%, rgba(250, 248, 252, 0) 100%);
}

.ifhub-hero-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 37rem) minmax(16rem, 1fr);
    gap: 2.5rem;
    align-items: center;
    min-height: 33rem;
}

.ifhub-hero-copy {
    max-width: 37rem;
}

.ifhub-hero-copy h1 {
    max-width: 10.5ch;
    margin-bottom: 1.35rem;
    font-size: clamp(3.1rem, 5.4vw, 4.7rem);
    line-height: 0.98;
}

.ifhub-hero-text {
    max-width: 32rem;
    margin-bottom: 1.35rem;
    color: var(--color-ink-muted);
    font-size: 1.04rem;
    line-height: 1.68;
}

.ifhub-hero-proof {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem 1rem;
    margin: 0 0 1.55rem;
    padding: 0;
    list-style: none;
    color: var(--color-ink-muted);
    font-size: 0.9rem;
}

.ifhub-hero-proof li {
    position: relative;
    padding-left: 0.9rem;
}

.ifhub-hero-proof li::before {
    content: '';
    position: absolute;
    top: 0.68em;
    left: 0;
    width: 0.38rem;
    height: 1px;
    background: var(--color-primary);
}

.ifhub-offer-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin-bottom: 1.9rem;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.ifhub-offer-card {
    padding: 1rem 1.15rem 1.05rem 0;
}

.ifhub-offer-card + .ifhub-offer-card {
    padding-left: 1.15rem;
    border-left: 1px solid var(--color-border);
}

.ifhub-offer-card span,
.ifhub-offer-card strong {
    display: block;
}

.ifhub-offer-card span {
    margin-bottom: 0.28rem;
    color: var(--color-ink-light);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
}

.ifhub-offer-card strong {
    color: var(--color-ink);
    font-size: 0.98rem;
    font-weight: 700;
    line-height: 1.45;
}

.ifhub-button-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.9rem;
    align-items: center;
}

.ifhub-hero-link {
    display: inline-flex;
    align-items: center;
    min-height: 2.8rem;
    color: var(--color-ink);
    font-size: 0.92rem;
    font-weight: 500;
    text-decoration: underline;
    text-decoration-color: rgba(126, 96, 191, 0.7);
    text-underline-offset: 0.35rem;
}

.ifhub-hero-link:hover {
    color: var(--color-primary);
}

.ifhub-hero-spacer {
    min-height: 1px;
}

.ifhub-section-process,
.ifhub-section-team {
    background: var(--color-surface);
}

.ifhub-section-process .ifhub-container,
.ifhub-section-team .ifhub-container {
    position: relative;
}

.ifhub-section-process::before,
.ifhub-section-process::after,
.ifhub-section-team::before,
.ifhub-section-team::after {
    display: none;
}

.ifhub-step-grid {
    position: relative;
    isolation: isolate;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin-top: 2.4rem;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.ifhub-step-grid::before {
    display: none;
}

.ifhub-step-card {
    position: relative;
    z-index: 1;
    overflow: hidden;
    min-height: 100%;
    padding: 1.7rem 1.55rem 1.8rem;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.ifhub-step-card + .ifhub-step-card {
    border-left: 1px solid var(--color-border);
}

.ifhub-step-card:hover {
    box-shadow: none;
}

.ifhub-step-icon {
    position: relative;
    z-index: 1;
    isolation: isolate;
    display: none;
    align-items: center;
    justify-content: center;
    width: 1.25rem;
    height: 1.25rem;
    margin-bottom: 0.9rem;
    border: 0;
    border-radius: 0;
    color: #7e60bf;
    background: transparent;
}

.ifhub-step-icon svg {
    width: 1.2rem;
    height: 1.2rem;
}

.ifhub-step-number {
    display: block;
    margin-bottom: 0.85rem;
    color: var(--color-primary);
    font-family: var(--font-body);
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0;
    line-height: 1;
}

.ifhub-step-card h3 {
    position: relative;
    z-index: 1;
    max-width: 15ch;
    margin-bottom: 0.65rem;
    font-size: 1.22rem;
    color: var(--color-ink);
}

.ifhub-step-card p {
    position: relative;
    z-index: 1;
    margin: 0;
    color: var(--color-ink-muted);
    max-width: 23rem;
    font-size: 0.93rem;
    line-height: 1.62;
}

.ifhub-home .ifhub-section-process {
    padding-bottom: 1rem;
}

.ifhub-home .ifhub-section-team {
    padding-top: 1rem;
}

.ifhub-section-team .ifhub-section-heading {
    margin-bottom: 0.2rem;
}

.ifhub-tutor-grid {
    position: relative;
    isolation: isolate;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 1.25rem;
    margin-top: 2.4rem;
}

.ifhub-tutor-grid::before {
    display: none;
}

.ifhub-tutor-card {
    position: relative;
    z-index: 1;
    overflow: hidden;
    border: 1px solid var(--color-border);
    border-radius: 12px;
    background: #fff;
    box-shadow: var(--shadow-sm);
}

.ifhub-tutor-card:hover {
    border-color: var(--color-border-strong);
    box-shadow: var(--shadow-sm);
}

.ifhub-tutor-card.is-featured {
    display: grid;
    grid-template-columns: minmax(10rem, 0.8fr) minmax(0, 1.4fr);
    gap: 1.6rem;
    padding: 1.35rem;
}

.ifhub-tutor-aura {
    display: none;
}

.ifhub-tutor-card.is-featured .ifhub-tutor-visual {
    grid-column: 1;
    grid-row: 1;
}

.ifhub-tutor-card.is-featured .ifhub-tutor-copy {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
}

.ifhub-tutor-card.is-compact {
    padding: 1.45rem 1.45rem 1.6rem;
}

.ifhub-tutor-visual {
    position: relative;
    z-index: 1;
    border-radius: 8px;
    overflow: hidden;
}

.ifhub-tutor-photo {
    width: 100%;
    height: 100%;
    min-height: 14rem;
    object-fit: cover;
    object-position: center top;
    border: none;
}

.ifhub-tutor-visual-fallback {
    min-height: 12rem;
    border: none;
    background: var(--color-surface-warm);
}

.ifhub-tutor-copy {
    position: relative;
    z-index: 1;
}

.ifhub-tutor-role {
    margin-bottom: 0.55rem;
    color: var(--color-ink-light);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: none;
}

.ifhub-tutor-copy h3 {
    margin-bottom: 0.55rem;
    font-size: 1.15rem;
    color: var(--color-ink);
}

.ifhub-tutor-card.is-compact .ifhub-tutor-copy h3 {
    font-size: 1.15rem;
}

.ifhub-tutor-copy p {
    margin-bottom: 1rem;
    color: var(--color-ink-muted);
    font-size: 0.94rem;
    line-height: 1.62;
}

.ifhub-tutor-credentials {
    margin-top: 0.9rem;
}

.ifhub-tutor-credentials li {
    margin-bottom: 0.6rem;
    color: var(--color-ink-muted);
    font-size: 0.86rem;
}

.ifhub-tutor-copy small {
    display: none;
}

.ifhub-section-cta {
    margin-top: 2rem;
    text-align: center;
}

.ifhub-final-cta {
    padding: 4.5rem 0;
    text-align: center;
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
}

.ifhub-final-cta h2 {
    max-width: 42rem;
    margin: 0 auto 1.75rem;
}

/* Trust strip */
.ifhub-trust-strip {
    padding: 1.35rem 0;
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(107, 70, 193, 0.08);
}

.ifhub-trust-strip-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1.5rem;
}

.ifhub-trust-strip-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.ifhub-trust-strip-item svg {
    width: 2rem;
    height: 2rem;
    flex-shrink: 0;
    color: var(--color-primary);
}

.ifhub-trust-strip-item strong {
    display: block;
    font-size: 0.88rem;
    color: var(--color-ink);
    line-height: 1.3;
}

.ifhub-trust-strip-item span {
    display: block;
    font-size: 0.76rem;
    color: var(--color-ink-muted);
    line-height: 1.3;
}

/* Instrument category cards */
.ifhub-section-categories {
    padding: var(--section-gap) 0;
    background:
        radial-gradient(circle at 30% 50%, rgba(234, 225, 255, 0.2) 0%, transparent 30%),
        radial-gradient(circle at 70% 50%, rgba(234, 225, 255, 0.2) 0%, transparent 30%),
        #fff;
}

.ifhub-category-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
    margin-top: 3rem;
}

.ifhub-instrument-card {
    position: relative;
    padding: 2.25rem 2rem;
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
    text-align: center;
    overflow: hidden;
    transition: transform var(--duration-md) var(--ease-out), box-shadow var(--duration-md) var(--ease-out), border-color var(--duration-md) var(--ease-out);
}

.ifhub-instrument-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
}

.ifhub-instrument-brass::before {
    background: linear-gradient(90deg, #B67A3C, #D4A574);
}

.ifhub-instrument-singing::before {
    background: linear-gradient(90deg, #C66B52, #E09A86);
}

.ifhub-instrument-percussion::before {
    background: linear-gradient(90deg, #4F6B72, #7A9AA3);
}

.ifhub-instrument-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(126, 96, 191, 0.18);
}

.ifhub-instrument-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    margin-bottom: 1.25rem;
    border-radius: 50%;
    background: rgba(126, 96, 191, 0.06);
    color: var(--color-primary);
}

.ifhub-instrument-card h3 {
    font-size: 1.4rem;
    font-family: var(--font-heading);
    margin-bottom: 0.6rem;
}

.ifhub-instrument-card p {
    margin-bottom: 0;
    color: var(--color-ink-muted);
    font-size: 0.92rem;
}

.ifhub-instrument-tutor {
    display: block;
    margin: 1rem 0 1.35rem;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--color-ink-muted);
    font-style: italic;
    font-family: var(--font-heading);
}

/* Dark portal preview section */
.ifhub-section-portal-preview {
    padding: 5.5rem 0 6rem;
    background: linear-gradient(180deg, #2D1A4C 0%, #1E1233 100%);
    color: var(--color-text-inv);
    overflow: hidden;
}

.ifhub-section-portal-preview h2 {
    color: var(--color-text-inv);
    max-width: 22ch;
    margin-left: auto;
    margin-right: auto;
}

.ifhub-section-portal-preview .ifhub-section-heading h2::after {
    background: linear-gradient(135deg, var(--color-secondary), rgba(255, 255, 255, 0.35));
}

.ifhub-kicker-light {
    color: var(--color-secondary);
}

.ifhub-deck-light {
    color: var(--color-text-inv-muted) !important;
}

.ifhub-portal-mockup {
    max-width: 48rem;
    margin: 3rem auto 0;
}

.ifhub-mockup-browser {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(255, 255, 255, 0.08);
}

.ifhub-mockup-toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: rgba(255, 255, 255, 0.06);
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.ifhub-mockup-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.15);
}

.ifhub-mockup-dot:first-child {
    background: #ff5f57;
}

.ifhub-mockup-dot:nth-child(2) {
    background: #ffbd2e;
}

.ifhub-mockup-dot:nth-child(3) {
    background: #28c840;
}

.ifhub-mockup-url {
    margin-left: 0.75rem;
    padding: 0.25rem 0.75rem;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.4);
    font-size: 0.72rem;
    font-family: monospace;
}

.ifhub-mockup-content {
    padding: 1.5rem;
    background: linear-gradient(180deg, #f8f6fc, #f4f0ff);
}

.ifhub-mockup-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.ifhub-mockup-stat {
    padding: 0.85rem;
    background: white;
    border: 1px solid rgba(126, 96, 191, 0.1);
    border-radius: 8px;
    text-align: center;
}

.ifhub-mockup-stat span {
    display: block;
    font-size: 0.6rem;
    font-weight: 600;
    color: #4E4B63;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.ifhub-mockup-stat strong {
    display: block;
    font-size: 1.4rem;
    font-family: var(--font-heading);
    color: var(--color-primary);
    margin-top: 0.2rem;
}

.ifhub-mockup-card {
    padding: 1rem;
    background: white;
    border: 1px solid rgba(126, 96, 191, 0.1);
    border-radius: 8px;
    margin-bottom: 0.75rem;
}

.ifhub-mockup-card:last-child {
    margin-bottom: 0;
}

.ifhub-mockup-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.6rem;
}

.ifhub-mockup-line-long {
    width: 55%;
    height: 8px;
    border-radius: 4px;
    background: #2A1B44;
}

.ifhub-mockup-line {
    width: 80%;
    height: 5px;
    border-radius: 3px;
    background: #E8E0F5;
    margin-bottom: 0.35rem;
}

.ifhub-mockup-line-short {
    width: 50%;
    height: 5px;
    border-radius: 3px;
    background: #E8E0F5;
}

.ifhub-mockup-badge {
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.55rem;
    font-weight: 700;
    background: #FAF5FF;
    color: #7E22CE;
    border: 1px solid #F3E8FF;
    white-space: nowrap;
}

.ifhub-mockup-badge-review {
    background: #EFF6FF;
    color: #1D4ED8;
    border-color: #DBEAFE;
}

.ifhub-mockup-actions {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.75rem;
}

.ifhub-mockup-btn {
    padding: 0.3rem 0.65rem;
    border-radius: 6px;
    background: var(--color-primary);
    color: white;
    font-size: 0.6rem;
    font-weight: 600;
}

.ifhub-mockup-btn-outline {
    padding: 0.3rem 0.65rem;
    border-radius: 6px;
    border: 1px solid #E8E0F5;
    color: #2A1B44;
    font-size: 0.6rem;
    font-weight: 600;
    background: white;
}

/* FAQ teaser section */
.ifhub-section-faq-teaser {
    padding: var(--section-gap) 0;
    background:
        radial-gradient(circle at 18% 46%, rgba(234, 225, 255, 0.2) 0%, transparent 28%),
        radial-gradient(circle at 82% 46%, rgba(234, 225, 255, 0.2) 0%, transparent 28%),
        #fff;
}

.ifhub-faq-teaser-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.55fr) minmax(0, 1.45fr);
    gap: 2.5rem;
    align-items: start;
}

.ifhub-section-faq-teaser .ifhub-section-heading {
    margin-bottom: 0;
}

.ifhub-section-faq-teaser .ifhub-link-button {
    margin-top: 1.25rem;
}

.ifhub-faq-teaser-list {
    display: grid;
    gap: 0.35rem;
}

/* Rich final CTA */
.ifhub-final-cta-rich {
    position: relative;
    padding: 5.5rem 0;
    background: var(--color-surface);
    border-top: 1px solid var(--color-border);
    overflow: hidden;
}

.ifhub-final-cta-rich::before {
    display: none;
}

.ifhub-final-cta-rich .ifhub-kicker {
    margin-bottom: 0.5rem;
}

.ifhub-final-cta-actions {
    justify-content: center;
    margin-top: 2rem;
}

@media (max-width: 1120px) {
    .ifhub-hero {
        padding-top: 2.6rem;
    }

    .ifhub-hero-grid {
        grid-template-columns: minmax(0, 32rem) minmax(10rem, 1fr);
        min-height: 29rem;
    }

    .ifhub-section-process::before,
    .ifhub-section-process::after,
    .ifhub-section-team::before,
    .ifhub-section-team::after {
        width: 4.5rem;
    }
}

@media (max-width: 860px) {
    .ifhub-home .ifhub-section {
        padding: 3.2rem 0;
    }

    .ifhub-hero {
        padding-top: 2rem;
        padding-bottom: 2.8rem;
    }

    .ifhub-hero-media {
        width: 52%;
    }

    .ifhub-hero-grid {
        grid-template-columns: minmax(0, 23rem) minmax(12rem, 1fr);
        gap: 1.25rem;
        min-height: 24rem;
    }

    .ifhub-hero-media::before {
        left: -12%;
        width: 24%;
        filter: blur(14px);
    }

    .ifhub-hero-copy { max-width: 23rem; }

    .ifhub-kicker { margin-bottom: 0.65rem; font-size: 0.76rem; }

    .ifhub-hero-copy h1 {
        max-width: 9.5ch;
        margin-bottom: 0.75rem;
        font-size: clamp(2.8rem, 6vw, 3.75rem);
        line-height: 0.98;
    }

    .ifhub-hero-text {
        max-width: 22rem;
        margin-bottom: 1rem;
        font-size: 0.9rem;
        line-height: 1.6;
    }

    .ifhub-hero-proof {
        gap: 0.4rem 0.7rem;
        margin-bottom: 1rem;
        font-size: 0.76rem;
    }

    .ifhub-offer-strip {
        margin-bottom: 1rem;
    }

    .ifhub-offer-card {
        padding: 0.75rem 0.7rem 0.75rem 0;
    }

    .ifhub-offer-card + .ifhub-offer-card {
        padding-left: 0.7rem;
    }

    .ifhub-offer-card span { font-size: 0.68rem; }

    .ifhub-offer-card strong {
        font-size: 0.84rem;
        line-height: 1.36;
    }

    .ifhub-button-row {
        gap: 0.65rem;
    }

    .ifhub-button-large {
        padding: 0.62rem 1rem;
        font-size: 0.78rem;
    }

    .ifhub-hero-link {
        min-height: 2rem;
        font-size: 0.78rem;
        text-underline-offset: 0.2rem;
    }

    .ifhub-section-heading { margin-bottom: 1.1rem; }

    .ifhub-section-heading-centered h2 { max-width: min(100%, 18rem); white-space: normal; }

    .ifhub-section-heading-centered .ifhub-kicker { margin-bottom: 0.4rem; }

    .ifhub-section-heading-centered h2 { font-size: 1.72rem; line-height: 1.12; }

    .ifhub-section-process {
        padding-top: 2.5rem;
        padding-bottom: 1.75rem;
    }

    .ifhub-section-team {
        padding-top: 1.75rem;
        padding-bottom: 2.25rem;
    }

    .ifhub-section-team .ifhub-section-heading {
        margin-bottom: 0;
    }

    .ifhub-step-grid {
        gap: 0;
        margin-top: 1.35rem;
    }

    .ifhub-step-card {
        padding: 1.2rem 0.85rem 1.25rem;
        border-radius: 0;
    }

    .ifhub-step-icon {
        width: 2rem;
        height: 2rem;
        margin-bottom: 0.35rem;
    }

    .ifhub-step-number { font-size: 0.72rem; margin-bottom: 0.5rem; }

    .ifhub-step-card h3 {
        font-size: 0.98rem;
        margin-bottom: 0.42rem;
    }

    .ifhub-step-card p {
        font-size: 0.78rem;
        line-height: 1.48;
    }

    .ifhub-tutor-grid {
        grid-template-columns: 1fr;
        gap: 1rem;
        margin-top: 1.3rem;
    }

    .ifhub-tutor-aura {
        display: none;
    }

    .ifhub-tutor-card.is-featured {
        grid-template-columns: minmax(9rem, 10.5rem) minmax(0, 1fr);
        gap: 1.25rem;
        padding: 1.1rem;
        align-items: start;
    }

    .ifhub-tutor-card.is-compact {
        padding: 1rem;
    }

    .ifhub-tutor-card { border-radius: 14px; }

    .ifhub-tutor-card.is-featured .ifhub-tutor-visual {
        width: 100%;
        max-width: 10.5rem;
        height: auto;
        aspect-ratio: 150 / 230;
        grid-column: 1;
        grid-row: 1;
        justify-self: start;
    }

    .ifhub-tutor-card.is-featured .ifhub-tutor-copy {
        grid-column: 2;
        grid-row: 1;
        align-self: start;
    }

    .ifhub-tutor-photo {
        min-height: 10rem;
    }

    .ifhub-tutor-card.is-featured .ifhub-tutor-photo {
        height: 100%;
        min-height: 0;
        object-position: center center;
    }

    .ifhub-tutor-role { font-size: 0.68rem; margin-bottom: 0.34rem; }

    .ifhub-tutor-copy h3 { font-size: 1rem; margin-bottom: 0.3rem; }

    .ifhub-tutor-copy p {
        font-size: 0.82rem;
        margin-bottom: 0.6rem;
        line-height: 1.48;
    }

    .ifhub-tutor-credentials li {
        margin-bottom: 0.35rem;
        padding-left: 1rem;
        font-size: 0.74rem;
    }

    .ifhub-tutor-credentials li::before {
        top: 0.35rem;
        width: 4px;
        height: 4px;
    }

    .ifhub-section-cta {
        margin-top: 1rem;
    }

    .ifhub-section-cta .ifhub-button-large {
        padding: 0.6rem 1.1rem;
        font-size: 0.78rem;
    }

    .ifhub-trust-strip { padding: 0.85rem 0; }
    .ifhub-trust-strip-item strong { font-size: 0.72rem; }
    .ifhub-trust-strip-item span { font-size: 0.62rem; }
    .ifhub-trust-strip-item svg { width: 1.4rem; height: 1.4rem; }

    .ifhub-section-categories { padding: 2rem 0; }
    .ifhub-category-grid { gap: 0.7rem; margin-top: 1.5rem; }
    .ifhub-instrument-card { padding: 1.25rem 1rem; }
    .ifhub-instrument-icon { width: 2.5rem; height: 2.5rem; margin-bottom: 0.75rem; }
    .ifhub-instrument-card h3 { font-size: 1.1rem; }
    .ifhub-instrument-card p { font-size: 0.78rem; }
    .ifhub-instrument-tutor { font-size: 0.7rem; margin: 0.6rem 0 0.85rem; }

    .ifhub-section-portal-preview { padding: 2.5rem 0 3rem; }
    .ifhub-portal-mockup { margin-top: 1.5rem; }
    .ifhub-mockup-content { padding: 0.85rem; }
    .ifhub-mockup-stats { gap: 0.4rem; }
    .ifhub-mockup-stat { padding: 0.5rem; }
    .ifhub-mockup-stat span { font-size: 0.5rem; }
    .ifhub-mockup-stat strong { font-size: 1rem; }
    .ifhub-mockup-card { padding: 0.65rem; }
    .ifhub-mockup-line-long { height: 6px; }
    .ifhub-mockup-line, .ifhub-mockup-line-short { height: 4px; }
    .ifhub-mockup-badge { font-size: 0.48rem; padding: 0.15rem 0.35rem; }

    .ifhub-section-faq-teaser { padding: 2rem 0; }
    .ifhub-final-cta-rich { padding: 3rem 0; }
}

@media (max-width: 720px) {
    .ifhub-home .ifhub-section {
        padding: 4.3rem 0;
    }

    .ifhub-section-process::before,
    .ifhub-section-process::after,
    .ifhub-section-team::before,
    .ifhub-section-team::after {
        display: none;
    }

    .ifhub-hero {
        padding-bottom: 3rem;
    }

    .ifhub-hero-media {
        position: relative;
        inset: auto;
        width: 100%;
        height: 20rem;
        margin-top: 1.5rem;
        border-radius: 12px;
        overflow: hidden;
    }

    .ifhub-hero-media::before {
        display: none;
    }

    .ifhub-hero-media-image {
        object-position: center;
    }

    .ifhub-hero-media-fade {
        background: linear-gradient(180deg, rgba(230, 224, 250, 0.22) 0%, rgba(230, 224, 250, 0.02) 100%);
    }

    .ifhub-hero-grid {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .ifhub-hero-spacer {
        display: none;
    }

    .ifhub-hero-copy h1 {
        max-width: 8ch;
        font-size: clamp(2.8rem, 12vw, 4rem);
    }

    .ifhub-offer-strip {
        grid-template-columns: 1fr;
        gap: 0.9rem;
    }

    .ifhub-offer-card,
    .ifhub-offer-card + .ifhub-offer-card {
        padding: 0.75rem 0;
        border-left: 0;
    }

    .ifhub-offer-card + .ifhub-offer-card {
        border-top: 1px solid var(--color-border);
    }

    .ifhub-button-row {
        flex-direction: column;
        align-items: stretch;
    }

    .ifhub-button-row .ifhub-button,
    .ifhub-button-row .ifhub-link-button,
    .ifhub-section-cta .ifhub-button {
        width: 100%;
    }

    .ifhub-step-card,
    .ifhub-tutor-card.is-featured,
    .ifhub-tutor-card.is-compact {
        padding: 1.25rem;
    }

    .ifhub-step-grid,
    .ifhub-tutor-grid {
        grid-template-columns: 1fr;
    }

    .ifhub-step-card + .ifhub-step-card {
        border-left: 0;
        border-top: 1px solid var(--color-border);
    }

    .ifhub-tutor-card.is-featured {
        grid-template-columns: 1fr;
    }

    .ifhub-tutor-card.is-featured .ifhub-tutor-visual,
    .ifhub-tutor-card.is-featured .ifhub-tutor-copy {
        grid-column: 1;
        grid-row: auto;
    }

    .ifhub-trust-strip-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }

    .ifhub-category-grid {
        grid-template-columns: 1fr;
    }

    .ifhub-faq-teaser-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
    }
}

@media (max-width: 480px) {
    .ifhub-trust-strip-grid {
        grid-template-columns: 1fr;
    }
}
