/* YTTWEAR public redesign overrides.
   Keep this file small and last-loaded. It contains page-level polish that
   should not be mixed into the older factory editorial theme. */

:root {
  --ytt-ink-final: #20262a;
  --ytt-paper-final: #fffdf8;
  --ytt-action-final: #315f5a;
  --ytt-line-final: rgba(31, 38, 45, 0.16);
}

.marketing-nav a:hover,
.marketing-nav a.active,
.marketing-track:hover {
  background: rgba(49, 95, 90, 0.10) !important;
  color: var(--ytt-ink-final) !important;
}

.marketing-quote,
.btn-primary,
.hero-actions .btn-primary,
.catalog-main .btn-primary,
.filter-actions .btn-primary,
.search-btn,
.submit-btn {
  background: var(--ytt-ink-final) !important;
  border-color: var(--ytt-ink-final) !important;
  color: var(--ytt-paper-final) !important;
  box-shadow: none !important;
}

.marketing-quote:hover,
.btn-primary:hover,
.hero-actions .btn-primary:hover,
.catalog-main .btn-primary:hover,
.filter-actions .btn-primary:hover,
.search-btn:hover,
.submit-btn:hover {
  background: var(--ytt-action-final) !important;
  border-color: var(--ytt-action-final) !important;
}

.btn-secondary,
.hero-actions .btn-secondary,
.catalog-main .btn-secondary,
.filter-reset {
  color: var(--ytt-ink-final) !important;
  border-color: rgba(31, 38, 45, 0.22) !important;
  background: transparent !important;
}

.catalog-quick-actions .btn,
.guide-end-actions .btn,
.product-chip,
.filter-chip,
.page-btn,
.trust-item,
.product-card,
.filter-panel,
.empty-state,
.loading-state {
  border-radius: 4px !important;
  box-shadow: none !important;
}

/* Products: catalog pages should start with filters and products, not a large hero image. */
.catalog-main .catalog-shell {
  width: min(1480px, calc(100% - 56px)) !important;
}

.catalog-main .catalog-intro {
  display: grid !important;
  grid-template-columns: minmax(0, 0.88fr) minmax(420px, 0.62fr) !important;
  gap: clamp(24px, 3.4vw, 44px) !important;
  align-items: end !important;
  padding: clamp(28px, 4vw, 50px) 0 24px !important;
  overflow: visible !important;
}

.catalog-main .catalog-copy {
  min-width: 0 !important;
  max-width: 100% !important;
  position: relative !important;
  z-index: 2 !important;
}

.catalog-main .catalog-copy h1 {
  width: min(18ch, 100%) !important;
  max-width: min(18ch, 100%) !important;
  white-space: normal !important;
  text-wrap: balance !important;
  overflow-wrap: normal !important;
  font-size: clamp(36px, 4vw, 58px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.catalog-main .catalog-copy p:not(.catalog-quick-actions) {
  max-width: 52ch !important;
}

.catalog-main .catalog-decision-strip {
  display: grid !important;
  grid-template-columns: 1fr !important;
  border-top: 1px solid var(--ytt-line-final) !important;
  border-bottom: 1px solid var(--ytt-line-final) !important;
  background: transparent !important;
}

.catalog-main .catalog-decision-strip div {
  min-height: 68px !important;
  display: grid !important;
  grid-template-columns: 40px minmax(0, 0.72fr) minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: baseline !important;
  padding: 14px 0 !important;
}

.catalog-main .catalog-decision-strip div + div {
  border-top: 1px solid rgba(31, 38, 45, 0.10) !important;
}

.catalog-main .filter-panel {
  margin-top: 18px !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* Contact: make the first viewport operational and image-led. */
.contact-page .hero-section {
  padding: clamp(54px, 7vw, 92px) 0 clamp(42px, 6vw, 76px) !important;
  text-align: left !important;
}

.contact-page .hero-wrap {
  max-width: 1220px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 0.82fr) minmax(420px, 0.78fr) !important;
  grid-template-areas:
    "copy media"
    "prep prep" !important;
  gap: clamp(26px, 4vw, 58px) !important;
  align-items: center !important;
}

.contact-page .contact-hero-copy {
  grid-area: copy !important;
  min-width: 0 !important;
}

.contact-page .hero-title {
  max-width: 11ch !important;
  margin-top: 24px !important;
  font-size: clamp(54px, 6.2vw, 88px) !important;
  line-height: 0.94 !important;
  letter-spacing: 0 !important;
  text-align: left !important;
}

.contact-page .hero-copy,
.contact-page .hero-note {
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: left !important;
}

.contact-page .hero-actions {
  justify-content: flex-start !important;
}

.contact-page .contact-hero-media {
  grid-area: media !important;
  position: relative !important;
  margin: 0 !important;
  overflow: hidden !important;
  border: 1px solid var(--ytt-line-final) !important;
  background: #ded8cc !important;
  box-shadow: 0 28px 70px rgba(31, 38, 45, 0.12) !important;
}

.contact-page .contact-hero-media img {
  width: 100% !important;
  height: clamp(420px, 42vw, 560px) !important;
  object-fit: cover !important;
  filter: saturate(0.9) contrast(1.04) !important;
}

.contact-page .contact-hero-media::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background: linear-gradient(180deg, rgba(31, 38, 45, 0) 48%, rgba(31, 38, 45, 0.70) 100%) !important;
}

.contact-page .contact-hero-media figcaption {
  position: absolute !important;
  right: 18px !important;
  bottom: 18px !important;
  left: 18px !important;
  z-index: 1 !important;
  max-width: 36ch !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(255, 254, 250, 0.42) !important;
  color: var(--ytt-paper-final) !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
  text-transform: uppercase !important;
}

.contact-page .quote-prep-strip {
  grid-area: prep !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  box-shadow: none !important;
}

.contact-page .quote-prep-item {
  min-height: 104px !important;
}

/* Guides: remove centered SEO-block feel from the topic module. */
.guide-hero {
  padding: clamp(34px, 5vw, 56px) 0 18px !important;
}

.guide-hero-shell {
  display: grid !important;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.58fr) !important;
  gap: clamp(24px, 4vw, 48px) !important;
  align-items: end !important;
}

