    :root {
      --color-primary: #b6c145;
      --color-primary-dark: #adb83a;
      --color-primary-light: #c0cd3b;
      --color-dark: #4b4a48;
      --color-white: #ffffff;
      --color-black: #000000;
      --color-overlay: rgba(0, 0, 0, 0.8);
      --color-header-transparent: rgba(75, 74, 72, 0.28);
      --color-header-scrolled: rgba(75, 74, 72, 0.92);
      --container-width: 1280px;
      --header-height: 92px;
      --transition-fast: 0.25s ease;
      --transition-medium: 0.45s ease;
      --shadow-soft: 0 18px 40px rgba(0, 0, 0, 0.16);
    }

* {box-sizing: border-box;margin: 0;padding: 0;}

html {scroll-behavior: smooth;}

    body {font-family: "Poppins", sans-serif; font-weight: 400;background: var(--color-white);color: var(--color-dark);line-height: 1.5;overflow-x: hidden;}
    a {color: inherit;text-decoration: none;}
    img {display: block;max-width: 100%;}
    ul {list-style: none;}
    button {font: inherit;border: none;background: none;cursor: pointer;}

    .container {width: min(100% - 32px, var(--container-width));margin: 0 auto;}

.mikro-nadpis {display: block;margin-bottom: 15px;color: var(--color-primary-dark);font-size: 0.9rem;letter-spacing: 0.16em;text-transform: uppercase;}
.mikro-nadpis-light {display: block;margin-bottom: 15px;color: var(--color-primary-light);font-size: 0.9rem;letter-spacing: 0.16em;text-transform: uppercase;}
.text-center{text-align: center;}
.InkonContH2{font-weight: 500;letter-spacing: 0.13em;text-transform: uppercase;}
.m-20{margin-bottom:20px;}


    .site-header {position: fixed;inset: 0 0 auto 0;z-index: 1000;height: var(--header-height);
      background: var(--color-header-transparent);backdrop-filter: blur(10px);-webkit-backdrop-filter: blur(10px);
      border-bottom: 1px solid rgba(255, 255, 255, 0.08);
      transition: background var(--transition-fast), box-shadow var(--transition-fast), height var(--transition-fast);
    }
    .site-header.is-scrolled {background: var(--color-header-scrolled);box-shadow: 0 10px 30px rgba(0, 0, 0, 0.16);height: 82px;}
    .site-header__inner {display: flex;align-items: center;justify-content: space-between;gap: 24px;min-height: 100%;}
    .site-logo {flex: 0 0 auto;display: inline-flex;align-items: center;max-width: 180px;}
    .site-logo img {width: 100%;height: auto;object-fit: contain;}
    .site-nav {display: flex;align-items: center;gap: 28px;margin-left: auto;}
    .site-nav a {color: var(--color-white);font-size: 0.95rem;letter-spacing: 0.04em;text-transform: uppercase;position: relative;transition: color var(--transition-fast);}

    .site-nav a::after {content: '';position: absolute;left: 0;bottom: -8px;width: 100%;height: 2px;background: var(--color-primary);transform: scaleX(0);transform-origin: left;transition: transform var(--transition-fast);}
    .site-nav a:hover::after, .site-nav a:focus-visible::after {transform: scaleX(1);}

    .header-phone {flex: 0 0 auto;display: inline-flex;align-items: center;justify-content: center;min-height: 48px;padding: 0 18px;border: 1px solid rgba(255, 255, 255, 0.25);
      border-radius: 999px;color: var(--color-white);background: rgba(0, 0, 0, 0.18);transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
    }

    .header-phone:hover, .header-phone:focus-visible {background: rgba(182, 193, 69, 0.18);border-color: rgba(182, 193, 69, 0.65);transform: translateY(-1px);}
    .menu-toggle {display: none;width: 52px;height: 52px;border-radius: 12px;align-items: center;justify-content: center;background: rgba(0, 0, 0, 0.28);border: 1px solid rgba(255, 255, 255, 0.2);position: relative;z-index: 1002;}
    .menu-toggle span, .menu-toggle::before, .menu-toggle::after {content: '';position: absolute;width: 24px;height: 2px;background: var(--color-white);transition: transform var(--transition-fast), opacity var(--transition-fast), top var(--transition-fast);}
    .menu-toggle span { top: 25px; }
    .menu-toggle::before { top: 18px; }
    .menu-toggle::after { top: 32px; }
    .menu-toggle.is-active span { opacity: 0; }
    .menu-toggle.is-active::before { top: 25px; transform: rotate(45deg); }
    .menu-toggle.is-active::after { top: 25px; transform: rotate(-45deg); }

    .hero-slider {position: relative;min-height: 100vh;isolation: isolate;background: var(--color-dark);}
    .hero-slider__track {position: relative;width: 100%;min-height: 100vh;overflow: hidden;}
    .hero-slide {position: absolute;inset: 0;opacity: 0;visibility: hidden;transform: scale(1.04);transition: opacity 0.9s ease, visibility 0.9s ease, transform 5.5s ease;}
    .hero-slide.is-active {opacity: 1;visibility: visible;transform: scale(1);z-index: 2;}
    .hero-slide::before {content: '';position: absolute;inset: 0;background: linear-gradient(90deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.2) 45%, rgba(0, 0, 0, 0.52) 100%);z-index: 1;}
    .hero-slide__image {position: absolute;inset: 0;width: 100%;height: 100%;object-fit: cover;}
    .hero-slide__content {position: relative;z-index: 2;min-height: 100vh;display: flex;align-items: center;padding-top: calc(var(--header-height) + 24px);padding-bottom: 48px;}
    .hero-slide__box {max-width: 560px;background: var(--color-overlay);color: var(--color-white);padding: 36px 38px;box-shadow: var(--shadow-soft);border-left: 6px solid var(--color-primary);}
    .hero-slide__eyebrow {display: inline-block;margin-bottom: 26px;color: var(--color-primary);font-size: 0.9rem;letter-spacing: 0.16em;text-transform: uppercase;}
    .hero-slide__title {font-size: clamp(1.4rem, 2.4vw, 1.2rem);line-height: 1.08;font-weight: 400;margin-bottom: 28px;text-transform: uppercase;}
    .hero-slide__text {font-size: 1.02rem;max-width: 54ch;color: rgba(255, 255, 255, 0.92);margin-bottom: 48px;}
    .hero-slide__actions {display: flex;flex-wrap: wrap;gap: 14px;align-items: center;}

    .btn {display: inline-flex;align-items: center;justify-content: center;min-height: 52px;padding: 0 24px;border-radius: 999px;text-transform: uppercase;letter-spacing: 0.06em;
      transition: transform var(--transition-fast), background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
    }

    .btn:hover, .btn:focus-visible {transform: translateY(-2px);}
    .btn--primary {background: var(--color-primary);color: var(--color-dark);}
    .btn--secondary {background: transparent;color: var(--color-white);border: 1px solid rgba(255, 255, 255, 0.35);}

    .hero-slider__controls {position: absolute;inset: auto 0 44px 0;z-index: 5;pointer-events: none;}
    .hero-slider__controls-inner {display: flex;justify-content: space-between;align-items: center;gap: 24px;}
    .hero-slider__nav {display: flex;gap: 12px;pointer-events: auto;}
    .hero-slider__arrow {width: 58px;height: 58px;border-radius: 50%;display: inline-flex;align-items: center;justify-content: center;color: var(--color-white);background: rgba(0, 0, 0, 0.42);border: 1px solid rgba(255, 255, 255, 0.24);
      transition: background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
    }

    .hero-slider__arrow:hover, .hero-slider__arrow:focus-visible {background: rgba(182, 193, 69, 0.18);border-color: rgba(182, 193, 69, 0.7);transform: translateY(-2px);}
    .hero-slider__dots {display: flex;gap: 10px;pointer-events: auto;}
    .hero-slider__dot {width: 12px;height: 12px;border-radius: 50%;background: rgba(255, 255, 255, 0.4);border: 1px solid transparent;
      transition: background var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);
    }

    .hero-slider__dot.is-active {background: var(--color-primary);border-color: rgba(255, 255, 255, 0.4);transform: scale(1.15);}

