/* DentStore 2026 - Design Overrides (PrestaShop 1.7, Classic) */

:root {
	/* Culori principale */
	--primary: #306bee;
	--primary-rgb: 48, 107, 238;
	--secondary: #13a3a1;
	--secondary-rgb: 19, 163, 161;
	--textcolor: #000000;
	--bg-white: #ffffff;
	--bg-grey: #f5f5f7;
	--bordercolor: #dddddd;

	/* Umbre */
	--shadow-header: 0 2px 8px rgba(0, 0, 0, 0.06);
	--shadow-card: 0 8px 24px rgba(0, 0, 0, 0.08);

	/* Spatiere */
	--radius: 15px;
	--radius-sm: 8px;
	--header-space: 16px;
	--card-space: 12px;
	--container-space-mobile: 12px;
	--container-space-tablet: 16px;
	--container-space-desktop: 24px;

	/* Animatii */
	--transition-fast: 0.2s ease;
}

html,
body {
	font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	font-size: 15px;
	color: var(--textcolor);
	background: var(--bg-white);
	overflow-x: hidden;
}

img,
svg,
video,
iframe {
	max-width: 100%;
	height: auto;
}

h1,
.h1 {
	font-size: clamp(1.5rem, 2.2vw, 2.15rem);
}

h2,
.h2 {
	font-size: clamp(1.25rem, 1.8vw, 1.75rem);
}

h3,
.h3 {
	font-size: clamp(1.1rem, 1.4vw, 1.35rem);
}

a {
	color: var(--primary);
	transition: color var(--transition-fast);
}

a:hover,
a:focus {
	color: var(--secondary);
	text-decoration: none;
}

/* ============================================
   HEADER - Linia 1: Logo | Search | Cont | Cos
            Linia 2: Categorii (stg) | Suport (dr)
============================================ */
#header {
	background: var(--bg-white);
	padding: 0;
	position: sticky;
	top: 0;
	z-index: 999;
	box-shadow: none;
}

/* Conținut header limitat la 1530px */
.ds-header-top .container-md,
.ds-header-nav .container-md {
	max-width: 1530px;
	width: 100%;
	margin: 0 auto;
	padding-left: var(--container-space-desktop);
	padding-right: var(--container-space-desktop);
}

/* --- Linia 1: ds-header-top --- */
.ds-header-top {
	background: var(--bg-white);
	border-bottom: 1px solid var(--bordercolor);
	padding: 10px 0;
}

.ds-header-top__row {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: nowrap;
}

/* Logo */
.ds-header-top__logo {
	flex-shrink: 0;
	margin-right: 32px;
}

.ds-header-top__logo img,
#header .logo img {
	max-height: 48px;
	width: auto;
	display: block;
}

/* Search - expandat la centru */
.ds-header-top__search {
	flex: 1;
	min-width: 0;
}

/* Anulam ms-auto de pe #_desktop_ps_searchbar */
.ds-header-top__search #_desktop_ps_searchbar {
	margin-left: 0 !important;
	width: 100%;
}

.ds-header-top__search #_desktop_ps_searchbar .ps-searchbar,
.ds-header-top__search #_desktop_ps_searchbar .js-search-widget {
	width: 100%;
}

.ds-header-top__search .search-widget,
.ds-header-top__search #search_widget {
	width: 100%;
}

/* Search input 700px */
.ps-searchbar__input,
.ds-header-top__search .ps-searchbar__input {
	width: 700px !important;
	max-width: 100%;
}

/* Linia 1: ascunde elementele de meniu din zona de search */
.ds-hook-top-line .ps-mainmenu,
.ds-hook-top-line #_desktop_top_menu,
.ds-hook-top-line nav.js-top-menu-container,
.ds-hook-top-line #top-menu,
.ds-hook-top-line ul.top-menu,
.ds-hook-top-line .top-menu-container {
	display: none !important;
}

