/* ─────────────────────────────────────────────────────────────────────
 * lyra-bt-link-in-bio.css
 *
 * Styles for three link-in-bio blocks:
 *   - link_in_bio_lead_first  → .lyra-bt-lib.lyra-bt-lib--lead-first
 *   - link_in_bio_visual_grid → .lyra-bt-lib.lyra-bt-lib--visual-grid
 *   - link_in_bio_social_proof → .lyra-bt-lib.lyra-bt-lib--social-proof
 *
 * Per-instance CSS variables (--lyra-bt-lib-*) carry colors and sizing
 * from the PHP renderer. The stylesheet stays generic.
 *
 * Variant-specific layout is encoded via .lyra-bt-lib--{variant} so the
 * renderer can stay declarative.
 * ───────────────────────────────────────────────────────────────────── */

.lyra-bt-lib {
    --lyra-bt-lib-bg:        #0f172a;
    --lyra-bt-lib-text:      #f8fafc;
    --lyra-bt-lib-muted:     #94a3b8;
    --lyra-bt-lib-accent:    #10b981;
    --lyra-bt-lib-btn-bg:    #1e293b;
    --lyra-bt-lib-btn-fg:    #f8fafc;
    --lyra-bt-lib-max-w:     440px;
    --lyra-bt-lib-pad-v:     40px;
    --lyra-bt-lib-pad-h:     24px;
    --lyra-bt-lib-gap:       10px;
    --lyra-bt-lib-profile:   96px;
    box-sizing: border-box;
    max-width: var(--lyra-bt-lib-max-w);
    margin: 0 auto;
    padding: var(--lyra-bt-lib-pad-v) var(--lyra-bt-lib-pad-h);
    background: var(--lyra-bt-lib-bg);
    color: var(--lyra-bt-lib-text);
    font-family: -apple-system, BlinkMacSystemFont, 'Inter', 'Segoe UI', Arial, sans-serif;
    line-height: 1.5;
    border-radius: 14px;
    text-align: center;
    position: relative;
}
.lyra-bt-lib *, .lyra-bt-lib *::before, .lyra-bt-lib *::after { box-sizing: border-box; }
.lyra-bt-lib a { color: inherit; text-decoration: none; }

.lyra-bt-lib--empty {
    padding: 12px 16px;
    background: #fef3c7;
    color: #92400e;
    border: 1px dashed #d97706;
    border-radius: 8px;
    text-align: left;
    font-size: 13px;
}

