/* ===============================
   STUDIO PAGE · GLOBAL
   =============================== */

.lm3-main {
  background:
    radial-gradient(circle at top right, #16261d 0, transparent 42%),
    radial-gradient(circle at bottom left, #111b16 0, transparent 40%);
}

/* ===============================
   1. HERO · STÜDYO DUVARI
   =============================== */

.lm3-hero {
  padding-top: 6.2rem;
  padding-bottom: 5.4rem;
  position: relative;
  overflow: hidden;
}

.lm3-hero::before,
.lm3-hero::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  filter: blur(34px);
  opacity: 0.7;
  pointer-events: none;
}

.lm3-hero::before {
  width: 340px;
  height: 340px;
  left: -80px;
  top: -120px;
  background: radial-gradient(circle, rgba(240, 179, 92, 0.5), transparent 60%);
}

.lm3-hero::after {
  width: 320px;
  height: 320px;
  right: -70px;
  bottom: -130px;
  background: radial-gradient(circle, rgba(79, 163, 122, 0.5), transparent 60%);
}

.lm3-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.4fr);
  gap: 3rem;
  align-items: center;
}

.lm3-hero__title {
  font-family: "LandMosaicDisplay", serif;
  font-size: clamp(2.1rem, 3vw + 1.2rem, 3rem);
  line-height: 1.1;
  letter-spacing: 0.03em;
  margin: 0 0 1.1rem;
}

.lm3-hero__text {
  margin: 0 0 0.7rem;
  font-size: 0.98rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-hero__text--muted {
  color: rgba(165, 195, 178, 0.96);
}

.lm3-hero__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 1.4rem;
}

.lm3-chip {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  padding: 0.32rem 0.9rem;
  border-radius: 999px;
  border: 1px solid rgba(165, 195, 178, 0.7);
  background: rgba(5, 9, 8, 0.9);
  color: rgba(245, 246, 243, 0.9);
}

/* hero mosaic */

.lm3-hero__mosaic {
  position: relative;
  width: min(480px, 100%);
  margin-inline: auto;
}

.lm3-hero__tile {
  position: absolute;
  padding: 0.35rem;
  border-radius: 1.9rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.96));
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.85);
  overflow: hidden;
}

.lm3-hero__tile img {
  border-radius: 1.6rem;
  transition: transform 220ms ease, filter 220ms ease;
  transform-origin: center;
}

/* позиции плиток */

.lm3-hero__tile--wall {
  position: relative;
  top: 0;
  left: 0;
  transform: translate(12px, 0);
}

.lm3-hero__tile--desk {
  top: 160px;
  left: -18px;
}

.lm3-hero__tile--model {
  top: 190px;
  right: -6px;
}

.lm3-hero__tile--plant {
  top: -10px;
  right: -16px;
}

/* сияние при наведении */

.lm3-hero__tile::before {
  content: "";
  position: absolute;
  inset: -25%;
  background: conic-gradient(
    from 210deg,
    rgba(240, 179, 92, 0.25),
    transparent,
    rgba(79, 163, 122, 0.25),
    transparent
  );
  mix-blend-mode: screen;
  opacity: 0;
  transform: rotate(0deg);
  transition: opacity 220ms ease;
}

.lm3-hero__tile:hover::before,
.lm3-hero__tile:focus-within::before {
  opacity: 1;
}

.lm3-hero__tile:hover img,
.lm3-hero__tile:focus-within img {
  transform: scale(1.04) translateY(-3px);
  filter: saturate(1.1);
}

/* ===============================
   2. STÜDYO RİTMİ · RYTHM
   =============================== */

.lm3-rhythm {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-rhythm__inner {
  display: grid;
  grid-template-rows: auto auto auto;
  row-gap: 2rem;
}

.lm3-rhythm__header {
  max-width: 40rem;
}

.lm3-rhythm__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.lm3-rhythm__block {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(18, 28, 22, 0.98), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-rhythm__block::before {
  content: "";
  position: absolute;
  inset-inline: 14%;
  top: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(240, 179, 92, 0.8), transparent);
  opacity: 0.9;
}

.lm3-rhythm__time {
  margin: 0 0 0.35rem;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(165, 195, 178, 0.95);
}

.lm3-rhythm__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-rhythm__gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.lm3-rhythm__figure img {
  border-radius: 1.4rem;
}

.lm3-rhythm__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.05), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.9);
}

