body {
	font-family: 'Inter', sans-serif;
	font-weight: 400;
	color: #666;
	font-size: 12px;
	line-height: 20px;
	width: 100%;
}

.inter-<uniquifier> {
	font-family: "Inter", sans-serif;
	font-optical-sizing: auto;
	font-weight: <weight>;
	font-style: normal;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: #798691;
}

/* default font size */
.fa {
	font-size: 14px;
}

/* Override the bootstrap defaults */
h1 {
	font-size: 33px;
}

h2 {
	font-size: 27px;
}

h3 {
	font-size: 18px;
}

h4 {
	font-size: 15px;
}

h5 {
	font-size: 12px;
}

h6 {
	font-size: 10.2px;
}

a {
	color: #0099ff;
}

a:hover {
	text-decoration: none;
}

legend {
	font-size: 18px;
	padding: 7px 0px
}

label {
	font-size: 12px;
	font-weight: normal;
}

/* MODERNIZAÇÃO: Inputs e Selects estilo App */
select.form-control,
textarea.form-control,
input[type="text"].form-control,
input[type="password"].form-control,
input[type="datetime"].form-control,
input[type="datetime-local"].form-control,
input[type="date"].form-control,
input[type="month"].form-control,
input[type="time"].form-control,
input[type="week"].form-control,
input[type="number"].form-control,
input[type="email"].form-control,
input[type="url"].form-control,
input[type="search"].form-control,
input[type="tel"].form-control,
input[type="color"].form-control {
	font-size: 13px;
	height: 44px;
	/* Altura confortável */
	border-radius: 8px;
	/* Cantos arredondados */
	background-color: #f9f9f9;
	border: 1px solid #e0e0e0;
	box-shadow: none;
	padding: 10px 15px;
	color: #555;
	transition: all 0.2s;
}

.form-control:focus {
	background-color: #fff;
	border-color: #3498db;
	box-shadow: 0 0 0 3px rgba(52, 152, 219, 0.1);
}

.input-group input,
.input-group select,
.input-group .dropdown-menu,
.input-group .popover {
	font-size: 12px;
}

/* AJUSTE FINO: Barra de Busca Estilo App (Input + Botão Integrados) */
.input-group .input-group-addon {
	font-size: 12px;
	height: 30px;
	background: #eee;
	border: 1px solid #e0e0e0;
	border-radius: 8px 0 0 8px;
}

/* Arredondamento do Input quando dentro de grupo (Search Header) */
.input-group .form-control:first-child,
#search .input-lg {
	border-top-right-radius: 0 !important;
	border-bottom-right-radius: 0 !important;
	border-top-left-radius: 8px !important;
	border-bottom-left-radius: 8px !important;
}

/* Arredondamento do Botão quando dentro de grupo (Search Header) */
.input-group-addon:last-child,
.input-group-btn:last-child>.btn,
.input-group-btn:last-child>.btn-group>.btn,
.input-group-btn:last-child>.dropdown-toggle,
.input-group-btn:first-child>.btn:not(:first-child),
.input-group-btn:first-child>.btn-group:not(:first-child)>.btn {
	border-top-left-radius: 0 !important;
	border-bottom-left-radius: 0 !important;
	border-top-right-radius: 8px !important;
	border-bottom-right-radius: 8px !important;
}

/* Fix some bootstrap issues */
span.hidden-xs,
span.hidden-sm,
span.hidden-md,
span.hidden-lg {
	display: inline;
}

.nav-tabs {
	margin-bottom: 15px;
}

div.required .control-label:before {
	content: '* ';
	color: #F00;
	font-weight: bold;
}

/* Gradent to all drop down menus */
.dropdown-menu li>a:hover {
	text-decoration: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

/* top */
#top {
	background-color: #EEEEEE;
	border-bottom: 1px solid #e2e2e2;
	padding: 4px 0px 3px 0;
	margin: 0 0 20px 0;
	min-height: 40px;
}

#top .container {
	padding: 0 20px;
}

#top #form-currency .currency-select,
#top #form-language .language-select {
	text-align: left;
}

#top #form-currency .currency-select:hover,
#top #form-language .language-select:hover {
	text-shadow: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

#top .btn-link,
#top-links li,
#top-links a {
	color: #888;
	text-shadow: 0 1px 0 #FFF;
	text-decoration: none;
}

#top .btn-link:hover,
#top-links a:hover {
	color: #444;
}

#top-links .dropdown-menu a {
	text-shadow: none;
}

#top-links .dropdown-menu a:hover {
	color: #FFF;
}

#top .btn-link strong {
	font-size: 14px;
	line-height: 14px;
}

#top-links {
	padding-top: 6px;
}

#top-links a+a {
	margin-left: 15px;
}

/* logo */
#logo {
	margin: 0 0 10px 0;
	width: 80px;
}

/* search */
#search {
	margin-bottom: 10px;
}

#search .input-lg {
	height: 40px;
	line-height: 20px;
	padding: 0 10px;
}

