@import url("reset.css");

@import url("https://fonts.googleapis.com/css?family=Inter:regular,500,600,700&display=swap");

/* ************COMMON************ */

.logo {
  font-weight: 700;
  font-size: 2.25rem;
}

body {
  font-family: "Inter", sans-serif;
  font-size: 1.1rem;
  color: #303a4d;
}

/* Ensure all elements use Inter font consistently */
* {
  font-family: "Inter", sans-serif;
}

[class*="__container"] {
  max-width: 72.624rem;
  margin: 0 auto;
  padding: 0 0.938rem;
}

.button {
  font-weight: 600;
  display: inline-block;
  padding: 0.75rem 1.5rem;
  border-radius: 30px;
  transition: all 0.3s;
  color: #fff;
  background-color: #303a4d;
}

.title {
  font-size: 3.5rem;
  font-weight: 600;
}

.wrapper {
  min-height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  overflow: hidden;
}

/* ************HEADER************ */

.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  background: transparent;
  z-index: 1000;
}

.header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 5.75rem;
  flex-wrap: wrap;
  max-width: 74.624rem;
}

.header__logo {
  position: relative;
  z-index: 2;
}

.header__navigation {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.menu__body {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.menu__link {
  font-weight: 600;
  position: relative;
}

.actions-header {
  display: flex;
  align-items: center;
  gap: 0.624rem;
}

.icon-menu {
  display: none;
}

.actions-header__button {
  font-weight: 600;
  display: inline-block;
  padding: 0.75rem 1.5rem;
  border-radius: 30px;
  transition: all 0.3s;
  color: #fff;
  background-color: #303a4d;
  border: none;
  letter-spacing: 0.02em;
  line-height: 110%;
}

/* ****************PAGES**************** */
.page__main {
  padding-bottom: 160px;
}

/* *****************HOME**************** */

.main {
  background: url("../images/home/guachohero.jpg") center top/cover no-repeat;
  min-height: 100vh;
}

.main__container {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding-top: 19.188rem;
}

.main__caption {
  text-transform: uppercase;
  margin-bottom: 1rem;
  font-weight: 500;
}

.main__title {
  font-size: 5.5rem;
  font-weight: 600;
  margin-bottom: 2rem;
}

.main__text {
  margin-bottom: 3.5rem;
  max-width: 33.375rem;
  line-height: 150%;
  letter-spacing: 0.02em;
}

.main__button {
  font-weight: 600;
  display: inline-block;
  padding: 1.25rem 3rem;
  border-radius: 30px;
  transition: all 0.3s;
  color: #fff;
  background-color: #303a4d;
  letter-spacing: 0.02em;
  font-size: 1.375rem;
  line-height: 110%;
}

.outro_home {
  background: url("../img/home/hero_placeholder.jpg") center / cover no-repeat;
}

/* ************ABOUT**************** */

.main_about {
  background: url("../img/about/background_placeholder.png") center / cover no-repeat;
}

.about__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-top: 8.75rem;
  padding-bottom: 8.75rem;
}

.about__image {
  position: relative;
  max-width: 552px;
  height: 614px;
}

.about__image img {
  border-radius: 16px;
  max-width: 100%;
  height: 100%;
  object-fit: cover;
}

.about__title {
  margin-bottom: 1.5rem;
}

.about__text {
  max-width: 30rem;
  letter-spacing: 0.02em;
  line-height: 150%;
  margin-bottom: 3.5rem;
}

.about__text p:not(:last-child) {
  margin-bottom: 2.5rem;
}

.outro_about {
  background: url("../img/about/hero_placeholder.jpg") center / cover no-repeat;
}

/* **************SERVICES**************** */

.main_services {
  background: url("../img/services/background_placeholder.png") center / cover no-repeat;
}

.services {
  background-color: #e1e4eb;
}

.services__container {
  padding-top: 8.75rem;
  padding-bottom: 8.75rem;
}

.services__title {
  text-align: center;
  margin-bottom: 5rem;
}

.services__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}

.item-services {
  display: flex;
  flex-direction: column;
  align-items: start;
  min-height: 100%;
}

.item-services__image {
  margin-bottom: 2rem;
  max-width: 360px;
  height: 421px;
}

.item-services__image img {
  max-width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}

.item-services__title {
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}

.item-services__text {
  max-width: 21.5rem;
  line-height: 150%;
  margin-bottom: 2rem;
  flex-grow: 1;
  letter-spacing: 0.02em;
}

.item-services__button {
  background-color: inherit;
  border: 2px solid #303a4d;
  color: #303a4d;
}

.outro_services {
  background: url("../img/services/hero_placeholder.jpg") center / cover no-repeat;
}

/* ************TESTIMONIAL**************** */

.testimonial__container {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  flex-direction: column;
  padding-top: 8.75rem;
  padding-bottom: 8.75rem;
}

.testiomonial__caption {
  margin-bottom: 4rem;
  font-weight: 600;
  text-transform: uppercase;
}

.testimonial__title {
  margin-bottom: 4rem;
  font-size: 2rem;
  max-width: 40.75rem;
  line-height: 136%;
  font-weight: 500;
}

.item-testimonial__image {
  max-width: 64px;
  margin: 0 auto;
  margin-bottom: 1.063rem;
  height: 64px;
}

.item-testimonial__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.item-testimonial__title {
  margin-bottom: 0.25rem;
  font-weight: 600;
}

.item-testimonial__caption {
  font-size: 0.938rem;
}

/* ****************OUTRO**************** */

.outro__container {
  padding-top: 8.75rem;
  padding-bottom: 8.75rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.outro__title {
  margin-bottom: 1.25rem;
}

.outro__text {
  max-width: 33.625rem;
  line-height: 150%;
  margin-bottom: 2.5rem;
  letter-spacing: 0.02em;
}

.outro__button {
  padding: 1.25rem 3rem;
}



/* ****************ABOUT PAGE**************** */
.main__text_pages {
  max-width: 37.5rem;
}

.main__container_pages {
  padding-top: 300px;
}

.main_pages {
  min-height: 676px !important;
}

/* ****************SERVICES PAGE**************** */
.services-page__container {
  padding-top: 160px;
}

.services-page__item {
  margin-bottom: 132px;
}

.services-page__item:not(:last-child) {
  padding-bottom: 132px;
  margin-bottom: 132px;
  border-bottom: 1px solid rgba(48, 58, 77, 0.4);
}

.services-page__column {
  display: flex;
  align-items: center;
  gap: 97px;
}

.services-page__title {
  margin-bottom: 24px;
}

.services-page__text {
  margin-bottom: 56px;
  max-width: 480px;
  font-size: 18px;
  line-height: 150%;
  letter-spacing: 0.02em;
}

.services-page__text p:not(:last-child) {
  margin-bottom: 20px;
}

.services-page__img {
  max-width: 552px;
  height: 614px;
}

.services-page__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}

/* ****************CONTACT PAGE****************/

.main_contact {
  background: url("../img/contact/background_placeholder.png") center / cover no-repeat;
}

.contact__container {
  display: flex;
  justify-content: space-between;
  gap: 109px;
  padding-top: 140px;
  padding-bottom: 140px;
}

.contact__title {
  margin-bottom: 48px;
  font-weight: 600;
  line-height: 110%;
  font-size: 40px;
}

.connect-contact {
  display: flex;
  flex-direction: column;
  align-items: start;
  row-gap: 32px;
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid #e1e4eb;
}

.connect-contact__item {
  display: inline-flex;
  align-items: center;
  gap: 24px;
}

.connect-contant__type {
  margin-bottom: 4px;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 110%;
  text-transform: uppercase;
}

.connect-contact__label {
  font-size: 22px;
  line-height: 150%;
  letter-spacing: 0.02em;
}

.contact__links {
  display: flex;
  align-items: center;
  gap: 12px;
}

.contact__text {
  max-width: 545px;
  font-size: 18px;
  line-height: 150%;
}

