/* ============================================================
    Custom: AI Voice Preview Fix
    ============================================================ */

#voice-preview {
     background: var(--dl-surface) !important;
     color: var(--dl-text) !important;
     border: 1px solid var(--dl-border) !important;
     border-radius: 10px !important;
     font-family: 'JetBrains Mono', 'Fira Mono', 'Consolas', monospace;
     white-space: pre-line;
}

/* ============================================================
   Divine Logic — Dark Mode Design System
   Glassmorphism · Neon Accents · Premium Spiritual Aesthetic
   ============================================================ */

/* --- CSS Variables ---------------------------------------- */
:root {
    /* Core dark palette */
    --dl-bg:            #07070f;
    --dl-bg-2:          #0e0e1a;
    --dl-bg-3:          #13131f;
    --dl-surface:       rgba(255,255,255,0.04);
    --dl-surface-2:     rgba(255,255,255,0.08);
    --dl-border:        rgba(255,255,255,0.09);
    --dl-border-glow:   rgba(139,92,246,0.45);

    /* Accent colors */
    --dl-purple:        #8b5cf6;
    --dl-purple-dark:   #6d28d9;
    --dl-purple-glow:   rgba(139,92,246,0.35);
    --dl-blue:          #06b6d4;
    --dl-blue-glow:     rgba(6,182,212,0.35);
    --dl-gold:          #f59e0b;
    --dl-gold-light:    #fcd34d;
    --dl-gold-glow:     rgba(245,158,11,0.35);

    /* Text */
    --dl-text:          #e2e8f0;
    --dl-text-dim:      #94a3b8;
    --dl-text-muted:    #4b5563;

    /* Status */
    --dl-success:       #10b981;
    --dl-danger:        #ef4444;

    /* Gradients */
    --dl-grad-purple:   linear-gradient(135deg, #6d28d9 0%, #8b5cf6 100%);
    --dl-grad-cyan:     linear-gradient(135deg, #0891b2 0%, #06b6d4 100%);
    --dl-grad-gold:     linear-gradient(135deg, #d97706 0%, #f59e0b 100%);
    --dl-grad-blue:     linear-gradient(135deg, #0369a1 0%, #06b6d4 100%);
    --dl-grad-divine:   linear-gradient(160deg, #07070f 0%, #0e0516 45%, #07070f 100%);

    /* Glassmorphism */
    --dl-glass-bg:      rgba(10,10,20,0.72);
    --dl-glass-blur:    blur(20px);

    /* Shadows */
    --dl-shadow-sm:     0 2px 10px rgba(0,0,0,0.45);
    --dl-shadow-md:     0 6px 28px rgba(0,0,0,0.55);
    --dl-shadow-glow:   0 0 24px var(--dl-purple-glow), 0 4px 24px rgba(0,0,0,0.5);

    /* Legacy compatibility — keeps existing PHP templates working */
    --sg-navy:          var(--dl-bg-3);
    --sg-navy-dark:     var(--dl-bg);
    --sg-gold:          var(--dl-gold);
    --sg-gold-light:    var(--dl-gold-light);
    --sg-parchment:     var(--dl-bg-2);
    --sg-cream:         var(--dl-bg-3);
    --sg-text:          var(--dl-text);
    --sg-muted:         var(--dl-text-muted);
    --sg-border:        var(--dl-border);
    --sg-green:         var(--dl-success);
}

/* --- Keyframe Animations ---------------------------------- */
@keyframes bgPulse {
    0%, 100% { background-position: 0% 50%; }
    50%       { background-position: 100% 50%; }
}
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}
@keyframes glowPulse {
    0%, 100% { opacity: 0.7; }
    50%       { opacity: 1; }
}
@keyframes aiTyping {
    0%, 100% { opacity: 1; }
    50%       { opacity: 0.25; }
}
@keyframes spin {
    to { transform: rotate(360deg); }
}

/* --- Base -------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    background: var(--dl-grad-divine);
    background-attachment: fixed;
    color: var(--dl-text);
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Subtle ambient orbs */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    background:
        radial-gradient(ellipse 55% 40% at 15% 20%, rgba(109,40,217,0.18) 0%, transparent 60%),
        radial-gradient(ellipse 45% 35% at 85% 75%, rgba(6,182,212,0.12) 0%, transparent 60%),
        radial-gradient(ellipse 30% 30% at 60% 45%, rgba(245,158,11,0.06) 0%, transparent 60%);
    pointer-events: none;
    z-index: 0;
}
body > * { position: relative; z-index: 1; }

/* Custom scrollbar */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--dl-bg-2); }
::-webkit-scrollbar-thumb { background: var(--dl-purple-dark); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--dl-purple); }

/* Typography */
h1, h2, h3, h4, h5, h6 { font-weight: 700; color: var(--dl-text); }
a { color: var(--dl-purple); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--dl-blue); }
hr { border-color: var(--dl-border) !important; opacity: 1 !important; }

/* --- Church Sidebar --------------------------------------- */
.sg-church-sidebar {
    position: fixed;
    top: 56px; /* navbar height */
    left: 0;
    width: 220px;
    height: calc(100vh - 56px);
    overflow-y: auto;
    overflow-x: hidden;
    z-index: 990;
    background: var(--dl-bg-2);
    border-right: 1px solid var(--dl-border);
    display: flex;
    flex-direction: column;
    padding-bottom: 1rem;
}
.sg-church-sidebar::-webkit-scrollbar { width: 4px; }
.sg-church-sidebar::-webkit-scrollbar-track { background: transparent; }
.sg-church-sidebar::-webkit-scrollbar-thumb { background: var(--dl-border); border-radius: 2px; }

.sg-sb-header {
    display: flex;
    align-items: center;
    padding: 0.85rem 1rem;
    border-bottom: 1px solid var(--dl-border);
    color: var(--dl-text);
    font-size: .8rem;
    min-height: 48px;
}

.sg-sb-section {
    padding: 0.75rem 0 0.25rem;
}

.sg-sb-label {
    font-size: .65rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--dl-text-muted);
    padding: 0 1rem 0.3rem;
}

.sg-sb-link {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.42rem 1rem;
    font-size: .83rem;
    color: var(--dl-text-dim);
    text-decoration: none;
    border-radius: 0;
    transition: background .15s, color .15s;
    position: relative;
    white-space: nowrap;
}
.sg-sb-link:hover {
    background: rgba(255,255,255,0.05);
    color: var(--dl-text);
}
.sg-sb-link.active {
    background: rgba(139,92,246,0.14);
    color: var(--dl-purple);
    font-weight: 600;
}
.sg-sb-link.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--dl-purple);
    border-radius: 0 2px 2px 0;
}
.sg-sb-link i { font-size: .95rem; flex-shrink: 0; }

.sg-sb-badge {
    margin-left: auto;
    background: var(--dl-gold);
    color: #000;
    font-size: .65rem;
    font-weight: 700;
    padding: 0.1rem 0.4rem;
    border-radius: 10px;
    line-height: 1.4;
}

/* Main content area offset when sidebar is present */
.sg-church-content {
    margin-left: 220px;
    width: calc(100% - 220px);
    max-width: calc(100% - 220px);
    box-sizing: border-box;
    overflow-x: hidden;
}

.team-members-page .sg-card {
    min-height: calc(100vh - 260px);
}

.sg-card a.text-body {
    color: var(--dl-text) !important;
}

.sg-card a.text-body:hover,
.sg-card a.text-body:focus {
    color: var(--dl-text) !important;
    background: rgba(255,255,255,0.06);
}

/* --- Navigation bar --------------------------------------- */
.sg-navbar {
    background: rgba(7,7,15,0.88) !important;
    backdrop-filter: blur(24px) saturate(180%);
    -webkit-backdrop-filter: blur(24px) saturate(180%);
    border-bottom: 1px solid var(--dl-border-glow) !important;
    box-shadow: 0 1px 0 rgba(139,92,246,0.25), 0 4px 24px rgba(0,0,0,0.4);
    position: sticky;
    top: 0;
    z-index: 1000;
    padding: 0.55rem 1rem;
}

.sg-navbar .navbar-brand {
    background: linear-gradient(90deg, var(--dl-purple), var(--dl-blue));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-size: 1.2rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    filter: drop-shadow(0 0 8px rgba(139,92,246,0.4));
}

.sg-navbar .nav-link {
    color: var(--dl-text-dim) !important;
    font-size: 0.875rem;
    font-weight: 500;
    padding: 0.45rem 0.85rem !important;
    border-radius: 8px;
    transition: all 0.2s ease;
    position: relative;
}

.sg-navbar .nav-link:hover {
    color: var(--dl-text) !important;
    background: var(--dl-surface);
}

.sg-navbar .nav-link.active {
    color: var(--dl-purple) !important;
    background: rgba(139,92,246,0.1);
}

.sg-navbar .nav-link.active::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    width: 18px;
    height: 2px;
    background: var(--dl-purple);
    border-radius: 2px;
    box-shadow: 0 0 8px var(--dl-purple);
}