/* MUDANÇA: Botão de Busca do Header Modernizado */
#search .btn-lg {
	font-size: 15px;
	line-height: 18px;
	padding: 10px 35px;
	text-shadow: none;
	height: 44px;
	/* Mesma altura do input modernizado */
	/* Bordas controladas pelo grupo input-group acima */
}

/* cart */
#cart {
	margin-bottom: 10px;
}

#cart>.btn {
	font-size: 12px;
	line-height: 18px;
	color: #FFF;
}

#cart.open>.btn {
	background-image: none;
	background-color: #FFFFFF;
	border: 1px solid #E6E6E6;
	color: #666;
	box-shadow: none;
	text-shadow: none;
}

#cart.open>.btn:hover {
	color: #444;
}

#cart .dropdown-menu {
	background: #eee;
	z-index: 1001;
}

#cart .dropdown-menu {
	min-width: 100%;
	overflow-y: auto;
	max-height: 800px;
	scrollbar-width: thin;
	overflow-x: hidden;
}

@media (max-width: 478px) {
	#cart .dropdown-menu {
		width: 100%;
	}
}

#cart .dropdown-menu table {
	margin-bottom: 10px;
}

#cart .dropdown-menu li>div {
	min-width: 427px;
	padding: 0 10px;
}

@media (max-width: 478px) {
	#cart .dropdown-menu li>div {
		min-width: 100%;
	}
}

#cart .dropdown-menu li p {
	margin: 20px 0;
}

/* menu */
#menu {
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
	min-height: 40px;
}

#menu .nav>li>a {
	color: #fff;
	text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25);
	padding: 10px 15px 10px 15px;
	min-height: 15px;
	background-color: transparent;
}

#menu .nav>li>a:hover,
#menu .nav>li.open>a {
	background-color: rgba(0, 0, 0, 0.1);
}

#menu .dropdown-menu {
	padding-bottom: 0;
}

#menu .dropdown-inner {
	display: table;
}

#menu .dropdown-inner ul {
	display: table-cell;
}

#menu .dropdown-inner a {
	min-width: 160px;
	display: block;
	padding: 3px 20px;
	clear: both;
	line-height: 20px;
	color: #333333;
	font-size: 12px;
}

#menu .dropdown-inner li a:hover {
	color: #FFFFFF;
}

#menu .see-all {
	display: block;
	margin-top: 0.5em;
	border-top: 1px solid #DDD;
	padding: 3px 20px;
	-webkit-border-radius: 0 0 4px 4px;
	-moz-border-radius: 0 0 4px 4px;
	border-radius: 0 0 3px 3px;
	font-size: 12px;
}

#menu .see-all:hover,
#menu .see-all:focus {
	text-decoration: none;
	color: #ffffff;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
}

#menu #category {
	float: left;
	padding-left: 15px;
	font-size: 16px;
	font-weight: 700;
	line-height: 40px;
	color: #fff;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.2);
}

#menu .btn-navbar {
	font-size: 15px;
	font-stretch: expanded;
	color: #FFF;
	padding: 2px 18px;
	float: right;
	background-color: #229ac8;
	background-image: linear-gradient(to bottom, #23a1d1, #1f90bb);
	background-repeat: repeat-x;
	border-color: #1f90bb #1f90bb #145e7a;
}

#menu .btn-navbar:hover,
#menu .btn-navbar:focus,
#menu .btn-navbar:active,
#menu .btn-navbar.disabled,
#menu .btn-navbar[disabled] {
	color: #ffffff;
	background-color: #229ac8;
}

@media (min-width: 768px) {
	#menu .dropdown:hover .dropdown-menu {
		display: block;
	}
}

@media (max-width: 767px) {
	#menu {
		border-radius: 4px;
	}

	#menu div.dropdown-inner>ul.list-unstyled {
		display: block;
	}

	#menu div.dropdown-menu {
		margin-left: 0 !important;
		padding-bottom: 10px;
		background-color: rgba(0, 0, 0, 0.1);
	}

	#menu .dropdown-inner {
		display: block;
	}

	#menu .dropdown-inner a {
		width: 100%;
		color: #fff;
	}

	#menu .dropdown-menu a:hover,
	#menu .dropdown-menu ul li a:hover {
		background: rgba(0, 0, 0, 0.1);
	}

	#menu .see-all {
		margin-top: 0;
		border: none;
		border-radius: 0;
		color: #fff;
	}
}

/* content */
#content {
	min-height: 600px;
}

#product-category #content,
#product-product #tab-description,
#information-information #content {
	font-size: 16px;
	line-height: 26px;
	font-weight: 300;
}

/* footer */
footer {
	margin-top: 30px;
	padding-top: 30px;
	background-color: #021838;
	border-top: 1px solid #ddd;
	color: #e2e2e2;
}
footer hr {
	border-top: none;
	border-bottom: 1px solid #666;
}
footer a {
	color: #ccc;
}
footer a:hover {
	color: #fff;
}
footer h5 {
	font-family: 'Montserrat', sans-serif;
	font-size: 13px;
	font-weight: bold;
	color: #fff;
}

/* alert */
.alert {
	padding: 8px 14px 8px 14px;
}

