/*
 * Home AI Philosophy
 * Runtime styles for the exhibition room section.
 */

.s-home-ai-philosophy {
  /* Section palette sampled from the generated exhibition assets. */
  --aiphil-ink: hsl(28, 31%, 13%);
  --aiphil-ink-soft: hsl(30, 24%, 24%);
  --aiphil-paper: hsl(41, 46%, 91%);
  --aiphil-paper-deep: hsl(38, 38%, 82%);
  --aiphil-brass: hsl(39, 54%, 48%);
  --aiphil-brass-dark: hsl(31, 39%, 29%);
  --aiphil-board: hsl(27, 24%, 13%);
  --aiphil-board-soft: hsl(28, 23%, 19%);
  --aiphil-teal: hsl(183, 57%, 54%);
  --aiphil-amber: hsl(38, 78%, 63%);
  --aiphil-forest: hsl(129, 29%, 40%);
  --aiphil-stage-shadow: hsla(25, 28%, 10%, 0.32);
  --ai-comment-current: var(--aiphil-teal);
  --ai-comment-current-glow: hsla(183, 57%, 54%, 0.48);
  position: relative;
  overflow: hidden;
  padding: 0;
  color: var(--aiphil-ink);
  background:
    radial-gradient(
      circle at 50% 0%,
      hsla(39, 76%, 88%, 0.34),
      transparent 28rem
    ),
    linear-gradient(180deg, hsl(39, 43%, 87%), hsl(35, 36%, 72%));
}

.s-home-ai-philosophy[data-ai-philosophy-active-cat="T"] {
  --ai-comment-current: var(--aiphil-amber);
  --ai-comment-current-glow: hsla(38, 78%, 63%, 0.5);
}

.s-home-ai-philosophy[data-ai-philosophy-active-cat="D"] {
  --ai-comment-current: hsl(129, 34%, 52%);
  --ai-comment-current-glow: hsla(129, 34%, 48%, 0.48);
}

.s-home-ai-philosophy[data-ai-philosophy-active-cat="S"] {
  --ai-comment-current: var(--aiphil-teal);
  --ai-comment-current-glow: hsla(183, 57%, 54%, 0.48);
}

.s-home-ai-philosophy {
  position: relative;
  min-height: clamp(51rem, 62vw, 60rem);
}

.s-home-ai-philosophy__stage {
  position: relative;
  min-height: inherit;
  width: min(100%, 104rem);
  margin-inline: auto;
  overflow: hidden;
  isolation: isolate;
  background-image:
    radial-gradient(
      circle at 50% 19%,
      hsla(43, 92%, 86%, 0.34),
      transparent 27rem
    ),
    linear-gradient(180deg, hsla(42, 70%, 96%, 0.08), hsla(28, 26%, 18%, 0.08)),
    var(--aiphil-bg);
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: cover;
  box-shadow:
    inset 0 1px 0 hsla(44, 70%, 96%, 0.32),
    0 1.2rem 3rem hsla(25, 28%, 10%, 0.13);
}

.s-home-ai-philosophy__stage::before,
.s-home-ai-philosophy__stage::after {
  display: none;
}

.s-home-ai-philosophy__stage::before {
  background:
    linear-gradient(
      90deg,
      hsla(190, 70%, 70%, 0.16),
      transparent 8%,
      transparent 92%,
      hsla(190, 70%, 70%, 0.14)
    ),
    linear-gradient(
      180deg,
      hsla(25, 22%, 8%, 0.16),
      transparent 12%,
      transparent 86%,
      hsla(25, 22%, 8%, 0.24)
    );
  mix-blend-mode: multiply;
}

.s-home-ai-philosophy__stage::after {
  inset: var(--space-3, 0.75rem);
  border: 1px solid hsla(184, 65%, 78%, 0.22);
  border-radius: var(--radius-lg, 1rem);
  background:
    linear-gradient(
      128deg,
      transparent 0 6%,
      hsla(185, 75%, 83%, 0.18) 7%,
      transparent 16%
    ),
    linear-gradient(
      312deg,
      transparent 0 8%,
      hsla(185, 75%, 83%, 0.1) 9%,
      transparent 18%
    );
}

.s-home-ai-philosophy__side-prop {
  display: none;
}

.s-home-ai-philosophy__side-prop--left {
  left: max(-1.2rem, calc((100% - 72rem) / 2 - 0.4rem));
}

.s-home-ai-philosophy__side-prop--right {
  right: max(-1.2rem, calc((100% - 72rem) / 2 - 0.4rem));
}

.s-home-ai-philosophy__header {
  position: absolute;
  top: clamp(1.8rem, 3vw, 3rem);
  left: clamp(2rem, 6vw, 6.5rem);
  z-index: 6;
  width: min(42%, 35rem);
  transform: none;
}

