/**
* Template Name: Personal - v2.1.0
* Template URL: https://bootstrapmade.com/personal-free-resume-bootstrap-template/
* Author: BootstrapMade.com
* License: https://bootstrapmade.com/license/
*/

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/
body {
	font-family: "Open Sans", sans-serif;
	color: #fff;
	position: relative;
	background: transparent;
}

body::before {
	content: "";
	position: fixed;
	background: #010e1b;
	background-size: cover;
	left: 0;
	right: 0;
	top: 0;
	height: 100vh;
}

@media (min-width: 1024px) {
	body::before {
		background-attachment: fixed;
	}
}

a {
	color: #12d640;
}

a:hover {
	color: #12d640;
	text-decoration: none;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: "Raleway", sans-serif;
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#header {
	transition: ease-in-out 0s;
	position: relative;
	height: 100vh;
	display: flex;
	align-items: center;
	z-index: 997;
	overflow-y: auto;
}

#header * {
	transition: ease-in-out 0s;
}

#header h1 {
	font-size: 48px;
	margin-top: 0px;
	padding: 0;
	line-height: 1;
	font-weight: 700;
	font-family: "Poppins", sans-serif;
}

#header h1 a,
#header h1 a:hover {
	color: #dee2e6;
	line-height: 1;
	display: inline-block;
}

#header h2 {
	font-size: 24px;
	margin-top: 20px;
	color: #12d640;
}

#header h2 span {
	color: #ffc107;
	border-bottom: 2px solid #1c7d32;
	padding-bottom: 6px;
}

#header img {
	padding: 0;
	margin: 0;
}

#header .social-links {
	margin-top: 40px;
	display: flex;
}

#header .social-links a {
	font-size: 16px;
	display: flex;
	justify-content: center;
	align-items: center;
	background: rgba(255, 255, 255, 0.1);
	color: #fff;
	line-height: 1;
	margin-right: 8px;
	border-radius: 50%;
	width: 40px;
	height: 40px;
}

#header .social-links a:hover {
	background: #1c7d32;
}

@media (max-width: 992px) {
	#header h1 {
		font-size: 36px;
	}

	#header h2 {
		font-size: 20px;
		line-height: 30px;
	}

	#header .social-links {
		margin-top: 15px;
	}

	#header .container {
		display: flex;
		flex-direction: column;
		align-items: center;
	}
}

/* Chatbot css */
/* Chatbot General Container */
#ai-chatbot-container {
	position: fixed;
	bottom: 25px;
	right: 25px;
	z-index: 9999;
}

/* Chatbot Toggle Button */
#ai-chatbot-button {
	width: 60px;
	height: 60px;
	background-color: #12D640;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	box-shadow: 0 5px 20px rgba(18, 214, 64, 0.4);
	transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
	position: relative;
}

#ai-chatbot-button:hover {
	transform: scale(1.1);
	box-shadow: 0 8px 25px rgba(18, 214, 64, 0.5);
}

#ai-chatbot-button svg {
	color: #010e1b;
	width: 30px;
	height: 30px;
	position: absolute;
	transition: transform 0.3s ease-out, opacity 0.3s ease-out;
}

#ai-chat-icon-close {
	transform: scale(0) rotate(-90deg);
	opacity: 0;
}

#ai-chatbot-button.open #ai-chat-icon-open {
	transform: scale(0) rotate(90deg);
	opacity: 0;
}

#ai-chatbot-button.open #ai-chat-icon-close {
	transform: scale(1) rotate(0deg);
	opacity: 1;
}

/* Chat Window */
#ai-chatbot-window {
	position: absolute;
	bottom: 75px;
	right: 0;
	width: 400px;
	height: 600px;
	/* FIX: Ensures the chat window doesn't touch the top of the screen */
	max-height: calc(100vh - 100px);
	background-color: #0d1a2b;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	box-shadow: 0 15px 50px rgba(0, 0, 0, 0.5);
	display: flex;
	flex-direction: column;
	overflow: hidden;
	transform-origin: bottom right;
	transform: scale(0.95) translateY(10px);
	opacity: 0;
	pointer-events: none;
	transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

#ai-chatbot-window.open {
	transform: scale(1) translateY(0);
	opacity: 1;
	pointer-events: auto;
}

/* Header */
.ai-chatbot-header {
	display: flex;
	align-items: center;
	padding: 15px 20px;
	background-color: #1a2a3a;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	flex-shrink: 0;
}

.ai-chatbot-avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	overflow: hidden;
	margin-right: 15px;
	border: 2px solid #12D640;
}

.ai-chatbot-avatar img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ai-chatbot-title h3 {
	margin: 0;
	color: #fff;
	font-size: 16px;
	font-weight: 600;
	font-family: "Poppins", sans-serif;
}

.ai-chatbot-title p {
	margin: 2px 0 0;
	color: #718096;
	/* Default to grey */
	font-size: 13px;
	font-weight: 500;
	font-family: "Poppins", sans-serif;
	position: relative;
	padding-left: 14px;
}

.ai-chatbot-title p::before {
	content: '';
	display: inline-block;
	width: 8px;
	height: 8px;
	background-color: #718096;
	/* Default to grey */
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: background-color 0.3s ease;
}

.ai-chatbot-title p.online {
	color: #12D640;
}

.ai-chatbot-title p.online::before {
	background-color: #12D640;
	animation: pulse 2s infinite;
}

.ai-chatbot-title p.offline::before {
	background-color: #e53e3e;
	/* Red for offline */
}


@keyframes pulse {
	0% {
		box-shadow: 0 0 0 0 rgba(18, 214, 64, 0.7);
	}

	70% {
		box-shadow: 0 0 0 10px rgba(18, 214, 64, 0);
	}

	100% {
		box-shadow: 0 0 0 0 rgba(18, 214, 64, 0);
	}
}

