@font-face {
    font-family: 'Satoshi';
    src: url('../fonts/Satoshi-Regular.woff2') format('woff2');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Satoshi';
    src: url('../fonts/Satoshi-Medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Satoshi';
    src: url('../fonts/Satoshi-Bold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

:root {
    --primary-color: #000000;
    --secondary-color: #ffffff;
    --accent-color: #c5a47e; 
    --text-color: #333333;
    --bg-color: #f9f9f9;
    
    --font-main: 'Satoshi', sans-serif; 
    --font-heading: 'Satoshi', sans-serif; 
}

html, body {
    overflow-x: hidden;
    width: 100%;
}

body {
    font-family: var(--font-main);
    color: var(--text-color);
    background-color: var(--bg-color);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;	
    margin: 0;
    padding: 0;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 500;
}

a {
    text-decoration: none;
    color: inherit;
    transition: 0.3s;
}

ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

.main-logo-white {display: none;}

.flex-row { display: flex; flex-wrap: wrap; }
.align-center { align-items: center; }
.j-center { justify-content: center; }
.text-center { text-align: center; }

.footer-container {
    max-width: 1550px;
    margin: 0 auto;
    width: 100%;
}

.space-between { justify-content: space-between; }

.footer-eco-bar {
    background: #696969;
    height: 88px;
    color: #fff;
    display: flex;
    align-items: center;
}

.footer-eco-bar .footer-container {
    justify-content: space-between; 
}

.eco-brand-group {
    display: flex;
    align-items: center;
}

.eco-flag {
    margin-right: 15px; 
}

.footer-eco-bar span {
    font-size: 13px; 
    font-weight: 400;
    letter-spacing: 0.1em; 
    white-space: nowrap;
    text-transform: uppercase;
}

.eco-text-labels span {
    margin-right: 0;
}

.footer-main-content {
    background: #E8E7E5;
    padding: 80px;
}

.footer-logo-row {
    padding-bottom: 65px;
}

.footer-logo-row img {
    width: 364px;
    height: auto;
}

.footer-columns-row {
    display: flex;
    justify-content: space-between;	
}

.footer-col {
    color: #000;
    font-size: 17px;
    line-height: 1.6;
    display: flex;
}

.col-30 { width: 30%; }
.col-links { width: 20%; }
.col-contact { width: 30%; }

.pl-50 { padding-left: 50px; }

.footer-links-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links-menu li {
    margin-bottom: 10px;
}

.footer-links-menu li a {
    text-decoration: none;
    color: #000;
    font-weight: 400;
    text-transform: uppercase;
    font-size: 17px;
}

.footer-links-menu li a:hover {
    opacity: 0.7;
}

address {
    font-style: normal;
}

address a {
    color: #000;
    text-decoration: none;
    display: block;
    margin-top: 5px;
}

/* 3. BOTTOM ROW */
.footer-bottom-row {
    border-top: 1px solid rgba(0,0,0,0.1);
    padding-top: 30px;
    min-height: 68px;
    display: flex;
    justify-content: space-between;	
}

.footer-payments {
    display: flex;
    align-items: center;
    gap: 20px;
}

a.footer-social-icon {
    display: flex;
    align-items: center;
} 

.payment-icon svg {
    height: 25px;
    width: auto;
}

.btn-footer-contact {
    display: block;
    border: 1px solid #000;
    padding: 12px 30px;
    text-align: center;
    text-decoration: none;
    color: #000;
    font-weight: 600;
    transition: all 0.3s;
}

.btn-footer-contact:hover {
    background: #000;
    color: #fff;
}

/* 4. AUTHOR BAR */
.footer-author-bar {
    width: 100%;
    background: #000;
    min-height: 30px;
    text-align: center;
    padding: 0.5em 0;
}

.footer-author-bar a {
    color: #888;
    text-decoration: none;
    font-size: 13px;
    text-transform: uppercase;
}

.footer-socials {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding-left: 25px;	
}

/* --- HEADER BASE --- */
.site-header {
    position: absolute; 
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
    padding: 10px 0; 
    height: 74px;
    display: flex;
    align-items: center;
    background: transparent;
}

.header-container {
    max-width: 1710px;
    width: 100%;
    margin: 0 auto;
    padding: 0 clamp(20px, 4vw, 80px); 
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.header-column {
    flex: 1;
    display: flex;
    align-items: center;
}

.header-center {
    justify-content: center;
    flex: 0 1 auto;
    min-width: fit-content;
    padding: 0 20px;
}

.header-right { justify-content: flex-end; }

img.main-logo {
    height: auto;
}

/* --- NAVIGATION --- */
.nav-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: clamp(10px, 1.5vw, 25px); 
    align-items: center;
}

.nav-menu li a {
    /* font-family: 'Satoshi', sans-serif; */
    font-weight: 600;
/*     font-size: clamp(10px, 0.75vw, 12px);  */
	 /* font-size: clamp(14px, 0.75vw, 15px);  */
	/* font-size: clamp(0.875rem, 0.6vw + 0.5rem, 1.25rem); */
	font-size: clamp(14px, 0.75vw, 17px); 
    line-height: 20px;
    color: #000;
    text-transform: uppercase;
    text-decoration: none;
    white-space: nowrap; 
    padding: 7px 0;
    position: relative;
}

.nav-menu li a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.nav-menu li a:hover::after {
    transform: scaleX(1);
}

.header-right-flex {
    display: flex;
    align-items: center;
    gap: 30px; 
}

.nav-menu.header-right-menu {
    display: flex;
    align-items: center;
    gap: 25px; 
}

/* --- DROPDOWNS (Lang & Currency) --- */
.header-controls {
    display: flex;
    align-items: center;
    gap: clamp(10px, 1.2vw, 20px);
    margin-left: clamp(10px, 1.5vw, 30px);
}

.custom-dropdown {
    position: relative;
    padding-bottom: 15px; 
    margin-bottom: -15px; 
}

.dropdown-trigger {
    display: flex;
    align-items: center;
    gap: 6px;
    /* font-family: 'Satoshi', sans-serif; */
    font-weight: 600;
    font-size: clamp(12px, 0.75vw, 15px);
    text-transform: uppercase;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    white-space: nowrap;
}

.dropdown-list li img, 
.lang-dropdown img {
    display: none !important;
}

.dropdown-list {
    display: none;
    position: absolute;
    top: 100%; 
    left: 50%;
    transform: translateX(-50%);
    background: #ffffff;
    border-radius: 12px;
    min-width: 145px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18);
    padding: 13px 0;
    margin-top: 0; 
    list-style: none;
    z-index: 100;
}

.dropdown-list::before {
    content: '';
    position: absolute;
    top: -15px; 
    left: 0;
    right: 0;
    height: 15px;
    background: transparent;
}

.dropdown-list li {
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.dropdown-list li a {
    color: #000000 !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    display: block !important;
    padding: 10px 20px !important;
    text-align: center;
    text-transform: uppercase;
    text-decoration: none !important;
}

.dropdown-list li a:hover {
    background-color: #f5f5f5 !important; 
}

.custom-dropdown:hover .dropdown-list {
    display: block;
    animation: currencyFade 0.2s ease forwards;
}

.currency-dropdown .dropdown-list li {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}

@keyframes currencyFade {
    from { opacity: 0; transform: translateX(-50%) translateY(10px); }
    to { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* --- KOSZYK IKONA --- */
.cart-icon-trigger {
    position: relative;
    display: flex;
    align-items: center;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
}

.cart-count {
    position: absolute;
    top: -5px;
    right: -8px;
    background: #D13333;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;	
}

/* --- SIDE CART CONTAINER (LOGIKA WYSUNIĘCIA) --- */
.side-cart {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
    visibility: hidden;
    transition: visibility 0.4s;
}

.side-cart.active {
    visibility: visible;
}

.side-cart-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    opacity: 0;
    transition: opacity 0.4s;
}

.side-cart.active .side-cart-overlay {
    opacity: 1;
}

.side-cart-content {
    position: absolute;
    top: 0;
    right: -420px;
    width: 100%;
    max-width: 420px;
    height: 100vh;
    background: #fff;
    transition: right 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    box-shadow: -5px 0 15px rgba(0,0,0,0.05);
    overflow: hidden;
}

.side-cart.active .side-cart-content {
    right: 0;
}

/* --- SIDE CART INTERNALS (WNĘTRZE) --- */

.side-cart-content {
    position: absolute;
    right: -420px;
    top: 0;
    width: 100%;
    max-width: 420px;
    height: 100vh;
    max-height: 100vh;
    background: #fff;
    transition: right 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    box-shadow: -5px 0 15px rgba(0,0,0,0.05);
    overflow: hidden;
    height: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;	
}

.side-cart.active .side-cart-content {
    right: 0;
}

.widget_shopping_cart_content {
    height: 100%;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.side-cart-header {
    flex: 0 0 auto;
    padding: 25px 30px;
    border-bottom: 1px solid #eee;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
}

.side-cart-title {
    font-weight: 600;
    font-size: 17px;
}

.side-cart-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px;
}

.side-cart-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 20px 30px;
    display: block;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.cart_list.product_list_widget,
.woocommerce-mini-cart {
    list-style: none;
    padding: 0;
    margin: 0;
    overflow: visible !important;
    max-height: none !important;
    height: auto !important;
}

.side-cart-footer {
    flex: 0 0 auto;
    padding: 24px 30px 30px;
    border-top: 1px solid #eee;
    background: #fff;
	box-shadow: 0 -6px 12px rgba(0,0,0,0.03);
}

/* LISTA PRODUKTÓW */

.mini-cart-item {
    display: flex;
    position: relative;
    padding: 20px 0;
    border-bottom: 1px solid #f5f5f5;
}

.mini-cart-item-remove {
    position: absolute;
    top: 28px;
    left: -10px;
    z-index: 5;
	display: flex;
	justify-content: center;
	align-items: center;	

    position: absolute;
    top: 50%;
    left: -18px;
    transform: translateY(-50%);
    z-index: 5;
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;	
}

.mini-cart-item-remove {
    position: absolute;
    top: 37px;
    left: -10px;
    z-index: 5;
	text-align: center;
}

.remove-item-link {
    color: #000;
    text-decoration: none;
    font-size: 18px;
    font-weight: 300;
    background: #fff;
    width: 20px;
    height: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
	border-radius: 50%;
    box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

.mini-cart-item-image {
	width: 75px;
	height: 75px;
	flex-shrink: 0;
	margin-right: 15px;	
	display: flex;
	align-items: center;
	justify-content: center;
}

.mini-cart-item-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
}

.mini-cart-item-info {
    flex-grow: 1;
}

.mini-cart-item-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 10px;
}

.mini-cart-item-name {
    font-weight: 600;
    font-size: 14px;
    max-width: 180px;
    line-height: 1.4;
    color: #000;
    text-decoration: none;
}

.mini-cart-item-price {
    font-size: 14px;
    font-weight: 400;
}

/* ILOŚĆ +/- */

.mini-cart-quantity-box {
    display: inline-flex;
    align-items: center;
    border: 1px solid #dcdcdc;
    background: #fff;	
}

.qty-btn {
    width: 40px;
    height: 36px;
    padding: 0;
    border: none;
    background: #fff;
    color: #000;
    cursor: pointer;
    font-size: 18px;
    line-height: 1;
    display: flex;
    align-items: center;
    justify-content: center;
}

.qty-input {
    width: 35px;
    height: 30px;
    border: none;
    border-left: 1px solid #e0e0e0;
    border-right: 1px solid #e0e0e0;
    text-align: center;
    font-size: 13px;
}

/* Awaryjnie ukrywamy strzałki, jeśli gdzieś zostanie type="number" */
.qty-input::-webkit-outer-spin-button,
.qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.qty-input[type="number"] {
    -moz-appearance: textfield;
}

/* STOPKA */

.side-cart-total {
    display: flex;
    justify-content: space-between;
    font-weight: 600;
    font-size: 16px;
    margin-bottom: 5px;
}

.tax-note {
    font-size: 12px;
    color: #777;
    margin-bottom: 20px;
    line-height: 1.4;
}

.btn-black.btn-full-width {
    width: 100%;
    background: #000;
    color: #fff;
    text-align: center;
    padding: 18px;
    text-decoration: none;
    text-transform: uppercase;
    font-weight: 600;
    letter-spacing: 1px;
    display: flex;
    justify-content: center;
    align-items: center;
	box-sizing: border-box;
}

/* KUPONY */

.side-cart-coupon {
    margin-bottom: 20px;
}

.coupon-toggle {
    background: none;
    border: none;
    font-weight: 600;
    font-size: 14px;
    padding: 10px 0;
    cursor: pointer;
    width: 100%;
    text-align: left;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: #000;
	background: #ededed;
	padding-left: 1em;
	padding-right: 1em;	
}

.coupon-toggle::after {
    content: "∨";
    font-size: 16px;
    line-height: 1;
    transition: transform 0.25s ease;
}

.side-cart-coupon.is-open .coupon-toggle::after {
    transform: rotate(180deg);
}


.coupon-form-wrapper {
    display: flex;
    gap: 0;
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    margin-top: 0;
    transition: max-height 0.25s ease, opacity 0.2s ease, margin-top 0.2s ease;
}

.side-cart-coupon.is-open .coupon-form-wrapper {
    max-height: 70px;
    opacity: 1;
    margin-top: 14px;
}

.coupon-form-wrapper input {
    flex-grow: 1;
    min-width: 0;
    border: 1px solid #e0e0e0;
    padding: 10px;
    font-size: 13px;
    height: 44px;
    box-sizing: border-box;
}

.coupon-form-wrapper .btn-black {
    padding: 10px 20px;
    font-size: 13px;
    margin-top: 0;
    height: 44px;
    padding: 10px 20px;
    font-size: 13px;
    margin-top: 0;
    border-radius: 0;	
}

/* --- SIDE CART FOOTER STICKY FIX --- */

.side-cart-content {
    height: 100vh;
    max-height: 100vh;
    overflow: hidden;
}

.widget_shopping_cart_content {
    height: 100%;
    max-height: 100%;
    overflow: hidden;
}

.side-cart-body {
    height: calc(100vh - 91px);
    overflow-y: auto;
    overflow-x: hidden;
    padding-bottom: 0;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
}

.side-cart-footer {
    position: sticky;
    bottom: 0;
    z-index: 20;
    background: #fff;
	padding-bottom: 20px;
	padding-right: 20px;
    border-top: 1px solid #eee;
    box-shadow: 0 -8px 20px rgba(0, 0, 0, 0.06);
}

.btn-black {
    display: inline-block;
    background: #000;
    color: #fff;
    padding: 15px 40px;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    margin-top: 20px;
    border-radius: 4px;
}

html.side-cart-open,
body.side-cart-open {
    overflow: hidden !important;
}

/* --- MOBILE MENU OVERLAY (1024px) --- */
.mobile-menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #F9F9F9;
    z-index: 11000;
    transform: translateY(-100%);
    transition: transform 0.5s cubic-bezier(0.77, 0, 0.175, 1);
    display: flex;
    flex-direction: column;
/*     overflow-y: auto;  */
    -webkit-overflow-scrolling: touch;	
}

.mobile-menu-overlay.active {
    transform: translateY(0);
}

.mobile-menu-header {
    padding: 20px;
    display: flex;
    justify-content: center;
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 10;
    border-bottom: 1px solid rgba(0,0,0,0.05);
    flex-shrink: 0;
}

.mobile-menu-close {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    cursor: pointer;
}

/* LISTA LINKÓW */
.mobile-nav-list {
    list-style: none;
    padding: 0;
    margin: 0;
    flex: 1 0 auto;
}

.mobile-nav-list li {
    border-bottom: 1px solid rgba(0,0,0,0.05);
}

.mobile-nav-list li a {
    display: block;
    padding: 16px 20px;
    font-size: 17px;
    font-weight: 500;
    text-transform: uppercase;
    color: #000;
    text-decoration: none;
    text-align: center;
    letter-spacing: 0.05em;
}

/* STOPKA MENU (Języki i Waluty) */
.mobile-menu-footer {
    /* margin-top: auto; */
    padding: 40px 20px 60px;
    background: #fff;
    flex-shrink: 0;
}

.mobile-switcher {
    margin-bottom: 25px;
    text-align: center;
}


.switcher-label {
    display: block;
    font-size: 12px;
    color: #888;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.mobile-lang-list, .mobile-currency-list {
    display: flex;
    justify-content: center;
    gap: 15px;
    list-style: none;
    padding: 0;
}

.mobile-lang-list, .mobile-currency-list {
    display: flex;
    justify-content: center;
    gap: 20px;
    list-style: none;
    padding: 0;
}

.m-curr, .mobile-lang-list li a {
    font-weight: 600;
    text-decoration: none;
    color: #000;
    /* font-family: 'Satoshi', sans-serif; */
}

.mobile-lang-list, .mobile-currency-list {
    display: flex;
    justify-content: center;
    gap: 20px;
    list-style: none;
    padding: 0;
}

.m-curr, .mobile-lang-list li a {
    font-weight: 600;
    font-size: 16px;
    text-decoration: none;
    color: #000;
    /* font-family: 'Satoshi', sans-serif; */
    text-transform: uppercase;
}

/* Aktywne stany */
.mobile-lang-list li.current-lang a,
.m-curr.is-active {
    text-decoration: underline;
    opacity: 1;
}

.m-curr, .mobile-lang-list li:not(.current-lang) a {
    opacity: 0.6; /* Nieaktywne są lekko bledsze */
}

/* GŁÓWNY KONTENER PRODUKTU */
/* Usunięcie marginesu pod nagłówkiem, by zdjęcie go dotykało */
.gardinale-product-page {
    padding-top: 70px;
}
.product-main-container {
	display: flex;
    flex-wrap: nowrap;
    width: 100%;
    max-width: none; /* Usuwamy ograniczenie szerokości */
    margin: 0;
    padding: 0; /* Usuwamy wszelkie marginesy i paddingi */
    align-items: flex-start;
}

/* LEWA KOLUMNA - GALERIA */
.product-gallery-side {
    width: 50% !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 0; /* Usuwa mikro-odstępy między zdjęciami */
}

.stack-img {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 0 23px 0;
}

/* PRAWA KOLUMNA - STICKY INFO */
.product-info-side {
    width: 50% !important;
    /* Zgodnie z Twoją obserwacją: padding tylko od góry i od prawej */
    /* Góra: 60px, Prawo: 5%, Dół: 60px, Lewo: 40px (dajemy mały odstęp, by tekst nie dotykał fizycznie zdjęcia) */
    padding: 10px 5% 60px 40px !important; 
    position: relative;
    box-sizing: border-box;
}

/* 4. Punkt przyklejenia dla prawej kolumny */
.product-sticky-box {
    position: sticky;
    top: 100px; /* Punkt parkowania pod nagłówkiem */
    height: auto;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start; /* Wszystko do lewej (do linii zdjęcia) */
}
/* TYPOGRAFIA I ELEMENTY */
.p-title {
    /* font-family: 'Satoshi', sans-serif; */
    font-size: 37px;
	line-height:1.2;
    text-transform: uppercase;
    font-weight: 400;
    margin-bottom: 10px;
    /* letter-spacing: 0.05em; */
	margin-top: 8px;
}

/* Usunięcie ewentualnych marginesów z nagłówków wewnątrz */
.p-title, .p-subtitle, .p-price {
    margin-left: 0;
    padding-left: 0;
    text-align: left;
}

.p-subtitle {
    /* font-family: 'Satoshi', sans-serif; */
    font-size: 21px;
    color: #666;
    margin-bottom: 12px;
    margin-top:0;
	line-height: 1.5;
}

.p-price .woocommerce-Price-amount {
    font-size: 28px;
    font-weight: 600;
    color: #000;
    font-family: 'Satoshi', sans-serif;
}

/* PRZYCISK DODAJ DO KOSZYKA */
.p-add-to-cart .single_add_to_cart_button {
    background: #000;
    color: #fff;
    border: none;
    padding: 18px 40px;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    width: 100%;
    margin-top: 20px;
    transition: opacity 0.3s;
}

.p-add-to-cart .single_add_to_cart_button:hover {
    opacity: 0.8;
}

/* Przycisk koszyka - upewnijmy się, że nie jest za szeroki, jeśli w produkcji był węższy */
.p-add-to-cart {
    width: 100%;
    max-width: 400px; /* Jeśli na produkcji był węższy, tu możemy to kontrolować */
}

/* AKORDEONY */
.p-accordions {
    margin-top: 50px;
	margin-top: 40px;
    border-top: 1px solid #0303031C;
}

.acc-item {
    border-bottom: 1px solid #0303031C;}

.acc-trigger {
    width: 100%;
	padding: 18px 0;
    background: none;
    border: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    text-transform: uppercase;
    /* font-family: 'Satoshi', sans-serif; */
    font-weight: 400;
    font-size: 20px;
    line-height: 30px;
    letter-spacing: 0.1em;
    color: #000;
    cursor: pointer;
    letter-spacing: 0.02em;
    transition: opacity 0.3s;	
}

.acc-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease-in-out; 
	font-size: 17px;
}

.acc-content.is-open {
    max-height: 2000px;
    transition: max-height 0.5s ease-in-out; 
    padding-bottom: 30px;
}

/* --- SEKCJA OPISU FULL WIDTH (Single Product) --- */
.p-section-fw {
    background-color: #ffffff;
    padding: 80px 0;
    width: 100%;
}

.p-container-narrow {
    max-width: 1240px;
    margin: 0 auto;
}

/* --- TYPOGRAFIA W SEKCJI FW --- */

.p-section-fw h2 {
    /* font-family: "Satoshi", sans-serif; */
    font-size: 33px;
    font-weight: 500;
    line-height: 45px;
    color: #000;
    margin-bottom: 30px;
    text-align: left; /* Zgodnie z produkcją AI-1 */
    text-transform: uppercase;
}

.p-section-fw h3, 
.p-section-fw h4, 
.p-section-fw h5 {
    /* font-family: "Satoshi", sans-serif; */
    font-weight: 600;
    margin-top: 40px;
    margin-bottom: 20px;
}

.p-section-fw p {
    font-size: 17px;
    font-weight: 400;
    line-height: 28px;
    color: #000;
    margin-bottom: 1em;
}

/* Listy punktowe */
.p-section-fw ul {
    margin-bottom: 25px;
    padding-left: 20px;
}

.p-section-fw li {
    /* font-family: "Satoshi", sans-serif; */
    font-size: 17px;
    line-height: 26px;
    margin-bottom: 8px;
    position: relative;
    list-style-type: disc; /* Lub customowy marker */
}

/* Tabele w sekcji FW (używamy tych samych zasad co w akordeonach) */
.p-section-fw table {
    width: 100%;
    border-collapse: collapse;
    margin: 40px 0;
    border: 1px solid #bfbfbf;
    font-size: 17px;
}

.p-section-fw th, 
.p-section-fw td {
    border: 1px solid #bfbfbf;
    padding: 15px;
    text-align: left;
    line-height: 22px;
}

.p-section-fw tbody tr:nth-child(odd) {
    background-color: #f6f6f6;
}




.acc-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease-out;
}
.acc-content.is-open {
    max-height: 2000px; /* Duża wartość, aby pomieścić długie tabele */
}

.p-pretitle {
	font-size: 21px;
	line-height: 32px;
}


.p-short-description {
    /* font-family: 'Satoshi', sans-serif; */
    font-size: 17px;
    line-height: 1.6;
    color: #333;
/*     margin-bottom: 40px;
    margin-top: 30px; */
}

/* Stylizacja listy w krótkim opisie (LION'S MANE itp.) */
.p-short-description ul {
    list-style: none;
    padding: 0;
    margin: 20px 0;
}

.p-short-description li {
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: 5px;
    letter-spacing: 0.05em;
}

/* Stylizacja logo liścia i etykiet pod spodem */
.p-short-description img {
    max-width: 100px;
    height: auto;
    margin: 20px 0 10px 0;
    display: block;
}

/* Układ: Ilość + Przycisk obok siebie */
.p-add-to-cart form.cart {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important; /* Wyrównanie do środka w pionie */
    gap: 12px; /* Odstęp między ilością a przyciskiem (dostosuj wg uznania) */
    margin-top: 30px;
    float: none !important;
    width: 100%;
}

/* Stylizacja pola ilości (Quantity) */
.p-add-to-cart .quantity {
	float: none !important;
    margin: 0 !important;
}


.p-add-to-cart .quantity input.qty {
    width: 60px;
    height: 55px;
    border: 1px solid #000;
    background-color: #fff;
    /* font-family: "Satoshi", sans-serif; */
    font-size: 13px;
    font-weight: 500;
    text-align: center;
    border-radius: 0;
}

/* Przycisk - czysty Flex-grow */
.p-add-to-cart .single_add_to_cart_button {
	float: none !important;
    flex: 0 1 auto; /* Przycisk nie rozciąga się na siłę, bierze szerokość z paddingu */
    /* Twoje style z produkcji */
    /* font-family: "Satoshi", sans-serif !important; */
    font-size: 13px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    color: #fff !important;
    background-color: #000 !important;
    border: 1px solid #000 !important;
    padding: 20px 38px !important; /* To definiuje szerokość przycisku */
    border-radius: 0 !important;
    cursor: pointer;
    white-space: nowrap; /* Zapobiega łamaniu tekstu */
    transition: all 0.2s !important;
}

/* Usunięcie strzałek w polu ilości (opcjonalnie dla czystego wyglądu) */
.p-add-to-cart input::-webkit-outer-spin-button,
.p-add-to-cart input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Stylizacja Przycisku DODAJ DO KOSZYKA */
.p-add-to-cart .single_add_to_cart_button {
    /* font-family: "Satoshi", sans-serif !important; */
    font-size: 13px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    color: #fff !important;
    background-color: #000 !important;
    
    border-style: solid !important;
    border-width: 1px 1px 1px 1px !important;
    border-color: #000 !important;
    border-radius: 0 0 0 0 !important;
    
    padding: 20px 38px 20px 38px !important;
    
    display: inline-block;
    cursor: pointer;
    flex-grow: 1; /* Przycisk rozciąga się na resztę kolumny */
    
    transition: all 0.2s !important;
    transition-duration: 0.2s !important;
    transition-delay: 0s !important;
}

.p-add-to-cart .single_add_to_cart_button:hover {
	background-color: #333 !important;
    border-color: #333 !important;
}

/* Ukrycie informacji o magazynie (jeśli na produkcji ich nie było w tym miejscu) */
.p-add-to-cart .stock {
    display: none !important;
}

.p-price {
    margin-top: 30px;
    /* font-family: 'Satoshi', sans-serif; */
}

.p-price .woocommerce-Price-amount {
    font-size: 32px;
	line-height:1;
    font-weight: 400;
    color: #000;
}

.p-price .woocommerce-Price-currencySymbol {
    font-size: 24px;
    margin-left: 5px;
}

/* --- TABELE W AKORDEONACH (Single Product) --- */

/* Wrapper dla tabeli - pozwala na scroll tylko gdy tabela się nie mieści */
.acc-content {
    overflow-x: auto; /* Zapewnia scroll poziomy jeśli tabela jest za szeroka */
}

.acc-content table {
    width: 100%;
    border-collapse: collapse;
    border-spacing: 0;
    margin-bottom: 20px;
    border: 1px solid #bfbfbf;
    background-color: transparent;
    font-size: 17px;
    font-weight: 400;
    line-height: 22px;
    color: #000;
}

/* Komórki nagłówka i zwykłe */
.acc-content th, 
.acc-content td {
    border: 1px solid #bfbfbf;
    padding: 12px 15px;
    text-align: left;
    vertical-align: middle;
}

/* Nagłówek tabeli (jeśli występuje thead) */
.acc-content th {
    font-weight: 600;
    text-align: center; /* Zgodnie z AI-1 nagłówki są wycentrowane */
}

/* Zebra Striping - naprzemienne kolory */
/* Pierwszy wiersz (odd), trzeci itd. mają kolor #f6f6f6 */
.acc-content tbody tr:nth-child(odd) {
    background-color: #f6f6f6;
}

/* Drugi wiersz (even), czwarty itd. mają kolor #fff */
.acc-content tbody tr:nth-child(even) {
    background-color: #ffffff;
}

/* --- SEKCJA DZIELONA (Split Section) --- */
.p-section-split {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    align-items: stretch;
    background-color: #f1e2ce;
}

/* Lewa Kolumna - Obrazek */
.split-img {
    flex: 0 0 50%;
    width: 50%;
    position: relative;
    overflow: hidden;
    min-height: 400px; /* Zabezpieczenie dla pustej kolumny */
}

.split-img img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Działa jak background-size: cover */
    display: block;
}

