/* Sidebar + Page Shell Layout — Sneat Style */

/* Page wrapper */
.app-layout {
  display: flex;
  min-height: 100vh;
}

/* ============ PRE-PAINT: instant sidebar collapse (no flash) ============ */
/* html.sc is set synchronously in <head> before first paint */
html.sc .sidebar { width: var(--sidebar-collapsed, 80px); }
/* Pre-paint: match .sidebar.collapsed styles exactly to avoid layout jump */
html.sc .sidebar .nav-label { opacity: 0; pointer-events: none; }
html.sc .sidebar .nav-section { opacity: 0; pointer-events: none; height: 0; padding: 0; margin: 0; overflow: hidden; }
html.sc .sidebar .user-info { opacity: 0; pointer-events: none; }
html.sc .sidebar .logo-full { display: none; }
html.sc .sidebar .logo-icon { display: block; }
html.sc .sidebar .sidebar-edition { opacity: 0; height: 0; margin: 0; overflow: hidden; }
html.sc .sidebar .sidebar-user-chevron { display: none; }
/* Suppress transitions on page load — only animate on manual toggle */
html.sc .sidebar,
html.sc .sidebar *,
html.sc .main-content {
  transition: none !important;
}
html.sc .sidebar .sidebar-logo { padding: 12px 0 0; }
@media (min-width: 768px) { html.sc .main-content { margin-left: var(--sidebar-collapsed, 80px); } }

/* ============ SIDEBAR — White with primary accent ============ */
.sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--sidebar-width);
  background: var(--color-sidebar);
  color: var(--color-text-secondary);
  display: flex;
  flex-direction: column;
  z-index: 100;
  transition: width var(--transition-slow);
  overflow: visible;
  box-shadow: var(--shadow-sidebar);
  border-right: 0;
}

.sidebar-nav {
  overflow: hidden;
}

.sidebar-footer {
  overflow: visible;
}

.sidebar.collapsed {
  width: var(--sidebar-collapsed);
}

/* Logo area */
.sidebar-logo {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 32px 0;
  position: relative;
  transition: padding var(--transition-slow);
}

.sidebar-logo .logo-full {
  width: 90px;
  height: auto;
  flex-shrink: 0;
  transition: opacity var(--transition-slow), width var(--transition-slow);
}

.sidebar-logo .logo-icon {
  width: 44px;
  height: auto;
  flex-shrink: 0;
  display: none;
}

/* Edition label (Skole/Pro) — subtle text below logo */
.sidebar-edition {
  margin-top: 2px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  opacity: 0.45;
  transition: opacity var(--transition);
}

.sidebar.collapsed .sidebar-logo {
  padding: 12px 0 0;
}

.sidebar.collapsed .sidebar-logo .logo-full {
  display: none;
}

.sidebar.collapsed .sidebar-logo .logo-icon {
  display: block;
  margin: 0 auto;
}

.sidebar.collapsed .sidebar-edition {
  opacity: 0;
  height: 0;
  margin: 0;
  overflow: hidden;
}

/* Logo text hidden — logo image is sufficient */
.sidebar-logo .logo-text {
  display: none;
}

.sidebar-logo-link {
  display: contents;
}

/* Toggle button — Sneat purple circle with chevron + bg-ring */
.sidebar-toggle {
  position: absolute;
  top: 50%;
  right: -18px;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--color-primary);
  border: 7px solid var(--color-bg);
  color: #ffffff;
  transition: opacity var(--transition);
  opacity: 0;
  cursor: pointer;
  z-index: 101;
}

.sidebar-toggle svg {
  width: 16px;
  height: 16px;
}

.sidebar:hover .sidebar-toggle {
  opacity: 1;
}

.sidebar.collapsed .sidebar-toggle {
  right: -18px;
}

.sidebar.collapsed .sidebar-toggle svg {
  transform: rotate(180deg);
}

/* Navigation */
.sidebar-nav {
  flex: 1;
  padding: var(--space-4) var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  overflow-y: auto;
}