.contact__text p:not(:last-child) {
  margin-bottom: 15px;
}

iframe {
  width: 100vw;
  height: 482px;
  filter: grayscale(100%);
}

/* **************REVIEWS PAGE**************** */
.reviews__container {
  padding-top: 160px;
  padding-bottom: 160px;
}

.reviews__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 24px;
  row-gap: 96px;
}

.reviews__column {
  border: 1px solid #e1e4eb;
  border-radius: 8px;
}

.reviews__item {
  padding-top: 48px;
  padding-bottom: 56px;
  padding-right: 32px;
  padding-left: 32px;
}

.item-reviews {
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.item-reviews__img {
  max-width: 46px;
  height: 36px;
  margin: 0 auto;
  margin-bottom: 46px;
}

.item-reviews__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.item-reviews__text {
  margin-bottom: 40px;
  font-size: 18px;
  letter-spacing: 0.02em;
  line-height: 150%;
}

.item-reviews__author {
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0.01em;
  margin-bottom: 10px;
}

.item-reviews__geo {
  font-size: 14px;
  letter-spacing: 0.002em;
}

/* ******************PRICING PAGE******************** */
.pricing__container {
  padding-top: 140px;
  padding-bottom: 140px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.pricing__caption {
  font-size: 24px;
  font-weight: 600;
  margin-bottom: 12px;
  letter-spacing: 4%;
}

.pricing__title {
  font-weight: 600;
  font-size: 72px;
  margin-bottom: 24px;
}

.pricing__text {
  font-size: 22px;
  letter-spacing: 2%;
  margin-bottom: 88px;
}

.pricing__row {
  display: flex;
  align-items: start;
  gap: 24px;
}

.pricing__column {
  border: 2px solid #e1e4eb;
  border-radius: 8px;
}

.pricing__item {
  padding: 40px;
  padding-bottom: 48px;
}

.item-pricing__info {
  padding-bottom: 32px;
  border-bottom: 1px solid #e1e4eb;
  margin-bottom: 32px;
}

.item-pricing__label {
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 1%;
  margin-bottom: 16px;
}

.item-pricing__cost {
  font-size: 72px;
  font-weight: 600;
  margin-bottom: 16px;
}

.item-pricing__list {
  margin-bottom: 64px;
}

.item-pricing__item {
  display: flex;
  align-items: center;
  gap: 6px;
}

.item-pricing__item::before {
  content: "";
  background: url("../img/pricing/check.svg") 0 0 no-repeat;
  width: 16px;
  height: 18px;
}

.item-pricing__item:not(:last-child) {
  margin-bottom: 12px;
}

.item-pricing__button {
  display: inline-block;
  font-size: 22px;
  letter-spacing: 2%;
  font-weight: 600;
  color: #fff;
  padding: 20px 82px;
  background-color: #303a4d;
  border-radius: 64px;
}

.team {
  background-color: #e1e4eb;
}

.team__container {
  padding-top: 140px;
  padding-bottom: 140px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.team__title {
  text-align: center;
  margin-bottom: 96px;
  max-width: 483px;
}

.team__row {
  display: grid;
  column-gap: 24px;
  row-gap: 96px;
  grid-template-columns: repeat(3, 1fr);
}

.team__item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.item-team__img {
  max-width: 360px;
  height: 363px;
  margin-bottom: 40px;
}

.item-team__img img {
  width: 100%;
  height: 100%;
  border-radius: 8px;
  object-fit: cover;
}

.item-team__name {
  max-width: 186px;
  font-size: 32px;
  font-weight: 600;
  line-height: 120%;
  text-align: center;
  margin-bottom: 12px;
}

.item-team__role {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 26px;
  letter-spacing: 2%;
}

.item-team__role span {
  display: flex;
  align-items: center;
  gap: 6px;
}

.item-team__role span::after {
  content: "";
  background: url("../img/team/icons/star.svg") 0 0 no-repeat;
  width: 12px;
  height: 12px;
}

.item-team__text {
  font-size: 16px;
  text-align: center;
  letter-spacing: 2%;
  line-height: 150%;
  max-width: 328px;
  margin-bottom: 20px;
}

.item-team__icons {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* *************FAQ PAGE************** */
.faqs__container {
  padding-top: 140px;
  padding-bottom: 140px;
}

.faqs__title {
  text-align: center;
  margin-bottom: 80px;
}

.spollers-faq__item {
  width: 100%;
}

.spollers-faq__item:not(:last-child) {
  margin-bottom: 24px;
}

.spollers-faq__button {
  display: inline-block;
  border: 2px solid #e1e4eb;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  border-radius: 8px;
}

.spollers-faq__button span {
  padding-left: 40px;
  padding-top: 32px;
  padding-bottom: 32px;
  font-weight: 600;
}

.spollers-faq__button img {
  padding-right: 34.5px;
}

.spollers-faq__text {
  max-height: 0;
  overflow: hidden;
  width: 100%;
  display: block;
}

.spollers-faq__item.active .spollers-faq__text {
  max-height: 1000px;
  max-height: calc(1000px + 16px);
}

.spollers-faq__item.active .spollers-faq__button {
  border-bottom: none;
  border-radius: 8px 8px 0px 0px;
}

.spollers-faq__item.active .spollers-faq__button span {
  padding-bottom: 32px;
}

.spollers-faq__item.active .spollers-faq__button img {
  transform: translate(-34px, 0px) rotate(180deg);
}

.spollers-faq__inner {
  padding-top: 20px;
  padding-left: 40px;
  border: 2px solid #e1e4eb;
  border-radius: 0px 0px 8px 8px;
  line-height: 150%;
  padding-bottom: 20px;
  border-top: none;
  padding-right: 100px;
}

/* ****************TEAM PAGE**************** */
.director__container {
  padding-top: 140px;
  padding-bottom: 140px;
  display: flex;
  align-items: center;
  gap: 96px;
}

.director__title {
  margin-bottom: 16px;
}

.director__role {
  font-size: 22px;
  letter-spacing: 2%;
  margin-bottom: 40px;
}

.director__text {
  letter-spacing: 2%;
  line-height: 150%;
  max-width: 480px;
}

.director__text p:not(:last-child) {
  margin-bottom: 20px;
}

.director__img {
  max-width: 552px;
  height: 614px;
}

.director__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}

/* ****************GALLERY**************** */
.gallery__container {
  padding-bottom: 140px;
  padding-top: 140px;
}

.gallery__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 24px;
  row-gap: 96px;
  margin-bottom: 96px;
  justify-items: center;
}

.gallery__item {
  max-width: 360px;
  height: 407px;
}

.gallery__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
}

.gallery__paggination {
  display: flex;
  align-items: center;
  justify-content: center;
  align-items: center;
  gap: 42px;
}

.gallery__paggination button:first-child {
  transform: translate(0px, 5px);
}

.gallery__paggination button:last-child {
  transform: rotate(-180deg) translate(0px, 5px);
}

.gallery_active {
  color: #fff;
  padding: 10px 15px;
  background-color: #303a4d;
  border-radius: 100px;
  display: inline-block;
}

/* ****************RESOURCES**************** */
.resources__container {
  padding-top: 140px;
  padding-bottom: 140px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 24px;
  row-gap: 96px;
  justify-items: center;
}

.resources__img {
  max-width: 360px;
  height: 330px;
  margin-bottom: 32px;
}

.resources__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 12px;
}

.resources__title {
  font-weight: 600;
  font-size: 24px;
  margin-bottom: 12px;
}

.resources__text {
  letter-spacing: 2%;
  line-height: 150%;
  max-width: 243px;
  margin-bottom: 32px;
}

.resources__button {
  background-color: #fff;
  color: #303a4d;
  font-weight: 600;
  letter-spacing: 2%;
  border: 2px solid #303a4d;
  border-radius: 64px;
}

/* ****************ADAPTIVE**************** */

