/* =============================================================================
   LINGO4ALL — Premium Theme (br_lingo)
   -----------------------------------------------------------------------------
   Standalone CSS. No Tailwind build required. Pure hand-crafted design system.
   Loaded AFTER Bagisto's compiled CSS to override the visual layer.

   Methodology: Component-based BEM-like (.brl-* classes).
   Markup stays clean. Each locale install gets this file as-is.
   ============================================================================= */

/* =========================== TOKENS / VARIABLES =========================== */
:root {
    /* Brand palette */
    --brl-primary:        #0B1220;
    --brl-primary-soft:   #111A2E;
    --brl-primary-tint:   #1A2342;
    --brl-primary-haze:   rgba(11, 18, 32, 0.04);
    --brl-accent:         #C9A66B;
    --brl-accent-strong:  #B8924E;
    --brl-accent-soft:    #F4ECDC;

    /* Neutrals */
    --brl-ink:            #0E1726;
    --brl-ink-2:          #2A3445;
    --brl-muted:          #5A6679;
    --brl-line:           #E6E8EE;
    --brl-line-soft:      #EEF0F4;
    --brl-bg:             #FFFFFF;
    --brl-bg-soft:        #F7F8FB;
    --brl-bg-softer:      #FAFBFD;

    /* States */
    --brl-success:        #16A34A;
    --brl-success-soft:   #DCFCE7;
    --brl-danger:         #DC2626;
    --brl-danger-soft:    #FEE2E2;
    --brl-warning:        #D97706;
    --brl-info:           #2563EB;

    /* Radii */
    --brl-r-xs:           6px;
    --brl-r-sm:           8px;
    --brl-r-md:           12px;
    --brl-r-lg:           16px;
    --brl-r-xl:           20px;
    --brl-r-2xl:          28px;
    --brl-r-pill:         9999px;

    /* Shadows (premium, neutral) */
    --brl-shadow-xs:  0 1px 2px rgba(11, 18, 32, 0.04);
    --brl-shadow-sm:  0 2px 6px rgba(11, 18, 32, 0.06), 0 1px 2px rgba(11, 18, 32, 0.04);
    --brl-shadow-md:  0 6px 16px rgba(11, 18, 32, 0.08), 0 2px 4px rgba(11, 18, 32, 0.04);
    --brl-shadow-lg:  0 14px 36px rgba(11, 18, 32, 0.10), 0 4px 10px rgba(11, 18, 32, 0.05);
    --brl-shadow-xl:  0 24px 60px rgba(11, 18, 32, 0.14), 0 8px 18px rgba(11, 18, 32, 0.06);
    --brl-ring-focus: 0 0 0 3px rgba(11, 18, 32, 0.12);
    --brl-ring-accent: 0 0 0 3px rgba(201, 166, 107, 0.20);

    /* Motion */
    --brl-ease:       cubic-bezier(0.22, 1, 0.36, 1);
    --brl-ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
    --brl-fast:       150ms;
    --brl-base:       220ms;
    --brl-slow:       360ms;

    /* Typography */
    --brl-font-sans:  "Inter", "Inter var", -apple-system, BlinkMacSystemFont, "Segoe UI",
                      Roboto, Helvetica, Arial, sans-serif;
    --brl-font-serif: "DM Serif Display", Georgia, serif;

    /* Spacing scale (in case we need it for grids) */
    --brl-sp-1:  4px;
    --brl-sp-2:  8px;
    --brl-sp-3:  12px;
    --brl-sp-4:  16px;
    --brl-sp-5:  20px;
    --brl-sp-6:  24px;
    --brl-sp-8:  32px;
    --brl-sp-10: 40px;
    --brl-sp-12: 48px;
    --brl-sp-16: 64px;
    --brl-sp-20: 80px;
    --brl-sp-24: 96px;

    /* Container widths */
    --brl-container-max: 1440px;
    --brl-container-px:  60px;
    --brl-container-px-md: 32px;
    --brl-container-px-sm: 20px;

    /* Z-index */
    --brl-z-base:    1;
    --brl-z-header:  40;
    --brl-z-drawer:  50;
    --brl-z-modal:   60;
    --brl-z-toast:   70;
}

