/* ========== CLICKTOTALENT DESIGN SYSTEM (FIGMA 1331:795) ========== */

@import url('../fonts/inter.css');
@import url('../fonts/gabarito.css');
@import url('../fonts/poppins.css');

:root {
	/* Brand Colors */
	--ctt-primary: #004B69;
	--ctt-primary-light: #1F87B1;
	--ctt-secondary: #03A1E0;
	/* Cyan button */
	--ctt-accent: #AA8524;
	/* Gold in AI gradient */

	/* Neutral Colors */
	--ctt-bg-main: #FFF6F6;
	--ctt-bg-section: #F5F7FA;
	--ctt-bg-ai: rgba(245, 247, 250, 0.61);
	--ctt-text-dark: #4D4D4D;
	--ctt-text-white: #FFFFFF;
	--ctt-text-muted: #717171;
	--ctt-text-gray: #455A64;
	--ctt-border-blue: rgba(4, 73, 152, 0.72);

	/* Typography Tokens */
	--ctt-font-main: 'Inter', sans-serif;
	--ctt-font-title: 'Poppins', sans-serif;
	--ctt-font-job: 'Gabarito', sans-serif;

	/* Spacing & Layout */
	--ctt-container-width: 1440px;
}

/* ========== BASE STYLES ========== */
body {
	background-color: var(--ctt-bg-main);
	color: var(--ctt-text-dark);
	font-family: var(--ctt-font-main);
	overflow-x: hidden;
}

.ctt-header-logo-text {
	color: var(--ctt-primary);
	font-family: var(--ctt-font-main);
}

.default_text {
	color: var(--ctt-primary);
}

.ctt-nav-link {
	color: var(--ctt-primary);
	font-size: 14px;
	font-family: var(--ctt-font-main);
	/* text-decoration: none; */
}


/* ========== TYPOGRAPHY PRESETS ========== */

.ctt-hero-title {
	font-family: var(--ctt-font-title);
	/* Inter */
	font-size: 70px;
	line-height: 76px;
	color: var(--ctt-text-white);
	/* Fixed to white for contrast on dark blue */
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

@media (min-width:1200px) {
	.job_actions {
		flex-direction: column;
		align-items: flex-end;
		min-height: 120px;
		gap: 1rem;
		width: auto !important;
	}
}

@media (min-width:992px) {
	.job_actions {
		width: 100%;
	}
}

@media (max-width: 991px) {
	.job_actions {
		width: 100%;
		flex-direction: row;
		align-items: center;
		gap: 1rem;
	}
}

@media (max-width: 767px) {
	#user_profiles_container {
		padding-right: 5px;
		/* Reduce padding on mobile */
	}

	.ctt-job-card {
		padding: 1.25rem;
		/* Slightly reduced padding */
	}
}

@media (max-width: 991px) {
	.ctt-hero-title {
		font-size: 52px;
		line-height: 58px;
	}

	.ctt-section-title {
		font-size: 32px;
		line-height: 40px;
	}

	.ctt-ai-pill {
		padding: 16px 20px !important
	}
}

@media (max-width: 767px) {
	.ctt-hero-title {
		font-size: 36px;
		line-height: 42px;
	}

	.ctt-section-title {
		font-size: 25px !important;
		line-height: 34px !important;
	}

	.ctt-subtitle {
		font-size: 16px;
		line-height: 22px;
	}
}



.ctt-section-title {
	font-family: var(--ctt-font-title);
	font-size: 36px;
	line-height: 44px;
	/* font-weight: 600; */
	color: var(--ctt-primary);
}

.ctt-subtitle {
	font-family: var(--ctt-font-title);
	font-size: 18px;
	line-height: 24px;
	color: var(--ctt-text-white);
}


.ctt-job-meta {
	font-family: var(--ctt-font-job);
	font-size: 16px;
	/* font-weight: 700; */
	color: #8B8D8D;
}

/* ========== UTILITIES & OVERRIDES ========== */
/* Backgrounds */
.bg-main {
	background-color: var(--ctt-bg-main) !important;
}

.bg-section {
	background-color: var(--ctt-bg-section) !important;
}

