/*
Theme Name: Mercadao Goiano
Theme URI: https://mercadaogoiano.go.gov.br
Author: Indexa
Author URI: https://indexa.com.br
Description: Tema institucional do Mercadao Goiano - O maior mercado popular de Goias.
Version: 4.0.0
Requires at least: 6.0
Requires PHP: 8.0
Text Domain: mercadaogoiano
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
*/

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */
:root {
	/* Colors - Brand */
	--c-green-900: #004d1c;
	--c-green-800: #006b28;
	--c-green-700: #007d30;
	--c-green: #009639;
	--c-green-500: #1aab4f;
	--c-green-400: #3dbe68;
	--c-green-300: #6dd48e;
	--c-green-200: #a3e6b8;
	--c-green-100: #d0f4dc;
	--c-green-50: #eefbf2;

	--c-yellow: #ffda00;
	--c-yellow-dark: #e8c600;
	--c-yellow-light: #fff3b0;

	--c-blue: #0f4c96;
	--c-blue-light: #1a6dd1;

	/* Colors - Neutral */
	--c-white: #ffffff;
	--c-gray-50: #f8f9fa;
	--c-gray-100: #f0f2f4;
	--c-gray-200: #e2e5e9;
	--c-gray-300: #c8cdd3;
	--c-gray-400: #9ca3ad;
	--c-gray-500: #6c757d;
	--c-gray-600: #4a5568;
	--c-gray-700: #374151;
	--c-gray-800: #1f2937;
	--c-gray-900: #111827;

	/* Typography */
	--ff-display: 'Oswald', sans-serif;
	--ff-body: 'Open Sans', sans-serif;

	--fs-xs: 0.75rem;
	--fs-sm: 0.875rem;
	--fs-base: 1rem;
	--fs-md: 1.125rem;
	--fs-lg: 1.25rem;
	--fs-xl: 1.5rem;
	--fs-2xl: 2rem;
	--fs-3xl: 2.5rem;
	--fs-4xl: 3.5rem;
	--fs-5xl: 5rem;

	/* Spacing */
	--sp-1: 0.25rem;
	--sp-2: 0.5rem;
	--sp-3: 0.75rem;
	--sp-4: 1rem;
	--sp-5: 1.25rem;
	--sp-6: 1.5rem;
	--sp-8: 2rem;
	--sp-10: 2.5rem;
	--sp-12: 3rem;
	--sp-16: 4rem;
	--sp-20: 5rem;
	--sp-24: 6rem;

	/* Border Radius */
	--radius-sm: 8px;
	--radius: 16px;
	--radius-lg: 28px;
	--radius-xl: 40px;
	--radius-full: 9999px;

	/* Shadows */
	--shadow-sm: 0 1px 3px rgba(0,0,0,.08);
	--shadow: 0 4px 16px rgba(0,0,0,.1);
	--shadow-lg: 0 8px 32px rgba(0,0,0,.12);
	--shadow-xl: 0 16px 48px rgba(0,0,0,.16);

	/* Layout */
	--container-max: 1000px;
	--header-h: 80px;

	/* Transitions */
	--ease: cubic-bezier(.4, 0, .2, 1);
	--duration: 300ms;
}

/* ==========================================================================
   RESET & BASE
   ========================================================================== */
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--ff-body);
	font-size: var(--fs-base);
	line-height: 1.6;
	color: var(--c-gray-800);
	background-color: var(--c-white);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

a {
	color: var(--c-green);
	text-decoration: none;
	transition: color var(--duration) var(--ease);
}

a:hover {
	color: var(--c-green-700);
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--ff-display);
	font-weight: 600;
	line-height: 1.2;
	color: var(--c-gray-900);
}

ul, ol {
	list-style: none;
}

button {
	cursor: pointer;
	border: none;
	background: none;
	font-family: inherit;
}

.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(--c-green);
	color: var(--c-white);
	clip: auto !important;
	display: block;
	font-size: var(--fs-sm);
	font-weight: 600;
	height: auto;
	padding: var(--sp-4);
	position: fixed;
	top: 5px;
	left: 5px;
	width: auto;
	z-index: 100000;
}

/* ==========================================================================
   CONTAINER
   ========================================================================== */
.container {
	width: 100%;
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--sp-6);
}

/* ==========================================================================
   BUTTONS
   ========================================================================== */
.btn {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-2);
	font-family: var(--ff-display);
	font-weight: 500;
	font-size: var(--fs-base);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: var(--sp-3) var(--sp-6);
	border-radius: var(--radius-full);
	transition: all var(--duration) var(--ease);
	text-decoration: none;
	border: 2px solid transparent;
	line-height: 1.3;
}

.btn svg { flex-shrink: 0; }

