/* ============================================================================
   Modern SaaS refresh v3 — New layout + premium look.
   Loaded LAST in AppAsset.php — wins over earlier component CSS.
   Markup untouched.

   STRUCTURAL changes:
   - Icon-rail floating sidebar (76px) that expands to 264px on hover
   - Content area uses overlay model (no grid shift on hover)
   - Asymmetric dashboard hero with floating brand orb + meta strip
   - Stat tiles redesigned: horizontal flow with gradient progress rail
   - Premium aurora background with animated drift
   ============================================================================ */

/* ---------- 1. Tokens ---------- */
:root,
[data-bs-theme="light"] {
    --mf-primary:        #6366F1;
    --mf-primary-hover:  #4F46E5;
    --mf-primary-subtle: #EEF0FF;
    --mf-primary-rgb:    99, 102, 241;
    --mf-accent:         #A855F7;
    --mf-accent-rgb:     168, 85, 247;
    --mf-accent-2:       #EC4899;
    --mf-accent-2-rgb:   236, 72, 153;

    --mf-brand-gradient:   linear-gradient(135deg, #6366F1 0%, #A855F7 50%, #EC4899 100%);
    --mf-brand-gradient-2: linear-gradient(135deg, #6366F1 0%, #A855F7 100%);
    --mf-brand-gradient-3: linear-gradient(135deg, #818CF8 0%, #C084FC 100%);

    --mf-bg:             #F5F6FB;
    --mf-bg-deep:        #ECEEF6;
    --mf-surface:        #FFFFFF;
    --mf-surface-2:      #F1F2F8;
    --mf-border:         #E6E8F0;
    --mf-border-strong:  #D4D7E4;

    --mf-text:           #0A0B1F;
    --mf-text-muted:     #5B5F75;
    --mf-text-subtle:    #8B8FA3;

    --mf-shadow-xs: 0 1px 2px rgba(13, 13, 30, .04);
    --mf-shadow-sm: 0 1px 2px rgba(13, 13, 30, .04), 0 1px 3px rgba(13, 13, 30, .03);
    --mf-shadow-md: 0 6px 16px -4px rgba(13, 13, 30, .08), 0 2px 6px -2px rgba(13, 13, 30, .04);
    --mf-shadow-lg: 0 20px 44px -12px rgba(13, 13, 30, .16), 0 6px 18px -6px rgba(13, 13, 30, .06);
    --mf-shadow-xl: 0 36px 72px -16px rgba(13, 13, 30, .22), 0 12px 28px -8px rgba(13, 13, 30, .08);
    --mf-shadow-glow:   0 10px 28px -6px rgba(99, 102, 241, .45);
    --mf-shadow-glow-2: 0 14px 40px -8px rgba(168, 85, 247, .42);

    --mf-radius-sm: 7px;
    --mf-radius:    10px;
    --mf-radius-lg: 16px;
    --mf-radius-xl: 22px;
    --mf-radius-2xl: 28px;

    /* Sidebar dimensions — permanent expanded */
    --mf-rail-w:        252px;
    --mf-rail-w-open:   252px;
    --mf-rail-gap:      14px;

    --mf-glass-bg:     rgba(255, 255, 255, .75);
    --mf-glass-border: rgba(255, 255, 255, .85);
    --mf-glass-blur:   blur(24px) saturate(180%);
}

[data-bs-theme="dark"] {
    --mf-primary:        #818CF8;
    --mf-primary-hover:  #A5B4FC;
    --mf-primary-subtle: rgba(129, 140, 248, .14);
    --mf-primary-rgb:    129, 140, 248;
    --mf-accent:         #C084FC;
    --mf-accent-rgb:     192, 132, 252;
    --mf-accent-2:       #F472B6;
    --mf-accent-2-rgb:   244, 114, 182;
    --mf-brand-gradient:   linear-gradient(135deg, #818CF8 0%, #C084FC 50%, #F472B6 100%);
    --mf-brand-gradient-2: linear-gradient(135deg, #818CF8 0%, #C084FC 100%);

    --mf-bg:             #06070D;
    --mf-bg-deep:        #02030A;
    --mf-surface:        #0E1018;
    --mf-surface-2:      #161827;
    --mf-border:         #1E2030;
    --mf-border-strong:  #2C3047;

    --mf-text:           #F4F5FA;
    --mf-text-muted:     #9CA0B5;
    --mf-text-subtle:    #6B6F85;

    --mf-shadow-xs: 0 1px 2px rgba(0, 0, 0, .35);
    --mf-shadow-sm: 0 0 0 1px var(--mf-border), 0 1px 2px rgba(0, 0, 0, .4);
    --mf-shadow-md: 0 0 0 1px var(--mf-border), 0 8px 20px rgba(0, 0, 0, .5);
    --mf-shadow-lg: 0 0 0 1px var(--mf-border), 0 28px 60px rgba(0, 0, 0, .6);
    --mf-shadow-xl: 0 0 0 1px var(--mf-border), 0 40px 88px rgba(0, 0, 0, .7);
    --mf-shadow-glow:   0 10px 32px -6px rgba(129, 140, 248, .55);
    --mf-shadow-glow-2: 0 14px 40px -10px rgba(192, 132, 252, .48);

    --mf-glass-bg:     rgba(14, 16, 24, .72);
    --mf-glass-border: rgba(255, 255, 255, .08);
}

/* ---------- 2. Typography ---------- */
html, body {
    font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    font-feature-settings: 'cv11', 'ss01', 'ss03', 'cv02';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    color: var(--mf-text);
}
@supports (font-variation-settings: normal) {
    html, body { font-family: 'Inter var', 'Inter', system-ui, sans-serif; }
}
h1, h2, h3, h4, h5, h6 { letter-spacing: -0.025em; font-weight: 650; }
.mf-stat__value, .mf-badge, table td, table th, code,
.mf-account-card__stats strong { font-variant-numeric: tabular-nums; }

/* ---------- 3. App shell — NEW LAYOUT: rail + overlay ---------- */
body { background: var(--mf-bg); }

.mf-app-shell {
    display: block;
    grid-template-columns: none;
    background:
        radial-gradient(ellipse 1000px 700px at 90% -100px,  rgba(var(--mf-accent-rgb), .14),    transparent 55%),
        radial-gradient(ellipse 800px 600px at -100px 110%,  rgba(var(--mf-primary-rgb), .12),   transparent 55%),
        radial-gradient(ellipse 600px 500px at 40% 50%,      rgba(var(--mf-accent-2-rgb), .04),  transparent 70%),
        var(--mf-bg);
    background-attachment: fixed;
    min-height: 100vh;
    padding: 0;
    position: relative;
}

[data-bs-theme="dark"] .mf-app-shell {
    background:
        radial-gradient(ellipse 1000px 700px at 90% -100px,  rgba(var(--mf-accent-rgb), .18),    transparent 55%),
        radial-gradient(ellipse 800px 600px at -100px 110%,  rgba(var(--mf-primary-rgb), .14),   transparent 55%),
        var(--mf-bg);
    background-attachment: fixed;
}

/* ---------- Floating sidebar (permanent expanded) ---------- */
.mf-app-shell__sidebar {
    position: fixed;
    top: var(--mf-rail-gap);
    left: var(--mf-rail-gap);
    bottom: var(--mf-rail-gap);
    width: var(--mf-rail-w);
    z-index: 100;
    grid-column: unset;
    background: transparent;
    border: 0;
    height: auto;
    overflow: visible;
}

.mf-sidebar {
    height: 100%;
    background: var(--mf-glass-bg);
    backdrop-filter: var(--mf-glass-blur);
    -webkit-backdrop-filter: var(--mf-glass-blur);
    border: 1px solid var(--mf-glass-border);
    border-radius: var(--mf-radius-xl);
    box-shadow: var(--mf-shadow-md);
    padding: 16px 14px;
    gap: 14px;
    overflow: hidden;
}
[data-bs-theme="dark"] .mf-sidebar { border-color: rgba(255,255,255,.06); }

/* Content area sits beside the rail with permanent left gutter */
.mf-app-shell__main {
    grid-column: unset;
    margin-left: calc(var(--mf-rail-w) + var(--mf-rail-gap) * 2);
    padding: 0;
}
.mf-app-shell__content {
    padding: 28px 40px 56px;
    width: 100%;
    max-width: none;
}
@media (min-width: 1600px) {
    .mf-app-shell__content { padding: 32px 56px 64px; }
}
@media (max-width: 1024px) {
    .mf-app-shell__content { padding: 22px 22px 36px; }
}

/* ---------- 4. Sidebar contents — collapsed-by-default labels ---------- */
.mf-sidebar__brand {
    height: 44px;
    padding: 0 6px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: -0.015em;
    color: var(--mf-text);
    gap: 12px;
    overflow: hidden;
}
.mf-sidebar__brand > span:last-child {
    background: var(--mf-brand-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    white-space: nowrap;
}

.mf-sidebar__brand-mark {
    width: 36px; height: 36px;
    border-radius: 11px;
    background: var(--mf-brand-gradient);
    color: #fff !important;
    -webkit-text-fill-color: #fff;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.25);
    font-size: 12px;
    font-weight: 700;
    position: relative;
    flex: 0 0 36px;
}
.mf-sidebar__brand-mark::after {
    content: '';
    position: absolute; inset: 0;
    border-radius: 11px;
    background: linear-gradient(180deg, rgba(255,255,255,.22), transparent 55%);
    pointer-events: none;
}

.mf-sidebar__section { gap: 4px; }

.mf-sidebar__item {
    height: 42px;
    padding: 0 11px;
    border-radius: 11px;
    color: var(--mf-text-muted);
    font-size: 13.5px;
    font-weight: 500;
    gap: 14px;
    position: relative;
    overflow: hidden;
}
.mf-sidebar__item-icon {
    width: 20px; height: 20px;
    flex: 0 0 20px;
    margin-left: 1px;
}
.mf-sidebar__item-label {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mf-sidebar__item:hover {
    background: rgba(var(--mf-primary-rgb), .08);
    color: var(--mf-text);
}
[data-bs-theme="dark"] .mf-sidebar__item:hover { background: rgba(255,255,255,.04); }

.mf-sidebar__item--active {
    background: var(--mf-brand-gradient-2);
    color: #fff;
    font-weight: 600;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.18);
}
.mf-sidebar__item--active:hover {
    background: var(--mf-brand-gradient-2);
    color: #fff;
    filter: brightness(1.06);
}

.mf-sidebar__item-count {
    font-size: 10.5px;
    padding: 2px 7px;
    border-radius: 6px;
    background: var(--mf-surface-2);
    color: var(--mf-text-subtle);
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    border: 1px solid var(--mf-border);
    margin-left: auto;
}
.mf-sidebar__item--active .mf-sidebar__item-count {
    background: rgba(255,255,255,.18);
    color: #fff;
    border-color: transparent;
}

.mf-sidebar__footer {
    border-top: 1px solid var(--mf-border);
    padding-top: 12px;
    gap: 8px;
}

.mf-sidebar__license {
    background: linear-gradient(135deg, var(--mf-surface-2) 0%, var(--mf-surface) 100%);
    border: 1px solid var(--mf-border);
    border-radius: 12px;
    padding: 12px;
    box-shadow: var(--mf-shadow-xs);
}
[data-bs-theme="dark"] .mf-sidebar__license { background: rgba(255,255,255,.025); }

/* Mobile: simpler full-width sidebar */
@media (max-width: 767.98px) {
    .mf-app-shell__sidebar {
        position: fixed;
        inset: var(--mf-rail-gap);
        width: var(--mf-rail-w);
    }
    .mf-app-shell__main {
        margin-left: calc(var(--mf-rail-w) + var(--mf-rail-gap) * 2);
    }
}

/* ---------- 5. Dashboard hero ---------- */
.mf-dashboard__header {
    margin-bottom: 28px;
    padding: 40px 48px;
    background:
        linear-gradient(135deg, rgba(var(--mf-primary-rgb), .10), rgba(var(--mf-accent-rgb), .08) 50%, transparent 80%),
        var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-2xl);
    box-shadow: var(--mf-shadow-sm);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
    min-height: 140px;
}
.mf-dashboard__header > div:first-child { max-width: 720px; flex: 1; min-width: 280px; }
.mf-dashboard__header::before {
    content: '';
    position: absolute;
    top: -100px; right: -100px;
    width: 360px; height: 360px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-accent-rgb), .28), transparent 65%);
    filter: blur(28px);
    animation: mf-orb 14s ease-in-out infinite alternate;
    pointer-events: none;
}
.mf-dashboard__header::after {
    content: '';
    position: absolute;
    bottom: -120px; left: 25%;
    width: 300px; height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-primary-rgb), .22), transparent 65%);
    filter: blur(32px);
    animation: mf-orb 18s ease-in-out infinite alternate-reverse;
    pointer-events: none;
}
@keyframes mf-orb {
    0%   { transform: translate(0, 0)    scale(1); }
    100% { transform: translate(-4%, 4%) scale(1.1); }
}
.mf-dashboard__header > * { position: relative; z-index: 1; }

