/* =========================================================
   Movy Esportes — Theme overrides
   Loaded after default stylesheet.css; only overrides
   visual layer, never removes OpenCart blocks.
   ========================================================= */

:root {
	--movy-primary: #FF6B00;
	--movy-primary-dark: #E55B00;
	--movy-primary-light: #FF8A33;
	--movy-dark: #0F0F0F;
	--movy-dark-soft: #1A1A1A;
	--movy-dark-2: #242424;
	--movy-text: #2B2B2B;
	--movy-muted: #6F6F6F;
	--movy-line: #ECECEC;
	--movy-bg: #FAFAFA;
	--movy-white: #FFFFFF;
	--movy-radius: 10px;
	--movy-radius-lg: 18px;
	--movy-shadow: 0 6px 24px rgba(0,0,0,.08);
	--movy-shadow-lg: 0 12px 40px rgba(0,0,0,.12);
	--movy-transition: all .25s ease;
}

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800&display=swap');

/* ---------- Base ---------- */
html, body {
	background: var(--movy-white);
}
body {
	font-family: 'Poppins', 'Open Sans', sans-serif;
	font-size: 14px;
	line-height: 1.6;
	color: var(--movy-text);
	-webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4, h5, h6 {
	font-family: 'Poppins', sans-serif;
	color: var(--movy-dark);
	font-weight: 700;
	letter-spacing: -0.01em;
}
h1 { font-size: 36px; }
h2 { font-size: 28px; }
h3 { font-size: 22px; }
h4 { font-size: 17px; }
h5 { font-size: 14px; }
a {
	color: var(--movy-primary);
	transition: var(--movy-transition);
}
a:hover, a:focus {
	color: var(--movy-primary-dark);
	text-decoration: none;
}

/* ---------- Topbar promocional ---------- */
.movy-topbar {
	background: var(--movy-dark);
	color: #fff;
	font-size: 12.5px;
	letter-spacing: .02em;
	padding: 9px 0;
}
.movy-topbar a { color: #fff; }
.movy-topbar a:hover { color: var(--movy-primary-light); }
.movy-topbar .movy-topbar-left,
.movy-topbar .movy-topbar-right {
	display: flex;
	align-items: center;
	gap: 18px;
	flex-wrap: wrap;
}
.movy-topbar .movy-topbar-right { justify-content: flex-end; }
.movy-topbar .fa { color: var(--movy-primary); margin-right: 6px; }

/* ---------- Top OpenCart (currency/language/login) ---------- */
#top {
	background: #fff !important;
	border-bottom: 1px solid var(--movy-line);
	padding: 6px 0 !important;
	margin: 0 !important;
	min-height: 36px !important;
}
#top .container { padding: 0 20px; }
#top-links { padding-top: 4px; }
#top-links li, #top-links a, #top .btn-link {
	color: var(--movy-muted) !important;
	text-shadow: none !important;
	font-size: 12.5px;
}
#top-links a:hover, #top .btn-link:hover {
	color: var(--movy-primary) !important;
}
#top .btn-link strong { font-weight: 600; }
#top #form-currency .currency-select:hover,
#top #form-language .language-select:hover {
	background: var(--movy-primary) !important;
	background-image: none !important;
	color: #fff !important;
	text-shadow: none !important;
}
#top-links .dropdown-menu {
	border: 1px solid var(--movy-line);
	border-radius: var(--movy-radius);
	box-shadow: var(--movy-shadow);
	padding: 6px 0;
}
.dropdown-menu li > a:hover {
	background: var(--movy-primary) !important;
	background-image: none !important;
	color: #fff !important;
}

/* ---------- Header ---------- */
header {
	padding: 22px 0 18px !important;
	border-bottom: 1px solid var(--movy-line);
}
#logo { margin: 0; padding-top: 4px; }
#logo img {
	max-height: 56px;
	width: auto;
	transition: var(--movy-transition);
}

/* ---------- Search ---------- */
#search {
	margin-bottom: 0;
	border-radius: 50px;
	overflow: hidden;
	border: 2px solid var(--movy-line);
	background: var(--movy-bg);
	transition: var(--movy-transition);
}
#search:focus-within {
	border-color: var(--movy-primary);
	background: #fff;
	box-shadow: 0 0 0 4px rgba(255, 107, 0, .12);
}
#search .input-lg {
	height: 46px;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	font-size: 13.5px;
	padding-left: 22px;
}
#search .btn-lg {
	height: 46px;
	background: var(--movy-primary) !important;
	background-image: none !important;
	border: none !important;
	color: #fff !important;
	text-shadow: none !important;
	padding: 0 26px;
	font-size: 16px;
	border-radius: 50px;
	margin: 0;
}
#search .btn-lg:hover { background: var(--movy-primary-dark) !important; }

