/* =========================================================
   SEGPOL HERO — FULL CSS / MOBILE FIRST
   Gradient variants:
   beige | olive | warm_brown | bluegray | dark

   PHP classes:
   .segpol-hero--gradient-beige
   .segpol-hero--gradient-olive
   .segpol-hero--gradient-warm-brown
   .segpol-hero--gradient-bluegray
   .segpol-hero--gradient-dark
   ========================================================= */


/* =========================================================
   BASE
   ========================================================= */

.segpol-hero {
  --segpol-hero-container: 1320px;

  --segpol-hero-white: #ffffff;
  --segpol-hero-beige: #f5f0e8;
  --segpol-hero-beige-soft: #faf7f1;
  --segpol-hero-warm: #e7d8c7;

  --segpol-hero-dark: #2e2a27;
  --segpol-hero-text: #6f6962;

  --segpol-hero-muted: #4f5543;
  --segpol-hero-olive: #747b63;
  --segpol-hero-brown: #9c5f3f;
  --segpol-hero-copper: #b46c47;
  --segpol-hero-bluegray: #9fb1b8;

  --segpol-hero-border: rgba(46, 42, 39, .22);
  --segpol-hero-shadow: 0 20px 55px rgba(50, 43, 36, .14);
  --segpol-hero-transition: 850ms cubic-bezier(.22, .61, .36, 1);

  /*
    Domyślne wartości gradientu — wariant beige.
    Nadpisywane przez klasy .segpol-hero--gradient-...
  */
  --segpol-hero-gradient-start: rgba(250, 247, 241, .98);
  --segpol-hero-gradient-mid: rgba(250, 247, 241, .92);
  --segpol-hero-gradient-end: rgba(250, 247, 241, .62);
  --segpol-hero-gradient-fade: rgba(250, 247, 241, 0);

  --segpol-hero-bg-color: #f5f0e8;

  --segpol-hero-text-main: var(--segpol-hero-dark);
  --segpol-hero-text-muted-current: var(--segpol-hero-text);
  --segpol-hero-text-subheading: #3e3a36;
  --segpol-hero-accent-current: var(--segpol-hero-brown);

  --segpol-hero-line-1: rgba(156, 95, 63, .08);
  --segpol-hero-line-2: rgba(116, 123, 99, .10);
  --segpol-hero-line-3: rgba(159, 177, 184, .08);

  position: relative;
  overflow: hidden;

  background: var(--segpol-hero-bg-color);
  color: var(--segpol-hero-text-main);
  isolation: isolate;
}


/* =========================================================
   BACKGROUND IMAGE
   ========================================================= */

.segpol-hero__background,
.segpol-hero__background-image {
  position: absolute;
  inset: 0;
  z-index: -4;
}

/* Media field / rendered entity wrappers */
.segpol-hero__background-image > div,
.segpol-hero__background-image article,
.segpol-hero__background-image picture,
.segpol-hero__background-image .field,
.segpol-hero__background-image .field__item {
  width: 100%;
  height: 100%;
}

.segpol-hero__background-image img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 62% center;
}


/* =========================================================
   OVERLAY / GRADIENT
   ========================================================= */

.segpol-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: -3;
  background:
    linear-gradient(
      180deg,
      var(--segpol-hero-gradient-start) 0%,
      var(--segpol-hero-gradient-mid) 42%,
      var(--segpol-hero-gradient-end) 100%
    );
}



/* Dolne wygaszenie */
.segpol-hero::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
  height: 110px;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(250, 247, 241, 0) 0%,
      rgba(250, 247, 241, .40) 100%
    );
}


/* =========================================================
   GRADIENT VARIANTS
   ========================================================= */

