canonrs-server 0.1.0

CanonRS server-side rendering support
/* ═══════════════════════════════════════════════════════════════
   SIDEBAR — Family D Navigation tokens compliant
   ═══════════════════════════════════════════════════════════════ */

[data-rs-sidebar] {
  display: flex;
  flex-direction: column;
  width: var(--sidebar-width);
  min-height: 300px;
  background: var(--sidebar-bg);
  border-right: var(--sidebar-border-width) solid var(--sidebar-border-color);
  transition: width var(--motion-duration-normal) var(--motion-ease-standard);
}

[data-rs-sidebar-header] {
  padding: var(--sidebar-header-padding);
  border-bottom: var(--sidebar-border-width) solid var(--sidebar-border-color);
}

[data-rs-sidebar-content] {
  flex: 1;
  overflow-y: auto;
  overflow-x: visible;
  padding: var(--sidebar-content-padding);
}

[data-rs-sidebar-footer] {
  padding: var(--sidebar-footer-padding);
  border-top: var(--sidebar-border-width) solid var(--sidebar-border-color);
}

[data-rs-sidebar-menu] {
  display: flex;
  flex-direction: column;
  gap: var(--sidebar-menu-gap);
}

/* =========================================================
   MENU ITEM
   ========================================================= */

[data-rs-sidebar-menu-item] {
  display: flex;
  align-items: center;
  gap: var(--sidebar-menu-item-gap);
  height: var(--sidebar-menu-item-height);
  padding-inline: var(--sidebar-menu-item-padding-x);
  padding-block: var(--sidebar-menu-item-padding-y);
  border-radius: var(--sidebar-menu-item-radius);
  background: var(--sidebar-menu-item-bg);
  color: var(--sidebar-menu-item-fg);
  font-size: var(--sidebar-menu-item-font-size);
  cursor: pointer;
  transition: background var(--sidebar-menu-item-transition-duration) var(--sidebar-menu-item-transition-ease);
  text-decoration: none;
}

[data-rs-sidebar-menu-item][data-rs-state~="active"] {
  background: var(--sidebar-menu-item-bg-active);
  color: var(--sidebar-menu-item-fg-active);
  font-weight: var(--sidebar-menu-item-font-weight-active);
  border-left: var(--border-medium) solid var(--theme-action-primary-bg);
  padding-left: calc(var(--sidebar-menu-item-padding-x) - var(--border-medium));
}

[data-rs-sidebar-menu-item][data-rs-state~="disabled"] {
  opacity: var(--opacity-disabled);
  pointer-events: none;
  cursor: not-allowed;
}

[data-rs-sidebar-menu-item]:focus-visible {
  outline: var(--focus-ring-width) solid var(--theme-action-focus-ring);
  outline-offset: var(--focus-ring-offset);
}

/* =========================================================
   GROUP LABEL / SEPARATOR / INSET
   ========================================================= */

[data-rs-sidebar-group-label] {
  padding-inline: var(--sidebar-group-label-padding-x);
  padding-block: var(--sidebar-group-label-padding-y);
  font-size: var(--sidebar-group-label-font-size);
  font-weight: var(--sidebar-group-label-font-weight);
  color: var(--sidebar-group-label-fg);
}

[data-rs-sidebar-separator] {
  height: var(--sidebar-separator-height);
  background: var(--sidebar-separator-color);
  margin-block: var(--sidebar-separator-margin-y);
}

[data-rs-sidebar-inset] {
  padding-left: var(--sidebar-inset-padding-left);
}

/* =========================================================
   SIDEBAR GROUP COLLAPSIBLE
   ========================================================= */

[data-rs-sidebar-group] {
  width: 100%;
}

[data-rs-sidebar-group-toggle] {
  min-height: var(--sidebar-menu-item-height);
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--sidebar-menu-item-gap);
  padding: var(--sidebar-menu-item-padding-y) var(--sidebar-menu-item-padding-x);
  background: transparent;
  border: none;
  color: var(--sidebar-menu-item-fg);
  font-size: var(--sidebar-menu-item-font-size);
  text-align: left;
  cursor: pointer;
  border-radius: var(--sidebar-menu-item-radius);
  transition: background var(--sidebar-menu-item-transition-duration) var(--sidebar-menu-item-transition-ease);
}

[data-rs-sidebar-group-toggle][data-rs-state~="hover"] {
  background: var(--sidebar-menu-item-bg-hover);
}

[data-rs-sidebar-group-content] {
  overflow: hidden;
  padding-left: var(--sidebar-inset-padding-left);
}

[data-rs-sidebar-group][data-rs-state~="collapsed"] [data-rs-sidebar-group-content] {
  display: none;
}

[data-rs-sidebar-group][data-rs-state~="expanded"] [data-rs-sidebar-group-content] {
  display: block;
}

[data-rs-sidebar-group-chevron] {
  margin-left: auto;
  transition: transform 160ms ease;
}

[data-rs-sidebar-group][data-rs-state~="collapsed"] [data-rs-sidebar-group-toggle] [data-rs-sidebar-group-chevron] {
  transform: rotate(-90deg);
}

/* =========================================================
   SIDEBAR COLLAPSED STATE
   ========================================================= */

