/* General */
body {
	overflow-x: hidden;
	max-width: 100dvw;
}

* { box-sizing: border-box; }
a { color: #070; text-decoration: none; }
a, a:hover {
	text-decoration: none !important;
	color: inherit;
}

/* BS5 Custom */
:root {
	--nav-h: 64px;
	--muted: #a0a8b8;
	--ok: #22c55e;
	--danger: #ef4444;
	--bg: #191919;
	--bs-body-bg: #191919;
	--bs-body-bg: #191919;
	--bs-body-color: #e5e7eb;
	--bs-card-color: #e5e7eb;
	--menu-bg: #262626;
	--text: #e5e7eb;
	--muted: #a3b1c5;
	--stroke: #1f2937;
	--brand-a: #8f2bc1;
	--brand-b: #b245e8;
	--badge: #482659;
	--good: #00ff00;
	--green: #22c55e;
	--shadow: 0 14px 32px rgba(0, 0, 0, .38);
	--radius: 18px;
	--bs-secondary-color: rgba(255,255,255,.4);
	
	--bs-form-valid-border-color: #198754;
	
	--od-green: #070;
	--od-surface: #0e1219;
	--od-border: rgba(255, 255, 255, .08);
	--od-muted: #9aa3b2;
	--od-ring: rgba(0, 119, 0, .35);
	--od-purple: #7c3aed;
	--od-purple-2: #a78bfa;
	--od-purple-ring: rgba(124, 58, 237, .35);
}
.list-group {
    --bs-list-group-action-hover-color: #ababab;
    --bs-list-group-action-hover-bg: #222;
}
.alert.slide {
  transform: translateY(100%);
  opacity: 0;
  transition: all 0.3s ease;
}
.alert.slide.show {
  transform: translateY(0);
  opacity: 1;
}
.alert.alert-toast {
  z-index: 99999;
  width: 480px;
  max-width: calc(100vw - 40px);
  min-width: 180px;
  max-height: 160px;
  pointer-events: all;	
}

.form-control::placeholder {
  color: #fff !important;
  opacity: .3 !important;
}
.fs-7 { font-size: .9rem!important; }
.fs-8 { font-size: .75rem!important; }

.cursor-default { cursor: default!important; }

#signToastPlaceholder { z-index: 100000; pointer-events: none; opacity: .9;}
#signToastPlaceholder .btn-close:focus,
#signToastPlaceholder .btn-close:active,
#signToastPlaceholder .btn-close:focus:active {
  box-shadow: none !important;
  outline: none !important;
}

/* Buttons */
.btn-primary {
	--bs-btn-bg: #070;
	--bs-btn-border-color: #070;
	--bs-btn-hover-bg: #060;
	--bs-btn-hover-border-color: #060;
	--bs-btn-active-bg: #050;
	--bs-btn-active-border-color: #050;
	--bs-btn-color: #fff;
	--bs-btn-hover-color: #fff;
	--bs-btn-active-color: #fff;
}
.btn-outline-danger {
	--bs-btn-color: var(--danger);
	--bs-btn-border-color: var(--danger);
}
.btn-outline-danger:hover {
	--bs-btn-color: #fff;
	--bs-btn-bg: var(--danger);
}
.btn-secondary {
	--bs-btn-bg: #8cef1f;
	--bs-btn-color: #0b0d12;
	--bs-btn-font-weight: 700;
	--bs-btn-border-color: #8cef1f;
	--bs-btn-hover-bg: #79d012;
	--bs-btn-hover-border-color: #79d012;
	--bs-btn-hover-color: #0b0d12;
	--bs-btn-active-color: #fff;
 	--bs-btn-active-bg: transparent;
	--bs-btn-active-border-color: #fff;
}
.badge {
    --bs-badge-color: #fff;
    background: rgba(88, 0, 122, .85);
}

/* Cards */
.card {
	border: 1px solid var(--stroke);
	background: linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, .015));
	box-shadow: var(--shadow);
}
.card .card {
	box-shadow: none;
	background: rgba(255, 255, 255, 0);
}
.card-header {
	border-bottom: 1px solid var(--stroke);
}
/* Layout */
.main-page { min-height: 100vh; }

/* Top bar */
.site-topbar {
	position: sticky;
	top: 0;
	width: 100%;
	z-index: 999;
	color: #fff;
	background: rgba(0, 0, 0, 0.3);
	backdrop-filter: blur(8px);
}
.site-topbar .logo-box img {
	width: auto;
	height: 48px;
	adisplay: grid;
	aplace-items: center;
	abackground: transparent;
	aborder: none;
	aborder-radius: 0;
}
.site-topbar .logo-box span {
	font-size: 12px;
	color: #a3a3a3;
}

