/* ================================================================
   OptinConnect — Design System (app.css)
   Premium enterprise UI • Indigo/Violet palette • Glass morphism
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300..900;1,14..32,300..900&display=swap');

/* ── Design Tokens ──────────────────────────────────────────────── */
:root {
    /* Brand */
    --c-primary:        #4f46e5;
    --c-primary-light:  #6366f1;
    --c-primary-dark:   #4338ca;
    --c-accent:         #8b5cf6;

    /* Surfaces */
    --c-surface:        #ffffff;
    --c-surface-raised: #f8fafc;
    --c-border:         #e2e8f0;
    --c-border-subtle:  #f1f5f9;

    /* Text */
    --c-text-primary:   #0f172a;
    --c-text-secondary: #475569;
    --c-text-muted:     #94a3b8;

    /* Radii */
    --r-sm:  0.375rem;
    --r-md:  0.625rem;
    --r-lg:  0.875rem;
    --r-xl:  1.25rem;
    --r-2xl: 1.5rem;

    /* Shadows */
    --shadow-xs:   0 1px 2px 0 rgba(0,0,0,.05);
    --shadow-sm:   0 1px 3px 0 rgba(0,0,0,.10), 0 1px 2px -1px rgba(0,0,0,.10);
    --shadow-md:   0 4px 6px -1px rgba(0,0,0,.10), 0 2px 4px -2px rgba(0,0,0,.10);
    --shadow-lg:   0 10px 15px -3px rgba(0,0,0,.10), 0 4px 6px -4px rgba(0,0,0,.10);
    --shadow-xl:   0 20px 25px -5px rgba(0,0,0,.10), 0 8px 10px -6px rgba(0,0,0,.10);
    --shadow-glow: 0 0 0 3px rgba(99,102,241,.22);
    --shadow-card-hover: 0 12px 28px -6px rgba(79,70,229,.15), 0 4px 8px -3px rgba(79,70,229,.1);

    /* Transitions */
    --t-fast:   120ms cubic-bezier(0.4,0,0.2,1);
    --t-base:   200ms cubic-bezier(0.4,0,0.2,1);
    --t-slow:   350ms cubic-bezier(0.4,0,0.2,1);
    --t-spring: 400ms cubic-bezier(0.16,1,0.3,1);
}

html.dark {
    --c-primary:        #6366f1;
    --c-primary-light:  #818cf8;
    --c-primary-dark:   #4f46e5;
    --c-accent:         #a78bfa;

    --c-surface:        #0f172a;
    --c-surface-raised: #1e293b;
    --c-border:         #1e293b;
    --c-border-subtle:  #1e293b;

    --c-text-primary:   #f1f5f9;
    --c-text-secondary: #94a3b8;
    --c-text-muted:     #475569;

    --shadow-xs:   0 1px 2px 0 rgba(0,0,0,.3);
    --shadow-sm:   0 1px 3px 0 rgba(0,0,0,.4);
    --shadow-md:   0 4px 6px -1px rgba(0,0,0,.4);
    --shadow-lg:   0 10px 15px -3px rgba(0,0,0,.5);
    --shadow-xl:   0 20px 25px -5px rgba(0,0,0,.6);
    --shadow-card-hover: 0 12px 28px -6px rgba(99,102,241,.25);
}

/* ── Base Reset ─────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    font-feature-settings: 'cv02','cv03','cv04','cv11';
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* ── Card Component ─────────────────────────────────────────────── */
.glass-card {
    background:    var(--c-surface);
    border:        1px solid var(--c-border);
    border-radius: var(--r-xl);
    box-shadow:    var(--shadow-sm);
    transition:    transform var(--t-base), box-shadow var(--t-base), border-color var(--t-base);
}

.glass-card:hover {
    box-shadow:    var(--shadow-card-hover);
    border-color:  rgba(99,102,241,.2);
}

/* Stat card accent bar */
.stat-card {
    position: relative;
    overflow: hidden;
}
.stat-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0;
    width: 4px; height: 100%;
    background: linear-gradient(180deg, var(--c-primary-light), var(--c-accent));
    border-radius: 4px 0 0 4px;
    opacity: 0;
    transition: opacity var(--t-base);
}
.stat-card:hover::before { opacity: 1; }

