/**
 * 3HO Recipes Single Template
 * Design: Blue #2E5F97 primary, Orange #E67E22 accents, White bg
 * Layout: 8/4 two-column with sidebar + floating social strip
 */

.recipe-single {
	--recipe-blue: #4D68B0;
	--recipe-blue-dark: #244a78;
	--recipe-blue-light: #e8eff7;
	--recipe-orange: #E67E22;
	--recipe-orange-light: #f39c12;
	--recipe-text: #333333;
	--recipe-text-dark: #1a1a1a;
	--recipe-text-muted: #888888;
	--recipe-bg: #ffffff;
	--recipe-border: #e0e0e0;
	--recipe-border-light: #f0f0f0;
}

/* ===== Header buttons ===== */
/* Favorites & Print: circular. Like: pill (inherits from style.css). All same height. */
.recipe-single #practice__header .d-flex.gap-2 {
	gap: 0.75rem !important;
	align-items: center;
}

.recipe-single .add-to-favorites,
.recipe-single .remove-from-favorites,
.recipe-single .show-login-modal-favorites,
.recipe-single .btn-outline-secondary {
	width: 38px !important;
	height: 38px !important;
	min-width: 38px !important;
	min-height: 38px !important;
	border-radius: 50% !important;
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	transition: all 0.3s ease;
}

.recipe-single .add-to-favorites i,
.recipe-single .remove-from-favorites i,
.recipe-single .show-login-modal-favorites i,
.recipe-single .btn-outline-secondary i {
	font-size: 1.1rem;
	line-height: 1;
	transition: all 0.3s ease;
}

.recipe-single .add-to-favorites {
	background: #fff !important;
	border-color: #F39200 !important;
	color: #F39200 !important;
}

.recipe-single .add-to-favorites:hover {
	background: #F39200 !important;
	color: white !important;
	transform: scale(1.08);
	box-shadow: 0 4px 15px rgba(243, 146, 0, 0.35);
}

.recipe-single .remove-from-favorites {
	background: #dc3545 !important;
	border-color: #dc3545 !important;
	color: white !important;
}

.recipe-single .remove-from-favorites:hover {
	background: #c82333 !important;
	transform: scale(1.08);
	box-shadow: 0 4px 15px rgba(220, 53, 69, 0.35);
}

.recipe-single .show-login-modal-favorites {
	background: #fff !important;
	border-color: #F39200 !important;
	color: #F39200 !important;
}

.recipe-single .show-login-modal-favorites:hover {
	background: #F39200 !important;
	color: white !important;
}

.recipe-single .btn-outline-secondary:hover {
	transform: scale(1.08);
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}

/* Like button: pill shape, match height with circular buttons */
.recipe-single .practice-like-btn {
	height: 38px !important;
	min-height: 38px !important;
	padding: 0 16px !important;
	display: flex !important;
	align-items: center !important;
}

/* ===== Main layout ===== */
.recipe-main {
	background: var(--recipe-bg);
	padding: 1.5rem 0 3rem;
}

.recipe-main__wrap {
	/* max-width: 1140px; */
	margin: 0 auto;
}



/* ===== Header subtitle & byline (inside #practice__header) ===== */
.recipe-single .recipe-header__subtitle {
	font-size: 0.95rem;
	color: var(--recipe-text-muted);
	font-style: italic;
	margin: 0 0 0.5rem;
}

.recipe-header__byline {
	font-size: 0.8125rem;
	color: var(--recipe-text-muted);
}

.recipe-header__byline .far {
	margin-right: 0.25rem;
}

/* ===== Meta bar (prep time, cook time, serves) ===== */
.recipe-meta-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	align-items: center;
	background: var(--recipe-blue);
	color: #fff;
	padding: 0.75rem 1.25rem;
	border-radius: 4px;
	font-size: 0.9rem;
	font-weight: 500;
}

.recipe-meta-bar__item {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.recipe-meta-bar__item i {
	opacity: 0.85;
}

/* ===== Recipe image ===== */
.recipe-image {
	border-radius: 5px;
	overflow: hidden;
	line-height: 0;
}

.recipe-image img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 6px;
}

/* ===== Recipe intro/description ===== */
.recipe-intro {
	margin-bottom: 2rem;
}

.recipe-intro__content {
	font-size: 0.95rem;
	line-height: 1.75;
	color: var(--recipe-text);
}

.recipe-intro__content p:last-child {
	margin-bottom: 0;
}

