/* =========================================================
   saas-core.css
   Oracle APEX 26.1 / Universal Theme / Iris-friendly
   Purpose: small reusable SaaS UI layer
   ========================================================= */


/* =========================================================
   01. Design Tokens
   ========================================================= */

:root {
  --sc-radius-sm: .5rem;
  --sc-radius-md: .75rem;
  --sc-radius-lg: 1rem;
  --sc-radius-xl: 1.5rem;
  --sc-gap-xs: .35rem;
  --sc-gap-sm: .5rem;
  --sc-gap-md: .75rem;
  --sc-gap-lg: 1rem;
  --sc-shadow-soft: 0 10px 26px rgba(0,0,0,.06);
}


/* =========================================================
   02. Public Navigation
   ========================================================= */

#publicTopNav .a-MenuBar {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: .35rem;
  padding: .25rem;
  background: color-mix(in srgb, var(--ut-component-background-color) 88%, transparent);
  border: 1px solid var(--ut-component-border-color);
  border-radius: 999px;
  box-shadow: var(--ut-shadow-sm, var(--sc-shadow-soft));
}

#publicTopNav .a-MenuBar-item {
  border: 0;
  background: transparent;
}

#publicTopNav .a-MenuBar-label {
  border-radius: 999px;
  padding: .55rem .9rem;
  color: var(--ut-body-text-color);
  font-weight: 600;
  text-decoration: none;
  transition: background-color .15s ease, color .15s ease;
}

#publicTopNav .a-MenuBar-label:hover,
#publicTopNav .a-MenuBar-label:focus {
  background: var(--ut-component-hover-background-color);
  color: var(--ut-palette-primary);
  text-decoration: none;
}

#publicTopNav .a-MenuBar-item.is-current .a-MenuBar-label,
#publicTopNav .a-MenuBar-item.is-active .a-MenuBar-label,
#publicTopNav .a-MenuBar-item.a-Menu--current .a-MenuBar-label {
  background: var(--ut-palette-primary);
  color: var(--ut-palette-primary-contrast, #fff);
}

#FooterNav .t-Tabs,
#engagementNav .t-NavigationBar {
  display: flex;
  justify-content: center;
}

.t-Footer .t-Footer-version {
  text-align: center;
  width: 100%;
}

@media (max-width: 768px) {
  #publicTopNav .a-MenuBar {
    flex-wrap: wrap;
    border-radius: var(--sc-radius-xl);
  }
}


/* =========================================================
   03. Generic Page Layout
   ========================================================= */

.sc-section-wide {
  max-width: 1200px;
  margin-inline: auto;
}

.sc-section-narrow {
  max-width: 860px;
  margin-inline: auto;
}

.sc-stack-lg {
  margin-bottom: 1.25rem;
}

.sc-page-header,
.sc-work-header {
  padding: .75rem 1rem;
  margin-bottom: .75rem;
  border-radius: var(--sc-radius-md);
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-sm);
}

.sc-page-header,
.sc-work-header__main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.sc-page-header__content {
  flex: 1;
  min-width: 0;
}

.sc-page-header__meta,
.sc-workspace-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .7rem;
}

.sc-page-header__actions {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}

.sc-eyebrow,
.sc-context-line {
  display: flex;
  align-items: center;
  gap: .4rem;
  margin-bottom: .2rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ut-component-text-muted-color);
}

.sc-page-title {
  margin: 0;
  line-height: 1.15;
  font-weight: 700;
}

.sc-page-title--compact,
.sc-work-header h1 {
  margin: .15rem 0;
  font-size: 1.5rem;
  font-weight: 700;
}

.sc-page-subtitle,
.sc-work-header p {
  margin: .25rem 0 0;
  max-width: 70rem;
  line-height: 1.4;
  color: var(--ut-component-text-muted-color);
}

.sc-work-header__status {
  white-space: nowrap;
}

