body #content button.btn.btn-conversion.add-to-cart-button[data-testid="buttonAddToCart"]{
  background-color: #fff !important;
  border: 2px solid #47b972 !important;
  color: #47b972 !important;

  height: 52px;
  line-height: 50px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;

  border-radius: 16px !important;

  transition: background-color .2s ease, color .2s ease, border-color .2s ease;
}

body #content button.btn.btn-conversion.add-to-cart-button[data-testid="buttonAddToCart"]:hover,
body #content button.btn.btn-conversion.add-to-cart-button[data-testid="buttonAddToCart"]:focus{
  background-color: #47b972 !important;
  border-color: #47b972 !important;
  color: #fff !important;
}
body #content button.btn.btn-conversion.add-to-cart-button[data-testid="buttonAddToCart"] *,
body #content button.btn.btn-conversion.add-to-cart-button[data-testid="buttonAddToCart"]:hover *{
  color: inherit !important;
}

#header .header-top .header__contact__text{
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 4px !important;   
  line-height: 1.2 !important;
}

#header .header-top .header__contact__text > *{
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.2 !important;
}

#header .header-top .header__contact__title{
  font-size: 14px;
  font-weight: 500;
}

#header .header-top .header__contact .tel{
  display: block !important;
  font-size: 14px;
  font-weight: 400;
}

#header .header-top .header__contact .tel a{
  color: #47b972;
  text-decoration: none;
}

#header .header-top .header__contact .opening__hours{
  display: block !important;
  font-size: 12px;
  opacity: .75;
  white-space: nowrap;
}
#header .header-top .header__contact.closed:after {
    background-color: #e44938;
}
#header .header-top .header__contact:after {
    content: '';
    width: 18px;
    height: 18px;
    border: 1px solid #fff;
    border-radius: 50%;
    left: 40px;
    bottom: 0;
    position: absolute;
    background-color: #cfcfcf;
}
*, :after, :before {
    box-sizing: border-box;
}
#header .header-top .header__contact {
    position: relative;
    display: flex;
    align-items: center;
    gap: 18px;
    white-space: nowrap;
}
html, body, #content, #content-wrapper, #main, .wrapper, .container {
    font-family: "Plus Jakarta Sans", sans-serif !important;
}
#header, #header .site-name a {
    color: var(--_color-header-text);
}
body {
    font-size: 15px;
    letter-spacing: .5px;
    line-height: 1.7;
    font-weight: 400;
}
html, body {
    font-family: 'Plus Jakarta Sans', sans-serif;
}
.h1, .h2, .h3, .h4, .h5, .h6, body, h1, h2, h3, h4, h5, h6 {
    color: #2e2a27;
}
.blank-mode, body, body.blank-mode {
    font-family: var(--template-font), sans-serif;
}
body {
    counter-reset: steps top;
    font-weight: 400;
    min-height: 100%;
}
body {
    font-family: sans-serif;
    font-size: 16px;
    line-height: 1.384615;
}
style attribute {
    --scrollbar-width: 15px;
    --vh: 10.65px;
    --scroll-offset-runtime: 10px;
}
:root {
    --size-h1: 36px;
    --size-h2: 32px;
    --size-h3: 24px;
    --size-h4: 20px;
    --size-h5: 18px;
    --size-h6: 16px;
    --size-normal: 15px;
    --size-small: 14px;
}
.header-background-light {
    --_color-header-text: #1a1937;
    --_color-header-link: var(--color-primary);
    --_color-header-contrast-text: #fff;
    --_color-header-contrast-bg: var(--color-primary);
}
:root {
    --tooltip-bubble-arrow-size: 5px;
    --tooltip-bubble-background: #000;
    --tooltip-bubble-color: #fff;
    --tooltip-bubble-padding: 4px 8px;
    --tooltip-bubble-z-index: 999999;
    --tooltip-bubble-max-width: min(21em, calc(100vw - 20px));
    --tooltip-bubble-border-radius: 4px;
    --tooltip-bubble-left-position: 50%;
    --tooltip-bubble-top-position: 100%;
    --tooltip-bubble-arrow-left-position: 50%;
    --tooltip-bubble-arrow-top-position: 100%;
    --tooltip-bubble-arrow-transform: translateX(-50%);
    --tooltip-decoration: underline;
    --tooltip-decoration-style: dashed;
}
:root {
    --colors-focus-primary: #09367e;
    --colors-focus-secondary: #fff;
    --scroll-offset: var(--scroll-offset-override, var(--scroll-offset-runtime, 0px));
    --scroll-extra-offset: 0px;
}
:root {
    --color-primary: #47b972;
    --color-primary-h: 143;
    --color-primary-s: 45%;
    --color-primary-l: 50%;
    --color-primary-hover: #318651;
    --color-primary-hover-h: 143;
    --color-primary-hover-s: 46%;
    --color-primary-hover-l: 36%;
    --color-secondary: #ffa700;
    --color-secondary-h: 39;
    --color-secondary-s: 100%;
    --color-secondary-l: 50%;
    --color-secondary-hover: #ffb938;
    --color-secondary-hover-h: 39;
    --color-secondary-hover-s: 100%;
    --color-secondary-hover-l: 61%;
    --color-tertiary: #cfcfcf;
    --color-tertiary-h: 0;
    --color-tertiary-s: 0%;
    --color-tertiary-l: 81%;
    --color-tertiary-hover: #c60101;
    --color-tertiary-hover-h: 0;
    --color-tertiary-hover-s: 99%;
    --color-tertiary-hover-l: 39%;
    --color-header-background: #ffffff;
    --template-font: "Open Sans";
    --template-headings-font: "Open Sans";
    --header-background-url: url(data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7);
    --cookies-notice-background: #F8FAFB;
    --cookies-notice-color: #252525;
    --cookies-notice-button-hover: #27263f;
    --cookies-notice-link-hover: #3b3a5f;
    --templates-update-management-preview-mode-content: "Náhled aktualizací šablony je aktivní pro váš prohlížeč.";
}
html {
    font-size: 10px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
html {
    font-family: sans-serif;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}
<style>
@font-face {
    font-family: 'Plus Jakarta Sans';
    font-style: italic;
    font-weight: 200 800;
    font-display: swap;
    src: url(https://fonts.gstatic.com/s/plusjakartasans/v12/LDIuaomQNQcsA88c7O9yZ4KMCoOg4Koz4yOqhMva.woff2) format('woff2');
    unicode-range: U +0460 -052F, U +1C80 -1C8A, U +20B4, U +2DE0 -2DFF, U + A640-A69F, U + FE2E-FE2F;
}
#header .header-top-wrapper{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

#header .header-top-wrapper .site-name{
  margin-left: 0 !important;
}

@media (min-width: 768px){
  #header .header-top-wrapper > .container{
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
}
@media (max-width: 992px){
  #header .header-top .header__contact{
    gap: 10px !important;
  }

  #header .header-top .header__contact__text{
    gap: 2px !important;
    line-height: 1.15 !important;
  }

  #header .header-top .header__contact__title{
    font-size: 11px !important;
    font-weight: 600 !important;
  }

  #header .header-top .header__contact .tel,
  #header .header-top .header__contact .tel a{
    font-size: 12px !important;
    font-weight: 700 !important;
  }

  #header .header-top .header__contact .opening__hours{
    font-size: 11px !important;
    opacity: .75 !important;
  }
}
/* ===== POSUN KONTAKTU OD LOGA SMĚREM K LUPE ===== */

