/* ============================================
   TAYA YOGA — Sections CSS
   Solo clases semanticas ty-*, sin IDs de Bricks
   ============================================ */

/* -- TIPOGRAFIA GLOBAL -- */
#brx-content h1,
#brx-content h2,
#brx-content h3,
#brx-content h4,
#brx-content h5,
#brx-content h6,
#brx-content .brxe-heading {
  font-family: var(--ty-font-heading) !important;
  color: var(--ty-color-heading);
}
#brx-content p,
#brx-content .brxe-text-basic,
#brx-content .brxe-text,
#brx-content li,
#brx-content a:not(.brxe-button),
#brx-content span:not(.brxe-heading) {
  font-family: var(--ty-font-body) !important;
}

/* -- RESET BASE -- */
.ty-section {
  padding: var(--ty-space-3xl) 0;
  width: 100%;
}
.ty-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  width: 100%;
  box-sizing: border-box;
}

/* -- BOTONES -- */
.ty-btn {
  border-radius: var(--ty-radius-pill);
  padding: 12px 28px;
  font-size: var(--ty-fs-sm);
  font-weight: var(--ty-fw-medium);
  font-family: var(--ty-font-body) !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: var(--ty-transition);
  cursor: pointer;
  border: none;
  line-height: 1.5;
}
.ty-btn--primary {
  background-color: var(--ty-color-primary) !important;
  color: #fff !important;
}
.ty-btn--primary:hover {
  background-color: var(--ty-color-primary-dark) !important;
}
.ty-btn--secondary {
  background-color: #fff !important;
  color: var(--ty-color-heading) !important;
  box-shadow: var(--ty-shadow-lg);
  padding: 16px 32px;
  font-size: var(--ty-fs-md);
}
.ty-btn--secondary:hover {
  background-color: var(--ty-color-hover-peach) !important;
}
.ty-btn--outline {
  background-color: transparent !important;
  color: var(--ty-color-heading) !important;
  border: 1px solid var(--ty-color-border) !important;
}
.ty-btn--outline:hover {
  border-color: var(--ty-color-primary) !important;
  color: var(--ty-color-primary) !important;
}
.ty-btn--ghost {
  background: none !important;
  color: var(--ty-color-text) !important;
  text-decoration: underline !important;
  text-underline-offset: 4px !important;
  padding: 0 !important;
}

/* ============================================
   HEADER (IDs se anaden post-creacion)
   ============================================ */

/* ============================================
   HERO
   ============================================ */
.ty-hero {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
}
.ty-hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: var(--ty-color-light-sage);
  color: var(--ty-color-badge-text);
  font-size: var(--ty-fs-sm);
  font-weight: var(--ty-fw-medium);
  padding: 8px 16px;
  border-radius: var(--ty-radius-pill);
  width: fit-content;
}
.ty-hero__title {
  font-size: var(--ty-fs-6xl) !important;
  line-height: 1.1 !important;
  color: var(--ty-color-heading-dark) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-hero__title em,
.ty-hero__title i {
  font-style: italic;
  color: var(--ty-color-primary);
}
.ty-hero__text {
  font-size: var(--ty-fs-lg) !important;
  line-height: 1.625 !important;
  color: var(--ty-color-text) !important;
}
.ty-hero__actions {
  display: flex;
  flex-direction: row;
  gap: var(--ty-space-sm);
  flex-wrap: wrap;
  align-items: center;
}
.ty-hero__microcopy {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
}
.ty-hero__media {
  border-radius: var(--ty-radius-xl);
  overflow: hidden;
}
.ty-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4/5;
}

/* ============================================
   METODO — "Como te acompano"
   ============================================ */