/* Prawa Kolumna - Tekst */
.split-txt {
    flex: 0 0 50%;
    width: 50%;
    display: flex;
    align-items: center; /* Centrowanie w pionie */
    justify-content: flex-start; /* Do lewej w poziomie */
    padding: 80px 0 80px 50px; /* Zgodnie z Twoimi danymi z produkcji */
    box-sizing: border-box;
}

.split-inner {
    max-width: 620px; /* Połowa z Twojego kontenera 1240px */
    padding-right: 40px; /* Margines bezpieczeństwa od prawej krawędzi ekranu */
}

/* Typografia wewnątrz sekcji dzielonej */
.split-inner h2 {
    /* font-family: "Satoshi", sans-serif; */
    font-size: 32px;
    font-weight: 600;
    line-height: 45px;
    color: #000;
    margin-bottom: 30px;
    text-transform: none; 
	font-size: clamp(24px, 4vw, 32px);
    line-height: 1.2;
    margin-bottom: 30px;
    font-weight: 600;
}

.split-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.split-list li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 20px;
    font-size: 1.15rem;
    line-height: 1.5;
    color: #1a1a1a;
}

.split-list li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0;
    font-weight: bold;
    color: #000;
}

.split-list li strong {
    font-weight: 700;
    display: inline-block;
    margin-right: 5px;
}

.split-inner .elementor-widget-text-editor {
    /* font-family: "Satoshi", sans-serif; */
    font-size: 20px;
    font-weight: 400;
    line-height: 35px;
    color: #000;
    text-align: start;
}

/* Stylizacja boldów w punktach */
.split-inner b, 
.split-inner strong {
    font-weight: 600;
}

/* --- SEKCJA PRZYCISKU MIĘDZY BLOKAMI --- */
.p-section-all-products {
    background-color: #ffffff;
    padding: 0 0 80px 0; /* Odstęp pod tekstem szyszynki, a nad przyciskiem */
}