.bg-ai-light {
	background-color: var(--ctt-bg-ai) !important;
}

/* Typography */
.fs-16 {
	font-size: 16px !important;
}

.font-inter {
	font-family: 'Inter', sans-serif !important;
}

.ctt-hero-min-height {
	min-height: 550px;
}

.mt-n2 {
	margin-top: -8px;
}

.ctt-hero-paragraph-width {
	max-width: 657px;
}

.ctt-hero-overlay-height {
	height: 200px;
}

.ctt-trusted-title {
	font-size: 20px;
	color: var(--ctt-primary);
	opacity: 0.8;
}

.ctt-trusted-meta {
	font-family: var(--ctt-font-main);
	/* color: var(--ctt-text-gray); */
	font-size: 14px;
	/* font-weight: 400; */
}

@media (min-width:1200px) {
	.ctt-dashboard-preview {
		width: 1039px;
	}
}

.ctt-dashboard-max-width {
	max-width: 1039px;
}

.ctt-ai-paragraph {
	font-size: 14px;
	line-height: 1.6;
}

.border-primary-custom {
	border-color: var(--ctt-primary) !important;
}

.z-2 {
	z-index: 2 !important;
}

.z-1 {
	z-index: 1 !important;
}


/* Seeker Section */
.ctt-seeker-img {
	height: 272px;
	/* width: 100%; */
	max-width: 350px;
	/* object-fit: cover; */
}

.ctt-seeker-p {
	font-size: 14px;
	opacity: 0.9;
}


.fs-14 {
	font-size: 14px !important;
}

.fs-15 {
	font-size: 15px !important;
}

.fs-20 {
	font-size: 20px !important;
}

/* Footer Section */


.bg-primary-custom {
	background-color: var(--ctt-primary) !important;
}

.ctt-footer-p {
	font-size: 14px;
	opacity: 0.8;
}

.ctt-social-icon {
	width: 32px;
	height: 32px;
	background-color: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	padding: 8px;
	/* display: flex; */
	/* text-decoration: none; */
}

.ctt-footer-list {
	font-size: 14px;
	opacity: 0.8;
}

.ctt-footer-input {
	border-radius: 8px 0 0 8px !important;
	padding: 12px 20px !important;
}

.ctt-footer-input-btn {
	border-radius: 0 8px 8px 0 !important;
}


/* ========== GRADIENTS ========== */

