/* ============================================================
   Enterprise Portal — Design System
   ============================================================ */

/* ── Design Tokens ────────────────────────────────────────── */
:root {
  --fmfp-ink: #0e1a2a;
  --fmfp-ink-2: #3b485a;
  --fmfp-ink-3: #6b7585;
  --fmfp-ink-4: #9aa3b0;
  --fmfp-paper: #ffffff;
  --fmfp-paper-2: #f4f6f8;
  --fmfp-paper-3: #eaeef2;
  --fmfp-blue: rgb(25, 66, 139);
  --fmfp-blue-dark: #0d4a7a;
  --fmfp-blue-soft: #e8f0f8;
  --fmfp-blue-ink: rgb(25, 66, 139);
  --fmfp-rule: #dfe3e8;
  --fmfp-rule-2: #c9d1da;
  --fmfp-ok: #2e7a4a;
  --fmfp-ok-soft: #e4f1ea;
  --fmfp-warn: #c97a3a;
  --fmfp-warn-soft: #fbeede;
  --fmfp-danger: #990303;
  --fmfp-danger-soft: #f8e4df;
  --fmfp-dark: #1C1C1C;
  --fmfp-teal: #1abc9c;
  --fmfp-muted: #8a94a6;
  --fmfp-text: #1a2233;

  --r-xs: 4px;
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 12px;
  --r-xl: 16px;
  --r-pill: 999px;

  --sidebar-w: 248px;
  --sidebar-w-collapsed: 64px;
  --topbar-h: 56px;
  --pad: 28px;

  --shadow-card: 0 1px 2px rgba(8, 38, 66, .04);
  --shadow-pop: 0 12px 36px -10px rgba(8, 38, 66, .2);
  --shadow-modal: 0 30px 70px -20px rgba(8, 38, 66, .45);
  --shadow-toast: 0 16px 40px -16px rgba(8, 38, 66, .28), 0 2px 8px -2px rgba(8, 38, 66, .08);

  /*
   * ── Breakpoints ─────────────────────────────────────────────
   * Note: CSS var() cannot be used inside @media conditions.
   * Use these values as the reference when writing media queries.
   * They are also readable from JS via getComputedStyle(root).
   *
   *  --bp-xs   480px   small mobile          @media (max-width: 480px)
   *  --bp-sm   640px   mobile/small tablet   @media (max-width: 640px)
   *  --bp-md   768px   mobile boundary       @media (max-width: 768px)
   *  --bp-lg   900px   tablet / topbar       @media (max-width: 900px)
   *  --bp-xl  1024px   sidebar auto-collapse @media (max-width: 1024px)
   * ────────────────────────────────────────────────────────────
   */
  --bp-xs:  480px;
  --bp-sm:  640px;
  --bp-md:  768px;
  --bp-lg:  900px;
  --bp-xl: 1024px;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* ── App Shell (CSS Grid) ─────────────────────────────────── */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-rows: var(--topbar-h) 1fr;
  grid-template-areas:
    "sb top"
    "sb main";
  height: 100vh;
  max-height: 100vh;
  background: var(--fmfp-paper-2);
  transition: grid-template-columns .22s ease;
}

@media (min-width: 769px) {
  body.sb-collapsed .app {
    grid-template-columns: var(--sidebar-w-collapsed) 1fr;
  }
}

/* ── Sidebar ─────────────────────────────────────────────── */
.sb {
  grid-area: sb;
  background: var(--fmfp-blue-ink);
  color: #fff;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  z-index: 200;
}

.sb::-webkit-scrollbar {
  width: 3px;
}

.sb::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, .15);
  border-radius: 2px;
}

/* Org block */
.sb-org {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
  display: flex;
  align-items: center;
  gap: 12px;
  height: var(--topbar-h);
  flex: 0 0 auto;
  cursor: pointer;
  transition: background .15s;
}

.sb-org:hover {
  background: rgba(255, 255, 255, .04);
}

.sb-org .avatar {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
  background: var(--fmfp-blue);
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12px;
  color: #fff;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.sb-org .who {
  min-width: 0;
  line-height: 1.25;
  flex: 1;
}

.sb-org .who .name {
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -.005em;
}

.sb-org .who .role {
  font-family: Inter, sans-serif;
  font-size: 10px;
  color: rgba(255, 255, 255, .5);
  letter-spacing: .1em;
  text-transform: uppercase;
  margin-top: 2px;
}

.sb-org .chev {
  color: rgba(255, 255, 255, .38);
  font-size: 11px;
  flex: 0 0 auto;
}

/* Nav */
.sb-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 12px 0 24px;
}

.sb-nav::-webkit-scrollbar {
  width: 3px;
}

.sb-nav::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, .1);
}

.sb-group {
  padding: 0 10px;
  margin-top: 16px;
}

.sb-group:first-child {
  margin-top: 6px;
}

.sb-group .hd {
  font-family: Inter, sans-serif;
  font-size: 10px;
  letter-spacing: .16em;
  color: rgba(255, 255, 255, .35);
  text-transform: uppercase;
  padding: 4px 8px;
  margin-bottom: 2px;
}

/* ── Collapsible groups ──────────────────────────────────── */
.sb-collapsible-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  border-radius: var(--r-xs);
  transition: color .15s;
}
.sb-collapsible-hd:hover { color: rgba(255,255,255,.6); }
.sb-collapsible-hd::after {
  content: "";
  width: 5px; height: 5px;
  border-right: 1.5px solid rgba(255,255,255,.3);
  border-bottom: 1.5px solid rgba(255,255,255,.3);
  transform: rotate(45deg);
  transition: transform .18s ease, border-color .15s;
  flex-shrink: 0;
  margin-right: 2px;
}
.sb-collapsible-hd:hover::after { border-color: rgba(255,255,255,.6); }
.sb-group.is-collapsed .sb-collapsible-hd::after {
  transform: rotate(-45deg);
  margin-top: 2px;
}

.sb-group-body {
  overflow: hidden;
  max-height: 400px;
  transition: max-height .22s ease;
}
.sb-group.is-collapsed .sb-group-body { max-height: 0; }