.sc-compact-breadcrumb .t-Breadcrumb {
  padding: .15rem 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.sc-work-region {
  margin-top: .5rem;
}


/* =========================================================
   04. Badges / KPI Strips
   ========================================================= */

.sc-badge-strip {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: .25rem 0 .75rem;
}

.sc-badge-strip .t-Badge {
  font-size: .8125rem;
  font-weight: 600;
  padding: .35rem .6rem;
}

.sc-kpi-strip {
  margin-bottom: .75rem;
}


/* =========================================================
   05. Public Marketing Pages
   ========================================================= */

.sc-public-hidden-link {
  display: none !important;
}

.sc-public-hero {
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--ut-palette-primary) 16%, transparent), transparent 34rem),
    linear-gradient(180deg, var(--ut-component-background-color), var(--ut-body-background-color));
  border-bottom: 1px solid var(--ut-component-border-color);
}

.sc-public-hero__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 5.5rem 1.25rem 4.5rem;
  text-align: center;
}

.sc-public-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .9rem;
  padding: .35rem .75rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ut-palette-primary) 10%, transparent);
  color: var(--ut-palette-primary);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sc-public-title {
  max-width: 980px;
  margin: 0 auto 1.25rem;
  font-size: clamp(2.35rem, 5vw, 4.8rem);
  line-height: 1.04;
  font-weight: 800;
  color: var(--ut-body-text-color);
}

.sc-public-subtitle {
  max-width: 780px;
  margin: 0 auto;
  font-size: 1.15rem;
  line-height: 1.65;
  color: var(--ut-component-text-muted-color);
}

.sc-public-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .8rem;
  flex-wrap: wrap;
  margin-top: 1.75rem;
}

.sc-public-note {
  margin-top: 1rem;
  color: var(--ut-component-text-muted-color);
  font-size: .95rem;
}

.sc-public-section {
  padding: 4rem 1.25rem;
}

.sc-public-section--soft {
  background: color-mix(in srgb, var(--ut-body-background-color) 92%, var(--ut-component-background-color));
  border-block: 1px solid var(--ut-component-border-color);
}

.sc-public-section__inner {
  max-width: 1180px;
  margin: 0 auto;
}

.sc-public-section-header {
  max-width: 760px;
  margin: 0 auto 2rem;
  text-align: center;
}

.sc-public-section-header h2,
.sc-public-final-cta h2,
.sc-public-split h2 {
  margin: 0 0 .75rem;
  font-size: clamp(1.8rem, 3vw, 2.8rem);
  line-height: 1.12;
  font-weight: 800;
}

.sc-public-section-header p,
.sc-public-final-cta p,
.sc-public-split p {
  color: var(--ut-component-text-muted-color);
  line-height: 1.6;
  font-size: 1.02rem;
}

.sc-public-card-grid {
  display: grid;
  gap: 1rem;
}

.sc-public-card-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.sc-public-card {
  padding: 1.35rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: 1.25rem;
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-sm, var(--sc-shadow-soft));
}

.sc-public-card__icon {
  width: 2.4rem;
  height: 2.4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: .85rem;
  border-radius: .85rem;
  background: color-mix(in srgb, var(--ut-palette-primary) 10%, transparent);
  color: var(--ut-palette-primary);
}

.sc-public-card h3 {
  margin: 0 0 .5rem;
  font-size: 1.1rem;
  font-weight: 800;
}

.sc-public-card p {
  margin: 0;
  color: var(--ut-component-text-muted-color);
  line-height: 1.55;
}

.sc-public-usecases {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.sc-public-usecase {
  padding: 1.25rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: var(--sc-radius-lg);
  background: var(--ut-component-background-color);
}

.sc-public-usecase strong {
  display: block;
  margin-bottom: .35rem;
  font-size: 1.05rem;
}

.sc-public-usecase span {
  color: var(--ut-component-text-muted-color);
  line-height: 1.5;
}

.sc-public-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: 2rem;
  align-items: center;
}

.sc-public-checklist {
  display: grid;
  gap: .75rem;
}

.sc-public-checklist div {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: 999px;
  background: var(--ut-component-background-color);
}

.sc-public-checklist .fa {
  color: var(--ut-palette-success);
}