/* 1. Beżowy — domyślny jasny katalogowy */
.segpol-hero--gradient-beige {
  --segpol-hero-gradient-start: rgba(250, 247, 241, .98);
  --segpol-hero-gradient-mid: rgba(250, 247, 241, .92);
  --segpol-hero-gradient-end: rgba(250, 247, 241, .62);
  --segpol-hero-gradient-fade: rgba(250, 247, 241, 0);

  --segpol-hero-bg-color: #f5f0e8;

  --segpol-hero-text-main: var(--segpol-hero-dark);
  --segpol-hero-text-muted-current: var(--segpol-hero-text);
  --segpol-hero-text-subheading: #3e3a36;
  --segpol-hero-accent-current: var(--segpol-hero-brown);

  --segpol-hero-line-1: rgba(156, 95, 63, .08);
  --segpol-hero-line-2: rgba(116, 123, 99, .10);
  --segpol-hero-line-3: rgba(159, 177, 184, .08);
}

/* 2. Oliwkowy — zielony premium */
.segpol-hero--gradient-olive {
  --segpol-hero-gradient-start: rgba(86, 92, 72, .97);
  --segpol-hero-gradient-mid: rgba(116, 123, 99, .82);
  --segpol-hero-gradient-end: rgba(116, 123, 99, .36);
  --segpol-hero-gradient-fade: rgba(116, 123, 99, 0);

  --segpol-hero-bg-color: #747b63;

  --segpol-hero-text-main: #ffffff;
  --segpol-hero-text-muted-current: rgba(255, 255, 255, .82);
  --segpol-hero-text-subheading: rgba(255, 255, 255, .90);
  --segpol-hero-accent-current: #e7d8c7;

  --segpol-hero-line-1: rgba(250, 247, 241, .10);
  --segpol-hero-line-2: rgba(180, 108, 71, .14);
  --segpol-hero-line-3: rgba(250, 247, 241, .08);
}

/* 3. Brązowy — drewno / MDF / naturalny */
.segpol-hero--gradient-warm-brown {
  --segpol-hero-gradient-start: rgba(111, 71, 49, .97);
  --segpol-hero-gradient-mid: rgba(156, 95, 63, .82);
  --segpol-hero-gradient-end: rgba(156, 95, 63, .34);
  --segpol-hero-gradient-fade: rgba(156, 95, 63, 0);

  --segpol-hero-bg-color: #9c5f3f;

  --segpol-hero-text-main: #ffffff;
  --segpol-hero-text-muted-current: rgba(255, 255, 255, .82);
  --segpol-hero-text-subheading: rgba(255, 255, 255, .90);
  --segpol-hero-accent-current: #f5f0e8;

  --segpol-hero-line-1: rgba(250, 247, 241, .12);
  --segpol-hero-line-2: rgba(116, 123, 99, .18);
  --segpol-hero-line-3: rgba(250, 247, 241, .08);
}

/* 4. Szaroniebieski — techniczny / park maszynowy */
.segpol-hero--gradient-bluegray {
  --segpol-hero-gradient-start: rgba(119, 139, 148, .96);
  --segpol-hero-gradient-mid: rgba(159, 177, 184, .82);
  --segpol-hero-gradient-end: rgba(159, 177, 184, .36);
  --segpol-hero-gradient-fade: rgba(159, 177, 184, 0);

  --segpol-hero-bg-color: #9fb1b8;

  --segpol-hero-text-main: #2e2a27;
  --segpol-hero-text-muted-current: rgba(46, 42, 39, .78);
  --segpol-hero-text-subheading: rgba(46, 42, 39, .88);
  --segpol-hero-accent-current: #9c5f3f;

  --segpol-hero-line-1: rgba(250, 247, 241, .16);
  --segpol-hero-line-2: rgba(156, 95, 63, .12);
  --segpol-hero-line-3: rgba(46, 42, 39, .06);
}

