/**
 * Instant Knowledge Base - Main Stylesheet
 * This file contains additional styles that are not in the modular files
 */

/* General Styles */
.ikbase-plugin {
	width: 100%;
	/* font-family: 'Poppins', sans-serif; */
}

/* Hero Section */
.ikbase-hero {
	background: linear-gradient(135deg, #1e73be, #00a8ff);
	color: #fff;
	text-align: center;
	padding: 100px 20px;
	position: relative;
}

.ikbase-hero-overlay {
	position: relative;
	z-index: 1;
	pointer-events: auto;
}

.ikbase-hero-content {
	position: relative;
	z-index: 2;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
	pointer-events: auto;
}

.ikbase-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.1);
	z-index: 0;
	pointer-events: none;
}

.ikbase-centered-title {
	font-size: 42px;
	margin-bottom: 20px;
	text-align: center;
	font-weight: 700;
	animation: fadeInDown 1s ease-in-out;
}

.ikbase-search-box {
	display: flex;
	justify-content: center;
	max-width: 600px;
	margin: 0 auto;
	/* background: rgba(255, 255, 255, 0.9); */
	border-radius: 50px;
	padding: 10px;
	/* box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1); */
	animation: fadeInUp 1s ease-in-out;
}

.ikbase-search-box input {
	flex: 1;
	padding: 15px;
	border: none;
	border-radius: 50px;
	outline: none;
	font-size: 16px;
}

.ikbase-search-button {
	background: #1e73be;
	border: none;
	font-size: 20px;
	cursor: pointer;
	padding: 10px 20px;
	border-radius: 50px;
	color: #fff;
	transition: background 0.3s ease;
}

.ikbase-search-button:hover {
	background: #0056b3;
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}

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

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

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

/* Most Read Articles Section */
.ikbase-most-read {
	max-width: 1100px;
	margin: 50px auto;
	text-align: left;
}

.ikbase-most-read h2 {
	margin-bottom: 30px;
	font-size: 24px;
	color: #333;
	text-align: center;
}

.ikbase-articles-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 15px;
	margin-top: 15px;
}

.ikbase-arrow {
	color: #1e73be;
	font-weight: bold;
	transition: color 0.3s ease;
}

.ikbase-article-item a:hover .ikbase-arrow {
	color: #fff;
}

/* Help Topics Section */
.ikbase-help-topics {
	max-width: 1100px;
	margin: 50px auto;
	text-align: center;
}

/* Hero Banner */
.ikbase-hero {
	background: linear-gradient(135deg, #1e73be, #00a8ff);
	padding: 120px 0px;

	text-align: center;
}

.ikbase-centered-title {
	color: white;
	font-size: 2.5em;
	margin-bottom: 20px;
}

/* Search Box Styling */
.ikbase-search-box {
	position: relative;
	max-width: 800px;
	margin: 0 auto;
}

#ikbase-search-input, #sticky-search-input {
	width: 100%;
	padding: 18px 60px 18px 30px;
	border: none;
	border-radius: 50px;
	font-size: 1.1em;
	background: #ffffff;
	box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
	transition: all 0.3s ease;
}

.ikbase-search-button {
	position: absolute;
	right: 25px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	font-size: 1.4em;
	cursor: pointer;
	color: #4a5568;
	transition: all 0.3s ease;
}

.ikbase-search-button:hover {
	color: #2d3748;
	transform: translateY(-50%) scale(1.1);
}

/* Sticky Search */


.ikbase-sticky-search.sticky-active {
	top: 5px;
	opacity: 1;
}


/* // 2  */

/* Category Cards Design */
.ikbase-category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 25px;
	margin-top: 30px;
}


.ikbase-category-card {
	display: flex;
	align-items: center;
	background: #ffffff;
	border-radius: 8px;
	padding: 15px;
	border: 1px solid #e3e8ef;
	transition: all 0.2s ease;
	gap: 15px;
	text-decoration: none;
}

/* Image styling */
.ikbase-category-image img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 50%;
}

/* Content styling */
.ikbase-category-content {
	flex: 1;
}

.ikbase-category-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 8px;
	border-bottom: 1px solid #f1f5f9;
	padding-bottom: 8px;
}

.ikbase-category-title {
	font-family: 'Inter', sans-serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: #1e293b;
	margin: 0;
}

.ikbase-category-count {
	font-size: 0.9rem;
	color: #64748b;
	font-weight: 500;
}

.ikbase-category-description {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #475569;
	margin: 0;
}

/* signle ikbase page  */




.view-count-updated {
	transform: scale(1.2);
	color: #1e73be;
}

.ikbase-hero {
	background: linear-gradient(135deg, #1e73be, #00a8ff);
	color: #fff;
	text-align: center;
	padding: 100px 20px;
	position: relative;
}

.ikbase-hero-overlay {
	position: relative;
	z-index: 1;
	pointer-events: auto;
}

.ikbase-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.1);
	z-index: 0;
}

.ikbase-centered-title {
	font-size: 42px;
	margin-bottom: 20px;
	text-align: center;
	font-weight: 700;
	animation: fadeInDown 1s ease-in-out;
}

.ikbase-hero p {
	font-size: 18px;
	color: #0000008a;
	max-width: 800px;
	margin: 0 auto;
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}

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

/* Main Layout */
.ikbase-category-layout {
	display: flex;
	max-width: 1200px;
	margin: 50px auto;
	gap: 20px;
	padding: 20px;
}

/* Sidebar - Categories (Hidden on Mobile) */
.ikbase-categories-sidebar {
	flex: 1;
	max-width: 250px;
	background: #f9f9f9;
	padding: 20px;
	border-radius: 8px;
}

.ikbase-categories-sidebar h3 {
	font-size: 18px;
	margin-bottom: 10px;
}

.ikbase-categories-sidebar ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ikbase-categories-sidebar li {
	margin-bottom: 10px;
}


.ikbase-categories-sidebar a {
	text-decoration: none;
	color: #333;
	display: block;
	padding: 10px;
	border-radius: 5px;
	background: #fff;
	transition: 0.3s;
}

.ikbase-categories-sidebar {
	width: 25%;
	background: #f9f9f9;
	padding: 20px;
	border-radius: 8px;
}

.ikbase-categories-sidebar a:hover {
	background: #1e73be;
	color: #fff;
}

/* Article Content */
.ikbase-category-content {
	flex: 3;
	background: #ffffff;
	padding: 0px;
	/* border-radius: 8px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); */
}

.ikbase-article-body {
	line-height: 1.6;
	font-size: 16px;
}

/* Like/Dislike System */
.ikbase-feedback-container {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 20px;
}

.ikbase-like-dislike {
	display: flex;
	gap: 10px;
}

.ikbase-like,
.ikbase-dislike {
	color: #0274be;
	background: #f9f9f9;
	border: 1px solid #0274be;
	padding: 8px 16px;
	border-radius: 5px;
	cursor: pointer;
	transition: background 0.3s, color 0.3s;
}

.ikbase-like:hover,
.ikbase-dislike:hover {
	background: #1e73be;
	color: #fff;
}

.ikbase-view-container {
	text-align: right;
	font-weight: bold;
	color: #555;
}

/* Related Articles */
.ikbase-related-articles {
	margin-top: 40px;
	text-align: center;
}

.ikbase-articles-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
	gap: 15px;
	margin-top: 15px;
}

.ikbase-article-box {
	background: #0073ea;
	padding: 10px;
	border-radius: 6px;
	transition: 0.3s ease-in-out;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
}

.ikbase-article-box:hover {
	background: #005bbd;
	transform: translateY(-3px);
}

.ikbase-article-box a {
	text-decoration: none;
	color: #fff;
	display: block;
	padding: 8px;
}

/* Support Block */
.ikbase-support-block {
	margin-top: 30px;
	padding: 20px;
	background: #eef4ff;
	border-radius: 8px;
	text-align: center;
	border: 1px solid #ccc;
}

.ikbase-support-block a {
	display: block;
	padding: 10px;
	background: #0073aa;
	color: white;
	text-decoration: none;
	font-weight: bold;
	margin-top: 10px;
	border-radius: 5px;
	transition: background 0.3s;
}

.ikbase-support-block a:hover {
	background: #005177;
}

