.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-10);
  border-radius: var(--radius-6);
  font-family: var(--font-body);
  font-weight: var(--font-weight-medium);
  font-size: var(--text-16);
  line-height: normal;
  text-decoration: none;
  cursor: pointer;
  border-width: var(--border-1);
  border-style: solid;
  border-color: transparent;
}

@media (min-width: 1025px) {
  .btn {
    align-self: flex-start;
  }
}

.btn--primary {
  background-color: var(--color-primary);
  color: var(--color-surface);
  padding: var(--btn-primary-pad-y) var(--btn-primary-pad-x);
}

.btn--primary:hover {
  background-color: var(--color-primary-hover);
}

.btn--primary:active {
  background-color: var(--color-primary-active);
}

.btn--secondary {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--color-border-strong);
  padding: var(--btn-secondary-pad-y) var(--btn-secondary-pad-x);
}

.btn--secondary:hover,
.btn--secondary:active {
  background-color: var(--color-secondary-surface);
  border-color: var(--color-border-hover);
  color: var(--color-ink-hover);
}

.btn--secondary .btn__icon--active {
  display: none;
}

.btn--secondary:hover .btn__icon--default,
.btn--secondary:active .btn__icon--default {
  display: none;
}

.btn--secondary:hover .btn__icon--active,
.btn--secondary:active .btn__icon--active {
  display: inline-flex;
}

.btn--nav {
  padding: var(--nav-cta-pad-y) var(--nav-cta-pad-x);
  font-size: var(--nav-cta-font-size);
}

.btn--hero {
  padding: var(--btn-hero-pad-y) var(--btn-hero-pad-x);
}

.btn__icon {
  width: var(--space-20);
  height: var(--space-20);
  display: inline-flex;
}

.card {
  background-color: var(--color-surface);
  border-width: var(--border-1);
  border-style: solid;
  border-color: var(--color-border-light);
  border-radius: var(--radius-20);
  box-shadow: var(--shadow-card);
  padding: var(--space-20);
}

.card--flat {
  box-shadow: none;
}

.nav {
  background-color: var(--color-navy);
  color: var(--color-surface);
  position: relative;
  z-index: var(--z-nav);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-32);
  padding-block: var(--nav-padding-y);
}

.nav__brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-12);
}

.nav__logo {
  width: var(--logo-width);
  height: var(--logo-height);
}

.nav__menu {
  display: var(--nav-menu-display);
  align-items: center;
  gap: var(--nav-menu-gap);
  font-family: var(--font-body);
  font-size: var(--text-16);
}

.nav__link {
  color: inherit;
  white-space: nowrap;
}

@media (min-width: 1025px) {
  .nav__link:hover {
    color: var(--color-link-active);
  }

  .footer__links a:hover {
    color: var(--color-link-active);
  }
}

.nav__toggle {
  display: var(--nav-toggle-display);
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  background: none;
  border-width: var(--border-1);
  border-style: solid;
  border-color: transparent;
  padding: var(--space-0);
  cursor: pointer;
}

.nav__icon {
  width: var(--space-20);
  height: var(--space-20);
}

.nav__icon--close {
  display: none;
}

.nav__cta--desktop {
  display: var(--nav-cta-desktop-display);
}

.nav__cta--mobile {
  display: var(--nav-cta-mobile-display);
}

@media (min-width: 1025px) {
  .nav__inner {
    justify-content: flex-start;
  }

  .nav__menu {
    margin-left: auto;
  }

  .nav__cta--desktop {
    margin-left: var(--space-32);
  }
}

@media (max-width: 640px) {
  .nav__inner {
    justify-content: flex-start;
    gap: var(--space-12);
  }

  .nav__cta--mobile {
    margin-left: auto;
    margin-right: var(--space-0);
  }

  .nav__toggle {
    margin-left: var(--space-12);
  }
}

