/* *{
box-sizing: border-box;
background: rgb(0 100 0 / 0.1) !important;
} */

/* *,*:focus,*:active {
outline: none !important;
user-select: none !important;
-webkit-tap-higlight-color: transparent !important;
} */

/* Disable blue highlight on button click */
/* button {
-webkit-tap-highlight-color: transparent;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
} */

/* You can do the same for links */
a, .hfe-nav-menu-icon {
	-webkit-tap-highlight-color: transparent !important;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
}

body:not(.elementor-page,.blog) #content{
	background: linear-gradient(180deg, #ffffff 0%, #fcfcfc 100%);
	border-radius: 24px;
	padding: 22px 18px 20px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, .05), 0 2px 10px rgba(0, 0, 0, .03);
	margin: 50px auto;
}

body:not(.elementor-page,.blog) #content a{
	color: var( --e-global-color-primary );
}

body:not(.elementor-page,.blog) #content h2{
	font-size: 1.5rem;
	font-weight: 600;
}

body:not(.elementor-page,.blog) #content h3{
	font-size: 1.2rem;
	font-weight: 600;
}


/* =========================================================
GLOBAL TOKENS
========================================================= */
:root {
	--ui-primary: var(--e-global-color-primary, #85907a);
	--ui-accent: var(--e-global-color-accent, #2b2f2d);
	--ui-text: var(--e-global-color-text, #1f2937);
	--ui-muted: rgba(31, 41, 55, 0.62);
	--ui-line: rgba(31, 41, 55, 0.08);
	--ui-bg: #fff;
	--ui-soft: rgba(133, 144, 122, 0.08);
	--ui-soft-strong: rgba(133, 144, 122, 0.1);
	--ui-shadow: 0 12px 30px rgba(17, 24, 39, 0.06);
	--ui-shadow-hover: 0 18px 44px rgba(17, 24, 39, 0.08);
	--ui-radius: 18px;
	--ui-radius-sm: 14px;
	--ui-radius-xs: 12px;
}

/************* Menu **************/

ul.sub-menu{
	border-radius:10px !important;
}
ul.sub-menu li:first-child a{
	border-radius:10px 10px 0px 0px !important;
}
ul.sub-menu li:last-child a{
	border-radius:0px 0px 10px 10px !important;
}

/*************Breadcrumbs***********/
#breadcrumbs a{
	color: var(--ui-primary);
	font-weight: 600;
}

#breadcrumbs .breadcrumb_last{
	color: var(--ui-primary);
	opacity: .9;
}


.blog .page-header h1{
	font-family: "Satisfy", Sans-serif;
	line-height: 1.15;
	font-weight: 500;
	color: var( --e-global-color-text );
}

.page-header p{
	color: #6b7280;
	font-size: .98rem;
}

.elementor-widget-navigation-menu > * {
	outline: 0 !important;
	border: none;
	-moz-outline-style: none;
}

body {
	font-family: "Manrope", sans-serif;
}
.single-recipe .r-card{
	border:1px solid rgb(31 41 55 / 4%);
}

.post-type-archive-recipe .page-header{
	display:none;
}

/*******HERO SECTION*****/
.cv-home-hero {
	position: relative;
	width: 100%;
	overflow: visible;
	display: flex;
	align-items: center;
	justify-content: center;
}

.cv-home-hero-stage {
	position: relative;
	width: 100%;
	min-height: 700px;
	transform-origin: center center;
}

/* κύκλοι */
.cv-home-hero-stage .cv-visual-rings {
	position: absolute;
	width: min(520px, 84%);
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	border: 2px solid rgb(255 255 255 / 83%);
	top: 40px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}

.cv-home-hero-stage .cv-visual-rings::before,
.cv-home-hero-stage .cv-visual-rings::after {
	content: "";
	position: absolute;
	inset: 24px;
	border-radius: 50%;
	border: 2px solid rgb(255 255 255 / 83%);
}

.cv-home-hero-stage .cv-visual-rings::after {
	inset: 48px;
	border-color: rgba(255,255,255,0.18);
}

/* blobs */
.cv-home-hero-stage .cv-visual-blob {
	position: absolute;
	z-index: 2;
}

.cv-home-hero-stage .cv-visual-blob-main {
	width: 404px;
	height: 420px;
	background: #7faa97;
	left: 35px;
	bottom: 40px;
	border-radius: 43% 57% 49% 51% / 38% 34% 66% 62%;
	transform: rotate(-18deg);
}

.cv-home-hero-stage .cv-visual-blob-top {
	width: 210px;
	height: 230px;
	background: #bfd296;
	right:80px;
	top: 100px;
	border-radius: 47% 53% 58% 42% / 46% 39% 61% 54%;
	transform: rotate(18deg);
	opacity: 0.9;
}

.cv-home-hero-stage .cv-visual-blob-bottom {
	width: 250px;
	height: 210px;
	background: #c8dcab;
	left: 30px;
	bottom: 10px;
	border-radius: 53% 47% 40% 60% / 54% 42% 58% 46%;
	transform: rotate(18deg);
	opacity: 0.9;
}

/* εικόνα */
.cv-home-hero-stage .cv-visual-person {
	position: absolute;
	inset: 0;
	z-index: 3;
	display: flex;
	align-items: flex-end;
	justify-content: center;
}

.cv-home-hero-stage .cv-visual-person img {
	width: 100%;
	display: block;
	position: relative;
	filter: drop-shadow(0 16px 24px rgba(0,0,0,0.12));
	max-width: 420px !important;
}

@media (max-width: 1024px) {

	.cv-home-hero-stage {
		transform: scale(0.85);
	}
}

@media (max-width: 767px) {

	.cv-home-hero-stage {
		transform: scale(1);
	}
	.cv-home-hero-stage .cv-visual-blob-main {
		left: 100px;
	}
	.cv-home-hero-stage .cv-visual-blob-top {
		right: 150px;
		top: 100px;
		border-radius: 47% 53% 58% 42% / 46% 39% 61% 54%;
		transform: rotate(18deg);
	}

}
@media (max-width: 560px) {

	.cv-visual-blob-top{
		width: 150px !important;
		height: 150px !important;
		right:60px!important;
		top: 150px !important;
	}
	.cv-home-hero-stage .cv-visual-blob-main {
		left: 40px;
		bottom: 40px;
	}

	.cv-home-hero-stage .cv-visual-blob-bottom {
		width: 220px !important;
		height: 180px !important;
		left: 38px;
		bottom: 10px;
	}
	.cv-home-hero-stage {
		min-height: 600px;
	}

}


/**********HEADER**********/
header {
	transition: background 0.3s ease, box-shadow 0.3s ease, padding 0.3s ease, transform 0.3s ease !important;
}

header.smooth-fixed {
	position: fixed !important;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9999 !important;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
	animation: slideDown 0.3s ease forwards;
	background-color:white;
}

header.smooth-fixed img {
	transform: scale(0.8) !important;
	transition: transform 0.3s ease !important;
}

header#masthead.smooth-fixed .elementor-widget-container {
	padding: 8px 0px 8px 0px !important;
} 
@keyframes slideDown {
	from {
		transform: translateY(-100%);
	}
	to {
		transform: translateY(0);
	}
}