.ty-metodo {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-metodo__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-metodo__header {
  text-align: center;
  max-width: 700px;
}
.ty-metodo__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
  margin-bottom: var(--ty-space-sm) !important;
}
.ty-metodo__subtitle {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.625 !important;
}
.ty-metodo__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ty-space-lg);
  width: 100%;
}
.ty-metodo__card {
  background: var(--ty-color-card-bg);
  border-radius: var(--ty-radius-md);
  padding: var(--ty-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-sm);
}
.ty-metodo__card-icon {
  width: 48px;
  height: 48px;
  color: var(--ty-color-primary);
}
.ty-metodo__card-title {
  font-size: var(--ty-fs-xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-metodo__card-text {
  font-size: var(--ty-fs-base) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   BENEFICIOS
   ============================================ */
.ty-beneficios {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-beneficios__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-beneficios__header {
  text-align: center;
  max-width: 700px;
}
.ty-beneficios__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-beneficios__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  width: 100%;
}
.ty-beneficios__col {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-beneficios__col-title {
  font-size: var(--ty-fs-2xl) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
  margin-bottom: var(--ty-space-xs) !important;
}
.ty-beneficios__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.ty-beneficios__check {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  color: var(--ty-color-secondary);
  margin-top: 2px;
}
.ty-beneficios__item-text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   TESTIMONIOS
   ============================================ */
.ty-testimonios {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-testimonios__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-testimonios__header {
  text-align: center;
}
.ty-testimonios__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-testimonios__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ty-space-md);
  width: 100%;
}
.ty-testimonios__card {
  background: var(--ty-color-card-bg);
  padding: var(--ty-space-lg);
  border-radius: var(--ty-radius-md);
  position: relative;
}
.ty-testimonios__quote-icon {
  color: var(--ty-color-secondary);
  opacity: 0.3;
  font-size: 48px;
  line-height: 1;
  margin-bottom: var(--ty-space-sm);
}
.ty-testimonios__quote {
  font-size: var(--ty-fs-base) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
  font-style: italic !important;
  margin-bottom: var(--ty-space-md) !important;
}
.ty-testimonios__author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.ty-testimonios__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #D1D5DB;
  overflow: hidden;
  flex-shrink: 0;
}
.ty-testimonios__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.ty-testimonios__name {
  font-size: var(--ty-fs-sm) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-testimonios__role {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-light) !important;
}

/* ============================================
   NEWSLETTER / LEAD MAGNET
   ============================================ */
.ty-newsletter {
  padding: var(--ty-space-3xl) 0;
}
.ty-newsletter__inner {
  background: var(--ty-color-heading);
  border-radius: var(--ty-radius-lg);
  padding: var(--ty-space-2xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--ty-space-md);
}
.ty-newsletter__title {
  color: #fff !important;
  font-size: var(--ty-fs-4xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  line-height: 1.25 !important;
}
.ty-newsletter__text {
  color: rgba(255,255,255,0.8) !important;
  font-size: var(--ty-fs-md) !important;
  line-height: 1.625 !important;
  max-width: 500px;
}
.ty-newsletter__form {
  display: flex;
  flex-direction: row;
  gap: var(--ty-space-sm);
  width: 100%;
  max-width: 500px;
}
.ty-newsletter__input {
  flex: 1;
  padding: 16px 24px;
  border-radius: var(--ty-radius-pill);
  border: none;
  font-size: var(--ty-fs-base);
  font-family: var(--ty-font-body);
  background: #fff;
  color: var(--ty-color-heading);
}
.ty-newsletter__input::placeholder {
  color: var(--ty-color-text-muted);
}
.ty-newsletter__consent {
  color: rgba(255,255,255,0.6) !important;
  font-size: var(--ty-fs-xs) !important;
}

/* ============================================
   CURSOS
   ============================================ */
.ty-cursos {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-cursos__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-cursos__header {
  text-align: center;
  max-width: 700px;
}
.ty-cursos__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-cursos__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ty-space-lg);
  width: 100%;
}
.ty-cursos__card {
  background: #fff;
  border-radius: var(--ty-radius-md);
  overflow: hidden;
  box-shadow: var(--ty-shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: flex;
  flex-direction: column;
}
.ty-cursos__card:hover {
  transform: translateY(-4px);
  box-shadow: var(--ty-shadow-md);
}
.ty-cursos__card-img {
  overflow: hidden;
  aspect-ratio: 16/10;
}
.ty-cursos__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.ty-cursos__card:hover .ty-cursos__card-img img {
  transform: scale(1.05);
}
.ty-cursos__card-body {
  padding: var(--ty-space-md);
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.ty-cursos__card-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.ty-cursos__tag {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-primary) !important;
  background: var(--ty-color-light-sage);
  padding: 4px 12px;
  border-radius: var(--ty-radius-pill);
  font-weight: var(--ty-fw-medium) !important;
}
.ty-cursos__card-title {
  font-size: var(--ty-fs-xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-cursos__card-meta {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
}
.ty-cursos__card-link {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-primary) !important;
  font-weight: var(--ty-fw-medium) !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: auto;
  transition: var(--ty-transition);
}
.ty-cursos__card-link:hover {
  gap: 8px;
}

/* ============================================
   COMUNIDAD
   ============================================ */
.ty-comunidad {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-light-sage);
}
.ty-comunidad__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
}
.ty-comunidad__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-comunidad__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-comunidad__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}
.ty-comunidad__media {
  display: flex;
  justify-content: center;
}
.ty-comunidad__media img {
  max-width: 380px;
  border-radius: var(--ty-radius-xl);
  box-shadow: var(--ty-shadow-lg);
  transform: rotate(3deg);
  border: 4px solid #fff;
}

/* ============================================
   SOBRE TAYA / ABOUT
   ============================================ */
.ty-about {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-card-bg);
}
.ty-about__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
}
.ty-about__media {
  border-radius: var(--ty-radius-md);
  overflow: hidden;
}
.ty-about__media img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  border-radius: var(--ty-radius-md);
  box-shadow: var(--ty-shadow-md);
}
.ty-about__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-about__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-about__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   BLOG PREVIEW
   ============================================ */
.ty-blog {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-blog__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-blog__header {
  text-align: center;
}
.ty-blog__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-blog__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ty-space-lg);
  width: 100%;
}
.ty-blog__card {
  cursor: pointer;
}
.ty-blog__card-img {
  overflow: hidden;
  border-radius: var(--ty-radius-md);
  margin-bottom: var(--ty-space-sm);
  height: 224px;
}
.ty-blog__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.ty-blog__card:hover .ty-blog__card-img img {
  transform: scale(1.05);
}
.ty-blog__card-cat {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-primary) !important;
  text-transform: uppercase;
  font-weight: var(--ty-fw-semibold) !important;
  letter-spacing: 0.05em;
}
.ty-blog__card-date {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-lightest) !important;
}
.ty-blog__card-title {
  font-size: var(--ty-fs-xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
  margin-top: 8px !important;
}

/* ============================================
   FAQ
   ============================================ */
.ty-faq {
  padding: var(--ty-space-3xl) 0;
  background-color: var(--ty-color-bg);
}
.ty-faq__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-faq__header {
  text-align: center;
}
.ty-faq__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-faq__list {
  width: 100%;
  max-width: 800px;
}
.ty-faq__item {
  border-bottom: 1px solid var(--ty-color-border);
}
.ty-faq__item:last-child {
  border-bottom: none;
}
.ty-faq__question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--ty-space-md) 0;
  cursor: pointer;
  font-size: var(--ty-fs-md) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  font-family: var(--ty-font-heading) !important;
}
.ty-faq__question:hover {
  color: var(--ty-color-primary) !important;
}
.ty-faq__chevron {
  transition: transform 0.3s ease;
  flex-shrink: 0;
  color: var(--ty-color-text-muted);
}
.ty-faq__item.is-open .ty-faq__chevron {
  transform: rotate(180deg);
}
.ty-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}
.ty-faq__item.is-open .ty-faq__answer {
  max-height: 500px;
  padding-bottom: var(--ty-space-md);
}
.ty-faq__answer-text {
  font-size: var(--ty-fs-base) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   FOOTER (IDs se anaden post-creacion)
   ============================================ */

/* ============================================
   RESPONSIVE — TABLET (max-width: 991px)
   ============================================ */
@media (max-width: 991px) {
  .ty-hero__inner {
    grid-template-columns: 1fr;
    gap: var(--ty-space-lg);
  }
  .ty-hero__title {
    font-size: var(--ty-fs-5xl) !important;
  }
  .ty-metodo__grid {
    grid-template-columns: 1fr;
    gap: var(--ty-space-md);
  }
  .ty-beneficios__grid {
    grid-template-columns: 1fr;
  }
  .ty-testimonios__grid {
    grid-template-columns: 1fr;
    gap: var(--ty-space-md);
  }
  .ty-cursos__grid {
    grid-template-columns: 1fr 1fr;
  }
  .ty-comunidad__inner {
    grid-template-columns: 1fr;
  }
  .ty-about__inner {
    grid-template-columns: 1fr;
  }
  .ty-blog__grid {
    grid-template-columns: 1fr 1fr;
  }
}

/* ============================================
   RESPONSIVE — MOBILE (max-width: 767px)
   ============================================ */
@media (max-width: 767px) {
  .ty-section {
    padding: var(--ty-space-xl) 0;
  }
  .ty-container {
    padding: 0 16px;
  }
  .ty-hero__title {
    font-size: var(--ty-fs-4xl) !important;
  }
  .ty-hero__text {
    font-size: var(--ty-fs-md) !important;
  }
  .ty-hero__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .ty-hero__actions .ty-btn {
    justify-content: center;
  }
  .ty-metodo__title,
  .ty-beneficios__title,
  .ty-testimonios__title,
  .ty-cursos__title,
  .ty-comunidad__title,
  .ty-about__title,
  .ty-blog__title,
  .ty-faq__title {
    font-size: var(--ty-fs-3xl) !important;
  }
  .ty-newsletter__inner {
    padding: var(--ty-space-xl) var(--ty-space-md);
  }
  .ty-newsletter__title {
    font-size: var(--ty-fs-3xl) !important;
  }
  .ty-newsletter__form {
    flex-direction: column;
  }
  .ty-cursos__grid {
    grid-template-columns: 1fr;
  }
  .ty-blog__grid {
    grid-template-columns: 1fr;
  }
  .ty-comunidad__media img {
    max-width: 280px;
  }
  .ty-btn--secondary {
    padding: 14px 24px;
    font-size: var(--ty-fs-base);
  }
}

/* ============================================
   HEADER
   ============================================ */
#brxe-hd001 {
  position: sticky !important;
  top: 0 !important;
  z-index: 999 !important;
  background-color: var(--ty-color-bg) !important;
  box-shadow: var(--ty-shadow-sm) !important;
  transition: box-shadow 0.3s ease !important;
  padding: 0 !important;
}
#brxe-hd002 {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  padding: 0 24px !important;
  min-height: 72px !important;
  flex-wrap: nowrap !important;
}
#brxe-hd003 img {
  height: 40px !important;
  width: auto !important;
  display: block !important;
}
#brxe-hd004 {
  flex: 1 !important;
  display: flex !important;
  justify-content: center !important;
}
#brxe-hd004 .bricks-nav-menu a {
  font-family: var(--ty-font-body) !important;
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text) !important;
  font-weight: var(--ty-fw-medium) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}
