.tm-case {
  padding-top: 5rem;
  background-color: #f5f7fb;
}

.tm-hero {
  position: relative;
  min-height: 42rem;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.tm-hero__backdrop {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(90deg, rgb(7 18 33 / 0.8) 0%, rgb(7 18 33 / 0.52) 44%, rgb(7 18 33 / 0.42) 100%),
    url("https://lh3.googleusercontent.com/aida-public/AB6AXuD8AUsBhVXTc5dWKjNxXQ_ityXG4qJl4o1ENzYy6z8mbd6Jy-w1xkYId2hY5zI72iOB3S5g_Fv-PKb_tyKHr_PDc9i-sfbofilPD29NcY4zK7aGIP4nA8tyRAXghELyTtEtljo3wsV8GuFUB-A1RuVYnX6NsnR4KaxWiw03kwZJZc20WorlTllAkNWKzBoUKa89at-dG735qwwyQoDoE9oBcR1MHhuHlcmGEUvZb0QKO94oFWUORfOMtjnMgE8Eg2YxBOjG5dgf2P_J");
  background-position: center;
  background-size: cover;
}

.tm-hero__backdrop--giro {
  background-image:
    linear-gradient(90deg, rgb(7 18 33 / 0.8) 0%, rgb(7 18 33 / 0.52) 44%, rgb(7 18 33 / 0.42) 100%),
    url("../assets/img/portada-main-giro.webp");
}

.tm-hero__backdrop--cachelo {
  background-image:
    linear-gradient(90deg, rgb(7 18 33 / 0.8) 0%, rgb(7 18 33 / 0.52) 44%, rgb(7 18 33 / 0.42) 100%),
    url("../assets/img/portada-main-cachelo.webp");
}

.tm-hero__backdrop--liora {
  background-image:
    linear-gradient(90deg, rgb(7 18 33 / 0.8) 0%, rgb(7 18 33 / 0.52) 44%, rgb(7 18 33 / 0.42) 100%),
    url("../assets/img/portada-main-liora.webp");
}

.tm-hero__backdrop--biocare {
  background-image:
    linear-gradient(90deg, rgb(7 18 33 / 0.8) 0%, rgb(7 18 33 / 0.52) 44%, rgb(7 18 33 / 0.42) 100%),
    url("../assets/img/portada-main-biocare.webp");
}

.tm-hero__content {
  position: relative;
  z-index: 1;
  width: 100%;
  color: #ffffff;
  padding: 2.5rem 0 7rem;
}

.tm-hero__pill {
  display: inline-flex;
  align-items: center;
  min-height: 2.2rem;
  padding: 0.1rem 1rem;
  border-radius: 999px;
  border: 1px solid rgb(147 197 253 / 0.45);
  background-color: rgb(37 99 235 / 0.32);
  font-size: 0.8rem;
  line-height: 1;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  font-weight: 700;
}

.tm-hero__title {
  margin: 1rem 0 0;
  max-width: 56rem;
  font-size: clamp(2.35rem, 5.4vw, 4.2rem);
  line-height: 1.03;
  letter-spacing: -0.03em;
}

.tm-hero__lead {
  margin: 1.4rem 0 0;
  max-width: 50rem;
  color: #dbe4f3;
  font-size: clamp(1rem, 1.75vw, 1.6rem);
  line-height: 1.38;
}

.tm-summary {
  margin-top: -4.2rem;
  position: relative;
  z-index: 2;
}

.tm-summary__panel {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  background-color: #ffffff;
  box-shadow: 0 24px 30px -24px rgb(2 6 23 / 0.45);
}

.tm-summary__item {
  padding: 1.6rem 1rem 1.5rem;
  text-align: center;
  border-right: 1px solid #e5e7eb;
}

.tm-summary__item:last-child {
  border-right: 0;
}

.tm-summary__icon {
  width: 3rem;
  height: 3rem;
  margin: 0 auto 1rem;
  border-radius: 999px;
  background-color: rgb(23 84 207 / 0.1);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
}

.tm-summary__icon .material-symbols-outlined {
  font-size: 1.35rem;
}

.tm-summary__item h3 {
  margin: 0;
  color: #0f172a;
  font-size: 1.06rem;
  line-height: 1.2;
}

.tm-summary__item p {
  margin: 0.65rem 0 0;
  color: #64748b;
  font-size: 0.9rem;
  line-height: 1.4;
}

.tm-challenge {
  padding: 4.7rem 0 4.4rem;
}

.tm-challenge__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.6rem;
  align-items: start;
}

