/* ════════════════════════════════════════════════════════════════
   E-KAKOVOST QMS — Skupni dizajn sistem
   Uvozi na vsako stran: <link rel="stylesheet" href="/skupno.css">
   ════════════════════════════════════════════════════════════════ */

/* ── Barvna paleta ───────────────────────────────────────────── */
:root {
  /* Primarne barve — identična na vseh straneh */
  --teal:       #3aa9b4;
  --teal-dark:  #2a7f88;
  --teal-deep:  #1e6069;
  --teal-light: #e8f5f6;
  --teal-mist:  #f1f8f9;

  /* Nevtralne */
  --ink:        #1a2b32;
  --ink-mid:    #3d5560;
  --ink-soft:   #5b7280;
  --ink-muted:  #8b9eaa;
  --border:     #dde4e8;
  --bg:         #f5f7f9;
  --white:      #ffffff;

  /* Status barve */
  --green:      #2e9e6b;
  --green-light:#e8f8f1;
  --red:        #d6483f;
  --red-light:  #fdf0ef;
  --yellow:     #c98a1f;
  --yellow-light:#fdf6e8;
  --blue:       #2d7dd2;
  --blue-light: #eaf2fb;

  /* Sence */
  --shadow-sm:  0 1px 3px rgba(0,0,0,.08);
  --shadow-md:  0 3px 10px rgba(0,0,0,.10);
  --shadow-lg:  0 6px 24px rgba(0,0,0,.12);

  /* Oblika */
  --radius:     8px;
  --radius-sm:  5px;
  --radius-lg:  12px;
}

/* ── Topbar — identičen na vseh straneh ─────────────────────── */
.topbar {
  background: linear-gradient(135deg, var(--teal-deep) 0%, var(--teal-dark) 50%, var(--teal) 100%);
  color: #fff;
  padding: 0 22px;
  height: 56px;
  display: flex;
  align-items: center;
  gap: 10px;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 12px rgba(0,0,0,.18);
  flex-shrink: 0;
}

/* Logo + naslov */
.topbar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fff;
  flex-shrink: 0;
}

.topbar-brand img {
  height: 34px;
  width: auto;
  filter: brightness(0) invert(1);
}

.topbar-brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.topbar-brand-text b {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .2px;
}

.topbar-brand-text span {
  font-size: 11px;
  opacity: .75;
}

/* Gumbi v topbaru */
.tb-btn, .topbar button, .topbar a.tb-link {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.28);
  color: #fff !important;
  padding: 6px 13px;
  border-radius: 7px;
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: background .15s;
  font-family: inherit;
  line-height: 1.4;
}

.tb-btn:hover, .topbar button:hover, .topbar a.tb-link:hover {
  background: rgba(255,255,255,.25);
  color: #fff !important;
}

/* Aktivni/poudarjen gumb */
.tb-btn.active, .tb-btn-active {
  background: rgba(255,255,255,.28);
  border-color: rgba(255,255,255,.5);
  font-weight: 700;
}

/* Desna stran topbara */
.topbar-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
}

/* Org oznaka */
.topbar-org {
  font-size: 12.5px;
  opacity: .85;
  display: flex;
  align-items: center;
  gap: 7px;
}

.topbar-org img {
  height: 24px;
  width: auto;
  border-radius: 4px;
  background: #fff;
  padding: 2px;
  object-fit: contain;
}

/* Zvonček in klepet ikoni */
.topbar-icon-btn {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 16px;
  position: relative;
  transition: background .15s;
  flex-shrink: 0;
}

.topbar-icon-btn:hover {
  background: rgba(255,255,255,.25);
}

.topbar-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: #e8453c;
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  border: 2px solid var(--teal-dark);
}

/* Separator */
.topbar-sep {
  width: 1px;
  height: 22px;
  background: rgba(255,255,255,.25);
  flex-shrink: 0;
}

/* ── Osnova ──────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ── Skupni gumbi ────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 8px 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  color: var(--ink);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
  white-space: nowrap;
  text-decoration: none;
}
.btn:hover { border-color: var(--teal); color: var(--teal-dark); background: var(--teal-mist); }
.btn.primary { background: var(--teal); border-color: var(--teal); color: #fff; }
.btn.primary:hover { background: var(--teal-dark); border-color: var(--teal-dark); }
.btn.ghost { background: transparent; }
.btn.ghost:hover { background: var(--teal-mist); }
.btn.danger { color: var(--red); border-color: #f0b8b5; }
.btn.danger:hover { background: var(--red-light); border-color: var(--red); }
.btn.sm { padding: 5px 11px; font-size: 12px; }
.btn:disabled { opacity: .45; cursor: not-allowed; pointer-events: none; }

/* ── Skupne kartice ──────────────────────────────────────────── */
.card {
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: 20px;
  margin-bottom: 16px;
}