/* =======================================================    BREADCRUMB MODERNO (Estilo App/Clean)   ======================================================= */
.breadcrumb {
	margin: 0 0 20px 0;
	padding: 10px 0;
	border: none;
	/* Remove borda antiga */
	background: transparent;
	/* Fundo transparente */
	display: flex;
	flex-wrap: nowrap;
	/* Impede quebra de linha */
	overflow-x: auto;
	/* Permite rolagem horizontal no mobile */
	-webkit-overflow-scrolling: touch;
	/* Rolagem suave no iOS */
	white-space: nowrap;
}

.breadcrumb i {
	font-size: 14px;
	color: #999;
}

.breadcrumb>li {
	text-shadow: none;
	padding: 0 5px;
	position: relative;
	white-space: nowrap;
	color: #888;
	font-size: 13px;
}

/* Remove setas antigas e bordas */
.breadcrumb>li+li:before {
	content: '/';
	/* Separador simples e moderno */
	padding: 0 8px;
	color: #ccc;
}

.breadcrumb>li:after {
	content: none;
	/* Remove seta CSS antiga */
	display: none;
}

.breadcrumb>li a {
	color: #555;
	text-decoration: none;
	transition: color 0.2s;
}

.breadcrumb>li a:hover {
	color: #3498db;
}

/* Item ativo (último) */
.breadcrumb>li:last-child {
	color: #333;
	font-weight: 600;
}

/* Ajuste RTL se necessário, mantendo simples */
html[dir=rtl] .breadcrumb>li::after {
	content: none;
}

.pagination {
	margin: 0;
}

/* buttons */
.buttons {
	margin: 1em 0;
}

/* MODERNIZAÇÃO: Botões estilo App */
.btn {
	padding: 8px 20px;
	font-size: 13px;
	border: none;
	border-radius: 8px;
	/* Padronizado 8px para consistência */
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
	text-transform: uppercase;
	font-weight: 600;
	letter-spacing: 0.5px;
	transition: all 0.2s;
}

.btn:active {
	box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.1);
}

.btn-xs {
	font-size: 9px;
	padding: 5px 10px;
}

.btn-sm {
	font-size: 10.2px;
}

.btn-lg {
	padding: 12px 24px;
	font-size: 15px;
}

.btn-group>.btn,
.btn-group>.dropdown-menu,
.btn-group>.popover {
	font-size: 12px;
}

.btn-group>.btn-xs {
	font-size: 9px;
}

.btn-group>.btn-sm {
	font-size: 10.2px;
}

.btn-group>.btn-lg {
	font-size: 15px;
}

.btn-default {
	color: #555;
	text-shadow: none;
	background-color: #fff;
	background-image: none;
	border: 1px solid #ddd;
}