/* ═════════════════════════════════════════════════════════════════════
 * Profile header (shared)
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib__header {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-bottom: 18px;
}

.lyra-bt-lib__avatar {
    width: var(--lyra-bt-lib-profile);
    height: var(--lyra-bt-lib-profile);
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
    border: 2px solid var(--lyra-bt-lib-accent);
    flex-shrink: 0;
}
.lyra-bt-lib__avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.lyra-bt-lib__avatar--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--lyra-bt-lib-muted);
    font-size: calc(var(--lyra-bt-lib-profile) * 0.4);
    font-weight: 700;
    line-height: 1;
}

.lyra-bt-lib--profile-circle  .lyra-bt-lib__avatar { border-radius: 50%; }
.lyra-bt-lib--profile-rounded .lyra-bt-lib__avatar { border-radius: 18px; }
.lyra-bt-lib--profile-square  .lyra-bt-lib__avatar { border-radius: 0; }

.lyra-bt-lib__name {
    margin: 8px 0 0;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: -0.005em;
    color: var(--lyra-bt-lib-text);
}
.lyra-bt-lib__handle {
    margin: 0;
    font-size: 13.5px;
    color: var(--lyra-bt-lib-muted);
    font-weight: 500;
    letter-spacing: 0.01em;
}
.lyra-bt-lib__bio {
    margin: 6px 0 0;
    font-size: 14.5px;
    line-height: 1.5;
    color: var(--lyra-bt-lib-muted);
    max-width: 38ch;
}

/* ═════════════════════════════════════════════════════════════════════
 * Social icons row (shared)
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib__social-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin: 8px 0 18px;
}
.lyra-bt-lib__social-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    color: var(--lyra-bt-lib-text);
    transition: background 0.15s ease, transform 0.15s ease;
    flex-shrink: 0;
}
.lyra-bt-lib__social-icon:hover {
    background: var(--lyra-bt-lib-accent);
    color: #fff;
    transform: translateY(-1px);
}
.lyra-bt-lib__social-icon:focus-visible {
    outline: 2px solid var(--lyra-bt-lib-accent);
    outline-offset: 3px;
}
.lyra-bt-lib__social-icon svg { width: 18px; height: 18px; display: block; }

/* ═════════════════════════════════════════════════════════════════════
 * Main link list (shared)
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib__links {
    display: flex;
    flex-direction: column;
    gap: var(--lyra-bt-lib-gap);
    margin: 12px 0 0;
}

.lyra-bt-lib__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    padding: 14px 16px;
    background: var(--lyra-bt-lib-btn-bg);
    color: var(--lyra-bt-lib-btn-fg);
    font-weight: 600;
    text-decoration: none;
    line-height: 1.3;
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
    position: relative;
    overflow: hidden;
}
.lyra-bt-lib__link:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
}
.lyra-bt-lib__link:focus-visible {
    outline: 2px solid var(--lyra-bt-lib-accent);
    outline-offset: 3px;
}
.lyra-bt-lib__link--highlighted {
    background: var(--lyra-bt-lib-accent);
    color: #fff;
}
.lyra-bt-lib__link-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05em;
    line-height: 1;
}
.lyra-bt-lib__link-label {
    font-size: inherit;
    line-height: 1.3;
}

/* Button style variants */
.lyra-bt-lib--btn-style-filled  .lyra-bt-lib__link  { /* default — already set above */ }
.lyra-bt-lib--btn-style-outline .lyra-bt-lib__link  {
    background: transparent;
    border: 1.5px solid var(--lyra-bt-lib-btn-bg);
    color: var(--lyra-bt-lib-text);
}
.lyra-bt-lib--btn-style-outline .lyra-bt-lib__link--highlighted {
    background: transparent;
    border-color: var(--lyra-bt-lib-accent);
    color: var(--lyra-bt-lib-accent);
}
.lyra-bt-lib--btn-style-soft .lyra-bt-lib__link {
    background: color-mix(in srgb, var(--lyra-bt-lib-btn-bg) 35%, transparent);
    color: var(--lyra-bt-lib-text);
}
.lyra-bt-lib--btn-style-soft .lyra-bt-lib__link--highlighted {
    background: color-mix(in srgb, var(--lyra-bt-lib-accent) 18%, transparent);
    color: var(--lyra-bt-lib-accent);
}

/* Button shape variants */
.lyra-bt-lib--btn-shape-pill    .lyra-bt-lib__link { border-radius: 999px; }
.lyra-bt-lib--btn-shape-rounded .lyra-bt-lib__link { border-radius: 12px;  }
.lyra-bt-lib--btn-shape-square  .lyra-bt-lib__link { border-radius: 4px;   }

/* Button size variants */
.lyra-bt-lib--btn-size-sm .lyra-bt-lib__link { padding: 10px 14px; font-size: 13.5px; }
.lyra-bt-lib--btn-size-md .lyra-bt-lib__link { padding: 13px 16px; font-size: 15px;   }
.lyra-bt-lib--btn-size-lg .lyra-bt-lib__link { padding: 16px 18px; font-size: 16.5px; }

