/* =============================================
   Vikon - Cart Krok 3 (Osobné údaje)
   ============================================= */

/* ── HLAVNÝ FORMULÁR ── */
form#order-form,
.order-contact-information-form {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    background: #F5F5F5 !important;
}

/* ── ĽAVÝ STĹPEC ── */
#checkoutContent .cart-content {
    padding: 1px !important;
    background: transparent !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

/* ── SEKCIE - biele boxy ── */
.co-contact-information,
.co-billing-address,
.co-shipping-address,
.co-box-additional {
    padding: 16px !important;
    box-sizing: border-box !important;
    border: none !important;
    border-top: none !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
    margin-bottom: 16px !important;
    overflow: hidden !important;
}

/* Shoptet fieldset reset */
.co-contact-information fieldset,
.co-billing-address fieldset,
.co-shipping-address fieldset {
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
}

.co-billing-address .box,
.co-contact-information .box {
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

/* ── NADPISY - pill header (len priame h4, NIE vnorené cez stay-in-touch) ── */
.co-contact-information > h4,
.co-contact-information > fieldset > h4,
.co-billing-address > h4,
.co-billing-address > fieldset > h4,
.co-shipping-address > h4,
.co-shipping-address > fieldset > h4 {
    display: flex !important;
    align-items: center !important;
    padding: 12px 16px !important;
    gap: 8px !important;
    width: 100% !important;
    height: 56px !important;
    background: #F1F1F6 !important;
    border-radius: 999px !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 20px !important;
    line-height: 32px !important;
    color: #14141F !important;
    text-transform: none !important;
    box-sizing: border-box !important;
    border: none !important;
    margin: 0 0 26px 0 !important;
    position: static !important;
}

.co-contact-information > h4::before,
.co-contact-information > fieldset > h4::before,
.co-billing-address > h4::before,
.co-billing-address > fieldset > h4::before,
.co-shipping-address > h4::before,
.co-shipping-address > fieldset > h4::before {
    position: static !important;
    margin-top: 0 !important;
    top: auto !important;
    left: auto !important;
    color: #14141F !important;
    font-size: 24px !important;
    line-height: 1 !important;
}

/* ── FORM GROUP ── */
.co-contact-information .form-group,
.co-billing-address .form-group,
.co-shipping-address .form-group {
    margin-bottom: 12.6px !important;
}

/* ── FLOATING LABEL WRAPPER ── */
.co-contact-information .smart-label-wrapper,
.co-billing-address .smart-label-wrapper,
.co-shipping-address .smart-label-wrapper {
    position: relative !important;
    margin-bottom: 12.6px !important;
}

.co-contact-information .smart-label-wrapper label,
.co-billing-address .smart-label-wrapper label,
.co-shipping-address .smart-label-wrapper label {
    position: absolute !important;
    left: 18.9px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 15px !important;
    line-height: 1 !important;
    color: #3D3D5C !important;
    opacity: 0.5 !important;
    pointer-events: none !important;
    transition: top 0.15s ease, font-size 0.15s ease, opacity 0.15s ease, transform 0.15s ease !important;
    white-space: nowrap !important;
    z-index: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.co-contact-information .smart-label-wrapper.populated label,
.co-contact-information .smart-label-wrapper input:focus ~ label,
.co-contact-information .smart-label-wrapper input:not(:placeholder-shown) ~ label,
.co-billing-address .smart-label-wrapper.populated label,
.co-billing-address .smart-label-wrapper input:focus ~ label,
.co-billing-address .smart-label-wrapper input:not(:placeholder-shown) ~ label,
.co-shipping-address .smart-label-wrapper.populated label,
.co-shipping-address .smart-label-wrapper input:focus ~ label,
.co-shipping-address .smart-label-wrapper input:not(:placeholder-shown) ~ label {
    top: 8px !important;
    transform: translateY(0) !important;
    font-size: 11px !important;
    opacity: 0 !important;
}

/* ── INPUT - v smart-label-wrapper ── */
.co-contact-information .smart-label-wrapper .form-control,
.co-billing-address .smart-label-wrapper .form-control,
.co-shipping-address .smart-label-wrapper .form-control {
    height: 56px !important;
    border: 1px solid #B7B7CF !important;
    border-radius: 999px !important;
    padding: 20px 18.9px 8px 18.9px !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 16px !important;
    line-height: 20px !important;
    color: #14141F !important;
    background: #FFFFFF !important;
    box-shadow: none !important;
    outline: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease !important;
}

.co-contact-information .smart-label-wrapper .form-control::placeholder,
.co-billing-address .smart-label-wrapper .form-control::placeholder,
.co-shipping-address .smart-label-wrapper .form-control::placeholder {
    color: transparent !important;
    opacity: 0 !important;
}

.co-contact-information .smart-label-wrapper .form-control:focus,
.co-billing-address .smart-label-wrapper .form-control:focus,
.co-shipping-address .smart-label-wrapper .form-control:focus {
    border-color: #14141F !important;
    box-shadow: none !important;
}

/* ── INPUT - mimo smart-label-wrapper (nie telefón) ── */
.co-contact-information .form-control:not(#phone):not(.js-phone-form-control),
.co-billing-address .form-control:not(#phone):not(.js-phone-form-control),
.co-shipping-address .form-control:not(#phone):not(.js-phone-form-control) {
    height: 56px !important;
    border: 1px solid #B7B7CF !important;
    border-radius: 999px !important;
    padding: 12.6px 18.9px !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 16px !important;
    line-height: 20px !important;
    color: #14141F !important;
    background: #FFFFFF !important;
    box-shadow: none !important;
    outline: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s ease !important;
}

.co-contact-information .form-control:not(#phone):not(.js-phone-form-control):focus,
.co-billing-address .form-control:not(#phone):not(.js-phone-form-control):focus,
.co-shipping-address .form-control:not(#phone):not(.js-phone-form-control):focus {
    border-color: #14141F !important;
    box-shadow: none !important;
}

/* ══════════════════════════════════════════════
   TELEFÓN
   ══════════════════════════════════════════════ */

.js-phone-form-group,
.phone-form-group {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 100% !important;
    position: relative !important;
    box-sizing: border-box !important;
    gap: 4px !important;
}

.js-phone-form-group > label,
.phone-form-group > label {
    display: block !important;
    position: static !important;
    transform: none !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    color: #3D3D5C !important;
    opacity: 0.7 !important;
    margin-bottom: 2px !important;
    padding-left: 18.9px !important;
}

.js-phone-form-group .phone-combined-input,
.phone-form-group .phone-combined-input {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
    box-sizing: border-box !important;
    min-width: 0 !important;
}

.js-phone-form-group .phone-combined-input .country-flags,
.phone-form-group .phone-combined-input .country-flags {
    flex: 0 0 auto !important;
    flex-shrink: 0 !important;
    height: 56px !important;
    min-width: 90px !important;
    max-width: 120px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 0 12px !important;
    border: 1px solid #B7B7CF !important;
    border-radius: 999px !important;
    background: #FFFFFF !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    color: #14141F !important;
}

.phone-combined-input select.js-phone-code {
    position: absolute !important;
    opacity: 0 !important;
    width: 0 !important;
    height: 0 !important;
    pointer-events: none !important;
}

/* Skryť SVG defs a všetky nevybrané vlajky vo vnútri country-flags-inner */
.country-flags-inner > svg[aria-hidden="true"] {
    display: none !important;
    position: absolute !important;
    width: 0 !important;
    height: 0 !important;
}

.country-flags-inner {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    width: 100% !important;
    height: 100% !important;
    overflow: hidden !important;
}

/* Chevron šípka za dial kódom */
.country-flags-inner .country-flag.selected::after {
    content: '' !important;
    display: inline-block !important;
    width: 8px !important;
    height: 5px !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%2314141F' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    flex-shrink: 0 !important;
    margin-left: 2px !important;
}

.country-flags-inner .country-flag:not(.selected) {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    pointer-events: none !important;
}

.country-flags-inner .country-flag.selected {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

.country-flags-inner .country-flag.selected .shp-flag {
    width: 22px !important;
    height: 15px !important;
    flex-shrink: 0 !important;
}

.country-flags-inner .country-flag.selected .shp-flag-label {
    display: flex !important;
    align-items: center !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    color: #14141F !important;
    gap: 0 !important;
}

.country-flags-inner .country-flag.selected .shp-flag-name {
    display: none !important;
}

/* Globálne skryť všetky country name texty vo flag buttone */
.country-flags .shp-flag-name,
.country-flags-inner .shp-flag-name {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
    font-size: 0 !important;
    opacity: 0 !important;
}

.js-phone-form-group .phone-combined-input input#phone,
.phone-form-group .phone-combined-input input#phone {
    flex: 1 1 auto !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: none !important;
    height: 56px !important;
    border: 1px solid #B7B7CF !important;
    border-radius: 999px !important;
    padding: 12.6px 18.9px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #14141F !important;
    background: #FFFFFF !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
    outline: none !important;
    align-self: center !important;
}

.js-phone-form-group .phone-combined-input input#phone:focus,
.phone-form-group .phone-combined-input input#phone:focus {
    border-color: #14141F !important;
    box-shadow: none !important;
}

/* ── KRAJINA / ŠTÁT - select ── */
.co-billing-address select,
.co-shipping-address select,
.co-billing-address select[disabled],
.co-billing-address select:disabled,
.co-shipping-address select[disabled],
.co-shipping-address select:disabled {
    height: 56px !important;
    background: #EFEFEF !important;
    border: 1px solid #E6E6EE !important;
    border-radius: 8px !important;
    padding: 7px 18.9px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 16px !important;
    color: #3D3D5C !important;
    opacity: 1 !important;
    width: 100% !important;
    box-sizing: border-box !important;
    cursor: default !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%233D3D5C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 16px center !important;
}

/* ── CHECKBOXY ── */
.co-billing-address .form-group label,
.co-box-additional .form-group label {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
}

/* ── CO-BOX-ADDITIONAL ── */
.co-box-additional {
    padding: 24px 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    background: #FFFFFF !important;
    border-radius: 16px !important;
}

/* ── ZOSTÁŇME V KONTAKTE - fieldset ── */
.co-box-additional .stay-in-touch {
    border: none !important;
    padding: 0 !important;
    margin: 8px 0 0 0 !important;
    background: transparent !important;
}

/* Nadpis "Zostáňme v kontakte" - normálny text, NIE pill */
.stay-in-touch h4,
.stay-in-touch .vikon-stay-title {
    display: block !important;
    height: auto !important;
    background: transparent !important;
    border-radius: 0 !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 0 8px 0 !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    line-height: 24px !important;
    color: #14141F !important;
    text-transform: none !important;
    position: static !important;
    box-sizing: border-box !important;
    align-items: unset !important;
    gap: unset !important;
}

.stay-in-touch h4::before,
.stay-in-touch .vikon-stay-title::before {
    content: none !important;
    display: none !important;
}

/* ── SIDEBAR - REKAPITULÁCIA ── */
#checkoutSidebar .cart-content {
    background: #FFFFFF !important;
    border-radius: 16px !important;
    padding: 32px !important;
    width: 100% !important;
    max-width: 436px !important;
    min-width: 320px !important;
    box-shadow: none !important;
    border: none !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 23.62px !important;
}

/* ── NADPIS REKAPITULÁCIE ── */
#summary-box h4 {
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 20px !important;
    line-height: 32px !important;
    color: #14141F !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 32px !important;
    display: flex !important;
    align-items: center !important;
    border: none !important;
}

/* ── POLOŽKY V KOŠÍKU ── */
.cart-item {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    padding: 0 !important;
    border: none !important;
    margin-bottom: 12px !important;
    gap: 8px !important;
}

/* Názov položky - ľavá časť */
.cart-item-name {
    flex: 1 1 auto !important;
    min-width: 0 !important;
}

/* Oprava: odkaz v názve položky - žiadna modrá, žiadny underline */
.cart-item-name a,
.cart-item-name a:link,
.cart-item-name a:visited,
.cart-item-name a:hover {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
    text-decoration: none !important;
}

/* Pravá časť - množstvo + cena zarovnané vpravo */
.cart-item-amount {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    text-align: right !important;
}

.cart-item-price {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    text-align: right !important;
    min-width: 60px !important;
}

/* ── OPRAVENÉ RIADKY DOPRAVY A PLATBY ── */
.recapitulation-single {
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
    gap: 8px !important;
}

.recap-method-name {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #14141F !important;
    flex: 1 1 auto !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.recap-method-price {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    color: #14141F !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    text-align: right !important;
}

/* ── CELKOM ZA TOVAR - zabrání zalomeniu strong tagu ── */
.order-summary-item.helper {
    border: none !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    gap: 8px !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    line-height: 20px !important;
    color: #14141F !important;
    margin-bottom: 6px !important;
}

.order-summary-item.helper > div:first-child {
    flex: 1 1 auto !important;
    white-space: nowrap !important;
}

.order-summary-item.helper strong {
    font-weight: 600 !important;
    white-space: nowrap !important;
    color: #14141F !important;
}

.order-summary-item.helper > div:last-child {
    flex-shrink: 0 !important;
    text-align: right !important;
    font-weight: 600 !important;
    white-space: nowrap !important;
}
.order-summary-item.price {
    border-top: none !important;
    border: none !important;
    padding-top: 20px !important;
    margin-top: 10px !important;
}

/* OPRAVA: rovnaký font, veľkosť aj rez pre label aj cenu */
.price-label.price-primary {
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 20px !important;
    line-height: 32px !important;
    color: #14141F !important;
}

.price.price-primary {
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 20px !important;
    line-height: 32px !important;
    color: #14141F !important;
}

/* ── TLAČIDLÁ ── */
.next-step {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
    margin-top: 20px !important;
}

.next-step-back {
    font-family: 'Inter', sans-serif !important;
    font-size: 0 !important;
    color: #14141F !important;
    text-decoration: none !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
}

.next-step-back::before {
    content: '<  Späť' !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    text-decoration: underline !important;
    visibility: visible !important;
    color: #14141F !important;
}

/* ── TLAČIDLO OBJEDNAŤ ── */
#submit-order {
    background: #CD0E1D !important;
    border-radius: 999px !important;
    height: 65px !important;
    min-width: 211px !important;
    border: none !important;
    padding: 16px 26px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    cursor: pointer !important;
    flex-direction: column !important;
}

#submit-order .order-button-text {
    font-family: 'Inter', sans-serif !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    text-transform: uppercase !important;
    color: #FFFFFF !important;
    line-height: 22px !important;
    display: block !important;
}

#submit-order .order-button-suffix {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 11px !important;
    color: rgba(255, 255, 255, 0.8) !important;
    text-transform: lowercase !important;
    line-height: 1 !important;
    display: block !important;
}

/* ── CHECKOUT BOX (skryť) ── */
.checkout-box {
    display: none !important;
}

/* ── ORDER SUMMARY HELPER (Celkom za tovar) ── */
/* OPRAVA: explicitný font-size + semi-bold pre odlíšenie od položiek */
.order-summary-item.helper {
    border: none !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 20px !important;
    color: #14141F !important;
    margin-bottom: 6px !important;
}

/* ── SÚHLAS S PODMIENKAMI ── */
.consents {
    padding: 0 !important;
    margin: 0 !important;
}

.consents label {
    font-family: 'Inter', sans-serif !important;
    font-size: 12px !important;
    line-height: 18px !important;
    color: #14141F !important;
}

.consents label a {
    color: #CD0E1D !important;
    text-decoration: underline !important;
}

/* ── SPOLOČNOSŤ SEKCIA ── */
.company-shopping {
    margin-bottom: 12px !important;
}

.company-shopping label {
    font-family: 'Inter', sans-serif !important;
    font-size: 14px !important;
    line-height: 20px !important;
    color: #14141F !important;
}

/* ── TOOLTIP ── */
.form-group-tooltip {
    border-radius: 50% !important;
    background: #F1F1F6 !important;
    color: #3D3D5C !important;
    border: 1px solid #B7B7CF !important;
}

/* Úplné skrytie labelu "Telefón" pre čistý vzhľad */
.js-phone-form-group > label,
.phone-form-group > label,
.js-phone-form-group .control-label,
.phone-form-group .control-label {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: none !important;
}

/* Uistíme sa, že kontajner s vlajkou a číslom nemá zbytočný horný margin */
.js-phone-form-group .phone-combined-input,
.phone-form-group .phone-combined-input {
    margin-top: 0 !important;
}

/* ── VLAJKY / DROPDOWN ── */
.country-flags,
.phone-combined-input,
.js-phone-form-group {
    overflow: visible !important;
    position: relative !important;
}

.country-flags-inner .country-flag:not(.selected) {
    display: none !important;
}

.country-flags:focus-within .country-flags-inner,
.country-flags:active .country-flags-inner {
    display: block !important;
    position: absolute !important;
    top: 58px !important;
    left: 0 !important;
    width: 280px !important;
    max-height: 350px !important;
    overflow-y: auto !important;
    background: #ffffff !important;
    border: 1px solid #B7B7CF !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.2) !important;
    z-index: 999999 !important;
    padding: 10px 0 !important;
}

.country-flags:focus-within .country-flag,
.country-flags:active .country-flag {
    display: flex !important;
    visibility: visible !important;
    padding: 12px 15px !important;
    border-bottom: 1px solid #f0f0f5 !important;
}

.country-flags:focus-within .shp-flag-name,
.country-flags:active .shp-flag-name {
    display: inline-block !important;
    visibility: visible !important;
    width: auto !important;
    font-size: 14px !important;
    opacity: 1 !important;
    margin-left: 10px !important;
}

/* ══════════════════════════════════════════════
   MOBILNÉ ŠTÝLY (max-width: 768px)
   ══════════════════════════════════════════════ */

@media (max-width: 768px) {

    /* ── HLAVNÝ FORMULÁR ── */
    form#order-form,
    .order-contact-information-form {
        gap: 12px !important;
    }

    /* ── ĽAVÝ STĹPEC ── */
    #checkoutContent .cart-content {
        gap: 12px !important;
        padding: 0 !important;
    }

    /* ── SEKCIE - biele boxy ── */
    .co-contact-information,
    .co-billing-address,
    .co-shipping-address,
    .co-box-additional {
        padding: 16px 12px !important;
        border-radius: 12px !important;
        margin-bottom: 12px !important;
    }

    /* ── NADPISY - pill header ── */
    .co-contact-information > h4,
    .co-contact-information > fieldset > h4,
    .co-billing-address > h4,
    .co-billing-address > fieldset > h4,
    .co-shipping-address > h4,
    .co-shipping-address > fieldset > h4 {
        font-size: 16px !important;
        height: 48px !important;
        padding: 10px 14px !important;
        margin: 0 0 20px 0 !important;
    }

    .co-contact-information > h4::before,
    .co-contact-information > fieldset > h4::before,
    .co-billing-address > h4::before,
    .co-billing-address > fieldset > h4::before,
    .co-shipping-address > h4::before,
    .co-shipping-address > fieldset > h4::before {
        font-size: 20px !important;
    }

    /* ── INPUTY ── */
    .co-contact-information .smart-label-wrapper .form-control,
    .co-billing-address .smart-label-wrapper .form-control,
    .co-shipping-address .smart-label-wrapper .form-control {
        height: 52px !important;
        font-size: 16px !important; /* 16px zachováva — iOS nezoomuje */
    }

    .co-contact-information .form-control:not(#phone):not(.js-phone-form-control),
    .co-billing-address .form-control:not(#phone):not(.js-phone-form-control),
    .co-shipping-address .form-control:not(#phone):not(.js-phone-form-control) {
        height: 52px !important;
        font-size: 16px !important;
    }

    /* ── TELEFÓN ── */
    .js-phone-form-group .phone-combined-input input#phone,
    .phone-form-group .phone-combined-input input#phone {
        height: 52px !important;
        font-size: 16px !important;
    }

    .js-phone-form-group .phone-combined-input .country-flags,
    .phone-form-group .phone-combined-input .country-flags {
        height: 52px !important;
        min-width: 80px !important;
    }

    /* ── SIDEBAR - na mobile ide pod formulár ── */
    #checkoutSidebar .cart-content {
        max-width: 100% !important;
        min-width: 0 !important;
        padding: 20px 16px !important;
        border-radius: 12px !important;
        gap: 16px !important;
    }

    /* ── NADPIS REKAPITULÁCIE ── */
    #summary-box h4 {
        font-size: 18px !important;
        height: auto !important;
        line-height: 28px !important;
    }

    /* ── POLOŽKY V KOŠÍKU ── */
    .cart-item {
        margin-bottom: 10px !important;
    }

    .cart-item-name a {
        font-size: 13px !important;
        line-height: 18px !important;
    }

    .cart-item-amount,
    .cart-item-price {
        font-size: 13px !important;
        line-height: 18px !important;
    }

    /* ── DOPRAVA A PLATBA ── */
    .recapitulation-single {
        font-size: 13px !important;
        line-height: 18px !important;
    }

    /* ── CELKOM ZA TOVAR ── */
    .order-summary-item.helper {
        font-size: 13px !important;
        line-height: 18px !important;
    }

    /* ── CELKOM K ÚHRADE ── */
    .price-label.price-primary {
        font-size: 18px !important;
        line-height: 28px !important;
    }

    .price.price-primary {
        font-size: 18px !important;
        line-height: 28px !important;
    }

    /* ── TLAČIDLÁ ── */
    .next-step {
        flex-direction: row !important;
        align-items: center !important;
        gap: 12px !important;
        margin-top: 16px !important;
    }

    #submit-order {
        height: 56px !important;
        min-width: 0 !important;
        flex: 1 !important;
        padding: 12px 16px !important;
    }

    #submit-order .order-button-text {
        font-size: 15px !important;
        line-height: 20px !important;
    }

    /* ── CO-BOX-ADDITIONAL ── */
    .co-box-additional {
        padding: 20px 12px !important;
        border-radius: 12px !important;
    }

    /* ── VLAJKY DROPDOWN - na mobile otvárať nahor ak málo miesta ── */
    .country-flags:focus-within .country-flags-inner,
    .country-flags:active .country-flags-inner {
        width: 240px !important;
        max-height: 280px !important;
    }
}