/* in icon-only sidebar, always show all items regardless of collapse state */
body.sb-collapsed .sb-group-body { overflow: visible; max-height: none !important; }

.sb-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  color: rgba(255, 255, 255, .68);
  font-size: 13px;
  border-radius: var(--r-sm);
  border: 1px solid transparent;
  transition: background .15s, color .15s, border-color .15s;
  cursor: pointer;
  position: relative;
  text-decoration: none !important;
  line-height: 1.35;
}

.sb-item:hover {
  background: rgba(255, 255, 255, .06);
  color: #fff;
}

.sb-item.is-active {
  background: rgb(11, 141, 202);
  color: #fff;
  border-color: rgba(255, 255, 255, .1);
}

.sb-item.is-active::before {
  content: "";
  position: absolute;
  left: -10px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: var(--fmfp-blue);
  border-radius: var(--r-pill);
}

.sb-item .ico {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .6);
}

.sb-item.is-active .ico,
.sb-item:hover .ico {
  color: #fff;
}

.sb-item .lbl {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sb-item .badge {
  font-family: Inter, sans-serif;
  font-size: 10px;
  padding: 2px 6px;
  border-radius: var(--r-pill);
  background: rgba(255, 255, 255, .12);
  color: #fff;
  letter-spacing: .06em;
  flex: 0 0 auto;
}

.sb-item .badge.warn {
  background: var(--fmfp-warn);
}

.sb-item .badge.blue {
  background: var(--fmfp-blue);
}

/* Footer */
.sb-foot {
  padding: 8px 12px;
  border-top: 1px solid rgba(255, 255, 255, .08);
  flex: 0 0 auto;
}

.sb-foot-pref {
  width: 100%;
}

/* ── Topbar ──────────────────────────────────────────────── */
.top {
  grid-area: top;
  background: var(--fmfp-paper);
  border-bottom: 1px solid var(--fmfp-rule);
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 0 24px;
  height: var(--topbar-h);
  position: sticky;
  top: 0;
  z-index: 250;
}

.top-toggle {
  width: 32px;
  height: 32px;
  border: 1px solid var(--fmfp-rule);
  background: var(--fmfp-paper);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fmfp-ink-2);
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: background .15s, border-color .15s;
}

.top-toggle:hover {
  background: var(--fmfp-paper-2);
  border-color: var(--fmfp-rule-2);
}

.top-toggle::after {
  content: attr(data-tooltip);
  position: absolute;
  top: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--fmfp-ink);
  color: #fff;
  font-size: 11px;
  padding: 4px 9px;
  border-radius: var(--r-xs);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  z-index: 200;
  font-family: Inter, sans-serif;
  letter-spacing: .04em;
}

.top-toggle:hover::after {
  opacity: 1;
}

/* Icon state: collapse visible by default, expand when collapsed */
.top-toggle .ico-expand {
  display: none;
}

.top-toggle .ico-collapse {
  display: block;
}

body.sb-collapsed .top-toggle .ico-expand {
  display: block;
}

body.sb-collapsed .top-toggle .ico-collapse {
  display: none;
}

.crumbs {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--fmfp-ink-3);
  min-width: 0;
  flex: 1;
}

.crumbs span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.crumbs .sep {
  color: var(--fmfp-ink-4);
  font-family: Inter, sans-serif;
  font-size: 11px;
  flex-shrink: 0;
}

.crumbs .cur {
  color: var(--fmfp-ink);
  font-weight: 500;
}

.top-right {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.top-date {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 12px;
  border: 1px solid var(--fmfp-rule);
  background: var(--fmfp-paper);
  border-radius: var(--r-sm);
  font-family: Inter, sans-serif;
  font-size: 11px;
  color: var(--fmfp-ink-2);
  letter-spacing: .08em;
  white-space: nowrap;
  box-sizing: border-box;
}

.top-icon-btn {
  width: 32px;
  height: 32px;
  border: 1px solid var(--fmfp-rule);
  background: var(--fmfp-paper);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fmfp-ink-2);
  cursor: pointer;
  position: relative;
  text-decoration: none !important;
  transition: background .15s, color .15s;
  flex-shrink: 0;
}

.top-icon-btn:hover {
  background: var(--fmfp-paper-2);
  color: var(--fmfp-ink);
}

.top-icon-btn.is-active {
  background: var(--fmfp-blue-soft);
  color: var(--fmfp-blue);
  border-color: var(--fmfp-blue-soft);
}

/* Search button in topbar */
.top-search-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 6px 0 10px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: var(--fmfp-ink-3);
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
  min-width: 200px;
  border-radius: 8px;
  transition: border-color .15s, background .15s;
  flex-shrink: 0;
}

.top-search-btn:hover {
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.12);
}

.top-search-btn .lbl {
  flex: 1;
  text-align: left;
}

.top-search-btn .kbd {
  font-family: Inter, sans-serif;
  font-size: 9px;
  letter-spacing: .06em;
  padding: 1px 5px;
  color: var(--fmfp-ink-3);
  white-space: nowrap;
}

@media (min-width: 901px) {
  body.sb-collapsed .top-search-btn {
    min-width: 150px;
  }
}

.top-user {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 8px 0 5px;
  border: 1px solid var(--fmfp-rule);
  background: var(--fmfp-paper);
  border-radius: var(--r-sm);
  cursor: pointer;
  margin-left: 4px;
  transition: background .15s;
  position: relative;
  flex-shrink: 0;
  box-sizing: border-box;
}

.top-user:hover {
  background: var(--fmfp-paper-2);
}

.top-user .avatar {
  width: 24px;
  height: 24px;
  background: var(--fmfp-blue);
  color: #fff;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  flex: 0 0 auto;
  overflow: hidden;
}

.top-user .avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.top-user .nm {
  font-size: 12px;
  font-weight: 500;
  color: var(--fmfp-ink);
  max-width: 160px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.top-user .chev {
  font-family: Inter, sans-serif;
  font-size: 10px;
  color: var(--fmfp-ink-3);
}

/* User dropdown menu */
.top-user-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  background: var(--fmfp-paper);
  border: 1px solid var(--fmfp-rule);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-pop);
  min-width: 220px;
  max-width: 225px;
  overflow: hidden;
  z-index: 300;
}