/* Boxes */
.boxed {
    border: 1px solid #2b313a;
    border-radius: 16px;
    background: radial-gradient(120% 120% at 0% 0%, rgba(255, 255, 255, .04) 0%, rgba(255, 255, 255, 0) 60%), rgba(16, 20, 27, .55);
    box-shadow: 0 6px 24px rgba(0, 0, 0, .25);
    padding: 2rem;	
}

/* Main Nav */
.nav-shell {
	display: grid;
	grid-template-columns: 190px 1fr auto;
	align-items: center;
	gap: 4px;
}
@media (max-width: 1024px) {
	.nav-shell {
		grid-template-columns: 1fr;
		row-gap: 8px;
	}
}

.micro-brand {
	display: grid;
	place-items: center;
	padding: 10px 0;
}
.micro-brand img {
	height: 26px;
}

@media (min-width: 992px) {
	.profile-info {
		max-width: 180px;
	}
}

.pma-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 26px;
	border-radius: 10px;
	background: #e5edf9;
	color: #0b0f1a;
	border: 1px solid #c7d4ea;
	cursor: pointer;
	transition: .18s ease;
}
.pma-btn:hover {
	transform: translateY(-1px);
	box-shadow: 0 6px 14px rgba(0, 0, 0, .08);
}
.pma-btn:active {
	transform: none;
}
.pma-btn i {
	font-size: 12px;
	line-height: 1;
}
.pma-count {
	position: absolute;
	top: -15px;
	right: -6px;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	border-radius: 999px;
	background: #070;
	color: #e5e7eb;
	border: 1px solid #080;
	font-size: 9px;
	font-weight: 700;
	line-height: 18px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .25);
}
.pma-btn[data-action="favorites"]:hover i { color: #ef4444; }
.pma-btn[data-action="comments"]:hover i { color: #22c55e; }
.pma-btn[data-action="history"]:hover i { color: #60a5fa; }

.menu .item {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	height: 28px;
	line-height: 1;
	font-size: 13px;
	font-weight: 600;
	color: #d1d5db;
	text-align: center;
}
.menu .item svg {
	width: 14px;
	height: 14px;
	color: #22e065;
	flex: none;
}
.menu .pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	background: rgba(34, 224, 101, .1);
	border: 1px solid rgba(34, 224, 101, .35);
	border-radius: 8px;
	padding: 3px 6px;
	font-size: 12px;
	height: 24px;
}


/* Mobile NAV */
#mobileNav .btn-nav-toggle {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 6px;
	background-color: #333;
}
#mobileNav .btn-nav-toggle:hover {
	background-color: #444;
}
#mobileNav .btn-nav-toggle i {
	color: rgb(241, 245, 249);
	font-size: 24px;
	line-height: 24px;
}
#mobileNavOffCanvas {
	height: 100dvh;
	background: #262626;
}
#mobileNavOffCanvas .mobile-nav {
	border-left: 1px solid #1f2937;
	padding: 18px;
	z-index: 100;	
}
#mobileNavOffCanvas .mobile-nav ul {
	list-style: none;
	margin: 0;
	padding: 12px 0 0 0;
	display: flex;
	flex-direction: column;
	gap: 10px;
}
#mobileNavOffCanvas .mobile-nav a {
	display: block;
	padding: 12px 10px;
	border-radius: 10px;
	background: #1f1f1f;
	color: #e5e7eb;
	font-weight: 700;
	text-decoration: none;
}
#mobileNavOffCanvas .mobile-nav a:hover {
	background: #222;
	color: #00ff00;
}
#mobileNavOffCanvas .mobile-nav a svg {
	vertical-align: -2px;
	margin-right: 4px;
}

