/* =====================================================================
   KARTY ODPORNOŚCI – REDESIGN BIZNESOWY (granatowa identyfikacja)
   Addytywny arkusz nadpisujący style Hello Elementor + WooCommerce.
   ===================================================================== */

/* ------------------------------------------------------------------
   1. ZMIENNE / SYSTEM PROJEKTOWY
   ------------------------------------------------------------------ */
:root {
	--koz-navy:        #0F2A4A;
	--koz-navy-700:    #163A63;
	--koz-navy-900:    #0A1E37;
	--koz-accent:      #E0A341;
	--koz-accent-700:  #C98A28;
	--koz-bg:          #FFFFFF;
	--koz-bg-soft:     #F5F7FA;
	--koz-text:        #1A2330;
	--koz-muted:       #5B6675;
	--koz-border:      #E4E8EE;
	--koz-radius:      14px;
	--koz-radius-sm:   10px;
	--koz-shadow:      0 6px 24px rgba(15, 42, 74, 0.08);
	--koz-shadow-lg:   0 14px 40px rgba(15, 42, 74, 0.14);
	--koz-transition:  all .25s ease;
	--koz-font-head:   "Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", sans-serif;
	--koz-font-body:   "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* Nadpisanie globalnych zmiennych Elementora (nagłówek/stopka zbudowane w Elementorze) */
.elementor-kit-6 {
	--e-global-color-primary:   #0F2A4A;
	--e-global-color-secondary: #163A63;
	--e-global-color-text:      #1A2330;
	--e-global-color-accent:    #E0A341;
	--e-global-typography-primary-font-family:   "Plus Jakarta Sans";
	--e-global-typography-secondary-font-family: "Plus Jakarta Sans";
	--e-global-typography-text-font-family:       "Inter";
	--e-global-typography-accent-font-family:     "Inter";
}

/* ------------------------------------------------------------------
   2. TYPOGRAFIA / BAZA
   ------------------------------------------------------------------ */
body {
	font-family: var(--koz-font-body);
	color: var(--koz-text);
	background: var(--koz-bg);
	-webkit-font-smoothing: antialiased;
	line-height: 1.65;
}

h1, h2, h3, h4, h5, h6,
.page-title,
.woocommerce-loop-product__title,
.product_title {
	font-family: var(--koz-font-head);
	color: var(--koz-navy);
	letter-spacing: -0.01em;
	line-height: 1.2;
}

a { color: var(--koz-navy-700); text-decoration: none; transition: var(--koz-transition); }
a:hover { color: var(--koz-accent-700); }

/* Szerszy, spójny kontener treści sklepu */
.woocommerce-page .site-main,
body.woocommerce .site-main {
	max-width: 920px;
	margin-inline: auto;
	padding: 48px 24px 72px;
}

/* ------------------------------------------------------------------
   3. NAGŁÓWEK (Header Footer Elementor)
   ------------------------------------------------------------------ */
.ehf-header #masthead,
header.site-header {
	box-shadow: 0 2px 16px rgba(15, 42, 74, 0.06);
	background: #fff;
}

/* Linki menu – czarny tekst, bez tła */
.hfe-nav-menu .menu-item > a.hfe-menu-item,
.hfe-masthead-custom-menu-items.woocommerce-custom-menu-item a,
.hfe-creative-menu.menu-item-type-custom > a {
	font-family: var(--koz-font-head);
	font-weight: 600;
	color: #000 !important;
	letter-spacing: .01em;
	background: none !important;
	padding: 0;
	border-radius: 0;
	display: inline;
	transition: var(--koz-transition);
}
.hfe-nav-menu .menu-item > a.hfe-menu-item:hover,
.hfe-nav-menu .menu-item.current-menu-item > a.hfe-menu-item,
.hfe-masthead-custom-menu-items.woocommerce-custom-menu-item a:hover,
.hfe-creative-menu.menu-item-type-custom > a:hover {
	color: var(--koz-navy-700) !important;
	background: none !important;
	transform: none;
}

/* Koszyk w nagłówku */
.hfe-site-header-cart .hfe-cart-count,
.hfe-cart-count {
	background: var(--koz-navy);
	color: #fff;
	font-weight: 700;
	border-radius: 999px;
}
.hfe-site-header-cart a:hover { color: var(--koz-navy-700); }

/* ------------------------------------------------------------------
   4. SKLEP – NAGŁÓWEK ARCHIWUM + PASEK SORTOWANIA
   ------------------------------------------------------------------ */
.woocommerce-products-header {
	text-align: center;
	margin-bottom: 40px;
}
.woocommerce-products-header__title.page-title {
	font-size: clamp(2rem, 4vw, 2.8rem);
	font-weight: 800;
	position: relative;
	display: inline-block;
	padding-bottom: 18px;
}
.woocommerce-products-header__title.page-title::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 64px;
	height: 4px;
	border-radius: 4px;
	background: var(--koz-accent);
}

