/* CREANODE homepage: hero os */
.home-hero-os-shell {width: max-content;
  max-width: 100%;
  display: grid;
  justify-content: center;
  justify-self: center;
  align-self: flex-start;
  margin-inline: auto;}

.home-hero-expand-toggle {grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 12;
  width: var(--hero-toggle-width);
  height: 100%;
  min-width: 0;
  min-height: 0;
  align-self: stretch;
  padding: 0;
  display: grid;
  place-items: center;
  border: 0;
  border-right: 1px solid rgba(245, 242, 223, .18);
  border-radius: 18px 0 0 18px;
  color: rgba(255, 248, 232, .96);
  background:
    radial-gradient(circle at 52% 18%, rgba(217, 201, 142, .09), transparent 5.8rem),
    linear-gradient(180deg, rgba(245, 242, 223, .075), rgba(21, 25, 20, .42));
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, .06), inset 1px 0 0 rgba(255, 255, 255, .08);
  backdrop-filter: blur(12px) saturate(126%);
  cursor: pointer;
  isolation: isolate;
  transform: none;
  transition:
    background-color .32s var(--ease),
    box-shadow .32s var(--ease),
    opacity .32s ease;}

.home-hero-expand-toggle:hover,
.home-hero-expand-toggle:focus-visible {background:
    radial-gradient(circle at 50% 18%, rgba(217, 201, 142, .14), transparent 6.2rem),
    linear-gradient(180deg, rgba(245, 242, 223, .11), rgba(21, 25, 20, .48));
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, .12), 0 0 32px rgba(217, 201, 142, .08);
  outline: none;}

.home-hero-expand-glow {position: absolute;
  inset: 8px 7px;
  z-index: -1;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(217, 201, 142, .10), transparent 48%, rgba(245, 242, 223, .045));
  opacity: .68;
  pointer-events: none;}

.home-hero-expand-icon {position: relative;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  color: rgba(255, 248, 232, .98);
  background: transparent;
  font-size: 0;
  font-weight: 700;
  line-height: 1;
  box-shadow: none;
  transition: transform 1.15s cubic-bezier(.16, 1, .3, 1), color .3s ease;}

.home-hero-expand-icon::before {content: "<";
  display: block;
  font-size: 2.35rem;
  font-weight: 500;
  line-height: .8;
  letter-spacing: -.08em;
  color: currentColor;
  text-shadow: 0 0 16px rgba(255, 248, 232, .18), 0 0 24px rgba(217, 201, 142, .08);}

.home-hero-expand-icon::after {content: "";
  position: absolute;
  inset: 1px;
  border-radius: 999px;
  border: 1px solid rgba(255, 248, 232, .10);
  pointer-events: none;}

.home-hero-panel {--hero-toggle-width: clamp(50px, 4.2vw, 60px);
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  --look-x: 0px;
  --look-y: 0px;
  position: relative;
  overflow: visible;
  width: clamp(464px, 43.7vw, 568px);
  max-width: 568px;
  justify-self: center;
  min-height: 0;
  height: clamp(367px, 48.6vh, 438px);
  max-height: 438px;
  margin-top: 0;
  display: grid;
  grid-template-columns: var(--hero-toggle-width) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  gap: 0;
  border-radius: 18px;
  padding: 0;
  color: rgba(255, 248, 232, .92);
  background:
    radial-gradient(circle at 76% 16%, rgba(245, 242, 223, .105), transparent 16rem),
    radial-gradient(circle at 42% 42%, rgba(217, 201, 142, .040), transparent 14rem),
    linear-gradient(145deg, rgba(245, 242, 223, .084), rgba(245, 242, 223, .030) 58%, rgba(217, 201, 142, .016));
  border: 1px solid rgba(245, 242, 223, .22);
  box-shadow: 0 24px 72px rgba(0, 0, 0, .32), inset 0 1px 0 rgba(255, 255, 255, .16), inset 0 -1px 0 rgba(0, 0, 0, .22);
  backdrop-filter: blur(12px) saturate(124%);
  transform: perspective(1100px) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) translateZ(0);
  transform-style: preserve-3d;
  cursor: pointer;
  transition:
    width 2.22s cubic-bezier(.16, 1, .3, 1),
    height 2.22s cubic-bezier(.16, 1, .3, 1),
    max-width 2.22s cubic-bezier(.16, 1, .3, 1),
    max-height 2.22s cubic-bezier(.16, 1, .3, 1),
    margin 2.22s cubic-bezier(.16, 1, .3, 1),
    padding 2.22s cubic-bezier(.16, 1, .3, 1),
    border-radius .62s ease,
    border-color .22s var(--ease),
    box-shadow .22s var(--ease),
    transform .3s ease;}