/* =========================================================
GLOBAL BUTTONS
========================================================= */
.elementor-button {
	transition:
		box-shadow 0.3s,
		border-radius 0.3s,
		border-color 0.3s,
		transform 0.3s,
		background-color 0.3s,
		color 0.3s;
}

.elementor-element .elementor-button:hover {
	box-shadow: 0 8px 14px 0 rgb(83 119 66 / 25%) !important;
	border-radius: 16px !important;
	transform: translate3d(0, -3px, 0.01px) !important;
	color: #fff !important; 
}

/**HOME PAGE**/
.cv-animation-fadeInDown{
	opacity: 0;
	transform: translateY(-30px);
	animation: fadeInDown 0.8s ease-out forwards;
}
.cv-animation-fadeInDown__slow{
	opacity: 0;
	transform: translateY(-30px);
	animation: fadeInDown 0.6s ease-out forwards;
}

/* =========================================================
BLOG ARCHIVE
========================================================= */

.blog #content{
	max-width: 1140px !important;
}
.archive-wrap{
	max-width:1120px;
	margin:0 auto;
	padding:56px 18px 80px;
}

.archive-header{
	text-align:center;
	margin-bottom:30px;
}

.archive-title{
	margin:0 0 10px;
	font-size:3.12rem;
	line-height:1.05;
	letter-spacing:-0.03em;
	color:var(--primary);
	font-weight:800;
}

.archive-subtitle{
	max-width:720px;
	margin:0 auto;
	font-size:16px;
	line-height:1.8;
	color:var(--muted);
}

.archive-grid{
	display:grid;
	grid-template-columns:repeat(3,minmax(0,1fr));
	gap:22px;
}

@media (max-width:1024px){
	.archive-grid{
		grid-template-columns:repeat(2,minmax(0,1fr));
	}
}

@media (max-width:640px){
	.archive-grid{
		grid-template-columns:1fr;
	}
}