.btn--primary {
	background: var(--c-green);
	color: var(--c-white);
	border-color: var(--c-green);
}
.btn--primary:hover {
	background: var(--c-green-700);
	border-color: var(--c-green-700);
	color: var(--c-white);
}

.btn--secondary {
	background: var(--c-yellow);
	color: var(--c-gray-900);
	border-color: var(--c-yellow);
}
.btn--secondary:hover {
	background: var(--c-yellow-dark);
	border-color: var(--c-yellow-dark);
	color: var(--c-gray-900);
}

.btn--outline-white {
	background: transparent;
	color: var(--c-white);
	border-color: var(--c-white);
}
.btn--outline-white:hover {
	background: var(--c-white);
	color: var(--c-green);
}

.btn--sm { font-size: var(--fs-sm); padding: var(--sp-2) var(--sp-4); }
.btn--lg { font-size: var(--fs-md); padding: var(--sp-4) var(--sp-8); }

/* ==========================================================================
   HEADER
   ========================================================================== */
.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: var(--c-green-800);
	height: var(--header-h);
	transition: box-shadow var(--duration) var(--ease), background var(--duration) var(--ease);
}

.header.is-scrolled {
	box-shadow: 0 4px 16px rgba(0, 77, 28, 0.25);
	background: var(--c-green-900);
}

.header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: var(--header-h);
}

.header__logo {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

.header__logo-img {
	height: 44px;
	width: auto;
}

/* Desktop Navigation */
.main-nav__list {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
}

.main-nav__link {
	font-family: var(--ff-display);
	font-weight: 500;
	font-size: var(--fs-base);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--c-white);
	padding: var(--sp-2) var(--sp-4);
	border-radius: var(--radius-full);
	transition: all var(--duration) var(--ease);
	text-decoration: none;
}

.main-nav__link:hover,
.main-nav__link.is-active {
	color: var(--c-yellow);
	background: rgba(255, 255, 255, 0.12);
}

.menu-toggle__bar {
	background: var(--c-white) !important;
}

/* Mobile Toggle */
.menu-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	padding: 8px;
	border-radius: var(--radius-sm);
	transition: background var(--duration) var(--ease);
}

.menu-toggle:hover { background: var(--c-gray-100); }

.menu-toggle__bar {
	display: block;
	width: 100%;
	height: 2px;
	background: var(--c-gray-700);
	border-radius: 2px;
	transition: all var(--duration) var(--ease);
}

.menu-toggle.is-active .menu-toggle__bar:nth-child(1) {
	transform: translateY(7px) rotate(45deg);
}
.menu-toggle.is-active .menu-toggle__bar:nth-child(2) {
	opacity: 0;
}
.menu-toggle.is-active .menu-toggle__bar:nth-child(3) {
	transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Menu */
.mobile-menu {
	position: fixed;
	top: var(--header-h);
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--c-white);
	z-index: 999;
	transform: translateX(100%);
	transition: transform var(--duration) var(--ease);
	overflow-y: auto;
	padding: var(--sp-8) var(--sp-6);
}

.mobile-menu.is-active { transform: translateX(0); }

.mobile-menu__list {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
}

.mobile-menu__list li a {
	display: block;
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--c-gray-800);
	padding: var(--sp-4);
	border-radius: var(--radius);
	transition: all var(--duration) var(--ease);
	text-decoration: none;
}

.mobile-menu__list li a:hover {
	background: var(--c-green-50);
	color: var(--c-green);
}

.mobile-menu__info {
	margin-top: var(--sp-12);
	padding-top: var(--sp-6);
	border-top: 1px solid var(--c-gray-200);
}

.mobile-menu__hours {
	font-size: var(--fs-sm);
	color: var(--c-gray-500);
	line-height: 1.6;
}

.mobile-menu__hours strong {
	display: block;
	color: var(--c-green);
	font-size: var(--fs-base);
	margin-top: var(--sp-1);
}

/* ==========================================================================
   MAIN CONTENT
   ========================================================================== */
.site-main {
	padding-top: var(--header-h);
}

/* ==========================================================================
   CAROUSEL (generic)
   ========================================================================== */
.carousel {
	position: relative;
	overflow: hidden;
}

.carousel__track {
	display: flex;
	transition: transform 500ms var(--ease);
	will-change: transform;
}

.carousel__slide {
	flex: 0 0 100%;
	min-width: 0;
}

.carousel__slide img {
	width: 100%;
	height: auto;
	display: block;
}

.carousel__dots {
	display: flex;
	justify-content: center;
	gap: var(--sp-2);
	padding: var(--sp-4) 0;
}

.carousel__dot {
	width: 12px;
	height: 12px;
	border-radius: var(--radius-full);
	background: var(--c-gray-300);
	border: none;
	cursor: pointer;
	transition: all var(--duration) var(--ease);
	padding: 0;
}