/* Linia 2: ascunde searchul din zona de meniu (orice ar fi) */
.ds-hook-nav-line .search-widget,
.ds-hook-nav-line #search_widget,
.ds-hook-nav-line form.search-widget,
.ds-hook-nav-line #_desktop_search_widget,
.ds-hook-nav-line #_desktop_ps_searchbar,
.ds-hook-nav-line .ps-searchbar--mobile,
.ds-header-nav #_desktop_ps_searchbar,
.ds-header-nav .ps-searchbar--mobile,
.ds-header-nav .search-widget,
.ds-header-nav #search_widget {
	display: none !important;
}

#header .search-widget form,
.ds-header-top__search form {
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
}

#header .search-widget form input[type="text"],
.ds-header-top__search input[type="text"],
.ds-header-top__search input[type="search"],
.ds-header-top__search .ps-searchbar__input,
#header .ps-searchbar__input,
.ps-searchbar .ps-searchbar__input {
	width: 100%;
	border: 1.5px solid #000000 !important;
	border-radius: 50px;
	min-height: 44px;
	padding: 10px 52px 10px 18px;
	font-size: 0.95rem;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
	background: var(--bg-white);
	color: var(--textcolor);
}

#header .search-widget form input[type="text"]:focus,
.ds-header-top__search input:focus {
	border-color: var(--primary);
	box-shadow: 0 0 0 3px rgba(var(--primary-rgb), 0.12);
	outline: none;
}

#header .search-widget form button[type="submit"],
.ds-header-top__search button[type="submit"] {
	position: absolute;
	right: 4px;
	top: 50%;
	transform: translateY(-50%);
	background: var(--primary);
	border: none;
	border-radius: 50px;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--bg-white);
	cursor: pointer;
	transition: background var(--transition-fast);
	flex-shrink: 0;
}

#header .search-widget form button[type="submit"]:hover,
.ds-header-top__search button[type="submit"]:hover {
	background: var(--secondary);
}

/* Actiuni dreapta: Cont + Cos */
.ds-header-top__actions {
	display: flex;
	align-items: center;
	gap: 8px;
	flex-shrink: 0;
	margin-left: auto;
}

.ds-header-top__actions .blockcart,
.ds-header-top__actions #_desktop_user_info,
.ds-header-top__actions #_desktop_cart {
	margin-bottom: 0;
}

/* Sign in + Cart: icon sus, text jos */
.ds-header-top__actions .header-block__action-btn {
	display: flex !important;
	flex-direction: column !important;
	align-items: center !important;
	justify-content: center !important;
	gap: 2px;
	text-decoration: none;
	color: var(--textcolor);
	font-size: 0.73rem;
	font-weight: 600;
	line-height: 1.2;
	min-width: 52px;
	text-align: center;
	transition: color var(--transition-fast);
	background: transparent;
	border: none;
	padding: 4px 8px;
	position: relative;
}

.ds-header-top__actions .header-block__action-btn:hover {
	color: var(--primary);
}

/* Wrapper iconita - relativ pentru badge */
.ds-header-top__actions .header-block__icon {
	font-size: 22px !important;
	line-height: 1;
	display: block;
	position: relative;
}

/* Înlocuiești iconița Sign In cu SVG custom */
.ds-header-top__actions #_desktop_ps_customersignin .header-block__icon {
	font-size: 0 !important;
	color: transparent;
	width: 27px;
	height: 27px;
	background: url('sign_in_icon.svg') center / contain no-repeat;
	display: block;
}

/* Înlocuiești iconița Cart cu SVG custom */
.ds-header-top__actions #_desktop_ps_shoppingcart .header-block__icon {
	font-size: 0 !important;
	color: transparent;
	width: 27px;
	height: 27px;
	background: url('cart_icon.svg') center / contain no-repeat;
	display: block;
}

/* Textul jos - forțat vizibil */
.ds-header-top__actions .header-block__title {
	display: block !important;
	font-size: 0.73rem;
	font-weight: 600;
	line-height: 1;
}

/* Badge coș: suprapus pe iconita, top-right */
.ds-header-top__actions .header-block__badge {
	position: absolute;
	top: -2px;
	right: 2px;
	background: var(--primary);
	color: #fff;
	border-radius: 50px;
	min-width: 18px;
	height: 18px;
	padding: 0 4px;
	font-size: 0.65rem;
	font-weight: 700;
	display: flex !important;
	align-items: center;
	justify-content: center;
	line-height: 1;
	border: 2px solid var(--bg-white);
}