.btn-black-shop {
    display: inline-block;
    background-color: #000000;
    color: #ffffff !important;
    padding: 16px 35px;
    /* font-family: "Satoshi", sans-serif; */
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: 0.1em;
    transition: background-color 0.3s, opacity 0.3s;
}

.btn-black-shop:hover {
    background-color: #333333;
    opacity: 0.9;
}

/* --- PRODUCT SLIDER SECTION --- */
.p-slider-section {
    padding: 80px 70px 120px 70px;
    background-color: #fff;
    overflow: hidden;
}

.p-slider-container {
    max-width: 1710px;
    margin: 0 auto;
	position: relative;
}

.slider-title {
    /* font-family: "Satoshi", sans-serif; */
    font-size: 20px;
    font-weight: 400;
    line-height: 26px;
    color: #000;
    text-transform: uppercase;
    margin-bottom: 40px;
    padding-bottom: 20px;
    border-bottom: 1px solid #000;
    display: inline-block;
    min-width: 250px;
}

/* Karta Produktu w Sliderze */
.slider-product-card {
    display: flex;
    flex-direction: column;
    text-decoration: none;
	color: #000 !important;
}

.slider-product-info {
    display: block !important;
    text-align: left;
}

.slider-product-img {
    width: 100%;
    aspect-ratio: 504 / 630;
    margin-bottom: 25px;
    background: #f6f6f6;
    overflow: hidden;
}

.slider-product-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.slider-product-info h3 {
    /* font-family: "Satoshi", sans-serif !important; */
    font-size: 20px !important;
    font-weight: 400 !important;
    line-height: 1.2 !important;
    color: #000 !important;
    margin: 0 0 8px 0 !important;
    text-transform: uppercase !important;
}

.slider-product-info p {
    /* font-family: "Satoshi", sans-serif !important; */
    font-size: 18px !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    color: #000 !important;
    margin: 0 0 10px 0 !important;
    text-transform: uppercase !important;
    opacity: 0.7;
}

.slider-product-info .price {
    display: block;
    /* font-family: "Satoshi", sans-serif !important; */
    font-size: 16px !important;
    font-weight: 400 !important;
    color: #000 !important;
}

/* Style nawigacji Glide.js */
#product-slider .glide__arrow {
    width: 44px;
    height: 44px;
    background: #fff;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    pointer-events: auto;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    border-radius: 0;
}

#product-slider .glide__arrow svg {
    width: 20px;
    height: 20px;
    stroke: #000;
}

.glide__arrow--left { transform: translateX(-20px); }
.glide__arrow--right { transform: translateX(20px); }

/* --- FIX STRZAŁEK SLIDERA --- */

#product-slider {
    position: relative; /* To jest kotwica dla strzałek */
    width: 100%;
}

#product-slider .glide__arrows {
    /* Usuwamy pozycjonowanie statyczne, wymuszamy absolutne */
    position: absolute !important;
    top: 35% !important; /* Ustawia strzałki mniej więcej w połowie wysokości obrazka */
    left: -25px !important;
    right: -25px !important;
    width: calc(100% + 50px) !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    pointer-events: none; /* Pozwala klikać w produkty pod spodem */
    z-index: 999;
}

#product-slider .glide__arrow {
    pointer-events: auto; /* Przywraca klikalność samym przyciskom */
    width: 44px;
    height: 44px;
    background: #ffffff;
    border: 1px solid #ebebeb;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transition: all 0.3s ease;
}

#product-slider .glide__arrow:hover {
    background: #000;
}

#product-slider .glide__arrow:hover svg {
    stroke: #fff;
}

#product-slider .glide__arrow svg {
    width: 20px;
    height: 20px;
    stroke: #000;
    fill: none;
}

.glide__arrow--disabled {
    opacity: 0.2;
    cursor: default;
    pointer-events: none;
}

.p-section-all-products-bottom {
    background-color: #fff;
    padding-bottom: 120px;
    margin-top: -40px;
}

.slider-footer-btn {
    display: flex;
    justify-content: flex-end;
    width: 100%;
}

.flex-end {
    display: flex;
    justify-content: flex-end;
}

.p-section-all-products-bottom {
    padding-bottom: 120px;
}

.p-short-description p {
    margin-bottom: 0;
    margin-top: 0;
}

.p-short-description p:last-child {
    margin-bottom: 0;
}

.acc-intro-pretitle,
.acc-intro-subtitle
{
	margin: 0 0 8px 0;
}

.shop-hero {
    display: flex;
    width: 100%;
    background-color: #ba6c3b;
    min-height: 85vh;
}

.shop-hero-text {
    flex: 0 0 50%;
    background-color: #ba6c3b;
    display: flex;
	align-items: flex-start;
    box-sizing: border-box;
	padding-left: 80px;
    padding-bottom: 80px;
    padding-right: 40px;
}

.shop-hero-image {
    flex: 0 0 50%;
}

.shop-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.shop-container {
    max-width: 1710px;
    margin: 0 auto;
    padding: 80px 20px;
}

.category-section-title {
    /* font-family: 'Satoshi', sans-serif; */
    font-size: 32px;
    font-weight: 500;
    text-transform: none;
    margin: 60px 0 40px 0;
    width: 100%;
    border-bottom: 1px solid #eee;
    padding-bottom: 20px;
}

/* Usuwamy czyszczenie floatów z WooCommerce */

.woocommerce ul.cart_list li, .woocommerce ul.product_list_widget li {
  padding: 0;
}

.products-grid::before, 
.products-grid::after {
    display: none !important;
    content: none !important;
}

.products-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    margin-left: -12.5px;
    margin-right: -12.5px;
    margin-bottom: 80px;
    list-style: none;
    padding: 0;
}

.product-card-item {
    text-align: left;
}

.product-card-image {
    background: #f6f6f6;
    margin-bottom: 20px;
    aspect-ratio: 1/1.25;
}

.product-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.product-card-title {
    font-size: 18px;
    line-height: 1.2;
    margin-bottom: 8px;
    display: block;
}

.product-card-subtitle {
    font-size: 15px;
    color: #666;
    margin-bottom: 10px;
}

.product-card-price {
    font-weight: 600;
    font-size: 16px;
}

.hero-title {
	/* font-family: "Satoshi", Sans-serif; */
	font-size: 45px;
	font-weight: 500;
    line-height: 45px;
	color:#000;
	margin-bottom:0;
}

p.hero-subtitle {
	font-size: 28px;
	font-weight: 500;
	line-height: 35px;
	color:#000;
}

/* --- 1. KONTENER GŁÓWNY SKLEPU --- */

/* 1. RESET WOOCOMMERCE DEFAULTS (Zabijamy style systemowe) */
.products-grid::before, 
.products-grid::after {
    display: none !important;
    content: none !important;
}

.shop-hero {
    display: flex;
    width: 100%;
    min-height: 85vh;
    background-color: #ba6c3b;
    overflow: hidden;
}

.shop-hero-col {
    flex: 0 0 50%;
    width: 50%;
    box-sizing: border-box;
}

.shop-hero-text {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding-left: 80px;
    padding-bottom: 80px;
    padding-right: 40px;
}

.hero-title {
    font-size: 45px;
    line-height: 45px;
    font-weight: 500;
    color: #000;
    margin: 0 0 15px 0;
    text-transform: capitalize;
}

.hero-subtitle {
    font-size: 28px;
    line-height: 35px;
    font-weight: 500;
    color: #000;
    margin: 0;
}

.shop-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}


.category-title-main {
    font-size: 42px;
    line-height: 45px;
    font-weight: 400;
    color: #000;
    margin: 0 0 45px 0;
    text-align: left;
}

.products-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    margin-left: -12.5px;
    margin-right: -12.5px;
    margin-bottom: 80px;
}

.product-card-item {
    display: flex !important;
    flex-direction: column;
    flex: 0 0 calc(33% - 25px) !important;
    max-width: calc(33% - 25px) !important;
    margin: 0 12.5px 60px 12.5px !important;
    text-decoration: none;
    color: inherit;
    box-sizing: border-box;
    transition: transform 0.3s ease;
}

.product-card-info {
    display: flex;
    flex-direction: column;
    flex-grow: 1;
}

.product-card-title {
    font-size: 20px;
    line-height: 1.2;
    font-weight: 400;
    color: #000;
    text-transform: uppercase;
    margin: 0 0 8px 0;
}

.product-card-subtitle {
    font-size: 18px;
    line-height: 1.2;
    font-weight: 400;
    color: #000;
    text-transform: uppercase;
    margin: 0 0 15px 0;
}

.product-card-price {
    font-size: 18px;
    line-height: 27px;
    font-weight: 600;
    color: #000;
    text-transform: uppercase;
}

.product-card-image {
    position: relative;
    background: #f6f6f6;
    width: 100%;
    aspect-ratio: 368 / 500;
    overflow: hidden;
    margin-bottom: 25px;
}

.product-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.4s ease-in-out;
}

.product-card-image .hover-img {
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
}

.product-card-item:hover .main-img {
    opacity: 0;
}

.product-card-item:hover .hover-img {
    opacity: 1;
}

.product-card-title {
    font-size: 20px;
    line-height: 1.2;
    font-weight: 400;
    color: #000;
    text-transform: uppercase;
    margin: 0 0 8px 0;
    display: block;
}

.product-card-subtitle {
    font-size: 18px;
    line-height: 1.2;
    font-weight: 400;
    color: #000;
    text-transform: uppercase;
    margin: 0 0 8px 0;
    display: block;

}

.product-card-price,
.product-card-price .amount {
    font-size: 18px;
    line-height: 27px;
    font-weight: 400;
    color: #000;
    text-transform: uppercase;
    display: block;
}


.shop-main-wrapper {
    padding: 100px 80px;
    max-width: 1710px;
    margin: 0 auto;
    box-sizing: border-box;
}

/* =========================================
                       slider 
   ========================================= */

/* --- FIX POZYCJONOWANIA --- */
.home-hero-slider .glide__slide {
    position: relative !important;
    overflow: hidden;
    height: 100vh;
}

/* Product slider - nie dziedziczy wysokości hero slidera */
#product-slider .glide__slide {
    height: auto !important;
    overflow: visible !important;
}

#product-slider .glide__track {
    overflow: hidden;
}

/* --- HERO SLIDER BASE --- */
.home-hero-slider {
    width: 100%;
    height: 100vh;
    background: #000;
    position: relative;
}

.slider-bg-img {
    width: 100%;
    height: 100vh;
    object-fit: cover;
    display: block;
	z-index: 1;
}

/* POZYCJONOWANIE VW / VH */
.slider-content-wrapper {
    position: absolute !important;
    z-index: 99;
    /* transform: translate(-50%, -50%); */
    width: auto;
    max-width: 300px;
    max-width: 800px;
	pointer-events: none;
}

.glide--fade .glide__slides {
    transform: none !important;
    width: 100% !important;
    display: block !important;
}

.slider-content-inner {
    pointer-events: auto; /* Przywracamy klikalność przycisków */
    padding: 20px;
}

/* TYPOGRAFIA SLIDERA */
.hero-slider-title {
    /* font-size: clamp(32px, 5vw, 65px); */
	font-size: clamp(24px, 4vw, 45px);
    line-height: 1.1;
    font-weight: 500;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.hero-slider-subtitle {
    font-size: clamp(16px, 1.2vw, 20px);
    line-height: 1.5;
    margin-bottom: 30px;
}

.btn-hero-slider {
    display: inline-block;
    padding: 16px 40px;
    border: 1px solid;
    text-transform: uppercase;
    font-weight: 600;
    font-size: 13px;
    letter-spacing: 0.1em;
    transition: 0.3s;
}

.btn-hero-slider:hover {
    background: #fff;
    color: #000 !important;
    border-color: #fff !important;
}

/* LOGIKA FADE (Przenikanie) */
.glide--fade .glide__slide {
    opacity: 0;
    transition: opacity 800ms ease-in-out;
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    opacity: 0;
    transition: opacity 800ms ease-in-out !important;
    z-index: 1;
}

.glide--fade .glide__slide--active {
    opacity: 1;
    z-index: 2;
}

/* BULLETS */
.glide__bullets {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 12px;
    z-index: 20;
}

.glide__bullet {
    width: 10px;
    height: 10px;
    background: rgba(255,255,255,0.3);
    border: 1px solid #fff;
    border-radius: 50%;
    cursor: pointer;
    padding: 0;
}

.glide__bullet--active {
    background: #fff;
}

/* --- SHOP VIDEO HERO --- */
.shop-video-hero {
    position: relative;
    width: 100%;
    line-height: 0; /* Usuwa lukę pod wideo */
    overflow: hidden;
}

.video-container {
    position: relative;
    width: 100%;
}

.hero-video-bg {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.video-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    padding: 89px; /* Twoje wytyczne */
    box-sizing: border-box;
}

.btn-kup-teraz {
    background-color: #000000;
    color: #ffffff;
    font-family: "Satoshi", sans-serif;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    text-transform: uppercase;
    width: 169px;
    height: 62px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.3s ease-in-out;
    letter-spacing: 1px;
}

.btn-kup-teraz:hover {
    background-color: #ffffff;
    color: #000000;
}

/* --- SHOP CONTACT SECTION (AI-1.png) --- */
.shop-contact-section {
    padding: 100px 20px;
    background-color: #fff;
    text-align: center;
}

.shop-contact-container {
    max-width: 800px;
    margin: 0 auto;
}

.contact-title {
    font-size: 48px;
    font-weight: 400;
    margin-bottom: 20px;
    font-family: "Satoshi", sans-serif;
}

.contact-subtitle {
    font-size: 18px;
    color: #000;
    margin-bottom: 50px;
    line-height: 1.4;
}

/* Formularz */
.gardinale-fake-form {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.form-row {
    display: flex;
/*     gap: 10px; */
}

.gardinale-fake-form input,
.gardinale-fake-form textarea {
    width: 100%;
    padding: 15px;
    border: 1px solid #e0e0e0;
    font-family: "Satoshi", sans-serif;
    font-size: 14px;
    text-transform: uppercase;
    color: #999;
}

.gardinale-fake-form textarea {
    height: 150px;
    resize: none;
}

.btn-wyslij {
    background: #000;
    color: #fff;
    border: none;
    padding: 20px 60px;
    font-family: "Satoshi", sans-serif;
    font-weight: 700;
    font-size: 16px;
    align-self: center; /* Wyśrodkowanie przycisku */
    cursor: pointer;
    margin-top: 20px;
}

/* --- SEKCJA KONTAKT - FIX KONFLIKTU WOOCOMMERCE --- */

/* Usuwamy wszelkie śmieci wstrzykiwane przez WooCommerce */
.gardinale-contact-form .gardinale-row::before,
.gardinale-contact-form .gardinale-row::after {
    display: none !important;
    content: none !important;
}

.gardinale-row {
    display: flex !important; /* Wymuszamy flex */
    gap: 20px;
    margin-bottom: 20px;
    width: 100%;
}

.gardinale-group {
    flex: 1;
    margin-bottom: 20px;
    text-align: left;
}

/* Reszta stylów bez zmian, ale z poprawionymi selektorami */
.gardinale-contact-form input[type="text"],
.gardinale-contact-form input[type="email"],
.gardinale-contact-form textarea {
    width: 100%;
    padding: 15px;
    border: 1px solid #D1D1D1;
    box-sizing: border-box; /* Kluczowe dla przylegania do krawędzi */
    font-family: "Satoshi", sans-serif;
}

/* Wyśrodkowanie kontenera */
.shop-contact-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 10px; /* Mały margines bezpieczeństwa dla krawędzi okna */
}

/* storna glowna sekcja pod sliderem */

/* Home Intro Section */
.home-intro {
    background-color: #ffffff;
    padding: 100px 20px;
    text-align: center;
}

.home-intro__wrapper {
    max-width: 650px;
    margin: 0 auto;
}

.home-intro__logo {
    margin-bottom: 40px;
}

.home-intro__logo img {
    max-width: 228px;
    height: auto;
}

.home-intro__title {
    font-weight: 500;
    font-size: 42px;
    line-height: 1.2;
    color: #000000;
    margin-bottom: 50px;
    letter-spacing: -0.01em;
}

.home-intro__text {
    font-weight: 400;
    font-size: 18px;
    line-height: 1.6;
    color: #000000;
}

.home-intro__text p {
    margin-bottom: 24px;
}

.home-intro__text p:last-child {
    margin-bottom: 0;
}


/* Home Split Section - Naprawa 1:1 */
.home-split {
    width: 100%;
    background-color: #ffffff;
    line-height: 0;
	box-sizing: border-box;
}

.home-split__row {
    display: flex;
    flex-wrap: wrap;
    min-height: 600px;
}

/* Kolumna tekstowa */
.home-split__content {
    box-sizing: border-box !important;
	flex: 0 0 50%;
    background-color: #c5beb0;
    display: flex;
    align-items: end;
    justify-content: flex-start;
    padding: 80px;
    line-height: normal;
}

.home-split__text-wrapper {
    max-width: 500px;
}

.home-split__title {
    font-family: 'Satoshi', sans-serif;
    font-size: 48px;
    font-weight: 500;
    line-height: 1.1;
    color: #000000;
    margin-bottom: 40px;
    letter-spacing: -0.02em;
}

.home-split__description {
    font-family: 'Satoshi', sans-serif;
    font-size: 18px;
    line-height: 1.6;
    color: #000000;
}

.home-split__description p {
    margin-bottom: 25px;
}

.home-split__footer-text {
    margin-top: 40px;
    font-weight: 500;
}

/* Kolumna mediów */
.home-split__media {
    flex: 0 0 50%;
    position: relative;
    overflow: hidden;
}

.home-split__media img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Zdjęcie wypełnia całą połowę */
    display: block;
}