/* ===== Section titles ===== */
.recipe-section__title {
	font-family: 'Barlow Semi Condensed', 'Barlow', sans-serif;
	font-size: 1.55rem;
	font-weight: 500;
	color: var(--recipe-text-dark);
	text-transform: none;
	letter-spacing: 0;
	margin: 0 0 0.75rem;
	padding-bottom: 0.5rem;
	border-bottom: none;
}

.recipe-section__title i {
	margin-right: 0.35rem;
}

/* ===== Ingredients - checkboxes ===== */
.recipe-ingredients {
	margin-bottom: 2rem;
	padding: 1.25rem;
	background: var(--recipe-blue-light);
	border-radius: 6px;
	border-left: 4px solid var(--recipe-blue);
}

.recipe-ingredients .recipe-section__title {
	margin-bottom: 0.75rem;
	padding-bottom: 0;
}

.recipe-ingredients__group {
	margin-bottom: 1.25rem;
}

.recipe-ingredients__group:last-child {
	margin-bottom: 0;
}

.recipe-ingredients__group-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--recipe-blue);
	margin: 1rem 0;
	padding: 0;
}

.recipe-ingredients__list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.recipe-ingredients__item {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	padding: 0.35rem 0;
	line-height: 1.55;
	font-size: 0.95rem;
}

.recipe-ingredients__checkbox {
	appearance: none;
	-webkit-appearance: none;
	width: 1.125rem;
	height: 1.125rem;
	min-width: 1.125rem;
	margin-top: 0.15rem;
	border: 2px solid #999;
	border-radius: 2px;
	background: #fff;
	cursor: pointer;
	position: relative;
	transition: border-color 0.15s, background 0.15s;
}

.recipe-ingredients__checkbox:checked {
	background: var(--recipe-blue);
	border-color: var(--recipe-blue);
}

.recipe-ingredients__checkbox:checked::after {
	content: '';
	position: absolute;
	left: 3px;
	top: 0px;
	width: 5px;
	height: 9px;
	border: solid #fff;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.recipe-ingredients__label {
	flex: 1;
	cursor: pointer;
	color: var(--recipe-text);
}

.recipe-ingredients__item:has(.recipe-ingredients__checkbox:checked) .recipe-ingredients__label {
	text-decoration: line-through;
	color: #aaa;
}

/* ===== Instructions ===== */
.recipe-instructions {
	margin-bottom: 2rem;
	padding: 1.25rem;
	background: var(--recipe-blue-light);
	border-radius: 6px;
	border-left: 4px solid var(--recipe-blue);
}

.recipe-instructions .recipe-section__title {
	margin-bottom: 0.75rem;
	padding-bottom: 0;
}

.recipe-instructions__group {
	margin-bottom: 1.5rem;
}

.recipe-instructions__group:last-child {
	margin-bottom: 0;
}

.recipe-instructions__group-title {
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--recipe-blue);
	margin: 1rem 0;
	padding: 0;
}

.recipe-instructions__list {
	list-style: none;
	padding: 0;
	margin: 0;
	counter-reset: recipe-step;
}

.recipe-instructions__step {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 1.25rem;
	font-size: 0.95rem;
	line-height: 1.75;
	color: var(--recipe-text);
	counter-increment: recipe-step;
}

.recipe-instructions__step::before {
	content: counter(recipe-step);
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.75rem;
	height: 1.75rem;
	min-width: 1.75rem;
	background: var(--recipe-blue);
	color: #fff;
	font-size: 0.8rem;
	font-weight: 700;
	border-radius: 50%;
	margin-top: 0.15rem;
}

.recipe-instructions__step:last-child {
	margin-bottom: 0;
}

.recipe-instructions__text p {
	margin: 0 0 0.5rem;
}

.recipe-instructions__text p:last-child {
	margin-bottom: 0;
}

/* ===== Recipe Notes (yellow box) ===== */
.recipe-notes-box {
	margin-bottom: 2rem;
	padding: 1.25rem 1.5rem;
	background: #FFF8E7;
	border: 1px solid #f0dca0;
	border-radius: 6px;
	border-left: 4px solid var(--recipe-orange);
}

.recipe-notes-box__title {
	font-family: 'Barlow Semi Condensed', 'Barlow', sans-serif;
	font-size: 0.9rem;
	font-weight: 700;
	color: var(--recipe-orange);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin: 0 0 0.5rem;
}

.recipe-notes-box__content {
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--recipe-text);
}

.recipe-notes-box__content p:last-child {
	margin-bottom: 0;
}

/* ===== Content fallback ===== */
.recipe-content {
	margin-bottom: 2rem;
}