/* Messages Area */
#ai-chatbot-messages {
	flex-grow: 1;
	padding: 20px;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.ai-chatbot-message {
	max-width: 85%;
	padding: 12px 18px;
	border-radius: 20px;
	line-height: 1.5;
	font-size: 15px;
	font-family: "Open Sans", sans-serif;
	white-space: pre-wrap;
	/* Renders newlines from Gemini */
}

.ai-chatbot-message.user {
	align-self: flex-end;
	background-color: #12D640;
	color: #010e1b;
	font-weight: 500;
	border-bottom-right-radius: 5px;
}

.ai-chatbot-message.bot {
	align-self: flex-start;
	background-color: #1a2a3a;
	color: #e2e8f0;
	border-bottom-left-radius: 5px;
}

.ai-chatbot-message.bot.typing {
	display: flex;
	align-items: center;
	gap: 5px;
	padding: 14px 18px;
}

.typing-dot {
	width: 8px;
	height: 8px;
	background-color: #718096;
	border-radius: 50%;
	animation: typing-animation 1.4s infinite ease-in-out both;
}

.typing-dot:nth-child(1) {
	animation-delay: -0.32s;
}

.typing-dot:nth-child(2) {
	animation-delay: -0.16s;
}

@keyframes typing-animation {

	0%,
	80%,
	100% {
		transform: scale(0);
	}

	40% {
		transform: scale(1.0);
	}
}

/* Input Area */
.ai-chatbot-input-area {
	display: flex;
	padding: 15px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	background-color: #0d1a2b;
	flex-shrink: 0;
}

#ai-chatbot-input {
	flex-grow: 1;
	border: 1px solid #4a5568;
	background-color: #1a2a3a;
	color: #fff;
	font-size: 15px;
	padding: 10px 15px;
	border-radius: 20px;
	outline: none;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	font-family: "Open Sans", sans-serif;
}

#ai-chatbot-input:focus {
	border-color: #12D640;
	box-shadow: 0 0 0 3px rgba(18, 214, 64, 0.2);
}

#ai-chatbot-send-btn {
	background: none;
	border: none;
	color: #12D640;
	cursor: pointer;
	padding: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	margin-left: 10px;
	transition: background-color 0.2s ease;
}

#ai-chatbot-send-btn:hover {
	background-color: rgba(18, 214, 64, 0.15);
}

/* Disabled State */
#ai-chatbot-input:disabled {
	background-color: #2d3748;
	cursor: not-allowed;
}

#ai-chatbot-send-btn:disabled {
	color: #718096;
	cursor: not-allowed;
}

#ai-chatbot-send-btn:disabled:hover {
	background-color: transparent;
}

/* Responsive Design */
@media (max-width: 480px) {
	#ai-chatbot-container {
		bottom: 15px;
		right: 15px;
	}

	#ai-chatbot-window {
		width: calc(100vw - 30px);
		/* FIX: Ensures a gap from the top on mobile */
		max-height: calc(100vh - 100px);
		height: calc(100vh - 100px);
		bottom: 80px;
		right: 0;
	}
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
/* Desktop Navigation */
.nav-menu {
	margin-top: 35px;
}

.nav-menu ul {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}

.nav-menu li+li {
	margin-left: 30px;
}

.nav-menu a {
	display: block;
	position: relative;
	color: #fff;
	font-size: 19px;
	font-family: "Poppins", sans-serif;
	font-weight: 400;
}

.nav-menu a:before {
	content: "";
	position: absolute;
	width: 0;
	height: 2px;
	bottom: -4px;
	left: 0;
	background-color: #9e7f25;
	visibility: hidden;
	width: 0px;
	transition: all 0.3s ease-in-out 0s;
}

.nav-menu a:hover:before,
.nav-menu li:hover>a:before,
.nav-menu .active>a:before {
	visibility: visible;
	width: 25px;
}

.nav-menu a:hover,
.nav-menu .active>a,
.nav-menu li:hover>a {
	color: #12d640;
	text-decoration: none;
}

/* Mobile Navigation */
.mobile-nav-toggle {
	position: fixed;
	right: 15px;
	top: 15px;
	z-index: 9998;
	border: 0;
	background: none;
	font-size: 24px;
	transition: all 0.4s;
	outline: none !important;
	line-height: 1;
	cursor: pointer;
	text-align: right;
}

.mobile-nav-toggle i {
	color: #fff;
}

.mobile-nav {
	position: fixed;
	top: 55px;
	right: 15px;
	bottom: 15px;
	left: 15px;
	z-index: 9999;
	overflow-y: auto;
	background: rgba(0, 0, 0, 0.7);
	transition: ease-in-out 0s;
	opacity: 0;
	visibility: hidden;
	border-radius: 10px;
	padding: 10px 0;
	border: 2px solid rgba(255, 255, 255, 0.12);
}

.mobile-nav * {
	margin: 0;
	padding: 0;
	list-style: none;
}

.mobile-nav a {
	display: block;
	position: relative;
	color: #fff;
	padding: 10px 20px;
	font-weight: 500;
	outline: none;
}

.mobile-nav a:hover,
.mobile-nav .active>a,
.mobile-nav li:hover>a {
	color: #1c7d32;
	text-decoration: none;
}

.mobile-nav-overly {
	width: 100%;
	height: 100%;
	z-index: 9997;
	top: 0;
	left: 0;
	position: fixed;
	background: rgba(9, 9, 9, 0.6);
	overflow: hidden;
	display: none;
	transition: ease-in-out 0s;
}

.mobile-nav-active {
	overflow: hidden;
}

.mobile-nav-active .mobile-nav {
	opacity: 1;
	visibility: visible;
}

.mobile-nav-active .mobile-nav-toggle i {
	color: #fff;
}

/* Header Top */
#header.header-top {
	height: 90px;
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	background: #09203a;
}

#header.header-top .social-links,
#header.header-top h2 {
	display: none;
}