.sc-public-final-cta {
  padding: 4.5rem 1.25rem;
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--ut-palette-primary) 12%, transparent),
    color-mix(in srgb, var(--ut-palette-info, var(--ut-palette-primary)) 8%, transparent)
  );
  text-align: center;
}

.sc-public-final-cta__inner {
  max-width: 860px;
  margin: 0 auto;
}


/* =========================================================
   06. Pricing / FAQ
   ========================================================= */

.sc-public-pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.sc-public-pricing-card {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 1.5rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: 1.5rem;
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-sm, var(--sc-shadow-soft));
}

.sc-public-pricing-card--featured {
  border-color: var(--ut-palette-primary);
  box-shadow: var(--ut-shadow-md, var(--sc-shadow-soft));
  transform: translateY(-.35rem);
}

.sc-public-pricing-card__header h3 {
  margin: .5rem 0 .35rem;
}

.sc-public-pricing-badge {
  display: inline-flex;
  padding: .35rem .65rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ut-palette-primary) 10%, transparent);
  color: var(--ut-palette-primary);
  font-weight: 750;
  font-size: .8rem;
}

.sc-public-price span {
  display: block;
  font-size: 2.25rem;
  line-height: 1;
  font-weight: 850;
  letter-spacing: -.04em;
}

.sc-public-price small {
  color: var(--ut-component-text-muted-color);
}

.sc-public-pricing-card .t-Button {
  margin-top: auto;
}

.sc-public-faq {
  display: grid;
  gap: .75rem;
  max-width: 900px;
  margin: 0 auto;
}

.sc-public-faq details {
  border: 1px solid var(--ut-component-border-color);
  border-radius: 1rem;
  padding: 1rem 1.15rem;
  background: var(--ut-component-background-color);
}

.sc-public-faq summary {
  cursor: pointer;
  font-weight: 750;
}

.sc-public-faq p {
  margin: .75rem 0 0;
  color: var(--ut-component-text-muted-color);
}


/* =========================================================
   07. Authentication / Request Access Pages
   ========================================================= */

#loginLinks {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: .75rem;
}

#loginLinks .uix-link {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  box-shadow: none !important;
  text-decoration: none;
}

#loginLinks .uix-link:hover {
  text-decoration: underline;
}

.sc-login-title {
  margin: .35rem auto .5rem;
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  line-height: 1.08;
  font-weight: 800;
  color: var(--ut-body-text-color);
}

.sc-login-copy {
  max-width: 34rem;
  margin: 0 auto;
  color: var(--ut-component-text-muted-color);
  line-height: 1.55;
}

.sc-auth-card {
  max-width: 520px;
  margin: 2rem auto;
}

.sc-auth-hero {
  text-align: center;
  margin-bottom: 1.5rem;
}

.sc-auth-icon,
.sc-request-icon {
  width: 4rem;
  height: 4rem;
  margin: 0 auto 1rem;
  border-radius: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--ut-palette-success) 14%, transparent);
  color: var(--ut-palette-success);
  font-size: 1.5rem;
}

.sc-request-hero {
  text-align: center;
  padding-block: 3rem 2rem;
}

.sc-request-form-region {
  max-width: 980px;
  margin: 0 auto;
  border: 1px solid var(--ut-component-border-color);
  border-radius: 1.5rem;
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-md, var(--sc-shadow-soft));
}

.sc-password-rules {
  display: grid;
  gap: .35rem;
  margin-block: .5rem .75rem;
}

.pw-rule,
.sc-password-rules .pw-rule {
  display: flex;
  align-items: center;
  gap: .45rem;
  font-size: .875rem;
  color: var(--ut-component-text-muted-color);
}

.pw-rule.is-ok,
.pw-rule.is-valid,
.sc-password-rules .pw-rule.is-valid {
  color: var(--ut-palette-success);
  font-weight: 600;
}

.pw-rule .fa,
.sc-password-rules .fa {
  width: 1rem;
}


/* =========================================================
   08. Setup Guide / Checklist
   ========================================================= */

.sc-setup-checklist-region .t-Report-report,
.sc-setup-checklist-region .t-Report-cell {
  border: 0;
  background: transparent;
}