/* =========================== RESET / BASE =========================== */
.brl-body,
.brl-body *,
.brl-body *::before,
.brl-body *::after {
    box-sizing: border-box;
}

.brl-body,
.brl-body *,
.brl-body *::before,
.brl-body *::after {
    font-family: var(--brl-font-sans);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-feature-settings: "cv11", "ss01";
}

/* Preserve Bagisto icon font (critical for chrome) */
.brl-body [class^="icon-"],
.brl-body [class*=" icon-"],
.brl-body [class^="icon-"]::before,
.brl-body [class*=" icon-"]::before {
    font-family: "bagisto-shop" !important;
}

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

.brl-body {
    color: var(--brl-ink);
    font-weight: 400;
    letter-spacing: -0.005em;
    background: var(--brl-bg);
    line-height: 1.5;
    margin: 0;
}

.brl-body a {
    color: inherit;
    text-decoration: none;
    transition: color var(--brl-fast) var(--brl-ease), opacity var(--brl-fast) var(--brl-ease);
}

.brl-body img { display: block; max-width: 100%; height: auto; }

.brl-body :focus-visible {
    outline: 2px solid var(--brl-primary);
    outline-offset: 2px;
    border-radius: var(--brl-r-xs);
}

::selection { background-color: rgba(11, 18, 32, 0.16); color: var(--brl-ink); }

/* =========================== TYPOGRAPHY =========================== */
.brl-body h1, .brl-body .brl-h1,
.brl-body h2, .brl-body .brl-h2,
.brl-body h3, .brl-body .brl-h3,
.brl-body h4, .brl-body .brl-h4,
.brl-body h5, .brl-body .brl-h5,
.brl-body h6, .brl-body .brl-h6 {
    color: var(--brl-ink);
    margin: 0;
    letter-spacing: -0.02em;
    line-height: 1.2;
    font-weight: 700;
}

.brl-body .brl-h1, .brl-body h1 { font-size: clamp(36px, 5.5vw, 64px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; }
.brl-body .brl-h2, .brl-body h2 { font-size: clamp(28px, 3.6vw, 44px); font-weight: 750; letter-spacing: -0.025em; line-height: 1.15; }
.brl-body .brl-h3, .brl-body h3 { font-size: clamp(22px, 2.4vw, 28px); font-weight: 700; letter-spacing: -0.02em; line-height: 1.25; }
.brl-body .brl-h4, .brl-body h4 { font-size: 20px; font-weight: 700; letter-spacing: -0.015em; }
.brl-body .brl-h5, .brl-body h5 { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; }
.brl-body .brl-h6, .brl-body h6 { font-size: 14px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; }

.brl-body .brl-serif { font-family: var(--brl-font-serif) !important; font-weight: 400; letter-spacing: -0.005em; font-style: normal; }

.brl-body .brl-lead    { font-size: clamp(16px, 1.4vw, 19px); line-height: 1.6; color: var(--brl-ink-2); }
.brl-body .brl-text    { font-size: 15px; line-height: 1.6; color: var(--brl-ink-2); }
.brl-body .brl-muted   { color: var(--brl-muted); }
.brl-body .brl-text-sm { font-size: 13.5px; line-height: 1.5; color: var(--brl-muted); }
.brl-body .brl-text-xs { font-size: 12px; line-height: 1.4; color: var(--brl-muted); }
.brl-body .brl-tabular { font-variant-numeric: tabular-nums; letter-spacing: -0.005em; }

/* Eyebrow */
.brl-body .brl-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--brl-accent-strong);
}

.brl-body .brl-eyebrow::before {
    content: "";
    width: 24px;
    height: 1px;
    background: currentColor;
    display: inline-block;
}

.brl-body .brl-eyebrow--center::after {
    content: "";
    width: 24px;
    height: 1px;
    background: currentColor;
    display: inline-block;
}