/* Eliminăm flex-row de pe header-block */
.ds-header-top__actions .header-block {
	display: flex;
	align-items: center;
}

/* --- Linia 2: ds-header-nav --- */
.ds-header-nav {
	background: var(--bg-white);
	border-top: 1px solid var(--bordercolor);
}

.ds-header-nav__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 30px;
	gap: 16px;
}

/* Iconite categorii meniu */
.ds-menu-cat-icon {
	width: 20px;
	height: 20px;
	object-fit: contain;
	flex-shrink: 0;
	display: inline-block;
	vertical-align: middle;
	margin-right: 4px;
}

/* Meniu categorii - stanga */
.ds-header-nav__menu {
	flex: 1;
	min-width: 0;
}

.ps-mainmenu__tree-link {
	color: #000000 !important;
	font-weight: 600 !important;
	padding-left: 20px !important;
	padding-right: 20px !important;
	padding-top: 1rem !important;
	padding-bottom: 1rem !important;
}

#top-menu,
.top-menu {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 2px;
}

#top-menu > li > a,
.top-menu > li > a {
	font-weight: 600;
	font-size: 0.92rem;
	color: var(--textcolor);
	padding: 10px 14px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	gap: 5px;
	transition: background var(--transition-fast), color var(--transition-fast);
	white-space: nowrap;
	text-decoration: none;
}

#top-menu > li > a:hover,
.top-menu > li > a:hover,
#top-menu > li.current > a,
.top-menu > li.current > a {
	background: rgba(var(--primary-rgb), 0.08);
	color: var(--primary);
}

/* Suport telefonic - dreapta */
.ds-header-nav__contact {
	flex-shrink: 0;
	white-space: nowrap;
}

.ds-header-nav__contact a,
.ds-header-nav__contact span,
#_desktop_contact_link a,
#_desktop_contact_link span {
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--textcolor);
	display: flex;
	align-items: center;
	gap: 6px;
	text-decoration: none;
	transition: color var(--transition-fast);
}

.ds-header-nav__contact a:hover,
#_desktop_contact_link a:hover {
	color: var(--primary);
}

/* Buttons */
.btn,
.btn-primary,
button,
input[type="submit"] {
	border-radius: var(--radius);
	transition: all var(--transition-fast);
}

.btn-primary,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
input.btn-primary,
button.btn-primary {
	background: var(--primary);
	border-color: var(--primary);
	color: var(--bg-white);
}

.btn-primary:hover,
input.btn-primary:hover,
button.btn-primary:hover {
	background: var(--secondary);
	border-color: var(--secondary);
}

.btn-link,
.btn-unstyle,
.dropdown a,
.product-price,
.product-title a {
	color: var(--primary);
}

/* Forms */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="search"],
input[type="number"],
textarea,
select,
.form-control {
	border: 1px solid var(--bordercolor);
	border-radius: var(--radius);
	min-height: 44px;
	color: var(--textcolor);
	background: var(--bg-white);
}

input:focus,
textarea:focus,
select:focus,
.form-control:focus {
	border-color: var(--primary);
	box-shadow: 0 0 0 0.2rem rgba(var(--primary-rgb), 0.15);
}

/* Product cards */
.product-miniature,
.products .product-miniature {
	margin-bottom: 16px;
}

/* Hummingbird: border pe tot cardul (__inner), nu numai pe __top */
.product-miniature__inner {
	border: 1px solid var(--bordercolor);
	border-radius: var(--radius) !important;
	overflow: hidden;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}

.product-miniature__inner:hover {
	border-color: var(--primary) !important;
	box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.06) !important;
	transform: translateY(-2px);
}

.product-miniature__top {
	border: none !important;
	border-radius: 0 !important;
}

.product-miniature__bottom {
	padding: 1rem 1.4rem 1.4rem 1.4rem;
}

/* Titlu negru */
.product-miniature__title {
	color: #000000 !important;
	font-weight: 600;
}

