@import url('./tokens.css');

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

html {
  font-size: 16px;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: var(--font-family-base);
  background: var(--color-bg);
  color: var(--color-text);
  letter-spacing: var(--letter-spacing-tight);
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
}

body.sidebar-scroll-locked {
  overflow: hidden;
}

/* ========================================
   CUSTOM SCROLLBAR (iOS-inspired)
   ======================================== */

/* Webkit browsers (Chrome, Safari, Edge) */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: var(--radius-pill);
}

/* Sidebar-specific scrollbar (darker theme) */
.app-sidebar::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
}

/* Notification view scrollbar */
.notification-view-v2::-webkit-scrollbar-thumb,
.notification-view-list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}

.app-sidebar {
  scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}

.notification-view-v2,
.notification-view-list {
  scrollbar-color: rgba(255, 255, 255, 0.15) transparent;
}


img {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  font-family: inherit;
  border: none;
  background: none;
  cursor: pointer;
}

.app-shell {
  display: grid;
  grid-template-columns: 240px 1fr;
  min-height: 100vh;
  background: var(--color-bg);
  position: relative;
}

.app-sidebar-toggle {
  display: none;
  align-items: center;
  gap: var(--space-2);
  padding: 0;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
}

.app-sidebar-toggle i {
  color: inherit;
}

.app-sidebar-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 900;
  display: none;
}

.app-sidebar {
  background: #171820;
  border-right: 1px solid rgba(255, 255, 255, 0.08);
  padding: 0; /* Removed padding - individual elements have their own padding */
  display: flex;
  flex-direction: column;
  gap: 0; /* Gap handled by individual element padding */
  color: #f5f5f7;
  height: 100vh;
  max-height: 100vh;
  position: sticky;
  top: 0;
  transition: width var(--transition-medium);
  overflow-y: auto;
  overflow-x: hidden;
  scroll-behavior: auto;
  z-index: 200;
  /* ✅ FIXED: Prevent sidebar from stretching beyond viewport */
}

/* ✅ FIXED: When notification view is active, sidebar should scroll independently like normal sidebar */
.app-sidebar.notification-view-active {
  overflow-y: auto;
  overflow-x: hidden;
  /* Same scroll behavior as normal sidebar */
}

.app-sidebar__brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  position: relative;
  /* Samme padding som nav-buttons for konsistens */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  flex-shrink: 0;
  overflow: hidden;
}

.app-sidebar__brand-content {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  /* Fjernet gap - bruker margin-left på tekst i stedet for å unngå offset når collapsed */
  gap: 0;
  flex: 1;
  min-width: 0;
  /* Konsistent i alle tilstander for å unngå layout-shift */
  position: relative;
  /* GPU-akselerering for jevnere animasjon */
  transform: translateZ(0);
}

.app-sidebar__brand-logo {
  max-width: 28px;
  max-height: 28px;
  width: auto;
  height: auto;
  object-fit: contain;
  flex-shrink: 0;
}

.app-sidebar__brand-text {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--color-text-inverse);
  white-space: nowrap;
  opacity: 1;
  transition: opacity var(--transition-medium), transform var(--transition-medium), max-width var(--transition-medium), margin-left var(--transition-medium);
  transform: translateX(0);
  max-width: 200px;
  overflow: hidden;
  /* Mellomrom mellom logo og tekst - erstatter gap på parent */
  margin-left: var(--space-3);
}

.app-sidebar__nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: 0 var(--space-3);
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
}

.app-sidebar__nav-button {
  /* Fast padding-left (14px) sentrerer 20px ikon i 48px bred collapsed nav */
  /* (72px sidebar - 24px sidebar-padding = 48px) → (48px - 20px) / 2 = 14px */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  color: rgba(255, 255, 255, 0.7);
  background: transparent;
  transition: background var(--transition-medium), color var(--transition-medium);
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  text-align: left;
  /* Fast høyde for å forhindre hopping ved expand/collapse */
  min-height: 36px;
  box-sizing: border-box;
  text-decoration: none; /* Ensure no underline for anchors */
  border: none; /* Reset border for buttons/anchors */
  cursor: pointer;
}