.recipe-content__body {
	font-size: 0.95rem;
	line-height: 1.75;
}

/* ===== Bottom social share (reuses templates/social-share.php) ===== */
.recipe-main__content .social-share-3ho {
	margin: 2rem 0;
}

/* ===== Feedback box (reuses .kundalini-comments-intro from style.css) ===== */
.recipe-feedback.kundalini-comments-intro {
	border-left-color: var(--recipe-blue);
	margin: 2.5rem 0;
}

.recipe-feedback .comments-intro-title {
	color: var(--recipe-blue);
}

.recipe-feedback .comments-intro-title i {
	color: #e74c3c;
}

.recipe-feedback .feature-item {
	color: var(--recipe-blue);
	background: rgba(46, 95, 151, 0.1);
	border: none;
	cursor: pointer;
	font-family: inherit;
	text-decoration: none;
}

.recipe-feedback .feature-item:hover {
	background: rgba(46, 95, 151, 0.2);
	transform: translateY(-2px);
	color: var(--recipe-blue);
}

.recipe-feedback .feature-item i {
	color: var(--recipe-blue);
}

.recipe-feedback .feature-item.recipe-saved-state {
	background: rgba(39, 174, 96, 0.15);
	color: #27ae60;
}

.recipe-feedback .feature-item.recipe-saved-state i {
	color: #27ae60;
}

/* ===== Sidebar ===== */
.recipe-sidebar-col {
	padding-left: 1rem;
}

.recipe-sidebar {

}

.recipe-sidebar__section {
	margin-bottom: 2rem;
}

.recipe-sidebar__title {
	font-family: 'Barlow Semi Condensed', 'Barlow', sans-serif;
	font-size: 1.55rem;
	font-weight: 500;
	color: var(--recipe-text-dark);
	margin: 0 0 1rem;
}

.recipe-sidebar__items {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.recipe-sidebar__card {
	margin: 0 0 1.25rem 0;
}

.recipe-sidebar__card-img-link {
	display: block;
	text-decoration: none;
}

.recipe-sidebar__card-img {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-radius: 5px;
	background: #f5f5f5;
}

.recipe-sidebar__card-like-wrap {
	position: absolute;
	top: 0.5rem;
	right: 0.5rem;
	z-index: 2;
}

.recipe-sidebar__card-like-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.25rem 0.6rem;
	font-size: 0.8rem;
	font-weight: 600;
	color: #fff;
	background: var(--recipe-orange);
	border: none;
	border-radius: 20px;
	cursor: pointer;
	transition: background 0.2s, transform 0.2s;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.recipe-sidebar__card-like-btn:hover {
	background: var(--recipe-orange-light);
	color: #fff;
	transform: scale(1.05);
}

.recipe-sidebar__card-like-btn.liked {
	background: #28a745;
}

.recipe-sidebar__card-like-btn.liked:hover {
	background: #218838;
	color: #fff;
}

.recipe-sidebar__card-like-btn.logged-out {
	background: rgba(0, 0, 0, 0.5);
}

.recipe-sidebar__card-like-btn .like-icon,
.recipe-sidebar__card-like-btn .fa-thumbs-up {
	font-size: 0.75rem;
}

.recipe-sidebar__card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}

.recipe-sidebar__card:hover .recipe-sidebar__card-img img {
	transform: scale(1.04);
}

.recipe-sidebar__card-body {
	padding: 0.75rem 0 0;
}

.recipe-sidebar__card-title {
	margin: 0 0 0.35rem;
}

.recipe-sidebar__card-title a {
	text-decoration: none;
}

.recipe-sidebar__card-title a:hover {
	color: var(--recipe-blue);
}

.recipe-sidebar__card-excerpt {
	color: var(--recipe-text-muted);
	line-height: 1.5;
	margin: 0 0 0.35rem;
}

.recipe-sidebar__card-more {
	font-family: 'Barlow Semi Condensed', 'Barlow', sans-serif;
	font-weight: 600;
	color: var(--recipe-orange);
	text-decoration: none;
}

.recipe-sidebar__card-more:hover {
	text-decoration: underline;
	color: var(--recipe-orange);
}

/* Floating share sidebar: reuses .social-share-sidebar-3ho from style.css */

/* ===== Comments ===== */
.recipe-main .comments-area {
	margin-top: 2rem;
}


/* ===== Responsive ===== */
@media (max-width: 991px) {
	.recipe-main__content {
		padding-right: 0;
	}

	.recipe-sidebar-col {
		padding-left: 0;
		padding-top: 2rem;
		border-left: none;
		border-top: 1px solid var(--recipe-border-light);
	}

	.recipe-sidebar {
		position: static;
	}

}

