/*
  EsterGlass - small, readable CSS overrides.
  Loaded after /scss/style.css via functions.php.
*/

@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,700&display=swap");

:root {
  --eg-blue: #415a77;
  --eg-grey: #707070;
  --eg-bg: #f5fcff;
  --eg-ink: #1f2937;
  --eg-radius: 6px;
  --eg-radius-sm: 6px;
  --eg-border: 1px solid rgba(112, 112, 112, 0.18);
  --eg-shadow: 0 18px 50px rgba(0, 0, 0, 0.10);
  --eg-shadow-soft: 0 10px 28px rgba(0, 0, 0, 0.08);
  --eg-serif-alt: "Fraunces", serif;
}

body {
  background: radial-gradient(1200px 600px at 10% -10%, rgba(65, 90, 119, 0.10), transparent 60%),
    radial-gradient(900px 500px at 90% 0%, rgba(65, 90, 119, 0.08), transparent 55%),
    #ffffff;
}

/* Thank you page */
.thankyou {
  width: 100%;
  min-height: 80vh;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 120px 5vw 80px 5vw;
}

.thankyou .thankyou__inner {
  width: 100%;
  max-width: 860px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.78));
  border: var(--eg-border);
  box-shadow: var(--eg-shadow-soft);
  padding: 28px;
  font-family: "Poppins", sans-serif;
}

.thankyou .thankyou__inner .heading {
  font-family: "Poppins", sans-serif;
  letter-spacing: 0.06em;
}

.thankyou .thankyou__inner p {
  margin-top: 14px;
}

.thankyou .thankyou__inner .button {
  margin-top: 18px;
  width: 100%;
}

@media (min-width: 720px) {
  .thankyou .thankyou__inner .button {
    width: auto;
  }
}

/* Make logo visible on desktop too (white on transparent, dark on white) */
#nav.nav_bg .logo {
  display: block;
}

#nav.nav_bg .logo_white {
  display: none;
}

#nav:not(.nav_bg) .logo {
  display: none;
}

#nav:not(.nav_bg) .logo_white {
  display: block;
}

/* Very subtle gradients in a few sections */
.homepage_wrapper .homepage_text_block {
  background: linear-gradient(135deg, #415a77 0%, #334a63 100%);
}

.oferta {
  background: linear-gradient(180deg, rgba(65, 90, 119, 0.05), rgba(245, 252, 255, 0.0) 60%);
}

.realizacje {
  background: linear-gradient(180deg, rgba(245, 252, 255, 0.0), rgba(65, 90, 119, 0.05));
}

/* Homepage contact section: extra top padding (anchor + fixed nav) */
body.home .kontakt {
  padding-top: 110px;
}

body.home .kontakt:target {
  scroll-margin-top: 110px;
}

.heading {
  font-size: clamp(2.0rem, 1.6vw + 1.3rem, 3.1rem);
  letter-spacing: 1.5px;
}

p {
  line-height: 1.55em;
}

/* Archive cards (category / realizacje): full titles, equal card heights */
.blog_wrapper .blog_posts_grid {
  align-items: stretch;
}

.blog_wrapper .blog_posts_grid .blog_post_card {
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.blog_wrapper .blog_posts_grid .blog_post_card > a:nth-child(1) {
  display: block;
  width: 100%;
}

.blog_wrapper .blog_posts_grid .blog_post_card > a:nth-child(1) img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
}

.blog_wrapper .blog_posts_grid .blog_post_card .post_title {
  height: auto !important;
  display: block;
  width: 100%;
  margin: 12px 0;
  line-height: 1.25em;
  font-weight: 600;
  text-decoration: none;
  word-break: break-word;
  overflow: visible;
  /* Reserve space so cards stay symmetric when titles wrap */
  min-height: calc(1.25em * 3);
}

.blog_wrapper .blog_posts_grid .blog_post_card .post_excerpt {
  margin-top: 0;
}

.blog_wrapper .blog_posts_grid .blog_post_card a.button {
  margin-top: auto;
}

@media (max-width: 768px) {
  .blog_wrapper .blog_posts_grid .blog_post_card > a:nth-child(1) img {
    height: 190px;
  }

  .blog_wrapper .blog_posts_grid .blog_post_card .post_title {
    min-height: calc(1.25em * 2);
  }
}

/* Single post: highlight links */
body.single .post_wrapper a,
body.single .post_wrapper_oferta a,
body.single article a {
  color: var(--eg-blue) !important;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

body.single .post_wrapper a:hover,
body.single .post_wrapper_oferta a:hover,
body.single article a:hover {
  opacity: 0.9;
}

/* Hero buttons row */
.home_hero_actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

@media (max-width: 768px) {
  .home_hero_actions {
    width: 100%;
  }

  .home_hero_actions .button {
    width: 100%;
  }
}

a.button {
  border-radius: var(--eg-radius);
  gap: 10px;
  padding: 14px 22px;
  min-height: 46px;
  line-height: 1;
  letter-spacing: 0.06em;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* Keep button styling for real <button> elements too */
button.button {
  padding: 14px 22px;
  min-height: 46px;
  border: 2px solid currentColor;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  transition: color 0.3s, background-color 0.3s, filter 0.2s;
  border-radius: var(--eg-radius);
  cursor: pointer;
}

button.button.button_filled {
  border-color: var(--eg-blue);
  background-color: var(--eg-blue);
  color: #ffffff;
}

button.button:hover {
  filter: brightness(0.98);
}

@media (max-width: 420px) {
  a.button,
  button.button {
    padding: 12px 18px;
    min-height: 44px;
  }
}

a.button.button_filled {
  background-color: var(--eg-blue);
  border-color: var(--eg-blue) !important;
  color: #ffffff !important;
}

a.button.button_filled:hover {
  filter: brightness(0.97);
}

/* Offer cards: add depth + nicer corners */
.oferta .oferta_grid .oferta_card {
  border-radius: var(--eg-radius);
  overflow: hidden;
  background: #ffffff;
  border: var(--eg-border);
  box-shadow: var(--eg-shadow-soft);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.oferta .oferta_grid .oferta_card .card_photo {
  border-radius: 0;
}

.oferta .oferta_grid .oferta_card:hover {
  transform: translateY(-3px);
}

/* Slider title: use a distinct (modern) serif */
.realizacje .realizacje_slider .slider_element .slider_inner h3 {
  font-family: var(--eg-serif-alt) !important;
  letter-spacing: 0.6px;
  font-size: clamp(1.7rem, 1.1vw + 1.2rem, 2.6rem);
}

.realizacje .realizacje_slider .slider_element .slider_inner {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.55), rgba(0, 0, 0, 0.72));
}

/* Slick arrows: force SVG, hide default text/pseudo */
.realizacje .realizacje_slider .slick-next,
.realizacje .realizacje_slider .slick-prev {
  font-size: 0;
  color: transparent;
}

.realizacje .realizacje_slider .slick-next:before,
.realizacje .realizacje_slider .slick-prev:before {
  content: none !important;
}

.realizacje .realizacje_slider .slick-next svg,
.realizacje .realizacje_slider .slick-prev svg {
  display: block;
}

/* Contact form (Formspark) */
.kontakt .contact_form form {
  width: 100%;
  max-width: 720px;
  margin: 0 auto;
  padding: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.78));
  border: var(--eg-border);
  border-radius: var(--eg-radius);
  box-shadow: var(--eg-shadow-soft);
}