/* Pret 18px */
.product-miniature__price {
	font-size: 18px !important;
}

/* Buton: full width, centrat, albastru, text alb */
.product-miniature__actions {
	width: 100%;
}

.product-miniature__form {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: .5rem;
	width: 100%;
}

.product-miniature__add,
.product-miniature__details {
	width: 100% !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	background: var(--primary) !important;
	color: #ffffff !important;
	border: 2px solid var(--primary) !important;
	border-radius: 50px !important;
	font-weight: 600;
	padding: 10px 16px;
	transition: background 0.3s ease, border-color 0.3s ease !important;
}

.product-miniature__add:hover,
.product-miniature__details:hover {
	background: var(--secondary) !important;
	border-color: var(--secondary) !important;
	color: #ffffff !important;
}

/* Classic theme fallback (.thumbnail-container standalone, NU in hummingbird) */
.product-miniature .thumbnail-container:not(.product-miniature__image-container),
.js-product-miniature .thumbnail-container:not(.product-miniature__image-container) {
	background: var(--bg-white);
	border: 1px solid var(--bordercolor);
	border-radius: var(--radius);
	overflow: hidden;
	padding: var(--card-space);
	height: 100%;
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);
}

.product-miniature .thumbnail-container:not(.product-miniature__image-container):hover,
.js-product-miniature .thumbnail-container:not(.product-miniature__image-container):hover {
	border-color: var(--primary);
	box-shadow: var(--shadow-card);
	transform: translateY(-2px);
}

/* Hummingbird: imaginea NU are border propriu */
.product-miniature__image-container.thumbnail-container {
	border: none !important;
	border-radius: 0 !important;
	padding: 0;
}

/* Ascunde Quick view */
.product-miniature__quickview-button,
.product-miniature__quickview-touch,
.quickview-button,
.quick-view {
	display: none !important;
}

/* Opreste zoom-ul pe imagine la hover */
.product-miniature__inner:hover .product-miniature__image {
	transform: none !important;
}

/* Shadow vizibil la hover in swiper */
.ds-swiper-outer .product-miniature__inner:hover {
	z-index: 10;
	position: relative;
}

.product-miniature .product-title,
.product-miniature .product-title a {
	color: var(--textcolor);
	font-weight: 600;
}

.product-miniature .product-price-and-shipping,
.product-miniature .price {
	color: var(--primary);
	font-weight: 700;
}

/* Product page */
#product #content,
.product-container,
.product-information,
.tabs {
	color: var(--textcolor);
}

#product .product-cover img,
.product-cover img {
	border-radius: var(--radius);
	border: 1px solid var(--bordercolor);
}

.product-images > li.thumb-container > .thumb,
.product-images .thumb {
	border: 1px solid var(--bordercolor);
	border-radius: var(--radius-sm);
}

.product-information {
	background: var(--bg-white);
	border: 1px solid var(--bordercolor);
	border-radius: var(--radius);
	padding: 16px;
}

.product-prices .current-price,
.product-prices .price {
	color: var(--primary);
}

/* Generic blocks */
.card,
.block-categories,
.block_newsletter,
.featured-products,
.category-cover,
.cart-grid-body,
.cart-grid-right {
	border-radius: var(--radius);
	border: 1px solid var(--bordercolor);
	background: var(--bg-white);
}

/* Footer */
#footer {
	margin-top: 24px;
	background: var(--bg-grey);
	color: var(--textcolor);
	border-top: 1px solid var(--bordercolor);
}

#footer .container {
	padding-top: 24px;
	padding-bottom: 24px;
}

#footer a {
	color: var(--primary);
}

#footer a:hover,
#footer a:focus {
	color: var(--secondary);
}

/* Mobile-first spacing */
.container {
	padding-left: var(--container-space-mobile);
	padding-right: var(--container-space-mobile);
}

/* Global responsive safeguards */
.products,
.product-list,
.cart-grid,
.checkout,
.row {
	min-width: 0;
}

.table-responsive,
.js-product-list .products {
	overflow-x: auto;
}