.sc-step-row {
  display: grid;
  grid-template-columns: 3rem 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.25rem;
  margin-bottom: .75rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: var(--sc-radius-lg);
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-sm);
}

.sc-step-marker {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 2.5rem;
  block-size: 2.5rem;
  border-radius: 999px;
  background: var(--ut-component-highlight-background-color);
  font-weight: 700;
}

.sc-step-content h3 {
  margin: 0 0 .25rem;
  font-size: 1.1rem;
}

.sc-step-content p {
  margin: 0;
  color: var(--ut-component-text-muted-color);
}

.sc-step-kicker {
  margin-bottom: .15rem;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--ut-component-text-muted-color);
}

.sc-step-action {
  display: flex;
  align-items: center;
  gap: .75rem;
  justify-content: flex-end;
}

.sc-step-badge {
  display: inline-flex;
  align-items: center;
  padding: .3rem .7rem;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 700;
  background: var(--ut-component-highlight-background-color);
  color: var(--ut-component-text-default-color);
  white-space: nowrap;
}

.sc-step-done .sc-step-marker {
  color: var(--ut-palette-success);
}

.sc-step-next {
  border-color: var(--ut-palette-primary);
}

.sc-step-locked {
  opacity: .6;
}

.sc-step-locked .t-Button,
.sc-step-locked .t-Button.is-disabled {
  pointer-events: none;
}


/* =========================================================
   09. Local Context Navigation
   ========================================================= */

.sc-local-nav-shell {
  position: sticky;
  top: 1rem;
}

.sc-local-nav-cards {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.sc-local-nav-link {
  display: flex;
  align-items: center;
  gap: .55rem;
  min-height: 44px;
  padding: .65rem .75rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: .5rem;
  color: var(--ut-body-text-color);
  background: var(--ut-component-background-color);
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
}

.sc-local-nav-link:hover,
.sc-local-nav-link:focus {
  color: var(--ut-body-text-color);
  background: var(--ut-component-hover-background-color);
  text-decoration: none;
}

.sc-local-nav-link .fa {
  flex: 0 0 auto;
  font-size: 1rem;
}

.sc-local-nav-cards .a-CardView-items {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

.sc-local-nav-cards .a-CardView-item {
  width: 100%;
}

.sc-local-nav-cards .a-CardView-card {
  min-height: 48px;
  border-radius: .75rem;
}

.sc-local-nav-card-body {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-size: .9rem;
  font-weight: 700;
  color: var(--ut-body-text-color);
}

.sc-local-nav-card-body .fa {
  flex: 0 0 auto;
  font-size: 1rem;
}

.sc-local-nav-card-title {
  display: inline-block;
  white-space: normal;
}

.sc-local-nav-cards .a-CardView-body {
  display: block !important;
}

.sc-local-nav-cards .a-CardView-subTitle,
.sc-local-nav-cards .a-CardView-title {
  display: none !important;
}

.sc-local-nav-cards .a-CardView-item.is-active .a-CardView-card,
.sc-local-nav-cards .a-CardView-item.is-active .a-CardView-fullLink {
  background-color: var(--ut-component-highlight-background-color) !important;
  border-color: var(--ut-component-border-color) !important;
  box-shadow: inset 4px 0 0 var(--ut-palette-primary);
}

.sc-local-nav-cards .a-CardView-item.is-active .sc-local-nav-card-body,
.sc-local-nav-cards .a-CardView-item.is-active .sc-local-nav-card-body * {
  color: var(--ut-body-text-color) !important;
}

.sc-hub-actions {
  display: flex;
  justify-content: flex-end;
  gap: .5rem;
  margin-bottom: .75rem;
}

.sc-hub-actions .t-Region-body {
  display: flex;
  justify-content: space-between;
  gap: .5rem;
  width: 100%;
}

.sc-hub-actions .t-ButtonRegion-buttons {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}

#engagement-workspace > .t-Region-bodyWrap > .t-Region-body,
#engagement-workspace > .t-Region-body {
  display: grid;
  grid-template-columns: minmax(12rem, 14rem) minmax(0, 1fr);
  gap: .9rem;
  max-width: 1200px;
  margin-inline: auto;
  align-items: start;
}

#engagement-menu {
  position: sticky;
  top: 1rem;
  align-self: start;
}

