/* -----------------------------------
   NOVA ERP / INVENTORY – v2 design
   Egységes háttér • Topbar • Kártyák • Táblák • Reszponzív finomítások
----------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Exo+2:wght@600;700;800&family=Inter:wght@400;500;600;700&display=swap');
@import url('/assets/css/design_tokens.css');

:root {
  color-scheme: light;
}

html, body,
input, select, textarea, button {
  font-family: var(--nova-font-body);
}

h1, h2, h3, h4, h5, h6,
.page-title,
.card-title,
.brand,
.topbar .brand-link {
  font-family: var(--nova-font-heading);
}

/* Háttér – minden oldalra */
body.nova-bg {
  min-height: 100vh;
  margin: 0;
  background: linear-gradient(
    135deg,
    var(--nova-bg-grad-1),
    var(--nova-bg-grad-2),
    var(--nova-bg-grad-3)
  );
  background-size: 400% 400%;
  animation: gradientBG 15s ease infinite;
  font-family: var(--nova-font-body);
  /* sticky footer support */
  display: flex;
  flex-direction: column;
  position: relative;
}
    @keyframes gradientBG {
      0%{background-position:0% 50%}
      50%{background-position:100% 50%}
      100%{background-position:0% 50%}
    }

/* Alap dobozmodel és margin reset */
*,
*::before,
*::after { box-sizing: border-box; }

/* Shell (belső tartalom) */
.shell {
  max-width: var(--nova-shell-max);
  margin: 0 auto;
  padding: var(--nova-space-6) var(--nova-shell-pad-x) var(--nova-shell-pad-bottom) var(--nova-shell-pad-x);
  position: relative;
  z-index: 1;
}

/* Alternate page-shell used by some views */
.page-shell { max-width: 1200px; margin: 0 auto; padding: var(--nova-space-6) var(--nova-shell-pad-x) var(--nova-shell-pad-bottom); width: 100%; }

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0;
  min-height: var(--nova-topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: nowrap;
  gap: var(--nova-space-3);
  background: var(--nova-color-surface-glass);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  padding: 10px var(--nova-space-5);
  z-index: 100;
  border-bottom: 1px solid var(--nova-color-border-soft);
}

.brand {
  font-size: var(--nova-font-size-xl);
  font-weight: 800;
  color: var(--nova-color-white);
  letter-spacing: 0.3px;
  display: flex; align-items: center; gap: var(--nova-space-3);
  flex: 0 1 auto;
  min-width: 0;
}
.brand .muted { opacity: .75; font-weight: 600; }

/* Make brand clickable like elsewhere, and keep hover subtle */
.brand a { color: var(--nova-color-white); text-decoration: none; display: inline-flex; align-items: center; gap: var(--nova-space-3); }
.brand a:hover { opacity: .9; }

.topright { display: flex; align-items: center; gap: var(--nova-space-3); }

/* Support both class names for topbar groups */
.topbar-left, .topbar-right { display: flex; align-items: center; gap: var(--nova-space-3); }
.topbar-right { flex: 0 0 auto; min-width: 0; }

.topbar-center {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  min-width: 0;
  padding: 0 12px;
  overflow: hidden;
}

.topbar-spacer {
  display: none !important;
}

.topbar + .shell,
.topbar + .page-shell,
.topbar + .dashboard-layout,
.topbar + .app-page,
.topbar + .page-items {
  margin-top: var(--nova-space-4);
}

.location-switch-form {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  max-width: min(100%, 640px);
}

.topbar-location-label {
  padding: 4px 10px;
  border-radius: 999px;
  font-weight: 600;
  background: rgba(255,255,255,.14);
  color: var(--nova-color-white);
  border: 1px solid rgba(255,255,255,.28);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  min-width: 0;
  max-width: min(520px, 42vw);
  flex: 1 1 auto;
  overflow: hidden;
}
.topbar-location-label > span:not(.topbar-location-role) {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.topbar-location-role {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  opacity: .78;
}

.topbar-location-select {
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--nova-color-border-soft);
  background: var(--nova-color-surface-glass);
  color: var(--nova-color-white);
  min-width: 92px;
  width: 110px;
  max-width: 110px;
  flex: 0 0 110px;
}

.topbar-location-select option {
  color: #111;
}

/* Menü gomb és panel */
.menu { position: relative; }
.menu-btn {
  background: var(--nova-color-surface-glass);
  color: var(--nova-color-white);
  border: 1px solid var(--nova-color-border-soft);
  border-radius: var(--nova-radius-md);
  padding: var(--nova-space-2) var(--nova-space-4);
  cursor: pointer;
  transition: transform var(--nova-motion-fast), background var(--nova-motion-normal), box-shadow var(--nova-motion-normal), border-color var(--nova-motion-normal);
  box-shadow: var(--nova-shadow-md);
}
.menu-btn:hover { background: var(--nova-color-surface-glass-hover); transform: translateY(-1px); }
.menu-btn:active { transform: translateY(0); }

.menu-panel {
  display: none;
  position: absolute;
  top: calc(100% + var(--nova-space-2)); right: 0;
  min-width: 240px;
  background: var(--nova-color-surface-glass-2);
  border: 1px solid var(--nova-color-border-strong);
  border-radius: var(--nova-radius-lg);
  backdrop-filter: blur(20px) saturate(140%);
  box-shadow: var(--nova-shadow-lg);
  padding: var(--nova-space-3);
  z-index: 200;
}
.menu.open .menu-panel { display: block; }
.menu-panel a,
.menu-panel button {
  width: 100%;
  display: flex; align-items: center; gap: var(--nova-space-3);
  text-decoration: none; color: var(--nova-color-text);
  background: var(--nova-color-surface-glass-2);
  border: 1px solid var(--nova-color-border-strong);
  border-radius: var(--nova-radius-md);
  padding: var(--nova-space-3) var(--nova-space-4);
  margin: 6px 0;
  transition: background var(--nova-motion-normal), border-color var(--nova-motion-normal), transform var(--nova-motion-fast), color var(--nova-motion-normal);
}
.menu-panel a:hover, .menu-panel button:hover {
  background: var(--nova-color-surface-glass-hover);
  border-color: rgba(16,58,143,.4);
  color: #0b2c74;
  transform: translateY(-1px);
}

/* --- Topbar menu hardening / compatibility selectors --- */
/* Some templates render the menu container with different class names.  
   Treat any of these as dropdown panels and hide them until the menu is open. */
.topbar .menu-panel,
.topbar .menu-dropdown,
.topbar .topmenu,
.topbar .menu-links,
.topbar .menu-items {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 240px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.4);
  padding: 10px;
  z-index: 200;
  display: none; /* hidden by default */
}
/* Show when menu wrapper has .open */
.topbar .menu.open .menu-panel,
.topbar .menu.open .menu-dropdown,
.topbar .menu.open .topmenu,
.topbar .menu.open .menu-links,
.topbar .menu.open .menu-items { display: block; }

/* Make links inside any of the panels look like buttons */
.topbar .menu-panel a, .topbar .menu-panel button,
.topbar .menu-dropdown a, .topbar .menu-dropdown button,
.topbar .topmenu a, .topbar .topmenu button,
.topbar .menu-links a, .topbar .menu-links button,
.topbar .menu-items a, .topbar .menu-items button {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: #fff;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px;
  padding: 10px 12px; margin: 6px 0;
  transition: background .2s ease, border-color .2s ease, transform .12s ease;
}
.topbar .menu-panel a:hover, .topbar .menu-panel button:hover,
.topbar .menu-dropdown a:hover, .topbar .menu-dropdown button:hover,
.topbar .topmenu a:hover, .topbar .topmenu button:hover,
.topbar .menu-links a:hover, .topbar .menu-links button:hover,
.topbar .menu-items a:hover, .topbar .menu-items button:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.25);
  transform: translateY(-1px);
}

/* Prevent raw links accidentally showing inline inside the topbar */
.topbar .menu > a:not(.menu-btn),
.topbar .menu > span > a {
  display: none;
}
.topbar .menu.open > a:not(.menu-btn),
.topbar .menu.open > span > a {
  display: flex; /* will be captured by the rules above */
}

/* Nyelvválasztó */
.langmenu select {
  background: var(--nova-color-surface-glass);
  color: var(--nova-color-white);
  border: 1px solid var(--nova-color-border-soft);
  border-radius: var(--nova-radius-pill);
  padding: 6px var(--nova-space-3);
  cursor: pointer;
  font-size: var(--nova-font-size-sm);
}

/* Legacy language selector (same look as .langmenu) */
.langform select {
  background: var(--nova-color-surface-glass);
  color: var(--nova-color-white);
  border: 1px solid var(--nova-color-border-soft);
  border-radius: var(--nova-radius-pill);
  padding: 6px var(--nova-space-3);
  cursor: pointer;
  font-size: var(--nova-font-size-sm);
}

/* Értesítés ikon */
.notif-bell {
  position: relative;
  background: none; border: none;
  color: #fff; font-size: 22px; cursor: pointer;
  transition: transform .12s ease, opacity .2s ease;
}
.notif-bell:hover { transform: translateY(-1px); opacity: .9; }
.notif-bell .badge {
  position: absolute; top: 2px; right: 0;
  background: #ef4444; color: #fff;
  border-radius: 999px; font-size: 11px; font-weight: 700;
  padding: 2px 6px; border: 1px solid rgba(255,255,255,.25);
}

/* Notification dropdown (glass panel like menu) */
.notif { position: relative; }  /* wrapper a harang köré */
.notif-panel,
.notif-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 320px;
  max-width: 90vw;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 14px;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  box-shadow: 0 16px 40px rgba(0,0,0,.4);
  padding: 10px;
  z-index: 210;
}
.notif.open .notif-panel,
.notif.open .notif-dropdown { display: block; }

.notif-list { display: grid; gap: 8px; }
.notif-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; padding: 10px 12px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 10px;
}
.notif-item .meta { font-size: 12px; opacity: .85; }

/* Soft cream-red badge for NEW */
.badge-alert {
  background: #fde2e2;        /* krém piros */
  color: #b91c1c;             /* sötétebb piros szöveg */
  border: 1px solid rgba(185,28,28,.25);
}

/* Kijelentkezés */
.logout-btn {
  background: var(--nova-btn-danger-bg-2); border: none; color: #fff;
  padding: 8px 16px; border-radius: 12px;
  font-weight: 600; cursor: pointer;
  transition: background .15s ease, transform .12s ease, box-shadow .2s ease;
  box-shadow: var(--nova-btn-danger-shadow);
}
.logout-btn:hover { background: #dc2626; transform: translateY(-1px); }
.logout-btn:active { transform: translateY(0); }

/* ---------- Kártyák / Widgetek ---------- */
.card,
.glass-card {
  border: 1px solid var(--nova-card-border);
  border-radius: 18px;
  background: var(--nova-card-bg);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--nova-card-shadow);
  padding: 18px;
  color: var(--nova-table-text);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: var(--nova-card-shadow-hover);
  border-color: var(--nova-card-border-hover);
  background: var(--nova-card-bg-hover);
}
.card h2 { margin: 0 0 8px; font-size: 18px; color: var(--nova-table-text); }

/* Lista elemek */
.list { display: grid; gap: 10px; }
.list .item {
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  padding: 10px 12px;
  transition: background .2s ease, border-color .2s ease, transform .12s ease;
}
.list .item:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255,255,255,.2);
  transform: translateY(-1px);
}

/* ---------- Grid layout ---------- */
.grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  max-width: 1200px;
  margin: 24px auto;
  padding: 0 12px;
}

/* ---------- Gombok ---------- */
.btn {
  background: var(--nova-btn-bg);
  color: var(--nova-btn-text);
  border: 1px solid var(--nova-btn-border);
  border-radius: 14px;
  padding: 10px 16px;
  cursor: pointer;
  font-size: 14px;
  text-decoration: none;
  transition: background .2s, border-color .2s, transform .12s ease, box-shadow .2s ease;
  box-shadow: var(--nova-btn-shadow);
  font-weight: 700;
}
.btn:hover { background: var(--nova-btn-bg-hover); border-color: var(--nova-btn-border-hover); transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn.primary {
  background: var(--nova-btn-primary-bg);
  color: var(--nova-btn-primary-text, #fff);
  border-color: rgba(255,255,255,.0);
  box-shadow: var(--nova-btn-primary-shadow);
}
.btn.primary:hover { background: var(--nova-btn-primary-bg-hover); }
.btn.ghost {
  background: var(--nova-btn-ghost-bg);
  color: var(--nova-btn-ghost-text);
  border-color: var(--nova-btn-ghost-border);
  box-shadow: var(--nova-btn-ghost-shadow);
}
.btn.ghost:hover {
  background: var(--nova-btn-ghost-bg-hover);
}

/* Backward/forward-compatible variant aliases */
.btn.btn--ghost {
  background: var(--nova-btn-ghost-bg);
  color: var(--nova-btn-ghost-text);
  border-color: var(--nova-btn-ghost-border);
  box-shadow: var(--nova-btn-ghost-shadow);
}
.btn.btn--ghost:hover {
  background: var(--nova-btn-ghost-bg-hover);
}

.btn.danger,
.btn.btn--danger {
  background: var(--nova-btn-danger-bg);
  color: #fff;
  border: 1px solid var(--nova-btn-danger-border);
  box-shadow: var(--nova-btn-danger-shadow);
}
.btn.danger:hover,
.btn.btn--danger:hover {
  filter: brightness(1.05);
}

/* Button variants */
.btn.sm { padding: 6px 10px; font-size: 13px; border-radius: 10px; }
.btn.btn--sm { padding: 6px 10px; font-size: 13px; border-radius: 10px; }
.btn.icon { width: 36px; height: 36px; padding: 0; display: inline-flex; align-items: center; justify-content: center; }
.btn:disabled,
.btn[disabled] { opacity: .6; cursor: not-allowed; filter: saturate(.7); }

/* Language pills like on the index hero */
.pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  color: #0f172a;
  font-weight: 700;
  font-size: 13px;
  border: 1px solid rgba(255,255,255,.95);
  box-shadow: 0 6px 16px rgba(31,41,55,.12);
}
.pill.active { background: #10bce0; color: #fff; border-color: transparent; }

/* ---------- Táblák ---------- */
table { width: 100%; border-collapse: collapse; color: var(--nova-table-text); }
th, td { padding: 10px 12px; border-top: 1px solid var(--nova-table-border); }
th { color: var(--nova-table-th-text); font-weight: 600; }

/* ---------- Form elemek ---------- */
select, textarea,
input[type="text"],
input[type="email"],
input[type="password"] {
  width: 100%;
  background: rgba(255,255,255,.9);
  color: #0f172a;
  border: 1px solid rgba(15,23,42,.1);
  border-radius: 12px;
  padding: 10px 12px;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
input::placeholder, textarea::placeholder { color: rgba(15,23,42,.55); }
input:focus, select:focus, textarea:focus {
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 3px rgba(37,99,235,.2);
  background: #fff;
}

/* Shared search bar controls used on dashboard/search widgets */
.searchbar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.searchbar input,
.searchbar select {
  flex: 1 1 220px;
  min-height: 42px;
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.92);
  color: #0f172a;
}
.searchbar input:focus,
.searchbar select:focus {
  border-color: rgba(37,99,235,.55);
  box-shadow: 0 0 0 3px rgba(37,99,235,.2);
  background: #fff;
}

/* ---------- Mikro animációk ---------- */
a { color: #1d4ed8; text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- Finom scrollbar ---------- */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb {
  background: #000;
  border-radius: 10px;
  border: 2px solid rgba(0,0,0,0);
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: #111; }
html { scrollbar-color: #000 rgba(0,0,0,.14); }

/* ---------- Modal (note dialog) ---------- */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--nova-modal-backdrop-bg);
  display: none;
  justify-content: center;
  align-items: center;
  z-index: var(--nova-modal-z);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.modal-overlay.open,
.modal-overlay.show { display: flex; }
.modal {
  position: relative;
  width: var(--nova-modal-width);
  max-height: var(--nova-modal-max-h);
  overflow-y: auto;
  background: var(--nova-modal-bg);
  color: var(--nova-modal-fg);
  border: 1px solid var(--nova-modal-border);
  border-radius: var(--nova-modal-radius);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--nova-modal-shadow);
  padding: var(--nova-modal-pad);
  margin: 0 auto;
  transform: translateY(0);
  animation: modalFadeIn 0.25s ease-out;
}
@keyframes modalFadeIn {
  from { opacity: 0; transform: translateY(15px); }
  to   { opacity: 1; transform: translateY(0); }
}
.modal header { font-weight: 800; margin-bottom: 10px; }
.modal .actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 12px; }

/* ---------- Feedback / Toast & inline save chip ---------- */

/* Inline "saved" badge you can place near a row or button */
.save-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 12px;
  line-height: 1;
  background: var(--nova-success-bg);
  color: var(--nova-success-text);
  border: 1px solid var(--nova-success-border);
  box-shadow: var(--nova-success-shadow);
  backdrop-filter: blur(8px);
}
.save-badge.success {
  background: var(--nova-success-bg-strong);
  border-color: var(--nova-success-border-strong);
}
.save-badge .dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--nova-success-dot);
  box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.18);
}

/* Bottom "toast" that slides up on save */
.toast {
  position: fixed;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%) translateY(12px);
  opacity: 0;
  padding: 10px 14px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 13px;
  z-index: 10000;
  background: var(--nova-toast-bg);
  color: var(--nova-toast-text);
  border: 1px solid var(--nova-toast-border);
  box-shadow: var(--nova-toast-shadow);
  backdrop-filter: blur(10px);
  transition: transform .18s ease, opacity .18s ease;
}
.toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}
.toast.success {
  background: linear-gradient(180deg, var(--nova-toast-success-grad-top), var(--nova-toast-success-grad-bottom));
  color: #fff;
  border: 1px solid rgba(16,185,129,.9);
  box-shadow: var(--nova-toast-success-shadow);
}

.toast.error {
  background: linear-gradient(180deg, var(--nova-toast-error-grad-top), var(--nova-toast-error-grad-bottom));
  color: #fff;
  border: 1px solid rgba(239,68,68,.9);
  box-shadow: var(--nova-toast-error-shadow);
}

/* --- Flash highlight on successful save (2s) --- */
/* Apply to a row or any input wrapper after a successful save, then remove after timeout */
tr.flash-ok,
.flash-ok,
.flash-ok input {
  outline: 2px solid #10b981; /* emerald-500 */
  box-shadow:
    0 0 0 3px rgba(16,185,129,.22),
    0 14px 34px rgba(16,185,129,.22);
  background: rgba(16,185,129,.08);
  transition: outline-color .25s ease, box-shadow .25s ease, background .25s ease;
}

/* ---------- Reszponzív finomítások ---------- */
@media (max-width: 900px) {
  .grid { gap: 14px; }
  .shell { padding: 70px 18px 36px; }
  .brand { font-size: 20px; }
  .topbar {
    flex-wrap: wrap;
    min-height: var(--nova-topbar-h);
    height: auto;
    padding-top: 8px;
    padding-bottom: 8px;
  }
  .topbar-center {
    order: 3;
    width: 100%;
    justify-content: flex-start;
    padding: 0;
    margin-top: 4px;
  }
}
@media (max-width: 600px) {
  .topbar { height: 50px; padding: 0 12px; }
  .shell { padding: 60px 14px 28px; }
  .brand { font-size: 18px; }
  .topright { gap: 8px; }
  .menu-panel { min-width: 220px; right: 0; }
  .btn, .menu-btn { padding: 8px 12px; font-size: 13px; }

  .topbar-left, .topbar-right, .topright { gap: 6px; }
  .menu-btn { padding: 6px 10px; }
}
@media (max-width: 400px) {
  .brand { font-size: 16px; }
  .topright { gap: 6px; }
  .langmenu select { padding: 4px 8px; font-size: 12px; }
}

/* ---------- Hasznos utilok ---------- */
.center { display: flex; align-items: center; justify-content: center; }
.row { display: flex; gap: 12px; align-items: center; }
.spacer { height: 16px; }
.maxw-1200 { max-width: 1200px; margin: 0 auto; }
.text-muted { color: rgba(255,255,255,.75); }

/* Index hero helper (big card) */
.hero-card {
  padding: 26px 28px;
  border-radius: 20px;
  background: rgba(255,255,255,.35);
  border: 1px solid rgba(255,255,255,.5);
  box-shadow: 0 22px 60px rgba(31,41,55,.28);
}
.hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }

/* ===== Warehouse page layout polish ===== */
.page-shell.container { max-width: 1280px; width: 100%; padding: 24px 16px 32px; margin: 0 auto; }

/* inline search bar */
.form-inline { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.form-inline .search-input { flex: 1 1 360px; min-width: 220px; }

/* table spacing + zebra and hover */
.table { width: 100%; border-collapse: collapse; color: var(--nova-table-text); }
.table th, .table td { padding: 12px 14px; border-top: 1px solid var(--nova-table-border); }
.table tr:nth-child(even) { background: var(--nova-table-row-even); }
.table tr:hover { background: var(--nova-table-row-hover); }

/* adjust column width for qty controls*/
.col-adjust { width: 220px; }

/* page footer actions */
.page-actions { display: flex; justify-content: center; margin-top: 18px; }
.footer { margin: 24px auto 12px; text-align: center; color: #666; opacity: .9; }
body.nova-bg > .footer { margin-top: auto; }
.footer--core {
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:12px;
  width:100%;
  color:#111;
}
.footer__text { margin:0; }

/* small helper for the back link button that sits above tables */
.btn.back { background: var(--nova-btn-ghost-bg); color: var(--nova-btn-ghost-text); border-color: var(--nova-btn-ghost-border); }
.btn.back:hover { background: var(--nova-btn-ghost-bg-hover); }


.form-inline { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.form-inline .search-input { flex: 1 1 480px; min-width: 220px; }

.modal-overlay.show {
  opacity: 1;
  animation: fadeIn 0.2s ease;
}

@keyframes fadeIn {
  from { opacity: 0; transform: scale(0.96); }
  to { opacity: 1; transform: scale(1); }
}
/* ===== Warehouse v2 – wide editable table polish ===== */

/* Wrap table to enable horizontal scroll on narrow screens while keeping a nice shadow */
/* stabilabb görgetés, ne mozduljon a body */
.table-wrap {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  scrollbar-gutter: stable both-edges; /* ahol támogatott: ne ugráljon a layout a scrollbar miatt */
  border-radius: 18px;
  box-shadow: var(--nova-table-wrap-shadow);
  padding-bottom: 4px; /* hogy a vízszintes scrollbar ne takarja ki az alsó szegélyt */
}

/* kicsi, diszkrét vízszintes scrollbar csak a wrapra */
.table-wrap::-webkit-scrollbar { height: 10px; }
.table-wrap::-webkit-scrollbar-thumb {
  background: #000;
  border-radius: 10px;
}

/* bal/jobb “fény” jelzés görgethető tartalomnál */
.table-wrap::before,
.table-wrap::after {
  content: "";
  position: absolute;
  top: 0;
  width: 24px;
  height: 100%;
  pointer-events: none;
  opacity: .0;
  transition: opacity .15s ease;
  border-radius: 18px;
}
.table-wrap::before {
  left: 0;
  background: linear-gradient(to right, var(--nova-table-wrap-fade), rgba(255,255,255,0));
}
.table-wrap::after {
  right: 0;
  background: linear-gradient(to left, var(--nova-table-wrap-fade), rgba(255,255,255,0));
}
.table-wrap::before { opacity: calc(var(--has-scroll,0) * (1 - var(--at-start,0))); }
.table-wrap::after  { opacity: calc(var(--has-scroll,0) * (1 - var(--at-end,0))); }

/* ha szeretnél teljes megoldást: kis JS-sel jelezd amikor elindult/lejárt a scroll */

/* Dedicated warehouse table layout */
.table.warehouse {
  width: 100%;
  min-width: 1150px; /* keep columns readable on desktop */
  color: var(--nova-table-text);
  border-collapse: collapse;
  background: var(--nova-table-warehouse-bg);
  border: 1px solid var(--nova-table-warehouse-border);
  border-radius: 18px;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
}
.table.warehouse th,
.table.warehouse td {
  padding: 12px 14px;
  border-top: 1px solid var(--nova-table-border);
  vertical-align: middle;
  white-space: nowrap;
}
.table.warehouse thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--nova-table-warehouse-head-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Reusable modernized tables (items/invites/inventory) */
.table-wrap .tbl,
.table-wrap .inv-list {
  width: 100%;
  min-width: 980px;
  color: var(--nova-table-text);
  border-collapse: collapse;
  background: var(--nova-table-warehouse-bg);
  border: 1px solid var(--nova-table-warehouse-border);
  border-radius: 18px;
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
}
.table-wrap .tbl th,
.table-wrap .tbl td,
.table-wrap .inv-list th,
.table-wrap .inv-list td {
  padding: 12px 14px;
  border-top: 1px solid var(--nova-table-border);
  vertical-align: middle;
}
.table-wrap .tbl thead th,
.table-wrap .inv-list thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: var(--nova-table-warehouse-head-bg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Stable row action zone on the right edge */
.table-wrap th.action-zone,
.table-wrap td.action-zone,
.table-wrap th.row-actions,
.table-wrap td.row-actions,
td.row-actions {
  position: sticky;
  right: 0;
  z-index: 4;
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-left: 1px solid var(--nova-table-border);
  box-shadow: -6px 0 14px rgba(31,41,55,.12);
}
.table-wrap th.action-zone,
.table-wrap th.row-actions {
  z-index: 5;
  text-align: left;
  white-space: nowrap;
}
.table-wrap td.action-zone .btn-group,
.table-wrap td.row-actions .btn-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
}

/* Inputs inside cells: consistent height & radius */
.table.warehouse input[type="text"],
.table.warehouse input[type="number"] {
  height: 36px;
  border-radius: 10px;
  padding: 6px 10px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.12);
  color: #0f172a;
}

/* Utility widths for tight columns */
.w-64  { width: 64px !important;  max-width: 64px !important; }
.w-80  { width: 80px !important;  max-width: 80px !important; }
.w-96  { width: 96px !important;  max-width: 96px !important; }
.w-120 { width: 120px !important; max-width: 120px !important; }
.w-160 { width: 160px !important; max-width: 160px !important; }

/* Apply narrower look to min/max/coord/extra fields */
.cell-narrow input { width: 80px; }
.cell-qty    input { width: 72px; text-align: center; }
.cell-code   input { width: 200px; }

/* Row "adjust" actions pinned to the right so they never jump out of view */
td.row-actions {
  position: sticky;
  right: 0;
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-left: 1px solid rgba(15,23,42,.08);
  box-shadow: -6px 0 14px rgba(31,41,55,.12);
  z-index: 2;
}

/* Compact action buttons in the adjust column */
.row-actions .btn { min-width: 34px; height: 34px; padding: 0 10px; font-size: 13px; border-radius: 10px; }
.row-actions .btn.icon { width: 34px; }

/* “Apply” button visual priority */
.row-actions .btn.apply {
  background: #0f172a;
  color: #fff;
  border-color: transparent;
  box-shadow: 0 10px 24px rgba(15,23,42,.28);
}
.row-actions .btn.apply:hover { background: #111827; }

/* Better spacing for back button below the table */
.page-actions { margin-top: 22px; }

/* Mobile & tablet refinements */
@media (max-width: 1200px) {
  .table.warehouse { min-width: 1000px; }
}
@media (max-width: 992px) {
  .table.warehouse { min-width: 900px; }
  .cell-narrow input { width: 72px; }
}
@media (max-width: 768px) {
  .shell, .page-shell.container { padding-left: 12px; padding-right: 12px; }
  .table.warehouse { min-width: 760px; }
  .table-wrap .tbl,
  .table-wrap .inv-list { min-width: 760px; }
  .row-actions .btn { height: 32px; min-width: 32px; }
  .cell-code input { width: 250px; }
}
@media (max-width: 560px) {
  .table.warehouse { min-width: 700px; }
  .table-wrap .tbl,
  .table-wrap .inv-list { min-width: 700px; }
  .w-120 { width: 200px !important; }
  .cell-code input { width: 250px; }
}
/* ===== Toolbar layout (items & warehouse) ===== */
.toolbar { margin: 6px 0 12px; }
.toolbar__row{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;          /* prevent overlap on smaller widths */
}
.toolbar__left{
  display:flex;
  align-items:center;
  gap:12px;
  flex:1 1 auto;
  min-width:0;
}
.toolbar__right{
  margin-left:auto;        /* push right-side actions to the edge */
  flex:0 0 auto;
}
/* Stretch search input to the end of the container */
.input--lg.input--stretch{
  flex:1 1 640px;
  min-width:260px;
}
/* Make the search field solid white with dark text */
.toolbar--search .input,
.toolbar--search input[type="text"],
.toolbar--search input[type="search"]{
  background:#ffffff !important;
  color:#0f172a !important;
  border:1px solid rgba(15,23,42,.14);
}
.toolbar--search .input::placeholder,
.toolbar--search input::placeholder{
  color:#6b7280; /* neutral placeholder */
}
/* Keep the warehouse selector a stable width; prevent wrap jitter */
.toolbar--search .select{
  flex:0 0 260px;
  min-width:220px;
}

/* Avoid toolbar element overlap & keep buttons from stretching */
.toolbar__row > * { flex: 0 0 auto; }
.toolbar .btn { flex: 0 0 auto; }

/* Ensure the stretch input actually grows to the edge */
.toolbar__left .input--stretch,
.input--stretch.input--lg { flex: 1 1 640px; min-width: 260px; }

/* Solid white search field with dark text (enforced) */
.toolbar--search .search-input,
.toolbar--search .input--stretch,
.toolbar--search input[type="search"],
.toolbar--search input[type="text"] {
  background: #ffffff !important;
  color: #0f172a !important;
  border: 1px solid rgba(15,23,42,.14);
}
.toolbar--search input::placeholder { color: #6b7280; }

/* Consolidated qty controls (single source of truth) */
.qty-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.qty-controls .btn {
  min-width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  line-height: 36px;
}
.qty-controls input[type="number"],
.qty-controls input[type="text"] {
  width: 72px;
  height: 36px;
  text-align: center;
}

/* Generic dropdown helper (used by ui.php or anywhere) */
.dropdown { position: relative; }
.dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 240px;
  background: rgba(15, 28, 52, 0.82);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 14px;
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  box-shadow: 0 16px 40px rgba(0,0,0,.45);
  padding: 10px;
  z-index: 200;
}
.dropdown.open .dropdown-menu { display: block; }
.dropdown-menu a, .dropdown-menu button {
  width: 100%;
  display: flex; gap: 10px; align-items: center;
  padding: 10px 12px; border-radius: 10px; text-decoration: none; color: #fff;
  background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.10);
  transition: background .2s, border-color .2s, transform .12s;
}
.dropdown-menu a:hover, .dropdown-menu button:hover {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
}

.notif .dropdown-menu {
  width: min(420px, calc(100vw - 24px));
  max-height: min(70vh, 560px);
  overflow: hidden;
  padding: 8px;
}

.notif .dropdown-head {
  padding: 8px 10px 10px;
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.notif .dropdown-body {
  max-height: calc(min(70vh, 560px) - 104px);
  overflow: auto;
  padding-right: 2px;
}

.notif .dropdown-foot {
  padding: 10px 6px 4px;
  border-top: 1px solid rgba(255,255,255,.1);
  margin-top: 8px;
}

.notif .dropdown-foot .link {
  justify-content: center;
  font-weight: 600;
}

.notif .notif-empty {
  padding: 18px 14px;
  text-align: center;
  color: rgba(255,255,255,.82);
  background: rgba(255,255,255,.05);
  border: 1px dashed rgba(255,255,255,.16);
  border-radius: 12px;
}

.notif .notif-item {
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: #fff;
  text-decoration: none;
}

.notif .notif-item.unread {
  background: linear-gradient(180deg, rgba(37,99,235,.22), rgba(255,255,255,.1));
  border-color: rgba(147,197,253,.42);
}

.notif .notif-item.read {
  opacity: .92;
}

.notif .notif-item__head {
  display: flex;
  align-items: center;
  gap: 10px;
}

.notif .notif-item__dot {
  flex: 0 0 9px;
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: #f87171;
  box-shadow: 0 0 0 4px rgba(248,113,113,.16);
}

.notif .notif-item__dot.is-read {
  background: rgba(255,255,255,.34);
  box-shadow: none;
}

.notif .notif-item__title {
  min-width: 0;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  color: #fff;
}

.notif .notif-item__body {
  margin-top: 8px;
  font-size: 13px;
  line-height: 1.45;
  color: rgba(255,255,255,.8);
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.notif .notif-item__meta {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  font-size: 11px;
  color: rgba(255,255,255,.68);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.notif .notif-item__type,
.notif .notif-item__time {
  white-space: nowrap;
}

@media (max-width: 720px) {
  .notif .dropdown-menu {
    right: -6px;
    width: min(360px, calc(100vw - 16px));
  }

  .notif .notif-item__meta {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* keep actions from overlapping; wrap neatly on small widths */
.list .item > *:last-child {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.hidden { display: none !important; }
.menu-btn { padding: 4px 8px; }
/* reinforce: nested inputs are also solid white */
.toolbar--search .input--stretch input,
.toolbar--search .search-input input {
  background: #fff !important;
  color: #0f172a !important;
}

.auth-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.auth-login__card {
  width: min(460px, 100%);
  padding: 28px 24px;
  position: relative;
}
.auth-login__lang-switch {
  position: absolute;
  top: 12px;
  right: 14px;
}
.auth-login__lang-switch select {
  min-width: 72px;
}
.auth-login__header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}
.auth-login__eyebrow {
  margin: 0;
  font-size: 12px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(15, 23, 42, 0.62);
  font-weight: 700;
}
.auth-login__title {
  margin: 0;
  font-size: clamp(30px, 5vw, 42px);
  line-height: 1.05;
}
.auth-login__lead {
  margin: 0;
  color: rgba(15, 23, 42, 0.72);
}
.auth-login__form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.auth-login__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.auth-login__field label {
  font-weight: 700;
  color: rgba(15, 23, 42, 0.84);
}
.auth-login__field--password {
  position: relative;
}
.auth-login__field--password .input {
  padding-right: 86px;
}
.auth-login__toggle {
  position: absolute;
  right: 10px;
  top: 36px;
  border: 0;
  background: transparent;
  color: rgba(15, 23, 42, 0.68);
  font-weight: 700;
  cursor: pointer;
}
.auth-login__submit {
  width: 100%;
  margin-top: 6px;
}
.auth-login__footer {
  margin: 14px 0 0;
  text-align: center;
}
.auth-login__forgot {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  background: rgba(255, 255, 255, 0.72);
  color: #0f172a;
  font-weight: 700;
  text-decoration: none;
  transition: transform .12s ease, box-shadow .16s ease, border-color .16s ease;
}
.auth-login__forgot:hover {
  border-color: rgba(15, 23, 42, 0.24);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.10);
  transform: translateY(-1px);
}
.auth-login__forgot:active {
  transform: translateY(0);
}
.auth-login__forgot:focus-visible {
  outline: 2px solid rgba(14, 116, 144, 0.65);
  outline-offset: 2px;
}
.auth-login__alert {
  border-radius: 16px;
  padding: 12px 14px;
  margin-bottom: 16px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  font-weight: 600;
}
.auth-login__alert--ok {
  background: rgba(22, 163, 74, 0.10);
  color: #166534;
}
.auth-login__alert--err {
  background: rgba(220, 38, 38, 0.10);
  color: #991b1b;
}
@media (max-width: 640px) {
  .auth-login {
    padding: 16px;
  }
  .auth-login__card {
    padding: 24px 18px;
  }
}

/* --- NOTIF BADGE --- */
.badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:11px;
  line-height:1;
  padding:4px 10px;
  border-radius:999px;
  gap:4px;
  min-height:24px;
  background:rgba(15,23,42,0.04);
  color:#0f172a;
  border:1px solid rgba(15,23,42,0.08);
}
.badge--subtle{
  background:rgba(148,163,184,0.18);
  color:#334155;
  border-color:rgba(148,163,184,0.45);
}
.badge--warn{
  background:rgba(239,68,68,0.12);
  color:#b91c1c;
  border-color:rgba(248,113,113,0.45);
}
.badge-alert{
  position:absolute;
  right:-4px;
  top:-4px;
  min-width:18px;
  height:18px;
  border-radius:999px;
  background:#ef4444;
  color:#fff;
  padding:0 5px;
  box-shadow:0 0 0 2px rgba(0,0,0,.12);
  border:1px solid rgba(255,255,255,.3);
}
.badge-alert[hidden],
#notifCount[hidden],
#bgUploadCount[hidden],
#bgUploadNav[hidden] {
  display: none !important;
}
.has-alert{ outline: 2px solid #ffb9b9; }
.nova-topbar .badge-alert,
header.topbar .badge-alert{
  background:#ef4444 !important;
  color:#fff !important;
  border:1px solid rgba(255,255,255,.35);
  box-shadow:0 0 0 2px rgba(0,0,0,.1);
}

/* --- FOOTER --- */
.footer{ margin:40px auto 24px; text-align:center; color:#eee; opacity:.9; }

/* űveg input/gomb egységes stílus maradhat a meglévő fájlodban */

/* ===== Item New form polish (Új tétel) ===== */
.item-form {
  max-width: 980px; margin: 24px auto;
  padding: 20px; border-radius: 18px;
  background: rgba(255,255,255,.35);
  border: 1px solid rgba(255,255,255,.45);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: 0 18px 50px rgba(31,41,55,.28);
  color: #0f172a;
}

/* rács: bal (alapmezők) + jobb (location/min/max/fájlok) */
.item-form .grid-2 {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px 22px;
}

/* egységes sorok */
.item-form .form-row { display: flex; flex-direction: column; gap: 6px; }
.item-form .form-row-inline { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.item-form label { font-weight: 600; color: rgba(15,23,42,.8); }

/* inputok egységesítése (örökli a globális definíciókat) */
.item-form input[type="text"],
.item-form input[type="number"],
.item-form input[type="email"],
.item-form input[type="password"],
.item-form select,
.item-form textarea {
  height: 40px; padding: 10px 12px; border-radius: 12px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(15,23,42,.12);
}
.item-form textarea { height: 130px; resize: vertical; }

/* location mini-grid (sor / oszlop) – ha nincs extra markup, az attr szelektor is segít */
.item-form .loc-grid,
.item-form .qty-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.item-form input[name*="loc_row"], .item-form input[name*="loc_col"],
.item-form input[name*="min"], .item-form input[name*="max"] {
  text-align: left;
}

/* fájlfeltöltés blokk */
.item-form .files { padding: 10px; border-radius: 12px; background: rgba(255,255,255,.6); }
.item-form .hint { font-size: 12px; color: rgba(15,23,42,.6); }

/* alsó gombsor */
.item-form .actions {
  display: flex; justify-content: flex-end; gap: 10px; margin-top: 8px;
}
.item-form .btn-primary {
  background: #0f172a; color: #fff; border: 0;
  box-shadow: 0 12px 28px rgba(15,23,42,.32);
}
.item-form .btn-primary:hover { background:#111827; }
.item-form .btn-ghost {
  background: rgba(255,255,255,.9); color:#0f172a; border:1px solid rgba(15,23,42,.12);
}

/* fejléccím */
.item-form .title { font-size: 24px; font-weight: 800; margin: 0 0 8px; }

/* reszponzív törés */
@media (max-width: 860px) {
  .item-form .grid-2 { grid-template-columns: 1fr; }
  .item-form .form-row-inline,
  .item-form .loc-grid,
  .item-form .qty-grid { grid-template-columns: 1fr; }
}

/* Modal centering fix (universal mobile/desktop) */
.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100dvh;
  background: var(--nova-modal-backdrop-bg);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: var(--nova-modal-z);
  overflow: hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.nova-modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100dvh;
  background: var(--nova-modal-backdrop-bg);
  z-index: var(--nova-modal-z);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--nova-space-4);
  overflow: hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.nova-modal-backdrop.is-open {
  display: flex;
}

.nova-modal {
  position: relative;
  width: var(--nova-modal-width);
  max-height: var(--nova-modal-max-h);
  overflow-y: auto;
  background: var(--nova-modal-bg);
  color: var(--nova-modal-fg);
  border: 1px solid var(--nova-modal-border);
  border-radius: var(--nova-modal-radius);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--nova-modal-shadow);
  padding: var(--nova-modal-pad);
  margin: 0 auto;
  transform: translateY(0);
  animation: modalFadeIn 0.25s ease-out;
}

.nova-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--nova-space-2);
  margin-bottom: var(--nova-space-2);
}

.nova-modal-body {
  overflow: auto;
}

html.modal-open, body.modal-open {
  overflow: hidden !important;
  height: 100%;
}

/* iOS specific fix */
@supports (-webkit-touch-callout: none) {
  .modal-backdrop {
    height: 100vh;
  }
}

.user-chip{
  padding:6px 14px;
  border-radius:999px;
  font-weight:700;
  white-space:nowrap;
  background:rgba(255,255,255,.92);
  color:#0f172a;
  border:1px solid rgba(15,23,42,.12);
  display:inline-flex;
  align-items:center;
  gap:8px;
  box-shadow:0 10px 24px rgba(0,0,0,.12);
}
.user-chip__avatar{ font-size:16px; }
.user-chip__role{
  padding:2px 10px;
  border-radius:999px;
  background:rgba(59,130,246,.16);
  color:#0f172a;
  font-size:12px;
  font-weight:800;
  border:1px solid rgba(59,130,246,.28);
  letter-spacing:.02em;
  text-transform:capitalize;
}
.user-chip--right{ margin-right:8px; }

/* ===== Shared App Page UI ===== */
.app-page {
  width: 100%;
}

.page-title {
  margin: 0 0 24px;
  color: var(--nova-color-white);
  letter-spacing: .01em;
  text-shadow: 0 8px 28px rgba(7, 17, 40, 0.25);
}

/* ===== Dashboard Page UI ===== */
.dashboard-layout {
  max-width: min(1720px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 24px 0 40px;
  box-sizing: border-box;
}

.dashboard-main {
  width: 100%;
  min-width: 0;
}

.dashboard-main .grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}

.grid--5x2 > .dashboard-widget {
  min-height: 140px;
}

.dashboard-main .card {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dashboard-main .list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.dashboard-main .item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}

.compact-list .list {
  gap: 10px;
}

.compact-list .item {
  align-items: flex-start;
}

.chart-wrap {
  width: 100%;
  overflow: hidden;
}

.dashboard-widget--interactive {
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}

.dashboard-widget--interactive:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 34px rgba(15, 23, 42, 0.14);
}

.nova-bg-upload-panel--embedded {
  position: static;
  inset: auto;
  width: 100%;
  max-width: none;
  max-height: 52vh;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.nova-bg-upload-panel--embedded .nova-bg-upload-head { display: none; }
.nova-bg-upload-panel--embedded .nova-bg-upload-list {
  padding: 0;
  max-height: 52vh;
  overflow: auto;
}
.bg-upload-nav .dropdown-menu {
  min-width: 360px;
  max-width: min(92vw, 420px);
  padding: 8px;
}
.bg-upload-nav .dropdown-head {
  padding: 8px 10px 10px;
  color: rgba(255,255,255,.92);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  display: none;
}
.bg-upload-nav .dropdown-body {
  padding-top: 2px;
  padding-bottom: 2px;
}
/* dark theme overrides for embedded upload items */
.bg-upload-nav .nova-bg-upload-panel--embedded {
  background: transparent;
}
.bg-upload-nav .nova-bg-upload-panel--embedded .nova-bg-upload-list {
  display: grid;
  gap: 8px;
  padding: 2px 0 4px;
  max-height: min(48vh, 360px);
}
.bg-upload-nav .nova-bg-upload-empty {
  display: block;
  color: rgba(255,255,255,.74);
  font-size: 12px;
  line-height: 1.35;
  text-align: center;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 8px 6px 6px;
  margin: 0;
}
.bg-upload-nav .nova-bg-upload-item {
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 10px;
  padding: 8px 10px;
  margin-bottom: 4px;
}
.bg-upload-nav .nova-bg-upload-item.is-error {
  background: rgba(220,38,38,.18);
  border-color: rgba(220,38,38,.35);
}
.bg-upload-nav .nova-bg-upload-title {
  color: rgba(255,255,255,.95);
  font-size: 13px;
  font-weight: 600;
}
.bg-upload-nav .nova-bg-upload-status {
  color: rgba(255,255,255,.6);
  font-size: 12px;
}
.bg-upload-nav .nova-bg-upload-status.is-error {
  color: rgba(248,113,113,.9);
}
.bg-upload-nav .nova-bg-upload-bar-wrap {
  background: rgba(255,255,255,.12);
  border-radius: 99px;
  height: 4px;
  overflow: hidden;
  margin-top: 4px;
}
.bg-upload-nav .nova-bg-upload-bar {
  height: 100%;
  background: rgba(99,202,183,.85);
  border-radius: 99px;
  transition: width .3s ease;
}
.dashboard-widget--interactive:focus-visible {
  outline: 3px solid rgba(59, 130, 246, 0.35);
  outline-offset: 3px;
}

.chart line.chart-zero-axis {
  stroke: rgba(15, 23, 42, 0.28);
  stroke-width: 2;
  stroke-dasharray: 4 5;
}

.chart .chart-area {
  fill: url(#movementAreaFill);
}

.chart .chart-line {
  fill: none;
  stroke: #0f172a;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chart .chart-point {
  fill: #fff;
  stroke: #0f172a;
  stroke-width: 3;
}

.chart-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.chart-summary__hint {
  font-size: 13px;
  color: rgba(15, 23, 42, 0.72);
}

.dashboard-modal {
  position: fixed;
  inset: 0;
  z-index: var(--nova-modal-z);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--nova-modal-backdrop-bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.dashboard-modal.is-open {
  display: flex;
}

.dashboard-modal__panel {
  position: relative;
  width: min(980px, 100%);
  max-height: min(86vh, 920px);
  overflow: auto;
  border-radius: var(--nova-modal-radius);
  background: var(--nova-modal-bg);
  color: var(--nova-modal-fg);
  border: 1px solid var(--nova-modal-border);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--nova-modal-shadow);
  padding: var(--nova-modal-pad);
  animation: modalFadeIn 0.25s ease-out;
}

.dashboard-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.dashboard-modal__title {
  margin: 0;
  font-size: clamp(22px, 3vw, 30px);
}

.dashboard-modal__subtitle {
  margin: 6px 0 0;
  color: rgba(15, 23, 42, 0.7);
}

.dashboard-modal__close {
  flex-shrink: 0;
  width: 40px;
  min-width: 40px;
  height: 40px;
  padding: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  line-height: 1;
}

.movement-summary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 18px;
}

.movement-summary-card {
  border-radius: var(--nova-modal-surface-radius);
  padding: 14px 16px;
  background: var(--nova-modal-surface-bg);
  border: 1px solid var(--nova-modal-surface-border);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.movement-summary-card strong {
  display: block;
  font-size: 22px;
  margin-top: 6px;
}

.movement-detail-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1.15fr);
  gap: 18px;
}

.movement-day-list,
.movement-event-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.movement-day-card,
.movement-event-card {
  border-radius: var(--nova-modal-surface-radius);
  background: var(--nova-modal-surface-bg);
  border: 1px solid var(--nova-modal-surface-border);
  padding: 14px 16px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.movement-day-head,
.movement-event-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.movement-event-meta,
.movement-day-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.movement-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
}

.movement-badge--in {
  background: rgba(22, 163, 74, 0.14);
  color: #166534;
}

.movement-badge--out {
  background: rgba(220, 38, 38, 0.14);
  color: #991b1b;
}

.movement-muted {
  color: rgba(15, 23, 42, 0.68);
  font-size: 13px;
}

.delta-pos {
  color: #15803d;
  font-weight: 600;
}

.delta-neg {
  color: #dc2626;
  font-weight: 600;
}

.pill {
  background: rgba(15, 23, 42, 0.05);
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 13px;
  font-weight: 600;
}

.warehouse-strip {
  margin-bottom: 18px;
}

.warehouse-strip .list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.warehouse-strip .item {
  border: 1px solid var(--nova-modal-surface-border);
  border-radius: 12px;
  padding: 10px;
  background: var(--nova-modal-surface-bg);
  align-items: center;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.widget-critical {
  border: 1px solid rgba(185, 28, 28, 0.45);
  background: linear-gradient(135deg, rgba(254, 226, 226, 0.92), rgba(254, 202, 202, 0.9));
  animation: criticalPulse 2.2s ease-in-out infinite;
}

.widget-critical h2 {
  color: #991b1b;
}

.widget-critical .pill {
  background: rgba(185, 28, 28, 0.14);
  color: #7f1d1d;
}

.repair-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
}

.repair-summary__hint {
  margin: 0;
  font-size: 13px;
  color: rgba(15, 23, 42, 0.72);
}

.repair-event-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.repair-event-card {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  border-radius: var(--nova-modal-surface-radius);
  background: var(--nova-modal-surface-bg);
  border: 1px solid var(--nova-modal-surface-border);
  padding: 14px 16px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: background 0.18s;
}
.repair-event-card:hover {
  background: rgba(255, 255, 255, 0.62);
}

.repair-event-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.repair-status-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 12px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  /* default = new/blue */
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
  border: 1px solid rgba(37, 99, 235, 0.18);
}
.repair-status-badge--new {
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
  border-color: rgba(37, 99, 235, 0.2);
}
.repair-status-badge--in-progress,
.repair-status-badge--in_progress {
  background: rgba(217, 119, 6, 0.12);
  color: #92400e;
  border-color: rgba(217, 119, 6, 0.22);
}
.repair-status-badge--done,
.repair-status-badge--completed {
  background: rgba(22, 163, 74, 0.12);
  color: #166534;
  border-color: rgba(22, 163, 74, 0.22);
}
.repair-status-badge--cancelled,
.repair-status-badge--closed {
  background: rgba(107, 114, 128, 0.12);
  color: #374151;
  border-color: rgba(107, 114, 128, 0.2);
}

@keyframes criticalPulse {
  0%, 100% {
    box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.12);
    transform: translateY(0);
  }
  50% {
    box-shadow: 0 0 0 8px rgba(220, 38, 38, 0.04);
    transform: translateY(-1px);
  }
}

@media (max-width: 1400px) {
  .dashboard-layout {
    max-width: 100%;
  }
}

@media (max-width: 1200px) {
  .dashboard-layout {
    max-width: 100%;
    padding: 16px 0 32px;
  }
}

@media (max-width: 880px) {
  .movement-detail-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-modal {
    padding: 12px;
  }

  .dashboard-modal__panel {
    padding: 18px;
    border-radius: 22px;
  }
}

/* ===== Superadmin Module Layout ===== */
.superadmin-shell {
  --superadmin-sidebar-width: 300px;
  --superadmin-sidebar-gap: 28px;
  max-width: none;
  width: 100%;
  margin: 0;
  padding-left: 24px;
  padding-right: 24px;
  padding-bottom: 48px;
}
.superadmin-shell > .page-title {
  margin: 0 0 24px calc(var(--superadmin-sidebar-width) + var(--superadmin-sidebar-gap));
}
.superadmin-layout {
  display: block;
}
@media (max-width: 980px) {
  .superadmin-shell {
    padding-left: 16px;
    padding-right: 16px;
  }
  .superadmin-shell > .page-title {
    margin-left: 0;
  }
  .superadmin-layout {
    display: block;
  }
}
.superadmin-nav {
  position: fixed;
  left: 0;
  top: 72px;
  width: var(--superadmin-sidebar-width);
  height: calc(100vh - 72px);
  overflow-y: auto;
  border-radius: 0 14px 14px 0;
  z-index: 20;
}
@media (max-width: 980px) {
  .superadmin-nav {
    position: static;
    width: auto;
    height: auto;
    overflow: visible;
    border-radius: 14px;
    z-index: auto;
  }
}
.superadmin-nav-title {
  margin: 0 0 12px;
}
.superadmin-nav-list {
  display: grid;
  gap: 8px;
}
@media (max-width: 980px) {
  .superadmin-nav-list {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }
}
.superadmin-nav-btn {
  text-align: left;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.14);
  background: rgba(255,255,255,0.65);
  cursor: pointer;
}
.superadmin-nav-btn:hover {
  background: rgba(37,99,235,0.12);
}
.superadmin-nav-btn.active {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
  border-color: transparent;
}
.superadmin-content {
  margin-left: calc(var(--superadmin-sidebar-width) + var(--superadmin-sidebar-gap));
  width: min(1720px, calc(100vw - var(--superadmin-sidebar-width) - var(--superadmin-sidebar-gap) - 36px));
  margin-right: auto;
  min-width: 0;
}
@media (max-width: 980px) {
  .superadmin-content {
    margin-left: 0;
    width: 100%;
  }
}
.superadmin-grid {
  display: block;
}
.module-panel {
  display: none;
}
.module-panel.active {
  display: block;
}
.superadmin-card h2 {
  margin-top: 0;
}
.muted {
  color: #6b7280;
  font-size: 0.9rem;
}
.lang-controls {
  display: flex;
  gap: 12px;
  margin: 16px 0;
  flex-wrap: wrap;
}
.lang-controls label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.lang-controls input,
.lang-controls select {
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  min-width: 160px;
}
.lang-controls .flex-1 {
  flex: 1 1 240px;
}
.lang-editor-wrapper {
  display: flex;
  gap: 16px;
  min-height: 280px;
}
@media (max-width: 900px) {
  .lang-editor-wrapper {
    flex-direction: column;
  }
}
.lang-keys {
  flex: 1 1 220px;
  max-height: 360px;
  overflow-y: auto;
  border: 1px solid rgba(0,0,0,0.1);
  border-radius: 8px;
  padding: 6px;
  background: rgba(255,255,255,0.58);
}
.lang-key {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px;
  border: none;
  background: transparent;
  border-radius: 6px;
  font-family: inherit;
  font-size: 0.9rem;
  cursor: pointer;
}
.lang-key:hover, .lang-key.active {
  background: rgba(59,130,246,0.15);
}
.lang-editor-panel {
  flex: 2 1 320px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.lang-editor-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.lang-editor-panel textarea {
  width: 100%;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.12);
  font-family: Menlo, Consolas, monospace;
  min-height: 160px;
}
.lang-editor-actions {
  display: flex;
  gap: 10px;
}
.status {
  min-height: 24px;
  font-size: 0.85rem;
  color: #047857;
}
.status.err {
  color: #b91c1c;
}
pre {
  margin: 0;
  max-height: 320px;
  overflow: auto;
  font-size: 0.85rem;
  line-height: 1.4;
}
.superadmin-shell .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: rgba(59,130,246,0.15);
  cursor: pointer;
}
.superadmin-shell .btn.primary {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
  border: none;
}
.superadmin-shell .btn--ghost {
  background: transparent;
  border: 1px solid rgba(0,0,0,0.15);
}
.superadmin-shell .btn--sm {
  padding: 6px 10px;
  font-size: 0.85rem;
}
.superadmin-shell .btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.support-wrapper {
  display: flex;
  gap: 18px;
  min-height: 340px;
}
@media (max-width: 900px) {
  .support-wrapper {
    flex-direction: column;
  }
}
.support-contacts {
  flex: 0 0 260px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 8px;
  background: rgba(255,255,255,0.6);
  max-height: 360px;
  overflow-y: auto;
  padding: 6px;
}
.support-contact {
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border: none;
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 0.9rem;
}
.support-contact.has-unread {
  background: rgba(239,68,68,0.12);
}
.support-contact.has-unread:hover,
.support-contact.has-unread.active {
  background: rgba(239,68,68,0.2);
}
.support-contact .support-label {
  font-weight: 600;
  color: #0f172a;
}
.support-contact .support-meta {
  font-size: 0.78rem;
  color: #6b7280;
}
.support-contact:hover,
.support-contact.active {
  background: rgba(59,130,246,0.14);
}
.support-contact.has-unread:hover,
.support-contact.has-unread.active {
  background: rgba(239,68,68,0.2);
}
.support-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.support-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #ef4444;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(255,255,255,0.8);
}
.support-chat-panel {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.support-chat-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.support-chat-actions {
  display: flex;
  gap: 8px;
}
.support-messages {
  flex: 1 1 auto;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 8px;
  background: rgba(255,255,255,0.6);
  padding: 12px;
  overflow-y: auto;
  max-height: 400px;
}
.support-message {
  max-width: 70%;
  margin-bottom: 10px;
  padding: 8px 12px;
  border-radius: 14px;
  background: rgba(59,130,246,0.15);
  color: #0f172a;
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  line-height: 1.35;
}
.support-message .support-body {
  white-space: pre-wrap;
  word-break: break-word;
}
.support-message.self {
  margin-left: auto;
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
}
.support-message .support-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-start;
}
.support-message.self .support-meta {
  justify-content: flex-end;
}
.support-message .support-time {
  font-size: 0.75rem;
  opacity: 0.7;
}
.support-message .support-read-state {
  font-size: 0.75rem;
  font-weight: 700;
  opacity: 0.88;
}
.support-empty {
  text-align: center;
  color: #6b7280;
  font-size: 0.9rem;
  padding: 20px 0;
}
.support-input {
  display: flex;
  gap: 10px;
}
.support-input textarea {
  flex: 1 1 auto;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.12);
  padding: 10px;
  min-height: 44px;
  resize: vertical;
}
.support-ai {
  border: 1px dashed rgba(0,0,0,0.2);
  border-radius: 12px;
  padding: 10px;
  background: rgba(255,255,255,0.5);
  margin-top: 6px;
}
.support-ai-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 8px;
}
.support-ai textarea {
  width: 100%;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,0.15);
  padding: 8px 10px;
  resize: vertical;
}
.support-ai-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}
.toggle-list {
  display: grid;
  gap: 10px;
}