/* Home slider in container */
.ps-imageslider,
.homeslider-container,
#homepage-slider {
	box-sizing: border-box;
	float: none;
	width: 100%;
	max-width: 1530px;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--container-space-mobile);
	padding-right: var(--container-space-mobile);
	position: relative;
	z-index: 1;
}

/* Elimina spatiul de deasupra sliderului pe homepage */
body#index #content-wrapper,
body#index .page-home,
body#index #main > .container,
body#index #main,
body#index #wrapper {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

/* Reducer spatiu intre header nav si slider */
.ds-header-nav {
	margin-bottom: 0 !important;
}

#wrapper,
#main,
.page-wrapper,
main {
	padding-top: 0 !important;
	margin-top: 0 !important;
}

.ps-imageslider .ps-imageslider__figure,
.homeslider-container,
#homepage-slider,
.homeslider,
.homeslider li,
.homeslider img {
	border-radius: var(--radius);
}

.ps-imageslider,
.homeslider-container,
#homepage-slider,
.homeslider,
.ps-imageslider .ps-imageslider__figure {
	overflow: hidden;
}

/* Mobile: up to 575px */
@media (max-width: 575.98px) {
	#header {
		padding: 10px 0;
	}

	#header .header-top,
	#header .header-nav {
		padding-left: 0;
		padding-right: 0;
	}

	.product-miniature,
	.products .product-miniature {
		margin-bottom: 12px;
	}

	.product-miniature .thumbnail-container,
	.js-product-miniature .thumbnail-container {
		padding: 10px;
	}

	.product-information {
		padding: 12px;
	}

	#footer .container {
		padding-top: 16px;
		padding-bottom: 16px;
	}

	/* Header mobil: search full-width pe rand nou */
	.ds-header-top__row {
		flex-wrap: wrap;
		gap: 10px;
	}

	.ds-header-top__logo {
		order: 1;
		flex: 1;
	}

	.ds-header-top__actions {
		order: 2;
	}

	.ds-header-top__search {
		order: 3;
		flex: 0 0 100%;
		max-width: 100%;
		margin: 0;
	}

	/* Categorii scroll orizontal pe mobil */
	.ds-header-nav__menu {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}

	#top-menu,
	.top-menu {
		flex-wrap: nowrap;
		overflow-x: auto;
		padding-bottom: 4px;
		scrollbar-width: none;
	}

	#top-menu::-webkit-scrollbar,
	.top-menu::-webkit-scrollbar {
		display: none;
	}

	.ds-header-nav__contact {
		display: none !important;
	}

	/* Mobile simplification: hide secondary elements */
	#_desktop_top_menu,
	#_desktop_contact_link,
	#_desktop_user_info,
	#search_filters_wrapper,
	.product-miniature .highlighted-informations,
	.product-miniature .product-description-short,
	.product-miniature .variant-links,
	.product-miniature .product-availability,
	.product-miniature .product-flags,
	.product-discounts,
	.product-prices .tax-shipping-delivery-label,
	.breadcrumb,
	.block-category .category-description,
	#footer .block_newsletter,
	#footer .social-sharing,
	#footer .block-contact {
		display: none !important;
	}
}

/* Large mobile: 576px - 767px */
@media (min-width: 576px) and (max-width: 767.98px) {
	.container {
		padding-left: 14px;
		padding-right: 14px;
	}

	.product-miniature .thumbnail-container,
	.js-product-miniature .thumbnail-container {
		padding: 12px;
	}

	/* Keep category/product lists compact on mobile landscape */
	.product-miniature .highlighted-informations,
	.product-miniature .variant-links,
	.product-miniature .product-availability,
	.product-miniature .product-description-short,
	.block-category .category-description,
	.product-discounts {
		display: none !important;
	}
}

@media (min-width: 768px) {
	.container {
		padding-left: var(--container-space-tablet);
		padding-right: var(--container-space-tablet);
	}

	.product-information {
		padding: 20px;
	}

	/* Header tabletă */
	.ds-header-top__search {
		max-width: 400px;
	}

	#footer .container {
		padding-top: 20px;
		padding-bottom: 20px;
	}

	.ps-imageslider,
	.homeslider-container,
	#homepage-slider {
		padding-left: var(--container-space-tablet);
		padding-right: var(--container-space-tablet);
	}
}