.hero-slider,.hero-slider__track {touch-action: pan-y;} /* skrolovani slideru pouze v ose X*/

    .mobile-panel {position: fixed;inset: 0 0 0 auto;width: min(88vw, 360px);background: rgba(75, 74, 72, 0.98);transform: translateX(100%);transition: transform var(--transition-medium);
      z-index: 1001;padding: 112px 28px 32px;display: none;box-shadow: -10px 0 30px rgba(0, 0, 0, 0.2);
    }

    .mobile-panel.is-open {transform: translateX(0);}

    .mobile-panel__nav {display: grid;gap: 18px;}
    .mobile-panel__nav a, .mobile-panel__phone {color: var(--color-white);font-size: 1rem;text-transform: uppercase;letter-spacing: 0.04em;}
    .mobile-overlay {position: fixed;inset: 0;background: rgba(0, 0, 0, 0.5);opacity: 0;visibility: hidden;transition: opacity var(--transition-fast), visibility var(--transition-fast);z-index: 1000;display: none;}
    .mobile-overlay.is-open {opacity: 1;visibility: visible;}
    .placeholder-section {padding: 96px 0;background: #f7f7f7;}
    .placeholder-section__box {background: var(--color-dark);color: var(--color-white);padding: 32px;border-left: 6px solid var(--color-primary);}

    @media (max-width: 1080px) {
      .site-nav {gap: 18px;}
      .site-nav a {font-size: 0.86rem;}
      .header-phone {padding: 0 14px;font-size: 0.9rem;}
    }

    @media (max-width: 920px) {
      .site-nav, .header-phone {display: none;}
      .menu-toggle, .mobile-panel, .mobile-overlay {display: flex;}
      .mobile-panel {display: block;}
      .site-logo {max-width: 150px;}
      .hero-slide__box {max-width: 100%;padding: 28px 24px;}
      .hero-slider__controls-inner {align-items: flex-end;}
    }

    @media (max-width: 640px) {
      :root {--header-height: 78px;}

      .container {width: min(100% - 24px, var(--container-width));}
      .site-logo {max-width: 132px;}
      .hero-slide__content {padding-bottom: 110px;}
      .hero-slide__title {font-size: clamp(1.8rem, 9vw, 2.8rem);}
      .hero-slide__text {font-size: 0.96rem;}
      .hero-slide__actions {flex-direction: column;align-items: stretch;}
      .btn {width: 100%;}
      .hero-slider__controls {bottom: 28px;}
      .hero-slider__controls-inner {flex-direction: column;align-items: flex-start;}
    }



/* =========================
   SLIDER OVLÁDÁNÍ
   ========================= */

.hero-slider__controls {position: absolute;inset: 0;z-index: 8;pointer-events: none;}
.hero-slider__controls-inner {position: relative;width: 100%;height: 100%;}
.hero-slider__nav {pointer-events: none;}
.hero-slider__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 64px;
  height: 64px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: 0.25s ease;
  pointer-events: auto;
  font-size: 26px;
  line-height: 1;
}

.hero-slider__arrow--prev {left: 22px;}
.hero-slider__arrow--next {right: 22px;}
.hero-slider__arrow:hover, .hero-slider__arrow:focus-visible {background: rgba(182, 193, 69, 0.22);border-color: rgba(182, 193, 69, 0.7);}
.hero-slider__arrow--prev:hover, .hero-slider__arrow--prev:focus-visible {transform: translateY(-50%) translateX(-2px);}
.hero-slider__arrow--next:hover, .hero-slider__arrow--next:focus-visible {transform: translateY(-50%) translateX(2px);}
.hero-slider__dots {position: absolute;left: 50%;bottom: 34px;transform: translateX(-50%);display: flex;gap: 10px;z-index: 9;pointer-events: auto;}

/* =========================
   TEXTOVÝ BLOK VE SLIDERU
   ========================= */