.ctt-gradient-hero {
	background: linear-gradient(360deg, rgba(80, 136, 188, 0) 0%, rgba(24, 74, 104, 0.542857) 37.98%, #004B69 90.87%);
}


.ctt-gradient-overlay {
	background: linear-gradient(180deg, rgba(80, 136, 188, 0) 0%, var(--ctt-bg-main) 100%);
}

.ctt-gradient-jobseeker {
	background: linear-gradient(90deg, #1F87B1 0%, #004B69 100%);
}

.ctt-gradient-card {
	background: linear-gradient(180deg, #FFFFFF 0%, #E8ECF1 100%);
}

.ctt-gradient-text-ai {
	background: linear-gradient(90deg, var(--ctt-primary) 0%, #AA8524 80%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* ========== COMPONENTS ========== */

/* Header */
.ctt-header {
	height: 84px;
	background-color: var(--ctt-bg-section);
	position: relative;
	z-index: 1000;
}

.ctt-header-login {
	color: var(--ctt-primary);
	font-size: 14px;
	font-family: var(--ctt-font-main);
	transition: color 0.3s ease;
}

.ctt-header-login:hover {
	color: var(--ctt-secondary);
}

.ctt-nav-link {
	color: var(--ctt-primary);
	font-size: 14px;
	font-family: var(--ctt-font-main);
	text-decoration: none;
	transition: all 0.3s ease;
}

.ctt-nav-link:hover {
	color: var(--ctt-secondary);
}


/* Buttons */
.ctt-btn-primary {
	background-color: var(--ctt-primary);
	color: white;
	border-radius: 30px;
	padding: 12px 32px;
	font-weight: 500;
	border: none;
	transition: all 0.3s ease;
	text-decoration: none;
	display: inline-block;
}

.ctt-nav-link:hover,
.ctt-btn-white:hover {
	transform: translateY(-2px);
}

.ctt-btn-primary:hover {
	background-color: var(--ctt-primary-light);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 75, 105, 0.2);
	color: white;
}

.ctt-btn-cyan {
	background-color: var(--ctt-secondary);
	color: white;
	border-radius: 30px;
	padding: 14px 48px 14px 32px;
	/* Reserve space on the right for the arrow */
	font-weight: 500;
	border: none;
	transition: all 0.3s ease;
	text-decoration: none;
	/* display: inline-flex; */
	/* align-items: center; */
	position: relative;
	/* Base for absolute positioning */
}

.ctt-btn-cyan:hover {
	background-color: #028ac1;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(3, 161, 224, 0.3);
	color: white;
}

.lstGetStarted:hover {
	background-color: #03A1E0 !important;
}

.ctt-btn-cyan img,
.ctt-btn-white img,
.ctt-btn-primary img {
	position: absolute;
	right: 25px;
	/* Positioned within the reserved padding */
	opacity: 0;
	transform: translateX(-10px);
	transition: all 0.3s ease;
}

.ctt-btn-cyan:hover img,
.ctt-btn-white:hover img,
.ctt-btn-primary:hover img {
	opacity: 1;
	transform: translateX(0);
}

.ctt-btn-ai {
	background: #004B69;
	padding: 12px 32px;
	border-radius: 30px;
	overflow: hidden;
	transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s;
	border: unset;
	color: #fff;
	position: relative;
	z-index: 1;
}

.ctt-btn-ai::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, #004B69 0%, #0094CF 100%);
	opacity: 0;
	transition: opacity 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
	z-index: -1;
}

.ctt-btn-ai:hover {
	box-shadow: 0 10px 20px rgba(0, 75, 105, 0.3);
	color: #fff;
}

.ctt-btn-ai:hover::before {
	opacity: 1;
}


.ctt-btn-white {
	background-color: white;
	color: var(--ctt-primary);
	border-radius: 30px;
	padding: 14px 32px;
	font-weight: 500;
	transition: all 0.3s ease;
	text-decoration: none;
	display: inline-block;
	border: 1px solid #fff;
	position: relative;
}

.ctt-btn-white:hover {
	background-color: #f8f9fa;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(255, 255, 255, 0.2);
	color: var(--ctt-primary);
}

.ctt-btn-white-started:hover {
	background-color: #f8f9fa;
	color: var(--ctt-primary);
	/* border and box-shadow removed as per user request */
}

/* Tabs */
.ctt-tabs-container {
	width: 1053px;
	max-width: 95%;
	border: 1px solid var(--ctt-border-blue);
	border-radius: 35px;
	padding: 4px;
	display: flex;
	justify-content: space-between;
	overflow-x: auto;
	-ms-overflow-style: none;
	scrollbar-width: none;
}

.ctt-tabs-container::-webkit-scrollbar {
	display: none;
}

@media (max-width: 991px) {
	.ctt-tabs-container {
		gap: 10px;
	}

	.ctt-tab-btn {
		font-size: 14px;
		padding: 10px 20px;
		white-space: nowrap;
	}
}


.ctt-tab-btn {
	border-radius: 35px;
	border: none;
	background: transparent;
	color: var(--ctt-primary);
	padding: 12px 24px;
	font-family: var(--ctt-font-title);
	font-weight: 500;
	transition: all 0.3s ease;
}

.ctt-tab-btn:hover:not(.active) {
	background-color: rgba(0, 75, 105, 0.05);
}

.ctt-tab-btn.active {
	background-color: var(--ctt-primary);
	color: white;
}

/* Utilities */
.tracking-tight {
	letter-spacing: -0.025em;
}

.tracking-tighter {
	letter-spacing: -0.05em;
}

/* Dashboard Card */
.ctt-dashboard-preview {
	border: 2px solid var(--ctt-primary);
	border-radius: 19px;
	overflow: hidden;

	transition: all 0.3s ease;
}

.ctt-dashboard-preview-gradient {
	background: linear-gradient(180deg, #FFFFFF 0%, #E8ECF1 100%);

}

.ctt-tab-content-title {
	font-size: 20px;
	color: var(--ctt-primary);
}

.ctt-tab-content-text {
	font-family: var(--ctt-font-main);
	font-size: 16px;
	line-height: 27px;
	color: var(--ctt-primary);
}


.ctt-tab-content-list {
	font-size: 14px;
	color: var(--ctt-primary);
}

.ctt-grayscale:hover {
	filter: grayscale(0);
	opacity: 1;
}

/* AI Feature Pills */
.ctt-ai-pill {
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid #DCF2FF;
	/* Border as inset shadow */
	border-radius: 100px;
	padding: 16px 40px;
	color: #000 !important;
	/* Darker default text */
	transition: all 0.3s ease;
	cursor: pointer;
	/* display: block; */
	width: 100%;
	margin-bottom: 12px;
	/* text-align: left; */
	backdrop-filter: blur(8px);
}

p.opportunities {
	color: #18191F;
}

span.count {
	color: #717171;
}

.ctt-ai-pill:hover {
	background: linear-gradient(90deg, #0381B4 0%, #004B69 100%);
	color: white !important;
	border: 1px solid #004B69;
	box-shadow: 0px 4px 4px 0px #00000040;
}

.ctt-ai-pill span {
	font-size: 14px;
}

.ctt-grayscale:hover {
	filter: grayscale(0);
	opacity: 1;
}

/* Figma Job Card Refinements */
.ctt-job-card {
	background: #FFFFFF;
	border-radius: 16px;
	padding: 15px 20px;
	position: relative;
	transition: all 0.3s ease;
	font-family: var(--ctt-font-job);
}

.ctt-job-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	transform: translateY(-2px);
}

.ctt-job-id {
	position: absolute;
	top: 10px;
	left: 24px;
	font-size: 15px;
	color: #000;
}

.ctt-job-logo-box {
	width: 86px;
	height: 86px;
	background: #FFFFFF;
	border: 1px solid #8B8D8D;
	border-radius: 3px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 15px;
}

.ctt-job-date {
	font-size: 14px;
	color: #B4B6B7;
	margin-top: 8px;
}

.ctt-job-title {
	color: #004B69;
	font-size: 20px;
	/* font-weight: 600; */
	margin-bottom: 4px;

}

.ctt-posted-by {
	font-size: 14px;
	color: #616161;
	margin-bottom: 15px;
}

.ctt-job-meta-item {
	/* display: flex; */
	/* align-items: center; */
	/* gap: 8px; */
	color: #8B8D8D;
	font-size: 14px;
	font-weight: 500;
}

.ctt-job-meta-item img {
	width: 17px;
	height: 17px;
}

.ctt-job-meta-item span {
	color: #8B8D8D;
}

.ctt-btn-view {
	background: #004B69;
	color: #FFFFFF !important;
	border-radius: 5px;
	padding: 5px 10px;
	font-size: 18px;
	font-weight: 500;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	transition: background 0.3s;
	position: absolute;
	top: 15px;
	right: 19px;
}

.ctt-btn-view:hover {
	background: #003850;
}

.ctt-share-link {
	color: #000000;
	font-size: 15px;
	font-weight: 400;
	position: absolute;
	bottom: 15px;
	right: 20px;
	/* text-decoration: none; */
	/* display: inline-flex; */
	/* align-items: center; */
	/* gap: 8px; */
}

@media (min-width:450px) and (max-width:768px) {
	.ctt-job-title {
		max-width: 72%;
	}
}

@media (min-width:450px) and (max-width:991px) {

	.ctt-job-title,
	.ctt-job-date,
	.ctt-posted-by {
		position: absolute;
		left: 120px;
	}

	.ctt-job-title {
		top: 60px;
	}

	.ctt-posted-by {
		top: 86px;
	}

	.ctt-job-date {
		top: 28px;
	}
}

/* .filter-white {
    filter: brightness(0) invert(1);
} */

/* Scrollable Job List */
.ctt-job-list-wrapper {
	position: relative;
	min-height: 400px;
}

#user_profiles_container {
	max-height: 775px;
	/* Approximately 4 cards high */
	overflow-y: auto;
	padding-right: 15px;
	scrollbar-width: thin;
	scrollbar-color: #004B69 #F0F0F0;
}

#user_profiles_container::-webkit-scrollbar {
	width: 8px;
}

#user_profiles_container::-webkit-scrollbar-track {
	background: #F0F0F0;
	border-radius: 10px;
}

#user_profiles_container::-webkit-scrollbar-thumb {
	background: #004B69;
	border-radius: 10px;
}