.mf-dashboard__title {
    font-size: 44px;
    font-weight: 800;
    letter-spacing: -0.045em;
    background: linear-gradient(135deg, var(--mf-text) 0%, #4F46E5 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    margin: 0;
    line-height: 1.02;
}
.mf-dashboard__title::after {
    content: '';
    display: block;
    width: 56px;
    height: 4px;
    margin-top: 14px;
    background: var(--mf-brand-gradient);
    border-radius: 4px;
    box-shadow: var(--mf-shadow-glow);
}
[data-bs-theme="dark"] .mf-dashboard__title {
    background: linear-gradient(135deg, #fff 0%, #A5B4FC 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.mf-dashboard__subtitle {
    font-size: 15px;
    color: var(--mf-text-muted);
    margin-top: 8px;
}

.mf-dashboard__header-actions { gap: 10px; }
.mf-dashboard__header .mf-btn--outline {
    background: var(--mf-glass-bg);
    backdrop-filter: blur(10px);
    border-color: var(--mf-border);
}

/* ---------- 6. Stat tiles — BENTO asymmetric grid ---------- */
.mf-dashboard__stats {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    grid-template-rows: 1fr 1fr;
    grid-template-areas:
        "hero side1"
        "hero side2";
    gap: 18px;
    margin-bottom: 36px;
    min-height: 280px;
}
.mf-dashboard__stats > .mf-stat:nth-child(1) {
    grid-area: hero;
    padding: 32px 36px;
    background:
        linear-gradient(135deg, rgba(var(--mf-primary-rgb), .06), transparent 60%),
        var(--mf-surface);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
}
.mf-dashboard__stats > .mf-stat:nth-child(1) .mf-stat__icon {
    width: 56px; height: 56px;
    border-radius: 16px;
}
.mf-dashboard__stats > .mf-stat:nth-child(1) .mf-stat__icon svg { width: 26px; height: 26px; }
.mf-dashboard__stats > .mf-stat:nth-child(1) .mf-stat__value {
    font-size: 58px;
    font-weight: 800;
    letter-spacing: -0.045em;
    line-height: 0.95;
    background: linear-gradient(180deg, var(--mf-text) 0%, var(--mf-text-muted) 220%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
[data-bs-theme="dark"] .mf-dashboard__stats > .mf-stat:nth-child(1) .mf-stat__value {
    background: linear-gradient(180deg, #fff 0%, var(--mf-text-muted) 180%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.mf-dashboard__stats > .mf-stat:nth-child(2) { grid-area: side1; }
.mf-dashboard__stats > .mf-stat:nth-child(3) { grid-area: side2; }

@media (max-width: 900px) {
    .mf-dashboard__stats {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        grid-template-areas: "hero" "side1" "side2";
        min-height: auto;
    }
    .mf-dashboard__stats > .mf-stat:nth-child(1) .mf-stat__value { font-size: 40px; }
}

.mf-stat {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    padding: 24px 26px;
    box-shadow: var(--mf-shadow-sm);
    position: relative;
    overflow: hidden;
    transition: transform 260ms cubic-bezier(.4,0,.2,1), box-shadow 260ms, border-color 260ms;
}
.mf-stat::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--mf-brand-gradient);
    transform: scaleX(0.3);
    transform-origin: left;
    transition: transform 320ms cubic-bezier(.4,0,.2,1);
}
.mf-stat::after {
    content: '';
    position: absolute;
    top: -50px; right: -50px;
    width: 180px; height: 180px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-primary-rgb), .14), transparent 70%);
    pointer-events: none;
    transition: transform 400ms;
}
.mf-stat--success::before { background: linear-gradient(135deg, #10B981, #059669); }
.mf-stat--success::after { background: radial-gradient(circle, rgba(16, 185, 129, .16), transparent 70%); }
.mf-stat--warning::before { background: linear-gradient(135deg, #F59E0B, #D97706); }
.mf-stat--warning::after { background: radial-gradient(circle, rgba(245, 158, 11, .16), transparent 70%); }

.mf-stat:hover {
    transform: translateY(-5px);
    box-shadow: var(--mf-shadow-lg);
    border-color: rgba(var(--mf-primary-rgb), .3);
}
.mf-stat:hover::before { transform: scaleX(1); }
.mf-stat:hover::after { transform: scale(1.25); }

.mf-stat__icon {
    width: 48px; height: 48px;
    border-radius: 13px;
    background: var(--mf-brand-gradient-2);
    color: #fff !important;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.25);
    position: relative;
}
.mf-stat__icon svg { width: 22px; height: 22px; }
.mf-stat__icon::after {
    content: '';
    position: absolute; inset: 0;
    border-radius: 13px;
    background: linear-gradient(180deg, rgba(255,255,255,.22), transparent 55%);
    pointer-events: none;
}
.mf-stat--success .mf-stat__icon {
    background: linear-gradient(135deg, #10B981 0%, #059669 100%);
    box-shadow: 0 10px 28px -6px rgba(16, 185, 129, .42), inset 0 1px 0 rgba(255,255,255,.25);
}
.mf-stat--warning .mf-stat__icon {
    background: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);
    box-shadow: 0 10px 28px -6px rgba(245, 158, 11, .42), inset 0 1px 0 rgba(255,255,255,.25);
}

.mf-stat__label {
    font-size: 12px;
    color: var(--mf-text-muted);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}
.mf-stat__value {
    font-size: 38px;
    font-weight: 750;
    letter-spacing: -0.04em;
    color: var(--mf-text);
    line-height: 1.02;
    margin-top: 4px;
}

@media (max-width: 900px) {
    .mf-dashboard__stats { grid-template-columns: 1fr; }
}

/* ---------- 7. Section titles ---------- */
.mf-dashboard__accounts-header {
    padding: 0 4px;
    margin-bottom: 18px;
}
.mf-dashboard__accounts-title {
    font-size: 18px;
    font-weight: 650;
    letter-spacing: -0.02em;
    color: var(--mf-text);
    display: flex; align-items: center; gap: 12px;
}
.mf-dashboard__accounts-title::before {
    content: '';
    width: 4px; height: 20px;
    background: var(--mf-brand-gradient-2);
    border-radius: 4px;
    box-shadow: var(--mf-shadow-glow);
}

/* ---------- 8. Account cards ---------- */
.mf-account-grid {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
}
@media (min-width: 1600px) {
    .mf-account-grid {
        grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
        gap: 18px;
    }
}

.mf-account-card {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    padding: 22px;
    transition: transform 260ms cubic-bezier(.4,0,.2,1), box-shadow 260ms, border-color 260ms;
    position: relative;
    overflow: hidden;
}
.mf-account-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--mf-brand-gradient);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 320ms cubic-bezier(.4,0,.2,1);
}
.mf-account-card::after {
    content: '';
    position: absolute;
    top: -40px; right: -40px;
    width: 160px; height: 160px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-primary-rgb), .08), transparent 70%);
    pointer-events: none;
    opacity: 0;
    transition: opacity 300ms;
}
.mf-account-card:hover::before { transform: scaleX(1); }
.mf-account-card:hover::after { opacity: 1; }
.mf-account-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--mf-shadow-lg);
    border-color: rgba(var(--mf-primary-rgb), .3);
}
.mf-account-card__name { font-size: 15px; font-weight: 650; letter-spacing: -0.01em; }
.mf-account-card__meta {
    font-size: 11px;
    color: var(--mf-text-subtle);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-weight: 600;
    margin-top: 3px;
}
.mf-account-card__stats {
    padding-top: 14px;
    margin-top: 2px;
    border-top: 1px solid var(--mf-border);
}
.mf-account-card__stats strong {
    font-size: 20px;
    font-weight: 700;
    color: var(--mf-text);
    letter-spacing: -0.025em;
    display: block;
}
.mf-account-card__stat-label {
    font-size: 10.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--mf-text-subtle);
    margin-bottom: 2px;
}