#engagement-menu .t-Region-body {
  padding: 0;
}

.sc-hub-local-menu__nav {
  display: grid;
  gap: .25rem;
}

#engagement-menu .t-TreeNav,
#engagement-menu .a-TreeView {
  width: 100%;
  display: grid;
  gap: .25rem;
}

#engagement-menu .a-TreeView-node,
#engagement-menu .t-TreeNav-item {
  margin-bottom: .35rem;
}

#engagement-menu a,
.sc-hub-local-menu__link {
  display: flex;
  align-items: center;
  gap: .45rem;
  min-height: 36px;
  padding: .45rem .55rem;
  border-radius: .5rem;
  color: var(--ut-body-text-color);
  font-size: .875rem;
  font-weight: 650;
  text-decoration: none;
  white-space: nowrap;
}

#engagement-menu a:hover,
#engagement-menu a:focus,
.sc-hub-local-menu__link:hover,
.sc-hub-local-menu__link:focus {
  background: var(--ut-component-hover-background-color);
  color: var(--ut-body-text-color);
  text-decoration: none;
}

#engagement-menu a.is-active,
#engagement-menu .is-active > a,
#engagement-menu .is-active > .a-TreeView-content,
.sc-hub-local-menu__link.is-active {
  background: var(--ut-component-highlight-background-color);
  color: var(--ut-body-text-color);
  box-shadow: inset 4px 0 0 var(--ut-palette-primary);
}

#engagement-content {
  min-width: 0;
}

.sc-hub-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
}

.sc-hub-overview__item {
  min-width: 0;
  padding: .75rem;
  border: 1px solid var(--ut-component-border-color);
  border-radius: .5rem;
  background: var(--ut-component-background-color);
}

.sc-hub-overview__label {
  display: block;
  margin-bottom: .2rem;
  color: var(--ut-component-text-muted-color);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
}

.sc-hub-overview__item strong {
  display: block;
  overflow-wrap: anywhere;
  font-size: 1rem;
}


/* =========================================================
   10. Reports / IG / Row Icons
   ========================================================= */

.sc-row-action,
#engagements-list .a-GV-cell a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  min-height: 2rem;
  width: 2rem;
  height: 2rem;
  border-radius: .5rem;
  text-decoration: none;
}

.sc-row-action:hover,
#engagements-list .a-GV-cell a:hover {
  background: var(--ut-component-hover-background-color);
}

.sc-row-action .fa,
#engagements-list .a-GV-cell a .fa {
  font-size: 1rem;
}


/* =========================================================
   11. Invite / Details
   ========================================================= */

.sc-invite-summary {
  padding: .75rem 1rem;
  margin-bottom: 1rem;
  border-radius: .75rem;
  background: var(--ut-component-background-color);
  box-shadow: var(--ut-shadow-sm);
}

.sc-invite-title {
  margin: .15rem 0 .5rem;
  font-size: 1.2rem;
  font-weight: 650;
}

.sc-invite-summary__body {
  display: grid;
  gap: .35rem;
}

.sc-detail-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  font-size: .9rem;
}

.sc-detail-label {
  color: var(--ut-component-text-muted-color);
}

.sc-detail-value {
  font-weight: 600;
  text-align: right;
}


/* =========================================================
   12. Responsive
   ========================================================= */