.woocommerce .woocommerce-result-count {
	color: var(--koz-muted);
	font-size: .92rem;
	margin-top: 6px;
}
.woocommerce .woocommerce-ordering select.orderby {
	font-family: var(--koz-font-body);
	border: 1px solid var(--koz-border);
	border-radius: var(--koz-radius-sm);
	padding: 10px 38px 10px 14px;
	background-color: #fff;
	color: var(--koz-text);
	cursor: pointer;
	transition: var(--koz-transition);
}
.woocommerce .woocommerce-ordering select.orderby:hover { border-color: var(--koz-navy); }

/* ------------------------------------------------------------------
   5. SIATKA PRODUKTÓW / KARTY
   ------------------------------------------------------------------ */
.woocommerce ul.products,
.woocommerce-page ul.products {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 28px;
	margin: 0;
}
/* Usunięcie clearfixów Woo – w gridzie tworzą puste komórki */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after { display: none !important; }

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	background: #fff;
	border: 1px solid var(--koz-border);
	border-radius: 0;
	padding: 16px 16px 22px;
	display: flex;
	flex-direction: column;
	box-shadow: var(--koz-shadow);
	transition: var(--koz-transition);
}
.woocommerce ul.products li.product:hover {
	transform: translateY(-6px);
	box-shadow: var(--koz-shadow-lg);
	border-color: #d4dbe6;
}

.woocommerce ul.products li.product a.woocommerce-LoopProduct-link {
	display: flex;
	flex-direction: column;
	flex: 1;
}
.woocommerce ul.products li.product img {
	border-radius: 0;
	margin-bottom: 16px;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	background: var(--koz-bg-soft);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.08rem;
	font-weight: 700;
	color: var(--koz-navy);
	padding: 0 0 8px;
	min-height: 2.6em;
}

/* Cena */
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price {
	color: var(--koz-navy);
	font-family: var(--koz-font-head);
	font-weight: 800;
	font-size: 1.2rem;
}
.woocommerce ul.products li.product .price { margin: 0 0 14px; }
.woocommerce del { color: var(--koz-muted); font-weight: 500; opacity: .7; }
.woocommerce ins { text-decoration: none; }

/* Plakietka promocji */
.woocommerce span.onsale {
	background: var(--koz-accent);
	color: var(--koz-navy-900);
	font-family: var(--koz-font-head);
	font-weight: 700;
	border-radius: 999px;
	padding: 6px 14px;
	min-height: 0;
	min-width: 0;
	line-height: 1;
	top: 14px;
	left: 14px;
	box-shadow: var(--koz-shadow);
}