/* ═════════════════════════════════════════════════════════════════════
 * Lead-First variant
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib--lead-first .lyra-bt-lib__value-prop {
    margin: 4px 0 16px;
    font-size: 15.5px;
    font-weight: 500;
    line-height: 1.4;
    color: var(--lyra-bt-lib-text);
    max-width: 36ch;
    margin-left: auto;
    margin-right: auto;
}

.lyra-bt-lib--lead-first .lyra-bt-lib__cta-wrap {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin: 0 0 18px;
}

.lyra-bt-lib__cta-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 20px;
    background: var(--lyra-bt-lib-accent);
    color: #fff;
    font-weight: 700;
    font-size: 15.5px;
    border: 0;
    cursor: pointer;
    text-decoration: none;
    border-radius: 999px;
    transition: transform 0.15s ease, box-shadow 0.15s ease, filter 0.15s ease;
    font-family: inherit;
}
.lyra-bt-lib__cta-button:hover {
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
    filter: brightness(1.05);
}
.lyra-bt-lib__cta-button:focus-visible {
    outline: 2px solid var(--lyra-bt-lib-text);
    outline-offset: 3px;
}
.lyra-bt-lib__cta-button svg { width: 14px; height: 14px; }

.lyra-bt-lib__call-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    border: 1.5px solid var(--lyra-bt-lib-accent);
    color: var(--lyra-bt-lib-text);
    border-radius: 999px;
    text-decoration: none;
    font-size: 14.5px;
    font-weight: 600;
    transition: background 0.15s ease, transform 0.15s ease;
    flex-wrap: wrap;
}
.lyra-bt-lib__call-link:hover {
    background: rgba(16, 185, 129, 0.12);
    transform: translateY(-1px);
}
.lyra-bt-lib__call-link svg { width: 14px; height: 14px; color: var(--lyra-bt-lib-accent); }
.lyra-bt-lib__call-label { font-weight: 600; }
.lyra-bt-lib__call-number { color: var(--lyra-bt-lib-muted); font-weight: 500; }

/* ═════════════════════════════════════════════════════════════════════
 * Visual Grid variant
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib--visual-grid .lyra-bt-lib__grid-heading {
    margin: 22px 0 12px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--lyra-bt-lib-muted);
}

.lyra-bt-lib__grid {
    display: grid;
    gap: 8px;
    margin: 12px 0 0;
}
.lyra-bt-lib__grid--2-by-2 { grid-template-columns: repeat(2, 1fr); }
.lyra-bt-lib__grid--3-by-3 { grid-template-columns: repeat(3, 1fr); }

.lyra-bt-lib__grid-tile {
    position: relative;
    aspect-ratio: 1;
    display: block;
    border: 0;
    background: rgba(0, 0, 0, 0.05);
    overflow: hidden;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    border-radius: 10px;
    padding: 0;
    font-family: inherit;
}
.lyra-bt-lib__grid-image {
    position: absolute;
    inset: 0;
    display: block;
}
.lyra-bt-lib__grid-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.lyra-bt-lib__grid-tile:hover .lyra-bt-lib__grid-image img,
.lyra-bt-lib__grid-tile:focus-visible .lyra-bt-lib__grid-image img {
    transform: scale(1.04);
}
.lyra-bt-lib__grid-tile:focus-visible {
    outline: 2px solid var(--lyra-bt-lib-accent);
    outline-offset: 3px;
}

.lyra-bt-lib__grid-placeholder {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--lyra-bt-lib-accent) 22%, transparent);
    color: var(--lyra-bt-lib-accent);
    font-size: 36px;
    font-weight: 800;
}

/* Plain mode — caption is hidden. */
.lyra-bt-lib__grid--hotspot-plain .lyra-bt-lib__grid-caption { display: none; }

/* Popover mode — caption rises on hover/tap via :focus-within fallback. */
.lyra-bt-lib__grid--hotspot-popover .lyra-bt-lib__grid-caption {
    position: absolute;
    inset: auto 0 0 0;
    padding: 14px 12px 10px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0) 100%);
    color: #fff;
    font-size: 12.5px;
    font-weight: 700;
    line-height: 1.3;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity 0.2s ease, transform 0.2s ease;
    pointer-events: none;
    text-align: left;
}
.lyra-bt-lib__grid--hotspot-popover .lyra-bt-lib__grid-tile:hover .lyra-bt-lib__grid-caption,
.lyra-bt-lib__grid--hotspot-popover .lyra-bt-lib__grid-tile:focus-visible .lyra-bt-lib__grid-caption {
    opacity: 1;
    transform: translateY(0);
}