/* ===============================
   3. MALZEME MASASI · MATERIAL
   =============================== */

.lm3-material {
  padding-top: 4.4rem;
  padding-bottom: 4.9rem;
}

.lm3-material__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-material__header {
  max-width: 40rem;
}

.lm3-material__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.3fr) minmax(0, 1.3fr);
  gap: 1.1rem;
  align-items: stretch;
}

.lm3-material__card {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-material__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-material__text {
  margin: 0 0 0.55rem;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-material__note {
  margin: 0;
  font-size: 0.86rem;
  color: rgba(165, 195, 178, 0.96);
}

.lm3-material__figure {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-material__figure img {
  border-radius: 1.4rem;
}

.lm3-material__halo {
  position: absolute;
  inset: -20%;
  border-radius: 2rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.3), transparent 70%);
  filter: blur(4px);
  opacity: 0.8;
  pointer-events: none;
  animation: lm3MaterialGlow 7800ms ease-in-out infinite alternate;
}

/* ===============================
   KEYFRAMES · STUDIO
   =============================== */

@keyframes lm3MaterialGlow {
  0% {
    opacity: 0.7;
    transform: translateY(2px);
  }
  100% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

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

@media (max-width: 1024px) {
  .lm3-hero__inner {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.2fr);
  }

  .lm3-rhythm__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lm3-material__grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.2fr) minmax(0, 1.2fr);
  }
}

@media (max-width: 840px) {
  .lm3-hero__inner {
    grid-template-columns: minmax(0, 1fr);
    gap: 2.1rem;
  }

  .lm3-hero__mosaic {
    margin-top: 0.5rem;
  }

  .lm3-rhythm__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .lm3-rhythm__gallery {
    grid-template-columns: minmax(0, 1fr);
  }

  .lm3-material__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    row-gap: 1.1rem;
  }
}

@media (max-width: 600px) {
  .lm3-hero,
  .lm3-rhythm,
  .lm3-material {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-hero__tile--wall {
    transform: translate(0, 0);
  }

  .lm3-hero__tile {
    position: relative;
    margin-bottom: 0.7rem;
  }

  .lm3-hero__mosaic {
    width: 100%;
  }

  .lm3-material__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
/* ===============================
   4. SAHA ESKİZLERİ · SKETCHES
   =============================== */

.lm3-sketches {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-sketches__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-sketches__header {
  max-width: 40rem;
}

.lm3-sketches__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.4fr);
  gap: 2.2rem;
  align-items: flex-start;
}

.lm3-sketches__steps {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.9rem;
}

.lm3-sketches__step {
  position: relative;
  padding: 0.7rem 0.9rem 0.9rem;
  border-radius: 1.5rem;
  background: radial-gradient(circle at top left, rgba(18, 28, 22, 0.98), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lm3-sketches__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-sketches__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-sketches__step::before {
  content: "";
  position: absolute;
  left: 0.9rem;
  top: 0.6rem;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: radial-gradient(circle, var(--lm-color-accent), var(--lm-color-accent-2));
  box-shadow: 0 0 0 0 rgba(240, 179, 92, 0.45);
  animation: lmDotPulse 2400ms ease-out infinite;
}

.lm3-sketches__board {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  align-items: center;
}

.lm3-sketches__photo {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-sketches__photo img {
  border-radius: 1.4rem;
}

.lm3-sketches__photo::before {
  content: "";
  position: absolute;
  inset: -20%;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.22), transparent 65%);
  opacity: 0.0;
  pointer-events: none;
  animation: lm3SketchGlow 8200ms ease-in-out infinite alternate;
}

.lm3-sketches__photo:nth-child(1) {
  transform: rotate(-1.5deg);
}

.lm3-sketches__photo:nth-child(2) {
  transform: rotate(1.5deg);
}

.lm3-sketches__photo:nth-child(3) {
  transform: rotate(-0.5deg);
}

/* ===============================
   5. DİJİTAL KATMANLAR · DIGITAL
   =============================== */

.lm3-digital {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-digital__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-digital__header {
  max-width: 40rem;
}

.lm3-digital__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.1fr);
  gap: 2rem;
  align-items: center;
}

.lm3-digital__copy {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.lm3-digital__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-digital__media {
  display: grid;
  grid-template-rows: repeat(2, auto);
  row-gap: 0.8rem;
}

.lm3-digital__figure {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-digital__figure img {
  border-radius: 1.4rem;
}

.lm3-digital__frame {
  position: absolute;
  inset: -10%;
  border-radius: 1.8rem;
  border: 1px dashed rgba(240, 179, 92, 0.65);
  pointer-events: none;
  opacity: 0.7;
  animation: lm3DigitalSweep 8200ms ease-in-out infinite;
}

.lm3-digital__frame--alt {
  border-color: rgba(165, 195, 178, 0.75);
  animation-direction: reverse;
}

/* ===============================
   6. ARŞİV RAFI · ARCHIVE
   =============================== */

.lm3-archive {
  padding-top: 4.4rem;
  padding-bottom: 4.9rem;
}

.lm3-archive__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2rem;
}

.lm3-archive__header {
  max-width: 40rem;
}

.lm3-archive__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.2fr) minmax(0, 1.1fr);
  gap: 1.1rem;
  align-items: center;
}