.top-user-menu.open {
  display: block;
}

.top-user-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  font-size: 13px;
  color: var(--fmfp-ink-2);
  text-decoration: none !important;
  transition: background .1s;
}

.top-user-menu a:hover {
  background: var(--fmfp-paper-2);
  color: var(--fmfp-ink);
}

.top-user-menu a svg {
  flex-shrink: 0;
  color: var(--fmfp-ink-3);
}

.top-user-menu-sep {
  height: 1px;
  background: var(--fmfp-rule);
  margin: 3px 0;
}

.top-user-menu-org {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px 10px;
}

.top-user-menu-org-avatar {
  width: 36px;
  height: 36px;
  background: var(--fmfp-blue);
  color: #fff;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  flex-shrink: 0;
  align-self: flex-start;
  overflow: hidden;
}

.top-user-menu-org-avatar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.top-user-menu-org-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.top-user-menu-org-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--fmfp-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.top-user-menu-org-cnaps {
  font-family: Inter, sans-serif;
  font-size: 10px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--fmfp-ink-3);
}

.top-user-menu-org-email {
  font-size: 11px;
  color: var(--fmfp-ink-4);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.top-company-logo {
  height: 32px;
  width: auto;
  max-width: 80px;
  border-radius: var(--r-xs);
  object-fit: contain;
  flex-shrink: 0;
  box-sizing: border-box;
}

.top-company-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  min-width: 30px;
  padding: 0 7px;
  border-radius: var(--r-xs);
  background: var(--fmfp-blue-soft);
  color: var(--fmfp-blue);
  font-family: Inter, sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  flex-shrink: 0;
  border: 1px solid rgba(21, 101, 168, .15);
}

/* ── Notification panel ─────────────────────────────────── */
.top-notif {
  position: relative;
}

.top-notif .top-icon-btn {
  position: relative;
}

.top-notif-badge {
  position: absolute;
  top: -5px;
  right: -6px;
  min-width: 19px;
  height: 19px;
  border-radius: 10px;
  background: var(--fmfp-danger);
  color: #fff;
  font-family: Inter, sans-serif;
  font-size: 10px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
  line-height: 1;
  pointer-events: none;
  box-shadow: 0 0 0 2px var(--fmfp-paper);
  transition: opacity .18s ease, transform .18s ease;
}

.top-notif-badge.is-hidden {
  opacity: 0;
  transform: scale(.6);
  pointer-events: none;
}

.top-notif-panel {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  right: -12px;
  width: 400px;
  max-height: 540px;
  background: var(--fmfp-paper);
  border: 1px solid var(--fmfp-rule);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
  z-index: 350;
  flex-direction: column;
  animation: topNotifIn .2s cubic-bezier(.2, .8, .2, 1);
}

.top-notif-panel.is-open {
  display: flex;
}

@keyframes topNotifIn {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(.97);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.top-notif-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--fmfp-rule);
  flex-shrink: 0;
}

.top-notif-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--fmfp-ink);
}

.top-notif-mark-all {
  font-size: 12px;
  font-weight: 500;
  color: var(--fmfp-blue);
  cursor: pointer;
  background: none;
  border: none;
  padding: 4px 8px;
  border-radius: var(--r-xs);
  transition: background .12s;
  font-family: inherit;
}

.top-notif-mark-all:hover {
  background: var(--fmfp-blue-soft);
}

.top-notif-list {
  overflow-y: auto;
  max-height: 400px;
  padding: 4px 0;
  flex: 1;
}

.top-notif-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 20px;
  cursor: pointer;
  text-decoration: none !important;
  color: inherit;
  transition: background .15s;
}
.top-notif-delete {
  position: absolute;
  top: 10px;
  right: 14px;
  width: 24px;
  height: 24px;
  border-radius: var(--r-xs);
  border: none;
  background: transparent;
  color: var(--fmfp-ink-4);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Inter, sans-serif;
  font-size: 13px;
  opacity: 0;
  transition: opacity .15s, background .12s, color .12s;
  z-index: 1;
}
.top-notif-item:hover .top-notif-delete {
  opacity: 1;
}
.top-notif-delete:hover {
  background: var(--fmfp-danger-soft);
  color: var(--fmfp-danger);
}

.top-notif-item:hover {
  background: var(--fmfp-paper-2);
}

.top-notif-item.is-unread {
  background: var(--fmfp-blue-soft);
}

.top-notif-item.is-unread:hover {
  background: #ddeaf5;
}

.top-notif-item.is-unread .top-notif-item-ico::after {
  content: "";
  position: absolute;
  top: -3px;
  right: -3px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--fmfp-blue);
  box-shadow: 0 0 0 2px var(--fmfp-blue-soft);
}

.top-notif-group-hd {
  font-family: Inter, sans-serif;
  font-size: 10px;
  letter-spacing: .1em;
  color: var(--fmfp-ink-4);
  text-transform: uppercase;
  padding: 20px 20px 6px;
}

.top-notif-group-hd:first-child {
  padding-top: 4px;
}

#entNotifDrawer .drw-bd {
  padding: 0;
  gap: 0;
}
#entNotifDrawer .drw-hd {
  justify-content: space-between;
}

.top-notif-sep {
  display: none;
}

.sub-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.4;
}
.sub-bot {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--fmfp-rule);
}

.top-notif-filter {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--fmfp-ink-3);
  font-size: 12px;
  cursor: pointer;
  user-select: none;
  font-weight: 400;
}
.top-notif-filter-toggle {
  position: relative;
  width: 30px;
  height: 17px;
  border-radius: 10px;
  background: var(--fmfp-rule-2);
  cursor: pointer;
  transition: background .2s ease;
  flex-shrink: 0;
}
.top-notif-filter-toggle::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 13px;
  height: 13px;
  border-radius: 50%;
  background: #fff;
  transition: transform .2s ease;
  box-shadow: 0 1px 2px rgba(0,0,0,.15);
}
.top-notif-filter-toggle.is-active {
  background: var(--fmfp-blue);
}
.top-notif-filter-toggle.is-active::after {
  transform: translateX(13px);
}
.top-notif-filter-lbl {
  white-space: nowrap;
}

