/* Landing: Architekt Białystok — hero, typografia, sekcje */

/* Architekt wnętrz (bez hero): pierwszy nagłówek — poniżej paska logo + nav */
.page-arch-wnetrz main > .content-heading-center:first-child {
  padding-top: clamp(100px, 14vh, 170px);
  padding-bottom: 16px;
}

.page-michal-arch .hero-section .hero-video,
.page-michal-arch .hero-section .hero-video-mobile {
  display: none !important;
}

.page-michal-arch .hero-section > .hero-arch-photo {
  display: block !important;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
  filter: brightness(0.3);
  border-radius: 0;
}

.page-michal-arch.page-michal-bialystok .hero-section > .hero-arch-photo,
.page-michal-arch.page-michal-warszaw .hero-section > .hero-arch-photo {
  filter: brightness(0.44);
}

/* Dodatkowe przyciemnienie jak na makiecie (index ~0.3 + warstwa gradientu) */
.page-michal-arch .hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    rgba(0, 0, 0, 0.45) 42%,
    rgba(0, 0, 0, 0.78) 100%
  );
}

.page-michal-arch.page-michal-bialystok .hero-section::before,
.page-michal-arch.page-michal-warszaw .hero-section::before {
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.12) 0%,
    rgba(0, 0, 0, 0.32) 42%,
    rgba(0, 0, 0, 0.62) 100%
  );
}

/* h1 + subtitle stack at bottom; image stays position:absolute */
.page-michal-arch .hero-section {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 0.3rem;
  padding-left: 7%;
  padding-right: 7%;
  padding-bottom: 11%;
  box-sizing: border-box;
}

/*
 * Reset styleglowna .hero-title { top:80%; … } — przy position:relative zostaje
 * top:% z globalnego .hero-title i wypycha h1 poza kadr; .hero-subtitle zostaje w flex.
 */
.page-michal-arch .hero-title {
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  bottom: auto;
  transform: none;
  z-index: 5;
  text-align: left;
  white-space: normal;
  width: 100%;
  max-width: min(1100px, 86vw);
  margin: 0;
  box-sizing: border-box;
  font-family: "Archivo", sans-serif;
  text-transform: uppercase;
  color: #fff;
  font-size: clamp(1.95rem, 5.25vw, 3.85rem);
  line-height: 1.2;
  padding: 0 1rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  display: block;
}

/* Wariant jak na stronie Warszawa: duży pierwszy wiersz (nazwa), mniejszy drugi — zwykła pisownia */
.page-michal-arch .hero-title.hero-title--mixed-case {
  text-transform: none;
}

.page-michal-arch .hero-subtitle {
  position: relative;
  z-index: 5;
  margin: 0;
  padding: 0 1rem;
  max-width: min(1100px, 86vw);
  width: 100%;
  box-sizing: border-box;
  font-family: "Archivo", sans-serif;
  color: #fff;
  text-align: left;
}

.page-michal-arch .hero-subtitle .hero-title-kicker {
  font-size: clamp(1.0625rem, 2.65vw, 1.65rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.05;
  margin-top: 0.5rem;
  margin-bottom: 0;
  padding: 0;
  display: block;
}

.page-michal-arch .hero-title .hero-title-name {
  font-size: inherit;
  font-weight: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  margin: 0;
  padding: 0;
}

/* Flex: bez tego długie linie nie kurczą się — wychodzą poza max-width i obcina overflow:hero */
.page-michal-arch .hero-subtitle .hero-title-kicker,
.page-michal-arch .hero-title .hero-title-name {
  min-width: 0;
  max-width: 100%;
  width: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
}

/*
 * 1025px–1440px: dopasowanie typografii — długie nagłówki mieszczą się w hero (overflow:hidden).
 */
@media (max-width: 1440px) and (min-width: 1025px) {
  .page-michal-arch .hero-title,
  .page-michal-arch .hero-subtitle {
    max-width: min(1100px, 86vw);
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.875rem, 2.75vw, 3.125rem);
    letter-spacing: 0.1em;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(3.25rem, 4.65vw + 1.125rem, 6.125rem);
    letter-spacing: 0.05em;
    line-height: 1.08;
  }

  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(1.9rem, 3.95vw + 0.5rem, 3.95rem);
    letter-spacing: 0.055em;
    line-height: 1.1;
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.5rem, 2.5vw, 2.65rem);
    letter-spacing: 0.08em;
  }
}