.s-home-ai-philosophy__plaque {
  position: relative;
  display: block;
  min-width: 0;
  padding: clamp(var(--space-3, 0.75rem), 1.3vw, var(--space-4, 1rem))
    clamp(var(--space-5, 1.5rem), 3vw, var(--space-7, 3rem));
  border: 1px solid hsla(30, 35%, 22%, 0.62);
  border-radius: 0.55rem;
  color: var(--aiphil-ink);
  background: linear-gradient(
    180deg,
    hsl(44, 66%, 75%),
    hsl(38, 48%, 58%) 55%,
    hsl(32, 38%, 43%)
  );
  box-shadow:
    inset 0 1px 0 hsla(50, 90%, 92%, 0.58),
    inset 0 -1px 0 hsla(25, 30%, 18%, 0.28),
    0 0.45rem 1.1rem hsla(25, 26%, 13%, 0.2);
  text-align: left;
}

.s-home-ai-philosophy__plaque::before,
.s-home-ai-philosophy__plaque::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 0.42rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: hsl(32, 42%, 32%);
  box-shadow: inset 0 1px 0 hsla(50, 80%, 88%, 0.68);
  transform: translateY(-50%);
}

.s-home-ai-philosophy__plaque::before {
  left: var(--space-2, 0.5rem);
}
.s-home-ai-philosophy__plaque::after {
  right: var(--space-2, 0.5rem);
}

.s-home-ai-philosophy__eyebrow {
  display: block;
  margin: 0;
  font-size: clamp(0.72rem, 0.9vw, 0.86rem);
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}

.s-home-ai-philosophy__title {
  margin: var(--space-1, 0.25rem) 0 0;
  font-size: clamp(1rem, 1.45vw, 1.35rem);
  line-height: 1.45;
  letter-spacing: 0.02em;
  text-wrap: pretty;
}

.s-home-ai-philosophy__art-area {
  position: absolute;
  top: clamp(7.2rem, 9vw, 8.6rem);
  left: clamp(2rem, 8vw, 7rem);
  z-index: 5;
  width: clamp(30rem, 43vw, 45rem);
  transform: none;
}

.s-home-ai-philosophy__art {
  position: relative;
  margin: 0;
}

.s-home-ai-philosophy__artwork {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  filter: drop-shadow(0 1.1rem 1.4rem hsla(25, 28%, 11%, 0.28))
    drop-shadow(0 0 2rem hsla(42, 88%, 72%, 0.18));
}

.s-home-ai-philosophy__caption {
  position: relative;
  width: min(78%, 31rem);
  margin: clamp(-2.1rem, -3vw, -1.3rem) auto 0;
  padding: clamp(var(--space-3, 0.75rem), 1.3vw, var(--space-4, 1rem))
    clamp(var(--space-4, 1rem), 2vw, var(--space-5, 1.5rem));
  border: 1px solid hsla(31, 34%, 34%, 0.52);
  border-radius: 0.45rem;
  color: var(--aiphil-ink-soft);
  background: linear-gradient(
    180deg,
    hsla(43, 62%, 95%, 0.98),
    hsla(38, 46%, 88%, 0.98)
  );
  box-shadow:
    inset 0 1px 0 hsla(48, 86%, 98%, 0.74),
    0 0.55rem 1.4rem hsla(25, 25%, 12%, 0.17);
}

.s-home-ai-philosophy__caption::before,
.s-home-ai-philosophy__caption::after {
  content: "";
  position: absolute;
  top: var(--space-3, 0.75rem);
  width: 0.42rem;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--aiphil-brass);
  box-shadow: inset 0 1px 0 hsla(50, 90%, 90%, 0.72);
}

.s-home-ai-philosophy__caption::before {
  left: var(--space-3, 0.75rem);
}
.s-home-ai-philosophy__caption::after {
  right: var(--space-3, 0.75rem);
}

.s-home-ai-philosophy__caption-title {
  margin: 0;
  font-size: clamp(1rem, 1.45vw, 1.24rem);
  line-height: 1.35;
  letter-spacing: 0.05em;
}

.s-home-ai-philosophy__caption-credit {
  margin: var(--space-1, 0.25rem) 0 0;
  font-size: 0.78rem;
  line-height: 1.55;
  font-weight: 700;
}

.s-home-ai-philosophy__caption-rule {
  display: block;
  width: min(100%, 20rem);
  height: 1px;
  margin: var(--space-2, 0.5rem) auto;
  background: linear-gradient(
    90deg,
    transparent,
    hsla(30, 28%, 30%, 0.5),
    transparent
  );
}