/* Przycisk */
.btn-primary {
    display: inline-block;
    margin-top: 20px;
    padding: 18px 45px;
    background-color: #000000;
    color: #ffffff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    text-transform: none;
    transition: background 0.3s ease;
}


.category-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 30px;
    padding-bottom: 10px;
    border-bottom: 1px solid #eee;
}

.category-title-main {
    font-family: 'Satoshi', sans-serif;
    font-size: 32px;
    font-weight: 500;
    margin: 0;
    color: #000;
}

.category-all-link {
    font-family: 'Satoshi', sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    text-decoration: underline;
    color: #000;
    letter-spacing: 0.05em;
    transition: opacity 0.3s;
}

.category-all-link:hover {
    opacity: 0.6;
}


.flex-col-gar-wrapper {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    box-sizing: border-box;
	min-height: 110vh;
}

.col-items-txt-50 {
    flex: 0 0 50%;
    padding: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.txt-content-inner {
    max-width: 550px; /* Kontrola szerokości linii tekstu */
}

.col-items-fot-50 {
    flex: 0 0 50%;
    background-size: cover;
    background-position: center;
    min-height: 600px; /* Zapewnia widoczność zdjęcia */
}

/* Typografia wewnątrz sekcji */
.gar-title-main { font-size: 38px; margin-bottom: 20px; font-weight: 500; }
.gar-title-sub { font-size: 24px; margin-bottom: 25px; font-weight: 400; color: #333; }
.gar-text-content { font-size: 17px; line-height: 1.6; }

.home-full-banner {
    width: 100%;
    height: 80vh;
    background-size: cover;
    background-position: center;
    background-attachment: scroll;
    position: relative;
    display: flex;
    align-items: flex-end;
    justify-content: end;
    padding-bottom: 80px;
	min-height: 110vh;
}

/* Przycisk specyficzny dla banera */
.btn-banner {
    min-width: 200px;
    text-align: center;
    letter-spacing: 0.1em;
    padding: 20px 50px;
    background-color: #000;
    color: #fff;
    transition: transform 0.3s ease;
	position: relative;
	right: 80px;
}

.btn-banner:hover {
    transform: scale(1.05);
    background-color: #333;
}

/* --- SINGLE JOURNAL POST --- */

.journal-post-single {
    width: 100%;
}

/* Hero na całą wysokość */
.journal-hero {
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}

.journal-hero__overlay {
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,0.5) 100%);
    display: flex;
    align-items: flex-end; /* Tytuł na dole */
}

.journal-hero__container {
    width: 100%;
    padding: 0 80px; /* Odstawienie 80px od lewej i prawej */
    margin-bottom: 100px; /* 100px od dołu zdjęcia */
    box-sizing: border-box;
}

.journal-hero__title {
    font-family: 'Satoshi', sans-serif;
    font-size: 52px;
    line-height: 59px;
    font-weight: 500;
    color: #ffffff;
    margin: 0;
    max-width: 1100px;
}

/* Kontener treści */
.journal-entry-content {
    width: 100%;
    display: flex;
    justify-content: center;
    background-color: #ffffff;
}

.journal-entry-content__inner {
    width: 100%;
    max-width: 1440px; /* Szerokość maksymalna dla czytelności */
    padding: 80px; /* 80px paddingu z każdej strony */
    box-sizing: border-box;
    font-family: 'Satoshi', sans-serif;
    font-size: 18px;
    line-height: 1.7;
    color: #000000;
}

/* Stylizacja elementów wewnątrz treści (Gutenberg) */
.journal-entry-content__inner p {
    margin-bottom: 25px;
}

.journal-entry-content__inner h2 {
    font-size: 32px;
    margin-top: 50px;
    margin-bottom: 25px;
    font-weight: 500;
}

/* --- HEADER OVERRIDE DLA SINGLE POST --- */

/* 1. Zmiana kolorów linków i triggerów na biały */
.single-post .site-header .nav-menu li a,
.single-post .site-header .dropdown-trigger,
.single-post .site-header .cart-icon-trigger {
    color: #ffffff !important;
}

/* 2. Zmiana koloru linii pod linkami (hover) na białą */
.single-post .site-header .nav-menu li a::after {
    background-color: #ffffff !important;
}

/* 3. Zmiana koloru ikon SVG (koszyk, strzałki) na biały */
.single-post .site-header svg,
.single-post .site-header .dropdown-trigger svg {
    stroke: #ffffff !important;
}

/* 4. LOGO: Jeśli masz czarne logo, ten filtr zmieni je w locie na białe */
.single-post .site-header img.main-logo {
    filter: brightness(0) invert(1);
}

/* 5. Obsługa licznik koszyka (opcjonalnie, by był bardziej widoczny) */
.single-post .cart-count {
    border: 1px solid #fff;
}

/* =========================================
   SEKCJA: JOURNAL / INNE ARTYKUŁY
   ========================================= */

.journal-recent-posts {
    padding: 100px 80px; /* Padding zgodny z Twoim shop-main-wrapper */
    background-color: #ffffff;
    box-sizing: border-box;
}

.journal-recent-container {
    max-width: 1710px;
    margin: 0 auto;
}

/* Nagłówek sekcji: Tytuł i Link "Przeczytaj wszystko" */
.journal-recent-header {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 50px;
    border-bottom: 1px solid #eeeeee;
    padding-bottom: 20px;
}

.journal-recent-title {
    font-family: 'Satoshi', sans-serif;
    font-size: 32px;
    font-weight: 500;
    margin: 0;
    color: #000;
    text-transform: none;
}

.journal-all-link {
    font-family: 'Satoshi', sans-serif;
    font-size: 13px;
    font-weight: 500;
    text-transform: uppercase;
    text-decoration: underline;
    color: #000;
    letter-spacing: 0.05em;
    transition: opacity 0.3s;
}

.journal-all-link:hover {
    opacity: 0.6;
}

/* Siatka artykułów */
.journal-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 kolumny na desktop */
    gap: 50px 30px; /* 50px odstępu pionowego, 30px poziomego */
}

/* Karta artykułu */
.journal-card__link {
    display: block;
    text-decoration: none;
    color: inherit;
}

.journal-card__image {
    width: 100%;
    aspect-ratio: 16 / 10; /* Elegancki format zdjęcia */
    background-color: #f6f6f6;
    overflow: hidden;
    margin-bottom: 25px;
}

.journal-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.journal-card:hover .journal-card__image img {
    transform: scale(1.05); /* Delikatny zoom na hover */
}

.journal-card__title {
    font-family: 'Satoshi', sans-serif;
    font-size: 22px;
    line-height: 1.3;
    font-weight: 500;
    color: #000;
    margin: 0 0 15px 0;
}

.journal-card__excerpt {
    font-size: 16px;
    line-height: 1.5;
    color: #444444;
	min-height: 100px;
}

.journal-archive-container {
    max-width: 1710px;
    margin: 0 auto;
    padding-left: 80px;
    padding-right: 80px;
    box-sizing: border-box;
    width: 100%;
}

/* Jeśli chodziło o kolumnę treści wewnątrz pojedynczego artykułu (single.php) */
.journal-entry-content__inner {
    padding-left: 80px !important;
    padding-right: 80px !important;
}

/* --- FIX DLA STRZAŁEK SLIDERA --- */

/* 1. Upewnij się, że kontener slidera jest bazą dla strzałek */
#product-slider {
    position: relative !important;
    overflow: visible !important; /* Pozwala strzałkom wystawać poza slider */
}

/* --- HOME HERO SLIDER --- */
.home-hero-slider {
    width: 100%;
    height: 100vh;
    position: relative;
    overflow: hidden;
}

.slider-bg-img {
    width: 100%;
    height: 100vh;
    object-fit: cover;
    display: block;
}

/* Pozycjonowanie napisu głównego */
.slider-content-wrapper {
    position: absolute;
    z-index: 10;
    width: auto;
    max-width: 800px;
    pointer-events: none;
    text-align: left;
}

.hero-slider-title {
    font-family: 'Satoshi', sans-serif;
    font-size: clamp(32px, 5vw, 45px);
    font-weight: 400;
    line-height: 1.2;
    text-shadow: 0 2px 10px rgba(0,0,0,0.2);
}

/* Przycisk KUP TERAZ - lewy dół */
.slider-cta-fixed {
    position: absolute;
    bottom: 80px;
    left: 80px;
    z-index: 20;
}

.btn-kup-teraz-slider {
    background: #000000;
    color: #ffffff;
    padding: 15px 45px;
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: inline-block;
}

/* Kropki (Bullets) - prawy dół */
.home-hero-slider .glide__bullets {
    position: absolute;
    bottom: 80px;
    right: 80px;
    left: auto;
    transform: none;
    display: flex;
    gap: 15px;
}

.home-hero-slider .glide__bullet {
    width: 12px;
    height: 12px;
    background-color: rgba(255,255,255,0.4);
    border: 2px solid #fff;
    border-radius: 50%;
    padding: 0;
    cursor: pointer;
    transition: all 0.3s ease;
}

.home-hero-slider .glide__bullet--active {
    background-color: #fff;
}

.journal-grid-wrapper {
	margin-top: 240px;
}

/* Wymuszenie wysokości dla slajdów, gdy są tłem */
.home-hero-slider, 
.home-hero-slider .glide, 
.home-hero-slider .glide__track, 
.home-hero-slider .glide__slides, 
.home-hero-slider .glide__slide {
    height: 100vh !important;
    width: 100%;
}

.home-hero-slider .glide__slide {
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: relative;
}

/* Pozycjonowanie tytułu w sliderze (100px od dołu, środek) */
.home-hero-slider .slider-content-wrapper {
    /* position: absolute !important;
    top: auto !important;
    bottom: 100px !important;
    left: 0 !important;
    width: 100% !important;
    max-width: none !important;
    text-align: center !important;
    z-index: 10;
    pointer-events: none; */
}

.home-hero-slider .slider-content-inner {
    display: inline-block;
    width: 100%;
    max-width: 1200px; /* Ograniczenie szerokości samego tekstu */
    margin: 0 auto;
}

.home-hero-slider .hero-slider-title {
    font-family: 'Satoshi', sans-serif;
    font-size: clamp(32px, 5vw, 45px);
    font-weight: 400;
    color: #ffffff;
    margin: 0;
    line-height: 1.2;
    text-transform: none; /* Jeśli ma być tak jak w tytule wpisu */
}

/* --- BIAŁE MENU TYLKO NA BLOGU I WPISACH --- */
/* .blog to strona Journal (home.php), .single-post to artykuł */

.blog .site-header .nav-menu li a,
.blog .site-header .dropdown-trigger,
.blog .site-header .cart-icon-trigger,
.single-post .site-header .nav-menu li a,
.single-post .site-header .dropdown-trigger,
.single-post .site-header .cart-icon-trigger {
    color: #ffffff !important;
}

.blog .site-header svg,
.single-post .site-header svg {
    stroke: #ffffff !important;
}

.blog .site-header img.main-logo,
.single-post .site-header img.main-logo {
    filter: brightness(0) invert(1); /* Zmienia logo na białe */
}

/* --- POWRÓT DO CZARNEGO MENU NA STRONIE GŁÓWNEJ --- */
/* Jeśli na stronie głównej nie ma 100vh slidera, wymuszamy czerń */

.home .site-header .nav-menu li a,
.home .site-header .dropdown-trigger,
.home .site-header .cart-icon-trigger {
    color: #000000 !important;
}

.home .site-header svg {
    stroke: #000000 !important;
}

.home .site-header img.main-logo {
    filter: none !important; /* Logo wraca do oryginału (czarne) */
}


.blog .home-hero-slider .hero-slider-title {
	 color: #000000 !important;
}

body.home h1.hero-slider-title
{
	 color: #000000 !important;
}

/* ==========================================================================
   STRONA: O NAS (About Page)
   ========================================================================== */

.about-page {
    width: 100%;
}

.about-hero {
    width: 100%;
    height: 100vh;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: end;
    justify-content: flex-start;
    position: relative;
	padding-left: 228px;
	padding-bottom: 100px;
	box-sizing: border-box;
}

.about-hero h1 {
    color: #ffffff;
    font-size: 52px;
    font-weight: 400;
    text-align: center;
    margin: 0;
    letter-spacing: -0.02em;
}

/* Kontener treści głównej */
.about-content-wrapper {
    padding-top: 80px;
    padding-bottom: 80px;
    padding-left: 80px;
    padding-right: 80px;
    display: flex;
    justify-content: center;
}

.about-text-content {
    width: 100%;
    max-width: 1240px; /* Standardowa szerokość kontenera Gardinale */
    font-size: 17px;
    line-height: 28px;
    font-weight: 400;
    color: #000;
}

/* Stylizacja akapitów i tekstu z edytora WP */
.about-text-content p {
    margin-bottom: 28px; /* Odstęp między akapitami równy interlinii */
}

.about-text-content p:last-child {
    margin-bottom: 0;
}

.about-text-content strong, 
.about-text-content b {
    font-weight: 700;
}