#brxe-hd004 .bricks-nav-menu a:hover {
  color: var(--ty-color-primary) !important;
}
@media (max-width: 767px) {
  #brxe-hd005 { display: none !important; }
  #brxe-hd002 { padding: 0 16px !important; min-height: 60px !important; }
  #brxe-hd003 img { height: 32px !important; }
}

/* ============================================
   FOOTER
   ============================================ */
#brxe-ft001 {
  background-color: var(--ty-color-footer-bg) !important;
  padding: 0 !important;
  width: 100% !important;
  overflow-x: hidden !important;
}
#brxe-ft002 {
  display: grid !important;
  grid-template-columns: 2fr 1fr 1fr 1.5fr !important;
  gap: var(--ty-space-xl) !important;
  padding: var(--ty-space-3xl) 24px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
  width: 100% !important;
  align-self: auto !important;
}
#brxe-ft003 { display: flex !important; flex-direction: column !important; gap: var(--ty-space-sm) !important; }
#brxe-ft004 img {
  height: 36px !important;
  width: auto !important;
  filter: brightness(0) invert(1) !important;
  opacity: 0.9 !important;
}
#brxe-ft005 { color: rgba(255,255,255,0.7) !important; font-size: var(--ty-fs-sm) !important; line-height: 1.6 !important; }
#brxe-ft006 { display: flex !important; flex-direction: row !important; gap: var(--ty-space-sm) !important; flex-wrap: wrap !important; margin-top: var(--ty-space-xs) !important; }
#brxe-ft006a a, #brxe-ft006b a, #brxe-ft006c a {
  color: rgba(255,255,255,0.6) !important;
  font-size: var(--ty-fs-xs) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}
#brxe-ft006a a:hover, #brxe-ft006b a:hover, #brxe-ft006c a:hover { color: var(--ty-color-secondary) !important; }
#brxe-ft008, #brxe-ft012, #brxe-ft016 { display: flex !important; flex-direction: column !important; gap: var(--ty-space-sm) !important; }
#brxe-ft009, #brxe-ft013, #brxe-ft017 {
  color: var(--ty-color-secondary) !important;
  font-family: var(--ty-font-heading) !important;
  font-size: var(--ty-fs-md) !important;
  font-weight: var(--ty-fw-semibold) !important;
  margin: 0 0 8px 0 !important;
}
#brxe-ft010 nav, #brxe-ft014 nav { display: flex !important; flex-direction: column !important; gap: 8px !important; }
#brxe-ft010 a, #brxe-ft014 a {
  color: rgba(255,255,255,0.7) !important;
  font-size: var(--ty-fs-sm) !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}
#brxe-ft010 a:hover, #brxe-ft014 a:hover { color: #fff !important; }
#brxe-ft018 { color: rgba(255,255,255,0.7) !important; font-size: var(--ty-fs-sm) !important; line-height: 1.6 !important; }

#brxe-ft020 {
  border-top: 1px solid rgba(255,255,255,0.1) !important;
  padding: var(--ty-space-md) 24px !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  text-align: center !important;
  box-sizing: border-box !important;
  width: 100% !important;
  align-self: auto !important;
}
#brxe-ft021 { color: rgba(255,255,255,0.4) !important; font-size: var(--ty-fs-xs) !important; }
@media (max-width: 991px) {
  #brxe-ft002 { grid-template-columns: 1fr 1fr !important; gap: var(--ty-space-lg) !important; }
}
@media (max-width: 767px) {
  #brxe-ft002 { grid-template-columns: 1fr !important; padding: var(--ty-space-xl) 16px !important; }
  #brxe-ft020 { padding: var(--ty-space-md) 16px !important; }
}

/* ============================================
   COMPLEMENTOS HOMEPAGE — Clases faltantes
   ============================================ */

/* Numero decorativo en cards Metodo (01/02/03) */
.ty-metodo__card-num {
  font-size: 40px !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-secondary) !important;
  font-family: var(--ty-font-heading) !important;
  line-height: 1 !important;
  opacity: 0.5;
}

/* Subtitulo seccion Cursos */
.ty-cursos__subtitle {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.625 !important;
}

/* CTA wrap (Ver todos los programas / articulos) */
.ty-cursos__cta-wrap,
.ty-blog__cta-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
}

/* Eyebrow label en About section */
.ty-about__eyebrow {
  font-size: var(--ty-fs-sm) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-primary) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Newsletter form wrapper */