/* ── Buttons ────────────────────────────────────────────────────── */
.btn-primary {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             0.4em;
    padding:         0.6rem 1.25rem;
    background:      linear-gradient(135deg, var(--c-primary-light) 0%, var(--c-primary-dark) 100%);
    color:           #fff;
    font-weight:     600;
    font-size:       0.875rem;
    letter-spacing:  0.01em;
    border-radius:   var(--r-md);
    border:          none;
    cursor:          pointer;
    text-decoration: none;
    box-shadow:      var(--shadow-xs), inset 0 1px 0 rgba(255,255,255,.15);
    transition:      all var(--t-base);
    user-select:     none;
    white-space:     nowrap;
    position:        relative;
    overflow:        hidden;
}
.btn-primary::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,.08) 0%, transparent 50%);
    pointer-events: none;
}
.btn-primary:hover {
    transform:   translateY(-1px);
    box-shadow:  0 4px 12px -2px rgba(79,70,229,.45), inset 0 1px 0 rgba(255,255,255,.15);
}
.btn-primary:active { transform: scale(0.975); box-shadow: none; }

.btn-secondary {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             0.4em;
    padding:         0.6rem 1.25rem;
    background:      var(--c-surface);
    color:           var(--c-text-primary);
    font-weight:     600;
    font-size:       0.875rem;
    letter-spacing:  0.01em;
    border-radius:   var(--r-md);
    border:          1px solid var(--c-border);
    cursor:          pointer;
    text-decoration: none;
    box-shadow:      var(--shadow-xs);
    transition:      all var(--t-base);
    user-select:     none;
    white-space:     nowrap;
}
.btn-secondary:hover {
    background:    var(--c-surface-raised);
    border-color:  #94a3b8;
    transform:     translateY(-1px);
    box-shadow:    var(--shadow-sm);
}
.btn-secondary:active { transform: scale(0.975); }

html.dark .btn-secondary {
    background:  #1e293b;
    color:       #f1f5f9;
    border-color:#334155;
}
html.dark .btn-secondary:hover {
    background:  #334155;
    border-color:#475569;
}