#header.header-top h1 {
	margin-right: auto;
	font-size: 36px;
}

#header.header-top .container {
	display: flex;
	align-items: center;
}

#header.header-top .nav-menu {
	margin: 0;
}

@media (max-width: 768px) {
	#header.header-top {
		height: 60px;
	}

	#header.header-top h1 {
		font-size: 26px;
	}
}

/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section {
	overflow: hidden;
	position: absolute;
	width: 100%;
	top: 140px;
	bottom: 100%;
	opacity: 0;
	z-index: 2;
}

section.section-show {
	top: 70px;
	bottom: auto;
	opacity: 1;
	padding-bottom: 0px;
}

section .container {
	background: rgba(0, 0, 0, 0);
	padding: 30px;
}

@media (max-width: 768px) {
	section {
		top: 120px;
	}

	section.section-show {
		top: 80px;
	}
}

.section-title h2 {
	font-size: 14px;
	font-weight: 500;
	padding: 0;
	line-height: 1px;
	margin: 0 0 20px 0;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: #dee2e6;
	font-family: "Poppins", sans-serif;
}

.section-title h2::after {
	content: "";
	width: 120px;
	height: 1px;
	display: inline-block;
	background: #dee2e6;
	margin: 4px 10px;
}

.section-title p {
	margin: 0;
	margin: -15px 0 15px 0;
	font-size: 36px;
	font-weight: 700;
	text-transform: uppercase;
	font-family: "Poppins", sans-serif;
	color: #fff;
}

/*--------------------------------------------------------------
# About
--------------------------------------------------------------*/
.about-me .content h3 {
	font-weight: 700;
	font-size: 26px;
	color: #1c7d32;
}

.about-me .content ul {
	list-style: none;
	padding: 0;
}

.about-me .content ul li {
	padding-bottom: 10px;
}

.about-me .content ul i {
	font-size: 20px;
	padding-right: 2px;
	color: #1c7d32;
}

.about-me .content p:last-child {
	margin-bottom: 0;
}

/*--------------------------------------------------------------
# Counts
--------------------------------------------------------------*/
.counts {
	padding: 70px 0 60px;
}

.counts .count-box {
	padding: 30px 30px 25px 30px;
	width: 100%;
	position: relative;
	text-align: center;
	background: rgba(255, 255, 255, 0.08);
}

.counts .count-box i {
	position: absolute;
	top: -25px;
	left: 50%;
	transform: translateX(-50%);
	font-size: 24px;
	background: rgba(255, 255, 255, 0.1);
	padding: 12px;
	color: #1c7d32;
	border-radius: 50px;
}

.counts .count-box span {
	font-size: 36px;
	display: block;
	font-weight: 600;
	color: #fff;
}

.counts .count-box p {
	padding: 0;
	margin: 0;
	font-family: "Raleway", sans-serif;
	font-size: 14px;
}

/*--------------------------------------------------------------
# Skills
--------------------------------------------------------------*/
.skills .progress {
	height: 50px;
	display: block;
	background: none;
}

.skills .progress .skill {
	padding: 0;
	margin: 0 0 6px 0;
	text-transform: uppercase;
	display: block;
	font-weight: 600;
	font-family: "Poppins", sans-serif;
	color: #fff;
}

.skills .progress .skill .val {
	float: right;
	font-style: normal;
}

.skills .progress-bar-wrap {
	background: rgba(255, 255, 255, 0.15);
}

.skills .progress-bar {
	width: 1px;
	height: 10px;
	transition: .9s;
	background-color: #1c7d32;
}

/*--------------------------------------------------------------
# Interests
--------------------------------------------------------------*/
.interests .icon-box {
	display: flex;
	align-items: center;
	padding: 20px;
	background: #09203a;
	transition: ease-in-out 0.3s;
}


.interests .icon-box i {
	font-size: 32px;
	padding-right: 10px;
	line-height: 1;
}

.interests .icon-box h3 {
	font-weight: 700;
	margin: 0;
	padding: 0;
	line-height: 1;
	font-size: 16px;
	color: #fff;
}

.interests .icon-box:hover {
	background: #042b56eb;
}

/*--------------------------------------------------------------
# Testimonials
--------------------------------------------------------------*/
.testimonials .testimonial-item {
	box-sizing: content-box;
	min-height: 320px;
}

.testimonials .testimonial-item .testimonial-img {
	width: 90px;
	border-radius: 50%;
	margin: -40px 0 0 40px;
	position: relative;
	z-index: 2;
	border: 6px solid rgba(255, 255, 255, 0.12);
}

.testimonials .testimonial-item h3 {
	font-size: 18px;
	font-weight: bold;
	margin: 10px 0 5px 45px;
	color: #fff;
}

.testimonials .testimonial-item h4 {
	font-size: 14px;
	color: #999;
	margin: 0 0 0 45px;
}

.testimonials .testimonial-item .quote-icon-left,
.testimonials .testimonial-item .quote-icon-right {
	color: rgba(255, 255, 255, 0.25);
	font-size: 26px;
}

.testimonials .testimonial-item .quote-icon-left {
	display: inline-block;
	left: -5px;
	position: relative;
}

.testimonials .testimonial-item .quote-icon-right {
	display: inline-block;
	right: -5px;
	position: relative;
	top: 10px;
}

.testimonials .testimonial-item p {
	font-style: italic;
	margin: 0 15px 0 15px;
	padding: 20px 20px 60px 20px;
	background: rgba(255, 255, 255, 0.1);
	position: relative;
	border-radius: 6px;
	position: relative;
	z-index: 1;
}

.testimonials .owl-nav,
.testimonials .owl-dots {
	margin-top: 5px;
	text-align: center;
}

.testimonials .owl-dot {
	display: inline-block;
	margin: 0 5px;
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.3) !important;
}

.testimonials .owl-dot.active {
	background-color: #1c7d32 !important;
}