.btn-primary {
	color: #ffffff;
	text-shadow: none;
	background-color: #0099ff;
	background-image: none;
	border: none;
	box-shadow: 0 4px 10px rgba(52, 152, 219, 0.3);
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary.active,
.btn-primary.disabled,
.btn-primary[disabled] {
	background-color: #2980b9;
	transform: translateY(-1px);
}

.btn-warning {
	color: #ffffff;
	text-shadow: none;
	background-color: #faa732;
	background-image: none;
	border: none;
}

.btn-warning:hover,
.btn-warning:active,
.btn-warning.active,
.btn-warning.disabled,
.btn-warning[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-danger {
	color: #ffffff;
	text-shadow: none;
	background-color: #da4f49;
	background-image: none;
	border: none;
}

.btn-danger:hover,
.btn-danger:active,
.btn-danger.active,
.btn-danger.disabled,
.btn-danger[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-success {
	color: #ffffff;
	text-shadow: none;
	background-color: #5bb75b;
	background-image: none;
	border: none;
}

.btn-success:hover,
.btn-success:active,
.btn-success.active,
.btn-success.disabled,
.btn-success[disabled] {
	box-shadow: inset 0 1000px 0 rgba(0, 0, 0, 0.1);
}

.btn-info {
	color: #ffffff;
	text-shadow: none;
	background-color: #19828d;
	background-image: none;
	border: none;
}

.btn-info:hover,
.btn-info:active,
.btn-info.active,
.btn-info.disabled,
.btn-info[disabled] {
	background-image: none;
	background-color: #df5c39;
}

.btn-link {
	border-color: rgba(0, 0, 0, 0);
	cursor: pointer;
	color: #23A1D1;
	border-radius: 0;
	box-shadow: none;
}

.btn-link,
.btn-link:active,
.btn-link[disabled] {
	background-color: rgba(0, 0, 0, 0);
	background-image: none;
	box-shadow: none;
}

.btn-inverse {
	color: #ffffff;
	text-shadow: none;
	background-color: #363636;
	background-image: none;
	border: none;
}

.btn-inverse:hover,
.btn-inverse:active,
.btn-inverse.active,
.btn-inverse.disabled,
.btn-inverse[disabled] {
	background-color: #222222;
	background-image: linear-gradient(to bottom, #333333, #111111);
}

/* list group */
.list-group a {
	border: 1px solid #DDDDDD;
	color: #888888;
	padding: 8px 12px;
}

.list-group a.active,
.list-group a.active:hover,
.list-group a:hover {
	color: #444444;
	background: #eeeeee;
	border: 1px solid #DDDDDD;
	text-shadow: 0 1px 0 #FFF;
}

/* carousel */
.carousel-caption {
	color: #FFFFFF;
	text-shadow: 0 1px 0 #000000;
}

.carousel-control .icon-prev:before {
	content: '\f053';
	font-family: FontAwesome;
}

.carousel-control .icon-next:before {
	content: '\f054';
	font-family: FontAwesome;
}

/* product list */
/* AJUSTE: Reduzir espaçamento lateral (gutter) entre produtos */
.product-layout {
	padding-left: 10px;
	padding-right: 10px;
	margin-top: 20px;
}

.product-thumb {
	border: 1px solid #ddd;
	margin-bottom: 20px;
	overflow: auto;
}

.product-thumb .image {
	text-align: center;
}

.product-thumb .image a {
	display: block;
}

.product-thumb .image a:hover {
	opacity: 0.8;
}

.product-thumb .image img {
	margin-left: auto;
	margin-right: auto;
}

.product-grid .product-thumb .image {
	float: none;
}

@media (min-width: 767px) {
	.product-list .product-thumb .image {
		float: left;
		padding: 0 15px;
	}
}

.product-thumb h4 {
	font-weight: bold;
}

.product-thumb .caption {
	padding: 0 20px;
	min-height: 180px;
}

.product-list .product-thumb .caption {
	margin-left: 230px;
}

@media (max-width: 1200px) {
	.product-grid .product-thumb .caption {
		min-height: 210px;
		padding: 0 10px;
	}
}

@media (max-width: 767px) {
	.product-list .product-thumb .caption {
		min-height: 0;
		margin-left: 0;
		padding: 0 10px;
	}

	.product-grid .product-thumb .caption {
		min-height: 0;
	}
}

.product-thumb .rating {
	padding-bottom: 10px;
}

.rating .fa-stack {
	font-size: 8px;
}

.rating .fa-star-o {
	color: #999;
	font-size: 15px;
}

.rating .fa-star {
	color: #FC0;
	font-size: 15px;
}

.rating .fa-star+.fa-star-o {
	color: #E69500;
}

h2.price {
	margin: 0;
}

.product-thumb .price {
	color: #444;
}

.product-thumb .price-new {
	font-weight: 600;
}

.product-thumb .price-old {
	color: #999;
	text-decoration: line-through;
	margin-left: 10px;
}

.product-thumb .price-tax {
	color: #999;
	font-size: 12px;
	display: block;
}

.product-thumb .button-group {
	border-top: 1px solid #ddd;
	background-color: #eee;
	overflow: auto;
}

.product-list .product-thumb .button-group {
	border-left: 1px solid #ddd;
}

@media (max-width: 768px) {
	.product-list .product-thumb .button-group {
		border-left: none;
	}
}

.product-thumb .button-group button {
	width: 60%;
	border: none;
	display: inline-block;
	float: left;
	background-color: #eee;
	color: #888;
	line-height: 38px;
	font-weight: bold;
	text-align: center;
	text-transform: uppercase;
}

.product-thumb .button-group button+button {
	width: 20%;
	border-left: 1px solid #ddd;
}

.product-thumb .button-group button:hover {
	color: #444;
	background-color: #ddd;
	text-decoration: none;
	cursor: pointer;
}

@media (max-width: 1200px) {

	.product-thumb .button-group button,
	.product-thumb .button-group button+button {
		width: 33.33%;
	}
}

@media (max-width: 767px) {

	.product-thumb .button-group button,
	.product-thumb .button-group button+button {
		width: 33.33%;
	}
}

.thumbnails {
	overflow: auto;
	clear: both;
	list-style: none;
	padding: 0;
	margin: 0;
}

.thumbnails>li {
	margin-left: 20px;
}

.thumbnails {
	margin-left: -20px;
}

.thumbnails>img {
	width: 100%;
}

.image-additional a {
	margin-bottom: 20px;
	padding: 5px;
	display: block;
	border: 1px solid #ddd;
}

.image-additional {
	max-width: 78px;
}

.thumbnails .image-additional {
	float: left;
	margin-left: 20px;
}

@media (min-width: 1200px) {

	#content .col-lg-2:nth-child(6n+1),
	#content .col-lg-3:nth-child(4n+1),
	#content .col-lg-4:nth-child(3n+1),
	#content .col-lg-6:nth-child(2n+1) {
		clear: left;
	}
}

@media (min-width: 992px) and (max-width: 1199px) {

	#content .col-md-2:nth-child(6n+1),
	#content .col-md-3:nth-child(4n+1),
	#content .col-md-4:nth-child(3n+1),
	#content .col-md-6:nth-child(2n+1) {
		clear: left;
	}
}

@media (min-width: 768px) and (max-width: 991px) {

	#content .col-sm-2:nth-child(6n+1),
	#content .col-sm-3:nth-child(4n+1),
	#content .col-sm-4:nth-child(3n+1),
	#content .col-sm-6:nth-child(2n+1) {
		clear: left;
	}
}

/* fixed colum left + content + right*/
@media (min-width: 768px) {
	#column-left .product-layout .col-md-3 {
		width: 100%;
	}

	#column-left+#content .product-layout .col-md-3 {
		width: 50%;
	}

	#column-left+#content+#column-right .product-layout .col-md-3 {
		width: 100%;
	}

	#content+#column-right .product-layout .col-md-3 {
		width: 100%;
	}
}