/* Avatar: gradient ring */
.mf-avatar {
    box-shadow:
        0 0 0 2px var(--mf-surface),
        0 0 0 4px transparent,
        0 6px 14px -4px rgba(13, 13, 30, .2),
        inset 0 1px 0 rgba(255,255,255,.25);
    font-weight: 700;
    letter-spacing: -0.01em;
    position: relative;
}
.mf-avatar--lg {
    border-radius: 14px;
}

/* ---------- 9. Buttons ---------- */
.mf-btn {
    height: 40px;
    border-radius: 10px;
    font-weight: 550;
    font-size: 13.5px;
    letter-spacing: -0.005em;
    transition: transform 150ms, box-shadow 200ms, filter 200ms, background 200ms, border-color 200ms, color 200ms;
}
.mf-btn--sm { height: 32px; border-radius: 8px; font-size: 12.5px; padding: 0 12px; }
.mf-btn--lg { height: 50px; border-radius: 12px; font-size: 15px; padding: 0 24px; }

.mf-btn--primary {
    background: var(--mf-brand-gradient-2);
    border-color: transparent;
    color: #fff;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.2);
}
.mf-btn--primary:hover {
    filter: brightness(1.08);
    transform: translateY(-1px);
    box-shadow: var(--mf-shadow-glow-2), inset 0 1px 0 rgba(255,255,255,.25);
    color: #fff;
}
.mf-btn--primary:active { transform: translateY(0); filter: brightness(.95); }

.mf-btn--outline {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border-strong);
    color: var(--mf-text);
    box-shadow: var(--mf-shadow-xs);
}
.mf-btn--outline:hover {
    background: var(--mf-surface-2);
    border-color: rgba(var(--mf-primary-rgb), .4);
    color: var(--mf-text);
    box-shadow: var(--mf-shadow-sm);
}

.mf-btn--ghost:hover { background: rgba(var(--mf-primary-rgb), .08); color: var(--mf-text); }

