@import url('fonts.css');

/*
 * VereinsMail Admin UI — Design System
 * Version 1.0.0
 * Stack: Bootstrap 5 + custom layer
 *
 * TABLE OF CONTENTS
 * ─────────────────────────────────────────────────────
 *  1.  Custom Properties (Tokens)
 *  2.  Base & Reset
 *  3.  Typography
 *  4.  Layout — Sidebar
 *  5.  Layout — Topbar
 *  6.  Layout — Main & Content
 *  7.  Navigation
 *  8.  Components — Cards & Panels
 *  9.  Components — Stat Cards
 * 10.  Components — Tables
 * 11.  Components — Badges & Status
 * 12.  Components — Buttons
 * 13.  Components — Forms & Inputs
 * 14.  Components — Ticket Items
 * 15.  Components — DNS / Record Rows
 * 16.  Components — Charts & Meters
 * 17.  Components — Score Ring
 * 18.  Components — Alerts & Notices
 * 19.  Components — Modals
 * 20.  Components — Dropdowns
 * 21.  Components — Avatars
 * 22.  Components — Empty States
 * 23.  Components — Skeleton Loaders
 * 24.  Utilities
 * 25.  Animations
 * 26.  Scrollbar
 * 27.  Responsive
 * ─────────────────────────────────────────────────────
 */

/* ═══════════════════════════════════════════════════
   1. CUSTOM PROPERTIES (TOKENS)
   ═══════════════════════════════════════════════════ */
:root {
  /* Background layers */
  --vm-bg:          #080b12;
  --vm-bg2:         #0c1018;
  --vm-surface:     #111720;
  --vm-surface2:    #161d28;
  --vm-surface3:    #1b2535;

  /* Borders */
  --vm-border:      #1e2a3a;
  --vm-border2:     #243447;
  --vm-border3:     #2d4060;

  /* Brand colors */
  --vm-blue:        #3b82f6;
  --vm-blue-dim:    #3b82f620;
  --vm-cyan:        #06b6d4;
  --vm-cyan-dim:    #06b6d420;
  --vm-purple:      #8b5cf6;
  --vm-purple-dim:  #8b5cf620;

  /* Semantic */
  --vm-success:     #10b981;
  --vm-success-dim: #10b98118;
  --vm-warning:     #f59e0b;
  --vm-warning-dim: #f59e0b18;
  --vm-danger:      #ef4444;
  --vm-danger-dim:  #ef444418;
  --vm-info:        #06b6d4;
  --vm-info-dim:    #06b6d418;

  /* Text */
  --vm-text:        #e2e8f0;
  --vm-text2:       #94a3b8;
  --vm-text3:       #4a6080;
  --vm-text4:       #2d3f56;

  /* Sidebar */
  --vm-sidebar-w:   260px;

  /* Topbar */
  --vm-topbar-h:    60px;

  /* Radius */
  --vm-radius-sm:   6px;
  --vm-radius:      10px;
  --vm-radius-lg:   14px;
  --vm-radius-xl:   20px;

  /* Shadows */
  --vm-shadow-sm:   0 2px 8px #00000040;
  --vm-shadow:      0 4px 20px #00000050;
  --vm-shadow-lg:   0 10px 40px #00000060;

  /* Typography */
  --vm-font-display: 'Manrope', sans-serif;
  --vm-font-body:    'IBM Plex Sans', sans-serif;
  --vm-font-mono:    'IBM Plex Mono', monospace;

  /* Transitions */
  --vm-transition:  all .18s ease;
}


/* ═══════════════════════════════════════════════════
   2. BASE & RESET
   ═══════════════════════════════════════════════════ */
*, *::before, *::after {
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

body {
  font-family: var(--vm-font-body);
  background: var(--vm-bg);
  color: var(--vm-text);
  font-size: 15px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

::selection {
  background: var(--vm-blue-dim);
  color: var(--vm-blue);
}


/* ═══════════════════════════════════════════════════
   3. TYPOGRAPHY
   ═══════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6,
.vm-heading {
  font-family: var(--vm-font-display);
  font-weight: 800;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.3px;
}

.vm-page-title {
  font-family: var(--vm-font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 .25rem;
}

.vm-page-subtitle {
  font-size: .875rem;
  color: var(--vm-text2);
  margin: 0;
}

.vm-section-label {
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--vm-text3);
}

.vm-mono {
  font-family: var(--vm-font-mono);
  font-size: .875em;
}

.vm-muted  { color: var(--vm-text2); }
.vm-subtle { color: var(--vm-text3); }
.vm-link   { color: var(--vm-blue); cursor: pointer; text-decoration: none; }
.vm-link:hover { color: var(--vm-cyan); text-decoration: underline; }


/* ═══════════════════════════════════════════════════
   4. LAYOUT — SIDEBAR
   ═══════════════════════════════════════════════════ */
.vm-sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--vm-sidebar-w);
  background: var(--vm-bg2);
  border-right: 1px solid var(--vm-border);
  display: flex;
  flex-direction: column;
  z-index: 200;
  transition: transform .3s cubic-bezier(.4,0,.2,1);
  overflow: hidden;
}

/* Logo area */
.vm-sidebar-logo {
  padding: 1.25rem 1.1rem 1rem;
  border-bottom: 1px solid var(--vm-border);
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-shrink: 0;
}

.vm-logo-mark {
  width: 36px; height: 36px;
  border-radius: var(--vm-radius);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: 0 4px 12px #3b82f630;
  overflow: hidden;
}