.lm3-archive__card {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-archive__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-archive__text {
  margin: 0 0 0.5rem;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-archive__media {
  display: grid;
  grid-template-rows: repeat(2, auto);
  row-gap: 0.7rem;
}

.lm3-archive__figure {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-archive__figure img {
  border-radius: 1.4rem;
}

.lm3-archive__glow {
  position: absolute;
  inset: -18%;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.28), transparent 70%);
  filter: blur(3px);
  opacity: 0.85;
  pointer-events: none;
  animation: lm3ArchivePulse 7800ms ease-in-out infinite alternate;
}

.lm3-archive__glow--small {
  inset: -20%;
  background: radial-gradient(circle at top, rgba(79, 163, 122, 0.25), transparent 70%);
}

/* ===============================
   KEYFRAMES · 4–6
   =============================== */

@keyframes lm3SketchGlow {
  0% {
    opacity: 0;
    transform: translateY(2px);
  }
  100% {
    opacity: 0.9;
    transform: translateY(-2px);
  }
}

@keyframes lm3DigitalSweep {
  0% {
    transform: translate3d(4px, 6px, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes lm3ArchivePulse {
  0% {
    opacity: 0.7;
    transform: translateY(1px);
  }
  100% {
    opacity: 1;
    transform: translateY(-1px);
  }
}

/* ===============================
   RESPONSIVE · 4–6
   =============================== */

@media (max-width: 1024px) {
  .lm3-sketches__grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.3fr);
  }

  .lm3-digital__grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.1fr);
  }

  .lm3-archive__grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.3fr) minmax(0, 1.1fr);
  }
}

@media (max-width: 840px) {
  .lm3-sketches__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-digital__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-archive__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    row-gap: 1.1rem;
  }
}

@media (max-width: 600px) {
  .lm3-sketches,
  .lm3-digital,
  .lm3-archive {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-archive__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
/* ===============================
   7. PROTOTİP MASASI · PROTOTYPE
   =============================== */

.lm3-prototype {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-prototype__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-prototype__header {
  max-width: 40rem;
}

.lm3-prototype__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.2fr);
  gap: 2.2rem;
  align-items: center;
}

.lm3-prototype__copy {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}

.lm3-prototype__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

/* mosaic */

.lm3-prototype__mosaic {
  position: relative;
  width: min(420px, 100%);
  margin-inline: auto;
}

.lm3-prototype__tile {
  position: absolute;
  padding: 0.3rem;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-prototype__tile img {
  border-radius: 1.5rem;
  transition: transform 220ms ease, filter 220ms ease;
}

.lm3-prototype__tile--main {
  position: relative;
  top: 0;
  left: 0;
  transform: translate(6px, 0);
}

.lm3-prototype__tile--side {
  top: 150px;
  right: -10px;
}

.lm3-prototype__tile--bottom {
  top: 200px;
  left: -12px;
}

.lm3-prototype__tile::before {
  content: "";
  position: absolute;
  inset: -25%;
  background: conic-gradient(
    from 210deg,
    rgba(240, 179, 92, 0.25),
    transparent,
    rgba(79, 163, 122, 0.25),
    transparent
  );
  opacity: 0;
  mix-blend-mode: screen;
  transition: opacity 220ms ease;
}

.lm3-prototype__tile:hover::before,
.lm3-prototype__tile:focus-within::before {
  opacity: 1;
}

.lm3-prototype__tile:hover img,
.lm3-prototype__tile:focus-within img {
  transform: scale(1.04) translateY(-3px);
  filter: saturate(1.1);
}

/* ===============================
   8. EKİP MASASI · TEAM
   =============================== */

.lm3-team {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-team__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-team__header {
  max-width: 40rem;
}

.lm3-team__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.5fr);
  gap: 2.3rem;
  align-items: center;
}

.lm3-team__copy {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.8rem;
}

.lm3-team__note {
  position: relative;
  padding: 0.75rem 0.9rem 0.9rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(18, 28, 22, 0.98), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lm3-team__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-team__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-team__note::before {
  content: "";
  position: absolute;
  inset-inline: 10%;
  bottom: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(240, 179, 92, 0.8), transparent);
  opacity: 0.9;
}

.lm3-team__gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

.lm3-team__figure {
  position: relative;
  padding: 0.25rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.05), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.9);
}