/* ── Badge ───────────────────────────────────────────────────── */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 700;
}
.badge.green { background: var(--green-light); color: var(--green); }
.badge.red   { background: var(--red-light); color: var(--red); }
.badge.yellow{ background: var(--yellow-light); color: var(--yellow); }
.badge.blue  { background: var(--blue-light); color: var(--blue); }
.badge.gray  { background: #f0f2f4; color: var(--ink-soft); }

/* ── Toast ───────────────────────────────────────────────────── */
#toast {
  position: fixed;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%) translateY(80px);
  background: var(--ink);
  color: #fff;
  padding: 10px 20px;
  border-radius: 20px;
  font-size: 13.5px;
  z-index: 9999;
  pointer-events: none;
  transition: transform .25s ease;
  white-space: nowrap;
  box-shadow: var(--shadow-lg);
}
#toast.show { transform: translateX(-50%) translateY(0); }
#toast.error { background: var(--red); }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .topbar { padding: 0 14px; gap: 6px; height: 52px; }
  .topbar-brand-text span { display: none; }
  .topbar-brand-text b { font-size: 13px; }
  .topbar-brand img { height: 28px; }
  .tb-btn, .topbar button, .topbar a.tb-link { padding: 5px 10px; font-size: 12px; }
}

/* ════════════════════════════════════════════════════════════════
   DARK MODE
   Aktivira se z: document.body.classList.add('dark')
   Shranjuje se v: localStorage['ek_tema'] = 'dark'
   ════════════════════════════════════════════════════════════════ */

body.dark {
  --teal:        #4bbcc8;
  --teal-dark:   #3a9aa5;
  --teal-deep:   #2d7f8a;
  --teal-light:  rgba(75,188,200,.12);
  --teal-mist:   rgba(75,188,200,.07);

  --ink:         #e2eaed;
  --ink-mid:     #b0c4cc;
  --ink-soft:    #7a9aa5;
  --ink-muted:   #4d6b75;
  --border:      #2a3d44;
  --bg:          #0f1c21;
  --white:       #162028;

  --green:       #3bbd82;
  --green-light: rgba(59,189,130,.12);
  --red:         #e05a52;
  --red-light:   rgba(224,90,82,.12);
  --yellow:      #dda03a;
  --yellow-light:rgba(221,160,58,.12);
  --blue:        #4d9de0;
  --blue-light:  rgba(77,157,224,.12);

  --shadow-sm:   0 1px 3px rgba(0,0,0,.4);
  --shadow-md:   0 3px 12px rgba(0,0,0,.5);
  --shadow-lg:   0 6px 28px rgba(0,0,0,.6);

  background: var(--bg);
  color: var(--ink);
}