/* Modal mode — caption is always visible below the image strip. */
.lyra-bt-lib__grid--hotspot-modal .lyra-bt-lib__grid-caption {
    position: absolute;
    inset: auto 0 0 0;
    padding: 8px 10px;
    background: rgba(0, 0, 0, 0.62);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.3;
    pointer-events: none;
    text-align: center;
}

/* ═════════════════════════════════════════════════════════════════════
 * Social Proof variant
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib--social-proof .lyra-bt-lib__badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 6px 13px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 18px;
}
.lyra-bt-lib--social-proof .lyra-bt-lib__badge-icon { font-size: 14px; line-height: 1; }
.lyra-bt-lib__badge--verified   { background: #e0f2fe; color: #075985; }
.lyra-bt-lib__badge--experience { background: #fef3c7; color: #92400e; }
.lyra-bt-lib__badge--guarantee  { background: #d1fae5; color: #065f46; }
.lyra-bt-lib__badge--custom     { background: color-mix(in srgb, var(--lyra-bt-lib-accent) 18%, transparent); color: var(--lyra-bt-lib-accent); }

.lyra-bt-lib__badge--pos-top-centered { align-self: center; }
.lyra-bt-lib__badge--pos-top-left     { align-self: flex-start; margin-left: 0; }
.lyra-bt-lib__badge--pos-top-right    { align-self: flex-end;   margin-right: 0; }

/* Testimonial slider */
.lyra-bt-lib__slider {
    margin: 24px 0 0;
    position: relative;
    text-align: left;
}
.lyra-bt-lib__slider-heading {
    margin: 0 0 10px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--lyra-bt-lib-muted);
    text-align: center;
}
.lyra-bt-lib__slider-track {
    position: relative;
    background: color-mix(in srgb, var(--lyra-bt-lib-text) 5%, transparent);
    border-radius: 12px;
    padding: 18px 18px 16px;
    min-height: 130px;
    overflow: hidden;
}
.lyra-bt-lib__slider-slide {
    position: absolute;
    inset: 18px 18px 16px;
    opacity: 0;
    transition: opacity 0.4s ease;
    pointer-events: none;
}
.lyra-bt-lib__slider-slide.is-active { opacity: 1; pointer-events: auto; position: relative; inset: auto; }

/* Slide-transition variant — slides horizontally instead of fading */
.lyra-bt-lib--social-proof .lyra-bt-lib__slider--slide .lyra-bt-lib__slider-slide {
    transform: translateX(20px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}
.lyra-bt-lib--social-proof .lyra-bt-lib__slider--slide .lyra-bt-lib__slider-slide.is-active {
    transform: translateX(0);
}

.lyra-bt-lib__slider-quote {
    margin: 0 0 10px;
    font-style: italic;
    font-size: 14.5px;
    line-height: 1.55;
    color: var(--lyra-bt-lib-text);
    font-weight: 500;
}
.lyra-bt-lib__slider-cite {
    display: flex;
    flex-direction: column;
    font-style: normal;
}
.lyra-bt-lib__slider-author {
    font-style: normal;
    font-weight: 700;
    font-size: 13px;
    color: var(--lyra-bt-lib-text);
}
.lyra-bt-lib__slider-role {
    font-size: 12px;
    color: var(--lyra-bt-lib-muted);
    margin-top: 1px;
}

.lyra-bt-lib__slider-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.45);
    color: #fff;
    border: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: background 0.15s ease;
}
.lyra-bt-lib__slider-arrow:hover { background: rgba(0, 0, 0, 0.65); }
.lyra-bt-lib__slider-arrow:focus-visible { outline: 2px solid var(--lyra-bt-lib-accent); outline-offset: 2px; }
.lyra-bt-lib__slider-arrow--prev { left: -6px; }
.lyra-bt-lib__slider-arrow--next { right: -6px; }
.lyra-bt-lib__slider-arrow svg { width: 14px; height: 14px; }