.sg-navbar .navbar-toggler {
    border-color: var(--dl-border-glow);
    color: var(--dl-text-dim);
}

/* Dropdown */
.dropdown-menu {
    background: rgba(10,10,22,0.96) !important;
    backdrop-filter: blur(24px);
    border: 1px solid var(--dl-border) !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 40px rgba(0,0,0,0.6), 0 0 1px rgba(139,92,246,0.3);
    padding: 0.45rem;
}

.dropdown-item {
    color: var(--dl-text-dim) !important;
    border-radius: 8px;
    padding: 0.45rem 0.85rem;
    font-size: 0.875rem;
    transition: all 0.15s;
}

.dropdown-item:hover {
    background: var(--dl-surface) !important;
    color: var(--dl-text) !important;
}

.dropdown-divider { border-color: var(--dl-border) !important; }

/* --- Primary button --------------------------------------- */
.btn-sg-primary {
    background: var(--dl-grad-purple);
    border: none;
    color: #fff;
    font-weight: 600;
    border-radius: 10px;
    padding: 0.55rem 1.25rem;
    box-shadow: 0 0 18px var(--dl-purple-glow), var(--dl-shadow-sm);
    transition: all 0.25s ease;
    letter-spacing: 0.02em;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.btn-sg-primary:hover,
.btn-sg-primary:focus {
    background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
    color: #fff;
    box-shadow: 0 0 32px rgba(139,92,246,0.65), var(--dl-shadow-md);
    transform: translateY(-1px);
}

.btn-sg-primary {
    background: var(--dl-purple);
    border: none;
    color: #fff;
    font-weight: 600;
    border-radius: 10px;
    padding: 0.55rem 1.25rem;
    box-shadow: 0 0 18px var(--dl-purple-glow), var(--dl-shadow-sm);
    transition: all 0.25s ease;
    letter-spacing: 0.02em;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.btn-primary {
    background: transparent !important;
    color: var(--dl-purple) !important;
    border: 1px solid var(--dl-purple) !important;
    box-shadow: none !important;
}

.btn-primary:hover,
.btn-primary:focus {
    background: rgba(139,92,246,0.14) !important;
    color: var(--dl-purple) !important;
    box-shadow: 0 0 14px rgba(139,92,246,0.25) !important;
    transform: translateY(0);
}

.ai-assistant-page .btn-primary {
    background: var(--dl-gold, #f59e0b) !important;
    color: #111 !important;
    border: none !important;
    box-shadow: 0 0 18px rgba(245,158,11,0.25) !important;
}

.ai-assistant-page .btn-primary:hover,
.ai-assistant-page .btn-primary:focus {
    filter: brightness(1.08);
}

.btn-sg-primary:hover,
.btn-sg-primary:focus {
    background: linear-gradient(135deg, #7c3aed 0%, #6d28d9 100%);
    color: #fff;
    box-shadow: 0 0 32px rgba(139,92,246,0.65), var(--dl-shadow-md);
    transform: translateY(-1px);
}

.btn-primary:active,
.btn-sg-primary:active {
    transform: translateY(0);
}

.btn-success,
.btn-danger,
.btn-warning {
    border: none;
    font-weight: 600;
    border-radius: 10px;
    padding: 0.55rem 1.25rem;
    box-shadow: 0 0 18px rgba(0,0,0,0.08), var(--dl-shadow-sm);
    transition: all 0.25s ease;
    letter-spacing: 0.02em;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.btn-success {
    background: transparent !important;
    color: var(--dl-success, #16a34a) !important;
    border: 1px solid var(--dl-success, #16a34a) !important;
    box-shadow: none !important;
}

.btn-success:hover,
.btn-success:focus {
    background: rgba(22,163,74,0.12) !important;
    color: var(--dl-success, #16a34a) !important;
    box-shadow: 0 0 14px rgba(22,163,74,0.25) !important;
    transform: translateY(0);
}

.btn-danger {
    background: var(--dl-danger, #ef4444);
    color: #fff;
}

.btn-danger:hover,
.btn-danger:focus {
    filter: brightness(1.08);
}

.btn-warning {
    background: var(--dl-gold, #f59e0b);
    color: #111;
}

.btn-warning:hover,
.btn-warning:focus {
    filter: brightness(1.08);
}

/* Outline variants */
.btn-outline-secondary {
    border-color: var(--dl-border) !important;
    color: var(--dl-text-dim) !important;
    background: transparent !important;
    border-radius: 8px !important;
    transition: all 0.2s;
}
.btn-outline-secondary:hover {
    background: var(--dl-surface) !important;
    border-color: var(--dl-border-glow) !important;
    color: var(--dl-text) !important;
}
.btn-check:checked + .btn-outline-secondary {
    background: rgba(139,92,246,0.22) !important;
    border-color: rgba(139,92,246,0.6) !important;
    color: var(--dl-purple-light, #c4b5fd) !important;
}
.btn-check:checked + .btn-outline-secondary:hover {
    background: rgba(139,92,246,0.30) !important;
}

.btn-outline-primary {
    border-color: var(--dl-purple) !important;
    color: var(--dl-purple) !important;
    background: transparent !important;
    border-radius: 8px !important;
    transition: all 0.2s;
}
.btn-outline-primary:hover,
.btn-outline-primary.active,
.btn-outline-primary:focus,
.btn-outline-primary:focus-visible,
.btn-outline-primary:active {
    background: rgba(139,92,246,0.14) !important;
    color: var(--dl-purple) !important;
    box-shadow: 0 0 14px var(--dl-purple-glow);
}

.btn-outline-warning {
    border-color: var(--dl-gold, #f59e0b) !important;
    color: var(--dl-gold, #f59e0b) !important;
    background: transparent !important;
    border-radius: 8px !important;
    transition: all 0.2s;
}
.btn-outline-warning:hover {
    background: rgba(245,158,11,0.14) !important;
    color: var(--dl-gold, #f59e0b) !important;
    box-shadow: 0 0 14px rgba(245,158,11,0.4);
}
.btn-outline-warning:focus,
.btn-outline-warning:focus-visible,
.btn-outline-warning:active {
    background: rgba(245,158,11,0.2) !important;
    color: var(--dl-gold, #f59e0b) !important;
    box-shadow: 0 0 0 3px rgba(245,158,11,0.35) !important;
}

.btn-outline-danger {
    border-color: var(--dl-danger) !important;
    color: var(--dl-danger) !important;
    background: transparent !important;
    border-radius: 8px !important;
    transition: all 0.2s;
}
.btn-outline-danger:hover {
    background: rgba(239,68,68,0.1) !important;
}

.btn-outline-success {
    border-color: var(--dl-success, #16a34a) !important;
    color: var(--dl-success, #16a34a) !important;
    background: transparent !important;
    border-radius: 8px !important;
    transition: all 0.2s;
}
.btn-outline-success:hover {
    background: rgba(22,163,74,0.14) !important;
    color: var(--dl-success, #16a34a) !important;
    box-shadow: 0 0 14px rgba(22,163,74,0.4);
}
.btn-outline-success:focus,
.btn-outline-success:focus-visible,
.btn-outline-success:active {
    background: rgba(22,163,74,0.2) !important;
    color: var(--dl-success, #16a34a) !important;
    box-shadow: 0 0 0 3px rgba(22,163,74,0.35) !important;
}

.btn-sm { font-size: 0.8rem !important; padding: 0.3rem 0.75rem !important; }

/* --- Form controls ---------------------------------------- */
.form-control,
.form-select {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 10px !important;
    color: var(--dl-text) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    transition: all 0.2s;
    padding: 0.55rem 0.9rem;
}

.form-select,
.form-control {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
}

.form-control::placeholder { color: var(--dl-text-muted) !important; }

.form-control:focus,
.form-select:focus {
    background: rgba(139,92,246,0.07) !important;
    border-color: var(--dl-purple) !important;
    box-shadow: 0 0 0 3px rgba(139,92,246,0.18), 0 0 14px var(--dl-purple-glow) !important;
    color: var(--dl-text) !important;
    outline: none !important;
}

.form-label {
    color: var(--dl-text-dim);
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    margin-bottom: 0.35rem;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.form-select option {
    background: var(--dl-bg-3);
    color: var(--dl-text);
}

.input-group-text {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    color: var(--dl-text-muted) !important;
    border-radius: 10px !important;
}

/* --- Cards ------------------------------------------------ */
.card {
    background: var(--dl-glass-bg) !important;
    backdrop-filter: var(--dl-glass-blur);
    -webkit-backdrop-filter: var(--dl-glass-blur);
    border: 1px solid var(--dl-border) !important;
    border-radius: 16px !important;
    color: var(--dl-text);
    box-shadow: var(--dl-shadow-sm);
    transition: all 0.3s ease;
}

.card:hover {
    border-color: rgba(139,92,246,0.3) !important;
    box-shadow: 0 0 24px rgba(139,92,246,0.1), var(--dl-shadow-md) !important;
}

.card-header {
    background: rgba(255,255,255,0.03) !important;
    border-bottom: 1px solid var(--dl-border) !important;
    border-radius: 16px 16px 0 0 !important;
    color: var(--dl-text);
    padding: 0.9rem 1.25rem;
    font-weight: 600;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.card-body { color: var(--dl-text); }

.card-footer {
    background: rgba(255,255,255,0.02) !important;
    border-top: 1px solid var(--dl-border) !important;
    border-radius: 0 0 16px 16px !important;
}

/* --- Auth / Login page ------------------------------------ */
.sg-auth-wrapper {
    background: var(--dl-grad-divine);
    background-size: 400% 400%;
    animation: bgPulse 10s ease infinite;
    min-height: 100vh;
    position: relative;
}

.sg-auth-wrapper::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 65% 50% at 15% 25%, rgba(109,40,217,0.28) 0%, transparent 60%),
        radial-gradient(ellipse 50% 60% at 80% 70%, rgba(6,182,212,0.18) 0%, transparent 60%);
    pointer-events: none;
}

.sg-auth-card {
    background: var(--dl-glass-bg) !important;
    backdrop-filter: blur(28px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(28px) saturate(180%) !important;
    border: 1px solid rgba(139,92,246,0.28) !important;
    border-radius: 22px !important;
    box-shadow: 0 0 70px rgba(139,92,246,0.22), 0 8px 48px rgba(0,0,0,0.7) !important;
    animation: fadeInUp 0.5s ease both;
}

.sg-brand-icon {
    font-size: 3rem;
    background: linear-gradient(135deg, var(--dl-purple), var(--dl-blue));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 0 18px rgba(139,92,246,0.55));
}

.sg-brand-title {
    background: linear-gradient(90deg, var(--dl-text), var(--dl-text-dim));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-weight: 800;
    letter-spacing: 0.03em;
}

/* Nav tabs */
.nav-tabs {
    border-bottom: 1px solid var(--dl-border) !important;
    gap: 4px;
}

.nav-tabs .nav-link {
    color: var(--dl-text-muted) !important;
    border: 1px solid transparent !important;
    border-radius: 10px 10px 0 0 !important;
    padding: 0.5rem 1.1rem;
    font-weight: 500;
    font-size: 0.875rem;
    transition: all 0.2s;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.nav-tabs .nav-link:hover { color: var(--dl-text-dim) !important; }

.nav-tabs .nav-link.active {
    background: rgba(139,92,246,0.1) !important;
    border-color: rgba(139,92,246,0.3) rgba(139,92,246,0.3) transparent !important;
    color: var(--dl-purple) !important;
}

/* --- Alerts ----------------------------------------------- */
.alert {
    border-radius: 12px !important;
    border: 1px solid var(--dl-border) !important;
    background: var(--dl-surface) !important;
    color: var(--dl-text) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}
.alert-success {
    border-color: rgba(16,185,129,0.4) !important;
    background: rgba(16,185,129,0.07) !important;
    color: #6ee7b7 !important;
}
.alert-danger {
    border-color: rgba(239,68,68,0.4) !important;
    background: rgba(239,68,68,0.07) !important;
    color: #fca5a5 !important;
}
.alert-warning {
    border-color: rgba(245,158,11,0.4) !important;
    background: rgba(245,158,11,0.07) !important;
    color: #fcd34d !important;
}
.alert-info {
    border-color: rgba(6,182,212,0.4) !important;
    background: rgba(6,182,212,0.07) !important;
    color: #67e8f9 !important;
}

/* --- Welcome banner --------------------------------------- */
.sg-welcome-banner {
    background: linear-gradient(135deg, rgba(109,40,217,0.28), rgba(3,105,161,0.18));
    border: 1px solid rgba(139,92,246,0.3);
    border-left: 4px solid var(--dl-purple) !important;
    border-radius: 16px;
    backdrop-filter: blur(12px);
    box-shadow: 0 0 28px rgba(139,92,246,0.1);
    animation: fadeInUp 0.4s ease both;
}

.sg-welcome-banner h4 {
    background: linear-gradient(90deg, var(--dl-text), var(--dl-gold-light));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* --- Stat cards ------------------------------------------- */
.sg-stat-card {
    background: var(--dl-glass-bg) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 16px !important;
    position: relative;
    overflow: hidden;
    transition: all 0.3s ease;
}

.sg-stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--dl-grad-purple);
    opacity: 0;
    transition: opacity 0.3s;
}

.sg-stat-card:hover {
    border-color: rgba(139,92,246,0.38) !important;
    box-shadow: 0 0 28px rgba(139,92,246,0.14), var(--dl-shadow-md) !important;
    transform: translateY(-3px);
}

.sg-stat-card:hover::before { opacity: 1; }

.sg-stat-number {
    font-size: 2.2rem;
    font-weight: 800;
    background: linear-gradient(135deg, var(--dl-purple), var(--dl-blue));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    line-height: 1;
    margin-bottom: 0.25rem;
}

.sg-stat-label {
    font-size: 0.72rem;
    color: var(--dl-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.09em;
    font-weight: 600;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

/* --- Sermon cards ----------------------------------------- */
.sg-sermon-card {
    background: var(--dl-glass-bg) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 14px !important;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

.sg-sermon-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(139,92,246,0.04) 0%, transparent 60%);
    pointer-events: none;
}

.sg-sermon-card:hover {
    border-color: rgba(139,92,246,0.35) !important;
    box-shadow: 0 0 22px rgba(139,92,246,0.12), var(--dl-shadow-md) !important;
    transform: translateY(-2px);
}

/* --- Empty state ------------------------------------------ */
.sg-empty-state { color: var(--dl-text-muted); }

.sg-empty-icon {
    font-size: 4rem;
    background: linear-gradient(135deg, var(--dl-purple), var(--dl-gold));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 0 14px var(--dl-purple-glow));
}

/* --- Section labels --------------------------------------- */
.sg-section-label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--dl-text-muted);
    font-family: 'Inter', 'Segoe UI', sans-serif;
    font-weight: 600;
    margin-bottom: 0;
}
.sg-toggle-icon {
    transition: transform .25s ease;
}
.sg-toggle-icon.sg-toggle-rotated {
    transform: rotate(180deg);
}

/* --- Badges ----------------------------------------------- */
.badge {
    border-radius: 6px !important;
    font-weight: 600 !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.04em;
    padding: 0.3em 0.65em !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.bg-secondary { background: var(--dl-surface-2) !important; color: var(--dl-text-dim) !important; }
.bg-success   { background: rgba(16,185,129,0.15) !important; color: #6ee7b7 !important; border: 1px solid rgba(16,185,129,0.3) !important; }
.bg-warning   { background: rgba(245,158,11,0.15) !important; color: #fcd34d !important; border: 1px solid rgba(245,158,11,0.3) !important; }
.bg-danger    { background: rgba(239,68,68,0.15) !important; color: #fca5a5 !important; border: 1px solid rgba(239,68,68,0.3) !important; }
.bg-info      { background: rgba(6,182,212,0.15) !important; color: #67e8f9 !important; border: 1px solid rgba(6,182,212,0.3) !important; }
.bg-primary   { background: rgba(139,92,246,0.15) !important; color: var(--dl-purple) !important; border: 1px solid rgba(139,92,246,0.3) !important; }

/* --- Tables ----------------------------------------------- */
.table {
    /* Override Bootstrap 5's internal CSS variable system */
    --bs-table-bg:            transparent;
    --bs-table-color:         var(--dl-text);
    --bs-table-border-color:  var(--dl-border);
    --bs-table-striped-bg:    rgba(139,92,246,0.04);
    --bs-table-striped-color: var(--dl-text);
    --bs-table-hover-bg:      rgba(139,92,246,0.09);
    --bs-table-hover-color:   var(--dl-text);
    --bs-table-active-bg:     rgba(139,92,246,0.14);
    --bs-table-active-color:  var(--dl-text);
    color: var(--dl-text) !important;
    border-color: var(--dl-border) !important;
}

.table thead tr {
    background: rgba(139,92,246,0.10) !important;
    border-bottom: 1px solid var(--dl-border-glow) !important;
}

.table th {
    background: transparent !important;
    color: var(--dl-text-dim) !important;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    border-color: var(--dl-border) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    white-space: nowrap;
}

.table tbody tr {
    background-color: rgba(10,10,20,0.45) !important;
    transition: background 0.15s;
}

.table tbody tr:nth-child(even) {
    background-color: rgba(19,19,35,0.55) !important;
}

.table td {
    color: var(--dl-text) !important;
    border-color: var(--dl-border) !important;
    vertical-align: middle;
}

.table-hover tbody tr:hover {
    background: rgba(139,92,246,0.10) !important;
    color: var(--dl-text) !important;
}

/* Rounded table wrapper with dropdown support */
.table-responsive {
    border-radius: 12px;
    overflow: visible;
}

.table-responsive > .table {
    min-width: 100%;
}

.table-responsive .dropdown-menu {
    position: absolute;
    z-index: 1200;
}

.table-responsive .dropdown-menu.dropdown-menu-end {
    right: 0;
    left: auto;
}

/* Tighten form controls that appear inside table cells */
.table .form-control,
.table .form-select {
    border-radius: 8px !important;
    padding: 0.3rem 0.5rem !important;
    font-size: 0.82rem !important;
}

.table .input-group-text {
    border-radius: 8px !important;
}

/* --- Progress bar ----------------------------------------- */
.progress {
    background: var(--dl-surface) !important;
    border-radius: 99px !important;
    border: 1px solid var(--dl-border);
    overflow: visible !important;
}

.progress-bar {
    background: var(--dl-grad-purple) !important;
    box-shadow: 0 0 12px var(--dl-purple-glow);
    border-radius: 99px;
}

.progress-bar.bg-success {
    background: linear-gradient(90deg, #059669, #10b981) !important;
    box-shadow: 0 0 12px rgba(16,185,129,0.4);
}

/* --- Modals ----------------------------------------------- */
.modal-content {
    background: rgba(10,10,20,0.96) !important;
    backdrop-filter: blur(28px);
    -webkit-backdrop-filter: blur(28px);
    border: 1px solid var(--dl-border-glow) !important;
    border-radius: 20px !important;
    box-shadow: 0 0 70px rgba(139,92,246,0.22), 0 10px 48px rgba(0,0,0,0.75) !important;
    color: var(--dl-text);
}

.modal-header {
    border-bottom: 1px solid var(--dl-border) !important;
    padding: 1.25rem 1.5rem;
}

.modal-footer { border-top: 1px solid var(--dl-border) !important; }
.modal-title { font-weight: 700; }

.btn-close { filter: invert(1) !important; opacity: 0.4 !important; }

/* --- Toast notifications ---------------------------------- */
.toast {
    background: rgba(8,8,18,0.96) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid var(--dl-border-glow) !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 36px rgba(0,0,0,0.65), 0 0 18px var(--dl-purple-glow) !important;
    color: var(--dl-text) !important;
    min-width: 290px;
    overflow: hidden;
}

.toast-body {
    color: var(--dl-text) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    font-size: 0.88rem;
    font-weight: 500;
}

/* --- Offcanvas panels ------------------------------------ */
.offcanvas {
    background: rgba(10,10,20,0.94) !important;
    backdrop-filter: blur(26px);
    -webkit-backdrop-filter: blur(26px);
    border: 1px solid var(--dl-border-glow) !important;
    border-radius: 20px !important;
    box-shadow: 0 30px 80px rgba(0,0,0,0.55), 0 0 26px rgba(139,92,246,0.18) !important;
    color: var(--dl-text);
}

.offcanvas .offcanvas-header {
    border-bottom: 1px solid var(--dl-border) !important;
}

.offcanvas .offcanvas-title,
.offcanvas .offcanvas-body {
    color: var(--dl-text);
}

.offcanvas .offcanvas-body .text-success {
    color: var(--dl-success) !important;
}

.offcanvas .offcanvas-body .text-danger {
    color: var(--dl-danger) !important;
}

.offcanvas .offcanvas-body .text-warning {
    color: var(--dl-gold) !important;
}

.offcanvas .offcanvas-body .text-info {
    color: var(--dl-blue) !important;
}

.offcanvas .offcanvas-body .text-secondary {
    color: var(--dl-text-dim) !important;
}

.offcanvas .offcanvas-body .text-primary {
    color: var(--dl-purple) !important;
}

.offcanvas .btn-close {
    filter: invert(1) !important;
    opacity: 0.55 !important;
}

.offcanvas .btn-close:hover {
    opacity: 0.9 !important;
}

.offcanvas .bg-light {
    background: var(--dl-surface) !important;
}

.offcanvas .border-bottom {
    border-color: var(--dl-border) !important;
}

/* Left accent bar per type */
.sg-toast-success { border-left: 3px solid var(--dl-success) !important; }
.sg-toast-danger  { border-left: 3px solid var(--dl-danger)  !important; }
.sg-toast-warning { border-left: 3px solid var(--dl-gold)    !important; }
.sg-toast-info    { border-left: 3px solid var(--dl-blue)    !important; }

/* --- List groups ------------------------------------------ */
.list-group-item {
    background: var(--dl-surface) !important;
    border-color: var(--dl-border) !important;
    color: var(--dl-text) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.list-group-item-action:hover {
    background: rgba(139,92,246,0.07) !important;
    color: var(--dl-text) !important;
}

.list-group-flush .list-group-item:first-child { border-radius: 0 !important; }
.list-group-flush .list-group-item:last-child  { border-radius: 0 0 16px 16px !important; }

/* --- Text utilities --------------------------------------- */
.text-muted   { color: var(--dl-text-dim) !important; }
.text-success { color: var(--dl-success) !important; }
.text-danger  { color: var(--dl-danger) !important; }
.text-warning { color: var(--dl-gold) !important; }
.text-info    { color: var(--dl-blue) !important; }
.border-bottom { border-color: var(--dl-border) !important; }
.bg-light { background: var(--dl-surface) !important; }

/* Spinner */
.spinner-border { color: var(--dl-purple) !important; filter: drop-shadow(0 0 6px var(--dl-purple-glow)); }

/* ============================================================
   SERMON BUILDER — Split-screen layout
   ============================================================ */
.sg-builder-container {
    height: calc(100vh - 58px);
    overflow: hidden;
}

.sg-builder-container .row { height: 100%; }

/* --- Bible panel (left) ----------------------------------- */
.sg-bible-panel {
    background: var(--dl-glass-bg);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-right: 1px solid var(--dl-border) !important;
    overflow: hidden;
    height: 100%;
}

.sg-bible-nav {
    background: rgba(7,7,15,0.82);
    backdrop-filter: blur(16px);
    flex-shrink: 0;
    border-bottom: 1px solid var(--dl-border);
    padding: 0.3rem 0.6rem 0.35rem;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

/* Scrollable body below the fixed nav */
.sg-bible-body { flex: 1 1 auto; overflow-y: auto; overflow-x: hidden; min-height: 80px; }

/* Tool panels (cross-refs, strong's, AI) pinned to bottom of the panel */
.sg-bible-tools { flex-shrink: 0; overflow-y: auto; border-top: 1px solid var(--dl-border); }

/* Compact version-toggle inside the nav */
.sg-bible-nav .btn-group .btn {
    font-size: 0.72rem;
    padding: 0.2rem 0;
    border-color: rgba(139,92,246,0.35);
    color: var(--dl-text-dim);
}
.sg-bible-nav .btn-group .btn-check:checked + .btn {
    background: rgba(139,92,246,0.25);
    border-color: rgba(139,92,246,0.6);
    color: var(--dl-purple-light, #c4b5fd);
}
/* Remove extra gutter space from the dropdowns row inside the nav */
.sg-bible-nav .row { margin: 0; }

/* Verse display area */
.sg-verse-area { min-height: 160px; }
.sg-verse-placeholder { padding: 2rem 1rem; }

.sg-verse-ref {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--dl-gold);
    filter: drop-shadow(0 0 6px var(--dl-gold-glow));
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.sg-verse-body {
    font-size: 1.1rem;
    line-height: 1.9;
    color: var(--dl-text);
    font-family: 'Playfair Display', Georgia, 'Times New Roman', serif;
    font-style: italic;
}

/* Cross-reference items */
.sg-crossref-list { max-height: 200px; overflow-y: auto; }

/* Position the two floating panels so they don't overlap by default */
#strongsPanel { left: 16px; right: auto; top: 120px; max-height: 70vh; }

.sg-crossref-item {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 8px !important;
    cursor: default;
    color: var(--dl-text) !important;
    transition: border-color 0.2s;
}

.sg-crossref-item:hover { border-color: rgba(139,92,246,0.35) !important; }

.sg-crossref-label {
    font-weight: 600;
    color: var(--dl-blue) !important;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    font-size: 0.8rem;
}
.sg-crossref-link {
    cursor: pointer;
    text-decoration: underline dotted;
    text-underline-offset: 2px;
    transition: color 0.15s;
}
.sg-crossref-link:hover { color: var(--dl-purple) !important; }

/* Search results */
.sg-search-results { max-height: 220px; overflow-y: auto; }

/* ============================================================
   DRAGGABLE SCRIPTURE SEARCH PANEL
   ============================================================ */
.search-panel {
    position: fixed;
    top: 80px;
    right: 16px;
    left: auto;
    width: 370px;
    max-height: 70vh;
    background: rgba(10,10,22,0.97);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(139,92,246,0.4);
    border-radius: 14px;
    box-shadow: 0 8px 40px rgba(0,0,0,0.75), 0 0 0 1px rgba(139,92,246,0.15);
    z-index: 1055;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.search-panel.d-none { display: none !important; }
.search-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.6rem 0.9rem;
    background: rgba(139,92,246,0.14);
    border-bottom: 1px solid var(--dl-border);
    cursor: move;
    user-select: none;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--dl-text);
    border-radius: 14px 14px 0 0;
    flex-shrink: 0;
}
.search-panel-close {
    background: none;
    border: none;
    color: var(--dl-text-dim);
    cursor: pointer;
    padding: 0.15rem 0.4rem;
    border-radius: 6px;
    font-size: 1rem;
    line-height: 1;
    transition: background 0.2s, color 0.2s;
}
.search-panel-close:hover { background: rgba(239,68,68,0.18); color: #ef4444; }
.search-panel-body { flex: 1 1 auto; overflow-y: auto; padding: 0.4rem; }

/* ── Strong's Lexicon Card ────────────────────────────────────────────────── */
.lex-back-btn {
    background: none;
    border: none;
    color: var(--dl-text-dim);
    cursor: pointer;
    padding: 0.15rem 0.4rem;
    border-radius: 6px;
    font-size: 0.95rem;
    line-height: 1;
    transition: background 0.2s, color 0.2s;
    flex-shrink: 0;
}
.lex-back-btn:hover { background: rgba(139,92,246,0.18); color: var(--dl-purple); }
.lex-card {
    background: var(--dl-surface);
    border: 1px solid var(--dl-border);
    border-radius: 10px;
    padding: 0.65rem 0.75rem;
}
.lex-card-header { line-height: 1.6; }
.lex-tabs .nav-link {
    font-size: 0.78rem;
    color: var(--dl-text-dim);
    padding: 0.2rem 0.55rem;
    border-radius: 6px 6px 0 0;
    border: 1px solid transparent;
}
.lex-tabs .nav-link.active {
    color: var(--dl-text);
    background: var(--dl-surface);
    border-color: var(--dl-border) var(--dl-border) var(--dl-surface);
}
.lex-tab-content {
    border: 1px solid var(--dl-border);
    border-top: none;
    border-radius: 0 0 6px 6px;
    padding: 0.55rem 0.85rem;
    font-size: 0.82rem;
    color: var(--dl-text);
    background: var(--dl-surface);
    min-height: 3rem;
}
.lex-usage-list { font-size: 0.82rem; line-height: 1.6; padding-right: 0.5rem; }
.lex-see-also { font-size: 0.78rem; }
.lex-chip {
    font-size: 0.72rem !important;
    line-height: 1.4;
    border-radius: 20px !important;
    padding: 0.1rem 0.55rem !important;
    color: var(--dl-text-dim) !important;
    border-color: var(--dl-border) !important;
    transition: background 0.15s, color 0.15s;
}
.lex-chip:hover {
    background: rgba(139,92,246,0.15) !important;
    color: var(--dl-purple) !important;
    border-color: rgba(139,92,246,0.4) !important;
}
.lex-ref-link {
    color: var(--dl-purple);
    text-decoration: underline dotted;
    text-underline-offset: 2px;
    cursor: pointer;
}
.lex-ref-link:hover { color: var(--dl-blue); }
.font-greek { font-family: 'SBL Greek', 'New Athena Unicode', Georgia, serif; }
.font-hebrew { font-family: 'SBL Hebrew', 'Ezra SIL', 'David', serif; direction: rtl; unicode-bidi: embed; }

/* Wider lexicon panel to accommodate tabs */
#strongsPanel { width: 480px; left: 16px; right: auto; top: 120px; max-height: 75vh; }

.sg-search-item {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 8px !important;
    cursor: pointer;
    color: var(--dl-text) !important;
    transition: all 0.15s;
}

.sg-search-item:hover {
    background: rgba(139,92,246,0.08) !important;
    border-color: rgba(139,92,246,0.35) !important;
}

/* ── Lexicon card: concordance button ──────────────────────────────────────── */
.lex-concordance-row { padding: 0 0.85rem 0.55rem; }
.lex-conc-btn { font-size: 0.75rem; padding: 0.2rem 0.6rem; }
.lex-conc-btn:hover { background: rgba(139,92,246,0.12); border-color: var(--dl-blue); color: var(--dl-blue); }

/* ── Concordance panel ─────────────────────────────────────────────────────── */
#concordancePanel {
    width: 460px;
    right: 16px;
    left: auto;
    top: 120px;
    max-height: 75vh;
}

.conc-verse-item {
    padding: 0.55rem 0.75rem;
    border-bottom: 1px solid var(--dl-border);
    cursor: pointer;
    transition: background 0.12s;
}
.conc-verse-item:last-child { border-bottom: none; }
.conc-verse-item:hover { background: rgba(139,92,246,0.07); }

.conc-verse-ref {
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: var(--dl-blue);
    margin-bottom: 0.15rem;
}
.conc-verse-text {
    color: var(--dl-text);
    line-height: 1.55;
}

.conc-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.45rem 0.75rem;
    border-top: 1px solid var(--dl-border);
    background: var(--dl-surface);
    font-size: 0.78rem;
    flex-shrink: 0;
}
.conc-pagination .btn { font-size: 0.75rem; padding: 0.15rem 0.5rem; }

/* AI panel */
.sg-ai-panel {
    background: rgba(139,92,246,0.05);
    border: 1px solid rgba(139,92,246,0.2);
    border-radius: 14px;
}

.sg-ai-output {
    background: var(--dl-surface);
    border: 1px solid var(--dl-border);
    border-radius: 10px;
    padding: 0.85rem;
    font-size: 0.875rem;
    max-height: 200px;
    overflow-y: auto;
    color: var(--dl-text);
    line-height: 1.75;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

/* AI generating animation */
.ai-generating::after {
    content: ' ▋';
    animation: aiTyping 0.9s ease infinite;
    color: var(--dl-purple);
}

/* --- Sermon editor panel (right) -------------------------- */
.sg-editor-panel {
    background: var(--dl-glass-bg);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    overflow-y: auto;
    height: 100%;
}

/* Style / Tone / Audience bar — own stacking layer above Quill */
.sg-style-tone-bar {
    position: relative;
    z-index: 10;
    background: rgba(7,7,15,0.88);
    flex-shrink: 0;
}

/* Preset mode bar */
.sg-preset-bar {
    position: relative;
    z-index: 10;
    background: rgba(7,7,15,0.88);
    flex-shrink: 0;
}

.sg-preset-label {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--dl-text-muted);
    white-space: nowrap;
    user-select: none;
}

.sg-plan-badge {
    font-size: 0.6rem;
    background: rgba(245,158,11,0.15);
    color: #fbbf24;
    border: 1px solid rgba(245,158,11,0.35);
    border-radius: 4px;
    padding: 1px 5px;
    vertical-align: middle;
    font-weight: 600;
    letter-spacing: 0.02em;
}

.sg-preset-btn {
    font-size: 0.72rem;
    padding: 3px 11px;
    border-radius: 20px;
    border: 1px solid rgba(245,158,11,0.28);
    background: rgba(245,158,11,0.05);
    color: #c49a3c;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s, box-shadow .15s;
    white-space: nowrap;
    line-height: 1.6;
}

.sg-preset-btn:hover:not(.sg-preset-locked) {
    background: rgba(245,158,11,0.16);
    border-color: rgba(245,158,11,0.55);
    color: #fbbf24;
    box-shadow: 0 0 8px rgba(245,158,11,0.18);
}

.sg-preset-btn.active {
    background: rgba(245,158,11,0.2);
    border-color: #f59e0b;
    color: #fbbf24;
    font-weight: 600;
    box-shadow: 0 0 10px rgba(245,158,11,0.25);
}

.sg-preset-btn.sg-preset-locked {
    opacity: 0.4;
    cursor: not-allowed;
    border-style: dashed;
}

/* Gear button to open Manage Presets modal */
.sg-preset-manage-btn {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 6px;
    color: var(--dl-text-muted);
    padding: 3px 7px;
    font-size: 0.78rem;
    cursor: pointer;
    transition: color .15s, border-color .15s, background .15s;
    flex-shrink: 0;
}
.sg-preset-manage-btn:hover {
    color: #fbbf24;
    border-color: rgba(245,158,11,0.4);
    background: rgba(245,158,11,0.08);
}

/* Preset list items inside the modal */
.sg-preset-list-item {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.08);
}
.sg-preset-list-item:hover {
    background: rgba(255,255,255,0.07);
}

.sg-preset-system-badge {
    font-size: 0.6rem;
    background: rgba(99,102,241,0.18);
    color: #a5b4fc;
    border: 1px solid rgba(99,102,241,0.3);
    border-radius: 4px;
    padding: 1px 5px;
    font-weight: 600;
    letter-spacing: 0.02em;
    vertical-align: middle;
}

.sg-preset-edited-badge {
    font-size: 0.6rem;
    background: rgba(245,158,11,0.15);
    color: #fbbf24;
    border: 1px solid rgba(245,158,11,0.3);
    border-radius: 4px;
    padding: 1px 5px;
    font-weight: 600;
    letter-spacing: 0.02em;
    vertical-align: middle;
}

.sg-preset-action-btn {
    background: transparent;
    border: none;
    color: var(--dl-text-muted);
    padding: 3px 6px;
    border-radius: 6px;
    font-size: 0.8rem;
    cursor: pointer;
    transition: color .15s, background .15s;
    flex-shrink: 0;
}
.sg-preset-action-btn:hover {
    background: rgba(255,255,255,0.08);
    color: var(--dl-text);
}
.sg-preset-action-btn.text-danger:hover {
    background: rgba(239,68,68,0.12);
    color: #f87171;
}

/* Added verses panel */
.sg-added-verses { max-height: 150px; overflow-y: auto; }

.sg-added-verse {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 8px;
    color: var(--dl-text);
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

/* ============================================================
   Responsive adjustments
   ============================================================ */
@media (max-width: 991.98px) {
    .sg-builder-container {
        height: auto;
        overflow: visible;
    }

    .sg-bible-panel,
    .sg-editor-panel,
    .sg-study-panel {
        height: auto;
        overflow-y: visible;
        border-right: none !important;
        border-bottom: 1px solid var(--dl-border);
    }
}

/* ============================================================
   Bible Study — specific overrides
   ============================================================ */
.study-section-card {
    background: var(--dl-glass-bg) !important;
    border: 1px solid var(--dl-border) !important;
    border-left: 4px solid var(--dl-purple) !important;
    border-radius: 12px !important;
    transition: all 0.2s;
}

.study-section-card.completed {
    border-left-color: var(--dl-success) !important;
    background: rgba(16,185,129,0.04) !important;
}

.question-item {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 10px !important;
    color: var(--dl-text);
    padding: 10px 12px;
    margin-bottom: 8px;
}
.question-header {
    cursor: pointer;
    user-select: none;
}
.question-chevron {
    transition: transform 0.2s ease;
    flex-shrink: 0;
}

.sg-study-panel {
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    height: calc(100vh - 58px);
    background: var(--dl-glass-bg);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}

/* ============================================================
   Quill editor overrides
   ============================================================ */
#sermon-editor {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
}

.ql-toolbar {
    background: var(--dl-surface) !important;
    border-color: var(--dl-border) !important;
    border-radius: 10px 10px 0 0 !important;
}

.ql-toolbar .ql-stroke { stroke: var(--dl-text-dim) !important; }
.ql-toolbar .ql-fill   { fill: var(--dl-text-dim) !important; }
.ql-toolbar button:hover .ql-stroke { stroke: var(--dl-purple) !important; }
.ql-toolbar button:hover .ql-fill   { fill: var(--dl-purple) !important; }
.ql-toolbar .ql-picker-label { color: var(--dl-text-dim) !important; }
.ql-toolbar .ql-picker-options {
    background: var(--dl-bg-3) !important;
    border-color: var(--dl-border) !important;
    border-radius: 8px !important;
}

.ql-container {
    background: var(--dl-surface) !important;
    border-color: var(--dl-border) !important;
    border-radius: 0 0 10px 10px !important;
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1rem !important;
    color: var(--dl-text) !important;
    flex: 1;
    min-height: 0;
    overflow-y: auto !important;
}

.ql-editor { color: var(--dl-text) !important; min-height: unset; height: 100%; }
.ql-editor.ql-blank::before { color: var(--dl-text-muted) !important; font-style: italic; }

.ql-editor blockquote {
    border-left: 4px solid var(--dl-gold) !important;
    background: rgba(245,158,11,0.05);
    border-radius: 0 8px 8px 0;
    color: var(--dl-text-dim) !important;
    font-style: italic;
    padding: 0.5rem 0.85rem !important;
    margin: 0.75rem 0 !important;
}

/* Undo / Redo toolbar buttons */
.ql-toolbar .ql-undo,
.ql-toolbar .ql-redo {
    width: 28px !important;
}
.ql-toolbar .ql-undo .ql-stroke,
.ql-toolbar .ql-redo .ql-stroke { stroke: var(--dl-text-dim) !important; }
.ql-toolbar .ql-undo .ql-fill,
.ql-toolbar .ql-redo .ql-fill   { fill: var(--dl-text-dim) !important; }
.ql-toolbar .ql-undo:hover .ql-stroke,
.ql-toolbar .ql-redo:hover .ql-stroke { stroke: var(--dl-purple) !important; }
.ql-toolbar .ql-undo:hover .ql-fill,
.ql-toolbar .ql-redo:hover .ql-fill   { fill: var(--dl-purple) !important; }

/* ============================================================
   Utility classes
   ============================================================ */
.cursor-pointer { cursor: pointer; }

/* Glow helpers */
.glow-purple { box-shadow: 0 0 18px var(--dl-purple-glow) !important; }
.glow-blue   { box-shadow: 0 0 18px var(--dl-blue-glow) !important; }
.glow-gold   { box-shadow: 0 0 18px var(--dl-gold-glow) !important; }

.text-purple { color: var(--dl-purple) !important; }
.text-blue   { color: var(--dl-blue) !important; }
.text-gold   { color: var(--dl-gold) !important; }

/* ============================================================
   Admin Dashboard — Sidebar Layout
   ============================================================ */
.admin-layout {
    display: flex;
    align-items: flex-start; /* required: lets sidebar use position:sticky */
    min-height: calc(100vh - 58px);
}

/* ============================================================
   Preach Mode Overlay
   ============================================================ */
.se-preach-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: #07070f;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 2rem;
}
.se-preach-overlay.active { display: flex; }

/* Timer — top center */
.se-preach-timer {
    position: fixed;
    top: 1.2rem;
    left: 50%;
    transform: translateX(-50%);
    font-family: 'Courier New', monospace;
    font-size: 1.4rem;
    letter-spacing: 0.15em;
    color: var(--dl-text-dim);
    background: rgba(255,255,255,0.05);
    padding: 0.25rem 1rem;
    border-radius: 8px;
    border: 1px solid var(--dl-border);
}

/* Close button — top right */
.se-preach-close {
    position: fixed;
    top: 1rem;
    right: 1.5rem;
    background: rgba(239,68,68,0.12);
    border: 1px solid rgba(239,68,68,0.35);
    color: #f87171;
    border-radius: 8px;
    padding: 0.4rem 1rem;
    cursor: pointer;
    font-size: 0.9rem;
    transition: background 0.2s;
}
.se-preach-close:hover { background: rgba(239,68,68,0.25); }

/* Point body */
.se-preach-body {
    max-width: 860px;
    width: 100%;
    max-height: calc(100vh - 220px);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.se-preach-pointnum {
    font-size: 0.85rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--dl-text-dim);
    margin-bottom: 1.2rem;
    flex-shrink: 0;
}
.se-preach-point {
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    font-family: 'Playfair Display', Georgia, serif;
    line-height: 1.25;
    color: #fff;
    margin-bottom: 1rem;
    text-shadow: 0 0 40px rgba(139,92,246,0.4);
    flex-shrink: 0;
}
.se-preach-scripture {
    font-size: clamp(1rem, 2vw, 1.35rem);
    color: var(--dl-purple-light, #c4b5fd);
    font-style: italic;
    line-height: 1.8;
    text-align: center;
    min-height: 2rem;
    width: 100%;
}
.se-preach-scripture p {
    margin-bottom: 1rem;
    color: var(--dl-purple-light, #c4b5fd);
}
.se-preach-scripture p:last-child { margin-bottom: 0; }
.se-preach-scripture blockquote {
    border-left: 4px solid rgba(139,92,246,0.75);
    background: rgba(139,92,246,0.1);
    border-radius: 0 8px 8px 0;
    padding: 0.75rem 1.25rem;
    margin: 0.75rem auto;
    text-align: left;
    max-width: 680px;
    width: 100%;
    color: #e2d9f3;
    font-style: italic;
    box-sizing: border-box;
}
.se-preach-scripture ul,
.se-preach-scripture ol {
    text-align: left;
    padding-left: 1.75rem;
    margin: 0 auto 1rem;
    max-width: 680px;
    width: 100%;
    box-sizing: border-box;
}
.se-preach-scripture li { margin-bottom: 0.4rem; }
.se-preach-scripture em { font-style: italic; color: #a78bfa; }

/* Nav — bottom */
.se-preach-nav {
    position: fixed;
    bottom: 2.5rem;
    display: flex;
    gap: 1.5rem;
}
.se-preach-btn {
    background: rgba(139,92,246,0.15);
    border: 1px solid rgba(139,92,246,0.45);
    color: #c4b5fd;
    border-radius: 10px;
    padding: 0.65rem 2rem;
    font-size: 1rem;
    cursor: pointer;
    transition: background 0.2s, transform 0.1s;
}
.se-preach-btn:hover  { background: rgba(139,92,246,0.3); }
.se-preach-btn:active { transform: scale(0.97); }

/* Keyboard hint — very bottom */
.se-preach-hint {
    position: fixed;
    bottom: 0.7rem;
    font-size: 0.7rem;
    color: var(--dl-text-dim);
    opacity: 0.5;
    letter-spacing: 0.05em;
}

/* Passage slides — italic, smaller, more readable for long text */
.se-preach-is-passage .se-preach-point {
    font-size: clamp(1rem, 2.2vw, 1.65rem);
    font-weight: 400;
    font-style: italic;
    text-shadow: none;
    color: #e5e5e5;
}
.se-preach-is-passage .se-preach-pointnum {
    font-size: 0.75rem;
    color: var(--dl-purple-light, #c4b5fd);
    font-style: normal;
}

.admin-sidebar {
    width: 240px;
    flex-shrink: 0;
    background: rgba(7,7,15,0.97);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-right: 1px solid var(--dl-border-glow);
    display: flex;
    flex-direction: column;
    /* Sticky: stays in view while main content scrolls */
    position: sticky;
    top: 58px;
    height: calc(100vh - 58px);
    overflow-y: auto;
    z-index: 10;
}

.admin-main {
    flex-grow: 1;
    min-width: 0; /* prevent flex blowout on narrow screens */
    padding: 1.75rem;
}

/* Sidebar header */
.admin-sidebar-header {
    padding: 1.25rem 1rem;
    border-bottom: 1px solid var(--dl-border);
}

.admin-avatar {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: var(--dl-grad-purple);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: #fff;
    flex-shrink: 0;
    box-shadow: 0 0 14px var(--dl-purple-glow);
}

/* Nav section */
.admin-nav { padding: 0 0.5rem; }

.admin-nav-label {
    font-size: 0.63rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.13em;
    color: var(--dl-text-muted);
    padding: 0.3rem 0.65rem 0.4rem;
    font-family: 'Inter', 'Segoe UI', sans-serif;
}

.admin-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 0.62rem 0.85rem;
    color: var(--dl-text-dim);
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: 1px solid transparent;
    background: none;
    text-align: left;
    font-family: 'Inter', 'Segoe UI', sans-serif;
    margin-bottom: 2px;
    text-decoration: none;
}

.admin-nav-item:hover {
    background: var(--dl-surface);
    color: var(--dl-text);
    text-decoration: none;
}

.admin-nav-item.active {
    background: rgba(139,92,246,0.12);
    border-color: rgba(139,92,246,0.25);
    color: var(--dl-purple);
    box-shadow: 0 0 10px rgba(139,92,246,0.07);
}

.admin-nav-item.active i {
    filter: drop-shadow(0 0 6px var(--dl-purple-glow));
}

/* Sidebar footer */
.admin-sidebar-footer {
    padding: 0.65rem 0.5rem;
    border-top: 1px solid var(--dl-border);
    margin-top: auto;
}

/* Panel headings */
.admin-panel-header {
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--dl-border);
}

.admin-panel-title {
    font-size: 1.2rem;
    font-weight: 700;
    margin-bottom: 0.2rem;
}

.admin-panel-sub {
    color: var(--dl-text-dim);
    font-size: 0.875rem;
    margin-bottom: 0;
}

/* Panel visibility */
.admin-panel { display: none; }
.admin-panel.active { display: block; animation: fadeInUp 0.25s ease both; }

/* Utility text sizes */
.text-xs { font-size: 0.7rem; }
.text-sm { font-size: 0.875rem; }

/* Responsive — sidebar becomes a horizontal strip */
@media (max-width: 991.98px) {
    .admin-layout {
        flex-direction: column;
        min-height: auto;
    }

    .admin-sidebar {
        width: 100%;
        height: auto;
        max-height: none;
        position: static; /* not sticky on mobile */
        border-right: none;
        border-bottom: 1px solid var(--dl-border);
    }

    .admin-nav {
        display: flex;
        flex-wrap: wrap;
        gap: 4px;
        padding: 0.5rem;
    }

    .admin-nav-item { width: auto; flex: 0 0 auto; }
    .admin-nav-label { display: none; }
    .admin-sidebar-footer { padding: 0.5rem; border-top: none; }

    .admin-main { padding: 1rem; }
}


/* ============================================================
   BIBLE READER
   Premium reading experience with annotations.
   ============================================================ */

/* Controls card */
.br-controls-card {
    background: var(--dl-bg-2) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 16px !important;
}

/* Compact form labels */
.br-label {
    display: block;
    font-size: .72rem;
    font-weight: 700;
    color: var(--dl-text-dim);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: .3rem;
}

/* Styled selects / inputs inside reader controls */
.br-select,
.br-select.form-select,
.br-select.form-control {
    background: var(--dl-bg-3) !important;
    border: 1px solid var(--dl-border) !important;
    color: var(--dl-text) !important;
    border-radius: 9px !important;
    font-size: .875rem;
    transition: border-color .2s, box-shadow .2s;
}
.br-select:focus {
    border-color: var(--dl-border-glow) !important;
    box-shadow: 0 0 0 3px rgba(139,92,246,.2) !important;
    outline: none;
}
.br-select option      { background: #0e0e1a; color: var(--dl-text); }
.br-select optgroup    { color: var(--dl-text-dim); font-size: .78rem; }

/* Reference label (bold book/chapter display) */
.br-ref-label {
    font-family: 'Playfair Display', 'Georgia', serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--dl-gold);
    letter-spacing: .01em;
}

/* Sidebar cards */
.br-sidebar-card {
    background: var(--dl-bg-2) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 16px !important;
}
.br-sidebar-header {
    border-bottom: 1px solid var(--dl-border) !important;
    padding: .9rem 1.1rem .75rem !important;
}
.br-sidebar-item {
    border-bottom: 1px solid var(--dl-border);
    transition: background .15s;
}
.br-sidebar-item:last-child { border-bottom: none; }
.br-sidebar-item:hover      { background: var(--dl-surface); }

/* Bottom nav separator */
.br-bottom-nav {
    border-top: 1px solid var(--dl-border);
}

/* -- Skeleton loader ----------------------------------- */
.br-skeleton-line {
    height: 1.1rem;
    background: linear-gradient(
        90deg,
        var(--dl-surface)   25%,
        var(--dl-surface-2) 50%,
        var(--dl-surface)   75%
    );
    background-size: 200% 100%;
    animation: brShimmer 1.6s ease-in-out infinite;
    border-radius: 6px;
    margin-bottom: .9rem;
}
@keyframes brShimmer {
    0%   { background-position:  200% 0; }
    100% { background-position: -200% 0; }
}

/* -- Reading area ------------------------------------- */
.br-reading-area {
    background: var(--dl-bg-2);
    border: 1px solid var(--dl-border);
    border-radius: 16px;
    padding: 2rem 2.5rem;
    min-height: 340px;
    transition: opacity .2s ease;
}
@media (max-width: 575px) {
    .br-reading-area { padding: 1.25rem 1rem; }
}
.br-loaded { animation: fadeInUp .28s ease both; }

/* Empty state */
.br-empty-state {
    text-align: center;
    padding: 3.5rem 1rem;
}

/* -- Individual verse --------------------------------- */
.br-verse {
    position: relative;
    padding: .6rem .5rem .6rem 0;
    border-radius: 10px;
    transition: background .15s ease;
}
.br-verse:hover { background: var(--dl-surface); }
.br-verse:hover .br-verse-actions {
    opacity: 1;
    pointer-events: auto;
}

/* Verse text � Playfair for premium readability */
.br-verse-body {
    font-family: 'Playfair Display', 'Georgia', serif;
    font-size: 1.2rem;
    line-height: 1.9;
    color: var(--dl-text);
}
@media (min-width: 768px) {
    .br-verse-body { font-size: 1.25rem; }
}

/* Superscript verse number */
.br-verse-num {
    font-family: 'Inter', sans-serif;
    font-size: .68em;
    font-weight: 700;
    color: var(--dl-gold);
    opacity: .7;
    vertical-align: super;
    line-height: 0;
    margin-right: .35em;
    user-select: none;
}

/* ============================================================
   Church White-Label Branding
   Applied via body.church-branded when a church branding row
   exists. Overrides the default purple palette with the
   church's --church-primary / --church-secondary colors.
   ============================================================ */

body.church-branded .sg-navbar {
    background: var(--church-primary, rgba(7,7,15,0.88)) !important;
    border-bottom-color: color-mix(in srgb, var(--church-primary, #8b5cf6) 45%, transparent) !important;
    box-shadow: 0 1px 0 color-mix(in srgb, var(--church-primary, #8b5cf6) 25%, transparent),
                0 4px 24px rgba(0,0,0,0.4);
}

body.church-branded .sg-navbar .navbar-brand {
    background: none;
    -webkit-background-clip: unset;
    -webkit-text-fill-color: #fff;
    background-clip: unset;
    color: #fff;
    filter: none;
}

body.church-branded .sg-navbar .nav-link.active {
    color: var(--church-secondary, #c8a84b) !important;
    background: color-mix(in srgb, var(--church-secondary, #c8a84b) 12%, transparent);
}

body.church-branded .sg-navbar .nav-link.active::after {
    background: var(--church-secondary, #c8a84b);
    box-shadow: 0 0 8px var(--church-secondary, #c8a84b);
}

body.church-branded .btn-sg-primary,
body.church-branded .btn-primary {
    background: var(--church-primary, var(--dl-purple)) !important;
    border-color: var(--church-primary, var(--dl-purple)) !important;
}

body.church-branded .btn-primary:hover,
body.church-branded .btn-sg-primary:hover {
    filter: brightness(1.12);
}

body.church-branded .btn-outline-primary {
    color: var(--dl-purple) !important;
    border-color: var(--dl-purple) !important;
}

body.church-branded .btn-outline-primary:hover {
    background: rgba(139,92,246,0.14) !important;
    color: #7c3aed !important;
}

body.church-branded .nav-tabs .nav-link.active {
    color: var(--church-primary, var(--dl-purple)) !important;
    border-bottom-color: var(--church-primary, var(--dl-purple)) !important;
}

body.church-branded .text-primary {
    color: var(--church-primary, var(--dl-purple)) !important;
}

body.church-branded .sg-card {
    border-top: 2px solid var(--church-primary, var(--dl-purple));
}

body.church-branded .sg-brand-icon,
body.church-branded .sg-brand-title {
    color: var(--church-primary, var(--dl-purple));
    -webkit-text-fill-color: var(--church-primary, var(--dl-purple));
    background: none;
}


/* Note dot indicator */
.br-note-dot {
    font-size: .45rem;
    color: var(--dl-purple);
    vertical-align: super;
    margin-left: .2em;
    cursor: pointer;
    opacity: .9;
    transition: opacity .15s;
}
.br-note-dot:hover { opacity: 1; }

/* Bookmarked verse — gold left stripe via ::before pseudo-element */
.br-bookmarked {
    padding-left: .65rem;
}
.br-bookmarked::before {
    content: '';
    position: absolute;
    left: 0; top: 4px; bottom: 4px;
    width: 3px;
    background: var(--dl-gold);
    border-radius: 2px;
}

/* -- Verse action buttons (appear on hover) ----------- */
.br-verse-actions {
    display: flex;
    align-items: center;
    gap: .3rem;
    margin-top: .35rem;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s ease;
}
/* Always visible on touch screens */
@media (max-width: 767px) {
    .br-verse-actions { opacity: 1; pointer-events: auto; }
}

.br-action-btn {
    background: transparent;
    border: 1px solid var(--dl-border);
    color: var(--dl-text-dim);
    border-radius: 7px;
    padding: .25rem .5rem;
    font-size: .78rem;
    line-height: 1;
    cursor: pointer;
    transition: all .15s;
}
.br-action-btn:hover {
    background: var(--dl-surface-2);
    color: var(--dl-text);
    border-color: var(--dl-border-glow);
}
/* Generic active (note / highlight) */
.br-action-btn.active {
    background: rgba(139,92,246,.14);
    border-color: rgba(139,92,246,.4);
    color: var(--dl-purple);
}
/* Bookmark active � gold */
.br-action-btn[data-action="bookmark"].active {
    background: rgba(245,158,11,.12);
    border-color: rgba(245,158,11,.4);
    color: var(--dl-gold);
}
/* Highlight active � green */
.br-action-btn[data-action="highlight"].active {
    background: rgba(16,185,129,.12);
    border-color: rgba(16,185,129,.4);
    color: var(--dl-success);
}

/* -- Highlight color overlays ------------------------ */
.br-hl-gold   { background: rgba(245,158,11,.13) !important; border-radius: 10px; }
.br-hl-green  { background: rgba(16,185,129,.13) !important; border-radius: 10px; }
.br-hl-blue   { background: rgba(6,182,212,.12)  !important; border-radius: 10px; }
.br-hl-purple { background: rgba(139,92,246,.14) !important; border-radius: 10px; }
.br-hl-red    { background: rgba(239,68,68,.11)  !important; border-radius: 10px; }

/* -- Floating color picker --------------------------- */
.br-color-picker {
    position: fixed;       /* fixed so it stays aligned regardless of scroll */
    z-index: 1065;
    background: rgba(10,10,22,.97);
    backdrop-filter: blur(16px);
    border: 1px solid var(--dl-border);
    border-radius: 12px;
    box-shadow: var(--dl-shadow-md);
}
.br-color-swatch {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,.2);
    cursor: pointer;
    transition: transform .15s, border-color .15s;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    flex-shrink: 0;
    padding: 0;
}
.br-color-swatch:hover {
    transform: scale(1.25);
    border-color: #fff;
}
.br-color-remove {
    background: var(--dl-surface-2) !important;
    border-color: var(--dl-border) !important;
    color: var(--dl-text-dim);
}

/* -- Note modal --------------------------------------- */
.br-modal-content {
    background: var(--dl-bg-2) !important;
    border-radius: 16px !important;
    color: var(--dl-text);
}

/* Navigation buttons */
.br-nav-btn {
    min-width: 72px;
    border-radius: 10px !important;
}

/* -- Verse number � tappable --------------------------- */
.br-verse-num {
    cursor: pointer;
    transition: opacity .15s, color .15s;
}
.br-verse-num:hover {
    opacity: 1 !important;
    color: var(--dl-gold-light);
}

/* -- Floating action pill ------------------------------ */
.br-verse-menu {
    position: fixed;
    z-index: 1065;
    background: rgba(8,8,20,.97);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--dl-border);
    border-radius: 50px;
    box-shadow: 0 4px 28px rgba(0,0,0,.65), 0 0 0 1px rgba(139,92,246,.12);
    display: flex;
    align-items: center;
    padding: .25rem .35rem;
    gap: 0;
    animation: brPopIn .12s ease both;
}
@keyframes brPopIn {
    from { opacity: 0; transform: translateY(-4px) scale(.96); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.br-vm-sep {
    width: 1px;
    height: 18px;
    background: var(--dl-border);
    flex-shrink: 0;
    margin: 0 .15rem;
}

.br-vm-btn {
    background: transparent;
    border: none;
    color: var(--dl-text-dim);
    border-radius: 50px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    cursor: pointer;
    transition: background .15s, color .15s;
    flex-shrink: 0;
    padding: 0;
}
.br-vm-btn:hover           { background: var(--dl-surface); color: var(--dl-text); }
.br-vm-btn.active-bookmark { color: var(--dl-gold); }
.br-vm-btn.active-highlight{ color: var(--dl-success); }
.br-vm-btn.active-note     { color: var(--dl-purple); }

/* Hide old action rows (now replaced by the pill) */
.br-verse-actions { display: none !important; }

/* Verse with a note — purple left stripe via ::after pseudo-element */
.br-has-note {
    padding-left: .65rem;
}
.br-has-note::after {
    content: '';
    position: absolute;
    left: 0; top: 4px; bottom: 4px;
    width: 3px;
    background: var(--dl-purple);
    border-radius: 2px;
}

/* Both bookmark + note — gold stripe + purple stripe with a 1px dark gap */
.br-bookmarked.br-has-note {
    padding-left: .95rem;
}
.br-bookmarked.br-has-note::before {
    left: 0;   /* gold at the very edge */
}
.br-bookmarked.br-has-note::after {
    left: 4px; /* purple offset: 3px gold + 1px gap */
}

/* --- Section Styles Accordion (#brand-sections) ----------- */
#brand-sections .accordion-item {
    background: var(--dl-surface) !important;
    border: 1px solid var(--dl-border) !important;
    border-radius: 12px !important;
    overflow: hidden;
}

#brand-sections .accordion-button {
    background: var(--dl-surface-2) !important;
    color: var(--dl-text) !important;
    font-size: 0.92rem;
    letter-spacing: 0.02em;
    box-shadow: none !important;
    border-radius: 12px !important;
    padding: 0.85rem 1.1rem;
    transition: background 0.2s ease;
}

#brand-sections .accordion-button:not(.collapsed) {
    background: linear-gradient(90deg, rgba(139,92,246,0.18) 0%, rgba(6,182,212,0.10) 100%) !important;
    color: var(--dl-text) !important;
    border-bottom: 1px solid var(--dl-border);
    border-radius: 12px 12px 0 0 !important;
}

#brand-sections .accordion-button::after {
    filter: invert(1) brightness(0.7);
}

#brand-sections .accordion-button:focus {
    box-shadow: 0 0 0 2px var(--dl-purple-glow) !important;
}

#brand-sections .accordion-body {
    background: rgba(10,10,20,0.55) !important;
    padding: 1.1rem 1.25rem;
    border-top: none;
}

#brand-sections .accordion-collapse {
    border: none;
}

/* gradient preview bar inside accordion */
#brand-sections .grad-preview {
    border-color: var(--dl-border) !important;
}