.mf-btn--danger {
    background: linear-gradient(135deg, #F43F5E 0%, #DC2626 100%);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 10px 28px -6px rgba(244, 63, 94, .45), inset 0 1px 0 rgba(255,255,255,.2);
}
.mf-btn--danger:hover { filter: brightness(1.08); transform: translateY(-1px); }

/* ---------- 10. Forms ---------- */
.mf-input,
.form-control {
    height: 44px;
    border-radius: 11px;
    border: 1px solid var(--mf-border);
    background: var(--mf-surface);
    transition: border-color 150ms, box-shadow 150ms, background 150ms;
    padding: 0 14px;
    font-size: 14px;
}
.mf-input:hover:not(:focus),
.form-control:hover:not(:focus) { border-color: var(--mf-border-strong); }
.mf-input:focus,
.form-control:focus {
    border-color: var(--mf-primary);
    box-shadow: 0 0 0 4px rgba(var(--mf-primary-rgb), .14), 0 1px 2px rgba(17, 17, 26, .05);
    background: var(--mf-surface);
}
.mf-input-group {
    height: 44px;
    border-radius: 11px;
    border: 1px solid var(--mf-border);
    background: var(--mf-surface);
}
.mf-input-group:focus-within {
    border-color: var(--mf-primary);
    box-shadow: 0 0 0 4px rgba(var(--mf-primary-rgb), .14);
}
.mf-input-group__icon { color: var(--mf-text-subtle); }
.mf-input-group:focus-within .mf-input-group__icon { color: var(--mf-primary); }

.mf-label { font-size: 12.5px; font-weight: 600; letter-spacing: -0.005em; }

/* ---------- 11. Badges ---------- */
.mf-badge {
    padding: 3px 9px;
    font-size: 11px;
    font-weight: 600;
    text-transform: none;
    letter-spacing: -0.005em;
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px rgba(0,0,0,.03);
}
[data-bs-theme="dark"] .mf-badge { box-shadow: inset 0 0 0 1px rgba(255,255,255,.05); }

/* ---------- 12. Banner ---------- */
.mf-banner {
    border-radius: 14px;
    padding: 14px 18px;
    box-shadow: var(--mf-shadow-xs);
    border-width: 1px;
}
.mf-banner--warning {
    background: linear-gradient(135deg, #FEF3C7 0%, #FDE68A 100%);
    border-color: #FCD34D;
    color: #78350F;
}
[data-bs-theme="dark"] .mf-banner--warning {
    background: linear-gradient(135deg, rgba(245, 158, 11, .14), rgba(245, 158, 11, .06));
    border-color: rgba(245, 158, 11, .35);
    color: #FCD34D;
}

/* ---------- 13. Tables ---------- */
table.table,
.mf-table {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    background: var(--mf-surface);
    border-radius: var(--mf-radius-lg);
    overflow: hidden;
    border: 1px solid var(--mf-border);
    box-shadow: var(--mf-shadow-sm);
}
table.table th, .mf-table th {
    font-size: 11.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--mf-text-subtle);
    background: var(--mf-surface-2);
    padding: 12px 18px;
    border-bottom: 1px solid var(--mf-border);
    text-align: left;
}
table.table td, .mf-table td {
    padding: 14px 18px;
    border-bottom: 1px solid var(--mf-border);
    font-size: 13.5px;
    color: var(--mf-text);
}
table.table tbody tr:last-child td,
.mf-table tbody tr:last-child td { border-bottom: 0; }
table.table tbody tr:hover,
.mf-table tbody tr:hover { background: rgba(var(--mf-primary-rgb), .04); }

/* ---------- 14. Auth shell — premium splash ---------- */
.mf-auth-shell {
    min-height: 100vh;
    background:
        radial-gradient(ellipse 700px 500px at 15% 20%, rgba(var(--mf-primary-rgb), .16), transparent 55%),
        radial-gradient(ellipse 800px 600px at 85% 80%, rgba(var(--mf-accent-rgb), .14), transparent 55%),
        radial-gradient(ellipse 500px 400px at 50% 50%, rgba(var(--mf-accent-2-rgb), .08), transparent 60%),
        var(--mf-bg);
    background-attachment: fixed;
    padding: 32px;
}

.mf-auth-shell__topbar { padding: 24px 36px; }
.mf-auth-shell__topbar .mf-topbar__brand {
    background: var(--mf-brand-gradient);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
    font-size: 15px;
    letter-spacing: -0.015em;
}

.mf-auth-card {
    border-radius: 26px;
    box-shadow:
        0 40px 88px -16px rgba(13, 13, 30, .28),
        0 14px 36px -12px rgba(13, 13, 30, .14),
        0 0 0 1px var(--mf-border);
    overflow: hidden;
    background: var(--mf-surface);
    max-width: 1020px;
}

.mf-auth-card__brand {
    background:
        linear-gradient(135deg, #4338CA 0%, #6366F1 30%, #A855F7 65%, #EC4899 100%);
    padding: 60px 52px;
    min-height: 580px;
    overflow: hidden;
    position: relative;
}
.mf-auth-card__brand::before {
    background:
        radial-gradient(circle at 20% 90%, rgba(255, 255, 255, .25) 0%, transparent 35%),
        radial-gradient(circle at 90% 10%, rgba(255, 200, 240, .28) 0%, transparent 40%),
        radial-gradient(circle at 50% 50%, rgba(168, 85, 247, .2) 0%, transparent 55%);
    animation: mf-aurora 18s ease-in-out infinite alternate;
}
@keyframes mf-aurora {
    0%   { transform: translate(0, 0)     scale(1); opacity: .9; }
    50%  { transform: translate(2%, -2%)  scale(1.06); opacity: 1; }
    100% { transform: translate(-2%, 2%)  scale(1); opacity: .9; }
}
.mf-auth-card__brand::after {
    content: '';
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
    background-size: 36px 36px;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
    pointer-events: none;
    opacity: .55;
}

.mf-auth-card__brand h1 {
    font-size: 40px;
    font-weight: 750;
    line-height: 1.08;
    letter-spacing: -0.04em;
    color: #fff;
    margin-bottom: 18px;
}
.mf-auth-card__brand p {
    font-size: 16px;
    line-height: 1.6;
    opacity: .92;
}

.mf-login__logo-mark {
    width: 40px; height: 40px;
    border-radius: 12px;
    background: rgba(255, 255, 255, .14);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, .24);
    box-shadow: 0 8px 24px -6px rgba(0, 0, 0, .3), inset 0 1px 0 rgba(255,255,255,.32);
    font-weight: 700;
    font-size: 15px;
}

.mf-auth-card__features { margin-top: 40px; gap: 12px; }
.mf-auth-card__feature {
    background: rgba(255, 255, 255, .09);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 13px;
    padding: 13px 15px;
    color: rgba(255, 255, 255, .96);
    font-weight: 500;
    transition: background 220ms, transform 220ms, border-color 220ms;
}
.mf-auth-card__feature:hover {
    background: rgba(255, 255, 255, .15);
    border-color: rgba(255, 255, 255, .22);
    transform: translateX(5px);
}

.mf-auth-card__form {
    padding: 60px 52px;
    background: var(--mf-surface);
}

.mf-login__title {
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -0.032em;
    margin-bottom: 6px;
    text-align: left;
}
.mf-login__subtitle {
    font-size: 14.5px;
    margin-bottom: 30px;
    text-align: left;
}

.mf-login__hint {
    margin-top: 24px;
    font-size: 13px;
    padding-top: 20px;
    border-top: 1px solid var(--mf-border);
}

/* ---------- 15. Topbar (mailbox/drive full-bleed) — glass ---------- */
.mf-topbar {
    backdrop-filter: blur(16px) saturate(180%);
    -webkit-backdrop-filter: blur(16px) saturate(180%);
    background: var(--mf-glass-bg);
    border-bottom: 1px solid var(--mf-border);
    padding-left: calc(var(--mf-rail-w) + var(--mf-rail-gap) * 2);
}
.mf-topbar__title { font-weight: 650; letter-spacing: -0.015em; }

/* ---------- 16. Empty states ---------- */
.mf-empty {
    background: var(--mf-surface);
    border: 1px dashed var(--mf-border-strong);
    border-radius: var(--mf-radius-2xl);
    padding: 72px 32px;
    text-align: center;
    box-shadow: var(--mf-shadow-sm);
}
.mf-empty__icon {
    width: 68px; height: 68px;
    border-radius: 20px;
    background: var(--mf-brand-gradient-2);
    color: #fff;
    margin: 0 auto 20px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.22);
}
.mf-empty__icon svg { width: 30px; height: 30px; }
.mf-empty__title { font-size: 19px; font-weight: 650; letter-spacing: -0.02em; margin-bottom: 8px; }
.mf-empty__body { color: var(--mf-text-muted); max-width: 440px; margin: 0 auto; font-size: 14px; line-height: 1.55; }

/* ---------- 17. Scrollbars, selection, focus ---------- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
    background: var(--mf-border-strong);
    border-radius: 999px;
    border: 2px solid transparent;
    background-clip: content-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--mf-text-subtle); background-clip: content-box; }

::selection { background: rgba(var(--mf-primary-rgb), .24); color: var(--mf-text); }

:focus-visible {
    outline: 2px solid var(--mf-primary);
    outline-offset: 2px;
    border-radius: 6px;
}
.mf-btn:focus-visible { outline-offset: 3px; }

/* ---------- 18. Mobile polish ---------- */
@media (max-width: 767.98px) {
    .mf-app-shell__content { padding: 20px 16px 32px; }
    .mf-dashboard__header { padding: 26px 22px; border-radius: 20px; }
    .mf-dashboard__title { font-size: 26px; }
    .mf-stat { padding: 20px 22px; }
    .mf-stat__value { font-size: 28px; }
    .mf-auth-shell { padding: 16px; }
    .mf-auth-card__brand { min-height: 200px; padding: 36px 28px; }
    .mf-auth-card__brand h1 { font-size: 28px; }
    .mf-auth-card__form { padding: 40px 28px; }
}

/* ============================================================================
   FULL-WIDTH OVERRIDES — kill page-level max-width constraints so content
   fills the screen on wide monitors (was 1200/1280/880px caps).
   ============================================================================ */
.mf-extract,
.mf-logs,
.mf-admin-dash,
.mf-settings,
.mf-sending,
#mf-dashboard {
    max-width: none !important;
    width: 100%;
}

/* ============================================================================
   PAGE-SPECIFIC POLISH — Connected accounts, Themes, Sending, Logs, Extract
   ============================================================================ */

/* ---------- A. Connected accounts — HORIZONTAL LIST layout ---------- */
.mf-dashboard__accounts-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 18px;
    padding: 0 4px;
}

/* Override grid: single column rows that span full width */
.mf-account-grid {
    display: flex !important;
    flex-direction: column;
    gap: 12px;
    grid-template-columns: none !important;
}

/* Each account = horizontal row */
.mf-account-card {
    display: grid !important;
    grid-template-columns: auto 1fr auto auto;
    align-items: center;
    gap: 24px;
    padding: 18px 24px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    transition: transform 220ms cubic-bezier(.4,0,.2,1), box-shadow 220ms, border-color 220ms;
    position: relative;
    overflow: hidden;
    flex-direction: unset;
    text-decoration: none;
}
.mf-account-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 4px;
    background: var(--mf-brand-gradient);
    transform: scaleY(0);
    transform-origin: center;
    transition: transform 280ms cubic-bezier(.4,0,.2,1);
}
.mf-account-card:hover::before { transform: scaleY(1); }
.mf-account-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--mf-shadow-lg);
    border-color: rgba(var(--mf-primary-rgb), .3);
}
.mf-account-card::after { display: none; }

/* Column 1: Avatar */
.mf-account-card__header {
    display: contents;
}
.mf-account-card__header .mf-avatar {
    grid-column: 1;
    width: 52px;
    height: 52px;
    border-radius: 14px;
    font-size: 16px;
    box-shadow:
        0 0 0 2px var(--mf-surface),
        0 0 0 3px transparent,
        0 8px 18px -4px rgba(13, 13, 30, .25),
        inset 0 1px 0 rgba(255,255,255,.25);
}