.kontakt .contact_form form .form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.kontakt .contact_form form .form-grid .form-row {
  margin: 0;
}

.kontakt .contact_form form .form-row {
  display: flex;
  flex-direction: column !important;
  align-items: stretch;
  gap: 8px;
  margin: 12px 0;
}

.kontakt .contact_form form label {
  display: block;
  width: 100% !important;
  max-width: 100% !important;
  font-weight: 500;
  color: rgba(31, 41, 55, 0.85);
  font-size: 0.98rem;
}

.kontakt .contact_form form label a {
  color: var(--eg-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.kontakt .contact_form form input,
.kontakt .contact_form form textarea {
  width: 100%;
  border-radius: var(--eg-radius);
  border: 1px solid rgba(112, 112, 112, 0.25);
  padding: 12px 12px;
  font-size: 1rem;
  outline: none;
  background: #ffffff;
}

.kontakt .contact_form form input {
  height: 44px;
}

.kontakt .contact_form form textarea {
  resize: vertical;
  min-height: 140px;
}

.kontakt .contact_form form input:focus,
.kontakt .contact_form form textarea:focus {
  border-color: rgba(65, 90, 119, 0.65);
  box-shadow: 0 0 0 3px rgba(65, 90, 119, 0.12);
}

.kontakt .contact_form form input::placeholder,
.kontakt .contact_form form textarea::placeholder {
  color: rgba(31, 41, 55, 0.45);
}

.kontakt .contact_form form #submit-button {
  width: 100%;
  margin-top: 10px;
  box-shadow: none;
}

.kontakt .contact_form form .form-row--consent {
  flex-direction: row !important;
  align-items: flex-start;
  gap: 10px;
  margin-top: 16px;
}

.kontakt .contact_form form .form-row--consent input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  padding: 0;
  flex: 0 0 auto;
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  appearance: checkbox;
  accent-color: var(--eg-blue);
}

.kontakt .contact_form form .form-row--consent label {
  font-weight: 400;
  line-height: 1.35em;
  white-space: nowrap;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  gap: 6px;
}

.kontakt .contact_form form .form-row--consent label a {
  display: inline;
  white-space: nowrap;
}

@media (max-width: 640px) {
  .kontakt .contact_form form {
    max-width: 100%;
  }

  .kontakt .contact_form form .form-grid {
    grid-template-columns: 1fr;
  }
}

