/* Brand Color #ffcc00 */

*{
-webkit-font-smoothing: antialiased; 
-moz-osx-font-smoothing: grayscale;
margin: 0;
padding: 0;
box-sizing: border-box;
}

/* Basic reset and styling */
body, html {
		margin: 0;
		padding: 0;
		font-family: "azo-sans-web", sans-serif;
		font-weight: 500;
		font-style: normal;
		transition: transform .8s;
		min-height: 100vh
}

body {
	background: linear-gradient(to bottom, #ffcc00, #edbe00);
	background-color: #ffcc00;
	background-image: url('/images/keyart-alt.jpg');
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	min-height: 100%;
	display: flex;
	flex-direction: column;
}

/* Header styling */
header {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 0;
		/*background-color: #ffcc00;*/
		/*background: linear-gradient(to top, #ffcc00, #edbe00);
		background-image: url('/images/keyart.jpg');
		background-size: cover;
		background-repeat: no-repeat;
		background-position: top center;*/
		transition: transform .8s;
		height: 140px;
		display: flex;
		flex-direction: column;
		align-items: center;
}

.logo img.svg-logo {
		width: 180px;
		height: auto;
		margin-top: 40px;
		filter: brightness(1) invert(1); /* Ensures the logo is black */
}

.logo img.svg-logo:hover {
		transform: scale(1.05);
		transition: all 0.15s ease-in-out;
		cursor: pointer!important;
}


/* Social media icons */
.social-icons {padding-left: 50px; padding-right: 50px;}

.social-icons a, .social-icons h2 {
		margin-left: 15px;
		transform: translate(-50%, -50%);
		text-decoration-line: none;
		filter: brightness(0) invert(0); /* Ensures the logo is black */
}

.social-icons img {
		width: 30px;
		height: 30px;
		transition: all 0.15s ease-in-out;
}
	
.social-icons a:hover img {
		filter: brightness(0) invert(1); /* Invert icon on hover */
		transform: scale(1.12);
		transition: all 0.15s ease-in-out;
}



/* Container styling */
.container {
		padding: 20px;
		max-width: 1200px; /* Constrain width on larger screens */
		margin: 0 auto; /* Center container */
		height: auto;
		border-radius: 10px;
}

/* Channel banner styling */
.channel-banner {
		/*background-color: #ffcc00;*/
		border: 4px rgba(255, 255, 255, 0.9);
		transition: transform .8s;
		border-radius: 10px;
		/*box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);*/
		padding: 0px;
		margin: 0px;
		text-align: center;
}

.channel-banner:hover {
		/*box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1);*/
}

/* Channel banner content */
.channel-banner-top-content {
		margin-bottom: 10px;
}

.channel-banner h2 {
		font-size: 2.3rem;
		margin-bottom: 25px;
		color: black;
		font-weight: 800;
}

.channel-banner p.intro {
		font-weight: 600;
		color: #3c3000;
		line-height: 1.6em;
		font-size: 1.3rem;
		padding: 0px 60px 20px;
}

.channel-banner p.intro a {color: #3c3000;}
.channel-banner p.intro a:hover {color: white; transform: scale(1.12); transition: all 0.15s ease-in-out;}

/* Stats section styling */
.stats-container {
		display: flex;
		justify-content: center;
		gap: 20px;
		margin-bottom: 20px;
}

.stat-box {
		/*background-color: rgba(255, 255, 255, 0.25);*/
		border-radius: 10px;
		padding: 10px;
		width: 33%;
		box-shadow: 0 1px 5px rgba(0, 0, 0, 0.1);
		transition: transform .8s;
}

.stat-box span {
		transition: all 0.3s ease-in-out;
}

.stat-box:hover {
	transform: scale(1.015);
	transition: all 0.15s ease-in-out;
	box-shadow: 0 5px 8px rgba(0, 0, 0, 0.3);
	cursor: pointer;
}

.stat-box:hover .video-overlay {
	background: rgba(255, 255, 255, 0.90);
	transition: all 0.15s ease-in-out;
}

.stat-box p {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.697);
	text-transform: uppercase;
	font-weight: 600;
	line-height: 3rem;
}

.stat-box #youtube-subscribers, .stat-box #youtube-views, .stat-box #youtube-videos {
		font-weight: 800;
		font-size: 3.3rem;
		color: white;
}