@media (max-width: 992px) {
  .services__row {
    grid-template-columns: 1fr;
    gap: 6rem;
    justify-items: center;
  }

  .item-services {
    text-align: center;
    align-items: center;
  }

  .page__main {
    padding-bottom: 80px;
  }
}

@media (min-width: 47.999rem) {
  .menu__list {
    display: none;
  }
}

@media (max-width: 995px) {
  .item-pricing__button {
    font-size: 19px;
  }
}

@media (max-width: 62.6875rem) {
  .resources__container {
    padding-top: 70px;
    padding-bottom: 70px;
    grid-template-columns: repeat(2, 1fr);
  }

  .gallery__paggination {
    gap: 27px;
  }

  .gallery__row {
    grid-template-columns: repeat(2, 1fr);
  }

  .team__row {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 30px;
  }

  .director__container {
    flex-direction: column;
    padding-top: 70px;
    padding-bottom: 70px;
    gap: 10px;
    text-align: center;
  }

  .item-pricing {
    padding: 20px;
    padding-bottom: 30px;
  }

  .pricing__title {
    font-size: 39px;
  }

  .pricing__text {
    margin-bottom: 25px;
  }

  .item-pricing__button {
    padding: 16px 42px;
  }

  .footer__container {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 2rem;
  }

  .footer__policy,
  .footer__copyright {
    justify-self: center;
    text-align: center;
    margin: 0.5rem 0;
  }

  .footer__logo {
    margin-bottom: 1rem;
  }

  .services-page__column {
    gap: 30px;
    font-size: 15px;
  }

  .services-page__title {
    font-size: 29px;
  }

  .reviews__row {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 30px;
    column-gap: 10px;
  }

  .reviews__item {
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 20px;
    padding-top: 20px;
    display: inline-block;
  }

  .item-reviews__text {
    font-size: 16px;
  }

  .item-reviews__author {
    font-size: 16px;
  }
}

@media (max-width: 47.999rem) {
  .spollers-faq__item.active .spollers-faq__button img {
    transform: translate(-10px, -10px) rotate(180deg);
  }

  .spollers-faq__button span {
    padding-top: 15px;
    padding-left: 10px;
    padding-bottom: 15px;
    font-weight: 600;
    font-size: 14px;
  }

  .spollers-faq__button img {
    padding-right: 10px;
  }

  .spollers-faq__inner {
    font-size: 16px;
    padding-left: 10px;
    line-height: 130%;
  }

  .pricing__container {
    text-align: center;
    padding-top: 70px;
    padding-bottom: 70px;
  }

  .pricing__row {
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }

  .item-pricing__button {
    font-size: 17px;
    padding: 15px 32px;
  }

  .reviews__container {
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .icon-menu {
    display: block;
    position: relative;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 1.875rem;
    flex: 0 0 1.875rem;
    width: 1.875rem;
    height: 1.125rem;
    cursor: pointer;
    z-index: 5;
  }

  .icon-menu span,
  .icon-menu::before,
  .icon-menu::after {
    content: "";
    -webkit-transition: all 0.3s ease 0s;
    -o-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
    right: 0;
    position: absolute;
    width: 100%;
    height: 0.125rem;
    background-color: #000;
  }

  .icon-menu::before {
    top: 0;
  }

  .icon-menu::after {
    bottom: 0;
  }

  .contact__container {
    flex-direction: column;
    padding-top: 80px;
    gap: 50px;
    padding-bottom: 80px;
  }

  .icon-menu span {
    top: calc(50% - 0.0625rem);
  }

  .menu-open .icon-menu span {
    width: 0;
  }

  .menu-open .icon-menu::before {
    top: calc(50% - 0.0625rem);
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }

  .menu-open .icon-menu::after {
    bottom: calc(50% - 0.0625rem);
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
  }

  .menu__body {
    background-color: #fff;
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    padding: 9.375rem 0.938rem 1.875rem 0.938rem;
    overflow: auto;
    flex-direction: column;
    row-gap: 5rem;
  }

  .menu__body::before {
    content: "";
    position: fixed;
    top: 0;
    left: -100%;
    width: 100%;
    min-height: 5.75rem;
    background-color: #fff;
    border-bottom: 1px solid #000;
    z-index: 2;
  }

  .menu-open .menu__body {
    left: 0;
  }

  .menu-open .menu__body::before {
    left: 0;
  }

  .menu__item {
    text-align: center;
  }

  .menu__item:not(:last-child) {
    margin-bottom: 1.563rem;
  }

  .menu__link {
    font-size: 2rem;
  }

  .actions-header__button {
    padding: 0.75rem;
  }

  .main__container {
    padding-top: 12.5rem;
  }

  .main__container_pages {
    padding-top: 290px;
  }

  .main__title {
    font-size: 3rem;
  }

  .title {
    font-size: 2rem;
  }

  .about__content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
  }

  .about__container {
    flex-direction: column;
    padding-top: 4.375rem;
    padding-bottom: 4.375rem;
    gap: 4rem;
  }

  .services__container {
    padding-top: 4.375rem;
    padding-bottom: 4.375rem;
  }

  .testimonial__title {
    font-size: 1.5rem;
    margin-bottom: 2rem;
  }

  .testiomonial__caption {
    margin-bottom: 2rem;
  }

  .outro__container {
    padding-top: 4.375rem;
    padding-bottom: 4.375rem;
  }

  .logo {
    font-size: 1rem;
  }

  .services-page__column {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    font-size: 20px;
    gap: 4rem;
  }
}

@media (max-width: 61.936rem) {
  .footer__container {
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    row-gap: 0.938rem;
  }

  .logo {
    font-size: 2rem;
  }
}

@media (max-width: 530px) {
  .reviews__row {
    grid-template-columns: 1fr;
  }

  .team__row {
    grid-template-columns: 1fr;
  }

  .gallery__row {
    grid-template-columns: 1fr;
  }

  .resources__container {
    grid-template-columns: 1fr;
  }
}

/* Hero two-column layout */
.hero-flex {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 3rem;
  padding-top: 14rem;
  background: none;
}
.hero-left {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
}
.hero-right {
  flex: 1;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}
.hero-image {
  max-width: 100%;
  height: auto;
  border-radius: 16px;
}
.main__title {
  text-align: left !important;
  font-family: "Inter", sans-serif;
  font-size: 3.3rem;
  margin-left: 0;
  margin-bottom: 1.5rem;
}
.main__text {
  text-align: left !important;
  margin-bottom: 2.5rem;
}
.main__button {
  text-align: left !important;
  display: inline-block;
}
.logo-large {
  font-size: 1.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.logo-small {
  font-size: 1.44rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

/* --- Services Section Refactor --- */
.services__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  margin-top: 3rem;
  align-items: stretch;
}
@media (min-width: 768px) {
  .services__row {
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
  }
}
@media (min-width: 1280px) {
  .services__row {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 3rem;
  }
}
.services__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background: #fff;
  border: 1px solid #e1e4eb;
  border-radius: 16px;
  padding: 28px;
  min-height: 340px;
  box-sizing: border-box;
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transition: box-shadow 0.2s, border-color 0.2s;
  height: 100%;
}
.services__card:hover {
  box-shadow: 0 4px 24px 0 rgba(48,58,77,0.08);
  border-color: #bfc7d1;
}
.services__icon {
  width: 64px;
  height: 64px;
  object-fit: contain;
  opacity: 0.85;
  margin-bottom: 1.5rem;
  flex-shrink: 0;
}
.services__card-title {
  font-size: 1.375rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: #303a4d;
  line-height: 1.2;
  flex-shrink: 0;
}
.services__card-desc {
  font-size: 1rem;
  line-height: 1.6;
  max-width: 45ch;
  color: #303a4d;
  margin-bottom: 0;
  flex: 1 1 auto;
}
.services__container {
  padding-top: 6rem;
  padding-bottom: 6rem;
}