.home-hero-panel-content {grid-column: 2;
  grid-row: 1;
  min-width: 0;
  min-height: 0;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 7px;
  padding: 10px;
  overflow: hidden;}

.home-hero-panel:focus-visible {outline: 2px solid rgba(217, 201, 142, .82);
  outline-offset: 5px;}

.home-hero-panel::before {content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 76% 16%, rgba(245, 242, 223, .095), transparent 16rem),
    radial-gradient(circle at 54% 42%, rgba(217, 201, 142, .045), transparent 13rem),
    linear-gradient(135deg, rgba(255, 255, 255, .055), transparent 42%, rgba(228, 154, 46, .022));
  opacity: .88;}

.home-hero-panel::after {content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(115deg, transparent 31%, rgba(255, 248, 232, .08) 43%, rgba(217, 201, 142, .055) 49%, transparent 62%);
  opacity: .30;
  transform: translate3d(calc(var(--look-x) * .55), calc(var(--look-y) * .55), 0);
  mix-blend-mode: screen;}

.home-hero-panel > * {position: relative;
  z-index: 1;}

.home-panel-top {min-height: 30px;
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr);
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0 2px 6px;
  border-bottom: 1px solid rgba(255, 248, 232, .15);}

.home-panel-window-controls {display: inline-flex;
  gap: 4px;
  align-items: center;}

.home-window-control {position: relative;
  width: 11px;
  height: 11px;
  display: grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  appearance: none;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .22), inset 0 1px 1px rgba(255, 255, 255, .36), 0 0 12px rgba(255, 248, 232, .07);
  transition: transform .25s ease, filter .25s ease, box-shadow .25s ease;}

.home-window-control span {width: 100%;
  height: 100%;
  border-radius: inherit;
  pointer-events: none;}