.stat-box:hover p {
	color: black!important;
}

.stat-box:hover p span {color: black!important;}

/* Subscribe button */
.subscribe-button {
		display: inline-block;
		margin: 10px 0px 50px 0px;
		padding: 15px 30px 15px 60px; /* Combined padding-left and padding-right */
		background-color: white;
		color: black;
		text-decoration: none;
		border-radius: 10px;
		background-image: url('/images/youtube-red.svg');
		background-repeat: no-repeat;
		background-position: center left;
		background-size: contain;
		transition: transform .8s;
		font-weight: 900;
		text-transform: uppercase;
		letter-spacing: 0.05em;
		font-size: 1.3rem;
}

.subscribe-button:hover {
		box-shadow: 0 3px 5px rgba(0, 0, 0, 0.02);
		transform: scale(1.05);
		transition: all 0.15s ease-in-out;
		cursor: pointer!important;
}

u {
background: url(/images/underline.svg) bottom center/100% 0.15em no-repeat;
box-decoration-break: clone;
-webkit-box-decoration-break: clone;
padding-bottom: 0.1em;
text-decoration: none;
}

a {text-decoration: none;}

/* Container for the background video */
.video-background-container {
		position: relative;
		overflow: hidden;
		width: 100%;
		height: 100%;
}

.video-background-container video {
		width: 100%;
		height: 100%;
		object-fit: cover;
		position: absolute;
		top: 0;
		left: 0;
}

/* Position the video absolutely inside the container, not affecting layout */
#bgVideo {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		object-fit: cover; /* Ensures the video covers the container */
		opacity: 0; /* Start with opacity 0 */
		transition: opacity 1s ease-in-out; /* Smooth fade-in effect */
		z-index: -2; /* Keep the video behind the overlay and content */
}

/* Placeholder thumbnail until the video loads */
.video-placeholder {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		object-fit: cover; /* Ensures the thumbnail covers the div */
		z-index: -1; /* Keeps the placeholder behind content */
}

/* White overlay to make the text stand out */
.video-overlay {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: rgba(0, 0, 0, 0.45); /* opacity mask */
		z-index: -1; /* Ensure the overlay is above the video but behind text */
}

/* Ensure content inside the div is displayed correctly */
.video-background-container p {
		position: relative;
		z-index: 1; /* Ensure text stays on top of the video and overlay */
		color: white; /* Ensure the text color is visible */
		text-align: center;
		font-size: 16px;
		margin: 10px 0;
}

/* Hide the thumbnail when the video is fully loaded */
.video-loaded .video-placeholder {
		display: none;
}






/* Embedded video styling */
.embedded-video {
		position: relative;
		padding-bottom: 56.25%;
		height: 0;
		overflow: hidden;
		width: 100%;
}

.embedded-video iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		border-radius: 8px;
}

/* General heading styles */
h1, h2 {
		text-align: center;
		font-family: "azo-sans-uber", sans-serif;
}

h1 {
		font-size: 2.5rem;
		margin-bottom: 1rem;
}


/* Video container layout */
.video-container {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap; /* Allows videos to wrap on smaller screens */
		text-align: center;
}

.video {
		width: 100%;
		max-width: 23%;
		margin-bottom: 20px;
		border-radius: 8px;
		overflow: hidden;
		box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
		transition: all 0.2s ease-in-out;
}

.video img {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: cover; /* Ensures the thumbnail fills the container without black bars */
}

.video:hover {
		transform: scale(1.05);
}

/* Video play button */
.play-button {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		font-size: 36px;
		color: white;
		opacity: 0.55;
}

.video:hover .play-button {
		opacity: 1;
		transform: translate(-50%, -50%) scale(1.1);
		transition: all 0.2s ease-in-out;
}

/* Video title */
.video-title {
		text-align: center;
		padding: 10px;
}


/* Footer Styling */
.site-footer {
		/*background: linear-gradient(to bottom, #ffcc00, #edbe00);*/
		padding: 0px 20px; /* Space around the content */
		color: #000; /* Text color */
		text-align: center;
}

.footer-container {
		max-width: 1200px; /* Maximum width for the footer */
		margin: 0 auto; /* Center the content */
		display: flex;
		flex-direction: column;
		align-items: center;
}