.archive-card{
	display:flex;
	flex-direction:column;
	background:#fff;
	border:1px solid var(--ui-line);
	border-radius:var(--ui-radius);
	box-shadow:var(--ui-shadow);
	overflow:hidden;
	transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.archive-card:hover{
	transform:translateY(-3px);
	border-color:rgba(133,144,122,.22);
	box-shadow:0 18px 44px rgba(17,24,39,.08);
}

.archive-thumb{
	display:block;
	overflow:hidden;
}

.archive-thumb img{
	width:100%;
	height:220px;
	object-fit:cover;
	display:block;
	transition:transform .3s ease;
}

.archive-card:hover .archive-thumb img{
	transform:scale(1.05);
}

.archive-thumb-fallback{
	height:220px;
	display:flex;
	align-items:center;
	justify-content:center;
	background:linear-gradient(180deg, rgba(133,144,122,.10), rgba(255,255,255,.96));
	color:var(--ui-muted);
	font-size:36px;
}

.archive-body{
	padding:18px;
	display:flex;
	flex-direction:column;
	gap:10px;
	flex:1;
	text-align: center;
}

.archive-card-title{
	margin: 0 0 10px;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.35;
	color: #111827;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.archive-card-title a{
	color:var(--text);
	text-decoration:none;
}

.archive-card-title a:hover{
	color:var(--ui-primary);
}

.archive-excerpt{
	color:var(--ui-muted);
	font-size:14px;
	line-height:1.7;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;

}

.archive-excerpt p{
	margin:0;
}

.archive-cta{
	display: inline-block;
	margin-top: auto;
	padding: 14px 26px;
	font-size: .82rem;
	font-weight: 400;
	text-decoration: none !important;
	color: var(--e-global-color-d6cea4e);
	border-radius: 16px 0px 16px 0px;
	background-color: var(--ui-text);
	transition: all .22s ease;
	width: fit-content;
	margin: 30px auto 0;
}

.archive-cta:hover{
	color:#fff;
	box-shadow:0 8px 14px rgba(149,212,119,.23);
	border-radius:16px;
	transform:translate3d(0,-3px,0.01px);
	background: var(--e-global-color-accent);
}

.archive-pagination{
	margin-top:40px;
	display:flex;
	justify-content:space-between;
	align-items:center;
	gap:12px;
	flex-wrap:wrap;
}

.archive-pagination .nav-previous a,
.archive-pagination .nav-next a{
	display:inline-flex;
	align-items:center;
	justify-content:center;
	padding:10px 16px;
	border:1px solid var(--ui-line);
	border-radius:999px;
	background:#fff;
	color:var(--ui-text);
	text-decoration:none;
	transition:box-shadow .3s, border-color .3s, transform .3s, color .3s;
}

.archive-pagination .nav-previous a:hover,
.archive-pagination .nav-next a:hover{
	color:var(--ui-primary);
	box-shadow:0 8px 14px rgba(149,212,119,.23);
	transform:translate3d(0,-3px,0.01px);
}
/* =========================================================
SERVICE ITEM
========================================================= */
.cv-service-item {
	box-shadow: rgba(149, 157, 165, 0.2) 0 8px 24px 0;
}

.cv-service-item svg {
	position: relative;
}

.cv-service-item .elementor-icon::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: -1;
	width: 140px;
	height: 140px;
	background: #fffaf6;
	border-radius: 50%;
	transform: translate(-50%, -80%);
}

/* =========================================================
MAILCHIMP FORM
========================================================= */
.cv_mailchimp_form {
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.cv_mailchimp_form #email {
	min-height: 72px;
	margin-bottom: 0;
	padding: 16px 24px;
	border: 1px solid #eff4ed;
	border-radius: 0 0 16px;
	background-color: #fff;
	box-shadow: 0 2px 14px 0 rgba(20, 20, 43, 0.04);
	font-size: 18px !important;
	font-weight: 500;
	line-height: 1.111em;
	transition: box-shadow 0.3s, color 0.3s, border-color 0.3s;
}

.cv_mailchimp_form .mailchimp_submit {
	display: inline-flex;
	justify-content: center;
	padding: 24px 38px;
	border: none;
	border-radius: 16px 0;
	background-color: #191a17 !important;
	color: #fff;
	text-align: center;
	text-decoration: none;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.111em;
	transform-style: preserve-3d;
	transition:
		box-shadow 0.3s,
		border-color 0.3s,
		background-color 0.3s,
		border-radius 0.3s,
		transform 0.3s,
		color 0.3s;
}

.cv_mailchimp_form .mailchimp_submit:hover{
	background-color: var(--e-global-color-primary) !important;
	box-shadow: 0 8px 14px 0 rgb(83 119 66 / 25%) !important;
	border-radius: 16px !important;
	transform: translate3d(0, -3px, 0.01px) !important;
	color: #fff !important;
}

/* =========================================================
FAQ - HOMEPAGE
========================================================= */
.faq-homepage .e-n-accordion-item {
	margin-bottom: 15px !important;
	overflow: hidden;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	background: var(--ui-bg);
	box-shadow: var(--ui-shadow);
}

.faq-homepage .e-n-accordion-item .e-n-accordion-item-title {
	padding: 20px 40px;
}

.faq-homepage .e-n-accordion-item .e-child {
	padding: 0 20px;
}


/* =========================================================
SINGLE SERVICE
========================================================= */
.service-wrap {
	max-width: 1120px;
	margin: 0 auto;
	padding: 56px 18px 90px;
	color: var(--ui-text);
}

.service-hero {
	display: grid;
	grid-template-columns: 420px 1fr;
	grid-template-areas:
		"breadcrumbs breadcrumbs"
		"media head";
	gap: 18px;
	align-items: center;
}

#breadcrumbs {
	grid-area: breadcrumbs;
}

.service-hero > div:first-of-type {
	grid-area: media;
}

.service-photo,
.service-head,
.service-content,
.service-booking {
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	box-shadow: var(--ui-shadow);
}

.service-photo {
	overflow: hidden;
	background: #fff;
}

.service-photo img {
	display: block;
	width: 100%;
	max-height: 350px;
	object-fit: cover;
}

.service-photo-fallback {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 420px;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	background: linear-gradient(180deg, rgba(133, 144, 122, 0.1), rgba(255, 255, 255, 0.96));
	box-shadow: var(--ui-shadow);
	color: var(--ui-muted);
	font-size: 52px;
}

.service-head {
	grid-area: head;
	padding: 28px;
	background: var(--ui-bg);
}

.service-title {
	margin: 0 0 14px;
	color: var(--ui-primary);
	line-height: 1.02;
	letter-spacing: -0.03em;
}

.service-excerpt {
	max-width: 720px;
	margin: 0 0 22px;
	color: var(--ui-muted);
	font-size: 17px;
	line-height: 1.85;
}

.service-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 190px;
	padding: 16px 24px;
	border-radius: 18px 0 18px 0;
	background: #151815;
	color: #fff;
	text-decoration: none;
	font-weight: 500;
	transition: transform 0.15s ease, opacity 0.15s ease;
}