.brl-body .brl-eyebrow--light  { color: var(--brl-accent); }

/* =========================== CONTAINER & SECTIONS =========================== */
.brl-body .brl-container {
    width: 100%;
    max-width: var(--brl-container-max);
    margin-left: auto;
    margin-right: auto;
    padding-left: var(--brl-container-px);
    padding-right: var(--brl-container-px);
}

@media (max-width: 1180px) {
    .brl-body .brl-container { padding-left: var(--brl-container-px-md); padding-right: var(--brl-container-px-md); }
}

@media (max-width: 767px) {
    .brl-body .brl-container { padding-left: var(--brl-container-px-sm); padding-right: var(--brl-container-px-sm); }
}

.brl-body .brl-section {
    padding-top: clamp(36px, 4vw, 64px);
    padding-bottom: clamp(36px, 4vw, 64px);
}

/* Collapse spacing when sections are stacked back-to-back (avoid double padding) */
.brl-body .brl-section + .brl-section { padding-top: 0; }
.brl-body .brl-section--tight + .brl-section,
.brl-body .brl-section + .brl-section--tight { padding-top: 0; }

.brl-body .brl-section--tight   { padding-top: clamp(20px, 2.5vw, 36px); padding-bottom: clamp(20px, 2.5vw, 36px); }
.brl-body .brl-section--bleed   { padding-top: 0; padding-bottom: 0; }
.brl-body .brl-section--soft    { background: var(--brl-bg-soft); }
.brl-body .brl-section--softer  { background: var(--brl-bg-softer); }
.brl-body .brl-section--dark    {
    background:
        radial-gradient(900px 500px at 90% 10%, rgba(201, 166, 107, 0.10), transparent 60%),
        radial-gradient(900px 500px at -10% 100%, rgba(255, 255, 255, 0.03), transparent 60%),
        var(--brl-primary);
    color: #FFFFFF;
}

.brl-body .brl-section--dark .brl-h1,
.brl-body .brl-section--dark .brl-h2,
.brl-body .brl-section--dark .brl-h3,
.brl-body .brl-section--dark h1,
.brl-body .brl-section--dark h2,
.brl-body .brl-section--dark h3 { color: #FFFFFF; }

.brl-body .brl-section--dark .brl-text,
.brl-body .brl-section--dark .brl-lead { color: rgba(255, 255, 255, 0.75); }

.brl-body .brl-section--dark .brl-muted { color: rgba(255, 255, 255, 0.55); }

/* Section header (eyebrow + title + subtitle) */
.brl-body .brl-section-header {
    display: grid;
    gap: 16px;
    margin-bottom: clamp(32px, 4vw, 56px);
    max-width: 720px;
}

.brl-body .brl-section-header--center {
    margin-left: auto;
    margin-right: auto;
    text-align: center;
}

.brl-body .brl-section-header--center .brl-eyebrow { justify-content: center; }

/* =========================== BUTTONS =========================== */
.brl-body .brl-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: var(--brl-r-md);
    padding: 14px 26px;
    font-weight: 600;
    font-size: 14.5px;
    letter-spacing: 0.005em;
    line-height: 1.2;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background var(--brl-base) var(--brl-ease),
                color var(--brl-base) var(--brl-ease),
                border-color var(--brl-base) var(--brl-ease),
                transform var(--brl-fast) var(--brl-ease),
                box-shadow var(--brl-base) var(--brl-ease),
                opacity var(--brl-fast) var(--brl-ease);
    white-space: nowrap;
    text-decoration: none;
    user-select: none;
}

.brl-body .brl-btn:disabled,
.brl-body .brl-btn[disabled] { cursor: not-allowed; opacity: 0.5; transform: none !important; }

/* Sizes */
.brl-body .brl-btn--sm { padding: 10px 18px; font-size: 13px; }
.brl-body .brl-btn--lg { padding: 16px 32px; font-size: 15.5px; }