/* ------------------------------------------------------------------
   6. PRZYCISKI (globalnie)
   ------------------------------------------------------------------ */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.wc-block-components-button {
	font-family: var(--koz-font-head);
	font-weight: 700;
	letter-spacing: .01em;
	background: var(--koz-navy);
	color: #fff;
	border: none;
	border-radius: 999px;
	padding: 13px 24px;
	transition: var(--koz-transition);
	box-shadow: 0 4px 14px rgba(15, 42, 74, 0.18);
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.wc-block-components-button:hover {
	background: var(--koz-navy-700);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: var(--koz-shadow-lg);
}

/* Przycisk „dodaj do koszyka” na karcie – pełna szerokość, akcent przy hover */
.woocommerce ul.products li.product .button.add_to_cart_button {
	margin-top: auto;
	width: 100%;
	text-align: center;
}
.woocommerce ul.products li.product .button.add_to_cart_button:hover {
	background: var(--koz-accent);
	color: var(--koz-navy-900);
}
.woocommerce ul.products li.product .added_to_cart {
	display: block;
	text-align: center;
	margin-top: 10px;
	font-weight: 600;
	color: var(--koz-accent-700);
}

/* Przycisk-duszek (np. „Wyświetl koszyk”) */
.woocommerce a.button.wc-forward,
.woocommerce .button.added_to_cart {
	background: #fff;
	color: var(--koz-navy);
	border: 1.5px solid var(--koz-navy);
	box-shadow: none;
}
.woocommerce a.button.wc-forward:hover { background: var(--koz-navy); color: #fff; }

/* ------------------------------------------------------------------
   7. KOMUNIKATY / NOTYFIKACJE WOO
   ------------------------------------------------------------------ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top: none;
	border-left: 4px solid var(--koz-navy);
	border-radius: var(--koz-radius-sm);
	background: var(--koz-bg-soft);
	box-shadow: var(--koz-shadow);
}
.woocommerce-message::before { color: var(--koz-navy); }
.woocommerce-message { border-left-color: var(--koz-accent); }
.woocommerce-message::before { color: var(--koz-accent-700); }

/* ------------------------------------------------------------------
   8. STRONA PRODUKTU
   ------------------------------------------------------------------ */
.woocommerce div.product .product_title { font-size: clamp(1.6rem, 3vw, 2.3rem); font-weight: 800; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	border-bottom-color: var(--koz-accent);
}
.woocommerce div.product .quantity .qty {
	border: 1px solid var(--koz-border);
	border-radius: var(--koz-radius-sm);
	padding: 10px;
}
.woocommerce div.product form.cart .button { padding: 14px 30px; }
.woocommerce div.product .images img { border-radius: var(--koz-radius); }

/* ------------------------------------------------------------------
   9. KOSZYK / ZAMÓWIENIE / KONTO
   ------------------------------------------------------------------ */
.woocommerce table.shop_table {
	border: 1px solid var(--koz-border);
	border-radius: var(--koz-radius);
	overflow: hidden;
	border-collapse: separate;
}
.woocommerce table.shop_table thead th {
	background: var(--koz-bg-soft);
	font-family: var(--koz-font-head);
	color: var(--koz-navy);
}
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
	background: var(--koz-bg-soft);
	border: 1px solid var(--koz-border);
	border-radius: var(--koz-radius);
	padding: 22px;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-container .select2-selection {
	border: 1px solid var(--koz-border) !important;
	border-radius: var(--koz-radius-sm) !important;
	padding: 12px 14px;
	font-family: var(--koz-font-body);
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
	border-color: var(--koz-navy) !important;
	outline: none;
	box-shadow: 0 0 0 3px rgba(15, 42, 74, 0.08);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
	color: var(--koz-accent-700);
	font-weight: 700;
}

/* ------------------------------------------------------------------
   10. STOPKA (Header Footer Elementor)
   ------------------------------------------------------------------ */
/* ===== PREMIUM STOPKA (ciemna, granatowa) ===== */
#colophon {
	position: relative;
	background: var(--koz-navy-900);
	color: rgba(255, 255, 255, 0.80);
	font-family: var(--koz-font-body);
}
/* Akcentowa linia u góry */
#colophon::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--koz-accent), var(--koz-accent-700));
}
/* Kontenery przezroczyste – tło niesie <footer> */
#colophon .e-con,
#colophon .e-con-inner,
#colophon .elementor-element { background-color: transparent !important; }

/* Oddech sekcji */
#colophon > .e-con,
#colophon .e-con.e-parent { padding-block: 8px; }
#colophon .e-con.e-parent:first-of-type { padding-top: 60px; }