.carousel__dot.is-active {
	background: var(--c-green);
	transform: scale(1.2);
}

.carousel__dot:hover:not(.is-active) {
	background: var(--c-gray-400);
}

.carousel__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 5;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	background: rgba(255,255,255,.85);
	color: var(--c-gray-800);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	border: none;
	box-shadow: var(--shadow);
	transition: all var(--duration) var(--ease);
	opacity: 0;
}

.carousel:hover .carousel__arrow { opacity: 1; }

.carousel__arrow:hover {
	background: var(--c-white);
	box-shadow: var(--shadow-lg);
}

.carousel__arrow--prev { left: var(--sp-4); }
.carousel__arrow--next { right: var(--sp-4); }

/* ==========================================================================
   HOME — wrapper, hero, highlights, news
   ========================================================================== */

/* Hero band — full-bleed, comeca abaixo do header (sem fundo verde) */
.home-hero-band {
	background: transparent;
	position: relative;
	overflow: hidden;
	padding: 0;
	margin: 0;
}

/* Wrapper do hero: ocupa toda a largura (anula o max-width padrao) */
.home-hero-band .home-wrapper {
	max-width: none;
	margin: 0;
	padding: 0;
	position: relative;
	z-index: 1;
}

/* Wrapper padrao (mantido para outras secoes que ainda usam) */
.home-wrapper {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 var(--sp-4);
	position: relative;
	z-index: 2;
}

/* Hero — full-bleed, sem moldura, encostado no header */
.home-hero {
	position: relative;
	overflow: hidden;
	background: var(--c-green-900);
}

.home-hero .carousel__slide {
	overflow: hidden;
	aspect-ratio: 16 / 7;
	max-height: 78vh;
}

.home-hero .carousel__slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Dots horizontais centralizados no rodape do hero */
.home-hero .carousel__dots {
	position: absolute;
	left: 50%;
	bottom: var(--sp-6);
	transform: translateX(-50%);
	z-index: 5;
	padding: 0;
	flex-direction: row;
	gap: 12px;
}

.home-hero .carousel__dot {
	width: 14px;
	height: 14px;
	background: rgba(255, 255, 255, 0.55);
	box-shadow: 0 1px 6px rgba(0, 0, 0, 0.3);
	border-radius: 50%;
	transition: all var(--duration) var(--ease);
}

.home-hero .carousel__dot.is-active {
	background: var(--c-white);
	transform: scale(1.3);
}

/* Highlights agora ficam abaixo da faixa verde, com seu proprio padding-top */
.home-cards-wrap {
	max-width: 1000px;
	margin: 0 auto;
	padding: 40px var(--sp-4) 0;
}

/* Highlights — 2 galerias retrato */
.home-highlights {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
}

.home-highlights__card {
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--c-green-800);
}

.home-highlights__card .carousel__slide img {
	width: 100%;
	display: block;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

/* Dots das galerias highlights: absolute sobre a imagem */
.home-highlights__card .carousel__dots {
	position: absolute;
	bottom: var(--sp-3);
	left: 50%;
	transform: translateX(-50%);
	z-index: 5;
	padding: 0;
	background: transparent;
}

.home-highlights__card .carousel__dot {
	width: 10px;
	height: 10px;
	background: rgba(255, 255, 255, 0.55);
	box-shadow: 0 1px 3px rgba(0,0,0,.25);
}

.home-highlights__card .carousel__dot.is-active {
	background: var(--c-white);
	transform: scale(1.2);
}

/* ==========================================================================
   HOME NEWS — Notícias + Fotos
   ========================================================================== */
.home-news {
	padding-top: 40px;
	overflow: hidden;
}

.home-news__headings {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 var(--sp-4);
	position: relative;
	z-index: 2;
}

.home-news__title {
	display: block;
	font-family: var(--ff-display);
	font-size: var(--fs-3xl);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: var(--c-gray-900);
	text-align: center;
	padding-bottom: var(--sp-3);
	border-bottom: 3px solid var(--c-green);
	margin-bottom: 0;
}

/* Green gradient background — label colado nos cards */
.home-news__bg {
	position: relative;
	padding: var(--sp-6) 0 var(--sp-10);
	margin-top: 0;
	background: linear-gradient(
		180deg,
		rgba(163, 230, 184, 0.0) 0%,
		rgba(109, 212, 142, 0.22) 15%,
		rgba(61, 190, 104, 0.30) 50%,
		rgba(109, 212, 142, 0.22) 85%,
		rgba(163, 230, 184, 0.0) 100%
	);
}

/* Cards */
.home-news__cards {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 var(--sp-4);
}

.home-news__col {
	min-width: 0;
}

.home-news__link {
	position: relative;
}

/* Dots das galerias de noticias/fotos: absolute sobre a imagem */
.home-news__col .carousel {
	background: transparent;
	position: relative;
}

.home-news__col .carousel__dots {
	position: absolute;
	bottom: var(--sp-3);
	left: 50%;
	transform: translateX(-50%);
	z-index: 5;
	padding: 0;
	background: transparent;
}

.home-news__col .carousel__dot {
	width: 10px;
	height: 10px;
	background: rgba(255, 255, 255, 0.6);
	box-shadow: 0 1px 3px rgba(0,0,0,.25);
}

.home-news__col .carousel__dot.is-active {
	background: var(--c-white);
	transform: scale(1.2);
}

.home-news__link {
	display: block;
	border-radius: var(--radius-xl);
	overflow: hidden;
	box-shadow: 0 12px 48px rgba(0,0,0,.18);
	transition: box-shadow var(--duration) var(--ease);
	width: 100%;
}

.home-news__link:hover {
	box-shadow: 0 20px 64px rgba(0,0,0,.24);
}

.home-news__img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

/* ==========================================================================
   FEAT CARD (used on inner pages for news listing)
   ========================================================================== */
.feat-card {
	display: block;
	position: relative;
	overflow: hidden;
	border-radius: var(--radius-lg);
	background: var(--c-gray-100);
	transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

.feat-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.feat-card__image {
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	position: relative;
}

.feat-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms var(--ease);
}

.feat-card:hover .feat-card__img { transform: scale(1.05); }

.feat-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,.6) 100%);
	pointer-events: none;
}