.guide-hero h1 {
  max-width: min(18ch, 100%) !important;
  margin-top: 14px !important;
  font-size: clamp(36px, 4.4vw, 58px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.guide-hero-copy {
  max-width: 64ch !important;
  font-size: 16px !important;
}

.guide-hero-actions {
  margin-top: 22px !important;
}

.guide-paths {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-top: 1px solid var(--ytt-line-final) !important;
  border-bottom: 1px solid var(--ytt-line-final) !important;
  background: transparent !important;
  box-shadow: none !important;
}

.guide-topic-link {
  min-height: 50px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 0 !important;
  border-bottom: 1px solid rgba(31, 38, 45, 0.10) !important;
  color: var(--ytt-ink-final) !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.guide-topic-link:last-child {
  border-bottom: 0 !important;
}

.guide-topic-link::after {
  content: "View" !important;
  color: var(--ytt-action-final) !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}

.guide-categories {
  margin-top: 0 !important;
  padding-top: 8px !important;
}

.guide-categories .category-heading {
  max-width: 1220px !important;
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: center !important;
  margin: 0 auto 18px !important;
  text-align: left !important;
}

.guide-categories .category-heading .section-kicker {
  grid-column: auto !important;
  justify-self: start !important;
}

.guide-categories .category-heading h2 {
  grid-column: auto !important;
  max-width: none !important;
  margin: 0 !important;
  color: var(--ytt-ink-final) !important;
  font-size: 18px !important;
  line-height: 1.2 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.guide-categories .category-heading-mark {
  display: none !important;
}

.guide-categories .category-heading p {
  grid-column: 1 / -1 !important;
  max-width: 58ch !important;
  margin: 0 !important;
  color: var(--ytt-copy) !important;
  font-size: 14px !important;
  line-height: 1.62 !important;
  text-align: left !important;
}

.guide-categories .category-showcase {
  max-width: 1220px !important;
  margin: 0 auto !important;
}

.guide-categories .category-card {
  border-radius: 4px !important;
}

.guide-categories .category-img {
  height: 132px !important;
}

@media (max-width: 1180px) {
  .catalog-main .catalog-intro {
    grid-template-columns: 1fr !important;
  }

  .catalog-main .catalog-copy h1 {
    width: min(18ch, 100%) !important;
    max-width: min(18ch, 100%) !important;
  }
}

@media (max-width: 900px) {
  .contact-page .hero-wrap,
  .guide-hero-shell,
  .guide-categories .category-heading {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "copy"
      "media"
      "prep" !important;
  }

  .contact-page .hero-title {
    font-size: clamp(44px, 12vw, 64px) !important;
  }

  .contact-page .contact-hero-media img {
    height: auto !important;
    aspect-ratio: 4 / 3 !important;
  }

  .guide-categories .category-heading .section-kicker,
  .guide-categories .category-heading h2,
  .guide-categories .category-heading p {
    grid-column: auto !important;
  }
}

@media (max-width: 760px) {
  .catalog-main .catalog-shell {
    width: calc(100% - 28px) !important;
  }

  .catalog-main .catalog-decision-strip div {
    grid-template-columns: 1fr !important;
  }

  .catalog-main .catalog-copy h1 {
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(34px, 11vw, 46px) !important;
  }
}