.brl-body .brl-btn--pill   { border-radius: var(--brl-r-pill); }
.brl-body .brl-btn--block  { width: 100%; }

/* Variants */
.brl-body .brl-btn--primary {
    background: var(--brl-primary);
    color: #FFFFFF;
    border-color: var(--brl-primary);
    box-shadow: var(--brl-shadow-sm);
}
.brl-body .brl-btn--primary:hover { background: var(--brl-primary-soft); border-color: var(--brl-primary-soft); box-shadow: var(--brl-shadow-md); transform: translateY(-1px); }
.brl-body .brl-btn--primary:active { transform: translateY(0); box-shadow: var(--brl-shadow-xs); }

.brl-body .brl-btn--secondary {
    background: transparent;
    color: var(--brl-primary);
    border-color: var(--brl-primary);
}
.brl-body .brl-btn--secondary:hover { background: var(--brl-primary); color: #FFFFFF; box-shadow: var(--brl-shadow-sm); transform: translateY(-1px); }

.brl-body .brl-btn--accent {
    background: var(--brl-accent);
    color: var(--brl-primary);
    border-color: var(--brl-accent);
    box-shadow: var(--brl-shadow-sm);
}
.brl-body .brl-btn--accent:hover { background: var(--brl-accent-strong); border-color: var(--brl-accent-strong); box-shadow: var(--brl-shadow-md); transform: translateY(-1px); }

.brl-body .brl-btn--ghost {
    background: transparent;
    color: var(--brl-ink);
    border-color: transparent;
}
.brl-body .brl-btn--ghost:hover { background: var(--brl-bg-soft); color: var(--brl-primary); }

.brl-body .brl-btn--light {
    background: #FFFFFF;
    color: var(--brl-primary);
    border-color: rgba(255, 255, 255, 0.0);
    box-shadow: var(--brl-shadow-sm);
}
.brl-body .brl-btn--light:hover { background: var(--brl-bg-soft); box-shadow: var(--brl-shadow-md); transform: translateY(-1px); }

.brl-body .brl-btn--dark {
    background: var(--brl-primary);
    color: #FFFFFF;
    border-color: var(--brl-primary);
}
.brl-body .brl-btn--dark:hover { background: var(--brl-primary-soft); }

/* Bagisto's primary-button / secondary-button polish (compat) */
.brl-body .primary-button,
.brl-body .secondary-button {
    border-radius: var(--brl-r-md) !important;
    padding: 14px 26px !important;
    font-weight: 600 !important;
    letter-spacing: 0.005em;
    transition: background var(--brl-base) var(--brl-ease),
                color var(--brl-base) var(--brl-ease),
                border-color var(--brl-base) var(--brl-ease),
                transform var(--brl-fast) var(--brl-ease),
                box-shadow var(--brl-base) var(--brl-ease);
}
.brl-body .primary-button {
    background: var(--brl-primary) !important;
    color: #FFFFFF !important;
    border-color: var(--brl-primary) !important;
    box-shadow: var(--brl-shadow-sm);
}
.brl-body .primary-button:hover { background: var(--brl-primary-soft) !important; box-shadow: var(--brl-shadow-md); transform: translateY(-1px); opacity: 1 !important; }
.brl-body .secondary-button {
    color: var(--brl-primary) !important;
    border-color: var(--brl-primary) !important;
    background: transparent !important;
}
.brl-body .secondary-button:hover { background: var(--brl-primary) !important; color: #FFFFFF !important; transform: translateY(-1px); }

/* =========================== BADGES & PILLS =========================== */
.brl-body .brl-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-radius: var(--brl-r-pill);
    line-height: 1;
    border: 1px solid transparent;
}

.brl-body .brl-badge--sale   { background: var(--brl-danger); color: #FFFFFF; }
.brl-body .brl-badge--new    { background: var(--brl-primary); color: #FFFFFF; }
.brl-body .brl-badge--gold   { background: var(--brl-accent); color: var(--brl-primary); }
.brl-body .brl-badge--soft   { background: var(--brl-bg-soft); color: var(--brl-ink-2); border-color: var(--brl-line); }
.brl-body .brl-badge--outline{ background: transparent; color: var(--brl-ink-2); border-color: var(--brl-line); }

.brl-body .brl-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: rgba(11, 18, 32, 0.04);
    border-radius: var(--brl-r-pill);
    font-size: 13px;
    color: var(--brl-ink-2);
}

.brl-body .brl-pill--dot::before {
    content: "";
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--brl-success);
    box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.18);
}