.feat-card__body {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--sp-6);
	z-index: 2;
}

.feat-card__date {
	display: inline-block;
	font-size: var(--fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: rgba(255,255,255,.8);
	margin-bottom: var(--sp-2);
}

.feat-card__title {
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 600;
	line-height: 1.3;
	color: var(--c-white);
}

.feat-card__title a { color: inherit; text-decoration: none; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer {
	background: var(--c-green-800);
	color: var(--c-white);
	padding-top: 40px;
	margin-top: 40px;
}

.footer__logo-wrap {
	margin-bottom: 40px;
}

.footer__logo {
	height: 96px;
	width: auto;
	filter: brightness(0) invert(1);
	opacity: 1;
}

.footer__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	padding-bottom: 40px;
}

.footer__title {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--c-white);
	margin-bottom: var(--sp-4);
}

.footer__text {
	font-size: var(--fs-sm);
	line-height: 1.7;
	color: var(--c-green-200);
	margin-bottom: var(--sp-2);
}

.footer__text a {
	color: var(--c-green-100);
	text-decoration: none;
}
.footer__text a:hover { color: var(--c-yellow); }

.footer__contact-block {
	margin-top: var(--sp-6);
}

.footer__subtitle {
	font-family: var(--ff-display);
	font-size: var(--fs-base);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: var(--c-white);
	margin-top: var(--sp-4);
	margin-bottom: var(--sp-2);
}

.footer__social-item {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
	margin-bottom: var(--sp-4);
	font-size: var(--fs-sm);
	color: var(--c-green-200);
}

.footer__social-item svg {
	flex-shrink: 0;
	color: var(--c-yellow);
}

.footer__social-item a {
	color: var(--c-green-100);
	text-decoration: none;
}
.footer__social-item a:hover { color: var(--c-yellow); }

.footer__social-label {
	font-weight: 600;
	color: var(--c-white);
	margin-right: var(--sp-2);
}

.footer__bottom {
	border-top: 1px solid rgba(255,255,255,.15);
	padding: var(--sp-5) 0;
}

.footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: center;
}

.footer__copyright {
	font-size: var(--fs-xs);
	color: var(--c-green-300);
	text-align: center;
}

/* ==========================================================================
   PAGE HERO
   ========================================================================== */
.page-hero {
	position: relative;
	background: linear-gradient(135deg, var(--c-green-800), var(--c-green));
	padding: var(--sp-16) 0 var(--sp-12);
	overflow: hidden;
}

.page-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60" viewBox="0 0 60 60"><circle cx="30" cy="30" r="1.5" fill="rgba(255,255,255,0.05)"/></svg>');
	pointer-events: none;
}

.page-hero__content { position: relative; z-index: 1; }

.page-hero__title {
	font-family: var(--ff-display);
	font-size: var(--fs-4xl);
	font-weight: 700;
	text-transform: uppercase;
	color: var(--c-white);
	margin-bottom: var(--sp-2);
}

.page-hero__subtitle {
	font-size: var(--fs-lg);
	color: var(--c-green-200);
	max-width: 600px;
}

/* Breadcrumbs */
.breadcrumbs {
	padding: var(--sp-4) 0;
	background: var(--c-gray-50);
	border-bottom: 1px solid var(--c-gray-200);
}