@media (max-width: 767px) {
	.testimonials {
		margin: 30px 10px;
	}
}

/*--------------------------------------------------------------
# Skills
--------------------------------------------------------------*/
/* Custom CSS variables for consistent theming */
:root {
	--primary: #12d640;
	/* Vibrant Green */
	--accent: #00a2ff;
	/* Bright Blue */
	--dark-bg: #0d1a2b;
	/* Dark Blue-Gray */
	--card-bg: #1a2a3a;
	/* Slightly lighter card background */
	--skill-bg: #2c2f3f;
	/* Skill tag background */
	--text-light: #e0e0e0;
	/* Off-white for text */
	--border-color: rgba(255, 255, 255, 0.15);
	/* Subtle border */
	--shadow-strong: rgba(0, 0, 0, 0.4);
	--shadow-light: rgba(18, 214, 64, 0.3);
	/* Green shadow */
	/* New variable for a slightly softer/more controlled glow color for cards */
	--card-glow-color: rgba(18, 214, 64, 0.8);
	/* Slightly more opaque green for glow */
	/* New variable for skill tag hover background */
	--skill-tag-hover-bg: #0c9c33;
	/* A darker, less saturated green for hover */
	/* New variable for skill tag hover shadow */
	--skill-tag-hover-shadow: rgba(18, 214, 64, 0.4);
	/* Slightly softer shadow for tags */
}

body {
	font-family: 'Poppins', sans-serif;
	background: linear-gradient(135deg, var(--dark-bg), #0a1120);
	/* Reverse gradient direction for subtle change */
	color: var(--text-light);
	min-height: 100vh;
	/* Adjusted padding to fit only the skills section comfortably */
	padding: 80px 20px;
	/* Consistent top and bottom padding for the single section */
	overflow-x: hidden;
	/* Prevent horizontal scrolling */
}

/* Skills Grid */
.skills-container {
	max-width: 1200px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
	gap: 30px;
}

/* Skill Card */
.skill-card {
	background: var(--card-bg);
	border-radius: 15px;
	/* Enhanced transition for smoother hover effects */
	transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1),
		/* Smooth ease-out */
		border-color 0.6s cubic-bezier(0.4, 0, 0.2, 1),
		box-shadow 0.6s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid var(--border-color);
	/* Initial box-shadow with a transparent glow layer for smooth transition */
	box-shadow: 0 5px 25px rgba(0, 0, 0, 0.2),
		0 0 0px rgba(18, 214, 64, 0);
	/* Start with 0 blur, 0 opacity green glow */
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.skill-card:hover {
	transform: translateY(-8px);
	/* Updated box-shadow to animate the glow */
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.4),
		0 0 25px var(--card-glow-color);
	/* Animate to desired glow blur and opacity */
	border-color: var(--primary);
	/* Keep primary green border on hover */
}

/* Card Header */
.card-header {
	display: flex;
	align-items: center;
	padding: 25px 30px;
	background: rgba(0, 0, 0, 0.15);
	border-bottom: 1px solid var(--border-color);
}

.card-header .icon {
	font-size: 28px;
	margin-right: 15px;
	color: var(--primary);
	/* Green icon color */
	min-width: 35px;
	text-align: center;
}

.card-header h3 {
	font-weight: 600;
	font-size: 22px;
	color: #fff;
	margin: 0;
}

/* Skills List */
.skills-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	padding: 30px;
	list-style: none;
}

.skills-list li {
	background: var(--skill-bg);
	padding: 10px 20px;
	border-radius: 8px;
	font-size: 15px;
	font-weight: 500;
	color: var(--text-light);
	/* Smoother transition for list items */
	transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
	border: 1px solid var(--border-color);
	cursor: default;
}

.skills-list li:hover {
	color: var(--text-main);
	/* Change text to main text color for better contrast */
	background-color: var(--skill-tag-hover-bg);
	/* Use the new darker green for background */
	transform: scale(1.05);
	border-color: var(--primary);
	/* Keep primary green border on hover */
	box-shadow: 0 0 10px var(--skill-tag-hover-shadow);
	/* Use the softer shadow */
}

/* Responsive Adjustments */
@media (max-width: 1100px) {
	.skills-container {
		grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
	}
}

@media (max-width: 900px) {
	.section-title h2 {
		font-size: 2.8rem;
		/* Adjusted for smaller desktops */
		white-space: normal;
		/* allow text to wrap */
		word-break: break-word;
		/* optional: break long words */
		line-height: 1.2;
		/* improve spacing between lines */
		text-align: center;
		/* optional: center for better UX on small screens */

	}


	.skills-container {
		grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
	}

	.card-header {
		padding: 20px 25px;
	}

	.skills-list {
		padding: 25px;
	}
}

@media (max-width: 768px) {
	body {
		padding: 60px 15px;
		/* Adjust body padding for smaller screens */
	}

	.section-title {
		margin-bottom: 40px;
	}

	.section-title h2 {
		font-size: 2.2rem;
	}

	.section-title h2::after {
		width: 80px;
	}

	.skills-container {
		grid-template-columns: 1fr;
	}

	.card-header h3 {
		font-size: 20px;
	}

	.skills-list li {
		padding: 8px 16px;
		font-size: 14px;
	}
}

@media (max-width: 480px) {
	.section-title h2 {
		font-size: 1.8rem;
	}

	.section-title h2::after {
		width: 60px;
		bottom: -10px;
	}

	.card-header {
		padding: 18px 20px;
	}

	.skills-list {
		padding: 20px;
		gap: 10px;
	}
}

/*--------------------------------------------------------------
# Resume
--------------------------------------------------------------*/
.resume .resume-title {
	font-size: 26px;
	font-weight: 700;
	margin-top: 20px;
	margin-bottom: 20px;
	color: #fff;
}