/* desktop */
@media (min-width: 993px){
  #header .header-top .header__contact{
    margin-left: 40px !important;   /* ← tady si klidně dolaď 30–60px */
  }
}

/* mobil */
@media (max-width: 992px){
  #header .header-top .header__contact{
    margin-left: 16px !important;
  }
}
/* =========================================================
   UNIGARDIA  sjednocen button (search + filtry)
   ========================================================= */

/* ZKLAD  stejn styl jako Add to cart */
body #content
button.btn.btn-primary.js-try-search-button,
body #content
button.btn.btn-primary.search-widget-try-button,
body #content
a.btn.btn-default.unveil-button{
  background-color: #fff !important;
  border: 2px solid #47b972 !important;
  color: #47b972 !important;

  height: 52px !important;
  line-height: 50px !important;
  padding: 0 24px !important;

  border-radius: 16px !important;

  font-weight: 600 !important;
  font-size: 13px !important;   /* ?? pidej toto */

  text-decoration: none !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  transition: background-color .2s ease,
              color .2s ease,
              border-color .2s ease;
}
/* HOVER + FOCUS  zelen */
body #content
button.btn.btn-primary.js-try-search-button:hover,
body #content
button.btn.btn-primary.search-widget-try-button:hover,
body #content
a.btn.btn-default.unveil-button:hover,
body #content
button.btn.btn-primary.js-try-search-button:focus,
body #content
button.btn.btn-primary.search-widget-try-button:focus,
body #content
a.btn.btn-default.unveil-button:focus{
  background-color: #47b972 !important;
  border-color: #47b972 !important;
  color: #fff !important;
}

/* DDINOST BARVY (ikony, span, svg) */
body #content
button.btn.btn-primary.js-try-search-button *,
body #content
button.btn.btn-primary.search-widget-try-button *,
body #content
a.btn.btn-default.unveil-button *,
body #content
button.btn.btn-primary.js-try-search-button:hover *,
body #content
button.btn.btn-primary.search-widget-try-button:hover *,
body #content
a.btn.btn-default.unveil-button:hover *{
  color: inherit !important;
  fill: currentColor !important;
}
/* NADPIS NAD BENEFIT BANNER  homepage + produkt + kategorie (desktop i mobil) */
.benefitBanner.position--benefitHomepage::before,
.benefitBanner.position--benefitProduct::before,
.benefitBanner.position--benefitCategory::before{
  content: "esk znaka poctivch produkt pro vai zahradu";
  display: block;
  width: 100%;
  text-align: center;
  font-weight: 500;
  font-size: 22px;
  line-height: 3;
  color: #343537;
  margin: 0 0 18px 0;
}