.ctt-view-all-wrapper {
	margin-top: 40px;
	text-align: center;
}

/* Localized AJAX Loader */
#page_loader {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.7);
	z-index: 100;
	display: none;
	align-items: center;
	justify-content: center;
	border-radius: 16px;
}

.loader {
	width: 5rem;
	height: 5rem;
	border: 1rem solid rgba(0, 75, 105, 0.2);
	border-top-color: #004B69;
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

/* MOBILE */
@media (max-width: 600px) {
	.loader {
		width: 3rem;
		height: 3rem;
		border-width: 0.4rem;
	}
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

.footer_links a {
	color: #fff;
	letter-spacing: 0.37px;
}

.footer_links a:hover {
	color: #ffffff;
	font-weight: 700;
	letter-spacing: 0;
}

/* Responsive Helpers for inline style replacement */
.ctt-ai-assistant-img {
	width: 100%;
	max-width: 430px;
	height: auto;
}

.ctt-post-job-btn {
	width: fit-content;
}

.ctt-lottie-contact {
	width: 100%;
	max-width: 500px;
	height: auto;
}

@media (max-width: 767px) {
	.ctt-post-job-btn {
		width: 100%;
		/* Full width on mobile for better touch target */
	}
}

footer a:hover {
	color: var(--ctt-secondary);
}

.stat-icon {
	width: 46px;
	/* fixed width like Figma */
	height: 46px;
	flex: 0 0 46px;
	/* prevents shrinking */
	/* display: flex; */
	/* align-items: center; */
	/* justify-content: center; */
}

.stat-icon img {
	max-width: 100%;
	max-height: 100%;
}

.stat-item h4 {
	line-height: 1.1;
}

input#newsletterEmail::placeholder {
	color: #D9DBE1;
}

input#newsletterEmail::-webkit-input-placeholder {
	/* Chrome, Safari */
	color: #D9DBE1;
}

