/* ── Témy ─────────────────────────────────────────────────── */
:root {
  --bg:       #0f1117;
  --surface:  #161920;
  --surface2: #1e2230;
  --nav:      #1a1d27;
  --border:   #2a2d38;
  --border2:  #374151;
  --muted2:   #4b5563;
  --muted:    #6b7280;
  --secondary:#9ca3af;
  --text:     #e8e8e8;
  --white:    #ffffff;
  --accent:   #f5a623;
  --accentOn: #0f1117;
  --hdr-bg:   #161920;
  --green:    #22c55e;
  --greenBg:  #1e2a1e;
  --dev-done-bg:     #111a0f;
  --dev-done-border: #1e3318;
  --dev-done-text:   #4b7a3f;
  --red:      #ef4444;
  --kpi-green-bg: #0d1f14;
  --indigo:   #6366f1;
  --indigo-bg: rgba(99,102,241,.08);
  --indigo-border: rgba(99,102,241,.2);
  --orange-dark: #1a1208;
  --dark-row: #0a0c12;
  --overlay:  rgba(0,0,0,.75);
  --overlay-light: rgba(0,0,0,.7);
  --greenBorder: rgba(34,197,94,.27);
  --red-bg:   rgba(127,29,29,.15);
  --red-border: #7f1d1d;
}

[data-theme="grey"] {
  --bg:       #2a2d35;
  --surface:  #32363f;
  --surface2: #3a3e48;
  --nav:      #3a3e48;
  --border:   #4a4e5a;
  --border2:  #555a68;
  --muted2:   #9ca3af;
  --muted:    #9ca3af;
  --secondary:#c4c9d4;
  --text:     #e2e5ec;
  --white:    #f0f2f7;
  --accent:   #f5a623;
  --accentOn: #0f1117;
  --hdr-bg:   #1f2128;
  --green:    #22c55e;
  --greenBg:  #1e2d20;
  --dev-done-bg:     #1a2b18;
  --dev-done-border: #2a4226;
  --dev-done-text:   #5a9050;
  --red:      #ef4444;
  --kpi-green-bg: #1e2d20;
  --indigo:   #6366f1;
  --indigo-bg: rgba(99,102,241,.1);
  --indigo-border: rgba(99,102,241,.25);
  --orange-dark: #2a2010;
  --dark-row: #1e2028;
  --overlay:  rgba(0,0,0,.75);
  --overlay-light: rgba(0,0,0,.7);
  --greenBorder: rgba(34,197,94,.27);
  --red-bg:   rgba(127,29,29,.2);
  --red-border: #7f1d1d;
}

