/*
Theme Name: Kadence Child
Theme URI: https://vclav-kivk.local
Description: Kadence Child Theme — Václav Křivák
Author: David
Template: kadence
Version: 1.0.0
Text Domain: kadence-child
*/

/* ==========================================================================
   KADENCE THEME FIXES
   ========================================================================== */

/* Fix: .site wrapper gets white bg on content-style-unboxed pages */
body.content-style-unboxed #wrapper,
body.content-style-unboxed .site { background: transparent !important; }

/* Fix: entry-content-wrap padding */
.content-style-unboxed .entry:not(.loop-entry) > .entry-content-wrap { padding: 0 !important; }

/* Fix: entry box-shadow on homepage */
.home .entry.single-entry { box-shadow: none !important; }


/* ==========================================================================
   GLOBAL COMPONENTS
   ========================================================================== */

/* --- Cards --- */
.vk-card {
  background: #113468;
  border: 1px solid rgba(27, 118, 255, 0.15);
  border-radius: 12px;
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.vk-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(27, 118, 255, 0.14);
  border-color: rgba(27, 118, 255, 0.4);
}

/* --- Buttons --- */
.elementor-button {
  border-radius: 50px !important;
  transition: transform .15s, opacity .15s, box-shadow .15s !important;
}
.elementor-button:hover {
  opacity: .9;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(27, 118, 255, 0.35);
}


/* ==========================================================================
   HOMEPAGE — NAŠE PROGRAMY (vk00022)
   ========================================================================== */

/* Program cards — hover */
.vk-prog-card {
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

/* Growth programy — stejná výška karet (Online Marketing + industry pages) */
.elementor-element-d00231e,
.elementor-element-0d7f0f2,
.elementor-element-08cdf97,
.elementor-element-43e4ea5 { height: 100%; }
.elementor-element-d00231e .elementor-widget-html,
.elementor-element-d00231e .elementor-widget-container,
.elementor-element-0d7f0f2 .elementor-widget-html,
.elementor-element-0d7f0f2 .elementor-widget-container,
.elementor-element-08cdf97 .elementor-widget-html,
.elementor-element-08cdf97 .elementor-widget-container,
.elementor-element-43e4ea5 .elementor-widget-html,
.elementor-element-43e4ea5 .elementor-widget-container { height: 100%; }

/* Střechy & Dřevostavby */
.elementor-element-94dffdc,.elementor-element-0383679,.elementor-element-754523b,.elementor-element-66ff9cb { height:100%; }
.elementor-element-94dffdc .elementor-widget-html,.elementor-element-94dffdc .elementor-widget-container,
.elementor-element-0383679 .elementor-widget-html,.elementor-element-0383679 .elementor-widget-container,
.elementor-element-754523b .elementor-widget-html,.elementor-element-754523b .elementor-widget-container,
.elementor-element-66ff9cb .elementor-widget-html,.elementor-element-66ff9cb .elementor-widget-container { height:100%; }

/* Bazény & Sauny */
.elementor-element-2405da1,.elementor-element-65bf211,.elementor-element-6d2e559,.elementor-element-20adc8f { height:100%; }
.elementor-element-2405da1 .elementor-widget-html,.elementor-element-2405da1 .elementor-widget-container,
.elementor-element-65bf211 .elementor-widget-html,.elementor-element-65bf211 .elementor-widget-container,
.elementor-element-6d2e559 .elementor-widget-html,.elementor-element-6d2e559 .elementor-widget-container,
.elementor-element-20adc8f .elementor-widget-html,.elementor-element-20adc8f .elementor-widget-container { height:100%; }

/* Vzduchotechnika & Klimatizace */
.elementor-element-53578e2,.elementor-element-0081f25,.elementor-element-0d50eb9,.elementor-element-7c06c2f { height:100%; }
.elementor-element-53578e2 .elementor-widget-html,.elementor-element-53578e2 .elementor-widget-container,
.elementor-element-0081f25 .elementor-widget-html,.elementor-element-0081f25 .elementor-widget-container,
.elementor-element-0d50eb9 .elementor-widget-html,.elementor-element-0d50eb9 .elementor-widget-container,
.elementor-element-7c06c2f .elementor-widget-html,.elementor-element-7c06c2f .elementor-widget-container { height:100%; }

/* Nábytek & Interiéry */
.elementor-element-a99dd1f,.elementor-element-3ec26b7,.elementor-element-6cf53ed,.elementor-element-4a13018 { height:100%; }
.elementor-element-a99dd1f .elementor-widget-html,.elementor-element-a99dd1f .elementor-widget-container,
.elementor-element-3ec26b7 .elementor-widget-html,.elementor-element-3ec26b7 .elementor-widget-container,
.elementor-element-6cf53ed .elementor-widget-html,.elementor-element-6cf53ed .elementor-widget-container,
.elementor-element-4a13018 .elementor-widget-html,.elementor-element-4a13018 .elementor-widget-container { height:100%; }

/* Elektroinstalace & Smart Home */
.elementor-element-27a161b,.elementor-element-24f6eef,.elementor-element-a8de579,.elementor-element-3d4254e { height:100%; }
.elementor-element-27a161b .elementor-widget-html,.elementor-element-27a161b .elementor-widget-container,
.elementor-element-24f6eef .elementor-widget-html,.elementor-element-24f6eef .elementor-widget-container,
.elementor-element-a8de579 .elementor-widget-html,.elementor-element-a8de579 .elementor-widget-container,
.elementor-element-3d4254e .elementor-widget-html,.elementor-element-3d4254e .elementor-widget-container { height:100%; }

/* Podlahy */
.elementor-element-e12e19f,.elementor-element-33112d7,.elementor-element-459ac22,.elementor-element-4dc4a5b { height:100%; }
.elementor-element-e12e19f .elementor-widget-html,.elementor-element-e12e19f .elementor-widget-container,
.elementor-element-33112d7 .elementor-widget-html,.elementor-element-33112d7 .elementor-widget-container,
.elementor-element-459ac22 .elementor-widget-html,.elementor-element-459ac22 .elementor-widget-container,
.elementor-element-4dc4a5b .elementor-widget-html,.elementor-element-4dc4a5b .elementor-widget-container { height:100%; }
.vk-prog-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 48px rgba(27, 118, 255, .2);
  border-color: rgba(27, 118, 255, .4);
}

/* Equal height cards */
.elementor-section[data-id="vk00022"] .elementor-row { align-items: stretch; }
.elementor-section[data-id="vk00022"] .elementor-column-wrap,
.elementor-section[data-id="vk00022"] .elementor-widget-wrap,
.elementor-section[data-id="vk00022"] .elementor-widget-html,
.elementor-section[data-id="vk00022"] .elementor-widget-container { height: 100%; }

/* Tablet 768px–1024px — 2×2 grid */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-vk00022 .elementor-container { flex-wrap: wrap !important; }
  .elementor-element-vk00015,
  .elementor-element-vk00017,
  .elementor-element-vk00019,
  .elementor-element-vk00021 {
    flex: 0 0 50% !important;
    width: 50% !important;
    max-width: 50% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
  .elementor-element-vk00014,
  .elementor-element-vk00016,
  .elementor-element-vk00018,
  .elementor-element-vk00020 {
    width: 100% !important;
    max-width: 100% !important;
  }
  .elementor-element-vk00022 .vk-prog-card { width: 100%; box-sizing: border-box; }
}

/* Mobile ≤767px — 1 karta na řádek */
@media (max-width: 767px) {
  .elementor-element-vk00015,
  .elementor-element-vk00017,
  .elementor-element-vk00019,
  .elementor-element-vk00021 {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
    margin-bottom: 12px !important;
  }
  .elementor-element-vk00014,
  .elementor-element-vk00016,
  .elementor-element-vk00018,
  .elementor-element-vk00020 {
    width: 100% !important;
    max-width: 100% !important;
  }
}


/* ==========================================================================
   HOMEPAGE — ACCORDION PROCES (vk-step)
   ========================================================================== */