/* Column 2: email + meta */
.mf-account-card__body {
    grid-column: 2;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.mf-account-card__name {
    font-size: 15px;
    font-weight: 650;
    letter-spacing: -0.015em;
    color: var(--mf-text);
    margin: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mf-account-card__meta {
    font-size: 11px;
    color: var(--mf-text-subtle);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
}
.mf-account-card__meta::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #10B981;
    box-shadow: 0 0 8px rgba(16, 185, 129, .6);
}

/* Column 3: inline stats (pills) */
.mf-account-card__stats {
    grid-column: 3;
    display: flex !important;
    align-items: center;
    gap: 10px;
    padding: 0 !important;
    margin: 0 !important;
    border-top: 0 !important;
    justify-content: flex-end !important;
}
.mf-account-card__stats > div {
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    border-radius: 10px;
    padding: 8px 14px;
    min-width: 82px;
    text-align: center;
    transition: border-color 200ms, background 200ms;
}
.mf-account-card:hover .mf-account-card__stats > div {
    border-color: rgba(var(--mf-primary-rgb), .25);
}
.mf-account-card__stat-label {
    font-size: 10px !important;
    font-weight: 600 !important;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mf-text-subtle) !important;
    display: block;
    margin: 0 0 2px !important;
}
.mf-account-card__stats strong {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--mf-text) !important;
    letter-spacing: -0.02em !important;
    display: block !important;
    line-height: 1.1;
    font-variant-numeric: tabular-nums;
}

/* Column 4: actions inline */
.mf-account-card__actions {
    grid-column: 4;
    display: flex !important;
    flex-direction: row !important;
    gap: 8px;
    margin-top: 0 !important;
    grid-template-columns: none !important;
}
.mf-account-card__actions .mf-btn {
    width: auto !important;
    padding: 0 16px;
    height: 38px;
    border-radius: 10px;
}
.mf-account-card__actions .mf-btn--outline {
    background: var(--mf-surface-2);
    border-color: var(--mf-border);
}
.mf-account-card__actions .mf-btn--outline:hover {
    background: var(--mf-bg);
    border-color: rgba(var(--mf-primary-rgb), .4);
}

/* Error state */
.mf-account-card--error {
    background: linear-gradient(135deg, rgba(245, 158, 11, .08), var(--mf-surface));
    border-color: rgba(245, 158, 11, .35);
}
.mf-account-card--error::before {
    background: linear-gradient(180deg, #F59E0B, #D97706);
    transform: scaleY(1);
}
.mf-account-card--error .mf-account-card__meta::before {
    background: #F59E0B;
    box-shadow: 0 0 8px rgba(245, 158, 11, .6);
}
.mf-account-card__error-badge { margin-left: 0; }

/* Responsive — collapse to stacked card on narrow screens */
@media (max-width: 1100px) {
    .mf-account-card {
        grid-template-columns: auto 1fr;
        gap: 14px 18px;
    }
    .mf-account-card__stats {
        grid-column: 1 / -1;
        justify-content: flex-start !important;
        padding-top: 12px !important;
        border-top: 1px solid var(--mf-border) !important;
    }
    .mf-account-card__actions {
        grid-column: 1 / -1;
    }
    .mf-account-card__actions .mf-btn { flex: 1; }
}
@media (max-width: 600px) {
    .mf-account-card {
        padding: 16px 18px;
        gap: 12px 14px;
    }
    .mf-account-card__header .mf-avatar { width: 44px; height: 44px; font-size: 14px; }
    .mf-account-card__stats > div { min-width: 0; flex: 1; }
}

/* ---------- B. Page headers (Themes/Sending/Logs/Extract) — unified hero ---------- */
.mf-admin-dash__header,
.mf-logs__header,
.mf-extract__header {
    margin-bottom: 28px;
    padding: 32px 40px;
    background:
        linear-gradient(135deg, rgba(var(--mf-primary-rgb), .09), rgba(var(--mf-accent-rgb), .07) 55%, transparent 80%),
        var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-2xl);
    box-shadow: var(--mf-shadow-sm);
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    flex-wrap: wrap;
    min-height: 120px;
}
.mf-admin-dash__header::before,
.mf-logs__header::before,
.mf-extract__header::before {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 280px; height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-accent-rgb), .22), transparent 65%);
    filter: blur(28px);
    animation: mf-orb 16s ease-in-out infinite alternate;
    pointer-events: none;
}
.mf-admin-dash__header > *,
.mf-logs__header > *,
.mf-extract__header > * { position: relative; z-index: 1; }

.mf-admin-dash__title,
.mf-logs__title,
.mf-extract__title {
    font-size: 32px;
    font-weight: 800;
    letter-spacing: -0.04em;
    margin: 0;
    background: linear-gradient(135deg, var(--mf-text) 0%, #4F46E5 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
[data-bs-theme="dark"] .mf-admin-dash__title,
[data-bs-theme="dark"] .mf-logs__title,
[data-bs-theme="dark"] .mf-extract__title {
    background: linear-gradient(135deg, #fff 0%, #A5B4FC 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.mf-admin-dash__subtitle,
.mf-logs__subtitle,
.mf-extract__subtitle {
    font-size: 14.5px;
    color: var(--mf-text-muted);
    margin-top: 8px;
    max-width: 620px;
    line-height: 1.5;
}

/* ---------- C. Themes page ---------- */
.mf-current-theme {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-xl);
    box-shadow: var(--mf-shadow-sm);
    padding: 22px 26px;
    margin-bottom: 28px;
    display: flex;
    align-items: center;
    gap: 20px;
    position: relative;
    overflow: hidden;
}
.mf-current-theme::before {
    content: '';
    position: absolute;
    top: 0; left: 0; bottom: 0;
    width: 4px;
    background: var(--mf-brand-gradient);
}
.mf-current-theme::after {
    content: '';
    position: absolute;
    top: -60px; right: -60px;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-primary-rgb), .14), transparent 70%);
    pointer-events: none;
}
.mf-current-theme > * { position: relative; z-index: 1; }
.mf-current-theme--empty::before {
    background: linear-gradient(135deg, #F59E0B, #D97706);
}

.mf-current-theme__icon {
    width: 52px; height: 52px;
    border-radius: 14px;
    background: var(--mf-brand-gradient-2);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 52px;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.25);
}
.mf-current-theme__icon svg { width: 24px; height: 24px; }
.mf-current-theme--empty .mf-current-theme__icon {
    background: linear-gradient(135deg, #F59E0B, #D97706);
    box-shadow: 0 10px 28px -6px rgba(245, 158, 11, .42), inset 0 1px 0 rgba(255,255,255,.25);
}

.mf-current-theme__body { flex: 1; min-width: 0; }
.mf-current-theme__label {
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mf-text-subtle);
    margin-bottom: 4px;
}
.mf-current-theme__name {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.025em;
    color: var(--mf-text);
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 8px;
}
.mf-current-theme__slug {
    font-size: 12px;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    color: var(--mf-text-subtle);
    background: var(--mf-surface-2);
    padding: 3px 9px;
    border-radius: 7px;
    border: 1px solid var(--mf-border);
    font-weight: 500;
    letter-spacing: 0;
}
.mf-current-theme__meta {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.mf-current-theme__hint {
    font-size: 13px;
    color: var(--mf-text-muted);
}

.mf-theme-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 22px;
}
.mf-theme-card {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 260ms cubic-bezier(.4,0,.2,1), box-shadow 260ms, border-color 260ms;
    position: relative;
}
.mf-theme-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--mf-shadow-lg);
    border-color: rgba(var(--mf-primary-rgb), .3);
}
.mf-theme-card--selected {
    border-color: transparent;
    box-shadow: var(--mf-shadow-glow), 0 0 0 2px var(--mf-primary), var(--mf-shadow-md);
}
.mf-theme-card--selected::before {
    content: '';
    position: absolute;
    top: 12px; right: 12px;
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--mf-brand-gradient-2);
    box-shadow: var(--mf-shadow-glow);
    z-index: 3;
    display: flex;
    align-items: center;
    justify-content: center;
}
.mf-theme-card--selected::after {
    content: '✓';
    position: absolute;
    top: 12px; right: 12px;
    width: 28px; height: 28px;
    color: #fff;
    font-weight: 700;
    font-size: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 4;
}