/* Nagłówki kolumn */
#colophon .elementor-heading-title {
	font-family: var(--koz-font-head);
	color: #fff;
	letter-spacing: .01em;
}
/* Mniejsze nagłówki kolumn (Social media / Ważne linki) z akcentem */
#colophon .elementor-element-0327448 .elementor-heading-title {
	font-size: 1.05rem;
	font-weight: 700;
	margin-bottom: 14px;
	padding-bottom: 10px;
	position: relative;
}
#colophon .elementor-element-0327448 .elementor-heading-title::after {
	content: "";
	position: absolute;
	left: 0; bottom: 0;
	width: 34px; height: 3px; border-radius: 3px;
	background: var(--koz-accent);
}

/* Tekst i akapity */
#colophon p,
#colophon li,
#colophon .elementor-widget-text-editor { color: rgba(255, 255, 255, 0.72); line-height: 1.7; }

/* Wyróżniony telefon (h1 w opisie marki) */
#colophon h1 {
	color: #fff;
	font-family: var(--koz-font-head);
	font-weight: 800;
	font-size: 1.5rem;
	margin: 18px 0 0;
}

/* Listy linków */
#colophon ul { list-style: none; margin: 0; padding: 0; }
#colophon li { margin-bottom: 10px; }
#colophon a {
	color: rgba(255, 255, 255, 0.72);
	transition: var(--koz-transition);
}
#colophon a:hover { color: var(--koz-accent); }

/* Social jako pigułki (po href) */
#colophon li:has(a[href*="facebook.com"]),
#colophon li:has(a[href*="linkedin.com"]),
#colophon li:has(a[href*="instagram.com"]) {
	display: inline-block;
	margin: 0 8px 8px 0;
}
#colophon a[href*="facebook.com"],
#colophon a[href*="linkedin.com"],
#colophon a[href*="instagram.com"] {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	padding: 9px 18px;
	border-radius: 999px;
	font-weight: 600;
	font-family: var(--koz-font-head);
}
#colophon a[href*="facebook.com"]:hover,
#colophon a[href*="linkedin.com"]:hover,
#colophon a[href*="instagram.com"]:hover {
	border-color: var(--koz-accent);
	background: rgba(224, 163, 65, 0.12);
	color: var(--koz-accent);
	transform: translateY(-1px);
}
/* Ikonki portali (maska w kolorze tekstu) */
#colophon a[href*="facebook.com"]::before,
#colophon a[href*="linkedin.com"]::before,
#colophon a[href*="instagram.com"]::before {
	content: "";
	width: 16px;
	height: 16px;
	flex: 0 0 16px;
	background-color: currentColor;
	-webkit-mask: center / contain no-repeat;
	mask: center / contain no-repeat;
}
#colophon a[href*="facebook.com"]::before {
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.101 23.691v-7.98H6.627v-3.667h2.474v-1.58c0-4.085 1.848-5.978 5.858-5.978.401 0 .955.042 1.468.103a8.68 8.68 0 0 1 1.141.195v3.325a8.623 8.623 0 0 0-.653-.036 26.805 26.805 0 0 0-.733-.009c-.707 0-1.259.096-1.675.309a1.686 1.686 0 0 0-.679.622c-.258.42-.374.995-.374 1.752v1.297h3.919l-.386 2.103-.287 1.564h-3.246v8.245C19.396 23.238 24 18.179 24 12.044c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.628 3.874 10.35 9.101 11.647Z'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9.101 23.691v-7.98H6.627v-3.667h2.474v-1.58c0-4.085 1.848-5.978 5.858-5.978.401 0 .955.042 1.468.103a8.68 8.68 0 0 1 1.141.195v3.325a8.623 8.623 0 0 0-.653-.036 26.805 26.805 0 0 0-.733-.009c-.707 0-1.259.096-1.675.309a1.686 1.686 0 0 0-.679.622c-.258.42-.374.995-.374 1.752v1.297h3.919l-.386 2.103-.287 1.564h-3.246v8.245C19.396 23.238 24 18.179 24 12.044c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.628 3.874 10.35 9.101 11.647Z'/%3E%3C/svg%3E");
}
#colophon a[href*="linkedin.com"]::before {
	-webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433a2.062 2.062 0 0 1-2.063-2.065 2.064 2.064 0 1 1 2.063 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z'/%3E%3C/svg%3E");
	mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20.447 20.452h-3.554v-5.569c0-1.328-.027-3.037-1.852-3.037-1.853 0-2.136 1.445-2.136 2.939v5.667H9.351V9h3.414v1.561h.046c.477-.9 1.637-1.85 3.37-1.85 3.601 0 4.267 2.37 4.267 5.455v6.286zM5.337 7.433a2.062 2.062 0 0 1-2.063-2.065 2.064 2.064 0 1 1 2.063 2.065zm1.782 13.019H3.555V9h3.564v11.452zM22.225 0H1.771C.792 0 0 .774 0 1.729v20.542C0 23.227.792 24 1.771 24h20.451C23.2 24 24 23.227 24 22.271V1.729C24 .774 23.2 0 22.222 0h.003z'/%3E%3C/svg%3E");
}