.vm-logo-mark i { color: #fff; }

.vm-logo-text {
  font-family: var(--vm-font-display);
  font-weight: 800;
  font-size: 1.1rem;
  color: #fff;
  letter-spacing: -.5px;
  line-height: 1;
}

.vm-logo-text .accent { color: var(--vm-cyan); }

.vm-logo-version {
  font-size: .6rem;
  color: var(--vm-text3);
  font-family: var(--vm-font-mono);
  margin-top: .15rem;
}

/* Org switcher */
.vm-org-switcher {
  margin: .85rem .75rem;
  background: var(--vm-surface);
  border: 1px solid var(--vm-border);
  border-radius: var(--vm-radius);
  padding: .6rem .85rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: .65rem;
  transition: var(--vm-transition);
  flex-shrink: 0;
}

.vm-org-switcher:hover {
  border-color: var(--vm-border3);
  background: var(--vm-surface2);
}

.vm-org-name {
  font-size: .82rem;
  font-weight: 600;
  color: var(--vm-text);
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vm-org-plan {
  font-size: .68rem;
  color: var(--vm-text3);
  margin-top: .05rem;
}

.vm-org-chevron {
  color: var(--vm-text3);
  font-size: .7rem;
  flex-shrink: 0;
}

/* Sidebar nav scroll area */
.vm-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: .25rem 0 1rem;
}

/* Sidebar footer */
.vm-sidebar-footer {
  border-top: 1px solid var(--vm-border);
  padding: .85rem .5rem;
  flex-shrink: 0;
}

/* Overlay (mobile) */
.vm-sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(4px);
  z-index: 199;
}


/* ═══════════════════════════════════════════════════
   5. LAYOUT — TOPBAR
   ═══════════════════════════════════════════════════ */
.vm-topbar {
  position: sticky;
  top: 0;
  height: var(--vm-topbar-h);
  background: var(--vm-bg2);
  border-bottom: 1px solid var(--vm-border);
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0 1.75rem;
  z-index: 100;
  flex-shrink: 0;
}

.vm-topbar-left {
  display: flex;
  align-items: center;
  gap: .75rem;
  min-width: 0;
}

.vm-topbar-title {
  font-family: var(--vm-font-display);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}