.home-window-control-close {background: radial-gradient(circle at 36% 28%, rgba(255, 255, 255, .62), transparent 18%), #ff5f57;}

.home-window-control-minimize {background: radial-gradient(circle at 36% 28%, rgba(255, 255, 255, .58), transparent 18%), #ffbd2e;}

.home-window-control-zoom {background: radial-gradient(circle at 36% 28%, rgba(255, 255, 255, .58), transparent 18%), #28c840;}

.home-window-control::before,
.home-window-control::after {content: "";
  position: absolute;
  opacity: .72;
  background: rgba(32, 24, 20, .68);
  transition: opacity .2s ease;}

.home-panel-window-controls:hover .home-window-control::before,
.home-panel-window-controls:hover .home-window-control::after,
.home-window-control:focus-visible::before,
.home-window-control:focus-visible::after {opacity: .9;}

.home-window-control-close::before,
.home-window-control-close::after {width: 6px;
  height: 1.3px;
  border-radius: 99px;}

.home-window-control-close::before {transform: rotate(45deg);}

.home-window-control-close::after {transform: rotate(-45deg);}

.home-window-control-minimize::before {width: 6px;
  height: 1.3px;
  border-radius: 99px;}

.home-window-control-zoom::before {width: 5px;
  height: 5px;
  border-radius: 1.5px;
  background: transparent;
  border: 1.2px solid rgba(32, 24, 20, .68);}

.home-window-control:hover,
.home-window-control:focus-visible {transform: scale(1.12);
  filter: saturate(1.12) brightness(1.05);
  outline: none;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .28), inset 0 1px 1px rgba(255, 255, 255, .42), 0 0 16px rgba(255, 248, 232, .12);}

.home-panel-top > span {font-size: .62rem;
  font-weight: 700;
  letter-spacing: .14em;
  color: #fffbea;
  text-shadow: 0 0 18px rgba(255, 248, 232, .16);
  white-space: nowrap;}

.home-panel-top strong {justify-self: end;
  max-width: 150px;
  color: rgba(255, 248, 232, .78);
  font-size: .50rem;
  font-weight: 500;
  line-height: 1.12;
  text-align: right;
  text-transform: uppercase;
  letter-spacing: .07em;}

.home-panel-bottom {display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  padding-top: 5px;
  border-top: 1px solid rgba(255, 248, 232, .15);}

.home-panel-bottom span {min-height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3px 4px;
  border-radius: 8px;
  color: rgba(255, 248, 232, .80);
  font-size: .48rem;
  line-height: 1.05;
  background: rgba(255, 248, 232, .034);
  border: 1px solid rgba(255, 248, 232, .09);}

.home-os-workspace {display: none;
  min-height: 0;
  opacity: 0;
  grid-template-columns: minmax(150px, 210px) minmax(0, 1fr);
  gap: 12px;
  transition: opacity .85s ease .48s;}

.home-os-sidebar,
.home-os-main,
.home-os-status,
.home-os-app {border: 1px solid rgba(255, 248, 232, .12);
  background: rgba(5, 6, 4, .18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .075);}

.home-os-sidebar {min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 12px;
  border-radius: 16px;}

.home-os-sidebar-label {margin-bottom: 6px;
  color: rgba(217, 201, 142, .92);
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;}

.home-os-nav {min-height: 38px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  border: 1px solid rgba(255, 248, 232, .11);
  border-radius: 12px;
  padding: 0 11px;
  color: rgba(255, 248, 232, .78);
  background: rgba(255, 248, 232, .035);
  font: inherit;
  font-size: .78rem;
  cursor: default;}

.home-os-nav.is-active {color: #080907;
  background: linear-gradient(135deg, #fffbea, #d9c98e 58%, #e49a2e);
  border-color: rgba(255, 248, 232, .24);
  box-shadow: 0 14px 36px rgba(228, 154, 46, .12);}

.home-os-main {min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
  padding: 12px;
  border-radius: 18px;}

.home-os-status {min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 12px 14px;
  border-radius: 15px;
  background:
    radial-gradient(circle at 86% 22%, rgba(217, 201, 142, .09), transparent 9rem),
    rgba(255, 248, 232, .035);}

.home-os-status span {display: block;
  margin-bottom: 5px;
  color: rgba(217, 201, 142, .94);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .16em;}

.home-os-status strong {color: rgba(255, 248, 232, .98);
  font-size: clamp(.92rem, 1.4vw, 1.3rem);
  letter-spacing: -.025em;}

.home-os-status p {max-width: 340px;
  margin: 0;
  color: rgba(255, 248, 232, .68);
  font-size: .74rem;
  line-height: 1.45;
  text-align: right;}

.home-os-app-grid {min-height: 0;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-content: stretch;}

.home-os-app {min-height: 108px;
  display: grid;
  align-content: start;
  gap: 7px;
  border-radius: 17px;
  padding: 13px;
  color: rgba(255, 248, 232, .88);
  font: inherit;
  text-align: left;
  cursor: default;
  transition: border-color .22s ease, background-color .22s ease, transform .22s ease;}

.home-os-app:hover,
.home-os-app:focus-visible {transform: translateY(-2px);
  border-color: rgba(255, 248, 232, .24);
  background: rgba(255, 248, 232, .055);
  outline: none;}

.home-os-app span {width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 13px;
  color: #080907;
  background: linear-gradient(135deg, #fffbea, #d9c98e 58%, #e49a2e);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .06em;
  box-shadow: 0 13px 34px rgba(228, 154, 46, .14);}

.home-os-app strong {color: rgba(255, 248, 232, .98);
  font-size: .86rem;
  line-height: 1.12;
  letter-spacing: -.02em;}

.home-os-app small {color: rgba(255, 248, 232, .64);
  font-size: .68rem;
  line-height: 1.28;}

.home-hero.is-os-expanded .sticky-scroll-copy {z-index: 13;
  pointer-events: none;}

.home-hero.is-os-expanded .sticky-scroll-copy-inner {opacity: 0;
  filter: blur(5px);
  transform: translate3d(0, -128vh, 0) !important;}

.home-hero.is-os-expanded .home-hero-os-shell {width: min(1500px, calc(100vw - (var(--page-gutter) * 2)));
  max-width: 1500px;
  grid-template-columns: minmax(0, 1fr);
  justify-content: center;}

.home-hero.is-os-expanded .sticky-scroll-track {grid-column: 1 / -1;
  grid-row: 1;
  z-index: 8;
  justify-items: center;}

.home-hero.is-os-expanded .sticky-scroll-item:first-child {width: 100%;
  min-height: min(78vh, 720px);
  justify-content: center;
  align-items: flex-start;}

.home-hero.is-os-expanded .home-hero-panel {grid-column: 1;
  grid-template-columns: minmax(0, 1fr);
  width: 100%;
  max-width: none;
  height: clamp(500px, 70vh, 650px);
  max-height: calc(100vh - 122px);
  margin-top: clamp(-20px, -2vh, -8px);
  padding: 0;
  border-radius: 24px;
  cursor: default;
  transform: none !important;
  box-shadow: 0 34px 110px rgba(0, 0, 0, .42), 0 0 54px rgba(217, 201, 142, .055), inset 0 1px 0 rgba(255, 255, 255, .16), inset 0 -1px 0 rgba(0, 0, 0, .24);}

.home-hero.is-os-expanded .home-hero-panel-content {grid-column: 1;
  padding: 14px;
  gap: 10px;}

.home-hero.is-os-expanded .home-hero-os-shell::after {display: none;}

.home-hero.is-os-expanded .home-hero-expand-toggle {display: none;}

.home-hero.is-os-expanded .home-hero-expand-toggle:hover,
.home-hero.is-os-expanded .home-hero-expand-toggle:focus-visible {transform: translate3d(-3px, 0, 0);}

.home-hero.is-os-expanded .home-hero-expand-icon {transform: none;}

.home-hero.is-os-expanded .home-panel-top {min-height: 42px;
  padding: 0 4px 10px;}

.home-hero.is-os-expanded .home-window-control {width: 13px;
  height: 13px;}

.home-hero.is-os-expanded .home-panel-top > span {font-size: .74rem;}

.home-hero.is-os-expanded .home-panel-top strong {max-width: none;
  font-size: .58rem;}

.home-hero.is-os-expanded .home-os-workspace {display: grid;
  opacity: 1;
  pointer-events: auto;}

.home-hero.is-os-expanded .home-panel-bottom {grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding-top: 8px;}

.home-hero.is-os-expanded .home-panel-bottom span {min-height: 34px;
  font-size: .62rem;}

.home-hero.is-os-expanded .home-hero-expand-icon::before {content: ">";
  letter-spacing: -.05em;}

html.home-os-scroll-lock,
body.home-os-scroll-lock {overflow: hidden;
  overscroll-behavior: none;}

.home-story.home-hero.is-os-expanded .sticky-scroll-track,
.home-story.is-os-expanded .home-story-track {grid-column: 1 / -1;
  grid-row: 1;
  z-index: 8;
  justify-items: center;}

.home-story.home-hero.is-os-expanded .sticky-scroll-item:not(:first-child) {display: none;}

.home-hero-panel {height: clamp(400px, 50.8vh, 473px);
  max-height: 473px;
  background:
    radial-gradient(circle at 74% 14%, rgba(217, 201, 142, .12), transparent 16rem),
    radial-gradient(circle at 36% 52%, rgba(245, 242, 223, .055), transparent 15rem),
    linear-gradient(145deg, rgba(245, 242, 223, .088), rgba(245, 242, 223, .030) 58%, rgba(228, 154, 46, .018));
  border-color: rgba(245, 242, 223, .25);}

.home-hero-panel-content {grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 8px;}

.home-panel-top {border-bottom-color: rgba(217, 201, 142, .18);}

.home-panel-top strong {color: rgba(255, 248, 232, .72);}

.home-os-preview {position: relative;
  min-height: 0;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 9px;
  padding: 10px;
  border: 1px solid rgba(255, 248, 232, .12);
  border-radius: 16px;
  overflow: hidden;
  background:
    radial-gradient(circle at 80% 14%, rgba(217, 201, 142, .13), transparent 10rem),
    radial-gradient(circle at 18% 82%, rgba(245, 242, 223, .060), transparent 10rem),
    rgba(5, 6, 4, .20);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .075);}

.home-os-preview::before {content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(245, 242, 223, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245, 242, 223, .040) 1px, transparent 1px);
  background-size: 34px 34px;
  opacity: .32;
  mask-image: radial-gradient(circle at 72% 38%, black, transparent 78%);
  pointer-events: none;}

.home-os-preview > * {position: relative;
  z-index: 1;}

.home-os-preview-header {display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;}

.home-os-preview-header span {color: rgba(217, 201, 142, .95);
  font-size: .58rem;
  font-weight: 850;
  letter-spacing: .16em;
  text-transform: uppercase;}

.home-os-preview-header strong {max-width: 210px;
  color: rgba(255, 248, 232, .88);
  font-size: .68rem;
  line-height: 1.16;
  text-align: right;}

.home-os-preview-grid {display: grid;
  grid-template-columns: 1.12fr .92fr .92fr;
  gap: 7px;
  align-content: stretch;}

.home-os-preview-card {min-height: 116px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 5px;
  padding: 10px;
  border: 1px solid rgba(245, 242, 223, .12);
  border-radius: 13px;
  background: rgba(255, 248, 232, .040);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .07);}

.home-os-preview-card.is-active {border-color: rgba(217, 201, 142, .31);
  background:
    radial-gradient(circle at 28% 18%, rgba(217, 201, 142, .14), transparent 7rem),
    rgba(255, 248, 232, .052);
  box-shadow: 0 16px 44px rgba(0, 0, 0, .16), inset 0 1px 0 rgba(255, 255, 255, .08);}

.home-os-preview-card small {margin-bottom: auto;
  color: rgba(217, 201, 142, .90);
  font-size: .54rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;}

.home-os-preview-card strong {color: rgba(255, 248, 232, .98);
  font-size: .78rem;
  line-height: 1.06;}

.home-os-preview-card span {color: rgba(255, 248, 232, .65);
  font-size: .58rem;
  line-height: 1.20;}

.home-os-preview-metrics {display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;}

.home-os-preview-metrics span {min-height: 44px;
  display: grid;
  align-content: center;
  gap: 2px;
  padding: 7px 8px;
  border: 1px solid rgba(245, 242, 223, .10);
  border-radius: 11px;
  background: rgba(255, 248, 232, .034);}

.home-os-preview-metrics strong {color: rgba(255, 248, 232, .92);
  font-size: .62rem;
  line-height: 1;}

.home-os-preview-metrics small {color: rgba(255, 248, 232, .55);
  font-size: .50rem;
  line-height: 1.12;}

.home-os-dashboard {display: grid;
  grid-template-columns: minmax(0, 1.25fr) repeat(2, minmax(0, .62fr));
  gap: 10px;}

.home-os-dashboard-card {min-height: 88px;
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 12px;
  border: 1px solid rgba(245, 242, 223, .12);
  border-radius: 15px;
  background: rgba(255, 248, 232, .034);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .065);}