.service-cta:hover, .service-booking button[type="submit"]:hover,
.service-booking .wpforms-submit:hover {
	box-shadow: 0 8px 14px 0 rgb(83 119 66 / 25%) !important;
	border-radius: 16px !important;
	transform: translate3d(0, -3px, 0.01px) !important;
	background-color: var(--e-global-color-primary)!important;
	color:#fff !important;
}

.service-content {
	margin: 25px 0px;
	padding: 26px;
	background: var(--ui-bg);
}

.service-content :where(p, ul, ol, blockquote) {
	margin-top: 0;
	line-height: 1.9;
}

.service-content :where(h2, h3) {
	margin-top: 24px;
	color: var(--ui-text);
	line-height: 1.2;
	letter-spacing: -0.02em;
}

.service-content a {
	color: var(--ui-primary);
}

.service-booking {
	padding: 26px;
	background: var(--ui-soft);
}

/* Booking intro */
.service-booking__head {
	margin-bottom: 18px;
}

body:not(.single-service) .service-booking__title, body:not(.single-service) .service-booking__text {
	text-align: center;
}
.service-booking__title {
	margin: 0 0 10px;
	color: var(--ui-text); 
	font-size: clamp(28px, 3vw, 42px);
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.03em;
}

.service-booking__text {
	margin: 0;
	color: var(--ui-muted);
	font-size: 16px;
	line-height: 1.8;
}

/* WPForms */
.service-booking .wpforms-container {
	margin: 0 !important;
}

.service-booking .wpforms-form {
	padding: 18px;
	border: 1px solid var(--ui-line);
	border-radius: 16px;
	background: rgba(255, 255, 255, 0.82);
}

.service-booking .wpforms-field {
	padding: 0 0 16px !important;
}

.service-booking .wpforms-field-label {
	margin-bottom: 8px !important;
	color: var(--ui-text) !important;
	font-weight: 700 !important;
}

.service-booking .wpforms-field-sublabel {
	color: var(--ui-muted) !important;
}

.service-booking input[type="text"],
.service-booking input[type="email"],
.service-booking input[type="tel"],
.service-booking input[type="number"],
.service-booking input[type="url"],
.service-booking input[type="date"],
.service-booking input[type="time"],
.service-booking select,
.service-booking textarea {
	padding: 12px 14px !important;
	border: 1px solid var(--ui-line) !important;
	border-radius: var(--ui-radius-xs) !important;
	background: #fff !important;
	color: var(--ui-text) !important;
	box-shadow: none !important;
}

.service-booking input:focus,
.service-booking select:focus,
.service-booking textarea:focus {
	outline: none !important;
	border-color: rgba(133, 144, 122, 0.35) !important;
	box-shadow: 0 0 0 3px rgba(133, 144, 122, 0.1) !important;
}

.service-booking .wpforms-submit-container {
	padding-top: 6px !important;
}

.service-booking button[type="submit"],
.service-booking .wpforms-submit {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	min-width: 180px;
	padding: 27px 22px !important;
	border: 0 !important;
	border-radius: 18px 0 18px 0 !important;
	background: #151815 !important;
	color: #fff !important;
	font-weight: 500 !important;
	transition: transform 0.15s ease, opacity 0.15s ease !important;
}

.service-booking .wpforms-error {
	font-size: 13px !important;
}

.service-booking .wpforms-confirmation-container-full {
	border: 1px solid var(--ui-line) !important;
	border-radius: var(--ui-radius-sm) !important;
	background: #fff !important;
	color: var(--ui-text) !important;
}
.service-booking .wpforms-container .wpforms-required-label, .wp-core-ui div.wpforms-container .wpforms-required-label {
	color: #2f4d2d;
}

/* =========================================================
RECIPES ARCHIVE
========================================================= */

.r-more-hero-section{
	text-align: center;
}
.r-more-grid-archive__bg{
	padding: 0px 5px 50px !important;
	border-radius:0px 0px 18px 18px;
}
.r-meta{
	justify-content: center;
}
.r-more-hero-section h2, .r-more-hero-section p {
	opacity: 0;
	transform: translateY(-30px);
	animation: fadeInDown 0.8s ease-out forwards;
}

@keyframes fadeInDown {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media (min-width: 1140px){
	.r-more-grid-archive__bg{
		padding-right: 20px !important;
		padding-left: 20px !important;
	}
}
/* =========================================================
RECIPE / CONTENT PAGE
========================================================= */
.r-wrap {
	max-width: 1140px;
	margin: 0 auto;
	padding: 48px 10px 72px;
	color: var(--ui-text);
}

.r-header {
	margin-bottom: 26px;
	text-align: center;
}

.r-header h1 {
	margin: 0 0 10px;
	color: var(--ui-text);
	font-size: 2rem;
	font-weight: 500;
	line-height: 1.05;
	letter-spacing: -0.02em;
}

.r-sub {
	max-width: 760px;
	margin: 0 auto;
	color: var(--ui-muted);
	font-size: 16px;
	line-height: 1.7;
}

.r-chips {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 10px;
}

.r-chips {
	margin-top: 16px;
}

.r-actions,.r-share-btn {
	margin-top: 10px;
}

.r-share-btn{
	display:flex;
	justify-content:end;
	gap:20px;
}
.r-share-btn h4{
	font-family: "Manrope", sans-serif;
	font-size: 0.8rem;
	padding:0;
	margin:0;
	align-self:center;
	color:var(--ui-text);
	font-weight:400;
}

.r-share-icons {
	display: flex;
	gap: 12px;
}

.r-share-icons {
	display: flex;
	gap: 12px;
}

.r-share-icons a {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border:1px solid #ceddbf;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all .25s ease;
}

.r-share-icons svg {
	width: 18px;
	height: 18px;
	fill: var(--ui-text);
}

.r-share-icons a:hover {
	transform: translateY(-2px);
}


.r-chip,
.r-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	text-decoration: none;
}