.mf-theme-card__preview {
    aspect-ratio: 16 / 10;
    background: var(--mf-surface-2);
    overflow: hidden;
    border-bottom: 1px solid var(--mf-border);
    position: relative;
}
.mf-theme-card__iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
    background: #fff;
}
.mf-theme-card__body {
    padding: 16px 18px 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.mf-theme-card__name {
    font-size: 16px;
    font-weight: 650;
    letter-spacing: -0.015em;
    margin: 0;
    color: var(--mf-text);
}
.mf-theme-card__slug {
    font-size: 11.5px;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    color: var(--mf-text-subtle);
    letter-spacing: 0;
}
.mf-theme-card__badges {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 4px;
}
.mf-theme-card__actions {
    padding: 12px 18px 16px;
    display: flex;
    gap: 8px;
    border-top: 1px solid var(--mf-border);
    margin-top: 8px;
    background: linear-gradient(180deg, transparent, rgba(var(--mf-primary-rgb), .02));
}
.mf-theme-card__actions > * { flex: 1; }

/* Theme preview modal */
.mf-theme-preview-backdrop {
    position: fixed; inset: 0;
    background: rgba(13, 13, 30, .55);
    backdrop-filter: blur(8px);
    z-index: 900;
    opacity: 0;
    pointer-events: none;
    transition: opacity 200ms;
}
.mf-theme-preview-backdrop[aria-hidden="false"] {
    opacity: 1;
    pointer-events: auto;
}
.mf-theme-preview-modal {
    position: fixed;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%) scale(.96);
    width: min(92vw, 1100px);
    height: min(90vh, 720px);
    background: var(--mf-surface);
    border-radius: var(--mf-radius-xl);
    box-shadow: var(--mf-shadow-xl);
    border: 1px solid var(--mf-border);
    z-index: 901;
    display: flex;
    flex-direction: column;
    opacity: 0;
    pointer-events: none;
    transition: opacity 220ms, transform 220ms cubic-bezier(.4,0,.2,1);
    overflow: hidden;
}
.mf-theme-preview-modal[aria-hidden="false"] {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
    pointer-events: auto;
}
.mf-theme-preview-modal__header {
    padding: 16px 22px;
    border-bottom: 1px solid var(--mf-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: linear-gradient(180deg, var(--mf-surface-2), var(--mf-surface));
}
.mf-theme-preview-modal__title {
    font-size: 15px;
    font-weight: 650;
    letter-spacing: -0.015em;
    margin: 0;
}
.mf-theme-preview-modal__body { flex: 1; overflow: hidden; }
.mf-theme-preview-modal__iframe {
    width: 100%; height: 100%;
    border: 0;
    background: #fff;
}

/* ---------- D. Sending page ---------- */
.mf-sending {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 320px;
    gap: 24px;
    align-items: start;
}
@media (max-width: 1100px) {
    .mf-sending { grid-template-columns: 1fr; }
}
.mf-sending__col { display: flex; flex-direction: column; gap: 18px; }

.mf-sending__card {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    padding: 22px 24px;
    transition: border-color 200ms, box-shadow 200ms;
}
.mf-sending__card:hover { border-color: var(--mf-border-strong); }
.mf-sending__card h3 {
    font-size: 11.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mf-text-subtle);
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.mf-sending__card h3::before {
    content: '';
    width: 4px;
    height: 14px;
    border-radius: 3px;
    background: var(--mf-brand-gradient-2);
    box-shadow: var(--mf-shadow-glow);
}

.mf-sending__field { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
.mf-sending__field:last-child { margin-bottom: 0; }
.mf-sending__field label {
    font-size: 12.5px;
    font-weight: 600;
    color: var(--mf-text);
    letter-spacing: -0.005em;
}
.mf-sending__field input[type="text"],
.mf-sending__field input[type="number"],
.mf-sending__card input[type="text"],
.mf-sending__card input[type="number"] {
    height: 42px;
    padding: 0 14px;
    border-radius: 10px;
    border: 1px solid var(--mf-border);
    background: var(--mf-surface);
    color: var(--mf-text);
    font-size: 14px;
    transition: border-color 150ms, box-shadow 150ms;
}
.mf-sending__field input:focus,
.mf-sending__card input:focus {
    outline: none;
    border-color: var(--mf-primary);
    box-shadow: 0 0 0 4px rgba(var(--mf-primary-rgb), .14);
}

.mf-sending__row {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: end;
}

.mf-sending__toggle {
    display: inline-flex;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    border-radius: 11px;
    padding: 4px;
    gap: 2px;
}
.mf-sending__toggle button {
    height: 34px;
    padding: 0 16px;
    border: 0;
    background: transparent;
    color: var(--mf-text-muted);
    font-size: 13px;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: background 200ms, color 200ms;
}
.mf-sending__toggle button:hover { color: var(--mf-text); }
.mf-sending__toggle button.is-active {
    background: var(--mf-brand-gradient-2);
    color: #fff;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.18);
    font-weight: 600;
}

.mf-sending__accounts {
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: var(--mf-text-muted);
    font-size: 13px;
}
.mf-sending__accounts label {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 10px;
    background: var(--mf-surface-2);
    border: 1px solid transparent;
    cursor: pointer;
    transition: background 150ms, border-color 150ms;
    color: var(--mf-text);
    font-size: 13.5px;
}
.mf-sending__accounts label:hover {
    border-color: var(--mf-border-strong);
}
.mf-sending__accounts input { accent-color: var(--mf-primary); }

.mf-sending__editor,
.mf-sending__card textarea {
    width: 100%;
    min-height: 180px;
    padding: 14px;
    border-radius: 11px;
    border: 1px solid var(--mf-border);
    background: var(--mf-surface);
    color: var(--mf-text);
    font-size: 13.5px;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    line-height: 1.6;
    resize: vertical;
    transition: border-color 150ms, box-shadow 150ms;
}
.mf-sending__editor:focus,
.mf-sending__card textarea:focus {
    outline: none;
    border-color: var(--mf-primary);
    box-shadow: 0 0 0 4px rgba(var(--mf-primary-rgb), .14);
}

.mf-sending__toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    border-radius: 10px;
    margin-bottom: 8px;
}
.mf-sending__toolbar button {
    height: 28px;
    padding: 0 10px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    color: var(--mf-text-muted);
    border-radius: 7px;
    cursor: pointer;
    font-size: 11.5px;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    font-weight: 500;
    transition: all 150ms;
}
.mf-sending__toolbar button:hover {
    background: rgba(var(--mf-primary-rgb), .08);
    color: var(--mf-primary);
    border-color: rgba(var(--mf-primary-rgb), .3);
}

.mf-sending__counter {
    font-size: 12px;
    color: var(--mf-text-subtle);
    margin-top: 6px;
    font-variant-numeric: tabular-nums;
}

.mf-sending__attachments-list {
    list-style: none;
    padding: 0;
    margin: 12px 0 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.mf-sending__attachments-list li {
    padding: 8px 12px;
    background: var(--mf-surface-2);
    border-radius: 8px;
    font-size: 12.5px;
    color: var(--mf-text);
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid var(--mf-border);
}

.mf-sending__card input[type="file"] {
    display: block;
    font-size: 13px;
    color: var(--mf-text-muted);
}

.mf-sending__start {
    width: 100%;
    height: 52px;
    padding: 0 28px;
    background: var(--mf-brand-gradient-2);
    color: #fff;
    border: 0;
    border-radius: 13px;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: -0.01em;
    cursor: pointer;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.2);
    transition: all 200ms;
}
.mf-sending__start:hover:not(:disabled) {
    filter: brightness(1.08);
    transform: translateY(-1px);
    box-shadow: var(--mf-shadow-glow-2), inset 0 1px 0 rgba(255,255,255,.25);
}
.mf-sending__start:disabled {
    opacity: .55;
    cursor: not-allowed;
    background: var(--mf-surface-2);
    color: var(--mf-text-subtle);
    box-shadow: none;
}

.mf-sending__progress {
    background: var(--mf-brand-gradient);
    color: #fff;
    padding: 18px 22px;
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-glow-2);
    display: flex;
    flex-direction: column;
    gap: 12px;
    position: relative;
    overflow: hidden;
}
.mf-sending__progress::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 20% 80%, rgba(255,255,255,.15), transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(255,255,255,.1), transparent 50%);
    pointer-events: none;
}
.mf-sending__progress > * { position: relative; z-index: 1; }
.mf-sending__progress strong {
    font-size: 15px;
    font-weight: 650;
    letter-spacing: -0.015em;
}
.mf-sending__progress-bar {
    height: 10px;
    background: rgba(255,255,255,.18);
    border-radius: 999px;
    overflow: hidden;
}
.mf-sending__progress-bar > div {
    height: 100%;
    background: #fff;
    border-radius: 999px;
    transition: width 300ms ease;
    box-shadow: 0 0 12px rgba(255,255,255,.5);
}

.mf-sending__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.mf-sending__tags button,
.mf-sending__tags .tag-chip {
    padding: 6px 11px;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    color: var(--mf-text);
    font-size: 11.5px;
    font-family: ui-monospace, 'SF Mono', Menlo, monospace;
    border-radius: 7px;
    cursor: pointer;
    transition: all 150ms;
}
.mf-sending__tags button:hover,
.mf-sending__tags .tag-chip:hover {
    background: rgba(var(--mf-primary-rgb), .1);
    color: var(--mf-primary);
    border-color: rgba(var(--mf-primary-rgb), .4);
    transform: translateY(-1px);
}

.mf-sending__recent {
    display: flex;
    flex-direction: column;
    gap: 8px;
    font-size: 13px;
    color: var(--mf-text-muted);
}

/* ============================================================================
   AUTO-EXTRACT RECIPIENTS — premium panel (v2)
   ============================================================================ */