@media (min-width: 992px) {
	.container {
		padding-left: var(--container-space-desktop);
		padding-right: var(--container-space-desktop);
	}

	.product-miniature {
		margin-bottom: 20px;
	}

	.product-miniature .thumbnail-container,
	.js-product-miniature .thumbnail-container {
		padding: 14px;
	}

	.product-information {
		padding: 24px;
	}

	.ps-imageslider,
	.homeslider-container,
	#homepage-slider {
		padding-left: var(--container-space-desktop);
		padding-right: var(--container-space-desktop);
	}
}

/* Desktop wide: 1200px+ */
@media (min-width: 1200px) {
	.container {
		max-width: 1530px;
		width: 100%;
	}

	/* Desktop: search mai lat */
	.ds-header-top__search {
		max-width: 700px;
	}

	.product-miniature .thumbnail-container,
	.js-product-miniature .thumbnail-container {
		padding: 16px;
	}

	#footer .container {
		padding-top: 24px;
		padding-bottom: 24px;
	}
}

/* ============================================
   SEARCH BORDER - Override final (prioritate maxima)
============================================ */
#header #search_widget form input,
#header #search_widget form input[type="text"],
#header #search_widget form input[type="search"],
#header .search-widget form input,
#header .search-widget form input[type="text"],
#header .search-widget form input[type="search"],
#header .ps-searchbar .ps-searchbar__input,
#header .ps-searchbar__input,
.ds-header-top__search input,
.ds-header-top__search input[type="text"],
.ds-header-top__search input[type="search"],
.ds-header-top__search .ps-searchbar__input {
	border: 1.5px solid #000000 !important;
	border-radius: 50px !important;
	background-color: var(--bg-white) !important;
	padding: 10px 80px 10px 18px !important;
}

/* Iconita search (lupa) - pill albastru la dreapta */
.ds-header-top__search .ps-searchbar__magnifier,
.ds-header-top__search .js-search-icon,
#header .ps-searchbar__magnifier,
#header .js-search-icon {
	left: auto !important;
	right: 4px !important;
	top: 50% !important;
	transform: translateY(-50%) !important;
	position: absolute !important;
	/* Stil pill albastru */
	background: var(--primary) !important;
	color: #fff !important;
	border-radius: 50px !important;
	width: auto !important;
	height: 36px !important;
	padding: 0 18px !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 22px !important;
	cursor: pointer !important;
	transition: background var(--transition-fast) !important;
}

.ds-header-top__search .ps-searchbar__magnifier:hover,
#header .ps-searchbar__magnifier:hover {
	background: var(--secondary) !important;
}

#header #ps_searchbar .ps-searchbar__magnifier {
	left: auto !important;
	right: 4px !important;
}
/* ============================================
   SECTIUNEA CATEGORII HOMEPAGE
============================================ */
.ds-cat-section {
	padding: 48px 0;
}

.ds-cat-section__grid {
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr;
	gap: 20px;
	align-items: center;
}

/* Card intro - stanga, verde - iese peste Cabinet */
.ds-cat-section__intro {
	background: var(--secondary);
	border-radius: var(--radius);
	padding: 2.5rem 150px 2.5rem 2rem;
	display: flex;
	flex-direction: column;
	justify-content: center;
	color: #ffffff;
	align-self: stretch;
	min-height: 440px;
	position: relative;
	z-index: 0;
	margin-right: -80px;
}

.ds-cat-section__intro-title {
	font-size: 1.4rem;
	font-weight: 700;
	color: #ffffff;
	margin-bottom: 1rem;
}

.ds-cat-section__intro-desc {
	font-size: 0.92rem;
	color: rgba(255,255,255,0.85);
	line-height: 1.6;
	margin: 0;
}

/* Carduri categorii */
.ds-cat-card {
	position: relative;
	border-radius: var(--radius);
	overflow: hidden;
	height: 340px;
	align-self: center;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	background: #2a6b6a center / cover no-repeat;
	text-decoration: none;
	transition: transform var(--transition-fast), box-shadow var(--transition-fast);
	z-index: 1;
}