.r-chip {
	padding: 8px 12px;
	border: 1px solid var(--ui-line);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.8);
	color: var(--ui-text);
	font-size: 14px;
}

.r-chip svg,
.r-btn svg {
	width: 16px;
	height: 16px;
}
.r-btn:hover{
	border-radius: 16px !important;
	transform: translate3d(0, -3px, 0.01px) !important;
}
.r-chip svg {
	color: var(--ui-primary);
}

.r-grid {
	display: grid;
	grid-template-columns: 1.1fr 0.9fr;
	gap: 18px;
	align-items: start;
	margin-top: 22px;
}

.r-card{
	height: 100%;
}
.r-card,
.r-thumb {
	overflow: hidden;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	background: var(--ui-bg);
	box-shadow: var(--ui-shadow);
}

.r-card__head {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 18px 18px 8px;
}

.r-badge {
	display: flex;
	flex: 0 0 46px;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 999px;
	background: var(--ui-soft-strong);
}

.r-badge svg {
	width: 22px;
	height: 22px;
	color: var(--ui-primary);
}

.r-card__title {
	margin: 0;
	color: var(--ui-text);
	font-size: 20px;
	font-weight: 400;
}

.r-card__body {
	padding: 12px 18px 18px;
	color: var(--ui-text);
}

.r-thumb img {
	display: block;
	width: 100%;
	height: auto;
}

.r-list {
	margin: 0;
	padding-left: 18px;
	color: var(--ui-text);
}

.r-list li {
	margin: 8px 0;
}


.r-steps {
	list-style: none;
	margin: 0;
	padding: 0;
	counter-reset: step;
}

.r-steps li {
	position: relative;
	counter-increment: step;
	padding: 10px 0 42px 70px; 
	margin: 0;
	min-height: 56px;
}

/* ο αριθμός μέσα στον κύκλο */
.r-steps li::before {
	content: counter(step);
	position: absolute;
	top: 0;
	left: 0;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: var(--ui-primary);
	color: var(--ui-bg);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 23px;
	font-weight: 500;
	line-height: 1;
	z-index: 2;
}

/* η κάθετη γραμμή */
.r-steps li::after {
	content: "";
	position: absolute;
	left: 24px;
	top: 48px; 
	bottom: -6px; 
	width: 1px;
	background: var(--ui-primary);
	opacity: 0.35;
}

/* να μην συνεχίζει η γραμμή μετά το τελευταίο */
.r-steps li:last-child::after {
	display: none;
}


.r-nutri {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10px;
}

.r-n {
	padding: 12px;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius-sm);
	background: #fff;
}

.r-n .k {
	margin: 0;
	color: var(--ui-muted);
	font-size: 12px;
}

.r-n .v {
	margin: 6px 0 0;
	color: var(--ui-text);
	font-size: 16px;
	font-weight: 600;
}

.r-btn {
	justify-content: center;
	min-width: 160px;
	padding: 10px 15px;
	border: 1px solid var(--ui-soft-strong);
	border-radius: 10px;
	background: var(--ui-soft-strong);
	color: var(--ui-primary);
	border-radius: 16px 0px 16px 0px;
	transition: all .22s ease;
	font-weight: 700;
	cursor: pointer;
}
.r-btn:hover {
	background: var(--ui-soft-strong);
	color: var(--ui-primary);
}
.r-btn--dark {
	border-color: #9caa8d;
	background: #9caa8d;
	color: #fff;
}
.r-btn--dark:hover{
	border-color: #9caa8d;
	background: #9caa8d;
	color: #fff;
}
.r-content :where(p, ul, ol) {
	margin-top: 0;
	line-height: 1.75;
}

.r-content a {
	color: var(--ui-primary);
}

.r-muted {
	margin: 0;
	color: var(--ui-muted);
}

/* ======================================= MORE RECIPES ========================================= */
.r-more{
	margin-top: 56px;
	padding: 32px 0 8px;
}

.r-more__head{
	text-align: center;
	margin-bottom: 28px;
}

.r-more__head h2, .r-more-hero-section h2{
	padding: 0 0 6px;
	font-size: 3.12rem;
	line-height: 1.15;
	font-weight: 500;
	color: var( --e-global-color-text );
	font-family: "Satisfy", Sans-serif;
}

.r-more__head p, .r-more-hero-section p{
	margin: 0;
	color: #6b7280;
	font-size: .98rem;
}