/* ── MALÉ MOBILY (max-width: 480px) ── */

@media (max-width: 480px) {

    /* ── SEKCIE ── */
    .co-contact-information,
    .co-billing-address,
    .co-shipping-address,
    .co-box-additional {
        padding: 14px 10px !important;
        border-radius: 10px !important;
    }

    /* ── NADPISY ── */
    .co-contact-information > h4,
    .co-contact-information > fieldset > h4,
    .co-billing-address > h4,
    .co-billing-address > fieldset > h4,
    .co-shipping-address > h4,
    .co-shipping-address > fieldset > h4 {
        font-size: 15px !important;
        height: 44px !important;
        padding: 8px 12px !important;
        margin: 0 0 16px 0 !important;
    }

    /* ── SIDEBAR ── */
    #checkoutSidebar .cart-content {
        padding: 16px 12px !important;
        border-radius: 10px !important;
    }

    /* ── TLAČIDLO OBJEDNAŤ ── */
    #submit-order {
        height: 52px !important;
        padding: 10px 14px !important;
    }

    #submit-order .order-button-text {
        font-size: 14px !important;
    }

    /* ── CELKOM K ÚHRADE ── */
    .price-label.price-primary,
    .price.price-primary {
        font-size: 17px !important;
        line-height: 26px !important;
    }
}