@media (max-width: 1024px) {
  /*
   * Wyśrodkowanie bloku tekstu: stretch + max-width — treść nie wychodzi poza .hero-section.
   */
  .page-michal-arch .hero-section {
    align-items: stretch;
    padding-bottom: 10%;
    padding-left: max(12px, env(safe-area-inset-left, 0px));
    padding-right: max(12px, env(safe-area-inset-right, 0px));
  }

  .page-michal-arch .hero-title,
  .page-michal-arch .hero-subtitle {
    text-align: center;
    width: calc(100vw - 32px);
    max-width: calc(100vw - 32px);
    margin-left: auto;
    margin-right: auto;
    box-sizing: border-box;
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.375rem, 3.25vw, 2.25rem);
    letter-spacing: 0.09em;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(1.625rem, 4.85vw, 3.5rem);
    letter-spacing: 0.045em;
    line-height: 1.12;
  }
}

/* Hero — вужчі екрани, пропорційні розміри (900 / 768 / 600 / 480) */
@media (max-width: 900px) {
  .page-michal-arch .hero-section {
    padding-bottom: 10%;
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.375rem, 5vw, 2rem);
    letter-spacing: 0.1em;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(1.375rem, 11vw, 3.625rem);
  }
}

@media (max-width: 768px) {
  .page-michal-arch .hero-section {
    padding-bottom: 11%;
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.125rem, 3.4vw, 1.75rem);
    letter-spacing: 0.06em;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(1.25rem, 6.2vw, 2.75rem);
    letter-spacing: 0.04em;
  }
}

@media (max-width: 600px) {
  .page-michal-arch .hero-section {
    padding-bottom: 10%;
  }

  .page-michal-arch .hero-title,
  .page-michal-arch .hero-subtitle {
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(1.25rem, 4vw, 1.4375rem);
    line-height: 1.2;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(1.75rem, 9.5vw, 2.25rem);
    line-height: 1.15;
  }
}

@media (max-width: 480px) {
  .page-michal-arch .hero-section {
    padding-bottom: 9%;
  }

  .page-michal-arch .hero-title,
  .page-michal-arch .hero-subtitle {
    width: calc(100vw - 20px);
    max-width: calc(100vw - 20px);
    padding-left: max(10px, env(safe-area-inset-left, 0px));
    padding-right: max(10px, env(safe-area-inset-right, 0px));
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.875rem, 4.2vw, 1.25rem);
    letter-spacing: 0.05em;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(0.9375rem, 5.1vw, 1.625rem);
    letter-spacing: 0.035em;
    line-height: 1.18;
  }
}

/* 320–375px: długi tracking musi zmieścić się w ~280px treści */
@media (max-width: 400px) {
  .page-michal-arch .hero-title,
  .page-michal-arch .hero-subtitle {
    width: calc(100vw - 12px);
    max-width: calc(100vw - 12px);
    padding-left: max(6px, env(safe-area-inset-left, 0px));
    padding-right: max(6px, env(safe-area-inset-right, 0px));
  }

  .page-michal-arch .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.6875rem, 3.25vw, 1rem);
    letter-spacing: 0.035em;
    line-height: 1.2;
  }

  .page-michal-arch .hero-title {
    font-size: clamp(0.75rem, 3.85vw, 1.125rem);
    letter-spacing: 0.025em;
    line-height: 1.2;
    word-break: break-word;
  }
}

/* Hero mixed-case: długie nagłówki — dopasowanie do szerokości (bez obcinania przez overflow na .hero-section) */
@media (max-width: 1024px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(1.125rem, min(5vw, 5.2vh), 2.75rem);
    letter-spacing: 0.04em;
    line-height: 1.12;
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(1rem, min(3.4vw, 3.6vh), 2rem);
    letter-spacing: 0.07em;
  }
}