.r-more__grid{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.r-mini-card{
	position: relative;
}

.r-mini-card__link{
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	text-decoration: none;
	background: linear-gradient(180deg, #ffffff 0%, #fcfcfc 100%);
	height: 100%;
	border-radius: 24px;
	padding: 22px 18px 20px;
	min-height: 100%;
	box-shadow:
		0 10px 30px rgba(0,0,0,.05),
		0 2px 10px rgba(0,0,0,.03);
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.r-mini-card__link:hover{
	transform: translateY(-4px);
	box-shadow:
		0 16px 34px rgba(0,0,0,.08),
		0 4px 12px rgba(0,0,0,.04);
	border-color: rgba(0,0,0,.1);
}

.r-mini-card__media{
	position: relative;
	width: 200px;
	height: 200px;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.r-mini-card__shadow{
	position: absolute;
	inset: auto 16px 8px 16px;
	height: 26px;
	border-radius: 999px;
	background: radial-gradient(ellipse at center, rgba(0,0,0,.22) 0%, rgba(0,0,0,.08) 45%, rgba(0,0,0,0) 75%);
	filter: blur(8px);
	z-index: 0;
}

.r-mini-card__thumb{
	position: relative;
	z-index: 1;
	width: 180px;
	height: 180px;
	object-fit: cover;
	border-radius: 50%;
	display: block;
	border: 5px solid #fff;
	box-shadow:
		0 12px 24px rgba(0,0,0,.10),
		inset 0 1px 0 rgba(255,255,255,.7);
}

.r-mini-card__thumb--placeholder{
	background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
}

.r-mini-card__content, .r-mini-card_arcive_content{
	display: flex;
	flex-direction: column;
	align-items:center;
	height: 100%;
}
.r-mini-card__content{
	padding: 0px 18px;
}
.r-mini-card__title{
	margin: 0 0 10px;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.35;
	color: #111827;
}
.r-mini-card__btn{
	display: inline-block;
	margin-top: auto;
	padding: 14px 26px;
	font-size: .82rem;
	font-weight: 400;
	color: var(--e-global-color-d6cea4e);
	border-radius: 16px 0px 16px 0px;
	background-color: var(--ui-text);
	transition: all .22s ease;
}

.r-mini-card__link:hover .r-mini-card__btn{
	border-radius: 16px !important;
	transform: translate3d(0, -3px, 0.01px) !important;
	background: var(--e-global-color-accent);
}

/* .r-mini-card__excerpt{
margin: 0 auto;
max-width: 28ch;
color: #6b7280;
font-size: .95rem;
line-height: 1.6;

display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
} */

/* =========================================================
LISTING CARDS (lr / lp)
========================================================= */
.lr-wrap,
.lp-wrap, 
.r-wrap {
	--list-primary: var(--ui-primary);
	--list-text: var(--ui-text);
	--list-muted: var(--ui-muted);
	--list-line: var(--ui-line);
	--list-bg: var(--ui-bg);
	--list-shadow: var(--ui-shadow);
	--list-radius: var(--ui-radius);
}

.lr-grid,
.lp-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

@media (max-width: 640px){

	.lp-grid{
		display: block !important;
	}

	.lp-grid .lp-card{
		width: 100%;
	}

}

.lp-card {
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow: hidden;
	border: 1px solid var(--list-line);
	border-radius: var(--list-radius);
	background: var(--list-bg);
	box-shadow: var(--list-shadow);
	color: inherit;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease, border-color 0.15s ease;
}

.lr-card{
	display: flex;
	flex-direction: column;
	min-height: 100%;
	overflow: hidden;
	transition: transform 0.15s ease;
	margin-right: 40px;
	overflow: visible;
}

@media (max-width: 500px){
	.lr-card{
		margin-right: 0;
		border: 1px solid var(--list-line);
		border-radius: var(--list-radius);
		background: var(--list-bg);
		box-shadow: var(--list-shadow);
	}
}

.lp-card:hover {
	transform: translateY(-3px);
	border-color: rgba(133, 144, 122, 0.22);
	box-shadow: var(--ui-shadow-hover);
}

.lr-thumb,
.lp-thumb {
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-bottom: 1px solid var(--list-line);
	border-radius: var(--list-radius);
	background: #fff;
}

.lp-thumb{
	border-radius: var(--list-radius)  var(--list-radius) 0 0;
}

@media (max-width: 500px){
	.lr-thumb{
		border-radius: var(--list-radius)  var(--list-radius) 0 0;
	}
}

.lr-thumb img,
.lp-thumb img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.lr-fallback,
.lp-fallback {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	background: linear-gradient(180deg, rgba(133, 144, 122, 0.12), rgba(255, 255, 255, 0));
	color: var(--list-muted);
	font-size: 36px;
}

.lp-body {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 10px;
	padding: 18px;
}

/* recipes body */
.lr-body{
	display: flex;
	gap: 20px;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	padding: 48px 32px;
	background-color: #fff;
	box-shadow: 0 2px 14px 0 rgba(20, 20, 43, .04);
	transform: translate(30px, -40px);
}

@media (max-width: 500px){
	.lr-body{
		min-height: unset;
		transform: unset;
		padding: 20px;
		border-radius: 0 0 var(--list-radius) var(--list-radius) ;
	}
}

.owl-stage{
	padding-left:0px !important;
}

.lr-title,
.lp-title {
	margin: 0;
	color: var(--list-text);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.25;
	letter-spacing: -0.01em;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* owl nav */


.owl-nav{
	display: flex !important;
	gap: 20px;
	position: absolute;
	top: -14%;
	right: 10%;
}

@media (max-width: 1024px){
	.owl-nav{
		right: 50%;
		transform: translateX(50%);
	}
}

@media (max-width: 800px){
	.owl-nav{
		top: -13%;
	}
}


.owl-nav button{
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 8px 14px 0 rgba(83 119 66 / 25%) !important;
	border-radius: 50%;
	background: #fff !important;
}

.owl-nav img{
	max-width: 35px;
	transition: ease .3s;
	padding: 3px;
}

.owl-nav img:hover{
	transform: scale(0.9);
}

.lr-meta,
.lp-meta{
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.lr-chip,
.lp-chip,
.r-chip{
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	border: 1px solid var(--list-line);
	border-radius: 999px;
	background: #fff;
	color: var(--list-text);
	font-size: 13px;
}

.lr-chip svg,
.lp-chip svg{
	width: 14px;
	height: 14px;
	color: var(--list-primary);
}

.lr-excerpt,
.lp-excerpt {
	margin: 0;
	color: var(--list-muted);
	font-size: 14px;
	line-height: 1.6;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.lr-cta,
.lp-cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	margin-top: auto;
	color: var(--list-primary);
	font-size: 14px;
	font-weight: 700;
}

.lr-cta svg,
.lp-cta svg {
	width: 16px;
	height: 16px;
}
/* =========================================================
SINGLE POST
========================================================= */

:root{
	--p-primary: var(--e-global-color-primary, #85907a);
	--p-text:    var(--e-global-color-text, #1f2937);
	--p-muted:   rgba(31,41,55,.62);
	--p-line:    rgba(31,41,55,.08);
	--p-bg:      #ffffff;
	--p-shadow:  0 12px 30px rgba(17,24,39,.06);
	--p-radius:  18px;
}

.p-wrap{
	max-width: 1140px;
	margin: 0 auto;
	padding: 56px 18px 80px;
	color: var(--p-text);
}

.p-header{
	text-align:center;
}

.p-title{
	margin: 0 0 12px;
	font-size: 2rem;
	line-height: 1.06;
	letter-spacing: -0.02em;
	color: var(--p-text);
	font-weight: 500;
}

.p-meta{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	gap: 10px;
}

.p-chip{
	display:inline-flex;
	align-items:center;
	gap: 8px;
	padding: 8px 12px;
	border-radius: 999px;
	border: 1px solid var(--p-line);
	background: rgba(255,255,255,.9);
	color: var(--ui-text);
	font-size: 14px;
	text-decoration:none;
}
.p-chip svg{ width: 16px; height: 16px; color: var(--p-primary); }

.p-thumb{
	margin: 22px auto 26px;
	/* 	max-width: 920px; */
	border-radius: var(--p-radius);
	overflow:hidden;
	border: 1px solid var(--p-line);
	box-shadow: var(--p-shadow);
	background:#fff;
}
.p-thumb img{ width:100%; height:auto; display:block; max-height: 500px; object-fit: cover; }

/* Layout: content + sidebar */
.p-layout{
	display:grid;
	grid-template-columns: 1fr 340px;
	gap: 18px;
	align-items:start;
}
@media (max-width: 980px){
	.p-layout{ grid-template-columns: 1fr; }
}

.p-content{
	background: var(--p-bg);
	border: 1px solid var(--p-line);
	border-radius: var(--p-radius);
	box-shadow: var(--p-shadow);
	padding: 22px;
}
.p-content :where(p,ul,ol,blockquote){ margin-top: 0; line-height: 1.8; }
.p-content :where(h2,h3){ margin-top: 22px; line-height: 1.25; letter-spacing: -0.01em; }
.p-content a{ color: var(--p-primary); }
.p-content img{ max-width: 100%; height: auto; }

/* Sidebar card */
.p-side{
	position: sticky;
	top: 18px;
}
@media (max-width: 980px){
	.p-side{ position: static; }
}

.p-card{
	background: var(--p-bg);
	border: 1px solid var(--p-line);
	border-radius: var(--p-radius);
	box-shadow: var(--p-shadow);
	overflow:hidden;
}

.p-card__head{
	padding: 16px 16px 10px;
	border-bottom: 1px solid var(--p-line);
}
.p-card__title{
	margin: 0;
	font-size: 15px;
	font-weight: 800;
	letter-spacing: -0.01em;
	color: var(--p-text);
	display:flex;
	align-items:center;
	gap: 8px;
}
.p-card__title svg{ width: 16px; height: 16px; color: var(--p-primary); }

.p-related{
	padding: 10px;
	display:grid;
	gap: 10px;
}

.p-item{
	display:flex;
	gap: 10px;
	align-items:center;
	text-decoration:none;
	color: inherit;
	border: 1px solid var(--p-line);
	border-radius: 14px;
	padding: 10px;
	background: #fff;
	transition: transform .15s ease, border-color .15s ease, box-shadow .15s ease;
}
.p-item:hover{
	transform: translateY(-2px);
	border-color: rgba(133,144,122,.22);
	box-shadow: 0 12px 22px rgba(17,24,39,.06);
}

.p-item__thumb{
	width: 62px;
	height: 50px;
	border-radius: 12px;
	overflow:hidden;
	border: 1px solid var(--p-line);
	background: #fff;
	flex: 0 0 62px;
	display:flex;
	align-items:center;
	justify-content:center;
	color: var(--p-muted);
	font-size: 20px;
}
.p-item__thumb img{
	width:100%;
	height:100%;
	object-fit: cover;
	display:block;
}

.p-item__title{
	margin: 0;
	font-size: 14px;
	line-height: 1.35;
	font-weight: 800;
	color: var(--p-text);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

@media print{
	.p-thumb, .p-content, .p-card{ box-shadow:none; }
	.p-side{ display:none; }
}
/* =========================================================
DETAILED FAQ
========================================================= */
.dfaq-wrap {
	max-width: 980px;
	margin: 0 auto;
}

.dfaq-head {
	margin-bottom: 24px;
	text-align: center;
}

.dfaq-title {
	margin: 0 0 10px;
	color: var(--ui-primary);
	font-size: clamp(32px, 4vw, 52px);
	font-weight: 800;
	line-height: 1.02;
	letter-spacing: -0.03em;
}

.dfaq-sub {
	margin: 0;
	color: rgba(31, 41, 55, 0.64);
	font-size: 16px;
	line-height: 1.8;
}

.dfaq-list {
	display: grid;
	gap: 14px;
}

.dfaq-item {
	overflow: hidden;
	border: 1px solid var(--ui-line);
	border-radius: var(--ui-radius);
	background: var(--ui-bg);
	box-shadow: var(--ui-shadow);
}

.dfaq-question {
	display: flex;
	align-items: center;
	gap: 16px;
	width: 100%;
	padding: 18px 20px;
	border: 0;
	background: transparent;
	color: var(--ui-text);
	text-align: left;
	cursor: pointer;
	appearance: none;
}

.dfaq-icon {
	display: flex;
	flex: 0 0 46px;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 999px;
	background: var(--ui-soft);
}

.dfaq-icon svg {
	width: 22px;
	height: 22px;
	color: var(--ui-primary);
}

.dfaq-qtext {
	flex: 1;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.01em;
}

.dfaq-toggle {
	position: relative;
	flex: 0 0 18px;
	width: 18px;
	height: 18px;
}

.dfaq-toggle::before,
.dfaq-toggle::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 16px;
	height: 2px;
	border-radius: 999px;
	background: var(--ui-primary);
	transform: translate(-50%, -50%);
	transition: transform 0.2s ease, opacity 0.2s ease;
}

.dfaq-toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

.dfaq-item.is-open .dfaq-toggle::after {
	opacity: 0;
	transform: translate(-50%, -50%) rotate(90deg) scale(0.6);
}

.dfaq-answer {
	display: none;
	padding: 0 20px 20px 82px;
	color: rgba(31, 41, 55, 0.64);
	font-size: 16px;
	line-height: 1.85;
}

.dfaq-item.is-open .dfaq-answer {
	display: block;
}



/* =========================================================
RESPONSIVE
========================================================= */
.p-header, .r-more-hero-section{
	margin:0 0 50px;
}

@media (min-width: 1200px){
	.r-more__head h2{
		font-size: 3.4375rem !important;
	} 
}

@media (max-width: 980px) {
	.service-hero,
	.r-grid {
		grid-template-columns: 1fr;
	}
	.service-hero {
		grid-template-columns: 1fr;
		grid-template-areas:
			"breadcrumbs"
			"head"
			"media";
	}

	.lr-grid,
	.lp-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
	}
	.r-more__grid{
		gap: 10px;
	}
	.r-mini-card__link{
		padding: 10px 10px 10px;
	}
	.r-mini-card__content{
		padding:0px;
	}
}

@media (max-width: 900px) {
	.single-tribe_events .tribe-events-single-section.tribe-events-event-meta {
		grid-template-columns: 1fr;
	}
	.r-mini-card__title {
		font-size: 16px !important;
	}
}

@media (max-width: 680px) {
	.dfaq-question {
		gap: 12px;
		padding: 16px;
	}

	.dfaq-icon {
		flex-basis: 40px;
		width: 40px;
		height: 40px;
	}

	.dfaq-answer {
		padding: 0 16px 18px;
	}
	.r-share-btn{
		justify-content:start;
	}

}

@media (max-width: 1024px){
	.lr-grid,
	.lp-grid {
		grid-template-columns: 1fr 1fr !important;
	}

	.r-more__grid{
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 500px){
	.lr-grid,
	.lp-grid {
		grid-template-columns: 1fr !important;
	}

	.r-more__grid{
		grid-template-columns: 1fr;
	}
}

@media (max-width: 560px) {

	.r-mini-card__link{
		padding: 20px 16px 18px;
	}
	.p-title{
		font-size: 1.6rem;
	}
	.service-booking {
		padding: 15px 10px;
	}
	.cv-home-hero-stage .cv-visual-blob-main {
		width: 250px;
		height: 320px;
		left: 40px;
		bottom: 40px;
	}
	.cv-home-hero-stage .cv-visual-blob-top {
		right:20px;
		top: 150px;
	}
}

/* =========================================================
PRINT
========================================================= */
@media print {
	.single-tribe_events .tribe-events-event-image,
	.single-tribe_events .tribe-events-content,
	.single-tribe_events .tribe-events-single-event-description,
	.single-tribe_events .tribe-events-meta-group,
	.single-tribe_events .tribe-tickets__rsvp,
	.single-tribe_events .tribe-tickets__rsvp-message,
	.single-tribe_events .tec-tickets__attendees-list-wrapper,
	.service-photo,
	.service-head,
	.service-content,
	.service-booking,
	.r-card,
	.r-thumb {
		box-shadow: none !important;
	}

	.r-actions {
		display: none;
	}
}




/* =========================================================
FOOTER
========================================================= */
.cv-signature a{
	color:#92A089;
}