/* Home: quick contact strip */
.home_contact_quick {
  width: 100%;
  max-width: 1100px;
  margin: 40px auto 70px auto;
  padding: 0 5vw;
}

.home_contact_quick .home_contact_quick_inner {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.78));
  border: var(--eg-border);
  border-radius: var(--eg-radius);
  box-shadow: var(--eg-shadow);
  padding: 18px;
}

.home_contact_quick .contact_card {
  border-radius: var(--eg-radius-sm);
  padding: 16px;
  background: #ffffff;
  border: var(--eg-border);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.home_contact_quick .contact_card .kicker {
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(31, 41, 55, 0.70);
}

.home_contact_quick .contact_card strong {
  font-size: 1.05rem;
  color: var(--eg-ink);
}

.home_contact_quick .contact_card a {
  color: var(--eg-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
  opacity: 0.9;
}

.home_contact_quick .contact_card a:hover {
  opacity: 1;
}

.home_contact_quick .contact_card .actions {
  margin-top: auto;
}

.home_contact_quick .contact_card .actions a.button {
  box-shadow: none;
  border-color: var(--eg-blue);
  color: var(--eg-blue);
  width: 100%;
}

.home_contact_quick .contact_card .actions a.button:hover {
  background: var(--eg-blue);
  color: #ffffff;
}

/* Mobile menu improvements */
body.no-scroll {
  overflow: hidden;
}

nav .nav-icon {
  background: transparent;
  border: 0;
  padding: 10px;
  line-height: 0;
  cursor: pointer;
}

nav .nav-icon svg {
  width: 34px;
  height: 34px;
  fill: var(--eg-grey);
}

body.home nav:not(.nav_bg) .nav-icon svg {
  fill: #ffffff;
}

nav.is-mobile-open .nav-icon svg {
  fill: #ffffff;
}

@media (max-width: 980px) {
  nav {
    height: 72px;
    padding: 12px 16px;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }

  nav .logo img,
  nav .logo_white img {
    max-height: 56px;
    max-width: 56vw;
  }

  nav #nav-hamburger-menu {
    display: block;
  }

  nav #nav-close-button {
    display: none;
  }

  nav.is-mobile-open {
    background-color: rgba(112, 112, 112, 0.98);
    border-bottom-color: rgba(255, 255, 255, 0.22) !important;
  }

  nav.is-mobile-open #nav-close-button {
    display: block;
  }

  nav.is-mobile-open #nav-hamburger-menu {
    display: none;
  }

  nav.is-mobile-open ul {
    display: flex !important;
    position: fixed;
    top: 72px;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100vw;
    height: calc(100vh - 72px);
    padding: 20px 16px 24px 16px;
    gap: 12px;
    justify-content: flex-start;
    background: rgba(112, 112, 112, 0.98);
    overflow: auto;
  }

  nav.is-mobile-open ul li {
    width: 100%;
  }

  nav.is-mobile-open ul li a {
    display: flex;
    width: 100%;
    justify-content: center;
    padding: 14px 16px;
    border-radius: var(--eg-radius);
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.14);
    opacity: 1;
    color: #ffffff !important;
  }

  nav.is-mobile-open ul li a:hover {
    border-bottom: 1px solid rgba(255, 255, 255, 0.22);
  }
}

@media (min-width: 981px) {
  nav .logo img,
  nav .logo_white img {
    max-height: 54px;
    max-width: 220px;
  }
}

@media (max-width: 980px) {
  nav.is-mobile-open .logo_white {
    display: block;
  }

  nav.is-mobile-open .logo {
    display: none;
  }
}

@media (max-width: 768px) {
  .realizacje .realizacje_slider .slider_element .slider_inner div {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
  }

  /* Hero spacing so full-width buttons don't touch edges */
  .homepage_wrapper .homepage_text_block {
    padding-left: 5vw;
    padding-right: 5vw;
  }

  .homepage_wrapper .homepage_text_block .inner_homepage_text_block {
    padding-left: 0;
    padding-right: 0;
  }

  .home_contact_quick {
    margin: 28px auto 60px auto;
  }

  .home_contact_quick .home_contact_quick_inner {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  /* Contact form: keep everything within ~95% width */
  .kontakt .contact_form form {
    width: 95%;
    padding: 18px;
  }

  .kontakt .kontakt_inner_container .contact_form form {
    max-width: 100% !important;
  }

  /* Remove legacy mobile widths from main stylesheet */
  .kontakt .kontakt_inner_container .contact_form form .form-row {
    width: auto !important;
    max-width: 100% !important;
  }

  .kontakt .contact_form form input,
  .kontakt .contact_form form textarea {
    max-width: 100%;
    box-sizing: border-box;
  }
}

@media (max-width: 420px) {
  nav .logo img,
  nav .logo_white img {
    max-height: 62px;
    max-width: 68vw;
  }
}