/* fixed product layouts used in left and right columns */
#column-left .product-layout,
#column-right .product-layout {
	width: 100%;
}

/* fixed mobile cart quantity input */
.input-group .form-control[name^=quantity] {
	min-width: 50px;
}

/* Missing focus and border color to overwrite bootstrap */
.btn-info:hover,
.btn-info:active,
.btn-info.active,
.btn-info.disabled,
.btn-info[disabled] {
	background-image: none;
	background-color: #df5c39;
}

html[dir=rtl] .checkbox input[type="checkbox"],
html[dir=rtl] .checkbox-inline input[type="checkbox"],
html[dir=rtl] .radio input[type="radio"],
html[dir=rtl] .radio-inline input[type="radio"] {
	position: absolute;
	margin-top: 4px\9;
	margin-right: -20px;
	margin-left: unset;
}

html[dir=rtl] .input-group-btn:last-child>.btn {
	border-top-right-radius: 0;
	border-bottom-right-radius: 0;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
}

html[dir=rtl] .input-group .form-control:first-child {
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	border-top-left-radius: unset;
	border-bottom-left-radius: unset;
}

html[dir=rtl] .container .row:first-child .col-sm-4,
html[dir=rtl] .container .row:first-child .col-sm-5 {
	float: right;
}

html[dir=rtl] #cart .dropdown-menu {
	left: 0;
	right: auto;
}

@media (min-width: 768px) {
	html[dir=rtl] .navbar-nav {
		float: right;
		margin: 0;
	}

	html[dir=rtl] .navbar-nav>li {
		float: right;
	}
}

/***********************************************/
/* =======================================================    PÁGINA DO PRODUTO (REFINAMENTO DE LAYOUT)   ======================================================= */
/* Estilo para ícones pequenos e quadrados com cantos arredondados */
.btn-icon-square-small {
	width: 36px;
	height: 36px;
	padding: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 8px !important;
	/* Cantos arredondados fixos */
	background: #fff;
	border: 1px solid #ddd;
	color: #666;
	margin-right: 5px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
	transition: all 0.2s;
}

.btn-icon-square-small:hover {
	background: #3498db;
	color: #fff;
	border-color: #3498db;
}

/* Título do produto */
.product-header-group-v2 h1 {
	font-size: 28px;
	font-weight: 800;
	margin-bottom: 10px;
	margin-top: 0;
}

/* Grupo de Meta Dados */
.product-meta-group {
	border-bottom: 1px solid #eee;
}

.meta-details {
	margin-top: 10px;
}

.meta-label {
	color: #999;
	font-weight: 600;
	margin-right: 5px;
}

/* Grupo de Preço - Aumentando o distanciamento inferior */
.product-price-group {
	margin-bottom: 10px !important;
	padding: 15px 0;
}

.price-main {
	font-size: 32px;
	font-weight: 800;
	color: #2c3e50;
	margin: 0;
}

.price-suffix {
	font-size: 14px;
	font-weight: 400;
	color: #999;
}

/* Botão Assinar em destaque */
.btn-add-cart {
	height: 54px;
	font-size: 16px;
	border-radius: 10px;
	box-shadow: 0 6px 20px rgba(52, 152, 219, 0.4);
}

/* Miniaturas redondas na galeria */
.app-thumbnails .thumbnail {
	border-radius: 12px;
	border: 1px solid #eee;
	padding: 5px;
}

/***********************************************/
/* =======================================================    CARD DE PRODUTO PERSONALIZADO (DESTACADO)   ======================================================= */
/* O Card Principal - Estilo App: Mais arredondado e sombra difusa */
.product-card-modern {
	border: none !important;
	margin-bottom: 20px;
	/* Alterado de 30px para 20px */
	background: #fff;
	border-radius: 16px;
	/* MUDANÇA: Sombra mais escura e difusa para destaque no fundo branco */
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.20);
	overflow: hidden;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
	border: 1px solid #eee;
	/* Borda sutil */
}

.product-card-modern:hover {
	transform: translateY(-5px);
	box-shadow: 0 15px 40px rgba(0, 0, 0, 0.20);
	border-color: transparent;
}

/* Área da Imagem (Posição Relativa para segurar os ícones) */
.product-card-modern .image {
	padding: 0;
	text-align: center;
	background: #fff;
	position: relative;
	/* Essencial para os ícones funcionarem */
	overflow: hidden;
	width: 100%;
	/* Garantir que o container ocupe tudo */
}