.lm3-team__figure img {
  border-radius: 1.4rem;
}

/* ===============================
   9. ATÖLYE GÜNLERİ · LAB
   =============================== */

.lm3-lab {
  padding-top: 4.4rem;
  padding-bottom: 4.9rem;
}

.lm3-lab__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2rem;
}

.lm3-lab__header {
  max-width: 40rem;
}

.lm3-lab__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}

.lm3-lab__card {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-lab__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-lab__text {
  margin: 0 0 0.6rem;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-lab__figure {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-lab__figure img {
  border-radius: 1.4rem;
}

/* lab stripes */

.lm3-lab__stripe {
  position: absolute;
  inset-inline: 12%;
  top: 0.4rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(240, 179, 92, 0.85), transparent);
  opacity: 0.95;
  overflow: hidden;
}

.lm3-lab__stripe::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.9), transparent);
  transform: translateX(-120%);
  animation: lm3LabSweep 4200ms ease-in-out infinite;
}

.lm3-lab__stripe--alt {
  inset-inline: 16%;
  background: linear-gradient(90deg, rgba(79, 163, 122, 0.85), transparent);
}

.lm3-lab__stripe--soft {
  inset-inline: 20%;
  background: linear-gradient(90deg, rgba(165, 195, 178, 0.85), transparent);
}

/* ===============================
   KEYFRAMES · 7–9
   =============================== */

@keyframes lm3ProtoDrift {
  0% {
    transform: translate3d(4px, 6px, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}

@keyframes lm3LabSweep {
  0% {
    transform: translateX(-120%);
  }
  60% {
    transform: translateX(120%);
  }
  100% {
    transform: translateX(120%);
  }
}

/* ===============================
   RESPONSIVE · 7–9
   =============================== */

@media (max-width: 1024px) {
  .lm3-prototype__grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.2fr);
  }

  .lm3-team__layout {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.5fr);
  }

  .lm3-lab__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 840px) {
  .lm3-prototype__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-prototype__mosaic {
    width: min(360px, 100%);
  }

  .lm3-team__layout {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-team__gallery {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lm3-lab__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media (max-width: 600px) {
  .lm3-prototype,
  .lm3-team,
  .lm3-lab {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-prototype__tile {
    position: relative;
    margin-bottom: 0.7rem;
    left: 0;
    right: 0;
    top: 0;
    transform: none;
  }

  .lm3-prototype__mosaic {
    width: 100%;
  }

  .lm3-team__gallery {
    grid-template-columns: minmax(0, 1fr);
  }

  .lm3-lab__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
/* ===============================
   10. İŞ AKIŞI · FLOW
   =============================== */

.lm3-flow {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-flow__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-flow__header {
  max-width: 40rem;
}

.lm3-flow__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1.2fr);
  gap: 2.3rem;
  align-items: center;
}

.lm3-flow__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
}

.lm3-flow__steps::before {
  content: "";
  position: absolute;
  left: 0.95rem;
  top: 0.3rem;
  bottom: 0.3rem;
  width: 2px;
  border-radius: 999px;
  background: linear-gradient(to bottom, rgba(240, 179, 92, 0.85), rgba(79, 163, 122, 0.5));
}

.lm3-flow__step {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.8rem;
  padding: 0.6rem 0 0.8rem;
}

.lm3-flow__badge {
  width: 1.9rem;
  height: 1.9rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: radial-gradient(circle, var(--lm-color-accent), var(--lm-color-accent-2));
  color: #050908;
  box-shadow: 0 0 0 0 rgba(240, 179, 92, 0.4);
  animation: lmDotPulse 2600ms ease-out infinite;
}

.lm3-flow__title {
  margin: 0 0 0.25rem;
  font-size: 0.95rem;
}

.lm3-flow__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-flow__media {
  position: relative;
  max-width: 340px;
  margin-inline: auto;
}

.lm3-flow__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-flow__figure img {
  border-radius: 1.5rem;
}

.lm3-flow__figure--small {
  position: absolute;
  right: -10px;
  bottom: -28px;
  max-width: 260px;
}

.lm3-flow__ring {
  position: absolute;
  inset: -18%;
  border-radius: 1.9rem;
  border: 1px solid rgba(240, 179, 92, 0.6);
  pointer-events: none;
  opacity: 0.8;
  animation: lm3FlowRing 7800ms ease-in-out infinite alternate;
}

.lm3-flow__ring--soft {
  border-color: rgba(165, 195, 178, 0.7);
}

/* ===============================
   11. BULUŞMA MASASI · SESSION
   =============================== */

.lm3-session {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-session__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-session__header {
  max-width: 40rem;
}

.lm3-session__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1.3fr) minmax(0, 1.15fr);
  gap: 1.3rem;
  align-items: center;
}

.lm3-session__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.05), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.9);
}