.breadcrumbs__list {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	flex-wrap: wrap;
}

.breadcrumbs__item {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
	font-size: var(--fs-sm);
}

.breadcrumbs__link { color: var(--c-gray-500); }
.breadcrumbs__link:hover { color: var(--c-green); }
.breadcrumbs__sep { color: var(--c-gray-300); }
.breadcrumbs__current { color: var(--c-gray-700); font-weight: 500; }

/* ==========================================================================
   LOJAS PAGE
   ========================================================================== */
.lojas-filter {
	padding: var(--sp-8) 0;
	background: var(--c-gray-50);
}

.lojas-filter__inner {
	display: flex;
	gap: var(--sp-4);
	flex-wrap: wrap;
}

.lojas-filter__search {
	flex: 1;
	min-width: 240px;
	position: relative;
}

.lojas-filter__search input {
	width: 100%;
	padding: var(--sp-3) var(--sp-4) var(--sp-3) var(--sp-10);
	border: 2px solid var(--c-gray-200);
	border-radius: var(--radius-full);
	font-size: var(--fs-base);
	font-family: var(--ff-body);
	transition: border-color var(--duration) var(--ease);
	background: var(--c-white);
}

.lojas-filter__search input:focus {
	outline: none;
	border-color: var(--c-green);
}

.lojas-filter__search svg {
	position: absolute;
	left: var(--sp-4);
	top: 50%;
	transform: translateY(-50%);
	color: var(--c-gray-400);
	pointer-events: none;
}

.lojas-filter__select select {
	padding: var(--sp-3) var(--sp-8) var(--sp-3) var(--sp-4);
	border: 2px solid var(--c-gray-200);
	border-radius: var(--radius-full);
	font-size: var(--fs-base);
	font-family: var(--ff-body);
	background: var(--c-white);
	appearance: none;
	cursor: pointer;
	transition: border-color var(--duration) var(--ease);
}

.lojas-filter__select select:focus {
	outline: none;
	border-color: var(--c-green);
}

.lojas-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-6);
	padding: var(--sp-10) 0;
}

/* Loja Card */
.loja-card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--duration) var(--ease);
}

.loja-card:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-4px);
}

.loja-card__image {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: linear-gradient(135deg, var(--c-green-100), var(--c-green-200));
	position: relative;
}

.loja-card__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms var(--ease);
}

.loja-card:hover .loja-card__image img { transform: scale(1.05); }

.loja-card__badge {
	position: absolute;
	top: var(--sp-3);
	left: var(--sp-3);
	background: var(--c-yellow);
	color: var(--c-gray-900);
	font-family: var(--ff-display);
	font-size: var(--fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	padding: var(--sp-1) var(--sp-3);
	border-radius: var(--radius-sm);
}

.loja-card__body { padding: var(--sp-5); }

.loja-card__numero {
	font-family: var(--ff-display);
	font-size: var(--fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--c-green);
	margin-bottom: var(--sp-2);
}

.loja-card__title {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	color: var(--c-gray-900);
	margin-bottom: var(--sp-2);
}

.loja-card__title a { color: inherit; text-decoration: none; }

.loja-card__excerpt {
	font-size: var(--fs-sm);
	color: var(--c-gray-500);
	line-height: 1.6;
	margin-bottom: var(--sp-4);
}

.loja-card__meta {
	display: flex;
	flex-direction: column;
	gap: var(--sp-2);
	font-size: var(--fs-xs);
	color: var(--c-gray-500);
}

.loja-card__meta span {
	display: flex;
	align-items: center;
	gap: var(--sp-2);
}

.loja-card__meta svg {
	width: 14px;
	height: 14px;
	color: var(--c-green);
}

/* ==========================================================================
   CONTACT PAGE
   ========================================================================== */
.contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--sp-10);
	padding: var(--sp-10) 0;
}

.contact-form .form-group { margin-bottom: var(--sp-5); }

.contact-form label {
	display: block;
	font-size: var(--fs-sm);
	font-weight: 600;
	color: var(--c-gray-700);
	margin-bottom: var(--sp-2);
}

.contact-form input,
.contact-form textarea,
.contact-form select {
	width: 100%;
	padding: var(--sp-3) var(--sp-4);
	border: 2px solid var(--c-gray-200);
	border-radius: var(--radius);
	font-size: var(--fs-base);
	font-family: var(--ff-body);
	transition: border-color var(--duration) var(--ease);
	background: var(--c-white);
}

.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
	outline: none;
	border-color: var(--c-green);
}

.contact-form textarea {
	resize: vertical;
	min-height: 120px;
}

.contact-info {
	background: var(--c-green-50);
	border-radius: var(--radius-lg);
	padding: var(--sp-8);
}

