/* LOGO */
header .navbar-brand img {
	max-height: 100px;
}
  
header .col-auto .navbar-brand {
	max-width: 220px;
}
  
.default-logo, .alt-logo {
	width: 200px !important;
	height: auto !important;
	max-width: none !important;
	max-height: none !important;
}

footer .footer-logo img {
	max-height: 100px !important;
}

.footer-logo {
	width: 100px !important;
	height: auto !important;
	max-width: none !important;
	max-height: none !important;
}

/* Dynamic Separator Spacing */
.responsive-separator-margin {
	margin-top: 0px; /* Default margin */
}
@media (min-width: 800px) {
	.responsive-separator-margin {
		margin-top: 30px !important;
	}
}
@media (min-width: 1000px) {
	.responsive-separator-margin {
		margin-top: 40px !important;
	}
}
@media (min-width: 1200px) {
	.responsive-separator-margin {
		margin-top: 50px !important;
	}
}
@media (min-width: 1400px) {
	.responsive-separator-margin {
		margin-top: 60px !important;
	}
}
@media (min-width: 1600px) {
	.responsive-separator-margin {
		margin-top: 70px !important;
	}
}
@media (min-width: 1800px) {
	.responsive-separator-margin {
		margin-top: 80px !important;
	}
}
@media (min-width: 3000px) {
	.responsive-separator-margin {
		margin-top: 100px !important;
	}
}


/* WordClouds */
.clouds-container {
	position: relative;
	width: 100%;
	height: 30vh;
	overflow: hidden;
	display: flex;
    align-items: center;
    justify-content: center;
}

@media (min-width: 400px) {
	.clouds-container {
		height: 40vh;
	}
}
@media (min-width: 600px) {
	.clouds-container {
		height: 45vh;
	}
}
@media (min-width: 800px) {
	.clouds-container {
		height: 50vh;
	}
}
@media (min-width: 1000px) {
	.clouds-container {
		height: 57vh;
	}
}
@media (min-width: 1200px) {
	.clouds-container {
		height: 60vh;
	}
}
@media (min-width: 1300px) {
	.clouds-container {
		height: 63vh;
	}
}
@media (min-width: 1400px) {
	.clouds-container {
		height: 65vh;
	}
}
@media (min-width: 1600px) {
	.clouds-container {
		height: 70vh;
	}
}
@media (min-width: 1800px) {
	.clouds-container {
		height: 75vh;
	}
}
@media (min-width: 2000px) {
	.clouds-container {
		height: 80vh;
	}
}

#wordcloud2d {
	width: 100%;
	height: 70vh;
	top: 0;
	left: 0;
	z-index: 5; /* Background element */
}
#wordcloud2d g {
	transform: translate(50%, 50%); /* Center the 2D cloud */
}

#wordcloud2dimg {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Center the image */
    width: 30vw; /* Responsive width based on viewport width */
    height: auto; /* Keep aspect ratio */
    max-width: 60vw; /* Limits maximum size */
    max-height: 40vh; /* Limits maximum height */
    z-index: 5; /* Keep it behind the 3D cloud */
}

/* Center the 2D Word Cloud Image inside the 3D container */
.persistent-image {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%); /* Center the image */
    /* width: 30vw;
    height: auto;
    max-width: 60vw; 
    max-height: 60vh;  */
	width: 70%;
    height: 70%;
    z-index: 5; /* Behind the 3D cloud */
}
@media (min-width: 350px) {
	#wordcloud3d {
		width: 80%;
		height: 80%;
	}
}

#wordcloud3d {
	width: 100%;
	height: 30vh;
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 15; /* Above 2D cloud */
	pointer-events: none; /* Prevent interfering with text content */
}
@media (min-width: 400px) {
	#wordcloud3d {
		height: 40vh;
	}
}
@media (min-width: 600px) {
	#wordcloud3d {
		height: 45vh;
	}
}
@media (min-width: 800px) {
	#wordcloud3d {
		height: 50vh;
	}
}
@media (min-width: 1000px) {
	#wordcloud3d {
		height: 55vh;
	}
}
@media (min-width: 1200px) {
	#wordcloud3d {
		height: 60vh;
	}
}
@media (min-width: 1400px) {
	#wordcloud3d {
		height: 65vh;
	}
}
@media (min-width: 1600px) {
	#wordcloud3d {
		height: 70vh;
	}
}
@media (min-width: 1800px) {
	#wordcloud3d {
		height: 75vh;
	}
}


.responsive-wave-svg {
    height: 120px;
}
@media (min-width: 500px) {
    .responsive-wave-svg {
        height: 240px;
    }
}
/* @media (min-width: 800px) {
	.responsive-wave-svg {
		height: 200px;
	}
}
@media (min-width: 1000px) {
	.responsive-wave-svg {
		height: 160px;
	}
}
@media (min-width: 1200px) {
	.responsive-wave-svg {
		height: 120px;
	}
} */


/* Expand sections button */
.expand-section-button {
    width: 20px;
    height: 20px;
    background-color: #ffffff;
    color: #6c757d;
    border-radius: 50%;
    font-size: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
    transform: translateY(-70%);
    transition: all 0.3s ease;
    cursor: pointer;
}
.expand-section-button:hover {
    background-color: #f8f9fa;
    color: #495057;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
	border-radius: 80%;
}
/* Fade-in Animation */
@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.fade-in {
    animation: fadeIn 0.3s ease-in-out;
}
/* Fade-out Animation */
@keyframes fadeOut {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
    }
}
.fade-out {
    animation: fadeOut 0.3s ease-in-out;
}


.powered-badge {
	font-size: 14px;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}