@import url("../assets/css/shared.css");

* {
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

header {
  padding: 32px 36px 0;
}

.stylists-showcase {
  position: relative;
  min-height: 100vh;
  min-height: 100dvh;
  padding: 104px 32px 40px;
  background:
    linear-gradient(135deg, rgba(92, 80, 68, 0.46), rgba(92, 80, 68, 0.18)),
    url("/images/salon/salon-background.jpg") center / cover no-repeat;
}

.stylists-layout {
  position: relative;
  z-index: 1;
  width: min(1180px, 100%);
  margin: 0 auto;
  display: grid;
  gap: 28px;
}

.stylists-hero {
  max-width: 760px;
  color: #fffaf4;
}

.eyebrow {
  margin: 0 0 14px;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(255, 244, 231, 0.8);
}

.stylists-hero h1 {
  margin: 0;
  font-size: clamp(2.5rem, 5vw, 5rem);
  line-height: 0.95;
  font-weight: 500;
  text-wrap: balance;
}

.hero-copy {
  margin: 18px 0 0;
  max-width: 58ch;
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.65;
  color: rgba(255, 244, 231, 0.92);
}

.stylists-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.stylists-jump-nav {
  display: none;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.jump-link {
  display: grid;
  justify-items: center;
  gap: 10px;
  text-decoration: none;
  color: #fffaf4;
}

.jump-photo {
  width: 78px;
  height: 78px;
  border-radius: 999px;
  object-fit: cover;
  border: 2px solid rgba(255, 255, 255, 0.22);
  box-shadow: 0 10px 22px rgba(34, 27, 22, 0.14);
  background: #d9d3ca;
}

.jump-link span {
  font-size: 0.92rem;
}

.jump-link:hover .jump-photo,
.jump-link:focus-visible .jump-photo {
  border-color: #fffaf4;
  transform: translateY(-2px);
}

.jump-link:focus-visible {
  outline: none;
}

.jump-link:focus-visible span {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.stylist-card {
  display: grid;
  grid-template-columns: minmax(180px, 220px) minmax(0, 1fr);
  align-items: stretch;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(105, 92, 81, 0.44);
  box-shadow: 0 24px 48px rgba(34, 27, 22, 0.16);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

.stylist-photo {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  object-position: center;
  background: #d9d3ca;
}

.stylist-copy {
  display: grid;
  align-content: start;
  gap: 14px;
  padding: 24px;
  color: #fffaf4;
}

.stylist-role {
  margin: 0;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(255, 244, 231, 0.74);
}

.stylist-copy h2 {
  margin: 0;
  font-size: clamp(1.6rem, 2vw, 2.1rem);
  line-height: 1.02;
  font-weight: 500;
}

.stylist-copy p:last-of-type {
  margin: 0;
  font-size: 1rem;
  line-height: 1.65;
  color: rgba(255, 244, 231, 0.9);
}

.stylist-links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 4px;
}

.stylist-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 15px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 250, 245, 0.14);
  color: #fffaf4;
  text-decoration: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.stylist-links a:hover,
.stylist-links a:focus-visible {
  background: #fffaf4;
  border-color: #fffaf4;
  color: #221c18;
}

.stylist-links a:focus-visible {
  outline: 2px solid #fffaf4;
  outline-offset: 2px;
}

@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  .stylist-card {
    background: rgba(100, 86, 74, 0.86);
  }
}

@media (max-width: 1024px) {
  .stylists-showcase {
    padding: 96px 24px 32px;
    background:
      linear-gradient(135deg, rgba(92, 80, 68, 0.5), rgba(92, 80, 68, 0.22)),
      url("/images/salon/salon-background-mobile.jpg") center / cover no-repeat;
  }

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

  .stylists-jump-nav {
    display: grid;
  }
}

@media (max-width: 720px) {
  header {
    padding: 24px 20px 0;
  }

  .stylists-showcase {
    padding: 84px 16px 20px;
  }

  .stylist-card {
    grid-template-columns: minmax(120px, 160px) minmax(0, 1fr);
  }

  .stylist-photo {
    min-height: 100%;
  }

  .stylist-copy {
    padding: 20px 18px;
  }
}

@media (max-width: 480px) {
  .stylists-jump-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .stylist-card {
    grid-template-columns: minmax(104px, 132px) minmax(0, 1fr);
  }

  .hero-copy,
  .stylist-copy p:last-of-type {
    font-size: 0.96rem;
  }

  .stylist-links {
    flex-direction: column;
  }

  .stylist-links a {
    width: 100%;
  }
}
