/* ServiceManager – Enterprise SaaS UI. Dark theme with custom color palette */

:root {
  /* Colors – dark theme palette */
  --color-bg: #2d3250;
  --color-bg-elevated: #424769;
  --color-border: #676f9d;
  --color-border-focus: #f9b17a;
  --color-text: #ffffff;
  --color-text-muted: #676f9d;
  --color-primary: #f9b17a;
  --color-primary-hover: #e8a066;
  --color-danger: #dc3545;
  --color-danger-hover: #bb2d3b;
  --color-success: #198754;
  --color-sidebar-bg: #1e293b;
  --color-sidebar-text: #e2e8f0;
  --color-sidebar-text-active: #ffffff;
  --color-sidebar-hover: rgba(255,255,255,0.1);
  --color-topbar-bg: #424769;
  --color-topbar-border: #676f9d;
  --color-table-header: #424769;
  /* Spacing – malo veće za disanje */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  /* Typography – veće za čitljivost */
  --font-sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --text-sm: 0.9375rem;
  --text-base: 1rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.75rem;
  /* Shape */
  --radius: 6px;
  --radius-sm: 4px;
  /* Shadow – malo izraženije granice */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.3);
  --shadow: 0 2px 6px rgba(0,0,0,0.4);
}

* { box-sizing: border-box; }

html { font-size: 16px; }
html, body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--color-text);
  background: var(--color-bg);
  height: 100%;
  -webkit-font-smoothing: antialiased;
}

a {
  color: var(--color-primary);
  text-decoration: none;
}
a:hover { text-decoration: underline; }

/* ---- Layout: app shell ---- */

.app-layout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  width: 100%;
}

.app-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.app-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  padding: 0 var(--space-6);
  background: var(--color-topbar-bg);
  border-bottom: 1px solid var(--color-topbar-border);
  flex-shrink: 0;
}

.app-topbar-brand {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-text);
}
.app-topbar-brand:hover { text-decoration: none; color: var(--color-text); }

.app-topbar-user {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--text-base);
  color: var(--color-text-muted);
}
.app-topbar-user a {
  color: var(--color-text);
  font-weight: 600;
}
.app-topbar-user a:hover { color: var(--color-primary); }

.app-nav {
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}

.app-nav-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1);
  padding: var(--space-2) var(--space-6);
}

.app-nav-link {
  display: inline-block;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-text);
  border-radius: var(--radius-sm);
}
.app-nav-link:hover {
  color: var(--color-primary);
  background: var(--color-bg);
  text-decoration: none;
}
.app-nav-link.active {
  color: var(--color-primary);
  background: rgba(249, 177, 122, 0.15);
  text-decoration: none;
}
.app-nav-icon { margin-right: var(--space-1); }

.app-content {
  flex: 1;
  padding: var(--space-6) var(--space-8);
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

/* ---- Page structure ---- */

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.page-title { margin: 0; font-size: var(--text-2xl); font-weight: 600; color: var(--color-text); letter-spacing: -0.02em; }

.page-actions { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }

.breadcrumb {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
  font-weight: 500;
}
.breadcrumb a { color: var(--color-text-muted); }
.breadcrumb a:hover { color: var(--color-primary); }

/* ---- Cards ---- */

.card {
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  margin-bottom: var(--space-6);
}
.card-header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  font-weight: 700;
  font-size: var(--text-lg);
  color: var(--color-text);
}
.card-header.card-header-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  font-weight: 500;
  font-size: var(--text-base);
}

.card-body { padding: var(--space-5) var(--space-6); }

/* ---- Forms ---- */

.form-card {
  max-width: 32rem;
  margin-bottom: var(--space-6);
}

.form-explanation {
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}

.form-advanced-toggle { padding-left: 0; font-size: var(--text-sm); color: var(--color-primary); }
.form-advanced { margin-bottom: var(--space-2); padding-left: var(--space-2); border-left: 2px solid var(--color-border); }

.form-group {
  margin-bottom: var(--space-4);
}
.form-label {
  display: block;
  font-weight: 600;
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
  color: var(--color-text);
}
.form-hint,
.loading { font-size: var(--text-base); color: var(--color-text-muted); margin-top: var(--space-1); }
.loading { font-weight: 500; color: var(--color-text); }

.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="date"],
select,
textarea {
  display: block;
  width: 100%;
  max-width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  font-family: inherit;
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-sm);
}
.form-control:focus,
input:focus, select:focus, textarea:focus {
  outline: 0;
  border-color: var(--color-border-focus);
  box-shadow: 0 0 0 3px rgba(249, 177, 122, 0.2);
}
.form-control::placeholder,
input::placeholder, textarea::placeholder { color: var(--color-text-muted); }
textarea { min-height: 80px; resize: vertical; }