/* Mobile Responsive */
@media screen and (max-width: 768px) {
	.ikbase-category-layout {
		flex-direction: column;
	}

	.ikbase-categories-sidebar {
		display: none;
	}

	.ikbase-category-content {
		width: 100%;
	}

	.ikbase-articles-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	
	/* Mobile breadcrumb adjustments */
	.ikbase-breadcrumb {
		font-size: 12px;
		margin-bottom: 10px;
		text-align: center;
		padding: 5px 0;
	}
	
	.ikbase-breadcrumb a {
		padding: 6px 10px;
		font-size: 12px;
		min-height: 24px;
		display: inline-block;
	}
	
	.ikbase-hero {
		padding: 60px 15px;
	}
	
	.ikbase-centered-title {
		font-size: 28px;
	}
	
	.ikbase-article-item {
		padding: 12px;
	}
	
	.ikbase-article-item h3 {
		font-size: 16px;
	}
	
	.ikbase-article-description {
		font-size: 13px;
	}
}

/* Full-width Footer Container */
.ikbase-main-footer {
	width: 100%;
	margin: 40px 0 0;
	background: #f8f9fa;
	border-top: 1px solid #e9ecef;
}

/* Inner Footer Content */
.ikbase-plugin-footer {
	max-width: 1200px;
	margin: 0 auto;
	padding: 25px 20px;
	text-align: center;
}

.ikbase-plugin-footer p {
	margin: 0;
	color: #4a5568;
	font-size: 0.95em;
}

.ikbase-plugin-footer a {
	color: #2d3748;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.3s ease;
}

.ikbase-plugin-footer a:hover {
	color: #1a202c;
	text-decoration: underline;
}


/* // taxonomy ikbase page  */

/* Breadcrumb */
.ikbase-breadcrumb {
	font-size: 14px;
	color: #fff;
	margin-bottom: 15px;
	position: relative;
	z-index: 20;
	text-align: center;
	line-height: 1.4;
	pointer-events: auto;
	display: block;
	width: 100%;
}

/* Ensure breadcrumb is always clickable */
.ikbase-breadcrumb * {
	pointer-events: auto;
}

.ikbase-breadcrumb a {
	color: #fff;
	text-decoration: none;
	transition: all 0.3s ease;
	display: inline-block;
	padding: 4px 8px;
	border-radius: 4px;
	position: relative;
	z-index: 21;
	pointer-events: auto;
	cursor: pointer;
	/* Force clickable area */
	min-width: 20px;
	min-height: 20px;
	/* Prevent any overlapping */
	isolation: isolate;
}

.ikbase-breadcrumb a:hover {
	color: #e0e0e0;
	background-color: rgba(255, 255, 255, 0.15);
	text-decoration: underline;
	transform: translateY(-1px);
}

/* Hero Section */
.ikbase-hero {
	background: linear-gradient(135deg, #1e73be, #00a8ff);
	color: #fff;
	text-align: center;
	padding: 100px 20px;
	position: relative;
}

.ikbase-hero-overlay {
	position: relative;
	z-index: 1;
	pointer-events: auto;
}

.ikbase-hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.1);
	z-index: 0;
}

.ikbase-centered-title {
	font-size: 42px;
	margin-bottom: 20px;
	text-align: center;
	font-weight: 700;
	animation: fadeInDown 1s ease-in-out;
}

.ikbase-hero p {
	font-size: 18px;
	color: #0000008a;
	max-width: 800px;
	margin: 0 auto;
}

@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}

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

/* Main Layout */
.ikbase-category-layout {
	display: flex;
	max-width: 1200px;
	margin: 50px auto;
	gap: 20px;
}

/* Left Sidebar - List of Categories */
.ikbase-categories-sidebar {
	width: 25%;
	background: #f9f9f9;
	padding: 20px;
	border-radius: 8px;
}

.ikbase-categories-sidebar h3 {
	margin-bottom: 15px;
	font-size: 18px;
}

.ikbase-categories-sidebar ul {
	list-style: none;
	padding: 0;
}

.ikbase-categories-sidebar li {
	margin-bottom: 10px;
}

.ikbase-categories-sidebar a {
	text-decoration: none;
	color: #333;
	display: block;
	padding: 10px;
	border-radius: 5px;
	background: #fff;
	transition: 0.3s;
}

.ikbase-categories-sidebar a:hover {
	background: #1e73be;
	color: #fff;
}

/* Right Side - Category Content */
.ikbase-category-content {
	width: 75%;
	padding: 0px;
	background: #fff;
	/* border-radius: 8px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1); */
}

/* Articles Grid */
.ikbase-articles-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 15px;
	margin-top: 15px;
}

.ikbase-article-item {
	background: #f9f9f9;
	padding: 15px;
	border-radius: 8px;
	transition: 0.3s ease-in-out;
	border: 1px solid #e5e7eb;
}

.ikbase-article-item:hover {
	background: #1e73be;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(30, 115, 190, 0.15);
}

.ikbase-article-item a {
	text-decoration: none;
	color: inherit;
	display: block;
}

.ikbase-article-item h3 {
	font-size: 18px;
	margin: 0 0 8px 0;
	font-weight: 600;
}

.ikbase-article-description {
	font-size: 14px;
	color: #666;
	margin: 8px 0 0 0;
	line-height: 1.5;
}

.ikbase-article-item:hover .ikbase-article-description {
	color: rgba(255, 255, 255, 0.9);
}

.ikbase-article-header {
	display: flex;
	align-items: center;
	gap: 8px;
}

.ikbase-article-type-icon {
	font-size: 16px;
	margin-right: 4px;
}

.ikbase-no-articles {
	text-align: center;
	color: #777;
	padding: 2rem;
	font-style: italic;
}

/* Hide Categories Sidebar on Mobile */
@media screen and (max-width: 768px) {
	.ikbase-category-layout {
		flex-direction: column;
	}

	.ikbase-categories-sidebar {
		display: none;
	}

	.ikbase-category-content {
		width: 100%;
	}

	.ikbase-articles-grid {
		grid-template-columns: 1fr;
		gap: 12px;
	}
	
	/* Mobile breadcrumb adjustments */
	.ikbase-breadcrumb {
		font-size: 12px;
		margin-bottom: 10px;
		text-align: center;
		padding: 5px 0;
	}
	
	.ikbase-breadcrumb a {
		padding: 6px 10px;
		font-size: 12px;
		min-height: 24px;
		display: inline-block;
	}
	
	.ikbase-hero {
		padding: 60px 15px;
	}
	
	.ikbase-centered-title {
		font-size: 28px;
	}
	
	.ikbase-article-item {
		padding: 12px;
	}
	
	.ikbase-article-item h3 {
		font-size: 16px;
	}
	
	.ikbase-article-description {
		font-size: 13px;
	}
}

.ikbase-categories-sidebar ul {
	margin: 0px;
}

/* Full-width Footer Container */
.ikbase-main-footer {
	width: 100%;
	margin: 40px 0 0;
	background: #f8f9fa;
	border-top: 1px solid #e9ecef;
}

/* Inner Footer Content */
.ikbase-plugin-footer {
	max-width: 1200px;
	margin: 0 auto;
	padding: 25px 20px;
	text-align: center;
}

.ikbase-plugin-footer p {
	margin: 0;
	color: #4a5568;
	font-size: 0.95em;
}

.ikbase-plugin-footer a {
	color: #2d3748;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.3s ease;
}

.ikbase-plugin-footer a:hover {
	color: #1a202c;
	text-decoration: underline;
}



/* Add these new styles */
.ikbase-like.disabled,
.ikbase-dislike.disabled {
	opacity: 0.6;
	cursor: not-allowed;
}

.ikbase-like.voted {
	background: #4CAF50 !important;
	color: white !important;
	border-color: #4CAF50 !important;
}

.ikbase-dislike.voted {
	background: #f44336 !important;
	color: white !important;
	border-color: #f44336 !important;
}

.ikbase-vote-message {
	margin-top: 10px;
	padding: 10px;
	border-radius: 4px;
	display: none;
}

.ikbase-vote-message.success {
	background: #dff0d8;
	color: #3c763d;
}

.ikbase-vote-message.error {
	background: #f2dede;
	color: #a94442;
}


