/* =========================================================================
   protvoreni.cz – Shoptet custom styly
   Načítáno přes jsDelivr CDN z GitHubu (viz README.md)
   Sekce: 1) Registrace  2) Login popup  3) Quantity widget  4) Upsell  5) Mobil
   ========================================================================= */

/* === 1) Registrace – Zákazník / B2B ==================================== */
/* Cili na .reg-ucet (legacy) i .co-registration (aktualni Shoptet fieldset) */
.reg-ucet,.co-registration{display:grid!important;grid-template-columns:1fr 1fr!important;gap:18px!important;margin:0 0 48px!important;padding:0!important;border:0!important;min-width:0!important;background:0!important;box-shadow:none!important}
.reg-ucet>h4,.co-registration>h4{grid-column:1/-1!important;margin:0 0 6px!important;font-size:18px!important;font-weight:700!important;color:#16223b!important}
.reg-ucet>.form-group,.co-registration>.form-group{position:relative!important;display:block!important;box-sizing:border-box!important;min-height:150px!important;margin:0!important;padding:30px 32px 30px 66px!important;border:1px solid #e2e4ea!important;border-radius:14px!important;background:#fff!important;box-shadow:0 4px 16px rgba(0,0,0,.04)!important;overflow:visible!important;cursor:pointer!important;transition:border-color .15s,box-shadow .15s,background .15s!important}
.reg-ucet>.form-group:has(input:checked),.co-registration>.form-group:has(input:checked){border-color:#1f6fb2!important;background:#f3f8ff!important;box-shadow:0 0 0 1px #1f6fb2 inset,0 6px 20px rgba(31,111,178,.10)!important}
.reg-ucet>.form-group:hover,.co-registration>.form-group:hover{border-color:#9cc3ee!important;box-shadow:0 6px 20px rgba(31,111,178,.08)!important}
.reg-ucet input[type=radio],.co-registration>.form-group input[type=radio]{display:inline-block!important;visibility:visible!important;opacity:1!important;position:absolute!important;top:31px!important;left:30px!important;width:22px!important;height:22px!important;min-width:22px!important;margin:0!important;appearance:auto!important;-webkit-appearance:radio!important;accent-color:#1f6fb2!important;cursor:pointer!important}
.reg-ucet label,.co-registration>.form-group label{display:block!important;width:auto!important;margin:0!important;padding:0!important;border:0!important;background:0!important;box-shadow:none!important;font-size:14px!important;line-height:1.6!important;color:#5a6b7e!important;text-align:left!important;text-transform:none!important;cursor:pointer!important}
.reg-ucet label strong,.co-registration>.form-group label strong{display:block!important;margin:0 0 10px!important;font-size:18px!important;line-height:1.3!important;font-weight:700!important;color:#16223b!important}

/* === 2) Login popup s benefity ========================================= */
#login.has-benefits{width:min(760px,95vw)!important;max-width:none!important;right:0!important;left:auto!important}
#login.has-benefits .popup-widget-inner{display:grid!important;grid-template-columns:1fr 1fr!important;grid-template-rows:auto 1fr!important;padding:0!important;overflow:hidden!important;border-radius:16px!important;box-shadow:0 24px 60px rgba(16,34,59,.18)!important}
#login.has-benefits>.popup-widget-inner>h2{grid-column:1!important;grid-row:1!important;margin:0!important;padding:40px 38px 18px!important;font-size:22px!important;font-weight:700!important;color:#16223b!important;background:0!important}
#login.has-benefits>.popup-widget-inner>#customerLogin{grid-column:1!important;grid-row:2!important;padding:0 38px 40px!important}
#login.has-benefits .login-benefits{grid-column:2!important;grid-row:1/-1!important;display:flex!important;flex-direction:column!important;padding:56px 56px 48px 48px!important;background:linear-gradient(180deg,#f4f8fe,#eaf1fb)!important;border-left:1px solid #e3ebf7!important}
#login .lb-title{margin:0 0 6px!important;padding:0!important;font-size:22px!important;font-weight:700!important;color:#16223b!important;background:0!important;border:0!important}
#login .lb-sub{margin:0 0 22px!important;padding:0!important;font-size:14px!important;line-height:1.5!important;color:#5a6b7e!important}
#login .lb-list{list-style:none!important;margin:0 0 28px!important;padding:0!important}
#login .lb-list li{position:relative!important;margin:0!important;padding:9px 0 9px 38px!important;font-size:15px!important;line-height:1.45!important;color:#2c3a4f!important}
#login .lb-list li::before{content:"✓"!important;position:absolute!important;left:0!important;top:6px!important;width:24px!important;height:24px!important;line-height:24px!important;text-align:center!important;border-radius:50%!important;background:#1f6fb2!important;color:#fff!important;font-size:13px!important;font-weight:700!important}
#login .lb-cta{display:block!important;margin-top:auto!important;padding:15px 18px!important;text-align:center!important;background:#1f6fb2!important;color:#fff!important;border-radius:10px!important;font-weight:700!important;font-size:15px!important;text-decoration:none!important;box-shadow:0 6px 16px rgba(31,111,178,.28)!important;transition:.15s}
#login .lb-cta:hover{background:#18567f!important;color:#fff!important;box-shadow:0 8px 20px rgba(31,111,178,.36)!important}
/* Odsazeni modalu od praveho kraje na sirokem desktopu */
@media(min-width:992px){#login.has-benefits{right:120px!important;left:auto!important}}

/* === 3) Quantity widget u "Do košíku" ================================== */
/* Scopnuto na .p-tools, ktere realne dostaly widget (:has(.qty-wrap)),
   aby se nezasahovalo do caruselu a jinych karet. Vse ukotveno do karty. */
.p .p-tools:has(.qty-wrap){position:static!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;gap:8px!important;flex-wrap:wrap!important}
.p .p-tools:has(.qty-wrap) form.pr-action{display:flex!important;align-items:center!important;gap:8px!important;flex:1 1 auto!important;min-width:0!important;width:auto!important;margin:0!important;padding:0!important}
.p .p-tools:has(.qty-wrap) form.pr-action .quantity{margin:0!important}
.p .p-tools:has(.qty-wrap) .add-to-cart-button,.p .p-tools:has(.qty-wrap) .btn.btn-cart{flex:1 1 auto!important;min-width:0!important;width:auto!important;height:auto!important;min-height:42px!important}
.p .qty-wrap{display:inline-flex;align-items:stretch;flex:0 0 auto;border:1px solid #ddd;border-radius:6px;overflow:hidden;height:38px;box-sizing:border-box}
.p .qty-btn{width:30px;border:0;background:#f5f5f5;cursor:pointer;font-size:16px;line-height:1;padding:0;user-select:none}
.p .qty-btn:hover{background:#e8e8e8}
.p .qty-input{width:42px;text-align:center;border:0;border-left:1px solid #ddd;border-right:1px solid #ddd;padding:0;font-size:14px;-moz-appearance:textfield;min-width:0}
.p .qty-input::-webkit-outer-spin-button,.p .qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* === 4) Upsell v košíku ================================================ */
#upsell-box{margin:0 0 20px;padding:12px 16px}
#upsell-box .upsell-title{margin:0 0 10px;padding:0;font-size:16px;background:none;border:0}
#upsell-box .upsell-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f0f0f0}
#upsell-box .upsell-item:last-child{border-bottom:0;padding-bottom:0}
#upsell-box .upsell-img{width:90px;height:90px;max-width:90px;object-fit:contain;flex:0 0 auto}
#upsell-box .upsell-name{flex:1 1 auto;font-size:14px;color:#222}
#upsell-box .upsell-price{font-weight:bold;white-space:nowrap}
#upsell-box .upsell-add{flex:0 0 auto;border:0;background:#4caf50;color:#fff;padding:9px 16px;font-weight:bold;cursor:pointer}
#upsell-box .upsell-add:hover{background:#43a047}
#upsell-box .upsell-add:disabled{background:#999;cursor:default}

/* === 5) Mobil ========================================================== */
@media(max-width:767px){
  .reg-ucet,.co-registration{grid-template-columns:1fr!important;gap:14px!important;margin-bottom:36px!important}
  .reg-ucet>.form-group,.co-registration>.form-group{min-height:auto!important;padding:22px 20px 22px 54px!important}
  .reg-ucet input[type=radio],.co-registration>.form-group input[type=radio]{top:24px!important;left:20px!important;width:20px!important;height:20px!important;min-width:20px!important}
  .reg-ucet label,.co-registration>.form-group label{font-size:14px!important}
  .reg-ucet label strong,.co-registration>.form-group label strong{font-size:17px!important;margin-bottom:8px!important}
  .p .p-tools:has(.qty-wrap){flex-direction:column!important;align-items:stretch!important;gap:8px!important}
  .p .p-tools:has(.qty-wrap) form.pr-action{flex-direction:column!important;align-items:stretch!important;width:100%!important;gap:8px!important}
  .p .p-tools:has(.qty-wrap) .qty-wrap{width:100%!important;height:44px!important}
  .p .p-tools:has(.qty-wrap) .qty-input{flex:1 1 auto!important;width:auto!important}
  .p .p-tools:has(.qty-wrap) .qty-btn{flex:0 0 46px!important;width:46px!important}
  .p .p-tools:has(.qty-wrap) .add-to-cart-button,.p .p-tools:has(.qty-wrap) .btn.btn-cart{width:100%!important;height:auto!important;min-height:46px!important}
}
@media(max-width:600px){
  #login.has-benefits{width:min(440px,96vw)!important}
  #login.has-benefits .popup-widget-inner{grid-template-columns:1fr!important;grid-template-rows:auto auto auto!important;border-radius:14px!important}
  #login.has-benefits>.popup-widget-inner>h2{padding:28px 24px 14px!important;font-size:20px!important}
  #login.has-benefits>.popup-widget-inner>#customerLogin{padding:0 24px 26px!important}
  #login.has-benefits .login-benefits{grid-column:1!important;grid-row:auto!important;padding:28px 24px!important;border-left:0!important;border-top:1px solid #e3ebf7!important}
  #login .lb-title{font-size:19px!important}
  #login .lb-cta{margin-top:8px!important}
}

/* === 6) Původní úpravy webu (menu, akce, ceny, footer, logo) ========== */

/* "Další kategorie" – přejmenování hamburger menu na desktopu */
@media (min-width: 992px) {
  .menu-helper[data-testid="hamburgerMenu"] {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    width: auto !important;
    max-width: none !important;
    cursor: pointer;
  }
  .menu-helper[data-testid="hamburgerMenu"] > span {
    display: inline-block !important;
    visibility: visible !important;
    position: static !important;
    width: auto !important;
    height: auto !important;
    clip: auto !important;
    overflow: visible !important;
    text-indent: 0 !important;
    background: none !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    font-size: 0 !important;
  }
  .menu-helper[data-testid="hamburgerMenu"] > span::after {
    content: "Další kategorie";
    font-size: 14px;
    font-weight: 600;
    color: #1f6fb2;
    line-height: 1;
  }
  .menu-helper[data-testid="hamburgerMenu"]:hover > span::after {
    text-decoration: underline;
  }
}

/* Logo */
#header .site-name a img { max-height: 60px; }

/* Akční ceny červené */
.product:has(.flag-discount) .price-final strong { color: #e30613; }
.p:has(.flag-discount) .prices .price-final strong,
.p:has(.flag-discount) .prices .price-final { color: #e30613 !important; }
.flag.flag-discount { background-color: #e30613 !important; }
.p-detail:has(.flag-discount) .price-final,
.p-detail:has(.price-standard) .price-final { color: #e30613; }

/* Barvy položek menu */
.menu-item-1942 a b { color: #e30613 !important; }
.menu-item-5685 a,
.menu-item-5685 a b { color: #2563eb !important; }
.menu-item-5685 a:hover,
.menu-item-5685 a:hover b { color: #1d4ed8 !important; }

/* Tlačítko Akce – červené zvýraznění */
a[href="/akce/"][data-testid="headerMenuItem"] {
  background: #e30613 !important;
  color: #fff !important;
  transition: background .2s ease;
}
a[href="/akce/"][data-testid="headerMenuItem"] b { color: #fff !important; }
a[href="/akce/"][data-testid="headerMenuItem"]:hover {
  background: #c20410 !important;
  color: #fff !important;
}
.navigation-in > ul > li > a[href="/akce/"]::after,
.navigation-in > ul > li:hover > a[href="/akce/"]::after,
.navigation-in > ul > li.exp > a[href="/akce/"]::after {
  background-color: #e30613 !important;
}

/* Otevírací doba v top liště */
.top-navigation-contacts::before {
  content: "Po–Pá 8:00–16:30";
  margin-right: 16px;
  padding-right: 16px;
  border-right: 1px solid rgba(255,255,255,.2);
  color: #ccc;
  font-size: 14px;
}

/* Pořadí footer bannerů */
.custom-footer__banner3 { order: 1; }
.custom-footer__banner2 { order: 2; }
.custom-footer__banner1 { order: 3; }