@media (min-width: 641px) and (max-width: 1024px) {
  .nav__inner {
    justify-content: flex-start;
    gap: var(--space-12);
  }

  .nav__cta--desktop {
    margin-left: auto;
  }

  .nav__cta--mobile {
    margin-left: auto;
    margin-right: var(--space-0);
  }

  .nav__toggle {
    margin-left: var(--space-12);
  }
}

.nav__panel {
  display: var(--nav-panel-display);
  flex-direction: column;
  background-color: var(--color-navy);
  color: var(--color-surface);
  padding: var(--nav-panel-padding-y) var(--nav-panel-padding-x);
  position: absolute;
  left: var(--space-0);
  top: var(--size-full);
  width: var(--size-full);
  z-index: var(--z-nav-panel);
}

.nav--open .nav__panel {
  display: var(--nav-panel-display-open);
}

.nav--open .nav__icon--open {
  display: none;
}

.nav--open .nav__icon--close {
  display: inline-flex;
}

.nav__panel-link {
  padding-block: var(--nav-panel-item-padding-y);
  border-bottom-width: var(--border-1);
  border-bottom-style: solid;
  border-bottom-color: var(--color-nav-divider);
  font-family: var(--font-body);
  font-size: var(--text-16);
}

.nav__panel-link:first-child {
  border-top-width: var(--border-1);
  border-top-style: solid;
  border-top-color: var(--color-nav-divider);
}

.nav__panel-link.is-active {
  color: var(--color-link-active);
}

.footer {
  background-color: var(--color-navy);
  color: var(--color-surface);
  padding-block: var(--footer-padding-top)
    calc(var(--footer-padding-bottom) + env(safe-area-inset-bottom, 0px));
}

.footer__inner {
  display: flex;
  flex-direction: var(--footer-direction);
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--footer-gap);
}

.footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-12);
}

.footer__links {
  display: grid;
  gap: var(--space-16);
  font-family: var(--font-body);
  font-size: var(--footer-link-size);
}

.footer__divider {
  width: var(--size-full);
  height: 1px;
  margin-top: var(--space-64);
  background-color: #293151;
}

.footer__bar {
  text-align: center;
  font-size: var(--text-14);
  line-height: var(--lh-120);
  margin-top: var(--space-24);
  color: #7f7f97;
}

@media (max-width: 640px) {
  .footer__divider {
    margin-top: var(--space-32);
  }

  .footer__links {
    line-height: normal;
  }
}

.divider {
  width: var(--size-full);
}

.photo-pair {
  position: relative;
  width: max(calc(var(--photo-lg-x) + var(--photo-lg-w)), calc(var(--photo-sm-x) + var(--photo-sm-w)));
  height: max(calc(var(--photo-lg-y) + var(--photo-lg-h)), calc(var(--photo-sm-y) + var(--photo-sm-h)));
}

.photo-pair__large,
.photo-pair__small {
  position: absolute;
  border-radius: var(--radius-20);
  overflow: hidden;
}

.photo-pair__large {
  width: var(--photo-lg-w);
  height: var(--photo-lg-h);
  left: var(--photo-lg-x);
  top: var(--photo-lg-y);
}

.photo-pair__small {
  width: var(--photo-sm-w);
  height: var(--photo-sm-h);
  left: var(--photo-sm-x);
  top: var(--photo-sm-y);
  border-width: var(--border-10);
  border-style: solid;
  border-color: var(--color-surface);
}

.photo-pair--left {
  --photo-lg-w: var(--photo-left-lg-w);
  --photo-lg-h: var(--photo-left-lg-h);
  --photo-lg-x: var(--photo-left-lg-x);
  --photo-lg-y: var(--photo-left-lg-y);
  --photo-sm-w: var(--photo-left-sm-w);
  --photo-sm-h: var(--photo-left-sm-h);
  --photo-sm-x: var(--photo-left-sm-x);
  --photo-sm-y: var(--photo-left-sm-y);
}

