/* Shared library block design presets (variant / density / accent). */

:root {
    --lib-accent: #4f8cff;
}

[class*="lib-"][class*="--density-compact"] {
    --lib-density-gap: 0.5rem;
    --lib-density-pad: 0.75rem;
}

[class*="lib-"][class*="--density-balanced"] {
    --lib-density-gap: 1rem;
    --lib-density-pad: 1.25rem;
}

[class*="lib-"][class*="--density-roomy"] {
    --lib-density-gap: 1.5rem;
    --lib-density-pad: 2rem;
}

/* Brand mark (navigation / site header logos) */
.lib-brand-mark {
    --brand-mark-accent: var(--lib-accent, #2563eb);
    display: inline-flex;
    align-items: center;
    gap: 0.55rem;
    text-decoration: none;
    color: inherit;
    max-width: min(100%, 280px);
}

.lib-brand-mark:hover { text-decoration: none; opacity: 0.92; }

.lib-brand-mark__link.navbar-brand,
.lib-brand-mark__link.site-header-brand {
    margin: 0;
    padding: 0;
}

.lib-brand-mark__image {
    display: block;
    max-height: 2.25rem;
    width: auto;
    max-width: 180px;
    object-fit: contain;
}

.lib-brand-mark__wordmark {
    font-weight: 800;
    font-size: 1.35rem;
    letter-spacing: -0.02em;
    line-height: 1.1;
    color: inherit;
}

.lib-brand-mark__monogram {
    display: grid;
    place-items: center;
    width: 2.35rem;
    height: 2.35rem;
    border-radius: 0.65rem;
    font-size: 0.85rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: #fff;
    background: linear-gradient(145deg, var(--brand-mark-accent), color-mix(in srgb, var(--brand-mark-accent) 65%, #0f172a));
    flex-shrink: 0;
}

.lib-brand-mark__initial {
    display: grid;
    place-items: center;
    width: 2.1rem;
    height: 2.1rem;
    border-radius: 50%;
    font-size: 1rem;
    font-weight: 700;
    color: var(--brand-mark-accent);
    background: color-mix(in srgb, var(--brand-mark-accent) 14%, #fff);
    border: 1px solid color-mix(in srgb, var(--brand-mark-accent) 28%, transparent);
    flex-shrink: 0;
}

.lib-brand-mark__name--beside {
    font-weight: 700;
    font-size: 1.1rem;
    line-height: 1.15;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.lib-brand-mark--monogram .lib-brand-mark__name--beside {
    font-size: 1rem;
}

@media (max-width: 576px) {
    .lib-brand-mark--monogram .lib-brand-mark__name--beside,
    .lib-brand-mark--initial-icon .lib-brand-mark__name--beside {
        display: none;
    }
}

.lib-brand-mark__stack {
    display: flex;
    flex-direction: column;
    line-height: 1.05;
    gap: 0.1rem;
}

.lib-brand-mark__stack-primary {
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--brand-mark-accent);
}

.lib-brand-mark__stack-secondary {
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: inherit;
}

.lib-brand-mark__badge {
    display: inline-block;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.95rem;
    font-weight: 700;
    color: #0f172a;
    background: color-mix(in srgb, var(--brand-mark-accent) 12%, #fff);
    border: 1px solid color-mix(in srgb, var(--brand-mark-accent) 28%, transparent);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

.lib-brand-mark__gradient {
    font-weight: 800;
    font-size: 1.3rem;
    letter-spacing: -0.02em;
    background: linear-gradient(90deg, #0f172a 0%, var(--brand-mark-accent) 70%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lib-navigation--theme-dark .lib-brand-mark__wordmark,
.lib-navigation--theme-dark .lib-brand-mark__name--beside,
.lib-navigation--theme-dark .lib-brand-mark__stack-secondary { color: #f8fafc; }

.lib-navigation--theme-dark .lib-brand-mark__badge { color: #f8fafc; background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); }

.lib-navigation--theme-dark .lib-brand-mark__gradient {
    background: linear-gradient(90deg, #f8fafc 0%, var(--brand-mark-accent) 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

.lib-site-header--theme-dark .lib-brand-mark__wordmark,
.lib-site-header--theme-dark .lib-brand-mark__name--beside,
.lib-site-header--theme-dark .lib-brand-mark__stack-secondary { color: var(--header-fg, #f8fafc); }

/* Card */
.lib-card--horizontal .card {
    display: flex;
    flex-direction: row;
    align-items: stretch;
}

.lib-card--horizontal .card-image,
.lib-card--horizontal .card-img-top {
    width: 42%;
    max-width: 320px;
    height: auto;
    min-height: 180px;
}

.lib-card--elevated .card {
    border: none;
    box-shadow: 0 1rem 2rem rgba(15, 23, 42, 0.12);
}

.lib-card--bordered .card {
    border: 2px solid color-mix(in srgb, var(--lib-accent) 55%, #cbd5e1);
}

.lib-card--overlay .card-image {
    position: relative;
}

.lib-card--overlay .card-body {
    position: absolute;
    inset: auto 0 0;
    color: #fff;
    background: linear-gradient(180deg, transparent, rgba(15, 23, 42, 0.85));
}

.lib-card--glass .card {
    background: rgba(255, 255, 255, 0.72);
    backdrop-filter: blur(12px);
    border-color: rgba(255, 255, 255, 0.35);
}

.lib-card--pricing .card-title {
    color: var(--lib-accent);
}

.lib-card--pricing .card-body {
    text-align: center;
}

/* Heading */
.lib-heading {
    --lib-heading-accent: var(--lib-accent, #2563eb);
    margin: 1.25rem 0;
    line-height: 1.2;
    font-weight: 600;
    color: #0f172a;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    overflow-x: clip;
}

.lib-heading__stack {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    min-width: 0;
    max-width: 100%;
}

.lib-heading__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--lib-heading-accent);
}

.lib-heading__title {
    margin: 0;
    font-weight: inherit;
    line-height: inherit;
    letter-spacing: inherit;
    color: inherit;
}

.lib-heading--align-center .lib-heading__stack { align-items: center; text-align: center; }
.lib-heading--align-right .lib-heading__stack { align-items: flex-end; text-align: right; }
.lib-heading--align-justify .lib-heading__title { text-align: justify; }

.lib-heading--density-compact { margin: 0.75rem 0; }
.lib-heading--density-compact .lib-heading__stack { gap: 0.4rem; }
.lib-heading--density-roomy { margin: 2rem 0; }
.lib-heading--density-roomy .lib-heading__stack { gap: 0.85rem; }

.lib-heading--classic .lib-heading__title { font-size: clamp(1.75rem, 3vw, 2.25rem); font-weight: 700; }
.lib-heading.heading-h1 .lib-heading__title { font-size: clamp(2rem, 4vw, 2.85rem); }
.lib-heading.heading-h3 .lib-heading__title { font-size: clamp(1.35rem, 2.5vw, 1.65rem); }
.lib-heading.heading-h4 .lib-heading__title { font-size: clamp(1.15rem, 2vw, 1.35rem); }
.lib-heading.heading-h5 .lib-heading__title { font-size: clamp(1rem, 1.8vw, 1.15rem); }
.lib-heading.heading-h6 .lib-heading__title { font-size: 0.95rem; text-transform: uppercase; letter-spacing: 0.06em; }

.lib-heading--display .lib-heading__title {
    font-size: clamp(2.25rem, 5vw, 3.5rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.05;
    max-width: min(18ch, 100%);
}

.lib-heading--editorial .lib-heading__title {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.12;
}

.lib-heading--underline .lib-heading__title {
    font-size: clamp(1.85rem, 3.5vw, 2.5rem);
    font-weight: 700;
    padding-bottom: 0.65rem;
    border-bottom: 3px solid var(--lib-heading-accent);
    display: block;
    width: fit-content;
    max-width: 100%;
}

.lib-heading--accent-bar .lib-heading__stack {
    padding-left: 1rem;
    border-left: 4px solid var(--lib-heading-accent);
}
.lib-heading--accent-bar .lib-heading__title { font-size: clamp(1.65rem, 3vw, 2.15rem); font-weight: 700; }

.lib-heading--inset .lib-heading__stack {
    padding: 1.25rem 1.5rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--lib-heading-accent) 7%, #fff), rgba(248, 250, 252, 0.95));
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
}

.lib-heading--centered-stack .lib-heading__stack { align-items: center; text-align: center; }
.lib-heading--centered-stack .lib-heading__title {
    font-size: clamp(1.9rem, 4vw, 2.75rem);
    font-weight: 700;
    max-width: min(22ch, 100%);
}

.lib-heading--eyebrow .lib-heading__eyebrow::before {
    content: "";
    width: 2rem;
    height: 2px;
    background: var(--lib-heading-accent);
    border-radius: 999px;
    flex-shrink: 0;
}

.lib-heading--gradient .lib-heading__stack {
    padding: 0.35rem 0;
}
.lib-heading--gradient .lib-heading__title {
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: 800;
    line-height: 1.08;
    background: linear-gradient(90deg, #0f172a 0%, var(--lib-heading-accent) 55%, color-mix(in srgb, var(--lib-heading-accent) 70%, #ec4899) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lib-heading--glass .lib-heading__stack {
    padding: 1.15rem 1.35rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.62);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.5);
    box-shadow: 0 12px 36px rgba(15, 23, 42, 0.08);
}
.lib-heading--glass .lib-heading__title { font-size: clamp(1.85rem, 3.5vw, 2.45rem); font-weight: 700; }

.lib-heading--banner .lib-heading__stack {
    padding: 1.35rem 1.5rem;
    border-radius: 0.75rem;
    background: linear-gradient(90deg,
        color-mix(in srgb, var(--lib-heading-accent) 16%, #0f172a) 0%,
        color-mix(in srgb, var(--lib-heading-accent) 48%, #1e293b) 100%);
}
.lib-heading--banner .lib-heading__title,
.lib-heading--banner .lib-heading__eyebrow { color: rgba(255, 255, 255, 0.95); }
.lib-heading--banner .lib-heading__eyebrow { opacity: 0.88; }
.lib-heading--banner .lib-heading__title { font-size: clamp(1.85rem, 4vw, 2.65rem); font-weight: 700; }

.lib-heading--minimal .lib-heading__title {
    font-size: clamp(1.25rem, 2.5vw, 1.55rem);
    font-weight: 600;
    color: #475569;
    letter-spacing: -0.01em;
}

.lib-heading--pill .lib-heading__stack { align-items: flex-start; }
.lib-heading--pill .lib-heading__eyebrow {
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--lib-heading-accent) 12%, #fff);
    border: 1px solid color-mix(in srgb, var(--lib-heading-accent) 24%, transparent);
    letter-spacing: 0.08em;
}
.lib-heading--pill .lib-heading__title { font-size: clamp(1.75rem, 3.2vw, 2.2rem); font-weight: 700; }

.lib-heading--split .lib-heading__stack {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.75rem 1.25rem;
    align-items: center;
}
.lib-heading--split .lib-heading__eyebrow {
    grid-column: 1;
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    letter-spacing: 0.2em;
    font-size: 0.65rem;
    align-self: stretch;
    justify-content: center;
    border-right: 2px solid var(--lib-heading-accent);
    padding-right: 0.65rem;
}
.lib-heading--split .lib-heading__title { grid-column: 2; font-size: clamp(1.8rem, 3.5vw, 2.4rem); font-weight: 700; }

.lib-heading--outlined .lib-heading__stack {
    padding: 1rem 1.25rem;
    border-radius: 0.85rem;
    border: 2px solid color-mix(in srgb, var(--lib-heading-accent) 35%, #e2e8f0);
}
.lib-heading--outlined .lib-heading__title { font-size: clamp(1.7rem, 3vw, 2.2rem); font-weight: 700; }

.lib-heading--neon .lib-heading__title {
    font-size: clamp(1.9rem, 3.8vw, 2.6rem);
    font-weight: 800;
    color: #0f172a;
    text-shadow:
        0 0 24px color-mix(in srgb, var(--lib-heading-accent) 45%, transparent),
        0 0 2px color-mix(in srgb, var(--lib-heading-accent) 80%, transparent);
}

@media (max-width: 768px) {
    .lib-heading--display .lib-heading__title { font-size: clamp(1.85rem, 8vw, 2.5rem); }
    .lib-heading--inset .lib-heading__stack { padding: 1rem 1.1rem; }
    .lib-heading--split .lib-heading__stack { grid-template-columns: 1fr; }
    .lib-heading--split .lib-heading__eyebrow {
        writing-mode: horizontal-tb;
        transform: none;
        border-right: none;
        border-bottom: 2px solid var(--lib-heading-accent);
        padding: 0 0 0.5rem;
    }
    .lib-heading--split .lib-heading__title { grid-column: 1; }
}

/* Paragraph */
.lib-paragraph {
    --lib-paragraph-accent: var(--lib-accent, #2563eb);
    margin: 1rem 0;
    color: #334155;
}

.lib-paragraph__eyebrow {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--lib-paragraph-accent);
    margin-bottom: 0.65rem;
}

.lib-paragraph .paragraph-container { position: relative; }
.lib-paragraph .paragraph-text {
    margin: 0;
    line-height: 1.65;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.lib-paragraph--align-center .paragraph-container,
.lib-paragraph--align-center .paragraph-text { text-align: center; }
.lib-paragraph--align-right .paragraph-container,
.lib-paragraph--align-right .paragraph-text { text-align: right; }
.lib-paragraph--align-justify .paragraph-text { text-align: justify; }

.lib-paragraph--density-compact { margin: 0.5rem 0; }
.lib-paragraph--density-compact .paragraph-container { padding-block: 0.15rem; }
.lib-paragraph--density-roomy { margin: 1.75rem 0; }
.lib-paragraph--density-roomy .paragraph-container { padding-block: 0.35rem; }

.lib-paragraph--classic .paragraph-text { font-size: 1rem; color: #334155; }

.lib-paragraph--lead .paragraph-text {
    font-size: clamp(1.1rem, 2.2vw, 1.28rem);
    line-height: 1.75;
    color: #1e293b;
    font-weight: 450;
    max-width: 52rem;
}

.lib-paragraph--narrow .paragraph-container {
    max-width: 42rem;
    margin-inline: auto;
}
.lib-paragraph--narrow .paragraph-text { line-height: 1.7; }

.lib-paragraph--inset .paragraph-container {
    max-width: 44rem;
    margin-inline: auto;
    padding: 1.25rem 1.5rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, color-mix(in srgb, var(--lib-paragraph-accent) 6%, #fff), rgba(248, 250, 252, 0.9));
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 8px 24px rgba(15, 23, 42, 0.04);
}

.lib-paragraph--quote .paragraph-container {
    max-width: 40rem;
    position: relative;
    padding: 0.5rem 0 0.5rem 1.5rem;
}
.lib-paragraph--quote .paragraph-container::before {
    content: "\201C";
    position: absolute;
    left: 0;
    top: -0.15rem;
    font-size: 2.75rem;
    line-height: 1;
    color: var(--lib-paragraph-accent);
    font-family: Georgia, "Times New Roman", serif;
    opacity: 0.85;
}
.lib-paragraph--quote .paragraph-text,
.lib-paragraph--quote blockquote.paragraph-text {
    font-size: 1.12rem;
    font-style: italic;
    border-left: 3px solid var(--lib-paragraph-accent);
    padding-left: 1rem;
    color: #0f172a;
}

.lib-paragraph--highlight .paragraph-container {
    padding: 1rem 1.25rem;
    border-radius: 0.85rem;
    background: color-mix(in srgb, var(--lib-paragraph-accent) 11%, #fff);
    border: 1px solid color-mix(in srgb, var(--lib-paragraph-accent) 24%, transparent);
    box-shadow: 0 4px 16px color-mix(in srgb, var(--lib-paragraph-accent) 8%, transparent);
}

.lib-paragraph--callout .paragraph-container {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.85rem;
    align-items: start;
    padding: 1rem 1.15rem;
    border-radius: 0.85rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-left: 4px solid var(--lib-paragraph-accent);
}
.lib-paragraph--callout .lib-paragraph__eyebrow { grid-column: 2; margin-bottom: 0.25rem; }
.lib-paragraph--callout .paragraph-container::before {
    content: "i";
    font-family: Georgia, serif;
    font-weight: 700;
    font-style: italic;
    width: 2rem;
    height: 2rem;
    border-radius: 0.55rem;
    display: grid;
    place-items: center;
    font-size: 0.95rem;
    color: var(--lib-paragraph-accent);
    background: color-mix(in srgb, var(--lib-paragraph-accent) 14%, #fff);
    grid-row: 1 / span 2;
}
.lib-paragraph--callout .paragraph-text { grid-column: 2; }

.lib-paragraph--glass .paragraph-container {
    padding: 1.15rem 1.35rem;
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.65);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, 0.55);
    box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}

.lib-paragraph--editorial .paragraph-text {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.05rem;
    line-height: 1.8;
    color: #1e293b;
}
.lib-paragraph--editorial .lib-paragraph__eyebrow {
    font-family: system-ui, -apple-system, sans-serif;
}

.lib-paragraph--minimal .paragraph-text {
    font-size: 0.92rem;
    color: #64748b;
    line-height: 1.6;
    max-width: 38rem;
}

.lib-paragraph--gradient .paragraph-container {
    padding: 1.1rem 1.25rem;
    border-radius: 1rem;
    background: linear-gradient(120deg,
        color-mix(in srgb, var(--lib-paragraph-accent) 8%, #fff) 0%,
        #fff 45%,
        color-mix(in srgb, var(--lib-paragraph-accent) 5%, #f8fafc) 100%);
    border: 1px solid color-mix(in srgb, var(--lib-paragraph-accent) 18%, transparent);
}
.lib-paragraph--gradient .paragraph-text {
    background: linear-gradient(90deg, #0f172a 0%, color-mix(in srgb, var(--lib-paragraph-accent) 65%, #0f172a) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.lib-paragraph--pill .paragraph-container {
    display: flex;
    justify-content: center;
}
.lib-paragraph--pill .paragraph-text {
    display: inline-block;
    padding: 0.65rem 1.25rem;
    border-radius: 999px;
    background: color-mix(in srgb, var(--lib-paragraph-accent) 10%, #fff);
    border: 1px solid color-mix(in srgb, var(--lib-paragraph-accent) 22%, transparent);
    font-size: 0.95rem;
    font-weight: 500;
    color: #0f172a;
    max-width: 100%;
}

.lib-paragraph--banner .paragraph-container {
    padding: 1.25rem 1.5rem;
    border-radius: 0.75rem;
    background: linear-gradient(90deg,
        color-mix(in srgb, var(--lib-paragraph-accent) 14%, #0f172a) 0%,
        color-mix(in srgb, var(--lib-paragraph-accent) 42%, #1e293b) 100%);
}
.lib-paragraph--banner .paragraph-text,
.lib-paragraph--banner .lib-paragraph__eyebrow { color: rgba(255, 255, 255, 0.92); }
.lib-paragraph--banner .lib-paragraph__eyebrow { opacity: 0.85; }

.lib-paragraph--muted .paragraph-text {
    font-size: 0.9rem;
    color: #64748b;
    background: #f8fafc;
    padding: 0.85rem 1rem;
    border-radius: 0.65rem;
    border: 1px dashed #e2e8f0;
}

.lib-paragraph--columns-2 .paragraph-text {
    column-count: 2;
    column-gap: 2rem;
}

.lib-paragraph--drop-cap .paragraph-text::first-letter {
    float: left;
    font-size: 3.25rem;
    line-height: 0.85;
    font-weight: 700;
    margin: 0.08rem 0.5rem 0 0;
    color: var(--lib-paragraph-accent);
    font-family: Georgia, "Times New Roman", serif;
}

/* Image */
.lib-image--framed img {
    border: 1px solid #e2e8f0;
    padding: 0.35rem;
    background: #fff;
}

.lib-image--rounded img {
    border-radius: 1rem;
}

.lib-image--polaroid img {
    background: #fff;
    border: 1px solid #e2e8f0;
    padding: 0.5rem 0.5rem 2rem;
    box-shadow: 0 0.5rem 1.25rem rgba(15, 23, 42, 0.12);
}

.lib-image--full-bleed img {
    width: 100%;
    border-radius: 0;
}

.lib-image--shadow img {
    box-shadow: 0 1rem 2rem rgba(15, 23, 42, 0.18);
}

.lib-image--cover-banner img {
    width: 100%;
    min-height: 220px;
    object-fit: cover;
}

.lib-image--hero-band img {
    width: 100%;
    min-height: 280px;
    object-fit: cover;
    border-radius: 0;
}

.lib-image--editorial .lib-image__figure {
    max-width: 960px;
}

.lib-image--inset .lib-image__figure {
    max-width: 720px;
    margin-inline: auto;
}

.lib-image--circle img {
    border-radius: 50%;
    aspect-ratio: 1;
    object-fit: cover;
}

.lib-image--caption-overlay .lib-image__figure {
    position: relative;
}

.lib-image--bordered img {
    border: 2px solid color-mix(in srgb, var(--lib-accent) 40%, #e2e8f0);
}

.lib-image--elevated img {
    box-shadow: 0 1.25rem 2.5rem rgba(15, 23, 42, 0.16);
}

.lib-image--minimal img {
    box-shadow: none;
    border-radius: 0;
}

.lib-image--gallery-tile img {
    width: 100%;
    min-height: 220px;
    object-fit: cover;
}

/* Button */
.lib-button--design-pill .btn {
    border-radius: 999px;
}

.lib-button--design-soft .btn {
    background: color-mix(in srgb, var(--lib-accent) 18%, #fff);
    border-color: transparent;
    color: var(--lib-accent);
}

.lib-button--design-ghost .btn {
    background: transparent;
    border-color: color-mix(in srgb, var(--lib-accent) 35%, #cbd5e1);
}

.lib-button--design-emphasis .btn {
    box-shadow: 0 0.75rem 1.5rem color-mix(in srgb, var(--lib-accent) 35%, transparent);
}

/* Navigation */
.lib-navigation--transparent .navbar {
    background: transparent;
    box-shadow: none;
}

.lib-navigation--modern .navbar {
    border-radius: 999px;
    margin-top: 0.75rem;
    box-shadow: 0 0.5rem 1.25rem rgba(15, 23, 42, 0.08);
}

.lib-navigation--bottom {
    position: sticky;
    bottom: 0;
    z-index: 1030;
    padding-bottom: env(safe-area-inset-bottom, 0);
}

.lib-navigation--bottom .navbar {
    border-radius: 1rem 1rem 0 0;
    box-shadow: 0 -0.35rem 1.25rem rgba(15, 23, 42, 0.12);
    min-height: 3.5rem;
}

.lib-navigation--bottom .navbar-nav {
    flex-direction: row;
    justify-content: space-around;
    width: 100%;
}

.lib-navigation--bottom .nav-link {
    font-size: 0.85rem;
    padding: 0.5rem 0.75rem;
}

/* Footer */
.lib-footer {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    overflow-x: clip;
}

.lib-footer .footer-full,
.lib-footer .footer-simple {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.lib-footer .footer-container,
.lib-footer .footer-cta-inner,
.lib-footer .footer-bottom-content,
.lib-footer .footer-simple .footer-content {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.lib-footer .footer-section {
    min-width: 0;
}

.lib-footer .footer-company,
.lib-footer .footer-tagline,
.lib-footer .footer-link,
.lib-footer .footer-legal-link,
.lib-footer .contact-item a,
.lib-footer .contact-item span,
.lib-footer .footer-newsletter-desc,
.lib-footer .footer-copyright p {
    overflow-wrap: anywhere;
    word-break: break-word;
}

.lib-footer .newsletter-input-group {
    min-width: 0;
    max-width: 100%;
}

.lib-footer .newsletter-input {
    min-width: 0;
}

.lib-footer--dark-band .footer-full,
.lib-footer--dark-band .footer-simple {
    background: #0f172a;
    color: #e2e8f0;
}

.lib-footer--centered .footer-content,
.lib-footer--centered .footer-full {
    text-align: center;
}

.lib-footer--split .footer-container {
    grid-template-columns: 1fr;
}

@media (min-width: 769px) {
    .lib-footer--split .footer-container {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 2fr);
    }
}

/* Testimonials */
.lib-testimonials--quote .testimonial-card {
    border: none;
    background: color-mix(in srgb, var(--lib-accent) 8%, #fff);
}

.lib-testimonials--spotlight .testimonial-card {
    border: 2px solid var(--lib-accent);
}

.lib-testimonials--minimal .testimonials-header {
    text-align: left;
}

/* Statistics */
.lib-statistics--banner {
    background: linear-gradient(135deg, color-mix(in srgb, var(--lib-accent) 85%, #0f172a), #0f172a);
    color: #fff;
    border-radius: 1rem;
    padding: var(--lib-density-pad, 2rem);
}

.lib-statistics--banner .statistics-title,
.lib-statistics--banner .statistics-subtitle,
.lib-statistics--banner .statistic-label,
.lib-statistics--banner .statistic-description {
    color: inherit;
}

.lib-statistics--cards .statistic-item {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0.75rem;
    padding: var(--lib-density-pad, 1.25rem);
}

.lib-statistics--gradient {
    background: linear-gradient(120deg, color-mix(in srgb, var(--lib-accent) 20%, #fff), #fff);
    border-radius: 1rem;
}

/* Gallery */
.lib-gallery--mosaic .gallery-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: 120px;
    gap: 0.5rem;
}

.lib-gallery--framed .gallery-item img {
    border: 1px solid #e2e8f0;
    padding: 0.35rem;
    background: #fff;
}

.lib-gallery--compact .gallery-item {
    margin-bottom: 0.5rem;
}

/* Forms */
.lib-form--card form,
.lib-form--card .form-container {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0.75rem;
    padding: var(--lib-density-pad, 1.25rem);
}

.lib-form--floating .form-group {
    margin-bottom: 1.25rem;
}

.lib-form--split .form-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--lib-density-gap, 1rem);
}

/* Media */
.lib-media--theater .media-container {
    max-width: 960px;
    margin-inline: auto;
}

.lib-media--card .media-container {
    border: 1px solid #e2e8f0;
    border-radius: 0.75rem;
    overflow: hidden;
    background: #fff;
}

/* Container */
.lib-container--panel {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 0.75rem;
    padding: var(--lib-density-pad, 1.25rem);
}

.lib-container--inset {
    background: #f8fafc;
    border-radius: 0.75rem;
    padding: var(--lib-density-pad, 1.25rem);
}

/* E-commerce */
.lib-ecommerce--sidebar .ecommerce-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--lib-density-gap, 1rem);
}

.lib-ecommerce--minimal .ecommerce-header {
    margin-bottom: 0.5rem;
}

.lib-ecommerce--showcase .product-card {
    border: none;
    box-shadow: 0 1rem 2rem rgba(15, 23, 42, 0.08);
}

/* Blog / classified / VTU */
.blog-list-card__image,
.blog-list-lead__image {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    max-height: 420px;
}

.blog-list-split__image {
    min-height: 220px;
    object-fit: cover;
}

.blog-list-overlay__media {
    min-height: 280px;
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: flex-end;
}

.blog-list-overlay__media::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, transparent 20%, rgba(15, 23, 42, 0.82) 100%);
}

.blog-list-overlay__content {
    position: relative;
    z-index: 1;
    width: 100%;
}

.blog-list-minimal__thumb {
    width: 96px;
    height: 72px;
    object-fit: cover;
    flex-shrink: 0;
}

.blog-detail-hero__media {
    border-radius: 0.75rem 0.75rem 0 0;
    overflow: hidden;
}

.blog-detail-hero__media--tall {
    max-height: 480px;
}

.blog-detail-hero__image,
.blog-detail-classic__image,
.blog-detail-editorial__image {
    width: 100%;
    object-fit: cover;
    aspect-ratio: 16 / 9;
    max-height: 440px;
}

.blog-detail-hero__body {
    margin-top: -2rem;
    position: relative;
    z-index: 1;
    max-width: min(920px, 94%);
    margin-left: auto;
    margin-right: auto;
}

.blog-detail-editorial {
    max-width: 720px;
}

.blog-detail-split__image {
    min-height: 320px;
    object-fit: cover;
}

.lib-blog-list--magazine .blog-list-lead__image {
    max-height: 480px;
}

.lib-classified-listing-grid--list .classified-grid {
    display: flex;
    flex-direction: column;
    gap: var(--lib-density-gap, 1rem);
}

.lib-classified-listing-detail--split.card {
    display: grid;
    grid-template-columns: minmax(220px, 42%) 1fr;
}

.lib-classified-listing-detail--split.card > .card-img-top {
    grid-column: 1;
    grid-row: 1;
    min-height: 240px;
    height: 100%;
    object-fit: cover;
}

.lib-classified-listing-detail--split.card > .card-body {
    grid-column: 2;
}

.lib-classified-listing-detail--gallery .card-img-top {
    max-height: 420px;
    object-fit: cover;
}

.lib-classified-listing-detail--minimal .card-title {
    font-size: 1.35rem;
}

.lib-classified-listing-detail--minimal .card-img-top {
    max-height: 220px;
    object-fit: cover;
}

.classified-detail-price--emphasis {
    color: var(--lib-accent);
    font-size: 1.35rem;
}

.lib-classified-category-browse--chips .classified-category-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.45rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--lib-accent) 30%, #cbd5e1);
    border-radius: 999px;
    text-decoration: none;
    color: inherit;
    background: color-mix(in srgb, var(--lib-accent) 8%, #fff);
}

.lib-classified-category-browse--list .classified-category-list {
    border-radius: 0.75rem;
    overflow: hidden;
}

.lib-classified-category-browse--compact .classified-category-card .card-body {
    padding: 0.75rem;
}

.lib-classified-category-browse--cards .classified-category-card {
    border: 1px solid #e2e8f0;
    box-shadow: 0 0.5rem 1.25rem rgba(15, 23, 42, 0.06);
}

.lib-vtu-service-grid--featured .vtu-service-card:first-child {
    border: 2px solid var(--lib-accent);
}

/* Auth / payment / checkout */
.lib-login-form--split .login-form-container,
.lib-payment--split .payment-container,
.dynamic-checkout.lib-checkout--split .checkout-shell {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--lib-density-gap, 1rem);
}

.lib-admin-dashboard--dense .admin-dashboard-grid {
    gap: 0.5rem;
}

.lib-live-chat--docked .chat-panel {
    position: sticky;
    bottom: 1rem;
}

/* Portal */
.lib-portal-welcome--banner .card,
.lib-portal-dashboard--banner .card,
.lib-portal-tracks--banner .card {
    background: linear-gradient(135deg, color-mix(in srgb, var(--lib-accent) 18%, #fff), #fff);
    border: 1px solid color-mix(in srgb, var(--lib-accent) 25%, #e2e8f0);
}

.lib-portal-access--split .card-body,
.lib-portal-mywork--split .card-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--lib-density-gap, 1rem);
}

@media (max-width: 768px) {
    .lib-footer .footer-container {
        grid-template-columns: 1fr !important;
        gap: 1.75rem;
        padding: 2rem 1rem 1.5rem;
    }

    .lib-footer--split .footer-full,
    .lib-footer--newsletter-focus .footer-container,
    .lib-footer--mega-grid .footer-container {
        grid-template-columns: 1fr !important;
    }

    .lib-footer--social-strip .footer-container,
    .lib-footer--compact-bar .footer-container {
        flex-direction: column;
        align-items: stretch;
    }

    .lib-footer .footer-cta-inner {
        flex-direction: column;
        align-items: stretch;
        text-align: center;
    }

    .lib-footer .footer-bottom-content {
        flex-direction: column;
        text-align: center;
    }

    .lib-footer .footer-legal {
        flex-wrap: wrap;
        justify-content: center;
    }

    .lib-card--horizontal .card {
        flex-direction: column;
    }

    .lib-card--horizontal .card-image,
    .lib-card--horizontal .card-img-top {
        width: 100%;
        max-width: none;
    }

    .lib-paragraph--columns-2 .paragraph-container {
        column-count: 1;
    }

    .lib-footer--split .footer-full,
    .lib-form--split .form-container,
    .lib-ecommerce--sidebar .ecommerce-layout,
    .lib-login-form--split .login-form-container,
    .lib-payment--split .payment-container,
    .dynamic-checkout.lib-checkout--split .checkout-shell,
    .lib-portal-access--split .card-body,
    .lib-portal-mywork--split .card-body,
    .lib-classified-listing-detail--split.card {
        grid-template-columns: 1fr;
    }

    .lib-classified-listing-detail--split.card > .card-img-top,
    .lib-classified-listing-detail--split.card > .card-body {
        grid-column: auto;
    }

    .lib-portal-welcome .card-body,
    .lib-portal-tracks,
    .lib-portal-dashboard,
    .lib-portal-announcements,
    .lib-portal-resources {
        padding-left: 0.75rem;
        padding-right: 0.75rem;
    }

    .lib-portal-tracks .list-group-item,
    .lib-portal-announcements .card,
    .lib-portal-resources .list-group-item {
        padding-top: 0.65rem;
        padding-bottom: 0.65rem;
    }

    .lib-portal-tracks .btn-sm,
    .lib-portal-access .btn {
        min-height: 2.5rem;
        padding-left: 1rem;
        padding-right: 1rem;
    }
}