/* Topbar dark */
body.dark .topbar {
  background: linear-gradient(135deg, #0d1a1f 0%, #162a32 50%, #1e3d47 100%);
  box-shadow: 0 2px 16px rgba(0,0,0,.5);
}

/* Kartice dark */
body.dark .card {
  background: var(--white);
  border: 1px solid var(--border);
}

/* Gumbi dark */
body.dark .btn {
  background: var(--white);
  border-color: var(--border);
  color: var(--ink);
}
body.dark .btn:hover {
  background: rgba(75,188,200,.1);
  border-color: var(--teal);
  color: var(--teal);
}
body.dark .btn.primary {
  background: var(--teal-deep);
  border-color: var(--teal);
  color: #fff;
}
body.dark .btn.primary:hover { background: var(--teal-dark); }
body.dark .btn.ghost:hover { background: rgba(75,188,200,.08); }

/* Tabele dark */
body.dark table { border-color: var(--border); }
body.dark th { background: #1a2d35 !important; color: var(--ink-soft) !important; border-color: var(--border) !important; }
body.dark td { border-color: var(--border) !important; }
body.dark tr:hover td { background: rgba(75,188,200,.05) !important; }

/* Inputi dark */
body.dark input,
body.dark select,
body.dark textarea {
  background: #1a2d35;
  border-color: var(--border);
  color: var(--ink);
}
body.dark input:focus,
body.dark select:focus,
body.dark textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px rgba(75,188,200,.15);
}

/* Modal dark */
body.dark .modal-bg,
body.dark .overlay-bg {
  background: rgba(0,0,0,.75);
}
body.dark .modal,
body.dark [style*="background:#fff"],
body.dark [style*="background: #fff"] {
  background: #1a2d35 !important;
  border: 1px solid var(--border);
}

/* Badges dark */
body.dark .badge.green  { background: var(--green-light);  color: var(--green); }
body.dark .badge.red    { background: var(--red-light);    color: var(--red); }
body.dark .badge.yellow { background: var(--yellow-light); color: var(--yellow); }
body.dark .badge.blue   { background: var(--blue-light);   color: var(--blue); }
body.dark .badge.gray   { background: #1a2d35; color: var(--ink-soft); }

/* Muted tekst */
body.dark .muted { color: var(--ink-soft) !important; }

/* Scrollbar dark */
body.dark ::-webkit-scrollbar { width: 6px; height: 6px; }
body.dark ::-webkit-scrollbar-track { background: #0f1c21; }
body.dark ::-webkit-scrollbar-thumb { background: #2a3d44; border-radius: 3px; }
body.dark ::-webkit-scrollbar-thumb:hover { background: var(--teal-deep); }

/* ── Gumb za preklop teme ────────────────────────────────────── */
#tema-preklop {
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 16px;
  transition: background .15s;
  flex-shrink: 0;
}
#tema-preklop:hover { background: rgba(255,255,255,.25); }

/* Anti-flash: skrij vsebino pred nalaganjem teme */
body.tema-nalaganje { visibility: hidden; }

/* ── Page-specifični dark mode dopolnili ─────────────────────── */

/* app.html — koraki, plan, vprašalnik */
body.dark .step-bar,
body.dark .steps-row { background: #162028 !important; border-color: var(--border) !important; }
body.dark .step .circle { border-color: var(--border); color: var(--ink-soft); }
body.dark .step.active .circle { border-color: var(--teal); color: var(--teal); background: var(--teal-light); }
body.dark .step.done .circle { background: var(--teal); border-color: var(--teal); }
body.dark .std-card { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .std-card.selected { background: var(--teal-light) !important; border-color: var(--teal) !important; }
body.dark .std-card .std-sub { color: var(--ink-soft); }
body.dark .profile-card { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .profile-card.selected { background: var(--teal-light) !important; border-color: var(--teal) !important; }
body.dark .q-item { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .q-item:hover { background: rgba(75,188,200,.06) !important; }
body.dark .q-btn { background: #1a2d35 !important; border-color: var(--border) !important; color: var(--ink-soft) !important; }
body.dark .q-btn.sel { color: #fff !important; }
body.dark .topbar-brand-text span { opacity: .65; }
body.dark .plan-card { background: var(--white) !important; border-color: var(--border) !important; }

/* home.html — dashboard */
body.dark .dash-col { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .dash-item { border-color: var(--border) !important; }
body.dark .dash-item:hover { background: rgba(75,188,200,.07) !important; }
body.dark .module-tile { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .module-tile:hover:not(.disabled) { border-color: var(--teal) !important; }
body.dark .module-tile.disabled { opacity: .4; }
body.dark .module-badge { background: var(--teal-light); color: var(--teal); }

/* admin.html — tabela, overlay */
body.dark .tab { color: var(--ink-soft); }
body.dark .tab.active { color: var(--teal); border-bottom-color: var(--teal); }
body.dark .checkitem { background: var(--white) !important; border-color: var(--border) !important; color: var(--ink) !important; }
body.dark .checkitem.checked { background: var(--teal-light) !important; border-color: var(--teal) !important; }
body.dark .pill { background: #1a2d35 !important; }
body.dark .error-box { background: var(--red-light) !important; color: var(--red) !important; }

/* dokumenti.html */
body.dark .doc-row { border-color: var(--border) !important; }
body.dark .doc-row:hover { background: rgba(75,188,200,.06) !important; }
body.dark .status-badge { filter: brightness(0.85) saturate(0.9); }

/* pritozbe/capa */
body.dark .list-item { background: var(--white) !important; border-color: var(--border) !important; }
body.dark .list-item:hover { background: rgba(75,188,200,.07) !important; }
body.dark .detail-panel { background: var(--white) !important; border-color: var(--border) !important; }

/* Overlay/modalni pojavni okni z inline style */
body.dark [id*="Overlay"] > div,
body.dark [id*="overlay"] > div,
body.dark [id*="Modal"] > div,
body.dark [id*="modal"] > div {
  background: #1a2d35 !important;
  border: 1px solid var(--border);
}
body.dark hr { border-color: var(--border) !important; }
body.dark label { color: var(--ink) !important; }
body.dark .field label { color: var(--ink-soft) !important; }
body.dark b, body.dark strong { color: var(--ink); }
body.dark .sub, body.dark .muted, body.dark [class*="muted"],
body.dark [style*="color:#5b"], body.dark [style*="color: #5b"],
body.dark [style*="color:#8b"], body.dark [style*="color: #8b"] {
  color: var(--ink-soft) !important;
}
