:root {
  --ink: #18181b;
  --muted: #71717a;
  --soft: #a1a1aa;
  --panel: #fafafa;
  --line: #e4e4e7;
  --content: 1392px;
  --viewport-width: 100vw;
  --side: max(24px, calc((var(--viewport-width) - var(--content)) / 2));
  --wide-offset: calc(var(--side) - 264px);
  --share-left: calc(var(--side) - 444px);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --modal-frost-bg: rgba(255, 255, 255, 0.74);
  --modal-frost-blur: blur(22px);
  --hero-copy-y: 0px;
  --hero-board-y: 0px;
  --hero-accent-y: 0px;
  --hero-fade: 1;
  --scroll-progress: 0;
  --footer-top: 4836px;
  --design-height: 5540px;
  --section-title-top: 48px;
  --section-title-size: 48px;
  --section-title-line: 84px;
  --feature-head-left: calc(var(--side) + 368px);
  --feature-head-top: 940px;
  --feature-head-width: 655px;
  --feature-head-height: 132px;
  --feature-kicker-left: 255.5px;
  --feature-accent-left: 655px;
  --feature-accent-top: 30px;
  --layout-head-left: calc(var(--side) + 408px);
  --layout-head-top: 2012px;
  --layout-head-width: 576px;
  --layout-head-height: 132px;
  --layout-kicker-left: 216px;
  --layout-accent-left: 576px;
  --layout-accent-top: 30px;
  --share-head-left: calc(var(--side) + 480px);
  --share-head-top: 3090px;
  --share-head-width: 432px;
  --share-head-height: 132px;
  --share-kicker-left: 120px;
  --share-accent-left: 444px;
  --share-accent-top: 42px;
  /* FAQ 标题居中：块整体右移至 504，内部 kicker/title/accent 与 Figma 1440 对齐 */
  --faq-head-left: calc(var(--side) + 480px);
  --faq-head-top: 4102px;
  --faq-head-width: 480px;
  --faq-head-height: 136px;
  --faq-title-top: 52px;
  --faq-kicker-left: 144px;
  --faq-accent-left: 432px;
  --faq-accent-top: 28px;
  --features-left: var(--side);
  --features-top: 1108px;
  --features-width: var(--content);
  --features-height: 744px;
  --feature-card-width: 684px;
  --feature-card-height: 360px;
  --feature-card-gap-x: 24px;
  --feature-card-gap-y: 24px;
  --feature-card-1-left: 0px;
  --feature-card-1-top: 0px;
  --feature-card-2-left: calc(var(--feature-card-width) + var(--feature-card-gap-x));
  --feature-card-2-top: 0px;
  --feature-card-3-left: 0px;
  --feature-card-3-top: calc(var(--feature-card-height) + var(--feature-card-gap-y));
  --feature-card-4-left: calc(var(--feature-card-width) + var(--feature-card-gap-x));
  --feature-card-4-top: calc(var(--feature-card-height) + var(--feature-card-gap-y));
  --feature-pattern-left: 174px;
  --feature-pattern-alt-left: 174px;
  --feature-shot-left: 342px;
  --feature-shot-top: 24px;
  --feature-copy-width: 580px;
  --layout-toggle-left: calc(var(--side) + 562px);
  --layout-toggle-top: 2156px;
  --layout-demo-left: var(--side);
  --layout-demo-top: 2252px;
  --layout-demo-width: var(--content);
  --layout-demo-height: 678px;
  --layout-column-1-left: 60px;
  --layout-column-1-top: -271px;
  --layout-column-2-left: 384px;
  --layout-column-2-top: -149px;
  --layout-column-3-left: 708px;
  --layout-column-3-top: -321px;
  --layout-column-4-left: 1032px;
  --layout-column-4-top: -199px;
  --layout-panel-left: 396px;
  --layout-panel-top: 169px;
  --sidebar-column-1-left: 60px;
  --sidebar-column-1-top: -235px;
  --sidebar-column-2-left: 382px;
  --sidebar-column-2-top: -381px;
  --sidebar-column-3-left: 708px;
  --sidebar-column-3-top: -334px;
  --layout-sidebar-panel-left: 1032px;
  --layout-sidebar-panel-top: 24px;
  --share-row-left: var(--share-left);
  --share-row-top: 3258px;
  --share-row-gap: 24px;
  --share-row-height: 684px;
  --share-card-width: 360px;
  --share-card-height: 684px;
  --share-marquee-distance: -3456px;
  --faq-left: var(--side);
  --faq-top: 4270px;
  --faq-width: var(--content);
  --faq-col-width: 684px;
  --faq-col-gap: 24px;
  --footer-left: var(--side);
  --footer-width: var(--content);
  --footer-height: 536px;
  --footer-art-width: var(--content);
  --footer-wordmark-left: 36px;
  --footer-wordmark-top: 404px;
  --footer-wordmark-width: 1320px;
  --footer-wordmark-height: 220px;
  --footer-legal-left: 583px;
  --footer-social-left: 1224px;
  background: #fff;
  color: var(--ink);
  font-family: "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

/* AI workbench landing page */
.workbench-page {
  overflow-x: hidden;
  min-width: 1440px;
  padding-top: 36px;
  background: #fff;
}

.workbench {
  position: relative;
  min-height: 100vh;
  overflow: visible;
  color: #27272a;
  background:
    linear-gradient(180deg, #fafafa 0, rgba(250, 250, 250, 0) 780px),
    #fff;
}

.workbench-page .inspiration-nav {
  left: 209px;
  width: 420px;
  transform: none;
}

.workbench-page .inspiration-header {
  left: var(--side);
  width: var(--content);
}

.workbench-page .inspiration-header .inspiration-search {
  left: 986px;
}

.workbench-page .inspiration-header .inspiration-download-wrap,
.workbench-page .inspiration-download-wrap {
  left: 1274px;
}

.workbench-hero,
.workbench-tools,
.workbench-feature,
.workbench-cta,
.workbench-footer {
  width: min(1392px, calc(100vw - 48px));
  margin-right: auto;
  margin-left: auto;
}

.workbench-hero {
  position: relative;
  min-height: 1305px;
  padding-top: 120px;
}

.workbench-hero::before,
.workbench-hero::after {
  display: none;
  content: none;
}

.workbench-hero-butterfly {
  position: absolute;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  user-select: none;
  will-change: transform;
}

.workbench-hero-butterfly img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.workbench-hero-butterfly::after {
  position: absolute;
  inset: 0;
  content: "";
  pointer-events: none;
  background: linear-gradient(110deg, transparent 0 36%, rgba(255, 255, 255, 0.04) 42%, rgba(255, 255, 255, 0.5) 48%, rgba(232, 121, 249, 0.22) 52%, transparent 61%);
  mix-blend-mode: screen;
  opacity: 0;
  transform: translate3d(-120%, 0, 0) skewX(-10deg);
  animation: workbench-butterfly-scan 5.8s cubic-bezier(0.25, 1, 0.5, 1) infinite;
  will-change: transform, opacity;
}

.workbench-hero-butterfly-large {
  top: 46px;
  right: max(24px, calc((100vw - 1392px) / 2));
  width: 360px;
  height: 360px;
  animation: workbench-butterfly-mech-large 7.4s steps(1, end) infinite;
}

.workbench-hero-butterfly-large::after {
  -webkit-mask: url("./assets/workbench/hero-butterfly-dots-large.png") center / contain no-repeat;
  mask: url("./assets/workbench/hero-butterfly-dots-large.png") center / contain no-repeat;
}

.workbench-hero-butterfly-small {
  top: 250.212px;
  right: max(315.349px, calc((100vw - 1392px) / 2 + 291.349px));
  width: 237.651px;
  height: 237.651px;
  animation: workbench-butterfly-mech-small 6.2s steps(1, end) -1.35s infinite;
}

.workbench-hero-butterfly-small::after {
  -webkit-mask: url("./assets/workbench/hero-butterfly-dots-small.png") center / contain no-repeat;
  mask: url("./assets/workbench/hero-butterfly-dots-small.png") center / contain no-repeat;
  animation-delay: -2.15s;
}

.workbench-dot {
  position: absolute;
  width: 405px;
  height: 405px;
  object-fit: cover;
  opacity: 0.22;
  pointer-events: none;
  mix-blend-mode: multiply;
}

.workbench-hero-copy {
  position: relative;
  z-index: 2;
  width: 740px;
  padding-left: 118px;
  will-change: transform;
}

.workbench-kicker {
  margin: 0 0 4px;
  font-size: 54px;
  font-weight: 600;
  line-height: 72px;
  color: transparent;
  background: url("./assets/figma/title-gradient.webp") center / cover no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
}

.workbench-hero h1,
.workbench-section-head h2,
.workbench-feature-copy h2,
.workbench-cta h2 {
  margin: 0;
  color: #27272a;
  font-weight: 600;
  letter-spacing: 0;
  text-wrap: balance;
}

.workbench-hero h1 {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 54px;
  line-height: 72px;
}

.workbench-hero h1 span {
  display: block;
}

.workbench-hero h1 span:first-child {
  color: transparent;
  background: url("./assets/figma/title-gradient.webp") 0% 50% / 168% 100% no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  animation: title-gradient-flow 6.8s var(--ease-out-quart) infinite alternate;
  will-change: background-position;
}

.workbench-hero-copy > p:not(.workbench-kicker) {
  width: 684px;
  margin: 16px 0 0;
  color: #71717a;
  font-size: 16px;
  line-height: 24px;
  text-wrap: pretty;
}

.workbench-actions {
  display: flex;
  gap: 16px;
  margin-top: 24px;
}

.workbench-primary,
.workbench-secondary,
.workbench-feature-copy a,
.workbench-cta-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 49px;
  min-width: 160px;
  padding: 0 30px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 500;
  line-height: 20px;
  white-space: nowrap;
  transition:
    color 180ms var(--ease-out-quart),
    border-color 220ms var(--ease-out-quart),
    background-color 220ms var(--ease-out-quart),
    transform 180ms var(--ease-out-quart);
}

.workbench-primary {
  color: #fff;
  background: #27272a;
}

.workbench-secondary,
.workbench-feature-copy a,
.workbench-cta-actions a + a {
  color: #52525b;
  border: 1px solid #d4d4d8;
  background: #fafafa;
}

.workbench-primary:hover,
.workbench-primary:focus-visible,
.workbench-secondary:hover,
.workbench-secondary:focus-visible,
.workbench-feature-copy a:hover,
.workbench-feature-copy a:focus-visible,
.workbench-cta-actions a:hover,
.workbench-cta-actions a:focus-visible {
  outline: none;
}

.workbench-primary:hover,
.workbench-primary:focus-visible {
  color: rgba(255, 255, 255, 0.6);
  background: #27272a;
  transform: translate3d(0, 0, 0);
}

.workbench-primary:active {
  transform: translate3d(0, 0, 0) scale(0.98);
}

.workbench-secondary:hover,
.workbench-secondary:focus-visible,
.workbench-feature-copy a:hover,
.workbench-feature-copy a:focus-visible,
.workbench-cta-actions a + a:hover,
.workbench-cta-actions a + a:focus-visible {
  color: #a1a1aa;
}

.workbench-cta-actions a + a:hover,
.workbench-cta-actions a + a:focus-visible {
  border-color: #27272a;
}

.workbench-demo {
  position: relative;
  height: 680px;
  margin-top: 60px;
  overflow: visible;
  border-radius: 16px;
  background: url("./assets/workbench/hero-gradient.jpg") center / cover no-repeat;
  box-shadow: none;
  will-change: transform;
}

.workbench-panel {
  position: absolute;
  z-index: 4;
  left: 118px;
  top: 48px;
  width: 300px;
  height: 632px;
  overflow: hidden;
  background: transparent;
  box-shadow: none;
  will-change: transform;
}

.workbench-panel img {
  display: block;
  width: 100%;
  height: auto;
}

.workbench-stage-image {
  position: absolute;
  z-index: 2;
  left: 234px;
  top: 80px;
  width: 924px;
  height: 600px;
  overflow: hidden;
  border-radius: 0 16px 0 0;
}

.workbench-stage-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.workbench-select-frame {
  position: absolute;
  z-index: 5;
  left: 818px;
  top: 56px;
  width: 448px;
  height: 312px;
  border: 1.5px solid rgba(255, 255, 255, 0.98);
  background: rgba(255, 255, 255, 0.2);
  will-change: transform;
}

.workbench-select-frame span {
  position: absolute;
  width: 16px;
  height: 16px;
  border: 1.5px solid #fff;
  border-radius: 4px;
  background: #e879f9;
  box-shadow: none;
}

.workbench-select-frame span:nth-child(1) {
  left: -9px;
  top: -9px;
}

.workbench-select-frame span:nth-child(2) {
  right: -9px;
  top: -9px;
}

.workbench-select-frame span:nth-child(3) {
  left: -9px;
  bottom: -9px;
}

.workbench-select-frame span:nth-child(4) {
  right: -9px;
  bottom: -9px;
}

.workbench-arrow {
  position: absolute;
  left: calc(50% + 34px);
  top: -132px;
  z-index: 6;
  display: block;
  width: 136px;
  height: 90px;
  pointer-events: none;
  overflow: visible;
  background: transparent;
  transform: rotate(-160deg);
}

.workbench-tools {
  padding: 0 118px 108px;
}

.workbench-section-head {
  margin-bottom: 36px;
}

.workbench-label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 12px;
  color: #52525b;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
}

.workbench-label::before {
  display: inline-block;
  width: 36px;
  height: 36px;
  flex: 0 0 36px;
  content: "";
  border: 0;
  border-radius: 0;
  background: url("./assets/workbench/icon-painting-ai.svg") center / contain no-repeat;
  box-shadow: none;
}

.workbench-label-tools::before {
  background-image: url("./assets/workbench/icon-painting-ai.svg?v=20260604-workbench-figma-2");
}

.workbench-label-prompt::before {
  background-image: url("./assets/remote/b53c88c7-241a-4cf6-be87-3d356ebe9f57.svg?v=20260604-workbench-figma-2");
}

.workbench-label-process::before {
  background-image: url("./assets/workbench/ai-generate-3d-line.svg?v=20260604-workbench-figma-3");
}

.workbench-label-workflow::before {
  background-image: url("./assets/workbench/loop-right-ai-line.svg?v=20260604-workbench-figma-3");
}

.workbench-section-head h2,
.workbench-feature-copy h2 {
  font-size: 48px;
  line-height: 60px;
}

.workbench-tool-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.workbench-tool-card {
  overflow: hidden;
  min-height: 420px;
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: #fafafa;
  box-shadow: none;
  transition:
    transform 320ms var(--ease-out-quart),
    box-shadow 320ms var(--ease-out-quart),
    border-color 320ms var(--ease-out-quart);
}

.workbench-tool-card:hover {
  border-color: #e4e4e7;
  box-shadow: none;
  transform: translate3d(0, -6px, 0);
}

.workbench-tool-media {
  position: relative;
  height: 280px;
  overflow: hidden;
  background: #fafafa;
  border-radius: 12px 12px 0 0;
}

.workbench-tool-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 700ms var(--ease-out-quart);
}

.workbench-tool-media-ascii img {
  object-position: center 43%;
}

.workbench-tool-media-compare img {
  object-position: center 28%;
}

.workbench-tool-card:hover .workbench-tool-media img {
  transform: scale(1.045);
}

.workbench-tool-card:hover .workbench-tool-media img.workbench-svg-icon {
  transform: none;
}

.workbench-tool-media-composite img {
  object-position: center;
}

.workbench-tool-media-composite::before,
.workbench-tool-media-composite::after {
  display: none;
}

.workbench-tool-media-ascii::after {
  position: absolute;
  left: 244px;
  top: 14px;
  z-index: 1;
  width: 276px;
  height: 276px;
  content: "";
  opacity: 0.88;
  background: url("./assets/workbench/dot-pattern.svg") center / 276px 276px no-repeat;
  filter: drop-shadow(0 10px 22px rgba(255, 255, 255, 0.28));
  animation: workbench-card-dot-float 7s var(--ease-out-quart) infinite;
  will-change: transform, opacity;
}

.workbench-tool-media-ascii::before {
  position: absolute;
  left: 20px;
  top: 92px;
  z-index: 2;
  --workbench-dot-rotate: 180deg;
  width: 156px;
  height: 156px;
  content: "";
  opacity: 0.82;
  background: url("./assets/workbench/dot-pattern.svg") center / 156px 156px no-repeat;
  filter: drop-shadow(0 8px 18px rgba(255, 255, 255, 0.24));
  transform: rotate(var(--workbench-dot-rotate));
  animation: workbench-card-dot-float 8.6s var(--ease-out-quart) -2.4s infinite;
  will-change: transform, opacity;
}

.workbench-tool-media-ascii span {
  position: absolute;
  z-index: 3;
  left: 24px;
  top: 24px;
  color: transparent;
  background: linear-gradient(90deg, #fff 0%, rgba(255, 255, 255, 0.32) 58%, rgba(255, 255, 255, 0) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  font-family: "Lora", Georgia, serif;
  font-size: 40px;
  font-style: italic;
  font-weight: 600;
  line-height: 60px;
}

.workbench-tool-media-compare::before {
  position: absolute;
  inset: 0 auto 0 0;
  z-index: 1;
  width: 50%;
  content: "";
  background: rgba(0, 0, 0, 0.3);
  pointer-events: none;
}

.workbench-tool-media-compare::after {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  z-index: 2;
  width: 1px;
  content: "";
  background: rgba(255, 255, 255, 0.64);
  transform: translateX(-0.5px);
}

.workbench-before-after {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.76);
  border-radius: 50%;
  background: rgba(120, 130, 126, 0.78);
  font-size: 15px;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  transform: translate(-50%, -50%);
}

.workbench-tool-media-frame::before,
.workbench-tool-media-frame::after {
  position: absolute;
  z-index: 2;
  content: "";
  pointer-events: none;
}

.workbench-tool-media-frame::before {
  inset: 24px;
  border: 2px dashed rgba(255, 255, 255, 0.82);
}

.workbench-tool-media-frame::after {
  inset: 0;
  background:
    radial-gradient(circle at 24px 24px, #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    radial-gradient(circle at calc(100% - 24px) 24px, #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    radial-gradient(circle at 24px 50%, #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    radial-gradient(circle at calc(100% - 24px) 50%, #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    radial-gradient(circle at 24px calc(100% - 24px), #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    radial-gradient(circle at calc(100% - 24px) calc(100% - 24px), #71717a 0 5px, rgba(255, 255, 255, 0.9) 5px 7px, transparent 7px),
    linear-gradient(90deg, rgba(0, 0, 0, 0.08), rgba(255, 255, 255, 0.04));
}

.workbench-detect-char {
  position: absolute;
  z-index: 3;
  top: 50%;
  color: rgba(255, 255, 255, 0.92);
  color: transparent;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 50%, rgba(255, 255, 255, 0) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  font-size: 160px;
  font-weight: 600;
  line-height: 1;
  transform: translateY(-50%);
  pointer-events: none;
}

.workbench-detect-char-left {
  left: 88px;
}

.workbench-detect-char-right {
  right: 84px;
  opacity: 0.82;
}

.workbench-tool-media-svg::before {
  display: none;
}

.workbench-svg-line {
  position: absolute;
  z-index: 2;
  left: 0;
  top: 139px;
  width: 100%;
  height: 0;
  border-top: 2px dashed rgba(255, 255, 255, 0.78);
}

.workbench-svg-icon {
  position: absolute;
  z-index: 3;
  width: auto;
  height: auto;
  object-fit: contain;
}

.workbench-tool-media img.workbench-svg-icon {
  transition: none;
}

.workbench-tool-media img.workbench-svg-icon-left {
  left: calc(25.6% - 22px);
  top: 118px;
  width: 44px;
  height: 44px;
}

.workbench-tool-media img.workbench-svg-icon-center {
  left: calc(50% - 36px);
  top: 104px;
  width: 72px;
  height: 72px;
}

.workbench-tool-media img.workbench-svg-icon-right {
  left: calc(74.4% - 22px);
  top: 118px;
  width: 44px;
  height: 44px;
}

.workbench-tool-card h3 {
  margin: 26px 24px 0;
  color: #27272a;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
  text-wrap: balance;
}

.workbench-tool-card p {
  margin: 10px 24px 26px;
  color: #a1a1aa;
  font-size: 16px;
  line-height: 24px;
  text-wrap: pretty;
}

.workbench-tool-launch {
  display: inline-flex;
  min-height: 36px;
  align-items: center;
  justify-content: center;
  margin: -8px 24px 26px;
  padding: 0 16px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #52525b;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  transition: border-color 0.2s ease, background 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.workbench-tool-launch:hover,
.workbench-tool-launch:focus-visible {
  border-color: #d4d4d8;
  background: #fafafa;
  color: #27272a;
  outline: none;
  transform: translateY(-1px);
}

.workbench-feature {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 448px) minmax(0, 566px);
  gap: 142px;
  align-items: start;
  padding: 0 118px;
  isolation: isolate;
}

.workbench-feature-prompt {
  margin-top: 50px;
  align-items: center;
}

.workbench-feature::before {
  position: absolute;
  z-index: -1;
  width: 405px;
  height: 405px;
  content: "";
  opacity: 1;
  pointer-events: none;
  background: url("./assets/workbench/dot-pattern-solid.svg") center / 405px 405px no-repeat;
}

.workbench-feature-prompt::before {
  right: 0;
  bottom: -92px;
}

.workbench-feature-reverse::before {
  left: -24px;
  bottom: -96px;
  transform: scaleX(-1);
}

.workbench-workflow::before {
  display: none;
}

.workbench-feature-reverse {
  grid-template-columns: minmax(0, 566px) minmax(0, 448px);
  margin-top: 160px;
}

.workbench-workflow {
  display: block;
  margin-top: 160px;
  min-height: calc(100vh + 1040px);
}

.workbench-workflow-sticky {
  position: sticky;
  top: max(86px, calc((100vh - 566px) / 2));
  display: grid;
  grid-template-columns: minmax(0, 480px) minmax(0, 566px);
  gap: 110px;
  align-items: start;
  isolation: isolate;
}

.workbench-workflow-sticky::before {
  position: absolute;
  right: -118px;
  top: -116px;
  z-index: -1;
  width: 405px;
  height: 405px;
  content: "";
  opacity: 1;
  pointer-events: none;
  background: url("./assets/workbench/dot-pattern-solid.svg") center / 405px 405px no-repeat;
  transform: scaleY(-1);
}

.workbench-feature-prompt .workbench-feature-copy {
  padding-top: 0;
}

.workbench-feature-copy h2 span,
.workbench-cta h2 span {
  display: block;
  white-space: nowrap;
}

.workbench-feature-reverse .workbench-feature-copy {
  padding-top: 86px;
}

.workbench-workflow .workbench-feature-copy {
  padding-top: 67px;
}

.workbench-workflow .workbench-feature-copy h2 {
  width: max-content;
  max-width: 100%;
  white-space: nowrap;
}

.workbench-feature-copy p:not(.workbench-label) {
  width: min(448px, 100%);
  margin: 16px 0 0;
  color: #71717a;
  font-size: 16px;
  line-height: 24px;
  text-wrap: pretty;
}

.workbench-feature-copy a {
  height: 49px;
  min-width: 160px;
  margin-top: 24px;
  padding: 0 24px;
  border-radius: 8px;
  font-size: 16px;
}

.workbench-feature-image {
  position: relative;
  overflow: hidden;
  height: 566px;
  margin: 0;
  border-radius: 12px;
  background: #f4f4f5;
  box-shadow: none;
}

.workbench-feature-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.workbench-feature-image-garden img {
  object-position: center 42%;
}

.workbench-feature-image-blue {
  background: #23a8ff;
}

.workbench-feature-image-blue::after {
  position: absolute;
  inset: 0;
  content: "";
  background:
    radial-gradient(circle at 20% 20%, rgba(255, 255, 255, 0.26), transparent 18%),
    linear-gradient(180deg, rgba(14, 165, 233, 0.12), transparent 42%);
}

.workbench-feature-image-soft img {
  object-position: center 32%;
}

.workbench-workflow .workbench-feature-image {
  box-shadow: none;
}

.workbench-steps {
  width: min(480px, 100%);
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}

.workbench-steps li {
  position: relative;
  display: block;
  padding: 15px 0 16px;
  border-bottom: 1px solid #f4f4f5;
  opacity: 1;
  transform: none;
  transition:
    border-color 320ms var(--ease-out-quart);
}

.workbench-steps li::before {
  position: absolute;
  left: 0;
  top: 14px;
  width: 35px;
  height: 36px;
  content: "";
  opacity: 0;
  transform: scale(0.76);
  transform-origin: center;
  background: url("./assets/workbench/workflow-accent.svg") center / contain no-repeat;
  transition:
    opacity 260ms var(--ease-out-quart),
    transform 360ms var(--ease-out-quint);
}

.workbench-steps li.is-active {
  border-color: #f4f4f5;
}

.workbench-steps li.is-active::before {
  opacity: 1;
  transform: scale(1);
}

.workbench-steps strong {
  display: block;
  color: #27272a;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
  transition:
    color 240ms var(--ease-out-quart),
    padding-left 320ms var(--ease-out-quart);
}

.workbench-steps span {
  display: block;
  overflow: hidden;
  max-height: 0;
  margin-top: 0;
  color: #a1a1aa;
  font-size: 16px;
  line-height: 24px;
  opacity: 0;
  transition:
    color 240ms var(--ease-out-quart),
    max-height 300ms var(--ease-out-quart),
    margin-top 300ms var(--ease-out-quart),
    opacity 260ms var(--ease-out-quart);
}

.workbench-steps li.is-active strong {
  padding-left: 48px;
  color: #27272a;
}

.workbench-steps li.is-active span {
  max-height: 24px;
  margin-top: 8px;
  color: #71717a;
  opacity: 1;
}

.workbench-cta {
  position: relative;
  height: 360px;
  margin-top: 162px;
  padding: 0;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 16px;
  background: #fafafa;
  text-align: left;
}

.workbench-cta::before,
.workbench-cta::after {
  display: none;
  position: absolute;
  z-index: 0;
  content: "";
  pointer-events: none;
  background: none;
  opacity: 1;
}

.workbench-cta::before {
  left: 914px;
  top: 0;
  width: 360px;
  height: 360px;
}

.workbench-cta::after {
  display: none;
}

.workbench-cta-art,
.workbench-cta-art-small-frame {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  user-select: none;
}

.workbench-cta-art {
  display: block;
  object-fit: cover;
}

.workbench-cta-art-large {
  left: calc(66.666% - 4px);
  top: 5px;
  width: 350px;
  height: 350px;
}

.workbench-cta-art-small-frame {
  left: calc(41.666% + 96px);
  top: 122px;
  display: flex;
  width: 237.651px;
  height: 237.651px;
  align-items: center;
  justify-content: center;
}

.workbench-cta-art-small-img {
  display: block;
  width: 180px;
  height: 180px;
  object-fit: cover;
  transform: rotate(-24deg);
  transform-origin: center;
  user-select: none;
}

.workbench-cta > p {
  position: absolute;
  z-index: 1;
  left: 52px;
  top: 90px;
  width: auto;
  margin: 0;
  color: #e879f9;
  background: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  animation: none;
  font-family: "Playball", cursive;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
  will-change: auto;
}

.workbench-cta h2 {
  position: absolute;
  z-index: 1;
  left: 52px;
  top: 130px;
  width: min(680px, calc(100% - 104px));
  font-size: 54px;
  line-height: 72px;
}

.workbench-cta h2 span {
  display: block;
}

.workbench-cta-panel {
  display: none;
}

.workbench-cta-panel::before {
  position: absolute;
  inset: 0;
  z-index: 1;
  content: "";
  background: linear-gradient(180deg, rgba(39, 39, 42, 0.24), rgba(39, 39, 42, 0.04) 42%, rgba(39, 39, 42, 0.24));
}

.workbench-cta-panel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.workbench-cta-copy {
  position: absolute;
  z-index: 2;
  left: 28px;
  top: 28px;
  width: 440px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 15px;
  line-height: 28px;
}

.workbench-cta-copy p {
  margin: 0;
  text-wrap: pretty;
}

.workbench-cta-actions {
  position: absolute;
  z-index: 2;
  right: 28px;
  top: 28px;
  display: flex;
  gap: 12px;
}

.workbench-cta-actions a:first-child {
  color: #27272a;
  background: #fff;
}

.workbench-cta-actions a {
  height: 40px;
  min-width: 112px;
  padding: 0 20px;
  color: #fff;
  border-color: rgba(255, 255, 255, 0.38);
  background: rgba(255, 255, 255, 0.06);
}

.workbench-cta-panel strong {
  position: absolute;
  z-index: 2;
  left: 34px;
  bottom: 8px;
  color: #fff;
  font-family: "Lora", Georgia, serif;
  font-size: 138px;
  font-style: italic;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0;
}

.workbench-footer {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 32px;
  align-items: center;
  padding: 0 0 38px;
}

.footer.workbench-shared-footer {
  position: relative;
  left: auto;
  top: auto;
  width: min(var(--footer-width), calc(100vw - 48px));
  height: var(--footer-height);
  margin: 24px auto 48px;
}

.workbench-page .footer.workbench-shared-footer .footer-art {
  border-radius: 12px;
}

.workbench-page .footer.workbench-shared-footer .footer-cta {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(39, 39, 42, 0.14);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.workbench-page .footer.workbench-shared-footer .footer-copy p {
  width: min(620px, 100%);
  color: rgba(255, 255, 255, 0.88);
  font-size: 15px;
  line-height: 24px;
  text-wrap: pretty;
}

.workbench-page .footer.workbench-shared-footer .footer-actions {
  gap: 16px;
}

.workbench-page .footer.workbench-shared-footer .footer-wordmark {
  display: block;
  opacity: 1;
  filter: none;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .workbench-page {
    min-width: 0;
    padding-top: 36px;
  }

  .workbench {
    --workbench-content: min(976px, calc(100vw - 48px));
    overflow: hidden;
  }

  .workbench-page .site-header,
  .workbench-page .inspiration-header {
    position: relative;
    left: auto;
    top: auto;
    width: var(--workbench-content);
    height: 36px;
    margin: 24px auto 0;
    gap: 42px;
  }

  .workbench-page .site-header .logo,
  .workbench-page .site-header .logo-svg {
    width: 155px;
    height: 32px;
  }

  .workbench-page .site-header .site-nav,
  .workbench-page .inspiration-nav {
    position: relative;
    left: auto;
    top: 0;
    display: flex;
    width: auto;
    height: 36px;
    align-items: center;
    gap: 24px;
    transform: none;
  }

  .workbench-page .site-header .site-header-search,
  .workbench-page .inspiration-header .inspiration-search {
    position: absolute;
    left: auto;
    right: 142px;
    top: 0;
    width: 240px;
    height: 36px;
  }

  .workbench-page .site-header .site-header-download,
  .workbench-page .inspiration-header .inspiration-download-wrap,
  .workbench-page .inspiration-download-wrap {
    position: absolute;
    left: auto;
    right: 0;
    top: 0;
    width: 118px;
    height: 36px;
  }

  .workbench-page .site-header .site-header-download .download,
  .workbench-page .inspiration-download-wrap .download {
    width: 118px;
    height: 36px;
    border-radius: 6px;
    font-size: 14px;
    line-height: 16px;
  }

  .workbench-hero,
  .workbench-tools,
  .workbench-feature,
  .workbench-cta,
  .workbench-footer {
    width: var(--workbench-content);
  }

  .workbench-hero {
    min-height: auto;
    padding-top: 60px;
    padding-bottom: 120px;
  }

  .workbench-hero-copy {
    width: min(684px, 100%);
    margin: 0 auto;
    padding-left: 0;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) {
    width: 100%;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) br {
    display: none;
  }

  .workbench-demo {
    height: clamp(520px, 58vw, 620px);
    margin-top: 60px;
  }

  .workbench-panel {
    left: 8.477%;
    top: 7.059%;
    width: 21.552%;
    height: 92.941%;
  }

  .workbench-stage-image {
    left: 16.81%;
    top: 11.765%;
    width: 66.379%;
    height: 88.235%;
  }

  .workbench-select-frame {
    left: 58.764%;
    right: auto;
    top: 8.235%;
    width: 32.184%;
    height: 45.882%;
  }

  .workbench-arrow {
    left: calc(50% + 34px);
    top: -132px;
  }

  .workbench-tools {
    padding: 0 0 120px;
  }

  .workbench-section-head h2,
  .workbench-feature-copy h2 {
    font-size: clamp(40px, 4.3vw, 48px);
    line-height: clamp(52px, 5.4vw, 60px);
  }

  .workbench-tool-card {
    min-height: 0;
  }

  .workbench-tool-media {
    height: clamp(220px, 24vw, 280px);
  }

  .workbench-tool-card h3 {
    margin-top: 22px;
  }

  .workbench-tool-media-ascii.workbench-tool-media-composite img {
    object-position: left center;
  }

  .workbench-feature {
    grid-template-columns: minmax(0, 40%) minmax(0, 1fr);
    gap: clamp(56px, 7vw, 96px);
    padding: 0;
  }

  .workbench-feature-reverse {
    grid-template-columns: minmax(0, 1fr) minmax(0, 40%);
  }

  .workbench-feature-prompt .workbench-feature-copy {
    padding-top: 80px;
  }

  .workbench-feature-reverse .workbench-feature-copy {
    padding-top: 52px;
  }

  .workbench-workflow {
    min-height: calc(100vh + 820px);
  }

  .workbench-workflow-sticky {
    grid-template-columns: minmax(0, 42%) minmax(0, 1fr);
    gap: clamp(48px, 6vw, 84px);
  }

  .workbench-workflow .workbench-feature-copy h2 {
    width: auto;
    max-width: 100%;
    font-size: clamp(40px, 4.1vw, 42px);
    line-height: 54px;
    white-space: normal;
  }

  .workbench-workflow-sticky::before {
    right: -24px;
  }

  .workbench-feature-image {
    height: auto;
    aspect-ratio: 1 / 1;
  }

  .workbench-cta {
    height: clamp(320px, 35vw, 360px);
    margin-top: 132px;
  }

  .footer.workbench-shared-footer {
    width: var(--workbench-content);
  }

  .footer.workbench-shared-footer {
    width: min(var(--footer-width), calc(100vw - 48px));
  }
}

@media (max-width: 767px) {
  .workbench-page {
    --workbench-mobile-gutter: 16px;
    --workbench-mobile-content: calc(100vw - var(--workbench-mobile-gutter) - var(--workbench-mobile-gutter));
    min-width: 0;
    padding-top: 34px;
  }

  .footer.workbench-shared-footer {
    width: var(--workbench-mobile-content);
    max-width: var(--workbench-mobile-content);
    height: 577px;
    margin-top: 16px;
  }
}

.workbench-footer .designer,
.workbench-footer .footer-legal,
.workbench-footer nav {
  position: static;
}

.workbench-footer .designer {
  display: flex;
  align-items: center;
  height: 32px;
}

.workbench-footer .footer-legal {
  display: flex;
  gap: 16px;
}

.workbench-footer nav {
  display: flex;
  gap: 18px;
  width: auto;
  height: auto;
}

.workbench-footer nav a,
.workbench-footer nav img {
  width: 20px;
  height: 20px;
}

.reveal-item.workbench-section-head,
.reveal-item.workbench-tool-card,
.reveal-item.workbench-feature-copy,
.reveal-item.workbench-feature-image,
.reveal-item.workbench-cta {
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  transition:
    opacity 320ms var(--ease-out-quart),
    transform 420ms var(--ease-out-quart);
  transition-delay: var(--reveal-delay, 0ms);
}

.reveal-item.workbench-tool-card:nth-child(2n),
.reveal-item.workbench-feature-image {
  transform: translate3d(0, 22px, 0) scale(0.995);
}

.reveal-item.is-visible.workbench-section-head,
.reveal-item.is-visible.workbench-tool-card,
.reveal-item.is-visible.workbench-feature-copy,
.reveal-item.is-visible.workbench-feature-image,
.reveal-item.is-visible.workbench-cta {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

@media (max-width: 1023px) {
  .workbench-hero {
    min-height: auto;
  }

  .workbench-hero-copy,
  .workbench-tools,
  .workbench-feature {
    padding-left: 0;
    padding-right: 0;
  }

  .workbench-demo {
    height: 520px;
  }

  .workbench-panel {
    left: 42px;
    width: 248px;
  }

  .workbench-stage-image {
    left: 244px;
    width: calc(100% - 286px);
  }

  .workbench-select-frame {
    left: auto;
    right: 64px;
    width: 280px;
  }

  .workbench-feature,
  .workbench-feature-reverse {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .workbench-feature-prompt .workbench-feature-copy,
  .workbench-feature-reverse .workbench-feature-copy,
  .workbench-workflow .workbench-feature-copy {
    padding-top: 0;
  }

  .workbench-workflow {
    min-height: auto;
  }

  .workbench-workflow-sticky {
    position: relative;
    top: auto;
    grid-template-columns: 1fr;
    gap: 42px;
  }

  .workbench-workflow .workbench-feature-copy h2 {
    width: auto;
    white-space: normal;
  }

  .workbench-steps li {
    padding: 14px 0 15px;
  }

  .workbench-steps span {
    opacity: 1;
  }

  .workbench-feature-reverse .workbench-feature-image {
    order: 2;
  }

  .workbench-footer {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }
}

@media (min-width: 768px) and (max-width: 900px) {
  .workbench-page .site-header .site-header-search,
  .workbench-page .site-header .site-header-download,
  .workbench-page .inspiration-header .inspiration-search,
  .workbench-page .inspiration-header .inspiration-download-wrap {
    display: none;
  }
}

@media (min-width: 901px) and (max-width: 1199px) {
  .workbench-hero-copy {
    width: min(740px, calc(100% - 8.477%));
    margin-left: 8.477%;
    margin-right: auto;
  }

  .workbench-arrow {
    left: calc(50% + 34px);
    top: -132px;
  }
}

@media (min-width: 1024px) and (max-width: 1439px) {
  .workbench-hero-copy {
    width: min(740px, calc(100% - 8.477%));
    margin-left: 8.477%;
    margin-right: auto;
    padding-left: 0;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) {
    width: 684px;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) br {
    display: inline;
  }

  .workbench-arrow {
    left: calc(50% + 34px);
    top: -132px;
  }
}

@media (max-width: 767px) {
  .workbench-page .site-header,
  .workbench-page .inspiration-header {
    left: var(--workbench-mobile-gutter);
    width: var(--workbench-mobile-content);
    margin: 16px 0 0;
  }

  .workbench-hero,
  .workbench-tools,
  .workbench-feature,
  .workbench-cta,
  .workbench-footer {
    width: var(--workbench-mobile-content);
  }

  .workbench-hero {
    min-height: 0;
    padding-top: 30px;
    padding-bottom: 120px;
  }

  .workbench-hero-copy {
    width: auto;
    padding: 0;
  }

  .workbench-kicker {
    font-size: 32px;
    line-height: 42px;
  }

  .workbench-hero h1 {
    gap: 0;
    font-size: clamp(30px, 7.96vw, 32px);
    line-height: 48px;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) {
    width: auto;
    margin-top: 12px;
    font-size: 14px;
    line-height: 20px;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) br {
    display: none;
  }

  .workbench-actions {
    width: 256px;
    gap: 16px;
    margin-top: 16px;
  }

  .workbench-primary,
  .workbench-secondary {
    flex: 0 0 120px;
    min-width: 120px;
    height: 40px;
    padding: 0 16px;
    border-radius: 6px;
    font-size: 14px;
    line-height: 20px;
  }

  .workbench-demo {
    height: auto;
    aspect-ratio: 370 / 450;
    margin-top: 48px;
    border-radius: 12px;
  }

  .workbench-panel {
    left: 4.324%;
    top: 8.889%;
    width: 43.243%;
    height: 91.111%;
    border-radius: 0;
  }

  .workbench-stage-image {
    left: 26.486%;
    top: 14.667%;
    width: 64.865%;
    height: 85.333%;
    border-radius: 0;
  }

  .workbench-select-frame {
    left: 63.243%;
    right: auto;
    top: 8.889%;
    width: 32.432%;
    height: 26.667%;
  }

  .workbench-select-frame span {
    width: clamp(9px, 2.986vw, 12px);
    height: clamp(9px, 2.986vw, 12px);
    border-width: 1px;
    border-radius: 3px;
  }

  .workbench-select-frame span:nth-child(1) {
    left: -7px;
    top: -7px;
  }

  .workbench-select-frame span:nth-child(2) {
    right: -7px;
    top: -7px;
  }

  .workbench-select-frame span:nth-child(3) {
    left: -7px;
    bottom: -7px;
  }

  .workbench-select-frame span:nth-child(4) {
    right: -7px;
    bottom: -7px;
  }

  .workbench-arrow {
    display: none;
  }

  .workbench-tools {
    padding: 0 0 120px;
  }

  .workbench-section-head {
    margin-bottom: 16px;
  }

  .workbench-section-head h2,
  .workbench-feature-copy h2,
  .workbench-cta h2 {
    font-size: clamp(28px, 7.96vw, 32px);
    line-height: 48px;
  }

  .workbench-feature-copy h2 span,
  .workbench-cta h2 span {
    white-space: normal;
  }

  .workbench-label {
    gap: 12px;
    margin-bottom: 8px;
    font-size: 16px;
    line-height: 24px;
  }

  .workbench-label::before {
    width: 24px;
    height: 24px;
    flex-basis: 24px;
  }

  .workbench-tool-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .workbench-tool-card {
    min-height: 0;
    min-height: 292px;
    height: auto;
    border-radius: 8px;
  }

  .workbench-tool-media {
    height: auto;
    aspect-ratio: 370 / 182;
    border-radius: 8px 8px 0 0;
  }

  .workbench-tool-card h3 {
    margin: 16px 16px 0;
    font-size: 20px;
    line-height: 30px;
  }

  .workbench-tool-card p {
    margin: 8px 16px 0;
    font-size: 14px;
    line-height: 20px;
  }

  .workbench-feature,
  .workbench-feature-reverse {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 0;
  }

  .workbench-feature-prompt {
    margin-top: 0;
  }

  .workbench-feature-reverse,
  .workbench-workflow,
  .workbench-cta {
    margin-top: 120px;
  }

  .workbench-feature-prompt .workbench-feature-copy,
  .workbench-feature-reverse .workbench-feature-copy,
  .workbench-workflow .workbench-feature-copy {
    padding-top: 0;
  }

  .workbench-feature-copy p:not(.workbench-label) {
    width: 100%;
    margin-top: 12px;
    font-size: 14px;
    line-height: 24px;
  }

  .workbench-feature-copy a {
    height: 49px;
    min-width: 160px;
    margin-top: 16px;
    padding: 0 24px;
    border-radius: 8px;
    font-size: 16px;
    line-height: 24px;
  }

  .workbench-feature-image {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
    margin-top: 32px;
    border-radius: 8px;
  }

  .workbench-feature::before,
  .workbench-workflow-sticky::before {
    display: none;
  }

  .workbench-feature-reverse .workbench-feature-image {
    order: 2;
  }

  .workbench-workflow {
    min-height: auto;
  }

  .workbench-workflow-sticky {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .workbench-workflow .workbench-feature-copy h2 {
    width: auto;
    white-space: normal;
  }

  .workbench-steps {
    width: 100%;
    margin-top: 16px;
  }

  .workbench-steps li {
    padding: 16px 0 15px;
  }

  .workbench-steps li:first-child {
    padding-top: 0;
  }

  .workbench-steps li::before {
    top: 0;
    width: 35px;
    height: 36px;
  }

  .workbench-steps li.is-active strong {
    padding-left: 48px;
  }

  .workbench-steps strong {
    font-size: 24px;
    line-height: 36px;
  }

  .workbench-steps span {
    font-size: 16px;
    line-height: 24px;
    opacity: 0;
  }

  .workbench-steps li.is-active span {
    max-height: 48px;
    margin-top: 8px;
    opacity: 1;
  }

  .workbench-cta {
    height: auto;
    aspect-ratio: 370 / 196;
    padding: 0;
    border-radius: 12px;
  }

  .workbench-cta > p {
    left: 24px;
    top: 46px;
    font-size: 16px;
    line-height: 24px;
  }

  .workbench-cta::before {
    display: none;
  }

  .workbench-cta::after {
    display: none;
  }

  .workbench-cta-art-large {
    left: 49.189%;
    top: 8px;
    width: 48.649%;
    height: 91.837%;
  }

  .workbench-cta-art-small-frame {
    display: none;
  }

  .workbench-cta h2 {
    left: 24px;
    top: 78px;
    width: calc(100% - 48px);
    color: #18181b;
    font-size: 24px;
    line-height: 36px;
  }

  .workbench-cta h2 span {
    display: block;
  }

  .workbench-footer {
    gap: 18px;
    padding-bottom: 28px;
  }

  .workbench-footer .footer-legal {
    flex-wrap: wrap;
    justify-content: center;
    row-gap: 8px;
  }
}

@media (max-width: 768px) {
  .workbench {
    --workbench-content: calc(100vw - 32px);
  }

  .workbench-page .site-header,
  .workbench-page .inspiration-header,
  .workbench-hero,
  .workbench-tools,
  .workbench-feature,
  .workbench-cta,
  .workbench-footer,
  .footer.workbench-shared-footer {
    width: calc(100vw - 32px);
  }

  .workbench-page .site-header,
  .workbench-page .inspiration-header {
    margin-top: 16px;
  }

  .workbench-hero-copy {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
  }

  .workbench-hero-copy > p:not(.workbench-kicker) {
    width: 100%;
  }

  .workbench-arrow {
    display: none;
  }
}

@media (hover: none) and (pointer: coarse) {
  .workbench-tool-card:hover {
    border-color: #e4e4e7;
    box-shadow: none;
    transform: none;
  }

  .workbench-tool-card:hover .workbench-tool-media img {
    transform: none;
  }
}

@media (max-width: 360px) {
  .footer.workbench-shared-footer {
    height: 625px;
  }

  .footer.workbench-shared-footer .footer-bottom {
    height: 121px;
  }

  .footer.workbench-shared-footer .designer {
    left: 0;
    top: 504px;
    justify-content: center;
    width: 100%;
  }

  .footer.workbench-shared-footer nav {
    left: 0;
    top: 536px;
    justify-content: center;
    width: 100%;
  }

  .footer.workbench-shared-footer .footer-legal {
    top: 593px;
  }
}

@font-face {
  font-family: "Lora";
  src: url("./assets/fonts/Lora-SemiBoldItalic.ttf") format("truetype");
  font-style: italic;
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "Playball";
  src: url("./assets/fonts/Playball-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: block;
}

@font-face {
  font-family: "Funnel Display";
  src: url("./assets/fonts/funnel-display/FunnelDisplay-Regular.ttf") format("truetype");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "Funnel Display";
  src: url("./assets/fonts/funnel-display/FunnelDisplay-Medium.ttf") format("truetype");
  font-style: normal;
  font-weight: 500;
  font-display: swap;
}

@font-face {
  font-family: "Funnel Display";
  src: url("./assets/fonts/funnel-display/FunnelDisplay-SemiBold.ttf") format("truetype");
  font-style: normal;
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Sans SC";
  src: url("./assets/fonts/ibm-plex-sans-sc/IBMPlexSansSC-Regular.woff2") format("woff2");
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Sans SC";
  src: url("./assets/fonts/ibm-plex-sans-sc/IBMPlexSansSC-Medium.woff2") format("woff2");
  font-style: normal;
  font-weight: 500;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Sans SC";
  src: url("./assets/fonts/ibm-plex-sans-sc/IBMPlexSansSC-SemiBold.woff2") format("woff2");
  font-style: normal;
  font-weight: 600;
  font-display: swap;
}

@font-face {
  font-family: "IBM Plex Sans SC";
  src: url("./assets/fonts/ibm-plex-sans-sc/IBMPlexSansSC-Bold.woff2") format("woff2");
  font-style: normal;
  font-weight: 700;
  font-display: swap;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-width: 1440px;
  overflow-x: hidden;
  padding-top: 36px;
  background: #fff;
  font-family: "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

body.notice-hidden {
  padding-top: 0;
}

body::before {
  display: none;
  content: none;
}

.global-notice {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 60;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-width: 1440px;
  height: 36px;
  border-bottom: 1px solid rgba(228, 228, 231, 0.8);
  background: #fafafa;
}

.global-notice.is-hidden {
  display: none;
}

.global-notice::after {
  display: none;
}

.global-notice-track {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  width: max-content;
}

.global-notice-copy {
  display: flex;
  align-items: center;
  gap: 4px;
  margin: 0;
  padding: 0;
  color: #27272a;
  font-size: 13px;
  font-weight: 400;
  line-height: 18px;
  white-space: nowrap;
}

.global-notice-copy[aria-hidden="true"] {
  display: none;
}

.global-notice-copy a {
  color: #e879f9;
  font-weight: 500;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
  transition: color 160ms ease, opacity 160ms ease;
}

.global-notice-copy a:hover,
.global-notice-copy a:focus-visible {
  color: #d946ef;
}

.global-notice-close {
  position: absolute;
  right: 6px;
  left: auto;
  top: 6px;
  width: 24px;
  height: 24px;
  padding: 0;
  border: 0;
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  cursor: pointer;
  opacity: 1;
  transition: opacity 160ms ease;
}

.global-notice-close:hover,
.global-notice-close:focus-visible {
  opacity: 0.6;
  outline: none;
}

.global-notice-close svg {
  display: block;
  width: 24px;
  height: 24px;
}

@keyframes notice-marquee {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(-50%, 0, 0);
  }
}

img {
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

.design {
  position: relative;
  width: 100%;
  min-width: 1440px;
  height: var(--design-height);
  overflow: hidden;
  background: #fff;
}

.design-stage {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: var(--design-height);
  transform: none;
  transform-origin: top left;
}

.policy-page {
  position: relative;
  width: 100%;
  min-width: 1440px;
  height: 2972px;
  overflow: hidden;
  background: #fff;
}

.policy-header {
  position: absolute;
  left: var(--side);
  top: 24px;
  display: flex;
  align-items: center;
  gap: 48px;
  height: 36px;
}

.policy-header .logo {
  display: block;
  flex: 0 0 auto;
}

.policy-card {
  position: absolute;
  left: var(--side);
  top: 108px;
  display: none;
  width: var(--content);
  height: 2261px;
  margin-left: 0;
  border: 1px solid #f4f4f5;
  border-radius: 20px;
  background: #fafafa;
}

.policy-sidebar {
  --policy-sidebar-opacity: 1;
  position: absolute;
  left: calc(var(--side) + 1062px);
  top: 216px;
  z-index: 40;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: var(--card-w, 330px);
  height: 472px;
  padding: 24px;
  border: 1px solid #f4f4f5;
  border-radius: 16px;
  background: #fff;
  opacity: var(--policy-sidebar-opacity);
  transition: opacity 220ms var(--ease-out-quart);
  will-change: background-position;
}

.policy-sidebar.is-fixed {
  position: fixed;
  top: 48px;
}

.policy-sidebar.is-hidden-near-footer {
  pointer-events: none;
}

.policy-sidebar a {
  position: relative;
  z-index: 2;
  color: #a1a1aa;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  white-space: nowrap;
  transition: color 220ms var(--ease-out-quart);
}

.policy-sidebar a:hover,
.policy-sidebar a:focus-visible,
.policy-sidebar a.is-active {
  color: #27272a;
  outline: none;
}

.policy-sidebar-accent {
  position: absolute;
  left: 24px;
  top: calc(42px + var(--policy-active-index, 0) * 40px);
  z-index: 1;
  width: 100px;
  height: 12px;
  pointer-events: none;
  transition: top 260ms var(--ease-out-quart);
}

.policy-title-row {
  position: absolute;
  left: var(--side);
  top: 108px;
  display: flex;
  align-items: center;
  gap: 12px;
  height: 48px;
  margin-left: 0;
}

.policy-page h1 {
  margin: 0;
  width: 576px;
  color: #18181b;
  font-size: 32px;
  font-weight: 600;
  line-height: 48px;
  text-align: left;
  white-space: nowrap;
}

.policy-title-accent {
  flex: 0 0 auto;
  width: 48px;
  height: 48px;
}

.policy-date {
  position: absolute;
  left: var(--side);
  top: 168px;
  margin: 0;
  color: #a1a1aa;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
}

.policy-divider {
  position: absolute;
  left: var(--side);
  top: 216px;
  width: 920px;
  margin-left: 0;
  height: 1px;
  background: #e4e4e7;
}

.policy-intro {
  position: absolute;
  left: var(--side);
  top: 240px;
  width: 920px;
  margin: 0;
  color: #71717a;
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
}

.policy-section {
  position: absolute;
  left: var(--side);
  width: 920px;
  margin-left: 0;
  color: #71717a;
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
}

.policy-section-narrow {
  width: 544px;
}

.policy-section h2 {
  margin: 0 0 12px;
  color: #27272a;
  font-size: 24px;
  font-weight: 600;
  line-height: 36px;
}

.policy-section p {
  margin: 0;
}

.policy-section ol {
  margin: 24px 0 0;
  padding: 0;
  list-style-position: inside;
}

.policy-section-4 p,
.policy-section-4 li {
  line-height: 24px;
}

.policy-section-4 ol {
  margin: 24px 0 12px;
}

.policy-section-1 { top: 288px; }
.policy-section-2 { top: 536px; }
.policy-section-3 { top: 784px; }
.policy-section-4 { top: 936px; }
.policy-section-5 { top: 1244px; }
.policy-section-6 { top: 1396px; }
.policy-section-7 { top: 1524px; }
.policy-section-8 { top: 1652px; }
.policy-section-9 { top: 1900px; }
.policy-section-10 { top: 2004px; }
.policy-section-11 { top: 2108px; }

.policy-page .footer {
  top: 2388px;
}

.policy-mobile-break {
  display: none;
}

html[data-lang="en"] body.policy-body,
html[data-lang="en"] body.policy-body button,
html[data-lang="en"] body.policy-body input,
html[data-lang="en"] body.policy-body a,
html[data-lang="en"] body.policy-body .policy-page,
html[data-lang="en"] body.policy-body .policy-sidebar,
html[data-lang="en"] body.policy-body .policy-section,
html[data-lang="en"] body.policy-body .footer,
html[data-lang="en"] body.policy-body .footer-copy,
html[data-lang="en"] body.policy-body .footer-desc,
html[data-lang="en"] body.policy-body .footer-legal {
  font-family: var(--display-font);
}

html[data-lang="en"] body.policy-body .policy-page h1,
html[data-lang="en"] body.policy-body .policy-section h2 {
  font-weight: 500;
}

html[data-lang="en"] body.policy-body .policy-page h1 {
  width: 760px;
}

html[data-lang="en"] body.policy-body .policy-section-narrow {
  width: 920px;
}

html[data-lang="en"] body.policy-body .policy-section ol {
  margin-top: 12px;
}

.inspiration-body {
  position: relative;
}

.inspiration-header-bg {
  --header-dot-flow-duration: 16s;
  --header-dot-flow-ease: linear;
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 0;
  width: 100vw;
  min-width: 0;
  height: 400px;
  overflow: hidden;
  content: "";
  pointer-events: none;
  background-color: #fafafa;
  background-image: url("./assets/inspiration/header-dots-base.svg?v=20260528-header-bg-25");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 1440px 400px;
  transform: translateX(-50%);
}

.inspiration-header-bg,
.skills-header-bg {
  background-image: none;
}

.inspiration-header-bg::before,
.skills-header-bg::before,
.inspiration-header-bg .header-dot-cursor,
.skills-header-bg .header-dot-cursor {
  display: none;
}

.inspiration-header-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(228, 228, 231, 0) 0%, rgba(228, 228, 231, 1) 38%, rgba(228, 228, 231, 0.4) 52%, rgba(228, 228, 231, 0) 72%);
  background-size: 52% 100%;
  background-position: -72% 0;
  background-repeat: no-repeat;
  -webkit-mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
  mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
  -webkit-mask-position: center top;
  mask-position: center top;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 1440px 400px;
  mask-size: 1440px 400px;
  animation:
    header-dot-flow var(--header-dot-flow-duration) var(--header-dot-flow-ease) infinite,
    header-dot-opacity var(--header-dot-flow-duration) cubic-bezier(0.25, 1, 0.5, 1) infinite;
  will-change: background-position, opacity;
  contain: paint;
}

.header-dot-cursor {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0;
  background: radial-gradient(circle at var(--header-dot-pointer-x, 50%) var(--header-dot-pointer-y, 50%), rgba(228, 228, 231, 1) 0 28px, rgba(228, 228, 231, 0.72) 58px, rgba(228, 228, 231, 0.28) 88px, rgba(228, 228, 231, 0) 124px);
  background-repeat: no-repeat;
  -webkit-mask-position: center top;
  mask-position: center top;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 1440px 400px;
  mask-size: 1440px 400px;
  transition: opacity 320ms cubic-bezier(0.25, 1, 0.5, 1);
  will-change: opacity, background;
  contain: paint;
}

.inspiration-header-bg .header-dot-cursor,
.cases-header-bg .header-dot-cursor {
  -webkit-mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
  mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
}

.skills-header-bg .header-dot-cursor {
  -webkit-mask-image: url("./assets/skills/skills-header-dots-mask.svg?v=20260528-header-bg-25");
  mask-image: url("./assets/skills/skills-header-dots-mask.svg?v=20260528-header-bg-25");
}

.header-dot-pointer-active .header-dot-cursor {
  animation: header-dot-pointer-opacity 1800ms cubic-bezier(0.25, 1, 0.5, 1) -900ms infinite;
}

.inspiration-header-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0.9) 18%, rgba(255, 255, 255, 0) 68%) center top / 100% 100% no-repeat;
}

.global-notice.is-hidden + .inspiration-header-bg {
  top: 0;
}

.inspiration-page {
  position: relative;
  z-index: 1;
  width: 1440px;
  min-width: 1440px;
  height: var(--inspiration-page-height, 3608px);
  margin: 0 auto;
  overflow: visible;
  background: transparent;
}

.inspiration-page::before {
  display: none;
  content: "";
}

.inspiration-page::after {
  display: none;
  content: "";
}

.inspiration-header {
  position: absolute;
  left: 24px;
  top: 24px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 48px;
  height: 36px;
}

.inspiration-nav {
  position: absolute;
  left: 209px;
  top: 6px;
  width: 420px;
  flex-wrap: nowrap;
}

.inspiration-nav a::after {
  background-image: url("./assets/inspiration/nav-underline.svg");
}

.inspiration-nav a {
  flex: 0 0 auto;
  white-space: nowrap;
}

.inspiration-download-wrap {
  position: absolute;
  left: 1282px;
  top: 0;
  width: 118px;
  height: 36px;
}

.inspiration-header .inspiration-download-wrap {
  position: absolute;
  left: 1282px;
  top: 0;
  width: 118px;
  height: 36px;
}

.inspiration-download {
  width: 118px;
  height: 36px;
  border-radius: 6px;
  color: #fff;
  background: #27272a;
  font-size: 14px;
  line-height: 16px;
}

.inspiration-download-wrap .inspiration-download {
  width: 118px;
  height: 36px;
  border-radius: 6px;
  color: #fff;
  background: #27272a;
  font-size: 14px;
  line-height: 16px;
}

.inspiration-download:hover,
.inspiration-download:focus-visible {
  color: #fff;
  background: #18181b;
}

.inspiration-download-wrap .download-menu {
  left: auto;
  right: 0;
  top: 48px;
  transform-origin: top right;
}

.inspiration-hero {
  position: absolute;
  left: 378px;
  top: 140px;
  z-index: 2;
  width: 684px;
  text-align: center;
}

.inspiration-title-wrap {
  position: relative;
  display: block;
  width: 684px;
  max-width: none;
}

.inspiration-kicker {
  width: 684px;
  margin: 0 0 16px;
  color: #e879f9;
  font-family: "Playball", cursive;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
  text-align: center;
}

.inspiration-hero h1 {
  display: inline-block;
  margin: 0;
  color: #18181b;
  font-size: 48px;
  font-weight: 600;
  line-height: 60px;
  white-space: nowrap;
}

.inspiration-hero h1 br {
  display: none;
}

.inspiration-hero p {
  width: 684px;
  margin: 12px 0 0;
  color: #71717a;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
}

.inspiration-hero .inspiration-kicker {
  margin: 0 0 16px;
  color: #e879f9;
  font-family: "Playball", cursive;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
}

.kicker-write {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.kicker-write-object,
.kicker-write-svg {
  display: block;
  width: 168px;
  height: 30px;
  opacity: 1;
  pointer-events: none;
}

.inspiration-kicker .kicker-write-object,
.inspiration-kicker .kicker-write-svg {
  width: 196px;
  height: 34px;
  opacity: 1;
}

.skills-kicker .kicker-write-object,
.skills-kicker .kicker-write-svg {
  width: 128px;
  height: 34px;
  opacity: 1;
}

html[data-color-scheme="dark"] .skills-kicker .kicker-write-object {
  display: none !important;
  background: transparent;
}

html[data-color-scheme="dark"] .skills-kicker::before {
  display: block;
  content: "Skill Gallery";
  color: #e879f9;
  background: transparent;
  font-family: "Playball", cursive;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
}

.inspiration-title-accent {
  display: none;
  position: absolute;
  left: calc(100% + 8px);
  top: -24px;
  width: 48px;
  height: 48px;
  transform: translate3d(0, var(--hero-accent-y), 0) rotate(180deg);
  overflow: visible;
  will-change: transform;
}

.inspiration-title-accent-draw {
  overflow: visible;
}

.inspiration-title-accent-draw path:not(.accent-mask-path) {
  fill: #e879f9;
}

.inspiration-title-accent-draw .accent-mask-path {
  fill: none;
  stroke: #fff;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 1;
  stroke-dashoffset: 1;
  animation: inspiration-accent-draw 3600ms var(--ease-out-quart) infinite;
}

.inspiration-title-accent-draw .accent-mask-path-2 {
  animation-delay: 120ms;
}

.inspiration-title-accent-draw .accent-mask-path-3 {
  animation-delay: 240ms;
}

@keyframes inspiration-accent-draw {
  0%,
  8% {
    stroke-dashoffset: 1;
  }

  30%,
  72% {
    stroke-dashoffset: 0;
  }

  92%,
  to {
    stroke-dashoffset: 1;
  }
}

@keyframes inspiration-accent-draw-once {
  to {
    stroke-dashoffset: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .inspiration-title-accent-draw .accent-mask-path {
    animation: none;
    stroke-dashoffset: 0;
  }
}

.inspiration-mode-tabs {
  position: absolute;
  left: 24px;
  top: 366px;
  z-index: 6;
  display: flex;
  align-items: flex-start;
  gap: 24px;
  height: 48px;
}

.inspiration-mode-tabs button {
  position: relative;
  display: flex;
  align-items: center;
  height: 36px;
  padding: 0;
  border: 0;
  color: #a1a1aa;
  background: transparent;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
  white-space: nowrap;
  transition: color 180ms var(--ease-out-quart);
}

.inspiration-mode-tabs button::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 36px;
  width: 48px;
  height: 12px;
  opacity: 0;
  background-image: url("./assets/inspiration/nav-underline.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 48px auto;
  transform: translate3d(-50%, 0, 0);
  transition: opacity 180ms var(--ease-out-quart);
}

.inspiration-mode-tabs button.is-active,
.inspiration-mode-tabs button:hover,
.inspiration-mode-tabs button:focus-visible {
  color: #27272a;
  outline: none;
}

.inspiration-mode-tabs button.is-active::after {
  opacity: 1;
}

.inspiration-filters {
  position: absolute;
  left: 656px;
  top: 366px;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: auto;
  max-width: calc(100% - 680px);
  height: 36px;
  overflow: visible;
  transform: none;
}

.inspiration-filters button {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 4px 16px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #a1a1aa;
  background: #fff;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  white-space: nowrap;
  transition: color 180ms var(--ease-out-quart), border-color 180ms var(--ease-out-quart);
}

.inspiration-filters button.is-active,
.inspiration-filters button:hover,
.inspiration-filters button:focus-visible {
  color: #27272a;
  border-color: #27272a;
  outline: none;
}

.inspiration-filter-menu {
  position: relative;
  flex: 0 0 auto;
}

.inspiration-filters.has-open-menu {
  overflow: visible;
}

.inspiration-filters .inspiration-filter-more {
  gap: 4px;
  width: 36px;
  padding: 4px 7px;
}

.inspiration-filter-more span {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.inspiration-filter-more svg {
  width: 20px;
  height: 20px;
  transition: opacity 180ms var(--ease-out-quart);
}

.inspiration-filter-menu-list {
  position: absolute;
  right: 0;
  top: 44px;
  z-index: 30;
  display: grid;
  gap: 6px;
  min-width: 132px;
  padding: 6px;
  border: 1px solid #e4e4e7;
  border-radius: 8px;
  opacity: 0;
  background: #fff;
  box-shadow: 0 18px 48px rgba(24, 24, 27, 0.12);
  transform: translate3d(0, -4px, 0);
  pointer-events: none;
  transition:
    opacity 160ms var(--ease-out-quart),
    transform 160ms var(--ease-out-quart);
}

.inspiration-filter-menu.is-open .inspiration-filter-menu-list {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  pointer-events: auto;
}

.inspiration-filters .inspiration-filter-menu-item {
  width: 100%;
  justify-content: flex-start;
  border-color: transparent;
  border-radius: 6px;
  background: transparent;
}

.inspiration-filters .inspiration-filter-menu-item:hover,
.inspiration-filters .inspiration-filter-menu-item:focus-visible {
  border-color: transparent;
  background: #fafafa;
}

.inspiration-filters .inspiration-filter-menu-item.is-active {
  border-color: #27272a;
  color: #27272a;
  background: #fafafa;
}

.site-search {
  position: absolute;
  top: 0;
  width: 264px;
  height: 36px;
  cursor: text;
}

.inspiration-header .inspiration-search {
  left: 1010px;
}

.site-search img {
  position: absolute;
  left: 7px;
  top: 7px;
  z-index: 1;
  width: 20px;
  height: 20px;
}

.site-search input {
  width: 100%;
  height: 36px;
  padding: 4px 52px 4px 35px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #71717a;
  background: #fff;
  font: 400 13px/20px "IBM Plex Sans SC", sans-serif;
  caret-color: transparent;
  cursor: text;
}

.site-search input::placeholder {
  color: #8a8a93;
}

.site-search input:focus {
  border-color: #27272a;
  outline: none;
}

.site-search-shortcut,
.global-search-shortcut {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  pointer-events: none;
}

.site-search-shortcut {
  right: 7px;
  top: 9px;
}

.site-search-shortcut kbd,
.global-search-shortcut kbd {
  display: inline-flex;
  min-width: 18px;
  height: 18px;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 1px solid #e4e4e7;
  border-radius: 5px;
  color: #8a8a93;
  background: #fafafa;
  font: 500 10px/14px "IBM Plex Sans SC", sans-serif;
}

.global-search-modal {
  position: fixed;
  inset: 0;
  z-index: 1400;
  display: grid;
  place-items: start center;
  padding-top: 104px;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  background: var(--modal-frost-bg);
  -webkit-backdrop-filter: var(--modal-frost-blur);
  backdrop-filter: var(--modal-frost-blur);
  transition: opacity 220ms var(--ease-out-quart), visibility 220ms var(--ease-out-quart);
}

.global-search-modal.is-open {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}

.global-search-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: transparent;
  cursor: default;
}

.global-search-panel {
  position: relative;
  z-index: 1;
  width: 600px;
  max-height: min(680px, calc(100vh - 148px));
  overflow: hidden;
  border: 1px solid #e4e4e7;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 20px 72px rgba(24, 24, 27, 0.1);
  opacity: 0;
  transform: translate3d(0, 14px, 0) scale(0.985);
  transition: opacity 260ms var(--ease-out-quart), transform 320ms var(--ease-out-expo);
}

.global-search-modal.is-open .global-search-panel {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.global-search-input-row {
  position: relative;
  display: block;
  height: 64px;
  padding: 8px;
  border-bottom: 1px solid var(--ps-border-subtle);
}

.global-search-input-row::before {
  position: absolute;
  inset: 8px;
  content: "";
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  background: #fafafa;
  pointer-events: none;
}

.global-search-recommendations {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 12px 2px;
  border-bottom: 1px solid #f4f4f5;
}

.global-search-recommendations button {
  display: inline-flex;
  height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  border: 1px solid #e4e4e7;
  border-radius: 999px;
  color: #52525b;
  background: #fff;
  font: 500 12px/18px "IBM Plex Sans SC", sans-serif;
  white-space: nowrap;
  cursor: pointer;
  transition:
    border-color 180ms var(--ease-out-quart),
    color 180ms var(--ease-out-quart),
    background-color 180ms var(--ease-out-quart);
}

.global-search-recommendations button:hover,
.global-search-recommendations button:focus-visible {
  border-color: #27272a;
  color: #27272a;
  background: #fafafa;
  outline: none;
}

.global-search-input-row img {
  position: absolute;
  left: 22px;
  top: 22px;
  width: 20px;
  height: 20px;
  z-index: 1;
}

.global-search-input-row input {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 48px;
  padding: 0 74px 0 46px;
  border: 0;
  color: #27272a;
  background: transparent;
  font: 400 15px/24px "IBM Plex Sans SC", sans-serif;
}

.global-search-input-row input::placeholder {
  color: #8a8a93;
}

.global-search-input-row input:focus {
  outline: none;
}

.global-search-shortcut {
  right: 22px;
  top: 23px;
}

.global-search-results {
  max-height: min(562px, calc(100vh - 274px));
  overflow: auto;
  padding: 8px;
  scrollbar-width: thin;
  scrollbar-color: #d4d4d8 transparent;
}

.global-search-results::-webkit-scrollbar {
  width: 4px;
}

.global-search-results::-webkit-scrollbar-track {
  background: transparent;
}

.global-search-results::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #d4d4d8;
}

.global-search-result {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  width: 100%;
  min-height: 72px;
  padding: 12px;
  border: 0;
  border-radius: 10px;
  color: #27272a;
  background: transparent;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: background-color 180ms var(--ease-out-quart);
}

.global-search-result:hover,
.global-search-result:focus-visible,
.global-search-result.is-active {
  background: #fafafa;
  outline: none;
}

.global-search-thumb {
  display: block;
  width: 44px;
  height: 44px;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fafafa;
}

.global-search-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.global-search-result-body {
  min-width: 0;
}

.global-search-result-title {
  display: block;
  overflow: hidden;
  color: #27272a;
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.global-search-result-summary {
  display: -webkit-box;
  margin-top: 4px;
  overflow: hidden;
  color: #71717a;
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.global-search-result-type {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 52px;
  height: 24px;
  padding: 0 10px;
  border: 1px solid #e4e4e7;
  border-radius: 999px;
  color: #71717a;
  background: #fff;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
  white-space: nowrap;
}

.global-search-empty {
  display: grid;
  place-items: center;
  height: 148px;
  color: #a1a1aa;
  font-size: 14px;
  line-height: 20px;
  text-align: center;
}

.global-search-footer {
  display: flex;
  min-height: 46px;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 12px;
  border-top: 1px solid var(--ps-border-subtle);
  color: #8a8a93;
  background: #fafafa;
  font-size: 12px;
  line-height: 18px;
}

.global-search-count {
  flex: 0 0 auto;
  display: inline-flex;
  height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #52525b;
  background: #fff;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
  white-space: nowrap;
}

.global-search-count::before {
  content: none;
}

.global-search-help {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 0;
  color: #8a8a93;
  font-size: 12px;
  line-height: 18px;
  white-space: nowrap;
}

.global-search-action {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-width: 0;
  height: 28px;
  padding: 0 6px 0 8px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fff;
}

.global-search-action-label {
  color: #71717a;
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
}

.global-search-key {
  display: inline-flex;
  min-width: 22px;
  height: 20px;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  border: 1px solid #f4f4f5;
  border-radius: 5px;
  color: #52525b;
  background: #fafafa;
  font-size: 12px;
  font-weight: 500;
  line-height: 16px;
}

.global-search-key-wide {
  min-width: 40px;
}

.site-toast {
  position: fixed;
  left: 50%;
  bottom: 32px;
  z-index: 180;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 144px;
  height: 40px;
  padding: 0 16px;
  border: 1px solid rgba(228, 228, 231, 0.8);
  border-radius: 999px;
  color: #27272a;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 48px rgba(39, 39, 42, 0.12);
  font-size: 14px;
  font-weight: 500;
  line-height: 20px;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-50%, 12px, 0) scale(0.96);
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  transition:
    opacity 220ms var(--ease-out-quart),
    transform 260ms var(--ease-out-expo);
}

.site-toast.is-visible {
  opacity: 1;
  transform: translate3d(-50%, 0, 0) scale(1);
}

html.global-search-lock,
body.global-search-open {
  overflow: hidden;
}

.inspiration-grid {
  position: absolute;
  inset: 0 auto auto 0;
  z-index: 2;
  width: 1440px;
  height: var(--inspiration-grid-height, 2744px);
  overflow: visible;
  transform: translate3d(0, 46px, 0);
  transition: height 620ms var(--ease-out-expo);
}

.prompt-card {
  position: absolute;
  left: var(--x);
  top: var(--y);
  --card-reveal-y: 0px;
  --tilt-lift: 0px;
  --tilt-scale: 1;
  --tilt-x: 0deg;
  --tilt-y: 0deg;
  width: var(--card-w, 330px);
  height: var(--h);
  overflow: hidden;
  border: 1px solid transparent;
  border-radius: 12px;
  background: transparent;
  cursor: pointer;
  transform: perspective(1000px) translate3d(0, calc(var(--card-reveal-y) + var(--tilt-lift)), 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) scale(var(--tilt-scale));
  transform-origin: center center;
  transition:
    height 620ms var(--ease-out-expo),
    transform 260ms var(--ease-out-quart),
    border-color 260ms var(--ease-out-quart),
    background-color 260ms var(--ease-out-quart),
    box-shadow 320ms var(--ease-out-quart);
}

.prompt-card.is-open {
  border-color: #f4f4f5;
  background: #fafafa;
  box-shadow: none;
}

.prompt-card.is-hidden {
  display: none !important;
}

.prompt-card-tilt {
  position: absolute;
  inset: 0;
  border-radius: inherit;
}

.prompt-card.is-tilting {
  z-index: 8;
  /* 仅 hover 期间挂 will-change，避免 70+ 卡片永久占用合成层 */
  will-change: transform;
  box-shadow: 0 14px 22px rgba(39, 39, 42, 0.09), 0 3px 8px rgba(39, 39, 42, 0.05);
}

.prompt-card.is-tilting .prompt-card-image {
  filter: saturate(1.02) contrast(1.01);
}

.prompt-card:focus-visible {
  outline: 2px solid rgba(39, 39, 42, 0.24);
  outline-offset: 4px;
}

.prompt-card-image {
  display: block;
  width: 100%;
  height: var(--ih);
  border-radius: 12px;
  object-fit: cover;
  transition: border-radius 260ms var(--ease-out-quart), filter 360ms var(--ease-out-quart);
}

.prompt-card.is-open .prompt-card-image {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.prompt-card--case {
  border-color: #f4f4f5;
  background: #fafafa url("./assets/cases/card-bg.png") center / 100% 100% no-repeat;
}

.prompt-card--case .prompt-card-image {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}

.prompt-card h2 {
  position: absolute;
  left: 16px;
  top: calc(var(--ih) + 16px);
  width: 298px;
  margin: 0;
  overflow: hidden;
  color: #27272a;
  font-size: 20px;
  font-weight: 600;
  line-height: 30px;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.prompt-card p {
  position: absolute;
  left: 16px;
  top: calc(var(--ih) + 54px);
  display: -webkit-box;
  width: 298px;
  margin: 0;
  overflow: hidden;
  color: #71717a;
  font-size: 12px;
  font-weight: 400;
  line-height: 20px;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
}

.prompt-actions {
  position: absolute;
  left: 16px;
  bottom: 16px;
  display: flex;
  gap: 14px;
  width: 298px;
  height: 36px;
}

.prompt-card h2,
.prompt-card p,
.prompt-actions {
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, 12px, 0);
  transition:
    opacity 260ms var(--ease-out-quart),
    transform 420ms var(--ease-out-expo);
}

.prompt-card.is-open h2,
.prompt-card.is-open p,
.prompt-card.is-open .prompt-actions {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0);
  transition-delay: 110ms;
}

.prompt-card--case h2,
.prompt-card--case p {
  opacity: 1;
  pointer-events: auto;
  transform: none;
  transition-delay: 0ms;
}

.prompt-card--case h2 {
  width: calc(100% - 32px);
  font-weight: 500;
}

.prompt-card--case p {
  width: calc(100% - 32px);
  color: #a1a1aa;
  line-height: 18px;
  -webkit-line-clamp: 2;
}

.prompt-actions button,
.prompt-modal-save,
.prompt-modal-copy {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 142px;
  height: 36px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  line-height: 16px;
  transition:
    color 180ms var(--ease-out-quart),
    background-color 180ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart);
}

.prompt-modal-save,
.prompt-modal-copy {
  width: 200px;
  height: 40px;
  font-size: 14px;
  line-height: 20px;
}

.prompt-actions img,
.prompt-modal-save img,
.prompt-modal-copy img {
  width: 20px;
  height: 20px;
}

.prompt-modal-save img,
.prompt-modal-copy img {
  width: 24px;
  height: 24px;
}

.prompt-detail,
.prompt-modal-save,
.case-prompt-detail {
  border: 1px solid #e4e4e7;
  color: #71717a;
  background: transparent;
}

.prompt-copy,
.prompt-modal-copy,
.case-prompt-copy {
  border: 1px solid #27272a;
  color: #fff;
  background: #27272a;
}

.prompt-detail:hover,
.prompt-detail:focus-visible,
.prompt-modal-save:hover,
.prompt-modal-save:focus-visible,
.case-prompt-detail:hover,
.case-prompt-detail:focus-visible {
  color: #27272a;
  border-color: #d4d4d8;
  background: #fff;
  outline: none;
}

.prompt-copy:hover,
.prompt-copy:focus-visible,
.prompt-modal-copy:hover,
.prompt-modal-copy:focus-visible,
.case-prompt-copy:hover,
.case-prompt-copy:focus-visible {
  color: #fff;
  border-color: #18181b;
  background: #18181b;
  outline: none;
}

.prompt-actions .prompt-detail,
.prompt-actions .case-prompt-detail {
  border-color: #d4d4d8;
  color: #71717a;
  background: transparent;
}

.prompt-actions .prompt-detail img,
.prompt-actions .case-prompt-detail img {
  filter: none;
}

.prompt-actions .prompt-copy,
.prompt-actions .case-prompt-copy {
  border-color: #27272a;
  color: #fff;
  background: #27272a;
}

.prompt-actions .prompt-copy img,
.prompt-actions .case-prompt-copy img {
  filter: none;
}

.prompt-actions .prompt-detail:hover,
.prompt-actions .prompt-detail:focus-visible {
  color: #27272a;
  border-color: #a1a1aa;
  background: #fff;
}

.prompt-actions .prompt-copy:hover,
.prompt-actions .prompt-copy:focus-visible {
  color: #fff;
  border-color: #18181b;
  background: #18181b;
}

.inspiration-fade {
  position: absolute;
  left: 50%;
  top: var(--inspiration-fade-top, 2450px);
  z-index: 4;
  width: 100vw;
  height: 360px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 50%);
  opacity: 1;
  transform: translate3d(-50%, 0, 0);
  transition: opacity 240ms var(--ease-out-quart), visibility 240ms var(--ease-out-quart);
}

.inspiration-more {
  position: absolute;
  left: 614px;
  top: var(--inspiration-more-top, 2702px);
  z-index: 5;
  width: 212px;
  height: 48px;
  border: 1px solid #e4e4e7;
  border-radius: 8px;
  color: #52525b;
  background: #fff;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  opacity: 1;
  transition:
    color 180ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart),
    opacity 240ms var(--ease-out-quart),
    visibility 240ms var(--ease-out-quart);
}

.inspiration-more:hover,
.inspiration-more:focus-visible {
  color: #27272a;
  border-color: #d4d4d8;
  outline: none;
}

.inspiration-footer {
  left: 24px;
  top: var(--inspiration-footer-top, 2910px);
}

.inspiration-page .inspiration-footer {
  left: 24px;
  top: var(--inspiration-footer-top, 2910px);
}

.inspiration-page.is-expanded .inspiration-fade,
.inspiration-page:not(.has-more) .inspiration-fade {
  visibility: hidden;
  opacity: 0;
}

.inspiration-page.is-expanded .inspiration-more,
.inspiration-page:not(.has-more) .inspiration-more {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

body.prompt-modal-open {
  overflow: hidden;
}

body.prompt-modal-open .global-notice {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.prompt-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 32px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms var(--ease-out-quart);
}

.prompt-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.prompt-modal-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: var(--modal-frost-bg);
  -webkit-backdrop-filter: var(--modal-frost-blur);
  backdrop-filter: var(--modal-frost-blur);
}

.prompt-modal-panel {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 424px 424px;
  gap: 24px;
  box-sizing: border-box;
  width: 920px;
  max-width: calc(100vw - 64px);
  height: 472px;
  max-height: calc(100vh - 64px);
  padding: 24px;
  overflow: visible;
  border: 0;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 24px 56px rgba(39, 39, 42, 0.11);
  transform: translateY(12px) scale(0.98);
  transition: transform 260ms var(--ease-out-quart);
  --modal-image-height: 436px;
}

.prompt-modal.is-open .prompt-modal-panel {
  transform: translateY(0) scale(1);
}

.prompt-modal-close {
  position: absolute;
  right: 24px;
  top: 24px;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  transition:
    background-color 180ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart),
    box-shadow 220ms var(--ease-out-quart),
    transform 180ms var(--ease-out-quart);
}

.prompt-modal-close:focus,
.prompt-modal-close:focus-visible {
  outline: none;
}

.prompt-modal-close:hover {
  border-color: #27272a;
  background: #27272a;
  box-shadow: 0 6px 16px rgba(39, 39, 42, 0.1);
  transform: scale(1.05);
}

.prompt-modal-close:focus-visible {
  border-color: #27272a;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(39, 39, 42, 0.08);
}

.prompt-modal-close:active {
  transform: scale(0.97);
}

.prompt-modal-close img {
  width: 24px;
  height: 24px;
  transition: filter 180ms var(--ease-out-quart), opacity 180ms var(--ease-out-quart);
}

.prompt-modal-close:hover img {
  filter: brightness(0) invert(1);
}

.prompt-modal-close::before,
.prompt-modal-close::after {
  display: none;
}

.prompt-modal-image {
  display: block;
  width: 424px;
  height: 424px;
  border-radius: 8px;
  background: #fafafa;
  object-fit: contain;
  box-shadow: inset 0 0 0 1px #f4f4f5;
}

.prompt-modal-content {
  position: relative;
  height: 424px;
  padding: 0;
}

.prompt-modal-content h2 {
  margin: 0;
  overflow: hidden;
  color: #27272a;
  font-size: 24px;
  font-weight: 600;
  line-height: 36px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.prompt-modal-info {
  box-sizing: border-box;
  position: relative;
  width: 424px;
  height: calc(100% - 50px);
  margin-top: 14px;
  padding: 12px 4px 12px 12px;
  overflow: hidden;
  border: 0;
  border-radius: 8px;
  background: #fafafa;
  box-shadow: inset 0 0 0 1px #f4f4f5;
}

.prompt-modal-info::after {
  content: "";
  position: absolute;
  left: 1px;
  right: 1px;
  bottom: 52px;
  z-index: 1;
  height: 24px;
  opacity: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(250, 250, 250, 0) 0%, rgba(250, 250, 250, 0.92) 66%, #fafafa 100%);
  transition: opacity 180ms var(--ease-out-quart);
}

.prompt-modal-info.is-overflowing:not(.is-scroll-end)::after {
  opacity: 1;
}

.prompt-modal-text {
  position: relative;
  z-index: 0;
  max-height: calc(100% - 64px);
  margin: 0;
  overflow-x: hidden;
  overflow-y: auto;
  padding-right: 8px;
  color: #52525b;
  font-size: 15px;
  font-weight: 400;
  line-height: 24px;
  overscroll-behavior: contain;
  overflow-wrap: anywhere;
  scrollbar-color: rgba(161, 161, 170, 0.32) transparent;
  scrollbar-width: thin;
  white-space: pre-wrap;
  word-break: break-word;
}

.prompt-modal-text::-webkit-scrollbar {
  width: 4px;
  height: 4px;
}

.prompt-modal-text::-webkit-scrollbar-track {
  margin: 2px 0;
  background: transparent;
}

.prompt-modal-text::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(161, 161, 170, 0.32);
}

.prompt-modal-text::-webkit-scrollbar-thumb:hover {
  background: rgba(113, 113, 122, 0.48);
}

.prompt-modal-text::-webkit-scrollbar-corner {
  background: transparent;
}

.prompt-modal-actions {
  position: absolute;
  left: 12px;
  bottom: 12px;
  z-index: 2;
  display: flex;
  width: 400px;
  gap: 12px;
  height: 40px;
}

.prompt-modal-save,
.prompt-modal-copy {
  width: 194px;
  text-decoration: none;
}

.prompt-modal-panel.is-portrait {
  height: 684px;
}

.prompt-modal-panel.is-portrait .prompt-modal-image,
.prompt-modal-panel.is-portrait .prompt-modal-content {
  height: 636px;
}

.prompt-modal-panel.is-portrait .prompt-modal-image {
  object-fit: contain;
}

.prompt-modal-panel.is-landscape,
.prompt-modal-panel.is-ultrawide {
  display: grid;
  grid-template-columns: 636px;
  grid-template-rows: 36px 318px 260px;
  gap: 24px;
  width: 684px;
  height: 710px;
}

.prompt-modal-panel.is-landscape .prompt-modal-image,
.prompt-modal-panel.is-ultrawide .prompt-modal-image {
  grid-column: 1;
  grid-row: 2;
  width: 636px;
  max-width: none;
  height: 318px;
  object-fit: contain;
}

.prompt-modal-panel.is-landscape .prompt-modal-content,
.prompt-modal-panel.is-ultrawide .prompt-modal-content {
  display: contents;
}

.prompt-modal-panel.is-landscape .prompt-modal-content h2,
.prompt-modal-panel.is-ultrawide .prompt-modal-content h2 {
  grid-column: 1;
  grid-row: 1;
  align-self: center;
  width: calc(100% - 60px);
  font-size: 24px;
  line-height: 36px;
}

.prompt-modal-panel.is-landscape .prompt-modal-info,
.prompt-modal-panel.is-ultrawide .prompt-modal-info {
  grid-column: 1;
  grid-row: 3;
  position: relative;
  left: auto;
  top: auto;
  width: 636px;
  height: 260px;
  margin-top: 0;
}

.prompt-modal-panel.is-landscape .prompt-modal-text,
.prompt-modal-panel.is-ultrawide .prompt-modal-text {
  max-height: calc(100% - 64px);
  line-height: 24px;
}

.prompt-modal-panel.is-landscape .prompt-modal-actions,
.prompt-modal-panel.is-ultrawide .prompt-modal-actions {
  width: 612px;
}

.prompt-modal-panel.is-landscape .prompt-modal-save,
.prompt-modal-panel.is-landscape .prompt-modal-copy,
.prompt-modal-panel.is-ultrawide .prompt-modal-save,
.prompt-modal-panel.is-ultrawide .prompt-modal-copy {
  width: 300px;
}

.prompt-modal-panel.is-landscape .prompt-modal-image,
.prompt-modal-panel.is-ultrawide .prompt-modal-image {
  object-fit: contain;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .prompt-modal-panel {
    display: block;
    width: min(680px, calc(100vw - 48px));
    height: auto;
    max-height: calc(100vh - 48px);
    padding: 16px;
    overflow: auto;
  }

  .prompt-modal-image {
    position: static;
    width: 100%;
    height: auto;
    max-height: 480px;
    object-fit: contain;
  }

  .prompt-modal-content {
    position: static;
    width: 100%;
    height: auto;
    padding: 20px 0 0;
  }

  .prompt-modal-info {
    width: 100%;
    height: auto;
    min-height: 0;
  }

  .prompt-modal-info::after {
    display: none;
  }

  .prompt-modal-actions {
    position: static;
    width: 400px;
    margin-top: 16px;
  }

  .prompt-modal-panel.is-portrait,
  .prompt-modal-panel.is-landscape,
  .prompt-modal-panel.is-ultrawide {
    height: auto;
  }

  .prompt-modal-panel.is-portrait .prompt-modal-image,
  .prompt-modal-panel.is-portrait .prompt-modal-content,
  .prompt-modal-panel.is-landscape .prompt-modal-image,
  .prompt-modal-panel.is-ultrawide .prompt-modal-image,
  .prompt-modal-panel.is-landscape .prompt-modal-content,
  .prompt-modal-panel.is-ultrawide .prompt-modal-content {
    display: block;
    position: static;
    width: 100%;
    max-width: none;
    height: auto;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-info,
  .prompt-modal-panel.is-ultrawide .prompt-modal-info {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    height: auto;
    margin-top: 14px;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-text,
  .prompt-modal-panel.is-ultrawide .prompt-modal-text {
    max-height: 220px;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-actions,
  .prompt-modal-panel.is-ultrawide .prompt-modal-actions {
    width: 100%;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-save,
  .prompt-modal-panel.is-landscape .prompt-modal-copy,
  .prompt-modal-panel.is-ultrawide .prompt-modal-save,
  .prompt-modal-panel.is-ultrawide .prompt-modal-copy {
    flex: 1 1 0;
    width: auto;
  }
}

.hero {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 780px;
}

.hero-bg {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 780px;
  object-fit: cover;
}

.hero-header {
  position: absolute;
  left: var(--side);
  top: 24px;
  display: flex;
  align-items: center;
  gap: 42px;
}

.logo {
  width: 155px;
  height: 32px;
}

.logo-svg {
  width: 155px;
  height: 32px;
  object-fit: contain;
}

.hero-nav {
  display: flex;
  gap: 24px;
  contain: layout style;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
}

.hero-nav a {
  position: relative;
  color: #a1a1aa;
  transition: color 160ms ease;
}

.hero-nav a::after {
  position: absolute;
  left: 50%;
  top: 24px;
  width: 48px;
  height: 8px;
  content: "";
  opacity: 0;
  pointer-events: none;
  background: url("./assets/remote/f107f9fd-b4b2-4155-8538-1e2346b53bcd.svg") center / contain no-repeat;
  transform: translate3d(-50%, -2px, 0) scaleX(0.72);
  transition: opacity 160ms ease, transform 180ms var(--ease-out-quart);
  will-change: opacity, transform;
}

.hero-nav a.is-active,
.hero-nav a:hover {
  color: #27272a;
}

.hero-nav a.is-active::after,
.hero-nav a:hover::after,
.hero-nav a:focus-visible::after {
  opacity: 1;
  transform: translate3d(-50%, 0, 0) scaleX(1);
}

.hero-nav:hover a.is-active:not(:hover)::after {
  opacity: 0;
}

.hero-nav a:hover {
  color: #27272a;
}

.hero-nav a:focus-visible {
  color: #27272a;
  outline: 2px solid #27272a;
  outline-offset: 4px;
}

.mobile-menu-toggle,
.mobile-menu {
  display: none;
}

.hero-header,
.inspiration-header,
.policy-header,
.skills-header,
.cases-header,
.site-header {
  contain: layout style;
}

body.page-enter .hero-header,
body.page-enter .inspiration-header,
body.page-enter .policy-header,
body.page-enter .skills-header,
body.page-enter .cases-header,
body.page-enter .site-header {
  animation: none;
  opacity: 1;
  transform: none;
}

body.page-enter .policy-title-row {
  animation: pageContentEnter 320ms var(--ease-out-quart) both;
}

body.page-navigating .hero-header,
body.page-navigating .inspiration-header,
body.page-navigating .policy-header,
body.page-navigating .skills-header,
body.page-navigating .cases-header,
body.page-navigating .site-header {
  opacity: 1;
  transform: none;
  transition: none;
}

@keyframes pageHeaderEnter {
  from {
    opacity: 0;
    transform: translate3d(0, -8px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes pageContentEnter {
  from {
    opacity: 0;
    transform: translate3d(0, 10px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

.mobile-break {
  display: none;
}

.scroll-text {
  position: absolute;
  left: var(--side);
  top: 732px;
  font-size: 16px;
  line-height: 24px;
  color: #a1a1aa;
}

.scroll-arrow {
  position: absolute;
  left: calc(var(--side) + 88px);
  top: 728px;
  width: 107.94px;
  height: 96.96px;
  object-fit: contain;
  transform: rotate(-150deg);
}

.accent {
  position: absolute;
  object-fit: contain;
}

.accent-hero {
  left: calc(var(--side) + 498px);
  top: 169px;
  width: 66.14px;
  height: 66.14px;
  transform: translate3d(0, var(--hero-accent-y), 0) rotate(32deg);
  will-change: transform;
}

.hero-title {
  position: absolute;
  left: var(--side);
  top: 210px;
  width: 498px;
  height: 150px;
  font-size: 54px;
  font-weight: 600;
  line-height: 72px;
  white-space: nowrap;
  opacity: var(--hero-fade);
  transform: translate3d(0, var(--hero-copy-y), 0);
  transition: opacity 240ms linear;
}

.hero-title div {
  position: relative;
}

.title-row-1 {
  display: flex;
  align-items: center;
  gap: 8px;
}

.hero-title span {
  color: transparent;
  background: url("./assets/figma/title-gradient.webp") 0% 50% / 168% 100% no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  animation: title-gradient-flow 6.8s var(--ease-out-quart) infinite alternate;
  will-change: background-position;
}

@keyframes title-gradient-flow {
  from {
    background-position: 0% 50%;
  }

  to {
    background-position: 100% 50%;
  }
}

.hero-desc {
  position: absolute;
  left: var(--side);
  top: 376px;
  width: 498px;
  height: 72px;
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 24px;
  opacity: var(--hero-fade);
  transform: translate3d(0, var(--hero-copy-y), 0);
  transition: opacity 240ms linear;
}

.hero-actions {
  position: absolute;
  left: var(--side);
  top: 472px;
  z-index: 40;
  display: flex;
  gap: 16px;
  width: 336px;
  height: 48px;
  opacity: var(--hero-fade);
  transform: translate3d(0, var(--hero-copy-y), 0);
  transition: opacity 240ms linear;
}

.download,
.learn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 48px;
  border-radius: 8px;
  font-family: inherit;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  transform: translate3d(0, 0, 0);
  transition: transform 220ms var(--ease-out-quart), box-shadow 220ms var(--ease-out-quart), border-color 220ms var(--ease-out-quart), background-color 220ms var(--ease-out-quart), color 220ms var(--ease-out-quart), filter 220ms var(--ease-out-quart), opacity 220ms var(--ease-out-quart);
}

.download-wrap {
  position: relative;
  width: 160px;
  height: 48px;
  z-index: 20;
}

.download {
  gap: 8px;
  appearance: none;
  border: 0;
  color: #fff;
  background: #27272a;
  cursor: pointer;
}

.download:hover,
.learn:hover {
  transform: translate3d(0, 0, 0);
}

.download:hover {
  color: rgba(255, 255, 255, 0.6);
  background: #27272a;
  box-shadow: none;
  transform: translate3d(0, 0, 0);
}

.learn:hover {
  color: rgba(39, 39, 42, 0.6);
  border-color: #d4d4d8;
  background: #fafafa;
}

.download:active,
.learn:active {
  transform: translate3d(0, 0, 0) scale(0.98);
}

.download img {
  width: 24px;
  height: 24px;
  opacity: 1;
}

.download:hover img {
  opacity: 0.6;
  filter: none;
}

.download-menu {
  position: absolute;
  left: 0;
  top: 60px;
  z-index: 80;
  width: 308px;
  padding: 8px;
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 44px rgba(39, 39, 42, 0.12);
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, -8px, 0) scale(0.98);
  transform-origin: top left;
  transition:
    opacity 220ms var(--ease-out-quart),
    transform 260ms var(--ease-out-quart);
  backdrop-filter: blur(18px);
}

.download-wrap.is-open .download-menu {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
}

.download-menu a {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  border-radius: 8px;
  color: #27272a;
  transition:
    background-color 180ms var(--ease-out-quart),
    color 180ms var(--ease-out-quart);
}

.download-menu a:hover,
.download-menu a:focus-visible {
  outline: none;
  background: #f4f4f5;
}

.download-menu span {
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
}

.download-menu .download-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.download-menu .download-badge {
  flex: 0 0 auto;
  padding: 2px 8px;
  border: 1px solid rgba(217, 70, 239, 0.32);
  border-radius: 999px;
  color: #d946ef;
  background: transparent;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.download-menu small {
  color: #71717a;
  font-size: 13px;
  font-weight: 400;
  line-height: 20px;
}

.learn {
  color: #52525b;
  background: #fafafa;
  border: 1px solid #d4d4d8;
}

.hero-board {
  position: absolute;
  left: calc(var(--side) + 600px);
  top: 84px;
  width: 792px;
  height: 672px;
  overflow: hidden;
  border-radius: 16px;
  transform: translate3d(0, var(--hero-board-y), 0);
  will-change: transform;
}

.board-shadow {
  position: absolute;
  inset: 0;
  width: 792px;
  height: 672px;
  border-radius: 16px;
  background: #f4f4f5;
  display: none;
}

.board-white {
  position: absolute;
  inset: 0;
  width: 792px;
  height: 672px;
  border-radius: 16px;
  background: #fff;
}

.hero-col {
  position: absolute;
  width: 360px;
  overflow: visible;
}

.hero-col-left {
  left: 24px;
  top: -61px;
}

.hero-col-right {
  left: 408px;
  top: 24px;
}

.hero-track {
  display: flex;
  flex-direction: column;
  gap: 24px;
  will-change: transform;
}

.hero-track img {
  width: 360px;
  height: auto;
  display: block;
  object-fit: cover;
  border-radius: 12px;
  flex-shrink: 0;
}

.hero-track-left {
  animation: hero-scroll-left 34s linear infinite;
}

.hero-track-right {
  animation: hero-scroll-right 52s linear infinite;
}

@keyframes hero-scroll-left {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(0, -1632px, 0); }
}

@keyframes hero-scroll-right {
  from { transform: translate3d(0, -2204px, 0); }
  to { transform: translate3d(0, 0, 0); }
}

.hero-shot {
  position: absolute;
  width: 360px;
  object-fit: cover;
}

.hero-shot-1 {
  left: 24px;
  top: -61px;
  height: 684px;
}

.hero-shot-2 {
  left: 408px;
  top: 24px;
  height: 716px;
}

.hero-shot-3 {
  left: 24px;
  top: 647px;
  height: 504px;
}

.kicker {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 12px;
  height: 36px;
  color: #52525b;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
}

.kicker img {
  width: 36px;
  height: 36px;
}

.feature-head,
.layout-head,
.share-head,
.faq-head {
  position: absolute;
  left: var(--side);
}

.feature-head {
  left: var(--feature-head-left);
  top: var(--feature-head-top);
  width: var(--feature-head-width);
  height: var(--feature-head-height);
}

.layout-head {
  left: var(--layout-head-left);
  top: var(--layout-head-top);
  width: var(--layout-head-width);
  height: var(--layout-head-height);
}

.share-head {
  left: var(--share-head-left);
  top: var(--share-head-top);
  width: var(--share-head-width);
  height: var(--share-head-height);
}

.faq-head {
  left: var(--faq-head-left);
  top: var(--faq-head-top);
  width: var(--faq-head-width);
  height: var(--faq-head-height);
}

.feature-head .kicker,
.layout-head .kicker,
.share-head .kicker,
.faq-head .kicker {
  left: 0;
  top: 0;
}

.feature-head h2,
.layout-head h2,
.share-head h2,
.faq-head h2 {
  position: absolute;
  left: 0;
  top: var(--section-title-top);
  margin: 0;
  font-size: var(--section-title-size);
  font-weight: 600;
  line-height: var(--section-title-line);
  white-space: nowrap;
}

.feature-head .kicker {
  left: var(--feature-kicker-left);
}

.feature-accent {
  position: absolute;
  left: var(--feature-accent-left);
  top: var(--feature-accent-top);
  width: 60px;
  height: 60px;
}

.layout-head .kicker {
  left: var(--layout-kicker-left);
}

.layout-accent {
  position: absolute;
  left: var(--layout-accent-left);
  top: var(--layout-accent-top);
  width: 60px;
  height: 60px;
}

.share-head .kicker {
  left: var(--share-kicker-left);
}

.share-accent {
  position: absolute;
  left: var(--share-accent-left);
  top: var(--share-accent-top);
  width: 90px;
  height: 48px;
}

.faq-head .kicker {
  left: var(--faq-kicker-left);
}

.faq-head h2 {
  left: 0;
  top: var(--faq-title-top);
}

.faq-accent {
  position: absolute;
  left: var(--faq-accent-left);
  top: var(--faq-accent-top);
  width: 48px;
  height: 48px;
  transform: rotate(180deg);
}

.features {
  position: absolute;
  left: var(--features-left);
  top: var(--features-top);
  width: var(--features-width);
  height: var(--features-height);
}

.feature-card {
  position: absolute;
  width: var(--feature-card-width);
  height: var(--feature-card-height);
  overflow: hidden;
  border-radius: 20px;
  background: #fafafa;
  transform: translate3d(0, 0, 0);
  transition: transform 360ms var(--ease-out-quart);
}

.feature-card:hover {
  transform: translate3d(0, -6px, 0);
}

.f1 {
  left: var(--feature-card-1-left);
  top: var(--feature-card-1-top);
}

.f2 {
  left: var(--feature-card-2-left);
  top: var(--feature-card-2-top);
}

.f3 {
  left: var(--feature-card-3-left);
  top: var(--feature-card-3-top);
}

.f4 {
  left: var(--feature-card-4-left);
  top: var(--feature-card-4-top);
}

.feature-panel {
  position: absolute;
  inset: 0;
  z-index: 0;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fafafa;
}

.feature-pattern {
  position: absolute;
  left: var(--feature-pattern-left);
  top: 12px;
  z-index: 1;
  width: 336px;
  height: 336px;
  opacity: 0.6;
  pointer-events: none;
  background-image: radial-gradient(circle, #e4e4e7 0 1.5px, transparent 1.6px);
  background-position: 5px 5px;
  background-size: 19px 19px;
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 0 42%, rgba(0, 0, 0, 0) 72%);
  mask-image: radial-gradient(circle at 50% 50%, #000 0 42%, rgba(0, 0, 0, 0) 72%);
}

.f4 .feature-pattern {
  left: var(--feature-pattern-alt-left);
}

.feature-symbol {
  position: absolute;
  left: 24px;
  top: 156px;
  z-index: 3;
  width: 60px;
  height: 60px;
  overflow: hidden;
}

.feature-symbol img {
  display: block;
}

.symbol-f1 img {
  position: absolute;
  left: 5px;
  top: 5px;
  width: 52.975px;
  height: 52.553px;
  filter: none;
}

html[data-color-scheme="dark"] .symbol-f1 img {
  filter: none;
}

.symbol-mask {
  position: absolute;
  display: block;
  overflow: hidden;
  -webkit-mask-image: none !important;
  mask-image: none !important;
}

.symbol-mask img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: fill;
  filter: none;
}

html[data-color-scheme="dark"] .symbol-mask img {
  filter: none;
}

.symbol-f2-main {
  left: 5.009px;
  top: 5.004px;
  width: 50.013px;
  height: 49.99px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -5.009px -5.004px;
  mask-position: -5.009px -5.004px;
}

.symbol-f2-spark {
  left: 35.5px;
  top: 35.875px;
  width: 22.525px;
  height: 22.525px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -35.5px -35.875px;
  mask-position: -35.5px -35.875px;
}

.symbol-f3-main {
  left: 7.025px;
  top: 8.275px;
  width: 45.925px;
  height: 43.425px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -7.025px -8.275px;
  mask-position: -7.025px -8.275px;
}

.symbol-f3-spark {
  left: 39.5px;
  top: 38px;
  width: 17.475px;
  height: 17.525px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -39.5px -38px;
  mask-position: -39.5px -38px;
}

.symbol-f4-main {
  left: 4.425px;
  top: 7.496px;
  width: 46.6px;
  height: 45.004px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -4.425px -7.496px;
  mask-position: -4.425px -7.496px;
}

.symbol-f4-spark {
  left: 32.975px;
  top: 5.875px;
  width: 22.525px;
  height: 22.525px;
  -webkit-mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  mask-image: url("./assets/remote/dd304fbd-738e-4212-bf08-0ab268fa4b63.svg");
  -webkit-mask-position: -32.975px -5.875px;
  mask-position: -32.975px -5.875px;
}

.feature-card h3 {
  position: absolute;
  left: 24px;
  top: 240px;
  z-index: 3;
  margin: 0;
  color: #27272a;
  font-family: var(--display-font);
  font-size: 32px;
  font-weight: 600;
  line-height: 48px;
  letter-spacing: 0;
}

html[data-lang="en"] .feature-card h3 {
  font-weight: 500;
}

html[data-lang="zh"] .feature-card h3 {
  font-weight: 600;
}

.feature-card > p {
  position: absolute;
  left: 24px;
  top: 300px;
  z-index: 3;
  width: var(--feature-copy-width);
  margin: 0;
  color: var(--muted);
  font-family: var(--display-font);
  font-size: 20px;
  font-weight: 400;
  line-height: 36px;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.f4 > p {
  top: 300px;
  width: var(--feature-copy-width);
  z-index: 3;
  font-size: 20px;
  line-height: 36px;
  white-space: normal;
}

.menu-shot,
.prompt-shot,
.share-shot,
.model-shot {
  position: absolute;
  left: var(--feature-shot-left);
  top: var(--feature-shot-top);
  z-index: 2;
  width: 318px;
  height: 312px;
}

.menu-shot > img:first-child,
.prompt-shot > img:first-child,
.shot-bg {
  position: absolute;
  inset: 0;
  width: 318px;
  height: 312px;
}

.menu-shot span,
.prompt-shot span,
.model-shot span {
  position: absolute;
  font-size: 20px;
  line-height: 30px;
}

.m1 { left: 24px; top: 16px; color: var(--soft); }
.m2 { left: 24px; top: 62px; color: var(--soft); }
.m3 { left: 24px; top: 108px; color: var(--soft); }
.m4 { display: none; }
.m5 { left: 24px; top: 230px; color: var(--soft); }

.menu-active {
  position: absolute;
  left: 12px;
  top: 154px;
  width: 294px;
  height: 60px;
}

.menu-label {
  left: 72px;
  top: 169px;
  color: #27272a;
  font-size: 20px;
  font-weight: 500;
  line-height: 30px;
  white-space: nowrap;
}

.menu-shot .menu-label {
  font-size: 20px;
  line-height: 30px;
}

html[data-lang="en"] .menu-shot .menu-label {
  font-size: 16px;
}

.menu-logo {
  left: 24px;
  top: 166px;
  width: 36px;
  height: 36px;
  overflow: hidden;
  border-radius: 8px;
  background: #ffffff;
}

.menu-logo img {
  position: absolute;
  left: 2px;
  top: 2px;
  width: 155px;
  height: 32px;
  max-width: none;
}

.cursor {
  left: 246px;
  top: 202px;
  width: 36px;
  height: 36px;
}

.cursor img {
  position: absolute;
  max-width: none;
}

.cursor .cursor-fallback {
  display: none;
}

.cursor .cursor-outline,
.cursor .cursor-fill {
  position: absolute;
  display: block;
  inset: auto;
  max-width: none;
}

.cursor .cursor-outline {
  left: 15.32%;
  top: 10.51%;
  width: 75.29%;
  height: 80.09%;
}

.cursor .cursor-fill {
  left: 19.07%;
  top: 14.26%;
  width: 67.79%;
  height: 72.64%;
}

.prompt-shot span {
  left: 16px;
  top: 16px;
  width: 286px;
  height: 192px;
  overflow: hidden;
  color: var(--soft);
  font-size: 16px;
  line-height: 24px;
}

.wallpaper {
  position: absolute;
  left: 12px;
  top: 12px;
  width: 294px;
  height: 240px;
  border-radius: 10px;
  object-fit: cover;
  object-position: center;
}

.selected {
  position: absolute;
  left: 12px;
  top: 12px;
  width: 294px;
  height: 48px;
  border-radius: 8px;
  background: #f4f4f5;
}

.down {
  position: absolute;
  left: 270px;
  top: 24px;
  width: 24px;
  height: 24px;
}

.model {
  position: absolute;
  left: 24px;
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.gemini { top: 24px; }
.minimax { top: 76px; }
.qwen { top: 124px; }
.doubao { top: 172px; }
.deepseek { top: 220px; }

.qwen {
  left: 26.062px;
  top: 126.062px;
  width: 19.877px;
  height: 19.877px;
}

.deepseek {
  left: 25.296px;
  top: 223.698px;
  width: 22.14px;
  height: 16.602px;
}

.deepseek,
.t-deepseek {
  display: none;
}

.model-shot span {
  left: 60px;
  color: #27272a;
  font-size: 20px;
  font-weight: 500;
  line-height: 24px;
  white-space: nowrap;
}

.t-gemini { top: 24px; }
.t-minimax { top: 76px; }
.t-qwen { top: 124px; }
.t-doubao { top: 172px; }
.t-deepseek { top: 220px; }

.layout-toggle {
  position: absolute;
  left: var(--layout-toggle-left);
  top: var(--layout-toggle-top);
  display: flex;
  align-items: center;
  gap: 4px;
  width: 268px;
  height: 60px;
  padding: 6px;
  border-radius: 60px;
  background: #f4f4f5;
  isolation: isolate;
  overflow: hidden;
}

.layout-toggle::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 6px;
  z-index: 0;
  width: 116px;
  height: 48px;
  border-radius: 60px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(39, 39, 42, 0.04);
  transform: translate3d(0, 0, 0) scaleX(1);
  transform-origin: left center;
  transition:
    transform 420ms var(--ease-out-quart),
    box-shadow 420ms var(--ease-out-quart);
  will-change: transform;
}

.layout-toggle.is-sidebar::before {
  transform: translate3d(120px, 0, 0) scaleX(1.1724);
}

.layout-toggle:hover::before {
  box-shadow: 0 8px 22px rgba(39, 39, 42, 0.08);
}

.layout-toggle button {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  height: 48px;
  border: 0;
  border-radius: 60px;
  background: transparent;
  color: #a1a1aa;
  font: 500 20px/30px "IBM Plex Sans SC", sans-serif;
  white-space: nowrap;
  cursor: pointer;
  transition:
    color 260ms var(--ease-out-quart),
    transform 320ms var(--ease-out-quart);
}

.layout-toggle button:first-child {
  width: 116px;
}

.layout-toggle button:last-child {
  width: 136px;
}

.layout-toggle button.is-active {
  color: #27272a;
  transform: translate3d(0, -1px, 0);
}

.layout-demo {
  position: absolute;
  left: var(--layout-demo-left);
  top: var(--layout-demo-top);
  width: var(--layout-demo-width);
  height: var(--layout-demo-height);
  overflow: hidden;
  border-radius: 20px;
  background: #27272a;
  isolation: isolate;
}

.layout-window-layer {
  position: absolute;
  inset: 0;
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
  transform-origin: center;
  transition:
    opacity 340ms var(--ease-out-quart),
    transform 460ms var(--ease-out-quart);
  will-change: opacity, transform;
  backface-visibility: hidden;
}

.layout-mode-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 260ms var(--ease-out-quart);
}

.layout-demo.is-sidebar .layout-window-layer {
  opacity: 0;
  visibility: hidden;
  transform: translate3d(-18px, 0, 0) scale(0.985);
  pointer-events: none;
  transition: none;
}

.layout-demo.is-sidebar .layout-window-layer .layout-column-track {
  animation-play-state: paused;
}

.layout-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.6;
  transition: opacity 260ms var(--ease-out-quart);
}

.layout-column {
  position: absolute;
  top: -271px;
  width: 300px;
  opacity: 0.4;
  transition: opacity 260ms var(--ease-out-quart);
}

.layout-column-track {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 300px;
  animation: layout-column-scroll 42s linear infinite;
  will-change: transform;
}

.layout-column-track-reverse {
  animation-name: layout-column-scroll-reverse;
  animation-duration: 48s;
}

.layout-column img,
.layout-card-empty {
  width: 300px;
  border-radius: 12px;
  object-fit: cover;
  flex-shrink: 0;
}

.layout-card-tall,
.layout-card-empty {
  height: 400px;
}

.layout-card-small {
  height: 300px;
}

.layout-card-empty {
  display: block;
}

.layout-column.c1 { left: var(--layout-column-1-left); top: var(--layout-column-1-top); }
.layout-column.c2 { left: var(--layout-column-2-left); top: var(--layout-column-2-top); }
.layout-column.c3 { left: var(--layout-column-3-left); top: var(--layout-column-3-top); }
.layout-column.c4 { left: var(--layout-column-4-left); top: var(--layout-column-4-top); }

.layout-panel {
  position: absolute;
  left: var(--layout-panel-left);
  top: var(--layout-panel-top);
  width: 600px;
  height: 340px;
  border-radius: 12px;
  overflow: hidden;
  background: transparent;
  z-index: 2;
  transition: opacity 260ms var(--ease-out-quart);
}

.layout-panel-shot,
.layout-sidebar-panel-shot {
  position: absolute;
  inset: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: cover;
}

.layout-panel-shot ~ *,
.layout-sidebar-panel-shot ~ * {
  display: none;
}

.layout-panel-title {
  position: absolute;
  left: 10px;
  top: 8px;
  color: #27272a;
  font-family: "Smiley_Sans:Oblique", "Smiley Sans", "Smiley_Sans", "IBM Plex Sans SC", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
}

.layout-divider {
  position: absolute;
  left: 0;
  top: 40px;
  width: 600px;
  height: 1px;
  background: #e4e4e7;
}

.layout-config {
  position: absolute;
  right: 43px;
  top: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
  width: 60px;
  height: 24px;
  padding: 4px 8px;
  border: 1px solid #e4e4e7;
  border-radius: 24px;
  color: #52525b;
  font-size: 12px;
  line-height: 16px;
  white-space: nowrap;
}

.layout-config img,
.layout-actions-mini img {
  width: 16px;
  height: 16px;
}

.layout-avatar {
  position: absolute;
  right: 10px;
  top: 8px;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  overflow: hidden;
  border-radius: 999px;
}

.layout-avatar .layout-avatar-bg,
.layout-avatar .layout-avatar-icon {
  position: absolute;
  left: 0;
  top: 0;
}

.layout-avatar .layout-avatar-bg {
  width: 24px;
  height: 24px;
}

.layout-avatar .layout-avatar-icon {
  left: 4px;
  top: 4px;
  width: 16px;
  height: 16px;
}

.layout-upload,
.layout-result {
  position: absolute;
  top: 50px;
  height: 280px;
  border: 1px solid #f4f4f5;
  background: #fff;
}

.layout-upload {
  left: 10px;
  width: 280px;
  overflow: hidden;
  border-radius: 12px;
}

.layout-preview-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.layout-result {
  left: 300px;
  width: 290px;
  border-radius: 8px;
}

.layout-result p {
  position: absolute;
  left: 11px;
  top: 11px;
  width: 268px;
  margin: 0;
  color: #52525b;
  font-size: 12px;
  line-height: 16px;
}

.layout-actions-mini {
  position: absolute;
  left: 11px;
  bottom: 11px;
  display: flex;
  gap: 8px;
}

.layout-actions-mini button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 130px;
  height: 32px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fff;
  color: #27272a;
  font: 400 12px/16px "IBM Plex Sans SC", sans-serif;
}

.layout-actions-mini button:last-child {
  border-color: transparent;
  background: #27272a;
  color: #fff;
}

.layout-sidebar-layer {
  position: absolute;
  inset: 0;
  z-index: 3;
  opacity: 0;
  visibility: hidden;
  transform: translate3d(18px, 0, 0) scale(0.985);
  transform-origin: center;
  pointer-events: none;
  transition:
    opacity 340ms var(--ease-out-quart),
    transform 460ms var(--ease-out-quart);
  will-change: opacity, transform;
  backface-visibility: hidden;
}

.layout-sidebar-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.6;
}

.sidebar-column {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 24px;
  opacity: 0.5;
  overflow: visible;
}

.sidebar-column-1 {
  left: var(--sidebar-column-1-left);
  top: var(--sidebar-column-1-top);
  border-radius: 12px;
  width: 300px;
}

.sidebar-column-2 {
  left: var(--sidebar-column-2-left);
  top: var(--sidebar-column-2-top);
  width: 302px;
}

.sidebar-column-3 {
  left: var(--sidebar-column-3-left);
  top: var(--sidebar-column-3-top);
  width: 300px;
}

.sidebar-column-track {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
  will-change: transform;
}

.sidebar-column-track-1172 {
  animation: sidebar-scroll-1172 44s linear infinite;
}

.sidebar-column-track-1148 {
  animation: sidebar-scroll-1148 42s linear infinite;
}

.sidebar-column-track-1072 {
  animation: sidebar-scroll-1072 40s linear infinite;
}

.sidebar-column-track-reverse {
  animation-direction: reverse;
}

.sidebar-column img {
  width: 100%;
  object-fit: cover;
  border-radius: 12px;
  flex-shrink: 0;
}

.sidebar-card-tall {
  height: 400px;
}

.sidebar-card-small {
  height: 300px;
}

.sidebar-card-short {
  height: 200px;
}

.layout-sidebar-panel {
  position: absolute;
  left: var(--layout-sidebar-panel-left);
  top: var(--layout-sidebar-panel-top);
  width: 300px;
  height: 630px;
  border-radius: 10px;
  overflow: hidden;
  background: transparent;
}

.sidebar-panel-title {
  position: absolute;
  left: 10px;
  top: 8px;
  color: #27272a;
  font-family: "Smiley_Sans:Oblique", "Smiley Sans", "Smiley_Sans", "IBM Plex Sans SC", sans-serif;
  font-size: 20px;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
}

.sidebar-panel-divider {
  position: absolute;
  left: 0;
  top: 40px;
  width: 300px;
  height: 1px;
  background: #e4e4e7;
}

.sidebar-panel-config {
  position: absolute;
  left: 196px;
  top: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
  width: 60px;
  height: 24px;
  padding: 4px 8px;
  border: 1px solid #e4e4e7;
  border-radius: 24px;
  color: #52525b;
  font-size: 12px;
  line-height: 16px;
  white-space: nowrap;
}

.sidebar-panel-config img,
.sidebar-panel-actions img {
  width: 16px;
  height: 16px;
}

.sidebar-panel-close {
  position: absolute;
  left: 266px;
  top: 8px;
  width: 24px;
  height: 24px;
}

.sidebar-close-bg,
.sidebar-close-icon {
  position: absolute;
  left: 0;
  top: 0;
}

.sidebar-close-bg {
  width: 24px;
  height: 24px;
}

.sidebar-close-icon {
  left: 4px;
  top: 4px;
  width: 16px;
  height: 16px;
}

.sidebar-panel-preview,
.sidebar-panel-result {
  position: absolute;
  left: 10px;
  width: 280px;
  border: 1px solid #f4f4f5;
  background: #fff;
}

.sidebar-panel-preview {
  top: 50px;
  height: 280px;
  overflow: hidden;
  border-radius: 12px;
}

.sidebar-panel-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-panel-result {
  top: 340px;
  height: 280px;
  border-radius: 8px;
}

.sidebar-panel-result p {
  position: absolute;
  left: 10px;
  top: 10px;
  width: 260px;
  margin: 0;
  color: #52525b;
  font-size: 12px;
  line-height: 16px;
}

.sidebar-panel-actions {
  position: absolute;
  left: 10px;
  bottom: 11px;
  display: flex;
  gap: 12px;
}

.sidebar-panel-actions button {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  width: 124px;
  height: 32px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fff;
  color: #27272a;
  font: 400 12px/16px "IBM Plex Sans SC", sans-serif;
}

.sidebar-panel-actions button:last-child {
  border-color: transparent;
  background: #27272a;
  color: #fff;
}

.layout-demo.is-window .layout-sidebar-layer .sidebar-column-track {
  animation-play-state: paused;
}

.layout-demo.is-sidebar .layout-bg,
.layout-demo.is-sidebar .layout-column,
.layout-demo.is-sidebar .layout-panel {
  opacity: 0;
  pointer-events: none;
}

.layout-demo.is-sidebar .layout-sidebar-layer {
  opacity: 1;
  visibility: visible;
  transform: translate3d(0, 0, 0) scale(1);
  pointer-events: auto;
}

.layout-demo.is-sidebar .layout-sidebar-layer .sidebar-column-track {
  animation-play-state: running;
}

.layout-mobile-panel {
  display: none;
}

@keyframes layout-column-scroll {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(0, -1172px, 0);
  }
}

@keyframes layout-column-scroll-reverse {
  from {
    transform: translate3d(0, -1172px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes sidebar-scroll-1172 {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(0, -1172px, 0);
  }
}

@keyframes sidebar-scroll-1148 {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(0, -1148px, 0);
  }
}

@keyframes sidebar-scroll-1072 {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(0, -1072px, 0);
  }
}

.share-row {
  position: absolute;
  left: var(--share-row-left);
  top: var(--share-row-top);
  display: flex;
  gap: var(--share-row-gap);
  width: max-content;
  height: var(--share-row-height);
  animation: share-marquee 96s linear infinite;
  will-change: transform;
}

.share-image {
  flex: 0 0 auto;
  width: var(--share-card-width);
  height: var(--share-card-height);
  object-fit: cover;
  border-radius: 12px;
  transform: translate3d(0, 0, 0);
  transition: transform 360ms var(--ease-out-quart), box-shadow 360ms var(--ease-out-quart);
}

.share-image:hover {
  transform: translate3d(0, -8px, 0);
  box-shadow: 0 18px 48px rgba(24, 24, 27, 0.12);
}

@keyframes share-marquee {
  to {
    transform: translateX(var(--share-marquee-distance));
  }
}

@media (prefers-reduced-motion: reduce) {
  .share-row {
    animation: none;
  }
}

.faq {
  position: absolute;
  left: var(--faq-left);
  top: var(--faq-top);
  display: grid;
  grid-template-columns: repeat(2, var(--faq-col-width));
  column-gap: var(--faq-col-gap);
  align-items: start;
  width: var(--faq-width);
  min-height: 406px;
  padding-top: 17px;
}

.top-line {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--faq-width);
  height: 1px;
  background: #f4f4f5;
}

.faq-col {
  width: var(--faq-col-width);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

details {
  position: relative;
  min-height: 65px;
  border-bottom: 1px solid #f4f4f5;
}

summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 48px;
  list-style: none;
  color: #27272a;
  font-size: 24px;
  font-weight: 500;
  line-height: 48px;
  cursor: pointer;
  transition: color 220ms var(--ease-out-quart), transform 220ms var(--ease-out-quart);
}

summary:hover {
  color: #27272a;
  background: none;
  -webkit-text-fill-color: currentColor;
  transform: none;
}

summary::-webkit-details-marker {
  display: none;
}

summary img {
  width: 36px;
  height: 36px;
  transition: transform 260ms var(--ease-out-quart), opacity 260ms var(--ease-out-quart);
}

summary:hover img {
  opacity: 0.72;
  transform: rotate(-6deg);
}

details p {
  display: none;
  width: var(--faq-col-width);
  margin: 12px 0 16px;
  color: var(--muted);
  font-size: 16px;
  line-height: 24px;
}

details[open] p {
  display: block;
}

details[open] summary img {
  transform: rotate(180deg);
}

.footer {
  position: absolute;
  left: var(--footer-left);
  top: var(--footer-top);
  width: var(--footer-width);
  height: var(--footer-height);
  overflow: visible;
  background: #fff;
}

.footer-cta,
.footer-copy,
.footer-actions,
.footer-art,
.footer-wordmark,
.footer-bg {
  position: absolute;
}

.footer-cta {
  left: 24px;
  top: 24px;
  z-index: 4;
  width: calc(var(--content) - 48px);
  height: 96px;
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.1);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
}

.footer-copy {
  left: 24px;
  top: 24px;
  width: 684px;
}

.footer-copy h2 {
  display: none;
  margin: 0;
  color: #27272a;
  font-size: 36px;
  font-weight: 600;
  line-height: 48px;
  white-space: nowrap;
}

.footer-copy h2 span {
  color: transparent;
  background: url("./assets/figma/title-gradient.webp") 0% 50% / 168% 100% no-repeat;
  -webkit-background-clip: text;
  background-clip: text;
  animation: title-gradient-flow 6.8s var(--ease-out-quart) infinite alternate;
  will-change: background-position;
}

.footer-mobile-break {
  display: none;
}

.footer-desktop-comma {
  color: inherit;
  background: none;
  -webkit-background-clip: border-box;
  background-clip: border-box;
  animation: none;
}

.footer-copy p {
  width: 684px;
  margin: 0;
  color: #fff;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
}

.footer-actions {
  right: 24px;
  left: auto;
  top: 24px;
  z-index: 20;
  display: flex;
  gap: 16px;
  align-items: center;
  width: 336px;
  height: 48px;
}

.footer-download-wrap {
  z-index: 30;
}

.footer-download {
  color: #27272a;
  background: #fff;
}

.footer-download img {
  content: url("./assets/figma/footer-chrome-dark.svg");
}

.footer-download:hover,
.footer-download:focus-visible {
  color: rgba(39, 39, 42, 0.72);
  background: #fff;
}

.footer-download:hover img,
.footer-download:focus-visible img {
  opacity: 0.72;
  filter: none;
}

.footer-download-menu {
  left: 0;
  top: 60px;
}

.footer-top-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 48px;
  border: 1px solid rgba(250, 250, 250, 0.6);
  border-radius: 8px;
  color: #fff;
  background: transparent;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  transition:
    color 220ms var(--ease-out-quart),
    border-color 220ms var(--ease-out-quart),
    background-color 220ms var(--ease-out-quart);
}

.footer-top-button:hover,
.footer-top-button:focus-visible {
  color: rgba(255, 255, 255, 0.66);
  border-color: rgba(250, 250, 250, 0.6);
  background: transparent;
  outline: none;
}

.footer-art {
  left: 0;
  top: 0;
  z-index: 1;
  width: var(--footer-art-width);
  height: 480px;
  overflow: hidden;
  border-radius: 16px;
}

.footer-art img,
.footer-art video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center;
}

.footer-art video {
  display: block;
}

.footer.inspiration-footer {
  top: var(--inspiration-footer-top, 2910px);
}

.footer-wordmark {
  display: none;
  left: var(--footer-wordmark-left);
  top: var(--footer-wordmark-top);
  z-index: 2;
  width: var(--footer-wordmark-width);
  height: var(--footer-wordmark-height);
  pointer-events: none;
}

.footer-bg {
  display: none;
}

.footer-bottom {
  position: absolute;
  display: none;
}

.footer-desc,
.designer,
.footer-legal,
.footer nav {
  position: absolute;
}

.footer-desc {
  display: none;
}

.footer-desc-desktop {
  display: inline;
}

.footer-desc-mobile {
  display: none;
}

.designer,
.footer-legal {
  color: #a1a1aa;
  font-size: 14px;
  line-height: 16px;
}

.designer {
  left: 0;
  top: 504px;
  display: flex;
  align-items: center;
  height: 32px;
}

.designer img {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 36px;
  object-fit: cover;
}

.designer a {
  color: #52525b;
  font-weight: 500;
  line-height: 16px;
  white-space: nowrap;
}

.designer a span {
  border-bottom: 1px solid transparent;
  transition: border-color 220ms var(--ease-out-quart);
}

.designer a:hover span {
  border-color: currentColor;
}

.footer-legal {
  left: var(--footer-legal-left);
  top: 512px;
  display: flex;
  gap: 16px;
  align-items: center;
  font-weight: 400;
  white-space: nowrap;
}

.footer-legal a {
  color: inherit;
  border-bottom: 1px solid transparent;
  transition: color 220ms var(--ease-out-quart), border-color 220ms var(--ease-out-quart);
}

.footer-legal a:hover,
.footer-legal a:focus-visible {
  color: #52525b;
  border-color: currentColor;
  outline: none;
}

.footer nav {
  left: var(--footer-social-left);
  top: 508px;
  display: flex;
  gap: 24px;
  width: 168px;
  height: 24px;
}

.footer nav a {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
}

.footer nav img {
  width: 24px;
  height: 24px;
  opacity: 1;
  filter: none;
  transition:
    filter 220ms var(--ease-out-quart),
    opacity 220ms var(--ease-out-quart);
}

.footer nav a:hover,
.footer nav a:focus-visible {
  outline: none;
}

.footer nav a:hover img,
.footer nav a:focus-visible img {
  opacity: 1;
  filter: brightness(0) saturate(100%) invert(13%) sepia(6%) saturate(526%) hue-rotate(202deg) brightness(95%) contrast(90%);
}

.motion-ready .reveal-item {
  opacity: 0;
  transform: translate3d(0, 34px, 0);
  transition: opacity 680ms var(--ease-out-quint), transform 680ms var(--ease-out-quint);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.motion-ready .reveal-item.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.motion-ready .prompt-card.reveal-item {
  --card-reveal-y: 0px;
  transform: perspective(1000px) translate3d(0, calc(var(--card-reveal-y) + var(--tilt-lift)), 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) scale(var(--tilt-scale));
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 680ms var(--ease-out-quint),
    height 620ms var(--ease-out-expo),
    border-color 260ms var(--ease-out-quart),
    background-color 260ms var(--ease-out-quart),
    box-shadow 320ms var(--ease-out-quart);
}

.motion-ready .prompt-card.reveal-item.is-visible {
  --card-reveal-y: 0px;
  transform: perspective(1000px) translate3d(0, calc(var(--card-reveal-y) + var(--tilt-lift)), 0) rotateX(var(--tilt-x)) rotateY(var(--tilt-y)) scale(var(--tilt-scale));
  transition-delay: 0ms;
}

.motion-ready .prompt-card.reveal-item.is-visible.is-tilting {
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 90ms var(--ease-out-quart),
    height 620ms var(--ease-out-expo),
    border-color 220ms var(--ease-out-quart),
    background-color 220ms var(--ease-out-quart),
    box-shadow 220ms var(--ease-out-quart),
    filter 220ms var(--ease-out-quart);
}

.motion-ready .skill-card.reveal-item {
  --skill-card-reveal-y: 34px;
  transform: perspective(900px) translate3d(0, calc(var(--skill-card-reveal-y) + var(--skill-tilt-lift)), 0) rotateX(var(--skill-tilt-x)) rotateY(var(--skill-tilt-y)) scale(var(--skill-tilt-scale));
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 680ms var(--ease-out-quint),
    border-color 220ms var(--ease-out-quart),
    box-shadow 260ms var(--ease-out-quart);
}

.motion-ready .skill-card.reveal-item.is-visible {
  --skill-card-reveal-y: 0px;
  transform: perspective(900px) translate3d(0, calc(var(--skill-card-reveal-y) + var(--skill-tilt-lift)), 0) rotateX(var(--skill-tilt-x)) rotateY(var(--skill-tilt-y)) scale(var(--skill-tilt-scale));
}

.motion-ready .skill-card.reveal-item.is-visible.is-tilting {
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 90ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart),
    box-shadow 180ms var(--ease-out-quart);
}

.motion-ready .case-card.reveal-item {
  --case-card-reveal-y: 34px;
  transform: perspective(1000px) translate3d(0, calc(var(--case-card-reveal-y) + var(--case-tilt-lift)), 0) rotateX(var(--case-tilt-x)) rotateY(var(--case-tilt-y)) scale(var(--case-tilt-scale));
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 680ms var(--ease-out-quint),
    border-color 220ms var(--ease-out-quart),
    box-shadow 260ms var(--ease-out-quart);
}

.motion-ready .case-card.reveal-item.is-visible {
  --case-card-reveal-y: 0px;
  transform: perspective(1000px) translate3d(0, calc(var(--case-card-reveal-y) + var(--case-tilt-lift)), 0) rotateX(var(--case-tilt-x)) rotateY(var(--case-tilt-y)) scale(var(--case-tilt-scale));
}

.motion-ready .case-card.reveal-item.is-visible.is-tilting {
  transition:
    opacity 680ms var(--ease-out-quint),
    transform 90ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart),
    box-shadow 180ms var(--ease-out-quart);
}

.motion-ready .feature-card.reveal-item {
  transform: translate3d(0, 34px, 0) scale(0.985);
}

.motion-ready .feature-card.reveal-item.is-visible {
  transform: translate3d(0, 0, 0) scale(1);
}

.motion-ready .feature-card.reveal-item.is-visible:hover {
  transform: translate3d(0, -6px, 0) scale(1);
}

.motion-ready .share-image.reveal-item {
  transform: translate3d(0, 34px, 0) scale(0.985);
}

.motion-ready .share-image.reveal-item.is-visible {
  transform: translate3d(0, 0, 0) scale(1);
}

.motion-ready .share-image.reveal-item.is-visible:hover {
  transform: translate3d(0, -8px, 0) scale(1);
}

@media (min-width: 768px) and (max-width: 1439px) {
  :root {
    --content: 976px;
    --side: 24px;
    --wide-offset: 0px;
    --share-left: -508px;
    --footer-top: 5248px;
    --design-height: 5952px;
    --tablet-scale: 1;
    --tablet-stage-left: 0px;
    --tablet-visual-height: 5952px;
    --tablet-hero-bg-left: 0px;
    --tablet-hero-bg-width: 1024px;
    --section-title-size: 40px;
    --section-title-line: 60px;
    --feature-head-left: 239px;
    --feature-head-top: 860px;
    --feature-head-width: 546px;
    --feature-head-height: 108px;
    --feature-kicker-left: 201px;
    --feature-accent-left: 546px;
    --feature-accent-top: 18px;
    --layout-head-left: 224px;
    --layout-head-top: 2632px;
    --layout-head-width: 576px;
    --layout-head-height: 108px;
    --layout-accent-left: 528px;
    --layout-accent-top: 18px;
    --share-head-left: 296px;
    --share-head-top: 3666px;
    --share-head-width: 432px;
    --share-head-height: 108px;
    --share-accent-left: 402px;
    --share-accent-top: 28px;
    /* FAQ 标题居中（1024 设计稿）：x=332, w=408, kicker x=108, accent x=360 y=24 */
    --faq-head-left: 332px;
    --faq-head-top: 4558px;
    --faq-head-width: 408px;
    --faq-head-height: 108px;
    --faq-title-top: 48px;
    --faq-kicker-left: 108px;
    --faq-accent-left: 360px;
    --faq-accent-top: 24px;
    --features-left: 24px;
    --features-top: 1004px;
    --features-width: 976px;
    --features-height: 1488px;
    --feature-card-width: 976px;
    --feature-card-height: 360px;
    --feature-card-2-left: 0px;
    --feature-card-2-top: 376px;
    --feature-card-3-left: 0px;
    --feature-card-3-top: 752px;
    --feature-card-4-left: 0px;
    --feature-card-4-top: 1128px;
    --feature-pattern-left: 466px;
    --feature-shot-left: 634px;
    --layout-toggle-left: 378px;
    --layout-toggle-top: 2764px;
    --layout-demo-left: 24px;
    --layout-demo-top: 2848px;
    --layout-demo-width: 976px;
    --layout-column-1-left: -148px;
    --layout-column-2-left: 176px;
    --layout-column-3-left: 500px;
    --layout-column-4-left: 824px;
    --layout-panel-left: 188px;
    /* 1440 以下：面板右距容器边由 0 改为 24px（676 - 24 = 652），与窗口模式视觉一致 */
    --layout-sidebar-panel-left: 652px;
    --sidebar-column-1-left: -148px;
    --sidebar-column-2-left: 176px;
    --sidebar-column-3-left: 500px;
    --share-row-left: -508px;
    --share-row-top: 3810px;
    --share-row-height: 608px;
    --share-card-width: 320px;
    --share-card-height: 608px;
    --share-marquee-distance: -3096px;
    --faq-left: 24px;
    --faq-top: 4702px;
    --faq-width: 976px;
    --faq-col-width: 476px;
    --footer-left: 24px;
    --footer-width: 976px;
    --footer-art-width: 976px;
    --footer-wordmark-left: 24px;
    --footer-wordmark-top: 470px;
    --footer-wordmark-width: 928px;
    --footer-wordmark-height: 154px;
    --footer-legal-left: 375px;
    --footer-social-left: 808px;
    --policy-side: max(24px, calc((100vw - 976px) / 2));
    --policy-content: min(976px, calc(100vw - 48px));
    --policy-inner: calc(var(--policy-content) - 48px);
  }

  body,
  .global-notice {
    min-width: 0;
  }

  body::before {
    display: none;
  }

  .global-notice {
    overflow: hidden;
  }

  .design {
    width: 100vw;
    min-width: 0;
    height: var(--tablet-visual-height);
    overflow: hidden;
  }

  .design-stage {
    left: var(--tablet-stage-left);
    top: 0;
    width: 1024px;
    height: var(--design-height);
    margin-left: 0;
    transform: scale(var(--tablet-scale));
    transform-origin: top left;
  }

  .inspiration-page {
    width: 100vw;
    min-width: 0;
    height: auto;
    min-height: 0;
    padding: 24px 24px 48px;
    overflow: hidden;
  }

  .inspiration-header-bg {
    top: 0;
    min-width: 0;
    width: 100vw;
    height: 340px;
  }

  .inspiration-header {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    gap: 42px;
  }

  .inspiration-nav {
    position: relative;
    left: auto;
    top: auto;
  }

  .inspiration-download-wrap {
    left: auto;
    right: 0;
    top: 0;
  }

  .inspiration-header .inspiration-download-wrap {
    left: auto;
    right: 0;
    top: 0;
  }

  .inspiration-hero {
    position: relative;
    left: auto;
    top: auto;
    margin: 96px auto 0;
  }

  .inspiration-filters {
    position: relative;
    left: auto;
    top: auto;
    flex-wrap: wrap;
    justify-content: center;
    width: min(976px, calc(100vw - 48px));
    height: auto;
    margin: 48px auto 0;
    padding-right: 0;
    transform: none;
  }

  .inspiration-header .inspiration-search {
    left: auto;
    right: 142px;
  }

  .inspiration-grid {
    position: relative;
    inset: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 448px));
    gap: 24px;
    justify-content: center;
    /* 横图卡不被同行方图卡拉伸：每张卡按内容自然高度（Pinterest 式参差） */
    align-items: start;
    width: min(976px, calc(100vw - 48px));
    height: auto;
    margin: 24px auto 0;
    overflow: visible;
    transform: none;
    transition: none;
  }

  .prompt-card {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    padding-bottom: 0;
  }

  .prompt-card-tilt {
    position: static;
    transform: none !important;
    transition: none;
  }

  .prompt-card.is-open {
    padding-bottom: 72px;
  }

  .prompt-card-image {
    height: auto;
    aspect-ratio: var(--card-ratio, 16 / 9);
  }

  .prompt-card h2 {
    position: static;
    width: auto;
    margin: 16px 16px 0;
    text-align: left;
  }

  .prompt-card p {
    position: static;
    width: calc(100% - 32px);
    margin: 8px 16px 0;
  }

  .prompt-card:not(.is-open) h2,
  .prompt-card:not(.is-open) p,
  .prompt-card:not(.is-open) .prompt-actions {
    display: none;
  }

  .prompt-card.is-open h2 {
    display: block;
  }

  .prompt-card.is-open p {
    display: -webkit-box;
  }

  .prompt-card.is-open .prompt-actions {
    display: flex;
  }

  .prompt-card:nth-child(2n + 3) .prompt-card-image {
    aspect-ratio: var(--card-ratio, 2 / 3);
  }

  .prompt-actions {
    width: calc(100% - 32px);
  }

  .prompt-actions button {
    flex: 1 1 0;
    width: auto;
  }

  .inspiration-fade {
    display: none;
  }

  .inspiration-more {
    position: relative;
    left: auto;
    top: auto;
    display: block;
    margin: 48px auto 0;
  }

  .inspiration-page.is-expanded .inspiration-more,
  .inspiration-page:not(.has-more) .inspiration-more {
    display: none;
  }

  .inspiration-footer {
    position: relative;
    left: auto;
    top: auto;
    width: min(976px, calc(100vw - 48px));
    margin: 160px auto 0;
  }

  .inspiration-footer .footer-cta {
    width: calc(100% - 48px);
  }

  .inspiration-footer .footer-art {
    width: 100%;
  }

  .inspiration-footer .footer-wordmark {
    width: calc(100% - 48px);
    height: auto;
  }

  .inspiration-footer .footer-legal {
    left: calc((100% - 226px) / 2);
  }

  .inspiration-footer nav {
    left: calc(100% - 168px);
  }

  .policy-page {
    width: 100vw;
    min-width: 0;
    height: 3233px;
  }

  .policy-header {
    left: var(--policy-side);
    width: var(--policy-content);
  }

  .policy-card {
    left: var(--policy-side);
    width: var(--policy-content);
    display: none;
    margin-left: 0;
  }

  .policy-sidebar {
    display: none;
  }

  .policy-title-row,
  .policy-date,
  .policy-divider,
  .policy-intro,
  .policy-section,
  .policy-section-narrow {
    left: calc(var(--policy-side) + 24px);
    width: var(--policy-inner);
    margin-left: 0;
  }

  .policy-divider {
    width: var(--policy-inner);
  }

  .policy-page .footer {
    left: var(--policy-side);
    top: 2529px;
    width: var(--policy-content);
  }

  .policy-page .footer-cta {
    width: calc(var(--policy-content) - 48px);
  }

  .policy-page .footer-art {
    width: var(--policy-content);
  }

  .policy-page .footer-wordmark {
    width: calc(var(--policy-content) - 48px);
    height: auto;
  }

  .policy-page .footer-legal {
    left: calc((var(--policy-content) - 226px) / 2);
  }

  .policy-page .footer nav {
    left: calc(var(--policy-content) - 168px);
  }

  .hero {
    width: 1024px;
    height: 820px;
  }

  .hero-bg {
    left: var(--tablet-hero-bg-left);
    width: var(--tablet-hero-bg-width);
    height: 720px;
    max-width: none;
  }

  .hero-header {
    left: 24px;
    top: 24px;
    gap: 42px;
    height: 32px;
  }

  .logo,
  .logo-svg {
    width: 155px;
    height: 32px;
  }

  .hero-nav {
    gap: 24px;
    font-size: 16px;
    line-height: 24px;
  }

  .hero-nav a::after {
    top: 24px;
  }

  .mobile-menu-toggle,
  .mobile-menu {
    display: none;
  }

  .accent-hero {
    display: block;
    left: 468px;
    top: 155px;
    width: 56px;
    height: 56px;
  }

  .hero-title {
    left: 24px;
    top: 196px;
    width: 444px;
    height: 128px;
    font-size: 48px;
    line-height: 60px;
  }

  .title-row-1 {
    gap: 12px;
  }

  .hero-desc {
    left: 24px;
    top: 340px;
    width: 444px;
    height: 72px;
    font-size: 16px;
    line-height: 24px;
  }

  .hero-actions {
    left: 24px;
    top: 436px;
    width: 356px;
    height: 49px;
    gap: 16px;
  }

  .download-wrap {
    width: 180px;
    height: 49px;
  }

  .download {
    width: 180px;
    height: 49px;
    gap: 8px;
  }

  .learn {
    width: 160px;
    height: 49px;
  }

  .download,
  .learn {
    font-size: 16px;
    line-height: 24px;
  }

  .hero-board {
    left: 539px;
    top: 24px;
    width: 792px;
    height: 672px;
    border-radius: 24px;
  }

  .board-shadow,
  .board-white {
    width: 792px;
    height: 672px;
    border-radius: 24px;
  }

  .hero-col {
    width: 260px;
  }

  .hero-col-left {
    left: 16px;
    top: -24px;
  }

  .hero-col-right {
    left: 292px;
    top: -24px;
  }

  .hero-track {
    gap: 16px;
  }

  .hero-track img {
    width: 260px;
    border-radius: 12px;
  }

  .scroll-text {
    left: 24px;
    top: 672px;
  }

  .scroll-arrow {
    left: 88px;
    top: 668px;
    width: 107.94px;
    height: 96.96px;
  }

  .kicker {
    gap: 12px;
    height: 36px;
    font-size: 24px;
    line-height: 36px;
  }

  .kicker img {
    width: 36px;
    height: 36px;
  }

  .footer-cta {
    left: 24px;
    top: 24px;
    width: 928px;
    height: 96px;
  }

  .footer-copy {
    left: 24px;
    top: 24px;
    width: 500px;
  }

  .footer-copy p {
    width: 500px;
    font-size: 14px;
    line-height: 24px;
  }

  .footer-actions {
    right: 24px;
    top: 24px;
    width: 336px;
    height: 48px;
  }

  .designer {
    left: 0;
    top: 504px;
    height: 32px;
  }

  .designer img {
    width: 32px;
    height: 32px;
  }

  .footer-legal {
    top: 512px;
  }

  .footer nav {
    top: 508px;
  }

  .footer-legal {
    font-size: 14px;
    line-height: 16px;
  }

  .footer nav a,
  .footer nav img {
    width: 24px;
    height: 24px;
  }

  @keyframes hero-scroll-left {
    from { transform: translate3d(0, 0, 0); }
    to { transform: translate3d(0, -1175px, 0); }
  }

  @keyframes hero-scroll-right {
    from { transform: translate3d(0, -1588px, 0); }
    to { transform: translate3d(0, 0, 0); }
  }

}

@media (max-width: 767px) {
  :root {
    --mobile-page: 100vw;
    --mobile-side: 16px;
    --mobile-stage-left: 0px;
    --mobile-hero-card-width: calc((var(--mobile-page) - 42px) / 2);
    --mobile-card-width: calc(var(--mobile-page) - 32px);
    --content: calc(var(--mobile-page) - 32px);
    --side: var(--mobile-side);
    --wide-offset: 0px;
    --share-left: -379px;
    --footer-top: 4603px;
    --design-height: 5196px;
  }

  body::before {
    display: none;
  }

  .global-notice {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    height: 34px;
    overflow: hidden;
    padding: 8px 60px 0 16px;
    border-bottom-color: rgba(228, 228, 231, 0.8);
  }

  .global-notice::after {
    position: absolute;
    right: 0;
    top: 0;
    z-index: 2;
    display: block;
    width: 120px;
    height: 34px;
    content: "";
    pointer-events: none;
    background: linear-gradient(90deg, rgba(250, 250, 250, 0) 0%, #fafafa 62%);
  }

  .global-notice-track {
    gap: 0;
    animation: notice-marquee 34s linear infinite;
    will-change: transform;
  }

  .global-notice-copy,
  .global-notice-copy[aria-hidden="true"] {
    display: flex;
    flex: 0 0 auto;
    z-index: 0;
    gap: 4px;
    padding-right: 36px;
    color: #27272a;
    font-size: 11px;
    line-height: 18px;
    white-space: nowrap;
  }

  .global-notice-copy a {
    font-size: 11px;
    line-height: 18px;
  }

  .global-notice-close {
    right: 5px;
    left: auto;
    top: 5px;
    z-index: 4;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .global-search-modal {
    padding: 48px 16px 0;
  }

  .global-search-panel {
    width: min(100%, 370px);
    max-height: calc(100vh - 72px);
    border-radius: 14px;
  }

  .global-search-results {
    max-height: calc(100vh - 174px);
  }

  .global-search-footer {
    min-height: 46px;
    gap: 8px;
    padding: 8px;
    font-size: 12px;
    line-height: 16px;
  }

  .global-search-count {
    height: 28px;
    padding: 0 8px;
  }

  .global-search-help {
    gap: 6px;
  }

  .global-search-action {
    gap: 4px;
    height: 28px;
    padding: 0 5px;
  }

  .global-search-action-label {
    font-size: 12px;
    line-height: 16px;
  }

  .global-search-key {
    min-width: 22px;
    height: 20px;
    padding: 0 5px;
    border-radius: 5px;
    font-size: 12px;
    line-height: 16px;
  }

  .global-search-key-wide {
    min-width: 34px;
  }

  .site-search-shortcut {
    display: none;
  }

  .global-search-result {
    grid-template-columns: 44px minmax(0, 1fr);
    min-height: 72px;
  }

  .global-search-thumb {
    width: 44px;
    height: 44px;
  }

  .global-search-result-type {
    display: none;
  }

  body {
    min-width: 0;
    overflow-x: hidden;
    padding-top: 34px;
  }

  body.notice-hidden {
    padding-top: 0;
  }

body.mobile-menu-open {
  overflow: hidden;
}

body.prompt-modal-open {
  overflow: hidden;
}

  .design {
    width: 100vw;
    min-width: 0;
    height: var(--design-height);
    margin: 0;
    overflow: hidden;
  }

  .design-stage {
    left: var(--mobile-stage-left);
    top: 0;
    width: var(--mobile-page);
    height: var(--design-height);
    margin-left: 0;
    transform: none;
  }

  .policy-page {
    width: 100vw;
    min-width: 0;
    height: 3135px;
    overflow: hidden;
  }

  .inspiration-page {
    width: 100vw;
    min-width: 0;
    height: auto;
    padding: 16px 16px 24px;
    overflow: hidden;
  }

  .inspiration-header-bg {
    top: 0;
    min-width: 0;
    width: 100vw;
    height: 300px;
  }

  .inspiration-header {
    position: relative;
    left: auto;
    top: auto;
    z-index: 20;
    width: calc(var(--mobile-page) - 32px);
    height: 32px;
    margin: 0 auto;
    gap: 0;
    justify-content: space-between;
  }

  .inspiration-header .logo,
  .inspiration-header .logo-svg {
    width: 155px;
    height: 32px;
  }

  .inspiration-nav,
  .inspiration-download-wrap,
  .inspiration-search {
    display: none;
  }

  .inspiration-page .mobile-menu-toggle {
    right: 0;
    top: 0;
    z-index: 2;
    display: block;
  }

  .inspiration-hero {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    margin: 72px auto 0;
    text-align: center;
  }

  .inspiration-title-wrap {
    width: auto;
    max-width: 100%;
  }

  .inspiration-hero h1 {
    font-size: 32px;
    line-height: 48px;
    white-space: normal;
  }

  .inspiration-hero h1 br {
    display: block;
  }

  .inspiration-hero p {
    width: 100%;
    margin-top: 12px;
    font-size: 14px;
    line-height: 24px;
  }

  .inspiration-title-accent {
    left: calc(100% + 8px);
    top: -6px;
    width: 36px;
    height: 36px;
  }

  .inspiration-filters {
    position: relative;
    left: auto;
    top: auto;
    display: flex;
    justify-content: flex-start;
    width: var(--mobile-card-width);
    height: auto;
    margin: 40px auto 0;
    padding-bottom: 0;
    gap: 8px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    transform: none;
  }

  .inspiration-filters::-webkit-scrollbar {
    display: none;
  }

  .inspiration-filters button {
    flex: 0 0 auto;
    height: 34px;
    padding: 4px 14px;
    font-size: 13px;
  }

  .inspiration-grid {
    position: relative;
    inset: auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    width: var(--mobile-card-width);
    height: auto;
    margin: 24px auto 0;
    overflow: visible;
    transition: none;
  }

  .prompt-card {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    height: auto;
    min-height: 0;
    padding-bottom: 0;
    border-radius: 14px;
  }

  .prompt-card-tilt {
    position: static;
    transform: none !important;
    transition: none;
  }

  .prompt-card.is-open {
    padding-bottom: 72px;
  }

  .prompt-card-image {
    height: auto;
    aspect-ratio: var(--card-ratio, 16 / 9);
  }

  .prompt-card h2 {
    position: static;
    width: auto;
    margin: 14px 16px 0;
    text-align: left;
  }

  .prompt-card p {
    position: static;
    width: calc(100% - 32px);
    margin: 8px 16px 0;
  }

  .prompt-card:not(.is-open) h2,
  .prompt-card:not(.is-open) p,
  .prompt-card:not(.is-open) .prompt-actions {
    display: none;
  }

  .prompt-card.is-open h2 {
    display: block;
  }

  .prompt-card.is-open p {
    display: -webkit-box;
  }

  .prompt-card.is-open .prompt-actions {
    display: flex;
  }

  .prompt-card:nth-child(3n) .prompt-card-image,
  .prompt-card:nth-child(4n) .prompt-card-image {
    aspect-ratio: var(--card-ratio, 2 / 3);
  }

  .prompt-card h2 {
    font-size: 20px;
    line-height: 30px;
  }

  .prompt-card p {
    font-size: 12px;
    line-height: 20px;
  }

  .prompt-actions {
    width: calc(100% - 32px);
    gap: 12px;
  }

  .prompt-actions button {
    flex: 1 1 0;
    width: auto;
    font-size: 13px;
  }

  .prompt-actions img {
    width: 20px;
    height: 20px;
  }

  .inspiration-fade {
    display: none;
  }

  .inspiration-more {
    position: relative;
    left: auto;
    top: auto;
    display: block;
    width: 160px;
    height: 44px;
    margin: 40px auto 0;
    font-size: 14px;
  }

  .inspiration-page.is-expanded .inspiration-more,
  .inspiration-page:not(.has-more) .inspiration-more {
    display: none;
  }

  .inspiration-footer {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    margin: 96px auto 0;
  }

  .prompt-modal {
    display: grid;
    align-items: start;
    justify-items: center;
    padding: 60px 0 24px;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .prompt-modal-backdrop {
    position: fixed;
    background: rgba(0, 0, 0, 0.3);
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }

  .prompt-modal-panel {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    width: min(402px, 100vw);
    height: auto;
    max-width: none;
    max-height: none;
    padding: 16px 16px 26px;
    overflow: visible;
    border-radius: 14px 14px 0 0;
    box-shadow: 0 24px 56px rgba(39, 39, 42, 0.16);
  }

  .prompt-modal-close {
    right: 16px;
    top: 16px;
    width: 36px;
    height: 36px;
    border-color: #f4f4f5;
    border-radius: 8px;
    background: #fff;
  }

  .prompt-modal-image {
    order: 2;
    position: relative;
    width: 100%;
    max-width: none;
    height: auto;
    max-height: none;
    border-radius: 8px;
    object-fit: contain;
    box-shadow: none;
  }

  .prompt-modal-content {
    display: contents;
  }

  .prompt-modal-content h2 {
    order: 1;
    width: calc(100% - 52px);
    min-height: 36px;
    margin: 0;
    color: #27272a;
    font-size: 24px;
    font-weight: 600;
    line-height: 36px;
    white-space: nowrap;
  }

  .prompt-modal-info {
    order: 3;
    width: 100%;
    height: 400px;
    min-height: 0;
    margin-top: 0;
    padding: 12px 12px 16px;
    border-radius: 8px;
    background: #fafafa;
    box-shadow: inset 0 0 0 1px #f4f4f5;
  }

  .prompt-modal-info::after {
    display: none;
  }

  .prompt-modal-actions {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 16px;
    width: auto;
    height: 40px;
    margin-top: 0;
    gap: 10px;
  }

  .prompt-modal-text {
    max-height: calc(100% - 64px);
    padding-right: 0;
    font-size: 15px;
    font-weight: 400;
    line-height: 24px;
  }

  .prompt-modal-save,
  .prompt-modal-copy {
    flex: 0 0 calc((100% - 10px) / 2);
    width: calc((100% - 10px) / 2);
    min-width: 0;
    height: 40px;
    font-size: 14px;
    font-weight: 500;
  }

  .prompt-modal-save img,
  .prompt-modal-copy img {
    width: 24px;
    height: 24px;
  }

  .prompt-modal-panel.is-portrait,
  .prompt-modal-panel.is-landscape,
  .prompt-modal-panel.is-ultrawide {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: none;
    gap: 16px;
    width: min(402px, 100vw);
    max-width: none;
    height: auto;
    max-height: none;
    padding: 16px 16px 26px;
  }

  .prompt-modal-panel.is-portrait .prompt-modal-image,
  .prompt-modal-panel.is-portrait .prompt-modal-content,
  .prompt-modal-panel.is-landscape .prompt-modal-image,
  .prompt-modal-panel.is-ultrawide .prompt-modal-image,
  .prompt-modal-panel.is-landscape .prompt-modal-content,
  .prompt-modal-panel.is-ultrawide .prompt-modal-content {
    display: block;
    position: relative;
    width: 100%;
    max-width: none;
    height: auto;
    max-height: none;
  }

  .prompt-modal-panel.is-portrait .prompt-modal-content,
  .prompt-modal-panel.is-landscape .prompt-modal-content,
  .prompt-modal-panel.is-ultrawide .prompt-modal-content {
    display: contents;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-info,
  .prompt-modal-panel.is-ultrawide .prompt-modal-info {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    height: 400px;
    margin-top: 0;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-content h2,
  .prompt-modal-panel.is-ultrawide .prompt-modal-content h2 {
    width: calc(100% - 52px);
    font-size: 24px;
    line-height: 36px;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-text,
  .prompt-modal-panel.is-ultrawide .prompt-modal-text {
    max-height: calc(100% - 64px);
  }

  .prompt-modal-panel.is-landscape .prompt-modal-actions,
  .prompt-modal-panel.is-ultrawide .prompt-modal-actions {
    width: auto;
  }

  .prompt-modal-panel.is-landscape .prompt-modal-save,
  .prompt-modal-panel.is-landscape .prompt-modal-copy,
  .prompt-modal-panel.is-ultrawide .prompt-modal-save,
  .prompt-modal-panel.is-ultrawide .prompt-modal-copy {
    flex: 0 0 calc((100% - 10px) / 2);
    width: calc((100% - 10px) / 2);
  }

  .policy-header {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 16px;
    z-index: 20;
    width: calc(var(--mobile-page) - 32px);
    height: 32px;
    gap: 0;
    justify-content: space-between;
  }

  .policy-header .logo,
  .policy-header .logo-svg {
    width: 155px;
    height: 32px;
  }

  .policy-page .mobile-menu-toggle {
    right: 0;
    top: 0;
    z-index: 2;
    display: block;
  }

  .policy-card {
    left: var(--mobile-stage-left);
    top: 84px;
    display: block;
    width: var(--mobile-page);
    height: 2338px;
    margin-left: 0;
    border-radius: 16px;
  }

  .policy-sidebar {
    display: none;
  }

  .policy-title-row {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 108px;
    display: block;
    width: calc(var(--mobile-page) - 32px);
    height: 72px;
    margin-left: 0;
  }

  .policy-page h1 {
    width: calc(var(--mobile-page) - 32px);
    font-size: 24px;
    line-height: 36px;
    white-space: normal;
  }

  .policy-mobile-break {
    display: block;
  }

  .policy-title-accent {
    position: absolute;
    left: calc(100% - 36px);
    top: 0;
    width: 36px;
    height: 36px;
  }

  .policy-date {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 188px;
    margin-left: 0;
    font-size: 12px;
    line-height: 18px;
  }

  .policy-divider {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 222px;
    width: calc(var(--mobile-page) - 32px);
    margin-left: 0;
  }

  .policy-intro {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 238px;
    width: calc(var(--mobile-page) - 32px);
    margin-left: 0;
    font-size: 12px;
    line-height: 24px;
  }

  .policy-section,
  .policy-section-narrow {
    left: calc(var(--mobile-stage-left) + 16px);
    width: calc(var(--mobile-page) - 32px);
    margin-left: 0;
    font-size: 12px;
    line-height: 24px;
  }

  .policy-section h2 {
    margin-bottom: 12px;
    font-size: 16px;
    line-height: 24px;
  }

  .policy-section p,
  .policy-section li,
  .policy-section-4 p,
  .policy-section-4 li {
    font-size: 12px;
    line-height: 24px;
  }

  .policy-section ol {
    margin: 24px 0 0;
  }

  .policy-section-4 ol {
    margin: 24px 0 12px;
  }

  .policy-section-1 { top: 310px; }
  .policy-section-2 { top: 538px; }
  .policy-section-3 { top: 766px; }
  .policy-section-4 { top: 946px; }
  .policy-section-5 { top: 1282px; }
  .policy-section-6 { top: 1486px; }
  .policy-section-7 { top: 1642px; }
  .policy-section-8 { top: 1798px; }
  .policy-section-9 { top: 2074px; }
  .policy-section-10 { top: 2158px; }
  .policy-section-11 { top: 2266px; }

  .policy-page .footer {
    left: calc(var(--mobile-stage-left) + 16px);
    top: 2542px;
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
  }

  .policy-page .footer nav {
    top: 506px;
  }

  .policy-page .footer nav a,
  .policy-page .footer nav img {
    width: 20px;
    height: 20px;
  }

  .hero {
    width: var(--mobile-page);
    height: 820px;
  }

  .hero-bg {
    width: var(--mobile-page);
    height: 820px;
    content: url("./assets/figma/hero-bg-mobile.webp");
    object-fit: cover;
  }

  .hero-header {
    left: 16px;
    top: 16px;
    width: calc(var(--mobile-page) - 32px);
    height: 32px;
    gap: 0;
    justify-content: space-between;
  }

  .logo,
  .logo-svg {
    width: 155px;
    height: 32px;
  }

  .hero-nav {
    display: none;
  }

  .mobile-menu-toggle {
    position: absolute;
    right: 0;
    top: 0;
    display: block;
    width: 32px;
    height: 32px;
    overflow: hidden;
    padding: 0;
    border: 1px solid #e4e4e7;
    border-radius: 8px;
    background: #fff;
    color: transparent;
    font-size: 0;
    cursor: pointer;
    transform: translate3d(0, 0, 0);
    transition:
      transform 180ms var(--ease-out-quart),
      border-color 180ms var(--ease-out-quart),
      background-color 180ms var(--ease-out-quart);
  }

  .mobile-menu-toggle::before {
    position: absolute;
    left: 50%;
    top: 50%;
    width: 24px;
    height: 24px;
    background: #27272a;
    content: "";
    transform: translate3d(-50%, -50%, 0);
    transition: background-color 180ms var(--ease-out-quart);
    -webkit-mask: url("./Menu.svg") center / 24px 24px no-repeat;
    mask: url("./Menu.svg") center / 24px 24px no-repeat;
  }

  .mobile-menu-toggle:hover,
  .mobile-menu-toggle:focus-visible {
    border-color: #d4d4d8;
    background: #fafafa;
    outline: none;
  }

  .mobile-menu-toggle:active {
    transform: translate3d(0, 0, 0) scale(0.96);
  }

  .hero-nav::before,
  .hero-nav::after {
    display: none;
    content: none;
  }

  .mobile-menu {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: block;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
      opacity 260ms var(--ease-out-quart),
      visibility 260ms var(--ease-out-quart);
  }

  .mobile-menu.is-open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  .mobile-menu-backdrop {
    position: absolute;
    inset: 0;
    padding: 0;
    border: 0;
    background: #ffffff;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    cursor: pointer;
    opacity: 0;
    transition: opacity 300ms var(--ease-out-quart);
  }

  .mobile-menu.is-open .mobile-menu-backdrop {
    opacity: 1;
  }

  .mobile-menu-panel {
    position: absolute;
    left: var(--mobile-stage-left);
    top: 0;
    --mobile-menu-gutter: 16px;
    --mobile-menu-control-bottom: calc(32px + env(safe-area-inset-bottom, 0px));
    --mobile-menu-search-width: min(212px, calc(var(--mobile-page) - 190px));
    width: var(--mobile-page);
    height: 100vh;
    height: 100dvh;
    min-height: 384px;
    overflow: hidden;
    border-bottom: 0;
    background: #fff;
    opacity: 0;
    transform: translate3d(0, -18px, 0) scale(0.985);
    transform-origin: top center;
    transition:
      opacity 240ms var(--ease-out-quart),
      transform 360ms var(--ease-out-quint);
    will-change: opacity, transform;
  }

  .mobile-menu.is-open .mobile-menu-panel {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }

  .mobile-menu-logo {
    position: absolute;
    left: 16px;
    top: 16px;
    width: 155px;
    height: 32px;
    object-fit: contain;
    opacity: 0;
    transform: translate3d(0, -8px, 0);
    transition:
      opacity 240ms var(--ease-out-quart),
      transform 320ms var(--ease-out-quint);
    transition-delay: 40ms;
  }

  .mobile-menu-close {
    position: absolute;
    right: 16px;
    top: 16px;
    display: flex;
    width: 32px;
    height: 32px;
    align-items: center;
    justify-content: center;
    padding: 4px;
    border: 1px solid #e4e4e7;
    border-radius: 8px;
    background: #fff;
    cursor: pointer;
    opacity: 0;
    transform: translate3d(0, -8px, 0) scale(0.96);
    transition:
      opacity 240ms var(--ease-out-quart),
      transform 320ms var(--ease-out-quint),
      background-color 180ms var(--ease-out-quart);
    transition-delay: 70ms;
  }

  .mobile-menu-close::before {
    width: 24px;
    height: 24px;
    content: "";
    background: #27272a;
    -webkit-mask: url("./assets/figma/mobile-menu-close.svg") center / 24px 24px no-repeat;
    mask: url("./assets/figma/mobile-menu-close.svg") center / 24px 24px no-repeat;
  }

  .mobile-menu.is-open .mobile-menu-logo,
  .mobile-menu.is-open .mobile-menu-close {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }

  .mobile-menu-close:active {
    transform: translate3d(0, 0, 0) scale(0.96);
  }

  .mobile-menu-nav {
    position: absolute;
    left: 16px;
    top: 80px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 32px;
    width: calc(var(--mobile-page) - 32px);
  }

  .mobile-menu-nav a {
    position: relative;
    color: #a1a1aa;
    font-size: 32px;
    font-weight: 500;
    line-height: 48px;
    white-space: nowrap;
    opacity: 0;
    transform: translate3d(0, -12px, 0);
    transition:
      color 180ms var(--ease-out-quart),
      opacity 320ms var(--ease-out-quart),
      transform 420ms var(--ease-out-quint);
    will-change: opacity, transform;
  }

  .mobile-menu.is-open .mobile-menu-nav a {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }

  .mobile-menu.is-open .mobile-menu-nav a:nth-child(1) {
    transition-delay: 90ms;
  }

  .mobile-menu.is-open .mobile-menu-nav a:nth-child(2) {
    transition-delay: 130ms;
  }

  .mobile-menu.is-open .mobile-menu-nav a:nth-child(3) {
    transition-delay: 170ms;
  }

  .mobile-menu.is-open .mobile-menu-nav a:nth-child(4) {
    transition-delay: 210ms;
  }

  .mobile-menu.is-open .mobile-menu-nav a:nth-child(5) {
    transition-delay: 250ms;
  }

  .mobile-menu-nav a.is-active {
    color: #27272a;
  }

  .mobile-menu-nav a.is-active::after {
    position: absolute;
    left: -4px;
    top: 48px;
    width: 72px;
    height: 12px;
    content: "";
    background: url("./assets/remote/f107f9fd-b4b2-4155-8538-1e2346b53bcd.svg") center / contain no-repeat;
    transform: none;
  }

  .accent-hero {
    left: min(calc(var(--mobile-page) - 63px), 339px);
    top: 65px;
    width: 36px;
    height: 36px;
  }

  .hero-title {
    left: 16px;
    top: 96px;
    width: var(--mobile-card-width);
    height: auto;
    font-size: clamp(32px, 8.955vw, 36px);
    line-height: clamp(44px, 11.94vw, 48px);
  }

  .hero-title .title-row-1 {
    gap: 8px;
  }

  .hero-desc {
    left: 16px;
    top: 208px;
    width: calc(var(--mobile-page) - 32px);
    height: auto;
    font-size: 14px;
    line-height: 20px;
  }

  .hero-actions {
    left: 16px;
    top: 284px;
    width: 256px;
    height: 40px;
    gap: 16px;
  }

  .download-wrap,
  .download,
  .learn {
    width: 120px;
    height: 40px;
  }

  .download,
  .learn {
    font-size: 14px;
    line-height: 20px;
  }

  .download img {
    width: 20px;
    height: 20px;
  }

  .download-menu {
    top: 48px;
    width: 300px;
  }

  .download-menu span {
    font-size: 14px;
    line-height: 20px;
  }

  .download-menu small {
    font-size: 12px;
    line-height: 18px;
  }

  .hero-board {
    left: 8px;
    top: 372px;
    width: calc(var(--mobile-page) - 16px);
    height: 380px;
    border-radius: 12px;
  }

  .board-shadow,
  .board-white {
    width: 100%;
    height: 100%;
    border-radius: 12px;
  }

  .hero-col {
    width: var(--mobile-hero-card-width);
  }

  .hero-col-left {
    left: 8px;
    top: -36px;
  }

  .hero-col-right {
    left: calc(18px + var(--mobile-hero-card-width));
    top: -36px;
  }

  .hero-track {
    gap: 8px;
  }

  .hero-track img {
    width: var(--mobile-hero-card-width);
    border-radius: 8px;
  }

  .hero-col-left .hero-track img:nth-child(1),
  .hero-col-left .hero-track img:nth-child(4) {
    content: url("./assets/hero/mobile-1-4.png");
  }

  .hero-col-left .hero-track img:nth-child(2),
  .hero-col-left .hero-track img:nth-child(5) {
    content: url("./assets/hero/mobile-1-5.png");
  }

  .hero-col-left .hero-track img:nth-child(3),
  .hero-col-left .hero-track img:nth-child(6) {
    content: url("./assets/hero/mobile-1-6.png");
  }

  .hero-col-right .hero-track img:nth-child(1),
  .hero-col-right .hero-track img:nth-child(4) {
    content: url("./assets/hero/mobile-1-1.png");
  }

  .hero-col-right .hero-track img:nth-child(2),
  .hero-col-right .hero-track img:nth-child(5) {
    content: url("./assets/hero/mobile-1-2.png");
  }

  .hero-col-right .hero-track img:nth-child(3),
  .hero-col-right .hero-track img:nth-child(6) {
    content: url("./assets/hero/mobile-1-3.png");
  }

  .hero-track-left {
    animation-duration: 38s;
  }

  .hero-track-right {
    animation-duration: 56s;
  }

  .scroll-text {
    left: 16px;
    top: 780px;
    font-size: 14px;
    line-height: 24px;
  }

  .scroll-arrow {
    left: 74px;
    top: 786px;
    width: 92px;
    height: 62px;
    content: url("./assets/figma/hero-arrow.svg");
    object-fit: contain;
  }

  .feature-head,
  .layout-head,
  .share-head,
  .faq-head {
    left: 16px;
    width: calc(var(--mobile-page) - 32px);
    height: 132px;
  }

  .feature-head {
    top: 940px;
  }

  .layout-head {
    top: 2232px;
  }

  .share-head {
    top: 3180px;
  }

  .faq-head {
    top: 3758px;
    height: 84px;
  }

  .kicker {
    height: 24px;
    font-size: 16px;
    line-height: 24px;
    gap: 12px;
  }

  .kicker img {
    width: 24px;
    height: 24px;
  }

  .feature-head .kicker,
  .layout-head .kicker,
  .share-head .kicker {
    left: 50%;
    top: 0;
    transform: translateX(-50%);
  }

  .faq-head .kicker {
    left: 50%;
    top: 0;
    transform: translateX(-50%);
  }

  .feature-head h2,
  .layout-head h2,
  .share-head h2,
  .faq-head h2 {
    left: 50%;
    top: 36px;
    width: calc(var(--mobile-page) - 32px);
    font-size: 32px;
    line-height: 48px;
    text-align: center;
    white-space: normal;
    transform: translateX(-50%);
  }

  .mobile-break {
    display: block;
  }

  /* FAQ 标题在 mobile 下与 feature/layout/share 一样居中：继承共享 h2 规则即可 */

  .feature-accent {
    left: min(calc(50% + 150px), calc(100% - 48px));
    top: -8px;
    width: 48px;
    height: 48px;
  }

  .layout-accent {
    left: min(calc(50% + 150px), calc(100% - 48px));
    top: -8px;
    width: 48px;
    height: 48px;
  }

  .share-accent {
    left: min(calc(50% + 150px), calc(100% - 67px));
    top: 0;
    width: 67px;
    height: 36px;
  }

  .faq-accent {
    /* 跟随居中后的标题尾部：50% + 半个标题宽 (144px ≈ 8 字 × 32px / 2) */
    left: calc(50% + 144px);
    top: 18px;
    width: 36px;
    height: 36px;
  }

  .features {
    left: 16px;
    top: 1108px;
    width: calc(var(--mobile-page) - 32px);
    height: 1008px;
  }

  .feature-card {
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    height: 240px;
  }

  .feature-card:hover {
    transform: none;
  }

  .f1,
  .f2,
  .f3,
  .f4 {
    left: 0;
  }

  .f1 { top: 0; }
  .f2 { top: 256px; }
  .f3 { top: 512px; }
  .f4 { top: 768px; }

  .feature-panel {
    border-radius: 12px;
  }

  .feature-pattern {
    left: 85px;
    top: 10px;
    width: 200px;
    height: 200px;
    background: url("./assets/figma/mobile-feature-pattern.webp") center / contain no-repeat;
    -webkit-mask-image: none;
    mask-image: none;
  }

  .f1 .feature-pattern {
    left: 75px;
    width: 220px;
    height: 220px;
  }

  .feature-symbol {
    left: 12px;
    top: 108px;
    width: 60px;
    height: 60px;
    transform: scale(0.8);
    transform-origin: left top;
  }

  .f2 .feature-symbol { left: 12px; top: 90px; }
  .f3 .feature-symbol { left: 16px; top: 84px; }
  .f4 .feature-symbol { left: 16px; top: 86px; }

  .feature-card h3 {
    left: 14px;
    top: 172px;
    font-size: 20px;
    line-height: 30px;
  }

  .feature-card > p,
  .f4 > p {
    left: 14px;
    top: 210px;
    width: calc(100% - 32px);
    font-size: 14px;
    line-height: 20px;
    white-space: normal;
  }

  .f2 h3 { left: 12px; top: 154px; }
  .f2 > p { left: 12px; top: 190px; width: calc(100% - 24px); }
  .f3 h3 { left: 16px; top: 148px; }
  .f3 > p { left: 16px; top: 184px; width: calc(100% - 32px); }
  .f4 h3 { left: 16px; top: 150px; }
  .f4 > p { left: 16px; top: 186px; width: calc(100% - 32px); }

  .menu-shot,
  .prompt-shot,
  .share-shot {
    left: calc(100% - 204px);
    top: 12px;
    transform: scale(0.60378);
    transform-origin: left top;
  }

  .model-shot {
    left: calc(100% - 212px);
    top: 12px;
    transform: scale(0.62893);
    transform-origin: left top;
  }

  .f4 .model-shot {
    left: calc(100% - 204px);
    top: 12px;
    width: 192px;
    height: 176px;
    transform: none;
  }

  .menu-shot > img:first-child {
    content: url("./assets/figma/mobile-menu-shot-bg.svg");
  }

  .f1 .menu-shot {
    left: calc(100% - 204px);
    top: 12px;
    width: 192px;
    height: 190px;
    transform: none;
  }

  .f1 .menu-shot > img:first-child {
    width: 192px;
    height: 190px;
  }

  .f1 .menu-shot span {
    font-size: 12px;
    line-height: 18px;
  }

  .f1 .m1 { left: 12px; top: 12px; }
  .f1 .m2 { left: 12px; top: 38px; }
  .f1 .m3 { left: 12px; top: 64px; }
  .f1 .m5 { left: 12px; top: 130px; }

  .f1 .menu-active {
    left: 6px;
    top: 88px;
    width: 180px;
    height: 36px;
  }

  .f1 .menu-label {
    left: 44px;
    top: 97px;
    font-size: 16px;
    line-height: 24px;
  }

  .f1 .menu-shot .menu-label {
    font-size: 16px;
    line-height: 24px;
  }

  .f1 .menu-logo {
    left: 12px;
    top: 94px;
    width: 24px;
    height: 24px;
    border-radius: 6px;
  }

  .f1 .menu-logo img {
    width: 107.33px;
    height: 24px;
  }

  .f1 .cursor {
    left: 146px;
    top: 118px;
    width: 24px;
    height: 24px;
    overflow: visible;
    filter: drop-shadow(0 1px 1px rgba(0, 0, 0, 0.3));
  }

  .f1 .cursor .cursor-fallback {
    display: none;
  }

  .f1 .cursor .cursor-outline,
  .f1 .cursor .cursor-fill {
    position: absolute;
    display: block;
    inset: auto;
    max-width: none;
  }

  .f1 .cursor .cursor-outline {
    left: 15.32%;
    top: 10.51%;
    width: 75.29%;
    height: 80.09%;
  }

  .f1 .cursor .cursor-fill {
    left: 19.07%;
    top: 14.26%;
    width: 67.79%;
    height: 72.64%;
  }

  .menu-active {
    content: url("./assets/figma/mobile-menu-active.svg");
    left: 10px;
    top: 146px;
    width: 298px;
    height: 70px;
  }

  .menu-label {
    left: 60px;
    top: 156px;
  }

  .menu-logo {
    left: 20px;
    top: 156px;
    width: 40px;
    height: 40px;
  }

  .cursor {
    left: 249px;
    top: 205px;
    width: 40px;
    height: 40px;
  }

  .cursor img {
    width: 40px;
    height: 40px;
  }

  .prompt-shot > img:first-child {
    content: url("./assets/figma/mobile-prompt-shot-bg.svg");
    height: 291.5px;
  }

  .share-shot .shot-bg {
    content: url("./assets/figma/mobile-share-shot-bg.svg");
    height: 291.5px;
  }

  .model-shot .shot-bg {
    content: url("./assets/figma/mobile-model-shot-bg.svg");
    width: 192px;
    height: 176px;
  }

  .f4 .model-shot .selected {
    left: 6px;
    top: 6px;
    width: 180px;
    height: 28px;
    border-radius: 6px;
  }

  .f4 .model-shot .down {
    content: url("./assets/figma/mobile-model-check.svg");
    left: 164px;
    top: 12px;
    width: 16px;
    height: 16px;
  }

  .f4 .model-shot .model {
    left: 12px;
    width: 16px;
    height: 16px;
  }

  .f4 .model-shot .gemini { top: 12px; }
  .f4 .model-shot .gemini { content: url("./assets/figma/mobile-model-gemini.svg"); }
  .f4 .model-shot .minimax {
    content: url("./assets/figma/mobile-model-minimax.svg");
    top: 44px;
  }
  .f4 .model-shot .qwen {
    content: url("./assets/figma/mobile-model-qwen.svg");
    left: 12px;
    top: 76px;
    width: 16px;
    height: 16px;
  }
  .f4 .model-shot .doubao {
    content: url("./assets/figma/mobile-model-doubao.svg");
    top: 108px;
  }
  .f4 .model-shot .deepseek {
    content: url("./assets/figma/mobile-model-deepseek.svg");
    left: 12px;
    top: 142px;
    width: 16px;
    height: 12px;
    object-fit: contain;
  }

  .f4 .model-shot span {
    left: 36px;
    color: #27272a;
    font-size: 14px;
    font-weight: 500;
    line-height: 16px;
  }

  .f4 .model-shot .t-gemini { top: 12px; }
  .f4 .model-shot .t-minimax { top: 44px; }
  .f4 .model-shot .t-qwen { top: 76px; }
  .f4 .model-shot .t-doubao { top: 108px; }
  .f4 .model-shot .t-deepseek { top: 140px; }

  .f4 .feature-pattern {
    left: 85px;
    top: 10px;
    width: 200px;
    height: 200px;
  }

  .wallpaper {
    left: 12px;
    top: 12px;
    width: 294px;
    height: 240px;
    border-radius: 8px;
  }

  .layout-toggle {
    left: calc((var(--mobile-page) - 268px) / 2);
    top: 2380px;
    width: 268px;
    height: 48px;
    padding: 4px;
  }

  .layout-toggle::before {
    left: 4px;
    top: 4px;
    height: 40px;
  }

  .layout-toggle.is-sidebar::before {
    transform: translate3d(120px, 0, 0) scaleX(1.1724);
  }

  .layout-toggle button {
    height: 40px;
    font-size: 16px;
    line-height: 24px;
  }

  .layout-demo {
    left: 0;
    top: 2460px;
    width: var(--mobile-page);
    height: 600px;
    border-radius: 0;
  }

  .layout-window-layer,
  .layout-sidebar-layer {
    left: -495px;
    top: 0;
    width: 1392px;
    height: 600px;
  }

  .layout-bg,
  .layout-sidebar-bg {
    width: 1392px;
    height: 600px;
  }

  .layout-column.c1 { left: 60px; top: -271px; }
  .layout-column.c2 { left: 384px; top: -149px; }
  .layout-column.c3 { left: 708px; top: -321px; }
  .layout-column.c4 { left: 1032px; top: -199px; }

  .layout-panel,
  .layout-sidebar-panel {
    display: none;
  }

  .layout-mobile-panel {
    position: absolute;
    left: 16px;
    top: 195px;
    z-index: 3;
    display: block;
    width: calc(var(--mobile-page) - 32px);
    height: 210px;
    object-fit: cover;
    opacity: 1;
    transition:
      opacity 260ms var(--ease-out-quart),
      transform 360ms var(--ease-out-quart);
  }

  .layout-mobile-panel-window {
    top: clamp(92px, calc(306px - 28vw), 195px);
    height: auto;
    aspect-ratio: 30 / 17;
    object-fit: contain;
  }

  .layout-mobile-panel-sidebar {
    left: calc((var(--mobile-page) - 240px) / 2);
    top: 48px;
    width: 240px;
    height: 504px;
    object-fit: cover;
    opacity: 0;
    transform: translate3d(18px, 0, 0) scale(0.985);
    pointer-events: none;
  }

  .layout-demo.is-sidebar .layout-mobile-panel-window {
    opacity: 0;
    transform: translate3d(-18px, 0, 0) scale(0.985);
    pointer-events: none;
  }

  .layout-demo.is-sidebar .layout-mobile-panel-sidebar {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
  }

  .share-row {
    left: -379px;
    top: 3296px;
    gap: 16px;
    height: 380px;
    animation-duration: 72s;
  }

  .share-image {
    width: 200px;
    height: 380px;
    border-radius: 0;
  }

  .share-image:hover {
    transform: none;
    box-shadow: none;
  }

  .faq {
    left: 16px;
    top: 3874px;
    display: flex;
    flex-direction: column;
    gap: 0;
    width: calc(var(--mobile-page) - 32px);
    min-height: 0;
    padding-top: 0;
  }

  .top-line {
    width: 100%;
  }

  .faq-col {
    width: 100%;
    gap: 0;
  }

  details {
    min-height: 57px;
  }

  summary {
    align-items: flex-start;
    height: 57px;
    padding-top: 17px;
    font-size: 16px;
    line-height: 24px;
    white-space: nowrap;
  }

  summary img {
    width: 24px;
    height: 24px;
  }

  details p {
    width: 100%;
    margin: 8px 0 10px;
    font-size: 14px;
    line-height: 22px;
  }

  .footer {
    left: 16px;
    top: var(--footer-top);
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    height: 577px;
    overflow: visible;
    transform: none;
  }

  .footer-cta {
    display: block;
    left: 12px;
    top: 12px;
    z-index: 4;
    width: calc(100% - 24px);
    height: 132px;
    border-radius: 8px;
    background: rgba(0, 0, 0, 0.1);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
  }

  .footer-copy {
    left: 12px;
    top: 12px;
    width: calc(100% - 24px);
  }

  .footer-copy h2 {
    display: none;
  }

  .footer-copy p {
    width: 100%;
    margin: 0;
    color: #fff;
    font-size: 13px;
    line-height: 20px;
    overflow-wrap: normal;
    word-break: normal;
  }

  .footer-mobile-break {
    display: block;
  }

  .footer-desktop-comma {
    display: none;
  }

  .footer-actions {
    left: 12px;
    top: 84px;
    z-index: 30;
    display: flex;
    align-items: stretch;
    gap: 16px;
    width: 256px;
    height: 36px;
  }

  .footer-actions > * {
    flex: 0 0 120px;
    height: 36px;
    min-width: 0;
  }

  .footer-download-wrap,
  .footer-top-button {
    width: 120px;
    height: 36px;
  }

  .footer-download-wrap {
    display: flex;
  }

  .footer-download,
  .footer-top-button {
    width: 120px;
    height: 36px;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    padding: 0;
    font-size: 14px;
    line-height: 20px;
  }

  .footer-download {
    border-radius: 6px;
    color: #27272a;
    background: #fff;
  }

  .footer-download img {
    content: url("./assets/figma/footer-chrome-dark.svg");
  }

  .footer-top-button {
    border-radius: 8px;
    color: #fff;
    border-color: rgba(255, 255, 255, 0.6);
    background: transparent;
  }

  .footer-download-menu {
    left: 0;
    top: 48px;
    width: min(332px, calc(var(--mobile-page) - 32px));
  }

  .footer-art {
    display: block;
    left: 0;
    top: 0;
    width: 100%;
    height: 480px;
    border-radius: 12px;
  }

  .footer-wordmark {
    display: none;
  }

  .footer-bg {
    display: none;
  }

  .footer-bottom {
    display: block;
    left: 0;
    top: 504px;
    width: 100%;
    height: 73px;
    border-top: 0;
    background: #fff;
  }

  .footer-bottom::before {
    position: absolute;
    left: 0;
    top: 40px;
    width: 100%;
    height: 1px;
    content: "";
    background: #f4f4f5;
  }

  .footer-desc {
    display: none;
  }

  .footer-desc-desktop {
    display: none;
  }

  .footer-desc-mobile {
    display: block;
  }

  .designer {
    left: 0;
    top: 504px;
    height: 24px;
    font-size: 12px;
    line-height: 16px;
  }

  .designer a {
    color: #52525b;
  }

  .designer img {
    width: 24px;
    height: 24px;
  }

  .footer nav {
    left: calc(100% - 128px);
    right: auto;
    top: 506px;
    gap: 16px;
    width: 128px;
    height: 20px;
  }

  .footer nav a,
  .footer nav img {
    width: 20px;
    height: 20px;
  }

  .footer-legal {
    left: 0;
    top: 561px;
    justify-content: center;
    width: 100%;
    gap: 12px;
    font-size: 12px;
    line-height: 16px;
    transform: none;
  }

  @keyframes hero-scroll-left {
    from { transform: translate3d(0, 0, 0); }
    to { transform: translate3d(0, -804px, 0); }
  }

  @keyframes hero-scroll-right {
    from { transform: translate3d(0, -1090px, 0); }
    to { transform: translate3d(0, 0, 0); }
  }

  @keyframes share-marquee {
    to {
      transform: translateX(-1944px);
    }
  }

  .motion-ready .feature-card.reveal-item.is-visible:hover,
  .motion-ready .share-image.reveal-item.is-visible:hover {
    transform: translate3d(0, 0, 0) scale(1);
  }
}

@media (max-width: 360px) {
  .policy-page {
    height: 3653px;
  }

  .policy-card {
    height: 2870px;
  }

  .policy-title-row {
    height: 102px;
  }

  .policy-page h1 {
    font-size: 22px;
    line-height: 34px;
  }

  .policy-title-accent {
    display: none;
  }

  .policy-date {
    top: 218px;
  }

  .policy-divider {
    top: 252px;
  }

  .policy-intro {
    top: 268px;
  }

  .policy-section-1 { top: 350px; }
  .policy-section-2 { top: 638px; }
  .policy-section-3 { top: 926px; }
  .policy-section-4 { top: 1118px; }
  .policy-section-5 { top: 1530px; }
  .policy-section-6 { top: 1790px; }
  .policy-section-7 { top: 1990px; }
  .policy-section-8 { top: 2190px; }
  .policy-section-9 { top: 2520px; }
  .policy-section-10 { top: 2630px; }
  .policy-section-11 { top: 2770px; }

  .policy-page .footer {
    top: 3060px;
  }

  .hero-actions {
    top: 324px;
  }

  .hero-board {
    top: 430px;
  }

  .scroll-text {
    top: 838px;
  }

  .scroll-arrow {
    top: 844px;
  }
}

@media (min-width: 768px) and (max-width: 1439px) {
  .inspiration-footer {
    position: relative;
    left: auto;
    top: auto;
    width: min(976px, calc(100vw - 48px));
    margin: 160px auto 0;
  }

  .inspiration-footer .footer-cta {
    width: calc(100% - 48px);
  }

  .inspiration-footer .footer-copy p {
    width: min(500px, calc(100vw - 548px));
  }

  .inspiration-footer .footer-art {
    width: 100%;
  }

  .inspiration-footer .footer-wordmark {
    width: calc(100% - 48px);
    height: auto;
  }

  .inspiration-footer .footer-legal {
    left: calc((100% - 226px) / 2);
  }

  .inspiration-footer nav {
    left: calc(100% - 168px);
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .inspiration-footer .footer-copy p {
    width: 312px;
    font-size: 13px;
    line-height: 20px;
  }

  .inspiration-footer .footer-actions {
    width: 256px;
    gap: 16px;
  }

  .inspiration-footer .footer-actions > * {
    flex: 0 0 120px;
    min-width: 0;
  }

  .inspiration-footer .footer-download,
  .inspiration-footer .footer-top-button {
    width: 120px;
    height: 36px;
    font-size: 14px;
    line-height: 20px;
  }
}

@media (max-width: 767px) {
  .inspiration-footer {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    margin: 96px auto 0;
  }

  .inspiration-footer nav {
    top: 506px;
  }
}

.skills-body {
  background: #fff;
}

.skills-page {
  position: relative;
  width: 1440px;
  min-height: var(--skills-page-height, 1928px);
  margin: 0 auto;
  overflow: visible;
  background: #fff;
}

.skills-header-bg {
  --header-dot-flow-duration: 16s;
  --header-dot-flow-ease: linear;
  position: absolute;
  left: 50%;
  top: 0;
  width: 100vw;
  height: 400px;
  background-color: #fafafa;
  background-image: url("./assets/skills/skills-header-dots-base.svg?v=20260528-header-bg-25");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 1440px 400px;
  transform: translateX(-50%);
}

.skills-header-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(228, 228, 231, 0) 0%, rgba(228, 228, 231, 1) 38%, rgba(228, 228, 231, 0.4) 52%, rgba(228, 228, 231, 0) 72%);
  background-size: 52% 100%;
  background-position: -72% 0;
  background-repeat: no-repeat;
  -webkit-mask-image: url("./assets/skills/skills-header-dots-mask.svg?v=20260528-header-bg-25");
  mask-image: url("./assets/skills/skills-header-dots-mask.svg?v=20260528-header-bg-25");
  -webkit-mask-position: center top;
  mask-position: center top;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 1440px 400px;
  mask-size: 1440px 400px;
  animation:
    header-dot-flow var(--header-dot-flow-duration) var(--header-dot-flow-ease) infinite,
    header-dot-opacity var(--header-dot-flow-duration) cubic-bezier(0.25, 1, 0.5, 1) infinite;
  will-change: background-position, opacity;
  contain: paint;
}

.skills-header-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0.9) 18%, rgba(255, 255, 255, 0) 68%) center top / 100% 100% no-repeat;
}

.inspiration-header-bg,
.skills-header-bg {
  background-image: none;
}

@keyframes header-dot-flow {
  0% {
    background-position: -72% 0;
  }

  100% {
    background-position: 172% 0;
  }
}

@keyframes header-dot-opacity {
  0%,
  100% {
    opacity: 0.6;
  }

  50% {
    opacity: 0.6;
  }
}

@keyframes workbench-hero-dot-flow {
  0% {
    background-position: center, -72% 0;
  }

  100% {
    background-position: center, 172% 0;
  }
}

@keyframes workbench-hero-dot-opacity {
  0%,
  100% {
    opacity: 0.26;
  }

  50% {
    opacity: 0.62;
  }
}

@keyframes workbench-butterfly-mech-large {
  0%,
  11%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  18% {
    transform: translate3d(1px, -1px, 0);
  }

  31% {
    transform: translate3d(-2px, 1px, 0);
  }

  47% {
    transform: translate3d(2px, 0, 0);
  }

  59% {
    transform: translate3d(-1px, -2px, 0);
  }

  73% {
    transform: translate3d(1px, 2px, 0);
  }

  86% {
    transform: translate3d(-1px, 0, 0);
  }
}

@keyframes workbench-butterfly-mech-small {
  0%,
  8%,
  100% {
    transform: translate3d(0, 0, 0);
  }

  16% {
    transform: translate3d(-1px, 2px, 0);
  }

  29% {
    transform: translate3d(2px, -1px, 0);
  }

  41% {
    transform: translate3d(-2px, -1px, 0);
  }

  53% {
    transform: translate3d(1px, 1px, 0);
  }

  68% {
    transform: translate3d(3px, 0, 0);
  }

  81% {
    transform: translate3d(-1px, 1px, 0);
  }

  92% {
    transform: translate3d(1px, -2px, 0);
  }
}

@keyframes workbench-butterfly-scan {
  0%,
  52%,
  100% {
    opacity: 0;
    transform: translate3d(-118%, 0, 0) skewX(-10deg);
  }

  59% {
    opacity: 0.42;
  }

  66% {
    opacity: 0.18;
    transform: translate3d(118%, 0, 0) skewX(-10deg);
  }

  67% {
    opacity: 0;
  }
}

@keyframes workbench-cta-dot-pulse {
  0%,
  100% {
    opacity: 0.12;
  }

  50% {
    opacity: 0.46;
  }
}

@keyframes workbench-card-dot-float {
  0%,
  100% {
    opacity: 0.76;
    transform: translate3d(0, 0, 0) rotate(var(--workbench-dot-rotate, 0deg));
  }

  50% {
    opacity: 1;
    transform: translate3d(-8px, 6px, 0) rotate(var(--workbench-dot-rotate, 0deg));
  }
}

@keyframes header-dot-pointer-opacity {
  0%,
  100% {
    opacity: 0;
  }

  50% {
    opacity: 0.6;
  }
}

.skills-header {
  position: absolute;
  left: 24px;
  top: 24px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 48px;
  height: 36px;
}

.skills-nav {
  gap: 24px;
  font-size: 16px;
  line-height: 24px;
}

.skills-nav a::after {
  background-image: url("./assets/inspiration/nav-underline.svg");
}

.skills-top-search {
  position: absolute;
  left: 1010px;
  top: 0;
  width: 240px;
  height: 36px;
}

.skills-download-wrap {
  position: absolute;
  left: 1274px;
  top: 0;
  width: 118px;
  height: 36px;
}

.skills-download {
  width: 118px;
  height: 36px;
  border-radius: 6px;
  color: #fff;
  background: #27272a;
  font-size: 14px;
  line-height: 16px;
}

.skills-download:hover,
.skills-download:focus-visible {
  color: #fff;
  background: #18181b;
}

.skills-download-wrap .download-menu {
  left: auto;
  right: 0;
  top: 48px;
  transform-origin: top right;
}

.skills-hero {
  position: absolute;
  left: 50%;
  top: 140px;
  z-index: 2;
  width: 760px;
  text-align: center;
  transform: translateX(-50%);
}

.skills-title-wrap {
  position: relative;
  display: block;
  width: 100%;
  max-width: 100%;
}

.skills-kicker {
  width: 100%;
  margin: 0 0 16px;
  color: #e879f9;
  font-family: "Playball", cursive;
  font-size: 24px;
  font-weight: 400;
  line-height: 24px;
  text-align: center;
}

.skills-kicker .kicker-write-object,
.skills-kicker .kicker-write-svg {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

.skills-hero h1 {
  margin: 0;
  color: #27272a;
  font-size: 48px;
  font-weight: 600;
  line-height: 60px;
  white-space: nowrap;
}

.skills-mobile-title-break {
  display: none;
}

.skills-hero p {
  width: 100%;
  margin: 12px auto 0;
  color: #71717a;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  white-space: nowrap;
}

.skills-agent-strip {
  position: absolute;
  left: 50%;
  top: 310px;
  z-index: 3;
  width: 612px;
  text-align: center;
  transform: translateX(-50%);
}

.skills-agent-strip p {
  margin: 0 0 16px;
  color: #a1a1aa;
  font-size: 14px;
  font-weight: 400;
  line-height: 16px;
}

.skills-agent-marquee {
  position: relative;
  width: 612px;
  height: 48px;
  overflow: hidden;
}

.skills-agent-marquee::before,
.skills-agent-marquee::after {
  position: absolute;
  top: 0;
  z-index: 2;
  width: 72px;
  height: 48px;
  content: "";
  pointer-events: none;
}

.skills-agent-marquee::before {
  left: 0;
  background: linear-gradient(90deg, #fff 0%, #fff 50%, rgba(255, 255, 255, 0) 100%);
}

.skills-agent-marquee::after {
  right: 0;
  background: linear-gradient(270deg, #fff 0%, #fff 50%, rgba(255, 255, 255, 0) 100%);
}

.skills-agent-track {
  display: flex;
  align-items: center;
  gap: 24px;
  width: max-content;
  padding-left: 30px;
  animation: skills-agent-marquee 22s linear infinite;
  will-change: transform;
}

.skills-agent-icon {
  position: relative;
  flex: 0 0 auto;
  display: block;
  width: 48px;
  height: 48px;
  overflow: hidden;
  border-radius: 8px;
}

.skills-agent-icon.is-composite {
  background: #f4f4f5;
}

.skills-agent-bg,
.skills-agent-mark {
  position: absolute;
  display: block;
  object-fit: contain;
}

.skills-agent-bg {
  inset: 0;
  width: 48px;
  height: 48px;
}

.skills-agent-mark.is-nous-mark {
  left: 14px;
  top: 14px;
  width: 20px;
  height: 20px;
}

.skills-agent-mark.is-cursor-mark {
  left: 17px;
  top: 16px;
  width: 14px;
  height: 16px;
}

.skills-agent-mark.is-gemini-mark {
  left: 16px;
  top: 16px;
  width: 16px;
  height: 16px;
}

html[data-color-scheme="dark"] .skills-agent-bg[src$="/nous-research.svg"] {
  content: url("./assets/skills/agents/dark/nous-research.svg?v=20260605-nous-dark-1");
}

html[data-color-scheme="dark"] .skills-agent-bg[src$="/nous-research.svg"] + .skills-agent-mark.is-nous-mark {
  display: none;
}

html[data-color-scheme="dark"] .skills-agent-bg[src$="/gemini.svg"] {
  content: url("./assets/skills/agents/dark/gemini.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon[src$="/github-copilot.svg"] {
  content: url("./assets/skills/agents/dark/github-copilot.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon[src$="/windsurf.svg"] {
  content: url("./assets/skills/agents/dark/windsurf.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon[src$="/codex.svg"] {
  content: url("./assets/skills/agents/dark/codex.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon[src$="/claude-code.svg"] {
  content: url("./assets/skills/agents/dark/claude-code.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon[src$="/clawdbot.svg"] {
  content: url("./assets/skills/agents/dark/clawdbot.svg");
}

html[data-color-scheme="dark"] .skills-agent-icon.is-composite {
  background: #18181b;
}

html[data-color-scheme="dark"] .skills-agent-mark {
  filter: brightness(0) saturate(100%) invert(68%) sepia(6%) saturate(319%) hue-rotate(202deg) brightness(93%) contrast(89%);
}

@keyframes skills-agent-marquee {
  0% {
    transform: translate3d(0, 0, 0);
  }

  100% {
    transform: translate3d(-576px, 0, 0);
  }
}

.skills-hero .skills-kicker {
  margin: 0 0 16px;
  color: #e879f9;
  font-family: "Playball", cursive;
  font-size: 24px;
  line-height: 24px;
}

.skills-title-accent {
  display: none;
  position: absolute;
  left: calc(100% + 8px);
  top: -24px;
  width: 48px;
  height: 48px;
  overflow: visible;
  transform: translate3d(0, var(--hero-accent-y), 0) rotate(180deg);
  will-change: transform;
}

.skills-directory-controls {
  position: absolute;
  left: 24px;
  top: 470px;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 1392px;
  height: 36px;
}

.skills-mode-tabs {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 24px;
  height: 44px;
}

.skills-mode-tabs button {
  position: relative;
  z-index: 1;
  padding: 0;
  border: 0;
  color: #a1a1aa;
  background: transparent;
  font-size: 24px;
  font-weight: 500;
  line-height: 36px;
  transition: color 180ms var(--ease-out-quart);
}

.skills-mode-tabs button.is-active,
.skills-mode-tabs button:hover,
.skills-mode-tabs button:focus-visible {
  color: #27272a;
  outline: none;
}

.skills-mode-underline {
  position: absolute;
  left: 0;
  top: 36px;
  width: 48px;
  height: 8px;
  background: url("./assets/inspiration/nav-underline.svg") center / 48px 8px no-repeat;
  transform: translateX(var(--skills-mode-underline-x, 0px));
  transition: transform 220ms var(--ease-out-quart);
}

.skills-mode-tabs.is-hot .skills-mode-underline {
  transform: translateX(var(--skills-mode-underline-x, 72px));
}

.skills-filters {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  height: 36px;
}

.skills-filters button {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 4px 16px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #a1a1aa;
  background: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  white-space: nowrap;
  transition: color 180ms var(--ease-out-quart), border-color 180ms var(--ease-out-quart);
}

.skills-filters button.is-active,
.skills-filters button:hover,
.skills-filters button:focus-visible {
  color: #27272a;
  border-color: #27272a;
  outline: none;
}

.skills-grid {
  position: absolute;
  left: 24px;
  top: 530px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, 330px);
  gap: 24px;
  width: 1392px;
}

.skill-card {
  position: relative;
  display: block;
  --skill-card-reveal-y: 0px;
  --skill-tilt-lift: 0px;
  --skill-tilt-scale: 1;
  --skill-tilt-x: 0deg;
  --skill-tilt-y: 0deg;
  width: 330px;
  height: 178px;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 12px;
  color: inherit;
  background: #fafafa;
  opacity: 1;
  transform: perspective(900px) translate3d(0, calc(var(--skill-card-reveal-y) + var(--skill-tilt-lift)), 0) rotateX(var(--skill-tilt-x)) rotateY(var(--skill-tilt-y)) scale(var(--skill-tilt-scale));
  transform-origin: center center;
  transform-style: preserve-3d;
  will-change: transform;
  transition:
    border-color 220ms var(--ease-out-quart),
    box-shadow 260ms var(--ease-out-quart),
    transform 260ms var(--ease-out-quart),
    opacity 260ms var(--ease-out-quart);
}

.skill-card:hover,
.skill-card:focus-visible {
  --skill-tilt-lift: -2px;
  --skill-tilt-scale: 1.006;
  border-color: #e4e4e7;
  box-shadow: 0 10px 24px rgba(39, 39, 42, 0.055);
  outline: none;
}

.skill-card.is-tilting {
  z-index: 3;
  box-shadow: 0 12px 24px rgba(39, 39, 42, 0.07), 0 3px 8px rgba(39, 39, 42, 0.04);
  transition:
    border-color 180ms var(--ease-out-quart),
    box-shadow 180ms var(--ease-out-quart),
    transform 90ms var(--ease-out-quart),
    opacity 180ms var(--ease-out-quart);
}

.skill-card.is-hidden {
  display: none;
}

.skill-card-hover-bg {
  position: absolute;
  right: -2px;
  bottom: -2px;
  z-index: 0;
  width: 84px;
  height: 84px;
  background: url("./assets/skills/card-hover-mark-figma.webp") center / contain no-repeat;
  opacity: 0;
  transform: translate3d(14px, 12px, 18px) rotate(12deg) scale(0.9);
  transform-origin: center;
  transition:
    opacity 220ms var(--ease-out-quart),
    transform 280ms var(--ease-out-expo);
}

.skill-card:hover .skill-card-hover-bg,
.skill-card:focus-visible .skill-card-hover-bg,
.skill-card.is-tilting .skill-card-hover-bg {
  opacity: 1;
  transform: translate3d(0, 0, 18px) rotate(12deg) scale(1);
}

.skill-card h2 {
  position: absolute;
  left: 16px;
  top: 16px;
  z-index: 1;
  max-width: 298px;
  margin: 0;
  overflow: hidden;
  color: #27272a;
  font-size: 20px;
  font-weight: 500;
  line-height: 36px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.skill-card-divider {
  position: absolute;
  left: 16px;
  top: 60px;
  z-index: 1;
  width: 298px;
  height: 1px;
  background: #e4e4e7;
}

.skill-card p {
  position: absolute;
  left: 16px;
  top: 68px;
  z-index: 1;
  display: -webkit-box;
  width: 298px;
  margin: 0;
  overflow: hidden;
  color: #71717a;
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.skill-card-meta {
  position: absolute;
  left: 16px;
  bottom: 16px;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 24px;
  max-width: calc(100% - 32px);
  min-width: 0;
  height: 24px;
}

.skill-card-author {
  position: static;
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  max-width: 180px;
  height: 24px;
  color: #27272a;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}

.skill-card-author img {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  background: #fff;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.skill-card-author span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.skill-card-stars {
  position: static;
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  color: #27272a;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
  font-variant-numeric: tabular-nums;
  opacity: 1;
  transition: color 180ms var(--ease-out-quart), opacity 180ms var(--ease-out-quart);
}

.skill-card-stars img {
  width: 24px;
  height: 24px;
}

.skill-card:hover .skill-card-stars,
.skill-card:focus-visible .skill-card-stars {
  color: #52525b;
  opacity: 1;
}

.skills-fade {
  position: absolute;
  left: 50%;
  top: var(--skills-fade-top, 744px);
  z-index: 4;
  width: 100vw;
  height: 480px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, #fff 50%);
  transform: translate3d(-50%, 0, 0);
}

.skills-page.is-expanded .skills-fade,
.skills-page:not(.has-more) .skills-fade {
  display: none;
}

.skills-more {
  position: absolute;
  left: 614px;
  top: var(--skills-more-top, 1016px);
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 212px;
  height: 48px;
  border: 1px solid #e4e4e7;
  border-radius: 8px;
  color: #52525b;
  background: #fff;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  transition: color 180ms var(--ease-out-quart), border-color 180ms var(--ease-out-quart);
}

.skills-more:hover,
.skills-more:focus-visible {
  color: #27272a;
  border-color: #27272a;
  outline: none;
}

.skills-page.is-expanded .skills-more,
.skills-page:not(.has-more) .skills-more {
  display: none;
}

.footer.skills-footer {
  left: 24px;
  top: var(--skills-footer-top, 1224px);
  width: 1392px;
}

.skill-detail-body {
  min-width: 0;
  overflow: hidden;
  background: rgba(39, 39, 42, 0.9);
}

html.skill-modal-lock,
body.skill-modal-open {
  overflow: hidden;
}

.skill-modal {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 48px 24px;
  overflow: hidden;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  background: var(--modal-frost-bg);
  -webkit-backdrop-filter: var(--modal-frost-blur);
  backdrop-filter: var(--modal-frost-blur);
  transition: opacity 240ms var(--ease-out-quart), visibility 240ms var(--ease-out-quart);
}

.skill-modal.is-open {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}

.skill-modal-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: transparent;
}

.skill-detail-page {
  display: grid;
  place-items: start center;
  width: 100vw;
  min-height: 100vh;
  padding: 70px 24px;
  background: rgba(39, 39, 42, 0.9);
}

.skill-detail-card {
  position: relative;
  width: 684px;
  height: 760px;
  overflow: hidden;
  border-radius: 16px;
  background: #fff;
}

.skill-modal .skill-detail-card {
  opacity: 0;
  box-shadow: 0 20px 56px rgba(39, 39, 42, 0.1);
  transform: translate3d(0, 18px, 0) scale(0.985);
  transition: opacity 260ms var(--ease-out-quart), transform 320ms var(--ease-out-expo);
}

.skill-modal.is-open .skill-detail-card {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.skill-detail-head h1,
.skill-detail-eyebrow,
.skill-detail-divider,
.skill-detail-github,
.skill-detail-close,
.skill-detail-author,
.skill-detail-summary,
.skill-detail-tags,
.skill-install-block,
.skill-intro-block {
  position: absolute;
}

.skill-detail-eyebrow {
  left: 24px;
  top: 30px;
  margin: 0;
  color: #a1a1aa;
  font-size: 16px;
  font-weight: 500;
  line-height: 24px;
  white-space: nowrap;
}

.skill-detail-divider {
  left: 24px;
  top: 72px;
  width: 636px;
  height: 1px;
  background: #f4f4f5;
}

.skill-detail-head h1 {
  left: 24px;
  top: 97px;
  margin: 0;
  color: #27272a;
  font-size: 24px;
  font-weight: 600;
  line-height: 36px;
  white-space: nowrap;
}

.skill-detail-github {
  right: 72px;
  top: 24px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 6px;
  width: 99px;
  height: 36px;
  padding: 0 12px;
  border-radius: 6px;
  color: #fff;
  background: #27272a;
  font-size: 14px;
  font-weight: 400;
  line-height: 16px;
  text-transform: none;
  transition:
    background-color 180ms var(--ease-out-quart),
    box-shadow 220ms var(--ease-out-quart),
    color 180ms var(--ease-out-quart),
    opacity 180ms var(--ease-out-quart),
    transform 180ms var(--ease-out-quart);
}

.skill-detail-github:hover,
.skill-detail-github:focus-visible {
  background: #18181b;
  box-shadow: 0 6px 16px rgba(39, 39, 42, 0.12);
  transform: translateY(-1px);
  outline: none;
}

.skill-detail-github:active {
  transform: translateY(0);
}

.skill-detail-github img {
  width: 24px;
  height: 24px;
}

.skill-detail-close {
  right: 24px;
  top: 24px;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  transition:
    border-color 180ms var(--ease-out-quart),
    background-color 180ms var(--ease-out-quart),
    box-shadow 220ms var(--ease-out-quart),
    transform 180ms var(--ease-out-quart);
}

.skill-detail-close:hover {
  border-color: #27272a;
  background: #27272a;
  box-shadow: 0 6px 16px rgba(39, 39, 42, 0.1);
  outline: none;
  transform: scale(1.05);
}

.skill-detail-close:focus-visible {
  border-color: #27272a;
  background: #fff;
  box-shadow: 0 0 0 3px rgba(39, 39, 42, 0.08);
  outline: none;
}

.skill-detail-close:active {
  transform: scale(0.97);
}

.skill-detail-close img {
  width: 24px;
  height: 24px;
  transition: filter 180ms var(--ease-out-quart), opacity 180ms var(--ease-out-quart);
}

.skill-detail-close:hover img {
  filter: brightness(0) invert(1);
}

.skill-detail-author {
  left: 24px;
  top: 141px;
  display: flex;
  align-items: center;
  gap: 8px;
  height: 24px;
  color: #52525b;
  font-size: 14px;
  font-weight: 500;
  line-height: 24px;
}

.skill-detail-author img {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.skill-detail-summary {
  left: 24px;
  top: 177px;
  width: 636px;
  margin: 0;
  display: -webkit-box;
  overflow: hidden;
  color: #71717a;
  font-size: 14px;
  font-weight: 400;
  line-height: 24px;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.skill-detail-tags {
  left: auto;
  right: 24px;
  top: 141px;
  display: flex;
  gap: 12px;
}

.skill-detail-tags span {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  height: 24px;
  padding: 0;
  border: 0;
  border-radius: 6px;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.skill-detail-tags span::before {
  display: block;
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  content: "";
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.skill-detail-tags .is-codex {
  width: 72px;
  color: #3b82f6;
  background-image: url("./assets/skills/tag-codex.svg");
}

.skill-detail-tags .is-codex::before {
  background-image: url("./assets/skills/icon-codex.svg");
}

.skill-detail-tags .is-claude {
  width: 72px;
  color: #d97706;
  background-image: url("./assets/skills/tag-claude.svg");
}

.skill-detail-tags .is-claude::before {
  background-image: url("./assets/skills/icon-claude.svg");
}

.skill-install-block {
  left: 24px;
  top: 249px;
  width: 636px;
}

.skill-install-block h2,
.skill-intro-block h2 {
  margin: 0 0 4px;
  color: #a1a1aa;
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
}

.skill-install-command {
  position: relative;
  display: flex;
  align-items: center;
  width: 636px;
  height: 36px;
  overflow: hidden;
  border-radius: 6px;
  background: #fafafa url("./assets/skills/install-bg.svg") center / 100% 100% no-repeat;
}

.skill-install-command code {
  display: block;
  width: 586px;
  overflow: hidden;
  padding-left: 12px;
  color: #27272a;
  font: 500 14px/18px "IBM Plex Sans SC", monospace;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.skill-install-token {
  color: #27272a;
}

.skill-install-token.is-command {
  color: #27272a;
}

.skill-install-token.is-value {
  color: #a1a1aa;
}

.skill-install-copy {
  position: absolute;
  right: 10px;
  top: 10px;
  display: grid;
  place-items: center;
  width: 16px;
  height: 16px;
  padding: 0;
  border: 0;
  color: #a1a1aa;
  background: transparent;
  cursor: pointer;
  transition: opacity 180ms var(--ease-out-quart), transform 180ms var(--ease-out-quart);
}

.skill-install-copy img {
  width: 16px;
  height: 16px;
}

.skill-install-copy:hover,
.skill-install-copy:focus-visible {
  opacity: 0.72;
  outline: none;
}

.skill-install-copy.is-copied {
  opacity: 1;
  transform: scale(1.04);
}

.skill-intro-block {
  left: 24px;
  top: 331px;
  width: 636px;
}

.skill-intro-scroll {
  width: 636px;
  height: 383px;
  overflow: auto;
  border-radius: 6px;
  background: #fafafa;
  border: 1px solid #f4f4f5;
  scrollbar-width: thin;
  scrollbar-color: #d4d4d8 transparent;
}

.skill-intro-scroll::-webkit-scrollbar {
  width: 4px;
}

.skill-intro-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.skill-intro-scroll::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #d4d4d8;
}

.skill-intro-text {
  margin: 0;
  padding: 12px;
  color: #71717a;
  font: 400 12px/20px "IBM Plex Sans SC", monospace;
  white-space: pre-wrap;
  word-break: break-word;
}

.skill-intro-text strong {
  color: #27272a;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .skills-body {
    min-width: 0;
    overflow-x: hidden;
  }

  .skills-page {
    width: 100vw;
    min-height: var(--skills-page-height, 1720px);
    overflow: hidden;
  }

  .skills-header-bg {
    width: 100vw;
  }

  .skills-header {
    left: 24px;
    width: calc(100vw - 48px);
  }

  .skills-top-search {
    left: auto;
    right: 142px;
  }

  .skills-download-wrap {
    left: auto;
    right: 0;
  }

  .skills-hero {
    position: relative;
    left: auto;
    top: auto;
    margin: 140px auto 0;
    transform: none;
  }

  .skills-agent-strip {
    position: relative;
    left: auto;
    top: auto;
    width: min(612px, calc(100vw - 48px));
    margin: 32px auto 0;
    transform: none;
  }

  .skills-agent-marquee {
    width: 100%;
  }

  .skills-directory-controls {
    position: relative;
    left: auto;
    top: auto;
    align-items: flex-start;
    width: min(976px, calc(100vw - 48px));
    height: auto;
    margin: 56px auto 0;
  }

  .skills-filters {
    position: static;
    flex-wrap: wrap;
    justify-content: flex-end;
    width: min(720px, calc(100vw - 180px));
    height: auto;
    margin: 0;
  }

  .skills-grid {
    position: relative;
    left: auto;
    top: auto;
    grid-template-columns: repeat(2, 330px);
    justify-content: center;
    width: min(976px, calc(100vw - 48px));
    margin: 24px auto 0;
  }

  .skills-fade {
    display: none;
  }

  .skills-more {
    position: relative;
    left: auto;
    top: auto;
    margin: 48px auto 0;
  }

  .footer.skills-footer {
    position: relative;
    left: auto;
    top: auto;
    width: min(976px, calc(100vw - 48px));
    margin: 160px auto 0;
  }
}

@media (max-width: 767px) {
  .skills-body,
  .skill-detail-body {
    min-width: 0;
    overflow-x: hidden;
  }

  .skills-page {
    width: 100vw;
    min-height: 0;
    padding: 16px 16px 24px;
    overflow: hidden;
  }

  .skills-header-bg {
    left: 0;
    top: 0;
    width: 100%;
    height: 300px;
    transform: none;
  }

  .skills-header {
    position: relative;
    left: auto;
    top: auto;
    z-index: 20;
    justify-content: space-between;
    width: calc(var(--mobile-page) - 32px);
    height: 32px;
    margin: 0 auto;
    gap: 0;
  }

  .skills-header .logo,
  .skills-header .logo-svg {
    width: 155px;
    height: 32px;
  }

  .skills-nav,
  .skills-top-search,
  .skills-download-wrap {
    display: none;
  }

  .skills-page .mobile-menu-toggle {
    right: 0;
    top: 0;
    z-index: 2;
    display: block;
  }

  .skills-hero {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    margin: 72px auto 0;
    transform: none;
  }

  .skills-hero h1 {
    font-size: 30px;
    line-height: 44px;
    white-space: normal;
  }

  .skills-mobile-title-break {
    display: block;
  }

  .skills-hero p {
    width: 100%;
    margin-left: 0;
    font-size: 14px;
    line-height: 24px;
    white-space: normal;
  }

  .skills-title-accent {
    left: calc(100% + 4px);
    top: -10px;
    width: 36px;
    height: 36px;
  }

  .skills-agent-strip {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    margin: 28px auto 0;
    transform: none;
  }

  .skills-agent-strip p {
    margin-bottom: 12px;
  }

  .skills-agent-marquee {
    width: min(100%, 320px);
    margin: 0 auto;
  }

  .skills-agent-marquee::before,
  .skills-agent-marquee::after {
    width: 48px;
  }

  .skills-agent-track {
    gap: 16px;
    padding-left: 0;
    animation-duration: 18s;
  }

  .skills-directory-controls {
    position: relative;
    left: auto;
    top: auto;
    flex-direction: column;
    align-items: stretch;
    width: var(--mobile-card-width);
    height: auto;
    margin: 40px auto 0;
  }

  .skills-mode-tabs {
    width: 100%;
  }

  .skills-filters {
    position: static;
    justify-content: flex-start;
    width: 100%;
    height: auto;
    margin: 20px 0 0;
    overflow-x: auto;
    padding-bottom: 4px;
  }

  .skills-filters::-webkit-scrollbar {
    display: none;
  }

  .skills-grid {
    position: relative;
    left: auto;
    top: auto;
    display: grid;
    grid-template-columns: 1fr;
    width: var(--mobile-card-width);
    margin: 24px auto 0;
  }

  .skill-card {
    width: 100%;
  }

  .skill-card h2,
  .skill-card p,
  .skill-card-divider {
    width: calc(100% - 32px);
    max-width: none;
  }

  .skills-fade {
    display: none;
  }

  .skills-more {
    position: relative;
    left: auto;
    top: auto;
    width: 100%;
    margin: 40px auto 0;
  }

  .footer.skills-footer {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    margin: 96px auto 0;
  }

  .skill-detail-page {
    display: block;
    min-height: 100vh;
    padding: 16px;
    overflow-y: auto;
  }

  .skill-modal {
    display: block;
    padding: 16px;
    overflow-y: auto;
  }

  .skill-detail-card {
    width: 100%;
    height: auto;
    min-height: calc(100vh - 32px);
    padding: 24px;
    overflow: visible;
  }

  .skill-detail-head h1,
  .skill-detail-eyebrow,
  .skill-detail-divider,
  .skill-detail-github,
  .skill-detail-close,
  .skill-detail-author,
  .skill-detail-summary,
  .skill-detail-tags,
  .skill-install-block,
  .skill-intro-block {
    position: static;
  }

  .skill-detail-head {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: 12px;
    align-items: center;
  }

  .skill-detail-head h1 {
    overflow: hidden;
    font-size: 22px;
    text-overflow: ellipsis;
  }

  .skill-detail-eyebrow {
    margin-bottom: 12px;
  }

  .skill-detail-divider {
    width: 100%;
    margin-bottom: 20px;
  }

  .skill-detail-github {
    width: 90px;
  }

  .skill-detail-close {
    width: 36px;
    height: 36px;
  }

  .skill-detail-author {
    margin-top: 8px;
  }

  .skill-detail-summary {
    width: 100%;
    margin-top: 12px;
  }

  .skill-detail-tags {
    margin-top: 12px;
  }

  .skill-install-block,
  .skill-intro-block {
    width: 100%;
    margin-top: 24px;
  }

  .skill-install-command,
  .skill-intro-scroll {
    width: 100%;
  }

  .skill-install-command code {
    width: calc(100% - 44px);
  }

  .skill-intro-scroll {
    height: 52vh;
  }

  .skill-modal .skill-detail-card {
    min-height: calc(100vh - 32px);
  }
}

@media (max-width: 731px) {
  body.prompt-modal-open {
    padding-top: 0;
    background: #3f3f46;
  }

  body.prompt-modal-open .global-notice {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  .prompt-modal {
    display: block;
    padding: 60px 0 0;
    overflow-x: hidden;
    overflow-y: auto;
    background: #3f3f46;
    -webkit-overflow-scrolling: touch;
  }

  .prompt-modal-backdrop {
    position: fixed;
    background: #3f3f46;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }

  .prompt-modal-panel.is-square {
    position: relative;
    display: block;
    width: min(402px, 100vw);
    height: 880px;
    min-height: 880px;
    max-width: none;
    max-height: none;
    margin: 0 auto;
    padding: 0;
    overflow: hidden;
    border-radius: 16px 16px 0 0;
    background: #fff;
    box-shadow: none;
  }

  .prompt-modal-panel.is-square .prompt-modal-close {
    right: 16px;
    top: 16px;
    width: 36px;
    height: 36px;
    border: 1px solid #f4f4f5;
    border-radius: 8px;
    background: #fff;
  }

  .prompt-modal-panel.is-square .prompt-modal-close:hover {
    border-color: #f4f4f5;
    background: #fff;
    box-shadow: none;
    transform: none;
  }

  .prompt-modal-panel.is-square .prompt-modal-close:hover img {
    filter: none;
  }

  .prompt-modal-panel.is-square .prompt-modal-image {
    position: absolute;
    left: 16px;
    top: 68px;
    width: calc(100% - 32px);
    height: calc(100% - 32px);
    max-height: 370px;
    border-radius: 8px;
    background: #fafafa;
    object-fit: cover;
    box-shadow: none;
  }

  .prompt-modal-panel.is-square .prompt-modal-content {
    display: contents;
  }

  .prompt-modal-panel.is-square .prompt-modal-content h2 {
    position: absolute;
    left: 16px;
    top: 16px;
    width: calc(100% - 68px);
    min-height: 36px;
    margin: 0;
    overflow: hidden;
    color: #27272a;
    font-size: 24px;
    font-weight: 600;
    line-height: 36px;
    text-align: left;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .prompt-modal-panel.is-square .prompt-modal-info {
    position: absolute;
    left: 16px;
    top: calc(52px + min(402px, 100vw));
    width: calc(100% - 32px);
    height: 400px;
    min-height: 0;
    margin: 0;
    padding: 12px 12px 16px;
    overflow: hidden;
    border-radius: 8px;
    background: #fafafa;
    box-shadow: inset 0 0 0 1px #f4f4f5;
  }

  .prompt-modal-panel.is-square .prompt-modal-info::after {
    display: none;
  }

  .prompt-modal-panel.is-square .prompt-modal-text {
    max-height: calc(100% - 64px);
    padding-right: 0;
    color: #52525b;
    font-size: 15px;
    font-weight: 400;
    line-height: 24px;
    white-space: pre-wrap;
    word-break: break-word;
  }

  .prompt-modal-panel.is-square .prompt-modal-actions {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 16px;
    display: flex;
    width: auto;
    height: 40px;
    gap: 10px;
  }

  .prompt-modal-panel.is-square .prompt-modal-save,
  .prompt-modal-panel.is-square .prompt-modal-copy {
    flex: 0 0 calc((100% - 10px) / 2);
    width: calc((100% - 10px) / 2);
    min-width: 0;
    height: 40px;
    font-size: 14px;
    font-weight: 500;
    line-height: 20px;
  }

  .prompt-modal-panel.is-square .prompt-modal-save {
    color: #71717a;
    border-color: #e4e4e7;
    background: #fff;
  }

  .prompt-modal-panel.is-square .prompt-modal-copy {
    color: #fff;
    border-color: #27272a;
    background: #27272a;
  }

  .prompt-modal-panel.is-square .prompt-modal-save img,
  .prompt-modal-panel.is-square .prompt-modal-copy img {
    width: 24px;
    height: 24px;
  }

  .skill-detail-body {
    min-width: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding-top: 0;
    background: #3f3f46;
  }

  body.skill-modal-open {
    background: #fff;
  }

  body.skill-modal-open .global-notice,
  .skill-detail-body .global-notice {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
  }

  .skill-detail-page {
    display: block;
    width: 100vw;
    min-height: 100dvh;
    padding: 60px 0 0;
    overflow: visible;
    background: #3f3f46;
  }

  .skill-modal {
    display: block;
    padding: 60px 0 0;
    overflow-x: hidden;
    overflow-y: auto;
    background: #3f3f46;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }

  .skill-modal-backdrop {
    background: transparent;
  }

  .skill-detail-card,
  .skill-modal .skill-detail-card {
    position: relative;
    width: 100vw;
    min-width: 0;
    max-width: none;
    height: 880px;
    min-height: 880px;
    margin: 0;
    padding: 0;
    overflow: hidden;
    border-radius: 16px 16px 0 0;
    background: #fff;
  }

  .skill-modal .skill-detail-card {
    box-shadow: none;
  }

  .skill-detail-head h1,
  .skill-detail-eyebrow,
  .skill-detail-divider,
  .skill-detail-github,
  .skill-detail-close,
  .skill-detail-author,
  .skill-detail-summary,
  .skill-detail-tags,
  .skill-install-block,
  .skill-intro-block {
    position: absolute;
  }

  .skill-detail-eyebrow {
    left: 16px;
    top: 23px;
    margin: 0;
    color: #a1a1aa;
    font-size: 16px;
    font-weight: 500;
    line-height: 24px;
  }

  .skill-detail-divider {
    left: 16px;
    top: 68px;
    width: calc(100vw - 32px);
    height: 1px;
    margin: 0;
    background: #f4f4f5;
  }

  .skill-detail-head {
    display: block;
  }

  .skill-detail-head h1 {
    left: 16px;
    top: 85px;
    max-width: calc(100vw - 32px);
    margin: 0;
    overflow: hidden;
    color: #27272a;
    font-size: 20px;
    font-weight: 600;
    line-height: 36px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .skill-detail-github {
    right: 68px;
    top: 16px;
    width: 99px;
    height: 36px;
    padding: 0 12px;
    gap: 6px;
    border-radius: 6px;
    color: #fff;
    background: #27272a;
    font-size: 14px;
    font-weight: 400;
    line-height: 16px;
  }

  .skill-detail-github img {
    width: 24px;
    height: 24px;
  }

  .skill-detail-close {
    right: 16px;
    top: 16px;
    width: 36px;
    height: 36px;
    border: 1px solid #f4f4f5;
    border-radius: 8px;
    background: #fff;
  }

  .skill-detail-close:hover {
    border-color: #f4f4f5;
    background: #fff;
    box-shadow: none;
    transform: none;
  }

  .skill-detail-close:hover img {
    filter: none;
  }

  .skill-detail-author {
    left: 16px;
    top: 129px;
    display: flex;
    align-items: center;
    gap: 8px;
    height: 24px;
    margin: 0;
    color: #52525b;
    font-size: 14px;
    font-weight: 500;
    line-height: 24px;
  }

  .skill-detail-author img {
    width: 24px;
    height: 24px;
    border-radius: 48px;
  }

  .skill-detail-tags {
    right: 16px;
    top: 129px;
    display: flex;
    gap: 12px;
    margin: 0;
  }

  .skill-detail-tags span {
    height: 24px;
    font-size: 12px;
    font-weight: 500;
    line-height: 18px;
  }

  .skill-detail-summary {
    left: 16px;
    top: 177px;
    width: calc(100vw - 32px);
    margin: 0;
    display: -webkit-box;
    overflow: hidden;
    color: #71717a;
    font-size: 12px;
    font-weight: 400;
    line-height: 18px;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
  }

  .skill-install-block {
    left: 16px;
    top: 243px;
    width: calc(100vw - 32px);
    margin: 0;
  }

  .skill-install-block h2,
  .skill-intro-block h2 {
    margin: 0 0 4px;
    color: #a1a1aa;
    font-size: 12px;
    font-weight: 400;
    line-height: 18px;
  }

  .skill-install-command {
    width: 100%;
    height: 36px;
    border-radius: 6px;
    background: #fafafa;
    box-shadow: inset 0 0 0 1px #f4f4f5;
  }

  .skill-install-command code {
    width: calc(100% - 44px);
    padding-left: 12px;
    color: #27272a;
    font: 500 14px/18px "IBM Plex Sans SC", monospace;
  }

  .skill-install-copy {
    right: 10px;
    top: 10px;
  }

  .skill-intro-block {
    left: 16px;
    top: 325px;
    width: calc(100vw - 32px);
    margin: 0;
  }

  .skill-intro-scroll {
    width: 100%;
    height: 517px;
    border: 1px solid #f4f4f5;
    border-radius: 6px;
    background: #fafafa;
  }

  .skill-intro-text {
    padding: 12px;
    color: #71717a;
    font: 400 12px/18px "IBM Plex Sans SC", monospace;
  }
}

@media (prefers-reduced-motion: reduce) {
  .inspiration-header-bg::before,
  .cases-header-bg::before,
  .skills-header-bg::before {
    animation: none;
    background-position: center, 50% 0;
    opacity: 0.6;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }

  :root {
    --hero-copy-y: 0px !important;
    --hero-board-y: 0px !important;
    --hero-accent-y: 0px !important;
    --hero-fade: 1 !important;
  }

  .motion-ready .reveal-item,
  .motion-ready .feature-card.reveal-item,
  .motion-ready .share-image.reveal-item {
    opacity: 1;
    transform: none;
  }

  .motion-ready .prompt-card.reveal-item,
  .motion-ready .prompt-card.reveal-item.is-visible,
  .motion-ready .skill-card.reveal-item,
  .motion-ready .skill-card.reveal-item.is-visible,
  .motion-ready .case-card.reveal-item,
  .motion-ready .case-card.reveal-item.is-visible,
  .prompt-card,
  .prompt-card-tilt,
  .skill-card,
  .case-card {
    transform: none !important;
  }

  .skills-agent-track {
    animation: none;
    transform: translate3d(0, 0, 0);
  }

  .workbench-hero-butterfly {
    animation: none !important;
    transform: translate3d(0, 0, 0) !important;
  }

  .workbench-hero-butterfly::after {
    display: none;
  }

  .hero-title span {
    animation: none;
    background-position: center;
  }

}

/* Final privacy layout override: keep policy copy in flow across all breakpoints. */
.policy-page {
  height: auto;
  min-height: 100vh;
  overflow: visible;
  padding-top: 108px;
  padding-bottom: 48px;
}

.policy-title-row,
.policy-date,
.policy-divider,
.policy-intro,
.policy-section,
.policy-section-narrow {
  position: relative;
  left: auto;
  top: auto !important;
  margin-left: var(--side);
}

.policy-title-row {
  margin-top: 0;
}

.policy-date {
  margin-top: 12px;
}

.policy-divider {
  margin-top: 24px;
  height: 1px;
  border-top: 0;
  background: #f4f4f5;
}

.policy-intro {
  margin-top: 24px;
}

.policy-section,
.policy-section-narrow {
  margin-top: 36px;
}

.policy-section-1 {
  margin-top: 24px;
}

.policy-section p + p,
.policy-section ol + p {
  margin-top: 12px;
}

.policy-page .footer {
  position: relative;
  left: var(--side);
  top: auto !important;
  margin-top: 160px;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .policy-page {
    height: auto;
    padding-top: 108px;
  }

  .policy-title-row,
  .policy-date,
  .policy-divider,
  .policy-intro,
  .policy-section,
  .policy-section-narrow {
    margin-left: calc(var(--policy-side) + 24px);
    width: var(--policy-inner);
  }

  .policy-page .footer {
    left: var(--policy-side);
    width: var(--policy-content);
  }
}

@media (max-width: 767px) {
  .policy-page {
    width: 100vw;
    min-width: 0;
    height: auto;
    overflow: visible;
    padding-top: 108px;
    padding-bottom: 16px;
  }

  .policy-card {
    display: none;
    top: 84px;
    bottom: 680px;
    height: auto;
  }

  .policy-title-row,
  .policy-date,
  .policy-divider,
  .policy-intro,
  .policy-section,
  .policy-section-narrow {
    margin-left: calc(var(--mobile-stage-left) + 16px);
    width: calc(var(--mobile-page) - 32px);
  }

  .policy-date {
    margin-top: 8px;
  }

  .policy-divider,
  .policy-intro {
    margin-top: 16px;
  }

  .policy-section,
  .policy-section-narrow {
    margin-top: 32px;
  }

  .policy-page .footer {
    left: calc(var(--mobile-stage-left) + 16px);
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    margin-top: 96px;
  }
}

@media (max-width: 360px) {
  .policy-page {
    height: auto;
  }

  .policy-card {
    bottom: 680px;
    height: auto;
  }
}

.cases-body {
  background: #fff;
}

.cases-page {
  position: relative;
  width: 1440px;
  min-height: var(--cases-page-height, 2008px);
  margin: 0 auto;
  overflow: visible;
  background: #fff;
}

.cases-header-bg {
  --header-dot-flow-duration: 16s;
  --header-dot-flow-ease: linear;
  position: absolute;
  left: 50%;
  top: 0;
  width: 100vw;
  height: 400px;
  overflow: hidden;
  pointer-events: none;
  background-color: #fafafa;
  background-image: url("./assets/inspiration/header-dots-base.svg?v=20260528-header-bg-25");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 1440px 400px;
  transform: translateX(-50%);
}

.cases-header-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(228, 228, 231, 0) 0%, rgba(228, 228, 231, 1) 38%, rgba(228, 228, 231, 0.4) 52%, rgba(228, 228, 231, 0) 72%);
  background-size: 52% 100%;
  background-position: -72% 0;
  background-repeat: no-repeat;
  -webkit-mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
  mask-image: url("./assets/inspiration/header-dots-mask.svg?v=20260528-header-bg-25");
  -webkit-mask-position: center top;
  mask-position: center top;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 1440px 400px;
  mask-size: 1440px 400px;
  animation:
    header-dot-flow var(--header-dot-flow-duration) var(--header-dot-flow-ease) infinite,
    header-dot-opacity var(--header-dot-flow-duration) cubic-bezier(0.25, 1, 0.5, 1) infinite;
  will-change: background-position, opacity;
  contain: paint;
}

.cases-header-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(0deg, #fff 0%, rgba(255, 255, 255, 0) 50%) center top / 100% 100% no-repeat;
}

.cases-header {
  position: absolute;
  left: 24px;
  top: 24px;
  z-index: 20;
  display: flex;
  align-items: center;
  gap: 48px;
  height: 36px;
}

.cases-nav {
  gap: 24px;
  font-size: 16px;
  line-height: 24px;
}

.cases-nav a::after {
  background-image: url("./assets/inspiration/nav-underline.svg");
}

.cases-top-search {
  position: absolute;
  left: 1010px;
  top: 0;
  width: 240px;
  height: 36px;
}

.cases-download-wrap {
  position: absolute;
  left: 1274px;
  top: 0;
  width: 118px;
  height: 36px;
}

.cases-download {
  width: 118px;
  height: 36px;
  border-radius: 6px;
  color: #fff;
  background: #27272a;
  font-size: 14px;
  line-height: 16px;
}

.cases-download:hover,
.cases-download:focus-visible {
  color: #fff;
  background: #18181b;
}

.cases-download-wrap .download-menu {
  left: auto;
  right: 0;
  top: 48px;
  transform-origin: top right;
}

.cases-hero {
  position: absolute;
  left: 335px;
  top: 140px;
  z-index: 2;
  width: 770px;
  text-align: center;
}

.cases-title-wrap {
  position: relative;
  display: inline-block;
  width: max-content;
  max-width: none;
}

.cases-hero h1 {
  display: inline-block;
  margin: 0;
  color: #27272a;
  font-size: 48px;
  font-weight: 600;
  line-height: 60px;
  white-space: nowrap;
}

.cases-title-mobile-break {
  display: none;
}

.cases-hero p {
  width: 684px;
  margin: 12px auto 0;
  color: #71717a;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
}

.cases-title-accent {
  position: absolute;
  left: calc(100% + 8px);
  top: -24px;
  width: 48px;
  height: 48px;
  overflow: visible;
  transform: rotate(180deg);
}

.cases-filters {
  position: absolute;
  left: 50%;
  top: 340px;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: max-content;
  height: 36px;
  transform: translateX(-50%);
}

.cases-filters button {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 4px 16px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  color: #a1a1aa;
  background: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  white-space: nowrap;
  transition: color 180ms var(--ease-out-quart), border-color 180ms var(--ease-out-quart);
}

.cases-filters button.is-active,
.cases-filters button:hover,
.cases-filters button:focus-visible {
  color: #27272a;
  border-color: #27272a;
  outline: none;
}

.cases-grid {
  position: absolute;
  left: 24px;
  top: 400px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 448px);
  gap: 24px;
  width: 1392px;
}

.case-card {
  position: relative;
  display: block;
  --case-card-reveal-y: 0px;
  --case-tilt-lift: 0px;
  --case-tilt-scale: 1;
  --case-tilt-x: 0deg;
  --case-tilt-y: 0deg;
  width: 448px;
  height: 360px;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 12px;
  color: inherit;
  background: #fafafa url("./assets/cases/card-bg.png") center / 100% 100% no-repeat;
  cursor: pointer;
  transform: perspective(1000px) translate3d(0, calc(var(--case-card-reveal-y) + var(--case-tilt-lift)), 0) rotateX(var(--case-tilt-x)) rotateY(var(--case-tilt-y)) scale(var(--case-tilt-scale));
  transform-origin: center center;
  transform-style: preserve-3d;
  will-change: transform;
  transition:
    border-color 220ms var(--ease-out-quart),
    box-shadow 220ms var(--ease-out-quart),
    transform 220ms var(--ease-out-quart),
    opacity 220ms var(--ease-out-quart);
}

.case-card:hover,
.case-card:focus-visible {
  --case-tilt-lift: -2px;
  --case-tilt-scale: 1.006;
  border-color: #e4e4e7;
  box-shadow: 0 10px 24px rgba(39, 39, 42, 0.055);
  outline: none;
}

.case-card.is-tilting {
  z-index: 3;
  box-shadow: 0 14px 28px rgba(39, 39, 42, 0.08), 0 3px 8px rgba(39, 39, 42, 0.045);
  transition:
    border-color 180ms var(--ease-out-quart),
    box-shadow 180ms var(--ease-out-quart),
    transform 90ms var(--ease-out-quart),
    opacity 180ms var(--ease-out-quart);
}

.case-card.is-tilting .case-card-image img {
  filter: saturate(1.02) contrast(1.01);
}

.case-card.is-hidden {
  display: none;
}

.case-card-image {
  display: block;
  width: 448px;
  height: 254px;
  overflow: hidden;
  border-radius: 12px 12px 0 0;
}

.case-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: filter 260ms var(--ease-out-quart);
}

.case-card h2 {
  margin: 16px 16px 0;
  overflow: hidden;
  color: #27272a;
  font-size: 20px;
  font-weight: 500;
  line-height: 30px;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-card p {
  display: -webkit-box;
  width: 416px;
  margin: 8px 16px 0;
  overflow: hidden;
  color: #a1a1aa;
  font-size: 12px;
  font-weight: 400;
  line-height: 18px;
  text-align: left;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.footer.cases-footer {
  left: 24px;
  top: var(--cases-footer-top, 1304px);
  width: 1392px;
}

html.case-modal-lock,
body.case-modal-open {
  overflow: hidden;
}

body.case-modal-open .global-notice {
  display: none;
}

.case-detail-body .global-notice {
  display: none;
}

.case-modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: grid;
  place-items: center;
  padding: 48px 24px;
  overflow: hidden;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  background: var(--modal-frost-bg);
  -webkit-backdrop-filter: var(--modal-frost-blur);
  backdrop-filter: var(--modal-frost-blur);
  transition: opacity 240ms var(--ease-out-quart), visibility 240ms var(--ease-out-quart);
}

.case-modal.is-open {
  pointer-events: auto;
  visibility: visible;
  opacity: 1;
}

.case-modal-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: transparent;
}

.case-detail-body {
  min-width: 0;
  overflow: hidden;
  background: rgba(39, 39, 42, 0.9);
}

.case-detail-page {
  display: grid;
  place-items: center;
  width: 100vw;
  min-height: 100vh;
  padding: 48px 24px;
}

.case-detail-shell {
  position: relative;
  width: 1392px;
  height: 774px;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 12px;
  background: #fff;
}

.case-detail-shell::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
  width: 224px;
  height: 100%;
  border-radius: 12px 0 0 12px;
  background: #fafafa;
  pointer-events: none;
}

.case-modal .case-detail-shell {
  z-index: 1;
  opacity: 0;
  transform: translate3d(0, 18px, 0) scale(0.985);
  transition: opacity 260ms var(--ease-out-quart), transform 320ms var(--ease-out-expo);
}

.case-modal.is-open .case-detail-shell {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.case-thumb-rail {
  position: absolute;
  left: 18px;
  top: 24px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 188px;
  height: 726px;
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-width: none;
}

.case-thumb-rail::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

.case-thumb-scrollbar {
  position: absolute;
  left: 218px;
  top: 24px;
  z-index: 2;
  width: 4px;
  height: 726px;
  overflow: hidden;
  pointer-events: none;
}

.case-thumb-scrollbar.is-hidden {
  display: none;
}

.case-thumb-scrollbar span {
  display: block;
  width: 4px;
  min-height: 32px;
  border-radius: 999px;
  background: #e4e4e7;
  transform: translate3d(0, 0, 0);
}

.case-thumb-divider {
  position: absolute;
  left: 224px;
  top: 0;
  z-index: 2;
  width: 1px;
  height: 774px;
  background: #f4f4f5;
  pointer-events: none;
}

.case-thumb {
  position: relative;
  width: 188px;
  height: 104px;
  flex: 0 0 104px;
  padding: 0;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 4px;
  background: transparent;
  opacity: 0.4;
  cursor: pointer;
  transition: opacity 180ms var(--ease-out-quart), border-color 180ms var(--ease-out-quart), box-shadow 180ms var(--ease-out-quart);
}

.case-thumb.is-loading {
  border-color: #f4f4f5;
  background: #f4f4f5;
  opacity: 1;
}

.case-thumb.is-active,
.case-thumb:hover,
.case-thumb:focus-visible {
  opacity: 1;
  border-color: #27272a;
  outline: none;
}

.case-thumb:focus-visible {
  box-shadow: 0 0 0 2px rgba(39, 39, 42, 0.16);
}

.case-thumb img {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 460ms cubic-bezier(0.22, 1, 0.36, 1);
}

.case-thumb.is-loaded img {
  opacity: 1;
}

.case-loading-skeleton {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  overflow: hidden;
  background: #f4f4f5;
  pointer-events: none;
}

.case-loading-skeleton::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(228, 228, 231, 0) 0%,
    rgba(250, 250, 250, 0) 34%,
    rgba(250, 250, 250, 0.72) 50%,
    rgba(250, 250, 250, 0) 66%,
    rgba(228, 228, 231, 0) 100%
  );
  transform: translateX(-120%);
  animation: case-skeleton-shimmer 1600ms cubic-bezier(0.45, 0, 0.25, 1) infinite;
  pointer-events: none;
}

@keyframes case-skeleton-shimmer {
  0% {
    transform: translateX(-120%);
  }

  100% {
    transform: translateX(120%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .case-loading-skeleton::after {
    animation: none;
    transform: translateX(0);
    opacity: 0.45;
  }
}

.case-slide-frame {
  position: absolute;
  left: 236px;
  top: 24px;
  z-index: 1;
  width: 1132px;
  height: 642px;
  margin: 0;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fafafa;
}

.case-slide-loader {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #f4f4f5;
  opacity: 0;
  transition: opacity 360ms cubic-bezier(0.22, 1, 0.36, 1);
  pointer-events: none;
}

.case-slide-frame.is-loading .case-slide-loader {
  opacity: 1;
}

.case-slide-frame img {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 520ms cubic-bezier(0.22, 1, 0.36, 1);
}

.case-slide-frame.is-loaded img {
  opacity: 1;
}

.case-detail-toolbar {
  position: absolute;
  left: 236px;
  top: 690px;
  z-index: 1;
  width: 1132px;
  height: 60px;
  border: 1px solid #f4f4f5;
  border-radius: 10px;
  background: #fafafa;
}

.case-detail-title {
  position: absolute;
  left: 16px;
  top: 15px;
  width: 408px;
  margin: 0;
  overflow: hidden;
  color: #27272a;
  font-size: 20px;
  font-weight: 500;
  line-height: 30px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.case-detail-toolbar button,
.case-detail-count {
  position: absolute;
  top: 12px;
  height: 36px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
}

.case-detail-prompt-toggle,
.case-detail-copy,
.case-detail-prev,
.case-detail-next,
.case-detail-close {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid #e4e4e7;
  color: #71717a;
  background: #fff;
  cursor: pointer;
  transition:
    color 180ms var(--ease-out-quart),
    border-color 180ms var(--ease-out-quart),
    background-color 180ms var(--ease-out-quart),
    opacity 180ms var(--ease-out-quart);
}

.case-detail-toolbar button img {
  transition: filter 180ms var(--ease-out-quart), opacity 180ms var(--ease-out-quart);
}

.case-detail-prev:hover img,
.case-detail-prev:focus-visible img,
.case-detail-next:hover img,
.case-detail-next:focus-visible img {
  filter: brightness(0) saturate(100%) invert(13%) sepia(6%) saturate(526%) hue-rotate(202deg) brightness(95%) contrast(90%);
}

.case-detail-copy img {
  filter: brightness(0) invert(1);
}

.case-detail-prompt-toggle {
  left: 460px;
  width: 144px;
}

.case-detail-copy {
  left: 616px;
  width: 144px;
  border-color: #27272a;
  color: #fff;
  background: #27272a;
}

.case-detail-count {
  left: 772px;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 84px;
  border: 1px solid #e4e4e7;
  color: #d4d4d8;
  background: #fff;
}

.case-detail-count strong {
  color: #27272a;
  font-weight: 500;
}

.case-detail-prev {
  left: 868px;
  width: 96px;
}

.case-detail-next {
  left: 976px;
  width: 96px;
}

.case-detail-close {
  left: 1084px;
  width: 36px;
  padding: 0;
  border-radius: 8px;
}

.case-detail-toolbar button img {
  width: 20px;
  height: 20px;
}

.case-detail-close img {
  width: 24px;
  height: 24px;
}

.case-detail-toolbar button:hover,
.case-detail-toolbar button:focus-visible {
  border-color: #27272a;
  color: #27272a;
  outline: none;
}

.case-detail-toolbar .case-detail-prompt-toggle:hover,
.case-detail-toolbar .case-detail-prompt-toggle:focus-visible {
  color: #27272a;
  border-color: #a1a1aa;
  background: #fff;
}

.case-detail-toolbar .case-detail-copy:hover,
.case-detail-toolbar .case-detail-copy:focus-visible {
  color: #fff;
  border-color: #18181b;
  background: #18181b;
}

.case-detail-close:hover {
  color: #fff;
  border-color: #27272a;
  background: #27272a;
  box-shadow: 0 6px 16px rgba(39, 39, 42, 0.1);
  transform: scale(1.05);
}

.case-detail-close:hover img {
  filter: brightness(0) invert(1);
}

.case-detail-close:active {
  transform: scale(0.97);
}

.case-detail-toolbar button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.case-prompt-panel {
  position: absolute;
  right: 24px;
  bottom: 96px;
  z-index: 4;
  width: 520px;
  max-height: 300px;
  overflow: auto;
  border: 1px solid #f4f4f5;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 48px rgba(39, 39, 42, 0.1);
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, 10px, 0) scale(0.98);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
  scrollbar-width: thin;
  scrollbar-color: #d4d4d8 transparent;
  transition: opacity 220ms var(--ease-out-quart), transform 260ms var(--ease-out-expo);
}

.case-prompt-panel.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
}

.case-prompt-panel::-webkit-scrollbar {
  width: 4px;
}

.case-prompt-panel::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: #d4d4d8;
}

.case-prompt-panel p {
  margin: 0;
  padding: 16px;
  color: #52525b;
  font-size: 13px;
  font-weight: 400;
  line-height: 24px;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .cases-body {
    min-width: 0;
    overflow-x: hidden;
  }

  .cases-page {
    width: 100vw;
    min-height: var(--cases-page-height, 1900px);
    overflow: hidden;
  }

  .cases-header-bg {
    width: 100vw;
  }

  .cases-header {
    left: 24px;
    width: calc(100vw - 48px);
  }

  .cases-top-search {
    left: auto;
    right: 142px;
  }

  .cases-download-wrap {
    left: auto;
    right: 0;
  }

  .cases-hero {
    position: relative;
    left: auto;
    top: auto;
    width: min(770px, calc(100vw - 48px));
    margin: 140px auto 0;
  }

  .cases-hero h1 {
    font-size: 42px;
    line-height: 54px;
  }

  .cases-hero p {
    width: min(684px, 100%);
  }

  .cases-title-accent {
    left: calc(100% + 12px);
  }

  .cases-filters {
    position: relative;
    left: auto;
    top: auto;
    flex-wrap: wrap;
    width: min(976px, calc(100vw - 48px));
    height: auto;
    margin: 80px auto 0;
    transform: none;
  }

  .cases-grid {
    position: relative;
    left: auto;
    top: auto;
    grid-template-columns: repeat(2, minmax(0, 448px));
    justify-content: center;
    width: min(976px, calc(100vw - 48px));
    margin: 24px auto 0;
  }

  .footer.cases-footer {
    position: relative;
    left: auto;
    top: auto;
    width: min(976px, calc(100vw - 48px));
    margin: 160px auto 0;
  }

  .case-detail-shell {
    width: min(1392px, calc(100vw - 48px));
    height: calc((min(1392px, calc(100vw - 48px))) * 0.556);
    min-height: 620px;
  }

  .case-detail-shell::before {
    width: 181px;
  }

  .case-thumb-rail {
    width: 148px;
  }

  .case-thumb-scrollbar {
    left: 176px;
  }

  .case-thumb-divider {
    left: 180px;
    height: 100%;
  }

  .case-thumb {
    width: 148px;
    height: 82px;
    flex-basis: 82px;
  }

  .case-slide-frame,
  .case-detail-toolbar {
    left: 188px;
    width: calc(100% - 212px);
  }

  .case-detail-title {
    width: 320px;
  }

  .case-detail-prompt-toggle {
    left: auto;
    right: 528px;
  }

  .case-detail-copy {
    left: auto;
    right: 372px;
  }

  .case-detail-count {
    left: auto;
    right: 276px;
  }

  .case-detail-prev {
    left: auto;
    right: 168px;
  }

  .case-detail-next {
    left: auto;
    right: 60px;
  }

  .case-detail-close {
    left: auto;
    right: 12px;
  }
}

@media (max-width: 767px) {
  .cases-body,
  .case-detail-body {
    min-width: 0;
    overflow-x: hidden;
  }

  .cases-page {
    width: 100vw;
    min-height: 0;
    padding: 16px 16px 24px;
    overflow: hidden;
  }

  .cases-header-bg {
    left: 0;
    top: 0;
    width: 100%;
    height: 300px;
    transform: none;
  }

  .cases-header {
    position: relative;
    left: auto;
    top: auto;
    z-index: 20;
    justify-content: space-between;
    width: calc(var(--mobile-page) - 32px);
    height: 32px;
    margin: 0 auto;
    gap: 0;
  }

  .cases-header .logo,
  .cases-header .logo-svg {
    width: 155px;
    height: 32px;
  }

  .cases-nav,
  .cases-top-search,
  .cases-download-wrap {
    display: none;
  }

  .cases-page .mobile-menu-toggle {
    right: 0;
    top: 0;
    z-index: 2;
    display: block;
  }

  .cases-hero {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    margin: 72px auto 0;
  }

  .cases-title-wrap {
    width: max-content;
    max-width: calc(100% - 44px);
  }

  .cases-hero h1 {
    display: block;
    width: 100%;
    font-size: 30px;
    line-height: 44px;
    white-space: normal;
  }

  .cases-title-line {
    white-space: nowrap;
  }

  .cases-title-mobile-break {
    display: block;
  }

  .cases-hero p {
    width: 100%;
    font-size: 14px;
    line-height: 24px;
  }

  .cases-title-accent {
    left: calc(100% - 28px);
    top: -12px;
    width: 36px;
    height: 36px;
  }

  .cases-filters {
    position: relative;
    left: auto;
    top: auto;
    justify-content: flex-start;
    width: var(--mobile-card-width);
    height: auto;
    margin: 40px auto 0;
    overflow-x: auto;
    padding-bottom: 4px;
    transform: none;
  }

  .cases-filters::-webkit-scrollbar {
    display: none;
  }

  .cases-grid {
    position: relative;
    left: auto;
    top: auto;
    grid-template-columns: 1fr;
    width: var(--mobile-card-width);
    margin: 24px auto 0;
  }

  .case-card {
    width: 100%;
    height: 322px;
    background-size: 100% 100%;
  }

  .case-card-image {
    width: 100%;
    height: 194px;
  }

  .case-card h2 {
    font-size: 18px;
    line-height: 28px;
  }

  .case-card p {
    width: calc(100% - 32px);
    -webkit-line-clamp: 3;
  }

  .footer.cases-footer {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width);
    max-width: var(--mobile-card-width);
    margin: 96px auto 0;
  }

  .case-modal,
  .case-detail-page {
    display: block;
    padding: 16px;
    overflow-y: auto;
  }

  .case-detail-shell {
    width: 100%;
    height: auto;
    min-height: calc(100vh - 32px);
    padding: 16px;
    overflow: visible;
  }

  .case-detail-shell::before {
    display: none;
  }

  .case-thumb-rail {
    position: static;
    flex-direction: row;
    width: 100%;
    height: 64px;
    overflow-x: auto;
    overflow-y: hidden;
    gap: 8px;
    margin-bottom: 12px;
  }

  .case-thumb-scrollbar,
  .case-thumb-divider {
    display: none;
  }

  .case-thumb {
    flex: 0 0 112px;
    width: 112px;
    height: 62px;
  }

  .case-slide-frame {
    position: static;
    width: 100%;
    height: auto;
    aspect-ratio: 1132 / 642;
  }

  .case-detail-toolbar {
    position: relative;
    left: auto;
    top: auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    width: 100%;
    height: auto;
    margin-top: 12px;
    padding: 12px;
  }

  .case-detail-title,
  .case-detail-toolbar button,
  .case-detail-count {
    position: static;
  }

  .case-detail-title {
    grid-column: 1 / -1;
    width: 100%;
    font-size: 18px;
    line-height: 28px;
  }

  .case-detail-prompt-toggle,
  .case-detail-copy,
  .case-detail-prev,
  .case-detail-next,
  .case-detail-count {
    width: 100%;
  }

  .case-detail-close {
    position: absolute;
    right: 12px;
    top: 12px;
    width: 36px;
  }

  .case-prompt-panel {
    position: static;
    width: 100%;
    max-height: 260px;
    margin-top: 12px;
    pointer-events: none;
    display: none;
  }

  .case-prompt-panel.is-open {
    display: block;
    pointer-events: auto;
  }
}

/* Responsive directory pages: inspiration / skills / cases */
.inspiration-body,
.skills-body,
.cases-body {
  overflow-x: hidden;
}

.inspiration-page,
.skills-page,
.cases-page {
  width: 100%;
  max-width: 1440px;
  min-width: 0;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .inspiration-page,
  .skills-page,
  .cases-page {
    padding-right: 24px;
    padding-left: 24px;
  }

  .inspiration-header,
  .skills-header,
  .cases-header {
    width: 100%;
  }

  .inspiration-hero,
  .skills-hero,
  .cases-hero {
    width: min(760px, 100%);
  }

  .inspiration-hero h1,
  .skills-hero h1,
  .cases-hero h1 {
    font-size: clamp(38px, 4.8vw, 48px);
    line-height: 1.25;
  }

  .inspiration-hero p,
  .skills-hero p,
  .cases-hero p {
    width: min(684px, 100%);
    margin-right: auto;
    margin-left: auto;
    white-space: normal;
  }

  .inspiration-filters,
  .skills-filters,
  .cases-filters {
    width: min(1392px, 100%);
    gap: 10px;
  }

  .skills-directory-controls .skills-filters {
    width: min(720px, calc(100vw - 180px));
  }

  .inspiration-grid,
  .skills-grid,
  .cases-grid {
    width: min(1392px, 100%);
    gap: 24px;
  }

  .inspiration-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 288px), 1fr));
  }

  .skills-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 298px), 1fr));
  }

  .cases-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  }

  .skill-card,
  .case-card {
    width: 100%;
  }

  .case-card {
    height: auto;
    min-height: 0;
    background-size: 100% 100%;
  }

  .case-card-image {
    width: 100%;
    height: auto;
    aspect-ratio: 448 / 254;
  }

  .case-card p {
    width: calc(100% - 32px);
  }

  .inspiration-footer,
  .footer.skills-footer,
  .footer.cases-footer {
    width: min(1392px, 100%);
  }

  .inspiration-page .inspiration-footer,
  .inspiration-footer {
    left: auto;
    top: auto;
  }
}

@media (min-width: 1180px) and (max-width: 1439px) {
  .inspiration-grid {
    grid-template-columns: repeat(auto-fit, minmax(276px, 1fr));
  }
}

@media (min-width: 768px) and (max-width: 900px) {
  .inspiration-page,
  .skills-page,
  .cases-page {
    padding-right: 16px;
    padding-left: 16px;
  }

  .inspiration-header,
  .skills-header,
  .cases-header {
    width: 100%;
  }

  .inspiration-header .inspiration-search,
  .skills-top-search,
  .cases-top-search {
    display: none;
  }

  .inspiration-grid,
  .skills-grid,
  .cases-grid {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .inspiration-page,
  .skills-page,
  .cases-page {
    min-height: 100dvh;
  }

  .inspiration-filters,
  .skills-filters,
  .cases-filters {
    scroll-padding-inline: 16px;
  }

  .inspiration-grid,
  .skills-grid,
  .cases-grid {
    gap: 16px;
  }

  .prompt-card,
  .skill-card,
  .case-card {
    transform: translate3d(0, 0, 0);
  }

  .skill-card-meta {
    gap: 16px;
  }

  .case-card {
    min-height: 0;
  }

  .case-card-image {
    aspect-ratio: 448 / 254;
  }

  .inspiration-page .inspiration-footer,
  .inspiration-footer {
    left: auto;
    top: auto;
  }
}

@media (max-width: 1439px) {
  .inspiration-grid {
    position: relative;
    inset: auto;
    display: block;
    width: min(1392px, 100%);
    height: var(--inspiration-grid-height, auto);
    margin: 24px auto 0;
    overflow: visible;
    transition: height 420ms var(--ease-out-expo);
  }

  .prompt-card {
    position: absolute;
    left: var(--x);
    top: var(--y);
    width: var(--card-w, 330px);
    height: var(--h);
    min-height: 0;
    padding-bottom: 0;
  }

  .prompt-card-tilt {
    position: absolute;
    inset: 0;
    transform: none !important;
  }

  .prompt-card-image {
    display: block;
    width: 100%;
    height: var(--ih);
    aspect-ratio: auto !important;
    object-fit: cover;
  }

  .prompt-card h2 {
    position: absolute;
    left: 16px;
    top: calc(var(--ih) + 16px);
    width: calc(100% - 32px);
    margin: 0;
  }

  .prompt-card p {
    position: absolute;
    left: 16px;
    top: calc(var(--ih) + 54px);
    width: calc(100% - 32px);
    margin: 0;
  }

  .prompt-actions {
    position: absolute;
    left: 16px;
    bottom: 16px;
    width: calc(100% - 32px);
    margin: 0;
  }

  .prompt-actions button {
    flex: 1 1 0;
    width: auto;
  }
}

@media (max-width: 767px) {
  .inspiration-grid {
    margin-top: -22px;
  }
}

@media (max-width: 1439px) {
  .skills-agent-strip {
    position: relative;
    left: 50%;
    right: auto;
    width: min(612px, calc(100vw - 48px));
    margin-right: 0;
    margin-left: 0;
    transform: translateX(-50%);
  }

  .skills-agent-marquee {
    margin-right: auto;
    margin-left: auto;
  }
}

@media (max-width: 767px) {
  .skills-agent-strip {
    width: var(--mobile-card-width);
    transform: translateX(-50%);
  }

  .skills-agent-marquee {
    width: min(100%, 320px);
  }
}

@media (min-width: 1440px) {
  :root {
    --site-header-top: 24px;
    --site-header-height: 36px;
    --site-logo-width: 155px;
    --site-logo-height: 32px;
    --site-nav-left: 209px;
    --site-nav-top: 0;
    --site-nav-width: 264px;
    --site-nav-gap: 24px;
    --site-search-left: 986px;
    --site-search-width: 264px;
    --site-download-left: 1274px;
    --site-download-width: 118px;
    --site-control-height: 36px;
  }

  .site-header {
    position: absolute;
    top: var(--site-header-top);
    z-index: 20;
    display: flex;
    align-items: center;
    gap: 48px;
    width: var(--content);
    height: var(--site-header-height);
    contain: layout style;
  }

  .hero-header.site-header,
  .policy-header.site-header,
  .workbench-page .site-header {
    left: var(--side);
  }

  .inspiration-page > .site-header,
  .skills-page > .site-header,
  .cases-page > .site-header {
    left: 24px;
  }

  .site-header .logo {
    display: block;
    flex: 0 0 auto;
    width: var(--site-logo-width);
    height: var(--site-logo-height);
  }

  .site-header .logo-svg {
    width: var(--site-logo-width);
    height: var(--site-logo-height);
  }

  .site-header .site-nav {
    position: absolute;
    left: var(--site-nav-left);
    top: var(--site-nav-top);
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: var(--site-nav-gap);
    width: var(--site-nav-width);
    height: var(--site-control-height);
    font-size: 16px;
    line-height: 24px;
    transform: none;
  }

  .site-header .site-nav a {
    display: flex;
    align-items: center;
    height: 24px;
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .site-header .site-nav a::after {
    background-image: url("./assets/inspiration/nav-underline.svg");
  }

  .site-header .site-header-search {
    position: absolute;
    left: var(--site-search-left);
    top: 0;
    width: var(--site-search-width);
    height: var(--site-control-height);
  }

  .site-header .site-header-download {
    position: absolute;
    left: var(--site-download-left);
    top: 0;
    width: var(--site-download-width);
    height: var(--site-control-height);
  }

  .site-header .site-header-download .download {
    width: var(--site-download-width);
    height: var(--site-control-height);
    border-radius: 6px;
    font-size: 14px;
    line-height: 16px;
  }

  .site-header .site-header-download .download-menu {
    left: auto;
    right: 0;
    top: 48px;
    transform-origin: top right;
  }

  body.page-enter .site-header,
  body.page-navigating .site-header {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

@media (max-width: 767px) {
  body.workbench-page {
    --workbench-mobile-gutter: 16px;
    --workbench-mobile-content: calc(100vw - 32px);
    overflow-x: hidden;
    padding-top: 0;
  }

  body.workbench-page.notice-hidden {
    padding-top: 0;
  }

  body.workbench-page .global-notice {
    position: relative;
    width: 100%;
    min-width: 0;
  }

  .workbench-page .workbench {
    display: flow-root;
    overflow-x: hidden;
    width: 100%;
    margin: 0;
  }

  .workbench-page .site-header,
  .workbench-page .inspiration-header {
    position: relative;
    left: 0;
    right: auto;
    top: auto;
    box-sizing: border-box;
    width: var(--workbench-mobile-content);
    margin: 16px auto 0;
    padding: 0;
  }

  .workbench-page .site-header .logo,
  .workbench-page .site-header .logo-svg {
    display: block;
    width: 155px;
    height: 32px;
  }

  .workbench-page .mobile-menu-toggle {
    right: 0;
    top: 0;
  }

  .workbench-page .workbench-tools,
  .workbench-page .workbench-feature,
  .workbench-page .workbench-cta,
  .workbench-page .workbench-footer,
  .workbench-page .footer.workbench-shared-footer {
    width: var(--workbench-mobile-content);
    margin-right: auto;
    margin-left: auto;
  }

  .workbench-page .workbench-hero {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-left: 0;
    padding-right: var(--workbench-mobile-gutter);
    padding-left: var(--workbench-mobile-gutter);
  }

  .workbench-page .workbench-hero-copy {
    width: 100%;
    margin-right: 0;
    margin-left: 0;
    padding-left: 0;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .workbench-page .workbench-hero-copy {
    width: min(684px, 100%);
    margin-right: auto;
    margin-left: auto;
    padding-left: 0;
    text-align: left;
  }

  .workbench-page .workbench-hero-copy > p:not(.workbench-kicker) {
    width: 100%;
  }

  .workbench-page .workbench-hero-copy > p:not(.workbench-kicker) br {
    display: none;
  }

  .workbench-page .workbench-workflow {
    height: auto;
    min-height: 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }

  .workbench-page .workbench-workflow .workbench-feature-copy {
    padding-top: 0;
  }

  .workbench-page .workbench-workflow-sticky {
    position: relative;
    top: auto;
    min-height: 0;
  }

  .workbench-page .workbench-steps {
    margin-top: 16px;
  }

  .workbench-page .workbench-cta {
    margin-top: 24px;
  }

  .workbench-page .workbench-workflow + .workbench-cta {
    margin-top: 24px;
  }
}

@media (max-width: 767px) {
  .workbench-page .workbench-tool-card {
    box-sizing: border-box;
    padding-bottom: 16px;
  }

  .workbench-page .workbench-tool-card p {
    margin-bottom: 0;
  }

  .workbench-page .footer.workbench-shared-footer {
    height: 604px;
    margin-top: 20px;
    margin-bottom: 40px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-art {
    height: 500px;
    border-radius: 12px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-cta {
    left: 12px;
    top: 12px;
    width: calc(100% - 24px);
    height: 136px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 8px;
    background: rgba(39, 39, 42, 0.16);
  }

  .workbench-page .footer.workbench-shared-footer .footer-copy {
    left: 12px;
    top: 12px;
    width: calc(100% - 24px);
  }

  .workbench-page .footer.workbench-shared-footer .footer-copy p {
    width: 100%;
    font-size: 13px;
    line-height: 20px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-actions {
    left: 12px;
    right: auto;
    top: 88px;
    gap: 12px;
    width: calc(100% - 24px);
    height: 36px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-actions > * {
    flex: 1 1 0;
    width: auto;
    min-width: 0;
  }

  .workbench-page .footer.workbench-shared-footer .footer-download,
  .workbench-page .footer.workbench-shared-footer .footer-top-button {
    width: 100%;
    height: 36px;
    font-size: 14px;
    line-height: 20px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-wordmark {
    display: block;
    left: 16px;
    top: 402px;
    width: calc(100% - 32px);
    height: 60px;
    opacity: 1;
  }
}

@media (min-width: 1010px) and (max-width: 1424px) {
  .workbench-page .workbench-workflow {
    height: auto;
    min-height: 0;
    margin-bottom: 0;
    padding-bottom: 0;
  }

  .workbench-page .workbench-workflow .workbench-feature-copy {
    padding-top: 0;
  }

  .workbench-page .workbench-workflow-sticky {
    position: relative;
    top: auto;
    min-height: 0;
  }

  .workbench-page .workbench-steps {
    margin-top: 16px;
  }

  .workbench-page .workbench-cta {
    margin-top: 24px;
  }

  .workbench-page .workbench-workflow + .workbench-cta {
    margin-top: 24px;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .workbench-page .workbench-cta {
    height: 320px;
    aspect-ratio: auto;
    margin-top: 24px;
  }

  .workbench-page .workbench-cta.reveal-item {
    opacity: 1;
    transform: none;
  }

  .workbench-page .workbench-workflow + .workbench-cta {
    margin-top: 24px;
  }

  .workbench-page .workbench-cta > p {
    left: 44px;
    top: 72px;
    font-size: 24px;
    line-height: 24px;
  }

  .workbench-page .workbench-cta h2 {
    left: 44px;
    top: 114px;
    width: calc(100% - 88px);
    font-size: clamp(40px, 5.4vw, 48px);
    line-height: 60px;
  }

  .workbench-page .workbench-cta-art-large {
    left: calc(64% - 24px);
    top: 0;
    width: 320px;
    height: 320px;
  }

  .workbench-page .workbench-cta-art-small-frame {
    left: calc(43% + 40px);
    top: 116px;
    display: flex;
    width: 210px;
    height: 210px;
  }

  .workbench-page .workbench-cta-art-small-img {
    width: 164px;
    height: 164px;
  }
}

/* Inspiration gallery merged with cases: design update 2026-06-03 */
@media (min-width: 1440px) {
  .inspiration-page > .site-header .site-nav {
    width: 264px;
  }

  .inspiration-page > .site-header .site-header-search {
    left: 1010px;
  }

  .inspiration-page > .site-header .site-header-download {
    left: 1298px;
  }

  .inspiration-mode-tabs {
    left: 24px;
    top: 366px;
  }

  .inspiration-filters {
    left: auto;
    right: var(--side);
    top: 366px;
    justify-content: flex-end;
    width: max-content;
    max-width: calc(var(--content) - 240px);
    overflow: visible;
  }
}

@media (min-width: 768px) and (max-width: 1439px) {
  .inspiration-hero {
    margin-top: 88px;
  }

  .inspiration-title-wrap,
  .inspiration-kicker {
    width: min(760px, 100%);
  }

  .inspiration-mode-tabs {
    position: relative;
    left: auto;
    top: auto;
    width: min(1392px, 100%);
    margin: 44px auto 0;
  }

  .inspiration-filters {
    position: relative;
    left: auto;
    top: auto;
    justify-content: flex-start;
    width: min(1392px, 100%);
    max-width: 100%;
    height: auto;
    margin: 18px auto 0;
    overflow-x: auto;
    transform: none;
    scrollbar-width: none;
  }

  .inspiration-filters::-webkit-scrollbar {
    display: none;
  }
}

@media (max-width: 767px) {
  .inspiration-title-wrap,
  .inspiration-kicker {
    width: 100%;
  }

  .inspiration-kicker {
    margin-bottom: 10px;
    font-size: 22px;
    line-height: 24px;
  }

  .inspiration-mode-tabs {
    position: relative;
    left: auto;
    top: auto;
    width: var(--mobile-card-width, calc(100vw - 32px));
    height: 50px;
    margin: 36px auto 0;
    gap: 22px;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none;
  }

  .inspiration-mode-tabs::-webkit-scrollbar {
    display: none;
  }

  .inspiration-mode-tabs button {
    height: 34px;
    font-size: 22px;
    line-height: 34px;
  }

  .inspiration-mode-tabs button::after {
    top: 34px;
  }

  .inspiration-filters {
    position: relative;
    left: auto;
    top: auto;
    justify-content: flex-start;
    width: var(--mobile-card-width, calc(100vw - 32px));
    max-width: none;
    height: auto;
    margin: 14px auto 0;
    overflow-x: auto;
    transform: none;
    scrollbar-width: none;
  }

  .inspiration-filters::-webkit-scrollbar {
    display: none;
  }
}

.inspiration-page.inspiration-mode-cases .prompt-card--case h2 {
  display: block;
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.inspiration-page.inspiration-mode-cases .prompt-card--case p {
  display: -webkit-box;
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.inspiration-page.inspiration-mode-cases .prompt-card--case .prompt-actions {
  display: none !important;
}

/* ASCII editor app */
.ascii-editor-page {
  min-width: 1180px;
  min-height: 100vh;
  margin: 0;
  padding-top: 0;
  overflow: hidden;
  background: #fafafa;
  color: #27272a;
  font-family: "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

.ascii-editor-page *,
.ascii-editor-page *::before,
.ascii-editor-page *::after {
  box-sizing: border-box;
}

.ascii-app {
  position: relative;
  width: 100vw;
  height: 100vh;
  min-height: 720px;
  overflow: hidden;
  background-color: #fafafa;
}

.ascii-app::before {
  position: absolute;
  inset: 0;
  z-index: 0;
  content: "";
  background-image: radial-gradient(circle, rgba(161, 161, 170, 0.26) 1px, transparent 1px);
  background-position: 0 0;
  background-size: 16px 16px;
  pointer-events: none;
}

.ascii-tool-rail {
  position: absolute;
  left: 24px;
  top: 50%;
  z-index: 20;
  display: flex;
  width: 48px;
  height: 256px;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 8px;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 44px rgba(24, 24, 27, 0.08);
  transform: translateY(-50%);
}

.ascii-tool-rail::after {
  position: absolute;
  top: 47px;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background: #f4f4f5;
}

.ascii-logo-button,
.ascii-tool-button {
  position: relative;
  z-index: 1;
  display: grid;
  width: 32px;
  height: 32px;
  place-items: center;
  border: 0;
  border-radius: 5px;
  background: transparent;
  color: #a1a1aa;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.16s ease, color 0.16s ease;
}

.ascii-logo-button {
  margin-bottom: 8px;
}

.ascii-logo-button img {
  width: 32px;
  height: 32px;
  object-fit: contain;
}

.ascii-rail-img {
  display: block;
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.ascii-tool-rail > .ascii-tool-button:nth-child(4) .ascii-rail-img,
.ascii-tool-rail > .ascii-tool-button:nth-child(5) .ascii-rail-img {
  transform: translateX(-2px);
}

.ascii-tool-rail > .ascii-tool-button:nth-child(6) .ascii-rail-img {
  width: 20px;
  height: 20px;
}

.ascii-tool-button:hover,
.ascii-tool-button:focus-visible {
  background: #f4f4f5;
  color: #52525b;
  outline: none;
}

.ascii-tool-button.is-active {
  background: #27272a;
  color: #fff;
}

.ascii-tool-button:disabled {
  cursor: default;
}

.ascii-rail-toast,
.ascii-rail-menu {
  position: absolute;
  left: calc(100% + 10px);
  z-index: 4;
  border: 1px solid rgba(228, 228, 231, 0.9);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 16px 44px rgba(24, 24, 27, 0.1);
  -webkit-backdrop-filter: blur(16px);
  backdrop-filter: blur(16px);
}

.ascii-rail-toast {
  top: var(--rail-toast-top, 56px);
  display: flex;
  height: 32px;
  align-items: center;
  padding: 0 10px;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  opacity: 0;
  pointer-events: none;
  white-space: nowrap;
  transform: translate3d(-4px, 0, 0) scale(0.98);
  transition: opacity 0.16s ease, transform 0.18s var(--ease-out-expo), top 0.18s var(--ease-out-expo);
}

.ascii-rail-toast.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.ascii-rail-menu {
  top: 206px;
  display: grid;
  min-width: 124px;
  padding: 4px;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(-4px, 0, 0) scale(0.98);
  transform-origin: left center;
  transition: opacity 0.16s ease, transform 0.18s var(--ease-out-expo);
}

.ascii-rail-menu.is-open {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
}

.ascii-rail-menu a,
.ascii-rail-menu button {
  display: flex;
  width: 100%;
  height: 32px;
  align-items: center;
  padding: 0 10px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  text-align: left;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
}

.ascii-rail-menu a:hover,
.ascii-rail-menu a:focus-visible,
.ascii-rail-menu button:hover,
.ascii-rail-menu button:focus-visible {
  background: #f4f4f5;
  color: #27272a;
  outline: none;
}

.ascii-stage {
  position: absolute;
  inset: 24px 324px 24px 0;
  z-index: 1;
  display: grid;
  place-items: center;
  overflow: visible;
}

.ascii-stage::before {
  display: none;
}

.ascii-stage::after {
  display: none;
  content: "";
}

.ascii-canvas-arrow {
  position: absolute;
  left: calc(50% + 3px);
  top: calc(50% + 92px);
  z-index: 1;
  display: block;
  width: 172px;
  height: 120px;
  border: 0;
  opacity: 1;
  pointer-events: none;
  transform: scaleX(-1);
}

.ascii-stage.has-source .ascii-canvas-arrow {
  display: none;
}

.ascii-output,
.ascii-mask-layer,
.ascii-crop-layer {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  max-width: min(100%, 1040px);
  max-height: min(100%, 760px);
  border-radius: 8px;
  transform: translate(-50%, -50%);
}

.ascii-output.has-source {
  box-shadow: 0 22px 70px rgba(24, 24, 27, 0.12);
}

.ascii-mask-layer {
  z-index: 5;
  display: none;
  cursor: crosshair;
}

.ascii-mask-layer.is-active {
  display: block;
}

.ascii-crop-layer {
  z-index: 6;
  display: none;
  cursor: default;
  touch-action: none;
}

.ascii-crop-layer.is-active {
  display: block;
}

.ascii-crop-box {
  position: absolute;
  display: none;
  border: 1px solid #e879f9;
  background: rgba(232, 121, 249, 0.12);
  cursor: move;
  pointer-events: auto;
  touch-action: none;
}

.ascii-crop-shade {
  position: absolute;
  display: none;
  background: rgba(24, 24, 27, 0.18);
  pointer-events: none;
}

.ascii-crop-layer.is-active .ascii-crop-shade {
  display: block;
}

.ascii-crop-box.is-visible {
  display: block;
}

.ascii-crop-box::before {
  position: absolute;
  inset: 8px;
  border: 1px dashed rgba(255, 255, 255, 0.72);
  content: "";
  pointer-events: none;
}

.ascii-crop-handle {
  position: absolute;
  display: block;
  width: 10px;
  height: 10px;
  border: 2px solid #e879f9;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 8px rgba(24, 24, 27, 0.18);
}

.ascii-crop-handle-nw {
  top: -6px;
  left: -6px;
  cursor: nwse-resize;
}

.ascii-crop-handle-ne {
  top: -6px;
  right: -6px;
  cursor: nesw-resize;
}

.ascii-crop-handle-sw {
  bottom: -6px;
  left: -6px;
  cursor: nesw-resize;
}

.ascii-crop-handle-se {
  right: -6px;
  bottom: -6px;
  cursor: nwse-resize;
}

.ascii-hidden-media,
#ascii-file-input {
  display: none;
}

.ascii-drop-zone {
  position: relative;
  z-index: 4;
  display: flex;
  width: 260px;
  flex-direction: column;
  align-items: center;
  gap: 0;
  border: 0;
  background: transparent;
  color: #a1a1ab;
  cursor: pointer;
  transform: translateY(-20px);
}

.ascii-drop-zone.is-hidden {
  display: none;
}

.ascii-drop-zone.drag-over {
  color: #27272a;
}

.ascii-drop-icon {
  display: block;
  width: 60px;
  height: 60px;
  margin-bottom: 12px;
  object-fit: contain;
}

.ascii-drop-title {
  color: #a1a1ab;
  font-size: 20px;
  font-weight: 400;
}

.ascii-drop-subtitle {
  color: #a1a1ab;
  font-size: 14px;
  font-weight: 400;
  margin-top: 4px;
}

.ascii-canvas-actions {
  position: absolute;
  bottom: 24px;
  left: 50%;
  z-index: 8;
  display: flex;
  max-width: min(980px, calc(100% - 48px));
  min-height: 48px;
  align-items: center;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 6px;
  padding: 7px;
  border: 1px solid rgba(228, 228, 231, 0.86);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 16px 44px rgba(24, 24, 27, 0.08);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  backdrop-filter: blur(18px);
}

.ascii-stage.has-source .ascii-canvas-actions {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.ascii-canvas-actions button,
.ascii-canvas-actions select,
.ascii-secondary-button {
  min-height: 30px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fff;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  cursor: pointer;
}

.ascii-toolbar-group {
  display: inline-flex;
  height: 32px;
  align-items: center;
  gap: 4px;
  padding: 1px;
  border: 1px solid #f4f4f5;
  border-radius: 7px;
  background: #fafafa;
  white-space: nowrap;
}

.ascii-toolbar-group button {
  min-width: 48px;
  height: 28px;
  min-height: 28px;
  padding: 0 10px;
  border-color: transparent;
  background: transparent;
}

.ascii-toolbar-group button:hover,
.ascii-toolbar-group button:focus-visible {
  border-color: #e4e4e7;
  background: #fff;
  outline: none;
}

.ascii-canvas-actions select {
  height: 28px;
  min-height: 28px;
  min-width: 70px;
  padding: 0 24px 0 8px;
  appearance: none;
  background-image: url("./assets/ascii-editor/icons/chevron.svg?v=20260602-panel-icons-1222");
  background-position: right 6px center;
  background-size: 14px 14px;
  background-repeat: no-repeat;
}

.ascii-canvas-actions button.is-active {
  border-color: #e879f9;
  background: #fff;
  color: #27272a;
  box-shadow: 0 0 0 2px rgba(232, 121, 249, 0.16);
}

.ascii-canvas-actions .ascii-video-tool {
  display: none;
}

.ascii-stage.is-video-source .ascii-canvas-actions .ascii-video-tool {
  display: inline-flex;
}

.ascii-toolbar-field,
.ascii-video-speed {
  display: inline-flex;
  height: 32px;
  min-height: 32px;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid #f4f4f5;
  border-radius: 7px;
  background: #fafafa;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  white-space: nowrap;
}

.ascii-video-speed {
  height: 28px;
  min-height: 28px;
  padding: 0 0 0 8px;
  border: 0;
  background: transparent;
}

.ascii-video-fps {
  display: inline-flex;
  height: 28px;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 8px;
  border-left: 1px solid #e4e4e7;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
}

.ascii-video-progress input {
  width: 180px;
  height: 4px;
  margin: 0;
  appearance: none;
  border-radius: 4px;
  background: linear-gradient(to right, #e879f9 0 var(--video-progress, 0%), #f4f4f5 var(--video-progress, 0%) 100%);
}

.ascii-video-progress input::-webkit-slider-runnable-track {
  height: 4px;
  border-radius: 4px;
  background: transparent;
}

.ascii-video-progress input::-webkit-slider-thumb {
  width: 8px;
  height: 8px;
  margin-top: -2px;
  appearance: none;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 2px #e879f9;
}

.ascii-video-progress input::-moz-range-track {
  height: 4px;
  border-radius: 4px;
  background: transparent;
}

.ascii-video-progress input::-moz-range-thumb {
  width: 8px;
  height: 8px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 2px #e879f9;
}

.ascii-canvas-actions button:hover,
.ascii-secondary-button:hover {
  border-color: #d4d4d8;
  color: #27272a;
}

.ascii-panel {
  position: absolute;
  top: 24px;
  right: 24px;
  bottom: 24px;
  z-index: 25;
  display: flex;
  height: auto;
  max-height: none;
  flex-direction: column;
  width: 312px;
  overflow: hidden;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 16px 44px rgba(24, 24, 27, 0.08);
}

.ascii-panel-scroll {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #d4d4d8 transparent;
}

.ascii-panel-scroll::-webkit-scrollbar {
  width: 4px;
}

.ascii-panel-scroll::-webkit-scrollbar-thumb {
  border-radius: 3px;
  background: #d4d4d8;
}

.ascii-panel-header {
  z-index: 2;
  display: flex;
  flex: 0 0 48px;
  height: 48px;
  align-items: center;
  justify-content: space-between;
  padding: 0 12px;
  border-bottom: 1px solid #f4f4f5;
  background: #fff;
}

.ascii-panel-header h1 {
  margin: 0;
  color: #27272a;
  font-size: 16px;
  font-weight: 600;
}

.ascii-panel-header a {
  display: grid;
  width: 24px;
  height: 24px;
  place-items: center;
  border: 1px solid #f4f4f5;
  border-radius: 4px;
  color: #a1a1aa;
  text-decoration: none;
  transition: border-color 0.16s ease, background 0.16s ease, transform 0.16s ease;
}

.ascii-panel-header a:hover,
.ascii-panel-header a:focus-visible {
  border-color: #e4e4e7;
  background: #f4f4f5;
  outline: none;
  transform: translateY(-1px);
}

.ascii-panel-header a img {
  display: block;
  width: 16px;
  height: 16px;
}

.ascii-panel-section {
  padding: 12px;
  border-bottom: 1px solid #f4f4f5;
}

.ascii-panel-scroll > .ascii-panel-section:last-child {
  border-bottom: 0;
}

.ascii-panel-section:nth-of-type(2) {
  padding-bottom: 20px;
}

.ascii-panel-section h2 {
  margin: 0 0 12px;
  color: #8f8f99;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.ascii-source-section {
  padding-bottom: 14px;
}

.ascii-image-section {
  min-height: 136px;
}

.ascii-image-section h2 {
  display: none;
}

.ascii-image-section .ascii-control-line:first-of-type {
  margin-top: 0;
}

.ascii-upload-box {
  display: flex;
  width: 100%;
  height: 104px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background: #fafafa;
  color: #a1a1aa;
  font: 400 14px/20px "IBM Plex Sans SC", sans-serif;
  cursor: pointer;
  transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.ascii-upload-box:hover,
.ascii-upload-box:focus-visible {
  border-color: #e4e4e7;
  background: #f4f4f5;
  color: #71717a;
  outline: none;
  transform: translateY(-1px);
}

.ascii-upload-box span:first-child {
  font-size: 0;
}

.ascii-upload-icon {
  display: block;
  width: 24px;
  height: 24px;
  object-fit: contain;
}

.ascii-export-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 10px;
}

.ascii-export-row select,
.ascii-export-scale-row select,
.ascii-control-line select,
.ascii-control-line input[type="text"] {
  width: 100%;
  min-height: 32px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fff;
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  transition: border-color 0.16s ease, background-color 0.16s ease, box-shadow 0.16s ease;
}

.ascii-export-row select,
.ascii-export-scale-row select,
.ascii-control-line select {
  padding: 0 28px 0 8px;
  appearance: none;
  background-image: url("./assets/ascii-editor/icons/chevron.svg?v=20260602-panel-icons-1222");
  background-position: right 8px center;
  background-size: 16px 16px;
  background-repeat: no-repeat;
}

.ascii-export-row select:hover,
.ascii-export-scale-row select:hover,
.ascii-control-line select:hover,
.ascii-control-line input[type="text"]:hover {
  border-color: #d4d4d8;
  background-color: #fafafa;
}

.ascii-export-row select:focus-visible,
.ascii-export-scale-row select:focus-visible,
.ascii-control-line select:focus-visible,
.ascii-control-line input[type="text"]:focus-visible {
  border-color: #d4d4d8;
  outline: none;
  box-shadow: 0 0 0 2px rgba(24, 24, 27, 0.06);
}

.ascii-export-scale-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  color: #52525b;
  font-size: 13px;
  font-weight: 500;
}

.ascii-control-line input[type="text"] {
  padding: 0 8px;
  font-family: "SF Mono", "Menlo", monospace;
  font-size: 12px;
}

.ascii-export-button {
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  gap: 4px;
  border: 0;
  border-radius: 6px;
  background: #27272a;
  color: #fff;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  cursor: pointer;
  transition: background 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}

.ascii-export-button:hover,
.ascii-export-button:focus-visible {
  background: #18181b;
  outline: none;
  box-shadow: 0 10px 24px rgba(24, 24, 27, 0.14);
  transform: translateY(-1px);
}

.ascii-export-button img {
  width: 16px;
  height: 16px;
}

.ascii-preset-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.ascii-preset-grid button {
  overflow: hidden;
  height: 70px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 4px;
  background: #f4f4f5;
  cursor: pointer;
  transition: border-color 0.16s ease, box-shadow 0.16s ease, transform 0.16s ease;
}

.ascii-preset-grid button:hover,
.ascii-preset-grid button:focus-visible {
  border-color: #e4e4e7;
  outline: none;
  transform: translateY(-1px);
}

.ascii-preset-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.18s ease;
}

.ascii-preset-grid button:hover img {
  transform: scale(1.04);
}

.ascii-preset-grid button.is-selected {
  border-color: #e879f9;
  box-shadow: 0 0 0 2px rgba(232, 121, 249, 0.18);
}

.ascii-control-line,
.ascii-slider-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  align-items: center;
  gap: 8px;
  min-height: 32px;
  margin-top: 10px;
  color: #52525b;
  font-size: 13px;
  font-weight: 500;
}

.ascii-slider-row {
  grid-template-columns: 72px 1fr 34px;
}

.ascii-slider-row input[type="range"] {
  width: 100%;
  height: 4px;
  margin: 0;
  appearance: none;
  border-radius: 4px;
  background: linear-gradient(to right, #e879f9 0 var(--range-progress, 0%), #f4f4f5 var(--range-progress, 0%) 100%);
  accent-color: #e879f9;
}

.ascii-slider-row input[type="range"]::-webkit-slider-runnable-track {
  height: 4px;
  border-radius: 4px;
  background: transparent;
}

.ascii-slider-row input[type="range"]::-webkit-slider-thumb {
  width: 8px;
  height: 8px;
  margin-top: -2px;
  appearance: none;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 2px #e879f9;
}

.ascii-slider-row input[type="range"]::-moz-range-track {
  height: 4px;
  border-radius: 4px;
  background: transparent;
}

.ascii-slider-row input[type="range"]::-moz-range-thumb {
  width: 8px;
  height: 8px;
  border: 0;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 2px #e879f9;
}

.ascii-slider-row output {
  color: #a1a1aa;
  font-size: 11px;
  font-weight: 400;
  text-align: right;
}

.ascii-switch-grid,
.ascii-effect-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  margin-top: 8px;
}

.ascii-switch-grid label,
.ascii-effect-grid label {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 28px;
  min-height: 30px;
  align-items: center;
  padding-right: 36px;
  color: #52525b;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: color 0.16s ease, background 0.16s ease;
}

.ascii-switch-grid input,
.ascii-effect-grid input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ascii-switch-grid label::before,
.ascii-switch-grid label::after,
.ascii-effect-grid label::before,
.ascii-effect-grid label::after {
  position: absolute;
  content: "";
}

.ascii-switch-grid label::before,
.ascii-effect-grid label::before {
  right: 0;
  top: 50%;
  width: 28px;
  height: 16px;
  border-radius: 999px;
  background: #e4e4e7;
  transform: translateY(-50%);
  transition: background 0.16s ease, box-shadow 0.16s ease;
}

.ascii-switch-grid label::after,
.ascii-effect-grid label::after {
  right: 14px;
  top: 50%;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  transform: translateY(-50%);
  transition: right 0.16s ease, background 0.16s ease;
}

.ascii-switch-grid label:has(input:checked),
.ascii-effect-grid label:has(input:checked) {
  color: #27272a;
}

.ascii-switch-grid label:has(input:checked)::before,
.ascii-effect-grid label:has(input:checked)::before {
  background: #e879f9;
}

.ascii-switch-grid label:has(input:checked)::after,
.ascii-effect-grid label:has(input:checked)::after {
  right: 2px;
}

.ascii-switch-grid label:hover,
.ascii-switch-grid label:focus-within,
.ascii-effect-grid label:hover,
.ascii-effect-grid label:focus-within {
  color: #27272a;
}

.ascii-switch-grid label:hover::before,
.ascii-switch-grid label:focus-within::before,
.ascii-effect-grid label:hover::before,
.ascii-effect-grid label:focus-within::before {
  box-shadow: 0 0 0 3px rgba(24, 24, 27, 0.06);
}

.ascii-light-section {
  padding-top: 12px;
}

.ascii-light-section > h2:first-child {
  margin-bottom: 10px;
  color: #8f8f99;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0;
}

.ascii-light-enable-row {
  display: grid;
  grid-template-columns: 72px 1fr;
  min-height: 32px;
  align-items: center;
  gap: 8px;
  color: #52525b;
  font-size: 13px;
  font-weight: 500;
}

.ascii-toggle-control {
  position: relative;
  display: block;
  justify-self: end;
  width: 28px;
  height: 16px;
  cursor: pointer;
}

.ascii-toggle-control input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.ascii-toggle-control span {
  position: absolute;
  inset: 0;
  border-radius: 999px;
  background: #e4e4e7;
  transition: background 0.16s ease, box-shadow 0.16s ease;
}

.ascii-toggle-control span::after {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  content: "";
  background: #fff;
  transition: transform 0.16s ease;
}

.ascii-toggle-control input:checked + span {
  background: #e879f9;
}

.ascii-toggle-control:hover span,
.ascii-toggle-control:focus-within span {
  box-shadow: 0 0 0 3px rgba(24, 24, 27, 0.06);
}

.ascii-toggle-control input:checked + span::after {
  transform: translateX(12px);
}

.ascii-light-editor {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 192px;
  margin-top: 10px;
  border: 1px solid #f4f4f5;
  border-radius: 8px;
  background:
    radial-gradient(circle, rgba(161, 161, 170, 0.28) 1px, transparent 1px) 0 0 / 16px 16px,
    #fafafa;
}

.ascii-light-pad {
  display: block;
  width: 100%;
  height: 192px;
  background: #fafafa;
  cursor: crosshair;
}

.ascii-light-toolbar {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.ascii-light-toolbar span {
  min-width: 48px;
  padding: 3px 10px;
  border: 1px solid #e4e4e7;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #52525b;
  font: 500 13px/18px "IBM Plex Sans SC", sans-serif;
  text-align: center;
  backdrop-filter: blur(12px);
}

.ascii-light-toolbar button {
  position: relative;
  width: 26px;
  height: 26px;
  border: 1px solid #e4e4e7;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.86) url("./assets/ascii-editor/icons/delete.svg?v=20260602-light-delete") center / 16px 16px no-repeat;
  cursor: pointer;
  backdrop-filter: blur(12px);
  transition: border-color 0.16s ease, background-color 0.16s ease, transform 0.16s ease;
}

.ascii-light-toolbar button:hover,
.ascii-light-toolbar button:focus-visible {
  border-color: #d4d4d8;
  background-color: #fff;
  outline: none;
  transform: translateY(-1px);
}

.ascii-light-help {
  margin: 10px 0 2px;
  padding: 9px 10px;
  border: 1px solid #e4e4e7;
  border-radius: 6px;
  background: #fafafa;
  color: #71717a;
  font-size: 12px;
  line-height: 18px;
}

.ascii-light-slider {
  grid-template-columns: 72px 1fr 34px;
}

.ascii-subsection-title {
  margin-top: 16px !important;
}

.ascii-secondary-button {
  width: 100%;
  margin-top: 10px;
  transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* PromptSnap semantic design system: shared nav controls, theme tokens, and page primitives */
:root {
  --ps-canvas: #ffffff;
  --ps-page: #ffffff;
  --ps-surface: #ffffff;
  --ps-surface-soft: #fafafa;
  --ps-surface-muted: #f4f4f5;
  --ps-surface-raised: #ffffff;
  --ps-overlay-frost: rgba(255, 255, 255, 0.74);
  --ps-overlay-cta: rgba(0, 0, 0, 0.1);
  --ps-text-primary: #27272a;
  --ps-text-secondary: #52525b;
  --ps-text-muted: #71717a;
  --ps-text-disabled: #a1a1aa;
  --ps-text-inverse: #ffffff;
  --ps-border-subtle: #f4f4f5;
  --ps-border: #e4e4e7;
  --ps-border-strong: #d4d4d8;
  --ps-control-bg: #ffffff;
  --ps-control-bg-muted: #f4f4f5;
  --ps-control-active: #ffffff;
  --ps-button-primary-bg: #27272a;
  --ps-button-primary-text: #ffffff;
  --ps-button-secondary-bg: #ffffff;
  --ps-button-secondary-text: #27272a;
  --ps-button-secondary-border: #d4d4d8;
  --ps-header-media-opacity: 1;
  --ps-header-media-filter: none;
  --ps-marquee-fade-start: #ffffff;
  --ps-shadow-soft: 0 20px 72px rgba(24, 24, 27, 0.1);
  --surface: var(--ps-surface);
  --surface-soft: var(--ps-surface-soft);
  --surface-muted: var(--ps-surface-muted);
  --text-strong: var(--ps-text-primary);
  --text-main: var(--ps-text-secondary);
  --text-muted: var(--ps-text-muted);
  --text-soft: var(--ps-text-disabled);
  --border-main: var(--ps-border);
  --border-strong: var(--ps-border-strong);
  --shadow-soft: var(--ps-shadow-soft);
  --display-font: "Funnel Display", "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
  --modal-frost-bg: var(--ps-overlay-frost);
  color-scheme: light;
}

html[data-color-scheme="dark"] {
  --ink: #fafafa;
  --muted: #a1a1aa;
  --soft: #71717a;
  --panel: #18181b;
  --line: #3f3f46;
  --ps-canvas: #000000;
  --ps-page: #000000;
  --ps-surface: #18181b;
  --ps-surface-soft: #18181b;
  --ps-surface-muted: #27272a;
  --ps-surface-raised: #18181b;
  --ps-overlay-frost: rgba(9, 9, 11, 0.68);
  --ps-overlay-cta: rgba(0, 0, 0, 0.1);
  --ps-text-primary: #fafafa;
  --ps-text-secondary: #a1a1aa;
  --ps-text-muted: #71717a;
  --ps-text-disabled: #52525b;
  --ps-text-inverse: #ffffff;
  --ps-border-subtle: #27272a;
  --ps-border: #27272a;
  --ps-border-strong: #3f3f46;
  --ps-control-bg: #18181b;
  --ps-control-bg-muted: #18181b;
  --ps-control-active: #27272a;
  --ps-button-primary-bg: #fafafa;
  --ps-button-primary-text: #27272a;
  --ps-button-secondary-bg: #18181b;
  --ps-button-secondary-text: #fafafa;
  --ps-button-secondary-border: #3f3f46;
  --ps-header-media-opacity: 0.26;
  --ps-header-media-filter: brightness(0.72) saturate(0.82);
  --ps-marquee-fade-start: #000000;
  --ps-shadow-soft: 0 22px 80px rgba(0, 0, 0, 0.38);
  --surface: var(--ps-page);
  --surface-soft: var(--ps-surface);
  --surface-muted: var(--ps-surface-muted);
  --text-strong: var(--ps-text-primary);
  --text-main: var(--ps-text-secondary);
  --text-muted: var(--ps-text-secondary);
  --text-soft: var(--ps-text-disabled);
  --border-main: var(--ps-border);
  --border-strong: var(--ps-border-strong);
  --modal-frost-bg: var(--ps-overlay-frost);
  --shadow-soft: var(--ps-shadow-soft);
  color-scheme: dark;
}

html[data-lang="zh"] {
  --display-font: "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

body,
body.workbench-page,
body.inspiration-body,
body.skills-body,
body.cases-body,
body.policy-body,
.design,
.design-stage,
.inspiration-page,
.skills-page,
.cases-page,
.policy-page,
.workbench {
  background-color: var(--surface);
  color: var(--text-strong);
}

body.inspiration-body {
  min-height: 100vh;
  background: var(--ps-page);
}

body.inspiration-body .inspiration-page {
  background-color: transparent;
}

body.inspiration-body::before {
  content: "";
  display: none;
}

html[data-color-scheme="dark"] body,
html[data-color-scheme="dark"] body.workbench-page,
html[data-color-scheme="dark"] body.inspiration-body,
html[data-color-scheme="dark"] body.skills-body,
html[data-color-scheme="dark"] body.cases-body,
html[data-color-scheme="dark"] body.policy-body,
html[data-color-scheme="dark"] .design,
html[data-color-scheme="dark"] .design-stage,
html[data-color-scheme="dark"] .inspiration-page,
html[data-color-scheme="dark"] .skills-page,
html[data-color-scheme="dark"] .cases-page,
html[data-color-scheme="dark"] .policy-page,
html[data-color-scheme="dark"] .workbench {
  background-color: var(--ps-page);
  color: var(--ps-text-primary);
}

html[data-lang="en"] body,
html[data-lang="en"] .design,
html[data-lang="en"] .inspiration-page,
html[data-lang="en"] .skills-page,
html[data-lang="en"] .cases-page,
html[data-lang="en"] .policy-page,
html[data-lang="en"] .workbench,
html[data-lang="en"] .hero-nav,
html[data-lang="en"] .site-search input,
html[data-lang="en"] .download,
html[data-lang="en"] .learn,
html[data-lang="en"] .kicker,
html[data-lang="en"] h1,
html[data-lang="en"] h2,
html[data-lang="en"] h3 {
  font-family: var(--display-font);
}

html[data-lang="en"] body.inspiration-body,
html[data-lang="en"] body.inspiration-body button,
html[data-lang="en"] body.inspiration-body input,
html[data-lang="en"] body.inspiration-body a,
html[data-lang="en"] body.inspiration-body .download-menu,
html[data-lang="en"] body.inspiration-body .footer,
html[data-lang="en"] body.inspiration-body .footer-copy,
html[data-lang="en"] body.inspiration-body .footer-desc,
html[data-lang="en"] body.inspiration-body .footer-legal,
html[data-lang="en"] body.inspiration-body .designer,
html[data-lang="en"] body.inspiration-body .prompt-modal,
html[data-lang="en"] body.inspiration-body .prompt-modal button,
html[data-lang="en"] body.inspiration-body .prompt-modal a,
html[data-lang="en"] body.inspiration-body .inspiration-filter-menu-list,
html[data-lang="en"] body.inspiration-body .site-toast {
  font-family: var(--display-font);
}

html[data-lang="en"] body.inspiration-body .inspiration-kicker {
  font-family: "Playball", cursive;
}

html[data-lang="en"] body.workbench-page,
html[data-lang="en"] body.workbench-page button,
html[data-lang="en"] body.workbench-page input,
html[data-lang="en"] body.workbench-page a,
html[data-lang="en"] body.workbench-page .download-menu,
html[data-lang="en"] body.workbench-page .footer,
html[data-lang="en"] body.workbench-page .workbench-tool-card,
html[data-lang="en"] body.workbench-page .workbench-feature-copy,
html[data-lang="en"] body.workbench-page .workbench-steps {
  font-family: var(--display-font);
}

html[data-lang="en"] body.workbench-page .workbench-hero h1,
html[data-lang="en"] body.workbench-page .workbench-section-head h2,
html[data-lang="en"] body.workbench-page .workbench-feature-copy h2,
html[data-lang="en"] body.workbench-page .workbench-cta h2 {
  font-weight: 500;
}

html[data-lang="en"] body.workbench-page .workbench-cta > p {
  font-family: "Playball", cursive;
}

body,
body.workbench-page,
body.inspiration-body,
body.skills-body,
body.cases-body,
body.policy-body {
  padding-top: 0;
}

.hero-kicker {
  display: none;
}

html[data-lang="en"] .hero-kicker {
  position: absolute;
  display: block;
  left: var(--side);
  top: 200px;
  margin: 0;
  color: var(--text-main);
  font-family: var(--display-font);
  font-size: 20px;
  font-weight: 500;
  line-height: 30px;
  opacity: var(--hero-fade);
  transform: translate3d(0, var(--hero-copy-y), 0);
  transition: opacity 240ms linear;
}

.site-header .site-header-search {
  z-index: 4;
}

.site-header-language,
.site-header-theme {
  position: absolute;
  top: 0;
  z-index: 4;
}

.site-language-toggle {
  display: inline-flex;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 0;
  border: 1px solid var(--ps-border);
  border-radius: 6px;
  color: #27272a;
  background: var(--ps-surface-soft);
  font: 500 0/1 var(--display-font);
  cursor: pointer;
  transition: border-color 180ms var(--ease-out-quart), background-color 180ms var(--ease-out-quart), transform 180ms var(--ease-out-quart);
}

.site-language-toggle img {
  display: none;
}

.site-language-toggle::before {
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background: currentColor;
  -webkit-mask: url("./assets/figma/nav-language.svg") center / 18px 18px no-repeat;
  mask: url("./assets/figma/nav-language.svg") center / 18px 18px no-repeat;
}

.site-language-toggle:hover,
.site-language-toggle:focus-visible {
  border-color: var(--border-strong);
  background: var(--ps-surface);
  outline: none;
}

.site-language-toggle:active {
  transform: scale(0.96);
}

.site-theme-toggle {
  display: inline-flex;
  width: 102px;
  height: 36px;
  align-items: center;
  gap: 3px;
  padding: 2px;
  border: 1px solid var(--ps-border);
  border-radius: 6px;
  background: #f4f4f5;
}

.site-theme-toggle button {
  display: inline-flex;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 0;
  border-radius: 4px;
  color: #d4d4d8;
  background: transparent;
  cursor: pointer;
  transition: color 180ms var(--ease-out-quart), background-color 180ms var(--ease-out-quart), transform 180ms var(--ease-out-quart);
}

.site-theme-toggle button img {
  display: none;
}

.site-theme-toggle button::before {
  display: block;
  width: var(--theme-icon-width, 18px);
  height: var(--theme-icon-height, 18px);
  content: "";
  background: currentColor;
}

.site-theme-toggle [data-theme-option="light"]::before {
  --theme-icon-width: 18px;
  --theme-icon-height: 18px;
  -webkit-mask: url("./assets/figma/nav-theme-light.svg") center / contain no-repeat;
  mask: url("./assets/figma/nav-theme-light.svg") center / contain no-repeat;
}

.site-theme-toggle [data-theme-option="dark"]::before {
  --theme-icon-width: 16px;
  --theme-icon-height: 16px;
  -webkit-mask: url("./assets/figma/nav-theme-dark.svg") center / contain no-repeat;
  mask: url("./assets/figma/nav-theme-dark.svg") center / contain no-repeat;
}

.site-theme-toggle [data-theme-option="system"]::before {
  --theme-icon-width: 19px;
  --theme-icon-height: 19px;
  -webkit-mask: url("./assets/figma/nav-theme-system.svg") center / contain no-repeat;
  mask: url("./assets/figma/nav-theme-system.svg") center / contain no-repeat;
}

.site-theme-toggle button.is-active {
  color: #27272a;
  background: #ffffff;
  box-shadow: 0 1px 2px rgba(24, 24, 27, 0.06);
}

.site-theme-toggle button:not(.is-active):hover,
.site-theme-toggle button:not(.is-active):focus-visible {
  color: #71717a;
  background: rgba(161, 161, 170, 0.16);
  outline: none;
}

.site-theme-toggle button:active {
  transform: scale(0.94);
}

.site-search input {
  border-color: var(--ps-border);
  color: var(--ps-text-secondary);
  background: var(--ps-control-bg);
  font-family: var(--display-font);
  font-size: 12px;
}

.site-search input::placeholder {
  color: var(--ps-text-disabled);
}

.site-search-shortcut kbd,
.global-search-shortcut kbd {
  border-color: var(--border-main);
  color: var(--text-soft);
  background: var(--surface-soft);
}

.layout-toggle {
  background: #f4f4f5;
}

.layout-toggle::before {
  background: #ffffff;
}

.layout-toggle button {
  color: #a1a1aa;
}

.layout-toggle button.is-active {
  color: #27272a;
}

html[data-lang="en"] .hero-title {
  top: 238px;
  width: 560px;
  height: 144px;
  color: var(--ps-text-primary);
  font-family: var(--display-font);
  font-weight: 500;
  font-size: 54px;
  line-height: 72px;
  letter-spacing: 0;
}

html[data-lang="en"] .hero-title div {
  height: 72px;
}

html[data-lang="en"] .hero-title span {
  background-size: 180% 100%;
}

html[data-lang="en"] .accent-hero {
  left: calc(var(--side) + 390.8px);
  top: 206px;
  width: 82.68px;
  height: 82.68px;
  transform: translate3d(0, calc(var(--hero-accent-y) * 0.35), 0) rotate(32deg);
  transform-origin: center;
}

html[data-lang="en"] .scroll-arrow {
  left: calc(var(--side) + 88px);
  top: 728px;
  width: 107.94px;
  height: 96.96px;
}

html[data-lang="en"] .hero-desc {
  top: 398px;
  width: 480px;
  height: auto;
  color: var(--ps-text-secondary);
  font-family: var(--display-font);
}

html[data-lang="en"] .hero-actions {
  top: 470px;
  width: 356px;
}

html[data-lang="en"] .hero-actions .download-wrap,
html[data-lang="en"] .hero-actions .download {
  width: 180px;
}

@media (min-width: 768px) {
  html[data-lang="en"] {
    --section-title-line: 60px;
    --feature-head-left: calc(var(--side) + 346px);
    --feature-head-width: 701px;
    --feature-head-height: 108px;
    --feature-kicker-left: 277px;
    --feature-accent-left: 703px;
    --feature-accent-top: 18px;
    --layout-head-left: calc(var(--side) + 354px);
    --layout-head-width: 684px;
    --layout-head-height: 108px;
    --layout-kicker-left: 270px;
    --layout-accent-left: 654px;
    --layout-accent-top: 24px;
    --share-head-left: calc(var(--side) + 480px);
    --share-head-width: 432px;
    --share-head-height: 108px;
    --share-kicker-left: 120px;
    --share-accent-left: 520px;
    --share-accent-top: 30px;
    --faq-head-left: calc(var(--side) + 468px);
    --faq-head-width: 506px;
    --faq-head-height: 108px;
    --faq-title-top: 48px;
    --faq-kicker-left: 181px;
    --faq-accent-left: 458px;
    --faq-accent-top: 30px;
    --features-top: 1084px;
    --features-height: 796px;
    --feature-card-height: 384px;
    --feature-card-gap-y: 28px;
    --feature-copy-width: 636px;
    --layout-head-top: 2040px;
    --layout-toggle-top: 2172px;
    --layout-demo-top: 2268px;
    --share-head-top: 3106px;
    --share-row-top: 3274px;
    --faq-head-top: 4118px;
    --faq-top: 4262px;
    --footer-top: 4828px;
    --design-height: 5412px;
  }

  html[data-lang="en"] .f1,
  html[data-lang="en"] .f2 {
    height: 388px;
  }

html[data-lang="en"] .feature-head h2,
html[data-lang="en"] .layout-head h2,
html[data-lang="en"] .share-head h2,
html[data-lang="en"] .faq-head h2,
html[data-lang="en"] .footer-copy h2 {
  font-weight: 500;
}

  html[data-lang="en"] .layout-head h2,
  html[data-lang="en"] .share-head h2 {
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
  }

  html[data-lang="en"] .f1 h3,
  html[data-lang="en"] .f2 h3 {
    font-weight: 500;
    top: 244px;
  }

  html[data-lang="en"] .feature-card h3 {
    font-weight: 500;
  }

  html[data-lang="en"] .f1 > p,
  html[data-lang="en"] .f2 > p {
    top: 304px;
  }

  html[data-lang="en"] .feature-card > p,
  html[data-lang="en"] .f4 > p {
    font-family: var(--display-font);
    line-height: 30px;
    white-space: normal;
  }

  html[data-lang="en"] .footer-copy p {
    font-family: var(--display-font);
    font-weight: 500;
  }

  html[data-lang="en"] .f4 > p {
    width: 624px;
    line-height: 36px;
    white-space: nowrap;
  }

  html[data-lang="en"] .layout-toggle button {
    font-family: var(--display-font);
  }
}

html[data-lang="en"] .hero-board {
  top: 84px;
  height: 672px;
  border-radius: 16px;
}

html[data-lang="en"] .board-shadow {
  display: none;
}

html[data-lang="en"] .board-white {
  height: 672px;
  border-radius: 16px;
  background: var(--ps-surface);
}

html[data-lang="en"] .hero-col-left {
  top: -17px;
}

html[data-lang="en"] .hero-col-right {
  top: 68px;
}

.scroll-text {
  color: var(--text-soft);
}

.feature-card,
.feature-panel,
.global-search-panel,
.global-search-input-row::before,
.global-search-result-type,
.global-search-count,
.global-search-action,
.download-menu {
  border-color: var(--ps-border);
  background-color: var(--ps-surface);
  color: var(--ps-text-primary);
}

.feature-panel,
.global-search-input-row::before,
.global-search-result:hover,
.global-search-result:focus-visible,
.global-search-result.is-active,
.global-search-footer {
  background-color: var(--ps-surface-soft);
}

.global-search-panel {
  box-shadow: var(--shadow-soft);
}

.global-search-recommendations {
  border-color: var(--ps-border-subtle);
}

.global-search-recommendations button {
  border-color: var(--ps-border);
  color: var(--ps-text-secondary);
  background: var(--ps-surface);
  font-family: var(--display-font);
}

.global-search-result-title,
.download-menu a,
.hero-nav a.is-active,
.hero-nav a:hover,
.hero-nav a:focus-visible {
  color: var(--ps-text-primary);
}

.global-search-result-summary,
.global-search-help,
.global-search-action-label,
.download-menu small {
  color: var(--ps-text-secondary);
}

.global-search-input-row input {
  color: var(--ps-text-primary);
  font-family: var(--display-font);
}

.global-search-key {
  border-color: var(--ps-border);
  color: var(--ps-text-secondary);
  background: var(--ps-surface);
}

html[data-color-scheme="dark"] .site-search-shortcut kbd,
html[data-color-scheme="dark"] .global-search-shortcut kbd {
  border-color: #27272a;
  color: #52525b;
  background: #18181b;
}

html[data-color-scheme="dark"] .site-search img,
html[data-color-scheme="dark"] .global-search-input-row img {
  filter: brightness(0) invert(1);
  opacity: 0.64;
}

html[data-color-scheme="dark"] .hero-bg,
html[data-color-scheme="dark"] .inspiration-header-bg,
html[data-color-scheme="dark"] .skills-header-bg,
html[data-color-scheme="dark"] .cases-header-bg {
  opacity: 0.26;
  filter: brightness(0.72) saturate(0.82);
}

html[data-color-scheme="dark"] .design .hero {
  background: #18181b;
  box-shadow: none;
}

html[data-color-scheme="dark"] .design .hero-bg {
  content: url("./assets/figma/hero-bg-dark.png");
  opacity: 1;
  filter: none;
}

html[data-color-scheme="dark"] .hero-title,
html[data-color-scheme="dark"] .skills-hero h1,
html[data-color-scheme="dark"] .inspiration-title h1,
html[data-color-scheme="dark"] .cases-hero h1,
html[data-color-scheme="dark"] .workbench-hero h1,
html[data-color-scheme="dark"] .workbench-section-head h2,
html[data-color-scheme="dark"] .workbench-feature-copy h2,
html[data-color-scheme="dark"] .workbench-cta h2,
html[data-color-scheme="dark"] .feature-head h2,
html[data-color-scheme="dark"] .layout-head h2,
html[data-color-scheme="dark"] .share-head h2,
html[data-color-scheme="dark"] .faq-head h2 {
  color: var(--ps-text-primary);
}

html[data-color-scheme="dark"] .hero-kicker,
html[data-color-scheme="dark"] .kicker,
html[data-color-scheme="dark"] .hero-desc,
html[data-color-scheme="dark"] .skills-hero p,
html[data-color-scheme="dark"] .skills-agent-strip p,
html[data-color-scheme="dark"] .inspiration-subtitle,
html[data-color-scheme="dark"] .cases-hero p,
html[data-color-scheme="dark"] .workbench-hero-copy > p:not(.workbench-kicker),
html[data-color-scheme="dark"] .workbench-feature-copy p:not(.workbench-label),
html[data-color-scheme="dark"] .scroll-text {
  color: var(--ps-text-secondary);
}

html[data-color-scheme="dark"] .kicker {
  color: #e4e4e7;
}

html[data-color-scheme="dark"] .hero-actions .download {
  border-color: var(--ps-button-primary-bg);
  background: var(--ps-button-primary-bg);
  color: var(--ps-button-primary-text);
}

html[data-color-scheme="dark"] .hero-actions .learn {
  border-color: var(--ps-button-secondary-border);
  background: var(--ps-button-secondary-bg);
  color: var(--ps-button-secondary-text);
}

html[data-color-scheme="dark"] .site-theme-toggle button.is-active {
  color: #fafafa;
  background: #27272a;
}

html[data-color-scheme="dark"] .site-language-toggle,
html[data-color-scheme="dark"] .site-theme-toggle {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .site-theme-toggle button:not(.is-active) {
  color: #52525b;
  background: transparent;
}

html[data-color-scheme="dark"] .site-theme-toggle button:not(.is-active):hover,
html[data-color-scheme="dark"] .site-theme-toggle button:not(.is-active):focus-visible {
  color: #a1a1aa;
  background: #27272a;
}

html[data-color-scheme="dark"] .site-language-toggle {
  color: #fafafa;
}

html[data-color-scheme="dark"] .site-header .logo,
html[data-color-scheme="dark"] .hero-header .logo {
  background: transparent;
  box-shadow: none;
}

html[data-color-scheme="dark"] .site-header .logo .logo-svg,
html[data-color-scheme="dark"] .hero-header .logo .logo-svg,
html[data-color-scheme="dark"] .mobile-menu-logo,
html[data-color-scheme="dark"] .menu-logo img {
  content: url("./assets/figma/logo-dark.svg");
}

html[data-color-scheme="dark"] body.policy-body {
  background: #000000;
}

html[data-color-scheme="dark"] body.policy-body .policy-page {
  color: #fafafa;
  background: #000000;
}

html[data-color-scheme="dark"] body.policy-body .policy-card {
  border-color: #27272a;
  background: #000000;
}

html[data-color-scheme="dark"] body.policy-body .policy-sidebar {
  border-color: #27272a;
  background: #000000;
}

html[data-color-scheme="dark"] body.policy-body .policy-sidebar a {
  color: #52525b;
}

html[data-color-scheme="dark"] body.policy-body .policy-sidebar a:hover,
html[data-color-scheme="dark"] body.policy-body .policy-sidebar a:focus-visible {
  color: #e4e4e7;
}

html[data-color-scheme="dark"] body.policy-body .policy-sidebar a.is-active {
  color: #fafafa;
}

html[data-color-scheme="dark"] body.policy-body .policy-page h1,
html[data-color-scheme="dark"] body.policy-body .policy-section h2 {
  color: #fafafa;
}

html[data-color-scheme="dark"] body.policy-body .policy-date,
html[data-color-scheme="dark"] body.policy-body .policy-intro,
html[data-color-scheme="dark"] body.policy-body .policy-section {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] body.policy-body .policy-divider {
  background: #27272a;
}

html[data-color-scheme="dark"] body.policy-body .site-search input {
  border-color: #27272a;
  color: #a1a1aa;
  background: #18181b;
}

html[data-color-scheme="dark"] body.policy-body .site-search input::placeholder {
  color: #52525b;
}

html[data-color-scheme="dark"] body.policy-body .site-search input:focus {
  border-color: #3f3f46;
}

html[data-color-scheme="dark"] body.workbench-page {
  background: #000000;
}

html[data-color-scheme="dark"] .workbench {
  color: #fafafa;
  background:
    linear-gradient(180deg, #18181b 0, #111113 120px, #000000 308px, #000000 100%),
    #000000;
}

html[data-color-scheme="dark"] .workbench-feature::before,
html[data-color-scheme="dark"] .workbench-workflow-sticky::before {
  opacity: 0.44;
  filter: brightness(0.5) saturate(0.82);
}

html[data-color-scheme="dark"] .workbench-demo {
  background-color: #18181b;
  background-image:
    linear-gradient(180deg, rgba(24, 24, 27, 0.1), rgba(0, 0, 0, 0.34)),
    url("./assets/workbench/hero-gradient.jpg");
  box-shadow: inset 0 0 0 1px #27272a;
}

html[data-color-scheme="dark"] .workbench-panel,
html[data-color-scheme="dark"] .workbench-stage-image {
  filter: brightness(0.82) saturate(0.86);
}

html[data-color-scheme="dark"] .workbench-cta-art {
  opacity: 1;
  filter: none;
}

html[data-color-scheme="dark"] .workbench-select-frame {
  border-color: rgba(250, 250, 250, 0.72);
  background: rgba(24, 24, 27, 0.2);
}

html[data-color-scheme="dark"] .workbench-select-frame span {
  border-color: #fafafa;
  background: #e879f9;
}

html[data-color-scheme="dark"] .workbench-label {
  color: #e4e4e7;
}

html[data-color-scheme="dark"] .workbench-label::before {
  filter: none;
}

html[data-color-scheme="dark"] .workbench-primary,
html[data-color-scheme="dark"] .workbench-cta-actions a:first-child {
  color: #27272a;
  background: #fafafa;
}

html[data-color-scheme="dark"] .workbench-primary:hover,
html[data-color-scheme="dark"] .workbench-primary:focus-visible,
html[data-color-scheme="dark"] .workbench-cta-actions a:first-child:hover,
html[data-color-scheme="dark"] .workbench-cta-actions a:first-child:focus-visible {
  color: rgba(39, 39, 42, 0.64);
  background: #fafafa;
}

html[data-color-scheme="dark"] .workbench-secondary,
html[data-color-scheme="dark"] .workbench-feature-copy a,
html[data-color-scheme="dark"] .workbench-cta-actions a + a {
  border-color: #3f3f46;
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-secondary:hover,
html[data-color-scheme="dark"] .workbench-secondary:focus-visible,
html[data-color-scheme="dark"] .workbench-feature-copy a:hover,
html[data-color-scheme="dark"] .workbench-feature-copy a:focus-visible,
html[data-color-scheme="dark"] .workbench-cta-actions a + a:hover,
html[data-color-scheme="dark"] .workbench-cta-actions a + a:focus-visible {
  border-color: #52525b;
  color: #fafafa;
  background: #27272a;
}

html[data-color-scheme="dark"] .hero-board,
html[data-color-scheme="dark"] .feature-card,
html[data-color-scheme="dark"] .footer-cta,
html[data-color-scheme="dark"] .workbench-tool-card,
html[data-color-scheme="dark"] .workbench-feature-image,
html[data-color-scheme="dark"] .workbench-cta,
html[data-color-scheme="dark"] .skills-card,
html[data-color-scheme="dark"] .skill-card,
html[data-color-scheme="dark"] .inspiration-card,
html[data-color-scheme="dark"] .cases-card {
  border-color: var(--ps-border);
  background: var(--ps-surface);
}

html[data-color-scheme="dark"] .workbench-tool-card {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-tool-card:hover {
  border-color: #3f3f46;
  box-shadow: none;
}

html[data-color-scheme="dark"] .workbench-tool-media {
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-tool-media img,
html[data-color-scheme="dark"] .workbench-feature-image img {
  filter: brightness(0.82) saturate(0.86);
}

html[data-color-scheme="dark"] .workbench-tool-media-ascii::before,
html[data-color-scheme="dark"] .workbench-tool-media-ascii::after {
  opacity: 0.38;
  filter: brightness(0.52) saturate(0.84);
}

html[data-color-scheme="dark"] .workbench-feature-image {
  border: 1px solid #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-feature-image-blue {
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-feature-image-blue::after {
  background:
    radial-gradient(circle at 20% 20%, rgba(250, 250, 250, 0.08), transparent 18%),
    linear-gradient(180deg, rgba(24, 24, 27, 0.18), rgba(0, 0, 0, 0.18) 62%);
}

html[data-color-scheme="dark"] .workbench-steps li {
  border-color: #27272a;
}

html[data-color-scheme="dark"] .workbench-steps li.is-active {
  border-color: #3f3f46;
}

html[data-color-scheme="dark"] .workbench-steps li::before {
  background-color: transparent;
  filter: none;
}

html[data-color-scheme="dark"] .workbench-cta {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .workbench-cta > p {
  color: #e879f9;
}

html[data-color-scheme="dark"] .workbench-cta h2 {
  color: #fafafa;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-cta {
  border-color: rgba(250, 250, 250, 0.14);
  background: rgba(0, 0, 0, 0.1);
  box-shadow: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art {
  background: #18181b;
}

html[data-color-scheme="dark"] .hero-board,
html[data-color-scheme="dark"] .board-white {
  background: #000000;
}

html[data-color-scheme="dark"] .feature-panel {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .feature-pattern {
  left: var(--feature-pattern-left);
  top: 12px;
  width: 336px;
  height: 336px;
  opacity: 0.42;
  background: url("./assets/figma/dark-home/feature-pattern-dark.svg") center / 336px 336px no-repeat;
  -webkit-mask-image: radial-gradient(circle at 50% 50%, #000 0 42%, rgba(0, 0, 0, 0) 72%);
  mask-image: radial-gradient(circle at 50% 50%, #000 0 42%, rgba(0, 0, 0, 0) 72%);
}

html[data-color-scheme="dark"] .f4 .feature-pattern {
  left: var(--feature-pattern-alt-left);
}

html[data-color-scheme="dark"] .feature-card h3,
html[data-color-scheme="dark"] .menu-label {
  color: #fafafa;
}

html[data-color-scheme="dark"] .feature-card > p,
html[data-color-scheme="dark"] .f4 > p,
html[data-color-scheme="dark"] .menu-shot span,
html[data-color-scheme="dark"] .prompt-shot span,
html[data-color-scheme="dark"] .model-shot span {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .faq .top-line,
html[data-color-scheme="dark"] .faq details {
  border-color: #27272a;
}

html[data-color-scheme="dark"] .faq .top-line {
  background: #27272a;
}

html[data-color-scheme="dark"] .faq summary {
  color: #f4f4f5;
}

html[data-color-scheme="dark"] .faq summary:hover,
html[data-color-scheme="dark"] .faq summary:focus-visible {
  color: #fafafa;
}

html[data-color-scheme="dark"] .faq summary img {
  content: url("./assets/figma/dark-home/faq-arrow-dark.svg");
  opacity: 1;
  filter: none;
}

html[data-color-scheme="dark"] .faq .left details:first-child summary img {
  content: url("./assets/figma/dark-home/faq-arrow-dark-primary.svg");
}

@media (max-width: 767px) {
  html[data-color-scheme="dark"] .feature-pattern {
    left: 85px;
    top: 10px;
    width: 200px;
    height: 200px;
    background: url("./assets/figma/dark-home/feature-pattern-dark.svg") center / 200px 200px no-repeat;
    -webkit-mask-image: none;
    mask-image: none;
  }

  html[data-color-scheme="dark"] .f1 .feature-pattern {
    left: 75px;
    width: 220px;
    height: 220px;
    background-size: 220px 220px;
  }

  html[data-color-scheme="dark"] .f4 .feature-pattern {
    left: 85px;
    top: 10px;
    width: 200px;
    height: 200px;
    background-size: 200px 200px;
  }
}

html[data-color-scheme="dark"] .selected {
  background: #18181b;
}

html[data-color-scheme="dark"] .model-shot .shot-bg,
html[data-color-scheme="dark"] .prompt-shot > img:first-child,
html[data-color-scheme="dark"] .share-shot .shot-bg {
  filter: none;
}

html[data-color-scheme="dark"] .menu-shot > img:first-child,
html[data-color-scheme="dark"] .prompt-shot > img:first-child,
html[data-color-scheme="dark"] .model-shot .shot-bg {
  content: url("./assets/figma/dark-home/feature-prompt-model-shot-bg.svg");
}

html[data-color-scheme="dark"] .menu-shot > img:first-child {
  content: url("./assets/figma/dark-home/feature-menu-shot-bg.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .shot-bg {
  content: url("./assets/figma/dark-home/model-shot-bg.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .down {
  content: url("./assets/figma/dark-home/model-check.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .gemini {
  content: url("./assets/figma/dark-home/model-gemini.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .minimax {
  content: url("./assets/figma/dark-home/model-minimax.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .qwen {
  content: url("./assets/figma/dark-home/model-qwen.svg");
}

html[data-color-scheme="dark"] .f4 .model-shot .doubao {
  content: url("./assets/figma/dark-home/model-doubao.svg");
}

html[data-color-scheme="dark"] .menu-active {
  content: url("./assets/figma/dark-home/menu-active-dark.svg");
}

html[data-color-scheme="dark"] .share-shot .shot-bg {
  content: url("./assets/figma/dark-home/feature-share-shot-bg.svg");
}

html[data-color-scheme="dark"] .layout-toggle {
  background: #18181b;
}

html[data-color-scheme="dark"] .layout-toggle::before {
  background: #000000;
  box-shadow: none;
}

html[data-color-scheme="dark"] .layout-toggle button {
  color: #52525b;
}

html[data-color-scheme="dark"] .layout-toggle button.is-active {
  color: #f4f4f5;
}

html[data-color-scheme="dark"] .learn,
html[data-color-scheme="dark"] .download-menu,
html[data-color-scheme="dark"] .mobile-menu-panel,
html[data-color-scheme="dark"] .mobile-menu-backdrop {
  border-color: var(--ps-border);
  color: var(--ps-text-secondary);
  background: var(--ps-surface);
}

html[data-color-scheme="dark"] .download {
  color: var(--ps-button-primary-text);
  background: var(--ps-button-primary-bg);
}

html[data-color-scheme="dark"] .download:hover {
  color: rgba(9, 9, 11, 0.62);
  background: #fafafa;
}

html[data-color-scheme="dark"] .hero-actions .download,
html[data-color-scheme="dark"] .hero-actions .download:hover {
  border-color: var(--ps-button-primary-bg);
  background: var(--ps-button-primary-bg);
  color: var(--ps-button-primary-text);
}

html[data-color-scheme="dark"] .hero-actions .learn {
  border-color: var(--ps-button-secondary-border);
  background: var(--ps-button-secondary-bg);
  color: var(--ps-button-secondary-text);
}

html[data-color-scheme="dark"] .hero-actions .learn:hover,
html[data-color-scheme="dark"] .hero-actions .learn:focus-visible {
  border-color: #52525b;
  background: #27272a;
  color: var(--ps-button-secondary-text);
}

html[data-color-scheme="dark"] .download img,
html[data-color-scheme="dark"] .footer-download img {
  filter: brightness(0);
}

html[data-color-scheme="dark"] .skills-header-bg,
html[data-color-scheme="dark"] .inspiration-header-bg,
html[data-color-scheme="dark"] .cases-header-bg {
  background-color: var(--ps-page);
}

html[data-color-scheme="dark"] .skills-header-bg::before,
html[data-color-scheme="dark"] .inspiration-header-bg::before {
  background: linear-gradient(90deg, rgba(82, 82, 91, 0) 0%, rgba(82, 82, 91, 0.42) 38%, rgba(82, 82, 91, 0.2) 52%, rgba(82, 82, 91, 0) 72%);
}

html[data-color-scheme="dark"] .skills-header-bg::after,
html[data-color-scheme="dark"] .inspiration-header-bg::after {
  background: linear-gradient(0deg, var(--ps-page) 0%, rgba(0, 0, 0, 0.9) 18%, rgba(0, 0, 0, 0) 68%) center top / 100% 100% no-repeat;
}

html[data-color-scheme="dark"] body.inspiration-body {
  min-height: 100vh;
  background: #000000;
}

html[data-color-scheme="dark"] body.inspiration-body::before {
  position: fixed;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100vw;
  height: 100vh;
  content: "";
  pointer-events: none;
  background: linear-gradient(180deg, #18181b 0, #111113 120px, #000000 320px, #000000 100%);
}

html[data-color-scheme="dark"] .inspiration-page {
  min-height: max(100vh, var(--inspiration-page-height, 3608px));
  background: transparent;
}

html[data-color-scheme="dark"] .inspiration-header-bg {
  display: none;
  top: 0;
  height: 320px;
  opacity: 1;
  filter: none;
  background: linear-gradient(180deg, #18181b 0%, rgba(24, 24, 27, 0) 100%);
}

html[data-color-scheme="dark"] .inspiration-header-bg::before,
html[data-color-scheme="dark"] .inspiration-header-bg::after {
  display: none;
}

@media (min-width: 1440px) {
  html[data-color-scheme="dark"] .inspiration-grid {
    transform: none;
  }
}

html[data-color-scheme="dark"] .inspiration-hero h1 {
  color: #fafafa;
}

html[data-color-scheme="dark"] .inspiration-hero > p:not(.inspiration-kicker) {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .inspiration-mode-tabs button {
  color: #52525b;
}

html[data-color-scheme="dark"] .inspiration-mode-tabs button.is-active,
html[data-color-scheme="dark"] .inspiration-mode-tabs button:hover,
html[data-color-scheme="dark"] .inspiration-mode-tabs button:focus-visible {
  color: #fafafa;
}

html[data-color-scheme="dark"] .inspiration-filters button {
  border-color: #27272a;
  color: #a1a1aa;
  background: transparent;
}

html[data-color-scheme="dark"] .inspiration-filters button.is-active,
html[data-color-scheme="dark"] .inspiration-filters button:hover,
html[data-color-scheme="dark"] .inspiration-filters button:focus-visible {
  border-color: #fafafa;
  color: #fafafa;
  background: #000000;
}

html[data-color-scheme="dark"] .inspiration-filter-menu-list {
  border-color: #27272a;
  background: #18181b;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.38);
}

html[data-color-scheme="dark"] .inspiration-filters .inspiration-filter-menu-item:hover,
html[data-color-scheme="dark"] .inspiration-filters .inspiration-filter-menu-item:focus-visible {
  border-color: transparent;
  color: #fafafa;
  background: #27272a;
}

html[data-color-scheme="dark"] .inspiration-filters .inspiration-filter-menu-item.is-active {
  border-color: #fafafa;
  color: #fafafa;
  background: #000000;
}

html[data-color-scheme="dark"] .prompt-card.is-open {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .prompt-card--case {
  border-color: #27272a;
  background-color: #18181b;
}

html[data-color-scheme="dark"] .prompt-card h2,
html[data-color-scheme="dark"] .prompt-card--case h2 {
  color: #fafafa;
}

html[data-color-scheme="dark"] .prompt-card p,
html[data-color-scheme="dark"] .prompt-card--case p {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .prompt-actions .prompt-detail,
html[data-color-scheme="dark"] .prompt-modal-save {
  border-color: #d4d4d8;
  color: #e4e4e7;
  background: transparent;
}

html[data-color-scheme="dark"] .prompt-actions .prompt-detail img,
html[data-color-scheme="dark"] .prompt-modal-save img {
  filter: brightness(0) saturate(100%) invert(93%) sepia(4%) saturate(125%) hue-rotate(202deg) brightness(99%) contrast(88%);
}

html[data-color-scheme="dark"] .prompt-actions .prompt-detail:hover,
html[data-color-scheme="dark"] .prompt-actions .prompt-detail:focus-visible,
html[data-color-scheme="dark"] .prompt-modal-save:hover,
html[data-color-scheme="dark"] .prompt-modal-save:focus-visible {
  border-color: #fafafa;
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .prompt-actions .prompt-copy,
html[data-color-scheme="dark"] .prompt-modal-copy {
  border-color: #fafafa;
  color: #18181b;
  background: #fafafa;
}

html[data-color-scheme="dark"] .prompt-actions .prompt-copy img,
html[data-color-scheme="dark"] .prompt-modal-copy img {
  filter: brightness(0) saturate(100%) invert(9%) sepia(8%) saturate(483%) hue-rotate(202deg) brightness(95%) contrast(93%);
}

html[data-color-scheme="dark"] .prompt-actions .prompt-copy:hover,
html[data-color-scheme="dark"] .prompt-actions .prompt-copy:focus-visible,
html[data-color-scheme="dark"] .prompt-modal-copy:hover,
html[data-color-scheme="dark"] .prompt-modal-copy:focus-visible {
  border-color: #e4e4e7;
  color: #18181b;
  background: #e4e4e7;
}

html[data-color-scheme="dark"] .inspiration-fade {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000000 50%);
}

html[data-color-scheme="dark"] .inspiration-more {
  border-color: #27272a;
  color: #d4d4d8;
  background: #000000;
}

html[data-color-scheme="dark"] .inspiration-more:hover,
html[data-color-scheme="dark"] .inspiration-more:focus-visible {
  border-color: #52525b;
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .prompt-modal-panel {
  border: 1px solid #27272a;
  background: #18181b;
  box-shadow: 0 24px 72px rgba(0, 0, 0, 0.42);
}

html[data-color-scheme="dark"] .prompt-modal-image,
html[data-color-scheme="dark"] .prompt-modal-info {
  background: #09090b;
  box-shadow: inset 0 0 0 1px #27272a;
}

html[data-color-scheme="dark"] .prompt-modal-content h2 {
  color: #fafafa;
}

html[data-color-scheme="dark"] .prompt-modal-text {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .prompt-modal-info::after {
  background: linear-gradient(180deg, rgba(9, 9, 11, 0) 0%, rgba(9, 9, 11, 0.92) 66%, #09090b 100%);
}

html[data-color-scheme="dark"] .prompt-modal-close {
  border-color: #27272a;
  background: #18181b;
}

html[data-color-scheme="dark"] .prompt-modal-close img {
  filter: brightness(0) invert(1);
  opacity: 0.8;
}

html[data-color-scheme="dark"] .prompt-modal-close:hover,
html[data-color-scheme="dark"] .prompt-modal-close:focus-visible {
  border-color: #52525b;
  background: #27272a;
}

html[data-color-scheme="dark"] .skill-detail-body,
html[data-color-scheme="dark"] .skill-detail-page {
  background: #000000;
}

html[data-color-scheme="dark"] .skill-modal {
  background: rgba(9, 9, 11, 0.68);
}

html[data-color-scheme="dark"] .skill-detail-card {
  border: 1px solid #27272a;
  background: #18181b;
  box-shadow: 0 24px 72px rgba(0, 0, 0, 0.42);
}

html[data-color-scheme="dark"] .skill-modal .skill-detail-card {
  box-shadow: 0 24px 72px rgba(0, 0, 0, 0.42);
}

html[data-color-scheme="dark"] .skill-detail-eyebrow,
html[data-color-scheme="dark"] .skill-install-block h2,
html[data-color-scheme="dark"] .skill-intro-block h2 {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .skill-detail-divider {
  background: #27272a;
}

html[data-color-scheme="dark"] .skill-detail-head h1,
html[data-color-scheme="dark"] .skill-intro-text strong {
  color: #fafafa;
}

html[data-color-scheme="dark"] .skill-detail-author {
  color: #e4e4e7;
}

html[data-color-scheme="dark"] .skill-detail-summary,
html[data-color-scheme="dark"] .skill-intro-text {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .skill-detail-author img {
  background: #27272a;
  box-shadow: inset 0 0 0 1px rgba(250, 250, 250, 0.08);
}

html[data-color-scheme="dark"] .skill-detail-github {
  border: 1px solid #fafafa;
  color: #18181b;
  background: #fafafa;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-detail-github img {
  filter: brightness(0) saturate(100%) invert(9%) sepia(8%) saturate(483%) hue-rotate(202deg) brightness(95%) contrast(93%);
}

html[data-color-scheme="dark"] .skill-detail-github:hover,
html[data-color-scheme="dark"] .skill-detail-github:focus-visible {
  border-color: #e4e4e7;
  color: #18181b;
  background: #e4e4e7;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-detail-close {
  border-color: #27272a;
  background: #18181b;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-detail-close img {
  filter: brightness(0) invert(1);
  opacity: 0.8;
}

html[data-color-scheme="dark"] .skill-detail-close:hover,
html[data-color-scheme="dark"] .skill-detail-close:focus-visible {
  border-color: #52525b;
  background: #27272a;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-detail-close:hover img,
html[data-color-scheme="dark"] .skill-detail-close:focus-visible img {
  opacity: 1;
}

html[data-color-scheme="dark"] .skill-detail-tags .is-codex {
  color: #93c5fd;
  background-image: none;
  box-shadow: inset 0 0 0 1px rgba(96, 165, 250, 0.48);
}

html[data-color-scheme="dark"] .skill-detail-tags .is-claude {
  color: #fbbf24;
  background-image: none;
  box-shadow: inset 0 0 0 1px rgba(251, 191, 36, 0.44);
}

html[data-color-scheme="dark"] .skill-detail-tags .is-codex::before,
html[data-color-scheme="dark"] .skill-detail-tags .is-claude::before {
  filter: brightness(1.08) saturate(0.92);
}

html[data-color-scheme="dark"] .skill-install-command {
  border: 1px solid #27272a;
  background: #09090b;
}

html[data-color-scheme="dark"] .skill-install-command code,
html[data-color-scheme="dark"] .skill-install-token,
html[data-color-scheme="dark"] .skill-install-token.is-command {
  color: #e4e4e7;
}

html[data-color-scheme="dark"] .skill-install-token.is-value {
  color: #71717a;
}

html[data-color-scheme="dark"] .skill-install-copy {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .skill-install-copy img {
  filter: brightness(0) saturate(100%) invert(68%) sepia(6%) saturate(319%) hue-rotate(202deg) brightness(93%) contrast(89%);
}

html[data-color-scheme="dark"] .skill-install-copy:hover,
html[data-color-scheme="dark"] .skill-install-copy:focus-visible {
  opacity: 1;
}

html[data-color-scheme="dark"] .skill-intro-scroll {
  border-color: #27272a;
  background: #09090b;
  scrollbar-color: #3f3f46 transparent;
}

html[data-color-scheme="dark"] .skill-intro-scroll::-webkit-scrollbar-thumb {
  background: #3f3f46;
}

html[data-lang="en"] .inspiration-hero h1,
html[data-lang="en"] .inspiration-hero p,
html[data-lang="en"] .inspiration-mode-tabs button,
html[data-lang="en"] .inspiration-filters button,
html[data-lang="en"] .prompt-card h2,
html[data-lang="en"] .prompt-card p,
html[data-lang="en"] .prompt-actions button,
html[data-lang="en"] .prompt-modal-panel,
html[data-lang="en"] .inspiration-more {
  font-family: var(--display-font);
}

html[data-lang="en"] .inspiration-hero h1 {
  font-weight: 500;
}

@media (min-width: 1440px) {
  html[data-lang="en"] .inspiration-hero {
    top: 120px;
  }

  html[data-lang="en"] .inspiration-mode-tabs,
  html[data-lang="en"] .inspiration-filters {
    top: 360px;
  }

  html[data-lang="en"] .inspiration-filters {
    left: auto;
    right: var(--side);
    justify-content: flex-end;
    width: max-content;
    max-width: calc(var(--content) - 240px);
  }
}

@media (min-width: 1440px) {
  /* Figma 5879:8603: filters live inside the centered 1440px page, right edge x=1416. */
  body.inspiration-body .inspiration-page .inspiration-filters {
    left: 656px;
    right: 24px;
    justify-content: flex-end;
    width: auto;
    max-width: none;
  }
}

@media (min-width: 768px) and (max-width: 1439px) {
  body.inspiration-body .inspiration-page .inspiration-filters {
    justify-content: flex-end;
  }
}

html[data-color-scheme="dark"] .skills-agent-marquee::before {
  background: linear-gradient(90deg, var(--ps-marquee-fade-start) 0%, var(--ps-marquee-fade-start) 50%, rgba(0, 0, 0, 0) 100%);
}

html[data-color-scheme="dark"] .skills-agent-marquee::after {
  background: linear-gradient(270deg, var(--ps-marquee-fade-start) 0%, var(--ps-marquee-fade-start) 50%, rgba(0, 0, 0, 0) 100%);
}

html[data-color-scheme="dark"] .skills-mode-tabs button,
html[data-color-scheme="dark"] .skills-filters button,
html[data-color-scheme="dark"] .skills-more {
  border-color: var(--ps-border);
  color: var(--ps-text-disabled);
  background: var(--ps-control-bg);
}

html[data-color-scheme="dark"] .skills-mode-tabs button.is-active,
html[data-color-scheme="dark"] .skills-mode-tabs button:hover,
html[data-color-scheme="dark"] .skills-mode-tabs button:focus-visible,
html[data-color-scheme="dark"] .skills-filters button.is-active,
html[data-color-scheme="dark"] .skills-filters button:hover,
html[data-color-scheme="dark"] .skills-filters button:focus-visible,
html[data-color-scheme="dark"] .skills-more:hover,
html[data-color-scheme="dark"] .skills-more:focus-visible {
  border-color: var(--ps-border-strong);
  color: var(--ps-text-primary);
}

html[data-color-scheme="dark"] .skill-card h2,
html[data-color-scheme="dark"] .skill-card-author,
html[data-color-scheme="dark"] .skill-card-stars,
html[data-color-scheme="dark"] .workbench-tool-card h3,
html[data-color-scheme="dark"] .workbench-steps strong {
  color: var(--ps-text-primary);
}

html[data-color-scheme="dark"] .skill-card p,
html[data-color-scheme="dark"] .skill-card:hover .skill-card-stars,
html[data-color-scheme="dark"] .workbench-tool-card p,
html[data-color-scheme="dark"] .workbench-steps span {
  color: var(--ps-text-secondary);
}

html[data-color-scheme="dark"] .skill-card-divider,
html[data-color-scheme="dark"] .workbench-steps li::before {
  background: var(--ps-border);
}

html[data-color-scheme="dark"] .workbench-steps li::before {
  background: url("./assets/workbench/workflow-accent.svg") center / contain no-repeat;
  filter: none;
}

html[data-color-scheme="dark"] .skill-card-author img,
html[data-color-scheme="dark"] .skills-agent-icon.is-composite {
  background: var(--ps-surface-muted);
}

html[data-color-scheme="dark"] .skills-fade {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, var(--ps-page) 50%);
}

html[data-color-scheme="dark"] .footer {
  background: transparent;
}

html[data-color-scheme="dark"] .footer-bottom {
  background: transparent;
}

html[data-color-scheme="dark"] .footer-bottom::before {
  background: #27272a;
}

html[data-color-scheme="dark"] .footer-cta {
  background: rgba(0, 0, 0, 0.1);
}

html[data-color-scheme="dark"] .footer-copy p {
  color: var(--ps-text-inverse);
}

html[data-color-scheme="dark"] .scroll-text {
  color: #52525b;
}

html[data-color-scheme="dark"] .scroll-arrow {
  content: url("./assets/figma/hero-arrow-dark.svg");
}

html[data-color-scheme="dark"] .footer-download,
html[data-color-scheme="dark"] .footer-download:hover,
html[data-color-scheme="dark"] .footer-download:focus-visible {
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .footer-download img,
html[data-color-scheme="dark"] .footer-download:hover img,
html[data-color-scheme="dark"] .footer-download:focus-visible img {
  opacity: 1;
  filter: brightness(0) invert(1);
}

html[data-color-scheme="dark"] .footer-top-button,
html[data-color-scheme="dark"] .footer-top-button:hover,
html[data-color-scheme="dark"] .footer-top-button:focus-visible {
  color: #27272a;
  border-color: rgba(24, 24, 27, 0.2);
  background: transparent;
}

html[data-color-scheme="dark"] .designer a {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .footer-legal {
  color: #52525b;
}

html[data-color-scheme="dark"] .footer-legal a:hover,
html[data-color-scheme="dark"] .footer-legal a:focus-visible {
  color: #fafafa;
  border-color: currentColor;
}

html[data-color-scheme="dark"] .footer nav img {
  filter: brightness(0) saturate(100%) invert(13%) sepia(6%) saturate(526%) hue-rotate(202deg) brightness(95%) contrast(90%);
}

html[data-color-scheme="dark"] .footer nav a:hover img,
html[data-color-scheme="dark"] .footer nav a:focus-visible img {
  opacity: 1;
  filter: brightness(0) saturate(100%) invert(99%) sepia(1%) saturate(715%) hue-rotate(176deg) brightness(103%) contrast(96%);
}

html[data-lang="en"] body.skills-body,
html[data-lang="en"] body.skills-body button,
html[data-lang="en"] body.skills-body input,
html[data-lang="en"] body.skills-body a,
html[data-lang="en"] body.skills-body .footer,
html[data-lang="en"] body.skills-body .footer-copy,
html[data-lang="en"] body.skills-body .footer-desc,
html[data-lang="en"] body.skills-body .footer-legal {
  font-family: var(--display-font);
}

html[data-lang="en"] body.skills-body .skills-hero h1,
html[data-lang="en"] body.skills-body .skill-card h2 {
  font-weight: 500;
}

html[data-lang="en"] body.skills-body .skills-hero {
  width: min(820px, calc(100vw - 48px));
  text-align: center;
}

html[data-lang="en"] body.skills-body .skills-title-wrap {
  width: 100%;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

html[data-lang="en"] body.skills-body .skills-hero h1 {
  width: 100%;
  text-align: center;
}

html[data-lang="en"] body.skills-body .skills-hero-copy {
  width: min(684px, 100%);
  margin-right: auto;
  margin-left: auto;
  text-align: center;
  text-wrap: balance;
  white-space: normal;
}

@media (min-width: 1280px) {
  html[data-lang="en"] body.skills-body .skills-hero h1 {
    white-space: nowrap;
  }
}

html[data-lang="en"] body.workbench-page .workbench-hero h1 {
  width: 684px;
}

html[data-lang="en"] body.workbench-page .workbench-hero h1 span {
  display: block;
}

html[data-color-scheme="dark"] body.skills-body {
  min-height: 100vh;
  background: #000000;
}

html[data-color-scheme="dark"] body.skills-body::before {
  position: fixed;
  inset: 0;
  z-index: 0;
  display: block;
  width: 100vw;
  height: 100vh;
  content: "";
  pointer-events: none;
  background: linear-gradient(180deg, #18181b 0, #111113 120px, #000000 320px, #000000 100%);
}

html[data-color-scheme="dark"] .skills-page {
  background: transparent;
}

html[data-color-scheme="dark"] .skills-header-bg {
  display: none;
}

@media (min-width: 1440px) {
  html[data-color-scheme="dark"] .skills-hero {
    top: 140px;
  }

  html[data-color-scheme="dark"] .skills-agent-strip {
    top: 304px;
  }

  html[data-color-scheme="dark"] .skills-directory-controls {
    top: 464px;
  }

  html[data-color-scheme="dark"] .skills-grid {
    top: 524px;
  }
}

html.is-theme-transitioning::view-transition-old(root),
html.is-theme-transitioning::view-transition-new(root) {
  animation-duration: 280ms;
  animation-timing-function: var(--ease-out-quart);
  animation-fill-mode: both;
  mix-blend-mode: normal;
}

html.is-theme-transitioning::view-transition-old(root) {
  animation-name: theme-root-fade-out;
}

html.is-theme-transitioning::view-transition-new(root) {
  animation-name: theme-root-reveal;
}

@keyframes theme-root-fade-out {
  from {
    opacity: 1;
  }

  to {
    opacity: 0.18;
  }
}

@keyframes theme-root-reveal {
  from {
    clip-path: circle(0 at var(--theme-transition-x, 50vw) var(--theme-transition-y, 50vh));
  }

  to {
    clip-path: circle(var(--theme-transition-radius, 150vmax) at var(--theme-transition-x, 50vw) var(--theme-transition-y, 50vh));
  }
}

.theme-transition-fallback {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 1;
  transition: opacity 260ms var(--ease-out-quart);
}

.theme-transition-fallback.is-leaving {
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  html.is-theme-transitioning::view-transition-old(root),
  html.is-theme-transitioning::view-transition-new(root) {
    animation: none;
  }

  .theme-transition-fallback {
    display: none;
  }
}

html[data-color-scheme="dark"] .skills-hero h1 {
  color: #fafafa;
}

html[data-color-scheme="dark"] .skills-hero-copy {
  color: #71717a;
}

html[data-color-scheme="dark"] .skills-agent-strip p {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .skills-mode-tabs button {
  border: 0;
  color: #71717a;
  background: transparent;
}

html[data-color-scheme="dark"] .skills-mode-tabs button.is-active,
html[data-color-scheme="dark"] .skills-mode-tabs button:hover,
html[data-color-scheme="dark"] .skills-mode-tabs button:focus-visible {
  color: #fafafa;
}

html[data-color-scheme="dark"] .skills-filters button {
  border-color: #27272a;
  color: #a1a1aa;
  background: #000000;
}

html[data-color-scheme="dark"] .skills-filters button.is-active,
html[data-color-scheme="dark"] .skills-filters button:hover,
html[data-color-scheme="dark"] .skills-filters button:focus-visible {
  border-color: #fafafa;
  color: #fafafa;
  background: #000000;
}

html[data-color-scheme="dark"] .skill-card {
  border-color: #27272a;
  background: #18181b;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-card:hover,
html[data-color-scheme="dark"] .skill-card:focus-visible,
html[data-color-scheme="dark"] .skill-card.is-tilting {
  border-color: #3f3f46;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-card:hover .skill-card-hover-bg,
html[data-color-scheme="dark"] .skill-card:focus-visible .skill-card-hover-bg,
html[data-color-scheme="dark"] .skill-card.is-tilting .skill-card-hover-bg {
  opacity: 0.05;
}

html[data-color-scheme="dark"] .skill-card h2,
html[data-color-scheme="dark"] .skill-card-author {
  color: #fafafa;
}

html[data-color-scheme="dark"] .skill-card p {
  color: #71717a;
}

html[data-color-scheme="dark"] .skill-card-divider {
  background: #27272a;
}

html[data-color-scheme="dark"] .skills-more {
  border-color: #27272a;
  color: #e4e4e7;
  background: #000000;
}

html[data-color-scheme="dark"] .skills-more:hover,
html[data-color-scheme="dark"] .skills-more:focus-visible {
  border-color: #52525b;
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .skills-fade {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, #000000 50%);
}

@media (min-width: 1440px) {
  :root {
    --site-nav-left: 201px;
    --site-nav-width: 332px;
    --site-search-left: 982px;
    --site-search-width: 240px;
    --site-language-left: 1238px;
    --site-theme-left: 1290px;
  }

  .site-header .site-header-download {
    display: none;
  }

  .site-header .site-header-language {
    left: var(--site-language-left);
  }

  .site-header .site-header-theme {
    left: var(--site-theme-left);
  }

  .inspiration-header .inspiration-search,
  .workbench-page .inspiration-header .inspiration-search,
  .inspiration-page > .site-header .site-header-search,
  .skills-page > .site-header .site-header-search,
  .cases-page > .site-header .site-header-search {
    left: var(--site-search-left);
    width: var(--site-search-width);
  }

  .policy-header .policy-header-language {
    left: 1260px;
  }

  .policy-header .policy-header-theme {
    left: 1312px;
  }
}

@media (min-width: 768px) and (max-width: 1439px) {
  .site-header-search,
  .site-header-language,
  .site-header-theme,
  .site-header-download {
    display: none;
  }

  html[data-lang="en"] .hero-kicker {
    left: 24px;
    top: 162px;
    font-size: 18px;
    line-height: 28px;
  }

  html[data-lang="en"] .hero-title {
    top: 196px;
  }

  html[data-lang="en"] .hero-desc {
    top: 340px;
  }

  html[data-lang="en"] .hero-actions {
    top: 436px;
  }
}

@media (max-width: 767px) {
  .site-header-search,
  .site-header-language,
  .site-header-theme,
  .site-header-download {
    display: none;
  }

  .mobile-menu-search {
    position: absolute;
    left: 16px;
    bottom: var(--mobile-menu-control-bottom);
    display: inline-flex;
    width: var(--mobile-menu-search-width);
    height: 36px;
    align-items: center;
    gap: 8px;
    padding: 0 10px 0 7px;
    border: 1px solid #e4e4e7;
    border-radius: 6px;
    color: #a1a1aa;
    background: #ffffff;
    font: 400 12px/16px var(--display-font);
    text-align: left;
    cursor: pointer;
    opacity: 0;
    transform: translate3d(0, -8px, 0);
    transition:
      opacity 260ms var(--ease-out-quart),
      transform 360ms var(--ease-out-quint),
      border-color 180ms var(--ease-out-quart),
      color 180ms var(--ease-out-quart);
    transition-delay: 250ms;
  }

  .mobile-menu-search img {
    width: 20px;
    height: 20px;
    flex: 0 0 auto;
  }

  .mobile-menu-search span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-menu-search:hover,
  .mobile-menu-search:focus-visible {
    border-color: #d4d4d8;
    color: #71717a;
    outline: none;
  }

  .mobile-menu-controls {
    position: absolute;
    left: calc(16px + var(--mobile-menu-search-width) + 8px);
    bottom: var(--mobile-menu-control-bottom);
    display: flex;
    align-items: center;
    gap: 8px;
  }

  .mobile-menu-controls .site-language-toggle,
  .mobile-menu-controls .site-theme-toggle {
    opacity: 0;
    transform: translate3d(0, -8px, 0);
    transition:
      opacity 260ms var(--ease-out-quart),
      transform 360ms var(--ease-out-quint);
    transition-delay: 250ms;
  }

  .mobile-menu-controls .site-language-toggle {
    border-color: #e4e4e7;
    background: #fafafa;
  }

  .mobile-menu-controls .site-theme-toggle {
    border-color: #e4e4e7;
    background: #f4f4f5;
  }

  .mobile-menu-controls [data-language-label] {
    display: none;
  }

  .mobile-menu.is-open .mobile-menu-search,
  .mobile-menu.is-open .mobile-menu-controls .site-language-toggle,
  .mobile-menu.is-open .mobile-menu-controls .site-theme-toggle {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }

  html[data-color-scheme="dark"] .mobile-menu-backdrop,
  html[data-color-scheme="dark"] .mobile-menu-panel {
    background: #18181b;
  }

  html[data-color-scheme="dark"] .mobile-menu-toggle {
    border-color: #27272a;
    background: #18181b;
  }

  html[data-color-scheme="dark"] .mobile-menu-toggle::before {
    background: #fafafa;
  }

  html[data-color-scheme="dark"] .mobile-menu-toggle:hover,
  html[data-color-scheme="dark"] .mobile-menu-toggle:focus-visible {
    border-color: #3f3f46;
    background: #27272a;
  }

  html[data-color-scheme="dark"] .mobile-menu-logo {
    left: 24px;
    top: 24px;
  }

  html[data-color-scheme="dark"] .mobile-menu-close,
  html[data-color-scheme="dark"] .mobile-menu-search,
  html[data-color-scheme="dark"] .mobile-menu-controls .site-language-toggle,
  html[data-color-scheme="dark"] .mobile-menu-controls .site-theme-toggle {
    border-color: #27272a;
    background: #18181b;
  }

  html[data-color-scheme="dark"] .mobile-menu-close::before {
    background: #a1a1aa;
  }

  html[data-color-scheme="dark"] .mobile-menu-nav a {
    color: #52525b;
  }

  html[data-color-scheme="dark"] .mobile-menu-nav a.is-active {
    color: #fafafa;
  }

  html[data-color-scheme="dark"] .mobile-menu-nav a.is-active::after {
    left: 0;
  }

  html[data-color-scheme="dark"] .mobile-menu-search {
    width: min(208px, calc(var(--mobile-page) - 194px));
    color: #52525b;
  }

  html[data-color-scheme="dark"] .mobile-menu-search:hover,
  html[data-color-scheme="dark"] .mobile-menu-search:focus-visible {
    color: #a1a1aa;
    border-color: #3f3f46;
  }

  html[data-color-scheme="dark"] .mobile-menu-search img {
    filter: brightness(0) saturate(100%) invert(31%) sepia(7%) saturate(573%) hue-rotate(202deg) brightness(88%) contrast(83%);
  }

  html[data-lang="en"] .hero-kicker {
    left: 16px;
    top: 86px;
    width: calc(var(--mobile-page) - 32px);
    font-size: 14px;
    line-height: 20px;
  }

  html[data-lang="en"] .accent-hero {
    display: none;
  }

  html[data-lang="en"] .hero-title {
    top: 116px;
    width: calc(var(--mobile-page) - 32px);
    height: auto;
    font-size: 36px;
    line-height: 48px;
  }

  html[data-lang="en"] .hero-title div {
    height: auto;
  }

  html[data-lang="en"] .hero-desc {
    top: 232px;
    width: calc(var(--mobile-page) - 32px);
  }

  html[data-lang="en"] .hero-actions {
    top: 320px;
  }

  html[data-lang="en"] .hero-board {
    top: 408px;
    height: 380px;
  }

  html[data-lang="en"] .board-white {
    height: 100%;
  }
}

@media (max-width: 1100px) {
  .ascii-editor-page {
    min-width: 0;
    overflow: auto;
  }

  .ascii-app {
    min-height: 1000px;
    overflow: visible;
  }

  .ascii-stage {
    inset: 88px 16px 380px;
  }

  .ascii-canvas-actions {
    max-width: calc(100% - 24px);
    flex-wrap: wrap;
  }

  .ascii-video-progress input {
    width: 120px;
  }

  .ascii-tool-rail {
    left: 16px;
    top: 16px;
    width: auto;
    min-height: 48px;
    flex-direction: row;
    transform: none;
  }

  .ascii-tool-rail::after {
    display: none;
  }

  .ascii-panel {
    top: auto;
    right: 16px;
    bottom: 16px;
    left: 16px;
    width: auto;
    height: 340px;
    max-height: 340px;
  }
}

.workbench-page .footer.workbench-shared-footer .footer-art {
  border-radius: 16px;
  background: transparent;
}

.workbench-page .footer.workbench-shared-footer .footer-cta {
  border: 0;
  background: rgba(0, 0, 0, 0.1);
  box-shadow: none;
}

.workbench-page .footer.workbench-shared-footer .footer-copy p {
  width: 684px;
  color: #fff;
  font-size: 16px;
  line-height: 24px;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-cta {
  border: 0;
  background: rgba(0, 0, 0, 0.1);
  box-shadow: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art {
  background: transparent;
}

html[data-lang="en"] body.workbench-page .workbench-hero h1 {
  width: min(920px, calc(100vw - 48px));
  max-width: 920px;
  font-size: 48px;
  line-height: 60px;
  text-wrap: normal;
}

html[data-lang="en"] body.workbench-page .workbench-hero h1 span {
  display: block;
  white-space: nowrap;
}

html[data-lang="en"] body.workbench-page .workbench-cta h2 span {
  white-space: nowrap;
}

@media (min-width: 1024px) {
  .workbench-page .workbench-cta h2 {
    font-size: 48px;
    line-height: 60px;
  }
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer {
  background: #000000;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art {
  background: #09090b;
  box-shadow: inset 0 0 0 1px rgba(250, 250, 250, 0.08);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art video,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art img {
  filter: brightness(0.52) saturate(0.72) contrast(1.08);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art::after {
  position: absolute;
  inset: 0;
  z-index: 2;
  content: "";
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0, 0, 0, 0.46) 0%, rgba(0, 0, 0, 0.24) 38%, rgba(0, 0, 0, 0.7) 100%),
    radial-gradient(circle at 78% 22%, rgba(63, 63, 70, 0.24), rgba(0, 0, 0, 0) 36%);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-cta {
  border: 1px solid rgba(250, 250, 250, 0.1);
  background: rgba(0, 0, 0, 0.42);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-copy p {
  color: rgba(250, 250, 250, 0.86);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button:hover,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button:focus-visible {
  color: rgba(250, 250, 250, 0.86);
  border-color: rgba(250, 250, 250, 0.28);
  background: transparent;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-wordmark {
  opacity: 0.14;
  filter: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-bottom {
  background: #000000;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-bottom::before {
  background: #27272a;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .designer a,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal {
  color: #71717a;
}

@media (min-width: 768px) and (max-width: 900px) {
  html[data-lang="en"] body.workbench-page .workbench-hero h1 {
    width: min(720px, 100%);
    max-width: 720px;
    font-size: 40px;
    line-height: 52px;
  }
}

@media (max-width: 767px) {
  html[data-lang="en"] body.workbench-page .workbench-hero h1 {
    width: 100%;
    max-width: 100%;
    font-size: clamp(18px, 5.25vw, 24px);
    line-height: 30px;
  }

  html[data-lang="en"] body.workbench-page .workbench-cta h2 {
    font-size: clamp(18px, 5.4vw, 22px);
    line-height: 30px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-art {
    border-radius: 12px;
  }

  .workbench-page .footer.workbench-shared-footer .footer-copy p {
    width: 100%;
    font-size: 13px;
    line-height: 20px;
  }
}

.workbench-page .footer.workbench-shared-footer {
  margin-bottom: 48px;
}

.workbench-page .footer.workbench-shared-footer .footer-wordmark {
  display: none !important;
}

@media (min-width: 768px) and (max-width: 1439px) {
  .footer.skills-footer {
    margin-bottom: 48px;
  }
}

@media (max-width: 767px) {
  .workbench-page .footer.workbench-shared-footer,
  .footer.skills-footer {
    margin-bottom: 48px;
  }
}

/* Shared dark footer, aligned to Figma 5883:14983. */
html[data-color-scheme="dark"] .footer {
  background: transparent;
}

html[data-color-scheme="dark"] .footer-art {
  border-radius: 16px;
  background: transparent;
  box-shadow: none;
}

html[data-color-scheme="dark"] .footer-art video,
html[data-color-scheme="dark"] .footer-art img {
  filter: none;
}

html[data-color-scheme="dark"] .footer-art::after {
  display: none;
}

html[data-color-scheme="dark"] .footer-cta {
  border: 0;
  background: rgba(0, 0, 0, 0.1);
  -webkit-backdrop-filter: blur(20px);
  backdrop-filter: blur(20px);
  box-shadow: none;
}

html[data-color-scheme="dark"] .footer-copy p {
  color: #ffffff;
}

html[data-color-scheme="dark"] .footer-download,
html[data-color-scheme="dark"] .footer-download:hover,
html[data-color-scheme="dark"] .footer-download:focus-visible {
  color: #fafafa;
  background: #18181b;
}

html[data-color-scheme="dark"] .footer-download img,
html[data-color-scheme="dark"] .footer-download:hover img,
html[data-color-scheme="dark"] .footer-download:focus-visible img {
  content: url("./assets/figma/footer-chrome.svg");
  opacity: 1;
  filter: none;
}

html[data-color-scheme="dark"] .footer-top-button,
html[data-color-scheme="dark"] .footer-top-button:hover,
html[data-color-scheme="dark"] .footer-top-button:focus-visible {
  color: #fafafa;
  border-color: rgba(250, 250, 250, 0.3);
  background: transparent;
}

html[data-color-scheme="dark"] .footer-bottom {
  background: transparent;
}

html[data-color-scheme="dark"] .footer-bottom::before {
  background: #27272a;
}

html[data-color-scheme="dark"] .designer,
html[data-color-scheme="dark"] .designer a {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .footer-legal {
  color: #52525b;
}

html[data-color-scheme="dark"] .footer-legal span {
  transition: color 220ms var(--ease-out-quart);
}

html[data-color-scheme="dark"] .footer-legal span:hover,
html[data-color-scheme="dark"] .footer-legal a:hover,
html[data-color-scheme="dark"] .footer-legal a:focus-visible {
  color: #e4e4e7;
  border-color: currentColor;
}

html[data-color-scheme="dark"] .footer nav img,
html[data-color-scheme="dark"] .footer nav a:hover img,
html[data-color-scheme="dark"] .footer nav a:focus-visible img {
  opacity: 1;
}

html[data-color-scheme="dark"] .footer nav img {
  filter: none;
}

html[data-color-scheme="dark"] .footer nav a:hover img,
html[data-color-scheme="dark"] .footer nav a:focus-visible img {
  filter: brightness(0) saturate(100%) invert(94%) sepia(4%) saturate(198%) hue-rotate(202deg) brightness(98%) contrast(91%);
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer {
  background: transparent;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art {
  background: transparent;
  box-shadow: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art video,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art img {
  filter: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-art::after {
  display: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-cta {
  border: 0;
  background: rgba(0, 0, 0, 0.1);
  box-shadow: none;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-copy p {
  color: #ffffff;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button:hover,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-top-button:focus-visible {
  color: #fafafa;
  border-color: rgba(250, 250, 250, 0.3);
  background: transparent;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-bottom {
  background: transparent;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-bottom::before {
  background: #27272a;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .designer a {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal {
  color: #52525b;
}

html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal span:hover,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal a:hover,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal a:focus-visible {
  color: #e4e4e7;
}

/* Focused dark-mode fixes, kept at the end to override legacy page-specific rules. */
html[data-color-scheme="dark"] .download-menu a:hover,
html[data-color-scheme="dark"] .download-menu a:focus-visible {
  color: #fafafa;
  background: #27272a;
  outline: none;
}

html[data-color-scheme="dark"] .download-menu a:hover small,
html[data-color-scheme="dark"] .download-menu a:focus-visible small {
  color: #a1a1aa;
}

@media (min-width: 1440px) {
  body.inspiration-body .inspiration-page .inspiration-hero {
    top: 140px;
  }

  body.inspiration-body .inspiration-page .inspiration-mode-tabs,
  body.inspiration-body .inspiration-page .inspiration-filters {
    top: 366px;
  }

  html[data-lang="en"] body.inspiration-body .inspiration-page .inspiration-hero {
    top: 120px;
  }

  html[data-lang="en"] body.inspiration-body .inspiration-page .inspiration-mode-tabs,
  html[data-lang="en"] body.inspiration-body .inspiration-page .inspiration-filters {
    top: 360px;
  }
}

.skill-card-stars img {
  width: 20px;
  height: 20px;
}

html[data-color-scheme="dark"],
html[data-color-scheme="dark"] body.workbench-page {
  background: #000000;
}

html[data-color-scheme="dark"] body.workbench-page::after {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  height: 160px;
  content: "";
  pointer-events: none;
  background: #000000;
}

html[data-color-scheme="dark"] body.workbench-page .workbench,
html[data-color-scheme="dark"] body.workbench-page .footer.workbench-shared-footer,
html[data-color-scheme="dark"] body.workbench-page .footer.workbench-shared-footer .footer-bottom {
  background-color: #000000;
}

html[data-color-scheme="dark"] .footer .footer-legal,
html[data-color-scheme="dark"] .footer .footer-legal span,
html[data-color-scheme="dark"] .footer .footer-legal a,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal span,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer .footer-legal a {
  color: #71717a;
}

html[data-color-scheme="dark"] .footer nav img,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer nav img {
  opacity: 1;
  filter: brightness(0) saturate(100%) invert(45%) sepia(7%) saturate(478%) hue-rotate(202deg) brightness(95%) contrast(88%);
}

html[data-color-scheme="dark"] .footer nav a:hover img,
html[data-color-scheme="dark"] .footer nav a:focus-visible img,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer nav a:hover img,
html[data-color-scheme="dark"] .workbench-page .footer.workbench-shared-footer nav a:focus-visible img {
  filter: brightness(0) saturate(100%) invert(94%) sepia(4%) saturate(198%) hue-rotate(202deg) brightness(98%) contrast(91%);
}

html[data-lang="zh-Hant"] {
  --display-font: "IBM Plex Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;
}

.site-language-menu {
  position: absolute;
  left: var(--site-language-left, 1238px);
  top: 44px;
  z-index: 80;
  display: grid;
  width: 132px;
  padding: 6px;
  border: 1px solid var(--ps-border);
  border-radius: 8px;
  background: var(--ps-surface);
  box-shadow: 0 16px 44px rgba(24, 24, 27, 0.12);
  opacity: 0;
  visibility: hidden;
  transform: translate3d(0, -6px, 0) scale(0.98);
  transform-origin: top right;
  transition:
    opacity 160ms var(--ease-out-quart),
    visibility 160ms var(--ease-out-quart),
    transform 180ms var(--ease-out-quart);
  pointer-events: none;
}

.site-language-menu.is-open {
  opacity: 1;
  visibility: visible;
  transform: translate3d(0, 0, 0) scale(1);
  pointer-events: auto;
}

.site-language-menu button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 32px;
  padding: 0 10px;
  border: 0;
  border-radius: 6px;
  color: var(--ps-text-secondary);
  background: transparent;
  font: 500 13px/20px var(--display-font);
  text-align: left;
  cursor: pointer;
  transition: color 150ms var(--ease-out-quart), background-color 150ms var(--ease-out-quart);
}

.site-language-menu button::after {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  content: "";
  background: transparent;
}

.site-language-menu button:hover,
.site-language-menu button:focus-visible {
  color: var(--ps-text-primary);
  background: var(--ps-surface-soft);
  outline: none;
}

.site-language-menu button.is-active {
  color: var(--ps-text-primary);
  background: var(--ps-control-active);
}

.site-language-menu button.is-active::after {
  background: #e879f9;
}

.policy-header .site-language-menu {
  left: 1260px;
}

.mobile-menu-controls .site-language-menu {
  left: 0;
  top: 44px;
}

html[data-color-scheme="dark"] .site-language-menu {
  border-color: #27272a;
  background: #18181b;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.42);
}

html[data-color-scheme="dark"] .site-language-menu button {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .site-language-menu button:hover,
html[data-color-scheme="dark"] .site-language-menu button:focus-visible,
html[data-color-scheme="dark"] .site-language-menu button.is-active {
  color: #fafafa;
  background: #27272a;
}

.workbench-page.motion-ready .reveal-item {
  transform: translate3d(0, 18px, 0);
  transition-duration: 360ms;
  transition-delay: min(var(--reveal-delay, 0ms), 108ms);
}

.workbench-page.motion-ready .workbench-tool-card.reveal-item,
.workbench-page.motion-ready .workbench-feature-copy.reveal-item,
.workbench-page.motion-ready .workbench-feature-image.reveal-item,
.workbench-page.motion-ready .workbench-cta.reveal-item {
  transition-timing-function: var(--ease-out-quart);
}

/* Skill detail: compact model-support count with an agent-name tooltip. */
.skill-detail-tags.skill-agent-support {
  align-items: center;
  justify-content: flex-end;
  width: max-content;
  gap: 0;
  overflow: visible;
}

.skill-detail-tags.skill-agent-support span::before {
  display: none;
  content: none;
}

.skill-agent-count {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 24px;
  padding: 0 8px;
  border: 1px solid #f4f4f5;
  border-radius: 6px;
  color: #52525b;
  background: #fafafa;
  font: 500 12px/18px "IBM Plex Sans SC", sans-serif;
  cursor: default;
  transition:
    border-color 180ms var(--ease-out-quart),
    background-color 180ms var(--ease-out-quart),
    color 180ms var(--ease-out-quart),
    box-shadow 180ms var(--ease-out-quart);
}

.skill-agent-count:hover,
.skill-agent-count:focus-visible {
  border-color: #e4e4e7;
  color: #27272a;
  background: #fff;
  box-shadow: 0 6px 16px rgba(39, 39, 42, 0.08);
  outline: none;
}

.skill-detail-tags.skill-agent-support .skill-agent-count-label {
  display: inline;
  height: auto;
  padding: 0;
  color: #a1a1aa;
  background: none;
  font: inherit;
}

.skill-detail-tags.skill-agent-support .skill-agent-count-value {
  display: inline-grid;
  place-items: center;
  width: 16px;
  height: 16px;
  padding: 0;
  border-radius: 999px;
  color: #fff;
  background: #27272a;
  font-size: 11px;
  font-weight: 600;
  line-height: 16px;
}

.skill-agent-tooltip {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 8;
  display: flex;
  align-items: center;
  gap: 6px;
  min-height: 40px;
  padding: 8px;
  border: 1px solid #e4e4e7;
  border-radius: 8px;
  color: #52525b;
  background: #fff;
  box-shadow: 0 14px 32px rgba(39, 39, 42, 0.12);
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, -4px, 0);
  transition:
    opacity 180ms var(--ease-out-quart),
    transform 220ms var(--ease-out-quart),
    visibility 180ms var(--ease-out-quart);
  visibility: hidden;
  white-space: nowrap;
}

.skill-agent-tooltip::before {
  position: absolute;
  right: 18px;
  top: -5px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #e4e4e7;
  border-left: 1px solid #e4e4e7;
  background: #fff;
  content: "";
  transform: rotate(45deg);
}

.skill-detail-tags.skill-agent-support:hover .skill-agent-tooltip,
.skill-detail-tags.skill-agent-support:focus-within .skill-agent-tooltip {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  visibility: visible;
}

.skill-detail-tags.skill-agent-support .skill-agent-tooltip span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: 24px;
  padding: 0 8px;
  border-radius: 6px;
  background-image: none;
  font-size: 12px;
  font-weight: 500;
  line-height: 18px;
}

.skill-agent-tooltip .is-codex {
  color: #3b82f6;
  background: rgba(59, 130, 246, 0.08);
}

.skill-agent-tooltip .is-claude {
  color: #d97706;
  background: rgba(217, 119, 6, 0.1);
}

html[data-color-scheme="dark"] .skill-agent-count {
  border-color: #27272a;
  color: #e4e4e7;
  background: #09090b;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-agent-count:hover,
html[data-color-scheme="dark"] .skill-agent-count:focus-visible {
  border-color: #3f3f46;
  color: #fafafa;
  background: #18181b;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-detail-tags.skill-agent-support .skill-agent-count-label {
  color: #a1a1aa;
}

html[data-color-scheme="dark"] .skill-detail-tags.skill-agent-support .skill-agent-count-value {
  color: #18181b;
  background: #fafafa;
}

html[data-color-scheme="dark"] .skill-agent-tooltip {
  border-color: #27272a;
  color: #e4e4e7;
  background: #09090b;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.36);
}

html[data-color-scheme="dark"] .skill-agent-tooltip::before {
  border-color: #27272a;
  background: #09090b;
}

html[data-color-scheme="dark"] .skill-detail-tags.skill-agent-support .skill-agent-tooltip span {
  background-image: none;
  box-shadow: none;
}

html[data-color-scheme="dark"] .skill-agent-tooltip .is-codex {
  color: #93c5fd;
  background: rgba(96, 165, 250, 0.14);
}

html[data-color-scheme="dark"] .skill-agent-tooltip .is-claude {
  color: #fbbf24;
  background: rgba(251, 191, 36, 0.14);
}

@media (max-width: 767px) {
  .skill-detail-tags.skill-agent-support {
    position: relative;
    left: auto;
    right: auto;
    top: auto;
    justify-content: flex-start;
    margin-top: 12px;
  }

  .skill-agent-tooltip {
    left: 0;
    right: auto;
    max-width: calc(100vw - 48px);
    flex-wrap: wrap;
    white-space: normal;
  }

  .skill-agent-tooltip::before {
    left: 20px;
    right: auto;
  }
}

@media (max-width: 731px) {
  .skill-detail-tags.skill-agent-support {
    position: absolute;
    left: auto;
    right: 16px;
    top: 129px;
    justify-content: flex-end;
    margin: 0;
  }

  .skill-agent-tooltip {
    left: auto;
    right: 0;
    max-width: calc(100vw - 32px);
  }

  .skill-agent-tooltip::before {
    left: auto;
    right: 18px;
  }
}

@media (min-width: 768px) {
  html[data-color-scheme="dark"] .skills-agent-strip p {
    margin-bottom: 16px;
  }
}

@media (min-width: 768px) and (max-width: 1439px) {
  html[data-color-scheme="dark"] .skills-directory-controls {
    margin-top: 80px;
  }
}

@media (min-width: 1440px) {
  html[data-color-scheme="dark"] .skills-hero {
    top: 140px;
  }

  html[data-color-scheme="dark"] .skills-agent-strip {
    top: 304px;
  }

  html[data-color-scheme="dark"] .skills-directory-controls {
    top: 464px;
  }

  html[data-color-scheme="dark"] .skills-grid {
    top: 524px;
  }
}