/* ---------- Cart ---------- */
#cart {
	margin-bottom: 0;
}
#cart > .btn {
	background: var(--movy-dark) !important;
	background-image: none !important;
	border: none !important;
	border-radius: 50px;
	height: 46px;
	font-weight: 600;
	font-size: 13px;
	color: #fff !important;
	text-shadow: none !important;
	padding: 0 22px;
	transition: var(--movy-transition);
}
#cart > .btn:hover { background: var(--movy-primary) !important; }
#cart > .btn .fa { margin-right: 6px; font-size: 15px; }
#cart.open > .btn {
	background: var(--movy-primary) !important;
	color: #fff !important;
	border: none !important;
}
#cart .dropdown-menu {
	background: #fff;
	border: 1px solid var(--movy-line);
	border-radius: var(--movy-radius);
	box-shadow: var(--movy-shadow-lg);
	padding: 12px;
}

/* ---------- Menu de categorias ---------- */
#menu {
	background: var(--movy-dark) !important;
	background-image: none !important;
	border: none !important;
	border-radius: 0 !important;
	min-height: 50px;
	margin-bottom: 0;
}
#menu .nav > li > a {
	color: #fff !important;
	text-shadow: none !important;
	font-weight: 500;
	font-size: 13.5px;
	letter-spacing: .02em;
	padding: 15px 18px !important;
	position: relative;
	transition: var(--movy-transition);
}
#menu .nav > li > a:hover,
#menu .nav > li.open > a {
	background: transparent !important;
	color: var(--movy-primary) !important;
}
#menu .nav > li > a::after {
	content: '';
	position: absolute;
	left: 18px; right: 18px; bottom: 8px;
	height: 2px;
	background: var(--movy-primary);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform .25s ease;
}
#menu .nav > li > a:hover::after,
#menu .nav > li.open > a::after { transform: scaleX(1); }
#menu .dropdown-menu {
	border: 1px solid var(--movy-line);
	border-radius: var(--movy-radius);
	box-shadow: var(--movy-shadow-lg);
	padding: 14px 0 0;
	margin-top: 0;
}
#menu .dropdown-inner a {
	color: var(--movy-text) !important;
	font-size: 13px;
	padding: 6px 22px !important;
	font-weight: 500;
	transition: var(--movy-transition);
}
#menu .dropdown-inner a:hover {
	color: var(--movy-primary) !important;
	background: transparent !important;
	padding-left: 26px !important;
}
#menu .see-all {
	background: var(--movy-bg);
	color: var(--movy-dark) !important;
	font-weight: 600;
	font-size: 12.5px;
	padding: 12px 22px !important;
	border-top: 1px solid var(--movy-line);
}
#menu .see-all:hover {
	background: var(--movy-primary) !important;
	background-image: none !important;
	color: #fff !important;
}
#menu .btn-navbar {
	background: var(--movy-primary) !important;
	background-image: none !important;
	border: none !important;
	border-radius: 6px;
}
#menu #category {
	color: #fff;
	text-shadow: none;
	font-weight: 600;
	font-size: 14px;
}

/* ---------- Hero ---------- */
.movy-hero {
	position: relative;
	border-radius: var(--movy-radius-lg);
	overflow: hidden;
	margin: 28px 0 32px;
	background: var(--movy-dark);
	box-shadow: var(--movy-shadow-lg);
	min-height: 360px;
	display: flex;
	align-items: stretch;
}
.movy-hero img.movy-hero-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}
.movy-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(15,15,15,.85) 0%, rgba(15,15,15,.55) 45%, rgba(15,15,15,0) 70%);
	z-index: 1;
}
.movy-hero-content {
	position: relative;
	z-index: 2;
	padding: 64px 56px;
	max-width: 620px;
	color: #fff;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.movy-hero-eyebrow {
	display: inline-block;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: .25em;
	text-transform: uppercase;
	color: var(--movy-primary);
	margin-bottom: 14px;
}
.movy-hero h1 {
	color: #fff;
	font-size: 44px;
	font-weight: 800;
	line-height: 1.1;
	margin: 0 0 18px;
}
.movy-hero p {
	font-size: 16px;
	line-height: 1.55;
	margin-bottom: 26px;
	color: #DADADA;
	max-width: 480px;
}
.movy-hero .movy-btn { align-self: flex-start; }