.tm-challenge__grid--single {
  grid-template-columns: 1fr;
}

.tm-challenge__grid--single > div {
  width: 100%;
}

.tm-title {
  margin: 0;
  color: #0f172a;
  letter-spacing: -0.02em;
  font-size: clamp(1.7rem, 2.45vw, 2.35rem);
  line-height: 1.1;
}

.tm-title--lined {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

.tm-title--lined::before {
  content: "";
  width: 1.9rem;
  height: 0.2rem;
  border-radius: 999px;
  background-color: var(--color-primary);
  flex-shrink: 0;
}

.tm-challenge__text {
  margin: 1.6rem 0 0;
  width: 100%;
  max-width: 100%;
  color: #475569;
  font-size: 0.98rem;
  line-height: 1.7;
}

.tm-challenge__details {
  margin-top: 1.4rem;
  width: 100%;
  display: grid;
  gap: 0.9rem;
}

.tm-challenge-detail {
  width: 100%;
  border-radius: 0.8rem;
  border: 1px solid #dbe2ef;
  background-color: #ffffff;
  padding: 1rem 1.05rem 1.08rem;
}

.tm-challenge-detail h3 {
  margin: 0;
  color: #1f2937;
  font-size: 0.98rem;
  line-height: 1.3;
}

.tm-challenge-detail p {
  margin: 0.62rem 0 0;
  color: #64748b;
  line-height: 1.58;
  font-size: 0.93rem;
}

.tm-highlight {
  margin-top: 1.4rem;
  border-left: 4px solid var(--color-primary);
  background-color: rgb(23 84 207 / 0.08);
  border-radius: 0.75rem;
  padding: 1rem 1.1rem;
}

.tm-highlight h3 {
  margin: 0;
  color: var(--color-primary);
  font-size: 0.95rem;
}

.tm-highlight p {
  margin: 0.6rem 0 0;
  color: #334155;
  line-height: 1.5;
  font-style: italic;
}

.tm-problems {
  display: grid;
  gap: 1rem;
}

.tm-problem {
  border-radius: 0.8rem;
  border: 1px solid #e5e7eb;
  background-color: #ffffff;
  padding: 1.2rem 1.2rem 1.3rem;
}

.tm-problem__head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.tm-problem__head .material-symbols-outlined {
  color: #ef4444;
  font-size: 1.2rem;
}

.tm-problem__head h3 {
  margin: 0;
  font-size: 0.98rem;
  color: #1f2937;
}

.tm-problem p {
  margin: 0.68rem 0 0;
  color: #64748b;
  line-height: 1.52;
}

.tm-strategy {
  background-color: #e9eef8;
  padding: 4.2rem 0 4.2rem;
}

.tm-strategy__header {
  max-width: 48rem;
  margin: 0 auto;
  text-align: center;
}

.tm-strategy__lead {
  margin: 0.9rem 0 0;
  color: #64748b;
  line-height: 1.58;
  font-size: 0.95rem;
}

.tm-strategy__grid {
  margin-top: 2.3rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.tm-step {
  min-height: 18rem;
  border-radius: 0.85rem;
  border: 1px solid #dce2ee;
  background-color: #ffffff;
  padding: 1.4rem 1.2rem 1.45rem;
}

.tm-step--featured {
  border-top: 4px solid var(--color-primary);
  padding-top: 1.12rem;
}

.tm-step__number {
  margin: 0;
  font-size: 3.2rem;
  line-height: 1;
  font-weight: 900;
  color: rgb(23 84 207 / 0.22);
}

.tm-step h3 {
  margin: 0.7rem 0 0;
  color: #111827;
  font-size: 0.98rem;
}

.tm-step p {
  margin: 0.75rem 0 0;
  color: #475569;
  line-height: 1.56;
}

.tm-tech-heading {
  padding: 4.2rem 0 0;
}

.tm-tech-heading__header {
  max-width: 54rem;
  margin: 0 auto;
  text-align: center;
}

.tm-tech-heading__lead {
  margin: 0.9rem 0 0;
  color: #64748b;
  line-height: 1.58;
  font-size: 0.95rem;
}

.tm-tech {
  padding: 2.6rem 0 4.6rem;
}

.tm-tech__grid {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 2.6rem;
}

.tm-tech__grid--single {
  grid-template-columns: 1fr;
}

.tm-tech__intro p {
  margin: 1rem 0 0;
  color: #64748b;
  line-height: 1.66;
}

.tm-tech__image {
  margin-top: 1.4rem;
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 20px 30px -24px rgb(15 23 42 / 0.42);
}

.tm-tech__image img {
  width: 100%;
  height: 17rem;
  object-fit: cover;
  display: block;
}

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

.tm-feature {
  display: flex;
  align-items: flex-start;
  gap: 0.78rem;
}

.tm-feature__icon {
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 0.62rem;
  background-color: rgb(23 84 207 / 0.1);
  color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.tm-feature__icon .material-symbols-outlined {
  font-size: 1.15rem;
}

.tm-feature h3 {
  margin: 0.06rem 0 0;
  color: #111827;
  font-size: 0.96rem;
}

.tm-feature p {
  margin: 0.5rem 0 0;
  color: #64748b;
  line-height: 1.52;
  font-size: 0.88rem;
}

.tm-web-showcase {
  padding: 0 0 2.2rem;
}

.tm-web-showcase__card {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 1.35rem;
  background: linear-gradient(145deg, #ffffff 0%, #f4f7fd 100%);
  border: 1px solid #dbe3f0;
  border-radius: 1rem;
  box-shadow: 0 20px 30px -24px rgb(15 23 42 / 0.35);
  overflow: hidden;
}

.tm-web-showcase__card--reverse {
  grid-template-columns: 0.95fr 1.05fr;
}

.tm-web-showcase__card--reverse .tm-web-showcase__content {
  padding: 1.35rem 0.2rem 1.4rem 1.3rem;
}

.tm-web-showcase__media {
  margin: 0;
  min-height: 20rem;
}

.tm-web-showcase__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.tm-web-showcase__content {
  padding: 1.35rem 1.3rem 1.4rem 0.2rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.tm-web-showcase__kicker {
  margin: 0;
  display: inline-flex;
  align-items: center;
  min-height: 1.85rem;
  padding: 0 0.78rem;
  border-radius: 999px;
  background-color: rgb(23 84 207 / 0.1);
  color: var(--color-primary);
  font-size: 0.75rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  font-weight: 700;
}

.tm-web-showcase__content h3 {
  margin: 0.75rem 0 0;
  color: #0f172a;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.tm-web-showcase__content p {
  margin: 0.9rem 0 0;
  color: #475569;
  line-height: 1.62;
  font-size: 0.93rem;
}

.tm-web-showcase__button {
  margin-top: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.44rem;
  min-height: 2.85rem;
  padding: 0 1.2rem;
  border-radius: 0.72rem;
  border: 1px solid var(--color-primary);
  background-color: var(--color-primary);
  color: #ffffff;
  font-size: 0.9rem;
  font-weight: 700;
  transition: background-color 220ms, border-color 220ms, transform 220ms;
}

.tm-web-showcase__button:hover {
  background-color: #1d4ed8;
  border-color: #1d4ed8;
  transform: translateY(-1px);
}

.tm-web-showcase__button .material-symbols-outlined {
  font-size: 1rem;
}

.tm-web-showcase--dual .tm-web-showcase__gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.8rem;
  padding: 0.9rem 0.2rem 0.9rem 0.9rem;
}

.tm-web-showcase--dual .tm-web-showcase__media {
  min-height: 16rem;
  border-radius: 0.85rem;
  overflow: hidden;
}

.tm-web-showcase--dual .tm-web-showcase__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tm-web-showcase--loyalty .tm-web-showcase__card {
  grid-template-columns: 1fr 1fr;
}

.tm-web-showcase--loyalty .tm-web-showcase__content {
  padding: 1.8rem 0.7rem 1.8rem 1.8rem;
}

.tm-web-showcase--loyalty .tm-web-showcase__media {
  min-height: 20rem;
  padding: 1rem 1.4rem 1rem 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
}

.tm-web-showcase--loyalty .tm-web-showcase__media img {
  width: min(80%, 28rem);
  height: auto;
  max-height: 23rem;
  object-fit: contain;
  border-radius: 15px;
}

.tm-results {
  background-color: #0f172a;
  color: #ffffff;
  padding: 4.8rem 0;
}

.tm-results .tm-title {
  color: #ffffff;
}

.tm-results ::selection {
  background-color: rgb(96 165 250 / 0.35);
  color: #ffffff;
}

.tm-results ::-moz-selection {
  background-color: rgb(96 165 250 / 0.35);
  color: #ffffff;
}

.tm-results__lead {
  margin: 0.8rem 0 0;
  color: #94a3b8;
}

.tm-results__grid {
  margin-top: 2.3rem;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.tm-result {
  border-radius: 1rem;
  border: 1px solid rgb(255 255 255 / 0.14);
  background-color: rgb(255 255 255 / 0.05);
  padding: 1.25rem 1.15rem;
}

.tm-result__value {
  margin: 0;
  color: #60a5fa;
  font-size: clamp(1.85rem, 3.6vw, 2.55rem);
  line-height: 1;
  font-weight: 900;
}

.tm-result h3 {
  margin: 0.72rem 0 0;
  font-size: 1rem;
}

.tm-result p {
  margin: 0.62rem 0 0;
  color: #cbd5e1;
  line-height: 1.58;
}

.tm-result__status {
  margin-top: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.85rem;
  color: #60a5fa;
  font-weight: 700;
}

.tm-result__status .material-symbols-outlined {
  font-size: 1.05rem;
}

.tm-cta {
  padding: 4.5rem 0 5.1rem;
  text-align: center;
}

.tm-cta__title {
  margin: 0;
  color: #0f172a;
  letter-spacing: -0.02em;
  font-size: clamp(1.7rem, 3.25vw, 2.4rem);
}

.tm-cta__text {
  margin: 1rem auto 0;
  max-width: 48rem;
  color: #64748b;
  font-size: 0.98rem;
  line-height: 1.62;
}

.tm-cta__button {
  margin-top: 1.7rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 3.3rem;
  padding: 0 1.8rem;
  border-radius: 0.85rem;
  border: 1px solid var(--color-primary);
  background-color: var(--color-primary);
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 700;
  transition: transform 220ms, background-color 220ms, border-color 220ms;
}

.tm-cta__button:hover {
  transform: translateY(-1px);
  background-color: #1d4ed8;
  border-color: #1d4ed8;
}

@media (max-width: 1120px) {
  .tm-summary__panel {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tm-summary__item:nth-child(2n) {
    border-right: 0;
  }

  .tm-summary__item:nth-child(-n + 2) {
    border-bottom: 1px solid #e5e7eb;
  }

  .tm-challenge__grid,
  .tm-tech__grid {
    grid-template-columns: 1fr;
    gap: 1.8rem;
  }

  .tm-tech__features,
  .tm-results__grid {
    grid-template-columns: 1fr 1fr;
  }

  .tm-web-showcase__card {
    grid-template-columns: 1fr;
  }

  .tm-web-showcase--loyalty .tm-web-showcase__card {
    grid-template-columns: 1fr;
  }

  .tm-web-showcase__media {
    min-height: 16rem;
  }

  .tm-web-showcase--dual .tm-web-showcase__gallery {
    grid-template-columns: 1fr;
    padding: 1rem 1rem 0;
  }

  .tm-web-showcase__content {
    padding: 1.15rem 1.15rem 1.25rem;
  }

  .tm-web-showcase--loyalty .tm-web-showcase__content {
    padding: 1.2rem 1.15rem 1.3rem;
  }

  .tm-strategy__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .tm-hero {
    min-height: 36rem;
  }

  .tm-hero__content {
    padding-bottom: 6rem;
  }

  .tm-summary {
    margin-top: -3.3rem;
  }

  .tm-summary__panel,
  .tm-tech__features,
  .tm-results__grid {
    grid-template-columns: 1fr;
  }

  .tm-web-showcase__media {
    min-height: 13rem;
  }

  .tm-web-showcase--dual .tm-web-showcase__media {
    min-height: 12rem;
  }

  .tm-web-showcase--loyalty .tm-web-showcase__media {
    min-height: 14rem;
    padding: 0.6rem 1rem 0.8rem;
  }

  .tm-summary__item {
    border-right: 0;
    border-bottom: 1px solid #e5e7eb;
  }

  .tm-summary__item:last-child {
    border-bottom: 0;
  }
}

.pagina.tema-oscuro .tm-case {
  background-color: #0b1220;
}

.pagina.tema-oscuro .tm-summary__panel,
.pagina.tema-oscuro .tm-problem,
.pagina.tema-oscuro .tm-step,
.pagina.tema-oscuro .tm-challenge-detail,
.pagina.tema-oscuro .tm-web-showcase__card {
  background-color: #1f2937;
  border-color: #334155;
}

.pagina.tema-oscuro .tm-summary__item,
.pagina.tema-oscuro .tm-summary__item:nth-child(-n + 2) {
  border-color: #334155;
}

.pagina.tema-oscuro .tm-summary__item h3,
.pagina.tema-oscuro .tm-title,
.pagina.tema-oscuro .tm-problem__head h3,
.pagina.tema-oscuro .tm-step h3,
.pagina.tema-oscuro .tm-feature h3,
.pagina.tema-oscuro .tm-challenge-detail h3,
.pagina.tema-oscuro .tm-web-showcase__content h3,
.pagina.tema-oscuro .tm-cta__title {
  color: #f8fafc;
}

.pagina.tema-oscuro .tm-summary__item p,
.pagina.tema-oscuro .tm-challenge__text,
.pagina.tema-oscuro .tm-problem p,
.pagina.tema-oscuro .tm-strategy__lead,
.pagina.tema-oscuro .tm-tech-heading__lead,
.pagina.tema-oscuro .tm-step p,
.pagina.tema-oscuro .tm-tech__intro p,
.pagina.tema-oscuro .tm-feature p,
.pagina.tema-oscuro .tm-challenge-detail p,
.pagina.tema-oscuro .tm-web-showcase__content p,
.pagina.tema-oscuro .tm-cta__text {
  color: #cbd5e1;
}

.pagina.tema-oscuro .tm-highlight {
  background-color: rgb(23 84 207 / 0.18);
}

.pagina.tema-oscuro .tm-highlight p {
  color: #dbeafe;
}

.pagina.tema-oscuro .tm-strategy {
  background-color: #0f172a;
}