/* ---------- Service module shared UI (centralized) ---------- */
.btn-primary,.btn-secondary,.btn-small { border:none; border-radius:8px; cursor:pointer; font-weight:700; }
.btn-primary { background:#0f766e; color:#fff; padding:9px 14px; }
.btn-secondary { background:#e2e8f0; color:#0f172a; padding:9px 14px; }
.btn-small { background:#0f172a; color:#fff; padding:5px 9px; font-size:12px; }
.btn-small.warn { background:#92400e; }
.btn-small.ok { background:#166534; }
.btn-small.gray { background:#475569; }
.btn-small.print { background:#334155; }

.svc-filters { display:grid; grid-template-columns:repeat(6,minmax(120px,1fr)); gap:8px; margin:10px 0 12px; }
.svc-filters input, .svc-filters select { width:100%; border:1px solid #cbd5e1; border-radius:8px; padding:8px; }
.svc-filters .actions { display:flex; gap:8px; }

.svc-table { width:100%; border-collapse:collapse; }
.svc-table th, .svc-table td { text-align:left; padding:8px 9px; border-bottom:1px solid #e2e8f0; vertical-align:top; }
.svc-table th { font-size:12px; color:#475569; }

.svc-status { display:inline-flex; border-radius:999px; padding:3px 9px; font-size:11px; font-weight:700; }
.svc-status.new { background:#dbeafe; color:#1d4ed8; }
.svc-status.in_progress { background:#fef3c7; color:#92400e; }
.svc-status.paused { background:#fee2e2; color:#991b1b; }
.svc-status.waiting_parts { background:#ffedd5; color:#9a3412; }
.svc-status.done { background:#dcfce7; color:#166534; }
.svc-status.closed { background:#e2e8f0; color:#334155; }

.svc-meta { color:#64748b; font-size:12px; }
.svc-msg { margin:8px 0 0; font-size:12px; }
.svc-row-actions { display:flex; gap:6px; flex-wrap:wrap; }

.svc-modal-backdrop { position:fixed; inset:0; background:var(--nova-modal-backdrop-bg); display:none; align-items:center; justify-content:center; z-index:var(--nova-modal-z); padding:18px; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); }
.svc-modal { width:min(820px, 96vw); max-height:88dvh; overflow:auto; background:var(--nova-modal-bg); color:var(--nova-modal-fg); border:1px solid var(--nova-modal-border); border-radius:var(--nova-modal-radius); box-shadow:var(--nova-modal-shadow); }
.svc-modal .head, .svc-modal-head { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--nova-modal-surface-border); }
.svc-modal .body, .svc-modal-body { padding:16px; }
.svc-modal .row { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; margin-bottom:10px; }
.svc-modal label { font-size:12px; color:#334155; display:block; margin:0 0 4px; font-weight:600; }
.svc-modal input,.svc-modal select,.svc-modal textarea,
.svc-modal .svc-input, .svc-modal .svc-select, .svc-modal .svc-textarea { width:100%; border:1px solid var(--nova-modal-surface-border); border-radius:10px; padding:9px; background:var(--nova-modal-surface-bg); color:var(--nova-modal-fg); }
.svc-modal textarea, .svc-modal .svc-textarea { min-height:90px; }
.svc-modal .foot { display:flex; justify-content:flex-end; gap:8px; margin-top:10px; border-top:1px solid var(--nova-modal-surface-border); padding-top:10px; }

.parts-search-results { margin-top:6px; border:1px solid #cbd5e1; border-radius:8px; max-height:170px; overflow:auto; background:#fff; }
.parts-search-item { padding:8px 10px; border-bottom:1px solid #e2e8f0; cursor:pointer; }
.parts-search-item:last-child { border-bottom:none; }
.parts-search-item:hover { background:#f8fafc; }
.waiting-parts-picked { display:flex; gap:6px; flex-wrap:wrap; margin-top:6px; }
.waiting-parts-chip { display:inline-flex; align-items:center; gap:6px; background:#fff7ed; border:1px solid #fed7aa; border-radius:999px; padding:4px 8px; font-size:12px; }

.parts-detail { margin-top:8px; border:1px solid #e2e8f0; border-radius:10px; padding:10px; background:#f8fafc; }
.parts-detail-grid { display:grid; grid-template-columns:84px 1fr; gap:10px; }
.parts-thumb { width:84px; height:84px; border-radius:8px; border:1px solid #cbd5e1; object-fit:cover; cursor:pointer; background:#fff; }
.parts-image-backdrop { position:fixed; inset:0; background:rgba(2,6,23,.72); display:none; align-items:center; justify-content:center; z-index:2100; }
.parts-image-box { width:min(920px, 95vw); max-height:90vh; background:#fff; border-radius:12px; padding:10px; }
.parts-image-box img { width:100%; max-height:82vh; object-fit:contain; display:block; }

.assignee-grid, .svc-assignees { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:6px; border:1px solid #cbd5e1; border-radius:8px; padding:8px; max-height:190px; overflow:auto; background:#fff; }
.assignee-item, .svc-assignee-item { display:flex; align-items:center; gap:6px; font-size:13px; }

.svc-line-dd { position:relative; }
.svc-line-dd-btn { width:100%; border:1px solid var(--nova-modal-surface-border); border-radius:10px; padding:8px 10px; background:var(--nova-modal-surface-bg); color:var(--nova-modal-fg); text-align:left; cursor:pointer; }
.svc-line-dd-panel { position:absolute; z-index:50; left:0; right:0; margin-top:6px; border:1px solid var(--nova-modal-surface-border); border-radius:10px; background:var(--nova-modal-surface-bg); box-shadow:0 8px 24px rgba(2,6,23,.18); max-height:220px; overflow:auto; display:none; }
.svc-line-dd-item { display:flex; align-items:center; gap:8px; padding:8px 10px; border-bottom:1px solid #eef2f7; font-size:13px; }
.svc-line-dd-item:last-child { border-bottom:none; }

.svc-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:10px; }
.svc-card { border:1px solid #dbe4f0; border-radius:12px; background:#fff; padding:12px; }
.svc-title { margin:0 0 10px; font-size:18px; font-weight:800; color:#0f172a; }
.svc-row { display:grid; grid-template-columns:repeat(12,1fr); gap:8px; margin:0 0 8px; }
.svc-row > div { grid-column: span 12; }

@media (min-width: 900px) {
  .svc-row .w-3 { grid-column: span 3; }
  .svc-row .w-4 { grid-column: span 4; }
  .svc-row .w-6 { grid-column: span 6; }
  .svc-row .w-12 { grid-column: span 12; }
}

.svc-input, .svc-select, .svc-textarea { width:100%; border:1px solid #cbd5e1; border-radius:10px; padding:8px 10px; font-size:14px; }
.svc-select[multiple] { min-height:110px; }
.svc-textarea { min-height:82px; resize:vertical; }

.svc-btn { border:1px solid #1d4ed8; border-radius:10px; padding:8px 12px; background:#2563eb; color:#fff; font-weight:700; cursor:pointer; }
.svc-btn.alt { background:#fff; color:#1d4ed8; }
.svc-btn.warn { background:#dc2626; border-color:#b91c1c; }

.svc-check-row { display:flex; align-items:flex-start; gap:8px; border-bottom:1px solid #f1f5f9; padding:6px 0; }
.svc-check-item { border:1px solid #dbe4f0; border-radius:10px; padding:8px; margin:6px 0; background:#f8fafc; }
.svc-inline { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.svc-inline > * { flex:1 1 auto; }
.svc-close { border:none; background:transparent; font-size:22px; cursor:pointer; color:#64748b; }
.svc-badge { display:inline-block; border-radius:999px; padding:2px 9px; font-size:11px; font-weight:700; }
.st-new { background:#dbeafe; color:#1e40af; }
.st-in_progress { background:#dcfce7; color:#166534; }
.st-paused { background:#fee2e2; color:#991b1b; }
.st-done { background:#fef3c7; color:#92400e; }
.st-closed { background:#e2e8f0; color:#334155; }

.svc-hidden { display:none; }
.svc-overflow-auto { overflow:auto; }
.svc-flex-1 { flex:1; }
.svc-p-18 { padding:18px; }
.svc-m-0 { margin:0; }
.svc-mt-4 { margin-top:4px; }
.svc-mt-6 { margin-top:6px; }
.svc-mt-12 { margin-top:12px; }
.svc-mb-8 { margin-bottom:8px; }
.svc-mb-12 { margin-bottom:12px; }
.svc-mb-10 { margin-bottom:10px; }
.svc-mb-14 { margin-bottom:14px; }
.svc-px-18 { padding-left:18px; padding-right:18px; }
.svc-py-12 { padding-top:12px; padding-bottom:12px; }

@media (max-width: 980px) {
  .svc-filters { grid-template-columns:repeat(2,minmax(120px,1fr)); }
  .svc-modal .row { grid-template-columns:1fr; }
  .assignee-grid, .svc-assignees { grid-template-columns:1fr; }
}

/* ---------- Service catalog ---------- */
.svc-catalog-grid { display:grid; gap:12px; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); margin-bottom:12px; }
.svc-form { border:1px solid var(--nova-card-border); border-radius:12px; background:var(--nova-card-bg); padding:12px; }
.svc-form h4 { margin:0 0 10px; font-size:14px; }
.svc-row-flex { display:flex; gap:8px; flex-wrap:wrap; }
.svc-row-flex input, .svc-row-flex select { min-width:120px; padding:8px 10px; border:1px solid #cbd5e1; border-radius:8px; }
.svc-row-flex button { padding:8px 12px; border:1px solid #334155; border-radius:8px; background:#0f172a; color:#fff; font-weight:700; cursor:pointer; }
.svc-actions { display:flex; gap:6px; }
.svc-actions button { padding:5px 8px; border-radius:8px; border:1px solid #cbd5e1; background:#fff; cursor:pointer; }
.svc-actions .danger { border-color:#fecaca; color:#991b1b; background:#fff1f2; }
.svc-error { color:#b91c1c; }
.svc-ok { color:#166534; }

/* ---------- Service dashboard ---------- */
.service-dashboard-page main.shell[data-service-dashboard="1"] {
  width: min(1400px, calc(100vw - 48px)) !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
}
.service-dashboard-page main.shell[data-service-dashboard="1"] .service-module-top-card {
  margin: 0 !important;
  border-radius: 0 !important;
  border-left: none !important;
  border-right: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  padding: var(--nova-shell-pad-x) !important;
  padding-bottom: 18px !important;
}
.service-module-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:12px; }
.service-card-link {
  display:block; text-decoration:none; color:inherit;
  border:1px solid var(--nova-card-border); border-radius:14px;
  background:var(--nova-card-bg); padding:14px; cursor:pointer;
}
.service-card-link:hover { border-color: var(--nova-card-border-hover); background: var(--nova-card-bg-hover); }
.service-card-link.active {
  border-color: var(--nova-color-accent);
  box-shadow: 0 0 0 1px rgba(37,99,235,.22) inset;
  background: rgba(255,255,255,.72);
}
.service-card-link h3 { margin:0 0 6px; font-size:16px; }
.service-card-link p { margin:0; color:#64748b; font-size:13px; }
.service-module-viewer {
  border:1px solid var(--nova-card-border); border-radius:18px; background:var(--nova-card-bg);
  backdrop-filter:blur(22px) saturate(140%); -webkit-backdrop-filter:blur(22px) saturate(140%);
  box-shadow:var(--nova-card-shadow); overflow:hidden; width:100%;
}
.service-module-viewer-head {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:14px 18px; border-bottom:1px solid var(--nova-card-border); background:var(--nova-card-bg);
}
.service-module-viewer-head h2 { margin:0; font-size:18px; }
.service-module-loader { font-size:12px; color:#64748b; padding:8px 18px 0; }
.service-module-content-wrap { padding:0; background:#fff; min-height:680px; overflow:auto; }
.service-module-content { min-height:100%; }

/* ---------- Service location stats ---------- */
.sls-card { background:var(--nova-card-bg); border:1px solid var(--nova-card-border); border-radius:14px; padding:18px; margin-bottom:14px; }
.sls-no-data { text-align:center; padding:32px; color:#94a3b8; font-size:14px; }
.sls-btn-back { display:inline-flex; align-items:center; gap:6px; border:1px solid #cbd5e1; border-radius:8px; padding:7px 14px; background:#fff; color:#0f172a; font-size:13px; font-weight:600; text-decoration:none; margin-bottom:14px; }
.sls-btn-back:hover { border-color:#94a3b8; background:#f1f5f9; }
.sls-loc-select { border:1px solid #cbd5e1; border-radius:8px; padding:7px 12px; font-size:14px; background:#fff; cursor:pointer; }
.sls-stats-grid { display:grid; gap:10px; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); margin-bottom:16px; }
.sls-stat-card { background:var(--nova-card-bg); border:1px solid var(--nova-card-border); border-radius:12px; padding:12px 14px; }
.sls-stat-card .sv { font-size:26px; font-weight:800; color:var(--nova-color-text); margin:3px 0 1px; }
.sls-stat-card .sl { font-size:12px; color:#64748b; }
.sls-stat-card.warn .sv { color:#dc2626; }
.sls-legend { display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-bottom:16px; font-size:12px; color:#64748b; }
.sls-legend-item { display:flex; align-items:center; gap:5px; }
.sls-line-section { margin-bottom:22px; }
.sls-line-label { font-size:11px; font-weight:800; color:#94a3b8; text-transform:uppercase; letter-spacing:.07em; margin-bottom:9px; padding-bottom:6px; border-bottom:1px solid #e5e7eb; }
.sls-type-grid { display:flex; flex-wrap:wrap; gap:9px; }
.sls-type-btn {
  position:relative; display:flex; flex-direction:column; align-items:flex-start; gap:2px;
  border:1.5px solid #e2e8f0; border-radius:12px; padding:13px 36px 11px 13px;
  background:#fff; text-decoration:none; color:#0f172a; min-width:120px; flex:0 1 auto;
  transition:border-color .12s, box-shadow .12s, background .12s;
}
.sls-type-btn:hover { border-color:#94a3b8; box-shadow:0 2px 10px rgba(0,0,0,.08); }
.sls-type-btn.has-repair { border-color:#fca5a5; background:#fff5f5; }
.sls-type-btn.has-maint { border-color:#fed7aa; background:#fffbf0; }
.sls-type-btn.has-both { border-color:#f59e0b; background:#fff9f0; }
.sls-type-btn .btn-name { font-size:14px; font-weight:700; line-height:1.3; }
.sls-type-btn .btn-line { font-size:11px; color:#64748b; margin-top:1px; }
.sls-type-btn .btn-counts { display:flex; gap:5px; margin-top:5px; }
.bc-repair { font-size:11px; font-weight:700; color:#dc2626; background:#fee2e2; padding:1px 6px; border-radius:20px; }
.bc-maint { font-size:11px; font-weight:700; color:#d97706; background:#fef3c7; padding:1px 6px; border-radius:20px; }
.sls-dot-wrap { position:absolute; top:10px; right:10px; }
.sls-dot { width:13px; height:13px; border-radius:50%; display:inline-block; box-shadow:0 0 0 2px #fff, 0 0 0 3.5px rgba(0,0,0,.10); }
.sls-dot.green { background:#16a34a; }
.sls-dot.orange { background:#f59e0b; }
.sls-dot.red { background:#dc2626; }
.sls-dot.both { background:linear-gradient(90deg, #f59e0b 50%, #dc2626 50%); }
.sls-table { width:100%; border-collapse:collapse; font-size:14px; }
.sls-table th { text-align:left; padding:8px 10px; border-bottom:2px solid #e5e7eb; font-size:12px; color:#64748b; white-space:nowrap; }
.sls-table td { padding:8px 10px; border-bottom:1px solid #f1f5f9; vertical-align:middle; }
.sls-table tbody tr:hover { background:#f8fafc; }
.sls-tl-row { display:flex; gap:7px; align-items:flex-start; font-size:12px; padding:3px 0; border-bottom:1px solid #f1f5f9; }
.sls-tl-row:last-child { border-bottom:none; }
.sls-tl-meta { color:#64748b; }

/* ---------- Service print ---------- */
.svc-print-body { font-family: Arial, sans-serif; margin: 20px; color: #0f172a; }
.svc-print-h1 { margin:0 0 12px; }
.svc-print-meta { color:#475569; margin-bottom:14px; }
.svc-print-ticket { border:1px solid #cbd5e1; border-radius:8px; margin:0 0 14px; padding:10px; page-break-inside:avoid; }
.svc-print-head { font-weight:700; margin-bottom:8px; }
.svc-print-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.svc-print-logs { margin-top:8px; border-top:1px dashed #cbd5e1; padding-top:6px; }
.svc-print-log { font-size:12px; margin:4px 0; }

.svc-maint-print-body { font-family: Arial, sans-serif; color:#111827; margin:20px; }
.svc-maint-print-h1 { font-size:22px; margin:0 0 10px; }
.svc-maint-print-meta { margin:0 0 14px; font-size:14px; }
.svc-maint-print-meta div { margin:3px 0; }
.svc-maint-print-table { width:100%; border-collapse:collapse; margin:12px 0; }
.svc-maint-print-table th, .svc-maint-print-table td { border:1px solid #cbd5e1; padding:8px; font-size:13px; vertical-align:top; }
.svc-maint-print-table th { background:#f1f5f9; text-align:left; }
.svc-maint-print-check-cell { width:56px; text-align:center; font-size:18px; }
.svc-maint-print-sign { margin-top:22px; display:flex; gap:32px; }
.svc-maint-print-line { flex:1; border-top:1px solid #111827; padding-top:8px; font-size:12px; }

@media (max-width: 920px) {
  .service-module-content-wrap { min-height:520px; }
}
@media (max-width: 900px) {
  .service-dashboard-page main.shell[data-service-dashboard="1"] { width: calc(100vw - 36px) !important; }
}
@media (max-width: 600px) {
  .service-dashboard-page main.shell[data-service-dashboard="1"] { width: calc(100vw - 28px) !important; }
  .service-module-content-wrap { min-height:400px; }
}
@media print {
  .no-print { display:none !important; }
  .svc-print-body { margin:0.6cm; }
  .svc-maint-print-body { margin:8mm; }
  .svc-maint-print-body button { display:none; }
}

/* ---------- Personal weekly/review ---------- */
.module-nav { display:flex; gap:10px; flex-wrap:wrap; margin:0 0 14px; }
.module-link,
.review-switch-link {
  display:inline-flex; align-items:center; gap:8px;
  text-decoration:none; border:1px solid var(--nova-card-border);
  background:var(--nova-card-bg); color:var(--nova-table-text);
  border-radius:12px; padding:10px 14px; font-weight:700;
}
.module-link.active,
.review-switch-link.active {
  border-color:var(--nova-color-accent);
  box-shadow:0 0 0 1px rgba(37,99,235,.22) inset;
  background:rgba(255,255,255,.72);
}
.review-switch { display:flex; gap:10px; flex-wrap:wrap; margin:0 0 14px; }
.review-meta { display:flex; justify-content:space-between; gap:12px; align-items:center; flex-wrap:wrap; margin-bottom:12px; }
.hr-table { width:100%; border-collapse:collapse; font-size:13px; }
.hr-table th, .hr-table td { padding:9px 12px; border-bottom:1px solid var(--nova-card-border); text-align:left; vertical-align:middle; }
.hr-table thead th { font-weight:700; background:rgba(0,0,0,.03); }
.action-btns { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.btn-approve, .btn-reject { border:none; border-radius:8px; padding:8px 14px; cursor:pointer; font-weight:700; font-size:13px; }
.btn-approve { background:#059669; color:#fff; }
.btn-reject { background:#dc2626; color:#fff; }
.review-note-input { padding:8px 10px; border:1px solid var(--nova-card-border); border-radius:8px; background:var(--nova-card-bg); color:var(--nova-table-text); width:100%; }
.review-note-input.is-invalid { border-color:#dc2626; box-shadow:0 0 0 3px rgba(220,38,38,.16); }
.status-badge { display:inline-flex; align-items:center; border-radius:999px; padding:4px 10px; font-size:12px; font-weight:800; }
.status-badge.approved { background:#d1fae5; color:#065f46; }
.status-badge.rejected, .status-badge.rework { background:#fee2e2; color:#991b1b; }

.print-sheet { max-width:1100px; margin:0 auto; }
.report-table { width:100%; border-collapse:collapse; font-size:13px; }
.report-table th, .report-table td { padding:9px 12px; border:1px solid var(--nova-card-border); text-align:left; vertical-align:middle; }
.report-table thead th { font-weight:700; background:rgba(0,0,0,.04); }
.report-table .weekend td, .report-table .weekend th { background:rgba(100,116,139,.09); }
.report-table .overtime td { color:#dc2626; font-weight:700; }
.shift-dot { display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:5px; vertical-align:middle; }
.summary-row td { font-weight:700; background:rgba(0,0,0,.03); }
.print-btn { background:var(--nova-color-accent); color:#fff; border:none; border-radius:8px; padding:10px 22px; font-weight:700; cursor:pointer; font-size:14px; }
.signature-section { display:grid; grid-template-columns:1fr 1fr; gap:32px; margin-top:24px; }
.signature-box { border-top:1px solid #000; margin-top:32px; padding-top:8px; text-align:center; font-size:12px; font-weight:600; min-height:50px; }
.signature-title { font-size:11px; color:#64748b; margin-bottom:2px; }
.print-date { font-size:12px; color:#64748b; margin-top:16px; }
.ticket-detail-list { display:grid; gap:4px; }
.ticket-detail-item { display:block; font-size:11px; line-height:1.35; }
.ticket-detail-item strong { font-size:11px; }
.workflow-box { border:1px solid var(--nova-card-border); border-radius:12px; background:rgba(148,163,184,.08); padding:10px 12px; margin-top:10px; }
.workflow-box strong { font-size:13px; }
.workflow-status { display:inline-flex; padding:4px 10px; border-radius:999px; font-size:12px; font-weight:800; }
.workflow-status.pending { background:#fef3c7; color:#92400e; }
.workflow-status.rework { background:#fee2e2; color:#991b1b; }
.workflow-status.approved { background:#d1fae5; color:#065f46; }

.cardx{background:var(--nova-card-bg);border:1px solid var(--nova-card-border);border-radius:14px;padding:14px;margin-bottom:12px;}
.day-row{display:flex;justify-content:space-between;align-items:center;gap:8px;border:1px solid var(--nova-card-border);border-radius:8px;padding:6px 8px;margin-bottom:6px;background:#fff;}
.actions{display:flex;gap:6px;}
.btn-day{border:1px solid var(--nova-card-border);border-radius:6px;padding:2px 8px;background:#fff;cursor:pointer;font-weight:700;}
.btn-day.ok.active{background:#d1fae5;color:#065f46;border-color:#065f46;}
.btn-day.bad.active{background:#fee2e2;color:#991b1b;border-color:#991b1b;}
.note-item{font-size:12px;margin:0 0 4px;}

.pr-p18{padding:18px;}
.pr-mb14{margin-bottom:14px;}
.pr-m0{margin:0;}
.pr-mb8{margin-bottom:8px;}
.pr-mb12{margin-bottom:12px;}
.pr-mt4{margin-top:4px;}
.pr-mt6{margin-top:6px;}
.pr-mt8{margin-top:8px;}
.pr-mt10{margin-top:10px;}
.pr-mt12{margin-top:12px;}
.pr-text-sm12{font-size:12px;}
.pr-text-sm13{font-size:13px;}
.pr-text-md16{font-size:16px;}
.pr-text-lg18{font-size:18px;}
.pr-text-xl20{font-size:20px;}
.pr-fw700{font-weight:700;}
.pr-fw800{font-weight:800;}
.pr-form-inline{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.pr-label-col{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:600;}
.pr-input-week{padding:9px 10px;border:1px solid var(--nova-card-border);border-radius:8px;background:var(--nova-card-bg);color:var(--nova-table-text);}
.pr-btn-auto{width:auto;padding:9px 18px;}
.pr-btn-sm{width:auto;padding:8px 12px;}
.pr-btn-xs{display:inline-flex;width:auto;padding:4px 8px;}
.pr-btn-danger{background:#991b1b !important;border-color:#991b1b !important;color:#fff !important;}
.pr-flex-between{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;}
.pr-flex-wrap{display:flex;flex-wrap:wrap;}
.pr-gap8{gap:8px;}
.pr-hidden{display:none !important;}
.pr-flex-end{display:flex;gap:8px;justify-content:flex-end;margin-top:10px;}
.pr-overflow{overflow:auto;}
.pr-hr{margin:14px 0;border:none;border-top:1px solid var(--nova-card-border);}
.pr-details-summary{cursor:pointer;}
.pr-head-wrap{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px;margin-bottom:16px;}
.pr-head-right{text-align:right;}
.pr-text-muted{color:#64748b;}
.pr-text-danger{color:#dc2626;}
.pr-badge-bg{background:rgba(148,163,184,.08);padding-top:6px;padding-bottom:8px;}
.pr-small-muted{color:#64748b;font-size:11px;}
.pr-card-lite{margin-top:10px;padding:12px;border-radius:12px;}
.pr-modal-box{width:min(520px,92vw);background:#fff;border-radius:12px;padding:14px;border:1px solid var(--nova-card-border);}

.hr-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:16px;}
.hr-form-grid label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:600;color:var(--nova-table-text);}
.hr-form-grid input,.hr-form-grid select,.hr-form-grid textarea{padding:9px 11px;border:1px solid var(--nova-card-border);border-radius:8px;background:var(--nova-card-bg);color:var(--nova-table-text);font-size:14px;}
.hr-form-grid textarea{resize:vertical;min-height:70px;}
.hr-status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;}
.hr-status-badge--pending{background:#fef3c7;color:#92400e;}
.hr-status-badge--approved{background:#d1fae5;color:#065f46;}
.hr-status-badge--rejected{background:#fee2e2;color:#991b1b;}
.sick-upload-form{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.sick-upload-form input[type="file"]{max-width:200px;}
.sick-upload-done{color:#166534;font-weight:700;font-size:12px;}
#hrSubmitResult{margin-top:10px;padding:10px 14px;border-radius:8px;display:none;font-size:14px;}
#hrSubmitResult.ok{background:#d1fae5;color:#065f46;}
#hrSubmitResult.err{background:#fee2e2;color:#991b1b;}
.req-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);display:none;align-items:center;justify-content:center;padding:20px;z-index:1300;}
.req-modal-backdrop.show{display:flex;}
.req-modal{width:min(520px,100%);background:#fff;border-radius:16px;box-shadow:0 30px 80px rgba(15,23,42,.25);padding:18px;}
.req-modal h3{margin:0 0 8px;}
.req-modal p{margin:0 0 12px;color:#475569;}
.req-modal textarea{width:100%;min-height:96px;padding:10px 12px;border:1px solid var(--nova-card-border);border-radius:8px;background:var(--nova-card-bg);color:var(--nova-table-text);resize:vertical;}
.req-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px;}
.req-modal-btn{border:none;border-radius:8px;padding:8px 12px;cursor:pointer;font-weight:700;}
.req-modal-btn.cancel{background:#e2e8f0;color:#0f172a;}
.req-modal-btn.submit{background:var(--nova-color-accent);color:#fff;}

.hr-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:12px;}
.hr-metrics .m{border:1px solid var(--nova-card-border);border-radius:12px;background:var(--nova-card-bg);padding:12px;}
.hr-metrics .v{font-size:22px;font-weight:800;color:var(--nova-table-text);}
.hr-hours-table{width:100%;border-collapse:collapse;}
.hr-hours-table th,.hr-hours-table td{padding:10px 12px;border-bottom:1px solid var(--nova-card-border);text-align:left;}
.ot-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);display:none;align-items:center;justify-content:center;padding:20px;z-index:1200;}
.ot-modal{width:min(520px,100%);background:#fff;border-radius:16px;box-shadow:0 30px 80px rgba(15,23,42,.25);padding:16px;}
.ot-modal form{display:grid;gap:10px;}
.ot-modal input{padding:9px 11px;border:1px solid var(--nova-card-border);border-radius:8px;}
.ot-modal-actions{display:flex;justify-content:flex-end;gap:8px;}

.pr-panel{border:1px solid var(--nova-card-border);border-radius:12px;padding:16px;margin-bottom:18px;background:var(--nova-card-bg);}
.pr-ww-nowrap{white-space:nowrap;}
.pr-btn-compact{width:auto;padding:6px 10px;color:#111;}
.pr-overflow-mb12{overflow:auto;margin-bottom:12px;}
.pr-center-pad16{text-align:center;padding:16px;}
.pr-center-pad18{text-align:center;padding:18px;}
.pwsp-filter-card{padding:18px; margin-bottom:14px;}
.pwsp-title{margin:0 0 8px;}
.pwsp-hint{margin:0 0 12px;}
.pwsp-filter-form{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.pwsp-card{padding:18px;}
.pwsp-head{margin-bottom:12px; display:flex; justify-content:space-between; gap:18px; align-items:flex-start; flex-wrap:wrap;}
.pwsp-head-title{margin:0;font-size:18px;font-weight:800;}
.pwsp-head-sub{margin:4px 0 0;}
.pwsp-head-right{margin:0;}
.pwsp-table-wrap{overflow:auto;}

.hr-layout { display:grid; grid-template-columns:minmax(280px,360px) minmax(0,1fr); gap:14px; }
.hr-panel { border:1px solid var(--nova-card-border); border-radius:14px; background:var(--nova-card-bg); padding:14px; }
.metric-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.metric-card { border:1px solid var(--nova-card-border); border-radius:12px; background:rgba(255,255,255,.62); padding:12px; }
.metric-card strong { display:block; font-size:22px; }
.upload-form label { display:flex; flex-direction:column; gap:4px; margin-bottom:10px; font-size:13px; font-weight:600; }
.upload-form input, .upload-form select, .upload-form textarea { padding:9px 11px; border:1px solid var(--nova-card-border); border-radius:8px; background:var(--nova-card-bg); color:var(--nova-table-text); }
.status-ok, .status-err { padding:10px 12px; border-radius:10px; margin-bottom:10px; }
.status-ok { background:#d1fae5; color:#065f46; }
.status-err { background:#fee2e2; color:#991b1b; }

@media (max-width: 960px) {
  .hr-layout { grid-template-columns:1fr; }
  .metric-grid { grid-template-columns:1fr 1fr; }
}

/* ---------- Personal schedule calendar ---------- */
.planner-shell { display:block; }
.planner-grid { border:1px solid var(--nova-card-border); border-radius:14px; background:var(--nova-card-bg); padding:10px; }
.month-nav { display:flex; align-items:center; gap:12px; }
.month-nav-btn { display:inline-flex; align-items:center; justify-content:center; width:36px; height:36px; border:1px solid var(--nova-card-border); border-radius:10px; background:var(--nova-card-bg); color:var(--nova-table-text); text-decoration:none; font-size:18px; font-weight:700; line-height:1; }
.month-nav-btn:hover { border-color:var(--nova-color-accent); }
.month-nav-label { font-size:16px; font-weight:700; min-width:160px; text-align:center; }
.planner-header { display:grid; grid-template-columns:repeat(7,minmax(0,1fr)); gap:8px; margin-bottom:8px; }
.planner-header div { padding:8px 10px; font-size:12px; font-weight:700; color:#64748b; text-transform:uppercase; }
.planner-days { display:grid; grid-template-columns:repeat(7,minmax(0,1fr)); gap:8px; }
.planner-day { min-height:150px; border:1px dashed rgba(100,116,139,.40); border-radius:14px; padding:10px; background:rgba(203,213,225,.46); display:flex; flex-direction:column; gap:8px; }
.planner-shell:not(.readonly-mode) .planner-day:not(.planner-day--empty) { cursor:pointer; }
.planner-day--empty { background:transparent; border-color:transparent; min-height:150px; }
.planner-day--holiday { background:rgba(254, 202, 202, .75); border-color:rgba(220, 38, 38, .65); }
.planner-day.weekend.planner-day--holiday { background:rgba(252, 165, 165, .78); border-color:rgba(185, 28, 28, .75); }
.planner-day.weekend { background:rgba(100,116,139,.30); border-color:rgba(71,85,105,.60); }
.planner-day__title { font-weight:800; font-size:15px; color:var(--nova-table-text); }
.planner-holiday-flag { display:inline-flex; align-items:center; gap:6px; align-self:flex-start; border-radius:8px; padding:3px 8px; background:rgba(254,226,226,.9); color:#7f1d1d; border:1px solid rgba(220,38,38,.35); font-size:11px; font-weight:700; }
.planner-holiday-square { width:10px; height:10px; border-radius:2px; background:#dc2626; border:1px solid #991b1b; display:inline-block; }
.planner-entry { border-radius:10px; padding:7px 9px; color:#fff; font-size:12px; cursor:pointer; }
.readonly-mode .planner-entry { cursor:default; }
.planner-entry.leave { background:#f59e0b; }
.planner-entry.sick_leave { background:#dc2626; }
.planner-entry.holiday { background:#0f766e; }
.planner-entry.custom_shift { background:#7c3aed; }
.planner-entry .muted { color:rgba(255,255,255,.86); display:block; font-size:11px; }
.shift-tag { display:inline-flex; align-items:center; gap:8px; padding:6px 12px; border-radius:999px; color:#fff; font-weight:700; margin:0 6px 6px 0; font-size:12px; }
.readonly-mode .planner-modal-backdrop { display:none !important; }
.planner-modal-backdrop { position:fixed; inset:0; background:rgba(15,23,42,.48); display:none; align-items:center; justify-content:center; padding:20px; z-index:1200; }
.planner-modal-backdrop.is-open { display:flex; }
.planner-modal { width:min(520px,100%); background:#fff; border-radius:18px; box-shadow:0 30px 80px rgba(15,23,42,.25); padding:18px; }
.planner-modal form { display:grid; gap:10px; }
.planner-modal input, .planner-modal select, .planner-modal textarea { padding:8px 10px; border:1px solid var(--nova-card-border); border-radius:8px; background:var(--nova-card-bg); color:var(--nova-table-text); width:100%; }
.planner-modal-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:8px; }
.planner-btn { border:none; border-radius:8px; padding:8px 14px; cursor:pointer; font-weight:700; font-size:13px; }
.planner-btn,.month-nav-btn { color:#111 !important; }
#shiftTemplateForm .btn.primary,#plannerModalForm .btn.primary { color:#fff !important; }
.shift-form { border:1px solid var(--nova-card-border); border-radius:12px; padding:12px; background:var(--nova-card-bg); }
.shift-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:10px; }
.shift-grid label { display:flex; flex-direction:column; gap:6px; font-size:13px; font-weight:600; }
.shift-grid input { padding:8px 10px; border:1px solid var(--nova-card-border); border-radius:8px; background:var(--nova-card-bg); color:var(--nova-table-text); }
.shift-template-table, .monthly-plan-table { width:100%; border-collapse:collapse; margin-top:12px; }
.shift-template-table th, .shift-template-table td, .monthly-plan-table th, .monthly-plan-table td { padding:10px 12px; border-bottom:1px solid var(--nova-card-border); text-align:left; vertical-align:middle; }
.shift-template-table th, .monthly-plan-table th { font-size:12px; text-transform:uppercase; color:#64748b; }
.shift-actions, .monthly-plan-actions { display:flex; gap:8px; flex-wrap:wrap; }
.monthly-plan-input { width:110px; padding:8px 10px; border:1px solid var(--nova-card-border); border-radius:8px; background:var(--nova-card-bg); color:var(--nova-table-text); }
.monthly-plan-note-input { width:220px; }
.legend-color { display:inline-block; width:16px; height:16px; border-radius:6px; }
.btn-danger-soft { background:#fee2e2; border-color:#fecaca; color:#7f1d1d; }
.ps-section { padding:18px; margin-bottom:14px; }
.ps-section-last { padding:18px; }
.ps-head { display:flex; justify-content:space-between; gap:12px; align-items:center; flex-wrap:wrap; margin-bottom:0; }
.ps-head-spaced { margin-bottom:12px; }
.ps-title { margin:0; font-size:17px; font-weight:700; }
.ps-sub { margin:4px 0 0; }
.ps-actions { margin-top:12px; display:flex; gap:8px; flex-wrap:wrap; }
.ps-overflow { overflow:auto; }
.is-hidden { display:none; }
.weekday-mini { font-size:11px; font-weight:600; }
.entry-employee-name { display:block; font-weight:700; font-size:11px; opacity:.9; margin-bottom:2px; }
.ps-legend-row { margin-top:14px; display:flex; gap:6px; flex-wrap:wrap; align-items:center; font-size:12px; }
.ps-legend-label { font-weight:700; margin-right:4px; }
.shift-tag-leave { background:#f59e0b; }
.shift-tag-sick { background:#dc2626; }
.shift-tag-holiday { background:#0f766e; }
.shift-tag-custom-shift { background:#7c3aed; }
.ps-modal-title { margin:0 0 10px; }

@keyframes personalPlannerModalIn {
  from { opacity:0; transform:translateY(15px); }
  to { opacity:1; transform:translateY(0); }
}
[data-personal-floating-modal="1"] {
  position:fixed;
  top:0;
  left:0;
  width:100vw;
  height:100dvh;
  background:var(--nova-modal-backdrop-bg);
  display:none;
  align-items:center;
  justify-content:center;
  padding:var(--nova-space-4);
  z-index:var(--nova-modal-z);
  overflow:hidden;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
[data-personal-floating-modal="1"].is-open { display:flex; }
[data-personal-floating-modal="1"] .planner-modal {
  position:relative;
  width:var(--nova-modal-width);
  max-height:var(--nova-modal-max-h);
  overflow-y:auto;
  background:var(--nova-modal-bg);
  color:var(--nova-modal-fg);
  border:1px solid var(--nova-modal-border);
  border-radius:var(--nova-modal-radius);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  box-shadow:var(--nova-modal-shadow);
  padding:var(--nova-modal-pad);
  margin:0 auto;
  animation:personalPlannerModalIn .25s ease-out;
}
[data-personal-floating-modal="1"] .planner-modal form { display:grid; gap:10px; }
[data-personal-floating-modal="1"] .planner-modal input,
[data-personal-floating-modal="1"] .planner-modal select,
[data-personal-floating-modal="1"] .planner-modal textarea {
  padding:8px 10px;
  border:1px solid var(--nova-card-border);
  border-radius:8px;
  background:var(--nova-card-bg);
  color:var(--nova-table-text);
  width:100%;
}
[data-personal-floating-modal="1"] .planner-modal-actions {
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top:8px;
  flex-wrap:wrap;
}
[data-personal-floating-modal="1"] #plannerDeleteBtn {
  background:#fee2e2;
  border-color:#fecaca;
  color:#7f1d1d;
}

/* ---------- Personal weekly schedule print ---------- */
body.weekly-schedule-print-page { background:#f3f4f6; color:#111827; margin:0; }
.print-sheet { width:min(1180px, calc(100vw - 48px)); margin:28px auto; background:#fff; color:#111827; padding:28px 30px 38px; box-shadow:0 18px 40px rgba(15,23,42,.14); }
.print-header { display:flex; justify-content:space-between; gap:24px; align-items:flex-start; border-bottom:2px solid #111827; padding-bottom:14px; margin-bottom:18px; }
.print-brand { font-size:24px; font-weight:800; letter-spacing:.01em; }
.print-meta { text-align:right; }
.print-title { margin:0; font-size:24px; font-weight:800; }
.print-subtitle { margin:6px 0 0; font-size:14px; color:#374151; font-weight:600; }
.schedule-grid { width:100%; border-collapse:collapse; table-layout:fixed; margin-top:14px; }
.schedule-grid th,.schedule-grid td { border:1px solid #111827; padding:8px 6px; text-align:center; vertical-align:middle; font-size:12px; }
.schedule-grid thead th { background:#e5e7eb; font-weight:800; }
.schedule-grid tbody th { text-align:left; background:#f9fafb; font-weight:700; width:170px; }
.date-line { display:block; font-size:12px; font-weight:700; }
.day-line { display:block; margin-top:2px; font-size:11px; color:#4b5563; }
.cell-content { min-height:34px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2px; }
.print-legend { margin-top:18px; display:flex; flex-wrap:wrap; gap:10px; }
.print-legend-item { display:inline-flex; align-items:center; gap:6px; font-size:12px; color:#1f2937; }
.print-legend-dot { width:12px; height:12px; border-radius:999px; border:1px solid rgba(17,24,39,.25); }
.print-footer { margin-top:22px; display:flex; justify-content:space-between; align-items:flex-end; gap:20px; }
.print-signature { width:min(320px,100%); border-top:1px solid #111827; padding-top:8px; font-size:12px; color:#374151; }
.print-note { font-size:11px; color:#6b7280; }
.signature-block { min-width:280px; text-align:right; }
.signature-label { font-size:14px; font-weight:600; margin-bottom:42px; }
.signature-line { border-top:1.5px solid #111827; width:280px; margin-left:auto; }
.print-actions { width:min(1180px, calc(100vw - 48px)); margin:18px auto 0; display:flex; justify-content:flex-end; gap:12px; }
.print-action-btn { border:none; border-radius:10px; background:#111827; color:#fff; font-weight:700; padding:10px 18px; cursor:pointer; }
.print-action-btn.secondary { background:#e5e7eb; color:#111827; }

.print-btn { background:var(--nova-color-accent, #111827); color:#fff; border:1px solid rgba(15,23,42,.2); border-radius:8px; padding:10px 22px; font-weight:700; cursor:pointer; font-size:14px; text-decoration:none; display:inline-flex; align-items:center; justify-content:center; }
.weekly-load-btn { background:#e5e7eb; color:#111827; border:1px solid rgba(15,23,42,.2); border-radius:8px; padding:10px 18px; font-weight:700; cursor:pointer; }
.weekly-load-btn:hover { background:#dbe1ea; }
.schedule-grid .cell-empty { background:#fafafa; }
.cell-label { display:block; font-size:11px; font-weight:700; color:inherit; line-height:1.2; }
.cell-time { display:block; font-size:10px; color:inherit; opacity:.92; margin-top:2px; }
.day-header { font-size:11px; color:#64748b; }
.schedule-cell--empty { background:transparent; color:#111827; border-color:#d1d5db; }
.schedule-cell--leave { background:#e5e7eb; color:#111827; border-color:#9ca3af; }
.schedule-cell--sick { background:#fecaca; color:#111827; border-color:#ef4444; }
.schedule-cell--holiday { background:#ccfbf1; color:#0f172a; border-color:#14b8a6; }

@media (max-width: 980px) { .planner-shell { grid-template-columns:1fr; } }
@media (max-width: 720px) { .planner-header, .planner-days { grid-template-columns:1fr; } .planner-day { min-height:unset; } }
@media print {
  html, body, .print-sheet, .schedule-grid, .schedule-grid th, .schedule-grid td {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
    forced-color-adjust: none !important;
  }
  body.weekly-schedule-print-page { background:#fff; }
  .print-actions { display:none !important; }
  .print-sheet { width:auto; margin:0; box-shadow:none; padding:8mm 8mm 12mm; }
  .print-header { margin-bottom:12px; }
  .schedule-grid th, .schedule-grid td { padding:6px 4px; font-size:11px; }
  .print-footer { margin-top:16px; }
}

.hr-doc-table { width:100%; border-collapse:collapse; }
.hr-doc-table th, .hr-doc-table td { padding:10px 12px; border-bottom:1px solid var(--nova-card-border); text-align:left; }
.hr-pill { display:inline-block; padding:3px 9px; border-radius:999px; background:rgba(37,99,235,.12); color:var(--nova-color-accent-strong); font-size:12px; }
.docs-summary-grid { display:grid; gap:14px; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); margin:0 0 18px; }
.docs-summary-card { position:relative; overflow:hidden; border:1px solid rgba(148,163,184,.18); border-radius:18px; padding:18px 18px 16px; background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(248,250,252,.78)); box-shadow:0 14px 36px rgba(15,23,42,.08); }
.docs-summary-card::after { content:""; position:absolute; inset:auto -22px -28px auto; width:96px; height:96px; border-radius:999px; background:radial-gradient(circle, rgba(59,130,246,.22), rgba(59,130,246,0)); }
.docs-summary-label { margin:0 0 8px; font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:#64748b; }
.docs-summary-value { margin:0; font-size:31px; line-height:1; font-weight:900; color:#0f172a; letter-spacing:-.05em; }
.docs-summary-copy { margin:8px 0 0; font-size:13px; color:#475569; }
.docs-grid { display:grid; gap:14px; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); }
.docs-section { border:1px solid rgba(148,163,184,.18); border-radius:22px; background:linear-gradient(180deg, rgba(255,255,255,.9), rgba(248,250,252,.84)); padding:18px; box-shadow:0 18px 42px rgba(15,23,42,.08); }
.docs-section-head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin:0 0 14px; }
.docs-section-title-wrap { display:flex; flex-direction:column; gap:6px; }
.docs-section-title { margin:0; font-size:18px; line-height:1.2; color:#0f172a; }
.docs-count-badge { display:inline-flex; align-items:center; justify-content:center; min-width:34px; height:34px; border-radius:999px; padding:0 12px; background:#0f172a; color:#fff; font-size:13px; font-weight:800; box-shadow:0 12px 24px rgba(15,23,42,.18); }
.docs-list { display:grid; gap:12px; }
.docs-item { display:grid; gap:10px; padding:14px; border:1px solid rgba(148,163,184,.16); border-radius:16px; background:rgba(255,255,255,.72); }
.docs-item-top { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; }
.docs-item-title { margin:0; font-size:15px; font-weight:800; color:#0f172a; }
.docs-item-file { margin:4px 0 0; font-size:12px; color:#64748b; word-break:break-word; }
.docs-item-meta { display:flex; flex-wrap:wrap; gap:8px; }
.docs-meta-pill { display:inline-flex; align-items:center; gap:6px; min-height:28px; border-radius:999px; padding:0 10px; background:rgba(15,23,42,.05); color:#334155; font-size:12px; font-weight:700; }
.docs-item-note { margin:0; padding:10px 12px; border-radius:12px; background:rgba(59,130,246,.06); color:#334155; font-size:13px; line-height:1.5; }
.docs-item-actions { display:flex; justify-content:flex-end; }
.doc-download-link { display:inline-flex; align-items:center; justify-content:center; min-width:132px; min-height:42px; padding:0 14px; border-radius:12px; text-decoration:none; background:linear-gradient(135deg, #0f172a, #1d4ed8); color:#fff; font-weight:800; box-shadow:0 14px 28px rgba(29,78,216,.18); }
.doc-download-link:hover { filter:brightness(1.03); transform:translateY(-1px); }
.docs-empty { margin:0; padding:16px; border-radius:16px; border:1px dashed rgba(148,163,184,.35); background:rgba(255,255,255,.52); color:#64748b; }
.docs-locked { position:relative; min-height:calc(100vh - 280px); border-radius:26px; overflow:hidden; background:linear-gradient(180deg, rgba(203,213,225,.28), rgba(226,232,240,.56) 38%, rgba(241,245,249,.82) 100%); box-shadow:inset 0 0 0 1px rgba(148,163,184,.18); }
.docs-locked .docs-lock-target { min-height:inherit; padding:18px 18px 120px; filter:blur(7px) saturate(.9); pointer-events:none; user-select:none; }
.docs-2fa-modal-backdrop { position:fixed; inset:0; background:radial-gradient(circle at top, rgba(59,130,246,.16), rgba(15,23,42,.62) 42%, rgba(15,23,42,.74) 100%); backdrop-filter: blur(8px); display:flex; align-items:center; justify-content:center; padding:24px; z-index:1400; }
.docs-2fa-modal { width:min(560px,100%); position:relative; overflow:hidden; background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,250,252,.96)); border:1px solid rgba(255,255,255,.72); border-radius:24px; box-shadow:0 28px 90px rgba(15,23,42,.28); padding:0; }
.docs-2fa-modal::before { content:""; position:absolute; inset:0 auto auto 0; width:100%; height:6px; background:linear-gradient(90deg, #0f172a, #2563eb, #38bdf8); }
.docs-2fa-modal-body { display:grid; grid-template-columns:minmax(0, 1.15fr) minmax(220px, .85fr); gap:0; background:linear-gradient(135deg, rgba(255,255,255,.82), rgba(248,250,252,.94)); }
.docs-2fa-main { position:relative; padding:28px 28px 24px; background:linear-gradient(160deg, rgba(239,246,255,.96), rgba(255,255,255,.92) 52%, rgba(224,231,255,.72) 100%); }
.docs-2fa-main::after { content:""; position:absolute; inset:auto auto -56px -44px; width:180px; height:180px; border-radius:999px; background:radial-gradient(circle, rgba(37,99,235,.18), rgba(37,99,235,0) 70%); pointer-events:none; }
.docs-2fa-side { border-left:1px solid rgba(148,163,184,.18); background:linear-gradient(180deg, rgba(37,99,235,.08), rgba(15,23,42,.03)); padding:28px 22px 24px; display:flex; flex-direction:column; justify-content:center; gap:14px; }
.docs-2fa-badge { width:52px; height:52px; border-radius:16px; display:inline-flex; align-items:center; justify-content:center; background:linear-gradient(135deg, #0f172a, #1d4ed8); color:#fff; font-size:24px; box-shadow:0 16px 30px rgba(29,78,216,.22); margin-bottom:16px; position:relative; z-index:1; }
.docs-2fa-title { margin:0 0 8px; font-size:27px; line-height:1.08; color:#0f172a; letter-spacing:-.03em; position:relative; z-index:1; }
.docs-2fa-subtitle { margin:0 0 18px; color:#475569; max-width:34ch; font-size:14px; line-height:1.55; position:relative; z-index:1; }
.docs-2fa-form { display:flex; flex-direction:column; gap:14px; position:relative; z-index:1; padding:16px; border-radius:18px; border:1px solid rgba(148,163,184,.16); background:rgba(255,255,255,.62); box-shadow:0 18px 38px rgba(15,23,42,.08); }
.docs-2fa-label { display:flex; flex-direction:column; gap:7px; font-size:13px; font-weight:700; color:#0f172a; }
.docs-2fa-input { width:100%; max-width:220px; height:50px; border-radius:14px; border:1px solid rgba(148,163,184,.42); background:#fff; color:#0f172a; font-size:22px; letter-spacing:.28em; text-align:center; font-weight:800; box-shadow: inset 0 1px 0 rgba(255,255,255,.92), 0 1px 2px rgba(15,23,42,.05); }
.docs-2fa-input:focus { outline:none; border-color:#2563eb; box-shadow:0 0 0 4px rgba(37,99,235,.14); }
.docs-2fa-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.docs-2fa-button { min-width:168px; height:48px; border:none; border-radius:14px; background:linear-gradient(135deg, #0f172a, #1e3a8a); color:#fff; font-weight:800; letter-spacing:.01em; box-shadow:0 16px 28px rgba(15,23,42,.2); }
.docs-2fa-button:hover { filter:brightness(1.03); transform:translateY(-1px); }
.docs-2fa-error { margin:0; padding:11px 13px; border-radius:14px; background:rgba(239,68,68,.10); border:1px solid rgba(239,68,68,.18); color:#991b1b; font-weight:700; font-size:13px; }
.docs-2fa-side-title { margin:0; font-size:15px; font-weight:800; color:#0f172a; }
.docs-2fa-side-copy { margin:0; font-size:13px; line-height:1.6; color:#475569; }
.docs-2fa-side-points { display:grid; gap:10px; margin:0; }
.docs-2fa-side-point { display:flex; gap:10px; align-items:flex-start; color:#0f172a; font-size:13px; line-height:1.5; }
.docs-2fa-side-dot { width:9px; height:9px; flex:0 0 9px; border-radius:999px; margin-top:6px; background:linear-gradient(135deg, #1d4ed8, #38bdf8); box-shadow:0 0 0 4px rgba(59,130,246,.10); }

@media (max-width: 760px) {
  .docs-locked { min-height:calc(100vh - 220px); }
  .docs-locked .docs-lock-target { padding:14px 14px 100px; }
  .docs-2fa-modal-backdrop { padding:14px; }
  .docs-2fa-modal-body { grid-template-columns:1fr; }
  .docs-2fa-side { border-left:none; border-top:1px solid rgba(148,163,184,.18); }
  .docs-2fa-main, .docs-2fa-side { padding:22px 20px; }
  .docs-2fa-title { font-size:23px; }
  .docs-2fa-input, .docs-2fa-button { max-width:none; width:100%; }
  .docs-2fa-actions { align-items:stretch; }
  .docs-item-top, .docs-section-head { flex-direction:column; align-items:flex-start; }
  .docs-item-actions { justify-content:stretch; }
  .doc-download-link { width:100%; }
}

@media print {
  @page { margin: 10mm; }
  .topbar, .nova-topbar, .footer, .nova-chat-fab, .nova-chat-panel, .nova-chat-backdrop { display:none !important; }
  body { background:#fff !important; }
  .shell { max-width:100% !important; padding:0 !important; }
  .card.glass-card { box-shadow:none !important; border:none !important; padding:0 !important; }
  .report-table { font-size:11px; }
}

/* ---------- Personal dashboard host ---------- */
.personal-dashboard-page main.shell[data-personal-dashboard="1"] {
  width: min(1400px, calc(100vw - 48px)) !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
}
.personal-dashboard-page main.shell[data-personal-dashboard="1"] .personal-module-top-card {
  margin: 0 !important;
  border-radius: 0 !important;
  border-left: none !important;
  border-right: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  padding: var(--nova-shell-pad-x) !important;
  padding-bottom: 18px !important;
}
.personal-dashboard-page main.shell[data-personal-dashboard="1"] .module-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
  gap: 12px !important;
}
.personal-dashboard-page main.shell[data-personal-dashboard="1"] .module-grid > .hr-card-link {
  display: block !important;
  width: 100% !important;
}
.personal-dashboard-page main.shell[data-personal-dashboard="1"] #personal-module-viewer {
  width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}
.module-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:12px; }
.hr-card-link {
  display:block; text-decoration:none; color:inherit;
  border:1px solid var(--nova-card-border); border-radius:14px;
  background:var(--nova-card-bg); padding:14px; cursor:pointer;
}
.hr-card-link:hover { border-color: var(--nova-card-border-hover); background: var(--nova-card-bg-hover); }
.hr-card-link.active {
  border-color: var(--nova-color-accent);
  box-shadow: 0 0 0 1px rgba(37,99,235,.22) inset;
  background: rgba(255,255,255,.72);
}
.hr-card-link h3 { margin:0 0 6px; font-size:16px; }
.hr-card-link p { margin:0; color:#64748b; font-size:13px; }
.personal-module-viewer {
  border:1px solid var(--nova-card-border);
  border-radius:18px;
  background:var(--nova-card-bg);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  box-shadow:var(--nova-card-shadow);
  overflow:hidden;
  width:100%;
}
.personal-module-viewer-head {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:14px 18px; border-bottom:1px solid var(--nova-card-border);
  background:var(--nova-card-bg);
}
.personal-module-viewer-head h2 { margin:0; font-size:18px; }
.personal-module-content-wrap { padding:0; background:#fff; min-height:720px; overflow:auto; }
.personal-module-viewer.personal-modal-open { overflow:visible; }
.personal-module-content-wrap.personal-modal-open { overflow:visible; }
.personal-module-content { min-height:100%; }
.personal-dashboard-page #personal-module-content .btn:not(.primary):not(.danger):not(.btn--danger) {
  color:#111827 !important;
  border-color:rgba(15,23,42,.24);
  background:rgba(15,23,42,.08);
}
.personal-dashboard-page #personal-module-content .btn:not(.primary):not(.danger):not(.btn--danger):hover {
  background:rgba(15,23,42,.14);
  border-color:rgba(15,23,42,.34);
}
.personal-dashboard-page #personal-module-content .btn.secondary,
.personal-dashboard-page #personal-module-content .btn.ghost,
.personal-dashboard-page #personal-module-content .btn.btn--ghost {
  color:#111827 !important;
  background:rgba(255,255,255,.92);
  border-color:rgba(15,23,42,.24);
}
.personal-dashboard-page #personal-module-content .btn.primary {
  color:#ffffff !important;
  background:#111827;
  border-color:#111827;
}
.personal-module-loader { font-size:12px; color:#64748b; padding:8px 18px 0; }

@media (max-width: 920px) {
  .personal-module-content-wrap { min-height:540px; }
}
@media (max-width: 900px) {
  .personal-dashboard-page main.shell[data-personal-dashboard="1"] { width: calc(100vw - 36px) !important; }
}
@media (max-width: 600px) {
  .personal-dashboard-page main.shell[data-personal-dashboard="1"] { width: calc(100vw - 28px) !important; }
  .personal-module-content-wrap { min-height:400px; }
}
.toggle-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.55);
}
.toggle-item strong {
  text-transform: capitalize;
}
.superadmin-users-toolbar {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}
.superadmin-create-user {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}
@media (max-width: 800px) {
  .superadmin-create-user {
    grid-template-columns: 1fr;
  }
}
.superadmin-create-user input {
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  padding: 8px 10px;
}
.superadmin-modal-footer {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}
/* Wider panel for superadmin create-user modal */
#superadmin-create-user-modal .dashboard-modal__panel {
  width: min(640px, 96vw);
}
.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.9rem;
}
.superadmin-users-toolbar input {
  flex: 1 1 auto;
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  padding: 8px 10px;
}
.superadmin-users-list {
  display: grid;
  gap: 8px;
  max-height: 380px;
  overflow-y: auto;
}
.superadmin-modal {
  position: fixed;
  inset: 0;
  z-index: calc(var(--nova-modal-z) + 20);
  display: none;
}
.superadmin-modal.is-open {
  display: block;
}
.superadmin-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
}
.superadmin-modal__panel {
  position: relative;
  z-index: 1;
  width: min(760px, calc(100vw - 24px));
  margin: 7vh auto 0;
  background: rgba(255,255,255,0.98);
  border: 1px solid rgba(0,0,0,0.14);
  border-radius: 14px;
  box-shadow: 0 18px 40px rgba(0,0,0,0.22);
  display: flex;
  flex-direction: column;
  max-height: 86vh;
}
.superadmin-modal__header,
.superadmin-modal__footer {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.superadmin-modal__footer {
  border-bottom: none;
  border-top: 1px solid rgba(0,0,0,0.08);
  justify-content: flex-end;
}
.superadmin-modal__body {
  padding: 14px;
  overflow: auto;
}
.superadmin-user-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: nowrap;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 10px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.55);
  overflow-x: auto;
}
.superadmin-user-meta {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}

.superadmin-audit-item {
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  padding: 12px;
  overflow: hidden;
  border-left-width: 4px;
}
.superadmin-audit-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
.superadmin-audit-title-wrap {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.superadmin-audit-title {
  font-size: 0.96rem;
  line-height: 1.2;
  word-break: break-word;
}
.superadmin-audit-subtitle {
  font-size: 0.75rem;
  letter-spacing: 0.01em;
  word-break: break-word;
}
.superadmin-audit-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.superadmin-audit-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.72rem;
  border: 1px solid rgba(15, 23, 42, 0.2);
  background: rgba(148, 163, 184, 0.14);
  color: #0f172a;
}
.superadmin-audit-badge--domain {
  background: rgba(37, 99, 235, 0.12);
  border-color: rgba(37, 99, 235, 0.35);
  color: #1d4ed8;
}
.superadmin-audit-item--security { border-left-color: #dc2626; }
.superadmin-audit-item--stock { border-left-color: #2563eb; }
.superadmin-audit-item--personal { border-left-color: #7c3aed; }
.superadmin-audit-item--service { border-left-color: #0f766e; }
.superadmin-audit-item--hr { border-left-color: #9333ea; }
.superadmin-audit-item--shift_leader { border-left-color: #ea580c; }

.superadmin-audit-badge--security { background: rgba(220, 38, 38, 0.14); border-color: rgba(220, 38, 38, 0.35); color: #b91c1c; }
.superadmin-audit-badge--stock { background: rgba(37, 99, 235, 0.14); border-color: rgba(37, 99, 235, 0.35); color: #1d4ed8; }
.superadmin-audit-badge--personal { background: rgba(124, 58, 237, 0.14); border-color: rgba(124, 58, 237, 0.35); color: #6d28d9; }
.superadmin-audit-badge--service { background: rgba(15, 118, 110, 0.14); border-color: rgba(15, 118, 110, 0.35); color: #0f766e; }
.superadmin-audit-badge--hr { background: rgba(147, 51, 234, 0.14); border-color: rgba(147, 51, 234, 0.35); color: #7e22ce; }
.superadmin-audit-badge--shift_leader { background: rgba(234, 88, 12, 0.14); border-color: rgba(234, 88, 12, 0.35); color: #c2410c; }
.superadmin-audit-time {
  font-size: 0.8rem;
  white-space: nowrap;
}
.superadmin-audit-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 8px;
}
.superadmin-audit-meta-item {
  border: 1px dashed rgba(15, 23, 42, 0.16);
  border-radius: 8px;
  padding: 6px 8px;
  display: grid;
  gap: 2px;
}
.superadmin-audit-meta-item strong {
  font-size: 0.84rem;
  word-break: break-word;
}
.superadmin-audit-details details {
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.45);
}
.superadmin-audit-details summary {
  cursor: pointer;
  padding: 6px 10px;
  font-weight: 600;
  font-size: 0.82rem;
}
.superadmin-audit-pre {
  margin: 0;
  padding: 8px 10px 10px;
  max-height: 180px;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
  font-size: 0.78rem;
  line-height: 1.35;
  color: #334155;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}
.superadmin-audit-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
}
.superadmin-audit-badge--done {
  background: rgba(22, 163, 74, 0.16);
  border-color: rgba(22, 163, 74, 0.36);
  color: #166534;
}

.nova-bg-upload-panel {
  position: fixed;
  right: 16px;
  bottom: 16px;
  width: min(430px, calc(100vw - 24px));
  max-height: min(70vh, 520px);
  overflow: auto;
  z-index: 11000;
  border: 1px solid var(--nova-card-border);
  border-radius: 14px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 26px rgba(15, 23, 42, .18);
  backdrop-filter: blur(6px);
}
.nova-bg-upload-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(15, 23, 42, .08);
}
.nova-bg-upload-list { padding: 10px; display: grid; gap: 8px; }
.nova-bg-upload-empty { font-size: 12px; }
.nova-bg-upload-item {
  border: 1px solid rgba(15, 23, 42, .1);
  border-radius: 10px;
  padding: 8px 10px;
  background: #fff;
  overflow: hidden;
}
.nova-bg-upload-item.is-error { border-color: rgba(220, 38, 38, .45); background: rgba(254, 226, 226, .35); }
.nova-bg-upload-title {
  font-weight: 700;
  font-size: 13px;
  margin-bottom: 4px;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.nova-bg-upload-status {
  font-size: 12px;
  margin-bottom: 6px;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.nova-bg-upload-status.is-error { color: #b91c1c; }
.nova-bg-upload-bar-wrap {
  height: 8px;
  border-radius: 999px;
  background: rgba(148, 163, 184, .25);
  overflow: hidden;
}
.nova-bg-upload-bar {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, #2563eb, #06b6d4);
  transition: width .2s ease;
}
@media (max-width: 900px) {
  .superadmin-audit-meta {
    grid-template-columns: 1fr;
  }
}
.superadmin-user-item.is-password-pending {
  border-color: rgba(220, 38, 38, 0.7);
  box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.18);
  animation: superadminBorderPulse 1.25s ease-out infinite;
}
.superadmin-user-title-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.superadmin-status-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
  border: 1px solid rgba(255,255,255,0.85);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.06);
}
.superadmin-status-dot.online {
  background: #16a34a;
}
.superadmin-status-dot.offline {
  background: #ef4444;
}
.superadmin-pulse-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #dc2626;
  box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.7);
  animation: superadminPulse 1.2s ease-out infinite;
}
@keyframes superadminPulse {
  0% { box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.65); }
  75% { box-shadow: 0 0 0 10px rgba(220, 38, 38, 0); }
  100% { box-shadow: 0 0 0 0 rgba(220, 38, 38, 0); }
}
@keyframes superadminBorderPulse {
  0% { box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.18), 0 0 0 0 rgba(220, 38, 38, 0.35); }
  70% { box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.34), 0 0 0 8px rgba(220, 38, 38, 0); }
  100% { box-shadow: inset 0 0 0 1px rgba(220, 38, 38, 0.18), 0 0 0 0 rgba(220, 38, 38, 0); }
}
.superadmin-user-assign {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: nowrap;
  white-space: nowrap;
}
.superadmin-user-assign .input,
.superadmin-user-assign select {
  min-width: 140px;
}
.superadmin-user-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.12);
  font-size: 0.78rem;
  color: #334155;
  background: rgba(255,255,255,0.75);
}
.superadmin-reset-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.superadmin-reset-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.75rem;
  background: rgba(37, 99, 235, 0.15);
  color: #1d4ed8;
}
.superadmin-reset-selected {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 12px 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(15,23,42,0.08);
  box-shadow: 0 12px 30px rgba(15,23,42,0.08);
}
.superadmin-reset-form {
  align-items: center;
}
.sim-controls {
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.sim-controls label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sim-controls select {
  width: 100%;
  min-width: 180px;
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,.14);
  padding: 8px 10px;
}
.sim-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}
.sim-result {
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 10px;
  padding: 10px;
  background: rgba(255,255,255,.55);
  min-height: 52px;
}
.smtp-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0;
}
@media (max-width: 900px) {
  .smtp-grid {
    grid-template-columns: 1fr;
  }
}
.smtp-grid label {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.smtp-grid input,
.smtp-grid select {
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  padding: 8px 10px;
}


/* ===== ITEMS PAGE (migrated from inline style) ===== */
  /* Page-scoped tweaks for items list layout */
  .page-items .toolbar__row{
    display:flex;
    align-items:center;
    gap:12px;
    flex-wrap:wrap; /* prevent overlap on smaller widths */
  }
  .page-items .toolbar__left{
    display:flex;
    align-items:center;
    gap:12px;
    flex:1 1 auto;
    min-width:0;
  }
  .page-items .toolbar__right{
    margin-left:auto;      /* push back button to the far right */
    flex:0 0 auto;
  }
  /* Stretch the search input to the end of the container */
  .page-items .input--lg.input--stretch{
    flex:1 1 640px;        /* grow as space allows */
    min-width:260px;
  }
  /* Keep the warehouse selector a stable width; prevent wrap jitter */
  .page-items .toolbar__left .select{
    flex:0 0 260px;
    min-width:220px;
  }
  .page-items .toolbar--search .toolbar__left .input--lg.input--stretch,
  .page-items .toolbar--search .toolbar__left .select{
    min-height:42px;
    border-radius:999px;
    border:1px solid rgba(15,23,42,.14);
    background:rgba(255,255,255,.92);
    color:#0f172a;
    box-shadow:0 4px 14px rgba(15,23,42,.08);
  }
  .page-items .toolbar--search .toolbar__left .input--lg.input--stretch:focus,
  .page-items .toolbar--search .toolbar__left .select:focus{
    border-color:rgba(37,99,235,.55);
    box-shadow:0 0 0 3px rgba(37,99,235,.2);
    background:#fff;
  }
  .page-items .toolbar--search .toolbar__left .search-toggle{
    display:inline-flex;
    align-items:center;
    gap:8px;
    white-space:nowrap;
    min-height:42px;
    padding:0 14px;
    border-radius:999px;
    border:1px solid rgba(15,23,42,.12);
    background:rgba(255,255,255,.72);
    color:#0f172a;
    font-weight:600;
  }
  .page-items .toolbar--search .toolbar__left .search-toggle input[type="checkbox"]{
    width:16px;
    height:16px;
    accent-color:#2563eb;
  }
  .page-items .toolbar--search .toolbar__left .search-submit{
    border-radius:999px;
    min-height:42px;
    padding:10px 18px;
  }
  .page-items .toolbar__left .btn{
    flex:0 0 auto;
  }
  /* Make table scroller hints play nice on this page too */
  .page-items .table-wrap{
    position:relative;
    width:100%;
    max-width:100%;
    overflow-x:auto;
    overflow-y:visible;
    overscroll-behavior:auto;
    -webkit-overflow-scrolling:touch;
  }
  .page-items #items-table th,
  .page-items #items-table td{
    border-right:1px solid rgba(15,23,42,.12);
  }
  .page-items #items-table th:last-child,
  .page-items #items-table td:last-child{
    border-right:none;
  }
  /* Keep machine list compact: the "Gepek" column should fit in max two lines. */
  .page-items #items-table th:nth-child(8),
  .page-items #items-table td:nth-child(8){
    width:150px;
    max-width:150px;
  }
  .page-items #items-table td:nth-child(8){
    font-size:12px;
    line-height:1.2;
  }
  .page-items #items-table td:nth-child(8) .cell-extra1{
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:normal;
    word-break:break-word;
  }
  .items-location-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    border-radius:999px;
    padding:4px 10px;
    font-size:11px;
    font-weight:800;
    line-height:1.2;
    border:1px solid transparent;
    white-space:nowrap;
  }
  .items-location-badge--current{
    background:rgba(15,118,110,.10);
    border-color:rgba(15,118,110,.24);
    color:#0f766e;
  }
  .items-location-badge--other{
    background:rgba(37,99,235,.12);
    border-color:rgba(37,99,235,.26);
    color:#1d4ed8;
  }
  .page-items #items-table tr.items-row--cross-location td{
    background:rgba(219,234,254,.24);
  }
  .page-items #items-table tr.items-row--cross-location:hover td{
    background:rgba(191,219,254,.36);
  }
  .btn--danger{ background:#ffe5e5; color:#8a1f1f; border:1px solid #ffb3b3; }
  .btn--disabled{ opacity:.55; pointer-events:none; }

  .tbl th:first-child, .tbl td:first-child{ width:32px; text-align:center; }
  .btn.btn--sm{ padding:6px 8px; line-height:1; }
  .btn-group .btn{ min-width:32px; justify-content:center; }
  .selection-info{
    display:none;
    margin:12px 0 0;
    padding:8px 12px;
    border:1px solid #dbeafe;
    background:#eff6ff;
    border-radius:8px;
    gap:12px;
    align-items:center;
    flex-wrap:wrap;
    color:#0f172a;
  }
  .selection-info [data-role="selection-text"]{
    font-weight:500;
  }
  .selection-info .btn--ghost{
    color:#0f172a !important;
    border-color:#0f172a;
    background:transparent;
  }
  .actions-toggle-wrap{
    display:flex;
    justify-content:flex-end;
    margin:8px 0;
  }
  .page-items.actions-collapsed #items-table th.action-zone,
  .page-items.actions-collapsed #items-table td.action-zone{
    display:none;
  }
  .qty-cell{
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:6px;
    white-space:nowrap;
  }
  .qty-cell .stock-btn{
    width:28px;
    height:28px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:0;
    font-size:18px;
    line-height:1;
  }
  .qty-cell .qty-val{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:40px;
  }
  .js-start-test .icon-play{
    color:#16a34a;
  }
  .modal-overlay{
    position:fixed;
    inset:0;
    display:none;
    align-items:flex-start;
    justify-content:center;
    z-index:1500;
    padding:88px 20px 24px;
    box-sizing:border-box;
  }
  .modal-overlay.open{ display:flex; }
  .modal-overlay .modal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(15,23,42,.55);
  }
  .modal-overlay .modal-card{
    position:relative;
    background:#fff;
    border-radius:14px;
    padding:20px;
    box-shadow:0 20px 45px rgba(15,23,42,.25);
    width:100%;
    max-width:520px;
    max-height:calc(100vh - 120px);
    overflow:auto;
    z-index:10;
  }
  @media (max-width: 768px){
    .modal-overlay{
      padding:76px 12px 16px;
    }
    .modal-overlay .modal-card{
      max-height:calc(100vh - 96px);
    }
  }
  .modal-overlay .modal-close{
    position:absolute;
    right:12px;
    top:12px;
    border:none;
    background:none;
    font-size:20px;
    line-height:1;
    cursor:pointer;
    color:#475569;
  }
  .modal-overlay .modal-title{
    margin-top:0;
    margin-bottom:16px;
  }
  .modal-overlay .modal-actions{
    display:flex;
    justify-content:flex-end;
    gap:12px;
    margin-top:18px;
  }
  .modal-overlay .modal-actions .btn,
  .modal-overlay .modal-actions .btn.secondary{
    color:#0f172a !important;
  }
  .edit-form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
  }
  .edit-form-grid label{
    font-size:13px;
    font-weight:600;
    color:#0f172a;
    display:block;
    margin-bottom:4px;
  }
  .edit-form-grid .field{
    display:flex;
    flex-direction:column;
  }
  .edit-form-grid input{
    width:100%;
  }
  /* Harmonize input/select appearance with the currency dropdown */
  .edit-form-grid input,
  .edit-form-grid select{
    border:1px solid rgba(15,23,42,.18);
    border-radius:10px;
    padding:10px 12px;
    background:#fff;
    color:#0f172a;
    height:42px;
  }
  .edit-form-grid select{
    appearance:none;
    background-position: right 10px center;
    background-repeat:no-repeat;
  }
  .price-input{
    display:flex;
    gap:8px;
    align-items:center;
  }
  .price-input .price-currency{
    max-width:110px;
    text-transform:uppercase;
  }
  @media (max-width:560px){
    .edit-form-grid{
      grid-template-columns:1fr;
    }
  }
  .modal-card .form-row{
    display:flex;
    flex-direction:column;
    gap:4px;
    margin-bottom:14px;
  }
  .modal-card textarea{
    resize:vertical;
  }
  .modal-card .input.is-invalid{
    border-color:#dc2626 !important;
    box-shadow:0 0 0 2px rgba(220,38,38,.15);
  }
  .modal-card .field-error-msg{
    color:#b91c1c;
    font-size:12px;
    font-weight:600;
    margin-top:2px;
  }

/* ============================================================
   Warehouse Layout Designer - app/Modules/Inventory
   ============================================================*/
    body { margin:0; }
    .layout-shell {
      display:flex;
      gap:0;
      height:calc(100vh - var(--nova-topbar-h));
      padding-top:var(--nova-topbar-h);
    }
    .panel { padding:16px; overflow:auto; }
    .panel.left { width:320px; }
    .panel.right { width:340px; }
    .canvas-wrap {
      flex:1;
      position:relative;
      margin:16px 16px 16px 0;
      border:1px solid var(--nova-card-border);
      border-radius:18px;
      background:var(--nova-card-bg);
      backdrop-filter: blur(22px) saturate(140%);
      -webkit-backdrop-filter: blur(22px) saturate(140%);
      box-shadow: var(--nova-card-shadow);
      overflow:hidden;
    }
    #canvas { width:100%; height:100%; cursor:default; }
    #canvas .grid line { stroke:rgba(148,163,184,.5); stroke-width:0.6; }
    .toolbar button,
    .canvas-toolbar button,
    #place-items,
    #btn-apply,
    #btn-rotate-left,
    #btn-rotate-right,
    #btn-delete,
    [data-copy-cancel],
    [data-copy-confirm] {
      background: var(--nova-btn-bg);
      color: var(--nova-btn-text);
      border: 1px solid var(--nova-btn-border);
      border-radius: 12px;
      padding: 8px 12px;
      cursor: pointer;
      font-weight: 700;
      box-shadow: var(--nova-btn-shadow);
      transition: background .2s, border-color .2s, transform .12s ease;
    }
    .toolbar button:hover,
    .canvas-toolbar button:hover,
    #place-items:hover,
    #btn-apply:hover,
    #btn-rotate-left:hover,
    #btn-rotate-right:hover,
    #btn-delete:hover,
    [data-copy-cancel]:hover,
    [data-copy-confirm]:hover {
      background: var(--nova-btn-bg-hover);
      border-color: var(--nova-btn-border-hover);
      transform: translateY(-1px);
    }
    .toolbar button.is-active { background: var(--nova-btn-ghost-bg-hover); border-color: var(--nova-btn-ghost-border); color: var(--nova-btn-ghost-text); }
    .tool-grid { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:8px; margin-top:8px; }
    .quick-actions { display:grid; grid-template-columns:1fr; gap:8px; margin:10px 0; }
    .section-title { font-size:12px; color:var(--nova-muted); text-transform:uppercase; letter-spacing:.08em; margin-bottom:6px; }
    .dot { display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:6px; }
    .dot.red { background:#ef4444; } .dot.orange { background:#f59e0b; } .dot.green { background:#22c55e; }
    .layout-list button { width:100%; text-align:left; margin-bottom:0; }
    .layout-list > div { align-items: center; }
    .search { margin-bottom:12px; }
    .inspector label { display:block; font-size:12px; color:var(--nova-muted); margin-top:8px; }
    .inspector input { width:100%; }
    .sel-outline { stroke:#60a5fa; stroke-width:2; fill:none; pointer-events:none; }
    .canvas-toolbar {
      position:absolute;
      top:10px;
      right:10px;
      display:flex;
      gap:4px;
      background: var(--nova-card-bg);
      border:1px solid var(--nova-card-border);
      padding:4px;
      border-radius:12px;
      backdrop-filter: blur(14px) saturate(130%);
    }
    .canvas-toolbar button,
    .canvas-toolbar select {
      min-height: 30px;
      font-size: 12px;
      padding: 5px 8px;
      border-radius: 8px;
    }
    .preview-active #canvas { cursor:default; }
    .preview-badge { color:#1d4ed8; font-weight:700; }
    .panel.right { display:none; }
    .modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,0.45); display:none; align-items:center; justify-content:center; z-index:50; }
    .modal-backdrop.show { display:flex; }
    .modal-card { background:var(--nova-card-bg); border:1px solid var(--nova-card-border); padding:16px; border-radius:16px; box-shadow:var(--nova-card-shadow-hover); max-width:460px; width:90%; max-height:90vh; overflow:auto; }
    .hint-chip { display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; background:var(--nova-btn-ghost-bg); color:var(--nova-btn-ghost-text); border:1px solid var(--nova-btn-ghost-border); font-size:12px; margin-right:6px; }
    .empty-placeholder { border:1px dashed var(--border); border-radius:14px; padding:30px; text-align:center; color:var(--muted); background:rgba(255,255,255,0.7); }
    .layout-topbar-meta { opacity:.75; }
    .floating-search {
      position:fixed;
      right:12px;
      bottom:12px;
      width:320px;
      z-index:30;
    }
    .floating-search .card { margin:0; }
    #btn-delete { color:#b91c1c; border-color:rgba(185,28,28,.35); }
    #row-filter { min-width:64px; }
    .toolbar button[data-tool="label"],
    #quick-add-wall,
    #quick-add-shelf,
    #toggle-connect,
    #preview-toggle,
    #toggle-move-mode,
    #zoom-reset {
      display: none !important;
    }
    .layout-action-btn {
      width:34px;
      min-width:34px;
      height:34px;
      padding:0;
      text-align:center;
      display:inline-flex;
      align-items:center;
      justify-content:center;
      line-height:1;
    }
    .layout-action-btn--danger { background:var(--nova-btn-danger-bg); color:#fff; border-color:var(--nova-btn-danger-border); }
    .layout-action-btn--danger:hover { background:var(--nova-btn-danger-bg-2); }
    .draw-hud {
      position:fixed;
      pointer-events:none;
      z-index:25;
      display:none;
      padding:6px 10px;
      border-radius:10px;
      background:var(--nova-card-bg);
      border:1px solid var(--nova-card-border);
      font-size:12px;
      color:var(--nova-table-text);
      box-shadow:var(--nova-card-shadow);
      backdrop-filter: blur(10px) saturate(130%);
      -webkit-backdrop-filter: blur(10px) saturate(130%);
    }

/* ============================================================
   Inventory Warehouses Page (merged from inventory_warehouses_page.css)
   ============================================================*/
.list { display: grid; gap: 16px; }
.list .card { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 18px 20px; }
.list .card .card-main { min-width: 0; }
.list .card .meta { margin-top: 6px; opacity: .8; font-size: .95em; }
.list .card .actions { display: flex; gap: 10px; flex-wrap: wrap; margin-left: auto; }
.pairing-inline { font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; letter-spacing: 2px; }
.pairing-wrap { display:inline-flex; align-items:center; gap:8px; margin-left:8px; }
.btn[style*="display:none"]{ visibility:hidden; }
.warehouse-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:15px; }
@media (max-width: 640px){
  .list .card { flex-direction: column; }
  .list .card .actions { width: 100%; justify-content: flex-start; }
}

/* ============================================================
   Move Module - Export / Import page
   ============================================================*/
.ei-shell { padding-bottom: 40px; }
.ei-header { margin: 0 0 16px; }
.ei-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.ei-card h2 { margin-top: 0; }
.ei-form { display: grid; gap: 12px; }
.ei-note {
  margin-bottom: 14px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid rgba(245, 158, 11, 0.35);
  background: rgba(254, 249, 195, 0.45);
  color: #78350f;
}
.ei-note .sub { font-size: 0.9rem; opacity: 0.85; margin-top: 4px; }
.ei-inline-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.ei-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.ei-mapping-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
#importModal{position:fixed;inset:0;width:100vw;height:100vh;padding:16px;background:rgba(0,0,0,.45);display:none;align-items:center;justify-content:center;z-index:9999;overflow:auto;}
#importModal[aria-hidden="true"]{display:none;}
#importModal .modal-dialog{position:relative;width:min(1200px, calc(100vw - 32px));max-height:calc(100vh - 32px);margin:auto;background:#fff;border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.35);display:flex;flex-direction:column;overflow:hidden;}
#importModal .modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #eee;}
#importModal .modal-body{padding:16px;overflow:auto;min-width:0;}
#importModal .modal-body > div{min-width:0;}
#importModal .modal-footer{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #eee;justify-content:flex-end;}
#importModal .modal-body img{display:block;max-width:100%;height:auto;margin:0 auto;object-fit:contain;}
#importModal .overflow-auto{overflow:auto;max-width:100%;}
#importModal table{max-width:100%;}
@media (max-width: 960px) {
  .ei-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .ei-inline-grid { grid-template-columns: 1fr; }
  .ei-mapping-grid { grid-template-columns: 1fr; }
  #importModal{padding:8px;}
  #importModal .modal-dialog{width:calc(100vw - 16px);max-height:calc(100vh - 16px);border-radius:12px;}
  #importModal .modal-header,#importModal .modal-body,#importModal .modal-footer{padding:10px;}
}
#importModal [data-close]{cursor:pointer;}

/* ============================================================
   Move Module - Notifications page
   ============================================================*/
body.notifications-page { color: #0f172a; }
.notifications-page-main {
  max-width: 1100px;
  margin: 24px auto 48px;
  padding: 18px;
}
.notifications-panel { margin-bottom: 16px; }
.notifications-list { display: flex; flex-direction: column; gap: 12px; }
.notifications-heading-row { display: flex; align-items: center; gap: 10px; }
.notifications-title { margin: 0; font-size: 20px; }
.notifications-hint { margin-top: 8px; }

.notifications-page .notif-card {
  background: #ffffff;
  border: 1px solid rgba(15,23,42,.18);
  border-radius: 14px;
  padding: 14px 16px;
  display: flex;
  gap: 12px;
  align-items: flex-start;
  box-shadow: 0 12px 28px rgba(15,23,42,.16);
  color: #0f172a;
}
.notifications-page .notif-card.unread { border-color: #2563eb; box-shadow: 0 18px 48px rgba(37,99,235,.18); }
.notifications-page .notif-card.read { border-color: rgba(15,23,42,.2); background: #f8fafc; }
.notifications-page .notif-card .chk { margin-top: 3px; }
.notifications-page .notif-card .meta { font-size: 12px; color: #334155; margin-top: 4px; }

.notifications-page .empty {
  padding: 28px;
  text-align: center;
  color: #334155;
  background: #ffffff;
  border: 1px dashed rgba(15,23,42,.22);
  border-radius: 14px;
}

.notifications-page .badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 999px;
  border: 1px solid rgba(15,23,42,.2);
  font-size: 11px;
  background: #eff6ff;
  margin-left: 6px;
  color: #0f172a;
}

.notifications-page .pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 999px;
  background: #ffffff;
  color: #0f172a;
  font-weight: 700;
  font-size: 13px;
  box-shadow: 0 10px 24px rgba(0,0,0,.12);
  border: 1px solid rgba(15,23,42,.16);
}

.notifications-page .toolbar .btn { border-radius: 10px; }

html[data-theme='dark'] .notifications-page .notif-card {
  background: rgba(15,23,42,.9);
  border: 1px solid rgba(148,163,184,.25);
  color: #e2e8f0;
  box-shadow: 0 20px 60px rgba(0,0,0,.32);
}
html[data-theme='dark'] .notifications-page .notif-card.unread { border-color: #38bdf8; box-shadow: 0 18px 48px rgba(56,189,248,.25); }
html[data-theme='dark'] .notifications-page .notif-card .meta { color: #cbd5e1; }
html[data-theme='dark'] .notifications-page .empty { color: #cbd5e1; background: rgba(15,23,42,.9); border-color: rgba(148,163,184,.35); }
html[data-theme='dark'] .notifications-page .muted { color: #94a3b8; }
html[data-theme='dark'] .notifications-page .badge { border-color: rgba(148,163,184,.35); background: rgba(148,163,184,.12); color: #e2e8f0; }
html[data-theme='dark'] .notifications-page .pill { background: rgba(15,23,42,.85); color: #e2e8f0; border: 1px solid rgba(148,163,184,.35); }
html[data-theme='dark'] .glass-panel.notifications-panel {
  background: rgba(15,23,42,.9);
  border: 1px solid rgba(148,163,184,.25);
  box-shadow: 0 18px 48px rgba(0,0,0,.28);
  color: #e2e8f0;
}
html[data-theme='dark'] .notifications-page-main {
  background: rgba(15,23,42,.78);
  border-color: rgba(148,163,184,.28);
}

@media (max-width: 640px) {
  .notifications-page-main { margin: 18px auto 40px; padding: 14px; }
  .toolbar { flex-wrap: wrap; }
}

/* ============================================================
   Move Module - Roles page
   ============================================================*/
.roles-page .page-hdr{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.roles-page .perm-grid{display:grid;grid-template-columns:200px repeat(var(--roles-columns,2),1fr);gap:6px;align-items:center}
.roles-page .perm-grid .head{font-weight:700;opacity:.8}
.roles-page .switch{--w:36px;--h:22px;position:relative;width:var(--w);height:var(--h);display:inline-block}
.roles-page .switch input{display:none}
.roles-page .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#e5e7eb;border-radius:999px;transition:.2s}
.roles-page .slider:before{content:"";position:absolute;height:18px;width:18px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.roles-page .switch input:checked + .slider{background:#16a34a}
.roles-page .switch input:checked + .slider:before{transform:translateX(14px)}
.roles-page .muted{opacity:.7}
.roles-page .role-col{text-align:center}
.roles-page .role-name{font-weight:600}
.roles-page .tbl-wrap{overflow:auto;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:12px;background:rgba(255,255,255,.6);backdrop-filter:saturate(140%) blur(6px)}

/* ============================================================
   Move Module - Equipment repairs page
   ============================================================*/
.equipment-repairs-page {
  --bg: var(--nova-bg-1, linear-gradient(135deg, #f8e4ec 0%, #f5b9d4 55%, #dca4ce 100%));
  --panel: var(--nova-card-bg, rgba(255,255,255,0.76));
  --line: var(--nova-card-border, rgba(255,255,255,0.55));
  --ink: var(--nova-text, #1f2a37);
  --muted: var(--nova-muted, #6b7280);
  --accent: var(--nova-btn-bg, #f97316);
  --ok: var(--nova-ok, #16a34a);
  --err: var(--nova-danger, #ef4444);
}
.equipment-repairs-page * { box-sizing: border-box; }
.equipment-repairs-page .wrap { max-width: 1260px; margin: 0 auto; padding: 88px 16px 20px; }
.equipment-repairs-page .row { display: grid; grid-template-columns: 1fr; gap: 14px; align-items: start; }
@media (min-width: 1000px) {
  .equipment-repairs-page .row { grid-template-columns: 1fr 1fr; }
}
.equipment-repairs-page .card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  box-shadow: var(--nova-card-shadow, 0 16px 34px rgba(15,23,42,.14));
  backdrop-filter: blur(14px) saturate(130%);
  -webkit-backdrop-filter: blur(14px) saturate(130%);
}
.equipment-repairs-page .row > .card { align-self: start; }
.equipment-repairs-page .repairs-card { margin-top: 0; }
.equipment-repairs-page h1,
.equipment-repairs-page h2,
.equipment-repairs-page h3 { margin: 0 0 10px; }
.equipment-repairs-page form { display: grid; gap: 8px; }
.equipment-repairs-page input,
.equipment-repairs-page select,
.equipment-repairs-page textarea,
.equipment-repairs-page button {
  width: 100%;
  font: inherit;
  padding: 10px;
  border-radius: 9px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.94);
  color: var(--ink);
}
.equipment-repairs-page textarea { min-height: 90px; resize: vertical; }
.equipment-repairs-page button {
  cursor: pointer;
  background: var(--accent);
  color: #fff;
  border: 1px solid transparent;
  font-weight: 600;
}
.equipment-repairs-page button:hover { filter: brightness(1.05); }
.equipment-repairs-page button:disabled { background: #9ca3af; cursor: not-allowed; opacity: 0.9; }
.equipment-repairs-page table { width: 100%; border-collapse: collapse; }
.equipment-repairs-page th,
.equipment-repairs-page td { text-align: left; padding: 8px; border-bottom: 1px solid var(--line); font-size: 0.93rem; }
.equipment-repairs-page th { background: rgba(255,255,255,.62); font-weight: 700; }
.equipment-repairs-page .muted { color: var(--muted); }
.equipment-repairs-page .msg { padding: 8px 10px; border-radius: 9px; margin-bottom: 10px; }
.equipment-repairs-page .msg.ok { background: #dcfce7; color: var(--ok); }
.equipment-repairs-page .msg.err { background: #fee2e2; color: var(--err); }
.equipment-repairs-page .link-btn {
  display: inline-block;
  margin-right: 8px;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--ink);
  text-decoration: none;
  background: rgba(255,255,255,0.92);
  font-size: 0.85rem;
}
.equipment-repairs-page .link-btn.is-disabled { opacity: 0.55; pointer-events: none; }
.equipment-repairs-page .bulk-print-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.equipment-repairs-page .bulk-print-count { color: var(--muted); font-size: 0.9rem; }
.equipment-repairs-page .chk-col { width: 38px; text-align: center; }
.equipment-repairs-page .chk-col input[type='checkbox'] { width: 16px; height: 16px; cursor: pointer; }
.equipment-repairs-page .head-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.equipment-repairs-page .ghost-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: auto;
  padding: 8px 12px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,0.92);
  color: var(--ink);
  border-radius: 10px;
  cursor: pointer;
  font-weight: 600;
}
.equipment-repairs-page .modal {
  position: fixed;
  inset: 0;
  background: rgba(39, 36, 27, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
  z-index: 1000;
}
.equipment-repairs-page .modal.open { display: flex; }
.equipment-repairs-page .modal-card {
  width: min(760px, 100%);
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  box-shadow: 0 16px 30px rgba(39, 36, 27, 0.2);
}
.equipment-repairs-page .modal-actions { display: flex; gap: 8px; justify-content: flex-end; margin-top: 10px; }
.equipment-repairs-page .switch-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255,255,255,0.92);
}
.equipment-repairs-page .switch { --w: 44px; --h: 26px; position: relative; width: var(--w); height: var(--h); display: inline-block; flex: 0 0 auto; }
.equipment-repairs-page .switch input { display: none; }
.equipment-repairs-page .switch .slider { position: absolute; inset: 0; border-radius: 999px; background: #d1d5db; transition: background .2s ease; }
.equipment-repairs-page .switch .slider:before {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: #fff;
  transition: transform .2s ease;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
.equipment-repairs-page .switch input:checked + .slider { background: #16a34a; }
.equipment-repairs-page .switch input:checked + .slider:before { transform: translateX(18px); }
.equipment-repairs-page .history-item {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: rgba(255,255,255,0.92);
  padding: 10px;
}
.equipment-repairs-page .history-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 0.92rem;
}
.equipment-repairs-page .history-action { font-weight: 700; }
.equipment-repairs-page .history-details {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.9rem;
  display: grid;
  gap: 4px;
}
.equipment-repairs-page .asset-search { margin-bottom: 10px; }
.equipment-repairs-page .danger-btn {
  background: #b91c1c;
  color: #fff;
  border: 0;
  border-radius: 8px;
  padding: 6px 10px;
  width: auto;
  cursor: pointer;
  font-size: 0.85rem;
}
.equipment-repairs-page .icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  margin-right: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,255,255,0.92);
  color: var(--ink);
  cursor: pointer;
  text-decoration: none;
}
.equipment-repairs-page .modal-history-content {
  max-height: 62vh;
  overflow: auto;
  display: grid;
  gap: 8px;
  padding-right: 4px;
}

/* ============================================================
   Move Module - Documentation Warehouse page
   ============================================================*/
.doc-modal-actions-wrap {
  border: 1px solid var(--nova-border-soft-ink);
  border-radius: var(--nova-radius-lg);
  padding: var(--nova-space-2);
  background: rgba(255, 255, 255, 0.28);
}

.doc-modal-actions-row {
  display: flex;
  gap: var(--nova-space-2);
  align-items: center;
  flex-wrap: wrap;
}

.doc-modal-actions-title {
  font-size: var(--nova-font-size-sm);
  font-weight: 700;
  color: var(--nova-color-text-soft);
  margin-bottom: var(--nova-space-2);
}

.nova-modal .btn,
.nova-modal .btn.btn--ghost,
.nova-modal .btn.btn--danger {
  color: var(--nova-color-ink) !important;
}

html[data-theme='dark'] .nova-modal .btn,
html[data-theme='dark'] .nova-modal .btn.btn--ghost,
html[data-theme='dark'] .nova-modal .btn.btn--danger {
  color: var(--nova-btn-text) !important;
}

.orphan-qty-wrap { display: inline-flex; align-items: center; gap: 2px; white-space: nowrap; }
.orphan-qty-value { font-weight: 700; color: #0f172a; font-size: 10px; }
.orphan-btn {
  border: none;
  border-radius: 5px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  font-weight: 800;
  cursor: pointer;
  padding: 0;
  font-size: 10px;
}
.orphan-btn-minus { background: #fee2e2; color: #b91c1c; }
.orphan-btn-minus-zero { background: #dc2626; color: #fff; border: 1px solid #991b1b; }
.orphan-btn-plus { background: #dcfce7; color: #166534; }
.orphan-btn-open {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background: #e0f2fe;
  color: #0c4a6e;
}
.orphan-btn-delete { background: #f1f5f9; color: #334155; }
.orphan-assign-btn { background: #dbeafe; color: #1d4ed8; border: 1px solid #93c5fd; }

.pdf-overlay-root { position: relative; }
.pdf-reader-mode-bar { display: flex; align-items: center; justify-content: flex-end; gap: 8px; margin: 0 0 10px 0; }
.pdf-reader-mode-bar .btn { width: auto; }
.pdf-reader-hint { font-size: 12px; color: #475569; }
.pdf-render-status {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 8px;
  padding: 6px 10px;
  border-radius: 8px;
  border: 1px solid rgba(2, 132, 199, 0.25);
  background: rgba(186, 230, 253, 0.35);
  color: #0c4a6e;
  font-size: 12px;
  font-weight: 700;
}
.pdfjs-viewer {
  max-height: 84vh;
  min-height: 68vh;
  overflow: auto;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 10px;
  background: #f1f5f9;
  padding: 10px;
}
.pdf-page-wrap { position: relative; width: fit-content; margin: 0 auto 12px auto; }
.pdf-page-canvas { display: block; border-radius: 8px; box-shadow: 0 4px 12px rgba(0,0,0,.15); background: #fff; }
.pdf-page-overlay { position: absolute; inset: 0; }
.pdfjs-viewer[data-place-mode="1"] .pdf-page-overlay { cursor: crosshair; background: rgba(15,23,42,.05); }
.pdf-overlay-marker {
  position: absolute;
  right: 8px;
  left: auto !important;
  transform: translate(0, 0);
  background: rgba(255,255,255,0.96);
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 8px;
  padding: 2px 3px;
  width: auto;
  min-width: 180px;
  max-width: min(320px, calc(100% - 16px));
  box-shadow: 0 6px 16px rgba(0,0,0,.15);
  pointer-events: auto;
}
.pdf-overlay-marker.compact { min-width: 130px; max-width: 190px; padding: 2px; }
.pdf-overlay-marker.ultra-compact { min-width: 114px; max-width: 168px; padding: 1px 2px; }
.pdf-overlay-row { display: flex; align-items: center; gap: 3px; min-width: 0; }
.pdf-overlay-marker.is-selected { outline: 2px solid #0ea5e9; box-shadow: 0 0 0 3px rgba(14,165,233,.2), 0 6px 16px rgba(0,0,0,.15); }
.pdf-overlay-marker.is-focus-item { outline: 2px solid #22c55e; box-shadow: 0 0 0 3px rgba(34,197,94,.2), 0 6px 16px rgba(0,0,0,.15); }
.pdfjs-viewer[data-move-mode="1"] .pdf-page-overlay,
.pdfjs-viewer[data-move-mode="1"] .pdf-overlay-marker { cursor: ns-resize; }
.pdf-overlay-title {
  font-size: 10px;
  font-weight: 700;
  color: #0f172a;
  line-height: 1.2;
  white-space: normal;
  overflow-wrap: anywhere;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
}
.pdf-overlay-meta {
  font-size: 8px;
  color: #475569;
  line-height: 1.1;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pdf-overlay-marker.compact .pdf-overlay-title { font-size: 9px; }
.pdf-overlay-marker.ultra-compact .pdf-overlay-title { font-size: 8px; }
.pdf-overlay-open-link { min-width: 16px; text-align: center; font-size: 10px; font-weight: 700; }
.pdf-overlay-stock-btn { min-width: 18px; width: 18px; height: 18px; line-height: 18px; }
.pdf-overlay-stock-btn[disabled] { cursor: not-allowed; opacity: 1; }
.pdf-move-stock-form {
  display: grid;
  grid-template-columns: minmax(130px, 170px) minmax(90px, 120px) minmax(220px, 1fr) auto;
  gap: 8px;
  align-items: center;
}
.pdf-move-stock-form input,
.pdf-move-stock-form select { width: 100%; min-height: 32px; padding: 6px 8px; }
.field-error-msg { color: #b91c1c; font-size: var(--nova-font-size-sm); font-weight: 600; margin-top: -2px; }
input.is-invalid,
textarea.is-invalid,
select.is-invalid { border: 1px solid #dc2626 !important; box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.18); }
.pdf-overlay-marker.compact .orphan-btn,
.pdf-overlay-marker.compact .pdf-overlay-open-link { width: 14px; height: 14px; line-height: 14px; min-width: 14px; font-size: 9px; }
.pdf-overlay-marker.ultra-compact .orphan-btn,
.pdf-overlay-marker.ultra-compact .pdf-overlay-open-link { width: 12px; height: 12px; line-height: 12px; min-width: 12px; font-size: 8px; }

.container.full-preview-mode > section.card.glass-card:first-of-type { display: none !important; }
.container.full-preview-mode > .nova-modal-backdrop { display: none !important; }

/* =====================================================
   Personal Dashboard – teljes shell-szélesség viewer
   ===================================================== */
.personal-dashboard-page .shell {
  max-width: var(--nova-shell-max);
  padding-left: 0;
  padding-right: 0;
  padding-bottom: 0;
}
.personal-dashboard-page .personal-module-top-card {
  margin-left: 0;
  margin-right: 0;
  border-radius: 0;
  border-left: none;
  border-right: none;
  border-bottom: none;
  box-shadow: none;
  padding: var(--nova-shell-pad-x);
  padding-bottom: 18px;
}
.personal-dashboard-page .personal-module-viewer {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid var(--nova-card-border);
  border-radius: 0 0 18px 18px;
  background: var(--nova-card-bg);
  backdrop-filter: blur(22px) saturate(140%);
  -webkit-backdrop-filter: blur(22px) saturate(140%);
  box-shadow: var(--nova-card-shadow);
  overflow: hidden;
}
@media (max-width: 900px) {
  .personal-dashboard-page .personal-module-top-card {
    padding: 18px 18px 14px;
  }
}
@media (max-width: 600px) {
  .personal-dashboard-page .personal-module-top-card {
    padding: 14px 14px 12px;
  }
  .personal-dashboard-page .personal-module-viewer {
    border-radius: 0 0 12px 12px;
  }
}
.container.full-preview-mode > .content-grid { grid-template-columns: minmax(0, 1fr) !important; }
.container.full-preview-mode > .content-grid > :not(.preview-panel) { display: none !important; }
.container.full-preview-mode > .content-grid > .preview-panel { grid-column: 1 / -1; }
.container.docs-readonly > .content-grid { grid-template-columns: minmax(0, 1fr) !important; }
.container.full-preview-mode > .content-grid > .preview-panel > :not(#previewSection) { display: none !important; }
.container.full-preview-mode > .content-grid > .preview-panel { padding: 0 !important; border: 0 !important; background: transparent !important; box-shadow: none !important; }
.container.full-preview-mode #previewSection {
  margin-top: 0 !important;
  border-top: 0 !important;
  padding-top: 0 !important;
  height: calc(100vh - 72px);
  display: flex;
  flex-direction: column;
}
.container.full-preview-mode #previewSection > :not(#pdfTopLayerPanel):not(#pdfOverlayRoot) { display: none !important; }
.container.full-preview-mode #pdfTopLayerPanel {
  display: block !important;
  position: sticky;
  top: 0;
  z-index: 60;
  margin: 0 !important;
  border-top: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-radius: 0 !important;
  box-shadow: 0 6px 16px rgba(0,0,0,.08);
}
.container.full-preview-mode #pdfTopLayerPanel > :not(.pdf-overlay-controls-row):not(#overlayAddForm):not(#overlayMoveForm) { display: none !important; }
.container.full-preview-mode #pdfTopLayerPanel { padding: 8px 10px !important; }
.container.full-preview-mode #pdfTopLayerPanel .pdf-overlay-controls-row { margin: 0 !important; }
.container.full-preview-mode #pdfRenderStatus,
.container.full-preview-mode .footer,
.container.full-preview-mode .nova-chat-fab,
.container.full-preview-mode .nova-chat-panel,
.container.full-preview-mode .nova-chat-backdrop { display: none !important; }
.container.full-preview-mode ~ .footer,
.container.full-preview-mode ~ .nova-chat-fab,
.container.full-preview-mode ~ .nova-chat-panel,
.container.full-preview-mode ~ .nova-chat-backdrop { display: none !important; }
.container.full-preview-mode { max-width: none !important; width: 100% !important; padding: 0 !important; }
.container.full-preview-mode #pdfOverlayRoot { margin: 0 !important; flex: 1 1 auto; min-height: 0; }
.container.full-preview-mode .pdfjs-viewer {
  max-height: none !important;
  height: 100% !important;
  min-height: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 16px !important;
  background: #e5e7eb !important;
}

@media (max-width: 860px) {
  .doc-modal-actions-wrap { padding: var(--nova-space-1); }
  .nova-modal { width: 96vw; }
  .pdf-overlay-marker { right: 4px; min-width: 170px; max-width: min(240px, calc(100% - 8px)); }
  .pdfjs-viewer { max-height: 64vh; padding: 6px; }
  .pdf-move-stock-form { grid-template-columns: 1fr 1fr; }
}