#entNotifEmpty {
  flex: 1;
  justify-content: center;
}

.top-notif-item-ico {
  position: relative;
  width: 34px;
  height: 34px;
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.top-notif-item-ico.status {
  background: #e8f0f8;
  color: var(--fmfp-blue);
}

.top-notif-item-ico.payment {
  background: var(--fmfp-ok-soft);
  color: var(--fmfp-ok);
}

.top-notif-item-ico.warning {
  background: var(--fmfp-warn-soft);
  color: var(--fmfp-warn);
}

.top-notif-item-ico.success {
  background: var(--fmfp-ok-soft);
  color: var(--fmfp-ok);
}

.top-notif-item-ico.deadline {
  background: #fef3c7;
  color: #b45309;
}

.top-notif-item-bd {
  flex: 1;
  min-width: 0;
}

.top-notif-item-txt {
  font-size: 13px;
  color: var(--fmfp-ink);
  line-height: 1.45;
  margin: 0;
}

.top-notif-item-txt strong {
  font-weight: 600;
}

.top-notif-item-time {
  font-family: Inter, sans-serif;
  font-size: 10.5px;
  color: var(--fmfp-ink-3);
  margin-top: 5px;
  display: block;
  letter-spacing: .04em;
}

.top-notif-item-arrow {
  color: var(--fmfp-ink-4);
  flex-shrink: 0;
  margin-top: 8px;
  opacity: 0;
  transition: opacity .15s, transform .15s;
  transform: translateX(-4px);
}

.top-notif-item:hover .top-notif-item-arrow {
  opacity: 1;
  transform: translateX(0);
}

.top-notif-foot {
  display: block;
  padding: 12px 20px;
  border-top: 1px solid var(--fmfp-rule);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--fmfp-blue);
  text-decoration: none;
  text-align: center;
  transition: background .12s;
  flex-shrink: 0;
}

.top-notif-foot:hover {
  background: var(--fmfp-paper-2);
}

/* ── Notification empty state ────────────────────────────── */
.top-notif-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 48px 20px 40px;
  text-align: center;
}

.top-notif-empty-ico {
  width: 48px;
  height: 48px;
  border: 1.5px solid var(--fmfp-rule-2);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fmfp-ink-3);
  border-radius: var(--r-md);
  margin-bottom: 2px;
}

.top-notif-empty-ti {
  font-size: 14px;
  font-weight: 600;
  color: var(--fmfp-ink);
}

.top-notif-empty-desc {
  font-size: 12.5px;
  color: var(--fmfp-ink-3);
  line-height: 1.5;
  max-width: 260px;
}

@media (max-width: 480px) {
  .top-notif-panel {
    position: fixed;
    top: var(--topbar-h);
    left: 8px;
    right: 8px;
    width: auto;
    max-height: calc(100vh - var(--topbar-h) - 16px);
    border-radius: var(--r-lg);
  }
}

/* ── Main content ─────────────────────────────────────────── */
.main {
  grid-area: main;
  background: var(--fmfp-paper-2);
  min-width: 0;
  padding: 20px 24px;
  overflow-x: clip;
  overflow-y: auto;
  position: relative;
}

/* ── Collapsed state ──────────────────────────────────────── */
body.sb-collapsed .sb {
  overflow: visible;
}

/* collapsed sidebar — overflow visible for tooltips */
body.sb-collapsed .sb-nav { overflow: visible; }

body.sb-collapsed .sb-org {
  justify-content: center;
  padding: 12px 8px;
  gap: 0;
}

body.sb-collapsed .sb-org .who,
body.sb-collapsed .sb-org .chev {
  display: none;
}

body.sb-collapsed .sb-group {
  padding: 0 8px;
}

body.sb-collapsed .sb-group .hd {
  height: 1px;
  background: rgba(255, 255, 255, .08);
  padding: 0;
  margin: 10px 8px 6px;
  color: transparent;
  font-size: 0;
}

body.sb-collapsed .sb-collapsible-hd::after { display: none; }

body.sb-collapsed .sb-item {
  justify-content: center;
  padding: 9px 0;
  gap: 0;
}

body.sb-collapsed .sb-item .lbl,
body.sb-collapsed .sb-item .badge {
  display: none;
}

body.sb-collapsed .sb-item .ico {
  color: rgba(255, 255, 255, .65);
}

body.sb-collapsed .sb-item.is-active::before {
  left: -8px;
}

.sb-tooltip {
  position: fixed;
  transform: translateY(-50%);
  background: var(--fmfp-ink);
  color: #fff;
  font-size: 12px;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity .15s;
  z-index: 500;
  font-family: "Inter", -apple-system, sans-serif;
  letter-spacing: .02em;
}
.sb-tooltip.is-visible {
  opacity: 1;
}

body.sb-collapsed .sb-foot {
  padding: 8px;
}