/* ---------- Botões ---------- */
.movy-btn,
.btn-primary {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--movy-primary) !important;
	background-image: none !important;
	border: none !important;
	color: #fff !important;
	font-weight: 600;
	font-size: 13.5px;
	letter-spacing: .02em;
	padding: 13px 28px;
	border-radius: 50px;
	text-shadow: none !important;
	box-shadow: 0 8px 20px rgba(255,107,0,.28);
	transition: var(--movy-transition);
	cursor: pointer;
}
.movy-btn:hover,
.btn-primary:hover {
	background: var(--movy-primary-dark) !important;
	color: #fff !important;
	transform: translateY(-2px);
	box-shadow: 0 12px 26px rgba(255,107,0,.35);
}
.movy-btn-ghost {
	background: transparent !important;
	color: #fff !important;
	border: 2px solid #fff !important;
	box-shadow: none;
}
.movy-btn-ghost:hover {
	background: #fff !important;
	color: var(--movy-dark) !important;
}
.btn-default, .btn-info, .btn-inverse {
	border-radius: 50px;
}

/* ---------- Faixa de benefícios ---------- */
.movy-benefits {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
	margin: 0 0 36px;
}
.movy-benefit {
	background: #fff;
	border: 1px solid var(--movy-line);
	border-radius: var(--movy-radius);
	padding: 20px 22px;
	display: flex;
	align-items: center;
	gap: 14px;
	transition: var(--movy-transition);
}
.movy-benefit:hover {
	transform: translateY(-3px);
	box-shadow: var(--movy-shadow);
	border-color: rgba(255,107,0,.3);
}
.movy-benefit-icon {
	width: 46px; height: 46px;
	display: grid; place-items: center;
	background: rgba(255,107,0,.10);
	border-radius: 50%;
	color: var(--movy-primary);
	font-size: 18px;
	flex-shrink: 0;
}
.movy-benefit-text strong {
	display: block;
	font-size: 13.5px;
	color: var(--movy-dark);
	font-weight: 700;
	margin-bottom: 2px;
}
.movy-benefit-text span {
	font-size: 12px;
	color: var(--movy-muted);
	line-height: 1.35;
	display: block;
}

/* ---------- Section heading ---------- */
.movy-section-heading {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	margin-bottom: 22px;
	gap: 16px;
	flex-wrap: wrap;
}
.movy-section-heading h2 {
	margin: 0;
	font-size: 26px;
	font-weight: 700;
}
.movy-section-heading .movy-eyebrow {
	display: block;
	font-size: 12px;
	color: var(--movy-primary);
	font-weight: 700;
	letter-spacing: .25em;
	text-transform: uppercase;
	margin-bottom: 6px;
}
.movy-section-heading a {
	font-size: 13px;
	font-weight: 600;
	color: var(--movy-dark);
	display: inline-flex;
	align-items: center;
	gap: 6px;
}
.movy-section-heading a:hover { color: var(--movy-primary); }

/* ---------- Banner secundário ---------- */
.movy-promo {
	position: relative;
	border-radius: var(--movy-radius-lg);
	overflow: hidden;
	margin: 36px 0;
	min-height: 220px;
	display: flex;
	align-items: center;
	box-shadow: var(--movy-shadow);
	background: var(--movy-dark);
}
.movy-promo img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: .75;
}
.movy-promo::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(15,15,15,.7), rgba(15,15,15,.2));
}
.movy-promo-content {
	position: relative;
	z-index: 2;
	padding: 36px 48px;
	color: #fff;
}
.movy-promo h3 {
	color: #fff;
	font-size: 28px;
	font-weight: 800;
	margin: 0 0 8px;
	line-height: 1.15;
	max-width: 460px;
}
.movy-promo p {
	color: #E0E0E0;
	margin: 0 0 18px;
	max-width: 380px;
}