.lyra-bt-lib__slider-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
}
.lyra-bt-lib__slider-dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: color-mix(in srgb, var(--lyra-bt-lib-text) 22%, transparent);
    cursor: pointer;
    transition: background 0.15s ease, transform 0.15s ease;
}
.lyra-bt-lib__slider-dot:hover { transform: scale(1.2); }
.lyra-bt-lib__slider-dot.is-active { background: var(--lyra-bt-lib-accent); }
.lyra-bt-lib__slider-dot:focus-visible { outline: 2px solid var(--lyra-bt-lib-accent); outline-offset: 2px; }

/* "Featured In" logo bar */
.lyra-bt-lib__logos {
    margin: 22px 0 0;
}
.lyra-bt-lib__logos-heading {
    margin: 0 0 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.2em;
    text-transform: uppercase;
    color: var(--lyra-bt-lib-muted);
}
.lyra-bt-lib__logos-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 16px 22px;
    opacity: 0.85;
}
.lyra-bt-lib__logo-item {
    display: inline-flex;
    align-items: center;
    height: 28px;
    transition: opacity 0.15s ease, transform 0.15s ease;
}
.lyra-bt-lib__logo-item img {
    max-height: 28px;
    max-width: 110px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: grayscale(0.4);
    transition: filter 0.15s ease;
}
.lyra-bt-lib__logos-row a.lyra-bt-lib__logo-item:hover img { filter: grayscale(0); }
.lyra-bt-lib__logos-row a.lyra-bt-lib__logo-item:hover { transform: translateY(-1px); }

.lyra-bt-lib__logo-placeholder {
    padding: 6px 12px;
    background: color-mix(in srgb, var(--lyra-bt-lib-text) 8%, transparent);
    border-radius: 6px;
    color: var(--lyra-bt-lib-muted);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    white-space: nowrap;
}

/* ═════════════════════════════════════════════════════════════════════
 * Modal overlay (used by Lead-First CTA modal + Visual Grid modal)
 * ═════════════════════════════════════════════════════════════════════ */

.lyra-bt-lib__modal-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px 18px;
    overscroll-behavior: contain;
}
.lyra-bt-lib__modal-overlay[hidden] { display: none; }