.contact-info__title {
	font-family: var(--ff-display);
	font-size: var(--fs-xl);
	font-weight: 600;
	text-transform: uppercase;
	color: var(--c-green-800);
	margin-bottom: var(--sp-6);
}

.contact-info__item {
	display: flex;
	align-items: flex-start;
	gap: var(--sp-4);
	margin-bottom: var(--sp-6);
}

.contact-info__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: var(--radius-full);
	background: var(--c-green);
	color: var(--c-white);
	flex-shrink: 0;
}

.contact-info__label {
	font-size: var(--fs-xs);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--c-gray-500);
	margin-bottom: var(--sp-1);
}

.contact-info__value {
	font-size: var(--fs-base);
	color: var(--c-gray-800);
}

.contact-info__value a { color: var(--c-green); }

.form-message {
	display: none;
	padding: var(--sp-4);
	border-radius: var(--radius);
	font-size: var(--fs-sm);
	margin-bottom: var(--sp-5);
}

.form-message--success {
	background: var(--c-green-100);
	color: var(--c-green-800);
	border: 1px solid var(--c-green-300);
}

.form-message--error {
	background: #fef2f2;
	color: #991b1b;
	border: 1px solid #fecaca;
}

/* ==========================================================================
   ABOUT PAGE
   ========================================================================== */
.about-section { padding: var(--sp-12) 0; }

.about-section__content { max-width: 800px; }

.about-section__content h2 {
	font-size: var(--fs-3xl);
	margin-bottom: var(--sp-6);
	color: var(--c-green-800);
}

.about-section__content p {
	margin-bottom: var(--sp-4);
	line-height: 1.8;
}

.values-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-6);
	margin-top: var(--sp-10);
}

.value-card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--sp-8);
	box-shadow: var(--shadow-sm);
	border-top: 4px solid var(--c-green);
	text-align: center;
}

.value-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-full);
	background: var(--c-green-50);
	color: var(--c-green);
	margin: 0 auto var(--sp-4);
}

.value-card__title {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	text-transform: uppercase;
	color: var(--c-gray-900);
	margin-bottom: var(--sp-3);
}

.value-card__text {
	font-size: var(--fs-sm);
	color: var(--c-gray-600);
	line-height: 1.7;
}

/* ==========================================================================
   AGENDA PAGE
   ========================================================================== */
.agenda-section { padding: var(--sp-10) 0; }

.agenda-section h2 {
	font-family: var(--ff-display);
	font-size: var(--fs-2xl);
	text-transform: uppercase;
	color: var(--c-green-800);
	margin-bottom: var(--sp-6);
}

.schedule-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-6);
	margin-bottom: var(--sp-10);
}

.schedule-card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--sp-6);
	box-shadow: var(--shadow-sm);
	text-align: center;
	border-top: 4px solid var(--c-green);
}

.schedule-card__day {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	text-transform: uppercase;
	color: var(--c-gray-700);
	margin-bottom: var(--sp-3);
}

.schedule-card__time {
	font-family: var(--ff-display);
	font-size: var(--fs-2xl);
	font-weight: 700;
	color: var(--c-green);
}

.schedule-card__note {
	font-size: var(--fs-sm);
	color: var(--c-gray-500);
	margin-top: var(--sp-2);
}

/* No content */
.no-content {
	text-align: center;
	padding: var(--sp-16) var(--sp-6);
}

.no-content__icon { color: var(--c-gray-300); margin-bottom: var(--sp-4); }
.no-content__icon svg { width: 64px; height: 64px; }
.no-content__title { font-family: var(--ff-display); font-size: var(--fs-2xl); color: var(--c-gray-700); margin-bottom: var(--sp-3); }
.no-content__text { color: var(--c-gray-500); margin-bottom: var(--sp-6); }

/* Pagination */
.pagination {
	display: flex;
	justify-content: center;
	gap: var(--sp-2);
	padding: var(--sp-8) 0;
}

.pagination .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--sp-3);
	border-radius: var(--radius-sm);
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--c-gray-600);
	background: var(--c-white);
	border: 1px solid var(--c-gray-200);
	text-decoration: none;
	transition: all var(--duration) var(--ease);
}

.pagination .page-numbers:hover { border-color: var(--c-green); color: var(--c-green); }
.pagination .page-numbers.current { background: var(--c-green); color: var(--c-white); border-color: var(--c-green); }

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */
.animate-on-scroll {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 600ms var(--ease), transform 600ms var(--ease);
}

.animate-on-scroll.is-visible {
	opacity: 1;
	transform: translateY(0);
}

/* ==========================================================================
   LOJAS CATEGORIES PAGE (V4)
   ========================================================================== */