/* 1. Ustawienie nagłówka nad zdjęciem Hero */
.page-template-template-about .site-header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    background: transparent !important;
    border-bottom: none !important;
}

/* 2. Zmiana kolorów napisów w menu na biały */
.page-template-template-about .site-header .menu-item a,
.page-template-template-about .site-header .nav-link,
.page-template-template-about .site-header .header-cart-link,
.page-template-template-about .site-header .header-login-link,
.page-template-template-about .site-header .currency-switcher {
    color: #ffffff !important;
}

/* 3. Jeśli logo jest tekstowe lub SVG, zmieniamy mu kolor */
.page-template-template-about .site-header .logo,
.page-template-template-about .site-header .logo a {
    color: #ffffff !important;
}

/* 4. Kolor ikon (np. koszyka, wyszukiwarki) */
.page-template-template-about .site-header svg {
    fill: #ffffff !important;
    stroke: #ffffff !important;
}

/* 5. Opcjonalnie: zmiana koloru po najechaniu (hover) */
.page-template-template-about .site-header .menu-item a:hover {
    opacity: 0.7;
}


/* --- STRONA NAUKA --- */

.science-page {
    width: 100%;
    overflow-x: hidden;
}

/* Sekcja 1: Hero */
.science-hero {
    display: flex;
    width: 100%;
    height: 100vh;
    min-height: 700px;
}

.science-hero-col {
    flex: 1; /* Każda kolumna bierze 50% */
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.hero-box {
    background: rgba(181, 172, 151, 0.85);
    padding: 60px;
    max-width: 500px;
    margin: 40px;
    color: #fff;
}

.hero-box h1 {
    font-size: 42px;
    line-height: 1.1;
    margin-bottom: 20px;
    font-weight: 400;
}

.hero-box p {
    font-size: 17px;
    line-height: 1.6;
    margin-bottom: 30px;
}

/* Sekcje 2-7: Układ naprzemienny */
.science-row {
    display: flex;
    width: 100%;
    min-height: 100vh;
}

.science-row.is-reversed {
    flex-direction: row-reverse;
}

.science-col-text {
    display: flex;
    align-items: end;
    justify-content: center;
    padding: 80px;
    background-color: #fff;
	width: 50%;
	box-sizing: border-box;	
}

.science-col-image {
    flex: 1;
    background-size: cover;
    background-position: center;
    min-height: 400px;
}

.text-content {
    max-width: 550px;
}

.text-content h2 {
    font-size: 32px;
    margin-bottom: 25px;
    font-weight: 400;
}

.text-content .description {
    font-size: 17px;
    line-height: 28px;
    margin-bottom: 30px;
}

/* Guzik Przeczytaj więcej */
.btn-underline {
    text-decoration: none;
    color: #000;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;
    border-bottom: 2px solid #000;
    padding-bottom: 5px;
    transition: opacity 0.3s;
}

.btn-underline:hover {
    opacity: 0.6;
}

/* ==========================================================================
   STRONA STANDARDOWA (B2B, Regulaminy itp.)
   ========================================================================== */

.standard-page-template {
    width: 100%;
}

.standard-hero {
    position: relative;
    width: 100%;
	height: 100vh;
    display: flex;
	align-items: end;
    justify-content: flex-start;
    background-image: var(--bg-desktop);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    box-sizing: border-box;
	padding-left: 80px;	
	padding-bottom: 100px;
}

.standard-hero .container {
    position: relative;
    z-index: 2;
    width: 100%;
}

.standard-hero h1 {
    margin: 0 auto;
    max-width: 90%;
    font-size: clamp(2rem, 6vw, 4.2rem);
    line-height: 1.1;
    font-weight: 500;
	font-size: 52px;
}

/* Treść strony */
.page-content-section {
    padding: 100px 0;
    background: #fff;
}

.container-small {
    max-width: 800px;
    margin: 0 auto;
    padding: 0 20px;
}

/* --- Logika Nagłówka (Light / Dark) --- */

/* Wariant LIGHT - białe napisy na Hero */
.light-header-active .site-header .nav-menu li a,
.light-header-active .site-header .dropdown-trigger,
.light-header-active .site-header .cart-icon-trigger {
    color: #ffffff !important;
}

.light-header-active .site-header svg {
    stroke: #ffffff !important;
}

.light-header-active .site-header img.main-logo {
    filter: brightness(0) invert(1) !important;
}

/* Wariant DARK - czarne napisy na Hero */
.dark-header-active .site-header .nav-menu li a,
.dark-header-active .site-header .dropdown-trigger,
.dark-header-active .site-header .cart-icon-trigger {
    color: #000000 !important;
}

.dark-header-active .site-header svg {
    stroke: #000000 !important;
}

.dark-header-active .site-header img.main-logo {
    filter: none !important;
}



/* --- SIDE CART FOOTER FULL WIDTH FIX --- */

.side-cart-footer {
    left: 0;
    right: 0;
    width: 100%;
    box-sizing: border-box;
    margin-left: 0;
    margin-right: 0;
}

.side-cart-body .side-cart-footer {
    margin-left: -30px;
    margin-right: -30px;
    width: calc(100% + 60px);
    padding-left: 30px;
    padding-right: 30px;
}

.mini-cart-quantity-box.is-loading {
    opacity: 0.55;
    pointer-events: none;
}

#apply_coupon_btn.is-loading {
    opacity: 0.55;
    pointer-events: none;
}

.mini-cart-item.is-removing {
    opacity: 0.45;
    pointer-events: none;
}

.side-cart-discounts {
    margin-top: 10px;
}

.side-cart-discount-row,
.side-cart-final-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.side-cart-discount-row {
    font-size: 13px;
    color: #4f7c44;
    margin-top: 6px;
}

.side-cart-final-total {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #eee;
    font-size: 16px;
    font-weight: 600;
}

/*    ----------------------------------- koszyk ------------------ */

/* --- CHECKOUT LAYOUT --- */

/* --- CHECKOUT LAYOUT --- */

.gardinale-checkout-layout {
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px 70px 0;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 0;
}

.gardinale-checkout-left,
.gardinale-checkout-right {
    min-width: 0;
}

.gardinale-checkout-left {
    padding-right: 40px;
    box-sizing: border-box;
}

.gardinale-checkout-right {
    background: #f7f7f7;
    padding: 28px 32px;
    box-sizing: border-box;
}

.gardinale-order-review-heading {
    margin: 0 0 25px;
    font-size: 22px;
    font-weight: 500;
    text-transform: uppercase;
}

/*    ----------------------------------- koszyk end ------------------ */

/*    ----------------------------------- koszyk lewa kolumna ------------------ */

/* Checkout - prawa kolumna */

.gardinale-checkout-right {
    background: #fafafa;
    padding: 34px 34px 44px;
}

.gardinale-checkout-right h3,
.gardinale-checkout-right #order_review_heading {
    margin: 0 0 28px;
    font-size: 22px;
    font-weight: 400;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.gardinale-checkout-right .shop_table {
    width: 100%;
    margin: 0 0 24px;
    border: 1px solid #d7d7d7;
    border-collapse: collapse;
    background: #fff;
    font-size: 14px;
}

.gardinale-checkout-right .shop_table th,
.gardinale-checkout-right .shop_table td {
    padding: 13px 14px;
    border: 1px solid #d7d7d7;
    vertical-align: top;
}

.gardinale-checkout-right .shop_table th {
    font-weight: 600;
}

.gardinale-checkout-right .shop_table .product-name {
    width: 58%;
}

.gardinale-checkout-right .shop_table .product-total {
    text-align: right;
}

.gardinale-checkout-right .cart-subtotal td,
.gardinale-checkout-right .order-total td {
    font-weight: 600;
}

.gardinale-checkout-right .cart-discount td {
    font-weight: 600;
}

.gardinale-checkout-right .cart-discount a {
    color: #111;
    text-decoration: underline;
}

.gardinale-checkout-right .woocommerce-shipping-methods {
    margin: 0;
    padding: 0;
    list-style: none;
}

.gardinale-checkout-right .woocommerce-shipping-methods li {
    margin: 0 0 8px;
}

.gardinale-checkout-right .woocommerce-shipping-methods label {
    cursor: pointer;
}

.gardinale-checkout-right #payment {
    margin-top: 22px;
    padding: 24px;
    background: #eeeaf1;
    border-radius: 0;
}

.gardinale-checkout-right #payment ul.payment_methods {
    margin: 0;
    padding: 0 0 18px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}

.gardinale-checkout-right #payment ul.payment_methods li {
    margin: 0 0 12px;
    list-style: none;
}

.gardinale-checkout-right #payment ul.payment_methods li:last-child {
    margin-bottom: 0;
}

.gardinale-checkout-right #payment label {
    cursor: pointer;
    font-size: 16px;
}

.gardinale-checkout-right #payment .payment_box {
    margin: 12px 0 0;
    padding: 18px;
    background: #e1dbe8;
    color: #555;
    font-size: 13px;
    line-height: 1.5;
}

.gardinale-checkout-right #payment .payment_box p {
    margin: 0;
}

.gardinale-checkout-right .place-order {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin: 22px 0 0;
    padding: 0;
}

.gardinale-checkout-right .woocommerce-terms-and-conditions-wrapper {
    flex: 1;
    font-size: 13px;
    line-height: 1.5;
}

.gardinale-checkout-right .woocommerce-terms-and-conditions-wrapper p {
    margin: 0;
}

.gardinale-checkout-right #place_order {
    min-width: 118px;
    min-height: 66px;
    padding: 14px 18px;
    border: 0;
    border-radius: 2px;
    background: #7e4db6;
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.1;
    text-align: center;
    cursor: pointer;
}

.gardinale-checkout-right #place_order:hover {
    background: #6f42a5;
}


/* --- CHECKOUT - LEFT COLUMN RESET --- */

.gardinale-checkout-left #customer_details,
.gardinale-checkout-left #customer_details.col2-set {
    width: 100%;
    display: block;
}

.gardinale-checkout-left #customer_details .col-1,
.gardinale-checkout-left #customer_details .col-2 {
    float: none;
    width: 100%;
    max-width: none;
    padding: 0;
    margin: 0;
}

.gardinale-checkout-left #customer_details .col-2 {
    margin-top: 22px;
}

.gardinale-checkout-left .woocommerce-billing-fields,
.gardinale-checkout-left .woocommerce-shipping-fields,
.gardinale-checkout-left .woocommerce-additional-fields {
    width: 100%;
}

/* Sekcje lewej kolumny */

.gardinale-checkout-section {
    margin-bottom: 28px;
}

.gardinale-checkout-section-title {
    margin: 0 0 24px;
    font-size: 22px;
    font-weight: 500;
    text-transform: none;
}

.gardinale-required-note {
    margin: 0 0 26px;
    color: #d60000;
    font-size: 13px;
}

/* Układ pól */

.gardinale-checkout-address {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 22px;
    row-gap: 16px;
    column-gap: 0 !important;
    row-gap: 0 !important;	
}

.gardinale-checkout-address .gardinale-checkout-section-title {
    grid-column: 1 / -1;
}

.gardinale-checkout .form-row {
    float: none !important;
    width: 100% !important;
    margin: 0 0 16px;
    padding: 0;
}

.gardinale-checkout-address .form-row {
    margin: 0;
}

.gardinale-checkout-address .form-row-wide {
    grid-column: 1 / -1;
}

.gardinale-checkout-address .form-row-first,
.gardinale-checkout-address .form-row-last {
    grid-column: auto;
}

/* Labelki */

.gardinale-checkout-left .form-row label {
	width: 100% !important;
	display: block !important;
	margin: 0 !important;
	padding: 0 0 0 1.4em !important;
	font-size: 15px;
	line-height: 1.35;
	color: #111;
	font-size: 16px !important;
}

.gardinale-checkout select {
    width: 100%;
    height: 48px;
    padding: 0 14px;
    border: 1px solid #ddd;
    background: #fff;
    font-size: 15px;
    color: #111;
}

.gardinale-checkout-left .required {
    color: #d60000;
    text-decoration: none;
}

/* Inputy */

.gardinale-checkout-left .woocommerce-input-wrapper {
    display: block;
    width: 100%;
}

.gardinale-checkout-left input.input-text,
.gardinale-checkout-left textarea,
.gardinale-checkout-left select {
    width: 100% !important;
    max-width: none !important;
	box-sizing: border-box;
	min-height: 46px;
    border: 1px solid #dcdcdc;
    border-radius: 23px !important;
    padding: 0 1.4em !important;
    background: #fff;
    font-size: 16px;
    line-height: 46px;
    box-sizing: border-box;
    color: #111;
	border: 1px solid #aaa !important;
}


.gardinale-checkout-left textarea {
    min-height: 170px;
    padding-top: 14px;
    line-height: 1.5;
    resize: vertical;
}

/* Select2 WooCommerce */

.gardinale-checkout-left .select2-container {
    width: 100% !important;
}

.gardinale-checkout-left .select2-container .select2-selection--single {
    height: 44px;
    border: 1px solid #dcdcdc;
    border-radius: 22px;
    background: #fff;
	border: 1px solid #aaa !important;
	display: flex;
	align-items: center !important;
}

.gardinale-checkout-left .select2-container .select2-selection__rendered {
    line-height: 44px;
    padding-left: 18px;
    padding-right: 38px;
    font-size: 13px;
}

.gardinale-checkout-left .select2-container .select2-selection__arrow {
    height: 44px;
    right: 12px;
}

/* Checkboxy */

.gardinale-checkout-left .woocommerce-form__label-for-checkbox,
.gardinale-checkout-left .checkbox {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    line-height: 1.4;
}

.gardinale-checkout-left input[type="checkbox"] {
    width: 16px;
    height: 16px;
    margin-top: 1px;
    flex: 0 0 auto;
}

.gardinale-checkout-left .select2-container {
    width: 100% !important;
}

.gardinale-checkout-left .select2-container .select2-selection--single {
    width: 100%;
    height: 46px;
    min-height: 46px;
    border: 1px solid #dcdcdc;
    border-radius: 23px !important;
    background: #fff;
    box-sizing: border-box;
}

.gardinale-checkout-left .select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 1.4em;
    padding-right: 42px;
    line-height: 46px;
    font-size: 16px;
    color: #111;
}

.gardinale-checkout-left .select2-container--default .select2-selection--single .select2-selection__placeholder {
    color: #9b9b9b;
}

.gardinale-checkout-left .select2-container--default .select2-selection--single .select2-selection__arrow {
    height: 46px;
    right: 14px;
}

.gardinale-checkout-left .select2-container--default.select2-container--open .select2-selection--single,
.gardinale-checkout-left .select2-container--default.select2-container--focus .select2-selection--single {
    border-color: #111;
    outline: none;
}


.select2-dropdown {
    border: 1px solid #dcdcdc;
    border-radius: 12px;
    overflow: hidden;
}

.select2-results__option {
    font-size: 14px;
    padding: 10px 14px;
}


/* ------------- dodoane na koncu -------------- */

/* --- CHECKOUT - LABEL NAD INPUTEM --- */

.gardinale-checkout-left .form-row {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100% !important;
    margin: 0 0 18px !important;
    padding: 0 !important;
    float: none !important;
}

.gardinale-checkout-left .form-row label {
    width: 100% !important;
    display: block !important;
    margin: 0 !important;
    font-size: 13px;
    line-height: 1.35;
    color: #111;
	
}