/* Danger variant */
.btn-danger {
    display:         inline-flex;
    align-items:     center;
    justify-content: center;
    gap:             0.4em;
    padding:         0.6rem 1.25rem;
    background:      linear-gradient(135deg, #f87171, #ef4444);
    color:           #fff;
    font-weight:     600;
    font-size:       0.875rem;
    border-radius:   var(--r-md);
    border:          none;
    cursor:          pointer;
    text-decoration: none;
    box-shadow:      var(--shadow-xs);
    transition:      all var(--t-base);
}
.btn-danger:hover { transform: translateY(-1px); box-shadow: 0 4px 12px -2px rgba(239,68,68,.4); }
.btn-danger:active { transform: scale(0.975); }

/* ── Global select reset (beats Tailwind CDN preflight) ─────────── */
select {
    -webkit-appearance: none;
    -moz-appearance:    none;
    appearance:         none;
}
select::-ms-expand { display: none; }

/* ── Form Elements ──────────────────────────────────────────────── */
.form-label {
    display:       block;
    font-size:     0.8125rem;
    font-weight:   500;
    color:         var(--c-text-secondary);
    margin-bottom: 0.35rem;
    letter-spacing: 0.01em;
}
html.dark .form-label { color: #94a3b8; }

.form-input {
    display:       block;
    width:         100%;
    padding:       0.625rem 0.875rem;
    background:    var(--c-surface);
    border:        1.5px solid var(--c-border);
    border-radius: var(--r-md);
    color:         var(--c-text-primary);
    font-size:     0.875rem;
    font-family:   inherit;
    transition:    border-color var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
    appearance:    none;
    -webkit-appearance: none;
}
.form-input::placeholder { color: var(--c-text-muted); }
.form-input:focus {
    outline:      none;
    border-color: var(--c-primary-light);
    box-shadow:   var(--shadow-glow);
    background:   var(--c-surface);
}
.form-input:hover:not(:focus) { border-color: #94a3b8; }

/* ── Select / Dropdown ──────────────────────────────────────────── */
select.form-input {
    cursor:             pointer;
    /* Kill native arrow on ALL browsers */
    -webkit-appearance: none;
    -moz-appearance:    none;
    appearance:         none;
    background-image:   url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%236366f1' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");
    background-repeat:  no-repeat;
    background-position:right 0.75rem center;
    background-size:    1.1rem;
    padding-right:      2.5rem;
    /* IE/Edge fallback – hides native arrow */
    background-clip:    padding-box;
}
/* Suppress IE arrow */
select.form-input::-ms-expand { display: none; }

/* Light-mode option colours */
select.form-input option {
    background: #ffffff;
    color:      #0f172a;
    padding:    4px 8px;
}

/* Dark mode select */
html.dark select.form-input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%23818cf8' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z'/%3E%3C/svg%3E");
}
html.dark select.form-input option {
    background: #1e293b;
    color:      #f1f5f9;
}

/* Accent border when focused */
select.form-input:focus {
    border-color: var(--c-primary-light);
    box-shadow:   0 0 0 3px rgba(99,102,241,.2);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%236366f1' d='M14.707 12.707a1 1 0 01-1.414 0L10 9.414l-3.293 3.293a1 1 0 01-1.414-1.414l4-4a1 1 0 011.414 0l4 4a1 1 0 010 1.414z'/%3E%3C/svg%3E");
}
html.dark select.form-input:focus {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='%23818cf8' d='M14.707 12.707a1 1 0 01-1.414 0L10 9.414l-3.293 3.293a1 1 0 01-1.414-1.414l4-4a1 1 0 011.414 0l4 4a1 1 0 010 1.414z'/%3E%3C/svg%3E");
}
textarea.form-input { resize: vertical; min-height: 90px; }

html.dark .form-input {
    background:   #0f172a;
    border-color: #334155;
    color:        #f8fafc;
}
html.dark .form-input::placeholder { color: #475569; }
html.dark .form-input:focus { border-color: var(--c-primary-light); box-shadow: 0 0 0 3px rgba(99,102,241,.25); }
html.dark .form-input:hover:not(:focus) { border-color: #475569; }

/* Input group with icon */
.input-icon-wrap { position: relative; }
.input-icon-wrap .form-input { padding-left: 2.6rem; }
.input-icon-wrap .input-icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--c-text-muted);
    pointer-events: none;
    width: 1.1rem;
    height: 1.1rem;
}

/* ── Navigation ─────────────────────────────────────────────────── */
.nav-link {
    font-size:       0.875rem;
    font-weight:     500;
    color:           var(--c-text-secondary);
    text-decoration: none;
    transition:      color var(--t-fast);
}
.nav-link:hover { color: var(--c-text-primary); }
html.dark .nav-link { color: #94a3b8; }
html.dark .nav-link:hover { color: #fff; }

/* Sidebar item — kept for legacy fallback; primary styles are in dashboard.php */
.sidebar-item {
    display:         flex;
    align-items:     center;
    gap:             0.625rem;
    padding:         0.55rem 0.75rem;
    border-radius:   0.625rem;
    font-size:       0.875rem;
    font-weight:     500;
    color:           #94a3b8;
    text-decoration: none;
    transition:      background .15s, color .15s;
    position:        relative;
    overflow:        hidden;
    cursor:          pointer;
    border:          none;
    background:      transparent;
    width:           100%;
    text-align:      left;
}
.sidebar-item:hover { background: rgba(255,255,255,.06); color: #f8fafc; }
.sidebar-item.active {
    background: rgba(99,102,241,.18);
    color: #a5b4fc;
    font-weight: 600;
}
.sidebar-item.active::before {
    content: '';
    position: absolute;
    left: 0; top: 20%; bottom: 20%;
    width: 3px;
    background: linear-gradient(180deg, #818cf8, #6366f1);
    border-radius: 0 3px 3px 0;
}

/* ── Status Badges ──────────────────────────────────────────────── */
%badge-base {
    display:        inline-flex;
    align-items:    center;
    padding:        0.2em 0.65em;
    border-radius:  999px;
    font-size:      0.7rem;
    font-weight:    600;
    letter-spacing: 0.04em;
    text-transform: capitalize;
    white-space:    nowrap;
}

.badge-emerald,.badge-green { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(16,185,129,.12);border:1px solid rgba(16,185,129,.3);color:#10b981; }
.badge-red    { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);color:#ef4444; }
.badge-yellow,.badge-amber { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(234,179,8,.1);border:1px solid rgba(234,179,8,.25);color:#ca8a04; }
.badge-blue   { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.25);color:#3b82f6; }
.badge-indigo { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(99,102,241,.1);border:1px solid rgba(99,102,241,.25);color:#6366f1; }
.badge-purple { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.25);color:#8b5cf6; }
.badge-slate  { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(100,116,139,.1);border:1px solid rgba(100,116,139,.25);color:#64748b; }
.badge-teal   { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(20,184,166,.1);border:1px solid rgba(20,184,166,.25);color:#0d9488; }
.badge-orange { display:inline-flex;align-items:center;padding:.2em .65em;border-radius:999px;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:capitalize;white-space:nowrap; background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25);color:#ea580c; }

html.dark .badge-emerald,.badge-green { color:#34d399; }
html.dark .badge-red    { color:#f87171; }
html.dark .badge-yellow,.badge-amber { color:#fbbf24; }
html.dark .badge-blue   { color:#60a5fa; }
html.dark .badge-indigo { color:#818cf8; }
html.dark .badge-purple { color:#a78bfa; }
html.dark .badge-slate  { color:#94a3b8; }
html.dark .badge-teal   { color:#2dd4bf; }
html.dark .badge-orange { color:#fb923c; }

/* ── Table ──────────────────────────────────────────────────────── */
.data-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
}
.data-table th {
    padding: 0.75rem 1.25rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--c-text-muted);
    border-bottom: 1px solid var(--c-border);
    text-align: left;
    white-space: nowrap;
}
.data-table td {
    padding: 0.875rem 1.25rem;
    vertical-align: middle;
    border-bottom: 1px solid var(--c-border-subtle);
    color: var(--c-text-primary);
}
.data-table tbody tr:last-child td { border-bottom: none; }
.data-table tbody tr {
    transition: background var(--t-fast);
}
.data-table tbody tr:hover { background: rgba(99,102,241,.03); }
html.dark .data-table tbody tr:hover { background: rgba(99,102,241,.06); }
html.dark .data-table th { color: #475569; border-color: #1e293b; }
html.dark .data-table td { border-color: #1e293b; }

/* ── Animations ─────────────────────────────────────────────────── */
@keyframes fade-in {
    from { opacity:0; transform:translateY(-6px); }
    to   { opacity:1; transform:translateY(0); }
}
@keyframes fade-in-up {
    from { opacity:0; transform:translateY(14px); }
    to   { opacity:1; transform:translateY(0); }
}
@keyframes slide-in-right {
    from { opacity:0; transform:translateX(24px); }
    to   { opacity:1; transform:translateX(0); }
}
@keyframes slide-in-down {
    from { opacity:0; transform:translateY(-14px); }
    to   { opacity:1; transform:translateY(0); }
}
@keyframes scale-in {
    from { opacity:0; transform:scale(.94); }
    to   { opacity:1; transform:scale(1); }
}
@keyframes indeterminate-progress {
    0%   { transform:translateX(-100%); }
    50%  { transform:translateX(0%); }
    100% { transform:translateX(100%); }
}
@keyframes pulse-slow {
    0%,100% { opacity:1; }
    50%      { opacity:.55; }
}
@keyframes shimmer {
    from { background-position: -200% 0; }
    to   { background-position:  200% 0; }
}

.animate-fade-in       { animation: fade-in      0.35s ease forwards; }
.animate-fade-in-up    { animation: fade-in-up   0.4s  cubic-bezier(.16,1,.3,1) forwards; }
.animate-slide-in-right{ animation: slide-in-right 0.3s cubic-bezier(.16,1,.3,1) forwards; }
.animate-slide-in-down { animation: slide-in-down 0.35s cubic-bezier(.16,1,.3,1) forwards; }
.animate-scale-in      { animation: scale-in     0.25s cubic-bezier(.16,1,.3,1) forwards; }
.animate-pulse         { animation: pulse-slow   2s ease-in-out infinite; }

/* Staggered children */
.animate-stagger > * {
    opacity: 0;
    animation: fade-in-up 240ms cubic-bezier(.16,1,.3,1) forwards;
}
.animate-stagger > *:nth-child(1)  { animation-delay: 40ms;  }
.animate-stagger > *:nth-child(2)  { animation-delay: 80ms;  }
.animate-stagger > *:nth-child(3)  { animation-delay: 120ms; }
.animate-stagger > *:nth-child(4)  { animation-delay: 160ms; }
.animate-stagger > *:nth-child(5)  { animation-delay: 200ms; }
.animate-stagger > *:nth-child(6)  { animation-delay: 240ms; }
.animate-stagger > *:nth-child(7)  { animation-delay: 280ms; }
.animate-stagger > *:nth-child(n+8){ animation-delay: 320ms; }

/* ── Page Loader ─────────────────────────────────────────────────── */
.page-loader {
    position:        fixed;
    top:             0; left: 0; right: 0;
    height:          3px;
    background:      linear-gradient(90deg, #6366f1, #a78bfa, #6366f1);
    background-size: 200% auto;
    z-index:         9999;
    transform-origin:left;
    animation:       indeterminate-progress 1.6s infinite ease-in-out,
                     shimmer 2s linear infinite;
    pointer-events:  none;
    opacity:         0;
    transition:      opacity 200ms ease;
}
.page-loader.active { opacity: 1; }

/* ── Scrollbar ───────────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #e2e8f0; border-radius: 9999px; }
::-webkit-scrollbar-thumb:hover { background: #cbd5e1; }
html.dark ::-webkit-scrollbar-thumb       { background: #334155; }
html.dark ::-webkit-scrollbar-thumb:hover { background: #475569; }

/* ── Backgrounds ─────────────────────────────────────────────────── */
.bg-mesh {
    background-color: #f8fafc;
    background-image:
        radial-gradient(at 27% 37%, hsla(215,98%,61%,.06) 0, transparent 50%),
        radial-gradient(at 97% 21%, hsla(265,98%,72%,.08) 0, transparent 50%),
        radial-gradient(at 52% 99%, hsla(254,98%,72%,.06) 0, transparent 50%),
        radial-gradient(at 10% 29%, hsla(235,82%,65%,.06) 0, transparent 50%),
        radial-gradient(at 97% 96%, hsla(281,98%,72%,.06) 0, transparent 50%);
}
html.dark .bg-mesh {
    background-color: #020617;
    background-image:
        radial-gradient(at 27% 37%, hsla(215,98%,61%,.08) 0, transparent 50%),
        radial-gradient(at 97% 21%, hsla(265,98%,72%,.06) 0, transparent 50%),
        radial-gradient(at 52% 99%, hsla(254,98%,72%,.05) 0, transparent 50%),
        radial-gradient(at 10% 29%, hsla(235,82%,65%,.05) 0, transparent 50%);
}

.bg-grid-subtle {
    background-image:
        linear-gradient(rgba(99,102,241,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(99,102,241,.04) 1px, transparent 1px);
    background-size: 40px 40px;
}
html.dark .bg-grid-subtle {
    background-image:
        linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
}

/* ── Custom Confirm Modal ────────────────────────────────────────── */
#lc-confirm-overlay {
    position:         fixed;
    inset:            0;
    z-index:          9998;
    display:          flex;
    align-items:      center;
    justify-content:  center;
    padding:          1rem;
    background:       rgba(15,23,42,.6);
    backdrop-filter:  blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity:          0;
    transition:       opacity 200ms ease;
    pointer-events:   none;
}
#lc-confirm-overlay.open { opacity: 1; pointer-events: all; }
#lc-confirm-box {
    background:    var(--c-surface);
    border:        1px solid var(--c-border);
    border-radius: var(--r-xl);
    box-shadow:    var(--shadow-xl);
    padding:       1.75rem;
    width:         100%;
    max-width:     420px;
    transform:     scale(.94) translateY(8px);
    transition:    transform var(--t-spring), box-shadow var(--t-spring);
}
#lc-confirm-overlay.open #lc-confirm-box { transform: scale(1) translateY(0); }

/* ── Divider ─────────────────────────────────────────────────────── */
.divider {
    display: flex;
    align-items: center;
    gap: 1rem;
    color: var(--c-text-muted);
    font-size: 0.75rem;
}
.divider::before,.divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--c-border);
}

/* ── Skeleton Loader ─────────────────────────────────────────────── */
.skeleton {
    background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%);
    background-size: 200% auto;
    border-radius: var(--r-md);
    animation: shimmer 1.5s linear infinite;
}
html.dark .skeleton {
    background: linear-gradient(90deg, #1e293b 25%, #334155 50%, #1e293b 75%);
    background-size: 200% auto;
}

/* ── Tooltip ─────────────────────────────────────────────────────── */
[data-tooltip] { position: relative; }
[data-tooltip]::after {
    content:          attr(data-tooltip);
    position:         absolute;
    bottom:           calc(100% + 6px);
    left:             50%;
    transform:        translateX(-50%);
    background:       #1e293b;
    color:            #f8fafc;
    font-size:        0.7rem;
    font-weight:      500;
    white-space:      nowrap;
    padding:          0.3em 0.7em;
    border-radius:    var(--r-sm);
    pointer-events:   none;
    opacity:          0;
    transition:       opacity var(--t-fast);
    z-index:          50;
}
[data-tooltip]:hover::after { opacity: 1; }

/* ── Utility overrides ───────────────────────────────────────────── */
.text-gradient {
    background: linear-gradient(135deg, var(--c-primary-light), var(--c-accent));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* Spinner inside buttons */
.btn-primary.is-loading,
.btn-secondary.is-loading {
    opacity: .75;
    cursor: not-allowed;
    pointer-events: none;
}