.photo-pair--right {
  --photo-lg-w: var(--photo-right-lg-w);
  --photo-lg-h: var(--photo-right-lg-h);
  --photo-lg-x: var(--photo-right-lg-x);
  --photo-lg-y: var(--photo-right-lg-y);
  --photo-sm-w: var(--photo-right-sm-w);
  --photo-sm-h: var(--photo-right-sm-h);
  --photo-sm-x: var(--photo-right-sm-x);
  --photo-sm-y: var(--photo-right-sm-y);
}


.service-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
}

.service-card__image {
  border-radius: var(--radius-30);
  overflow: hidden;
}

.list {
  padding-left: var(--list-indent, var(--space-24));
  margin: var(--space-0);
  list-style: disc;
  list-style-position: outside;
}

.list--wide {
  --list-indent: var(--space-27);
}

.pill {
  background-color: var(--color-surface-tint);
  border-radius: var(--radius-6);
  padding: var(--space-10);
  display: flex;
  align-items: center;
  gap: var(--space-8);
}

.pill__icon {
  width: var(--space-16);
  height: var(--space-16);
}

.testimonial-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-16);
}

.home-testimonials__card {
  gap: var(--space-12);
}

.home-testimonials__card > .stack {
  gap: 0;
}

.home-testimonials__card > .stack > .stack {
  gap: 0;
}

.home-testimonials__card > .stack > .stack > p + p {
  margin-top: 6px;
}

.testimonial-carousel {
  position: relative;
  overflow: visible;
  width: 100%;
}

.testimonial-card {
  transition: transform 320ms ease, opacity 320ms ease;
  will-change: transform, opacity;
}

.testimonial-card[data-state="active"] {
  opacity: 1;
  transform: translateX(0);
  position: relative;
  pointer-events: auto;
}

.testimonial-card[data-state="prev"] {
  opacity: 0;
  transform: translateX(-15%);
  position: absolute;
  inset: var(--space-0);
  pointer-events: none;
}

.testimonial-card[data-state="next"] {
  opacity: 0;
  transform: translateX(15%);
  position: absolute;
  inset: var(--space-0);
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .testimonial-card {
    transition: none;
  }
}

.rating {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.rating__icon {
  width: var(--space-24);
  height: var(--space-24);
}

.contact-card {
  display: flex;
  align-items: center;
  gap: var(--space-12);
  width: var(--contact-card-width);
  background-color: var(--color-surface-alt);
  border-width: var(--border-1);
  border-style: solid;
  border-color: var(--color-border-light);
  border-radius: var(--radius-12);
  padding: var(--space-20);
  box-shadow: none;
}

.contact-card__icon {
  width: 66px;
  height: 66px;
  border-radius: 50%;
  flex-shrink: 0;
}

.contact-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-8);
  text-align: left;
  min-width: 0;
}

.contact-card .type-title-sm {
  font-size: var(--text-20);
  line-height: normal;
  letter-spacing: 0.6px;
  font-weight: var(--font-weight-semibold);
}

.contact-card .type-body-sm,
.contact-card .type-body {
  line-height: 1.2;
}

.contact-card .type-body {
  font-size: var(--text-16);
}

.contact-card .type-body-sm,
.contact-card .type-body {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 360px) {
  .contact-card .type-body-sm,
  .contact-card .type-body {
    font-size: var(--text-14);
  }
}

.carousel-controls {
  display: flex;
  align-items: center;
  gap: var(--space-9);
  justify-content: center;
  width: 100%;
}

.carousel-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-12);
  border-radius: var(--radius-7);
  border-width: var(--border-0-75);
  border-style: solid;
  border-color: var(--color-primary);
  background-color: var(--color-surface);
}

.carousel-button:hover,
.carousel-button:active {
  background-color: var(--color-primary);
}

.carousel-button__icon {
  width: var(--space-18);
  height: var(--space-18);
}

.carousel-button__icon--active {
  display: none;
}

.carousel-button:hover .carousel-button__icon--default,
.carousel-button:active .carousel-button__icon--default {
  display: none;
}

.carousel-button:hover .carousel-button__icon--active,
.carousel-button:active .carousel-button__icon--active {
  display: inline-flex;
}