.gardinale-checkout-left .woocommerce-input-wrapper {
    width: 100% !important;
    display: block !important;
}



/* Select2 - kraj */

.gardinale-checkout-left .select2-container {
    width: 100% !important;
    max-width: none !important;
}

/* Pola 2-kolumnowe dalej zostają 50/50 */

.gardinale-checkout-address .form-row-first,
.gardinale-checkout-address .form-row-last {
    width: 100% !important;
}

/* Checkboxy zostają poziomo: checkbox + tekst */

.gardinale-checkout-left .form-row.gardinale-checkbox-row,
.gardinale-checkout-left .form-row.create-account,
.gardinale-checkout-left .woocommerce-form__label-for-checkbox {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
}

.gardinale-checkout-left .woocommerce-form__label-for-checkbox span,
.gardinale-checkout-left .checkbox span {
    display: inline-block;
    width: auto;
}

/* --- CHECKOUT - TOP SPACING --- */

.woocommerce-checkout .site-main,
.woocommerce-checkout main,
.woocommerce-checkout .page-content {
    padding-top: 90px;
}

.gardinale-checkout-left textarea#order_comments {
    padding-top: 1em !important;
}
	
.gardinale-checkout-left .woocommerce-form__label-for-checkbox,
.gardinale-checkout-left label.checkbox,
.gardinale-checkout-left #ship-to-different-address label {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 0 0 18px 0 !important;
    padding: 0 !important;
    font-size: 16px !important;
    line-height: 1.4;
    font-weight: 400;
    text-transform: none;
    color: #111;
    cursor: pointer;
}

.gardinale-checkout-left .woocommerce-form__label-for-checkbox input[type="checkbox"],
.gardinale-checkout-left label.checkbox input[type="checkbox"],
.gardinale-checkout-left #ship-to-different-address input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 0 !important;
    flex: 0 0 18px;
}

.gardinale-checkout-left .woocommerce-form__label-for-checkbox span,
.gardinale-checkout-left label.checkbox span,
.gardinale-checkout-left #ship-to-different-address span {
    font-size: 16px !important;
    line-height: 1.4;
    font-weight: 400;
    text-transform: none;
}	

/*    ----------------------------------- koszyk lewa kolumna END ------------------ */

/* ----------- dane do faktury -------------- */

.gardinale-checkout-left .gardinale-vat-field {
    display: none;
}

.gardinale-checkout-left .gardinale-vat-field.is-visible {
    display: block;
}

.gardinale-checkout-left .gardinale-vat-heading-row {
    margin-top: 12px !important;
    margin-bottom: 18px !important;
}

.gardinale-checkout-left .gardinale-vat-heading {
    margin: 0;
    font-size: 22px;
    line-height: 1.25;
    font-weight: 500;
    color: #111;
}

.gardinale-checkout-left .gardinale-vat-heading-row,
.gardinale-checkout-left #billing_invoice_company_field,
.gardinale-checkout-left #billing_invoice_tax_id_field,
.gardinale-checkout-left #billing_invoice_country_field,
.gardinale-checkout-left #billing_invoice_street_field,
.gardinale-checkout-left #billing_invoice_building_field,
.gardinale-checkout-left #billing_invoice_postcode_field,
.gardinale-checkout-left #billing_invoice_city_field {
    display: none !important;
}

.gardinale-checkout-left .gardinale-vat-heading-row.is-visible,
.gardinale-checkout-left #billing_invoice_company_field.is-visible,
.gardinale-checkout-left #billing_invoice_tax_id_field.is-visible,
.gardinale-checkout-left #billing_invoice_country_field.is-visible,
.gardinale-checkout-left #billing_invoice_street_field.is-visible,
.gardinale-checkout-left #billing_invoice_building_field.is-visible,
.gardinale-checkout-left #billing_invoice_postcode_field.is-visible,
.gardinale-checkout-left #billing_invoice_city_field.is-visible {
    display: block !important;
}

.gardinale-checkout-left .woocommerce-shipping-fields {
    display: none !important;
}

/* ----------- dane do faktury END -------------- */


/* ========================================
   CHECKOUT - PRAWA KOLUMNA
======================================== */

.gardinale-checkout-right {
    background: #f7f7f7;
    border-radius: 20px;
    padding: 28px;
}

.gardinale-checkout-right h3,
.gardinale-checkout-right #order_review_heading {
    margin: 0 0 22px;
    font-size: 22px;
    font-weight: 500;
    line-height: 1.2;
    text-transform: uppercase;
}

.gardinale-checkout-right .woocommerce-checkout-review-order-table,
.gardinale-checkout-right .shop_table {
    width: 100%;
    margin: 0 0 22px;
    border: 1px solid #d7d7d7;
    border-radius: 16px;
    overflow: hidden;
    border-collapse: separate;
    border-spacing: 0;
    background: #fff;
}

.gardinale-checkout-right .shop_table th,
.gardinale-checkout-right .shop_table td {
    padding: 16px 18px;
    border-bottom: 1px solid #d7d7d7;
    vertical-align: top;
}

.gardinale-checkout-right .shop_table th:first-child,
.gardinale-checkout-right .shop_table td:first-child {
    border-right: 1px solid #d7d7d7;
}

.gardinale-checkout-right .shop_table tr:last-child th,
.gardinale-checkout-right .shop_table tr:last-child td {
    border-bottom: 0;
}

.gardinale-checkout-right .shop_table thead th {
    font-size: 14px;
    font-weight: 700;
    text-transform: uppercase;
}

.gardinale-checkout-right .shop_table .product-total,
.gardinale-checkout-right .shop_table td:last-child {
    text-align: left;
}

.gardinale-checkout-right .cart-subtotal th,
.gardinale-checkout-right .cart-subtotal td,
.gardinale-checkout-right .order-total th,
.gardinale-checkout-right .order-total td {
    font-weight: 700;
}

.gardinale-checkout-right .cart-discount a {
    color: #111;
    font-weight: 600;
    text-decoration: underline;
}

.gardinale-checkout-product-line {
    display: flex;
    align-items: center;
    gap: 12px;
}

.gardinale-checkout-product-thumb {
    width: 52px;
    height: 52px;
    min-width: 52px;
    object-fit: cover;
    border-radius: 10px;
    overflow: hidden;
}

.gardinale-checkout-product-name {
    display: inline-block;
    line-height: 1.4;
}

.gardinale-checkout-right .woocommerce-shipping-methods {
    margin: 0;
    padding: 0;
    list-style: none;
}

.gardinale-checkout-right .woocommerce-shipping-methods li {
    margin: 0 0 10px;
    line-height: 1.45;
}

.gardinale-checkout-right .woocommerce-shipping-methods li:last-child {
    margin-bottom: 0;
}

.gardinale-checkout-right .woocommerce-shipping-methods label {
    cursor: pointer;
}

.gardinale-checkout-right #payment {
    margin-top: 18px;
    padding: 24px;
    background: #efefef;
    border: 1px solid #dddddd;
    border-radius: 18px;
}

.gardinale-checkout-right #payment ul.payment_methods {
    margin: 0;
    padding: 0 0 16px;
    border-bottom: 1px solid #dddddd;
}

.gardinale-checkout-right #payment ul.payment_methods li {
    margin: 0 0 14px;
    list-style: none;
}

.gardinale-checkout-right #payment ul.payment_methods li:last-child {
    margin-bottom: 0;
}

.gardinale-checkout-right #payment label {
    cursor: pointer;
    font-size: 16px;
    line-height: 1.4;
}

.gardinale-checkout-right #payment .payment_box {
    margin: 12px 0 0;
    padding: 16px 18px;
    background: #f7f7f7;
    border: 1px solid #dddddd;
    border-radius: 14px;
    color: #555;
    font-size: 13px;
    line-height: 1.55;
}

.gardinale-checkout-right #payment .payment_box p {
    margin: 0;
}

.gardinale-checkout-right .place-order {
    display: block;
    margin: 20px 0 0;
    padding: 0;
}

.gardinale-checkout-right .gardinale-privacy-consent-row,
.gardinale-checkout-right .woocommerce-terms-and-conditions-wrapper {
    margin: 0 0 14px;
    font-size: 13px;
    line-height: 1.55;
}

.gardinale-checkout-right .gardinale-privacy-consent-row label,
.gardinale-checkout-right .woocommerce-terms-and-conditions-wrapper label {
    display: inline;
    cursor: pointer;
}

.gardinale-checkout-right .gardinale-privacy-consent-row input,
.gardinale-checkout-right .woocommerce-terms-and-conditions-wrapper input {
    margin-right: 8px;
}

.gardinale-checkout-right .woocommerce-privacy-policy-text {
    display: none;
}

.gardinale-checkout-right #place_order {
    width: 100%;
    min-height: 58px;
    margin-top: 8px;
    padding: 16px 20px;
    border: 0;
    border-radius: 16px;
    background: #111;
    color: #fff;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.2;
    cursor: pointer;
    transition: opacity 0.2s ease;
}

.gardinale-checkout-right #place_order:hover {
    opacity: 0.9;
}

.gardinale-checkout-right .required {
    color: #d93025;
}

/* Checkout - linki w zgodach */
.gardinale-checkout-right .gardinale-privacy-consent-row a,
.gardinale-checkout-right .woocommerce-terms-and-conditions-checkbox-text a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
}

.gardinale-checkout-right .gardinale-privacy-consent-row a:hover,
.gardinale-checkout-right .woocommerce-terms-and-conditions-checkbox-text a:hover {
    opacity: 0.7;
}


/* =========================================================
   Moje konto - login / rejestracja
   ========================================================= */

.woocommerce-account .entry-content {
    max-width: 1280px;
    margin: 0 auto;
    padding: 70px 24px 80px;
}

.woocommerce-account .entry-title,
.woocommerce-account h1 {
    max-width: 1280px;
    margin: 0 auto;
    padding: 40px 24px 0;
    font-size: 34px;
    font-weight: 400;
    line-height: 1.2;
    color: #333;
	text-align: center;
}

.woocommerce-account #customer_login {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 54px;
    align-items: start;
}

.woocommerce-account #customer_login .u-column1,
.woocommerce-account #customer_login .u-column2 {
    float: none;
    width: auto;
}

.woocommerce-account #customer_login h2 {
    margin: 0 0 36px;
    font-size: 24px;
    font-weight: 400;
    line-height: 1.3;
    color: #333;
}

.woocommerce-account #customer_login form.login,
.woocommerce-account #customer_login form.register {
    margin: 0;
    padding: 32px;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
    background: #fff;
}

.woocommerce-account #customer_login .form-row {
    margin: 0 0 22px;
    padding: 0;
}

.woocommerce-account #customer_login label {
    display: block;
    margin: 0 0 8px;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.4;
    color: #5f6872;
}

.woocommerce-account #customer_login .required {
    color: #b00000;
    text-decoration: none;
}

.woocommerce-account #customer_login input.input-text {
    width: 100%;
    height: 52px;
    padding: 10px 14px;
    border: 1px solid #d2d2d2;
    border-radius: 4px;
    background: #fff;
    font-size: 16px;
    color: #222;
    box-shadow: none;
}

.woocommerce-account #customer_login input.input-text:focus {
    outline: none;
    border-color: #111;
}

.woocommerce-account #customer_login .password-input {
    display: block;
    width: 100%;
}

.woocommerce-account #customer_login .show-password-input {
    top: 50%;
    transform: translateY(-50%);
}

.woocommerce-account #customer_login button.button,
.woocommerce-account #customer_login .woocommerce-button {
    min-width: 150px;
    height: 44px;
    padding: 0 28px;
    border: 1px solid #000;
    border-radius: 4px;
    background: #000;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    line-height: 42px;
    text-align: center;
    cursor: pointer;
}

.woocommerce-account #customer_login button.button:hover,
.woocommerce-account #customer_login .woocommerce-button:hover {
    background: #222;
    border-color: #222;
    color: #fff;
}

/* Login - przycisk i zapamiętaj mnie w jednej linii */
.woocommerce-account #customer_login form.login p.form-row:nth-of-type(3) {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px;
}

.woocommerce-account #customer_login .woocommerce-form-login__submit {
    order: 1;
}

.woocommerce-account #customer_login .woocommerce-form-login__rememberme {
    order: 2;
    display: inline-flex;
    align-items: center;
    gap: 7px;
	margin-bottom: 0 0 0 10px
}

.woocommerce-account #customer_login .woocommerce-form-login__rememberme input {
    width: 16px;
    height: 16px;
    margin: 0;
}

.woocommerce-account #customer_login .woocommerce-form-login__rememberme span {
    font-size: 16px;
    color: #5f6872;
}

.woocommerce-account #customer_login .lost_password {
    margin: 0;
}

.woocommerce-account #customer_login .lost_password a {
    color: #111;
    font-size: 15px;
    text-decoration: none;
}

.woocommerce-account #customer_login .lost_password a:hover {
    text-decoration: underline;
}

/* Rejestracja - teksty */
.woocommerce-account #customer_login form.register p {
    font-size: 15px;
    line-height: 1.65;
    color: #5f6872;
}

.woocommerce-account #customer_login .woocommerce-privacy-policy-text {
    margin: 0 0 22px;
}

.woocommerce-account #customer_login .woocommerce-privacy-policy-text p {
    margin: 0;
}

.woocommerce-account #customer_login .woocommerce-privacy-policy-text a {
    color: #111;
}

/* Moje konto - poprawka układu kolumn */

.entry-content #customer_login {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 56px !important;
    max-width: 1180px;
    margin: 0 auto;
    clear: both;
}

.entry-content #customer_login > .u-column1,
.entry-content #customer_login > .u-column2,
.entry-content #customer_login > .col-1,
.entry-content #customer_login > .col-2 {
    float: none !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

.entry-content #customer_login h2 {
    margin: 0 0 28px;
}

.entry-content #customer_login form.login,
.entry-content #customer_login form.register {
    width: 100%;
    box-sizing: border-box;
}

/* Wymuś label nad inputem */
.entry-content #customer_login .form-row {
    display: block !important;
}

.entry-content #customer_login label {
    display: block !important;
    width: 100% !important;
}

.entry-content #customer_login input.input-text,
.entry-content #customer_login .password-input {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box;
}


div.woocommerce div#customer_login
{
	display: flex !important;
}

.woocommerce-account .entry-title {
    margin-top: 70px;
}


/* -------- zalogowany panel klineta ------------------- */

/* =========================================================
   Moje konto - widok zalogowanego klienta
   ========================================================= */

.woocommerce-account .woocommerce {
    display: flex;
    flex-wrap: wrap;
    gap: 80px;
    align-items: flex-start;
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 24px 90px;
}

.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
    float: none !important;
}

/* Lewa kolumna */
.woocommerce-account .woocommerce-MyAccount-navigation {
    flex: 0 0 260px;
    width: 260px !important;
    margin: 0;
}

/* Prawa kolumna */
.woocommerce-account .woocommerce-MyAccount-content {
    flex: 1 1 0;
    width: auto !important;
    min-width: 0;
    padding: 34px 40px;
    border: 1px solid #d8d8d8;
    background: #fff;
    font-size: 17px;
    line-height: 1.7;
    color: #333;
}

/* Menu konta */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    margin: 0;
    padding: 0;
    list-style: none;
    border: 1px solid #d8d8d8;
    background: #fff;
}

.woocommerce-account .woocommerce-MyAccount-navigation li {
    margin: 0;
    border-bottom: 1px solid #d8d8d8;
}