.lojas-intro {
	padding: var(--sp-10) 0 var(--sp-4);
	max-width: 800px;
}

.lojas-intro p {
	line-height: 1.8;
	color: var(--c-gray-600);
	font-size: var(--fs-md);
}

.lojas-categories {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--sp-6);
	padding: var(--sp-6) 0 var(--sp-10);
}

.lojas-category-card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--sp-8);
	box-shadow: var(--shadow-sm);
	border-top: 4px solid var(--c-green);
	text-align: center;
	transition: all var(--duration) var(--ease);
}

.lojas-category-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.lojas-category-card__icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 64px;
	height: 64px;
	border-radius: var(--radius-full);
	background: var(--c-green-50);
	color: var(--c-green);
	margin: 0 auto var(--sp-4);
}

.lojas-category-card__icon svg {
	width: 28px;
	height: 28px;
}

.lojas-category-card__count {
	font-family: var(--ff-display);
	font-size: var(--fs-4xl);
	font-weight: 700;
	color: var(--c-green);
	line-height: 1;
	margin-bottom: var(--sp-1);
}

.lojas-category-card__count span {
	display: block;
	font-size: var(--fs-xs);
	font-family: var(--ff-body);
	color: var(--c-gray-400);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-top: var(--sp-1);
}

.lojas-category-card__name {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	text-transform: uppercase;
	color: var(--c-gray-800);
	margin-bottom: var(--sp-3);
}

.lojas-category-card__desc {
	font-size: var(--fs-sm);
	color: var(--c-gray-500);
	line-height: 1.6;
}

.lojas-total {
	text-align: center;
	background: linear-gradient(135deg, var(--c-green-800), var(--c-green));
	color: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--sp-8) var(--sp-6);
	margin-bottom: var(--sp-10);
}

.lojas-total__number {
	font-family: var(--ff-display);
	font-size: var(--fs-5xl);
	font-weight: 700;
	line-height: 1;
}

.lojas-total__label {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	opacity: 0.85;
	margin-top: var(--sp-2);
}

/* ==========================================================================
   ADMIN TEAM (V4)
   ========================================================================== */
.about-section__heading {
	font-family: var(--ff-display);
	font-size: var(--fs-2xl);
	text-transform: uppercase;
	color: var(--c-green-800);
	margin-bottom: var(--sp-2);
	text-align: center;
}

.admin-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: var(--sp-6);
	margin-top: var(--sp-6);
}

.admin-card {
	text-align: center;
	padding: var(--sp-6);
	background: var(--c-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	transition: all var(--duration) var(--ease);
}

.admin-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-lg);
}

.admin-card__avatar {
	width: 80px;
	height: 80px;
	border-radius: var(--radius-full);
	background: var(--c-green-50);
	color: var(--c-green-300);
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto var(--sp-4);
}

.admin-card__avatar svg {
	width: 32px;
	height: 32px;
}

.admin-card__name {
	font-family: var(--ff-display);
	font-size: var(--fs-md);
	font-weight: 600;
	color: var(--c-gray-900);
	margin-bottom: var(--sp-1);
}

.admin-card__role {
	font-size: var(--fs-sm);
	color: var(--c-green);
	font-weight: 500;
}

/* ==========================================================================
   AGENDA EVENTS & PARKING (V4)
   ========================================================================== */
.agenda-section__badge {
	display: inline-block;
	background: var(--c-green-50);
	color: var(--c-green);
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	padding: var(--sp-2) var(--sp-4);
	border-radius: var(--radius-sm);
	margin-bottom: var(--sp-6);
}

.agenda-section h2 svg {
	vertical-align: -3px;
	margin-right: var(--sp-2);
}

.events-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--sp-6);
	margin-bottom: var(--sp-6);
}

.event-card {
	background: var(--c-white);
	border-radius: var(--radius-lg);
	padding: var(--sp-6);
	box-shadow: var(--shadow-sm);
	border-left: 4px solid var(--c-yellow);
	transition: all var(--duration) var(--ease);
}

.event-card:hover {
	box-shadow: var(--shadow-lg);
}

.event-card__date {
	font-family: var(--ff-display);
	font-size: var(--fs-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--c-green);
	margin-bottom: var(--sp-2);
}

.event-card__title {
	font-family: var(--ff-display);
	font-size: var(--fs-lg);
	font-weight: 600;
	color: var(--c-gray-900);
	margin-bottom: var(--sp-2);
}

.event-card__meta {
	font-size: var(--fs-sm);
	color: var(--c-gray-500);
	display: flex;
	gap: var(--sp-4);
	margin-bottom: var(--sp-3);
}

.event-card__meta svg {
	width: 14px;
	height: 14px;
	vertical-align: -2px;
	margin-right: var(--sp-1);
}