.hero-slide__box {max-width: 640px;background: transparent;color: #fff;padding: 0;box-shadow: none;border-left: none;}

.hero-slide__panel-bg {width: 100%;max-width: 640px;background: rgba(0, 0, 0, 0.8);border-left: 6px solid #b6c145;box-shadow: 0 18px 40px rgba(0, 0, 0, 0.16);overflow: hidden;
  /* počáteční stav */
  max-height: 1px;padding: 0 38px;opacity: 0;
}

/* skryto před animací */
.hero-slide__eyebrow, .hero-slide__title, .hero-slide__text, .hero-slide__actions {opacity: 0;transform: translateY(18px);}

/* živější zoom */
.hero-slide__image {transform: scale(1);}

/* při aktivním slide se spustí animace */
.hero-slide.is-active .hero-slide__image {animation: heroImageZoom 2.4s ease forwards;}
.hero-slide.is-active .hero-slide__panel-bg {animation: revealPanel 1.25s ease forwards;animation-delay: 2.1s;}
.hero-slide.is-active .hero-slide__eyebrow {animation: revealLine 0.45s ease forwards;animation-delay: 2.8s;}
.hero-slide.is-active .hero-slide__title {animation: revealLine 0.75s ease forwards;animation-delay: 3.0s;}
.hero-slide.is-active .hero-slide__text {animation: revealLine 0.75s ease forwards;animation-delay: 3.25s;}
.hero-slide.is-active .hero-slide__actions {animation: revealLine 0.75s ease forwards;animation-delay: 3.5s;}

@keyframes heroImageZoom {
  0% {transform: scale(1);}
  100% {transform: scale(1.14);}
}
@keyframes revealPanel {
  0% {max-height: 1px;opacity: 0.15;padding-top: 0;padding-bottom: 0;}
  100% {max-height: 420px;opacity: 1;padding-top: 32px;padding-bottom: 32px;}
}
@keyframes revealLine {
  0% {opacity: 0;transform: translateY(18px);}
  100% {opacity: 1;transform: translateY(0);}
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 920px) {
  .hero-slider__arrow {width: 54px;height: 54px;}
  .hero-slider__arrow--prev {left: 12px;}
  .hero-slider__arrow--next {right: 12px;}
  .hero-slide__panel-bg {max-width: 100%;padding-left: 24px;padding-right: 24px;}
}

@media (max-width: 640px) {
  .hero-slider__arrow {width: 48px;height: 48px;border-radius: 8px;font-size: 22px;}
  .hero-slider__arrow--prev {left: 8px;}
  .hero-slider__arrow--next {right: 8px;}
  .hero-slider__dots {bottom: 22px;}
  .hero-slide__panel-bg {padding-left: 20px;padding-right: 20px;}

  @keyframes revealPanel {
    0% {max-height: 1px;opacity: 0.15;padding-top: 0;padding-bottom: 0;}
    100% {max-height: 520px;opacity: 1;padding-top: 24px;padding-bottom: 24px;}
  }
}




/* blok interieru*/

.interior-offer {padding: 110px 0;background: #ffffff;}
.interior-offer__container {width: min(100% - 32px, 1280px);margin: 0 auto;}
.interior-offer__heading {max-width: 760px;margin-bottom: 40px;}
.interior-offer__eyebrow {display: inline-block;margin-bottom: 12px;color: #b6c145;font-size: 0.9rem;letter-spacing: 0.16em;text-transform: uppercase;}
.interior-offer__title {margin: 0 0 16px;font-size: clamp(2rem, 3vw, 3.4rem);line-height: 1.08;font-weight: 600;text-transform: uppercase;color: #4b4a48;}
.interior-offer__text {margin: 0;color: rgba(75, 74, 72, 0.88);line-height: 1.7;}
.interior-offer__grid {display: grid;grid-template-columns: 1fr 1fr;gap: 24px;}
.interior-offer__small-grid {display: grid;grid-template-columns: 1fr 1fr;gap: 24px;}
.interior-card {cursor:pointer;position: relative;overflow: hidden;background: #ddd;min-height: 340px;  border-radius: 4px;opacity: 0;transform: translateY(30px);transition: opacity 0.7s ease, transform 0.7s ease;}
.interior-card--large {min-height: 704px;}
.interior-card__image {width: 100%;height: 100%;object-fit: cover;display: block; transform: scale(1.8);
  transition: transform 0.8s cubic-bezier(.25,.46,.45,.94);}
.interior-card:hover .interior-card__image {transform: scale(1.4);}
.interior-card::after {content: "";position: absolute;inset: 0;background: linear-gradient(180deg,rgba(0, 0, 0, 0.08) 0%,rgba(0, 0, 0, 0.14) 45%,rgba(0, 0, 0, 0.28) 100%);}
.interior-card::after{transition:background 0.5s ease;}

.interior-card:hover::after{
background:linear-gradient(
180deg,
rgba(0,0,0,0.18) 0%,
rgba(0,0,0,0.25) 45%,
rgba(0,0,0,0.4) 100%
);
}

.interior-card__label {position: absolute;left: 18px;right: 18px;bottom: 18px;z-index: 2;background: rgba(0, 0, 0, 0.5);padding: 14px 18px;opacity: 0;transform: translateY(12px);transition: opacity 0.45s ease, transform 0.45s ease;}
.interior-card__title {margin: 0;color: #fff;font-size: clamp(1rem, 1.4vw, 1.3rem);line-height: 1.25;font-weight: 500;text-transform: uppercase;}
.interior-card__title .char {display: inline-block;opacity: 0;transform: translateY(8px);}
.interior-offer.is-active .interior-card.is-visible {opacity: 1;transform: translateY(0);}
.interior-offer.is-active .interior-card.is-visible .interior-card__image {transform: scale(1);}
.interior-offer.is-active .interior-card.is-visible .interior-card__label {opacity: 1;transform: translateY(0);}
.interior-offer.is-active .interior-card.is-visible .interior-card__title .char {animation: interiorCharIn 0.28s ease forwards;}


/* hover zoom pro sekci interior-offer */
.interior-offer .interior-card {
  overflow: hidden;
}

.interior-offer .interior-card .interior-card__image {
  transition: transform 0.7s ease;
  will-change: transform;
}

/* po načtení sekce zůstane základní stav */
.interior-offer.is-active .interior-card.is-visible .interior-card__image {
  transform: scale(1);
}

/* hover musí být specifičtější než základní stav animace */
.interior-offer.is-active .interior-card.is-visible:hover .interior-card__image,
.interior-offer .interior-card:hover .interior-card__image {
  transform: scale(1.08);
}

@keyframes interiorCharIn {
  from {opacity: 0;transform: translateY(8px);}
  to {opacity: 1;transform: translateY(0);}
}

@media (max-width: 1080px) {
  .interior-offer__grid {grid-template-columns: 1fr;}
  .interior-card--large {min-height: 560px;}
}

@media (max-width: 920px) {
  .interior-offer {padding: 84px 0;}
}

@media (max-width: 640px) {
  .interior-offer__container {width: min(100% - 24px, 1280px);}
  .interior-offer__small-grid {grid-template-columns: 1fr;}
  .interior-card--large,.interior-card {min-height: 320px;}
  .interior-card__label {left: 14px;right: 14px;bottom: 14px;padding: 12px 14px;}
}

/*socky */

.sockyWidget{background-color: var(--color-dark);padding:60px 40px 60px 40px;color: white;}
.sockyTitle{text-align: center;display: flex;justify-content: center;align-items: center;padding-bottom:20px;}
.sockyIcons{text-align: left;display: flex; justify-content: center;align-items: center;}
.sockyIconBox{  display: inline-table;  margin: 0px 15px 0px 15px;}
.sockyIconHref{color:rgba(255,255,255,0.85); font-size: 40px;transition: color .5s ease-out;}
.sockyIconHref:hover{color:   rgba(192,205,59,1);}

.sockyIconHref i.h3{ font-size: 40px;}

/*socky animace*/
.sockyWidget {opacity: 0;transform: translateY(40px);transition: opacity 0.8s ease, transform 0.8s ease;}

.sockyWidget.is-visible {opacity: 1;transform: translateY(0);}

/* jednotlivé položky */
.sockyWidget .sockyItem {opacity: 0;transform: translateY(30px);transition: opacity 0.6s ease, transform 0.6s ease;}

/* postupné zobrazení */
.sockyWidget.is-visible .sockyItem:nth-child(1) {transition-delay: 0.15s;}

.sockyWidget.is-visible .sockyItem:nth-child(2) {transition-delay: 0.3s;}
.sockyWidget.is-visible .sockyItem:nth-child(3) {transition-delay: 0.45s;}
.sockyWidget.is-visible .sockyItem:nth-child(4) {transition-delay: 0.6s;}
.sockyWidget.is-visible .sockyItem {opacity: 1;transform: translateY(0);}

/* footer*/
/* =========================
   FOOTER
========================= */

.footer-top{background:#4b4a48;padding:60px 0;color:#ffffff;}
.footer-top .footer-container{max-width:1280px;margin:0 auto;padding:0 20px;margin-bottom:20px;

display:flex;gap:40px;justify-content:space-between;}

.footer-top .footer-col{flex:1;}
.footer-top h4{margin-bottom:20px;font-size:18px;font-weight:600;color:#b6c145;}
.footer-top p, .footer-top a{font-size:14px;color:#ffffff;text-decoration:none;line-height:1.6;}
.footer-top a:hover{color:#b6c145;}

.footerText{margin-bottom:25px;}

.social-icons222  {display: flex;}
.social-icons222 a i {font-size:26px;}

.sockyIconHrefFooter{
  color: #efefef;
    width: 40px;
    height: 40px;
    line-height: 40px;
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
    border-radius: 4px;
    margin-right: 5px;
    margin-bottom: 5px;
    background: var(--color-primary-light);
   
}
.sockyIconHrefFooter:hover {
    background: var(--color-primary-dark);
    color: #f1f1f1;
}
.sockyIconHrefFooter:hover i{
    color: #ffffff;
}

.footer_s_inner{margin-bottom:10px;}



/* =========================
   FOOTER BOTTOM
========================= */

.footer-bottom{background:#4b4a48;border-top:1px solid rgba(255,255,255,0.1);padding:18px 0;color:#ffffff;font-size:14px;}

.footer-bottom .footer-container{
max-width:1280px;
margin:0 auto;
padding:0 20px;

display:flex;justify-content:space-between;align-items:center;}

.footer-bottom-left{text-align:left;}

.footer-bottom-right{text-align:right;}


/* =========================
   RESPONSIVE
========================= */

@media (max-width:900px){

.footer-top .footer-container{flex-direction:column;gap:30px;}
.footer-bottom .footer-container{flex-direction:column;gap:10px;text-align:center;}
.footer-bottom-right{text-align:center;}

}

/*pocitadla */
.stats-section {padding: 90px 0;background: #ffffff;}
.stats-section__container {width: min(100% - 32px, 1280px);margin: 0 auto;}
.stats-grid {display: grid;grid-template-columns: repeat(3, minmax(0, 1fr));gap: 24px;}
.stats-card {background: #4b4a48;color: #ffffff;padding: 42px 28px;text-align: center;border-radius: 8px;box-shadow: 0 16px 34px rgba(0, 0, 0, 0.12);transition: transform 0.35s ease, box-shadow 0.35s ease;}
.stats-card:hover {transform: translateY(-4px);box-shadow: 0 22px 42px rgba(0, 0, 0, 0.16);}
.stats-card__icon {display: flex;align-items: center;justify-content: center;min-height: 72px;margin-bottom: 18px;}
.stats-card__icon i {font-size:60px;border:2px solid var(--color-white);padding:20px;border-radius: 50%;}
.stats-card__number {margin-bottom: 12px;font-size: clamp(2.2rem, 4vw, 3.6rem);line-height: 1;font-weight: 600;color: #b6c145;}
.stats-card__label {font-size: 1.35rem;line-height: 1.5;text-transform: uppercase;letter-spacing: 0.04em;color: #ffffff;font-weight: 500;}

@media (max-width: 920px) {
  .stats-grid {grid-template-columns: 1fr;}
  .stats-card {padding: 34px 22px;}
}

/* řekli o nás*/
.reviews-section {padding: 100px 0;background: #ffffff;}
.reviews-section__container {width: min(100% - 32px, 1280px);margin: 0 auto;}
.reviews-section__heading {margin-bottom: 36px;text-align: center;}
.reviews-section__eyebrow {display: inline-block;margin-bottom: 12px;color: #b6c145;font-size: 0.9rem;letter-spacing: 0.16em;text-transform: uppercase;}
.reviews-section__title {margin: 0;font-size: clamp(2rem, 3vw, 3.2rem);line-height: 1.08;font-weight: 800;text-transform: uppercase;color: #4b4a48;}
.reviews-carousel {position: relative;display: flex;align-items: center;gap: 20px;}
.reviews-carousel__viewport {overflow: hidden;width: 100%;}
.reviews-carousel__track {display: flex;transition: transform 0.6s ease;will-change: transform;}

.review-card{
flex:0 0 calc((100% - 48px) / 3);
margin-right:24px;
background:#4b4a48;
color:#ffffff;
min-height:240px;
padding:34px 28px;
display:flex;
flex-direction:column;
justify-content:flex-start;
border-radius:8px;
box-shadow:0 16px 34px rgba(0,0,0,0.12);
}


.review-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.review-card__name{margin:0;font-size:1.2rem;font-weight:700;color:#b6c145;text-transform:uppercase;}
.review-card__year{font-size:0.9rem;opacity:0.8;}

.review-card:last-child {margin-right: 0;}
.review-card__name {margin: 0 0 14px;font-size: 1.35rem;line-height: 1.2;font-weight: 700;color: #b6c145;text-transform: uppercase;}
.review-card__city {margin: 0;font-size: 1rem;line-height: 1.5;color: #ffffff;opacity: 0.9;}
.review-card__city{margin:0 0 14px 0;font-size:0.9rem;opacity:0.9;}
.review-card__text{margin:0;font-size:0.95rem;line-height:1.6;opacity:0.9;}

.reviews-carousel__arrow {
  flex: 0 0 auto;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(75, 74, 72, 0.16);
  background: #4b4a48;
  color: #ffffff;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease;
}

.reviews-carousel__arrow:hover,.reviews-carousel__arrow:focus-visible {background: #b6c145;color: #4b4a48;border-color: #b6c145;transform: translateY(-2px);}

.review-card{transition:transform .35s ease, box-shadow .35s ease;}
.review-card:hover{box-shadow:0 24px 48px rgba(0,0,0,0.18);}

@media (max-width: 920px) {
  .review-card {flex: 0 0 calc((100% - 24px) / 2);}
}

@media (max-width: 640px) {
  .reviews-section {padding: 80px 0;}
  .reviews-section__container {width: min(100% - 24px, 1280px);}
  .reviews-carousel {gap: 12px;}
  .review-card {flex: 0 0 100%;margin-right: 16px;min-height: 190px;padding: 28px 22px;}
  .reviews-carousel__arrow {width: 48px;height: 48px;border-radius: 8px;font-size: 20px;}
}


/* proces */

.process-section {
  padding: 110px 0;
  background: #ffffff;
  overflow: hidden;
}

.process-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.process-section__heading {
  max-width: 820px;
  margin: 0 auto 56px;
  text-align: center;
}

.process-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.process-section__title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3.2vw, 3.5rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
  color: #4b4a48;
}

.process-section__text {
  margin: 0 auto;
  max-width: 64ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.7;
}

.process-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 24px;
}

.process-timeline__line {
  position: absolute;
  top: 54px;
  left: 6%;
  right: 6%;
  height: 2px;
  background: linear-gradient(
    90deg,
    rgba(182, 193, 69, 0.15) 0%,
    rgba(182, 193, 69, 0.9) 50%,
    rgba(182, 193, 69, 0.15) 100%
  );
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 1s ease;
  z-index: 0;
}

.process-section.is-visible .process-timeline__line {
  transform: scaleX(1);
}

.process-step {position: relative;z-index: 1;opacity: 0;transform: translateY(40px);transition: opacity 0.65s ease, transform 0.65s ease;}
.process-step.is-visible {opacity: 1;transform: translateY(0);}
.process-step__number {font-size: 0.95rem;letter-spacing: 0.14em;text-transform: uppercase;color: #b6c145;margin-bottom: 16px;text-align: center;}
.process-step__icon {
  width: 108px;
  height: 108px!important;
  min-height: 108px!important;
  margin: 0 auto 24px;
  border-radius: 18px;
  background: #4b4a48;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.12);
  transform: scale(0.9);
  transition: transform 0.5s ease;
}

.process-step.is-visible .process-step__icon {transform: scale(1);}
.process-step__icon i {font-size: 52px;color:var(--color-white);}
.process-step__icon img {max-width: 52px;max-height: 52px;width: auto;height: auto;display: block;}

.process-step__content{background:#ffffff;border:1px solid rgba(75,74,72,0.08);box-shadow:0 14px 30px rgba(0,0,0,0.06);padding:28px 22px;display:flex;flex-direction:column;height:100%;}
.process-step{display:flex;flex-direction:column;}
.process-step__title {margin: 0 0 14px;font-size: 1.15rem;line-height: 1.25;font-weight: 700;text-transform: uppercase;color: #4b4a48;margin-bottom:14px;}
.process-step__desc {margin: 0;color: rgba(75, 74, 72, 0.88);line-height: 1.7;font-size: 0.96rem;flex-grow:1;}
.process-step__title, .process-step__desc {opacity: 0;transform: translateY(16px);transition: opacity 0.5s ease, transform 0.5s ease;}
.process-step.is-visible .process-step__title,.process-step.is-visible .process-step__desc {opacity: 1;transform: translateY(0);}
.process-step.is-visible .process-step__title {transition-delay: 0.18s;}
.process-step.is-visible .process-step__desc {transition-delay: 0.3s;}

@media (max-width: 1180px) {
  .process-timeline {grid-template-columns: repeat(3, minmax(0, 1fr));}
  .process-timeline__line {display: none;}
}

@media (max-width: 820px) {
  .process-section {padding: 84px 0;}
  .process-timeline {grid-template-columns: 1fr;gap: 20px;}
  .process-step {display: grid;grid-template-columns: 88px 1fr;gap: 18px;align-items: start;}
  .process-step__number {grid-column: 1 / -1;text-align: left;margin-bottom: 0;}

  .process-step__icon {width: 88px;height: 88px;margin: 0;border-radius: 14px;}
  .process-step__icon i {font-size: 42px;color:var(--color-white);}
  .process-step__icon img {max-width: 42px;max-height: 42px;}

  .process-step__content {min-height: auto;padding: 22px 18px;}
}

@media (max-width: 640px) {
  .process-section__container {
    width: min(100% - 24px, 1280px);
  }

  .process-step {
    grid-template-columns: 1fr;
  }

  .process-step__number {
    margin-bottom: 6px;
  }

  .process-step__icon {
    margin-bottom: 8px;
  }
}

/* ddoplnkove interiery*/

.references-showcase {
  padding: 110px 0;
  background: #ffffff;
}

.references-showcase__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.references-showcase__heading {
  max-width: 760px;
  margin-bottom: 42px;
}

.references-showcase__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.references-showcase__title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3.2vw, 3.4rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
  color: #4b4a48;
}

.references-showcase__text {
  margin: 0;
  max-width: 60ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.7;
}

.references-showcase__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
}

.references-showcase__photos {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, 1fr);
  gap: 24px;
  min-height: 700px;
}

.reference-tile {
  position: relative;
  overflow: hidden;
  min-height: 338px;
  background: #ececec;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reference-tile__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.08);
  transition: transform 1.15s ease;
}

.reference-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.08) 0%,
    rgba(0, 0, 0, 0.15) 45%,
    rgba(0, 0, 0, 0.28) 100%
  );
  pointer-events: none;
}

.reference-tile__label {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  background: rgba(0, 0, 0, 0.5);
  padding: 14px 18px;
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 0.45s ease, transform 0.45s ease;
}

.reference-tile__title {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1rem, 1.5vw, 1.35rem);
  line-height: 1.25;
  font-weight: 700;
  text-transform: uppercase;
  min-height: 1.25em;
}

.reference-tile__title .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(10px);
}

.references-panel {
  background: #f3f3f1;
  min-height: 700px;
  padding: 42px 38px;
  display: flex;
  align-items: center;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}

.references-panel__inner {
  width: 100%;
}

.references-panel__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.references-panel__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(1.8rem, 2.4vw, 2.9rem);
  line-height: 1.1;
  font-weight: 800;
  text-transform: uppercase;
}

.references-panel__text {
  margin: 0 0 28px;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
  max-width: 48ch;
}

.references-links {
  display: grid;
  gap: 14px;
}

.references-link {
  display: block;
  padding: 18px 20px;
  background: #ffffff;
  border: 1px solid rgba(75, 74, 72, 0.08);
  color: #4b4a48;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

.references-link:hover,
.references-link:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.08);
  border-color: rgba(182, 193, 69, 0.45);
}

.references-link__title {
  display: block;
  margin-bottom: 6px;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.3;
}

.references-link__meta {
  display: block;
  color: rgba(75, 74, 72, 0.72);
  font-size: 0.92rem;
}

.references-panel__eyebrow,
.references-panel__title,
.references-panel__text,
.references-link {
  opacity: 0;
  transform: translateY(16px);
}

.references-panel__eyebrow .char,
.references-panel__title .char,
.references-panel__text .char,
.references-link .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(10px);
}

.references-showcase.is-visible .reference-tile.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.references-showcase.is-visible .reference-tile.is-visible .reference-tile__image {
  transform: scale(1);
}

.references-showcase.is-visible .reference-tile.is-visible .reference-tile__label {
  opacity: 1;
  transform: translateY(0);
}
/*
.references-showcase.is-visible .reference-tile.is-visible .reference-tile__title .char {
  animation: referencesCharIn 0.28s ease forwards;
}
*/
.references-showcase.is-visible .reference-tile.is-visible .reference-tile__title .char {
  opacity: 1;
  transform: translateY(0);
}

.references-showcase.is-visible .references-panel.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.references-showcase.is-visible .references-panel.is-visible .references-panel__eyebrow,
.references-showcase.is-visible .references-panel.is-visible .references-panel__title,
.references-showcase.is-visible .references-panel.is-visible .references-panel__text,
.references-showcase.is-visible .references-panel.is-visible .references-link {
  opacity: 1;
  transform: translateY(0);
}

.references-showcase.is-visible .references-panel.is-visible .char {
  animation: referencesCharIn 0.28s ease forwards;
}

@keyframes referencesCharIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.reference-tile:hover .reference-tile__image {
  transform: scale(1.08);
}

@media (max-width: 1080px) {
  .references-showcase__grid {
    grid-template-columns: 1fr;
  }

  .references-panel,
  .references-showcase__photos {
    min-height: 560px;
  }
}

@media (max-width: 920px) {
  .references-showcase {
    padding: 84px 0;
  }

  .references-showcase__photos,
  .references-panel {
    min-height: auto;
  }

  .references-panel {
    padding: 34px 28px;
  }
}

@media (max-width: 640px) {
  .references-showcase__container {
    width: min(100% - 24px, 1280px);
  }

  .references-showcase__photos {
    grid-template-columns: 1fr;
  }

  .reference-tile {
    min-height: 320px;
  }

  .reference-tile__label {
    left: 14px;
    right: 14px;
    bottom: 14px;
    padding: 12px 14px;
  }

  .references-panel {
    padding: 26px 20px;
  }

  .references-panel__title {
    font-size: clamp(1.5rem, 8vw, 2.2rem);
  }
}


/*dva interierz*/

.dual-reference-section {
  padding: 110px 0;
  background: #ffffff;
}

.dual-reference-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.dual-reference-section__heading {
 /* max-width: 760px;*/
  margin-bottom: 42px;
}

.dual-reference-section__eyebrow {
  display: block;
  margin-bottom: 24px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-align: center;
}

.dual-reference-section__title {
  margin: 0 0 18px;
  font-size: clamp(2rem, 3.2vw, 3.4rem);
  line-height: 1.08;
  font-weight: 600;
  text-transform: uppercase;
  color: #4b4a48;
  text-align: center;
}

.dual-reference-section__text {
  margin: 0 auto 20px auto;
  max-width: 60ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.7;
  text-align: center;
}

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

.dual-reference-card {
  position: relative;
  overflow: hidden;
  min-height: 620px;
  background: #e9e9e9;
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}

.dual-reference-card__link {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.dual-reference-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.06);
  transition: transform 0.9s ease;
}

.dual-reference-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.08) 0%,
    rgba(0, 0, 0, 0.18) 42%,
    rgba(0, 0, 0, 0.48) 100%
  );
  pointer-events: none;
  transition: background 0.45s ease;
}

.dual-reference-card__overlay {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 28px;
  z-index: 2;
  background: rgba(0, 0, 0, 0.5);
  padding: 24px 24px 22px;
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease, background 0.35s ease;
}

.dual-reference-card__eyebrow,
.dual-reference-card__title,
.dual-reference-card__text,
.dual-reference-card__cta {
  opacity: 0;
  transform: translateY(12px);
}

.dual-reference-card__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.dual-reference-card__title {
  margin: 0 0 14px;
  color: #ffffff;
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.12;
  font-weight: 600;
  text-transform: uppercase;
}

.dual-reference-card__text {
  margin: 0 0 18px;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.7;
  max-width: 48ch;
}

.dual-reference-card__cta {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 18px;
  border: 1px solid rgba(182, 193, 69, 0.5);
  color: #ffffff;
  font-size: 0.86rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(182, 193, 69, 0.14);
}

.dual-reference-card__title .char,
.dual-reference-card__text .char,
.dual-reference-card__eyebrow .char,
.dual-reference-card__cta .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(10px);
}
.dual-reference-section.is-visible .dual-reference-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__overlay {
  opacity: 1;
  transform: translateY(0);
}

.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__eyebrow,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__title,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__text,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__cta {
  opacity: 1;
  transform: translateY(0);
}

.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__title .char,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__text .char,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__eyebrow .char,
.dual-reference-section.is-visible .dual-reference-card.is-visible .dual-reference-card__cta .char {
  animation: dualReferenceCharIn 0.28s ease forwards;
}

@keyframes dualReferenceCharIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* hover efekt */
.dual-reference-card:hover .dual-reference-card__image {
  transform: scale(1.12);
}

.dual-reference-card:hover::after {
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.12) 0%,
    rgba(0, 0, 0, 0.22) 42%,
    rgba(0, 0, 0, 0.58) 100%
  );
}

.dual-reference-card:hover .dual-reference-card__overlay {
  background: rgba(0, 0, 0, 0.62);
}

.dual-reference-card:hover .dual-reference-card__cta {
  background: rgba(182, 193, 69, 0.24);
  border-color: rgba(182, 193, 69, 0.85);
}

@media (max-width: 920px) {
  .dual-reference-section {
    padding: 84px 0;
  }

  .dual-reference-grid {
    grid-template-columns: 1fr;
  }

  .dual-reference-card {
    min-height: 500px;
  }
}

@media (max-width: 640px) {
  .dual-reference-section__container {
    width: min(100% - 24px, 1280px);
  }

  .dual-reference-card {
    min-height: 380px;
  }

  .dual-reference-card__overlay {
    left: 16px;
    right: 16px;
    bottom: 16px;
    padding: 18px 16px 16px;
  }

  .dual-reference-card__title {
    font-size: clamp(1.2rem, 7vw, 1.6rem);
  }

  .dual-reference-card__text {
    font-size: 0.95rem;
  }
}

/* podstránky kategorii*/

/* ===== PODSTRÁNKA: ZAKÁZKOVÉ KUCHYNĚ – FUNKČNÍ ANIMACE ===== */

/* HERO */
.subpage-hero {position: relative;min-height: 58vh;display: flex;align-items: flex-end;overflow: hidden;background: #4b4a48;}

.subpage-hero__media,.subpage-hero__image,.subpage-hero__overlay {position: absolute;inset: 0;}
.subpage-hero__image {width: 100%;height: 100%;object-fit: cover;}
.subpage-hero__overlay {background: linear-gradient(180deg, rgba(0, 0, 0, 0.18) 0%, rgba(0, 0, 0, 0.48) 100%);}
.subpage-hero__content {  position: relative;z-index: 2;width: 100%;padding: 180px 0 70px;}
.subpage-hero__container,.kitchen-detail-section__container,.kitchen-cta-section__container,.kitchen-gallery-section__container {width: min(100% - 32px, 1280px);margin: 0 auto;}
.subpage-hero__box {display: inline-block;background: rgba(0, 0, 0, 0.62);padding: 28px 34px;border-left: 6px solid #b6c145;}
.subpage-hero__eyebrow {display: inline-block;margin-bottom: 12px;color: #b6c145;font-size: 0.88rem;letter-spacing: 0.16em;text-transform: uppercase;}
.subpage-hero__title {margin: 0;color: #ffffff;font-size: clamp(2.2rem, 4vw, 4.2rem);line-height: 1.05;font-weight: 800;text-transform: uppercase;}

/* DETAIL */
.kitchen-detail-section {padding: 100px 0;background: #ffffff;}
.kitchen-detail-section__grid {display: grid;grid-template-columns: 1fr 1fr;gap: 28px;align-items: stretch;}
.kitchen-detail-section__text {background: #f5f5f3;padding: 42px 38px;display: flex;flex-direction: column;justify-content: center;}
.kitchen-detail-section__eyebrow {display: inline-block;margin-bottom: 14px;color: #b6c145;font-size: 0.88rem;letter-spacing: 0.16em;text-transform: uppercase;}
.kitchen-detail-section__title {margin: 0 0 18px;color: #4b4a48;font-size: clamp(1.8rem, 2.8vw, 3rem);line-height: 1.08;font-weight: 800;text-transform: uppercase;}
.kitchen-detail-section__desc {margin: 0 0 16px;color: rgba(75, 74, 72, 0.88);line-height: 1.75;}
.kitchen-detail-section__desc:last-child {margin-bottom: 0;}
.kitchen-detail-section__photo {overflow: hidden;min-height: 560px;}
.kitchen-detail-section__photo img {width: 100%;height: 100%;object-fit: cover;display: block;}

/* CTA */
.kitchen-cta-section {padding: 0 0 90px;background: #ffffff;}
.kitchen-cta-section__box {background: #4b4a48;color: #ffffff;padding: 34px 38px;display: flex;justify-content: space-between;align-items: center;gap: 28px;}
.kitchen-cta-section__eyebrow {display: inline-block;margin-bottom: 10px;color: #b6c145;font-size: 0.85rem;letter-spacing: 0.16em;text-transform: uppercase;}
.kitchen-cta-section__title {margin: 0 0 12px;font-size: clamp(1.5rem, 2.4vw, 2.4rem);line-height: 1.08;font-weight: 800;text-transform: uppercase;}
.kitchen-cta-section__text {margin: 0;color: rgba(255, 255, 255, 0.9);line-height: 1.7;}
.kitchen-cta-section__button {display: inline-flex;align-items: center;justify-content: center;min-height: 54px;padding: 0 24px;background: #b6c145;color: #4b4a48;text-decoration: none;text-transform: uppercase;letter-spacing: 0.06em;transition: transform 0.25s ease, opacity 0.25s ease;}

.kitchen-cta-section__button:hover {transform: translateY(-2px);}

/* GALERIE */
.kitchen-gallery-section {padding: 0 0 110px;background: #ffffff;}
.kitchen-gallery-section__heading {max-width: 760px;margin-bottom: 38px;}
.kitchen-gallery-section__eyebrow {display: inline-block;margin-bottom: 12px;color: #b6c145;font-size: 0.88rem;letter-spacing: 0.16em;text-transform: uppercase;}
.kitchen-gallery-section__title {margin: 0 0 16px;color: #4b4a48;font-size: clamp(1.8rem, 2.8vw, 3rem);line-height: 1.08;font-weight: 800;text-transform: uppercase;}
.kitchen-gallery-section__text {margin: 0;color: rgba(75, 74, 72, 0.88);line-height: 1.7;}
.kitchen-gallery-grid {display: grid;grid-template-columns: repeat(3, minmax(0, 1fr));gap: 24px;}
.kitchen-gallery-item {position: relative;display: block;min-height: 320px;max-height: 400px;overflow: hidden;text-decoration: none;}
.kitchen-gallery-item img {width: 100%;height: 100%;object-fit: cover;display: block;transform: scale(1.05);transition: transform 0.75s ease;}
/*.kitchen-gallery-item::after {content: "";position: absolute;inset: 0;background: linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.38) 100%);transition: background 0.3s ease;}*/
.kitchen-gallery-item__caption {position: absolute;left: 18px;right: 18px;bottom: 18px;z-index: 2;background: rgba(0,0,0,0.55);color: #ffffff;padding: 12px 16px;text-transform: uppercase;letter-spacing: 0.05em;}
.kitchen-gallery-item:hover img {transform: scale(1.11);}
.kitchen-gallery-item:hover::after {background: linear-gradient(180deg, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.52) 100%);}

/* ANIMAČNÍ STAVY */
.kitchen-detail-section__text.is-armed,
.kitchen-detail-section__photo.is-armed,
.kitchen-cta-section__box.is-armed,
.kitchen-gallery-item.is-armed {
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 0.75s ease, transform 0.75s ease;
  will-change: opacity, transform;
}

.kitchen-detail-section__text.is-armed.is-visible,
.kitchen-detail-section__photo.is-armed.is-visible,
.kitchen-cta-section__box.is-armed.is-visible,
.kitchen-gallery-item.is-armed.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* RESPONSIVE */
@media (max-width: 980px) {
  .kitchen-detail-section__grid,
  .kitchen-gallery-grid {
    grid-template-columns: 1fr;
  }

  .kitchen-detail-section__photo {
    min-height: 420px;
  }

  .kitchen-cta-section__box {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 640px) {
  .subpage-hero__content {
    padding: 150px 0 48px;
  }

  .subpage-hero__container,
  .kitchen-detail-section__container,
  .kitchen-cta-section__container,
  .kitchen-gallery-section__container {
    width: min(100% - 24px, 1280px);
  }

  .subpage-hero__box,
  .kitchen-detail-section__text,
  .kitchen-cta-section__box {
    padding: 24px 20px;
  }

  .kitchen-gallery-item {
    min-height: 260px;
  }
}

.kitchen-trust-section {
  padding: 110px 0;
  background: #ffffff;
  overflow: hidden;
}

.kitchen-trust-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.kitchen-trust-section__heading {
  max-width: 840px;
  margin: 0 auto 44px;
  text-align: center;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.kitchen-trust-section.is-visible .kitchen-trust-section__heading {
  opacity: 1;
  transform: translateY(0);
}

.kitchen-trust-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.kitchen-trust-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.kitchen-trust-section__text {
  margin: 0 auto;
  max-width: 68ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.8;
}

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

.kitchen-trust-card {
  background: #f5f5f3;
  border-left: 4px solid #b6c145;
  padding: 30px 26px;
  min-height: 250px;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.7s ease, transform 0.7s ease, box-shadow 0.3s ease, transform 0.3s ease;
}

.kitchen-trust-section.is-visible .kitchen-trust-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.kitchen-trust-card:hover {
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.08);
}

.kitchen-trust-card__number {
  margin-bottom: 16px;
  color: #b6c145;
  font-size: 0.95rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}

.kitchen-trust-card__title {
  margin: 0 0 14px;
  color: #4b4a48;
  font-size: 1.2rem;
  line-height: 1.25;
  font-weight: 700;
  text-transform: uppercase;
}

.kitchen-trust-card__desc {
  margin: 0;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
  font-size: 0.96rem;
}

@media (max-width: 980px) {
  .kitchen-trust-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .kitchen-trust-section {
    padding: 84px 0;
  }

  .kitchen-trust-section__container {
    width: min(100% - 24px, 1280px);
  }

  .kitchen-trust-grid {
    grid-template-columns: 1fr;
  }

  .kitchen-trust-card {
    min-height: auto;
    padding: 24px 20px;
  }

  .kitchen-trust-section__title {
    font-size: clamp(1.6rem, 8vw, 2.3rem);
  }
}




/*poptavkovy formular*/

.contact-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.42);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 1200;
}

.contact-drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.contact-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(92vw, 560px);
  height: 100vh;
  background: #ffffff;
  box-shadow: -18px 0 42px rgba(0, 0, 0, 0.18);
  transform: translateX(100%);
  transition: transform 0.38s ease;
  z-index: 1201;
  display: flex;
  flex-direction: column;
}

.contact-drawer.is-open {
  transform: translateX(0);
}

.contact-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 20px 16px;
  border-bottom: 1px solid rgba(75, 74, 72, 0.12);
}

.contact-drawer__tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.contact-drawer__tab {
  min-height: 42px;
  padding: 0 16px;
  border: 1px solid rgba(75, 74, 72, 0.15);
  background: #f5f5f3;
  color: #4b4a48;
  font: inherit;
  cursor: pointer;
  transition: 0.25s ease;
}

.contact-drawer__tab.is-active {
  background: #b6c145;
  color: #4b4a48;
  border-color: #b6c145;
}

.contact-drawer__close {width: 44px;height: 44px;border: 1px solid rgba(75, 74, 72, 0.15);background: #ffffff;color: #4b4a48;font-size: 28px;line-height: 1;cursor: pointer;transition: 0.25s ease;}
.contact-drawer__close:hover {background: #f5f5f3;}
.contact-drawer__body {flex: 1;overflow-y: auto;padding: 24px 20px 28px;}
.contact-drawer__panel {display: none;}
.contact-drawer__panel.is-active {display: block;}
.contact-drawer__title {margin: 0 0 10px;color: #4b4a48;font-size: clamp(1.5rem, 2vw, 2rem);line-height: 1.1;font-weight: 800;text-transform: uppercase;}
.contact-drawer__intro {margin: 0 0 24px;color: rgba(75, 74, 72, 0.82);line-height: 1.7;}
.contact-form__grid {display: grid;grid-template-columns: 1fr 1fr;gap: 16px;}
.contact-form__field {display: flex;flex-direction: column;gap: 8px;margin-bottom: 16px;}
.contact-form__field label {color: #4b4a48;font-size: 0.94rem;font-weight: 600;}
.contact-form__field input,.contact-form__field textarea {width: 100%;border: 1px solid rgba(75, 74, 72, 0.18);background: #ffffff;color: #4b4a48;font: inherit;padding: 14px 14px;outline: none;transition: border-color 0.25s ease, box-shadow 0.25s ease;}
.contact-form__field input:focus,.contact-form__field textarea:focus {border-color: #b6c145;box-shadow: 0 0 0 3px rgba(182, 193, 69, 0.15);}
.contact-form__field input[type="file"] {padding: 10px 0;border: none;box-shadow: none;}
.contact-form__consent {display: grid;grid-template-columns: 20px 1fr;gap: 12px;align-items: start;margin: 8px 0 22px;color: rgba(75, 74, 72, 0.86);line-height: 1.5;cursor: pointer;}
.contact-form__consent input {margin-top: 3px;}
.contact-form__submit {min-height: 54px;padding: 0 24px;border: none;background: #b6c145;color: #4b4a48;font: inherit;font-weight: 700;text-transform: uppercase;letter-spacing: 0.05em;cursor: pointer;transition: transform 0.25s ease, opacity 0.25s ease;}
.contact-form__submit:hover {transform: translateY(-2px);}

body.contact-drawer-open {overflow: hidden;}

@media (max-width: 640px) {
  .contact-drawer {width: 100vw;}
  .contact-drawer__header {align-items: flex-start;flex-direction: column;}
  .contact-drawer__close {align-self: flex-end;margin-top: -52px;}
  .contact-form__grid {grid-template-columns: 1fr;}
  .contact-drawer__body {padding: 20px 16px 24px;}
}
/*poptavkovy formular*/

/* mini light box*/
.gallery-lightbox {
  position: fixed;
  inset: 0;
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.gallery-lightbox.is-open {
  opacity: 1;
  visibility: visible;
}

.gallery-lightbox__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.82);
}

.gallery-lightbox__dialog {
  position: relative;
  z-index: 2;
  width: min(100% - 32px, 1320px);
  height: 100vh;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) 72px;
  align-items: center;
  gap: 18px;
}

.gallery-lightbox__content {
  position: relative;
  text-align: center;
}

.gallery-lightbox__image {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 80vh;
  margin: 0 auto;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
  background: #ffffff;
}

.gallery-lightbox__caption {
  margin-top: 16px;
  color: #ffffff;
  font-size: 0.95rem;
  line-height: 1.5;
  text-align: center;
}

.gallery-lightbox__close {
  position: absolute;
  top: 24px;
  right: 0;
  width: 52px;
  height: 52px;
  border: none;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-size: 30px;
  line-height: 1;
  cursor: pointer;
  z-index: 3;
  transition: background 0.25s ease, transform 0.25s ease;
}

.gallery-lightbox__close:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
}

.gallery-lightbox__arrow {
  width: 64px;
  height: 64px;
  border: none;
  background: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  transition: background 0.25s ease, transform 0.25s ease;
}

.gallery-lightbox__arrow:hover {
  background: rgba(182, 193, 69, 0.28);
  transform: translateY(-1px);
}

body.gallery-lightbox-open {
  overflow: hidden;
}

@media (max-width: 768px) {
  .gallery-lightbox__dialog {
    width: min(100% - 20px, 1320px);
    grid-template-columns: 48px minmax(0, 1fr) 48px;
    gap: 10px;
  }

  .gallery-lightbox__arrow {
    width: 44px;
    height: 44px;
    font-size: 20px;
  }

  .gallery-lightbox__close {
    top: 14px;
    right: 0;
    width: 44px;
    height: 44px;
    font-size: 26px;
  }

  .gallery-lightbox__image {
    max-height: 72vh;
  }

  .gallery-lightbox__caption {
    margin-top: 12px;
    font-size: 0.9rem;
  }
}

/*KOntakty*/

.contact-page-hero {
  position: relative;
  min-height: 52vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: #4b4a48;
}

.contact-page-hero__media,
.contact-page-hero__image,
.contact-page-hero__overlay {
  position: absolute;
  inset: 0;
}

.contact-page-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.contact-page-hero__overlay {
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.18) 0%, rgba(0, 0, 0, 0.5) 100%);
}

.contact-page-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 180px 0 60px;
}

.contact-page-hero__container,
.contact-page-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.contact-page-hero__box {
  display: inline-block;
  background: rgba(0, 0, 0, 0.62);
  padding: 28px 34px;
  border-left: 6px solid #b6c145;
}

.contact-page-hero__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.contact-page-hero__title {
  margin: 0;
  color: #ffffff;
  font-size: clamp(2.2rem, 4vw, 4rem);
  line-height: 1.05;
  font-weight: 800;
  text-transform: uppercase;
}

.contact-page-section {
  padding: 100px 0 110px;
  background: #ffffff;
}

.contact-page-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(320px, 0.8fr);
  gap: 28px;
  align-items: start;
}

.contact-page-main {
  display: grid;
  gap: 28px;
}

.contact-card {
  background: #f5f5f3;
  padding: 36px 34px;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.contact-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.contact-card__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.85rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.contact-card__title {
  margin: 0 0 14px;
  color: #4b4a48;
  font-size: clamp(1.6rem, 2.5vw, 2.5rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.contact-card__text {
  margin: 0 0 24px;
  color: rgba(75, 74, 72, 0.86);
  line-height: 1.75;
}

.contact-page-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.contact-page-form__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.contact-page-form__field label {
  color: #4b4a48;
  font-size: 0.94rem;
  font-weight: 600;
}

.contact-page-form__field input,
.contact-page-form__field textarea {
  width: 100%;
  padding: 14px 14px;
  border: 1px solid rgba(75, 74, 72, 0.16);
  background: #ffffff;
  color: #4b4a48;
  font: inherit;
  outline: none;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}

.contact-page-form__field input:focus,
.contact-page-form__field textarea:focus {
  border-color: #b6c145;
  box-shadow: 0 0 0 3px rgba(182, 193, 69, 0.15);
}

.contact-page-form__consent {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 12px;
  align-items: start;
  margin: 6px 0 22px;
  color: rgba(75, 74, 72, 0.86);
  line-height: 1.5;
  cursor: pointer;
}

.contact-page-form__consent input {
  margin-top: 3px;
}

.contact-page-form__submit {
  min-height: 54px;
  padding: 0 24px;
  border: none;
  background: #b6c145;
  color: #4b4a48;
  font: inherit;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.contact-page-form__submit:hover {
  transform: translateY(-2px);
}

.contact-map {
  min-height: 420px;
  overflow: hidden;
}

.contact-map iframe {
  display: block;
  width: 100%;
  min-height: 420px;
}

.contact-info-list {
  display: grid;
  gap: 24px;
}

.contact-info-item__title {
  margin: 0 0 8px;
  color: #4b4a48;
  font-size: 1rem;
  line-height: 1.3;
  font-weight: 700;
  text-transform: uppercase;
}

.contact-info-item__text {
  margin: 0;
  color: rgba(75, 74, 72, 0.86);
  line-height: 1.75;
}

.contact-info-item__text a {
  color: #4b4a48;
  text-decoration: none;
}

.contact-info-item__text a:hover {
  color: #b6c145;
}

@media (max-width: 980px) {
  .contact-page-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .contact-page-hero__content {
    padding: 150px 0 48px;
  }

  .contact-page-hero__container,
  .contact-page-section__container {
    width: min(100% - 24px, 1280px);
  }

  .contact-page-hero__box,
  .contact-card {
    padding: 24px 20px;
  }

  .contact-page-form__grid {
    grid-template-columns: 1fr;
  }

  .contact-map,
  .contact-map iframe {
    min-height: 320px;
  }
}


/* vizualizace*/
.viz-page-hero {
  position: relative;
  min-height: 58vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: #4b4a48;
}

.viz-page-hero__media,
.viz-page-hero__image,
.viz-page-hero__overlay {
  position: absolute;
  inset: 0;
}

.viz-page-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.viz-page-hero__overlay {
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.48) 100%);
}

.viz-page-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 180px 0 70px;
}

.viz-page-hero__container,
.viz-info-section__container,
.viz-benefits-section__container,
.viz-gallery-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.viz-page-hero__box {
  display: inline-block;
  background: rgba(0, 0, 0, 0.62);
  padding: 28px 34px;
  border-left: 6px solid #b6c145;
}

.viz-page-hero__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.viz-page-hero__title {
  margin: 0;
  color: #ffffff;
  font-size: clamp(2.2rem, 4vw, 4.2rem);
  line-height: 1.05;
  font-weight: 800;
  text-transform: uppercase;
}

.viz-info-section {
  padding: 100px 0;
  background: #ffffff;
}

.viz-info-section__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: stretch;
}

.viz-info-section__text,
.viz-info-section__photo {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}

.viz-info-section.is-visible .viz-info-section__text,
.viz-info-section.is-visible .viz-info-section__photo {
  opacity: 1;
  transform: translateY(0);
}

.viz-info-section__text {
  background: #f5f5f3;
  padding: 42px 38px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.viz-info-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.viz-info-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(1.8rem, 2.8vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.viz-info-section__desc {
  margin: 0 0 16px;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
}

.viz-info-section__desc:last-child {
  margin-bottom: 0;
}

.viz-info-section__photo {
  overflow: hidden;
  min-height: 560px;
}

.viz-info-section__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.viz-benefits-section {
  padding: 0 0 100px;
  background: #ffffff;
  overflow: hidden;
}

.viz-benefits-section__intro {
  max-width: 840px;
  margin: 0 auto 44px;
  text-align: center;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.viz-benefits-section.is-visible .viz-benefits-section__intro {
  opacity: 1;
  transform: translateY(0);
}

.viz-benefits-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.viz-benefits-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.viz-benefits-section__text {
  margin: 0 auto;
  max-width: 68ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.8;
}

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

.viz-benefit-card {
  background: #f5f5f3;
  border-left: 4px solid #b6c145;
  padding: 30px 26px;
  min-height: 250px;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.7s ease, transform 0.7s ease, box-shadow 0.3s ease;
}

.viz-benefits-section.is-visible .viz-benefit-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.viz-benefit-card:hover {
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.08);
}

.viz-benefit-card__number {
  margin-bottom: 16px;
  color: #b6c145;
  font-size: 0.95rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}

.viz-benefit-card__title {
  margin: 0 0 14px;
  color: #4b4a48;
  font-size: 1.2rem;
  line-height: 1.25;
  font-weight: 700;
  text-transform: uppercase;
}

.viz-benefit-card__desc {
  margin: 0;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
  font-size: 0.96rem;
}

.viz-gallery-section {
  padding: 0 0 110px;
  background: #ffffff;
}

.viz-gallery-section__heading {
  max-width: 760px;
  margin-bottom: 38px;
}

.viz-gallery-section__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.viz-gallery-section__title {
  margin: 0 0 16px;
  color: #4b4a48;
  font-size: clamp(1.8rem, 2.8vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.viz-gallery-section__text {
  margin: 0;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.7;
}

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

.viz-gallery-item {
  position: relative;
  display: block;
  min-height: 320px;
  overflow: hidden;
  text-decoration: none;
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.viz-gallery-section.is-visible .viz-gallery-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.viz-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.05);
  transition: transform 0.75s ease;
}

.viz-gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.38) 100%);
  transition: background 0.3s ease;
}

.viz-gallery-item__caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  background: rgba(0,0,0,0.55);
  color: #ffffff;
  padding: 12px 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.viz-gallery-item:hover img {
  transform: scale(1.11);
}

.viz-gallery-item:hover::after {
  background: linear-gradient(180deg, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.52) 100%);
}

@media (max-width: 980px) {
  .viz-info-section__grid,
  .viz-gallery-grid {
    grid-template-columns: 1fr;
  }

  .viz-benefits-grid {
    grid-template-columns: 1fr 1fr;
  }

  .viz-info-section__photo {
    min-height: 420px;
  }
}

@media (max-width: 640px) {
  .viz-page-hero__content {
    padding: 150px 0 48px;
  }

  .viz-page-hero__container,
  .viz-info-section__container,
  .viz-benefits-section__container,
  .viz-gallery-section__container {
    width: min(100% - 24px, 1280px);
  }

  .viz-page-hero__box,
  .viz-info-section__text {
    padding: 24px 20px;
  }

  .viz-benefits-grid,
  .viz-gallery-grid {
    grid-template-columns: 1fr;
  }

  .viz-gallery-item {
    min-height: 260px;
  }

  .viz-benefits-section {
    padding: 0 0 84px;
  }

  .viz-gallery-section {
    padding: 0 0 84px;
  }
}

/* o nas */
.about-intro-section {
  padding: 110px 0;
  background: #ffffff;
  overflow: hidden;
}

.about-intro-section__container,
.about-history-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.about-intro-section__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
  gap: 32px;
  align-items: stretch;
}

.about-intro-section__content,
.about-intro-section__side {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}

.about-intro-section.is-visible .about-intro-section__content,
.about-intro-section.is-visible .about-intro-section__side {
  opacity: 1;
  transform: translateY(0);
}

.about-intro-section__content {
  background: #f5f5f3;
  padding: 42px 38px;
}

.about-intro-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-intro-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(2rem, 3vw, 3.4rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.about-intro-section__text {
  margin: 0 0 16px;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.8;
}

.about-intro-section__text:last-child {
  margin-bottom: 0;
}

.about-intro-section__side {
  display: grid;
  gap: 24px;
}

.about-intro-badge {
  background: #4b4a48;
  color: #ffffff;
  padding: 34px 28px;
  text-align: center;
}

.about-intro-badge__number {
  font-size: clamp(2.8rem, 5vw, 4.6rem);
  line-height: 1;
  font-weight: 800;
  color: #b6c145;
  margin-bottom: 10px;
}

.about-intro-badge__label {
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.about-intro-points {
  display: grid;
  gap: 14px;
}

.about-intro-point {
  background: #f5f5f3;
  border-left: 4px solid #b6c145;
  padding: 18px 18px;
  color: #4b4a48;
  line-height: 1.6;
}

/* historie */
.about-history-section {
  padding: 0 0 110px;
  background: #ffffff;
  overflow: hidden;
}

.about-history-section__heading {
  max-width: 820px;
  margin: 0 auto 38px;
  text-align: center;
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.about-history-section.is-visible .about-history-section__heading {
  opacity: 1;
  transform: translateY(0);
}

.about-history-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.9rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.about-history-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(2rem, 3vw, 3.2rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.about-history-section__text {
  margin: 0 auto;
  max-width: 68ch;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.8;
}

.about-history-carousel {
  position: relative;
  display: flex;
  align-items: center;
  gap: 20px;
}

.about-history-carousel__viewport {
  overflow: hidden;
  width: 100%;
}

.about-history-carousel__track {
  display: flex;
  transition: transform 0.65s ease;
  will-change: transform;
}

.about-history-card {
  flex: 0 0 calc((100% - 48px) / 3);
  margin-right: 24px;
  background: #f5f5f3;
  border-left: 4px solid #b6c145;
  padding: 28px 24px;
  min-height: 270px;
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.about-history-section.is-visible .about-history-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.about-history-card__year {
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.95rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}

.about-history-card__title {
  margin: 0 0 14px;
  color: #4b4a48;
  font-size: 1.15rem;
  line-height: 1.25;
  font-weight: 700;
}

.about-history-card__text {
  margin: 0;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
  font-size: 0.96rem;
}

.about-history-carousel__arrow {
  flex: 0 0 auto;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(75, 74, 72, 0.16);
  background: #4b4a48;
  color: #ffffff;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease;
}

.about-history-carousel__arrow:hover,
.about-history-carousel__arrow:focus-visible {
  background: #b6c145;
  color: #4b4a48;
  border-color: #b6c145;
  transform: translateY(-2px);
}

@media (max-width: 980px) {
  .about-intro-section__grid {
    grid-template-columns: 1fr;
  }

  .about-history-card {
    flex: 0 0 calc((100% - 24px) / 2);
  }
}

@media (max-width: 640px) {
  .about-intro-section {
    padding: 84px 0;
  }

  .about-history-section {
    padding: 0 0 84px;
  }

  .about-intro-section__container,
  .about-history-section__container {
    width: min(100% - 24px, 1280px);
  }

  .about-intro-section__content {
    padding: 24px 20px;
  }

  .about-history-card {
    flex: 0 0 100%;
    margin-right: 16px;
    min-height: 240px;
  }

  .about-history-carousel {
    gap: 12px;
  }

  .about-history-carousel__arrow {
    width: 46px;
    height: 46px;
    font-size: 20px;
  }
}

/*rozsireni o sub menu*/
.site-nav__item--has-submenu {
  position: relative;
}

.site-nav__toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: none;
  color: #ffffff;
  font: inherit;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  padding: 0;
}

.site-nav__toggle::after {
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  transition: transform 0.25s ease;
}

.site-nav__item--has-submenu:hover .site-nav__toggle::after,
.site-nav__item--has-submenu.is-open .site-nav__toggle::after {
  transform: rotate(-135deg) translateY(-1px);
}

.site-submenu {
  position: absolute;
  top: calc(100% + 18px);
  left: 0;
  min-width: 260px;
  background: rgba(75, 74, 72, 0.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.16);
  padding: 14px 0;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
  z-index: 1005;
}

.site-submenu li {
  list-style: none;
}

.site-submenu a {
  display: block;
  padding: 12px 18px;
  color: #ffffff;
  text-decoration: none;
  text-transform: none;
  letter-spacing: 0.01em;
  transition: background 0.25s ease, color 0.25s ease, padding-left 0.25s ease;
}

.site-submenu a:hover,
.site-submenu a:focus-visible {
  background: rgba(182, 193, 69, 0.16);
  color: #b6c145;
  padding-left: 22px;
}

.site-nav__item--has-submenu:hover .site-submenu,
.site-nav__item--has-submenu.is-open .site-submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* mobil */
@media (max-width: 920px) {
  .site-submenu {
    position: static;
    min-width: 100%;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 8px 0 0;
    opacity: 1;
    visibility: visible;
    transform: none;
    display: none;
  }

  .site-nav__item--has-submenu.is-open .site-submenu {
    display: block;
  }

  .site-submenu a {
    padding: 10px 0 10px 14px;
    color: rgba(255, 255, 255, 0.92);
  }

  .site-submenu a:hover,
  .site-submenu a:focus-visible {
    background: transparent;
    color: #b6c145;
    padding-left: 18px;
  }
}

/*Realizace*/
.realizace-page-hero {
  position: relative;
  min-height: 58vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: #4b4a48;
}

.realizace-page-hero__media,
.realizace-page-hero__image,
.realizace-page-hero__overlay {
  position: absolute;
  inset: 0;
}

.realizace-page-hero__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.realizace-page-hero__overlay {
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.48) 100%);
}

.realizace-page-hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  padding: 180px 0 70px;
}

.realizace-page-hero__container,
.realizace-info-section__container,
.realizace-gallery-section__container {
  width: min(100% - 32px, 1280px);
  margin: 0 auto;
}

.realizace-page-hero__box {
  display: inline-block;
  background: rgba(0, 0, 0, 0.62);
  padding: 28px 34px;
  border-left: 6px solid #b6c145;
}

.realizace-page-hero__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.realizace-page-hero__title {
  margin: 0;
  color: #ffffff;
  font-size: clamp(2.2rem, 4vw, 4.2rem);
  line-height: 1.05;
  font-weight: 800;
  text-transform: uppercase;
}

.realizace-info-section {
  padding: 100px 0;
  background: #ffffff;
}

.realizace-info-section__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: stretch;
}

.realizace-info-section__text,
.realizace-info-section__photo {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}

.realizace-info-section.is-visible .realizace-info-section__text,
.realizace-info-section.is-visible .realizace-info-section__photo {
  opacity: 1;
  transform: translateY(0);
}

.realizace-info-section__text {
  background: #f5f5f3;
  padding: 42px 38px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.realizace-info-section__eyebrow {
  display: inline-block;
  margin-bottom: 14px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.realizace-info-section__title {
  margin: 0 0 18px;
  color: #4b4a48;
  font-size: clamp(1.8rem, 2.8vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.realizace-info-section__desc {
  margin: 0 0 16px;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.75;
}

.realizace-info-section__desc:last-child {
  margin-bottom: 0;
}

.realizace-info-section__photo {
  overflow: hidden;
  min-height: 560px;
}

.realizace-info-section__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.realizace-gallery-section {
  padding: 0 0 110px;
  background: #ffffff;
}

.realizace-gallery-section__heading {
  max-width: 760px;
  margin-bottom: 38px;
}

.realizace-gallery-section__eyebrow {
  display: inline-block;
  margin-bottom: 12px;
  color: #b6c145;
  font-size: 0.88rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.realizace-gallery-section__title {
  margin: 0 0 16px;
  color: #4b4a48;
  font-size: clamp(1.8rem, 2.8vw, 3rem);
  line-height: 1.08;
  font-weight: 800;
  text-transform: uppercase;
}

.realizace-gallery-section__text {
  margin: 0;
  color: rgba(75, 74, 72, 0.88);
  line-height: 1.7;
}

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

.realizace-gallery-item {
  position: relative;
  display: block;
  min-height: 320px;
  overflow: hidden;
  text-decoration: none;
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.realizace-gallery-section.is-visible .realizace-gallery-item.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.realizace-gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1.05);
  transition: transform 0.75s ease;
}

.realizace-gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.08) 0%, rgba(0,0,0,0.38) 100%);
  transition: background 0.3s ease;
}

.realizace-gallery-item__caption {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  z-index: 2;
  background: rgba(0,0,0,0.55);
  color: #ffffff;
  padding: 12px 16px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.realizace-gallery-item:hover img {
  transform: scale(1.11);
}

.realizace-gallery-item:hover::after {
  background: linear-gradient(180deg, rgba(0,0,0,0.14) 0%, rgba(0,0,0,0.52) 100%);
}

@media (max-width: 980px) {
  .realizace-info-section__grid,
  .realizace-gallery-grid {
    grid-template-columns: 1fr;
  }

  .realizace-info-section__photo {
    min-height: 420px;
  }
}

@media (max-width: 640px) {
  .realizace-page-hero__content {
    padding: 150px 0 48px;
  }

  .realizace-page-hero__container,
  .realizace-info-section__container,
  .realizace-gallery-section__container {
    width: min(100% - 24px, 1280px);
  }

  .realizace-page-hero__box,
  .realizace-info-section__text {
    padding: 24px 20px;
  }

  .realizace-gallery-item {
    min-height: 260px;
  }

  .realizace-gallery-section {
    padding: 0 0 84px;
  }
}



.form-response {
  margin: 0 0 20px;
  padding: 14px 16px;
  line-height: 1.6;
  font-size: 0.95rem;
  border: 1px solid transparent;
}

.form-response--success {
  background: rgba(182, 193, 69, 0.14);
  border-color: rgba(182, 193, 69, 0.4);
  color: #4b4a48;
}

.form-response--error {
  background: rgba(180, 40, 40, 0.08);
  border-color: rgba(180, 40, 40, 0.28);
  color: #8a1f1f;
}