/* ── Tablet auto-collapse (769px – 1024px) ────────────────── */
@media (min-width: 769px) and (max-width: 1024px) {
  .app {
    grid-template-columns: var(--sidebar-w-collapsed) 1fr;
  }

  .sb { overflow: visible; }
  .sb-nav { overflow: visible; }
  .sb-group-body { overflow: visible; max-height: none !important; }

  .sb-org { justify-content: center; padding: 12px 8px; gap: 0; }
  .sb-org .who,
  .sb-org .chev { display: none; }

  .sb-group { padding: 0 8px; }
  .sb-group .hd {
    height: 1px; background: rgba(255,255,255,.08); padding: 0; overflow: hidden;
  }
  .sb-collapsible-hd::after { display: none; }

  .sb-item { justify-content: center; padding: 9px 0; gap: 0; position: relative; }
  .sb-item .lbl,
  .sb-item .badge { display: none; }
  .sb-item .ico { color: rgba(255,255,255,.65); }
  .sb-item.is-active .ico { color: #fff; }

  .sb-foot { padding: 10px 8px; }
}

/* ── Mobile ───────────────────────────────────────────────── */
@media (max-width: 768px) {
  .app {
    grid-template-columns: 1fr;
    grid-template-rows: var(--topbar-h) 1fr;
    grid-template-areas: "top" "main";
  }

  .sb {
    position: fixed;
    left: 0;
    top: 0;
    height: 100vh;
    width: var(--sidebar-w) !important;
    transform: translateX(calc(-1 * var(--sidebar-w)));
    transition: transform .22s ease;
    z-index: 300;
  }

  body.sb-open .sb {
    transform: translateX(0);
  }

  body.sb-open::after {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(8, 20, 36, .45);
    z-index: 250;
  }

  .top {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    z-index: 200;
  }

  .main {
    margin-top: 0;
    padding: 16px 16px;
  }

  :root {
    --pad: 18px;
  }

  .top-user .nm,
  .top-date {
    display: none;
  }

  /* ── Cancel collapsed icon-only styles on mobile overlay ── */
  body.sb-collapsed .sb { overflow: hidden; }
  body.sb-collapsed .sb-nav { overflow: hidden; }

  body.sb-collapsed .sb-org {
    justify-content: flex-start;
    padding: 12px 16px;
    gap: 12px;
  }
  body.sb-collapsed .sb-org .who,
  body.sb-collapsed .sb-org .chev { display: block; }

  body.sb-collapsed .sb-group { padding: 0 10px; }
  body.sb-collapsed .sb-group .hd {
    height: auto;
    background: transparent;
    padding: 4px 8px;
    margin: 0;
    color: rgba(255, 255, 255, .35);
    font-size: 10px;
  }
  body.sb-collapsed .sb-collapsible-hd::after { display: block; }

  body.sb-collapsed .sb-item {
    justify-content: flex-start;
    padding: 8px 10px;
    gap: 10px;
  }
  body.sb-collapsed .sb-item .lbl,
  body.sb-collapsed .sb-item .badge { display: block; }
  body.sb-collapsed .sb-item .ico { color: rgba(255, 255, 255, .68); }

}

@media (max-width: 480px) {
  .main {
    padding: 12px 10px;
  }

  :root {
    --pad: 12px;
  }
}

/* ── Legacy theme overrides ───────────────────────────────── */
body.ent-layout {
  margin: 0;
  padding: 0;
}

body.ent-layout .navbar {
  display: none !important;
}

body.ent-layout #__content {
  margin-top: 0 !important;
}

body.ent-layout .vd_content-section {
  border: none;
  background: transparent;
}

body.ent-layout .vd_title-section {
  background: transparent;
  border: none;
}

/* ── Alert banner ────────────────────────────────────────── */
.ent-alert-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--fmfp-warn-soft);
  border-left: 3px solid var(--fmfp-warn);
  border-radius: var(--r-sm);
  margin-bottom: 16px;
  font-size: 13.5px;
  color: #78350f;
  flex-wrap: wrap;
}

.ent-alert-icon {
  color: var(--fmfp-warn);
  flex-shrink: 0;
}

.ent-alert-text {
  flex: 1;
  min-width: 200px;
  line-height: 1.4;
}

.ent-alert-link {
  font-weight: 600;
  color: var(--fmfp-blue);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
}

.ent-alert-link:hover {
  text-decoration: underline;
}

.ent-alert-close {
  background: none;
  border: none;
  cursor: pointer;
  color: #9a6c00;
  font-size: 14px;
  padding: 0 4px;
  line-height: 1;
  flex-shrink: 0;
  opacity: .7;
  transition: opacity .12s;
}

.ent-alert-close:hover {
  opacity: 1;
}

/* ── Toast system (v2 — stacked, progress, hover-expand) ─── */
#ent-toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column-reverse;
  align-items: flex-end;
  width: 360px;
  pointer-events: none;
}

.ent-toast {
  pointer-events: auto;
  background: var(--fmfp-paper);
  border: 1px solid var(--fmfp-rule);
  border-radius: var(--r-lg);
  padding: 13px 14px 15px;
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 11px;
  box-shadow: var(--shadow-toast);
  position: relative;
  overflow: hidden;
  transform-origin: bottom right;
  transition: transform .35s cubic-bezier(.2, .8, .2, 1), margin .35s cubic-bezier(.2, .8, .2, 1), opacity .25s ease;
  animation: entToastIn .35s cubic-bezier(.2, .8, .2, 1);
}

@keyframes entToastIn {
  from {
    opacity: 0;
    transform: translateX(40px);
  }

  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Stack collapse — 2nd+ sit behind the newest, scaled & offset */
#ent-toast-container .ent-toast+.ent-toast {
  margin-bottom: -58px;
  transform: translateY(-8px) scale(.96);
  z-index: 1;
}

#ent-toast-container .ent-toast+.ent-toast+.ent-toast {
  margin-bottom: -58px;
  transform: translateY(-16px) scale(.92);
  opacity: .95;
  z-index: 0;
}

#ent-toast-container .ent-toast+.ent-toast+.ent-toast+.ent-toast {
  display: none;
}

/* Hover: expand the full stack */
#ent-toast-container:hover .ent-toast,
#ent-toast-container .ent-toast+.ent-toast,
#ent-toast-container .ent-toast+.ent-toast+.ent-toast {
  margin-bottom: 8px;
}

#ent-toast-container:hover .ent-toast {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.ent-toast.ent-toast--out {
  animation: entToastOut .22s ease forwards;
}

@keyframes entToastOut {
  to {
    opacity: 0;
    transform: translateX(40px) scale(.96);
  }
}

/* Icon badge */
.ent-toast-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--r-md);
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-family: Inter, sans-serif;
  font-weight: 700;
  font-size: 13px;
  background: var(--fmfp-ink-3);
}

.ent-toast--success .ent-toast-icon {
  background: var(--fmfp-ok);
}

.ent-toast--error .ent-toast-icon {
  background: var(--fmfp-danger);
}

.ent-toast--warning .ent-toast-icon {
  background: var(--fmfp-warn);
}

.ent-toast--info .ent-toast-icon {
  background: var(--fmfp-blue);
}

/* Body */
.ent-toast-bd {
  flex: 1;
  min-width: 0;
  padding-top: 3px;
}

.ent-toast-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--fmfp-ink);
  line-height: 1.25;
}

.ent-toast-desc {
  font-size: 12px;
  color: var(--fmfp-ink-3);
  margin-top: 3px;
  line-height: 1.4;
}

