/* Skip Link */
.skip-link{
  position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  background:var(--color-accent);color:var(--color-text-inverse);
  padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);
  z-index:var(--z-toast);font-weight:var(--weight-medium);
  transition:top var(--transition-fast);
}
.skip-link:focus{top:var(--space-md)}

/* Back Navigation */
.back-nav{margin-bottom:var(--space-md)}
.back-link{
  display:inline-flex;align-items:center;gap:var(--space-xs);
  color:var(--color-text-secondary);font-size:var(--text-sm);
  padding:var(--space-xs) 0;
  transition:color var(--transition-fast);
}
.back-link:hover{color:var(--color-accent-text)}
.back-arrow{font-size:var(--text-lg)}

/* App Layout - Fixed sidebar, scrollable content */
.app-layout{
  display:block;
  min-height:calc(100vh - var(--header-height));
  min-height:calc(100dvh - var(--header-height));
  padding-left:var(--sidebar-width);
}

/* Sidebar - Fixed position */
.sidebar{
  position:fixed;
  top:var(--header-height);
  left:0;
  width:var(--sidebar-width);
  height:calc(100vh - var(--header-height));
  height:calc(100dvh - var(--header-height));
  background:var(--color-bg-surface);
  border-right:1px solid var(--color-border);
  display:flex;flex-direction:column;
  padding:var(--space-md) 0;
  overflow-y:auto;
  overflow-x:visible;
  z-index:var(--z-sticky);
}

.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-2xs);padding:0 var(--space-sm)}

.sidebar-link{
  display:flex;flex-direction:column;align-items:center;gap:var(--space-2xs);
  padding:var(--space-sm);border-radius:var(--radius-md);
  color:var(--color-text-secondary);font-size:var(--text-xs);
  transition:all var(--transition-fast);
}
.sidebar-link:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}
.sidebar-link[aria-current="page"]{background:var(--color-accent-light);color:var(--color-accent-text)}

.sidebar-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg)}

/* Main Content */
.main-content{
  padding:var(--space-lg);
  padding-bottom:calc(var(--space-lg) + var(--mobile-nav-height) + env(safe-area-inset-bottom));
  max-width:var(--content-max-width);margin:0 auto;width:100%;
  overflow-x:hidden;
}
.main-content:focus{outline:none}

.page-content{animation:fadeIn var(--transition-base)}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Page Grid */
.page-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(320px,100%),1fr));gap:var(--space-lg)}
.page-grid--2col{grid-template-columns:repeat(2,1fr)}
.grid-full{grid-column:1/-1}

/* Mobile Nav */
.mobile-nav{
  display:none;position:fixed;bottom:0;left:0;right:0;
  height:var(--mobile-nav-height);
  padding-bottom:env(safe-area-inset-bottom);
  background:var(--color-bg-surface);
  border-top:1px solid var(--color-border);
  z-index:var(--z-fixed);
}
.mobile-nav-inner{display:flex;justify-content:space-around;align-items:center;height:100%;max-width:500px;margin:0 auto;padding:0 var(--space-xs)}
.mobile-nav-link{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:var(--space-xs) var(--space-sm);color:var(--color-text-muted);
  font-size:var(--text-xs);font-weight:var(--weight-medium);min-width:56px;
  transition:color var(--transition-fast);text-decoration:none;
}
.mobile-nav-link:hover{color:var(--color-text-secondary)}
.mobile-nav-link.active,.mobile-nav-link[aria-current="page"]{color:var(--color-accent-text)}
.mobile-nav-icon{display:flex;align-items:center;justify-content:center}
.mobile-nav-icon svg{width:24px;height:24px;stroke-width:2}

/* Responsive */
@media(max-width:899px){
  .app-layout{padding-left:0}
  .sidebar{display:none}
  .mobile-nav{display:block}
  .main-content{
    padding:var(--space-md);
    padding-bottom:calc(var(--space-md) + var(--mobile-nav-height) + env(safe-area-inset-bottom) + 60px);
  }
}

@media(max-width:599px) and (orientation:portrait){
  .page-grid{grid-template-columns:1fr!important}
  .main-content{
    padding:var(--space-sm);
    padding-bottom:calc(var(--space-sm) + var(--mobile-nav-height) + env(safe-area-inset-bottom) + 60px);
  }
  /* Compact mobile nav for narrow portrait screens */
  .mobile-nav-link{min-width:40px;padding:var(--space-2xs);font-size:9px}
  .mobile-nav-icon svg{width:20px;height:20px}
}

@media(max-width:899px) and (orientation:landscape){
  .page-grid{grid-template-columns:1fr 1fr!important}
}

@media(min-width:900px){
  .main-content{padding-bottom:var(--space-xl)}
}
