/* stage-32-sidebar-polish */

:root {
  --sidebar-polish-width: var(--focus-sidebar-expanded, 280px);
  --sidebar-polish-collapsed: var(--focus-sidebar-collapsed, 72px);
}

@media (min-width: 761px) {
  .app-shell {
    grid-template-columns: var(--sidebar-polish-width) minmax(0, 1fr) minmax(280px, 360px);
  }

  .app-shell.sidebar-collapsed {
    grid-template-columns: var(--sidebar-polish-collapsed) minmax(0, 1fr) minmax(280px, 360px);
  }

  .sidebar {
    position: sticky;
    top: clamp(0.85rem, 1.6vw, 1.5rem);
    isolation: isolate;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    gap: 1rem;
    width: auto;
    min-height: calc(100vh - clamp(1.7rem, 3.2vw, 3rem));
    padding: 1rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 1.75rem;
    color: rgba(246, 241, 233, 0.94);
    background:
      radial-gradient(circle at 0% 0%, rgba(255, 194, 118, 0.16), transparent 13rem),
      radial-gradient(circle at 100% 20%, rgba(86, 120, 245, 0.13), transparent 14rem),
      linear-gradient(180deg, rgba(20, 24, 34, 0.78), rgba(20, 24, 34, 0.58));
    box-shadow:
      0 1.8rem 4.6rem rgba(17, 20, 26, 0.28),
      inset 0 1px 0 rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(26px);
    -webkit-backdrop-filter: blur(26px);
  }

  .sidebar::before {
    position: absolute;
    inset: 0.65rem;
    z-index: -1;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1.35rem;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025));
    content: "";
    pointer-events: none;
  }

  .sidebar :where(strong, span, small, button) {
    color: inherit;
  }

  .sidebar-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--focus-icon-button-size, 44px);
    align-items: center;
    gap: 0.75rem;
    min-height: 3.8rem;
    margin: 0;
    padding: 0.52rem;
    border: 1px solid rgba(255, 255, 255, 0.10);
    border-radius: 1.2rem;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }

  .brand.compact {
    display: grid;
    grid-template-columns: 2.6rem minmax(0, 1fr);
    align-items: center;
    gap: 0.7rem;
    min-width: 0;
  }

  .brand.compact .brand-mark {
    width: 2.6rem;
    height: 2.6rem;
    border-radius: 0.9rem;
    box-shadow:
      0 0.8rem 1.8rem rgba(0, 0, 0, 0.22),
      inset 0 1px 0 rgba(255, 255, 255, 0.12);
  }

  .brand.compact strong {
    overflow: hidden;
    font-size: 1rem;
    font-weight: 680;
    letter-spacing: 0;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  #sidebarToggle {
    width: var(--focus-icon-button-size, 44px);
    min-width: var(--focus-icon-button-size, 44px);
    height: var(--focus-icon-button-size, 44px);
    border-radius: 0.95rem;
    border-color: rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.09);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.10);
  }

  #sidebarToggle:hover {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--primary) 26%, rgba(255, 255, 255, 0.14));
    background: color-mix(in srgb, var(--primary) 13%, rgba(255, 255, 255, 0.09));
    box-shadow:
      0 0.95rem 1.8rem rgba(0, 0, 0, 0.16),
      0 0 0 4px color-mix(in srgb, var(--primary) 10%, transparent);
  }

  .side-actions {
    display: grid;
    align-content: start;
    gap: 0.55rem;
    min-height: 0;
    padding: 0.1rem;
    overflow: hidden auto;
    scrollbar-width: thin;
  }

  .side-button {
    display: grid;
    grid-template-columns: 2.35rem minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
    width: 100%;
    min-height: 3.2rem;
    padding: 0.3rem 0.78rem 0.3rem 0.38rem;
    border: 1px solid transparent;
    border-radius: 1rem;
    color: rgba(246, 241, 233, 0.80);
    background: transparent;
    box-shadow: none;
    text-align: left;
    transform: translateX(0);
  }

  .side-button .icon {
    display: grid;
    width: 2.35rem;
    min-width: 2.35rem;
    height: 2.35rem;
    place-self: center;
    border-radius: 0.86rem;
    background-color: currentColor;
    opacity: 0.92;
    transition:
      transform var(--focus-motion-standard, 220ms cubic-bezier(.2, .8, .2, 1)),
      opacity var(--focus-motion-standard, 220ms cubic-bezier(.2, .8, .2, 1));
  }

  .side-button > span:last-child {
    overflow: hidden;
    font-size: 0.92rem;
    font-weight: 650;
    letter-spacing: 0;
    line-height: 1.16;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .side-button:hover,
  .side-button.active {
    transform: translateX(2px);
    border-color: color-mix(in srgb, var(--primary) 22%, rgba(255, 255, 255, 0.10));
    color: #fff8ed;
    background:
      radial-gradient(circle at 4% 50%, color-mix(in srgb, var(--primary) 20%, transparent), transparent 64%),
      color-mix(in srgb, var(--primary) 13%, rgba(255, 255, 255, 0.05));
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.12),
      0 0.85rem 1.9rem color-mix(in srgb, var(--primary) 12%, transparent);
  }

  .side-button:hover .icon,
  .side-button.active .icon {
    opacity: 1;
    transform: translateY(-1px);
  }

  .sidebar-footer {
    display: grid;
    gap: 0.65rem;
    margin-top: auto;
  }

  .sidebar-user-card {
    display: grid;
    grid-template-columns: 2.65rem minmax(0, 1fr);
    align-items: center;
    gap: 0.72rem;
    min-height: 3.85rem;
    padding: 0.62rem;
    border: 1px solid rgba(255, 255, 255, 0.10);
    border-radius: 1.18rem;
    background: rgba(255, 255, 255, 0.08);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }

  .sidebar-user-avatar {
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 0.9rem;
    color: #f0a01f;
    background: linear-gradient(145deg, #151511, #25231d);
  }

  .sidebar-user-text {
    display: grid;
    gap: 0.12rem;
    min-width: 0;
  }

  .sidebar-user-text strong,
  .sidebar-user-text small {
    overflow: hidden;
    color: inherit;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .sidebar-user-text strong {
    font-size: 0.88rem;
    font-weight: 700;
  }

  .sidebar-user-text small {
    color: rgba(246, 241, 233, 0.60);
    font-size: 0.74rem;
  }

  .desktop-logout {
    display: inline-flex;
    min-height: 2.9rem;
    justify-content: center;
    border-radius: 1rem;
    border-color: rgba(255, 255, 255, 0.10);
    background: rgba(255, 255, 255, 0.06);
    color: rgba(246, 241, 233, 0.72);
  }

  .desktop-logout:hover {
    transform: translateY(-1px);
    color: #fff8ed;
    border-color: color-mix(in srgb, var(--focus-accent-terracotta, #c56a4b) 25%, rgba(255, 255, 255, 0.12));
    background: color-mix(in srgb, var(--focus-accent-terracotta, #c56a4b) 12%, rgba(255, 255, 255, 0.06));
    box-shadow: 0 0.9rem 1.9rem rgba(197, 106, 75, 0.12);
  }

  .app-shell.sidebar-collapsed .sidebar {
    padding: 0.72rem 0.5rem;
    border-radius: 1.45rem;
  }

  .app-shell.sidebar-collapsed .sidebar::before {
    inset: 0.48rem;
    border-radius: 1.05rem;
  }

  .app-shell.sidebar-collapsed .sidebar-top {
    grid-template-columns: 1fr;
    justify-items: center;
    min-height: auto;
    padding: 0.42rem;
  }

  .app-shell.sidebar-collapsed .brand.compact {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 0;
  }

  .app-shell.sidebar-collapsed .brand.compact strong,
  .app-shell.sidebar-collapsed .side-button > span:last-child,
  .app-shell.sidebar-collapsed .sidebar-user-text {
    display: none;
  }

  .app-shell.sidebar-collapsed #sidebarToggle {
    width: 2.72rem;
    min-width: 2.72rem;
    height: 2.72rem;
  }

  .app-shell.sidebar-collapsed .side-actions {
    align-self: start;
    justify-content: start;
    place-content: start;
    justify-items: center;
    gap: 0.55rem;
    margin-top: 0.15rem;
    overflow: visible;
  }

  .app-shell.sidebar-collapsed .side-button {
    grid-template-columns: 1fr;
    place-items: center;
    width: 3.02rem;
    height: 3.02rem;
    min-height: 3.02rem;
    padding: 0;
    border-radius: 1rem;
  }

  .app-shell.sidebar-collapsed .side-button .icon {
    width: 2.12rem;
    min-width: 2.12rem;
    height: 2.12rem;
  }

  .app-shell.sidebar-collapsed .sidebar-user-card {
    grid-template-columns: 1fr;
    justify-items: center;
    width: 3.02rem;
    min-height: 3.02rem;
    padding: 0.18rem;
    border-radius: 1rem;
  }
}

:root[data-theme="dark"] .sidebar {
  border-color: rgba(255, 255, 255, 0.12);
  background:
    radial-gradient(circle at 0% 0%, rgba(216, 154, 61, 0.10), transparent 12rem),
    radial-gradient(circle at 100% 18%, rgba(111, 140, 255, 0.16), transparent 15rem),
    linear-gradient(180deg, rgba(16, 20, 31, 0.86), rgba(16, 20, 31, 0.70));
  box-shadow:
    0 1.8rem 5rem rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

:root[data-theme="dark"] .sidebar-top,
:root[data-theme="dark"] .sidebar-user-card,
:root[data-theme="dark"] #sidebarToggle,
:root[data-theme="dark"] .desktop-logout {
  border-color: rgba(255, 255, 255, 0.09);
  background: rgba(255, 255, 255, 0.055);
}

@media (max-width: 760px) {
  .sidebar,
  .app-shell.sidebar-collapsed .sidebar {
    display: contents !important;
  }

  .sidebar-top,
  .app-shell.sidebar-collapsed .sidebar-top,
  .sidebar-footer,
  .app-shell.sidebar-collapsed .sidebar-footer,
  .desktop-logout,
  .mobile-logout {
    display: none !important;
  }

  .side-actions,
  .app-shell.sidebar-collapsed .side-actions {
    position: fixed !important;
    left: max(0.65rem, env(safe-area-inset-left)) !important;
    right: max(0.65rem, env(safe-area-inset-right)) !important;
    bottom: max(0.65rem, env(safe-area-inset-bottom)) !important;
    z-index: 72 !important;
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0.24rem;
    width: auto !important;
    max-width: 34rem;
    height: var(--focus-mobile-nav-height, 74px);
    margin-inline: auto;
    padding: 0.38rem;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.26);
    border-radius: 1.55rem;
    background:
      linear-gradient(135deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0.20)),
      color-mix(in srgb, var(--glass-surface, rgba(255, 255, 255, 0.42)) 76%, transparent);
    box-shadow:
      0 1.35rem 3.4rem rgba(48, 38, 29, 0.20),
      inset 0 1px 0 rgba(255, 255, 255, 0.24);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
  }

  .side-button,
  .app-shell.sidebar-collapsed .side-button {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-template-rows: 1.7rem 1fr;
    justify-items: center;
    align-items: center;
    gap: 0.04rem;
    width: 100% !important;
    min-width: 0 !important;
    height: 100% !important;
    min-height: 0 !important;
    padding: 0.33rem 0.18rem 0.28rem;
    border: 1px solid transparent;
    border-radius: 1.12rem;
    color: color-mix(in srgb, var(--text, #2f2a26) 76%, var(--text-muted, #6f655e));
    background: transparent;
    box-shadow: none;
    transform: none;
  }

  .side-button:hover,
  .side-button.active,
  .app-shell.sidebar-collapsed .side-button:hover,
  .app-shell.sidebar-collapsed .side-button.active {
    transform: translateY(-1px);
    border-color: color-mix(in srgb, var(--primary, #5678f5) 26%, transparent);
    color: var(--primary, #5678f5);
    background: color-mix(in srgb, var(--primary, #5678f5) 13%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
  }

  .side-button .icon,
  .app-shell.sidebar-collapsed .side-button .icon {
    width: 1.55rem !important;
    min-width: 1.55rem !important;
    height: 1.55rem !important;
    opacity: 0.95;
  }

  .side-button > span:last-child,
  .app-shell.sidebar-collapsed .side-button > span:last-child {
    display: block !important;
    width: 100%;
    max-width: 100%;
    overflow: hidden;
    color: currentColor;
    font-size: clamp(0.55rem, 2vw, 0.65rem);
    font-weight: 650;
    line-height: 1.05;
    letter-spacing: 0;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  body:has(.modal[open]) .side-actions {
    opacity: 0;
    pointer-events: none;
    transform: translateY(calc(100% + 1.2rem));
  }

  :root[data-theme="dark"] .side-actions,
  :root[data-theme="dark"] .app-shell.sidebar-collapsed .side-actions {
    border-color: rgba(255, 255, 255, 0.14);
    background:
      linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.06)),
      rgba(19, 23, 34, 0.76);
    box-shadow:
      0 1.35rem 3.4rem rgba(0, 0, 0, 0.34),
      inset 0 1px 0 rgba(255, 255, 255, 0.10);
  }
}

@media (max-width: 520px) {
  .side-actions,
  .app-shell.sidebar-collapsed .side-actions {
    height: 3.65rem;
    border-radius: 1.35rem;
    padding: 0.32rem;
  }

  .side-button,
  .app-shell.sidebar-collapsed .side-button {
    grid-template-rows: 1fr;
    border-radius: 1rem;
    padding: 0.28rem 0.18rem;
  }

  .side-button .icon,
  .app-shell.sidebar-collapsed .side-button .icon {
    width: 1.38rem !important;
    min-width: 1.38rem !important;
    height: 1.38rem !important;
  }

  .side-button > span:last-child,
  .app-shell.sidebar-collapsed .side-button > span:last-child {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .sidebar,
  .sidebar *,
  .sidebar *::before,
  .sidebar *::after,
  .side-actions,
  .side-button {
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .side-button:hover,
  .side-button.active {
    transform: none;
  }
}