.valid.modified:not([type="checkbox"]) { outline: 1px solid var(--color-success); }
.invalid { outline: 1px solid var(--color-danger); }
.validation-message { color: var(--color-danger); font-size: var(--text-sm); margin-top: var(--space-1); }
.validation-summary { color: var(--color-danger); margin-bottom: var(--space-4); font-size: var(--text-sm); }

.form-actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}

/* InputSelect / select when used inside EditForm need to match */
.InputSelect, .form-control select, .form-control select option { font-size: inherit; }

/* ---- Buttons ---- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-base);
  font-weight: 500;
  font-family: inherit;
  line-height: 1.5;
  text-align: center;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-decoration: none;
}
.btn:disabled { opacity: 0.65; cursor: not-allowed; }
.btn:hover:not(:disabled) { text-decoration: none; }

.btn-primary {
  color: #fff;
  background: var(--color-primary);
  border-color: var(--color-primary);
}
.btn-primary:hover:not(:disabled) { background: var(--color-primary-hover); border-color: var(--color-primary-hover); }

.btn-secondary {
  color: var(--color-text);
  background: var(--color-bg-elevated);
  border-color: var(--color-border);
}
.btn-secondary:hover:not(:disabled) { background: var(--color-border); }

.btn-danger {
  color: #fff;
  background: var(--color-danger);
  border-color: var(--color-danger);
}
.btn-danger:hover:not(:disabled) { background: var(--color-danger-hover); border-color: var(--color-danger-hover); }

.btn-text {
  background: none;
  border: none;
  color: var(--color-primary);
}
.btn-text:hover:not(:disabled) { text-decoration: underline; }

/* ---- Tables ---- */

.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-base);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.data-table th,
.data-table td {
  padding: var(--space-4) var(--space-5);
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}
.data-table th {
  background: var(--color-table-header);
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--color-text);
  text-transform: none;
  letter-spacing: 0.01em;
}
.data-table tbody tr:last-child td { border-bottom: none; }
.data-table tbody tr:hover { background: var(--color-bg); }
.data-table td { font-weight: 400; color: var(--color-text); }
.data-table .col-actions { white-space: nowrap; }
.data-table .col-actions .btn { margin-left: var(--space-2); font-size: var(--text-sm); }

/* Error event severity badges (System Errors admin UI) */
.error-event-severity {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 600;
}
.error-event-severity-error {
  background: rgba(220, 53, 69, 0.2);
  color: #f87171;
}
.error-event-severity-warning {
  background: rgba(245, 158, 11, 0.2);
  color: #fbbf24;
}

/* ---- Filter bar ---- */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
}
.filter-bar .form-control { max-width: 100%; }
.filter-bar input[type="text"] { min-width: 12rem; }

/* ---- Sortable column headers ---- */
.data-table th.sortable { cursor: pointer; user-select: none; }
.data-table th.sortable:hover { background: #676f9d; }
.data-table th .sort-icon { margin-left: var(--space-1); font-size: 0.75em; opacity: 0.8; }

/* ---- Alerts ---- */

.alert {
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius);
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
  font-weight: 500;
  line-height: 1.5;
}
.alert-error {
  background: rgba(220, 53, 69, 0.15);
  border: 1px solid rgba(220, 53, 69, 0.3);
  color: #ff6b7a;
}
.alert-info {
  background: rgba(249, 177, 122, 0.15);
  border: 1px solid rgba(249, 177, 122, 0.3);
  color: #f9b17a;
}

/* ---- Record status (evidencije) ---- */