.resume .resume-item {
	padding: 0 0 20px 20px;
	margin-top: -2px;
	border-left: 2px solid rgba(255, 255, 255, 0.2);
	position: relative;
}

.resume .resume-item h4 {
	line-height: 18px;
	font-size: 18px;
	font-weight: 600;
	text-transform: uppercase;
	font-family: "Poppins", sans-serif;
	color: #1c7d32;
	margin-bottom: 10px;
}

.resume .resume-item h5 {
	font-size: 16px;
	background: rgba(255, 255, 255, 0.15);
	padding: 5px 15px;
	display: inline-block;
	font-weight: 600;
	margin-bottom: 10px;
}

.resume .resume-item ul {
	padding-left: 20px;
}

.resume .resume-item ul li {
	padding-bottom: 10px;
}

.resume .resume-item:last-child {
	padding-bottom: 0;
}

.resume .resume-item::before {
	content: "";
	position: absolute;
	width: 16px;
	height: 16px;
	border-radius: 50px;
	left: -9px;
	top: 0;
	background: #9e7f25;
	border: 2px solid #9e7f25;
}

/* Import a modern and professional font pairing */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@500;600;700&family=Source+Sans+Pro:wght@400;600&display=swap');
/* Import icon font for contact details */
@import url('https://cdn.jsdelivr.net/npm/icofont@1.0.0/dist/icofont.min.css');

:root {
	--primary-bg: #1a202c;
	--secondary-bg: #2d3748;
	--accent-green: #12d640;
	--text-primary: #e2e8f0;
	--text-secondary: #a0aec0;
	--text-meta: #718096;
	--text-accent: #ffffff;
	--border-color: #4a5568;
}

#resume-paper-container {
	background: var(--primary-bg);
	margin: 0 auto;
	max-width: 950px;
	border-radius: 12px;
	box-shadow: 0 25px 60px -12px rgba(0, 0, 0, 0.5);
	font-family: 'Source Sans Pro', sans-serif;
	color: var(--text-secondary);
	overflow: hidden;
	opacity: 0;
	animation: fadeIn 0.8s 0.2s ease-out forwards;
}

.resume-grid {
	display: grid;
	grid-template-columns: 1fr;
}

@media(min-width: 768px) {
	.resume-grid {
		grid-template-columns: 3.8fr 6.2fr;
	}
}

.resume-left-panel {
	padding: 2.5rem;
	background: var(--secondary-bg);
}

.profile-picture {
	width: 140px;
	height: 140px;
	border-radius: 50%;
	border: 4px solid var(--accent-green);
	margin: 0 auto 1.5rem;
	display: block;
	object-fit: cover;
}

.profile-header h1 {
	font-family: 'Poppins', sans-serif;
	font-size: 2.1rem;
	font-weight: 700;
	color: var(--text-accent);
	line-height: 1.2;
	margin: 0;
	text-align: center;
}

.profile-header h2 {
	font-family: 'Poppins', sans-serif;
	font-size: 1.1rem;
	font-weight: 500;
	color: var(--accent-green);
	margin-top: 0.25rem;
	margin-bottom: 2.5rem;
	text-align: center;
}

.left-panel-section h3 {
	font-family: 'Poppins', sans-serif;
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--text-accent);
	margin: 0 0 1rem 0;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--border-color);
}

.contact-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.contact-list li {
	margin-bottom: 0.5rem;
}

.contact-list a {
	display: flex;
	align-items: center;
	text-decoration: none;
	color: var(--text-secondary);
	padding: 0.3rem;
	border-radius: 6px;
	transition: background-color 0.3s;
}

.contact-list a:hover {
	background-color: var(--border-color);
}

.contact-list a:hover span {
	color: var(--text-accent);
}

.contact-list .icon-container {
	width: 32px;
	height: 32px;
	min-width: 32px;
	border-radius: 50%;
	background-color: var(--accent-green);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-right: 0.75rem;
	transition: transform 0.3s;
}

.contact-list a:hover .icon-container {
	transform: scale(1.1);
}

.contact-list i,
.contact-list svg {
	font-size: 1rem;
	color: var(--primary-bg);
}

.contact-list .icon-container svg {
	width: 18px;
	height: 18px;
	fill: var(--primary-bg);
}

.contact-list span {
	font-weight: 500;
	font-size: 0.9rem;
	line-height: 1.4;
	transition: color 0.3s;
	word-break: break-all;
}

/* --- Custom Email Me Form --- */
.custom-email-container {
	margin-top: 30px;
}

.custom-email-form {
	padding: 30px;
	background: #09203a;
	border-radius: 15px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 0 1px 5px rgba(0, 0, 0, 0.2);
	position: relative;
	z-index: 1;
}

.custom-email-form .form-group {
	margin-bottom: 20px;
}

.custom-email-form input,
.custom-email-form textarea {
	color: #fff !important;
	/* force full white text */
	background: rgba(255, 255, 255, 0.15);
	/* bump up opacity for better contrast */
	border: 1px solid rgba(255, 255, 255, 0.35);
	/* make border more visible */
	border-radius: 4px;
	box-shadow: none;
	font-size: 14px;
	transition: all 0.3s ease;
	width: 100%;
	padding: 15px 18px;
	outline: none;
	opacity: 1;
}

.custom-email-form textarea {
	padding: 12px 18px;
}

.custom-email-form input:focus,
.custom-email-form textarea:focus {
	background-color: rgba(18, 214, 64, 0.15);
	/* subtle greenish glow background on focus */
	border-color: #12d640;
	/* keep that green border */
	box-shadow: 0 0 6px 2px rgba(18, 214, 64, 0.5);
}