@media (max-width: 900px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(1rem, min(5.5vw, 6vh), 2.5rem);
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.9375rem, min(3.8vw, 4vh), 1.875rem);
  }
}

@media (max-width: 768px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(0.9375rem, min(5.8vw, 6.5vh), 2.25rem);
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.875rem, min(3.6vw, 4vh), 1.75rem);
  }
}

@media (max-width: 600px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(0.875rem, min(6.5vw, 7vh), 2rem);
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.8125rem, min(4vw, 4.5vh), 1.5rem);
  }
}

@media (max-width: 480px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(0.75rem, min(5.8vw, 6.5vh), 1.625rem);
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.6875rem, min(4.2vw, 4.8vh), 1.25rem);
  }
}

@media (max-width: 400px) {
  .page-michal-arch .hero-title.hero-title--mixed-case {
    font-size: clamp(0.6875rem, min(4.8vw, 5.5vh), 1.25rem);
  }

  .page-michal-arch .hero-title.hero-title--mixed-case + .hero-subtitle .hero-title-kicker {
    font-size: clamp(0.625rem, min(3.8vw, 4.2vh), 1.0625rem);
  }
}

/*
 * Warszawa: drugi wiersz hero — na 320–768px mniejsza czcionka i ciaśniejszy tracking niż ogólny mixed-case.
 */
@media (max-width: 768px) {
  .page-michal-arch.page-michal-warszaw
    .hero-title.hero-title--mixed-case
    + .hero-subtitle
    .hero-title-kicker {
    font-size: clamp(0.5625rem, min(2.45vw, 2.65vh), 1.125rem);
    letter-spacing: 0.03em;
    line-height: 1.22;
  }
}

@media (max-width: 600px) {
  .page-michal-arch.page-michal-warszaw
    .hero-title.hero-title--mixed-case
    + .hero-subtitle
    .hero-title-kicker {
    font-size: clamp(0.5rem, min(2.55vw, 2.75vh), 1rem);
    letter-spacing: 0.028em;
    line-height: 1.24;
  }
}

@media (max-width: 480px) {
  .page-michal-arch.page-michal-warszaw
    .hero-title.hero-title--mixed-case
    + .hero-subtitle
    .hero-title-kicker {
    font-size: clamp(0.4375rem, min(2.35vw, 2.55vh), 0.8125rem);
    letter-spacing: 0.025em;
    line-height: 1.26;
  }
}

@media (max-width: 400px) {
  .page-michal-arch.page-michal-warszaw
    .hero-title.hero-title--mixed-case
    + .hero-subtitle
    .hero-title-kicker {
    font-size: clamp(0.4375rem, min(2.2vw, 2.4vh), 0.75rem);
    letter-spacing: 0.022em;
    line-height: 1.28;
  }
}

/* ——— Sekcje: odstępy (luxury rhythm) ——— */
.page-michal-arch .content-sections.content-sections-bottom {
  padding: clamp(80px, 10vw, 120px) 0;
  gap: clamp(72px, 9vw, 112px);
}

.page-michal-arch .content-block {
  gap: clamp(40px, 5vw, 88px);
}

/*
 * Jak w makiecie: obie kolumny tej samej wysokości (stretch), zdjęcie wypełnia
 * komórkę — wiersz = max(tekst, min. wysokość kadru), bez „pływającego” obrazka
 * przy długim tekście; krótki tekst dostaje sensowny min. kadr.
 */
.page-michal-arch .content-sections-bottom .content-block {
  align-items: stretch;
}

@media (min-width: 1025px) {
  /* Absolute fill: height:100% na <img> w gridzie bywa bez bazy — img nie rozciągał się z tekstem */
  .page-michal-arch .content-sections-bottom .image-wrap,
  .page-michal-arch .content-sections-bottom .image-wrap-middle {
    position: relative;
    align-self: stretch;
    min-height: clamp(300px, 32vw, 420px);
    overflow: hidden;
  }

  .page-michal-arch .content-sections-bottom .image-wrap img,
  .page-michal-arch .content-sections-bottom .image-wrap-middle img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: cover;
    object-position: center;
  }

  .page-michal-arch
    .content-sections-bottom
    .image-wrap
    img.content-image-focus-bottom,
  .page-michal-arch
    .content-sections-bottom
    .image-wrap-middle
    img.content-image-focus-bottom {
    object-position: center 78%;
  }
}