/* Category Cards Design */
.ikbase-category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 25px;
	margin-top: 30px;
}


.ikbase-category-card {
	display: flex;
	align-items: center;
	background: #ffffff;
	border-radius: 8px;
	padding: 15px;
	border: 1px solid #e3e8ef;
	transition: all 0.2s ease;
	gap: 15px;
	text-decoration: none;
}

/* Image styling */
.ikbase-category-image img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 50%;
}

/* Content styling */
.ikbase-category-content {
	flex: 1;
}

.ikbase-category-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 8px;
	border-bottom: 1px solid #f1f5f9;
	padding-bottom: 8px;
}

.ikbase-category-title {
	font-family: 'Inter', sans-serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: #1e293b;
	margin: 0;
}

.ikbase-category-count {
	font-size: 0.9rem;
	color: #64748b;
	font-weight: 500;
}

.ikbase-category-description {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #475569;
	margin: 0;
}

.ikbase-category-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 25px;
	margin-top: 30px;
}


.ikbase-category-card {
	display: flex;
	align-items: center;
	background: #ffffff;
	border-radius: 8px;
	padding: 15px;
	border: 1px solid #e3e8ef;
	transition: all 0.2s ease;
	gap: 15px;
	text-decoration: none;
}

/* Image styling */
.ikbase-category-image img {
	width: 80px;
	height: 80px;
	object-fit: cover;
	border-radius: 50%;
}

/* Content styling */
.ikbase-category-content {
	flex: 1;
}

.ikbase-category-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 8px;
	border-bottom: 1px solid #f1f5f9;
	padding-bottom: 8px;
}

.ikbase-category-title {
	font-family: 'Inter', sans-serif;
	font-size: 1.1rem;
	font-weight: 600;
	color: #1e293b;
	margin: 0;
}

.ikbase-category-count {
	font-size: 0.9rem;
	color: #64748b;
	font-weight: 500;
}

.ikbase-category-description {
	font-size: 0.95rem;
	line-height: 1.6;
	color: #475569;
	margin: 0;
}

/* Full-width Footer Container */
.ikbase-main-footer {
	width: 100%;
	margin: 40px 0 0;
	background: #f8f9fa;
	border-top: 1px solid #e9ecef;
}

/* Inner Footer Content */
.ikbase-plugin-footer {
	max-width: 1200px;
	margin: 0 auto;
	padding: 25px 20px;
	text-align: center;
}

.ikbase-plugin-footer p {
	margin: 0;
	color: #4a5568;
	font-size: 0.95em;
}

.ikbase-plugin-footer a {
	color: #2d3748;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.3s ease;
}

.ikbase-plugin-footer a:hover {
	color: #1a202c;
	text-decoration: underline;
}

.ikbase-header {
	background: linear-gradient(90deg, #6a11cb, #2575fc);
	padding: 30px 0;
	text-align: center;
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}

.ikbase-header-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: 100%;
	max-width: 1100px;
	text-align: center;
}

/* Logo Styling */
.ikbase-logo img {
	height: 50px;
	margin-bottom: 15px;
}

/* Search Bar */
.ikbase-search-bar {
	display: flex;
	justify-content: center;
	align-items: center;
	background: #fff;
	border-radius: 30px;
	padding: 5px;
	max-width: 600px;
	width: 100%;
}

.ikbase-search-box input {
	flex: 1;
	padding: 12px;
	border: none;
	border-radius: 30px;
	outline: none;
}

.ikbase-search-button {
	background: none;
	border: none;
	font-size: 18px;
	cursor: pointer;
	padding: 10px;
}

/* Header Right (Language Switcher & Button) */
.ikbase-header-right {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 15px;
	margin-top: 10px;
}

.ikbase-language-switcher {
	padding: 8px;
	border-radius: 5px;
	border: none;
	cursor: pointer;
}

.ikbase-website-button {
	background: #0073ea;
	color: #fff;
	padding: 10px 15px;
	border-radius: 5px;
	text-decoration: none;
	font-weight: bold;
}

.ikbase-website-button:hover {
	background: #005bbd;
}

/* Responsive Adjustments */
@media screen and (max-width: 768px) {
	.ikbase-header {
		padding: 20px 0;
	}

	.ikbase-logo img {
		height: 40px;
	}

	.ikbase-search-bar {
		max-width: 90%;
	}

	.ikbase-header-right {
		flex-direction: column;
	}

	.ikbase-language-switcher {
		width: 100%;
	}

	.ikbase-website-button {
		width: 100%;
		text-align: center;
	}
}

/* Plugin Branding Styles */
.ikbase-plugin-branding {
	text-align: center;
	padding: 20px 0;
	margin-top: 40px;
	border-top: 1px solid #e5e5e5;
	background: #fafafa;
}

.ikbase-branding-text {
	margin: 0;
	font-size: 13px;
	color: #666;
	font-weight: 400;
	line-height: 1.4;
}

.ikbase-heart {
	color: #e74c3c;
	font-size: 14px;
	animation: ikbase-heartbeat 1.5s ease-in-out infinite;
	display: inline-block;
}

.ikbase-branding-link {
	color: #3498db;
	text-decoration: none;
	font-weight: 500;
	transition: all 0.3s ease;
}

.ikbase-branding-link:hover {
	color: #2980b9;
	text-decoration: underline;
}

@keyframes ikbase-heartbeat {
	0%, 100% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.1);
	}
}

/* Responsive branding */
@media screen and (max-width: 768px) {
	.ikbase-plugin-branding {
		padding: 15px 10px;
		margin-top: 30px;
	}
	
	.ikbase-branding-text {
		font-size: 12px;
	}
}

/* ==========================================
   HIERARCHY SYSTEM STYLES
   ========================================== */

/* Breadcrumbs */
.ikbase-breadcrumbs {
    margin-bottom: 1rem;
    font-size: 0.9rem;
}

.ikbase-breadcrumb-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.ikbase-breadcrumb-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.ikbase-breadcrumb-link {
    color: #666;
    text-decoration: none;
    transition: color 0.2s ease;
}

.ikbase-breadcrumb-link:hover {
    color: #007cba;
    text-decoration: underline;
}

.ikbase-breadcrumb-current {
    color: #333;
    font-weight: 500;
}

.ikbase-breadcrumb-separator {
    color: #999;
    font-size: 0.8rem;
}

/* Article Hierarchy Metadata */
.ikbase-article-hierarchy-meta {
    margin: 0.75rem 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.ikbase-hierarchy-type,
.ikbase-hierarchy-section,
.ikbase-hierarchy-category {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.8rem;
    text-decoration: none;
}

.ikbase-hierarchy-type {
    background: #e7f3ff;
    color: #0073aa;
    border: 1px solid #b8d4f0;
}

.ikbase-hierarchy-section {
    background: #f0f9ff;
    color: #0369a1;
    border: 1px solid #bae6fd;
}

.ikbase-hierarchy-category {
    background: #fef3c7;
    color: #92400e;
    border: 1px solid #fcd34d;
}

.ikbase-hierarchy-type a,
.ikbase-hierarchy-section a,
.ikbase-hierarchy-category a {
    color: inherit;
    text-decoration: none;
}

.ikbase-hierarchy-type a:hover,
.ikbase-hierarchy-section a:hover,
.ikbase-hierarchy-category a:hover {
    text-decoration: underline;
}

/* Article Type Icons */
.ikbase-article-type-icon {
    margin-right: 0.5rem;
    font-size: 1.2em;
}

.ikbase-related-type-icon {
    margin-right: 0.25rem;
    font-size: 1em;
}

/* Hierarchy Search Filters */
.ikbase-hierarchy-search-filters {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin-bottom: 1rem;
    padding: 1rem;
    background: #f8f9fa;
    border-radius: 8px;
}

.ikbase-filter-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ikbase-filter-group label {
    font-weight: 500;
    color: #333;
    font-size: 0.9rem;
}

.ikbase-filter-select {
    padding: 0.5rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: white;
    font-size: 0.9rem;
    transition: border-color 0.2s ease;
}

.ikbase-filter-select:focus {
    outline: none;
    border-color: #007cba;
    box-shadow: 0 0 0 2px rgba(0, 124, 186, 0.1);
}

/* Article Type Filters */
.ikbase-article-type-filter {
    margin-bottom: 1.5rem;
    text-align: center;
}

.ikbase-type-filter {
    display: inline-block;
    padding: 0.5rem 1rem;
    margin: 0.25rem;
    border: 1px solid #ddd;
    background: white;
    color: #333;
    text-decoration: none;
    border-radius: 20px;
    font-size: 0.9rem;
    cursor: pointer;
    transition: all 0.2s ease;
}

.ikbase-type-filter:hover {
    border-color: #007cba;
    background: #f0f8ff;
    color: #007cba;
}

.ikbase-type-filter.active {
    background: #007cba;
    color: white;
    border-color: #007cba;
}

.ikbase-type-filter .count {
    margin-left: 0.5rem;
    opacity: 0.7;
    font-size: 0.8rem;
}

/* Sections Overview */
.ikbase-sections-overview {
    margin: 2rem 0;
}

.ikbase-sections-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5rem;
    margin-top: 1rem;
}