input#newsletterEmail:-ms-input-placeholder {
	/* IE 10-11 */
	color: #D9DBE1;
}

input#newsletterEmail::-ms-input-placeholder {
	/* Edge (old) */
	color: #D9DBE1;
}

#newsletterForm .input-group {
	border-radius: 8px;
}

#newsletterEmail {
	background-color: #336f87;
	color: #D9DBE1;
}

#subscribeBtn {
	background-color: #336f87;
}

@media (max-width: 767px) {
	#headerLogo {
		height: 25px;
	}
}

/* ========== CUSTOM ANIMATIONS ========== */

/* Floating Animation */
@keyframes floating {
	0% {
		transform: translate(0, 0px);
	}

	50% {
		transform: translate(0, 15px);
	}

	100% {
		transform: translate(0, -0px);
	}
}

.floating-animation {
	animation-name: floating;
	animation-duration: 3s;
	animation-iteration-count: infinite;
	animation-timing-function: ease-in-out;
}

/* Pulse Animation for Buttons */
@keyframes pulse-blue {
	0% {
		box-shadow: 0 0 0 0 rgba(0, 75, 105, 0.7);
	}

	70% {
		box-shadow: 0 0 0 10px rgba(0, 75, 105, 0);
	}

	100% {
		box-shadow: 0 0 0 0 rgba(0, 75, 105, 0);
	}
}

.pulse-animation {
	animation: pulse-blue 2s infinite;
}

.hero-typed-text {
	color: var(--ctt-secondary);
	/* font-weight: 700; */
}