/**
 * TINGLE DIGITAL - Layout Styles
 * Header, Footer, Site Structure
 * Light Theme - Nova Paleta 2025
 *
 * @version 2.0.0
 */

/* ============================================
 * CONTAINER
 * ============================================ */

.container {
	width: 100%;
	max-width: var(--container-xl);
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-6);
	padding-right: var(--space-6);
}

@media (max-width: 768px) {
	.container {
		padding-left: var(--space-4);
		padding-right: var(--space-4);
	}
}

/* ============================================
 * SITE HEADER - LIGHT THEME
 * ============================================ */

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	padding: var(--space-4) 0;
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(50, 30, 12, 0.08);
	transition: var(--transition-all);
}

.site-header.scrolled {
	padding: var(--space-3) 0;
	background: rgba(255, 255, 255, 0.95);
	box-shadow: var(--shadow-md);
}

.header-container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-8);
}

/* Site Branding / Logo */
.site-branding {
	flex-shrink: 0;
}

.site-branding a {
	display: flex;
	align-items: center;
	gap: var(--space-1);
	text-decoration: none;
}

.site-branding img,
.site-branding .site-logo {
	height: 48px;
	width: auto;
	max-width: 180px;
	object-fit: contain;
}

.site-branding .custom-logo {
	height: 48px;
	width: auto;
}

.logo-text {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--font-bold);
	color: var(--tingle-brown);
}

.logo-accent {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--font-bold);
	color: var(--tingle-coral);
}

/* Main Navigation */
.main-navigation {
	flex: 1;
	display: flex;
	justify-content: center;
}

.primary-menu {
	display: flex;
	align-items: center;
	gap: var(--space-8);
	list-style: none;
	margin: 0;
	padding: 0;
}

.primary-menu .menu-item a {
	font-family: var(--font-body);
	font-size: var(--text-base);
	font-weight: var(--font-medium);
	color: var(--text-secondary);
	text-decoration: none;
	position: relative;
	padding: var(--space-2) 0;
	transition: color var(--duration-normal) var(--ease-smooth);
}

.primary-menu .menu-item a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--gradient-coral-amber);
	transition: width var(--duration-normal) var(--ease-smooth);
}

.primary-menu .menu-item a:hover,
.primary-menu .menu-item.current-menu-item a {
	color: var(--tingle-coral);
}

.primary-menu .menu-item a:hover::after,
.primary-menu .menu-item.current-menu-item a::after {
	width: 100%;
}

/* Header CTA */
.header-cta {
	flex-shrink: 0;
}

/* Mobile Menu Toggle */
.menu-toggle {
	/* Mobile: mostrar em telas pequenas */
	display: none;
	padding: var(--space-2);
	background: transparent;
	border: none;
	cursor: pointer;
}

.hamburger {
	display: flex;
	flex-direction: column;
	gap: 6px;
	width: 28px;
}

.hamburger span {
	display: flex !important;
		align-items: center;
		justify-content: center;
	width: 100%;
	height: 2px;
	background: var(--tingle-brown);
	border-radius: 2px;
	transition: var(--transition-all);
}

.menu-toggle[aria-expanded="true"] .hamburger span:nth-child(1) {
	transform: rotate(45deg) translate(6px, 6px);
}

.menu-toggle[aria-expanded="true"] .hamburger span:nth-child(2) {
	opacity: 0;
}

.menu-toggle[aria-expanded="true"] .hamburger span:nth-child(3) {
	transform: rotate(-45deg) translate(6px, -6px);
}

/* Mobile Navigation */
@media (max-width: 1024px) {
	.menu-toggle {
	/* Mobile: mostrar em telas pequenas */
		display: flex !important;
		align-items: center;
		justify-content: center;
	}

	.main-navigation {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background: var(--light-primary);
		display: flex;
		align-items: center;
		justify-content: center;
		opacity: 0;
		visibility: hidden;
		transition: var(--transition-all);
		z-index: 999;
	}

	.main-navigation.toggled {
		opacity: 1;
		visibility: visible;
	}

	.primary-menu {
		flex-direction: column;
		gap: var(--space-6);
	}

	.primary-menu .menu-item a {
		font-size: var(--text-2xl);
		color: var(--tingle-brown);
	}

	.header-cta {
		display: none;
	}
}

/* ============================================
 * SITE FOOTER - LIGHT THEME
 * ============================================ */

.site-footer {
	position: relative;
	background: var(--light-secondary);
	padding: var(--space-20) 0 var(--space-8);
	overflow: hidden;
}

.footer-container {
	max-width: var(--container-xl);
	margin: 0 auto;
	padding: 0 var(--space-6);
}

/* Footer Widgets */
.footer-widgets {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: var(--space-12);
	padding-bottom: var(--space-12);
	border-bottom: 1px solid rgba(50, 30, 12, 0.1);
}