.ikbase-section-card {
    padding: 1.5rem;
    background: white;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    transition: all 0.2s ease;
}

.ikbase-section-card:hover {
    border-color: #007cba;
    box-shadow: 0 4px 12px rgba(0, 124, 186, 0.1);
    transform: translateY(-2px);
}

.ikbase-section-card h3,
.ikbase-section-card h4 {
    margin: 0 0 0.5rem 0;
    color: #1f2937;
}

.ikbase-section-card h3 a,
.ikbase-section-card h4 a {
    color: inherit;
    text-decoration: none;
}

.ikbase-section-card h3 a:hover,
.ikbase-section-card h4 a:hover {
    color: #007cba;
}

.ikbase-section-description {
    color: #6b7280;
    margin-bottom: 1rem;
    line-height: 1.5;
}

.ikbase-section-count {
    font-size: 0.9rem;
    color: #9ca3af;
    font-weight: 500;
}

.ikbase-section-categories {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ikbase-category-tag {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    background: #f3f4f6;
    color: #374151;
    text-decoration: none;
    border-radius: 12px;
    font-size: 0.8rem;
    transition: all 0.2s ease;
}

.ikbase-category-tag:hover {
    background: #007cba;
    color: white;
}

/* Enhanced Article Items */
.ikbase-article-item {
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 1rem;
    margin-bottom: 1rem;
    background: white;
    transition: all 0.2s ease;
}

.ikbase-article-item:hover {
    border-color: #007cba;
    box-shadow: 0 2px 8px rgba(0, 124, 186, 0.1);
}

.ikbase-article-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.ikbase-article-header h3 {
    margin: 0;
    color: #1f2937;
    flex: 1;
}

.ikbase-article-meta {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid #f3f4f6;
}

.ikbase-article-stats {
    display: flex;
    gap: 1rem;
    margin-top: 0.5rem;
    font-size: 0.8rem;
    color: #6b7280;
}

.ikbase-article-excerpt {
    color: #6b7280;
    line-height: 1.5;
    margin: 0.5rem 0;
}

/* Enhanced Sidebar */
.ikbase-categories-sidebar h4 {
    color: #374151;
    font-size: 1rem;
    margin: 1.5rem 0 0.75rem 0;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid #e5e7eb;
}

.ikbase-categories-sidebar h4:first-child {
    margin-top: 0;
}

.ikbase-sidebar-sections,
.ikbase-sidebar-categories,
.ikbase-sidebar-types {
    margin-bottom: 2rem;
}

.ikbase-sidebar-sections ul,
.ikbase-sidebar-categories ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ikbase-sidebar-sections li,
.ikbase-sidebar-categories li {
    margin-bottom: 0.5rem;
}

.ikbase-sidebar-sections a,
.ikbase-sidebar-categories a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    color: #374151;
    text-decoration: none;
    border-radius: 4px;
    transition: all 0.2s ease;
	font-size: 18px;
}

.ikbase-sidebar-sections a:hover,
.ikbase-sidebar-categories a:hover {
    background: #f3f4f6;
    color: #007cba;
}

.ikbase-sidebar-sections .current-section a,
.ikbase-sidebar-categories .current-category a,
.ikbase-sidebar-types .current-type a {
    background: #e7f3ff;
    color: #007cba;
    font-weight: 500;
}

.ikbase-sidebar-sections .count,
.ikbase-sidebar-categories .count,
.ikbase-sidebar-types .count {
    margin-left: auto;
    font-size: 0.8rem;
    color: #9ca3af;
}

/* Type Filters in Sidebar */
.ikbase-type-filters {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ikbase-sidebar-types .ikbase-type-filter {
    text-align: left;
    border-radius: 4px;
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

/* Category Search */
.ikbase-category-search {
    margin-bottom: 2rem;
}

.ikbase-category-search-form {
    display: flex;
    gap: 0.5rem;
    max-width: 400px;
}

.ikbase-category-search input[type="search"] {
    flex: 1;
    padding: 0.75rem;
    border: 1px solid #ddd;
    border-radius: 4px;
    font-size: 0.9rem;
}

.ikbase-category-search button {
    padding: 0.75rem 1.5rem;
    background: #007cba;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.9rem;
    transition: background 0.2s ease;
}

.ikbase-category-search button:hover {
    background: #005a87;
}

/* Related Categories */
.ikbase-related-categories {
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid #e5e7eb;
}

.ikbase-related-categories h4 {
    margin-bottom: 1rem;
    color: #374151;
}

.ikbase-related-categories-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 1rem;
}

.ikbase-related-category {
    text-align: center;
}

.ikbase-related-category a {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
    padding: 1rem;
    background: #f8f9fa;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    text-decoration: none;
    color: #374151;
    transition: all 0.2s ease;
}

.ikbase-related-category a:hover {
    background: #007cba;
    color: white;
    border-color: #007cba;
    transform: translateY(-2px);
}

.ikbase-related-category-name {
    font-weight: 500;
    font-size: 0.9rem;
}

.ikbase-related-category-count {
    font-size: 0.8rem;
    opacity: 0.7;
}

/* Article Metadata */
.ikbase-article-metadata {
    margin-top: 1rem;
    text-align: center;
}

.ikbase-article-stats {
    display: flex;
    justify-content: center;
    gap: 2rem;
    margin-top: 0.5rem;
    font-size: 0.9rem;
    color: #fff;
    font-weight: 500;
}

/* Individual stat items */
.ikbase-publish-date,
.ikbase-view-count {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    background: rgba(255, 255, 255, 0.15);
    padding: 0.375rem 0.75rem;
    border-radius: 20px;
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.2);
}

/* When header override is enabled */
.ikbase-content-header .ikbase-article-stats {
    color: #374151;
}

.ikbase-content-header .ikbase-publish-date,
.ikbase-content-header .ikbase-view-count {
    color: #374151;
    background: rgba(0, 124, 186, 0.1);
    border: 1px solid rgba(0, 124, 186, 0.2);
}

/* ==========================================
   ACCORDION-STYLE SIDEBAR
   ========================================== */

/* Sidebar accordion containers */
.ikbase-sidebar-sections,
.ikbase-sidebar-categories,
.ikbase-sidebar-types {
    /* margin-bottom: 1rem; */
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    background: white;
    /* overflow: hidden; */
}

/* Accordion headers */
.ikbase-accordion-header {
    background: #f8f9fa;
    border-bottom: 1px solid #e5e7eb;
    padding: 0;
    margin: 0;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
}

.ikbase-accordion-header:hover {
    background: #e9ecef;
}

.ikbase-accordion-header.active {
    background: #007cba;
    color: white;
}

.ikbase-accordion-header h4 {
    margin: 0;
    padding: 1rem;
    font-size: 1rem;
    font-weight: 600;
    color: #374151;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease;
}

.ikbase-accordion-header.active h4 {
    color: white;
}

/* Accordion toggle icons */
.ikbase-accordion-toggle {
    font-size: 0.8rem;
    transition: transform 0.3s ease;
    color: #6b7280;
}

.ikbase-accordion-header.active .ikbase-accordion-toggle {
    transform: rotate(180deg);
    color: white;
}

/* Accordion content */
.ikbase-accordion-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    background: white;
}

.ikbase-accordion-content.active {
    max-height: 500px;
    overflow-y: auto;
}