@media (max-width: 980px) {
  .sc-public-card-grid--4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sc-public-split {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .sc-public-pricing-grid {
    grid-template-columns: 1fr;
  }

  .sc-public-pricing-card--featured {
    transform: none;
  }
}

@media (max-width: 768px) {
  .sc-page-header,
  .sc-work-header__main {
    flex-direction: column;
    align-items: stretch;
  }

  .sc-page-header__actions {
    width: 100%;
  }

  .sc-page-header__actions .t-Button {
    flex: 1;
    justify-content: center;
  }

  .sc-local-nav-shell {
    position: static;
    margin-bottom: 1rem;
  }

  .sc-hub-actions,
  .sc-hub-actions .t-Region-body {
    justify-content: stretch;
  }

  .sc-hub-actions .t-Button,
  .sc-hub-actions .t-ButtonRegion-buttons {
    flex: 1 1 auto;
  }

  #engagement-workspace > .t-Region-bodyWrap > .t-Region-body,
  #engagement-workspace > .t-Region-body {
    display: block;
  }

  #engagement-menu {
    position: static;
    margin-bottom: .75rem;
  }

  #engagement-menu .a-TreeView,
  #engagement-menu .t-TreeNav,
  .sc-hub-local-menu__nav {
    display: flex;
    overflow-x: auto;
    gap: .35rem;
    padding-bottom: .25rem;
  }

  #engagement-menu .a-TreeView-node,
  #engagement-menu .t-TreeNav-item,
  .sc-hub-local-menu__link {
    flex: 0 0 auto;
    margin-bottom: 0;
  }

  #engagement-menu a,
  .sc-hub-local-menu__link {
    min-width: 8rem;
    justify-content: center;
    box-shadow: none;
  }

  .sc-hub-overview {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .sc-public-form-grid,
  .sc-public-card-grid--4,
  .sc-public-usecases {
    grid-template-columns: 1fr;
  }

  .sc-public-actions .t-Button {
    width: 100%;
  }
}

@media (max-width: 640px) {
  #loginLinks {
    flex-direction: column;
    align-items: center;
  }

  .sc-public-hero__inner {
    padding: 3.25rem 1rem 3rem;
  }

  .sc-public-section,
  .sc-public-final-cta {
    padding: 3rem 1rem;
  }

  .sc-step-row {
    grid-template-columns: 2.75rem 1fr;
  }

  .sc-step-action {
    grid-column: 2;
    justify-content: flex-start;
    flex-wrap: wrap;
  }

/* Page 152 Engagement Hub */

#hub-layout {
  margin-top: 1rem;
}

#hub-layout > .t-Region-bodyWrap,
#hub-layout > .t-Region-bodyWrap > .t-Region-body {
  width: 100%;
}

#hub-layout > .t-Region-bodyWrap > .t-Region-body {
  display: grid;
  grid-template-columns: minmax(16rem, 20rem) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

#hub-local-menu-actions {
  grid-column: 1;
  grid-row: 1;
}

#context-hub-menu {
  grid-column: 1;
  grid-row: 2;
  position: sticky;
  top: 3.25rem;
  z-index: 2;
}

#hub-content {
  grid-column: 2;
  grid-row: 1 / span 2;
  min-width: 0;
  width: 100%;
}

#context-hub-menu-toggle {
  justify-content: flex-start;
  width: 100%;
}

.js-context-hub-local-nav-collapsed #hub-layout > .t-Region-bodyWrap > .t-Region-body {
  grid-template-columns: 3.25rem minmax(0, 1fr);
}

.js-context-hub-local-nav-collapsed #context-hub-menu {
  display: none;
}

.js-context-hub-local-nav-collapsed #context-hub-menu-toggle {
  justify-content: center;
}

.js-context-hub-local-nav-collapsed .sc-context-hub-menu-toggle-label {
  display: none;
}

#hub-content > .t-Region-bodyWrap,
#hub-content > .t-Region-bodyWrap > .t-Region-body {
  width: 100%;
}

#hub-content .t-Region {
  width: 100%;
  max-width: 100%;
}

#quick-access {
  margin-bottom: 1rem;
}

@media (max-width: 768px) {
  #hub-layout > .t-Region-bodyWrap > .t-Region-body {
    display: block;
  }

  #hub-local-menu-actions {
    display: none;
  }

  #context-hub-menu {
    position: static;
    display: block;
  }
}

#context-hub-menu .t-Region-body {
  padding: 0;
}

#context-hub-menu .a-TreeView,
#context-hub-menu .t-TreeNav {
  width: 100%;
}

#context-hub-menu .a-TreeView-toggle,
#context-hub-menu .t-TreeNav-toggle {
  margin-right: .15rem;
}