/* =========================== FORMS =========================== */
.brl-body .brl-input,
.brl-body input[type="text"]:not(.no-brl),
.brl-body input[type="email"]:not(.no-brl),
.brl-body input[type="password"]:not(.no-brl),
.brl-body input[type="search"]:not(.no-brl),
.brl-body input[type="number"]:not(.no-brl),
.brl-body input[type="tel"]:not(.no-brl),
.brl-body input[type="url"]:not(.no-brl),
.brl-body select:not(.no-brl),
.brl-body textarea:not(.no-brl) {
    width: 100%;
    padding: 12px 16px;
    background: #FFFFFF;
    border: 1px solid var(--brl-line);
    border-radius: var(--brl-r-md);
    font-size: 14.5px;
    color: var(--brl-ink);
    font-family: var(--brl-font-sans);
    transition: border-color var(--brl-fast) var(--brl-ease),
                box-shadow var(--brl-fast) var(--brl-ease),
                background var(--brl-fast) var(--brl-ease);
    line-height: 1.4;
}

.brl-body .brl-input:focus,
.brl-body input[type="text"]:focus,
.brl-body input[type="email"]:focus,
.brl-body input[type="password"]:focus,
.brl-body input[type="search"]:focus,
.brl-body input[type="number"]:focus,
.brl-body input[type="tel"]:focus,
.brl-body input[type="url"]:focus,
.brl-body select:focus,
.brl-body textarea:focus {
    border-color: var(--brl-primary);
    box-shadow: var(--brl-ring-focus);
    outline: none;
}

.brl-body .brl-input::placeholder,
.brl-body input::placeholder,
.brl-body textarea::placeholder { color: var(--brl-muted); }

.brl-body .brl-input--pill,
.brl-body input.brl-input--pill { border-radius: var(--brl-r-pill); padding-left: 22px; padding-right: 22px; }

.brl-body label, .brl-body .brl-label { color: var(--brl-ink-2); font-weight: 500; font-size: 14px; }

/* =========================== CARDS =========================== */
.brl-body .brl-card {
    background: #FFFFFF;
    border: 1px solid var(--brl-line-soft);
    border-radius: var(--brl-r-lg);
    overflow: hidden;
    transition: transform var(--brl-base) var(--brl-ease),
                box-shadow var(--brl-base) var(--brl-ease),
                border-color var(--brl-base) var(--brl-ease);
}

.brl-body .brl-card--hover:hover {
    transform: translateY(-3px);
    box-shadow: var(--brl-shadow-md);
    border-color: var(--brl-line);
}

.brl-body .brl-card__media {
    background: var(--brl-bg-soft);
    overflow: hidden;
    aspect-ratio: 1;
    position: relative;
}

.brl-body .brl-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--brl-slow) var(--brl-ease);
}

.brl-body .brl-card--hover:hover .brl-card__media img { transform: scale(1.04); }

.brl-body .brl-card__body { padding: 18px 20px 20px; display: grid; gap: 8px; }

.brl-body .brl-card__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--brl-ink);
    letter-spacing: -0.01em;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.brl-body .brl-card__price {
    font-size: 18px;
    font-weight: 800;
    color: var(--brl-primary);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.01em;
}

.brl-body .brl-card__meta {
    font-size: 12.5px;
    color: var(--brl-muted);
    font-weight: 500;
}