.lm3-session__figure img {
  border-radius: 1.4rem;
}

.lm3-session__notes {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.8rem;
}

.lm3-session__card {
  position: relative;
  padding: 0.75rem 0.9rem 0.9rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(18, 28, 22, 0.98), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lm3-session__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-session__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

/* ===============================
   12. NOT DUVARI · WALL
   =============================== */

.lm3-wall {
  padding-top: 4.4rem;
  padding-bottom: 4.9rem;
}

.lm3-wall__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-wall__header {
  max-width: 40rem;
}

.lm3-wall__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.3fr);
  gap: 2.2rem;
  align-items: center;
}

.lm3-wall__notes {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.8rem;
}

.lm3-wall__card {
  position: relative;
  padding: 0.75rem 0.9rem 0.9rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px dashed rgba(255, 255, 255, 0.12);
}

.lm3-wall__label {
  margin: 0 0 0.25rem;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(165, 195, 178, 0.96);
}

.lm3-wall__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-wall__media {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-wall__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-wall__figure img {
  border-radius: 1.5rem;
}

.lm3-wall__figure--small {
  position: absolute;
  right: -14px;
  bottom: -26px;
  max-width: 260px;
}

.lm3-wall__glow {
  position: absolute;
  inset: -20%;
  border-radius: 1.9rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.26), transparent 68%);
  filter: blur(4px);
  opacity: 0.8;
  pointer-events: none;
  animation: lm3WallGlow 7800ms ease-in-out infinite alternate;
}

.lm3-wall__glow--soft {
  background: radial-gradient(circle at top, rgba(165, 195, 178, 0.26), transparent 68%);
}

/* ===============================
   KEYFRAMES · 10–12
   =============================== */

@keyframes lm3FlowRing {
  0% {
    opacity: 0.7;
    transform: scale(0.96) rotate(0deg);
  }
  100% {
    opacity: 1;
    transform: scale(1.02) rotate(4deg);
  }
}

@keyframes lm3WallGlow {
  0% {
    opacity: 0.7;
    transform: translateY(2px);
  }
  100% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

/* ===============================
   RESPONSIVE · 10–12
   =============================== */

@media (max-width: 1024px) {
  .lm3-flow__layout {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.1fr);
  }

  .lm3-session__grid {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.4fr) minmax(0, 1.1fr);
  }

  .lm3-wall__grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.2fr);
  }
}

@media (max-width: 840px) {
  .lm3-flow__layout {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-flow__figure--small {
    position: relative;
    right: 0;
    bottom: 0;
    margin-top: 0.7rem;
  }

  .lm3-session__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.4rem;
  }

  .lm3-wall__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }
}

@media (max-width: 600px) {
  .lm3-flow,
  .lm3-session,
  .lm3-wall {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-flow__steps::before {
    left: 0.85rem;
  }

  .lm3-wall__figure--small {
    position: relative;
    right: 0;
    bottom: 0;
    margin-top: 0.7rem;
  }
}
/* ===============================
   13. STÜDYO SESLERİ · SOUND
   =============================== */

.lm3-sound {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-sound__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-sound__header {
  max-width: 40rem;
}

.lm3-sound__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1.3fr);
  gap: 2.3rem;
  align-items: center;
}

.lm3-sound__copy {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.8rem;
}