/* 5. Ciemny — elegancki kontrast */
.segpol-hero--gradient-dark {
  --segpol-hero-gradient-start: rgba(46, 42, 39, .97);
  --segpol-hero-gradient-mid: rgba(46, 42, 39, .84);
  --segpol-hero-gradient-end: rgba(46, 42, 39, .38);
  --segpol-hero-gradient-fade: rgba(46, 42, 39, 0);

  --segpol-hero-bg-color: #2e2a27;

  --segpol-hero-text-main: #ffffff;
  --segpol-hero-text-muted-current: rgba(255, 255, 255, .78);
  --segpol-hero-text-subheading: rgba(255, 255, 255, .90);
  --segpol-hero-accent-current: #b46c47;

  --segpol-hero-line-1: rgba(250, 247, 241, .08);
  --segpol-hero-line-2: rgba(180, 108, 71, .16);
  --segpol-hero-line-3: rgba(250, 247, 241, .06);
}


/* =========================================================
   CONTENT
   ========================================================= */

.segpol-hero__inner {
  position: relative;
  z-index: 2;
  width: min(100% - 32px, var(--segpol-hero-container));
 
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-block: 110px 42px;
}

.segpol-hero__content {
  max-width: 560px;
}

.segpol-hero__eyebrow {
  margin-bottom: 16px;
  color: var(--segpol-hero-accent-current);
  font-size: 12px;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.segpol-hero__heading {
  margin: 0;
  max-width: 560px;
  color: var(--segpol-hero-text-main);
  font-size: clamp(40px, 12vw, 74px);
  line-height: .98;
  font-weight: 400;
  letter-spacing: .105em;
  text-transform: uppercase;
}

.segpol-hero__heading span,
.segpol-hero__heading strong,
.segpol-hero__heading em {
  color: var(--segpol-hero-accent-current);
  font-style: normal;
  font-weight: 400;
}

.segpol-hero__decor {
  width: 74px;
  height: 5px;
  margin-block: 28px;
  background: var(--segpol-hero-accent-current);
}

.segpol-hero__subheading {
  max-width: 500px;
  color: var(--segpol-hero-text-subheading);
  font-size: clamp(18px, 4vw, 24px);
  line-height: 1.45;
  font-weight: 600;
}

.segpol-hero__text {
  max-width: 540px;
  margin-top: 18px;
  color: var(--segpol-hero-text-muted-current);
  font-size: 16px;
  line-height: 1.75;
}

.segpol-hero__text p {
  margin: 0 0 12px;
}

.segpol-hero__text p:last-child {
  margin-bottom: 0;
}


/* =========================================================
   ACTIONS / BUTTONS
   ========================================================= */

.segpol-hero__actions {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 32px;
}

.segpol-hero__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 15px 24px;
  border: 2px solid transparent;
  color: var(--segpol-hero-dark);
  font-size: 14px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  transition:
    background-color .25s ease,
    color .25s ease,
    border-color .25s ease,
    transform .25s ease;
}

.segpol-hero__button:hover,
.segpol-hero__button:focus-visible {
  transform: translateY(-2px);
}

/* Primary — bazowo */
.segpol-hero__button--primary {
  background: var(--segpol-hero-muted);
  border-color: var(--segpol-hero-muted);
  color: var(--segpol-hero-white) !important;
}

.segpol-hero__button--primary:visited {
  color: var(--segpol-hero-white) !important;
}

.segpol-hero__button--primary:hover,
.segpol-hero__button--primary:focus-visible {
  background: #555c4d;
  border-color: #555c4d;
  color: var(--segpol-hero-white) !important;
}

/* Secondary — bazowo jasny */
.segpol-hero__button--secondary {
  background: rgba(255, 255, 255, .45);
  border-color: var(--segpol-hero-border);
  color: var(--segpol-hero-dark);
  backdrop-filter: blur(8px);
}

.segpol-hero__button--secondary:visited {
  color: var(--segpol-hero-dark);
}

.segpol-hero__button--secondary:hover,
.segpol-hero__button--secondary:focus-visible {
  background: var(--segpol-hero-white);
  border-color: var(--segpol-hero-dark);
  color: var(--segpol-hero-dark);
}