.s-home-ai-philosophy__caption-text {
  margin: 0;
  font-size: clamp(0.76rem, 1.05vw, 0.86rem);
  line-height: 1.75;
  text-wrap: pretty;
}

.s-home-ai-philosophy__cats {
  position: absolute;
  left: 50%;
  bottom: clamp(13rem, 15vw, 15.8rem);
  z-index: 7;
  display: none;
  width: clamp(13rem, 19vw, 17rem);
  margin: 0;
  transform: translateX(-50%);
}

.s-home-ai-philosophy__desk-cats {
  position: absolute;
  right: clamp(2rem, 9vw, 8rem);
  bottom: clamp(12.6rem, 15vw, 15rem);
  z-index: 8;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: clamp(24rem, 34vw, 36rem);
  margin: 0;
  pointer-events: none;
}

.s-home-ai-philosophy__desk-cat {
  display: block;
  width: auto;
  height: clamp(13rem, 18vw, 18.2rem);
  object-fit: contain;
  filter: drop-shadow(0 1rem 1.3rem hsla(25, 26%, 10%, 0.28))
    drop-shadow(0 0 1rem hsla(42, 80%, 80%, 0.12));
}

.s-home-ai-philosophy__desk-cat--toto {
  height: clamp(13rem, 18vw, 18.8rem);
  margin-right: clamp(-4.8rem, -5.2vw, -3.5rem);
  transform: translateY(0.1rem) rotate(-1.5deg);
}

.s-home-ai-philosophy__desk-cat--dora {
  height: clamp(12.4rem, 17vw, 17.5rem);
  margin-right: clamp(-3.8rem, -4.2vw, -2.7rem);
  transform: translateY(0.2rem);
}

.s-home-ai-philosophy__desk-cat--shimagi {
  height: clamp(13.4rem, 18.5vw, 19.3rem);
  transform: translateY(0.15rem) rotate(1deg);
}

.s-home-ai-philosophy__cats-img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 956 / 840;
  object-fit: contain;
  filter: drop-shadow(0 1rem 1.2rem hsla(25, 26%, 10%, 0.28))
    drop-shadow(0 0 1rem hsla(42, 80%, 80%, 0.18));
}

.s-home-ai-philosophy__comment {
  display: none;
}

.s-home-ai-philosophy__comment--T {
  left: calc(50% - min(31vw, 26rem));
  bottom: clamp(19rem, 21vw, 22rem);
}

.s-home-ai-philosophy__comment--D {
  left: 50%;
  bottom: clamp(17.2rem, 18.5vw, 19.2rem);
  transform: translateX(-50%);
}

.s-home-ai-philosophy__comment--S {
  right: calc(50% - min(31vw, 26rem));
  bottom: clamp(19rem, 21vw, 22rem);
}

.s-home-ai-philosophy__comment--teal {
  border-color: hsla(183, 55%, 56%, 0.62);
}
.s-home-ai-philosophy__comment--amber {
  border-color: hsla(38, 70%, 58%, 0.66);
}
.s-home-ai-philosophy__comment--forest {
  border-color: hsla(129, 34%, 48%, 0.64);
}

.s-home-ai-philosophy__comment-name {
  position: absolute;
  top: -0.62rem;
  left: var(--space-2, 0.5rem);
  padding: 0.1rem 0.48rem;
  border: 1px solid currentColor;
  border-radius: 0.2rem;
  color: inherit;
  background: hsl(25, 22%, 13%);
  font-size: 0.66rem;
  font-weight: 800;
  line-height: 1.2;
}

.s-home-ai-philosophy__comment-text {
  margin: 0;
  font-size: clamp(0.72rem, 1vw, 0.82rem);
  line-height: 1.56;
  text-wrap: pretty;
}

.s-home-ai-philosophy__comment::before,
.s-home-ai-philosophy__comment::after {
  content: "";
  position: absolute;
  width: 0.44rem;
  height: 0.44rem;
  border: 1px solid currentColor;
  opacity: 0.72;
}

.s-home-ai-philosophy__comment::before {
  top: 4px;
  left: 4px;
  border-right: none;
  border-bottom: none;
}

.s-home-ai-philosophy__comment::after {
  right: 4px;
  bottom: 4px;
  border-top: none;
  border-left: none;
}

.s-home-ai-philosophy__mobile-dialogue {
  position: absolute;
  right: clamp(2rem, 10vw, 9.5rem);
  bottom: clamp(31rem, 35vw, 34rem);
  z-index: 8;
  display: block;
  width: clamp(16rem, 24vw, 22rem);
}