/* Sidebar section headers (Sneat style) */
.nav-section {
  font-size: var(--font-size-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--color-text-secondary);
  opacity: 0.6;
  padding: var(--space-4) var(--space-4) var(--space-1);
  margin-top: var(--space-2);
  white-space: nowrap;
  overflow: hidden;
  transition: opacity var(--transition);
}

.sidebar.collapsed .nav-section {
  opacity: 0;
  pointer-events: none;
  height: 0;
  padding: 0;
  margin: 0;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: 10px var(--space-4);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  white-space: nowrap;
  transition: background var(--transition-slow), color var(--transition-slow);
  position: relative;
  min-height: 44px;
  text-decoration: none;
  font-size: var(--font-size-base);
  font-weight: 500;
}

.nav-item:hover {
  background: var(--color-sidebar-hover);
  color: var(--color-primary);
}

.nav-item.active {
  background: var(--color-sidebar-active);
  color: var(--color-primary);
  border-radius: var(--radius-md);
}

/* Remove the left accent bar — Sneat uses tinted bg instead */
.nav-item.active::before {
  display: none;
}

.nav-item svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.nav-item .nav-label {
  opacity: 1;
  transition: opacity var(--transition);
}

.sidebar.collapsed .nav-label {
  opacity: 0;
  pointer-events: none;
}

/* Sidebar footer (user info) */
.sidebar-footer {
  padding: var(--space-4);
  border-top: 1px solid var(--color-border);
  flex-shrink: 0;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2);
  border-radius: var(--radius-md);
  transition: background var(--transition);
}

.sidebar-user:hover {
  background: var(--color-sidebar-hover);
}

.user-avatar {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: var(--font-size-sm);
  color: #ffffff;
  flex-shrink: 0;
}

.user-info {
  overflow: hidden;
  opacity: 1;
  transition: opacity var(--transition);
}

.sidebar.collapsed .user-info {
  opacity: 0;
  pointer-events: none;
}

.sidebar.collapsed .sidebar-user-chevron {
  display: none;
}

.sidebar-user-chevron {
  margin-left: auto;
  opacity: 0.5;
  flex-shrink: 0;
}

.user-name {
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-role {
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
}

.sidebar-logout {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-2) var(--space-4);
  margin-top: var(--space-2);
  border-radius: var(--radius-sm);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  transition: background var(--transition), color var(--transition);
}

.sidebar-logout:hover {
  background: var(--color-error-light);
  color: var(--color-error);
}

/* Sidebar user dropdown (replaces top navbar) */
.sidebar-user-wrap {
  position: relative;
}

.sidebar-user {
  cursor: pointer;
}

.sidebar-user .user-badge {
  position: absolute;
  top: 4px;
  left: 28px;
  width: 8px;
  height: 8px;
  background: var(--color-error);
  border-radius: var(--radius-full);
  border: 2px solid var(--color-sidebar);
}

.sidebar-user-dropdown {
  position: absolute;
  bottom: calc(100% + 8px);
  left: var(--space-2);
  right: var(--space-2);
  background: var(--color-card);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-popup);
  padding: var(--space-2);
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
  transition: opacity var(--transition), transform var(--transition);
  z-index: 200;
  min-width: 200px;
}

.sidebar-user-dropdown.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.sidebar-user-dropdown .dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-sm);
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: background var(--transition), color var(--transition);
  cursor: pointer;
  width: 100%;
  border: none;
  background: none;
  text-align: left;
}

.sidebar-user-dropdown .dropdown-item:hover {
  background: var(--color-sidebar-hover);
  color: var(--color-primary);
}

.sidebar-user-dropdown .dropdown-item.logout:hover {
  background: var(--color-error-light);
  color: var(--color-error);
}

.sidebar-user-dropdown .dropdown-item svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.sidebar-user-dropdown .dropdown-divider {
  height: 1px;
  background: var(--color-border);
  margin: var(--space-2) 0;
}

.sidebar-logout svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.sidebar.collapsed .sidebar-logout .nav-label {
  opacity: 0;
  pointer-events: none;
}