.ty-newsletter__form-wrap {
  width: 100%;
  max-width: 500px;
}
.ty-newsletter__form-wrap p { margin: 0 !important; }
.ty-nl-form { width: 100%; display: flex; flex-direction: column; gap: 12px; }

/* Initials en avatar de testimonios */
.ty-testimonios__avatar-initials {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--ty-color-primary);
  color: #fff;
  font-size: var(--ty-fs-sm) !important;
  font-weight: var(--ty-fw-semibold) !important;
  font-family: var(--ty-font-body) !important;
}

/* FAQ nativa con <details>/<summary> */
details.ty-faq__item {
  border-bottom: 1px solid var(--ty-color-border);
}
details.ty-faq__item:last-child {
  border-bottom: none;
}
details.ty-faq__item summary {
  list-style: none;
  cursor: pointer;
  padding: var(--ty-space-md) 0;
  font-size: var(--ty-fs-md) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
  font-family: var(--ty-font-heading) !important;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: color 0.2s ease;
}
details.ty-faq__item summary::-webkit-details-marker { display: none; }
details.ty-faq__item summary::after {
  content: "+";
  font-size: 20px;
  font-weight: var(--ty-fw-normal) !important;
  color: var(--ty-color-text-muted);
  transition: transform 0.3s ease;
  flex-shrink: 0;
  margin-left: 12px;
}
details.ty-faq__item[open] summary::after {
  transform: rotate(45deg);
}
details.ty-faq__item summary:hover {
  color: var(--ty-color-primary) !important;
}
details.ty-faq__item .ty-faq__answer-text {
  padding-bottom: var(--ty-space-md);
}

/* ============================================
   PAGINAS INTERNAS — Estilos compartidos
   ============================================ */

/* Hero de paginas internas */
.ty-page-hero {
  background-color: var(--ty-color-card-bg);
  padding: var(--ty-space-2xl) 0 var(--ty-space-xl);
}
.ty-page-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
}
.ty-page-hero__center {
  text-align: center;
}
.ty-page-hero__text-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-md);
  max-width: 700px;
  margin: 0 auto;
}
.ty-page-hero__badge {
  display: inline-flex;
  background-color: var(--ty-color-light-sage);
  color: var(--ty-color-badge-text);
  font-size: var(--ty-fs-sm);
  font-weight: var(--ty-fw-medium);
  padding: 6px 16px;
  border-radius: var(--ty-radius-pill);
}
.ty-page-hero__title {
  font-size: var(--ty-fs-5xl) !important;
  line-height: 1.1 !important;
  color: var(--ty-color-heading-dark) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-page-hero__text {
  font-size: var(--ty-fs-lg) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
  max-width: 600px;
}
.ty-page-hero__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-page-hero__media {
  border-radius: var(--ty-radius-xl);
  overflow: hidden;
}
.ty-page-hero__media img,
.ty-page-hero__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--ty-radius-xl);
}

/* Titulos y subtitulos de seccion reutilizables */
.ty-section-title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
  text-align: center;
  margin-bottom: var(--ty-space-xs) !important;
}
.ty-section-subtitle {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.625 !important;
  text-align: center;
}

/* CTA section (fondo claro, centrado) */
.ty-cta-section {
  background-color: var(--ty-color-light-sage);
}
.ty-cta-section__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--ty-space-md);
}
.ty-cta-section__title {
  font-size: var(--ty-fs-4xl) !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-cta-section__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  max-width: 500px;
}

/* ============================================
   QUE ES / YOGA TERAPEUTICO
   ============================================ */
.ty-quees__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
}
.ty-quees__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-quees__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-quees__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}
.ty-quees__media img,
.ty-quees__img {
  width: 100%;
  border-radius: var(--ty-radius-md);
  box-shadow: var(--ty-shadow-md);
  aspect-ratio: 4/5;
  object-fit: cover;
}

/* Para quien */
.ty-paraquien__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-paraquien__header { text-align: center; }
.ty-paraquien__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-md);
  width: 100%;
  max-width: 900px;
}
.ty-paraquien__item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.ty-paraquien__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   CURSOS FULL (pagina programas)
   ============================================ */
.ty-cursos-full__inner {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-xl);
}
.ty-cursos-full__grid {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-2xl);
}
.ty-curso-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--ty-space-xl);
  align-items: center;
  padding: var(--ty-space-xl);
  background: var(--ty-color-card-bg);
  border-radius: var(--ty-radius-md);
}
.ty-curso-card:nth-child(even) {
  direction: rtl;
}
.ty-curso-card:nth-child(even) > * {
  direction: ltr;
}
.ty-curso-card__img {
  border-radius: var(--ty-radius-md);
  overflow: hidden;
}
.ty-curso-card__img img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--ty-radius-md);
}
.ty-curso-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-sm);
}
.ty-curso-card__tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.ty-curso-card__title {
  font-size: var(--ty-fs-3xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-curso-card__meta {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
}
.ty-curso-card__desc {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}
.ty-curso-card__includes {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.8 !important;
}

/* ============================================
   SOBRE TAYA
   ============================================ */
.ty-bio__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--ty-space-2xl);
  align-items: start;
}
.ty-bio__media img,
.ty-bio__img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  border-radius: var(--ty-radius-md);
  box-shadow: var(--ty-shadow-md);
}
.ty-bio__content {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-bio__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-bio__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.7 !important;
}
.ty-bio__credentials {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 2 !important;
}
.ty-valores__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-xl);
}
.ty-valores__header { text-align: center; }
.ty-valores__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--ty-space-lg);
  width: 100%;
}
.ty-valor__card {
  background: #fff;
  border-radius: var(--ty-radius-md);
  padding: var(--ty-space-lg);
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-sm);
}
.ty-valor__num {
  font-size: 40px !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-secondary) !important;
  opacity: 0.5;
  line-height: 1 !important;
  font-family: var(--ty-font-heading) !important;
}
.ty-valor__title {
  font-size: var(--ty-fs-xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-valor__text {
  font-size: var(--ty-fs-base) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}

/* ============================================
   CONTACTO
   ============================================ */
.ty-contacto__inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--ty-space-2xl);
  align-items: start;
}
.ty-contacto__info {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-contacto__title {
  font-size: var(--ty-fs-4xl) !important;
  line-height: 1.25 !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-contacto__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.625 !important;
}
.ty-contacto__data {
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: var(--ty-color-card-bg);
  padding: var(--ty-space-md);
  border-radius: var(--ty-radius-sm);
}
.ty-contacto__data-item {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text) !important;
}
.ty-contacto__microcopy {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
}
.ty-contacto__form-wrap {
  background: var(--ty-color-card-bg);
  border-radius: var(--ty-radius-md);
  padding: var(--ty-space-xl);
}
.ty-contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-md);
}
.ty-form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.ty-form-label {
  font-size: var(--ty-fs-sm) !important;
  font-weight: var(--ty-fw-medium) !important;
  color: var(--ty-color-heading) !important;
}
.ty-form-input {
  padding: 14px 20px;
  border-radius: var(--ty-radius-sm);
  border: 1px solid var(--ty-color-border);
  background: #fff;
  font-size: var(--ty-fs-base);
  font-family: var(--ty-font-body);
  color: var(--ty-color-text);
  width: 100%;
  box-sizing: border-box;
  transition: border-color 0.2s ease;
}
.ty-form-input:focus {
  border-color: var(--ty-color-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(132, 169, 140, 0.15);
}
.ty-form-textarea {
  resize: vertical;
  min-height: 140px;
}
.ty-form-submit { width: 100%; justify-content: center; }
.ty-form-gdpr {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-muted) !important;
  margin: 0 !important;
}