.s-home-ai-philosophy__comment-status {
  position: relative;
  display: none;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 0.45rem;
  align-items: center;
  overflow: hidden;
  margin-bottom: 0.45rem;
  padding: 0.34rem 0.58rem 0.44rem;
  border: 1px solid hsla(42, 58%, 66%, 0.46);
  border-radius: 0.28rem;
  background: linear-gradient(
    180deg,
    hsla(172, 28%, 16%, 0.94),
    hsla(26, 25%, 12%, 0.96)
  );
  color: hsl(42, 48%, 88%);
  box-shadow:
    inset 0 1px 0 hsla(42, 58%, 78%, 0.13),
    0 0.45rem 1rem hsla(25, 25%, 10%, 0.2);
  font-size: clamp(0.68rem, 0.82vw, 0.76rem);
  font-weight: 800;
  line-height: 1.25;
  pointer-events: auto;
}

.s-home-ai-philosophy.is-comment-auto
  .s-home-ai-philosophy__comment-status {
  display: grid;
}

.s-home-ai-philosophy__comment-status::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    hsl(171, 52%, 57%),
    hsl(42, 78%, 68%),
    hsl(96, 42%, 58%)
  );
  transform: scaleX(0);
  transform-origin: left center;
}

.s-home-ai-philosophy.is-comment-ticking
  .s-home-ai-philosophy__comment-status::after {
  animation: homeAiCommentProgress var(--ai-comment-progress-duration, 4200ms)
    linear forwards;
}

.s-home-ai-philosophy.is-comment-paused
  .s-home-ai-philosophy__comment-status {
  border-color: hsla(42, 72%, 70%, 0.62);
}

.s-home-ai-philosophy.is-comment-paused
  .s-home-ai-philosophy__comment-status::after {
  opacity: 0.58;
  animation-play-state: paused;
}

.s-home-ai-philosophy__comment-status-dot {
  display: block;
  width: 0.48rem;
  aspect-ratio: 1;
  border-radius: 999px;
  background: var(--ai-comment-current);
  box-shadow: 0 0 0.55rem var(--ai-comment-current-glow);
  animation: homeAiCommentStatusDot 1.6s ease-in-out infinite;
}

.s-home-ai-philosophy.is-comment-paused
  .s-home-ai-philosophy__comment-status-dot {
  opacity: 0.7;
  animation: none;
}