[data-rs-sidebar][data-rs-state~="collapsed"] {
  width: var(--sidebar-width-collapsed);
  overflow: visible;
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-label],
[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-search],
[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-group-label],
[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-badge] {
  display: var(--sidebar-label-collapsed-display);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-menu-item] {
  justify-content: var(--sidebar-item-collapsed-justify);
  padding-inline: var(--sidebar-item-collapsed-padding-x);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-group-toggle] {
  justify-content: var(--sidebar-item-collapsed-justify);
  padding-inline: var(--sidebar-item-collapsed-padding-x);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-group-chevron] {
  display: var(--sidebar-label-collapsed-display);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-icon] {
  display: flex;
  justify-content: center;
  width: 100%;
  font-size: var(--font-size-xl);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-header] {
  display: flex;
  justify-content: center;
  padding: var(--space-md);
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-group-content] {
  visibility: hidden;
  height: 0;
  overflow: hidden;
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-content] {
  overflow: visible;
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-sidebar-menu] {
  overflow: visible;
}

/* =========================================================
   SIDEBAR EXPANDED STATE
   ========================================================= */

[data-rs-sidebar][data-rs-state~="expanded"] {
  visibility: visible;
}

/* =========================================================
   SIDEBAR ICON
   ========================================================= */

[data-rs-sidebar]:not([data-rs-state~="collapsed"]) [data-rs-sidebar-icon] {
  display: inline-flex;
  margin-right: var(--space-xs);
}

/* =========================================================
   TOOLTIPS
   ========================================================= */

[data-rs-sidebar]:not([data-rs-state~="collapsed"]) [data-rs-tooltip-content] {
  visibility: hidden;
  width: 0;
  height: 0;
  overflow: hidden;
  pointer-events: none;
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-tooltip-content] {
  visibility: hidden;
}

[data-rs-sidebar][data-rs-state~="collapsed"] [data-rs-tooltip-content][data-rs-state~="open"] {
  visibility: visible;
  width: auto;
  height: auto;
  overflow: visible;
  pointer-events: auto;
}

/* =========================================================
   BADGES
   ========================================================= */

[data-rs-sidebar-menu-item] [data-rs-badge] {
  margin-left: auto;
  flex-shrink: 0;
}

[data-rs-sidebar-menu-item] [data-rs-badge][data-rs-variant="default"]     { background: var(--badge-bg-default); color: var(--badge-fg-default); }
[data-rs-sidebar-menu-item] [data-rs-badge][data-rs-variant="primary"]     { background: var(--badge-bg-primary); color: var(--badge-fg-primary); }
[data-rs-sidebar-menu-item] [data-rs-badge][data-rs-variant="success"]     { background: var(--badge-bg-success); color: var(--badge-fg-success); animation: badge-pulse var(--motion-duration-slow) var(--motion-ease-standard) infinite; }
[data-rs-sidebar-menu-item] [data-rs-badge][data-rs-variant="warning"]     { background: var(--badge-bg-warning); color: var(--badge-fg-warning); }
[data-rs-sidebar-menu-item] [data-rs-badge][data-rs-variant="destructive"] { background: var(--badge-bg-destructive); color: var(--badge-fg-destructive); animation: badge-pulse var(--motion-duration-slow) var(--motion-ease-standard) infinite; }

@keyframes badge-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: var(--opacity-disabled); }
}

/* =========================================================
   RESPONSIVE / CONTAINER
   ========================================================= */

[data-rs-sidebar-container] {
  position: relative;
  width: 100%;
  height: 100vh;
}

[data-rs-sidebar-pin-toggle] {
  transition: transform var(--motion-duration-fast) var(--motion-ease-standard);
}

[data-rs-sidebar][data-rs-pinned="true"] [data-rs-sidebar-pin-toggle] {
  transform: rotate(-45deg);
}

[data-rs-sidebar-toggle] {
  padding: var(--space-sm);
  background: var(--theme-surface-bg);
  border: var(--border-thin) solid var(--theme-surface-border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--font-size-xl);
}

[data-rs-sidebar-overlay] {
  position: fixed;
  inset: 0;
  background: var(--color-overlay-50);
  z-index: var(--layer-dropdown);
  display: none;
}

[data-rs-sidebar-container][data-rs-mode="tablet"][data-rs-state~="open"] [data-rs-sidebar-overlay],
[data-rs-sidebar-container][data-rs-mode="mobile"][data-rs-state~="open"] [data-rs-sidebar-overlay] {
  display: block;
}

[data-rs-sidebar-wrapper] {
  transition: all var(--motion-duration-normal) var(--motion-ease-standard);
}

[data-rs-sidebar-container][data-rs-mode="desktop"] [data-rs-sidebar-wrapper] {
  position: relative;
  width: var(--sidebar-width);
  height: 100vh;
}

[data-rs-sidebar-container][data-rs-mode="tablet"] [data-rs-sidebar-wrapper],
[data-rs-sidebar-container][data-rs-mode="mobile"] [data-rs-sidebar-wrapper] {
  position: fixed;
  top: 0;
  left: calc(-1 * var(--sidebar-width));
  width: var(--sidebar-width);
  height: 100vh;
  z-index: var(--layer-overlay);
}

[data-rs-sidebar-container][data-rs-mode="tablet"][data-rs-state~="open"] [data-rs-sidebar-wrapper],
[data-rs-sidebar-container][data-rs-mode="mobile"][data-rs-state~="open"] [data-rs-sidebar-wrapper] {
  left: 0;
}

[data-rs-sidebar-container][data-rs-mode="mobile"]:not([data-rs-state~="open"]) [data-rs-sidebar-wrapper],
[data-rs-sidebar-container][data-rs-mode="tablet"]:not([data-rs-state~="open"]) [data-rs-sidebar-wrapper] {
  display: none;
}