.site-footer h3 {
	font-size: 1.3rem;
	margin-bottom: 30px;
	color: #3c3000;
}

.footer-logo img {
		width: 150px;
		margin-bottom: 0px;
		filter: brightness(1) invert(1); /* Ensures the logo is black */
}

.footer-social-icons {
		margin-bottom: 20px;
}

.footer-social-icons a {
		margin: 0 10px;
		transition: transform 0.3s ease;
		text-decoration-line: none;
}

.footer-social-icons img {
		width: 50px;
		height: 50px;
		filter: brightness(1) invert(0); /* Black icons */
		
}

.footer-social-icons a:hover img {
		filter: brightness(0) invert(1); /* White icons on hover */
		transform: scale(1.21);
		transition: all 0.15s ease-in-out;
}

.footer-links {
		display: flex;
		flex-direction: row;
		gap: 15px;
		margin-bottom: 20px;
}

.footer-links a {
		text-decoration: none;
		color: black;
		font-size: 1rem;
}

.footer-links a:hover {
		color: white;
		transform: scale(1.12);
		transition: all 0.15s ease-in-out;
}

.footer-copyright {
		font-size: 0.9rem;
		color: rgba(0, 0, 0, 0.45) /* Slightly muted text */
}

@media (max-width: 768px) {
	body {padding-bottom: 20px;}
	header {height: 120px;}
	.logo img.svg-logo {width: 150px;}
	.channel-banner p.intro {line-height: 1.6em; font-size: 0.89rem; padding-left: 10px; padding-right: 10px; padding-top: 10px; padding-bottom: 10px; font-weight: 600;}
	.channel-banner {margin: 5px;}
	.container {max-width: 100%; padding: 0;}
	.channel-banner h2 {font-size: 1.9rem; margin: 8px 0;}
	.stat-box {width: 28%!important; padding: 1px!important;}
	.stat-box p {font-size: 0.68rem!important; color: white; line-height: 2.5rem!important; letter-spacing: -0.01em;}
	.stat-box #youtube-subscribers, .stat-box #youtube-views, .stat-box #youtube-videos {font-size: 1.95rem!important; letter-spacing: -0.07em;}
	.footer-social-icons img {width: 40px; height: 40px;}
	.site-footer h3 {margin-top: 10px; margin-bottom: 20px;}
	.subscribe-button {margin: 10px 0px 30px 0px;}
	.footer-social-icons {margin-bottom: 0;}
	.footer-logo img {width: 100px;}
}


/* ===========================
   Privacy Page Styles
   =========================== */
.privacy-page {
  margin: 0 auto;
  padding: 48px 20px;
  color: #111;
  background: white; /* optional: ensures text is readable if global bg is image */
  border-radius: 10px;
}

.privacy-page p,
.privacy-page li {
  font-size: 18px;
  line-height: 1.75; /* improved readability */
  letter-spacing: 0;
  margin-bottom: 1em;
}

.privacy-page ul {
  margin: 0.5em 0 1.25em 1.25em;
  padding-left: 1.25em;
}

.privacy-page li + li {
  margin-top: 0.35em;
}

.privacy-page h1 {
  font-family: "azo-sans-uber", sans-serif;
  font-size: clamp(32px, 5vw, 44px);
  line-height: 1.2;
  margin: 0 0 0.4em;
}

.privacy-page h2 {
  font-family: "azo-sans-uber", sans-serif;
  font-size: clamp(20px, 3vw, 28px);
  line-height: 1.3;
  margin: 1.8em 0 0.5em;
}

.privacy-page h3 {
  font-size: 18px;
  line-height: 1.35;
  margin: 1.25em 0 0.4em;
}

.privacy-page .last-updated {
  opacity: 0.7;
  font-size: 16px;
  line-height: 1.6;
  margin-top: -0.25em;
  margin-bottom: 1.25em;
}

.privacy-page a {
  text-decoration: underline;
  text-underline-offset: 2px;
  color: black;
  text-decoration: underline;
}

@media (max-width: 520px) {
  .privacy-page {
	padding: 36px 16px;
  }
  .privacy-page p,
  .privacy-page li {
	line-height: 1.7;
  }
}