.custom-email-form input::placeholder,
.custom-email-form textarea::placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.custom-email-form button[type="submit"] {
	background: #1c7d32;
	border: 0;
	padding: 10px 30px;
	color: #fff;
	transition: all 0.4s ease;
	border-radius: 4px;
	font-weight: 600;
	letter-spacing: 1px;
	text-transform: uppercase;
	cursor: pointer;
	position: relative;
	overflow: hidden;
	z-index: 1;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

.custom-email-form button[type="submit"]:hover {
	background: #15bb62;
	transform: scale(1.02);
	box-shadow: 0 6px 15px rgba(0, 0, 0, 0.6), 0 0 20px rgba(18, 214, 64, 0.7);
}

.custom-email-form button[type="submit"]::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 0;
	height: 0;
	background: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	opacity: 0;
	transition: width 0.4s ease-in-out, height 0.4s ease-in-out, opacity 0.4s ease-in-out;
	z-index: 0;
}

.custom-email-form button[type="submit"]:hover::before {
	width: 200%;
	height: 200%;
	opacity: 1;
}

.custom-email-form button[type="submit"] span {
	position: relative;
	z-index: 1;
}

.custom-email-form .loading,
.custom-email-form .error-message,
.custom-email-form .sent-message {
	display: none;
	color: #fff;
	text-align: center;
	padding: 15px;
	font-weight: 600;
	border-radius: 4px;
	margin: 15px 0;
}

.custom-email-form .loading {
	background: rgba(255, 255, 255, 0.08);
}

.custom-email-form .error-message {
	background: #ed3c0d;
	color: #fff !important;
	/* force full white text */

}

.custom-email-form .sent-message {
	background: #1c7d32;
	color: #fff !important;
	/* force full white text */

}

.custom-email-form .loading:before {
	content: "";
	display: inline-block;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: 0 10px -6px 0;
	border: 3px solid #1c7d32;
	border-top-color: #eee;
	animation: animate-loading 1s linear infinite;
}

@keyframes animate-loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}


.left-panel-section {
	margin-bottom: 2.5rem;
}

.left-panel-section:last-child {
	margin-bottom: 0;
}

.skills-category {
	margin-bottom: 1rem;
}

.skills-category:last-child {
	margin-bottom: 0;
}

.skills-category h4 {
	font-family: 'Poppins', sans-serif;
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--text-primary);
	margin: 0 0 0.75rem 0;
}

.skill-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.skill-tag {
	background-color: var(--border-color);
	color: var(--text-primary);
	padding: 0.3rem 0.75rem;
	border-radius: 5px;
	font-size: 0.85rem;
	font-weight: 500;
	transition: all 0.2s ease-in-out;
}

.skill-tag:hover {
	background-color: var(--accent-green);
	color: var(--primary-bg);
	transform: translateY(-2px);
}

.resume-right-panel {
	padding: 2.5rem;
}

/* This is the key change: these are now divs so they don't conflict with your main template's section styles */
.right-panel-section {
	margin-bottom: 2.5rem;
}

.right-panel-section:last-child {
	margin-bottom: 0;
}

.right-panel-section-header {
	font-family: 'Poppins', sans-serif;
	font-size: 1.6rem;
	color: var(--text-accent);
	font-weight: 600;
	margin: 0 0 1.5rem 0;
	position: relative;
	padding-left: 1.25rem;
}

.right-panel-section-header::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	height: 90%;
	width: 5px;
	background-color: var(--accent-green);
	border-radius: 5px;
}

.professional-summary p {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--text-primary);
	margin-top: -0.5rem;
}

.timeline {
	position: relative;
	border-left: 2px solid var(--secondary-bg);
}

.timeline-item {
	position: relative;
	padding: 1.25rem;
	margin-left: 1rem;
	margin-bottom: 1.5rem;
	border-radius: 8px;
	transition: background-color 0.3s, transform 0.3s, box-shadow 0.3s;
	opacity: 0;
	animation: slideIn 0.6s ease-out forwards;
}

.timeline-item:hover {
	background-color: var(--secondary-bg);
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}

.timeline-item:last-child {
	margin-bottom: 0;
}

.timeline-item::before {
	content: '';
	position: absolute;
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: var(--accent-green);
	border: 3px solid var(--primary-bg);
	z-index: 1;
	top: 1.4rem;
	left: -1rem;
	transform: translateX(-50%);
}

.timeline-subheader-container {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.timeline-subheader {
	font-size: 1.15rem;
	font-weight: 600;
	color: var(--text-primary);
	line-height: 1.3;
	margin: 0;
}

.project-link-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.project-link-icon svg {
	width: 1.1rem;
	height: 1.1rem;
	fill: var(--text-secondary);
	transition: fill 0.3s, transform 0.3s;
}

.project-link-icon:hover svg {
	fill: var(--accent-green);
	transform: scale(1.1);
}

.timeline-meta {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--text-meta);
	margin-bottom: 0.75rem;
	margin-top: 0.15rem;
}

.timeline-meta span {
	color: var(--text-secondary);
	font-weight: 400;
}

.timeline-content ul {
	list-style: none;
	padding-left: 0;
	margin: 0;
}

.timeline-content li {
	position: relative;
	padding-left: 1.25rem;
	margin-bottom: 0.5rem;
	font-size: 0.95rem;
	line-height: 1.6;
}

.timeline-content li::before {
	content: '•';
	position: absolute;
	left: 0;
	top: 0;
	color: var(--accent-green);
}

.timeline-content p {
	margin: 0.5rem 0;
	font-size: 0.95rem;
	line-height: 1.6;
}

.coursework-list {
	margin-top: 0.75rem !important;
}

.coursework-list li {
	font-size: 0.9rem;
	color: #8f9ca9;
}

