/* ══════════════════════════════════════════════════════════════
   Slepnex — Közös design tokens és alapstílusok
   Logo paletta: lime → teal → navy
   Light mód az alap. Dark mód később toggle-lel.
   ══════════════════════════════════════════════════════════════ */

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
    /* Logo paletta */
    --lime:        #a8f078;
    --lime-bright: #8eea7a;
    --teal:        #30c0a8;
    --teal-dark:   #189078;
    --teal-light:  #5fd3a3;
    --cyan:        #41bcce;
    --navy:        #003060;
    --navy-mid:    #1e3a6b;

    /* DARK (sidebar + login bal panel) */
    --dark-bg:      #0a0f1f;
    --dark-bg2:     #0f1629;
    --dark-card:    #141c33;
    --dark-card-2:  #1a2340;
    --dark-border:  #1e293b;
    --dark-border2: #2a3855;
    --dark-text:    #f1f5f9;
    --dark-text-mid:#94a3b8;
    --dark-text-dim:#64748b;

    /* LIGHT (alap) */
    --bg:           #f8faf7;
    --bg-2:         #eef5ec;
    --bg-3:         #e4ede1;
    --card:         #ffffff;
    --border:       #e4eae2;
    --border-2:     #d4dcd1;
    --text:         #0f172a;
    --text-mid:     #475569;
    --text-dim:     #64748b;

    /* Alias változók — egyes moduloknál külön nevek vannak használva.
       Itt összekötjük őket a fő változókkal, hogy a téma egységes legyen. */
    --surface:      var(--card);
    --surface-2:    var(--bg-2);
    --card-bg:      var(--card);
    --card-bg-alt:  var(--bg-2);
    --hover-bg:     var(--bg-2);
    --text-muted:   var(--text-mid);
    --text-soft:    var(--text-dim);
    --border-strong:var(--border-2);
    --gradient-lime:linear-gradient(135deg, var(--lime) 0%, var(--lime-bright) 100%);
    --dark-bg3:     #1a2340;

    /* Semantic */
    --success:  #189078;
    --warning:  #a16207;
    --danger:   #dc2626;
    --info:     #0e8fa8;

    /* Gradients */
    --gradient-primary: linear-gradient(135deg, #8eea7a 0%, #5fd3a3 35%, #30c0a8 65%, #1e3a6b 100%);
    --gradient-text:    linear-gradient(135deg, #8eea7a 0%, #5fd3a3 50%, #41bcce 100%);
    --gradient-btn:     linear-gradient(135deg, #189078 0%, #30c0a8 50%, #1e3a6b 100%);
    --gradient-btn-dark:linear-gradient(135deg, #a8f078 0%, #5fd3a3 100%);

    /* Shadows */
    --shadow-sm:  0 1px 3px rgba(0,48,96,.08);
    --shadow:     0 2px 8px rgba(0,48,96,.08), 0 1px 3px rgba(0,48,96,.06);
    --shadow-md:  0 4px 16px rgba(0,48,96,.10);
    --shadow-lg:  0 12px 40px rgba(0,48,96,.12);
    --glow-teal:  0 0 20px rgba(48,192,168,.3);
    --glow-lime:  0 0 16px rgba(168,240,120,.35);

    /* Radius */
    --radius-sm: 6px;
    --radius:    10px;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;

    /* Fonts */
    --font-display: 'Sora', -apple-system, BlinkMacSystemFont, sans-serif;
    --font:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono:    'JetBrains Mono', ui-monospace, Consolas, monospace;
}

/* ══════════════════════════════════════════════════════════════
   DARK MODE — fő változók felülírása
   Amikor html[data-theme="dark"], a --bg, --card, --text stb. mind
   dark színekre vált. Mivel az alias változók (--surface, --card-bg,
   --text-muted stb.) a fő változókra hivatkoznak, automatikusan
   minden modul-CSS dark módra vált.
   ══════════════════════════════════════════════════════════════ */
html[data-theme="dark"] {
    --bg:           var(--dark-bg);
    --bg-2:         var(--dark-bg2);
    --bg-3:         var(--dark-card-2);
    --card:         var(--dark-card);
    --border:       var(--dark-border);
    --border-2:     var(--dark-border2);
    --text:         var(--dark-text);
    --text-mid:     var(--dark-text-mid);
    --text-dim:     var(--dark-text-dim);

    /* Alias változók is automatikusan átveszik a dark értékeket */
    --surface:      var(--dark-card);
    --surface-2:    var(--dark-bg2);
    --card-bg:      var(--dark-card);
    --card-bg-alt:  var(--dark-bg2);
    --hover-bg:     var(--dark-card-2);
    --text-muted:   var(--dark-text-mid);
    --text-soft:    var(--dark-text-dim);
    --border-strong:var(--dark-border2);

    /* Shadow visszafogás dark módban (fekete háttéren a sötét árnyék nem látszik) */
    --shadow-sm:    0 1px 3px rgba(0,0,0,.3);
    --shadow:       0 2px 8px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.2);
    --shadow-md:    0 4px 16px rgba(0,0,0,.35);
    --shadow-lg:    0 12px 40px rgba(0,0,0,.4);
}

html, body {
    font-family: var(--font);
    font-size: 15px;
    line-height: 1.6;
    color: var(--text);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}

/* ── TYPO ──────────────────────────────────────────────────── */
h1, h2, h3, h4 { font-family: var(--font-display); letter-spacing: -.3px; color: var(--text); }
a { color: var(--teal-dark); text-decoration: none; }
a:hover { color: var(--teal); }

/* ── BUTTONS — Slepnex unified button system ─────────────────
   7 variáns, minden szerep fix:
     .btn--primary   = gradient teal-navy → Mentés / lezárás modalban
     .btn--dark      = fekete → Új entitás flow (+ Új X, lista fejléc)
     .btn--lime      = neon zöld → Rendszer akció (backup, rbar +)
     .btn--warm      = narancs → Ritka nagyobb akció (napi mentés, bulk archive)
     .btn--danger    = piros → Törlés / destruktív
     .btn--secondary = fehér outline → Másodlagos (szerkesztés, export)
     .btn--ghost     = átlátszó → Mégse / vissza
   Minden modul ezt használja — NINCS többé pr-btn/cl-btn/bk-btn/pf-btn/se-btn.
   ─────────────────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 7px;
    padding: 0 16px; height: 38px;
    font-size: 13px; font-weight: 600; font-family: var(--font, inherit);
    border: 1px solid transparent; border-radius: 10px;
    cursor: pointer; transition: all .15s;
    line-height: 1; white-space: nowrap; letter-spacing: -.01em;
    text-decoration: none;
}
.btn:disabled, .btn.is-disabled { opacity: .5; cursor: not-allowed; pointer-events: none; }
.btn .i { width: 15px; height: 15px; flex-shrink: 0; }

/* 1. PRIMARY — gradient teal-navy (Mentés) */
.btn--primary {
    background: var(--gradient-btn, linear-gradient(135deg, #189078 0%, #30c0a8 50%, #1e3a6b 100%));
    color: #fff; border-color: transparent;
    box-shadow: 0 2px 10px rgba(48,192,168,.25);
}
.btn--primary:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(48,192,168,.35);
    color: #fff;
}

/* 2. DARK — fekete (+ Új X) */
.btn--dark {
    background: var(--text, #0f172a);
    color: #fff;
    border-color: var(--text, #0f172a);
}
.btn--dark:hover { background: #1e293b; border-color: #1e293b; color: #fff; }

/* 3. LIME — neon zöld (rendszer akció) */
.btn--lime {
    background: var(--lime, #a8f078);
    color: var(--navy, #003060);
    border-color: var(--lime, #a8f078);
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
    font-weight: 700;
}
.btn--lime:hover {
    background: var(--lime-bright, #8eea7a);
    border-color: var(--lime-bright, #8eea7a);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(168,240,120,.35);
}

/* 4. WARM — narancs-sárga (ritka nagyobb akció) */
.btn--warm {
    background: #fbbf24;
    color: #451a03;
    border-color: #fbbf24;
    box-shadow: 0 1px 3px rgba(0,0,0,.06);
    font-weight: 700;
}
.btn--warm:hover {
    background: #f59e0b;
    border-color: #f59e0b;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(251,191,36,.35);
}

/* 5. DANGER — piros (törlés) */
.btn--danger {
    background: #fef2f2;
    color: var(--danger, #dc2626);
    border-color: rgba(220,38,38,.3);
}
.btn--danger:hover {
    background: #fee2e2;
    border-color: var(--danger, #dc2626);
}

/* 6. SECONDARY — fehér outline (másodlagos) */
.btn--secondary {
    background: var(--card, #fff);
    color: var(--text, #0f172a);
    border-color: var(--border-2, #d4dcd1);
}
.btn--secondary:hover {
    border-color: var(--text-dim, #94a3b8);
    color: var(--text, #0f172a);
}

/* 7. GHOST — átlátszó (Mégse) */
.btn--ghost {
    background: transparent;
    color: var(--text-mid, #475569);
    border-color: transparent;
}
.btn--ghost:hover {
    background: var(--bg-2, #eef5ec);
    color: var(--text, #0f172a);
}

/* Size variációk */
.btn--sm { height: 32px; padding: 0 12px; font-size: 12.5px; }
.btn--lg { height: 44px; padding: 0 20px; font-size: 14.5px; }

/* Dark mode adaptáció */
html[data-theme="dark"] .btn--secondary {
    background: var(--dark-card, #141c33);
    color: var(--dark-text, #f1f5f9);
    border-color: var(--dark-border2, #2a3855);
}
html[data-theme="dark"] .btn--secondary:hover {
    border-color: var(--dark-text-mid, #94a3b8);
}
html[data-theme="dark"] .btn--ghost { color: var(--dark-text-mid, #94a3b8); }
html[data-theme="dark"] .btn--ghost:hover { background: rgba(255,255,255,.06); color: var(--dark-text, #f1f5f9); }
html[data-theme="dark"] .btn--dark {
    background: var(--dark-card-2, #1a2340);
    border-color: var(--dark-border2, #2a3855);
}
html[data-theme="dark"] .btn--dark:hover {
    background: var(--dark-border2, #2a3855);
}
html[data-theme="dark"] .btn--danger {
    background: rgba(220,38,38,.1);
    border-color: rgba(220,38,38,.35);
}

/* ── LEGACY — megtartva kompatibilitás okán, de új kódban .btn--X használandó ── */
.btn-primary { background: var(--gradient-btn); color: #fff;
               box-shadow: 0 2px 10px rgba(48,192,168,.25), 0 0 0 1px rgba(48,192,168,.2); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(48,192,168,.35), 0 0 0 1px rgba(48,192,168,.3); }

.btn-secondary { background: var(--card); color: var(--text); border: 1px solid var(--border-2); }
.btn-secondary:hover { border-color: var(--teal); color: var(--teal-dark); }

.btn-ghost { background: transparent; color: var(--text-mid); }
.btn-ghost:hover { background: var(--bg-2); color: var(--text); }

.btn-danger { background: #fef2f2; color: var(--danger); border: 1px solid #fecaca; }
.btn-danger:hover { background: #fee2e2; }

.btn-lg { padding: 13px 20px; font-size: 15px; border-radius: var(--radius); }

/* ── FORM ──────────────────────────────────────────────────── */
.fld { margin-bottom: 16px; }
.fld-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 6px; }
.lbl { display: block; font-size: 12.5px; font-weight: 600; color: var(--text-mid); letter-spacing: .02em; }
.inp-wrap { position: relative; }
.inp {
    width: 100%; padding: 12px 14px; font-size: 14.5px; font-family: var(--font);
    color: var(--text); background: var(--card); border: 1.5px solid var(--border-2);
    border-radius: var(--radius); outline: none; transition: all .15s;
}
.inp.has-icon { padding-left: 42px; }
.inp:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(48,192,168,.12); }
.inp::placeholder { color: var(--text-dim); }
.inp-ico { position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
           color: var(--text-dim); font-size: 15px; pointer-events: none; }

/* ── CARD ──────────────────────────────────────────────────── */
.card { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-md);
        overflow: hidden; box-shadow: var(--shadow-sm); }

.card-header { display: flex; align-items: center; justify-content: space-between;
               padding: 14px 18px; border-bottom: 1px solid var(--border); }
.card-title { font-size: 13.5px; font-weight: 700; color: var(--text); letter-spacing: -.2px; }
.card-link  { font-size: 11.5px; color: var(--teal-dark); font-weight: 600; text-decoration: none; }
.card-link:hover { color: var(--teal); }
.card-body { padding: 18px; }

/* ── BADGE ─────────────────────────────────────────────────── */
.badge { display: inline-block; padding: 2px 9px; border-radius: 20px;
         font-size: 10.5px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase; }
.badge-ok    { background: rgba(24,144,120,.12); color: var(--teal-dark); border: 1px solid rgba(24,144,120,.3); }
.badge-info  { background: rgba(65,188,206,.12); color: var(--info);     border: 1px solid rgba(65,188,206,.3); }
.badge-warn  { background: rgba(234,179,8,.12);  color: var(--warning);  border: 1px solid rgba(234,179,8,.3); }
.badge-err   { background: #fef2f2;              color: var(--danger);   border: 1px solid #fecaca; }
.badge-gray  { background: var(--bg-2);          color: var(--text-mid); border: 1px solid var(--border); }

/* ── STATUS — Slepnex unified status system ───────────────────
   6 variáns, egységesen minden modulban:
     .status--ok       = zöld → Aktív, OK, Kész
     .status--pending  = sárga → Függőben, Folyamatban
     .status--expired  = piros → Lejárt, Hibás, Elutasítva
     .status--archived = szürke → Archivált, Inaktív, Lezárt
     .status--info     = kék → Info, Új, Lead, Elküldve
     .status--prospect = lila → Érdeklődő, Prospect

   + .status-pill = filter tab verzió (Clients/Products szűrő fejléc)
   ─────────────────────────────────────────────────────────── */
.status {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 11.5px;
    font-weight: 600;
    letter-spacing: 0.01em;
    line-height: 1.4;
    white-space: nowrap;
}
.status .dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }

.status--ok        { background: rgba(24,144,120,.12); color: #189078; }
.status--ok .dot   { background: #189078; }

.status--pending       { background: #fef3c7; color: #a16207; }
.status--pending .dot  { background: #a16207; }

.status--expired       { background: #fef2f2; color: #dc2626; }
.status--expired .dot  { background: #dc2626; }

.status--archived      { background: #f1f5f9; color: #64748b; }
.status--archived .dot { background: #9ca3af; }

.status--info      { background: rgba(59,130,246,.12); color: #2563eb; }
.status--info .dot { background: #3b82f6; }

.status--prospect      { background: rgba(139,92,246,.12); color: #7c3aed; }
.status--prospect .dot { background: #8b5cf6; }

/* Dark mode */
html[data-theme="dark"] .status--ok        { background: rgba(24,144,120,.18); color: #6ee7b7; }
html[data-theme="dark"] .status--ok .dot   { background: #6ee7b7; }
html[data-theme="dark"] .status--pending   { background: rgba(245,158,11,.18); color: #fcd34d; }
html[data-theme="dark"] .status--pending .dot { background: #fcd34d; }
html[data-theme="dark"] .status--expired   { background: rgba(220,38,38,.18); color: #fca5a5; }
html[data-theme="dark"] .status--expired .dot { background: #fca5a5; }
html[data-theme="dark"] .status--archived  { background: rgba(100,116,139,.18); color: #cbd5e1; }
html[data-theme="dark"] .status--archived .dot { background: #94a3b8; }
html[data-theme="dark"] .status--info      { background: rgba(59,130,246,.18); color: #93c5fd; }
html[data-theme="dark"] .status--info .dot { background: #93c5fd; }
html[data-theme="dark"] .status--prospect  { background: rgba(139,92,246,.18); color: #c4b5fd; }
html[data-theme="dark"] .status--prospect .dot { background: #c4b5fd; }

/* ── STATUS PILL — filter tab verzió ─── */
.status-pill {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12.5px;
    font-weight: 500;
    background: var(--card, #fff);
    color: var(--text-mid, #475569);
    border: 1px solid var(--border-2, #d4dcd1);
    cursor: pointer;
    transition: all .15s;
    text-decoration: none;
    white-space: nowrap;
}
.status-pill:hover {
    border-color: var(--text-dim, #94a3b8);
    color: var(--text, #0f172a);
}
.status-pill .dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--text-dim, #94a3b8);
    flex-shrink: 0;
}
.status-pill .count {
    font-size: 11px; font-weight: 600;
    color: var(--text-mid, #64748b);
    background: var(--bg-2, #eef5ec);
    padding: 1px 7px; border-radius: 10px;
    margin-left: 2px;
}

/* Pill dot variációk — ugyanazok a színek mint a status-ban */
.status-pill.p-ok       .dot { background: #189078; }
.status-pill.p-pending  .dot { background: #a16207; }
.status-pill.p-expired  .dot { background: #dc2626; }
.status-pill.p-archived .dot { background: #9ca3af; }
.status-pill.p-info     .dot { background: #3b82f6; }
.status-pill.p-prospect .dot { background: #8b5cf6; }

/* Active state — pill kitöltve sötét háttérrel (pl. "Mind" szűrő vagy választott státusz) */
.status-pill.on {
    background: var(--text, #0f172a);
    color: #fff;
    border-color: var(--text, #0f172a);
}
.status-pill.on .count {
    background: rgba(255,255,255,.22);
    color: #fff;
}

/* Dark mode */
html[data-theme="dark"] .status-pill {
    background: var(--dark-card, #141c33);
    color: var(--dark-text-mid, #94a3b8);
    border-color: var(--dark-border2, #2a3855);
}
html[data-theme="dark"] .status-pill:hover {
    color: var(--dark-text, #f1f5f9);
    border-color: var(--dark-text-mid, #94a3b8);
}
html[data-theme="dark"] .status-pill .count {
    background: rgba(255,255,255,.08);
    color: var(--dark-text-mid, #94a3b8);
}
html[data-theme="dark"] .status-pill.on {
    background: var(--lime, #a8f078);
    color: var(--navy, #003060);
    border-color: var(--lime, #a8f078);
}
html[data-theme="dark"] .status-pill.on .count {
    background: rgba(0,48,96,.2);
    color: var(--navy, #003060);
}

/* ── TABLE ─────────────────────────────────────────────────── */
.tbl { width: 100%; font-size: 13px; border-collapse: collapse; }
.tbl th { text-align: left; padding: 10px 18px; font-size: 10.5px;
          font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
          color: var(--text-dim); background: var(--bg-2); border-bottom: 1px solid var(--border); }
.tbl td { padding: 12px 18px; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.tbl td b { color: var(--text); font-weight: 600; }
.tbl tr:last-child td { border-bottom: none; }
.tbl tr:hover td { background: var(--bg-2); }

/* ── ALERT ─────────────────────────────────────────────────── */
.alert { padding: 12px 16px; border-radius: var(--radius); font-size: 14px;
         border-left: 3px solid; margin-bottom: 16px; line-height: 1.55; }
.alert-err  { background: #fef2f2; border-left-color: var(--danger);
              color: #7f1d1d; border: 1px solid #fecaca; border-left-width: 3px; }
.alert-ok   { background: #f0fdf4; border-left-color: #10b981;
              color: #14532d; border: 1px solid #bbf7d0; border-left-width: 3px; }
.alert-info { background: #eef5ec; border-left-color: var(--teal);
              color: var(--navy); border: 1px solid var(--border-2); border-left-width: 3px; }
.alert-warn { background: #fffbeb; border-left-color: #f59e0b;
              color: #78350f; border: 1px solid #fde68a; border-left-width: 3px; }

/* ── LOGO SVG (inline horse) ───────────────────────────────── */
.logo-svg { display: inline-block; }

/* Utility */
.mt-4  { margin-top: 16px; }
.mb-4  { margin-bottom: 16px; }
.mt-8  { margin-top: 32px; }
.mb-8  { margin-bottom: 32px; }
.text-center { text-align: center; }
.text-muted  { color: var(--text-mid); }
.text-dim    { color: var(--text-dim); }
.text-sm     { font-size: 13px; }
.text-xs     { font-size: 11.5px; }

/* ════════════════════════════════════════════════════════════════
   STAT-GRID — rendszer-szintű komponens (modulok közötti egységes
   stat-kártya megjelenítéshez). Több oldal használja: cron-status,
   commissions, coupons-stripe, disputes-stripe, webhook-events.
   Modul-specifikus duplikációk (.cs-stat a cron-status.css-ben és
   coupons-stripe.css-ben) ezzel ki vannak váltva.
   ════════════════════════════════════════════════════════════════ */
.cs-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}

.cs-stat {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 12px 14px;
}

.cs-stat-l {
    font-size: 11px;
    color: var(--text-mid);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 4px;
}

.cs-stat-v {
    font-size: 22px;
    font-weight: 600;
    color: var(--text);
    line-height: 1.2;
}

.cs-stat--ok {
    background: rgba(16, 185, 129, 0.06);
    border-color: rgba(16, 185, 129, 0.25);
}
.cs-stat--ok .cs-stat-v { color: #15803d; }

.cs-stat--warn {
    background: rgba(245, 158, 11, 0.08);
    border-color: rgba(245, 158, 11, 0.3);
}
.cs-stat--warn .cs-stat-v { color: #c2750b; }

.cs-stat--late {
    background: rgba(220, 38, 38, 0.06);
    border-color: rgba(220, 38, 38, 0.25);
}
.cs-stat--late .cs-stat-v { color: #dc2626; }

.cs-stat--neutral {
    background: var(--bg-2);
    border-color: var(--border);
}

/* Dark mode */
html[data-theme="dark"] .cs-stat {
    background: var(--dark-card);
    border-color: var(--dark-border);
}
html[data-theme="dark"] .cs-stat-l { color: var(--dark-text-mid); }
html[data-theme="dark"] .cs-stat-v { color: var(--dark-text); }
html[data-theme="dark"] .cs-stat--ok .cs-stat-v { color: #34d399; }
html[data-theme="dark"] .cs-stat--warn .cs-stat-v { color: #fbbf24; }
html[data-theme="dark"] .cs-stat--late .cs-stat-v { color: #f87171; }
html[data-theme="dark"] .cs-stat--neutral { background: var(--dark-bg3); }
/* ════════════════════════════════════════════════════════════════
   SLEPNEX — DARK MODE GLOBAL OVERRIDES
   ════════════════════════════════════════════════════════════════
   Ez a fájl felülírja a modul-CSS fájlokban hardcode-olt világos
   színeket, amik dark módban nem cserélődtek le.

   Architektúra:
   - app.css → :root + html[data-theme="dark"] változók (alapok)
   - modul.css fájlok → többségük var() használ, jól vált
   - dark-overrides.css (ez) → kizárólag a maradék hardcode-olt
     fehér/világos foltok dark megfelelője

   Ezt a fájlt MINDIG az app.css UTÁN, és a modul-CSS fájlok UTÁN
   kell betölteni, hogy a CSS specifity (cascade) érvényesüljön.

   Verzió: 1.0 (6/E utáni alapos átfésülés)
   ════════════════════════════════════════════════════════════════ */

html[data-theme="dark"] {

    /* ─── PRODUCTS modul ─────────────────────────────────────────
       A products.php tábla, modal, toggle és bulk action gombok */
    .pr-table thead {
        background: var(--dark-bg2);
        border-bottom-color: var(--dark-border);
    }
    .pr-table tbody tr:hover {
        background: var(--dark-card-2);
    }
    .pr-modal-foot {
        background: var(--dark-bg2);
    }
    .pr-stripe-compact {
        background: var(--dark-bg2);
    }
    .pr-toggle-track {
        background: var(--dark-border2);
    }
    .pr-toggle-track::after {
        background: var(--dark-text);
    }
    .pr-src-sel,
    .pr-btn--secondary {
        background: var(--dark-card);
        color: var(--dark-text);
        border-color: var(--dark-border2);
    }
    .pr-btn--secondary:hover {
        background: var(--dark-card-2);
    }
    .pr-search-clear:hover {
        background: var(--dark-card-2);
    }
    .pr-bulk-btn--danger:hover {
        background: rgba(220,38,38,.15);
    }
    .pr-row-popup a.danger:hover {
        background: rgba(220,38,38,.15);
    }
    .pr-modal-close:hover {
        background: var(--dark-card-2);
    }
    .pr-tpl-badge {
        background: rgba(139,92,246,.15);
        color: #c4b5fd;
    }
    .pr-stripe-status.pending {
        background: rgba(245,158,11,.15);
        color: #fcd34d;
    }
    #pr-form .has-error:focus {
        background: rgba(220,38,38,.10);
    }

    /* ─── TASKS modul ───────────────────────────────────────────
       Kanban oszlopok, tábla, chip-ek */
    .col {
        background: var(--dark-card);
    }
    .col-add:hover {
        background: var(--dark-card-2);
    }
    .c-meta .mchip {
        background: var(--dark-bg2);
    }
    .c-meta .mchip.cli {
        background: rgba(24,95,165,.20);
        border-color: rgba(24,95,165,.35);
        color: #93c5fd;
    }
    .tbl-head {
        background: var(--dark-bg2);
    }
    .tbl-row:hover {
        background: var(--dark-card-2);
    }
    .bulk .acts button {
        background: var(--dark-card);
        color: var(--dark-text);
    }
    .m-top .m-check:hover {
        background: rgba(16,185,129,.15);
    }
    .color-none {
        background: rgba(220,38,38,.12);
    }
    .m-row:hover {
        background: var(--dark-card-2);
    }
    .m-chip {
        background: rgba(48,192,168,.15);
        color: #6ee7b7;
    }
    .cmt-item {
        background: var(--dark-bg2);
        border-color: var(--dark-border);
    }
    .dd-menu a.danger:hover {
        background: rgba(220,38,38,.15);
    }
    .m-add-field:hover,
    .upload-btn:hover,
    .pt-btn.active {
        background: var(--dark-card-2);
    }

    /* ─── CLIENTS modul (Ügyfelek) ──────────────────────────────
       Avatar színek, dropdown items, mini gombok */
    .cl-avatar {
        background: rgba(99,102,241,.20);
    }
    .cl-avatar--individual,
    .cx-avatar--individual {
        background: rgba(236,72,153,.20);
    }
    .cl-f select:disabled {
        background: var(--dark-bg2);
        color: var(--dark-text-dim);
    }
    .sel-item.is-selected {
        background: rgba(48,192,168,.15);
        color: var(--dark-text);
    }
    .cx-dr-pending {
        background: rgba(59,130,246,.12);
    }
    .cx-dr-opened {
        background: rgba(245,158,11,.12);
        border-color: rgba(245,158,11,.30);
    }
    .cx-dr-submitted {
        background: rgba(16,185,129,.12);
    }
    .cx-stripe-record-actions .btn-mini {
        background: var(--dark-card);
        color: var(--dark-text);
        border-color: var(--dark-border2);
    }
    .cx-stripe-record-actions .btn-mini:hover {
        background: var(--dark-card-2);
    }

    /* ─── SC-BULK (Stripe bulk action bar) ──────────────────────
       Az ügyfelek és customers oldalakon a tömeges akció bar */
    .sc-bulk-bar {
        background: rgba(48,192,168,.12);
        border-color: rgba(48,192,168,.25);
    }
    .sc-bulk-btn {
        background: var(--dark-card);
        color: var(--dark-text);
        border-color: var(--dark-border2);
    }
    .sc-bulk-btn:hover {
        background: var(--dark-card-2);
    }
    .sc-bulk-btn--danger {
        border-color: rgba(220,38,38,.4);
    }
    .sc-bulk-btn--danger:hover {
        background: rgba(220,38,38,.15);
        border-color: rgba(220,38,38,.6);
    }
    .sc-bulk-btn--ghost:hover {
        border-color: var(--dark-border2);
    }
    .sc-table tbody tr.sc-row-selected:hover {
        background: rgba(48,192,168,.18);
    }

    /* ─── CUSTOMERS-STRIPE alerts ───────────────────────────────
       (a vörös és sárga riasztások már részben dark-ok, finomítjuk) */
    .alert-err {
        background: rgba(220,38,38,.12);
        border-color: rgba(220,38,38,.30);
        color: #fca5a5;
    }
    .alert-warn {
        background: rgba(245,158,11,.12);
        border-color: rgba(245,158,11,.30);
        color: #fcd34d;
    }

    /* ─── SETTINGS-EMAIL ────────────────────────────────────────
       Status card-ok (OK/warn) */
    .se-status-card.is-ok {
        background: rgba(16,185,129,.12);
        border-color: rgba(16,185,129,.30);
    }
    .se-status-card.is-warn {
        background: rgba(245,158,11,.12);
        border-color: rgba(245,158,11,.30);
        color: #fcd34d;
    }
    .se-warn {
        background: rgba(245,158,11,.12);
        border-color: rgba(245,158,11,.30);
        color: #fcd34d;
    }

    /* ─── SETTINGS-STRIPE alerts ────────────────────────────────*/
    .alert-warn {
        background: rgba(245,158,11,.12);
        color: #fcd34d;
    }
    /* .alert-err: már fent definiálva */

    /* ─── SHELL — dropdown és quick create ─────────────────────
       A right rail és sidebar dropdown menük + quick-create hover */
    .qc-item:hover:not(:disabled) {
        background: var(--dark-card-2);
    }
    .user-dd-item.danger:hover {
        background: rgba(220,38,38,.15);
    }

    /* ─── FLASH üzenetek (shell-v4.css) ─────────────────────────
       Felső flash bar — light, dark verziókban */
    .flash-ok {
        background: rgba(16,185,129,.12);
        color: #6ee7b7;
        border-color: rgba(16,185,129,.30);
    }
    .flash-err {
        background: rgba(220,38,38,.12);
        color: #fca5a5;
        border-color: rgba(220,38,38,.30);
    }
    .flash-warn {
        background: rgba(245,158,11,.12);
        color: #fcd34d;
        border-color: rgba(245,158,11,.30);
    }

    /* ─── WEBHOOK EVENTS ────────────────────────────────────────*/
    .we-payload {
        background: var(--dark-bg);
        color: var(--dark-text);
        border-color: var(--dark-border);
    }
    /* webhook-events.css 369: .we-* osztály amelyik #fafbf9-t használ */

    /* ─── Skeleton loading animáció ─────────────────────────────*/
    .skel {
        background: linear-gradient(90deg, var(--dark-bg2) 0%, var(--dark-card) 50%, var(--dark-bg2) 100%);
        background-size: 200% 100%;
    }

    /* ─── BTN--DANGER (app.css-ben hardcode #fef2f2 háttér) ────
       A piros gomb light módban világos piros háttér + sötét piros szöveg.
       Dark módban: átlátszó piros háttér + világos piros szöveg. */
    .btn--danger {
        background: rgba(220,38,38,.15);
        border-color: rgba(220,38,38,.40);
        color: #fca5a5;
    }
    .btn--danger:hover {
        background: rgba(220,38,38,.25);
        border-color: rgba(220,38,38,.60);
        color: #fecaca;
    }
}

/* ════════════════════════════════════════════════════════════
   .slx-bulk-bar — KÖZÖS CSOPORTOS MŰVELETEK BAR (globális)
   Használat: minden listán ahol bulk-műveletek kellenek.
   HTML-minta:
     <div class="slx-bulk-bar">
       <div class="slx-bulk-bar__count"><strong>N</strong> elem kijelölve</div>
       <div class="slx-bulk-bar__dropdown">
         <button class="slx-bulk-bar__btn">Státusz váltása ▾</button>
         <div class="slx-bulk-bar__menu">
           <div class="slx-bulk-bar__menu-item">...</div>
         </div>
       </div>
       <button class="slx-bulk-bar__btn">Duplikálás</button>
       <button class="slx-bulk-bar__btn slx-bulk-bar__btn--danger">Törlés</button>
       <button class="slx-bulk-bar__close">×</button>
     </div>
   ════════════════════════════════════════════════════════════ */
.slx-bulk-bar{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--card,var(--surface,#fff));border:1px solid var(--border,#e4eae2);border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.18);padding:11px 16px;display:flex;align-items:center;gap:10px;z-index:500;max-width:calc(100vw - 40px);font-size:13px;color:var(--text,#0f172a);}
.slx-bulk-bar__count{font-size:13px;color:var(--text,#0f172a);padding-right:10px;border-right:1px solid var(--border,#e4eae2);margin-right:4px;white-space:nowrap;}
.slx-bulk-bar__count strong{color:var(--teal-dark,#189078);font-weight:700;font-size:14px;margin-right:4px;}
.slx-bulk-bar__btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;background:var(--bg-2,#eef5ec);border:1px solid var(--border,#e4eae2);border-radius:8px;font-size:12.5px;color:var(--text,#0f172a);font-weight:600;cursor:pointer;font-family:inherit;transition:all .12s;white-space:nowrap;}
.slx-bulk-bar__btn:hover:not(:disabled){background:var(--card,var(--surface,#fff));border-color:var(--teal,#30c0a8);color:var(--teal-dark,#189078);}
.slx-bulk-bar__btn:disabled{opacity:.5;cursor:not-allowed;}
.slx-bulk-bar__btn svg{width:14px;height:14px;flex-shrink:0;}
.slx-bulk-bar__btn--danger:hover:not(:disabled){background:rgba(220,38,38,.08);border-color:rgba(220,38,38,.30);color:var(--danger,#dc2626);}
.slx-bulk-bar__dropdown{position:relative;}
.slx-bulk-bar__menu{display:none;position:absolute;bottom:calc(100% + 6px);left:0;background:var(--card,var(--surface,#fff));border:1px solid var(--border,#e4eae2);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);min-width:200px;padding:4px;z-index:600;}
.slx-bulk-bar__dropdown.is-open .slx-bulk-bar__menu{display:block;}
.slx-bulk-bar__menu-item{display:flex;align-items:center;gap:9px;padding:8px 11px;border-radius:5px;font-size:12.5px;color:var(--text,#0f172a);cursor:pointer;user-select:none;}
.slx-bulk-bar__menu-item:hover{background:var(--bg-2,#eef5ec);}
.slx-bulk-bar__dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0;}
.slx-bulk-bar__close{background:none;border:none;cursor:pointer;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-meta,#6b7280);border-radius:6px;margin-left:4px;flex-shrink:0;}
.slx-bulk-bar__close:hover{background:rgba(220,38,38,.08);color:var(--danger,#dc2626);}
.slx-bulk-bar__close svg{width:14px;height:14px;}

/* Sor-kijelölés vizuális kiemelés (közös bármely táblán) */
.slx-row-selected{background:rgba(48,192,168,.10) !important;box-shadow:inset 3px 0 0 var(--teal,#30c0a8);}
.slx-row-selected:hover{background:rgba(48,192,168,.16) !important;}

/* Master + per-row checkbox közös stílus */
.slx-bulk-check{width:18px;height:18px;cursor:pointer;accent-color:var(--teal,#30c0a8);margin:0;vertical-align:middle;}

/* Sötét mód */
html[data-theme="dark"] .slx-bulk-bar{background:var(--card,var(--surface));box-shadow:0 12px 40px rgba(0,0,0,.50);}
html[data-theme="dark"] .slx-bulk-bar__btn{background:rgba(255,255,255,.04);}
html[data-theme="dark"] .slx-bulk-bar__btn:hover:not(:disabled){background:rgba(255,255,255,.08);border-color:var(--teal,#30c0a8);}
html[data-theme="dark"] .slx-bulk-bar__menu{background:var(--card,var(--surface));box-shadow:0 8px 24px rgba(0,0,0,.45);}
html[data-theme="dark"] .slx-bulk-bar__menu-item:hover{background:rgba(255,255,255,.06);}
html[data-theme="dark"] .slx-row-selected{background:rgba(48,192,168,.16) !important;}