/* ---------- Newsletter ---------- */
.movy-newsletter {
	margin: 48px 0 12px;
	padding: 44px 48px;
	background: linear-gradient(135deg, var(--movy-primary) 0%, #FF8E3C 100%);
	border-radius: var(--movy-radius-lg);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 28px;
	flex-wrap: wrap;
	box-shadow: var(--movy-shadow-lg);
}
.movy-newsletter h3 {
	color: #fff;
	font-size: 26px;
	margin: 0 0 6px;
	font-weight: 800;
}
.movy-newsletter p {
	margin: 0;
	color: rgba(255,255,255,.92);
	font-size: 14px;
}
.movy-newsletter form {
	display: flex;
	gap: 10px;
	flex: 1;
	min-width: 320px;
	max-width: 460px;
}
.movy-newsletter input[type="email"] {
	flex: 1;
	height: 50px;
	padding: 0 22px;
	border-radius: 50px;
	border: none;
	font-size: 14px;
	color: var(--movy-dark);
	box-shadow: 0 6px 18px rgba(0,0,0,.10);
}
.movy-newsletter button {
	height: 50px;
	padding: 0 28px;
	border-radius: 50px;
	border: none;
	background: var(--movy-dark);
	color: #fff;
	font-weight: 600;
	font-size: 13.5px;
	cursor: pointer;
	transition: var(--movy-transition);
}
.movy-newsletter button:hover { background: #000; }

/* ---------- Cards de produto / categoria genéricos ---------- */
.product-thumb,
.product-layout .product-thumb {
	border: 1px solid var(--movy-line) !important;
	border-radius: var(--movy-radius);
	overflow: hidden;
	background: #fff;
	transition: var(--movy-transition);
	margin-bottom: 24px;
}
.product-thumb:hover {
	border-color: rgba(255,107,0,.3) !important;
	transform: translateY(-4px);
	box-shadow: var(--movy-shadow);
}
.product-thumb .image { background: var(--movy-bg); padding: 12px; }
.product-thumb .image img { transition: transform .35s ease; }
.product-thumb:hover .image img { transform: scale(1.04); }
.product-thumb .caption { padding: 16px 18px; }
.product-thumb h4 { font-size: 14.5px; margin: 0 0 8px; font-weight: 600; }
.product-thumb h4 a { color: var(--movy-dark); }
.product-thumb h4 a:hover { color: var(--movy-primary); }
.product-thumb .price {
	color: var(--movy-dark);
	font-weight: 700;
	font-size: 18px;
	margin-bottom: 10px;
}
.product-thumb .price-old {
	color: var(--movy-muted);
	text-decoration: line-through;
	font-size: 13px;
	font-weight: 500;
	margin-right: 6px;
}
.product-thumb .price-new { color: var(--movy-primary); }
.product-thumb .button-group {
	border-top: 1px solid var(--movy-line);
	background: transparent;
	overflow: hidden;
}
.product-thumb .button-group button {
	background: transparent !important;
	background-image: none !important;
	border: none !important;
	color: var(--movy-muted) !important;
	text-shadow: none !important;
	font-size: 12.5px;
	font-weight: 600;
	padding: 12px 8px !important;
	transition: var(--movy-transition);
}
.product-thumb .button-group button:hover {
	color: var(--movy-primary) !important;
	background: var(--movy-bg) !important;
}
.product-thumb .button-group button + button {
	border-left: 1px solid var(--movy-line) !important;
}

/* ---------- Breadcrumb ---------- */
.breadcrumb {
	background: transparent;
	border: none !important;
	padding: 14px 0 !important;
	margin-bottom: 18px !important;
	font-size: 12.5px;
}
.breadcrumb > li { padding: 0 12px 0 0 !important; text-shadow: none !important; }
.breadcrumb > li:after { display: none !important; }
.breadcrumb > li + li:before {
	content: '/' !important;
	padding: 0 10px 0 0 !important;
	color: var(--movy-muted);
}
.breadcrumb a { color: var(--movy-muted); }
.breadcrumb a:hover { color: var(--movy-primary); }
.breadcrumb > .active { color: var(--movy-dark); font-weight: 600; }

/* ---------- Pagination ---------- */
.pagination > li > a, .pagination > li > span {
	border-radius: 6px !important;
	margin: 0 3px;
	border: 1px solid var(--movy-line) !important;
	color: var(--movy-text);
}
.pagination > .active > a,
.pagination > .active > span,
.pagination > li > a:hover {
	background: var(--movy-primary) !important;
	border-color: var(--movy-primary) !important;
	color: #fff !important;
}

/* ---------- Footer ---------- */
footer {
	margin-top: 56px !important;
	padding-top: 56px !important;
	background: var(--movy-dark) !important;
	border-top: none !important;
	color: #BDBDBD !important;
}
footer .container { max-width: 1170px; }
footer h5 {
	color: #fff !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	margin-bottom: 18px;
	letter-spacing: .04em;
	text-transform: uppercase;
}
footer ul { padding: 0; }
footer ul li { margin-bottom: 8px; list-style: none; }
footer a {
	color: #BDBDBD !important;
	font-size: 13px;
	transition: var(--movy-transition);
}
footer a:hover {
	color: var(--movy-primary) !important;
	padding-left: 4px;
}
footer hr {
	border-top: 1px solid rgba(255,255,255,.08) !important;
	border-bottom: none !important;
	margin: 32px 0 22px;
}
footer p { font-size: 12.5px; color: #888; margin: 0; }

.movy-footer-brand img {
	max-height: 50px;
	margin-bottom: 16px;
	filter: brightness(1.05);
}
.movy-footer-about {
	font-size: 13px;
	line-height: 1.7;
	color: #B0B0B0;
	margin-bottom: 18px;
}
.movy-footer-contact li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	font-size: 13px;
	color: #BDBDBD;
}
.movy-footer-contact .fa {
	color: var(--movy-primary);
	font-size: 14px;
	margin-top: 4px;
	flex-shrink: 0;
}
.movy-social {
	display: flex;
	gap: 10px;
	margin-top: 16px;
}
.movy-social a {
	width: 38px; height: 38px;
	display: grid; place-items: center;
	background: rgba(255,255,255,.06);
	color: #fff !important;
	border-radius: 50%;
	font-size: 15px;
	transition: var(--movy-transition);
}
.movy-social a:hover {
	background: var(--movy-primary);
	color: #fff !important;
	transform: translateY(-3px);
	padding-left: 0;
}
.movy-payments {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}
.movy-payments span {
	background: rgba(255,255,255,.07);
	color: #DADADA;
	border-radius: 6px;
	padding: 6px 10px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.movy-footer-bottom {
	background: #000;
	margin-top: 22px;
	padding: 16px 0;
	font-size: 12px;
	color: #888;
}
.movy-footer-bottom .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 10px;
}

/* ---------- Forms genéricos ---------- */
.form-control {
	border-radius: 8px;
	border-color: var(--movy-line);
	height: 40px;
	padding: 8px 14px;
	box-shadow: none;
	transition: var(--movy-transition);
}
.form-control:focus {
	border-color: var(--movy-primary);
	box-shadow: 0 0 0 3px rgba(255,107,0,.12);
}

/* ---------- Alerts ---------- */
.alert { border-radius: 8px; border: none; }
.alert-success { background: #E8F7EE; color: #1F7A3A; }
.alert-danger { background: #FDE8E8; color: #B41E1E; }

/* ---------- Responsive ---------- */
@media (max-width: 991px) {
	.movy-hero-content { padding: 44px 36px; }
	.movy-hero h1 { font-size: 34px; }
	.movy-benefits { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 767px) {
	header { padding: 16px 0 !important; }
	#logo { text-align: center; margin-bottom: 14px; }
	#search, #cart { margin-bottom: 12px; }
	.movy-topbar .movy-topbar-right { display: none; }
	.movy-hero { min-height: 280px; }
	.movy-hero::after {
		background: linear-gradient(180deg, rgba(15,15,15,.4) 0%, rgba(15,15,15,.85) 70%);
	}
	.movy-hero-content { padding: 32px 24px; max-width: 100%; }
	.movy-hero h1 { font-size: 26px; }
	.movy-hero p { font-size: 14px; }
	.movy-benefits { grid-template-columns: 1fr; }
	.movy-promo-content { padding: 24px; }
	.movy-promo h3 { font-size: 22px; }
	.movy-newsletter { padding: 28px 22px; flex-direction: column; align-items: stretch; text-align: center; }
	.movy-newsletter form { flex-direction: column; min-width: 100%; }
	.movy-newsletter input[type="email"], .movy-newsletter button { width: 100%; }
	#menu .nav > li > a::after { display: none; }
	.movy-footer-bottom .container { flex-direction: column; text-align: center; }
}