@media (max-width: 1024px) {
  .page-michal-arch .content-sections-bottom .content-block {
    align-items: start;
  }

  .page-michal-arch .content-sections-bottom .image-wrap,
  .page-michal-arch .content-sections-bottom .image-wrap-middle {
    min-height: 0;
    height: auto;
  }

  .page-michal-arch .content-sections-bottom .image-wrap img,
  .page-michal-arch .content-sections-bottom .image-wrap-middle img {
    position: static;
    inset: auto;
    width: 100%;
    height: 340px;
    min-height: 0;
  }

  .page-michal-arch
    .content-sections-bottom
    .image-wrap
    img.content-image-focus-bottom,
  .page-michal-arch
    .content-sections-bottom
    .image-wrap-middle
    img.content-image-focus-bottom {
    object-fit: cover;
    object-position: center 78%;
  }
}

@media (max-width: 768px) {
  .page-michal-arch .content-sections-bottom .image-wrap img,
  .page-michal-arch .content-sections-bottom .image-wrap-middle img {
    height: 260px;
  }
}

/* ——— Nagłówki sekcji ——— */
.page-michal-arch .content-title-text {
  font-size: clamp(1.35rem, 2.35vw, 2.65rem);
  font-weight: 700;
  letter-spacing: 0.12em;
  line-height: 1.2;
  color: #fff;
  margin: 0 0 2rem;
  max-width: none;
  text-transform: uppercase;
}

.page-michal-arch .content-title-text .michal-cta-heading {
  color: inherit;
  text-decoration: none;
  border-bottom: none;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: pointer;
  transition: opacity 0.25s ease;
}

.page-michal-arch .content-title-text .michal-cta-heading:hover {
  opacity: 0.82;
  border-bottom: 1px solid rgba(255, 255, 255, 0.6);
}

/* ——— Tekst główny (akapit + .content-description-text) ——— */
.page-michal-arch .content-text1 p:not(.content-title-text),
.page-michal-arch .content-text2 p:not(.content-title-text),
.page-michal-arch .content-description-text {
  font-size: 1rem;
  line-height: 1.65;
  color: #c9c9c9;
  font-weight: 400;
  max-width: 38rem;
}

.page-michal-arch .content-description-text {
  margin: 0 0 1.15rem;
}

.page-michal-arch .content-text1 p:not(.content-title-text),
.page-michal-arch .content-text2 p:not(.content-title-text) {
  margin: 0 0 1.15rem;
}

.page-michal-arch .content-text1 p:not(.content-title-text):last-child,
.page-michal-arch .content-text2 p:not(.content-title-text):last-child {
  margin-bottom: 0;
}

/* ——— Listy ——— */
.page-michal-arch .content-list {
  margin: 0.25rem 0 1.35rem;
  padding-left: 1.2rem;
  color: #c9c9c9;
  font-size: 1rem;
  line-height: 1.65;
}

.page-michal-arch .content-list li {
  margin: 0.4rem 0;
  padding-left: 0.25rem;
}

.page-michal-arch .content-list li::marker {
  color: #fff;
  font-size: 0.85em;
}

/* ——— Zdjęcia: ostre kąty; ten sam gradient co index (styleglowna), bez opacity ——— */
.page-michal-arch .image-wrap img,
.page-michal-arch .image-wrap-middle img {
  border-radius: 0;
}

/* ——— Współpraca: full-bleed ——— */
.arch-process {
  position: relative;
  margin: 0;
  /* менше зверху — заголовок трохи вище; знизу залишаємо повітря */
  padding: clamp(40px, 5.5vw, 72px) 7.5% clamp(72px, 9vw, 120px);
  overflow: hidden;
}