/* Valid=neutral, ExpiringSoon=warning, Expired=critical */
.record-status {
  display: inline-block;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 500;
}
.record-status-valid { background: rgba(103, 111, 157, 0.2); color: #ffffff; }
.record-status-expiringsoon { background: rgba(249, 177, 122, 0.2); color: #f9b17a; }
.record-status-expired { background: rgba(220, 53, 69, 0.2); color: #ff6b7a; }

/* ---- Home: Records summary (read-only) ---- */

.home-records-summary { margin-top: var(--space-4); }
.home-records-summary-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.home-records-title { font-weight: 600; color: var(--color-text); }
.home-records-counts { display: inline-flex; align-items: center; gap: var(--space-2); }
.home-records-expiring { color: #f9b17a; }
.home-records-expired { color: #ff6b7a; }
.home-records-sep { color: var(--color-border); }
.home-records-allok { color: #ffffff; }
.home-records-link { color: var(--color-primary); white-space: nowrap; }

/* ---- Delete confirmation ---- */

.delete-confirm {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding: var(--space-5);
  background: rgba(220, 53, 69, 0.15);
  border: 1px solid rgba(220, 53, 69, 0.3);
  border-radius: var(--radius);
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
  font-weight: 500;
  color: #ff6b7a;
}

/* ---- Login: split — LEVO tekst, DESNO login. Desktop-first: podrazumevano dve kolone; mobil prekidač. ---- */

.app-login {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-6);
  background: var(--color-bg);
}

/* Podrazumevano (desktop): dve kolone, tekst levo, forma desno — grid-template-areas osigurava redosled. */
.app-login-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: "text form";
  gap: var(--space-8);
  width: 100%;
  max-width: 960px;
  min-height: 0;
}
.app-login-split-left {
  grid-area: text;
}
.app-login-split-right {
  grid-area: form;
}

/* LEVI kontejner — samo tekst (SERVISNIK i ostalo). */
.app-login-split-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-6) 0;
}
.app-login-landing-title {
  margin: 0 0 var(--space-3);
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--color-text);
}
.app-login-landing-subtitle {
  margin: 0 0 var(--space-4);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1.4;
}
.app-login-landing-body {
  margin: 0 0 var(--space-4);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.55;
}
.app-login-landing-features {
  margin: 0 0 var(--space-4);
  padding-left: var(--space-5);
  font-size: var(--text-base);
  color: var(--color-text-muted);
  line-height: 1.6;
}
.app-login-landing-features li {
  margin-bottom: var(--space-2);
}
.app-login-landing-closing {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  font-style: italic;
  line-height: 1.5;
}

/* DESNI kontejner — login forma. */
.app-login-split-right {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
}
.app-login-card {
  width: 100%;
  max-width: 400px;
  padding: var(--space-8);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.app-login-title { margin: 0 0 var(--space-6); font-size: var(--text-2xl); font-weight: 700; text-align: center; color: var(--color-text); }
.app-login .form-actions { border-top: none; padding-top: 0; margin-top: var(--space-4); }
.app-login-helper {
  margin: var(--space-4) 0 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
  line-height: 1.4;
}

/* Mobil: jedna kolona, forma gore (area form), tekst dole (area text). */
@media (max-width: 768px) {
  .app-login-split {
    grid-template-columns: 1fr;
    grid-template-areas: "form" "text";
    max-width: 400px;
  }
  .app-login-split-left {
    padding: 0 0 var(--space-4);
    text-align: center;
  }
  .app-login-landing-features {
    list-style-position: inside;
    padding-left: 0;
  }
}

/* ---- Blazor error UI ---- */

#blazor-error-ui {
  background: rgba(249, 177, 122, 0.2);
  border-top: 1px solid #f9b17a;
  bottom: 0;
  display: none;
  left: 0;
  padding: var(--space-3) var(--space-6);
  position: fixed;
  width: 100%;
  z-index: 1000;
  font-size: var(--text-sm);
  color: var(--color-text);
}
#blazor-error-ui .dismiss {
  cursor: pointer;
  position: absolute;
  right: var(--space-4);
  top: 50%;
  transform: translateY(-50%);
}

@media print {
  #blazor-error-ui { display: none !important; }
  
  /* Print styles - svetla tema za štampu */
  html, body {
    background: #ffffff !important;
    color: #212529 !important;
  }
  
  .app-topbar,
  .app-nav,
  .app-content {
    background: #ffffff !important;
    color: #212529 !important;
  }
  
  .card,
  .data-table,
  .form-card,
  .app-login-card {
    background: #ffffff !important;
    color: #212529 !important;
    border-color: #dee2e6 !important;
  }
  
  .card-header,
  .data-table th,
  .data-table td,
  .page-title,
  .form-label,
  .form-control,
  input,
  select,
  textarea {
    color: #212529 !important;
    background: #ffffff !important;
  }
  
  .data-table th {
    background: #e9ecef !important;
    color: #212529 !important;
  }
  
  .btn-primary {
    background: #0d6efd !important;
    color: #ffffff !important;
    border-color: #0d6efd !important;
  }
  
  .btn-secondary {
    background: #ffffff !important;
    color: #212529 !important;
    border-color: #dee2e6 !important;
  }
  
  .app-nav-link {
    color: #495057 !important;
  }
  
  .app-nav-link.active {
    color: #0d6efd !important;
    background: rgba(13, 110, 253, 0.08) !important;
  }
  
  .alert-error {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #991b1b !important;
  }
  
  .alert-info {
    background: #f0f9ff !important;
    border-color: #bae6fd !important;
    color: #0369a1 !important;
  }
  
  .record-status-valid {
    background: #f1f5f9 !important;
    color: #475569 !important;
  }
  
  .record-status-expiringsoon {
    background: #fef3c7 !important;
    color: #b45309 !important;
  }
  
  .record-status-expired {
    background: #fee2e2 !important;
    color: #b91c1c !important;
  }
  
  .delete-confirm {
    background: #fef2f2 !important;
    border-color: #fecaca !important;
    color: #991b1b !important;
  }
}