@media (max-width: 768px) {
	.footer-widgets {
		grid-template-columns: 1fr;
		gap: var(--space-8);
	}
}

.footer-widget-area h3 {
	font-family: var(--font-heading);
	font-size: var(--text-lg);
	font-weight: var(--font-semibold);
	color: var(--tingle-brown);
	margin-bottom: var(--space-4);
}

/* Footer Brand */
.footer-brand {
	max-width: 300px;
}

.footer-brand img,
.footer-brand .footer-logo {
	height: 50px;
	width: auto;
	max-width: 180px;
	object-fit: contain;
	margin-bottom: var(--space-4);
}

.footer-brand a {
	display: inline-block;
}

.footer-logo-text {
	font-family: var(--font-display);
	font-size: var(--text-2xl);
	font-weight: var(--font-bold);
	background: var(--gradient-coral-amber);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	display: flex !important;
		align-items: center;
		justify-content: center;
	margin-bottom: var(--space-4);
}

.footer-tagline {
	color: var(--text-secondary);
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
}

/* Footer Menu */
.footer-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-menu li {
	margin-bottom: var(--space-3);
}

.footer-menu a {
	color: var(--text-secondary);
	text-decoration: none;
	font-size: var(--text-base);
	transition: color var(--duration-fast) ease;
}

.footer-menu a:hover {
	color: var(--tingle-coral);
}

/* Footer Contact */
.footer-contact {
	list-style: none;
	margin: 0;
	padding: 0;
}

.footer-contact li {
	margin-bottom: var(--space-3);
}

.footer-contact a,
.footer-address {
	color: var(--text-secondary);
	text-decoration: none;
	font-size: var(--text-base);
	transition: color var(--duration-fast) ease;
}

.footer-contact a:hover {
	color: var(--tingle-coral);
}

/* Footer Bottom */
.footer-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: var(--space-8);
	gap: var(--space-4);
}

@media (max-width: 768px) {
	.footer-bottom {
		flex-direction: column;
		text-align: center;
	}
}

.footer-copyright {
	color: var(--text-muted);
	font-size: var(--text-sm);
}

.footer-copyright a {
	color: var(--tingle-coral);
	text-decoration: none;
}

.footer-copyright a:hover {
	color: var(--tingle-magenta);
}

/* Footer Social */
.footer-social {
	display: flex;
	gap: var(--space-4);
}

.social-link {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	background: rgba(50, 30, 12, 0.05);
	color: var(--text-secondary);
	transition: var(--transition-all);
}

.social-link:hover {
	background: var(--tingle-coral);
	color: white;
	transform: translateY(-3px);
	box-shadow: var(--shadow-coral);
}

.social-link svg {
	width: 20px;
	height: 20px;
}

/* Footer Decoration */
.footer-decoration {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	pointer-events: none;
	overflow: hidden;
}

.footer-orb-1 {
	position: absolute;
	top: -200px;
	right: -100px;
	width: 400px;
	height: 400px;
	background: var(--tingle-coral);
	border-radius: 50%;
	filter: blur(150px);
	opacity: 0.08;
}

.footer-orb-2 {
	position: absolute;
	bottom: -150px;
	left: -100px;
	width: 300px;
	height: 300px;
	background: var(--tingle-turquoise);
	border-radius: 50%;
	filter: blur(120px);
	opacity: 0.06;
}

/* ============================================
 * SCREEN READER TEXT
 * ============================================ */

.screen-reader-text {
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute !important;
	height: 1px;
	width: 1px;
	overflow: hidden;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--light-primary);
	border-radius: var(--radius-sm);
	box-shadow: 0 0 2px 2px rgba(50, 30, 12, 0.2);
	clip: auto !important;
	color: var(--tingle-brown);
	display: flex !important;
		align-items: center;
		justify-content: center;
	font-size: var(--text-sm);
	font-weight: var(--font-bold);
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Skip Link */
.skip-link:focus {
	position: fixed;
	top: var(--space-2);
	left: var(--space-2);
	z-index: 10000;
	padding: var(--space-4) var(--space-6);
	background: var(--tingle-coral);
	color: white;
	border-radius: var(--radius-md);
}

/* ============================================
 * MAIN CONTENT OFFSET (for fixed header)
 * ============================================ */

.site-main {
	padding-top: 0; /* Hero is full screen */
}

.site-main > section:first-child:not(.hero) {
	padding-top: calc(80px + var(--space-16)); /* Header height + spacing */
}

/* Mobile Menu Open State */
body.menu-open {
	overflow: hidden;
}

/* Ensure menu toggle is above the navigation overlay */
.site-header .menu-toggle {
	/* Mobile: mostrar em telas pequenas */
	position: relative;
	z-index: 1000;
}