.vm-topbar-breadcrumb {
  font-size: .78rem;
  color: var(--vm-text3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.vm-topbar-breadcrumb .sep {
  margin: 0 .3rem;
  color: var(--vm-text4);
}

.vm-topbar-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-shrink: 0;
}

/* Topbar search */
.vm-search {
  background: var(--vm-surface);
  border: 1px solid var(--vm-border);
  border-radius: var(--vm-radius);
  padding: .45rem .9rem;
  display: flex;
  align-items: center;
  gap: .5rem;
  min-width: 200px;
  transition: var(--vm-transition);
}

.vm-search:focus-within {
  border-color: var(--vm-blue);
  background: var(--vm-surface2);
  box-shadow: 0 0 0 3px var(--vm-blue-dim);
}

.vm-search i { color: var(--vm-text3); font-size: .85rem; }

.vm-search input {
  background: transparent;
  border: none;
  color: var(--vm-text);
  font-size: .82rem;
  outline: none;
  font-family: var(--vm-font-body);
  width: 100%;
}

.vm-search input::placeholder { color: var(--vm-text3); }

.vm-search-kbd {
  font-size: .6rem;
  color: var(--vm-text3);
  background: var(--vm-surface3);
  padding: 2px 5px;
  border-radius: 4px;
  font-family: var(--vm-font-mono);
  border: 1px solid var(--vm-border2);
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════
   6. LAYOUT — MAIN & CONTENT
   ═══════════════════════════════════════════════════ */
.vm-layout {
  display: flex;
  min-height: 100vh;
}

.vm-main {
  margin-left: var(--vm-sidebar-w);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.vm-content {
  padding: 1.75rem;
  flex: 1;
}

.vm-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
}

.vm-page-header-left {}
.vm-page-header-actions {
  display: flex;
  gap: .5rem;
  align-items: center;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════
   7. NAVIGATION
   ═══════════════════════════════════════════════════ */
.vm-nav-section {
  padding: .9rem .9rem .2rem;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--vm-text3);
}

.vm-nav-item {
  margin: 1px .5rem;
}

.vm-nav-link {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .55rem .8rem;
  color: var(--vm-text2);
  text-decoration: none;
  font-size: .85rem;
  font-weight: 500;
  border-radius: var(--vm-radius-sm);
  transition: var(--vm-transition);
  position: relative;
  cursor: pointer;
}

.vm-nav-link i {
  font-size: .95rem;
  width: 16px;
  text-align: center;
  flex-shrink: 0;
}

.vm-nav-link:hover {
  color: var(--vm-text);
  background: var(--vm-surface);
}

.vm-nav-link.active {
  color: #fff;
  background: var(--vm-surface2);
}

.vm-nav-link.active::before {
  content: '';
  position: absolute;
  left: -2px;
  top: 22%; bottom: 22%;
  width: 3px;
  background: var(--vm-blue);
  border-radius: 0 3px 3px 0;
}

.vm-nav-link .vm-nav-text { flex: 1; }

/* Badges on nav */
.vm-nav-badge {
  margin-left: auto;
  padding: 1px 7px;
  border-radius: 20px;
  font-size: .62rem;
  font-weight: 700;
  font-family: var(--vm-font-mono);
  line-height: 1.6;
}

.vm-nav-badge.default { background: var(--vm-danger); color: #fff; }
.vm-nav-badge.success { background: var(--vm-success); color: #fff; }
.vm-nav-badge.warning { background: var(--vm-warning); color: #000; }
.vm-nav-badge.info    { background: var(--vm-blue); color: #fff; }

/* User card in sidebar footer */
.vm-user-card {
  display: flex;
  align-items: center;
  gap: .7rem;
  padding: .5rem .75rem;
  border-radius: var(--vm-radius-sm);
  cursor: pointer;
  transition: var(--vm-transition);
}

.vm-user-card:hover { background: var(--vm-surface); }
.vm-user-name  { font-size: .82rem; font-weight: 600; color: var(--vm-text); }
.vm-user-role  { font-size: .7rem; color: var(--vm-text2); }


/* ═══════════════════════════════════════════════════
   8. COMPONENTS — CARDS & PANELS
   ═══════════════════════════════════════════════════ */

/* Generic panel */
.vm-panel {
  background: var(--vm-surface);
  border: 1px solid var(--vm-border);
  border-radius: var(--vm-radius-lg);
  overflow: hidden;
}

.vm-panel-head {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--vm-border);
  display: flex;
  align-items: center;
  gap: .75rem;
  flex-wrap: wrap;
}

.vm-panel-icon {
  font-size: 1rem;
  flex-shrink: 0;
}

.vm-panel-title {
  font-family: var(--vm-font-display);
  font-size: .92rem;
  font-weight: 700;
  color: #fff;
}

.vm-panel-subtitle {
  font-size: .78rem;
  color: var(--vm-text2);
  margin-top: .1rem;
}

.vm-panel-actions {
  margin-left: auto;
  display: flex;
  gap: .4rem;
  align-items: center;
  flex-wrap: wrap;
}

.vm-panel-body { padding: 1.5rem; }
.vm-panel-body--sm { padding: 1rem; }
.vm-panel-body--lg { padding: 2rem; }

.vm-panel-footer {
  padding: .875rem 1.5rem;
  border-top: 1px solid var(--vm-border);
  background: var(--vm-bg2);
  display: flex;
  align-items: center;
  gap: .75rem;
}

/* Hoverable panel variant */
.vm-panel-hover {
  transition: var(--vm-transition);
  cursor: pointer;
}

.vm-panel-hover:hover {
  border-color: var(--vm-border3);
  transform: translateY(-2px);
  box-shadow: var(--vm-shadow);
}


/* ═══════════════════════════════════════════════════
   9. COMPONENTS — STAT CARDS
   ═══════════════════════════════════════════════════ */
.vm-stat {
  background: var(--vm-surface);
  border: 1px solid var(--vm-border);
  border-radius: var(--vm-radius-lg);
  padding: 1.4rem 1.5rem;
  transition: var(--vm-transition);
}

.vm-stat:hover {
  border-color: var(--vm-border2);
  transform: translateY(-2px);
}

.vm-stat-icon {
  width: 42px; height: 42px;
  border-radius: var(--vm-radius);
  display: grid;
  place-items: center;
  font-size: 1.1rem;
  margin-bottom: .9rem;
}

.vm-stat-value {
  font-family: var(--vm-font-display);
  font-size: 1.9rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  margin-bottom: .3rem;
}

.vm-stat-label {
  font-size: .78rem;
  color: var(--vm-text2);
  font-weight: 500;
}

.vm-stat-change {
  display: flex;
  align-items: center;
  gap: .25rem;
  font-size: .72rem;
  font-family: var(--vm-font-mono);
  margin-top: .5rem;
}
.vm-stat-change.up     { color: var(--vm-success); }
.vm-stat-change.down   { color: var(--vm-danger); }
.vm-stat-change.neutral{ color: var(--vm-text3); }


/* ═══════════════════════════════════════════════════
   10. COMPONENTS — TABLES
   ═══════════════════════════════════════════════════ */
.vm-table {
  width: 100%;
  border-collapse: collapse;
}

.vm-table th {
  padding: .65rem 1.5rem;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--vm-text3);
  background: var(--vm-bg2);
  border-bottom: 1px solid var(--vm-border);
  white-space: nowrap;
  text-align: left;
}

.vm-table td {
  padding: .85rem 1.5rem;
  border-bottom: 1px solid var(--vm-border);
  font-size: .85rem;
  vertical-align: middle;
}

.vm-table tbody tr:last-child td { border-bottom: none; }

.vm-table tbody tr {
  transition: background .1s;
}

.vm-table tbody tr:hover td {
  background: var(--vm-surface2);
}

/* Compact table variant */
.vm-table--sm th { padding: .5rem 1rem; }
.vm-table--sm td { padding: .6rem 1rem; font-size: .8rem; }

/* Col types */
.vm-table .col-mono {
  font-family: var(--vm-font-mono);
  font-size: .78rem;
  color: var(--vm-cyan);
}

.vm-table .col-muted {
  color: var(--vm-text2);
  font-size: .8rem;
}

.vm-table .col-actions {
  width: 1%;
  white-space: nowrap;
}


/* ═══════════════════════════════════════════════════
   11. COMPONENTS — BADGES & STATUS
   ═══════════════════════════════════════════════════ */

/* Status dot badge */
.vm-badge {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .22rem .65rem;
  border-radius: 20px;
  font-size: .7rem;
  font-weight: 600;
  font-family: var(--vm-font-mono);
  white-space: nowrap;
  line-height: 1.4;
}

.vm-badge::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}

.vm-badge.active   { background: var(--vm-success-dim); color: var(--vm-success); }
.vm-badge.active::before { background: var(--vm-success); box-shadow: 0 0 5px var(--vm-success); }
.vm-badge.warning  { background: var(--vm-warning-dim); color: var(--vm-warning); }
.vm-badge.warning::before { background: var(--vm-warning); }
.vm-badge.error    { background: var(--vm-danger-dim);  color: var(--vm-danger); }
.vm-badge.error::before  { background: var(--vm-danger); box-shadow: 0 0 5px var(--vm-danger); }
.vm-badge.inactive { background: #94a3b812; color: var(--vm-text3); }
.vm-badge.inactive::before { background: var(--vm-text3); }
.vm-badge.info     { background: var(--vm-info-dim); color: var(--vm-info); }
.vm-badge.info::before { background: var(--vm-info); }

/* Plain label badge (no dot) */
.vm-tag {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .2rem .6rem;
  border-radius: var(--vm-radius-sm);
  font-size: .72rem;
  font-weight: 600;
  white-space: nowrap;
}

.vm-tag.blue   { background: var(--vm-blue-dim);   color: var(--vm-blue);   }
.vm-tag.cyan   { background: var(--vm-cyan-dim);   color: var(--vm-cyan);   }
.vm-tag.purple { background: var(--vm-purple-dim); color: var(--vm-purple); }
.vm-tag.green  { background: var(--vm-success-dim);color: var(--vm-success);}
.vm-tag.orange { background: var(--vm-warning-dim);color: var(--vm-warning);}
.vm-tag.red    { background: var(--vm-danger-dim); color: var(--vm-danger); }
.vm-tag.muted  { background: var(--vm-surface2);   color: var(--vm-text2);  }


/* ═══════════════════════════════════════════════════
   12. COMPONENTS — BUTTONS
   ═══════════════════════════════════════════════════ */

/* Icon button (topbar) */
.vm-icon-btn {
  width: 34px; height: 34px;
  border-radius: var(--vm-radius-sm);
  border: 1px solid var(--vm-border);
  background: var(--vm-surface);
  color: var(--vm-text2);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: var(--vm-transition);
  position: relative;
  font-size: .9rem;
  text-decoration: none;
  flex-shrink: 0;
}

.vm-icon-btn:hover {
  border-color: var(--vm-border2);
  color: var(--vm-text);
  background: var(--vm-surface2);
}

.vm-icon-btn .vm-notif-dot {
  position: absolute;
  top: 4px; right: 4px;
  width: 6px; height: 6px;
  background: var(--vm-danger);
  border-radius: 50%;
  border: 1px solid var(--vm-bg2);
}

/* General small action buttons */
.vm-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .45rem 1rem;
  border-radius: var(--vm-radius);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--vm-transition);
  border: 1px solid transparent;
  text-decoration: none;
  font-family: var(--vm-font-body);
  white-space: nowrap;
  line-height: 1;
}

.vm-btn:disabled {
  opacity: .4;
  pointer-events: none;
}

/* Variants */
.vm-btn-primary {
  background: var(--vm-blue);
  border-color: var(--vm-blue);
  color: #fff;
}
.vm-btn-primary:hover { background: #2563eb; border-color: #2563eb; color: #fff; }

.vm-btn-secondary {
  background: var(--vm-surface2);
  border-color: var(--vm-border2);
  color: var(--vm-text2);
}
.vm-btn-secondary:hover { border-color: var(--vm-border3); color: var(--vm-text); }

.vm-btn-ghost {
  background: transparent;
  border-color: var(--vm-border);
  color: var(--vm-text2);
}
.vm-btn-ghost:hover { background: var(--vm-surface); border-color: var(--vm-border2); color: var(--vm-text); }

.vm-btn-danger {
  background: var(--vm-danger-dim);
  border-color: var(--vm-danger);
  color: var(--vm-danger);
}
.vm-btn-danger:hover { background: var(--vm-danger); color: #fff; }

.vm-btn-success {
  background: var(--vm-success-dim);
  border-color: var(--vm-success);
  color: var(--vm-success);
}
.vm-btn-success:hover { background: var(--vm-success); color: #fff; }

.vm-btn-warning {
  background: var(--vm-warning-dim);
  border-color: var(--vm-warning);
  color: var(--vm-warning);
}
.vm-btn-warning:hover { background: var(--vm-warning); color: #000; }

/* Sizes */
.vm-btn-sm { padding: .28rem .7rem; font-size: .75rem; border-radius: var(--vm-radius-sm); }
.vm-btn-lg { padding: .7rem 1.5rem; font-size: .95rem; }
.vm-btn-xl { padding: .9rem 2rem; font-size: 1rem; }


/* ═══════════════════════════════════════════════════
   13. COMPONENTS — FORMS & INPUTS
   ═══════════════════════════════════════════════════ */
.vm-form-group {
  margin-bottom: 1.25rem;
}

.vm-label {
  display: block;
  font-size: .78rem;
  font-weight: 600;
  color: var(--vm-text2);
  margin-bottom: .4rem;
}

.vm-label .required { color: var(--vm-danger); margin-left: .2rem; }

.vm-input,
.vm-select,
.vm-textarea {
  width: 100%;
  background: var(--vm-surface2);
  border: 1px solid var(--vm-border2);
  border-radius: var(--vm-radius);
  color: var(--vm-text);
  font-size: .875rem;
  font-family: var(--vm-font-body);
  padding: .65rem 1rem;
  transition: var(--vm-transition);
  outline: none;
  appearance: none;
}

.vm-input:focus,
.vm-select:focus,
.vm-textarea:focus {
  border-color: var(--vm-blue);
  background: var(--vm-surface3);
  box-shadow: 0 0 0 3px var(--vm-blue-dim);
}

.vm-input::placeholder { color: var(--vm-text3); }
.vm-textarea { resize: vertical; min-height: 100px; }

.vm-input.vm-mono,
.vm-input--mono {
  font-family: var(--vm-font-mono);
  font-size: .8rem;
  color: var(--vm-cyan);
}

.vm-hint {
  display: block;
  margin-top: .35rem;
  font-size: .75rem;
  color: var(--vm-text3);
}

/* Input group (addon) */
.vm-input-group {
  display: flex;
}

.vm-input-group .vm-input {
  border-radius: 0 var(--vm-radius) var(--vm-radius) 0;
  flex: 1;
}

.vm-input-addon {
  background: var(--vm-surface3);
  border: 1px solid var(--vm-border2);
  border-right: none;
  border-radius: var(--vm-radius) 0 0 var(--vm-radius);
  padding: .65rem 1rem;
  font-size: .78rem;
  color: var(--vm-text3);
  white-space: nowrap;
  display: flex;
  align-items: center;
}

.vm-input-addon-right {
  border: 1px solid var(--vm-border2);
  border-left: none;
  border-radius: 0 var(--vm-radius) var(--vm-radius) 0;
}

.vm-input-group .vm-input:first-child { border-radius: var(--vm-radius) 0 0 var(--vm-radius); border-right: none; }

/* Toggle switch */
.vm-toggle {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
  border-bottom: 1px solid var(--vm-border);
}

.vm-toggle:last-child { border-bottom: none; }
.vm-toggle-title { font-size: .875rem; font-weight: 600; color: var(--vm-text); margin-bottom: .15rem; }
.vm-toggle-desc  { font-size: .75rem; color: var(--vm-text2); }

/* Bootstrap switch override */
.form-check-input {
  background-color: var(--vm-surface3);
  border-color: var(--vm-border2);
  cursor: pointer;
}
.form-check-input:checked {
  background-color: var(--vm-blue);
  border-color: var(--vm-blue);
}
.form-check-input:focus {
  box-shadow: 0 0 0 3px var(--vm-blue-dim);
}


/* ═══════════════════════════════════════════════════
   14. COMPONENTS — TICKET ITEMS
   ═══════════════════════════════════════════════════ */
.vm-ticket {
  padding: 1rem 1.5rem;
  border-bottom: 1px solid var(--vm-border);
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  cursor: pointer;
  transition: background .1s;
}

.vm-ticket:hover { background: var(--vm-surface2); }
.vm-ticket:last-child { border-bottom: none; }

.vm-ticket-prio {
  width: 3px;
  align-self: stretch;
  border-radius: 2px;
  flex-shrink: 0;
  margin-top: 4px;
}

.vm-ticket-prio.high   { background: var(--vm-danger); }
.vm-ticket-prio.medium { background: var(--vm-warning); }
.vm-ticket-prio.low    { background: var(--vm-success); }

.vm-ticket-body  { flex: 1; min-width: 0; }
.vm-ticket-title { font-size: .875rem; font-weight: 600; color: var(--vm-text); margin-bottom: .2rem; }
.vm-ticket-meta  { font-size: .75rem; color: var(--vm-text2); }
.vm-ticket-id    { font-family: var(--vm-font-mono); font-size: .68rem; color: var(--vm-text3); margin-top: .15rem; }

.vm-ticket-aside { text-align: right; flex-shrink: 0; }


/* ═══════════════════════════════════════════════════
   15. COMPONENTS — DNS / RECORD ROWS
   ═══════════════════════════════════════════════════ */
.vm-record {
  padding: .875rem 1.5rem;
  border-bottom: 1px solid var(--vm-border);
  display: flex;
  align-items: center;
  gap: .85rem;
  flex-wrap: wrap;
}

.vm-record:last-child { border-bottom: none; }

.vm-record-type {
  width: 62px;
  text-align: center;
  padding: .28rem .5rem;
  background: var(--vm-surface2);
  border: 1px solid var(--vm-border2);
  border-radius: var(--vm-radius-sm);
  font-family: var(--vm-font-mono);
  font-size: .7rem;
  font-weight: 600;
  color: var(--vm-cyan);
  flex-shrink: 0;
}

.vm-record-info { flex: 1; min-width: 0; }

.vm-record-name {
  font-size: .82rem;
  font-weight: 600;
  color: var(--vm-text);
  margin-bottom: .15rem;
}

.vm-record-value {
  font-family: var(--vm-font-mono);
  font-size: .7rem;
  color: var(--vm-text3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


/* ═══════════════════════════════════════════════════
   16. COMPONENTS — CHARTS & METERS
   ═══════════════════════════════════════════════════ */

/* Progress / meter bar */
.vm-meter {
  height: 6px;
  background: var(--vm-surface3);
  border-radius: 3px;
  overflow: hidden;
}

.vm-meter--sm { height: 4px; }
.vm-meter--md { height: 8px; }
.vm-meter--lg { height: 10px; }

.vm-meter-fill {
  height: 100%;
  border-radius: 3px;
  transition: width .5s ease;
}

.vm-meter-fill.blue   { background: linear-gradient(90deg, var(--vm-blue), var(--vm-cyan)); }
.vm-meter-fill.green  { background: linear-gradient(90deg, var(--vm-success), #6ee7b7); }
.vm-meter-fill.orange { background: linear-gradient(90deg, var(--vm-warning), #fcd34d); }
.vm-meter-fill.red    { background: linear-gradient(90deg, var(--vm-danger), #fca5a5); }
.vm-meter-fill.purple { background: linear-gradient(90deg, var(--vm-purple), #c4b5fd); }

/* Mini bar chart */
.vm-bar-chart {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 60px;
}

.vm-bar-group {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  align-items: center;
}

.vm-bar {
  width: 100%;
  border-radius: 3px 3px 0 0;
  transition: opacity .15s;
  cursor: pointer;
}

.vm-bar:hover { opacity: .75; }
.vm-bar.blue   { background: var(--vm-blue); }
.vm-bar.cyan   { background: var(--vm-cyan); }
.vm-bar.red    { background: var(--vm-danger); opacity: .7; }
.vm-bar.green  { background: var(--vm-success); }

.vm-bar-label {
  font-size: .6rem;
  color: var(--vm-text3);
  margin-top: 4px;
  font-family: var(--vm-font-mono);
}

/* Chart legend */
.vm-chart-legend {
  display: flex;
  gap: 1.25rem;
  font-size: .75rem;
  color: var(--vm-text2);
  flex-wrap: wrap;
}

.vm-chart-legend-item {
  display: flex;
  align-items: center;
  gap: .35rem;
}

.vm-chart-legend-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}


/* ═══════════════════════════════════════════════════
   17. COMPONENTS — SCORE RING
   ═══════════════════════════════════════════════════ */
.vm-score-ring {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.vm-score-ring svg { transform: rotate(-90deg); }

.vm-score-ring-value {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-family: var(--vm-font-display);
  font-weight: 800;
  color: #fff;
  line-height: 1;
}

.vm-score-ring-value .sub {
  font-size: .55em;
  color: var(--vm-text3);
  font-family: var(--vm-font-body);
  font-weight: 500;
}


/* ═══════════════════════════════════════════════════
   18. COMPONENTS — ALERTS & NOTICES
   ═══════════════════════════════════════════════════ */
.vm-alert {
  padding: .9rem 1.1rem;
  border-radius: var(--vm-radius);
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  font-size: .85rem;
  line-height: 1.5;
}

.vm-alert i { font-size: 1rem; flex-shrink: 0; margin-top: .1rem; }

.vm-alert.info    { background: var(--vm-info-dim);    border-left: 3px solid var(--vm-info);    color: #7dd3fc; }
.vm-alert.success { background: var(--vm-success-dim); border-left: 3px solid var(--vm-success); color: #6ee7b7; }
.vm-alert.warning { background: var(--vm-warning-dim); border-left: 3px solid var(--vm-warning); color: #fde68a; }
.vm-alert.error   { background: var(--vm-danger-dim);  border-left: 3px solid var(--vm-danger);  color: #fca5a5; }


/* ═══════════════════════════════════════════════════
   19. COMPONENTS — MODALS
   ═══════════════════════════════════════════════════ */

/* Override Bootstrap modal for dark theme */
.modal-content {
  background: var(--vm-surface);
  border: 1px solid var(--vm-border2);
  border-radius: var(--vm-radius-xl);
  box-shadow: var(--vm-shadow-lg);
}

.modal-header {
  border-bottom: 1px solid var(--vm-border);
  padding: 1.25rem 1.5rem;
}

.modal-title {
  font-family: var(--vm-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
}

.modal-body { padding: 1.5rem; }

.modal-footer {
  border-top: 1px solid var(--vm-border);
  padding: 1rem 1.5rem;
  gap: .5rem;
}

.btn-close {
  filter: invert(1) brightness(.6);
}

.btn-close:hover { filter: invert(1) brightness(1); }

.modal-backdrop { backdrop-filter: blur(4px); }


/* ═══════════════════════════════════════════════════
   20. COMPONENTS — DROPDOWNS
   ═══════════════════════════════════════════════════ */
.dropdown-menu {
  background: var(--vm-surface2);
  border: 1px solid var(--vm-border2);
  border-radius: var(--vm-radius-lg);
  box-shadow: var(--vm-shadow-lg);
  padding: .4rem;
  min-width: 180px;
}

.dropdown-item {
  color: var(--vm-text2);
  font-size: .85rem;
  font-family: var(--vm-font-body);
  padding: .5rem .75rem;
  border-radius: var(--vm-radius-sm);
  transition: var(--vm-transition);
  display: flex;
  align-items: center;
  gap: .6rem;
}

.dropdown-item:hover {
  background: var(--vm-surface3);
  color: var(--vm-text);
}

.dropdown-item.text-danger:hover {
  background: var(--vm-danger-dim);
  color: var(--vm-danger);
}

.dropdown-divider {
  border-color: var(--vm-border);
  margin: .3rem 0;
}

.dropdown-header {
  color: var(--vm-text3);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  padding: .5rem .75rem .2rem;
}


/* ═══════════════════════════════════════════════════
   21. COMPONENTS — AVATARS
   ═══════════════════════════════════════════════════ */
.vm-avatar {
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
  font-family: var(--vm-font-display);
  text-transform: uppercase;
}

.vm-avatar-sm  { width: 26px; height: 26px; font-size: .65rem; }
.vm-avatar-md  { width: 34px; height: 34px; font-size: .82rem; }
.vm-avatar-lg  { width: 44px; height: 44px; font-size: 1rem;   }
.vm-avatar-xl  { width: 56px; height: 56px; font-size: 1.3rem; }

/* Preset gradient avatars */
.vm-avatar-blue   { background: linear-gradient(135deg, var(--vm-blue), var(--vm-cyan)); }
.vm-avatar-purple { background: linear-gradient(135deg, var(--vm-purple), var(--vm-blue)); }
.vm-avatar-green  { background: linear-gradient(135deg, var(--vm-success), var(--vm-cyan)); }
.vm-avatar-orange { background: linear-gradient(135deg, #f59e0b, #f97316); }
.vm-avatar-pink   { background: linear-gradient(135deg, #ec4899, var(--vm-purple)); }

/* Square avatar (org) */
.vm-avatar-sq { border-radius: var(--vm-radius); }


/* ═══════════════════════════════════════════════════
   22. COMPONENTS — EMPTY STATES
   ═══════════════════════════════════════════════════ */
.vm-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3.5rem 2rem;
  gap: .75rem;
}

.vm-empty-icon {
  font-size: 2.5rem;
  color: var(--vm-text4);
  margin-bottom: .5rem;
}

.vm-empty-title {
  font-family: var(--vm-font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--vm-text2);
}

.vm-empty-desc {
  font-size: .85rem;
  color: var(--vm-text3);
  max-width: 320px;
  line-height: 1.6;
}


/* ═══════════════════════════════════════════════════
   23. COMPONENTS — SKELETON LOADERS
   ═══════════════════════════════════════════════════ */
@keyframes vm-shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}

.vm-skeleton {
  background: linear-gradient(90deg,
    var(--vm-surface2) 25%,
    var(--vm-surface3) 50%,
    var(--vm-surface2) 75%
  );
  background-size: 200% 100%;
  animation: vm-shimmer 1.4s infinite;
  border-radius: var(--vm-radius-sm);
}

.vm-skeleton-text { height: .875rem; margin-bottom: .5rem; }
.vm-skeleton-title { height: 1.4rem; width: 60%; margin-bottom: .75rem; }
.vm-skeleton-circle { border-radius: 50%; }
.vm-skeleton-badge { height: 1.2rem; width: 80px; border-radius: 20px; }


/* ═══════════════════════════════════════════════════
   24. UTILITIES
   ═══════════════════════════════════════════════════ */

/* Colors */
.vm-c-blue   { color: var(--vm-blue); }
.vm-c-cyan   { color: var(--vm-cyan); }
.vm-c-purple { color: var(--vm-purple); }
.vm-c-green  { color: var(--vm-success); }
.vm-c-orange { color: var(--vm-warning); }
.vm-c-red    { color: var(--vm-danger); }
.vm-c-text   { color: var(--vm-text); }
.vm-c-muted  { color: var(--vm-text2); }
.vm-c-subtle { color: var(--vm-text3); }
.vm-c-white  { color: #fff; }

/* Background accents (icon backgrounds) */
.vm-bg-blue   { background: var(--vm-blue-dim);   color: var(--vm-blue); }
.vm-bg-cyan   { background: var(--vm-cyan-dim);   color: var(--vm-cyan); }
.vm-bg-purple { background: var(--vm-purple-dim); color: var(--vm-purple); }
.vm-bg-green  { background: var(--vm-success-dim);color: var(--vm-success); }
.vm-bg-orange { background: var(--vm-warning-dim);color: var(--vm-warning); }
.vm-bg-red    { background: var(--vm-danger-dim); color: var(--vm-danger); }

/* Divider */
.vm-divider {
  border: none;
  border-top: 1px solid var(--vm-border);
  margin: 1.25rem 0;
}

/* Monospace value display */
.vm-mono-val {
  font-family: var(--vm-font-mono);
  font-size: .82rem;
  color: var(--vm-cyan);
}

/* Truncate */
.vm-truncate {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Pulse animation (notifications) */
.vm-pulse {
  animation: vm-pulse 2s ease infinite;
}

/* Gradient text */
.vm-gradient-text {
  background: linear-gradient(135deg, var(--vm-blue), var(--vm-cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ═══════════════════════════════════════════════════
   25. ANIMATIONS
   ═══════════════════════════════════════════════════ */
@keyframes vm-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(59,130,246,.4); }
  70%  { box-shadow: 0 0 0 8px rgba(59,130,246,0); }
  100% { box-shadow: 0 0 0 0 rgba(59,130,246,0); }
}

@keyframes vm-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes vm-slide-in {
  from { opacity: 0; transform: translateX(-12px); }
  to   { opacity: 1; transform: translateX(0); }
}

.vm-fade-in {
  animation: vm-fade-in .25s ease both;
}

/* Stagger helper classes */
.vm-delay-1 { animation-delay: .05s; }
.vm-delay-2 { animation-delay: .10s; }
.vm-delay-3 { animation-delay: .15s; }
.vm-delay-4 { animation-delay: .20s; }


/* ═══════════════════════════════════════════════════
   26. SCROLLBAR
   ═══════════════════════════════════════════════════ */
::-webkit-scrollbar          { width: 5px; height: 5px; }
::-webkit-scrollbar-track    { background: transparent; }
::-webkit-scrollbar-thumb    { background: var(--vm-border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--vm-border3); }


/* ═══════════════════════════════════════════════════
   27. RESPONSIVE
   ═══════════════════════════════════════════════════ */
@media (max-width: 991.98px) {
  .vm-sidebar {
    transform: translateX(-100%);
    box-shadow: var(--vm-shadow-lg);
  }

  .vm-sidebar.open {
    transform: translateX(0);
  }

  .vm-sidebar-overlay.open {
    display: block;
  }

  .vm-main {
    margin-left: 0;
  }
}

@media (max-width: 767.98px) {
  .vm-content { padding: 1.25rem; }
  .vm-topbar  { padding: 0 1.25rem; }
  .vm-panel-head { padding: .875rem 1.25rem; }
  .vm-panel-body { padding: 1.25rem; }
  .vm-table th,
  .vm-table td { padding: .7rem 1rem; }
}

/* ═══════════════════════════════════════════════════
   28. CUSTOM DROPDOWNS (vm-dropdown-*)
   Replaces Bootstrap dropdowns for full control.
   Usage:
     <div class="vm-dropdown">
       <div class="vm-dropdown-toggle">...</div>
       <ul class="vm-dropdown-menu">
         <li><a class="vm-dropdown-item" href="#">...</a></li>
       </ul>
     </div>
   ═══════════════════════════════════════════════════ */
.vm-dropdown {
  position: relative;
  display: inline-flex;
}

.vm-dropdown-toggle {
  cursor: pointer;
  user-select: none;
}

.vm-dropdown-menu {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  background: var(--vm-surface2);
  border: 1px solid var(--vm-border2);
  border-radius: var(--vm-radius-lg);
  box-shadow: var(--vm-shadow-lg);
  padding: .4rem;
  z-index: 500;
  list-style: none;
  margin: 0;
  animation: vm-fade-in .15s ease both;
}

.vm-dropdown-menu.open {
  display: block;
}

/* Align right */
.vm-dropdown-menu.right { left: auto; right: 0; }

.vm-dropdown-item {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .5rem .75rem;
  border-radius: var(--vm-radius-sm);
  color: var(--vm-text2);
  text-decoration: none;
  font-size: .85rem;
  font-family: var(--vm-font-body);
  cursor: pointer;
  transition: var(--vm-transition);
  background: none;
  border: none;
  width: 100%;
  text-align: left;
}

.vm-dropdown-item:hover {
  background: var(--vm-surface3);
  color: var(--vm-text);
}

.vm-dropdown-item.danger { color: var(--vm-danger); }
.vm-dropdown-item.danger:hover { background: var(--vm-danger-dim); }

.vm-dropdown-item.active {
  background: var(--vm-blue-dim);
  color: var(--vm-blue);
}

.vm-dropdown-divider {
  border: none;
  border-top: 1px solid var(--vm-border);
  margin: .3rem 0;
}

.vm-dropdown-header {
  padding: .5rem .75rem .2rem;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--vm-text3);
}

/* Org item variant (with avatar + plan line) */
.vm-dropdown-org {
  padding: .6rem .75rem;
}

.vm-dropdown-org:hover {
  background: var(--vm-surface3);
}

/* Login page */
.vm-login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--vm-bg);
  padding: 2rem 1rem;
  position: relative;
  overflow: hidden;
}

.vm-login-wrap::before {
  content: '';
  position: absolute;
  top: -30%;
  left: 50%;
  transform: translateX(-50%);
  width: 900px;
  height: 600px;
  background: radial-gradient(ellipse at center, #1e3a8a20 0%, transparent 70%);
  pointer-events: none;
}

.vm-login-wrap::after {
  content: '';
  position: absolute;
  bottom: -20%;
  right: -10%;
  width: 600px;
  height: 600px;
  background: radial-gradient(ellipse at center, #8b5cf615 0%, transparent 70%);
  pointer-events: none;
}

.vm-login-box {
  width: 100%;
  max-width: 420px;
  position: relative;
  z-index: 1;
}

.vm-login-logo {
  text-align: center;
  margin-bottom: 2rem;
}

.vm-login-card {
  background: var(--vm-surface);
  border: 1px solid var(--vm-border);
  border-radius: var(--vm-radius-xl);
  padding: 2.5rem 2rem;
  box-shadow: 0 20px 60px #00000050;
}

.vm-login-title {
  font-family: var(--vm-font-display);
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: .35rem;
}

.vm-login-sub {
  font-size: .875rem;
  color: var(--vm-text2);
  margin-bottom: 2rem;
}

.vm-login-footer {
  text-align: center;
  margin-top: 1.25rem;
  font-size: .8rem;
  color: var(--vm-text3);
}

.vm-login-footer a { color: var(--vm-blue); text-decoration: none; }
.vm-login-footer a:hover { text-decoration: underline; }

.vm-password-toggle {
  position: relative;
}

.vm-password-toggle .vm-input {
  padding-right: 2.75rem;
}

.vm-password-toggle .vm-pw-btn {
  position: absolute;
  right: .75rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--vm-text3);
  cursor: pointer;
  font-size: 1rem;
  padding: 0;
  transition: color .15s;
}

.vm-password-toggle .vm-pw-btn:hover { color: var(--vm-text); }

/* Topbar notification dropdown */
.vm-notif-panel {
  min-width: 320px;
  max-height: 400px;
  overflow-y: auto;
}

.vm-notif-item {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  padding: .85rem .75rem;
  border-radius: var(--vm-radius-sm);
  cursor: pointer;
  transition: background .1s;
  text-decoration: none;
}

.vm-notif-item:hover { background: var(--vm-surface3); }

.vm-notif-dot-new {
  width: 7px; height: 7px;
  background: var(--vm-blue);
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
}

.vm-notif-title { font-size: .82rem; font-weight: 600; color: var(--vm-text); margin-bottom: .15rem; }
.vm-notif-meta  { font-size: .73rem; color: var(--vm-text2); }

/* Dropdown immer nach oben — nie dynamisch überschreiben */
.vm-dropdown-menu.vm-dropdown-up {
  top: auto !important;
  bottom: calc(100% + 6px) !important;
  margin-top: 0 !important;
  margin-bottom: 4px !important;
}

/* ── Notification Panel: Mobile fix ─────────────────────────
   Auf kleinen Screens am rechten Viewport-Rand ausrichten
   statt relativ zum Toggle-Button                           */
@media (max-width: 576px) {
  .vm-notif-panel {
    position: fixed !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    min-width: unset !important;
    max-width: unset !important;
    top: 56px !important;   /* unter der Topbar */
    bottom: auto !important;
  }
}

/* ═══════════════════════════════════════════════════
   PAGE SEARCH — Highlights & floating counter
   ═══════════════════════════════════════════════════ */

/* Treffer-Highlight */
mark.vm-hl {
  background: #f59e0b40;
  color: #fbbf24;
  border-radius: 2px;
  padding: 0 1px;
  font: inherit;
  transition: background .15s;
}

/* Aktiver (angesprungener) Treffer */
mark.vm-hl--active {
  background: #f59e0b;
  color: #000;
  border-radius: 3px;
  outline: 2px solid #fbbf24;
  outline-offset: 1px;
}

/* Floating counter */
.vm-search-counter {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 2px;
  background: #1b2535;
  border: 1px solid #2d4060;
  border-radius: 10px;
  padding: 6px 8px;
  box-shadow: 0 8px 32px #00000070;
  font-family: var(--vm-font-body);
  font-size: .8rem;
  transition: opacity .18s;
}

.vm-sc-label {
  color: #e2e8f0;
  min-width: 56px;
  text-align: center;
  font-weight: 600;
  padding: 0 6px;
}

.vm-sc-prev,
.vm-sc-next,
.vm-sc-close {
  background: none;
  border: none;
  color: #94a3b8;
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: grid;
  place-items: center;
  font-size: .85rem;
  transition: background .12s, color .12s;
}
.vm-sc-prev:hover,
.vm-sc-next:hover { background: #243447; color: #e2e8f0; }
.vm-sc-prev:disabled,
.vm-sc-next:disabled { opacity: .3; cursor: not-allowed; }
.vm-sc-close:hover { background: #3f1f1f; color: #ef4444; }

@media (max-width: 576px) {
  .vm-search-counter {
    bottom: 16px;
    right: 12px;
    left: 12px;
    justify-content: center;
  }
}

/* ═══════════════════════════════════════════════════
   SIDEBAR BRAND FOOTER
   ═══════════════════════════════════════════════════ */
.vm-sidebar-brand-footer {
  display: flex;
  align-items: center;
  gap: .45rem;
  padding: .7rem 1.1rem .85rem;
  border-top: 1px solid var(--vm-border);
  margin-top: auto;
  font-size: .68rem;
  color: var(--vm-text3);
  letter-spacing: .01em;
  line-height: 1;
}

.vm-bf-icon {
  flex-shrink: 0;
  border-radius: 4px;
  opacity: .85;
}

.vm-bf-heart {
  color: #ef4444;
  font-size: .72rem;
}

.vm-bf-link {
  color: var(--vm-blue);
  text-decoration: none;
  font-weight: 600;
  transition: color .15s;
}
.vm-bf-link:hover { color: var(--vm-cyan); }