.lm3-sound__card {
  position: relative;
  padding: 0.75rem 0.9rem 0.9rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(18, 28, 22, 0.98), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lm3-sound__label {
  margin: 0 0 0.25rem;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(165, 195, 178, 0.96);
}

.lm3-sound__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

/* sound stack */

.lm3-sound__stack {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  align-items: center;
}

.lm3-sound__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-sound__figure img {
  border-radius: 1.5rem;
}

.lm3-sound__figure--garden {
  transform: rotate(-0.5deg);
}

.lm3-sound__figure--water {
  transform: rotate(1.2deg);
}

.lm3-sound__figure--studio {
  transform: rotate(-1deg);
}

.lm3-sound__glow {
  position: absolute;
  inset: -20%;
  border-radius: 1.9rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.26), transparent 70%);
  filter: blur(4px);
  opacity: 0.8;
  pointer-events: none;
  animation: lm3SoundGlow 7800ms ease-in-out infinite alternate;
}

.lm3-sound__glow--soft {
  background: radial-gradient(circle at top, rgba(79, 163, 122, 0.26), transparent 70%);
}

.lm3-sound__glow--thin {
  background: radial-gradient(circle at top, rgba(165, 195, 178, 0.26), transparent 70%);
}

/* ===============================
   14. KÜTÜPHANE RAFI · LIBRARY
   =============================== */

.lm3-library {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-library__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-library__header {
  max-width: 40rem;
}

.lm3-library__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1.4fr) minmax(0, 1.15fr);
  gap: 1.2rem;
  align-items: center;
}

.lm3-library__figure {
  position: relative;
  padding: 0.3rem;
  border-radius: 1.8rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.06), rgba(6, 10, 8, 0.97));
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.9);
  overflow: hidden;
}

.lm3-library__figure img {
  border-radius: 1.5rem;
}

.lm3-library__veil {
  position: absolute;
  inset: -20%;
  border-radius: 1.9rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.22), transparent 68%);
  pointer-events: none;
  opacity: 0.8;
}

.lm3-library__notes {
  display: grid;
  grid-template-rows: repeat(3, auto);
  row-gap: 0.8rem;
}

.lm3-library__card {
  position: relative;
  padding: 0.75rem 0.9rem 0.9rem;
  border-radius: 1.6rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
}

.lm3-library__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-library__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-library__media {
  display: grid;
  grid-template-rows: repeat(2, auto);
  row-gap: 0.7rem;
}

.lm3-library__figure--open {
  transform: rotate(-1deg);
}

.lm3-library__figure--stack {
  transform: rotate(1.5deg);
}

/* ===============================
   15. GELECEK SAHNELER · FUTURE
   =============================== */

.lm3-future {
  padding-top: 4.4rem;
  padding-bottom: 5rem;
}

.lm3-future__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-future__header {
  max-width: 40rem;
}

.lm3-future__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}