.s-home-ai-philosophy__comment-status-text {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.s-home-ai-philosophy__comment-status-count {
  color: var(--ai-comment-current);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.s-home-ai-philosophy__mobile-card {
  --ai-card-border: hsla(38, 42%, 52%, 0.58);
  --ai-card-accent-soft: hsla(38, 35%, 50%, 0.14);
  --ai-card-accent-glow: hsla(38, 35%, 50%, 0.1);
  --ai-card-name: hsl(42, 46%, 88%);
  position: relative;
  padding: clamp(var(--space-3, 0.75rem), 1.3vw, var(--space-4, 1rem));
  border: 1.5px solid var(--ai-card-border);
  border-radius: 0.28rem;
  color: hsl(42, 46%, 88%);
  background:
    radial-gradient(
      circle at 16% 0%,
      var(--ai-card-accent-glow),
      transparent 54%
    ),
    linear-gradient(180deg, hsla(25, 21%, 18%, 0.95), hsla(26, 25%, 12%, 0.97));
  box-shadow:
    inset 0 0 0 2px hsla(25, 20%, 9%, 0.72),
    inset 0 0 0 3px var(--ai-card-accent-soft),
    0 0.65rem 1.3rem hsla(25, 25%, 10%, 0.24);
}

.s-home-ai-philosophy__mobile-card--teal {
  --ai-card-border: hsla(183, 55%, 56%, 0.68);
  --ai-card-accent-soft: hsla(183, 55%, 56%, 0.14);
  --ai-card-accent-glow: hsla(183, 55%, 56%, 0.18);
  --ai-card-name: hsl(183, 62%, 76%);
}

.s-home-ai-philosophy__mobile-card--amber {
  --ai-card-border: hsla(38, 72%, 62%, 0.72);
  --ai-card-accent-soft: hsla(38, 72%, 62%, 0.16);
  --ai-card-accent-glow: hsla(38, 72%, 62%, 0.2);
  --ai-card-name: hsl(42, 82%, 78%);
}

.s-home-ai-philosophy__mobile-card--forest {
  --ai-card-border: hsla(129, 36%, 52%, 0.68);
  --ai-card-accent-soft: hsla(129, 36%, 52%, 0.14);
  --ai-card-accent-glow: hsla(129, 36%, 52%, 0.18);
  --ai-card-name: hsl(116, 42%, 74%);
}

.s-home-ai-philosophy.is-comment-ready
  .s-home-ai-philosophy__mobile-card:not(.is-active) {
  display: none;
}

.s-home-ai-philosophy__mobile-name {
  display: inline-block;
  margin-bottom: var(--space-2, 0.5rem);
  padding: 0.12rem 0.55rem;
  border: 1px solid var(--ai-card-border);
  border-radius: 0.2rem;
  color: var(--ai-card-name);
  background:
    linear-gradient(180deg, hsla(25, 22%, 13%, 0.96), hsla(25, 22%, 10%, 0.96)),
    var(--ai-card-accent-glow);
  font-size: 0.74rem;
  font-weight: 800;
  line-height: 1.2;
}

.s-home-ai-philosophy__mobile-text {
  margin: 0;
  font-size: clamp(0.82rem, 1.1vw, 0.96rem);
  line-height: 1.65;
  text-wrap: pretty;
}

.s-home-ai-philosophy__cat-hit {
  display: none;
}

.s-home-ai-philosophy__statement {
  position: absolute;
  left: auto;
  right: clamp(2rem, 8vw, 7rem);
  bottom: clamp(var(--space-4, 1rem), 2.4vw, var(--space-7, 3rem));
  z-index: 9;
  width: clamp(31rem, 42vw, 46rem);
  transform: none;
}

.s-home-ai-philosophy__statement-frame {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1750 / 537;
  object-fit: fill;
  filter: drop-shadow(0 0.8rem 1.5rem hsla(25, 26%, 8%, 0.34));
}

.s-home-ai-philosophy__statement-copy {
  position: absolute;
  inset: 22% 8.5% 20%;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.s-home-ai-philosophy__statement-lead {
  margin: 0;
  color: hsl(42, 62%, 86%);
  font-size: clamp(1.28rem, 2.35vw, 2.05rem);
  font-weight: 800;
  line-height: 1.25;
  letter-spacing: 0.04em;
  white-space: nowrap;
  text-wrap: pretty;
  text-shadow: 0 0 1rem hsla(42, 90%, 72%, 0.2);
}

.s-home-ai-philosophy__statement-body {
  width: min(100%, 34rem);
  margin: clamp(var(--space-1, 0.25rem), 0.9vw, var(--space-3, 0.75rem)) 0 0;
  color: hsla(42, 42%, 85%, 0.9);
  font-size: clamp(0.78rem, 1.05vw, 0.96rem);
  line-height: 1.72;
  text-wrap: pretty;
}

.s-home-ai-philosophy__console-edge {
  display: none;
}

.s-home-ai-philosophy__fade {
  opacity: 1;
}

.js-ready .s-home-ai-philosophy__fade {
  opacity: 1;
}

.js-ready .s-home-ai-philosophy__fade.is-visible {
  opacity: 1;
}

.s-home-ai-philosophy__fade--d1 {
  transition-delay: 0.12s;
}
.s-home-ai-philosophy__fade--d2 {
  transition-delay: 0.24s;
}
.s-home-ai-philosophy__fade--d3 {
  transition-delay: 0.36s;
}

@keyframes homeAiCommentProgress {
  from {
    transform: scaleX(0);
  }
  to {
    transform: scaleX(1);
  }
}

@keyframes homeAiCommentStatusDot {
  0%,
  100% {
    opacity: 0.58;
    transform: scale(0.82);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
}

@media (min-width: 961px) {
  .s-home-ai-philosophy {
    min-height: clamp(52rem, 66vw, 64rem);
  }

  .s-home-ai-philosophy__stage {
    width: min(100%, 106rem);
    background-position: center bottom;
  }

  .s-home-ai-philosophy__stage::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    display: block;
    pointer-events: none;
    background:
      radial-gradient(
        ellipse at 31% 42%,
        hsla(43, 94%, 86%, 0.24),
        transparent 33rem
      ),
      linear-gradient(
        180deg,
        hsla(42, 64%, 92%, 0.1),
        transparent 52%,
        hsla(27, 34%, 24%, 0.12)
      );
  }

  .s-home-ai-philosophy__header {
    top: clamp(2rem, 3vw, 3.2rem);
    right: clamp(1.6rem, 5vw, 5rem);
    left: auto;
    width: clamp(24rem, 31vw, 34rem);
  }

  .s-home-ai-philosophy__plaque {
    padding: clamp(1.08rem, 1.58vw, 1.38rem) clamp(2.35rem, 3.7vw, 3.9rem);
    border-color: hsla(28, 33%, 17%, 0.8);
    color: hsl(42, 58%, 92%);
    background-image:
      linear-gradient(
        180deg,
        hsla(35, 34%, 32%, 0.22),
        hsla(25, 42%, 17%, 0.38)
      ),
      linear-gradient(
        90deg,
        hsla(34, 34%, 12%, 0.2),
        transparent 16%,
        transparent 84%,
        hsla(34, 34%, 12%, 0.24)
      ),
      var(--aiphil-header-wood);
    background-repeat: no-repeat, no-repeat, repeat;
    background-position: center, center, center;
    background-size:
      cover,
      cover,
      38rem auto;
    box-shadow:
      inset 0 1px 0 hsla(43, 52%, 78%, 0.34),
      inset 0 -1px 0 hsla(25, 48%, 10%, 0.62),
      0 0.55rem 1.2rem hsla(25, 26%, 13%, 0.25);
    text-shadow: 0 1px 1px hsla(25, 32%, 8%, 0.74);
  }

  .s-home-ai-philosophy__plaque::before,
  .s-home-ai-philosophy__plaque::after {
    background: hsl(39, 54%, 58%);
    box-shadow:
      inset 0 1px 0 hsla(50, 88%, 88%, 0.78),
      0 1px 2px hsla(25, 35%, 8%, 0.48);
  }

  .s-home-ai-philosophy__title {
    color: hsl(42, 58%, 92%);
    font-size: clamp(1.3rem, 1.9vw, 1.75rem);
    font-weight: 800;
    line-height: 1.3;
    letter-spacing: 0;
  }

  .s-home-ai-philosophy__title-line {
    display: block;
  }

  .s-home-ai-philosophy__eyebrow {
    color: hsla(42, 58%, 92%, 0.88);
    font-size: clamp(0.82rem, 1.05vw, 1rem);
  }

  .s-home-ai-philosophy__art-area {
    top: clamp(2rem, 3vw, 3.2rem);
    left: clamp(1.5rem, 4.2vw, 4.6rem);
    width: clamp(38rem, 55vw, 56.5rem);
  }

  .s-home-ai-philosophy__caption {
    position: absolute;
    left: 50%;
    bottom: -3.4rem;
    z-index: 4;
    width: min(70%, 33rem);
    margin: 0;
    transform: translateX(-50%);
    backdrop-filter: blur(2px);
  }

  .s-home-ai-philosophy__mobile-dialogue {
    right: clamp(4rem, 10vw, 10rem);
    bottom: clamp(28.4rem, 31vw, 31.6rem);
    width: clamp(17rem, 22vw, 21.5rem);
  }

  .s-home-ai-philosophy__desk-cats {
    right: clamp(1.3rem, 4.9vw, 4.6rem);
    bottom: clamp(11rem, 12.7vw, 12.9rem);
    width: clamp(20rem, 26vw, 28.5rem);
  }

  .s-home-ai-philosophy__desk-cat--toto {
    height: clamp(12.1rem, 16.3vw, 17rem);
    margin-right: clamp(-7.5rem, -6.8vw, -5.7rem);
    transform: translateY(0.3rem) rotate(-2deg);
  }

  .s-home-ai-philosophy__desk-cat--dora {
    height: clamp(11.6rem, 15.6vw, 16.1rem);
    margin-right: clamp(-6.3rem, -5.8vw, -4.9rem);
    transform: translateY(0.45rem);
  }

  .s-home-ai-philosophy__desk-cat--shimagi {
    height: clamp(12.2rem, 16.8vw, 17.5rem);
    transform: translateY(0.35rem) rotate(1.2deg);
  }

  .s-home-ai-philosophy__statement {
    right: clamp(0.75rem, 3.6vw, 3.3rem);
    bottom: clamp(2.25rem, 3vw, 3.1rem);
    width: clamp(28.5rem, 37vw, 39rem);
  }

  .s-home-ai-philosophy__statement::before {
    content: "";
    position: absolute;
    top: -0.28rem;
    left: 9%;
    right: 9%;
    height: 0.34rem;
    border-radius: 999px;
    background: linear-gradient(
      90deg,
      transparent,
      hsla(183, 62%, 58%, 0.48),
      hsla(39, 55%, 56%, 0.46),
      transparent
    );
    filter: blur(0.5px);
    opacity: 0.78;
  }

  .s-home-ai-philosophy__statement-copy {
    inset: 21% 9% 20%;
  }

  .s-home-ai-philosophy__statement-lead {
    font-size: clamp(1.22rem, 2vw, 1.82rem);
    letter-spacing: 0;
  }

  .s-home-ai-philosophy__statement-body {
    width: min(100%, 31rem);
    font-size: clamp(0.76rem, 0.94vw, 0.9rem);
  }
}

@media (max-width: 960px) {
  .s-home-ai-philosophy {
    min-height: clamp(78rem, 150vw, 90rem);
  }

  .s-home-ai-philosophy__side-prop {
    display: none;
  }

  .s-home-ai-philosophy__header {
    top: clamp(1.6rem, 3vw, 2.6rem);
    left: 50%;
    width: min(84%, 36rem);
    transform: translateX(-50%);
  }

  .s-home-ai-philosophy__plaque {
    border-color: hsla(28, 33%, 17%, 0.8);
    color: hsl(42, 58%, 92%);
    background-image:
      linear-gradient(
        180deg,
        hsla(35, 34%, 32%, 0.22),
        hsla(25, 42%, 17%, 0.38)
      ),
      linear-gradient(
        90deg,
        hsla(34, 34%, 12%, 0.2),
        transparent 16%,
        transparent 84%,
        hsla(34, 34%, 12%, 0.24)
      ),
      var(--aiphil-header-wood);
    background-repeat: no-repeat, no-repeat, repeat;
    background-position: center, center, center;
    background-size:
      cover,
      cover,
      34rem auto;
    box-shadow:
      inset 0 1px 0 hsla(43, 52%, 78%, 0.34),
      inset 0 -1px 0 hsla(25, 48%, 10%, 0.62),
      0 0.55rem 1.2rem hsla(25, 26%, 13%, 0.25);
    text-shadow: 0 1px 1px hsla(25, 32%, 8%, 0.74);
    text-align: center;
  }

  .s-home-ai-philosophy__plaque::before,
  .s-home-ai-philosophy__plaque::after {
    background: hsl(39, 54%, 58%);
    box-shadow:
      inset 0 1px 0 hsla(50, 88%, 88%, 0.78),
      0 1px 2px hsla(25, 35%, 8%, 0.48);
  }

  .s-home-ai-philosophy__eyebrow {
    color: hsla(42, 58%, 92%, 0.88);
  }

  .s-home-ai-philosophy__title {
    color: hsl(42, 58%, 92%);
    letter-spacing: 0;
  }

  .s-home-ai-philosophy__art-area {
    top: clamp(7rem, 10vw, 8.8rem);
    left: 50%;
    width: clamp(28rem, 68vw, 38rem);
    transform: translateX(-50%);
  }

  .s-home-ai-philosophy__comment {
    width: min(24vw, 12rem);
  }

  .s-home-ai-philosophy__desk-cats {
    display: none;
  }

  .s-home-ai-philosophy__cats {
    display: block;
    bottom: clamp(13rem, 19vw, 16rem);
  }

  .s-home-ai-philosophy__mobile-dialogue {
    right: auto;
    left: 50%;
    bottom: clamp(22rem, 32vw, 24.5rem);
    width: min(88%, 25rem);
    transform: translateX(-50%);
  }

  .s-home-ai-philosophy__statement {
    right: auto;
    left: 50%;
    width: min(86%, 50rem);
    transform: translateX(-50%);
  }
}

@media (max-width: 760px) {
  .s-home-ai-philosophy {
    background: linear-gradient(180deg, hsl(39, 44%, 87%), hsl(32, 33%, 69%));
  }

  .s-home-ai-philosophy {
    min-height: clamp(68rem, 216vw, 78rem);
  }

  .s-home-ai-philosophy__stage {
    width: 100%;
    background-position: center bottom;
    border-radius: 0;
  }

  .s-home-ai-philosophy__stage::after {
    inset: var(--space-2, 0.5rem);
    border-radius: var(--radius-md, 0.75rem);
  }

  .s-home-ai-philosophy__side-prop {
    display: none;
  }

  .s-home-ai-philosophy__header {
    top: var(--space-4, 1rem);
    left: 50%;
    width: min(90%, 24rem);
  }

  .s-home-ai-philosophy__plaque {
    min-width: 0;
    padding: var(--space-2, 0.5rem) var(--space-4, 1rem);
  }

  .s-home-ai-philosophy__eyebrow {
    font-size: 0.68rem;
  }

  .s-home-ai-philosophy__title {
    font-size: 0.92rem;
  }

  .s-home-ai-philosophy__art-area {
    top: 8.7rem;
    width: min(88%, 24.5rem);
  }

  .s-home-ai-philosophy__caption {
    width: 92%;
    margin-top: -1.2rem;
    padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
  }

  .s-home-ai-philosophy__caption-title {
    font-size: 1rem;
  }

  .s-home-ai-philosophy__caption-credit,
  .s-home-ai-philosophy__caption-text {
    font-size: 0.74rem;
    line-height: 1.62;
  }

  .s-home-ai-philosophy__comment {
    display: none;
  }

  .s-home-ai-philosophy__mobile-dialogue {
    position: absolute;
    left: 50%;
    bottom: clamp(14rem, 38vw, 16.5rem);
    z-index: 8;
    display: block;
    width: min(84%, 24rem);
    transform: translateX(-50%);
    pointer-events: none;
  }

  .s-home-ai-philosophy.is-comment-auto
    .s-home-ai-philosophy__comment-status {
    display: none;
  }

  .s-home-ai-philosophy__mobile-card {
    position: relative;
    padding: var(--space-3, 0.75rem) var(--space-4, 1rem);
    border: 1.5px solid var(--ai-card-border);
    border-radius: 0.28rem;
    color: hsl(42, 46%, 88%);
    background:
      radial-gradient(
        circle at 16% 0%,
        var(--ai-card-accent-glow),
        transparent 54%
      ),
      linear-gradient(180deg, hsla(25, 21%, 18%, 0.95), hsla(26, 25%, 12%, 0.97));
    box-shadow:
      inset 0 0 0 2px hsla(25, 20%, 9%, 0.72),
      inset 0 0 0 3px var(--ai-card-accent-soft),
      0 0.65rem 1.3rem hsla(25, 25%, 10%, 0.24);
  }

  .s-home-ai-philosophy.is-comment-ready
    .s-home-ai-philosophy__mobile-card:not(.is-active) {
    display: none;
  }

  .s-home-ai-philosophy__mobile-name {
    display: inline-block;
    margin-bottom: var(--space-1, 0.25rem);
    padding: 0.12rem 0.55rem;
    border: 1px solid var(--ai-card-border);
    border-radius: 0.2rem;
    color: var(--ai-card-name);
    background:
      linear-gradient(180deg, hsla(25, 22%, 13%, 0.96), hsla(25, 22%, 10%, 0.96)),
      var(--ai-card-accent-glow);
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1.2;
  }

  .s-home-ai-philosophy__mobile-text {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.58;
  }

  .s-home-ai-philosophy__cats {
    display: block;
    bottom: clamp(10.5rem, 30vw, 12.6rem);
    width: min(70%, 18rem);
  }

  .s-home-ai-philosophy__cat-hit {
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 10;
    display: block;
    width: 33.333%;
    border: 0;
    border-radius: var(--radius-md, 0.75rem);
    background: transparent;
    color: transparent;
    cursor: pointer;
  }

  .s-home-ai-philosophy__cat-hit--T {
    left: 0;
  }
  .s-home-ai-philosophy__cat-hit--D {
    left: 33.333%;
  }
  .s-home-ai-philosophy__cat-hit--S {
    right: 0;
  }

  .s-home-ai-philosophy__cat-hit[aria-selected="true"] {
    outline: 0;
    box-shadow: none;
  }

  .s-home-ai-philosophy__cat-hit:focus-visible {
    outline: 3px solid hsla(174, 86%, 70%, 0.9);
    outline-offset: 0.22rem;
    background: hsla(174, 86%, 70%, 0.08);
    box-shadow:
      0 0 0 0.28rem hsla(25, 28%, 10%, 0.46),
      inset 0 0 0 2px hsla(42, 88%, 84%, 0.66);
  }

  .s-home-ai-philosophy__statement {
    bottom: var(--space-4, 1rem);
    width: min(96%, 29rem);
  }

  .s-home-ai-philosophy__statement-frame {
    height: clamp(8.4rem, 34vw, 10rem);
    object-fit: fill;
  }

  .s-home-ai-philosophy__statement-copy {
    inset: 16% 8% 15%;
  }

  .s-home-ai-philosophy__statement-lead {
    font-size: clamp(0.98rem, 4.1vw, 1.24rem);
    line-height: 1.28;
  }

  .s-home-ai-philosophy__statement-body {
    width: min(100%, 22rem);
    font-size: clamp(0.68rem, 2.8vw, 0.78rem);
    line-height: 1.5;
  }

  .s-home-ai-philosophy__console-edge {
    height: 3.4rem;
  }
}

@media (max-width: 420px) {
  .s-home-ai-philosophy {
    min-height: 70rem;
  }

  .s-home-ai-philosophy__art-area {
    width: min(90%, 23rem);
  }

  .s-home-ai-philosophy__mobile-dialogue {
    bottom: 14.7rem;
    width: min(88%, 23rem);
  }

  .s-home-ai-philosophy__cats {
    bottom: 10.7rem;
  }

  .s-home-ai-philosophy__statement-body {
    display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 1;
    line-clamp: 3;
    -webkit-box-orient: vertical;
  }
}

@media (prefers-reduced-motion: reduce) {
  .s-home-ai-philosophy__fade {
    opacity: 1;
    transition: none;
  }

  .s-home-ai-philosophy__comment-status-dot,
  .s-home-ai-philosophy.is-comment-ticking
    .s-home-ai-philosophy__comment-status::after {
    animation: none;
  }
}