/* Responsive — paginas internas */
@media (max-width: 991px) {
  .ty-page-hero__inner,
  .ty-quees__inner,
  .ty-bio__inner,
  .ty-contacto__inner { grid-template-columns: 1fr; }
  .ty-curso-card { grid-template-columns: 1fr; direction: ltr !important; }
  .ty-curso-card:nth-child(even) { direction: ltr !important; }
  .ty-valores__grid { grid-template-columns: 1fr 1fr; }
  .ty-paraquien__grid { grid-template-columns: 1fr; }
}
@media (max-width: 767px) {
  .ty-page-hero__title { font-size: var(--ty-fs-4xl) !important; }
  .ty-valores__grid { grid-template-columns: 1fr; }
  .ty-contacto__form-wrap { padding: var(--ty-space-md); }
}

/* ============================================
   HEADER MOBILE — hamburguesa a la derecha
   ============================================ */
@media (max-width: 767px) {
  #brxe-hd004 {
    flex: 0 0 auto !important;
    justify-content: flex-end !important;
    margin-left: auto !important;
  }
  #brxe-hd004 .bricks-nav-menu--toggle {
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
  }
  /* Panel mobile del menú: ancho completo, fondo warm white */
  #brxe-hd004 .bricks-nav-menu {
    text-align: left !important;
  }
}

/* ============================================
   BLOG ARCHIVE — /blog/ y categorías
   ============================================ */

/* Hero del archivo */
.ty-archive-hero {
  background-color: var(--ty-color-card-bg);
  padding: var(--ty-space-2xl) 0 var(--ty-space-xl);
  text-align: center;
}
.ty-archive-hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-sm);
}
.ty-archive-hero__title {
  font-size: var(--ty-fs-5xl) !important;
  line-height: 1.1 !important;
  color: var(--ty-color-heading-dark) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-archive-hero__subtitle {
  font-size: var(--ty-fs-lg) !important;
  color: var(--ty-color-text-muted) !important;
  max-width: 560px;
}

/* Filtros de categoría */
.ty-section--sm {
  padding: var(--ty-space-md) 0 0;
  background-color: var(--ty-color-card-bg);
}
.ty-blog-filters__inner {
  border-bottom: 1px solid var(--ty-color-border);
  padding-bottom: var(--ty-space-md);
}
.ty-blog-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.ty-blog-cat {
  padding: 6px 18px;
  border-radius: var(--ty-radius-pill);
  font-size: var(--ty-fs-sm) !important;
  font-weight: var(--ty-fw-medium) !important;
  color: var(--ty-color-text) !important;
  text-decoration: none !important;
  border: 1px solid var(--ty-color-border);
  background: #fff;
  transition: var(--ty-transition);
  white-space: nowrap;
}
.ty-blog-cat:hover,
.ty-blog-cat--all,
.ty-blog-cat.current-cat {
  background-color: var(--ty-color-primary) !important;
  color: #fff !important;
  border-color: var(--ty-color-primary) !important;
}

/* Grid de posts (Bricks loop) */
.ty-blog-grid-section {
  background-color: var(--ty-color-bg);
}
.ty-blog-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--ty-space-xl) !important;
  width: 100% !important;
}
.ty-blog-grid__inner {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-2xl);
}

/* Card de blog (loop) */
.ty-blog-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: var(--ty-radius-md);
  overflow: hidden;
  box-shadow: var(--ty-shadow-sm);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ty-blog-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--ty-shadow-md);
}
.ty-blog-card__img-wrap {
  overflow: hidden;
  aspect-ratio: 16/9;
  flex-shrink: 0;
}
.ty-blog-card__img-wrap img,
.ty-blog-card__img-wrap a img,
.ty-post-img-fallback {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.ty-blog-card:hover .ty-blog-card__img-wrap img {
  transform: scale(1.05);
}
.ty-blog-card--loop .ty-blog-card__cat,
.ty-blog-card--loop .ty-blog-card__title,
.ty-blog-card--loop .ty-blog-card__excerpt,
.ty-blog-card--loop .ty-blog-card__meta,
.ty-blog-card--loop .ty-blog-card__link {
  padding-left: var(--ty-space-md);
  padding-right: var(--ty-space-md);
}
.ty-blog-card__cat {
  padding-top: var(--ty-space-sm) !important;
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-primary) !important;
  text-transform: uppercase;
  font-weight: var(--ty-fw-semibold) !important;
  letter-spacing: 0.05em;
  text-decoration: none !important;
}
.ty-blog-card__cat a {
  color: inherit !important;
  text-decoration: none !important;
}
.ty-blog-card__title {
  font-size: var(--ty-fs-lg) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
  line-height: 1.3 !important;
  margin-top: 8px !important;
}
.ty-blog-card__title a {
  color: inherit !important;
  text-decoration: none !important;
  transition: color 0.2s ease;
}
.ty-blog-card__title a:hover {
  color: var(--ty-color-primary) !important;
}
.ty-blog-card__excerpt {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.6 !important;
  margin-top: 8px !important;
}
.ty-blog-card__meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding-top: var(--ty-space-sm);
  padding-bottom: var(--ty-space-sm);
  border-top: 1px solid var(--ty-color-border);
  margin-top: 12px;
}
.ty-blog-card__date {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-lightest) !important;
}
.ty-blog-card__readtime {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-lightest) !important;
}
.ty-blog-card__readtime::before { content: · ; }
.ty-blog-card__link {
  padding-bottom: var(--ty-space-md) !important;
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-primary) !important;
  font-weight: var(--ty-fw-medium) !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: gap 0.2s ease;
}
.ty-blog-card__link:hover { gap: 8px !important; }