/* Secondary na ciemniejszych gradientach */
.segpol-hero--gradient-olive .segpol-hero__button--secondary,
.segpol-hero--gradient-warm-brown .segpol-hero__button--secondary,
.segpol-hero--gradient-dark .segpol-hero__button--secondary {
  background: rgba(255, 255, 255, .10);
  border-color: rgba(255, 255, 255, .45);
  color: #fff;
}

.segpol-hero--gradient-olive .segpol-hero__button--secondary:visited,
.segpol-hero--gradient-warm-brown .segpol-hero__button--secondary:visited,
.segpol-hero--gradient-dark .segpol-hero__button--secondary:visited {
  color: #fff;
}

.segpol-hero--gradient-olive .segpol-hero__button--secondary:hover,
.segpol-hero--gradient-olive .segpol-hero__button--secondary:focus-visible,
.segpol-hero--gradient-warm-brown .segpol-hero__button--secondary:hover,
.segpol-hero--gradient-warm-brown .segpol-hero__button--secondary:focus-visible,
.segpol-hero--gradient-dark .segpol-hero__button--secondary:hover,
.segpol-hero--gradient-dark .segpol-hero__button--secondary:focus-visible {
  background: #fff;
  border-color: #fff;
  color: var(--segpol-hero-dark);
}

/* Primary na ciemnych gradientach — jasny premium */
.segpol-hero--gradient-olive .segpol-hero__button--primary,
.segpol-hero--gradient-warm-brown .segpol-hero__button--primary,
.segpol-hero--gradient-dark .segpol-hero__button--primary {
  background: #f5f0e8;
  border-color: #f5f0e8;
  color: var(--segpol-hero-dark) !important;
}

.segpol-hero--gradient-olive .segpol-hero__button--primary:visited,
.segpol-hero--gradient-warm-brown .segpol-hero__button--primary:visited,
.segpol-hero--gradient-dark .segpol-hero__button--primary:visited {
  color: var(--segpol-hero-dark) !important;
}

.segpol-hero--gradient-olive .segpol-hero__button--primary:hover,
.segpol-hero--gradient-olive .segpol-hero__button--primary:focus-visible,
.segpol-hero--gradient-warm-brown .segpol-hero__button--primary:hover,
.segpol-hero--gradient-warm-brown .segpol-hero__button--primary:focus-visible,
.segpol-hero--gradient-dark .segpol-hero__button--primary:hover,
.segpol-hero--gradient-dark .segpol-hero__button--primary:focus-visible {
  background: var(--segpol-hero-brown);
  border-color: var(--segpol-hero-brown);
  color: #fff !important;
}


/* =========================================================
   PRODUCT IMAGE
   ========================================================= */

.segpol-hero__product {
  display: none;
}


/* =========================================================
   TABLET
   ========================================================= */

@media (min-width: 700px) {


  .segpol-hero__inner {
    padding-block: 135px 56px;
  }

  .segpol-hero__overlay {
    background:
      linear-gradient(
        90deg,
        var(--segpol-hero-gradient-start) 0%,
        var(--segpol-hero-gradient-mid) 34%,
        var(--segpol-hero-gradient-end) 68%,
        var(--segpol-hero-gradient-fade) 100%
      );
  }

  .segpol-hero__actions {
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
  }

  .segpol-hero__button {
    min-width: 210px;
  }
}


/* =========================================================
   DESKTOP
   ========================================================= */

@media (min-width: 1024px) {

  .segpol-hero__inner {
    justify-content: center;
    padding-block: 110px 80px;
  }

  .segpol-hero__content {
    max-width: 540px;
  }

  .segpol-hero__background-image img {
    object-position: center center;
  }

  .segpol-hero__overlay {
    background:
      linear-gradient(
        90deg,
        var(--segpol-hero-gradient-start) 0%,
        var(--segpol-hero-gradient-mid) 26%,
        var(--segpol-hero-gradient-end) 48%,
        var(--segpol-hero-gradient-fade) 76%,
        transparent 100%
      );
  }

  .segpol-hero__heading {
    font-size: clamp(58px, 5.1vw, 88px);
  }

  .segpol-hero__product {
    display: block;
    position: absolute;
    right: clamp(16px, 2vw, 42px);
    bottom: 24px;
    z-index: 2;
    width: min(46vw, 680px);
    pointer-events: none;
  }

  .segpol-hero__product img {
    display: block;
    width: 100%;
    height: auto;
    filter: drop-shadow(0 24px 38px rgba(46, 42, 39, .18));
  }
}