.mf-sending__extract {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(135deg, rgba(var(--mf-primary-rgb), .06), rgba(var(--mf-accent-rgb), .04) 50%, transparent 80%),
        var(--mf-surface);
    border: 1px solid rgba(var(--mf-primary-rgb), .22);
    box-shadow: var(--mf-shadow-sm);
}
.mf-sending__extract::before {
    content: '';
    position: absolute;
    top: -80px; right: -80px;
    width: 240px; height: 240px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-accent-rgb), .14), transparent 65%);
    filter: blur(28px);
    pointer-events: none;
}
.mf-sending__extract::after {
    content: '';
    position: absolute;
    bottom: -100px; left: 30%;
    width: 220px; height: 220px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(var(--mf-primary-rgb), .10), transparent 65%);
    filter: blur(32px);
    pointer-events: none;
}
.mf-sending__extract > * { position: relative; z-index: 1; }
/* Kill the existing card h3 default accent so our custom head shows clean */
.mf-sending__extract > h3 { display: none; }

/* ---- Head: icon + title + live summary badge ---- */
.mf-extract-rcp__head {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 22px;
}
.mf-extract-rcp__icon {
    flex: 0 0 48px;
    width: 48px; height: 48px;
    border-radius: 13px;
    background: var(--mf-brand-gradient-2);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.22);
    position: relative;
}
.mf-extract-rcp__icon::after {
    content: '';
    position: absolute; inset: 0;
    border-radius: 13px;
    background: linear-gradient(180deg, rgba(255,255,255,.22), transparent 55%);
    pointer-events: none;
}
.mf-extract-rcp__icon svg { width: 22px; height: 22px; }

.mf-extract-rcp__head-text { flex: 1; min-width: 0; }
.mf-extract-rcp__title {
    font-size: 17px !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em;
    color: var(--mf-text) !important;
    margin: 2px 0 4px !important;
    text-transform: none !important;
    display: block !important;
}
.mf-extract-rcp__title::before { content: none !important; }
.mf-extract-rcp__subtitle {
    margin: 0;
    font-size: 13px;
    color: var(--mf-text-muted);
    line-height: 1.5;
}
.mf-extract-rcp__badge {
    align-self: center;
    flex: 0 0 auto;
    font-size: 12px;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    color: var(--mf-text-muted);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    transition: all 200ms;
}
.mf-extract-rcp__badge[data-state="ready"] {
    background: rgba(var(--mf-primary-rgb), .1);
    border-color: rgba(var(--mf-primary-rgb), .35);
    color: var(--mf-primary);
    box-shadow: 0 0 0 4px rgba(var(--mf-primary-rgb), .06);
}
.mf-extract-rcp__badge strong { font-weight: 700; color: var(--mf-text); }
.mf-extract-rcp__badge[data-state="ready"] strong { color: var(--mf-primary); }

/* ---- Sections ---- */
.mf-extract-rcp__section { margin-bottom: 18px; }
.mf-extract-rcp__section-label {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--mf-text-subtle);
    margin-bottom: 10px;
}
.mf-extract-rcp__section-label > span:first-child { margin-right: auto; }

.mf-extract-rcp__quick {
    height: 24px;
    padding: 0 9px;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    color: var(--mf-text-muted);
    font-size: 10.5px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: 6px;
    cursor: pointer;
    transition: all 150ms;
}
.mf-extract-rcp__quick:hover {
    background: rgba(var(--mf-primary-rgb), .08);
    border-color: rgba(var(--mf-primary-rgb), .35);
    color: var(--mf-primary);
}

/* ---- Folder icon chips ---- */
.mf-extract-rcp__folders {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 8px;
}
.mf-extract-rcp__folder {
    position: relative;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 13px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: 11px;
    font-size: 13px;
    color: var(--mf-text);
    cursor: pointer;
    transition: all 180ms cubic-bezier(.4, 0, .2, 1);
}
.mf-extract-rcp__folder input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}
.mf-extract-rcp__folder:hover {
    border-color: rgba(var(--mf-primary-rgb), .35);
    transform: translateY(-1px);
    box-shadow: var(--mf-shadow-xs);
}
.mf-extract-rcp__folder-icon {
    width: 28px; height: 28px;
    border-radius: 8px;
    background: var(--mf-surface-2);
    color: var(--mf-text-subtle);
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 28px;
    transition: all 180ms;
}
.mf-extract-rcp__folder-icon svg { width: 15px; height: 15px; }
.mf-extract-rcp__folder-label { font-weight: 500; }

.mf-extract-rcp__folder:has(input:checked) {
    background: linear-gradient(135deg, rgba(var(--mf-primary-rgb), .1), rgba(var(--mf-accent-rgb), .05));
    border-color: rgba(var(--mf-primary-rgb), .5);
    color: var(--mf-primary);
}
.mf-extract-rcp__folder:has(input:checked) .mf-extract-rcp__folder-icon {
    background: var(--mf-brand-gradient-2);
    color: #fff;
    box-shadow: var(--mf-shadow-glow);
}
.mf-extract-rcp__folder:has(input:checked) .mf-extract-rcp__folder-label {
    font-weight: 600;
}
.mf-extract-rcp__folder:has(input:checked)::after {
    content: '✓';
    position: absolute;
    top: 8px; right: 10px;
    font-size: 11px;
    font-weight: 700;
    color: var(--mf-primary);
}

/* ---- Filter switch (custom toggle) ---- */
.mf-extract-rcp__filter {
    padding: 14px 16px;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    border-radius: 12px;
    margin-bottom: 18px;
}
.mf-extract-rcp__switch {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
}
.mf-extract-rcp__switch input { position: absolute; opacity: 0; pointer-events: none; }
.mf-extract-rcp__switch-track {
    flex: 0 0 38px;
    width: 38px; height: 22px;
    background: var(--mf-border-strong);
    border-radius: 999px;
    position: relative;
    transition: background 220ms;
    margin-top: 2px;
}
.mf-extract-rcp__switch-thumb {
    position: absolute;
    top: 2px; left: 2px;
    width: 18px; height: 18px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0,0,0,.2);
    transition: transform 220ms cubic-bezier(.4, 0, .2, 1);
}
.mf-extract-rcp__switch input:checked ~ .mf-extract-rcp__switch-track {
    background: var(--mf-brand-gradient-2);
    box-shadow: var(--mf-shadow-glow);
}
.mf-extract-rcp__switch input:checked ~ .mf-extract-rcp__switch-track .mf-extract-rcp__switch-thumb {
    transform: translateX(16px);
}
.mf-extract-rcp__switch-text { display: flex; flex-direction: column; gap: 2px; }
.mf-extract-rcp__switch-text strong {
    font-size: 13.5px;
    font-weight: 600;
    color: var(--mf-text);
    letter-spacing: -0.01em;
}
.mf-extract-rcp__switch-text span {
    font-size: 12px;
    color: var(--mf-text-muted);
    line-height: 1.4;
}
.mf-extract-rcp__switch-text code {
    background: var(--mf-bg);
    padding: 1px 5px;
    border-radius: 4px;
    font-size: 10.5px;
    border: 1px solid var(--mf-border);
}

/* ---- Action row ---- */
.mf-extract-rcp__actions {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}
.mf-extract-rcp__actions .mf-btn--primary {
    height: 44px;
    padding: 0 22px;
    font-size: 14px;
    font-weight: 600;
}
.mf-extract-rcp__status {
    font-size: 12.5px;
    color: var(--mf-text-muted);
    font-variant-numeric: tabular-nums;
    flex: 1;
    min-width: 0;
}

/* Spinner on the action button while running */
#mf-extract-recipients-btn[disabled]:not([hidden]) svg {
    animation: mf-spin 1s linear infinite;
}
@keyframes mf-spin { to { transform: rotate(360deg); } }

/* ============================================================================
   Live progress panel
   ============================================================================ */