/* Paginación */
.ty-blog-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: var(--ty-space-md) 0;
  width: 100%;
}
.ty-blog-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border-radius: var(--ty-radius-pill);
  font-size: var(--ty-fs-sm);
  font-weight: var(--ty-fw-medium);
  color: var(--ty-color-text);
  text-decoration: none;
  border: 1px solid var(--ty-color-border);
  background: #fff;
  transition: var(--ty-transition);
}
.ty-blog-pagination .page-numbers.current,
.ty-blog-pagination .page-numbers:hover {
  background-color: var(--ty-color-primary);
  color: #fff;
  border-color: var(--ty-color-primary);
}
.ty-blog-pagination .prev,
.ty-blog-pagination .next {
  padding: 0 20px;
}

/* ============================================
   SINGLE POST
   ============================================ */

/* Barra breadcrumb */
.ty-breadcrumb-bar {
  background-color: var(--ty-color-card-bg);
  padding: var(--ty-space-sm) 0;
}
.ty-breadcrumb__nav {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--ty-fs-xs);
  flex-wrap: wrap;
}
.ty-breadcrumb__link {
  color: var(--ty-color-text-muted) !important;
  text-decoration: none !important;
  transition: color 0.2s ease;
}
.ty-breadcrumb__link:hover { color: var(--ty-color-primary) !important; }
.ty-breadcrumb__sep { color: var(--ty-color-text-lightest); }
.ty-breadcrumb__current {
  color: var(--ty-color-text);
  font-weight: var(--ty-fw-medium);
}

/* Hero del post */
.ty-post-hero {
  background-color: var(--ty-color-card-bg);
  padding: var(--ty-space-xl) 0;
  text-align: center;
}
.ty-post-hero__inner {
  max-width: 800px;
  margin: 0 auto;
}
.ty-post-hero__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--ty-space-sm);
}
.ty-post-hero__cat {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-primary) !important;
  text-transform: uppercase;
  font-weight: var(--ty-fw-semibold) !important;
  letter-spacing: 0.05em;
  text-decoration: none !important;
}
.ty-post-hero__cat a { color: inherit !important; text-decoration: none !important; }
.ty-post-hero__title {
  font-size: var(--ty-fs-5xl) !important;
  line-height: 1.15 !important;
  color: var(--ty-color-heading-dark) !important;
  font-weight: var(--ty-fw-bold) !important;
  max-width: 720px;
}
.ty-post-hero__excerpt {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.6 !important;
  max-width: 600px;
}
.ty-post-hero__meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: var(--ty-fs-xs);
  color: var(--ty-color-text-lightest);
  flex-wrap: wrap;
  justify-content: center;
}
.ty-post-meta__date, .ty-post-meta__readtime {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-lightest) !important;
}

/* Imagen destacada del post */
.ty-post-featured-img {
  padding: 0;
}
.ty-post-featured-img .ty-container { padding: 0; max-width: 1000px; }
.ty-post-img {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
  border-radius: 0;
  display: block;
}
.ty-post-img img,
.ty-post-img a img {
  width: 100%;
  max-height: 500px;
  object-fit: cover;
  display: block;
}

/* Cuerpo del post: contenido + sidebar */
.ty-post-body {
  background-color: var(--ty-color-bg);
}
.ty-post-body__inner {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--ty-space-2xl);
  align-items: start;
}

/* Tipografía del contenido (la prosa del artículo) */
.ty-prose,
.ty-post-content {
  font-family: var(--ty-font-body) !important;
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  line-height: 1.8 !important;
}
.ty-prose h2,
.ty-post-content h2 {
  font-size: var(--ty-fs-3xl) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
  margin-top: var(--ty-space-xl) !important;
  margin-bottom: var(--ty-space-sm) !important;
  line-height: 1.3 !important;
}
.ty-prose h3,
.ty-post-content h3 {
  font-size: var(--ty-fs-xl) !important;
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
  margin-top: var(--ty-space-lg) !important;
  margin-bottom: 8px !important;
}
.ty-prose p,
.ty-post-content p {
  margin-bottom: var(--ty-space-md) !important;
}
.ty-prose ul, .ty-prose ol,
.ty-post-content ul, .ty-post-content ol {
  padding-left: var(--ty-space-lg) !important;
  margin-bottom: var(--ty-space-md) !important;
}
.ty-prose li,
.ty-post-content li {
  margin-bottom: 8px !important;
  line-height: 1.7 !important;
}
.ty-prose strong,
.ty-post-content strong {
  font-weight: var(--ty-fw-semibold) !important;
  color: var(--ty-color-heading) !important;
}
.ty-prose table,
.ty-post-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--ty-space-md);
  font-size: var(--ty-fs-sm);
}
.ty-prose th,
.ty-post-content th {
  background-color: var(--ty-color-light-sage);
  color: var(--ty-color-heading);
  padding: 10px 16px;
  text-align: left;
  font-weight: var(--ty-fw-semibold);
}
.ty-prose td,
.ty-post-content td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--ty-color-border);
}
.ty-prose blockquote,
.ty-post-content blockquote {
  border-left: 3px solid var(--ty-color-primary);
  padding: var(--ty-space-sm) var(--ty-space-md);
  margin: var(--ty-space-md) 0;
  background-color: var(--ty-color-card-bg);
  border-radius: 0 var(--ty-radius-sm) var(--ty-radius-sm) 0;
  font-style: italic;
  color: var(--ty-color-text-muted);
}

/* Sidebar */
.ty-post-sidebar {
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-lg);
}

/* Box "Sobre Taya" en sidebar */
.ty-post-author-box {
  background-color: var(--ty-color-card-bg);
  border-radius: var(--ty-radius-md);
  padding: var(--ty-space-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--ty-space-sm);
}
.ty-post-author__img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}
.ty-post-author__img img { width: 100%; height: 100%; object-fit: cover; }
.ty-post-author__name {
  font-size: var(--ty-fs-md) !important;
  font-weight: var(--ty-fw-bold) !important;
  color: var(--ty-color-heading) !important;
  margin: 0 !important;
}
.ty-post-author__role {
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-primary) !important;
  font-weight: var(--ty-fw-medium) !important;
}
.ty-post-author__bio {
  font-size: var(--ty-fs-sm) !important;
  color: var(--ty-color-text-muted) !important;
  line-height: 1.6 !important;
}

