/*-- -------------------------- -->
<---           Footer           -->
<--- -------------------------- -*/

/* Mobile - Default */
@media only screen and (min-width: 0px) {

	/* Footer Shell */
	.site-footer {
		background: var(--navy);
		color: rgba(255, 255, 255, 0.5);
		font-family: var(--bodyFont);
	}

	/* Footer Main */
	.footer-main {
		display: grid;
		grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
		gap: 3rem;
		padding: 5rem 6vw 4rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}

	/* Brand Column */
	.footer-brand {
		display: flex;
		flex-direction: column;
		gap: 1.2rem;
	}

	.footer-logo-link {
		display: inline-block;
	}

	.footer-logo {
		display: block;
		width: 11.25rem;
		height: auto;
		object-fit: contain;
	}

	.footer-tagline {
		font-size: 0.875rem;
		font-weight: 300;
		line-height: 1.65;
		color: rgba(255, 255, 255, 0.45);
		margin: 0;
	}

	.footer-est {
		font-size: 0.625rem;
		font-weight: 400;
		letter-spacing: 0.2em;
		text-transform: uppercase;
		color: rgba(255, 255, 255, 0.25);
		margin: 0;
	}

	/* Nav Columns */
	.footer-col {
		display: flex;
		flex-direction: column;
		gap: 1rem;
	}

	.footer-col-heading {
		font-family: var(--headerFont);
		font-size: 1rem;
		font-weight: 600;
		font-style: normal;
		color: rgba(255, 255, 255, 0.85);
		margin: 0;
		padding-bottom: 0.6rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	}

	.footer-links {
		list-style: none;
		padding: 0;
		margin: 0;
		display: flex;
		flex-direction: column;
		gap: 0.55rem;
	}

	.footer-links a {
		font-size: 0.8125rem;
		font-weight: 300;
		letter-spacing: 0.02em;
		color: rgba(255, 255, 255, 0.4);
		text-decoration: none;
		display: inline-block;
		transition: color 0.2s ease, padding-left 0.2s ease;
	}

	.footer-links a:hover {
		color: rgba(255, 255, 255, 0.9);
		padding-left: 0.3rem;
	}

	/* Accreditations Bar */
	.footer-accreditations {
		padding: 2.5rem 6vw;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
		display: flex;
		align-items: center;
		gap: 3rem;
		flex-wrap: wrap;
	}

	.footer-accred-label {
		font-size: 0.625rem;
		font-weight: 500;
		letter-spacing: 0.2em;
		text-transform: uppercase;
		color: rgba(255, 255, 255, 0.25);
		margin: 0;
		white-space: nowrap;
		flex-shrink: 0;
	}

	.footer-accred-logos {
		display: flex;
		align-items: center;
		gap: 2.5rem;
		flex-wrap: wrap;
	}

	.footer-accred-logos img {
		height: 2.5rem;
		width: auto;
		object-fit: contain;
		opacity: 0.5;
		filter: brightness(0) invert(1);
		transition: opacity 0.2s ease;
	}

	.footer-accred-logos img:hover {
		opacity: 0.8;
	}

	/* Placeholder — remove once real logos are in place */
	.footer-accred-placeholder {
		font-size: 0.625rem;
		font-weight: 500;
		letter-spacing: 0.1em;
		text-transform: uppercase;
		color: rgba(255, 255, 255, 0.2);
		text-align: center;
		line-height: 1.4;
		padding: 0.6rem 1rem;
		border: 1px solid rgba(255, 255, 255, 0.1);
		border-radius: 0.25rem;
	}

	/* Bottom Bar */
	.footer-bottom {
		padding: 1.5rem 6vw;
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 1.5rem;
		flex-wrap: wrap;
	}

	.footer-copy {
		font-size: 0.75rem;
		font-weight: 300;
		color: rgba(255, 255, 255, 0.2);
		margin: 0;
	}

	.footer-legal {
		display: flex;
		align-items: center;
		gap: 1rem;
		flex-wrap: wrap;
	}

	.footer-legal a {
		font-size: 0.6875rem;
		font-weight: 300;
		letter-spacing: 0.08em;
		color: rgba(255, 255, 255, 0.2);
		text-decoration: none;
		text-transform: uppercase;
		transition: color 0.2s ease;
	}

	.footer-legal a:hover {
		color: rgba(255, 255, 255, 0.6);
	}

	.footer-legal-dot {
		width: 2px;
		height: 2px;
		border-radius: 50%;
		background: rgba(255, 255, 255, 0.15);
		flex-shrink: 0;
	}

}

/* Tablet (max-width: 1100px) */
@media only screen and (max-width: 1100px) {

	.footer-main {
		grid-template-columns: 1fr 1fr 1fr;
		gap: 2.5rem;
	}

	.footer-brand {
		grid-column: 1 / -1;
		flex-direction: row;
		align-items: flex-start;
		gap: 3rem;
		padding-bottom: 2rem;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}

	.footer-tagline,
	.footer-est {
		max-width: 16.25rem;
	}
}

/* Tablet (max-width: 760px) */
@media only screen and (max-width: 760px) {

	.footer-main {
		grid-template-columns: 1fr 1fr;
		padding: 3.5rem 1.5rem 3rem;
		gap: 2rem;
	}

	.footer-brand {
		flex-direction: column;
		gap: 1rem;
	}

	.footer-accreditations {
		padding: 2rem 1.5rem;
		gap: 1.5rem;
		flex-direction: column;
		align-items: flex-start;
	}

	.footer-bottom {
		padding: 1.25rem 1.5rem;
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}
}

/* Mobile Only (0–480px) */
@media only screen and (max-width: 480px) {

	.footer-main {
		grid-template-columns: 1fr;
		padding: 3rem 1rem 2.5rem;
	}

	.footer-bottom {
		padding: 1.25rem 1rem;
	}

	.footer-accreditations {
		padding: 2rem 1rem;
	}

	.footer-accred-logos {
		gap: 1.5rem;
	}
}