/* Close button */
.ent-toast-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--fmfp-ink-4);
  font-family: Inter, sans-serif;
  font-size: 13px;
  padding: 0 4px;
  line-height: 1;
  flex-shrink: 0;
  transition: color .1s;
}

.ent-toast-close:hover {
  color: var(--fmfp-ink);
}

/* ══════════════════════════════════════════════════════════════
   TOPBAR RESPONSIVE
   ══════════════════════════════════════════════════════════════ */

/* ── md ≤ 900px — collapse non-essential items ─────────────── */
@media (max-width: 900px) {
  /* hide date chip */
  .top-date { display: none; }

  /* hide username in user button */
  .top-user .nm { display: none; }

  /* hide breadcrumbs — not enough room on tablet/mobile */
  .crumbs { display: none; }

  /* push icon cluster to the right edge */
  .top-right { margin-left: auto; }

  /* collapse search bar to 32×32 icon button — matches .top-icon-btn */
  .top-search-btn {
    min-width: 0;
    width: 32px;
    height: 32px;
    padding: 0;
    justify-content: center;
    border: 1px solid var(--fmfp-rule) !important;
    background: var(--fmfp-paper) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-radius: var(--r-sm);
    color: var(--fmfp-ink-2);
  }
  .top-search-btn:hover {
    background: var(--fmfp-paper-2) !important;
    border-color: var(--fmfp-rule-2) !important;
  }
  .top-search-btn .lbl,
  .top-search-btn .kbd { display: none; }
}

/* ── mobile ≤ 768px — compact topbar ──────────────────────── */
@media (max-width: 768px) {
  /* reduce topbar padding and internal gap */
  .top {
    padding: 0 12px;
    gap: 8px;
  }

  /* remove chevron from user pill (no room) */
  .top-user .chev { display: none; }

  /* reduce gap inside top-right cluster */
  .top-right { gap: 4px; }
}

/* ── xs ≤ 480px — minimal topbar ──────────────────────────── */
@media (max-width: 480px) {
  /* hide preferences shortcut icon — accessible via user menu */
  .top-right > a.top-icon-btn { display: none; }

  /* user pill: avatar only */
  .top-user {
    padding: 0 6px;
    margin-left: 0;
  }
}

/* Progress bar */
.ent-toast-progress {
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  width: 100%;
  transform-origin: left center;
  opacity: .45;
}

@keyframes entToastTimer {
  from {
    transform: scaleX(1);
  }

  to {
    transform: scaleX(0);
  }
}

.ent-toast--success .ent-toast-progress {
  background: var(--fmfp-ok);
}

.ent-toast--error .ent-toast-progress {
  background: var(--fmfp-danger);
}

.ent-toast--warning .ent-toast-progress {
  background: var(--fmfp-warn);
}

.ent-toast--info .ent-toast-progress {
  background: var(--fmfp-blue);
}

#ent-toast-container:hover .ent-toast-progress {
  animation-play-state: paused;
}

/* ── Enterprise Dev Kit ──────────────────────────────────── */
#ent-devkit {
  position: fixed;
  bottom: 20px;
  right: 24px;
  z-index: 9998;
  display: none;
  flex-direction: column;
  align-items: flex-end;
  gap: 0;
  font-family: Inter, sans-serif;
  font-size: 11px;
}

#ent-devkit-tab {
  display: flex;
  align-items: center;
  gap: 5px;
  background: #0f1c2e;
  color: #7dd3a8;
  border: 1px solid #1e3a5a;
  border-bottom: none;
  padding: 5px 12px;
  cursor: grab;
  border-radius: 4px 4px 0 0;
  letter-spacing: .06em;
  user-select: none;
  -webkit-user-select: none;
}
.ent-dk-dragging #ent-devkit-tab { cursor: grabbing; }

#ent-devkit-tab:hover {
  background: #162032;
}

.ent-dk-tab-label {
  font-size: 10px;
  letter-spacing: .1em;
}

#ent-devkit-panel {
  display: none;
  background: #0f1c2e;
  border: 1px solid #1e3a5a;
  border-radius: 4px 4px 4px 0;
  width: 320px;
  max-height: 420px;
  overflow-y: auto;
}

#ent-devkit-panel.open {
  display: block;
}

#ent-devkit-panel::-webkit-scrollbar {
  width: 4px;
}

#ent-devkit-panel::-webkit-scrollbar-thumb {
  background: #1e3a5a;
}

.ent-dk-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px 8px;
  border-bottom: 1px solid #1e3a5a;
}

.ent-dk-title {
  color: #7dd3a8;
  font-size: 11px;
  letter-spacing: .08em;
}

.ent-dk-close {
  background: none;
  border: none;
  cursor: pointer;
  color: #4a7a9b;
  font-size: 13px;
  padding: 0;
  line-height: 1;
}

.ent-dk-close:hover {
  color: #e2e8f0;
}

.ent-dk-section-label {
  font-size: 9px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2e5270;
  padding: 8px 14px 4px;
}

#ent-dk-cookie-list {
  padding: 0 8px;
}

.ent-dk-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 6px;
  border-radius: 3px;
  background: #162032;
  margin-bottom: 3px;
}