.vk-step { border-bottom: 1px solid rgba(255, 255, 255, 0.07); padding: 22px 0; cursor: pointer; user-select: none; }
.vk-step:hover .vk-step-title { color: #fff !important; }
.vk-chevron { border-color: #1B76FF; }
.vk-step.inactive .vk-chevron { border-color: #2A2E4A; }
.vk-step.active { border-bottom: 1px solid rgba(27, 118, 255, 0.3); }
.vk-step-row { display: flex; justify-content: space-between; align-items: center; }
.vk-step-title { font-family: "Montserrat", sans-serif; font-size: 17px; font-weight: 700; color: #fff; }
.vk-step.inactive .vk-step-title { color: #4B5580; font-weight: 500; }
.vk-step-num { font-family: "Montserrat", sans-serif; font-size: 16px; font-weight: 700; color: #1B76FF; }
.vk-step.inactive .vk-step-num { color: #2A2E4A; }
.vk-step-desc { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 15px; line-height: 1.8; margin-top: 12px; padding-bottom: 4px; }
.vk-step-accent { color: #1B76FF; font-weight: 500; }


/* ==========================================================================
   HOMEPAGE — ÚSPĚŠNÉ PROJEKTY (vk00045)
   ========================================================================== */

.vk-cases { width: 100%; box-sizing: border-box; }
.vk-case-card { width: 100%; max-width: 100%; box-sizing: border-box; }


/* Hover efekt — nahrazuje inline onmouseenter/onmouseleave */
.vk-case-card:hover {
  border-color: rgba(27,118,255,.45) !important;
  box-shadow: 0 12px 48px rgba(27,118,255,.12) !important;
}
/* Tablet */
@media (min-width: 768px) and (max-width: 1024px) {
  .vk-case-card {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 280px !important;
    box-sizing: border-box !important;
  }
  .vk-case-img { width: 42% !important; }
  .vk-case-text { padding: 32px 28px !important; }
  .vk-case-text h3 { font-size: 24px !important; margin-bottom: 12px !important; }
}

/* Mobile */
@media (max-width: 767px) {
  .elementor-element-vk00045 {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }
  .vk-cases { max-width: 100% !important; overflow: hidden !important; }
  .vk-case-card {
    flex-direction: column !important;
    min-height: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }
  .vk-case-img {
    width: 100% !important;
    min-height: 200px !important;
    flex-shrink: 0 !important;
    flex: none !important;
    max-width: 100% !important;
  }
  .vk-case-text {
    padding: 24px 20px !important;
    flex: none !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .vk-case-text h3 { font-size: 22px !important; margin-bottom: 10px !important; }
}


/* ==========================================================================
   LABEL
   ========================================================================== */

.vk-label-dot { display: inline-flex; align-items: center; gap: 8px; color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 12px; font-weight: 500; letter-spacing: 3px; text-transform: uppercase; margin: 0 0 20px; }
.vk-dot { width: 7px; height: 7px; background: #1B76FF; border-radius: 50%; display: inline-block; box-shadow: 0 0 8px rgba(27,118,255,.7); flex-shrink: 0; }


/* ==========================================================================
   PROGRAM CARDS — INNER ELEMENTS
   ========================================================================== */

.vk-prog-card { position: relative; border-radius: 16px; padding: 32px 24px 28px; background: #113468; border: 1px solid rgba(27,118,255,.2); display: flex; flex-direction: column; height: 100%; }
.vk-prog-card--featured { border: 2px solid #1B76FF !important; box-shadow: 0 0 32px rgba(27,118,255,.15); }
.vk-prog-badge { position: absolute; top: -13px; left: 50%; transform: translateX(-50%); background: #1B76FF; color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; padding: 4px 16px; border-radius: 50px; white-space: nowrap; }
.vk-prog-name { color: #fff; font-family: "Montserrat", sans-serif; font-weight: 900; font-size: 26px; margin-bottom: 6px; }
.vk-prog-sub { color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 14px; }
.vk-prog-desc { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 14px; line-height: 1.75; margin: 0 0 20px; }
.vk-prog-list { list-style: none; padding: 0; margin: 0 0 24px; flex: 1; }
.vk-prog-item { display: flex; align-items: center; gap: 8px; color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 14px; padding: 5px 0; }
.vk-prog-bullet { color: #1B76FF; font-size: 10px; flex-shrink: 0; }
.vk-prog-btn { display: block; text-align: center; background: #1B76FF; color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 13px; padding: 13px 20px; border-radius: 50px; text-decoration: none; letter-spacing: .5px; margin-top: auto; }
.vk-prog-btn:hover { opacity: .9; }


/* ==========================================================================
   STATS BAR
   ========================================================================== */

.vk-stats-bar { display: flex; align-items: center; justify-content: space-around; flex-wrap: wrap; padding: 40px 0; }
.vk-stat-cell { text-align: center; padding: 16px 24px; }
.vk-stat-num { color: #fff; font-family: "Montserrat", sans-serif; font-size: 52px; font-weight: 900; line-height: 1; letter-spacing: -2px; display: block; }
.vk-stat-lbl { color: #fff; font-family: "Roboto", sans-serif; font-size: 12px; text-transform: uppercase; letter-spacing: 2.5px; margin-top: 10px; opacity: .85; display: block; }
.vk-stat-divider { width: 1px; height: 56px; background: rgba(255,255,255,0.3); }
.vk-stat-divider--dark { background: rgba(255,255,255,0.07); }
.vk-stat-num-blue { color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 900; font-size: 52px; line-height: 1; letter-spacing: -2px; }
.vk-stat-lbl-gray { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 12px; text-transform: uppercase; letter-spacing: 2.5px; margin-top: 10px; }

@media (max-width: 767px) {
  .vk-stats-bar { flex-direction: column !important; padding: 28px 16px !important; gap: 0 !important; align-items: center !important; }
  .vk-stat-cell { padding: 12px 24px !important; }
  .vk-stat-divider, .vk-stat-divider--dark { width: 56px !important; height: 1px !important; margin: 4px auto !important; }
  .vk-stat-num, .vk-stat-num-blue { font-size: 38px !important; letter-spacing: -1px !important; }
  .vk-stat-lbl, .vk-stat-lbl-gray { font-size: 11px !important; margin-top: 6px !important; }
}


/* ==========================================================================
   RECENZE KARTY
   ========================================================================== */

.vk-review-quote { color: rgba(27,118,255,0.15); font-family: Georgia, serif; font-size: 80px; line-height: 1; position: absolute; top: 20px; right: 24px; font-weight: 900; }
.vk-review-stars { display: flex; align-items: center; gap: 10px; margin-bottom: 24px; }
.vk-review-line { flex: 1; height: 1px; background: rgba(27,118,255,0.2); }
.vk-review-text { color: #CCCCCC; font-family: "Roboto", sans-serif; font-size: 15px; line-height: 1.9; margin: 0 0 32px; }
.vk-review-footer { border-top: 1px solid rgba(255,255,255,.06); padding-top: 22px; }
.vk-review-author { color: #fff; font-family: "Montserrat", sans-serif; font-weight: 800; font-size: 15px; }

@media (max-width: 767px) {
  .vk-review-text { font-size: 14px !important; }
}


/* ==========================================================================
   TLAČÍTKA
   ========================================================================== */

.vk-btn-primary { display: inline-flex; align-items: center; gap: 10px; background: #1B76FF; color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 14px; padding: 17px 36px; border-radius: 50px; text-decoration: none; box-shadow: 0 4px 24px rgba(27,118,255,.4); letter-spacing: .5px; }
.vk-btn-ghost { background: transparent; color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 14px; padding: 17px 36px; border-radius: 50px; border: 2px solid rgba(255,255,255,.25); text-decoration: none; letter-spacing: .5px; }
.vk-btn-blue-outline { background: transparent; color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 14px; padding: 15px 40px; border-radius: 50px; border: 2px solid #1B76FF; text-decoration: none; display: inline-block; letter-spacing: .5px; }
.vk-btn-white { background: #fff; color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 800; font-size: 15px; padding: 18px 50px; border-radius: 50px; text-decoration: none; display: inline-block; box-shadow: 0 8px 32px rgba(0,0,0,.2); letter-spacing: .5px; }
.vk-btn-link { color: #1B76FF; font-family: "Montserrat", sans-serif; font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; text-decoration: none; }
.vk-btn-link-sm { color: #1B76FF; font-family: "Montserrat", sans-serif; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 2px; text-decoration: none; }

@media (max-width: 767px) {
  .vk-btn-primary, .vk-btn-ghost { width: 100% !important; justify-content: center !important; text-align: center !important; padding: 15px 20px !important; }
}


/* ==========================================================================
   HERO BADGE
   ========================================================================== */

.vk-hero-badge { display: inline-flex; align-items: center; gap: 8px; border: 1px solid rgba(255,255,255,.2); border-radius: 50px; padding: 8px 18px; margin-bottom: 32px; }
.vk-hero-stars { color: #F5C518; font-size: 14px; letter-spacing: 2px; }
.vk-hero-badge-text { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 13px; font-weight: 500; letter-spacing: .5px; }


/* ==========================================================================
   INCLUDED LIST
   ========================================================================== */

.vk-incl-row { display: flex; gap: 10px; align-items: flex-start; padding: 9px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.vk-incl-check { color: #1B76FF; font-size: 14px; flex-shrink: 0; margin-top: 2px; }
.vk-incl-text { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 14px; line-height: 1.6; }


/* ==========================================================================
   PILLAR KARTY
   ========================================================================== */

.vk-pillar { background: #113468; border: 1px solid rgba(27,118,255,.12); border-radius: 12px; padding: 28px 22px; }
.vk-pillar-icon { font-size: 32px; margin-bottom: 14px; }
.vk-pillar-title { color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 16px; margin-bottom: 10px; }
.vk-pillar-text { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 14px; line-height: 1.8; }

.vk-incl-col { background: #113468; border: 1px solid rgba(27,118,255,.15); border-radius: 12px; padding: 28px 24px; height: 100%; }
.vk-incl-col-icon { font-size: 28px; margin-bottom: 10px; }
.vk-incl-col-title { color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; margin-bottom: 16px; }


/* ==========================================================================
   HOMEPAGE V2 — NAŠE PROGRAMY (hp2s2)
   ========================================================================== */

/* Equal height — stretch HTML widget to fill card container */
.elementor-element-hp2s2cards .elementor-widget-html,
.elementor-element-hp2s2cards .elementor-widget-container { height: 100%; }

/* Tablet 2×2 — explicit flex-wrap override */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-hp2s2cards.e-con { flex-wrap: wrap !important; }
  .elementor-element-hp2s2c1,
  .elementor-element-hp2s2c2,
  .elementor-element-hp2s2c3,
  .elementor-element-hp2s2c4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}



/* ==========================================================================
   SEKCE 5 — MINI METRICKÉ KARTY (hp2s5mini)
   ========================================================================== */

@media (max-width: 767px) {
  .elementor-element-hp2s5mini .vk-card {
    flex-direction: column !important;
  }
  .elementor-element-hp2s5mini .vk-card img {
    width: 100% !important;
    max-width: 100% !important;
    height: 160px !important;
    object-fit: cover !important;
  }
}

/* ==========================================================================
   REVIEWS SLIDER (hp2s6)
   ========================================================================== */

.vk-slider { position: relative; }
.vk-reviews-track { display: flex; gap: 24px; transition: transform .4s cubic-bezier(.4,0,.2,1); }
.vk-review-slide { flex-shrink: 0; }

/* Author on top */
.vk-review-author-top {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 800;
  font-size: 15px;
  padding-bottom: 16px;
  margin-bottom: 20px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* Equal-height slides */
.vk-review-slide .vk-card { height: 100%; display: flex; flex-direction: column; }
.vk-review-slide .vk-review-text { flex: 1; }

/* Slider controls */
.vk-slider-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 32px;
}
.vk-slider-prev,
.vk-slider-next {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.5);
  color: #fff;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, border-color .2s;
  padding: 0;
}
.vk-slider-prev:hover,
.vk-slider-next:hover { background: rgba(255,255,255,.25); border-color: #fff; }
.vk-slider-prev:disabled,
.vk-slider-next:disabled { opacity: .3; cursor: not-allowed; }




/* ==========================================================================
   NAŠE SLUŽBY V2 — PACKAGE DETAIL COMPONENTS
   ========================================================================== */

/* Price card */
.vk-price-card:hover {
  border-color: rgba(27,118,255,1) !important;
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0,0,0,.3);
}

/* Benefits grid — 4 columns desktop, 2 tablet, 1 mobile */
.vk-benefits-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.vk-benefit-card {
  background: #113468;
  border: 1px solid rgba(27,118,255,.12);
  border-radius: 12px;
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.vk-icon-box {
  height: 40px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
}
.vk-benefit-title {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 10px;
}
.vk-benefit-text {
  color: #EBEBEB;
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  line-height: 1.8;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .vk-benefits-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .vk-benefits-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   NAŠE SLUŽBY V2 — GROWTH PROGRAMY KARTY (ns2s2)
   ========================================================================== */

/* Equal height — stretch HTML widget to fill card container */
.elementor-element-ns2s2cards .elementor-widget-html,
.elementor-element-ns2s2cards .elementor-widget-container { height: 100%; }

/* Tablet 2×2 */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-ns2s2cards.e-con { flex-wrap: wrap !important; }
  .elementor-element-ns2s2c1,
  .elementor-element-ns2s2c2,
  .elementor-element-ns2s2c3,
  .elementor-element-ns2s2c4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}

/* ==========================================================================
   HOMEPAGE V2 — GROWTH PROGRAMY KARTY (hp2prog)
   ========================================================================== */

.elementor-element-hp2progcards .elementor-widget-html,
.elementor-element-hp2progcards .elementor-widget-container { height: 100%; }

@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-hp2progcards.e-con { flex-wrap: wrap !important; }
  .elementor-element-hp2progc1,
  .elementor-element-hp2progc2,
  .elementor-element-hp2progc3,
  .elementor-element-hp2progc4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}

/* ==========================================================================
   SEKCE 7 — S KÝM PRACUJEME (hp2s7)
   ========================================================================== */

.vk-grid-container {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(3, 1fr);
}

/* Scoped card styles for industry grid */
.vk-grid-container .vk-card {
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 20px;
  text-align: center;
  text-decoration: none;
}

.vk-icon-wrapper {
  height: 40px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.vk-card-title {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  display: block;
}

/* Tablet — 2 sloupce */
@media (min-width: 768px) and (max-width: 1024px) {
  .vk-grid-container { grid-template-columns: repeat(2, 1fr); }
}

/* Mobile — 1 sloupec */
@media (max-width: 767px) {
  .vk-grid-container { grid-template-columns: 1fr; gap: 10px; }
  .vk-grid-container .vk-card { padding: 25px 15px; }
}

/* ==========================================================================
   KLIENT KARTY
   ========================================================================== */

.vk-client-name { color: #fff; font-family: "Montserrat", sans-serif; font-size: 15px; font-weight: 700; margin-bottom: 6px; }
.vk-client-service { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 13px; }
.vk-client-metric { color: #1B76FF; font-family: "Montserrat", sans-serif; font-size: 14px; font-weight: 700; white-space: nowrap; }


/* ==========================================================================
   NAŠE SLUŽBY V2 — STRATEGY GRID (ns2s4b, ns2s5b, ns2s6b)
   ========================================================================== */

.vk-strategy-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  width: 100%;
}
.vk-strategy-card {
  background: #113468;
  border: 1px solid rgba(27,118,255,.12);
  border-radius: 12px;
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.vk-strategy-title {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 10px;
}
.vk-strategy-text {
  color: #EBEBEB;
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  line-height: 1.8;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .vk-strategy-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .vk-strategy-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   NAŠE SLUŽBY V2 — AUTHORITY / TOOLS GRID (ns2s7)
   ========================================================================== */

.vk-authority-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  width: 100%;
}
.vk-authority-card {
  background: #113468;
  border: 1px solid rgba(27,118,255,.12);
  border-radius: 12px;
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.vk-authority-title {
  color: #fff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 10px;
}
.vk-authority-text {
  color: #EBEBEB;
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  line-height: 1.8;
}
@media (min-width: 768px) and (max-width: 1024px) {
  .vk-authority-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
  .vk-authority-grid { grid-template-columns: 1fr; }
}


/* Timeline — desktop 2 sloupce, mobile 1 sloupec */
.vk-timeline-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  width: 100%;
}
@media (max-width: 767px) {
  .vk-timeline-grid { grid-template-columns: 1fr; }
}


/* ==========================================================================
   ONLINE MARKETING V2
   ========================================================================== */

/* Service section — responsive image */
.om-service-img { width: 100%; height: auto; border-radius: 16px; display: block; object-fit: cover; }

/* Service section — checkmark bullets */
.om-bullets { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 10px; }
.om-bullet-row { display: flex; align-items: flex-start; gap: 10px; color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 15px; line-height: 1.6; }
.om-bullet-icon { flex-shrink: 0; margin-top: 2px; }

/* Zjistit vice link */
.om-more-link { display: inline-flex; align-items: center; gap: 8px; color: #1B76FF; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 14px; text-decoration: none; letter-spacing: .5px; margin-top: 8px; }
.om-more-link:hover { opacity: .8; }

/* Obsah & kreativa card */
.om-content-visual { background:#113468; border:1px solid rgba(27,118,255,.2); border-radius:16px; padding:28px 24px; display:flex; flex-direction:column; gap:16px; }
.om-content-visual-title { color:#fff; font-family:"Montserrat",sans-serif; font-weight:700; font-size:11px; letter-spacing:2.5px; text-transform:uppercase; }
.om-content-tags { display:flex; flex-wrap:wrap; gap:8px; }
.om-tag { background:rgba(27,118,255,.15); border:1px solid rgba(27,118,255,.25); color:#fff; font-family:"Roboto",sans-serif; font-size:12px; padding:4px 12px; border-radius:50px; }
.om-content-bar { display:flex; align-items:center; gap:12px; padding:10px 0; border-top:1px solid rgba(255,255,255,.07); }
.om-content-bar-icon { flex-shrink:0; display:flex; align-items:center; }
.om-content-bar-text { color:#EBEBEB; font-family:"Roboto",sans-serif; font-size:14px; flex:1; }
.om-content-bar-val { color:#1B76FF; font-family:"Montserrat",sans-serif; font-weight:700; font-size:13px; white-space:nowrap; }

/* Extra service cards */
.om-extra-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; width: 100%; }
.om-extra-card { background: #113468; border: 1px solid rgba(27,118,255,.12); border-radius: 12px; padding: 28px 22px; display: flex; flex-direction: column; gap: 12px; height: 100%; }
.om-extra-title { color: #fff; font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 16px; margin: 0; }
.om-extra-desc { color: #EBEBEB; font-family: "Roboto", sans-serif; font-size: 14px; line-height: 1.8; flex: 1; }
.om-extra-link { color: #1B76FF; font-family: "Montserrat", sans-serif; font-size: 13px; font-weight: 700; text-decoration: none; }
@media (min-width: 768px) and (max-width: 1024px) { .om-extra-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 767px) { .om-extra-grid { grid-template-columns: 1fr; } }

/* Social Performance Card */
.om-social-card { background: #113468; border: 1px solid rgba(27,118,255,.2); border-radius: 16px; padding: 30px; font-family: "Montserrat", sans-serif; max-width: 420px; margin: 0 auto; }
.om-social-header { display: flex; align-items: center; gap: 10px; margin-bottom: 15px; }
.om-pulse-icon { width: 20px; height: 20px; }
.om-social-title { color: #fff; font-size: 13px; font-weight: 700; letter-spacing: 1px; }
.om-social-divider { height: 1px; background: rgba(255,255,255,.07); margin-bottom: 28px; }
.om-social-networks { display: flex; justify-content: space-around; margin-bottom: 30px; }
.om-sn-box { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; background: rgba(27,118,255,.2); border: 1px solid rgba(27,118,255,.3); }
.om-sn-fb, .om-sn-ig, .om-sn-li, .om-sn-x { background: rgba(27,118,255,.2); border: 1px solid rgba(27,118,255,.3); box-shadow: none; }
.om-social-bars { display: flex; flex-direction: column; gap: 18px; }
.om-bar-row { display: grid; grid-template-columns: 90px 1fr 52px; align-items: center; gap: 12px; }
.om-bar-label { color: #EBEBEB; font-size: 13px; font-family: "Roboto", sans-serif; }
.om-bar-val { color: #1B76FF; font-size: 13px; font-weight: 700; text-align: right; font-family: "Montserrat", sans-serif; }
.om-bar-track { height: 8px; background: rgba(255,255,255,.07); border-radius: 4px; overflow: hidden; }
.om-bar-fill { height: 100%; border-radius: 4px; }
.om-bar-green { background: linear-gradient(90deg,#1B76FF,#60A5FA); width: 85%; }
.om-bar-blue { background: linear-gradient(90deg,#2563EB,#93C5FD); width: 65%; }
.om-bar-yellow { background: linear-gradient(90deg,#3B82F6,#BFDBFE); width: 55%; }
.om-social-footer { margin-top: 28px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.om-live-dot { width: 8px; height: 8px; background: #1B76FF; border-radius: 50%; box-shadow: 0 0 8px rgba(27,118,255,.7); animation: om-blink 2s infinite; flex-shrink: 0; }
.om-live-text { color: rgba(255,255,255,.6); font-size: 10px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; }
@keyframes om-blink { 0%,100% { opacity: .4; } 50% { opacity: 1; } }
@media (max-width: 767px) {
  .om-bar-row { grid-template-columns: 1fr 52px; }
  .om-bar-label { grid-column: 1 / -1; margin-bottom: -6px; }
  .om-social-card { max-width: 100%; }
}

/* ==========================================================================
   ONLINE MARKETING V2 — PROGRAM CARDS (om2prog)
   ========================================================================== */

/* Equal height — same mechanism as ns2s2 */
.elementor-element-om2progcards .elementor-widget-html,
.elementor-element-om2progcards .elementor-widget-container { height: 100%; }

/* Tablet 768px–1024px — 2x2 grid */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-om2progcards.e-con { flex-wrap: wrap !important; }
  .elementor-element-om2progc1,
  .elementor-element-om2progc2,
  .elementor-element-om2progc3,
  .elementor-element-om2progc4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}
/* ==========================================================================
   TVORBA WEBOVÝCH STRÁNEK V2 — FEATURES GRID (tw2s2)
   ========================================================================== */

.tw2-feat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
}

.tw2-feat-card {
  background: #113468;
  border: 1px solid rgba(27,118,255,.12);
  border-radius: 14px;
  padding: 28px 22px;
  transition: border-color .2s, box-shadow .2s;
}

.tw2-feat-card:hover {
  border-color: rgba(27,118,255,.4);
  box-shadow: 0 6px 30px rgba(27,118,255,.12);
}

/* Tablet — 2×4 */
@media (min-width: 768px) and (max-width: 1024px) {
  .tw2-feat-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Mobile */
@media (max-width: 767px) {
  .tw2-feat-grid { grid-template-columns: 1fr; }
}

/* ==========================================================================
   TVORBA WEBOVÝCH STRÁNEK V2 — PROGRAM CARDS (tw2prog)
   ========================================================================== */

.elementor-element-tw2progcards .elementor-widget-html,
.elementor-element-tw2progcards .elementor-widget-container { height: 100%; }

@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-tw2progcards.e-con { flex-wrap: wrap !important; }
  .elementor-element-tw2progc1,
  .elementor-element-tw2progc2,
  .elementor-element-tw2progc3,
  .elementor-element-tw2progc4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}

/* ==========================================================================
   TVORBA WEBOVÝCH STRÁNEK V2 — RESPONSIVE
   ========================================================================== */

/* --- Tablet 768px–1024px --- */
@media (min-width: 768px) and (max-width: 1024px) {
  /* Hero: column, text nahoře (je první v HTML), obrázek dole */
  .elementor-element-tw2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-tw2s0r { width: 100% !important; max-width: 100% !important;
    padding: 60px 40px 40px !important; }
  .elementor-element-tw2s0l { width: 100% !important; max-width: 100% !important;
    padding: 0 40px 60px !important; }

  /* Dvousloupcové sekce: zachovat layout, zmenšit padding */
  .elementor-element-tw2s1,
  .elementor-element-tw2s4,
  .elementor-element-tw2s6 { padding: 60px 24px !important; gap: 32px !important; }

  /* Sekce s plnou šířkou */
  .elementor-element-tw2s2,
  .elementor-element-tw2s5wrap,
  .elementor-element-tw2stats,
  .elementor-element-tw2s8 { padding: 60px 24px !important; }
  .elementor-element-tw2prog { padding: 60px 0 !important; }
}

/* --- Mobile ≤767px --- */
@media (max-width: 767px) {
  /* Hero: column, text nahoře (je první v HTML), obrázek dole */
  .elementor-element-tw2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-tw2s0r { width: 100% !important; max-width: 100% !important;
    padding: 48px 24px 32px !important; }
  .elementor-element-tw2s0l { width: 100% !important; max-width: 100% !important;
    padding: 0 24px 48px !important; }

  /* Dvousloupcové sekce: přeskládat na sloupec */
  .elementor-element-tw2s1,
  .elementor-element-tw2s4,
  .elementor-element-tw2s6 { flex-direction: column !important; padding: 50px 20px !important; gap: 32px !important; }
  .elementor-element-tw2s1l, .elementor-element-tw2s1r,
  .elementor-element-tw2s4l, .elementor-element-tw2s4r,
  .elementor-element-tw2s6l, .elementor-element-tw2s6r { width: 100% !important; max-width: 100% !important; }

  /* Sekce s plnou šířkou */
  .elementor-element-tw2s2,
  .elementor-element-tw2s5wrap,
  .elementor-element-tw2stats,
  .elementor-element-tw2s8 { padding: 50px 20px !important; }
  .elementor-element-tw2prog { padding: 50px 0 !important; }

  /* Case studies: karty pod sebou */
  .tw2-cs-grid { grid-template-columns: 1fr !important; max-width: 100% !important; }
}

/* ==========================================================================
   PRŮBĚH SPOLUPRÁCE V2 (sp2)
   ========================================================================== */

/* Trust badges — 4 columns */
.sp2-badges {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
}
.sp2-badge-card {
  background: #113468;
  border: 1px solid rgba(27,118,255,.12);
  border-radius: 16px;
  padding: 32px 24px;
  transition: border-color .2s, box-shadow .2s;
}
.sp2-badge-card:hover {
  border-color: rgba(27,118,255,.4);
  box-shadow: 0 6px 30px rgba(27,118,255,.12);
}

/* Timeline */
.sp2-timeline { display: flex; flex-direction: column; gap: 0; max-width: 860px; margin: 0 auto; }
.sp2-step { display: flex; gap: 28px; }
.sp2-step-left { display: flex; flex-direction: column; align-items: center; flex-shrink: 0; }
.sp2-step-num {
  width: 48px; height: 48px; background: #1B76FF; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  color: #fff; font-family: Montserrat, sans-serif; font-weight: 900; font-size: 18px;
  box-shadow: 0 0 0 6px rgba(27,118,255,.15);
}
.sp2-step-line { width: 2px; flex: 1; background: rgba(27,118,255,.25); min-height: 40px; margin: 8px 0; }
.sp2-step-body { padding-bottom: 48px; flex: 1; }
.sp2-step-time {
  color: #1B76FF; font-family: Montserrat, sans-serif; font-weight: 700;
  font-size: 11px; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 8px;
}
.sp2-step-title {
  color: #fff; font-family: Montserrat, sans-serif; font-weight: 800;
  font-size: 20px; margin: 0 0 10px; line-height: 1.3;
}
.sp2-step-desc { color: #EBEBEB; font-family: Roboto, sans-serif; font-size: 15px; line-height: 1.7; margin: 0 0 14px; }
.sp2-step-bullets { list-style: none; padding: 0; margin: 0 0 14px; display: flex; flex-direction: column; gap: 7px; }
.sp2-step-bullets li {
  display: flex; align-items: flex-start; gap: 10px;
  color: #EBEBEB; font-family: Roboto, sans-serif; font-size: 14px; line-height: 1.55;
}
.sp2-step-bullets li::before {
  content: ''; width: 6px; height: 6px; background: #1B76FF; border-radius: 50%;
  flex-shrink: 0; margin-top: 6px;
}
.sp2-step-tip {
  display: flex; align-items: flex-start; gap: 8px;
  background: rgba(27,118,255,.08); border-left: 3px solid #1B76FF;
  border-radius: 0 8px 8px 0; padding: 10px 14px;
  color: rgba(255,255,255,.7); font-family: Roboto, sans-serif; font-size: 13px;
  line-height: 1.6; font-style: italic;
}
.sp2-step-tip svg { flex-shrink: 0; margin-top: 2px; }

/* Review cards — 3 columns */
.sp2-reviews-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; width: 100%; }
.sp2-review-card {
  background: #113468; border: 1px solid rgba(27,118,255,.15);
  border-radius: 16px; padding: 32px 28px;
}

/* Program cards */
.elementor-element-sp2progcards .elementor-widget-html,
.elementor-element-sp2progcards .elementor-widget-container { height: 100%; }

/* --- Tablet 768px–1024px --- */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-sp2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-sp2s0r,
  .elementor-element-sp2s0l { width: 100% !important; max-width: 100% !important; padding: 50px 32px !important; }
  .sp2-badges { grid-template-columns: repeat(2, 1fr); }
  .sp2-reviews-grid { grid-template-columns: repeat(2, 1fr); }
  .elementor-element-sp2s1,
  .elementor-element-sp2s2,
  .elementor-element-sp2s4,
  .elementor-element-sp2stats,
  .elementor-element-sp2s6 { padding: 60px 24px !important; }
  .elementor-element-sp2prog { padding: 60px 0 !important; }
  .elementor-element-sp2progcards.e-con { flex-wrap: wrap !important; }
  .elementor-element-sp2progc1,
  .elementor-element-sp2progc2,
  .elementor-element-sp2progc3,
  .elementor-element-sp2progc4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}

/* --- Mobile ≤767px --- */
@media (max-width: 767px) {
  .elementor-element-sp2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-sp2s0r { order: 1; width: 100% !important; max-width: 100% !important; padding: 48px 20px 28px !important; }
  .elementor-element-sp2s0l { order: 2; width: 100% !important; max-width: 100% !important; padding: 0 20px 48px !important; }
  .sp2-badges { grid-template-columns: 1fr; }
  .sp2-reviews-grid { grid-template-columns: 1fr; }
  .elementor-element-sp2s1,
  .elementor-element-sp2s2,
  .elementor-element-sp2s4,
  .elementor-element-sp2stats,
  .elementor-element-sp2s6 { padding: 50px 20px !important; }
  .elementor-element-sp2prog { padding: 50px 0 !important; }
  .sp2-step-body { padding-bottom: 36px; }
  .sp2-step-title { font-size: 17px; }
}

/* ==========================================================================
   NAŠI KLIENTI & CASE STUDIES V2 (kl2)
   ========================================================================== */

/* Case studies — 3 columns */
.kl2-cs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  width: 100%;
}

/* Clients — 4 columns */
.kl2-clients-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  width: 100%;
}

/* Program cards */
.elementor-element-kl2progcards .elementor-widget-html,
.elementor-element-kl2progcards .elementor-widget-container { height: 100%; }

/* --- Tablet 768px–1024px --- */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-kl2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-kl2s0r,
  .elementor-element-kl2s0l { width: 100% !important; max-width: 100% !important; padding: 50px 32px !important; }
  .kl2-cs-grid { grid-template-columns: 1fr 1fr; }
  .kl2-clients-grid { grid-template-columns: 1fr 1fr; }
  .elementor-element-kl2s1,
  .elementor-element-kl2s2,
  .elementor-element-kl2s4,
  .elementor-element-kl2stats,
  .elementor-element-kl2s6 { padding: 60px 24px !important; }
  .elementor-element-kl2prog { padding: 60px 0 !important; }
  .elementor-element-kl2progcards.e-con { flex-wrap: wrap !important; }
  .elementor-element-kl2progc1,
  .elementor-element-kl2progc2,
  .elementor-element-kl2progc3,
  .elementor-element-kl2progc4 { width: 47% !important; max-width: 47% !important; flex: 0 0 47% !important; }
}

/* --- Mobile ≤767px --- */
@media (max-width: 767px) {
  .elementor-element-kl2s0 { flex-direction: column !important; min-height: auto !important; }
  .elementor-element-kl2s0r { order: 1; width: 100% !important; max-width: 100% !important; padding: 48px 20px 28px !important; }
  .elementor-element-kl2s0l { order: 2; width: 100% !important; max-width: 100% !important; padding: 0 20px 48px !important; }
  .kl2-cs-grid,
  .kl2-clients-grid { grid-template-columns: 1fr; }
  .elementor-element-kl2s1,
  .elementor-element-kl2s2,
  .elementor-element-kl2s4,
  .elementor-element-kl2stats,
  .elementor-element-kl2s6 { padding: 50px 20px !important; }
  .elementor-element-kl2prog { padding: 50px 0 !important; }
}

/* ==========================================================================
   NASI KLIENTI V2 - VYSLEDKY CASE STUDIES (kl2s3)
   ========================================================================== */

.kl2-result-cards {
  display: flex;
  flex-direction: column;
  gap: 48px;
  width: 100%;
  margin-top: 24px;
}
.kl2-result-card {
  display: flex;
  gap: 60px;
  align-items: center;
  background: #0F284E;
  border: 1px solid rgba(27,118,255,.2);
  border-radius: 20px;
  padding: 48px 56px;
}
.kl2rc-text { flex: 1; display: flex; flex-direction: column; }
.kl2rc-label {
  color: #1B76FF; font-family: Montserrat,sans-serif; font-weight: 700;
  font-size: 11px; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 8px;
}
.kl2rc-client {
  color: #fff; font-family: Montserrat,sans-serif; font-weight: 700;
  font-size: 16px; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 16px;
}
.kl2rc-metric {
  color: #1B76FF; font-family: Montserrat,sans-serif; font-weight: 900;
  font-size: 56px; line-height: 1; margin-bottom: 4px;
}
.kl2rc-metric-sub {
  color: #EBEBEB; font-family: Roboto,sans-serif; font-size: 14px; margin-bottom: 20px;
}
.kl2rc-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(27,118,255,.1); border: 1px solid rgba(27,118,255,.25);
  border-radius: 50px; padding: 7px 16px; margin-bottom: 20px;
  align-self: flex-start; color: #1B76FF;
  font-family: Montserrat,sans-serif; font-weight: 700;
  font-size: 12px; letter-spacing: 1px;
}
.kl2rc-dot { width: 6px; height: 6px; background: #1B76FF; border-radius: 50%; flex-shrink: 0; }
.kl2rc-desc {
  color: #EBEBEB; font-family: Roboto,sans-serif; font-size: 15px;
  line-height: 1.7; margin: 0 0 20px;
}
.kl2rc-bullets {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 10px;
}
.kl2rc-bullets li {
  display: flex; align-items: flex-start; gap: 10px;
  color: #EBEBEB; font-family: Roboto,sans-serif; font-size: 14px; line-height: 1.6;
}
.kl2rc-bullets li::before {
  content: ""; width: 7px; height: 7px; background: #1B76FF; border-radius: 50%;
  flex-shrink: 0; margin-top: 6px; display: block;
}
.kl2rc-img { flex: 0 0 400px; max-width: 400px; }
.kl2rc-img img {
  width: 100%; height: auto; border-radius: 12px; display: block;
  border: 2px solid rgba(27,118,255,.2);
}
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-kl2s3 { padding: 60px 24px !important; }
  .kl2-result-card { flex-direction: column; padding: 40px 32px; gap: 32px; }
  .kl2rc-img { flex: none; max-width: 100%; width: 100%; }
  .kl2rc-metric { font-size: 44px; }
}
@media (max-width: 767px) {
  .elementor-element-kl2s3 { padding: 50px 20px !important; }
  .kl2-result-card { flex-direction: column; padding: 28px 20px; gap: 24px; }
  .kl2rc-img { flex: none; max-width: 100%; width: 100%; }
  .kl2rc-metric { font-size: 36px; }
  .kl2rc-metric-sub { font-size: 13px; }
}

/* ==========================================================================
   BLOG V2 (bl2)
   ========================================================================== */

.bl2-feat-card { background:#113468; border:1px solid rgba(27,118,255,.15); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; height:100%; }
.bl2-feat-img-wrap { position:relative; flex-shrink:0; }
.bl2-feat-img-wrap img { width:100%; height:320px; object-fit:cover; display:block; }
.bl2-feat-badge { position:absolute; top:16px; left:16px; background:#1B76FF; color:#fff; font-family:Montserrat,sans-serif; font-weight:700; font-size:10px; letter-spacing:2px; text-transform:uppercase; padding:5px 14px; border-radius:50px; }
.bl2-feat-cat { position:absolute; top:16px; right:16px; background:rgba(13,15,30,.85); border:1px solid rgba(27,118,255,.3); color:#1B76FF; font-family:Montserrat,sans-serif; font-weight:700; font-size:10px; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; border-radius:50px; }
.bl2-feat-body { padding:26px 28px 30px; display:flex; flex-direction:column; flex:1; }
.bl2-feat-title { color:#fff; font-family:Montserrat,sans-serif; font-weight:900; font-size:22px; line-height:1.3; margin:0 0 10px; text-transform:uppercase; }
.bl2-feat-meta { color:rgba(235,235,235,.55); font-family:Roboto,sans-serif; font-size:13px; display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.bl2-feat-excerpt { color:#EBEBEB; font-family:Roboto,sans-serif; font-size:14px; line-height:1.75; margin:0 0 20px; flex:1; }

.bl2-mini-cards { display:flex; flex-direction:column; gap:14px; height:100%; }
.bl2-mini-card { display:flex; align-items:stretch; background:#113468; border:1px solid rgba(27,118,255,.15); border-radius:12px; overflow:hidden; transition:border-color .2s,box-shadow .2s; flex:1; text-decoration:none; }
.bl2-mini-card:hover { border-color:rgba(27,118,255,.4); box-shadow:0 6px 20px rgba(27,118,255,.1); }
.bl2-mini-thumb { flex-shrink:0; width:130px; }
.bl2-mini-thumb img { width:130px; height:100%; min-height:90px; object-fit:cover; display:block; }
.bl2-mini-body { padding:14px 16px 14px 16px; display:flex; flex-direction:column; justify-content:center; flex:1; }
.bl2-mini-cat { color:#1B76FF; font-family:Montserrat,sans-serif; font-weight:700; font-size:10px; letter-spacing:2px; text-transform:uppercase; margin-bottom:5px; }
.bl2-mini-title { color:#fff; font-family:Montserrat,sans-serif; font-weight:700; font-size:13px; line-height:1.4; margin-bottom:5px; }
.bl2-mini-date { color:rgba(235,235,235,.45); font-family:Roboto,sans-serif; font-size:12px; }

.bl2-filter-wrap { display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.bl2-cat-tabs { display:flex; flex-wrap:wrap; gap:8px; }
.bl2-cat-btn { background:transparent; border:1px solid rgba(27,118,255,.25); color:rgba(235,235,235,.7); font-family:Montserrat,sans-serif; font-weight:600; font-size:12px; padding:8px 18px; border-radius:50px; cursor:pointer; transition:background .2s,border-color .2s,color .2s; white-space:nowrap; }
.bl2-cat-btn:hover { background:rgba(27,118,255,.1); border-color:rgba(27,118,255,.5); color:#fff; }
.bl2-cat-btn.active { background:#1B76FF; border-color:#1B76FF; color:#fff; }
.bl2-search-wrap { display:flex; align-items:center; background:rgba(255,255,255,.05); border:1px solid rgba(27,118,255,.2); border-radius:50px; padding:0 16px; min-width:200px; }
.bl2-search-icon { color:rgba(235,235,235,.4); font-size:13px; flex-shrink:0; }
.bl2-search-input { background:transparent; border:none; outline:none; color:#fff; font-family:Roboto,sans-serif; font-size:14px; padding:10px 10px; flex:1; width:100%; }
.bl2-search-input::placeholder { color:rgba(235,235,235,.35); }

.bl2-articles-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; width:100%; }
.bl2-article-card { background:#113468; border:1px solid rgba(27,118,255,.15); border-radius:16px; overflow:hidden; display:flex; flex-direction:column; transition:border-color .2s,box-shadow .2s,transform .2s; text-decoration:none; }
.bl2-article-card:hover { border-color:rgba(27,118,255,.4); box-shadow:0 8px 32px rgba(27,118,255,.12); transform:translateY(-4px); }
.bl2-art-img-wrap { position:relative; flex-shrink:0; }
.bl2-art-img-wrap img { width:100%; height:195px; object-fit:cover; display:block; }
.bl2-art-cat-badge { position:absolute; top:12px; left:12px; background:rgba(13,15,30,.85); border:1px solid rgba(27,118,255,.35); color:#1B76FF; font-family:Montserrat,sans-serif; font-weight:700; font-size:9px; letter-spacing:2px; text-transform:uppercase; padding:4px 10px; border-radius:50px; }
.bl2-art-body { padding:20px 22px 24px; display:flex; flex-direction:column; flex:1; }
.bl2-art-meta { color:rgba(235,235,235,.5); font-family:Roboto,sans-serif; font-size:12px; margin-bottom:8px; }
.bl2-art-title { color:#fff; font-family:Montserrat,sans-serif; font-weight:800; font-size:16px; line-height:1.35; margin:0 0 10px; }
.bl2-art-excerpt { color:#EBEBEB; font-family:Roboto,sans-serif; font-size:13px; line-height:1.7; margin:0 0 18px; flex:1; }
.bl2-read-more { color:#1B76FF; font-family:Montserrat,sans-serif; font-weight:700; font-size:12px; text-decoration:none; letter-spacing:.5px; align-self:flex-start; }
.bl2-read-more:hover { opacity:.75; }

.bl2-pagination { display:flex; align-items:center; justify-content:center; gap:8px; flex-wrap:wrap; }
.bl2-page-btn { display:inline-flex; align-items:center; justify-content:center; min-width:40px; height:40px; padding:0 14px; border:1px solid rgba(27,118,255,.25); border-radius:50px; color:rgba(235,235,235,.7); font-family:Montserrat,sans-serif; font-weight:600; font-size:13px; text-decoration:none; transition:background .2s,border-color .2s,color .2s; }
.bl2-page-btn:hover { background:rgba(27,118,255,.1); border-color:rgba(27,118,255,.5); color:#fff; }
.bl2-page-btn.active { background:#1B76FF; border-color:#1B76FF; color:#fff; }
.bl2-page-dots { color:rgba(235,235,235,.4); font-family:Montserrat,sans-serif; font-size:14px; padding:0 4px; }

.bl2-newsletter { display:flex; align-items:center; gap:60px; }
.bl2-nl-left { flex:1; }
.bl2-nl-right { flex:0 0 420px; }
.bl2-nl-title { color:#fff; font-family:Montserrat,sans-serif; font-weight:900; font-size:30px; line-height:1.2; margin:0 0 12px; text-transform:uppercase; }
.bl2-nl-desc { color:#EBEBEB; font-family:Roboto,sans-serif; font-size:15px; line-height:1.7; margin:0; }
.bl2-nl-form { display:flex; background:rgba(255,255,255,.06); border:1px solid rgba(27,118,255,.25); border-radius:50px; overflow:hidden; padding:6px 6px 6px 20px; }
.bl2-nl-input { background:transparent; border:none; outline:none; color:#fff; font-family:Roboto,sans-serif; font-size:15px; flex:1; min-width:0; }
.bl2-nl-input::placeholder { color:rgba(235,235,235,.4); }
.bl2-nl-submit { background:#1B76FF; color:#fff; border:none; border-radius:50px; padding:12px 26px; font-family:Montserrat,sans-serif; font-weight:700; font-size:13px; cursor:pointer; white-space:nowrap; transition:opacity .2s; }
.bl2-nl-submit:hover { opacity:.9; }

/* Hero left/right flex proportions */
.elementor-element-bl2s0cols { gap:28px !important; }
.elementor-element-bl2s0l { flex:1.6 !important; }
.elementor-element-bl2s0r { flex:1 !important; }

@media (min-width:768px) and (max-width:1024px) {
  .elementor-element-bl2s0cols { flex-direction:column !important; }
  .elementor-element-bl2s0l, .elementor-element-bl2s0r { width:100% !important; max-width:100% !important; flex:none !important; }
  .bl2-feat-img-wrap img { height:240px; }
  .bl2-articles-grid { grid-template-columns:repeat(2,1fr); }
  .bl2-newsletter { flex-direction:column; gap:32px; }
  .bl2-nl-right { flex:none; width:100%; }
  .elementor-element-bl2s0,
  .elementor-element-bl2s1,
  .elementor-element-bl2s2,
  .elementor-element-bl2s3,
  .elementor-element-bl2s4 { padding:60px 24px !important; }
  .elementor-element-bl2s5 { padding:60px 0 !important; }
}

@media (max-width:767px) {
  .elementor-element-bl2s0cols { flex-direction:column !important; }
  .elementor-element-bl2s0l, .elementor-element-bl2s0r { width:100% !important; max-width:100% !important; flex:none !important; }
  .bl2-feat-img-wrap img { height:200px; }
  .bl2-articles-grid { grid-template-columns:1fr; }
  .bl2-mini-card { flex-direction:column; }
  .bl2-mini-thumb { width:100%; }
  .bl2-mini-thumb img { width:100%; min-height:130px; }
  .bl2-filter-wrap { flex-direction:column; align-items:flex-start; }
  .bl2-search-wrap { width:100%; }
  .bl2-newsletter { flex-direction:column; gap:24px; }
  .bl2-nl-right { flex:none; width:100%; }
  .bl2-nl-title { font-size:24px; }
  .elementor-element-bl2s0,
  .elementor-element-bl2s1,
  .elementor-element-bl2s2,
  .elementor-element-bl2s3,
  .elementor-element-bl2s4 { padding:50px 20px !important; }
  .elementor-element-bl2s5 { padding:50px 0 !important; }
}

/* ==========================================================================
   NABYTEK & INTERIERY V2 (ni2)
   ========================================================================== */

.ni2-why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; width:100%; }
.ni2-why-card { background:#113468; border:1px solid rgba(27,118,255,.12); border-radius:14px; padding:28px 22px; transition:border-color .2s,box-shadow .2s; }
.ni2-why-card:hover { border-color:rgba(27,118,255,.4); box-shadow:0 6px 30px rgba(27,118,255,.12); }

.ni2-svc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; width:100%; }
.ni2-svc-card { background:#113468; border:1px solid rgba(27,118,255,.12); border-radius:12px; padding:24px 20px; }

.ni2-support-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; width:100%; }
.ni2-support-card { background:#113468; border:1px solid rgba(27,118,255,.12); border-radius:12px; padding:22px 18px; display:flex; align-items:flex-start; gap:14px; }

.ni2-stat-highlight { background:rgba(27,118,255,.08); border:1px solid rgba(27,118,255,.25); border-radius:16px; padding:28px 32px; display:flex; align-items:center; gap:24px; margin-bottom:32px; }
.ni2-stat-big { color:#1B76FF; font-family:Montserrat,sans-serif; font-weight:900; font-size:56px; line-height:1; flex-shrink:0; }
.ni2-stat-desc { color:#EBEBEB; font-family:Roboto,sans-serif; font-size:15px; line-height:1.6; }

.ni2-qual-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:14px; }
.ni2-qual-item { display:flex; align-items:flex-start; gap:12px; color:#EBEBEB; font-family:Roboto,sans-serif; font-size:15px; line-height:1.6; }
.ni2-qual-check { color:#1B76FF; font-size:18px; flex-shrink:0; margin-top:1px; font-weight:700; }

/* Growth programs — equal height + tablet 2x2 */
.elementor-element-ni2progcards .elementor-widget-html,
.elementor-element-ni2progcards .elementor-widget-container { height:100%; }
@media (min-width:768px) and (max-width:1024px) {
  .elementor-element-ni2progcards.e-con { flex-wrap:wrap !important; }
  .elementor-element-ni2progc1,.elementor-element-ni2progc2,.elementor-element-ni2progc3,.elementor-element-ni2progc4 { width:47% !important; max-width:47% !important; flex:0 0 47% !important; }
}

/* Responsive */
@media (min-width:768px) and (max-width:1024px) {
  .elementor-element-ni2s0,.elementor-element-ni2s1,.elementor-element-ni2s6 { flex-direction:column !important; }
  .elementor-element-ni2s0l,.elementor-element-ni2s0r,.elementor-element-ni2s1l,.elementor-element-ni2s1r,.elementor-element-ni2s6l,.elementor-element-ni2s6r { width:100% !important; max-width:100% !important; }
  .ni2-why-grid,.ni2-svc-grid { grid-template-columns:repeat(2,1fr); }
  .ni2-support-grid { grid-template-columns:repeat(2,1fr); }
  .ni2-stat-highlight { flex-direction:column; gap:16px; }
  .ni2-stat-big { font-size:44px; }
  .elementor-element-ni2s0,.elementor-element-ni2s1,.elementor-element-ni2stats,.elementor-element-ni2s2,.elementor-element-ni2s3,.elementor-element-ni2s4,.elementor-element-ni2s5,.elementor-element-ni2s6,.elementor-element-ni2s7 { padding:60px 24px !important; }
  .elementor-element-ni2prog { padding:60px 0 !important; }
}
@media (max-width:767px) {
  .elementor-element-ni2s0,.elementor-element-ni2s1,.elementor-element-ni2s6 { flex-direction:column !important; }
  .elementor-element-ni2s0l,.elementor-element-ni2s0r,.elementor-element-ni2s1l,.elementor-element-ni2s1r,.elementor-element-ni2s6l,.elementor-element-ni2s6r { width:100% !important; max-width:100% !important; }
  .ni2-why-grid,.ni2-svc-grid,.ni2-support-grid { grid-template-columns:1fr; }
  .ni2-stat-highlight { flex-direction:column; gap:16px; }
  .ni2-stat-big { font-size:40px; }
  .elementor-element-ni2s0,.elementor-element-ni2s1,.elementor-element-ni2stats,.elementor-element-ni2s2,.elementor-element-ni2s3,.elementor-element-ni2s4,.elementor-element-ni2s5,.elementor-element-ni2s6,.elementor-element-ni2s7 { padding:50px 20px !important; }
  .elementor-element-ni2prog { padding:50px 0 !important; }
}



/* ===== EL2 ELEKTROINSTALACE V2 — Jak zákazníci grid ===== */
.el2-jak-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  max-width: 1000px;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .el2-jak-grid {
    display: flex !important;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
  }
  .el2-jak-grid > div {
    width: calc(33.333% - 4px);
    flex-shrink: 0;
  }
  .el2-jak-arrow { display: none !important; }
}

/* ===== EL2 ELEKTROINSTALACE V2 — Growth programs ===== */
.elementor-element-el2progcards .elementor-widget-html,
.elementor-element-el2progcards .elementor-widget-container { height:100%; }
@media (min-width:768px) and (max-width:1024px) {
  .elementor-element-el2progcards.e-con { flex-wrap:wrap !important; }
  .elementor-element-el2progc1,.elementor-element-el2progc2,.elementor-element-el2progc3,.elementor-element-el2progc4 { width:47% !important; max-width:47% !important; flex:0 0 47% !important; }
  .elementor-element-el2prog { padding:60px 0 !important; }
}
@media (max-width:767px) {
  .elementor-element-el2progc1,.elementor-element-el2progc2,.elementor-element-el2progc3,.elementor-element-el2progc4 { width:100% !important; max-width:100% !important; flex:0 0 100% !important; }
  .elementor-element-el2prog { padding:50px 0 !important; }
}

/* ===== PO2 PODLAHY V2 — Growth programs ===== */
.elementor-element-po2progcards .elementor-widget-html,
.elementor-element-po2progcards .elementor-widget-container { height:100%; }
@media (min-width:768px) and (max-width:1024px) {
  .elementor-element-po2progcards.e-con { flex-wrap:wrap !important; }
  .elementor-element-po2progc1,.elementor-element-po2progc2,.elementor-element-po2progc3,.elementor-element-po2progc4 { width:47% !important; max-width:47% !important; flex:0 0 47% !important; }
  .elementor-element-po2prog { padding:60px 0 !important; }
}
@media (max-width:767px) {
  .elementor-element-po2progc1,.elementor-element-po2progc2,.elementor-element-po2progc3,.elementor-element-po2progc4 { width:100% !important; max-width:100% !important; flex:0 0 100% !important; }
  .elementor-element-po2prog { padding:50px 0 !important; }
}
/* ===== NI2 V2 REBUILD — new sections ===== */

/* Contact section columns */
.elementor-element-ni2s9kontakt > .elementor-container { max-width: 1200px; margin: 0 auto; padding: 0 40px; }
.elementor-element-ni2s9kl { flex: 1; }
.elementor-element-ni2s9kr { flex: 1; }

/* Jak to funguje grid on mobile */
@media (max-width: 767px) {
  .elementor-element-ni2s6jgrid > .elementor-widget-container > div,
  .elementor-element-ni2s8grid > .elementor-widget-container > div,
  .elementor-element-ni2s4grid > .elementor-widget-container > div {
    grid-template-columns: 1fr !important;
  }
  .elementor-element-ni2s9kontakt { flex-direction: column !important; }
  .elementor-element-ni2s9kontakt > .elementor-container { padding: 0 20px; }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1024px) {
  .elementor-element-ni2s8grid > .elementor-widget-container > div,
  .elementor-element-ni2s4grid > .elementor-widget-container > div {
    grid-template-columns: repeat(2,1fr) !important;
  }
  .elementor-element-ni2s9kontakt { flex-direction: column !important; }
  .elementor-element-ni2s9kontakt > .elementor-container { padding: 0 24px; }
}


/* ===== NI2 MOBILE FIXES ===== */

@media (max-width: 767px) {

  /* Case studies: image below text */
  .elementor-element-ni2s5cs .elementor-widget-container > div > div {
    flex-direction: column-reverse !important;
    min-height: unset !important;
  }
  .elementor-element-ni2s5cs .elementor-widget-container > div > div > div:first-child {
    width: 100% !important;
    min-height: 220px !important;
  }
  /* Fix gradient direction for stacked layout */
  .elementor-element-ni2s5cs .elementor-widget-container > div > div > div:first-child > div:last-child {
    background: linear-gradient(to bottom, #0D1635 0%, transparent 35%) !important;
  }
  .elementor-element-ni2s5cs .elementor-widget-container > div > div > div:last-child {
    padding: 28px 20px !important;
  }

  /* Web jako nastroj prodeje: stack cards */
  [class*="elementor-element-ni2s8grid"] .elementor-widget-container > div {
    grid-template-columns: 1fr !important;
  }

  /* Jak to funguje: stack cards */
  [class*="elementor-element-ni2s6jgrid"] .elementor-widget-container > div {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }

}


/* ===== NÁBYTEK & INTERIÉRY — WEB JAKO NÁSTROJ PRODEJE — karty ===== */

/* Desktop: 4 karty v jednom řádku */
.vk-nabytek-web-cards {
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}

/* Rovné výšky karet */
.vk-nabytek-web-cards > .elementor-element,
.vk-nabytek-web-cards > .elementor-element > .elementor-widget-container {
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* Tablet: 2×2 */
@media (max-width: 1024px) {
  .vk-nabytek-web-cards {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* Mobil: 1 sloupec */
@media (max-width: 767px) {
  .vk-nabytek-web-cards {
    grid-template-columns: 1fr !important;
  }
}


/* ===== ELEKTROINSTALACE & SMART HOME — WEB JAKO NÁSTROJ PRODEJE — karty ===== */

.vk-elektro-web-cards {
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
}

.vk-elektro-web-cards > .elementor-element,
.vk-elektro-web-cards > .elementor-element > .elementor-widget-container {
  height: 100%;
  display: flex;
  flex-direction: column;
}

@media (max-width: 1024px) {
  .vk-elektro-web-cards {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 767px) {
  .vk-elektro-web-cards {
    grid-template-columns: 1fr !important;
  }
}