.product-card-modern .image img {
	margin: 0;
	/* Remove margens automáticas */
	width: 100%;
	/* Força a largura total */
	max-width: 100%;
	display: block;
	/* Remove espaços em branco inferiores de elementos inline */
}

/* ÍCONES FLUTUANTES (Sobre a Imagem) - Ajuste Fino */
.product-card-modern .image-icons-overlay {
	position: absolute;
	bottom: 12px;
	right: 12px;
	display: flex;
	gap: 8px;
	z-index: 10;
}

.product-card-modern .btn-icon-square {
	background: rgba(255, 255, 255, 0.95);
	/* Leve transparência */
	color: #3498db;
	border: none;
	/* Remove borda para ficar mais clean */
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
	/* Sombra no botão flutuante */
	border-radius: 8px;
	width: 35px;
	height: 35px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s;
	padding: 0;
	cursor: pointer;
}

.product-card-modern .btn-icon-square:hover {
	background: #3498db;
	color: #fff;
}

.product-card-modern .btn-icon-square i {
	font-size: 14px;
}

/* Legenda / Textos */
/* CORREÇÃO: Remove altura mínima forçada para tirar espaço branco excessivo */
/* Reforçado com seletor específico .product-grid .product-thumb... para vencer o padrão do tema */
.product-card-modern .caption,
.product-grid .product-thumb.product-card-modern .caption {
	padding: 5px 5px 10px;
	/* Reduzido padding para diminuir espaço */
	text-align: center;
	flex-grow: 0;
	display: flex;
	flex-direction: column;
	min-height: auto !important;
	/* Reforço para resetar altura mínima */
	height: auto !important;
}