.ent-dk-row-name {
  color: #4a9eda;
  flex: 0 0 110px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ent-dk-row-val {
  color: #7dd3a8;
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ent-dk-del {
  background: none;
  border: none;
  cursor: pointer;
  color: #4a7a9b;
  font-size: 11px;
  padding: 0 2px;
  flex-shrink: 0;
  transition: color .1s;
}

.ent-dk-del:hover {
  color: #ef4444;
}

.ent-dk-empty {
  color: #2e5270;
  padding: 6px 14px;
  font-style: italic;
}

.ent-dk-actions {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 0 8px;
}

.ent-dk-actions button {
  background: #162032;
  border: 1px solid #1e3a5a;
  color: #7fa8c4;
  padding: 4px 8px;
  border-radius: 3px;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  font-size: 11px;
  transition: background .1s, color .1s;
}

.ent-dk-actions button:hover {
  background: #1e3a5a;
  color: #e2e8f0;
}

.ent-dk-danger {
  background: none;
  border: none;
  cursor: pointer;
  color: #e07070;
  font-family: inherit;
  font-size: 11px;
  padding: 6px 14px 10px;
  display: block;
  width: 100%;
  text-align: left;
  transition: color .1s;
}

.ent-dk-danger:hover {
  color: #ef4444;
}

/* ── Search Modal Overlay ─────────────────────────────────── */
.ent-ovl {
  position: fixed;
  inset: 0;
  background: rgb(10 21 37 / 63%);
  backdrop-filter: blur(14px) saturate(.6);
  -webkit-backdrop-filter: blur(14px) saturate(.6);
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 9000;
  padding-top: 14vh;
  animation: entOvlIn .15s ease;
}

.ent-ovl.is-open { display: flex; }

@keyframes entOvlIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes entOvlOut {
  from { opacity: 1; }
  to   { opacity: 0; }
}

@keyframes entModalIn {
  from { opacity: 0; transform: translateY(-8px) scale(.97); }
  to   { opacity: 1; transform: none; }
}
@keyframes entModalOut {
  from { opacity: 1; transform: none; }
  to   { opacity: 0; transform: translateY(-6px) scale(.97); }
}

.ent-ovl.is-closing {
  animation: entOvlOut .14s ease forwards;
}
.ent-ovl.is-closing .ent-search-modal {
  animation: entModalOut .14s cubic-bezier(.2, 0, 0, 1) forwards;
}

.ent-search-modal {
  width: min(660px, calc(100vw - 40px));
  background: rgba(10, 18, 36, .92);
  backdrop-filter: blur(28px) saturate(1.2);
  -webkit-backdrop-filter: blur(28px) saturate(1.2);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .08);
  overflow: hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.04) inset,
    0 4px 40px rgba(0,0,0,.4);
  animation: entModalIn .2s cubic-bezier(.2, 0, 0, 1);
}

.ent-search-input {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}

.ent-search-input .ic {
  color: rgba(255,255,255,.35);
  flex-shrink: 0;
}

.ent-search-input input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-size: 15px;
  font-family: inherit;
  color: rgba(255,255,255,.9);
}

.ent-search-input input::placeholder {
  color: rgba(255,255,255,.25);
}

.ent-search-input .esc {
  font-family: Inter, sans-serif;
  font-size: 10px;
  letter-spacing: .06em;
  color: rgba(255,255,255,.25);
  padding: 3px 7px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 5px;
  flex-shrink: 0;
}

/* ── Results ───────────────────────────────────────────────── */
.ent-search-results {
  max-height: 400px;
  overflow: auto;
  padding: 4px 0 10px;
}

.ent-search-results::-webkit-scrollbar {
  width: 4px;
}

.ent-search-results::-webkit-scrollbar-track {
  background: transparent;
}

.ent-search-results::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.1);
  border-radius: 2px;
}

.ent-search-results::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,.18);
}

.ent-search-group-hd {
  font-family: Inter, sans-serif;
  font-size: 9px;
  letter-spacing: .12em;
  color: rgba(255,255,255,.2);
  text-transform: uppercase;
  padding: 12px 22px 4px;
}

.ent-search-result {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 22px;
  cursor: pointer;
  text-decoration: none !important;
  color: inherit;
  border-radius: 6px;
  margin: 1px 10px;
  transition: background .1s;
}

.ent-search-result:hover,
.ent-search-result.is-active {
  background: rgba(255, 255, 255, .06);
}

.ent-search-result .ic {
  width: 30px;
  height: 30px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.35);
  flex: 0 0 auto;
}

.ent-search-result:hover .ic,
.ent-search-result.is-active .ic {
  color: var(--fmfp-blue-light, #5b9bd5);
  border-color: rgba(91,155,213,.25);
  background: rgba(91,155,213,.08);
}

.ent-search-result .bd {
  flex: 1;
  min-width: 0;
}

.ent-search-result .ti {
  font-size: 13px;
  color: rgba(255,255,255,.85);
  font-weight: 500;
  line-height: 1.2;
}

.ent-search-result .ds {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  margin-top: 1px;
}

/* ── Footer ────────────────────────────────────────────────── */
.ent-search-foot {
  padding: 8px 22px;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: Inter, sans-serif;
  font-size: 9.5px;
  letter-spacing: .05em;
  color: rgba(255,255,255,.2);
  text-transform: uppercase;
}

/* Action items */
.ent-search-result.is-action .ic {
  background: rgba(239,68,68,.15);
  border-color: transparent;
  color: rgba(239,68,68,.8);
}
.ent-search-result.is-action:hover .ic,
.ent-search-result.is-action.is-active .ic { border-color: rgba(239,68,68,.3); }

/* Appel items (div-based, has Soumettre button) */
.ent-search-result--appel {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 22px;
  cursor: default;
  text-decoration: none !important;
  color: inherit;
  border-radius: 6px;
  margin: 1px 10px;
  transition: background .1s;
}
.ent-search-result--appel:hover,
.ent-search-result--appel.is-active { background: rgba(255, 255, 255, .06); }
.ent-search-result--appel .ic {
  width: 30px; height: 30px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.35);
  flex: 0 0 auto;
}
.ent-search-result--appel:hover .ic,
.ent-search-result--appel.is-active .ic {
  color: var(--fmfp-blue-light, #5b9bd5);
  border-color: rgba(91,155,213,.25);
  background: rgba(91,155,213,.08);
}
.ent-search-result--appel .bd { flex: 1; min-width: 0; }
.ent-search-result--appel .bd .ti { font-size: 13px; color: rgba(255,255,255,.85); font-weight: 500; line-height: 1.2; }
.ent-search-result--appel .bd .ds { font-size: 11px; color: rgba(255,255,255,.35); margin-top: 1px; }

.ent-search-soumettre {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 10px;
  font-size: 12px; font-family: inherit; font-weight: 600;
  color: rgba(255,255,255,.75);
  background: transparent;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
  transition: color .15s, border-color .15s, background .15s;
}
.ent-search-soumettre:hover {
  color: #fff;
  border-color: rgba(255,255,255,.25);
  background: rgba(255,255,255,.06);
}
.ent-search-soumettre .arr { transition: transform .15s; }
.ent-search-soumettre:hover .arr { transform: translateX(3px); }

/* Empty state */
.ent-search-empty {
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 36px 24px;
  color: rgba(255,255,255,.15);
  text-align: center;
}
.ent-search-empty-ti {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,.4);
}
.ent-search-empty-ds {
  font-size: 11px;
  color: rgba(255,255,255,.25);
}
.ent-search-empty-ds strong { color: rgba(255,255,255,.45); }