@media (max-width: 479px){
  .benefitBanner.position--benefitHomepage::before,
  .benefitBanner.position--benefitProduct::before,
  .benefitBanner.position--benefitCategory::before{
    content: "esk znaka poctivch produkt pro vai zahradu";
    display: block;
    width: 100%;
    text-align: center;
    font-weight: 500;
    font-size: 22px;
    line-height: 1.3;
    color: #343537;
    margin: 0 0 16px 0;
  }
} /* ? zavt @media 479 */


/* ====== 992 media (colorbox) ====== */
@media (max-width: 992px) {
  #cboxNext::after,
  #cboxPrevious::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: rgba(220, 220, 220, 0.65);
    pointer-events: none;
    z-index: 0;
  }

  #cboxNext:before,
  #cboxPrevious:before {
    position: relative !important;
    z-index: 1 !important;
  }

  div.benefitBanner__picture {
    flex-basis: 40px !important;
    max-width: 40px !important;
    margin-right: 6px !important;
  }
} /* ? zavt @media 992 */


/* =========================
   DESKTOP  NEMNME
   ========================= */
@media (min-width: 768px) {

  .p-image-wrapper .flags-extra .flag.flag-freeshipping{
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    padding: 2px 10px !important;

    background: #47b972 !important;
    color: #fff !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: row !important;

    text-transform: uppercase !important;
    font-size: 14px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    margin-left: 0 !important;
  }

  .p-image-wrapper .flags-extra .flag.flag-discount{
    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    padding: 2px 7px !important;

    background: #e00000 !important;
    color: #fff !important;

    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-direction: row !important;

    text-transform: uppercase !important;
    font-size: 14px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    margin-left: 0 !important;
  }

  .p-image-wrapper .flags-extra .flag.flag-freeshipping,
  .p-image-wrapper .flags-extra .flag.flag-discount{
    padding: 3px 12px !important;
    font-size: 14px !important;
  }
}

.p-image-wrapper,
.p-thumbnail,
.p {
  position: relative;
}

.flags.flags-extra{
  position: absolute !important;
  top: 8px !important;
  left: 8px !important;
  z-index: 20 !important;
  pointer-events: none !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: flex-start !important;
}

@media (max-width: 767px){

  .flags.flags-extra{
    top: 6px !important;
    left: 6px !important;
    gap: 4px !important;
  }

  .flags.flags-extra .flag{
    padding: 3px 7px !important;
    font-size: 10px !important;
    line-height: 1.15 !important;

    max-width: 72vw !important;
    white-space: normal !important;
    word-break: break-word !important;
    hyphens: auto !important;

    border-radius: 4px !important;
  }

  .flags.flags-extra .flag.flag-freeshipping{
    background: #47b972 !important;
    color: #fff !important;
    font-weight: 700 !important;
  }

  .flags.flags-extra .flag.flag-discount{
    background: #e00000 !important;
    color: #fff !important;
    font-weight: 700 !important;
  }
}

@media (min-width: 321px) and (max-width: 767px) {

  /* kontejner a necentruje a nenut ku */
  .columns-mobile-2 .products-block>div .flags.flags-extra,
  .columns-mobile-2 .products-block>div .flags-extra{
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    text-align: left !important;
  }

  .columns-mobile-2 .products-block>div .flags.flags-extra .flag,
  .columns-mobile-2 .products-block>div .flags-extra .flag{
    flex: 0 0 auto !important;
    min-width: 0 !important;
    width: auto !important;

    margin: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    margin-top: 0 !important;

    padding: 3px 7px !important;
    border-radius: 0px !important;

    white-space: normal !important;
    max-width: 72vw !important;
    word-break: break-word !important;
    hyphens: auto !important;
  }
}
@media (max-width: 767px){
  .flags.flags-extra,
  .wide .p-detail .flags.flags-extra{
    top: 8px !important;
    left: 8px !important;
    right: auto !important;
    bottom: auto !important;
  }
}

.flags-extra .flag.flag-freeshipping{
  background: #47b972 !important;
  color: #fff !important;

  width: auto !important;
  height: auto !important;
  min-width: 0 !important;
  min-height: 0 !important;

  border-radius: 0 !important;
  padding: 3px 12px !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: row !important;

  text-transform: uppercase !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  line-height: 1 !important;

  white-space: nowrap !important;
  margin-left: 0 !important;

  word-break: normal !important;
  hyphens: none !important;
}
.benefitBanner__picture{
  margin-right: -15px !important;
}
@media (max-width: 767px) {
  .flags.flags-extra .flag.flag-discount {
    background: #e00000 !important;
    color: #fff !important;

    width: auto !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;

    border-radius: 0 !important;
    margin-left: 0 !important; 
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;

    padding: 3px 7px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    line-height: 1 !important;

    white-space: nowrap !important;
    word-break: normal !important;
    hyphens: none !important;
  }
}
body.type-detail #content .p-to-cart-block{
  background-color:#fff !important;
}