#context-hub-menu .a-TreeView-node,
#context-hub-menu .t-TreeNav-item {
  margin-bottom: .35rem;
}

#context-hub-menu .a-TreeView-content .fa,
#context-hub-menu .t-TreeNav-link .fa {
  width: 1rem;
  text-align: center;
  flex: 0 0 1rem;
}

#context-hub-menu .a-TreeView-content,
#context-hub-menu .t-TreeNav-link {
  border-radius: .75rem;
}

@media (max-width: 768px) {
  #context-hub-menu {
    margin-bottom: .75rem;
  }

  #context-hub-menu .a-TreeView,
  #context-hub-menu .t-TreeNav {
    display: block;
    overflow-x: visible;
  }
}

.sc-hub-section {
  width: 100%;
}

/* =========================================================
   14. Tree Type Differentiation
   ========================================================= */

.sc-ops-node,
.sc-area-node {
  flex-wrap: wrap;
  row-gap: .25rem;
}

.sc-tree-node-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  flex: 0 0 1.5rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--ut-component-background-color) 76%, var(--ut-component-border-color));
  color: var(--ut-component-text-muted-color);
}

.sc-tree-node-icon .fa {
  width: auto;
  flex: 0 0 auto;
}

.sc-tree-node-main {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  min-width: 0;
  flex-wrap: wrap;
}

.sc-tree-node-icon--account,
.sc-tree-node-icon--account {
  background: color-mix(in srgb, var(--ut-component-background-color) 78%, #b28953 22%);
  color: #6e532e;
}

.sc-tree-node-icon--engagement,
.sc-tree-node-icon--engagement {
  background: color-mix(in srgb, var(--ut-component-background-color) 74%, #3d8f86 26%);
  color: #1f665f;
}

.sc-tree-node-icon--workspace,
.sc-tree-node-icon--project-workspace,
.sc-tree-node-icon--project-resource,
.sc-tree-node-icon--project,
.sc-tree-node-icon--project {
  background: color-mix(in srgb, var(--ut-component-background-color) 72%, #4b79c9 28%);
  color: #29569e;
}

.sc-tree-node-icon--resource,
.sc-tree-node-icon--other,
.sc-tree-node-icon--other-workspace,
.sc-tree-node-icon--other-workspace {
  background: color-mix(in srgb, var(--ut-component-background-color) 78%, #758195 22%);
  color: #4d5767;
}

.sc-tree-node-icon--document-workspace,
.sc-tree-node-icon--document-library-resource,
.sc-tree-node-icon--document-resource,
.sc-tree-node-icon--folder,
.sc-tree-node-icon--document,
.sc-tree-node-icon--document {
  background: color-mix(in srgb, var(--ut-component-background-color) 70%, #d29a37 30%);
  color: #8b5f0a;
}

.sc-tree-node-icon--calendar-workspace,
.sc-tree-node-icon--calendar,
.sc-tree-node-icon--booking-page,
.sc-tree-node-icon--booking-page {
  background: color-mix(in srgb, var(--ut-component-background-color) 72%, #3c9b7a 28%);
  color: #1d6f55;
}

.sc-tree-node-icon--communication-workspace,
.sc-tree-node-icon--chat-room,
.sc-tree-node-icon--chat-room {
  background: color-mix(in srgb, var(--ut-component-background-color) 72%, #4f8ea3 28%);
  color: #2b6476;
}

.sc-tree-node-icon--support-workspace,
.sc-tree-node-icon--ticket-queue,
.sc-tree-node-icon--ticket-queue {
  background: color-mix(in srgb, var(--ut-component-background-color) 74%, #c56a58 26%);
  color: #8f3e2f;
}

.sc-tree-node-icon--learning-workspace,
.sc-tree-node-icon--course,
.sc-tree-node-icon--course {
  background: color-mix(in srgb, var(--ut-component-background-color) 72%, #6f7fc8 28%);
  color: #43539a;
}

.sc-tree-node-icon--crm-space,
.sc-tree-node-icon--crm-space {
  background: color-mix(in srgb, var(--ut-component-background-color) 72%, #c06b87 28%);
  color: #8a3e59;
}