@keyframes fadeIn {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes slideIn {
	from {
		opacity: 0;
		transform: translateX(-20px);
	}

	to {
		opacity: 1;
		transform: translateX(0);
	}
}

.timeline-item:nth-child(1) {
	animation-delay: 0.3s;
}

.timeline-item:nth-child(2) {
	animation-delay: 0.4s;
}

.timeline-item:nth-child(3) {
	animation-delay: 0.5s;
}

.timeline-item:nth-child(4) {
	animation-delay: 0.6s;
}

.timeline-item:nth-child(5) {
	animation-delay: 0.7s;
}

/*--------------------------------------------------------------
# Services
--------------------------------------------------------------*/
.services .icon-box {
	text-align: center;
	background: #09203a;
	padding: 40px 40px;
	transition: all ease-in-out 0.3s;
	margin: 10px
}

.services .icon-box .icon {
	margin: 0 auto;
	width: 64px;
	height: 64px;
	background: #1c7d32;
	border-radius: 5px;
	transition: all .3s ease-out 0s;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	transform-style: preserve-3d;
}

.services .icon-box .icon i {
	color: #fff;
	font-size: 28px;
}

.services .icon-box .icon::before {
	position: absolute;
	content: '';
	left: -8px;
	top: -8px;
	height: 100%;
	width: 100%;
	background: rgba(255, 255, 255, 0.15);
	border-radius: 5px;
	transition: all .3s ease-out 0s;
	transform: translateZ(-1px);
}

.services .icon-box h4 {
	font-weight: 700;
	margin-bottom: 15px;
	font-size: 24px;
}

.services .icon-box h4 a {
	color: #fff;
}

.services .icon-box p {
	line-height: 24px;
	font-size: 14px;
	margin-bottom: 0;
}

.services .icon-box:hover {
	background: #042e5f;
	border-color: #1c7d32;
}

.services .icon-box:hover .icon {
	background: #fff;
}

.services .icon-box:hover .icon i {
	color: #1c7d32;
}

.services .icon-box:hover .icon::before {
	background: #35e888;
}

.services .icon-box:hover h4 a,
.services .icon-box:hover p {
	color: #12d640;
}


/*--------------------------------------------------------------
# Education & Certifications Section
--------------------------------------------------------------*/

/* Main container for the certification card */
.certification-card {
	background-color: #1a2a3a;
	/* Matching your skills card background */
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	/* Added border-color to the transition for a smoother effect */
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.certification-card:hover {
	transform: translateY(-8px);
	/* --- THE FIX --- */
	/* Switched to a subtle blue glow that matches the background theme */
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35), 0 0 25px rgba(0, 162, 255, 0.5);
	border-color: #00a2ff;
	/* Using a blue accent color found elsewhere in your theme */
}

/* Container for the image to handle aspect ratio */
.certification-img-container {
	aspect-ratio: 16 / 9;
	background-color: #ffffff;
	/* White background for logos */
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 1rem;
	overflow: hidden;
}

.certification-img-container img {
	object-fit: contain;
	max-width: 100%;
	max-height: 100%;
	transition: transform 0.4s ease;
}

.certification-card:hover .certification-img-container img {
	transform: scale(1.05);
}

/* Styling for the content area of the card */
.certification-content {
	padding: 25px;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	justify-content: space-between;
}

.certification-content h4 {
	font-family: "Poppins", sans-serif;
	color: #fff;
	font-size: 20px;
	font-weight: 600;
}

.certification-content p {
	color: #a0aec0;
	font-size: 14px;
	margin-bottom: 20px;
}

/* The "View" button still uses the primary green on hover, maintaining a consistent call-to-action color */
.certification-content .btn-view-cert {
	display: inline-block;
	background-color: transparent;
	border: 2px solid #1c7d32;
	color: #fff;
	padding: 8px 20px;
	border-radius: 50px;
	text-align: center;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 14px;
	transition: all 0.3s ease;
	align-self: flex-start;
}

.certification-content .btn-view-cert:hover {
	background-color: #1c7d32;
	color: #fff;
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: 0 4px 10px rgba(18, 214, 64, 0.3);
}

/*--------------------------------------------------------------
# Portfolio 
--------------------------------------------------------------*/
.portfolio #portfolio-flters {
	padding: 0;
	margin: 0 auto 40px auto;
	list-style: none;
	text-align: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 15px;
}

.portfolio #portfolio-flters li {
	cursor: pointer;
	padding: 12px 25px;
	font-size: 15px;
	font-weight: 600;
	text-transform: uppercase;
	color: #fff;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 50px;
	transition: all 0.3s ease-in-out;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
}

/* UPDATED: Filter hover/active state is now the signature green */
.portfolio #portfolio-flters li:hover,
.portfolio #portfolio-flters li.filter-active {
	background: #12d640;
	border-color: #12d640;
	color: #010e1b;
	/* Dark text for high contrast on green button */
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(18, 214, 64, 0.4);
}

/* --- Project Card --- */
.portfolio .portfolio-item {
	margin-bottom: 30px;
}

.portfolio .project-card {
	background-color: #1a2a3a;
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
}

/* UPDATED: Hover effect is now the signature green glow */
.portfolio .project-card:hover {
	transform: translateY(-8px);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.35), 0 0 25px rgba(18, 214, 64, 0.5);
	border-color: #12d640;
}

/* --- Card Image --- */
.portfolio .project-image {
	overflow: hidden;
	aspect-ratio: 16 / 9;
}

.portfolio .project-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

/* Image zoom effect is disabled */
.portfolio .project-card:hover .project-image img {
	transform: scale(1);
}

/* --- Card Content --- */
.portfolio .project-content {
	padding: 25px;
	display: flex;
	flex-direction: column;
	flex-grow: 1;
	text-align: left;
}

.portfolio .project-title-card {
	font-family: "Poppins", sans-serif;
	color: #fff;
	font-size: 20px;
	font-weight: 600;
	margin-bottom: 8px;
}

.portfolio .project-category {
	color: #a0aec0;
	font-size: 14px;
	margin-bottom: 20px;
}