/* ============ MAIN CONTENT ============ */
.main-content {
  flex: 1;
  min-width: 0;
  margin-left: 0;
  padding: var(--space-8) 36px;
  transition: margin-left var(--transition-slow);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Desktop: sidebar offsets main content */
@media (min-width: 768px) {
  .main-content {
    margin-left: var(--sidebar-width);
  }
}

@media (min-width: 768px) {
  .sidebar.collapsed ~ .main-content,
  .app-layout.sidebar-collapsed .main-content {
    margin-left: var(--sidebar-collapsed);
  }
}

/* Editor open: no sidebar offset at any screen size */
body.apb-editor-mode .main-content { margin-left: 0 !important; }

.main-content > h1 {
  margin-bottom: var(--space-6);
}

.page-header {
  margin-bottom: var(--space-8);
}

.page-title {
  font-size: var(--font-size-2xl);
  font-weight: 700;
  color: var(--color-text-primary);
}

.page-subtitle {
  font-size: var(--font-size-base);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}

/* ============ MOBILE BOTTOM NAV ============ */
.mobile-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--color-card);
  border-top: 1px solid var(--color-border);
  box-shadow: var(--shadow-mobile-nav);
  z-index: 100;
  padding: var(--space-2) 0;
  padding-bottom: calc(var(--space-2) + env(safe-area-inset-bottom, 0px));
}

.mobile-nav-items {
  display: flex;
  justify-content: space-around;
  align-items: center;
}

.mobile-nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: var(--space-1) var(--space-2);
  color: var(--color-text-secondary);
  font-size: 10px;
  font-weight: 600;
  text-decoration: none;
  transition: color var(--transition);
}

.mobile-nav-item.active {
  color: var(--color-text, #384551);
}

.mobile-nav-item svg {
  width: 22px;
  height: 22px;
}

/* ── Redesigned icon system (outline/filled toggle) ── */
.mobile-nav-item .nav-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
}

.mobile-nav-item .nav-icon svg {
  width: 22px;
  height: 22px;
}

/* Show outline by default, filled when active */
.mobile-nav-item .icon-f { display: none; }
.mobile-nav-item .icon-o { display: block; }
.mobile-nav-item.active .icon-f { display: block; }
.mobile-nav-item.active .icon-o { display: none; }

/* Center "Skriv" button — elevated circle */
.mobile-nav-center .nav-center-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-text, #384551);
  color: #fff;
  margin-top: -10px;
  box-shadow: 0 2px 8px rgba(56, 69, 81, 0.25);
}

.mobile-nav-center .nav-center-btn svg {
  width: 20px;
  height: 20px;
}

.mobile-nav-center .nav-label {
  margin-top: 2px;
}

/* ── Scroll-hide bottom nav (voksen content pages) ── */
html.scroll-hide-nav .mobile-nav {
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

html.scroll-hide-nav .mobile-nav.nav-hidden {
  transform: translateY(100%);
  pointer-events: none;
}

/* Keep visible when any child has focus (keyboard a11y) */
html.scroll-hide-nav .mobile-nav:focus-within {
  transform: translateY(0) !important;
  pointer-events: auto !important;
}

/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  html.scroll-hide-nav .mobile-nav {
    transition: none;
  }
}

/* ============ RESPONSIVE ============ */