/* Initial setup for categories accordion - ensure it's visible by default */
.ikbase-sidebar-categories .ikbase-accordion-content.active {
    max-height: none; /* Remove height restriction for the default open one */
    overflow: visible;
}

/* Accordion lists */
.ikbase-accordion-content ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ikbase-accordion-content li {
    border-bottom: 1px solid #f3f4f6;
}

.ikbase-accordion-content li:last-child {
    border-bottom: none;
}

.ikbase-accordion-content a {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    color: #374151;
    text-decoration: none;
    transition: all 0.2s ease;
    font-size: 0.9rem;
}

.ikbase-accordion-content a:hover {
    background: #f3f4f6;
    color: #007cba;
    padding-left: 1.25rem;
}

.ikbase-accordion-content .current-section a,
.ikbase-accordion-content .current-category a,
.ikbase-accordion-content .current-type a {
    background: #e7f3ff;
    color: #007cba;
    font-weight: 500;
    border-left: 3px solid #007cba;
}

.ikbase-accordion-content .count {
    margin-left: auto;
    font-size: 0.8rem;
    color: #9ca3af;
    background: #f3f4f6;
    padding: 0.125rem 0.375rem;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
}

.ikbase-accordion-content .current-section .count,
.ikbase-accordion-content .current-category .count,
.ikbase-accordion-content .current-type .count {
    background: rgba(0, 124, 186, 0.2);
    color: #007cba;
}

/* Dashicons alignment in accordion */
.ikbase-accordion-content .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
    margin-right: 0.25rem;
    color: #6b7280;
    flex-shrink: 0;
}

.ikbase-accordion-content .current-category .dashicons {
    color: #007cba;
}

/* Enhanced current item highlighting */
.ikbase-accordion-content .current-section,
.ikbase-accordion-content .current-category,
.ikbase-accordion-content .current-type {
    position: relative;
}

.ikbase-accordion-content .current-section::before,
.ikbase-accordion-content .current-category::before,
.ikbase-accordion-content .current-type::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: #22c55e;
    border-radius: 0 2px 2px 0;
}

/* Fix for empty categories message */
.ikbase-accordion-content.empty {
    padding: 1rem;
    color: #6b7280;
    font-style: italic;
    text-align: center;
}

/* Ensure proper vertical alignment */
.ikbase-accordion-content a {
    align-items: center;
    min-height: 44px; /* Touch-friendly minimum */
}

/* Better spacing for folder icons */
.ikbase-accordion-content a[href*="kb-section"] {
    padding-left: 1.25rem;
}

.ikbase-accordion-content a[href*="kb-section"]::before {
    content: '📁';
    margin-right: 0.5rem;
    font-size: 14px;
}

/* Legacy support for old sidebar structure */
.ikbase-categories-sidebar h4 {
    color: #374151;
    font-size: 1rem;
    margin: 0;
    padding: 1rem;
    /* background: #f8f9fa; */
    border-bottom: 1px solid #e5e7eb;
    cursor: pointer;
    transition: all 0.3s ease;
}
.ikbase-view-container {
    display: none !important;
}

.ikbase-categories-sidebar h4:hover {
    background: #007cba;
}

.ikbase-categories-sidebar h3 {
    color: #1f2937;
    font-size: 1.2rem;
    margin: 0 0 1.5rem 0;
    padding: 1rem;
    background: #f8f9fa;
    border-radius: 8px;
    text-align: center;
    border: 1px solid #e5e7eb;
}

/* ==========================================
   COMPACT-STYLE BREADCRUMB STYLES (Default for all templates)
   ========================================== */

/* Main breadcrumb container */
.ikbase-breadcrumb-section {
    background: #f8f9fa;
    border-bottom: 1px solid #e5e7eb;
    padding: 0.75rem 0;
    margin-bottom: 1rem;
}

/* Breadcrumb navigation */
.ikbase-breadcrumb {
    font-size: 0.9rem;
    color: #fff;
    margin-bottom: 0;
    line-height: 1.4;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.25rem;
}

/* Breadcrumb links */
.ikbase-breadcrumb a {
    color: #007cba;
    text-decoration: none;
    transition: all 0.3s ease;
    display: inline-block;
    padding: 4px 8px;
    border-radius: 4px;
    position: relative;
    z-index: 21;
    pointer-events: auto;
    cursor: pointer;
    font-weight: 500;
}

.ikbase-breadcrumb a:hover {
    color: #005a87;
    background: rgba(0, 124, 186, 0.1);
    text-decoration: underline;
}

/* Breadcrumb separators */
.ikbase-breadcrumb-separator {
    color: #6b7280;
    margin: 0 0.25rem;
    font-weight: normal;
}

/* Current page breadcrumb styling */
.ikbase-breadcrumb-current {
    color: #374151;
    font-weight: 600;
    padding: 4px 8px;
}

/* Hero section breadcrumbs (on colored backgrounds) */
.ikbase-hero .ikbase-breadcrumb,
.ikbase-hero-content .ikbase-breadcrumb {
    color: rgba(255, 255, 255, 0.9);
}

.ikbase-hero .ikbase-breadcrumb a,
.ikbase-hero-content .ikbase-breadcrumb a {
    color: #fff;
    /* background: rgba(255, 255, 255, 0.1); */
    border-radius: 4px;
}

.ikbase-hero .ikbase-breadcrumb a:hover,
.ikbase-hero-content .ikbase-breadcrumb a:hover {
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
    text-decoration: none;
    transform: translateY(-1px);
}

.ikbase-hero .ikbase-breadcrumb-separator,
.ikbase-hero-content .ikbase-breadcrumb-separator {
    color: rgba(255, 255, 255, 0.7);
}

.ikbase-hero .ikbase-breadcrumb-current,
.ikbase-hero-content .ikbase-breadcrumb-current {
    color: #fff;
    font-weight: 600;
    opacity: 0.9;
}

/* Content header breadcrumbs (when header override is enabled) */
.ikbase-content-header .ikbase-breadcrumb {
    justify-content: flex-start;
    margin-bottom: 1rem;
}

.ikbase-content-header .ikbase-breadcrumb a {
    color: #007cba;
    background: transparent;
}

.ikbase-content-header .ikbase-breadcrumb a:hover {
    color: #005a87;
    background: rgba(0, 124, 186, 0.1);
}

/* Content-Focus template breadcrumb overrides */
.ikbase-content-focus-landing .ikbase-breadcrumb-section,
.ikbase-content-focus-single .ikbase-breadcrumb-section,
.ikbase-content-focus-category .ikbase-breadcrumb-section {
    background: #f8f9fa;
    border-bottom: 1px solid #e5e7eb;
    padding: 0.5rem 0;
}

.ikbase-content-focus-landing .ikbase-breadcrumb,
.ikbase-content-focus-single .ikbase-breadcrumb,
.ikbase-content-focus-category .ikbase-breadcrumb {
    color: #374151;
    justify-content: center;
}

.ikbase-content-focus-landing .ikbase-breadcrumb a,
.ikbase-content-focus-single .ikbase-breadcrumb a,
.ikbase-content-focus-category .ikbase-breadcrumb a {
    color: #22c55e;
}

.ikbase-content-focus-landing .ikbase-breadcrumb a:hover,
.ikbase-content-focus-single .ikbase-breadcrumb a:hover,
.ikbase-content-focus-category .ikbase-breadcrumb a:hover {
    color: #16a34a;
    background: rgba(34, 197, 94, 0.1);
}

.ikbase-content-focus-landing .ikbase-breadcrumb-current,
.ikbase-content-focus-single .ikbase-breadcrumb-current,
.ikbase-content-focus-category .ikbase-breadcrumb-current {
    color: #000;
    font-weight: 600;
}

/* Default template breadcrumb */
.ikbase-style-default .ikbase-breadcrumb-section {
    background: #f8f9fa;
    border-bottom: 1px solid #e5e7eb;
    padding: 0.75rem 0;
    margin-bottom: 1rem;
}

.ikbase-style-default .ikbase-breadcrumb {
    color: #fff;
    justify-content: center;
}

.ikbase-style-default .ikbase-breadcrumb a {
    color: #fff;
}

.ikbase-style-default .ikbase-breadcrumb a:hover {
    color: #fff;
    /* background: rgba(0, 124, 186, 0.1); */
}