/* =========================== ICON BUTTONS =========================== */
.brl-body .brl-icon-btn {
    display: inline-grid;
    place-items: center;
    width: 42px;
    height: 42px;
    border-radius: var(--brl-r-pill);
    background: var(--brl-bg-soft);
    color: var(--brl-ink);
    cursor: pointer;
    border: none;
    position: relative;
    transition: background var(--brl-fast) var(--brl-ease),
                color var(--brl-fast) var(--brl-ease),
                transform var(--brl-fast) var(--brl-ease);
}

.brl-body .brl-icon-btn:hover {
    background: var(--brl-primary);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.brl-body .brl-icon-btn [class^="icon-"] { font-size: 19px; }

.brl-body .brl-icon-btn__count {
    position: absolute;
    top: -2px;
    right: -2px;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 9px;
    background: var(--brl-accent);
    color: var(--brl-primary);
    font-size: 10.5px;
    font-weight: 700;
    display: grid;
    place-items: center;
    line-height: 1;
}

/* =========================== UTILITIES =========================== */
.brl-body .brl-grid       { display: grid; }
.brl-body .brl-flex       { display: flex; }
.brl-body .brl-inline-flex{ display: inline-flex; }
.brl-body .brl-block      { display: block; }
.brl-body .brl-hidden     { display: none !important; }
.brl-body .brl-items-center{ align-items: center; }
.brl-body .brl-items-start { align-items: flex-start; }
.brl-body .brl-justify-between { justify-content: space-between; }
.brl-body .brl-justify-center  { justify-content: center; }
.brl-body .brl-gap-2 { gap: 8px; }
.brl-body .brl-gap-3 { gap: 12px; }
.brl-body .brl-gap-4 { gap: 16px; }
.brl-body .brl-gap-6 { gap: 24px; }
.brl-body .brl-gap-8 { gap: 32px; }

.brl-body .brl-text-center { text-align: center; }
.brl-body .brl-text-left   { text-align: left; }
.brl-body .brl-text-right  { text-align: right; }

.brl-body .brl-mt-0  { margin-top: 0; }
.brl-body .brl-mt-2  { margin-top: 8px; }
.brl-body .brl-mt-4  { margin-top: 16px; }
.brl-body .brl-mt-6  { margin-top: 24px; }
.brl-body .brl-mt-8  { margin-top: 32px; }
.brl-body .brl-mt-12 { margin-top: 48px; }

.brl-body .brl-mb-0  { margin-bottom: 0; }
.brl-body .brl-mb-2  { margin-bottom: 8px; }
.brl-body .brl-mb-4  { margin-bottom: 16px; }
.brl-body .brl-mb-6  { margin-bottom: 24px; }
.brl-body .brl-mb-8  { margin-bottom: 32px; }

.brl-body .brl-max-w-prose  { max-width: 65ch; }
.brl-body .brl-max-w-2xl    { max-width: 720px; }

.brl-body .brl-scroll-hide::-webkit-scrollbar { display: none; }
.brl-body .brl-scroll-hide { -ms-overflow-style: none; scrollbar-width: none; }

@media (max-width: 1023px) {
    .brl-body .brl-hide-lg { display: none !important; }
}
@media (max-width: 767px) {
    .brl-body .brl-hide-md { display: none !important; }
}
@media (max-width: 525px) {
    .brl-body .brl-hide-sm { display: none !important; }
}
@media (min-width: 1024px) {
    .brl-body .brl-show-lg-only { display: none !important; }
}

/* Animations */
@keyframes brlFadeUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes brlFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes brlPulse  { 0%, 100% { opacity: 1; } 50% { opacity: 0.45; } }

.brl-body [data-brl-anim="fade-up"] { opacity: 0; animation: brlFadeUp var(--brl-slow) var(--brl-ease) forwards; }
.brl-body [data-brl-anim="fade-in"] { opacity: 0; animation: brlFadeIn var(--brl-slow) var(--brl-ease) forwards; }

@media (prefers-reduced-motion: reduce) {
    .brl-body *, .brl-body *::before, .brl-body *::after {
        animation-duration: 0ms !important;
        transition-duration: 0ms !important;
    }
}