.lm3-future__card {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-future__label {
  margin: 0 0 0.3rem;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(165, 195, 178, 0.96);
}

.lm3-future__text {
  margin: 0 0 0.6rem;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-future__figure {
  position: relative;
  max-width: 320px;
  margin-inline: auto;
}

.lm3-future__figure img {
  border-radius: 1.5rem;
}

.lm3-future__halo {
  position: absolute;
  inset: -20%;
  border-radius: 1.9rem;
  background: radial-gradient(circle at top, rgba(240, 179, 92, 0.24), transparent 70%);
  filter: blur(4px);
  opacity: 0.8;
  pointer-events: none;
  animation: lm3FutureFloat 8200ms ease-in-out infinite alternate;
}

.lm3-future__halo--soft {
  background: radial-gradient(circle at top, rgba(79, 163, 122, 0.24), transparent 70%);
}

.lm3-future__halo--line {
  background: radial-gradient(circle at top, rgba(165, 195, 178, 0.24), transparent 70%);
}

/* ===============================
   KEYFRAMES · 13–15 (+ общий lmDotPulse)
   =============================== */

@keyframes lm3SoundGlow {
  0% {
    opacity: 0.6;
    transform: translateY(2px);
  }
  100% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

@keyframes lm3FutureFloat {
  0% {
    opacity: 0.7;
    transform: translate3d(2px, 4px, 0);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* для бейджей и точек, используемых в других секциях */
@keyframes lmDotPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(240, 179, 92, 0.45);
  }
  100% {
    box-shadow: 0 0 0 10px rgba(240, 179, 92, 0);
  }
}

/* ===============================
   RESPONSIVE · 13–15
   =============================== */

@media (max-width: 1024px) {
  .lm3-sound__grid {
    grid-template-columns: minmax(0, 1.3fr) minmax(0, 1.2fr);
  }

  .lm3-library__grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.4fr) minmax(0, 1.1fr);
  }

  .lm3-future__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 840px) {
  .lm3-sound__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-library__grid {
    grid-template-columns: minmax(0, 1fr);
    row-gap: 1.8rem;
  }

  .lm3-future__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media (max-width: 600px) {
  .lm3-sound,
  .lm3-library,
  .lm3-future {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-future__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
/* ===============================
   16. STÜDYO RİTÜELLERİ · RITUAL
   =============================== */

.lm3-ritual {
  padding-top: 4.4rem;
  padding-bottom: 4.8rem;
}

.lm3-ritual__inner {
  display: grid;
  grid-template-rows: auto 1fr auto;
  row-gap: 2.1rem;
}

.lm3-ritual__header {
  max-width: 40rem;
}

.lm3-ritual__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}

.lm3-ritual__card {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-ritual__tag {
  margin: 0 0 0.3rem;
  font-size: 0.83rem;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(165, 195, 178, 0.96);
}

.lm3-ritual__title {
  margin: 0 0 0.3rem;
  font-size: 0.96rem;
}

.lm3-ritual__text {
  margin: 0;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

/* декоративная полоса внизу */

.lm3-ritual__stripe {
  position: relative;
  margin-top: 0.8rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(240, 179, 92, 0.7), transparent, rgba(79, 163, 122, 0.7));
  overflow: hidden;
}

.lm3-ritual__dot {
  position: absolute;
  top: -3px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #f0b35c;
  box-shadow: 0 0 0 0 rgba(240, 179, 92, 0.4);
  animation: lm3RitualDot 5200ms ease-in-out infinite;
}

.lm3-ritual__dot:nth-child(1) {
  left: 8%;
}

.lm3-ritual__dot:nth-child(2) {
  left: 48%;
  animation-delay: 600ms;
}

.lm3-ritual__dot:nth-child(3) {
  left: 82%;
  animation-delay: 1200ms;
}

/* ===============================
   17. STÜDYO İLE TEMAS · ENDING
   =============================== */

.lm3-ending {
  padding-top: 4.4rem;
  padding-bottom: 5.2rem;
}

.lm3-ending__inner {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 2.1rem;
}

.lm3-ending__header {
  max-width: 40rem;
}

.lm3-ending__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.1rem;
}

.lm3-ending__block {
  position: relative;
  padding: 0.9rem 0.95rem 1.05rem;
  border-radius: 1.7rem;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.04), rgba(6, 10, 8, 0.97));
  border: 1px solid rgba(255, 255, 255, 0.06);
  overflow: hidden;
}

.lm3-ending__block--accent {
  background: radial-gradient(circle at top left, rgba(240, 179, 92, 0.16), rgba(6, 10, 8, 0.97));
  border-color: rgba(240, 179, 92, 0.6);
}

.lm3-ending__title {
  margin: 0 0 0.35rem;
  font-size: 0.96rem;
}

.lm3-ending__text {
  margin: 0 0 0.7rem;
  font-size: 0.9rem;
  color: rgba(245, 246, 243, 0.9);
}

.lm3-ending__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

/* ===============================
   KEYFRAMES · 16–17
   =============================== */

@keyframes lm3RitualDot {
  0% {
    transform: translateY(0);
    box-shadow: 0 0 0 0 rgba(240, 179, 92, 0.4);
  }
  50% {
    transform: translateY(-3px);
    box-shadow: 0 0 0 10px rgba(240, 179, 92, 0);
  }
  100% {
    transform: translateY(0);
    box-shadow: 0 0 0 0 rgba(240, 179, 92, 0);
  }
}

/* ===============================
   RESPONSIVE · 16–17
   =============================== */

@media (max-width: 1024px) {
  .lm3-ritual__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lm3-ending__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 840px) {
  .lm3-ritual__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    row-gap: 1.1rem;
  }

  .lm3-ending__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

@media (max-width: 600px) {
  .lm3-ritual,
  .lm3-ending {
    padding-top: 3.7rem;
    padding-bottom: 3.8rem;
  }

  .lm3-ritual__grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .lm3-ending__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}
