/*
Theme Name: OCME.pl
Theme URI: https://ocme.pl
Description: Theme of OCME.pl
Author: maxroy.agency
Author URI: https://maxroy.agency
Template: shoptimizer
Version: 1.2.3
*/

::-moz-selection { color: #fff; background: #B87333; }
::selection { color: #fff; background: #B87333; }

.x { clear: both; }
.x3 { clear: both; height: 30px; }

.topbar-wrapper .top-bar .col-full { border-bottom: 1px rgba(255,255,255,0.35) solid; }

.top-bar-right { flex: 0 0 auto !important; }

.header-4 .menu-primary-menu-container > ul > li > a, .header-4 .shoptimizer-cart .cart-contents .amount, .header-4 .search-trigger, .header-4 .search-trigger:hover, .header-4 .search-trigger:focus, .shoptimizer-myaccount a, .shoptimizer-myaccount a:hover { color: #fff !important; }

/* =========================================================
   Navbar – prawa strona (ikonki + przyciski rezerwacji)
   ========================================================= */

@media (min-width: 993px) {
	
/* header-4: col-full-nav jest flex-containerem dla menu + prawej strony */
.header-4 .col-full-nav {
	display: flex !important;
	align-items: center;
	flex: 1;
	min-width: 0;
}

/* Zwiększ gap między logo a menu do 45px (parent ustawia 30px margin-right) */
.header-4 .site-header {
	margin-right: 45px !important;
}

/* Cofnij absolutne pozycjonowanie i wyśrodkowanie menu z parent theme */
.header-4 .primary-navigation {
	position: static !important;
	width: auto !important;
	text-align: left !important;
	flex-shrink: 0;
}

/* Poza header-4: shoptimizer-primary-navigation jako flexbox */
.shoptimizer-primary-navigation {
	display: flex !important;
	align-items: center;
}

.ocme-header-right {
	display: flex;
	align-items: center;
	gap: 20px;
	margin-left: auto;
	flex-shrink: 0;
}

/* Ikonki: konto, ulubione, koszyk */
.ocme-header-icons {
	display: flex;
	align-items: center;
	gap: 10px;
}

.ocme-header-icons .shoptimizer-myaccount a,
.ocme-header-icons .shoptimizer-myaccount a:hover,
.ocme-wishlist a,
.ocme-wishlist a:hover,
.ocme-header-icons .site-header-cart .cart-contents,
.ocme-header-icons .site-header-cart .cart-contents:hover {
	color: #fff !important;
	display: flex;
	align-items: center;
	position: relative;
	text-decoration: none;
	line-height: 0;
}

/* Licznik ulubionych */
.ocme-wishlist {
	position: relative;
}

.ocme-wishlist-count {
	position: absolute;
	top: -5px;
	right: -7px;
	background: #B87333;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	min-width: 16px;
	height: 16px;
	border-radius: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 3px;
	line-height: 1;
}

/* Koszyk – wrapper shortcode (brak konfliktów z CSS parent theme) */
.ocme-header-icons .shoptimizer-cart-shortcode {
	display: flex;
	align-items: center;
	cursor: pointer;
}

.ocme-header-icons .shoptimizer-cart-shortcode .cart-contents {
	display: flex;
	align-items: center;
	color: #fff;
	text-decoration: none;
	line-height: 0;
}

.ocme-header-icons .shoptimizer-cart-shortcode .shoptimizer-cart .amount,
.ocme-header-icons .shoptimizer-cart-shortcode .shoptimizer-cart .mini-count,
.ocme-header-icons .shoptimizer-cart-shortcode .shoptimizer-cart .count {
	display: none;
}

/* Przyciski rezerwacji */
.ocme-reservations {
	line-height: 0;
}

.ocme-reservations ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 8px;
}

.ocme-reservations ul li {
	margin: 0;
	padding: 0;
}

.ocme-reservations ul li a {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: #B87333;
	color: #fff !important;
	font-size: 13px;
	font-weight: 600;
	height: 60px;
	padding: 0 18px;
	border-radius: 6px;
	text-decoration: none !important;
	white-space: nowrap;
	transition: background 0.2s ease, transform 0.15s ease;
	line-height: 1.2;
}

.ocme-reservations ul li a::after {
	content: '→';
	font-size: 14px;
	transition: transform 0.2s ease;
}

.ocme-reservations ul li a:hover {
	background: #9e6226;
	transform: translateY(-1px);
}

.ocme-reservations ul li a:hover::after {
	transform: translateX(3px);
}

}

/* =========================================================
   Blog loop – siatka 4 kolumn + karty wpisów
   ========================================================= */

.ocme-blog-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
	padding: 8px 0 40px;
}

/* Karta */
.ocme-card {
	background: #fff;
	border-radius: 20px;
	border: 1px solid #ebebeb;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.06);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: box-shadow 0.25s ease, transform 0.25s ease;
	margin: 0;
}

.ocme-card:hover {
	box-shadow: 0 6px 28px rgba(0, 0, 0, 0.12);
	transform: translateY(-3px);
}

/* Miniatura – otoczka z paddingiem */
.ocme-card__thumb-wrap {
	padding: 12px 12px 0;
}

.ocme-card__thumb {
	display: block;
	overflow: hidden;
	border-radius: 12px;
	aspect-ratio: 4 / 3;
}

.ocme-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.4s ease;
}