/* Avatar */
.sign-avatar {
	flex: none;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 800;
	background: #f0f0f0;
	color: #aaa;
	border: 2px solid #aaa;
	font-size: 20px;
}
.sign-avatar.color1 {color: #155e75; border-color: #155e75; background: #a5f3fc;}
.sign-avatar.color2 {color: #1e3a8a; border-color: #1e3a8a; background: #bfdbfe;}
.sign-avatar.color3 {color: #0d3b66; border-color: #0d3b66; background: #9dd9f3;}
.sign-avatar.color4 {color: #312e81; border-color: #312e81; background: #c7d2fe;}
.sign-avatar.color5 {color: #4c1d95; border-color: #4c1d95; background: #e9d5ff;}
.sign-avatar.color6 {color: #831843; border-color: #831843; background: #fbcfe8;}
.sign-avatar.color7 {color: #1f2937; border-color: #1f2937; background: #e5e7eb;}
.sign-avatar.color8 {color: #00332a; border-color: #00332a; background: #b9fbc0;}
.sign-avatar.color9 {color: #14532d; border-color: #14532d; background: #bbf7d0;}
.sign-avatar.color10 {color: #3f6212; border-color: #3f6212; background: #d9f99d;}
.sign-avatar.color11 {color: #7c2d12; border-color: #7c2d12; background: #fed7aa;}
.sign-avatar.color12 {color: #3e1f0d; border-color: #3e1f0d; background: #f5deb3;}
.sign-avatar.color13 {color: #78350f; border-color: #78350f; background: #fef9c3;}
.sign-avatar.color14 {color: #78350f; border-color: #78350f; background: #fcd34d;}
.sign-avatar.color15 {color: #7f1d1d; border-color: #7f1d1d; background: #fecaca;}

/* Formulário */

.form-control:focus,
.form-select:focus {
	border-color: var(--od-green);
	box-shadow: 0 0 0 .25rem var(--od-ring);
	outline: none;
}

label { white-space: nowrap; }
form .row > div { padding-bottom: 4px; }
form [data-mandatory="true"] label:after {
	content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="11px" height="11px" viewBox="0 -960 960 960" fill="%23ee0000"><path d="M440-120v-264L254-197l-57-57 187-186H120v-80h264L197-706l57-57 186 187v-264h80v264l186-187 57 57-187 186h264v80H576l187 186-57 57-186-187v264h-80Z"/></svg>');
	display: inline-block;
	width: 11px;
	height: 11px;
	vertical-align: -1px;
	margin-left: 3px;
}
form [data-mandatory="true"] label {
	position: relative;
	cursor: help;
}
form [data-mandatory="true"] label:before {
	position: absolute;
	top: 0px;
	left: calc(100% + 6px);
	content: 'Obrigatório';
	padding: 2px 4px;
	background: #fef4c5;
	border: 1px solid #d4b943;
	font-size: 11px;
	border-radius: 3px;
	color: #222;
	display: none;
	opacity: .7;
}
form [data-mandatory="true"] label:hover:before { display: block; }
form.is-validation [data-mandatory="true"][data-absent="true"] { background: rgba(204,0,0,.05); }
form.is-validation [data-mandatory="true"][data-absent="true"] .frm-content { color: #cc0000!important; }

form[data-form="toggleable"] .frm-input { display: none; }
form[data-form="toggleable"] .frm-content { display: block; width: 100%; font-weight: bold;}
form[data-form="toggleable"].frm-editting .frm-content { display: none; }
form[data-form="toggleable"].frm-editting .frm-input { display: block; }
form[data-form="toggleable"] label {color: rgba(255,255,255,.6);}

form input::-webkit-calendar-picker-indicator,
form input::-webkit-clear-button,
form input::-webkit-inner-spin-button {
    filter: invert(1);
    cursor: pointer;
}
select[data-subset].subset-loading {
	animation: bgwaves 6s infinite linear;
	background: #ddd linear-gradient(to right, rgba(255, 255, 255, 0), rgba(255, 255, 255, .9), rgba(255, 255, 255, 0));
}
@keyframes bgwaves { from {background-position: 0% top;} to { background-position: 1000px top; } }

/* Botão revelar passowrd */
[data-form="password-revealer"]:focus,
[data-form="password-revealer"]:active {
	outline: none;
	box-shadow: none;
}
[data-form="password-revealer"]:before {
	width: 24px;
	height: 24px;
	display: block;
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="%236C757D"><path d="m644-428-58-58q9-47-27-88t-93-32l-58-58q17-8 34.5-12t37.5-4q75 0 127.5 52.5T660-500q0 20-4 37.5T644-428Zm128 126-58-56q38-29 67.5-63.5T832-500q-50-101-143.5-160.5T480-720q-29 0-57 4t-55 12l-62-62q41-17 84-25.5t90-8.5q151 0 269 83.5T920-500q-23 59-60.5 109.5T772-302Zm20 246L624-222q-35 11-70.5 16.5T480-200q-151 0-269-83.5T40-500q21-53 53-98.5t73-81.5L56-792l56-56 736 736-56 56ZM222-624q-29 26-53 57t-41 67q50 101 143.5 160.5T480-280q20 0 39-2.5t39-5.5l-36-38q-11 3-21 4.5t-21 1.5q-75 0-127.5-52.5T300-500q0-11 1.5-21t4.5-21l-84-82Zm319 93Zm-151 75Z"/></svg>');
	content: '';
}
[data-form="password-revealer"].revealed:before {
	background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="%236C757D"><path d="M480-320q75 0 127.5-52.5T660-500q0-75-52.5-127.5T480-680q-75 0-127.5 52.5T300-500q0 75 52.5 127.5T480-320Zm0-72q-45 0-76.5-31.5T372-500q0-45 31.5-76.5T480-608q45 0 76.5 31.5T588-500q0 45-31.5 76.5T480-392Zm0 192q-146 0-266-81.5T40-500q54-137 174-218.5T480-800q146 0 266 81.5T920-500q-54 137-174 218.5T480-200Zm0-300Zm0 220q113 0 207.5-59.5T832-500q-50-101-144.5-160.5T480-720q-113 0-207.5 59.5T128-500q50 101 144.5 160.5T480-280Z"/></svg>');
}

/* Conteúdo exclusivo */
.exclusive-wrap {
	margin-top: 54px;
}
.exclusive-title {
	font-weight: 900;
	text-transform: uppercase;
	text-align: center;
	letter-spacing: .5px;
	margin-bottom: 18px;
	color: #0e7001;
}
.exclusive-outer {
	background: #ffffff;
	border-radius: 26px;
	padding: 22px;
	box-shadow: 0 0 0 2px rgba(255, 255, 255, .04) inset;
}
.exclusive-inner {
	background: #ffffff;
	border-radius: 18px;
	padding: 18px;
	box-shadow: 0 0 0 1px rgba(0, 0, 0, .08) inset;
}
.news-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 22px;
}
.news {
	display: grid;
	grid-template-columns: 120px 1fr;
	gap: 14px;
	align-items: start;
	transition: transform ease 180ms;
}
.news:hover {
	transform: scale(1.01);
}
.news img {
	width: 120px;
	height: 96px;
	object-fit: cover;
	border-radius: 10px;
}
.news h3 {
	margin: 0 0 6px;
	font-size: 16px;
	font-weight: 800;
	color: #0b0b0b;
}
.news p {
	margin: 0;
	font-size: 14px;
	color: #374151;
}
.readmore {
	grid-column: 2/span 1;
	text-align: right;
	margin-top: 6px;
	font-weight: 700;
	color: #0b0b0b;
}
.readmore span {
	opacity: .85;
}

/* Seleção de Newsletter */
.nl-wrap {
	margin-top: 64px;
}

.nl-title {
	font-weight: 900;
	text-transform: uppercase;
	text-align: center;
	letter-spacing: .5px;
	margin-bottom: 22px;
}

.nl-carousel {
	position: relative;
}

.nl-rail {
	display: grid;
	gap: 22px;
	padding: 0 8px;
}

.nl-rail::-webkit-scrollbar {
	width: 8px;
	background: #191919;
}

.nl-rail::-webkit-scrollbar-thumb {
	background: #3a3a3a;
	border-radius: 8px;
}

.nl-arrow {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .08);
	border: 1px solid rgba(255, 255, 255, .15);
	display: grid;
	place-items: center;
	cursor: pointer;
	user-select: none;
	z-index: 2;
}

.nl-arrow svg {
	width: 26px;
	height: 26px;
	color: #00ff6a;
}

.nl-arrow.up {
	top: -28px;
}

.nl-arrow.down {
	bottom: -28px;
}

.nl-list {
	display: grid;
	gap: 22px;
}

.nl-card {
	background: #fff;
	border-radius: 26px;
	padding: 18px 22px;
	scroll-snap-align: start;
}

.nl-row {
	display: grid;
	grid-template-columns: 220px 1px 1fr 84px;
	align-items: center;
	gap: 18px;
}

.nl-logo {
	display: flex;
	align-items: center;
	gap: 14px;
	margin: auto;
}

.nl-logo img {
	max-height: 64px;
	max-width: 100%;
	width: auto;
	display: block;
}

.nl-vl {
	width: 1px;
	height: 66px;
	background: #e5e7eb;
}

.nl-desc {
	color: #1f2937;
	font-size: 18px;
	font-weight: 600;
}

.nl-cta {
	display: flex;
	justify-content: flex-end;
}

.nl-check {
	position: relative;
	width: 56px;
	height: 56px;
}

.nl-check input {
	opacity: 0;
	position: absolute;
	inset: 0;
	cursor: pointer;
}

.nl-box {
	position: absolute;
	inset: 0;
	border-radius: 14px;
	border: 2px solid #d1d5db;
	background: #fff;
	display: grid;
	place-items: center;
	transition: .2s ease;
}

.nl-box::after {
	content: "";
	width: 18px;
	height: 18px;
	border-radius: 50%;
	background: #070;
	transform: scale(0);
	transition: .2s ease;
}

.nl-check input:checked+.nl-box {
	border-color: #070;
	box-shadow: 0 0 0 4px rgba(0, 255, 0, .15) inset;
}

.nl-check input:checked+.nl-box::after {
	transform: scale(1);
}

/* Footer */
.site-footer {
	background: #0a0a0a;
	border-top: 1px solid #1f2937;
	color: #cbd5e1;
	margin-top: 28px;
}

.site-footer .inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 28px 24px;
}

.footer-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	margin-bottom: 22px;
}

.footer-brand {
	display: flex;
	align-items: center;
	gap: 12px;
}

.footer-brand img {
	max-height: 36px;
	width: auto;
	display: block;
}

.footer-tag {
	color: #94a3b8;
	font-size: 14px;
}

.site-footer .grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 22px;
}

.site-footer h4 {
	margin: 0 0 10px;
	font-size: 13px;
	color: #e5e7eb;
	text-transform: uppercase;
	letter-spacing: .6px;
}

.site-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 8px;
}

.site-footer a {
	color: #a3b2c8;
	text-decoration: none;
	font-size: 14px;
}

.site-footer a:hover,
.site-footer a:focus {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.footer-social {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 8px;
}

.footer-social a {
	display: inline-flex;
	width: 36px;
	height: 36px;
	border-radius: 10px;
	align-items: center;
	justify-content: center;
	background: #141414;
	border: 1px solid #1f2937;
	color: #cbd5e1;
}

.footer-social a:hover {
	background: #1a1a1a;
	color: #070;
}

.site-footer .bottom {
	border-top: 1px solid #1f2937;
	margin-top: 22px;
	padding-top: 14px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	align-items: center;
	justify-content: space-between;
	font-size: 13px;
	color: #94a3b8;
}

.footer-legal {
	display: flex;
	gap: 14px;
}

.footer-legal a {
	color: #94a3b8;
	text-decoration: none;
}

.footer-legal a:hover {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.footer-row {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 14px;
	margin: 10px 0;
}

.footer-logo img {
	max-height: 40px;
	width: auto;
	display: block;
}

.footer-links ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 18px;
	flex-wrap: wrap;
}

.footer-links a {
	color: #a3b2c8;
	text-decoration: none;
	font-size: 14px;
}

.footer-links a:hover,
.footer-links a:focus {
	color: #ffffff;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.footer-copy {
	font-size: 13px;
	color: #94a3b8;
	text-align: center;
	margin-top: 8px;
}
@media (max-width: 540px) {
    .site-footer .grid { grid-template-columns: 1fr; }
    .footer-legal { flex-wrap: wrap; }
    .footer-links ul { gap: 12px; }
    .footer-social a { width: 32px; height: 32px; }
}
@media (max-width: 768px) {
    .site-footer .grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 992px) {
	.site-footer .inner { padding: 28px 18px; }
	.footer-head { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* Cart Widget */
#storeCartButton {display: none;}
body[data-slug=store] #storeCartButton {display: block;}
#storeCartButton.has-items {display: block;}

#storeCartBar:not([data-store-has-items="no"]) [data-store="if-has-no-items"] {display: none;}
#storeCartBar:not([data-store-has-items="yes"]) [data-store="if-has-items"] {display: none;}
#storeCartBar[data-items="0"] {display: none;}
#storeCartBar [data-cart-widget="cart-items"] li:last-child { border-bottom-color: transparent!important; }
#storeCartBar:not([data-store-has-prime-offer="yes"]) [data-store="prime-offer"] {display: none;}
#storeCartBar:not([data-store-has-discount="yes"]) [data-store="if-discount"] {display: none;}
#storeCartBar .cart-item { cursor: pointer; }
#storeCartBar .cart-item .product-name {
	text-overflow: ellipsis;
	overflow: hidden;
	white-space: nowrap;
	flex: 1;
	min-width: 0;
}
#storeCartBar .cart-item .cart-badge {
	margin-top: 2px;
	margin-bottom: 2px;
	background-color: rgba(88, 0, 122, .85);
	color: #fff;
	border: 0;	
}
#storeCartBar .cart-item .cart-image {
	width: 112px;
	height: 72px;
	object-fit: cover;
	border-radius: 8px;
	border: 1px solid var(--stroke);
}	
#storeCartBar .cart-item:not([data-store-is-subscription=yes]) [data-store=cart-item-every] {display: none;}
#storeCartBar .cart-item:not([data-store-has-was-now=yes]) [data-store=if-was-now] {display: none;}