.lyra-bt-lib__modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(15, 23, 42, 0.62);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    animation: lyra-bt-lib-fade-in 0.18s ease;
}
.lyra-bt-lib__modal-dialog {
    position: relative;
    max-width: 480px;
    width: 100%;
    max-height: calc(100vh - 48px);
    overflow-y: auto;
    background: #ffffff;
    color: #0f172a;
    border-radius: 16px;
    padding: 28px 28px 24px;
    box-shadow: 0 24px 60px rgba(0, 0, 0, 0.32);
    font-family: -apple-system, BlinkMacSystemFont, 'Inter', sans-serif;
    text-align: left;
    animation: lyra-bt-lib-pop-in 0.22s ease;
}
.lyra-bt-lib__modal-dialog--grid { max-width: 560px; }
.lyra-bt-lib__modal-grid-image {
    width: calc(100% + 56px);
    margin: -28px -28px 18px;
    aspect-ratio: 16 / 10;
    background: #f1f5f9;
    overflow: hidden;
    border-radius: 16px 16px 0 0;
}
.lyra-bt-lib__modal-grid-image img,
.lyra-bt-lib__modal-grid-image .lyra-bt-lib__grid-placeholder { width: 100%; height: 100%; object-fit: cover; position: static; aspect-ratio: auto; }
.lyra-bt-lib__modal-x {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 32px;
    height: 32px;
    border: 0;
    border-radius: 50%;
    background: rgba(15, 23, 42, 0.08);
    color: #0f172a;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: background 0.15s ease;
}
.lyra-bt-lib__modal-x:hover { background: rgba(15, 23, 42, 0.16); }
.lyra-bt-lib__modal-x:focus-visible { outline: 2px solid #0f172a; outline-offset: 2px; }
.lyra-bt-lib__modal-x svg { width: 16px; height: 16px; }

.lyra-bt-lib__modal-title {
    margin: 0 0 8px;
    font-size: 22px;
    font-weight: 800;
    letter-spacing: -0.014em;
    line-height: 1.18;
    color: #0f172a;
    padding-right: 36px;
}
.lyra-bt-lib__modal-intro,
.lyra-bt-lib__modal-desc {
    margin: 0 0 18px;
    font-size: 14.5px;
    line-height: 1.55;
    color: #475569;
}
.lyra-bt-lib__modal-visit {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 11px 18px;
    background: #0f172a;
    color: #fff;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 700;
    text-decoration: none;
    margin-top: 4px;
}
.lyra-bt-lib__modal-visit:hover { background: #1e293b; color: #fff; }
.lyra-bt-lib__modal-visit svg { width: 12px; height: 12px; }

.lyra-bt-lib__modal-form { display: flex; flex-direction: column; gap: 14px; margin-top: 4px; }
.lyra-bt-lib__modal-field { display: flex; flex-direction: column; gap: 5px; }
.lyra-bt-lib__modal-field label {
    font-size: 13px;
    font-weight: 600;
    color: #0f172a;
}
.lyra-bt-lib__modal-req { color: #dc2626; font-weight: 700; }
.lyra-bt-lib__modal-field input,
.lyra-bt-lib__modal-field textarea,
.lyra-bt-lib__modal-field select {
    padding: 11px 13px;
    background: #ffffff;
    color: #0f172a;
    border: 1.5px solid #cbd5e1;
    border-radius: 9px;
    font-size: 14.5px;
    font-family: inherit;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.lyra-bt-lib__modal-field textarea { resize: vertical; min-height: 88px; }
.lyra-bt-lib__modal-field input:focus,
.lyra-bt-lib__modal-field textarea:focus,
.lyra-bt-lib__modal-field select:focus {
    outline: none;
    border-color: var(--lyra-bt-lib-accent, #10b981);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--lyra-bt-lib-accent, #10b981) 25%, transparent);
}

.lyra-bt-lib__modal-honey {
    position: absolute !important;
    left: -9999px !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.lyra-bt-lib__modal-submit {
    margin-top: 8px;
    padding: 14px 16px;
    background: var(--lyra-bt-lib-accent, #10b981);
    color: #fff;
    border: 0;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 800;
    cursor: pointer;
    font-family: inherit;
    transition: filter 0.15s ease, transform 0.15s ease;
}
.lyra-bt-lib__modal-submit:hover:not(:disabled) { transform: translateY(-1px); filter: brightness(1.06); }
.lyra-bt-lib__modal-submit:disabled { opacity: 0.7; cursor: wait; }
.lyra-bt-lib__modal-submit:focus-visible { outline: 2px solid #0f172a; outline-offset: 2px; }

.lyra-bt-lib__modal-status {
    margin-top: 4px;
    padding: 0;
    font-size: 13.5px;
    line-height: 1.4;
    min-height: 1px;
}
.lyra-bt-lib__modal-status--success {
    padding: 10px 12px;
    background: #d1fae5;
    color: #065f46;
    border-radius: 8px;
    font-weight: 600;
}
.lyra-bt-lib__modal-status--error {
    padding: 10px 12px;
    background: #fee2e2;
    color: #b91c1c;
    border-radius: 8px;
    font-weight: 600;
}

@keyframes lyra-bt-lib-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes lyra-bt-lib-pop-in  { from { opacity: 0; transform: translateY(10px) scale(0.97); } to { opacity: 1; transform: translateY(0) scale(1); } }

/* ═════════════════════════════════════════════════════════════════════
 * Reduced motion + responsive
 * ═════════════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
    .lyra-bt-lib *,
    .lyra-bt-lib *::before,
    .lyra-bt-lib *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

@media (max-width: 480px) {
    .lyra-bt-lib { padding: 28px 18px; border-radius: 0; }
    .lyra-bt-lib__modal-dialog { padding: 22px 20px 20px; border-radius: 14px; }
    .lyra-bt-lib__modal-grid-image { width: calc(100% + 40px); margin: -22px -20px 14px; }
}