/* --- Details Button (Styled with Green Theme) --- */
.portfolio .project-details-btn {
	display: inline-block;
	background-color: transparent;
	border: 2px solid #1c7d32;
	/* Using theme's darker green */
	color: #fff;
	padding: 8px 20px;
	border-radius: 50px;
	text-align: center;
	text-transform: uppercase;
	font-weight: 600;
	font-size: 14px;
	transition: all 0.3s ease;
	align-self: flex-start;
	margin-top: auto;
	text-decoration: none;
}

.portfolio .project-details-btn:hover {
	background-color: #1c7d32;
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(18, 214, 64, 0.3);
}

/* Cleanup old/unused styles */
.portfolio .portfolio-wrap,
.portfolio .project-title {
	display: none;
}


/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact .info-box {
	color: #444444;
	padding: 20px;
	width: 100%;
	background: #09203a;
}

.contact .info-box i.bx {
	font-size: 24px;
	color: #dee2e6;
	border-radius: 50%;
	padding: 14px;
	float: left;
	background: rgba(255, 255, 255, 0.1);
}

.contact .info-box h3 {
	font-size: 20px;
	color: #28a745;
	font-weight: 700;
	margin: 10px 0 8px 68px;
}

.contact .info-box p {
	padding: 0;
	color: #fff;
	line-height: 24px;
	font-size: 14px;
	margin: 0 0 0 68px;
}

.contact .info-box .social-links {
	margin: 5px 0 0 68px;
	display: flex;
}

.contact .info-box .social-links a {
	font-size: 18px;
	display: inline-block;
	color: #fff;
	line-height: 1;
	margin-right: 12px;
	transition: 0.3s;
}

.contact .info-box .social-links a:hover {
	color: #12d640;
}

.contact .php-email-form {
	padding: 30px;
	background: rgba(255, 255, 255, 0.08);
}

.contact .php-email-form .validate {
	display: none;
	color: red;
	margin: 0 0 15px 0;
	font-weight: 400;
	font-size: 13px;
}

.contact .php-email-form .error-message {
	display: none;
	background: rgba(255, 255, 255, 0.08);
	background: #ed3c0d;
	text-align: center;
	padding: 15px;
	font-weight: 600;
}

.contact .php-email-form .sent-message {
	display: none;
	background: rgba(255, 255, 255, 0.08);
	background: #1c7d32;
	text-align: center;
	padding: 15px;
	font-weight: 600;
}

.contact .php-email-form .loading {
	display: none;
	background: rgba(255, 255, 255, 0.08);
	text-align: center;
	padding: 15px;
}

.contact .php-email-form .loading:before {
	content: "";
	display: inline-block;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: 0 10px -6px 0;
	border: 3px solid #1c7d32;
	border-top-color: #eee;
	-webkit-animation: animate-loading 1s linear infinite;
	animation: animate-loading 1s linear infinite;
}

.contact .php-email-form input,
.contact .php-email-form textarea {
	border-radius: 0;
	box-shadow: none;
	font-size: 14px;
	background: rgba(255, 255, 255, 0.08);
	border: 0;
	transition: 0.3s;
	color: #fff;
}

.contact .php-email-form input:focus,
.contact .php-email-form textarea:focus {
	background-color: rgba(255, 255, 255, 0.11);
}

.contact .php-email-form input::-webkit-input-placeholder,
.contact .php-email-form textarea::-webkit-input-placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.contact .php-email-form input::-moz-placeholder,
.contact .php-email-form textarea::-moz-placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.contact .php-email-form input:-ms-input-placeholder,
.contact .php-email-form textarea:-ms-input-placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.contact .php-email-form input::-ms-input-placeholder,
.contact .php-email-form textarea::-ms-input-placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.contact .php-email-form input::placeholder,
.contact .php-email-form textarea::placeholder {
	color: rgba(255, 255, 255, 0.3);
	opacity: 1;
}

.contact .php-email-form input {
	padding: 20px 15px;
}

.contact .php-email-form textarea {
	padding: 12px 15px;
}

.contact .php-email-form button[type="submit"] {
	background: #1c7d32;
	border: 0;
	padding: 10px 30px;
	color: #fff;
	transition: 0.4s;
	border-radius: 4px;
}

.contact .php-email-form button[type="submit"]:hover {
	background: #15bb62;
}

@-webkit-keyframes animate-loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

@keyframes animate-loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

/*--------------------------------------------------------------
# Credits
--------------------------------------------------------------*/
.credits {
	position: fixed;
	right: 15px;
	bottom: 15px;
	font-size: 13px;
	color: #fff;
	z-index: 1;
}

.credits a {
	color: #1c7d32;
	transition: 0.3s;
}

.credits a:hover {
	color: #fff;
}

@media (max-width: 992px) {
	.credits {
		left: 50%;
		right: 0;
		transform: translateX(-50%);
	}
}

/* =================================================================
   FEATURE TOGGLE SYSTEM - DYNAMIC SHOW/HIDE
   ================================================================= */

/* Hide chatbot when disabled */
body.chatbot-disabled #ai-chatbot-button,
body.chatbot-disabled #ai-chatbot-window,
body.chatbot-disabled .ai-chatbot-button,
body.chatbot-disabled .ai-chatbot-window {
	display: none !important;
	visibility: hidden !important;
}

/* Hide contact form when disabled - maintain layout spacing */
body.messaging-disabled .custom-email-container {
	opacity: 0 !important;
	visibility: hidden !important;
	height: 0 !important;
	overflow: hidden !important;
	margin: 0 !important;
	padding: 0 !important;
	transition: all 0.3s ease !important;
}

/* When messaging is enabled, ensure proper display */
body:not(.messaging-disabled) .custom-email-container {
	opacity: 1;
	visibility: visible;
	height: auto;
	overflow: visible;
	transition: all 0.3s ease;
}

/* Hide individual form elements for extra safety */
body.messaging-disabled #contact-form,
body.messaging-disabled .custom-email-form {
	display: none !important;
}