.ent-search-foot kbd {
  font-family: inherit;
  font-size: 9px;
  padding: 1px 5px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 4px;
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.25);
  margin-right: 4px;
}

/* ── Search modal — tabs ─────────────────────────────────── */
.ent-search-tabs {
  display: flex;
  gap: 2px;
  padding: 0 20px 10px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.ent-search-tab {
  font-size: 11px;
  font-family: Inter, sans-serif;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: rgba(255,255,255,.3);
  background: transparent;
  border: none;
  padding: 5px 12px;
  border-radius: 5px;
  cursor: pointer;
  transition: all .12s;
}
.ent-search-tab:hover { color: rgba(255,255,255,.55); background: rgba(255,255,255,.04); }
.ent-search-tab.is-active { color: #fff; background: rgba(255,255,255,.1); }

/* ── Search modal — results highlights ──────────────────── */
.ent-search-result mark {
  background: rgba(91,155,213,.25);
  color: inherit;
  border-radius: 2px;
  padding: 0 2px;
}

/* ── Search modal — status pill in results ──────────────── */
.ent-search-result .pill {
  font-size: 9px;
  font-family: Inter, sans-serif;
  letter-spacing: .05em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 4px;
  white-space: nowrap;
  margin-left: auto;
  flex-shrink: 0;
}
.ent-search-result .pill.ok    { background: rgba(22,163,74,.15); color: #4ADE80; }
.ent-search-result .pill.blue  { background: rgba(37,99,235,.15); color: #60A5FA; }
.ent-search-result .pill.danger{ background: rgba(220,38,38,.15);  color: #F87171; }
.ent-search-result .pill.draft { background: rgba(148,163,184,.1); color: #94A3B8; }

/* ── Search modal — history (empty input) ───────────────── */
.ent-search-history {
  padding: 0 20px 6px;
}
.ent-search-history-hd {
  font-family: Inter, sans-serif;
  font-size: 9px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.2);
  padding: 10px 2px 4px;
}
.ent-search-history-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  margin: 0;
  border-radius: 5px;
  cursor: pointer;
  color: rgba(255,255,255,.5);
  font-size: 12.5px;
  transition: background .1s;
}
.ent-search-history-item:hover { background: rgba(255,255,255,.06); color: rgba(255,255,255,.75); }
.ent-search-history-item .ic { color: rgba(255,255,255,.2); flex-shrink: 0; }
.ent-search-history-item .del {
  margin-left: auto;
  color: rgba(255,255,255,.15);
  cursor: pointer;
  flex-shrink: 0;
  padding: 2px;
}
.ent-search-history-item .del:hover { color: rgba(239,68,68,.7); }

/* ── Search modal — suggestions (empty input) ───────────── */
.ent-search-suggestions {
  padding: 0 20px 6px;
}
.ent-search-suggestions .ent-search-history-hd { padding-top: 6px; }
.ent-search-suggestions .ent-search-history-item .ic { color: rgba(255,255,255,.3); }

/* ── Search modal — loading state ───────────────────────── */
.ent-search-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 28px 20px;
  color: rgba(255,255,255,.2);
  font-size: 12px;
}
.ent-search-loading .spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,.08);
  border-top-color: rgba(255,255,255,.35);
  border-radius: 50%;
  animation: entSearchSpin .6s linear infinite;
}
@keyframes entSearchSpin { to { transform: rotate(360deg); } }

/* ── Back to top ─────────────────────────────────────────── */
#back-top {
  position: fixed;
  bottom: 28px;
  left: calc((100vw + var(--sidebar-w)) / 2);
  transform: translateX(-50%) translateY(12px);
  z-index: 190;

  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px 8px 12px;

  background: var(--fmfp-ink);
  color: #fff;
  border: none;
  border-radius: var(--r-pill);
  font-family: Inter, sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none !important;
  white-space: nowrap;
  cursor: pointer;

  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease, background .12s;
  box-shadow: 0 4px 16px -4px rgba(8, 26, 42, .35);
}

#back-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

#back-top:hover {
  background: var(--fmfp-blue-ink);
  color: #fff;
}

#back-top svg {
  flex-shrink: 0;
}

@media (min-width: 901px) {
  body.sb-collapsed #back-top {
    left: calc((100vw + var(--sidebar-w-collapsed)) / 2);
  }
}

@media (max-width: 900px) {
  #back-top {
    left: 50%;
  }
}

/* Kill old theme.css vd_back-top styles on enterprise pages */
body.ent-layout .vd_back-top {
  display: none !important;
}

/* ── Page loader (top linear bar) ────────────────────────── */
/* Suppress the old full-screen overlay on enterprise pages */
body.ent-layout .modal-mask {
  display: none !important;
}

#ent-page-bar {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  width: 0%;
  z-index: 99999;
  pointer-events: none;
  border-radius: 0 2px 2px 0;
  background: linear-gradient(90deg, var(--fmfp-blue-dark), var(--fmfp-blue) 40%, #5badee);
  box-shadow: 0 0 8px rgba(21, 101, 168, .55), 0 0 2px rgba(21, 101, 168, .3);
  transition: width .38s cubic-bezier(.4, 0, .2, 1), opacity .35s ease;
  opacity: 1;
}

#ent-page-bar.is-done {
  opacity: 0;
  width: 100% !important;
  transition: width .25s ease, opacity .4s ease .1s;
}

#ent-page-overlay {
  position: fixed;
  inset: 0;
  z-index: 99998;
  background: rgba(8, 20, 36, .32);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(1px);
  opacity: 1;
  transition: opacity .4s ease;
  cursor: wait;
}

#ent-page-overlay.is-done {
  opacity: 0;
  pointer-events: none;
}