/* Logo w stopce (kolorowy znak KOP) – na jasnym chipie dla czytelności na ciemnym tle */
#colophon .elementor-widget-image img {
	background: #fff;
	padding: 14px 18px;
	border-radius: var(--koz-radius-sm);
	max-width: 200px;
	height: auto;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
}

/* Dolny pasek (copyright) */
#colophon .e-con.e-parent:last-of-type {
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	margin-top: 12px;
	padding-block: 22px;
}
#colophon .e-con.e-parent:last-of-type .elementor-heading-title {
	font-family: var(--koz-font-body);
	font-size: .9rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.55);
}
#colophon .e-con.e-parent:last-of-type .elementor-heading-title::after { display: none; }

/* ------------------------------------------------------------------
   10b. SEKCJA „O MARCE”
   ------------------------------------------------------------------ */
/* Sekcja pełnoszerokowa „klei się” do stopki – kasujemy dolny padding main na sklepie */
.woocommerce-shop .site-main,
.post-type-archive-product .site-main { padding-bottom: 0 !important; }

.koz-about {
	clear: both;
	margin: 72px calc(50% - 50vw) 0;
	padding: 72px 24px;
	background: var(--koz-bg-soft);
	border-top: 1px solid var(--koz-border);
}
.koz-about__inner {
	max-width: 1100px;
	margin-inline: auto;
	text-align: center;
}
.koz-about__eyebrow {
	display: inline-block;
	font-family: var(--koz-font-head);
	font-weight: 700;
	font-size: .8rem;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--koz-accent-700);
	margin-bottom: 12px;
}
.koz-about__title {
	font-size: clamp(1.8rem, 3.5vw, 2.6rem);
	font-weight: 800;
	margin: 0 0 18px;
}
.koz-about__lead {
	max-width: 760px;
	margin: 0 auto 44px;
	font-size: 1.1rem;
	color: var(--koz-muted);
}
.koz-about__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	text-align: left;
}
.koz-about__card {
	background: #fff;
	border: 1px solid var(--koz-border);
	padding: 28px 26px;
	box-shadow: var(--koz-shadow);
}
.koz-about__card h3 {
	font-size: 1.15rem;
	font-weight: 700;
	margin: 0 0 10px;
	padding-left: 16px;
	border-left: 4px solid var(--koz-accent);
}
.koz-about__card p { margin: 0; color: var(--koz-muted); }

@media (max-width: 768px) {
	.koz-about { padding: 56px 16px; margin-top: 56px; }
	.koz-about__grid { grid-template-columns: 1fr; }
}

/* ------------------------------------------------------------------
   11. RWD
   ------------------------------------------------------------------ */
@media (max-width: 768px) {
	.woocommerce-page .site-main { padding: 32px 16px 56px; }
}
@media (max-width: 480px) {
	.woocommerce ul.products,
	.woocommerce-page ul.products { grid-template-columns: 1fr !important; }
}