/* Primul card foto se suprapune peste cardul verde */
.ds-cat-section__intro + .ds-cat-card {
	margin-left: 0;
}

.ds-cat-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 32px rgba(0,0,0,0.18);
	text-decoration: none;
}

/* Overlay inchis-gradient */
.ds-cat-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(to bottom, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.62) 100%);
	border-radius: var(--radius);
	z-index: 0;
}

/* Icon deasupra titlului */
.ds-cat-card__icon {
	background: #ffffff;
	border-radius: 16px;
	width: 76px;
	height: 76px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 14px rgba(0,0,0,0.18);
	margin-bottom: 0.75rem;
}

.ds-cat-card__icon img {
	width: 46px;
	height: 46px;
	object-fit: contain;
}

/* Continut jos */
.ds-cat-card__body {
	position: relative;
	z-index: 1;
	padding: 1.2rem;
}

.ds-cat-card__name {
	font-size: 1.1rem;
	font-weight: 700;
	color: #ffffff;
	margin-bottom: 0.4rem;
}

.ds-cat-card__desc {
	font-size: 0.82rem;
	color: rgba(255,255,255,0.85);
	margin-bottom: 1rem;
	line-height: 1.4;
}

/* Butoane */
.ds-cat-card__actions {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}

.ds-cat-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 14px;
	border-radius: 50px;
	font-size: 0.82rem;
	font-weight: 600;
	text-decoration: none;
	transition: background var(--transition-fast), color var(--transition-fast);
}

.ds-cat-card__btn--outline {
	background: transparent;
	border: 1.5px solid rgba(255,255,255,0.8);
	color: #ffffff;
}

.ds-cat-card__btn--outline:hover {
	background: #ffffff;
	color: var(--textcolor);
	border-color: #ffffff;
}

/* Responsive */
@media (max-width: 991.98px) {
	.ds-cat-section__grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 575.98px) {
	.ds-cat-section__grid {
		grid-template-columns: 1fr;
	}

	.ds-cat-section {
		padding: 32px 0;
	}
}

/* ============================================
   SWIPER CAROUSEL - Homepage only
============================================ */
.ds-swiper-outer {
	overflow: hidden;
	padding: 4px 2px 14px 2px;
	margin: -4px -2px -14px -2px;
}

.ds-products-swiper {
	position: relative;
	overflow: visible;
}

/* Ascuns pana la init Swiper - previne FOUC */
.ds-products-swiper:not(.swiper-initialized) {
	visibility: hidden;
	min-height: 380px;
}

.ds-products-swiper .swiper-wrapper {
	padding: 15px 0;
}

.ds-products-swiper .swiper-slide {
	height: auto;
	display: flex;
}

.ds-products-swiper .swiper-slide .product-miniature {
	margin-bottom: 0;
	height: 100%;
	width: 100%;
}

.ds-products-swiper .swiper-slide .product-miniature__inner {
	width: 100%;
}

/* Aspect ratio fix - previne CLS la incarcare */
.ds-products-swiper .product-miniature__image-container {
	aspect-ratio: 1 / 1;
	overflow: hidden;
}

.ds-products-swiper .product-miniature__image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transition: none !important;
}

/* Butoane nav */
.ds-swiper-prev,
.ds-swiper-next {
	width: 40px !important;
	height: 40px !important;
	background: var(--bg-white) !important;
	border: 1px solid var(--bordercolor) !important;
	border-radius: 50% !important;
	box-shadow: var(--shadow-card);
	transition: background var(--transition-fast), border-color var(--transition-fast);
}

.ds-swiper-prev:hover,
.ds-swiper-next:hover {
	background: var(--primary) !important;
	border-color: var(--primary) !important;
}

.ds-swiper-prev::after,
.ds-swiper-next::after {
	font-size: 14px !important;
	font-weight: 700;
	color: var(--textcolor);
	transition: color var(--transition-fast);
}

.ds-swiper-prev:hover::after,
.ds-swiper-next:hover::after {
	color: #ffffff;
}