/* Tablet: sidebar collapses, click toggle to expand as overlay */
@media (max-width: 1279px) {
  .main-content {    margin-left: var(--sidebar-collapsed) !important;  }
  .sidebar {
    width: var(--sidebar-collapsed);
    transition: width 0.25s ease, box-shadow 0.25s ease;
  }
  .sidebar .nav-label,
  .sidebar .nav-section,
  .sidebar .user-info,
  .sidebar .sidebar-logout .nav-label,
  .sidebar .sidebar-edition,
  .sidebar .sidebar-user-chevron,
  .sidebar .nav-badge {
    opacity: 0;
    pointer-events: none;
    height: 0;
    overflow: hidden;
    margin: 0;
    padding: 0;
    transition: opacity 0.2s ease;
  }
  .sidebar .nav-group-items {
    display: none;
  }
  .sidebar .nav-group-arrow {
    display: none;
  }
  .sidebar .sidebar-logo {
    padding: 12px 0 0;
    justify-content: center;
  }
  .sidebar .sidebar-logo .logo-full {
    display: none;
  }
  .sidebar .sidebar-logo .logo-icon {
    display: block;
    width: 44px;
    margin: 0 auto;
  }
  .sidebar.sidebar-open .sidebar-toggle svg {
    transform: rotate(180deg);
  }
  /* Toggle open: expand as overlay over content */
  .sidebar.sidebar-open {
    width: var(--sidebar-width);
    z-index: 1100;
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12);
  }
  .sidebar.sidebar-open .nav-label,
  .sidebar.sidebar-open .nav-section,
  .sidebar.sidebar-open .user-info,
  .sidebar.sidebar-open .sidebar-logout .nav-label,
  .sidebar.sidebar-open .sidebar-edition,
  .sidebar.sidebar-open .sidebar-user-chevron,
  .sidebar.sidebar-open .nav-badge {
    opacity: 1;
    pointer-events: auto;
    height: auto;
    overflow: visible;
    margin: revert;
    padding: revert;
  }
  .sidebar.sidebar-open .nav-group-items {
    display: block;
  }
  .sidebar.sidebar-open .nav-group-arrow {
    display: block;
  }
  .sidebar.sidebar-open .sidebar-logo {
    padding: 12px 32px 0;
  }
  .sidebar.sidebar-open .sidebar-logo .logo-full {
    display: block;
    width: 90px;
  }
  .sidebar.sidebar-open .sidebar-logo .logo-icon {
    display: none;
  }
  /* Backdrop when sidebar is open on tablet */
  .sidebar-overlay.tablet-visible {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: 1099;
  }
}

/* Mobile: sidebar hidden, bottom nav */
@media (max-width: 767px) {
  .sidebar {
    transform: translateX(-100%);
    width: var(--sidebar-width);
  }
  .sidebar.mobile-open {
    transform: translateX(0);
  }
  .sidebar.mobile-open .nav-label,
  .sidebar.mobile-open .user-info,
  .sidebar.mobile-open .sidebar-logout .nav-label {
    opacity: 1;
    pointer-events: auto;
  }
  .main-content {
    margin-left: 0 !important;
    padding: var(--space-4);
    padding-bottom: 80px;
  }
  .mobile-nav {
    display: flex;
    justify-content: space-around;
    align-items: center;
  }
  .sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 99;
  }
  .sidebar.mobile-open ~ .sidebar-overlay {
    display: block;
  }
}

/* ── Mobile "Mere" Bottom Sheet ── */
.mobile-more-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 199;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, visibility 0s 0.25s;
}

.mobile-more-overlay.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.25s ease, visibility 0s 0s;
}

.mobile-more-sheet {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--color-card);
  border-radius: 16px 16px 0 0;
  z-index: 200;
  padding: 8px 16px 24px;
  padding-bottom: calc(24px + env(safe-area-inset-bottom, 0px));
  transform: translateY(100%);
  visibility: hidden;
  pointer-events: none;
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1), visibility 0s 0.3s;
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.1);
}

.mobile-more-sheet.open {
  transform: translateY(0);
  visibility: visible;
  pointer-events: auto;
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1), visibility 0s 0s;
}

.mobile-more-handle {
  width: 36px;
  height: 4px;
  background: var(--color-border);
  border-radius: 2px;
  margin: 0 auto 16px;
}

.mobile-more-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}

.mobile-more-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 12px 4px;
  border-radius: 12px;
  text-decoration: none;
  color: var(--color-text-primary);
  font-size: 11px;
  font-weight: 600;
  text-align: center;
  transition: background 0.15s ease;
  min-height: 48px;
}

.mobile-more-item:hover,
.mobile-more-item:active {
  background: var(--color-bg);
  color: var(--color-text-primary);
}

.mobile-more-item.active {
  color: var(--color-text-primary);
  font-weight: 700;
}

.mobile-more-item.active .mobile-more-icon {
  color: var(--color-text-primary);
}

.mobile-more-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-secondary);
  background: var(--color-bg, #f5f5f9);
  transition: color 0.15s ease, background 0.15s ease;
}