@media (max-width: 575px) {
	.recipe-header__title {
		font-size: 1.5rem;
	}

}

/* ===== Print ===== */
@media print {
	.recipe-single .social-share-3ho,
	.recipe-single .recipe-feedback.kundalini-comments-intro,
	.recipe-single .recipe-sidebar-col,
	.recipe-single #comments,
	.recipe-single .comment-respond {
		display: none !important;
	}

	.recipe-single .recipe-main__content {
		max-width: 100%;
		flex: 0 0 100%;
	}

	.recipe-ingredients__checkbox {
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}
}

/* ===== Archive: recipe cards with favorite + like (same design as Kundalini) ===== */
.recipe-archive-card .row {
	align-items: stretch;
}
.recipe-archive-card .card-image-wrapper {
	position: relative;
	overflow: hidden;
	min-height: 200px;
}
/* Override archive card-image: no padding-bottom / fixed aspect ratio for Recent Vegetarian Recipes */
#archive #recent-posts .recipe-archive-card .card-image {
	position: absolute;
	padding-bottom: 0;
	overflow: visible;
}
.recipe-archive-card .card-image {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	display: block;
}
.recipe-archive-card .card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.recipe-archive-card .favorite-badge .btn,
#featured-posts .favorite-badge .btn {
	width: 35px !important;
	height: 35px !important;
	border-radius: 50% !important;
	padding: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	background: rgba(255,255,255,0.9) !important;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}
.recipe-archive-card .favorite-badge .add-to-favorites,
#featured-posts .favorite-badge .add-to-favorites {
	border-color: #F39200 !important;
	color: #F39200 !important;
}
.recipe-archive-card .favorite-badge .remove-from-favorites,
#featured-posts .favorite-badge .remove-from-favorites {
	background: #dc3545 !important;
	border-color: #dc3545 !important;
	color: #fff !important;
}
.recipe-archive-card .favorite-badge .show-login-modal-favorites,
#featured-posts .favorite-badge .show-login-modal-favorites {
	border-color: #F39200 !important;
	color: #F39200 !important;
}
.recipe-archive-card .practice-like-btn,
#featured-posts .practice-like-btn {
	border-radius: 20px !important;
	padding: 0.375rem 0.75rem !important;
	font-size: 0.875rem !important;
	font-weight: 500 !important;
	margin-left: 0.5rem;
}
.recipe-archive-card .card-footer-recipe .btn-primary,
#featured-posts .card-actions .btn-primary {
	border-radius: 5px !important;
}
.recipe-archive-card .practice-like-btn.liked,
#featured-posts .practice-like-btn.liked {
	background-color: #198754 !important;
	border-color: #198754 !important;
	color: white !important;
}
.recipe-archive-card .practice-like-btn.not-liked,
#featured-posts .practice-like-btn.not-liked {
	background-color: #ff6b35 !important;
	border-color: #ff6b35 !important;
	color: white !important;
}
.recipe-archive-card .practice-like-btn.logged-out,
#featured-posts .practice-like-btn.logged-out {
	background-color: transparent !important;
	border-color: #6c757d !important;
	color: #6c757d !important;
}

/* Must read articles: equal height cards, footer aligned at bottom with consistent height */
#featured-posts.row {
	align-items: stretch;
}
#featured-posts .recipe-featured-card {
	display: flex;
	flex-direction: column;
	height: 100%;
}
#featured-posts .recipe-featured-card .card-body {
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	padding-bottom: 0;
	min-height: 0;
}
#featured-posts .recipe-featured-card .card-body > div:not(.card-actions) {
	flex-grow: 1;
	min-height: 0;
	overflow: hidden;
}
#featured-posts .recipe-featured-card .card-actions {
	margin-top: auto;
	flex-shrink: 0;
	min-height: 54px;
	display: flex;
	align-items: center;
	background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
	border-top: 1px solid #dee2e6;
	padding: 15px;
	margin-left: -20px;
	margin-right: -20px;
	margin-bottom: -20px;
	border-radius: 0 0 10px 10px;
}

/* Recent articles: footer-style container for buttons */
.recipe-archive-card .card-footer-recipe {
	background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
	border-top: 1px solid #dee2e6;
	padding: 15px;
	margin-left: -20px;
	margin-right: -20px;
	margin-bottom: -20px;
	border-radius: 0 0 10px 10px;
}