.woocommerce-account .woocommerce-MyAccount-navigation li:last-child {
    border-bottom: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation a {
    display: block;
    padding: 15px 18px;
    font-size: 16px;
    line-height: 1.3;
    color: #333;
    text-decoration: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
    background: #000;
    color: #fff;
}

/* Treść konta */
.woocommerce-account .woocommerce-MyAccount-content p {
    margin: 0 0 20px;
}

.woocommerce-account .woocommerce-MyAccount-content p:last-child {
    margin-bottom: 0;
}

.woocommerce-account .woocommerce-MyAccount-content a {
    color: #111;
    text-decoration: underline;
    text-underline-offset: 3px;
}

.woocommerce-account .woocommerce-MyAccount-content strong {
    font-weight: 600;
}

/* Tabele w koncie - zamówienia */
.woocommerce-account .woocommerce-MyAccount-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 0 0 24px;
    border: 1px solid #d8d8d8;
}

.woocommerce-account .woocommerce-MyAccount-content table th,
.woocommerce-account .woocommerce-MyAccount-content table td {
    padding: 14px 16px;
    border-bottom: 1px solid #d8d8d8;
    text-align: left;
    font-size: 15px;
}

.woocommerce-account .woocommerce-MyAccount-content table th {
    font-weight: 600;
    background: #f7f7f7;
}

/* Przyciski w panelu klienta */
.woocommerce-account .woocommerce-MyAccount-content .button,
.woocommerce-account .woocommerce-MyAccount-content button.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 42px;
    padding: 0 24px;
    border: 1px solid #000;
    border-radius: 4px;
    background: #000;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
}

.woocommerce-account .woocommerce-MyAccount-content .button:hover,
.woocommerce-account .woocommerce-MyAccount-content button.button:hover {
    background: #222;
    border-color: #222;
    color: #fff;
}

/* =========================================================
   Moje konto - szczegóły konta
   ========================================================= */

.woocommerce-account .woocommerce-EditAccountForm {
    width: 100%;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row {
    margin: 0 0 22px;
    padding: 0;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row-first,
.woocommerce-account .woocommerce-EditAccountForm .form-row-last {
    float: none;
    width: calc(50% - 12px);
    display: inline-block;
    vertical-align: top;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row-first {
    margin-right: 20px;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row-wide {
    width: 100%;
}

.woocommerce-account .woocommerce-EditAccountForm label {
    display: block;
    margin: 0 0 8px;
    font-size: 15px;
    line-height: 1.4;
    color: #5f6872;
}

.woocommerce-account .woocommerce-EditAccountForm .required {
    color: #b00000;
    text-decoration: none;
}

.woocommerce-account .woocommerce-EditAccountForm input.input-text {
    width: 100%;
    height: 52px;
    padding: 10px 14px;
    border: 1px solid #d2d2d2;
    border-radius: 4px;
    background: #fff;
    font-size: 16px;
    color: #222;
    box-shadow: none;
}

.woocommerce-account .woocommerce-EditAccountForm input.input-text:focus {
    outline: none;
    border-color: #111;
}

.woocommerce-account .woocommerce-EditAccountForm .password-input {
    display: block;
    width: 100%;
}

.woocommerce-account .woocommerce-EditAccountForm .show-password-input {
    top: 50%;
    transform: translateY(-50%);
}

.woocommerce-account .woocommerce-EditAccountForm #account_display_name_description {
    display: block;
    margin-top: 8px;
    font-size: 14px;
    line-height: 1.5;
    color: #6b7280;
}

.woocommerce-account .woocommerce-EditAccountForm fieldset {
    margin: 34px 0 26px;
    padding: 28px;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
}

.woocommerce-account .woocommerce-EditAccountForm legend {
    padding: 0 10px;
    font-size: 20px;
    line-height: 1.3;
    font-weight: 400;
    color: #333;
}

.woocommerce-account .woocommerce-EditAccountForm button.button {
    min-width: 170px;
    height: 44px;
    padding: 0 28px;
    border: 1px solid #000;
    border-radius: 4px;
    background: #000;
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    line-height: 42px;
    text-align: center;
    cursor: pointer;
}

.woocommerce-account .woocommerce-EditAccountForm button.button:hover {
    background: #222;
    border-color: #222;
    color: #fff;
}

/* Moje konto - szczegóły konta: label nad inputem */

.woocommerce-account .woocommerce-EditAccountForm .form-row,
.woocommerce-account .woocommerce-EditAccountForm fieldset .form-row {
    display: block !important;
    width: 100% !important;
}

.woocommerce-account .woocommerce-EditAccountForm label,
.woocommerce-account .woocommerce-EditAccountForm fieldset label {
    display: block !important;
    width: 100% !important;
    margin: 0 0 8px !important;
}

.woocommerce-account .woocommerce-EditAccountForm input.input-text,
.woocommerce-account .woocommerce-EditAccountForm .password-input {
    display: block !important;
    width: 100% !important;
}

.woocommerce-account .woocommerce-EditAccountForm .form-row-first,
.woocommerce-account .woocommerce-EditAccountForm .form-row-last {
    float: none !important;
    display: block !important;
    width: 100% !important;
    margin-right: 0 !important;
}

/* -------- zalogowany END ------------------- */


/* ---------------- Podstorna koszyk ---- */

/* =========================================================
   Koszyk - odstęp od headera
   ========================================================= */

.woocommerce-cart .entry-title {
    margin-top: 90px;
}

.woocommerce-cart .entry-content {
    padding-bottom: 80px;
}


/* ---------------- Podstorna koszyk END ---- */



/* =========================================================
   Header biały na stronie Nauka
   ========================================================= */

.page-template-template-science .site-header .menu-item a,
.page-template-template-science .site-header .nav-link,
.page-template-template-science .site-header .dropdown-trigger,
.page-template-template-science .site-header .header-cart-link,
.page-template-template-science .site-header .header-login-link,
.page-template-template-science .site-header .currency-switcher {
    color: #ffffff !important;
}

/* Strzałki dropdownów PL / waluta */
.page-template-template-science .site-header .dropdown-trigger svg path {
    stroke: #ffffff !important;
}

/* Ikona koszyka */
.page-template-template-science .site-header .cart-icon-trigger svg path {
    fill: #ffffff !important;
}

/* Hamburger mobile */
.page-template-template-science .site-header .mobile-menu-toggle span {
    background: #ffffff !important;
}


/* ----------------- slider blog ---------------------- */

/* =========================================================
   Journal / Blog hero slider - tytuł na dole na środku
   ========================================================= */

body.blog main.journal-archive-page .home-hero-slider .slider-content-wrapper {
    position: absolute !important;
    left: 50% !important;
    right: auto !important;
    top: auto !important;
    bottom: 120px !important;
    width: 100% !important;
    max-width: 1100px !important;
    transform: translateX(-50%) !important;
    text-align: center !important;
    z-index: 20 !important;
    pointer-events: none;
}

body.blog main.journal-archive-page .home-hero-slider .slider-content-inner {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
    padding: 0 40px !important;
    text-align: center !important;
}

body.blog main.journal-archive-page .home-hero-slider .hero-slider-title {
    color: #ffffff !important;
    text-align: center !important;
    margin: 0 auto !important;
    max-width: 1000px !important;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.35);
}

/* ----------------- slider blog end ---------------------- */

.home-category-carousel .glide {
    position: relative;
}

.home-category-carousel .glide__arrows {
    position: absolute;
    top: 42%;
    left: 0;
    right: 0;
    z-index: 5;
    pointer-events: none;
}

.home-category-carousel .glide__arrow {
    position: absolute;
    top: 0;
    transform: translateY(-50%);
    pointer-events: auto;
}

.home-category-carousel .glide__arrow--left {
    left: 16px;
}

.home-category-carousel .glide__arrow--right {
    right: 16px;
}

.home-category-carousel .glide__arrow {
    width: 42px;
    height: 42px;
    border: 1px solid #111;
    background: #fff;
    color: #111;
    display: flex;
    align-items: center;
    justify-content: center;
}

.category-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

.category-header-left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.category-intro-text {
    margin: 10px 0 0;
    font-size: 18px;
    line-height: 1.4;
    font-weight: 400;
    color: #111;
}

.category-all-link {
    flex-shrink: 0;
    margin-top: 8px;
}


section.home-category-carousel
{
	margin-top: 120px;
}

.footer-newsletter-col {
    max-width: 320px;
}

.footer-newsletter-text {
    margin: 0 0 18px;
    font-size: 13px;
    line-height: 1.55;
    font-weight: 400;
    color: #111;
}

.footer-newsletter-form .tnp-subscription {
    max-width: 100%;
    margin: 0;
}

.footer-newsletter-form form {
    margin: 0;
}

.footer-newsletter-form input[type="email"],
.footer-newsletter-form .tnp-email {
    width: 100%;
    height: 42px;
    border: 1px solid #111;
    border-radius: 0;
    padding: 0 12px;
    font-size: 13px;
    background: transparent;
    color: #111;
}

.footer-newsletter-form input[type="submit"],
.footer-newsletter-form .tnp-submit {
    width: 100%;
    height: 42px;
    margin-top: 8px;
    border: 1px solid #111;
    border-radius: 0;
    background: #111;
    color: #fff;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .04em;
    cursor: pointer;
}

.footer-newsletter-form .tnp-privacy-field,
.footer-newsletter-form .tnp-field-privacy {
    margin-top: 10px;
    font-size: 11px;
    line-height: 1.4;
}

.footer-newsletter-form .tnp-privacy-field label,
.footer-newsletter-form .tnp-field-privacy label {
    display: flex;
    gap: 8px;
    align-items: flex-start;
}

.tnp-field label {

}

footer div.footer-newsletter-form form div.tnp-field label
{
	font-size: 14px;	
}

.tnp-subscription input.tnp-submit
{
	padding: 6px;
	font-size: 11px;
}

.site-footer .footer-newsletter-form .tnp-submit {
	display: block;
	border: 1px solid #000;
	padding: 12px 30px;
	text-align: center;
	text-decoration: none;
	color: #000;
	font-weight: 600;
	transition: all 0.3s;
	background: transparent !important;
	font-size: 16px;
}

body.page-id-846 #primary,
body.page-id-846 .site-main {
    padding-top: 70px;
	padding-bottom: 200px;
}

/* Newsletter public page - ukrycie opcjonalnych pól profilu */
body.page-id-846 .tnp-profile .tnp-field-firstname,
body.page-id-846 .tnp-profile .tnp-field-lastname,
body.page-id-846 .tnp-profile .tnp-field-gender {
    display: none !important;
}

.product-certificates-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 12px;
    padding: 20px 0 28px;
}

.product-certificate-link {
	display: block;
	text-decoration: none;
	border: 1px solid #666;
	width: 15%;
	margin: 0;
	margin-right: 1%;
	padding: 0;
	background: #fff;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.product-certificate-link:hover {
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.14);
  transform: translateY(-2px);
}

.product-certificate-image {
    display: block;
    width: 100%;
    height: auto;
}

body.page-id-65 .main-logo-black,
body.page-id-199 .main-logo-black
{
  display: none;
}

body.page-id-65 .main-logo-white,
body.page-id-199 .main-logo-white
{
  display: block;
}



@media (max-width: 768px) {
    .product-certificate-link {
        flex-basis: 30%;
        max-width: none;
    }
}

@media (max-width: 480px) {
    .product-certificate-link {
        flex-basis: 46%;
    }
}

/* =========================================
   RESPONSIVE LOGIC (JEDEN GŁÓWNY PUNKT: 1024PX)
   ========================================= */

@media (min-width: 1025px) {
    .mobile-only { display: none !important; }
    .desktop-only { display: flex; align-items: center; }
}