.app-sidebar__nav-button-content {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  /* Fjernet gap - bruker margin-left på label i stedet for å unngå offset når collapsed */
  gap: 0;
  flex: 1;
  min-width: 0;
  /* Fast høyde for å forhindre hopping når label vises/skjules */
  min-height: 20px;
  /* Konsistent i alle tilstander for å unngå layout-shift */
  position: relative;
  /* GPU-akselerering for jevnere animasjon */
  transform: translateZ(0);
}

.app-sidebar__nav-button i {
  flex-shrink: 0;
  width: 20px;
  text-align: center;
  font-size: 1rem;
  /* Forhindrer sub-pixel rendering endringer under animasjon */
  transform: translateZ(0);
  backface-visibility: hidden;
}

.app-sidebar__nav-button:hover:not([data-active="true"]) {
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 255, 255, 0.9);
}

.app-sidebar__nav-label {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  opacity: 1;
  transition: opacity var(--transition-medium), transform var(--transition-medium), max-width var(--transition-medium), margin-left var(--transition-medium);
  transform: translateX(0);
  max-width: 200px;
  overflow: hidden;
  /* Mellomrom mellom ikon og tekst - erstatter gap på parent */
  margin-left: var(--space-3);
}

.app-sidebar__nav-button[data-active="true"] {
  background: var(--color-primary, #741C47);
  color: #ffffff;
}

.app-sidebar__nav-button[data-active="true"]:hover {
  background: rgba(116, 28, 71, 0.9);
}

.app-sidebar__footer {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-3) var(--space-3);
  flex-shrink: 0;
  overflow: hidden;
}

.notification-bell-btn,
.sidebar-logout-btn {
  width: 100%;
  border: none;
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-4);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  white-space: nowrap;
  font-size: var(--font-size-sm);
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
  cursor: pointer;
  transition: background var(--transition-medium), color var(--transition-medium);
  position: relative;
}

.notification-bell-icon-wrapper {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}

.notification-bell-btn.has-notifications {
  color: #ffffff;
}

.notification-bell-btn:hover {
  background: rgba(255, 255, 255, 0.16);
  color: #ffffff;
}

.notification-bell-btn.has-notifications:hover {
  background: rgba(116, 28, 71, 0.25);
}

.notification-badge {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  display: none; /* Hidden by default, shown via JavaScript when count > 0 */
  align-items: center !important;
  justify-content: center !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 4px !important;
  background: #e74c3c !important;
  color: white !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  border-radius: 9px !important;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) !important;
  z-index: 10 !important;
  box-sizing: border-box !important;
  direction: ltr !important;
}

.notification-badge.single-digit {
  width: 18px;
  padding: 0;
  min-width: 18px;
  border-radius: 50%;
}

.notification-badge.multi-digit {
  width: auto;
  min-width: 18px;
  padding: 0 4px;
  border-radius: 9px;
}

.sidebar-collapse-btn {
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  padding: var(--space-1);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-sm);
  transition: color var(--transition-medium), transform var(--transition-medium);
  flex-shrink: 0;
}

.sidebar-collapse-btn:hover {
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.08);
}

.sidebar-collapse-btn i {
  font-size: 0.875rem;
  transition: transform var(--transition-medium);
}

.app-shell[data-sidebar-collapsed="true"] .sidebar-collapse-btn i,
.app-shell[data-sidebar-mode="collapsed"] .sidebar-collapse-btn i {
  transform: rotate(180deg);
}

.notification-bell-btn i,
.sidebar-logout-btn i {
  width: 20px;
  text-align: center;
}

.sidebar-logout-btn {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fda4af;
  position: relative;
  overflow: hidden;
}

/* Logout tekst - samme stil som nav-label for konsistent animasjon */
.sidebar-logout-btn span {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  opacity: 1;
  transition: opacity var(--transition-medium), transform var(--transition-medium), max-width var(--transition-medium), width var(--transition-medium);
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: hidden;
}

.sidebar-logout-btn:hover {
  background: #dc2626;
  border-color: #dc2626;
  color: #ffffff;
}

.sidebar-logout-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.app-main {
  padding: var(--space-8);
  background: var(--color-bg);
}

.app-main__header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.app-main__headline {
  font-size: var(--font-size-display);
  font-weight: 600;
  margin: 0;
}

.pill-button {
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-pill);
  background: var(--color-text);
  color: var(--color-text-inverse);
  font-size: var(--font-size-sm);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  transition: transform var(--transition-fast);
}

.pill-button:active {
  transform: translateY(1px) scale(0.99);
}