[data-theme="chastia"] {
  --bg:       #eef1f5;
  --surface:  #ffffff;
  --surface2: #f1f5f9;
  --nav:      #f0f4f8;
  --border:   #d1d5db;
  --border2:  #e2e8f0;
  --muted2:   #6b7280;
  --muted:    #64748b;
  --secondary:#4b5563;
  --text:     #1e293b;
  --white:    #0f172a;
  --accent:   #f5a623;
  --accentOn: #0f1117;
  --hdr-bg:   #004379;
  --green:    #16a34a;
  --greenBg:  #dcfce7;
  --dev-done-bg:     #f0fdf4;
  --dev-done-border: #bbf7d0;
  --dev-done-text:   #15803d;
  --red:      #dc2626;
  --kpi-green-bg: #f0fdf4;
  --indigo:   #4f46e5;
  --indigo-bg: rgba(79,70,229,.06);
  --indigo-border: rgba(79,70,229,.18);
  --orange-dark: #fff7ed;
  --dark-row: #f8fafc;
  --overlay:  rgba(0,0,0,.6);
  --overlay-light: rgba(0,0,0,.5);
  --greenBorder: rgba(22,163,74,.27);
  --red-bg:   rgba(220,38,38,.08);
  --red-border: #fca5a5;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { height: 100%; overflow-x: hidden; }
html, html { font-size: 16px; }
body { height: 100%; }
body { background: var(--bg); font-family: 'IBM Plex Sans','Segoe UI',sans-serif; color: var(--text); min-height: 100vh; overflow-y: auto; overflow-x: hidden; -webkit-overflow-scrolling: touch; touch-action: pan-y; }
body.pin-mode { overflow: hidden; }
header { background: var(--hdr-bg); border-bottom: 1px solid var(--border); padding: 20px 0; position: sticky; top: 0; z-index: 200; }
.header-inner { max-width: 900px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 12px; }
.badge { font-size: 10px; font-weight: 700; letter-spacing: .12em; color: var(--accent); margin-bottom: 4px; text-transform: uppercase; }
h1 { font-size: 20px; font-weight: 700; color: var(--white); letter-spacing: -.01em; overflow-wrap: break-word; word-break: break-word; }
.subtitle { font-size: 13px; color: var(--muted); margin-top: 4px; text-transform: capitalize; }
.session-info { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; width: 100%; }
.session-info .nav-btns { flex: 1; min-width: 0; }
.header-row1 { display: flex; align-items: center; justify-content: space-between; gap: 8px; width: 100%; }
.mobile-header-actions { display: none; }
#headerRight { display: flex; flex-direction: column; gap: 8px; width: 100%; min-width: 0; }
.firma-chip { background: var(--surface2); border: 1px solid var(--border); border-radius: 8px; padding: 6px 14px; font-size: 13px; font-weight: 600; color: #f5a623; white-space: nowrap; }
.logout-btn { background: transparent; border: 1px solid var(--border2); color: var(--muted); padding: 6px 12px; border-radius: 8px; cursor: pointer; font-size: 12px; font-family: inherit; white-space: nowrap; }
.logout-btn:hover { border-color: #ef4444; color: #ef4444; }
    /* ── Desktop nav — skupinové ghost-border tlačidlá ── */
    .nav-btns { display: none; }
    .nav-btns-desk { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
    .nav-group { position: relative; }
    .nav-group-btn { display: flex; align-items: center; gap: 6px; padding: 5px 11px; border-radius: 7px; border: 1.5px solid transparent; background: transparent; color: var(--secondary); font-size: 13px; font-weight: 400; cursor: pointer; font-family: inherit; white-space: nowrap; transition: border-color .14s, color .14s, background .14s; }
    .nav-group-btn:hover { border-color: var(--border2); color: var(--text); }
    .nav-group-btn.active { border-color: var(--accent); color: var(--accent); font-weight: 500; }
    .nav-group-btn.nav-group-open { border-color: var(--accent); color: var(--accent); }
    .nav-group-btn svg { flex-shrink: 0; }
    .nav-chevron { opacity: .5; transition: transform .15s; }
    .nav-group-btn.nav-group-open .nav-chevron { transform: rotate(180deg); }
    .nav-dropdown { position: absolute; top: calc(100% + 5px); left: 0; background: var(--surface); border: 1px solid var(--border2); border-radius: 10px; min-width: 175px; overflow: hidden; z-index: 400; transform-origin: top left; transform: translateY(-6px) scale(.96); opacity: 0; pointer-events: none; transition: transform .17s cubic-bezier(.34,1.4,.64,1), opacity .13s ease; }
    .nav-dropdown.nav-dropdown-open { transform: translateY(0) scale(1); opacity: 1; pointer-events: all; }
    .nav-gear-dropdown { left: auto; right: 0; transform-origin: top right; }
    .nav-drop-item { display: flex; align-items: center; gap: 9px; padding: 8px 13px; width: 100%; font-size: 13px; color: var(--text); background: transparent; border: none; cursor: pointer; font-family: inherit; text-align: left; transition: background .1s; }
    .nav-drop-item:hover { background: var(--surface2); }
    .nav-drop-item svg { flex-shrink: 0; color: var(--muted); }
    .nav-drop-sep { height: 1px; background: var(--border); border: none; margin: 3px 0; }
    .nav-icon-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 7px; border: 1px solid var(--border2); background: transparent; color: var(--secondary); cursor: pointer; transition: all .13s; font-family: inherit; flex-shrink: 0; }
    .nav-icon-btn:hover { border-color: var(--muted2); color: var(--text); background: var(--surface2); }
    .nav-icon-btn.active { border-color: var(--accent); color: var(--accent); }
    .nav-icon-btn.nav-group-open { border-color: var(--accent); color: var(--accent); background: var(--surface2); }
    .nav-icon-btn-danger:hover { border-color: var(--red) !important; color: var(--red) !important; }
    .nav-role-chip { font-size: 12px; font-weight: 500; color: var(--accent); padding: 4px 10px; border-radius: 6px; border: 1px solid var(--border); background: var(--surface2); white-space: nowrap; }
    .nav-btn { background: transparent; border: 1.5px solid transparent; color: var(--secondary); padding: 5px 11px; border-radius: 7px; cursor: pointer; font-size: 13px; font-weight: 400; display: flex; align-items: center; gap: 6px; transition: all .14s; font-family: inherit; white-space: nowrap; flex-shrink: 0; }
    .nav-btn:hover { border-color: var(--border2); color: var(--text); }
    .nav-btn.active { border-color: var(--accent); color: var(--accent); font-weight: 500; }
.pill { background: var(--accent); color: var(--accentOn); border-radius: 99px; padding: 1px 7px; font-size: 11px; font-weight: 700; }
.fab { position: fixed; bottom: 85px; right: 20px; width: 56px; height: 56px; background: #2a3a52; color: #fff; border-radius: 16px; display: none; align-items: center; justify-content: center; font-size: 28px; box-shadow: 0 4px 12px rgba(0,0,0,0.3); border: 1px solid rgba(255,255,255,0.1); cursor: pointer; z-index: 100; }
body:not(.pin-mode) .fab.visible { display: flex; }
main { max-width: 900px; margin: 0 auto; padding: 32px 24px 64px; width: 100%; box-sizing: border-box; transform: none; }
main.main-fullwidth { max-width: 100%; padding: 0 8px 16px; }
main:has(#viewSumarPrac:not(.hidden)) { max-width: 100%; }
/* ── Login screen redesign ─────────────────────────────────── */
.pin-wrap {
  display: flex; align-items: center; justify-content: center;
  min-height: 100dvh; width: 100%;
  position: fixed; top: 0; left: 0;
  background: #0b0e14;
  z-index: 10; padding: 16px; box-sizing: border-box;
  overflow-y: auto; overflow-x: hidden;
}
/* Animated particle canvas */
#loginBgCanvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 0; opacity: .55;
}
/* Grid overlay */
.pin-grid-overlay {
  position: fixed; inset: 0;
  background-image:
    linear-gradient(rgba(245,166,35,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,166,35,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none; z-index: 1;
}
/* Glow orbs */
.pin-orb {
  position: fixed; border-radius: 50%; filter: blur(90px);
  pointer-events: none; z-index: 1;
  animation: pinOrbFloat 9s ease-in-out infinite;
}
.pin-orb1 { width: 450px; height: 450px; background: rgba(245,166,35,.065); top: -120px; right: -120px; animation-delay: 0s; }
.pin-orb2 { width: 320px; height: 320px; background: rgba(30,45,80,.45); bottom: -80px; left: -80px; animation-delay: -4.5s; }
@keyframes pinOrbFloat {
  0%,100% { transform: translate(0,0) scale(1); }
  50%      { transform: translate(18px,-18px) scale(1.06); }
}
.pin-card {
  position: relative; z-index: 10;
  background: rgba(18,21,30,.92);
  border: 1px solid rgba(245,166,35,.16);
  border-radius: 24px;
  padding: 40px 36px 32px;
  width: 100%; max-width: 388px;
  text-align: center;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 0 0 1px rgba(245,166,35,.05), 0 32px 80px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.04);
  animation: pinCardIn .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes pinCardIn {
  from { opacity: 0; transform: translateY(22px) scale(.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);   }
}
/* Logo row inside card */
.pin-logo-row {
  display: flex; align-items: center; justify-content: center; gap: 13px;
  margin-bottom: 12px;
}
.pin-logo-icon {
  width: 42px; height: 42px;
  background: linear-gradient(135deg, #f5a623, #e8870a);
  border-radius: 11px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 18px rgba(245,166,35,.38);
}
.pin-logo-wordmark { font-size: 26px; font-weight: 700; letter-spacing: -.02em; color: #fff; line-height: 1; }
.pin-logo-wordmark span { color: #f5a623; }
.pin-tagline {
  font-size: 11px; font-weight: 500; letter-spacing: .1em;
  text-transform: uppercase; color: rgba(245,166,35,.6);
  margin-bottom: 24px;
}
.pin-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245,166,35,.18), transparent);
  margin-bottom: 24px;
}
.pin-icon { display: none; }
.pin-title { display: none; }
.pin-desc {
  font-size: 12px; color: rgba(255,255,255,.35);
  margin-bottom: 22px; line-height: 1.6;
}
.pin-dots { display: flex; justify-content: center; gap: 14px; margin-bottom: 20px; }
.pin-dot {
  width: 13px; height: 13px; border-radius: 50%;
  border: 2px solid rgba(255,255,255,.15); background: transparent;
  transition: all .2s cubic-bezier(.22,1,.36,1);
}
.pin-dot.filled {
  background: var(--accent); border-color: var(--accent);
  box-shadow: 0 0 10px rgba(245,166,35,.5);
  transform: scale(1.12);
}
.pin-dot.pin-error-dot { background: #ef4444; border-color: #ef4444; animation: pinShake .3s ease; }
@keyframes pinShake {
  0%,100% { transform: translateX(0); }
  25%      { transform: translateX(-4px); }
  75%      { transform: translateX(4px); }
}
.pin-pad { display: grid; grid-template-columns: repeat(3,1fr); gap: 9px; margin-bottom: 8px; }
.pin-key {
  background: rgba(28,32,46,.85);
  border: 1px solid rgba(255,255,255,.07);
  color: var(--white); border-radius: 14px;
  padding: 0; height: 58px;
  font-size: 20px; font-weight: 600; cursor: pointer;
  transition: all .12s; font-family: inherit;
  position: relative; overflow: hidden;
}
.pin-key:hover { background: rgba(40,46,66,.9); border-color: rgba(245,166,35,.28); transform: scale(1.03); }
.pin-key:active { background: rgba(245,166,35,.14); border-color: var(--accent); transform: scale(.97); }
.pin-key::after {
  content:''; position:absolute; width:100%; height:100%; top:0; left:0;
  background: radial-gradient(circle, rgba(245,166,35,.2) 0%, transparent 70%);
  opacity:0; transition:opacity .25s;
}
.pin-key:active::after { opacity:1; }
.pin-key.del { color: rgba(255,255,255,.35); font-size: 17px; }
.pin-key.del:hover { color: #ef4444; border-color: rgba(239,68,68,.3); }
.pin-key.empty { visibility: hidden; }
.pin-error { color: #ef4444; font-size: 12px; min-height: 18px; margin-top: 4px; font-weight: 500; }
/* ── Desktop split-screen layout ──────────────────────────── */

/* Full-page sparse background canvas — musí byť mimo pin-wrap */
#loginBgPageCanvas {
  position: fixed; inset: 0; width: 100%; height: 100%;
  pointer-events: none; z-index: 11; opacity: .28;
}

/* pin-left / pin-right hidden on mobile */
.pin-left  { display: none; }
.pin-right { display: contents; }

@media (min-width: 860px) {
  .pin-left  { display: flex; }
  .pin-right { display: flex; }
  /* Príchodové/odchodové tlačidlá — PC: vpravo vedľa textu */
  .skupina-row { flex-wrap: nowrap; align-items: center; }
  .rzac-btns { width: auto; flex-shrink: 0; margin-left: 8px; }
  .rzac-btns .realizacia-btn { width: auto; min-width: 90px; }

  .pin-wrap {
    padding: 0;
    align-items: stretch;
    justify-content: stretch;
    overflow: hidden;
    position: fixed; /* zachovaj fixed */
  }

  /* Left panel — branding + dense particle canvas */
  .pin-left {
    flex: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: #070a0f;
    padding: 48px;
  }
  /* Dense particle canvas lives inside left panel */
  #loginBgCanvas {
    position: absolute; inset: 0; width: 100%; height: 100%;
    opacity: .6;
  }
  .pin-grid-overlay { position: absolute; }
  .pin-orb { position: absolute; }
  .pin-orb1 { top: -80px; right: -80px; }
  .pin-orb2 { bottom: -60px; left: -60px; }

  /* Right panel — na desktop: plávajúci PIN v pravom hornom rohu */
  .pin-right {
    position: absolute;
    top: 24px;
    right: 28px;
    width: 260px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 0;
    background: none;
    border-left: none;
    overflow: visible;
    z-index: 20;
  }
  .pin-card {
    width: 100%;
    max-width: 260px;
    border-radius: 16px;
    padding: 20px 18px 16px;
    animation: pinCardIn 1.1s .4s cubic-bezier(.22,1,.36,1) both;
    background: rgba(14,17,26,.88);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    border: 1px solid rgba(245,166,35,.15);
    box-shadow: 0 8px 32px rgba(0,0,0,.5);
  }
  /* PIN desc skryť — zbytočný text v malom boxe */
  .pin-card .pin-desc { display: none; }
  /* Tlačidlá skryť na desktop */
  #webauthnLoginBtn { display: none !important; }
  .pin-card > div[style*="margin-top:16px"] { display: none !important; }
  #appDownloadSection { display: none !important; }
  /* Menšie PIN klávesy */
  .pin-key { height: 44px; font-size: 16px; border-radius: 10px; }
  .pin-dots { margin-bottom: 14px; }
  .pin-dot { width: 10px; height: 10px; }
  .pin-pad { gap: 7px; margin-bottom: 6px; }

  /* Left panel content — fills full panel height, truly centred */
  .pin-left-content {
    position: relative; z-index: 5;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    width: 100%; height: 100%;
    flex: 1;
  }
  .pin-left-logo {
    display: flex; align-items: center; justify-content: center;
    gap: 16px; margin-bottom: 14px;
    animation: pinFadeUp 1s .2s cubic-bezier(.22,1,.36,1) both;
  }
  .pin-left-logo-icon {
    width: 56px; height: 56px;
    background: linear-gradient(135deg, #f5a623, #e8870a);
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 6px 28px rgba(245,166,35,.45);
    flex-shrink: 0;
  }
  .pin-left-wordmark {
    font-size: 38px; font-weight: 700; letter-spacing: -.03em;
    color: #fff; line-height: 1;
    font-family: 'IBM Plex Sans', sans-serif;
  }
  .pin-left-wordmark span { color: #f5a623; }
  .pin-left-tagline {
    font-size: 11px; font-weight: 600; letter-spacing: .14em;
    text-transform: uppercase; color: rgba(245,166,35,.55);
    margin-bottom: 40px;
    animation: pinFadeUp 1s .35s cubic-bezier(.22,1,.36,1) both;
  }
  @keyframes pinFadeUp {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .pin-features {
    display: flex; flex-direction: column; gap: 0;
    width: 100%; max-width: 320px;
  }
  .pin-feature {
    display: flex; align-items: center; gap: 16px;
    background: none; border: none; border-radius: 0;
    border-bottom: 1px solid rgba(255,255,255,.07);
    padding: 13px 0; text-align: left;
    animation: featureIn 1.4s cubic-bezier(.22,1,.36,1) both;
  }
  .pin-feature:last-child { border-bottom: none; }
  .pin-feature:nth-child(1) { animation-delay: .9s; }
  .pin-feature:nth-child(2) { animation-delay: 1.2s; }
  .pin-feature:nth-child(3) { animation-delay: 1.5s; }
  @keyframes featureIn {
    from { opacity: 0; transform: translateX(-22px); }
    to   { opacity: 1; transform: translateX(0); }
  }
  .pin-feature-icon {
    width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 13px;
  }
  .pin-feature-icon.fi-orange { background: rgba(245,166,35,.1); border-radius: 50%; }
  .pin-feature-icon.fi-blue   { background: rgba(60,120,200,.1); border-radius: 50%; }
  .pin-feature-icon.fi-green  { background: rgba(34,197,94,.08); border-radius: 50%; }
  .pin-feature-body { flex: 1; }
  .pin-feature-title { font-size: 13px; font-weight: 600; color: rgba(255,255,255,.85); margin-bottom: 2px; }
  .pin-feature-sub   { font-size: 11px; color: rgba(255,255,255,.28); line-height: 1.4; }

  .pin-left-footer {
    position: absolute; bottom: 24px; left: 0; right: 0;
    text-align: center; z-index: 5;
    font-size: 10px; color: rgba(255,255,255,.15);
    letter-spacing: .08em;
  }

  /* Hide logo/tagline from card on desktop */
  .pin-logo-row  { display: none; }
  .pin-tagline   { display: none; }
  .pin-divider   { display: none; }
}

/* Responsive: small screens scroll */
@media (max-height: 680px) and (max-width: 859px) {
  .pin-wrap { align-items: flex-start; padding: 12px; }
  .pin-card  { padding: 28px 22px 22px; }
  .pin-key   { height: 50px; font-size: 18px; }
}
@media (max-width: 400px) {
  .pin-card  { padding: 32px 18px 24px; border-radius: 20px; }
  .pin-key   { height: 54px; font-size: 18px; }
}
.card { background: var(--surface); box-sizing: border-box; border-radius: 16px; border: 1px solid var(--border); padding: 32px; }
.card-title { font-size: 20px; font-weight: 700; color: var(--white); margin-bottom: 4px; }
.card-desc { font-size: 13px; color: var(--muted); margin-bottom: 28px; }
.row { display: flex; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.field { display: flex; flex-direction: column; gap: 6px; flex: 1; min-width: 180px; }
label { font-size: 12px; font-weight: 600; color: var(--secondary); letter-spacing: .05em; text-transform: uppercase; }
.req { color: var(--accent); }
input, select, textarea { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 10px 14px; color: var(--text); font-size: 14px; outline: none; transition: border-color .2s; width: 100%; font-family: inherit; }
input:focus, select:focus, textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(245,166,35,.12); }
input.err, select.err { border-color: #ef4444; }
input[readonly] { color: var(--accent); cursor: default; }
textarea { resize: vertical; }
select option { background: var(--surface); }
.section { margin-bottom: 20px; }
.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.section-labels { display: grid; grid-template-columns: 24px 1fr 80px 1fr 32px; gap: 8px; margin-bottom: 4px; }
.section-labels span { font-size: 10px; font-weight: 700; color: var(--muted); letter-spacing: .08em; text-transform: uppercase; padding: 0 4px; }
.add-btn { background: transparent; border: 1px dashed var(--accent); color: var(--accent); border-radius: 6px; padding: 4px 12px; font-size: 12px; cursor: pointer; font-weight: 600; font-family: inherit; }
.worker-row { display: grid; grid-template-columns: 24px 1fr 80px 1fr 32px; gap: 8px; align-items: center; margin-bottom: 8px; }
.worker-num { color: var(--muted); font-size: 13px; text-align: center; }
.remove-btn { background: transparent; border: none; color: var(--muted); cursor: pointer; font-size: 14px; padding: 4px 0; text-align: center; }
.err-msg { color: var(--red); font-size: 12px; margin-bottom: 8px; }
.submit-btn { background: var(--accent); color: var(--accentOn); border: none; border-radius: 10px; padding: 13px 28px; font-size: 15px; font-weight: 700; cursor: pointer; margin-top: 8px; transition: opacity .2s; font-family: inherit; }
.submit-btn:hover { opacity: .85; }
.submit-btn:disabled { opacity: .5; cursor: not-allowed; }
.outline-btn { background: transparent; border: 1px solid var(--border); color: var(--text); margin-left: 12px; }
.success-card { background: var(--surface); border-radius: 16px; border: 1px solid var(--border); padding: 56px 32px; text-align: center; }
.check-circle { width: 64px; height: 64px; border-radius: 50%; background: #14532d; border: 2px solid #22c55e; color: #22c55e; font-size: 28px; display: flex; align-items: center; justify-content: center; margin: 0 auto 20px; }
.success-title { font-size: 24px; font-weight: 700; color: var(--white); margin-bottom: 12px; }
.success-msg { color: var(--secondary); font-size: 14px; max-width: 420px; margin: 0 auto 28px; line-height: 1.6; }
.success-btns { display: flex; justify-content: center; }
.prehled-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; flex-wrap: wrap; gap: 12px; }
.admin-badge { background: var(--greenBg); border: 1px solid var(--green); color: var(--green); border-radius: 99px; padding: 4px 12px; font-size: 11px; font-weight: 700; }
.refresh-btn { background: transparent; border: 1px solid var(--border); color: var(--secondary); padding: 6px 14px; border-radius: 8px; cursor: pointer; font-size: 12px; font-family: inherit; }
.refresh-btn:hover { border-color: var(--accent); color: var(--accent); }
.stats-row { display: flex; gap: 12px; margin-bottom: 20px; flex-wrap: wrap; }
.stat-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 16px 20px; flex: 1; min-width: 140px; }
.stat-val { font-size: 28px; font-weight: 700; color: var(--accent); }
.stat-label { font-size: 12px; color: var(--muted); margin-top: 4px; }
.history-row { display: flex; flex-wrap: nowrap; gap: 8px; margin-bottom: 20px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; padding-bottom: 4px; cursor: grab; user-select: none; }
.history-row::-webkit-scrollbar { display: none; }
.history-row button { flex-shrink: 0; white-space: nowrap; }
.empty-state { text-align: center; background: var(--surface); border: 1px dashed var(--border); border-radius: 16px; padding: 48px; color: var(--muted); display: flex; flex-direction: column; align-items: center; gap: 12px; }
.subm-card { background: var(--surface); border: 1px solid var(--border); border-radius: 12px; padding: 20px; margin-bottom: 16px; border-left: 4px solid var(--border); }
.subm-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 10px; flex-wrap: wrap; gap: 8px; }
.subm-firma { font-size: 16px; font-weight: 700; color: var(--white); }
.subm-time { font-size: 12px; color: var(--muted); }
.subm-meta { display: flex; gap: 16px; flex-wrap: wrap; font-size: 13px; color: var(--secondary); margin-bottom: 12px; }
.skupina-row { background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 10px 14px; margin-bottom: 8px; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.skupina-name { font-size: 13px; font-weight: 600; color: var(--text); flex: 1; min-width: 160px; }
.skupina-count { font-size: 12px; color: var(--secondary); white-space: nowrap; }
.skupina-hd a { font-size: 12px; color: var(--accent); text-decoration: none; }
.skupina-hd a:hover { text-decoration: underline; }
.subm-note { font-size: 13px; color: var(--muted); margin-top: 10px; font-style: italic; }
.changepin-card { background: var(--surface); border-radius: 16px; border: 1px solid var(--border); padding: 32px; max-width: 420px; margin: 0 auto; }

/* ── Worker picker ────────────────────────────────────────── */
.worker-picker-wrap {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100dvh;
  position: fixed; top: 0; left: 0;
  background: #0b0e14;
  z-index: 300; padding: 16px;
  box-sizing: border-box;
  overflow: hidden;
}
.worker-picker-card {
  position: relative; z-index: 10;
  background: rgba(18,21,30,.92);
  border: 1px solid rgba(245,166,35,.16);
  border-radius: 24px;
  padding: 32px 24px 28px;
  width: 100%; max-width: 440px;
  max-height: calc(100dvh - 32px);
  box-sizing: border-box;
  text-align: center;
  display: flex; flex-direction: column;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  box-shadow: 0 0 0 1px rgba(245,166,35,.05), 0 32px 80px rgba(0,0,0,.65);
  animation: pinCardIn .35s cubic-bezier(.22,1,.36,1) both;
}
#workerBtns {
  overflow-y: auto; overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  flex: 1; min-height: 0;
}
/* viewWorkerPicker — override desktop pin-wrap overflow:hidden */
#viewWorkerPicker .pin-wrap {
  position: relative !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  min-height: 100dvh;
  align-items: flex-start;
}
#viewWorkerPicker .pin-card {
  max-height: calc(100dvh - 40px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
@media (max-width: 480px) {
  .worker-picker-wrap { padding: 10px; }
  .worker-picker-card { padding: 24px 14px 20px; border-radius: 18px; max-width: 100%; max-height: calc(100dvh - 20px); }
}
.spinner { display: inline-block; width: 16px; height: 16px; border: 2px solid rgba(245,166,35,.3); border-top-color: #f5a623; border-radius: 50%; animation: spin .6s linear infinite; vertical-align: middle; margin-right: 8px; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes tvScroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
@keyframes tvPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(1.15)} }
.hidden { display: none; }
.fade-in { animation: fadeIn .3s ease; }
@keyframes fadeIn { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

@media (max-width: 640px) {

  /* ── RESET & BASE ─────────────────────────────────────────── */
  * { -webkit-tap-highlight-color: transparent; }
  main { padding: 0 12px 90px; }

  /* ── HEADER ───────────────────────────────────────────────── */
  header {
    padding: 0;
    background: var(--hdr-bg);
    border-bottom: 1px solid var(--border);
    position: sticky;
    top: 0;
    z-index: 100;
  }
  .header-inner {
    padding: 10px 14px;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0;
    flex-wrap: nowrap;
  }
  .header-inner > div:first-child {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 0;
  }
  /* Skryť badge, h1, subtitle — nahradí dátum */
  .header-inner .badge,
  .header-inner h1,
  .header-inner .subtitle { display: none; }

  /* Dátum vedľa loga */
  #todayStr {
    display: block !important;
    font-size: 13px;
    font-weight: 500;
    color: var(--secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .header-row1 { display: none; }
  #headerRight { display: block; }
  /* ── Mobile action bar (firma + akcie) ───────────────────── */
  .mobile-header-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 14px;
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    gap: 8px;
    position: relative;
  }
  .mob-header-logo {
    display: flex; align-items: center; gap: 6px;
    position: absolute; left: 50%; transform: translateX(-50%);
  }
  .mob-header-logo-icon {
    width: 26px; height: 26px; background: #1e2d42;
    border-radius: 6px; display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
  }
  .mob-header-wordmark {
    font-size: 15px; font-weight: 500;
    color: var(--text); letter-spacing: -.2px;
  }
  .mob-header-wordmark span { color: #f5a623; }


  /* Settings tlačidlo */
  .mobile-settings-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--surface2);
    border: 1px solid var(--border);
    color: var(--text);
    font-size: 18px;
    cursor: pointer;
    padding: 7px;
    border-radius: 10px;
    flex-shrink: 0;
  }
  .mobile-settings-menu {
    display: none;
    position: absolute;
    top: 54px;
    right: 14px;
    background: var(--surface2);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 6px;
    z-index: 300;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
    min-width: 180px;
  }
  .mobile-settings-menu.visible { display: flex; flex-direction: column; gap: 2px; }
  .mobile-settings-menu button {
    background: transparent;
    border: none;
    color: var(--text);
    padding: 11px 14px;
    text-align: left;
    font-size: 13px;
    font-family: inherit;
    border-radius: 10px;
    white-space: nowrap;
    cursor: pointer;
  }
  .mobile-settings-menu button:active { background: var(--border); }

  /* ── BOTTOM NAV ───────────────────────────────────────────── */
  .nav-btns {
    display: flex !important;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    z-index: 200;
    background: var(--nav);
    border-top: 1px solid var(--border);
    padding: 8px 6px env(safe-area-inset-bottom, 8px);
    gap: 4px;
  }
  .mob-nav-group { flex: 1; position: relative; display: flex; justify-content: center; }
  .mob-nav-btn {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 8px 6px 9px; width: 100%;
    border: none; background: transparent;
    color: var(--muted); font-size: 11px; font-weight: 400;
    cursor: pointer; font-family: inherit; gap: 4px;
    position: relative; border-radius: 12px;
    transition: background .14s, color .14s;
  }
  .mob-nav-btn svg { flex-shrink: 0; width: 30px; height: 30px; }
  .mob-nav-btn.active {
    color: #f5a623;
    background: rgba(245,166,35,0.12);
    font-weight: 500;
  }
  .mob-nav-btn.nav-group-open {
    color: #f5a623;
    background: rgba(245,166,35,0.12);
  }
  .mob-active-bar { display: none; }

  /* FAB — rýchle hlásenie (vedúci/majiteľ) */
  .mob-nav-fab-wrap { flex: 0 0 68px; display: flex; align-items: center; justify-content: center; }
  .mob-nav-fab {
    width: 48px; height: 48px; border-radius: 15px;
    background: #f5a623; border: none; color: #1a1000;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; position: relative; bottom: 10px;
    box-shadow: 0 4px 12px rgba(245,166,35,0.4);
    transition: transform .12s, box-shadow .12s;
  }
  .mob-nav-fab:active { transform: scale(0.92); box-shadow: 0 2px 6px rgba(245,166,35,0.25); }

  /* Mobile dropdown — otvára sa nahor */
  .mob-dropdown {
    bottom: calc(100% + 4px); top: auto; left: 50%;
    transform: translateX(-50%) scale(.94) translateY(6px);
    transform-origin: bottom center;
  }
  .mob-dropdown.nav-dropdown-open {
    transform: translateX(-50%) scale(1) translateY(0);
  }

  /* Legacy .nav-btn */
  .nav-btn {
    flex: 1; flex-direction: column; align-items: center; justify-content: center;
    padding: 6px 2px 4px; background: transparent; border: none; border-radius: 10px;
    font-size: 10px; gap: 2px; color: var(--muted); font-weight: 400;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .nav-btn .nav-icon { font-size: 22px; line-height: 1; }
  .nav-btn.active { color: var(--accent); }

  /* ── PIN ──────────────────────────────────────────────────── */
  .pin-wrap { padding: 8px; align-items: center; }
  .pin-card { padding: 18px 14px 16px; border-radius: 16px; max-width: 100%; }
  .pin-logo-row { margin-bottom: 4px; }
  .pin-tagline { margin-bottom: 8px; font-size: 11px; }
  .pin-divider { margin: 8px 0; }
  .pin-logo-icon { width: 28px; height: 28px; }
  .pin-title { font-size: 17px; }
  .pin-icon { font-size: 28px; margin-bottom: 8px; }
  .pin-desc { font-size: 11px; margin-bottom: 12px; }
  .pin-dots { margin-bottom: 12px; gap: 12px; }
  .pin-dot { width: 13px; height: 13px; }
  .pin-key { padding: 12px; font-size: 20px; border-radius: 10px; }
  .pin-pad { gap: 6px; }

  /* ── KARTA ────────────────────────────────────────────────── */
  .card {
    padding: 16px 14px;
    border-radius: 14px;
    margin-bottom: 12px;
  }
  .card-title { font-size: 16px; margin-bottom: 2px; }
  .card-desc { font-size: 12px; margin-bottom: 16px; }

  /* ── FORMULÁR ─────────────────────────────────────────────── */
  .row { flex-direction: column; gap: 10px; margin-bottom: 10px; }
  .field { min-width: 0; }
  .field label { font-size: 12px; }
  input, select, textarea {
    font-size: 16px !important;
    border-radius: 10px;
    padding: 10px 12px !important;
  }
  textarea { min-height: 80px; }

  /* Skupiny riadky — kompaktnejšie */
  .section-labels { display: none; }
  .section-header { margin-bottom: 10px; }
  .section-header label { font-size: 13px; font-weight: 600; }

  .submit-btn {
    width: 100%;
    padding: 14px;
    font-size: 15px;
    border-radius: 12px;
    margin-top: 6px;
  }
  .outline-btn { margin-top: 8px; }

  /* ── PREHĽAD ──────────────────────────────────────────────── */
  .prehled-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    margin-bottom: 10px;
  }
  .prehled-header > div:first-child { gap: 8px; }
  .prehled-header .card-title { font-size: 16px; }
  /* Tlačidlá filtrov — scrollovateľný rad */
  .prehled-header > div:last-child {
    display: flex;
    overflow-x: auto;
    gap: 6px;
    width: 100%;
    padding-bottom: 2px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .prehled-header > div:last-child::-webkit-scrollbar { display: none; }
  .refresh-btn {
    padding: 6px 12px;
    font-size: 12px;
    border-radius: 8px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* História dátumov */
  .history-row {
    display: flex;
    overflow-x: auto;
    gap: 6px;
    margin-bottom: 10px;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .history-row::-webkit-scrollbar { display: none; }
  .history-row button { flex-shrink: 0; font-size: 12px; padding: 5px 10px; border-radius: 8px; }

  /* ── SUBMISSION KARTY ─────────────────────────────────────── */
  .subm-card {
    background: var(--surface) !important;
    border-radius: 14px;
    border: 1px solid var(--border);
    border-left: 4px solid;
    padding: 14px;
    margin-bottom: 10px;
    box-shadow: none;
  }
  .subm-firma { font-size: 15px !important; font-weight: 700; }
  .subm-time { font-size: 12px !important; }
  .subm-note {
    font-size: 12px;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--border);
  }

  /* Skupina riadky */
  .skupina-row {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px;
    margin-top: 8px;
    gap: 8px;
    flex-wrap: wrap;
  }
  .skupina-name { font-size: 13px !important; font-weight: 600; width: 100%; }
  .skupina-hd a { font-size: 13px !important; }
  /* Príchodové/odchodové tlačidlá — mobile: pod textom, plná šírka */
  .rzac-btns { width: 100%; flex-shrink: 0; }
  .rzac-btns .realizacia-btn { width: 100%; box-sizing: border-box; }
  .sk-detail-btn {
    background: var(--surface2) !important;
    color: var(--text) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
    padding: 7px 14px !important;
    font-size: 12px !important;
  }

  /* ── ŠTATISTIKY ───────────────────────────────────────────── */
  .stats-row { gap: 8px; }
  .stat-card {
    background: var(--surface);
    border-radius: 12px;
    border: 1px solid var(--border);
    padding: 12px 14px;
  }
  .stat-val { font-size: 22px; }
  .stat-label { font-size: 11px; }

  /* ── DASHBOARD KPI ────────────────────────────────────────── */
  .dash-kpi-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .dash-kpi-card { padding: 12px 10px; background: var(--surface); border: 1px solid var(--border); border-radius: 14px; }
  .dash-kpi-card.dash-kpi-green { border-color: color-mix(in srgb, var(--green) 20%, transparent); background: var(--kpi-green-bg); }
  .dash-kpi-val { font-size: 22px; }
  .dash-kpi-card:last-child { grid-column: span 2; }
  .dash-charts-row { flex-direction: column; }
  .dash-bar-label { width: 80px; }

  /* ── ADMIN ────────────────────────────────────────────────── */
  .admin-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 4px;
    flex-wrap: nowrap;
    padding-bottom: 2px;
  }
  .admin-tabs::-webkit-scrollbar { display: none; }
  .admin-tab-btn {
    font-size: 12px;
    padding: 7px 12px;
    white-space: nowrap;
    flex-shrink: 0;
    border-radius: 8px;
  }

}
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:0.4} }

    /* ── Chastia theme overrides pre hardcoded inline štýly ─── */
    [data-theme="chastia"] header { background: var(--hdr-bg) !important; }
    [data-theme="chastia"] header .badge { color: #f5a623 !important; }
    [data-theme="chastia"] header h1,
    [data-theme="chastia"] header .subtitle { color: #fff !important; }

    /* Nav tlačidlá v headeri — svetlé na tmavom modrom pozadí */
    [data-theme="chastia"] header .nav-group-btn,
    [data-theme="chastia"] header .nav-btn { color: rgba(255,255,255,0.85) !important; }
    [data-theme="chastia"] header .nav-group-btn:hover,
    [data-theme="chastia"] header .nav-btn:hover { color: #fff !important; background: rgba(255,255,255,0.12) !important; border-color: rgba(255,255,255,0.25) !important; }
    [data-theme="chastia"] header .nav-group-btn.nav-group-open { color: #f5a623 !important; border-color: #f5a623 !important; background: rgba(245,166,35,0.12) !important; }
    [data-theme="chastia"] header .nav-icon-btn { color: rgba(255,255,255,0.8) !important; border-color: rgba(255,255,255,0.25) !important; }
    [data-theme="chastia"] header .nav-icon-btn:hover { color: #fff !important; background: rgba(255,255,255,0.12) !important; border-color: rgba(255,255,255,0.4) !important; }
    [data-theme="chastia"] header .nav-role-chip { color: #f5a623 !important; border-color: rgba(245,166,35,0.4) !important; background: rgba(245,166,35,0.12) !important; }

    /* Logo pozadie */
    [data-theme="chastia"] header img {
      border-radius: 6px;
      background: #161920;
      padding: 3px 5px;
      box-sizing: content-box;
    }

    /* Modaly - vnútorné karty */
    [data-theme="chastia"] #iosModal > div,
    [data-theme="chastia"] #zonaPickerModal > div,
    [data-theme="chastia"] #arealEditorModal > div,
    [data-theme="chastia"] #refreshModal > div,
    [data-theme="chastia"] #pracovniciModal > div,
    [data-theme="chastia"] #pracovnikEditModal > div,
    [data-theme="chastia"] #adminUserModal > div,
    [data-theme="chastia"] #adminSkupinaModal > div,
    [data-theme="chastia"] #fotoMailModal > div,
    [data-theme="chastia"] #cennikModal > div,
    [data-theme="chastia"] #predlzitModal > div,
    [data-theme="chastia"] #notesModal > div,
    [data-theme="chastia"] #kopirovatModal > div {
      background: var(--surface) !important;
      border-color: var(--border) !important;
    }

    /* Modal overlay - bottom sheet */
    [data-theme="chastia"] #modalOverlay { background: rgba(0,0,0,.4) !important; }
    [data-theme="chastia"] #modalBox { background: var(--surface) !important; border-color: var(--border) !important; }

    /* Zavrieť tlačidlá v modaloch */
    [data-theme="chastia"] #iosModal button[onclick*="style.display"],
    [data-theme="chastia"] #zonaPickerModal button[onclick*="closeZona"],
    [data-theme="chastia"] #arealEditorModal button[onclick*="closeAreal"],
    [data-theme="chastia"] #refreshModal button[onclick*="style.display"],
    [data-theme="chastia"] #pracovniciModal button[onclick*="style.display"],
    [data-theme="chastia"] #pracovnikEditModal button[onclick*="style.display"],
    [data-theme="chastia"] #adminUserModal button[onclick*="style.display"],
    [data-theme="chastia"] #adminSkupinaModal button[onclick*="style.display"],
    [data-theme="chastia"] #fotoMailModal button[onclick*="style.display"],
    [data-theme="chastia"] #cennikModal button[onclick*="closeCennikModal"],
    [data-theme="chastia"] #predlzitModal button[onclick*="style.display"] {
      background: var(--surface2) !important;
      border: 1px solid var(--border) !important;
      color: var(--secondary) !important;
    }

    /* Texty v modaloch */
    [data-theme="chastia"] #pracovniciModal h3,
    [data-theme="chastia"] #adminUserModal h3,
    [data-theme="chastia"] #adminSkupinaModal h3,
    [data-theme="chastia"] #notesModal h3 { color: var(--white) !important; }
    [data-theme="chastia"] #pracovniciModal p { color: var(--muted) !important; }

    /* Selecty v modaloch */
    [data-theme="chastia"] #pwRola,
    [data-theme="chastia"] #auRola,
    [data-theme="chastia"] #fotoMailSelect {
      background: var(--bg) !important;
      border-color: var(--border) !important;
      color: var(--text) !important;
    }

    /* Refresh interval tlačidlá */
    [data-theme="chastia"] .refresh-interval-opt {
      background: var(--surface2) !important;
      border-color: var(--border) !important;
      color: var(--secondary) !important;
    }

    /* App download sekcia */
    [data-theme="chastia"] #appDownloadSection { border-color: var(--border) !important; }
    [data-theme="chastia"] #btnDownloadApk,
    [data-theme="chastia"] #appDownloadSection button {
      background: var(--surface2) !important;
      border-color: var(--border2) !important;
      color: var(--text) !important;
    }

    /* Worker name display */
    [data-theme="chastia"] #workerNameDisplay {
      background: var(--surface2) !important;
      color: var(--secondary) !important;
    }

    /* Mapa containery */
    [data-theme="chastia"] #mapaContainer,
    [data-theme="chastia"] #arealContainer { background: var(--surface2) !important; }
    [data-theme="chastia"] #arealUploadSection {
      background: var(--bg) !important;
      border-color: var(--border2) !important;
    }

    /* TV banner karta */
    [data-theme="chastia"] [onclick="openTvMode()"] {
      background: linear-gradient(135deg, #1b3d6e 0%, #1e4a82 100%) !important;
      border-color: var(--border) !important;
    }
    [data-theme="chastia"] [onclick="openTvMode()"] div[style*="monospace"] {
      background: rgba(0,0,0,.2) !important;
      border-color: rgba(255,255,255,.2) !important;
      color: rgba(255,255,255,.7) !important;
    }
    [data-theme="chastia"] [onclick="openTvMode()"] p,
    [data-theme="chastia"] [onclick="openTvMode()"] span { color: rgba(255,255,255,.85) !important; }

    /* Sumarny toggle */
    [data-theme="chastia"] #sumarnyToggle { background: var(--border) !important; }
    .sumarny-den-lbl { display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--muted);cursor:pointer;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 10px;transition:background .15s,color .15s; }
    .sumarny-den-lbl:has(input:checked) { background:#f5a62322;border-color:#f5a623;color:#f5a623; }
    .sumarny-den-lbl input { display:none; }

    /* Notes a kopirovat modaly */
    [data-theme="chastia"] #notesModal > div,
    [data-theme="chastia"] #kopirovatModal > div {
      background: var(--surface) !important;
      border-color: var(--border) !important;
    }
    [data-theme="chastia"] #noteInput {
      background: var(--bg) !important;
      border-color: var(--border) !important;
      color: var(--text) !important;
    }

    /* Pruh v prehlade (progress bar) */
    [data-theme="chastia"] div[style*="height:6px"][style*="background:#2a2d38"] {
      background: var(--border) !important;
    }
    /* Bottom sheet handle */
    [data-theme="chastia"] div[style*="width:40px"][style*="height:4px"] {
      background: var(--border2) !important;
    }

    /* Check circle - success */
    [data-theme="chastia"] .check-circle {
      background: var(--greenBg) !important;
      border-color: var(--green) !important;
      color: var(--green) !important;
    }

    /* Logout btn hover */
    [data-theme="chastia"] .logout-btn:hover { border-color: var(--red) !important; color: var(--red) !important; }
    [data-theme="chastia"] .pin-error { color: var(--red); }

    /* Farby textov v modaloch */
    [data-theme="chastia"] #iosModal *,
    [data-theme="chastia"] #zonaPickerModal *,
    [data-theme="chastia"] #refreshModal *,
    [data-theme="chastia"] #pracovniciModal *,
    [data-theme="chastia"] #pracovnikEditModal *,
    [data-theme="chastia"] #adminUserModal *,
    [data-theme="chastia"] #adminSkupinaModal *,
    [data-theme="chastia"] #fotoMailModal *,
    [data-theme="chastia"] #predlzitModal *,
    [data-theme="chastia"] #notesModal *,
    [data-theme="chastia"] #kopirovatModal *,
    [data-theme="chastia"] #cennikModal * { color: var(--text) !important; }

    /* Ale farebné prvky nechaj */
    [data-theme="chastia"] #iosModal a,
    [data-theme="chastia"] #notesModal h3,
    [data-theme="chastia"] #kopirovatModal h3,
    [data-theme="chastia"] #adminUserModal h3,
    [data-theme="chastia"] #adminSkupinaModal h3,
    [data-theme="chastia"] #pracovniciModal h3 { color: var(--white) !important; }

    /* Submit btn v modaloch nech ma accentOn */
    [data-theme="chastia"] #iosModal button[style*="background:#f5a623"],
    [data-theme="chastia"] #notesModal button[onclick="submitNote()"],
    [data-theme="chastia"] #kopirovatModal button[onclick="potvrditKopirovat()"] {
      color: var(--accentOn) !important;
    }

    /* TV dashboard ostáva vždy tmavý */
    #viewTV, #viewTV * { --chastia-override: none; }

    /* Progress bar v prehlade */
    [data-theme="chastia"] .progress-bar-bg { background: var(--border) !important; }

    /* Hrubka karty hlasenia v prehlade */
    [data-theme="chastia"] .subm-card { box-shadow: 0 1px 4px rgba(0,0,0,.06); }

    /* Modalne okno - pozadie overlay svetlejšie */
    [data-theme="chastia"] #modalOverlay,
    [data-theme="chastia"] #iosModal,
    [data-theme="chastia"] #zonaPickerModal,
    [data-theme="chastia"] #arealEditorModal,
    [data-theme="chastia"] #refreshModal,
    [data-theme="chastia"] #pracovniciModal,
    [data-theme="chastia"] #pracovnikEditModal,
    [data-theme="chastia"] #adminUserModal,
    [data-theme="chastia"] #adminSkupinaModal,
    [data-theme="chastia"] #fotoMailModal,
    [data-theme="chastia"] #predlzitModal,
    [data-theme="chastia"] #notesModal,
    [data-theme="chastia"] #kopirovatModal { background: rgba(15,30,60,.45) !important; }

    /* Spinner farba */
    [data-theme="chastia"] .spinner {
      border-color: rgba(245,166,35,.3) !important;
      border-top-color: var(--accent) !important;
    }

    /* Grafy axis text - Chart.js */
    [data-theme="chastia"] canvas { background: transparent; }
    .aktivny-badge { font-size:11px; color:#22c55e; margin-left:4px; animation: pulse 1.5s ease-in-out infinite; display:inline-block; }

    /* ── Dashboard ── */
    .dash-kpi-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-bottom:18px; }
    .dash-kpi-card { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:20px 18px; display:flex; flex-direction:column; gap:6px; }
    .dash-kpi-card.dash-kpi-green { border-color:color-mix(in srgb, var(--green) 20%, transparent); background:var(--kpi-green-bg); }
    .dash-kpi-icon { font-size:22px; }
    .dash-kpi-val { font-size:32px; font-weight:800; color:var(--white); line-height:1; }
    .dash-kpi-label { font-size:12px; color:var(--muted); }
    .dash-kpi-green .dash-kpi-val { color:var(--green); }
    .dash-charts-row { display:flex; gap:14px; margin-bottom:18px; flex-wrap:wrap; }
    .dash-chart-card { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:18px; min-width:0; flex:1; }
    .dash-chart-title { font-size:13px; font-weight:600; color:var(--secondary); letter-spacing:.04em; text-transform:uppercase; margin-bottom:4px; }
    .dash-bar-row { display:flex; align-items:center; gap:8px; margin-bottom:8px; }
    .dash-bar-label { font-size:12px; color:var(--text); width:130px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; flex-shrink:0; }
    .dash-bar-track { flex:1; height:8px; background:var(--surface2); border-radius:99px; overflow:hidden; }
    .dash-bar-fill { height:100%; border-radius:99px; background:var(--accent); transition:width .6s ease; }
    .dash-bar-count { font-size:12px; color:var(--muted); width:28px; text-align:right; flex-shrink:0; }
    .dash-recent-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--surface2); }
    .dash-recent-row:last-child { border-bottom:none; }
    .dash-recent-firma { font-size:13px; font-weight:600; color:var(--accent); flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
    .dash-recent-meta { font-size:11px; color:var(--muted); }
    .dash-dot { width:8px; height:8px; border-radius:50%; background:var(--accent); flex-shrink:0; }
    @media (max-width:640px) {
      .dash-kpi-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
      .dash-kpi-val { font-size:24px; }
      .dash-kpi-card { padding:14px 12px; }
      .dash-kpi-card:last-child { grid-column: span 2; }
      .dash-charts-row { flex-direction:column; }
      .dash-bar-label { width:90px; }
    }

/* ── Custom Picker Trigger ── */
.picker-trigger {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  background: var(--surface2, #1a1d27);
  border: 1px solid var(--border, #2a2d38);
  border-radius: 8px;
  color: var(--text, #e5e7eb);
  font-size: 15px;
  font-family: inherit;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  transition: border-color .15s;
  min-height: 44px;
}
.picker-trigger:hover, .picker-trigger:focus {
  border-color: #f5a623;
  outline: none;
}
.picker-trigger .picker-icon { font-size: 17px; flex-shrink: 0; }
/* Blikajúce orámovanie aktívneho hlásenia */
@keyframes aktivny-blink {
  0%, 100% { outline-color: #22c55e; box-shadow: 0 0 0 0 rgba(34,197,94,0); }
  50%       { outline-color: #4ade80; box-shadow: 0 0 8px 2px rgba(34,197,94,0.25); }
}

@keyframes vandal-glow {
  0%, 100% { box-shadow: 0 0 0 1px rgba(220,38,38,0.25), 0 0 10px 1px rgba(220,38,38,0.12); }
  50%       { box-shadow: 0 0 0 1px rgba(220,38,38,0.55), 0 0 22px 6px rgba(220,38,38,0.28); }
}

/* Animovaný pracovník */
@keyframes arm-swing {
  from { transform: rotate(-35deg); }
  to   { transform: rotate(20deg); }
}
@keyframes leg-swing {
  from { transform: rotate(-20deg); }
  to   { transform: rotate(25deg); }
}
@keyframes tool-move {
  from { transform: translateY(-2px) rotate(-10deg); }
  to   { transform: translateY(2px) rotate(10deg); }
}
/* ── TV Dashboard — full-screen fix ──────────────────────── */
#viewTV {
  position: fixed !important;
  top: 0 !important; left: 0 !important;
  right: 0 !important; bottom: 0 !important;
  width: 100vw !important; height: 100vh !important;
  z-index: 500;
  overflow: hidden;
}

/* ── TV Dashboard — téma-aware štýly ─────────────────────── */
.tv-empty { color: var(--muted2); font-size: 11px; padding: 8px 0; }
.tv-empty-lg { color: var(--muted); font-size: 13px; text-align: center; padding: 32px 0; line-height: 1.6; }
.tv-empty-sub { font-size: 11px; color: var(--muted2); }

/* Číslovacie koliesko úlohy */
.tv-task-num {
  min-width: 22px; height: 22px;
  background: var(--surface2);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700;
  color: var(--secondary);
  flex-shrink: 0; margin-top: 1px;
}

/* Text úlohy */
.tv-task-text { font-size: 13px; color: var(--text); line-height: 1.5; word-break: break-word; }
.tv-task-empty { font-size: 12px; color: var(--muted2); font-style: italic; }

/* Termín progress bar pozadie */
.tv-task-bar-bg { background: var(--surface2); border-radius: 4px; height: 5px; overflow: hidden; }

/* Termín dátum text */
.tv-task-date { font-size: 10px; color: var(--muted); }

/* Vandalizmus panel */
.tv-vand-empty { color: var(--muted); font-size: 11px; text-align: center; padding: 24px 8px; opacity: .5; }
.tv-vand-card {
  background: rgba(239,68,68,.08);
  border: 1px solid rgba(239,68,68,.3);
  border-left: 3px solid #ef4444;
  border-radius: 7px; padding: 8px 10px; margin-bottom: 7px;
}
.tv-vand-firma { font-size: 12px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tv-vand-hd { font-size: 10px; color: var(--muted); margin-top: 2px; }

/* Editor úloh */
.tv-editor-label { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; }
.tv-editor-num { font-size: 11px; color: var(--muted); min-width: 20px; flex-shrink: 0; }

/* Hlásenia panel */
.tv-hlasenie-firma { font-size: 11px; font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.tv-hlasenie-sub { font-size: 9px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Sekcie nadpisy */
.tv-section-title {
  padding: 8px 14px 4px;
  font-size: 9px; font-weight: 700; letter-spacing: .12em;
  color: var(--muted); text-transform: uppercase;
  flex-shrink: 0;
  background: var(--surface); border-bottom: 1px solid var(--border);
}

/* Vandalizmus sekcia nadpis */
.tv-section-title-vand {
  padding: 8px 10px 4px;
  font-size: 9px; font-weight: 700; letter-spacing: .1em;
  color: #ef4444; text-transform: uppercase;
  flex-shrink: 0; border-bottom: 1px solid rgba(239,68,68,.2);
}
/* ── Farebný akcent swatche (adminUserModal) ── */
.au-swatch-row { display:flex; align-items:center; gap:6px; flex-wrap:wrap; margin-top:6px; }
.au-swatch {
  width:24px; height:24px; border-radius:50%; border:2px solid transparent;
  cursor:pointer; padding:0; flex-shrink:0; transition:transform .12s, border-color .12s;
  font-size:11px; font-weight:700; line-height:24px; text-align:center;
}
.au-swatch:hover { transform:scale(1.18); border-color:rgba(255,255,255,.5); }
.au-swatch.au-active { border-color:#fff; transform:scale(1.15); box-shadow:0 0 0 2px rgba(255,255,255,.3); }
.au-swatch-auto { background:#374151 !important; color:#9ca3af; border-color:#6b7280 !important; }
.au-swatch-custom {
  background:transparent !important; border-color:var(--border2) !important;
  color:var(--muted); font-size:16px; line-height:20px;
}
.au-swatch-custom.au-active { border-color:var(--accent) !important; color:var(--accent); }
.au-swatch-hint { margin-top:6px; font-size:11px; color:var(--muted); }

/* Chastia tema — swatche viditeľné (hover ring tmavý) */
[data-theme="chastia"] .au-swatch:hover { border-color:rgba(0,0,0,.4); }
[data-theme="chastia"] .au-swatch.au-active { border-color:#1e293b; box-shadow:0 0 0 2px rgba(0,0,0,.2); }
[data-theme="chastia"] .au-swatch-auto { color:#374151 !important; }
[data-theme="chastia"] .au-swatch-custom { color:var(--muted) !important; }

/* Chastia téma — mobilný UI viditeľnosť tlačidiel */
/* NEGUJ header .nav-icon-btn overrides pre mobile-header-actions */
[data-theme="chastia"] .mobile-header-actions .nav-icon-btn {
  color: #334155 !important;
  border-color: #cbd5e1 !important;
}
[data-theme="chastia"] .mobile-header-actions .nav-icon-btn:hover {
  color: #0f172a !important;
  background: #e2e8f0 !important;
  border-color: #cbd5e1 !important;
}
[data-theme="chastia"] .mobile-header-actions .nav-icon-btn.nav-icon-btn-danger:hover {
  color: #dc2626 !important;
  border-color: #dc2626 !important;
}
[data-theme="chastia"] .mobile-header-actions .nav-role-chip {
  color: #f5a623 !important;
  border-color: #f59e0b !important;
  background: #fef3c7 !important;
}
[data-theme="chastia"] .mob-nav-btn {
  color: #475569 !important;
}
[data-theme="chastia"] .mob-nav-btn:active {
  background: #f1f5f9 !important;
}
[data-theme="chastia"] .mob-nav-btn.active {
  color: #f5a623 !important;
  background: rgba(245, 166, 35, 0.12) !important;
  font-weight: 500;
}

/* ── Vyhľadávanie v prehľade ──────────────────────────────── */
#prehledSearchInput {
  transition: border-color .2s, box-shadow .2s;
}
#prehledSearchInput:focus {
  outline: none;
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 2px rgba(245, 166, 35, .15) !important;
}
[data-theme="chastia"] #prehledSearchInput:focus {
  box-shadow: 0 0 0 2px rgba(245, 166, 35, .08) !important;
}

.submission-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 10px;
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: all .2s;
}
.submission-card:hover {
  background: var(--surface2);
  border-color: var(--border2);
}

@media (max-width: 768px) {
  #prehledSearchInput {
    min-width: 120px;
    max-width: none;
  }
}

/* ══════════════════════════════════════════════════════════════
   MODULARIZÁCIA — nové reusable triedy (v1.8.0)
   ══════════════════════════════════════════════════════════════ */

/* ── Modal systém ─────────────────────────────────────────── */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--overlay);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.modal-overlay--top {
  align-items: flex-start;
  overflow-y: auto;
}
.modal-overlay--z1001 { z-index: 1001; }
.modal-overlay--z1002 { z-index: 1002; }
.modal-overlay--z1010 { z-index: 1010; }
.modal-overlay--z1020 { z-index: 1020; }
.modal-overlay--z2000 { z-index: 2000; }
.modal-overlay--z3000 { z-index: 3000; }
.modal-overlay--z4000 { z-index: 4000; }
.modal-overlay--z4500 { z-index: 4500; }
.modal-overlay--dark  { background: var(--overlay); }
.modal-overlay--darker { background: rgba(0,0,0,.8); }
.modal-overlay--darkest { background: rgba(0,0,0,.9); }

.modal-box {
  background: var(--nav);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  width: 100%;
  position: relative;
}
.modal-box--xs  { max-width: 360px; }
.modal-box--sm  { max-width: 400px; }
.modal-box--md  { max-width: 420px; }
.modal-box--lg  { max-width: 520px; }
.modal-box--xl  { max-width: 560px; }
.modal-box--xxl { max-width: 900px; }
.modal-box--padded { padding: 28px; }
.modal-box--center { margin: auto; }

.modal-close {
  position: absolute;
  top: 12px;
  right: 12px;
  background: var(--surface2);
  border: none;
  color: var(--secondary);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: background .15s;
}
.modal-close:hover {
  background: var(--border);
  color: var(--white);
}
.modal-close--lg {
  width: 30px;
  height: 30px;
  font-size: 15px;
}

.modal-title {
  color: var(--white);
  margin: 0 0 20px;
  font-size: 16px;
  font-weight: 700;
}
.modal-title--tight { margin-bottom: 6px; }

.modal-subtitle {
  color: var(--muted);
  font-size: 12px;
  margin: 0 0 16px;
}
.modal-subtitle--sm { font-size: 13px; }

.modal-header {
  background: var(--surface2);
  border-radius: 16px 16px 0 0;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-body {
  padding: 20px;
}

.modal-emoji {
  font-size: 28px;
  text-align: center;
  margin-bottom: 10px;
}

/* ── Layout utility ───────────────────────────────────────── */
.flex-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-col {
  display: flex;
  flex-direction: column;
}

.flex-wrap { flex-wrap: wrap; }
.flex-1    { flex: 1; }
.min-w-0   { min-width: 0; }

.gap-4  { gap: 4px; }
.gap-6  { gap: 6px; }
.gap-8  { gap: 8px; }
.gap-10 { gap: 10px; }
.gap-12 { gap: 12px; }
.gap-14 { gap: 14px; }
.gap-16 { gap: 16px; }

.mb-0  { margin-bottom: 0; }
.mb-4  { margin-bottom: 4px; }
.mb-6  { margin-bottom: 6px; }
.mb-8  { margin-bottom: 8px; }
.mb-10 { margin-bottom: 10px; }
.mb-12 { margin-bottom: 12px; }
.mb-16 { margin-bottom: 16px; }
.mb-20 { margin-bottom: 20px; }
.mt-4  { margin-top: 4px; }
.mt-8  { margin-top: 8px; }
.mt-10 { margin-top: 10px; }
.mt-12 { margin-top: 12px; }
.mt-16 { margin-top: 16px; }
.mt-20 { margin-top: 20px; }

.p-0   { padding: 0; }
.p-16  { padding: 16px; }
.p-20  { padding: 20px; }
.p-24  { padding: 24px; }

.text-center { text-align: center; }
.text-right  { text-align: right; }

.hidden { display: none !important; }
.truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.shrink-0 { flex-shrink: 0; }
.nowrap { white-space: nowrap; }

/* ── Toggle switch ────────────────────────────────────────── */
.toggle-track {
  width: 40px;
  height: 22px;
  border-radius: 99px;
  background: var(--border);
  position: relative;
  cursor: pointer;
  transition: background .2s;
  flex-shrink: 0;
}
.toggle-track--on {
  background: var(--accent);
}
.toggle-knob {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--muted);
  transition: all .2s;
}
.toggle-knob--on {
  left: 21px;
  background: var(--white);
}
.toggle-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
  color: var(--secondary);
}

/* ── Toolbar buttons (info editor, etc.) ──────────────────── */
.toolbar-btn {
  width: 30px;
  height: 28px;
  border: 1px solid var(--border);
  border-radius: 5px;
  background: var(--bg);
  color: var(--white);
  cursor: pointer;
  font-family: inherit;
  font-size: 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s;
}
.toolbar-btn:hover {
  background: var(--surface2);
}
.toolbar-sep {
  width: 1px;
  background: var(--border);
  margin: 3px 2px;
  align-self: stretch;
}

/* ── KPI karta ────────────────────────────────────────────── */
.kpi-card {
  background: var(--surface2);
  border-radius: 8px;
  padding: 14px 16px;
}
.kpi-card__label {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 4px;
}
.kpi-card__val {
  font-size: 24px;
  font-weight: 600;
  color: var(--white);
}
.kpi-card__sub {
  font-size: 11px;
  color: var(--muted);
  margin-top: 2px;
}

/* ── Popis / hinty ────────────────────────────────────────── */
.field-hint {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px;
}
.field-desc {
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 16px;
}
.section-desc {
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 16px;
}

/* ── Section header (flex-between s mb) ───────────────────── */
.section-flex {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.section-flex--tight { margin-bottom: 4px; }

/* ── Admin riadky (JS-generované) ─────────────────────────── */
.admin-row {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 8px;
  background: var(--bg);
}
.admin-row__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}
.admin-row__name {
  color: var(--white);
  font-weight: 600;
  font-size: 15px;
}
.admin-row__name--blocked {
  color: var(--red);
}
.admin-row__email {
  font-size: 12px;
  color: var(--muted);
  margin: 6px 0 0;
}
.admin-row__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

/* ── Admin tlačidlá ───────────────────────────────────────── */
.admin-btn {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--secondary);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
  cursor: pointer;
  font-family: inherit;
  transition: background .15s;
}
.admin-btn:hover {
  background: var(--border);
}
.admin-btn--accent {
  border-color: rgba(245,166,35,.33);
  color: var(--accent);
}
.admin-btn--indigo {
  border-color: var(--indigo-border);
  color: var(--indigo);
}
.admin-btn--danger {
  border-color: var(--red-border);
  color: var(--red);
}
.admin-btn--green {
  border-color: var(--greenBorder);
  color: var(--green);
}

/* ── Badge (rola, stav) ───────────────────────────────────── */
.badge-rola {
  font-size: 11px;
  background: var(--surface2);
  border-radius: 4px;
  padding: 2px 7px;
  margin-left: 8px;
}
.badge-rola--admin      { color: var(--accent); }
.badge-rola--firma      { color: var(--green); }
.badge-rola--subscriber { color: #3b82f6; }
.badge-blocked {
  font-size: 11px;
  color: var(--red);
  margin-left: 6px;
}

/* ── Log tabuľky ──────────────────────────────────────────── */
.log-table {
  width: 100%;
  border-collapse: collapse;
}
.log-th {
  padding: 8px 10px;
  text-align: left;
  color: var(--muted);
  font-weight: 600;
  font-size: 12px;
  border-bottom: 1px solid var(--border);
}
.log-th--center { text-align: center; }
.log-td {
  padding: 9px 12px;
  font-size: 13px;
  color: var(--text);
  border-bottom: 1px solid var(--border);
}
.log-td--muted { color: var(--secondary); }

/* ── Skupina riadok (dark row) ────────────────────────────── */
.sk-row {
  background: var(--dark-row);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 6px;
}

/* ── Farba dot ────────────────────────────────────────────── */
.color-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ── Swatch paletka ───────────────────────────────────────── */
.swatch-btn {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  padding: 0;
  transition: border-color .15s;
}
.swatch-btn:hover {
  border-color: var(--white);
}
.swatch-btn.au-active {
  border-color: var(--white);
  box-shadow: 0 0 0 2px var(--accent);
}

/* ── Chart / graph kontajner ──────────────────────────────── */
.chart-wrap {
  background: var(--bg);
  border: 1px solid var(--surface2);
  border-radius: 10px;
  padding: 16px 18px;
}
.chart-wrap__title {
  font-size: 13px;
  font-weight: 500;
  color: var(--secondary);
  margin-bottom: 10px;
}

/* ── BOZP alert boxy ──────────────────────────────────────── */
.alert-box {
  padding: 14px;
  border-radius: 10px;
  margin-bottom: 16px;
}
.alert-box--green {
  background: rgba(20,83,45,.13);
  border: 1px solid var(--greenBorder);
}
.alert-box--neutral {
  background: var(--surface2);
  border: 1px solid var(--border);
}

/* ── Kontajner na stránky (max-width + auto) ──────────────── */
.page-container {
  padding: 20px;
  max-width: 1100px;
  margin: 0 auto;
}
.page-container--sm { max-width: 680px; }
.page-container--md { max-width: 860px; }

/* ── Info editor ──────────────────────────────────────────── */
.info-editor {
  min-height: 260px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 0 0 8px 8px;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.7;
  outline: none;
  font-family: inherit;
  white-space: pre-wrap;
}
.info-preview {
  color: var(--text);
  font-size: 14px;
  line-height: 1.7;
  padding: 16px;
  background: var(--nav);
  border-radius: 8px;
  border: 1px solid var(--border);
}

/* ── Toolbar row ──────────────────────────────────────────── */
.toolbar-row {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  padding: 8px;
  background: var(--nav);
  border: 1px solid var(--border);
  border-radius: 8px 8px 0 0;
  border-bottom: none;
}

/* ── Success msg / error msg ──────────────────────────────── */
.msg-ok {
  color: var(--green);
  font-size: 13px;
}
.msg-err {
  color: var(--red);
  font-size: 13px;
}

/* ── Category label (uppercase muted) ─────────────────────── */
.cat-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .07em;
  margin-bottom: 8px;
}

/* ── Cron / monospace output ──────────────────────────────── */
.mono-output {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px;
  font-family: monospace;
  font-size: 12px;
  color: #a3e635;
  white-space: pre-wrap;
  max-height: 200px;
  overflow-y: auto;
}

/* ── Checkbox kontrolovaný ────────────────────────────────── */
.chk-accent {
  width: 14px;
  height: 14px;
  accent-color: var(--indigo);
}
.chk-lg {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
}