@media (max-width: 1024px) {
	
	.home-hero-slider .slider-content-wrapper {
        bottom: 150px !important; /* Na mobile nieco wyżej, żeby zrobić miejsce na przycisk/kropki */
    }
    .slider-cta-fixed { left: 40px; bottom: 40px; }
    .home-hero-slider .glide__bullets { right: 40px; bottom: 40px; }
    .hero-slider-title { font-size: 28px; width: 90%; margin: 0 auto; }

	.glide__arrows {
        display: none !important;
    }
	
	.journal-archive-container,
    .journal-entry-content__inner {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
	
	.journal-recent-posts {
        padding: 60px 20px;
    }

    .journal-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 40px 20px;
    }

    .journal-recent-title {
        font-size: 26px;
    }
	.journal-hero__container {
        padding: 0 40px;
        margin-bottom: 60px;
    }
    .journal-hero__title {
        font-size: 36px;
        line-height: 42px;
    }
    .journal-entry-content__inner {
        padding: 60px 20px;
    }
	
	.home-full-banner {
        height: 60vh;
        padding-bottom: 40px;
		justify-content: center;
    }
    .btn-banner {
        min-width: auto;
		position: static;
    }
	
    .flex-col-gar-wrapper {
        flex-direction: column !important; /* Układamy kolumny pionowo */
        display: flex !important;
    }

    .col-items-txt-50 {
        flex: 0 0 100% !important;
        width: 100% !important;
        padding: 60px 20px !important;
        order: 1; /* Wymuszamy, aby tekst był ZAWSZE pierwszy na górze */
        text-align: center; /* Opcjonalnie: wyśrodkowanie tekstu na mobile */
    }

    .col-items-fot-50 {
        flex: 0 0 100% !important;
        width: 100% !important;
        min-height: 400px !important; /* Wysokość zdjęcia na mobile */
        order: 2; /* Wymuszamy, aby zdjęcie było ZAWSZE drugie na dole */
    }

    /* Resetujemy ewentualne row-reverse ustawione w kodzie inline dla S2/S3/S4 */
    .home-split__row, 
    .flex-col-gar-wrapper {
        flex-direction: column !important;
    }
	
	.home-split__title {
        font-size: 36px;
    }
	
	 .category-header {
        flex-direction: column;
        gap: 10px;
    }
	
    .home-split__content, 
    .home-split__media {
        flex: 0 0 100%;
        width: 100%;
    }
    .home-split__media {
        height: 400px;
    }
    .home-split__content {
        padding: 60px 20px;
    }	
	
	.video-overlay {
        padding: 40px;
    }
	
 /* Hero na mobile */
    .shop-hero { flex-direction: column; min-height: auto; }
    .shop-hero-col { width: 100%; flex: 0 0 100%; }
    .shop-hero-text { height: 392px; padding: 40px 20px; justify-content: center; }
    .shop-hero-image { height: 561px; }

    .hero-title { font-size: 32px; line-height: 35px; }
    .hero-subtitle { font-size: 20px; line-height: 26px; }

    /* Grid na mobile */
    .shop-main-wrapper { padding: 60px 20px; }
    
    .product-card-item {
        flex: 0 0 calc(50% - 20px) !important;
        max-width: calc(50% - 20px) !important;
        margin: 0 10px 40px 10px !important;
    }
    
    .category-title-main { font-size: 28px; margin-bottom: 30px; }
    .shop-main-wrapper {
        padding: 60px 20px;
    }
    .products.columns-4 {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 30px 15px !important;
    }
    .category-title-main {
        font-size: 28px;
        margin-bottom: 25px;
    } 
	.hero-title, p.hero-subtitle
	{
	color:#FFF;
	}

    .shop-hero {padding-top: 74px;}
    .shop-hero {
        flex-direction: column;
        min-height: auto;
    }

    .shop-hero-text {
        height: 392px;
        padding: 40px 20px;
        order: 1; /* Tekst na górze (jak na AI-3) */
    }

    .shop-hero-image {
        height: 561px;
        order: 2; /* Zdjęcie pod tekstem */
    }

    .hero-title { font-size: 32px; line-height: 1.1; }
    .hero-subtitle { font-size: 20px; }

    .products.columns-4 {
        grid-template-columns: repeat(2, 1fr) !important;
    }

    .category-section-title {
        font-size: 24px;
        margin: 40px 0 20px 0;
    }
	.p-add-to-cart .quantity input.qty {
        width: 60px !important;
        height: 55px !important;
        border: 1px solid #000 !important;
    }

	.p-add-to-cart .quantity {
        margin: 0 !important;
        flex: 0 0 auto;
    }

    .product-main-container {
        flex-direction: column;
        display: block;
    }

    .product-gallery-side {
        width: 100% !important;
        padding: 0 !important;
    }

    .gallery-stack {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 5px;
        padding: 5px;
    }

    .gallery-stack .stack-img:first-child {
        grid-column: span 3;
        margin-bottom: 5px;
    }

    /* Reszta zdjęć (miniaturki) dopasowuje się do siatki 3-kolumnowej */
    .stack-img {
        width: 100%;
        height: auto;
    }

    /* Sekcja z informacjami (pod zdjęciami) */
    .product-info-side {
        width: 100% !important;
        padding: 30px 20px !important; /* Odstępy dla treści */
        box-sizing: border-box;
    }

    /* Wyłączenie STICKY na mobile */
    .product-sticky-box {
        position: static !important;
        display: block;
    }

	.p-container-narrow {
	  padding-left: 20px;
	  padding-right: 20px;
	  box-sizing: border-box;
	}

    /* Typografia mobilna */
    .p-title {
        font-size: 28px; /* Nieco mniejszy tytuł na telefon */
        line-height: 1.2;
        margin-top: 15px;
		margin-bottom: 16px;
		font-weight: 500;
    }

    .p-subtitle {
        font-size: 18px;
    }

    /* Przycisk dodaj do koszyka na całą szerokość */
    .p-add-to-cart form.cart {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: stretch !important;
        gap: 12px;
        margin-top: 20px;
        width: 100%;
    }

    .p-add-to-cart .single_add_to_cart_button {
        flex: 1 1 auto !important;
        width: auto !important;
        margin: 0 !important;
        height: 55px !important;
        padding: 0 20px !important;
        font-size: 13px !important;
        white-space: nowrap;
    }
	
	.p-add-to-cart .payu-installments-widget, 
    .p-add-to-cart .payu-installments-info {
        width: 100%;
        margin-bottom: 10px;
    }
	
	.flex-end {
        justify-content: center;
    }
    .p-section-all-products-bottom {
        padding-bottom: 60px;
    }
	.p-section-all-products-bottom {
        padding-bottom: 60px;
        margin-top: 0;
    }
    .slider-footer-btn {
        justify-content: center; /* Na mobile lepiej wycentrować */
    }
	
    .p-slider-section { padding: 40px 20px; }
    .glide__arrows { top: 150px; left: 0; right: 0; width: 100%; }
	
	.p-slider-section {
        padding: 40px 20px 80px 20px;
    }
    .glide__arrows {
        margin-top: 20px;
        justify-content: center;
        gap: 20px;
    }
    #product-slider .glide__arrow { transform: none; }
	
	.p-section-all-products {
        text-align: center; /* Na mobile przycisk może być wycentrowany */
        padding-bottom: 50px;
    }
	
	.split-img, .split-txt {
        flex: 0 0 100%;
        width: 100%;
    }
    
    .split-txt {
        padding: 60px 20px;
    }
    
    .split-img {
        height: 300px; /* Na mobile obrazek nad tekstem */
    }
    
    .split-inner h2 {
        font-size: 26px;
        line-height: 1.3;
    }
    
    .split-inner .elementor-widget-text-editor {
        font-size: 18px;
        line-height: 1.5;
    }
	
	.p-section-fw {
        padding: 50px 0;
    }
    .p-section-fw h2 {
        font-size: 26px;
        line-height: 1.3;
    }
	
    .acc-content table {
        display: block;
        width: 100%;
        min-width: 600px;
    }	
	
    /* 1. Header */
    .desktop-only { display: none !important; }
    .mobile-only { display: flex; align-items: center; }

    .site-header { height: 70px; padding: 5px 0; }
    .header-container { padding: 0 20px; }
    
    .header-left { flex: 0 0 25%; justify-content: flex-start; }
    .header-center { flex: 0 0 50%; justify-content: center; }
    .header-right { justify-content: flex-end; }

    .header-center .main-logo {
        width: clamp(150px, 18vw, 203px);
        height: auto;
    }

	.mobile-menu-toggle {
		background: none;
		border: none;
		width: 30px;
		height: 20px; /* Stała wysokość dla 3 kresek */
		display: flex;
		flex-direction: column;
		justify-content: space-between; /* Rozkłada 3 kreski równomiernie: góra, środek, dół */
		cursor: pointer;
		padding: 0;
		z-index: 1001;
		margin-left: auto; /* Dosuwa do prawej w kolumnie */
    }
	.mobile-menu-toggle span {
		display: block;
		width: 30px;
		height: 2px;
		background: #000000;
		flex: none; 
		transition: 0.3s;
	}
	
	/* Opcjonalnie: Hover, aby sprawdzić czy działa */
	.mobile-menu-toggle:hover span {
		background: #444;
	}
	
    .mobile-menu-toggle span:first-child { top: 4px; }
    .mobile-menu-toggle span:last-child { bottom: 4px; }

    /* 2. Footer */
    .footer-eco-bar { display: none; }
    .footer-main-content { padding: 40px 20px; }
    .footer-columns-row { flex-direction: column; }
    
    .footer-col {
        width: 100% !important;
        padding-left: 0;
        margin-bottom: 30px;
        display: flex;
        justify-content: center;
        text-align: center;
		flex-wrap: wrap;
    }
    
    .footer-cta-wrapper { text-align: center; margin: auto;}
    .footer-payments { width: 100%; justify-content: center; margin-bottom: 20px; }
    .eco-text-labels { display: none; }
    
    .footer-socials {
        display: flex;
        justify-content: center;
        gap: 20px;
        padding-left: 0;
    }
    
    .btn-footer-contact {
        display: inline-block;
    }
	
	
    .about-content-wrapper {
        padding-top: 60px;
        padding-left: 40px;
        padding-right: 40px;
    }
    
    .about-hero h1 {
        font-size: 42px;
    }
	
    .science-hero-col {
        height: 500px;
        width: 100%;
    }

    .science-row {
		min-height: 380px;
		display: block;
    }

    .science-col-text {
        padding: 60px 40px;
    }

	.science-col-text {width:100%;}
	

	.science-hero {
        height: auto;
        flex-direction: column;
    }
    .science-hero {
        position: relative;
        display: block;
        height: 100vh;
        min-height: 500px;
        overflow: hidden;
    }	
	
	 /* Prawa kolumna (BEŻOWA) staje się tłem całej sekcji */
    .science-hero-col.right-col {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 1; /* Pod spodem */
    }

    /* Lewa kolumna (CZARNO-BIAŁA) - ukrywamy jej zdjęcie, zostawiamy tekst */
    .science-hero-col.left-col {
        position: relative;
        z-index: 2;
        background-image: none !important;
        height: 100%;
        width: 100%;
        display: flex;
		align-items: flex-start;
        justify-content: center;
    }

    /* Dopasowanie boksu z tekstem na mobile */
    .hero-box {
        margin: 0;
        width: 90%;
        max-width: 350px;
        padding: 30px;
        text-align: center;
		background: transparent;
    }

    .hero-box h1 {
        font-size: 28px;
        margin-bottom: 20px;
    }

    .hero-box .btn-black {
        width: 100%; /* Przycisk na całą szerokość boksu na mobile */
    }
	.hero-box a.btn-black {
		display: none;
	}
	
	section.science-hero {
		background: #c2b7a6;
	}
	.science-hero-col {
		background-size: 100vw;
		background-position-x: center;
		background-position-y: bottom;
		background-repeat: no-repeat;
	}
	
	.science-col-image 
	{
		width: calc(100% - 40px);
		margin-left: 20px;
		margin-right: 20px;
	}
	
   .standard-hero {
        background-image: var(--bg-mobile) !important;
    }
    .standard-hero.hero-big { 
        height: 70vh !important; 
        min-height: 500px !important;
    }

	.standard-hero {
		align-items: flex-start;
		justify-content: flex-start;
		padding-top: 50px;
		padding-left:30px;
	}
	
	.qty-btn {
        width: 44px;
        height: 40px;
        font-size: 20px;
    }

    .qty-input {
        width: 40px;
        height: 40px;
        font-size: 15px;
        line-height: 40px;
    }
	
	.gardinale-checkout-layout {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 40px 20px;
    }

    .gardinale-checkout-left {
        padding-right: 0;
    }
	
	.gardinale-checkout-right {
        padding: 26px 20px 34px;
    }

    .gardinale-checkout-right .place-order {
        display: block;
    }

    .gardinale-checkout-right #place_order {
        width: 100%;
        margin-top: 18px;
    }
	.gardinale-checkout-right {
        padding: 22px 18px;
        border-radius: 16px;
    }

    .gardinale-checkout-right .shop_table th,
    .gardinale-checkout-right .shop_table td {
        padding: 14px;
    }

    .gardinale-checkout-product-line {
        align-items: flex-start;
    }
	

    div.woocommerce div#customer_login {
		display: flex !important;
		flex-wrap: wrap;
	}
	
	.entry-content #customer_login {
        display: block !important;
        max-width: 100%;
    }

    .entry-content #customer_login > .u-column1 {
        margin-bottom: 42px !important;
    }
	
    .woocommerce-account .entry-content {
        padding: 56px 22px 70px;
    }

    .woocommerce-account #customer_login {
        gap: 32px;
    }

    .woocommerce-account #customer_login form.login,
    .woocommerce-account #customer_login form.register {
        padding: 26px;
    }	
	
	    .woocommerce-account .entry-title,
    .woocommerce-account h1 {
        padding: 28px 18px 0;
        font-size: 30px;
    }

    .woocommerce-account .entry-content {
        padding: 38px 18px 56px;
    }

    .woocommerce-account #customer_login {
        display: block;
    }

    .woocommerce-account #customer_login .u-column1 {
        margin-bottom: 42px;
    }

    .woocommerce-account #customer_login h2 {
        margin-bottom: 20px;
        font-size: 22px;
    }

    .woocommerce-account #customer_login form.login,
    .woocommerce-account #customer_login form.register {
        padding: 22px 18px;
    }

    .woocommerce-account #customer_login input.input-text {
        height: 50px;
    }

    .woocommerce-account #customer_login form.login p.form-row:nth-of-type(3) {
        display: block;
    }

    .woocommerce-account #customer_login button.button,
    .woocommerce-account #customer_login .woocommerce-button {
        width: 100%;
        margin-bottom: 14px;
    }

    .woocommerce-account #customer_login .woocommerce-form-login__rememberme {
        display: flex;
    }
	
	.woocommerce-account .woocommerce-EditAccountForm .form-row-first,
    .woocommerce-account .woocommerce-EditAccountForm .form-row-last {
        display: block;
        width: 100%;
        margin-right: 0;
    }

    .woocommerce-account .woocommerce-EditAccountForm fieldset {
        padding: 22px 18px;
    }

    .woocommerce-account .woocommerce-EditAccountForm button.button {
        width: 100%;
    }
	.woocommerce-cart .entry-title {
        margin-top: 40px;
    }

    .woocommerce-cart .entry-content {
        padding-bottom: 56px;
    }
	.footer-columns-row {
        flex-wrap: wrap;
        gap: 32px;
    }

    .footer-newsletter-col {
        max-width: none;
        width: 100%;
    }
	
}
/* ---------------- end media queries ----------------- */

@media (max-width: 768px) {

	.slider-cta-fixed { left: 20px; bottom: 100px; width: calc(100% - 40px); text-align: center; }
    .home-hero-slider .glide__bullets { width: 100%; justify-content: center; right: 0; bottom: 40px; }

    .home-intro {
        padding: 60px 20px;
    }
    
    .home-intro__title {
        font-size: 28px;
    }
    
    .home-intro__text {
        font-size: 16px;
    }	
    .glide__arrows {
        display: none !important;
    }
	
	 .video-overlay {
        justify-content: center;
        padding: 20px;
    }

    .gardinale-row {
        flex-direction: column;
        gap: 0;
    }
	
    .journal-grid {
        grid-template-columns: 1fr; /* 1 kolumna na telefonach */
    }

    .journal-recent-header {
        flex-direction: column;
        gap: 15px;
        align-items: flex-start;
    }
    
    .journal-card__title {
        font-size: 20px;
    }

    .about-content-wrapper {
        padding: 40px 20px 0 20px;
    }
    .about-hero {
        height: 100vh;
    }
    .about-hero-content h1 {
        font-size: 32px;
    }
	
	.about-content-wrapper {
		padding: 40px 20px;
	}
	.about-text-content {
		font-size: 16px;
		line-height: 26px;
	}

    .about-hero h1 {
        font-size: 32px;
        padding: 0 20px;
    }

    .about-content-wrapper {
        padding-top: 40px;
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 40px;
    }

    .about-text-content {
        font-size: 16px;
        line-height: 26px;
    }

    .hero-box {
        padding: 30px;
        margin: 20px;
		
    }
    
    .hero-box h1 {
        font-size: 32px;
    }

    .science-col-text {
        padding: 40px 20px;
    }
	
		
	    .woocommerce-account .woocommerce {
        gap: 36px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        flex: 0 0 230px;
        width: 230px !important;
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        padding: 30px;
    }
	
    .woocommerce-account .woocommerce {
        display: flex;
        flex-direction: column;
        gap: 28px;
        padding-left: 18px;
        padding-right: 18px;
        padding-bottom: 60px;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        flex: 0 0 auto;
        width: 100% !important;
        margin: 0;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation ul {
        display: block;
    }

    .woocommerce-account .woocommerce-MyAccount-navigation a {
        padding: 14px 16px;
    }

    .woocommerce-account .woocommerce-MyAccount-content {
        flex: 0 0 auto;
        width: 100% !important;
        padding: 24px 20px;
        font-size: 16px;
    }

    .woocommerce-account .woocommerce-MyAccount-content table,
    .woocommerce-account .woocommerce-MyAccount-content thead,
    .woocommerce-account .woocommerce-MyAccount-content tbody,
    .woocommerce-account .woocommerce-MyAccount-content th,
    .woocommerce-account .woocommerce-MyAccount-content td,
    .woocommerce-account .woocommerce-MyAccount-content tr {
        display: block;
    }

    .woocommerce-account .woocommerce-MyAccount-content table th {
        display: none;
    }

    .woocommerce-account .woocommerce-MyAccount-content table td {
        border-bottom: 1px solid #d8d8d8;
    }

	
}


@media (max-width: 580px) {
    .products.columns-4 {
        grid-template-columns: 1fr !important;
    }
    .product-card-item {
        flex: 0 0 100% !important;
        max-width: 100% !important;
        margin: 0 0 40px 0 !important;
    }	
}