/* MUDANÇA: Título com limite de linhas (Estilo App Grid) */
.product-card-modern h4 {
	margin: 0 0 5px 0;
	min-height: 38px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.product-card-modern h4 a {
	color: #333 !important;
	font-size: 15px;
	font-weight: 700;
	text-decoration: none;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.3;
}

.product-card-modern h4 a:hover {
	color: #3498db !important;
}

/* Preço */
.product-card-modern .price {
	font-size: 18px;
	font-weight: 800;
	/* Mais pesado */
	color: #333;
	margin-top: 0;
	margin-bottom: 0;
	letter-spacing: -0.5px;
	/* Estilo moderno */
}

.product-card-modern .price-new {
	color: #2c69f1;
}

.product-card-modern .price-old {
	font-size: 13px;
	color: #e74c3c;
	text-decoration: line-through;
	margin-right: 5px;
}

.product-card-modern .price-tax {
	display: none;
}

/* Avaliação */
.product-card-modern .rating {
	margin-bottom: 5px;
}

/* Margem reduzida de 8px */
.product-card-modern .rating .fa-star {
	color: #f1c40f;
}

.product-card-modern .rating .fa-star-o {
	color: #ccc;
}

/* Botão "DETALHES" - Estilo Pill (Pílula) dentro do Card */
.product-card-modern .button-group {
	background: #fff;
	border: none;
	padding: 0 15px 15px 15px;
}

.product-card-modern .btn-details-full {
	display: block;
	width: 100%;
	background: #0099ff;
	color: #fff;
	text-align: center;
	padding: 10px 0;
	border-radius: 8px;
	/* Formato Pílula */
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
	font-size: 12px;
	transition: all 0.3s;
	border: none;
	letter-spacing: 0.5px;
	box-shadow: 0 4px 10px rgba(52, 152, 219, 0.25);
	/* Sombra no botão de ação principal */
}

.product-card-modern .btn-details-full:hover {
	background: #2980b9;
	color: #fff;
	text-decoration: none;
	transform: translateY(-2px);
	box-shadow: 0 6px 15px rgba(52, 152, 219, 0.35);
}

/* =======================================================    CARRINHO DE COMPRAS (APP LIKE)   ======================================================= */
/* Tabela Base Clean */
.table-app-like {
	border: none;
}

.table-app-like td,
.table-app-like th {
	border: none;
	vertical-align: middle !important;
}

.table-app-like thead td {
	background: #f8f9fa;
	color: #95a5a6;
	font-weight: 600;
	text-transform: uppercase;
	font-size: 11px;
	border-bottom: 1px solid #eee;
	padding: 15px;
}

.table-app-like tbody td {
	padding: 15px;
	border-bottom: 1px solid #f1f1f1;
}

/* Imagem do Produto no Carrinho */
.table-app-like .img-thumbnail {
	border: none;
	padding: 0;
	border-radius: 8px;
	max-width: 60px;
}

/* Input Group de Quantidade */
.cart-qty-group {
	display: flex;
	align-items: center;
	max-width: 120px;
}

.cart-qty-group .form-control {
	text-align: center;
	border-radius: 8px 0 0 8px !important;
	height: 36px;
	border-color: #eee;
	background: #fff;
	box-shadow: none;
}

.cart-qty-group .input-group-btn {
	display: flex;
}

.cart-qty-group .btn {
	height: 36px;
	padding: 0 10px;
	border-color: #eee;
	display: flex;
	align-items: center;
	justify-content: center;
}

.cart-qty-group .btn-primary {
	border-radius: 0;
	background: #f8f9fa;
	color: #3498db;
	border: 1px solid #eee;
	border-left: none;
	box-shadow: none;
}

.cart-qty-group .btn-danger {
	border-radius: 0 8px 8px 0;
	background: #fff0f0;
	color: #e74c3c;
	border: 1px solid #eee;
	border-left: none;
	box-shadow: none;
}

/* NOVA CLASSE: Estilo para quantidade fixa (Assinatura) */
.cart-qty-static-wrapper {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	/* Desktop */
	gap: 15px;
}

.qty-display {
	font-weight: 700;
	color: #333;
	background: #f5f5f5;
	padding: 6px 12px;
	border-radius: 6px;
	font-size: 13px;
	border: 1px solid #eee;
}

.cart-qty-static-wrapper .btn {
	padding: 6px 10px;
	border-radius: 6px;
}

/* Cartões de Totais */
.cart-totals-modern {
	background: #fff;
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
	padding: 20px;
	border: 1px solid #f2f2f2;
}

.cart-totals-modern table {
	width: 100%;
	margin: 0;
}

.cart-totals-modern td {
	padding: 10px 0;
	border: none;
	color: #555;
}

.cart-totals-modern td strong {
	color: #2c3e50;
}

.cart-totals-modern tr:last-child td {
	font-size: 18px;
	font-weight: 800;
	color: #2c3e50;
	border-top: 1px solid #eee;
	padding-top: 15px;
	margin-top: 5px;
}

/* Botões de Ação */
.cart-actions-modern {
	margin-top: 20px;
}

.cart-actions-modern .btn {
	border-radius: 8px;
	padding: 12px 25px;
	font-weight: 700;
	text-transform: uppercase;
	font-size: 13px;
}

/* RESPONSIVIDADE MOBILE (CARD VIEW) */
@media (max-width: 767px) {
	.table-app-like thead {
		display: none;
	}

	.table-app-like tbody,
	.table-app-like tr,
	.table-app-like td {
		display: block;
		width: 100%;
	}

	.table-app-like tr {
		background: #fff;
		border-radius: 12px;
		box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
		margin-bottom: 15px;
		padding: 15px;
		border: 1px solid #f5f5f5;
		position: relative;
	}

	.table-app-like td {
		padding: 5px 0;
		text-align: left !important;
		border: none;
	}

	/* Layout do Card Mobile */
	.table-app-like td:first-child {
		/* Image */
		float: left;
		width: 70px;
		margin-right: 15px;
		margin-bottom: 10px;
	}

	.table-app-like td:first-child img {
		width: 60px;
		height: 60px;
		object-fit: cover;
	}

	.table-app-like td:nth-child(2) {
		/* Name */
		font-weight: 700;
		font-size: 14px;
		color: #2c3e50;
		margin-bottom: 5px;
		padding-top: 0;
		min-height: 60px;
		/* Alinha com a imagem */
	}

	.table-app-like td:nth-child(3) {
		/* Model - Hide on mobile */
		display: none;
	}

	.table-app-like td:nth-child(4) {
		/* Quantity Input or Static */
		clear: both;
		margin-top: 10px;
		border-top: 1px solid #f9f9f9;
		padding-top: 10px;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	/* Ajuste para quantidade estática no mobile */
	.table-app-like td:nth-child(4) .cart-qty-static-wrapper {
		justify-content: flex-end;
		/* Alinha à direita no card */
		width: 100%;
	}

	/* Label for quantity on mobile */
	.table-app-like td:nth-child(4):before {
		content: 'Qtd:';
		font-size: 12px;
		color: #999;
		margin-right: 10px;
	}

	.table-app-like td:nth-child(5) {
		/* Unit Price - Hide or Styling */
		display: none;
	}

	.table-app-like td:nth-child(6) {
		/* Total */
		position: absolute;
		top: 15px;
		right: 15px;
		text-align: right !important;
		font-weight: 800;
		color: #3498db;
		font-size: 15px;
		width: auto;
		padding: 0;
	}

	/* MODIFICAÇÃO: Botão Fixo (Standard) em vez de Flutuante */
	.cart-actions-modern {
		position: relative;
		/* Mudado de fixed para relative */
		bottom: auto;
		left: auto;
		width: 100%;
		background: transparent;
		/* Removido fundo branco do flutuante */
		padding: 0;
		/* Removido padding do container flutuante */
		box-shadow: none;
		/* Removido sombra superior */
		display: flex;
		flex-direction: column;
		/* Botões empilhados no mobile */
		gap: 10px;
		margin-top: 30px;
		/* Espaço após os totais */
	}

	.cart-actions-modern .pull-left,
	.cart-actions-modern .pull-right {
		width: 100%;
		display: block;
		float: none !important;
		/* Força quebra de float */
	}

	.cart-actions-modern .btn {
		width: 100%;
		display: block;
		padding: 15px;
		/* Botões maiores no mobile */
	}

	/* Reset padding do footer */
	footer {
		padding-bottom: 40px;
	}
}

/* =======================================================    AJUSTES GLOBAIS PARA MOBILE (PRODUTOS EM GRADE)   ======================================================= */
@media (max-width: 767px) {

	/* Aumentar fonte global do corpo no mobile */
	body {
		font-size: 16px;
		font-weight: 300;
	}
	.product-layout.col-xs-12 {
		width: 50% !important;
		float: left;
	}
	.product-thumb {
		height: auto;
		/*min-height: 350px;*/
	}
	/* Limpa o fluxo a cada 2 itens */
	.product-layout:nth-child(2n+1) {
		clear: left;
	}

	.product-thumb .caption p,
	.product-card-modern .caption p,
	#content .product-layout .caption p,
	.product-thumb .caption .description,
	#tab-description p {
		font-size: 16px !important;
		line-height: 1.6 !important;
		color: #444 !important;
		margin-top: 10px;
	}
	.product-thumb h4,
	.product-card-modern h4 a {
		font-size: 16px !important;
	}
}

.alert-dismissable .close,
.alert-dismissible .close {
	right: 0px !important;
}

.btn-block {
	display: block;
}

.layout1 {
	font-size: 16px;
	line-height: 26px;
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.20);
	padding: 20px;
	border-radius: 20px;
}