.event-card__desc {
	font-size: var(--fs-sm);
	color: var(--c-gray-600);
	line-height: 1.6;
}

.agenda-empty {
	text-align: center;
	padding: var(--sp-10) 0;
	color: var(--c-gray-400);
}

.agenda-empty svg {
	width: 48px;
	height: 48px;
	margin-bottom: var(--sp-3);
}

.agenda-empty p {
	font-size: var(--fs-md);
	color: var(--c-gray-500);
}

.parking-table {
	width: 100%;
	border-collapse: collapse;
	border-radius: var(--radius-sm);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	margin-bottom: var(--sp-6);
}

.parking-table th,
.parking-table td {
	padding: var(--sp-3) var(--sp-4);
	text-align: left;
	font-size: var(--fs-sm);
}

.parking-table th {
	background: var(--c-green);
	color: var(--c-white);
	font-family: var(--ff-display);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.parking-table td {
	border-bottom: 1px solid var(--c-gray-100);
	color: var(--c-gray-700);
}

.parking-table tr:nth-child(even) td {
	background: var(--c-gray-50);
}

.parking-table tr:last-child td {
	font-weight: 700;
	background: var(--c-green-50);
	color: var(--c-green-800);
	border-bottom: none;
}

/* ==========================================================================
   PROMOCOES PAGE (V4)
   ========================================================================== */
.promocoes-section {
	padding: var(--sp-10) 0;
}

.promocoes-banner {
	background: linear-gradient(135deg, var(--c-yellow), var(--c-yellow-dark));
	border-radius: var(--radius-lg);
	padding: var(--sp-8);
	text-align: center;
	margin-bottom: var(--sp-8);
}

.promocoes-banner svg {
	width: 40px;
	height: 40px;
	color: var(--c-gray-800);
	margin-bottom: var(--sp-3);
}

.promocoes-banner__title {
	font-family: var(--ff-display);
	font-size: var(--fs-2xl);
	font-weight: 700;
	text-transform: uppercase;
	color: var(--c-gray-900);
	margin-bottom: var(--sp-2);
}

.promocoes-banner__subtitle {
	font-size: var(--fs-md);
	color: var(--c-gray-700);
}

.promocoes-content {
	max-width: 800px;
}

.promocoes-content p {
	line-height: 1.8;
	margin-bottom: var(--sp-4);
	color: var(--c-gray-600);
}

.promocoes-empty {
	text-align: center;
	padding: var(--sp-16) 0;
	color: var(--c-gray-400);
}

.promocoes-empty svg {
	width: 64px;
	height: 64px;
	margin-bottom: var(--sp-4);
}

.promocoes-empty p {
	font-size: var(--fs-lg);
	color: var(--c-gray-500);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 1024px) {
	.lojas-grid { grid-template-columns: repeat(2, 1fr); }
	.lojas-categories { grid-template-columns: repeat(2, 1fr); }
	.values-grid { grid-template-columns: repeat(2, 1fr); }
	.schedule-grid { grid-template-columns: repeat(2, 1fr); }
	.events-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
	:root {
		--header-h: 64px;
		--fs-3xl: 2rem;
		--fs-4xl: 2.5rem;
		--fs-5xl: 3.5rem;
	}

	.menu-toggle { display: flex; }
	.main-nav { display: none; }

	.home-wrapper { padding: var(--sp-3) var(--sp-3) 0; }
	.home-hero-band .home-wrapper { padding: 0; }
	.home-highlights { gap: var(--sp-2); }
	.home-highlights__card img { aspect-ratio: 3 / 4; }
	.home-hero .carousel__slide { aspect-ratio: 4 / 5; max-height: 70vh; }
	.home-hero .carousel__dots { bottom: var(--sp-4); }

	.home-news { padding-top: 32px; }
	.home-news__headings { gap: var(--sp-3); }
	.home-news__cards { gap: var(--sp-4); }
	.home-news__link { max-width: 100%; }

	.footer__grid { grid-template-columns: 1fr; gap: var(--sp-6); }

	.contact-grid { grid-template-columns: 1fr; }
	.lojas-grid { grid-template-columns: 1fr; }
	.lojas-categories { grid-template-columns: 1fr; }
	.values-grid { grid-template-columns: 1fr; }
	.schedule-grid { grid-template-columns: 1fr; }
	.events-grid { grid-template-columns: 1fr; }
	.admin-grid { grid-template-columns: repeat(2, 1fr); }

	.page-hero { padding: var(--sp-10) 0 var(--sp-8); }
	.page-hero__title { font-size: var(--fs-3xl); }
}

@media (max-width: 480px) {
	.container { padding: 0 var(--sp-4); }
	.home-wrapper { padding: var(--sp-2) var(--sp-2) 0; }
	.home-news__title { font-size: var(--fs-2xl); }
}