.blazor-error-boundary {
  background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHZpZXdCb3g9IjAgMCA1NiA0OSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTEzLjA5MzggMTMuMDkzOEg0Mi45MDYyVjM1LjkwNjJIMTMuMDkzOFYxMy4wOTM4WiIgZmlsbD0iI0Y1RjVGNSIvPgo8cGF0aCBkPSJNMTguNzE4OCAxOC43MTg4SDM3LjI4MTJWMTguNzE4OEgxOC43MTg4WiIgZmlsbD0iI0EzQTNBMyIvPgo8cGF0aCBkPSJNMTguNzE4OCAyNC4zNDM4SDM3LjI4MTJWMjQuMzQzOEgxOC43MTg4WiIgZmlsbD0iI0EzQTNBMyIvPgo8cGF0aCBkPSJNMTguNzE4OCAyOS45Njg4SDMwLjkwNjJWMjkuOTY4OEgxOC43MTg4WiIgZmlsbD0iI0EzQTNBMyIvPgo8cGF0aCBkPSJNNDIuOTA2MiAzNS45MDYyQzQyLjkwNjIgMzcuMDQzNyA0MS45NDM3IDM3Ljk5OTkgNDAuODEyNSAzNy45OTk5QzM5LjY4MTMgMzcuOTk5OSAzOC43MTg4IDM3LjA0MzcgMzguNzE4OCAzNS45MDYyQzM4LjcxODggMzQuNzc1IDM5LjY4MTMgMzMuODEyNSAzOC43MTg4IDMyLjg0MzhDMzguNzE4OCAzMS43MTI1IDM5LjY4MTMgMzAuNzUgNDAuODEyNSAzMC43NUM0MS45NDM3IDMwLjc1IDQyLjkwNjIgMzEuNzEyNSA0Mi45MDYyIDMyLjg0MzhDNDIuOTA2MiAzMy45NzUgNDEuOTQzNyAzNC45Mzc1IDQwLjgxMjUgMzQuOTM3NUMzOS42ODEzIDM0LjkzNzUgMzguNzE4OCAzNS44OTk5IDM4LjcxODggMzYuOTM3NUMzOC43MTg4IDM4LjA2ODcgMzkuNjgxMyAzOC45OTk5IDQwLjgxMjUgMzguOTk5OUM0MS45NDM3IDM4Ljk5OTkgNDIuOTA2MiAzOC4wNjg3IDQyLjkwNjIgMzYuOTM3NVoiIGZpbGw9IiNGRjU1MDAiLz4KPC9zdmc+) no-repeat 1rem/1.8rem, #b32121;
  padding: 1rem 1rem 1rem 3.7rem;
  color: white;
}
.blazor-error-boundary::after { content: "An error has occurred."; }

/* ---- Global Admin panel (SystemAdmin only) ---- */

.admin-global-layout {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background: var(--color-bg);
}

.admin-global-header {
  background: #2d3748;
  color: #fff;
  padding: var(--space-4) var(--space-6);
  border-bottom: 3px solid #c53030;
  flex-shrink: 0;
}

.admin-global-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-4);
}

.admin-global-title {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: 0.05em;
}

.admin-global-badge {
  display: inline-block;
  padding: var(--space-1) var(--space-3);
  background: #c53030;
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 700;
  border-radius: var(--radius-sm);
  letter-spacing: 0.05em;
}

.admin-global-nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  background: var(--color-bg-elevated);
  border-bottom: 1px solid var(--color-border);
}

.admin-global-nav a {
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  font-weight: 500;
}
.admin-global-nav a:hover { background: var(--color-bg); color: var(--color-primary); text-decoration: none; }
.admin-global-nav a.active { color: var(--color-primary); background: rgba(249, 177, 122, 0.15); }

.admin-global-content {
  flex: 1;
  padding: var(--space-6) var(--space-8);
  max-width: 1400px;
  width: 100%;
  margin: 0 auto;
}

.admin-global-header a.admin-global-user {
  color: #e2e8f0;
  font-weight: 500;
}
.admin-global-header a.admin-global-user:hover { color: #fff; text-decoration: none; }

/* ---- Impersonation banner (shown in MainLayout when SystemAdmin is impersonating) ---- */

.impersonation-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding: var(--space-3) var(--space-6);
  background: #c53030;
  color: #fff;
  font-size: var(--text-base);
  font-weight: 600;
}

.impersonation-banner a {
  color: #fff;
  text-decoration: underline;
}
.impersonation-banner a:hover { color: #feb2b2; }