.home-os-dashboard-card-wide {align-content: start;}

.home-os-dashboard-card small {color: rgba(217, 201, 142, .88);
  font-size: .58rem;
  font-weight: 850;
  letter-spacing: .13em;
  text-transform: uppercase;}

.home-os-dashboard-card strong {color: rgba(255, 248, 232, .96);
  font-size: clamp(.92rem, 1.15vw, 1.22rem);
  line-height: 1.06;}

.home-os-dashboard-card p {margin: 0;
  color: rgba(255, 248, 232, .62);
  font-size: .68rem;
  line-height: 1.24;}

.home-os-flow-line {display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5px;
  margin-top: 4px;}

.home-os-flow-line span {height: 5px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(217, 201, 142, .86), rgba(245, 242, 223, .26));
  box-shadow: 0 0 18px rgba(217, 201, 142, .12);}

.home-os-app.is-selected {border-color: rgba(217, 201, 142, .32);
  background:
    radial-gradient(circle at 80% 18%, rgba(217, 201, 142, .11), transparent 8rem),
    rgba(255, 248, 232, .058);}

.home-hero.is-os-expanded .home-os-preview {display: none;}

.home-hero.is-os-expanded .home-os-workspace {grid-template-columns: minmax(150px, 206px) minmax(0, 1fr);}

.home-hero.is-os-expanded .home-os-main {grid-template-rows: auto auto minmax(0, 1fr);}