/* Collapsed sidebar (icon rail) */
.app-shell[data-sidebar-mode="collapsed"] {
  grid-template-columns: 72px 1fr;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar {
  width: 72px;
  align-items: stretch;
  z-index: 200;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__brand {
  /* Samme layout som åpen - logoen forblir på plass */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: space-between;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__nav {
  padding: 0 var(--space-3);
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__footer {
  padding: var(--space-4) var(--space-3) var(--space-3);
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__brand,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__footer {
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__brand {
  position: relative;
}

.app-shell[data-sidebar-mode="collapsed"] .sidebar-collapse-btn {
  display: none;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .sidebar-collapse-btn,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .sidebar-collapse-btn {
  display: flex;
}

/* Logo size is now fixed at 43px - no change needed for collapsed state */

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__brand-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__brand-text {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  width: 0;
  overflow: hidden;
  pointer-events: none;
  margin-left: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__brand-content,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__brand-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__brand-text,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
  margin-left: var(--space-3);
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__nav {
  gap: var(--space-2);
  align-items: stretch;
  width: 100%;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__nav-button {
  /* Samme layout som åpen - ikonet forblir på plass */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: flex-start;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__nav-button-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar__nav-label {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  overflow: hidden;
  pointer-events: none;
  margin-left: 0;
}


.app-shell[data-sidebar-mode="collapsed"] .sidebar-logout-btn span {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  width: 0;
  overflow: hidden;
  pointer-events: none;
}

.app-shell[data-sidebar-mode="collapsed"] .sidebar-logout-btn {
  justify-content: center;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within {
  width: 240px;
  z-index: 950;
  align-items: stretch;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__brand,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__brand {
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: space-between;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__nav,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__nav {
  padding: 0 var(--space-3);
}

/* Forhindre padding-endring når notifications er åpen */
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-notifications-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-notifications-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-company-selector-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-company-selector-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__footer,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__footer {
  padding: var(--space-4) var(--space-3) var(--space-3);
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__brand,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__brand,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__footer,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__footer {
  justify-content: space-between;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__brand-text,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  position: static;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__nav-button,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__nav-button {
  /* Tilbake til normal layout når hover/expanded */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: flex-start;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__nav-button-content,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__nav-button-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__nav-label,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__nav-label {
  position: static;
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  overflow: visible;
  pointer-events: auto;
  margin-left: var(--space-3);
}


/* Logo size is now fixed at 43px - no hover size change */

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .app-sidebar__nav,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .app-sidebar__nav {
  align-items: stretch;
}

.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:hover .sidebar-logout-btn span,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar:focus-within .sidebar-logout-btn span {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

/* Manual collapsed state (via toggle button) */
.app-shell[data-sidebar-collapsed="true"] {
  grid-template-columns: 72px 1fr;
}

/* Prevent sidebar collapse when notifications are open */
/* ✅ FIXED: Always show full width (240px) when notifications are open, regardless of collapsed state or screen size */
.app-sidebar[data-notifications-open="true"],
.app-sidebar.notification-view-active {
  width: 240px !important;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-collapsed="true"] .app-sidebar.notification-view-active {
  width: 240px !important;
}

/* ✅ FIXED: Override collapsed mode when notifications are open */
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar.notification-view-active {
  width: 240px !important;
}

.app-shell[data-sidebar-mode="collapsed"][data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-mode="collapsed"][data-sidebar-collapsed="true"] .app-sidebar.notification-view-active {
  width: 240px !important;
}

/* ✅ FIXED: When notifications are open in collapsed state, overlay content like hover does */
/* Don't change grid-template-columns - use position and z-index instead */
.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-collapsed="true"] .app-sidebar.notification-view-active,
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-mode="collapsed"] .app-sidebar.notification-view-active,
.app-shell[data-sidebar-mode="collapsed"][data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"],
.app-shell[data-sidebar-mode="collapsed"][data-sidebar-collapsed="true"] .app-sidebar.notification-view-active {
  position: relative;
  z-index: 950 !important; /* Same z-index as hover state */
  /* Don't change grid-template-columns - let it overlay like hover */
}

/* Company Selector: Prevent collapse when open (same as notifications) */
.app-sidebar[data-company-selector-open="true"] {
  width: 240px !important;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-company-selector-open="true"] {
  width: 240px !important;
}

/* V2 Notification View Styles */
.app-sidebar.notification-view-active .app-sidebar__nav.notification-view-active {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0;
  gap: 0;
  /* ✅ FIXED: Same scroll behavior as normal sidebar - independent scrolling */
  min-height: 0;
}

/* V2 Company Selector View Styles (same as notification view) */
.app-sidebar.company-selector-view-active .app-sidebar__nav.company-selector-view-active {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  padding: 0;
  gap: 0;
}

.notification-view-v2 {
  display: flex;
  flex-direction: column;
  height: 100%;
  max-height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  color: #f5f5f7;
  width: 100%;
  padding: 0;
  /* Scrollbar goes to edge - no padding on container */
  /* ✅ FIXED: Ensure scrolling works by limiting height */
  min-height: 0;
}

.notification-view-list {
  padding: var(--space-2) 0;
}

.notification-view-item {
  margin: var(--space-1) 0;
  padding: var(--space-3) 0;
  width: 100%;
  /* Padding removed - handled by parent .notification-view-list */
}

.notification-view-header {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0 var(--space-3);
  flex-shrink: 0;
  border: none;
}

.notification-view-title {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: 0 auto;
}

.notification-view-title i {
  color: #ffffff;
  font-size: 1.25rem;
}

.notification-view-title h2 {
  margin: 0;
  font-size: var(--font-size-lg);
  font-weight: 600;
  color: #ffffff;
}

.notification-count-badge {
  background: #e74c3c;
  color: white;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
}

.notification-close-btn {
  background: transparent;
  border: none;
  color: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  transition: color var(--transition-medium), background var(--transition-medium);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
}

.notification-close-btn:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
}

.notification-view-list {
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1 1 auto;
  min-height: 0;
  max-height: 100%;
  padding: var(--space-2) var(--space-3);
  width: 100%;
  /* Padding on sides only - scrollbar goes to edge */
  /* ✅ FIXED: Ensure scrolling works by limiting height and using flex */
}

.notification-view-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-10) var(--space-4);
  text-align: center;
}

.notification-view-empty i {
  font-size: 3rem;
  color: rgba(255, 255, 255, 0.5);
  margin-bottom: var(--space-4);
}

.notification-view-empty p {
  margin: 0 0 var(--space-2);
  color: #ffffff;
  font-size: var(--font-size-md);
  font-weight: 600;
}

.notification-view-empty .text-secondary {
  color: rgba(255, 255, 255, 0.7);
  font-size: var(--font-size-sm);
}

.notification-view-item {
  padding: var(--space-3) var(--space-2) var(--space-2) var(--space-2);
  margin: var(--space-1) 0;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition-medium), border-color var(--transition-medium);
  width: 100%;
}

.notification-view-item:hover {
  background: rgba(116, 28, 71, 0.08);
  border-color: rgba(116, 28, 71, 0.3);
}

/* Uleste kort - Matcher iOS app (#301c27 bakgrunn, #741C47 border) */
.notification-view-item.unread {
  background: #301c27 !important; /* Mørk lilla bakgrunn - matcher iOS */
  border-color: #741C47 !important; /* Lilla border - matcher iOS */
}

.notification-view-item.unread:hover {
  background: #3a2330 !important; /* Litt lysere på hover */
  border-color: #741C47 !important;
}

/* Leste kort - Gjennomsiktig bakgrunn med tynn grå border */
.notification-view-item:not(.unread) {
  background: transparent !important; /* Gjennomsiktig bakgrunn */
  border: 0.5px solid #c4c4c4 !important; /* Tynn grå border */
}

.notification-view-item:not(.unread):hover {
  background: transparent !important;
  border-color: #c4c4c4 !important;
}

/* Leste kort - Grå tekstfarger */
.notification-view-item:not(.unread) .notification-view-content .notification-view-title,
.notification-view-item:not(.unread) .notification-view-message,
.notification-view-item:not(.unread) .notification-view-footer .time,
.notification-view-item:not(.unread) .notification-mark-read-btn,
.notification-view-item:not(.unread) .notification-mark-read-btn i {
  color: #c4c4c4 !important; /* Gråfarge */
}

.notification-view-content {
  width: 100%;
}

.notification-view-content .notification-view-title {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: #ffffff;
  margin-bottom: var(--space-1);
}

.notification-view-message {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: 0;
  line-height: 1.4;
}

.notification-view-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-top: 0;
}

.notification-view-meta {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.notification-view-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  padding: 0;
}

.notification-view-footer .time {
  font-size: var(--font-size-xs);
  color: rgba(255, 255, 255, 0.6);
}

.notification-mark-read-btn {
  padding: 0;
  background: transparent;
  border: none;
  color: rgba(255, 255, 255, 0.5);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-sm);
  transition: color var(--transition-medium), transform var(--transition-medium);
  flex-shrink: 0;
}

.notification-mark-read-btn:hover {
  color: rgba(255, 255, 255, 0.8);
  transform: scale(1.1);
}

.notification-mark-read-btn.is-read {
  color: rgba(255, 255, 255, 0.6);
}

.notification-mark-read-btn.is-read:hover {
  color: rgba(255, 255, 255, 0.8);
}

/* Leste kort - Grå mark as read knapp */
.notification-view-item:not(.unread) .notification-mark-read-btn.is-read,
.notification-view-item:not(.unread) .notification-mark-read-btn.is-read i {
  color: #c4c4c4 !important; /* Gråfarge */
}

.notification-mark-read-btn i {
  font-size: 0.875rem;
}

.notification-section-header {
  padding: var(--space-3) var(--space-4) var(--space-2);
  font-size: var(--font-size-xs);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* This is for the "Mark all as read" button container (not inside footer) */
.notification-view-v2 > .notification-view-actions {
  padding: var(--space-2) var(--space-3);
  flex-shrink: 0;
  border: none;
}

.btn-mark-all-read {
  width: 100%;
  background: #301c27; /* Mørk lilla bakgrunn - matcher uleste kort */
  border: 1px solid #741C47; /* Lilla border - matcher uleste kort */
  color: #ffffff;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  cursor: pointer;
  transition: background var(--transition-medium), border-color var(--transition-medium);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
}

.btn-mark-all-read--has-unread {
  background: #301c27; /* Mørk lilla bakgrunn - matcher uleste kort */
  border-color: #741C47; /* Lilla border - matcher uleste kort */
  color: #ffffff;
}

.btn-mark-all-read--has-unread:hover {
  background: #3a2330; /* Litt lysere på hover - matcher uleste kort hover */
  border-color: #741C47;
}

.btn-mark-all-read:hover {
  background: #3a2330; /* Litt lysere på hover - matcher uleste kort hover */
  border-color: #741C47;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar {
  width: 72px;
  align-items: stretch;
  transition: width var(--transition-medium);
  z-index: 200;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__brand {
  /* Samme layout som åpen - logoen forblir på plass */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: space-between;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__nav {
  padding: 0 var(--space-3);
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__footer {
  padding: var(--space-4) var(--space-3) var(--space-3);
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__brand,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar__footer {
  width: 100%;
  display: flex;
  justify-content: flex-start;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__brand {
  position: relative;
}

.app-shell[data-sidebar-collapsed="true"] .sidebar-collapse-btn {
  display: none;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .sidebar-collapse-btn,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .sidebar-collapse-btn {
  display: flex;
}

/* Logo size is now fixed at 43px - no change needed for collapsed state */

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__brand-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__brand-text {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  width: 0;
  overflow: hidden;
  pointer-events: none;
  margin-left: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand-content,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand-text,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__nav {
  gap: var(--space-2);
  align-items: stretch;
  width: 100%;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__nav-button {
  /* Samme layout som åpen - ikonet forblir på plass */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: flex-start;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__nav-button-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar__nav-label {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  overflow: hidden;
  pointer-events: none;
  margin-left: 0;
}

.app-shell[data-sidebar-collapsed="true"] .sidebar-logout-btn span {
  opacity: 0;
  transform: translateX(-10px);
  max-width: 0;
  width: 0;
  overflow: hidden;
  pointer-events: none;
}

.app-shell[data-sidebar-collapsed="true"] .sidebar-logout-btn {
  justify-content: center;
}

/* Hover to expand when collapsed (all screen sizes) - but not if locked */
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:hover,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:focus-within {
  width: 240px;
  z-index: 950;
  align-items: stretch;
}

.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:hover .app-sidebar__brand,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:focus-within .app-sidebar__brand {
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: space-between;
}

.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:focus-within .app-sidebar__nav {
  padding: 0 var(--space-3);
}

/* Forhindre padding-endring når notifications er åpen */
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar[data-notifications-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar[data-notifications-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar[data-company-selector-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar[data-company-selector-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:hover .app-sidebar__footer,
.app-shell[data-sidebar-collapsed="true"]:not([data-sidebar-locked="true"]) .app-sidebar:focus-within .app-sidebar__footer {
  padding: var(--space-4) var(--space-3) var(--space-3);
}

/* When locked in expanded state, always show expanded width */
.app-shell[data-sidebar-locked="true"]:not([data-sidebar-collapsed="true"]) .app-sidebar {
  width: 240px;
  align-items: stretch;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand {
  justify-content: space-between;
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__nav {
  padding: 0 var(--space-3);
}

/* Forhindre padding-endring når notifications er åpen */
.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-notifications-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-company-selector-open="true"]:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar[data-company-selector-open="true"]:focus-within .app-sidebar__nav {
  padding: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__footer,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__footer {
  padding: var(--space-4) var(--space-3) var(--space-3);
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand-content,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand-text,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__brand-text,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__footer,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__footer {
  justify-content: flex-start;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__nav-button,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__nav-button {
  /* Tilbake til normal layout når hover/expanded */
  padding: var(--space-2) var(--space-2) var(--space-2) 14px;
  justify-content: flex-start;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__nav-button-content,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__nav-button-content {
  justify-content: flex-start;
  gap: 0;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__nav-label,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__nav-label {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  overflow: visible;
  pointer-events: auto;
  margin-left: var(--space-3);
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .app-sidebar__nav,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .app-sidebar__nav {
  align-items: stretch;
}

.app-shell[data-sidebar-collapsed="true"] .app-sidebar:hover .sidebar-logout-btn span,
.app-shell[data-sidebar-collapsed="true"] .app-sidebar:focus-within .sidebar-logout-btn span {
  opacity: 1;
  transform: translateX(0);
  max-width: 200px;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

/* On small screens, JavaScript will set data-sidebar-collapsed="true" or data-sidebar-mode="collapsed" */
/* The normal collapsed menu styling (above) will handle it - no special media query needed */

.app-shell[data-sidebar-mode="mobile"] {
  grid-template-columns: 1fr;
}

.app-shell[data-sidebar-mode="mobile"] .app-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: min(320px, 85vw);
  max-width: 320px;
  transform: translateX(-100%);
  transition: transform 0.3s ease;
  height: 100vh;
  z-index: 1000;
  padding: var(--space-5);
  overflow-y: auto;
}

.app-shell[data-sidebar-mode="mobile"][data-sidebar-open="true"] .app-sidebar {
  transform: translateX(0);
}

.app-shell[data-sidebar-mode="mobile"] .app-sidebar-backdrop {
  display: block;
  opacity: 0;
  pointer-events: none;
}

.app-shell[data-sidebar-mode="mobile"][data-sidebar-open="true"] .app-sidebar-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.app-shell[data-sidebar-mode="mobile"][data-sidebar-open="false"] .app-sidebar__brand-text {
  opacity: 0;
  transform: translateX(-10px);
  width: 0;
  overflow: hidden;
}

.app-shell[data-sidebar-mode="mobile"][data-sidebar-open="true"] .app-sidebar__brand-text {
  opacity: 1;
  transform: translateX(0);
  position: static;
  width: auto;
  overflow: visible;
  pointer-events: auto;
}

.app-shell[data-sidebar-mode="mobile"] .app-sidebar-toggle {
  display: inline-flex;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-pill);
  background: rgba(23, 24, 32, 0.08);
  color: var(--color-text);
  font-size: var(--font-size-sm);
  font-weight: 600;
  transition: background var(--transition-medium), color var(--transition-medium);
}

.app-shell[data-sidebar-mode="mobile"] .app-sidebar-toggle:hover,
.app-shell[data-sidebar-mode="mobile"] .app-sidebar-toggle:focus-visible {
  background: rgba(23, 24, 32, 0.14);
  outline: none;
}

.app-shell[data-sidebar-mode="mobile"] .app-main__header {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-3);
}

/* Hide collapse button on mobile */
.app-shell[data-sidebar-mode="mobile"] .sidebar-collapse-btn {
  display: none;
}

@media (max-width: 900px) {
  .app-main {
    padding: var(--space-6);
  }
}

@media (max-width: 640px) {
  .app-main {
    padding: var(--space-4);
  }
}