.ocme-card:hover .ocme-card__thumb img {
	transform: scale(1.04);
}

/* Treść karty */
.ocme-card__body {
	padding: 18px 20px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}

/* Odznaki kategorii – linkowane */
.ocme-card__cats {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.ocme-card__cat {
	display: inline-block;
	padding: 5px 18px;
	border: 1.5px solid #C4A06A;
	border-radius: 50px;
	font-size: 13px;
	line-height: 1.2;
	color: #3a2e1f;
	background: #fff;
	font-weight: 400;
	letter-spacing: 0.01em;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.ocme-card__cat:hover {
	background: #C4A06A;
	color: #fff;
}

/* Tytuł */
.ocme-card__title {
	font-size: 20px;
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
}

.ocme-card__title a {
	color: #1a1a1a;
	text-decoration: none;
}

.ocme-card__title a:hover {
	color: #B87333;
}

/* Meta: autor + data w jednym wierszu */
.ocme-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 16px;
}

.ocme-card__author,
.ocme-card__date {
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 13px;
	color: #7a7a7a;
	line-height: 1;
}

.ocme-card__author svg,
.ocme-card__date svg {
	flex-shrink: 0;
	color: #9a9a9a;
}

/* Excerpt */
.ocme-card__excerpt {
	font-size: 14px;
	line-height: 1.6;
	color: #555;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Link CTA */
.ocme-card__link {
	display: inline-block;
	margin-top: auto;
	padding-top: 4px;
	font-size: 14px;
	font-weight: 700;
	color: #1a1a1a;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 0.2s ease;
}

.ocme-card__link:hover {
	color: #B87333;
	text-decoration: underline;
}

.site-main:not(.grid) article.post { padding-bottom: 0 !important; }

.elementor-button { background-color: #B87333; }

/* ─── Responsywność ──────────────────────────── */
@media (max-width: 1200px) {
	.ocme-blog-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 993px) {
	.header-4 .shoptimizer-myaccount { padding-right: 0 !important; }
	
	.main-navigation ul.menu li.full-width > .sub-menu-wrapper { background: #000 !important; }
	.main-navigation ul.menu li.menu-item-has-children.full-width > .sub-menu-wrapper li.menu-item-has-children > a { color: #fff !important; font-weight: 700 !important; text-transform: uppercase; }
	.main-navigation ul li.full-width > .sub-menu-wrapper > .container > ul.sub-menu > li { border-color: #585858 !important; }
}

@media (max-width: 900px) {
	.ocme-blog-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}
}

@media (max-width: 560px) {
	.ocme-blog-grid {
		grid-template-columns: 1fr;
		gap: 16px;
	}
}

@media (max-width: 992px) {

}

/* cennik */

@media(min-width:551px){
	.tablepress tr.row-1 th {
    background-color: transparent;
    text-align: center;
    color: black;
	border: none !important;
		border-top: 1px solid #D7D7D7 !important;
	border-bottom: 1px solid #D7D7D7 !important;
	padding: 1rem 0rem !important;
			font-size: 24px;
		font-weight: 600;
}
.tablepress{
	border: none; 
}
.tablepress td {
    text-align: center;
		font-size: 24px;
		font-weight: 300;
	border: none;
	background-color: transparent;
	background: transparent !important;
		font-family: "Raleway";
}

.orignal-prices{
	text-decoration: line-through;
}

.discount-prices{
	color: #B87333;
	font-weight: 400 !important;
}
}

@media(max-width:550px){
	.tablepress tr.row-1 th {
    background-color: transparent;
    text-align: center;
    color: black;
	border: none !important;
		border-top: 1px solid #D7D7D7 !important;
	border-bottom: 1px solid #D7D7D7 !important;
	padding: 1rem 0rem !important;
			font-size: 16px;
		font-weight: 600;
}
	td.column-2 {
    display: flex;
    flex-direction: column;
    align-items: center;
}
	
.tablepress{
	border: none; 
}
.tablepress td {
    text-align: center;
		font-size: 16px;
		font-weight: 300;
	vertical-align: middle;
	border: none;
	background-color: transparent;
	background: transparent !important;
		font-family: "Raleway";
}

.orignal-prices{
	text-decoration: line-through;
}

.discount-prices{
	color: #B87333;
	font-weight: 400 !important;
}
}

/* changes v2 */

#ocme-footer a:hover { color: #B87333; }

#ocme-bottom a:hover { color: #B87333; }

.zespol-umow-wizyte { margin-top: auto !important; }

.acf-icons-ocme {
            display: flex;
            flex-direction: row;
            gap: 20px;
        }

        .acf-icons-ocme .acf-icon-item {
            display: flex;
            gap: 15px;
            align-items: flex-start;
        }

        .acf-icons-ocme.layout-vertical {
            flex-direction: column;
        }

        .acf-icons-ocme .acf-icon-image img {
            width: 32px;
            height: 32px;
            object-fit: contain;
            display: block;
        }

        .acf-icons-ocme .acf-icon-text {
            flex: 1;
        }

        @media (max-width: 767px) {
            .acf-icons-ocme {
                flex-direction: column !important;
            }
        }