/* Suppress focus ring on bottom sheet items (touch targets) */
/* Suppress focus ring on mobile nav bar items (touch targets) */
.mobile-nav-item:focus-visible,
.mobile-nav-item:focus {
  outline: none;
}

.mobile-more-item:focus-visible,
.mobile-more-item:focus {
  outline: none;
}

/* Divider between tools and account section */
.mobile-more-divider {
  grid-column: 1 / -1;
  height: 1px;
  background: var(--color-border);
  margin: 4px 0;
}

/* Logout button reset */
.mobile-more-logout {
  border: none;
  background: none;
  cursor: pointer;
  font-family: inherit;
}

.mobile-more-logout .mobile-more-icon {
  color: var(--color-text-tertiary);
}

/* Hide on desktop */
@media (min-width: 768px) {
  .mobile-more-overlay,
  .mobile-more-sheet {
    display: none !important;
  }
}

/* ============================================================
   Sidebar font protection — prevents robot bundle CSS bleed
   High specificity to beat any bundle selectors
   ============================================================ */
.app-layout > .sidebar {
  font-family: 'Nunito Sans', system-ui, -apple-system, sans-serif !important;
}
.app-layout > .sidebar button,
.app-layout > .sidebar input,
.app-layout > .sidebar select {
  font-family: inherit !important;
}
.app-layout > .sidebar .nav-item {
  font-size: var(--font-size-base) !important;
  font-weight: 500 !important;
  color: var(--color-text-secondary) !important;
}
.app-layout > .sidebar .nav-item:hover {
  color: var(--color-primary) !important;
}
.app-layout > .sidebar .nav-item.active {
  color: var(--color-primary) !important;
}

/* ─── Sidebar nav badge (email unread count) ─── */
.nav-badge {
  display: none;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: var(--radius-pill);
  background: var(--color-primary);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Hide badge when sidebar is collapsed */
.sidebar.collapsed .nav-badge { display: none !important; }
html.sc .sidebar .nav-badge { display: none !important; }

/* ─── Version-conditional sidebar items ─── */
.v-skole-only { display: none !important; }
.v-voksen-only { display: none !important; }
.v-skole .v-skole-only { display: flex !important; }
.v-voksen .v-voksen-only { display: flex !important; }
.v-voksen .nav-group.v-voksen-only { display: block !important; }

/* ============ MULTI-LEVEL NAV (Sneat style) ============ */
.nav-group { position: relative; margin-bottom: 0; }
.nav-group-toggle { cursor: pointer; position: relative; }
.nav-group-toggle .nav-group-arrow {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  transition: transform var(--transition);
  opacity: 0.5;
}
.nav-group.open .nav-group-toggle .nav-group-arrow { transform: translateY(-50%) rotate(180deg); }

.nav-group-items {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.25s ease;
}
.nav-group.open .nav-group-items { max-height: 200px; padding-bottom: 0; }

.nav-subitem {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 16px 8px 46px;
  min-height: 44px;
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: var(--font-size-sm);
  font-weight: 500;
  font-family: var(--font-family);
  transition: color var(--transition), background var(--transition);
  border-radius: var(--radius-md);
  margin: 2px 12px;
}
.nav-subitem:hover {
  color: var(--color-text-primary);
  background: var(--color-sidebar-hover);
}
.nav-subitem.active {
  color: var(--color-primary);
}
.nav-subitem-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-text-secondary);
  opacity: 0.4;
  flex-shrink: 0;
}
.nav-subitem.active .nav-subitem-dot {
  background: var(--color-primary);
  opacity: 1;
}

/* Collapsed sidebar: hide sub-items and arrow */
.sidebar.collapsed .nav-group-items { display: none; }
.sidebar.collapsed .nav-group-arrow { display: none; }
.sidebar.collapsed .nav-group-toggle { cursor: pointer; }
html.sc .sidebar .nav-group-items { display: none; }
html.sc .sidebar .nav-group-arrow { display: none; }
html.sc .sidebar .nav-group-toggle { cursor: pointer; }