/* --- Our Approach Section --- */
.our-approach {
  background: #fff;
  padding-top: 80px;
  padding-bottom: 80px;
}
.our-approach__container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1.5rem;
  text-align: left;
}
.our-approach__title {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  margin-bottom: 2.25rem;
  line-height: 1.2;
  text-align: center;
}
.our-approach__intro {
  font-size: 1.125rem;
  line-height: 1.65;
  max-width: 720px;
  margin-bottom: 2rem;
}
.our-approach__bullets {
  font-size: 1.08rem;
  line-height: 1.65;
  max-width: 700px;
  margin-bottom: 2.25rem;
  padding-left: 1.5rem;
}
.our-approach__bullets li {
  margin-bottom: 0.75rem;
}
.our-approach__outcome {
  font-size: 1.13rem;
  line-height: 1.7;
  max-width: 720px;
  font-weight: 600;
}
@media (max-width: 1024px) {
  .our-approach {
    padding-top: 48px;
    padding-bottom: 48px;
  }
}
@media (max-width: 600px) {
  .our-approach {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .our-approach__title {
    font-size: 1.75rem;
  }
  .our-approach__intro, .our-approach__bullets, .our-approach__outcome {
    font-size: 1rem;
  }
}



/* --- Testimonials Section (3-up grid) --- */
.testimonials {
  background: #e1e4eb;
  padding-top: 80px;
  padding-bottom: 80px;
}






@media (max-width: 1024px) {
  .testimonials {
    padding-top: 48px;
    padding-bottom: 48px;
  }
}
@media (max-width: 600px) {
  .testimonials {
    padding-top: 32px;
    padding-bottom: 32px;
  }
  .testimonials__title {
    font-size: 1.75rem;
  }
  .testimonial__quote, .testimonial__name, .testimonial__role {
    font-size: 1rem;
  }
}


@media (max-width: 1024px) {
  .cta-closer {
    padding-top: 64px;
    padding-bottom: 64px;
  }
}
@media (max-width: 600px) {
  .cta-closer {
    padding-top: 40px;
    padding-bottom: 40px;
  }
  .cta-closer__container {
    align-items: flex-start;
    text-align: left;
  }
}

:root{
  --ink:#13202C;
  --ink-2:#556475;
  --brand:#0F2739;
  --brand-hover:#143449;
  --focus:#85B6D6;
  --leather:#8B5E3C;
  --sky-1:#F0F6FF;
  --sky-2:#CFE6FF;
  --grass-1:#F8F4EC;
  --grass-2:#E7D8BF;
  --stroke:#E6E1D9;
  --page:#FCFBF8;
  --card:#FFFFFF;
  --shadow:0 10px 30px rgba(17,24,39,.06);
  
  --paper:#FCFBF8;         /* warm paper */
  --grain:rgba(0,0,0,.02); /* faint grain */
  --warm:#F7F3EC;          /* simple warm tint */
}

/* Global neutrals and text */
body{ background:var(--page); color:var(--ink); }
h1,h2,h3{ color:var(--ink); }
p,li{ color:var(--ink-2); }

/* Buttons and links */
.btn.btn--primary{ background:var(--brand); color:#fff; }
.btn.btn--primary:hover{ background:var(--brand-hover); }
a{ color:var(--brand); text-decoration:underline transparent 2px; text-underline-offset:2px; }
a:hover{ text-decoration-color:currentColor; }
.approach{padding-block:clamp(48px,6vw,96px);}
.approach__container{max-width:1100px;margin:0 auto;padding:0 24px;}
.kicker{
  font-size: clamp(18px, 2.5vw, 24px);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--leather, #8B5E3C);
  margin: 0 auto clamp(8px, 1.2vw, 12px);
  text-align: center;
  display: block;
  font-weight: 600;
}
.approach__title{margin:0 0 16px;font-size:clamp(28px,3.4vw,40px);line-height:1.2;color:#1A2533;text-align:left;}
.approach__grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start;}
@media(min-width:900px){.approach__grid{grid-template-columns:1.1fr .9fr;gap:40px;}}
.approach__lead .lead{font-size:18px;line-height:1.6;max-width:60ch;color:#2b3441;}
.approach__lead .lead-secondary{margin-top:8px;color:#4b5563;}
.approach__card{background:#F6F7FB;border:1px solid #E6EAF2;border-radius:16px;padding:24px;box-shadow:0 1px 2px rgba(17,24,39,.05);}
.checklist{list-style:none;margin:0;padding:0;display:grid;gap:14px;}
.checklist li{display:grid;grid-template-columns:20px 1fr;gap:12px;align-items:start;}
.check{color:var(--fig-accent);margin-top:2px;}
.item-text{line-height:1.55;}
.term{font-weight:700;color:var(--ink);}
.desc{color:#2b3441;}
.approach__cta{margin-top:20px;}
.inline-cta{color:var(--fig-deep);text-decoration:none;border-bottom:1px solid currentColor;padding-bottom:2px;}
.inline-cta:hover{opacity:.8;}

/* shared palette used earlier */
:root{
  --fig-deep:#4A2C4C;
  --fig-accent:#8A5670;
  --ink:#111111;
}

.expertise{padding-block:clamp(48px,6vw,96px);}
.expertise__container{max-width:1100px;margin:0 auto;padding:0 24px;}
/* reuse same kicker + title as Approach for symmetry */
/* keep using .approach__title so the type matches exactly */
.approach__title{text-align:left;}

.expertise__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  align-items:stretch;
}
@media(min-width:900px){
  .expertise__grid{grid-template-columns:repeat(3,1fr);gap:32px;}
}

.expertise__card{
  background:#fff;
  border:1px solid #E6EAF2;
  border-radius:16px;
  padding:24px;
  box-shadow:0 1px 2px rgba(17,24,39,.05);
  display:flex;
  flex-direction:column;
  gap:12px;
}

.card__icon{opacity:.9;}
.card__title{font-size:20px;line-height:1.3;color:#1A2533;margin:4px 0 0;font-weight:800;}
.card__body{color:#2b3441;line-height:1.6;margin:0;}

.consult{padding-block:clamp(48px,6vw,96px);}
.consult__container{max-width:1100px;margin:0 auto;padding:0 24px;}
/* reuse shared kicker + .approach__title from other sections */
.approach__title{text-align:left;}
.consult__grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:start;}
@media(min-width:900px){.consult__grid{grid-template-columns:0.9fr 1.1fr;gap:40px;}}
.consult__intro{color:#2b3441;line-height:1.6;margin:0;}

.steps{list-style:none;margin:0;padding:0;display:grid;gap:16px;}
.steps li{display:grid;grid-template-columns:32px 1fr;gap:14px;align-items:start;}
.badge{
  width:32px;height:32px;border-radius:999px;
  display:grid;place-items:center;
  font-weight:700;font-size:14px;line-height:1;
  background:#1A2533;color:#fff;
}
.item-text{line-height:1.55;}
.term{font-weight:800;color:#111111;margin-right:8px;}
.desc{color:#2b3441;}
/* Optional tiny em dash between term and desc on wider screens */
@media(min-width:700px){
  .item-text .term::after{content:" — ";opacity:.5;}
}

/* remove em dashes in Approach */
.approach .item-text .term::after{ content: none !important; }

/* Our Approach: more space between the three paragraphs */
.approach .approach__lead p{ margin:0; }
.approach .approach__lead p + p{
  margin-top: clamp(28px, 3.8vw, 56px) !important;
}

.consult__fineprint{margin-top:24px;color:#6b7280;text-align:center;font-size:14px;}

.testimonials{padding-block:clamp(48px,6vw,96px);}
.testimonials__container{max-width:1100px;margin:0 auto;padding:0 24px;}
.approach__title{text-align:left;} /* keep section symmetry */

.testimonials__grid{
  display:grid;
  grid-template-columns:1fr;
  gap:32px;
}
@media(min-width:900px){
  .testimonials__grid{grid-template-columns:repeat(3,1fr);}
}

.tcard{
  background:#fff;
  border:1px solid #E6EAF2;
  border-radius:16px;
  padding:24px 24px 20px;
  box-shadow:0 1px 2px rgba(17,24,39,.05);
  display:flex;flex-direction:column;justify-content:space-between;min-height:260px;
}

/* Fix odd first-line spacing by resetting blockquote and using pseudo quotes */
.tcard__quote{
  margin:0;
  font-style:italic;
  line-height:1.6;
  color:#1f2937;
  position:relative;
  quotes:""" """;
  text-wrap:pretty;
}
.tcard__quote::before,
.tcard__quote::after{
  position:absolute;
  font-size:36px;
  line-height:1;
  color:#8A5670;
  opacity:.25;
}
.tcard__quote::before{content:open-quote;left:-2px;top:-6px;}
.tcard__quote::after{content:close-quote;right:-2px;bottom:-10px;}

/* Author */
.tcard__meta{margin-top:18px;color:#6b7280;}
.tcard__meta .name{display:block;font-weight:800;color:#111111;}
.tcard__meta .role{display:block;font-size:14px;}

/* CTA */
.cta-final{padding-block:clamp(48px,6vw,96px);background:#fff;}
.cta-final__container{max-width:1100px;margin:0 auto;padding:0 24px;}
.approach__title{text-align:left;} /* section symmetry */
.cta-final__grid{display:grid;grid-template-columns:1fr;gap:20px;align-items:center;}
@media(min-width:900px){.cta-final__grid{grid-template-columns:1.2fr .8fr;gap:32px;}}
.cta-final__copy{color:#2b3441;line-height:1.6;margin:0;}
.cta-final__actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-start;}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:999px;
  font-weight:800;text-decoration:none;
  border:1px solid transparent;transition:transform .06s ease,opacity .15s ease;
}
.btn:focus-visible{outline:2px solid var(--fig-accent);outline-offset:2px;}
.btn--primary{background:#1A2533;color:#fff;}
.btn--primary:hover{opacity:.9;transform:translateY(-1px);}
.btn--ghost{background:#fff;border-color:#E6EAF2;color:#1A2533;}
.btn--ghost:hover{background:#F6F7FB;}
.btn__icon{margin-left:2px;}
.cta-final__fineprint{margin-top:14px;color:#6b7280;font-size:14px;}

/* Footer */
.site-footer{border-top:1px solid #E6EAF2;background:#fff;}
.site-footer__container{
  max-width:1100px;margin:0 auto;padding:18px 24px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;
}
.footer__links{display:flex;gap:10px;flex-wrap:wrap;color:#374151;}
.footer__links a{color:#374151;text-decoration:none;border-bottom:1px solid transparent;}
.footer__links a:hover{border-bottom-color:#374151;}
.footer__brand{font-weight:900;letter-spacing:.04em;color:#111111;text-decoration:none;}
.footer__copyright{justify-self:end;color:#374151;white-space:nowrap;font-size:14px;}
@media(max-width:720px){
  .site-footer__container{grid-template-columns:1fr;gap:8px;text-align:center;}
  .footer__copyright{justify-self:center;white-space:normal;}
}

:root{
  --fig-deep:#4A2C4C; --fig-accent:#8A5670; --ink:#111111;
}

.site-header{
  position:fixed; inset:0 0 auto 0; z-index:50;
  background: rgba(255,255,255, var(--hdr-a, 0));        /* 0 at top */
  border-bottom: 1px solid rgba(230,234,242, var(--hdr-a, 0));
  backdrop-filter: saturate(var(--hdr-s, 1)) blur(var(--hdr-b, 0px)); /* no blur at top */
  -webkit-backdrop-filter: saturate(var(--hdr-s, 1)) blur(var(--hdr-b, 0px));
  transition: background .2s ease, border-color .2s ease, backdrop-filter .2s ease, -webkit-backdrop-filter .2s ease;
}

/* hard opaque fallback if class is used elsewhere */
.site-header.is-scrolled{
  --hdr-a: 1; --hdr-s: 1.4; --hdr-b: 8px;
  background:#fff; border-bottom-color:#E6EAF2;
}
.site-header__container{
  max-width:1100px; margin:0 auto; padding:10px 24px;
  display:flex; align-items:center; gap:16px;
}
.brand{font-weight:900;letter-spacing:.04em;text-decoration:none;color:#111;}
.nav-toggle{margin-left:auto;background:transparent;border:0;font-size:22px;line-height:1;display:none;}
.site-nav{margin-left:auto;display:flex;align-items:center;gap:16px;}
.site-nav ul{display:flex;gap:16px;list-style:none;margin:0;padding:0;}
.site-nav a{color:#1A2533;text-decoration:none;}
.header-cta{margin-left:8px}

/* Mobile nav */
@media(max-width:860px){
  .nav-toggle{display:block;}
  .site-nav{position:absolute;top:60px;right:24px;left:24px;flex-direction:column;gap:12px;
    background:#fff;border:1px solid #E6EAF2;border-radius:12px;padding:12px;display:none;}
  .site-nav.is-open{display:flex;}
  .site-nav ul{flex-direction:column;gap:10px;}
  .header-cta{align-self:stretch;text-align:center}
}

/* Buttons (reuse your existing .btn rules; add sizes) */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:999px;
  font-weight:800;text-decoration:none;border:1px solid transparent;transition:transform .06s ease,opacity .15s ease;}
.btn--primary{background:#1A2533;color:#fff;}
.btn--primary:hover{opacity:.9;transform:translateY(-1px);}
.btn--ghost{background:#fff;border-color:#E6EAF2;color:#1A2533;}
.btn--ghost:hover{background:#F6F7FB;}
.btn--lg{padding:14px 22px;font-size:16px}
.btn--sm{padding:8px 12px;font-size:14px}

/* ---- Reveal hero base ---- */
.hero{ --split:0%; position:relative; isolation:isolate; touch-action:pan-y; }

/* Focal point shared by BOTH images in the reveal stack */
#hero{ --focal-x: 78%; --focal-y: 26%; }           /* desktop default */
@media (max-width: 900px){
  #hero{ --focal-x: 62%; --focal-y: 20%; }         /* mobile tweak */
}
.hero::after{ /* keep existing scrim strength or use this */
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(90deg, rgba(255,255,255,.92) 0%, rgba(255,255,255,.78) 38%, rgba(255,255,255,.35) 60%, rgba(255,255,255,0) 78%);
}
.hero .hero__container{ position:relative; z-index:2; max-width:1100px; margin:0 auto; padding:clamp(96px,14vw,220px) 24px clamp(56px,10vw,120px); }
.hero__title{ margin:0 0 12px; font-size:clamp(32px,6vw,56px); line-height:1.05; color:#1A2533; max-width:16ch; text-wrap:balance; }
.hero__lead{ margin:0 0 18px; color:#2b3441; line-height:1.6; max-width:52ch; }

/* ---- Image stack ---- */
.hero__stack{ position:absolute; inset:0; z-index:0; overflow:hidden; }

/* Ensure both layers use the same fit + focal point */
.hero__img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover;
  object-position: var(--focal-x) var(--focal-y);
  will-change:clip-path;
  filter:grayscale(100%);
}
.hero__img--color{ filter:grayscale(0); }
.hero__img--bw{ clip-path: inset(0 0 0 var(--split)); } /* show right side only */

/* ---- Handle ---- */
.reveal-handle{ position:absolute; inset:0; pointer-events:none; z-index:3; }
.reveal-line{ position:absolute; top:0; bottom:0; left:var(--split); transform:translateX(-0.5px); width:1px; background:#111; opacity:.35; }
.reveal-knob{ position:absolute; left:var(--split); top:50%; transform:translate(-50%,-50%); width:16px; height:16px; border-radius:999px; background:#111; opacity:.6; box-shadow:0 0 0 3px rgba(255,255,255,.65); }

/* ---- Slider (keyboard control) ---- */
.hero__controls{ position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:4; }

/* base input: no visible bar */
.hero__slider{
  -webkit-appearance:none; appearance:none;
  width:min(420px,60vw);
  height:0;                       /* no bar height */
  padding:12px 0;                 /* keep hit area */
  background:transparent;
  border-radius:999px;
  outline:none;
  accent-color: initial;          /* ignore UA progress color */
}

/* focus ring still visible on the control */
.hero__slider:focus-visible{ outline:2px solid #8A5670; outline-offset:2px; }

/* WebKit: remove track and progress entirely */
.hero__slider::-webkit-slider-runnable-track{
  height:0;
  background:transparent;
  border:0;
}

/* WebKit thumb stays as the only visible part */
.hero__slider::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none;
  width:16px; height:16px; border-radius:50%;
  background:#111111; border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.12);
  margin-top:-8px; /* centers thumb in the padded hit area */
}

/* Firefox: remove track/progress visuals */
.hero__slider::-moz-range-track{ height:0; background:transparent; border:0; }
.hero__slider::-moz-range-progress{ height:0; background:transparent; border:0; }
.hero__slider::-moz-range-thumb{
  width:16px; height:16px; border-radius:50%;
  background:#111111; border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.12);
}

.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Hide the slider controls block */
.hero__controls{ display:none; }

/* Defensive: if the input stays in DOM later, hide its thumb in all engines */
.hero__slider{
  -webkit-appearance:none; appearance:none;
  width:0; height:0; padding:0; border:0; background:transparent; outline:none;
}
.hero__slider::-webkit-slider-runnable-track{ height:0; background:transparent; border:0; }
.hero__slider::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none;
  width:0; height:0; border:0; box-shadow:none; background:transparent; margin:0; opacity:0;
}
.hero__slider::-moz-range-track{ height:0; background:transparent; border:0; }
.hero__slider::-moz-range-progress{ height:0; background:transparent; border:0; }
.hero__slider::-moz-range-thumb{
  width:0; height:0; border:0; box-shadow:none; background:transparent; opacity:0;
}

/* Ensure text does not collide with subject on very wide screens */
@media (min-width:1100px){
  .hero__container{ padding-right:clamp(40px,10vw,220px); }
}

/* Centered, larger, simple icons */
.expertise__card .card__icon{
  display:block;
  width:56px; height:56px;          /* bigger */
  margin:0 auto 14px;               /* centered */
  color:var(--fig-accent);
}

/* Extra height at the bottom of the hero */
#hero{ --hero-extra: 10vh; } /* tweak value as needed */

.hero .hero__container{
  /* existing top/side paddings unchanged; add extra bottom */
  padding-bottom: calc(clamp(56px, 10vw, 120px) + var(--hero-extra));
}

/* Optionally reduce on small screens */
@media (max-width: 900px){
  #hero{ --hero-extra: 6vh; }
}

/* add ~20% viewport height to the bottom of the hero */
#hero{ --hero-extra-bottom: 20vh; }

.hero .hero__container{
  padding-bottom: calc(clamp(56px, 10vw, 120px) + var(--hero-extra-bottom));
}

/* optional: smaller boost on mobile */
@media (max-width:900px){
  #hero{ --hero-extra-bottom: 6vh; }
}

/* Avoid content behind fixed header when jumping to anchors */
:target{scroll-margin-top:80px;}

:root{
  --leather:#8B5E3C; /* leather brown */
}

/* Kickers and icons use leather */
.kicker{ color:var(--leather) !important; }
.expertise__card .card__icon{ color:var(--leather) !important; }

/* Cards unify */
.card,.expertise__card,.testimonial{ background:var(--card); border:1px solid var(--stroke); box-shadow:var(--shadow); }



/* Step bullets use brand */
.steps .num{ background:var(--brand); color:#fff; }

/* Borders/dividers */
hr, .divider{ border-color:var(--stroke); }

/* Focus style */
:focus-visible{ outline:2px solid var(--focus); outline-offset:2px; }

/* Paper with faint grain (no leather band) */
.section--paper{ position:relative; background:var(--paper); }
.section--paper::before{ content:none !important; display:none !important; }   /* remove separators */
.section--paper::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image: radial-gradient(var(--grain) .6px, transparent .6px);
  background-size:4px 4px; opacity:.25;
}

/* Ensure sections can host pseudo-elements */
.expertise, .testimonials{ position:relative; }

/* Expertise & Testimonials: simple warm flat background */
.expertise{ background:var(--warm) !important; }
.testimonials{ background:var(--warm) !important; }

/* Approach checklist ticks */
.approach .check{ color: var(--leather) !important; }

/* Defensive hide for removed navigation elements */
.site-nav, .nav-toggle, .header-cta { display:none !important; }

/* Defensive hide for removed hero secondary button */
.hero__actions .btn--ghost{ display:none !important; }

/* Consult section -> single centered column */
.consult .kicker,
.consult .approach__title{ text-align:left !important; }

.consult .consult__grid{
  display:grid;
  grid-template-columns:1fr;      /* no left/right split */
  justify-items:center;
  gap:24px;
  text-align:center;              /* center the intro */
}

.consult .consult__intro{ 
  max-width:56ch; 
  margin:0; 
  text-align:left !important;
  justify-self:start; /* moves the block to the left within the centered grid */
}

/* Keep the list readable: center the block, left-align its text */
.consult .steps{
  max-width:760px;
  margin:0 auto;
  text-align:left;
}

.consult .steps li{
  grid-template-columns:40px 1fr;
  justify-content:flex-start;
}

@media (max-width: 720px){
  /* stronger left-to-right scrim on mobile */
  .hero::after{
    background: linear-gradient(90deg,
      rgba(255,255,255,.98) 0%,
      rgba(255,255,255,.92) 45%,
      rgba(255,255,255,.70) 65%,
      rgba(255,255,255,0) 85%);
  }

  /* frosted backdrop behind hero copy */
  .hero .hero__container{ position:relative; }
  .hero .hero__container::before{
    content:"";
    position:absolute;
    left:16px; right:16px;
    top: clamp(72px,16vw,120px);
    bottom: 16px;
    background:
      linear-gradient(90deg,
        rgba(255,255,255,.55) 0%,
        rgba(255,255,255,.45) 40%,
        rgba(255,255,255,.18) 70%,
        rgba(255,255,255,0) 100%);
    border-radius: 16px;
    backdrop-filter: blur(6px) saturate(115%);
    -webkit-backdrop-filter: blur(6px) saturate(115%);
    z-index:1;
  }
  .hero__title, .hero__lead, .hero__actions{ position:relative; z-index:2; }

  /* mobile type tweaks */
  .hero__title{ font-size: clamp(28px, 8.2vw, 40px); line-height:1.1; }
  .hero__lead{ font-size:16px; line-height:1.5; max-width:40ch; }

  /* remove interactive handle on small screens */
  .reveal-handle{ display:none; }
}

/* Unified card look (matches Expertise/Testimonial cards) */
.card{
  background: var(--card, #fff);
  border: 1px solid var(--stroke, #E6E1D9);
  border-radius: 16px;
  box-shadow: var(--shadow, 0 10px 30px rgba(17,24,39,.06));
  padding: clamp(16px, 2.2vw, 24px);
}

/* If the old Approach panel had its own bg/border, neutralize it */
.approach .card{
  background: var(--card, #fff) !important;
  border-color: var(--stroke, #E6E1D9) !important;
  box-shadow: var(--shadow, 0 10px 30px rgba(17,24,39,.06)) !important;
}

/* Approach checklist: tighten space after the bold term */
.approach .item-text{ 
  display:flex; 
  gap:.35ch;            /* precise, small gap */
  flex-wrap:wrap; 
  align-items:baseline;
}
.approach .item-text .term{ margin:0 !important; }
.approach .item-text .term::after{ content:none !important; }  /* no em dash */

/* Approach checklist: keep term + desc on the same line */
.approach .item-text{ 
  display:inline !important;
  white-space:normal !important;
}
.approach .item-text .term,
.approach .item-text .desc{
  display:inline !important;
}
.approach .item-text .term{
  margin-right:.35ch !important;
}
.approach .item-text .term::after{
  content:none !important;
}

/* Approach checklist: exactly one space after the bold term */
.approach .item-text{ display:inline !important; word-spacing:normal !important; }
.approach .item-text .term,
.approach .item-text .desc{ display:inline !important; }

.approach .item-text .term{
  margin-right:0 !important; padding-right:0 !important;
}
.approach .item-text .desc{
  margin-left:0 !important; padding-left:0 !important;
}

/* inject a single space only */
.approach .item-text .term::after{ content:" "; }   /* regular space */

/* Logo sizing */
.brand, .footer__brand{ display:inline-flex; align-items:center; gap:8px; text-decoration:none; }
.brand img{ height:32px; width:auto; display:block; }
.footer__brand img{ height:33.6px; width:auto; display:block; }

@media (min-width:900px){
  .brand img{ height:36px; }
  .footer__brand img{ height:36px; }
}

/* Visually hidden text (if not already present) */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* Utility class for hiding elements (optional helper) */
.is-hidden{ display:none !important; }

/* Final CTA section background */
.cta-final{ background: var(--warm) !important; }

/* CTA row under the list */
.consult .consult__cta{
  margin-top:16px;
  display:flex; justify-content:center;
}

/* Subtle callout for the MIT stat */
.approach .note{
  margin: clamp(12px, 1.6vw, 18px) 0;
  padding: 12px 14px;
  border-left: 3px solid var(--leather, #8B5E3C);
  background: color-mix(in oklab, var(--leather, #8B5E3C) 8%, #fff);
  border-radius: 8px;
  color: var(--ink-2, #556475);
}

/* Checklist term/desc spacing: exactly one space, single line */
.approach .item-text{ display:inline !important; }
.approach .item-text .desc{ display:inline !important; }
.approach .item-text .term{ margin:0 !important; padding:0 !important; }
.approach .item-text .term::after{ content:" " !important; }

/* ===== Gaucho Approach v2 ===== */
.approach .wrap{ max-width:1200px; margin:0 auto; }

/* Two-column with a subtle vertical separator on wide screens */
.approach2{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(420px, 520px);
  gap:clamp(24px,4vw,64px);
  align-items:start;
  position:relative;
}
@media (min-width:1024px){
  .approach2::before{
    content:"";
    position:absolute; top:0; bottom:0; left:calc(100% - min(520px,42vw) - clamp(12px,2vw,24px));
    width:1px; background:var(--stroke,#E6E1D9);
    opacity:.6;
  }
}

/* LEFT column */
.approach2__left{ max-width:62ch; }
.approach2__left .lead{ margin:0 0 clamp(10px,1.2vw,14px); }
.approach2__left .lead-secondary{ margin-top: clamp(14px,1.8vw,20px); }

/* Quote callout */
.approach2__quote{
  position:relative;
  margin: clamp(12px,1.6vw,18px) 0 clamp(18px,2.2vw,24px);
  padding: clamp(16px,2vw,18px) clamp(18px,2.2vw,22px);
  background: color-mix(in oklab, var(--leather,#8B5E3C) 8%, #fff);
  border-left:3px solid var(--leather,#8B5E3C);
  border-radius:12px;
  color:var(--ink-2,#556475);
}
.approach2__quote .quote__mark{
  position:absolute; left:10px; top:-8px; font-size:40px; line-height:.8;
  color:color-mix(in oklab, var(--leather,#8B5E3C) 30%, #000 0%);
  opacity:.25;
}

/* RIGHT card */
.approach2__card{ position:sticky; top:clamp(12px,8vh,80px); }
.card__header{ padding-bottom:10px; border-bottom:1px solid var(--stroke,#E6E1D9); margin-bottom:6px; }
.card__title{ font-size:clamp(16px,1.2vw,18px); letter-spacing:.02em; color:var(--ink,#13202C); }

/* List */
.approach2__list{ display:flex; flex-direction:column; margin:0; padding:6px 0 0; }
.approach2__list li{
  display:grid; grid-template-columns:24px 1fr; align-items:start;
  gap:12px; padding:14px 0;
  border-top:1px solid var(--stroke,#E6E1D9);
}
.approach2__list li:first-child{ border-top:0; padding-top:10px; }
.approach2__list .li__icon{
  width:24px; height:24px; color:var(--leather,#8B5E3C);
  display:grid; place-items:center; margin-top:2px;
}
.approach2__list .li__icon svg{ width:20px; height:20px; display:block; }

/* Mobile stack */
@media (max-width:900px){
  .approach2{ grid-template-columns:1fr; }
  .approach2::before{ display:none; }
  .approach2__card{ position:static; }
}

/* Keep your existing .card style and section tokens. Do not remove other rules. */

.approach2__quote footer{
  margin-top:8px;
  font-size:0.95em;
  color:var(--ink-2,#556475);
  font-style:normal; /* keep only the report title italic via <em> */
}
.approach2__quote + .approach2__quote{
  margin-top: clamp(12px,1.6vw,16px);
}

.approach2__quote + .lead{ margin-top: clamp(14px, 2vw, 22px); }
.lead + .lead-secondary{ margin-top: clamp(10px, 1.4vw, 16px); }

/* ===== Our Expertise v2 ===== */
.expertise .wrap{ max-width:1200px; margin:0 auto; }

.expertise2{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap: clamp(18px, 3vw, 28px);
  align-items:stretch;
}

.expertise2__card{
  display:flex; flex-direction:column;
  padding: clamp(18px, 2.4vw, 28px);
  min-height: 100%;
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}

.card--rail{
  border-top: 4px solid var(--leather, #8B5E3C);
  border-radius: 14px;
}

.expertise2__title{
  font-size: clamp(18px, 1.5vw, 22px);
  line-height:1.25;
  margin: 4px 0 10px;
  color: var(--ink, #13202C);
}

.expertise2__card p{
  color: var(--ink-2, #556475);
  line-height:1.6;
}

/* Hover affordance */
.expertise2__card:hover{
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(17,24,39,.08);
  border-color: color-mix(in oklab, var(--leather,#8B5E3C), #000 10%);
}

/* Responsive */
@media (max-width: 1024px){
  .expertise2{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media (max-width: 680px){
  .expertise2{ grid-template-columns:1fr; }
}

/* Section title alignment stays consistent with site */
.section-title{ margin-bottom: clamp(10px,1.6vw,14px); }

/* Optional: if any old icon wrappers exist, hide them safely */
.expertise .card__icon, .expertise .badge { display:none !important; }

/* Center the kicker only in this section */
#approach .kicker{
  text-align:center;
  display:block;
  margin-left:auto;
  margin-right:auto;
  margin-bottom: clamp(8px, 1.2vw, 12px);
}

/* Extra breathing room before the "But it shouldn't be daunting…" bridge line */
.approach2__bridge{
  margin-top: clamp(14px, 2.2vw, 24px);
  line-height: 1.7;
}

/* Optional: tighten section spacing since we removed the H2 */
#approach .approach2{ margin-top: clamp(8px, 1.2vw, 12px); }

/* Centered kicker for Expertise */
#expertise .kicker{
  text-align:center;
  display:block;
  margin-left:auto;
  margin-right:auto;
  margin-bottom: clamp(10px, 1.6vw, 16px);
}

/* Optional: small nudge since the H2 was removed */
#expertise .expertise2{ margin-top: clamp(8px, 1.2vw, 12px); }

/* ===== Mobile comfort spacing for Approach + Expertise ===== */
@media (max-width: 700px){
  /* Section padding */
  #approach,
  #expertise{
    padding-block: clamp(44px, 10vw, 56px);
  }

  /* Horizontal breathing room inside the wrap */
  #approach .wrap,
  #expertise .wrap{
    padding-left: clamp(18px, 5vw, 22px);
    padding-right: clamp(18px, 5vw, 22px);
  }

  /* Grid gaps when stacked */
  #approach .approach2{
    grid-template-columns: 1fr;        /* already stacks, ensure single column */
    gap: clamp(18px, 5vw, 24px);
  }
  #expertise .expertise2{
    grid-template-columns: 1fr;        /* 1-up cards on mobile */
    gap: clamp(16px, 4.5vw, 22px);
    margin-top: clamp(10px, 2.5vw, 14px);
  }

  /* Card internal padding */
  #approach .approach2__card.card,
  #expertise .expertise2__card{
    padding: clamp(18px, 5vw, 24px);
    border-radius: 14px;
  }

  /* Quotes and bridge copy spacing so nothing hugs edges */
  #approach .approach2__quote{
    margin-left: 0;
    margin-right: 0;
    padding: clamp(14px, 4.5vw, 18px) clamp(16px, 5vw, 20px);
  }
  #approach .approach2__bridge{
    margin-top: clamp(16px, 5vw, 22px);
  }

  /* Card titles a touch tighter for small screens */
  #expertise .expertise2__title{
    font-size: clamp(17px, 4.2vw, 19px);
    margin-bottom: 8px;
  }
}

/* Slightly larger phone comfort (very narrow viewports) */
@media (max-width: 360px){
  #approach,
  #expertise{ padding-block: 56px; }
  #approach .wrap,
  #expertise .wrap{ padding-left: 22px; padding-right: 22px; }
}

/* ===== Consult – single column ===== */
#consult .kicker--center{ text-align:center; display:block; margin-inline:auto; }
#consult .section-title{ text-align:left; margin-top:4px; }

.consult-one{
  max-width: 880px;
  margin: clamp(14px,2vw,18px) auto 0;
}
.consult-one__intro{
  color: var(--ink-2,#556475);
  line-height: 1.7;
  margin-bottom: clamp(16px,2.6vw,22px);
}

/* Timeline card */
.tl{
  list-style:none; margin:0; padding: clamp(14px,2vw,18px);
  background: var(--paper,#fff);
  border: 1px solid var(--stroke,#E6E1D9);
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(17,24,39,.06);
  position: relative;
}
.tl::before{
  content:""; position:absolute; left: 26px; top: 16px; bottom: 16px; width:2px;
  background: var(--stroke,#E6E1D9); opacity:.6;
}
.tl__item{
  display:grid; grid-template-columns: 48px 1fr; column-gap: 14px;
  padding: 12px 0;
  border-top: 1px solid var(--stroke,#E6E1D9);
}
.tl__item:first-child{ border-top:0; padding-top:0; }

.tl__num{
  display:grid; place-items:center;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--leather,#8B5E3C); color:#fff; font-weight:700; font-size:.95rem;
  box-shadow: 0 1px 0 rgba(0,0,0,.08);
  margin-top: 2px;
}
.tl__title{
  display:block; font-weight:700; color:var(--ink,#13202C);
  font-size: 1.05rem; line-height:1.3; margin-bottom: 3px;
}
.tl__desc{
  display:block; color:var(--ink-2,#556475); line-height:1.6; font-size:1rem;
}

.consult-one__cta{ text-align:center; margin-top: clamp(18px,3vw,28px); }
.consult-one__cta .fineprint{ margin-top:8px; color:var(--ink-2,#556475); font-size:.95rem; }

/* Mobile comfort */
@media (max-width: 700px){
  .consult-one{ padding-inline: clamp(16px,5vw,22px); }
  .tl{ padding: clamp(12px,4.8vw,18px); }
  .tl::before{ left: 22px; }
  .tl__item{ grid-template-columns: 44px 1fr; }
  .tl__num{ width:28px; height:28px; }
}

/* ===== Consult header centering & feature ===== */
#consult .kicker{
  text-align: center;
  display: block;
  margin: 0 auto clamp(6px, 1.2vw, 10px);
}

#consult .section-title--center{
  text-align: center;
  margin: 0 auto clamp(12px, 2vw, 18px);
  font-size: clamp(28px, 3.5vw, 40px);      /* tasteful display size */
  line-height: 1.15;
  max-width: 24ch;
}


/* keep the intro snug under the featured header */
#consult .consult-one__intro{
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(10px, 1.6vw, 14px);
  max-width: 68ch;
}

/* mobile comfort */
@media (max-width: 700px){
  #consult .section-title--center{ font-size: clamp(26px, 7vw, 34px); }
  #consult .consult-one__intro{ padding-inline: clamp(16px, 5vw, 22px); }
}

/* Force-center the consult kicker */
#consult .kicker--center{
  text-align: center !important;
  display: block;
  width: 100%;
  margin: 0 auto clamp(6px, 1.2vw, 10px);
}

/* Sublead under the consult intro */
#consult .consult-one__sublead{
  text-align: center;
  margin: clamp(8px, 1.6vw, 12px) auto clamp(12px, 2vw, 18px);
  font-weight: 600;
  color: var(--ink, #13202C);
}

/* Remove the vertical rule through the numbers */
#consult .tl::before{
  content: none !important;
  display: none !important;
}

/* Hide legal links globally */
.site-footer .footer__legal{
  display: none !important;
}

/* Ensure footer content stacks and centers */
.site-footer .wrap{
  display: block;                  /* neutralize any previous flex/grid */
}

.site-footer .footer__stack{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  width: 100%;
  margin: 8px 0 12px;
}

.site-footer .footer__brand{
  display: flex;
  justify-content: center;
  align-items: center;
}

.site-footer .footer__brand a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.site-footer .footer__brand img{
  display: block;
  height: auto;
  max-width: 200px;  /* adjust if needed */
}

.site-footer .footer__copy{
  margin: 4px 0 0;
  font-size: 0.95rem;
  line-height: 1.5;
}

/* Center the footer container itself */
.site-footer,
.site-footer .wrap{
  text-align: center;
}

.site-footer .wrap{
  /* ensure the footer content is centered within the page width */
  max-width: var(--content-max, 1200px);
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}

/* Stack + center logo and copyright */
.site-footer .footer__stack{
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

/* Logo row */
.site-footer .footer__brand{
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.site-footer .footer__brand a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.site-footer .footer__brand img{
  display: block;
  height: auto;
  max-width: 200px;
}

/* Copyright line */
.site-footer .footer__copy{
  width: 100%;
  margin: 4px 0 12px;
  text-align: center;
}

/* Safety: neutralize any inherited grid/float that might misalign */
.site-footer .footer__stack > *{
  float: none !important;
}

/* ----- Footer: Simple and direct centering ----- */
.site-footer{
  text-align: center;
  width: 100%;
}

.site-footer .site-footer__container{
  text-align: center;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 20px;
  display: block;
}

.site-footer .footer__stack{
  text-align: center;
  width: 100%;
  display: block;
}

.site-footer .footer__brand{
  text-align: center;
  width: 100%;
  margin: 0 auto 10px;
  display: block;
}

.site-footer .footer__brand a{
  display: inline-block;
  text-align: center;
}

.site-footer .footer__brand img{
  display: block;
  margin: 0 auto;
  height: auto;
  max-width: 200px;
}

.site-footer .footer__copy{
  text-align: center;
  width: 100%;
  margin: 0;
  display: block;
}

/* ===== Kicker Headers: Large, Centered, and Consistent ===== */
.kicker{
  font-size: clamp(18px, 2.5vw, 24px) !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--leather, #8B5E3C) !important;
  margin: 0 auto clamp(8px, 1.2vw, 12px) !important;
  text-align: center !important;
  display: block !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
}

/* Ensure all kickers are centered regardless of section */
#approach .kicker,
#expertise .kicker,
#consult .kicker,
#testimonials .kicker,
#cta-final .kicker{
  text-align: center !important;
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
}