.ikbase-style-default .ikbase-breadcrumb-current {
    color: #374151;
    font-weight: 600;
}

.ikbase-style-default .ikbase-breadcrumb-separator {
    color: #6b7280;
}

/* Mobile responsiveness for breadcrumbs */
@media (max-width: 768px) {
    .ikbase-breadcrumb {
        font-size: 0.8rem;
        gap: 0.125rem;
    }
    
    .ikbase-breadcrumb a,
    .ikbase-breadcrumb-current {
        padding: 2px 4px;
    }
    
    .ikbase-breadcrumb-separator {
        margin: 0 0.125rem;
    }
}

/* ==========================================
   CATEGORY PAGE HEADING FIXES
   ========================================== */

/* Fix for oversized category page headings */
.ikbase-category-layout .ikbase-centered-title {
    font-size: 2rem !important;
    margin-bottom: 1rem !important;
    text-align: center !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
}

.ikbase-content-header .ikbase-page-title {
    font-size: 2rem !important;
    margin-bottom: 1rem !important;
    text-align: center !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
}

/* Category page description styling */
.ikbase-category-description,
.ikbase-page-description {
    /* font-size: 1rem !important; */
    text-align: left !important;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 1rem !important;
    max-width: 600px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Category stats styling */
.ikbase-category-stats,
.ikbase-page-stats {
    text-align: center !important;
    margin-top: 1rem !important;
}

.ikbase-article-count {
    font-size: 0.9rem !important;
    opacity: 0.9 !important;
}

/* ==========================================
   TABLE OF CONTENTS STYLES
   ========================================== */

/* Table of Contents Layout */
.ikbase-article-layout-with-toc {
    display: grid;
    grid-template-columns: 320px 1fr 250px;
    gap: 2rem;
    max-width: 1400px;
    margin: 30px auto;
    padding: 0 20px;
}

.ikbase-article-sidebar-right {
    background: white;
    border-radius: 8px;
    padding: 1.5rem;
    height: fit-content;
    position: sticky;
    top: 2rem;
	box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.ikbase-toc-title {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0 0 1rem 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: #374151;
    border-bottom: 1px solid #e5e7eb;
    padding-bottom: 0.75rem;
}

.ikbase-toc {
    list-style: none;
    padding: 0;
    margin: 0;
}

.ikbase-toc-item {
    margin: 0.5rem 0;
}

.ikbase-toc-link {
    display: block;
    padding: 0.5rem 0;
    color: #6b7280;
    text-decoration: none;
    font-size: 0.9rem;
    border-left: 2px solid transparent;
    padding-left: 1rem;
    transition: all 0.3s ease;
    line-height: 1.4;
}

.ikbase-toc-link:hover,
.ikbase-toc-link.active {
    color: #22c55e;
    border-left-color: #22c55e;
    background: #f0fdf4;
    padding-left: 1.25rem;
}

.ikbase-toc-link.level-h3 {
    padding-left: 2rem;
    font-size: 0.85rem;
    color: #9ca3af;
}

.ikbase-toc-link.level-h3:hover,
.ikbase-toc-link.level-h3.active {
    padding-left: 2.25rem;
}

.ikbase-toc-link.level-h4 {
    padding-left: 2.5rem;
    font-size: 0.8rem;
    color: #9ca3af;
}

.ikbase-toc-link.level-h4:hover,
.ikbase-toc-link.level-h4.active {
    padding-left: 2.75rem;
}

.ikbase-toc-empty {
    color: #6b7280;
    font-style: italic;
    text-align: center;
    padding: 1rem 0;
}

/* Enhanced Categories Sidebar with wider layout */
.ikbase-categories-sidebar {
    width: 100%;
    max-width: 320px;
    background: #f9f9fa;
    padding: 0;
    border-radius: 8px;
    overflow: hidden;
}

/* Nested accordion for articles within categories */
.ikbase-category-articles {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    background: #f8f9fa;
    border-top: 1px solid #e5e7eb;
}

.ikbase-category-articles.active {
    max-height: 400px;
    overflow-y: auto;
}

.ikbase-category-articles ul {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ikbase-category-articles li {
    border-bottom: 1px solid #e5e7eb;
}

.ikbase-category-articles li:last-child {
    border-bottom: none;
}

.ikbase-category-articles a {
    display: block;
    padding: 0.75rem 1.5rem;
    color: #4b5563;
    text-decoration: none;
    font-size: 0.85rem;
    line-height: 1.4;
    transition: all 0.2s ease;
    border-left: 3px solid transparent;
}

.ikbase-category-articles a:hover {
    background: #e5e7eb;
    color: #1f2937;
    border-left-color: #22c55e;
    padding-left: 1.75rem;
}

.ikbase-category-articles .current-article a {
    background: #dcfce7;
    color: #16a34a;
    border-left-color: #22c55e;
    font-weight: 500;
}

/* Category accordion headers with expand indicators */
.ikbase-accordion-content .category-with-articles {
    position: relative;
}

.ikbase-accordion-content .category-expand-toggle {
    position: absolute;
    right: 2.5rem;
    top: 35px;
    transform: translateY(-50%);
    font-size: 0.75rem;
    color: #9ca3af;
    transition: transform 0.3s ease, color 0.3s ease;
    cursor: pointer;
}

.ikbase-accordion-content .category-expanded .category-expand-toggle {
    transform: translateY(-50%) rotate(180deg);
    color: #22c55e;
}

.ikbase-accordion-content .category-with-articles a {
    padding-right: 3.5rem; /* Make room for expand indicator */
    cursor: pointer;
}

/* Loading indicator for articles */
.ikbase-category-articles .loading {
    padding: 1rem;
    text-align: center;
    color: #9ca3af;
    font-style: italic;
    font-size: 0.8rem;
}

/* Empty state for categories */
.ikbase-category-articles .no-articles {
    padding: 1rem 1.5rem;
    color: #9ca3af;
    font-style: italic;
    font-size: 0.8rem;
    text-align: center;
}

/* Article count indicators */
.ikbase-accordion-content .count {
    margin-left: auto;
    font-size: 0.75rem;
    color: #9ca3af;
    background: #f3f4f6;
    padding: 0.125rem 0.375rem;
    border-radius: 10px;
    min-width: 20px;
    text-align: center;
    margin-right: 1.5rem; /* Space for expand toggle */
}

/* Responsive adjustments for wider sidebar */
@media (max-width: 1200px) {
    .ikbase-article-layout-with-toc {
        grid-template-columns: 280px 1fr 220px;
        gap: 1.5rem;
    }
    
    .ikbase-categories-sidebar {
        max-width: 280px;
    }
}

/* Responsive adjustments for TOC */
@media (max-width: 1024px) {
    .ikbase-article-layout-with-toc {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .ikbase-categories-sidebar,
    .ikbase-article-sidebar-right {
        position: static;
        order: 2;
        max-width: 100%;
    }

    .ikbase-article-main-with-toc {
        order: 1;
    }
}

/* ==========================================
   RESTORED MISSING STYLES
   ========================================== */

/* Enhanced article main content with TOC */
.ikbase-article-main-with-toc {
    background: white;
    border-radius: 8px;
    padding: 2rem;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    min-height: 600px;
}

/* Enhanced heading styles for better TOC anchoring */
.ikbase-article-main-with-toc h1,
.ikbase-article-main-with-toc h2,
.ikbase-article-main-with-toc h3,
.ikbase-article-main-with-toc h4,
.ikbase-article-main-with-toc h5,
.ikbase-article-main-with-toc h6 {
    scroll-margin-top: 100px;
    position: relative;
}

.ikbase-article-main-with-toc h2 {
    border-bottom: 2px solid #22c55e;
    padding-bottom: 0.5rem;
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.ikbase-article-main-with-toc h3 {
    margin-top: 1.5rem;
    margin-bottom: 0.75rem;
}

.ikbase-article-main-with-toc h4,
.ikbase-article-main-with-toc h5,
.ikbase-article-main-with-toc h6 {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

/* Category Header Image */
.ikbase-category-header-image {
    max-width: 48px;
    max-height: 48px;
    margin-right: 0.5rem;
    vertical-align: middle;
}

/* Category Stats */
.ikbase-category-stats {
    margin-top: 1rem;
    text-align: center;
}

.ikbase-article-count {
    display: inline-block;
    padding: 0.5rem 1rem;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 20px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.9rem;
    font-weight: 500;
}

/* Related Article Categories */
.ikbase-related-category {
    margin-top: 0.5rem;
    font-size: 0.8rem;
    color: #6b7280;
    font-style: italic;
}

/* Enhanced accordion animations */
.ikbase-accordion-content {
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.ikbase-accordion-toggle {
    transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Responsive Design */
@media (max-width: 768px) {
    .ikbase-hierarchy-search-filters {
        grid-template-columns: 1fr;
    }
    
    .ikbase-sections-grid {
        grid-template-columns: 1fr;
    }
    
    .ikbase-article-stats {
        flex-direction: column;
        gap: 0.5rem;
        align-items: center;
    }
    
    .ikbase-category-search-form {
        flex-direction: column;
        max-width: none;
    }
    
    .ikbase-related-categories-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .ikbase-breadcrumb-list {
        font-size: 0.8rem;
    }
    
    .ikbase-article-hierarchy-meta {
        justify-content: center;
        text-align: center;
    }
    
    /* Mobile accordion adjustments */
    .ikbase-accordion-header h4 {
        font-size: 0.9rem;
        padding: 0.75rem;
    }
    
    .ikbase-accordion-content a {
        padding: 0.5rem 0.75rem;
        font-size: 0.8rem;
    }
    
    .ikbase-publish-date,
    .ikbase-view-count {
        padding: 0.25rem 0.5rem;
        font-size: 0.8rem;
    }
}

@media (max-width: 480px) {
    .ikbase-type-filter {
        display: block;
        width: 100%;
        margin: 0.25rem 0;
        text-align: center;
    }
    
    .ikbase-related-categories-grid {
        grid-template-columns: 1fr;
    }
    
    .ikbase-hierarchy-type,
    .ikbase-hierarchy-section,
    .ikbase-hierarchy-category {
        font-size: 0.7rem;
        padding: 0.2rem 0.4rem;
    }
    
    /* Stack article stats vertically on very small screens */
    .ikbase-article-stats {
        flex-direction: column;
        gap: 0.25rem;
    }
    
    .ikbase-publish-date,
    .ikbase-view-count {
        width: 100%;
        justify-content: center;
        text-align: center;
    }
    }
/* New Custom CSS */
input#ikbase-hero-search {
    background: #fff !important;
}
.ikbase-header-override .ikbase-hero-section {
    padding: 0px !important;
}
.ikbase-header-override .ikbase-hero-content {
    padding: 100px 20px !important;
}
.ikbase-header-override form.ikbase-hero-search-form {
    width: 800px;
}

/* Inline Code Styling - Premium Feature */
.ikbase-plugin code {
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 4px;
    color: #e83e8c;
    font-family: 'Courier New', Courier, 'Lucida Console', Monaco, monospace;
    font-size: 0.9em;
    padding: 2px 6px;
    white-space: nowrap;
    word-break: break-all;
    display: inline-block;
    vertical-align: baseline;
    line-height: 1.4;
}

.ikbase-plugin code:hover {
    background-color: #e9ecef;
    border-color: #dee2e6;
}

/* Dark theme support for inline code */
.ikbase-plugin.dark-theme code,
.ikbase-plugin .dark-theme code {
    background-color: #2d3748;
    border-color: #4a5568;
    color: #f7fafc;
}

.ikbase-plugin.dark-theme code:hover,
.ikbase-plugin .dark-theme code:hover {
    background-color: #4a5568;
    border-color: #718096;
}

/* Code Block Styling */
.ikbase-plugin pre {
    background-color: #f8f9fa;
    border: 1px solid #e9ecef;
    border-radius: 6px;
    padding: 16px;
    margin: 16px 0;
    overflow-x: auto;
    font-family: 'Courier New', Courier, 'Lucida Console', Monaco, monospace;
    font-size: 14px;
    line-height: 1.5;
    color: #333;
}

.ikbase-plugin pre code {
    background: none;
    border: none;
    padding: 0;
    color: inherit;
    font-size: inherit;
    line-height: inherit;
    white-space: pre;
    word-break: normal;
    display: block;
}

/* Dark theme support for code blocks */
.ikbase-plugin.dark-theme pre,
.ikbase-plugin .dark-theme pre {
    background-color: #2d3748;
    border-color: #4a5568;
    color: #f7fafc;
}

.ikbase-plugin.dark-theme pre code,
.ikbase-plugin .dark-theme pre code {
    color: inherit;
}

/* Responsive code blocks */
@media (max-width: 768px) {
    .ikbase-plugin pre {
        padding: 12px;
        font-size: 13px;
        margin: 12px 0;
    }
}

/* Content Boxes Styling */
.ikbase-plugin .ikbase-tip-box,
.ikbase-tip-box {
    background-color: #d4edda;
    border: 1px solid #c3e6cb;
    border-radius: 6px;
    padding: 16px;
    margin: 16px 0;
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.ikbase-plugin .ikbase-tip-icon,
.ikbase-tip-icon {
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

.ikbase-plugin .ikbase-tip-content,
.ikbase-tip-content {
    flex: 1;
    color: #155724;
    line-height: 1.5;
}

.ikbase-plugin .ikbase-info-box,
.ikbase-info-box {
    background-color: #fff3cd;
    border: 1px solid #ffeaa7;
    border-radius: 6px;
    padding: 16px;
    margin: 16px 0;
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.ikbase-plugin .ikbase-info-icon,
.ikbase-info-icon {
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

.ikbase-plugin .ikbase-info-content,
.ikbase-info-content {
    flex: 1;
    color: #856404;
    line-height: 1.5;
}

.ikbase-plugin .ikbase-warning-box,
.ikbase-warning-box {
    background-color: #f8d7da;
    border: 1px solid #f5c6cb;
    border-radius: 6px;
    padding: 16px;
    margin: 16px 0;
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.ikbase-plugin .ikbase-warning-icon,
.ikbase-warning-icon {
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

.ikbase-plugin .ikbase-warning-content,
.ikbase-warning-content {
    flex: 1;
    color: #721c24;
    line-height: 1.5;
}

/* Dark theme support for content boxes */
.ikbase-plugin.dark-theme .ikbase-tip-box,
.ikbase-plugin .dark-theme .ikbase-tip-box,
.dark-theme .ikbase-tip-box {
    background-color: #1e4d2b;
    border-color: #2d5a3a;
}

.ikbase-plugin.dark-theme .ikbase-tip-content,
.ikbase-plugin .dark-theme .ikbase-tip-content,
.dark-theme .ikbase-tip-content {
    color: #d4edda;
}

.ikbase-plugin.dark-theme .ikbase-info-box,
.ikbase-plugin .dark-theme .ikbase-info-box,
.dark-theme .ikbase-info-box {
    background-color: #4a3c1a;
    border-color: #5a4a2a;
}

.ikbase-plugin.dark-theme .ikbase-info-content,
.ikbase-plugin .dark-theme .ikbase-info-content,
.dark-theme .ikbase-info-content {
    color: #fff3cd;
}

.ikbase-plugin.dark-theme .ikbase-warning-box,
.ikbase-plugin .dark-theme .ikbase-warning-box,
.dark-theme .ikbase-warning-box {
    background-color: #4a1e1e;
    border-color: #5a2a2a;
}

.ikbase-plugin.dark-theme .ikbase-warning-content,
.ikbase-plugin .dark-theme .ikbase-warning-content,
.dark-theme .ikbase-warning-content {
    color: #f8d7da;
}

/* Media Elements Styling */
.ikbase-plugin .ikbase-image-container,
.ikbase-plugin .ikbase-gif-container,
.ikbase-plugin .ikbase-video-container,
.ikbase-image-container,
.ikbase-gif-container,
.ikbase-video-container {
    margin: 20px 0;
    text-align: center;
    border-radius: 8px;
    overflow: hidden;
}

.ikbase-plugin .ikbase-image,
.ikbase-plugin .ikbase-gif,
.ikbase-plugin .ikbase-video,
.ikbase-image,
.ikbase-gif,
.ikbase-video {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ikbase-plugin .ikbase-image:hover,
.ikbase-plugin .ikbase-gif:hover,
.ikbase-plugin .ikbase-video:hover,
.ikbase-image:hover,
.ikbase-gif:hover,
.ikbase-video:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.2);
}

/* Video specific styling */
.ikbase-plugin .ikbase-video,
.ikbase-video {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    display: block;
}

/* GIF specific styling */
.ikbase-plugin .ikbase-gif,
.ikbase-gif {
    max-width: 100%;
    border-radius: 8px;
}

/* Image specific styling */
.ikbase-plugin .ikbase-image,
.ikbase-image {
    max-width: 100%;
    border-radius: 6px;
}

/* Dark theme support for media elements */
.ikbase-plugin.dark-theme .ikbase-image-container,
.ikbase-plugin.dark-theme .ikbase-gif-container,
.ikbase-plugin.dark-theme .ikbase-video-container,
.dark-theme .ikbase-image-container,
.dark-theme .ikbase-gif-container,
.dark-theme .ikbase-video-container {
    background-color: #2d3748;
    padding: 16px;
    border-radius: 8px;
}

.ikbase-plugin.dark-theme .ikbase-image,
.ikbase-plugin.dark-theme .ikbase-gif,
.ikbase-plugin.dark-theme .ikbase-video,
.dark-theme .ikbase-image,
.dark-theme .ikbase-gif,
.dark-theme .ikbase-video {
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

/* Responsive content boxes */
@media (max-width: 768px) {
    .ikbase-plugin .ikbase-tip-box,
    .ikbase-plugin .ikbase-info-box,
    .ikbase-plugin .ikbase-warning-box,
    .ikbase-tip-box,
    .ikbase-info-box,
    .ikbase-warning-box {
        padding: 12px;
        margin: 12px 0;
        gap: 8px;
    }
    
    .ikbase-plugin .ikbase-tip-icon,
    .ikbase-plugin .ikbase-info-icon,
    .ikbase-plugin .ikbase-warning-icon,
    .ikbase-tip-icon,
    .ikbase-info-icon,
    .ikbase-warning-icon {
        font-size: 18px;
    }
    
    .ikbase-plugin .ikbase-image-container,
    .ikbase-plugin .ikbase-gif-container,
    .ikbase-plugin .ikbase-video-container,
    .ikbase-image-container,
    .ikbase-gif-container,
    .ikbase-video-container {
        margin: 16px 0;
        padding: 8px;
    }
    
    .ikbase-plugin .ikbase-image,
    .ikbase-plugin .ikbase-gif,
    .ikbase-plugin .ikbase-video,
    .ikbase-image,
    .ikbase-gif,
    .ikbase-video {
        border-radius: 4px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    }
}

/* Responsive inline code */
@media (max-width: 768px) {
    .ikbase-plugin code {
        font-size: 0.85em;
        padding: 1px 4px;
    }
}

/* iFrame Elements Styling */
.ikbase-plugin .ikbase-iframe-container,
.ikbase-iframe-container { /* Added for broader applicability */
    margin: 20px 0;
    text-align: center;
    border-radius: 8px;
    overflow: hidden;
}

.ikbase-plugin .ikbase-iframe,
.ikbase-iframe { /* Added for broader applicability */
    max-width: 100%;
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.ikbase-plugin .ikbase-iframe:hover,
.ikbase-iframe:hover { /* Added for broader applicability */
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.2);
}

/* iFrame specific styling */
.ikbase-plugin .ikbase-iframe,
.ikbase-iframe { /* Added for broader applicability */
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    display: block;
    border: none;
}

/* Dark theme support for iFrame elements */
.ikbase-plugin.dark-theme .ikbase-iframe-container,
.dark-theme .ikbase-iframe-container { /* Added for broader applicability */
    background-color: #2d3748;
    padding: 16px;
    border-radius: 8px;
}

.ikbase-plugin.dark-theme .ikbase-iframe,
.dark-theme .ikbase-iframe { /* Added for broader applicability */
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

/* Responsive iFrame elements */
@media (max-width: 768px) {
    .ikbase-plugin .ikbase-iframe-container,
    .ikbase-iframe-container { /* Added for broader applicability */
        margin: 16px 0;
        padding: 8px;
    }
    
    .ikbase-plugin .ikbase-iframe,
    .ikbase-iframe { /* Added for broader applicability */
        border-radius: 4px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.1);
    }
}

/* Subcategories Styles */
.ikbase-subcategories {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid #e5e7eb;
}

.ikbase-subcategories-title {
    font-size: 12px;
    font-weight: 600;
    color: #6b7280;
    margin: 0 0 8px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ikbase-subcategories-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.ikbase-subcategory-item {
    margin: 0;
    padding: 0;
}

.ikbase-subcategory-link {
    display: inline-block;
    background: #f3f4f6;
    color: #374151;
    text-decoration: none;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 500;
    transition: all 0.2s ease;
    border: 1px solid #e5e7eb;
}

.ikbase-subcategory-link:hover {
    background: #e5e7eb;
    color: #1f2937;
    text-decoration: none;
    transform: translateY(-1px);
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.ikbase-subcategory-count {
    color: #9ca3af;
    font-weight: 400;
    margin-left: 4px;
}

/* Responsive subcategories */
@media (max-width: 768px) {
    .ikbase-subcategories-list {
        flex-direction: column;
        gap: 4px;
    }
    
    .ikbase-subcategory-link {
        font-size: 10px;
        padding: 3px 6px;
    }
}

/* Navigation Subcategories Styles */
.ikbase-nav-subcategories {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #e5e7eb;
}

.ikbase-nav-subcategories-title {
    font-size: 11px;
    font-weight: 600;
    color: #6b7280;
    margin: 0 0 8px 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.ikbase-nav-subcategories-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.ikbase-nav-subcategory-item {
    margin: 0;
    padding: 0;
}

.ikbase-nav-subcategory-link {
    display: block;
    color: #6b7280;
    text-decoration: none;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 500;
    border-radius: 4px;
    transition: all 0.2s ease;
    margin-bottom: 2px;
    background: #f9fafb;
    border-left: 3px solid #e5e7eb;
}

.ikbase-nav-subcategory-link:hover {
    background: #f3f4f6;
    color: #374151;
    text-decoration: none;
    border-left-color: #3b82f6;
}

.ikbase-nav-subcategory-count {
    color: #9ca3af;
    font-weight: 400;
    margin-left: 4px;
    font-size: 11px;
}

/* Also Read Section */
.ikbase-also-read {
    margin: 30px 0;
    padding: 20px 0;
}

.ikbase-also-read h4 {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 15px;
    color: #333;
}

.ikbase-also-read-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.ikbase-also-read-item {
    margin: 0;
}

.ikbase-also-read-item a {
    display: block;
    padding: 8px 0;
    color: #007cba;
    text-decoration: none;
    font-size: 14px;
    line-height: 1.4;
    transition: color 0.2s ease;
}

.ikbase-also-read-item a:hover {
    color: #005a87;
    text-decoration: underline;
}

/* Was this helpful? Section */
.ikbase-helpful {
    margin: 30px 0;
    padding: 20px 0;
    border-top: 1px solid #e5e7eb;
    border-bottom: 1px solid #e5e7eb;
}

.ikbase-helpful-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 15px;
    color: #374151;
    text-align: center;
}

.ikbase-helpful-actions {
    display: flex;
    justify-content: center;
    gap: 15px;
}

.ikbase-helpful-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    border: 2px solid #e5e7eb;
    background: #fff;
    color: #374151;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.2s ease;
}

.ikbase-helpful-btn:hover {
    border-color: #007cba;
    color: #007cba;
    background: #f8fafc;
}

.ikbase-helpful-btn.voted {
    border-color: #007cba;
    background: #007cba;
    color: #fff;
}

.ikbase-helpful-btn .dashicons {
    font-size: 16px;
    width: 16px;
    height: 16px;
}

.ikbase-helpful-message {
    text-align: center;
    margin-top: 15px;
    padding: 10px;
    border-radius: 4px;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.ikbase-helpful-message.success {
    background: #d1fae5;
    color: #065f46;
    border: 1px solid #a7f3d0;
}

.ikbase-helpful-message.error {
    background: #fee2e2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}