.blogs_post {
	border-radius: 10px;
	padding: 20px;
	margin: 20px -7px;
	box-shadow: 0 5px 20px rgba(0, 0, 0, 0.20);
}

/*#post_ex1 {    border: 1px solid #abb6ff;    border-radius: 10px;    margin: 0px;    margin-top: 20px;}*/
.post_date_blog {
	margin: 15px 0px 0px;
	font-size: 14px;
}

.price-old {
	font-size: 19px;
	color: #e74c3c;
	text-decoration: line-through;
	font-weight: 500;
}

#tto-1 {
	margin: 40px 10px 0px;
	color: #337ab7;
}

.row.layout3 {
	margin: -7px;
	margin-top: 30px;
}

#tto_card {
	font-size: 16px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	line-height: 1.25;
}

.layout1 h1,
.layout2 h3,
.layout3 h3 {
	text-transform: capitalize;
}

h3 {
	line-height: 1.35;
}

/* CAIXA NEWSLETTER --- Estilo Padrão / Clássico (Flat Design) --- */
.app-newsletter-container {
	background: #f8f9fa;
	border: 1px solid #5e5e5e;
	border-radius: 10px;
	padding: 20px;
	margin: 20px 10px;
	text-align: left;
}

.app-newsletter-title {
	font-size: 16px;
	font-weight: 700;
	color: #222;
	text-transform: uppercase;
	margin-top: 0;
	margin-bottom: 8px;
	letter-spacing: 0.5px;
}

.app-newsletter-text {
	color: #666;
	font-size: 13px;
	margin-bottom: 15px;
	line-height: 1.5;
	display: block;
}

/* Input Clássico */
.app-newsletter-input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #ced4da;
	border-radius: 4px;
	background-color: #fff;
	font-size: 14px;
	color: #495057;
	box-shadow: none;
	height: 42px;
	box-sizing: border-box;
}

.app-newsletter-input:focus {
	border-color: #80bdff;
	outline: 0;
	box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* Botão Clássico */
.app-newsletter-btn {
	width: 100%;
	margin-top: 10px;
	padding: 0 20px;
	height: 42px;
	border-radius: 10px;
	border: none;
	background: #0099ff;
	color: white;
	font-weight: 600;
	font-size: 14px;
	cursor: pointer;
	text-transform: uppercase;
	transition: background-color 0.2s;
	box-shadow: none;
}

.app-newsletter-btn:hover {
	background: #337ab7;
	transform: none;
}

/* Mensagens de Erro/Sucesso */
#text-danger-newsletter {
	margin-top: 10px;
	font-size: 12px;
	color: #dc3545;
}

#column-right .app-newsletter-container {
	margin: 20px 0px;
}

/* --- Comportamento Responsivo (Sidebar vs Full Width) --- */
/* A lógica aqui é: Mobile First (tudo empilhado).   Apenas se a tela for grande E houver espaço suficiente, colocamos lado a lado.*/
@media (min-width: 992px) {

	.app-newsletter-form-group {
		display: flex;
		flex-wrap: wrap;
		gap: 10px;
		align-items: center;
	}

	.app-newsletter-input {
		flex: 1 1 200px;
		margin-bottom: 0;
	}

	.app-newsletter-btn {
		margin-top: 0;
		flex: 0 1 auto;
		width: auto;
		min-width: 120px;
	}
}

/* Correção para sobreposição de texto no carrinho mobile */
@media (max-width: 767px) {

	.table-responsive .table td.text-left {
		white-space: normal !important;
		max-width: 150px;
		overflow-wrap: break-word;
	}

	.table-responsive .table td.text-left a {
		font-size: 13px;
		display: inline-block;
	}
}


/*Códigos*/

.price-new {margin-top: 10px;color: #337ab7;}