/* Newsletter sidebar */
.ty-post-sidebar__nl {
  background-color: var(--ty-color-heading);
  border-radius: var(--ty-radius-md);
  padding: var(--ty-space-md);
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-sm);
}
.ty-post-sidebar__nl-title {
  color: #fff !important;
  font-size: var(--ty-fs-md) !important;
  font-weight: var(--ty-fw-bold) !important;
  margin: 0 !important;
}
.ty-post-sidebar__nl-text {
  color: rgba(255,255,255,0.7) !important;
  font-size: var(--ty-fs-sm) !important;
  line-height: 1.5 !important;
}
.ty-sidebar-nl-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ty-sidebar-nl-form .ty-form-input {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  color: #fff;
}
.ty-sidebar-nl-form .ty-form-input::placeholder { color: rgba(255,255,255,0.4); }

/* Tags del post */
.ty-post-tags-section {
  padding: var(--ty-space-md) 0;
  border-top: 1px solid var(--ty-color-border);
  border-bottom: 1px solid var(--ty-color-border);
  background: var(--ty-color-bg);
}
.ty-post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ty-post-tags a {
  padding: 4px 14px;
  border-radius: var(--ty-radius-pill);
  font-size: var(--ty-fs-xs) !important;
  color: var(--ty-color-text-muted) !important;
  border: 1px solid var(--ty-color-border);
  text-decoration: none !important;
  transition: var(--ty-transition);
  background: #fff;
}
.ty-post-tags a:hover {
  border-color: var(--ty-color-primary) !important;
  color: var(--ty-color-primary) !important;
}

/* CTA post final */
.ty-post-cta {
  background-color: var(--ty-color-light-sage);
}
.ty-post-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--ty-space-md);
}
.ty-post-cta__title {
  font-size: var(--ty-fs-4xl) !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-post-cta__text {
  font-size: var(--ty-fs-md) !important;
  color: var(--ty-color-text) !important;
  max-width: 500px;
}

/* Posts relacionados */
.ty-related-posts {
  background-color: var(--ty-color-bg);
}
.ty-related-posts__inner {
  display: flex;
  flex-direction: column;
  gap: var(--ty-space-lg);
}
.ty-related-posts__title {
  font-size: var(--ty-fs-3xl) !important;
  color: var(--ty-color-heading) !important;
  font-weight: var(--ty-fw-bold) !important;
}
.ty-related-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--ty-space-lg) !important;
}
.ty-blog-card--related .ty-blog-card__title {
  font-size: var(--ty-fs-base) !important;
  padding: 8px var(--ty-space-sm) 0 !important;
}
.ty-blog-card--related .ty-blog-card__date {
  padding: 0 var(--ty-space-sm) var(--ty-space-sm) !important;
}

/* ============================================
   RESPONSIVE — BLOG (tablet + mobile)
   ============================================ */
@media (max-width: 991px) {
  .ty-blog-grid,
  .ty-related-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .ty-post-body__inner { grid-template-columns: 1fr !important; }
  .ty-post-sidebar { position: static; }
  .ty-post-hero__title { font-size: var(--ty-fs-4xl) !important; }
}
@media (max-width: 767px) {
  .ty-blog-grid,
  .ty-related-grid { grid-template-columns: 1fr !important; }
  .ty-archive-hero__title { font-size: var(--ty-fs-4xl) !important; }
  .ty-post-hero__title { font-size: var(--ty-fs-3xl) !important; }
  .ty-blog-cats { justify-content: flex-start; }
}

/* ============================================
   TY-BLOG-GRID — Bricks posts element styling
   (replaces orphaned ty-blog-card child approach)
   ============================================ */

/* Cards layout */
.ty-blog-grid .bricks-layout-inner {
  background: var(--ty-color-card-bg);
  border-radius: var(--ty-radius-md);
  overflow: hidden;
  box-shadow: var(--ty-shadow-sm);
  transition: var(--ty-transition);
  height: 100%;
  display: flex;
  flex-direction: column;
}
.ty-blog-grid .bricks-layout-inner:hover {
  box-shadow: var(--ty-shadow-md);
  transform: translateY(-2px);
}

/* Image */
.ty-blog-grid .image-wrapper {
  display: block;
  overflow: hidden;
  aspect-ratio: 16/9;
  border-radius: 0;
  margin: 0;
}
.ty-blog-grid .image-wrapper img,
.ty-blog-grid .image-wrapper a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
  border-radius: 0;
}
.ty-blog-grid .bricks-layout-inner:hover .image-wrapper img {
  transform: scale(1.04);
}

/* Content wrapper */
.ty-blog-grid .content-wrapper {
  padding: var(--ty-space-md);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 8px;
}

/* Field 0: Category */
.ty-blog-grid .dynamic[data-field-id="0"],
.ty-blog-grid .content-wrapper > .dynamic:first-child {
  font-size: var(--ty-fs-sm);
  font-weight: var(--ty-fw-semibold);
  color: var(--ty-color-primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.ty-blog-grid .dynamic[data-field-id="0"] a {
  color: var(--ty-color-primary);
  text-decoration: none;
}
.ty-blog-grid .dynamic[data-field-id="0"] a:hover {
  text-decoration: underline;
}

/* Field 1: Title (h2) */
.ty-blog-grid .dynamic[data-field-id="1"],
.ty-blog-grid h2.dynamic {
  font-size: var(--ty-fs-md);
  font-weight: var(--ty-fw-bold);
  color: var(--ty-color-heading);
  line-height: 1.3;
  margin: 0;
}
.ty-blog-grid h2.dynamic a,
.ty-blog-grid .dynamic[data-field-id="1"] a {
  color: var(--ty-color-heading);
  text-decoration: none;
}
.ty-blog-grid h2.dynamic a:hover,
.ty-blog-grid .dynamic[data-field-id="1"] a:hover {
  color: var(--ty-color-primary);
}

/* Field 2: Excerpt */
.ty-blog-grid .dynamic[data-field-id="2"] {
  font-size: var(--ty-fs-base);
  color: var(--ty-color-text);
  line-height: 1.6;
  flex: 1;
}

/* Field 3: Date */
.ty-blog-grid .dynamic[data-field-id="3"] {
  font-size: var(--ty-fs-sm);
  color: var(--ty-color-text-lightest);
  margin-top: auto;
  padding-top: var(--ty-space-xs);
}

/* Pagination */
.ty-blog-pagination .bricks-pagination {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: var(--ty-space-xl);
}
.ty-blog-pagination .bricks-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--ty-radius-pill);
  border: 2px solid var(--ty-color-border);
  color: var(--ty-color-text);
  font-size: var(--ty-fs-sm);
  text-decoration: none;
  transition: var(--ty-transition);
}
.ty-blog-pagination .bricks-pagination .page-numbers.current,
.ty-blog-pagination .bricks-pagination .page-numbers:hover {
  background: var(--ty-color-primary);
  border-color: var(--ty-color-primary);
  color: #fff;
}