.arch-process__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.arch-process__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* низ кадру лишається в кадрі; зайве обрізається зверху */
  object-position: center bottom;
  display: block;
  /* легке розмиття + легкий zoom, щоб краї після blur не світились */
  filter: brightness(0.62) blur(2.5px);
  transform: scale(1.04);
  transform-origin: center bottom;
}

.arch-process__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.2) 0%,
    rgba(0, 0, 0, 0.44) 100%
  );
}

.arch-process__inner {
  position: relative;
  z-index: 2;
  width: 85%;
  max-width: 1400px;
  margin: 0 auto;
}

.page-michal-arch .arch-process__title {
  font-family: "Archivo", sans-serif;
  font-size: clamp(1.35rem, 2.4vw, 2.65rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  line-height: 1.2;
  color: #fff;
  text-align: center;
  margin: 0 auto 2.5rem;
  max-width: min(52rem, 95%);
}

.page-michal-arch .arch-process__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px 72px;
  color: #c9c9c9;
  font-family: "Archivo", sans-serif;
  font-size: 1rem;
  line-height: 1.65;
}

.page-michal-arch .arch-process__grid p {
  margin: 0 0 1em;
}

.page-michal-arch .michal-lead {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #fff;
  margin: 2rem 0 0.65rem;
  line-height: 1.4;
}

.page-michal-arch .arch-process__grid .michal-lead:first-child {
  margin-top: 0;
}

.page-michal-arch .arch-process__grid ul.content-list {
  margin-top: 0.5rem;
  margin-bottom: 1rem;
}

@media (max-width: 900px) {
  .arch-process {
    padding: clamp(32px, 8vw, 48px) 5% clamp(56px, 10vw, 72px);
  }

  .page-michal-arch .arch-process__grid {
    grid-template-columns: 1fr;
    gap: 0;
  }
}

/* ——— Tablet / mobile: як index (styleglowna) — картинка → текст, текст по центру ——— */
@media (max-width: 1024px) {
  .page-michal-arch .content-text1,
  .page-michal-arch .content-text2,
  .page-michal-arch .content-text3 {
    align-items: center;
    text-align: center;
  }

  .page-michal-arch .content-description-text,
  .page-michal-arch .content-text1 p:not(.content-title-text),
  .page-michal-arch .content-text2 p:not(.content-title-text) {
    max-width: 90%;
  }

  .page-michal-arch .content-list {
    text-align: left;
    align-self: center;
    max-width: min(100%, 520px);
  }
}

/* ——— Sekcje treści: te same odstępy i typografia co na głównej (≤768, ≤480) ——— */
@media (max-width: 768px) {
  .page-michal-arch .content-sections.content-sections-bottom {
    padding: 48px 0 56px;
    gap: 40px;
  }

  .page-michal-arch .content-title-text {
    font-size: 20px;
    margin-bottom: 16px;
  }

  .page-michal-arch .content-description-text,
  .page-michal-arch .content-text1 p:not(.content-title-text),
  .page-michal-arch .content-text2 p:not(.content-title-text) {
    font-size: 14px;
  }

  /* Gradienty pionowe jak w styleglowna (nad horizontal z desktopu) */
  .page-michal-arch .image-wrap::after,
  .page-michal-arch .image-wrap-middle::after {
    background: linear-gradient(
      to bottom,
      rgba(0, 0, 0, 0) 0%,
      rgba(0, 0, 0, 0.8) 100%
    );
  }

  /* Animacja reveal: z dołu, jak na index */
  .js .page-michal-arch .text-reveal-left,
  .js .page-michal-arch .text-reveal-right {
    transform: translateY(30px) !important;
  }

  .js .page-michal-arch .text-reveal-left.active,
  .js .page-michal-arch .text-reveal-right.active {
    transform: translateY(0) !important;
  }

  .page-arch-wnetrz main > .content-heading-center:first-child {
    padding-top: clamp(88px, 22vw, 120px);
  }
}

@media (max-width: 480px) {
  .page-michal-arch .content-title-text {
    font-size: 18px;
  }

  .page-michal-arch .content-description-text,
  .page-michal-arch .content-text1 p:not(.content-title-text),
  .page-michal-arch .content-text2 p:not(.content-title-text) {
    font-size: 13px;
  }
}