/* =========================================================
   LARGE DESKTOP
   ========================================================= */

@media (min-width: 1440px) {
  .segpol-hero__content {
    max-width: 600px;
  }

  .segpol-hero__heading {
    max-width: 620px;
    font-size: clamp(68px, 5vw, 96px);
  }

  .segpol-hero__product {
    width: min(44vw, 720px);
    right: clamp(32px, 4vw, 86px);
  }
}


/* =========================================================
   ANIMATIONS
   ========================================================= */

.segpol-hero--animation-none {
  opacity: 1;
  transform: none;
}

.js-segpol-hero-animate {
  will-change: opacity, transform;
}

.segpol-hero--animation-fade-in {
  opacity: 0;
  transition: opacity var(--segpol-hero-transition);
}

.segpol-hero--animation-fade-in.is-visible {
  opacity: 1;
}

.segpol-hero--animation-slide-up {
  opacity: 0;
  transform: translateY(42px);
  transition:
    opacity var(--segpol-hero-transition),
    transform var(--segpol-hero-transition);
}

.segpol-hero--animation-slide-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.segpol-hero--animation-slide-down {
  opacity: 0;
  transform: translateY(-42px);
  transition:
    opacity var(--segpol-hero-transition),
    transform var(--segpol-hero-transition);
}

.segpol-hero--animation-slide-down.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.segpol-hero--animation-zoom-soft {
  opacity: 0;
  transform: scale(.985);
  transition:
    opacity var(--segpol-hero-transition),
    transform 900ms cubic-bezier(.22, .61, .36, 1);
}

.segpol-hero--animation-zoom-soft.is-visible {
  opacity: 1;
  transform: scale(1);
}


/* =========================================================
   STAGGER ANIMATION
   ========================================================= */

.segpol-hero--animation-stagger-soft .segpol-hero__eyebrow,
.segpol-hero--animation-stagger-soft .segpol-hero__heading,
.segpol-hero--animation-stagger-soft .segpol-hero__decor,
.segpol-hero--animation-stagger-soft .segpol-hero__subheading,
.segpol-hero--animation-stagger-soft .segpol-hero__text,
.segpol-hero--animation-stagger-soft .segpol-hero__actions,
.segpol-hero--animation-stagger-soft .segpol-hero__product {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 720ms cubic-bezier(.22, .61, .36, 1),
    transform 720ms cubic-bezier(.22, .61, .36, 1);
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__eyebrow {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 60ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__heading {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 160ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__decor {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 260ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__subheading {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 360ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__text {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 460ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__actions {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 560ms;
}

.segpol-hero--animation-stagger-soft.is-visible .segpol-hero__product {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 660ms;
}


/* =========================================================
   ACCESSIBILITY
   ========================================================= */

@media (prefers-reduced-motion: reduce) {
  .js-segpol-hero-animate,
  .segpol-hero--animation-fade-in,
  .segpol-hero--animation-slide-up,
  .segpol-hero--animation-slide-down,
  .segpol-hero--animation-zoom-soft,
  .segpol-hero--animation-stagger-soft .segpol-hero__eyebrow,
  .segpol-hero--animation-stagger-soft .segpol-hero__heading,
  .segpol-hero--animation-stagger-soft .segpol-hero__decor,
  .segpol-hero--animation-stagger-soft .segpol-hero__subheading,
  .segpol-hero--animation-stagger-soft .segpol-hero__text,
  .segpol-hero--animation-stagger-soft .segpol-hero__actions,
  .segpol-hero--animation-stagger-soft .segpol-hero__product {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}