.mf-extract-rcp__progress {
    margin-top: 18px;
    padding: 16px 18px;
    background:
        linear-gradient(135deg, rgba(var(--mf-primary-rgb), .12), rgba(var(--mf-accent-rgb), .08)),
        var(--mf-surface);
    border: 1px solid rgba(var(--mf-primary-rgb), .35);
    border-radius: 14px;
    box-shadow: var(--mf-shadow-glow);
    display: flex;
    flex-direction: column;
    gap: 12px;
    animation: mf-progress-in 280ms cubic-bezier(.4, 0, .2, 1);
}
@keyframes mf-progress-in {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.mf-extract-rcp__progress-head {
    display: flex;
    align-items: center;
    gap: 12px;
}
.mf-extract-rcp__progress-icon {
    width: 32px; height: 32px;
    border-radius: 9px;
    background: var(--mf-brand-gradient-2);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 32px;
    box-shadow: var(--mf-shadow-glow);
}
.mf-extract-rcp__progress-icon svg {
    width: 16px; height: 16px;
    animation: mf-spin 1.2s linear infinite;
}
.mf-extract-rcp__step {
    flex: 1;
    min-width: 0;
    color: var(--mf-text);
    font-weight: 600;
    font-size: 13.5px;
    letter-spacing: -0.01em;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.mf-extract-rcp__pct {
    color: var(--mf-primary);
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    font-size: 18px;
    letter-spacing: -0.02em;
    flex: 0 0 auto;
}
.mf-extract-rcp__bar {
    height: 10px;
    background: rgba(var(--mf-primary-rgb), .12);
    border-radius: 999px;
    overflow: hidden;
    border: 1px solid rgba(var(--mf-primary-rgb), .18);
}
.mf-extract-rcp__bar > span {
    display: block;
    height: 100%;
    width: 0%;
    background: var(--mf-brand-gradient);
    border-radius: 999px;
    box-shadow: 0 0 14px rgba(var(--mf-primary-rgb), .65);
    transition: width 320ms cubic-bezier(.4, 0, .2, 1);
    position: relative;
    overflow: hidden;
}
.mf-extract-rcp__bar > span::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.5), transparent);
    animation: mf-shine 1.4s linear infinite;
}
@keyframes mf-shine {
    from { transform: translateX(-100%); }
    to   { transform: translateX(100%); }
}
.mf-extract-rcp__progress-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}
.mf-extract-rcp__meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-variant-numeric: tabular-nums;
}
.mf-extract-rcp__stat {
    display: inline-flex;
    align-items: baseline;
    gap: 5px;
    padding: 4px 10px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: 999px;
    font-size: 11.5px;
    color: var(--mf-text-muted);
    font-weight: 500;
}
.mf-extract-rcp__stat strong {
    color: var(--mf-text);
    font-weight: 700;
    font-size: 13px;
}
.mf-extract-rcp__stat--success {
    background: rgba(16, 185, 129, .1);
    border-color: rgba(16, 185, 129, .35);
    color: #047857;
}
.mf-extract-rcp__stat--success strong { color: #047857; }
[data-bs-theme="dark"] .mf-extract-rcp__stat--success { color: #6EE7B7; }
[data-bs-theme="dark"] .mf-extract-rcp__stat--success strong { color: #6EE7B7; }
.mf-extract-rcp__stat--danger {
    background: rgba(239, 68, 68, .1);
    border-color: rgba(239, 68, 68, .35);
    color: #B91C1C;
}
.mf-extract-rcp__stat--danger strong { color: #B91C1C; }
[data-bs-theme="dark"] .mf-extract-rcp__stat--danger { color: #FCA5A5; }
[data-bs-theme="dark"] .mf-extract-rcp__stat--danger strong { color: #FCA5A5; }

/* ---------- E. Logs page ---------- */
.mf-logs__summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 24px;
}
.mf-logs__summary > * {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    padding: 18px 20px;
    box-shadow: var(--mf-shadow-sm);
    position: relative;
    overflow: hidden;
    transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.mf-logs__summary > *::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--mf-brand-gradient);
    opacity: .8;
}
.mf-logs__summary > *:hover {
    transform: translateY(-3px);
    box-shadow: var(--mf-shadow-md);
    border-color: rgba(var(--mf-primary-rgb), .3);
}

.mf-logs__controls-card {
    margin-bottom: 22px;
    border-radius: var(--mf-radius-lg);
}
.mf-logs__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
}
.mf-logs__search-group {
    grid-column: 1 / -1;
}

.mf-logs__status {
    font-size: 12.5px;
    color: var(--mf-text-muted);
    font-variant-numeric: tabular-nums;
    margin-right: auto;
}

.mf-logs__table-wrap {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    overflow: hidden;
}
.mf-logs__placeholder {
    padding: 60px 24px;
    text-align: center;
    color: var(--mf-text-subtle);
    font-size: 14px;
    margin: 0;
}

.mf-logs__pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    margin-top: 20px;
    padding: 12px 16px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius);
    box-shadow: var(--mf-shadow-xs);
}
.mf-logs__page-info {
    font-size: 13px;
    color: var(--mf-text-muted);
    font-variant-numeric: tabular-nums;
}

/* ---------- F. Extract page ---------- */
.mf-extract__controls-card { margin-bottom: 22px; }
.mf-extract__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 14px;
}
.mf-extract__custom-range {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 14px;
    padding: 14px;
    background: var(--mf-surface-2);
    border-radius: 11px;
    border: 1px dashed var(--mf-border-strong);
}

.mf-extract__status {
    font-size: 13px;
    color: var(--mf-text-muted);
    margin-right: auto;
    font-variant-numeric: tabular-nums;
}

.mf-progress {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    padding: 18px 22px;
    box-shadow: var(--mf-shadow-sm);
    margin-bottom: 22px;
}
.mf-progress__bar {
    height: 8px;
    background: var(--mf-surface-2);
    border-radius: 999px;
    overflow: hidden;
    margin-bottom: 10px;
}
.mf-progress__bar > span {
    display: block;
    height: 100%;
    background: var(--mf-brand-gradient);
    border-radius: 999px;
    box-shadow: 0 0 12px rgba(var(--mf-primary-rgb), .5);
    transition: width 300ms ease;
}
.mf-progress__label {
    font-size: 13px;
    color: var(--mf-text-muted);
    font-variant-numeric: tabular-nums;
}

.mf-extract__summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 14px;
    margin-bottom: 22px;
}
.mf-extract__summary > * {
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    padding: 18px 20px;
    box-shadow: var(--mf-shadow-sm);
    position: relative;
    overflow: hidden;
}
.mf-extract__summary > *::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: var(--mf-brand-gradient);
}

.mf-extract__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 18px;
    padding: 14px 16px;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-sm);
    flex-wrap: wrap;
}

.mf-extract__tabs {
    display: inline-flex;
    background: var(--mf-surface-2);
    border: 1px solid var(--mf-border);
    border-radius: 11px;
    padding: 4px;
    gap: 2px;
}
.mf-extract__tab {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    height: 36px;
    padding: 0 14px;
    border: 0;
    background: transparent;
    color: var(--mf-text-muted);
    font-size: 13px;
    font-weight: 500;
    border-radius: 8px;
    cursor: pointer;
    transition: all 200ms;
}
.mf-extract__tab:hover { color: var(--mf-text); }
.mf-extract__tab--active {
    background: var(--mf-brand-gradient-2);
    color: #fff;
    box-shadow: var(--mf-shadow-glow), inset 0 1px 0 rgba(255,255,255,.18);
    font-weight: 600;
}
.mf-extract__tab-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 22px;
    height: 18px;
    padding: 0 6px;
    background: var(--mf-bg);
    color: var(--mf-text-muted);
    font-size: 10.5px;
    font-weight: 600;
    border-radius: 999px;
    font-variant-numeric: tabular-nums;
    border: 1px solid var(--mf-border);
}
.mf-extract__tab--active .mf-extract__tab-count {
    background: rgba(255,255,255,.22);
    color: #fff;
    border-color: transparent;
}

.mf-extract__toolbar-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.mf-extract__filter {
    min-width: 240px;
}
.mf-extract__view-select {
    height: 36px;
    width: auto;
    padding: 0 32px 0 12px;
    font-size: 13px;
}
.mf-extract__system-toggle {
    font-size: 13px;
    color: var(--mf-text-muted);
    gap: 6px;
}

.mf-extract__history {
    position: absolute;
    z-index: 50;
    background: var(--mf-surface);
    border: 1px solid var(--mf-border);
    border-radius: var(--mf-radius-lg);
    box-shadow: var(--mf-shadow-xl);
    padding: 8px;
    min-width: 320px;
}

/* ---------- Generic alerts on these pages ---------- */
.mf-alert {
    padding: 12px 16px;
    border-radius: 11px;
    margin-bottom: 18px;
    font-size: 13.5px;
    border: 1px solid;
}
.mf-alert--success {
    background: linear-gradient(135deg, #D1FAE5, #A7F3D0);
    border-color: #6EE7B7;
    color: #065F46;
}
.mf-alert--danger {
    background: linear-gradient(135deg, #FEE2E2, #FECACA);
    border-color: #FCA5A5;
    color: #991B1B;
}
[data-bs-theme="dark"] .mf-alert--success {
    background: rgba(16, 185, 129, .12);
    border-color: rgba(16, 185, 129, .35);
    color: #6EE7B7;
}
[data-bs-theme="dark"] .mf-alert--danger {
    background: rgba(239, 68, 68, .12);
    border-color: rgba(239, 68, 68, .35);
    color: #FCA5A5;
}

/* ---------- Mobile polish for these pages ---------- */
@media (max-width: 767.98px) {
    .mf-admin-dash__header,
    .mf-logs__header,
    .mf-extract__header { padding: 24px 22px; min-height: auto; }
    .mf-admin-dash__title,
    .mf-logs__title,
    .mf-extract__title { font-size: 24px; }
    .mf-current-theme { padding: 18px 20px; flex-wrap: wrap; }
    .mf-current-theme__name { font-size: 18px; }
    .mf-sending__card { padding: 18px 20px; }
}

/* ---------- 19. Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: .001ms !important;
        transition-duration: .001ms !important;
    }
}