/* Responsive adjustments for blog grid */
@media (max-width: 767px) {
  .ty-blog-grid .content-wrapper {
    padding: var(--ty-space-sm);
  }
}

/* ─────────────────────────────────────────────
   FIX: Blog grid — grid en ul, no en div padre
   ───────────────────────────────────────────── */

/* Quitar grid del div padre (solo 1 hijo: el <ul>) */
.ty-blog-grid {
  display: block !important;
  grid-template-columns: none !important;
}

/* Aplicar grid al <ul> que contiene los <li> */
.ty-blog-grid .bricks-layout-wrapper {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--ty-space-xl, 32px) !important;
  width: 100% !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Items deben ocupar todo el ancho de su celda */
.ty-blog-grid .bricks-layout-item {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}

/* El sizer isotope de Bricks no debe ocupar celda visual */
.ty-blog-grid .bricks-isotope-sizer {
  display: none !important;
}

/* Responsive tablet */
@media (max-width: 991px) {
  .ty-blog-grid .bricks-layout-wrapper {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: var(--ty-space-lg, 24px) !important;
  }
}

/* Responsive mobile */
@media (max-width: 767px) {
  .ty-blog-grid .bricks-layout-wrapper {
    grid-template-columns: 1fr !important;
    gap: var(--ty-space-md, 16px) !important;
  }
}

/* ─────────────────────────────────────────────
   FIX: Blog hero — centrar títulos
   ───────────────────────────────────────────── */
.ty-archive-hero__content {
  text-align: center !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  width: 100% !important;
}

#brx-content .ty-archive-hero__title {
  text-align: center !important;
}

#brx-content .ty-archive-hero__subtitle {
  text-align: center !important;
}

.ty-archive-hero .ty-about__eyebrow {
  text-align: center !important;
  width: auto !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LEGAL PAGES
   ═══════════════════════════════════════════════════════════════════════════ */

.ty-legal {
  padding: var(--ty-space-2xl) 0;
  background: var(--ty-color-bg);
}

.ty-legal__inner {
  max-width: 780px;
}

.ty-legal__header {
  margin-bottom: var(--ty-space-xl);
  padding-bottom: var(--ty-space-lg);
  border-bottom: 2px solid var(--ty-color-sage-light);
}

.ty-legal__title {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  color: var(--ty-color-heading);
  margin-bottom: var(--ty-space-sm);
}

.ty-legal__intro {
  color: var(--ty-color-text-light);
  font-size: 0.95rem;
}

.ty-legal__body {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.ty-legal__subtitle {
  font-size: 1.2rem;
  color: var(--ty-color-heading);
  margin-top: var(--ty-space-lg);
  margin-bottom: var(--ty-space-sm);
  padding-top: var(--ty-space-md);
  border-top: 1px solid var(--ty-color-border, #eee);
}

.ty-legal__subtitle:first-child {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

.ty-legal__text {
  color: var(--ty-color-text);
  font-size: 0.95rem;
  line-height: 1.75;
}

.ty-legal__text p {
  margin-bottom: 0.75em;
}

.ty-legal__text ul,
.ty-legal__text ol {
  padding-left: 1.5em;
  margin-bottom: 1em;
}

.ty-legal__text li {
  margin-bottom: 0.4em;
  line-height: 1.65;
}

.ty-legal__text a {
  color: var(--ty-color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.ty-legal__text a:hover {
  color: var(--ty-color-primary-dark, var(--ty-color-heading));
}

.ty-legal__text table {
  width: 100%;
  border-collapse: collapse;
  margin: 1em 0;
  font-size: 0.9rem;
}

.ty-legal__text th,
.ty-legal__text td {
  padding: 0.65em 1em;
  border: 1px solid var(--ty-color-border, #e0e0e0);
  text-align: left;
}

.ty-legal__text th {
  background: var(--ty-color-sage-light);
  font-weight: 600;
  color: var(--ty-color-heading);
}

.ty-legal__text strong {
  color: var(--ty-color-heading);
}

/* Footer legal links */
.ty-footer__legal {
  display: flex;
  flex-wrap: wrap;
  gap: var(--ty-space-sm) var(--ty-space-md);
  justify-content: center;
}

.ty-footer__legal-link {
  font-size: 0.8rem;
  color: var(--ty-color-text-light);
  text-decoration: none;
  transition: var(--ty-transition);
}

.ty-footer__legal-link:hover {
  color: var(--ty-color-primary);
}

@media (max-width: 767px) {
  .ty-legal {
    padding: var(--ty-space-xl) 0;
  }
  .ty-legal__title {
    font-size: 1.5rem;
  }
  .ty-legal__text table {
    font-size: 0.8rem;
  }
  .ty-legal__text th,
  .ty-legal__text td {
    padding: 0.5em 0.6em;
  }
  .ty-footer__legal {
    flex-direction: column;
    align-items: center;
    gap: var(--ty-space-xs);
  }
}

/* Footer social icons */
.ty-footer__social {
  display: flex !important;
  flex-direction: row !important;
  gap: 12px !important;
  margin-top: var(--ty-space-sm) !important;
}
.ty-footer__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  transition: all 0.2s ease;
}
.ty-footer__icon:hover {
  background: var(--ty-color-primary);
  color: #fff;
}
.ty-footer__icon svg {
  display: block;
}
.ty-footer__social-link {
  line-height: 1 !important;
}

/* Footer newsletter form — inline with arrow button */
.ty-ftr-form {
  display: flex !important;
  flex-direction: row !important;
  gap: 0 !important;
  margin-top: 4px;
  position: relative;
}
.ty-ftr-form__input {
  flex: 1;
  padding: 10px 44px 10px 16px;
  border-radius: var(--ty-radius-pill);
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.08);
  color: #fff;
  font-size: var(--ty-fs-sm);
  font-family: var(--ty-font-body);
}
.ty-ftr-form__input::placeholder { color: rgba(255,255,255,0.4); }
.ty-ftr-form__input:focus { border-color: var(--ty-color-primary); outline: none; }
.ty-ftr-form__btn {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: var(--ty-color-primary);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 0.2s ease;
}
.ty-ftr-form__btn:hover {
  background: var(--ty-color-primary-dark, #5a7d5f);
}
.ty-ftr-form__btn svg {
  display: block;
}
